{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from neurips_utils import *\n",
    "from math import log,sqrt\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Data and Parameters\n",
    "#dimension\n",
    "p = 5\n",
    "#samples\n",
    "n = 5\n",
    "#width\n",
    "l = 100\n",
    "\n",
    "X,Y,H,pred = data_orthogonal(p,n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting up experiment\n",
    "iterations = [10**(5)]\n",
    "scales = [0.001 , 0.01 ,.1 , 1, 5 ]\n",
    "\n",
    "deltas = [1, 2, 3, 4, 5, 20 ]\n",
    "\n",
    "stepsize = .01\n",
    "\n",
    "num_iter = iterations[0]\n",
    "list_of_experiments = [\n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'gd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[2]) }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[2]), 'delta' : deltas[2]  }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[2]), 'delta' : deltas[3]  }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[2]), 'delta' : deltas[4]  }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'gd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[3]) }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[3]), 'delta' : deltas[2]  }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[3]), 'delta' : deltas[3]  }, \n",
    "{ 'X' : X, 'Y' : Y, 'step' : stepsize, 'iterations': num_iter, 'alg': 'lngd', 'repetitions': 1, 'test_points': generate_test_samples(num_iter)  , 'init' : init_linear_network_wtopw_I_a_zero(l,p,scales[3]), 'delta' : deltas[4]  }, \n",
    "]\n",
    "\n",
    "result_summary = []\n",
    "for exp in list_of_experiments:\n",
    "    result = { \n",
    "        'eig' : np.zeros((exp['test_points'].shape[0],exp['repetitions'],p)), \n",
    "        }\n",
    "    result_summary.append(result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_exp = 0\n",
    "for exp in list_of_experiments:\n",
    "    print(\"Experiment \", n_exp )\n",
    "    runs = exp['repetitions']\n",
    "    iterations = exp['iterations']\n",
    "    step = exp['step']\n",
    "    test_points = exp['test_points']\n",
    "    index = indices(iterations, test_points)\n",
    "    alg = exp['alg']\n",
    "    X = exp['X']\n",
    "    Y = exp['Y']\n",
    "    if alg == 'lngd':\n",
    "        delta = exp['delta']\n",
    "    for run in range(runs):\n",
    "        a, W, U_0, U_perp = exp['init'] \n",
    "        R_0 = W.T@W\n",
    "        L_0 = W@W.T\n",
    "        for it in range(iterations):\n",
    "            if index[it] >= 0:\n",
    "                s,rank,u,v = rankW(W,.00001)\n",
    "                result_summary[n_exp]['eig'][index[it], run, :] = s # Eigen values\n",
    "\n",
    "            if alg == 'sgd':\n",
    "                grad = stochastic_gradient(a,W, X, Y, it)\n",
    "            elif alg == 'lngd':\n",
    "                yln = Y + delta*np.random.randn(Y.shape[0], Y.shape[1])\n",
    "                grada,gradW = gradient(a,W,X,yln)\n",
    "            else:\n",
    "                grada, gradW = gradient(a,W,X,Y)\n",
    "                \n",
    "            a =  a - step*grada\n",
    "            W =  W - step*gradW\n",
    "    n_exp = n_exp + 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import itertools\n",
    "import matplotlib.patches as mpatches\n",
    "import matplotlib.lines as mlines\n",
    "\n",
    "plt.rcParams.update({\n",
    "    'font.size': 14,\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"Times\",\n",
    "    'text.latex.preamble': r'\\usepackage{amsfonts}',\n",
    "    \"font.sans-serif\": [\"Helvetica\"]})\n",
    "\n",
    "legend_line_width = 2\n",
    "plot_line_width = 2\n",
    "marker_size = 7\n",
    "\n",
    "plt.figure(figsize = (6, 6))\n",
    "plt.rcParams['figure.dpi'] = 100\n",
    "plt.rcParams['savefig.dpi'] = 300\n",
    "\n",
    "\n",
    "fig,ax = plt.subplots()\n",
    "start = 0 \n",
    "end = -1\n",
    "colors = itertools.cycle(('#377eb8', '#ff7f00', '#4daf4a',\n",
    "              '#f781bf', '#a65628', '#984ea3',\n",
    "              '#999999', '#e41a1c', '#dede00'))\n",
    "t=0\n",
    "list = [t, t+3]\n",
    "linestyles = ['solid','dashed']\n",
    "func = ax.loglog\n",
    "\n",
    "scales = [.01, 1, .001]\n",
    "\n",
    "p1 = min(p,4)\n",
    "patch1 = mlines.Line2D([],[],linestyle='solid', color = '#a65628', label='GD')\n",
    "patch2 = mlines.Line2D([],[],linestyle='dashed', color = '#a65628', label='LNGD')\n",
    "\n",
    "\n",
    "first_legend = ax.legend(handles = [patch1,patch2], loc='lower center', ncol = 3, bbox_to_anchor = (0., -.35, 1, .1))\n",
    "\n",
    "# first_legend = ax.legend(handles = [patch1,patch2,patch3], loc='lower left', bbox_to_anchor = (0., .1, 1, .1))\n",
    "\n",
    "# first_legend = ax.legend(handles = [patch1,patch2,patch3], loc='outside lower center', ncol = 3)\n",
    "ax.add_artist(first_legend)\n",
    "\n",
    "for direction in range(p1):\n",
    "    color = next(colors)\n",
    "    label = r'$\\sigma_{:2d}$ '.format(direction)\n",
    "    for  l in range(len(list)):\n",
    "        exp = list_of_experiments[list[l]]\n",
    "        result = result_summary[list[l]]\n",
    "        line, = func(exp['test_points'][start:end], result['eig'][start:end,0,direction], color, linestyle = linestyles[l], linewidth = plot_line_width )\n",
    "    line.set_label(label)\n",
    "\n",
    "plt.legend(loc = 'lower left', bbox_to_anchor = (0., .1, 1, .102))\n",
    "\n",
    "plt.xlabel('Iterations')\n",
    "plt.ylabel('Singular Values')\n",
    "\n",
    "# plt.savefig('../latex/images/vector-reg-non-orthogonal.pdf', format = 'pdf' )\n",
    "\n",
    "plt.savefig('../latex/images/reg-label-noise-eigenv.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.8"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
