{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "# os.environ[\"CUDA_DEVICE_ORDER\"] = \"PCI_BUS_ID\" # for choosing the second GPU \n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = '1'\n",
    "\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "from jax import grad, jit, vmap\n",
    "from jax import random\n",
    "from jax.experimental import optimizers\n",
    "from jax.scipy.special import logsumexp\n",
    "\n",
    "import itertools\n",
    "\n",
    "import tensorflow_datasets as tfds\n",
    "import time\n",
    "import numpy as np\n",
    "from plotnine import * \n",
    "import pandas as pd\n",
    "\n",
    "# A helper function to randomly initialize weights and biases\n",
    "# for a dense neural network layer\n",
    "def random_layer_params(m, n, key):\n",
    "    w_key, b_key = random.split(key)\n",
    "    return random.normal(w_key, (n, m))\n",
    "\n",
    "# Initialize all layers for a fully-connected neural network with sizes \"sizes\"\n",
    "def init_network_params(sizes, key):\n",
    "    keys = random.split(key, len(sizes))\n",
    "    return [random_layer_params(m, n, k) for m, n, k in zip(sizes[:-1], sizes[1:], keys)]\n",
    "\n",
    "def relu(x):\n",
    "    return jnp.maximum(0, x)\n",
    "\n",
    "def flip_signs(x):\n",
    "    return x*jnp.reshape(2*(jnp.arange(x.size)%2)-1, x.shape) \n",
    "\n",
    "def predict(params, image):\n",
    "    al=1/jnp.sqrt(2)\n",
    "    la=1/jnp.sqrt(2)\n",
    "    # per-example predictions\n",
    "    activations = image\n",
    "\n",
    "    w = params[0]\n",
    "    activations = (jnp.dot(w, activations))*jnp.sqrt(1/nin) \n",
    "\n",
    "    # initialize \"random\" signs with fixed key \n",
    "    key = random.PRNGKey(0)\n",
    "    d = len(params)\n",
    "    n = activations.shape[0]\n",
    "    R = random.choice(key, jnp.asarray([-1,1]), shape = (d, n), replace = True)\n",
    "\n",
    "    # skip layers \n",
    "    l = 0\n",
    "    for w in params[1:-1]:\n",
    "#         activations_relu = relu( jnp.einsum( 'i,i->i', R[l,:], activations ) )\n",
    "        activations_relu = relu( activations )\n",
    "        l += 1\n",
    "        outputs = (jnp.dot(w, activations_relu))*jnp.sqrt(2/n) \n",
    "        activations = al * activations + la * outputs\n",
    "\n",
    "    final_w = params[-1]\n",
    "    logits = jnp.dot(final_w, activations)*jnp.sqrt(1/n) \n",
    "    return logits - logsumexp(logits)\n",
    "\n",
    "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)\n",
    "#           for (w), (dw) in zip(params, grads)]\n",
    "\n",
    "def get_train_batches(dataset_str):\n",
    "    # as_supervised=True gives us the (image, label) as a tuple instead of a dict\n",
    "    ds = tfds.load(name = dataset_str, split='train', as_supervised=True, data_dir=data_dir)\n",
    "    # You can build up an arbitrary tf.data input pipeline\n",
    "    ds = ds.batch(batch_size).prefetch(1)\n",
    "    # tfds.dataset_as_numpy converts the tf.data.Dataset into an iterable of NumPy arrays\n",
    "    return tfds.as_numpy(ds)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_str = 'cifar10'\n",
    "# dataset_str = 'mnist'\n",
    "\n",
    "if dataset_str == 'cifar10':\n",
    "    nin = 3072 #32*32*3 for CIFAR10 data\n",
    "elif dataset_str == 'mnist':\n",
    "    nin = 784\n",
    "n = 500\n",
    "d = 100\n",
    "nout = 10\n",
    "\n",
    "layer_sizes = [nin] + d*[n] + [nout]\n",
    "batch_size = 128\n",
    "# learning_rate = 0.05\n",
    "n_targets = 10\n",
    "# params = init_network_params(layer_sizes, random.PRNGKey(int(time.time())))\n",
    "\n",
    "# Make a batched version of the `predict` function\n",
    "batched_predict = vmap(predict, in_axes=(None, 0))\n",
    "\n",
    "data_dir = '/tmp/tfds'\n",
    "\n",
    "# Fetch full datasets for evaluation\n",
    "# tfds.load returns tf.Tensors (or tf.data.Datasets if batch_size != -1)\n",
    "# You can convert them to NumPy arrays (or iterables of NumPy arrays) with tfds.dataset_as_numpy\n",
    "mnist_data, info = tfds.load(name = dataset_str, batch_size=-1, data_dir=data_dir, with_info=True)\n",
    "mnist_data = tfds.as_numpy(mnist_data)\n",
    "train_data, test_data = mnist_data['train'], mnist_data['test']\n",
    "num_labels = info.features['label'].num_classes\n",
    "h, w, c = info.features['image'].shape\n",
    "num_pixels = h * w * c\n",
    "\n",
    "# Full train set\n",
    "train_images, train_labels = train_data['image'], train_data['label']\n",
    "train_images = jnp.reshape(train_images, (len(train_images), num_pixels))\n",
    "train_labels = one_hot(train_labels, num_labels)\n",
    "\n",
    "# Full test set\n",
    "test_images, test_labels = test_data['image'], test_data['label']\n",
    "test_images = jnp.reshape(test_images, (len(test_images), num_pixels))\n",
    "test_labels = one_hot(test_labels, num_labels)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 in 0.00 sec\n",
      "Training set accuracy 9.53\n",
      "Test set accuracy 9.75\n",
      "NaNs?  False\n",
      "Epoch 1 in 43.60 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 2 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 3 in 27.10 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 4 in 27.29 sec\n",
      "Training set accuracy 10.04\n",
      "Test set accuracy 10.11\n",
      "NaNs?  False\n",
      "Epoch 5 in 27.14 sec\n",
      "Training set accuracy 10.16\n",
      "Test set accuracy 10.21\n",
      "NaNs?  False\n",
      "Epoch 6 in 27.51 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 7 in 27.37 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 8 in 26.98 sec\n",
      "Training set accuracy 12.87\n",
      "Test set accuracy 12.55\n",
      "NaNs?  False\n",
      "Epoch 9 in 27.49 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 10 in 27.18 sec\n",
      "Training set accuracy 10.02\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 11 in 27.16 sec\n",
      "Training set accuracy 12.73\n",
      "Test set accuracy 12.30\n",
      "NaNs?  False\n",
      "Epoch 12 in 27.47 sec\n",
      "Training set accuracy 12.21\n",
      "Test set accuracy 11.94\n",
      "NaNs?  False\n",
      "Epoch 13 in 27.67 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 14 in 27.24 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.01\n",
      "NaNs?  False\n",
      "Epoch 15 in 27.13 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 16 in 27.24 sec\n",
      "Training set accuracy 13.36\n",
      "Test set accuracy 13.08\n",
      "NaNs?  False\n",
      "Epoch 17 in 27.20 sec\n",
      "Training set accuracy 13.16\n",
      "Test set accuracy 12.86\n",
      "NaNs?  False\n",
      "Epoch 18 in 27.39 sec\n",
      "Training set accuracy 14.54\n",
      "Test set accuracy 14.52\n",
      "NaNs?  False\n",
      "Epoch 19 in 27.35 sec\n",
      "Training set accuracy 14.94\n",
      "Test set accuracy 14.85\n",
      "NaNs?  False\n",
      "Epoch 20 in 27.42 sec\n",
      "Training set accuracy 14.11\n",
      "Test set accuracy 14.24\n",
      "NaNs?  False\n",
      "Epoch 21 in 27.14 sec\n",
      "Training set accuracy 14.45\n",
      "Test set accuracy 14.19\n",
      "NaNs?  False\n",
      "Epoch 22 in 27.10 sec\n",
      "Training set accuracy 13.74\n",
      "Test set accuracy 13.45\n",
      "NaNs?  False\n",
      "Epoch 23 in 27.21 sec\n",
      "Training set accuracy 10.13\n",
      "Test set accuracy 10.15\n",
      "NaNs?  False\n",
      "Epoch 24 in 27.07 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 25 in 27.50 sec\n",
      "Training set accuracy 10.01\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 26 in 27.04 sec\n",
      "Training set accuracy 12.79\n",
      "Test set accuracy 12.64\n",
      "NaNs?  False\n",
      "Epoch 27 in 27.00 sec\n",
      "Training set accuracy 12.38\n",
      "Test set accuracy 12.15\n",
      "NaNs?  False\n",
      "Epoch 28 in 27.19 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 29 in 27.17 sec\n",
      "Training set accuracy 11.23\n",
      "Test set accuracy 10.96\n",
      "NaNs?  False\n",
      "Epoch 30 in 26.87 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 31 in 26.92 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 32 in 27.86 sec\n",
      "Training set accuracy 11.24\n",
      "Test set accuracy 11.42\n",
      "NaNs?  False\n",
      "Epoch 33 in 27.57 sec\n",
      "Training set accuracy 9.39\n",
      "Test set accuracy 9.70\n",
      "NaNs?  False\n",
      "Epoch 34 in 27.60 sec\n",
      "Training set accuracy 10.23\n",
      "Test set accuracy 10.24\n",
      "NaNs?  False\n",
      "Epoch 35 in 26.98 sec\n",
      "Training set accuracy 10.33\n",
      "Test set accuracy 10.33\n",
      "NaNs?  False\n",
      "Epoch 36 in 27.15 sec\n",
      "Training set accuracy 9.88\n",
      "Test set accuracy 10.10\n",
      "NaNs?  False\n",
      "Epoch 37 in 26.97 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 38 in 26.96 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 39 in 27.10 sec\n",
      "Training set accuracy 10.45\n",
      "Test set accuracy 10.57\n",
      "NaNs?  False\n",
      "Epoch 40 in 27.17 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 41 in 27.32 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 42 in 27.22 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 43 in 27.04 sec\n",
      "Training set accuracy 11.87\n",
      "Test set accuracy 11.73\n",
      "NaNs?  False\n",
      "Epoch 44 in 27.40 sec\n",
      "Training set accuracy 11.12\n",
      "Test set accuracy 10.97\n",
      "NaNs?  False\n",
      "Epoch 45 in 27.39 sec\n",
      "Training set accuracy 10.51\n",
      "Test set accuracy 10.59\n",
      "NaNs?  False\n",
      "Epoch 46 in 27.19 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 47 in 27.03 sec\n",
      "Training set accuracy 10.73\n",
      "Test set accuracy 10.88\n",
      "NaNs?  False\n",
      "Epoch 48 in 27.29 sec\n",
      "Training set accuracy 9.65\n",
      "Test set accuracy 9.82\n",
      "NaNs?  False\n",
      "Epoch 49 in 26.96 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 50 in 27.03 sec\n",
      "Training set accuracy 10.08\n",
      "Test set accuracy 10.01\n",
      "NaNs?  False\n",
      "Epoch 51 in 27.26 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 52 in 27.07 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 53 in 27.27 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 54 in 27.06 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 55 in 26.78 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 56 in 27.21 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 57 in 27.19 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 58 in 26.98 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 59 in 27.41 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 60 in 27.10 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 61 in 26.93 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 62 in 27.11 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 63 in 27.14 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 64 in 27.51 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 65 in 27.28 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 66 in 26.90 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 67 in 27.50 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 68 in 26.69 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 69 in 26.97 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 70 in 26.79 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 71 in 27.09 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 72 in 26.59 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 73 in 27.02 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 74 in 27.18 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 75 in 27.14 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 76 in 27.25 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 77 in 26.79 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 78 in 26.98 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 79 in 26.94 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 80 in 27.27 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 81 in 27.12 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 82 in 27.27 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 83 in 27.06 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 84 in 27.13 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 85 in 27.20 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 86 in 26.97 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 87 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 88 in 26.96 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 89 in 26.98 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 90 in 26.94 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 91 in 26.70 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 92 in 27.30 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 93 in 26.71 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 94 in 26.99 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "NaNs?  False\n",
      "Epoch 95 in 27.13 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 96 in 26.89 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 97 in 26.92 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 98 in 26.87 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 99 in 27.04 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 100 in 26.91 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 101 in 26.90 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 102 in 26.78 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 103 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 104 in 27.10 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 105 in 27.13 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 106 in 26.93 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 107 in 26.95 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 108 in 27.08 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 109 in 26.91 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 110 in 27.18 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 111 in 26.68 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 112 in 27.21 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 113 in 27.05 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 114 in 26.76 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 115 in 26.81 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 116 in 26.76 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 117 in 26.59 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 118 in 26.76 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 119 in 26.91 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 120 in 26.79 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 121 in 26.58 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 122 in 26.65 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 123 in 26.62 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 124 in 26.93 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 125 in 26.78 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 126 in 26.86 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 127 in 27.05 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 128 in 27.45 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 129 in 27.54 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 130 in 26.97 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 131 in 27.06 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 132 in 27.10 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 133 in 26.92 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 134 in 27.06 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 135 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 136 in 27.00 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 137 in 27.03 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 138 in 26.84 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 139 in 26.62 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 140 in 26.84 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 141 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 142 in 26.66 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 143 in 26.87 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 144 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 145 in 26.91 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 146 in 26.74 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 147 in 27.28 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 148 in 26.86 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 149 in 26.46 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 150 in 26.74 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 151 in 27.00 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 152 in 26.89 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 153 in 27.00 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 154 in 26.85 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 155 in 26.78 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 156 in 27.03 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 157 in 26.63 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 158 in 26.64 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 159 in 26.76 sec\n",
      "Training set accuracy 10.01\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 160 in 26.73 sec\n",
      "Training set accuracy 10.01\n",
      "Test set accuracy 10.10\n",
      "NaNs?  False\n",
      "Epoch 161 in 26.72 sec\n",
      "Training set accuracy 10.22\n",
      "Test set accuracy 10.34\n",
      "NaNs?  False\n",
      "Epoch 162 in 26.90 sec\n",
      "Training set accuracy 13.90\n",
      "Test set accuracy 13.68\n",
      "NaNs?  False\n",
      "Epoch 163 in 26.72 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 164 in 26.72 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 165 in 26.58 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 166 in 26.69 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 167 in 26.67 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 168 in 26.68 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 169 in 27.03 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 170 in 26.84 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 171 in 26.89 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 172 in 27.12 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 173 in 27.03 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 174 in 26.67 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 175 in 26.89 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 176 in 26.73 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 177 in 26.59 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 178 in 26.38 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 179 in 26.95 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 180 in 27.07 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 181 in 26.69 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 182 in 27.02 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 183 in 26.62 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 184 in 26.91 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 185 in 27.17 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 186 in 26.83 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 187 in 26.63 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 188 in 26.94 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "NaNs?  False\n",
      "Epoch 189 in 26.78 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 190 in 26.61 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 191 in 26.80 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 192 in 26.81 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 193 in 27.02 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 194 in 27.01 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 195 in 26.97 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 196 in 27.32 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 197 in 26.75 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 198 in 27.23 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n",
      "Epoch 199 in 27.26 sec\n",
      "Training set accuracy 10.00\n",
      "Test set accuracy 10.00\n",
      "NaNs?  False\n"
     ]
    }
   ],
   "source": [
    "init_params = init_network_params(layer_sizes, random.PRNGKey(int(time.time())))\n",
    "num_epochs = 200\n",
    "row_list = []\n",
    "epoch_time = 0\n",
    "\n",
    "learning_rate = 0.01\n",
    "momentum = 0.9\n",
    "# opt_init, opt_update, get_params = optimizers.momentum(learning_rate, momentum)\n",
    "opt_init, opt_update, get_params = optimizers.adam(learning_rate)\n",
    "opt_state = opt_init(init_params)\n",
    "\n",
    "@jit\n",
    "def update(i, opt_state, x, y):\n",
    "    params = get_params(opt_state)\n",
    "    return opt_update(i, grad(loss)(params, x, y), opt_state)\n",
    "\n",
    "itercount = itertools.count()\n",
    "\n",
    "# grads = grad(loss)(params, x, y)\n",
    "# def step(step, opt_state, x, y):\n",
    "#     value, grads = jax.value_and_grad(loss)(get_params(opt_state), x, y)\n",
    "#     opt_state = opt_update(step, grads, opt_state)\n",
    "#     return value, opt_state\n",
    "\n",
    "# for i in range(num_steps):\n",
    "#     value, opt_state = step(i, opt_state)\n",
    "for epoch in range(num_epochs):\n",
    "    start_time = time.time()\n",
    "    \n",
    "    params = get_params(opt_state)\n",
    "    train_acc = accuracy(params, train_images, train_labels)\n",
    "    test_acc = accuracy(params, test_images, test_labels)\n",
    "    dict1 = {'epoch': epoch, \n",
    "             'train_acc': np.copy(train_acc).item(), \n",
    "             'test_acc': np.copy(test_acc).item() }\n",
    "    row_list += [dict1] \n",
    "    print(\"Epoch {} in {:0.2f} sec\".format(epoch, epoch_time))\n",
    "    print(\"Training set accuracy {:0.2f}\".format(100*train_acc))\n",
    "    print(\"Test set accuracy {:0.2f}\".format(100*test_acc))\n",
    "    print(\"NaNs? \",any([jnp.isnan(a).any() for p in params for a in p ]))\n",
    "\n",
    "    for x, y in get_train_batches(dataset_str):\n",
    "        x = jnp.reshape(x, (len(x), num_pixels))\n",
    "        y = one_hot(y, num_labels)\n",
    "        opt_state = update(next(itercount), opt_state, x, y)\n",
    "#         params = update(params, x, y, learning_rate)\n",
    "#         value, opt_state = step(i, opt_state, x, y)\n",
    "#         i += 1\n",
    "        \n",
    "    #train_acc = accuracy(params, train_images, train_labels)\n",
    "    #test_acc = accuracy(params, test_images, test_labels)\n",
    "    #print(\"...Training set accuracy {}\".format(train_acc))\n",
    "    #print(\"...Test set accuracy {}\".format(test_acc))\n",
    "    epoch_time = time.time() - start_time\n",
    "\n",
    "\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "df = pd.DataFrame(row_list) \n",
    "plt4 = ggplot(df, aes( x = 'epoch', y = 'train_acc')) + \\\n",
    "    geom_line() + \\\n",
    "    geom_line(aes(y = 'test_acc'), color = 'red') + \\\n",
    "    scale_y_continuous( limits = [0, 1]) \n",
    "# print(plt2)\n",
    "print(plt4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv('ResNet_d30.csv', index = False)\n",
    "# df.to_csv('Balanced_ResNet_d30.csv', index = False)\n",
    "# df.to_csv('CIFAR_ResNet_d30.csv', index = False)\n",
    "# df.to_csv('CIFAR_Balanced_ResNet_d30.csv', index = False)\n",
    "\n",
    "# df.to_csv('CIFAR_ResNet_d100.csv', index = False)\n",
    "# df.to_csv('CIFAR_Balanced_ResNet_d100.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/h/mufan/condaenvs/jax/plotnine/ggplot.py:721: PlotnineWarning: Saving 6 x 4 in image.\n",
      "/h/mufan/condaenvs/jax/plotnine/ggplot.py:722: PlotnineWarning: Filename: Figures/cifar_resnet30.pdf\n"
     ]
    }
   ],
   "source": [
    "import matplotlib as mpl\n",
    "mpl.rc('text', usetex=True) # for plotting latex\n",
    "mpl.rc('text.latex', preamble=r'\\usepackage{amssymb}')\n",
    "\n",
    "# df_mnist = pd.read_csv('ResNet_d30.csv')\n",
    "# df_mnist_bal = pd.read_csv('Balanced_ResNet_d30.csv')\n",
    "df_mnist = pd.read_csv('CIFAR_ResNet_d30.csv')\n",
    "df_mnist_bal = pd.read_csv('CIFAR_Balanced_ResNet_d30.csv')\n",
    "df_mnist['Architecture'] = 'Vanilla ResNet'\n",
    "df_mnist_bal['Architecture'] = 'Balanced ResNet'\n",
    "\n",
    "df_mnist_merge = pd.concat([df_mnist, df_mnist_bal])\n",
    "df_mnist_merge = df_mnist_merge.rename( columns = {'train_acc': 'Training', 'test_acc': 'Test'} )\n",
    "df_mnist_melt = pd.melt(df_mnist_merge, id_vars = ['epoch', 'Architecture'])\n",
    "\n",
    "plt_mnist = ggplot(df_mnist_melt, aes( x = 'epoch', y = 'value', color = 'Architecture', linetype = 'variable')) + \\\n",
    "    geom_line() + \\\n",
    "    scale_color_manual( values = ['#e41a1c', '#377eb8'], \n",
    "                        breaks = ['Vanilla ResNet', 'Balanced ResNet'] ) + \\\n",
    "    scale_linetype_manual( values = ['dashed', 'solid'], breaks = ['Training', 'Test'] ) + \\\n",
    "    scale_y_continuous( limits = [0, 1] ) + \\\n",
    "    labs( x = 'Epoch', y = '' ) + \\\n",
    "    theme(legend_title = element_blank(), figure_size = (6,4), subplots_adjust = {'wspace':0.1}, \n",
    "          legend_position = 'bottom', \n",
    "          legend_box = 'horizontal', \n",
    "          legend_box_spacing = 0.55, \n",
    "          text = element_text( size = 16 ) ) \n",
    "print(plt_mnist)\n",
    "# plt_mnist.save(filename = 'mnist_resnet30.pdf', path = 'Figures/' )\n",
    "# plt_mnist.save(filename = 'cifar_resnet30.pdf', path = 'Figures/' )\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
