{
 "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": 12,
   "id": "e4e97afc",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((7, 10))\n",
    "E_RIE = np.zeros((7, 10))\n",
    "\n",
    "SNR = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7ef8eab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(7):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('Y-Gaussian_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('Y-Gaussian_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b8c32050",
   "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": 15,
   "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",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\alpha$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"aspect-ratio-Y-RIE.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e69fdf4c",
   "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
}
