{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 202,
   "id": "5161bc01",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "a11a9760",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tikzplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 204,
   "id": "0d7c7e2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "SNR_list = [0.1, 0.3, 0.6, 1.0, 2.0, 3.0, 4.0, 5.0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "id": "e4e97afc",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "E_RIEth = np.zeros((8, 10))\n",
    "\n",
    "E_Oracle_2 = np.zeros((8, 10))\n",
    "E_RIE_2 = np.zeros((8, 10))\n",
    "E_RIEth_2 = np.zeros((8, 10))\n",
    "\n",
    "sparsity = 0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "id": "7ef8eab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('Y-'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('Y-'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_RIE.npy')\n",
    "    E_RIEth[i,:] = np.load('Y-'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_RIEth.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 228,
   "id": "7790cec3",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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fv16/f3vf9fbb7/tdinGGzNmjNatW6errrpKR48e1YoVKzRu3Di9++67GjhwYNjrIdx0gmVZrY4dx2nTBkSyOXPm6J133tHOnTvdLsVoV199tfbs2aMTJ06ouLhYM2fO1LZt2wg4PaC6ulo/+tGPtHXrVsXHx7tdjvGys7OD//9b3/qWMjMzNXz4cP3ud79Tbm5u2Osh3JzDoEGDFBUV1WaUpra2ts1oDhCp5s6dq9dee03bt2/X0KFD3S7HaLGxsbryyislSenp6Xr77bf1y1/+UoWFhS5XZp7y8nLV1tYqLS0t2NbU1KTt27dr9erV8vv9ioqKcrFCs1144YX61re+pffee8+V92fOzTnExsYqLS1NJSUlrdpLSko0btw4l6oCQsNxHM2ZM0evvPKK/vrXvyo1NdXtkvocx3Hk9/vdLsNIN998s/bt26c9e/YEX+np6fq3f/s37dmzh2DTw/x+vw4cOKBLL73Ulfdn5OZr5Obm6v7771d6eroyMzP13HPPqaqqSjk5OW6XZqRTp07p/fffDx4fPHhQe/bsUVJSklJSUlyszDyPPvqoXnrpJf3xj3/UgAEDgiOUiYmJ6tevn8vVmefxxx9Xdna2fD6fTp48qfXr1+vNN9/UG2+84XZpRhowYECb+WMXXnihBg4cyLyyHrBw4UJNnjxZKSkpqq2t1YoVK9TQ0KCZM2e6Ug/h5mtMnz5dx48f17Jly1RTU6ORI0dqy5YtGjZsmNulGamsrEyTJk0KHrfcq505c6bWrl3rUlVmalne4MYbb2zV/sILL+iBBx4If0GGO3r0qO6//37V1NQoMTFR1157rd544w3deuutbpcGdNvHH3+se++9V3V1dbrkkks0duxYvfXWW679VrLODQAAMApzbgAAgFEINwAAwCiEGwAAYBTCDQAAMArhBgAAGIVwAwAAjEK4AQAARiHcAAAAoxBuAACAUQg3AADAKIQbAABgFMINgIh34sQJWZalXbt2SZLef/99XX311Vq8eLHYPg/oewg3ACLe3r17ZVmWrr32Wu3cuVMTJ07U4sWL9dOf/lSWZbldHoAwi3a7AADorr1792r48OHavHmzfvzjH+ull17SpEmT3C4LgEsYuQEQ8fbu3asjR45o5syZ8nq9uvHGG90uCYCLCDcAIt7evXuVnp6ubdu2ad++fSouLna7JAAushxm2wGIYE1NTerfv782bNigO+64Q3fffbf279+vd955Rx4P//0G9EX8kw8golVWVurMmTO67rrrJElPPvmk9u/fr9///vfuFgbANYQbABFt7969uuiii5SSkiJJGjlypO666y4tXbpUTU1NLlcHwA3clgIAAEZh5AYAABiFcAMAAIxCuAEAAEYh3AAAAKMQbgAAgFEINwAAwCiEGwAAYBTCDQAAMArhBgAAGIVwAwAAjEK4AQAARvl/I+ZIpJIhJl0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.errorbar(SNR_list, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='v', color='red',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(SNR_list, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='^', color='royalblue',ecolor='lightslategray',label=' RIE')\n",
    "plt.errorbar(SNR_list, E_RIEth.mean(1), yerr=E_RIE.std(1), fmt='x', color='seagreen',ecolor='lightgreen',label='RIEth')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "\n",
    "# tikzplotlib.save(\"Y-RIE-Rademacherentry-0.9.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "8e4d6a0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy.linalg as LA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 238,
   "id": "d6197511",
   "metadata": {},
   "outputs": [],
   "source": [
    "sparsity = 0.9\n",
    "\n",
    "N = 2000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "id": "d8855422",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6\n",
      "0.7\n",
      "0.7\n",
      "0.8\n",
      "0.8\n",
      "0.9\n",
      "0.9\n",
      "0.9\n"
     ]
    }
   ],
   "source": [
    "E_RIE = np.zeros(8)\n",
    "E_RIEthopt = np.zeros(8)\n",
    "\n",
    "for i in range(8):\n",
    "    \n",
    "    Y = np.load('Example-Y-'+str(sparsity)+'_SNR='+str(SNR_list[i])+'.npy')\n",
    "    Y_oracle = np.load('Example-Y-RIE-'+str(sparsity)+'_SNR='+str(SNR_list[i])+'.npy')\n",
    "    \n",
    "    Y_norm = LA.norm(Y)**2\n",
    "    \n",
    "    E_th_list = np.zeros(11)\n",
    "    for j in range(11):\n",
    "        p = j/10\n",
    "        \n",
    "        Y_t = Y_oracle.copy()\n",
    "        \n",
    "        Y_t[ Y_t > p/(2*np.sqrt(N))] = 1/np.sqrt(N)\n",
    "        Y_t[Y_t < -p/(2*np.sqrt(N))] = -1/np.sqrt(N)\n",
    "        Y_t[ abs(Y_t)<p/(2*np.sqrt(N))] = 0\n",
    "        \n",
    "        E_th_list[j] = ( LA.norm(Y-Y_t)**2 ) / Y_norm\n",
    "        \n",
    "    \n",
    "    E_RIE[i] = ( LA.norm(Y-Y_oracle)**2 ) / Y_norm\n",
    "    \n",
    "    E_RIEthopt[i] = min(E_th_list)\n",
    "    print(np.argmin(E_th_list)/10)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 240,
   "id": "0cfacc8f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(SNR_list,E_RIE,'^', color='royalblue')\n",
    "plt.plot(SNR_list,E_RIEthopt,'x',color='seagreen')\n",
    "\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "\n",
    "# tikzplotlib.save(\"Y-RIEth-Rademacherentry-0.9.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4cc28a17",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
