{
 "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": "c2b5cc36",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tikzplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0d7c7e2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "M = [2000, 3000, 4000, 5000, 6000, 7000, 8000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "877b795b",
   "metadata": {},
   "outputs": [],
   "source": [
    "ar = np.zeros(7)\n",
    "for i in range(7):\n",
    "    ar[i] = 2000/M[i]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5056771",
   "metadata": {},
   "source": [
    "#### Estimating $\\mathbf{X}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e4e97afc",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((7, 10))\n",
    "E_RIE = np.zeros((7, 10))\n",
    "E_sqXXRIE = np.zeros((7, 10))\n",
    "\n",
    "SNR = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7ef8eab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(7):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_RIE.npy')\n",
    "#     E_sqXXRIE[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "00c4b414",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_relative = np.zeros(7)\n",
    "\n",
    "for i in range(7):\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": 8,
   "id": "7790cec3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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vP/617+EXC4X0dHR4tKlS+Lw4cPCy8tL9OzZU19DqJXajrfKhAkThI+PT2N394nVdrwlJSXCyclJjB49Wvz+++/iwIED4oUXXhDvvPOOvoZQK7Ud7xdffCG2b98uzp8/L86cOSM++ugjAUBs3bpVX0Oolbr+fa7S1O5uq+14v/zyS7Fjxw5x/vx5cf78eREXFycsLS3F7Nmz9TWEBsUkqZFV3R778PHmm28KIYR48803Rf/+/bXq/PLLL6J79+7C2NhYPP/882L16tWN3/EntGrVKuHi4iKMjY1Fjx49xIEDBzTvPTzmjIwM0a1bN2FqaiosLS3Fq6++Ks6ePauHXtddbcYrROUt/3/5y1+EqampcHBwEOPHjxc3btxo5F7XXW3HW1hYKExNTcWaNWsauaf1o7bjzczMFIMGDRKmpqbCyclJhIWFibt37zZyr+uuNuP9/PPPRbt27YSJiYmwtrYWL774oti1a5ceel13tf35/llTS5KEqN14V65cKTp16iTMzMyEpaWl6N69u4iOjhbl5eV66HnDkwnxlM/nExEREenB073Ag4iIiEhPmCQRERERSWCSRERERCSBSRIRERGRBCZJRERERBKYJBERERFJYJJEREREJIFJEhEREZEEJklEREREEpgkEREREUlgkkREREQkgUkSEdGf/Oc//8GAAQNgamoKd3d3HD9+HGvWrMGIESP03TUiamR8wC0R0X8dPXoUAwcOxNy5cxEYGIiZM2eirKwM58+fx3fffYfu3bvru4tE1IiYJBER/Vfv3r3h5uaGr7/+GgDw3XffISgoCK+++iq2bdum594RUWPj5TYiIgA3btxASkoKJk+erCkzNjaGEAKffvqpHntGRPrCJImICEBmZiYAwMvLS1N27tw59OzZE56envrqFhHpEZMkIiIARUVFMDQ01LwuKCjA4sWLoVAo9NgrItInJklERAC6deuG8vJyLF68GGfPnkVQUBBcXFyQmZmJrKwsfXePiPSASRIREYD27dsjIiICK1asQPfu3eHg4IB9+/bB2dkZgwYN0nf3iEgPeHcbERERkQTOJBERERFJYJJEREREJIFJEhEREZEEJklEREREEpgkEREREUlgkkREREQkgUkSERERkQQmSUREREQSmCQRERERSWCSRERERCSBSRIRERGRhP8Py0o3saMPYpIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "plt.errorbar(ar, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='v', color='red',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(ar, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='^', color='royalblue',ecolor='lightslategray',label='RIE')\n",
    "ax.invert_xaxis()\n",
    "\n",
    "x = ar\n",
    "y = E_RIE.mean(1)\n",
    "\n",
    "ax.annotate(str(E_relative[0])+'\\%',xy=(ar[0]-0.05,E_Oracle.mean(1)[0]),size=12)\n",
    "for i,j in zip(range(1,7),E_Oracle.mean(1)[1:]):\n",
    "    ax.annotate(str(E_relative[i])+'\\%',xy=(ar[i]+0.1,j),size=12)\n",
    "\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\alpha$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"aspect-ratio-X-RIE.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ae77f1a",
   "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
}
