{
 "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": "0d7c7e2c",
   "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": "b1d22869",
   "metadata": {},
   "source": [
    "### Wigner"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5056771",
   "metadata": {},
   "source": [
    "#### Estimating $\\mathbf{X}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e4e97afc",
   "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",
    "sparsity = 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7ef8eab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(8):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('X-Bernoulli_sparsity_'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('X-Bernoulli_sparsity_'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_RIE.npy')\n",
    "    E_sqXXRIE[i,:] = np.load('X-Bernoulli_sparsity_'+str(sparsity)+'_SNR='+str(SNR_list[i])+'_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7790cec3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'MMSE')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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4+3Z856++ipHb799TA6Hv664QnryySe1ZcsWbdy4Uffcc09jv3KdWtSVm7CwMBUVFXm0HTt2TG3atDFlimy7vfIRTqnmo25V62lpF37s0Fv7qS9fH6+l1mRlnG/f4nz7VlWYrOsRZJtNioxsujAZ3qF+qam+/bzl3IsB8fE1r7hs3LhR119/vcLCwhQUFKSHH35YeXl51Z/v379fQ4YM8dgmKKjyse9z/fvfe/Xjj6d0442d9etfByk8PEhBQUHKzc3V119/7cVvVlOLCjcJCQnKysryaHv77bcVHx/fqHdQNEZysrRxo9Stm2d7RERle33nrvDWfurL18drqTVZGefbtzjfvmN2mEyMSlREcIRsqj1d2WRTZHCkEqO8m6569uwpm82mAwcO1Pr5v//9b/3iF79QSEiIJKl9+/Yen+/atUu33367hg0bpjfeeEP79u3TvHnzPAYbn3u7S/pPWDxXRUWFQkLCtXbtfmVn79f+/ZXL559/rtmzZzfim16YqbelTp06pa+++qp6PTc3V/v371enTp0UFRWluXPnqqCgQGvWrJEkTZ48WcuXL1dKSoruvvtuffTRR3rxxRe1bt06s76CpMp/lEaMaPxEUd7aT3M9Xkutyco4377F+fadqjBZ26SJaWlNGybtfnal35SuUX8bJZtsHgOLqwJP2k1psvt59z98586dNXToUGVkZOi+++7zCCJFRUVau3atxo4dW+cwjg8++EDR0dHVg44l6dtvv/Xo07t3b73zzju66667PNp/8QupRw/PMPlf/9VPJ04U6dJL26hPn+6N/4INUf+pdbzvvffeMyTVWMaNG2cYhmGMGzfOGDhwoMc227dvN6666irD4XAY3bt3N30SPwBA81VebhjvvWcYr7xS+X/L6zGHnrcm8dt0YJMR8VQ3Q4+oeolcGmlsOtB0MzZ+8cUXRkhIiJGYmGjs2LHDyMvLM958802jV69exmWXXWacOHHCMAzDiI6ONp5++mmPbbds2WK0adPGWLdunfHVV18Z6enpRqdOnQyn01nd57333jP8/PyM+fPnGwcOHDA+/fRT4/HHH6/+PDo62khNfdo4ftwwXK4K4/rrrzf69OljbNu2zcjNzTU++OADY968ecbu3btrrd9bk/iZGm7MQLgBAJxPS5+h+JtvvjHGjx9vhIWFGW3btjUiIyON6dOnG8eP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RkZ69XsAAIDmxfQBxTabzWPdMIwabVUOHDigGTNmaP78+dq7d6+2bdum3NxcTZ48uc79z507Vy6Xq3rJz8/3av0AAKB5aWPWgUNCQmS322tcpTl27FiNqzlVUlNTdd1112n27NmSpN69e6t9+/ZKTEzU4sWLFR4eXmMbf39/+fv7e/8LAACAZsm0KzcOh0P9+/dXVlaWR3tWVpYGDBhQ6zZnzpyRn59nyXa7XVLlFR8AAABTb0ulpKRo5cqVWrVqlQ4ePKj77rtPeXl51beZ5s6dq7Fjx1b3Hz58uDIzM7VixQodOnRIH3zwgWbMmKGrr75aXbt2NetrAACAZsS021KSNHr0aJ04cUKLFi1SYWGhevXqpa1btyo6OlqSVFhY6DHnzfjx41VSUqLly5frj3/8ozp27KjBgwfr8ccfN+srAACAZsZmtLL7OcXFxXI6nXK5XAoODja7HAAAUA8N+f02/WkpAAAAbyLcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAAS2lQuHniiSf0448/Vq/v3LlTpaWl1eslJSWaMmVKgwrIyMhQTEyMAgIC1L9/f2VnZ5+3f2lpqebNm6fo6Gj5+/urR48eWrVqVYOOCQAArMtmGIZR3852u12FhYXq0qWLJCk4OFj79+/XpZdeKkk6evSounbtKrfbXa/9bdiwQXfeeacyMjJ03XXX6bnnntPKlSt14MABRUVF1brNiBEjdPToUS1evFg9e/bUsWPHVF5ergEDBtTrmMXFxXI6nXK5XAoODq7XNgAAwFwN+f1u05Adn5uDGpCLarV06VJNnDhRkyZNkiSlpaXprbfe0ooVK5Samlqj/7Zt27Rjxw4dOnRInTp1kiR17969UTUAAABrMW3MTVlZmfbu3aukpCSP9qSkJH344Ye1bvP6668rPj5eTzzxhLp166bLL79c999/v8etsnOVlpaquLjYYwEAANbVoCs33nT8+HG53W6FhoZ6tIeGhqqoqKjWbQ4dOqT3339fAQEB2rx5s44fP64pU6bo+++/r3PcTWpqqhYuXOj1+gEAQPPU4HCzcuVKBQUFSZLKy8u1evVqhYSESKocUNxQNpvNY90wjBptVSoqKmSz2bR27Vo5nU5Jlbe2Ro0apb/85S9q165djW3mzp2rlJSU6vXi4mJFRkY2uE4AANAyNCjcREVF6YUXXqheDwsL01//+tcafeojJCREdru9xlWaY8eO1biaUyU8PFzdunWrDjaSFBsbK8MwdPjwYV122WU1tvH395e/v3+9agIAAC1fg8LNN99847UDOxwO9e/fX1lZWfrtb39b3Z6VlaURI0bUus11112nV199VadOnaq+evTFF1/Iz89PERERXqsNAAC0XKZO4peSkqKVK1dq1apVOnjwoO677z7l5eVp8uTJkipvKY0dO7a6/x133KHOnTvrrrvu0oEDB7Rz507Nnj1bEyZMqPWWFAAAaH0aFG7+8Y9/6M033/RoW7NmjWJiYtSlSxfdc889HpP6Xcjo0aOVlpamRYsWqW/fvtq5c6e2bt2q6OhoSVJhYaHy8vKq+wcFBSkrK0snT55UfHy8xowZo+HDh2vZsmUN+RoAAMDCGjSJ37BhwzRo0CA98MADkqScnBz169dP48ePV2xsrJYsWaJ7771XjzzySFPV22hM4gcAQMvTkN/vBl252b9/v4YMGVK9vn79el1zzTV64YUXlJKSomXLlulvf/vbxVUNAADgBQ0KNz/88IPHk0w7duzQTTfdVL3+q1/9Svn5+d6rDgAAoIEaFG5CQ0OVm5srqXKG4U8++UQJCQnVn5eUlKht27berRAAAKABGhRubrrpJj344IPKzs7W3LlzFRgYqMTExOrPP/30U/Xo0cPrRQIAANRXg+a5Wbx4sZKTkzVw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uRQcHGx2OYDpmKEYQEvQkN9vJvEDWjl7W4f63j7L7DIAwGu4LQUAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyFcAMAACyljdkFAEBr4j5bppxNGTrz7dcKjO6huJFTZG/rMLsswFIINwDgI7uWzVHU/KXq63JXtx1x3q+8RSm6dsYTJlYGWAvhBgB8YNeyObp65pIa7WEut8JmLtEuiYADeAljbgCgibnPlilq/lJJNf/RrVqPXLBU7rNlPq0LsCrCDQA0sZxNGerqctf5D66fpG4n3crZlOHLsgDLItwAQBM78+3XXu0H4PwINwDQxAKje3i1H4DzI9wAQBOLGzlFR5x2VdTxeYWkgo52xY2c4suyAMsi3ABAE7O3dShvUYok1Qg4Vev5C1OY7wbwEsINAPjAtTOe0Mfps1XktHu0F3a06+P02TwGDniRzTAMw+wifKm4uFhOp1Mul0vBwcFmlwOglWGGYuDiNOT3m0n8AMCH7G0d6nv7LLPLACzN9NtSGRkZiomJUUBAgPr376/s7Ow6+2ZmZmro0KG65JJLFBwcrISEBL311ls+rBYAADR3poabDRs2aNasWZo3b5727dunxMREDRs2THl5ebX237lzp4YOHaqtW7dq7969uuGGGzR8+HDt27fPx5UDAIDmytQxN9dcc4369eunFStWVLfFxsbq1ltvVWpqar32ceWVV2r06NGaP39+vfoz5gYAgJanIb/fpl25KSsr0969e5WUlOTRnpSUpA8//LBe+6ioqFBJSYk6depUZ5/S0lIVFxd7LAAAwLpMCzfHjx+X2+1WaGioR3toaKiKiorqtY+nnnpKp0+f1m233VZnn9TUVDmdzuolMjKyUXUDAIDmzfQBxTabzWPdMIwabbVZt26dHnnkEW3YsEFdunSps9/cuXPlcrmql/z8/EbXDAAAmi/THgUPCQmR3W6vcZXm2LFjNa7mnGvDhg2aOHGiXn31Vd14443n7evv7y9/f/9G1wsAAFoG067cOBwO9e/fX1lZWR7tWVlZGjBgQJ3brVu3TuPHj9crr7yiW265panLBAAALYypk/ilpKTozjvvVHx8vBISEvT8888rLy9PkydPllR5S6mgoEBr1qyRVBlsxo4dq/T0dF177bXVV33atWsnp9Np2vcAADRPzAjdOpkabkaPHq0TJ05o0aJFKiwsVK9evbR161ZFR0dLkgoLCz3mvHnuuedUXl6uqVOnaurUqdXt48aN0+rVq31dPgCgGdu1bI6i5i9VX5e7uu2I837lLUrhXV4Wx7ulAACWs2vZHF09c4kkz/EXVW9h52WlLU+LmOcGAICm4D5bpqj5SyXV/JGrWo9csFTus2U+rQu+Q7gBAFhKzqYMdXW56/yB85PU7aRbOZsyfFkWfIhwAwCwlDPffu3Vfmh5CDcAAEsJjO7h1X5oeQg3AABLiRs5RUec9urBw+eqkFTQ0a64kVN8WRZ8iHADALAUe1uH8halSFKNgFO1nr8whfluLIxwAwCwnGtnPKGP02eryGn3aC/saOcx8FaAeW4AAJbFDMXW0ZDfb1NnKAYAoCnZ2zrU9/ZZZpcBH+O2FAAAsBTCDQAAsBRuSwEAAK9oLmOcCDcAAKDRmtNb2Ak3AACgUX7+FvafC3O5FTZziXZJPg04jLkBAAAXrTm+hZ1wAwAALlpzfAs74QYAAFy05vgWdsINAAC4aM3xLeyEGwAAcNGa41vYCTcAAOCiNce3sBNuAABAozS3t7DzVnAAAOAVTTlDMW8FBwAAPtdc3sLObSkAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGApre71C1Wv0iouLja5EgAAUF9Vv9v1eSVmqws3JSUlkqTIyEiTKwEAAA1VUlIip9N53j6t7q3gFRUVOnLkiDp06CCbzVbv7YqLixUZGan8/HzeJu4DnG/f4nz7FufbtzjfvtVU59swDJWUlKhr167y8zv/qJpWd+XGz89PERERF719cHAw/+PwIc63b3G+fYvz7Vucb99qivN9oSs2VRhQDAAALIVwAwAALIVwU0/+/v5asGCB/P39zS6lVeB8+xbn27c4377F+fat5nC+W92AYgAAYG1cuQEAAJZCuAEAAJZCuAEAAJZCuAEAAJZCuKmHjIwMxcTEKCAgQP3791d2drbZJVnWzp07NXz4cHXt2lU2m01btmwxuyTLSk1N1a9+9St16NBBXbp00a233qrPP//c7LIsa8WKFerdu3f1xGYJCQl68803zS6r1UhNTZXNZtOsWbPMLsWSHnnkEdlsNo8lLCzMtHoINxewYcMGzZo1S/PmzdO+ffuUmJioYcOGKS8vz+zSLOn06dPq06ePli9fbnYplrdjxw5NnTpVu3btUlZWlsrLy5WUlKTTp0+bXZolRURE6LHHHtOePXu0Z88eDR48WCNGjNBnn31mdmmWt3v3bj3//PPq3bu32aVY2pVXXqnCwsLqJScnx7RaeBT8Aq655hr169dPK1asqG6LjY3VrbfeqtTUVBMrsz6bzabNmzfr1ltvNbuUVuG7775Tly5dtGPHDv361782u5xWoVOnTlqyZIkmTpxodimWderUKfXr108ZGRlavHix+vbtq7S0NLPLspxHHnlEW7Zs0f79+80uRRJXbs6rrKxMe/fuVVJSkkd7UlKSPvzwQ5OqApqGy+WSVPmDi6bldru1fv16nT59WgkJCWaXY2lTp07VLbfcohtvvNHsUizvyy+/VNeuXRUTE6Pbb79dhw4dMq2WVvfizIY4fvy43G63QkNDPdpDQ0NVVFRkUlWA9xmGoZSUFF1//fXq1auX2eVYVk5OjhISEvTTTz8pKChImzdv1i9/+Uuzy7Ks9evX65NPPtHu3bvNLsXyrrnmGq1Zs0aXX365jh49qsWLF2vAgAH67LPP1LlzZ5/XQ7ipB5vN5rFuGEaNNqAlmzZtmj799FO9//77ZpdiaVdccYX279+vkydPatOmTRo3bpx27NhBwGkC+fn5mjlzpt5++20FBASYXY7lDRs2rPrPcXFxSkhIUI8ePfTyyy8rJSXF5/UQbs4jJCREdru9xlWaY8eO1biaA7RU06dP1+uvv66dO3cqIiLC7HIszeFwqGfPnpKk+Ph47d69W+np6XruuedMrsx69u7dq2PHjql///7VbW63Wzt37tTy5ctVWloqu91uYoXW1r59e8XFxenLL7805fiMuTkPh8Oh/v37Kysry6M9KytLAwYMMKkqwDsMw9C0adOUmZmpd999VzExMWaX1OoYhqHS0lKzy7CkIUOGKCcnR/v3769e4uPjNWbMGO3fv59g08RKS0t18OBBhYeHm3J8rtxcQEpKiu68807Fx8crISFBzz//vPLy8jR58mSzS7OkU6dO6auvvqpez83N1f79+9WpUydFRUWZWJn1TJ06Va+88opee+01dejQofoKpdPpVLt27Uyuznr+9Kc/adiwYYqMjFRJSYnWr1+v7du3a9u2bWaXZkkdOnSoMX6sffv26ty5M+PKmsD999+v4cOHKyoqSseOHdPixYtVXFyscePGmVIP4eYCRo8erRMnTmjRokUqLCxUr169tHXrVkVHR5tdmiXt2bNHN9xwQ/V61b3acePGafXq1SZVZU1V0xsMGjTIo/2ll17S+PHjfV+QxR09elR33nmnCgsL5XQ61bt3b23btk1Dhw41uzSg0Q4fPqzf//73On78uC655BJde+212rVrl2m/lcxzAwAALIUxNwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAs46GHHpK/v7/uuOMOs0sBYCJevwDAMoqLi/XXv/5V06ZN05dffqmePXuaXRIAE3DlBoBlBAcHa8KECfLz81NOTo7Z5QAwCeEGgKWUl5crMDBQ//rXv8wuBYBJCDcALOWhhx7SqVOnCDdAK8aYGwCWsXfvXg0YMEBDhw5Vbm6uPvvsM7NLAmACwg0AS6ioqNDVV1+tgQMH6pprrtGYMWN0+vRpORwOs0sD4GPclgJgCc8884y+++47LVq0SHFxcSovL9fnn39udlkATEC4AdDiFRQU6OGHH1ZGRobat2+vyy67TP7+/oy7AVopwg2AFm/GjBkaNmyYbrnlFklSmzZtFBsbS7gBWqk2ZhcAAI3xxhtv6N1339XBgwc92uPi4gg3QCvFgGIAAGAp3JYCAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACW8v8An0rXGEIbbxEAAAAASUVORK5CYII=\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')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "71d79306",
   "metadata": {},
   "outputs": [],
   "source": [
    "Oracle = np.load('X-Wishart_SNR=1.0_Oracle.npy')\n",
    "RIE = np.load('X-Wishart_SNR=1.0_RIE.npy')\n",
    "sqXX = np.load('X-Wishart_SNR=1.0_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "931439d6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.05831803 0.05829702 0.05835046 0.05820058 0.05837389 0.05823896\n",
      " 0.05838512 0.05836517 0.058316   0.05843164]\n",
      "[0.05949848 0.05966061 0.0595163  0.05949416 0.0598084  0.05948975\n",
      " 0.05954524 0.05963283 0.05921731 0.05964925]\n",
      "[0.05980056 0.05984    0.05986494 0.05973121 0.05992618 0.05976373\n",
      " 0.05987451 0.05986708 0.05980345 0.05994552]\n"
     ]
    }
   ],
   "source": [
    "print(Oracle)\n",
    "print(RIE)\n",
    "print(sqXX)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a6248dc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "Oracle_XX = np.load('XX-Wishart_SNR=1.0_Oracle.npy')\n",
    "RIE_XX = np.load('XX-Wishart_SNR=1.0_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "304f878a",
   "metadata": {},
   "outputs": [],
   "source": [
    "Oracle = np.load('X-Wigner_SNR=1.0_Oracle.npy')\n",
    "RIE = np.load('X-Wigner_SNR=1.0_RIE.npy')\n",
    "sqXX = np.load('X-Wigner_SNR=1.0_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "963ecd7a",
   "metadata": {},
   "outputs": [],
   "source": [
    "Oracle_X = np.load('X-Wishart_SNR=1.0_Oracle.npy')\n",
    "RIE_X = np.load('X-Wishart_SNR=1.0_RIE.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "398886c0",
   "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
}
