{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5161bc01",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "62b103c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tikzplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "52cf6255",
   "metadata": {},
   "outputs": [],
   "source": [
    "SNR_list = [0.1, 0.3, 0.6, 1.0, 2.0, 3.0, 4.0, 5.0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e9c7bd8b",
   "metadata": {},
   "source": [
    "### Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9cc592ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "E_sqXXRIE = np.zeros((8, 10))\n",
    "\n",
    "prior = \"Gaussian\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "45d4eee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('Y-'+prior+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('Y-'+prior+'_SNR='+str(SNR_list[i])+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a1bc8e56",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_relative = np.zeros(8)\n",
    "\n",
    "for i in range(8):\n",
    "    tmp = 0\n",
    "    for j in range(10):\n",
    "        tmp += abs( E_Oracle[i,j]- E_RIE[i,j])/E_Oracle[i,j]\n",
    "    \n",
    "    E_relative[i] = tmp/10\n",
    "\n",
    "E_relative = E_relative*100\n",
    "E_relative=np.round(E_relative, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "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",
    "\n",
    "x = SNR_list\n",
    "y = E_RIE.mean(1)\n",
    "\n",
    "ax.annotate(str(E_relative[0])+'\\%',xy=(SNR_list[0]+0.1,E_Oracle.mean(1)[0]),size=12)\n",
    "for i,j in zip(range(1,8),E_Oracle.mean(1)[1:]):\n",
    "    ax.annotate(str(E_relative[i])+'\\%',xy=(SNR_list[i]-0.15,j+0.02),size=12)\n",
    "    \n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"Gaussian-Y-RIE.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "418c7110",
   "metadata": {},
   "source": [
    "### Uniform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9ba2b2a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "E_sqXXRIE = np.zeros((8, 10))\n",
    "\n",
    "prior = \"Uniform\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ebcb9b10",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('Y-'+prior+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('Y-'+prior+'_SNR='+str(SNR_list[i])+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3e73389b",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_relative = np.zeros(8)\n",
    "\n",
    "for i in range(8):\n",
    "    tmp = 0\n",
    "    for j in range(10):\n",
    "        tmp += abs( E_Oracle[i,j]- E_RIE[i,j])/E_Oracle[i,j]\n",
    "    \n",
    "    E_relative[i] = tmp/10\n",
    "\n",
    "E_relative = E_relative*100\n",
    "E_relative=np.round(E_relative, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "fa2c66a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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EZFEGKyIiIiIJMJgRURERCQRBisiIiIiiTBYEREREUmEwYqIiIhIIgxWRERERBJhsCIiIiKSCIMVERERkUQYrIiIiIgkwmBFREREJBEGKyIiIiKJMFgRERERSYTBioiIiEgiDFZEREREEmGwIiIiIpIIgxURERGRRBisiIiIiCTCYEVEREQkEQYrIiIiIokwWBERERFJhMGKiIiISCIMVkREREQSYbAiIiIikgiDFREREZFEGKyIiIiIJMJgRURERCQRBisiIiIiiTBYEREREUmEwYqIiIhIIgxWRERERBJhsCIiIiKSCIMVERERkUQYrIiIiIgkwmBFREREJBEGKyIiIiKJMFgRERERSYTBioiIiEgiDFZEREREEmGwIiIiIpKI7MEqOjoarq6uMDMzg6enJ37++edq627btg0BAQFo1aoVrKys4Ovri++//16rTmxsLBQKhc5WVFRU35dCRERETZyswWrz5s2IiIjAzJkzkZycjIEDByIoKAhpaWl66yclJSEgIADx8fE4fvw4Bg0ahKeffhrJycla9aysrJCRkaG1mZmZNcQlERERUROmEEIIuU7et29feHh4YOXKlZoyNzc3DBs2DIsWLarVMbp164bQ0FB8+OGHACpHrCIiIpCbm1vrfhQXF6O4uFjzOT8/H05OTsjLy4OVlVWtj0NERETyyc/Ph1qtlvX+LduIVUlJCY4fP47AwECt8sDAQBw6dKhWx6ioqEBBQQFsbGy0ygsLC+Hi4oK2bdviqaee0hnRutuiRYugVqs1m5OTU90uhoiIiAgyBqubN2+ivLwc9vb2WuX29vbIzMys1TE++eQT3L59G88//7ymrEuXLoiNjcXOnTsRFxcHMzMz9O/fH+fPn6/2ODNmzEBeXp5mS09Pv7+LIiIioibNWO4OKBQKrc9CCJ0yfeLi4jBnzhzs2LEDdnZ2mnIfHx/4+PhoPvfv3x8eHh747LPPsHz5cr3HUqlUUKlU93kFRERERJVkC1YtW7aEkZGRzuhUVlaWzijW3TZv3oyxY8diy5YtePzxx2usq1Qq4e3tXeOIFREREZEUZJsKNDU1haenJxITE7XKExMT0a9fv2rbxcXF4ZVXXsHGjRvx5JNP3vM8QgikpKSgdevWD9xnIiIioprIOhU4depUjBw5El5eXvD19cWaNWuQlpaG8PBwAJXPPl29ehXr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cHNzE7t27RKRkZFCqVSKxMREqb4iIiIivQxhHas6BSuVSiXS0tI0n/v37y/mz5+v+Xz58mVhYWEhXe9kIucPpqCgQEyZMkU4ODgIU1NT0aNHDxEXF6dVZ/To0QKAuHz5slZ5ZmamGDVqlLCxsRFmZmbCx8dHJ9CcP39ePPHEE6JNmzZCpVIJMzMz4e7uLv71r3+JoqIivX26dOmSACD279+vVT5r1izRs2dPUVpaqlWelZUlRowYIdRqtXBychKRkZH3+W0QERHVniEEK4UQtZ+jcXFxwfr16+Hn54eSkhK0aNEC3377LQYPHgygcmrQ399f88D0wyo/Px9qtRp5eXmwsrKSuzsGwcPDAwMGDMDy5cvl7goREZFehnD/rtNyC0OHDsV7772Hjz/+GP/973/RvHlzrUUpT506hfbt20veSZLfiRMn5O4CERGRwatTsFqwYAGGDx8Of39/WFhYIDY2Fqamppr9MTExCAwMlLyTRERERA+DOk0FVsnLy4OFhQWMjIy0ynNycmBpaan5PXIPK0MYSiQiIqK6MYT7d51GrMaMGVOrejExMffVGSIiIqKHWZ2CVWxsLFxcXNC7d2+uS0RERER0lzoFq/DwcGzatAmXLl3CmDFj8PLLL9/zV6UQERERNRV1Wnk9OjoaGRkZmD59Or799ls4OTnh+eefx/fff88RLCIiImry7uvh9Sp//vknYmNjsW7dOpSWluLs2bOwsLCQsn+yMISH34iIiKhuDOH+XacRq7spFAooFAoIIVBRUSFVn4iIiIgeSnUOVsXFxYiLi0NAQAA6d+6M06dP4/PPP0daWlqjGK0iIiIiul91enh9woQJ2LRpE5ydnfHqq69i06ZNsLW1ra++ERERET1U6vSMlVKphLOzM3r37g2FQlFtvW3btknSObkYwhwtERER1Y0h3L/rNBU4atQoDBo0CC1atIBara52q4vo6Gi4urrCzMwMnp6e+Pnnn6utu23bNgQEBKBVq1awsrKCr68vvv/+e516W7duRdeuXaFSqdC1a1ds3769Tn0iIiIiuh91XiBUSps3b0ZERASio6PRv39/rF69GkFBQTh79iycnZ116iclJSEgIAALFy5EixYt8OWXX+Lpp5/G0aNH0bt3bwDA4cOHERoaivnz5yM4OBjbt2/H888/jwMHDqBv376S9p+IiIjonx5ouYUH1bdvX3h4eGDlypWaMjc3NwwbNgyLFi2q1TG6deuG0NBQfPjhhwCA0NBQ5OfnIyEhQVNn6NChsLa2RlxcXK2OaQhDiXqlpwM3blS/384OaNu24fpDRERkQAzh/v1Ayy08iJKSEhw/fhyBgYFa5YGBgTh06FCtjlFRUYGCggKt1d8PHz6sc8whQ4bUeMzi4mLk5+drbQanuBjw9gY8PQFPTxx/ZgpeXXwLx5+ZoimDt3dlPSIiIpKFbMHq5s2bKC8vh729vVa5vb09MjMza3WMTz75BLdv38bzzz+vKcvMzKzzMRctWqT1jJiTk1MdrqSBmJoCzs6AUgkB4Auf6fjTpiO+8JkOAQBKJeDkVFmPiIiIZCFbsKpy99uFQoga3zisEhcXhzlz5mDz5s2ws7N7oGPOmDEDeXl5mi09Pb0OV9BAFApg/nygogLHnPxwzq4nAOCcXU8cc/IDKioq99fiuyMiIqL6UaeH16XUsmVLGBkZ6YwkZWVl6Yw43W3z5s0YO3YstmzZgscff1xrn4ODQ52PqVKpoFKp6ngFMggMhPD2Rozz21BWlKFCaQxlRRli+rwNL4e/obhrCpSIiIgalmwjVqampvD09ERiYqJWeWJiIvr161dtu7i4OLzyyivYuHEjnnzySZ39vr6+Osfcs2dPjcd8aCgUODZ5Gc7Z9USFsjITVyiNK0etJi/jaBUREZHMZBuxAoCpU6di5MiR8PLygq+vL9asWYO0tDSEh4cDqJyiu3r1KtatWwegMlSNGjUKUVFR8PHx0YxMNWvWTLN+1ptvvgk/Pz98/PHHePbZZ7Fjxw788MMPOHDggDwXKSEhBGKutodSFKFCYaQpV4pyxFxtD69aTqMSERFR/ZD1GavQ0FBERkZi3rx56NWrF5KSkhAfHw8XFxcAQEZGBtLS0jT1V69ejbKyMkycOBGtW7fWbG+++aamTr9+/bBp0yZ8+eWX6NGjB2JjY7F58+ZGsYbVsdQinEsr1QpVAFChMMK5tFIcSy2SqWdEREQEyLyOlaEyhHUw7iaEwITF1/FHWgn0/cQUCqCTsymi37XnqBURETVJhnD/lv2tQKqd0jIgK6dMb6gCACGArFtlKC1r2H4RERHR/8j6jBXVnqmJAiunOyC3sKLaOtaWSpiacLSKiIhILgxWDxE7G2PY2dy7HhEREcmDU4FEREREEmGwIiIiIpIIgxURERGRRBisiIiIiCTCYEVEREQkEQYrIiIiIokwWBERERFJhMGKiIiISCIMVkREREQSYbAiIiIikgiDFREREZFEGKyIiIiIJMJgRURERCQRBisiIiIiiTBYEREREUmEwYqIiIhIIgxWRERERBJhsCIiIiKSCIMVERERkUQYrIiIiIgkwmBFREREJBEGKyIiIiKJMFgRERERSYTBioiIiEgiDFZEREREEmGwIiIiIpIIgxURERGRRBisiIiIiCTCYEVEREQkEQYrIiIiIokwWBERERFJhMGqCSssLERERAQcHR1hZmaGXr16YdOmTbVqm5WVhVdeeQUtW7ZE8+bN4evri7179+rUKykpwYcffghXV1eYmprCxcUFM2bMwN9//62pExQUhJCQEL3nSUpKQu/evWFpaQk/Pz+cPXtWp87EiRPh7+8PIUQtr5yIiKh+MFg1YcOHD8fatWsxe/ZsJCQkwNvbG2FhYdi4cWON7YqLizF48GDs3bsXUVFR2LFjB+zt7TF06FDs379fq25YWBiWLFmCcePGIT4+Hq+99hqWLVuG0NBQTZ0RI0Zg9+7duHPnjlbb3NxcBAcHw9vbG9u2bYNarcbw4cNRXl6uqXPkyBHExMRg9erVUCgUEnwrRERED0CQjry8PAFA5OXlyd2VerNr1y4BQGzcuFGrPCAgQDg6OoqysrJq265YsUIAEIcOHdKUlZaWiq5du4o+ffpoyg4fPiwAiE8++USr/cKFCwUAsWfPHiGEEDdv3hTGxsbim2++0aoXHx8vzM3NRUlJiRBCiKtXrwoAIjU1VQghRElJiXB3dxezZ8+u+xdARESNjiHcvzli1URt374dFhYWeO6557TKX331VVy7dg1Hjx6tsW3nzp3h6+urKTM2NsbLL7+MX375BVevXgUAHDx4EADwxBNPaLV/6qmnAABbt24FANja2sLf31/zuUpRURFUKhVMTEwAABYWFppyAFi6dClKSkowY8aMul08ERFRPWGwaqJ+++03uLm5wdjYWKu8R48emv01ta2qp6/tmTNnAFQ+XwUAKpVKq17V51OnTmnKQkJC8N1336G4uFhT5uXlhYKCAqxcuRK5ublYuHAhbG1t0blzZ1y8eBELFizAmjVrdI5PREQkFwarJio7Oxs2NjY65VVl2dnZD9y2a9euAP43clXlwIEDOucIDg7G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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "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",
    "\n",
    "x = SNR_list\n",
    "y = E_RIE.mean(1)\n",
    "\n",
    "ax.annotate(str(E_relative[0])+'\\%',xy=(SNR_list[0]+0.1,E_Oracle.mean(1)[0]),size=12)\n",
    "for i,j in zip(range(1,8),E_Oracle.mean(1)[1:]):\n",
    "    ax.annotate(str(E_relative[i])+'\\%',xy=(SNR_list[i]-0.15,j+0.02),size=12)\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"Uniform-Y-RIE.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9eb921fa",
   "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
}
