{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# A demo of the spectral method for structured models\n",
    "\n",
    "In this demo, we are going to apply the Wigner rank one denoising problem to a structured model. To do so, we are simply downloading the MNIST data set, and use a very simple (some would say trivial) model for its structure by simply measuring the covariance matrix $\\Sigma$ between images. As we shall see, this is enough to improve on the spectral method.\n",
    "\n",
    "First, we download the MNIST dataset:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "60000 train set\n",
      "10000 test set\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x1262619b0>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ETmnqjd1ly5dmnP87W9/O+508nrggQdMPHr0aGvOv4lOVAj/qScXXHCBNdfR0RH65xxxxBEDxoB9OssHH3yQ82cce+yx1rilpSX08qPGNT4icg4bHxE5h42PiJxT1fv4rrvuOmusqiZetWqVNXfNNdeY+MADDyxLPrt37zbxb37zG2tuzpw5Jr7zzjvLsnxyz0MPPWTifPv0br/9dmscPN3rG9/4hon/85//WHNXX321iV955RVrbtKkSSZub2+35g455JCc+ZTboGt8IvKoiPSKyGu+10aKyHIR6fa+H17eNImix9p2V5hN3QUAJgVemw2gQ1XHAujwxkSVZgFY204adFNXVVeLSEPg5RYAE7y4HcAqADdEmFfRdu7caeIPP/zQmhMRE//xj3+05q644goT33vvvdZcfX196OW/8cYbJt68ebM1d+utt5o4eKa83/HHHx96eVS8SqvtYlx22WUm7unpsebOPfdcE0+cODHvz3nzzTdN7N+0BezN26OOOsqaa2trM3FtbW2IjONR7MGNOlX97Le4BUC895QhKh/WtgNKPqqr2SMGmmteRGaISEZEMn19faUujig2+WqbdV3Zim18W0VkFAB433tzvVFV56lqk6o2pWlVlyiHULXNuq5sxZ7OsgxAK4C53vel+d8en3nz5pl4x44d1pz/9JatW7dac08++aSJly1bZs0NHz489PK3b99u4r1794b+nH+/3ne/+93Qn6PIpba2i+G//DF4ClU+n3zyiTU+66yzTOy/qwsAjBkzxsR//etfrbm07q8OczrLIgCdAI4TkfdEZDqyRTFRRLoBnOONiSoKa9tdYY7q5rpR1tkR50IUK9a2uyr+yo3+/n5rfN999+V877Rp00zc0NBgzfkfduI/2x344sNV8vFvWpx33nnWnH+1f+bMmdbcTTfdZOKDDz449PKIonDmmWda43/961/W+H//+5+JTzzxRGsuk8mYeOjQoWXILnq8VpeInMPGR0TOYeMjIudU/D6+devWWWP/aSpHH320NXfSSSeZeMiQIdac/zK14J0qCuH/ufvtZ/9/ZfLkySYO3pnCf7oAUTn4L+cE7DsC+R/8DXxxP/OPf/xjEwfvHlQp+/X8uMZHRM5h4yMi51T8pu7q1atzzj3yyCPWOLh563fAAZ//KkaMGFF6YrBPAQDszYm5c+3zYr/yla9E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\n",
      "text/plain": [
       "<Figure size 432x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import tensorflow as tf\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "\n",
    "# Load the fashion-mnist pre-shuffled train data and test data\n",
    "(x_train, y_train), (x_test, y_test) = tf.keras.datasets.mnist.load_data()\n",
    "\n",
    "# Print the number of training and test datasets\n",
    "print(x_train.shape[0], 'train set')\n",
    "print(x_test.shape[0], 'test set')\n",
    "\n",
    "plt.subplot(221)\n",
    "img_index = 51432\n",
    "plt.imshow(x_train[img_index],cmap='Greys')\n",
    "\n",
    "plt.subplot(222)\n",
    "img_index = 567\n",
    "plt.imshow(x_train[img_index],cmap='Greys')\n",
    "\n",
    "plt.subplot(223)\n",
    "img_index = 26579\n",
    "plt.imshow(x_train[img_index],cmap='Greys')\n",
    "\n",
    "plt.subplot(224)\n",
    "img_index = 8765\n",
    "plt.imshow(x_train[img_index],cmap='Greys')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "All right, let us build our data set for the rank-one problem. We center the data, normalize them, and compute the empirical correlation $\\Sigma$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "data=x_train.reshape(60000,784)-np.sum(x_train.reshape(60000,784),1).reshape(60000,1)/784\n",
    "data=tf.keras.utils.normalize(data, axis=-1,order=2)*np.sqrt(784)\n",
    "SIGMA=data.T@data/60000;\n",
    "\n",
    "data_test=x_test.reshape(10000,784)-np.sum(x_test.reshape(10000,784),1).reshape(10000,1)/784\n",
    "data_test=tf.keras.utils.normalize(data_test, axis=-1,order=2)*np.sqrt(784)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "All right, now, let us pick up a given unseen image from the test set and do the rank one stuff:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x1316eb710>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#x=data_test[2209].reshape(784,1)\n",
    "x=data_test[5609].reshape(784,1)\n",
    "plt.imshow(x.reshape(28,28),cmap='Greys')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 784\n",
    "#create noise, and the random matrix observation:\n",
    "b = np.random.randn(N,N)\n",
    "W = np.tril(b) + np.tril(b, -1).T\n",
    "DELTA=3\n",
    "Y = x@x.T/(N) + np.sqrt(DELTA)*W/np.sqrt(N)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "First, we try to apply the standard PCA approach:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x1395626d8>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.sparse.linalg import eigsh,eigs\n",
    "# Method one: naive PCA\n",
    "val, vec = eigsh(Y, k=1,which='LA')\n",
    "plt.imshow(vec.reshape(28,28),cmap='Greys')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "And the improve spectral approach, that uses the correlation:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x13ab0f748>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Method two: linearized AMP: LAMP\n",
    "val, vec = eigs(SIGMA@(Y-np.eye(784,784)), k=1,which='LR')\n",
    "plt.imshow((vec.real).reshape(28,28),cmap='Greys')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The difference is really strinking. We can actually plot the mean-square error that the two methods yields as a function of $\\Delta$:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1   1.4872407459936048   0.16738399009186705\n",
      "2   1.9402286476760946   0.27718094291991835\n",
      "3   1.9490870239842817   0.2967250271008078\n",
      "4   1.897655260557435   0.2798257132253814\n",
      "5   1.723554770444399   0.3925387373825087\n",
      "6   1.9317558703527342   0.33362861827090223\n",
      "7   1.9921236723346303   0.543852508035826\n",
      "8   1.7060738989777624   0.4130391402179883\n",
      "9   1.9494762839795565   0.500179213677947\n",
      "10   1.8003176146023554   0.5250980326106209\n",
      "11   1.9952471952771829   0.4465798831202047\n",
      "12   1.7645761394647226   0.42741766338912807\n",
      "13   1.920196533151087   0.5470121891677585\n",
      "14   1.9951895065505056   0.453954213719709\n",
      "15   1.8854261055233545   0.421289832398373\n",
      "16   1.8737287588234584   0.3908781947556162\n",
      "17   1.969029280760767   0.4980357206563001\n",
      "18   1.9750789274549714   1.4377376989335573\n",
      "19   1.9934410722226485   0.6716285593719419\n",
      "20   1.871197910432821   0.6641459600694601\n",
      "21   1.9687515667886883   0.9714898351901695\n",
      "22   1.9546849649145097   0.815710175685861\n",
      "23   1.9077499014736157   0.9410753642122028\n",
      "24   1.8969362544843082   0.4338440583085508\n",
      "25   1.8757049062172224   0.8993033967682953\n",
      "26   1.9953964636260901   0.7469463596728256\n",
      "27   1.9497001348000027   0.5562279101819024\n",
      "28   1.9228668404453721   0.9021591846045404\n",
      "29   1.9859496779059151   0.5757855339149487\n",
      "30   1.8243030561636402   0.9578185113099584\n",
      "31   1.988611062315618   1.1340756030482138\n",
      "32   1.9299262777075692   0.6351847708816881\n",
      "33   1.9025428471608923   0.7593579270460736\n",
      "34   1.9407269007769468   0.835802440712959\n",
      "35   1.8523623063645125   1.2691882359350142\n",
      "36   1.935356800454239   0.7404150265287549\n",
      "37   1.903546144103116   1.3202395300692684\n",
      "38   1.9410239568383687   0.8012259396574767\n",
      "39   1.9413221699804284   1.1301700647213928\n",
      "40   1.9909780401552106   1.8272591066686201\n",
      "41   1.9161718811987003   1.0244337322342014\n",
      "42   1.9263438667187642   1.113168255320203\n",
      "43   1.8241309740895228   0.8980506332278873\n",
      "44   1.9902722296925772   0.8359609487425432\n",
      "45   1.9907531461450256   0.9842257416329873\n",
      "46   1.8853672405104667   1.2697269503417317\n",
      "47   1.9672176803195278   0.8978369069056448\n",
      "48   1.8389598524758108   0.5571403983330405\n",
      "49   1.9493226344594696   1.1436405236079732\n",
      "50   1.930455616163137   1.0676796287038564\n"
     ]
    }
   ],
   "source": [
    "MSEs = np.zeros((50,2))\n",
    "deltas = np.zeros((50,1))\n",
    "DELTA=0\n",
    "d_DELTA=1\n",
    "\n",
    "for i in range(50):\n",
    "    #create noise\n",
    "    b = np.random.randn(N,N)\n",
    "    W = np.tril(b) + np.tril(b, -1).T\n",
    "    DELTA=DELTA+d_DELTA\n",
    "    Y = x@x.T/(N) + np.sqrt(DELTA)*W/np.sqrt(N)\n",
    "    \n",
    "    deltas[i]=DELTA\n",
    "    # PCA\n",
    "    val, vec = eigsh(Y, k=1,which='LA')\n",
    "    error_1=sum((x/np.sqrt(N) - vec)**2)\n",
    "    error_2=sum((x/np.sqrt(N) + vec)**2)\n",
    "    MSEs[i,0]=min(error_1,error_2)\n",
    "    \n",
    "     # LAMP\n",
    "    val, vec = eigs(SIGMA@(Y-np.eye(784,784)), k=1,which='LR')\n",
    "    error_1=sum((x/np.sqrt(N) - vec.real)**2)\n",
    "    error_2=sum((x/np.sqrt(N) + vec.real)**2)\n",
    "    MSEs[i,1]=min(error_1,error_2)\n",
    "\n",
    "    print(DELTA,\" \",MSEs[i,0],\" \",MSEs[i,1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x13b0ca198>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.title(\"Fashion MNIST recovery\")\n",
    "plt.plot(deltas,MSEs[:,0],'*-', label='PCA')\n",
    "plt.plot(deltas,MSEs[:,1],'+-', label='LAMP')\n",
    "plt.xlabel(\"$\\Delta$\")\n",
    "plt.ylabel(\"$MSE$\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
