{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "olympic-maximum",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "from torchvision import transforms\n",
    "from torchvision.datasets import MNIST\n",
    "from copy import deepcopy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fixed-decline",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = torch.device('cuda', 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "refined-store",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load data\n",
    "class Flatten(object):\n",
    "    def __call__(self, pic):\n",
    "        return torch.flatten(pic)\n",
    "    \n",
    "mnist_dataset = MNIST('/tmp/mnist/', download=True, train=True,\n",
    "                      transform=transforms.Compose([transforms.ToTensor(), Flatten()]))\n",
    "images = mnist_dataset.data\n",
    "targets = mnist_dataset.targets\n",
    "np.random.seed(0)\n",
    "val_inds = np.sort(np.random.choice(len(images), size=10000, replace=False))\n",
    "train_inds = np.setdiff1d(np.arange(len(images)), val_inds)\n",
    "\n",
    "# Training dataset\n",
    "train_dataset = torch.utils.data.Subset(mnist_dataset, train_inds)\n",
    "\n",
    "# Validation dataset\n",
    "val_dataset = torch.utils.data.Subset(mnist_dataset, val_inds)\n",
    "\n",
    "# Test dataset\n",
    "test_dataset = MNIST('/tmp/mnist/', download=True, train=False,\n",
    "                     transform=transforms.Compose([transforms.ToTensor(), Flatten()]))\n",
    "\n",
    "# Set input/output dimensions\n",
    "d_in = 784\n",
    "d_out = 10"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "perceived-blind",
   "metadata": {},
   "source": [
    "# Train model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "503c1728-3310-4a51-8bd6-c900bd000506",
   "metadata": {},
   "outputs": [],
   "source": [
    "from adaptive import BaseModel\n",
    "from torchmetrics import Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "separate-going",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------Epoch 1--------\n",
      "Val loss = 0.9626\n",
      "\n",
      "--------Epoch 2--------\n",
      "Val loss = 0.9658\n",
      "\n",
      "--------Epoch 3--------\n",
      "Val loss = 0.9764\n",
      "\n",
      "--------Epoch 4--------\n",
      "Val loss = 0.9780\n",
      "\n",
      "--------Epoch 5--------\n",
      "Val loss = 0.9794\n",
      "\n",
      "--------Epoch 6--------\n",
      "Val loss = 0.9799\n",
      "\n",
      "--------Epoch 7--------\n",
      "Val loss = 0.9806\n",
      "\n",
      "--------Epoch 8--------\n",
      "Val loss = 0.9763\n",
      "\n",
      "--------Epoch 9--------\n",
      "Val loss = 0.9818\n",
      "\n",
      "--------Epoch 10--------\n",
      "Val loss = 0.9774\n",
      "\n",
      "--------Epoch 11--------\n",
      "Val loss = 0.9768\n",
      "\n",
      "--------Epoch 12--------\n",
      "Val loss = 0.9770\n",
      "\n",
      "Epoch    12: reducing learning rate of group 0 to 2.0000e-04.\n",
      "--------Epoch 13--------\n",
      "Val loss = 0.9832\n",
      "\n",
      "--------Epoch 14--------\n",
      "Val loss = 0.9843\n",
      "\n",
      "--------Epoch 15--------\n",
      "Val loss = 0.9845\n",
      "\n",
      "--------Epoch 16--------\n",
      "Val loss = 0.9844\n",
      "\n",
      "--------Epoch 17--------\n",
      "Val loss = 0.9846\n",
      "\n",
      "--------Epoch 18--------\n",
      "Val loss = 0.9846\n",
      "\n",
      "--------Epoch 19--------\n",
      "Val loss = 0.9846\n",
      "\n",
      "--------Epoch 20--------\n",
      "Val loss = 0.9847\n",
      "\n",
      "--------Epoch 21--------\n",
      "Val loss = 0.9846\n",
      "\n",
      "--------Epoch 22--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "--------Epoch 23--------\n",
      "Val loss = 0.9848\n",
      "\n",
      "--------Epoch 24--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "--------Epoch 25--------\n",
      "Val loss = 0.9850\n",
      "\n",
      "Epoch    25: reducing learning rate of group 0 to 4.0000e-05.\n",
      "--------Epoch 26--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "--------Epoch 27--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "--------Epoch 28--------\n",
      "Val loss = 0.9852\n",
      "\n",
      "--------Epoch 29--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "--------Epoch 30--------\n",
      "Val loss = 0.9852\n",
      "\n",
      "--------Epoch 31--------\n",
      "Val loss = 0.9851\n",
      "\n",
      "Epoch    31: reducing learning rate of group 0 to 8.0000e-06.\n",
      "--------Epoch 32--------\n",
      "Val loss = 0.9852\n",
      "\n",
      "--------Epoch 33--------\n",
      "Val loss = 0.9853\n",
      "\n",
      "--------Epoch 34--------\n",
      "Val loss = 0.9854\n",
      "\n",
      "--------Epoch 35--------\n",
      "Val loss = 0.9853\n",
      "\n",
      "--------Epoch 36--------\n",
      "Val loss = 0.9852\n",
      "\n",
      "--------Epoch 37--------\n",
      "Val loss = 0.9853\n",
      "\n",
      "Epoch    37: reducing learning rate of group 0 to 1.6000e-06.\n",
      "--------Epoch 38--------\n",
      "Val loss = 0.9853\n",
      "\n",
      "Stopping early at epoch 38\n"
     ]
    }
   ],
   "source": [
    "# Set up model\n",
    "model = nn.Sequential(\n",
    "    nn.Linear(d_in, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, 512),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(512, d_out))\n",
    "trainer = BaseModel(model).to(device)\n",
    "\n",
    "# Pretrain\n",
    "trainer.fit(train_dataset,\n",
    "            val_dataset,\n",
    "            mbsize=128,\n",
    "            lr=1e-3,\n",
    "            nepochs=100,\n",
    "            loss_fn=nn.CrossEntropyLoss(),\n",
    "            val_loss_fn=Accuracy(),\n",
    "            val_loss_mode='max')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a0bc0f1d-2694-4561-9218-4b1361721b39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Acc = 98.56\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Calculate accuracy\n",
    "test_acc = trainer.evaluate(test_dataset, Accuracy(), 1024)\n",
    "print(f'Acc = {100*test_acc:.2f}\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "abf05734-ad77-4cd9-a40f-ad0a14072a7c",
   "metadata": {},
   "source": [
    "# Check calibration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "90d7a11c-4372-4ed2-85c6-121ddbdd44c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchmetrics.functional.classification.calibration_error import _ce_update, _binning_bucketize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9daf8c3b-d1c6-4b74-b431-d3a009d75529",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Prepare inputs\n",
    "x = torch.stack([x for x, y in test_dataset])\n",
    "y = torch.tensor(np.array([y for x, y in test_dataset]))\n",
    "\n",
    "# Generate predictions\n",
    "with torch.no_grad():\n",
    "    pred = model.forward(x.to(device)).softmax(dim=1).cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "970af148-b5ba-48bc-8631-dbe1bba76c41",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calibration error = 0.0276\n"
     ]
    }
   ],
   "source": [
    "# Calculate per-bin calibration results\n",
    "bin_boundaries = torch.linspace(0, 1, 20)\n",
    "confidences, accuracies = _ce_update(pred, y)\n",
    "acc_bin, conf_bin, prop_bin = _binning_bucketize(confidences, accuracies, bin_boundaries)\n",
    "\n",
    "# Calculate l2 metric\n",
    "ce = torch.sqrt(torch.sum(torch.pow(acc_bin - conf_bin, 2) * prop_bin))\n",
    "print(f'Calibration error = {ce:.4f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b6438398-0dfb-4ceb-a98d-e72dcc3c51eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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NpIv1m5j1958zvFhtxWoRUdERETKkZ6ezujRo3nzzTcBOPfcc7nqqqswq7Ta0n5zl6XQoWUoY3u1q8swD0mJjoiIiBykXbt2dOzYkdDQ0GofuyM7jy9+3sZZw6MJCvRtqqFER0RERABYtmwZZ555Jnv37iUwMJD33nuPyZMnV/s87ySkUVjsOGe4b7utQImOiIiIeGVnZ5OYmMjGjRtrdJ55y1KI7dKK3h1b1lJkh0+JjoiISBP2+eef8/zzzwNw7LHHsn79egYPHnzY51udlsmaLVk+H4RcQomOiIhIE/b000/zxBNP7C/CWd7Cf9Uxb1kqIYEBnBnru7VzSlOiIyIi0sS8++67bN26FYDZs2fzww8/7C/CWRP5hcUsSEjlpAEdiWxWs4SptijRERERaULS0tKYOnUq//73vwFPEc7w8PBaOfeX3rVzpoyon4KdVaEFA0VERPycc46lS5cycuRIoqKi+N///sfIkSNr/Tpzl6XQrkUo43q3r/VzHy616IiIiPi52bNnM2rUqP1FOMeMGVPjsThl7czO4/Oft3F2A1g7pzS16IiIiPih4uJidu3aRbt27bjooosws0MW4ayJdxM9a+dMaQBr55TWcFIuERERqTXnnnsuZ5xxBkVFRTRv3pxrrrmm0iKcNTV3WQpDurSibyffr51Tmlp0RERE/ERhYSGBgYGYGeeffz579uypchHOmliTlsXqtCzumziwzq9VXWrRERER8QPp6ekceeSRvPHGGwCcc845XH755VUuwlkT85anEBxoTGwga+eUpkRHRETED7Rr146YmBiaN29er9ctKCrmnYRUTuzfkdbNG8baOaUp0REREWmklixZwumnn76/COeCBQuYOHFivcbw1drt7MjObzAlH8pSoiMiItJI5eTksGbNGjZt2uSzGPavndOn4aydU5oSHRERkUbk008/5bnnngNg3LhxrF27loEDfTMIeNfefP73czqTh0YR3IDWzimtYUYlIiIi5Zo1axZPPfVUrRXhrIl3E1IpKHJMaaDdVqBER0REpMF7++2366QIZ03NW57KoOgI+neO8HUoFVKiIyIi0oClpqZy/vnn7y/C2aZNG8LCwnwcFfy8NYuVqZmc08BWQi7L9+mgiIiIHMA5x+LFiznqqKOIjo7miy++IC4uztdhHWDeMu/aOUMbTqXy8qhFR0REpIGZ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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(9, 6))\n",
    "\n",
    "# Plot\n",
    "plt.plot(conf_bin, acc_bin, marker='o')\n",
    "plt.plot([0, 1], [0, 1], color='black', linestyle=':')\n",
    "\n",
    "# Labels\n",
    "plt.xlabel('Confidence', fontsize=18)\n",
    "plt.ylabel('Accuracy', fontsize=18)\n",
    "plt.tick_params(labelsize=16)\n",
    "plt.title('Calibration', fontsize=20)\n",
    "\n",
    "# Axis spines\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aedbce0-b61f-47d0-a691-4c876ca1520b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
