{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.backends.cudnn as cudnn\n",
    "\n",
    "cwd = os.getcwd()\n",
    "module_path = \"/\".join(cwd.split('/')[0:-1])\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(module_path)\n",
    "\n",
    "# Network architectures\n",
    "from net.lenet import lenet\n",
    "from net.resnet import resnet18\n",
    "from net.vgg import vgg16"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load LeNet model\n",
    "lenet_model = lenet().to(device)\n",
    "lenet_model = nn.DataParallel(lenet_model, device_ids=range(torch.cuda.device_count()))\n",
    "cudnn.benchmark = True\n",
    "lenet_model.load_state_dict(torch.load(\"./lenet_1_100.model\"))\n",
    "\n",
    "# Load ResNet-18 model\n",
    "resnet18_sn_model = resnet18(spectral_normalization=True,\n",
    "                             mod = False,\n",
    "                             mnist = True).to(device)\n",
    "resnet18_sn_model = nn.DataParallel(resnet18_sn_model, device_ids=range(torch.cuda.device_count()))\n",
    "resnet18_sn_model.load_state_dict(torch.load(\"./resnet18_sn_3.0_1_100.model\"))\n",
    "\n",
    "# Load VGG-16 model\n",
    "vgg16_model = vgg16(spectral_normalization = False,\n",
    "                    mod = False,\n",
    "                    mnist = True).to(device)\n",
    "vgg16_model = nn.DataParallel(vgg16_model, device_ids=range(torch.cuda.device_count()))\n",
    "vgg16_model.load_state_dict(torch.load(\"./vgg16_1_100.model\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compute softmax entropy & feature density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "from data.fast_mnist import create_MNIST_dataset\n",
    "from data.ambiguous_mnist.ambiguous_mnist import get_loaders\n",
    "from data.dirty_mnist import get_train_valid_loader, get_test_loader\n",
    "import data.fashion_mnist as fashion_mnist\n",
    "\n",
    "import metrics.uncertainty_confidence as uncertainty_confidence\n",
    "\n",
    "from utils.gmm_utils import get_embeddings, gmm_fit, gmm_evaluate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_classes = 10\n",
    "batch_size = 128\n",
    "\n",
    "# MNIST data loader\n",
    "_, mnist_test_dataset = create_MNIST_dataset()\n",
    "mnist_loader = torch.utils.data.DataLoader(mnist_test_dataset,\n",
    "                                           batch_size=batch_size,\n",
    "                                           num_workers=0,\n",
    "                                           shuffle=False)\n",
    "\n",
    "# Ambiguous MNIST data loader\n",
    "ambiguous_mnist_loader = get_loaders(root='/home/jishnu/Projects/OATML/DDU/code/',\n",
    "                                     train=False,\n",
    "                                     batch_size=batch_size)\n",
    "\n",
    "# Dirty MNIST data loader\n",
    "dirty_mnist_train_loader, dirty_mnist_val_loader = get_train_valid_loader(root='/home/jishnu/Projects/OATML/DDU/code/',\n",
    "                                                                          batch_size=batch_size)\n",
    "dirty_mnist_loader = get_test_loader(root='/home/jishnu/Projects/OATML/DDU/code/',\n",
    "                                     batch_size=batch_size)\n",
    "\n",
    "# Fashion MNIST data loader\n",
    "fashion_mnist_loader = fashion_mnist.get_loaders(batch_size=batch_size,\n",
    "                                                 train=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_logits (model, data_loader, device):\n",
    "    logits = []\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        for (data, label) in tqdm(data_loader):\n",
    "            data = data.to(device)\n",
    "            label = label.to(device)\n",
    "\n",
    "            output = model(data)\n",
    "            logits.append(output)\n",
    "        \n",
    "    logits = torch.cat(logits, dim=0)\n",
    "    return logits\n",
    "\n",
    "\n",
    "def train_gmm(model, num_dim, train_loader, device):\n",
    "    embeddings, labels = get_embeddings(model,\n",
    "                                        train_loader,\n",
    "                                        num_dim,\n",
    "                                        dtype=torch.double,\n",
    "                                        device=device,\n",
    "                                        storage_device=device)\n",
    "    gaussians_model, jitter_eps = gmm_fit(embeddings=embeddings,\n",
    "                                          labels=labels,\n",
    "                                          num_classes=10)\n",
    "    return gaussians_model\n",
    "\n",
    "\n",
    "def get_gmm_logits(model, gmm_model, data_loader, device):\n",
    "    gmm_logits, gmm_labels = gmm_evaluate(model,\n",
    "                                          gmm_model,\n",
    "                                          data_loader,\n",
    "                                          device=device,\n",
    "                                          num_classes=10,\n",
    "                                          storage_device=device)\n",
    "    return gmm_logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:00<00:00, 106.11it/s]\n",
      "100%|██████████| 469/469 [00:00<00:00, 775.22it/s]\n",
      "100%|██████████| 547/547 [00:00<00:00, 717.87it/s]\n",
      "100%|██████████| 79/79 [00:00<00:00, 165.10it/s]\n",
      "100%|██████████| 844/844 [00:01<00:00, 749.79it/s]\n",
      "100%|██████████| 79/79 [00:00<00:00, 556.37it/s]\n",
      "100%|██████████| 469/469 [00:00<00:00, 597.86it/s]\n",
      "100%|██████████| 547/547 [00:00<00:00, 573.77it/s]\n",
      "100%|██████████| 79/79 [00:00<00:00, 160.59it/s]\n"
     ]
    }
   ],
   "source": [
    "# Computing entropies for LeNet\n",
    "lenet_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(lenet_model, mnist_loader, device)\n",
    ")\n",
    "lenet_ambiguous_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(lenet_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "lenet_dirty_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(lenet_model, dirty_mnist_loader, device)\n",
    ")\n",
    "lenet_fashion_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(lenet_model, fashion_mnist_loader, device)\n",
    ")\n",
    "\n",
    "# Computing GMM densities for LeNet\n",
    "lenet_gmm_model = train_gmm(lenet_model, 84, dirty_mnist_train_loader, device)\n",
    "lenet_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(lenet_model, lenet_gmm_model, mnist_loader, device)\n",
    ")\n",
    "lenet_ambiguous_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(lenet_model, lenet_gmm_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "lenet_dirty_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(lenet_model, lenet_gmm_model, dirty_mnist_loader, device)\n",
    ")\n",
    "lenet_fashion_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(lenet_model, lenet_gmm_model, fashion_mnist_loader, device)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:02<00:00, 33.27it/s]\n",
      "100%|██████████| 469/469 [00:12<00:00, 37.05it/s]\n",
      "100%|██████████| 547/547 [00:15<00:00, 35.56it/s]\n",
      "100%|██████████| 79/79 [00:02<00:00, 34.07it/s]\n",
      "100%|██████████| 844/844 [00:22<00:00, 38.18it/s]\n",
      "100%|██████████| 79/79 [00:02<00:00, 33.68it/s]\n",
      "100%|██████████| 469/469 [00:14<00:00, 33.17it/s]\n",
      "100%|██████████| 547/547 [00:17<00:00, 31.02it/s]\n",
      "100%|██████████| 79/79 [00:02<00:00, 30.80it/s]\n"
     ]
    }
   ],
   "source": [
    "# Computing entropies for ResNet18-SN\n",
    "resnet18_sn_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(resnet18_sn_model, mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_ambiguous_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(resnet18_sn_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_dirty_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(resnet18_sn_model, dirty_mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_fashion_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(resnet18_sn_model, fashion_mnist_loader, device)\n",
    ")\n",
    "\n",
    "# Computing GMM densities for resnet18_sn\n",
    "resnet18_sn_gmm_model = train_gmm(resnet18_sn_model, 512, dirty_mnist_train_loader, device)\n",
    "resnet18_sn_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(resnet18_sn_model, resnet18_sn_gmm_model, mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_ambiguous_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(resnet18_sn_model, resnet18_sn_gmm_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_dirty_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(resnet18_sn_model, resnet18_sn_gmm_model, dirty_mnist_loader, device)\n",
    ")\n",
    "resnet18_sn_fashion_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(resnet18_sn_model, resnet18_sn_gmm_model, fashion_mnist_loader, device)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:03<00:00, 24.80it/s]\n",
      "100%|██████████| 469/469 [00:16<00:00, 28.36it/s]\n",
      "100%|██████████| 547/547 [00:19<00:00, 28.21it/s]\n",
      "100%|██████████| 79/79 [00:02<00:00, 28.65it/s]\n",
      "100%|██████████| 844/844 [00:27<00:00, 30.29it/s]\n",
      "100%|██████████| 79/79 [00:02<00:00, 27.60it/s]\n",
      "100%|██████████| 469/469 [00:16<00:00, 27.64it/s]\n",
      "100%|██████████| 547/547 [00:20<00:00, 27.14it/s]\n",
      "100%|██████████| 79/79 [00:03<00:00, 26.23it/s]\n"
     ]
    }
   ],
   "source": [
    "# Computing entropies for VGG-16\n",
    "vgg16_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(vgg16_model, mnist_loader, device)\n",
    ")\n",
    "vgg16_ambiguous_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(vgg16_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "vgg16_dirty_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(vgg16_model, dirty_mnist_loader, device)\n",
    ")\n",
    "vgg16_fashion_mnist_entropies = uncertainty_confidence.entropy(\n",
    "    get_logits(vgg16_model, fashion_mnist_loader, device)\n",
    ")\n",
    "\n",
    "# Computing GMM densities for vgg16\n",
    "vgg16_gmm_model = train_gmm(vgg16_model, 512, dirty_mnist_train_loader, device)\n",
    "vgg16_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(vgg16_model, vgg16_gmm_model, mnist_loader, device)\n",
    ")\n",
    "vgg16_ambiguous_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(vgg16_model, vgg16_gmm_model, ambiguous_mnist_loader, device)\n",
    ")\n",
    "vgg16_dirty_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(vgg16_model, vgg16_gmm_model, dirty_mnist_loader, device)\n",
    ")\n",
    "vgg16_fashion_mnist_densities = uncertainty_confidence.logsumexp(\n",
    "    get_gmm_logits(vgg16_model, vgg16_gmm_model, fashion_mnist_loader, device)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot softmax entropy & feature density"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sb\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from matplotlib import rc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataclasses import dataclass\n",
    "\n",
    "os.makedirs(\"./pdfs\")\n",
    "os.makedirs(\"./pngs\")\n",
    "\n",
    "@dataclass\n",
    "class Results:\n",
    "    mnist: np.array\n",
    "    ambiguous_mnist: np.array\n",
    "    fashion_mnist: np.array\n",
    "    dirty_mnist: pd.DataFrame\n",
    "\n",
    "# lenet_dirty_mnist_entropies = torch.load('lenet_dirty_mnist_entropies.pt').cpu().numpy()\n",
    "def combine_dirty_mnist(mnist, ambiguous_mnist):\n",
    "    dirty_mnist = np.concatenate((mnist, ambiguous_mnist))\n",
    "    dirty_mnist_categories = np.concatenate((np.zeros_like(mnist, dtype=np.int8), np.ones_like(ambiguous_mnist, dtype=np.int8)))\n",
    "\n",
    "    df = pd.DataFrame(dict(entropy=dirty_mnist, category=dirty_mnist_categories))\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "lenet_entropy = Results(\n",
    "    lenet_mnist_entropies.cpu(),\n",
    "    lenet_ambiguous_mnist_entropies.cpu(),\n",
    "    lenet_fashion_mnist_entropies.cpu(),\n",
    "    combine_dirty_mnist(lenet_mnist_entropies.cpu(), lenet_ambiguous_mnist_entropies.cpu())\n",
    ")\n",
    "\n",
    "resnet18_sn_entropy = Results(\n",
    "    resnet18_sn_mnist_entropies.cpu(),\n",
    "    resnet18_sn_ambiguous_mnist_entropies.cpu(),\n",
    "    resnet18_sn_fashion_mnist_entropies.cpu(),\n",
    "    combine_dirty_mnist(resnet18_sn_mnist_entropies.cpu(), resnet18_sn_ambiguous_mnist_entropies.cpu())\n",
    ")\n",
    "\n",
    "vgg16_entropy = Results(\n",
    "    vgg16_mnist_entropies.cpu(),\n",
    "    vgg16_ambiguous_mnist_entropies.cpu(),\n",
    "    vgg16_fashion_mnist_entropies.cpu(),\n",
    "    combine_dirty_mnist(vgg16_mnist_entropies.cpu(), vgg16_ambiguous_mnist_entropies.cpu())\n",
    ")\n",
    "\n",
    "lenet_density = Results(\n",
    "    lenet_mnist_densities.cpu(),\n",
    "    lenet_ambiguous_mnist_densities.cpu(),\n",
    "    lenet_fashion_mnist_densities.cpu(),\n",
    "    combine_dirty_mnist(lenet_dirty_mnist_densities.cpu(), np.array([]))\n",
    ")\n",
    "\n",
    "resnet18_sn_density = Results(\n",
    "    resnet18_sn_mnist_densities.cpu(),\n",
    "    resnet18_sn_ambiguous_mnist_densities.cpu(),\n",
    "    resnet18_sn_fashion_mnist_densities.cpu(),\n",
    "    combine_dirty_mnist(resnet18_sn_dirty_mnist_densities.cpu(), np.array([]))\n",
    ")\n",
    "\n",
    "vgg16_density = Results(\n",
    "    vgg16_mnist_densities.cpu(),\n",
    "    vgg16_ambiguous_mnist_densities.cpu(),\n",
    "    vgg16_fashion_mnist_densities.cpu(),\n",
    "    combine_dirty_mnist(vgg16_dirty_mnist_densities.cpu(), np.array([]))\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "clrs = ['#1f77b4','#ff7f0e', '#2ca02c','#d62728', '#9467bd', '#8c564b', '#e377c2', '#7f7f7f', '#bcbd22','#17becf']\n",
    "\n",
    "sb.set_style('whitegrid')\n",
    "sb.set_context(\"paper\", font_scale=1, rc={\"lines.linewidth\": 2.5})\n",
    "\n",
    "rc('text', usetex=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jishnu/anaconda3/lib/python3.7/site-packages/ipykernel_launcher.py:8: UserWarning: This figure was using constrained_layout==True, but that is incompatible with subplots_adjust and or tight_layout: setting constrained_layout==False. \n",
      "  \n",
      "/home/jishnu/anaconda3/lib/python3.7/site-packages/ipykernel_launcher.py:8: UserWarning: This figure was using constrained_layout==True, but that is incompatible with subplots_adjust and or tight_layout: setting constrained_layout==False. \n",
      "  \n",
      "/home/jishnu/anaconda3/lib/python3.7/site-packages/ipykernel_launcher.py:8: UserWarning: This figure was using constrained_layout==True, but that is incompatible with subplots_adjust and or tight_layout: setting constrained_layout==False. \n",
      "  \n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_entropy(results, separate_ID=False):\n",
    "    common_kwargs = dict(stat='probability', kde=False, bins=12, binrange=[0,2.4], label=\"dummy\", legend=False, element=\"step\", alpha=0.7)\n",
    "    id_kwargs = dict(\n",
    "              hue=\"category\", multiple=\"stack\", \n",
    "              palette=[sb.color_palette()[0], sb.color_palette()[4]]) if separate_ID else dict(color=sb.color_palette()[0]) \n",
    "\n",
    "    fig, axes = plt.subplots(2, 1, sharex=True, figsize=(2.5,2.5/1.6), gridspec_kw={'height_ratios': [1, 3]}, constrained_layout=True)\n",
    "    fig.subplots_adjust(hspace=0.30)  # adjust space between axes\n",
    "\n",
    "    for ax in axes:\n",
    "        sb.histplot(data=results.dirty_mnist, x=\"entropy\", **id_kwargs,\n",
    "                    **common_kwargs, ax=ax)\n",
    "        sb.histplot(results.fashion_mnist, color=sb.color_palette()[1],\n",
    "                    **common_kwargs, ax=ax)\n",
    "\n",
    "    axes[0].set_ylim(0.4, 0.55)  # outliers only\n",
    "    axes[1].set_ylim(0, .15)  # most of the data\n",
    "\n",
    "    axes[0].spines['bottom'].set_visible(False)\n",
    "    axes[1].spines['top'].set_visible(False)\n",
    "    axes[0].set_ylabel(\"\")\n",
    "    axes[1].set_ylabel(\"Fraction\", fontsize=12)\n",
    "    axes[1].set_xlabel(\"Entropy\", fontsize=12)\n",
    "\n",
    "    axes[1].yaxis.set_label_coords(-0.04, 0.5, fig.transFigure)\n",
    "\n",
    "    d = .5  # proportion of vertical to horizontal extent of the slanted line\n",
    "    kwargs = dict(marker=[(-1, -d), (1, d)], markersize=12,\n",
    "                  linestyle=\"none\", color='k', mec='k', mew=1, clip_on=False)\n",
    "    axes[0].plot([0, 1], [0, 0], transform=axes[0].transAxes, **kwargs)\n",
    "    axes[1].plot([0, 1], [1, 1], transform=axes[1].transAxes, **kwargs)\n",
    "\n",
    "    fig.set_size_inches(2.5,2.5/1.6)\n",
    "\n",
    "    return fig, axes\n",
    "\n",
    "separate_ID = False\n",
    "\n",
    "plot_entropy(lenet_entropy, separate_ID=separate_ID)\n",
    "plt.savefig('pdfs/entropy_hist_lenet_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/entropy_hist_lenet_dirty_mnist_vs_fmnist.png', bbox_inches='tight')\n",
    "\n",
    "fig, axes = plot_entropy(resnet18_sn_entropy, separate_ID=separate_ID)\n",
    "plt.savefig('pdfs/entropy_hist_resnet18_sn_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/entropy_hist_resnet18_sn_dirty_mnist_vs_fmnist.png', bbox_inches='tight')\n",
    "\n",
    "fig, axes = plot_entropy(vgg16_entropy, separate_ID=separate_ID)\n",
    "plt.savefig('pdfs/entropy_hist_vgg16_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/entropy_hist_vgg16_dirty_mnist_vs_fmnist.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 180x112.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_density(results: Results, binrange, separate_ID=False):\n",
    "    clrs = ['#1f77b4','#ff7f0e', '#2ca02c','#d62728', '#9467bd', '#8c564b', '#e377c2', '#7f7f7f', '#bcbd22','#17becf']\n",
    "    sb.set_style('whitegrid')\n",
    "\n",
    "    plt.figure(figsize=(2.5,2.5/1.6))\n",
    "    plt.tight_layout()\n",
    "\n",
    "    range = dict(bins=30, binrange=binrange, element=\"step\", fill=True, alpha=0.7)\n",
    "    kw_separate_id = dict(hue=\"category\", multiple=\"stack\",\n",
    "                hue_order=[1, 0],\n",
    "                palette=[sb.color_palette()[4], sb.color_palette()[0]]) if separate_ID else dict(color=sb.color_palette()[0])\n",
    "\n",
    "    sb.histplot(data=results.dirty_mnist, x=\"entropy\", **kw_separate_id,\n",
    "                stat='probability', kde=False, **range, label=\"dummy\", legend=False) # 'Dirty-MNIST (In-distribution)')\n",
    "    sb.histplot(results.fashion_mnist, color=sb.color_palette()[1],\n",
    "                stat='probability', kde=False, **range, label=\"dummy\", legend=False) #, label='Fashion-MNIST (OoD)')\n",
    "\n",
    "\n",
    "    plt.xlabel('Log Density', fontsize=12)\n",
    "    plt.ylabel('Fraction', fontsize=12)\n",
    "\n",
    "\n",
    "plot_density(lenet_density, binrange=[-250, 100], separate_ID=separate_ID)\n",
    "plt.savefig('pdfs/logdensity_hist_lenet_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/logdensity_hist_lenet_dirty_mnist_vs_fmnist.png', bbox_inches='tight')\n",
    "\n",
    "plot_density(resnet18_sn_density,  binrange=[-1500, 2500], separate_ID=separate_ID)\n",
    "plt.axvline(1250, color=clrs[3], linestyle='dashed', linewidth=2.5)\n",
    "plt.savefig('pdfs/logdensity_hist_resnet18_sn_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/logdensity_hist_resnet18_sn_dirty_mnist_vs_fmnist.png', bbox_inches='tight')\n",
    "\n",
    "plot_density(vgg16_density, binrange=[-1500, 3000], separate_ID=separate_ID)\n",
    "plt.savefig('pdfs/logdensity_hist_vgg16_dirty_mnist_vs_fmnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/logdensity_hist_vgg16_dirty_mnist_vs_fmnist.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABMMAAAGiCAYAAADqeQFjAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAAgAElEQVR4nOzdd1jUx/o28HvpvanBAoIVFbuJiIqJsXfsscfYIrbE5MQWj5oYE5OYaFDjLzEWbAGNBTGKoqigIMFKtSAiwYYU6WVh3z9493sWgWXZwoLcn+vKdWZ3Z2eeXcbjxePMMyKJRCIBERERERERERFRHaCj7QCIiIiIiIiIiIiqC5NhRERERERERERUZzAZRkREREREREREdQaTYUREREREREREVGcwGUZERERERERERHUGk2FERERERERERFRnMBlGRERERERERER1hp62A6iqoqIixMXFITIyElFRUYiMjERsbCzy8vIAAAsXLsSiRYvUPm9OTg68vb3h7++PhIQEZGVloX79+ujUqRPGjh0LNzc3tc9JRERERERERETqVeuSYZ988gnOnj1brXNGR0dj8eLFSExMLPX8kydP8OTJE5w+fRojRozAhg0bYGBgUK2xERERERERERGR4mpdMqyoqKjUYysrK1hZWeHRo0camS8pKQlz5szBy5cvAQAdO3bEyJEjYW1tjXv37sHb2xvp6ek4efIkRCIRfvjhB43EQUREREREREREqqt1ybCOHTuiRYsWcHZ2hrOzM+zt7XH06FGsWLFCI/Nt2LBBSISNHTsW69evh47O/0qtTZw4EVOnTsWTJ0/g6+uLYcOG4b333tNILEREREREREREpJpalwz7+OOPq22u2NhYBAQEAAAaN26MNWvWlEqEAUCTJk2wdu1azJ07FwDg6enJZBgRERERERERUQ3F2yTl+Pvvv4X2hAkTYGhoWG6/Pn36wMHBAQAQGRlZprYYERERERERERHVDLVuZ1h1Cg4OFtrybosUiUTo3bs3EhISAACXL1/GlClTFJrj+vXrqgVJRERERERERERldOvWrdznmQyrQHFxMeLi4gAAenp6aNOmjdz+7du3F9r379+v0lwV/XBqm5iYGLRt21bbYVAtxjVE6sB1ROrAdUSq4hoideA6InXgOiJ1qI3rSN7mIx6TrMCzZ8+Ql5cHALC1tYWenvy8YePGjYW2pm62JCIiIiIiIiIi1TAZVoGMjAyhbWVlVWl/2T6y7yUiIiIiIiIiopqDybAK5OTkCO2KCufLMjIyEtrZ2dkaiYmIiIiIiIiIiFTDmmE1QExMjLZDUIu8vLw35rOQdnANkTpwHZE6cB2RqriGSB24jkgduI5IHd60dcRkWAVMTEyEdn5+fqX9pfXFAMDU1LRKc9W2InQVqY0F9ahm4RoideA6InXgOiJVcQ2ROnAdkTpwHZE61MZ1xAL6SrCwsBDa6enplfaX7SP7XiIiIiIiIiIiqjmYDKtAw4YNhTpgz58/h1gsltv/yZMnQtvR0VGToRERERERERERkZKYDKuAjo4OWrRoAQAQi8WIjY2V2z8yMlJot2rVSqOxERERERERERGRcpgMk8PNzU1oBwcHV9hPIpGUer1Pnz4ajYuIiIiIiIiIiJTDZJgcQ4YMEdre3t4VFtK/fPkyEhISAADt27eHvb19tcRHRERERERERERVU2eTYcuXL4eTkxOcnJzg6elZbp82bdqgf//+AEpqgn311VcoLi4u1efJkydYu3at8HjRokUai5mIiIiIiIiIiFSjp+0AqioxMRFHjhwp9dzdu3eFdmhoaJli94MGDUK7du2Umm/lypW4desWXr58iSNHjuD+/fsYNWoUrKyscO/ePfz555/CTZIjRozAe++9p9Q8RERERERERESkebUuGfbkyRPs2LGjwtfDw8MRHh5e6jkHBwelk2FNmjTB77//jsWLFyMxMRG3b9/G7du3y/QbPnw4NmzYoNQcRERERERERERUPWpdMkwb2rVrB19fX3h7e8Pf3x+PHj1CdnY26tWrh06dOmHs2LEsmk9ERERE1aa4uBjZ2dnIzMyssK4t1X4SiQTx8fHaDoNqOa4jUofqWkeGhoYwNzeHqakpdHQ0V9lLJJFIJBobnSp1/fp1dOvWTdthqEXyq2ToGTK/KqWvow8zAzNth1GrxMTEoG3bttoOg2o5riNSB64jUpUm11BRURESExNhbGwMCwsLGBkZQSQSaWQu0q7c3FwYGxtrOwyq5biOSB2qYx1JJBLk5eUhIyMDubm5sLe3h66urtLjycu3MHNBaiPRkeCzS59pO4waY9O7m7QdAhEREb1hiouLkZiYiPr168PMjP/oRkREbw6RSARjY2MYGxsjKysLiYmJaNq0qUZ2iNXZ2ySJiIiIiGqb7OxsGBsbMxFGRERvNDMzMxgbGyM7O1sj4zMZRkRERERUS2RmZsLCwkLbYRAREWmchYUFMjMzNTI2k2FERERERLVEfn4+jIyMtB0GERGRxhkZGWnskhgmw4iIiIiIahEWyyciorpAk3/fMRlGRERERERERER1BpNhRERERERERERUZzAZRkREREREREREdQaTYUREREREREREVGcwGUZERERERERERHUGk2FERERERET0xoqMjETbtm3h5OSEiIiIMq9fu3YNTk5OcHJygqenZ7XGVlRUhEGDBsHJyQmbNm2q1rmJ6jI9bQdARERERERU2zg5OZV6PHXqVKxevVqh937zzTfw8vIq9dzdu3fL9EtKSsKwYcOExwYGBvD390fjxo3ljv/bb78JiZVvv/0WY8aMKdNn+fLlOHbsmNw+Ui9fvsTx48dx9epV3Lt3DxkZGSguLoapqSkaN26M5s2bo0OHDujRowfatGkjvG/atGkICwuTG6siunfvjn379in9/q+//hrFxcXo27cvOnTooNQYst+XLB0dHZiamsLMzAw2NjZwcnKCs7Mz3nvvPdjZ2VU6rq6uLubPn49ly5Zh9+7dGDduHBwcHJSKkYgUx2QYEREREdEbKqsgC4XFhdoOo9ro6+jDzMBMK3P7+flh2bJlMDAwkNuvsLAQJ0+eVGqOgoICbN26FRs2bFDq/cr4888/sXHjRuTk5JR5LT09Henp6YiOjoafnx8AYM2aNZg8eXK1xVeZs2fP4tatWwCARYsWqX384uJiZGZmIjMzE0+fPkVUVBSOHj2K9evXo1evXli0aBE6d+4sd4wRI0bg119/xaNHj7Blyxb89NNPao+TiEpjMoyIiIiI6A1VWFyIzy59pu0wqs2md6v/mJmenh7EYjHS09MRGBiIQYMGye1/8eJFpKWllXpvVRw/fhyzZs1CixYtlI5ZUV5eXvjmm2+Ex23btkXfvn3h4OAAIyMjZGZm4sGDB7hx4wYiIiIgkUhQXFws9F+yZAnS09MrHH/BggVCe9u2bRX2s7KyUvozSI89urm5wdnZudw+Li4u5e7Mq8i0adPQo0cP4XFubi4yMjLw77//4tatW7h16xaKi4sRHByMkJAQzJs3D0uWLKlwPF1dXcyePRtffvklTp8+DQ8PD7Rs2VLheIio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xrhx4/D3338jPz+/wn5isRg///wzQkJCAJTcPDl8+HCV51dVz549hfadO3eqde7ExER88cUX+Pbbb4XnFi9ejC5dush9X2ZmJuLj4wGUHDvV1dXVaJxEdZmetgMgIiIiIiIi1UyYMAG7du1CUlIScnJy1DJmREQEPv30U5iZmeGdd95Bp06d0LBhQ5iYmCArKwsPHjzA2bNn8e+//wrvmTNnTo3Y0fTuu+9CX18fhYWFCAsLw7hx49Q2dnR0tFCnDQDy8/ORkZGBx48f4/bt27h586ZwNFNXVxdz586Fh4dHpeNeu3YNEokEANC/f3+1xUtEZTEZRkREREREVMsZGBhg8eLFWLZsmVrGc3BwgImJCXJycpCVlYXAwMBSRyFfZ2JigoULFwr1y7TNysoK7777LgICAnDu3Dnk5ubC2NhYLWPv27ev0ps7RSIRXF1dsWTJEnTu3Fmhcf38/ACUHLPVVI05IirBZBgREREREdEbYOTIkdi5cyfu37+v8ljjx4/HyJEjERoairCwMERHRyMhIQGpqakoKCiAkZERbGxs0KpVK7i6umLYsGGoV6+eGj6F+kyePBkBAQHIyclBQEAARowYofY5RCIRTE1NYWZmBhsbG7Rp0wbOzs547733YGdnp/A40oQjUPJzlL2AgYjUTySR7sMkrbh+/Tq6deum7TDU4kXmCyy/ulzbYdQYm97dBGsja22HUavExMSgbdu22g6DajmuI1IHriNSlabWUHx8PJo1a6Zw/6yCLBQWF6o9jppKX0cfZgZvThJBnbuZ6qqRI0fi7t276N27N/744w9th1OhI0eOYNWqVRCJRPDz81PrUVOuI1IHba2jqv69J0tevoU7w4iIiIiI3lBvUmKISBmLFi3CwoULERwcjMjISLRv317bIZVRVFSEnTt3AgCGDh1aI2quEb3peJskERERERERvZEGDBgg3OK4detWLUdTPj8/P8THx0NfXx9LlizRdjhEdQKTYURERERERPTGWr16NXR0dBAYGIiIiAhth1NKUVERfv31VwDAzJkz4eDgoOWIiOoGHpMkIiIiIiKiN5azszNiYmK0HUa5dHV1cebMGW2HQVTncGcYERERERERERHVGUyGERERERERERFRncFkGBERERERERER1RlMhhERERERERERUZ1RKwvoSyQSnD59GidOnEBMTAxSU1Nh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mD17NjZt2qTyWLa2tggICEBsbCxCQkJw8+ZNxMfH49mzZ8jOzoa+vj7Mzc3h4OCAjh07YsiQITWuxlXfvn3RuHFjPHnyBL6+vmpLhr3O0NAQZmZmMDc3R7NmzeDs7Ix33nkHLi4uyMvLU/j/86T1AS0tLTFs2DCNxKoqkaS8w9VUba5fv45u3bppOwy1eJH5AsuvLtd2GDXGpnc3wdrIWtth1CoxMTFo27attsOgWo7riNSB64hUpak1FB8fX+ENdeUpyBWjqKhY7XHUVLq6OjAwfnP+vT83NxfGxsbaDqPaXbhwAfPnzwcArFixQu4tl1S5urqO3jR79uzBt99+C11dXVy4cAENGzas1vkVXUdZWVlwc3NDTk4O5syZg88//1yleav6954sefmWN+dvCiIiIiIiKuVNSgxR3SEtVA+gykdRid5UH3zwAXbu3Ink5GTs3LkTX375pbZDKpeXlxdycnJgamqKjz76SNvhVIi3SRIREREREVG1eL1GmKzi4mL8+OOPCA4OBlByiyF36RKVMDIywsKFCwEA3t7eeP78uZYjKisrKwt79+4FUFL3zcbGRssRVYz/VERERERERETV4sMPPxRqcLVu3RqWlpbIz8/Hw4cPcebMGaHGlr6+PtatW6fdYIlqmAkTJsDHxwdRUVH47bffsHr1am2HVIqXlxfS09NhZ2eH2bNnazscuZgMIyIiIiIiomqTkJCAhISECl+3srLC5s2b0a5du2qMiqjm09HRKXWRR03j4eEBDw8PbYehECbDiIiIiIiIqFr8/vvvuHDhAiIiIvDy5UukpaWhsLAQVlZWaNGiBdzc3PDBBx/AzMxM26ES0RuMyTAiIiIiIiKqFr169UKvXr20HQYR1XEsoE9ERERERERERHUGk2FERERERERERFRnMBlGRERERERERER1BpNhRERERERERERUZzAZRkREREREREREdQaTYUREREREREREVGcwGUZEREREVItIJBJth0BERKRxmvz7jskwIiIiIqJawtDQEHl5edoOg4iISOPy8vJgaGiokbGZDCMiIiIiqiXMzc2RkZGh7TCIiIg0LiMjA+bm5hoZW09dAyUnJyMkJARxcXF49eoV8vPzK32PSCTChg0b1BUCEREREdEbzdTUFCkpKcjKyoKZmZm2wyEiItKIrKws5ObmokGDBhoZX+VkWEZGBjZs2AA/Pz8UFRVV+f1MhhERERERKUZHRwf29vZITExEdnY2LCwsYGRkBJFIpO3QiIiIVCKRSJCXl4eMjAzk5ubC3t4eOjqaOdCoUjIsLy8PM2bMQGxsrFKFzfiXNhERERFR1ejq6qJp06bIzs5GWlqaQicyqHbKzc2FsbGxtsOgWo7riNShutaRoaEhzM3N0aBBA40lwgAVk2FeXl6IiYmBSCSChYUFJk+ejB49esDW1hYGBgbqipGIiIiIiGTo6OjA3NxcY7VUqGaIiYlBs2bNtB0G1XJcR6QOb9o6UikZdubMGQCAlZUVDh8+DDs7O7UERUREREREREREpAkq7Tl79OgRRCIRpkyZwkQYERERERERERHVeGo5gNmiRQt1DENERERERERERKRRKiXDmjRpAgDIyclRSzBERERERERERESapFIybODAgZBIJAgLC1NXPERERERERERERBqjUjJs6tSpeOutt3Dq1ClERESoKyYiIiIiIiIiIiKNUCkZZm1tje3bt8PS0hKzZ8/GyZMnIZFI1BUbERERERERERGRWump8uYVK1YAAFq1aoXQ0FB88cUX+O6779C+fXtYW1tDJBLJfb9IJMKGDRtUCYGIiIiIiIiIiEhhKiXDjh07JiS8pP+bmpqKy5cvKzwGk2FERERERERERFRdVEqGAVDpWGRlO8fkzXn69GmcOHECMTExSE1NhZWVFVq0aIHhw4dj9OjR0NNT+aOVUVRUhLNnz+Ls2bOIjIzEy5cvIRKJUL9+fTRt2hQuLi4YMGAAHB0d1T43ERERERERERGpTqWM0fnz59UVh8JevXqFxYsXIzQ0tNTzycnJSE5ORmhoKA4dOoStW7eicePGaps3Ojoaq1atQnR0dJnXsrOzkZCQgKCgILx48QKrVq1S27xERERERERERKQ+KiXDmjRpoq44FFJQUAAPDw+Eh4cDABo1aoQJEybAwcEBz549w19//YW4uDhERUVhzpw58Pb2hpmZmcrzXr9+HXPnzkVWVhYAoHv37nBzc0OjRo2gq6uL5ORkREVF4dKlSyrPRUREREREREREmqP+s4QadOjQISER5uzsjN27d8PS0lJ4ferUqfDw8EBwcDAePHiAbdu2YdmyZSrN+fLlS3h4eCArKwvW1tbYsmULXFxcyu1bVFSElJQUleYjIiIiIiIiIiLN0dF2AIoS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uZAbb7zR2E5MTLRY9tChQ8Z29+7d6xXPw8ND3bp1k1T2rfyRI0dsitnQ7Uf1nP05ZGRkaPr06UpNTZUk3XvvvXruuecckiCx9K08bOPsflSb2j77xt5+d9BYPoOEhAT99NNPksoeFz9o0CC71i9V/ha94h1xaFoYF8ERGBehITAugrVcaVxEMsyFDB482Njes2ePxbLlc3wlaciQIfWOWfFcSzHNZnOl40OHDq1SxhntR1XO/BwyMzM1Y8YM4wIbFham6Ohoi4u+1ldhYaG+++4742e+ubKvxvzv+dy5czpx4oSksil1HTt2rFKmMbffXTSWz2DDhg3G9n333eeQ69HXX39tbJevk4GmiXER7IlxERoC4yLUhSuNi0iGuZABAwaoTZs2kqS9e/fq2LFj1Za7cOGCtm7dKqlsfYDhw4fXO+bo0aON7djY2BoXVdy1a5fxjVafPn2MW20rGjFihPF0iX/961+6cOFCtXUlJycrPj5eknTttddWmlMM2zmjH0ll30jNmDFDx48flyTdc889Wrp0qTw9PW2qtyZvvfWWcdttcHCwunTp4pA47spZ/cgaMTExMpvNksrWJKhufSmuR87XGPrQ5cuXFRcXJ0kymUwaP3683eou969//ctYD6Nly5bq16+f3WOg4TAugr0wLkJDYVwEa7nauIhkmAvx8vLSnDlzJJV947ho0SLl5ORUKlNQUKBFixYpPz9fkjR16tRKc3IrevzxxxUaGqrQ0FCtWLGi2jI9evTQiBEjJJXND//b3/6m0tLSSmXS0tIqrWswf/78autq06aNpkyZIknKz8/X448/XmUQmZOTo0WLFhkX7Llz5zpsUOCunNGPLl26pIceekhHjx6VJA0fPlwvv/yysVhnXbz66qtKSUmxWGbdunVavny58XP564X9OKMfvfTSS5XWqbhaSUmJli9frtjYWGNfTZ891yPnc0Yfutpnn32mvLw8SWV/IFSXsKjJu+++W+kui+p8/vnn+vOf/2z8/NBDD8nHx8fqGGhYjItgD4yLYA+Mi2ArxkVS3a+oaNQmT56s7du368CBA0pMTNS4ceM0adIkdenSRenp6Vq/fr3xCzEkJERRUVE2x3zyySf17bff6vz581q/fr2OHTumcePGKSAgQMnJyfrggw+Meehjx47VsGHDaqxr3rx52r17t3788Uft2rVLERERmjBhgtq1a6fU1FTFxsbqzJkzksr+AU6cONHm9qOqhu5Hs2bNMtYfuO666zRmzBh9+eWXFs9p3rx5pVu2y3322WdatmyZevXqpdtuu03dunVT69atVVRUpJMnT2r79u3G4FIqW3sjIiLCpvajeg3dj9atW6fXX39dffv21a233qrg4GC1atVKV65cUUpKiuLi4io9Kn7OnDkWv7HkeuR8zvidVpEtC8TGx8fr+eefV9euXTVw4ECFhIQoMDBQZrNZp0+f1s6dO3Xw4EGj/IABAzR79my7tR3/c+rUKa1fv77Svoq/B+Lj46ssdj9y5Ej16tWrXvEYF7mmhuxHjItcV0P2I8ZFrqmhf6dV5GrjIpJhLsbb21uvvPKKFixYoPj4eJ05c0bLli2rUq53796KiYmxy4J0QUFBev3117VgwQKdOnVK3333XbVZ3zFjxmjx4sUW62rdurVef/11zZ8/X0lJSUpJSVF0dHSVcoMGDdLy5cuN23VhXw3djype+M6dO6dHH3201nOCgoK0c+fOGo8nJSUpKSmpxuNeXl6aNWuW5s2bV7fGwmrOuB6ZzWYlJCQoISGhxjItWrTQH/7wB02bNs1iXVyPnM8ZfajcyZMnjTUrWrVqpZEjR9arnp9++slY76c6JpNJEydO1BNPPCFvb+96xYBlaWlpeu2112o8fuDAAR04cKDSvi5dutT7DwfGRa6pIfsR4yLX1dDXI8ZFrqeh+1A5VxwXkQxzQf7+/nr77bcVFxenzZs3KykpSVlZWfL391dISIjCw8M1fvz4et1qXZNevXppy5Ytio2N1bZt23TixAnl5eWpbdu2uuWWWxQZGVnt4rDV6dSpkz788ENt2rRJn376qY4fP66cnBwFBgaqV69eGjdunEaPHu2Qp+jgf5zRj+xhyZIlOnDggA4ePKjjx48rKytL2dnZKi0tNdp+22236f7771e7du2c3VyX15D96M0331RCQoIOHjyoEydOKDMzU9nZ2fL09FRAQIBCQ0M1cOBARUREVHqEuCVcj5zPWdeijRs3GlM9wsLC1Lx58zqd//jjj+uuu+7St99+qyNHjigzM1NZWVkqLi5W69atFRwcrH79+mn8+PEsmu+CGBehsWBc5L4YF8GeXHFcZDKXvyIAAAAAAADAxbGAPgAAAAAAANwGyTAAAAAAAAC4DZJhAAAAAAAAcBskwwAAAAAAAOA2SIYBAAAAAADAbZAMAwAAAAAAgNsgGQYAAAAAAAC3QTIMAAAAAAAAboNkGAAAAAAAANwGyTAAAAAAAAC4DS9nNwAAAMCVhIaG1vmcHj16aPPmzQ5oTZmff/5ZmzZtkiTdfvvtGjBggMNiAQAANHbcGQYAAODiTp8+rZiYGMXExOi///2vs5sDAADgVNwZBgAA4CArV660qpyfn5+DWwIAAIByJMMAAAAcZMSIEc5uAgAAAK7CNEkAAAAAAAC4DZPZbDY7uxEAAACuouIC+kePHq13Pfv379eDDz4oSZo3b57mz5+vtLQ0vfvuu/riiy+Unp4uLy8vhYSEaOzYsZo0aZK8vLxqrKM2Fdu6YsUKxcTESJLeffddDRgwQPv27dNHH32kb7/9VhkZGSosLNSOHTvUqVMn4zyz2ay4uDh99tln+v7773XhwgX5+PioQ4cOGjRokCZPnqzg4OA6veajR49qzZo12rdvn86dOydfX1/16NFD999/v8aMGVNtPRMnTtR3332nZs2a6YsvvtA111xj8bWfP39ew4YNU1FRkW6++WZ99NFHVr1nAACgaWKaJAAAQBOwa9cu/f73v9fFixcr7T948KAOHjyoHTt26LXXXpO3t7dd45rNZv3tb3/T2rVrLZY7f/685s2bp4MHD1baX1hYqEuXLik5OVlr167VggULNHv2bKtif/zxx/rLX/6iwsJCY19BQYH27dunffv26ZNPPtE//vEP+fj4VDpv0qRJ+u6771RUVKRNmzZp1qxZFuNs3LhRRUVFksoSaQAAwLWRDAMAAGjkDh8+rDfffFNms1mTJk1S37595e3trUOHDumDDz5Qfn6+vvrqK7366qt65JFHjPO6d++ulStXKjk5WcuXL5ckhYWFKTw83OrYb775pnbt2qVrr71WERER6t69u0pKSvT9998bibfc3FxNnTpVJ06ckCRde+21ioyMVPfu3XX58mXt3btXn332mYqKivTSSy+ptLRUc+bMsRj3hx9+0D//+U9JUmRkpG677TZ5eHjohx9+0IYNG5Sfn68vvvhCjz32mP7xj39UOjc8PFzR0dG6ePGi1q9fbzEZZjabtX79eklSy5Yt6/TeAACApolkGAAAQCO3Y8cOdezYUW+99ValaYbh4eEaPXq0Jk+erOLiYq1du1Zz5841klRt2rTRiBEj1KpVK+OcG264oU4L++/atUv9+vXTqlWrKj31MiIiwtheunSpkQjr16+f/vnPf1aKOWHCBEVGRioqKkoFBQVasWKFhg0bph49etQY98svv1TLli21evVq/b//9/+M/ePGjdO0adP0wAMP6Ny5c9q2bZu2bdumkSNHGmWaN2+ucePG6b333tOJEye0f/9+DRgwoNo4+/fvV2pqqiRpzJgx8vX1tfq9AQAATRML6AMAADhIaGioVf9t3Lix1rqWLl1a7XpbN998s0aPHi1JysnJ0ffff2/X1+Dr66u///3vlRJhFWVmZhrt9/Pz0/LlyyslwsoNHjzYuGutuLhYb7zxRq2x//jHP1ZKhJULDg7W888/b/y8evXqKmV+9atfGduW1gCreGzChAm1tgkAADR9JMMAAAAauV69eql///41Hr/jjjuM7ePHj9s19j333KN27drVePyLL74w1vSKiIjQtddeW2PZKVOmqGXLlpKknTt3qqSkpMay/v7+Gj9+fI3Hhw4dqpCQEEkyFvWvKCQkxHjPtm/frpycnCp1ZGdna/v27ZLK3uObbrqpxngAAMB1ME0SAADAQVauXGlVuV69elk8fsstt1g8XjFZdfUC+7aylISTVOlOtF/84hcWy7Zo0UL9+vXTrl27lJeXp+PHj1d6+mZF/fr1q/VhAHfccYeR/Pvhhx909913Vzo+adIkHThwQAUFBdq8eXOVJ2tu3rzZSORxVxgAAO6DZBgAAICD1GVtLksCAwMtHq+YNCooKLBLzHLXXXedxeMV78iqbhrn1YKDg7Vr1y7j3JqSYV26dKm1rs6dOxvb586dq3J81KhRev7555Wdna2PPvqoSjKsfOH8Fi1aaOzYsbXGAwAAroFpkgAAAI2ch4fzhmzNmze3eDwvL8/Ytmbx+YplKp5b17hX15Wfn1/luLe3tzHVMjk5Wd99951x7Ntvv1VycrIkafTo0dWucwYAAFwTyTAAAADUW/kaYFL1CamrVSxT8dyrXblypU511ZSImzRpkkwmkyTpww8/NPZX3GaKJAAA7oVkGAAAAOqt4oL5qamptZavWMbSFExr6jp58mStdQUHBxsPGNi6davy8vKUm5uruLg4SVL37t1166231hoLAAC4DpJhAAAALq7iNEuz2WzXum+++WZj+6uvvrJY9sqVK/rmm28kld0V1q1btxrLJiQkqKioyGJ9+/fvN7YtPQly0qRJksruJPv000/16aefGneVcVcYAADuh2QYAACAi6s4hfDy5ct2rXvYsGHGAv4ff/yxLly4UGPZdevWKTc3V5I0fPhweXp61lg2OztbmzZtqvH4nj17dOzYMUlS3759K92hdrURI0YYxz/88ENjiqS3t7fGjRtX43kAAMA1kQwDAABwcZ06dTK2ExMT7Vp3mzZtFBkZKUm6ePGiFi5caCS8Ktq3b5+WLVsmSfLy8tLDDz9ca90vvviivv/++yr7T548qSeffNL4eebMmRbradasmdHGH374QYcOHZIk3XPPPQoICKi1HQAAwLV4ObsBAAAArurzzz+3uuydd96pZs2aOaQd/v7+6tWrl5KSkrR//3499dRTGjhwYKUF7IcOHVrv+v/whz9o3759OnHihP773/8qLCxMkZGRCgkJ0eXLl7Vv3z5t3bpVpaWlkqT58+erR48eFuu88847tXfvXk2ZMkX33Xef+vfvLw8PD/3www9av369Mc1x5MiRGjlyZK1tnDBhglatWmW0Qfrf9EkAAOBeSIYBAAA4yG9/+1ury3799dcOS4ZJ0sKFCzV37lyVlJQoNjZWsbGxlY4fPXq03nX7+flpzZo1mjdvnr799ludPXtWr7zySpVyXl5eWrBggX7zm9/UWudNN92k8PBw/fnPf9ZHH32kjz76qEqZO++8U0uXLrWqjZ06ddLgwYO1a9cuSb4kEbUAAAGnSURBVGUL699+++1WnQsAAFwLyTAAAAA3cOedd2rdunV699139e233+r8+fO6cuWK3eq/9tpr9cEHHyguLk5bt27VDz/8oMzMTHl7e6tDhw4aNGiQpkyZouDgYKvrHDdunHr06KH33ntP8fHxOnfunFq0aKEePXro/vvv19ixY+vUxkGDBhnJMBbOBwDAfZnM9n6kEAAAAFAP+/fv14MPPihJmjdvnubPn2/X+idPnqyEhAQ1a9ZMX375pdq2bWvX+gEAQNPAAvoAAABweUePHlVCQoKksqdLkggDAMB9kQwDAACAy1uxYoWx/cADDzixJQAAwNlYMwwAAAAuJzU1VampqcrNzdXnn3+uf//735LK1g3r16+fk1sHAACciWQYAAAAXM6WLVsUExNTaV9AQICeeeYZJ7UIAAA0FiTDAAAA4LI8PDzUrl079e/fX4888oiuv/56ZzcJAAA4GU+TBAAAAAAAgNtgAX0AAAAAAAC4DZJhAAAAAAAAcBskwwAAAAAAAOA2SIYBAAAAAADAbZAMAwAAAAAAgNsgGQYAAAAAAAC38f8BCpPxXMzwC3kAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1440x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# LeNet entropy plots Figure 1\n",
    "sb.set_style('whitegrid')\n",
    "plt.rcParams[\"figure.figsize\"] = (20, 6)\n",
    "plt.rcParams[\"legend.loc\"] = 'upper right'\n",
    "\n",
    "sb.histplot(resnet18_sn_mnist_entropies.cpu().numpy(), color=clrs[2], \n",
    "            stat='probability', kde=False, bins=15, line_kws = {'linewidth': 8}, label='MNIST (iD)')\n",
    "sb.histplot(resnet18_sn_ambiguous_mnist_entropies.cpu().numpy(), color=clrs[4], \n",
    "            stat='probability', kde=False, bins=15, line_kws = {'linewidth': 8}, label='Ambiguous-MNIST (iD)')\n",
    "\n",
    "plt.xticks(fontsize=30)\n",
    "plt.yticks(fontsize=30)\n",
    "plt.xlabel('Entropy', fontsize=30)\n",
    "plt.ylabel('Fraction', fontsize=30)\n",
    "plt.legend(fontsize=30)\n",
    "plt.savefig('pdfs/entropy_hist_resnet18_sn_dirty_mnist_vs_ambi_mnist.pdf', bbox_inches='tight')\n",
    "plt.savefig('pngs/entropy_hist_resnet18_sn_dirty_mnist_vs_ambi_mnist.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Calibration Plot for Dirty-MNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "from metrics.classification_metrics import test_classification_net\n",
    "from metrics.calibration_metrics import reliability_plot\n",
    "from utils.temperature_scaling import ModelWithTemperature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Ot3JFBERqWeSzW6Yc9s6XD/A7EZgKycOSOokhUwREZF6xmyGiDWOry4f9xwKmVIuPS4XEREREadTyBQRERERp9PjchERkVouOTn/EbcjAgJA+/pLTVDIFBERqeXMZoiIcKzuuHEKmVIz9LhcRERERJxOIVNEREREnE4hU0REREScTiFTRERERJxOIVNEREREnE4hU0REREScTlsYiYiI1HZWK1hsDtY1oXtKUhMUMkVERGo7qxXOXHCwbnMUMqUm6KdORERERJxOIVNEREREnE4hU0REREScTiFTRERERJxOIVNEREREnE4hU0REREScTiFTRERERJxOIVNEREREnE4hU0REREScTiFTRERERJxOIVNEREREnE4hU0REREScTiFTRERERJxOIVNEREREnE4hU0RERESczqOmByAiIlKn5FrAanW8vpsbeOqfZ3F9+ikWERFxouSLYI41O1w/IOw6Als5cUAiNUQhU0RExInMZohY4/idzHHPoZApdYLmZIqIiIiI0ylkioiIiIjTKWSKiIiIiNMpZIqIiIiI09kdMi9fvlwV4xARERGROsTukNmvXz/mzp3L4cOHq2I8IiIiIlIH2B0yr169yqZNm3jssccYMmQI77//PqmpqVUxNhERERFxUXaHzI4dO2Kz2bDZbPz6668sWrSI/v3788wzz3Do0KGqGKOIiIiIuBi7N2PfsmULP/74I+vWrWPHjh1kZWWRk5PD9u3b2b59O0FBQYwaNYqHHnqIZs2aVcWYRUREnCY5OX8DdUcEBEBgoHPHI1JXOHTiT9euXenatSvz589n69atrF+/np9++gmA06dP8+abb/Kvf/2LgQMHMmrUKPr37+/UQYuIiDiL2QwREY7VHTdOIVOkNJXawsjHx4cxY8awfv16Nm3axKOPPoqfnx82mw2LxcLnn3/OlClTGDhwIMuXL+f8+fPOGreIiIiI1GJO2yczNDSUF154gQMHDrBw4UJ69uxpzN1MTExk6dKlDBw4kCeeeII9e/ZgtTp+rquIiIiI1G5O34zdy8uLkSNHsnr1anbs2MGoUaMAsNls5OXlsW/fPqZNm8bAgQN59913yczMdPYQRERERKSGVdmJP9999x3Lly9n69atmEwmTCYTgHF3MykpiTfffJNBgwaxe/fuqhqGiIiIiNQAhxb+lMZsNhMZGcmGDRs4deoU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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for LeNet\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(lenet_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"lenet\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Before temperature - NLL: 0.282, ECE: 0.011\n",
      "Optimal temperature: 1.100\n",
      "After temperature - NLL: 0.280, ECE: 0.013\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApkAAAIICAYAAAAllfW0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAAgAElEQVR4nOzdeVxVdeL/8dcFFEFQwRR3LDNUzLJUMrcyy0ZNrZSyTHMatVzLarScyprJtMnJxmVM51eTWmgq5l5mmkuKJZYNiEsUpiKKsi8il3t/fzCcL8h6L5flwvv5ePB4HO79bJcj+vac8/l8TFar1YqIiIiIiAO5VPUARERERKTmUcgUEREREYdTyBQRERERh1PIFBERERGHU8gUEREREYdTyBQRERERh1PIFBERERGHc6vqAdgqJyeH6OhoIiIiiIyMJCIighMnTnD16lUApkyZwtSpUx3eb0ZGBmvXruWrr77izJkzpKWlccMNN3Dbbbfx6KOP0qdPH7vaDQ8Pd/BIRURERCrOnXfeWaZyThcyn3/+eXbu3FmpfR4/fpxp06Zx9uzZAq/HxsYSGxvLjh07eOihh5g7dy5169a1uf2ynqzyiIqKomPHjhXej9hG56X60rmpnnReqi+dm+rJ0efFlotjThcyc3JyCnzfqFEjGjVqRExMTIX0d/78ecaPH8/ly5cB6NKlC0OHDsXHx4dTp06xdu1akpKS2LJlCyaTib///e8VMg4RERERZ+J0IbNLly60a9eOwMBAAgMDad26NaGhobzyyisV0t/cuXONgPnoo4/yt7/9DReX/3uU9bHHHmP06NHExsayefNmBg8ezD333FMhYxERERFxFk4XMp999tlK6+vEiRPs2rULgBYtWvDGG28UCJgALVu2ZM6cOUyYMAGARYsWKWSKiIhIrafZ5SXYvn27cRwcHIy7u3uR5fr27Yu/vz8AERERhZ7dFBEREaltFDJLcODAAeO4pNnjJpOJ3r17G9/v27evQsclIiIiUt0pZBbDYrEQHR0NgJubGx06dCixfOfOnY3j06dPV+jYRERERKo7hcxixMXFGWtv+vn54eZW8uOrLVq0MI4raqa7iIiIiLNQyCxGSkqKcdyoUaNSy+cvk7+uiIiISG3kdLPLK0tGRoZxXNyEn/zq1atnHKenp9vUV1RUlE3l7XH16tVK6Udso/NSfencVE86L9WXzk31VJXnRSGzGqiMHRK0E0P1pPNSfencVE86L9WXzk31VJU7/uh2eTE8PT2N46ysrFLL5z2/CVC/fv0KGZOIiIiIs1DILEaDBg2M46SkpFLL5y+Tv66IiIhIbaSQWYxmzZoZz1levHgRs9lcYvnY2FjjuG3bthU5NBEREZFqT89kFsPFxYV27doRGRmJ2WzmxIkTBdbCvF5ERIRx3L59+8oYosFisZCenk5qamqxt/atViu//fZbpY5LSqfzUn1Vxblxd3fH29ub+vXrF9rCVkTE2ShklqBPnz5ERkYCubv/FBcyrVZrgd2B+vbtWynjA8jJyeHs2bN4eHjg4+NDvXr1MJlMhcplZmbi4eFRaeOSstF5qb4q+9xYrVauXr1KSkoKV65coXXr1ri6ulZa/yIijqb/KpfgD3/4g3G8du3aYq8S7tu3jzNnzgC5O/+0bt26UsZnsVg4e/YsN9xwA35+fnh4eBQZMEWk+jOZTHh4eODn58cNN9zA2bNnsVgsVT0sERG71dqQOWvWLAICAggICGDRokVFlunQoQMDBgwAcp+5fOuttwr9pR8bG8ucOXOM76dOnVphY75eeno6Hh4eeHl5VVqfIlLxvLy88PDwsHnNXRGR6sTpbpefPXuW9evXF3jt5MmTxnFYWFihSToDBw6kU6dOdvX36quv8tNPP3H58mXWr1/P6dOnGTZsGI0aNeLUqVOsWbPGmFn+0EMPcc8999jVjz1SU1Px8fGptP5EpPI0aNCAxMREvL29q3ooIiJ2cbqQGRsby7Jly4p9/8iRIxw5cqTAa/7+/naHzJYtW7JixQqmTZvG2bNnOXbsGMeOHStUbsiQIcydO9euPuyVlZVVYKchEak56tWrV6Y1ekWkZomPh4QE++r6+kKTJo4dT3k4XcisCp06dWLz5s2sXbuWr776ipiYGNLT02ncuDG33XYbjz76aKVO9slPz2CK1Ez63RapnRISICTEvrqjRilklktQUFCB2+P2mjdvHvPmzStzeU9PT8aNG8e4cePK3beIiIhITVdrJ/6IiIiISMVRyBQRERERh1PIFBERERGHU8gUEREREYdTyBQRcaDDhw+XutGDiEixLBYw59j3Vc12CXO62eUi1VFAQIDNdTp06MCaNWsqYDQ1V1RUFLt27QJgwIABdOzYsYpHJCLiYBYLnLtkZ92mVKfrhwqZtUm2udr9L6dCubhAHf0Rr0mioqJYvHgxkLtRgkKmiEj1pX+BaxOLBcJ+rupRVJ67ulRJt0uWLClTOe05LyIiNZlCpoiDDRgwoMxlMzMzK3AkIiIiVaf63LgXERERkRpDVzJFqonvv/+esWPHYrFYaN68OZs3b6ZBgwZFlj179izDhw8nLS0NT09PNmzYwE033WS8v2jRIuPZxZUrVxIUFMTevXtZs2YNkZGRJCQk4OvrS7du3Xjqqafo2rVrmcaYkJDA2rVr2b9/P2fOnCE5ORkvLy9uuukm7r33Xp544gnq169fprYOHTrE9u3bOXLkCPHx8WRmZuLt7c1NN91E9+7deeihh7j55psBCA0N5ZVXXilQ/5VXXin0WsuWLdm9e3eR/Z0+fZr169cTFhbGhQsXyMjIwMfHh8DAQAYNGsSQIUNwcSn9/91Hjhzh008/5ciRIyQlJeHr60tgYCCPP/44ffv2LdNnFxGpDRQyRaqJHj16MGHCBJYtW8aFCxd47bXX+OCDDwqVM5vNvPTSS6SlpQHw6quvFgiYRXnzzTf57LPPCrx28eJFtm3bxo4dO5g8eTJTpkwpsY3Q0FD+9re/kZ6eXuD1xMREwsPDCQ8P5z//+Q+LFy8uMbQmJCTw4osvcvDgwULv5W9r2bJlnDx5ssQxlYXZbGbevHl8+umnWK6b+Hbp0iUuXbrEnj17WL16NUuWLKFJkybFtvX+++/z4YcfYrVajdfi4uKIi4vjm2++YfTo0TzwwAPlHrOISE2gkClSjUydOpVDhw5x7NgxvvzyS9avX8+IESMKlFm8eDE//fQTAAMHDmTkyJEltrly5Up27dqFj48PI0eOJCAggMzMTPbv38/OnTuxWCwsWrSIRo0aMXr06CLb+OSTT5g7dy4AHh4eDBw4kK5du9KoUSMSExPZv38/u3fv5vLly4wbN47169cbVyHzS0hIYOTIkZw7dw4Ab29vBg8ezK233oqXlxdJSUlERUXx7bffEhcXZ9S76667WLJkCWFhYaxatQqAp556irvuuqtA+/Xq1SvwvdVq5fnnn+frr78GoEmTJgwePJgOHTpQr149YmNj2bZtG5GRkRw7doynn36a9evX4+HhUWjs//73v1m2bBkAJpOJQYMGcffdd1OvXj1OnDjBunXrWL16NRcvXizxfIiI1BYKmSLViJubGwsWLGDYsGGkp6fz9ttv061bN9q2bQvk3qpdvnw5AM2bN+evf/1rqW3u2rWL9u3b88knn9C4cWPj9ZEjR7Jr1y6mT5+O2Wzmvffeo3///rRo0aJA/f/+97+8++67AHTs2JGlS5cWKjNq1Cj27NnD1KlTyczM5NVXX+Xzzz8vNJaZM2caAbNnz54sXLiQRo0aFSpntVr55ptvjO9btGhBixYtSElJMV7r1KlTqZOsVq5caQTMoUOH8tZbbxUKkH/84x9ZuHAhy5Yt45dffmHJkiW89NJLBcr8/vvvxlXlOnXqsGTJEvr162e8P2TIEMaOHcuYMWOM/kREajtN/BFxsLzdXkr7Cg0NLbJ+69atef311wHIyMjgxRdfJDs7m5SUFF5++WVycnJwcXHh73//Ow0bNix1PG5ubrz//vsFAmaeAQMGMG7cOCB3pntISEihMkuWLMFsNlO/fn0+/PDDQgEzz7333sv48eMBOHbsGEePHi3w/tGjR9m3bx8A/v7+LF26tMiACblXCm2ZpV+UrKwsPvzwQwBuvfVW5s+fX+QVSpPJxAsvvEC3bt0ACAkJISsrq0CZVatWce3aNQCeffbZAgEzT5MmTXj//fdxdXUt17hFRGoKhUyRamj48OEMGTIEgIiICD744ANef/11YmNjAZgwYQLdu3cvU1u9e/emffv2xb4/duxYIxhdfxUuOTmZvXv3ArlX6/z8/Ersa+jQocbxd999V+C9LVu2GMfPPfccnp6eZRq/vfbv38+VK1cAePrpp0ud1JM39rS0NONxhDx5uwzVqVOn2EcKIHcXp169epVn2CIiNYZul4s4WFkXY+/UqVOJ77/55pv89NNPnDt3jhUrVhiv33777UydOrXM4+nZs2eJ7zdp0oR27dpx6tQpYmJiSE1NxdvbG8i9+pg3WcbFxcUIW8XJzs42jqOjowu8Fx4eDuReObz33nvLPH575fUHuWG5tLHnf5YyOjqaLl1yF/O/cuWKEe47duxY7NXXPD179jSu2IqI1GYKmSIO5qjF2L28vHjvvfcYPXo0ZrO5wGtubmX/1W3Tpk2Zypw6dQqr1Up8fLwRMs+fP2+UCQkJKfJ2enHyPz8J/xfiGjduXGpQc4T8Y3/rrbdsqpt/7Jcu/d8ewmX9WYqIiG6Xi1RrzZo1K/AcYWBgIK1bt7apjaKeQyypTEZGhnGcmppqU1/55b+qCRhLLlX0bfI8jhp7/iWbyvKzrKzPJyJS3elKpkg1ZbFYePnllwuEpcOHD/PZZ5/xxBNPlLmdsmxdmb9M/pCU/3ju3Lk8+uijZe73enlLFOUPsRUp/9h37dplczjP+5nkX1y+LD/Lyvp8IlL14uMhIcH++r6+UMLSvE5PIVOkmvrwww/54YcfgNzn/CIiIkhNTWX+/PkEBQXRrl27MrXz+++/l7mMyWQqsBh5/ok++dettIefnx9JSUlcuXKFpKSkCr9lnn/sFy9etDlk5mnatKlxbMvPUkRqvoQEsOEpokJGjarZIVO3y0WqoWPHjhnbQjZt2pT333+fOXPmAHD16lVmzJhhLKlTmrCwsBLfj4+PNybptG3b1ngeE6B79+6YTCag8GxxW+UtEWS1WtmzZ49dbeSfIZ5/152i5J99f+DAAbv6g9xnSFu2bAlAVFQUycnJJZY/dOiQ3X2JiJOxWMCcY//XdbuQ1TQKmSLVTFpaGi+99BJmsxmTycT8+fPx8fFhyJAhDBs2DIATJ07w3nvvlam9/fv3F5rpnd+qVavIyckBKLQlYuPGjenTpw+QO1u7PGEt//JGy5Yts+u2cv5b4KXduu7Xrx8+Pj5A7qSl/BN4bJU3mSs7O5vVq1cXW+7UqVPlDuMi4kQsFjh30f4vhUwRqUxvvfWWcct13Lhx3H333cZ7r7/+unHbd+XKlezfv7/U9sxmM88//zwJRTw4tHv3bj766CMgd1LLqFGjCpV5/vnnqVOnDgAzZswodXme8+fPM3/+fGONyjy33367sYh5TEwMkydPJikpqcg2rt/xJ0+rVq2M48jIyBLH4enpaezHnpSUxJ/+9CdiYmJKrHPs2DFjd6P8Ro8eTd26dYHcgFxU2L58+TIzZswwAruISG2nZzJFHKy09Rjz69GjR4EZy1u3bmXTpk1A7jqaL7zwQoHyXl5eLFiwgCeeeAKz2cwrr7zC5s2b8fX1LbaPAQMGsGvXLgYPHkxwcDC33HILmZmZHDhwgC+//NK47fzSSy/RvHnzQvUDAwN54403eO2110hOTmb8+PHccccd9O3bl1atWuHm5kZycjK//vor4eHhREREALmLvF9v3rx5xt7lBw8e5P7772fQoEHG3uUpKSmcPHmSPXv2cP78eU6ePFmg/i233ELjxo25cuUKW7ZswdfXl9tvvx13d3cgd+/yHj16GOVHjx7Nf//7X7744gtOnjzJ4MGD6d+/P926daNJkyZYLBYSEhI4deoUhw4d4ty5c7Rp04Y///nPBfpt06YN06dP5+9//zvXrl1j/Pjxxt7l7u7unDx5knXr1pGYmMj999+vrSVFRFDIFHG4yZMnl7nsvn37aNCgAQDnzp0znrv08PDgvffeM66e5XfbbbcxZcoUFi5cSHx8PK+++irLli0rto8xY8bg5+fHp59+WmQ5k8nE5MmTS9zJZuTIkTRu3JjXXnuNy5cvc/To0ULbRubXqFGjIsfu6+vL2rVreeGFF/j+++9JSUlhzZo1rFmzpshxXc/NzY3p06fz+uuvk52dzb///e8C77ds2ZLdu3cXeG3evHn4+/vzr3/9i2vXrrFz50527txZ7NibNWtW5Ot/+tOfSE5OZsWKFVgsFrZu3crWrVsLlHnqqacUMkVE/kchU6QayMnJKbBc0axZs0qcPT5x4kS+++47fvjhB/bs2cPq1atLDImvv/46/fr1IyQkhMjISBITE/Hx8aFbt26MGTOGrl27ljrG/v37c/fdd/PFF1+wd+9eoqKiSExMJCcnB29vb/z9/encuTO9evWiV69eRYZMgBtuuIFVq1axd+9etm3bxtGjR7ly5QrZ2dk0aNCAdu3aERQUZGyreb3HHnuMFi1asGbNGiIiIkhISChxEpTJZGLSpEmMGDGCdevWERYWxm+//UZSUhIuLi74+Phw0003Gbfzb7/99mLbevHFF+nXrx+rVq0iPDycpKQkfH19CQwM5PHHH6dfv34cPny41J+liEhtoJBZm7i4wF1dqnoUlaeUvaod6frbumWVN3nF1dXVpt10XFxcSpyAUpR+/foZz0Taq169ejz++OM8/vjj5WqnvOPp06ePMSGprJo2bcrkyZNtutJclG7duhkz5YsSFBRk958HEZGaRCGzNqmj0y0iIiKVQ7PLRURERMThdGlLREREaoXybANZ07eArAgKmSIiIlIrlGcbyJq+BWRF0O1yEREREXE4XckUqYGmTp3K1KlTq3oYIiJSi+lKpoiIiIg4nEKmiIiIiDicQqaIiIiIOJxCpoiIiIg4nCb+iIiISO1gsYDZamddE7o2ZxuFTBEREakdLBY4d8nOuk1RyLSNfloiIiIi4nAKmSIiIiLicAqZIiIiIuJwCpkiIiIi4nAKmSIiIiLicAqZIiIiIuJwWsJIREREqp34eEhIsL++ry80aeK48YjtFDJFRESk2klIgJAQ++uPGqWQWdV0u1xEqqVFixYREBBAQEAAhw8frurhiIiIjXQlU6QCvfrqq2zYsAEAk8nE119/TevWrSu839DQUM6fPw/A1KlTK7w/ERGR6ylk1iLlfb7F2VT18zgZGRns2LHD+N5qtbJx40amTZtW4X1v3LiR77//HlDIFBGRqqGQWYuU9/kWZ1PVz+N89dVXZGRkFHjtiy++YOrUqZhMpioalYiISOXQM5kiFSQ0NBSAOnXq8NBDDwFw/vx5wsLCqnJYIiIilUIhU6QCnD17lh9++AGA3r17M27cOOO9vGc0RUREajLdLhepAKGhoVitVgCGDx9OYGAg7du35/Tp03z99dekpaXh5eVVajuZmZmEhoayb98+Tpw4QWJiIgBNmjShY8eO9OnTh8GDBxttPfXUU8azmHkCAgIKtTtlyhTjWc3Dhw8zZsyYQq8XpSxlzWYzhw4d4rvvvuPYsWPExMSQmppKnTp1aNq0KV27duXRRx+le/fupX5+ERFxXgqZIg5msVj44osvAGjQoAH9+/cHYOjQoSxYsICrV6+ybds2HnvssRLb2bdvH6+88gqXL18u9N65c+c4d+4cX3/9NT/99BPvvPOO4z+IncaNG1co6AJkZ2cTExNDTEwMGzdu5OGHH+att96ibt26VTBKEan2LBYwW8tR34Ru2FYthUwRBwsLCyM2NhaABx980AhRw4YN4/3338disRAaGlpiyNy+fTsvvfQSOTk5QO7VyAceeAB/f39MJhMXLlzgxx9/5MCBA8YVU4Dp06eTlJTEwoULOX36NABLliwp1P6NN97osM97vaysLDw9PenZsyeBgYG0bNkSd3d34uPj+eWXX9iyZQsZGRls3LgRb29vZs+eXWFjEREnZrHAuUvlqN8UhcyqpZAp4mD5n7kcNmyYcezn50dQUBCHDh3ip59+Ijo6mhYtWhSqf/bsWWbPnk1OTg4uLi7MmjWLMWPGFDkjPTk5mRMnThjfd+vWDYBPPvnEeG3AgAEO+Vxl9cILL9C1a1fq1atX7PuTJ08mPDyc1atXM2bMmEpZO1RERCqXIr6IA6WmprJr1y4AWrVqxZ133lng/eHDhxvHebPPr7d8+XJj6aPx48czduzYYpc8atiwIUFBQY4YusP07Nmz2IAJ4OPjw/z584HcRwu2bNlSWUMTEZFKpJAp4kDbtm3j6tWrQO4zmNeHwwceeABPT08ANm3aZNwOz5OTk8P27dsBqF+/PhMmTKiEUVe+1q1b0+R/i5j+/PPPVTwaERGpCLpdLuJAxd0qz+Pp6cmAAQPYvHkz8fHxfPfddwwcONB4/+TJk6SlpQEQFBRUphno1VFaWhqbN29m3759nDp1isTExEIL0+eJi4ur5NGJiEhlUMgUcZBffvnFuCp3++2307Zt2yLLDR8+nM2bNwO5VzPzh8z8gatdu3YVN9gKFBYWxksvvUR8fHyZyueFahERqVmcMmRarVZ27NjBpk2biIqKIiEhgUaNGtGuXTuGDBnCww8/jJub4z6a1Wpl7969bNmyhf/+97/Ex8dz7do1vLy8uPHGG+nRowcjRoygTZs2DutTnE/+q5hDhw4ttlzPnj3x8/Pj4sWL7N27l4SEBHx9fYGCgSvvtroziYmJYeLEicYjAzfeeCN9+/bF39+fRo0a4e7ubpR97bXXSEhIwGKxVNVwRUSkAjldyExOTmbatGmFtuaLj48nPj6esLAwQkJCWLx4cZEzd22VkJDA9OnTi1z3LykpiR9//JEff/yRjz76iOnTpzN+/Phy9ynOx2w2G1cnAd566y3eeuutMtXbsmULY8eOBShwe7y428tVqbRA+OGHHxoB89lnn+X5558vdtLSX/7yF4ePT0REqg+nCpnXrl1j0qRJHDlyBIDmzZsTHByMv78/cXFxbNiwgejoaCIjIxk/fjxr164t1zNtZrOZ8ePHExERAYC7uzvDhw8nICCAhg0bcuHCBfbs2UN4eDjZ2dm89957eHp68uSTTzrk84rz2LdvX5GLppdFaGioETKbNWtmvB4dHe2QsZUm/2Lo2dnZJZbN23GoOIcOHQKgcePGTJ8+vdiAmZaWRnJyso0jFRERZ+JUITMkJMQImIGBgXz88cc0bNjQeH/06NFMmjSJAwcO8Msvv7BkyRJmzpxpd39bt241Ambz5s359NNPadmyZYEy48eP5/PPP+e1114DYNGiRTz22GMOvV0v1V/+5YgefvjhQn9OirJ161ZiYmI4ceIEx48fp1OnTgQEBODl5UVaWhqHDx8u8/aT18sf7qxWa7FhD3J3Jcpz6VLJCx+XNhM8L2i3atUKF5fiF684dOiQbpOLiNRwTpOEzGYzy5YtA3L/AZ0/f36BgAm5VxrfffddBgwYQEZGBqtXr2bChAn4+PjY1eeBAweM4/HjxxcbHIKDg1mzZg2RkZEkJiYSHR1d5H7RUjMlJCTw7bffArm3u+fMmVPiOpF5GjRowNy5c4HckNqpUydcXV0ZPHgwa9euJT09neXLlzNjxgybx5T/ec6MjAzq169fbNk2bdpQp04dsrOz+f7774sNpSkpKcZ2mcXx8PAgOzubs2fPFttOTk6O8bssIiI1l9OskxkWFkZCQgKQO3Giffv2RZZr3LgxgwYNAnJvr3/zzTd295nXH1DsTOE8+bfpy8zMtLtPcT6bN282bjM/8MADZQqYAEOGDDGueG/ZsoVr164Buf+hyQuJK1as4JNPPimwdWR+KSkpRT4v3KpVK+P4+PHjJY6jTp063HXXXQCcP3+e1atXFyqTkZHBjBkzSr1dfuuttwK5vzv5dx3Kk52dzV/+8hfjDoGIiNRcTnMl87vvvjOO+/TpU2LZPn36sH79egD279/PiBEj7OqzcePGxnFMTAy9evUqtmxMTAwArq6upQZSqVny3yovaVb59Ro3bsxdd93FgQMHSEpKYvfu3Tz44IO0bt2at99+mxdffBGLxcLcuXPZsGEDAwcOpE2bNri4uHDx4kV++ukn9u3bx4MPPkiPHj0KtN2zZ09WrVoFwOzZsxk7diwtW7Y0bmH7+/vj7+9vlH/mmWfYv38/AG+//TY//fQTffr0oU6dOpw+fZqNGzcSFxfH4MGD2bZtW7GfafTo0cbv6jvvvMPhw4fp3bs3Pj4+xMTEsGnTJmJiYggKCuLMmTNaI1OkBsnJ8eHkSfvq+vrC//ZnkBrEaULmqVOnjOPAwMASy3bu3Nk4Pn36tN193nfffcaM4RUrVnDPPfcUecv8888/N67MDBs2jEaNGtndpziXyMhITv7vb9VmzZrZvMXjkCFDjMcyQkNDefDBBwEYNGgQHh4evPLKKyQmJnLy5Emjn+sVdUv6nnvu4c477yQ8PJwzZ84Umuk+ZcoUpk6danzfs2dPJk2axNKlS7FarWzdupWtW7cW6GPq1Kl07969xJDZv39/Jk6cyIcffgjA7t272b17d4Eyd9xxBwsXLrT7P38iUj2lpNRh50776o4apZBZEzlNyMy7UgiUOqmiWbNmuLq6kpOTw5kzZ0qd+FCcgQMHcv/99/P1119z4cIF/vCHPzB8+HA6dOhgzC7fvXs34eHhANx///1alqWWyX8Vc/DgwSVOdinKPffcY0z0OXDgABcvXsTPzw+Ae++9l127drF+/Xq+/fZbTp8+TXJyMq6urjRt2pSOHTtyzz33GME0P1dXVz7++GM++eQTdu/eza+//kpaWlqhbSzzmz59OnfeeSerV6/m2LFjpKam0rhxY+644w6efPJJunXrxuHDh0v9TDNmzKBbt258+umnHDt2jLS0tApdx1ZERKonp/mbPjU11a6B0D4AACAASURBVDgubSKPm5sbXl5eJCcnYzabS534UByTycQHH3zAP//5T1atWkV6ejpr164tVC4wMJBp06bRr18/u8JsZfH1zf3fYm3xv/XNK9Rrr71mrCxgj3r16hn/SSmKl5cXTz/9NE8//bTNbbu7uzNhwgSb9j/v3bs3vXv3Lvb9oKCgYq+o5te3b1/69u1bYpnrr3Beb+rUqQWutoqIiHNxmpCZf2Hq/LuGFCd/mfT0dLtCJuReEXrmmWdo0KABCxcuNCZn5BcZGcny5ctp0KABd9xxh819REVF2TU2q9Va5klGVqsVL69MnHQrbLtV9zlYtpxDqVzV4dxkZmba/fdDTXX16lX9TKqpBl43knOt5LV2i2POshAV9WvBF603l2s8Fqu18J+VcrTp6PYqos2i2qvK3xmnCZlVZd++fcyYMYPU1FR69OjBxIkTue2223B3d+fChQt8+eWXLFu2jPDwcJ5++mn+8Y9/MGDAAJv66Nixo11j++233/Dw8ChT2czMzDKXlcqj81J9VYdz4+HhUWDlCsn9T7m9f2dKxYqKyMY1Nt6uum6uTQm47ryejDSXazwuJpND23R0exXRZlHtOfp3pqS7b4XG47BeK1j+df+ysrJKLZ+/jL1XMfft28fEiRNJTU1l4MCBfPLJJ/Tu3Rtvb2/q1q2Lv78/EydO5JNPPqFu3bpkZWXx5z//mfh4+37JRERERGoKpwmZ3t7exnFpa/WZzWbS0tKA3DUA8wdUW8yfPx+LxYKLiwuzZ88udlJHly5dePjhh4HcW/MbN260qz8RERGRmsJpbpe3bduWc+fOAbkLRudfbPp6cXFxxizaNm3a2DUZ5+zZs/zyyy8A3HzzzcaM3+LcfffdxqSg0rbeExERqUrx8ZBvvxGbaV1LKQunCZm33HKLsZ5gZGRkiesR5t9NpLidgUqTfw/nstxuz3+ltaonC4iIiJQkIQFCQuyvr3UtpSyc5nZ5/mVV8u8pXpS8nUug9N2BiuOVbxp2WXYliY2NNY61GLuIiIjUdk4TMoOCgvD938KHBw8eLHYnnytXrrB9+3Ygdxmj++67z67+/P39jWWQLly4wNGjR0ssn38XlPw7DomIiIjURk4TMt3c3Hj22WeB3PXrZs6cSXJycoEyWVlZzJw501hT88knnyx24fZZs2YREBBAQEAAixYtKvR+vXr1CgTUWbNmFbhamd+yZcs4dOgQAHXr1uUPf/iD7R9QREREpAZxmmcyAUaNGsXOnTs5cuQIkZGRDBs2jMceewx/f3/i4uJYv3490dHRQO5knUmTJpWrvxkzZnDw4EGSkpI4c+YMQ4YMYejQodx+++0F1sk8duyYUWfKlCk0a9asXP2KiIiIODunCpl169Zl6dKlTJs2jbCwMC5cuMDChQsLlQsMDGTx4sUFJuPYo3Xr1nz00UfMmDGDmJgY0tPTCQkJIaSIp6Xd3NyYMmUKEydOLFefIiIiIjWBU4VMgIYNG/Kf//yHHTt2sGnTJo4fP05iYiINGzbk5ptvZvDgwTzyyCO4uTnmowUGBrJ582Z27NjBrl27OH78OAkJCWRnZ+Pl5UXbtm3p0aMHwcHBtG7d2iF9ioiIiDg7pwuZACaTiUGDBjFo0CC725g3bx7z5s0rU1l3d3eGDx/O8OHD7e6volitVrvWARWR6s1qtVb1EEREysVpJv5IYe7u7ly9erWqhyEiFeDq1avGChciIs5IIdOJeXt7k5KSUtXDEJEKkJKSUu7nykVEqpJCphOrX78+mZmZxj7tIlIzpKWlkZmZWabdxkREqiunfCZTcrm4uNC6dWvOnj1Leno6DRo0oF69enpGU8QJWa1Wrl69SkpKCpmZmbRu3RoXF10HEBHnpZDp5FxdXWnTpg3p6ekkJiaSlZVVZLnMzEw8PDwqeXRSGp2X6qsqzo27uzve3t40adJEAVMqlsUC5nJMLrOY0M1QKY1CZg3g4uKCt7d3ic9vRUVFceONN1biqKQsdF6qL50bqdEsFjh3qRz1m6KQKaXRnxARERERcTiFTBERERFxON0uFxERqebi4yEhwb66vr7QpIljxyNSFgqZIiIi1VxCAoSE2Fd31CiFTKkaul0uIiIiIg6nkCkiIiIiDqeQKSIiIiIOp5ApIiIiIg6nkCkiIiIiDqeQKSIiIiIOp5ApIiIiIg6ndTJFREQcqDwLp4MWT5eaQyFTRETEgcqzcDpo8XSpOXS7XEREREQcTiFTRERERBxOt8tFRESqO4sFzFY765rQNSWpCgqZIiIi1Z3FAucu2Vm3KQqZUhX0p05EREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBzOraoHICIiUqNYLGC2lqO+CV0DkppAIVNERMSRLBY4d6kc9ZuikCk1gf4Ui4iIiIjDKWSKiIiIiMMpZIqIiIiIw9kcMlNTUytiHCIiIiJSg9gcMvv06cOsWbM4cuRIRYxHRERERGoAm2eXX716lU2bNrFp0yZuvPFGgoODGT58OI0aNaqI8YmIiFSo+HhISLCvrq8vNGni2PGI1BQ2h8z27dtz+vRpAH777Tfmz5/PP/7xD+6//35GjBhBz549HT5IERGRipKQACEh9tUdNUohU6Q4Nt8u37JlC59//jmPPvooHh4eWK1Wrl27xvbt2/njH//IAw88wPLly7ly5UpFjFdEREREnIBds8u7dOnC22+/zYEDB3jrrbe49dZbsVqtWK1Wzp49y/vvv0+/fv2YNm0a+/btc/SYRURERKSaK9cSRp6engQHB7Nu3To2bdrEk08+ibe3N1arFbPZzNdff83EiRPp378/S5cu5eLFi44at4iIiIhUYw5bJzMgIIDXXnuN/fv3M2/ePLp3725c3YyNjWXRokX079+fZ599lt27d2OxWBzVtYiIiIhUMw5fjN3d3Z3hw4ezatUqduzYwYgRIwCwWq3k5OSwd+9eJk+eTP/+/Vm+fDnp6emOHoKIiIiIVLEK2/Hnhx9+YOnSpWzduhWTyYTJZAIwrm7GxcXx/vvvM2DAAHbt2lVRwxARERGRKmDzEkYlSUhIIDQ0lPXr13PmzBkgN1QCtGnThuDgYO6++26++uorQkNDiY+PJzExkWnTprFy5Uq6devmyOGIiIiISBVxSMjcv38/69atY8+ePZjNZiNYurm50b9/fx5//HHuvvtuo3ynTp2YMmUKISEhvPfee1y7do1//etf/L//9/8cMRwREamhcnJ8OHnS/vpaPF2k8tgdMuPi4li/fj2hoaFcuHAB+L+rli1atGDkyJGMGDGCJsX8NtepU4cxY8YQHx/PihUriIqKsncoIiJSS6Sk1GHnTvvrF7l4usUCZqt9DVpMVOCTZyJOzeaQuWvXLtatW8eBAwewWCxGsHRxcaFfv348/vjj9OvXz3gGszS33347AImJibYORUREpPwsFjh3yc66TVHIFCmazSFzypQpmEwmI1w2bdqUESNGMHLkSJo3b27zAOrWrWtzHRERERGp3uy+Xd6rVy8ef/xx+vfvj6urq90D6NKlCytXrrS7voiIiIhUPzaHzPHjxxMcHEzr1q0dMoCGDRvSo0cPh7QlIiIiItWDzSHzxRdfrIhxiIiIiEgNoqeVRURERMThbL6See3aNVasWIHVaqVv37506dKl1Do///wz+/btw8XFhQkTJuDmVr7lOa1WKzt27GDTpk1ERUWRkJBAo0aNaNeuHUOGDOHhhx8udx9FycnJYefOnezcuZOIiAguX76MyWTihhtuoE2bNgQFBXH//ffTtm1bh/ctIiIi4kxsTmJfffUVixYtws3NjeDg4DLVad68OcuWLSMnJ4d27doxcOBAmweaJzk5mWnTphEWFlbg9fj4eOLj4wkLCyMkJITFixfTokULu/u53vHjx5k9ezbHjx8v9F56ejpnzpxh//79XLp0idmzZzusXxERERFnZHPI/PbbbwEICgqiadOmZarTpEkTevbsyf79+9m9e7fdIfPatWtMmjSJI0eOALnhNTg4GH9/f+Li4tiwYQPR0dFERkYyfvx41q5di5eXl1195RceHs6ECRNIS0sDoEePHvTp04fmzZvj6upKfHw8kZGR7N27t9x9iYiIiNQENofMyMhITCaTzTPCu3fvzv79+4mIiLC1S0NISIgRMAMDA/n4449p2LCh8f7o0aOZNGkSBw4c4JdffmHJkiXMnDnT7v4ALl++zKRJk0hLS8PHx4cPPviAoKCgIsvm5ORw5cqVcvUnIiIiUhPYPPHn4sWLALRs2dKmenm3rvO2oLSV2Wxm2bJlAJhMJubPn18gYAK4u7vz7rvv4unpCcDq1avLvZPQ22+/TVJSEm5ubqxYsaLYgAng6upa5qu7IiIiIjWZzSHTbDbnVnSxrWpe+WvXrtnaJQBhYWEkJCQA0LNnT9q3b19kucaNGzNo0CCjr2+++cau/gDOnz/Pl19+CcDQoUO59dZb7W5LREREpDaxOWQ2atQIgNjYWJvq5ZW//upjWX333XfGcZ8+fUosm//9/fv329UfwMaNG7FYLEBuyBQRERGRsrE5ZN58881YrVb27NljU73du3cD2L28z6lTp4zjwMDAEst27tzZOD59+rRd/QHG858mk4lbb72V1NRUli5dytChQ+natStdu3Zl0KBBvPnmm0RHR9vdj4iIiEhNY3PI7NWrFwBHjx41biWXZseOHRw9ehSTyVTqVcjixMTEGMelPQ/arFkzYz/1M2fOYLVa7eozb5KSt7c3v//+Ow899BAffPABJ0+eJCMjg4yMDKKjo/nss8946KGHWL58uV39iIiIiNQ0Ns8uDw4OZtmyZaSnpzNr1ixSU1MZOXJkseXXrVvH22+/DYCnpyePPfaYXQNNTU01jn18fEos6+bmhpeXF8nJyZjNZjIyMqhfv75N/WVlZRl9WiwWJkyYQHx8PG3btuWRRx6hdevWJCUl8c0333DgwAFycnJYsGABderUYdy4cbZ/QBEREZEaxOaQ2aBBA2bPns0rr7xCVlYWr7/+OitWrOCee+6hXbt2eHp6Glf4vv32W86ePYvVasVkMvHKK6+UGhCLk5GRYRy7u7uXWj5/mfT0dJtDZkpKinGclpZGWloa9913HwsXLqRu3brGe0888QQhISHMmTMHgAULFvDggw/SvHnzMvcVFRVl09jscfXq1UrpR2yj81J96dxUTw28biTnWrbd9c1ZFqKifi34ovVmu9uzWK2F/5yUo72KaLOyxmilnUPbq60/R0ePsSr/LrNr78WHH36YxMREFixYQE5ODmfPnmXVqlVFlrVarbi6uvLSSy8xYsSIcg22MuVN+MnTqFEj5s+fXyBg5hk1ahSHDh3iq6++Ijs7m5CQEGbMmFHmvjp27Fju8ZYmKiqqUvoR2+i8VF86N9VTVEQ2rrHxdtd3c21KwHXn9WSk2e72XEwmh7ZXEW1W1hijIuwP//o5OqbNIs+Lg/8uCw8PL3NZuzf4/uMf/0jXrl1ZtGgRBw8eLLZc7969mTp1Krfddpu9XQG5t9qTk5OB3FvZpe1NnpWVZRzbehWzqDqDBg3C29u72PLBwcF89dVXABw6dMjm/kREaqL4ePjf6nM28/WFJk0cOx4RqTx2h0yArl278tFHH5GQkMDRo0eJi4sjLS0NLy8vmjVrxh133IGvr69DBurt7W2EzMTExBKDo9lsNraArFOnjrE4uy3q16+Pm5ubsS5oaTPa87//+++/29yfiEhNlJAAISH21R01SiFTxJmVK2Tm8fX1ZcCAAY5oqlht27bl3LlzQO4i6a1atSq2bFxcHDk5OQC0adMGk8lkc38mkwl/f39jaaKSrmJe/35ewBURERGprWxewqiq3HLLLcZxZGRkiWXz749e3M5AZREQEGAc55/dXpT873t5edndp4iIiEhN4DQhs3fv3sbxgQMHSiybf5cfe9flBOjbt69xXFqwzf/+jTfeaHefIiIiIjWBQ26XQ+4t4vT0dOM2dUlatGhhc/tBQUH4+vqSkJDAwYMHOX36dJFXKa9cucL27duB3GWM7rvvPpv7ynPffffh4eFBZmYm27dvZ8aMGcXeNv/888+N4/yBWERERKQ2sjtk5uTksGXLFjZv3szPP/9Menp6meqZTCaOHz9uc39ubm48++yzzJ07F6vVysyZM/n4448L7IWelZXFzJkzjTU1n3zyyWLX5Zw1axYbN24EYMqUKUydOrVQmQYNGjBu3DiWLl1KUlISM2fOLLROJsCaNWuMmeWenp488cQTNn8+ERERkZrErpB56dIlpkyZwn//+18Au7dttNWoUaPYuXMnR44cITIykmHDhvHYY4/h7+9PXFwc69evNybq3HzzzUyaNKncfU6YMIF9+/YRERHBN998w0MPPcSjjz5Kq1atSElJYdeuXQVuz7/55psOm1EvIiIi4qxsDpkWi4XnnnvOeAaxVatW3HbbbWzbtg2TyUSPHj1o1KgRsbGxREVFYTabMZlM3H333TRt2rRcg61bty5Lly5l2rRphIWFceHCBRYuXFioXGBgIIsXLy51RnhZeHh4sGLFCqZPn873339PTEwMCxYsKFSuXr16zJkzh6FDh5a7TxERERFnZ3PI3Lp1K5GRkZhMJsaMGcPMmTNxcXFh27ZtAIwZM8Z4DjIhIYFly5axevVqTp06xQsvvEDnzp3LNeCGDRvyn//8hx07drBp0yaOHz9OYmIiDRs25Oabb2bw4ME88sgjpS7WbgtfX19WrlzJjh07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lSvYsGEDXnjhBQCVt9CLiopw+PBhzJ07F+PGjcPOnTvx4MGDBmkwEREREZk+rbfLmzdvDj8/P/j5+SEtLU2cfL1qtHl6ejp27dqFXbt2oX///vD19TV4o4mIiIjItNV5nkwA6Nq1K5YuXYrz58/j4MGDmDJlCmxtbcX5Mm/duoX3339fzJ+RkYGysjLJG01EREREpk2nIdgymQxDhw7F0KFD8fjxY3z33Xc4evQobt++LW4HgOPHj+PcuXMYP348fH19Na43TkSkM6USUAja86ndX4Z6/uYmIiIt9J7nx97eHrNnz8bs2bORnJyMiIgInDp1Cnl5eQCA4uJiHD16FEePHkXHjh0xZcoUrFixQu+GExGJlEog/aEe+7cHg0wiImlJ+q3ao0cPhISE4NKlS/jkk08wbtw4WFlZibfTs7KysH//fimrJCIiIiITZJAZyy0tLTFq1CiMGjUK+fn5OHnyJI4dO4aEhARDVEdEREREJsbgy+K0adMG8+fPx/z58xEbG4tjx44ZukoiIiIiMrIGXXvRw8MDHh4eDVklERERERkBn3QnIiIiIskxyCQiIiIiyTHIJCIiIiLJMcgkIiIiIskxyCQiIiIiyTHIJCIiIiLJMcgkIiIiIskxyCQiIiIiyTHIJCIiIiLJMcgkIiIiIskxyCQiIiIiyTXo2uVERAAApRJQCDruKwN/HxMRmT4GmUTU8JRKIP2hjvu2B4NMIiLTx29qIiIiIpIcg0wiIiIikhyDTCIiIiKSHINMIiIiIpIcg0wiIiIikhyDTCIiIiKSHINMIiIiIpIcg0wiIiIikhyDTCIiIiKSHINMIiIiIpIcg0wiIiIikhyDTCIiIiKSHINMIiIiIpIcg0wiIiIikhyDTCIiIiKSnJWxG0BEJk6pBBSCHvvLwN+zRERND4NMItJMqQTSH+qxf3swyCQianr4zU9EREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJKzMnYDiEhi5QpAqdRtXwsLwJpfC0REpD+eTYgaG6USkN/Wbd8hntK2hYiImizeLiciIiIiyTHIJCIiIiLJMcgkIiIiIskx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gydOnNCrvOeee05Mp6SkaM2vmkf1qqopq2pnXl6e1iAsNTVV4/aqZyMFQag20t+YOnbsKKZ1HURlisdF1BQwyCQik1K1FCEAHD16FBkZGTqXpTpw5+rVq1rzX7lypdZ9TVlVO5VKJX799VeNeVUnuq/NCy+8IKYvX76sf+Mk4O7uLl7N/OWXX3S69W2Kx0XUFDDIJCKTMnDgQHGqoSdPnmDFihX1CiwOHTqEGzduAAC6dOkCDw8PAMDdu3erBZHP+v333yGXywFUzptZtZ+pGzt2rJjWNK/j06dPERYWprGsyZMnw9raGgCwf/9+nW9PS8nS0hKTJ08GUPn/Ye/evfUuwxSPi6gpYJBJRCZn48aN4m3Smzdv4pVXXhGXA1Tn9u3bWLhwITZs2FBtsMbrr78upkNCQmq95ZqZmYnly5dDqVQCAF577TVYWlpKcSgGN2rUKHFU/LVr17Bz584aecrLy7FmzRqtV4U7deqEf/zjHwAqHx0IDAzUOMpeqVTi6tWr2L17tx5HoN2iRYvE5yr37duHzz77rNalI4HK0eDPXtE11eMiauw48IeITE6bNm1w6NAhBAYGIiUlBQkJCZg1axb69euHF198EU5OTrC3t0dRUREePHiAn3/+GYmJibWW5ePjg3PnzuH06dPIzc2Fv78//Pz80L9/f1haWoprl1ddLR02bJjWSctNiaWlJT744AMEBASgvLwcO3bswNWrV+Hj44M2bdogMzMTx44dQ1JSEsaNG1dt8vbaLF++HPHx8bh27Rp++eUXjB07FuPHj0f//v3Rpk0blJeXIy8vD3fv3sXVq1eRm5uLoUOHIigoyGDH2LVrV3zwwQdYsWIFlEolQkNDceTIEUyYMAHdunWDhYUFcnJycOvWLURFRWHixIkYPHiwyR8XUWPHIJOITFL37t3x7bff4sMPP0RERATKy8sRExODmJgYtfs899xzWLJkCQYNGlTt9c2bN6NFixb49ttvxdvGtd06njBhAjZv3qx2yUJTNWjQIHz00UdYuXIlSkpKcP369WoTkAPA3//+d4SGhmoNMq2trbF3715s2rQJYWFhePr0KU6ePImTJ0+q3Ud1MnVD8fHxQfPmzfHOO++goKAACQkJSEhIqDVvbf1nqsdF1JgxyCQik9WqVSusXbsWgYGB+OGHHyCXy5GUlISCggI8ffoU9vb26Ny5M/r27YuRI0di5MiRta5JbWVlhfXr1+Oll17Ct99+i99++w25ublQKpVo164dBg4cCH9/f60r4piycePG4bvvvsOBAwdw6dIl5OTkwM7ODt27d4evry9efvnlOq8Fb2Njg3/961949dVXERERgV9++QVpaWl49OgRrK2t0bZtW/To0QODBg2Ct7c33N3dDXx0lUaNGoVz584hIiICP/30E+7du4eioiJYWlqiffv26NWrF7y9vTFx4kSzOi6ixkomqHuwhYiIiIhIRxz4Q0RERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkvt/cOtfonXX4xEAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for LeNet post temp scaling\n",
    "lenet_temp_model = ModelWithTemperature(lenet_model)\n",
    "lenet_temp_model.set_temperature(dirty_mnist_val_loader)\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(lenet_temp_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"lenet\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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b2/vYmP/5z//yZIlSwAwmUwMHjyYXr160bBhQ44ePcqqVasIDw/n7NmzZX4eIiL1hUKmSC3i4eHB/PnzGT58OBkZGbz55pt069aNK6+8Esi/VfvRRx8B0KpVK/7617+W2+a2bdvo0KEDn376KQEBAcbro0aNYtu2bcyYMQOLxcK7777LgAEDaN26dZH6//73v3n77bcB6NixIx988EGxMmPHjmXHjh1MmzaNrKwsXnrpJb744otiY5k5c6YRMHv27MmCBQto2rRpsXI2m43vvvvO+Lp169a0bt2atLQ047VOnTqVu8hq2bJlRsAcNmwYb7zxRrEA+fjjj7NgwQKWLFnCb7/9xuLFi3n++eeLlPnjjz+MWWVPT08WL15M//79jfeHDh3KI488wvjx443+RETqOy38EXGygtNeyvu1du3aEuu3a9eOV155BYDMzEyee+45cnNzSUtL44UXXiAvLw83NzfeeecdmjRpUu54PDw8eO+994oEzAIDBw7kscceA/JXukdERBQrs3jxYiwWC40aNeLDDz8sFjAL3HbbbUyYMAGAQ4cOcfDgwSLvHzx4kF27dgEQFBTEBx98UGLAhPyZQntW6ZckOzubDz/8EIAbbriBefPmlThDaTKZeOaZZ+jWrRsAERERZGdnFymzfPlycnJyAHjyySeLBMwCgYGBvPfee7i7u1dq3CIidYVCpkgtNGLECIYOHQrA4cOHef/993nllVdISEgAYOLEiXTv3r1CbfXp04cOHTqU+v4jjzxiBKPLZ+FSU1PZuXMnkD9b16JFizL7GjZsmHG9d+/eIu9t2LDBuH7qqafw8fGp0PgdtXv3bi5cuADAo48+Wu6inoKxp6enG48jFCg4ZcjT07PURwog/xSn3r17V2bYIiJ1hm6XizhZRTdj79SpU5nvv/766/zyyy+cOnWKpUuXGq936dKFadOmVXg8PXv2LPP9wMBAgoODOX78OHFxcVy8eBE/Pz8gf/axYLGMm5ubEbZKk5uba1zHxsYWeS8qKgrInzm87bbbKjx+RxX0B/lhubyxF36WMjY2ls6d8zfzv3DhghHuO3bsWOrsa4GePXsaM7YiIvWZQqaIkzlrM3ZfX1/effddxo0bh8ViKfKah0fF/+i2b9++QmWOHz+OzWYjKSnJCJmnT582ykRERJR4O700hZ+fhP+FuICAgHKDmjMU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9XsaN26c8WjLW2+9xf79++nTpw/NmjUjLi6OdevWERcXR1hYGCdPntQemSIidZjLhMzCK20Lb4NSmsJlMjIyHAqZkP+M5RNPPEHjxo1ZsGCBMdtUWHR0NB999BGNGzfmpptusruPmJgYh8Zms9kqvMjIZrNhseRSzrqOOsVigawsS5X2ERMTw7H/7tnRokULOnfubNfCryFDhhi7GKxatYr+/fsDcNttt7FgwQJeffVVkpOTOXbsmNHP5axWa7E+w8LC6Nq1Kz///DMnT54sttJ90qRJRU4b6tKlCxMnTuSjjz7CZrOxceNGNm7caLBSkcoAACAASURBVLxvMpl48sknufnmm42QmZubW6zfnj178vjjj/Pxxx8DsH37drZv316kTJcuXXjrrbeM/WRLGn9B+wWys7OrfUGdPX++qkpWVpbDfz/UVZcuXdLPpJZq7HsVeTmO/SNjybYSE/Ofoi/arqnUeKw2W/HfK5Vo09ntVUWbJbVXk39mXCZk1pRdu3bx7LPPcvHiRXr06MGkSZO48cYb8fLy4syZM3z99dcsWbKEqKgoHn30Uf7v//6PgQMH2tVHx44dHRrb77//jre3d4XKZmVl4eHhiaenQ125JA8P8Pau2m+48Kze0KFD7f7PzG233WYs9Nm3bx9paWm0aNECyH9co3fv3qxevZrvv/+eEydOkJqairu7O82bN6djx47ceuut3HXXXSX+Pvj000/59NNP2b59O//5z39IT08nLy8PyL9Ffnmd5557jrCwMMLDwzl06BAXL14kICCAm266iYceeohu3bqxf/9+o3xJbQDMnDmTnj178tlnn3Ho0CHS09NLPPa1YFbVzc2txHY8C/1m9fLyqvDvdWfJysqq9j4v5+3tXWTnCsn/j52jf2dK1Yo5nIt7QsUOYbich3tzQi77XI9FV26SwM1kcmqbzm6vKtosqT1n/5mJioqqcFmXCZk+Pj7GlifZ2dnlbnaenZ1tXDs6i7lr1y4mTZqE1Wpl0KBBLFiwoMiK2aCgICZNmkTPnj156KGHyM7O5s9//jPffPMNgbVwwy9///y9yOqL/+5vXqVefvll45lcRzRs2LDMP7C+vr48+uijPProo3a37eXlxcSJE+06/7xPnz706dOn1PfDwsJKnVEtrF+/fvTr16/MMpfPcF5u2rRpTJs2rdy+RESkdnKZkOnn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hoiISNlyLZCd49ivXEtNj16k1vJwZmNms5m1a9eyevVqTp48CeSHSoD27dszevRoevXqxTfffMPatWtJSkoiOTmZ6dOns2zZMrp16+bM4YiIiJTPaoXIXx2re0tn545FpA5xSsjcvXs3q1atYseOHVgsFiNYenh4MGDAAB544AF69epllO/UqRNTp04lIiKCd999l5ycHP7xj3/w//7f/3PGcERERESkhjkcMhMTE1m9ejVr167lzJkzwP9mLVu3bs2oUaO4//77CQwMLLG+p6cn48ePJykpiaVLlxITE+PoUERERESklrE7ZG7bto1Vq1axZ88erFarESzd3Nzo378/DzzwAP379zeewSxPly5dAEhOTrZ3KCIiIiJSS9kdMqdOnYrJZDLCZfPmzbn//vsZNWoUrVq1snsADRo0sLuOiIiIiNRuDt8u7927Nw888AADBgzA3d3d4QF07tyZZcuWOVxfRESkMpLMbphz2zpU19/sRqD98ysi9YLdIXPChAmMHj2adu3aOWUATZo0oUePHk5pS0RExF5mM0SEO3ZAyNgXUMgUKYXdIfO5556rinHYxWazsWXLFtatW0dMTAxms5mmTZsSHBzM0KFDGTlyJB4eTt2dCYC8vDy2bt3K1q1bOXz4MOfPn8dkMnHFFVfQvn17wsLCuOOOO7jyyiud3reIiIiIK3F+EqtiqampTJ8+ncjIyCKvJyUlkZSURGRkJBERESxatIjWrVs7rd8jR44we/Zsjhw5Uuy9jIwMTp48ye7duzl37hyzZ892Wr8iIiIirsjukJmTk8PSpUux2Wz069ePzp3L34j2119/ZdeuXbi5uTFx4kSHZxlzcnKYPHkyBw4cAKBVq1aMHj2aoKAgEhMTWbNmDbGxsURHRzNhwgRWrlyJr6+vQ30VFhUVxcSJE0lPTwegR48e9O3bl1atWuHu7k5SUhLR0dHs3Lmz0n2JiIiI1AV2p71vvvmGhQsX4uHhwejRoytUp1WrVixZsoS8vDyCg4MZNGiQ3QMFiIiIMAJmaGgo//rXv2jSpInx/rhx45g8eTJ79uzht99+Y/HixcycOdOhvgqcP3+eyZMnk56eTrNmzXj//fcJCwsrsWxeXh4XLlyoVH8iIiIidYHdZ5d///33AISFhdG8efMK1QkMDKRnz57YbDa2b99ub5cAWCwWlixZAoDJZGLe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Tzu1bREREZG6wuHV5QXHRVaU9b/n7losFof6i4yMxPzf+2E9e/akQ4cOJZYLCAhg8ODBQP7t9e+++86h/kry66+/smzZMgBefvnlKrkVLyIiIlIX2B0ymzVrBsDJkyftqvfHH38AFJt9rKi9e/ca13379i2zbOH3C54hrazc3Fxmz56N1Wrl9ttv54477nBKuyIiIiJ1kd0h87rrrsNms7F161a76n3zzTeYTCauvfZae7sE4Pjx48Z1aGhomWWvv/564/rEiRMO9Xe5jz76iOPHj9OoUSPjmUwRERERKZndIbNfv34AHDt2jPDw8ArVWb58OceOHQOgf//+9nYJQFxcnHHdpk2bMsu2bNkSd3d3IH/G1d5b+5eLjY01ngd9+umndRa7iIiISDnsDpn33nsvV1xxBQBvvfUWCxYsIDMzs8SymZmZvPfee8ydOxeTyUSzZs0YoHERAAAAIABJREFUNWqUQwO9ePGicV1wy740Hh4exvOSFoul1PFVhNVqZfbs2eTk5HD99dczbtw4h9sSERERqS/s3sKoYcOGzJkzh6eeegqr1cqHH35IeHg4YWFhBAcH4+PjQ2ZmJrGxsezfv5+MjAxsNhvu7u689dZbxspvexUOil5eXuWWL1wmIyODRo0aOdTv559/zs8//4y7uzt//etfcXNz/kmcldnWqaIuXbpULf2IffS5OEdycnOSkqwO179wwY2YmKI7XzT2vYq8nFyH2rNkW4mJ+U/RF23XODo8AKw2W/HfK5Vo09ntVUWbJbVnI9jh9kprsz7+HKtijJX5bPRzdE6bJbVXk//OOHT2Yr9+/XjnnXeYPXs2WVlZpKens337drZv316kXMFtah8fH958802Hb5XXlISEBObPnw/AI488QqdOnaqkn44dO1ZJu4XFxMRUSz9iH30uznHsWOX2uQwIgJCQgCKvxRzOxT0hyaH2PNybE3LZ53os2rGdNQq4mUxObdPZ7VVFmyW1F3PYseBfVpv18edYFWOszGejn6Nz2izxc3HyvzNRUVEVH4+jnQwePJj169czatQofH19sdlsxX75+voyZswY1q9fz9133+1oVwBFZkArcsJO4TKOzmK+9tprZGZm0qZNG6ZNm+ZQGyIiIiL1kUMzmQXatWvHX//6V15//XWOHTtGYmIi6enp+Pr60rJlS0JCQordXk5KSiLQgSkHPz8/UlNTAUhOTi4zOFosFtLT0wHw9PR06Bb9+vXr2blzJwCvvvqqw7f5RUREROqjSoXMAm5ubnTs2LHU6ViLxcL27dtZu3Yte/bs4fDhw3b3ceWVV3Lq1CkATp8+Tdu2bUstm5iYSF5eHgDt27fHZDLZ3d+qVasACAwMJDo6mujo6BLLFV6Q9NlnnxnnuY8ePdpYICUiRVXmrHGdMy4i4hqcEjJLc/ToUdasWcPGjRtJSUnBZrM5FPgArr32Wvbs2QNAdHQ0YWFhpZYtHGJLOxmoopKSknj//fcrVPbjjz82rm+77TaFTJFSVOascZ0zLiLiGpy+VDolJYXly5czcuRIRo4caZwfXrAIyNGjGPv06WNcF4TN0hQ+5ae804FERERExPmcMpNps9nYtWsXa9asYceOHVgsliIboHt4eNC7d2+GDx/O7bff7lAfYWFh+Pv7Yzab+eGHHzhx4kSJs5QXLlxg8/9v786jorjyvoF/m1UFRdG4oaIjARXFbSKaccEFUUTcEo3LBDTRKGPQmBkx+kyiMwa3x8S4xaNGyUowuEeJRk0kip0EF4yAIESQXQyLKGFput4/eKmnEbobmmq6G76fczzn0nXr3lt97a5fV9W99+xZAJXTGOla3+eff16nfOPGjUNGRgYA4OLFixpv4xMRERE1Fw0KMu/fv49jx47h5MmTyM2tnOqjKriUyWRwdHTEvHnz4OPjA3t7+4Y11MICS5cuRXBwMARBQFBQEA4fPlxtLfTS0lIEBQWJc2rOnz9f7cTta9aswfHjxwEAy5cv5+hxIiIiIgnVO8h8+vQpzp49i6NHjyImJkZ8vSq47NSpE3JycgAAPj4+ePXVVyVqKjB37lycP38e0dHRiI2NxbRp0zBnzhw4OjoiOzsb4eHhSE5OBgA4OTkhICBAsrqJiIiIqO7qHGTK5XIcO3YM33//PUpKSgD8X2DZsmVLeHp6Yvr06Rg+fLjeJi23srLC3r17ERgYCLlcjqysLOzYsaNGPldXV+zevVsc6U1EREREjUtjkJmRkYHjx4/j+PHjyMzMBPB/gaWZmRmGDx+OadOmwcvLCy1bttR/awHY2dkhJCQEEREROHnyJOLi4pCfnw87Ozs4OTlhypQpmDlzJiws9DpwnoiIiIg00BiJTZgwAQCqDeJ5/vnn4evrC19fX3Tq1Em/rVNDJpPB29sb3t7eOpexefNmbN68ucFteXYpTSIiIiLSEmRWzWspk8kwdepULFy4kOssExEREZFWdb6nHBERgSdPnmDGjBnw8PCApaWlPttFRERERCZM42TsM2fORMuWLSEIAsrLy/HDDz8gMDAQI0eOxHvvvYcbN240VjuJiIiIyIRoDDKDg4Nx9epVbNq0CS+88AKAylvohYWFOHLkCObPnw9PT0/s3r0bDx48aJQGExEREZHx03q7vGXLluISkWlpaeLk61WjzdPT07Fnzx7s2bMHgwYNgq+vr94bTURUjVIJKATt+dTuL4MeVtklImrW6jXPT/fu3bFixQpxnsqjR4/iwoUL4ryZt27dwq1bt8T8GRkZKCsrg5WVlbStJiJSpVQC6Q8bsH9HMMgkIpKWTpNJymQyjBgxAiNGjMCTJ0/w7bff4tixY7h9+7a4HQBOnDiBCxcuYOLEifD19YW7u7t0LSciIiIio9Xgn+62trZ45ZVXcOTIEZw5cwYLFy5E+/btIQgCBEFAUVERjh07Bn9/f4wdOxbbt2+Xot1EREREZMQkvT/Uu3dvBAUF4fLly/j444/h6ekJCwsLMeDMysrCwYMHpaySiIiIiIyQXtZeNDc3x9ixYzF27Fjk5eXh1KlTOH78OBISEvRRHREREREZGb0v8G1vbw9/f3/4+/sjNjYWx48f13eVRERERGRgeg8yVbm6usLV1bUxqyQiIiIiA+CcHUREREQkOQaZRERERCQ5BplEREREJDkGmUREREQkOQaZRERERCQ5BplEREREJDkGmUREREQkOQaZRERERCQ5BplEREREJLlGXfGHiAgAoFQCCkHHfWXg72MiIuPHIJOIGp9SCaQ/1HHfjmCQSURk/PhNTURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSszB0A4jIyJUrAKVS9/3NzABLftUQETU3/OYnIs2USkB+W/f9h7tJ1xYiIjIZvF1ORERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESS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qpOIiIjI1JnMwB+FQoF9+/YBAGQyGbZs2VItwAQAa2trbN26Fa1atQIAfPHFF8jPz9e5zrt37+LChQsAgK5du+K9996rFmACgIODA9avXy/+vWvXLp3rIyIiImoqTCbIlMvlyMvLAwCMGDECzz//fK352rdvD29vbwCVt9cvXryoc51nz54V07Nnz4a1tXWt+UaPHg1HR0cAwJ07d2o8u0lERETU3JhMkHn16lUxrW0kt+r2n376Sec6r1y5Uqc6ZTIZRo4cKf4dGRmpc51ERERETYHJBJmJiYli2tXVVWPe/v37i+l79+7pVJ9SqURycjIAwMLCAn369NF7nURERERNhckEmSkpKWLawcFBY97OnTvD3NwcAJCamgpBEOpdX3Z2NkpKSgAAnTp10jrvpup0SaptJSIiImqOTCbILCoqEtPt2rXTmNfCwkKcukihUKC4uLje9T1+/FhMt23bVmt+1Tyq+xIRERE1RzJBl8t8BtC/f3+Ul5cDAGJjY7VeWRw1ahQePnwIoPK5zI4dO9arvhs3bmDu3LkAgCFDhiA0NFRj/pSUFHh5eQEAevbsiXPnztWpnuvXr9erXURERESGNHTo0DrlM6l5MpuiunYUERERkSkxmdvlVXNfAkBpaanW/Kp5bGxs9F5f1fObutZHRERE1JSYTJDZunVrMa1tgnWFQoEnT54AACwtLasFjHXVpk0bMV1QUKA1v2oe1X2JiIiImiOTCTJ79uwppjMyMjTmzc7ORkVFBQCgR48ekMlk9a6vc+fOaNGiBQAgJycHCoVCY/7MzMxa20pERETUHJlMkOns7CymY2NjNea9c+eOmFa3MpA2ZmZm6N27N4DKK6N3797Ve51ERERETYXJBJmqK+qorsRTG9VVfrStDqSJ6r6a6hQEodr20aNH61wnERERUVNgMkGmu7s77O3tAQBRUVFqV9X5448/xDXHra2tMX78eJ3rnDx5spgOCwtTOwAoMjISqampACqnWurevbvOdRIRERE1BSYTZFpYWGDp0qUAKq8cBgUFobCwsFqe0tJSBAUFiZOvz58/X+3E7WvWrIGLiwtcXFywa9euWvP06dMHEyZMAFD5zOV//vMfKJXKankyMzOxfv168e8333xTp+MjIiIiakpMap7MuXPn4vz584iOjkZsbCymTZuGOXPmwNHREdnZ2QgPDxfXG3dy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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for ResNet-18_SN\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(resnet18_sn_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"resnet18_sn\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Before temperature - NLL: 0.302, ECE: 0.016\n",
      "Optimal temperature: 1.200\n",
      "After temperature - NLL: 0.296, ECE: 0.024\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApkAAAIICAYAAAAllfW0AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+j8jraAAAgAElEQVR4nOzdeViU5eL/8fcAiiCoQO4ilhoqZlkquZdZdtwrtSzTrKOWa1l91TyVdU6mld/suBzT82tRC03F3MtMUymxxLJERPOEqYiOsskiMMz8/uAwX5B1hmEZ+Lyuy+t6mLm34VH88DzPfd8Gi8ViQURERETEgVwqewAiIiIiUv0oZIqIiIiIwylkioiIiIjDKWSKiIiIiMMpZIqIiIiIwylkioiIiIjDKWSKiIiIiMO5VfYAbJWdnc2ZM2c4fvw4kZGRHD9+nJMnT3L9+nUApk6dyrRp0xzeb1paGuvXr+frr7/m7NmzpKSkcNNNN3H77bfzyCOP0Lt3b7vajYiIcPBIRURERMrPXXfdVapyThcyn3/+eXbv3l2hfZ44cYLp06dz7ty5fK/HxsYSGxvLrl27GDJkCPPnz6d27do2t1/ak1UWUVFRtG/fvtz7EdvovFRdOjdVk85L1aVzUzU5+rzYcnHM6UJmdnZ2vq8bNGhAgwYNiImJKZf+Lly4wIQJE7hy5QoAnTp1YujQofj4+HDq1CnWr19PYmIi27Ztw2Aw8O6775bLOEREREScidOFzE6dOtG6dWuCgoIICgrC39+f0NBQ5syZUy79zZ8/3xowH3nkEf7xj3/g4vJ/j7I++uijjBkzhtjYWLZu3cqgQYO45557ymUsIiIiIs7C6ULms88+W2F9nTx5kj179gDQrFkzXn/99XwBE6B58+bMmzePiRMnArBkyRKFTBEREanxNLu8GDt37rQejxo1Cnd390LL9enTh4CAAACOHz9e4NlNERERkZpGIbMYYWFh1uPiZo8bDAZ69epl/frAgQPlOi4RERGRqk4hswhms5kzZ84A4ObmRrt27Yot37FjR+vx6dOny3VsIiIiIlWdQmYR4uLirGtvNm7cGDe34h9fbdasmfW4vGa6i4iIiDgLhcwiJCcnW48bNGhQYvm8ZfLWFREREamJnG52eUVJS0uzHhc14SevOnXqWI9TU1Nt6isqKsqm8va4fv16hfQjttF5qbp0bqomnZeqS+emaqrM86KQWQVUxA4J2omhatJ5qbp0bqomnZeqS+emaqrMHX90u7wInp6e1uOMjIwSy+c+vwlQt27dchmTiIiIiLNQyCxCvXr1rMeJiYklls9bJm9dERERkZpIIbMITZo0sT5neenSJUwmU7HlY2NjrcetWrUqz6GJiIiIVHl6JrMILi4utG7dmsjISEwmEydPnsy3FuaNjh8/bj1u27ZtRQzRymw2k5qayrVr14q8tW+xWPjjjz8qdFxSMp2Xqqsyzo27uzve3t7UrVu3wBa2IiLORiGzGL179yYyMhLI2f2nqJBpsVjy7Q7Up0+fChkfQHZ2NufOncPDwwMfHx/q1KmDwWAoUC49PR0PD48KG5eUjs5L1VXR58ZisXD9+nWSk5O5evUq/v7+uLq6Vlj/IiKOpl+Vi/GXv/zFerx+/foirxIeOHCAs2fPAjk7//j7+1fI+MxmM+fOneOmm26icePGeHh4FBowRaTqMxgMeHh40LhxY2666SbOnTuH2Wyu7GGJiNitxobM2bNnExgYSGBgIEuWLCm0TLt27ejfvz+Q88zlm2++WeCHfmxsLPPmzbN+PW3atHIb841SU1Px8PDAy8urwvoUkfLn5eWFh4eHzWvuiohUJU53u/zcuXNs3Lgx32vR0dHW4/Dw8AKTdAYMGECHDh3s6u+VV17hl19+4cqVK2zcuJHTp08zbNgwGjRowKlTp1i3bp11ZvmQIUO455577OrHHteuXcPHx6fC+hORilOvXj0SEhLw9vau7KGIiNjF6UJmbGwsK1asKPL9I0eOcOTIkXyvBQQE2B0ymzdvzqpVq5g+fTrnzp3j2LFjHDt2rEC5wYMHM3/+fLv6sFdGRka+nYZEpPqoU6dOqdboFZHqxWiE+Hj76vr6QsOGjh1PWThdyKwMHTp0YOvWraxfv56vv/6amJgYUlNT8fPz4/bbb+eRRx6p0Mk+eekZTJHqSf+2RWqm+HgICbGv7ujRCpllEhwcnO/2uL0WLFjAggULSl3e09OT8ePHM378+DL3LSIiIlLd1diJPyIiIiJSfhQyRURERMThFDJFRERExOEUMkVERETE4RQyRUQc6PDhwyVu9CAiUiSzGUzZ9v2pYruEOd3scpGqKDAw0OY67dq1Y926deUwmuorKiqKPXv2ANC/f3/at29fySMSEXEwsxnOX7azbiOq0vVDhcyaJMtU5X7LKVcuLlBLf8Wrk6ioKJYuXQrkbJSgkCkiUnXpf+CaxGyG8F8rexQV5+5OldLtsmXLSlVOe86LiEh1ppAp4mD9+/cvddn09PRyHImIiEjlqTo37kVERESk2tCVTJEq4scff2TcuHGYzWaaNm3K1q1bqVevXqFlz507x/Dhw0lJScHT05NNmzZxyy23WN9fsmSJ9dnF1atXExwczP79+1m3bh2RkZHEx8fj6+tLly5dePLJJ+ncuXOpxhgfH8/69es5ePAgZ8+eJSkpCS8vL2655RbuvfdeHn/8cerWrVuqtg4dOsTOnTs5cuQIRqOR9PR0vL29ueWWW+jatStDhgyhTZs2AISGhjJnzpx89efMmVPgtebNm7N3795C+zt9+jQbN24kPDycixcvkpaWho+PD0FBQQwcOJDBgwfj4lLy791Hjhzhs88+48iRIyQmJuLr60tQUBCPPfYYffr0KdVnFxGpCRQyRaqIbt26MXHiRFasWMHFixd59dVX+eCDDwqUM5lMvPTSS6SkpADwyiuv5AuYhXnjjTf4/PPP87126dIlduzYwa5du5gyZQpTp04tto3Q0FD+8Y9/kJqamu/1hIQEIiIiiIiI4JNPPmHp0qXFhtb4+HhefPFFfvjhhwLv5W1rxYoVREdHFzum0jCZTCxYsIDPPvsM8w0T3y5fvszly5fZt28fa9euZdmyZTRs2LDItt5//30+/PBDLBaL9bW4uDji4uL49ttvGTNmDA888ECZxywiUh0oZIpUIdOmTePQoUMcO3aMr776io0bNzJixIh8ZZYuXcovv/wCwIABAxg5cmSxba5evZo9e/bg4+PDyJEjCQwMJD09nYMHD7J7927MZjNLliyhQYMGjBkzptA2Pv30U+bPnw+Ah4cHAwYMoHPnzjRo0ICEhAQOHjzI3r17uXLlCuPHj2fjxo3Wq5B5xcfHM3LkSM6fPw+At7c3gwYN4rbbbsPLy4vExESioqL47rvviIuLs9a7++67WbZsGeHh4axZswaAJ598krvvvjtf+3Xq1Mn3tcVi4fnnn+ebb74BoGHDhgwaNIh27dpRp04dYmNj2bFjB5GRkRw7doynnnqKjRs34uHhUWDs//73v1mxYgUABoOBgQMH0qNHD+rUqcPJkyfZsGEDa9eu5dKlS8WeDxGRmkIhU6QKcXNzY9GiRQwbNozU1FTeeustunTpQqtWrYCcW7UrV64EoGnTpvz9738vsc09e/bQtm1bPv30U/z8/Kyvjxw5kj179jBjxgxMJhPvvfce/fr1o1mzZvnq//bbb7zzzjsAtG/fnuXLlxcoM3r0aPbt28e0adNIT0/nlVde4YsvvigwllmzZlkDZvfu3Vm8eDENGjQoUM5isfDtt99av27WrBnNmjUjOTnZ+lqHDh1KnGS1evVqa8AcOnQob775ZoEA+fTTT7N48WJWrFjB77//zrJly3jppZfylfnzzz+tV5Vr1arFsmXL6Nu3r/X9wYMHM27cOMaOHWvtT0SkptPEHxEHy93tpaQ/oaGhhdb39/fntddeAyAtLY0XX3yRrKwskpOTefnll8nOzsbFxYV3332X+vXrlzgeNzc33n///XwBM1f//v0ZP348kDPTPSQkpECZZcuWYTKZqFu3Lh9++GGBgJnr3nvvZcKECQAcO3aMo0eP5nv/6NGjHDhwAICAgACWL19eaMCEnCuFtszSL0xGRgYffvghALfddhsLFy4s9AqlwWDghRdeoEuXLgCEhISQkZGRr8yaNWvIzMwE4Nlnn80XMHM1bNiQ999/H1dX1zKNW0SkulDIFKmChg8fzuDBgwE4fvw4H3zwAa+99hqxsbEATJw4ka5du5aqrV69etG2bdsi3x83bpw1GN14FS4pKYn9+/cDOVfrGjduXGxfQ4cOtR5///33+d7btm2b9fi5557D09OzVOO318GDB7l69SoATz31VImTenLHnpKSYn0cIVfuLkO1atUq8pECyNnFqWfPnmUZtog4EaMRoqPt/2M0VvYnKF+6XS7iYKVdjL1Dhw7Fvv/GG2/wyy+/cP78eVatWmV9/Y477mDatGmlHk/37t2Lfb9hw4a0bt2aU6dOERMTw7Vr1/D29gZyrj7mTpZxcXGxhq2iZGVlWY/PnDmT772IiAgg58rhvffeW+rx2yu3P8gJyyWNPe+zlGfOnKFTp5zF/K9evWoN9+3bty/y6muu7t27W6/Yikj1Fh8PhdwAKrXRo6GYuYZOTyFTxMEctRi7l5cX7733HmPGjMFkMuV7zc2t9P90W7ZsWaoyp06dwmKxYDQarSHzwoUL1jIhISGF3k4vSt7nJ+H/Qpyfn1+JQc0R8o79zTfftKlu3rFfvvx/ewiX9nspIiK6XS5SpTVp0iTfc4RBQUH4+/vb1EZhzyEWVyYtLc16fO3aNZv6yivvVU3AuuRSed8mz+Woseddsqk038uK+nwiIlWdrmSKVFFms5mXX345X1g6fPgwn3/+OY8//nip2ynN1pV5y+QNSXmP58+fzyOPPFLqfm+Uu0RR3hBbnvKOfc+ePTaH89zvSd7F5UvzvayozyciUtXpSqZIFfXhhx/y008/ATnP+eXewl64cGGB5x2L8+eff5a6jMFgyLcYed6JPnnXrbRHbltXr14lMTGxTG3Z0h9QprUrGzVqZD225XspIlLTKWSKVEHHjh2zbgvZqFEj3n//febNmwfA9evXmTlzpnVJnZKEh4cX+77RaLSG1latWlnDLEDXrl0xGAxAwdnitspdIshisbBv3z672sg7QzzvrjuFyTv7PiwszK7+IOcZ0ubNmwMQFRVFUlJSseUPHTpkd18i4mTMZjBl2//nhl3IqhuFTJEqJiUlhZdeegmTyYTBYGDhwoX4+PgwePBghg0bBsDJkyd57733StXewYMHi73yuWbNGrKzswEKbIno5+dH7969gZzZ2mUJa3mXN1qxYoVdt5Xz3gIv6dZ137598fHxAXImLeWdwGOr3MlcWVlZrF27tshyp06dKnMYFxEnYjbD+Uv2/1HIFJGK9Oabb1pvuY4fP54ePXpY33vttdeszxauXr2agwcPltieyWTi+eefJz4+vsB7e/fu5aOPPgJyJrWMHj26QJnnn3+eWrVqATBz5swSl+e5cOECCxcutK5RmeuOO+6wLmIeExPDlClTirxtfuOOP7latGhhPY6MjCx2HJ6entb92BMTE/nrX/9KTExMsXWOHTtm3d0orzFjxlC7dm0gJyAXFravXLnCzJkzrYFdRKSm08QfEQcraT3GvLp165ZvxvL27dvZsmULkLOO5gsvvJCvvJeXF4sWLeLxxx/HZDIxZ84ctm7diq+vb5F99O/fnz179jBo0CBGjRrFrbfeSnp6OmFhYXz11VfW284vvfQSTZs2LVA/KCiI119/nVdffZWkpCQmTJjAnXfeSZ8+fWjRogVubm4kJSXxn//8h4iICI4fPw7kLPJ+owULFlj3Lv/hhx+4//77GThwoHXv8uTkZKKjo9m3bx8XLlwgOjo6X/1bb70VPz8/rl69yrZt2/D19eWOO+7A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REREREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE4hU0REREQcTiFTRERERBxOIVNEREREHE47/oiIiDiQ0Qjx8fbX9/WFhg0dNx6RyqKQKSIi4kDx8RASYn/90aMVMqV60O1yEREREXE4hUwRERERcTiFTBERERFxOIVMEREREXE4TfwRERGp6sxmMFnsrGtA15SkMihkioiIVHVmM5y/bGfdRihkSmXQ3zoRERERcTiFTBERERFxOIVMEREREXE4hUwRERERcTiFTBERERFxOM0uFxGRGs1ozNlv3B6+vtpnXKQoCpkiIlKjxcdDSIh9dUePVsgUKYpul4uIiIiIwylkioiIiIjDKWSKiIiIiMMpZIqIiIiIwylkioiIiIjDKWSKiIiIiMMpZIqIiIiIwylkioiIiIjDaTF2ERERRzKbwWQpQ30DugYk1YFCpoiIiCOZzXD+chnqN0IhU6oD/S0WEREREYdTyBQRERERh1PIFBERERGHszlkXrt2rTzGISIiIiLViM0hs3fv3syePZsjR46Ux3hEREREpBqwOWRev36dLVu28OSTTzJw4EA++eQTEhMTy2NsIiIiIuKkbA6Zbdu2xWKxYLFY+OOPP1i4cCF9+vThxRdf5NChQ+UxRhERERFxMjaHzG3btvHFF1/wyCOP4OHhgcViITMzk507d/L000/zwAMPsHLlSq5evVoe4xURERERJ2DX7PJOnTrx1ltvERYWxptvvsltt91mvbp57tw53n//ffr27cv06dM5cOCAo8csIiIiIlVcmZYw8vT0ZNSoUWzYsIEtW7bwxBNP4O3tjcViwWQy8c033zBp0iT69evH8uXLuXTpkqPGLSIiIiJVmMPWyQwMDOTVV1/l4MGDLFiwgK5du1qvbsbGxrJkyRL69evHs88+y969ezGbzY7qWkRERESqGIcvxu7u7s7w4cNZs2YNu3btYsSIEQBYLBays7PZv38/U6ZMoV+/fqxcuZLU1FRHD0FEREREKlm57fjz008/sXz5crZv347BYMBgMABYr27GxcXx/vvv079/f/bs2VNewxARERGRSuDmyMbi4+MJDQ1l48aNnD17FsgJlQAtW7Zk1KhR9OjRg6+//prQ0FCMRiMJCQlMnz6d1atX06VLF0cOR0REREQqiUNC5sGDB9mwYQP7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nzZt2jBo0CAefvhh3Nwc9rgpvr6+rF69ml27drF9+3ZOnDjBlStXqFOnDv7+/vTu3ZsnnniCxo0bO6xPEREREWdmcxLLffawcePGvPzyy7i4FD1B3dfXl1deeYXWrVvz+uuvM23aNL788st8z1Haw2AwMHDgQAYOHGh3GwsWLGDBggUV2qeIiIhITWHzEka5VzGHDh1a6NXCwp7PfPTRR+natStxcXGEhITYN1IRERERcRo2h8yEhASAAjvu5F7RLGpf8QceeACLxcKePXts7VJEREREnIzNITP3SuWNt7xz9xK/cuVKofX8/PyAnC0hRURERKR6szlk5obFG/fnzp05fvr06ULrXbp0qdB6IiIiIlL92Dzxp3Xr1sTFxfHnn3/me719+/acOXOGvXv3cv36derUqWN9z2KxsGXLFgAaNmxYxiGLiEh5MBohPt7++r6+UOBHvNkMJjvXUjYbcKLdj0XkBjaHzDvvvJOwsDCOHj2a7/UBAwawfft2EhISmDp1KnPmzMHf359z587xwQcfcPLkSQwGA3fffbfDBi8iIo4THw9lmZs5enQRIfP8ZfsaNDdCIVPEedkcMvv27cs///lPfv75Z65evWq9fd6/f386dOjAiRMn+P777xk8eHCBuu7u7vz1r38t+6hFREREpEqz+VfEoKAgpk6dyvjx47l48aL1dYPBwL/+9S9at26NxWIp8MfDw4NFixZxyy23OPQDiIiIiEjVY9e2OFOnTi309caNG7Nlyxa2b9/OoUOHuHLlCh4eHtx22208/PDDeh5TREREpIZw3N6LuQ26uTF8+HCGDx/u6KZFRERExEnYHDK//PJLAG666SZ69erl8AGJiIiIiPOzOWTOnj0bg8HAlClTFDJFREREpFA2T/zJ3dlHE3hEREREpCg2h8zGjRsDRe9RLiIiIiJic8js2bMnAD///LPDByMiIiIi1YPNIfPxxx+ndu3abNmyhf/85z/lMSYRERERcXI2h8ybb76ZN954g+zsbMaNG8d3331XDsMSEREREWdm8+zypUuXAtCtWzd++OEHnnvuOZo1a8Zdd91F48aNcXd3L7GNohZzFxEREZHqwa6QaTAYgJytJC0WC7GxscTGxpa6DYVMERERkerNrh1/LBZLsV8XJzegioiIiEj1ZXPIXL16dXmMQ0RERESqEZtDZrdu3cpjHCIiUtnMZjCV/s5UwfoG7JhPKiLVlF23y0VEpBoym+H85TLUb4RCpojkUsgUEXFSRiPEx9tX19cXGjZ07HhERPJSyBQRcVLx8RASYl/d0aMVMkWkfNkcMn/66acyd9q1a9cytyEi4kzKctURdOVRRJyPzSHzySefLNMyRAaDgRMnTthdX0TEGZXlqiPoyqOIOB+HrJMpIiIiIpKXzSGzNLv1mM1mEhISOHbsGCdOnMBgMNCvXz/at29v1yBFRERExLmUS8jMKyIigpdffpkffviBUaNG0bdvX1u7FBEREREnU+4Lmt1111188sknALz88stcuHChvLsUERERkUpWIavmtmzZkqFDh5KcnKxtKUVERERqgArbmqFz584AfPfddxXVpYiIiIhUkgoLmbVr1wbg0qVLFdWliIiIiFSSCguZx48fB6BWrVoV1aWIiIiIVJIKCZknTpxg3bp1GAwG2rZtWxFdioiIiEglKrdtJbOysrh8+TLh4eHs2LGDrKwsDAYDw4YNs3mQIiIiIuJcKmRbydwdgnr06MHIkSNt7VJEREREnEyFbCtZr149xowZw7PPPouLS4U9BioiUr2ZzWCyc5tfs4EKfCxfRGqgctvxp3bt2nh7e9OmTRtuv/126+xyERFnkJ3tQ3S0fXV9faFhQ8eOp1BmM5y/bGfdRihkikh5KvdtJUVEnFFyci1277av7ujRFRQyRUSqMP0aKyIiIiIOp5ApIiIiIg5n18SfixcvYrFYqFevHl5eXiWWT0lJITk5GRcXF5o0aWJPlyIiIiLiRGy+kvnrr79y77330r9/fyIjI0tVJyoqin79+tGvXz9Onjxp8yBFRERExLnYHDJ37doFQEBAAMHBwaWq07VrV1q3bo3FYmHHjh22dikiIiIiTsbmkBkREYHBYKBv37421evTpw8Wi4UjR47Y2qWIiIiIOBmbQ+bZs2cBbN6DPLd8TEyMrV2KiIiIiJOxOWSmpqYClGrCT15169YF4Nq1a7Z2KSIiIiJOxubZ5XXr1iU5OZnk5GSb6iUlJQFQp04dW7sUESmW0Qjx8fbXr7AdekREahCbQ2aTJk1ITk7m6NGjjBw5stT1fv75ZwAaNWpka5ciIsWKj4eQEPvra4ceERHHs/l2edeuXbFYLOzatYtLly6Vqs7FixfZuXMnBoOBrl272jxIEREREXEuNofM4cOHA5CRkcFzzz3H1atXiy1/5coVpkyZQkZGBgAPPfSQHcMUEREREWdic8js2LEjgwYNwmKxEBUVxeDBg1m+fDknT54kMzMTgMzMTE6ePMmyZcsYMmQIUVFRGAwGBgwYwB133OHwDyEiIiIiVYtd20r+4x//4OzZsxw/fpzExESWLFnCkiVLAHB1dSU7O9ta1mKxANCpUyfefvttBwxZRERERKo6u0Kmh4cHn3/+OfPnz2fjxo2YTCbre3mPAdzc3Bg1ahSzZ8+mdu3aZRutiFQLZZkN7rQzwc1mMFnKUN+AHTefREQqjV0hE6B27drMmzePSZMmsXPnTiIiIoiLiyM1NZW6devSpEkTunTpwsCBA2nSpIkjxywiTq4ss8Gddia42QznL5ehfiMUMkXEmdgdMnM1bdqUZ555hmeeecYR4xERERGRakC/FouIiIiIwylkioiIiIjD2Xy7PCUlhfnz52OxWHj44YdLtbj6Tz/9RGhoKK6urvztb3/T1pIiIiIi1ZzNVzJ37txJaGgou3btol27dqWq065dO7766is2bdrEV199ZfMgRURERMS52BwyDx48CECvXr3w9vYuVR1vb2969+6NxWLhu+++s7XLAiwWCzt37mTSpEn06dOHjh070qtXL8aNG8eGDRsKLKNUHpKSkujZsyeBgYHWP+fPny/3fkVEREScgc23y3N37+ncubNN9Tp37szu3buJioqytct8kpKSmD59OuHh4fleNxqNGI1GwsPDCQkJYenSpTRr1qxMfRVnwYIFXLlypdzaFxEREXFmNodMo9EI5CxdZIvGjRsDcPmy/evEZWZmMnnyZI4cOWIdw6hRowgICCAuLo5NmzZx5swZIiMjmTBhAuvXr8fLy8vu/ory/fffExoaiouLC7Vq1bLuyy4iIiIiOeyeXZ67XWRpmc1moOCOQLYICQmxBsygoCC2bNnC5MmTGTRoEM888wybN2+mV69eAPz+++8sW7bM7r6Kkp6ezmuvvQbAE088wU033eTwPkREREScnc0h08fHB4CzZ8/aVO/PP/8EoH79+rZ2CeSE0xUrVgBgMBhYuHBhgbbc3d1555138PT0BGDt2rUkJCTY1V9RFi9ezPnz52ncuDHPP/+8Q9sWERERqS5sDpnt2rXDYrGwe/dum+p9/fXXGAwGbr31Vlu7BCA8PJz4/2523L17d9q2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khyDTCIiIiKSHINMIiIiIpIcg0wiIiIikhyDTCIiIiKSnJWxG0BkMOUKQKnUfX8LC8CaHxEiIiJd8AxKjZdSCchv677/EA/p2kJERNTE8HY5EREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJzsrYDSASlSsApVK3fS0sAGv+dyYiIjIVPCuT6VAqAflt3fYd4iFtW4iIiEgvvF1ORERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSszJ2A8hMlSsApVL3/S0sAGv+9yMiImqseJYn3SiVgPy27vsP8ZCuLURERGRyeLuciIiIiCTHIJOIiIiIJMcgk4iIiIgkxyCTiIiIiCRnlgN/BEFAeHg4Tp48ifj4eOTn56N169bo0aMHfHx8MH36dFhZSXtoJSUlCA0Nxblz55CamorHjx+jXbt26NevH2bOnInhw4dLWh8RERGROTO7ILOoqAiBgYGQy+XVXs/NzUVubi7kcjlCQkKwe/dudO7cWZI64+LiEBgYiLS0tGqvZ2ZmIjMzE+Hh4ZgyZQo2btwIGxsbSeokIiIiMmdmFWSWlZUhICAA0dHRAIBOnTph1qxZcHJyQnZ2No4ePYrk5GTExsZi0aJFCA0NhZ2dnV51ZmRkYNGiRcjLywMAeHh4wNfXF23atEFiYiJCQ0NRWFiI06dPQyaTYdu2bXofJxEREZG5M6sgMyQkRAww3d3dcfjwYdjb24vb58+fj4CAAFy5cgVJSUnYs2cPgoKC9Kpz48aNYoA5c+ZMbNiwARYW//co6+zZszF//nxkZmbi1KlTmDx5Mry8vPSqk4iIiMjcmc3AH4VCgX379gEAZDIZtmzZUi3ABABbW1ts3boVLVq0AAB89dVXKCgo0LnOu3fv4sKFCwCAzp074/33368WYAKAo6Mj1q1bJ/69a9cunesjIiIiaizMJsiUy+XIz88HAAwdOhQvvPBC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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for resnet18_sn post temp scaling\n",
    "resnet18_sn_temp_model = ModelWithTemperature(resnet18_sn_model)\n",
    "resnet18_sn_temp_model.set_temperature(dirty_mnist_val_loader)\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(resnet18_sn_temp_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"resnet18_sn\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EXE6hUwRERERcTqFTBERERFxOoVMEREREXE6hUwRERERcTqFTBERERFxOoVMEREREXE6hUwRERERcTqFTBERERFxOoVMEREREXE6hUwRERERcTqFTBERERFxOoVMEamR5s6dS0hICCEhIfz000/VPRwREbGTR3UPQKpOUhKYzdU9iqoTGAhBQdU7hpdeeolvvvkGAJPJxPfff0/Lli0rvd8VK1Zw8uRJACZOnFjp/YmIiFxKIfMyYjZDRER1j6LqDB9evSEzMzOT9evXG1/bbDa+/fZbJk2aVOl9f/vtt/z888+AQqaIuKaKXhipCRcaLncKmSKVZOPGjWRmZhZ67bvvvmPixImYTKZqGpWIiGswn7US8aXN4frDR5gICtJTgdVJIVOkkqxYsQIAT09P+vTpw+rVqzl58iSRkZF06dKlmkcnIlLDWa1w4kwF6jdCU0+ql777IpUgPj6eX375BYBu3brx2GOPGe/lP6MpIiJSm+lKpkglWLFiBTZb3m2eQYMGERoaStu2bTl69Cjff/896enp+Pr6ltlOVlYWK1asYMeOHRw6dIjk5GQAgoKCaNeuHd27d6dfv35GWw8//LDxLGa+kJCQIu1OmDDBeFbzp59+YtSoUUVeL055ylosFvbs2cPu3bvZv38/cXFxnD9/Hk9PTxo1asRNN93E/fffT6dOncr8/CIi4roUMkWczGq18t133wFQv359evXqBcCAAQOYPXs2Fy5cYO3atTzwwAOltrNjxw6mTZvG2bNni7x34sQJTpw4wffff89vv/3GO++84/wP4qDHHnusSNAFyMnJIS4ujri4OL799lsGDx7Mm2++SZ06daphlCIiUtkUMkWcLDIykoSEBAD69OljhKiBAwfywQcfYLVaWbFiRakhc926dTz//PPk5uYCeVcj7777blq3bo3JZOLUqVP8+uuv7Nq1y7hiCjB58mRSUlKYM2cOR48eBWD+/PlF2r/yyiud9nkvlZ2djY+PD126dCE0NJTmzZvj5eVFUlISf/75J6tXryYzM5Nvv/0WPz8/pk+fXmljERGR6qOQKeJkBZ+5HDhwoHHcuHFjwsLC2LNnD7/99huxsbE0a9asSP34+HimT59Obm4ubm5uvPjii4waNarYGempqakcOnTI+Lpjx44AfPHFF8ZrvXv3dsrnKq9nn32Wm266ibp165b4/vjx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nTlzhgkTJvDHH38Aec9IViWTyUTfvn3p27evw23MnDmTmTNnVmmfIiIiIpcLu0Om1Wrl6aefNpbsadGiBTfccANr167FZDLRuXNn/P39SUhIICYmBovFgslkomvXrjRq1MjpH0BEREREah67Q+aaNWuIjo7GZDIxatQopk6dipubG2vXrgVg1KhRxrJBZrOZBQsWEB4ezpEjR3j22We57rrrnPsJRERERKTGsXsJo/yleho3bswLL7yAm1vJTQQGBvLSSy/x2muvkZSUxMSJE4ssOyQiIiIitY/dITP/KuaAAQOKnVxT3POZDzzwAJ06dSIxMZGIiAjHRioiIiIiLsPukJmcnAzkPYtZqKH/u6KZnZ1dbL27774bm83G5s2b7e1SRERcldUKllzH/lit1T16EakAu5/JzL9S2aBBg0Kv16tXj/T0dM6ePVtsvYYNGwJw8uRJe7sUERFXZbXCiTMO1m2EC21MJyKXsPtvb35YTE9PL/R6/szxo0ePFlvv9OnTxdYTERERkdrH7pAZHBwMwPHjxwu93q5dO2w2G1u3buXChQuF3rPZbKxcuRKAoKAgR8cqIiIiIi7C7pB58803Y7PZ2LdvX6HX77nnHiDvmc0JEyYQGxvLxYsXiY2NZfLkyRw6dAiTycStt97qnJGLiIiISI1l9zOZPXv25F//+he//vor586dM26f9+7dm/bt23Pw4EF2795N//79i9T18vLiySefrPioRURERKRGs/tKZmhoKBMmTOCxxx7j1KlTxusmk4l///vfBAcHY7PZivzx9vZm9uzZXHXVVU79ACIiIiJS8zi0d/mECROKfb1x48asXLmSNWvWsGfPHs6ePYu3tzfXX3899913n57HFBEREblMOBQyS23Qw4NBgwYxaNAgZzctIiIiIi7C7pD53XffAXDFFVfQrVs3pw9IRERERFyf3SHzxRdfxGQyMX78eIVMERERESmW3RN/6tWrB6AJPCIiIiJSIrtDZuPGjYGS9ygXEREREbE7ZN52220A/Prrr04fjIiIiIjUDnY/k/nQQw/x9ddfs3LlSh599FHdNhcRqSWSksBsdrx+YCBopToRyWd3yLzyyit54403ePnll3nkkUd46623uP322ythaCIiUpqKhMLiAqHZDBERjo9n+HCFTBH5H7tD5rx58wDo3LkzP/74I08//TTNmjXj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Bh8fH/j4+OhcxqZNm7Bp06ZGt+XZpTSJiIiISEuQWT2vpUwmw9SpU7Fw4UJJF1knIiIiouap3veUq9cnnzFjBjw9PWFpaanPdhERERGRCdM4GfvMmTPRunVrCIKAiooK/PjjjwgODsbIkSPx/vvv4+bNm03VTiIiIiIyIRqDzNDQUFy9ehUbN27Eiy++CKDqFnpRURGOHDmC+fPnw8vLC7t27cLDhw+bpMFEREREZPy03i5v3bq1uERkWlqaOPl69Wjz9PR07N69G7t378agQYPg5+en90YTEdWgVAIKQXs+tfvLoIdVdomIWrQGzfPTo0cPLF++XJyn8ujRo7hw4YI4b+bt27dx+/ZtMX9GRgbKy8thZWUlbauJiFQplUD6o0bs3wkMMomIpKXTZJIymQwjRozAiBEj8OTJE3z33Xc4duwY7ty5I24HgBMnTuDChQuYOHEi/Pz84OHhIV3LiYiIiMhoNfqnu42NDV599VUcOXIEZ86cwcKFC9GhQwcIggBBEFBcXIxjx44hICAAY8eOxbZt26RoNxEREREZMUnvD/Xu3RshISG4fPkyPvnkE3h5ecHCwkIMOLOysnDgwAEpqyQiIiIiI6SXtRfNzc0xduxYjB07Fvn5+Th16hSOHz+OhIQEfVRHREREREZG7wt829vbIyAgAAEBAYiNjcXx48f1XSURERERGZjeg0xVbm5ucHNza8oqiYiIiMgAOGcHEREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJjkEmEREREUmOQSYRERERSY5BJhERERFJrklX/CEiAgAolYBC0HFfGfj7mIjI+DHIJKKmp1QC6Y903LcTGGQSERk/flMTERERkeQYZBIRERGR5BhkEhEREZHkGGQSERERkeQYZBIRERGR5BhkEhEREZHkGGQSERERkeQYZBIRERGR5BhkEhEREZHkGGQSERERkeQYZBIRERGR5BhkEhEREZHkGGQSERERkeQYZBIRERGR5BhkEhEREZHkLAzdACIyckoloBAasb8M/D1LRNTyMMgkIs2USiD9USP27wQGmURELQ+/+YmIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwy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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for ResNet-18_SN\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(vgg16_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"vgg16\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Before temperature - NLL: 0.299, ECE: 0.018\n",
      "Optimal temperature: 1.200\n",
      "After temperature - NLL: 0.293, ECE: 0.026\n"
     ]
    },
    {
     "data": {
      "image/png": "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IbNVq1ZYLBb27NljU73du3djMBi48847be0SgODgYGL+u0VIly5daNGiRa7lfHx86NevH5Bxe33fvn129ZebX3/9lTVr1gDw6quvFsuteBEREZGKwOaQ2bNnTwDCw8MJCAgoVJ21a9cSHh4OQK9evWztEsh4DjJTjx498i2b9f3M2fBFlZaWxrx58zCbzTz44IM89NBDDmlXREREpCKyOWQ+9thj1ucQ33nnHZYsWUJycnKuZZOTk/nggw9YuHAhBoMBLy8vhg0bZtdAz5w5Yz328/PLt2zbtm2tx2fPnrWrv1utWrWKM2fOUL16deszmSIiIiKSO5tnl1erVo0FCxbw7LPPYjab+eijjwgICMDf359mzZrh7u5OcnIyERER/PDDDyQlJWGxWHB2duadd96xPi9pq8jISOtxw4YN8y1br149nJ2dSU9P59y5c1gsFgwGg139InDZjgAAIABJREFUAkRERFifB33uueeoV6+e3W2JiIiIVAY2h0zIuGX+3nvvMW/ePFJSUkhMTGT//v3s378/W7nMGeju7u68/fbbdt8qB7h+/br1OHPyUV5cXFzw8PAgPj4ek8lEcnIy1atXt6tfs9nMvHnzuHnzJm3btmXMmDF2tSMiIiJSmdgVMgH69etHu3btWLVqFbt27SIxMTFHGQ8PD/r378+ECRNo1KhRkQaa9Za8q6trgeWzlklKSrI7ZH7xxRf8/PPPODs789Zbb+HkZPeqT3kq6gL1hXHjxo0S6UdsU1nPS2xsHYxGs111r11zIiws+3q7RWkvrzZreNxO+s00u9ozpZoJC/sj+4uW5vYODwCzxZLzz0oR2nR0e8XRZm7tWWhmd3t5tVkZf47FMcainBv9HB3TZm7tlea/M3aHTIDGjRvz1ltv8cYbbxAeHk50dDSJiYl4eHhQr149WrZsmSOUGY1GateuXaRBl5SoqCgWL14MwLhx42jTpk2x9NO6detiaTersLCwEulHbFNZz0t4ONj7a8DHB1q29HFYe3m1GXYyDecoo13tuTjXoeUt5zU8tGjb3ToZDA5t09HtFUebubUXdtK+4J9fm5Xx51gcYyzKudHP0TFt5npeHPzvTEhISKHLFilkZnJycqJ169Z5fgiTycT+/fsJCgriyJEjnDx50uY+3N3diY+PByA1NRUXl/yHnnUXHnuvYs6fP5/k5GQaNmzI9OnT7WpDREREpDJySMjMy+nTp9m0aRPbt28nLi6uSBNwPD09rSEzNjY23+BoMpmst++rVKli12SjrVu3cvDgQQBef/11uycsiYiIiFRGDg+ZcXFxbNu2jaCgIE6fPg1k34LS3gXMmzZtyoULFwC4ePFivs94RkdHk56eDkCTJk3sCrYbNmwAoHbt2oSGhhIaGppruawTkj7//HM8PT0BGD58uLacFBERkUrLISHTYrFw6NAhNm3axIEDBzCZTNmCpYuLC926dWPQoEE8+OCDdvVx5513cuTIEQBCQ0Px9/fPs2zW2/F57QxUWEajkQ8//LBQZT/++GPr8QMPPKCQKSIiIpVWkULmn3/+SVBQEFu2bMFozHhAPjNcGgwGfH19GT16NAMGDOD/t3fnYVEc+97Av8PqgoJo3FDRIwEVxe0c0VwXXFFE3BKX6AloolFOgkbvFaM3ieYY43JMjFt81KhZCQb3KNGIRqI4SXDBCAhCBNmFsIgSgWH6/YOXvoMwMzDTw8zA9/M8Pk8xXV1VPeVM/6a7q8rR0VGvhg4fPlwM4q5cuYKFCxeqzau6yo+21YGIiIiISHr1DjKfPHmCs2fP4ujRo4iJiRFfrwouO3TogJycHACAr68vXnnlFUka6unpCUdHR+Tn5yMqKgr37t2r9Srln3/+ibNnzwKonMZI1yunX375ZZ3yjRkzBhkZGQCAiIgIvadqIiIiImoM6jzpo1wux6pVqzB8+HC8++67iImJgSAIEAQBzZo1g5+fHw4ePIhLly4ZpKFWVlZYsmQJgMqANjg4WBwIVKW0tBTBwcHinJrz5s1TO3H76tWr4ebmBjc3N+zcudMgbSYiIiJqqjReyczIyMDx48dx/PhxZGZmAvi/K5YWFhYYOnQopk6dCm9vbzRv3tzgjZ07dy7Onz+P6OhoxMbGYurUqZg9ezacnZ2RnZ2NsLAwJCcnAwBcXFwQGBho8DYRERERUU0ag8xx48YBqD46/Pnnn4efnx/8/PzQoUMHw7buGTY2NtizZw+CgoIgl8uRlZWF7du318jn7u6OXbt2iSO9iYiIiKhhaQwyq+a1lMlkmDJlChYsWGD01Uns7e1x+PBhhIeH4+TJk4iLi0NBQQHs7e3h4uKCyZMnY8aMGVonayciIiIiw6lzJFa1Pvn06dPh5eUFa2trQ7ZLI5lMBh8fH/j4+OhcxqZNm7Bp0ya923Lx4kW9yyAiIiJqbDQO/JkxYwaaN28OQRBQXl6OS5cuISgoCMOHD8d7772HGzduNFQ7iYiIiMiMaLySuXHjRrzzzjv44YcfcOzYMURHR0MQBBQVFeHIkSM4cuQIunTpgqlTp8LPzw/dunVrqHYTUQPJzQXy83Xf39EReO456dpDRETmQevt8ubNm2P69OmYPn060tLSxMnXq0abp6enY/fu3di9ezcGDBgAPz8/gzeaiBpOfj4QEqL7/nPnMsgkImqK6jxPJgB07doVy5YtQ0REBA4dOgRfX1/Y2tqK82XeunUL77//vpg/IyMDZWVlkjeaiIiIiEybTkOwZTIZhg0bhmHDhuHx48f4/vvvcezYMdy+fVvcDgAnTpzAhQsXMGHCBPj5+Wlcb5yISGdKJaAQtOdTu78M9fzNTUREWug9z4+dnR3mzJmDOXPmIDk5GWFhYTh9+jTy8vIAAMXFxTh27BiOHTuGjh07wtfXFytXrtS74UREIqUSSH+ox/7twSCTiEhakn6r9uzZE8HBwbh8+TI+/fRTjB8/HlZWVuLt9KysLBw4cEDKKomIiIjIBBlkxnJLS0uMHj0ao0ePRn5+Pk6dOoXjx48jISHBENURERERkYkx+LI4jo6OCAgIQEBAAGJjY3H8+HFDV0lERERERtagay+6u7vD3d29IaskIiIiIiPgk+5EREREJDkGmUREREQkOQaZRERERCQ5BplEREREJDkGmUREREQkOQaZRERERCQ5BplEREREJDkGmUREREQkOQaZRERERCQ5BplEREREJDkGmUREREQkuQZdu5yICACgVAIKQcd9ZeDvYyIi08cgk4ganlIJpD/Ucd/2YJBJRGT6+E1NRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSY5BJRERERJJjkElEREREkmOQSURERESSszJ2A4jIxCmVgELQY38Z+HuWiKjpYZBJRJoplUD6Qz32bw8GmURETQ+/+YmIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwyiYiIiEhyDDKJiIiISHIMMomIiIhIcgwy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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Reliability plot for vgg16 post temp scaling\n",
    "vgg16_temp_model = ModelWithTemperature(vgg16_model)\n",
    "vgg16_temp_model.set_temperature(dirty_mnist_val_loader)\n",
    "conf_matrix, accuracy, labels, predictions, confidences = test_classification_net(vgg16_temp_model, dirty_mnist_loader, device)\n",
    "reliability_plot(confidences, predictions, labels, num_bins=25, model_name=\"vgg16\")"
   ]
  }
 ],
 "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
