{
 "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": 8,
   "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": 23,
   "id": "7790cec3",
   "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(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\")"
   ]
  }
 ],
 "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
}
