{
 "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",
    "from mmce import mmce_loss\n",
    "from brier import brier_loss\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": [
    "dataset = 'cifar100'\n",
    "base_model = 'resnet50'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "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",
    "    train_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",
    "    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",
    "    train_indices = torch.load('./train_indices_cifar10.pth')\n",
    "    valid_indices = torch.load('./valid_indices_cifar10.pth')\n",
    "elif dataset == 'cifar100':\n",
    "    num_classes = 100\n",
    "    train_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",
    "    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",
    "    train_indices = torch.load('./train_indices_cifar100.pth')\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",
    "train_loader = torch.utils.data.DataLoader(train_set, batch_size=batch_size,\n",
    "                                           sampler=SubsetRandomSampler(train_indices), pin_memory=True)\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": {},
   "outputs": [],
   "source": [
    "base_path = '/media/fastdata/laves/iclr_snapshots/'\n",
    "if base_model == 'resnet34':\n",
    "    snapshots = {\n",
    "        'mmce':    'swag_resnet34_cifar10_best_2020-09-28_23.06.18.pth.tar',\n",
    "        'uce':     'swag_resnet34_cifar10_best_2020-09-29_09.43.52.pth.tar',\n",
    "        'entropy': 'swag_resnet34_cifar10_best_2020-09-29_14.56.01.pth.tar',\n",
    "    }\n",
    "else:\n",
    "    snapshots = {\n",
    "        'mmce':    'swag_resnet50_cifar100_best_2020-09-28_23.06.33.pth.tar',\n",
    "        'uce':     'swag_resnet50_cifar100_best_2020-09-29_09.43.56.pth.tar',\n",
    "        'entropy': 'swag_resnet50_cifar100_best_2020-09-29_16.25.00.pth.tar',\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "pycharm": {}
   },
   "outputs": [],
   "source": [
    "from models import FrequentistNet, MonteCarloDropoutNet, GaussianDropoutNet, BBBNet, SWAGNet\n",
    "\n",
    "nets = {\n",
    "    'mmce': SWAGNet(num_classes, base_model).to(device),\n",
    "    'uce': SWAGNet(num_classes, base_model).to(device),\n",
    "    'entropy': SWAGNet(num_classes, base_model).to(device)\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading previous weights at epoch 149\n",
      "Loading previous weights at epoch 296\n",
      "Loading previous weights at epoch 269\n"
     ]
    }
   ],
   "source": [
    "for net in nets:\n",
    "    checkpoint = torch.load(base_path+snapshots[net], map_location=device)\n",
    "    nets[net].load_state_dict(checkpoint['state_dict'])\n",
    "    print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "\n",
    "    optimizer = optim.Adam(nets[net].parameters(), lr=3e-6, weight_decay=1e-6)\n",
    "    nets[net].train_swag(train_loader, optimizer, device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [01:17<00:00,  1.02it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mmce acc: 0.6769999861717224\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [01:17<00:00,  1.02it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "uce acc: 0.7107999920845032\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [01:18<00:00,  1.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "entropy acc: 0.6811000108718872\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "logits_test = {}\n",
    "\n",
    "for key in nets:\n",
    "    nets[key].eval()\n",
    "    logits = []\n",
    "    labels_test = []\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",
    "            pred = nets[key](data, mc=True, train=False)\n",
    "            if 'freq' not in key:\n",
    "                pred = pred.mean(dim=0)\n",
    "            logits.append(pred.detach())\n",
    "            labels_test.append(target.detach())\n",
    "    logits = torch.cat(logits, dim=0)\n",
    "    logits_test[key] = logits\n",
    "    labels_test = torch.cat(labels_test, dim=0)\n",
    "    print(key+' acc:', accuracy(logits, labels_test))\n",
    "\n",
    "del nets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:01<00:00,  2.20it/s]\n"
     ]
    }
   ],
   "source": [
    "eces = {}\n",
    "aces = {}\n",
    "uces = {}\n",
    "mmces = {}\n",
    "briers = {}\n",
    "nlls = {}\n",
    "\n",
    "for net in logits_test:\n",
    "    eces[net]   = []\n",
    "    aces[net]   = []\n",
    "    uces[net]   = []\n",
    "    mmces[net]  = []\n",
    "    briers[net] = []\n",
    "    nlls[net]   = []\n",
    "\n",
    "temps = {\n",
    "    'mmce':    1.0,\n",
    "    'uce':     1.0,\n",
    "    'entropy': 1.0,\n",
    "}\n",
    "\n",
    "for net in tqdm(eces):\n",
    "    nbins = 15\n",
    "    \n",
    "    ece = eceloss((temps[net]*logits_test[net]).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "    ace = classwise_ace((temps[net]*logits_test[net]).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "    uce = uceloss((temps[net]*logits_test[net]).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "    mmce = mmce_loss((temps[net]*logits_test[net]).softmax(dim=1), labels_test).sqrt()\n",
    "    brier = brier_loss((temps[net]*logits_test[net]).softmax(dim=1), labels_test)\n",
    "    nll = torch.nn.functional.cross_entropy((temps[net]*logits_test[net]), labels_test)       \n",
    "\n",
    "    eces[net] = ece.item()\n",
    "    aces[net] = np.mean(ace)\n",
    "    uces[net] = uce.item()\n",
    "    mmces[net] = mmce.item()\n",
    "    briers[net] = brier.item()\n",
    "    nlls[net] = nll.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cifar100/resnet50\n",
      "\n",
      "mmce\n",
      "ece:   17.8\n",
      "ace:   18.5\n",
      "uce:   23.1\n",
      "mmce:  14.3\n",
      "brier: 0.49\n",
      "nll:   1.66\n",
      "\n",
      "uce\n",
      "ece:   20.0\n",
      "ace:   20.3\n",
      "uce:   23.5\n",
      "mmce:  16.8\n",
      "brier: 0.47\n",
      "nll:   1.95\n",
      "\n",
      "entropy\n",
      "ece:   3.1\n",
      "ace:   12.8\n",
      "uce:   3.8\n",
      "mmce:  2.0\n",
      "brier: 0.44\n",
      "nll:   1.42\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(dataset+'/'+base_model)\n",
    "print()\n",
    "\n",
    "for net in logits_test:\n",
    "    print(net)\n",
    "    print('ece:  ', np.round(eces[net]*100,  decimals=1))\n",
    "    print('ace:  ', np.round(aces[net]*100,  decimals=1))\n",
    "    print('uce:  ', np.round(uces[net]*100,  decimals=1))\n",
    "    print('mmce: ', np.round(mmces[net]*100, decimals=1))\n",
    "    print('brier:', np.round(briers[net],    decimals=2))\n",
    "    print('nll:  ', np.round(nlls[net],      decimals=2))\n",
    "    print()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Eval temperature dependency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:44<00:00, 14.75s/it]\n"
     ]
    }
   ],
   "source": [
    "eces = {}\n",
    "aces = {}\n",
    "uces = {}\n",
    "mmces = {}\n",
    "briers = {}\n",
    "nlls = {}\n",
    "\n",
    "for net in logits_test:\n",
    "    eces[net]   = []\n",
    "    aces[net]   = []\n",
    "    uces[net]   = []\n",
    "    mmces[net]  = []\n",
    "    briers[net] = []\n",
    "    nlls[net]   = []\n",
    "\n",
    "temps = np.arange(0.5, 3.5, 0.1)\n",
    "\n",
    "for net in tqdm(eces):\n",
    "    nbins = 15\n",
    "    \n",
    "    eces1 = []\n",
    "    uces1 = []\n",
    "    aces1 = []\n",
    "    mmces1 = []\n",
    "    briers1 = []\n",
    "    nlls1 = []\n",
    "    \n",
    "    for t in temps:\n",
    "    \n",
    "        ece = eceloss((logits_test[net]/t).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "        ace = classwise_ace((logits_test[net]/t).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "        uce = uceloss((logits_test[net]/t).softmax(dim=1), labels_test, n_bins=nbins)[0]\n",
    "        mmce = mmce_loss((logits_test[net]/t).softmax(dim=1), labels_test).sqrt()\n",
    "        brier = brier_loss((logits_test[net]/t).softmax(dim=1), labels_test)\n",
    "        nll = torch.nn.functional.cross_entropy((logits_test[net]/t), labels_test)       \n",
    "\n",
    "        eces1.append(ece.item())\n",
    "        uces1.append(np.mean(ace))\n",
    "        aces1.append(uce.item())\n",
    "        mmces1.append(mmce.item())\n",
    "        briers1.append(brier.item())\n",
    "        nlls1.append(nll.item())\n",
    "\n",
    "    eces[net] = np.array(eces1)\n",
    "    aces[net] = np.array(uces1)\n",
    "    uces[net] = np.array(aces1)\n",
    "    mmces[net] = np.array(mmces1)\n",
    "    briers[net] = np.array(briers1)\n",
    "    nlls[net] = np.array(nlls1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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,iVBORw0KGgoAAAANSUhEUgAAAlgAAAH0CAYAAADhUFPUAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACWKADAAQAAAABAAAB9AAAAACc34KhAABAAElEQVR4Aex9B3wc1bX+2b6rXl1kW5blXsAU94aNC4aAjW2wSQiJKYZAQsuD8H9JIDxCXgppOC/hJUCchJAXAzam27h34wLGvRdZki1bve1q6/+eETM7d7SSVtKWmdlz+Im5bW75Zr175txzv2MIMAESQoAQIAQIAUKAECAECIGIIWCMWE/UESFACBAChAAhQAgQAoSAgAApWPRBIAQIAUKAECAECAFCIMIIkIIVYUCpO0KAECAECAFCgBAgBEjBos8AIUAIEAKEACFACBACEUaAFKwIA0rdEQKEACFACBAChAAhQAoWfQYIAUKAECAECAFCgBCIMAKkYEUYUOqOECAECAFCgBAgBAgBUrDoM0AIEAKEACFACBAChECEESAFK8KAUneEACFACBAChAAhQAiQgkWfAUKAECAECAFCgBAgBCKMAClYEQaUuiMECAFCgBAgBAgBQoAULPoMEAKEACFACBAChAAhEGEESMGKMKDUHSFACBAChAAhQAgQAqRg0WeAECAECAFCgBAgBAiBCCNAClaEAaXuCAFCgBAgBAgBQoAQIAWLPgOEACFACBAChAAhQAhEGAFSsCIMKHVHCBAChAAhQAgQAoQAKVj0GSAECAFCgBAgBAgBQiDCCJCCFWFAqTtCgBAgBAgBQoAQIARIwaLPACFACBAChAAhQAgQAhFGgBSsCANK3REChAAhQAgQAoQAIUAKFn0GCAFCgBAgBAgBQoAQiDAC5gj3p/nuduzYAa+++iocOnQIamtrYfjw4TBixAhYsmQJ9OnTp831Yfs///nPsHPnTkhPT4eampqw722zY6okBAgBQoAQIAQIAU0hQBYs2eN66aWXBOXqqaeegj179sC6detg0aJFsHz5cpgxY4ZQJ2vOJQ8fPgzTp08XylauXAnLli0DvKKChveuXr2aa08ZQoAQIAQIAUKAENAvAoYAE/0uL/yVoRK1fft2WLp0aYub0Kp17733CuUvv/wyzJ49u0Wb0aNHC9YqVKyUgorba6+9Jihs7VnB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\" width=\"300\">"
      ],
      "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,iVBORw0KGgoAAAANSUhEUgAAAlgAAAH0CAYAAADhUFPUAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACWKADAAQAAAABAAAB9AAAAACc34KhAABAAElEQVR4AeydB3xcxbXwz1b1YlnFttwtFxX3XgD3hmkGbAgEMLYhyQsllOS9lxeSAMn78jAETBrYQAgl2IDpLtjYGNxww0WSe5MlWV1W3dVqyzfnirt75+5K2pW23Ls6w8/snblzZ878Z7V7dubMORoHS0CJCBABIkAEiAARIAJEwG8EtH5riRoiAkSACBABIkAEiAAREAiQgkVvBCJABIgAESACRIAI+JkAKVh+BkrNEQEiQASIABEgAkSAFCx6DxABIkAEiAARIAJEwM8ESMHyM1BqjggQASJABIgAESACpGDRe4AIEAEiQASIABEgAn4mQAqWn4FSc0SACBABIkAEiAARIAWL3gNEgAgQASJABIgAEfAzAVKw/AyUmiMCRIAIEAEiQASIAClY9B4gAkSACBABIkAEiICfCZCC5Weg1BwRIAJEgAgQASJABEjBovcAESACRIAIEAEiQAT8TIAULD8DpeaIABEgAkSACBABIkAKFr0HiAARIAJEgAgQASLgZwKkYPkZKDVHBIgAESACRIAIEAFSsOg9QASIABEgAkSACBABPxMgBcvPQKk5IkAEiAARIAJEgAiQgkXvASJABIgAESACRIAI+JkAKVh+BkrNEQEiQASIABEgAkSAFCx6DxABIkAEiAARIAJEwM8ESMHyM1BqjggQASJABIgAESACpGDRe4AIEAEiQASIABEgAn4moPdze6pvbs+ePbBmzRrIzc2F2tpayM7OhpycHFi5ciX06dOn1fHNnj0bsrKyYOHChcIzWBefv3z5stDWunXr4IknnoApU6a02gbdIAJEgAgQASJABMKDgMbBUngMpfOjeO655yA/P19QhFCxQuUIFa6nnnpKaBwVJFS0PKXx48cLCpWne1i2dOlSePrpp1u7TeVEgAgQASJABIhAGBEgBeuHycQVpt27d8Pq1avdpheVrGXLlgnlL730EsyfP9+tTmsKVnx8PDzzzDMen3FrhAqIABEgAkSACBCBsCBAChabRtzKW7x4MWzbtq3V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T2CZLAmQAAmQAAmQQHwJUGDFt+5ZchIgARIgARIgAZ8IUGD5BJbJkgAJkAAJkAAJxJcABVZ8654lJwESIAESIAES8IkABZZPYJksCZAACZAACZBAfAlQYMW37llyEiABEiABEiABnwhQYPkElsmSAAmQAAmQAAnElwAFVnzrniUnARIgARIgARLwiQAFlk9gmSwJkAAJkAAJkEB8CVBgxbfuWXISIAESIAESIAGfCFBg+QSWyZIACZAACZAACcSXAAVWfOueJScBEiABEiABEvCJAAWWT2CZLAmQAAmQAAmQQHwJUGDFt+5ZchIgARIgARIgAZ8IUGD5BJbJkgAJkAAJkAAJxJcABVZ8654lJwESIAESIAES8IkABZZPYJksCZAACZAACZBAfAlQYMW37llyEiABEiABEiABnwhQYPkElsmSAAmQAAmQAAnElwAFVnzrniUnARIgARIgARLwiQAFlk9gmSwJkAAJkAAJkEB8CVBgxbfuWXISIAESIAESIAGfCFBg+QSWyZIACZAACZAACcSXAAVWfOueJScBEiABEiABEvCJAAWWT2CZLAmQAAmQAAmQQHwJUGDFt+5ZchIgARIgARIgAZ8IUGD5BJbJkgAJkAAJkAAJxJcABVZ8654lJwESIAESIAES8IkABZZPYJksCZAACZAACZBAfAlQYMW37llyEiABEiABEiABnwhQYPkElsmSAAmQAAmQAAnElwAFVnzrniUnARIgARIgARLwiQAFlk9gmSwJkAAJkAAJkEB8CVBgxbfuWXISIAESIAESIAGfCFBg+QSWyZIACZAACZAACcSXAAVWfOueJScBEiABEiABEvCJAAWWT2CZLAmQAAmQAAmQQHwJUGDFt+5ZchIgARIgARIgAZ8IUGD5BJbJkgAJkAAJkAAJxJcABVZ8654lJwESIAESIAES8IkABZZPYJksCZAACZAACZBAfAlQYMW37llyEiABEiABEiABnwhQYPkElsmSAAmQAAmQAAnElwAFVnzrniUnARIgARIgARLwiQAFlk9gmSwJkAAJkAAJkEB8CVBgxbfuWXISIAESIAESIAGfCFBg+QSWyZIACZAACZAACcSXAAVWfOueJScBEiABEiABEvCJAAWWT2CZLAmQAAmQAAmQQHwJUGDFt+5ZchIgARIgARIgAZ8IUGD5BJbJkgAJkAAJkAAJ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\" width=\"300\">"
      ],
      "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,iVBORw0KGgoAAAANSUhEUgAAAlgAAAH0CAYAAADhUFPUAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACWKADAAQAAAABAAAB9AAAAACc34KhAABAAElEQVR4Aey9CXwc1ZXvf9SburVbki1vkle82+Dd8gbebbaAWUySyQQIJsnMJ5AF/u//mfdCMiR5//8bAhMz/5k3CRCTvCQTCDhhMza2wWBL3m2M992W5V2Stat3/e8pUd11qltSt1TdXVV9Lh/RdW9V3br3e8vS6XvP/Z2MdpGAExNgAkyACTABJsAEmIBmBCya1cQVMQEmwASYABNgAkyACUgE2MDiF4EJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTYANLY6BcHRNgAkyACTABJsAE2MDid4AJMAEmwASYABNgAhoTsGlcn+Grq6yshFdeeQUOHz4MjY2NMH78eJgwYQKsXr0aSktLu+wfXv/rX/8aduzYAfn5+dDQ0BDzvV1WzCeZABNgAkyACTABQxHgGSzFcL3wwguScfXMM8/Anj17YPPmzbBq1Sp44403YPHixdI5xeXk8MiRI7Bo0SKpbN26dbB27VrATzTQ8N4NGzaQ6znDBJgAE2ACTIAJmJdARrtI5u1e7D1DI6qiogJefvnliJtwVuuxxx6TytesWQPLly+PuGb69OnSbBUaVuqEhturr74qGWzdzYKp7+U8E2ACTIAJMAEm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yOA9edIpAOoGARAAAasI8AyMnFVjJUoqVlaVj3JAAARAwCwBzGCZJYV8IAACIAACIAACIGCSABQsk6CQDQRAAARAAARAAATMEoCCZZYU8oEACIAACIAACICASQJQsEyCQjYQAAEQAAEQAAEQMEsACpZZUsgHAiAAAiAAAiAAAiYJ4C1Ck6CQDQRAAARAAARAAATMEsAMlllSyAcCIAACIAACIAACJglAwTIJCtlAAARAAARAAARAwCwBKFhmSSEfCIAACIAACIAACJgkAAXLJChkAwEQAAEQAAEQAAGzBKBgmSWFfCAAAiAAAiAAAiBgkgAULJOgkA0EQAAEQAAEQAAEzBKAgmWWFPKBAAiAAAiAAAiAgEkCULBMgkI2EAABEAABEAABEDBLAAqWWVLIBwIgAAIgAAIgAAImCUDBMgkK2UAABEAABEAABEDALAEoWGZJIR8IgAAIgAAIgAAImCQABcskKGQDARAAARAAARAAAbMEoGCZJYV8IAACIAACIAACIGCSABQsk6CQDQRAAARAAARAAATMEoCCZZYU8oEACIAACIAACICASQJQsEyCQjYQAAEQAAEQAAEQMEsACpZZUsgHAiAAAiAAAiAAAiYJQMEyCQrZQAAEQAAEQAAEQMAsAShYZkkhHwiAAAiAAAiAAAiYJAAFyyQoZAMBEAABEAABEAABswSgYJklhXwgAAIgAAIgAAIgYJIAFCyToJANBEAABEAABEAABMwSgIJllhTygQAIgAAIgAAIgIBJAv8fupzd6+nXx8oAAAAASUVORK5CYII=\" width=\"300\">"
      ],
      "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=\"300\">"
      ],
      "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,iVBORw0KGgoAAAANSUhEUgAAAlgAAAH0CAYAAADhUFPUAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACWKADAAQAAAABAAAB9AAAAACc34KhAABAAElEQVR4AeydB5gc1ZXvT3dPzjMaZY1yHgUEEkKSwWAkkHAAhCWEbdYgkjcBnxd231sbjLX+3tvvAc/gDW+FImBjJQRrQCCyMUggQCjnOEFppMl5unveObenWl3d1d3VM93T6X/5iqp769atur9qTf/73HPPtXRyIiQQAAEQAAEQAAEQAIGwEbCGrSU0BAIgAAIgAAIgAAIgoAhAYOGDAAIgAAIgAAIgAAJhJgCBFWagaA4EQAAEQAAEQAAEILDwGQABEAABEAABEACBMBOAwAozUDQHAiAAAiAAAiAAAhBY+AyAAAiAAAiAAAiAQJgJQGCFGSiaAwEQAAEQAAEQAAEILHwGQAAEQAAEQAAEQCDMBCCwwgwUzYEACIAACIAACIAABBY+AyAAAiAAAiAAAiAQZgIQWGEGiuZAAARAAARAAARAAAILnwEQAAEQAAEQAAEQCDMBCKwwA0VzIAACIAACIAACIACBhc8ACIAACIAACIAACISZAARWmIGiORAAARAAARAAARCAwMJnAARAAARAAARAAATCTAACK8xA0RwIgAAIgAAIgAAIQGDhMwACIAACIAACIAACYSYAgRVmoGgOBEAABEAABEAABCCw8BkAARAAARAAARAAgTATgMAKM1A0BwIgAAIgAAIgAAIQWPgMgAAIgAAIgAAIgECYCaSEub24b66+vp6WL19O27dvp/z8fKqrq6NJkybRAw88QCUlJT3qn9b2gQMHVLvS2JAhQ+ihhx6i0tLSHrWNi0EABEAABEAABGKHACxYHu9i//79dOONN6qSzZs305o1a0j2In7mzp1L77zzjkft0A63bdtGjzzyCM2ZM8fdrrS9ZMkSVf7000+H1iBqgwAIgAAIgAAIxCwBSyenmH26Xn6wGTNmKGuVCCvvJAJo5cqV9P7774dsyRLL1T333ENr166lvLw876apvLycFi5cSI899hjdeeedPudRAAIgAAIgAAIgEF8EYMHqel8ioEQI+RM4YmmS9OSTT3ZdYX4nQ44yzGgk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\" width=\"300\">"
      ],
      "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,iVBORw0KGgoAAAANSUhEUgAAAlgAAAH0CAYAAADhUFPUAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAACWKADAAQAAAABAAAB9AAAAACc34KhAABAAElEQVR4Aey9B5hcR5nu/3acnIM0owka5ZyznC1bThgwtgUGGwwYE23vrrm7e/e5PPvfy95dFrNgLwaMMRiMARucMA4ysiVbOWdplKWJGk3OodO/qkX3dHX3jKZnzvT0Of0Wj+hTdc6p8Kv2zDtVX32fySMSmEiABEiABEiABEiABDQjYNasJlZEAiRAAiRAAiRAAiTgJUCBxS8CCZAACZAACZAACWhMgAJLY6CsjgRIgARIgARIgAQosPgdIAESIAESIAESIAGNCVBgaQyU1ZEACZAACZAACZAABRa/AyRAAiRAAiRAAiSgMQEKLI2BsjoSIAESIAESIAESoMDid4AESIAESIAESIAENCZAgaUxUFZHAiRAAiRAAiRAAhRY/A6QAAmQAAmQAAmQgMYEKLA0BsrqSIAESIAESIAESIACi98BEiABEiABEiABEtCYAAWWxkBZHQmQAAmQAAmQAAlQYPE7QAIkQAIkQAIkQAIaE6DA0hgoqyMBEiABEiABEiABCix+B0iABEiABEiABEhAYwIUWBoDZXUkQAIkQAIkQAIkQIHF7wAJkAAJkAAJkAAJaEyAAktjoKyOBEiABEiABEiABCiw+B0gARIgARIgARIgAY0JUGBpDJTVkQAJkAAJkAAJkAAFFr8DJEACJEACJEACJKAxAQosjYGyOhIgARIgARIgARKgwOJ3gARIgARIgARIgAQ0JkCBpTFQVkcCJEACJEACJEACViIggUACbW09cLncgUURX6enJ8JiMXvrkfUxXSZALuG/CeRCLuEJhC/l94VcwhMYeqn8/SS/R6OdKLBGm7DO6pfiyul0adZrLevSrFMxUBG5hJ8EciGX8ATCl/L7Qi7hCcRGKbcIY2Me2AsSIAESIAESIAEDEaDAMtBkcigkQAIkQAIkQAKxQYACKzbmgb0gARIgARIgARIwEAEKLANNJodCAiRAAiRAAiQQGwQosGJjHtgLEiABEiABEiABAxGgwDLQZHIoJEACJEACJEACsUGAAis25oG9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P5bwwWz0EFd+c4ohTDmRVUm9oVfJxgkeL730kjmHqEI6uAaxWSi+/PgE8UN8cWknQcrDMMkjwB6s5NU5S0wCoROAGMLM7HgpWpskvGwhQLCETaGzL0/cY4cMEQbHdu0/LJlTbliqMN6wzx999FHzkkeebF6QdwgvrPmH42LOdRnB1TtZJ9KDCMKQZeG6i8XyWGm9oT6RBlhAWGFDuqhHpOmty2JpVuLvmmEleWFYEqiUQCqrrtKbGJ4ESIAEmpUAemBsrxpElBVWzVpelosESMANAfZgueHKWEmABEiABEiABBJMgAIrwZXPopMACZAACZAACbghQIHlhitjJQESIAESIAESSDABCqwEVz6LTgIkQAIkQAIk4IYABZYbroyVBEiABEiABEggwQT4FWGCK59FJwESIAESIAEScEOAPVhuuDJWEiABEiABEiCBBBOgwEpw5bPoJEACJEACJEACbghQYLnhylhJgARIgARIgAQSTIACK8GVz6KTAAmQAAmQAAm4IUCB5YYrYyUBEiABEiABEkgwAQqsBFc+i04CJEACJEACJOCGAAWWG66MlQRIgARIgARIIMEEKLASXPksOgmQAAmQAAmQgBsCFFhuuDJWEiABEiABEiCBBBOgwEpw5bPoJEACJEACJEACbghQYLnhylhJgARIgARIgAQSTIACK8GVz6KTAAmQAAmQAAm4IUCB5YYrYyUBEiABEiABEkgwAQqsBFc+i04CJEACJEACJOCGAAWWG66MlQRIgARIgARIIMEEKLASXPksOgmQAAmQAAmQgBsCFFhuuDJWEiABEiABEiCBBBOgwEpw5bPoJEACJEACJEACbghQYLnhylhJgARIgARIgAQSTIACK8GVz6KTAAmQAAmQAAm4IUCB5YYrYyUBEiABEiABEkgwAQqsBFc+i04CJEACJEACJOCGAAWWG66MlQRIgARIgARIIMEE/j90dg682oAiIgAAAABJRU5ErkJggg==\" width=\"300\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xticks = np.arange(0.5, 3.5, 0.5)\n",
    "\n",
    "figsize = (3,2.5)\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in eces:\n",
    "    ax.plot(temps, eces[net]*100, label=net)\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_xlabel(r'temperature $\\tau$')\n",
    "ax.set_ylabel('ECE in \\%')\n",
    "ax.set_ylim([0,20])\n",
    "ax.legend(prop={'size': 8}, loc=1)\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"ece_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in aces:\n",
    "    ax.plot(temps, aces[net]*100, label=net)\n",
    "#ax.legend()\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_ylim([5,25])\n",
    "ax.set_xlabel(r'temperature $\\tau$')\n",
    "ax.set_ylabel('ACE in \\%')\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"ace_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in uces:\n",
    "    ax.plot(temps, uces[net]*100, label=net)\n",
    "#ax.legend()\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_ylim([0,20])\n",
    "ax.set_xlabel(r'temperature $\\tau$')\n",
    "ax.set_ylabel('UCE in \\%')\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"uce_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in mmces:\n",
    "    ax.plot(temps, mmces[net]*100, label=net)\n",
    "#ax.legend()\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_ylim([0,20])\n",
    "ax.set_xlabel(r'temperature $\\tau$')\n",
    "ax.set_ylabel('MMCE in \\%')\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"mmce_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in briers:\n",
    "    ax.plot(temps, briers[net], label=net)\n",
    "#ax.legend()\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_ylim([0.2,0.8])\n",
    "ax.set_xlabel(r'temperature $\\tau$')\n",
    "ax.set_ylabel('Brier score')\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"brier_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=figsize)\n",
    "for net in nlls:\n",
    "    ax.plot(temps, nlls[net], label=net)\n",
    "#ax.legend(prop={'size': 9})\n",
    "ax.set_xticks(xticks)\n",
    "ax.set_xlabel(r'temperature ')\n",
    "ax.set_ylabel('NLL')\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"nll_vs_temp_reg_\"+dataset+\".pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
