{
 "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": [
    "M = [2000, 3000, 4000, 5000, 6000, 7000, 8000]"
   ]
  },
  {
   "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((7, 10))\n",
    "E_RIE = np.zeros((7, 10))\n",
    "E_sqXXRIE = np.zeros((7, 10))\n",
    "\n",
    "SNR = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7ef8eab6",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(7):\n",
    "    \n",
    "    E_Oracle[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_Oracle.npy')\n",
    "    E_RIE[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_RIE.npy')\n",
    "    E_sqXXRIE[i,:] = np.load('X-Wigner_N=2000_M='+str(M[i])+'_SNR='+str(SNR)+'_sqXX.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7790cec3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.0527912  0.05267162 0.05279692 0.05267464 0.05277208 0.05276611\n",
      " 0.05267257 0.05277165 0.05270428 0.05268843]\n",
      "[0.05313951 0.05297128 0.0530769  0.05309726 0.05304709 0.05313163\n",
      " 0.05302137 0.05313632 0.05303495 0.05297095]\n"
     ]
    },
    {
     "data": {
      "image/png": "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O/WrX/1KktS7d2+tWbNGe/bs0eLFi7Vy5Ur993//t/tzXn/9daWlpWnMmDEqLi7WW2+9paSkJPN7NQyNGTNGVVVVysvL086dO3Xttdfq1ltvbbFHq734dAmACRMm6NChQ1q0aJEcDofi4+OVl5enmJgYSZLD4fBYMyk2NlZ5eXmaNWuWli5dqoiICC1ZssT9+H+zzz//XO+++662bt1qet2KigpNmjRJNTU16t+/v4YOHar33nvPfd1zrbUdWD7q6AIAnGOOI637q7i1cW2xb98+GYahuLg40+NxcXH6+uuv9c9//lOSdMstt3h1Vjz22GPu3wcNGqSf//zn2rBhg375y19Kkp566ilNnDhRTzzxhDvuqquuMr3e22+/rd27d6u6ulpBQUGSpGeffVavvfaacnJy9OCDD575zZ6Gz19LMmPGDM2YMcP02Jo1a7zKbrrpJn344Yen/MxLL73UneGayc7OblMdO5rdLkVGuiZpm1XbYnEdt9vPfd0AAOeerXfr/ipubVx7OvmBKbMeoJycHGVlZemLL77Q0aNH1djY6PHA065du9xDc6ezc+dOHT161Gtk6Ntvv9X//d//nelttIrPkyRIVqu0eLHrKTaLxTNRan5oLyvLFQcAOP/Zo+2KDIlUZV2l6bwkiyyKDImUPbr9/3q++OKLZbFYtGfPHo0dO9br+GeffaYf/OAH6tevnyR5rUP43nvvuXuJRowYodDQUGVnZ+u5555zx5w8jHcqTU1Nstls2rZtm9exPn36tPpzzoTPlwCAS1qalJMjDRzoWR4Z6So/xXw2AMB5xupn1eKRiyW5EqITNe9njcyS1a/9/3ru27evbrvtNi1btkzffvutx7Gqqir97ne/04QJE1pcrudvf/ubYmJitGDBAiUlJemSSy7RwYMHPWKuvPJKvfXWW62qz7XXXquqqir5+/vr4osv9tiaE7WOQpLUiaSlSQcOSG+/Lf3+966fpaUkSADQHaXFpSnnrhwN7B3hUR4ZEqmcu3KUFtdxXw4vvPCC6uvrNWLECL3zzjsqLy/XG2+8odtuu00DBw7UU0891eK5F198scrKypSdna3/+7//05IlS7Rp0yaPmIULF2r9+vVauHChSkpKtHv3bv3mN78x/bzhw4crOTlZY8eO1ZYtW3TgwAFt375djz32mHbs2NGu930ykqROxmqVUlKk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iIgIxcbGauLEidq/f78k2snM5s2blZSUpB//+McaMGCArrnmGq1cudJ9nDYz19DQoFdeeUVTp06VxWKhnU5yww036K233tLnn38uSfroo4/07rvvavTo0ZK6xr8rXnDbwQzD0OzZs3XDDTcoPj5eklRVVSVJCgsL84gNCwvTwYMH3TGBgYH6wQ9+4BXTfH5VVZUGDBjgdc0BAwa4Y7qC3bt3Kzk5Wd9995169eqlTZs26fLLL3f/46advpedna0PP/xQf//7372O8e/qe0OGDNG6det06aWX6h//+IeefPJJDRs2TJ9++intZGL//v1avny5Zs+erfnz5+uDDz7QzJkzFRQUpMmTJ9NmLXjttdd0+PBh3XfffZL4b/Bkc+fOVW1trS677DJZrVY5nU499dRTmjRpkqSu0V4kSR3s4Ycf1scff6x3333X65jFYvHYNwzDq+xkJ8eYxbfmczqTf/u3f9OuXbt0+PBhbdy4UVOmTFFBQYH7OO3kUl5ervT0dG3dulXBwcEtxtFe0qhRo9y/JyQkKDk5WRdddJHWrl2roUOHSqKdTtTU1KSkpCQ9/fTTkqRrrrlGn376qZYvX67Jkye742gzT6tWrdKoUaMUERHhUU47uWzYsEGvvPKKfv/73+uKK67Qrl27lJGRoYiICE2ZMsUd15nbi+G2DvTII49o8+bNevvttxUZGekub37K5uQMt7q62p1Rh4eHq6GhQV9//fUpY/7xj394Xfef//ynV2bemQUGBuriiy9WUlKSMjMzddVVV2nx4sW000l27typ6upqJSYmyt/fX/7+/iooKNCSJUvk7+/vvhfay1vPnj2VkJCgffv28e/KhM1m0+WXX+5RFhcXp7KyMkn8f5aZgwcP6s0339T999/vLqOdPP3iF7/Qo48+qokTJyohIUH33nuvZs2apczMTEldo71IkjqAYRh6+OGHlZubq7/+9a+KjY31OB4bG6vw8HDl5+e7yxoaGlRQUKBhw4ZJkhITExUQEOAR43A49Mknn7hjkpOTVVtbqw8++MAd8/7776u2ttYd0xUZhqH6+nra6SS33nqrdu/erV27drm3pKQk3X333dq1a5cGDx5Me7Wgvr5eJSUlstls/Lsycf3113stU/L5558rJiZGEv+fZebll1/WgAEDNGbMGHcZ7eTp2LFj8vPzTDOsVqt7CYAu0V5nNe0bpn72s58ZoaGhxrZt2zweFT127Jg75plnnjFCQ0ON3NxcY/fu3cakSZNMH3uMjIw03nzzTePDDz80brnlFtPHHq+88kqjqKjIKCoqMhISErrUY6Lz5s0z3nnnHaO0tNT4+OOPjfnz5xt+fn7G1q1bDcOgnU7nxKfbDIP2avbzn//c2LZtm7F//37jvffeM26//Xajd+/exoEDBwzDoJ1O9sEHHxj+/v7GU089Zezbt8/43e9+Z/To0cN45ZVX3DG02fecTqcRHR1tzJ071+sY7fS9KVOmGAMHDnQvAZCbm2v069fP+OUvf+mO6eztRZLUASSZbi+//LI7pqmpyVi4cKERHh5uBAUFGTfeeKOxe/duj8/59ttvjYcffti48MILjQsuuMC4/fbbjbKyMo+YQ4cOGXfffbfRu3dvo3fv3sbdd99tfP311+fgLtvH1KlTjZiYGCMwMNDo37+/ceutt7oTJMOgnU7n5CSJ9nJpXmslICDAiIiIMNLS0oxPP/3UfZx28vanP/3JiI+PN4KCgozLLrvMePHFFz2O02bf27JliyHJ2Lt3r9cx2ul7dXV1Rnp6uhEdHW0EBwcbgwcPNhYsWGDU19e7Yzp7e1kMwzDOri8KAADg/MOcJAAAABMkSQAAACZIkgAAAEyQJAEAAJggSQIAADBBkgQAAGCCJAkAAMAESRIAAIAJkiQAAAATJEkAcILHHntMQUFB+slPfuLrqgDwMV5LAgAnqKur0//+7//q4Ycf1r59+3TxxRf7ukoAfISeJAA4QUhIiKZOnSo/Pz/t3r3b19UB4EMkSQBwksbGRvXo0UOffPKJr6sCwIdIkgDgJI899piOHj1KkgR0c8xJAoAT7Ny5U8OGDdNtt92m0tJSffrpp76uEgAfIUkCgH9pamrSddddp5tuuklDhgzR3XffrW+++UaBgYG+rhoAH2C4DQD+5be//a3++c9/atGiRUpISFBjY6P27t3r62oB8BGSJACQVFlZqV/96ldatmyZevbsqUsuuURBQUHMSwK6MZIkAJA0c+ZMjRo1SmPGjJEk+fv7Ky4ujiQJ6Mb8fV0BAPC1P//5z/rrX/+qkpISj/KEhASSJKAbY+I2AACACYbbAAAATJAkAQAAmCBJAgAAMEGSBAAAYIIkCQAAwARJEgAAgAmSJAAAABMkSQAAACZIkgAAAEyQJAEAAJggSQIAADDx/wFnWl0vMTm7kwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.errorbar(M, E_Oracle.mean(1), yerr=E_Oracle.std(1), fmt='o', color='green',ecolor='lightcoral',label='Oracle')\n",
    "plt.errorbar(M, E_RIE.mean(1), yerr=E_RIE.std(1), fmt='o', color='red',ecolor='lightcoral',label='RIE')\n",
    "plt.errorbar(M, 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')\n",
    "\n",
    "print(E_Oracle[2,:])\n",
    "print(E_RIE[2,:])"
   ]
  },
  {
   "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
}
