{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from PIL import Image\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "from utils.sim_missing_data import *\n",
    "from models.SRPCA import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Data/Image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "image = Image.open('../datasets/Capture6.png')\n",
    "true_img = np.asarray(image,dtype=np.float64)[:,:,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(true_img, cmap='gray')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Set parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "perc = 50#0 # Percentage of missing data\n",
    "seed = 50\n",
    "i_PCA = 80#30 # Number of Principal Components\n",
    "max_iter = 100 # Maximum number of ierations before breaking\n",
    "alpha = 1 # balancing estimate update parameter\n",
    "eps = 1e-5 # stability infitisimial\n",
    "eps_tol = 1e-4 # convergence threshold\n",
    "optional_smoothing = True # Option smoothening of estimates each iteration\n",
    "Nan = False # put Nan instead or 0 in missing entries\n",
    "return_normalized = True # return a normalized version of the matrix"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Simulate missing data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_avail,X_true,X_norm,X_true_norm,OmegaRow,OmegaCol,mu_O_list,std_O_list,rmIndMatrixRow,rmIndMatrixCol = simulate_missing_data(true_img,\n",
    "                                                                                                                               perc,\n",
    "                                                                                                                               eps=eps,\n",
    "                                                                                                                               Nan=Nan,\n",
    "                                                                                                                               return_normalized=return_normalized,\n",
    "                                                                                                                               seed=seed)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Run Algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#######################################\n",
      "############## SRPCA ##################\n",
      "#######################################\n",
      "Iteration #0, observed error: 0.02204957380802912 total error: 0.057059432645383594 time elapsed: 0.63268500007689\n",
      "Iteration #1, observed error: 0.005603987681511454 total error: 0.02290671395354861 time elapsed: 0.7318619999568909\n",
      "Iteration #2, observed error: 0.0030361657361791883 total error: 0.013381405778656028 time elapsed: 0.8337003670167178\n",
      "Iteration #3, observed error: 0.002241182068404096 total error: 0.009857592100206024 time elapsed: 0.9449793959502131\n",
      "Iteration #4, observed error: 0.0019257577681051827 total error: 0.008251688070065469 time elapsed: 1.0419120739679784\n",
      "Iteration #5, observed error: 0.001778328606000892 total error: 0.007442300940125679 time elapsed: 1.1398999290540814\n",
      "Iteration #6, observed error: 0.001702370988468334 total error: 0.006126935964028485 time elapsed: 1.2405468709766865\n"
     ]
    }
   ],
   "source": [
    "M, _, _ =SRPCA_func(X_norm, \n",
    "                    X_true_norm, \n",
    "                    OmegaCoord=[OmegaRow,OmegaCol], \n",
    "                    MissingIndCoord=[rmIndMatrixRow,rmIndMatrixCol],\n",
    "                    i_PCA=i_PCA, \n",
    "                    alpha=alpha ,\n",
    "                    eps=eps, \n",
    "                    eps_tol=eps_tol, \n",
    "                    optional_smoothing=optional_smoothing,\n",
    "                    verbose=True,\n",
    "                    seed=seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualizations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "M_img = M*(np.array(std_O_list)+eps)+np.array(mu_O_list)\n",
    "h = 6\n",
    "w = M.shape[1]*h/M.shape[0]\n",
    "plt.figure(figsize=(w,h))\n",
    "plt.imshow(M_img,cmap='gray')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(w,h))\n",
    "plt.imshow(X_avail,cmap='gray')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "SRPCA",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
