{
 "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 = 1"
   ]
  },
  {
   "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": "f6181e36",
   "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": 10,
   "id": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlYAAAGwCAYAAABrUCsdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABWrUlEQVR4nO3de1xU1fo/8M8Ml0FB5gAKRIyIGngDlYt3ISpQzskSxjI0NA+WqKV4+ZUePWno10tSRz2F5lES7YBWapmhRX7NS6lfUUxTNERTUpAAuRrgwPr9QUyNAwq6ZY/web9e+2Xz7LX3fvZ02U9rrVlbIYQQICIiIqL7ppQ7ASIiIqKWgoUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJxFzuBExRTU0Nrl27hnbt2kGhUMidDhERETWCEAKlpaVwcXGBUilP3xELq3pcu3YNGo1G7jSIiIjoHmRnZ8PV1VWWa7Owqke7du0A1P6NsbW1lTkbIiIiaoySkhJoNBr9c1wOLKzqUTf8Z2try8KKiIjoISPnNB5OXiciIiKSCAsrIiIiIomwsCIiIiKSCAsrIiIiIomwsCIiIiKSCAsrE1dWVoaYmBi4uLjAysoKffr0wZYtW+563Pbt2xEREYGuXbuiTZs26NSpE8aOHYvMzEyjtvPmzUPfvn1hb28PKysrdO7cGa+88gouX76sbxMaGgqtVlvvtQ4cOIC+ffuiXbt2CAgIwNmzZ43aTJ06FYGBgRBCNOHuiYiIHi4srExceHg4EhMTsWDBAuzevRv+/v6IiIhAUlLSHY9bvnw5bt68iXnz5mHPnj1YvHgx0tPT4ePjgzNnzhi0LSoqQkREBBITE7Fnzx7Mnj0bu3btQv/+/VFQUAAAGDVqFPbs2YObN28aHRsWFgZ/f39s374darUa4eHhqK6u1rc5cuQIEhIS8MEHH3AleyIiatkEGSkuLhYARHFxsax5fPnllwKASEpKMogHBwcLFxcXodPpGjz2+vXrRrGrV68KCwsLERUVdddrp6SkCABiw4YNQggh8vPzhbm5ufj000+N2llbW4uqqir9NQCIjIwMIYQQVVVVwsvLSyxYsOCu1yQiIrofpvD8Zo+VCduxYwdsbGzw3HPPGcQnTJiAa9eu4ejRow0e6+joaBRzcXGBq6srsrOz73rtDh06AADMzWvXkHVwcEBgYCC2bdtm0K6iogIqlQoWFhYAABsbG30cAOLi4lBVVYW5c+fe9ZpEREQPOxZWJuzHH39E9+7d9cVNHW9vb/3+prh48SIuX76Mnj171rtfp9Pht99+Q3p6OmJiYuDh4YHw8HD9fq1Wi127dqGyslIf8/PzQ2lpKdasWYOioiIsWbIEDg4O8PT0RFZWFhYvXox169ZBpVI1KVciIqKHEQurZnb8XAUmxF7D8XMVd21bUFAAe3t7o3hdrG7+U2PodDpERUXBxsYGM2bMMNqfm5sLCwsLtG3bFj4+PtDpdNi3b5++BwoAwsLCUF5ejtTUVH1Mo9Fg1apViImJgZ2dHdauXYuEhAS0adMG0dHRiIiIQEBAQKPzJCIiepixsGoO2dnAiRMQx09gfdJVXM7VYX3SVYjjJ4ATJ4Bffmnw0DtN9m7sRHAhBKKionDw4EFs2rQJGo3GqE379u1x7NgxHDp0CP/5z39QWFiIoKAg5OTk6Ns4Oztj8ODBRsOBkydPRmFhITIyMnD9+nU888wz2Lx5M06dOoUVK1agsLAQY8eORYcOHdClSxesXbu2UXkTERE9bPgS5getshLw9weuX0eaJgDnn94MADifb4G0sBnwzz4AODsDP/8M3DZc5uDgUG+vVGFhIQDU25t1OyEEJk6ciI8++giJiYl49tln621nbm4OPz8/AMDgwYMxfPhwuLu7Y9myZVi1apW+nVarRWxsLHQ6ncEQpbW1Nbp16wagtidt1qxZWLVqFezs7BAZGYnCwkJcuHABP/30E4KCguDp6YmgoKC75k9ERPQwYY/Vg2ZpCXTsCKFUIqHfbChrdAAAZY0OCf1mQyiVgEZT2+42Xl5eyMjIgE6nM4ifPn0aANCrV687XrquqPrwww+xfv16vPjii41O29XVFS4uLvjpp58M4lqtFjdu3MC+ffsaPHbWrFnw9fVFREQEAGD37t2YMmUK1Go1/P39ERISgpSUlEbnQkRE9LBgYfWgKRTAokVIe3QIzjv2Ro2ytpenRmmO8469kfboEGDRotp2twkLC0NZWZnR0FtiYiJcXFzQv3//Bi8rhMDLL7+MDz/8EB988AEmTJjQpLQvXLiAX375BV27djWIu7q6ol+/fkY51dm3bx8++eQTxMfHG+RSXl6u/1xWVsaFQomIqEXiUGAzEMHBSAiygLJGpy+sgN97rYIWwC/4cdQ3Wyo0NBTBwcGYPHkySkpK0LVrVyQnJ2PPnj346KOPYGZmBgCIiopCYmIisrKy4ObmBgCYNm0aNmzYgL///e/w8vLCkSNH9OdVqVTo27cvAODUqVOYMWMGRo0ahc6dO0OpVOL06dP417/+BQcHB8yePdsoL61Wi7i4OMTHx0Op/KM2r6ysxKRJk7Bw4UK4u7vr48OGDUNsbCxsbW2RmZmJvXv34vXXX7+v75SIiMgUKQS7DoyUlJRArVajuLgYtra2932+Y2d/wxvv/drg/uWvdoB/jzb17isrK8O8efPw8ccfo7CwEN26dcPcuXPxwgsv6Nu89NJLSExMxKVLl9CpUycAQKdOnQxeSfNnbm5u+PnnnwEA169fx+zZs3H48GHk5ORAp9PB1dUVISEh+Mc//lHvRPdLly6hc+fO2L9/v8Ev/v75z3/iiy++QFpamsH8q19//RVTpkxBamoqbG1tMWvWLEyfPr3B74OIiOheSP38vhcsrOoh5d8YIQSmvH0dP12pQn3ftEIBeHS0RPzrTg/V6158fHwwZMgQrF69Wu5UiIiIAJhGYcWhwAfslg7IK9TVW1QBgBBA3g0dbukAS4vmze1+nDhxQu4UiIiITA4LqwfM0kKBNW84o6ispraKGj8OOHMW6NkDSNwEKBSwa6eEpcXD01tFRERE9WNh1Qwc7c3hWLfk1PyXgWnTav9042teiIiIWhIWVs3tqaeAs2flzoKIiIgeAK5jRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEmFhRURERCQRFlZEREREEpG9sIqPj4e7uzusrKzg6+uLgwcPNuq47777Dubm5ujTp49BfOPGjVAoFEZbRUXFA8ieiIiI6A+yFlZbt25FTEwM5s2bh/T0dAwdOhShoaG4cuXKHY8rLi7GuHHj8OSTT9a739bWFjk5OQablZXVg7gFIiIiIj1ZC6t3330XUVFRmDhxIrp3746VK1dCo9FgzZo1dzxu0qRJGDNmDAYOHFjvfoVCAWdnZ4ONiIiI6EGTrbCqqqrC8ePHERISYhAPCQnB999/3+BxH374IbKysrBgwYIG25SVlcHNzQ2urq54+umnkZ6efsdcKisrUVJSYrARERERNZVshVV+fj6qq6vh5ORkEHdyckJubm69x2RmZmLOnDn473//C3Nz83rbdOvWDRs3bsTOnTuRnJwMKysrDB48GJmZmQ3msnTpUqjVav2m0Wju/caIiIio1ZJ98rpCoTD4LIQwigFAdXU1xowZg7feegseHh4Nnm/AgAF48cUX0bt3bwwdOhQff/wxPDw88O9//7vBY+bOnYvi4mL9lp2dfe83RERERK1W/d0+zaB9+/YwMzMz6p3Ky8sz6sUCgNLSUqSlpSE9PR2vvvoqAKCmpgZCCJibm+Prr7/GE088YXScUqmEv7//HXusVCoVVCrVfd4RERERtXay9VhZWlrC19cXqampBvHU1FQMGjTIqL2trS1Onz6NkydP6rfo6Gh4enri5MmT6N+/f73XEULg5MmTeOSRRx7IfRARERHVka3HCgBmzpyJyMhI+Pn5YeDAgVi3bh2uXLmC6OhoALVDdFevXsWmTZugVCrRq1cvg+MdHR1hZWVlEH/rrbcwYMAAPPbYYygpKcHq1atx8uRJvP/++816b0RERNT6yFpYjR49GgUFBYiNjUVOTg569eqFlJQUuLm5AQBycnLuuqbV7YqKivDKK68gNzcXarUaffv2xYEDB9CvX78HcQtEREREegohhJA7CVNTUlICtVqN4uJi2Nrayp0OERERNYIpPL9l/1UgERERUUvBwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysiIiIiCTCwoqIiIhIIiysTExZWRliYmLg4uICKysr9OnTB1u2bLnrcdu3b0dERAS6du2KNm3aoFOnThg7diwyMzPrbV9eXo4333wTHh4eUKlUcHBwQFBQkL59aGgotFptvcceOHAAffv2Rbt27RAQEICzZ88atZk6dSoCAwMhhGjC3RMRET3czOVOgAyFh4fj2LFjWLZsGTw8PJCUlISIiAjU1NRgzJgxDR63fPlyODs7Y968eejcuTOys7OxZMkS+Pj44MiRI+jZs6e+bVlZGYKCgnDt2jXMmTMH3t7eKC4uxvfff4+bN28CAEaNGoVp06bh5s2baNu2rf7YoqIihIWFQavV4u2338bq1asRHh6OM2fOwMzMDABw5MgRJCQkID09HQqF4gF9U0RERCZIkJHi4mIBQBQXFzfrdb/88ksBQCQlJRnEg4ODhYuLi9DpdA0ee/36daPY1atXhYWFhYiKijKIT58+XVhbW4usrKwGz5efny/Mzc3Fp59+ahBPSUkR1tbWoqqqSn8NACIjI0MIIURVVZXw8vISCxYsuOO9EhERSU2u5/efcSjQhOzYsQM2NjZ47rnnDOITJkzAtWvXcPTo0QaPdXR0NIq5uLjA1dUV2dnZ+tjNmzexfv16PPfcc+jcuXOD53NwcEBgYCC2bdtmEK+oqIBKpYKFhQUAwMbGRh8HgLi4OFRVVWHu3Ll3uVsiIqKWh4WVCfnxxx/RvXt3mJsbjtB6e3vr9zfFxYsXcfnyZYNhwOPHj6O8vByPPfYYJk+eDDs7O1haWsLPzw9ffvmlwfFarRa7du1CZWWlPubn54fS0lKsWbMGRUVFWLJkCRwcHODp6YmsrCwsXrwY69atg0qlaurtExERPfRYWJmQgoIC2NvbG8XrYgUFBY0+l06nQ1RUFGxsbDBjxgx9/OrVqwBq52SdPn0amzZtwo4dO2Bra4sRI0bgq6++0rcNCwtDeXk5UlNT9TGNRoNVq1YhJiYGdnZ2WLt2LRISEtCmTRtER0cjIiICAQEBTb53IiKiloCFlYm502Tvxk4EF0IgKioKBw8exKZNm6DRaPT7ampqAACWlpbYvXs3RowYgb/97W/YtWsXHnnkESxatEjf1tnZGYMHDzYaDpw8eTIKCwuRkZGB69ev45lnnsHmzZtx6tQprFixAoWFhRg7diw6dOiALl26YO3atU35CoiIiB5a/FWgCXFwcKi3V6qwsBAA6u3Nup0QAhMnTsRHH32ExMREPPvss0bXAIBBgwahXbt2+njbtm0RGBiIzz77zKC9VqtFbGwsdDqdwRCltbU1unXrBqC2J23WrFlYtWoV7OzsEBkZicLCQly4cAE//fQTgoKC4OnpiaCgoMZ9EURERA8p9liZEC8vL2RkZECn0xnET58+DQDo1avXHY+vK6o+/PBDrF+/Hi+++KJRm7r5Wg0dr1Qa/iOh1Wpx48YN7Nu3r8HjZs2aBV9fX0RERAAAdu/ejSlTpkCtVsPf3x8hISFISUm5Y+5EREQtAQsrExIWFoaysjKjobfExES4uLigf//+DR4rhMDLL7+MDz/8EB988AEmTJhQb7tHHnkEAwcOxHfffYeSkhJ9/ObNm9i/fz8GDBhg0N7V1RX9+vUzyqnOvn378MknnyA+Pt4gl/Lycv3nsrIyLhRKREStAocCTUhoaCiCg4MxefJklJSUoGvXrkhOTsaePXvw0Ucf6RfgjIqKQmJiIrKysuDm5gYAmDZtGjZs2IC///3v8PLywpEjR/TnValU6Nu3r/5zXFwcgoKCMGzYMLzxxhtQKBR45513kJ+fbzDHqo5Wq0VcXBzi4+MNerQqKysxadIkLFy4EO7u7vr4sGHDEBsbC1tbW2RmZmLv3r14/fXXJf++iIiITI5sK2iZMDkXGCstLRXTpk0Tzs7OwtLSUnh7e4vk5GSDNuPHjxcAxKVLl/QxNzc3AaDezc3Nzeg6Bw8eFIGBgaJt27aibdu24oknnhDfffddvTldvHhRABD79+83iM+fP1/07t1b3Lp1yyCel5cnRo0aJdRqtdBoNGLlypX39mUQERE1gSksEKoQgmM0tyspKYFarUZxcTFsbW3lTsck+Pj4YMiQIVi9erXcqRAREdXLFJ7fss+xio+Ph7u7O6ysrODr64uDBw826rjvvvsO5ubm6NOnj9G+bdu2oUePHlCpVOjRowd27Nghcdatz4kTJ1hUERER3YWshdXWrVsRExODefPmIT09HUOHDkVoaCiuXLlyx+OKi4sxbtw4PPnkk0b7Dh8+jNGjRyMyMhI//PADIiMj8fzzz9/xdTBEREREUpB1KLB///7w8fHBmjVr9LHu3btj5MiRWLp0aYPHvfDCC3jsscdgZmaGzz77DCdPntTvGz16NEpKSrB79259bPjw4bCzs0NycnK956usrDR4bUtJSQk0Gg2HAomIiB4irXoosKqqCsePH0dISIhBPCQkBN9//32Dx3344YfIysrCggUL6t1/+PBho3MOGzbsjudcunQp1Gq1fvvzSuVEREREjSXbcgv5+fmorq6Gk5OTQdzJyQm5ubn1HpOZmYk5c+bg4MGDRi8qrpObm9ukcwLA3LlzMXPmTP3nuh4rk5OdDfz6KwDg+FULvHfYGq8OLIfvo7dq9zs6Aq6uMiZIRETUusm+jtXt778TQtT7Trzq6mqMGTMGb731Fjw8PCQ5Zx2VSgWVStWErGVQWQn4+wPXr0MAWK/dicuOvbE+8Wf4bHsGCgBwdgZ+/hkw9XshIiJqoWQrrNq3bw8zMzOjnqS8vDyjHicAKC0tRVpaGtLT0/Hqq68CqH2hsBAC5ubm+Prrr/HEE0/A2dm50ed8qFhaAh07Ar/+irRHh+C8Y28AwHnH3kjTBMD/6iFAo6ltR0RERLKQbY6VpaUlfH19kZqaahBPTU3FoEGDjNrb2tri9OnTOHnypH6Ljo6Gp6cnTp48qX/dy8CBA43O+fXXX9d7zoeKQgEsWgRRU4OEfrOhrKl9n6CyRoeEfrMhamqARYtq2xEREZEsZB0KnDlzJiIjI+Hn54eBAwdi3bp1uHLlCqKjowHUzn26evUqNm3aBKVSafQSYkdHR1hZWRnEp0+fjoCAACxfvhzPPvssPv/8c3zzzTc4dOhQs97bAxESgrQnJ+p7qwCgRmle22v15ET43zZpn4iIiJqXrIXV6NGjUVBQgNjYWOTk5KBXr15ISUnRv/8uJyfnrmta3W7QoEHYsmUL5s+fj3/+85/o0qULtm7descXGD8sBFDbW1WoQ43yj791db1WfgDYX0VERCQfvtKmHqawDkZ9jp39DW+892uD+5e/2gH+Pdo0Y0ZERESmwxSe37K/0oYaRwiBhC+KG5xCpVAACV8Ug3UyERGRfFhYPSRu6YC8Qh0aqpuEAPJu6HBL17x5ERER0R9kX8eKGsfSQoE1bzijqKymNnD0KLBiBfD//h/w+/wxu3ZKWFpwlhUREZFcWFg9RBztzeFo//uHjkOB54bKmg8REREZ4lAgERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWBERERFJhIUVERERkURkL6zi4+Ph7u4OKysr+Pr64uDBgw22PXToEAYPHgwHBwe0adMG3bp1w7/+9S+DNhs3boRCoTDaKioqHvStEBERUStnLufFt27dipiYGMTHx2Pw4MH44IMPEBoairNnz6Jjx45G7a2trfHqq6/C29sb1tbWOHToECZNmgRra2u88sor+na2trY4f/68wbFWVlYP/H6IiIiodVMIIYRcF+/fvz98fHywZs0afax79+4YOXIkli5d2qhzhIeHw9raGps3bwZQ22MVExODoqKiRudRWVmJyspK/eeSkhJoNBoUFxfD1ta20echIiIi+ZSUlECtVsv6/JZtKLCqqgrHjx9HSEiIQTwkJATff/99o86Rnp6O77//HoGBgQbxsrIyuLm5wdXVFU8//TTS09PveJ6lS5dCrVbrN41G07SbISIiIoKMhVV+fj6qq6vh5ORkEHdyckJubu4dj3V1dYVKpYKfnx+mTp2KiRMn6vd169YNGzduxM6dO5GcnAwrKysMHjwYmZmZDZ5v7ty5KC4u1m/Z2dn3d3NERETUKsk6xwoAFAqFwWchhFHsdgcPHkRZWRmOHDmCOXPmoGvXroiIiAAADBgwAAMGDNC3HTx4MHx8fPDvf/8bq1evrvd8KpUKKpXqPu+EiIiIWjvZCqv27dvDzMzMqHcqLy/PqBfrdu7u7gAALy8vXL9+HQsXLtQXVrdTKpXw9/e/Y48VERERkRRkGwq0tLSEr68vUlNTDeKpqakYNGhQo88jhDCYeF7f/pMnT+KRRx6551yJiIiIGkPWocCZM2ciMjISfn5+GDhwINatW4crV64gOjoaQO3cp6tXr2LTpk0AgPfffx8dO3ZEt27dANSuaxUXF4fXXntNf8633noLAwYMwGOPPYaSkhKsXr0aJ0+exPvvv9/8N0hEREStiqyF1ejRo1FQUIDY2Fjk5OSgV69eSElJgZubGwAgJycHV65c0bevqanB3LlzcenSJZibm6NLly5YtmwZJk2apG9TVFSEV155Bbm5uVCr1ejbty8OHDiA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tGnTBt26dcO//vUvo3bbtm1Djx49oFKp0KNHD+zYseNB3gIRERERAJkLq61btyImJgbz5s1Deno6hg4ditDQUFy5cqXe9tbW1nj11Vdx4MABZGRkYP78+Zg/fz7WrVunb3P48GGMHj0akZGR+OGHHxAZGYnnn38eR48eba7bIiIiolaqSa+0kVr//v3h4+ODNWvW6GPdu3fHyJEjsXTp0kadIzw8HNbW1ti8eTMAYPTo0SgpKcHu3bv1bYYPHw47OzskJyfXe47KykpUVlbqP5eUlECj0fCVNkRERA8RU3iljWw9VlVVVTh+/DhCQkIM4iEhIfj+++8bdY709HR8//33CAwM1McOHz5sdM5hw4bd8ZxLly6FWq3WbxqNpgl3QkRERFRLtsIqPz8f1dXVcHJyMog7OTkhNzf3jse6urpCpVLBz88PU6dOxcSJE/X7cnNzm3zOuXPnori4WL9lZ2ffwx0RERFRa9ekdwU+CLe/1FkIcdcXPR88eBBlZWU4cuQI5syZg65duyIiIuKez6lSqaBSqe4heyIiIqI/yFZYtW/fHmZmZkY9SXl5eUY9Trdzd3cHAHh5eeH69etYuHChvrBydna+p3MSERER3S/ZhgItLS3h6+uL1NRUg3hqaioGDRrU6PMIIQwmng8cONDonF9//XWTzklERER0L2QdCpw5cyYiIyPh5+eHgQMHYt26dbhy5Qqio6MB1M59unr1KjZt2gQAeP/999GxY0d069YNQO26VnFxcXjttdf055w+fToCAgKwfPlyPPvss/j888/xzTff4NChQ81/g0RERNSqyFpYjR49GgUFBYiNjUVOTg569eqFlJQUuLm5AQBycnIM1rSqqanB3LlzcenSJZibm6NLly5YtmwZJk2apG8zaNAgbNmyBfPnz8c///lPdOnSBVu3bkX//v2b/f6IiIiodZF1HStTZQrrYBAREVHTmMLzW/ZX2hARERG1FCysyKSUlZUhJiYGLi4usLKyQp8+fbBly5a7Hvf4449DoVA0uP35l6K7du3CuHHj4OXlBQsLi3qX4ggNDYVWq633WgcOHEDfvn3Rrl07BAQE4OzZs0Ztpk6disDAQLBDmIiodZF9HSuiPwsPD8exY8ewbNkyeHh4ICkpCREREaipqcGYMWMaPC4+Ph4lJSUGsZs3b2L48OHw9fWFs7OzPr5jxw4c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ruw+atQo5OXl6X85WGfx4sVo27YtZsyYYRBftWoVevbsiTFjxuCdd97Bu+++e8d86qMQTe3jagVKSkqgVqtRXFwMW1tbudMhIqIH4auvcOzlJXjj996qP1u+KxL+//kHMGyYDInRvarv+e3j44MhQ4Y029phHAokIqJWSQQHIyHIAsoancGLr5U1OiQELYBf8OPgWxkffidOnGjW63EokIiIWqW0c5U4b93VoKgCgBqlOc5bd0XaucoGjiRqGAsrIiJqdYQQSPiiGA2tW6lQAAlfFDf5F2FELKyIiKjVuaUD8gp1aKhuEgLIu6HDLV39+4kawjlWRETU6lhaKLDmDWcUldXUVlHjxwFnzgI9ewCJmwCFAnbtlLC04CyrB+H4uQq893EhXn3eHr7drOROR1IsrIiIqFVytDeHY92bVua/DEybVvunG9eteiCys4Fff4UQwPrP1bicb4H1SVfh8+zvQ7KOjoCrq9xZ3jcWVkRERE89BZw9K3cWLVcrWpCVc6yIiIjowWpFC7KysCIiIqIHS6EAFi1C2qNDcN6xt36JixqlOc479kbao0OARYvQ4M80HyIcCiQiIqIHrrUsyMoeKyIiInrgWsuCrCysiIiI6IFqTQuysrAiIiKiB6o1LcjKOVZERET0QLWmBVlZWBEREdED11oWZGVhRURERM2rBS/IyjlWRERERBJhYUVEREQkERZWRERERBJhYUVEREQkERZWRERERBJhYUVEREQkERZWRERERBJhYUVEREQkERZWRERERBJhYUVEREQkEb7Sph7i99dvl5SUyJwJERERNVbdc7vuOS4HFlb1KC0tBQBoNBqZMyEiIqKmKi0thVqtluXaCiFnWWeiampqcO3aNbRr1w4KhaLRx5WUlECj0SA7Oxu2trYPMEMC+H03N37fzYvfd/Pi9928HtT3LYRAaWkpXFxcoFTKM9uJPVb1UCqVcHV1vefjbW1t+S9mM+L33bz4fTcvft/Ni99383oQ37dcPVV1OHmdiIiISCIsrIiIiIgkwsJKQiqVCgsWLIBKpZI7lVaB33fz4vfdvPh9Ny9+382rJX/fnLxOREREJBH2WBERERFJhIUVERERkURYWBERERFJhIUVERERkURYWEkkPj4e7u7usLKygq+vLw4ePCh3Si3WgQMHMGLECLi4uEChUOCzzz6TO6UWa+nSpfD3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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.01),size=12)\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"MF-X-1.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "418c7110",
   "metadata": {},
   "source": [
    "### Estimating $\\mathbf{Y}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9ba2b2a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "E_Oracle = np.zeros((8, 10))\n",
    "E_RIE = np.zeros((8, 10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": 13,
   "id": "7affd5e1",
   "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": 16,
   "id": "fa2c66a6",
   "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(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.01),size=12)\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\kappa$')\n",
    "plt.ylabel('MSE')\n",
    "# tikzplotlib.save(\"MF-Y-1.tex\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e117ab6e",
   "metadata": {},
   "source": [
    "### Estimating $\\mathbf{X}\\mathbf{Y}$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 11,
   "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": 12,
   "id": "d6b68266",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MSE')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAGwCAYAAABVdURTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA6j0lEQVR4nO3df3QU9b3/8ddskg0QSBRiAkgSUlBKoYAkiIFiRSSV41EpXIy1F0ShgoBeSEXgSyvyo41HLUUvTQpiSmkVUgxabdGa21b5EfCYCMoRjFrAREgI4UcCWvJjd75/xGxZ8oOE7O4kk+fjnDk6M5/Zfe+K7svPfObzMUzTNAUAAGATDqsLAAAA8CXCDQAAsBXCDQAAsBXCDQAAsBXCDQAAsBXCDQAAsBXCDQAAsJVgqwsINLfbrePHj6tbt24yDMPqcgAAQDOYpqlz586pd+/ecjia7pvpcOHm+PHjiomJsboMAABwBYqKitSnT58m23S4cNOtWzdJtV9OeHi4xdUAAIDmqKioUExMjOd3vCkdLtzU3YoKDw8n3AAA0M40Z0gJA4oBAICtEG4AAICtEG4AAICtdLgxNwAANJfL5VJ1dbXVZXQYTqfzso95NwfhBgCAS5imqZKSEp09e9bqUjoUh8Oh+Ph4OZ3OVr0O4QYAgEvUBZuoqCh16dKFSV8DoG6S3eLiYsXGxrbqOyfcAABwEZfL5Qk2PXr0sLqcDuWaa67R8ePHVVNTo5CQkCt+HQYUAwBwkboxNl26dLG4ko6n7naUy+Vq1esQbgAAaAC3ogLPV985t6UAAPATs6pKFWlpkqTwJUtktHKgLJqHnptWyti9Vev2ZDd4bt2ebGXs3hrgigAA6NgIN63kcDiU3kDAWbcnW+m7t/rkeX0AQDtTVCR98IG0b58cx4/Lcfy4tG9f7bEPPpC+/NLqCv2ib9++WrNmjdVlcFuqtWYlTZYkpX/TQzMrabIn2MwZPcVzHgDQQVRWSiNGSCdOyJDkWcN6/fr/tOnZUzp6VAoN9fnbFxUV6cknn9Sbb76psrIy9erVSxMnTtQTTzzRYZ7+Itz4wMUB54W9r6raVUOwAYCOyumUYmOlkyclt7v+eYdDiompbedjhw8fVlJSkq6//npt3rxZ8fHx+vjjj7Vw4UK9+eab2rt3r7p3717vuqqqqlZPnNeWcM/ER2YlTVZIULCqXTUKCQom2ABAR2UY0sqVDQcbqfb4ypW17Xxs7ty5cjqdevvtt/X9739fsbGxmjBhgv7v//5Px44d09KlSyXV3j5atWqVpk+froiICP3kJz+RJC1atEjXX3+9unTpom9961v6+c9/Xm/5iddff12JiYnq1KmTIiMjNWnSpEbrKS8v10MPPaSoqCiFh4fr1ltv1Ycffujzz30pwo2PrNuT7Qk21a6aRgcZAwA6gORkacQImUFB3seDgmpvWSUn+/wtT58+rb/97W+aM2eOOnfu7HWuZ8+e+vGPf6ysrCyZpilJeuaZZzR48GDl5+fr5z//uSSpW7du2rhxow4ePKjnnntOL7zwgn796197Xuevf/2rJk2apDvuuEP79u3T3//+dyUmJjZYj2mauuOOO1RSUqLt27crPz9fw4cP17hx43T69Gmff/6LcVvKBy4dY1O3L4keHADoiL7pvTFuv937uMvlt16bzz77TKZpauDAgQ2eHzhwoM6cOaOTJ09Kkm699VY99thjXm1+9rOfef6+b9+++ulPf6qsrCw9/vjjkqRf/OIXuvfee7V8+XJPu6FDhzb4fv/85z914MABlZaWKvSbsUXPPvusXnvtNb3yyit66KGHrvzDXgbhppUuDjaJV9+hB1Yc17x77tCc0SLgAEBHlpwsMyFB+uADGaYpMyhIxvDhfum1aY66Hpu6ifIa6nF55ZVXtGbNGn3++ec6f/68ampqFB4e7jm/f/9+zy2sy8nPz9f58+frDWL+97//rX/9619X+jGahXDTSm63W3NGT9FDN03SnKdP6IuSGm3481mlPz7Jcx4A0AEZhvTkkzLuvLN214+9NpLUv39/GYahgwcPauLEifXOf/LJJ7r66qsVGRkpSQoLC/M6v3fvXk+vzA9+8ANFRERoy5Yt+tWvfuVpc+ntrqa43W716tVL77zzTr1zV111VbNf50oQblrp4dFTJEnvH/y3Cr6okiQVfFGlvEMX6LEBgI5u/HjV9O6t4OPHZSYkyPBjr02PHj00fvx4paena8GCBV5BpKSkRC+99JKmTZvW6BIHu3fvVlxcnGfQsSR98cUXXm2GDBmiv//973rggQcuW8/w4cNVUlKi4OBg9e3b98o+1BViQHFrFRXJzP9AmVuOy2HUdvk5DFOZW47LzLfvRE0AgGYwDF0YN06uyEi/9trUWbt2rSor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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-1.tex\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "136af930",
   "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
}
