{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import pickle\n",
    "import matplotlib.pyplot as plt\n",
    "from datetime import datetime\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ReLU(h):\n",
    "    indx = (h>0.)\n",
    "    return indx*h, indx\n",
    "\n",
    "\n",
    "class twoLayersModel:\n",
    "    def __init__(self, n0, n1, n2):\n",
    "        self.W1 = np.random.randn(n1, n0)/np.sqrt(n1)\n",
    "        self.W2 = np.random.randn(n2, n1)/np.sqrt(n2)\n",
    "\n",
    "    def __call__(self, x):\n",
    "        h, indx1 = ReLU(np.matmul(self.W1, x))\n",
    "        y, indx2 = ReLU(np.matmul(self.W2, h))\n",
    "\n",
    "        W1px = self.W1 * indx1[:, None]\n",
    "        W2px = self.W2 * indx2[:, None]\n",
    "\n",
    "        Lambda_x = np.matmul(W2px, W1px)\n",
    "\n",
    "        return y, Lambda_x\n",
    "\n",
    "class threeLayersModel:\n",
    "    def __init__(self, n0, n1, n2, n3):\n",
    "        self.W1 = np.random.randn(n1, n0)/np.sqrt(n1)\n",
    "        self.W2 = np.random.randn(n2, n1)/np.sqrt(n2)\n",
    "        self.W3 = np.random.randn(n3, n2)/np.sqrt(n3)\n",
    "\n",
    "    def __call__(self, x):\n",
    "        h1, indx1 = ReLU(np.matmul(self.W1, x))\n",
    "        h2, indx2 = ReLU(np.matmul(self.W2, h1))\n",
    "        y, indx3 = ReLU(np.matmul(self.W3, h2))\n",
    "\n",
    "        W1px = self.W1 * indx1[:, None]\n",
    "        W2px = self.W2 * indx2[:, None]\n",
    "        W3px = self.W3 * indx3[:, None]\n",
    "\n",
    "        Lambda_x = np.matmul(W3px, np.matmul(W2px, W1px))\n",
    "\n",
    "        return y, Lambda_x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def flipped_GD_CS_run(net, A, b, x_t, ystar, xstar,\n",
    "                      learning_rate=0.1, num_steps=50000, \n",
    "                      path=None, verbose = 0, stopping = True):\n",
    "\n",
    "    iter_idx = 0\n",
    "\n",
    "    nrm_ystar = np.linalg.norm(ystar, 2)\n",
    "    nrm_xstar = np.linalg.norm(xstar, 2)\n",
    "\n",
    "    loss_func = []\n",
    "    relError_x = []\n",
    "    relError_y = []\n",
    "\n",
    "\n",
    "    # Step 0, logs\n",
    "    y_t, Lambda_x_t = net(x_t)\n",
    "    residual_t = np.matmul(A, y_t) - b\n",
    "    loss_t = (residual_t**2).sum()/2\n",
    "\n",
    "    loss_func.append(loss_t)\n",
    "    relError_x.append(np.linalg.norm(x_t - xstar,2)/nrm_xstar)\n",
    "    relError_y.append(np.linalg.norm(y_t - ystar,2)/nrm_ystar)\n",
    "\n",
    "    grad_flag = False\n",
    "\n",
    "    while iter_idx < num_steps and grad_flag == False:\n",
    "\n",
    "        # Negation step\n",
    "        y2, Lambda2_x_t = net(-x_t)\n",
    "        residual2 = np.matmul(A, y2) - b\n",
    "        loss2 = (residual2**2).sum()/2\n",
    "\n",
    "        if(loss2 < loss_t):\n",
    "            x_t = -x_t\n",
    "            y_t = y2\n",
    "            residual_t = residual2\n",
    "            Lambda_x_t = Lambda2_x_t\n",
    "\n",
    "        # GD step\n",
    "        Omega = np.matmul(Lambda_x_t.T, A.T)\n",
    "        grad_t = np.matmul(Omega, residual_t)\n",
    "        x_t = x_t - learning_rate*grad_t\n",
    "\n",
    "        # Logs\n",
    "        y_t, Lambda_x_t = net(x_t)\n",
    "        residual_t = np.matmul(A, y_t) - b\n",
    "        loss_t = (residual_t**2).sum()/2\n",
    "\n",
    "        loss_func.append(loss_t)\n",
    "        relError_x.append(np.linalg.norm(x_t - xstar,2)/nrm_xstar)\n",
    "        relError_y.append(np.linalg.norm(y_t - ystar,2)/nrm_ystar)\n",
    "\n",
    "        iter_idx += 1 \n",
    "\n",
    "        if verbose>1:\n",
    "            if (iter_idx%100 == 0):\n",
    "                print('Iteration', iter_idx)\n",
    "                print('Loss_func', loss_func[-1])\n",
    "                print('RelError_x',relError_x[-1])\n",
    "                print('RelError_y',relError_y[-1])\n",
    "                print('Grad norm', np.linalg.norm(grad_t))\n",
    "                print('*---------------*')\n",
    "\n",
    "        if(stopping):\n",
    "            if(np.linalg.norm(grad_t) < 1e-10):\n",
    "                grad_flag = True\n",
    "        \n",
    "\n",
    "    print('Number of iterations', iter_idx)\n",
    "\n",
    "    LOGS = {}\n",
    "    LOGS['loss_func'] = np.array(loss_func)\n",
    "    LOGS['relError_x'] = np.array(relError_x)\n",
    "    LOGS['relError_y'] = np.array(relError_y)\n",
    "\n",
    "    if verbose>0:\n",
    "        print('Final loss_func', LOGS['loss_func'][-1])\n",
    "        print('Final relError_x', LOGS['relError_x'][-1])\n",
    "        print('Final relError_y', LOGS['relError_y'][-1])\n",
    "        print('*---------------*')\n",
    "\n",
    "    if(path != None):\n",
    "        with open(path, 'wb') as handle:\n",
    "            pickle.dump(LOGS, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "    return [LOGS, x_t]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_experiments(num_runs, layers, m, eta, learning_rate=.7, num_steps=10000, path = None):\n",
    "\n",
    "    loss_func_vec = np.zeros(num_runs)\n",
    "    relError_x_vec = np.zeros(num_runs)\n",
    "    relError_y_vec = np.zeros(num_runs)\n",
    "\n",
    "    for j in range(num_runs):\n",
    "\n",
    "        if(len(layers) == 3):\n",
    "            n0, n1, n2 = layers\n",
    "            GenNet = twoLayersModel(n0, n1, n2)\n",
    "            A = np.random.randn(m, n2)/np.sqrt(m)\n",
    "        else:\n",
    "            n0, n1, n2, n3 = layers\n",
    "            GenNet = threeLayersModel(n0, n1, n2, n3)\n",
    "            A = np.random.randn(m, n3)/np.sqrt(m)\n",
    "        \n",
    "        # target latent vector\n",
    "        xstar = np.zeros(n0) \n",
    "        xstar[1] = 1 # the target point is zstar = e_2\n",
    "\n",
    "        # target vector in the range of G\n",
    "        ystar, _ = GenNet(xstar)\n",
    "        # scale it so that ystar is unit norm (use homogeneity)\n",
    "        xstar = xstar/np.linalg.norm(ystar)\n",
    "        ystar, _ = GenNet(xstar)\n",
    "\n",
    "        # noisy random linear measurements\n",
    "        b = np.matmul(A, ystar) + eta\n",
    "\n",
    "        # random initialization\n",
    "        x_t = np.random.randn(n0)\n",
    "        # recovery algorithm\n",
    "        [LOGS, x_t] = flipped_GD_CS_run(GenNet, A, b, x_t, ystar, xstar,\n",
    "                      learning_rate=learning_rate, num_steps=num_steps, \n",
    "                      path=None, verbose = 0, stopping = True)\n",
    "\n",
    "\n",
    "        loss_func_vec[j] = LOGS['loss_func'][-1]\n",
    "        relError_x_vec[j] = LOGS['relError_x'][-1]\n",
    "        relError_y_vec[j] = LOGS['relError_y'][-1]\n",
    "\n",
    "    LOGs_runs = {}\n",
    "    LOGs_runs['loss_func_mean'] = loss_func_vec.mean()\n",
    "    LOGs_runs['loss_func_std'] = loss_func_vec.std()\n",
    "\n",
    "    LOGs_runs['relError_x_mean'] = relError_x_vec.mean()\n",
    "    LOGs_runs['relError_x_std'] = relError_x_vec.std()\n",
    "    LOGs_runs['prob_recovery_x'] = (relError_x_vec < 1e-3).mean()\n",
    "    \n",
    "    LOGs_runs['relError_y_mean'] = relError_y_vec.mean()\n",
    "    LOGs_runs['relError_y_std'] = relError_y_vec.std()\n",
    "    LOGs_runs['prob_recovery_y'] = (relError_y_vec < 1e-3).mean()\n",
    "\n",
    "    return LOGs_runs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Errors (noisey)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_runs = 30\n",
    "n1, n2 =  700, 600\n",
    "m = 300\n",
    "etilde = np.random.randn(m) \n",
    "num_steps = 20000\n",
    "learning_rate = 0.7\n",
    "N0s = [15, 20, 25, 30, 35, 40, 45]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Two Layers, SNR = 80"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "tau = 1e-8\n",
    "eta = tau*etilde/np.linalg.norm(etilde)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "5\n",
      "Number of iterations 170\n",
      "Number of iterations 163\n",
      "Number of iterations 160\n",
      "Number of iterations 166\n",
      "Number of iterations 158\n",
      "Number of iterations 164\n",
      "Number of iterations 177\n",
      "Number of iterations 182\n",
      "Number of iterations 134\n",
      "Number of iterations 170\n",
      "Number of iterations 214\n",
      "Number of iterations 135\n",
      "Number of iterations 156\n",
      "Number of iterations 168\n",
      "Number of iterations 163\n",
      "Number of iterations 143\n",
      "Number of iterations 145\n",
      "Number of iterations 162\n",
      "Number of iterations 170\n",
      "Number of iterations 187\n",
      "Number of iterations 161\n",
      "Number of iterations 188\n",
      "Number of iterations 191\n",
      "Number of iterations 165\n",
      "Number of iterations 156\n",
      "Number of iterations 160\n",
      "Number of iterations 214\n",
      "Number of iterations 164\n",
      "Number of iterations 173\n",
      "Number of iterations 173\n",
      "------------\n",
      "10\n",
      "Number of iterations 218\n",
      "Number of iterations 192\n",
      "Number of iterations 230\n",
      "Number of iterations 225\n",
      "Number of iterations 191\n",
      "Number of iterations 190\n",
      "Number of iterations 198\n",
      "Number of iterations 177\n",
      "Number of iterations 189\n",
      "Number of iterations 240\n",
      "Number of iterations 179\n",
      "Number of iterations 180\n",
      "Number of iterations 190\n",
      "Number of iterations 238\n",
      "Number of iterations 210\n",
      "Number of iterations 183\n",
      "Number of iterations 210\n",
      "Number of iterations 199\n",
      "Number of iterations 216\n",
      "Number of iterations 189\n",
      "Number of iterations 205\n",
      "Number of iterations 213\n",
      "Number of iterations 214\n",
      "Number of iterations 231\n",
      "Number of iterations 230\n",
      "Number of iterations 205\n",
      "Number of iterations 220\n",
      "Number of iterations 189\n",
      "Number of iterations 248\n",
      "Number of iterations 238\n",
      "------------\n",
      "15\n",
      "Number of iterations 266\n",
      "Number of iterations 239\n",
      "Number of iterations 225\n",
      "Number of iterations 252\n",
      "Number of iterations 261\n",
      "Number of iterations 226\n",
      "Number of iterations 226\n",
      "Number of iterations 261\n",
      "Number of iterations 209\n",
      "Number of iterations 294\n",
      "Number of iterations 236\n",
      "Number of iterations 263\n",
      "Number of iterations 206\n",
      "Number of iterations 250\n",
      "Number of iterations 262\n",
      "Number of iterations 235\n",
      "Number of iterations 246\n",
      "Number of iterations 254\n",
      "Number of iterations 263\n",
      "Number of iterations 270\n",
      "Number of iterations 226\n",
      "Number of iterations 288\n",
      "Number of iterations 273\n",
      "Number of iterations 268\n",
      "Number of iterations 268\n",
      "Number of iterations 235\n",
      "Number of iterations 193\n",
      "Number of iterations 310\n",
      "Number of iterations 207\n",
      "Number of iterations 267\n",
      "------------\n",
      "20\n",
      "Number of iterations 374\n",
      "Number of iterations 280\n",
      "Number of iterations 245\n",
      "Number of iterations 341\n",
      "Number of iterations 361\n",
      "Number of iterations 312\n",
      "Number of iterations 316\n",
      "Number of iterations 332\n",
      "Number of iterations 309\n",
      "Number of iterations 276\n",
      "Number of iterations 309\n",
      "Number of iterations 276\n",
      "Number of iterations 376\n",
      "Number of iterations 308\n",
      "Number of iterations 361\n",
      "Number of iterations 269\n",
      "Number of iterations 286\n",
      "Number of iterations 336\n",
      "Number of iterations 263\n",
      "Number of iterations 270\n",
      "Number of iterations 304\n",
      "Number of iterations 293\n",
      "Number of iterations 328\n",
      "Number of iterations 274\n",
      "Number of iterations 325\n",
      "Number of iterations 253\n",
      "Number of iterations 395\n",
      "Number of iterations 328\n",
      "Number of iterations 259\n",
      "Number of iterations 234\n",
      "------------\n",
      "25\n",
      "Number of iterations 309\n",
      "Number of iterations 326\n",
      "Number of iterations 332\n",
      "Number of iterations 358\n",
      "Number of iterations 375\n",
      "Number of iterations 423\n",
      "Number of iterations 343\n",
      "Number of iterations 327\n",
      "Number of iterations 348\n",
      "Number of iterations 358\n",
      "Number of iterations 351\n",
      "Number of iterations 333\n",
      "Number of iterations 343\n",
      "Number of iterations 407\n",
      "Number of iterations 368\n",
      "Number of iterations 342\n",
      "Number of iterations 379\n",
      "Number of iterations 330\n",
      "Number of iterations 350\n",
      "Number of iterations 348\n",
      "Number of iterations 360\n",
      "Number of iterations 369\n",
      "Number of iterations 338\n",
      "Number of iterations 353\n",
      "Number of iterations 302\n",
      "Number of iterations 324\n",
      "Number of iterations 392\n",
      "Number of iterations 329\n",
      "Number of iterations 362\n",
      "Number of iterations 402\n",
      "------------\n",
      "30\n",
      "Number of iterations 363\n",
      "Number of iterations 338\n",
      "Number of iterations 464\n",
      "Number of iterations 517\n",
      "Number of iterations 466\n",
      "Number of iterations 364\n",
      "Number of iterations 410\n",
      "Number of iterations 385\n",
      "Number of iterations 394\n",
      "Number of iterations 553\n",
      "Number of iterations 422\n",
      "Number of iterations 353\n",
      "Number of iterations 393\n",
      "Number of iterations 420\n",
      "Number of iterations 388\n",
      "Number of iterations 367\n",
      "Number of iterations 485\n",
      "Number of iterations 397\n",
      "Number of iterations 379\n",
      "Number of iterations 321\n",
      "Number of iterations 426\n",
      "Number of iterations 516\n",
      "Number of iterations 302\n",
      "Number of iterations 338\n",
      "Number of iterations 478\n",
      "Number of iterations 567\n",
      "Number of iterations 416\n",
      "Number of iterations 378\n",
      "Number of iterations 347\n",
      "Number of iterations 410\n",
      "------------\n",
      "35\n",
      "Number of iterations 426\n",
      "Number of iterations 472\n",
      "Number of iterations 458\n",
      "Number of iterations 374\n",
      "Number of iterations 443\n",
      "Number of iterations 528\n",
      "Number of iterations 427\n",
      "Number of iterations 412\n",
      "Number of iterations 444\n",
      "Number of iterations 573\n",
      "Number of iterations 414\n",
      "Number of iterations 529\n",
      "Number of iterations 375\n",
      "Number of iterations 508\n",
      "Number of iterations 500\n",
      "Number of iterations 384\n",
      "Number of iterations 438\n",
      "Number of iterations 609\n",
      "Number of iterations 532\n",
      "Number of iterations 425\n",
      "Number of iterations 463\n",
      "Number of iterations 373\n",
      "Number of iterations 556\n",
      "Number of iterations 436\n",
      "Number of iterations 449\n",
      "Number of iterations 503\n",
      "Number of iterations 485\n",
      "Number of iterations 491\n",
      "Number of iterations 439\n",
      "Number of iterations 419\n",
      "------------\n",
      "40\n",
      "Number of iterations 594\n",
      "Number of iterations 496\n",
      "Number of iterations 557\n",
      "Number of iterations 504\n",
      "Number of iterations 501\n",
      "Number of iterations 545\n",
      "Number of iterations 509\n",
      "Number of iterations 461\n",
      "Number of iterations 552\n",
      "Number of iterations 474\n",
      "Number of iterations 563\n",
      "Number of iterations 423\n",
      "Number of iterations 414\n",
      "Number of iterations 558\n",
      "Number of iterations 557\n",
      "Number of iterations 567\n",
      "Number of iterations 551\n",
      "Number of iterations 547\n",
      "Number of iterations 663\n",
      "Number of iterations 542\n",
      "Number of iterations 685\n",
      "Number of iterations 470\n",
      "Number of iterations 517\n",
      "Number of iterations 536\n",
      "Number of iterations 474\n",
      "Number of iterations 561\n",
      "Number of iterations 544\n",
      "Number of iterations 521\n",
      "Number of iterations 488\n",
      "Number of iterations 537\n",
      "------------\n",
      "45\n",
      "Number of iterations 591\n",
      "Number of iterations 646\n",
      "Number of iterations 653\n",
      "Number of iterations 588\n",
      "Number of iterations 578\n",
      "Number of iterations 600\n",
      "Number of iterations 471\n",
      "Number of iterations 551\n",
      "Number of iterations 607\n",
      "Number of iterations 562\n",
      "Number of iterations 560\n",
      "Number of iterations 512\n",
      "Number of iterations 646\n",
      "Number of iterations 559\n",
      "Number of iterations 634\n",
      "Number of iterations 580\n",
      "Number of iterations 579\n",
      "Number of iterations 625\n",
      "Number of iterations 570\n",
      "Number of iterations 588\n",
      "Number of iterations 569\n",
      "Number of iterations 586\n",
      "Number of iterations 680\n",
      "Number of iterations 597\n",
      "Number of iterations 699\n",
      "Number of iterations 624\n",
      "Number of iterations 541\n",
      "Number of iterations 579\n",
      "Number of iterations 575\n",
      "Number of iterations 552\n",
      "Execution time 0:09:03.887484\n"
     ]
    }
   ],
   "source": [
    "summary_res = []\n",
    "start = datetime.now()\n",
    "\n",
    "for n0 in N0s:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2]\n",
    "    summary_res.append(run_experiments(num_runs, layers, m, eta, learning_rate=learning_rate, num_steps=num_steps, path = None))\n",
    "\n",
    "delta = datetime.now() - start\n",
    "print(\"Execution time\", delta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9\n"
     ]
    }
   ],
   "source": [
    "summary_res_SNR80 = summary_res\n",
    "path = './results/experiment_2_v2/summary_res_SNR80.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_SNR80, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "print(len(summary_res_SNR80))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Two Layers, SNR = 40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "tau = 1e-4\n",
    "eta = tau*etilde/np.linalg.norm(etilde)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "5\n",
      "Number of iterations 143\n",
      "Number of iterations 209\n",
      "Number of iterations 169\n",
      "Number of iterations 219\n",
      "Number of iterations 155\n",
      "Number of iterations 186\n",
      "Number of iterations 139\n",
      "Number of iterations 186\n",
      "Number of iterations 152\n",
      "Number of iterations 160\n",
      "Number of iterations 182\n",
      "Number of iterations 143\n",
      "Number of iterations 179\n",
      "Number of iterations 157\n",
      "Number of iterations 145\n",
      "Number of iterations 141\n",
      "Number of iterations 187\n",
      "Number of iterations 196\n",
      "Number of iterations 153\n",
      "Number of iterations 176\n",
      "Number of iterations 162\n",
      "Number of iterations 145\n",
      "Number of iterations 172\n",
      "Number of iterations 156\n",
      "Number of iterations 141\n",
      "Number of iterations 172\n",
      "Number of iterations 160\n",
      "Number of iterations 213\n",
      "Number of iterations 160\n",
      "Number of iterations 160\n",
      "------------\n",
      "10\n",
      "Number of iterations 206\n",
      "Number of iterations 193\n",
      "Number of iterations 253\n",
      "Number of iterations 195\n",
      "Number of iterations 210\n",
      "Number of iterations 209\n",
      "Number of iterations 206\n",
      "Number of iterations 226\n",
      "Number of iterations 241\n",
      "Number of iterations 215\n",
      "Number of iterations 236\n",
      "Number of iterations 228\n",
      "Number of iterations 228\n",
      "Number of iterations 220\n",
      "Number of iterations 209\n",
      "Number of iterations 212\n",
      "Number of iterations 211\n",
      "Number of iterations 184\n",
      "Number of iterations 189\n",
      "Number of iterations 182\n",
      "Number of iterations 216\n",
      "Number of iterations 221\n",
      "Number of iterations 197\n",
      "Number of iterations 231\n",
      "Number of iterations 199\n",
      "Number of iterations 226\n",
      "Number of iterations 197\n",
      "Number of iterations 194\n",
      "Number of iterations 219\n",
      "Number of iterations 220\n",
      "------------\n",
      "15\n",
      "Number of iterations 242\n",
      "Number of iterations 207\n",
      "Number of iterations 266\n",
      "Number of iterations 270\n",
      "Number of iterations 230\n",
      "Number of iterations 231\n",
      "Number of iterations 262\n",
      "Number of iterations 221\n",
      "Number of iterations 206\n",
      "Number of iterations 217\n",
      "Number of iterations 264\n",
      "Number of iterations 244\n",
      "Number of iterations 300\n",
      "Number of iterations 217\n",
      "Number of iterations 273\n",
      "Number of iterations 208\n",
      "Number of iterations 236\n",
      "Number of iterations 277\n",
      "Number of iterations 262\n",
      "Number of iterations 232\n",
      "Number of iterations 237\n",
      "Number of iterations 238\n",
      "Number of iterations 233\n",
      "Number of iterations 263\n",
      "Number of iterations 340\n",
      "Number of iterations 287\n",
      "Number of iterations 303\n",
      "Number of iterations 282\n",
      "Number of iterations 234\n",
      "Number of iterations 255\n",
      "------------\n",
      "20\n",
      "Number of iterations 302\n",
      "Number of iterations 298\n",
      "Number of iterations 322\n",
      "Number of iterations 263\n",
      "Number of iterations 427\n",
      "Number of iterations 283\n",
      "Number of iterations 335\n",
      "Number of iterations 263\n",
      "Number of iterations 277\n",
      "Number of iterations 286\n",
      "Number of iterations 301\n",
      "Number of iterations 290\n",
      "Number of iterations 285\n",
      "Number of iterations 361\n",
      "Number of iterations 283\n",
      "Number of iterations 320\n",
      "Number of iterations 311\n",
      "Number of iterations 284\n",
      "Number of iterations 297\n",
      "Number of iterations 313\n",
      "Number of iterations 247\n",
      "Number of iterations 310\n",
      "Number of iterations 253\n",
      "Number of iterations 299\n",
      "Number of iterations 250\n",
      "Number of iterations 345\n",
      "Number of iterations 349\n",
      "Number of iterations 331\n",
      "Number of iterations 273\n",
      "Number of iterations 273\n",
      "------------\n",
      "25\n",
      "Number of iterations 322\n",
      "Number of iterations 330\n",
      "Number of iterations 324\n",
      "Number of iterations 377\n",
      "Number of iterations 336\n",
      "Number of iterations 302\n",
      "Number of iterations 337\n",
      "Number of iterations 374\n",
      "Number of iterations 345\n",
      "Number of iterations 316\n",
      "Number of iterations 348\n",
      "Number of iterations 321\n",
      "Number of iterations 372\n",
      "Number of iterations 285\n",
      "Number of iterations 310\n",
      "Number of iterations 509\n",
      "Number of iterations 320\n",
      "Number of iterations 372\n",
      "Number of iterations 369\n",
      "Number of iterations 343\n",
      "Number of iterations 326\n",
      "Number of iterations 392\n",
      "Number of iterations 381\n",
      "Number of iterations 333\n",
      "Number of iterations 330\n",
      "Number of iterations 343\n",
      "Number of iterations 342\n",
      "Number of iterations 343\n",
      "Number of iterations 323\n",
      "Number of iterations 396\n",
      "------------\n",
      "30\n",
      "Number of iterations 390\n",
      "Number of iterations 399\n",
      "Number of iterations 373\n",
      "Number of iterations 299\n",
      "Number of iterations 374\n",
      "Number of iterations 383\n",
      "Number of iterations 422\n",
      "Number of iterations 324\n",
      "Number of iterations 402\n",
      "Number of iterations 375\n",
      "Number of iterations 398\n",
      "Number of iterations 465\n",
      "Number of iterations 439\n",
      "Number of iterations 426\n",
      "Number of iterations 545\n",
      "Number of iterations 375\n",
      "Number of iterations 386\n",
      "Number of iterations 328\n",
      "Number of iterations 391\n",
      "Number of iterations 450\n",
      "Number of iterations 425\n",
      "Number of iterations 357\n",
      "Number of iterations 397\n",
      "Number of iterations 452\n",
      "Number of iterations 436\n",
      "Number of iterations 384\n",
      "Number of iterations 350\n",
      "Number of iterations 452\n",
      "Number of iterations 369\n",
      "Number of iterations 347\n",
      "------------\n",
      "35\n",
      "Number of iterations 501\n",
      "Number of iterations 449\n",
      "Number of iterations 448\n",
      "Number of iterations 412\n",
      "Number of iterations 504\n",
      "Number of iterations 423\n",
      "Number of iterations 465\n",
      "Number of iterations 472\n",
      "Number of iterations 426\n",
      "Number of iterations 535\n",
      "Number of iterations 386\n",
      "Number of iterations 460\n",
      "Number of iterations 496\n",
      "Number of iterations 462\n",
      "Number of iterations 525\n",
      "Number of iterations 430\n",
      "Number of iterations 466\n",
      "Number of iterations 552\n",
      "Number of iterations 479\n",
      "Number of iterations 395\n",
      "Number of iterations 416\n",
      "Number of iterations 452\n",
      "Number of iterations 497\n",
      "Number of iterations 458\n",
      "Number of iterations 505\n",
      "Number of iterations 400\n",
      "Number of iterations 486\n",
      "Number of iterations 479\n",
      "Number of iterations 434\n",
      "Number of iterations 470\n",
      "------------\n",
      "40\n",
      "Number of iterations 550\n",
      "Number of iterations 497\n",
      "Number of iterations 543\n",
      "Number of iterations 477\n",
      "Number of iterations 504\n",
      "Number of iterations 476\n",
      "Number of iterations 632\n",
      "Number of iterations 443\n",
      "Number of iterations 498\n",
      "Number of iterations 551\n",
      "Number of iterations 527\n",
      "Number of iterations 527\n",
      "Number of iterations 568\n",
      "Number of iterations 556\n",
      "Number of iterations 571\n",
      "Number of iterations 553\n",
      "Number of iterations 510\n",
      "Number of iterations 486\n",
      "Number of iterations 522\n",
      "Number of iterations 542\n",
      "Number of iterations 501\n",
      "Number of iterations 492\n",
      "Number of iterations 529\n",
      "Number of iterations 428\n",
      "Number of iterations 634\n",
      "Number of iterations 473\n",
      "Number of iterations 533\n",
      "Number of iterations 441\n",
      "Number of iterations 548\n",
      "Number of iterations 589\n",
      "------------\n",
      "45\n",
      "Number of iterations 556\n",
      "Number of iterations 488\n",
      "Number of iterations 588\n",
      "Number of iterations 617\n",
      "Number of iterations 583\n",
      "Number of iterations 565\n",
      "Number of iterations 463\n",
      "Number of iterations 648\n",
      "Number of iterations 554\n",
      "Number of iterations 521\n",
      "Number of iterations 542\n",
      "Number of iterations 709\n",
      "Number of iterations 698\n",
      "Number of iterations 596\n",
      "Number of iterations 503\n",
      "Number of iterations 572\n",
      "Number of iterations 724\n",
      "Number of iterations 668\n",
      "Number of iterations 631\n",
      "Number of iterations 621\n",
      "Number of iterations 625\n",
      "Number of iterations 638\n",
      "Number of iterations 566\n",
      "Number of iterations 760\n",
      "Number of iterations 636\n",
      "Number of iterations 514\n",
      "Number of iterations 607\n",
      "Number of iterations 527\n",
      "Number of iterations 615\n",
      "Number of iterations 686\n",
      "Execution time 0:08:20.321917\n"
     ]
    }
   ],
   "source": [
    "summary_res = []\n",
    "start = datetime.now()\n",
    "\n",
    "for n0 in N0s:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2]\n",
    "    summary_res.append(run_experiments(num_runs, layers, m, eta, learning_rate=learning_rate, num_steps=num_steps, path = None))\n",
    "\n",
    "delta = datetime.now() - start\n",
    "print(\"Execution time\", delta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9\n"
     ]
    }
   ],
   "source": [
    "summary_res_SNR40 = summary_res\n",
    "path = './results/experiment_2_v2/summary_res_SNR40.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_SNR40, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "print(len(summary_res_SNR40))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Two Layers, SNR = 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "tau = 1e-2\n",
    "eta = tau*etilde/np.linalg.norm(etilde)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "5\n",
      "Number of iterations 201\n",
      "Number of iterations 150\n",
      "Number of iterations 156\n",
      "Number of iterations 179\n",
      "Number of iterations 204\n",
      "Number of iterations 165\n",
      "Number of iterations 175\n",
      "Number of iterations 185\n",
      "Number of iterations 150\n",
      "Number of iterations 140\n",
      "Number of iterations 143\n",
      "Number of iterations 175\n",
      "Number of iterations 193\n",
      "Number of iterations 171\n",
      "Number of iterations 168\n",
      "Number of iterations 185\n",
      "Number of iterations 149\n",
      "Number of iterations 195\n",
      "Number of iterations 164\n",
      "Number of iterations 221\n",
      "Number of iterations 172\n",
      "Number of iterations 196\n",
      "Number of iterations 181\n",
      "Number of iterations 155\n",
      "Number of iterations 165\n",
      "Number of iterations 150\n",
      "Number of iterations 153\n",
      "Number of iterations 144\n",
      "Number of iterations 162\n",
      "Number of iterations 170\n",
      "------------\n",
      "10\n",
      "Number of iterations 50000\n",
      "Number of iterations 199\n",
      "Number of iterations 50000\n",
      "Number of iterations 201\n",
      "Number of iterations 215\n",
      "Number of iterations 230\n",
      "Number of iterations 50000\n",
      "Number of iterations 199\n",
      "Number of iterations 220\n",
      "Number of iterations 241\n",
      "Number of iterations 251\n",
      "Number of iterations 172\n",
      "Number of iterations 289\n",
      "Number of iterations 236\n",
      "Number of iterations 194\n",
      "Number of iterations 225\n",
      "Number of iterations 173\n",
      "Number of iterations 198\n",
      "Number of iterations 232\n",
      "Number of iterations 237\n",
      "Number of iterations 202\n",
      "Number of iterations 223\n",
      "Number of iterations 209\n",
      "Number of iterations 239\n",
      "Number of iterations 177\n",
      "Number of iterations 192\n",
      "Number of iterations 255\n",
      "Number of iterations 50000\n",
      "Number of iterations 243\n",
      "Number of iterations 239\n",
      "------------\n",
      "15\n",
      "Number of iterations 235\n",
      "Number of iterations 254\n",
      "Number of iterations 240\n",
      "Number of iterations 255\n",
      "Number of iterations 299\n",
      "Number of iterations 226\n",
      "Number of iterations 253\n",
      "Number of iterations 273\n",
      "Number of iterations 240\n",
      "Number of iterations 194\n",
      "Number of iterations 229\n",
      "Number of iterations 199\n",
      "Number of iterations 219\n",
      "Number of iterations 278\n",
      "Number of iterations 288\n",
      "Number of iterations 265\n",
      "Number of iterations 262\n",
      "Number of iterations 254\n",
      "Number of iterations 238\n",
      "Number of iterations 269\n",
      "Number of iterations 282\n",
      "Number of iterations 269\n",
      "Number of iterations 277\n",
      "Number of iterations 203\n",
      "Number of iterations 273\n",
      "Number of iterations 240\n",
      "Number of iterations 256\n",
      "Number of iterations 290\n",
      "Number of iterations 278\n",
      "Number of iterations 248\n",
      "------------\n",
      "20\n",
      "Number of iterations 353\n",
      "Number of iterations 359\n",
      "Number of iterations 304\n",
      "Number of iterations 292\n",
      "Number of iterations 308\n",
      "Number of iterations 288\n",
      "Number of iterations 260\n",
      "Number of iterations 258\n",
      "Number of iterations 364\n",
      "Number of iterations 300\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 344\n",
      "Number of iterations 348\n",
      "Number of iterations 251\n",
      "Number of iterations 316\n",
      "Number of iterations 278\n",
      "Number of iterations 279\n",
      "Number of iterations 278\n",
      "Number of iterations 291\n",
      "Number of iterations 349\n",
      "Number of iterations 50000\n",
      "Number of iterations 274\n",
      "Number of iterations 290\n",
      "Number of iterations 291\n",
      "Number of iterations 303\n",
      "Number of iterations 319\n",
      "Number of iterations 245\n",
      "Number of iterations 345\n",
      "Number of iterations 371\n",
      "------------\n",
      "25\n",
      "Number of iterations 388\n",
      "Number of iterations 378\n",
      "Number of iterations 339\n",
      "Number of iterations 291\n",
      "Number of iterations 287\n",
      "Number of iterations 363\n",
      "Number of iterations 367\n",
      "Number of iterations 304\n",
      "Number of iterations 311\n",
      "Number of iterations 50000\n",
      "Number of iterations 374\n",
      "Number of iterations 330\n",
      "Number of iterations 411\n",
      "Number of iterations 364\n",
      "Number of iterations 333\n",
      "Number of iterations 50000\n",
      "Number of iterations 381\n",
      "Number of iterations 332\n",
      "Number of iterations 373\n",
      "Number of iterations 357\n",
      "Number of iterations 312\n",
      "Number of iterations 367\n",
      "Number of iterations 300\n",
      "Number of iterations 363\n",
      "Number of iterations 318\n",
      "Number of iterations 50000\n",
      "Number of iterations 295\n",
      "Number of iterations 315\n",
      "Number of iterations 325\n",
      "Number of iterations 314\n",
      "------------\n",
      "30\n",
      "Number of iterations 365\n",
      "Number of iterations 379\n",
      "Number of iterations 366\n",
      "Number of iterations 418\n",
      "Number of iterations 375\n",
      "Number of iterations 403\n",
      "Number of iterations 50000\n",
      "Number of iterations 431\n",
      "Number of iterations 50000\n",
      "Number of iterations 415\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 391\n",
      "Number of iterations 362\n",
      "Number of iterations 50000\n",
      "Number of iterations 445\n",
      "Number of iterations 438\n",
      "Number of iterations 479\n",
      "Number of iterations 467\n",
      "Number of iterations 369\n",
      "Number of iterations 406\n",
      "Number of iterations 452\n",
      "Number of iterations 50000\n",
      "Number of iterations 382\n",
      "Number of iterations 365\n",
      "Number of iterations 50000\n",
      "Number of iterations 402\n",
      "Number of iterations 353\n",
      "Number of iterations 389\n",
      "Number of iterations 376\n",
      "------------\n",
      "35\n",
      "Number of iterations 557\n",
      "Number of iterations 50000\n",
      "Number of iterations 441\n",
      "Number of iterations 558\n",
      "Number of iterations 50000\n",
      "Number of iterations 439\n",
      "Number of iterations 50000\n",
      "Number of iterations 524\n",
      "Number of iterations 403\n",
      "Number of iterations 567\n",
      "Number of iterations 451\n",
      "Number of iterations 562\n",
      "Number of iterations 449\n",
      "Number of iterations 441\n",
      "Number of iterations 485\n",
      "Number of iterations 50000\n",
      "Number of iterations 447\n",
      "Number of iterations 467\n",
      "Number of iterations 477\n",
      "Number of iterations 499\n",
      "Number of iterations 421\n",
      "Number of iterations 442\n",
      "Number of iterations 434\n",
      "Number of iterations 418\n",
      "Number of iterations 462\n",
      "Number of iterations 489\n",
      "Number of iterations 50000\n",
      "Number of iterations 441\n",
      "Number of iterations 446\n",
      "Number of iterations 553\n",
      "------------\n",
      "40\n",
      "Number of iterations 503\n",
      "Number of iterations 663\n",
      "Number of iterations 520\n",
      "Number of iterations 506\n",
      "Number of iterations 563\n",
      "Number of iterations 492\n",
      "Number of iterations 482\n",
      "Number of iterations 509\n",
      "Number of iterations 499\n",
      "Number of iterations 562\n",
      "Number of iterations 489\n",
      "Number of iterations 486\n",
      "Number of iterations 482\n",
      "Number of iterations 564\n",
      "Number of iterations 479\n",
      "Number of iterations 456\n",
      "Number of iterations 50000\n",
      "Number of iterations 452\n",
      "Number of iterations 518\n",
      "Number of iterations 519\n",
      "Number of iterations 489\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 503\n",
      "Number of iterations 570\n",
      "Number of iterations 455\n",
      "Number of iterations 546\n",
      "Number of iterations 486\n",
      "------------\n",
      "45\n",
      "Number of iterations 567\n",
      "Number of iterations 624\n",
      "Number of iterations 447\n",
      "Number of iterations 697\n",
      "Number of iterations 482\n",
      "Number of iterations 50000\n",
      "Number of iterations 544\n",
      "Number of iterations 521\n",
      "Number of iterations 582\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 515\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 556\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 504\n",
      "Number of iterations 493\n",
      "Number of iterations 50000\n",
      "Number of iterations 50000\n",
      "Number of iterations 554\n",
      "Number of iterations 539\n",
      "Number of iterations 482\n",
      "Number of iterations 483\n",
      "Number of iterations 668\n",
      "Number of iterations 502\n",
      "Number of iterations 571\n",
      "Number of iterations 50000\n",
      "Execution time 4:59:13.312990\n"
     ]
    }
   ],
   "source": [
    "summary_res = []\n",
    "start = datetime.now()\n",
    "\n",
    "for n0 in N0s:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2]\n",
    "    summary_res.append(run_experiments(num_runs, layers, m, eta, learning_rate=learning_rate, num_steps=num_steps, path = None))\n",
    "\n",
    "delta = datetime.now() - start\n",
    "print(\"Execution time\", delta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9\n"
     ]
    }
   ],
   "source": [
    "summary_res_SNR20 = summary_res\n",
    "path = './results/experiment_2_v2/summary_res_SNR20.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_SNR20, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "print(len(summary_res_SNR20))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f86e12ad520>]"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "relError_y_mean_SNR40 = []\n",
    "\n",
    "for res in summary_res_SNR40:\n",
    "    relError_y_mean_SNR40.append(res['relError_y_mean'])\n",
    "\n",
    "plt.plot(N0s, relError_y_mean_SNR40, '-*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f86e135e6d0>]"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "relError_y_mean_SNR20 = []\n",
    "\n",
    "for res in summary_res_SNR20:\n",
    "    relError_y_mean_SNR20.append(res['relError_y_mean'])\n",
    "\n",
    "plt.plot(N0s, relError_y_mean_SNR20, '-*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f86c12e28b0>]"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "relError_y_mean_SNR80 = []\n",
    "\n",
    "for res in summary_res_SNR80:\n",
    "    relError_y_mean_SNR80.append(res['relError_y_mean'])\n",
    "\n",
    "plt.plot(N0s, relError_y_mean_SNR80, '-*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "summary_res_SNR40\n",
    "relError_y_mean_SNR40 = []\n",
    "\n",
    "for res in summary_res_SNR20:\n",
    "    relError_y_mean_SNR20.append(res['relError_y_mean'])\n",
    "\n",
    "plt.plot(N0s, relError_y_mean_SNR20, '-*')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.12 ('ML21')",
   "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.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "982ac801f23870e9fed1de30414f48b3ec5ddc480779b2558e7f71a46d0972cf"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
