{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 34
    },
    "colab_type": "code",
    "id": "L6Q9A-AvgeCn",
    "outputId": "c2755a01-3585-4ab1-e378-a3eb70478363"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    }
   ],
   "source": [
    "%pylab inline\n",
    "\n",
    "%config InlineBackend.figure_format = 'retina'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import lconv\n",
    "import tensorflow as tf\n",
    "\n",
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"0\" \n",
    "\n",
    "sess = tf.compat.v1.InteractiveSession()\n",
    "# K = tf.keras.backend\n",
    "\n",
    "from tensorflow.keras import Model, Sequential\n",
    "from tensorflow.keras.layers import Layer, Input, Flatten, Reshape, Dense, Conv2D, MaxPool2D\n",
    "\n",
    "import pickle as pk\n",
    "import json\n",
    "# import numpy as np\n",
    "\n",
    "\n",
    "from scipy import ndimage\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def rotated_ims_rand(x):\n",
    "    return np.float32([ndimage.rotate(i, (np.random.rand()-.5)*180, reshape=False, mode='nearest') for i in x])\n",
    "        \n",
    "class Scramble_x:\n",
    "    def __init__(self,x):\n",
    "        s = x.shape[1:-1]\n",
    "        self.idx = np.argsort(np.random.rand(np.prod(s)))\n",
    "        r,c = np.int0(self.idx/s[0]), (self.idx % s[1]) \n",
    "        self.x = np.float32([i[r,c].reshape(s+(x.shape[-1],)) for i in x])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Defaults        \n",
    "configs= {\n",
    "    'dataset': dict(name= 'mnist',#'cifar100', #'mnist' ,#'mnist',cifar100, \n",
    "                    rotate=True, \n",
    "                    scramble=True,\n",
    "                   ),\n",
    "    'net': dict(architecture= 'lconv', # 'cnn', 'fc', \n",
    "                num_filters=16, \n",
    "                kernel_size=6, \n",
    "                L_hid= [8], #[16], \n",
    "                activation = 'relu',\n",
    "                L_trainable = True,\n",
    "                num_layers = 1,\n",
    "               ),\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rotating images\n",
      "Scrambling images\n"
     ]
    }
   ],
   "source": [
    "\n",
    "dataset_name = configs['dataset']['name']\n",
    "\n",
    "dataset = eval(\"tf.keras.datasets.%s.load_data()\" %dataset_name) \n",
    "(x_train, y_train), (x_test,y_test) = dataset\n",
    "if len(x_train.shape) == 3:\n",
    "    # mnist channel is missing\n",
    "    x_train = x_train[...,np.newaxis]\n",
    "    \n",
    "# normalize\n",
    "x_train = x_train/x_train[:100].max() -.5 \n",
    "# make categorical\n",
    "y_train = tf.keras.utils.to_categorical(y_train)\n",
    "\n",
    "\n",
    "results = {'configs':configs,}\n",
    "\n",
    "if configs['dataset']['rotate']:\n",
    "    print('Rotating images')\n",
    "    x_train = rotated_ims_rand(x_train)\n",
    "    \n",
    "if configs['dataset']['scramble']:\n",
    "    print('Scrambling images')\n",
    "    scr = Scramble_x(x_train)\n",
    "    x_train = scr.x\n",
    "    results['scramble_idx']=scr.idx.tolist()\n",
    "\n",
    "##### Make model #####\n",
    "\n",
    "net = configs['net']\n",
    "# arch = net['architecture']\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Matching number parameters: L-conv and CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_same_params = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_53\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_28 (InputLayer)        [(None, 28, 28, 1)]       0         \n",
      "_________________________________________________________________\n",
      "tf_op_layer_Reshape_10 (Tens [(None, 784, 1)]          0         \n",
      "_________________________________________________________________\n",
      "l__conv_10 (L_Conv)          (None, 784, 24)           47328     \n",
      "_________________________________________________________________\n",
      "flatten_26 (Flatten)         (None, 18816)             0         \n",
      "_________________________________________________________________\n",
      "dense_26 (Dense)             (None, 10)                188170    \n",
      "=================================================================\n",
      "Total params: 235,498\n",
      "Trainable params: 235,498\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "net = configs['net']\n",
    "\n",
    "net['kernel_size'] = 6\n",
    "net['L_hid'] = [6]\n",
    "net['num_filters'] = 24\n",
    "\n",
    "inp = Input(x_train[0].shape)\n",
    "\n",
    "x = inp\n",
    "for _ in range(net['num_layers']):\n",
    "    x = tf.reshape(x, shape=(-1,np.prod(x.shape[1:-1]), x.shape[-1]))\n",
    "    lay = lconv.L_Conv(num_filters= net['num_filters'], \n",
    "                          kernel_size= net['kernel_size'], \n",
    "                          L_hid = net['L_hid'], \n",
    "                          activation = net['activation'],)\n",
    "\n",
    "    x = lay(x)\n",
    "    lay.L.trainable = net['L_trainable']\n",
    "\n",
    "\n",
    "x = Flatten()(x)\n",
    "\n",
    "# x = Dense(100, activation = 'relu')(x)\n",
    "\n",
    "out = Dense(y_train.shape[-1], activation='softmax')(x)\n",
    "\n",
    "model = Model(inputs = [inp], outputs = [out])\n",
    "model.compile(loss = tf.keras.losses.categorical_crossentropy, metrics = ['accuracy'])\n",
    "\n",
    "model.summary()\n",
    "\n",
    "model._model_name = 'L-conv-n_L%d-d_h%d-nf%d' %(net['kernel_size'],\n",
    "                                   net['L_hid'][0],net['num_filters'],)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.7813 - accuracy: 0.7498 - val_loss: 0.4263 - val_accuracy: 0.8635\n",
      "Epoch 2/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.3782 - accuracy: 0.8878 - val_loss: 0.2993 - val_accuracy: 0.9136\n",
      "Epoch 3/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.2813 - accuracy: 0.9179 - val_loss: 0.2877 - val_accuracy: 0.9183\n",
      "Epoch 4/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.2312 - accuracy: 0.9339 - val_loss: 0.2445 - val_accuracy: 0.9313\n",
      "Epoch 5/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.2005 - accuracy: 0.9433 - val_loss: 0.2456 - val_accuracy: 0.9317\n",
      "Epoch 6/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.1723 - accuracy: 0.9495 - val_loss: 0.2443 - val_accuracy: 0.9337\n",
      "Epoch 7/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.1535 - accuracy: 0.9564 - val_loss: 0.2388 - val_accuracy: 0.9384\n",
      "Epoch 8/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.1343 - accuracy: 0.9616 - val_loss: 0.2543 - val_accuracy: 0.9321\n",
      "Epoch 9/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.1194 - accuracy: 0.9653 - val_loss: 0.2219 - val_accuracy: 0.9419\n",
      "Epoch 10/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.1053 - accuracy: 0.9692 - val_loss: 0.2510 - val_accuracy: 0.9371\n",
      "Epoch 11/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0949 - accuracy: 0.9722 - val_loss: 0.2565 - val_accuracy: 0.9402\n",
      "Epoch 12/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0848 - accuracy: 0.9759 - val_loss: 0.2775 - val_accuracy: 0.9417\n",
      "Epoch 13/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0787 - accuracy: 0.9765 - val_loss: 0.3007 - val_accuracy: 0.9394\n",
      "Epoch 14/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0695 - accuracy: 0.9798 - val_loss: 0.3095 - val_accuracy: 0.9441\n",
      "Epoch 15/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0634 - accuracy: 0.9808 - val_loss: 0.2971 - val_accuracy: 0.9403\n",
      "Epoch 16/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0567 - accuracy: 0.9834 - val_loss: 0.3444 - val_accuracy: 0.9392\n",
      "Epoch 17/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0503 - accuracy: 0.9854 - val_loss: 0.3518 - val_accuracy: 0.9405\n",
      "Epoch 18/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0485 - accuracy: 0.9856 - val_loss: 0.3321 - val_accuracy: 0.9431\n",
      "Epoch 19/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0426 - accuracy: 0.9871 - val_loss: 0.4123 - val_accuracy: 0.9427\n",
      "Epoch 20/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0419 - accuracy: 0.9876 - val_loss: 0.4158 - val_accuracy: 0.9386\n",
      "Epoch 21/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0382 - accuracy: 0.9888 - val_loss: 0.4005 - val_accuracy: 0.9411\n",
      "Epoch 22/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0370 - accuracy: 0.9895 - val_loss: 0.4164 - val_accuracy: 0.9413\n",
      "Epoch 23/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.0335 - accuracy: 0.9903 - val_loss: 0.5447 - val_accuracy: 0.9331\n",
      "Epoch 24/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0303 - accuracy: 0.9908 - val_loss: 0.4416 - val_accuracy: 0.9418\n",
      "Epoch 25/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.0275 - accuracy: 0.9920 - val_loss: 0.4565 - val_accuracy: 0.9402\n",
      "Epoch 26/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.0291 - accuracy: 0.9925 - val_loss: 0.4483 - val_accuracy: 0.9428\n",
      "Epoch 27/30\n",
      "1500/1500 [==============================] - 7s 4ms/step - loss: 0.0261 - accuracy: 0.9924 - val_loss: 0.5069 - val_accuracy: 0.9415\n",
      "Epoch 28/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0269 - accuracy: 0.9922 - val_loss: 0.5669 - val_accuracy: 0.9394\n",
      "Epoch 29/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0235 - accuracy: 0.9936 - val_loss: 0.6285 - val_accuracy: 0.9388\n",
      "Epoch 30/30\n",
      "1500/1500 [==============================] - 7s 5ms/step - loss: 0.0253 - accuracy: 0.9929 - val_loss: 0.4973 - val_accuracy: 0.9411\n"
     ]
    }
   ],
   "source": [
    "h = model.fit(x_train, y_train, validation_split=0.2, epochs=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 248,
       "width": 380
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in ['accuracy', 'val_accuracy']:\n",
    "    plot(h.history[k], )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "results_same_params.update({model._model_name: {'params' :model.count_params(), \n",
    "                                                      'acc':max(h.history['val_accuracy']) }})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'L-conv-n_L6-d_h8-nf16': {'params': 188362, 'acc': 0.9445000290870667},\n",
       " 'CNN-ker(2, 3)-nf32': {'params': 224874, 'acc': 0.9046666622161865},\n",
       " 'CNN-ker(3, 3)-nf32': {'params': 216650, 'acc': 0.9159166812896729},\n",
       " 'CNN-ker(4, 4)-nf32': {'params': 200554, 'acc': 0.922249972820282},\n",
       " 'L-conv-n_L8-d_h6-nf16': {'params': 191562, 'acc': 0.9440833330154419}}"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_same_params"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## CNN with similar parameters\n",
    "We may increase either the number of filters or the kernel-size to math parameters"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### more filters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_15\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_8 (InputLayer)         [(None, 28, 28, 1)]       0         \n",
      "_________________________________________________________________\n",
      "conv2d_3 (Conv2D)            (None, 27, 26, 32)        224       \n",
      "_________________________________________________________________\n",
      "flatten_7 (Flatten)          (None, 22464)             0         \n",
      "_________________________________________________________________\n",
      "dense_7 (Dense)              (None, 10)                224650    \n",
      "=================================================================\n",
      "Total params: 224,874\n",
      "Trainable params: 224,874\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "net = configs['net']\n",
    "\n",
    "kx = int(0.5+np.sqrt(net['kernel_size']))\n",
    "ky = int(0.5+net['kernel_size']/kx)\n",
    "kernel_size = (kx,ky)\n",
    "\n",
    "nf = 32\n",
    "\n",
    "inp = Input(x_train[0].shape)\n",
    "\n",
    "x = inp\n",
    "for _ in range(net['num_layers']):\n",
    "    x = Conv2D(filters=nf, \n",
    "                 kernel_size=kernel_size, \n",
    "                 activation = net['activation'])(x)\n",
    "\n",
    "    #x = MaxPool2D(pool_size=(2, 2),strides=(1, 1), padding='valid')(x)\n",
    "\n",
    "\n",
    "x = Flatten()(x)\n",
    "\n",
    "# x = Dense(100, activation = 'relu')(x)\n",
    "\n",
    "out = Dense(y_train.shape[-1], activation='softmax')(x)\n",
    "\n",
    "model = Model(inputs = [inp], outputs = [out])\n",
    "model.compile(loss = tf.keras.losses.categorical_crossentropy, metrics = ['accuracy'])\n",
    "\n",
    "model.summary()\n",
    "\n",
    "model._model_name = 'CNN-ker%s-nf%d' %(kernel_size,nf,)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.7701 - accuracy: 0.7611 - val_loss: 0.5283 - val_accuracy: 0.8453\n",
      "Epoch 2/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.4742 - accuracy: 0.8617 - val_loss: 0.4343 - val_accuracy: 0.8733\n",
      "Epoch 3/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3895 - accuracy: 0.8865 - val_loss: 0.3921 - val_accuracy: 0.8889\n",
      "Epoch 4/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3427 - accuracy: 0.8984 - val_loss: 0.3802 - val_accuracy: 0.8891\n",
      "Epoch 5/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3085 - accuracy: 0.9104 - val_loss: 0.3653 - val_accuracy: 0.8968\n",
      "Epoch 6/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2847 - accuracy: 0.9181 - val_loss: 0.3785 - val_accuracy: 0.8896\n",
      "Epoch 7/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2637 - accuracy: 0.9247 - val_loss: 0.3480 - val_accuracy: 0.9033\n",
      "Epoch 8/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2460 - accuracy: 0.9285 - val_loss: 0.3491 - val_accuracy: 0.9019\n",
      "Epoch 9/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2332 - accuracy: 0.9341 - val_loss: 0.3526 - val_accuracy: 0.9003\n",
      "Epoch 10/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2181 - accuracy: 0.9379 - val_loss: 0.3509 - val_accuracy: 0.9037\n",
      "Epoch 11/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2078 - accuracy: 0.9408 - val_loss: 0.3567 - val_accuracy: 0.9041\n",
      "Epoch 12/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1981 - accuracy: 0.9437 - val_loss: 0.3611 - val_accuracy: 0.9047\n",
      "Epoch 13/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1879 - accuracy: 0.9470 - val_loss: 0.3608 - val_accuracy: 0.9013\n",
      "Epoch 14/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1790 - accuracy: 0.9489 - val_loss: 0.3667 - val_accuracy: 0.9028\n",
      "Epoch 15/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1716 - accuracy: 0.9522 - val_loss: 0.3650 - val_accuracy: 0.9033\n",
      "Epoch 16/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1640 - accuracy: 0.9538 - val_loss: 0.3733 - val_accuracy: 0.9013\n",
      "Epoch 17/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1570 - accuracy: 0.9560 - val_loss: 0.3633 - val_accuracy: 0.9045\n",
      "Epoch 18/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1507 - accuracy: 0.9578 - val_loss: 0.3903 - val_accuracy: 0.9016\n",
      "Epoch 19/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1447 - accuracy: 0.9600 - val_loss: 0.3853 - val_accuracy: 0.9025\n",
      "Epoch 20/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1392 - accuracy: 0.9613 - val_loss: 0.4063 - val_accuracy: 0.9001\n",
      "Epoch 21/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1352 - accuracy: 0.9625 - val_loss: 0.3982 - val_accuracy: 0.9022\n",
      "Epoch 22/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1290 - accuracy: 0.9645 - val_loss: 0.3954 - val_accuracy: 0.9003\n",
      "Epoch 23/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1230 - accuracy: 0.9650 - val_loss: 0.4105 - val_accuracy: 0.9029\n",
      "Epoch 24/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1191 - accuracy: 0.9671 - val_loss: 0.4295 - val_accuracy: 0.8963\n",
      "Epoch 25/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1134 - accuracy: 0.9692 - val_loss: 0.4156 - val_accuracy: 0.9001\n",
      "Epoch 26/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1096 - accuracy: 0.9700 - val_loss: 0.4468 - val_accuracy: 0.8936\n",
      "Epoch 27/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1070 - accuracy: 0.9710 - val_loss: 0.4570 - val_accuracy: 0.8947\n",
      "Epoch 28/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1025 - accuracy: 0.9722 - val_loss: 0.4432 - val_accuracy: 0.8969\n",
      "Epoch 29/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.0985 - accuracy: 0.9732 - val_loss: 0.4498 - val_accuracy: 0.8965\n",
      "Epoch 30/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.0961 - accuracy: 0.9741 - val_loss: 0.4511 - val_accuracy: 0.8947\n"
     ]
    }
   ],
   "source": [
    "h = model.fit(x_train, y_train, validation_split=0.2, epochs=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "results_same_params.update({model._model_name: {'params' :model.count_params(), \n",
    "                                                      'acc':max(h.history['val_accuracy']) }})\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### larger kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_61\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_32 (InputLayer)        [(None, 28, 28, 1)]       0         \n",
      "_________________________________________________________________\n",
      "conv2d_20 (Conv2D)           (None, 27, 27, 24)        120       \n",
      "_________________________________________________________________\n",
      "flatten_30 (Flatten)         (None, 17496)             0         \n",
      "_________________________________________________________________\n",
      "dense_30 (Dense)             (None, 10)                174970    \n",
      "=================================================================\n",
      "Total params: 175,090\n",
      "Trainable params: 175,090\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "net = configs['net']\n",
    "\n",
    "kernel_size = (2,2)\n",
    "\n",
    "nf = 24\n",
    "\n",
    "inp = Input(x_train[0].shape)\n",
    "\n",
    "x = inp\n",
    "for _ in range(net['num_layers']):\n",
    "    x = Conv2D(filters=nf, \n",
    "                 kernel_size=kernel_size, \n",
    "                 activation = net['activation'])(x)\n",
    "\n",
    "    #x = MaxPool2D(pool_size=(2, 2),strides=(1, 1), padding='valid')(x)\n",
    "\n",
    "\n",
    "x = Flatten()(x)\n",
    "\n",
    "# x = Dense(100, activation = 'relu')(x)\n",
    "\n",
    "out = Dense(y_train.shape[-1], activation='softmax')(x)\n",
    "\n",
    "model = Model(inputs = [inp], outputs = [out])\n",
    "model.compile(loss = tf.keras.losses.categorical_crossentropy, metrics = ['accuracy'])\n",
    "\n",
    "model.summary()\n",
    "\n",
    "model._model_name = 'CNN-ker%s-nf%d' %(kernel_size,nf,)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.8166 - accuracy: 0.7431 - val_loss: 0.5618 - val_accuracy: 0.8315\n",
      "Epoch 2/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.5268 - accuracy: 0.8440 - val_loss: 0.4743 - val_accuracy: 0.8609\n",
      "Epoch 3/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.4427 - accuracy: 0.8704 - val_loss: 0.4295 - val_accuracy: 0.8739\n",
      "Epoch 4/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3987 - accuracy: 0.8836 - val_loss: 0.4113 - val_accuracy: 0.8802\n",
      "Epoch 5/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3678 - accuracy: 0.8927 - val_loss: 0.4090 - val_accuracy: 0.8814\n",
      "Epoch 6/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3444 - accuracy: 0.9010 - val_loss: 0.3960 - val_accuracy: 0.8873\n",
      "Epoch 7/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3263 - accuracy: 0.9049 - val_loss: 0.3876 - val_accuracy: 0.8882\n",
      "Epoch 8/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.3106 - accuracy: 0.9106 - val_loss: 0.3861 - val_accuracy: 0.8882\n",
      "Epoch 9/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2975 - accuracy: 0.9127 - val_loss: 0.3867 - val_accuracy: 0.8917\n",
      "Epoch 10/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2857 - accuracy: 0.9177 - val_loss: 0.3848 - val_accuracy: 0.8905\n",
      "Epoch 11/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2755 - accuracy: 0.9211 - val_loss: 0.3865 - val_accuracy: 0.8900\n",
      "Epoch 12/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2648 - accuracy: 0.9241 - val_loss: 0.3847 - val_accuracy: 0.8914\n",
      "Epoch 13/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2574 - accuracy: 0.9259 - val_loss: 0.3881 - val_accuracy: 0.8896\n",
      "Epoch 14/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2492 - accuracy: 0.9283 - val_loss: 0.3854 - val_accuracy: 0.8921\n",
      "Epoch 15/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2415 - accuracy: 0.9299 - val_loss: 0.3883 - val_accuracy: 0.8914\n",
      "Epoch 16/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2357 - accuracy: 0.9321 - val_loss: 0.3895 - val_accuracy: 0.8910\n",
      "Epoch 17/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2281 - accuracy: 0.9346 - val_loss: 0.3887 - val_accuracy: 0.8926\n",
      "Epoch 18/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2224 - accuracy: 0.9357 - val_loss: 0.3989 - val_accuracy: 0.8897\n",
      "Epoch 19/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2174 - accuracy: 0.9375 - val_loss: 0.4117 - val_accuracy: 0.8891\n",
      "Epoch 20/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2129 - accuracy: 0.9382 - val_loss: 0.4012 - val_accuracy: 0.8929\n",
      "Epoch 21/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2085 - accuracy: 0.9398 - val_loss: 0.4019 - val_accuracy: 0.8904\n",
      "Epoch 22/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.2031 - accuracy: 0.9406 - val_loss: 0.4081 - val_accuracy: 0.8902\n",
      "Epoch 23/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1973 - accuracy: 0.9433 - val_loss: 0.4072 - val_accuracy: 0.8907\n",
      "Epoch 24/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1949 - accuracy: 0.9433 - val_loss: 0.4224 - val_accuracy: 0.8881\n",
      "Epoch 25/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1913 - accuracy: 0.9447 - val_loss: 0.4190 - val_accuracy: 0.8898\n",
      "Epoch 26/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1864 - accuracy: 0.9465 - val_loss: 0.4230 - val_accuracy: 0.8866\n",
      "Epoch 27/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1820 - accuracy: 0.9480 - val_loss: 0.4272 - val_accuracy: 0.8894\n",
      "Epoch 28/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1796 - accuracy: 0.9495 - val_loss: 0.4210 - val_accuracy: 0.8860\n",
      "Epoch 29/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1751 - accuracy: 0.9501 - val_loss: 0.4324 - val_accuracy: 0.8879\n",
      "Epoch 30/30\n",
      "1500/1500 [==============================] - 6s 4ms/step - loss: 0.1718 - accuracy: 0.9506 - val_loss: 0.4259 - val_accuracy: 0.8882\n"
     ]
    }
   ],
   "source": [
    "h = model.fit(x_train, y_train, validation_split=0.2, epochs=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "results_same_params.update({model._model_name: {'params' :model.count_params(), \n",
    "                                                      'acc':max(h.history['val_accuracy']) }})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'L-conv-n_L6-d_h8-nf16': {'params': 188362, 'acc': 0.9445000290870667},\n",
       " 'CNN-ker(2, 3)-nf32': {'params': 224874, 'acc': 0.9046666622161865},\n",
       " 'CNN-ker(3, 3)-nf32': {'params': 216650, 'acc': 0.9159166812896729},\n",
       " 'CNN-ker(4, 4)-nf32': {'params': 200554, 'acc': 0.922249972820282},\n",
       " 'L-conv-n_L8-d_h6-nf16': {'params': 191562, 'acc': 0.9440833330154419},\n",
       " 'CNN-ker(5, 5)-nf32': {'params': 185162, 'acc': 0.9259166717529297},\n",
       " 'CNN-ker(2, 2)-nf24': {'params': 175090, 'acc': 0.8929166793823242}}"
      ]
     },
     "execution_count": 133,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_same_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Yf7552fppZfmwx/+cMfZlCNHjiQiuOaaa3juuec44IADWHnllZl//vlZYYUV2HPPPXn88cen22fSpEkstthiRASXXnppx+MYNWoUEcExxxwzoOMfzLiG09NPP83JJ58MwBFHHDFd0LCX/vrXv7Ltttuy5JJLssgii/Cud72LY445ZobmEL7uuuvYZpttWHrppVlwwQV55zvfyXHHHUdmNtV98sknp71+97vf3bK9ddddF4CXXnppwGNpfJhff8e2ySabEBGceuqpABxyyCHTchnXB4rnmmuuQQeOh+sakCRJkqQ3MoPHktTg2GOPZe211+bEE0/k3nvvnRbguv322zn22GP5yle+0rTPSSedxHrrrceZZ57JI488wkILLcSECRO48sor2XHHHdltt92YMmVK2z4feeQRRo8ezVFHHcVTTz1FRPDYY49x8skn84EPfIDx48dPq7vAAgvwsY99DIBf/epXbdu86aabuPvuu5l77rn5xCc+MahzMZBxDadzzz2XyZMns9RSS/HhD394hvRx9tlns8EGG3DppZcyfvx45p13Xu644w6+/OUvs9NOO82QPk899VQ23nhjLr/8cl5//XUmTZrEbbfdxr777sv+++/fVL/+IYM333xzyzZrP3aMHj162Ma25JJLsuyyy05LF7Hwwguz7LLLTlt6YTiuAUmSJEl6ozN4LEl1zj33XPbbbz+mTJnCjjvuyL/+9S9efPFFxo8fz7PPPssZZ5wxbSZnzfXXX8/nP/95pk6dyo477si4ceMYP348EyZM4LDDDiMiOOOMM/je977Xtt99992XJZZYguuvv56XXnqJF198kYsuuogRI0bw0EMPNe27yy67AHDxxRfz8ssvt2zzrLPOAmDTTTdlueWWG9T5GOi4hstf/vIXoKQ9eO211zj00EMZNWoUCyywAEsvvTRbb701l1xyyaDbv//++9l9992ZMmUKW265Jffffz/jx49n4sSJHHHEEVx44YVceOGFvTocoMyk3Wuvvfj85z/P448/Pi1v8b777gvAT37yk2k5hGuWW245ttlmGwD2339/zjvvPCZPngzAhAkTOPTQQznttNNYbLHFGDt27LCN7YILLuCJJ56Y9qPFV7/6VZ544olpSy/M6GtAkiRJkgRkpststAA3jh49OiVlfuYzn0kgN9544560N3ny5FxhhRUSyJ13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uW/WC9B6Px+P63HhfZ3zuT4XMA18OPfn4Fr929lae6yIoZYCGUAU8FfgamABcLm1dr6P8f/G1fe5FXAH8AiuovEWXBvmdbfWppTsqUQqXvfu3b2tB5YsWeJ4/NatWxMdHQ3AhAl5/8bjfJzIyEi/xdwePXrkG9+kSRNWr15NeHg4a9eupX///rlW/+YUHh4O+G9H4YScfY5zFlj/aHI+W85njomJ8fm1279/fwVk6Z+nLcbevXv9jtm1axfXXXcdx48fp2vXrixatEh9jkVERERERKTCOb3yOAaYzO+9jCuMtfagtfZOa209a20Va21ja+3D1tp8FRZrrbHW5tv9y1o721p7lbW2tjtGQ/dqaV+rlLHWxlprh1lrL7LWhllrA621F7g32fuXtVb9juWc1qBBA2644QYApk+fTnJycpHmFafFRUxMDJUrV+arr75i6dKlJcrTyTh5tWzZklWrVlGnTh1WrFjBoEGDfK5S9vQqPn78OJs2bXLs/jnVrl3bW0wtzYrhnPlFRkaWNq0S3btJkyZ+x3iKwWFhYdStW7c80nKU52tTrVo1n9f37t1Lr169OHLkCB07diQ2NpaqVauWZ4oiIiIiIiIiPjldPD7uPpfdUjsRqVDPPvssQUFBxMfHc9ttt5Genl7g+A8//JBp06YVOX7z5s0ZPnw4AE8++WSJeys7FceX1q1bs3LlSmrWrElsbCzR0dFkZub+21DLli3p3LkzAI899liBvXTT0tL8rmAuzJVXXgm4euX6UthzJycnM3XqVAA6depUYI/l4irs3suXLycuLg5w9T/25+uvvwZczxoQUK7dlgqV9+ue1w8//MDHH38MQNeuXfNdP3jwIL169SIhIYHLL7+czz77zG9vZhEREREREZHy5vRv4T+6zxc4HFdEzhJt2rRh5syZGGOIjY2lbdu2zJ07l+PHj3vHJCUlsXDhQnr27MngwYM5efJkse4xadIkqlSpwvbt20lISChxrk7F8aVNmzasWLGCsLAwFi1axNChQ8nKyso15pVXXiEoKIi4uDh69erFF1984e2FnJWVxY4dO3j66adp2rSpd4O94rr66quB3wusef3888907tyZt956iwMHDnhfP3PmDMuXL+eqq65iz549BAQE8PzzvluyR0ZGYoxhxIgRxcpt6tSp3HXXXaxcuTLX98Cvv/7KCy+8wMCBAwFo0aIFd911l984nmfzbK53NhkzZgxjxoxh48aNuf6QcuLECWbNmkX37t1JS0sjNDSUsWPH5pp75MgRrr32Wn7++Wcuvvhi7x8kRERERERERM4WlR2O9x+gEzAQV+9fEfkDGjlyJLVr1+a+++5j165d3H777YDrbfnGmFyFwsaNG3PNNdcUK36jRo249957mTFjRqnydCqOPx06dGD58uVcf/31fPjhhwQFBTFr1izv6tiOHTuyaNEihgwZwvr16+natStBQUFUq1aN5OTkXKuRPb2kiysqKorHH3+cuLg4UlJSfLZG2LRpk7c9RHBwMCEhIbnuX7VqVV5//fVif50Kc/r0ad555x3eeecdjDFUr14dY0yuzf0uvfRSlixZQlCQ725HaWlprF27FmMMt956q6P5OSE1NZXZs2czffp0AgICCAsLw1qb6xnr1q3LRx99RIMGDXLNff3119mzZw8A8fHxXHrppX7vM3jwYF5++eWyeQgRERERERERP5wuHk8H7gTuMsastNYucDi+iJwl+vfvz3XXXcfs2bOJjY3l22+/5ejRoxhjiIyMpEOHDgwcOJCBAwf6LQwWZMKECbz99tukpqaWKk+n4vjTuXNnli1bRu/evZkzZw6BgYG8+eab3mJwnz592LNnD9OnT2fZsmX8+OOPnDhxgho1atCiRQu6detGVFQUjRs3LtH9IyMj6dWrF6tWrWLx4sUMHTo01/Xw8HBeeeUVvvjiC7755ht+/fVXkpKSCAkJoXnz5vTq1Yu//OUvfu+fmZnJ0aNHAVcxvDiioqLIzMxk48aN7N27l2PHjpGRkUG9evVo06YNt9xyC0OHDi3w+yM2NpaTJ0/Ss2dPmjZtWqz7l4dx48bRqlUr1qxZw48//sjhw4fJyMggPDyc1q1b07dvX+666y7CwsLyzfWsQgdX+5CCeognJSWVSf4iIiIiIiIiBTFO9gE1xlQHGgDvA5cCi4D3gG+A34As/7PBWlu03bf+xIwxW9q1a9duy5YtFZ2KiJwlFixYQFRUFH379nV0c0CAr776ii5dulC/fn327t1boj8ElMagQYNYuHAh77//PkOGDCnXe4uIiIiIiIjk1b59e7Zu3brVWtu+onMpD06vPP4tx8cGGOA+isKWQT4iIn94AwcO5LLLLmPZsmXs3LmTVq1aORb7888/B+Dxxx8v98Lxjz/+yOLFi7n44osZPHhwud5bRERERERERJzfMM/kOPL+uyiHiIgUU0BAAFOnTsVay5QpUxyNHRcXR7169bjnnnscjVsUzz//PFlZWUyZMsXbR1pEREREREREyo/TK33HFj5ERESc1qdPH6ZNm8apU6fIzMykcmVn/vMeGxvrSJziys7OplmzZrz44ov079+/QnIQERERERER+bNztOexlD31PBYREREREREREakYf7aex3ofsIiIiIiIiIiIiIjko+KxiIiIiIiIiIiIiOSj4rGIiIiIiIiIiIiI5OPohnnGmGmlmW+tfcSpXERERERERERERESk5BwtHgMPA6XZgU/FYxEREREREREREZGzgNPF42QKLx6H5LivBVKBTIfzEBEREREREREREZFScLR4bK2tUZRxxpimwDDgceAH4CZrbbyTuYiIiIiIiIiIiIhIyVXIhnnW2p+stU8D1wAtgM+MMVUrIhcRERERERERERERya9Cisce1tpNwOtAK1z9kkVERERERERERETkLFChxWO3WPf51grNQkRERERERERERES8zobi8XH3uWmFZiEiIiIiIiIiIiIiXmdD8bh5RScgIiIiIiIiIiIiIrlVaPHYGBMCPAFYYFdF5iIiIiIiIiIiIiIiv6vsZDBjzGVFGBYA1AQ6AqOAxu7X33UyFxEREREREREREREpOUeLx8B2XKuIi8q4z8uB1xzORURERERERERERE1e9KcAACAASURBVERKqCzaVphiHPuBvwL9rLVZZZCLiIiIiIiIiIiIiJSA08XjAUU4bgauASKttU2ttdNUOBYRKUMpv8KeFbDhZVj3N9d5zwrX6yJSrmJiYjDGMGLEiIpOxa9jx44RFhZGs2bNyMzMrOh0Su3nn38mMDCQjh07VnQqJCYmcvfdd9OwYUMCAwMxxtCjR4+KTktERERExC9Hi8fW2sVFOD6x1q6z1h5w8t4iIpKDtbDnM5gzEP5+IbwfBSsnwbrnXOf3o1yvzxnoGmeL03FIxHmpqam89tpr9OvXj0aNGlG1alVCQkJo0qQJt9xyC3PnziUtLS3fvMjISIwxGGN45JFHCrxHgwYNMMYwa9asMovzRzBlyhSSk5MZP348lSsX3uEsJSWFhg0bej9/5fl5+ec//+m9b2RkpM8xjRs3ZtiwYWzevJkFCxaUW255ZWZmcs011/DWW28RHx9PaGgo4eHh1KpVC4BDhw7x4osvEhUVxcUXX0ydOnUIDAykTp06dO/enenTp3P69Gm/sT/99FNGjx5Nhw4dCAsLo0qVKtSrV4+bbrqJjz/+uDwfVURERET+QMqibYWIiFSkk4dh/jB4/1bYu7rgsXtXu8bNH+aaJ1IBPvnkE5o1a8b999/P0qVLOXjwIAEBAVSqVIn9+/fzn//8h9tvv50LL7yQNWvW+I3z2muvcejQoVLn41Scc9GBAwd49dVXadiwIcOHDy/SnIkTJxIfH1/GmeUXHx/Pk08+WaSxTzzxBAEBAUycOJGsrIp5w9tnn33Gzp07qVWrFnv27OH48eMkJiaycOFCANavX89jjz3GggUL2LlzJykpKVStWpVjx44RFxfHmDFjaNu2rc/vzb/85S/ccMMNzJgxgy1btpCWlkZwcDCJiYl88sknDBgwgKioKDIyMsr7sUVERETkHKfisYjIH8nRH+BfPWDX0uLN27XUNe/oD2WRlYhfs2bNon///iQmJtKiRQvmzJnD0aNHSUlJITk5mRMnTrBgwQJ69OhBQkICcXFxfmOlp6fz7LPPljonp+Kci2bOnMnp06cZMWIEgYGBhY7funUrM2bM4IorriiH7HIbPXo0KSkpRbp38+bN6datG7t372bZsmXlkF1+33//PQA9e/akefPm+a43atSIyZMns2bNGo4dO0Z6ejpJSUkkJSXxr3/9i2rVqrFz507uuOOOfHMzMjKIiIhg0qRJbNu2jdOnT5OcnMyhQ4d44IEHAFiwYAETJkwo24cUERERkT8cR4vHxpjaxphp7iOiCOMjcoyv7mQuIiJ/OicPw+yb4GRCCecnwLs3awWylJtvvvmGUaNGkZ2dzQ033MC2bdsYNmwYtWvX9o4JCwtj0KBBrF27lnnz5hEaGuozVp8+fQB466232LdvX4lzcirOuSgzM5PZs2cDEB0dXej47Oxs7rvvPsC1Wrs8LVmyhI8//pgBAwbQu3fvIs0ZMmQI4PraVgRP25Vq1ar5vH7llVcSExNDz549va0sAKpXr84999zDP//5TwDWrFnDwYMHc829//77+emnn3jqqado06YNxhgAIiIimDFjhrfH9syZM322fxERERER8cfplcdDgYeB6621hVYv3GOuBx4CbnM4FxGRPw9rYenYkheOPZIPQewj6oEs5WLi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PPEEH3zwAenp6YwYMYJDhw4VOu+NN95g/PjxALz00kv5NvITERERESkKp4vHs93nFsAcY0yQv4Hua++6x+acKyIixREYXEZxfb+9XcQJrVq1AlxFy927dzse/+mnnyYgIIA1a9awZs2aMo+TlZXlt6h75syZfOO7detGREQEGRkZ3H333aSl+f9jjafIefnll2OtLfSYNWuWzziVKvn/u36tWrW8H584ccLnmIceeoisrCymTJmCtZaUlJRch8fp06dJSUnxW8QurrVr17Jw4UIuueQS7rjjjnz39Xx+c+aUmZnpM5ZnRXCNGjUICPj9x+Djx4/7/NolJSU58gxO6NevH40bNyY1NZV58+YVOHbOnDncf//9AMTExDB27NjySFFERERE/oAcLR5ba78AFuBafTwY+N4Y81djzBXGmEbu4wpjzP8B37vHWGCJtbbkv9mJiPyZnd+qbOJeUEZxRYDu3bt7e8YuWbLE8fitW7cmOjoagAkTJpR5nMjISL/FXF/9eZs0acLq1asJDw9n7dq19O/fP9fq35zCw8MB/+0onJCzz7G/lgs///wzAHfccQehoaH5Do9Ro0YRGhrqWFsLz32///57atSoke++zz//PAAHDhzwvjZ37lyfsTzPlrev87p164pViK8onrYYe/fu9Tvmo48+4s477yQ7O5tHH32UyZMnl1d6IiIiIvIH5PTKY4AR/N6+ognwN2AjsM99bASmAk3dYzYC5bdVt4jIH01E23MrrgjQoEEDbrjhBgCmT59OcnJykeYVp8VFTEwMlStX5quvvmLp0qUlytPJOHm1bNmSVatWUadOHVasWMGgQYN8rlL29Co+fvw4mzZtcuz+OdWuXdtbUN23b1+Z3ONssH//fsD1uT8XefL3t2neJ598wtChQ8nKymLUqFGl6g8tIiIiIgJlUDy21qYC1wATgeO4CsS+jqPuMT2staeczkNE5E+j2vnQrJezMS+8FkLqFD5OpBSeffZZgoKCiI+P57bbbiM9veD+3R9++CHTpk0rcvzmzZszfPhwAJ588skS91Z2Ko4vrVu3ZuXKldSsWZPY2Fiio6PztVxo2bIlnTt3BuCxxx4rsJ9uWlqa3xXMhbnyyisB2Lx5s8/r+/fvL7Bdhsc777yDtdZb6CytESNGFHhfz8raxo0be18bMWKEz1hff/01AFdffbUjuTnJX6sNj/fee4+EhAQAunbtmu/6ypUriYqKIiMjg+HDh/Pqq6+WSZ4iIiIi8udSFiuPsdZmWWufA+oDPYFHca02ngr81f1aA2vtc9barLLIQUTkT+WK+5yN18nheCI+tGnThpkzZ2KMITY2lrZt2zJ37lyOHz/uHZOUlMTChQvp2bMngwcP5uTJk8W6x6RJk6hSpQrbt2/3Ft5Kwqk4vrRp04YVK1YQFhbGokWLvCtHc3rllVcICgoiLi6OXr168cUXX3h7IWdlZbFjxw6efvppmjZt6t1gr7g8BVVPgbUsGGMwxhATE1Nm9/DHWsuWLVsAV8/ps023bt2YOnUq//vf/3J9/Q8cOMBTTz3FXXfdBbg2cuzbt2+uuRs2bPC2PomOjubtt9/2toURERERESmNymUZ3Fp7BvjcfYiISFlpfj20vBF2OfCW+pY3QvPrSh9HpAhGjhxJ7dq1ue+++9i1axe333474HpbvjEmV7G4cePGXHPNNcWK36hRI+69915mzJhRqjydiuNPhw4dWL58Oddffz0ffvghQUFBzJo1y7upW8eOHVm0aBFDhgxh/fr1dO3alaCgIKpVq0ZycnKu1cglLRpGRUXx+OOPExcXR0pKit/WCOeqDRs2cOLECSIjI7niiisqOp18EhISGD9+POPHjycwMJDq1auTnp7OqVO/v0GvY8eOLFmyJNdmf+BaEe/ZoHDVqlVERET4vc/LL7/M4MGDy+YhREREROQPp0xWHouISDkzBvpOg1D/BYMiqV7fFUcr1qQc9e/fn59++omZM2dyww030KBBAzIzM8nMzCQyMpJbbrmF999/n927d5doxeiECROoWrVqqfN0Ko4/nTt3ZtmyZYSEhDBnzhzuueeeXO0g+vTpw549e5g4cSLt2rUjKCiIEydOUL16da688krGjRvHli1baNy4cYnuHxkZSa9evUhLS2Px4sVOPZZXzhXRHTt2dDx+YebNmwfAnXfeeVauyp01axaPP/44Xbp0ITw8nJSUFLKzs4mMjGTgwIF88MEHfPnll9StWzffXM8qdICjR49y+PBhv0daWlp5PpaIiIiInOOMk337jOsn8Uvd/9xbWC9jY0w1XBvnYa391rFE/sCMMVvatWvXzvO2SxGRXI7+AO/eDMmHij+3en24YwnUudD5vETknLBgwQKioqLo27evo5sDgqt4O2TIENq3b++3r3JZyczMpEGDBhw7doyffvqJhg0bluv9RUREROSPo3379mzdunWrtbZ9RedSHpxeedwX2I6rTUVRYgcAccA2Y4zeIy0iUlp1msM9a12tJ4qj5Y2ueSoci/ypDRw4kMsuu4xly5axc+dOR2N//rmri5lng7vyNGfOHA4fPszIkSNVOBYRERERKQani8cD3ef/WGsL3dHGWpsMfAQYIMrhXERE/pxCw2HwXLjtI7jw2oLHXnita9zgua55IvKnFhAQwNSpU7HWMmXKFEdjx8XF0bZtW/r16+do3MJkZ2czdepUzjvvPCZNmlSu9xYREREROdc5vWHeFYAFVhdjzipgJNDF4VxERP68jIGLrncdp45CwjY4shMy0iDwPLigFUS0hZA6FZ2piJxl+vTpw7Rp0zh16hSZmZlUruzMj4vff/+9I3GKKyEhgSFDhnDJJZcUuJGciIiIiIjk53TP4xTgPKCztfbrIs7pCGwCUqy11R1L5g9KPY9FREREREREREQqhnoel45naUpWMeZ4tocOcjgXERERERERERERESkhp4vHR93npsWY08R9Pu5wLiIiIiIiIiIiIiJSQk4Xj79xn4uz+d2t7vN3DuciIiIiIiIiIiIiIiXkdPF4CWCAQcaYmwsbbIwZAAzCtcneYodzEREREREREREREZEScrp4/A5wEFcB+SNjzLPGmAvyDjLGhBtjngPmuV9KAN50OBcRERERERERERERKaHKhQ8pOmvtGWPMIGAdUBUYD4wzxvwA/OIeVg9ojqvAbIA04BZrbbqTuYiIiIiIiIiIiIhIyTlaPAaw1m42xlyFa1VxC1wF4hbARe4hJsfw3cBt1tptTuchIiIiIiIiIiIiIiXnePEYwFr7jTHmYmAgcCPQDjjfffkosAX4BPjYWptdFjmIiIiIiIiIiIiISMmVSfEYwFprgf+4DxERERERERERERE5hzi9YV6JuVcqi4iIiIiIiIiIiMhZoEKLx8aYWsaYB40xXwPfVmQuIiIiIiIiIiIiIvK7Mmtb4Y8xpjLQFxgO3AAE4tpEz5Z3LiIiIiIiIiIiIiLiW7kVj40x7XEVjKOB2p6X3ed0YFl55SIiIiIiIiIiIiIiBSvT4rExph4wDFfRuJXnZff5FPApsACItdaeKstcRERERERERERERKToHC8eG2OCgQHAHcC1uPoqmxxDLDAFeN5am+b0/UVERERERERERESk9BwrHhtjrsa1wjgKCPW87D5/BcwBZrr//Z0KxyIiIiIiIiIiIiJnr1IVj40xkbhWGN8BNPG87D7vBd4D5lprf3SPn4mIiIiIiIiIiIiInPVKXDw2xnwOXIWrWOwpGB8HPgTmWGu/LH16IiIiInLWSPkVErbBrzshIx0Cg+H8VhDRFqqdX9HZiYiIiIiIw0qz8rir+5wOxAJzgWXW2oxSZyUiIiIiZwdr4YcVsOkN2Lva/7hmveCK+6D59WCM/3EiIiIiInLOKG3PYwtUAoKAKrg2xxMRERGRP4KThyH2Edi1tPCxe1e7jpY3Qt9pEBpe9vmJiIiIiEiZKk2xdw2u4nEg0BeYByQaY940xnR3IjkRERERqSBHf4B/9Sha4TinXUtd847+UBZZiYiIiIhIOSpx8dhaey0QCUwEfsDV9zgMuBNYY4zZb4yZYoxp5USiIiIiIlJOTh6G2TfByYQSzk+Ad292xRERERERkXNWqdpMWGvjrbXPWWtbAl2AN4ATuArJjYBxwHfGmK+NMQ+XOlsRERERKVvWwtKxJS8ceyQfcrW8sNaZvEREREREpNw51qPYWrvJWvsXoB5wK65N9LJwFZLbAy/lGN7BGFPdqXuLiIiIiEN+WAG7Y52JtWsp/LDSmVgiIiIiIlLuHN/gzlp7xlq7wFrbD2gA/BX4FlcR2eNR4LAxZqkxZoQxpobTeYiIiIhICWx6w9l4/3U4noiIiIiIlBvHi8c5WWuPWGunWWvbAG2Bl4FfcRWSg4A+wFu4CsmflmUuIiIiIlKIlF9h72pnY/64Ck4ddTamiIiIiIiUizItHudkrf3GWjsWqA/cBPwHyMBVSA4Eri+vXERERETEh4Rt51ZcEREREREpU+VWPPaw1mZZa5daa6Nw9Ud+APi6vPMQERERkTx+3Vk2cY+UUVwRERERESlT5V48zsla+5u19jVr7RXAxRWZi4iIiMifXkZ6GcVNK5u4IiIiIiJSpiq0eJyTtXZ3RecgIiIi8qcWGFxGcc8rm7giIiIiIlKmzprisYiIiIhUsPNblU3cC8ooroiIiIiIlCkVj0VERETEJaLtuRVXRERERETKlIrHIiIiIuJS7Xxo1svZmBdeCyF1nI0pIiIiIiLlQsVjEREREfndFfc5G6+Tw/FERERERKTcqHgsIiIiIr9rfj20vNGZWC1vhObXORNLRERERETKnYrHIiIiIvI7Y6DvNAiNKF2c6vVdcYxxJi8RERERESl3Kh6LiIiISG6h4TB8iasAXBLV68MdS1xxRERERETknKXisYiIiIjkV6c53LO2+C0sWt7omlfnwrLJS0REREREyo2jxWNjzG/GmGPGmBbFmBPpmedkLiIiIiJSSqHhMHgu3PYRXHhtwWMvvNY1bvBcrTgWEREREfmDqOxwvDDAApWKMadSjnkiIiIicjYxBi663nWcOgoJ2+DITshIg8Dz4IJWENEWQupUdKYiIiIiIuIwp4vHIiIiIvJHFVIHml/nOkRERERE5A/vbOh5XNN9PlWhWYiIiIiIiIiIiIiIV1kVj4vUgsIYUwm4x/3PfWWUi4iIiIiIiIiIiIgUU6naVhhjtvq59B9jTHoh04OAhkAIrmLzp6XJRUREREREREREREScU9qex21wFX5NjtcM0LKYcXYAz5cyFxERERERERERERFxSGmLx0vI3aLiZve/1wInC5hngXTgF2AjsMRam1HKXERERERERERERETEIaUqHltr++f8tzEm2/3hGGvt/0oTW0REREREREREREQqjtMb5r3iPo46HLfYjDENjDFvG2MSjDGnjTH7jTH/NMbULGacQcaYdcaYJGNMmjHme2PMeGNMFR9jmxtjHjfGrDHGHDTGnDHGHDbGLDbG9HTu6URERERERIonJiYGYwwjRoyo6FT8OnbsGGFhYTRr1ozMzMyKTqfUfv75ZwIDA+nYsWNFp0JiYiJ33303DRs2JDAwEGMMPXr0qOi0RETkLOdo8dha+7C1dqy19oiTcYvLGNMM2ALcCfwX+AfwE/AQ8KUxpnYR4zwHLADaA4uA14BU4DlgmTEmMM+UZ4CpQDiwDHgJ2AD0BdYYY8aU7slERERERMRpqampvPbaa/Tr149GjRpRtWpVQkJCaNKkCbfccgtz584lLS0t37zIyEiMMRhjeOSRRwq8R4MGDTDGMGvWrDKL80cwZcoUkpOTGT9+PJUr536j7ObNm3nyySfp3bs3F154IWFhYQQFBVG/fn1uvvlmPv744zLJ6cyZM7z++uvcddddtGvXjoiICKpUqUL16tVp164d48eP55dffvE5t3HjxgwbNozNmzezYMGCMsmvKDIzM7nmmmt46623iI+PJzQ0lPDwcGrVqgXAoUOHePHFF4mKiuLiiy+mTp06BAYGUqdOHbp378706dM5ffq039iffvopo0ePpkOHDoSFhVGlShXq1avHTTfdVGZfFxERKSfW2nI9cG2o1w64HmheRvf4DFdf5dF5Xp/mfv31IsRo5x77G9A0T/6vua89kmfOCKCtj1jdgTPAaaBeKZ9tS7t27ayIiIiIiJTekiVLbN26da3753sL2JCQEBsaGprrtYiICLt69epccxs3buy9HhwcbOPj4/3ep379+haw77zzTr5rTsUpzOTJky1ghw8fXuy55eHnn3+2QUFBtmHDhvbMmTP5rt933325vibVqlWzwcHBuV4bNGiQz7ml8csvv+S6R6VKlWzNmjWtMcb7WlhYmF2zZo3P+Xv27LEBAQG2RYsWNjMz09Hcimrp0qUWsLVq1bJ79uzJd/2DDz7I9YxBQUG2evXquV5r1aqVz+/Nu+++O9e4wMDAfP/7ueWWWxz/uoiIVJR27dpZYIst55pqRR2Orjw2xtQzxjzmPmr4uH4JsBP4GvgU2GWMWWGMOd/BHJrhKkzvB2bmuTwZOAXcbowJKSSUp5/zm9banzwvWmst8IT7nw/knGCtnWWt3ZY3kLX2c2AdUAW4skgPIiIiIiIiZWrWrFn079+fxMREWrRowZw5czh69CgpKSkkJydz4sQJFixYQI8ePUhISCAuLs5vrPT0dJ599tlS5+RUnHPRzJkzOX36NCNGjCAwMO+bPKFLly784x//YMuWLZw8eZKTJ0+SlpbGgQMH+L//+z8A/vOf/zB16lRH8woODubhhx9m4cKFHDp0iDNnznD8+HHS09NZtmwZLVu2JCkpiaioKE6cOJFvfvPmzenWrRu7y5JwsQAAIABJREFUd+9m2bJljuZWVN9//z0APXv2pHnz5vmuN2rUiMmTJ7NmzRqOHTtGeno6SUlJJCUl8a9//Ytq1aqxc+dO7rjjjnxzMzIyiIiIYNKkSWzbto3Tp0+TnJzMoUOHeOAB16/MCxYsYMKECWX7kCIiUiac7nk8EFfbhhHW2lz/r2mMCQaWAs1xrd71HL2AJcYY41AOnt7CK6y12TkvWGtP4mojURXoXEicuu7zT3kvWGt/w70i2RjTpIh5ZbjP537jLhERERGRc9w333zDqFGjyM7O5oYbbmDbtm0MGzaM2rV/73AXFhbGoEGDWLt2LfPmzSM0NNRnrD59+gDw1ltvsW/fvhLn5FScc1FmZiazZ88GIDo62ueY4cOH8/DDD9OuXTuqVavmfb1hw4a88MILDBs2DMDxlh41atTgH//4BwMGDCAiIoKAANev0VWqVKFPnz4sXboUcPVr/uSTT3zGGDJkCOD62lYET9uVnJ+3nK688kpiYmLo2bOnt5UFQPXq1bnnnnv45z//CcCaNWs4ePBgrrn3338/P/30E0899RRt2rTB86t9REQEM2bM8PbYnjlzps/2LyIicnZzunh8Ha63pSz2ce1OoLH744+A+3D1EzZAJ8D3TwjF18J93uPn+g/u80WFxPFs+pevOOxeVe3ZeK9F3us+xjfGVSRPBfwvV8g9Z4uvA2hZlPkiIiIiIuLfxIkTOX36NPXr1+f999/nvPPOK3D84MGD/fYjvummm+jUqRMZGRnExMSUOCen4pTU888/jzGG4OBgFi/O/yvd/v37GT16NC1atKBq1aqEhobSvn17/va3v3Hq1CmfMT29nPfv38/OnTsZPny4d8O2/v37e8ctW7aMw4cPc8kll3DxxReXKH/PpnQJCQklml9SzZo1o2bNmgXee9CgQQQEBBAbG8uRI8XfImj//v3ezyXAd999R3R0NHXr1iU4OJiWLVvyzDPPcObMmVzzRowYgTHG+/00e/ZsbxzP16Uocm74l/cZO3XqRFBQkN+5nuJxamoqO3fuLNL9RETk7OF08djz/pdNPq55isMrrbWDrbX/ttbeCizHVUAe7FAOYe5zkp/rntfztdXII9Z9vscYE+l50b1CekqOcTUpgDEmCHgPCAJi3KuWRURERESkghw6dIjYWNeP+2PGjCEsLKyQGS4FvVnS02rivffeY9euXSXOzak4xfX444/zxBNPEBISQmxsLDfffHOu6wsXLqRVq1bMmDGDPXv2YIzh9OnTbN26lXHjxtGlSxcOHz7sN/769evp0KED7777LklJSfk2w1uxYgUAV111VYmfYePGjQA0aVLUN4c6Y9euXfz2228F3rt27dq0bNmSzMxM1q5dW6r7rVixgk6dOjF//nzS09PJyMhg9+7dTJo0iVtvvTXX2LCwMMLDwwkJcXVtDA4OJjw83HtUqlSpSPf0fG7BtcFjceRczZ+VlVWsuSIiUvGcLh5f4D7H53zRGHMerjYRFngzz5zZ7nNbh3MpFWvt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hPbt2/vtq1xWMjMzadCgAceOHeOnn36iYcOG5Xp/ERFxVvv27dm6detWa237is6lPDja89gY0wCYhWtF8xbgSiDY33hrbSrwsfuf/8/JXEREREREROTcMXDgQC677DKWLVvGzp07HY39+eefAzB58mRH4xbFnDlzOHz4MCNHjlThWEREzjlOb5g3FjgP2Av0tNZ+ZQtf2vw5rhXK7RzORURERERERM4RAQEBTJ06FWstU6ZMcTR2XFwcbdu2pV+/fo7GLUx2djZTp07lvPPOY9KkSeV6bxERESc43fP4OlztKf5hrT1V2GC33e5zyZpjiYiIiIiIyB9Cnz59mDZtGqdOnSIzM5PKlZ35lfX77793JE5xJSQkMGTIEC655JICN5ITERE5WzldPI50n78uxhzPFsb5t9MVERERERGRP5WxY8dWdAqOadCgATExMRWdhoiISIk53bbCs/VqcYrSni1pUxzORURERERERERERERKyOnicaL73KQYczq5zwcdzkVERERERERERERESsjp4vEGXJvf3VKUwcaYQOA+XH2SP3c4FxEREREREREREREpIaeLx7Pd55uNMdcUNNBdOJ4FNHO/9KbDuYiIiIiIiIiIiIhICTlaPLbWrgYW4Vp9vNQY87Qx5rIcQ+oaY9oZY8YA3wLRuFYdv22t/dbJXERERERERERERESk5IqzsV1R3Q4sBXoAE9yHdV9bmWOccZ8/Ax4ogzxEREREREREREREpIScbluBtTYVuBb4P1wb6Bk/xzFgHNDXWnvG6TxEREREREREREREpORKvPLYGNPI/eEha21WzmvW2mzgJWPMy0AnoANwAVAJOApsAzZYa0+X9P4iIiIiIiIiIiIiUnZK07ZiP5ANXAb8z9cAa20msNF9iIiIiIiIiIiIiMg5orRtK0zhQ0RERERERERERETkXON4z2MREREREREREREROfepeCwiIiIiIiIiIiIi+ah4LCIiIiIiIiIiIiL5qHgsIiIiIiIiIiIiIvk4UTy2DsT4/+zdeXxU1d3H8e8JhAQwC5vBsAVpJBTKDuKGII8URCiLkSAqUFApFlvEVwuCELcW20pRwBarPiDaQkVxIdGGsIiCWlks6MOiLLIGZEkCWch2nj8mM024MyHLJIHweb9e85rJvef+zrmZ+M/Xw+8CAAAAAAAAAC4htf1QI8kYk+uH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+eWX9fbbb6tv375+XdcvfvELvfLKK56fAwMDFRwcrJSUFH3wwQf64IMPdNddd+nvf/+7AgMDHdc//vjjev311zVz5kwNGzZMtWrV8uv6SuNf//qXdu7cqYYNG+rzzz9XdHR0sfPdunXTd9995/m5Xr16kqR9+/Zp3759Wrp0qZ577jlNnTq1VPMdPnxYTzzxhP9uAAAAAAAAAJLYeVxljDFjJb0rV3C8W9J9khpba6+y1oZKCpd0l6T1kiIl9fZVy1qrZ555psJrys7O9kudy9HChQt1/vx5jR071hHC5ufnS5IGDRqkt956S6dPn1ZaWpoyMzOVmJio1q1b68yZMxo6dKhSUlL8uq7c3FxFRkZq1qxZ2rZtm86fP6/09HQdOXJEDz/8sCRpxYoVmjFjhtfro6Oj1bt3b+3evVuJiYl+XVtpffPNN5Kkvn37OoJjyXWPXbp00cKFC3XgwAFlZGTo3Llz+s9//qO+ffsqPz9fjz32WKnXP3nyZJ07d07XX3+9X+8DAAAAAADgSkd4XAWMMZ0k/VWu33eipC7W2jestafcY6y1adbat621fSXFSTrro1y6JL366qvav39/udc0cOBA+aPO5SgvL09LliyRJMXFxTnON2jQQNu2bdOqVat01113qUGDBpKkOnXqaODAgUpMTFRwcLDS09O1aNEiv65t0qRJ2rdvn5588kl17txZxhhJUmRkpBYsWODpIb1w4UJlZWV5rTFq1ChJru+2OrjXddVVV3k9v3TpUm3dulWTJk1Sq1atJEkBAQHq2LGjEhIS1K5dO0nSH//4x4vO9f777+vdd9/VsGHDNGDAAD/dAQAAAAAAACTC46ryjKQgSUck3WOt9Z76FbLWLpc018fp1Hr16ik3N1fx8fHlXtCQIUPUs2fPCtcpr9///vcyxig4OFjvvfee4/yBAwc0efJktW3bVvXq1VNISIi6deum5557ThkZGV5runveHjhwQDt37tSYMWM8D2wbOnSoZ1xiYqKOHz+u9u3b68c//rGjTlhYmDp16uRz7TExMerVq5ckacuWLWW99RL17NlTQUFBPs+7w+PMzEzt3LnT65gRI0YoICBACQkJOnHiRJnXcODAAc/vUpK+/vprxcXFqWnTpgoODlZMTIyeft5YRpgAACAASURBVPpp5eTkONZmjPH8PS1ZssRTx/29SNItt9zic+66detq5MiRki7+uz137px++ctfqn79+po3b16Z7xMAAAAAAAAlIzyuZMaYZpIGFf74orU2rTTX2aINdy8QGRkpSXrzzTe1a9eucq/N3bKionXK6re//a0ef/xx1a9fXwkJCfrZz35W7Pw777yjdu3aacGCBdqzZ4+MMTp//ry2bt2qadOm6YYbbtDx48d91v/kk0/UvXt3vf7660pLS3M8DC8pKUmSdNNNN5X7Hho1aiTpvy0uqop73pLmbtSokWJiYpSXl6d169ZVaL6kpCT17NlTy5cvV3Z2tnJzc7V7927NmjVLd999d7GxYWFhioiIUP369SVJwcHBioiI8LxK23+5tL/bWbNm6dChQ3riiSfUsmXLctwdAAAAAAAASkJ4XPn6SDKFn9/3R8HQ0FDdeuutys/P16xZs8pd5/bbb/dLndIqKCjQxIkT9Yc//EHh4eFavXq1+vXrV2zMl19+qbi4OOXl5WnGjBk6fPiwMjIylJWVpU2bNql79+7asWOH7r//fp/zTJo0ST169NCOHTuUnp6uzMxMPf/8857zGzdulOR6cFt55OXleWp06NChXDXK6+OPP5bkepDedddd53Nc9+7dJbmC9IoYOXKkBg8erP379ys1NVXp6emeXePvvfdesb7EL7zwglJSUvTYY495rk1JSfG8WrRoUao53fdY0u9227ZtevHFF9WuXTs9+uijFbhDAAAAAAAA+EJ4XPnaFb6fl+tBeX7h3jW8YsUKffXVV9Ve52Jyc3M1evRoLVq0SFdffbXWr1+vG264wTFuypQpys3N1YIFC/TMM8+oWbNmkqRatWrphhtu0L/+9S9dc801SkpK0ubNm73OdfXVV+vDDz/0hI/GGLVp00aS6yGBO3bskCR17NixXPeycOFCpaSkKCAgQGPGjClXjfI4d+6c5syZI0kaPny4wsLCfI51t9344osvKjRnjx49tGzZMkVFRUmS6tevr2nTpmnQINdm+hUrVlSo/oW2bt2qlStXSpLGjRvndUxBQYEefPBB5efn66WXXnI88BAAAAAAAAD+QXhc+dx9Bs6U1IqirG6++WYNGDBA1lrNnDmz2uuUJCsrS8OGDdOyZcvUokULffLJJ157Cu/du1cbN25UeHi4xo8f77VWw4YNPQ/7W716tdcxv/zlL1W3bl2v506cOOFph9C4ceMy38v27ds1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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 493,
       "width": 711
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figure(figsize=(10,7))\n",
    "col = dict(zip(['L','C'], mpl.colors.TABLEAU_COLORS))\n",
    "for k,v in results_same_params.items():\n",
    "    a = 0.003\n",
    "    if 'n_L8' in k: \n",
    "        a = -0.004\n",
    "        #continue\n",
    "    x = v['params']\n",
    "    y = v['acc']\n",
    "    plot([x], [y], marker='o', ms = 10, c=col[k[:1]])\n",
    "    text(x, y+a, k, ha='center', size = 12)\n",
    "    \n",
    "xlim(1.7e5, 2.4e5)\n",
    "\n",
    "ylim(0.89, 0.96)\n",
    "ylabel('Test Accuracy',size = 14)\n",
    "\n",
    "xlabel('# parameters',size = 14)\n",
    "title('L-conv vs CNN matching parameters\\nRot. Scrambled %s'%(dataset_name), size = 14)\n",
    "xt = xticks()[0]\n",
    "xticks(xt, [r'$%.1f\\times10^5$'%(i/1e5) for i in xt],rotation=30);\n",
    "\n",
    "tight_layout()\n",
    "# grid()\n",
    "\n",
    "savefig('figs/L-conv-CNN-match-%d.pdf'%(len(results_same_params)))\n",
    "savefig('figs/L-conv-CNN-match-%d.png'%(len(results_same_params)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Shallow FC with parameters matching the L-conv model "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The parameters \n",
    "xs * u + u* 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1075"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xs = np.prod(inp.shape[1:])\n",
    "# u = int(0.5+ lay.count_params()/ xs)\n",
    "u = int(.5+ model.count_params() / (model.output_shape[-1] + xs ))\n",
    "u"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_3\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         [(None, 32, 32, 3)]       0         \n",
      "_________________________________________________________________\n",
      "flatten_1 (Flatten)          (None, 3072)              0         \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              (None, 1075)              3303475   \n",
      "_________________________________________________________________\n",
      "dense_2 (Dense)              (None, 100)               107600    \n",
      "=================================================================\n",
      "Total params: 3,411,075\n",
      "Trainable params: 3,411,075\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "net = configs['net']\n",
    "\n",
    "inp = Input(x_train[0].shape)\n",
    "\n",
    "x = inp\n",
    "\n",
    "x = Flatten()(inp)\n",
    "# FC comparable to L-conv, but no shared weights \n",
    "x = Dense(u, activation = net['activation'])(x)\n",
    "\n",
    "out = Dense(y_train.shape[-1], activation='softmax')(x)\n",
    "\n",
    "model = Model(inputs = [inp], outputs = [out])\n",
    "model.compile(loss = tf.keras.losses.categorical_crossentropy, metrics = ['accuracy'])\n",
    "\n",
    "model.summary()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 4.3505 - accuracy: 0.1206 - val_loss: 4.1713 - val_accuracy: 0.1420\n",
      "Epoch 2/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.9070 - accuracy: 0.1848 - val_loss: 4.2039 - val_accuracy: 0.1650\n",
      "Epoch 3/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.7058 - accuracy: 0.2255 - val_loss: 4.1117 - val_accuracy: 0.1878\n",
      "Epoch 4/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.5451 - accuracy: 0.2544 - val_loss: 4.8140 - val_accuracy: 0.1781\n",
      "Epoch 5/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.3958 - accuracy: 0.2869 - val_loss: 4.3992 - val_accuracy: 0.1821\n",
      "Epoch 6/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.2576 - accuracy: 0.3169 - val_loss: 4.5950 - val_accuracy: 0.1988\n",
      "Epoch 7/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.1092 - accuracy: 0.3451 - val_loss: 4.9388 - val_accuracy: 0.1893\n",
      "Epoch 8/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.9819 - accuracy: 0.3800 - val_loss: 5.1262 - val_accuracy: 0.1933\n",
      "Epoch 9/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.8600 - accuracy: 0.4033 - val_loss: 5.4323 - val_accuracy: 0.1927\n",
      "Epoch 10/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.7234 - accuracy: 0.4313 - val_loss: 5.6304 - val_accuracy: 0.1902\n",
      "Epoch 11/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.6202 - accuracy: 0.4598 - val_loss: 5.6795 - val_accuracy: 0.2021\n",
      "Epoch 12/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.4936 - accuracy: 0.4812 - val_loss: 6.2062 - val_accuracy: 0.1952\n",
      "Epoch 13/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.3621 - accuracy: 0.5110 - val_loss: 6.3498 - val_accuracy: 0.2006\n",
      "Epoch 14/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.2828 - accuracy: 0.5314 - val_loss: 6.8185 - val_accuracy: 0.2076\n",
      "Epoch 15/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.1961 - accuracy: 0.5562 - val_loss: 6.9912 - val_accuracy: 0.1992\n",
      "Epoch 16/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.0824 - accuracy: 0.5715 - val_loss: 7.3662 - val_accuracy: 0.2000\n",
      "Epoch 17/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.0096 - accuracy: 0.5952 - val_loss: 7.7374 - val_accuracy: 0.1947\n",
      "Epoch 18/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.9498 - accuracy: 0.6051 - val_loss: 8.0833 - val_accuracy: 0.2032\n",
      "Epoch 19/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.8755 - accuracy: 0.6250 - val_loss: 8.6338 - val_accuracy: 0.1993\n",
      "Epoch 20/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.7955 - accuracy: 0.6419 - val_loss: 8.6264 - val_accuracy: 0.2086\n",
      "Epoch 21/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.7687 - accuracy: 0.6562 - val_loss: 8.9263 - val_accuracy: 0.2076\n",
      "Epoch 22/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.6695 - accuracy: 0.6693 - val_loss: 9.6866 - val_accuracy: 0.2030\n",
      "Epoch 23/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.6299 - accuracy: 0.6830 - val_loss: 9.7473 - val_accuracy: 0.2070\n",
      "Epoch 24/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.5655 - accuracy: 0.6931 - val_loss: 10.7333 - val_accuracy: 0.2005\n",
      "Epoch 25/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.5255 - accuracy: 0.7073 - val_loss: 10.8067 - val_accuracy: 0.2012\n",
      "Epoch 26/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.4941 - accuracy: 0.7142 - val_loss: 10.9942 - val_accuracy: 0.2002\n",
      "Epoch 27/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.4608 - accuracy: 0.7237 - val_loss: 11.6645 - val_accuracy: 0.2034\n",
      "Epoch 28/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.3985 - accuracy: 0.7359 - val_loss: 11.6220 - val_accuracy: 0.2058\n",
      "Epoch 29/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.3767 - accuracy: 0.7433 - val_loss: 12.3072 - val_accuracy: 0.2017\n",
      "Epoch 30/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.3341 - accuracy: 0.7549 - val_loss: 12.7778 - val_accuracy: 0.1996\n"
     ]
    }
   ],
   "source": [
    "h = model.fit(x_train, y_train, validation_split=0.2, epochs=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 248,
       "width": 373
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in ['accuracy', 'val_accuracy']:\n",
    "    plot(h.history[k], )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "./results-v2/cifar100/FC_shallow-u1075-n_lay-1-act-relu-rotate=False-scramble=False.json\n"
     ]
    }
   ],
   "source": [
    "model_name = f\"FC_shallow-u{u}\" \n",
    "\n",
    "\n",
    "model_name += f\"-n_lay-{net['num_layers']}\"\n",
    "model_name += f\"-act-{net['activation']}\"\n",
    "num_params = model.count_params() \n",
    "out_file_name = f\"./results-v2/{dataset_name}/{model_name}-rotate={bool(configs['dataset']['rotate'])}-scramble={bool(configs['dataset']['scramble'])}.json\"\n",
    "\n",
    "configs['net']['architecture'] = 'fc_shallow'\n",
    "\n",
    "results = {}\n",
    "results.update({\n",
    "    'num_params':num_params,\n",
    "    'result':h.history,\n",
    "    'configs':configs,\n",
    "#     'result': {k: np.float32(v).tolist() for k,v in h.history.items()}, # bug in json or TF2\n",
    "          })\n",
    "\n",
    "\n",
    "\n",
    "# for k,v in results['result'].items():\n",
    "#     print(k,type(v))\n",
    "\n",
    "import os\n",
    "\n",
    "# print(h.history)\n",
    "\n",
    "dirs = os.path.split(out_file_name)[0]\n",
    "os.makedirs(dirs,exist_ok=True)\n",
    "\n",
    "print(out_file_name)\n",
    "\n",
    "json.dump(results, open(out_file_name, 'w'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CNN + Max pool"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'dataset': {'name': 'cifar100', 'rotate': True, 'scramble': True},\n",
       " 'net': {'architecture': 'lconv',\n",
       "  'num_filters': 32,\n",
       "  'kernel_size': 9,\n",
       "  'L_hid': [8],\n",
       "  'activation': 'relu',\n",
       "  'L_trainable': True,\n",
       "  'num_layers': 1}}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "net['num_layers'] = 1\n",
    "configs\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_3\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         [(None, 32, 32, 3)]       0         \n",
      "_________________________________________________________________\n",
      "conv2d (Conv2D)              (None, 30, 30, 32)        896       \n",
      "_________________________________________________________________\n",
      "max_pooling2d (MaxPooling2D) (None, 29, 29, 32)        0         \n",
      "_________________________________________________________________\n",
      "flatten_1 (Flatten)          (None, 26912)             0         \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              (None, 100)               2691300   \n",
      "=================================================================\n",
      "Total params: 2,692,196\n",
      "Trainable params: 2,692,196\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "net = configs['net']\n",
    "\n",
    "kx = int(0.5+np.sqrt(net['kernel_size']))\n",
    "ky = int(0.5+net['kernel_size']/kx)\n",
    "kernel_size = (kx,ky)\n",
    "\n",
    "\n",
    "inp = Input(x_train[0].shape)\n",
    "\n",
    "x = inp\n",
    "for _ in range(net['num_layers']):\n",
    "    x = Conv2D(filters=net['num_filters'], \n",
    "                 kernel_size=kernel_size, \n",
    "                 activation = net['activation'])(x)\n",
    "\n",
    "    x = MaxPool2D(pool_size=(2, 2),strides=(1, 1), padding='valid')(x)\n",
    "\n",
    "\n",
    "x = Flatten()(x)\n",
    "\n",
    "# x = Dense(100, activation = 'relu')(x)\n",
    "\n",
    "out = Dense(y_train.shape[-1], activation='softmax')(x)\n",
    "\n",
    "model = Model(inputs = [inp], outputs = [out])\n",
    "model.compile(loss = tf.keras.losses.categorical_crossentropy, metrics = ['accuracy'])\n",
    "\n",
    "model.summary()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.9167 - accuracy: 0.1236 - val_loss: 3.7271 - val_accuracy: 0.1473\n",
      "Epoch 2/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.5135 - accuracy: 0.1927 - val_loss: 3.6933 - val_accuracy: 0.1582\n",
      "Epoch 3/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.3421 - accuracy: 0.2239 - val_loss: 3.6467 - val_accuracy: 0.1758\n",
      "Epoch 4/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.2010 - accuracy: 0.2546 - val_loss: 3.6889 - val_accuracy: 0.1663\n",
      "Epoch 5/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 3.0754 - accuracy: 0.2845 - val_loss: 3.8055 - val_accuracy: 0.1799\n",
      "Epoch 6/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.9545 - accuracy: 0.3071 - val_loss: 3.7576 - val_accuracy: 0.1786\n",
      "Epoch 7/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.8452 - accuracy: 0.3301 - val_loss: 3.8578 - val_accuracy: 0.1732\n",
      "Epoch 8/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.7313 - accuracy: 0.3489 - val_loss: 3.8588 - val_accuracy: 0.1688\n",
      "Epoch 9/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.6140 - accuracy: 0.3762 - val_loss: 3.9497 - val_accuracy: 0.1739\n",
      "Epoch 10/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.5057 - accuracy: 0.4000 - val_loss: 3.9963 - val_accuracy: 0.1631\n",
      "Epoch 11/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.3924 - accuracy: 0.4230 - val_loss: 4.0768 - val_accuracy: 0.1632\n",
      "Epoch 12/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.2901 - accuracy: 0.4454 - val_loss: 4.1800 - val_accuracy: 0.1581\n",
      "Epoch 13/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.1808 - accuracy: 0.4697 - val_loss: 4.2969 - val_accuracy: 0.1600\n",
      "Epoch 14/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 2.0804 - accuracy: 0.4894 - val_loss: 4.4049 - val_accuracy: 0.1651\n",
      "Epoch 15/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.9885 - accuracy: 0.5112 - val_loss: 4.4964 - val_accuracy: 0.1609\n",
      "Epoch 16/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.8966 - accuracy: 0.5336 - val_loss: 4.6298 - val_accuracy: 0.1590\n",
      "Epoch 17/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.8040 - accuracy: 0.5528 - val_loss: 4.6630 - val_accuracy: 0.1627\n",
      "Epoch 18/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.7130 - accuracy: 0.5712 - val_loss: 4.8223 - val_accuracy: 0.1548\n",
      "Epoch 19/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.6312 - accuracy: 0.5905 - val_loss: 4.9647 - val_accuracy: 0.1609\n",
      "Epoch 20/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.5499 - accuracy: 0.6095 - val_loss: 5.1244 - val_accuracy: 0.1548\n",
      "Epoch 21/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.4663 - accuracy: 0.6308 - val_loss: 5.3002 - val_accuracy: 0.1550\n",
      "Epoch 22/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.3956 - accuracy: 0.6469 - val_loss: 5.4341 - val_accuracy: 0.1556\n",
      "Epoch 23/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.3252 - accuracy: 0.6654 - val_loss: 5.7170 - val_accuracy: 0.1451\n",
      "Epoch 24/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.2559 - accuracy: 0.6827 - val_loss: 5.7569 - val_accuracy: 0.1495\n",
      "Epoch 25/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.1830 - accuracy: 0.6993 - val_loss: 5.9255 - val_accuracy: 0.1458\n",
      "Epoch 26/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.1174 - accuracy: 0.7147 - val_loss: 6.1386 - val_accuracy: 0.1498\n",
      "Epoch 27/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 1.0562 - accuracy: 0.7307 - val_loss: 6.3020 - val_accuracy: 0.1465\n",
      "Epoch 28/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 0.9958 - accuracy: 0.7465 - val_loss: 6.4740 - val_accuracy: 0.1424\n",
      "Epoch 29/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 0.9368 - accuracy: 0.7599 - val_loss: 6.6097 - val_accuracy: 0.1445\n",
      "Epoch 30/30\n",
      "1250/1250 [==============================] - 5s 4ms/step - loss: 0.8849 - accuracy: 0.7746 - val_loss: 6.8493 - val_accuracy: 0.1477\n"
     ]
    }
   ],
   "source": [
    "h = model.fit(x_train, y_train, validation_split=0.2, epochs=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 249,
       "width": 373
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in ['accuracy', 'val_accuracy']:\n",
    "    plot(h.history[k], )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"functional_3\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "input_2 (InputLayer)         [(None, 32, 32, 3)]       0         \n",
      "_________________________________________________________________\n",
      "conv2d (Conv2D)              (None, 30, 30, 32)        896       \n",
      "_________________________________________________________________\n",
      "max_pooling2d (MaxPooling2D) (None, 29, 29, 32)        0         \n",
      "_________________________________________________________________\n",
      "flatten_1 (Flatten)          (None, 26912)             0         \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              (None, 100)               2691300   \n",
      "=================================================================\n",
      "Total params: 2,692,196\n",
      "Trainable params: 2,692,196\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "./results-v2/cifar100/CNN_maxpool-nf32-ker(3, 3)-n_lay-1-act-relu-rotate=True-scramble=True.json\n"
     ]
    }
   ],
   "source": [
    "configs['net']['architecture'] = 'cnn_maxpool'\n",
    "\n",
    "model_name = f\"CNN_maxpool-nf{net['num_filters']}-ker{kernel_size}\"\n",
    "\n",
    "model_name += f\"-n_lay-{net['num_layers']}\"\n",
    "model_name += f\"-act-{net['activation']}\"\n",
    "num_params = model.count_params() \n",
    "\n",
    "out_file_name = f\"./results-v2/{dataset_name}/{model_name}-rotate={bool(configs['dataset']['rotate'])}-scramble={bool(configs['dataset']['scramble'])}.json\"\n",
    "\n",
    "configs['net']['architecture'] = 'cnn_maxpool'\n",
    "\n",
    "results = {}\n",
    "results.update({\n",
    "    'num_params':num_params,\n",
    "    'result':h.history,\n",
    "    'configs':configs,\n",
    "#     'result': {k: np.float32(v).tolist() for k,v in h.history.items()}, # bug in json or TF2\n",
    "          })\n",
    "\n",
    "\n",
    "\n",
    "# for k,v in results['result'].items():\n",
    "#     print(k,type(v))\n",
    "\n",
    "import os\n",
    "\n",
    "# print(h.history)\n",
    "\n",
    "dirs = os.path.split(out_file_name)[0]\n",
    "os.makedirs(dirs,exist_ok=True)\n",
    "\n",
    "print(out_file_name)\n",
    "\n",
    "\n",
    "json.dump(results, open(out_file_name, 'w'))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "TF2.0 Py3",
   "language": "python",
   "name": "tf2"
  },
  "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
