{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "18AF5Ab4p6VL"
   },
   "source": [
    "# Computing the Jacobian norm in MLPs\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "B_XlLLpcWjkA"
   },
   "source": [
    "This notebook can be used to reproduce some of the numerical results reported in the paper **\"Exploring Stability in Deep Neural Networks:\n",
    "The Role of Dependent Weights, Pruning,\n",
    "and Training Dynamics\"**.\n",
    "\n",
    "The notebook is structured as follows:\n",
    "\n",
    "I. IID Weights\n",
    "\n",
    "II. Dependent Weights\n",
    "\n",
    "III. Dynamics during training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "id": "OksHydJDtbbI"
   },
   "outputs": [],
   "source": [
    "import jax.numpy as jnp\n",
    "from jax import grad, jit, vmap, jacrev, jacfwd\n",
    "from jax import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "id": "QcGSeOkqV2vL"
   },
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "MTVcKi-ZYB3R"
   },
   "source": [
    "## Initialization and hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "-fmWA06xYE7d"
   },
   "outputs": [],
   "source": [
    "def random_layer_params(m, n, scale, key):\n",
    "  w_key, b_key = random.split(key)\n",
    "  return scale * random.normal(w_key, (n, m)), 1e-6 * random.normal(b_key, (n,))\n",
    "\n",
    "def init_network_params(sizes, scale, key):\n",
    "  keys = random.split(key, len(sizes))\n",
    "  return [random_layer_params(m, n, scale, k) for m, n, k in zip(sizes[:-1], sizes[1:], keys)]\n",
    "\n",
    "\n",
    "#used for classification\n",
    "batch_size = 128\n",
    "n_targets = 10"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "BtoNk_yxWtIw"
   },
   "source": [
    "## Some utilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "id": "7APc6tD7TiuZ"
   },
   "outputs": [],
   "source": [
    "from jax.scipy.special import logsumexp\n",
    "\n",
    "def relu(x):\n",
    "  return jnp.maximum(0, x)\n",
    "\n",
    "def predict(params, image):\n",
    "  # per-example predictions\n",
    "  activations = image\n",
    "  for w, b in params[:-1]:\n",
    "    outputs = jnp.dot(w, activations) + b\n",
    "    activations = relu(outputs)\n",
    "  \n",
    "  final_w, final_b = params[-1]\n",
    "  logits = jnp.dot(final_w, activations) + final_b\n",
    "  return logits - logsumexp(logits)\n",
    "\n",
    "def input_output(params, input):\n",
    "  activations = input\n",
    "  for w, b in params[1:-2]:\n",
    "    outputs = jnp.dot(w, activations) + b\n",
    "    activations = relu(outputs)\n",
    "  final_w, final_b = params[-2]\n",
    "  logits = jnp.dot(final_w, activations) + final_b\n",
    "  return logits\n",
    "\n",
    "jacobian_fn = jacrev(input_output, argnums=1)\n",
    "\n",
    "\n",
    "def forward_prop_record(params,image):\n",
    "    activations = [image]\n",
    "    for w, b in params[:-1]:\n",
    "        outputs = jnp.dot(w, activations[-1]) + b\n",
    "        activations.append(relu(outputs))\n",
    "  \n",
    "    final_w, final_b = params[-1]\n",
    "    activations.append(jnp.dot(final_w, activations[-1]) + final_b)\n",
    "    return activations\n",
    "\n",
    "\n",
    "#batched version of predict\n",
    "batched_predict = vmap(predict, in_axes=(None, 0))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "NwDuFqc9X7ER"
   },
   "source": [
    "## Loss function and SGD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "id": "6lTI6I4lWdh5"
   },
   "outputs": [],
   "source": [
    "def one_hot(x, k, dtype=jnp.float32):\n",
    "  \"\"\"Create a one-hot encoding of x of size k.\"\"\"\n",
    "  return jnp.array(x[:, None] == jnp.arange(k), dtype)\n",
    "  \n",
    "def accuracy(params, images, targets):\n",
    "  target_class = jnp.argmax(targets, axis=1)\n",
    "  predicted_class = jnp.argmax(batched_predict(params, images), axis=1)\n",
    "  return jnp.mean(predicted_class == target_class)\n",
    "\n",
    "def loss(params, images, targets):\n",
    "  preds = batched_predict(params, images)\n",
    "  return -jnp.mean(preds * targets)\n",
    "\n",
    "@jit\n",
    "def update(params, x, y, lr):\n",
    "  grads = grad(loss)(params, x, y)\n",
    "  return [(w - lr * dw, b - lr * db)\n",
    "          for (w, b), (dw, db) in zip(params, grads)]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "umJJGZCC2oKl"
   },
   "source": [
    "## Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "cellView": "both",
    "id": "94PjXZ8y3dVF"
   },
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-11-92d55511ff4b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mnumpy\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mutils\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorchvision\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdatasets\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mMNIST\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mnumpy_collate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbatch\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    696\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mnn\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnn\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    697\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mintrinsic\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 698\u001b[0;31m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantizable\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    699\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantized\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    700\u001b[0m \u001b[0;31m# AO depends on nn, as well as quantized stuff -- so should be after those.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantizable/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mmodules\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0;34m*\u001b[0m  \u001b[0;31m# noqa: F403\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantizable/modules/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mactivation\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mMultiheadAttention\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mrnn\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mLSTM\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mrnn\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mLSTMCell\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m __all__ = [\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantizable/modules/activation.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mnn\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfunctional\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnnF\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantized\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnnq\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      5\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mTensor\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantized/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mmodules\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0;34m*\u001b[0m  \u001b[0;31m# noqa: F403\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantized/modules/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodules\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpooling\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mMaxPool2d\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mactivation\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mReLU6\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mHardswish\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mELU\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mLeakyReLU\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mSigmoid\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      5\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mbatchnorm\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mBatchNorm2d\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mBatchNorm3d\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;34m.\u001b[0m\u001b[0mnormalization\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mLayerNorm\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mGroupNorm\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mInstanceNorm1d\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantized/modules/activation.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0;32mimport\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantized\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfunctional\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;32mclass\u001b[0m \u001b[0mReLU6\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mReLU\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     r\"\"\"Applies the element-wise function:\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/nn/quantized/functional.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodules\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mutils\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0m_pair\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0m_triple\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantized\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodules\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mutils\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0m_pair_from_first\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 9\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mjit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mannotations\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mBroadcastingList2\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     10\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     11\u001b[0m \u001b[0;31m# Although some of the functions and docstrings are mirrored from the torch.nn,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/jit/__init__.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     33\u001b[0m     \u001b[0m_unwrap_optional\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     34\u001b[0m )\n\u001b[0;32m---> 35\u001b[0;31m from torch.jit._trace import (\n\u001b[0m\u001b[1;32m     36\u001b[0m     \u001b[0mtrace\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     37\u001b[0m     \u001b[0mtrace_module\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/opt/anaconda3/lib/python3.7/site-packages/torch/jit/_trace.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    539\u001b[0m \u001b[0;31m# checks in nn will trigger them.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    540\u001b[0m \u001b[0mTracerWarning\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mignore_lib_warnings\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 541\u001b[0;31m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_C\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_tracer_warn_use_python\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    542\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    543\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from torch.utils import data\n",
    "from torchvision.datasets import MNIST\n",
    "\n",
    "def numpy_collate(batch):\n",
    "  if isinstance(batch[0], np.ndarray):\n",
    "    return np.stack(batch)\n",
    "  elif isinstance(batch[0], (tuple,list)):\n",
    "    transposed = zip(*batch)\n",
    "    return [numpy_collate(samples) for samples in transposed]\n",
    "  else:\n",
    "    return np.array(batch)\n",
    "\n",
    "class NumpyLoader(data.DataLoader):\n",
    "  def __init__(self, dataset, batch_size=1,\n",
    "                shuffle=False, sampler=None,\n",
    "                batch_sampler=None, num_workers=0,\n",
    "                pin_memory=False, drop_last=False,\n",
    "                timeout=0, worker_init_fn=None):\n",
    "    super(self.__class__, self).__init__(dataset,\n",
    "        batch_size=batch_size,\n",
    "        shuffle=shuffle,\n",
    "        sampler=sampler,\n",
    "        batch_sampler=batch_sampler,\n",
    "        num_workers=num_workers,\n",
    "        collate_fn=numpy_collate,\n",
    "        pin_memory=pin_memory,\n",
    "        drop_last=drop_last,\n",
    "        timeout=timeout,\n",
    "        worker_init_fn=worker_init_fn)\n",
    "\n",
    "class FlattenAndCast(object):\n",
    "  def __call__(self, pic):\n",
    "    return np.ravel(np.array(pic, dtype=jnp.float32))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "l314jsfP4TN4",
    "outputId": "41acf13c-b923-4dd6-d91c-2b382a2871df"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz to /tmp/mnist/MNIST/raw/train-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 9912422/9912422 [00:00<00:00, 94054396.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting /tmp/mnist/MNIST/raw/train-images-idx3-ubyte.gz to /tmp/mnist/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz to /tmp/mnist/MNIST/raw/train-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 28881/28881 [00:00<00:00, 103094207.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting /tmp/mnist/MNIST/raw/train-labels-idx1-ubyte.gz to /tmp/mnist/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz to /tmp/mnist/MNIST/raw/t10k-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1648877/1648877 [00:00<00:00, 27406492.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting /tmp/mnist/MNIST/raw/t10k-images-idx3-ubyte.gz to /tmp/mnist/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz to /tmp/mnist/MNIST/raw/t10k-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4542/4542 [00:00<00:00, 19906508.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting /tmp/mnist/MNIST/raw/t10k-labels-idx1-ubyte.gz to /tmp/mnist/MNIST/raw\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Define our dataset, using torch datasets\n",
    "mnist_dataset = MNIST('/tmp/mnist/', download=True, transform=FlattenAndCast())\n",
    "training_generator = NumpyLoader(mnist_dataset, batch_size=batch_size, num_workers=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "FTNo4beUvb6t",
    "outputId": "60aeb8ad-b61c-41f1-bcd1-d9075024311d"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.10/dist-packages/torchvision/datasets/mnist.py:75: UserWarning: train_data has been renamed data\n",
      "  warnings.warn(\"train_data has been renamed data\")\n",
      "/usr/local/lib/python3.10/dist-packages/torchvision/datasets/mnist.py:65: UserWarning: train_labels has been renamed targets\n",
      "  warnings.warn(\"train_labels has been renamed targets\")\n",
      "/usr/local/lib/python3.10/dist-packages/torchvision/datasets/mnist.py:80: UserWarning: test_data has been renamed data\n",
      "  warnings.warn(\"test_data has been renamed data\")\n",
      "/usr/local/lib/python3.10/dist-packages/torchvision/datasets/mnist.py:70: UserWarning: test_labels has been renamed targets\n",
      "  warnings.warn(\"test_labels has been renamed targets\")\n"
     ]
    }
   ],
   "source": [
    "# Get the full train dataset (for checking accuracy while training)\n",
    "train_images = np.array(mnist_dataset.train_data).reshape(len(mnist_dataset.train_data), -1)\n",
    "train_labels = one_hot(np.array(mnist_dataset.train_labels), n_targets)\n",
    "\n",
    "# Get full test dataset\n",
    "mnist_dataset_test = MNIST('/tmp/mnist/', download=True, train=False)\n",
    "test_images = jnp.array(mnist_dataset_test.test_data.numpy().reshape(len(mnist_dataset_test.test_data), -1), dtype=jnp.float32)\n",
    "test_labels = one_hot(np.array(mnist_dataset_test.test_labels), n_targets)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "nrggVgdMQooO"
   },
   "source": [
    "### **I. Stability with IID weights (init)**"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "zePAca0nQ4jy"
   },
   "source": [
    "In this section, we simulate the Jacobian norm as a function of depth. The goal is to show the role of the initialization hyperparameters on the Jacobian norm."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "0AZVE9WVRMYl"
   },
   "outputs": [],
   "source": [
    "width = 256\n",
    "depths = [5*i for i in range(1, 20)]\n",
    "scale_init = [2, 0.5, 4]\n",
    "\n",
    "def compute_jac(depth, input, scale, key):\n",
    "  layer_sizes = [784] + [width]*depth +[10]\n",
    "  params = init_network_params(layer_sizes, scale, key)\n",
    "  return jnp.linalg.svd(jacobian_fn(params, input))[1][0]\n",
    "\n",
    "nb_runs = 3\n",
    "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'scale'])\n",
    "jac_eval_in = jnp.ones(width)/jnp.sqrt(width)\n",
    "\n",
    "for scale in scale_init:\n",
    "  for depth in depths:\n",
    "    for rn in range(nb_runs):\n",
    "      evol.loc[len(evol.index)] = [float(compute_jac(depth, jac_eval_in, np.sqrt(scale/width), random.PRNGKey(rn))), depth, scale]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "CpU8nh4ag-dl"
   },
   "outputs": [],
   "source": [
    "evol.to_excel('jacobian_norm_init_iid.xlsx')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 315
    },
    "id": "Qd_BoxhLWHLu",
    "outputId": "9dd625a1-150e-48f6-ae06-7db873467c40"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#plotting the results\n",
    "\n",
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "cmap = [sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
    "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
    "\n",
    "ax = sns.lineplot(data=evol, x='depth', y='jac_norm', hue='scale', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
    "ax.set(yscale='log')\n",
    "ax.set_xlabel('Depth', fontsize=12)\n",
    "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
    "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
    "plt.legend(title=r'$\\sigma_w^2$', loc='lower left', fontsize=9)\n",
    "plt.savefig('jacnorm_iid_init_all.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "#experements with CNNs\n",
    "\n",
    "\n",
    "df = pd.DataFrame(columns=['scale', 'depth', 'jac_norm_init', 'jac_norm_end', 'train_acc', 'test_acc', 'BN', 'WD'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "#stable jacobian\n",
    "#----- no bn, no wd\n",
    "df.loc[len(df.index)] = [2., 5, 5., 2., 0.91, 0.77,  0, 0]\n",
    "df.loc[len(df.index)] = [2., 15, 10., 3., 0.97, 0.88,  0, 0]\n",
    "df.loc[len(df.index)] = [2., 25, 10.5, 3.1, 0.98, 0.91,  0, 0]\n",
    "df.loc[len(df.index)] = [2., 35, 10.5, 2.9, 0.99, 0.92,  0, 0]\n",
    "#----- with bn\n",
    "df.loc[len(df.index)] = [2., 5, 5., 2., 0.91, 0.78,  1, 0]\n",
    "df.loc[len(df.index)] = [2., 15, 10., 3., 0.97, 0.90,  1, 0]\n",
    "df.loc[len(df.index)] = [2., 25, 10.5, 3.1, 0.98, 0.92,  1, 0]\n",
    "df.loc[len(df.index)] = [2., 35, 10.5, 2.9, 0.99, 0.93,  1, 0]\n",
    "\n",
    "\n",
    "#unstable jacobian\n",
    "#----- no bn, no wd\n",
    "df.loc[len(df.index)] = [5., 5, 80., 10., 0.97, 0.73,  0, 0]\n",
    "df.loc[len(df.index)] = [5., 15, 9000., 100., 0.90, 0.85,  0, 0]\n",
    "df.loc[len(df.index)] = [5., 25, 1e6, 1e6, 0.10, 0.10,  0, 0]\n",
    "df.loc[len(df.index)] = [5., 35, 1e8, 1e8, 0.10, 0.10,  0, 0]\n",
    "#----- with bn\n",
    "df.loc[len(df.index)] = [5., 5, 80., 2., 0.91, 0.79,  1, 0]\n",
    "df.loc[len(df.index)] = [5., 15, 9000., 40., 0.97, 0.88,  1, 0]\n",
    "df.loc[len(df.index)] = [5., 25, 1e6, 100, 0.98, 0.75,  1, 0]\n",
    "df.loc[len(df.index)] = [5., 35, 1e8, 1e8, 0.10, 0.10,  1, 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 371
    },
    "id": "kJyyz09-fOsq",
    "outputId": "5914a452-e794-4e08-88c7-65b6c9a80648"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-18-7a4004230d27>:5: UserWarning: Ignoring `palette` because no `hue` variable has been assigned.\n",
      "  ax = sns.lineplot(data=evol[evol['scale']==2], x='depth', y='jac_norm', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#zoom on the critical line\n",
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "cmap = sns.color_palette('deep')\n",
    "ax = sns.lineplot(data=evol[evol['scale']==2], x='depth', y='jac_norm', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
    "ax.set(yscale='log')\n",
    "ax.set_xlabel('Depth', fontsize=12)\n",
    "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
    "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
    "#plt.legend(title=r'$\\sigma_w^2$', loc='lower left', fontsize=10)\n",
    "plt.savefig('jacnorm_iid_init_critical.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "OAvfimJPrrXd"
   },
   "source": [
    "### **II. Stability with correlated weights (init)**\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "tzh1CaPAru1c"
   },
   "outputs": [],
   "source": [
    "#utils dor simulating correlated weights\n",
    "def random_layer_params_corr(m, n, scale, corr, key):\n",
    "  w_key, b_key = random.split(key)\n",
    "  return scale * random.normal(w_key, (n, m)) + scale*corr*random.normal(random.PRNGKey(100)), 1e-6 * random.normal(b_key, (n,)) #He Initialization\n",
    "\n",
    "# Initialize all layers for a fully-connected neural network with sizes \"sizes\"\n",
    "def init_network_params_corr(sizes, scale, corr, key):\n",
    "  keys = random.split(key, len(sizes))\n",
    "  return [random_layer_params_corr(m, n, scale, corr, k) for m, n, k in zip(sizes[:-1], sizes[1:], keys)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "IRTt0om_2Y6U"
   },
   "outputs": [],
   "source": [
    "width = 256\n",
    "depths = [5*i for i in range(1, 20)]\n",
    "scale_init = [2]\n",
    "corrs = [0] + [2**(-k) for k in range(8,1,-1)]#[0.0, 0.001, 0.004, 0.01, 0.1, 0.5]  \n",
    "\n",
    "def compute_jac_corr(depth, input, scale, corr, key):\n",
    "  layer_sizes = [784] + [width]*depth +[10]\n",
    "  params = init_network_params_corr(layer_sizes, scale, corr, key)\n",
    "  return jnp.linalg.svd(jacobian_fn(params, input))[1][0]\n",
    "\n",
    "nb_runs = 3\n",
    "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'scale', 'corr'])\n",
    "jac_eval_in = jnp.ones(width)/jnp.sqrt(width)\n",
    "\n",
    "for scale in scale_init:\n",
    "  for corr in corrs:\n",
    "    for depth in depths:\n",
    "    # runs = []\n",
    "      for rn in range(nb_runs):\n",
    "        # runs.append(compute_jac(depth, jac_eval_in, random.PRNGKey(rn)))\n",
    "        # evol.append(runs)\n",
    "        evol.loc[len(evol.index)] = [float(compute_jac_corr(depth, jac_eval_in, np.sqrt(scale/width), corr, random.PRNGKey(rn))), depth, scale, corr]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "TVOqi9YAh1v3"
   },
   "outputs": [],
   "source": [
    "evol.to_excel(\"jacnorm_init_noniid.xlsx\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 642
    },
    "id": "AqgOMmPM6MIF",
    "outputId": "d295320d-82c5-4de4-9f42-e5bd1d8531af"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-43-5e0c4d696e10>:7: UserWarning: The palette list has more values (10) than needed (7), which may not be intended.\n",
      "  ax = sns.lineplot(data=data, x='depth', y='jac_norm', hue='corr', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb48e3d00> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb4771f30> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb4773220> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb47700a0> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb4772530> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb4770670> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
      "<ipython-input-43-5e0c4d696e10>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb47e1000> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f0fb4cb32b0>"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Lv1nP/tZYp+RantfMIXEpFccPXpUB/SNGzfquq7rLS0tusVi0Z977rnEPp999pkO6Js3bx6sbvYrPp9PLykp0d966y39oosuSgjJSLX9P//zP/ULLrig2+2apul5eXn6j3/840RbS0uLbrPZ9L/85S8D0cWkcdlll+k333xzh7bly5frN954o67rI9v2vmBObZn0itbWVgAyMjIA+Pjjj4nFYixZsiSxz5QpUygqKmLz5s2D0sf+5vbbb+eyyy7rYCOMXNtfeuklZs+ezRe+8AVycnKYNWsWv/71rxPbDxw4QG1tbQe7U1NTmTt37rC2G+C8885j/fr17NmzB4CysjLef/99li1bBoxs2/uCmbTRpMdomsZdd93F+eefzxlnnAFAbW0tVquVtLS0Dvvm5uZSW1s7CL3sX/7v//6Pbdu2sXXr1k7bRqrt+/fv54knnmD16tV897vfZevWrdxxxx1YrVZWrFiRsC03N7fD94a73QBr1qzB6/UyZcoUJElCVVUeeOABbrzxRoARbXtfMIXEpMfcfvvt7Ny5k/fff3+wuzIgHD58mDvvvJO33noLu90+2N0ZMDRNY/bs2Tz44IMAzJo1i507d/Lkk0+yYsWKQe5dcvnrX//Kn/70J/785z8zbdo0SktLueuuuygoKBjxtvcFc2rLpEesWrWKl19+mXfeeadDuvy8vDyi0SgtLS0d9q+rqyMvL2+Ae9m/fPzxxxw9epSzzjoLWZaRZZmNGzfy85//HFmWyc3NHZG25+fnM3Xq1A5tp59+OocOHQJI2HZ8dNpwtxvg29/+NmvWrOGGG25g+vTpfPnLX+Zb3/oWDz30EDCybe8LppCYnBBd11m1ahUvvPACGzZsYPz48R22n3322VgsFtavX59oKy8v59ChQ8ybN2+gu9uvLF68mE8++YTS0tLE3+zZs7nxxhsT/z8SbT///PM7hXjv2bOH4uJiAMaPH09eXl4Hu71eLx9++OGwthsgGAx2KuAkSRKapgEj2/Y+MdjefpOhzTe+8Q09NTVVf/fdd/WamprEXzAYTOxz66236kVFRfqGDRv0jz76SJ83b54+b968Qex18mgftaXrI9P2LVu26LIs6w888IBeUVGh/+lPf9KdTqf+zDPPJPZ5+OGH9bS0NH3dunX6jh079M9//vMjIgR2xYoVemFhYSL89/nnn9ezsrL0e+65J7HPSLW9L5hCYnJCgC7/nn766cQ+oVBIv+222/T09HTd6XTqV199tV5TUzN4nU4ixwvJSLX9H//4h37GGWfoNptNnzJliv7UU0912K5pmn7vvffqubm5us1m0xcvXqyXl5cPUm/7D6/Xq9955516UVGRbrfb9dNOO03/3ve+p0cikcQ+I9X2vmCmkTcxMTEx6ROmj8TExMTEpE+YQmJiYmJi0idMITExMTEx6ROmkJiYmJiY9AlTSExMTExM+oQpJCYmJiYmfcIUEhMTExOTPmEKiYnJKGPt2rUIgtCh4qGJSV8whcTEJAnEH9bxP7vdTkFBAUuXLuXnP/85Pp8v6X345S9/ydq1a5N+HhMTM428iUkS+e///m/Gjx9PLBajtraWd999l7vuuotHHnmEl156iTPPPDNp5/7lL39JVlYWK1euTNo5TEzAFBITk6SybNkyZs+enfj8ne98hw0bNnD55Zdz5ZVX8tlnn+FwOAaxhyYmfcec2jIxGWAWLVrEvffeS2VlJc8880yifffu3Vx77bVkZGRgt9uZPXs2L730UofvxqfM3nvvPb7+9a+TmZmJx+PhK1/5Cs3NzYn9xo0bx6effsrGjRsT02sLFizocKxIJMLq1avJzs4mJSWFq6++mvr6+qTabjIyMYXExGQQ+PKXvwzAm2++CcCnn37Kueeey2effcaaNWv4yU9+QkpKCldddRUvvPBCp++vWrWKzz77jB/84Ad85Stf4U9/+hNXXXUV8Rysjz76KGPGjGHKlCn88Y9/5I9//CPf+973Ohzjm9/8JmVlZXz/+9/nG9/4Bv/4xz9YtWpVki03GYmYU1smJoPAmDFjSE1NZd++fQDceeedFBUVsXXrVmw2GwC33XYbF1xwAf/5n//J1Vdf3eH7VquV9evXY7FYACguLuaee+7hH//4B1deeSVXXXUV//Vf/0VWVhZf+tKXuuxDZmYmb775JoIgAEaJ3Z///Oe0traSmpqaLNNNRiDmiMTEZJBwuVz4fD6amprYsGED1113HT6fj4aGBhoaGmhsbGTp0qVUVFRQVVXV4btf+9rXEiIC8I1vfANZlnn11Vd7fP6vfe1rCREBmD9/PqqqUllZ2XfjTEYV5ojExGSQ8Pv95OTksHfvXnRd59577+Xee+/tct+jR49SWFiY+FxSUtJhu8vlIj8/n4MHD/b4/EVFRR0+p6enA3TwtZiY9ARTSExMBoEjR47Q2trKxIkTE/XA7777bpYuXdrl/hMnTuz3PkiS1GW7WevOpLeYQmJiMgj88Y9/BGDp0qWcdtppAFgsFpYsWdKj71dUVLBw4cLEZ7/fT01NDZ/73OcSbe2nrUxMkonpIzExGWA2bNjAD3/4Q8aPH8+NN95ITk4OCxYs4Fe/+hU1NTWd9u8qJPepp54iFoslPj/xxBMoisKyZcsSbSkpKbS0tCTFBhOT9pgjEhOTJPLaa6+xe/duFEWhrq6ODRs28NZbb1FcXMxLL72E3W4H4PHHH+eCCy5g+vTp3HLLLZx22mnU1dWxefNmjhw5QllZWYfjRqNRFi9ezHXXXUd5eTm//OUvueCCC7jyyisT+5x99tk88cQT/M///A8TJ04kJyeHRYsWDaj9JqMDU0hMTJLIfffdBxjhuhkZGUyfPp1HH32Um266Cbfbndhv6tSpfPTRR9x///2sXbuWxsZGcnJymDVrVuIY7fnFL37Bn/70J+677z5isRj/9m//xs9//vMO01n33XcflZWV/OhHP8Ln83HRRReZQmKSFATd9KyZmAwb1q5dy0033cTWrVs7pF4xMRlMTB+JiYmJiUmfMIXExMTExKRPmEJiYmJiYtInTB+JiYmJiUmfMEckJiYmJiZ9whQSExMTE5M+YQqJiYmJiUmfMIXExMTExKRPmEJiYmJiYtInTCExMTExMekTppCYmJiYmPQJU0hMTExMTPqEKSQmJiYmJn3i/wP3gQzSJ/XATAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "cmap = sns.color_palette('deep')\n",
    "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
    "\n",
    "data = evol[evol['corr']!=0.25]\n",
    "ax = sns.lineplot(data=data, x='depth', y='jac_norm', hue='corr', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
    "ax.set(yscale='log')\n",
    "ax.set_xlabel('Depth', fontsize=12)\n",
    "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
    "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
    "labels_ = [r'$\\infty$', '_nolegend_']\n",
    "for k in range(8, 2, -1):\n",
    "  labels_ += [k, '_nolegend_']\n",
    "plt.legend(title=r'$\\eta = 2^{-k}, k=\\downarrow$', loc='lower left', fontsize=9, labels= labels_, ncol=2)\n",
    "#plt.savefig('jacnorm_noniid_init_all.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 464
    },
    "id": "Tf5Xe_LJ_HH_",
    "outputId": "8112d36b-0d60-4e05-a5bc-89c7f8826526"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-44-086efcc62b49>:8: UserWarning: The palette list has more values (10) than needed (3), which may not be intended.\n",
      "  ax = sns.lineplot(data=data, x='corr', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
      "<ipython-input-44-086efcc62b49>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb46b57e0> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title='Depth', loc='lower left', fontsize=9, labels=['5', '_nolegend_', '15', '_nolegend_', '50'])\n",
      "<ipython-input-44-086efcc62b49>:15: UserWarning: The label '_nolegend_' of <matplotlib.collections.PolyCollection object at 0x7f0fb46b6110> starts with '_'. It is thus excluded from the legend.\n",
      "  plt.legend(title='Depth', loc='lower left', fontsize=9, labels=['5', '_nolegend_', '15', '_nolegend_', '50'])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f0fb5c661d0>"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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4VEUZUIMf/tT4MrFrukIBLmOLBr9LTg1O83BNsLxyNFPkGEy5dOUBfAnP/kJdruds846iyVLlnDddddx3XXXsWTJEs444wzsdjs//vGP02rkZOS6665DkiQkSULTNIqKirjwwgv57W9/m/Y0muuuu27A0sH+iN4VMSlOBVscASEE0Wh0QvnUrtkpdOUTjIaYV3wS6xu34FDthGJhWgPtY21exnyasgBWV1ezefNmbrvtNjo7O3niiSd44okn6Ozs5Pbbb2fTpk1UVVWl1cjJysUXX0xjYyP19fW88MILLF26lNtvv51LL710yGo2mSIUCh23a00FTNNk69atEy4fNM+Zg1t3EopHmJ03nR3te/HaXLT2tOOPBMbUtkz5dFTJaoWFhfz3f/8327dvJxQKEQqF2L59O/fff/8RS2VZDMRms1FcXExZWRmnnXYad911F88++ywvvPACjzzyCJCoXfjlL3+ZgoICvF4v5513Hps2bUqe45577qG2tpZf/vKXVFRU4HQ6ufrqq+nu7k4+/+ijj/Lss88me5xr165Nvn7v3r0sW7YMl8vF3LlzJ2303uLo6IpGkbuAsBFhRm4lezoaUGQVwzRpDrRhiokl6CMhZQGMx+MDStEcjs/nO669l8nGeeedx9y5c5NVeK666ipaWlp44YUX+Mc//sFpp53G+eefPyAQtXv3bp588kmee+45XnzxRTZs2MCtt94KwB133MHVV1+d7G02NjZyxhlnJF/73e9+l9tvv50NGzYwa9YsPv/5z1vv3xQm25FFls1DIBpkQekp/OPQZrLsHjpDXXSFh//eT1RSFsDbbrttwBfocM4880y++c1vHpNRU50TTjiB+vp63nrrLdatW8dTTz3FggULqKmp4b/+67/Izs7mz3/+c/L4cDjMY489Rm1tLZ/4xCd48MEH+b//+z+amppwu904HI5kb7O4uBhd/3id5ze/+U2WLVvGrFmzuPfee2loaBiwEsdidEyklUD9UWWFIncBcdMg35VHd9hPJB5FldVEWowxdj+OmfBpymd88cUXhy0eConyWatXrz4mo6Y6ondp2qZNmwgEAuTl5eF2u5N/dXV17NmzJ3n8tGnTKCsrSz5esmQJpmmyY8eOo15r7ty5yShw35K2viVuFqNDURTmzZs3oaLA/cmye8hxZOOLBFhScRrvHliPx+bGFwnQ1tM5JjZlyqcprwU+dOjQgC/b4ZSWlnLw4MFjMmqqs23bNqqrqwkEApSUlAyYs+sjOzs7LddSVRXDMJJFJYEJN3k/3hBC4Pf78Xg8EzK9SJZkCt35dId9ycowHT2dODUHLcFWsu0e7NrxzfXNlE9T7gHm5eUdsWexbdu2ES1BsRiaV199lQ8//JDPfvaznHbaaTQ1NaGqKjNnzhzw138jp3379nHo0KHk43fffRdZlpk9ezaQqKJzpL0SxsMWjpMJ0zTZtWvXhP4h8egu8py5+CIBFpXVsu7gJly6g3A8Qkuw/bin+GTKpykL4MUXX8wvf/lLNmzYMOi59evX86tf/Yply5alxbjJTiQSoampiYMHD7J+/Xp+9KMf8elPf5pLL72UL33pS1xwwQUsWbKEyy+/nJdffpn6+nr+/ve/853vfIcPPvggeR673c6KFSvYtGkTb775JrfddhtXX311skZiVVUVmzdvZseOHbS1tRGLTd1tEC1GhiRJFLry0BQN0zQo8xZT17kfr81NW7ADfzQ41iamhZSHwN///vd58cUXWbRoEZ/61Kc46aSTANiyZQvPPfcchYWFfP/730+7oZORF198kZKSElRVJScnh7lz5/I///M/rFixIjnhu3r1ar7zne9w/fXX09raSnFxMZ/4xCcGbAswc+ZMrrjiCpYvX05HRweXXnopP//5z5PP33jjjaxdu5YFCxYQCAR47bXXrFxNi6Pi1B0UOHM56Gvi5MLZrN71KpXZZZgImv2tuDXnhA329JFyNRiAxsZG7rzzTp599tlkSozX6+Xyyy/nRz/6EaWlpWk3dLxwtGowx7syyj333MMzzzwz6jL/QgjC4TB2uz3luZWxuufxjmEYbN++nRNOOGHCBkL6CMcj7GzbiwS09nTQFfJxctFsusI+ZuRWkufMOS52jNSnqVaDGVVB1JKSEh599FGEELS2tgJQUFAwISd8pzqSJE2o8l0TAUVRkiOjiY5dtVHoyqeh+wDTssrY1rqbEwtmoisaTYFWvDY3mqJl3I5M+fSY+q+SJFFYWEhhYaElfhMUIQSxWGxCrVsd7wghaGtrmzQ+zXNm49ZdBKLB3oDIxsTjSPC4pcVkyqej3hPk7bffZv369XR3dw+KzEiSxL//+78fs3EWR+eee+7hnnvuOaZzRKNRVPWYtoex6IdpmjQ0NJCTkzPhh8AAmqJR5M5nb8c+cuxZxM04gUgAl+6gJdhGlt2DM8M7yWXKpyl/6js6OrjkkktYt25dMmG3T5X7/m8JoIXF5CLHnkWW3YM/GuD08tN4s2Edn5z5Cdp6OmkJtlOZVTYhR4EpD4G/9a1vsXnzZv74xz+yd+9ehBC89NJL7Ny5k5tvvpna2toBOWkWFhYTH0VWKHLlYwoTVVbJtmdxyN+M1+amPdgx5tViRkvKArh69WpuuukmrrnmGjweT+IksszMmTN5+OGHqaqq4l/+5V/SbadFBpkMw7TxhCRJeL3eCdkjOhLefkvk5peezD8OfYgmqwgETYG2jCZ+Z8qnKQtgV1dXMhrjdruBxFaWfXzyk5/kpZdeSpN5FplGkqRRpcBYDI8sy9TU1Ez4HLnDkSWZQlceiiwTNw1m5U1nR9sesmweukJddIS7MnftDPk05bOVlpbS1NQEJOrZFRYWDqhPd/DgQevLNIGYiNWLxzumaXLo0KEJvRRuODw2N3nOHPzRILPyqtnd0YAAbKpOc6CVqJGZVUaZ8mnKAviJT3yCv/3tb8nH11xzDT/5yU/44Q9/yPe//30eeOABli5dmlYjpxI94eO/TM1aGpdehBA0NjZO2h+VAlceNkUjHI/01gz8sDctpofWYGbK52fKpykL4MqVK/nUpz5FJJLYKOWee+7h9NNP59///d+5++67mT9/Pg8++GBajZwq+HuiPPP6bvw90Yxd47rrrkPX9WRpLY/Hw3vvvZex61lMPpyag3xXHoFoD0XuArrDPkLxMG7dSWuwnZ7oxNliIeU0mFNOOYVTTjkl+TgnJ4dXXnmFrq4uFEVJBkYsUsPfE+XBJzewo6GT+kYfX796Hh6nfvQXjoJbb72VBx54APh4Y3QLi1QocObSEeoiGAuxpOI03tm/nvOnn0mwLy1GmxhpMSMSwPXr16d0UkVR8Hq9VFZWTrqJ4EzQX/wAdjR08uCTGzIqgv2xkqDTiyRJ5OfnTwgBGC26qlPkLqCuYx95zmxsik5bTydZNjdtPe1kO7xk29NXFi9TPh3RJ3/BggWjurDL5eLaa6/l/vvvt9abDsPh4tdHJkXwscce47HHHqOkpIQbbriBb3zjG5P6y3q8kWWZysrKsTYj4+Tas2i3uwlEgiwqr+WVPW+xfNZSZCSaA614dBeKnJ4Uq0z5dEQC+Lvf/S6lk/ZVb123bh2/+tWvEEKwatWqURk40Xnp3Qbau4eeEzl3fjl/e6+BjTtbh3x+485Wnn5tFxcurmTtPw4Me428LAcXnT6yD8dtt93GT3/6U3Jzc3n//fe5+uqrMU2TO+64wxLBNGGaJvv376eiomJSj4BURaXIVcCejgZckpysGTgtq4zOcDedoW7yXblpuVamfDoiAVyxYsWoL5Cdnc0TTzwxZQXwaMJ0xdIaDrYGBvUAAWZX5nDF0ho8Tp1/uuiEtNhz2mmnJf9/+umn86//+q88+uij3HHHHWk5v8XHC/fLy8vH2pSMk233kmX34ov4OaXoBJ7fuYbK7DJsip6sFqOrxz6CyZRPM/7ztHTp0mTCtMVgPE6dr189j9mVA+uqza7MOS5zgJO5h2KReWRZpsidh0BgmHFOKTqBzU3bcetOgrEeWnoykxaTLjL+6b/iiivYu3dvpi8zoTlcBDMpfk8++SQ+nw8hBB988AE//vGP+fSnP53261hMHbw2D3mOHHzRIFXZ5TQGWoiZMTyak9ZgB8Ho+M0ysH7+xwl9InjR6ZUZ7fk99NBDTJs2DY/Hw7XXXsstt9xi7eOcZvq2GJ0qc6qSJFHgzkORFCLxCIvKannvwEbsmp24EaclcOx1/DLlUyv/YRzhcepcfs5MnPbMVdh94403MnZuiwSyLE/qbSGGwq27KHDmcsjfQoErh7gZxxf2J6rFhDrJcWSR7cga9fkz5VOrBzjOyKT4DUXfniCTddnWWDAZtsUcDQWuXOyaTk8sxOLy03j3wAY0RUWWZJoCrcTN4bdmPRrjZltMi8nHkfYMtkgdIURynnUqYdfsFLryCUZDOFQb2XZvsmZgd8RPR6hr1OfOlE8tAbSwsEgbec4c3LqTQLSH+aWnsP7QFiQkHKqdpkArkXjm1rmPBksALSws0oauaBS5C4gYUUCiJq+KHW17cWkOwrFQxqrFjBZLAC3Q9cyvN55K9C3bmqo5ltmOLLw2N4FogFl509ndUY8hTNy6i9ZgB4FoMOVzZsqnU/MdskgiSRKapk2ZlI3jwVQohnAkVFmhyF1A3DQwhMn83pqBdtVG3IzTHGjDFKkFMzLlU0sApzhCCEKh0JSbsM8khmHw0UcfTengUla//UNKPIV0h330xEJk2d10hLroDvtTOl+mfGoJoMWUS9c4HoTD4bE2YUyRJZlCdz4SEDVinF5xGu/u34Aqq6iSTHOglbgRT+mcmfCpJYDjDDMyfpcNWVikgkd3kefMxRcJ4LW50RSVtp5OPDY33WE/7T2DC4AcbywBHEcYIT9d7z2HEUpteGBhMR6RJIlCVx6aohGOhVlcXsv7BzciSzJOzU5zsI1wPDKmNloCOE4wQn5an/8F/g1/o/X5X2RMBB966CEWLFiAzWbj8ssvB8ButwNw7rnnYrPZkvuFuN1ua5P7UTBZt8UcDU7dQYErl0CsB03WKPUUU9+5H6fmIBSL0BoYWVrMuNkW0yL99Ilf5OBOACIHd2ZMBEtLS/nud7/LjTfeCCR+pRVFSUbXfvzjHxMIBJJ/U21NazqYrBujj5Z8Zy521U5PLMQpRbP5sGUHAoHX5qK1px1/JHDUc4ybjdEt0svh4tdHpkTwiiuu4PLLLyc/Px/4eFMkKwqcPgzDYMOGDVM6Ctwfu2qjyJVPTzwMSJxSOJsPm7djU3UM0xxRWkymfGpVg8kwvg2vEPcP3c13n/wJ/BtfIVS3acjnQ3Wb6HrnGTy1FxDYMnwVF9WTh3feBaO2sb/4/eAHP+A//uM/qKys5Bvf+AZf+tKXRn3eqYwVWR9IrjObtlAngWiQqpwKXtj1GicWzCTL7qEz1E1XyEeuM/uI58iETy0BzDBHE6bsJZcT62gc1AMEsJXNInvJ5SgOD7mfuCZTJia57777mDNnDk6nk1dffZWrr74aj8fDZz7zmYxf22JyoykaRe589nbswzDNZM3AsysXockKTYFWPDYXmnJ8qyFNySFwVVUVp556KrW1tSxdunRMbVEcHgouuQVb2awB7bayWRRccguK4/jts7xkyRKysrLQNI2LLrqIm266iSeeeOK4Xd9icpNjzyLL7sEf8ZPn/LhmoNvmxh8N0N7TddxtmpICCPD3v/+djRs38tprr421KYNE8HiL33BbllpRzNEhyzJz5syx/HcYiqxQ5MrHRBAz4smagbIk4VQdtARbCcWGTnbOlE+td2ic0CeCnnkXZlT84vE44XCYeDyOaZpEIhFisRjd3d2sXr2anp4eDMNgzZo1rFq1is9+9rMZsWMyI0kSuq5bUeAh8PZbIufU7MmagS7dQTgeoSU4dPn8TPl03AngG2+8wWWXXUZpaSmSJPHMM88MOubhhx+mqqoKu93O4sWLWbduXUrXkCSJc845h4ULF/KHP/whTZYfO4rDQ/biyzLa8/vBD36Aw+Hghz/8Ic899xwOh4MLLriAaDTKvffeS3FxMTk5OXzjG9/g/vvv56qrrsqYLZMVwzDYuHGjFQUeAlmSKXTlocgykXg0WTNQCJEonx/sxD9EtZhM+XTcBUGCwSBz587lhhtu4Iorrhj0/BNPPMHKlStZtWoVixcv5oEHHuCiiy5ix44dFBYWAlBbW0s8Pnid4csvv0xpaSlvvfUWZWVlNDY2csEFF3DKKadw6qmnDmlPJBIhEvk4W93n8wGJN6Tvzej7VRJCJP/6kCRp2F+0odplm3PEx6d6bkmSuPvuu7n77ruTbX3FEBwOB++++25K5+/7MwwDIQSSJA36gMqynFK7oigIIQZF/FJplyQJWZYxTXPQe5FKe6q29283TTP5/GS5p9Hafni7U3WQY8uiOdhKoTufGTmVbGvdzey86cQNg8buZtz5TuDjDIW+zxhwxHtKVSDHnQAuW7aMZcuWDfv8/fffz4033sj1118PwKpVq3j++ef57W9/y5133gnAxo0bj3iNsrIyAEpKSli+fDnr168fVgDvu+8+7r333kHtmzdvTu53nJ+fT1FREYZhEAqFkm++pmnouk4kEhnwxui6jqZphMPhAR8Uu92OoiiDqrP0zdH19AxcJ+x0OpMC1ockSTidTkzTHLB4XJZlHA4H8XicaPTjqryKogCJoXEsFku2q6qKzWYjGo0O+DHpf0+hUIhYLMb27duprKwkPz+f7du3D7huTU0NXq+XzZs3D7jXOXPmoOv6oPeqtraWaDTK1q1bB9g+b948/H4/u3btGuCvk046ifb2dhoaGpLtXq+XmpoampqaaGxsTLbn5+dTWVnJ/v37aWtrS7aXlJRQWlrKnj17kj9wwKjvadOmTezfvz9p+2S4p3S/T1Ejik8E8VS5KRBZvLDndeTmOBLQ4Wwj351LoNWXvCfTNJP3caR76u+DkSCJcZwBK0kSf/nLX5JLtqLRKE6nkz//+c/JNoAVK1bQ1dXFs88+e9RzBoNBTNPE4/EQCAQ455xzWLVqFQsXLhzy+KF6gBUVFXR0dOD1epN2RqNR9u7dS3V1dXJpWd9zqfbSMtkDPLy9fw/w8PmVo50nHA5TV1dHZWUlTqdzzHsW/e0by95SNBpl06ZNzJ07F0VRJsU9ZeJ9OuRv5pC/mVx7Fo3+Fg74GllYNhd/NIhNszEzpxJVTvTRDMNg8+bNzJs3b9Dnsr+NPp+P3Nxcuru7k9/PIzHueoBHoq2tDcMwKCoqGtBeVFTE9u3bR3SO5ubmZF6bYRjceOONw4ofgM1mw2azDWrv+2D3R5Kk5N/h7UORjvZjPUdfj3E05+n767+U7nCf9JFKe985j7V9uIhhqu2p3pOu65x22mkDnp/o95SJ96nInU9XxEfIiFCeXcLWtl1EzBheu4f2nk46Ql2UeIuS1583b96w9vUdc6Tnh2JCCWA6mD59Ops2Db3yYirSf87SilqmByEE0WgUu91u+fQI6KpOkbuAuo59ODU7p5fP470D61lafQYu3UlLsI0shxen5siYT8ddFPhI5OfnoygKzc3NA9qbm5spLi4eI6smPv3nEC2OHdM02bp1q7UcbgTk2rPw2t0EIkG8dg+qrNLe04lTsxMxYrQE25ND50z4dEIJoK7rzJ8/nzVr1iTbTNNkzZo1LFmyZAwts7CwGA2qolLkKiBmGhimweLyWtYd3AjQmxbTMaJqMaO+fsbOPEoCgQC7d+9OPq6rq2Pjxo3k5uYybdo0Vq5cyYoVK1iwYAGLFi3igQceIBgMJqPCFhYWE4tsu5csuxdfxE+OI4tSTxH1nfupyqkgCDQF2qjKKsvItcedAH7wwQcD1ueuXLkSSER6H3nkEa655hpaW1v53ve+R1NTE7W1tbz44ouDAiMTlVAshEMbemlaprDmqdKPtQxu5MiyTJE7D1/ET8yIcUrRCTy/81WmZZfhtbnpDHfTaXNnxKfjOg1mPOLz+cjKyhoUZu9LCTk8DSYVApEgq3e+xvJZS3HbXOkyOWOk454tLCAROKrv3E9bqJM8Rzb1nfvpjgSYW3wi/kgAVVGZlTf9qNVihvt+Dof1MzVOCESCrHr/96zZ+xar3v89gUjqm0ePhOuuuw5d1weUvX/rrbeSkeBYLMbXvvY1cnJyyM3N5etf//qQq2oshkcIgc/ns4rMpoAkSRS481AllUg8QlVOBYf8TUSNKA7NTjgWobOrM+0+tQRwHNAnfrva6wDY1V6XURG89dZbkyXv/X4/8+bNSz73gx/8gLfeeoutW7fy0Ucf8eabb/KjH/0oI3ZMVkzTZNeuXVYUOEXcuot8Zw6+3p0RF5XVsu5AImXNpTmRVXVqR4EnI4eLXx+ZFsHh+O1vf8t3v/tdSkpKKCkp4Tvf+Q6/+c1vjqsNFlOXAlcuDk2nJxYiz5lD1IghhKDIU8Df6t/oLaufPsZdEGSysWbPW7SHuoZ87uzKRby69202N28b8vnNzdt4dvvLnDf9TN5sGL7iTZ4jm/NnnDVimx577DEee+wxSkpKuP7667npppsA6Ozs5MCBA9TW1iaPra2tZd++fXR3d5OVlTXia1hYjAa7ZqfAlc++roPYVTvnTT8Tt83FL9//PTta9nDQ38TNC7+YtjlySwAzzNGE6dMnfJJGf8ugHiBATV41nz7hk7htLq4++dK02HPbbbfx05/+lNzcXN5//32uvvpqTNPkW9/6FoFAIt8qOzs7eXzf//1+vyWAKWAFhUZPnjOHjlBn7/+zeei9R9jZVociyezsHRndvPALaRFBawg8xrhtLm5e+AVq8qoHtNfkVaftTe7PaaedRkFBAYqicPrpp3PnnXfy9NNPI0lSsrpNd3d38vi+/3s8x680/0RHURROOumklNelWiTQFY0yTwl5zhxWrfs9ezr2ETcNVFVFQkrr9JAlgOOAw0UwU+I3FP1r++Xk5FBeXj6g9NHGjRupqKiwen8pIISgrW3oysYWI0NXNF7atZYd7XuQeh/3D4Dsaq9j9c7XCMWObRmnJYDjhD4RPH/6WRkVvyeffDKZovHBBx/w4x//mE996lPJ56+//np++MMf0tTURFNTEz/60Y/48pe/nBFbJiumadLQ0GBFgY8Bp+5g+azzmZU3PdlmGAaCxI9KTV41y2ctPeZFA5YAjiPcNheXnXB+Rnt+Dz30ENOmTcPj8XDttddyyy23cNtttyWf//d//3eWLFnCiSeeyIknnsiZZ57JXXfdlTF7LCyGw21zcvOiL2Z0esgKgowzMr0M7o03Bm6wLoQYUGla0zQefvhhHn744YzaYWFxNGRJRpNVblr4hWQUeFaap4csAbSwJuvTjCRJeL1ea411GnBqDnyRADct/AIv7lzLpSdckNYRkjUEnuJIkmQV7kwzsixTU1NjFURIA5IkkWXzEIj28KkTL8ST5ukh6x2a4vRV2rUilunDNE0OHTpkBUHShFN3kO/Iobuty1oKN96ZiELSfze4VJiI93o8EELQ2Nho+SeN6IqWEZ9aApgm+ubR+m85OdnpC55o2pFLFFlYjFesIEiaUFUVp9NJa2srmqZNmPkfIQSRSCS5teBIX9PT00NLSwvZ2dlWEMViwmIJYJqQJImSkhLq6uoGbGg93hFCYBjGgK0tR0p2dra1GdUQSJJEfn6+FVhKI5nyqSWAaUTXdWpqaqbEMFjTNKvnNwyyLFNZWTnWZkwqMuVTSwDTjCzLE6oSiGma7N+/n4qKigkzbB/vWD5NP5nyqfXuTHGshfvpx/Jp+smUTy0BtLCwmLJYQ+AU6fsF8vl8Y2xJejAMg0AggM/ns+b00oTl0/QzUp/2fS9H2lO0BDBF/H4/ABUVFWNsiYWFxXCMtIK5tS9wivQtc/J4PJMizcHn81FRUcH+/ftHtI+qxdGxfJp+RupTIQR+v5/S0tIRBUusHmCKyLJMeXn5WJuRdrxer/VlTTOWT9PPSHyaSvVyKwhiYWExZbEE0MLCYspiCeAUx2azcffdd2Oz2cbalEmD5dP0kymfWkEQCwuLKYvVA7SwsJiyWAJoYWExZbEE0MLCYspiCaCFhcWUxRJACwuLKYslgBbDsmPHDmpra5N/DoeDZ555ZqzNmvBUVVVx6qmnUltby9KlS8fanAlNV1cXCxYsoLa2lpNPPplf//rXKb3eSoOxGBGBQICqqioaGhpwudK7N+tUo6qqii1btuB2u8falAmPYRhEIhGcTifBYJCTTz6ZDz74gLy8vBG93uoBWoyI/+//+/84//zzLfGzGFcoioLT6QQgEokghEipaKolgJOY++67j4ULF+LxeCgsLOTyyy9nx44dozrXk08+yTXXXJNmCyce6fCpJEmcc845LFy4kD/84Q8ZsnRikA5/dnV1MXfuXMrLy/nWt75Ffn7+iF9rDYEnMRdffDGf+9znWLhwIfF4nLvuuostW7awdetWXC4XtbW1xOPxQa97+eWXKS0tTT72+XzMnDmTffv2Taj9TjJBOnx68OBBysrKaGxs5IILLuBPf/oTp5566vG+lXFBuj6jAM3NzVxxxRU8/fTTFBUVjcwAYTFlaGlpEYB4/fXXU3rdY489Jq699toMWTWxGa1P+7jjjjvE7373u/QaNYE5Vn/ecsst4qmnnhrx8dYQeArR3d0NQG5ubkqvs4a/w5OqT4PBYLKqeCAQ4NVXX+Wkk07KmH0TjVT92dzcnPRnd3c3b7zxBrNnzx7x9awh8BTBNE0+9alP0dXVxVtvvTXi13V3dzNr1iz279+PrusZtHDiMRqf7t27l8985jNAIoJ54403cvvtt2fSzAnDaPy5bt06vvKVrySDH1/96le56aabRnxNSwCnCLfccgsvvPACb7311qSsaD0WWD5NL2PhT6sk/hTga1/7Gn/961954403rC9qmrB8ml7Gyp+WAE5ihBB8/etf5y9/+Qtr166lurp6rE2a8Fg+TS9j7U9LACcxX/3qV/njH//Is88+i8fjoampCUhsGuNwOMbYuomJ5dP0Mtb+tOYAJzHDbdv5u9/9juuuu+74GjNJsHyaXsban5YAWlhYTFmsPEALC4spiyWAFhYWUxZLAC0sLKYslgBaWFhMWSwBtLCwmLJYAmhhYTFlsQTQwsJiymIJoIWFxZTFEkALC4spiyWAFlOeRx55BEmSqK+vT9s56+vrkSSJRx55JG3ntEg/lgBaZIw9e/Zw0003MX36dOx2O16vlzPPPJOf/exnhEKhsTYvLfzxj3/kgQceGGszLEaJVQ3GIiM8//zzXHXVVdhsNr70pS9x8sknE41Geeutt/jWt77FRx99xK9+9auxNvOY+eMf/8iWLVv4l3/5lwHtlZWVhEIhNE0bG8MsRoQlgBZpp66ujs997nNUVlby6quvUlJSknzuq1/9Krt37+b5558/pmsIIQiHw0OWTAqHw+i6jiyP3QBHkqQpv4PeRMAaAluknZ/85CcEAgF+85vfDBC/PmbOnJncByMej/P973+fGTNmYLPZqKqq4q677iISiQx4TVVVFZdeeikvvfQSCxYswOFw8Mtf/pK1a9ciSRL/93//x3e/+13KyspwOp34fD4A3nvvPS6++GKysrJwOp2cc845vP3220e9h2effZZLLrmE0tJSbDYbM2bM4Pvf/z6GYSSPOffcc3n++edpaGhAkiQkSaKqqgoYfg7w1Vdf5eyzz8blcpGdnc2nP/1ptm3bNuCYe+65B0mS2L17N9dddx3Z2dlkZWVx/fXX09PTc1TbLUaO1QO0SDvPPfcc06dP54wzzjjqsV/+8pd59NFHufLKK/nmN7/Je++9x3333ce2bdv4y1/+MuDYHTt28PnPf56bbrqJG2+8ccDuX9///vfRdZ077riDSCSCruu8+uqrLFu2jPnz53P33XcjyzK/+93vOO+883jzzTdZtGjRsHY98sgjuN1uVq5cidvt5tVXX+V73/sePp+Pn/70pwB85zvfobu7mwMHDvDf//3fALjd7mHP+corr7Bs2TKmT5/OPffcQygU4sEHH+TMM89k/fr1SfHs4+qrr6a6upr77ruP9evX87//+78UFhby4x//+Kh+tRgho9p808JiGLq7uwUgPv3pTx/12I0bNwpAfPnLXx7QfscddwhAvPrqq8m2yspKAYgXX3xxwLGvvfaaAMT06dNFT09Pst00TVFTUyMuuugiYZpmsr2np0dUV1eLCy+8MNn2u9/9TgCirq5uwHGHc9NNNwmn0ynC4XCy7ZJLLhGVlZWDjq2rqxPAgD1/a2trRWFhoWhvb0+2bdq0SciyLL70pS8l2+6++24BiBtuuGHAOT/zmc+IvLy8QdeyGD3WENgirfQNPT0ez1GPXb16NQArV64c0P7Nb34TYNA8YXV1NRdddNGQ51qxYsWA+cCNGzeya9cu/umf/on29nba2tpoa2sjGAxy/vnn88Ybb2Ca5rC29T+X3++nra2Ns88+m56eHrZv337UezucxsZGNm7cyHXXXTdgz9tTTz2VCy+8MOmL/tx8880DHp999tm0t7cnfWxx7FhDYIu04vV6AZKbVR+JhoYGZFlm5syZA9qLi4vJzs6moaFhQPuRNsw5/Lldu3YBCWEcju7ubnJycoZ87qOPPuK73/0ur7766iDB6du8OxX67mWoTbtPPPFEXnrpJYLBIC6XK9k+bdq0Acf12drZ2Zn0s8WxYQmgRVrxer2UlpayZcuWEb9muH0hDudIm+Qc/lxf7+6nP/0ptbW1Q75muPm6rq4uzjnnHLxeL//xH//BjBkzsNvtrF+/nn/91389Ys8xnSiKMmS7sHaxSBuWAFqknUsvvZRf/epXvPPOOyxZsmTY4yorKzFNk127dnHiiScm25ubm+nq6qKysnLUNsyYMQNICPIFF1yQ0mvXrl1Le3s7Tz/9NJ/4xCeS7XV1dYOOHal4993Ljh07Bj23fft28vPzB/T+LI4P1hygRdr59re/jcvl4stf/jLNzc2Dnt+zZw8/+9nPWL58OcCglRT3338/AJdccsmobZg/fz4zZszgv/7rvwgEAoOeb21tHfa1fT2v/j2taDTKz3/+80HHulyuEQ2JS0pKqK2t5dFHH6WrqyvZvmXLFl5++eWkLyyOL1YP0CLtzJgxgz/+8Y9cc801nHjiiQNWgvz973/nqaee4rrrruP2229nxYoV/OpXv0oOO9etW8ejjz7K5ZdfztKlS0dtgyzL/O///i/Lli3jpJNO4vrrr6esrIyDBw/y2muv4fV6ee6554Z87RlnnEFOTg4rVqzgtttuQ5IkHn/88SGHnvPnz+eJJ55g5cqVLFy4ELfbzWWXXTbkeX/605+ybNkylixZwj//8z8n02CysrK45557Rn2vFsfAGEehLSYxO3fuFDfeeKOoqqoSuq4Lj8cjzjzzTPHggw8mU0lisZi49957RXV1tdA0TVRUVIh/+7d/G5BqIkQiDeaSSy4ZdI2+NJinnnpqSBs2bNggrrjiCpGXlydsNpuorKwUV199tVizZk3ymKHSYN5++21x+umnC4fDIUpLS8W3v/1t8dJLLwlAvPbaa8njAoGA+Kd/+ieRnZ0tgGRKzFBpMEII8corr4gzzzxTOBwO4fV6xWWXXSa2bt064Ji+NJjW1tYB7UPZaXFsWPsCW1hYTFmsOUALC4spiyWAFhYWUxZLAC0sLKYslgBaWFhMWSwBtLCwmLJYAmhhYTFlsQTQwsJiymIJoIWFxZTFEkALC4spiyWAFhYWUxZLAC0sLKYslgBaWFhMWf5/tODWFkzJC6wAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(3,3))\n",
    "\n",
    "cmap = sns.color_palette('deep')\n",
    "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
    "\n",
    "data = evol[evol['depth'].isin([5, 15, 50])]\n",
    "data = data[data['corr']!=0.25]\n",
    "ax = sns.lineplot(data=data, x='corr', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
    "#ax.set(xscale='log', basex=2)\n",
    "ax.set_xscale('log', base=2)\n",
    "ax.set(yscale='log')\n",
    "ax.set_xlabel('Correlation', fontsize=12)\n",
    "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
    "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
    "plt.legend(title='Depth', loc='lower left', fontsize=9, labels=['5', '_nolegend_', '15', '_nolegend_', '50'])\n",
    "#plt.savefig('jacnorm_noniid_init_all.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "pHHaD8GKlRnK"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "3X5PBs70lS25"
   },
   "source": [
    "### **III. Stability during training**\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "rHrrBgJWllCM"
   },
   "outputs": [],
   "source": [
    "import time\n",
    "width = 100\n",
    "\n",
    "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'iter', 'train_acc', 'test_acc', 'lr'])\n",
    "jac_eval_in = jnp.ones(width)/jnp.sqrt(width)\n",
    "\n",
    "def compute_jac_training(params, input):\n",
    "  return jnp.linalg.svd(jacobian_fn(params, input))[1][0]\n",
    "\n",
    "def train_neural_network(params, num_epochs, record_freq, lr):\n",
    "  iter = 0\n",
    "  for epoch in range(num_epochs):\n",
    "    start_time = time.time()\n",
    "    for x, y in training_generator:\n",
    "      y = one_hot(y, n_targets)\n",
    "      params = update(params, x, y, lr)\n",
    "      iter+=1\n",
    "      if iter%record_freq==0:\n",
    "        train_acc = accuracy(params, train_images, train_labels)\n",
    "        test_acc = accuracy(params, test_images, test_labels)\n",
    "        evol.loc[len(evol.index)] = [float(compute_jac_training(params, jac_eval_in)), depth, iter, train_acc, test_acc, lr]\n",
    "        \n",
    "    epoch_time = time.time() - start_time\n",
    "    train_acc = accuracy(params, train_images, train_labels)\n",
    "    test_acc = accuracy(params, test_images, test_labels)\n",
    "    print(\"Epoch {} in {:0.2f} sec\".format(epoch, epoch_time))\n",
    "    print(\"Training set accuracy {}\".format(train_acc))\n",
    "    print(\"Test set accuracy {}\".format(test_acc))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "xc4sg7lmPnoy",
    "outputId": "d5ce59cb-878f-4a39-d9d5-7d0e48b7b8ad"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0001, Array(0.00101189, dtype=float32, weak_type=True))"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1/width**2, 1/width/jnp.log(width)**1.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "tH8uQ8j9lfmP",
    "outputId": "79cb44de-e419-4e0d-e142-dff8aa6a67e9"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 in 5.19 sec\n",
      "Training set accuracy 0.09380000084638596\n",
      "Test set accuracy 0.09209999442100525\n",
      "Epoch 1 in 4.66 sec\n",
      "Training set accuracy 0.10563333332538605\n",
      "Test set accuracy 0.10539999604225159\n",
      "Epoch 2 in 5.37 sec\n",
      "Training set accuracy 0.11781666427850723\n",
      "Test set accuracy 0.12159999459981918\n",
      "Epoch 3 in 4.92 sec\n",
      "Training set accuracy 0.1303500086069107\n",
      "Test set accuracy 0.13529999554157257\n",
      "Epoch 4 in 4.43 sec\n",
      "Training set accuracy 0.14176666736602783\n",
      "Test set accuracy 0.14509999752044678\n",
      "Epoch 5 in 6.44 sec\n",
      "Training set accuracy 0.15415000915527344\n",
      "Test set accuracy 0.15919999778270721\n",
      "Epoch 6 in 4.64 sec\n",
      "Training set accuracy 0.16448333859443665\n",
      "Test set accuracy 0.1688999980688095\n",
      "Epoch 7 in 5.80 sec\n",
      "Training set accuracy 0.17523333430290222\n",
      "Test set accuracy 0.18129999935626984\n",
      "Epoch 8 in 4.89 sec\n",
      "Training set accuracy 0.18434999883174896\n",
      "Test set accuracy 0.18869999051094055\n",
      "Epoch 9 in 4.74 sec\n",
      "Training set accuracy 0.1926666647195816\n",
      "Test set accuracy 0.20149999856948853\n",
      "Epoch 10 in 5.09 sec\n",
      "Training set accuracy 0.2007666677236557\n",
      "Test set accuracy 0.20909999310970306\n",
      "Epoch 11 in 4.46 sec\n",
      "Training set accuracy 0.2080666720867157\n",
      "Test set accuracy 0.21729999780654907\n",
      "Epoch 12 in 5.34 sec\n",
      "Training set accuracy 0.21511666476726532\n",
      "Test set accuracy 0.2255999892950058\n",
      "Epoch 13 in 4.53 sec\n",
      "Training set accuracy 0.2220333367586136\n",
      "Test set accuracy 0.23389999568462372\n",
      "Epoch 14 in 4.78 sec\n",
      "Training set accuracy 0.2287999987602234\n",
      "Test set accuracy 0.2410999983549118\n",
      "Epoch 15 in 5.07 sec\n",
      "Training set accuracy 0.23565000295639038\n",
      "Test set accuracy 0.24849998950958252\n",
      "Epoch 16 in 4.52 sec\n",
      "Training set accuracy 0.2424333393573761\n",
      "Test set accuracy 0.25609999895095825\n",
      "Epoch 17 in 5.27 sec\n",
      "Training set accuracy 0.2492000013589859\n",
      "Test set accuracy 0.2628999948501587\n",
      "Epoch 18 in 4.62 sec\n",
      "Training set accuracy 0.2554333508014679\n",
      "Test set accuracy 0.2703999876976013\n",
      "Epoch 19 in 4.87 sec\n",
      "Training set accuracy 0.26213333010673523\n",
      "Test set accuracy 0.2784000039100647\n",
      "Epoch 20 in 4.83 sec\n",
      "Training set accuracy 0.26856666803359985\n",
      "Test set accuracy 0.28439998626708984\n",
      "Epoch 21 in 4.50 sec\n",
      "Training set accuracy 0.274316668510437\n",
      "Test set accuracy 0.2913999855518341\n",
      "Epoch 22 in 5.16 sec\n",
      "Training set accuracy 0.281083345413208\n",
      "Test set accuracy 0.2976999878883362\n",
      "Epoch 23 in 4.58 sec\n",
      "Training set accuracy 0.2864833474159241\n",
      "Test set accuracy 0.30390000343322754\n",
      "Epoch 24 in 4.66 sec\n",
      "Training set accuracy 0.2922833263874054\n",
      "Test set accuracy 0.3093000054359436\n",
      "Epoch 25 in 5.05 sec\n",
      "Training set accuracy 0.29786667227745056\n",
      "Test set accuracy 0.31450000405311584\n",
      "Epoch 26 in 4.57 sec\n",
      "Training set accuracy 0.3030500113964081\n",
      "Test set accuracy 0.31949999928474426\n",
      "Epoch 27 in 5.18 sec\n",
      "Training set accuracy 0.3081166744232178\n",
      "Test set accuracy 0.32429999113082886\n",
      "Epoch 28 in 4.55 sec\n",
      "Training set accuracy 0.3138333261013031\n",
      "Test set accuracy 0.3296000063419342\n",
      "Epoch 29 in 4.61 sec\n",
      "Training set accuracy 0.3188333511352539\n",
      "Test set accuracy 0.33469998836517334\n",
      "Epoch 30 in 5.20 sec\n",
      "Training set accuracy 0.32394999265670776\n",
      "Test set accuracy 0.3392999768257141\n",
      "Epoch 31 in 4.83 sec\n",
      "Training set accuracy 0.3284499943256378\n",
      "Test set accuracy 0.34360000491142273\n",
      "Epoch 32 in 5.19 sec\n",
      "Training set accuracy 0.33303332328796387\n",
      "Test set accuracy 0.3488999903202057\n",
      "Epoch 33 in 4.53 sec\n",
      "Training set accuracy 0.33703333139419556\n",
      "Test set accuracy 0.35249999165534973\n",
      "Epoch 34 in 4.49 sec\n",
      "Training set accuracy 0.3413499891757965\n",
      "Test set accuracy 0.3572999835014343\n",
      "Epoch 35 in 5.26 sec\n",
      "Training set accuracy 0.34531667828559875\n",
      "Test set accuracy 0.36159998178482056\n",
      "Epoch 36 in 4.46 sec\n",
      "Training set accuracy 0.34931665658950806\n",
      "Test set accuracy 0.3652999997138977\n",
      "Epoch 37 in 5.27 sec\n",
      "Training set accuracy 0.3525499999523163\n",
      "Test set accuracy 0.37070000171661377\n",
      "Epoch 38 in 4.56 sec\n",
      "Training set accuracy 0.356550008058548\n",
      "Test set accuracy 0.37379997968673706\n",
      "Epoch 39 in 4.74 sec\n",
      "Training set accuracy 0.3606833517551422\n",
      "Test set accuracy 0.376800000667572\n",
      "Epoch 40 in 5.35 sec\n",
      "Training set accuracy 0.36410000920295715\n",
      "Test set accuracy 0.38029998540878296\n",
      "Epoch 41 in 4.57 sec\n",
      "Training set accuracy 0.3671500086784363\n",
      "Test set accuracy 0.3831000030040741\n",
      "Epoch 42 in 5.43 sec\n",
      "Training set accuracy 0.37105000019073486\n",
      "Test set accuracy 0.3865000009536743\n",
      "Epoch 43 in 4.51 sec\n",
      "Training set accuracy 0.3744833469390869\n",
      "Test set accuracy 0.39069998264312744\n",
      "Epoch 44 in 5.28 sec\n",
      "Training set accuracy 0.37751665711402893\n",
      "Test set accuracy 0.39479997754096985\n",
      "Epoch 45 in 4.78 sec\n",
      "Training set accuracy 0.38013333082199097\n",
      "Test set accuracy 0.398499995470047\n",
      "Epoch 46 in 4.60 sec\n",
      "Training set accuracy 0.38333332538604736\n",
      "Test set accuracy 0.4007999897003174\n",
      "Epoch 47 in 5.25 sec\n",
      "Training set accuracy 0.3860500156879425\n",
      "Test set accuracy 0.4043999910354614\n",
      "Epoch 48 in 4.52 sec\n",
      "Training set accuracy 0.38936665654182434\n",
      "Test set accuracy 0.406499981880188\n",
      "Epoch 49 in 4.96 sec\n",
      "Training set accuracy 0.3920833468437195\n",
      "Test set accuracy 0.41019999980926514\n",
      "Epoch 50 in 4.82 sec\n",
      "Training set accuracy 0.3945833444595337\n",
      "Test set accuracy 0.4122999906539917\n",
      "Epoch 51 in 4.62 sec\n",
      "Training set accuracy 0.397433340549469\n",
      "Test set accuracy 0.4153999984264374\n",
      "Epoch 52 in 5.20 sec\n",
      "Training set accuracy 0.400133341550827\n",
      "Test set accuracy 0.4169999957084656\n",
      "Epoch 53 in 4.56 sec\n",
      "Training set accuracy 0.4029333293437958\n",
      "Test set accuracy 0.4193999767303467\n",
      "Epoch 54 in 4.88 sec\n",
      "Training set accuracy 0.4053833484649658\n",
      "Test set accuracy 0.42179998755455017\n",
      "Epoch 55 in 4.97 sec\n",
      "Training set accuracy 0.4075666666030884\n",
      "Test set accuracy 0.4242999851703644\n",
      "Epoch 56 in 4.69 sec\n",
      "Training set accuracy 0.40960001945495605\n",
      "Test set accuracy 0.42639997601509094\n",
      "Epoch 57 in 5.34 sec\n",
      "Training set accuracy 0.4121333360671997\n",
      "Test set accuracy 0.42890000343322754\n",
      "Epoch 58 in 4.63 sec\n",
      "Training set accuracy 0.4146000146865845\n",
      "Test set accuracy 0.43149998784065247\n",
      "Epoch 59 in 4.91 sec\n",
      "Training set accuracy 0.41714999079704285\n",
      "Test set accuracy 0.4348999857902527\n",
      "Epoch 60 in 4.82 sec\n",
      "Training set accuracy 0.4192333519458771\n",
      "Test set accuracy 0.43709999322891235\n",
      "Epoch 61 in 4.48 sec\n",
      "Training set accuracy 0.4213166832923889\n",
      "Test set accuracy 0.44029998779296875\n",
      "Epoch 62 in 5.38 sec\n",
      "Training set accuracy 0.4233500063419342\n",
      "Test set accuracy 0.44189998507499695\n",
      "Epoch 63 in 4.58 sec\n",
      "Training set accuracy 0.4252166748046875\n",
      "Test set accuracy 0.4438999891281128\n",
      "Epoch 64 in 5.12 sec\n",
      "Training set accuracy 0.4272000193595886\n",
      "Test set accuracy 0.4448999762535095\n",
      "Epoch 65 in 4.71 sec\n",
      "Training set accuracy 0.42891666293144226\n",
      "Test set accuracy 0.4472000002861023\n",
      "Epoch 66 in 4.43 sec\n",
      "Training set accuracy 0.4310833513736725\n",
      "Test set accuracy 0.44909998774528503\n",
      "Epoch 67 in 5.38 sec\n",
      "Training set accuracy 0.4331166744232178\n",
      "Test set accuracy 0.4505999982357025\n",
      "Epoch 68 in 4.57 sec\n",
      "Training set accuracy 0.4351166784763336\n",
      "Test set accuracy 0.4526999890804291\n",
      "Epoch 69 in 5.09 sec\n",
      "Training set accuracy 0.4370666742324829\n",
      "Test set accuracy 0.4545999765396118\n",
      "Epoch 70 in 4.80 sec\n",
      "Training set accuracy 0.43880000710487366\n",
      "Test set accuracy 0.4560000002384186\n",
      "Epoch 71 in 4.65 sec\n",
      "Training set accuracy 0.4406000077724457\n",
      "Test set accuracy 0.45739999413490295\n",
      "Epoch 72 in 5.30 sec\n",
      "Training set accuracy 0.4424166679382324\n",
      "Test set accuracy 0.45889997482299805\n",
      "Epoch 73 in 4.50 sec\n",
      "Training set accuracy 0.44405001401901245\n",
      "Test set accuracy 0.461899995803833\n",
      "Epoch 74 in 5.33 sec\n",
      "Training set accuracy 0.4458666741847992\n",
      "Test set accuracy 0.4634999930858612\n",
      "Epoch 75 in 4.52 sec\n",
      "Training set accuracy 0.44768333435058594\n",
      "Test set accuracy 0.46629998087882996\n",
      "Epoch 76 in 4.59 sec\n",
      "Training set accuracy 0.44946667551994324\n",
      "Test set accuracy 0.4673999845981598\n",
      "Epoch 77 in 5.25 sec\n",
      "Training set accuracy 0.4511333405971527\n",
      "Test set accuracy 0.46859997510910034\n",
      "Epoch 78 in 4.61 sec\n",
      "Training set accuracy 0.4527166783809662\n",
      "Test set accuracy 0.4699999988079071\n",
      "Epoch 79 in 5.25 sec\n",
      "Training set accuracy 0.45419999957084656\n",
      "Test set accuracy 0.471699982881546\n",
      "Epoch 80 in 4.53 sec\n",
      "Training set accuracy 0.45553332567214966\n",
      "Test set accuracy 0.47279998660087585\n",
      "Epoch 81 in 4.64 sec\n",
      "Training set accuracy 0.45695000886917114\n",
      "Test set accuracy 0.4737999737262726\n",
      "Epoch 82 in 5.12 sec\n",
      "Training set accuracy 0.4584500193595886\n",
      "Test set accuracy 0.47519999742507935\n",
      "Epoch 83 in 4.73 sec\n",
      "Training set accuracy 0.46026667952537537\n",
      "Test set accuracy 0.4764999747276306\n",
      "Epoch 84 in 5.20 sec\n",
      "Training set accuracy 0.46183332800865173\n",
      "Test set accuracy 0.47689998149871826\n",
      "Epoch 85 in 4.53 sec\n",
      "Training set accuracy 0.46334999799728394\n",
      "Test set accuracy 0.47859999537467957\n",
      "Epoch 86 in 4.54 sec\n",
      "Training set accuracy 0.46470001339912415\n",
      "Test set accuracy 0.4802999794483185\n",
      "Epoch 87 in 5.18 sec\n",
      "Training set accuracy 0.4666166603565216\n",
      "Test set accuracy 0.48159998655319214\n",
      "Epoch 88 in 4.54 sec\n",
      "Training set accuracy 0.467766672372818\n",
      "Test set accuracy 0.4834999740123749\n",
      "Epoch 89 in 5.09 sec\n",
      "Training set accuracy 0.4690166711807251\n",
      "Test set accuracy 0.48420000076293945\n",
      "Epoch 90 in 4.72 sec\n",
      "Training set accuracy 0.4708999991416931\n",
      "Test set accuracy 0.4851999878883362\n",
      "Epoch 91 in 4.56 sec\n",
      "Training set accuracy 0.4720500111579895\n",
      "Test set accuracy 0.4869999885559082\n",
      "Epoch 92 in 5.29 sec\n",
      "Training set accuracy 0.47335001826286316\n",
      "Test set accuracy 0.4884999990463257\n",
      "Epoch 93 in 4.54 sec\n",
      "Training set accuracy 0.474783331155777\n",
      "Test set accuracy 0.48969998955726624\n",
      "Epoch 94 in 5.15 sec\n",
      "Training set accuracy 0.4760333299636841\n",
      "Test set accuracy 0.4908999800682068\n",
      "Epoch 95 in 4.63 sec\n",
      "Training set accuracy 0.47718334197998047\n",
      "Test set accuracy 0.4925999939441681\n",
      "Epoch 96 in 4.59 sec\n",
      "Training set accuracy 0.4784500002861023\n",
      "Test set accuracy 0.493399977684021\n",
      "Epoch 97 in 5.26 sec\n",
      "Training set accuracy 0.4799500107765198\n",
      "Test set accuracy 0.49539998173713684\n",
      "Epoch 98 in 4.44 sec\n",
      "Training set accuracy 0.48091667890548706\n",
      "Test set accuracy 0.49629998207092285\n",
      "Epoch 99 in 5.21 sec\n",
      "Training set accuracy 0.48240000009536743\n",
      "Test set accuracy 0.4973999857902527\n",
      "Epoch 100 in 4.57 sec\n",
      "Training set accuracy 0.4837999939918518\n",
      "Test set accuracy 0.4983999729156494\n",
      "Epoch 101 in 4.53 sec\n",
      "Training set accuracy 0.48501667380332947\n",
      "Test set accuracy 0.4992999732494354\n",
      "Epoch 102 in 5.28 sec\n",
      "Training set accuracy 0.48643332719802856\n",
      "Test set accuracy 0.5008000135421753\n",
      "Epoch 103 in 4.47 sec\n",
      "Training set accuracy 0.4876333475112915\n",
      "Test set accuracy 0.5015000104904175\n",
      "Epoch 104 in 5.03 sec\n",
      "Training set accuracy 0.48890000581741333\n",
      "Test set accuracy 0.5026000142097473\n",
      "Epoch 105 in 4.68 sec\n",
      "Training set accuracy 0.48998335003852844\n",
      "Test set accuracy 0.5033999681472778\n",
      "Epoch 106 in 4.66 sec\n",
      "Training set accuracy 0.4910833239555359\n",
      "Test set accuracy 0.5040000081062317\n",
      "Epoch 107 in 5.25 sec\n",
      "Training set accuracy 0.49203333258628845\n",
      "Test set accuracy 0.5047999620437622\n",
      "Epoch 108 in 4.63 sec\n",
      "Training set accuracy 0.4931666851043701\n",
      "Test set accuracy 0.5055999755859375\n",
      "Epoch 109 in 5.12 sec\n",
      "Training set accuracy 0.4944666624069214\n",
      "Test set accuracy 0.5069999694824219\n",
      "Epoch 110 in 4.76 sec\n",
      "Training set accuracy 0.49586668610572815\n",
      "Test set accuracy 0.5080999732017517\n",
      "Epoch 111 in 4.54 sec\n",
      "Training set accuracy 0.49709999561309814\n",
      "Test set accuracy 0.5095999836921692\n",
      "Epoch 112 in 5.10 sec\n",
      "Training set accuracy 0.4982333481311798\n",
      "Test set accuracy 0.5108999609947205\n",
      "Epoch 113 in 4.69 sec\n",
      "Training set accuracy 0.49961668252944946\n",
      "Test set accuracy 0.5119999647140503\n",
      "Epoch 114 in 4.93 sec\n",
      "Training set accuracy 0.5005000233650208\n",
      "Test set accuracy 0.5130000114440918\n",
      "Epoch 115 in 4.75 sec\n",
      "Training set accuracy 0.5016499757766724\n",
      "Test set accuracy 0.51419997215271\n",
      "Epoch 116 in 4.49 sec\n",
      "Training set accuracy 0.5024833679199219\n",
      "Test set accuracy 0.5148999691009521\n",
      "Epoch 117 in 5.23 sec\n",
      "Training set accuracy 0.5039499998092651\n",
      "Test set accuracy 0.5159000158309937\n",
      "Epoch 118 in 4.53 sec\n",
      "Training set accuracy 0.5052499771118164\n",
      "Test set accuracy 0.5169999599456787\n",
      "Epoch 119 in 4.89 sec\n",
      "Training set accuracy 0.5062000155448914\n",
      "Test set accuracy 0.517799973487854\n",
      "Epoch 120 in 4.90 sec\n",
      "Training set accuracy 0.5072500109672546\n",
      "Test set accuracy 0.5188999772071838\n",
      "Epoch 121 in 4.60 sec\n",
      "Training set accuracy 0.5079833269119263\n",
      "Test set accuracy 0.5198000073432922\n",
      "Epoch 122 in 5.26 sec\n",
      "Training set accuracy 0.5091166496276855\n",
      "Test set accuracy 0.5205999612808228\n",
      "Epoch 123 in 4.51 sec\n",
      "Training set accuracy 0.5101000070571899\n",
      "Test set accuracy 0.5218999981880188\n",
      "Epoch 124 in 4.95 sec\n",
      "Training set accuracy 0.5112833380699158\n",
      "Test set accuracy 0.5223000049591064\n",
      "Epoch 125 in 4.85 sec\n",
      "Training set accuracy 0.5123500227928162\n",
      "Test set accuracy 0.5231999754905701\n",
      "Epoch 126 in 4.64 sec\n",
      "Training set accuracy 0.5134166479110718\n",
      "Test set accuracy 0.5241999626159668\n",
      "Epoch 127 in 5.27 sec\n",
      "Training set accuracy 0.5143333673477173\n",
      "Test set accuracy 0.5250999927520752\n",
      "Epoch 128 in 4.59 sec\n",
      "Training set accuracy 0.5153666734695435\n",
      "Test set accuracy 0.5259000062942505\n",
      "Epoch 129 in 4.97 sec\n",
      "Training set accuracy 0.5165166854858398\n",
      "Test set accuracy 0.526199996471405\n",
      "Epoch 130 in 4.81 sec\n",
      "Training set accuracy 0.5177666544914246\n",
      "Test set accuracy 0.5268999934196472\n",
      "Epoch 131 in 4.67 sec\n",
      "Training set accuracy 0.5187667012214661\n",
      "Test set accuracy 0.528499960899353\n",
      "Epoch 132 in 5.26 sec\n",
      "Training set accuracy 0.5196833610534668\n",
      "Test set accuracy 0.529699981212616\n",
      "Epoch 133 in 4.63 sec\n",
      "Training set accuracy 0.5208333134651184\n",
      "Test set accuracy 0.5307999849319458\n",
      "Epoch 134 in 5.26 sec\n",
      "Training set accuracy 0.5216666460037231\n",
      "Test set accuracy 0.5318999886512756\n",
      "Epoch 135 in 4.56 sec\n",
      "Training set accuracy 0.5227167010307312\n",
      "Test set accuracy 0.5321999788284302\n",
      "Epoch 136 in 4.55 sec\n",
      "Training set accuracy 0.5234666466712952\n",
      "Test set accuracy 0.5328999757766724\n",
      "Epoch 137 in 5.23 sec\n",
      "Training set accuracy 0.5243333578109741\n",
      "Test set accuracy 0.5339999794960022\n",
      "Epoch 138 in 4.59 sec\n",
      "Training set accuracy 0.5250666737556458\n",
      "Test set accuracy 0.5347999930381775\n",
      "Epoch 139 in 4.89 sec\n",
      "Training set accuracy 0.526116669178009\n",
      "Test set accuracy 0.5356999635696411\n",
      "Epoch 140 in 4.87 sec\n",
      "Training set accuracy 0.5270166993141174\n",
      "Test set accuracy 0.5365999937057495\n",
      "Epoch 141 in 4.58 sec\n",
      "Training set accuracy 0.5277000069618225\n",
      "Test set accuracy 0.5370000004768372\n",
      "Epoch 142 in 5.23 sec\n",
      "Training set accuracy 0.5284667015075684\n",
      "Test set accuracy 0.5376999974250793\n",
      "Epoch 143 in 4.62 sec\n",
      "Training set accuracy 0.5293166637420654\n",
      "Test set accuracy 0.5392000079154968\n",
      "Epoch 144 in 4.81 sec\n",
      "Training set accuracy 0.5302667021751404\n",
      "Test set accuracy 0.5396999716758728\n",
      "Epoch 145 in 4.82 sec\n",
      "Training set accuracy 0.5309333205223083\n",
      "Test set accuracy 0.539900004863739\n",
      "Epoch 146 in 4.50 sec\n",
      "Training set accuracy 0.5318000316619873\n",
      "Test set accuracy 0.5408999919891357\n",
      "Epoch 147 in 5.37 sec\n",
      "Training set accuracy 0.5324167013168335\n",
      "Test set accuracy 0.5415999889373779\n",
      "Epoch 148 in 4.40 sec\n",
      "Training set accuracy 0.5331666469573975\n",
      "Test set accuracy 0.542199969291687\n",
      "Epoch 149 in 4.81 sec\n",
      "Training set accuracy 0.5340499877929688\n",
      "Test set accuracy 0.5432000160217285\n",
      "Epoch 150 in 4.96 sec\n",
      "Training set accuracy 0.5349000096321106\n",
      "Test set accuracy 0.5436999797821045\n",
      "Epoch 151 in 4.47 sec\n",
      "Training set accuracy 0.5354499816894531\n",
      "Test set accuracy 0.5443999767303467\n",
      "Epoch 152 in 5.23 sec\n",
      "Training set accuracy 0.5364333391189575\n",
      "Test set accuracy 0.5455999970436096\n",
      "Epoch 153 in 4.45 sec\n",
      "Training set accuracy 0.5372333526611328\n",
      "Test set accuracy 0.5467999577522278\n",
      "Epoch 154 in 4.80 sec\n",
      "Training set accuracy 0.5381667017936707\n",
      "Test set accuracy 0.5475000143051147\n",
      "Epoch 155 in 4.89 sec\n",
      "Training set accuracy 0.5390000343322754\n",
      "Test set accuracy 0.5483999848365784\n",
      "Epoch 156 in 4.57 sec\n",
      "Training set accuracy 0.5398833155632019\n",
      "Test set accuracy 0.5489000082015991\n",
      "Epoch 157 in 5.32 sec\n",
      "Training set accuracy 0.5406833291053772\n",
      "Test set accuracy 0.5493000149726868\n",
      "Epoch 158 in 4.47 sec\n",
      "Training set accuracy 0.5415833592414856\n",
      "Test set accuracy 0.5496999621391296\n",
      "Epoch 159 in 4.72 sec\n",
      "Training set accuracy 0.5423333644866943\n",
      "Test set accuracy 0.5512999892234802\n",
      "Epoch 160 in 5.14 sec\n",
      "Training set accuracy 0.543150007724762\n",
      "Test set accuracy 0.551800012588501\n",
      "Epoch 161 in 4.51 sec\n",
      "Training set accuracy 0.5438500046730042\n",
      "Test set accuracy 0.552899956703186\n",
      "Epoch 162 in 5.31 sec\n",
      "Training set accuracy 0.5446500182151794\n",
      "Test set accuracy 0.553600013256073\n",
      "Epoch 163 in 4.58 sec\n",
      "Training set accuracy 0.5452499985694885\n",
      "Test set accuracy 0.5552999973297119\n",
      "Epoch 164 in 4.52 sec\n",
      "Training set accuracy 0.5460000038146973\n",
      "Test set accuracy 0.5565999746322632\n",
      "Epoch 165 in 5.13 sec\n",
      "Training set accuracy 0.546750009059906\n",
      "Test set accuracy 0.5569999814033508\n",
      "Epoch 166 in 4.58 sec\n",
      "Training set accuracy 0.5473999977111816\n",
      "Test set accuracy 0.557200014591217\n",
      "Epoch 167 in 5.13 sec\n",
      "Training set accuracy 0.54830002784729\n",
      "Test set accuracy 0.557699978351593\n",
      "Epoch 168 in 4.55 sec\n",
      "Training set accuracy 0.5488166809082031\n",
      "Test set accuracy 0.5583999752998352\n",
      "Epoch 169 in 4.51 sec\n",
      "Training set accuracy 0.5497833490371704\n",
      "Test set accuracy 0.5591999888420105\n",
      "Epoch 170 in 5.19 sec\n",
      "Training set accuracy 0.5503833293914795\n",
      "Test set accuracy 0.5597999691963196\n",
      "Epoch 171 in 4.45 sec\n",
      "Training set accuracy 0.5509666800498962\n",
      "Test set accuracy 0.5597000122070312\n",
      "Epoch 172 in 5.26 sec\n",
      "Training set accuracy 0.5516166687011719\n",
      "Test set accuracy 0.5605999827384949\n",
      "Epoch 173 in 4.72 sec\n",
      "Training set accuracy 0.5524666905403137\n",
      "Test set accuracy 0.5615999698638916\n",
      "Epoch 174 in 4.64 sec\n",
      "Training set accuracy 0.5531333684921265\n",
      "Test set accuracy 0.562999963760376\n",
      "Epoch 175 in 5.19 sec\n",
      "Training set accuracy 0.5537499785423279\n",
      "Test set accuracy 0.5634999871253967\n",
      "Epoch 176 in 4.49 sec\n",
      "Training set accuracy 0.5544000267982483\n",
      "Test set accuracy 0.5641999840736389\n",
      "Epoch 177 in 5.24 sec\n",
      "Training set accuracy 0.5551666617393494\n",
      "Test set accuracy 0.5649999976158142\n",
      "Epoch 178 in 4.53 sec\n",
      "Training set accuracy 0.5558000206947327\n",
      "Test set accuracy 0.5658999681472778\n",
      "Epoch 179 in 4.60 sec\n",
      "Training set accuracy 0.5565333366394043\n",
      "Test set accuracy 0.5672000050544739\n",
      "Epoch 180 in 5.13 sec\n",
      "Training set accuracy 0.557116687297821\n",
      "Test set accuracy 0.5676000118255615\n",
      "Epoch 181 in 4.60 sec\n",
      "Training set accuracy 0.5578166842460632\n",
      "Test set accuracy 0.5688999891281128\n",
      "Epoch 182 in 5.34 sec\n",
      "Training set accuracy 0.5582833290100098\n",
      "Test set accuracy 0.5692999958992004\n",
      "Epoch 183 in 4.45 sec\n",
      "Training set accuracy 0.5590333342552185\n",
      "Test set accuracy 0.5703999996185303\n",
      "Epoch 184 in 4.57 sec\n",
      "Training set accuracy 0.5597000122070312\n",
      "Test set accuracy 0.5715000033378601\n",
      "Epoch 185 in 5.11 sec\n",
      "Training set accuracy 0.5601833462715149\n",
      "Test set accuracy 0.5719999670982361\n",
      "Epoch 186 in 4.66 sec\n",
      "Training set accuracy 0.5607166886329651\n",
      "Test set accuracy 0.5724999904632568\n",
      "Epoch 187 in 5.27 sec\n",
      "Training set accuracy 0.5615333318710327\n",
      "Test set accuracy 0.573199987411499\n",
      "Epoch 188 in 4.56 sec\n",
      "Training set accuracy 0.5620666742324829\n",
      "Test set accuracy 0.5735999941825867\n",
      "Epoch 189 in 4.61 sec\n",
      "Training set accuracy 0.5624499917030334\n",
      "Test set accuracy 0.5742999911308289\n",
      "Epoch 190 in 5.26 sec\n",
      "Training set accuracy 0.5631166696548462\n",
      "Test set accuracy 0.5744999647140503\n",
      "Epoch 191 in 4.63 sec\n",
      "Training set accuracy 0.5635833144187927\n",
      "Test set accuracy 0.5748000144958496\n",
      "Epoch 192 in 5.23 sec\n",
      "Training set accuracy 0.5639333128929138\n",
      "Test set accuracy 0.5758000016212463\n",
      "Epoch 193 in 4.69 sec\n",
      "Training set accuracy 0.5643333196640015\n",
      "Test set accuracy 0.576200008392334\n",
      "Epoch 194 in 4.66 sec\n",
      "Training set accuracy 0.5648166537284851\n",
      "Test set accuracy 0.5769000053405762\n",
      "Epoch 195 in 5.09 sec\n",
      "Training set accuracy 0.5655333399772644\n",
      "Test set accuracy 0.5777999758720398\n",
      "Epoch 196 in 4.52 sec\n",
      "Training set accuracy 0.5660833120346069\n",
      "Test set accuracy 0.5776999592781067\n",
      "Epoch 197 in 5.26 sec\n",
      "Training set accuracy 0.5664666891098022\n",
      "Test set accuracy 0.5778999924659729\n",
      "Epoch 198 in 4.51 sec\n",
      "Training set accuracy 0.5672500133514404\n",
      "Test set accuracy 0.5789999961853027\n",
      "Epoch 199 in 4.82 sec\n",
      "Training set accuracy 0.5679666996002197\n",
      "Test set accuracy 0.5798999667167664\n",
      "Epoch 200 in 5.06 sec\n",
      "Training set accuracy 0.5686500072479248\n",
      "Test set accuracy 0.5800999999046326\n",
      "Epoch 201 in 4.41 sec\n",
      "Training set accuracy 0.5692166686058044\n",
      "Test set accuracy 0.5800999999046326\n",
      "Epoch 202 in 5.26 sec\n",
      "Training set accuracy 0.5697000026702881\n",
      "Test set accuracy 0.5810999870300293\n",
      "Epoch 203 in 4.47 sec\n",
      "Training set accuracy 0.5704333186149597\n",
      "Test set accuracy 0.5813999772071838\n",
      "Epoch 204 in 4.83 sec\n",
      "Training set accuracy 0.571233332157135\n",
      "Test set accuracy 0.5821999907493591\n",
      "Epoch 205 in 5.10 sec\n",
      "Training set accuracy 0.5718166828155518\n",
      "Test set accuracy 0.5828999876976013\n",
      "Epoch 206 in 4.45 sec\n",
      "Training set accuracy 0.5724666714668274\n",
      "Test set accuracy 0.5837999582290649\n",
      "Epoch 207 in 5.36 sec\n",
      "Training set accuracy 0.5730166435241699\n",
      "Test set accuracy 0.5845000147819519\n",
      "Epoch 208 in 4.49 sec\n",
      "Training set accuracy 0.5734833478927612\n",
      "Test set accuracy 0.5849999785423279\n",
      "Epoch 209 in 4.66 sec\n",
      "Training set accuracy 0.5740166902542114\n",
      "Test set accuracy 0.5852999687194824\n",
      "Epoch 210 in 5.03 sec\n",
      "Training set accuracy 0.5744666457176208\n",
      "Test set accuracy 0.585599958896637\n",
      "Epoch 211 in 4.63 sec\n",
      "Training set accuracy 0.574916660785675\n",
      "Test set accuracy 0.5864999890327454\n",
      "Epoch 212 in 5.44 sec\n",
      "Training set accuracy 0.5754666924476624\n",
      "Test set accuracy 0.5871999859809875\n",
      "Epoch 213 in 4.62 sec\n",
      "Training set accuracy 0.5759833455085754\n",
      "Test set accuracy 0.5877000093460083\n",
      "Epoch 214 in 4.74 sec\n",
      "Training set accuracy 0.5766333341598511\n",
      "Test set accuracy 0.5881999731063843\n",
      "Epoch 215 in 4.98 sec\n",
      "Training set accuracy 0.5772833228111267\n",
      "Test set accuracy 0.5888999700546265\n",
      "Epoch 216 in 4.59 sec\n",
      "Training set accuracy 0.5776166915893555\n",
      "Test set accuracy 0.5888000130653381\n",
      "Epoch 217 in 5.20 sec\n",
      "Training set accuracy 0.5780666470527649\n",
      "Test set accuracy 0.5892999768257141\n",
      "Epoch 218 in 4.62 sec\n",
      "Training set accuracy 0.5786833167076111\n",
      "Test set accuracy 0.589199960231781\n",
      "Epoch 219 in 4.61 sec\n",
      "Training set accuracy 0.5791333317756653\n",
      "Test set accuracy 0.5896999835968018\n",
      "Epoch 220 in 5.16 sec\n",
      "Training set accuracy 0.5795666575431824\n",
      "Test set accuracy 0.590399980545044\n",
      "Epoch 221 in 4.62 sec\n",
      "Training set accuracy 0.5801500082015991\n",
      "Test set accuracy 0.5909000039100647\n",
      "Epoch 222 in 5.24 sec\n",
      "Training set accuracy 0.5806666612625122\n",
      "Test set accuracy 0.5911999940872192\n",
      "Epoch 223 in 4.58 sec\n",
      "Training set accuracy 0.5810333490371704\n",
      "Test set accuracy 0.5914999842643738\n",
      "Epoch 224 in 4.93 sec\n",
      "Training set accuracy 0.5816166996955872\n",
      "Test set accuracy 0.5920999646186829\n",
      "Epoch 225 in 5.20 sec\n",
      "Training set accuracy 0.5821666717529297\n",
      "Test set accuracy 0.5920000076293945\n",
      "Epoch 226 in 4.43 sec\n",
      "Training set accuracy 0.5824833512306213\n",
      "Test set accuracy 0.5924999713897705\n",
      "Epoch 227 in 5.32 sec\n",
      "Training set accuracy 0.5827500224113464\n",
      "Test set accuracy 0.5920999646186829\n",
      "Epoch 228 in 4.52 sec\n",
      "Training set accuracy 0.5834000110626221\n",
      "Test set accuracy 0.5924999713897705\n",
      "Epoch 229 in 4.82 sec\n",
      "Training set accuracy 0.5839666724205017\n",
      "Test set accuracy 0.5931999683380127\n",
      "Epoch 230 in 4.91 sec\n",
      "Training set accuracy 0.584600031375885\n",
      "Test set accuracy 0.5934000015258789\n",
      "Epoch 231 in 4.51 sec\n",
      "Training set accuracy 0.5851500034332275\n",
      "Test set accuracy 0.5940999984741211\n",
      "Epoch 232 in 5.35 sec\n",
      "Training set accuracy 0.5855000019073486\n",
      "Test set accuracy 0.5947999954223633\n",
      "Epoch 233 in 4.44 sec\n",
      "Training set accuracy 0.5860666632652283\n",
      "Test set accuracy 0.5952999591827393\n",
      "Epoch 234 in 4.90 sec\n",
      "Training set accuracy 0.5866000056266785\n",
      "Test set accuracy 0.5961999893188477\n",
      "Epoch 235 in 4.78 sec\n",
      "Training set accuracy 0.5871833562850952\n",
      "Test set accuracy 0.5961999893188477\n",
      "Epoch 236 in 4.61 sec\n",
      "Training set accuracy 0.5877666473388672\n",
      "Test set accuracy 0.5970999598503113\n",
      "Epoch 237 in 5.34 sec\n",
      "Training set accuracy 0.5880166888237\n",
      "Test set accuracy 0.5977999567985535\n",
      "Epoch 238 in 4.64 sec\n",
      "Training set accuracy 0.5884666442871094\n",
      "Test set accuracy 0.597599983215332\n",
      "Epoch 239 in 4.99 sec\n",
      "Training set accuracy 0.5888333320617676\n",
      "Test set accuracy 0.5983999967575073\n",
      "Epoch 240 in 4.77 sec\n",
      "Training set accuracy 0.5895000100135803\n",
      "Test set accuracy 0.5988999605178833\n",
      "Epoch 241 in 4.55 sec\n",
      "Training set accuracy 0.589983344078064\n",
      "Test set accuracy 0.5992000102996826\n",
      "Epoch 242 in 5.12 sec\n",
      "Training set accuracy 0.590233325958252\n",
      "Test set accuracy 0.5989999771118164\n",
      "Epoch 243 in 4.68 sec\n",
      "Training set accuracy 0.5906500220298767\n",
      "Test set accuracy 0.5995999574661255\n",
      "Epoch 244 in 4.94 sec\n",
      "Training set accuracy 0.5911333560943604\n",
      "Test set accuracy 0.6000999808311462\n",
      "Epoch 245 in 4.82 sec\n",
      "Training set accuracy 0.5918999910354614\n",
      "Test set accuracy 0.6004999876022339\n",
      "Epoch 246 in 4.53 sec\n",
      "Training set accuracy 0.5923833250999451\n",
      "Test set accuracy 0.6014999747276306\n",
      "Epoch 247 in 5.12 sec\n",
      "Training set accuracy 0.5928166508674622\n",
      "Test set accuracy 0.6018999814987183\n",
      "Epoch 248 in 4.59 sec\n",
      "Training set accuracy 0.5931000113487244\n",
      "Test set accuracy 0.6026999950408936\n",
      "Epoch 249 in 4.84 sec\n",
      "Training set accuracy 0.5936999917030334\n",
      "Test set accuracy 0.6031000018119812\n",
      "Epoch 250 in 5.03 sec\n",
      "Training set accuracy 0.5941166877746582\n",
      "Test set accuracy 0.6036999821662903\n",
      "Epoch 251 in 4.66 sec\n",
      "Training set accuracy 0.5945333242416382\n",
      "Test set accuracy 0.6038999557495117\n",
      "Epoch 252 in 5.28 sec\n",
      "Training set accuracy 0.594783365726471\n",
      "Test set accuracy 0.6040999889373779\n",
      "Epoch 253 in 4.57 sec\n",
      "Training set accuracy 0.595216691493988\n",
      "Test set accuracy 0.6040999889373779\n",
      "Epoch 254 in 4.86 sec\n",
      "Training set accuracy 0.5956833362579346\n",
      "Test set accuracy 0.6043999791145325\n",
      "Epoch 255 in 5.07 sec\n",
      "Training set accuracy 0.5960333347320557\n",
      "Test set accuracy 0.604699969291687\n",
      "Epoch 256 in 4.53 sec\n",
      "Training set accuracy 0.5963666439056396\n",
      "Test set accuracy 0.6047999858856201\n",
      "Epoch 257 in 5.31 sec\n",
      "Training set accuracy 0.5968666672706604\n",
      "Test set accuracy 0.6049999594688416\n",
      "Epoch 258 in 4.43 sec\n",
      "Training set accuracy 0.5972833633422852\n",
      "Test set accuracy 0.6053000092506409\n",
      "Epoch 259 in 4.89 sec\n",
      "Training set accuracy 0.5974833369255066\n",
      "Test set accuracy 0.6054999828338623\n",
      "Epoch 260 in 4.97 sec\n",
      "Training set accuracy 0.5976499915122986\n",
      "Test set accuracy 0.6061999797821045\n",
      "Epoch 261 in 4.48 sec\n",
      "Training set accuracy 0.5980499982833862\n",
      "Test set accuracy 0.6067000031471252\n",
      "Epoch 262 in 5.35 sec\n",
      "Training set accuracy 0.5985833406448364\n",
      "Test set accuracy 0.6068999767303467\n",
      "Epoch 263 in 4.41 sec\n",
      "Training set accuracy 0.5989000201225281\n",
      "Test set accuracy 0.6078000068664551\n",
      "Epoch 264 in 5.15 sec\n",
      "Training set accuracy 0.5993166565895081\n",
      "Test set accuracy 0.6078000068664551\n",
      "Epoch 265 in 4.75 sec\n",
      "Training set accuracy 0.5996333360671997\n",
      "Test set accuracy 0.6082000136375427\n",
      "Epoch 266 in 4.59 sec\n",
      "Training set accuracy 0.5999833345413208\n",
      "Test set accuracy 0.6087999939918518\n",
      "Epoch 267 in 5.15 sec\n",
      "Training set accuracy 0.6003333330154419\n",
      "Test set accuracy 0.6092999577522278\n",
      "Epoch 268 in 4.70 sec\n",
      "Training set accuracy 0.6007166504859924\n",
      "Test set accuracy 0.609499990940094\n",
      "Epoch 269 in 5.01 sec\n",
      "Training set accuracy 0.6010666489601135\n",
      "Test set accuracy 0.6097999811172485\n",
      "Epoch 270 in 4.77 sec\n",
      "Training set accuracy 0.6015666723251343\n",
      "Test set accuracy 0.6097999811172485\n",
      "Epoch 271 in 4.61 sec\n",
      "Training set accuracy 0.6020166873931885\n",
      "Test set accuracy 0.6103000044822693\n",
      "Epoch 272 in 5.20 sec\n",
      "Training set accuracy 0.602233350276947\n",
      "Test set accuracy 0.6105999946594238\n",
      "Epoch 273 in 4.63 sec\n",
      "Training set accuracy 0.6026666760444641\n",
      "Test set accuracy 0.6108999848365784\n",
      "Epoch 274 in 4.97 sec\n",
      "Training set accuracy 0.6029666662216187\n",
      "Test set accuracy 0.6107999682426453\n",
      "Epoch 275 in 4.78 sec\n",
      "Training set accuracy 0.6034500002861023\n",
      "Test set accuracy 0.6114999651908875\n",
      "Epoch 276 in 4.58 sec\n",
      "Training set accuracy 0.6038500070571899\n",
      "Test set accuracy 0.6116999983787537\n",
      "Epoch 277 in 5.28 sec\n",
      "Training set accuracy 0.6042667031288147\n",
      "Test set accuracy 0.6121999621391296\n",
      "Epoch 278 in 4.51 sec\n",
      "Training set accuracy 0.6045166850090027\n",
      "Test set accuracy 0.6126999855041504\n",
      "Epoch 279 in 4.70 sec\n",
      "Training set accuracy 0.6049500107765198\n",
      "Test set accuracy 0.6136999726295471\n",
      "Epoch 280 in 4.95 sec\n",
      "Training set accuracy 0.6056666970252991\n",
      "Test set accuracy 0.6140999794006348\n",
      "Epoch 281 in 4.49 sec\n",
      "Training set accuracy 0.606083333492279\n",
      "Test set accuracy 0.6146000027656555\n",
      "Epoch 282 in 5.21 sec\n",
      "Training set accuracy 0.6064500212669373\n",
      "Test set accuracy 0.6146999597549438\n",
      "Epoch 283 in 4.47 sec\n",
      "Training set accuracy 0.6068833470344543\n",
      "Test set accuracy 0.6144999861717224\n",
      "Epoch 284 in 4.81 sec\n",
      "Training set accuracy 0.6071500182151794\n",
      "Test set accuracy 0.6150999665260315\n",
      "Epoch 285 in 5.08 sec\n",
      "Training set accuracy 0.6074000000953674\n",
      "Test set accuracy 0.6155999898910522\n",
      "Epoch 286 in 4.53 sec\n",
      "Training set accuracy 0.607699990272522\n",
      "Test set accuracy 0.6158999800682068\n",
      "Epoch 287 in 5.42 sec\n",
      "Training set accuracy 0.6080666780471802\n",
      "Test set accuracy 0.6162999868392944\n",
      "Epoch 288 in 4.49 sec\n",
      "Training set accuracy 0.6083499789237976\n",
      "Test set accuracy 0.6164000034332275\n",
      "Epoch 289 in 4.96 sec\n",
      "Training set accuracy 0.6087999939918518\n",
      "Test set accuracy 0.616599977016449\n",
      "Epoch 290 in 4.89 sec\n",
      "Training set accuracy 0.6090333461761475\n",
      "Test set accuracy 0.6168000102043152\n",
      "Epoch 291 in 4.49 sec\n",
      "Training set accuracy 0.6094833612442017\n",
      "Test set accuracy 0.6171999573707581\n",
      "Epoch 292 in 5.26 sec\n",
      "Training set accuracy 0.6099666953086853\n",
      "Test set accuracy 0.6176999807357788\n",
      "Epoch 293 in 4.57 sec\n",
      "Training set accuracy 0.6103166937828064\n",
      "Test set accuracy 0.617900013923645\n",
      "Epoch 294 in 4.78 sec\n",
      "Training set accuracy 0.6107833385467529\n",
      "Test set accuracy 0.6186000108718872\n",
      "Epoch 295 in 4.87 sec\n",
      "Training set accuracy 0.6111000180244446\n",
      "Test set accuracy 0.6186000108718872\n",
      "Epoch 296 in 4.54 sec\n",
      "Training set accuracy 0.6113166809082031\n",
      "Test set accuracy 0.6190999746322632\n",
      "Epoch 297 in 5.18 sec\n",
      "Training set accuracy 0.6117166876792908\n",
      "Test set accuracy 0.6197999715805054\n",
      "Epoch 298 in 4.54 sec\n",
      "Training set accuracy 0.6119999885559082\n",
      "Test set accuracy 0.6197999715805054\n",
      "Epoch 299 in 4.84 sec\n",
      "Training set accuracy 0.6123833656311035\n",
      "Test set accuracy 0.6200999617576599\n",
      "Epoch 0 in 4.84 sec\n",
      "Training set accuracy 0.12148333340883255\n",
      "Test set accuracy 0.11809999495744705\n",
      "Epoch 1 in 4.61 sec\n",
      "Training set accuracy 0.14363333582878113\n",
      "Test set accuracy 0.13740000128746033\n",
      "Epoch 2 in 5.17 sec\n",
      "Training set accuracy 0.16243334114551544\n",
      "Test set accuracy 0.15760000050067902\n",
      "Epoch 3 in 4.68 sec\n",
      "Training set accuracy 0.17386667430400848\n",
      "Test set accuracy 0.17109999060630798\n",
      "Epoch 4 in 4.64 sec\n",
      "Training set accuracy 0.17828333377838135\n",
      "Test set accuracy 0.17409999668598175\n",
      "Epoch 5 in 5.06 sec\n",
      "Training set accuracy 0.18140000104904175\n",
      "Test set accuracy 0.17649999260902405\n",
      "Epoch 6 in 4.53 sec\n",
      "Training set accuracy 0.1861666738986969\n",
      "Test set accuracy 0.181099995970726\n",
      "Epoch 7 in 5.20 sec\n",
      "Training set accuracy 0.19144999980926514\n",
      "Test set accuracy 0.18609999120235443\n",
      "Epoch 8 in 4.61 sec\n",
      "Training set accuracy 0.1983499974012375\n",
      "Test set accuracy 0.1931999921798706\n",
      "Epoch 9 in 4.58 sec\n",
      "Training set accuracy 0.2046833336353302\n",
      "Test set accuracy 0.20089998841285706\n",
      "Epoch 10 in 5.02 sec\n",
      "Training set accuracy 0.2120833396911621\n",
      "Test set accuracy 0.20809999108314514\n",
      "Epoch 11 in 4.44 sec\n",
      "Training set accuracy 0.21958333253860474\n",
      "Test set accuracy 0.21409998834133148\n",
      "Epoch 12 in 5.42 sec\n",
      "Training set accuracy 0.22644999623298645\n",
      "Test set accuracy 0.2214999943971634\n",
      "Epoch 13 in 4.50 sec\n",
      "Training set accuracy 0.2324666678905487\n",
      "Test set accuracy 0.22869999706745148\n",
      "Epoch 14 in 4.67 sec\n",
      "Training set accuracy 0.23836666345596313\n",
      "Test set accuracy 0.23359999060630798\n",
      "Epoch 15 in 5.05 sec\n",
      "Training set accuracy 0.24449999630451202\n",
      "Test set accuracy 0.23999999463558197\n",
      "Epoch 16 in 4.51 sec\n",
      "Training set accuracy 0.24968333542346954\n",
      "Test set accuracy 0.24719999730587006\n",
      "Epoch 17 in 5.32 sec\n",
      "Training set accuracy 0.2549833357334137\n",
      "Test set accuracy 0.25200000405311584\n",
      "Epoch 18 in 4.59 sec\n",
      "Training set accuracy 0.259633332490921\n",
      "Test set accuracy 0.25699999928474426\n",
      "Epoch 19 in 4.87 sec\n",
      "Training set accuracy 0.264516681432724\n",
      "Test set accuracy 0.26269999146461487\n",
      "Epoch 20 in 4.89 sec\n",
      "Training set accuracy 0.2691666781902313\n",
      "Test set accuracy 0.2689000070095062\n",
      "Epoch 21 in 4.56 sec\n",
      "Training set accuracy 0.2745499908924103\n",
      "Test set accuracy 0.2744999825954437\n",
      "Epoch 22 in 5.20 sec\n",
      "Training set accuracy 0.27951666712760925\n",
      "Test set accuracy 0.2797999978065491\n",
      "Epoch 23 in 4.58 sec\n",
      "Training set accuracy 0.2839333415031433\n",
      "Test set accuracy 0.2849999964237213\n",
      "Epoch 24 in 4.82 sec\n",
      "Training set accuracy 0.2886333465576172\n",
      "Test set accuracy 0.28949999809265137\n",
      "Epoch 25 in 4.88 sec\n",
      "Training set accuracy 0.29278334975242615\n",
      "Test set accuracy 0.2936999797821045\n",
      "Epoch 26 in 4.60 sec\n",
      "Training set accuracy 0.29741665720939636\n",
      "Test set accuracy 0.29889997839927673\n",
      "Epoch 27 in 5.14 sec\n",
      "Training set accuracy 0.30176666378974915\n",
      "Test set accuracy 0.30230000615119934\n",
      "Epoch 28 in 4.68 sec\n",
      "Training set accuracy 0.30656665563583374\n",
      "Test set accuracy 0.3068999946117401\n",
      "Epoch 29 in 4.67 sec\n",
      "Training set accuracy 0.31033334136009216\n",
      "Test set accuracy 0.31200000643730164\n",
      "Epoch 30 in 5.13 sec\n",
      "Training set accuracy 0.3144000172615051\n",
      "Test set accuracy 0.3149999976158142\n",
      "Epoch 31 in 4.63 sec\n",
      "Training set accuracy 0.31806665658950806\n",
      "Test set accuracy 0.3197000026702881\n",
      "Epoch 32 in 5.22 sec\n",
      "Training set accuracy 0.3224000036716461\n",
      "Test set accuracy 0.3238999843597412\n",
      "Epoch 33 in 4.57 sec\n",
      "Training set accuracy 0.3265666663646698\n",
      "Test set accuracy 0.3271999955177307\n",
      "Epoch 34 in 4.70 sec\n",
      "Training set accuracy 0.3302166759967804\n",
      "Test set accuracy 0.33059999346733093\n",
      "Epoch 35 in 5.04 sec\n",
      "Training set accuracy 0.33328333497047424\n",
      "Test set accuracy 0.3334999978542328\n",
      "Epoch 36 in 4.56 sec\n",
      "Training set accuracy 0.336899995803833\n",
      "Test set accuracy 0.3358999788761139\n",
      "Epoch 37 in 5.29 sec\n",
      "Training set accuracy 0.3398500084877014\n",
      "Test set accuracy 0.33879998326301575\n",
      "Epoch 38 in 4.53 sec\n",
      "Training set accuracy 0.34264999628067017\n",
      "Test set accuracy 0.34360000491142273\n",
      "Epoch 39 in 4.95 sec\n",
      "Training set accuracy 0.3458999991416931\n",
      "Test set accuracy 0.34579998254776\n",
      "Epoch 40 in 4.90 sec\n",
      "Training set accuracy 0.34886667132377625\n",
      "Test set accuracy 0.3482999801635742\n",
      "Epoch 41 in 4.73 sec\n",
      "Training set accuracy 0.3520166575908661\n",
      "Test set accuracy 0.350600004196167\n",
      "Epoch 42 in 5.36 sec\n",
      "Training set accuracy 0.3548166751861572\n",
      "Test set accuracy 0.35409998893737793\n",
      "Epoch 43 in 4.53 sec\n",
      "Training set accuracy 0.3575666844844818\n",
      "Test set accuracy 0.35679998993873596\n",
      "Epoch 44 in 4.97 sec\n",
      "Training set accuracy 0.36028334498405457\n",
      "Test set accuracy 0.36059999465942383\n",
      "Epoch 45 in 4.70 sec\n",
      "Training set accuracy 0.3628000020980835\n",
      "Test set accuracy 0.3628999888896942\n",
      "Epoch 46 in 4.49 sec\n",
      "Training set accuracy 0.3653833270072937\n",
      "Test set accuracy 0.36640000343322754\n",
      "Epoch 47 in 5.23 sec\n",
      "Training set accuracy 0.36808332800865173\n",
      "Test set accuracy 0.3700000047683716\n",
      "Epoch 48 in 4.42 sec\n",
      "Training set accuracy 0.37070000171661377\n",
      "Test set accuracy 0.3725999891757965\n",
      "Epoch 49 in 4.87 sec\n",
      "Training set accuracy 0.37334999442100525\n",
      "Test set accuracy 0.3756999969482422\n",
      "Epoch 50 in 4.83 sec\n",
      "Training set accuracy 0.375983327627182\n",
      "Test set accuracy 0.37869998812675476\n",
      "Epoch 51 in 4.54 sec\n",
      "Training set accuracy 0.37841665744781494\n",
      "Test set accuracy 0.3804999887943268\n",
      "Epoch 52 in 5.17 sec\n",
      "Training set accuracy 0.38083332777023315\n",
      "Test set accuracy 0.3831999897956848\n",
      "Epoch 53 in 4.54 sec\n",
      "Training set accuracy 0.38351666927337646\n",
      "Test set accuracy 0.38509997725486755\n",
      "Epoch 54 in 4.89 sec\n",
      "Training set accuracy 0.3857000172138214\n",
      "Test set accuracy 0.38819998502731323\n",
      "Epoch 55 in 4.93 sec\n",
      "Training set accuracy 0.38806667923927307\n",
      "Test set accuracy 0.3901999890804291\n",
      "Epoch 56 in 4.57 sec\n",
      "Training set accuracy 0.39043334126472473\n",
      "Test set accuracy 0.39259999990463257\n",
      "Epoch 57 in 5.18 sec\n",
      "Training set accuracy 0.3926333487033844\n",
      "Test set accuracy 0.3953000009059906\n",
      "Epoch 58 in 4.50 sec\n",
      "Training set accuracy 0.39508333802223206\n",
      "Test set accuracy 0.39809998869895935\n",
      "Epoch 59 in 4.59 sec\n",
      "Training set accuracy 0.3971666693687439\n",
      "Test set accuracy 0.400299996137619\n",
      "Epoch 60 in 5.00 sec\n",
      "Training set accuracy 0.3995833396911621\n",
      "Test set accuracy 0.4009999930858612\n",
      "Epoch 61 in 4.42 sec\n",
      "Training set accuracy 0.40158334374427795\n",
      "Test set accuracy 0.4032000005245209\n",
      "Epoch 62 in 5.34 sec\n",
      "Training set accuracy 0.40346667170524597\n",
      "Test set accuracy 0.4050999879837036\n",
      "Epoch 63 in 4.49 sec\n",
      "Training set accuracy 0.4053666591644287\n",
      "Test set accuracy 0.40619999170303345\n",
      "Epoch 64 in 4.54 sec\n",
      "Training set accuracy 0.4074833393096924\n",
      "Test set accuracy 0.40939998626708984\n",
      "Epoch 65 in 5.16 sec\n",
      "Training set accuracy 0.40960001945495605\n",
      "Test set accuracy 0.4107999801635742\n",
      "Epoch 66 in 4.45 sec\n",
      "Training set accuracy 0.411133348941803\n",
      "Test set accuracy 0.4123999774456024\n",
      "Epoch 67 in 5.44 sec\n",
      "Training set accuracy 0.41288334131240845\n",
      "Test set accuracy 0.41439998149871826\n",
      "Epoch 68 in 4.51 sec\n",
      "Training set accuracy 0.4146333336830139\n",
      "Test set accuracy 0.4161999821662903\n",
      "Epoch 69 in 4.60 sec\n",
      "Training set accuracy 0.4164000153541565\n",
      "Test set accuracy 0.4179999828338623\n",
      "Epoch 70 in 5.05 sec\n",
      "Training set accuracy 0.4182499945163727\n",
      "Test set accuracy 0.4202999770641327\n",
      "Epoch 71 in 4.53 sec\n",
      "Training set accuracy 0.4203000068664551\n",
      "Test set accuracy 0.4213999807834625\n",
      "Epoch 72 in 5.25 sec\n",
      "Training set accuracy 0.4222666621208191\n",
      "Test set accuracy 0.4236999750137329\n",
      "Epoch 73 in 4.46 sec\n",
      "Training set accuracy 0.4239500164985657\n",
      "Test set accuracy 0.4251999855041504\n",
      "Epoch 74 in 4.69 sec\n",
      "Training set accuracy 0.42579999566078186\n",
      "Test set accuracy 0.4262999892234802\n",
      "Epoch 75 in 5.13 sec\n",
      "Training set accuracy 0.42721667885780334\n",
      "Test set accuracy 0.42729997634887695\n",
      "Epoch 76 in 4.54 sec\n",
      "Training set accuracy 0.4291166663169861\n",
      "Test set accuracy 0.4294999837875366\n",
      "Epoch 77 in 5.12 sec\n",
      "Training set accuracy 0.4307999908924103\n",
      "Test set accuracy 0.4309999942779541\n",
      "Epoch 78 in 4.52 sec\n",
      "Training set accuracy 0.43248334527015686\n",
      "Test set accuracy 0.43149998784065247\n",
      "Epoch 79 in 4.51 sec\n",
      "Training set accuracy 0.43371668457984924\n",
      "Test set accuracy 0.43209999799728394\n",
      "Epoch 80 in 5.45 sec\n",
      "Training set accuracy 0.43505001068115234\n",
      "Test set accuracy 0.43369999527931213\n",
      "Epoch 81 in 4.56 sec\n",
      "Training set accuracy 0.43656668066978455\n",
      "Test set accuracy 0.43539997935295105\n",
      "Epoch 82 in 5.20 sec\n",
      "Training set accuracy 0.4383000135421753\n",
      "Test set accuracy 0.43789997696876526\n",
      "Epoch 83 in 4.56 sec\n",
      "Training set accuracy 0.44003334641456604\n",
      "Test set accuracy 0.43879997730255127\n",
      "Epoch 84 in 4.45 sec\n",
      "Training set accuracy 0.4415000081062317\n",
      "Test set accuracy 0.4405999779701233\n",
      "Epoch 85 in 5.27 sec\n",
      "Training set accuracy 0.4430333375930786\n",
      "Test set accuracy 0.44179999828338623\n",
      "Epoch 86 in 4.54 sec\n",
      "Training set accuracy 0.4440166652202606\n",
      "Test set accuracy 0.44349998235702515\n",
      "Epoch 87 in 5.28 sec\n",
      "Training set accuracy 0.44530001282691956\n",
      "Test set accuracy 0.4456000030040741\n",
      "Epoch 88 in 4.55 sec\n",
      "Training set accuracy 0.44670000672340393\n",
      "Test set accuracy 0.44749999046325684\n",
      "Epoch 89 in 4.50 sec\n",
      "Training set accuracy 0.4478333294391632\n",
      "Test set accuracy 0.4486999809741974\n",
      "Epoch 90 in 5.24 sec\n",
      "Training set accuracy 0.4490000009536743\n",
      "Test set accuracy 0.4499000012874603\n",
      "Epoch 91 in 4.48 sec\n",
      "Training set accuracy 0.4499666690826416\n",
      "Test set accuracy 0.45080000162124634\n",
      "Epoch 92 in 5.38 sec\n",
      "Training set accuracy 0.45108333230018616\n",
      "Test set accuracy 0.45179998874664307\n",
      "Epoch 93 in 4.68 sec\n",
      "Training set accuracy 0.4523833394050598\n",
      "Test set accuracy 0.4537999927997589\n",
      "Epoch 94 in 4.54 sec\n",
      "Training set accuracy 0.4534499943256378\n",
      "Test set accuracy 0.45489999651908875\n",
      "Epoch 95 in 5.15 sec\n",
      "Training set accuracy 0.4545833468437195\n",
      "Test set accuracy 0.4569000005722046\n",
      "Epoch 96 in 4.46 sec\n",
      "Training set accuracy 0.4557666778564453\n",
      "Test set accuracy 0.45819997787475586\n",
      "Epoch 97 in 5.30 sec\n",
      "Training set accuracy 0.4570000171661377\n",
      "Test set accuracy 0.4592999815940857\n",
      "Epoch 98 in 4.48 sec\n",
      "Training set accuracy 0.4579166769981384\n",
      "Test set accuracy 0.4603999853134155\n",
      "Epoch 99 in 4.63 sec\n",
      "Training set accuracy 0.458950012922287\n",
      "Test set accuracy 0.4607999920845032\n",
      "Epoch 100 in 5.11 sec\n",
      "Training set accuracy 0.45988333225250244\n",
      "Test set accuracy 0.4617999792098999\n",
      "Epoch 101 in 4.54 sec\n",
      "Training set accuracy 0.46133333444595337\n",
      "Test set accuracy 0.462799996137619\n",
      "Epoch 102 in 5.25 sec\n",
      "Training set accuracy 0.4627000093460083\n",
      "Test set accuracy 0.46389999985694885\n",
      "Epoch 103 in 4.54 sec\n",
      "Training set accuracy 0.46388334035873413\n",
      "Test set accuracy 0.46449998021125793\n",
      "Epoch 104 in 4.63 sec\n",
      "Training set accuracy 0.4651166796684265\n",
      "Test set accuracy 0.46609997749328613\n",
      "Epoch 105 in 5.26 sec\n",
      "Training set accuracy 0.4662666618824005\n",
      "Test set accuracy 0.4675999879837036\n",
      "Epoch 106 in 4.71 sec\n",
      "Training set accuracy 0.4674166738986969\n",
      "Test set accuracy 0.4690999984741211\n",
      "Epoch 107 in 5.16 sec\n",
      "Training set accuracy 0.4684666693210602\n",
      "Test set accuracy 0.4708999991416931\n",
      "Epoch 108 in 4.60 sec\n",
      "Training set accuracy 0.4694666862487793\n",
      "Test set accuracy 0.47259998321533203\n",
      "Epoch 109 in 4.59 sec\n",
      "Training set accuracy 0.4708166718482971\n",
      "Test set accuracy 0.4733999967575073\n",
      "Epoch 110 in 5.28 sec\n",
      "Training set accuracy 0.47173333168029785\n",
      "Test set accuracy 0.4739999771118164\n",
      "Epoch 111 in 4.59 sec\n",
      "Training set accuracy 0.4727500081062317\n",
      "Test set accuracy 0.47509998083114624\n",
      "Epoch 112 in 5.27 sec\n",
      "Training set accuracy 0.4735333323478699\n",
      "Test set accuracy 0.47589999437332153\n",
      "Epoch 113 in 4.52 sec\n",
      "Training set accuracy 0.47476667165756226\n",
      "Test set accuracy 0.4761999845504761\n",
      "Epoch 114 in 4.44 sec\n",
      "Training set accuracy 0.4756166636943817\n",
      "Test set accuracy 0.47669997811317444\n",
      "Epoch 115 in 5.25 sec\n",
      "Training set accuracy 0.47671666741371155\n",
      "Test set accuracy 0.4777999818325043\n",
      "Epoch 116 in 4.51 sec\n",
      "Training set accuracy 0.47771668434143066\n",
      "Test set accuracy 0.4788999855518341\n",
      "Epoch 117 in 5.37 sec\n",
      "Training set accuracy 0.47868335247039795\n",
      "Test set accuracy 0.4797999858856201\n",
      "Epoch 118 in 4.62 sec\n",
      "Training set accuracy 0.4796000123023987\n",
      "Test set accuracy 0.48069998621940613\n",
      "Epoch 119 in 4.75 sec\n",
      "Training set accuracy 0.48065000772476196\n",
      "Test set accuracy 0.4822999835014343\n",
      "Epoch 120 in 5.15 sec\n",
      "Training set accuracy 0.4814000129699707\n",
      "Test set accuracy 0.4834999740123749\n",
      "Epoch 121 in 4.42 sec\n",
      "Training set accuracy 0.4821999967098236\n",
      "Test set accuracy 0.4846999943256378\n",
      "Epoch 122 in 5.28 sec\n",
      "Training set accuracy 0.4830166697502136\n",
      "Test set accuracy 0.4852999746799469\n",
      "Epoch 123 in 4.47 sec\n",
      "Training set accuracy 0.48391667008399963\n",
      "Test set accuracy 0.486299991607666\n",
      "Epoch 124 in 4.67 sec\n",
      "Training set accuracy 0.48500001430511475\n",
      "Test set accuracy 0.48659998178482056\n",
      "Epoch 125 in 5.18 sec\n",
      "Training set accuracy 0.4858666658401489\n",
      "Test set accuracy 0.4878000020980835\n",
      "Epoch 126 in 4.55 sec\n",
      "Training set accuracy 0.4868166744709015\n",
      "Test set accuracy 0.48819997906684875\n",
      "Epoch 127 in 5.24 sec\n",
      "Training set accuracy 0.48756667971611023\n",
      "Test set accuracy 0.48909997940063477\n",
      "Epoch 128 in 4.48 sec\n",
      "Training set accuracy 0.4884333312511444\n",
      "Test set accuracy 0.49069997668266296\n",
      "Epoch 129 in 4.59 sec\n",
      "Training set accuracy 0.489300012588501\n",
      "Test set accuracy 0.491599977016449\n",
      "Epoch 130 in 5.23 sec\n",
      "Training set accuracy 0.48998335003852844\n",
      "Test set accuracy 0.492499977350235\n",
      "Epoch 131 in 4.63 sec\n",
      "Training set accuracy 0.49079999327659607\n",
      "Test set accuracy 0.49390000104904175\n",
      "Epoch 132 in 5.29 sec\n",
      "Training set accuracy 0.49148333072662354\n",
      "Test set accuracy 0.49559998512268066\n",
      "Epoch 133 in 4.49 sec\n",
      "Training set accuracy 0.4921500086784363\n",
      "Test set accuracy 0.4966000020503998\n",
      "Epoch 134 in 4.57 sec\n",
      "Training set accuracy 0.49285000562667847\n",
      "Test set accuracy 0.49709999561309814\n",
      "Epoch 135 in 5.27 sec\n",
      "Training set accuracy 0.4936833381652832\n",
      "Test set accuracy 0.4984999895095825\n",
      "Epoch 136 in 4.58 sec\n",
      "Training set accuracy 0.49445000290870667\n",
      "Test set accuracy 0.4984999895095825\n",
      "Epoch 137 in 5.17 sec\n",
      "Training set accuracy 0.49533334374427795\n",
      "Test set accuracy 0.49949997663497925\n",
      "Epoch 138 in 4.65 sec\n",
      "Training set accuracy 0.4963500201702118\n",
      "Test set accuracy 0.5\n",
      "Epoch 139 in 4.50 sec\n",
      "Training set accuracy 0.4972666800022125\n",
      "Test set accuracy 0.5009999871253967\n",
      "Epoch 140 in 5.23 sec\n",
      "Training set accuracy 0.498199999332428\n",
      "Test set accuracy 0.5018999576568604\n",
      "Epoch 141 in 4.50 sec\n",
      "Training set accuracy 0.4989500045776367\n",
      "Test set accuracy 0.5024999976158142\n",
      "Epoch 142 in 5.26 sec\n",
      "Training set accuracy 0.49958333373069763\n",
      "Test set accuracy 0.5036999583244324\n",
      "Epoch 143 in 4.64 sec\n",
      "Training set accuracy 0.5002833604812622\n",
      "Test set accuracy 0.50409996509552\n",
      "Epoch 144 in 4.46 sec\n",
      "Training set accuracy 0.5009999871253967\n",
      "Test set accuracy 0.505299985408783\n",
      "Epoch 145 in 5.51 sec\n",
      "Training set accuracy 0.5018500089645386\n",
      "Test set accuracy 0.5062000155448914\n",
      "Epoch 146 in 4.44 sec\n",
      "Training set accuracy 0.5025500059127808\n",
      "Test set accuracy 0.507099986076355\n",
      "Epoch 147 in 5.23 sec\n",
      "Training set accuracy 0.5030999779701233\n",
      "Test set accuracy 0.5077999830245972\n",
      "Epoch 148 in 4.47 sec\n",
      "Training set accuracy 0.5035833120346069\n",
      "Test set accuracy 0.5080999732017517\n",
      "Epoch 149 in 4.61 sec\n",
      "Training set accuracy 0.5043333172798157\n",
      "Test set accuracy 0.5090000033378601\n",
      "Epoch 150 in 5.25 sec\n",
      "Training set accuracy 0.504800021648407\n",
      "Test set accuracy 0.5101000070571899\n",
      "Epoch 151 in 4.50 sec\n",
      "Training set accuracy 0.5056000351905823\n",
      "Test set accuracy 0.5108000040054321\n",
      "Epoch 152 in 5.23 sec\n",
      "Training set accuracy 0.5063666701316833\n",
      "Test set accuracy 0.5115000009536743\n",
      "Epoch 153 in 4.48 sec\n",
      "Training set accuracy 0.5071499943733215\n",
      "Test set accuracy 0.5115000009536743\n",
      "Epoch 154 in 4.64 sec\n",
      "Training set accuracy 0.5077999830245972\n",
      "Test set accuracy 0.5123000144958496\n",
      "Epoch 155 in 5.22 sec\n",
      "Training set accuracy 0.5086333155632019\n",
      "Test set accuracy 0.5130000114440918\n",
      "Epoch 156 in 4.49 sec\n",
      "Training set accuracy 0.5091166496276855\n",
      "Test set accuracy 0.5131999850273132\n",
      "Epoch 157 in 5.32 sec\n",
      "Training set accuracy 0.509850025177002\n",
      "Test set accuracy 0.5137999653816223\n",
      "Epoch 158 in 4.64 sec\n",
      "Training set accuracy 0.5104166865348816\n",
      "Test set accuracy 0.5149999856948853\n",
      "Epoch 159 in 4.65 sec\n",
      "Training set accuracy 0.5112666487693787\n",
      "Test set accuracy 0.5156999826431274\n",
      "Epoch 160 in 5.12 sec\n",
      "Training set accuracy 0.5118333101272583\n",
      "Test set accuracy 0.5162000060081482\n",
      "Epoch 161 in 4.63 sec\n",
      "Training set accuracy 0.5123000144958496\n",
      "Test set accuracy 0.5166000127792358\n",
      "Epoch 162 in 5.17 sec\n",
      "Training set accuracy 0.5129833221435547\n",
      "Test set accuracy 0.5171999931335449\n",
      "Epoch 163 in 4.61 sec\n",
      "Training set accuracy 0.5137333273887634\n",
      "Test set accuracy 0.5181999802589417\n",
      "Epoch 164 in 4.47 sec\n",
      "Training set accuracy 0.5145166516304016\n",
      "Test set accuracy 0.5184999704360962\n",
      "Epoch 165 in 5.26 sec\n",
      "Training set accuracy 0.5151833295822144\n",
      "Test set accuracy 0.5194999575614929\n",
      "Epoch 166 in 4.66 sec\n",
      "Training set accuracy 0.5159666538238525\n",
      "Test set accuracy 0.5202000141143799\n",
      "Epoch 167 in 5.23 sec\n",
      "Training set accuracy 0.5165166854858398\n",
      "Test set accuracy 0.520799994468689\n",
      "Epoch 168 in 4.59 sec\n",
      "Training set accuracy 0.5169166922569275\n",
      "Test set accuracy 0.5214999914169312\n",
      "Epoch 169 in 4.49 sec\n",
      "Training set accuracy 0.517133355140686\n",
      "Test set accuracy 0.5216000080108643\n",
      "Epoch 170 in 5.29 sec\n",
      "Training set accuracy 0.5177666544914246\n",
      "Test set accuracy 0.5218999981880188\n",
      "Epoch 171 in 4.71 sec\n",
      "Training set accuracy 0.5184000134468079\n",
      "Test set accuracy 0.5223999619483948\n",
      "Epoch 172 in 5.27 sec\n",
      "Training set accuracy 0.5189833641052246\n",
      "Test set accuracy 0.5241999626159668\n",
      "Epoch 173 in 4.60 sec\n",
      "Training set accuracy 0.5196166634559631\n",
      "Test set accuracy 0.5249999761581421\n",
      "Epoch 174 in 4.56 sec\n",
      "Training set accuracy 0.5201500058174133\n",
      "Test set accuracy 0.5254999995231628\n",
      "Epoch 175 in 5.23 sec\n",
      "Training set accuracy 0.5210000276565552\n",
      "Test set accuracy 0.525600016117096\n",
      "Epoch 176 in 4.46 sec\n",
      "Training set accuracy 0.5218666791915894\n",
      "Test set accuracy 0.525600016117096\n",
      "Epoch 177 in 5.29 sec\n",
      "Training set accuracy 0.5224999785423279\n",
      "Test set accuracy 0.5259000062942505\n",
      "Epoch 178 in 4.59 sec\n",
      "Training set accuracy 0.5229499936103821\n",
      "Test set accuracy 0.5270000100135803\n",
      "Epoch 179 in 4.83 sec\n",
      "Training set accuracy 0.5235666632652283\n",
      "Test set accuracy 0.5273000001907349\n",
      "Epoch 180 in 5.01 sec\n",
      "Training set accuracy 0.5241833329200745\n",
      "Test set accuracy 0.5277000069618225\n",
      "Epoch 181 in 4.69 sec\n",
      "Training set accuracy 0.5248667001724243\n",
      "Test set accuracy 0.5286999940872192\n",
      "Epoch 182 in 5.27 sec\n",
      "Training set accuracy 0.5253666639328003\n",
      "Test set accuracy 0.5292999744415283\n",
      "Epoch 183 in 4.49 sec\n",
      "Training set accuracy 0.5259166955947876\n",
      "Test set accuracy 0.5297999978065491\n",
      "Epoch 184 in 5.06 sec\n",
      "Training set accuracy 0.5263833403587341\n",
      "Test set accuracy 0.5306999683380127\n",
      "Epoch 185 in 4.92 sec\n",
      "Training set accuracy 0.5269166827201843\n",
      "Test set accuracy 0.5318999886512756\n",
      "Epoch 186 in 4.60 sec\n",
      "Training set accuracy 0.5275166630744934\n",
      "Test set accuracy 0.5324999690055847\n",
      "Epoch 187 in 5.22 sec\n",
      "Training set accuracy 0.5279666781425476\n",
      "Test set accuracy 0.5325999855995178\n",
      "Epoch 188 in 4.61 sec\n",
      "Training set accuracy 0.5285166501998901\n",
      "Test set accuracy 0.5327999591827393\n",
      "Epoch 189 in 4.85 sec\n",
      "Training set accuracy 0.5292666554450989\n",
      "Test set accuracy 0.5336999893188477\n",
      "Epoch 190 in 4.98 sec\n",
      "Training set accuracy 0.5296000242233276\n",
      "Test set accuracy 0.5343999862670898\n",
      "Epoch 191 in 4.72 sec\n",
      "Training set accuracy 0.5302833318710327\n",
      "Test set accuracy 0.5347999930381775\n",
      "Epoch 192 in 5.20 sec\n",
      "Training set accuracy 0.5307999849319458\n",
      "Test set accuracy 0.5354999899864197\n",
      "Epoch 193 in 4.71 sec\n",
      "Training set accuracy 0.5313833355903625\n",
      "Test set accuracy 0.5365999937057495\n",
      "Epoch 194 in 4.96 sec\n",
      "Training set accuracy 0.5320166945457458\n",
      "Test set accuracy 0.536899983882904\n",
      "Epoch 195 in 5.01 sec\n",
      "Training set accuracy 0.5324666500091553\n",
      "Test set accuracy 0.5371999740600586\n",
      "Epoch 196 in 4.65 sec\n",
      "Training set accuracy 0.5329333543777466\n",
      "Test set accuracy 0.5372999906539917\n",
      "Epoch 197 in 5.50 sec\n",
      "Training set accuracy 0.5333666801452637\n",
      "Test set accuracy 0.538100004196167\n",
      "Epoch 198 in 4.53 sec\n",
      "Training set accuracy 0.5338333249092102\n",
      "Test set accuracy 0.5388000011444092\n",
      "Epoch 199 in 5.33 sec\n",
      "Training set accuracy 0.5343666672706604\n",
      "Test set accuracy 0.539900004863739\n",
      "Epoch 200 in 4.67 sec\n",
      "Training set accuracy 0.534600019454956\n",
      "Test set accuracy 0.5401999950408936\n",
      "Epoch 201 in 4.45 sec\n",
      "Training set accuracy 0.5349833369255066\n",
      "Test set accuracy 0.5407999753952026\n",
      "Epoch 202 in 5.38 sec\n",
      "Training set accuracy 0.5354666709899902\n",
      "Test set accuracy 0.5414999723434448\n",
      "Epoch 203 in 4.51 sec\n",
      "Training set accuracy 0.5357833504676819\n",
      "Test set accuracy 0.5417999625205994\n",
      "Epoch 204 in 5.27 sec\n",
      "Training set accuracy 0.5365833640098572\n",
      "Test set accuracy 0.5425999760627747\n",
      "Epoch 205 in 4.68 sec\n",
      "Training set accuracy 0.5372000336647034\n",
      "Test set accuracy 0.5428999662399292\n",
      "Epoch 206 in 4.51 sec\n",
      "Training set accuracy 0.5377333164215088\n",
      "Test set accuracy 0.5430999994277954\n",
      "Epoch 207 in 5.32 sec\n",
      "Training set accuracy 0.5381500124931335\n",
      "Test set accuracy 0.5435000061988831\n",
      "Epoch 208 in 4.56 sec\n",
      "Training set accuracy 0.5385833382606506\n",
      "Test set accuracy 0.5435999631881714\n",
      "Epoch 209 in 5.46 sec\n",
      "Training set accuracy 0.5392000079154968\n",
      "Test set accuracy 0.5435999631881714\n",
      "Epoch 210 in 4.66 sec\n",
      "Training set accuracy 0.5397166609764099\n",
      "Test set accuracy 0.5436999797821045\n",
      "Epoch 211 in 4.60 sec\n",
      "Training set accuracy 0.540149986743927\n",
      "Test set accuracy 0.5440999865531921\n",
      "Epoch 212 in 5.18 sec\n",
      "Training set accuracy 0.5406833291053772\n",
      "Test set accuracy 0.5447999835014343\n",
      "Epoch 213 in 4.49 sec\n",
      "Training set accuracy 0.5411166548728943\n",
      "Test set accuracy 0.5449000000953674\n",
      "Epoch 214 in 5.32 sec\n",
      "Training set accuracy 0.5414833426475525\n",
      "Test set accuracy 0.5457000136375427\n",
      "Epoch 215 in 4.48 sec\n",
      "Training set accuracy 0.5418999791145325\n",
      "Test set accuracy 0.5462999939918518\n",
      "Epoch 216 in 4.56 sec\n",
      "Training set accuracy 0.5423333644866943\n",
      "Test set accuracy 0.546999990940094\n",
      "Epoch 217 in 5.30 sec\n",
      "Training set accuracy 0.5427333116531372\n",
      "Test set accuracy 0.5482000112533569\n",
      "Epoch 218 in 4.50 sec\n",
      "Training set accuracy 0.5431666970252991\n",
      "Test set accuracy 0.5483999848365784\n",
      "Epoch 219 in 5.25 sec\n",
      "Training set accuracy 0.5436999797821045\n",
      "Test set accuracy 0.5490999817848206\n",
      "Epoch 220 in 4.56 sec\n",
      "Training set accuracy 0.5441666841506958\n",
      "Test set accuracy 0.5490999817848206\n",
      "Epoch 221 in 4.55 sec\n",
      "Training set accuracy 0.5444333553314209\n",
      "Test set accuracy 0.5498999953269958\n",
      "Epoch 222 in 5.24 sec\n",
      "Training set accuracy 0.5448499917984009\n",
      "Test set accuracy 0.5507999658584595\n",
      "Epoch 223 in 4.74 sec\n",
      "Training set accuracy 0.5453000068664551\n",
      "Test set accuracy 0.5509999990463257\n",
      "Epoch 224 in 5.19 sec\n",
      "Training set accuracy 0.5454666614532471\n",
      "Test set accuracy 0.5507999658584595\n",
      "Epoch 225 in 4.50 sec\n",
      "Training set accuracy 0.5459333658218384\n",
      "Test set accuracy 0.5512999892234802\n",
      "Epoch 226 in 4.46 sec\n",
      "Training set accuracy 0.5462999939918518\n",
      "Test set accuracy 0.5519999861717224\n",
      "Epoch 227 in 5.37 sec\n",
      "Training set accuracy 0.5467166900634766\n",
      "Test set accuracy 0.5521999597549438\n",
      "Epoch 228 in 4.61 sec\n",
      "Training set accuracy 0.54708331823349\n",
      "Test set accuracy 0.5527999997138977\n",
      "Epoch 229 in 5.14 sec\n",
      "Training set accuracy 0.5474833250045776\n",
      "Test set accuracy 0.5532999634742737\n",
      "Epoch 230 in 4.64 sec\n",
      "Training set accuracy 0.547866702079773\n",
      "Test set accuracy 0.5539000034332275\n",
      "Epoch 231 in 4.48 sec\n",
      "Training set accuracy 0.5482000112533569\n",
      "Test set accuracy 0.554099977016449\n",
      "Epoch 232 in 5.27 sec\n",
      "Training set accuracy 0.5484333634376526\n",
      "Test set accuracy 0.5541999936103821\n",
      "Epoch 233 in 4.51 sec\n",
      "Training set accuracy 0.5487333536148071\n",
      "Test set accuracy 0.5543999671936035\n",
      "Epoch 234 in 5.25 sec\n",
      "Training set accuracy 0.5491666793823242\n",
      "Test set accuracy 0.5548999905586243\n",
      "Epoch 235 in 4.50 sec\n",
      "Training set accuracy 0.5496500134468079\n",
      "Test set accuracy 0.5557000041007996\n",
      "Epoch 236 in 4.56 sec\n",
      "Training set accuracy 0.5499833226203918\n",
      "Test set accuracy 0.5561000108718872\n",
      "Epoch 237 in 5.44 sec\n",
      "Training set accuracy 0.5504666566848755\n",
      "Test set accuracy 0.5564999580383301\n",
      "Epoch 238 in 4.43 sec\n",
      "Training set accuracy 0.5508833527565002\n",
      "Test set accuracy 0.5566999912261963\n",
      "Epoch 239 in 5.33 sec\n",
      "Training set accuracy 0.5511000156402588\n",
      "Test set accuracy 0.5572999715805054\n",
      "Epoch 240 in 4.58 sec\n",
      "Training set accuracy 0.5516666769981384\n",
      "Test set accuracy 0.5580999851226807\n",
      "Epoch 241 in 4.54 sec\n",
      "Training set accuracy 0.5519833564758301\n",
      "Test set accuracy 0.5583999752998352\n",
      "Epoch 242 in 5.27 sec\n",
      "Training set accuracy 0.5524500012397766\n",
      "Test set accuracy 0.558899998664856\n",
      "Epoch 243 in 4.59 sec\n",
      "Training set accuracy 0.5527666807174683\n",
      "Test set accuracy 0.5593999624252319\n",
      "Epoch 244 in 5.30 sec\n",
      "Training set accuracy 0.5532000064849854\n",
      "Test set accuracy 0.559499979019165\n",
      "Epoch 245 in 4.48 sec\n",
      "Training set accuracy 0.5537499785423279\n",
      "Test set accuracy 0.5600000023841858\n",
      "Epoch 246 in 4.58 sec\n",
      "Training set accuracy 0.5541166663169861\n",
      "Test set accuracy 0.5602999925613403\n",
      "Epoch 247 in 5.17 sec\n",
      "Training set accuracy 0.5546166896820068\n",
      "Test set accuracy 0.560699999332428\n",
      "Epoch 248 in 4.63 sec\n",
      "Training set accuracy 0.5549833178520203\n",
      "Test set accuracy 0.561199963092804\n",
      "Epoch 249 in 5.22 sec\n",
      "Training set accuracy 0.5554500222206116\n",
      "Test set accuracy 0.5615999698638916\n",
      "Epoch 250 in 4.62 sec\n",
      "Training set accuracy 0.555733323097229\n",
      "Test set accuracy 0.5619999766349792\n",
      "Epoch 251 in 4.48 sec\n",
      "Training set accuracy 0.5560833215713501\n",
      "Test set accuracy 0.5625\n",
      "Epoch 252 in 5.26 sec\n",
      "Training set accuracy 0.5564833283424377\n",
      "Test set accuracy 0.5626999735832214\n",
      "Epoch 253 in 4.60 sec\n",
      "Training set accuracy 0.556600034236908\n",
      "Test set accuracy 0.5630999803543091\n",
      "Epoch 254 in 5.27 sec\n",
      "Training set accuracy 0.556950032711029\n",
      "Test set accuracy 0.5634999871253967\n",
      "Epoch 255 in 4.54 sec\n",
      "Training set accuracy 0.557366669178009\n",
      "Test set accuracy 0.5636000037193298\n",
      "Epoch 256 in 4.46 sec\n",
      "Training set accuracy 0.5578833222389221\n",
      "Test set accuracy 0.5634999871253967\n",
      "Epoch 257 in 5.35 sec\n",
      "Training set accuracy 0.5583000183105469\n",
      "Test set accuracy 0.5640999674797058\n",
      "Epoch 258 in 4.58 sec\n",
      "Training set accuracy 0.5588666796684265\n",
      "Test set accuracy 0.5644999742507935\n",
      "Epoch 259 in 5.23 sec\n",
      "Training set accuracy 0.5593500137329102\n",
      "Test set accuracy 0.5651000142097473\n",
      "Epoch 260 in 4.54 sec\n",
      "Training set accuracy 0.5597167015075684\n",
      "Test set accuracy 0.5654000043869019\n",
      "Epoch 261 in 4.65 sec\n",
      "Training set accuracy 0.5601000189781189\n",
      "Test set accuracy 0.5656999945640564\n",
      "Epoch 262 in 5.31 sec\n",
      "Training set accuracy 0.560699999332428\n",
      "Test set accuracy 0.5663999915122986\n",
      "Epoch 263 in 4.58 sec\n",
      "Training set accuracy 0.5610333681106567\n",
      "Test set accuracy 0.5669000148773193\n",
      "Epoch 264 in 5.24 sec\n",
      "Training set accuracy 0.5613499879837036\n",
      "Test set accuracy 0.5672999620437622\n",
      "Epoch 265 in 4.49 sec\n",
      "Training set accuracy 0.5615666508674622\n",
      "Test set accuracy 0.567799985408783\n",
      "Epoch 266 in 4.51 sec\n",
      "Training set accuracy 0.5619666576385498\n",
      "Test set accuracy 0.568399965763092\n",
      "Epoch 267 in 5.17 sec\n",
      "Training set accuracy 0.562416672706604\n",
      "Test set accuracy 0.5684999823570251\n",
      "Epoch 268 in 4.59 sec\n",
      "Training set accuracy 0.5628166794776917\n",
      "Test set accuracy 0.5690000057220459\n",
      "Epoch 269 in 5.27 sec\n",
      "Training set accuracy 0.5629500150680542\n",
      "Test set accuracy 0.5694999694824219\n",
      "Epoch 270 in 4.59 sec\n",
      "Training set accuracy 0.5632833242416382\n",
      "Test set accuracy 0.5697999596595764\n",
      "Epoch 271 in 4.62 sec\n",
      "Training set accuracy 0.5634499788284302\n",
      "Test set accuracy 0.5698999762535095\n",
      "Epoch 272 in 5.21 sec\n",
      "Training set accuracy 0.5638666749000549\n",
      "Test set accuracy 0.5705999732017517\n",
      "Epoch 273 in 4.70 sec\n",
      "Training set accuracy 0.5642833113670349\n",
      "Test set accuracy 0.5706999897956848\n",
      "Epoch 274 in 5.17 sec\n",
      "Training set accuracy 0.5647333264350891\n",
      "Test set accuracy 0.5709999799728394\n",
      "Epoch 275 in 4.57 sec\n",
      "Training set accuracy 0.5650666952133179\n",
      "Test set accuracy 0.5709999799728394\n",
      "Epoch 276 in 4.71 sec\n",
      "Training set accuracy 0.5653499960899353\n",
      "Test set accuracy 0.5712000131607056\n",
      "Epoch 277 in 5.18 sec\n",
      "Training set accuracy 0.5658666491508484\n",
      "Test set accuracy 0.5712999701499939\n",
      "Epoch 278 in 4.48 sec\n",
      "Training set accuracy 0.56618332862854\n",
      "Test set accuracy 0.5715999603271484\n",
      "Epoch 279 in 5.23 sec\n",
      "Training set accuracy 0.5663833618164062\n",
      "Test set accuracy 0.5717999935150146\n",
      "Epoch 280 in 4.59 sec\n",
      "Training set accuracy 0.5665666460990906\n",
      "Test set accuracy 0.5720999836921692\n",
      "Epoch 281 in 4.50 sec\n",
      "Training set accuracy 0.5669833421707153\n",
      "Test set accuracy 0.5720999836921692\n",
      "Epoch 282 in 5.30 sec\n",
      "Training set accuracy 0.5671666860580444\n",
      "Test set accuracy 0.5719999670982361\n",
      "Epoch 283 in 4.48 sec\n",
      "Training set accuracy 0.5675166845321655\n",
      "Test set accuracy 0.5724999904632568\n",
      "Epoch 284 in 5.26 sec\n",
      "Training set accuracy 0.5680666565895081\n",
      "Test set accuracy 0.5730999708175659\n",
      "Epoch 285 in 4.58 sec\n",
      "Training set accuracy 0.5684166550636292\n",
      "Test set accuracy 0.5737999677658081\n",
      "Epoch 286 in 4.52 sec\n",
      "Training set accuracy 0.5685333609580994\n",
      "Test set accuracy 0.5740999579429626\n",
      "Epoch 287 in 5.29 sec\n",
      "Training set accuracy 0.5689499974250793\n",
      "Test set accuracy 0.574400007724762\n",
      "Epoch 288 in 4.50 sec\n",
      "Training set accuracy 0.5692499876022339\n",
      "Test set accuracy 0.5741999745368958\n",
      "Epoch 289 in 5.45 sec\n",
      "Training set accuracy 0.5697333216667175\n",
      "Test set accuracy 0.574400007724762\n",
      "Epoch 290 in 4.46 sec\n",
      "Training set accuracy 0.5702166557312012\n",
      "Test set accuracy 0.5745999813079834\n",
      "Epoch 291 in 4.50 sec\n",
      "Training set accuracy 0.5704833269119263\n",
      "Test set accuracy 0.5751999616622925\n",
      "Epoch 292 in 5.32 sec\n",
      "Training set accuracy 0.5710333585739136\n",
      "Test set accuracy 0.5755000114440918\n",
      "Epoch 293 in 4.51 sec\n",
      "Training set accuracy 0.5715166926383972\n",
      "Test set accuracy 0.5758999586105347\n",
      "Epoch 294 in 5.23 sec\n",
      "Training set accuracy 0.5717666745185852\n",
      "Test set accuracy 0.5762999653816223\n",
      "Epoch 295 in 4.51 sec\n",
      "Training set accuracy 0.5720166563987732\n",
      "Test set accuracy 0.5767999887466431\n",
      "Epoch 296 in 4.53 sec\n",
      "Training set accuracy 0.5724166631698608\n",
      "Test set accuracy 0.5767999887466431\n",
      "Epoch 297 in 5.17 sec\n",
      "Training set accuracy 0.572700023651123\n",
      "Test set accuracy 0.5774999856948853\n",
      "Epoch 298 in 4.56 sec\n",
      "Training set accuracy 0.5731000304222107\n",
      "Test set accuracy 0.5777999758720398\n",
      "Epoch 299 in 5.28 sec\n",
      "Training set accuracy 0.5732666850090027\n",
      "Test set accuracy 0.5780999660491943\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nb_runs = 2\n",
    "nb_epochs = 10\n",
    "record_freq = 100\n",
    "lrs = [0.01, 0.001]\n",
    "depths = [5*i for i in range(1, 3)]\n",
    "scale = jnp.sqrt(2/width)\n",
    "\n",
    "for depth in depths:\n",
    "  for lr in lrs:\n",
    "    for rn in range(nb_runs):\n",
    "      layer_sizes = [784] + [width]*depth +[10]\n",
    "      params = init_network_params(layer_sizes, scale, random.PRNGKey(rn))\n",
    "      train_neural_network(params, nb_epochs, record_freq, lr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Cidt9J6LqMu9"
   },
   "outputs": [],
   "source": [
    "evol.to_excel('jacnorm_during_training_depth5_300.xlsx')"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "jupytext": {
   "formats": "ipynb,md:myst"
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
