{
 "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\n",
    "from uce import eceloss, uceloss, classwise_uce, classwise_ece\n",
    "from utils import accuracy, nentr\n",
    "from models import FrequentistNet\n",
    "from matplotlib import pyplot as plt\n",
    "from scaler import TempScaler, NoneScaler\n",
    "from ace import classwise_ace\n",
    "\n",
    "import seaborn as sns\n",
    "sns.set()\n",
    "matplotlib.rcParams['text.usetex'] = True\n",
    "matplotlib.rcParams['font.size'] = 8"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = 'resnet34'\n",
    "dataset = 'cifar10'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "batch_size = 128\n",
    "\n",
    "mean = [0.5, 0.5, 0.5]\n",
    "std = [0.5, 0.5, 0.5]\n",
    "if dataset == 'cifar10':\n",
    "    num_classes = 10\n",
    "    valid_set = datasets.CIFAR10('../data', train=True, download=True,\n",
    "                                 transform=transforms.Compose([\n",
    "                                     transforms.RandomCrop(32, padding=4, padding_mode='reflect'),\n",
    "                                     transforms.RandomHorizontalFlip(),\n",
    "                                     transforms.ToTensor(),\n",
    "                                     transforms.Normalize(mean=mean, std=std)]))\n",
    "\n",
    "    test_set = datasets.CIFAR10('../data', train=False, download=False,\n",
    "                                transform=transforms.Compose([\n",
    "                                    transforms.ToTensor(),\n",
    "                                    transforms.Normalize(mean=mean, std=std)]))\n",
    "    valid_indices = torch.load('./valid_indices_cifar10.pth')\n",
    "elif dataset == 'cifar100':\n",
    "    num_classes = 100\n",
    "    valid_set = datasets.CIFAR100('../data', train=True, download=True,\n",
    "                                  transform=transforms.Compose([\n",
    "                                      transforms.RandomCrop(32, padding=4, padding_mode='reflect'),\n",
    "                                      transforms.RandomHorizontalFlip(),\n",
    "                                      transforms.ToTensor(),\n",
    "                                      transforms.Normalize(mean=mean, std=std)]))\n",
    "\n",
    "    test_set = datasets.CIFAR100('../data', train=False, download=True,\n",
    "                                 transform=transforms.Compose([\n",
    "                                     transforms.ToTensor(),\n",
    "                                     transforms.Normalize(mean=mean, std=std)]))\n",
    "    valid_indices = torch.load('./valid_indices_cifar100.pth')\n",
    "elif dataset == 'svhn':\n",
    "    num_classes = 10\n",
    "    valid_set = datasets.SVHN('../data', split='train', download=True,\n",
    "                              transform=transforms.Compose([\n",
    "                                  transforms.ToTensor(),\n",
    "                                  transforms.Normalize(mean=mean, std=std)\n",
    "                              ]))\n",
    "    test_set = datasets.SVHN('../data', split='test', download=True,\n",
    "                             transform=transforms.Compose([\n",
    "                                 transforms.ToTensor(),\n",
    "                                 transforms.Normalize(mean=mean, std=std)\n",
    "                             ]))\n",
    "    valid_indices = torch.load('./valid_indices_svhn.pth')\n",
    "\n",
    "valid_loader = torch.utils.data.DataLoader(valid_set, batch_size=batch_size,\n",
    "                                           sampler=SubsetRandomSampler(valid_indices))\n",
    "test_loader = torch.utils.data.DataLoader(test_set, batch_size=batch_size)\n",
    "\n",
    "device = torch.device(\"cuda:0\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/fastdata/laves/iclr_snapshots/none_resnet34_cifar10_best_2020-09-23_21.26.44.pth.tar\n",
      "Loading previous weights at epoch 296\n",
      "cuda:0\n"
     ]
    }
   ],
   "source": [
    "net1 = FrequentistNet(num_classes=num_classes, model=model).to(device)\n",
    "\n",
    "path = f'/media/fastdata/laves/iclr_snapshots/none_resnet34_cifar10_best_2020-09-23_21.26.44.pth.tar'\n",
    "print(path)\n",
    "checkpoint = torch.load(path, map_location=device)\n",
    "print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "net1.load_state_dict(checkpoint['state_dict'])\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/fastdata/laves/iclr_snapshots/none_resnet34_cifar10_best_2020-09-24_05.40.42.pth.tar\n",
      "Loading previous weights at epoch 231\n",
      "cuda:0\n"
     ]
    }
   ],
   "source": [
    "net2 = FrequentistNet(num_classes=num_classes, model=model).to(device)\n",
    "\n",
    "path = f'/media/fastdata/laves/iclr_snapshots/none_resnet34_cifar10_best_2020-09-24_05.40.42.pth.tar'\n",
    "print(path)\n",
    "checkpoint = torch.load(path, map_location=device)\n",
    "print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "net2.load_state_dict(checkpoint['state_dict'])\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "none_resnet34_cifar10_best_2020-09-23_21.26.44.pth.tar\n",
    "none_resnet34_cifar10_best_2020-09-24_01.48.25.pth.tar\n",
    "none_resnet34_cifar10_best_2020-09-24_05.40.42.pth.tar"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 40/40 [00:01<00:00, 21.20it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([5000, 10]) torch.Size([5000])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "logits_valid_freq1 = []\n",
    "labels_valid_freq1 = []\n",
    "with torch.no_grad():\n",
    "    for batch_idx, (data, target) in enumerate(tqdm(valid_loader)):\n",
    "        data, target = data.to(device), target.to(device)\n",
    "        logits = net1(data)\n",
    "        logits_valid_freq1.append(logits.detach())\n",
    "        labels_valid_freq1.append(target.detach())\n",
    "logits_valid_freq1 = torch.cat(logits_valid_freq1, dim=0)\n",
    "labels_valid_freq1 = torch.cat(labels_valid_freq1, dim=0)\n",
    "print(logits_valid_freq1.shape, labels_valid_freq1.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(logits, targets, scaler, epochs=30, lr=1e-2, patience=10):\n",
    "    optimizer = optim.Adam(scaler.parameters(), lr=lr, weight_decay=0)\n",
    "    lr_scheduler = optim.lr_scheduler.ReduceLROnPlateau(optimizer, patience=patience, 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)\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": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "none = NoneScaler()\n",
    "temp = TempScaler(init_T=2.0).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch  0, lr: 0.0100, loss: 0.2433, acc: 0.9176, T: 2.0100\n",
      "Epoch 50, lr: 0.0001, loss: 0.2423, acc: 0.9176, T: 2.1777\n",
      "Epoch 100, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 150, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 200, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 250, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 300, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 350, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 400, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n",
      "Epoch 450, lr: 0.0000, loss: 0.2423, acc: 0.9176, T: 2.1776\n"
     ]
    }
   ],
   "source": [
    "train(logits_valid_freq1, labels_valid_freq1, temp, epochs=500)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:01<00:00, 48.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([10000, 10]) torch.Size([10000])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "logits_test_freq1 = []\n",
    "labels_test_freq1 = []\n",
    "with torch.no_grad():\n",
    "    for batch_idx, (data, target) in enumerate(tqdm(test_loader)):\n",
    "        data, target = data.to(device), target.to(device)\n",
    "        logits = net1(data)\n",
    "        logits_test_freq1.append(logits.detach())\n",
    "        labels_test_freq1.append(target.detach())\n",
    "logits_test_freq1 = torch.cat(logits_test_freq1, dim=0)\n",
    "labels_test_freq1 = torch.cat(labels_test_freq1, dim=0)\n",
    "print(logits_test_freq1.shape, labels_test_freq1.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:01<00:00, 50.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([10000, 10]) torch.Size([10000])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "logits_test_freq2 = []\n",
    "labels_test_freq2 = []\n",
    "with torch.no_grad():\n",
    "    for batch_idx, (data, target) in enumerate(tqdm(test_loader)):\n",
    "        data, target = data.to(device), target.to(device)\n",
    "        logits = net2(data)\n",
    "        logits_test_freq2.append(logits.detach())\n",
    "        labels_test_freq2.append(target.detach())\n",
    "logits_test_freq2 = torch.cat(logits_test_freq2, dim=0)\n",
    "labels_test_freq2 = torch.cat(labels_test_freq2, dim=0)\n",
    "print(logits_test_freq2.shape, labels_test_freq2.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def scale(logits, scaler):\n",
    "    if len(logits.shape) == 2:\n",
    "        return scaler(logits).softmax(dim=1)\n",
    "    else:\n",
    "        return scaler(logits).mean(dim=0).softmax(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "scaler_name = 'temp'\n",
    "\n",
    "if scaler_name == 'temp':\n",
    "    scaler = temp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_conf(acc, conf):\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(2.5, 2.25))\n",
    "    ax.plot([0,1], [0,1], 'k--')\n",
    "    ax.plot(conf.data.cpu().numpy(), acc.data.cpu().numpy(), marker='.')\n",
    "    ax.set_xlabel(r'confidence')\n",
    "    ax.set_ylabel(r'accuracy')\n",
    "    ax.set_xticks((np.arange(0, 1.1, step=0.2)))\n",
    "    ax.set_yticks((np.arange(0, 1.1, step=0.2)))\n",
    "\n",
    "    return fig, ax\n",
    "\n",
    "def plot_uncert(err, entr):\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(2.5, 2.25))\n",
    "    \n",
    "    ax.plot([0,1], [0,1], 'k--') \n",
    "    ax.plot(entr.data.cpu().numpy(), err.data.cpu().numpy(), marker='.')\n",
    "    ax.set_xticks((np.arange(0, 1.1, step=0.2)))\n",
    "    ax.set_ylabel(r'error')\n",
    "    ax.set_xlabel(r'uncertainty')\n",
    "    ax.set_xticks((np.arange(0, 1.1, step=0.2)))\n",
    "    ax.set_yticks((np.arange(0, 1.1, step=0.2)))\n",
    "\n",
    "    return fig, ax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ece = 4.332984238862991\n",
      "uce = 3.9131049066781998\n"
     ]
    },
    {
     "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,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\" width=\"250\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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,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\" width=\"250\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ece1, acc1, conf1 = eceloss(scale(logits_test_freq1, none), labels_test_freq1)\n",
    "uce1, err1, entr1 = uceloss(scale(logits_test_freq1, none), labels_test_freq1)\n",
    "\n",
    "print('ece =', ece1.item()*100)\n",
    "print(\"uce =\", uce1.item()*100)\n",
    "\n",
    "fig1, ax1 = plot_conf(acc1, conf1)\n",
    "fig2, ax2 = plot_uncert(err1, entr1)\n",
    "\n",
    "textstr1 = r'ECE={:.2f}'.format(ece1.item()*100)\n",
    "props = dict(boxstyle='round', facecolor='white', alpha=0.75)\n",
    "ax1.text(0.075, 0.925, textstr1, transform=ax1.transAxes, fontsize=14,\n",
    "         verticalalignment='top',\n",
    "         horizontalalignment='left',\n",
    "         bbox=props\n",
    "        )\n",
    "ax1.set_title(r'MC Dropout Uncalib.')\n",
    "fig1.tight_layout()\n",
    "fig1.show()\n",
    "\n",
    "textstr2 = r'UCE={:.2f}'.format(uce1.item()*100)\n",
    "ax2.text(0.925, 0.075, textstr2, transform=ax2.transAxes, fontsize=14,\n",
    "         verticalalignment='bottom',\n",
    "         horizontalalignment='right',\n",
    "         bbox=props\n",
    "        )\n",
    "ax2.set_title(r'MC Dropout Uncalib.')\n",
    "fig2.tight_layout()\n",
    "fig2.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ece = 0.7458093110471964\n",
      "uce = 2.818675898015499\n"
     ]
    },
    {
     "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,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\" width=\"250\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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,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\" width=\"250\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ece2, acc2, conf2 = eceloss(scale(logits_test_freq1, scaler), labels_test_freq1)\n",
    "uce2, err2, entr2 = uceloss(scale(logits_test_freq1, scaler), labels_test_freq1)\n",
    "\n",
    "print('ece =', ece2.item()*100)\n",
    "print(\"uce =\", uce2.item()*100)\n",
    "\n",
    "fig3, ax3 = plot_conf(acc2, conf2)\n",
    "fig4, ax4 = plot_uncert(err2, entr2)\n",
    "\n",
    "textstr3 = r'ECE={:.2f}'.format(ece2.item()*100)\n",
    "props = dict(boxstyle='round', facecolor='white', alpha=0.75)\n",
    "ax3.text(0.075, 0.925, textstr3, transform=ax3.transAxes, fontsize=14,\n",
    "        verticalalignment='top',\n",
    "        horizontalalignment='left',\n",
    "        bbox=props\n",
    "        )\n",
    "ax3.set_title(r'MC Dropout TS')\n",
    "fig3.tight_layout()\n",
    "fig3.show()\n",
    "\n",
    "textstr4 = r'UCE={:.2f}'.format(uce2.item()*100)\n",
    "ax4.text(0.925, 0.075, textstr4, transform=ax4.transAxes, fontsize=14,\n",
    "         verticalalignment='bottom',\n",
    "         horizontalalignment='right',\n",
    "         bbox=props\n",
    "         )\n",
    "ax4.set_title(r'MC Dropout TS')\n",
    "fig4.tight_layout()\n",
    "fig4.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "eces1 = []\n",
    "eces2 = []\n",
    "uces1 = []\n",
    "uces2 = []\n",
    "aces1 = []\n",
    "aces2 = []\n",
    "for nbins in range(5, 100, 5):\n",
    "    ece = eceloss(logits_test_freq1.softmax(dim=1), labels_test_freq1, n_bins=nbins)[0]\n",
    "    uce = uceloss(logits_test_freq1.softmax(dim=1), labels_test_freq1, n_bins=nbins)[0]\n",
    "    ace = classwise_ace(logits_test_freq1.softmax(dim=1), labels_test_freq1, n_bins=nbins)[0]\n",
    "    eces1.append(ece.item())\n",
    "    uces1.append(uce.item())\n",
    "    aces1.append(np.mean(ace))\n",
    "    ece = eceloss(logits_test_freq2.softmax(dim=1), labels_test_freq2, n_bins=nbins)[0]\n",
    "    uce = uceloss(logits_test_freq2.softmax(dim=1), labels_test_freq2, n_bins=nbins)[0]\n",
    "    ace = classwise_ace(logits_test_freq2.softmax(dim=1), labels_test_freq2, n_bins=nbins)[0]\n",
    "    eces2.append(ece.item())\n",
    "    uces2.append(uce.item())\n",
    "    aces2.append(np.mean(ace))\n",
    "eces1 = np.array(eces1)\n",
    "eces2 = np.array(eces2)\n",
    "uces1 = np.array(uces1)\n",
    "uces2 = np.array(uces2)\n",
    "aces1 = np.array(aces1)\n",
    "aces2 = np.array(aces2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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,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+8+feoo3DtyjuAaCK+5fXGtOvMfNNLjvBgKjlet0rADjexAvdMwJ9++wYU9bVobN5733eX97E+FxUQS4AlIUHZ6LewJcAYn7KS5ygPjBheqM3QMmHkC7dz9DCz14A8hEArFIgPd4LM5adPoMj29wPQ630lgJ8Rago9Orolt18v7mCkjR7Et6lisgJSXI60mABGKOAOxMjOjVEDS8BRCsfqAM0owZ0/SbQagnGIbF+gT/IwEXE+A97uLJcWnXYANntoNzaTd1t3h/u3l2gusbV0CC48RScUqAKyBxOrEcFgmQAAmQAAmUgABXQEoAL4hL6QUrCEgsQgIkQAIkQAIkQAIkQAIkEB4CFEDCw5G1kAAJkAAJkAAJkAAJkAAJBEGAAkgQkFiEBEiABEiABEiABEiABEggPAQogISHI2shARIgARIgARIgARIgARIIggAFkCAgsQgJkAAJkAAJkAAJkAAJkEB4CFAACQ9H1kICJEACJEACJEACJEACJBAEAQogQUBiERIgARIgARIgARIgARIggfAQoAASHo6shQRIgARIgARIgARIgARIIAgCFECCgMQiJEACJEACJEACJEACJEAC4SFAASQ8HFkLCZAACZAACZAACZAACZBAEAQogAQBiUVIgARIgARIgARIgARIgATCQ4ACSHg4shYSIAESIAESIAESIAESIIEgCFAACQISi5AACZAACZAACZAACZAACYSHAAWQ8HBkLSRAAiRAAiRAAiRAAiRAAkEQoAASBCQWIQESIAESIAESIAESIAESCA+BMuGphrWQAAmUVgL33XevzJgxLajhp6eny9Sp3/otu3HjBhk3bqzMnDld9uzZLbm5uZKVVUfS0tKkffuO0q9ff31sVBDOto06uSWBQASuuupSWbp0ib4Xx46dEKi45TzvcQsOHkSJgPHd2bx5C3nnnQ+L7EX//ucJ7tu33/5AWrTILrIs7+8i8fCkiQAFEBMM7pIACZSMAH7MikoZGZl+Tw8f/oSMH/+55zwED5THDxoSHvg2bdooTz75jKeMeackbZvr4T4JFEUA9yPuRSTsL1myOOBDmVEf73GDBLfxSID3dzzOqnNjogDiHFvWTAKlikAwb9L8ARk8+Eb55Zc5+vSQIfdL3779LUXxkPfuu29JdnZLS75xUJK2jTq4JYFgCGCFDgkrcrhnx48fK0OGPBDw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g2/Qwg9XPwKiZAGXEuA97tKJcWG38J23ZMkigVtp76CsLuyu7pKT9zdXQJyddQogzvJl7S4nQAHE5RPkUPdg94EfLrytRvI2sMTbb6RwrLroivgfCUSYAO/xCANncxElEIn7mwKIs1NKAcRZvqzd5QQogLh8gtg9EiABEiABEogCAQogzkJnIEJn+bJ2EiABEiABEiABEiABEiABEwEKICYY3CUBEiABEiABEiABEiABEnCWAAUQZ/mydhIgARIgARIgARIgARIgARMBCiAmGNwlARIgARIgARIgARIgARJwlgAFEGf5snYSIAESIAESIAESIAESIAETAQogJhjcJQESIAESIAESIAESIAEScJYABRBn+bJ2EiABEiABEiABEiABEiABEwEKICYY3CUBEiABEiABEiABEiABEnCWAAUQZ/mydhIgARIgARIgARIgARIgARMBCiAmGNwlARIgARIgARIgARIgARJwlgAFEGf5snaXE0hKStI9LCjIl6NHC1zeW3aPBEiABEiABEjAaQJ4HsBzAZLxnOB0m6WtfgogpW3GOV4LgdTUVElIECV8iBw4cMByjgckQAIkQAIkQAKljwCeB/BcgOeDcuXKlT4AERgxBZAIQGYT7iWQkZGhvmAS9JfMrl07ZP/+fVwJce90sWckQAIkQAIk4BgBrHzgOQDPAxA+8HyQnp7uWHulueIypXnwHDsJVKhQQb/dwNuO/PwCycn5W3/pJCYWqmaREAmQAAmQAAmQQOkgUKiOXbjykZSUqJ8P8JzAFH4CCUdVCn+1rJEEYodAQUGBrFu3Tqtg4c+BfxGxM3fsKQmQAAmQAAmEk4Cx8gHVq3r16kliIpWFwsnXqIsCiEGC21JNAILHvn37JDc3Vwsi+fmFxmelGgoHTwIkQAIkQAKliAAMziF4QO0KKx9QwWJyhgAFEGe4slYSIAESIAESIAESIAESIAEbAlxXsoHCLBIgARIgARIgARIgARIgAWcIUABxhitrJQESIAESIAESIAESIAESsCFAAcQGCrNIgARIgARIgARIgARIgAScIUA3vM5wZa0xSGDPnoPaFW8Mdj3uupyRkaqizybq+cC8MLmPAOfIfXNi1yPOkx0Vd+Vxjtw1H+gNfn8wL0zOEaAA4hxb1hxjBBAH5MgRer9y27RxTtw2I7794Rz5MnFjDufJjbNi7RPn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u1wTCYaTZk23KWoQud2/Ag3dZjeYFLxs2rTJD4CCEyAG1+E1AggggAACCCCAQPYEGAOSvTot64hWrlzpj89QEKI7Uqk1Qq0i+/fv97tWqRvVc889FzmIXOtqrIeClHDriC2Elmt/mzdvNocOHTKaE0Tduvbu3WsWLFgQu2+7Pc8IIIAAAggggAAC2RJgJvRs1WdVR6OxGgom9FDQoAAjbvB4uRmpxUMtIdq39mkDnXL3k+T6Fy5crvlteJMsb5b3ffO2lLf486BwG9501jR1lM56CZeKegqLpO89dZS+Omlu5ja8SdcKLSBJC9fR/tWaEbx7VS2LroCGcR61FGVfCCCAAAIIIIBAfQowBqQ+641SI4AAAggggAACCCBQlwIEIHVZbRQaAQQQQAABBBBAAIH6FCAAqc96o9QIIIAAAggggAACCNSlAAFIXVYbhUYAAQQQQAABBBBAoD4FCEDqs94oNQIIIIAAAggggAACdSlAAFKX1UahEUAAAQQQQAABBBCoTwFuw1uf9UapExBoaiIeT4C16l3qfuykdAtQR+muH1s66slKpPeZOkpH3XA9kHw9MBFh8sbkgAACCCCAAAIIIIAAAl8I8JMvpwICCCCAAAIIIIAAAgg4EyAAcUZNRggggAACCCCAAAIIIEAAwjmAAAIIIIAAAggggAACzgQIQJxRkxECCCCAAAIIIIAAAggQgHAOIIAAAggggAACCCCAgDMBAhBn1GSEAAIIIIAAAggggAACBCCcAwgggAACCCCAAAIIIOBMgADEGTUZIYAAAggggAACCCCAAAEI5wACCCCAAAIIIIAAAgg4EyAAcUZNRggggAACCCCAAAIIIEAAwjmAAAIIIIAAAggggAACzgQIQJxRkxECCCCAAAIIIIAAAggQgHAOIIAAAggggAACCCCAgDMBAhBn1GSEAAIIIIAAAggggAACBCCcAwgggAACCCCAAAIIIOBMgADEGTUZIYAAAggggAACCCCAAAEI5wACCCCAAAIIIIAAAgg4EyAAcUZNRggggAACCCCAAAIIIEAAwjmAAAIIIIAAAggggAACzgQIQJxRkxECCCCAAAIIIIAAAggQgHAOIIAAAggggAACCCCAgDMBAhBn1GSEAAIIIIAAAggggAACBCCcAwgggAACCCCAAAIIIOBMgADEGTUZIYAAAggggAACCCCAAAEI5wACCCCAAAIIIIAAAgg4EyAAcUZNRggggAACCCCAAAIIINAMAQIIIOBC4PDhw2bXrl3m6NGjpq+vz8yZM8fMnTvXrF271kyZMqVgEbT+jh07zJEjR0xbW5vp7e0teduCO+bDkgUWL15stm3b5tdb3EbUU5xM7Zfr+7Rnzx7T09NjWltb/QxWrlxp9IhL1E+cTO2XW2vVj/6/Urr77rvNunXrCn6HtJ7dlv/vpEHKrMAACQEEEEhY4Pnnnx948sknB7zgw8/p1KlTA97F08DMmTP9x86dO2NLoG3mz58/oH0Ek93+1VdfDS7mdQICslddHTp0KHbv1FMsTc0/+N73vud/J8L1oXoKf09s5tSPlUj+WfWi/+/C9aP3jz32WGwdqWTUU/L1Qw7pEDDpKAalQACBrAooUNAFU1TSH2QbhMQFEgo+9Mc8KtkLYwU0pGQEdEFk6yh8QRXMkXoKaiT3+vHHH/eDj/A5r7pRHaiuohL1E6VS+2Vea8eA6kjPUUn1prrQ/4tRiXqKUmFZFgUYA5LZti0ODIGhF1BXAnW72r59e2RhFi5caPRQ2rBhg9/1ILjili1b/GVx3UpWrVrlr7558+bgZryuocDWrVuL7o16KkpUkxV0nh87dsw888wzg7ot7t+/P/f90fcumKifoEayr9VVVF1Lbbe4cG7qbvrEE0+Yl19+OfyRoZ4GkbAgwwIEIBmuXA4NgaEW8H49N6dPnzadnZ3+hVNUeYLBhdcKkrfKCy+84L9funRp3nL7Rn/M9VB/eOVDqq2AgkfZx11M2dyoJyuR3LMCD120qi6C3xmbo5YpmF+zZs2g+qJ+rFLyzxq30dLSUjCjefPmRf5/SD0VZOPDjAkQgGSsQjkcBNIkYIMCO6gyqmzBAei6yLJJQYVSsYtfu71+ASbVTkB1pzqIutgN5kI9BTWSe61f1pWWLVsWmYlu6rB7926zcePGvM+pnzyOxN/o/7q9e/cWzEeD0sP/r1FPBcn4MIMCBCAZrFQOCYG0CKgrgk2LFi2yL/Oew3+I7Yc2GLEBhl0efra/NnZ3d4c/4n0VAuru8+yzzxbdA/VUlKjqFXRRe+DAAX8/tstiqTulfkqVqs16+v9K9aW7xtkfYMJ7VktWOJCknsJKvM+6AAFI1muY40NgCAX0q2xXV5c5ePBg7C/p9g+viqn1bbIBhW67Wyi1t7f7H3/wwQeFVuOzMgTUmqQL3WLBn3ZJPZUBW+Gq6spoUyl1YtfVM/UT1Ej+tW0xVPChIETdGINJ7xWgaBxPMFFPQQ1eN4IA84A0Qi1zjAgMoYBaOOJaOVQs2/VAr4O/7vb392tR0WRbQPRHnVS9gBy92yKbffv2lbQz6qkkpqpW8u5wldteAYgubjVgWfbqzqMgXfPpBL8/dgPqx0q4edaYqSVLluRarHQTB41t0xw63p2v/LmM9N0K/59IPbmpH3JJjwABSHrqgpIg0JACduC5fjks99fdIJguxEjVC3z/+983P/jBD6rfUcweqKcYmAKLgxenCj50UasLWnsRqyB+9erV/gD08BiQAruN/Ij6iWQpa6Hu+qeWDnsHObXyqjVELbylBvbFMqSeignxedoF6IKV9hqifAhkWMDedlKBR7hLQrl/YGkBqf5E0YWsurQFu8IV2yv1VEyo+s+DYwk0GD0YfGjvavnQ90d3UQp3+aF+qvevZA/2rmTBbRWIrFixInJsCPUUlOJ1IwgQgDRCLXOMCKRQQBdVumDSr7i6e4/9NTeFRW2YIukX21IGnjcMSAoPVMF61HfF3qpadUgwPrQVp0DDm/Hcv4X1yZMn88a/2SBEzyQEGlmAAKSRa59jR2AIBdRlRBdS6pIQ1fWq2OBzW3TbPSXqosyuw3NxAbVGhVuhim9l/PEHpaxHPZWiFL2OHeekT+PuJhf8DgUnueN7FG2a1FK1IqqVQ61UdkC6gvrg/3MKEDXxajBRT0ENXjeCAAFII9Qyx4hAygTWr1/vD54N/lEOFzF40RX+LOp9qX/Ao7Zt9GX6NVYtUlGDmIvZUE/FhKr/3N7pTXsKBhrhPdsg3N5RSZ9TP2GlZN8rsNBkkOHvkro1Bu8GqO9bsLsc9ZRsvbD39AkQgKSvTigRApkW0C/tPT09eb8IRh2wvegK9n+PWu/ixYv+YnvxFbUOywoLbNq0yTz33HOFV4r5lHqKganh4uCYnEKBtv1M3y+bqB8rkfyzWp7UurFu3brYzNQaogBFKXgHQOoplowPMirAXbAyWrEcFgJpFNAfaE2oppaPcMCgP9z6g2z7stuLrmKDM23XnuCkh2k89rSWSQGeWkA6OzuLFlHd5mxSFxPVFfVkRZJ7Dp7b+j6EvzuFcqZ+CunU9jN9j1Q3xepHdyrTbOnBH1eop9rWBXtLvwABSPrriBIikAkBBRfqchAVfOgANdla8A+y7cJQbECt3caunwkshwehLj0aKBuX5G+DE90sIOxs31NPcYLVL7cXp9qTzve4blg2WO/o6MhlSv3kKBJ/YVtjS8lowYIFJjh5KvVUihrrZEmALlhZqk2OBYGUCuiiSXfniQs+VGxNtha8sNJre+EVd8cYXfTaAMS2nKSUILPFop7cVK0mt1Mq9F2wQeDy5ctzhaJ+chSJv5g3b57fBcvWQ6EM1U1OQYhN1JOV4LlRBAhAGqWmOU4EhkhAf4x1Vxj9sdWkg+qGFX5oXIi6JNiAwxb16aef9l++8sordlHes+1DXcndm/J2xJuqBKinqvhK2thOMGjP+fBGdrl+SQ8H49RPWCuZ97rrlbpf2QkI43JREKnWqvBYEeopTozlmRQYICGAAAIJCjz++OMDM2fOLOkRVQxvgLS/7alTp/I+9v6AD8yfP39A+yclJ+C1TOXqbufOnbEZUU+xNDX7QP76Lu3Zsydvn/a7oO9D+HtiV6R+rESyz/b78vzzz0dmpM9VT16X08jPqadIFhZmUGCYjimTkRUHhQACQy6glo7NmzeXVA79ctjV1RW5rm0h0S+E+oVX40U0nkR93bdv3x65DQurE7DjPqK6k6iuXnrppUEtVtRTdealbG2/U+qSpTlBvIDDbz1UC6PuZFZoADT1U4pw9euohUOtIOoeqv+v1LKrejpy5Ig/b47uhKUuV3GJeoqTYXmWBAhAslSbHAsCGRbQhbC6meiPui6y9Ie90B/xDFM4OTQbeERd0OqzqOUqGPWUfPUEjfUd0Hchrj7CpQluy/corFPb9/q/SsGInu0Yj1L/z6KealsX7C19AgQg6asTSoQAAggggAACCCCAQGYFGISe2arlwBBAAAEEEEAAAQQQSJ8AAUj66oQSIYAAAggggAACCCCQWQECkMxWLQeGAAIIIIAAAggggED6BAhA0lcnlAgBBBBAAAEEEEAAgcwKEIBktmo5MAQQQAABBBBAAAEE0idAAJK+OqFECCCAAAIIIIAAAghkVoAAJLNVy4EhgAACCCCAAAIIIJA+AQKQ9NUJJUIAAQQQQAABBBBAILMCBCCZrVoODAEEEEAAAQQQQACB9AkQgKSvTigRAggggAACCCCAAAKZFSAAyWzVcmAIIIAAAggggAACCKRPgAAkfXVCiRBAAAEEEEAAAQQQyKwAAUhmq5YDQwABBBBAAAEEEEAgfQIEIOmrE0qEAAIIIIAAAggggEBmBQhAMlu1HBgCCCCAAAIIIIAAAukTIABJX51QIgQQQAABBBBAAAEEMitAAJLZquXAEEAAgfQIvPzyy2bWrFn+Iz2lSldJtmzZYlasWOEbdXZ2+q9Pnz5dViFr4bx58+ZcXR0+fLis/FkZAQQQKEWguZSVWAcBBBBAAAEEkhE4duyYefLJJ01fX18uA73WcgUgU6ZMyS3nBQIIIJAFAQKQLNQix4AAAgggULcCGzZs8IOPJUuWmI0bN/oBhwKQoQo+FPDYoKetra1uXSk4AgikV4AAJL11Q8kQQAABBDIuoC5TCjRaW1vN9u3bc0er93PmzMm9d/li7dq1Rg8SAgggkJQAY0CSkmW/CCCAAAIIFBFQNyuluXPnFlmTjxFAAIHsCBCAZKcuORIEEEAAgToTsIPMW1pa6qzkFBcBBBCoXIAApHI7tkQAAQQQQAABBBBAAIEyBQhAygRjdQQQQAABBBBAAAEEEKhcgACkcju2RAABBCoW2LVrV26+B+1Edz3S/AuLFy/OLV+/fr0/QDkuE7sPza8RvIVrcP1i69jPNe+Ekvaj+SgKlcOuE5yzYvXq1f5tY4N5F3qtfShv7UN56xhK2YfN25ZPz3KKm6/Czothj09l0rgLbaNtday1SMoneCx23ypvOKnblZ0TxZb7wIEDuWX6zC4Pb1vu+0qcrZnKEZWizplyz13tV/tRnVsL1ZF1s2NjovJnGQII1L8Ad8Gq/zrkCBBAoM4FdLFpb8VqD0UXjroo1ePgwYO526Laz5N41kVf1HwUwXKoXFHr6Bh0Ab5v376id2/ShefWrVsHHYLdx7Zt28zSpUsjP9cFazDpYl4PlXHNmjX+bWyDn4dfK/DQujb19/fblxU9y0x1Z8dy2J3o/QsvvOA/oo5Hd7lSCgYodpndR7XPlTqXk28l566OWedK2EzL9bBuJ0+eLKcorIsAAnUkQAtIHVUWRUUAgewJ6IJLF9W6C5ICDV106SJec0LYpAvJpJPKocBC5VD+UeXQhbYuHDVHhF1HZV65cmWueDt27Mi9jnuh4EPb2OPVs4IHm6Iu6HWhb4MP2dj8u7q6zLPPPutvqgtX/Xofl7S9DT6Uv7ar5nazuoC2F9IyUaCh8li7hQsX+kXR8ezfvz9XLK2r9fSw6+iWu3ZZcHluowpeVOJcTjaVnrs6R2SngGv37t2+l8ysm86FoboFcTnHz7oIIFC5AAFI5XZsiQACCNREQBekuhDTs5IuvjQnhL0Ie/XVV2uST7GdaNI5lcPmGy6HggBdNL700ku5dVRmXcjbC2l7gV8or2eeecbfxh6vnjUBny7gbQoHXbqIV1LgELRRebRMAYlSVMuKlutiWb/WKy+tqzJrO1sGrVNusgGR9qEgSq02thVDdrJUHkoqv8rgMlXiXG75dOzlnrv2HHniiSdy543NV246F2x92uU8I4BAtgQIQLJVnxwNAgjUoYC9SA0XfcGCBf4iVxeuceVYtmxZrmhPP/107iI7t9B7YQMQLStW3rh8dAFv9xNsyVDrgf3F3LZ2BPPWa124alvlrUApLgUDrLh1Slluy6R1g4FTeFuV1wYlccFReJtavS/XuZJ84/Io5dyttvtbJeVlGwQQSIcAAUg66oFSIIBAAwvYi+4wQXt7e25RsYv63IpVvIgrh72A1q5LWae3t7fiUgQvaG0g8corr+T2py5PcY+jR4/669nn3EZfvFDXnmpaPIL7swGS9qfgp1CyAZyrlqxCZbGfRTnbz8p5jjsfCp27dhsZ6iYAtp7LyZd1EUCgvgUYhF7f9UfpEUAgAwK1uiiulqKUcgSDkWrzi9o+WAa1eujivqenx1+1WOuG3V9csLZo0SK7StXPNsjp6Ogoui8boKhcOqbgMRbdOKEVgmWwzpVkFdxPqdura5iCMXnYAec6rzT+SK1gweCo1H2yHgII1JcAAUh91RelRQABBIZUQONEkkzBC1pdGCvZFhVduFYzaFwXuLVKNsgJ/tIft++gmd0ubl1Xy6OcXeWtYOO1117zx+vYliS5aIyOHhr/o25tNnBzVS7yQQABdwJ0wXJnTU4IIIAAAkUEbLCh1Wxri72A7+7uLrJ14Y/t/gqvVdqndl82SCq0VXAdu12h9V18FuXsIl+bhxw0PkZ3vtK4nGD3OHnpjmxpCdZsmXlGAIHaCRCA1M6SPSGAAAIIVCkQHA9gWyxsNyfbFavKLGqyuW1BCAYXcTsOBk52u7h1XS2PcnaVdzgfjQnRna90JzEFI0oKPmzrSHh93iOAQP0LEIDUfx1yBAgggECsQPDiN3Ylxx8Ef30PZ71z505/kX4ht11wVq1a5S/TxX5wPo3wti7f23EKKpO6DcUlXUjb284G53aJW7+Wy8t1rmXele5LwYgdpJ7Gc7fS42I7BBDIFyAAyffgHQIIIFA3AsW68+ji98iRI6k7nrggQn3/7S/zGu9hky5IbTCyadOmQTNo2/X0rF/NS2mVCG5TyWsFINZ/8+bNsd2F7PwlykO/8rtM5Tq7KltcuWz+tv7S0lpky8UzAgjUToAApHaW7AkBBBBwKhC8QAt3V9FFXFr70Ws+DAUbto+/go7169fnJhHUcdkWBgtq59rQNosXL84LNHSsOn7dnlfBgL2Atdsm9awJGZWU32OPPZYrk8qoi2yV07aOaLxDsL78DRP+pxLnhIvk715BZGdnp38LXvnIT2b2PLD1t3z5chfFIQ8EEBgCAe6CNQToZIkAAgjUQkAtA7qo1QWbLjbVfUnvdTGnZfZCPhyc1CLvavah4ELl1SOcVGY7DiD4mZZrjIBmH9exKdCISmopsWNHoj6v5TLlpRm7baAXVyYFH+GAqpbliNtXJc5x+6rlct1UQHVob8EbtW8NSretXlGfswwBBOpbgBaQ+q4/So8AAg0uoIt1BSLqDqTAQw9drOuiVxfsabyIU/cqXbhrTITKqqRnXXSqzHZZuGq1XJ/r2ILHpdfalyy0X9s1Krx9Eu+Vd1dXl9ExBctkj0efDUXwoWOt1DkJp+A+VYeqK7nIydaXXtt6dN1dLVg+XiOAQPICwwa8lHw25IAAAggggAACCCCAAAIIGEMLCGcBAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACtct7fwAAAcVJREFUCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAIIEIBwDiCAAAIIIIAAAggggIAzAQIQZ9RkhAACCCCAAAIIIIAAAgQgnAMIIIAAAggggAACCCDgTIAAxBk1GSGAAAIIIIAAAggggAABCOcAAggggAACCCCAAAIIOBMgAHFGTUYIIIAAAggggAACCCBAAMI5gAACCCCAAAIIIIAAAs4ECECcUZMRAggggAACCCCAAAII/H8tjPDPnHgD/gAAAABJRU5ErkJggg==\" width=\"400\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3.2))\n",
    "ax.plot(range(5, 100, 5), eces1*100, 'k-.', label=r'ECE$_A$')\n",
    "ax.plot(range(5, 100, 5), eces2*100, 'g-.', label=r'ECE$_B$')\n",
    "\n",
    "ax.plot(range(5, 100, 5), aces1*100, 'k-', label=r'ACE$_A$')\n",
    "ax.plot(range(5, 100, 5), aces2*100, 'g-', label=r'ACE$_B$')\n",
    "\n",
    "ax.plot(range(5, 100, 5), uces1*100, 'k--', label=r'UCE$_A$')\n",
    "ax.plot(range(5, 100, 5), uces2*100, 'g--', label=r'UCE$_B$')\n",
    "\n",
    "ax.set_xlabel(r'number of bins')\n",
    "ax.set_ylabel(r'calibration error in \\%')\n",
    "\n",
    "fig.tight_layout(pad=3.9, w_pad=1, h_pad=1)\n",
    "ax.legend(bbox_to_anchor=(0., 1.01), loc=3, ncol=3, borderaxespad=0.,\n",
    "               columnspacing=2.0, prop={'size': 9})\n",
    "plt.show()\n",
    "fig.savefig(\"number_of_bins.pdf\", bbox_inches='tight', dpi=300)"
   ]
  },
  {
   "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
}
