{
 "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": "62b103c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tikzplotlib"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": 4,
   "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": 5,
   "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": 6,
   "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": 7,
   "id": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 7,
     "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": 8,
   "id": "9ba2b2a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "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": 11,
   "id": "fa2c66a6",
   "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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\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": 12,
   "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": 13,
   "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": 14,
   "id": "d6b68266",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b2485dc",
   "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
}
