{
 "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": 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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e0xERERUz1QpJAUEBODSpUuq15cvX8bkyZMxePBgLFiwAIcPH8bKlStrvJNEREREda1KIenixYt4+eWXVa/37NmDHj164Ouvv8acOXOwfv16fP/99zXeSSIiIqK6VqWQ9ODBA7V7CUVGRmLo0KGq125ubrzJIhERET0TqhSSLC0tVV/vLygoQFRUFHr16qVan5OTU+5+RUREREQNUZVC0tChQ7FgwQL8+uuvWLhwIYyMjNCvXz/V+kuXLqF9+/Y13kkiIiKiulal+yQtW7YMo0ePxoABA2BiYoIdO3ZAX19ftT4oKAju7u413kkiIiKiulat+yRlZWXBxMSk3ENjMzIy0LRp00ZxyY33SSIiImp4au2O2++8806l6gUFBVVls0RERET1TpVC0o4dO2BnZ4du3bqBN+omIiKiZ1mVQpKvry/27NmDhIQEvPPOOxg3bhxatGhRW30jIiIi0poqfbstMDAQycnJmD9/Pg4fPgxbW1u8/vrrOHr0KEeWiIiI6JnyVA+4TUxMxI4dO7Bz504UFhYiJiYGJiYmNdm/eosTt4mIiBqeWnvA7eNkMhlkMhmEECgpKXmaTRERERHVK1UOSUqlErt378aQIUPg4OCAy5cv46uvvsKdO3cazSgSERERPfuqNHF7xowZ2LNnD9q0aYNJkyZhz549MDMzq62+EREREWlNleYk6ejooE2bNujWrRtkMpnGegcOHKiRztVnnJNERETU8NTazSQnTJhQYTgiIiIielZU+WaSRERERI3BU327jYiIiOhZxZBEREREJIEhiYiIiEgCQxIRERGRBIYkIiIiIgkMSUREREQSGJKIiIiIJDAkEREREUlgSCIiIiKSwJBEREREJIEhiYiIiEgCQxIRERGRBIYkIiIiIgkMSUREREQSGJKIiIiIJDAkEREREUlgSCIiIiKSwJBEREREJIEhiYiIiEgCQxIRERGRBIYkIiIiIgkMSUREREQSGJKIiIiIJDAkEREREUlgSCIiIiKSwJBEREREJIEhiYiIiEgCQxIRERGRBIYkIiIiIgkMSUREREQSGJKIiIiIJDAkEREREUlgSCIiIiKSwJBEREREJIEhiYiIiEgCQxIRERGRBIYkIiIiIgkMSUREREQStB6SAgMDYW9vD0NDQ7i4uODXX3+tsH5kZCRcXFxgaGiIdu3aYdOmTeXqrF27Fg4O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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
}
