{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "NhIEWyG9Zd7_"
   },
   "outputs": [],
   "source": [
    "import tensorflow as tf\n",
    "import tensorflow.keras.layers as layers\n",
    "from tensorflow import initializers\n",
    "from tensorflow import keras\n",
    "from keras import optimizers\n",
    "from keras.callbacks import LearningRateScheduler\n",
    "from keras.preprocessing.image import ImageDataGenerator\n",
    "import numpy as np\n",
    "import matplotlib.pylab as plt\n",
    "import time\n",
    "from keras import backend as K\n",
    "import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "iwKWzG4nZjr6"
   },
   "outputs": [],
   "source": [
    "eps=1e-10\n",
    "\n",
    "\n",
    "class layer_exph(tf.keras.layers.Layer):\n",
    "  \"\"\"\n",
    "  X (n_sample, d)\n",
    "  out (n_sample, d)\n",
    "  \"\"\"\n",
    "  def __init__(self,**kwargs):\n",
    "    super().__init__(**kwargs)\n",
    "\n",
    "  def call(self, X):\n",
    "    r = tf.math.sqrt(tf.reduce_sum(X*X, -1, keepdims=True))+eps\n",
    "    omega = X/r\n",
    "    return tf.math.tanh(r)*omega*0.99\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "class BiasLayer(tf.keras.layers.Layer):\n",
    "    def __init__(self, *args, **kwargs):\n",
    "        super(BiasLayer, self).__init__(*args, **kwargs)\n",
    "\n",
    "    def build(self, input_shape):\n",
    "        self.bias = self.add_weight('bias',\n",
    "                                    shape=input_shape[1:],\n",
    "                                    initializer='zeros',\n",
    "                                    trainable=True)\n",
    "    def call(self, x):\n",
    "        return x + self.bias\n",
    "\n",
    "class layer_Horocycle(tf.keras.layers.Layer):\n",
    "  def __init__(self, in_features, out_features, **kwargs):\n",
    "    super().__init__(**kwargs)\n",
    "\n",
    "    w_pre = np.random.randn(in_features, out_features)\n",
    "    self.w = tf.Variable(\n",
    "      tf.random.normal([in_features, out_features]), name='w', dtype='float32')\n",
    "    self.w.assign(w_pre/np.sqrt(np.sum(w_pre*w_pre, 0)))\n",
    "  def call(self, x):\n",
    "    xnorm2 = tf.reduce_sum(x*x, axis=-1, keepdims=True)\n",
    "    Wnorm2 = 1\n",
    "    xW = tf.matmul(x, self.w)\n",
    "    return 0.5*tf.math.log((Wnorm2-xnorm2)/(Wnorm2+xnorm2-2*xW+eps)+eps)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "WUDN_qUxnZHM"
   },
   "outputs": [],
   "source": [
    "num_classes  = 10\n",
    "weight_decay = 0.0001\n",
    "batch_size = 128\n",
    "from keras import backend as K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "JxGhNqHanZk6"
   },
   "outputs": [],
   "source": [
    "class ResnetIdentityBlock(tf.keras.Model):\n",
    "  def __init__(self, filter,reduceDim=False):\n",
    "    super(ResnetIdentityBlock, self).__init__(name='')\n",
    "    self.reduceDim = reduceDim\n",
    "    if self.reduceDim:\n",
    "        self.conv2a = tf.keras.layers.Conv2D(filter, 3, strides=2, padding='same',kernel_initializer=initializers.he_normal())\n",
    "    else:\n",
    "        self.conv2a = tf.keras.layers.Conv2D(filter, 3, strides=1, padding='same',kernel_initializer=initializers.he_normal())\n",
    "    self.bn2a = tf.keras.layers.BatchNormalization()\n",
    "\n",
    "    self.conv2b = tf.keras.layers.Conv2D(filter, 3, strides=1,  padding='same',kernel_initializer=initializers.he_normal())\n",
    "    self.bn2b = tf.keras.layers.BatchNormalization()\n",
    "\n",
    "    self.conv2c = tf.keras.layers.Conv2D(filter, 1, strides=2, padding='same',kernel_initializer=initializers.he_normal())\n",
    "    self.bn2c = tf.keras.layers.BatchNormalization()\n",
    "  def call(self, input_tensor, training=False):\n",
    "    x = self.conv2a(input_tensor)\n",
    "    x = self.bn2a(x, training=training)\n",
    "    x = tf.nn.relu(x)\n",
    "    x = self.conv2b(x)\n",
    "    x = self.bn2b(x, training=training)\n",
    "    if self.reduceDim:\n",
    "        shortcut = self.conv2c(input_tensor)\n",
    "        shortcut = self.bn2c(shortcut, training=training)\n",
    "    else:\n",
    "        shortcut = input_tensor\n",
    "    x += shortcut\n",
    "    return tf.nn.relu(x)\n",
    "\n",
    "\n",
    "\n",
    "def ResNet(embed_dim, input_shape=(28,28,1), n_blocks=4, n_features=128):\n",
    "    input = layers.Input(shape=input_shape)\n",
    "    x = tf.keras.layers.Conv2D(16*4, 3 , strides=1, padding='same', activation=\"relu\",kernel_initializer=initializers.he_uniform())(input)\n",
    "    x = tf.keras.layers.BatchNormalization()(x)\n",
    "    for i in range(n_blocks):\n",
    "        x = ResnetIdentityBlock(16*4)(x,training=True)\n",
    "    x = ResnetIdentityBlock(32*4, True)(x,training=True)\n",
    "\n",
    "\n",
    "    for i in range(n_blocks):\n",
    "        x = ResnetIdentityBlock(32*4)(x,training=True)  \n",
    "    x = ResnetIdentityBlock(64*4, True)(x,training=True)  \n",
    "    for i in range(n_blocks):\n",
    "        x = ResnetIdentityBlock(64*4)(x,training=True) \n",
    "    x = ResnetIdentityBlock(128*4, True)(x,training=True)\n",
    "    x = tf.keras.layers.AveragePooling2D(pool_size=(3, 3), strides=(2, 2))(x)\n",
    "    x = layers.Flatten()(x)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    x= layers.Dense(n_features,  activation=tf.nn.relu)(x)\n",
    "    x = tf.keras.layers.BatchNormalization()(x)\n",
    "\n",
    "\n",
    "    x= layers.Dense(embed_dim,  activation=tf.nn.relu)(x)\n",
    "    out = tf.keras.layers.BatchNormalization()(x)\n",
    "\n",
    "    model = keras.models.Model(inputs=input, outputs=out)\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "r4Q4SnJybDSg"
   },
   "outputs": [],
   "source": [
    "def get_corrsum(tf_variable, n_class):\n",
    "  mtx_var=tf.matmul(tf.transpose(tf_variable), tf_variable)\n",
    "  mtx_corr = 0.0001+1-mtx_var/tf.sqrt(eps+tf.expand_dims(tf.linalg.diag_part(mtx_var),-1)*tf.linalg.diag_part(mtx_var))+tf.eye(n_class)\n",
    "  return tf.reduce_sum(1/mtx_corr)\n",
    "\n",
    "\n",
    "def get_sphereprototype(n_dim, n_class):\n",
    "  var_prototypes = tf.Variable(tf.random.normal(shape=[n_dim, n_class]))\n",
    "  lr = 0.00001\n",
    "  for epoch in range(1000):\n",
    "    with tf.GradientTape() as tape:\n",
    "      loss = get_corrsum(var_prototypes, n_class)\n",
    "      gradients = tape.gradient(loss, var_prototypes)\n",
    "    var_prototypes.assign(var_prototypes-lr*gradients[0])\n",
    "  return var_prototypes/tf.sqrt(tf.reduce_sum(var_prototypes**2,0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 12539,
     "status": "ok",
     "timestamp": 1605452680631,
     "user": {
      "displayName": "Mingxi Wang",
      "photoUrl": "",
      "userId": "02457827406398567223"
     },
     "user_tz": -60
    },
    "id": "k1qeV77wndsK",
    "outputId": "2e9a12b0-310c-41a6-dcaf-ab96f22b4642"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading data from https://www.cs.toronto.edu/~kriz/cifar-10-python.tar.gz\n",
      "170500096/170498071 [==============================] - 7s 0us/step\n"
     ]
    }
   ],
   "source": [
    "from tensorflow.keras import datasets\n",
    "(train_images, train_labels), (test_images, test_labels) = datasets.cifar10.load_data()\n",
    "train_images = train_images / 255.0\n",
    "test_images = test_images / 255.0\n",
    "test_labels=test_labels.ravel()\n",
    "train_labels=train_labels.ravel()\n",
    "\n",
    "a, b, c =train_images.mean(0).mean(0).mean(0)\n",
    "train_images[:,:,:,0] = (train_images[:,:,:,0]-a)\n",
    "train_images[:,:,:,1] = (train_images[:,:,:,1]-b)\n",
    "train_images[:,:,:,2] = (train_images[:,:,:,2]-c)\n",
    "test_images[:,:,:,0] = (test_images[:,:,:,0]-a)\n",
    "test_images[:,:,:,1] = (test_images[:,:,:,1]-b)\n",
    "test_images[:,:,:,2] = (test_images[:,:,:,2]-c)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "datagen = ImageDataGenerator(horizontal_flip=True, width_shift_range=0.125,height_shift_range=0.125,fill_mode='constant',cval=0.)\n",
    "datagen.fit(train_images)\n",
    "\n",
    "\n",
    "n_class=test_labels.max()+1\n",
    "n_iters = int(train_images.shape[0]/batch_size)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "s_2HUNBqvGHM"
   },
   "source": [
    "# Horocycle MLR--clustering in $\\mathrm{H}^2$"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "yd1G9Piivb18"
   },
   "source": [
    "We set the parameters on $S^1$ (equivalently end-prototypes) to be non-trainable because our implementation of tf.GradientTape() seems very slow for a ResNet-32 structure. Letting end-prototypes being non-trainable is motivated by the paper \"Hyperspherical Prototype Networks\". It is likely to improve the result if network parameters and prototype parameters are trained\n",
    "jointly in an end-to-end manner"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "2L-Ho_9pz86K"
   },
   "outputs": [],
   "source": [
    "embed_dim = 2\n",
    "model_dcnn = ResNet(embed_dim, input_shape=(32,32,3))\n",
    "model_exp = layer_exph()\n",
    "model_horopart = layer_Horocycle(embed_dim,n_class)\n",
    "model_biaspart = BiasLayer()\n",
    "model = tf.keras.Sequential([\n",
    "    model_dcnn,\n",
    "    model_exp,\n",
    "    model_horopart,\n",
    "    model_biaspart,\n",
    "])\n",
    "sphere_prototypes = get_sphereprototype(embed_dim,n_class).numpy()\n",
    "model_horopart.weights[0].assign(sphere_prototypes)\n",
    "model_horopart.trainable=False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 13339634,
     "status": "ok",
     "timestamp": 1605368391846,
     "user": {
      "displayName": "Mingxi Wang",
      "photoUrl": "",
      "userId": "01165593761653277599"
     },
     "user_tz": -60
    },
    "id": "iGJDQO4jz86O",
    "outputId": "9862db5b-405c-4099-9ff5-8ded72f22aca"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100\n",
      "1562/1562 [==============================] - 93s 60ms/step - loss: 2.2009 - accuracy: 0.1943 - val_loss: 2.1407 - val_accuracy: 0.2291\n",
      "Epoch 2/100\n",
      "1562/1562 [==============================] - 94s 60ms/step - loss: 2.1283 - accuracy: 0.2263 - val_loss: 2.0438 - val_accuracy: 0.2715\n",
      "Epoch 3/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 2.0384 - accuracy: 0.2716 - val_loss: 1.9740 - val_accuracy: 0.3061\n",
      "Epoch 4/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 1.9213 - accuracy: 0.3526 - val_loss: 1.8149 - val_accuracy: 0.4057\n",
      "Epoch 5/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.7307 - accuracy: 0.4484 - val_loss: 1.5511 - val_accuracy: 0.5172\n",
      "Epoch 6/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.5853 - accuracy: 0.5106 - val_loss: 1.4749 - val_accuracy: 0.5594\n",
      "Epoch 7/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.4864 - accuracy: 0.5516 - val_loss: 1.3842 - val_accuracy: 0.5845\n",
      "Epoch 8/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.4182 - accuracy: 0.5825 - val_loss: 1.2795 - val_accuracy: 0.6285\n",
      "Epoch 9/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.3483 - accuracy: 0.6097 - val_loss: 1.2516 - val_accuracy: 0.6426\n",
      "Epoch 10/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.2873 - accuracy: 0.6390 - val_loss: 1.2065 - val_accuracy: 0.6616\n",
      "Epoch 11/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.2253 - accuracy: 0.6608 - val_loss: 1.1151 - val_accuracy: 0.6926\n",
      "Epoch 12/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 1.1731 - accuracy: 0.6823 - val_loss: 1.0917 - val_accuracy: 0.6984\n",
      "Epoch 13/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 1.1356 - accuracy: 0.6997 - val_loss: 1.3197 - val_accuracy: 0.6363\n",
      "Epoch 14/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 1.0840 - accuracy: 0.7187 - val_loss: 1.1069 - val_accuracy: 0.7053\n",
      "Epoch 15/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 1.0318 - accuracy: 0.7357 - val_loss: 1.0548 - val_accuracy: 0.7239\n",
      "Epoch 16/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.9851 - accuracy: 0.7513 - val_loss: 1.0217 - val_accuracy: 0.7335\n",
      "Epoch 17/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.9526 - accuracy: 0.7628 - val_loss: 1.0038 - val_accuracy: 0.7392\n",
      "Epoch 18/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.9255 - accuracy: 0.7697 - val_loss: 0.8715 - val_accuracy: 0.7821\n",
      "Epoch 19/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.8891 - accuracy: 0.7828 - val_loss: 0.8396 - val_accuracy: 0.7875\n",
      "Epoch 20/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.8740 - accuracy: 0.7866 - val_loss: 0.8850 - val_accuracy: 0.7786\n",
      "Epoch 21/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.8601 - accuracy: 0.7921 - val_loss: 0.8584 - val_accuracy: 0.7939\n",
      "Epoch 22/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.8263 - accuracy: 0.8023 - val_loss: 0.8539 - val_accuracy: 0.7872\n",
      "Epoch 23/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.7969 - accuracy: 0.8130 - val_loss: 0.8046 - val_accuracy: 0.8007\n",
      "Epoch 24/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.7732 - accuracy: 0.8188 - val_loss: 0.9131 - val_accuracy: 0.7748\n",
      "Epoch 25/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.7573 - accuracy: 0.8230 - val_loss: 0.7624 - val_accuracy: 0.8146\n",
      "Epoch 26/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.7542 - accuracy: 0.8237 - val_loss: 0.7465 - val_accuracy: 0.8203\n",
      "Epoch 27/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.7379 - accuracy: 0.8310 - val_loss: 0.7530 - val_accuracy: 0.8183\n",
      "Epoch 28/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.7113 - accuracy: 0.8372 - val_loss: 0.7089 - val_accuracy: 0.8308\n",
      "Epoch 29/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.6920 - accuracy: 0.8433 - val_loss: 1.2272 - val_accuracy: 0.6546\n",
      "Epoch 30/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.6774 - accuracy: 0.8481 - val_loss: 0.7601 - val_accuracy: 0.8162\n",
      "Epoch 31/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.6742 - accuracy: 0.8491 - val_loss: 0.6796 - val_accuracy: 0.8345\n",
      "Epoch 32/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.6469 - accuracy: 0.8561 - val_loss: 0.7062 - val_accuracy: 0.8353\n",
      "Epoch 33/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.6330 - accuracy: 0.8610 - val_loss: 0.7167 - val_accuracy: 0.8326\n",
      "Epoch 34/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.6337 - accuracy: 0.8605 - val_loss: 0.8338 - val_accuracy: 0.7943\n",
      "Epoch 35/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.6152 - accuracy: 0.8656 - val_loss: 0.6652 - val_accuracy: 0.8439\n",
      "Epoch 36/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.6193 - accuracy: 0.8626 - val_loss: 0.6663 - val_accuracy: 0.8467\n",
      "Epoch 37/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.6137 - accuracy: 0.8664 - val_loss: 0.7001 - val_accuracy: 0.8347\n",
      "Epoch 38/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.6089 - accuracy: 0.8654 - val_loss: 0.7804 - val_accuracy: 0.8159\n",
      "Epoch 39/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5942 - accuracy: 0.8701 - val_loss: 0.6366 - val_accuracy: 0.8515\n",
      "Epoch 40/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5535 - accuracy: 0.8822 - val_loss: 0.6471 - val_accuracy: 0.8545\n",
      "Epoch 41/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5529 - accuracy: 0.8833 - val_loss: 0.6261 - val_accuracy: 0.8559\n",
      "Epoch 42/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5418 - accuracy: 0.8852 - val_loss: 0.6159 - val_accuracy: 0.8594\n",
      "Epoch 43/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5465 - accuracy: 0.8836 - val_loss: 0.8373 - val_accuracy: 0.8476\n",
      "Epoch 44/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5379 - accuracy: 0.8862 - val_loss: 0.6159 - val_accuracy: 0.8544\n",
      "Epoch 45/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5196 - accuracy: 0.8901 - val_loss: 0.5844 - val_accuracy: 0.8663\n",
      "Epoch 46/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5107 - accuracy: 0.8931 - val_loss: 0.6770 - val_accuracy: 0.8414\n",
      "Epoch 47/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5375 - accuracy: 0.8855 - val_loss: 0.6190 - val_accuracy: 0.8568\n",
      "Epoch 48/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5071 - accuracy: 0.8944 - val_loss: 0.5937 - val_accuracy: 0.8646\n",
      "Epoch 49/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.5164 - accuracy: 0.8917 - val_loss: 0.5833 - val_accuracy: 0.8657\n",
      "Epoch 50/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4691 - accuracy: 0.9047 - val_loss: 0.5988 - val_accuracy: 0.8647\n",
      "Epoch 51/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4799 - accuracy: 0.9020 - val_loss: 0.5640 - val_accuracy: 0.8738\n",
      "Epoch 52/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4706 - accuracy: 0.9039 - val_loss: 0.5735 - val_accuracy: 0.8730\n",
      "Epoch 53/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4597 - accuracy: 0.9072 - val_loss: 0.5486 - val_accuracy: 0.8796\n",
      "Epoch 54/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4797 - accuracy: 0.9010 - val_loss: 0.5730 - val_accuracy: 0.8710\n",
      "Epoch 55/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4490 - accuracy: 0.9106 - val_loss: 0.5441 - val_accuracy: 0.8787\n",
      "Epoch 56/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4356 - accuracy: 0.9134 - val_loss: 0.5718 - val_accuracy: 0.8774\n",
      "Epoch 57/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4480 - accuracy: 0.9101 - val_loss: 0.6370 - val_accuracy: 0.8537\n",
      "Epoch 58/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.4289 - accuracy: 0.9156 - val_loss: 0.5571 - val_accuracy: 0.8759\n",
      "Epoch 59/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4268 - accuracy: 0.9168 - val_loss: 0.5594 - val_accuracy: 0.8794\n",
      "Epoch 60/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4249 - accuracy: 0.9173 - val_loss: 0.9108 - val_accuracy: 0.8371\n",
      "Epoch 61/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4106 - accuracy: 0.9201 - val_loss: 0.5545 - val_accuracy: 0.8754\n",
      "Epoch 62/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4226 - accuracy: 0.9169 - val_loss: 0.5468 - val_accuracy: 0.8842\n",
      "Epoch 63/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4025 - accuracy: 0.9223 - val_loss: 0.5406 - val_accuracy: 0.8815\n",
      "Epoch 64/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.4092 - accuracy: 0.9205 - val_loss: 0.5720 - val_accuracy: 0.8745\n",
      "Epoch 65/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3912 - accuracy: 0.9246 - val_loss: 0.5384 - val_accuracy: 0.8830\n",
      "Epoch 66/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3864 - accuracy: 0.9259 - val_loss: 0.5025 - val_accuracy: 0.8918\n",
      "Epoch 67/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3875 - accuracy: 0.9270 - val_loss: 0.5212 - val_accuracy: 0.8877\n",
      "Epoch 68/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.4152 - accuracy: 0.9182 - val_loss: 0.5976 - val_accuracy: 0.8638\n",
      "Epoch 69/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3944 - accuracy: 0.9231 - val_loss: 0.5376 - val_accuracy: 0.8821\n",
      "Epoch 70/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3667 - accuracy: 0.9319 - val_loss: 0.5137 - val_accuracy: 0.8894\n",
      "Epoch 71/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3645 - accuracy: 0.9327 - val_loss: 0.5392 - val_accuracy: 0.8828\n",
      "Epoch 72/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3494 - accuracy: 0.9364 - val_loss: 0.5353 - val_accuracy: 0.8869\n",
      "Epoch 73/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3720 - accuracy: 0.9305 - val_loss: 0.5320 - val_accuracy: 0.8847\n",
      "Epoch 74/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3470 - accuracy: 0.9365 - val_loss: 0.5292 - val_accuracy: 0.8876\n",
      "Epoch 75/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3492 - accuracy: 0.9365 - val_loss: 0.5543 - val_accuracy: 0.8778\n",
      "Epoch 76/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3462 - accuracy: 0.9365 - val_loss: 0.5322 - val_accuracy: 0.8843\n",
      "Epoch 77/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3430 - accuracy: 0.9380 - val_loss: 0.5202 - val_accuracy: 0.8893\n",
      "Epoch 78/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3426 - accuracy: 0.9387 - val_loss: 0.8108 - val_accuracy: 0.8895\n",
      "Epoch 79/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3415 - accuracy: 0.9382 - val_loss: 0.4896 - val_accuracy: 0.8973\n",
      "Epoch 80/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3307 - accuracy: 0.9407 - val_loss: 0.5144 - val_accuracy: 0.8880\n",
      "Epoch 81/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3219 - accuracy: 0.9438 - val_loss: 0.4989 - val_accuracy: 0.8944\n",
      "Epoch 82/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3100 - accuracy: 0.9465 - val_loss: 0.4925 - val_accuracy: 0.8964\n",
      "Epoch 83/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3168 - accuracy: 0.9439 - val_loss: 0.9664 - val_accuracy: 0.8016\n",
      "Epoch 84/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3249 - accuracy: 0.9429 - val_loss: 0.5056 - val_accuracy: 0.8925\n",
      "Epoch 85/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3216 - accuracy: 0.9434 - val_loss: 0.5370 - val_accuracy: 0.8854\n",
      "Epoch 86/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3042 - accuracy: 0.9481 - val_loss: 0.4977 - val_accuracy: 0.8955\n",
      "Epoch 87/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.3095 - accuracy: 0.9461 - val_loss: 0.4989 - val_accuracy: 0.8934\n",
      "Epoch 88/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3006 - accuracy: 0.9491 - val_loss: 0.4885 - val_accuracy: 0.8991\n",
      "Epoch 89/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.3026 - accuracy: 0.9482 - val_loss: 0.4900 - val_accuracy: 0.8975\n",
      "Epoch 90/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2858 - accuracy: 0.9529 - val_loss: 0.4735 - val_accuracy: 0.9018\n",
      "Epoch 91/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2919 - accuracy: 0.9505 - val_loss: 0.4959 - val_accuracy: 0.8948\n",
      "Epoch 92/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2914 - accuracy: 0.9518 - val_loss: 0.4941 - val_accuracy: 0.8973\n",
      "Epoch 93/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2884 - accuracy: 0.9517 - val_loss: 0.5200 - val_accuracy: 0.8889\n",
      "Epoch 94/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.2794 - accuracy: 0.9538 - val_loss: 0.5142 - val_accuracy: 0.8942\n",
      "Epoch 95/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2753 - accuracy: 0.9545 - val_loss: 0.5091 - val_accuracy: 0.8932\n",
      "Epoch 96/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2761 - accuracy: 0.9558 - val_loss: 0.4848 - val_accuracy: 0.8994\n",
      "Epoch 97/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2771 - accuracy: 0.9545 - val_loss: 0.5152 - val_accuracy: 0.8942\n",
      "Epoch 98/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2731 - accuracy: 0.9554 - val_loss: 0.4984 - val_accuracy: 0.8966\n",
      "Epoch 99/100\n",
      "1562/1562 [==============================] - 96s 61ms/step - loss: 0.2617 - accuracy: 0.9586 - val_loss: 0.5137 - val_accuracy: 0.8900\n",
      "Epoch 100/100\n",
      "1562/1562 [==============================] - 95s 61ms/step - loss: 0.2716 - accuracy: 0.9554 - val_loss: 0.4695 - val_accuracy: 0.9049\n",
      "Epoch 1/50\n",
      " 2/48 [>.............................] - ETA: 33s - loss: 0.2389 - accuracy: 0.9658WARNING:tensorflow:Callbacks method `on_train_batch_end` is slow compared to the batch time (batch time: 0.4834s vs `on_train_batch_end` time: 0.9697s). Check your callbacks.\n",
      "48/48 [==============================] - 77s 2s/step - loss: 0.2156 - accuracy: 0.9661 - val_loss: 0.4571 - val_accuracy: 0.9084\n",
      "Epoch 2/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1999 - accuracy: 0.9688 - val_loss: 0.4473 - val_accuracy: 0.9105\n",
      "Epoch 3/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1891 - accuracy: 0.9720 - val_loss: 0.4355 - val_accuracy: 0.9123\n",
      "Epoch 4/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1832 - accuracy: 0.9737 - val_loss: 0.4258 - val_accuracy: 0.9136\n",
      "Epoch 5/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1814 - accuracy: 0.9740 - val_loss: 0.4217 - val_accuracy: 0.9145\n",
      "Epoch 6/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1759 - accuracy: 0.9755 - val_loss: 0.4225 - val_accuracy: 0.9141\n",
      "Epoch 7/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1731 - accuracy: 0.9765 - val_loss: 0.4187 - val_accuracy: 0.9152\n",
      "Epoch 8/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1702 - accuracy: 0.9772 - val_loss: 0.4178 - val_accuracy: 0.9160\n",
      "Epoch 9/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1680 - accuracy: 0.9777 - val_loss: 0.4167 - val_accuracy: 0.9165\n",
      "Epoch 10/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1643 - accuracy: 0.9786 - val_loss: 0.4142 - val_accuracy: 0.9171\n",
      "Epoch 11/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1620 - accuracy: 0.9793 - val_loss: 0.4160 - val_accuracy: 0.9169\n",
      "Epoch 12/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1609 - accuracy: 0.9797 - val_loss: 0.4141 - val_accuracy: 0.9170\n",
      "Epoch 13/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1590 - accuracy: 0.9799 - val_loss: 0.4122 - val_accuracy: 0.9189\n",
      "Epoch 14/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1589 - accuracy: 0.9801 - val_loss: 0.4130 - val_accuracy: 0.9175\n",
      "Epoch 15/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1604 - accuracy: 0.9797 - val_loss: 0.4130 - val_accuracy: 0.9168\n",
      "Epoch 16/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1540 - accuracy: 0.9813 - val_loss: 0.4117 - val_accuracy: 0.9176\n",
      "Epoch 17/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1528 - accuracy: 0.9818 - val_loss: 0.4107 - val_accuracy: 0.9193\n",
      "Epoch 18/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1543 - accuracy: 0.9811 - val_loss: 0.4112 - val_accuracy: 0.9191\n",
      "Epoch 19/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1498 - accuracy: 0.9820 - val_loss: 0.4112 - val_accuracy: 0.9192\n",
      "Epoch 20/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1513 - accuracy: 0.9820 - val_loss: 0.4141 - val_accuracy: 0.9188\n",
      "Epoch 21/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1509 - accuracy: 0.9822 - val_loss: 0.4150 - val_accuracy: 0.9185\n",
      "Epoch 22/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1499 - accuracy: 0.9820 - val_loss: 0.4146 - val_accuracy: 0.9189\n",
      "Epoch 23/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1476 - accuracy: 0.9827 - val_loss: 0.4140 - val_accuracy: 0.9181\n",
      "Epoch 24/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1466 - accuracy: 0.9833 - val_loss: 0.4142 - val_accuracy: 0.9188\n",
      "Epoch 25/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1449 - accuracy: 0.9833 - val_loss: 0.4126 - val_accuracy: 0.9191\n",
      "Epoch 26/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1455 - accuracy: 0.9835 - val_loss: 0.4132 - val_accuracy: 0.9184\n",
      "Epoch 27/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1453 - accuracy: 0.9833 - val_loss: 0.4137 - val_accuracy: 0.9184\n",
      "Epoch 28/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1452 - accuracy: 0.9835 - val_loss: 0.4139 - val_accuracy: 0.9180\n",
      "Epoch 29/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1415 - accuracy: 0.9842 - val_loss: 0.4145 - val_accuracy: 0.9183\n",
      "Epoch 30/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1415 - accuracy: 0.9846 - val_loss: 0.4151 - val_accuracy: 0.9183\n",
      "Epoch 31/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1401 - accuracy: 0.9849 - val_loss: 0.4147 - val_accuracy: 0.9193\n",
      "Epoch 32/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1414 - accuracy: 0.9846 - val_loss: 0.4138 - val_accuracy: 0.9186\n",
      "Epoch 33/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1402 - accuracy: 0.9851 - val_loss: 0.4109 - val_accuracy: 0.9187\n",
      "Epoch 34/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1393 - accuracy: 0.9848 - val_loss: 0.4138 - val_accuracy: 0.9180\n",
      "Epoch 35/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1372 - accuracy: 0.9859 - val_loss: 0.4162 - val_accuracy: 0.9180\n",
      "Epoch 36/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1367 - accuracy: 0.9857 - val_loss: 0.4142 - val_accuracy: 0.9191\n",
      "Epoch 37/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1352 - accuracy: 0.9862 - val_loss: 0.4130 - val_accuracy: 0.9192\n",
      "Epoch 38/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1372 - accuracy: 0.9853 - val_loss: 0.4121 - val_accuracy: 0.9190\n",
      "Epoch 39/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1354 - accuracy: 0.9863 - val_loss: 0.4144 - val_accuracy: 0.9180\n",
      "Epoch 40/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1333 - accuracy: 0.9865 - val_loss: 0.4186 - val_accuracy: 0.9182\n",
      "Epoch 41/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1343 - accuracy: 0.9863 - val_loss: 0.4187 - val_accuracy: 0.9174\n",
      "Epoch 42/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1355 - accuracy: 0.9855 - val_loss: 0.4211 - val_accuracy: 0.9154\n",
      "Epoch 43/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1334 - accuracy: 0.9866 - val_loss: 0.4200 - val_accuracy: 0.9166\n",
      "Epoch 44/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1331 - accuracy: 0.9866 - val_loss: 0.4203 - val_accuracy: 0.9173\n",
      "Epoch 45/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1313 - accuracy: 0.9871 - val_loss: 0.4250 - val_accuracy: 0.9156\n",
      "Epoch 46/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1332 - accuracy: 0.9866 - val_loss: 0.4214 - val_accuracy: 0.9167\n",
      "Epoch 47/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1293 - accuracy: 0.9876 - val_loss: 0.4204 - val_accuracy: 0.9166\n",
      "Epoch 48/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1288 - accuracy: 0.9876 - val_loss: 0.4219 - val_accuracy: 0.9161\n",
      "Epoch 49/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1288 - accuracy: 0.9878 - val_loss: 0.4210 - val_accuracy: 0.9156\n",
      "Epoch 50/50\n",
      "48/48 [==============================] - 75s 2s/step - loss: 0.1305 - accuracy: 0.9874 - val_loss: 0.4219 - val_accuracy: 0.9159\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<tensorflow.python.keras.callbacks.History at 0x7f48e3e6e4a8>"
      ]
     },
     "execution_count": 9,
     "metadata": {
      "tags": []
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_f=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True)\n",
    "\n",
    "batch_size   = 32\n",
    "epochs       = 100\n",
    "iterations   = int(len(train_images)/batch_size)\n",
    "\n",
    "\n",
    "\n",
    "datagen = ImageDataGenerator(horizontal_flip=True,\n",
    "        width_shift_range=0.125,height_shift_range=0.125,fill_mode='constant',cval=0.)\n",
    "\n",
    "datagen.fit(train_images)\n",
    "\n",
    "\n",
    "model.compile(optimizer='adam',\n",
    "              loss=loss_f,\n",
    "              metrics=['accuracy']\n",
    ")\n",
    "model.fit(datagen.flow(train_images, train_labels,batch_size=batch_size),\n",
    "        steps_per_epoch=iterations,\n",
    "        epochs=epochs,\n",
    "        validation_data=(test_images, test_labels)\n",
    "        )\n",
    "\n",
    "\n",
    "\n",
    "batch_size   = 1024\n",
    "epochs       = 50\n",
    "iterations   = int(len(train_images)/batch_size)\n",
    "model.fit(datagen.flow(train_images, train_labels,batch_size=batch_size),\n",
    "        steps_per_epoch=iterations,\n",
    "        epochs=epochs,\n",
    "        validation_data=(test_images, test_labels)\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 12125,
     "status": "ok",
     "timestamp": 1605371687836,
     "user": {
      "displayName": "Mingxi Wang",
      "photoUrl": "",
      "userId": "01165593761653277599"
     },
     "user_tz": -60
    },
    "id": "9wIp_I24OgBU",
    "outputId": "975f8aea-ab2a-4d90-d2d4-b06d9d8f0a87"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 6s 19ms/step - loss: 0.4219 - accuracy: 0.9159\n"
     ]
    }
   ],
   "source": [
    "x_2d=model_exp(model_dcnn.predict(test_images))\n",
    "w = model_horopart.weights[0]\n",
    "acc = model.evaluate(test_images,test_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 479
    },
    "executionInfo": {
     "elapsed": 8588,
     "status": "ok",
     "timestamp": 1605373140389,
     "user": {
      "displayName": "Mingxi Wang",
      "photoUrl": "",
      "userId": "01165593761653277599"
     },
     "user_tz": -60
    },
    "id": "FHK8hmtFOgBe",
    "outputId": "1ec2fc7b-2ca4-4261-fadd-905abb4231bd"
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "\n",
       "    async function download(id, filename, size) {\n",
       "      if (!google.colab.kernel.accessAllowed) {\n",
       "        return;\n",
       "      }\n",
       "      const div = document.createElement('div');\n",
       "      const label = document.createElement('label');\n",
       "      label.textContent = `Downloading \"${filename}\": `;\n",
       "      div.appendChild(label);\n",
       "      const progress = document.createElement('progress');\n",
       "      progress.max = size;\n",
       "      div.appendChild(progress);\n",
       "      document.body.appendChild(div);\n",
       "\n",
       "      const buffers = [];\n",
       "      let downloaded = 0;\n",
       "\n",
       "      const channel = await google.colab.kernel.comms.open(id);\n",
       "      // Send a message to notify the kernel that we're ready.\n",
       "      channel.send({})\n",
       "\n",
       "      for await (const message of channel.messages) {\n",
       "        // Send a message to notify the kernel that we're ready.\n",
       "        channel.send({})\n",
       "        if (message.buffers) {\n",
       "          for (const buffer of message.buffers) {\n",
       "            buffers.push(buffer);\n",
       "            downloaded += buffer.byteLength;\n",
       "            progress.value = downloaded;\n",
       "          }\n",
       "        }\n",
       "      }\n",
       "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
       "      const a = document.createElement('a');\n",
       "      a.href = window.URL.createObjectURL(blob);\n",
       "      a.download = filename;\n",
       "      div.appendChild(a);\n",
       "      a.click();\n",
       "      div.remove();\n",
       "    }\n",
       "  "
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": [
       "download(\"download_eae4dbfd-6ff2-4193-b95b-cecab4124434\", \"CIFAR10_B2.png\", 412632)"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "predict_labels=np.argmax(model.predict(test_images), -1)\n",
    "class_names = ['Airplane', 'Automobile', 'Bird', 'Cat', 'Deer',\n",
    "               'Dog', 'Frog', 'Horse', 'Ship', 'Truck']\n",
    "\n",
    "colors, colors1 = zip(['#B0FFB0', '#008000'],['#F5F5F5', '#000000'],['#E0E0E0', '#808080'],['#FFE4E1', '#BC8F8F'],['#FFF0F0','#FF0000'],\n",
    "                      ['#ADD8E6','#0000FF'],['#FDD0FD','#BA55D3'],['#FFF6E1','#FF69B4'], ['#E0FFFF','#00FFFF'], ['#FFFFE0', '#FFFF00'])\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "\n",
    "\n",
    "coord_x = np.linspace(-1,1,1000)\n",
    "coord_y = np.linspace(-1,1,1000)\n",
    "coord_x, coord_y =np.meshgrid(coord_x, coord_y)\n",
    "coord_x = coord_x.ravel()\n",
    "coord_y = coord_y.ravel()\n",
    "coord = np.vstack([coord_x, coord_y]).T\n",
    "idx_disk = np.sum(coord**2,1)<1\n",
    "coord=coord[idx_disk,:].astype('float32')\n",
    "cls = w.numpy()\n",
    "\n",
    "cls = np.argmax(model_biaspart(model_horopart(coord)).numpy(),1)\n",
    "for i in range(n_class):\n",
    "  ax.scatter(coord[cls==i,0], coord[cls==i,1],s=0.1, c= colors[i])\n",
    "\n",
    "ax.scatter(x_2d[:,0], x_2d[:,1],s=10, marker='x', c=[colors1[l] for l in test_labels.ravel()])\n",
    "for i in range(10):\n",
    "  ax.scatter(w[0,i]*1.05, w[1,i]*1.05, s=100, marker='d', c=colors1[i])\n",
    "  ax.text(w[0,i]*1.15, w[1,i]*1.15, class_names[i], fontsize=15)\n",
    "ax.axis('off')\n",
    "ax.axis('equal')\n",
    "ax.text(0.75,-0.9, 'test_acc:'+str(int(acc[1]*10000)/100)+'%')\n",
    "for spine in plt.gca().spines.values():\n",
    "    spine.set_visible(False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7nD13_jsvS9x"
   },
   "source": [
    "# Poisson MLR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "gG1I3H3pYswl"
   },
   "outputs": [],
   "source": [
    "class layer_Poisson(tf.keras.layers.Layer):\n",
    "  def __init__(self, in_features, out_features, **kwargs):\n",
    "    super().__init__(**kwargs)\n",
    "\n",
    "    self.w = tf.Variable(\n",
    "      tf.random.normal([in_features, out_features]), name='w')\n",
    "  def call(self, x):\n",
    "    xnorm2 = tf.reduce_sum(x*x, axis=-1, keepdims=True)\n",
    "    Wnorm2 = tf.reduce_sum(self.w*self.w, 0)\n",
    "    xW = tf.matmul(x, self.w)\n",
    "    return -(Wnorm2-xnorm2)/(Wnorm2+xnorm2-2*xW+eps)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "BXb5BC88aKSc"
   },
   "outputs": [],
   "source": [
    "n_feature=128\n",
    "model_dcnn = ResNet(n_feature, input_shape=(32,32,3))\n",
    "model_biaspart = BiasLayer()\n",
    "model = tf.keras.Sequential([\n",
    "    model_dcnn,\n",
    "    layer_Poisson(n_feature, n_class),\n",
    "    model_biaspart,\n",
    "    tf.keras.layers.BatchNormalization()\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6229710,
     "status": "ok",
     "timestamp": 1605462540404,
     "user": {
      "displayName": "Mingxi Wang",
      "photoUrl": "",
      "userId": "02457827406398567223"
     },
     "user_tz": -60
    },
    "id": "TyQLGP1kaKSh",
    "outputId": "0f414257-c4bf-4ef5-e71c-c76a8049d54c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/80\n",
      "1562/1562 [==============================] - 68s 44ms/step - loss: 1.8364 - accuracy: 0.3184 - val_loss: 1.5191 - val_accuracy: 0.4515\n",
      "Epoch 2/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 1.3161 - accuracy: 0.5306 - val_loss: 1.0393 - val_accuracy: 0.6444\n",
      "Epoch 3/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.9989 - accuracy: 0.6555 - val_loss: 0.8679 - val_accuracy: 0.7018\n",
      "Epoch 4/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.8215 - accuracy: 0.7205 - val_loss: 0.7201 - val_accuracy: 0.7580\n",
      "Epoch 5/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.7015 - accuracy: 0.7637 - val_loss: 0.6392 - val_accuracy: 0.7864\n",
      "Epoch 6/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.6208 - accuracy: 0.7912 - val_loss: 0.5992 - val_accuracy: 0.8032\n",
      "Epoch 7/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.5592 - accuracy: 0.8156 - val_loss: 0.5389 - val_accuracy: 0.8212\n",
      "Epoch 8/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.5045 - accuracy: 0.8319 - val_loss: 0.4708 - val_accuracy: 0.8439\n",
      "Epoch 9/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.4637 - accuracy: 0.8445 - val_loss: 0.4657 - val_accuracy: 0.8442\n",
      "Epoch 10/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.4285 - accuracy: 0.8580 - val_loss: 0.4887 - val_accuracy: 0.8407\n",
      "Epoch 11/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.3963 - accuracy: 0.8678 - val_loss: 0.4263 - val_accuracy: 0.8619\n",
      "Epoch 12/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.3691 - accuracy: 0.8787 - val_loss: 0.4098 - val_accuracy: 0.8651\n",
      "Epoch 13/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.3427 - accuracy: 0.8865 - val_loss: 0.4236 - val_accuracy: 0.8640\n",
      "Epoch 14/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.3232 - accuracy: 0.8936 - val_loss: 0.3739 - val_accuracy: 0.8769\n",
      "Epoch 15/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.3050 - accuracy: 0.8996 - val_loss: 0.3494 - val_accuracy: 0.8873\n",
      "Epoch 16/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.2793 - accuracy: 0.9080 - val_loss: 0.3805 - val_accuracy: 0.8793\n",
      "Epoch 17/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.2669 - accuracy: 0.9112 - val_loss: 0.3791 - val_accuracy: 0.8791\n",
      "Epoch 18/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.2489 - accuracy: 0.9168 - val_loss: 0.3728 - val_accuracy: 0.8827\n",
      "Epoch 19/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.2395 - accuracy: 0.9222 - val_loss: 0.3513 - val_accuracy: 0.8922\n",
      "Epoch 20/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.2243 - accuracy: 0.9247 - val_loss: 0.3418 - val_accuracy: 0.8912\n",
      "Epoch 21/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.2103 - accuracy: 0.9306 - val_loss: 0.3409 - val_accuracy: 0.8926\n",
      "Epoch 22/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.1974 - accuracy: 0.9346 - val_loss: 0.3483 - val_accuracy: 0.8933\n",
      "Epoch 23/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.1926 - accuracy: 0.9361 - val_loss: 0.3224 - val_accuracy: 0.8991\n",
      "Epoch 24/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.1811 - accuracy: 0.9390 - val_loss: 0.3091 - val_accuracy: 0.9023\n",
      "Epoch 25/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1672 - accuracy: 0.9443 - val_loss: 0.3198 - val_accuracy: 0.9006\n",
      "Epoch 26/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.1641 - accuracy: 0.9450 - val_loss: 0.3168 - val_accuracy: 0.9017\n",
      "Epoch 27/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.1526 - accuracy: 0.9487 - val_loss: 0.3110 - val_accuracy: 0.9020\n",
      "Epoch 28/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1445 - accuracy: 0.9516 - val_loss: 0.3187 - val_accuracy: 0.9031\n",
      "Epoch 29/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1360 - accuracy: 0.9536 - val_loss: 0.3334 - val_accuracy: 0.8975\n",
      "Epoch 30/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1344 - accuracy: 0.9556 - val_loss: 0.3306 - val_accuracy: 0.8979\n",
      "Epoch 31/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1244 - accuracy: 0.9586 - val_loss: 0.3185 - val_accuracy: 0.9049\n",
      "Epoch 32/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1218 - accuracy: 0.9594 - val_loss: 0.2994 - val_accuracy: 0.9095\n",
      "Epoch 33/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1104 - accuracy: 0.9631 - val_loss: 0.3473 - val_accuracy: 0.9007\n",
      "Epoch 34/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1113 - accuracy: 0.9625 - val_loss: 0.3124 - val_accuracy: 0.9083\n",
      "Epoch 35/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.1042 - accuracy: 0.9645 - val_loss: 0.3301 - val_accuracy: 0.9016\n",
      "Epoch 36/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0983 - accuracy: 0.9668 - val_loss: 0.3100 - val_accuracy: 0.9121\n",
      "Epoch 37/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0944 - accuracy: 0.9681 - val_loss: 0.3174 - val_accuracy: 0.9110\n",
      "Epoch 38/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0898 - accuracy: 0.9698 - val_loss: 0.2990 - val_accuracy: 0.9143\n",
      "Epoch 39/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0897 - accuracy: 0.9692 - val_loss: 0.2940 - val_accuracy: 0.9186\n",
      "Epoch 40/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0807 - accuracy: 0.9729 - val_loss: 0.2975 - val_accuracy: 0.9169\n",
      "Epoch 41/80\n",
      "1562/1562 [==============================] - 68s 44ms/step - loss: 0.0848 - accuracy: 0.9710 - val_loss: 0.3262 - val_accuracy: 0.9105\n",
      "Epoch 42/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0811 - accuracy: 0.9727 - val_loss: 0.3028 - val_accuracy: 0.9139\n",
      "Epoch 43/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0739 - accuracy: 0.9750 - val_loss: 0.3077 - val_accuracy: 0.9169\n",
      "Epoch 44/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0724 - accuracy: 0.9757 - val_loss: 0.3127 - val_accuracy: 0.9155\n",
      "Epoch 45/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0708 - accuracy: 0.9761 - val_loss: 0.3082 - val_accuracy: 0.9149\n",
      "Epoch 46/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0670 - accuracy: 0.9777 - val_loss: 0.3278 - val_accuracy: 0.9123\n",
      "Epoch 47/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0651 - accuracy: 0.9785 - val_loss: 0.3140 - val_accuracy: 0.9163\n",
      "Epoch 48/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0622 - accuracy: 0.9795 - val_loss: 0.3427 - val_accuracy: 0.9097\n",
      "Epoch 49/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0628 - accuracy: 0.9792 - val_loss: 0.3316 - val_accuracy: 0.9135\n",
      "Epoch 50/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0612 - accuracy: 0.9800 - val_loss: 0.3037 - val_accuracy: 0.9179\n",
      "Epoch 51/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0601 - accuracy: 0.9800 - val_loss: 0.3237 - val_accuracy: 0.9145\n",
      "Epoch 52/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0552 - accuracy: 0.9807 - val_loss: 0.3428 - val_accuracy: 0.9101\n",
      "Epoch 53/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0574 - accuracy: 0.9810 - val_loss: 0.3159 - val_accuracy: 0.9161\n",
      "Epoch 54/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0557 - accuracy: 0.9815 - val_loss: 0.2920 - val_accuracy: 0.9216\n",
      "Epoch 55/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0525 - accuracy: 0.9823 - val_loss: 0.2958 - val_accuracy: 0.9163\n",
      "Epoch 56/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0486 - accuracy: 0.9839 - val_loss: 0.3247 - val_accuracy: 0.9150\n",
      "Epoch 57/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0501 - accuracy: 0.9838 - val_loss: 0.3160 - val_accuracy: 0.9174\n",
      "Epoch 58/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0503 - accuracy: 0.9830 - val_loss: 0.2805 - val_accuracy: 0.9241\n",
      "Epoch 59/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0466 - accuracy: 0.9847 - val_loss: 0.3184 - val_accuracy: 0.9168\n",
      "Epoch 60/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0456 - accuracy: 0.9852 - val_loss: 0.3396 - val_accuracy: 0.9131\n",
      "Epoch 61/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0481 - accuracy: 0.9842 - val_loss: 0.3001 - val_accuracy: 0.9207\n",
      "Epoch 62/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0429 - accuracy: 0.9861 - val_loss: 0.2953 - val_accuracy: 0.9223\n",
      "Epoch 63/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0408 - accuracy: 0.9861 - val_loss: 0.3274 - val_accuracy: 0.9180\n",
      "Epoch 64/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0390 - accuracy: 0.9872 - val_loss: 0.3138 - val_accuracy: 0.9201\n",
      "Epoch 65/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0445 - accuracy: 0.9853 - val_loss: 0.3158 - val_accuracy: 0.9172\n",
      "Epoch 66/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0417 - accuracy: 0.9860 - val_loss: 0.3146 - val_accuracy: 0.9204\n",
      "Epoch 67/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0417 - accuracy: 0.9861 - val_loss: 0.3162 - val_accuracy: 0.9220\n",
      "Epoch 68/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0376 - accuracy: 0.9876 - val_loss: 0.3258 - val_accuracy: 0.9200\n",
      "Epoch 69/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0378 - accuracy: 0.9880 - val_loss: 0.3012 - val_accuracy: 0.9241\n",
      "Epoch 70/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0393 - accuracy: 0.9869 - val_loss: 0.3536 - val_accuracy: 0.9137\n",
      "Epoch 71/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0373 - accuracy: 0.9878 - val_loss: 0.3117 - val_accuracy: 0.9226\n",
      "Epoch 72/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0360 - accuracy: 0.9885 - val_loss: 0.3371 - val_accuracy: 0.9157\n",
      "Epoch 73/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0363 - accuracy: 0.9884 - val_loss: 0.3061 - val_accuracy: 0.9217\n",
      "Epoch 74/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0367 - accuracy: 0.9877 - val_loss: 0.3104 - val_accuracy: 0.9217\n",
      "Epoch 75/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0329 - accuracy: 0.9891 - val_loss: 0.3157 - val_accuracy: 0.9205\n",
      "Epoch 76/80\n",
      "1562/1562 [==============================] - 68s 43ms/step - loss: 0.0344 - accuracy: 0.9886 - val_loss: 0.3153 - val_accuracy: 0.9234\n",
      "Epoch 77/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0308 - accuracy: 0.9900 - val_loss: 0.3197 - val_accuracy: 0.9256\n",
      "Epoch 78/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0369 - accuracy: 0.9878 - val_loss: 0.3131 - val_accuracy: 0.9184\n",
      "Epoch 79/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0306 - accuracy: 0.9902 - val_loss: 0.3295 - val_accuracy: 0.9202\n",
      "Epoch 80/80\n",
      "1562/1562 [==============================] - 67s 43ms/step - loss: 0.0337 - accuracy: 0.9887 - val_loss: 0.2939 - val_accuracy: 0.9276\n",
      "Epoch 1/20\n",
      " 2/48 [>.............................] - ETA: 27s - loss: 0.0214 - accuracy: 0.9922WARNING:tensorflow:Callbacks method `on_train_batch_end` is slow compared to the batch time (batch time: 0.2878s vs `on_train_batch_end` time: 0.4624s). Check your callbacks.\n",
      "48/48 [==============================] - 40s 842ms/step - loss: 0.0153 - accuracy: 0.9951 - val_loss: 0.2895 - val_accuracy: 0.9303\n",
      "Epoch 2/20\n",
      "48/48 [==============================] - 40s 835ms/step - loss: 0.0104 - accuracy: 0.9968 - val_loss: 0.2920 - val_accuracy: 0.9314\n",
      "Epoch 3/20\n",
      "48/48 [==============================] - 40s 837ms/step - loss: 0.0080 - accuracy: 0.9976 - val_loss: 0.2938 - val_accuracy: 0.9319\n",
      "Epoch 4/20\n",
      "48/48 [==============================] - 40s 837ms/step - loss: 0.0071 - accuracy: 0.9983 - val_loss: 0.2956 - val_accuracy: 0.9328\n",
      "Epoch 5/20\n",
      "48/48 [==============================] - 40s 838ms/step - loss: 0.0058 - accuracy: 0.9984 - val_loss: 0.2986 - val_accuracy: 0.9341\n",
      "Epoch 6/20\n",
      "48/48 [==============================] - 40s 837ms/step - loss: 0.0055 - accuracy: 0.9983 - val_loss: 0.3002 - val_accuracy: 0.9344\n",
      "Epoch 7/20\n",
      "48/48 [==============================] - 40s 839ms/step - loss: 0.0053 - accuracy: 0.9985 - val_loss: 0.3022 - val_accuracy: 0.9338\n",
      "Epoch 8/20\n",
      "48/48 [==============================] - 40s 834ms/step - loss: 0.0044 - accuracy: 0.9989 - val_loss: 0.3054 - val_accuracy: 0.9345\n",
      "Epoch 9/20\n",
      "48/48 [==============================] - 40s 836ms/step - loss: 0.0035 - accuracy: 0.9991 - val_loss: 0.3083 - val_accuracy: 0.9343\n",
      "Epoch 10/20\n",
      "48/48 [==============================] - 40s 840ms/step - loss: 0.0042 - accuracy: 0.9988 - val_loss: 0.3074 - val_accuracy: 0.9348\n",
      "Epoch 11/20\n",
      "48/48 [==============================] - 40s 837ms/step - loss: 0.0036 - accuracy: 0.9990 - val_loss: 0.3091 - val_accuracy: 0.9344\n",
      "Epoch 12/20\n",
      "48/48 [==============================] - 40s 838ms/step - loss: 0.0037 - accuracy: 0.9990 - val_loss: 0.3107 - val_accuracy: 0.9345\n",
      "Epoch 13/20\n",
      "48/48 [==============================] - 40s 836ms/step - loss: 0.0035 - accuracy: 0.9991 - val_loss: 0.3113 - val_accuracy: 0.9347\n",
      "Epoch 14/20\n",
      "48/48 [==============================] - 40s 835ms/step - loss: 0.0031 - accuracy: 0.9991 - val_loss: 0.3136 - val_accuracy: 0.9348\n",
      "Epoch 15/20\n",
      "48/48 [==============================] - 40s 835ms/step - loss: 0.0030 - accuracy: 0.9992 - val_loss: 0.3151 - val_accuracy: 0.9342\n",
      "Epoch 16/20\n",
      "48/48 [==============================] - 40s 836ms/step - loss: 0.0026 - accuracy: 0.9994 - val_loss: 0.3159 - val_accuracy: 0.9348\n",
      "Epoch 17/20\n",
      "48/48 [==============================] - 40s 830ms/step - loss: 0.0029 - accuracy: 0.9992 - val_loss: 0.3173 - val_accuracy: 0.9353\n",
      "Epoch 18/20\n",
      "48/48 [==============================] - 40s 834ms/step - loss: 0.0025 - accuracy: 0.9993 - val_loss: 0.3186 - val_accuracy: 0.9359\n",
      "Epoch 19/20\n",
      "48/48 [==============================] - 40s 832ms/step - loss: 0.0022 - accuracy: 0.9995 - val_loss: 0.3201 - val_accuracy: 0.9344\n",
      "Epoch 20/20\n",
      "48/48 [==============================] - 40s 829ms/step - loss: 0.0021 - accuracy: 0.9995 - val_loss: 0.3201 - val_accuracy: 0.9354\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<tensorflow.python.keras.callbacks.History at 0x7f46e2895dd8>"
      ]
     },
     "execution_count": 28,
     "metadata": {
      "tags": []
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_f=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True)\n",
    "\n",
    "batch_size   = 32\n",
    "epochs       = 80\n",
    "iterations   = int(len(train_images)/batch_size)\n",
    "\n",
    "\n",
    "\n",
    "datagen = ImageDataGenerator(horizontal_flip=True,\n",
    "        width_shift_range=0.125,height_shift_range=0.125,fill_mode='constant',cval=0.)\n",
    "\n",
    "datagen.fit(train_images)\n",
    "\n",
    "\n",
    "model.compile(optimizer='adam',\n",
    "              loss=loss_f,\n",
    "              metrics=['accuracy']\n",
    ")\n",
    "model.fit(datagen.flow(train_images, train_labels,batch_size=batch_size),\n",
    "        steps_per_epoch=iterations,\n",
    "        epochs=epochs,\n",
    "        validation_data=(test_images, test_labels)\n",
    "        )\n",
    "\n",
    "\n",
    "\n",
    "batch_size   = 1024\n",
    "epochs       = 20\n",
    "iterations   = int(len(train_images)/batch_size)\n",
    "model.fit(datagen.flow(train_images, train_labels,batch_size=batch_size),\n",
    "        steps_per_epoch=iterations,\n",
    "        epochs=epochs,\n",
    "        validation_data=(test_images, test_labels)\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "0NWz3dz5bWLy"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "ResNet32-CIFAR10_final.ipynb",
   "provenance": [
    {
     "file_id": "1KRqlka2lK4R1NvF0espG5b-dD93_pc7K",
     "timestamp": 1604394163371
    }
   ]
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
