{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "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": 3,
   "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": 4,
   "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": [
    "### Succes of Recovery (noiseless)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Two Layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_runs = 30\n",
    "n1, n2 =  700, 600\n",
    "m = 300\n",
    "eta = np.zeros(m)\n",
    "num_steps = 20000\n",
    "learning_rate = 0.7\n",
    "N0s = [5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 70, 80, 90, 100, 150]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "5\n",
      "Number of iterations 157\n",
      "Number of iterations 161\n",
      "Number of iterations 142\n",
      "Number of iterations 126\n",
      "Number of iterations 163\n",
      "Number of iterations 154\n",
      "Number of iterations 171\n",
      "Number of iterations 174\n",
      "Number of iterations 156\n",
      "Number of iterations 151\n",
      "Number of iterations 150\n",
      "Number of iterations 160\n",
      "Number of iterations 177\n",
      "Number of iterations 158\n",
      "Number of iterations 182\n",
      "Number of iterations 172\n",
      "Number of iterations 191\n",
      "Number of iterations 156\n",
      "Number of iterations 203\n",
      "Number of iterations 249\n",
      "Number of iterations 134\n",
      "Number of iterations 188\n",
      "Number of iterations 170\n",
      "Number of iterations 176\n",
      "Number of iterations 156\n",
      "Number of iterations 206\n",
      "Number of iterations 144\n",
      "Number of iterations 172\n",
      "Number of iterations 171\n",
      "Number of iterations 193\n",
      "------------\n",
      "10\n",
      "Number of iterations 208\n",
      "Number of iterations 212\n",
      "Number of iterations 188\n",
      "Number of iterations 211\n",
      "Number of iterations 188\n",
      "Number of iterations 201\n",
      "Number of iterations 210\n",
      "Number of iterations 225\n",
      "Number of iterations 167\n",
      "Number of iterations 279\n",
      "Number of iterations 217\n",
      "Number of iterations 209\n",
      "Number of iterations 229\n",
      "Number of iterations 194\n",
      "Number of iterations 202\n",
      "Number of iterations 207\n",
      "Number of iterations 193\n",
      "Number of iterations 198\n",
      "Number of iterations 209\n",
      "Number of iterations 198\n",
      "Number of iterations 202\n",
      "Number of iterations 223\n",
      "Number of iterations 230\n",
      "Number of iterations 215\n",
      "Number of iterations 188\n",
      "Number of iterations 184\n",
      "Number of iterations 223\n",
      "Number of iterations 181\n",
      "Number of iterations 239\n",
      "Number of iterations 204\n",
      "------------\n",
      "15\n",
      "Number of iterations 269\n",
      "Number of iterations 250\n",
      "Number of iterations 225\n",
      "Number of iterations 260\n",
      "Number of iterations 218\n",
      "Number of iterations 300\n",
      "Number of iterations 271\n",
      "Number of iterations 218\n",
      "Number of iterations 261\n",
      "Number of iterations 265\n",
      "Number of iterations 256\n",
      "Number of iterations 233\n",
      "Number of iterations 265\n",
      "Number of iterations 287\n",
      "Number of iterations 244\n",
      "Number of iterations 252\n",
      "Number of iterations 264\n",
      "Number of iterations 313\n",
      "Number of iterations 200\n",
      "Number of iterations 282\n",
      "Number of iterations 265\n",
      "Number of iterations 243\n",
      "Number of iterations 296\n",
      "Number of iterations 280\n",
      "Number of iterations 242\n",
      "Number of iterations 290\n",
      "Number of iterations 245\n",
      "Number of iterations 266\n",
      "Number of iterations 242\n",
      "Number of iterations 238\n",
      "------------\n",
      "20\n",
      "Number of iterations 293\n",
      "Number of iterations 260\n",
      "Number of iterations 243\n",
      "Number of iterations 263\n",
      "Number of iterations 270\n",
      "Number of iterations 302\n",
      "Number of iterations 284\n",
      "Number of iterations 324\n",
      "Number of iterations 345\n",
      "Number of iterations 295\n",
      "Number of iterations 274\n",
      "Number of iterations 246\n",
      "Number of iterations 315\n",
      "Number of iterations 307\n",
      "Number of iterations 339\n",
      "Number of iterations 319\n",
      "Number of iterations 361\n",
      "Number of iterations 265\n",
      "Number of iterations 317\n",
      "Number of iterations 263\n",
      "Number of iterations 296\n",
      "Number of iterations 301\n",
      "Number of iterations 281\n",
      "Number of iterations 291\n",
      "Number of iterations 286\n",
      "Number of iterations 323\n",
      "Number of iterations 357\n",
      "Number of iterations 323\n",
      "Number of iterations 331\n",
      "Number of iterations 287\n",
      "------------\n",
      "25\n",
      "Number of iterations 338\n",
      "Number of iterations 376\n",
      "Number of iterations 273\n",
      "Number of iterations 359\n",
      "Number of iterations 423\n",
      "Number of iterations 361\n",
      "Number of iterations 324\n",
      "Number of iterations 346\n",
      "Number of iterations 317\n",
      "Number of iterations 374\n",
      "Number of iterations 327\n",
      "Number of iterations 355\n",
      "Number of iterations 407\n",
      "Number of iterations 336\n",
      "Number of iterations 331\n",
      "Number of iterations 396\n",
      "Number of iterations 314\n",
      "Number of iterations 404\n",
      "Number of iterations 367\n",
      "Number of iterations 323\n",
      "Number of iterations 344\n",
      "Number of iterations 333\n",
      "Number of iterations 315\n",
      "Number of iterations 390\n",
      "Number of iterations 347\n",
      "Number of iterations 385\n",
      "Number of iterations 391\n",
      "Number of iterations 358\n",
      "Number of iterations 313\n",
      "Number of iterations 333\n",
      "------------\n",
      "30\n",
      "Number of iterations 301\n",
      "Number of iterations 374\n",
      "Number of iterations 405\n",
      "Number of iterations 354\n",
      "Number of iterations 358\n",
      "Number of iterations 465\n",
      "Number of iterations 373\n",
      "Number of iterations 419\n",
      "Number of iterations 364\n",
      "Number of iterations 384\n",
      "Number of iterations 429\n",
      "Number of iterations 506\n",
      "Number of iterations 382\n",
      "Number of iterations 483\n",
      "Number of iterations 351\n",
      "Number of iterations 458\n",
      "Number of iterations 369\n",
      "Number of iterations 388\n",
      "Number of iterations 437\n",
      "Number of iterations 361\n",
      "Number of iterations 374\n",
      "Number of iterations 401\n",
      "Number of iterations 453\n",
      "Number of iterations 395\n",
      "Number of iterations 334\n",
      "Number of iterations 396\n",
      "Number of iterations 413\n",
      "Number of iterations 419\n",
      "Number of iterations 350\n",
      "Number of iterations 378\n",
      "------------\n",
      "35\n",
      "Number of iterations 493\n",
      "Number of iterations 527\n",
      "Number of iterations 414\n",
      "Number of iterations 471\n",
      "Number of iterations 511\n",
      "Number of iterations 483\n",
      "Number of iterations 416\n",
      "Number of iterations 433\n",
      "Number of iterations 413\n",
      "Number of iterations 414\n",
      "Number of iterations 487\n",
      "Number of iterations 490\n",
      "Number of iterations 464\n",
      "Number of iterations 431\n",
      "Number of iterations 484\n",
      "Number of iterations 501\n",
      "Number of iterations 445\n",
      "Number of iterations 421\n",
      "Number of iterations 396\n",
      "Number of iterations 434\n",
      "Number of iterations 386\n",
      "Number of iterations 492\n",
      "Number of iterations 500\n",
      "Number of iterations 378\n",
      "Number of iterations 420\n",
      "Number of iterations 564\n",
      "Number of iterations 504\n",
      "Number of iterations 496\n",
      "Number of iterations 408\n",
      "Number of iterations 439\n",
      "------------\n",
      "40\n",
      "Number of iterations 450\n",
      "Number of iterations 593\n",
      "Number of iterations 565\n",
      "Number of iterations 546\n",
      "Number of iterations 467\n",
      "Number of iterations 531\n",
      "Number of iterations 585\n",
      "Number of iterations 487\n",
      "Number of iterations 426\n",
      "Number of iterations 461\n",
      "Number of iterations 487\n",
      "Number of iterations 477\n",
      "Number of iterations 481\n",
      "Number of iterations 512\n",
      "Number of iterations 555\n",
      "Number of iterations 465\n",
      "Number of iterations 616\n",
      "Number of iterations 583\n",
      "Number of iterations 605\n",
      "Number of iterations 472\n",
      "Number of iterations 469\n",
      "Number of iterations 583\n",
      "Number of iterations 631\n",
      "Number of iterations 534\n",
      "Number of iterations 572\n",
      "Number of iterations 528\n",
      "Number of iterations 524\n",
      "Number of iterations 565\n",
      "Number of iterations 541\n",
      "Number of iterations 535\n",
      "------------\n",
      "45\n",
      "Number of iterations 592\n",
      "Number of iterations 607\n",
      "Number of iterations 648\n",
      "Number of iterations 540\n",
      "Number of iterations 612\n",
      "Number of iterations 565\n",
      "Number of iterations 617\n",
      "Number of iterations 776\n",
      "Number of iterations 540\n",
      "Number of iterations 596\n",
      "Number of iterations 512\n",
      "Number of iterations 661\n",
      "Number of iterations 620\n",
      "Number of iterations 504\n",
      "Number of iterations 658\n",
      "Number of iterations 732\n",
      "Number of iterations 671\n",
      "Number of iterations 643\n",
      "Number of iterations 621\n",
      "Number of iterations 563\n",
      "Number of iterations 675\n",
      "Number of iterations 546\n",
      "Number of iterations 667\n",
      "Number of iterations 807\n",
      "Number of iterations 555\n",
      "Number of iterations 524\n",
      "Number of iterations 650\n",
      "Number of iterations 493\n",
      "Number of iterations 558\n",
      "Number of iterations 830\n",
      "------------\n",
      "50\n",
      "Number of iterations 633\n",
      "Number of iterations 600\n",
      "Number of iterations 753\n",
      "Number of iterations 712\n",
      "Number of iterations 566\n",
      "Number of iterations 603\n",
      "Number of iterations 792\n",
      "Number of iterations 606\n",
      "Number of iterations 665\n",
      "Number of iterations 719\n",
      "Number of iterations 677\n",
      "Number of iterations 584\n",
      "Number of iterations 681\n",
      "Number of iterations 691\n",
      "Number of iterations 730\n",
      "Number of iterations 602\n",
      "Number of iterations 589\n",
      "Number of iterations 548\n",
      "Number of iterations 641\n",
      "Number of iterations 668\n",
      "Number of iterations 670\n",
      "Number of iterations 620\n",
      "Number of iterations 597\n",
      "Number of iterations 642\n",
      "Number of iterations 589\n",
      "Number of iterations 849\n",
      "Number of iterations 638\n",
      "Number of iterations 551\n",
      "Number of iterations 754\n",
      "Number of iterations 597\n",
      "------------\n",
      "55\n",
      "Number of iterations 736\n",
      "Number of iterations 690\n",
      "Number of iterations 733\n",
      "Number of iterations 670\n",
      "Number of iterations 864\n",
      "Number of iterations 687\n",
      "Number of iterations 807\n",
      "Number of iterations 721\n",
      "Number of iterations 666\n",
      "Number of iterations 835\n",
      "Number of iterations 789\n",
      "Number of iterations 726\n",
      "Number of iterations 730\n",
      "Number of iterations 761\n",
      "Number of iterations 794\n",
      "Number of iterations 837\n",
      "Number of iterations 914\n",
      "Number of iterations 869\n",
      "Number of iterations 828\n",
      "Number of iterations 712\n",
      "Number of iterations 864\n",
      "Number of iterations 697\n",
      "Number of iterations 794\n",
      "Number of iterations 748\n",
      "Number of iterations 732\n",
      "Number of iterations 707\n",
      "Number of iterations 734\n",
      "Number of iterations 678\n",
      "Number of iterations 806\n",
      "Number of iterations 618\n",
      "------------\n",
      "60\n",
      "Number of iterations 827\n",
      "Number of iterations 784\n",
      "Number of iterations 818\n",
      "Number of iterations 866\n",
      "Number of iterations 723\n",
      "Number of iterations 848\n",
      "Number of iterations 712\n",
      "Number of iterations 980\n",
      "Number of iterations 744\n",
      "Number of iterations 868\n",
      "Number of iterations 745\n",
      "Number of iterations 761\n",
      "Number of iterations 966\n",
      "Number of iterations 743\n",
      "Number of iterations 905\n",
      "Number of iterations 886\n",
      "Number of iterations 901\n",
      "Number of iterations 773\n",
      "Number of iterations 725\n",
      "Number of iterations 869\n",
      "Number of iterations 792\n",
      "Number of iterations 1093\n",
      "Number of iterations 877\n",
      "Number of iterations 727\n",
      "Number of iterations 964\n",
      "Number of iterations 831\n",
      "Number of iterations 730\n",
      "Number of iterations 1048\n",
      "Number of iterations 819\n",
      "Number of iterations 904\n",
      "------------\n",
      "70\n",
      "Number of iterations 1173\n",
      "Number of iterations 1100\n",
      "Number of iterations 1137\n",
      "Number of iterations 1041\n",
      "Number of iterations 1160\n",
      "Number of iterations 970\n",
      "Number of iterations 1115\n",
      "Number of iterations 1001\n",
      "Number of iterations 1007\n",
      "Number of iterations 1101\n",
      "Number of iterations 1081\n",
      "Number of iterations 1042\n",
      "Number of iterations 1063\n",
      "Number of iterations 1032\n",
      "Number of iterations 1088\n",
      "Number of iterations 915\n",
      "Number of iterations 1083\n",
      "Number of iterations 1175\n",
      "Number of iterations 1001\n",
      "Number of iterations 1119\n",
      "Number of iterations 1021\n",
      "Number of iterations 879\n",
      "Number of iterations 1007\n",
      "Number of iterations 1149\n",
      "Number of iterations 945\n",
      "Number of iterations 1024\n",
      "Number of iterations 1031\n",
      "Number of iterations 873\n",
      "Number of iterations 1028\n",
      "Number of iterations 1116\n",
      "------------\n",
      "80\n",
      "Number of iterations 1722\n",
      "Number of iterations 1072\n",
      "Number of iterations 1522\n",
      "Number of iterations 1517\n",
      "Number of iterations 1447\n",
      "Number of iterations 1607\n",
      "Number of iterations 1139\n",
      "Number of iterations 1404\n",
      "Number of iterations 1309\n",
      "Number of iterations 1407\n",
      "Number of iterations 1531\n",
      "Number of iterations 1492\n",
      "Number of iterations 1284\n",
      "Number of iterations 1319\n",
      "Number of iterations 1672\n",
      "Number of iterations 1430\n",
      "Number of iterations 1484\n",
      "Number of iterations 1435\n",
      "Number of iterations 1307\n",
      "Number of iterations 7089\n",
      "Number of iterations 1254\n",
      "Number of iterations 1275\n",
      "Number of iterations 1636\n",
      "Number of iterations 1262\n",
      "Number of iterations 1443\n",
      "Number of iterations 1463\n",
      "Number of iterations 1151\n",
      "Number of iterations 1301\n",
      "Number of iterations 1349\n",
      "Number of iterations 1321\n",
      "------------\n",
      "90\n",
      "Number of iterations 1822\n",
      "Number of iterations 1806\n",
      "Number of iterations 1607\n",
      "Number of iterations 1607\n",
      "Number of iterations 1674\n",
      "Number of iterations 1540\n",
      "Number of iterations 20000\n",
      "Number of iterations 1341\n",
      "Number of iterations 1751\n",
      "Number of iterations 1722\n",
      "Number of iterations 1673\n",
      "Number of iterations 1760\n",
      "Number of iterations 1809\n",
      "Number of iterations 1582\n",
      "Number of iterations 2204\n",
      "Number of iterations 1524\n",
      "Number of iterations 1842\n",
      "Number of iterations 1788\n",
      "Number of iterations 1756\n",
      "Number of iterations 1796\n",
      "Number of iterations 1578\n",
      "Number of iterations 2337\n",
      "Number of iterations 1756\n",
      "Number of iterations 1776\n",
      "Number of iterations 1875\n",
      "Number of iterations 1500\n",
      "Number of iterations 1600\n",
      "Number of iterations 1928\n",
      "Number of iterations 1634\n",
      "Number of iterations 1522\n",
      "------------\n",
      "100\n",
      "Number of iterations 3026\n",
      "Number of iterations 2192\n",
      "Number of iterations 2307\n",
      "Number of iterations 2363\n",
      "Number of iterations 2612\n",
      "Number of iterations 1988\n",
      "Number of iterations 3104\n",
      "Number of iterations 2585\n",
      "Number of iterations 2624\n",
      "Number of iterations 2031\n",
      "Number of iterations 1901\n",
      "Number of iterations 2145\n",
      "Number of iterations 2375\n",
      "Number of iterations 2464\n",
      "Number of iterations 1944\n",
      "Number of iterations 1860\n",
      "Number of iterations 1776\n",
      "Number of iterations 2147\n",
      "Number of iterations 1955\n",
      "Number of iterations 2056\n",
      "Number of iterations 1981\n",
      "Number of iterations 2822\n",
      "Number of iterations 2617\n",
      "Number of iterations 1972\n",
      "Number of iterations 2051\n",
      "Number of iterations 1873\n",
      "Number of iterations 2469\n",
      "Number of iterations 2333\n",
      "Number of iterations 2548\n",
      "Number of iterations 2246\n",
      "------------\n",
      "150\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 13545\n",
      "Number of iterations 6575\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 8495\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 6691\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 8702\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Execution time 2:09:44.829337\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": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "summary_res_2Layers = summary_res\n",
    "path = './results/experiment_1_v2/summary_res_2Layers.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_2Layers, handle, protocol=pickle.HIGHEST_PROTOCOL)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "prob_recovery_y_2L = []\n",
    "\n",
    "for res in summary_res_2Layers:\n",
    "    prob_recovery_y_2L.append(res['prob_recovery_y'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "120\n",
      "Number of iterations 2922\n",
      "Number of iterations 20000\n",
      "Number of iterations 4140\n",
      "Number of iterations 4187\n",
      "Number of iterations 3869\n",
      "Number of iterations 3273\n",
      "Number of iterations 5379\n",
      "Number of iterations 3474\n",
      "Number of iterations 4957\n",
      "Number of iterations 3796\n",
      "Number of iterations 4725\n",
      "Number of iterations 20000\n",
      "Number of iterations 3811\n",
      "Number of iterations 4129\n",
      "Number of iterations 3821\n",
      "Number of iterations 4021\n",
      "Number of iterations 3636\n",
      "Number of iterations 3807\n",
      "Number of iterations 4004\n",
      "Number of iterations 4337\n",
      "Number of iterations 3379\n",
      "Number of iterations 5099\n",
      "Number of iterations 4118\n",
      "Number of iterations 4145\n",
      "Number of iterations 3809\n",
      "Number of iterations 3844\n",
      "Number of iterations 3921\n",
      "Number of iterations 3399\n",
      "Number of iterations 20000\n",
      "Number of iterations 3390\n",
      "Execution time 0:23:02.703363\n"
     ]
    }
   ],
   "source": [
    "start = datetime.now()\n",
    "\n",
    "for n0 in [120]:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2]\n",
    "    summary_res_k120 = (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": [],
   "source": [
    "path = './results/experiment_1_v2/summary_res_2Layers_k120.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_k120, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "summary_res_2Layers.insert(16, summary_res_k120)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "135\n",
      "Number of iterations 4967\n",
      "Number of iterations 20000\n",
      "Number of iterations 7772\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 7887\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 4871\n",
      "Number of iterations 6870\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 5847\n",
      "Number of iterations 6242\n",
      "Number of iterations 6978\n",
      "Number of iterations 4958\n",
      "Number of iterations 5009\n",
      "Number of iterations 6299\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 5940\n",
      "Number of iterations 4629\n",
      "Number of iterations 20000\n",
      "Number of iterations 5234\n",
      "Number of iterations 20000\n",
      "Number of iterations 4686\n",
      "Number of iterations 20000\n",
      "Execution time 1:06:04.762280\n"
     ]
    }
   ],
   "source": [
    "start = datetime.now()\n",
    "\n",
    "for n0 in [135]:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2]\n",
    "    summary_res_k135 = (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)\n",
    "\n",
    "path = './results/experiment_1_v2/summary_res_2Layers_k135.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_k135, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "\n",
    "summary_res_2Layers.insert(17, summary_res_k120) # error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "summary_res_2Layers[17] =  summary_res_k135"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "prob_recovery_y_2L = []\n",
    "\n",
    "for res in summary_res_2Layers:\n",
    "    prob_recovery_y_2L.append(res['prob_recovery_y'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Three Layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_runs = 30\n",
    "n1, n2, n3 =  150, 700, 600\n",
    "m = 300\n",
    "eta = np.zeros(m)\n",
    "num_steps = 20000\n",
    "learning_rate = 0.7\n",
    "N0s = [5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 70, 80, 90, 100, 150]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------\n",
      "5\n",
      "Number of iterations 358\n",
      "Number of iterations 352\n",
      "Number of iterations 698\n",
      "Number of iterations 392\n",
      "Number of iterations 437\n",
      "Number of iterations 401\n",
      "Number of iterations 367\n",
      "Number of iterations 487\n",
      "Number of iterations 323\n",
      "Number of iterations 281\n",
      "Number of iterations 424\n",
      "Number of iterations 478\n",
      "Number of iterations 525\n",
      "Number of iterations 474\n",
      "Number of iterations 330\n",
      "Number of iterations 385\n",
      "Number of iterations 336\n",
      "Number of iterations 444\n",
      "Number of iterations 399\n",
      "Number of iterations 467\n",
      "Number of iterations 482\n",
      "Number of iterations 692\n",
      "Number of iterations 382\n",
      "Number of iterations 385\n",
      "Number of iterations 414\n",
      "Number of iterations 449\n",
      "Number of iterations 360\n",
      "Number of iterations 430\n",
      "Number of iterations 375\n",
      "Number of iterations 533\n",
      "------------\n",
      "10\n",
      "Number of iterations 547\n",
      "Number of iterations 689\n",
      "Number of iterations 803\n",
      "Number of iterations 461\n",
      "Number of iterations 577\n",
      "Number of iterations 532\n",
      "Number of iterations 801\n",
      "Number of iterations 631\n",
      "Number of iterations 757\n",
      "Number of iterations 690\n",
      "Number of iterations 525\n",
      "Number of iterations 700\n",
      "Number of iterations 436\n",
      "Number of iterations 636\n",
      "Number of iterations 615\n",
      "Number of iterations 533\n",
      "Number of iterations 536\n",
      "Number of iterations 679\n",
      "Number of iterations 607\n",
      "Number of iterations 669\n",
      "Number of iterations 704\n",
      "Number of iterations 458\n",
      "Number of iterations 620\n",
      "Number of iterations 862\n",
      "Number of iterations 620\n",
      "Number of iterations 636\n",
      "Number of iterations 465\n",
      "Number of iterations 711\n",
      "Number of iterations 590\n",
      "Number of iterations 510\n",
      "------------\n",
      "15\n",
      "Number of iterations 944\n",
      "Number of iterations 1000\n",
      "Number of iterations 940\n",
      "Number of iterations 1169\n",
      "Number of iterations 787\n",
      "Number of iterations 669\n",
      "Number of iterations 1022\n",
      "Number of iterations 751\n",
      "Number of iterations 819\n",
      "Number of iterations 1096\n",
      "Number of iterations 1010\n",
      "Number of iterations 1109\n",
      "Number of iterations 900\n",
      "Number of iterations 830\n",
      "Number of iterations 786\n",
      "Number of iterations 847\n",
      "Number of iterations 1015\n",
      "Number of iterations 1113\n",
      "Number of iterations 758\n",
      "Number of iterations 967\n",
      "Number of iterations 975\n",
      "Number of iterations 1011\n",
      "Number of iterations 731\n",
      "Number of iterations 1348\n",
      "Number of iterations 1053\n",
      "Number of iterations 785\n",
      "Number of iterations 692\n",
      "Number of iterations 928\n",
      "Number of iterations 788\n",
      "Number of iterations 774\n",
      "------------\n",
      "20\n",
      "Number of iterations 1308\n",
      "Number of iterations 1140\n",
      "Number of iterations 1217\n",
      "Number of iterations 1111\n",
      "Number of iterations 823\n",
      "Number of iterations 1092\n",
      "Number of iterations 1903\n",
      "Number of iterations 887\n",
      "Number of iterations 1254\n",
      "Number of iterations 904\n",
      "Number of iterations 1557\n",
      "Number of iterations 1213\n",
      "Number of iterations 1212\n",
      "Number of iterations 1510\n",
      "Number of iterations 1204\n",
      "Number of iterations 1139\n",
      "Number of iterations 1186\n",
      "Number of iterations 1670\n",
      "Number of iterations 1592\n",
      "Number of iterations 1292\n",
      "Number of iterations 1024\n",
      "Number of iterations 998\n",
      "Number of iterations 1207\n",
      "Number of iterations 1210\n",
      "Number of iterations 1176\n",
      "Number of iterations 954\n",
      "Number of iterations 1039\n",
      "Number of iterations 1336\n",
      "Number of iterations 1223\n",
      "Number of iterations 1070\n",
      "------------\n",
      "25\n",
      "Number of iterations 1189\n",
      "Number of iterations 1217\n",
      "Number of iterations 20000\n",
      "Number of iterations 1580\n",
      "Number of iterations 1407\n",
      "Number of iterations 1664\n",
      "Number of iterations 1077\n",
      "Number of iterations 1621\n",
      "Number of iterations 1733\n",
      "Number of iterations 2000\n",
      "Number of iterations 1156\n",
      "Number of iterations 1900\n",
      "Number of iterations 1603\n",
      "Number of iterations 1372\n",
      "Number of iterations 1823\n",
      "Number of iterations 1807\n",
      "Number of iterations 1578\n",
      "Number of iterations 1346\n",
      "Number of iterations 1528\n",
      "Number of iterations 1421\n",
      "Number of iterations 2587\n",
      "Number of iterations 1816\n",
      "Number of iterations 1301\n",
      "Number of iterations 1708\n",
      "Number of iterations 1854\n",
      "Number of iterations 1389\n",
      "Number of iterations 1423\n",
      "Number of iterations 1639\n",
      "Number of iterations 1574\n",
      "Number of iterations 2099\n",
      "------------\n",
      "30\n",
      "Number of iterations 3475\n",
      "Number of iterations 4011\n",
      "Number of iterations 2501\n",
      "Number of iterations 1898\n",
      "Number of iterations 1761\n",
      "Number of iterations 3054\n",
      "Number of iterations 2523\n",
      "Number of iterations 4435\n",
      "Number of iterations 2000\n",
      "Number of iterations 3822\n",
      "Number of iterations 2063\n",
      "Number of iterations 2161\n",
      "Number of iterations 2246\n",
      "Number of iterations 1885\n",
      "Number of iterations 1812\n",
      "Number of iterations 2076\n",
      "Number of iterations 2780\n",
      "Number of iterations 2087\n",
      "Number of iterations 2713\n",
      "Number of iterations 2677\n",
      "Number of iterations 2100\n",
      "Number of iterations 3107\n",
      "Number of iterations 2510\n",
      "Number of iterations 4080\n",
      "Number of iterations 3108\n",
      "Number of iterations 2357\n",
      "Number of iterations 1692\n",
      "Number of iterations 1989\n",
      "Number of iterations 2749\n",
      "Number of iterations 3348\n",
      "------------\n",
      "35\n",
      "Number of iterations 2944\n",
      "Number of iterations 4076\n",
      "Number of iterations 20000\n",
      "Number of iterations 2204\n",
      "Number of iterations 4817\n",
      "Number of iterations 2487\n",
      "Number of iterations 4172\n",
      "Number of iterations 2751\n",
      "Number of iterations 4485\n",
      "Number of iterations 4093\n",
      "Number of iterations 2819\n",
      "Number of iterations 2925\n",
      "Number of iterations 2907\n",
      "Number of iterations 2785\n",
      "Number of iterations 4611\n",
      "Number of iterations 2266\n",
      "Number of iterations 3222\n",
      "Number of iterations 4135\n",
      "Number of iterations 4109\n",
      "Number of iterations 3616\n",
      "Number of iterations 1470\n",
      "Number of iterations 1927\n",
      "Number of iterations 2545\n",
      "Number of iterations 2633\n",
      "Number of iterations 2713\n",
      "Number of iterations 20000\n",
      "Number of iterations 2922\n",
      "Number of iterations 2871\n",
      "Number of iterations 2731\n",
      "Number of iterations 3405\n",
      "------------\n",
      "40\n",
      "Number of iterations 20000\n",
      "Number of iterations 3561\n",
      "Number of iterations 6030\n",
      "Number of iterations 5050\n",
      "Number of iterations 3941\n",
      "Number of iterations 3747\n",
      "Number of iterations 3498\n",
      "Number of iterations 5171\n",
      "Number of iterations 4159\n",
      "Number of iterations 3489\n",
      "Number of iterations 2415\n",
      "Number of iterations 7396\n",
      "Number of iterations 4615\n",
      "Number of iterations 9280\n",
      "Number of iterations 7718\n",
      "Number of iterations 4200\n",
      "Number of iterations 3823\n",
      "Number of iterations 6232\n",
      "Number of iterations 6045\n",
      "Number of iterations 4760\n",
      "Number of iterations 4182\n",
      "Number of iterations 3771\n",
      "Number of iterations 6211\n",
      "Number of iterations 3404\n",
      "Number of iterations 20000\n",
      "Number of iterations 2876\n",
      "Number of iterations 3881\n",
      "Number of iterations 3208\n",
      "Number of iterations 3599\n",
      "Number of iterations 3680\n",
      "------------\n",
      "45\n",
      "Number of iterations 6399\n",
      "Number of iterations 13685\n",
      "Number of iterations 20000\n",
      "Number of iterations 7690\n",
      "Number of iterations 20000\n",
      "Number of iterations 6243\n",
      "Number of iterations 13349\n",
      "Number of iterations 7620\n",
      "Number of iterations 5965\n",
      "Number of iterations 5055\n",
      "Number of iterations 10157\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 5842\n",
      "Number of iterations 20000\n",
      "Number of iterations 6265\n",
      "Number of iterations 7915\n",
      "Number of iterations 4373\n",
      "Number of iterations 6268\n",
      "Number of iterations 20000\n",
      "Number of iterations 12829\n",
      "Number of iterations 6165\n",
      "Number of iterations 7170\n",
      "Number of iterations 16442\n",
      "Number of iterations 20000\n",
      "Number of iterations 5403\n",
      "Number of iterations 8882\n",
      "Number of iterations 6179\n",
      "Number of iterations 6384\n",
      "Number of iterations 4596\n",
      "------------\n",
      "50\n",
      "Number of iterations 20000\n",
      "Number of iterations 8777\n",
      "Number of iterations 6711\n",
      "Number of iterations 7329\n",
      "Number of iterations 8449\n",
      "Number of iterations 10431\n",
      "Number of iterations 8170\n",
      "Number of iterations 16597\n",
      "Number of iterations 8154\n",
      "Number of iterations 20000\n",
      "Number of iterations 7338\n",
      "Number of iterations 20000\n",
      "Number of iterations 10998\n",
      "Number of iterations 10638\n",
      "Number of iterations 17062\n",
      "Number of iterations 8835\n",
      "Number of iterations 9773\n",
      "Number of iterations 20000\n",
      "Number of iterations 9008\n",
      "Number of iterations 17339\n",
      "Number of iterations 20000\n",
      "Number of iterations 6262\n",
      "Number of iterations 14031\n",
      "Number of iterations 17392\n",
      "Number of iterations 7674\n",
      "Number of iterations 20000\n",
      "Number of iterations 6623\n",
      "Number of iterations 17360\n",
      "Number of iterations 10676\n",
      "Number of iterations 20000\n",
      "------------\n",
      "55\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 18583\n",
      "Number of iterations 10833\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 10760\n",
      "Number of iterations 20000\n",
      "Number of iterations 18922\n",
      "Number of iterations 10834\n",
      "Number of iterations 9640\n",
      "Number of iterations 8619\n",
      "Number of iterations 11469\n",
      "Number of iterations 14909\n",
      "Number of iterations 16733\n",
      "Number of iterations 20000\n",
      "Number of iterations 14427\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 8750\n",
      "Number of iterations 14425\n",
      "Number of iterations 20000\n",
      "Number of iterations 12280\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 17231\n",
      "------------\n",
      "60\n",
      "Number of iterations 14773\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 12195\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 19719\n",
      "Number of iterations 20000\n",
      "Number of iterations 16285\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "------------\n",
      "70\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "------------\n",
      "80\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "------------\n",
      "90\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "------------\n",
      "100\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "------------\n",
      "150\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Number of iterations 20000\n",
      "Execution time 22:17:19.583014\n"
     ]
    }
   ],
   "source": [
    "summary_res = []\n",
    "start = datetime.now()\n",
    "\n",
    "for n0 in N0s:\n",
    "    print('------------')\n",
    "    print(n0)\n",
    "    layers = [n0, n1, n2, n3]\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": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "summary_res_3Layers = summary_res\n",
    "path = './results/experiment_1_v2/summary_res_3Layers.pkl'\n",
    "with open(path, 'wb') as handle:\n",
    "    pickle.dump(summary_res_3Layers, handle, protocol=pickle.HIGHEST_PROTOCOL)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "prob_recovery_y_3L = []\n",
    "\n",
    "for res in summary_res_3Layers:\n",
    "    prob_recovery_y_3L.append(res['prob_recovery_y'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "19\n",
      "19\n"
     ]
    }
   ],
   "source": [
    "N0s2 = [5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 70, 80, 90, 100, 120, 130, 150]\n",
    "print(len(N0s2))\n",
    "print(len(prob_recovery_y_2L))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "path = './results/experiment_1_v2/'\n",
    "\n",
    "plt.plot(N0s2, prob_recovery_y_2L, 'b-*', label = '2 Layers')\n",
    "plt.plot(N0s, prob_recovery_y_3L, 'm-*', label = '3 Layers')\n",
    "plt.legend(loc = 'best')\n",
    "plt.xlabel('k', fontsize=18)\n",
    "plt.ylabel('Prob. of Succ. Rec', fontsize = 16)\n",
    "plt.savefig(path+'/prob_success.pdf',bbox_inches = 'tight',format='pdf')"
   ]
  },
  {
   "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
}
