{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Set up"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch import optim\n",
    "\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data import TensorDataset\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "def get_survival_rates(depth, mode='none', survival_prop=0.5):\n",
    "    if mode == 'uniform':\n",
    "        survival_rates = [survival_prop] * depth\n",
    "    elif mode == 'linear':\n",
    "        survival_rates =  [1 - 2 * float(i + 1) * (1-survival_prop) / float(depth+1)\n",
    "                       for i in range(depth)]\n",
    "    else:\n",
    "        survival_rates = None\n",
    "    return survival_rates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Set plotting parameters\n",
    "SMALL_SIZE = 14\n",
    "MEDIUM_SIZE = 16\n",
    "BIGGER_SIZE = 18\n",
    "\n",
    "plt.rc('font', size=SMALL_SIZE)          # controls default text sizes\n",
    "plt.rc('axes', titlesize=SMALL_SIZE)     # fontsize of the axes title\n",
    "plt.rc('axes', labelsize=MEDIUM_SIZE)    # fontsize of the x and y labels\n",
    "plt.rc('xtick', labelsize=SMALL_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('ytick', labelsize=SMALL_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('legend', fontsize=SMALL_SIZE)    # legend fontsize\n",
    "plt.rc('figure', titlesize=BIGGER_SIZE)  # fontsize of the figure title"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Section 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Illustrating Lemma 1\n",
    "\n",
    "Here we plot the distribution of the effective depth of a ResNet with depth 100 with average survival rate of the layers = 0.5. As expected from Lemma 1, the distribution with uniform mode has a larger spread than the one of the linear mode. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Plots with Average subnetwork depth:  50.0\n"
     ]
    },
    {
     "data": {
      "image/png": "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nH/++eyyyy707t2be+65p6T10lQKViIiBfbss8/yxhtvMHPmTKZNm8bDDz/MxIkTE9NOnDiRa6+9lj333JMlS5bw8ssvA3D55Zczbdo0fv3rX/Pqq68yePBgjjrqKJYsWbLN8ldccQU//elPeeuttzjwwDB293333UenTp148cUXufLKK7nooos4/vjjGTBgAHPmzOE73/kO3/ve97bLK80UrERECqxz585MmjSJQYMGceSRR3LSSSfxpz/9KTFtly5d6NSpE23atKFHjx50796d1atX88tf/pKbbrqJY489lkGDBjFp0iQqKyv5xS9+sc3y48eP58gjj6Rfv3507x4e3Pu5z32O8ePHs/fee3PJJZfQrVs32rVrx4UXXkj//v259tprcXeef/75otdFoeialUhz1oJvGm7O9t13X9q0abPl/R577MGLL+Z+J817773Hhg0bOOSQQ7ZMa9OmDSNGjODNN9/cJu3w4cO3W37//fff8r+ZsfvuuzN48OAt09q1a0fXrl1ZtmxZzmUqNwUrkXJpKNDQtyTFkNx17tyZlStXbjf9k08+2abTRLyTg5mxefPmgpQhPjxVx44dt0uTtP5ilqkUdBpQRCRHAwcO5JVXXsHdt5n+yiuvMHDgwIKt57Of/SwVFRXbnKbbtGkTs2fPZt999y3YepoTtaxERHI0ZswYbr/9dsaNG8c555xD+/btmT59Or/73e/4wx/+ULD1dOzYkTFjxnDFFVfQrVs3+vbtyy233MLSpUsZO3ZswdbTnChYiUgqFHtEiUI8IqRfv37MmjWLa665hiOPPJLa2lr22WcfHnjgAY4++ugClTS46aabADjrrLP45JNPGDp0KE888QQ9e/Ys6HqaC4s3Z1ubgQMH+ttvv13uYrQYLfkZTAXXwDWr6pq+VO28oGnrSGkHi/nz5zNo0KCSrlPPs8pffZ+Tmc119+17dxSJrlmJiEjqKViJiEjqKViJiEjqKViJiEjqKViJiEjqKViJiEjqKViJiEjqKViJiEjqKViJiEjqabglEUmHBkehb5qK9eugYsetEwo8ukefPn244IILuOyyywqarwQKViLFUuSDr5Te6NGjWbFiBY899th2815++eXEx3VIYShYiYgUQN1Testt/fr1VFRUlLsYBadrViIt2dM3NvySgujTpw8TJkzY8t7MmDJlCieddBId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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "depth = 100\n",
    "\n",
    "survival_prop = 0.5 # Average depth of subnetworks is survival_prop * depth\n",
    "\n",
    "n_samples = 100000\n",
    "\n",
    "print(\"Plots with Average subnetwork depth: \", survival_prop*depth)\n",
    "\n",
    "uniform_rates = get_survival_rates(depth, mode=\"uniform\", survival_prop=survival_prop)\n",
    "linear_rates = get_survival_rates(depth, mode=\"linear\", survival_prop=survival_prop)\n",
    "\n",
    "uniform_hist = np.sum(np.random.binomial(1, uniform_rates, size=(n_samples, depth)), axis=1)\n",
    "linear_hist = np.sum(np.random.binomial(1, linear_rates, size=(n_samples, depth)), axis=1)\n",
    "\n",
    "plt.figure()\n",
    "x_range = (int(survival_prop*depth-20), int(survival_prop*depth+20))\n",
    "\n",
    "plt.hist(uniform_hist, label=\"Uniform\", bins=range(*x_range), alpha=0.5, density=True)\n",
    "\n",
    "plt.hist(linear_hist, label=\"Linear\", bins=range(*x_range), alpha=0.5, density=True)\n",
    "plt.xlim(x_range)\n",
    "plt.title(\"Distribution of the Effective depth of the subnetworks\")\n",
    "plt.xlabel(r'$L_\\delta$')\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Section 3"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Illustrating Proposition 1\n",
    "\n",
    "In this section we show that the average growth rate of the gradients magnitude follow the theoretical formula of Proposition 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Import simple ResNet model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from model import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate synthetic data\n",
    "\n",
    "We consider here a simple regression task, where the true model is given by\n",
    "\\\\( y = \\sin( X \\cdot \\beta ) \\\\)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/disk1/fadhel/py36/lib/python3.6/site-packages/ipykernel_launcher.py:12: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  if sys.path[0] == '':\n"
     ]
    }
   ],
   "source": [
    "# Create dataset\n",
    "n = 10000\n",
    "in_features = 512 # input dimension\n",
    "\n",
    "n_train = 8000\n",
    "\n",
    "bs = 1 # Batch size\n",
    "\n",
    "beta = np.random.normal(size=in_features)\n",
    "\n",
    "X = torch.tensor(np.random.normal(size=(n, in_features)), dtype=torch.float32)\n",
    "y = torch.tensor(np.sin(X @ beta.transpose()), dtype=torch.float32)\n",
    "\n",
    "# Delete\n",
    "#y = (y>0).long()\n",
    "\n",
    "x_train = X[:n_train, :]\n",
    "y_train = y[:n_train]\n",
    "\n",
    "train_ds = TensorDataset(x_train, y_train)\n",
    "train_dl = DataLoader(train_ds, batch_size=bs)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Run experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/500 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experience  standard\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/disk1/fadhel/py36/lib/python3.6/site-packages/torch/nn/modules/module.py:795: UserWarning: Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
      "  warnings.warn(\"Using a non-full backward hook when the forward contains multiple autograd Nodes \"\n",
      "100%|██████████| 500/500 [05:08<00:00,  1.62it/s]\n",
      "  0%|          | 0/500 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experience  uniform_SD_0.7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/disk1/fadhel/py36/lib/python3.6/site-packages/numpy/core/fromnumeric.py:3373: RuntimeWarning: Mean of empty slice.\n",
      "  out=out, **kwargs)\n",
      "/mnt/disk1/fadhel/py36/lib/python3.6/site-packages/numpy/core/_methods.py:170: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n",
      "100%|██████████| 500/500 [05:04<00:00,  1.64it/s]\n",
      "  0%|          | 0/500 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experience  linear_SD_0.7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [05:03<00:00,  1.65it/s]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "# Define Simple ResNet Model\n",
    "depth = 50\n",
    "survival_rate = 0.7\n",
    "\n",
    "hook_depths = np.linspace(1, depth, 5, endpoint=False, dtype=int)\n",
    "# Optimize parameters\n",
    "lr = 0.01\n",
    "\n",
    "device = \"cuda:0\"\n",
    "\n",
    "# Init experiment params\n",
    "n_runs = 500\n",
    "experiment_name = \"section_3/init_expe/depth_{}_sd_{}_v2\".format(depth, survival_rate)\n",
    "experiments = [\n",
    "    {\n",
    "        'name': 'standard',\n",
    "        'res_scale': 1.,\n",
    "        'mode': None,\n",
    "    },\n",
    "    {\n",
    "        'name': 'uniform_SD_{}'.format(survival_rate),\n",
    "        'res_scale': 1.,\n",
    "        'mode': 'uniform',\n",
    "    },\n",
    "    {\n",
    "        'name': 'linear_SD_{}'.format(survival_rate),\n",
    "        'res_scale': 1.,\n",
    "        'mode': 'linear',\n",
    "    },    \n",
    "]\n",
    "\n",
    "for expe in experiments:\n",
    "    \n",
    "    expe['fc_in'] = []\n",
    "    expe['fc_mid0'] = []\n",
    "    expe['fc_mid1'] = []\n",
    "    expe['fc_mid2'] = []\n",
    "    expe['fc_mid3'] = []\n",
    "    expe['fc_out'] = []\n",
    "    \n",
    "    print(\"Experience \", expe['name'])\n",
    "    \n",
    "    for _ in tqdm(range(n_runs)):\n",
    "        model = SimpleResNet(\n",
    "            in_features=in_features,\n",
    "            out_features=1,\n",
    "            h_features=512,\n",
    "            depth=depth,\n",
    "            block=BasicBlock,\n",
    "            res_scale=expe['res_scale'],\n",
    "            survival_rates=get_survival_rates(depth, expe['mode'], survival_rate),\n",
    "        )\n",
    "        \n",
    "        model = model.to(device)\n",
    "        \n",
    "        grad_fc_in_hook = GradNormContainer()\n",
    "        grad_mid0_hook = GradNormContainer()\n",
    "        grad_mid1_hook = GradNormContainer()\n",
    "        grad_mid2_hook = GradNormContainer()\n",
    "        grad_mid3_hook = GradNormContainer()\n",
    "        grad_fc_out_hook = GradNormContainer()\n",
    "\n",
    "        #model.fc_in.register_backward_hook(grad_fc_in_hook)\n",
    "        model.resnet_layers[0].lin.register_backward_hook(grad_fc_in_hook)\n",
    "        \n",
    "        model.resnet_layers[hook_depths[1]].lin.register_backward_hook(grad_mid0_hook)\n",
    "        model.resnet_layers[hook_depths[2]].lin.register_backward_hook(grad_mid1_hook)\n",
    "        model.resnet_layers[hook_depths[3]].lin.register_backward_hook(grad_mid2_hook)\n",
    "        model.resnet_layers[hook_depths[4]].lin.register_backward_hook(grad_mid3_hook)\n",
    "        \n",
    "        model.resnet_layers[-1].lin.register_backward_hook(grad_fc_out_hook)\n",
    "\n",
    "\n",
    "        optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "        \n",
    "        # Delete\n",
    "        #loss_fn = nn.CrossEntropyLoss()\n",
    "        loss_fn = nn.MSELoss()\n",
    "        \n",
    "        \n",
    "        xb, yb  = list(train_dl)[0]\n",
    "        xb = xb.to(device)\n",
    "        yb = yb.to(device)\n",
    "\n",
    "        pred = model(xb).unsqueeze(0)\n",
    "        loss = loss_fn(pred, yb)\n",
    "        #output = torch.mean(loss)\n",
    "        output = loss\n",
    "\n",
    "        output.backward()\n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        expe['fc_in'] += [np.mean(grad_fc_in_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n",
    "        expe['fc_mid0'] += [np.mean(grad_mid0_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n",
    "        expe['fc_mid1'] += [np.mean(grad_mid1_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n",
    "        expe['fc_mid2'] += [np.mean(grad_mid2_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n",
    "        expe['fc_mid3'] += [np.mean(grad_mid3_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n",
    "        expe['fc_out'] += [np.mean(grad_fc_out_hook.grad_norms) / np.mean(grad_fc_out_hook.grad_norms)]\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Save results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd_in = pd.DataFrame()\n",
    "pd_mid0 = pd.DataFrame()\n",
    "pd_mid1 = pd.DataFrame()\n",
    "pd_mid2 = pd.DataFrame()\n",
    "pd_mid3 = pd.DataFrame()\n",
    "pd_out = pd.DataFrame()\n",
    "\n",
    "for expe in experiments:\n",
    "    pd_in[expe['name']] = expe['fc_in']\n",
    "    pd_mid0[expe['name']] = expe['fc_mid0']\n",
    "    pd_mid1[expe['name']] = expe['fc_mid1']\n",
    "    pd_mid2[expe['name']] = expe['fc_mid2']\n",
    "    pd_mid3[expe['name']] = expe['fc_mid3']\n",
    "    pd_out[expe['name']] = expe['fc_out']\n",
    "    \n",
    "\n",
    "if not os.path.exists(experiment_name):\n",
    "    os.makedirs(experiment_name)\n",
    "    \n",
    "pd_in.to_csv(os.path.join(experiment_name, \"in_grad_norm.csv\"))\n",
    "\n",
    "pd_mid0.to_csv(os.path.join(experiment_name, \"mid_grad0_norm.csv\"))\n",
    "pd_mid1.to_csv(os.path.join(experiment_name, \"mid_grad1_norm.csv\"))\n",
    "pd_mid2.to_csv(os.path.join(experiment_name, \"mid_grad2_norm.csv\"))\n",
    "pd_mid3.to_csv(os.path.join(experiment_name, \"mid_grad3_norm.csv\"))\n",
    "\n",
    "pd_out.to_csv(os.path.join(experiment_name, \"out_grad_norm.csv\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Visualize results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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BEYCpKSkkJ2d7VejDTlKi8Q43vx8HafmlXv16qiRk5Pj92tV00TCWJOSkjh8+HBI2iooKAh6W7m5zpF+qMZ07Nixctur6nhPnDhBnTp1fKo70vj73ubm5vr3f0BVo2oBTgALvNY9AaytbNsePXqov7KysvTZTzdo6/s/0t0/HfO7npoiKysr3F0ImUgY65o1a0LW1qFDhwJW17x58/Sss87ShIQEbdSokfbq1Uuff/55BUosDz/8sKqqTpkyRXv27KmJiYmanJysQ4YM0R07dhTXl5WVpYB++umn2rt3b61fv7726NFDlyxZUqLd119/XVu1aqX169fXzMxMfeGFF9TZ3Tk2bdqkl156qaakpGiDBg20e/fu+uGHH5ao45RTTtGHH35Yb7jhBk1KStIhQ4ZUqe5I5u97W9HnD1is5exTo/EIZhewxmvdWuDOYDc8OD2Npz/ZwMcrdzGi36nBbs7EsEc/XM2a7w8Fpe6CggLi4+NLre/YvBEPX9KpyvXk5+dz2WWXcdNNNzF16lTy8vJYunQpnTp14plnnuGBBx5g8+bNAMXpshMnTvDoo4/Svn179u/fz3333cfVV1/N/PnzS9Q9duxY/vSnP5GWlsadd97JNddcw5o1axARvvrqK0aMGMFjjz3GlVdeSVZWFg888ECJ7XNycrjooov4wx/+QEFBATNnzuTXv/41K1asoH379sXlnn76aR588EEWL16MqlapbvOzaAwwXwBneK1rBwQ9b9W2WSJnpDRk1srdFmBMzDt06BAHDx7kkksu4bTTTgMo3nkvW7YMESE1NbXENjfeeGPx323atOHFF1+kQ4cO7NixgxYtWhQ/99hjjzFw4EAAHnroIc455xx27txJixYtePbZZzn//PMZN24cAO3atWPRokX885//LN6+a9eudO3aFXBSW+PGjePDDz9k+vTpPPjgg8XlBgwYwL333lv8eNiwYZXWbX4WjQHmb8ACERkHvAV0B34HhORrxuD0NJ6Zu4G9h3Jp1qheKJo0MciXIwlfBeraXE2aNGHEiBEMGjSI888/n/PPP58hQ4bQqlWrcrdZunQpjz76KMuXL+fAgQNFKW6+/fbbEgGmS5cuxX83b94cgL1799KiRQvWrl3LJZdcUqLevn37lggCR44c4dFHH+Wjjz5i165d5OXlkZubW6JegJ49e5Z4XJW6zc+i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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "res = pd.DataFrame()\n",
    "for expe in experiments:\n",
    "    res[expe['name']] = [\n",
    "        np.nanmean(expe['fc_in']),\n",
    "        np.nanmean(expe['fc_mid0']),\n",
    "        np.nanmean(expe['fc_mid1']),\n",
    "        np.nanmean(expe['fc_mid2']),\n",
    "        np.nanmean(expe['fc_mid3']),\n",
    "        np.nanmean(expe['fc_out'])\n",
    "    ]\n",
    "\n",
    "res[r'$\\ell$'] = [0]+list(hook_depths[1:]+1)+[depth+1]\n",
    "res.set_index(r'$\\ell$', inplace=True)\n",
    "\n",
    "#res.plot(logy=True)\n",
    "res.plot()\n",
    "plt.ylabel(r'$ \\frac{|| \\nabla_{y_l} \\mathcal{L} ||^2}{|| \\nabla_{y_L} \\mathcal{L} ||^2}$')\n",
    "plt.title(\"Growth rate of gradient magnitude\")\n",
    "plt.grid()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Empirical groth rate\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>standard</th>\n",
       "      <th>uniform_SD_0.7</th>\n",
       "      <th>linear_SD_0.7</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>$\\ell$</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.003030</td>\n",
       "      <td>1.707265</td>\n",
       "      <td>1.696825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2.002817</td>\n",
       "      <td>1.706366</td>\n",
       "      <td>1.639207</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>2.002675</td>\n",
       "      <td>1.712600</td>\n",
       "      <td>1.588886</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>2.001763</td>\n",
       "      <td>1.718111</td>\n",
       "      <td>1.541861</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>2.001139</td>\n",
       "      <td>1.731213</td>\n",
       "      <td>1.507381</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        standard  uniform_SD_0.7  linear_SD_0.7\n",
       "$\\ell$                                         \n",
       "0       2.003030        1.707265       1.696825\n",
       "11      2.002817        1.706366       1.639207\n",
       "21      2.002675        1.712600       1.588886\n",
       "31      2.001763        1.718111       1.541861\n",
       "41      2.001139        1.731213       1.507381"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"Empirical groth rate\")\n",
    "emp_growth_rate = np.exp(np.log(res).div(depth-res.index, axis=0))\n",
    "emp_growth_rate[:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Theoretical growth rate\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>standard</th>\n",
       "      <th>uniform_SD_0.7</th>\n",
       "      <th>linear_SD_0.7</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>$\\ell$</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1.7</td>\n",
       "      <td>1.691467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1.7</td>\n",
       "      <td>1.629911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1.7</td>\n",
       "      <td>1.573390</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1.7</td>\n",
       "      <td>1.516277</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>2.0</td>\n",
       "      <td>1.7</td>\n",
       "      <td>1.458507</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        standard  uniform_SD_0.7  linear_SD_0.7\n",
       "$\\ell$                                         \n",
       "0            2.0             1.7       1.691467\n",
       "11           2.0             1.7       1.629911\n",
       "21           2.0             1.7       1.573390\n",
       "31           2.0             1.7       1.516277\n",
       "41           2.0             1.7       1.458507"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"Theoretical growth rate\")\n",
    "th_growth_rate = emp_growth_rate[:-1].copy()\n",
    "th_growth_rate['standard'] = 2.0\n",
    "th_growth_rate['uniform_SD_{}'.format(survival_rate)] = 1+survival_rate\n",
    "\n",
    "p = np.array(get_survival_rates(depth, 'linear', survival_rate))\n",
    "th_growth_rate['linear_SD_{}'.format(survival_rate)] = [np.exp(np.sum(np.log(p[l:]+1))/(depth-l)) for l in th_growth_rate.index.values] \n",
    "\n",
    "th_growth_rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Additional plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Out grad norm')"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure()\n",
    "pd_in.boxplot(sym=\"\")\n",
    "plt.title(\"In grad norm\")\n",
    "\n",
    "plt.figure()\n",
    "pd_mid0.boxplot(sym=\"\")\n",
    "plt.title(\"Mid0 grad norm\")\n",
    "\n",
    "plt.figure()\n",
    "pd_mid1.boxplot(sym=\"\")\n",
    "plt.title(\"Mid1 grad norm\")\n",
    "\n",
    "plt.figure()\n",
    "pd_mid2.boxplot(sym=\"\")\n",
    "plt.title(\"Mid2 grad norm\")\n",
    "\n",
    "plt.figure()\n",
    "pd_mid3.boxplot(sym=\"\")\n",
    "plt.title(\"Mid3 grad norm\")\n",
    "\n",
    "plt.figure()\n",
    "pd_out.boxplot(sym=\"\")\n",
    "plt.title(\"Out grad norm\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f1595d87b00>]"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.array(experiments[0]['fc_in'])/np.mean(experiments[0]['fc_in']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<model.GradNormContainer at 0x7f15964ee748>"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grad_fc_in_hook."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py36",
   "language": "python",
   "name": "py36"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
