{
 "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": "9150bf96",
   "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": [
    "### Wigner"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "df5b6ebb",
   "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",
    "E_sqXXRIE = np.zeros((8, 10))\n",
    "\n",
    "prior = \"Wigner\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "45d4eee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('X-'+prior+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('X-'+prior+'_SNR='+str(SNR_list[i])+'_RIE.npy')\n",
    "    E_sqXXRIE[i,:] = np.load('X-'+prior+'_SNR='+str(SNR_list[i])+'_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3d0b942b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MMSE')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkkAAAGxCAYAAAB2qSLdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABCTElEQVR4nO3de1yUZf7/8fcwCuQB+uYBBgHFrBaTDsJmWLNZKYp+3Vy0tJP2U+vrpslh3fVcZhn73U7oFroppu63FVvEcotN2TaJVjto2FpS2YqBNGS4K2gWxjC/P2aZdeQWAYEb8PV8POahc83nnvua6dFj3l7XdV+3xeVyuQQAAAAvPmZ3AAAAoC0iJAEAABggJAEAABggJAEAABggJAEAABggJAEAABggJAEAABjoZHYH2quamhp99dVX6t69uywWi9ndAQAADeByuXT8+HGFhITIx6f+sSJCUhN99dVXCgsLM7sbAACgCUpKShQaGlpvDSGpibp37y7J/SUHBASY3BsAANAQlZWVCgsL8/yO14eQ1ES1U2wBAQGEJAAA2pmGLJVh4TYAAIABQhIAAIABQhIAAIAB1iQBANDCnE6nfvjhB7O7cUHo3LmzrFZrs7wXIQkAgBbicrlUVlamY8eOmd2VC8rFF1+s4ODg897HkJAEAEALqQ1IvXv3VpcuXdh8uIW5XC6dPHlSR44ckSTZbLbzej9CEgAALcDpdHoCUo8ePczuzgXjoosukiQdOXJEvXv3Pq+pNxZuAwDQAmrXIHXp0sXknlx4ar/z810HRkgCAKAFMcXW+prrO2e6DQCANsx16pQqU1MlSQHz58vi62tyjy4chKS2xumU8vMlh0Oy2SS7XWqmSxkBAEDDMd3WlmRnS/36STffLN11l/vPfv3c7QCAC5Kzxql8FSlL+7Tjyzw5a5xmd6nF9evXT2lpaWZ3g5DUZmRnSxMmSIcPe7eXlrrbCUoAcMHJLsxWRPplGqv1mq7NuuUPceq3vJ+yC1v+N6GkpETTpk1TSEiIfH191bdvXyUmJuro0aMtfu62wvSQlJ6eroiICPn7+ys6Olr5+fn11ufl5Sk6Olr+/v7q37+/Vq1aVacmLS1NV1xxhS666CKFhYUpOTlZ33//vef1JUuWyGKxeD2Cg4Ob/bM1mNMpJSZKLlfd12rbkpLcdQCAC0J2YbYmvDxBh4+XerWXVpZqwssTWjQoHTx4UDExMfr888+1ceNGffHFF1q1apXefPNNxcbG6p///KfhcadOnWqxPpnB1JC0adMmJSUlaeHChSooKJDdbld8fLyKi4sN64uKijR69GjZ7XYVFBRowYIFmj17tjZv3uypeemllzRv3jw98sgjKiwsVEZGhjZt2qT58+d7vdeVV14ph8Pheezbt69FP2u98vPrjiCdzuWSSkrcdQCADs9Z41TiG4lyqe4/nmvbkt5IarGpt5kzZ8rX11fbt2/XTTfdpPDwcMXHx+svf/mLSktLtXDhQknuabHHH39c9913nwIDA3X//fdLkubOnavLL79cXbp0Uf/+/bV48eI6l+Nv3bpVMTEx8vf3V8+ePZWQkHDW/lRUVOiBBx5Q7969FRAQoFtuuUUfffRRi3z205kakp555hlNmzZN06dPV2RkpNLS0hQWFqaVK1ca1q9atUrh4eFKS0tTZGSkpk+frqlTp+qpp57y1OzatUs33HCD7rrrLvXr109xcXG68847tXv3bq/36tSpk4KDgz2PXr16tehnrZfD0bx1AIB2Lb84X4crz/6PZ5dcKqksUX5x8//j+Z///Ke2bdumBx980LMxY63g4GDdfffd2rRpk1z/nul48sknNWjQIO3Zs0eLFy+WJHXv3l3r1q3T/v37tXz5cq1evVrPPvus531ef/11JSQkaMyYMSooKNCbb76pmJgY48/qcmnMmDEqKytTTk6O9uzZo8GDB+vWW28964hWczEtJJ06dUp79uxRXFycV3tcXJx27txpeMyuXbvq1I8cOVK7d+/2JNQbb7xRe/bs0fvvvy/JPWSYk5OjMWPGeB134MABhYSEKCIiQpMmTdLBgwfr7W9VVZUqKyu9Hs2modumn+f26gCA9sFxvGH/KG5oXWMcOHBALpdLkZGRhq9HRkbqX//6l7755htJ0i233KI5c+ZowIABGjBggCRp0aJFGjp0qPr166exY8fqF7/4hV5++WXPeyxbtkyTJk3So48+qsjISF199dVasGCB4fneeust7du3T3/84x8VExOjyy67TE899ZQuvvhiZWVlNfOn92baFgDl5eVyOp0KCgryag8KClJZWZnhMWVlZYb11dXVKi8vl81m06RJk/TNN9/oxhtvlMvlUnV1tX7+859r3rx5nmOGDBmiDRs26PLLL9fXX3+txx9/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NWDAAF111VVasWKFqqqq9Oijj9Z7TM+ePTVgwACvx0UXXdRifWxphCQAANoau919FZulzookN4tFCgtz17WSRx55RE899ZS++uqrVjun2QhJAAC0NVar+zJ/Sa4zg1Lt87Q0d10rGTZsmK688ko98cQTZ605fvy4ysrKvB6VlZWt1sfmRkgCAKAtSkhwX+YfEuLdHhra4pf/n01KSopWr16tkpISw9cffvhh2Ww2r8evfvWrVu5l87G4XGduwICGqKysVGBgoCoqKhQQEGB2dwAAbcz333+voqIiRUREyN/fv8nv4/ruO33785/L58QJXfQ//yPLLbe06ghSe1Tfd9+Y32+ubgMAoC2zWuWMiJBT0kU33URAakWEJAAA2jCLr68CH3nE7G5ckFiTBAAAYICQBAAAYICQBAAAYICQBAAAYICQBAAAYICQBAAAYICQBABAG/btt+47kVgs7r+j9RCSAAAADBCSAABow5zO//z97be9n7c1TqdTQ4cO1fjx473aKyoqFBYWpkWLFkmScnJy5Ovrqw8//NCr7qmnnlLPnj1VVlbWan2uDyEJAIA2KjtbGjjwP89Hj5b69XO3t0VWq1Xr16/XG2+8oZdeesnT/tBDD+mSSy7Rww8/LEkaPXq0Jk+erMmTJ6uqqkqSVFhYqMWLF+v5559XcHCwKf0/EyEJAIA2KDtbmjBBKi31bi8tdbe3ZFDKyspSVFSULrroIvXo0UPDhw/Xt99+K6fTqZSUFF188cXq0aOHfvWrX2nKlCkaN26c59jLLrtMqampeuihh/TVV1/p1VdfVWZmptavXy9fX19P3bPPPqsTJ07okUceUXV1tSZPnqyxY8dq4sSJLffBGomQBABAG+N0SomJkstV97XatqSklpl6czgcuvPOOzV16lQVFhZqx44dSkhIkMvl0tNPP621a9cqIyND77zzjv75z39qy5Ytdd7joYce0tVXX63JkyfrgQce0MMPP6xrrrnGq6Z79+5au3atnn76ad19990qKSlRenp683+g88ANbgEAaGPy86XDh8/+ussllZS464YNa95zOxwOVVdXKyEhQX379pUkRUVFSZLS0tI0f/58z5qjVatWadu2bXXew2KxaOXKlYqMjFRUVJTmzZtneK5bbrlFEyZMUGZmpjZt2qSePXs274c5T4wkAQDQxjgczVvXGFdffbVu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ElNvAAA0hKlbAEycOFFHjx7V0qVL5XA4NGjQIOXk5Khv376SJIfD4bVnUkREhHJycpScnKznn39eISEhWrFihefy/1qff/653nnnHW3fvt3wvIcPH9add96p8vJy9erVS9dff73effddz3nbq/z8uiNIp3O5pJISd92wYa3WLQAA2iWLy2U07oBzqaysVGBgoCoqKhQQEGB2dyS5F2nfdde56/7wB+nOO1u+PwAAtDWN+f02/eo2NJ+GLqnqAEuvAABocYSkDsRud1/FdrYdFCwWKSzMXQcAAOpHSOpArFb3Zf5S3aBU+zwtzV0HAADqR0jqYBISpKwsqU8f7/bQUHc7+yQBANAwpl7dhpaRkCDddpv7KjaHw70GyW5nBAkAgMYgJHVQViuX+QMAcD6YbgMAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADDQqJD0m9/8Rt99953n+dtvv62qqirP8+PHj+vBBx9svt6h6ZxOaccOaeNG959Op9k9AgCgXbG4XC5XQ4utVqscDod69+4tSQoICNDevXvVv39/SdLXX3+tkJAQOS+AH+TKykoFBgaqoqJCAQEBZnfHW3a2lJgoHT78n7bQUGn5cikhwbx+AQBgssb8fjdqJOnMPNWIfHVW6enpioiIkL+/v6Kjo5Wfn19vfV5enqKjo+Xv76/+/ftr1apVXq8PGzZMFoulzmPMmDHndd52IztbmjDBOyBJUmmpuz0725x+AQDQzpi6JmnTpk1KSkrSwoULVVBQILvdrvj4eBUXFxvWFxUVafTo0bLb7SooKNCCBQs0e/Zsbd682VOTnZ0th8PheXz88ceyWq26/fbbm3zedsPpdI8gGYXX2rakJKbeAABogEZNt/n4+KisrMwz3da9e3d99NFHTZ5uGzJkiAYPHqyVK1d62iIjIzVu3DilpqbWqZ87d662bt2qwsJCT9uMGTP00UcfadeuXYbnSEtL08MPPyyHw6GuXbs26bySVFVV5bX+qrKyUmFhYW1rum3HDunmm89d99Zb0rBhLd0bAADanMZMt3Vq7JuvWbNG3bp1kyRVV1dr3bp16tmzpyT3wu2GOnXqlPbs2aN58+Z5tcfFxWnnzp2Gx+zatUtxcXFebSNHjlRGRoZ++OEHde7cuc4xGRkZmjRpkicgNeW8kpSamqpHH320QZ/NNA5H89YBAHABa1RICg8P1+rVqz3Pg4OD9fvf/75OTUOUl5fL6XQqKCjIqz0oKEhlZWWGx5SVlRnWV1dXq7y8XDabzeu1999/Xx9//LEyMjLO67ySNH/+fKWkpHie144ktSlnfP7zrgMA4ALWqJB06NChZu+AxWLxeu5yueq0naveqF1yjyINGjRI11133Xmf18/PT35+fmd9vU2w23UyqIf8vz5quNisRtL3wT3UxW5v7Z4BANDumLZwu2fPnrJarXVGb44cOVJnlKdWcHCwYX2nTp3Uo0cPr/aTJ08qMzNT06dPP+/zthdOi5QY7/57zRmv1T5PGuWuAwAA9WtUSHrvvff05z//2attw4YNioiIUO/evfXAAw94LW6uj6+vr6Kjo5Wbm+vVnpubq6FDhxoeExsbW6d++/btiomJqbMe6eWXX1ZVVZXuueee8z5ve5FfnK81/Y5qwh1S6Rlr0Q4HSBPukFb3O6r84g6y3QEAAC2oUdNtS5Ys0bBhwxQf7x6u2Ldvn6ZNm6b77rtPkZGRevLJJxUSEqIlS5Y06P1SUlJ07733KiYmRrGxsXrhhRdUXFysGTNmSHKvAyotLdWGDRskua9ke+6555SSkqL7779fu3btUkZGhjZu3FjnvTMyMjRu3Lg6I0wNOW975TjuXpC9ZaD06o8k+5eS7YTk6Cbl95VqfLzrAADA2TUqJO3du1ePPfaY53lmZqaGDBniWcwdFhamRx55pMEhaeLEiTp69KiWLl0qh8OhQYMGKScnR3379pUkORwOr72LIiIilJOTo+TkZD3//PMKCQnRihUrNH78eK/3/fzzz/XOO+9o+/btTTpve2Xr/p8F2TU+Ul7EuesAAICxRu2T5O/vrwMHDniu6rrxxhs1atQoLVq0SJJ7YXdUVFSjtgJor9ribUmcNU71W95PpZWlcqnuf1aLLAoNCFVRYpGsPlYTeggAgLla7LYkQUFBKioqkuTeb+jDDz9UbGys5/Xjx48b7lWE1mH1sWr5qOWS3IHodLXP00alEZAAAGiARoWkUaNGad68ecrPz9f8+fPVpUsX2U+7nPzvf/+7Lr300mbvJBouITJBWXdkqU9AH6/20IBQZd2RpYRIbnALAEBDNGpN0uOPP66EhATddNNN6tatm9avXy9fX1/P62vXrq2zIzZaX0Jkgm674jblF+fLcdwhW3eb7OF2RpAAAGiERq1JqlVRUaFu3brJavX+0f3nP/+pbt26eQWnjqotrkkCAAD1a9F7t0lSYGCgYfsll1zSlLcDAABocxoVkqZOndqgurVr1zapMwAAAG1Fo0LSunXr1LdvX1177bVqwiwdAABAu9GokDRjxgxlZmbq4MGDmjp1qu655x6m2AAAQIfUqC0A0tPT5XA4NHfuXP3pT39SWFiY7rjjDm3bto2RJQAA0KE06eq2Wl9++aXWrVunDRs26IcfftD+/fvVrVu35uxfm8XVbQAAtD8ttuP2mSwWiywWi1wul2pqas7nrQAAANqURoekqqoqbdy4USNGjNAVV1yhffv26bnnnlNxcfEFM4oEAAA6vkYt3H7wwQeVmZmp8PBw/b//9/+UmZmpHj16tFTfAAAATNOoNUk+Pj4KDw/XtddeK4vFcta67OzsZulcW8aaJAAA2p8W23F78uTJ9YYjAACAjqLRm0kCAABcCJr9tiQWi0UZGRlN7hAAAEBbwG1JAAAADHBbEgAAAAPclgQAAMAAtyVpIrYAAACg/eG2JAAAAOeJ25IAAAAY4LYkAAAABrgtSROxJgkAgPaH25IAAACcJ25LAgAAYOC8rm4DAADoqAhJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABghJAAAABhp1g1vgbJxOKT9fcjgkm02y2yWr1exeAQDQdKaPJKWnpysiIkL+/v6Kjo5Wfn5+vfV5eXmKjo6Wv7+/+vfvr1WrVtWpOXbsmGbOnCmbzSZ/f39FRkYqJyfH8/qSJUtksVi8HsHBwc3+2S4U2dlSv37SzTdLd93l/rNfP3c7AADtlakjSZs2bVJSUpLS09N1ww036He/+53i4+O1f/9+hYeH16kvKirS6NGjdf/99+v//u//9Le//U0PPvigevXqpfHjx0uSTp06pREjRqh3797KyspS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0QcffKDly5frd7/7nck963j27NmjI0eOKDo62tPmdDr19ttv67nnnlNVVZWsVquJPezYunbtqqioKB04cMCU87MmqRX4+voqOjpaubm5Xu25ubkaOnSoSb0CmofL5dKsWbOUnZ2tv/71r4qIiDC7Sxccl8ulqqoqs7vRId16663at2+f9u7d63nExMTo7rvv1t69ewlILayqqkqFhYWy2WymnJ+RpFaSkpKie++9VzExMYqNjdULL7yg4uJizZgxw+yudUgnTpzQF1984XleVFSkvXv36pJLLlF4eLiJPet4Zs6cqT/84Q969dVX1b17d8+IaWBgoC666CKTe9fxLFiwQPHx8QoLC9Px48eVmZmpHTt26I033jC7ax1S9+7d66yv69q1q3r06MG6uxYwZ84cjR07VuHh4Tpy5Igef/xxVVZWasqUKab0h5DUSiZOnKijR49q6dKlcjgcGjRokHJyctS3b1+zu9Yh7d69WzfffLPnee1c9pQpU7Ru3TqTetUx1W5rMWzYMK/2F198Uffdd1/rd6iD+/rrr3XvvffK4XAoMDBQV111ld544w2NGDHC7K4B5+3w4cO68847VV5erl69eun666/Xu+++a9pvJfskAQAAGGBNEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgAAgAFCEgCcZtGiRfLz89Ndd91ldlcAmIzbkgDAaSorK/X73/9es2bN0oEDBzRgwACzuwTAJIwkAcBpAgICNHXqVPn4+Gjfvn1mdweAiQhJAHCG6upqdenSRR9//LHZXQFgIkISAJxh0aJFOnHiBCEJuMCxJgkATrNnzx4NHTpUI0aMUFFRkT755BOzuwTAJIQkAPi3mpoaXXfddbrppps0ZMgQ3X333fr222/l6+trdtcAmIDpNgD4t9/+9rf65ptvtHTpUkVFRam6ulqfffaZ2d0CYBJCEgBIKi0t1eLFi5Wenq6uXbvqsssuk5+fH+uSgAsYIQkAJM2ePVvx8fEaM2aMJKlTp06KjIwkJAEXsE5mdwAAzPbaa6/pr3/9qwoLC73ao6KiCEnABYyF2wAAAAaYbgMAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADBASAIAADDw/wH+VduZ8KrMuAAAAABJRU5ErkJggg==\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='o', color='green',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(SNR_list, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='o', color='red',ecolor='lightcoral',label='RIE')\n",
    "plt.errorbar(SNR_list, E_sqXXRIE.mean(1), yerr=E_sqXXRIE.std(1), fmt='o', color='blue',ecolor='blue',label='sqXX')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlabel(r'$\\lambda$')\n",
    "plt.ylabel('MMSE')"
   ]
  }
 ],
 "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
}
