{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "MVcoFFI_bCi9"
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import os\n",
    "import pandas as pd\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from math import sqrt\n",
    "\n",
    "from utils.plot_utils import *\n",
    "plt.rcParams['figure.figsize'] = [12, 8]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "CbVlFmv-bOZl"
   },
   "outputs": [],
   "source": [
    "result_dir = \"res/models\" # here are the results\n",
    "plot_dir = \"plots\" # her go the plots\n",
    "latex = True # using latex?\n",
    "\n",
    "if not os.path.exists(plot_dir):\n",
    "    os.makedirs(plot_dir)\n",
    "\n",
    "if latex:\n",
    "  latexify()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "u7EHrQrA2rtX",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Import the available results from ```result_dir```"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 206
    },
    "id": "OPrx8ZOhbCji",
    "outputId": "1d09dd4b-ac4e-4fa3-f185-abf6ed5656b3",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>m</th>\n",
       "      <th>s</th>\n",
       "      <th>k</th>\n",
       "      <th>noise</th>\n",
       "      <th>n</th>\n",
       "      <th>db</th>\n",
       "      <th>dir</th>\n",
       "      <th>hist</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>AGLISTA</td>\n",
       "      <td>250</td>\n",
       "      <td>50</td>\n",
       "      <td>8</td>\n",
       "      <td>GaussianNoise40</td>\n",
       "      <td>2000</td>\n",
       "      <td>-15.923502</td>\n",
       "      <td>model=AGLISTA__m=250__s=50__k=8__noise=Gaussia...</td>\n",
       "      <td>0     -11.251444\n",
       "1     -12.345246\n",
       "2     -13.05...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NA_ALISTA_UR_16</td>\n",
       "      <td>250</td>\n",
       "      <td>50</td>\n",
       "      <td>16</td>\n",
       "      <td>GaussianNoise40</td>\n",
       "      <td>1000</td>\n",
       "      <td>-36.761836</td>\n",
       "      <td>model=NA_ALISTA_UR_16__m=250__s=50__k=16__nois...</td>\n",
       "      <td>0     -32.247113\n",
       "1     -32.391178\n",
       "2     -32.47...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>AGLISTA</td>\n",
       "      <td>250</td>\n",
       "      <td>50</td>\n",
       "      <td>16</td>\n",
       "      <td>GaussianNoise40</td>\n",
       "      <td>2000</td>\n",
       "      <td>-25.607043</td>\n",
       "      <td>model=AGLISTA__m=250__s=50__k=16__noise=Gaussi...</td>\n",
       "      <td>0     -11.719982\n",
       "1     -13.957159\n",
       "2     -15.48...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>ALISTA_AT</td>\n",
       "      <td>250</td>\n",
       "      <td>50</td>\n",
       "      <td>12</td>\n",
       "      <td>GaussianNoise40</td>\n",
       "      <td>1000</td>\n",
       "      <td>-30.788237</td>\n",
       "      <td>model=ALISTA_AT__m=250__s=50__k=12__noise=Gaus...</td>\n",
       "      <td>0     -18.601399\n",
       "1     -19.314646\n",
       "2     -19.77...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>AGLISTA</td>\n",
       "      <td>250</td>\n",
       "      <td>50</td>\n",
       "      <td>2</td>\n",
       "      <td>GaussianNoise40</td>\n",
       "      <td>500</td>\n",
       "      <td>-8.807956</td>\n",
       "      <td>model=AGLISTA__m=250__s=50__k=2__noise=Gaussia...</td>\n",
       "      <td>0     -7.563429\n",
       "1     -7.702815\n",
       "2     -7.77658...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             model    m   s   k            noise     n         db  \\\n",
       "0          AGLISTA  250  50   8  GaussianNoise40  2000 -15.923502   \n",
       "1  NA_ALISTA_UR_16  250  50  16  GaussianNoise40  1000 -36.761836   \n",
       "2          AGLISTA  250  50  16  GaussianNoise40  2000 -25.607043   \n",
       "3        ALISTA_AT  250  50  12  GaussianNoise40  1000 -30.788237   \n",
       "4          AGLISTA  250  50   2  GaussianNoise40   500  -8.807956   \n",
       "\n",
       "                                                 dir  \\\n",
       "0  model=AGLISTA__m=250__s=50__k=8__noise=Gaussia...   \n",
       "1  model=NA_ALISTA_UR_16__m=250__s=50__k=16__nois...   \n",
       "2  model=AGLISTA__m=250__s=50__k=16__noise=Gaussi...   \n",
       "3  model=ALISTA_AT__m=250__s=50__k=12__noise=Gaus...   \n",
       "4  model=AGLISTA__m=250__s=50__k=2__noise=Gaussia...   \n",
       "\n",
       "                                                hist  \n",
       "0  0     -11.251444\n",
       "1     -12.345246\n",
       "2     -13.05...  \n",
       "1  0     -32.247113\n",
       "1     -32.391178\n",
       "2     -32.47...  \n",
       "2  0     -11.719982\n",
       "1     -13.957159\n",
       "2     -15.48...  \n",
       "3  0     -18.601399\n",
       "1     -19.314646\n",
       "2     -19.77...  \n",
       "4  0     -7.563429\n",
       "1     -7.702815\n",
       "2     -7.77658...  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = []\n",
    "results = []\n",
    "for d in os.listdir(result_dir):\n",
    "    params = d.split('__')\n",
    "    res = {p.split('=')[0]: p.split('=')[1] for p in params}\n",
    "    try:\n",
    "      df_ = pd.read_csv(result_dir + \"/\" + d + \"/train_log\").drop(columns=[\"Unnamed: 0\"])\n",
    "      res[\"db\"] = df_[\"test_dbs\"].min()\n",
    "      res[\"dir\"] = d\n",
    "      res[\"hist\"] = df_[\"test_dbs\"]\n",
    "      results.append(res)\n",
    "    except:\n",
    "      print(f\"This job has not yet finished, but folder was created: {d}\")\n",
    "      \n",
    "df = pd.DataFrame(results)\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Daos7OuQcVI8",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Vary N, for Gaussian noise 20/40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 985
    },
    "id": "y1A7vOFTbCjw",
    "outputId": "1a10f4d6-2347-446b-d128-aca636fbed49",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = df\n",
    "for noisefn, yticks, ylim in [[\"GaussianNoise40\", range(-55, 5, 5), -57], [\"GaussianNoise20\", range(-30, 5, 5), -30]]:\n",
    "    df_ = df[df[\"noise\"] == noisefn]\n",
    "    df_ = df_[df_[\"k\"]=='16']\n",
    "    for alg, label, linestyle in [[\"ALISTA\", \"ALISTA\", \"--\"], [\"ALISTA_AT\", \"ALISTA-AT\", \":\"], [\"AGLISTA\", \"AGLISTA\", \"-\"],  [\"NA_ALISTA_UR_128\", \"NA-ALISTA\",\"-\"], [\"FISTA\", \"FISTA\", \"-\"], [\"ISTA\", \"ISTA\", \"-\"]]:\n",
    "            df_alg = df_[df_[\"model\"] == alg]\n",
    "            x_ = [500, 750, 1000,1250, 1500, 1750, 2000, 2250, 2500] \n",
    "            x = []\n",
    "            y = []\n",
    "            for n in x_:\n",
    "                try:\n",
    "                    y.append(df_alg[df_alg[\"n\"]==str(n)][\"db\"].values[0])\n",
    "                    x.append(n)\n",
    "                except Exception as e:\n",
    "                    print(f\"WARNING: Still missing n={n} for {alg} with {noisefn}.\")\n",
    "            plt.plot(x, y, label=label, linewidth=1.2)#, color=c[alg.split(\"_C\")[0]])\n",
    "            \n",
    "    plt.ylim(ylim, 0)\n",
    "    plt.yticks(yticks)\n",
    "    plt.xticks([500, 750, 1000, 1250, 1500, 1750, 2000, 2250, 2500])\n",
    "    plt.legend(loc=3, ncol=3)\n",
    "    plt.ylabel(\"nMSE (dB)\")\n",
    "    plt.xlabel(\"N\")\n",
    "    plt.grid()\n",
    "    plt.savefig(os.path.join(plot_dir, f\"noise={noisefn}__K=16__varyN.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "f2-dCqZIcmqt",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Vary N, for Gaussian noise 20/40, exclude (F)ISTA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 985
    },
    "id": "J6EWMd6RbCj7",
    "outputId": "ae0ff913-2932-43cf-94c4-6620b5960cac",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = df\n",
    "for noisefn, yticks, ylim in [[\"GaussianNoise40\", range(-45, 5, 5), -45], [\"GaussianNoise20\", range(-25, 5, 5), -25]]:\n",
    "    df_ = df[df[\"noise\"] == noisefn]\n",
    "    df_ = df_[df_[\"k\"]=='16']\n",
    "    for alg, label, linestyle in [[\"ALISTA\", \"ALISTA\", \"--\"], [\"ALISTA_AT\", \"ALISTA-AT\", \":\"], [\"AGLISTA\", \"AGLISTA\", \"-\"],  [\"NA_ALISTA_UR_128\", \"NA-ALISTA\",\"-\"], [\"NA_ALISTA_R_128\", \"NA-ALISTA $r$\",\"-\"],[\"NA_ALISTA_U_128\", \"NA-ALISTA $u$\",\"-\"]]:\n",
    "            df_alg = df_[df_[\"model\"] == alg]\n",
    "            x_ = [500, 750, 1000,1250, 1500, 1750, 2000, 2250, 2500] \n",
    "            x = []\n",
    "            y = []\n",
    "            for n in x_:\n",
    "                try:\n",
    "                    y.append(df_alg[df_alg[\"n\"]==str(n)][\"db\"].values[0])\n",
    "                    x.append(n)\n",
    "                except Exception as e:\n",
    "                    print(f\"WARNING: Still missing n={n} for {alg} with {noisefn}.\")\n",
    "            plt.plot(x, y, label=label, linewidth=1.2)\n",
    "            \n",
    "    plt.ylim(ylim, 0)\n",
    "    plt.yticks(yticks)\n",
    "    plt.xticks([500, 750, 1000, 1250, 1500, 1750, 2000, 2250, 2500])\n",
    "    plt.legend(loc=2)\n",
    "    plt.ylabel(\"nMSE (dB)\")\n",
    "    plt.xlabel(\"N\")\n",
    "    plt.grid()\n",
    "    plt.savefig(os.path.join(plot_dir, f\"noise={noisefn}__K=16__varyN_without_istafista.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7jpoAkudcwxh",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Vary k for N=500,1000,2000 and 40/20dB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "V02vqsxNbCkJ",
    "outputId": "3ff80599-0283-4c62-b48a-47f5eb4ef866",
    "pycharm": {
     "name": "#%%\n"
    },
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for n in [500,1000, 2000]:\n",
    "\n",
    "  df_ = df\n",
    "  for noisefn, yticks, ymin in [[\"GaussianNoise40\", range(-55, 5, 5), -58], [\"GaussianNoise20\", range(-30, 5, 5), -30]]:\n",
    "      df_ = df[df[\"noise\"] == noisefn]\n",
    "      df_ = df_[df_[\"n\"]==str(n)]\n",
    "      for alg, label, linestyle in [[\"ALISTA\", \"ALISTA\", \"--\"], [\"ALISTA_AT\", \"ALISTA-AT\", \":\"], [\"AGLISTA\", \"AGLISTA\", \"-\"], [\"NA_ALISTA_UR_128\", \"NA-ALISTA\",\"-\"], [\"FISTA\", \"FISTA\", \"-\"], [\"ISTA\", \"ISTA\", \"-\"]]:\n",
    "              df_alg = df_[df_[\"model\"] == alg]\n",
    "              x_ = [0, 1, 2, 4, 6, 8, 10, 12, 14, 16]\n",
    "              x = [0]\n",
    "              y = [0]\n",
    "              for k in x_[1:]:\n",
    "                  try:\n",
    "                      y.append(df_alg[df_alg[\"k\"]==str(k)][\"db\"].values[0])\n",
    "                      x.append(k)\n",
    "                  except Exception as e:\n",
    "                      print(f\"WARNING: Still missing k={k} for {alg}.\")\n",
    "              plt.plot(x, y, label=label, linewidth=1)\n",
    "              \n",
    "      plt.ylim(ymin, 2)\n",
    "      plt.yticks(yticks)\n",
    "      plt.xticks(range(17))\n",
    "      plt.legend(loc=3, ncol=3)\n",
    "      plt.ylabel(\"nMSE (dB)\")\n",
    "      plt.xlabel(\"Iterations (K)\")\n",
    "      plt.grid()\n",
    "      plt.savefig(os.path.join(plot_dir, f\"varyk__n={n}_noise={noisefn}.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "      plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "4PrQStu1c8fK",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Evaluate different numbers of hidden units in LSTM for NA-ALISTA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 608
    },
    "id": "g26FRBh8bCkb",
    "outputId": "51f77727-8636-4c2e-e0a3-df0844eb4b81",
    "pycharm": {
     "name": "#%%\n"
    },
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-7-8e277b921d57>:2: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_['h'] = df_.model.apply(lambda x: int(x.split('_')[-1]))\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_ = df[df.model.str.contains(\"NA_ALISTA_UR_\")]\n",
    "df_['h'] = df_.model.apply(lambda x: int(x.split('_')[-1]))\n",
    "df_.h\n",
    "df_ = df_[df_.k=='16']\n",
    "df_ = df_[df_['noise'] == 'GaussianNoise40']\n",
    "df_ = df_[np.logical_or(np.logical_or(df_.n == '1000' ,df_.n=='2000'), df_.n == '500')]\n",
    "df_ = df_[['h','n','db']].pivot(index='n',columns='h',values='db').T\n",
    "plt.plot(df_.index,df_['500'].values,label='N=500')\n",
    "plt.plot(df_.index, df_['1000'].values,label='N=1000')\n",
    "plt.plot(df_.index,df_['2000'].values,label='N=2000')\n",
    "plt.yticks(range(-50, -20, 5))\n",
    "plt.xticks(df_.index,[str(i) for i in df_.index])\n",
    "plt.xlabel('LSTM Size ($H$)')\n",
    "plt.ylabel('nMSE (db)')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(os.path.join(plot_dir, 'compare_hidden.pdf'), bbox_inches='tight', pad_inches=0.05)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "sHcLVBffdHQD",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Explore the learning rates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 497
    },
    "id": "CneVjUyFbCkl",
    "outputId": "50850e90-41fe-4a0d-edb0-a5b696a169a9",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for n in [1000]:\n",
    "\n",
    "  df_ = df\n",
    "  for noisefn, yticks in [[\"GaussianNoise40\", range(-45, 5, 5)]]:\n",
    "      df_ = df[df[\"noise\"] == noisefn]\n",
    "      df_ = df_[df_[\"n\"]==str(n)]\n",
    "      df_ = df_[df_[\"k\"]==str(16)]\n",
    "      for alg, label, linestyle in [[\"ALISTA\", \"ALISTA\", \"--\"], [\"ALISTA_AT\", \"ALISTA-AT\", \":\"], [\"AGLISTA\", \"AGLISTA\", \"-\"], [\"NA_ALISTA_UR_128\", \"NA-ALISTA\",\"-\"]]:\n",
    "              df_alg = df_[df_[\"model\"] == alg].iloc[0]\n",
    "              plt.plot(range(0, len(df_alg[\"hist\"])+1), [0] + list(df_alg[\"hist\"]), label=label, linewidth=1)\n",
    "              \n",
    "      plt.ylim(min(yticks), 2)\n",
    "      plt.yticks(yticks)\n",
    "      plt.legend(loc=9, ncol=2)\n",
    "      plt.ylabel(\"nMSE (dB)\")\n",
    "      plt.xlabel(\"Training Epochs\")\n",
    "      plt.grid()\n",
    "      plt.savefig(os.path.join(plot_dir, f\"training_n=1000_db=40.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "      plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "XS3bWKoAesUf",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## View the adaptive thresholds of NA-ALISTA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 500
    },
    "id": "b7NMqSiwbCk-",
    "outputId": "8fab3802-1b53-44db-d741-8a879098eada",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "gammas = np.load(\"res/params/gammas.npy\")\n",
    "thetas = np.load(\"res/params/thetas.npy\")\n",
    "\n",
    "gammas_mean = gammas.mean(axis=0)\n",
    "thetas_mean = thetas.mean(axis=0)\n",
    "\n",
    "\n",
    "gammas_min = gammas.min(axis=0)\n",
    "thetas_min = thetas.min(axis=0)\n",
    "\n",
    "gammas_max = gammas.max(axis=0)\n",
    "thetas_max = thetas.max(axis=0)\n",
    "\n",
    "k = 16\n",
    "plt.xticks(range(1, 17))\n",
    "plt.xlabel(\"Iterations (K)\")\n",
    "plt.plot(range(1, 17), gammas_max, label=\"$\\gamma$ Max\", color=\"red\", linestyle=\"dotted\")\n",
    "plt.plot(range(1, 17), gammas_mean, label=\"$\\gamma$ Mean\", color=\"red\")\n",
    "plt.plot(range(1, 17), gammas_min, label=\"$\\gamma$ Min\", color=\"red\", linestyle=\"--\")\n",
    "plt.plot(range(1, 17), thetas_max, label=\"$\\\\theta$ Max\", color=\"blue\", linestyle=\"dotted\")\n",
    "plt.plot(range(1, 17), thetas_mean, label=\"$\\\\theta$ Mean\", color=\"blue\")\n",
    "plt.plot(range(1, 17), thetas_min, label=\"$\\\\theta$ Min\", color=\"blue\", linestyle=\"--\")\n",
    "plt.legend(loc=2, ncol=2)\n",
    "plt.savefig(os.path.join(plot_dir,\"gammas_and_thetas.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Dl61K9npJCPp",
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## Verify the assumptions required from the reconstruction bound\n",
    "\n",
    "This cell requires a gpu!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 536
    },
    "id": "pyuQ0YDQbCkr",
    "outputId": "cf109afb-5f12-432c-8667-ee4b0a3b042e",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using saved phi from res/matrices/250_2000/.\n",
      "Using saved W from res/matrices/250_2000/.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 317.304x196.105 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils.optimize_matrices import get_matrices\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import numpy as np\n",
    "import os\n",
    "import json\n",
    "import pandas as pd\n",
    "from utils.get_data import Synthetic\n",
    "from utils.noise import GaussianNoise\n",
    "import torch\n",
    "from utils.train_utils import *\n",
    "from utils.all_models import *\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    device = \"cuda\"\n",
    "else:\n",
    "    device = \"cpu\"\n",
    "\n",
    "all_models = [NA_ALISTA_R_128,NA_ALISTA_UR_128, NA_ALISTA_U_128]\n",
    "all_models = {a.__name__ : a for a in all_models}\n",
    "\n",
    "    \n",
    "def validate_l1_proportionality(name):\n",
    "    params = name.split('__')\n",
    "    params = {p.split('=')[0]: p.split('=')[1] for p in params}\n",
    "    \n",
    "    # recover parameters\n",
    "    n = int(params['n'])\n",
    "    m = int(params['m'])\n",
    "    s = int(params['s'])\n",
    "    k = int(params['k'])\n",
    "    noise = params['noise']\n",
    "    p = (np.linspace((s * 1 * 1.2) // k, s * 1 * 1.2, k)).astype(int)\n",
    "    model_fn = all_models[params['model']]\n",
    "    noise_fn = {'GaussianNoise40':GaussianNoise(40)}[noise]\n",
    "\n",
    "\n",
    "    phi, W_frob = get_matrices(m, n)\n",
    "    data = Synthetic(m, n, s, s, batch_size=10000)\n",
    "    model = model_fn(m, n, s, k, p, phi, W_frob).to(device)\n",
    "    model.load(result_dir + '/' + name + \"/checkpoint\")\n",
    "\n",
    "    test_loss = []\n",
    "    test_normalizer = []\n",
    "    sparsities = []\n",
    "    with torch.no_grad():\n",
    "        for epoch in range(1):\n",
    "            for i, (X, info) in enumerate(data.train_loader):\n",
    "                if i >= 1:\n",
    "                  break\n",
    "                X = X.to(device)\n",
    "                info = info.to(device)\n",
    "                y = torch.matmul(X, model.phi.T)\n",
    "                X_hat, gammas, thetas, cs, xk = model(noise_fn(y), info, include_cs=True)\n",
    "                \n",
    "                \n",
    "                l1_err = []\n",
    "                for l in range(k):\n",
    "                  \n",
    "                  l1_err.append(torch.norm(xk[l]-X, dim=1, p=1).reshape(-1,1))\n",
    "                \n",
    "                # use true ground truth\n",
    "                cs = torch.cat(l1_err,dim=1)\n",
    "\n",
    "                m = (thetas/(gammas*cs)).cpu().detach().numpy().mean(axis=0)\n",
    "                s = (thetas/(gammas*cs)).cpu().detach().numpy().std(axis=0)\n",
    "  \n",
    "                ax = plt.gca()\n",
    "                ax2 = ax.twinx()\n",
    "                plt.xticks(range(1, k+1))\n",
    "\n",
    "                tm = (thetas/(gammas+0.2*10e-6)).cpu().detach().numpy().mean(axis=0)\n",
    "                ts = (thetas/(gammas+0.2*10e-6)).cpu().detach().numpy().std(axis=0)\n",
    "\n",
    "                _cm = (cs).cpu().detach().numpy().mean(axis=0)\n",
    "                _cs = (cs).cpu().detach().numpy().std(axis=0)\n",
    "                col = 'navy'\n",
    "                ax.plot(range(1, k+1),tm,c=col)\n",
    "                ax.tick_params(axis='y', labelcolor=col)\n",
    "                ax.fill_between(range(1,k+1),tm+ts, tm-ts, color=col,alpha=0.2, linewidth=0)\n",
    "                ax.set_ylabel(\"$\\\\theta^{(k)} / \\gamma^{(k)}$\",color=col)\n",
    "                ax.set_ylim(0,1.4)\n",
    "    \n",
    "                col= 'forestgreen'\n",
    "                ax2.plot(range(1, k+1),_cm,c=col)\n",
    "                ax2.fill_between(range(1, k+1),_cm+_cs, _cm-_cs, color=col,alpha=0.2, linewidth=0)\n",
    "                ax2.set_ylabel('$\\|x^{(k)}-x^*\\|_1$', color=col) \n",
    "                ax2.tick_params(axis='y', labelcolor=col)\n",
    "                ax.set_xlabel('Iterations (K)')\n",
    "                plt.savefig(os.path.join(plot_dir,f\"ratio_to_l1error__noise={noise}__n={n}__model={params['model']}.pdf\"), bbox_inches='tight', pad_inches=0.05)\n",
    "                \n",
    "                plt.show()\n",
    "\n",
    "                test_loss.extend(list(((X_hat - X) ** 2).cpu().detach().numpy()))\n",
    "                test_normalizer.extend(list((X ** 2).cpu().detach().numpy()))\n",
    "\n",
    "\n",
    "validate_l1_proportionality('model=NA_ALISTA_UR_128__m=250__s=50__k=16__noise=GaussianNoise40__n=2000')"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "plot_results.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
