{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Approximate Bayesian inference\n",
    "This notebook demonstrates how to compute various approximations of the Fisher information matrix from (pre-trained) PyTorch models (e.g. *torchvision* models pretrainted on ImageNet) which can be used as preconditioners in second-order optimization or to perform approximate Bayesian inference."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Standard imports\n",
    "import os\n",
    "import copy\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import torch\n",
    "import torchvision\n",
    "from matplotlib import pyplot as plt\n",
    "%matplotlib inline\n",
    "\n",
    "# From the repository\n",
    "import fisher\n",
    "from sampling import invert_factors, sample_and_replace_weights\n",
    "from utils import calibration_curve\n",
    "import plot"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Preliminaries\n",
    "After import a required modules, let's define some helper functions, the model and data we want to use and train the model (or use a pre-trained one)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Change this to 'cuda' if you have a working GPU.\n",
    "device = 'cpu'\n",
    "\n",
    "def train(model, data, criterion, optimizer, epochs):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        for images, labels in tqdm(data):\n",
    "            logits = model(images.to(device))\n",
    "\n",
    "            loss = criterion(logits, labels.to(device))\n",
    "            model.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            \n",
    "def eval(model, data):\n",
    "    model.eval()\n",
    "    logits = torch.Tensor().to(device)\n",
    "    targets = torch.LongTensor()\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for images, labels in tqdm(data):\n",
    "            logits = torch.cat([logits, model(images.to(device))])\n",
    "            targets = torch.cat([targets, labels])\n",
    "    return torch.nn.functional.softmax(logits, dim=1), targets\n",
    "\n",
    "def accuracy(predictions, labels):\n",
    "    print(f\"Accuracy: {100 * np.mean(np.argmax(predictions.cpu().numpy(), axis=1) == labels.numpy()):.2f}%\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define a PyTorch model (or load a pretrained one).\n",
    "class Flatten(torch.nn.Module):\n",
    "    def forward(self, input):\n",
    "        return input.view(input.size(0), -1)\n",
    "\n",
    "# This tutorial uses a LeNet-5 variant.\n",
    "model = torch.nn.Sequential(\n",
    "    torch.nn.Conv2d(1, 6, 5, padding=2),\n",
    "    torch.nn.ReLU(),\n",
    "    torch.nn.MaxPool2d(2, 2),\n",
    "    torch.nn.Conv2d(6, 16, 5),\n",
    "    torch.nn.ReLU(),\n",
    "    torch.nn.MaxPool2d(2, 2),\n",
    "    Flatten(),\n",
    "    torch.nn.Linear(16 * 5 * 5, 120),\n",
    "    torch.nn.ReLU(),\n",
    "    torch.nn.Linear(120, 84),\n",
    "    torch.nn.ReLU(),\n",
    "    torch.nn.Linear(84, 10)).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load some data for training\n",
    "torch_data = \"~/.torch/datasets\"  # Standard PyTorch dataset location\n",
    "train_set = torchvision.datasets.MNIST(root=torch_data,\n",
    "                                       train=True,\n",
    "                                       transform=torchvision.transforms.ToTensor(),\n",
    "                                       download=True)\n",
    "train_loader = torch.utils.data.DataLoader(train_set, batch_size=32)\n",
    "\n",
    "# And some for evaluating/testing\n",
    "test_set = torchvision.datasets.MNIST(root=torch_data,\n",
    "                                      train=False,\n",
    "                                      transform=torchvision.transforms.ToTensor(),\n",
    "                                      download=True)\n",
    "test_loader = torch.utils.data.DataLoader(test_set, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1875/1875 [00:27<00:00, 68.28it/s] \n",
      "100%|██████████| 1875/1875 [00:28<00:00, 65.56it/s]\n",
      "100%|██████████| 1875/1875 [00:27<00:00, 68.93it/s]\n"
     ]
    }
   ],
   "source": [
    "# Train the model (or load a pretrained one)\n",
    "criterion = torch.nn.CrossEntropyLoss().to(device)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=0.001, momentum=0.9)\n",
    "train(model, train_loader, criterion, optimizer, epochs=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 40/40 [00:01<00:00, 27.56it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy: 96.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Evaluate the model (optional)\n",
    "sgd_predictions, sgd_labels = eval(model, test_loader)\n",
    "accuracy(sgd_predictions, sgd_labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## The diagonal Fisher information matrix (IM)\n",
    "Now we can compute the simplest curvature approximation: The diagonal Fisher information matrix (IM). This is done in a very similar way to a standard PyTorch training loop, except that we sample our labels from the output distribution\n",
    "of the trained model to obtain the IM instead of the 'empirical' IM which uses labels from the data distribution and replace the optimizer by the update of our curvature estimator.\n",
    "\n",
    "This will give a rank-1 approximation of the IM. If a better approximation is desired, use more samples from the model output distribution."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1875/1875 [00:38<00:00, 48.71it/s]\n"
     ]
    }
   ],
   "source": [
    "model.train()\n",
    "diag = fisher.DIAG(model)\n",
    "\n",
    "for images, labels in tqdm(train_loader):\n",
    "    logits = model(images.to(device))\n",
    "    dist = torch.distributions.Categorical(logits=logits)\n",
    "    \n",
    "    # A rank-10 diagonal IM approximation.\n",
    "    for sample in range(10):\n",
    "        labels = dist.sample()\n",
    "        \n",
    "        loss = criterion(logits, labels)\n",
    "        model.zero_grad()\n",
    "        loss.backward(retain_graph=True)\n",
    "\n",
    "        diag.update(batch_size=images.size(0))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Kronecker factorization\n",
    "We can also compute the Kronecker factored IM (KFAC). The module interface is exactly the same."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1875/1875 [00:13<00:00, 134.32it/s]\n"
     ]
    }
   ],
   "source": [
    "kfac = fisher.KFAC(model)\n",
    "\n",
    "for images, labels in tqdm(train_loader):\n",
    "    logits = model(images.to(device))\n",
    "    dist = torch.distributions.Categorical(logits=logits)\n",
    "    \n",
    "    # A rank-1 Kronecker factored IM approximation.\n",
    "    labels = dist.sample()\n",
    "    \n",
    "    loss = criterion(logits, labels)\n",
    "    model.zero_grad()\n",
    "    loss.backward()\n",
    "    \n",
    "    kfac.update(batch_size=images.size(0))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Eigenvalue correction\n",
    "To compute the sparse information form of the IM, we first need to compute the eigenvalue corrected diagonal (EFB), which in turn requires the KFAC factors."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1875/1875 [00:49<00:00, 37.73it/s]\n"
     ]
    }
   ],
   "source": [
    "factors = list(kfac.state.values())\n",
    "efb = fisher.EFB(model, factors)\n",
    "\n",
    "for images, labels in tqdm(train_loader):\n",
    "    logits = model(images.to(device))\n",
    "    dist = torch.distributions.Categorical(logits=logits)\n",
    "    \n",
    "    for sample in range(10):\n",
    "        labels = dist.sample()\n",
    "        \n",
    "        loss = criterion(logits, labels)\n",
    "        model.zero_grad()\n",
    "        loss.backward(retain_graph=True)\n",
    "    \n",
    "        efb.update(batch_size=images.size(0))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sparse Information Form\n",
    "The final step is the computation of the diagonal correction term D. This does not involve any data. Further, we can choose the rank of the approximation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:00<00:00, 25.54it/s]\n"
     ]
    }
   ],
   "source": [
    "lambdas = list(efb.state.values())\n",
    "diags = list(diag.state.values())\n",
    "inf = fisher.INF(factors, lambdas, diags)\n",
    "inf.accumulate(rank=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Inversion and Sampling\n",
    "By inverting the IM approximation, we obtain an approximate weight posterior distribution of our model. Because the approximation is inaccurate, we need to regularize it with the two hyperparameters `N` (scale) and `tau` (norm).\n",
    "\n",
    "To transform our model into a Baysian Neural Network (BNN), we can now simply sample weights from the approximate posterior. Instead of single forward pass, we than perform multiple and average the results referred to as 'approximate Bayesian inference' or 'Monte Carlo integration'."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "estimator = 'inf'\n",
    "norm = 1e8\n",
    "scale = 2e10\n",
    "inv_factors = invert_factors(inf.state, norm, scale, estimator)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 40/40 [00:01<00:00, 39.48it/s]\n",
      "100%|██████████| 40/40 [00:01<00:00, 38.27it/s]\n",
      "100%|██████████| 40/40 [00:01<00:00, 39.27it/s]\n",
      "100%|██████████| 40/40 [00:00<00:00, 41.45it/s]\n",
      "100%|██████████| 40/40 [00:00<00:00, 41.44it/s]\n",
      "100%|██████████| 40/40 [00:01<00:00, 39.85it/s]\n",
      "100%|██████████| 40/40 [00:01<00:00, 39.10it/s]\n",
      "100%|██████████| 40/40 [00:00<00:00, 40.09it/s]\n",
      "100%|██████████| 40/40 [00:01<00:00, 39.32it/s]\n",
      "100%|██████████| 40/40 [00:00<00:00, 41.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy: 95.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "posterior_mean = copy.deepcopy(model.state_dict())\n",
    "mean_predictions = 0\n",
    "samples = 10  # 10 Monte Carlo samples from the weight posterior.\n",
    "\n",
    "with torch.no_grad():\n",
    "    for sample in range(samples):\n",
    "        sample_and_replace_weights(model, inv_factors, estimator)\n",
    "        predictions, labels = eval(model, test_loader)\n",
    "        mean_predictions += predictions\n",
    "        model.load_state_dict(posterior_mean)\n",
    "    mean_predictions /= samples\n",
    "    \n",
    "accuracy(mean_predictions, labels)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Calibration\n",
    "The obtained averaged model output can now be compared against the single determinstic forward pass of the standard model. Here we only have a look at the calibration. For this simple model and dataset, the baseline is already very well calibrated and there is practically no difference between the it and the Bayesian model, especially as we did not perform any hyperparameter search."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ECE NN: 0.61%, ECE BNN: 0.65%\n"
     ]
    }
   ],
   "source": [
    "ece_nn = calibration_curve(sgd_predictions.cpu().numpy(), sgd_labels.numpy())[0]\n",
    "ece_bnn = calibration_curve(mean_predictions.cpu().numpy(), labels.numpy())[0]\n",
    "print(f\"ECE NN: {100 * ece_nn:.2f}%, ECE BNN: {100 * ece_bnn:.2f}%\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(ncols=2, nrows=1, figsize=(12, 6), tight_layout=True)\n",
    "ax[0].set_title('SGD', fontsize=16)\n",
    "ax[1].set_title('INF-Laplace', fontsize=16)\n",
    "plot.reliability_diagram(sgd_predictions.cpu().numpy(), sgd_labels.numpy(), axis=ax[0])\n",
    "plot.reliability_diagram(mean_predictions.cpu().numpy(), labels.numpy(), axis=ax[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1gAAAHwCAYAAAC7T84CAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdd3zdZfn/8dd9RvZq2jRtulu60lIoLXuIIBaQjdYfCCLiREEciDiQLyAIRUAZiuAXBBzUL1A2RQEpS6Gl0L3oSjOaPZqcJGfcvz8+56TZPWlOcjLez8fjPHJyf9Z1rKW5ct33dRtrLSIiIiIiItJ7rngHICIiIiIiMlQowRIREREREYkRJVgiIiIiIiIxogRLREREREQkRpRgiYiIiIiIxIgn3gEMRaeffrp95ZVX4h2GiIiIiIjEhon2RFWw+kB5eXm8QxARERERkThQgiUiIiIiIhIjSrBERERERERiRAmWiIiIiIhIjCjBEhERERERiRElWCIiIiIiIjGiBEtERERERCRGlGCJiIiIiIjEiBIsERERERGRGFGCJSIiIiIiEiNKsERERERERGJECZaIiIiIiEiMKMESERERERGJESVYIiIiIiIiMaIES0REREREJEaUYImIiIiIiMSIEiwREREREZEY8cQ7ABERERlk1iyl4eUbSPKVUBQaycMJl3D4577BefPHxTsyEZG4UwVLREREordmKYFnryLFV4wLy3hXOT/2P8DbzzzAstWF8Y5ORCTulGCJiIhI9F67CU+wsc1QimnmGv7OkuWb4xSUiMjAoQRLREREolezp9PhPFNBUbWvn4MRERl4lGCJiIhI1GxieqfjJXYEYzKT+jkaEZGBRwmWiIiIRGfvemxTXaeH9pFEujtAoz/Yz0GJiAwsSrBERETkwEJB/M98BxeWt4JzqPLmEsJQYkdQSwozXEVcU3cnV/91JYFgKN7RiojEjRIsERERObD//gFvyWqKbDZPTPoVWT/djOvGasb8z04yvvVPggkZnOl+n5O23s4vlq3DWhvviEVE4kIJloiIiHSvcgfBf90EwM3269zw+WMwxuw/PmYu7ov/TsiVwCWe1xj94T387rVtcQpWRCS+lGCJiIhI16zF/+z3cAcbeTZ4HMedcTHjspI7njf5eFxfeASLi+97n6L0jQf4+/u7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0qVLKSgo4IgjjuDVV1/tNOaMM87gkksu6fP3lNhlJDoBkaEuXB54SGE1lAEj94O09MQmJSIi0oVbbrmFL3zhC1x44YVcccUV5Ofn8/bbb/Pwww/zxBNPcNppp7WOvffeeznvvPM48MADufLKK5kzZw6NjY288MIL/PznP+eRRx7hzTffbPf8U089leuuuw53p7Kykpdeeok777yT5cuXc/fdd3P22WfH9fuEn9dR2wKjpqaG008/neeff56LL76Yr33ta4wYMYL169fzm9/8hqVLl1JRUdE6fty4cTzwwAOdnjl69Oh+5fiNb3yDH/zgB3z729/msMMO49577+XDH/4wDz30EO9973t7vLepqYnTTz+dDRs2cNVVVzF//nxKS0v5+9//TktLS+u4xx9/nKeffprFixdjZlRXV3f5vPPOO4/MzEzuu+8+7rzzTj70oQ/x5ptvkpER/Mn/5z//mRdeeIHf/va3/fquEiN31yvOr8MOO8wledzz3Caf/tWH/M5f3OZ+baH7r9+f6JRERES6tN9++/lZZ53V5bWWlpbW92+++aZnZ2f7Oeec401NTZ3GNjY2+u23394uNn36dD/33HM7ja2urvajjz7ac3Nzvbi4uNccAb/rrrt6Hdfd53V00UUXeVZWlq9atarL6/fdd1/r+/POO8+nTJnS6zNjtWPHDs/KyvJrrrmmXfykk07yhQsX9nr/jTfe6AUFBb558+Yex7X9z+7cc8/16dOndxqzZ88eB/y5555zd/eSkhIH/I033nB395qaGp82bZrffffdveYlXYq5FtASQZFehC3a35VRFgS0/0pERLpx/8tbOea7TzDzyoc55rtPcP/LW/fp55eXlzNx4sQur6Wl7f2zb9myZUQiEX7605+2zm60lZmZyWc/+9mYPnPEiBHceuut1NXV8bOf/ax/ifdTSUkJv/rVr/j0pz/NUUcd1eWYeM+qtfXoo4/S2NjIxz/+8Xbxj3/847z22mts2LChx/tvvfVWPvzhD7Pffvv1OK7tf3bdCZcU5ubmApCfnw9AfX09ADfccAOzZs3qlKvEnwoskV6ESwSn2s4goBbtIiLShftf3spV973G1so6HNhaWcdV9722T4usd7/73fz617/mpptuYu3atd2Oe/zxxzn88MOZMGFCXD530aJFTJ48mWeeeSYuzwu5O83NzZ1eoSeffJKWlhbe//739+m5XT3T3Vuv//Of/4xpr9jrr79OdnY2s2fPbhdfsGABEOxx687mzZspLi5m1qxZfPrTn6awsJCcnByWLl3KK6+80qfvAzBq1Cj2339/li9fTkVFBT/84Q8ZNWoUc+bMYc2aNSxfvpxbb721z8+VvtMeLJFehDNYY5tKgoBatIuIJLUZVz4ct2fVNbXwxRWv8MUVff+DeeN3z+jzPbfffjsf+tCH+MpXvsJXvvIVxowZwymnnMIFF1zAe97zntZxW7ZsYfHixZ3ub2lpaVdodDW71Z1p06ZRUlLS55x7cs8993DPPfd0ij///PMsXryY4uJiAKZPj/1/m7du3UpmZman+E033cSXv/xlIGjEkZ6e3uvMUXl5OUVFRZhZu3i4n6u8vLzbe7dt2wbA9773PQ4//HDuvfdeGhoauPbaa1myZAmrV69m2rRpMX8vgDvuuINzzjmHO+64g7y8PH7961+Tl5fHJZdcwqWXXsq8efP69DzpHxVYIr0orqgDYERdeAbWjMQlIyIi0oMDDjiAl19+mWeeeYbHHnuMZ599lj//+c/ce++9fPOb3+Tqq6/u8f78/HwaGhpaf1+3bl2n2ZnuuHunQmOgTj/9dG644YZO8fnz5/f7mePHj+fhhzsX0W2X6Z1wwgntZsq60913blukdicSiQCQl5fHgw8+SF5eHgCLFy9m9uzZ/PSnP+V73/ter89pa8mSJZSUlPDOO+8wbdo08vLyuOeee3j77bd58MEH2bhxIxdffDHPPfcc06dPZ9myZSxZsqRPnyG9U4El0oPq+ibKaxrJzjAyqoJ/S0bRjITmJCIig6s/M0cAx3z3CbZW1nWKTynK5ZkrTxpoWjFLT0/n+OOP5/jjjweCmZLTTjuN66+/nksuuYRRo0YxdepUNm/e3OneVatWEYlEeOihh7j++uv79LnFxcXMnTs3Lt8hNHr06C5n2kJhUbRp0ybmzJkT0zMzMzN7fGZf86uoqOhUaIVdC3vqTDhmzBgAjjnmmNbiCoLvNHfuXF5++eV+5ZSVldX6n0NVVRVf/vKXue2228jLy+Pcc89lwYIF3HfffaxYsYKzzz6b9evXt+Yi8aE9WCI9KC4P/odyQVEL1lAFWQWQ1782riIiktyuOHUOuZntj/HIzUznilNj+8N/sEyePJlPfepTNDc3s27dOgBOOukknn/+eXbu3Nlu7KGHHsrixYu7PWepO6+88grbtm3j2GOPjVfaMVmyZAnp6ek8+OCD+/RzQwsWLKChoYG33367XTzce9XTTNusWbPIzc3tdgYslsYWvfnGN77B4sWL+cAHPkB1dTWrVq3i0ksvJS8vjwsuuIC0tDSeffbZAX+OtKcCS6QHxRXB/quDC3YHgVHTIc7LH0REJDmcdcgUbvzgQqYU5WIEM1c3fnAhZx2y7w6nD/ckdbRmzRqA1g6DX/ziFzEzLrnkknbnLfXHnj17uOSSS8jLy4u582C8TJ48mfPPP5877riDf//7312Ouf/++wft80877TSysrI6nSv1m9/8hgMPPJCZM2d2e29mZiZnnHEGTz/9NDU1Na3xzZs389Zbb3H44YcPKLdXX32Vu+66i1tuuQXYu2wx/Kzm5mYaGhpiWs4ofaMlgiI9CBtczMuJblLV/isREenBWYdM2acFVUcHHnggJ554ImeffTYzZ86kqqqKv/71r9x+++185CMfaW2aMG/ePH75y19ywQUXcMQRR/DpT3+aOXPm0NLSwoYNG7jjjjvIzMwkOzu73fPLysp49tlncXd2797detBwaWkpv/vd75g8eXJcv0/4eR1NnDixdZZt2bJlrF27lqVLl3LxxRdz8sknM2LECN555x1++9vf8sILL3DWWWe13tvY2NjlM/Py8jjooIMAeOqpp1i6dCm//OUv+eQnP9ltfuPHj+eyyy7jxhtvpKCggEMPPZQVK1bwxBNP8Je//KXd2KVLl7Jp0ybWr1/fGrv++ut597vfzRlnnMGXvvQl6uvruf766ykqKuLzn/9867jS0lKeeuopICjAamtr+eMf/wgEs2QdZ8rcnc997nNceeWVrf+cCgsLefe7382VV17J17/+df785z+Tnp7OkUce2e33k37qy6FZeumg4VTzjftf8+lffcj/c/c3gkOGH7kq0SmJiIh067bbbvMzzzzTp02b5tnZ2Z6Xl+cHH3ywf+973/OGhoZO41evXu3nn3++T5s2zbOysjw/P98POuggv/zyy33dunXtxk6fPt0BBzwtLc2Liop88eLF/tWvftU3btwYc4704aDh8PM6vi655JJ2YxsbG3358uV+1FFHeUFBgWdmZvqMGTP8oosu8ldffbV13HnnndftMxcsWNA67sknn4w5z+bmZv/mN7/Z+s9w4cKF/oc//KHTuBNOOKHLA4Kfe+45X7Jkiefm5nphYaF/4AMf6PTPPsynq9e1117b6Zm/+MUvfO7cuZ3+M1+3bp2fdNJJnp+f7/Pnz/dHH3201+8nrWKuBcw1LRh3ixcv9hdeeCHRacgA3f/yVr76p9U0NEf4Ye5dnON/h9O/D0fs2+UPIiIiycTMuOuuuzj//PMTnYpIX8S8R0R7sES6EB4W2dActFAd17wdgH+XFyQyLREREREZ4lRgiXThpkffoq5p76bf/SzosrT85aZEpSQiIiIiw4AKLJEubGtzjkkaEaZYGQAvVWkGS0RERES6py6CIl2YXJTbeljkRMrJshZ2ehGji4oSnJmIiMjwpv3/kuw0gyXShbaHRU5LC5YHbmF8wg+LFBEREZGhTTNYIl0IzzC56dG32K86KLDG7XcAhybwbBMRERERGfpUYIl0o/WwyCdWwUrYb9a8RKckIiIiIkOclgiK9KZiU/Bz1IyEpiEiIiIiQ58KLJHeVEYLrKLpic1DRERERIY8FVgivanYGPzUDJaIiIiI9EIFlkhPGmthzw5Iy4TCyYnORkRERP5/e3ceHkWV7nH8+xIIEECisojKOigO4EJkE5UtUbYBZRwHdRiIIMqACzAuqAhRCIuyujKKIyPgRe5FUWBGVkFcECIKiiMMuwIqm44iEAjn/lGV2Ol0J53QIQF+n+epJ+lTb1WdU9WQfvucOiVSzCnBEsnNDy2StksAAB6oSURBVDu8n/HVoURM0dZFREQkD1OnTsXM2LRpU1ZZcnIyZkbLli1zxC9evBgzY9myZVllKSkpmFnIJXC/oWRue+zYsai1KS/JycnUqlXrpB0vP8yMqVOn5hlXq1atsOd84sSJ2WKPHj3K888/z9VXX018fDylS5emdu3a9OrVizVr1mTFZV73UMuNN95YoPYcP36cUaNGUatWLcqUKcPll1/O7NmzI97+0KFDpKSkcNFFF1G6dGmqVq3K7373O9LT07Niwr3/guv86aef0rRpUypUqEBSUhLbt2/Ptv7YsWNcfvnlPPXUUwVq64nQLIIiudH9VyIicppYsWIF77zzDu3bt48o/v333ycmJvuXi9WrVy+MqgnQrl07UlJScpQHJo8HDx6kQ4cOrF69mr59+/LII49Qvnx5Nm3axPTp00lMTOTAgQNZ8ZUrV+btt9/Osc9zzjmnQHV87LHHGDt2LKmpqVx55ZXMnDmTm2++mXnz5tGxY8dctz169CgdOnRg69atPPzww9SvX589e/awaNEiMjIycsQHv/8C63zs2DH+8Ic/0LRpU1JTUxk5ciQ9e/bM9kXBM888Q0ZGBgMHDixQW0+EEiyR3GTdf6UES0RETl3VqlWjUqVKDBkyhHbt2mFmeW7TrFkzSpbUR8WTpVKlSjRv3jzXmPvuu4+PP/6YZcuWcdVVV2WVt2rVit69e/Pmm29mi4+Njc1zn5H6/vvvGTt2LIMHD+b+++8HoE2bNmzatInBgwfnmWCNGzeONWvWsH79+myJ+k033RQyPrf334YNG9iyZQsfffQRVapUoUKFCrRo0YJffvmFuLg4du3aRUpKCnPnzi2S97CGCIrkRlO0i4hIfqybBRMaQkq893PdrKKuEQAlSpRg+PDhfPLJJ7zxxhtFWpeFCxfSsWNHqlWrRlxcHA0bNmTcuHE5ejFq1apF9+7deemll6hbty5lypQhISGBd999N89jDBs2jISEBCpWrEilSpVo27YtK1euzBG3Z88e+vXrR/Xq1SldujTVq1fnz3/+M0eOHMmKWbt2LV26dOHss8+mbNmyXH311axYseLET0Q+7d69m6lTp9KnT59syVWgrl27FtrxFyxYQHp6Ot27d89W3r17dz7//HO2bt2a6/bPP/88N998c1R6QTOHFJYtWxaAcuXK4ZzLum6DBg2ia9euIYfFngxKsERyoyGCIiISqXWzYO698OPXgPN+zr232CRZN9xwA82aNWPo0KEcP348z/iMjAyOHTuWtUSyTSS2bNlCYmIif//735k/fz49e/YkJSWFRx99NEfs8uXLGT9+PKmpqcycOZPSpUvToUMHNmzYkOsxdu7cycCBA5kzZw5Tp06lSpUqtGzZknXr1mXFHDhwgBYtWvD6668zaNAg/vnPf/Lkk09y9OjRrA/wa9asoUWLFuzfv5+XXnqJ2bNnc+6555KUlMQnn3wSlfORyTmX7XxnLpneffddMjIy6NKlS772G2qfzrms9cuWLYvoXrH169dTunRp6tatm628QYMGAHz55Zdht92xYwdff/01derUoU+fPpx11lmUKVOGxMREPvvss5DbVK9enZiYGGrWrMlDDz3EoUOHstbVq1eP+Ph4Jk6cyIEDB5g0aRIXX3wxZ599NkuWLGHh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\n",
      "text/plain": [
       "<Figure size 864x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(12, 7), tight_layout=True)\n",
    "c1 = next(ax._get_lines.prop_cycler)['color']\n",
    "c2 = next(ax._get_lines.prop_cycler)['color']\n",
    "plot.calibration(sgd_predictions.cpu().numpy(), sgd_labels.numpy(), color=c1, label=\"SGD\", axis=ax)\n",
    "plot.calibration(mean_predictions.cpu().numpy(), labels.numpy(), color=c2, label=\"INF-Laplace\", axis=ax)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:torch-gpu] *",
   "language": "python",
   "name": "conda-env-torch-gpu-py"
  },
  "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
