{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nJH2TxfxM4rZ"
      },
      "outputs": [],
      "source": [
        "from tensorflow.keras.datasets import fashion_mnist\n",
        "from sklearn.metrics import recall_score\n",
        "from sklearn.metrics import precision_score\n",
        "from sklearn.metrics import f1_score\n",
        "\n",
        "# loads the Fashion-MNIST training and test dataset \n",
        "(x_train, y_train), (x_test, y_test)  = fashion_mnist.load_data()\n",
        "\n",
        "# Our Class Names, when loading data from .datasets() our classes are integers\n",
        "from tensorflow.python.client import device_lib\n",
        "\n",
        "print(device_lib.list_local_devices())"
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "p3xO0wyRsDrH"
      },
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "11FjTEHCNEyf"
      },
      "outputs": [],
      "source": [
        "from tensorflow.keras.preprocessing.image import ImageDataGenerator\n",
        "from matplotlib import pyplot\n",
        "from tensorflow.keras import backend as K\n",
        "\n",
        "# Reshape our data to be in the format [number of samples, width, height, color_depth]\n",
        "x_train = x_train.reshape(x_train.shape[0], 28, 28, 1)\n",
        "x_test = x_test.reshape(x_test.shape[0], 28, 28, 1)\n",
        "\n",
        "# Change datatype to float32\n",
        "x_train = x_train.astype('float32')\n",
        "x_test = x_test.astype('float32')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "8VZz1rFWNNA6"
      },
      "outputs": [],
      "source": [
        "# Lets store the number of rows and columns\n",
        "img_rows = x_train[0].shape[0]\n",
        "img_cols = x_train[0].shape[1]\n",
        "\n",
        "# store the shape of a single image \n",
        "input_shape = (img_rows, img_cols, 1)\n",
        "\n",
        "# Normalize our data between 0 and 1\n",
        "x_test /= 255.0"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "id": "35kn9WDBNTyW",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "6263c669-0d6c-4d4d-f603-21e1d6c7361e"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Number of Classes: 10\n"
          ]
        }
      ],
      "source": [
        "from tensorflow.keras.utils import to_categorical\n",
        "\n",
        "# Now we one hot encode outputs\n",
        "y_train = to_categorical(y_train)\n",
        "y_test = to_categorical(y_test)\n",
        "\n",
        "# Let's count the number columns in our hot encoded matrix \n",
        "print (\"Number of Classes: \" + str(y_test.shape[1]))\n",
        "\n",
        "num_classes = y_test.shape[1]\n",
        "num_pixels = x_train.shape[1] * x_train.shape[2]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Z_1RxQfCNbQm"
      },
      "outputs": [],
      "source": [
        "from keras.activations import *\n",
        "import numpy as np\n",
        "from numpy.polynomial import Polynomial\n",
        "from sklearn.datasets import make_blobs\n",
        "from tensorflow.keras.utils import to_categorical,get_custom_objects\n",
        "from keras.models import Sequential\n",
        "from keras.layers import Dense\n",
        "from matplotlib import pyplot\n",
        "from os import makedirs\n",
        "from sklearn.datasets import make_blobs\n",
        "from sklearn.metrics import accuracy_score\n",
        "from sklearn.linear_model import LogisticRegression\n",
        "from keras.models import load_model\n",
        "from numpy import dstack\n",
        "import tensorflow as tf\n",
        "from tensorflow.keras.datasets import mnist\n",
        "from tensorflow.keras.models import Sequential \n",
        "from tensorflow.keras.layers import Dense, Dropout, Flatten\n",
        "from tensorflow.keras.layers import BatchNormalization,Conv2D, MaxPooling2D, Embedding, Reshape, Concatenate, Dropout,AveragePooling2D\n",
        "from tensorflow.keras import backend as K\n",
        "from tensorflow.keras.optimizers import SGD \n",
        "from tensorflow.keras import regularizers\n",
        "from keras.layers import DepthwiseConv2D, Reshape, Activation\n",
        "import math\n",
        "\n",
        "\n",
        "# fit model on dataset\n",
        "def custom_activation(x):\n",
        "    return (x**2) +x\n",
        "\n",
        "get_custom_objects().update({'custom_activation': custom_activation})\n",
        "\n",
        "L2 = 0.001\n",
        "nets = 1\n",
        "model = [0] *nets\n",
        "for j in range(nets):\n",
        "  model[j] = Sequential()\n",
        "  model[j].add(Conv2D(32, kernel_size=(3, 3),\n",
        "                 activation='custom_activation',\n",
        "                 kernel_regularizer = regularizers.l2(L2),\n",
        "                 input_shape=input_shape))\n",
        "  model[j].add(BatchNormalization())\n",
        "  model[j].add(Conv2D(64, (3, 3), activation='custom_activation', kernel_regularizer = regularizers.l2(L2)))\n",
        "  model[j].add(BatchNormalization())\n",
        "  model[j].add(AveragePooling2D(pool_size=(2, 2)))\n",
        "  model[j].add(Dropout(0.2))\n",
        "  model[j].add(Flatten())\n",
        "  model[j].add(Dense(128, activation='custom_activation',kernel_regularizer = regularizers.l2(L2)))\n",
        "  model[j].add(Dropout(0.2))\n",
        "  model[j].add(Dense(num_classes, activation='softmax'))\n",
        "\n",
        "  model[j].compile(loss = 'mean_squared_error',\n",
        "              optimizer = SGD(lr=0.01, momentum=0.9, clipnorm=1.0),\n",
        "              metrics = ['accuracy'])\n",
        "\n",
        "print( model[j].summary())\n",
        "print('All Models Defined')\n",
        "from keras.callbacks import ReduceLROnPlateau\n",
        "learning_rate_reduction=ReduceLROnPlateau(monitor='val_accuracy', patience=3, verbose=0, factor=0.5, min_lr=0.00001)\n",
        "\n",
        "\n",
        "# train for 20 epochs\n",
        "history = [0] * nets\n",
        "epochs = 10\n",
        "\n",
        "train_datagen = ImageDataGenerator(\n",
        "        rescale = 1./255,\n",
        "        rotation_range=10,\n",
        "        width_shift_range=0.1,\n",
        "        height_shift_range=0.1,\n",
        "        shear_range=0.1,\n",
        "        zoom_range=0.1,\n",
        "        horizontal_flip=True,\n",
        "        fill_mode='nearest')\n",
        "\n",
        "# Here we fit the data generator to some sample data.\n",
        "#train_datagen.fit(x_train)\n",
        "\n",
        "batch_size=32\n",
        "# Fit the model\n",
        "# Notice we use train_datagen.flow, this takes data & label arrays, generates batches of augmented data.\n",
        "for j in range(nets):\n",
        "    print(f'Individual Net : {j+1}')   \n",
        "    history = model[j].fit(train_datagen.flow(x_train, y_train, batch_size = batch_size),\n",
        "                              epochs = epochs,\n",
        "                              validation_data = (x_test, y_test),\n",
        "                              verbose = 1,\n",
        "                              steps_per_epoch = x_train.shape[0] // batch_size)\n",
        "    \n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "model[j].evaluate(x_train, y_train, verbose=0)\n",
        "model[j].evaluate(x_test,y_test, verbose=0)\n",
        "\n"
      ],
      "metadata": {
        "id": "baxZzHz_G5cM",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "635a55ed-9b35-461a-f64a-aa9bb54c64a3"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "[0.03107236884534359, 0.8503999710083008]"
            ]
          },
          "metadata": {},
          "execution_count": 6
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "lFEOSCcmNjD7"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "results = np.zeros((10000,10)) \n",
        "\n",
        "r=model[0].predict(x_test)\n",
        "#print(y_test.shape)\n",
        "#print(r.shape)\n",
        "#print(results.shape)\n",
        "for j in range(0,nets):\n",
        "    \n",
        "    results = results + model[j].predict(x_test)\n",
        "\n",
        "res = np.argmax(results,axis = 1)\n",
        "y_labels= np.argmax(y_test,axis = 1)\n",
        "#print(res)\n",
        "#print(y_test)\n",
        "\n",
        "from sklearn.metrics import accuracy_score\n",
        "import numpy\n",
        "y_test = numpy.array(y_test)\n",
        "print(accuracy_score(res,y_labels ))\n",
        "print (\"Number of Nets: \" + str(nets))\n",
        "\n",
        "print (\"Total accuracy: \" + str(accuracy_score(res,y_labels )))"
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    },
    "gpuClass": "standard"
  },
  "nbformat": 4,
  "nbformat_minor": 0
}