{
 "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 = [ 100, 200, 300, 400, 500, 1000, 1500]"
   ]
  },
  {
   "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",
    "\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')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 9,
   "id": "7790cec3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Z2cnVq5c+feLUVHS85Giomr5TjWM2ly/ZUI0tTXCG4f8/HwolUqoVCp+jxsRETV5rq6u6Nu3L1avXv1oGxIC8PQE4uOBsrK/R5FOnWoUt9pqc/3m7TYiIiKqdqHmWpHJKuYeDR1a8bysrMnNRarEidtERERUv7y9gcpP13l4NL25SP/DkERERET1SyYDli0DOneu+NkER5EA3m4jIiKihjBoEJCYqO9ePBKOJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJDElEREREEhiSiIiIiCQwJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJDElEREREEhiSiIiIiCQwJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJDElEREREEhiSiIiIiCQwJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJDElEREREEhiSiIiIiCQwJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJDElEREREEhiSiIiIiCQwJBERERFJYEgiIiIiksCQRERERCSBIYmIiIhIAkMSERERkQSGJCIiIiIJeg9JISEhcHBwgImJCdzc3HDixIlq68fGxsLNzQ0mJibo2LEj1q1bV6XOypUr4ejoiGbNmsHOzg6zZs1CUVHRI+2XiIiIni56DUm7du1CYGAgFi5ciISEBPTr1w8+Pj64efOmZP3r169j2LBh6NevHxISEvDRRx9h5syZCA8P19T57rvvMH/+fCxevBhJSUnYtGkTdu3ahQULFtR5v0RERPT0kQkhhL527unpCVdXV6xdu1ZT1rlzZ4waNQrLly+vUn/evHn497//jaSkJE1ZQEAA/vOf/yAuLg4A8O677yIpKQlHjhzR1JkzZw5Onz6tGS2q7X4BQK1WQ61Wa57n5+fDzs4OKpUK5ubmdXwHiIiI6HHKz8+HUqms0fVbbyNJxcXFOHfuHLy9vbXKvb298dtvv0m2iYuLq1J/yJAhOHv2LEpKSgAAffv2xblz53D69GkAQGpqKiIiIjB8+PA67xcAli9fDqVSqXnY2dnV7oCJiIioSdFbSMrOzkZZWRmsrKy0yq2srJCZmSnZJjMzU7J+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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",
    "\n",
    "for i,j in zip(range(5),E_Oracle.mean(1)[:5]):\n",
    "    if i%2 ==0:\n",
    "        ax.annotate(str(E_relative[i])+'\\%',xy=(ar[i]-0.3,j),size=12)\n",
    "    else:\n",
    "        ax.annotate(str(E_relative[i])+'\\%',xy=(ar[i]+2.5,j),size=12)\n",
    "\n",
    "ax.annotate(str(E_relative[5])+'\\%',xy=(ar[5]+2.5,E_Oracle.mean(1)[5]),size=12)\n",
    "ax.annotate(str(E_relative[6])+'\\%',xy=(ar[6]+2.5,E_Oracle.mean(1)[6]),size=12)\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\alpha$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"aspect-ratio-X-RIE-alphag1.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "07508f70",
   "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
}
