{
 "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": 5,
   "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": 13,
   "id": "9cc592ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "\n",
    "prior = \"Gaussian\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "id": "c6d55c92",
   "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": 21,
   "id": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "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.01),size=12)\n",
    "    \n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"Gaussian-Y-RIE-alphag1.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "418c7110",
   "metadata": {},
   "source": [
    "### Uniform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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": 23,
   "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": 24,
   "id": "b7c4218a",
   "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": 28,
   "id": "fa2c66a6",
   "metadata": {},
   "outputs": [
    {
     "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.005),size=12)\n",
    "    \n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"Uniform-Y-RIE-alphag1.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
}
