{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [],
   "source": [
    "%matplotlib notebook\n",
    "import numpy as np\n",
    "import torch\n",
    "np.random.seed(42)\n",
    "torch.manual_seed(42)\n",
    "torch.backends.cudnn.benchmark = True\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torchvision import datasets, transforms, models\n",
    "from torch.utils.data.sampler import SubsetRandomSampler\n",
    "import matplotlib\n",
    "from tqdm import tqdm as tqdm\n",
    "from uce import eceloss, uceloss, classwise_uce, classwise_ece\n",
    "from utils import accuracy, nentr\n",
    "from models import BayesianNet\n",
    "from matplotlib import pyplot as plt\n",
    "import seaborn as sns\n",
    "from scaler import TempScaler, VectorScaler, AuxScaler, NoneScaler\n",
    "sns.set()\n",
    "sns.set_context('paper')\n",
    "matplotlib.rcParams['text.usetex'] = True\n",
    "matplotlib.rcParams['font.size'] = 8"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = 'resnet34'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "cuda:0\n"
     ]
    }
   ],
   "source": [
    "assert model in ['resnet34', 'densenet121']\n",
    "\n",
    "batch_size = 100\n",
    "\n",
    "mean = [0.5, 0.5, 0.5]\n",
    "std = [0.5, 0.5, 0.5]\n",
    "\n",
    "num_classes = 10\n",
    "cifar10_valid_set = datasets.CIFAR10('../data', train=True, download=True,\n",
    "                                     transform=transforms.Compose([\n",
    "                                         transforms.ToTensor(),\n",
    "                                         transforms.Normalize(mean=mean, std=std)]))\n",
    "cifar10_test_set = datasets.CIFAR10('../data', train=False, download=False,\n",
    "                                    transform=transforms.Compose([\n",
    "                                        transforms.ToTensor(),\n",
    "                                        transforms.Normalize(mean=mean, std=std)]))\n",
    "cifar10_valid_indices = torch.load('./valid_indices_cifar10.pth')\n",
    "cifar10_valid_loader = torch.utils.data.DataLoader(cifar10_valid_set, batch_size=batch_size,\n",
    "                                                   sampler=SubsetRandomSampler(cifar10_valid_indices))\n",
    "cifar10_test_loader = torch.utils.data.DataLoader(cifar10_test_set, batch_size=batch_size)\n",
    "\n",
    "cifar100_test_set = datasets.CIFAR100('../data', train=False, download=False,\n",
    "                                      transform=transforms.Compose([\n",
    "                                          transforms.Resize((32, 32)),\n",
    "                                          transforms.ToTensor(),\n",
    "                                          transforms.Normalize(mean=mean, std=std)]))\n",
    "\n",
    "device = torch.device(\"cuda:0\")\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/fastdata/laves/icml_snapshots/resnet34_cifar10.pth.tar\n",
      "Loading previous weights at epoch 399\n",
      "\n",
      "/media/fastdata/laves/icml_snapshots/resnet34_cifar10_cp.pth.tar\n",
      "Loading previous weights at epoch 399\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "net = BayesianNet(num_classes=num_classes, model=model).to(device)\n",
    "\n",
    "path = f'/media/fastdata/laves/icml_snapshots/{model}_cifar10.pth.tar'\n",
    "print(path)\n",
    "checkpoint = torch.load(path, map_location=device)\n",
    "print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "net.load_state_dict(checkpoint['state_dict'])\n",
    "\n",
    "print(\"\")\n",
    "\n",
    "net_cp = BayesianNet(num_classes=num_classes, model=model).to(device)\n",
    "\n",
    "path = f'/media/fastdata/laves/icml_snapshots/{model}_cifar10_cp.pth.tar'\n",
    "print(path)\n",
    "checkpoint = torch.load(path, map_location=device)\n",
    "print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "net_cp.load_state_dict(checkpoint['state_dict'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50/50 [02:08<00:00,  1.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([25, 5000, 10]) torch.Size([5000])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "logits_valid_bay = []\n",
    "labels_valid_bay = []\n",
    "with torch.no_grad():\n",
    "    for batch_idx, (data, target) in enumerate(tqdm(cifar10_valid_loader)):\n",
    "        data, target = data.to(device), target.to(device)\n",
    "        logits = net(data, mc=True)\n",
    "        logits_valid_bay.append(logits.detach())\n",
    "        labels_valid_bay.append(target.detach())\n",
    "logits_valid_bay = torch.cat(logits_valid_bay, dim=1)\n",
    "labels_valid_bay = torch.cat(labels_valid_bay, dim=0)\n",
    "print(logits_valid_bay.shape, labels_valid_bay.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(logits, targets, scaler, epochs=30):\n",
    "    optimizer = optim.Adam(scaler.parameters(), lr=1e-2, weight_decay=0)\n",
    "    lr_scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, patience=5, factor=0.1)\n",
    "    train_losses = []\n",
    "    train_accuracies = []\n",
    "\n",
    "    for e in range(epochs):\n",
    "        epoch_train_loss = []\n",
    "        epoch_train_acc = []\n",
    "        is_best = False\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        output = scaler(logits).mean(dim=0)\n",
    "        loss = F.cross_entropy(output, targets)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        \n",
    "        epoch_train_loss.append(loss.item())\n",
    "        epoch_train_acc.append(accuracy(output, targets))\n",
    "\n",
    "        epoch_train_loss = np.mean(epoch_train_loss)\n",
    "        epoch_train_acc = np.mean(epoch_train_acc)\n",
    "        lr_scheduler.step(epoch_train_loss)\n",
    "\n",
    "        # save epoch losses\n",
    "        train_losses.append(epoch_train_loss)\n",
    "        train_accuracies.append(epoch_train_acc)\n",
    "\n",
    "        if e % (epochs//10) == 0:\n",
    "            print(\"Epoch {:2d}, lr: {:.4f}, loss: {:.4f}, acc: {:.4f}, T: {:.4f}\"\n",
    "                  .format(e,\n",
    "                          optimizer.param_groups[0]['lr'],\n",
    "                          epoch_train_loss,\n",
    "                          epoch_train_acc,\n",
    "                          scaler.T.item() if type(scaler) == TempScaler else 0\n",
    "                          ))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "none = NoneScaler().to(device)\n",
    "temp = TempScaler(init_T=2.0).to(device)\n",
    "vec = VectorScaler(num_classes, init_T=1.0).to(device)\n",
    "aux = AuxScaler(num_classes, hidden=16).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch  0, lr: 0.0100, loss: 0.2339, acc: 0.9330, T: 2.0100\n",
      "Epoch 10, lr: 0.0100, loss: 0.2308, acc: 0.9330, T: 2.1087\n",
      "Epoch 20, lr: 0.0100, loss: 0.2287, acc: 0.9330, T: 2.2011\n",
      "Epoch 30, lr: 0.0100, loss: 0.2273, acc: 0.9330, T: 2.2826\n",
      "Epoch 40, lr: 0.0100, loss: 0.2265, acc: 0.9330, T: 2.3501\n",
      "Epoch 50, lr: 0.0100, loss: 0.2261, acc: 0.9330, T: 2.4027\n",
      "Epoch 60, lr: 0.0100, loss: 0.2260, acc: 0.9330, T: 2.4413\n",
      "Epoch 70, lr: 0.0100, loss: 0.2259, acc: 0.9330, T: 2.4680\n",
      "Epoch 80, lr: 0.0010, loss: 0.2259, acc: 0.9330, T: 2.4812\n",
      "Epoch 90, lr: 0.0000, loss: 0.2259, acc: 0.9330, T: 2.4816\n"
     ]
    }
   ],
   "source": [
    "train(logits_valid_bay, labels_valid_bay, temp, epochs=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch  0, lr: 0.0100, loss: 0.6247, acc: 0.9330, T: 0.0000\n",
      "Epoch 100, lr: 0.0100, loss: 0.5634, acc: 0.9330, T: 0.0000\n",
      "Epoch 200, lr: 0.0100, loss: 0.5000, acc: 0.9330, T: 0.0000\n",
      "Epoch 300, lr: 0.0100, loss: 0.4359, acc: 0.9330, T: 0.0000\n",
      "Epoch 400, lr: 0.0100, loss: 0.3735, acc: 0.9330, T: 0.0000\n",
      "Epoch 500, lr: 0.0100, loss: 0.3171, acc: 0.9330, T: 0.0000\n",
      "Epoch 600, lr: 0.0100, loss: 0.2720, acc: 0.9330, T: 0.0000\n",
      "Epoch 700, lr: 0.0100, loss: 0.2431, acc: 0.9330, T: 0.0000\n",
      "Epoch 800, lr: 0.0100, loss: 0.2300, acc: 0.9330, T: 0.0000\n",
      "Epoch 900, lr: 0.0100, loss: 0.2264, acc: 0.9330, T: 0.0000\n"
     ]
    }
   ],
   "source": [
    "train(logits_valid_bay, labels_valid_bay, vec, epochs=1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch  0, lr: 0.0100, loss: 11.6298, acc: 0.0716, T: 0.0000\n",
      "Epoch 200, lr: 0.0100, loss: 0.2227, acc: 0.9304, T: 0.0000\n",
      "Epoch 400, lr: 0.0100, loss: 0.2110, acc: 0.9328, T: 0.0000\n",
      "Epoch 600, lr: 0.0100, loss: 0.2083, acc: 0.9336, T: 0.0000\n",
      "Epoch 800, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n",
      "Epoch 1000, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n",
      "Epoch 1200, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n",
      "Epoch 1400, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n",
      "Epoch 1600, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n",
      "Epoch 1800, lr: 0.0000, loss: 0.2078, acc: 0.9330, T: 0.0000\n"
     ]
    }
   ],
   "source": [
    "train(logits_valid_bay, labels_valid_bay, aux, epochs=2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_ood(net, scaler, start=0):\n",
    "    batch_id = []\n",
    "    labels_id = []\n",
    "    batch_ood = []\n",
    "    labels_ood = []\n",
    "    \n",
    "    # compose batch\n",
    "    for i in range(start, start+100):\n",
    "        batch_id.append(cifar10_test_set[i][0].unsqueeze(0))\n",
    "        labels_id.append(torch.tensor([cifar10_test_set[i][1]]))\n",
    "        batch_ood.append(cifar100_test_set[i][0].unsqueeze(0))\n",
    "        labels_ood.append(torch.tensor([cifar100_test_set[i][1]]))\n",
    "    \n",
    "    acc = []\n",
    "    uncert = []\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for i in tqdm(range(0, 101, 10)):\n",
    "            batch = torch.cat(batch_id[i:] + batch_ood[:i], dim=0).to(device)\n",
    "            labels = torch.cat(labels_id[i:] + labels_ood[:i], dim=0).to(device)\n",
    "\n",
    "            logits = scaler(net(batch, mc=True)).mean(dim=0)\n",
    "\n",
    "            acc.append(accuracy(logits, labels))\n",
    "            \n",
    "            softmaxes = logits.softmax(dim=1)\n",
    "            uncertainties = nentr(softmaxes, base=softmaxes.size(1))\n",
    "            uncert.append(uncertainties.mean().item())\n",
    "\n",
    "    return uncert, acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 11/11 [00:32<00:00,  2.91s/it]\n",
      "100%|██████████| 11/11 [00:32<00:00,  2.92s/it]\n",
      "100%|██████████| 11/11 [00:32<00:00,  2.93s/it]\n",
      "100%|██████████| 11/11 [00:25<00:00,  2.05s/it]\n",
      "100%|██████████| 11/11 [00:15<00:00,  1.04s/it]\n"
     ]
    }
   ],
   "source": [
    "uncert_none, _ = test_ood(net, none, start=1337)\n",
    "uncert_temp, _ = test_ood(net, temp, start=1337)\n",
    "uncert_vec, _ = test_ood(net, vec, start=1337)\n",
    "uncert_aux, _ = test_ood(net, aux, start=1337)\n",
    "uncert_cp, _ = test_ood(net_cp, none, start=1337)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez(f\"ood_figures/ood_cifar10-cifar100_{model}\",\n",
    "         uncert_none=uncert_none, uncert_cp=uncert_cp, uncert_temp=uncert_temp,\n",
    "         uncert_vec=uncert_vec, uncert_aux=uncert_aux)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width, fig.canvas.height);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        event.shiftKey = false;\n",
       "        // Send a \"J\" for go to next cell\n",
       "        event.which = 74;\n",
       "        event.keyCode = 74;\n",
       "        manager.command_mode();\n",
       "        manager.handle_keydown(event);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAqgAAAH0CAYAAADxHN9NAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACqKADAAQAAAABAAAB9AAAAABC54c6AABAAElEQVR4Aey9CZxVxZn+/96t926gGwRpIEYNIBoTE1EBk6hsQhJUGMU1LkiMmkDMgDomOhM1/kx0MqJJ+CuijsYFTXCZKCAoJlEQIZuyucQomyh00/t2t389dfvcvvvSdzl3eerzudxz6tSpU/WtQ/fTb731lsWrkjCRAAmQAAmQAAmQAAmQQI4QsOZIO9gMEiABEiABEiABEiABEtAEKFD5IpAACZAACZAACZAACeQUAQrUnBoONoYESIAESIAESIAESIACle8ACZAACZAACZAACZBAThGgQM2p4WBjSIAESIAESIAESIAEKFD5DpAACZAACZAACZAACeQUAQrUnBoONoYESIAESIAESIAESIACle8ACZAACZAACZAACZBAThGgQM2p4WBjSIAESIAESIAESIAEKFD5DpAACZAACZAACZAACeQUAQrUnBoONoYESIAESIAESIAESIACle8ACZAACZAACZAACZBAThGgQM2p4WBjSIAESIAESIAESIAEKFD5DpAACZAACZAACZAACeQUAQrUnBoONoYESIAESIAESIAESIACle8ACZAACZAACZAACZBAThGgQM2p4WBjSIAESIAESIAESIAEKFD5DpAACZAACZAACZAACeQUAQrUnBoONoYESIAESIAESIAESIACle8ACZAACZAACZAACZBAThGgQM2p4WBjSIAESIAESIAESIAEKFD5DpAACZAACZAACZAACeQUAXtOtYaNIQESMJXAihUrZPXq1bJ79279QWNGjhypPxMnTpQzzzxTHxuNXLZsmdx99936dPPmzVJTU2Nc0t+B14MuRDlZtGiRzJ8/P+wq2rRw4UKdH61M6E3xno1+jRs3TmbOnKn7FXp/tHOwufzyy2XJkiVy7LHHRivmzwdTfLZt26b5TJgwQa666qqE7vVXkocHfJfiD1q23qVifQfjjwBL5DIBCtRcHh22jQSyRAAC8Oabb5aWlhb9RAhNiC9DqOJ7w4YN+vzWW2/tV6sgCEMFbGhFKBMp4Res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BEigyAgUlUBFKlOUl156yXWYX375ZROC6oYbbog6jpSmmzdvNmlSnQdSbc/ZBvdJgARIgARIgARIgASiCRSVQMXa0vvvv98ITYhOZ9mxY4eZ/n/kkUec1Wb/scceE4jXBx98MOpYqu1FNcI3JEACJEACJEACJEACUQSKykkKT37PPfeoE1G/3HHHHUasYr0pxOnjjz8uW7ZsEbfp/ZtuukmQ1nTTpk1R8FJtb0EjrCABEiABEiABEiABEogQKJnTEnlXRDvw2N+6davx6u/o6DDC1K/3vhumoNtzu4efOgwnFqgHXRBfFQVRAliyS4BjkV3+9u4cB0si+1uORfbHAD3gOBTPOCBaQElJsEmBYukVrUCNBcH3JEACJEACJEACJEACuUGgqNag5gZy9oIESIAESIAESIAESCAeAQrUeHR4jARIgARIgARIgARIIOMEKFAzjpw3JAESIAESIAESIAESiEeAAjUeHR4jARIgARIgARIgARLIOAEK1Iwj5w1JgARIgARIgARIgATiEaBAjUeHx0iABEiABEiABEiABDJOgAI148h5QxIgARIgARIgARIggXgEKFDj0eExEiABEiABEiABEiCBjBOgQM04ct6QBEiABEiABEiABEggHgEK1Hh0eIwESIAESIAESIAESCDjBChQM46cNyQBEiABEiABEiABEohHgAI1Hh0eIwESIAESIAESIAESyDgBCtSMI+cNSYAESIAESIAESIAE4hGgQI1Hh8dIgARIgARIgARIgAQyToACNePIeUMSIAESIAESIAESIIF4BChQ49HhMRIgARIgARIgARIggYwToEDNOHLekARIgARIgARIgARIIB4BCtR4dHiMBEiABEiABEiABEgg4wQoUDOOnDckARIgARIgARIgARKIR4ACNR4dHiMBEiABEiABEiABEsg4AQrUjCPnDUmABEiABEiABEiABOIRKI93kMdI4KGHHpI9e/YYEAMDA3LVVVfJAw88QDBpINDd3S3gPTQ0JLt27ZKOjg658cYb5Z577ol7N45RXDyBHXzwwQeloaEh7uefYxEY7qiGnnvuOXnppZdMHcagublZ7r//fmlsbIw6z77hOFgSwWwHBwflscceM99N/f39Zovvp3hjgDtzHBbHH/zw92DLli0JG0qFdSrXJOxIkCfMsZCACwEVo3Mf//jH57797W9H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\" width=\"340\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, figsize=(3.4,2.5))\n",
    "ax.plot(range(0, 101, 10), uncert_none, '.-', label='uncalib')\n",
    "ax.plot(range(0, 101, 10), uncert_cp, '.-', label='cp')\n",
    "ax.plot(range(0, 101, 10), uncert_temp, '.-', label='temp')\n",
    "ax.plot(range(0, 101, 10), uncert_vec, '.-', label='vec')\n",
    "ax.plot(range(0, 101, 10), uncert_aux, '.-', label='aux')\n",
    "ax.set_xlabel(r'\\% OoD data')\n",
    "ax.set_ylabel(r'mean uncertainty')\n",
    "ax.set_title(r'CIFAR10 $\\rightarrow$ CIFAR100')\n",
    "ax.legend()\n",
    "fig.tight_layout()\n",
    "fig.show()\n",
    "fig.savefig(f\"ood_figures/ood_cifar10-cifar100_{model}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
