{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Functional Encryption - Classification and information leakage\n",
    "\n",
    "We have said that we want to work on Quadratic Function Encryption (_reference deleted_). This paper makes a very interesting comparison and shows that its Functional Encryption scheme for quadratic multi-variate polynomials is equivalent to single hidden layer neural network with a quadratic activation!\n",
    "\n",
    "More specifically the second linear function should come with no bias and the width of the intermediary layer should be kept small to preserve efficiency in the encrypted setting. It is set at 40 in the paper.\n",
    "\n",
    "Let's implement this network with PyTorch and run a first evaluation of the model's performance!\n",
    "\n",
    "We'll see:\n",
    "- a basic implementation\n",
    "- the impact of regularization\n",
    "- an optimisation by replacing the argmax with extra layers"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2 Quadratic model improvements\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We will now use the code directly from the repo, to make the notebook more readable. Functions are standard for performing train, test and orchestrate the training with the main.\n",
    "\n",
    "_Note that the task we try to optimize here is the font because improvements given by extending the network are more visible compared to the character recognition whose baseline accuracy already is >99.4%_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Allow to load packages from parent\n",
    "import sys, os\n",
    "sys.path.insert(1, os.path.realpath(os.path.pardir))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "from learn import main, train, test, show_results, show_confusion_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_OUTPUT = 2\n",
    "\n",
    "class Parser:\n",
    "    \"\"\"Parameters for the training\"\"\"\n",
    "    def __init__(self):\n",
    "        self.epochs = 40\n",
    "        self.lr = 0.002\n",
    "        self.momentum = 0.5\n",
    "        self.test_batch_size = 1000\n",
    "        self.batch_size = 64\n",
    "        self.log_interval = 300"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2.1 Basic implementation\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2.1.1 Quadratic model\n",
    "Here is the quadratic model equivalent to Quadratic Functional Encryption"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class QuadNet(nn.Module):\n",
    "    def __init__(self, output_size):\n",
    "        super(QuadNet, self).__init__()\n",
    "        self.proj1 = nn.Linear(784, 40)\n",
    "        self.diag1 = nn.Linear(40, output_size, bias=None)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, 784)\n",
    "        x = self.proj1(x)\n",
    "        x = x * x\n",
    "        x = self.diag1(x)\n",
    "        return F.log_softmax(x, dim=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2.1.2 Training"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's train launch the training!\n",
    "\n",
    "Notice the `task` to specify if we work on character recognition (`char`) or font recognition (`font`)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training set 60000 items\n",
      "Testing set  10000 items\n",
      "Learning on font \n",
      "Train Epoch: 1 [0/60000 (0%)]\tLoss: 0.719468\n",
      "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 0.317057\n",
      "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 0.264033\n",
      "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 0.248714\n",
      "\n",
      "Test set: Average loss: 0.2109, Accuracy: 9157/10000 (91.57%)\n",
      "\n",
      "Train Epoch: 2 [0/60000 (0%)]\tLoss: 0.160980\n",
      "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 0.293187\n",
      "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 0.102611\n",
      "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 0.203059\n",
      "\n",
      "Test set: Average loss: 0.1532, Accuracy: 9432/10000 (94.32%)\n",
      "\n",
      "Train Epoch: 3 [0/60000 (0%)]\tLoss: 0.117752\n",
      "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 0.119851\n",
      "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 0.122889\n",
      "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 0.075990\n",
      "\n",
      "Test set: Average loss: 0.1263, Accuracy: 9570/10000 (95.70%)\n",
      "\n",
      "Train Epoch: 4 [0/60000 (0%)]\tLoss: 0.120892\n",
      "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 0.054771\n",
      "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 0.043726\n",
      "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 0.040869\n",
      "\n",
      "Test set: Average loss: 0.1228, Accuracy: 9549/10000 (95.49%)\n",
      "\n",
      "Train Epoch: 5 [0/60000 (0%)]\tLoss: 0.206578\n",
      "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 0.111932\n",
      "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 0.139532\n",
      "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 0.183160\n",
      "\n",
      "Test set: Average loss: 0.1013, Accuracy: 9675/10000 (96.75%)\n",
      "\n",
      "Train Epoch: 6 [0/60000 (0%)]\tLoss: 0.088933\n",
      "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 0.174907\n",
      "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 0.063796\n",
      "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 0.061631\n",
      "\n",
      "Test set: Average loss: 0.0974, Accuracy: 9675/10000 (96.75%)\n",
      "\n",
      "Train Epoch: 7 [0/60000 (0%)]\tLoss: 0.122492\n",
      "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 0.131695\n",
      "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 0.106037\n",
      "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 0.095278\n",
      "\n",
      "Test set: Average loss: 0.1028, Accuracy: 9620/10000 (96.20%)\n",
      "\n",
      "Train Epoch: 8 [0/60000 (0%)]\tLoss: 0.136832\n",
      "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 0.033691\n",
      "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 0.068052\n",
      "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 0.107193\n",
      "\n",
      "Test set: Average loss: 0.0830, Accuracy: 9719/10000 (97.19%)\n",
      "\n",
      "Train Epoch: 9 [0/60000 (0%)]\tLoss: 0.070927\n",
      "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 0.080466\n",
      "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 0.138029\n",
      "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 0.192372\n",
      "\n",
      "Test set: Average loss: 0.0890, Accuracy: 9679/10000 (96.79%)\n",
      "\n",
      "Train Epoch: 10 [0/60000 (0%)]\tLoss: 0.012021\n",
      "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 0.047455\n",
      "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 0.068375\n",
      "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 0.100460\n",
      "\n",
      "Test set: Average loss: 0.0805, Accuracy: 9732/10000 (97.32%)\n",
      "\n",
      "Train Epoch: 11 [0/60000 (0%)]\tLoss: 0.019376\n",
      "Train Epoch: 11 [19200/60000 (32%)]\tLoss: 0.138919\n",
      "Train Epoch: 11 [38400/60000 (64%)]\tLoss: 0.038633\n",
      "Train Epoch: 11 [57600/60000 (96%)]\tLoss: 0.025637\n",
      "\n",
      "Test set: Average loss: 0.0788, Accuracy: 9737/10000 (97.37%)\n",
      "\n",
      "Train Epoch: 12 [0/60000 (0%)]\tLoss: 0.094379\n",
      "Train Epoch: 12 [19200/60000 (32%)]\tLoss: 0.095334\n",
      "Train Epoch: 12 [38400/60000 (64%)]\tLoss: 0.011769\n",
      "Train Epoch: 12 [57600/60000 (96%)]\tLoss: 0.052068\n",
      "\n",
      "Test set: Average loss: 0.0761, Accuracy: 9748/10000 (97.48%)\n",
      "\n",
      "Train Epoch: 13 [0/60000 (0%)]\tLoss: 0.040116\n",
      "Train Epoch: 13 [19200/60000 (32%)]\tLoss: 0.076598\n",
      "Train Epoch: 13 [38400/60000 (64%)]\tLoss: 0.117052\n",
      "Train Epoch: 13 [57600/60000 (96%)]\tLoss: 0.036333\n",
      "\n",
      "Test set: Average loss: 0.0820, Accuracy: 9720/10000 (97.20%)\n",
      "\n",
      "Train Epoch: 14 [0/60000 (0%)]\tLoss: 0.023535\n",
      "Train Epoch: 14 [19200/60000 (32%)]\tLoss: 0.081810\n",
      "Train Epoch: 14 [38400/60000 (64%)]\tLoss: 0.014467\n",
      "Train Epoch: 14 [57600/60000 (96%)]\tLoss: 0.070747\n",
      "\n",
      "Test set: Average loss: 0.0756, Accuracy: 9755/10000 (97.55%)\n",
      "\n",
      "Train Epoch: 15 [0/60000 (0%)]\tLoss: 0.040170\n",
      "Train Epoch: 15 [19200/60000 (32%)]\tLoss: 0.034155\n",
      "Train Epoch: 15 [38400/60000 (64%)]\tLoss: 0.057747\n",
      "Train Epoch: 15 [57600/60000 (96%)]\tLoss: 0.009705\n",
      "\n",
      "Test set: Average loss: 0.0737, Accuracy: 9762/10000 (97.62%)\n",
      "\n",
      "Train Epoch: 16 [0/60000 (0%)]\tLoss: 0.054775\n",
      "Train Epoch: 16 [19200/60000 (32%)]\tLoss: 0.031278\n",
      "Train Epoch: 16 [38400/60000 (64%)]\tLoss: 0.106516\n",
      "Train Epoch: 16 [57600/60000 (96%)]\tLoss: 0.013689\n",
      "\n",
      "Test set: Average loss: 0.0751, Accuracy: 9748/10000 (97.48%)\n",
      "\n",
      "Train Epoch: 17 [0/60000 (0%)]\tLoss: 0.031416\n",
      "Train Epoch: 17 [19200/60000 (32%)]\tLoss: 0.022208\n",
      "Train Epoch: 17 [38400/60000 (64%)]\tLoss: 0.020170\n",
      "Train Epoch: 17 [57600/60000 (96%)]\tLoss: 0.088838\n",
      "\n",
      "Test set: Average loss: 0.0771, Accuracy: 9744/10000 (97.44%)\n",
      "\n",
      "Train Epoch: 18 [0/60000 (0%)]\tLoss: 0.033231\n",
      "Train Epoch: 18 [19200/60000 (32%)]\tLoss: 0.020478\n",
      "Train Epoch: 18 [38400/60000 (64%)]\tLoss: 0.016916\n",
      "Train Epoch: 18 [57600/60000 (96%)]\tLoss: 0.161918\n",
      "\n",
      "Test set: Average loss: 0.0728, Accuracy: 9769/10000 (97.69%)\n",
      "\n",
      "Train Epoch: 19 [0/60000 (0%)]\tLoss: 0.052674\n",
      "Train Epoch: 19 [19200/60000 (32%)]\tLoss: 0.025815\n",
      "Train Epoch: 19 [38400/60000 (64%)]\tLoss: 0.194940\n",
      "Train Epoch: 19 [57600/60000 (96%)]\tLoss: 0.109591\n",
      "\n",
      "Test set: Average loss: 0.0707, Accuracy: 9765/10000 (97.65%)\n",
      "\n",
      "Train Epoch: 20 [0/60000 (0%)]\tLoss: 0.071913\n",
      "Train Epoch: 20 [19200/60000 (32%)]\tLoss: 0.019206\n",
      "Train Epoch: 20 [38400/60000 (64%)]\tLoss: 0.086561\n",
      "Train Epoch: 20 [57600/60000 (96%)]\tLoss: 0.050236\n",
      "\n",
      "Test set: Average loss: 0.0729, Accuracy: 9774/10000 (97.74%)\n",
      "\n",
      "Train Epoch: 21 [0/60000 (0%)]\tLoss: 0.022751\n",
      "Train Epoch: 21 [19200/60000 (32%)]\tLoss: 0.096579\n",
      "Train Epoch: 21 [38400/60000 (64%)]\tLoss: 0.021506\n",
      "Train Epoch: 21 [57600/60000 (96%)]\tLoss: 0.038276\n",
      "\n",
      "Test set: Average loss: 0.0692, Accuracy: 9780/10000 (97.80%)\n",
      "\n",
      "Train Epoch: 22 [0/60000 (0%)]\tLoss: 0.024852\n",
      "Train Epoch: 22 [19200/60000 (32%)]\tLoss: 0.029605\n",
      "Train Epoch: 22 [38400/60000 (64%)]\tLoss: 0.068798\n",
      "Train Epoch: 22 [57600/60000 (96%)]\tLoss: 0.011417\n",
      "\n",
      "Test set: Average loss: 0.0716, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 23 [0/60000 (0%)]\tLoss: 0.034687\n",
      "Train Epoch: 23 [19200/60000 (32%)]\tLoss: 0.043969\n",
      "Train Epoch: 23 [38400/60000 (64%)]\tLoss: 0.012936\n",
      "Train Epoch: 23 [57600/60000 (96%)]\tLoss: 0.106054\n",
      "\n",
      "Test set: Average loss: 0.0697, Accuracy: 9782/10000 (97.82%)\n",
      "\n",
      "Train Epoch: 24 [0/60000 (0%)]\tLoss: 0.107143\n",
      "Train Epoch: 24 [19200/60000 (32%)]\tLoss: 0.025315\n",
      "Train Epoch: 24 [38400/60000 (64%)]\tLoss: 0.055301\n",
      "Train Epoch: 24 [57600/60000 (96%)]\tLoss: 0.239674\n",
      "\n",
      "Test set: Average loss: 0.0689, Accuracy: 9771/10000 (97.71%)\n",
      "\n",
      "Train Epoch: 25 [0/60000 (0%)]\tLoss: 0.013201\n",
      "Train Epoch: 25 [19200/60000 (32%)]\tLoss: 0.030046\n",
      "Train Epoch: 25 [38400/60000 (64%)]\tLoss: 0.015313\n",
      "Train Epoch: 25 [57600/60000 (96%)]\tLoss: 0.003874\n",
      "\n",
      "Test set: Average loss: 0.0745, Accuracy: 9762/10000 (97.62%)\n",
      "\n",
      "Train Epoch: 26 [0/60000 (0%)]\tLoss: 0.019181\n",
      "Train Epoch: 26 [19200/60000 (32%)]\tLoss: 0.013096\n",
      "Train Epoch: 26 [38400/60000 (64%)]\tLoss: 0.014488\n",
      "Train Epoch: 26 [57600/60000 (96%)]\tLoss: 0.047444\n",
      "\n",
      "Test set: Average loss: 0.0696, Accuracy: 9785/10000 (97.85%)\n",
      "\n",
      "Train Epoch: 27 [0/60000 (0%)]\tLoss: 0.022258\n",
      "Train Epoch: 27 [19200/60000 (32%)]\tLoss: 0.029947\n",
      "Train Epoch: 27 [38400/60000 (64%)]\tLoss: 0.048224\n",
      "Train Epoch: 27 [57600/60000 (96%)]\tLoss: 0.031788\n",
      "\n",
      "Test set: Average loss: 0.0739, Accuracy: 9766/10000 (97.66%)\n",
      "\n",
      "Train Epoch: 28 [0/60000 (0%)]\tLoss: 0.106767\n",
      "Train Epoch: 28 [19200/60000 (32%)]\tLoss: 0.019051\n",
      "Train Epoch: 28 [38400/60000 (64%)]\tLoss: 0.088062\n",
      "Train Epoch: 28 [57600/60000 (96%)]\tLoss: 0.006158\n",
      "\n",
      "Test set: Average loss: 0.0726, Accuracy: 9787/10000 (97.87%)\n",
      "\n",
      "Train Epoch: 29 [0/60000 (0%)]\tLoss: 0.042846\n",
      "Train Epoch: 29 [19200/60000 (32%)]\tLoss: 0.006825\n",
      "Train Epoch: 29 [38400/60000 (64%)]\tLoss: 0.268002\n",
      "Train Epoch: 29 [57600/60000 (96%)]\tLoss: 0.020643\n",
      "\n",
      "Test set: Average loss: 0.0700, Accuracy: 9774/10000 (97.74%)\n",
      "\n",
      "Train Epoch: 30 [0/60000 (0%)]\tLoss: 0.007063\n",
      "Train Epoch: 30 [19200/60000 (32%)]\tLoss: 0.033594\n",
      "Train Epoch: 30 [38400/60000 (64%)]\tLoss: 0.004714\n",
      "Train Epoch: 30 [57600/60000 (96%)]\tLoss: 0.036995\n",
      "\n",
      "Test set: Average loss: 0.0722, Accuracy: 9783/10000 (97.83%)\n",
      "\n",
      "Train Epoch: 31 [0/60000 (0%)]\tLoss: 0.145252\n",
      "Train Epoch: 31 [19200/60000 (32%)]\tLoss: 0.142184\n",
      "Train Epoch: 31 [38400/60000 (64%)]\tLoss: 0.023869\n",
      "Train Epoch: 31 [57600/60000 (96%)]\tLoss: 0.023832\n",
      "\n",
      "Test set: Average loss: 0.0701, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 32 [0/60000 (0%)]\tLoss: 0.043047\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Epoch: 32 [19200/60000 (32%)]\tLoss: 0.052055\n",
      "Train Epoch: 32 [38400/60000 (64%)]\tLoss: 0.034246\n",
      "Train Epoch: 32 [57600/60000 (96%)]\tLoss: 0.030147\n",
      "\n",
      "Test set: Average loss: 0.0762, Accuracy: 9764/10000 (97.64%)\n",
      "\n",
      "Train Epoch: 33 [0/60000 (0%)]\tLoss: 0.030427\n",
      "Train Epoch: 33 [19200/60000 (32%)]\tLoss: 0.108568\n",
      "Train Epoch: 33 [38400/60000 (64%)]\tLoss: 0.019433\n",
      "Train Epoch: 33 [57600/60000 (96%)]\tLoss: 0.019470\n",
      "\n",
      "Test set: Average loss: 0.0757, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 34 [0/60000 (0%)]\tLoss: 0.029818\n",
      "Train Epoch: 34 [19200/60000 (32%)]\tLoss: 0.004257\n",
      "Train Epoch: 34 [38400/60000 (64%)]\tLoss: 0.008645\n",
      "Train Epoch: 34 [57600/60000 (96%)]\tLoss: 0.040206\n",
      "\n",
      "Test set: Average loss: 0.0715, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 35 [0/60000 (0%)]\tLoss: 0.015198\n",
      "Train Epoch: 35 [19200/60000 (32%)]\tLoss: 0.009026\n",
      "Train Epoch: 35 [38400/60000 (64%)]\tLoss: 0.091951\n",
      "Train Epoch: 35 [57600/60000 (96%)]\tLoss: 0.005740\n",
      "\n",
      "Test set: Average loss: 0.0696, Accuracy: 9799/10000 (97.99%)\n",
      "\n",
      "Train Epoch: 36 [0/60000 (0%)]\tLoss: 0.012233\n",
      "Train Epoch: 36 [19200/60000 (32%)]\tLoss: 0.010342\n",
      "Train Epoch: 36 [38400/60000 (64%)]\tLoss: 0.035036\n",
      "Train Epoch: 36 [57600/60000 (96%)]\tLoss: 0.024123\n",
      "\n",
      "Test set: Average loss: 0.0723, Accuracy: 9798/10000 (97.98%)\n",
      "\n",
      "Train Epoch: 37 [0/60000 (0%)]\tLoss: 0.009211\n",
      "Train Epoch: 37 [19200/60000 (32%)]\tLoss: 0.020877\n",
      "Train Epoch: 37 [38400/60000 (64%)]\tLoss: 0.010774\n",
      "Train Epoch: 37 [57600/60000 (96%)]\tLoss: 0.047536\n",
      "\n",
      "Test set: Average loss: 0.0731, Accuracy: 9794/10000 (97.94%)\n",
      "\n",
      "Train Epoch: 38 [0/60000 (0%)]\tLoss: 0.019821\n",
      "Train Epoch: 38 [19200/60000 (32%)]\tLoss: 0.036303\n",
      "Train Epoch: 38 [38400/60000 (64%)]\tLoss: 0.011818\n",
      "Train Epoch: 38 [57600/60000 (96%)]\tLoss: 0.008971\n",
      "\n",
      "Test set: Average loss: 0.0750, Accuracy: 9780/10000 (97.80%)\n",
      "\n",
      "Train Epoch: 39 [0/60000 (0%)]\tLoss: 0.008825\n",
      "Train Epoch: 39 [19200/60000 (32%)]\tLoss: 0.004915\n",
      "Train Epoch: 39 [38400/60000 (64%)]\tLoss: 0.028634\n",
      "Train Epoch: 39 [57600/60000 (96%)]\tLoss: 0.003883\n",
      "\n",
      "Test set: Average loss: 0.0740, Accuracy: 9796/10000 (97.96%)\n",
      "\n",
      "Train Epoch: 40 [0/60000 (0%)]\tLoss: 0.028311\n",
      "Train Epoch: 40 [19200/60000 (32%)]\tLoss: 0.008801\n",
      "Train Epoch: 40 [38400/60000 (64%)]\tLoss: 0.035648\n",
      "Train Epoch: 40 [57600/60000 (96%)]\tLoss: 0.001089\n",
      "\n",
      "Test set: Average loss: 0.0741, Accuracy: 9783/10000 (97.83%)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "model=QuadNet(N_OUTPUT)\n",
    "results['QuadNet'], pred_labels = main(\n",
    "    model=model, \n",
    "    args=Parser(),\n",
    "    task='font',\n",
    "    return_pred_label=True,\n",
    "    reg_l2=False\n",
    ")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "For the sake of curiosity, let's print the confusion matrix for the base model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAJCCAYAAAA4MjbhAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvnQurowAAIABJREFUeJzt3Xm0HWWdL/zv74RJRQYRuRhwBBfq60hQEV+RKIOCDAqKeoVWrulWuqUnsZ3b6d722oqtLWhaFBxaHBEQu2kGFScIkzIICIooOICS4ARIwvP+UTt5j0iSfeycoYrPZ629zq6nau96dq21s3/51vNUVWstAAB9NzHbHQAAWBcUNQDAIChqAIBBUNQAAIOgqAEABkFRAwAMgqIGABgERQ0AMAiKGgBgENab7h1MTNzDJYthFtx6+/tnuwtwt7XBvJfWTO6vav0Z+61t7fYZ/WxTIakBAAZBUQMADMK0n34CAKZXZc6eEZpRkhoAYBAkNQDQdyWpSSQ1AMBASGoAoPdkFImjAAAMhKQGAHquZBRJJDUAwEBIagCg70pGkUhqAICBkNQAQO/JKBJHAQAYCEUNADAITj8BQM+Z0t1xFACAQZDUAEDPlSndSSQ1AMBASGoAoPdkFImjAAAMhKQGAHquat5sd2FOkNQAAIMgqQGAnnOdmo6jAAAMgqQGAHrOdWo6jgIAMAiSGgDoOWNqOo4CADAIkhoA6DljajqOAgAwCIoaAGAQnH4CgJ5zm4SOpAYAGARJDQD0nCndHUcBABgESQ0A9Jwp3R1HAQAYBEkNAPRcxeynRFIDAAyEpAYAes6Ymo6jAAAMgqQGAHpuQkaRRFIDAAyEpAYAes69nzqSGgBgECQ1ANBz7v3UcRQAgEFQ1AAAg+D0EwD03ISL7yWR1AAAAyGpAYCec0PLjqQGABgESQ0A9Jwp3R1HAQAYBEkNAPTchNskJJHUAAADIakBgJ4zpqbjKAAAgyCpAYCem3CdmiSSGgBgICQ1ANBzxtR0HAUAYBAkNQDQcxMyiiSSGgBgIBQ1AMAgOP0EAD1XpnQnkdQAAAMhqQGAnjNQuOMoAACDIKkBgJ6T1HQcBQBgECQ1ANBzZj91JDUAwCBIagCg54yp6TgKAMAgSGoAoOcmmowikdQAAAMhqQGAnisZRRJJDQAwEJIaAOg5s586jgIAMAiKGgBgEJx+AoCec/qp4ygAAIMgqQGAnnPxvY6jAAAMgqQGAHpuIjXbXZgTJDUAwCBIagCg59wmoeMoAACDIKkBgJ4zpqYjqQEABkFSAwA95zo1HUcBABgESQ0A9JwxNR1JDQAwCJIaAOi5ktQkkdQAAAOhqAGAnptIzdhjHFU1r6ouqqovjpYfXFXnVtXVVfWpqtpg1L7haPnq0foHTXqP14zar6yqPcc7DgAA69YRSS6ftPyOJEe11rZLsjTJYaP2w5IsHbUfNdouVfWIJAcneWSSvZIcXVXz1rZTRQ0AsM5U1TZJ9k7yodFyJVmY5LOjTY5Psv/o+X6j5YzWP320/X5JTmit3dZauybJ1UmesLZ9GygMAD03x6Z0vyfJkUnuPVreIsmy1try0fJ1SeaPns9P8uMkaa0tr6qbR9vPT3LOpPec/JrVktQAAGOrqkVVdf6kx6JJ6/ZJckNr7YLZ6JukBgB6biandLfWFidZvJrVuyTZt6qelWSjJJsk+Zckm1XVeqO0Zpsk14+2vz7Jtkmuq6r1kmya5JeT2lea/JrVktQAAOtEa+01rbVtWmsPSjfQ96zW2ouSfDnJgaPNDk1y0uj5yaPljNaf1Vpro/aDR7OjHpxk+yRL1rZ/SQ0A9NxEzakxNXfl1UlOqKq3JbkoybGj9mOTfKyqrk5yU7pCKK21y6rq00m+m2R5ksNbayvWthNFDQCwzrXWvpLkK6PnP8hdzF5qrd2a5KDVvP7tSd4+lX0qagCg5+bY7KdZY0wNADAIkhoA6DkJRcdxAAAGQVIDAD03k9epmcskNQDAIEhqAKDnenCdmhkhqQEABkFSAwA9J6HoOA4AwCAoagCAQXD6CQB6rgwUTiKpAQAGQlIDAD0noeg4DgDAIEhqAKDnjKnpSGoAgEGQ1ABAz0koOo4DADAIkhoA6LkJQ2qSSGoAgIGQ1ABAz1VENYmkBgAYCEXN3dTExEQuuOBbOfnkzyVJFi58Ws4//5u58MJzcvbZZ+ahD33Iqm0POui5ufTSC3PJJRfk4x8/blX7IYe8KFdeeUmuvPKSHHLIi2b2A0DPveF1X8quT3lfDtj32FVt73vv2XnO/h/OgQd8JIv+16dyww2/TpKct+RH2fkJR+XAAz6SAw/4SI45+huz1W3mqImaucdcVq21ad3BxMQ9pncH/En+5m9emR13fHw22eTe2Xff5+aKKy7O/vsflCuuuDIvf/mi7LTTgrz0pYuy3XYPzac+9fE8/enPzLJly7LlllvmxhtvzOabb57zzvtGdtppl7TWcv7538yCBU/OsmXLZvujMXLr7e+f7S6wBuef/+Pc857r53X/cGpOPPmwJMlvfnNbNt54wyTJJz52fr7//V/mjf+4Z85b8qMc95Elef8xB85ml5mCDea9dEZ//g/a7JUz9lv7mWXvnbOljaTmbmj+/Pl51rP2yrHHfmRVW2stm2yySZJk0003yU9/+tMkycte9tIcffQHVxUrN954Y5Jkzz13zxlnnJmlS5dm2bJlOeOMM7PXXnvM8CeB/lqwYNtsuuk9/qBtZUGTJLfccntcJJZx1Qw+5rKxBgpXd/3lFyV5SGvtLVX1gCT/o7W2ZFp7x7Q46qh35tWvfl3ufe+NV7W97GWvyKmnnphbbrk1v/rVr7LzzrsmSbbffvskyde+dlbmzZuXN7/5bTnttNMzf/798+MfX7fq9dddd33mz7//zH4QGKD3vufsnHzypbn3xhvm2ONesKr9O9++Ps894MPZcsuN8/ev2i3bbb/lLPYS5qZxk5qjk+ycZOU37NdJVpttV9Wiqjq/qs5vbfl/s4usS3vv/czceOMNufDCi/6g/a//+q+y994H5AEP2C7HHfexvPvd70iSrLfevGy33XbZbbc98sIXHpLFi4/OpptuOhtdh7uFV/71U3PGWa/I3vs8Ip/8xAVJkoc/Yqv81xkvz+dOfGle+KIdc8RfnTjLvYS5adyi5omttcOT3JokrbWlSTZY3cattcWttQWttQVVZo3PJbvssnOe/ex98oMfXJFPfvKjWbjwaTnllM/nMY95VJYsOS9J8qlPfTY77/ykJMn111+fU075YpYvX54f/vDafO97V2X77bfL9df/JNtuu82q991mm/m5/vqfzMIngmHae59H5ozTv5ekOy11z3t1/+Q+ddeHZvnyFVm69Hez2T3mmImqGXvMZeMWNbdX1bwkLUmqasskd0xbr5g2r33tG/OAB2yXhzxkh7zgBYfkrLO+kv33PyibbrpJtt9+uyTJ7rsvzOWXX5kk+cIXTsmuuz41SbLFFlvkYQ/bPj/4wTU57bTTs/vuz8hmm22WzTbbLLvv/oycdtrps/a5YAiu/eFNq56fddZVefBD7pMk+cWNv8nKSR2XXPyT3HFHy2ab3eMu3wPuzsaNUd6b5MQk96uqtyc5MMnrp61XzKgVK1Zk0aLD89nPfjJ33HFHli5dlsMO+/MkyWmnnZ499nhGLr30wqxYsSJHHvna3HRT9w/v2972f7JkydeTJG996//O0qVLZ+0zQN8c+fcn57wlP8qyZbfk6bu9P4f/5VPytbN/kB9ec1NqonL/+2+SN7xpzyTJf/3Xlfn0CRdl3noT2WjD9fLOd+2bmuP/Y2ZmmfXTGXtKd1XtkOTp6QY/n9lau3yc15nSDbPDlG6YPTM9pfuFmx8xY7+1/770X+ZsRT3u7Kf3JjmhteZfSQCYYwR3nXETqwuSvL6qvl9V/1xVC6azUwAAUzVWUtNaOz7J8VV1nyTPTfKOqnpAa237ae0dALBWc/32BTNlqmOLtkuyQ5IHJrli3XcHAOBPM+6Ymv+b5IAk30/yqSRvba25yQ8AzAGCms64U7q/n2Tn1tovprMzAAB/qjUWNVW1Q2vtiiTnJXnA6J5Pq7TWLpzOzgEAa2dMTWdtSc3fJlmU5F13sa4lWbjOewQA8CdYY1HTWls0+rvbzHQHAJgqVxTujHUcquqgqrr36Pnrq+rzVfW46e0aAMD4xi3u3tBa+3VVPSXJM5Icm+QD09ctAGBcVTP3mMvGLWpWjP7unWRxa+3UJBtMT5cAAKZu3KLm+qr6YJLnJ/lSVW04hdcCAEy7ca9T87wkeyX559basqraOsmrpq9bAMC4TOnurLWoqap5SS5sre2wsq219tMkP53OjgEATMVaTyG11lYkufLOF94DAOaGmsHHXDbu6afNk1xWVUuS/HZlY2tt32npFQDAFI1b1LxhWnsBAPzJjKnpjFXUtNa+Ot0dAQD47xirqKmqX6e711PSXZ9m/SS/ba1tMl0dAwDG4xornXGTmnuvfF5VlWS/JE+ark4BAEzVlIu71vlCkj2noT8AwBS5TUJn3NNPz5m0OJFkQZJbp6VHAAB/gnFnPz170vPlSX6YxHRuAJgDzH7qjFvUTCQ5orW2LEmqavMk70ry0unqGADAVIxb1Dx6ZUGTJK21pVX1uGnqEwAwBYKazrgDhSdG6UySpKruk/ELIgCAaTduYfKuJN+qqs+Mlg9K8vbp6RIAMBXG1HTGvU7NR6vq/CQLR03Paa19d/q6BQAwNWOfQhoVMQoZAGBOMi4GAHrObRI6jgMAMAiSGgDoubl++4KZIqkBAAZBUgMAPSeh6DgOAMAgSGoAoOeMqelIagCAQZDUAEDPTVSb7S7MCZIaAGAQJDUA0HOG1HQkNQDAIEhqAKDnJkQ1SSQ1AMBASGoAoOckFB3HAQAYBEUNADAITj8BQM+5TUJHUgMADIKkBgB6biJuk5BIagCAgZDUAEDPGVPTkdQAAIMgqQGAnnObhI6kBgAYBEkNAPSc2U8dSQ0AMAiSGgDoObOfOpIaAGAQJDUA0HMSio7jAAAMgqQGAHquyuynRFIDAAyEogYAGASnnwCg5yQUHccBABgESQ0A9NyEgcJJJDUAwEBIagCg59wloSOpAQAGQVIDAD03IapJIqkBAAZCUQMAPVfVZuyx5n7URlW1pKq+U1WXVdWbR+0Prqpzq+rqqvpUVW0wat9wtHz1aP2DJr3Xa0btV1bVnuMcB0UNALCu3JZkYWvtMUkem2SvqnpSknckOaq1tl2SpUkOG21/WJKlo/ajRtulqh6R5OAkj0yyV5Kjq2re2nauqAGAnpuYwceatM5vRovrjx4tycIknx21H59k/9Hz/UbLGa1/elXVqP2E1tptrbVrklyd5AnjHAcAgLFU1aKqOn/SY9Gd1s+rqm8nuSHJ6Um+n2RZa235aJPrkswfPZ+f5MdJMlp/c5ItJrffxWtWy+wnAOi5tY11WZdaa4uTLF7D+hVJHltVmyU5MckOM9U3SQ0AsM611pYl+XKSnZNsVlUrg5Rtklw/en59km2TZLR+0yS/nNx+F69ZLUUNAPTcXBlTU1VbjhKaVNU9kuye5PJ0xc2Bo80OTXLS6PnJo+WM1p/VWmuj9oNHs6MenGT7JEvWdhycfgIA1pWtkxw/mqk0keTTrbUvVtV3k5xQVW9LclGSY0fbH5vkY1V1dZKb0s14Smvtsqr6dJLvJlme5PDRaa01UtQAAOtEa+3iJI+7i/Yf5C5mL7XWbk1y0Gre6+1J3j6V/StqAKDnJmZwoPBcZkwNADAIkhoA6Dn3s+xIagCAQZDUAEDPGVPTkdQAAIMgqQGAnpvJ2yTMZZIaAGAQJDUA0HMSio7jAAAMgqQGAHrO7KeOpAYAGARJDQD0nCsKdyQ1AMAgSGoAoOeMqelIagCAQVDUAACD4PQTAPSc2yR0JDUAwCBIagCg5yYiqUkkNQDAQEhqAKDnytX3kkhqAICBkNQAQM+5+F5HUgMADIKkBgB6rsx+SiKpAQAGQlIDAD03YfZTEkkNADAQkhoA6DmznzqSGgBgECQ1ANBzZj91JDUAwCAoagCAQXD6CQB6zkDhjqQGABgESQ0A9FxJapJIagCAgZDUAEDPSSg6jgMAMAiSGgDoOWNqOpIaAGAQJDUA0HOuU9OR1AAAgyCpAYCeM6amI6kBAAZBUgMAPTcRSU0iqQEABkJSAwA9Z0xNR1IDAAzCtCc1t9/xoeneBXAX1qs/m+0uwN1Way+d0f25Tk1HUgMADIKiBgAYBAOFAaDnDBTuSGoAgEGQ1ABAzxko3JHUAACDIKkBgJ4zpqYjqQEABkFSAwA9V25omURSAwAMhKQGAHrO7KeOpAYAGARJDQD0nNlPHUkNADAIkhoA6DljajqSGgBgECQ1ANBzxtR0JDUAwCAoagCAQXD6CQB6zumnjqQGABgESQ0A9Jwp3R1JDQAwCJIaAOg5Y2o6khoAYBAkNQDQc5KajqQGABgESQ0A9JzZTx1JDQAwCJIaAOg5Y2o6khoAYBAkNQDQc5KajqQGABgESQ0A9JzZTx1JDQAwCIoaAGAQnH4CgJ4zULgjqQEABkFSAwA9J6npSGoAgEGQ1ABAz9WEpCaR1AAAAyGpAYCem6g7ZrsLc4KkBgAYBEkNAPSc2U8dSQ0AMAiSGgDoOUlNR1IDAAyCpAYAek5S05HUAACDIKkBgJ5zReGOpAYAGARFDQCwTlTVtlX15ar6blVdVlVHjNrvU1WnV9VVo7+bj9qrqt5bVVdX1cVV9fhJ73XoaPurqurQcfavqAGAnpuoNmOPtVie5O9aa49I8qQkh1fVI5L8Q5IzW2vbJzlztJwkz0yy/eixKMkxSVcEJXlTkicmeUKSN60shNZ4HKZ64AAA7kpr7aettQtHz3+d5PIk85Psl+T40WbHJ9l/9Hy/JB9tnXOSbFZVWyfZM8nprbWbWmtLk5yeZK+17d9AYQDouZrBG1pW1aJ0qcpKi1tri+9iuwcleVySc5Ns1Vr76WjVz5JsNXo+P8mPJ73sulHb6trXSFEDAIxtVMD8UREzWVVtnORzSf66tfarqpr8+lbTdGEdp58AoOeq2ow91t6XWj9dQfOJ1trnR80/H51WyujvDaP265NsO+nl24zaVte+RooaAGCdqC6SOTbJ5a21d09adXKSlTOYDk1y0qT2Q0azoJ6U5ObRaarTkuxRVZuPBgjvMWpbI6efAKDn5tDF93ZJ8uIkl1TVt0dtr03yT0k+XVWHJbk2yfNG676U5FlJrk7yuyQvSZLW2k1V9dYk5422e0tr7aa17VxRAwCsE621ryep1ax++l1s35Icvpr3+nCSD09l/4oaAOg5N7TsGFMDAAyCpAYAek5S05HUAACDIKkBgJ6bQ7OfZpWkBgAYBEkNAPTcTN77aS6T1AAAg6CoAQAGweknAOg5A4U7khoAYBAkNQDQcy6+15HUAACDIKkBgJ6T1HQkNQDAIEhqAKDnzH7qSGoAgEGQ1ABAz7lNQkdSAwAMgqQGAHrOmJqOpAYAGARJDQD0nOvUdCQ1AMAgSGoAoO+MqUkiqQEABkJRAwAMgtNPANBzLr7XkdQAAIMgqQGAnnPxvY6kBgAYBEkNAPSci+91JDUAwCBIagCg54yp6UhqAIBBkNQAQN9NuE5NIqkBAAZCUgMAPWf2U0dSAwAMgqQGAHrO7KeOpAYAGARJDQD0ndlPSSQ1AMBAKGoAgEFw+gkAes6U7o6kBgAYBEkNAPScKd0dSQ0AMAiSGgDoO1O6k0hqAICBkNQAQM+Z/dSR1AAAgyCpAYCeM/upI6kBAAZBUgMAfWf2UxJJDQAwEJIaAOg5s586khoAYBAkNQDQd2Y/JZHUAAADoagBAAbB6ScA6DkX3+tIagCAQZDUAEDfufheEkkNADAQkhoA6DkX3+tIagCAQZDUAEDfmf2URFIDAAyEpAYA+s7spySSGiY5/rhz8uy9j8m++xyTv//bz+W225bnVX/3+Txrz/dn332Oyetec3Juv33FbHcTem1iYiIXXnheTjnlC0mS3XZ7Wi64YEkuueSiHHfchzNv3rwkyQtf+IJ85zsX5uKLL8o3vnF2Hv3oRydJNtxww5x77jfz7W9fkEsv/Xb+8R/fOGufBeYaRQ1Jkp///Ff5+EeX5DOf+185+Ysvz4oVLV869dLss++jcup/viInnfIXue222/O5z1w0212FXjviiFfm8ssvT5JUVY4//sM5+OAX5VGPelyuvfbaHHroIUmSa675YXbddWEe/ejH5a1vfXsWLz4mSXLbbbdl4cLd89jH7pjHPnZB9tprzzzxiU+ctc/D3FATbcYec5mihlVWrLgjt966PMuX35Fbb70997vfvbPrrtunqlJVedSj5+dnP//VbHcTemv+/PnZe+9n5kMf+nCSZIsttsjvf//7XHXVVUmS008/I8997gFJkm9961tZtmxZkuScc87NNtvMX/U+v/3tb5Mk66+/ftZff/20Nrd/aGCmKGpIkmy11SZ5yUt3ztN3e092fcq7s/HGG2aXpzx01frbb1+Rk0+6OE/5fx+6hncB1uQ973lXjjzyNbnjjm78wy9+8Yust9562XHHHZMkBx743Gy77bZ/9LrDDntJ/uM/Tlu1PDExkYsuOj833PCTnH76GVmyZMnMfADmrmoz95jDxi5qqmrvqjqyqt648jGdHWNm3XzzLTnrzCtz+pmvzFe+9je55Zbbc/JJF69a/9Y3fykLFjwwCxY8cBZ7Cf21997Pyg033JgLL7zwD9oPPvh/5qij/jnnnvvN/PrXv86KFX84bu1pT9s1hx32krz61a9Z1XbHHXfkcY9bkG22eVCe8ISd8shHPnJGPgPMdWMVNVX1gSTPT/JXSSrJQUlW++tWVYuq6vyqOv/fFp+1TjrK9PrWN6/J/G02y33uc6+sv/687L7HDvn2RdclSd7/r1/NTTf9Lq9+zR6z3Evor112eXL23XefXHPNVTnhhE9k4cLd8rGPHZ9zzjknT33qbnniE5+cs8/+Wr73ve+tes2jHvWofOhDH8x++z03N9100x+9580335wvf/kr2Wsv3827vYk2c485bNyk5smttUOSLG2tvTnJzkketrqNW2uLW2sLWmsLXrZo4broJ9Ns6/tvku985/rccsvtaa3lnG9dk4c89L757GcuzDe+/v3887ufk4mJmu1uQm+99rWvz7bbPjgPfvD2OfjgF+Wss76cF7/40Gy55ZZJkg022CCvfvWr8oEPLE6SbLvttvn85z+dF7/4JavG3CTJfe9732y66aZJko022ii77/6MXHHFlTP/gWAOGvc6NbeM/v6uqu6f5JdJtp6eLjEbHvOYbbLHng/PgQcszrz1JvLwh/+PPO/5j8+Oj/0/uf/9N8sLnt8NbNx99x3yir/cdZZ7C8Pxqlf9XfbZ51mZmJjIMccszpe//JUkyRvf+PpsscUWOfro9yVJli9fnp12elK23nrrHH98N/V7YqLy6U9/Nqee+qVZ/AQwd9Q4o+ar6g1J3pfk6Unen6Ql+VBr7Q1re+2KfGJuZ1UwUOvVn812F+Buq7XbZzTavv1f7jFjv7XrH3HLnI3tx0pqWmtvHT39XFV9MclGrbWbp69bAABTs8aipqoWttbOqqrn3MW6tNY+P31dAwDGMscH8M6UtSU1uyY5K8mz72JdS6KoAQDmhDUWNa21N43+vmRmugMATJlL6SYZc0xNVf3tXTTfnOSC1tq3122XAACmbtwp3QtGj1NGy/skuTjJX1TVZ1pr/3c6OgcArN1cv9HkTBm3qNkmyeNba79Jkqp6U5JTkzw1yQVJFDUAwKwat6i5X5LbJi3fnmSr1totVXXbal4DAMyEOXvlmJk1blHziSTnVtVJo+VnJ/n3qrpXku9OS88AAKZg7IvvVdV/JNll1PQXrbXzR89fNC09AwDGY/ZTkjGKmqqal+Sy1toOSc5f2/YAALNhrUVNa21FVV1ZVQ9orf1oJjoFAEyBpCbJ+GNqNk9yWVUtSfLblY2ttX2npVcAAFM0blGz1rtxAwCzZML0p2T8gcJfraqtkuw0alrSWrth+roFADA1Y52Fq6rnJVmS5KAkz0s3vfvA6ewYAMBUjHv66XVJdlqZzlTVlknOSPLZ6eoYADCeMlA4yfjjpSfudLrpl1N4LQDAtBs3qfnPqjotySdHy89P8h/T0yUAYEoMFE4y/kDhV1XVc5I8ZdS0uLV24vR1CwBgasZNapLubty/aq2dUVX3rKp7t9Z+PV0dAwDGJKlJMv7sp5elGxT8wVHT/CRfmK5OAQBM1bhJzeFJnpDk3CRprV1VVfebtl4BAOOT1CQZfwbTba21369cqKr1krTp6RIAwNSNm9R8tapem+QeVbV7klckOWX6ugUAjM2FapKMn9T8Q5Ibk1ySZFGSU1trr5u2XgEAvVRVH66qG6rq0klt96mq06vqqtHfzUftVVXvraqrq+riqnr8pNccOtr+qqo6dJx9r7Goqar9qurw1todrbV/S/LAJAuSvNZtEgBgjpiomXus3XFJ9rpT2z8kObO1tn2SM0fLSfLMJNuPHouSHJN0RVCSNyV5YroxvW9aWQit8TCsZf2RSU6etLxBkh2TPC3Jy9f25gDA3Utr7ewkN92peb8kx4+eH59k/0ntH22dc5JsVlVbJ9kzyemttZtaa0uTnJ4/LpT+yNrG1GzQWvvxpOWvt9ZuSnJTVd1rbW8OAMyAiTk/pmar1tpPR89/lmSr0fP5SSbXGdeN2lbXvkZrOwp/EPW01v5y0uKWa3tzAGBYqmpRVZ0/6bFoKq9vrbVM0wzqtSU151bVy0bjaVapqj9PsmQ6OgQATNEMJjWttcVJFk/xZT+vqq1baz8dnV5aeZPs65NsO2m7bUZt16cb6jK5/Str28naipq/SfKFqnphkgtHbTsm2TD///kwAIA1OTnJoUn+afT3pEntf1lVJ6QbFHzzqPA5Lcn/njQ4eI8kr1nbTtZY1LTWbkjy5KpamOSRo+ZTW2tnTfXTAADTZA5dUbiqPpkuZblvVV2XbhbTPyX5dFUdluTaJM8bbf6lJM9KcnWS3yV5SZK01m4fRxc7AAAHIUlEQVSqqrcmOW+03VtGY3rXvO/u1Nb0WZFPuPIwzIL16s9muwtwt9Xa7TNaZaw4cYsZ+62dd8Av504FdSdzfrg0AMA4xr1NAgAwV839Kd0zwlEAAAZBUgMAfSepSSKpAQAGQlIDAH0nqUkiqQEABkJSAwA91yQ1SSQ1AMBASGoAoO8m5s12D+YESQ0AMAiSGgDoO2NqkkhqAICBkNQAQN9JapJIagCAgZDUAEDfSWqSSGoAgIFQ1AAAg+D0EwD0XHPxvSSSGgBgICQ1ANB3BgonkdQAAAMhqQGAvpPUJJHUAAADIakBgL4z+ymJpAYAGAhJDQD0XCsZRSKpAQAGQlIDAH1nTE0SSQ0AMBCSGgDoO0lNEkkNADAQkhoA6LnmisJJJDUAwEAoagCAQXD6CQD6zkDhJJIaAGAgJDUA0HNNUpNEUgMADISkBgD6TlKTRFIDAAyEpAYAes6Ymo6kBgAYBEkNAPSdpCaJpAYAGAhJDQD0nDE1HUkNADAIkhoA6DtJTRJJDQAwEJIaAOg5Y2o6khoAYBAUNQDAIDj9BAB9N+HnPJHUAAADobQDgL4zUDiJpAYAGAhJDQD0XDOmJomkBgAYCKUdAPSdMTVJJDUAwEBIagCg51r5OU8kNQDAQCjtAKDvzH5KIqkBAAZCaQcAfSepSSKpAQAGQmkHAD3nisIdSQ0AMAiKGgBgEORVANB3Lr6XRFIDAAyE0g4A+s5A4SSSGgBgIJR2ANB3kpokkhoAYCCUdgDQc2X2UxJJDQAwEEo7AOi7ifVnuwdzgqQGABgESQ0A9JwxNR1JDQAwCEo7AOg7SU0SSQ0AMBBKOwDouXJF4SSSGgBgIBQ1AMAgyKsAoOdM6e5IagCAQVDaAUDPSWo6khoAYBCUdgDQcxOSmiSSGgBgIJR2ANBzVfNmuwtzgqQGABgESQ0A9JzZTx1JDQAwCEo7AOi5iQljahJJDQAwENVam+0+MIdV1aLW2uLZ7gfc3fjuwdRJalibRbPdAbib8t2DKVLUAACDoKgBAAZBUcPaOKcPs8N3D6bIQGEAYBAkNQDAIChqGFtVfaiqHjHb/YC5rKq2qqp/r6ofVNUFVfWtqjpgmvf5lqp6xnTuA/rA6Sf+QFWt11pbPtv9gD6qqkryzSTHt9Y+MGp7YJJ9W2vv+2+8r+8ljEFSM2BVdUhVXVxV36mqj1XVcVV14KT1vxn9fVpVfa2qTk7y3aq6V1WdOnrdpVX1/NF2X6mqBVX1F1X1zknv82dV9a+j5/+zqpZU1ber6oNV5drd3J0sTPL7lQVNkrTWrm2tva+q5lXVO6vqvNH38s+TrhAatV9aVZdM+r79wfdy1PaGqrqyqr5eVZ+sqr8fta/6blfVG0f7uLSqFo8KLbhbUNQMVFU9MsnrkyxsrT0myRFrecnjkxzRWntYkr2S/KS19pjW2v+T5D/vtO3nkkyO05+f5ISqevjo+S6ttccmWZHkRf/9TwO98cgkF65m3WFJbm6t7ZRkpyQvq6oHJ3lOkscmeUySZyR5Z1VtPXrNqu9lVe2U5Lmj7Z6ZZMFq9vOvrbWdRt/deyTZZx18LugFN7QcroVJPtNa+0WStNZuWst/2Ja01q4ZPb8kybuq6h1Jvtha+9rkDVtrN47GCzwpyVVJdkjyjSSHJ9kxyXmjfd0jyQ3r8DNBr1TV+5M8Jcnvk1yb5NGT0tJNk2w/Wv/J1tqKJD+vqq+mK3p+lT/8Xu6S5KTW2q1Jbq2qU1az292q6sgk90xynySXJVndtjAoipq7l+UZpXNVNZFkg0nrfrvySWvte1X1+CTPSvK2qjqztfaWO73XCUmel+SKJCe21too5j6+tfaa6fwQMIddli5NSZK01g6vqvsmOT/Jj5L8VWvttMkvqKpnruH9fruGdX+kqjZKcnSSBa21H1fVPybZaCrvAX3m9NNwnZXkoKraIkmq6j5JfpguSUmSfZOsf1cvrKr7J/lda+3jSd6ZLgK/sxOT7JfkBekKnCQ5M8mBVXW/lfscDZKEu4uzkmxUVS+f1HbP0d/Tkry8qtZPkqp6WFXdK8nXkjx/NOZmyyRPTbLkLt77G0meXVUbVdXGuevTSisLmF+MtjnwLraBwZLUDFRr7bKqenuSr1bViiQXJXl1kpOq6jvpxsms7n+Bj0p3Xv+OJLcnefmdN2itLa2qy5M8orW2ZNT23ap6fZL/GiVBt6c7JXXtOv54MCeNEsv9kxw1OgV0Y7rv2auTfCbJg5JcOEo1b0yyf7r/IOyc5DtJWpIjW2s/q6od7vTe540GDV+c5OfpThPffKdtllXVvyW5NMnPkpw3XZ8V5iJTugF6oqo2bq39pqrumeTsJItaa6sbmAx3O5IagP5YPLoA5kbpxq8paGASSQ0AMAgGCgMAg6CoAQAGQVEDAAyCogYAGARFDQAwCIoaAGAQ/j+xHt00OUTIZQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "show_confusion_matrix(pred_labels, task='font')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2.2 Regularization\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training set 60000 items\n",
      "Testing set  10000 items\n",
      "Learning on font and reg_l2\n",
      "Train Epoch: 1 [0/60000 (0%)]\tLoss: 0.819279\n",
      "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 0.387368\n",
      "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 0.330577\n",
      "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 0.283093\n",
      "\n",
      "Test set: Average loss: 0.2116, Accuracy: 9152/10000 (91.52%)\n",
      "\n",
      "Train Epoch: 2 [0/60000 (0%)]\tLoss: 0.224554\n",
      "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 0.318623\n",
      "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 0.206573\n",
      "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 0.298528\n",
      "\n",
      "Test set: Average loss: 0.1565, Accuracy: 9441/10000 (94.41%)\n",
      "\n",
      "Train Epoch: 3 [0/60000 (0%)]\tLoss: 0.184100\n",
      "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 0.204253\n",
      "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 0.231604\n",
      "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 0.135547\n",
      "\n",
      "Test set: Average loss: 0.1315, Accuracy: 9558/10000 (95.58%)\n",
      "\n",
      "Train Epoch: 4 [0/60000 (0%)]\tLoss: 0.195498\n",
      "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 0.139618\n",
      "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 0.137817\n",
      "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 0.154951\n",
      "\n",
      "Test set: Average loss: 0.1351, Accuracy: 9489/10000 (94.89%)\n",
      "\n",
      "Train Epoch: 5 [0/60000 (0%)]\tLoss: 0.263507\n",
      "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 0.176998\n",
      "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 0.178833\n",
      "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 0.275605\n",
      "\n",
      "Test set: Average loss: 0.1108, Accuracy: 9624/10000 (96.24%)\n",
      "\n",
      "Train Epoch: 6 [0/60000 (0%)]\tLoss: 0.196487\n",
      "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 0.250093\n",
      "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 0.149119\n",
      "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 0.130062\n",
      "\n",
      "Test set: Average loss: 0.1060, Accuracy: 9649/10000 (96.49%)\n",
      "\n",
      "Train Epoch: 7 [0/60000 (0%)]\tLoss: 0.215787\n",
      "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 0.190706\n",
      "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 0.174876\n",
      "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 0.182876\n",
      "\n",
      "Test set: Average loss: 0.1101, Accuracy: 9607/10000 (96.07%)\n",
      "\n",
      "Train Epoch: 8 [0/60000 (0%)]\tLoss: 0.187326\n",
      "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 0.097482\n",
      "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 0.145363\n",
      "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 0.188729\n",
      "\n",
      "Test set: Average loss: 0.0934, Accuracy: 9682/10000 (96.82%)\n",
      "\n",
      "Train Epoch: 9 [0/60000 (0%)]\tLoss: 0.153429\n",
      "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 0.147883\n",
      "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 0.227087\n",
      "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 0.252390\n",
      "\n",
      "Test set: Average loss: 0.0936, Accuracy: 9680/10000 (96.80%)\n",
      "\n",
      "Train Epoch: 10 [0/60000 (0%)]\tLoss: 0.082068\n",
      "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 0.107096\n",
      "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 0.125117\n",
      "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 0.132756\n",
      "\n",
      "Test set: Average loss: 0.0869, Accuracy: 9704/10000 (97.04%)\n",
      "\n",
      "Train Epoch: 11 [0/60000 (0%)]\tLoss: 0.098076\n",
      "Train Epoch: 11 [19200/60000 (32%)]\tLoss: 0.164381\n",
      "Train Epoch: 11 [38400/60000 (64%)]\tLoss: 0.114987\n",
      "Train Epoch: 11 [57600/60000 (96%)]\tLoss: 0.127673\n",
      "\n",
      "Test set: Average loss: 0.0848, Accuracy: 9727/10000 (97.27%)\n",
      "\n",
      "Train Epoch: 12 [0/60000 (0%)]\tLoss: 0.138527\n",
      "Train Epoch: 12 [19200/60000 (32%)]\tLoss: 0.211810\n",
      "Train Epoch: 12 [38400/60000 (64%)]\tLoss: 0.081119\n",
      "Train Epoch: 12 [57600/60000 (96%)]\tLoss: 0.121188\n",
      "\n",
      "Test set: Average loss: 0.0814, Accuracy: 9719/10000 (97.19%)\n",
      "\n",
      "Train Epoch: 13 [0/60000 (0%)]\tLoss: 0.106034\n",
      "Train Epoch: 13 [19200/60000 (32%)]\tLoss: 0.154639\n",
      "Train Epoch: 13 [38400/60000 (64%)]\tLoss: 0.170575\n",
      "Train Epoch: 13 [57600/60000 (96%)]\tLoss: 0.126534\n",
      "\n",
      "Test set: Average loss: 0.0854, Accuracy: 9717/10000 (97.17%)\n",
      "\n",
      "Train Epoch: 14 [0/60000 (0%)]\tLoss: 0.108629\n",
      "Train Epoch: 14 [19200/60000 (32%)]\tLoss: 0.139346\n",
      "Train Epoch: 14 [38400/60000 (64%)]\tLoss: 0.080029\n",
      "Train Epoch: 14 [57600/60000 (96%)]\tLoss: 0.173205\n",
      "\n",
      "Test set: Average loss: 0.0800, Accuracy: 9724/10000 (97.24%)\n",
      "\n",
      "Train Epoch: 15 [0/60000 (0%)]\tLoss: 0.108745\n",
      "Train Epoch: 15 [19200/60000 (32%)]\tLoss: 0.110021\n",
      "Train Epoch: 15 [38400/60000 (64%)]\tLoss: 0.129024\n",
      "Train Epoch: 15 [57600/60000 (96%)]\tLoss: 0.074812\n",
      "\n",
      "Test set: Average loss: 0.0769, Accuracy: 9739/10000 (97.39%)\n",
      "\n",
      "Train Epoch: 16 [0/60000 (0%)]\tLoss: 0.118266\n",
      "Train Epoch: 16 [19200/60000 (32%)]\tLoss: 0.111897\n",
      "Train Epoch: 16 [38400/60000 (64%)]\tLoss: 0.150063\n",
      "Train Epoch: 16 [57600/60000 (96%)]\tLoss: 0.083080\n",
      "\n",
      "Test set: Average loss: 0.0766, Accuracy: 9746/10000 (97.46%)\n",
      "\n",
      "Train Epoch: 17 [0/60000 (0%)]\tLoss: 0.094530\n",
      "Train Epoch: 17 [19200/60000 (32%)]\tLoss: 0.095568\n",
      "Train Epoch: 17 [38400/60000 (64%)]\tLoss: 0.087219\n",
      "Train Epoch: 17 [57600/60000 (96%)]\tLoss: 0.166858\n",
      "\n",
      "Test set: Average loss: 0.0777, Accuracy: 9735/10000 (97.35%)\n",
      "\n",
      "Train Epoch: 18 [0/60000 (0%)]\tLoss: 0.108668\n",
      "Train Epoch: 18 [19200/60000 (32%)]\tLoss: 0.097677\n",
      "Train Epoch: 18 [38400/60000 (64%)]\tLoss: 0.079721\n",
      "Train Epoch: 18 [57600/60000 (96%)]\tLoss: 0.225298\n",
      "\n",
      "Test set: Average loss: 0.0735, Accuracy: 9757/10000 (97.57%)\n",
      "\n",
      "Train Epoch: 19 [0/60000 (0%)]\tLoss: 0.142267\n",
      "Train Epoch: 19 [19200/60000 (32%)]\tLoss: 0.094604\n",
      "Train Epoch: 19 [38400/60000 (64%)]\tLoss: 0.187068\n",
      "Train Epoch: 19 [57600/60000 (96%)]\tLoss: 0.201876\n",
      "\n",
      "Test set: Average loss: 0.0740, Accuracy: 9744/10000 (97.44%)\n",
      "\n",
      "Train Epoch: 20 [0/60000 (0%)]\tLoss: 0.158455\n",
      "Train Epoch: 20 [19200/60000 (32%)]\tLoss: 0.098739\n",
      "Train Epoch: 20 [38400/60000 (64%)]\tLoss: 0.159993\n",
      "Train Epoch: 20 [57600/60000 (96%)]\tLoss: 0.116921\n",
      "\n",
      "Test set: Average loss: 0.0731, Accuracy: 9742/10000 (97.42%)\n",
      "\n",
      "Train Epoch: 21 [0/60000 (0%)]\tLoss: 0.113592\n",
      "Train Epoch: 21 [19200/60000 (32%)]\tLoss: 0.129002\n",
      "Train Epoch: 21 [38400/60000 (64%)]\tLoss: 0.074425\n",
      "Train Epoch: 21 [57600/60000 (96%)]\tLoss: 0.099133\n",
      "\n",
      "Test set: Average loss: 0.0699, Accuracy: 9778/10000 (97.78%)\n",
      "\n",
      "Train Epoch: 22 [0/60000 (0%)]\tLoss: 0.087104\n",
      "Train Epoch: 22 [19200/60000 (32%)]\tLoss: 0.100305\n",
      "Train Epoch: 22 [38400/60000 (64%)]\tLoss: 0.121001\n",
      "Train Epoch: 22 [57600/60000 (96%)]\tLoss: 0.096235\n",
      "\n",
      "Test set: Average loss: 0.0709, Accuracy: 9759/10000 (97.59%)\n",
      "\n",
      "Train Epoch: 23 [0/60000 (0%)]\tLoss: 0.122294\n",
      "Train Epoch: 23 [19200/60000 (32%)]\tLoss: 0.116296\n",
      "Train Epoch: 23 [38400/60000 (64%)]\tLoss: 0.081043\n",
      "Train Epoch: 23 [57600/60000 (96%)]\tLoss: 0.163508\n",
      "\n",
      "Test set: Average loss: 0.0693, Accuracy: 9775/10000 (97.75%)\n",
      "\n",
      "Train Epoch: 24 [0/60000 (0%)]\tLoss: 0.182884\n",
      "Train Epoch: 24 [19200/60000 (32%)]\tLoss: 0.087898\n",
      "Train Epoch: 24 [38400/60000 (64%)]\tLoss: 0.110132\n",
      "Train Epoch: 24 [57600/60000 (96%)]\tLoss: 0.236755\n",
      "\n",
      "Test set: Average loss: 0.0696, Accuracy: 9761/10000 (97.61%)\n",
      "\n",
      "Train Epoch: 25 [0/60000 (0%)]\tLoss: 0.083249\n",
      "Train Epoch: 25 [19200/60000 (32%)]\tLoss: 0.077991\n",
      "Train Epoch: 25 [38400/60000 (64%)]\tLoss: 0.091204\n",
      "Train Epoch: 25 [57600/60000 (96%)]\tLoss: 0.073027\n",
      "\n",
      "Test set: Average loss: 0.0731, Accuracy: 9745/10000 (97.45%)\n",
      "\n",
      "Train Epoch: 26 [0/60000 (0%)]\tLoss: 0.075854\n",
      "Train Epoch: 26 [19200/60000 (32%)]\tLoss: 0.074461\n",
      "Train Epoch: 26 [38400/60000 (64%)]\tLoss: 0.072043\n",
      "Train Epoch: 26 [57600/60000 (96%)]\tLoss: 0.090496\n",
      "\n",
      "Test set: Average loss: 0.0668, Accuracy: 9792/10000 (97.92%)\n",
      "\n",
      "Train Epoch: 27 [0/60000 (0%)]\tLoss: 0.077344\n",
      "Train Epoch: 27 [19200/60000 (32%)]\tLoss: 0.094125\n",
      "Train Epoch: 27 [38400/60000 (64%)]\tLoss: 0.137913\n",
      "Train Epoch: 27 [57600/60000 (96%)]\tLoss: 0.093626\n",
      "\n",
      "Test set: Average loss: 0.0744, Accuracy: 9746/10000 (97.46%)\n",
      "\n",
      "Train Epoch: 28 [0/60000 (0%)]\tLoss: 0.138527\n",
      "Train Epoch: 28 [19200/60000 (32%)]\tLoss: 0.078554\n",
      "Train Epoch: 28 [38400/60000 (64%)]\tLoss: 0.120392\n",
      "Train Epoch: 28 [57600/60000 (96%)]\tLoss: 0.070376\n",
      "\n",
      "Test set: Average loss: 0.0679, Accuracy: 9768/10000 (97.68%)\n",
      "\n",
      "Train Epoch: 29 [0/60000 (0%)]\tLoss: 0.110052\n",
      "Train Epoch: 29 [19200/60000 (32%)]\tLoss: 0.071607\n",
      "Train Epoch: 29 [38400/60000 (64%)]\tLoss: 0.252090\n",
      "Train Epoch: 29 [57600/60000 (96%)]\tLoss: 0.085730\n",
      "\n",
      "Test set: Average loss: 0.0700, Accuracy: 9756/10000 (97.56%)\n",
      "\n",
      "Train Epoch: 30 [0/60000 (0%)]\tLoss: 0.075092\n",
      "Train Epoch: 30 [19200/60000 (32%)]\tLoss: 0.094742\n",
      "Train Epoch: 30 [38400/60000 (64%)]\tLoss: 0.061779\n",
      "Train Epoch: 30 [57600/60000 (96%)]\tLoss: 0.098998\n",
      "\n",
      "Test set: Average loss: 0.0656, Accuracy: 9779/10000 (97.79%)\n",
      "\n",
      "Train Epoch: 31 [0/60000 (0%)]\tLoss: 0.176472\n",
      "Train Epoch: 31 [19200/60000 (32%)]\tLoss: 0.154297\n",
      "Train Epoch: 31 [38400/60000 (64%)]\tLoss: 0.084463\n",
      "Train Epoch: 31 [57600/60000 (96%)]\tLoss: 0.097560\n",
      "\n",
      "Test set: Average loss: 0.0645, Accuracy: 9769/10000 (97.69%)\n",
      "\n",
      "Train Epoch: 32 [0/60000 (0%)]\tLoss: 0.097240\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Epoch: 32 [19200/60000 (32%)]\tLoss: 0.091405\n",
      "Train Epoch: 32 [38400/60000 (64%)]\tLoss: 0.087959\n",
      "Train Epoch: 32 [57600/60000 (96%)]\tLoss: 0.101077\n",
      "\n",
      "Test set: Average loss: 0.0646, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 33 [0/60000 (0%)]\tLoss: 0.074424\n",
      "Train Epoch: 33 [19200/60000 (32%)]\tLoss: 0.185871\n",
      "Train Epoch: 33 [38400/60000 (64%)]\tLoss: 0.075974\n",
      "Train Epoch: 33 [57600/60000 (96%)]\tLoss: 0.073974\n",
      "\n",
      "Test set: Average loss: 0.0679, Accuracy: 9790/10000 (97.90%)\n",
      "\n",
      "Train Epoch: 34 [0/60000 (0%)]\tLoss: 0.103279\n",
      "Train Epoch: 34 [19200/60000 (32%)]\tLoss: 0.067313\n",
      "Train Epoch: 34 [38400/60000 (64%)]\tLoss: 0.074826\n",
      "Train Epoch: 34 [57600/60000 (96%)]\tLoss: 0.107736\n",
      "\n",
      "Test set: Average loss: 0.0665, Accuracy: 9783/10000 (97.83%)\n",
      "\n",
      "Train Epoch: 35 [0/60000 (0%)]\tLoss: 0.092432\n",
      "Train Epoch: 35 [19200/60000 (32%)]\tLoss: 0.070287\n",
      "Train Epoch: 35 [38400/60000 (64%)]\tLoss: 0.196111\n",
      "Train Epoch: 35 [57600/60000 (96%)]\tLoss: 0.078212\n",
      "\n",
      "Test set: Average loss: 0.0635, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 36 [0/60000 (0%)]\tLoss: 0.065769\n",
      "Train Epoch: 36 [19200/60000 (32%)]\tLoss: 0.068594\n",
      "Train Epoch: 36 [38400/60000 (64%)]\tLoss: 0.115066\n",
      "Train Epoch: 36 [57600/60000 (96%)]\tLoss: 0.112469\n",
      "\n",
      "Test set: Average loss: 0.0681, Accuracy: 9767/10000 (97.67%)\n",
      "\n",
      "Train Epoch: 37 [0/60000 (0%)]\tLoss: 0.092969\n",
      "Train Epoch: 37 [19200/60000 (32%)]\tLoss: 0.072051\n",
      "Train Epoch: 37 [38400/60000 (64%)]\tLoss: 0.098066\n",
      "Train Epoch: 37 [57600/60000 (96%)]\tLoss: 0.093632\n",
      "\n",
      "Test set: Average loss: 0.0650, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 38 [0/60000 (0%)]\tLoss: 0.101262\n",
      "Train Epoch: 38 [19200/60000 (32%)]\tLoss: 0.143705\n",
      "Train Epoch: 38 [38400/60000 (64%)]\tLoss: 0.076799\n",
      "Train Epoch: 38 [57600/60000 (96%)]\tLoss: 0.058149\n",
      "\n",
      "Test set: Average loss: 0.0648, Accuracy: 9766/10000 (97.66%)\n",
      "\n",
      "Train Epoch: 39 [0/60000 (0%)]\tLoss: 0.066617\n",
      "Train Epoch: 39 [19200/60000 (32%)]\tLoss: 0.065473\n",
      "Train Epoch: 39 [38400/60000 (64%)]\tLoss: 0.076942\n",
      "Train Epoch: 39 [57600/60000 (96%)]\tLoss: 0.068758\n",
      "\n",
      "Test set: Average loss: 0.0630, Accuracy: 9807/10000 (98.07%)\n",
      "\n",
      "Train Epoch: 40 [0/60000 (0%)]\tLoss: 0.096978\n",
      "Train Epoch: 40 [19200/60000 (32%)]\tLoss: 0.074211\n",
      "Train Epoch: 40 [38400/60000 (64%)]\tLoss: 0.104632\n",
      "Train Epoch: 40 [57600/60000 (96%)]\tLoss: 0.059502\n",
      "\n",
      "Test set: Average loss: 0.0682, Accuracy: 9767/10000 (97.67%)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "results['QuadNet'], pred_labels = main(\n",
    "    model=QuadNet(N_OUTPUT), \n",
    "    args=Parser(),\n",
    "    task='font',\n",
    "    return_pred_label=True,\n",
    "    reg_l2=True,\n",
    "    reg=0.005,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Regularisation helps a little bit to improve accuracy, however the reason will keep it (it enabled by defult in the main function) is because it makes the weights a bit smaller, which is crucial for Functional Encryption.\n",
    "\n",
    "If you wonder why here is a 1-line explication: each number of the output comes as g ** x (where g is a field element) and must be decrypted to find x, the real output of the network. The weights will be converted to integers, and the higher x is the more complicated it is to do the computation g ** x -> x, called the _discrete log_."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2.3 Extend the network\n",
    "\n",
    "We now replace the argmax operation (and the log_softmax) with extra layers to get a deeper network. This has no consequences on the security of the first layers which remain the only one to contain encrypted data."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2.3.1 Quadratic + Linear 1\n",
    "Here we try to add linear wider model on top of the input, which consists or 2 linear units and 2 relu activations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "class QuadLinear1Net(nn.Module):\n",
    "    def __init__(self, output_size):\n",
    "        super(QuadLinear1Net, self).__init__()\n",
    "        self.proj1 = nn.Linear(784, 50)\n",
    "        self.diag1 = nn.Linear(50, output_size)\n",
    "        \n",
    "        # --- Linear\n",
    "        self.lin1 = nn.Linear(output_size, 4*output_size)\n",
    "        self.lin2 = nn.Linear(4*output_size, output_size)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, 784)\n",
    "        x = self.proj1(x)\n",
    "        x = x * x\n",
    "        x = self.diag1(x)\n",
    "        \n",
    "        # --- Linear\n",
    "        x = F.relu(x)\n",
    "        x = F.relu(self.lin1(x))\n",
    "        x = self.lin2(x)\n",
    "        \n",
    "        return F.log_softmax(x, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training set 60000 items\n",
      "Testing set  10000 items\n",
      "Learning on font \n",
      "Train Epoch: 1 [0/60000 (0%)]\tLoss: 0.720666\n",
      "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 0.665429\n",
      "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 0.531597\n",
      "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 0.458515\n",
      "\n",
      "Test set: Average loss: 0.4442, Accuracy: 8332/10000 (83.32%)\n",
      "\n",
      "Train Epoch: 2 [0/60000 (0%)]\tLoss: 0.445453\n",
      "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 0.291766\n",
      "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 0.200965\n",
      "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 0.246472\n",
      "\n",
      "Test set: Average loss: 0.2059, Accuracy: 9175/10000 (91.75%)\n",
      "\n",
      "Train Epoch: 3 [0/60000 (0%)]\tLoss: 0.185060\n",
      "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 0.179830\n",
      "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 0.175115\n",
      "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 0.097388\n",
      "\n",
      "Test set: Average loss: 0.1483, Accuracy: 9463/10000 (94.63%)\n",
      "\n",
      "Train Epoch: 4 [0/60000 (0%)]\tLoss: 0.146960\n",
      "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 0.082636\n",
      "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 0.075604\n",
      "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 0.129123\n",
      "\n",
      "Test set: Average loss: 0.1358, Accuracy: 9491/10000 (94.91%)\n",
      "\n",
      "Train Epoch: 5 [0/60000 (0%)]\tLoss: 0.178569\n",
      "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 0.115377\n",
      "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 0.150505\n",
      "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 0.216204\n",
      "\n",
      "Test set: Average loss: 0.1132, Accuracy: 9610/10000 (96.10%)\n",
      "\n",
      "Train Epoch: 6 [0/60000 (0%)]\tLoss: 0.105440\n",
      "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 0.145717\n",
      "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 0.087189\n",
      "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 0.091156\n",
      "\n",
      "Test set: Average loss: 0.1068, Accuracy: 9646/10000 (96.46%)\n",
      "\n",
      "Train Epoch: 7 [0/60000 (0%)]\tLoss: 0.152911\n",
      "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 0.185833\n",
      "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 0.088788\n",
      "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 0.111096\n",
      "\n",
      "Test set: Average loss: 0.1168, Accuracy: 9570/10000 (95.70%)\n",
      "\n",
      "Train Epoch: 8 [0/60000 (0%)]\tLoss: 0.153582\n",
      "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 0.037625\n",
      "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 0.084631\n",
      "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 0.148499\n",
      "\n",
      "Test set: Average loss: 0.0911, Accuracy: 9688/10000 (96.88%)\n",
      "\n",
      "Train Epoch: 9 [0/60000 (0%)]\tLoss: 0.105290\n",
      "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 0.078426\n",
      "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 0.183221\n",
      "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 0.191376\n",
      "\n",
      "Test set: Average loss: 0.0928, Accuracy: 9673/10000 (96.73%)\n",
      "\n",
      "Train Epoch: 10 [0/60000 (0%)]\tLoss: 0.017090\n",
      "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 0.034308\n",
      "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 0.062728\n",
      "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 0.090113\n",
      "\n",
      "Test set: Average loss: 0.0829, Accuracy: 9730/10000 (97.30%)\n",
      "\n",
      "Train Epoch: 11 [0/60000 (0%)]\tLoss: 0.018962\n",
      "Train Epoch: 11 [19200/60000 (32%)]\tLoss: 0.079373\n",
      "Train Epoch: 11 [38400/60000 (64%)]\tLoss: 0.032388\n",
      "Train Epoch: 11 [57600/60000 (96%)]\tLoss: 0.063597\n",
      "\n",
      "Test set: Average loss: 0.0819, Accuracy: 9722/10000 (97.22%)\n",
      "\n",
      "Train Epoch: 12 [0/60000 (0%)]\tLoss: 0.057271\n",
      "Train Epoch: 12 [19200/60000 (32%)]\tLoss: 0.121813\n",
      "Train Epoch: 12 [38400/60000 (64%)]\tLoss: 0.013153\n",
      "Train Epoch: 12 [57600/60000 (96%)]\tLoss: 0.078445\n",
      "\n",
      "Test set: Average loss: 0.0765, Accuracy: 9735/10000 (97.35%)\n",
      "\n",
      "Train Epoch: 13 [0/60000 (0%)]\tLoss: 0.037466\n",
      "Train Epoch: 13 [19200/60000 (32%)]\tLoss: 0.050022\n",
      "Train Epoch: 13 [38400/60000 (64%)]\tLoss: 0.114009\n",
      "Train Epoch: 13 [57600/60000 (96%)]\tLoss: 0.052152\n",
      "\n",
      "Test set: Average loss: 0.0815, Accuracy: 9716/10000 (97.16%)\n",
      "\n",
      "Train Epoch: 14 [0/60000 (0%)]\tLoss: 0.041174\n",
      "Train Epoch: 14 [19200/60000 (32%)]\tLoss: 0.094561\n",
      "Train Epoch: 14 [38400/60000 (64%)]\tLoss: 0.015639\n",
      "Train Epoch: 14 [57600/60000 (96%)]\tLoss: 0.065975\n",
      "\n",
      "Test set: Average loss: 0.0770, Accuracy: 9734/10000 (97.34%)\n",
      "\n",
      "Train Epoch: 15 [0/60000 (0%)]\tLoss: 0.028062\n",
      "Train Epoch: 15 [19200/60000 (32%)]\tLoss: 0.038057\n",
      "Train Epoch: 15 [38400/60000 (64%)]\tLoss: 0.076908\n",
      "Train Epoch: 15 [57600/60000 (96%)]\tLoss: 0.012156\n",
      "\n",
      "Test set: Average loss: 0.0727, Accuracy: 9756/10000 (97.56%)\n",
      "\n",
      "Train Epoch: 16 [0/60000 (0%)]\tLoss: 0.049789\n",
      "Train Epoch: 16 [19200/60000 (32%)]\tLoss: 0.056828\n",
      "Train Epoch: 16 [38400/60000 (64%)]\tLoss: 0.135080\n",
      "Train Epoch: 16 [57600/60000 (96%)]\tLoss: 0.011578\n",
      "\n",
      "Test set: Average loss: 0.0772, Accuracy: 9740/10000 (97.40%)\n",
      "\n",
      "Train Epoch: 17 [0/60000 (0%)]\tLoss: 0.034141\n",
      "Train Epoch: 17 [19200/60000 (32%)]\tLoss: 0.027932\n",
      "Train Epoch: 17 [38400/60000 (64%)]\tLoss: 0.010374\n",
      "Train Epoch: 17 [57600/60000 (96%)]\tLoss: 0.096054\n",
      "\n",
      "Test set: Average loss: 0.0840, Accuracy: 9708/10000 (97.08%)\n",
      "\n",
      "Train Epoch: 18 [0/60000 (0%)]\tLoss: 0.038405\n",
      "Train Epoch: 18 [19200/60000 (32%)]\tLoss: 0.015517\n",
      "Train Epoch: 18 [38400/60000 (64%)]\tLoss: 0.015918\n",
      "Train Epoch: 18 [57600/60000 (96%)]\tLoss: 0.117406\n",
      "\n",
      "Test set: Average loss: 0.0709, Accuracy: 9770/10000 (97.70%)\n",
      "\n",
      "Train Epoch: 19 [0/60000 (0%)]\tLoss: 0.042643\n",
      "Train Epoch: 19 [19200/60000 (32%)]\tLoss: 0.042819\n",
      "Train Epoch: 19 [38400/60000 (64%)]\tLoss: 0.121447\n",
      "Train Epoch: 19 [57600/60000 (96%)]\tLoss: 0.068192\n",
      "\n",
      "Test set: Average loss: 0.0703, Accuracy: 9763/10000 (97.63%)\n",
      "\n",
      "Train Epoch: 20 [0/60000 (0%)]\tLoss: 0.047966\n",
      "Train Epoch: 20 [19200/60000 (32%)]\tLoss: 0.011998\n",
      "Train Epoch: 20 [38400/60000 (64%)]\tLoss: 0.050097\n",
      "Train Epoch: 20 [57600/60000 (96%)]\tLoss: 0.038760\n",
      "\n",
      "Test set: Average loss: 0.0658, Accuracy: 9780/10000 (97.80%)\n",
      "\n",
      "Train Epoch: 21 [0/60000 (0%)]\tLoss: 0.013183\n",
      "Train Epoch: 21 [19200/60000 (32%)]\tLoss: 0.093876\n",
      "Train Epoch: 21 [38400/60000 (64%)]\tLoss: 0.016799\n",
      "Train Epoch: 21 [57600/60000 (96%)]\tLoss: 0.019381\n",
      "\n",
      "Test set: Average loss: 0.0706, Accuracy: 9783/10000 (97.83%)\n",
      "\n",
      "Train Epoch: 22 [0/60000 (0%)]\tLoss: 0.012243\n",
      "Train Epoch: 22 [19200/60000 (32%)]\tLoss: 0.029335\n",
      "Train Epoch: 22 [38400/60000 (64%)]\tLoss: 0.098604\n",
      "Train Epoch: 22 [57600/60000 (96%)]\tLoss: 0.010194\n",
      "\n",
      "Test set: Average loss: 0.0686, Accuracy: 9783/10000 (97.83%)\n",
      "\n",
      "Train Epoch: 23 [0/60000 (0%)]\tLoss: 0.123476\n",
      "Train Epoch: 23 [19200/60000 (32%)]\tLoss: 0.068531\n",
      "Train Epoch: 23 [38400/60000 (64%)]\tLoss: 0.019497\n",
      "Train Epoch: 23 [57600/60000 (96%)]\tLoss: 0.095021\n",
      "\n",
      "Test set: Average loss: 0.0668, Accuracy: 9790/10000 (97.90%)\n",
      "\n",
      "Train Epoch: 24 [0/60000 (0%)]\tLoss: 0.086781\n",
      "Train Epoch: 24 [19200/60000 (32%)]\tLoss: 0.024506\n",
      "Train Epoch: 24 [38400/60000 (64%)]\tLoss: 0.053685\n",
      "Train Epoch: 24 [57600/60000 (96%)]\tLoss: 0.165970\n",
      "\n",
      "Test set: Average loss: 0.0649, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 25 [0/60000 (0%)]\tLoss: 0.007362\n",
      "Train Epoch: 25 [19200/60000 (32%)]\tLoss: 0.005598\n",
      "Train Epoch: 25 [38400/60000 (64%)]\tLoss: 0.030339\n",
      "Train Epoch: 25 [57600/60000 (96%)]\tLoss: 0.005928\n",
      "\n",
      "Test set: Average loss: 0.0721, Accuracy: 9790/10000 (97.90%)\n",
      "\n",
      "Train Epoch: 26 [0/60000 (0%)]\tLoss: 0.008292\n",
      "Train Epoch: 26 [19200/60000 (32%)]\tLoss: 0.010059\n",
      "Train Epoch: 26 [38400/60000 (64%)]\tLoss: 0.054614\n",
      "Train Epoch: 26 [57600/60000 (96%)]\tLoss: 0.043814\n",
      "\n",
      "Test set: Average loss: 0.0664, Accuracy: 9793/10000 (97.93%)\n",
      "\n",
      "Train Epoch: 27 [0/60000 (0%)]\tLoss: 0.028536\n",
      "Train Epoch: 27 [19200/60000 (32%)]\tLoss: 0.014617\n",
      "Train Epoch: 27 [38400/60000 (64%)]\tLoss: 0.062905\n",
      "Train Epoch: 27 [57600/60000 (96%)]\tLoss: 0.029407\n",
      "\n",
      "Test set: Average loss: 0.0695, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 28 [0/60000 (0%)]\tLoss: 0.060205\n",
      "Train Epoch: 28 [19200/60000 (32%)]\tLoss: 0.036272\n",
      "Train Epoch: 28 [38400/60000 (64%)]\tLoss: 0.048474\n",
      "Train Epoch: 28 [57600/60000 (96%)]\tLoss: 0.044424\n",
      "\n",
      "Test set: Average loss: 0.0659, Accuracy: 9800/10000 (98.00%)\n",
      "\n",
      "Train Epoch: 29 [0/60000 (0%)]\tLoss: 0.032892\n",
      "Train Epoch: 29 [19200/60000 (32%)]\tLoss: 0.008865\n",
      "Train Epoch: 29 [38400/60000 (64%)]\tLoss: 0.157051\n",
      "Train Epoch: 29 [57600/60000 (96%)]\tLoss: 0.021727\n",
      "\n",
      "Test set: Average loss: 0.0657, Accuracy: 9797/10000 (97.97%)\n",
      "\n",
      "Train Epoch: 30 [0/60000 (0%)]\tLoss: 0.025843\n",
      "Train Epoch: 30 [19200/60000 (32%)]\tLoss: 0.019845\n",
      "Train Epoch: 30 [38400/60000 (64%)]\tLoss: 0.005781\n",
      "Train Epoch: 30 [57600/60000 (96%)]\tLoss: 0.033408\n",
      "\n",
      "Test set: Average loss: 0.0728, Accuracy: 9784/10000 (97.84%)\n",
      "\n",
      "Train Epoch: 31 [0/60000 (0%)]\tLoss: 0.110675\n",
      "Train Epoch: 31 [19200/60000 (32%)]\tLoss: 0.051084\n",
      "Train Epoch: 31 [38400/60000 (64%)]\tLoss: 0.022763\n",
      "Train Epoch: 31 [57600/60000 (96%)]\tLoss: 0.019395\n",
      "\n",
      "Test set: Average loss: 0.0661, Accuracy: 9803/10000 (98.03%)\n",
      "\n",
      "Train Epoch: 32 [0/60000 (0%)]\tLoss: 0.014623\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Epoch: 32 [19200/60000 (32%)]\tLoss: 0.010360\n",
      "Train Epoch: 32 [38400/60000 (64%)]\tLoss: 0.012992\n",
      "Train Epoch: 32 [57600/60000 (96%)]\tLoss: 0.045682\n",
      "\n",
      "Test set: Average loss: 0.0696, Accuracy: 9799/10000 (97.99%)\n",
      "\n",
      "Train Epoch: 33 [0/60000 (0%)]\tLoss: 0.007786\n",
      "Train Epoch: 33 [19200/60000 (32%)]\tLoss: 0.053814\n",
      "Train Epoch: 33 [38400/60000 (64%)]\tLoss: 0.005484\n",
      "Train Epoch: 33 [57600/60000 (96%)]\tLoss: 0.012028\n",
      "\n",
      "Test set: Average loss: 0.0741, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 34 [0/60000 (0%)]\tLoss: 0.030342\n",
      "Train Epoch: 34 [19200/60000 (32%)]\tLoss: 0.011802\n",
      "Train Epoch: 34 [38400/60000 (64%)]\tLoss: 0.004890\n",
      "Train Epoch: 34 [57600/60000 (96%)]\tLoss: 0.011228\n",
      "\n",
      "Test set: Average loss: 0.0732, Accuracy: 9788/10000 (97.88%)\n",
      "\n",
      "Train Epoch: 35 [0/60000 (0%)]\tLoss: 0.007350\n",
      "Train Epoch: 35 [19200/60000 (32%)]\tLoss: 0.019515\n",
      "Train Epoch: 35 [38400/60000 (64%)]\tLoss: 0.151375\n",
      "Train Epoch: 35 [57600/60000 (96%)]\tLoss: 0.002406\n",
      "\n",
      "Test set: Average loss: 0.0673, Accuracy: 9814/10000 (98.14%)\n",
      "\n",
      "Train Epoch: 36 [0/60000 (0%)]\tLoss: 0.008228\n",
      "Train Epoch: 36 [19200/60000 (32%)]\tLoss: 0.004839\n",
      "Train Epoch: 36 [38400/60000 (64%)]\tLoss: 0.026797\n",
      "Train Epoch: 36 [57600/60000 (96%)]\tLoss: 0.043077\n",
      "\n",
      "Test set: Average loss: 0.0696, Accuracy: 9804/10000 (98.04%)\n",
      "\n",
      "Train Epoch: 37 [0/60000 (0%)]\tLoss: 0.018282\n",
      "Train Epoch: 37 [19200/60000 (32%)]\tLoss: 0.030450\n",
      "Train Epoch: 37 [38400/60000 (64%)]\tLoss: 0.020102\n",
      "Train Epoch: 37 [57600/60000 (96%)]\tLoss: 0.026131\n",
      "\n",
      "Test set: Average loss: 0.0736, Accuracy: 9800/10000 (98.00%)\n",
      "\n",
      "Train Epoch: 38 [0/60000 (0%)]\tLoss: 0.022854\n",
      "Train Epoch: 38 [19200/60000 (32%)]\tLoss: 0.005076\n",
      "Train Epoch: 38 [38400/60000 (64%)]\tLoss: 0.002550\n",
      "Train Epoch: 38 [57600/60000 (96%)]\tLoss: 0.005713\n",
      "\n",
      "Test set: Average loss: 0.0716, Accuracy: 9800/10000 (98.00%)\n",
      "\n",
      "Train Epoch: 39 [0/60000 (0%)]\tLoss: 0.003929\n",
      "Train Epoch: 39 [19200/60000 (32%)]\tLoss: 0.008696\n",
      "Train Epoch: 39 [38400/60000 (64%)]\tLoss: 0.006993\n",
      "Train Epoch: 39 [57600/60000 (96%)]\tLoss: 0.016447\n",
      "\n",
      "Test set: Average loss: 0.0697, Accuracy: 9815/10000 (98.15%)\n",
      "\n",
      "Train Epoch: 40 [0/60000 (0%)]\tLoss: 0.038452\n",
      "Train Epoch: 40 [19200/60000 (32%)]\tLoss: 0.005953\n",
      "Train Epoch: 40 [38400/60000 (64%)]\tLoss: 0.004596\n",
      "Train Epoch: 40 [57600/60000 (96%)]\tLoss: 0.000804\n",
      "\n",
      "Test set: Average loss: 0.0723, Accuracy: 9789/10000 (97.89%)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "results[f'QuadNet + Linear1'] = main(\n",
    "    model=QuadLinear1Net(N_OUTPUT), \n",
    "    args=Parser(),\n",
    "    task='font'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "show_results(results, 'Quadratic variant models with Linear outputs', ymin=92)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2.3.2 Quadratic + Linear2\n",
    "Let's try to a bigger Linear model which performs quite well on MNIST too"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "class QuadLinear2Net(nn.Module):\n",
    "    def __init__(self, output_size):\n",
    "        super(QuadLinear2Net, self).__init__()\n",
    "        self.proj1 = nn.Linear(784, 50)\n",
    "        self.diag1 = nn.Linear(50, output_size)\n",
    "        \n",
    "        # --- Junction\n",
    "        self.jct = nn.Linear(output_size, 784)\n",
    "        \n",
    "        # --- Linear 2\n",
    "        self.fc1 = nn.Linear(784, 548)\n",
    "        self.bc1 = nn.BatchNorm1d(548)\n",
    "        \n",
    "        self.fc2 = nn.Linear(548, 252)\n",
    "        self.bc2 = nn.BatchNorm1d(252)\n",
    "        \n",
    "        self.fc3 = nn.Linear(252, output_size)\n",
    "        \n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, 784)\n",
    "        x = self.proj1(x)\n",
    "        x = x * x\n",
    "        x = self.diag1(x)\n",
    "        \n",
    "        # --- Junction\n",
    "        x = self.jct(x)\n",
    "        x = x.view((-1, 784))\n",
    "        \n",
    "        # --- Linear\n",
    "        h = self.fc1(x)\n",
    "        h = self.bc1(h)\n",
    "        h = F.relu(h)\n",
    "        h = F.dropout(h, p=0.5, training=self.training)\n",
    "        \n",
    "        h = self.fc2(h)\n",
    "        h = self.bc2(h)\n",
    "        h = F.relu(h)\n",
    "        h = F.dropout(h, p=0.2, training=self.training)\n",
    "        \n",
    "        h = self.fc3(h)\n",
    "        \n",
    "        return F.log_softmax(x, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training set 60000 items\n",
      "Testing set  10000 items\n",
      "Learning on font \n",
      "Train Epoch: 1 [0/60000 (0%)]\tLoss: 7.243496\n",
      "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 3.338873\n",
      "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 0.240132\n",
      "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 0.201158\n",
      "\n",
      "Test set: Average loss: 0.2110, Accuracy: 9157/10000 (91.57%)\n",
      "\n",
      "Train Epoch: 2 [0/60000 (0%)]\tLoss: 0.177697\n",
      "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 0.107242\n",
      "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 0.249957\n",
      "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 0.098987\n",
      "\n",
      "Test set: Average loss: 0.1523, Accuracy: 9422/10000 (94.22%)\n",
      "\n",
      "Train Epoch: 3 [0/60000 (0%)]\tLoss: 0.331209\n",
      "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 0.175291\n",
      "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 0.165335\n",
      "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 0.058510\n",
      "\n",
      "Test set: Average loss: 0.1244, Accuracy: 9554/10000 (95.54%)\n",
      "\n",
      "Train Epoch: 4 [0/60000 (0%)]\tLoss: 0.054130\n",
      "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 0.062530\n",
      "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 0.097115\n",
      "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 0.036237\n",
      "\n",
      "Test set: Average loss: 0.1029, Accuracy: 9657/10000 (96.57%)\n",
      "\n",
      "Train Epoch: 5 [0/60000 (0%)]\tLoss: 0.071601\n",
      "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 0.079188\n",
      "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 0.110000\n",
      "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 0.125030\n",
      "\n",
      "Test set: Average loss: 0.1009, Accuracy: 9648/10000 (96.48%)\n",
      "\n",
      "Train Epoch: 6 [0/60000 (0%)]\tLoss: 0.021596\n",
      "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 0.045660\n",
      "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 0.068618\n",
      "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 0.093364\n",
      "\n",
      "Test set: Average loss: 0.0939, Accuracy: 9696/10000 (96.96%)\n",
      "\n",
      "Train Epoch: 7 [0/60000 (0%)]\tLoss: 0.078856\n",
      "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 0.073581\n",
      "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 0.074859\n",
      "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 0.101978\n",
      "\n",
      "Test set: Average loss: 0.0831, Accuracy: 9711/10000 (97.11%)\n",
      "\n",
      "Train Epoch: 8 [0/60000 (0%)]\tLoss: 0.029340\n",
      "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 0.042259\n",
      "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 0.042898\n",
      "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 0.163159\n",
      "\n",
      "Test set: Average loss: 0.0863, Accuracy: 9680/10000 (96.80%)\n",
      "\n",
      "Train Epoch: 9 [0/60000 (0%)]\tLoss: 0.068862\n",
      "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 0.103318\n",
      "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 0.088422\n",
      "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 0.030854\n",
      "\n",
      "Test set: Average loss: 0.0828, Accuracy: 9704/10000 (97.04%)\n",
      "\n",
      "Train Epoch: 10 [0/60000 (0%)]\tLoss: 0.066594\n",
      "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 0.049982\n",
      "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 0.053046\n",
      "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 0.025937\n",
      "\n",
      "Test set: Average loss: 0.0758, Accuracy: 9750/10000 (97.50%)\n",
      "\n",
      "Train Epoch: 11 [0/60000 (0%)]\tLoss: 0.038832\n",
      "Train Epoch: 11 [19200/60000 (32%)]\tLoss: 0.007461\n",
      "Train Epoch: 11 [38400/60000 (64%)]\tLoss: 0.026840\n",
      "Train Epoch: 11 [57600/60000 (96%)]\tLoss: 0.116051\n",
      "\n",
      "Test set: Average loss: 0.0836, Accuracy: 9712/10000 (97.12%)\n",
      "\n",
      "Train Epoch: 12 [0/60000 (0%)]\tLoss: 0.036771\n",
      "Train Epoch: 12 [19200/60000 (32%)]\tLoss: 0.024559\n",
      "Train Epoch: 12 [38400/60000 (64%)]\tLoss: 0.083522\n",
      "Train Epoch: 12 [57600/60000 (96%)]\tLoss: 0.070170\n",
      "\n",
      "Test set: Average loss: 0.0782, Accuracy: 9742/10000 (97.42%)\n",
      "\n",
      "Train Epoch: 13 [0/60000 (0%)]\tLoss: 0.071825\n",
      "Train Epoch: 13 [19200/60000 (32%)]\tLoss: 0.061333\n",
      "Train Epoch: 13 [38400/60000 (64%)]\tLoss: 0.093375\n",
      "Train Epoch: 13 [57600/60000 (96%)]\tLoss: 0.040662\n",
      "\n",
      "Test set: Average loss: 0.0707, Accuracy: 9762/10000 (97.62%)\n",
      "\n",
      "Train Epoch: 14 [0/60000 (0%)]\tLoss: 0.059360\n",
      "Train Epoch: 14 [19200/60000 (32%)]\tLoss: 0.050450\n",
      "Train Epoch: 14 [38400/60000 (64%)]\tLoss: 0.005350\n",
      "Train Epoch: 14 [57600/60000 (96%)]\tLoss: 0.084215\n",
      "\n",
      "Test set: Average loss: 0.0771, Accuracy: 9748/10000 (97.48%)\n",
      "\n",
      "Train Epoch: 15 [0/60000 (0%)]\tLoss: 0.023923\n",
      "Train Epoch: 15 [19200/60000 (32%)]\tLoss: 0.033836\n",
      "Train Epoch: 15 [38400/60000 (64%)]\tLoss: 0.041988\n",
      "Train Epoch: 15 [57600/60000 (96%)]\tLoss: 0.048814\n",
      "\n",
      "Test set: Average loss: 0.0709, Accuracy: 9775/10000 (97.75%)\n",
      "\n",
      "Train Epoch: 16 [0/60000 (0%)]\tLoss: 0.055277\n",
      "Train Epoch: 16 [19200/60000 (32%)]\tLoss: 0.043257\n",
      "Train Epoch: 16 [38400/60000 (64%)]\tLoss: 0.024347\n",
      "Train Epoch: 16 [57600/60000 (96%)]\tLoss: 0.048332\n",
      "\n",
      "Test set: Average loss: 0.0704, Accuracy: 9773/10000 (97.73%)\n",
      "\n",
      "Train Epoch: 17 [0/60000 (0%)]\tLoss: 0.023949\n",
      "Train Epoch: 17 [19200/60000 (32%)]\tLoss: 0.064599\n",
      "Train Epoch: 17 [38400/60000 (64%)]\tLoss: 0.048890\n",
      "Train Epoch: 17 [57600/60000 (96%)]\tLoss: 0.090778\n",
      "\n",
      "Test set: Average loss: 0.0697, Accuracy: 9787/10000 (97.87%)\n",
      "\n",
      "Train Epoch: 18 [0/60000 (0%)]\tLoss: 0.011134\n",
      "Train Epoch: 18 [19200/60000 (32%)]\tLoss: 0.034437\n",
      "Train Epoch: 18 [38400/60000 (64%)]\tLoss: 0.025265\n",
      "Train Epoch: 18 [57600/60000 (96%)]\tLoss: 0.053001\n",
      "\n",
      "Test set: Average loss: 0.0707, Accuracy: 9781/10000 (97.81%)\n",
      "\n",
      "Train Epoch: 19 [0/60000 (0%)]\tLoss: 0.059256\n",
      "Train Epoch: 19 [19200/60000 (32%)]\tLoss: 0.005568\n",
      "Train Epoch: 19 [38400/60000 (64%)]\tLoss: 0.180693\n",
      "Train Epoch: 19 [57600/60000 (96%)]\tLoss: 0.077631\n",
      "\n",
      "Test set: Average loss: 0.0652, Accuracy: 9809/10000 (98.09%)\n",
      "\n",
      "Train Epoch: 20 [0/60000 (0%)]\tLoss: 0.028383\n",
      "Train Epoch: 20 [19200/60000 (32%)]\tLoss: 0.018498\n",
      "Train Epoch: 20 [38400/60000 (64%)]\tLoss: 0.037426\n",
      "Train Epoch: 20 [57600/60000 (96%)]\tLoss: 0.068087\n",
      "\n",
      "Test set: Average loss: 0.0721, Accuracy: 9775/10000 (97.75%)\n",
      "\n",
      "Train Epoch: 21 [0/60000 (0%)]\tLoss: 0.115891\n",
      "Train Epoch: 21 [19200/60000 (32%)]\tLoss: 0.043281\n",
      "Train Epoch: 21 [38400/60000 (64%)]\tLoss: 0.045909\n",
      "Train Epoch: 21 [57600/60000 (96%)]\tLoss: 0.042748\n",
      "\n",
      "Test set: Average loss: 0.0723, Accuracy: 9785/10000 (97.85%)\n",
      "\n",
      "Train Epoch: 22 [0/60000 (0%)]\tLoss: 0.033715\n",
      "Train Epoch: 22 [19200/60000 (32%)]\tLoss: 0.020069\n",
      "Train Epoch: 22 [38400/60000 (64%)]\tLoss: 0.008662\n",
      "Train Epoch: 22 [57600/60000 (96%)]\tLoss: 0.071352\n",
      "\n",
      "Test set: Average loss: 0.0732, Accuracy: 9792/10000 (97.92%)\n",
      "\n",
      "Train Epoch: 23 [0/60000 (0%)]\tLoss: 0.016560\n",
      "Train Epoch: 23 [19200/60000 (32%)]\tLoss: 0.029577\n",
      "Train Epoch: 23 [38400/60000 (64%)]\tLoss: 0.113169\n",
      "Train Epoch: 23 [57600/60000 (96%)]\tLoss: 0.019912\n",
      "\n",
      "Test set: Average loss: 0.0747, Accuracy: 9768/10000 (97.68%)\n",
      "\n",
      "Train Epoch: 24 [0/60000 (0%)]\tLoss: 0.013163\n",
      "Train Epoch: 24 [19200/60000 (32%)]\tLoss: 0.004189\n",
      "Train Epoch: 24 [38400/60000 (64%)]\tLoss: 0.011162\n",
      "Train Epoch: 24 [57600/60000 (96%)]\tLoss: 0.031487\n",
      "\n",
      "Test set: Average loss: 0.0787, Accuracy: 9768/10000 (97.68%)\n",
      "\n",
      "Train Epoch: 25 [0/60000 (0%)]\tLoss: 0.008926\n",
      "Train Epoch: 25 [19200/60000 (32%)]\tLoss: 0.027597\n",
      "Train Epoch: 25 [38400/60000 (64%)]\tLoss: 0.027688\n",
      "Train Epoch: 25 [57600/60000 (96%)]\tLoss: 0.066825\n",
      "\n",
      "Test set: Average loss: 0.0744, Accuracy: 9787/10000 (97.87%)\n",
      "\n",
      "Train Epoch: 26 [0/60000 (0%)]\tLoss: 0.010067\n",
      "Train Epoch: 26 [19200/60000 (32%)]\tLoss: 0.054059\n",
      "Train Epoch: 26 [38400/60000 (64%)]\tLoss: 0.017555\n",
      "Train Epoch: 26 [57600/60000 (96%)]\tLoss: 0.012086\n",
      "\n",
      "Test set: Average loss: 0.0658, Accuracy: 9807/10000 (98.07%)\n",
      "\n",
      "Train Epoch: 27 [0/60000 (0%)]\tLoss: 0.003627\n",
      "Train Epoch: 27 [19200/60000 (32%)]\tLoss: 0.048421\n",
      "Train Epoch: 27 [38400/60000 (64%)]\tLoss: 0.009893\n",
      "Train Epoch: 27 [57600/60000 (96%)]\tLoss: 0.009878\n",
      "\n",
      "Test set: Average loss: 0.0720, Accuracy: 9788/10000 (97.88%)\n",
      "\n",
      "Train Epoch: 28 [0/60000 (0%)]\tLoss: 0.019938\n",
      "Train Epoch: 28 [19200/60000 (32%)]\tLoss: 0.032323\n",
      "Train Epoch: 28 [38400/60000 (64%)]\tLoss: 0.031199\n",
      "Train Epoch: 28 [57600/60000 (96%)]\tLoss: 0.007621\n",
      "\n",
      "Test set: Average loss: 0.0702, Accuracy: 9812/10000 (98.12%)\n",
      "\n",
      "Train Epoch: 29 [0/60000 (0%)]\tLoss: 0.008076\n",
      "Train Epoch: 29 [19200/60000 (32%)]\tLoss: 0.022995\n",
      "Train Epoch: 29 [38400/60000 (64%)]\tLoss: 0.005329\n",
      "Train Epoch: 29 [57600/60000 (96%)]\tLoss: 0.016594\n",
      "\n",
      "Test set: Average loss: 0.0725, Accuracy: 9796/10000 (97.96%)\n",
      "\n",
      "Train Epoch: 30 [0/60000 (0%)]\tLoss: 0.005467\n",
      "Train Epoch: 30 [19200/60000 (32%)]\tLoss: 0.011899\n",
      "Train Epoch: 30 [38400/60000 (64%)]\tLoss: 0.016812\n",
      "Train Epoch: 30 [57600/60000 (96%)]\tLoss: 0.044723\n",
      "\n",
      "Test set: Average loss: 0.0744, Accuracy: 9810/10000 (98.10%)\n",
      "\n",
      "Train Epoch: 31 [0/60000 (0%)]\tLoss: 0.003184\n",
      "Train Epoch: 31 [19200/60000 (32%)]\tLoss: 0.007962\n",
      "Train Epoch: 31 [38400/60000 (64%)]\tLoss: 0.017916\n",
      "Train Epoch: 31 [57600/60000 (96%)]\tLoss: 0.100541\n",
      "\n",
      "Test set: Average loss: 0.0686, Accuracy: 9816/10000 (98.16%)\n",
      "\n",
      "Train Epoch: 32 [0/60000 (0%)]\tLoss: 0.009135\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train Epoch: 32 [19200/60000 (32%)]\tLoss: 0.001255\n",
      "Train Epoch: 32 [38400/60000 (64%)]\tLoss: 0.016321\n",
      "Train Epoch: 32 [57600/60000 (96%)]\tLoss: 0.017591\n",
      "\n",
      "Test set: Average loss: 0.0741, Accuracy: 9795/10000 (97.95%)\n",
      "\n",
      "Train Epoch: 33 [0/60000 (0%)]\tLoss: 0.019762\n",
      "Train Epoch: 33 [19200/60000 (32%)]\tLoss: 0.007528\n",
      "Train Epoch: 33 [38400/60000 (64%)]\tLoss: 0.011752\n",
      "Train Epoch: 33 [57600/60000 (96%)]\tLoss: 0.007005\n",
      "\n",
      "Test set: Average loss: 0.0755, Accuracy: 9801/10000 (98.01%)\n",
      "\n",
      "Train Epoch: 34 [0/60000 (0%)]\tLoss: 0.008116\n",
      "Train Epoch: 34 [19200/60000 (32%)]\tLoss: 0.012971\n",
      "Train Epoch: 34 [38400/60000 (64%)]\tLoss: 0.013181\n",
      "Train Epoch: 34 [57600/60000 (96%)]\tLoss: 0.007892\n",
      "\n",
      "Test set: Average loss: 0.0737, Accuracy: 9813/10000 (98.13%)\n",
      "\n",
      "Train Epoch: 35 [0/60000 (0%)]\tLoss: 0.004402\n",
      "Train Epoch: 35 [19200/60000 (32%)]\tLoss: 0.046030\n",
      "Train Epoch: 35 [38400/60000 (64%)]\tLoss: 0.003948\n",
      "Train Epoch: 35 [57600/60000 (96%)]\tLoss: 0.009754\n",
      "\n",
      "Test set: Average loss: 0.0753, Accuracy: 9815/10000 (98.15%)\n",
      "\n",
      "Train Epoch: 36 [0/60000 (0%)]\tLoss: 0.001919\n",
      "Train Epoch: 36 [19200/60000 (32%)]\tLoss: 0.026707\n",
      "Train Epoch: 36 [38400/60000 (64%)]\tLoss: 0.049377\n",
      "Train Epoch: 36 [57600/60000 (96%)]\tLoss: 0.009107\n",
      "\n",
      "Test set: Average loss: 0.0739, Accuracy: 9821/10000 (98.21%)\n",
      "\n",
      "Train Epoch: 37 [0/60000 (0%)]\tLoss: 0.007011\n",
      "Train Epoch: 37 [19200/60000 (32%)]\tLoss: 0.004565\n",
      "Train Epoch: 37 [38400/60000 (64%)]\tLoss: 0.048642\n",
      "Train Epoch: 37 [57600/60000 (96%)]\tLoss: 0.020214\n",
      "\n",
      "Test set: Average loss: 0.0848, Accuracy: 9779/10000 (97.79%)\n",
      "\n",
      "Train Epoch: 38 [0/60000 (0%)]\tLoss: 0.033282\n",
      "Train Epoch: 38 [19200/60000 (32%)]\tLoss: 0.003944\n",
      "Train Epoch: 38 [38400/60000 (64%)]\tLoss: 0.001253\n",
      "Train Epoch: 38 [57600/60000 (96%)]\tLoss: 0.066279\n",
      "\n",
      "Test set: Average loss: 0.0750, Accuracy: 9804/10000 (98.04%)\n",
      "\n",
      "Train Epoch: 39 [0/60000 (0%)]\tLoss: 0.003919\n",
      "Train Epoch: 39 [19200/60000 (32%)]\tLoss: 0.007435\n",
      "Train Epoch: 39 [38400/60000 (64%)]\tLoss: 0.087819\n",
      "Train Epoch: 39 [57600/60000 (96%)]\tLoss: 0.037665\n",
      "\n",
      "Test set: Average loss: 0.0774, Accuracy: 9812/10000 (98.12%)\n",
      "\n",
      "Train Epoch: 40 [0/60000 (0%)]\tLoss: 0.007780\n",
      "Train Epoch: 40 [19200/60000 (32%)]\tLoss: 0.003695\n",
      "Train Epoch: 40 [38400/60000 (64%)]\tLoss: 0.020493\n",
      "Train Epoch: 40 [57600/60000 (96%)]\tLoss: 0.032433\n",
      "\n",
      "Test set: Average loss: 0.0768, Accuracy: 9830/10000 (98.30%)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "results[f'QuadNet + Linear2'] = main(\n",
    "    model=QuadLinear2Net(N_OUTPUT),\n",
    "    args=Parser(),\n",
    "    task='font'\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "show_results(results, 'Quadratic variant models', ymin=95)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here the accuracy is alread very good so the improvement is very limited, but on average with Linear2 we achieve better results."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2.3.2  Quadratic + Conv1\n",
    "Here we try to add a CNN wider model on top of the input, which consists of the CNN block used previously and which is provided in the [official Pytorch tutorial on MNIST](https://github.com/pytorch/examples/blob/master/mnist/main.py)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Parser:\n",
    "    \"\"\"Parameters for the training\"\"\"\n",
    "    def __init__(self):\n",
    "        self.epochs = 10\n",
    "        self.lr = 0.002\n",
    "        self.momentum = 0.5\n",
    "        self.test_batch_size = 1000\n",
    "        self.batch_size = 64\n",
    "        self.log_interval = 300"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "class QuadConv1Net(nn.Module):\n",
    "    def __init__(self, output_size):\n",
    "        super(QuadConv1Net, self).__init__()\n",
    "        self.proj1 = nn.Linear(784, 50)\n",
    "        self.diag1 = nn.Linear(50, output_size)\n",
    "        \n",
    "        # --- Junction\n",
    "        self.jct = nn.Linear(output_size, 784)\n",
    "        \n",
    "        # --- CNN\n",
    "        self.conv1 = nn.Conv2d(1, 20, 5, 1)\n",
    "        self.conv2 = nn.Conv2d(20, 50, 5, 1)\n",
    "        self.fc1 = nn.Linear(4*4*50, 500)\n",
    "        self.fc2 = nn.Linear(500, output_size)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, 784)\n",
    "        x = self.proj1(x)\n",
    "        x = x * x\n",
    "        x = self.diag1(x)\n",
    "        \n",
    "        # --- Junction\n",
    "        x = self.jct(x)\n",
    "        x = x.view(-1, 1, 28, 28)\n",
    "        \n",
    "        # --- CNN\n",
    "        x = F.relu(self.conv1(x))\n",
    "        x = F.max_pool2d(x, 2, 2)\n",
    "        x = F.relu(self.conv2(x))\n",
    "        x = F.max_pool2d(x, 2, 2)\n",
    "        x = x.view(-1, 4*4*50)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return F.log_softmax(x, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training set 60000 items\n",
      "Testing set  10000 items\n",
      "Learning on font \n",
      "Train Epoch: 1 [0/60000 (0%)]\tLoss: 0.697213\n",
      "Train Epoch: 1 [19200/60000 (32%)]\tLoss: 0.691049\n",
      "Train Epoch: 1 [38400/60000 (64%)]\tLoss: 0.600323\n",
      "Train Epoch: 1 [57600/60000 (96%)]\tLoss: 0.346761\n",
      "\n",
      "Test set: Average loss: 0.3493, Accuracy: 8608/10000 (86.08%)\n",
      "\n",
      "Train Epoch: 2 [0/60000 (0%)]\tLoss: 0.299339\n",
      "Train Epoch: 2 [19200/60000 (32%)]\tLoss: 0.246099\n",
      "Train Epoch: 2 [38400/60000 (64%)]\tLoss: 0.086101\n",
      "Train Epoch: 2 [57600/60000 (96%)]\tLoss: 0.225254\n",
      "\n",
      "Test set: Average loss: 0.1472, Accuracy: 9463/10000 (94.63%)\n",
      "\n",
      "Train Epoch: 3 [0/60000 (0%)]\tLoss: 0.075447\n",
      "Train Epoch: 3 [19200/60000 (32%)]\tLoss: 0.139381\n",
      "Train Epoch: 3 [38400/60000 (64%)]\tLoss: 0.115160\n",
      "Train Epoch: 3 [57600/60000 (96%)]\tLoss: 0.068264\n",
      "\n",
      "Test set: Average loss: 0.1109, Accuracy: 9617/10000 (96.17%)\n",
      "\n",
      "Train Epoch: 4 [0/60000 (0%)]\tLoss: 0.175119\n",
      "Train Epoch: 4 [19200/60000 (32%)]\tLoss: 0.050371\n",
      "Train Epoch: 4 [38400/60000 (64%)]\tLoss: 0.069492\n",
      "Train Epoch: 4 [57600/60000 (96%)]\tLoss: 0.081696\n",
      "\n",
      "Test set: Average loss: 0.1145, Accuracy: 9585/10000 (95.85%)\n",
      "\n",
      "Train Epoch: 5 [0/60000 (0%)]\tLoss: 0.166219\n",
      "Train Epoch: 5 [19200/60000 (32%)]\tLoss: 0.054658\n",
      "Train Epoch: 5 [38400/60000 (64%)]\tLoss: 0.059906\n",
      "Train Epoch: 5 [57600/60000 (96%)]\tLoss: 0.205487\n",
      "\n",
      "Test set: Average loss: 0.0907, Accuracy: 9683/10000 (96.83%)\n",
      "\n",
      "Train Epoch: 6 [0/60000 (0%)]\tLoss: 0.148755\n",
      "Train Epoch: 6 [19200/60000 (32%)]\tLoss: 0.094618\n",
      "Train Epoch: 6 [38400/60000 (64%)]\tLoss: 0.080069\n",
      "Train Epoch: 6 [57600/60000 (96%)]\tLoss: 0.059098\n",
      "\n",
      "Test set: Average loss: 0.0843, Accuracy: 9705/10000 (97.05%)\n",
      "\n",
      "Train Epoch: 7 [0/60000 (0%)]\tLoss: 0.094513\n",
      "Train Epoch: 7 [19200/60000 (32%)]\tLoss: 0.062035\n",
      "Train Epoch: 7 [38400/60000 (64%)]\tLoss: 0.093098\n",
      "Train Epoch: 7 [57600/60000 (96%)]\tLoss: 0.094558\n",
      "\n",
      "Test set: Average loss: 0.0873, Accuracy: 9702/10000 (97.02%)\n",
      "\n",
      "Train Epoch: 8 [0/60000 (0%)]\tLoss: 0.111004\n",
      "Train Epoch: 8 [19200/60000 (32%)]\tLoss: 0.007958\n",
      "Train Epoch: 8 [38400/60000 (64%)]\tLoss: 0.084231\n",
      "Train Epoch: 8 [57600/60000 (96%)]\tLoss: 0.099810\n",
      "\n",
      "Test set: Average loss: 0.0682, Accuracy: 9782/10000 (97.82%)\n",
      "\n",
      "Train Epoch: 9 [0/60000 (0%)]\tLoss: 0.073045\n",
      "Train Epoch: 9 [19200/60000 (32%)]\tLoss: 0.045777\n",
      "Train Epoch: 9 [38400/60000 (64%)]\tLoss: 0.095547\n",
      "Train Epoch: 9 [57600/60000 (96%)]\tLoss: 0.104634\n",
      "\n",
      "Test set: Average loss: 0.0794, Accuracy: 9735/10000 (97.35%)\n",
      "\n",
      "Train Epoch: 10 [0/60000 (0%)]\tLoss: 0.014087\n",
      "Train Epoch: 10 [19200/60000 (32%)]\tLoss: 0.015748\n",
      "Train Epoch: 10 [38400/60000 (64%)]\tLoss: 0.083717\n",
      "Train Epoch: 10 [57600/60000 (96%)]\tLoss: 0.016365\n",
      "\n",
      "Test set: Average loss: 0.0668, Accuracy: 9792/10000 (97.92%)\n",
      "\n",
      "Train Epoch: 11 [0/60000 (0%)]\tLoss: 0.021936\n",
      "Train Epoch: 11 [19200/60000 (32%)]\tLoss: 0.059992\n",
      "Train Epoch: 11 [38400/60000 (64%)]\tLoss: 0.056224\n",
      "Train Epoch: 11 [57600/60000 (96%)]\tLoss: 0.003484\n",
      "\n",
      "Test set: Average loss: 0.0615, Accuracy: 9805/10000 (98.05%)\n",
      "\n",
      "Train Epoch: 12 [0/60000 (0%)]\tLoss: 0.043058\n",
      "Train Epoch: 12 [19200/60000 (32%)]\tLoss: 0.197779\n",
      "Train Epoch: 12 [38400/60000 (64%)]\tLoss: 0.019284\n",
      "Train Epoch: 12 [57600/60000 (96%)]\tLoss: 0.007467\n",
      "\n",
      "Test set: Average loss: 0.0600, Accuracy: 9825/10000 (98.25%)\n",
      "\n",
      "Train Epoch: 13 [0/60000 (0%)]\tLoss: 0.031564\n",
      "Train Epoch: 13 [19200/60000 (32%)]\tLoss: 0.023050\n",
      "Train Epoch: 13 [38400/60000 (64%)]\tLoss: 0.029677\n",
      "Train Epoch: 13 [57600/60000 (96%)]\tLoss: 0.022539\n",
      "\n",
      "Test set: Average loss: 0.0631, Accuracy: 9791/10000 (97.91%)\n",
      "\n",
      "Train Epoch: 14 [0/60000 (0%)]\tLoss: 0.005595\n",
      "Train Epoch: 14 [19200/60000 (32%)]\tLoss: 0.066908\n",
      "Train Epoch: 14 [38400/60000 (64%)]\tLoss: 0.005138\n",
      "Train Epoch: 14 [57600/60000 (96%)]\tLoss: 0.139873\n",
      "\n",
      "Test set: Average loss: 0.0729, Accuracy: 9770/10000 (97.70%)\n",
      "\n",
      "Train Epoch: 15 [0/60000 (0%)]\tLoss: 0.028896\n",
      "Train Epoch: 15 [19200/60000 (32%)]\tLoss: 0.007518\n",
      "Train Epoch: 15 [38400/60000 (64%)]\tLoss: 0.023708\n",
      "Train Epoch: 15 [57600/60000 (96%)]\tLoss: 0.009206\n",
      "\n",
      "Test set: Average loss: 0.0605, Accuracy: 9812/10000 (98.12%)\n",
      "\n",
      "Train Epoch: 16 [0/60000 (0%)]\tLoss: 0.032892\n",
      "Train Epoch: 16 [19200/60000 (32%)]\tLoss: 0.025340\n",
      "Train Epoch: 16 [38400/60000 (64%)]\tLoss: 0.121196\n",
      "Train Epoch: 16 [57600/60000 (96%)]\tLoss: 0.010366\n",
      "\n",
      "Test set: Average loss: 0.0715, Accuracy: 9786/10000 (97.86%)\n",
      "\n",
      "Train Epoch: 17 [0/60000 (0%)]\tLoss: 0.049866\n",
      "Train Epoch: 17 [19200/60000 (32%)]\tLoss: 0.003421\n",
      "Train Epoch: 17 [38400/60000 (64%)]\tLoss: 0.002174\n",
      "Train Epoch: 17 [57600/60000 (96%)]\tLoss: 0.026032\n",
      "\n",
      "Test set: Average loss: 0.0577, Accuracy: 9829/10000 (98.29%)\n",
      "\n",
      "Train Epoch: 18 [0/60000 (0%)]\tLoss: 0.037750\n",
      "Train Epoch: 18 [19200/60000 (32%)]\tLoss: 0.006068\n",
      "Train Epoch: 18 [38400/60000 (64%)]\tLoss: 0.001556\n",
      "Train Epoch: 18 [57600/60000 (96%)]\tLoss: 0.012266\n",
      "\n",
      "Test set: Average loss: 0.0637, Accuracy: 9804/10000 (98.04%)\n",
      "\n",
      "Train Epoch: 19 [0/60000 (0%)]\tLoss: 0.001623\n",
      "Train Epoch: 19 [19200/60000 (32%)]\tLoss: 0.043694\n",
      "Train Epoch: 19 [38400/60000 (64%)]\tLoss: 0.100753\n",
      "Train Epoch: 19 [57600/60000 (96%)]\tLoss: 0.083019\n",
      "\n",
      "Test set: Average loss: 0.0606, Accuracy: 9819/10000 (98.19%)\n",
      "\n",
      "Train Epoch: 20 [0/60000 (0%)]\tLoss: 0.002607\n",
      "Train Epoch: 20 [19200/60000 (32%)]\tLoss: 0.014648\n",
      "Train Epoch: 20 [38400/60000 (64%)]\tLoss: 0.099082\n",
      "Train Epoch: 20 [57600/60000 (96%)]\tLoss: 0.011390\n",
      "\n",
      "Test set: Average loss: 0.0603, Accuracy: 9827/10000 (98.27%)\n",
      "\n",
      "Train Epoch: 21 [0/60000 (0%)]\tLoss: 0.018007\n",
      "Train Epoch: 21 [19200/60000 (32%)]\tLoss: 0.077466\n",
      "Train Epoch: 21 [38400/60000 (64%)]\tLoss: 0.002466\n",
      "Train Epoch: 21 [57600/60000 (96%)]\tLoss: 0.063680\n",
      "\n",
      "Test set: Average loss: 0.0565, Accuracy: 9831/10000 (98.31%)\n",
      "\n",
      "Train Epoch: 22 [0/60000 (0%)]\tLoss: 0.008360\n",
      "Train Epoch: 22 [19200/60000 (32%)]\tLoss: 0.008810\n",
      "Train Epoch: 22 [38400/60000 (64%)]\tLoss: 0.033302\n",
      "Train Epoch: 22 [57600/60000 (96%)]\tLoss: 0.001313\n",
      "\n",
      "Test set: Average loss: 0.0584, Accuracy: 9816/10000 (98.16%)\n",
      "\n",
      "Train Epoch: 23 [0/60000 (0%)]\tLoss: 0.122134\n",
      "Train Epoch: 23 [19200/60000 (32%)]\tLoss: 0.025047\n",
      "Train Epoch: 23 [38400/60000 (64%)]\tLoss: 0.001157\n",
      "Train Epoch: 23 [57600/60000 (96%)]\tLoss: 0.051000\n",
      "\n",
      "Test set: Average loss: 0.0599, Accuracy: 9825/10000 (98.25%)\n",
      "\n",
      "Train Epoch: 24 [0/60000 (0%)]\tLoss: 0.024656\n",
      "Train Epoch: 24 [19200/60000 (32%)]\tLoss: 0.001460\n",
      "Train Epoch: 24 [38400/60000 (64%)]\tLoss: 0.013227\n",
      "Train Epoch: 24 [57600/60000 (96%)]\tLoss: 0.075732\n",
      "\n",
      "Test set: Average loss: 0.0629, Accuracy: 9833/10000 (98.33%)\n",
      "\n",
      "Train Epoch: 25 [0/60000 (0%)]\tLoss: 0.069465\n",
      "Train Epoch: 25 [19200/60000 (32%)]\tLoss: 0.000751\n",
      "Train Epoch: 25 [38400/60000 (64%)]\tLoss: 0.003613\n",
      "Train Epoch: 25 [57600/60000 (96%)]\tLoss: 0.006830\n",
      "\n",
      "Test set: Average loss: 0.0629, Accuracy: 9825/10000 (98.25%)\n",
      "\n",
      "Train Epoch: 26 [0/60000 (0%)]\tLoss: 0.008595\n",
      "Train Epoch: 26 [19200/60000 (32%)]\tLoss: 0.000611\n",
      "Train Epoch: 26 [38400/60000 (64%)]\tLoss: 0.028606\n",
      "Train Epoch: 26 [57600/60000 (96%)]\tLoss: 0.093609\n",
      "\n",
      "Test set: Average loss: 0.0604, Accuracy: 9827/10000 (98.27%)\n",
      "\n",
      "Train Epoch: 27 [0/60000 (0%)]\tLoss: 0.001589\n",
      "Train Epoch: 27 [19200/60000 (32%)]\tLoss: 0.003670\n",
      "Train Epoch: 27 [38400/60000 (64%)]\tLoss: 0.047528\n",
      "Train Epoch: 27 [57600/60000 (96%)]\tLoss: 0.049798\n",
      "\n",
      "Test set: Average loss: 0.0554, Accuracy: 9856/10000 (98.56%)\n",
      "\n",
      "Train Epoch: 28 [0/60000 (0%)]\tLoss: 0.014326\n",
      "Train Epoch: 28 [19200/60000 (32%)]\tLoss: 0.003014\n",
      "Train Epoch: 28 [38400/60000 (64%)]\tLoss: 0.008097\n",
      "Train Epoch: 28 [57600/60000 (96%)]\tLoss: 0.006480\n",
      "\n",
      "Test set: Average loss: 0.0597, Accuracy: 9823/10000 (98.23%)\n",
      "\n",
      "Train Epoch: 29 [0/60000 (0%)]\tLoss: 0.032848\n",
      "Train Epoch: 29 [19200/60000 (32%)]\tLoss: 0.001309\n",
      "Train Epoch: 29 [38400/60000 (64%)]\tLoss: 0.121447\n",
      "Train Epoch: 29 [57600/60000 (96%)]\tLoss: 0.041024\n",
      "\n",
      "Test set: Average loss: 0.0632, Accuracy: 9833/10000 (98.33%)\n",
      "\n",
      "Train Epoch: 30 [0/60000 (0%)]\tLoss: 0.004284\n",
      "Train Epoch: 30 [19200/60000 (32%)]\tLoss: 0.010977\n",
      "Train Epoch: 30 [38400/60000 (64%)]\tLoss: 0.015307\n",
      "Train Epoch: 30 [57600/60000 (96%)]\tLoss: 0.007490\n",
      "\n",
      "Test set: Average loss: 0.0648, Accuracy: 9825/10000 (98.25%)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "args = Parser()\n",
    "args.epochs = 30\n",
    "\n",
    "results['QuadNet + Conv1'] = main(\n",
    "    model=QuadConv1Net(N_OUTPUT),\n",
    "    args=args, \n",
    "    task='font'\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "show_results(results, 'Quadratic variant models', ymin=95)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The CNN configuration really outperforms the linear ones, which we could have expected because the CNN alone is doing really good on the MNIST official example. What's interesting is that it managed to exploit the private quadratic model to leverage its 10 bits output and still achieve a very good performance."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Conclusion\n",
    "\n",
    "This shows as a conclusion that we can expect some improvements on the global accuracy if we use a public network to leverage (and optimize) the output of the private quadratic network."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\n",
    "### If you like it, star it!\n",
    "\n",
    "The easiest way to show support is just by starring the Repos! This helps raise awareness on this topics and is a precious feedback for the repo maintainers!\n",
    "\n",
    "- _reference deleted_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
