{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5161bc01",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "62b103c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tikzplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "52cf6255",
   "metadata": {},
   "outputs": [],
   "source": [
    "SNR_list = [0.1, 0.3, 0.6, 1.0, 2.0, 3.0, 4.0, 5.0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e9c7bd8b",
   "metadata": {},
   "source": [
    "### Estimating $\\mathbf{X}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "9cc592ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "\n",
    "c = 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "45d4eee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('MF-X_c='+str(c)+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('MF-X_c='+str(c)+'_SNR='+str(SNR_list[i])+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ae80e7d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_relative = np.zeros(8)\n",
    "\n",
    "for i in range(8):\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": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ItIiJl9EREREWsTki4iIiEiLmHwRERERaRGTLyIiIiItYvJFREREpEVMvoiIiIi0iMkXERERkRYx+SIiIiLSIiZfRERERFrE5IuIiIhIi5h8EREREWkRky8iIiIiLWLyRURERKRFTL6IiIiItIjJFxEREZEWMfkiIiIi0iImX0RERERaxOSLiIiISIuYfBERERFpEZMvIiIiIi1i8kVERESkRUy+iIiIiLSIyRcRERGRFjH5IiIiItIiJl9EREREWsTki4iIiEiLmHwRERERaRGTLyIiIiIt0nnyFRkZCScnJ5iYmMDd3R3Hjx+vtf7Ro0fh7u4OExMTtG/fHtHR0Sr7Bw4cCIlEora98soryjoLFy5U229vb98o50dERET0IJ0mX9u3b0doaCgWLFiA5ORkDBgwAH5+fsjIyNBY//r16xg2bBgGDBiA5ORkfPDBBwgJCcHOnTuVdXbt2oXMzEzldunSJRgYGOD1119X+a6uXbuq1Lt48WKjnisRERERABjq8uCffvopJk6ciHfeeQcAEBERge+//x5RUVFYtmyZWv3o6Gi0bdsWERERAABnZ2ckJSVh1apVCAwMBABYWVmptImPj4epqala8mVoaMjeLiIiItI6nfV8KRQKnDlzBr6+virlvr6++OmnnzS2OXnypFr9IUOGICkpCffv39fYJiYmBqNHj4aZmZlKeVpaGhwcHODk5ITRo0cjPT291njLyspQWFioshERERHVlc6Sr5ycHFRUVMDOzk6l3M7ODllZWRrbZGVlaaxfXl6OnJwctfo///wzLl26pOxZq9arVy9s2bIF33//PTZu3IisrCz07dsXubm5Nca7bNkyyOVy5ebo6Pi4p0pERESkpPMJ9xKJROWzEEKt7FH1NZUDVb1eLi4u6Nmzp0q5n58fAgMD4erqisGDB2Pfvn0AgLi4uBqPO3/+fBQUFCi3W7du1X5iRERERBrobM6XjY0NDAwM1Hq5srOz1Xq3qtnb22usb2hoCGtra5Xye/fuIT4+HuHh4Y+MxczMDK6urkhLS6uxjrGxMYyNjR/5XURERES10VnPl5GREdzd3ZGYmKhSnpiYiL59+2ps06dPH7X6Bw8ehIeHB2QymUr5119/jbKyMowdO/aRsZSVlSE1NRWtW7eu41kQERER1Y1Ohx1nzpyJTZs2ITY2FqmpqZgxYwYyMjIQ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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(SNR_list, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='v', color='red',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(SNR_list, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='^', color='royalblue',ecolor='lightslategray',label='RIE')\n",
    "\n",
    "x = SNR_list\n",
    "y = E_RIE.mean(1)\n",
    "\n",
    "ax.annotate(str(E_relative[0])+'\\%',xy=(SNR_list[0]+0.1,E_Oracle.mean(1)[0]),size=12)\n",
    "for i,j in zip(range(1,8),E_Oracle.mean(1)[1:]):\n",
    "    ax.annotate(str(E_relative[i])+'\\%',xy=(SNR_list[i]-0.15,j+0.002),size=12)\n",
    "    \n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"MF-X-3.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "418c7110",
   "metadata": {},
   "source": [
    "### Estimating $\\mathbf{Y}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "9ba2b2a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ebcb9b10",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('MF-Y_c='+str(c)+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('MF-Y_c='+str(c)+'_SNR='+str(SNR_list[i])+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "8a63e7bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_relative = np.zeros(8)\n",
    "\n",
    "for i in range(8):\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": 31,
   "id": "fa2c66a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Zc2m0tJSTZkyRcePH1eLFi10++2367PPPtPIkSPt+goAAKCJcBhjjN1F1KeCggL5+fkpPz+f+U0AANwgGsL52/ZtVAAAAG4EhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsIDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmgAAACwgNAEAAFhAaAIAALCA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsIDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmgAAACwgNAEAAFhAaAIAALCA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsMD20JScnKzOnTurefPmCg0N1ebNmy0d99VXX8nDw0N9+/a9vgUCAADI5tD00UcfKTExUdOmTdOOHTt01113acSIEcrOzr7scfn5+Xr00Ud1991311OlAACgqXMYY4xdHz5w4ED1799f8+fPd7b16NFDDzzwgGbNmlXjcb/97W91yy23yN3dXZ988ol27txZY9+SkhKVlJQ4nxcUFCg4OFj5+fny9fWtk+8BAACur4KCAvn5+dl6/rZtpKm0tFTbtm1TdHS0S3t0dLS+/vrrGo977733dODAAU2fPt3S58yaNUt+fn7OR3Bw8DXVDQAAmibbQtPp06dVXl6u9u3bu7S3b99eJ0+erPaYffv26YUXXtCHH34oDw8PS58zdepU5efnOx9Hjx695toBAEDTYy15XEcOh8PluTGmSpsklZeX6+GHH9Yf//hH3XrrrZbf38vLS15eXtdcJwAAaNpsC01t27aVu7t7lVGl3NzcKqNPklRYWKjMzEzt2LFDTz31lCSpoqJCxhh5eHjo888/169+9at6qR0AADQ9tl2e8/T0VGhoqNavX+/Svn79et15551V+vv6+mr37t3auXOn8zFu3DiFhIRo586dGjhwYH2VDgAAmiBbL89NmjRJo0ePVlhYmAYNGqRFixYpOztb48aNk3RpPtLx48e1ZMkSubm5qWfPni7HBwQEqHnz5lXaAQAA6pqtoemhhx7SmTNnlJSUpJycHPXs2VNpaWnq1KmTJCknJ+eKazYBAADUB1vXabJDQ1jnAQAA1E5DOH/bvo0KAADAjYDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmgAAACwgNAEAAFhAaAIAALCA0AQAAGABoQkAAMACQhMAAIAFhCYAAAALCE0AAAAWEJoAAAAsIDQBAABYQGgCAACwgNAEAABgAaEJAADAAkITAACABYQmAAAACwhNAAAAFhCaAAAALCA0AQAAWEBoAgAAsIDQBAAAYAGhCQAAwAJCEwAAgAWEJgAAAAsITQAAABYQmupRUVGREhMTFRQUpObNm6tv375avnz5FY87duyYEhMTFRkZqZtuukkOh0OLFy+utu+0adPUr18/tWnTRs2bN1eXLl30xBNP6MiRI84+I0aMUFxcXLXHb9q0Sf369VOrVq0UERGhPXv2VOkzceJERUZGyhhj7YsDANAIEJrqUWxsrFJTUzV9+nStW7dO4eHhSkhI0NKlSy973P79+/Xhhx/K09NTI0eOvGzfc+fOKSEhQampqUpPT9eUKVO0du1aDRw4UGfOnJEkxcfHKz09XefPn69ybExMjMLDw7Vq1Sr5+fkpNjZW5eXlzj5btmxRSkqKFi5cKIfDcZW/BAAANyDTxOTn5xtJJj8/v14/97PPPjOSzNKlS13ahw0bZoKCgkxZWVmNx5aXlzv/vHXrViPJvPfee5Y/Oy0tzUgy7777rjHGmNOnTxsPDw+zYsWKKv28vb1NaWmpMcaY48ePG0kmKyvLGGNMaWmp6dWrl5k+fbrlzwYAoC7Ydf7+V4w01ZPVq1fLx8dHDz74oEv7Y489phMnTujbb7+t8Vg3t2v7a2rXrp0kycPDQ5Lk7++vyMhIrVy50qXfhQsX5OXlpWbNmkmSfHx8nO2SNGfOHJWWlmrq1KnXVA8AADciQlM9+f7779WjRw9ncKnUu3dv5+t1qaysTP/85z+1Y8cOJSYm6tZbb1VsbKzz9bi4OK1du1YlJSXOtrCwMBUWFmr+/Pk6d+6cXnnlFfn7+yskJEQHDhzQzJkztWjRInl5edVprQAA3AgITfXkzJkzatOmTZX2yrbK+UZ14eTJk2rWrJlatmyp/v37q6ysTBkZGc6RI0mKiYlRcXGx1q9f72wLDg7WvHnzlJiYqNatW2vBggVKSUlRixYtNG7cOCUkJCgiIqLO6gQA4EZCaKpHl5s4XZeTqtu2bautW7fqyy+/1Ntvv628vDxFRUUpJyfH2ScwMFCDBw+ucolu/PjxysvLU1ZWlk6dOqVRo0bp/fff165duzR79mzl5eXpkUceUbt27dS1a1ctWLCgzuoGAKAh87hyF9QFf3//akeT8vLyJKnaUair5eHhobCwMEnS4MGDNXz4cHXu3Fmvvvqq5s2b5+wXFxenpKQklZWVuVw29Pb2Vvfu3SVdGgGbPHmy5s2bp9atW2v06NHKy8vT/v379eOPPyoqKkohISGKioqqs/oBAGiIGGmqJ7169VJWVpbKyspc2nfv3i1J6tmz53X77A4dOigoKEg//vijS3tcXJzOnj2rjIyMGo+dPHmyQkNDlZCQIElat26dJkyYID8/P4WHhys6OlppaWnXrXYAABoKQlM9iYmJUVFRUZXLYampqQoKCtLAgQOv22fv379fx44dU7du3VzaO3TooAEDBlSpqVJGRoY+/vhjJScnO9uMMSouLnY+LyoqYpFLAECTwOW5ejJixAgNGzZM48ePV0FBgbp166Zly5YpPT1dH3zwgdzd3SVJY8eOVWpqqg4cOKBOnTo5j1+xYoUk6eDBg5KkzMxM58Tu+Ph4SdKuXbv0hz/8QfHx8erSpYvc3Ny0e/du/fnPf5a/v7+mTJlSpa64uDjNmTNHycnJLksblJSU6Mknn9SMGTPUuXNnZ/u9996rpKQk+fr6at++fdqwYYOee+65Ov61AABogGqzqNNrr71mzp8/73y+ceNGc+HCBefzgoICM378+LpaQ+q6sHNxrMLCQvPMM8+YwMBA4+npaXr37m2WLVvm0mfMmDFGkjl06JBLu6QaH5VOnjxpfve735muXbuali1bGk9PT9OlSxczbtw4k52dXW1NBw8eNJLMxo0bXdpffPFF06dPH3Px4kWX9tzcXBMfH2/8/PxMcHCwmTt37jX8IgAAWNMQFrd0GGP92oq7u7tycnIUEBAgSfL19dXOnTvVpUsXSdKpU6cUFBTksu1GQ1NQUCA/Pz/l5+fL19fX7nIahP79+2vIkCF688037S4FAIBqNYTzd60uz/08X9Uib6EB2759u90lAADQ4DGnqaE4elT66SdJ0rbjzfTWN956alCxQn9x8dLrAQFShw42FggAQNNGaGoISkqk8HDp1CkZSe/ErdGRgD56J/Ww+q8cJYckBQZKhw9LbGECAIAtah2a3nnnHeddW2VlZVq8eLHatm0rSSosLKzb6poKT0+pY0fpp5+U+Ysh2hvQR5K0N6CPMoMjFH78Syk4+FI/AABgi1pNBP/lL39pabuPQ4cOXVNR11NDmEhWrb//XWb4cE2IW6N9bW9XhZuH3CrKdMvpH5S8cpQc6enSvffaXSUAALZoCOfvWo00HT58+DqVAUVHK/Pux52jTJJU4eZxabTp7scVHh1tY3EAAIAVwRsIIyllwBS5Vbhus+JWUaaUAVPEfYoAANirVqHp22+/1bp161zalixZos6dOysgIEBPPPGESkpK6rTApiIz64L2nmuhCjfXwb8KNw/tPddCmVkXbKoMAABItQxNM2bM0K5du5zPd+/erbFjx+qee+7RCy+8oE8//VSzZs2q8yIbO2OMUj7NV03TxRwOKeXTfNbFAgDARrUKTTt37tTdd9/tfL58+XINHDhQb7/9tiZNmqQ333xTf/3rX+u8yMbuYpmUm1emmjKRMVLu2TJdLKv+dQAAcP3VaiL42bNn1b59e+fzjRs3avjw4c7n4eHhOnr0aN1V10R4NnNo/vOBOldUcanh22+l2bOl//xPaeBASVLrVm7ybHblOxcBAMD1UavQ1L59ex06dEjBwcEqLS3V9u3b9cc//tH5emFhoZo1a1bnRTYFAW08FNDmf550vEt68C5b6wEAAK5qdXlu+PDheuGFF7R582ZNnTpVLVu21F13/e/JfdeuXeratWudFwkAAGC3Wo00zZw5U7GxsYqMjJSPj48WL14sz39ZpTolJUXRrCcEAAAaoVqtCF4pPz9fPj4+cnd3d2nPy8tTq1atGvQluoawoigAAKidhnD+rtVI07//+79b6peSknJVxQAAADRUtQpNixcvVqdOndSvXz/WDAIAAE1KrULTuHHjtHz5ch08eFD//u//rt/97ndq06bNlQ8EAAC4wdXq7rnk5GTl5OTo+eef16effqrg4GD95je/0d///verHnlKTk5W586d1bx5c4WGhmrz5s019v3yyy81ePBg+fv7q0WLFure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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(SNR_list, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='v', color='red',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(SNR_list, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='^', color='royalblue',ecolor='lightslategray',label='RIE')\n",
    "\n",
    "x = SNR_list\n",
    "y = E_Oracle.mean(1)\n",
    "\n",
    "ax.annotate(str(E_relative[0])+'\\%',xy=(SNR_list[0]+0.1,E_Oracle.mean(1)[0]),size=12)\n",
    "for i,j in zip(range(1,8),E_Oracle.mean(1)[1:]):\n",
    "    ax.annotate(str(E_relative[i])+'\\%',xy=(SNR_list[i]-0.15,j+0.01),size=12)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"MF-Y-3.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e117ab6e",
   "metadata": {},
   "source": [
    "### Estimating $\\mathbf{X}\\mathbf{Y}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "43b1d233",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))\n",
    "E_XY_RIE = np.zeros((8, 10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "515145a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('MF-T_c='+str(c)+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('MF-T_c='+str(c)+'_SNR='+str(SNR_list[i])+'_RIE.npy')\n",
    "    E_XY_RIE[i,:] = np.load('MF-XY_c='+str(c)+'_SNR='+str(SNR_list[i])+'_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d6b68266",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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uEHXXnut9u7dq7/+9a9KTk72W49pmrr22mtVVlamrVu3qqioSCNHjtSkSZMa7UFqK5Y/fqGzO3+szfnO770ZdRmLQAFAl/J5741xzTX12z2eduu1ee+992SaphITE/2+npiYqNOnT+vEiROSpCuvvFL33XdfvWMefPBB378PHDhQP/rRj5Sbm6sf//jHkqSf/vSnuuWWW7R06VLfcSNGjPD7fn/729+0f/9+lZeXKzQ0VJL0xBNP6OWXX9YLL7ygu+6668t/2C9AuGmFul4bw5D8ddAYn/feJCeGsRgUAHQ1qakyk5KkN9+UYZoyg4JkjBzZLr02zVHXY1P3e+Svx+WFF17QihUr9P777+vcuXOqqampt4TKvn37fLewvkhRUZHOnTvX4BEWn332mf79739/2Y/RLISbVqiukco/rvEbbKTawFN+ukbVNZLzyz8iAwDQGRmG9PDDMj5/9qHRjr02kjR48GAZhqEDBw5oypQpDV5/5513dPHFF/uWTunevXu9119//XVfr8zVV1+tyMhIbdq0Sb/4xS98x7TkcRRer1d9+/atN7ykTs+ePZt9nS+DcNMKzhBD2Qv76My5RgaNSbo43CFnCL02ANAlTZ6smn79FHzsmMykJBnt2GvTu3dvTZ48WVlZWbr33nvrBZGysjI999xzmjZtWqN3Enbv3q34+HjfoGNJ+vDDD+sdM3z4cP31r3/V7bff/oX1jBw5UmVlZQoODg74xB/LBxR3dtG9gnVpnLPR7ZKLyY8A0GUZhionTZInKqpde23qrFq1Sm63W1dffbV27NihkpISbdu2TZMnT1b//v3105/+tNFzBw8erOLiYm3atEn//ve/9dRTT+mll16qd8ySJUu0ceNGLVmyRAcPHtT+/fv185//3O/1rrrqKqWkpGjKlCl69dVXdeTIERUUFOjBBx9UYWFhm37uCxFuAABoR55Bg3Ru3jxp0qR2f6+vfvWrKiws1KBBg5Senq5Bgwbprrvu0sSJE7Vnzx716tWr0XOvv/563XvvvZo3b54uv/xyFRQU+GZR1bniiiu0efNmvfLKK7r88st15ZVX6u9//7vf6xmGoa1bt2rChAm64447dOmll+qWW27RkSNHGn0SQVsxzC42V7klj0wHAHQ9lZWVOnz4sBISEhQWFtaqa5lVVarIzJQkRSxaJKMdFu6zk6a++5b8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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.errorbar(SNR_list, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='v', color='red',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(SNR_list, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='^', color='royalblue',ecolor='lightslategray',label='RIE')\n",
    "plt.errorbar(SNR_list, E_XY_RIE.mean(1), yerr=E_XY_RIE.std(1), fmt='x', color='seagreen',ecolor='lightgreen',label='RIE')\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "\n",
    "# tikzplotlib.save(\"MF-T-3.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
}
