{
 "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, uceloss_with_prop, eceloss_with_prop\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",
    "import pandas as pd\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 = 'cifar10'\n",
    "base_model = 'resnet34'"
   ]
  },
  {
   "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"
     ]
    }
   ],
   "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",
    "        'freq1':     'none_resnet34_cifar10_best_2020-09-23_21.26.44.pth.tar',\n",
    "        'freq2':     'none_resnet34_cifar10_best_2020-09-24_01.48.25.pth.tar',\n",
    "        'freq3':     'none_resnet34_cifar10_best_2020-09-24_05.40.42.pth.tar',\n",
    "        'mcdrop':    'mcdrop_resnet34_cifar10_best_2020-09-24_09.33.51.pth.tar',\n",
    "        'gaussdrop': 'gaussdrop_resnet34_cifar10_best_2020-09-24_13.27.30.pth.tar',\n",
    "        'bbb':       'bbb_resnet34_cifar10_best_2020-09-24_17.20.31.pth.tar',\n",
    "        'swag':      'swag_resnet34_cifar10_best_2020-09-24_21.12.54.pth.tar',\n",
    "    }\n",
    "else:\n",
    "    snapshots = {\n",
    "        'freq1':     'none_resnet50_cifar100_best_2020-09-23_21.26.41.pth.tar',\n",
    "        'freq2':     'none_resnet50_cifar100_best_2020-09-24_02.56.27.pth.tar',\n",
    "        'freq3':     'none_resnet50_cifar100_best_2020-09-24_08.27.28.pth.tar',\n",
    "        'mcdrop':    'mcdrop_resnet50_cifar100_best_2020-09-24_14.00.19.pth.tar',\n",
    "        'gaussdrop': 'gaussdrop_resnet50_cifar100_best_2020-09-24_19.31.34.pth.tar',\n",
    "        'bbb':       'bbb_resnet50_cifar100_best_2020-09-25_01.02.50.pth.tar',\n",
    "        'swag':      'swag_resnet50_cifar100_best_2020-09-25_06.31.20.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",
    "    'freq1': FrequentistNet(num_classes, base_model).to(device),\n",
    "    'freq2': FrequentistNet(num_classes, base_model).to(device),\n",
    "    'freq3': FrequentistNet(num_classes, base_model).to(device),\n",
    "    'mcdrop': MonteCarloDropoutNet(num_classes, base_model).to(device),\n",
    "    'gaussdrop': GaussianDropoutNet(num_classes, base_model).to(device),\n",
    "    'bbb': BBBNet(num_classes, base_model).to(device),\n",
    "    'swag': 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 296\n",
      "Loading previous weights at epoch 283\n",
      "Loading previous weights at epoch 231\n",
      "Loading previous weights at epoch 255\n",
      "Loading previous weights at epoch 236\n",
      "Loading previous weights at epoch 295\n",
      "Loading previous weights at epoch 297\n"
     ]
    }
   ],
   "source": [
    "for key in nets:\n",
    "    checkpoint = torch.load(base_path+snapshots[key], map_location=device)\n",
    "    nets[key].load_state_dict(checkpoint['state_dict'])\n",
    "    print(\"Loading previous weights at epoch \" + str(checkpoint['epoch']))\n",
    "\n",
    "optimizer = optim.Adam(nets['swag'].parameters(), lr=3e-6, weight_decay=1e-6)\n",
    "nets['swag'].train_swag(train_loader, optimizer, device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:01<00:00, 51.63it/s]\n",
      "  8%|▊         | 6/79 [00:00<00:01, 50.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "freq1 acc: 0.9351999759674072\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:01<00:00, 50.00it/s]\n",
      "  8%|▊         | 6/79 [00:00<00:01, 53.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "freq2 acc: 0.9340999722480774\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:01<00:00, 53.81it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "freq3 acc: 0.9318999648094177\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:35<00:00,  2.25it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mcdrop acc: 0.9354999661445618\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:35<00:00,  2.23it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gaussdrop acc: 0.9323999881744385\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:35<00:00,  2.22it/s]\n",
      "  0%|          | 0/79 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bbb acc: 0.9332000017166138\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 79/79 [00:35<00:00,  2.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "swag acc: 0.9434999823570251\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\n",
    "\n",
    "logits_test['ensemble'] = (logits_test['freq1']+logits_test['freq2']+logits_test['freq3'])/3\n",
    "del logits_test['freq1'], logits_test['freq2'], logits_test['freq3']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:15<00:00,  3.08s/it]\n"
     ]
    }
   ],
   "source": [
    "eces = {}\n",
    "aces = {}\n",
    "uces = {}\n",
    "\n",
    "for net in logits_test:\n",
    "    eces[net] = []\n",
    "    aces[net] = []\n",
    "    uces[net] = []\n",
    "\n",
    "temps = {\n",
    "    'ensemble':  0.5,\n",
    "    'mcdrop':    0.5,\n",
    "    'gaussdrop': 0.5,\n",
    "    'bbb':       0.5,\n",
    "    'swag':      0.5,\n",
    "}\n",
    "\n",
    "for net in tqdm(eces):\n",
    "    eces1 = []\n",
    "    uces1 = []\n",
    "    aces1 = []\n",
    "    for nbins in range(5, 100, 5):\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",
    "        eces1.append(ece.item())\n",
    "        aces1.append(np.mean(ace))\n",
    "        uces1.append(uce.item())\n",
    "    eces[net] = np.array(eces1)\n",
    "    aces[net] = np.array(aces1)\n",
    "    uces[net] = np.array(uces1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "window.mpl = {};\n",
       "\n",
       "\n",
       "mpl.get_websocket_type = function() {\n",
       "    if (typeof(WebSocket) !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof(MozWebSocket) !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert('Your browser does not have WebSocket support. ' +\n",
       "              'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "              'Firefox 4 and 5 are also supported but you ' +\n",
       "              'have to enable WebSockets in about:config.');\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = (this.ws.binaryType != undefined);\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById(\"mpl-warnings\");\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent = (\n",
       "                \"This browser does not support binary websocket messages. \" +\n",
       "                    \"Performance may be slow.\");\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = $('<div/>');\n",
       "    this._root_extra_style(this.root)\n",
       "    this.root.attr('style', 'display: inline-block');\n",
       "\n",
       "    $(parent_element).append(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen =  function () {\n",
       "            fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
       "            fig.send_message(\"send_image_mode\", {});\n",
       "            if (mpl.ratio != 1) {\n",
       "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
       "            }\n",
       "            fig.send_message(\"refresh\", {});\n",
       "        }\n",
       "\n",
       "    this.imageObj.onload = function() {\n",
       "            if (fig.image_mode == 'full') {\n",
       "                // Full images could contain transparency (where diff images\n",
       "                // almost always do), so we need to clear the canvas so that\n",
       "                // there is no ghosting.\n",
       "                fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "            }\n",
       "            fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "        };\n",
       "\n",
       "    this.imageObj.onunload = function() {\n",
       "        fig.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option);\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width, fig.canvas.height);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data'])\n",
       "    });\n",
       "    return ws;\n",
       "}\n",
       "\n",
       "mpl.mpl_figure_comm = function(comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = $(\"#\" + id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm)\n",
       "\n",
       "    function ondownload(figure, format) {\n",
       "        window.open(figure.imageObj.src);\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy,\n",
       "                           ondownload,\n",
       "                           element.get(0));\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element.get(0);\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error(\"Failed to find cell for figure\", id, fig);\n",
       "        return;\n",
       "    }\n",
       "\n",
       "    var output_index = fig.cell_info[2]\n",
       "    var cell = fig.cell_info[0];\n",
       "\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
       "    var width = fig.canvas.width/mpl.ratio\n",
       "    fig.root.unbind('remove')\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable()\n",
       "    $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
       "    fig.close_ws(fig, msg);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.close_ws = function(fig, msg){\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width/mpl.ratio\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message(\"ack\", {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () { fig.push_to_output() }, 1000);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>');\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items){\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) { continue; };\n",
       "\n",
       "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
       "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
       "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
       "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
       "    buttongrp.append(button);\n",
       "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
       "    titlebar.prepend(buttongrp);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(el){\n",
       "    var fig = this\n",
       "    el.on(\"remove\", function(){\n",
       "\tfig.close_ws(fig, {});\n",
       "    });\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(el){\n",
       "    // this is important to make the div 'focusable\n",
       "    el.attr('tabindex', 0)\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    }\n",
       "    else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager)\n",
       "        manager = IPython.keyboard_manager;\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which == 13) {\n",
       "        this.canvas_div.blur();\n",
       "        event.shiftKey = false;\n",
       "        // Send a \"J\" for go to next cell\n",
       "        event.which = 74;\n",
       "        event.keyCode = 74;\n",
       "        manager.command_mode();\n",
       "        manager.handle_keydown(event);\n",
       "    }\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.find_output_cell = function(html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i=0; i<ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code'){\n",
       "            for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] == html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "}\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel != null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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AAIIIIBA1AW8DdAPHTpkOjo6rO/q1avNHXfcYRYuXGjq6+snApAh09fXZ/793//dvP/++zbfggULzL333hv150H5cyCg4LyqKlKjN3JQa3eJMbfBOwIIIIAAAggggAACCERMoCAB+qlTp8zixYtNdXV1aJ433njDVFRUmBdeeMEoQA+mmpoao4Bc+7u7u81jjz1murq6CNCDSGxPtCaPma9Hvi0Lietqr5noNZD/HyUGBwfM2rX/kLZpW9uT5q67mlKe9+GHx82JEx+YL744Z776atDmnzt33sTfHTUTQ1kazK23rjRLliydcp18l2nKzfiAAAIIIIAAAggggEAeBQoSoO/evdsMDg6a1tbW0EG0mwjulltumbH6a9asscf7+/tnzMfB8hNQcP7IM0fKouIvPnm3+cFE1/6ops8++8Ts3v1MLCgP1sMF6gra3333iNm69RFz330/D2ZhGwEEEEAAAQQQQACBkhAoSIB++PBh2w19+/bt9n3nzp3mxz/+8YyAOv7BBx+YlpaWpBPBuQnk1NK+bNmyGa/HQQQQyK3AnXfebbZt+1XWF3399T+Y/ftftNdRS/n99683P/nJCjNv3ny7Ty3kCtKV7/PPPzU33JB8UshclSnrSnEBBBBAAAEEEEAAAQQyEChIgK5yaSK3tWvX2hnZ169fb26//Xbboj5v3ryExf7Xf/1Xo67xmr397rvvNrW1taaurs6oe/vo6KgZHh42IyMjdgI57X/66acTXoedCCDgr0AwOL/55h+ZXbuetX/GgyVWoK6XurYrWK+trQseZhsBBBBAAAEEEEAAgZIRyP+g1QCVgmy1nr/99tvmyy+/NCtXrjTPP/98IMffNxWIq+VdLemaxV0B+YULF8yZM2fsuz5rv5Zae+utt9Ia3/73u7CFAALFEjh//lys5Vyt4i+88PtpwXl82RSo6+8GEgIIIIAAAggggAACpShQsBb0IN6iRYts8K0J3nbs2GEneFML+G233RbMZieCO3jwoJ2xXS3pCtA1Nl3/QNekcwrONbM7CQEEoifw7LN/7/Wya9fvolcBSowAAggggAACCCCAQI4FihKguzpogje9NIncI488YhobG21X9ZtumjrGVEE4gbhT4x2B6Auo9VyTvilp3Lgbbx79mlEDBBBAAAEEEEAAAQQyFyhoF/dkxWxra7MTwqllXOPNf/Ob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CBCIgADddkCAAAECMwV+/PHH5p/u/8vM6TLBbw7/1c+97ssG9XOtwkQECBAgQIAAgb0UEKDvZbUqFAECBNYrkOD8v/+v/zPXQv/hf/5987c/3xovESBAgAABAgQILCagi2MxL1MTIECAAAECBAgQIECAAIGNCAjQN8JqoQQIECBAgAABAgQIECBAYDEBAfpiXqYmQIAAAQIECBAgQIAAAQIbERCgb4TVQgkQIECAAAECBAgQIECAwGICAvTFvExNgAABAgQIECBAgAABAgQ2IiBA3wirhRIgQIAAAQIECBAgQIAAgcUEBOiLeZmaAAECBAgQIECAAAECBAhsRECAvhFWCyVAgAABAgQIECBAgAABAosJCNAX8zI1AQIECBAgQIAAAQIECBDYiMChjSzVQncmcOPGjea9995r7t+/P8jD0aNHm4sXLzbHjx/fWZ6smAABAgQIECBAgAABAgRmC+hBn23UmyneeOON5s6dO80HH3zQ3Lp1q7l+/Xrz2GOPNWfPnm3eeuut3pRDRgkQIECAAAECBAgQIPAwCgjQ96TWb9++3Xz33XfNpUuXmsOHDw9KldcrV6406UV///33m0wjESBAgAABAgQIECBAgEA3BQTo3ayXhXP12WefNTdv3mxyi/toOnfu3GBQppEIECBAgAABAgQIECBAoJsCAvRu1svSubp3794D86YHPenrr79+YJwBBAgQIECAAAECBAgQINANAQ+Jm1IPH330UXP16tXB97mnTHYwKg9me/fdd5vPP/+8OXLkSPP99983J06caC5cuDC4zfxgwg28ya3tTz/9dHPq1KkHll5B+xNPPPHAOAMIECBAgAABAgQIECBAoBsCAvRWPSTATlCd72onOP/qq69aY6e/zbQvvPBC84c//GHwcLaaOss5ffp088477zRnzpypwRt5HRecZ0XJQ9Lzzz8/ePWPAAECBAgQIECAAAECBLon4Bb3X+okQfnJkyebF198sfnmm2+ap556aqHaSnCe3vL0ZLdTvv99/vz55tVXX22qJ7s9ftPvE5xnvfmptbrVfdPrtHwCBAgQIECAAAECBAgQWFxAgP6LWXqf7969O7idPUH2k08+ObdmfsIsve/1MLbRGavnOj+Dts2UwDzrTHCe2+wlAgQIECBAgAABAgQIEOiugFvc11A3+QmzpEm3sKfnOn/ppU/Q3O7JTgBdt6AvkpVZQXfWk98/nzXdIus0LQECBAgQIECAAAECBAhsTkCAvqJt/bZ4/fb4pMUlKE/QnJ9Ba/dmX758eRBET5pv0vBp60tvfm7VT3A+qVd/0nINJ0CAAAECBAgQIECAAIHdCAjQV3SvB8m1e8XHLfKxxx4bDL5z584Do6cF2w9MPGNAgvN8Hz6Bf/uhcRn+2muvNVeuXJmxBKMJECBAgAABAgQIECBAYBcCAvQV1Svgzs+qTUuPP/74YPS33347bbKVxiUIz8Po3nzzzeb48eNDy0pP/6yLCEMz+ECAAAECBAgQIECAAAECWxUQoK/I/cMPP8y1hOpBTxC9qZSe8/q5t/Y6ap35qTeJAAECBAgQIECAAAECBLopIEDfcr3kd9Y3kfIk+brdvgLy0fXoQR8V8ZkAAQIECBAgQIAAAQLdERCgr1gXiwbck4LnFbMx+P310d9gX3WZ5idAgAABAgQIECBAgACB7QkI0LdnbU0/Cxw+/FcPpcOvfvXI0uXOvH/zN3+99PzrnHGVciQf+1KWTZVjVd9l6npWWZbJ05Ff/9tBVjLv3/3dr5fJ1sLzbKIcC2diDTPMKkdWsUydrCFrCy9iVln2pRzqZOFNY+UZ9mXbqm1n2jF+X9pJX8qhTlZunhtZwKw2v5GV7nChAvQV8Wc9HK4WX99VX+cT22vZfXp99NFf9Sm7ncjrI4880jz66PIBficK8Usm9qUs+1KOVMsmyvLILxeksuxtpU2UY1t5b69nX8qRMu1LWfalHOqk3dK6835ftq99KYd20p220c7JPm1f7XJNei9AnyQz5/B6+NuckzfzBvTzLq9v0/35zz/2LctryW+u/GXnskz66aefmh9//GmZWdc+zyrlSGb2pSybKkf5/vTjj83//efv5qq/f/Pr3yy9bc1TJ5WnuTIzMtEi5cisq5RlVp2sUo6RYm3046xyZOX7UpZ9KYc62WiTGLvwWe2kL9tWCrcvZdmXcqiTsU1u5wNnbV/bzOA2OhsF6CvWaP182r1796Yu6bvv/v/J9sPeg37//r80//qvf55qtY8jc/vasr3gCc7/8R//uRMsq5QjBdiXsmyqHOWb4PzO//4fc9X5f7v4Xroq55p23ESzylJ5GjfvrGGLlCPLWqUsmyzHrHKuc/yscmRdq9TJOvM6a1mzyrIv5VAns7aE9Y/fl20rMvtSln0phzpZf3tdxxJnbV/rWMc8yzh06NHmN7/5d/NMutI07jdeia85+L3xWQ+Lq1vcT5w4seIazU6AAAECBAgQIECAAAEC+yggQF+xVk+dOjVYwqyns1cPe02/4mrNToAAAQIECBAgQIAAAQJ7JiBAX7FC89vix48fHyylfod8dJEJ3itAP3PmzOhonwkQIECAAAECBAgQIECAQCNAX8NG8NJLLw2W8qc//Wns0m7fvj0YfvHixbHjDSRAgAABAgQIECBAgAABAgL0CdtABdUZPalnvGZNr/i5c+ea999//6CnvMal9/z1118f9LJfuHChBnslQIAAAQIECBAgQIAAAQJDAp7i/gtHAulnnnlm8Gn0++Rnz55t6unrTz31VHPlypUhxHy4fPlyk59cy7TpUc93zb/88svm6tWrzaR5HliIAQQIECBAgAABAgQIECDw0AoI0H+p+gTgn3766eBTBeOjW8Vo4D46/tKlS83LL7/cpPc9f1nOtWvXmnxPXSJAgAABAgQIECBAgAABAtMEBOgtnUmBeU0ya3ymyzQeBFdiXgkQIECAAAECBAgQIEBgXgHfQZ9XynQECBAgQIAAAQIECBAgQGCDAgL0DeJaNAECBAgQIECAAAECBAgQmFdAgD6vlOkIECBAgAABAgQIECBAgMAGBQToG8S1aAIECBAgQIAAAQIECBAgMK+AAH1eKdMRIECAAAECBAgQIECAAIENCgjQN4hr0QQIECBAgAABAgQIECBAYF4BP7M2r5Tp1iLw6KMP9zWhQ796tPmv/+E/z2WZaSsdOvSX9zVsl6+LlCP53JeybKscjzx6qPnr//hfFqriTdfJoZ/b7rH/9O8XytMy5ajtZVPtZJlyJE/LlGWROllm21qmLJsuR9VfXpPm2XctU44se9NlUSfae7azedMi7T3LXHT7WqadLNNGKm8P2z64yp3XpE3tu9TJ/OfBg3ro2LnwtuKYR376OQ22RP8IECBAgAABAgQIECBAgACBnQk83N2ZO2O3YgIECBAgQIAAAQIECBAgMCwgQB/28IkAAQIECBAgQIAAAQIECOxEQIC+E3YrJUCAAAECBAgQIECAAAECwwIC9GEPnwgQIECAAAECBAgQIECAwE4EBOg7YbdSAgQIECBAgAABAgQIECAwLCBAH/bwiQABAgQIECBAgAABAgQI7ERAgL4TdislQIAAAQIECBAgQIAAAQLDAgL0YQ+fCBAgQIAAAQIECBAgQIDATgQE6Dtht1ICBAgQIECAAAECBAgQIDAsIEAf9vCJAAECBAgQIECAAAECBAjsRECAvhN2KyVAgAABAgQIECBAgAABAsMCAvRhD58IECBAgAABAgQIECBAgMBOBAToO2G3UgIECBAgQIAAAQIECBAgMCwgQB/28IkAAQIECBAgQIAAAQIECOxEQIC+E3YrJUCAAAECBAgQIECAAAECwwIC9GEPnwgQIECAAAECBAgQIECAwE4EBOg7YbdSAgQIECBAgAABAgQIECAwLCBAH/bwiQABAgQIECBAgAABAgQI7ERAgL4TdislQIAAAQIECBAgQIAAAQLDAgL0YQ+fCBAgQIAAAQIECBAgQIDATgQE6Dtht1ICBAgQIECAAAECBAgQIDAsIEAf9vCJAAECBAgQIECAAAECBAjsRECAvhN2KyVAgAABAgQIECBAgAABAsMCAvRhD58IECBAgAABAgQIECBAgMBOBAToO2G3UgIECBAgQIAAAQIECBAgMCwgQB/28IkAgR4LfPXVV80rr7zSnD59ujl27NjgNZ8zXCKwLoHbt28PtrOTJ08OtrO8ZjvLcGm7Avfu3WveeOON5uzZs71u8/fv32/eeuutoX1XypXydTVlv5ptP3mfJ42WMfN2vYzzlMs06xdYdNty7F9/HYwucdE6GZ3f58UEHvnp57TYLKYmQKAtkJ3WCy+80Hz66afN4cOH26N68/7GjRvNRx991Hz55ZeDk62jR482p06dai5cuNDkfR9STvRShqTUQ/Kdk9s6eTx//nxz6dKlPhRlL/KYYOP999+fWZZnn322uXLlyszpujJBAvGbN28OsjO6nXW5LGkH33///UKMXW/7ae9p95WS35Sxb20++6kXX3zxIBgfLce1a9cG++Mq565f4/vuu+8etO8vvvhi5rEvZcxFlKqbtJ16n/LssoyrHMNXmXcT9bhofrp27F9m2+r6sX/ROtnEdrHKMhetk3099q9iuMy8h5aZyTwECDSDk4v2SUpfTdoBR5UhJ1M5+c3f5cuXm3PnztWoTr5WGY4fP95cvHhx6GT26tWrzdtvvz04mXzyySebM2fOdLIM82QqJ7g52Ce98847vS5Llffxxx+vt51/Lf8EF/HPRaxKaTP562p69dVXF+rhTxkT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kfZ31ken69rnCgqT/3EXHrqW33Z+XnjhhUGvc9pI7moo/5Qlbb5uD+16m692kIuI1e5TzrSLV155ZdA2Koiv17ZD199X+5nVk163wvexjF2vg0Xy59i/iNZ6p6323+fjfkT25di/3tpdfGkC9MXNzEFgrwUSwFZwnpPcvtzaPq1S8jvpSSlbBSXTpt/luHbvxR//+MddZmWldedEO0HTpBPuBFKVJt3eW+N3+VrfjU05JpUl+fvtb387yOa33367y+wutO66Q6YuYC008w4nzkPgapuZ1Eby9YPUV9fbfPJZFxfyLIBjx441+S5tev8///zzwcWH6jmvnyLbIf3Cq672M2vGCuCrrLOmN379Ao796zedd4n7ctxPebPf3Ydj/7x1t6npBOibkrVcAj0UyAE6t43mKnp6znPyuA8pwWAFV13/qaK65TsPuao870MdjJahHaBne+tqaudzWh4rEEkb6kOKebn//ve/70OWD/JYvwee9jGtjVRA2/U2n7tM2u09QWo+f/rpp4M7G6qeKpA/gOjBm2o/9QsOk7JcZawe90nTGb4ZAcf+zbjOu9SH5bgfj9on5H21+7yXhgU8xX3YwycCD61A+wCdW0b7dsvrrIrLSW/K2OUDQvJW+UtvWj1de1zZcutupVxM6dudDn154FW1g1mBd92iW3XS9df0QlfqW+BXbaR9oldlab/W+Jq+Pa5r73OXT93p085b++sfzz33XHtUL97XtjWr/VQA35cnhvcCf85MOvbPCbWhyR6m434I+3Ls31B1z71YAfrcVCYksL8COUA/88wzgwA2vTl1UtWHEufgVifi0/JbJ+lPPPHEtMl2Pm5aWXJgqxPd9BzW7aDTehF3XqAJGaj6yOgub2/tvCVYqoB9tFjVS9v17avy/cknnwzetstX47r+miAut+e3t6Fxea6gry91Mq4MeapzUra7PrbzdnuZ1H6yT6v9Wt8uNI6rsz4Nc+zvRm09LMf9aLf32308/mxrixGgb0vaegh0VCAH6NzWntS34Dx5zglsDm7Tbsdv9xY+/fTTma2TKeXIU6gnpdRVvp+alKe7d/VkNt8Pznf983Nkk9KHH354MKrrPYP5jnYCwuS5HXBUAVLeOunoy9PQ6zvcdRt4laUPr3VSl/aQctTndt5rXIZ1uc238zz6PmWrHvR66N3oNH34nDaTckxqP/Vc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CNB3oW6dBAgQIECAwJBAes/HpTNnzjSnTp0ajMqt6aukSet46qmnBout2+pXWYd5CRAgQIDAKgIC9FX0zEuAAAECBAhsXKAdWE97YNysjFSgPzrd448/fjBIkH5A4Q0BAgQI7EBAgL4DdKskQIAAAQIE5heo294zxyoPcmsvZ/61m5IAAQIECGxPQIC+PWtrIkCAAAECBJYQaAfWqwToS6zaLAQIECBAYKsCAvStclsZAQIECBAgsKjA999/fzDL4cOHD957Q4AAAQIE9k1AgL5vNao8BAgQIEBgzwTa3zvPz6RJBAgQIEBgXwUE6Ptas8pFgAABAgR6JNDuJR/N9nvvvTcYlN7z+km00Wl8JkCAAAEC+yAgQN+HWlQGAgQIECDQc4EbN26MLUF++7x60PNb6RIBAgQIENhngUP7XDhlI0CAAAECBPoh8Pbbbw8ymp9US095gvJ33323uXnz5mB4HhTX/rm1fpRKLgkQIECAwGICAvTFvExNgAABAgQIbEAgwXeC9ArU26tIcH7t2rX2IO8JECBAgMBeCrjFfS+rVaEIECBAgEC/BHL7+vXr15tnn322qZ9Vy+v58+ebW7duHQzrV6nklgABAgQILCbwyE8/p8VmMTUBAgQIECBAgAABAgQIECCwbgE96OsWtTwCBAgQIECAAAECBAgQILCEgAB9CTSzECBAgAABAgQIECBAgACBdQsI0NctankECBAgQIAAAQIECBAgQGAJAQH6EmhmIUCAAAECBAgQIECAAAEC6xYQoK9b1PIIECBAgAABAgQIECBAgMASAgL0JdDMQoAAAQIECBAgQIAAAQIE1i0gQF+3qOURIECAAAECBAgQIECAAIElBAToS6CZhQABAgQIECBAgAABAgQIrFtAgL5uUcsjQIAAAQIECBAgQIAAAQJLCAjQl0AzCwECBAgQIECAAAECBAgQWLeAAH3dopZHgAABAgQIECBAgAABAgSWEBCgL4FmFgIECBAgQIAAAQIECBAgsG4BAfq6RS2PAAECBAgQIECAAAECBAgsISBAXwLNLAQIECBAgAABAgQIECBAYN0CAvR1i1oeAQIECBAgQIAAAQIECBBYQkCAvgSaWQgQIECAAAECBAgQIECAwLoFBOjrFrU8AgQIECBAgAABAgQIECCwhIAAfQk0sxAgQIAAAQIECBAgQIAAgXULCNDXLWp5BAgQIECAAAECBAgQIEBgCQEB+hJoZiFAgAABAgQIECBAgAABAusWEKCvW9TyCBAgQIAAAQIECBAgQIDAEgIC9CXQzEKAAAECBAgQIECAAAECBNYtIEBft6jlESBAgAABAgQIECBAgACBJQQE6EugmYUAAQIECBAgQIAAAQIECKxbQIC+blHLI0CAAAECBAgQIECAAAECSwgI0JdAMwsBAgQIECBAgAABAgQIEFi3gAB93aKWR4AAAQIECBAgQIAAAQIElhAQoC+BZhYCBAgQIECAAAECBAgQILBuAQH6ukUtjwABAgQIECBAgAABAgQILCHw/wCt9fDTi1mWqQAAAABJRU5ErkJggg==\" width=\"500\">"
      ],
      "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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AggggAACCERWwJsAXePNNb48OdXX19uWcs3qniopsCchgAACCCCAAAIIIIAAAgggEHUBrwJ0YWpCuGCaN2+e/djZ2RncnWhRJ0Afw8IHBBBAAAEEEEAAAQQQQACBiAp4E6Br1nal999/fxyljql1/cUXX0wce+qpp+y2Wt5JCCCAAAIIIIAAAggggAACCERdwJsAfdWqVbYre3JLuYDdhHCa6X3RokWmrq7OtrRrUrnly5dH/RlQfgQQQAABBBBAAAEEEEAAAQSMNwF6VVWVncH9iSeeMBcuXBjzaObPn29+//vf2wB+aGjIvmsGdwXnyk9CAAEEEEAAAQQQQAABBBBAIOoC3qyDLsiJWsObm5vNggULTHd3tzVXXrq3R/3rR/kRQAABBBBAAAEEEEAAAQScgFcBuitUundNGOcmjUuXh/0IIIAAAggggAACCCCAAAIIRFEgMgG6ur1rfHpvb69tOb/rrrvsWPQoolNmBBBAAAEEEEAAAQQQQAABBJIFvAnQ+/r6zH333Wc03vztt98eU04dW7NmzZh10vfs2WPWrVtnHn/88TF5+YAAAggggMBUCdRUXm0vVV5eZmbMuD7UZZWXhAACCCCAAAII5CLgzSRxhw4dspO/ueXWgpVpaWkxbnI4HZ89e7bNq1ndP/roo2BWthFAAAEEEJgygbK/B9taNaSiojzUS3lJCCCAAAIIIIBALgLetKAfPnzY6B816roeTPv37zf9/f322GuvvWZcAP/oo4+aI0eOmDfffNPceuutwVPYRgABBBBAYEoFRmMx8/03g6GueWXlDfb/WaEykwkBBBBAAAEEEAgIeBOgq4VcSWucB1NXV5f9qBnbXXCuHRs2bLABurq/kxBAAAEEEMingILz3t2bQt3i/2l91cQj9FB5yYQAAggggAACCAQFvOniPjw8HCxXYvvkyZO2JSJ5CTa3xJpa10kIIIAAAggggAACCCCAAAIIRF3AmwA9FaRax13gvnjx4jFZBgcvdzWsrq4es58PCCCAAAIIIIAAAggggAACCERRwJsA3XVfD076ponjXHLH3eeBgQG7WVNT43bxjgACCCCAAAIIIIAAAggggEBkBbwZg64W8p6eHqMZ25uammzLuSaI08Rx+pycTpw4YXclB+7J+fiMAAIIIIAAAggggAACCCCAQBQEvAnQtaZ5Z2enUcu41jhX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/FWC8em1Yjpwnx5/+fLl6o033qjS+55/yefmzZtVfqcuESBAgAABAgQIECBAgACBRQIC9JrOvMC8TLJsfKbLNB4EV8R8EiBAgAABAgQIECBAgMCqAn6DvqqU6QgQIECAAAECBAgQIECAwBYFBOhbxJU1AQIECBAgQIAAAQIECBBYVUCAvqqU6QgQIECAAAECBAgQIECAwBYFBOhbxJU1AQIECBAgQIAAAQIECBBYVUCAvqqU6QgQIECAAAECBAgQIECAwBYFBOhbxJU1AQIECBAgQIAAAQIECBBYVcBr1laVMl0rAk8/fbCvCR363dPV//wv/30ly0xb0qFD//hehu3yc516pJxjqctY6tFVmzz19KHqn/7r/1h7VV1n/Vq3TQ79ug869t/+89pl2qQu26zHpA03qMu267HJuqVN1t9O1lm3umqTTdatUrZtHRf7um6VeuczaZVj/CZ10Sarn3NN2mHN8y5t0r9912SD2uJ/XcUxT/3ya9piPWRNgAABAgQIECBAgAABAgQIrCBwsLszVwAyCQECBAgQIECAAAECBAgQ6EJAgN6FsmUQIECAAAECBAgQIECAAIElAgL0JUBGEyBAgAABAgQIECBAgACBLgQE6F0oWwYBAgQIECBAgAABAgQIEFgiIEBfAmQ0AQIECBAgQIAAAQIECBDoQkCA3oWyZRAgQIAAAQIECBAgQIAAgSUCAvQlQEYTIECAAAECBAgQIECAAIEuBAToXShbBgECBAgQIECAAAECBAgQWCIgQF8CZDQBAgQIECBAgAABAgQIEOhCQIDehbJlECBAgAABAgQIECBAgACBJQIC9CVARhMgQIAAAQIECBAgQIAAgS4EBOhdKFsGAQIECBAgQIAAAQIECBBYIiBAXwJkNAECBAgQIECAAAECBAgQ6EJAgN6FsmUQIECAAAECBAgQIECAAIElAgL0JUBGEyBAgAABAgQIECBAgACBLgQE6F0oWwYBAgQIECBAgAABAgQIEFgiIEBfAmQ0AQIECBAgQIAAAQIECBDoQkCA3oWyZRAgQIAAAQIECBAgQIAAgSUCAvQlQEYTIECAAAECBAgQIECAAIEuBAToXShbBgECBAgQIECAAAECBAgQWCIgQF8CZDQBAgQIECBAgAABAgQIEOhCQIDehbJlECBAgAABAgQIECBAgACBJQIC9CVARhMgQIAA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yWfuwsg69t1331Wffvrp5MJJtvk8T6PPKXcAZb2q77fyqr5sO0m5e6NcINplPbKulwsGKUf+Lqk+PG8zmL5zJu2SbSbbSraf1Cl3NaStSnCe+g9hX1DqPOTPvh37N123HPu3txZu2iZjO/ZvT3h5zk/98mtaPpkpCBCIwKydVjnZLQFIppt1kpLhfUrlxHDVMuWkavrEa9V5u5guvVB5Emppj/oyc/KXE/o+XmCol3PZ96x/5Rb31Kevt7iXeuS9ruUEvAzLZ9qhz7fo18ta/54Aozxttz6879tGvaz5ngsk5WctQ38gZNoj7TKdhrLNL9pv5aJQX3qV6/ueaev639m2v/rqq/qgve/zjjkJzHMnTRepyTG8ybzbqNum5ZnXDvPKuO39W9N1a9E21PV+YNM2mWef4XWfro779WUuKtu87X1sx/5FBtsapwd9W7LyHa1A6f2brmB9+KwgcXp6f7crkANxfr8d+xywc4DJwSPD07spdS9Qnkyd28LLNpELWWmTIaYEEumpzcPHsr0Pdf0qbZE2GGoPell/EtglkB1qm5T9Vtan1CH7reyv+nbxLev6w4cPC/tGn7nYkG0o++esg6ln9gdd75/rx+p6RerD69vIvGnmDZ83b336tr7Xy1zPsz68y/LUy7Dq96brVtmGUs8+HPvr9nWD+vCxt8nYjv31duzqux70rqQthwABAgQIECBAgAABAgQILBDwkLgFOEYRIECAAAECBAgQIECAAIGuBAToXUlbDgECBAgQIECAAAECBAgQWCAgQF+AYxQBAgQIECBAgAABAgQIEOhKQIDelbTlECBAgAABAgQIECBAgACBBQIC9AU4RhEgQIAAAQIECBAgQIAAga4EBOhdSVsOAQIECBAgQIAAAQIECBBYICBAX4BjFAECBAgQIECAAAECBAgQ6EpAgN6VtOUQIECAAAECBAgQIECAAIEFAgL0BThGESBAgAABAgQIECBAgACBrgQE6F1JWw4BAgQIECBAgAABAgQIEFggIEBfgGMUAQIECBAgQIAAAQIECBDoSkCA3pW05RAgQIAAAQIECBAgQIAAgQUCAvQFOEYRIECAAAECBAgQIECAAIGuBAToXUlbDgECBAgQIECAAAECBAgQWCAgQF+AYxQBAgQIECBAgAABAgQIEOhKQIDelbTlECBAgAABAgQIECBAgACBBQIC9AU4RhEgQIAAAQIECBAgQIAAga4EBOhdSVsOAQIECBAgsE/gk08+qY4dOzb5t2/EGn+8++67e3ncv39/jTlNSoAAAQIE+icgQO9fmygRAQIECBAgQIAAAQIECBxAgUMHsM6qTIAAAQIECIxE4OjRo1X+JT3zzDMjqZVqECBAgMBBFRCgH9SWV28CBAgQIDACgYsXL1b5JxEgQIAAgTEIuMV9DK2oDgQIECBAgAABAgQIECAweAEB+uCbUAUIECBAgAABAgQIECBAYAwCAvQxtKI6ECBAgAABAgQIECBAgMDgBQTog29CFSBAgAABAgQIECBAgACBMQgI0MfQiupAgAABAgRGIPD48ePqxo0b1blz56qTJ09O3m/+2muvVd98883c2i17l3ryy7vWk19SlpF3p585c2Zv+Jtvvlk9evRo7jKMIECAAAECXQkI0LuSthwCBAgQIEBgrkAC6QTRV69enQTkCaST7t+/PwnY79y5M3feVUckr9OnT1cJ6ktAnuXcvXt3ErCXYavmZzoCBAgQINC2gAC9bVH5ESBAgAABAmsLJDA/f/58de/everhw4eTzwsXLuzl89Zbb+0F1XsD1/iSQDy98SdOnNhbxu3bt6uXXnppL5dcJJAIECBAgMAuBQTou9S3bAIECBAgQGAicOnSperKlSvV0aNHJ3/n8/Lly9UHH3ywJ9Q0gE6eN2/e3FvG8ePHq2vXrlX5TPrss8/2luULAQIECBDYhYAAfRfqlkmAAAECBAjsE0jv+ax09uzZ6tSpU5NRuTW9SZq3jBdeeGGSbbmtvskyzEuAAAECBJoICNCb6JmXAAECBAgQ2LpAPbBe9MC4ZQUpgf70dM8+++zeIEH6HoUvBAgQILADAQH6DtAtkgABAgQIEFhdoNz2njmaPMitns/qSzclAQIECBDoTkCA3p21JREgQIAAAQIbCNQD6yYB+gaLNgsBAgQIEOhUQIDeKbeFESBAgAABAusK/Pjjj3uzHDlyZO+7LwQIECBAYGwCAvSxtaj6ECBAgACBkQnUf3ee16RJBAgQIEBgrAIC9LG2rHoRIECAAIEBCdR7yaeLff369cmg9J6XV6JNT+NvAgQIECAwBgEB+hhaUR0IECBAgMDABe7cuTOzBnn3eelBz7vSJQIECBAgMGaBQ2OunLoRIECAAAECwxC4evXqpKB5pVp6yhOUf/jhh9Xdu3cnw/OguPrr1oZRK6UkQIAAAQLrCQjQ1/MyNQECBAgQILAFgQTfCdJLoF5fRILzmzdv1gf5ToAAAQIERingFvdRNqtKESBAgACBYQnk9vXbt29XL730UlVeq5bPCxcuVPfu3dsbNqxaKS0BAgQIEFhP4Klffk3rzWJqAgQIECBAgAABAgQIECBAoG0BPehti8qPAAECBAgQIECAAAECBAhsICBA3wDNLAQIECBAgAABAgQIECBAoG0BAXrbovIjQIAAAQIECBAgQIAAAQIbCAjQN0AzCwECBAgQIECAAAECBAgQaFtAgN62qPwIECBAgAABAgQIECBAgMAGAgL0DdDMQoAAAQIECBAgQIAAAQIE2hYQoLctKj8CBAgQIECAAAECBAgQILCBgAB9AzSzECBAgAABAgQIECBAgACBtgUE6G2Lyo8AAQIECBAgQIAAAQIECGwgIEDfAM0sBAgQIECAAAECBAgQIECgbQEBetui8iNAgAABAgQIECBAgAABAhsICNA3QDMLAQIECBAgQIAAAQIECBBoW0CA3rao/AgQIECAAAECBAgQIECAwAYCAvQN0MxCgAABAgQIECBAgAABAgTaFhCgty0qPwIECBAgQIAAAQIECBAgsIGAAH0DNLMQIECAAAECBAgQIECAAIG2BQTobYvKjwABAgQIECBAgAABAgQIbCAgQN8AzSwECBAgQIAAAQIECBAgQKBtAQF626LyI0CAAAECBAgQIECAAAECGwgI0DdAMwsBAgQIECBAgAABAgQIEGhbQIDetqj8CBAgQIAAAQIECBAgQIDABgIC9A3QzEKAAAECBAgQIECAAAECBNoWEKC3LSo/AgQIECBAgAABAgQIECCwgYAAfQM0sxAgQIAAAQIECBAgQIAAgbYFBOhti8qPAAECBAgQIECAAAECBAhsICBA3wDNLAQIECBAgAABAgQIECBAoG0BAXrbovIjQIAAAQIECBAgQIAAAQIbCAjQN0AzCwECBAgQIECAAAECBAgQaFtAgN62qPwIECBAgAABAgQIECBAgMAGAv8fFIFQVQIwo7sAAAAASUVORK5CYII=\" width=\"500\">"
      ],
      "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,iVBORw0KGgoAAAANSUhEUgAAA+gAAAJYCAYAAADxHswlAAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAAD6KADAAQAAAABAAACWAAAAADDsFQWAABAAElEQVR4AezdXZRdVZ0o+llViApJpUjf2w8k8VGofLzcYRoTzoN2gEQf5BglodtDSyThwzMgNCboUEANNkNJ4AKO0wxMIHhse5CAYegYBxNIxAdJ/OAtn/gmSXzoc49WKpFGkapb/xVXuauyq/ZH1d619t6/OcZmr73WXHPN+Vs7If8955qza3gkJYkAAQIECBAgQIAAAQIECBCYUYHuGb26ixMgQIAAAQIECBAgQIAAAQKZgADdF4EAAQIECBAgQIAAAQIECBRAQIBegJugCgQIECBAgAABAgQIECBAQIDuO0CAAAECBAgQIECAAAECBAogIEAvwE1QBQIECBAgQIAAAQIECBAgIED3HSBAgAABAgQIECBAgAABAgUQEKAX4CaoAgECBAgQIECAAAECBAgQEKD7DhAgQIAAAQIECBAgQIAAgQIICNALcBNUgQABAgQIECBAgAABAgQICNB9BwgQIECAAAECBAgQIECAQAEEBOgFuAmqQIAAAQIECBAgQIAAAQIEBOi+AwQIECBAgAABAgQIECBAoAACAvQC3ARVIECAAAECBAgQIECAAAECAnTfAQIECBAgQIAAAQIECBAgUAABAXoBboIqECBAgAABAgQIECBAgAABAbrvAAECBAgQIECAAAECBAgQKICAAL0AN0EVCBAgQIAAAQIECBAgQICAAN13gAABAgQIECBAgAABAgQIFEBAgF6Am6AKBAgQIECAAAECBAgQIEBAgO47QIAAAQIECBAgQIAAAQIECiAgQC/ATVAFAgQIECBAgAABAgQIECAgQPcdIECAAAECBAgQIECAAAECBRAQoBfgJqgCAQIECBAgQIAAAQIECBAQoPsOECBAgAABAg0X2LVrV7riiiuyV70XK0oZ9dbfeQQIECBAoJKAAL2SkOMECBAgQIAAAQIECBAgQKAJAgL0JiC7BAECBAgQIECAAAECBAgQqCQgQK8k5DgBAgQIECBAgAABAgQIEGiCgAC9CcguQYAAAQIECBAgQIAAAQIEKgkI0CsJOU6AAAECBAgQIECAAAECBJogIEBvArJLECBAgAABAgQIECBAgACBSgIC9EpCjhMgQIAAAQIECBAgQIAAgSYICNCbgOwSBAgQIECAwFiBwcHBtH379rR69eq0dOnSbH30devWpaNHj47NOMmnopQxSRUdIkCAAAECNQkI0GvikpkAAQIECBCYqkAE5hGUb9u2LQvII9COdPDgwSxg37t3b8VLFKWMihWVgQABAgQI1CAgQK8BS1YCBAgQIEBg6gIRmK9duzbt378/vfHGG9n7+vXrRwveuHFjOnny5OjnchtFKaNc3ewjQIAAAQL1CgjQ65VzHgECBAgQIFCXwKZNm9KWLVvSggULsvPjffPmzenxxx8fLS96yCdLRSljsjo6RoAAAQIEahUQoNcqJj8BAgQIECAwJYHoPS+XVq1alZYvX54d2rVrV7kso/uKUsZohWwQIECAAIFpEBCgTwOiIggQIECAAIHpESgNvGuZMK706kUpo7ROtgkQIECAQDUCAvRqlOQhQIAAAQIEmiKQD3uPi1V6Dn2iChWljInqZz8BAgQIEJhIQIA+kYz9BAgQIECAQNMFihJcT0c9mo7nggQIECDQ8gIC9Ja/hRpAgAABAgTaR+DMmTOjjent7R3drmWjKGXUUmd5CRAgQIBACAjQfQ8IECBAgACBwgiUPne+ePHiuupVlDLqqryTCBAgQKCjBQToHX37NZ4AAQIECDRfoLSHe/zVv/Od72S7ovd80aJF4w+Pfi5KGaMVskGAAAECBKZBQIA+DYiKIECAAAECBKoX2Lt3b9nMsfZ53vsd65xPlopSxmR1dIwAAQIECNQqcFGtJ8hPgAABAgQIEJiKwLZt27LTYzm06CmPoPypp55K+/bty/bHBG2lS6WVu1ZRyihXN/sIECBAgEC9AgL0euWcR4AAAQIECNQlEMF3BNh5kF1aSATnO3fuLN1VdrsoZZStnJ0ECBAgQKBOAUPc64RzGgECBAgQIFCfQAxf37NnT1q5cmXKlzOL9/Xr16f9+/eP7pus9KKUMVkdHSNAgAABArUKdA2PpFpPkp8AAQIECBAgQIAAAQIECBCYXgE96NPrqTQCBAgQIECAAAECBAgQIFCXgAC9LjYnESBAgAABAgQIECBAgACB6RUQoE+vp9IIECBAgAABAgQIECBAgEBdAgL0uticRIAAAQIECBAgQIAAAQIEpldAgD69nkojQIAAAQIECBAgQIAAAQJ1CQjQ62JzEgECBAgQIECAAAECBAgQmF4BAfr0eiqNAAECBAgQIECAAAECBAjUJSBAr4vNSQQIECBAgAABAgQIECBAYHoFBOjT66k0AgQIECBAgAABAgQIECBQl4AAvS42JxEgQIAAAQIECBAgQIAAgekVEKBPr6fSCBAgQIAAAQIECBAgQIBAXQIC9LrYnESAAAECBAgQIECAAAECBKZXQIA+vZ5KI0CAAAECBAgQIECAAAECdQkI0OticxIBAgQIECBAgAABAgQIEJheAQH69HoqjQABAgQIECBAgAABAgQI1CVwUV1nOanQAnv37k3f+c530uDgYFbPBQsWpE2bNqVFixYVut4qR4AAAQIECBAgQIAAgU4W0IPeZnf/gQceSIcPH07PPvts2r9/f9qzZ0+aPXt2Wr16ddq6dWubtVZzCBAgQIAAAQIECBAg0D4CXcMjqX2a09ktOXjwYHruuefSE088cQHENddck06ePJl27tyZli9ffsFxOwgQIECAAAECBAgQIEBgZgUMcZ9Z/2m9+muvvZb27duXYoj7qlWrxpS9du3atG3bthR5ZjJAHxx8O7377tCYuvlAgAABAgQIECBAgACBIgv09HSn3t73NbyKAvSGEzf/AtFTPj7Fc+iRjh07Nv5QUz9HcP7nP7/b1Gu6GAECBAgQIECAAAECBFpBQIDexLu0a9eutH379uzZ8GouG5O8PfXUU+nQoUNpzpw56cyZM2nx4sVpw4YNKQ+4S8vZvHlzuvrqq8v2kOdB+8KFC0tPsU2AAAECBAgQIECAAAECBREQoDfwRkSAHUF1PBsewfnRo0ervlrkvfnmm9OaNWuyid7yE6OceJ788ccfv2AYe+SZaPh6nBfpxhtvzN79hwABAgQIECBAgAABAgSKJWAW9wbdjwjKly5dmtatW5fefPPNtGzZspquFMF59JZHr3hpimfJ169fnzZu3JhN+lZ6bKLtCM6jBz2WWivX8z7RefYTIECAAAECBAgQIECAQPMEBOgNso6e7DfeeCMbzh5B9pIlS6q+UiyHFr3vEYyXS3kveCypVilFYB75IjiPofESAQIECBAgQIAAAQIECBRTQIBewPuyY8eOrFbjZ2LPqxq94PGKXvr82fL8WOl7HIv1zwXnpSq2CRAg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velrX/vahG4vv/xy+vSnP50dj173G264YcK8DhAgQIAAAQIECBAgQIAAgVYRKMwQ91jzPJZW+9znPpd27dqVfvzjH48aPv300+nw4cPZhHDRez48PJz1nkd+iQABAgQIECBAgAABAgQItINAYXrQAzOWTvvBD36Q5s2bl86cOZO9Yv+2bdvSvn370ptvvpkF5/HcefSkz58/Pw5LBAgQIECAAAECBAgQIECg5QUK04OeSy5atCjt378/C8hfeumlrNc8gvU5c+ZkE8LFM+fLli3Ls3snQIAAAQIECBAgQIAAAQJtIVC4AD1XXblyZYqXRIAAAQIECBAgQIAAAQIEOkGgUEPcOwFcGwkQIECAAAECBAgQIECAQDkBAXo5FfsIECBAgAABAgQIECBAgECTBQToTQZ3OQIECBAgQIAAAQIECBAgUE6gac+g9/f3l7v+lPd1dXVlE8lNuSAFECBAgAABAgQIECBAgACBGRRoWoAea5dLBAgQIECAAAECBAgQIECAQHmBpgXoW7ZsKV8DewkQIECAAAECBAgQIECAAIHUtAB9zZo1uAkQIECAAAECBAgQIECAAIEJBEwSNwGM3QQIECBAgAABAgQIECBAoJkCAvRmarsWAQIECBAgQIAAAQIECBCYQKBpQ9wnuP6ku48fP55OnjyZvXp7e9PixYtTo2aDn7QiDhIgQIAAAQIECBAgQIAAgQYLFC5AP3XqVNq+fXvavXt32aZHoL5p06Z0ww03lD1uJwECBAgQIECAAAECBAgQaEWBQg1xj6D82muvzYLzWJat3OvMmTPpgQceSCtXrkynT59uRXN1JkCAAAECBAgQIECAAAECFwgUpgf90KFDWeCd13DBggVpw4YN2bD22I6h7ocPH06PPPJIGhwcTL/5zW/S6tWr0y9+8Yv8FO8ECBAgQIAAAQIECBAgQKBlBQrTg75169YMsaurKwvMX3nllRRLsy1cuDDNnj07e1+7dm365S9/me2PzBGoP/rooy2Lr+IECBAgQIAAAQIECBAgQCAXKEyAfuzYsRTB+fLly9MXvvCFvH5l37ds2ZIF7DEEfu/evWXz2EmAAAECBAgQIECAAAECBFpJoDABekz+Fmn9+vVV+cVEcZFi6LtEgAABAgQIECBAgAABAgRaXaAwAfqiRYsyyyVLllRlGj3tkfLAvqqTZCJAgAABAgQIECBAgAABAgUVKEyAngfcR44cqYrq7NmzWb5ly5ZVlV8mAgQIECBAgAABAgQIECBQZIHCBOgxAVw8U75r166qvPJ8+VD3qk6SiQABAgQIECBAgAABAgQIFFSgMMusxVD1eP786aefTjHMPWZwL5cGBgbSvn37suXWYhm2vr6+dO7cuXJZ06xZs8rut5MAAQIECBAgQIAAAQIECBRNoDABen9//6hNLLmWL7s2unPcRvS279ixI3uNO5R9jBnhY2Z4iQABAgQIECBAgAABAgQItIJAYQL0CLhrTfWcU+s15CdAgAABAgQIECBAgAABAs0QKEyAHmubSwQIECBAgAABAgQIECBAoFMFChOgT/TMeafeGO0mQIAAAQIECBAgQIAAgc4SKMws7p3FrrUECBAgQIAAAQIECBAgQGCsgAB9rIdPBAgQIECAAAECBAgQIEBgRgQE6DPC7qIECBAgQIAAAQIECBAgQGCsQGGeQR9brZStbR5rnleT5s+fX002eQgQIECAAIEWF5gz671ZC7q7u9LcuZfW1JqhoeE0MPBWTefITIAAAQIEmilQqAD9+PHj6amnnkr79u2r2sB651VTyUiAAAECBFpeoGskMI8U///v6Tm/XX2jhqrPKicBAgQIEJgBgcIE6MeOHUuf+tSnMgLrm8/AN8ElCRAgQIBACwkMDw2ld/5Q3Ui791zal7q6PdXXQrdXVQkQINCxAoUJ0Ldt25bywHz58uUpXr29vR17YzScAAECBAgQmFgggvPDT947cYaSI0vueDhdPHtuyR6bBAgQIECgmAKFCdCPHDmSDVeL9dC//vWvF1NLrQgQIECAAAECBAgQIECAQIMEChOgDw4OZgH6hg0bGtRUxRIgQIAAgdYX6Ou7JMUEafUkk6TVo+YcAgQIECDQPIHCPJC1cOHCrNVmZG/ezXclAgQIEGg9gQjOe3q663rVG9i3npIaEyBAgACB1hQoTA/6smXLUszifuLEiXTllVe2pqZaEyBAgACBJgkMjUyS9vvBt6u62mW97xvpdS/Mb/JV1VkmAgQIECDQiQKFCdBvv/32tHv37nTfffelZ599Ns2aNasT74c2EyBAgACBqgQiOL/zoReryvvtL38y/c3I0HiJAAECBAgQKLZAYQL02bNnZ4F5LLW2YsWKdNttt6XoVY/9fX19kyoK5iflcZAAAQIECBAgQIAAAQIEWkCgMAF6WM2ZMyfFs+ixJvrWrVur4uvq6sryV5VZJgIECBAgQIAAAQIECBAgUFCBwjyQdvLkyXTttddmz6GHVayJXu2roLYzVq2w3L59e1q6dGmK2fElAgQIECBAgAABAgQIECi+QGF60Ldt25YF5EEWvegf//jHU29vb/EFC1TDGHVw6NCh7NGAGIUQwfmZM2c4FugeqQoBAgQIECBAgAABAgQmEihMgB6BZQxXX7lyZXrssccmqq/9kwhs3rx59OgDDzwwum2DAAECBAgQIECAAAECBIovUJgh7vlQ7JgcTiJAgAABAgQIECBAgAABAp0mUJgAff78+Zl9f39/p90D7SVAgAABAgQIECBAgAABAqkwAXoMbY904sSJwtyWXbt2pWuuuabq+sQogHgOfPXq1WndunXZeww1j0nbJAIECBAgQIAAAQIECBAgMJlAYQL0GNoe65lXu7zaZI2q91gE2BFMR2AeQXYtwfXRo0ez9dvj2nv27Ek7d+7M3hctWpQF+Xv37q23Ws4jQIAAAQIECBAgQIAAgQ4QKEyAHjO2f/e7302HDx9O1113XXrmmWeyJdfOnTuXKr2m4z4dPHgwW5Yser7ffPPNbCb0Wsq9+eab0+LFi1PpRG1x/tq1a9P69evTxo0b9aTXAiovAQIECBAgQIAAAQIEOkygMLO4X3XVVRn92bNnU7yq7UmPmd9jSbGppuXLl6c33nhjtJhaeryjrtH7HsF4uXTjjTemHTt2ZD3y0bMuESBAgAABAgQIECBAgACB8QKFCdBjve5WTRF8R1q1alXZJixYsCDFK3rpYwh9bOcphtHHkPpa06ZNm9KGDRtqPU1+AgQIECBAgAABAgQIECioQGEC9Ag4WzFF0B0phuhPliIoj+A8euZLA+stW7aketpe6XqT1cUxAgQIECBAgAABAgQIECieQGEC9HhOuxVTTA4XqbRXvFw7Zs+ene2OZ+zHJ8H2eBGfCRAgQIAAAQIECBAg0HkChZkkrlXp84B7zpw5kzahr68vO37q1KlJ8zlIgAABAgQIECBAgAABAp0pIECf4n2PCe2qSXkPekwm14w0MDCQXaZZ12tGm1yDAAECBAgQIECAAAEC7SxQmCHu7Yxc2rZGToYXk83FK551zwPzWM89ht/HMPpnn3224rPypXW1TYAAAQIECBAgQIAAAQLNExCgT9G61oA7D5yneNmyp8cybxMt9Vb2hBnY2dv7vhm4qksSIECgfQS6u7vqbkycO3fupXWfP50nTqUd9dajUe1vdlvapR1xHxvRlmbfj0a1Iy833puZ3JPJtdvl+9Uu7Zj8brXm0cIF6PGM9vbt29ORI0eqWt98utZBb83b13q17unxVEXr3TU1JkCgXQTi/5k9PfUH+K3u0C7tb5d2xPepXdrSLu1wT4r5t1y7fL/apR2N/pYUKkDft29fuvvuu7M2Dw8PN7rt01J+pcnh8ovkz6p3+ozt7747lJN4J0CAAIE6BKLXI/6RU0+K/7cODRXj/69TaUc9bY9zGtX+ZrelXdrRqHvS7PvRqHZEue3SlnZph3sSAvWnRv3dVX+Naj+zGZ2NhQnQ47npjRs3ZkoRxC5btix7djrWGT9+/Hi65ZZbsmMxRPzQoUPZc9Yf+MAH0po1a2qXncYz8snfqi2y2oC+2vJaLd/g4Nvpz39+t9Wqrb4ECBAojEAMUa+3FzyC89/97g+FaMtU2lFvAxrV/ma3pV3aEfexEW1p9v1oVDui3HZpS7u0wz0JgfpTI/6811+b2s+86KKedNlll9R+Yo1nFCZAj2Htka6++ur09NNPjzZj27ZtWYB+++23p1mzZo3uj8nPInBftWrV6L6Z2MiXT4sfGCZL+azqnd6DPpmRYwQIECBAgAABAgQIEOhkgcI8EBy94jFk7/HHHy97P/IANz+4adOmbKjayy+/nO+akfdFixZl1600WVw+xH3x4sUzUk8XJUCAAIHOFZgz671Z42OYafRk1fLq62t8b0Hn3hktJ0CAAAECYwUKE6BHD3T0Lpf2kkdVYxh7pGPHjmXv+X+WL1+ebb722mv5rhl5z+tRaXb2vIc9zz8jlXVRAgQIEOhIga6/zPx+foKe7pEh8tW/IqiXCBAgQIAAgeYIFCZAj7W6ywW50eMcEwrErO7lUh74ljvWjH1R77wX/ejRo2UvGe3K6znTQ/LLVtBOAgQIEOgIgeGhofSns7+r6hV5JQIECBAgQKC5AoV5Bj0C3VhiLZ4r7+/vH1VYuHBhtr1r1650zz33jO7Pe9TzwHf0wAxs3HrrrdkEdy+99NJosF5ajZjoLlIMy5cIECBAgMBMCbzzh4F0+Ml7q7r8kjseThfPnltVXpkIECBAgACB6REoTA96zNoe6cc//vEFLYtj0Qv96KOPjh677777su0I7BuR8qA6yp6oZzy/bvSKr127Nu3YsWO0pzw/FvW+//77s8B9w4YN+W7vBAgQIECAAAECBAgQIEBgjEBhAvQbb7wxG8oePeXjUz4hXMz0ftVVV2U97NHTHs/SrVy5cnz2uj5HIL106dLsdcUVV6TSesSM8fmxu+66q2z5W7ZsSevXr0+RN+oZQX2UEZ/jB4Y9e/aUPc9OAgQIECBAgAABAgQIECAQAoUZ4h7riccM7jEb+rlz58ZMFhfPeH/9619PX/3qV7Pj+a2LnusvfOEL+ccpvccEdQcOHMjKmGgptAjiJ0ubN29Ot912W4re93hFOTt37szWc5/sPMcIECBAgAABAgQIECBAgEBhAvS4FZP1hscQ8iVLlmSBb553uoe3TxSY51+TSscjX+QxEVwu5p0AAQIECBAgQIAAAQIEqhUoVIBeqdIxYVw+aVylvI4TIECAAAECBAgQIECAAIFWEmiZAD2Gvccz3YcPH86GjH/84x8fM9t7K6GrKwECBAgQIECAAAECBAgQGC9QmAA9lk371Kc+lc12/sILL4ypZxxbt27dmHXSY8b0mBW9dOm1MSf5QIAAAQIECBAgQIAAAQIEWkigMLO4xxriw8PD2Yzn4/02btyYTQ6XH58/f36WN2ZL//nPfz4+u88ECBAgQIAAAQIECBAgQKDlBAoToO/bty9bNi2Grpem3bt3Z2uLx5JqMSP6M888k1555ZV03XXXZUH6c889V5rdNgECBAgQIECAAAECBAgQaEmBwgTosbxapP7+/jGQe/fuzT7HjO2xnniebr/99mwzhr9LBAgQIECAAAECBAgQIECg1QUK8wx6rDEeveTj05EjR7L945dgy5dYO3ny5PhTfCZQOIG+vktSd/eF3+9qKjo0NJwGBt6qJmvD80ylHVG5dmlLu7TDPWnMH5mp/Dkp0nfrokt6M6D4u2vu3EtrxmqXtrRLO4r2530q3y/3pOY/jlWd4J6cZ2qX71e7tKNof3dV9YdpipkKE6CXa0f0jueB+/Lly8dkGRgYyD5Xszb5mBN9IDADAvEP3J6eegesDM1AjctfcmrtiDLbpS3t0g73pPw3fWp7p/bnpDjfra6u839nxY/nPT31/MDYLm1pl3YU68/71L5f7snU/pYqf7Z7kru0y/erXdpRrL+78m9JI98LE6DH8PWY8C1eH/7wh7M2x8RxeSod3h77Tp06lR2aM2dOnsU7gcILDA0NpYH/HKyqnn3v7x3pda83qK/qEnVnqqUdcZF2aUu7tMM9qfurX9OJtfw58d2qibbuzO5J3XQNO9E9aRht3QW7J3XTNexE96RhtIUsuDABevSQHzp0KMWM7WvWrMl6zmOCuPjlPj6PT6+99lq2a3zgPj6fzwSKJBDB+T27v1pVlR5d8/U099K+qvI2O1Mt7Yi6tUtb2qUd7klz/sTU8ufEd8s9qUWglu+WP++1yNaf1z2p365RZ7onjZKtv9x2uif1K1Q+szABeqxpvmvXrqxnPNY4jxTLqkUP+ebNmy9oSR68r1q16oJjdhAgQIAAAQIECBAgQIAAgVYTKNT42RdffDHdcsstKdY5j1f0nO/fvz/NmjVrjGssyRbB+/iZ3cdk8oEAAQIECBAgQIAAAQIECLSQQGF60MNs9uzZWW95uR7zUtOY0X38rO6lx20TIECAAAECBAgQIECAAIFWEyhUD3qr4akvAQIECBAgQIAAAQIECBCYLgEB+nRJKocAAQIECBAgQIAAAQIECExBQIA+BTynEiBAgAABAgQIECBAgACB6RIQoE+XpHIIECBAgAABAgQIECBAgMAUBAToU8BzKgECBAgQIECAAAECBAgQmC4BAfp0SSqHAAECBAgQIECAAAECBAhMQUCAPgU8pxIgQIAAAQIECBAgQIAAgekSEKBPl6RyCBAgQIAAAQIECBAgQIDAFAQE6FPAcyoBAgQIECBAgAABAgQIEJguAQH6dEkqhwABAgQIECBAgAABAgQITEFAgD4FPKcSIECAAAECBAgQIECAAIHpEhCgT5ekcggQIECAAAECBAgQIECAwBQEBOhTwHMqAQIECBAgQIAAAQIECBCYLgEB+nRJKocAAQIECBAgQIAAAQIECExBQIA+BTynEiBAgAABAgQIECBAgACB6RIQoE+XpHIIECBAgAABAgQIECBAgMAUBC6awrlOJUCAAAECLSHQ13dJ6u7uqruuQ0PDaWDgrbrPdyIBAgQIECBAoBoBAXo1SvIQIECAQEsLRHDe0zOVQWNDLd1+lSdAgAABAgRaQ0CA3hr3SS0JECBAYBoEhoaG0u8H3666pMt63zfS8z6VwL7qS8lIgAABAgQIEEgCdF8CAgQIEOgYgQjO73zoxarb++0vfzL9zcjweIkAAQIECBAg0AwB3QLNUHYNAgQIECBAgAABAgQIECBQQUCAXgHIYQIECBAgQIAAAQIECBAg0AwBAXozlF2DAAECBAgQIECAAAECBAhUEBCgVwBymAABAgQIECBAgAABAgQINENAgN4MZdcgQIAAAQIECBAgQIAAAQIVBAToFYAcJkCAAAECBAgQIECAAAECzRAQoDdD2TUIECBAgAABAgQIECBAgEAFAQF6BSCHCRAgQIAAAQIECBAgQIBAMwQE6M1Qdg0CBAgQIECAAAECBAgQIFBB4KIKxx0mQIAAAQI1CfT1XZK6u7tqOicy13NOzRep8YQ5s96bnRF1mzv30qrOLmI7qqq4TAQIECBAgMCMCwjQZ/wWqAABAgTaSyAC1J6e9hig1fWXHxq6uqJNtf/o0F53VmsIECBAgACBRgsI0BstrHwCBAh0qMDw0FB65w8DVbf+PbMuSxEIFzHV0pYit6OItupEgAABAgQI/FVAgP5XC1sECBAgMI0CEZwffvLeqkv8fzZ9J41E6FXnb2bGWtpS5HY008y1CBAgQIAAgdoF2mMMYu3tdgYBAgQIECBAgAABAgQIECiUgAC9ULdDZQgQIECAAAECBAgQIECgUwUE6J1657WbAAECBAgQIECAAAECBAolIEAv1O1QGQIECBAgQIAAAQIECBDoVAEBeqfeee0mQIAAAQIECBAgQIAAgUIJCNALdTtUhgABAgQIECBAgAABAgQ6VUCA3ql3XrsJECBAgAABAgQIECBAoFACAvRC3Q6VIUCAAAECBAgQIECAAIFOFRCgd+qd124CBAgQIECAAAECBAj8/+3dP8wk5X0H8D3fNUlkOEVKmvisKEp0ksHlFYaSkw5c0uB0IB12laOBzlBgK4rka6ADLB1SGqC4lNxJR+mjoLSxdC24j8FNKhO+K/1ez6737+zszp/380jvu7vz93k+zzzzzG9mdpbAoAQE6IOqDpkhQIAAAQIECBAgQIAAgfMqIEA/rzWv3AQIECBAgAABAgQIECAwKAEB+qCqQ2YIECBAgAABAgQIECBA4LwKCNDPa80rNwECBAgQIECAAAECBAgMSkCAPqjqkBkCBAgQIECAAAECBAgQOK8Cl85rwZWbAAECBLYLXL78t7PvfOfC9gkbU+w7fWNWbwkQIECAAAEC51pAgH6uq1/hCRAgsFkgwfbFi2622qxkLAECBAgQIECgGwEBejeOlkKAAIFJC/z5z3+e/e/X/7dTGf/+8b+ZXbiw31X3nRZsIgIECBAgQIDAxAUE6BOvYMUjQIBAFwIJzv/jP/9np0X993/9++yiAH0nKxMRIECAAAECBJoC7ltsanhPgAABAgQIECBAgAABAgR6EhCg9wRvtQQIECBAgAABAgQIECBAoCkgQG9qeE+AAAECBAgQIECAAAECBHoSEKD3BG+1BAgQIECAAAECBAgQIECgKSBAb2p4T4AAAQIECBAgQIAAAQIEehIQoPcEb7UECBAgQIAAAQIECBAgQKApIEBvanhPgAABAgQIECBAgAABAgR6EhCg9wRvtQQIECBAgAABAgQIECBAoCkgQG9qeE+AAAECBAgQIECAAAECBHoSEKD3BG+1BAgQIECAAAECBAgQIECgKSBAb2p4T4AAAQIECBAgQIAAAQIEehIQoPcEb7UECBAgQIAAAQIECBAgQKApIEBvanhPgAABAgQIECBAgAABAgR6EhCg9wRvtQQIECBAgAABAgQIECBAoClwqfnBewLHFrh48XyfE7r0nYuzf/vHf9mJOdNWunTpL+9rWJ+v+5Qj+ZxKWaZSjjZ1cunbtnv1n/9hr83uwsVLs7/7p3/da57K27HaSZtyJE9tyrJPO2mzbbUpy7HLUfWX16Rd9l1typFlH7ss6kR7z3a2a9qnvWeZ+25fbdpJmzZSeTtv++Aqd16TjrXvUie7HwfP62Fgx8KnimMufPNtmm+J/hEgQIAAAQIECBAgQIAAAQK9CZzvy5m9sVsxAQIECBAgQIAAAQIECBBYFBCgL3r4RIAAAQIECBAgQIAAAQIEehEQoPfCbqUECBAgQIAAAQIECBAgQGBRQIC+6OETAQIECBAgQIAAAQIECBDoRUCA3gu7lRIgQIAAAQIECBAgQIAAgUUBAfqih08ECBAgQIAAAQIECBAgQKAXAQF6L+xWSoAAAQIECBAgQIAAAQIEFgUE6IsePhEgQIAAAQIECBAgQIAAgV4EBOi9sFspAQIECBAgQIAAAQIECBBYFBCgL3r4RIAAAQIECBAgQIAAAQIEehEQoPfCbqUECBAgQIAAAQIECBAgQGBRQIC+6OETAQIECBAgQIAAAQIECBDoRUCA3gu7lRIgQIAAAQIECBAgQIAAgUUBAfqih08ECBAgQIAAAQIECBAgQKAXAQF6L+xWSoAAAQIECBAgQIAAAQIEFgUE6IsePhEgQIAAAQIECBAgQIAAgV4EBOi9sFspAQIECBAgQIAAAQIECBBYFBCgL3r4RIAAAQIECBAgQIAAAQIEehEQoPfCbqUECBAgQIAAAQIECBAgQGBRQIC+6OETAQIECBAgQIAAAQIECBDoRUCA3gu7lRIgQIAAAQIECBAgQIAAgUUBAfqih08ECBAgQIAAAQIECBAgQKAXAQF6L+xWSoAAAQIECBAgQIAAAQIEFgUE6IsePhEgQIAAAQIECBAgQIAAgV4EBOi9sFspAQIECBAgQIAAAQIECBBYFBCgL3r4RIDAiAU+//zz2a1bt2bXr1+fXb16df6azxkuEehK4OHDh/Pt7Nq1a/PtLK/ZzjJcOq3Al19+OXvjjTdmzz///Kjb/Ndffz371a9+tbDvSrlSvqGm7Fez7Sfvu6TlMmbeoZdxl3KZpnuBfbctfX/3dbC8xH3rZHl+n/cTuPDNt2m/WUxNgEBTIDutF198cfbJJ5/MHnvsseao0by/d+/e7MMPP5z97ne/mx9sXblyZfbUU0/NXn755VnejyHlQC9lSEo9JN85uK2Dx5s3b85ee+21MRRlEnlMsPHrX/96a1lu3Lgxe/vtt7dON5QJEojfv39/np3l7WzIZUk7+Oqrr/ZiHHrbT3tPu6+U/KaMY2vz2U+99NJLZ8H4cjnu3Lkz3x9XOft+je8777xz1r4/++yzrX1fypiTKFU3aTv1PuXps4yH9OGHzHuMetw3P0Pr+9tsW0Pv+/etk2NsF4csc986mWrff4hhm3kvtZnJPAQIzOYHF82DlLGaNAOOKkMOpnLwm78333xz9sILL9SoQb5WGZ544onZq6++unAw+957781u3749P5j84Q9/OHv22WcHWYZdMpUD3HT2SW+99daoy1LlvXz5cr0d/Gv5J7iIf05iVUqbyd9Q0yuvvLLXFf6UMYHXUFPaQQXny/uo3MmQ8uYE0fe///1B779y8FuB6/IJnjrQTfC+SxB8zLqKd0ybJ0D2WV/KkLKmzaS+chIin7NvTj+T8Q8ePDjpCeHlwGOf8hwy7z7r2XXaNvmpfrO5jj76/kO2rSrDEPv+NnXSrIt6X/1OPp+q3z+kTirf217H1PdvK8sxxgvQj6FqmZMVOMVO65R4OQDM1cB0br/4xS/mr+lUcoD7+uuvzw+gchD85JNPzsedMm+7risHFFWGu3fv/tVsuQsg5cnfu+++O9qgNlc6sv2NLS0HHWPLf+U37SD+CVxX3S2TgCN/0mkEEiwmLQfnGZYg8P33358Hvqm3IZ9gzN1X2ecmz8t3kuSOn08//XS+3SWQTVn7SgnMs6/N9p82nYPrBNa7pPQzmTftI1fKK2VZKVPGZf+c6ZYNatquXg/pww+Zt6v8N5dzSH6G1Pe33baG2PcfUifNuq33ffX7beuk8p3XqfT9zTKd8r3voJ9S27pGL1A7rRQkO58hH/htw07nlitMOWhKYJsgPSkHTbnK3AxC6mB42zL7GJ/85/b1nFlel+pKZzrPsaacMEkdpX6k0wpku6lgJHdojLEOEhg9evRo61/t03LCbqgpAW32X0mV3+W8pq3UCZMEf0NM2a5qn5QTiavST3/60/ng2v5WTXOKYdmHZvvJlfwE0bVP3WXdH3300XyydWVMm0rKidbU7THTIX34IfMeo0xt8zO0vr/ttjXEvr9tnazbPvrq99vWybpyGL6/gAB9fzNznGOBKe20Pvjgg3lNrrsqkyCkDpzSoQ/1IDeFyJWmOhhftXnWwfyqcWMYlqsdOXBdF4yMoQxjzmO+ypKUNjHlOqjvo6aMQ/4qSJ6VUfUxf7PmX+0Thtr+a5+a7WpdwNscnvoZW8oJiAq6n3vuuZXZb554LJOVE3Yw8JA+/JB5O8j6Xy2ibX70/X9F2dmAtnWyKgP6/VUq52eYAP381LWSElgQyHczNx0YZuJmMFJXehYWMpIPddCXznNsqa52TD04HGq9JLioh8LV1cyh5vWQfGU7y50yCWrXnbQ7ZPldzluBdwV+65ZdgXlNv266voZX/h5//PG1WUi7r/z/9re/XTvdUEc0T6akLOtSvkaVVPvqddMZfriAvv9ww2MvQb9/bOHhL9930IdfR3JI4CgCCb7rwG/TCnJQlQPhOpjcNO0Qx+UsdOV93S2WQ8x35akehDXl4LDKOsTXCjCSt/oaSN7nhFWNy4mfXdpS5htqykO6koYenCePsY55grk8BHJVu864tPuaNvMNLdV+aVPgmjzX+N///vdDK8LW/HzxxRfzaba1jxpfJlsXbILWAvr+1nQnm1G/fzLqwa5IgD7YqpExAscX2OWKcl2l+u53v3v8DHW0hhzk5S8H73VFZvnp7h2t6qiLSd7zlwP0VUHIUVfe4cJThtRFBbS5Wpb6aAa8Ha6u00X95je/OVte8p1y5GGD1S5qZALb5h0nNXwMr3USK/uDXfYJQyhTnjmRpxvn4WlJzfaRW8Hz3c20m+ZDyYaQ72YeKihd3paa0zTf5/utY0t/+tOf5lnedJdAJqj+ZYxlHFudJL+7tPPaLqtuxlDOKfT9U+n3s72Mue/ve3sXoPddA9ZPYMACzasZ+YmyMaRr165NJniqs+j1LIAx+C/nMbeH1y3iCZhy0JdOO8HVGILaCjCS95///OfzsuQBkdUe8vCutJOqq7EF6amP+r36MW1nqY883DIBev3V9pVtMA+O/NnPfnZ29Xl5uxzC5wrQtwWltR+ugGkIed81D3/84x/nk24L8uonl8ZYxl0txjRdbXPJc+3rhp7/qfT91ZeMaX+8atsYe9+/qkynHOY76KfUti4CIxPIlbWkHEgO+aFRTdbkNQfq+auUq6DNA44aPuTXXKlNnnOVeWxB37JrypDfOM4ToPMk6CpPDkQSrA851XaTwCEHHLkim6dY54pt/lKuuhOgruYOuTzLeas856RDlWN5mqF+Thuv9p48NoO73A6+LfDtu1zlnXyve8ZH8yFrQy/PKs86wbVqnGHDFdD391M3U+r3Izjmvr+fLeAvaxWg/8XCOwIEGgIJnOrK56afMGvMMoi3uaqWQLD+EgymHNevXx98MFiACQorcBryz11Vfje9JoBKneS1Uq6cV3BSVwtq3JBfc0Vj1a2h1T4SaPX9c1j7+DXz+5Of/GSfWXufNnmvW9zz1YNsYzn5kxMmafPZfw29zWdbqhOJ9UsBy7C1H8jwbbeJL8/rM4E2Avr+NmqHzzOlfj8aU+r7D6/d/ZcgQN/fzBwEJi+QjqIeGpXgo4KpsRU8B78JBnN1MClPqc6B/dBTXb0Y41XNss3txQma8rcq1UPvsq0N+Sp689bcuvK/XJ4ciFQbaX5nfXm6oX2uoDD5X3XiYWj5bebnxRdfnF91ThvJXQ3ln7KkzdftoUNv89UOchKx2n3KmXZx69ateduoIL5emw5Df1/tZ9uV9LoVfoxlHHod7JM/ff8+Wt1OW+1/zP1+RKbS93dbu/svTYC+v5k5CExaIAFsBec5yB3Lre2bKiW/k56UslVQsmn6Psc1r1788pe/7DMrB607B9oJmtYdcCeQqrTu9t4a3+drfTc25VhXluTve9/73jybf/jDH/rM7l7rrjtk6gTWXjP3OHEeAlfbzLo2kq8fpL6G3uaTzzq5kGcBXL16dZbv0ubq/6effjo/+VBXzuunyHqk33vV1X62zVgBfJV12/TGdy+g7+/edNclTqXfT3mz351C379r3R1rOgH6sWQtl8AIBdJB57bRnEXPlfMcPE4hJRis4GroP1VUt3znIVeV5ynUwXIZmgF6trehpmY+N+WxApG0oTGkmJf7j3/84zFk+SyP9XvgaR+b2kgFtENv87nLpNneE6Tm8yeffDK/s6HqqQL5M4gRvKn2U7/gsC7LVca64r5uOsOPI6DvP47rrks9L/1+PGqfkPfV7vNeWhTwFPdFD58InFuBZgedW0bHdsvrtorLQW/KOOQOIXmr/OVqWj1de1XZcutupZxMGdudDmN54FW1g22Bd92iW3Uy9Ndcha40tsCv2kjzQK/K0nyt8TV9c9zQ3ucun7rTp5m35tc/nnvuueaoUbyvbWtb+6kAfixPDB8F/o6Z1PfvCHWkyc5Tvx/CsfT9R6runRcrQN+ZyoQEpiuQDvqZZ56ZB7C5mlMHVWMocTq3OhDflN86SP/BD36wabLex20qSzq2OtDNlcO6HXTTVcTeC7QmA1UfGT3k7a2ZtwRLFbAvF6uu0g59+6p8f/zxx/O3zfLVuKG/JojL7fnNbWhVnivoG0udrCpDnuqclO1ujO282V7WtZ/s02q/NrYTjavqbEzD9P3DqK3z0u9Hu7nfHmP/c6otRoB+KmnrITBQgXTQua09aWzBefKcA9h0bptux29eLXz66acz2yBTypGnUK9Lqat8PzUpT3cf6sFsvh+c7/rn58jWpQ8++OBs1NCvDOY72gkIk+dmwFEFSHnroGMsT0Ov73DXbeBVljG81kFd2kPKUZ+bea9xGTbkNt/M8/L7lK2uoNdD75anGcPntJmUY137qeeCZP+3KVAZQ1nHlEd9/zBqayr9fjSzz5pS39/nFuI76H3qWzeBngWqg86V2TEG5+FL55afIsoTj1Oe5ZTA6fXXX58PzoH8uidxL8/nc3uBdNAJaFMnq1JOmNQDyvLE7aFfGaxbj5Pn5smelC3bXH3dINvXqgB+lcFQhq0KboeSt3X5iHE5r3tKe9VJ9g9Db/MVhDfLmwPdPKk+Kd9HH2M9zTP/7b86ubCq/aSc9VWeTSdZa1leuxHQ93fjaCmLAlPr+xdLd9pPrqCf1tvaCAxGoDroBLD1O851FXBVJnM79RADqRzU5fu/OcjLAWAdvCevOfir36XO5yrnqvIZ1p1AnqydW75TH3kqdQKkCjBSH6mXpAwfevCUfCbIS5CRE0EJ/Ko8aUMpT9pNpnn//fcz+eBTs53X1yQGn+mlDKYt52s5KUtecxdGtrEvvvhi9tFHH81PnKTN53kaQ065AyjbVXO/lZ/qS9tJyt0bdYKoz3JkW68TBslHPldqDs+vGSzfOZN6SZtJW0n7SZlyV0PqqoLzlH8M+4Iq85hfh9b3t9229P3H2wrb1snU+v7jCW9f8oVvvk3bJzMFAQIRWLXTqoPdCkAy3aqDlAwfUqoDw13zlIOq5QOvXec9xXS5CpUnoVZ9NNeZg78c0A/xBEMzn9veZ/urW9xTnqHe4l7lyO+61gF4Dctr6mHIt+g389p8nwCjnrbbHD70ttHMa97nBEl9rWXsD4RMfaReltNY2vym/VZOCg3lqnJz37Ns3fyctv3ZZ581B529X9fnJDDPnTSnSIf04YfMe4yytc3PunpYl8dj798O3bY2taFT7wfa1sk6+wxv+pyq32+uc1Pe1rX3qfX9mwyONc4V9GPJWu5kBerq33IBm8NXBYnL0/vcrUA64nx/O/bpsNPBpPPI8FzdlE4vUE+mzm3h1SZyIit1MsaUQCJXavPwsbT3sW5fVRepg7FeQa/tJ4FdAtmx1kntt7I9pQzZb2V/NbSTb9nWHz16VOytXnOyIW0o++dsgyln9gen3j83++pmQZrDm21k3TTrhq+btzl9V++beW4uszn8lPlp5mHX94duW9WGUs4h9P1N+6ZBc/jU62RqfX+zHk/13hX0U0lbDwECBAgQIECAAAECBAgQ2CDgIXEbcIwiQIAAAQIECBAgQIAAAQKnEhCgn0raeggQIECAAAECBAgQIECAwAYBAfoGHKMIECBAgAABAgQIECBAgMCpBATop5K2HgIECBAgQIAAAQIECBAgsEFAgL4BxygCBAgQIECAAAECBAgQIHAqAQH6qaSthwABAgQIECBAgAABAgQIbBAQoG/AMYoAAQIECBAgQIAAAQIECJxKQIB+KmnrIUCAAAECBAgQIECAAAECGwQE6BtwjCJAgAABAgQIECBAgAABAqcSEKCfStp6CBAgQIAAAQIECBAgQIDABgEB+gYcowgQIECAAAECBAgQIECAwKkEBOinkrYeAgQIECBAgAABAgQIECCwQUCAvgHHKAIECBAgQIAAAQIECBAgcCoBAfqppK2HAAECBAgQIECAAAECBAhsEBCgb8AxigABAgQIECBAgAABAgQInEpAgH4qaeshQIAAAQIECBAgQIAAAQIbBAToG3CMIkCAAAECBAgQIECAAAECpxIQoJ9K2noIECBAgACBBYEPP/xwdvXq1fnfwog9Przxxhtny3j48OEec5qUAAECBAgMT0CAPrw6kSMCBAgQIECAAAECBAgQOIcCl85hmRWZAAECBAgQmIjAlStXZvlLevzxxydSKsUgQIAAgfMqIEA/rzWv3AQIECBAYAICL7/88ix/EgECBAgQmIKAW9ynUIvKQIAAAQIECBAgQIAAAQKjFxCgj74KFYAAAQIECBAgQIAAAQIEpiAgQJ9CLSoDAQIECBAgQIAAAQIECIxeQIA++ipUAAIECBAgQIAAAQIECBCYgoAAfQq1qAwECBAgQGACAl9//fXsvffemz3//POza9euzX/f/KWXXpp9/vnna0u37bfUs7z81nqWl5R15LfTr1+/fjb81q1bsy+//HLtOowgQIAAAQKnEhCgn0raeggQIECAAIG1AgmkE0Tfvn17HpAnkE56+PDhPGC/d+/e2nl3HZFlPfPMM7ME9RWQZz3379+fB+w1bNflmY4AAQIECHQtIEDvWtTyCBAgQIAAgb0FEpi/8MILswcPHswePXo0f7158+bZcl555ZWzoPps4B5vEojnavyTTz55to67d+/Obty4cbaUnCSQCBAgQIBAnwIC9D71rZsAAQIECBCYC7z66quzN998c3blypX557y+9tprs7feeutM6NAAOsu8c+fO2TqeeOKJ2dtvvz3La9LHH398ti5vCBAgQIBAHwIC9D7UrZMAAQIECBBYEMjV81Xp2WefnT311FPzUbk1/ZC0bh0/+tGP5out2+oPWYd5CRAgQIDAIQIC9EP0zEuAAAECBAgcXaAZWG96YNy2jFSgvzzd5cuXzwYJ0s8ovCFAgACBHgQE6D2gWyUBAgQIECCwu0Dd9p45DnmQW3M5u6/dlAQIECBA4HQCAvTTWVsTAQIECBAg0EKgGVgfEqC3WLVZCBAgQIDASQUE6CfltjICBAgQIEBgX4GvvvrqbJbHHnvs7L03BAgQIEBgagIC9KnVqPIQIECAAIGJCTS/d56fSZMIECBAgMBUBQToU61Z5SJAgAABAiMSaF4lX872u+++Ox+Uq+f1k2jL0/hMgAABAgSmICBAn0ItKgMBAgQIEBi5wL1791aWIL99XlfQ81vpEgECBAgQmLLApSkXTtkIECBAgACBcQjcvn17ntH8pFqulCcof+edd2b379+fD8+D4po/tzaOUsklAQIECBDYT0CAvp+XqQkQIECAAIEjCCT4TpBegXpzFQnO79y50xzkPQECBAgQmKSAW9wnWa0KRYAAAQIExiWQ29fv3r07u3Hjxqx+Vi2vN2/enD148OBs2LhKJbcECBAgQGA/gQvffJv2m8XUBAgQIECAAAECBAgQIECAQNcCrqB3LWp5BAgQIECAAAECBAgQIECghYAAvQWaWQgQIECAAAECBAgQIECAQNcCAvSuRS2PAAECBAgQIECAAAECBAi0EBCgt0AzCwECBAgQIECAAAECBAgQ6FpAgN61qOURIECAAAECBAgQIECAAIEWAgL0FmhmIUCAAAECBAgQIECAAAECXQsI0LsWtTwCBAgQIECAAAECBAgQINBCQIDeAs0sBAgQIECAAAECBAgQIECgawEBeteilkeAAAECBAgQIECAAEthFQ8AAAHJSURBVAECBFoICNBboJmFAAECBAgQIECAAAECBAh0LSBA71rU8ggQIECAAAECBAgQIECAQAsBAXoLNLMQIECAAAECBAgQIECAAIGuBQToXYtaHgECBAgQIECAAAECBAgQaCEgQG+BZhYCBAgQIECAAAECBAgQINC1gAC9a1HLI0CAAAECBAgQIECAAAECLQQE6C3QzEKAAAECBAgQIECAAAECBLoWEKB3LWp5BAgQIECAAAECBAgQIECghYAAvQWaWQgQIECAAAECBAgQIECAQNcCAvSuRS2PAAECBAgQIECAAAECBAi0EBCgt0AzCwECBAgQIECAAAECBAgQ6FpAgN61qOURIECAAAECBAgQIECAAIEWAgL0FmhmIUCAAAECBAgQIECAAAECXQsI0LsWtTwCBAgQIECAAAECBAgQINBCQIDeAs0sBAgQIECAAAECBAgQIECgawEBeteilkeAAAECBAgQIECAAAECBFoICNBboJmFAAECBAgQIECAAAECBAh0LSBA71rU8ggQIECAAAECBAgQIECAQAsBAXoLNLMQIECAAAECBAgQIECAAIGuBQToXYtaHgECBAgQIECAAAECBAgQaCHw/x8PRPMB+iwPAAAAAElFTkSuQmCC\" width=\"500\">"
      ],
      "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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BAgQIECAAAECBAgQWENAgL4GnlkJECBAgAABAgQIECBAgEBbAgL0tiQthwABAgQIECBAgAABAgQIrCEgQF8Dz6wECBAgQIAAAQIECBAgQKAtAQF6W5KWQ4AAAQIECBAgQIAAAQIE1hAQoK+BZ1YCBAgQIECAAAECBAgQINCWgAC9LUnLIUCAAAECBAgQIECAAAECawgI0NfAMysBAgQIECBAgAABAgQIEGhLQIDelqTlECBAgAABAgQIECBAgACBNQQE6GvgmZUAAQIECBAgQIAAAQIECLQlIEBvS9JyCBAgQIAAAQIECBAgQIDAGgIC9DXwzEqAAAECBAgQIECAAAECBNoSONTWgiynGwJ37typrl27Vj1+/HiUoaNHj1aXLl2qjh8/3o0MygUBAgQIECBAgAABAgQITBXQgz6VpZ8D33333erBgwfVzZs3q3v37lW3b9+unnnmmercuXPV+++/389CyTUBAgQIECBAgAABAgT2iYAAfSAVff/+/eqHH36oLl++XB0+fHhUqrxevXq1Si/6xx9/XGUaiQABAgQIECBAgAABAgS6KSBA72a9rJyrL774orp7926VW9wn0/nz50eDMo1EgAABAgQIECBAgAABAt0UEKB3s14a5+rRo0dPzZse9KRvv/32qXEGECBAgAABAgQIECBAgEA3BDwkbk493Lp1q7p+/fro+9xzJtsblQezffTRR9WXX35ZHTlypPrxxx+rEydOVBcvXhzdZr434Qbe5Nb2F198sTp16tRTSy9B+3PPPffUOAMIECBAgAABAgQIECBAoBsCAvRaPSTATlCd72onOP/mm29qY+e/zbSvvvpq9ac//Wn0cLYydZZz+vTp6sMPP6zOnj1bBm/kdVpwnhUlD0mvvPLK6NU/AgQIECBAgAABAgQIEOiegFvcf62TBOUnT56sXnvtteq7776rXnjhhZVqK8F5esvTk11P+f73hQsXqrfeeqsqPdn18Zt+n+A8681PrZVb3Te9TssnQIAAAQIECBAgQIAAgdUFBOi/mqX3+eHDh6Pb2RNkP//880tr5ifM0vteHsY2OWPpuc7PoG0zJTDPOhOc5zZ7iQABAgQIECBAgAABAgS6K+AW9xbqJj9hljTrFvb0XOcvvfQJmus92Qmgyy3oq2RlUdCd9eT3zxdNt8o6TUuAAAECBAgQIECAAAECmxMQ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TwQIECBAgAABAgQIECBAYCcCAvSdsFspAQIECBAgQIAAAQIECBAYFxCgj3v4RIAAAQIECBAgQIAAAQIEdiIgQN8Ju5USIECAAAECBAgQIECAAIFxAQH6uIdPBAgQIECAAAECBAgQIEBgJwIC9J2wWykBAgQIECBAgAABAgQIEBgXEKCPe/hEgAABAgQIECBAgAABAgR2IiBA3wm7lRIgQIAAAQIECBAgQIAAgXEBAfq4h08ECBAgQIAAAQIECBAgQGAnAgL0nbBbKQECBAgQIECAAAECBAgQGBcQoI97+ESAAAECBAgQIECAAAECBHYiIEDfCbuVEiBAgAABAgQIECBAgACBcQEB+riHTwQIECBAgAABAgQIECBAYCcCAvSdsFspAQIECBAgQIAAAQIECBAYFxCgj3v4RIAAAQIECBAgQIAAAQIEdiIgQN8Ju5USIECAAAECBAgQIECAAIFxAQH6uIdPBAj0WOCbb76p3nzzzer06dPVsWPHRq/5nOESgbYE7t+/P9rOTp48OdrO8prtLMOl7Qo8evSoevfdd6tz5871us0/fvy4ev/998f2XSlXytfVlP1qtv3kfZk0WcbM2/UyLlMu07QvsOq25djffh1MLnHVOpmc3+fVBA788iStNoupCRCoC2Sn9eqrr1aff/55dfjw4fqo3ry/c+dOdevWrerrr78enWwdPXq0OnXqVHXx4sUq7/uQcqKXMiSlHpLvnNyWk8cLFy5Uly9f7kNRBpHHBBsff/zxwrKcOXOmunr16sLpujJBAvG7d++OsjO5nXW5LGkHP/7440qMXW/7ae9p9yUlvylj39p89lOvvfbaXjA+WY4bN26M9selnLt+je9HH320176/+uqrhce+lDEXUUrdpO2U9ynPLsu4zjF8nXk3UY+r5qdrx/4m21bXj/2r1skmtot1lrlqnQz12L+OYZN5DzWZyTwECFSjk4v6SUpfTeoBRylDTqZy8pu/K1euVOfPny+jOvlaynD8+PHq0qVLYyez169frz744IPRyeTzzz9fnT17tpNlWCZTOcHNwT7pww8/7HVZSnmfffbZ8rbzr8U/wUX8cxGrpLSZ/HU1vfXWWyv18KeMCby6mtIOSnA+uY/KnQwpby4Q/eEPf+j0/isnvyVwnbzAU050E7wvEwRvsq7iHdP6BZBV1pcypKxpM6mvXITI5+yb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b0vaeggQIECAAAECBAgQIECAwBwBAfocHKMIECBAgAABAgQIECBAgMC2BATo25K2HgIECBAgQIAAAQIECBAgMEdAgD4HxygCBAgQIECAAAECBAgQILAtAQH6tqSthwABAgQIECBAgAABAgQIzBEQoM/BMYoAAQIECBAgQIAAAQIECGxLQIC+LWnrIUCAAAECBAgQIECAAAECcwQE6HNwjCJAgAABAgQIECBAgAABAtsSEKBvS9p6CBAgQIAAAQIECBAgQIDAHAEB+hwcowgQIECAAAECBAgQIECAwLYEBOjbkrYeAgQIECBAgAABAgQIECAwR0CAPgfHKAIECBAgQIAAAQIECBAgsC0BAfq2pK2HAAECBAgQIECAAAECBAjMERCgz8ExigABAgQIECBAgAABAgQIbEtAgL4taeshQIAAAQIExgRu3bpVHTt2bPQ3NmKFD+++++7eMu7fv7/CnCYlQIAAAQLdExCgd69O5IgAAQIECBAgQIAAAQIE9qHAoX1YZkUmQIAAAQIEBiJw9OjRKn9JR44cGUipFIMAAQIE9quAAH2/1rxyEyBAgACBAQhcvHixyp9EgAABAgSGIOAW9yHUojIQIECAAAECBAgQIECAQO8FBOi9r0IFIECAAAECBAgQIECAAIEhCAjQh1CLykCAAAECBAgQIECAAAECvRcQoPe+ChWAAAECBAgQIECAAAECBIYgIEAfQi0qAwECBAgQGIDA48ePq+vXr1fnzp2rTp48Ofp989dee6365ptvZpZu0W+pZ3n5rfUsLynryG+nnz59em/4m2++WT169GjmOowgQIAAAQLbEhCgb0vaeggQIECAAIGZAgmkE0R/8MEHo4A8gXTS/fv3RwH7nTt3Zs677Igs66WXXqoS1JeAPOu5e/fuKGAvw5ZdnukIECBAgEDbAgL0tkUtjwABAgQIEFhZIIH5+fPnq3v37lUPHz4cvV64cGFvOW+99dZeUL03cIU3CcTTG3/ixIm9ddy+fbs6c+bM3lJykUAiQIAAAQK7FBCg71LfugkQIECAAIGRwKVLl6orV65UR48eHX3O6+XLl6sPP/xwT2jdADrLvHHjxt46jh8/Xl29erXKa9Jnn322ty5vCBAgQIDALgQE6LtQt04CBAgQIEBgTCC959PS2bNnq1OnTo1G5db0ddKsdbzwwgujxZbb6tdZh3kJECBAgMA6AgL0dfTMS4AAAQIECGxcoB5Yz3tg3KKMlEB/crpnn312b5AgfY/CGwIECBDYgYAAfQfoVkmAAAECBAgsL1Bue88c6zzIrb6c5dduSgIECBAgsD0BAfr2rK2JAAECBAgQaCBQD6zXCdAbrNosBAgQIEBgqwIC9K1yWxkBAgQIECCwqsCPP/64N8vhw4f33ntDgAABAgSGJiBAH1qNKg8BAgQIEBiYQP175/mZNIkAAQIECAxVQIA+1JpVLgIECBAg0COBei/5ZLavXbs2GpTe8/KTaJPT+EyAAAECBIYgIEAfQi0qAwECBAgQ6LnAnTt3ppYgv31eetDzW+kSAQIECBAYssChIRdO2QgQIECAAIF+CHzwwQejjOYn1dJTnqD8o48+qu7evTsangfF1X9urR+lkksCBAgQILCagAB9NS9TEyBAgAABAhsQSPCdIL0E6vVVJDi/ceNGfZD3BAgQIEBgkAJucR9ktSoUAQIECBDol0BuX799+3Z15syZqvysWl4vXLhQ3bt3b29Yv0oltwQIECBAYDWBA788SavNYmoCBAgQIECAAAECBAgQIECgbQE96G2LWh4BAgQIECBAgAABAgQIEGggIEBvgGYWAgQIECBAgAABAgQIECDQtoAAvW1RyyNAgAABAgQIECBAgAABAg0EBOgN0MxCgAABAgQIECBAgAABAgTaFhCgty1qeQQIECBAgAABAgQIECBAoIGAAL0BmlkIECBAgAABAgQIECBAgEDbAgL0tkUtjwABAgQIECBAgAABAgQINBAQoDdAMwsBAgQIECBAgAABAgQIEGhbQIDetqjlESBAgAABAgQIECBAgACBBgIC9AZoZiFAgAABAgQIECBAgAABAm0LCNDbFrU8AgQIECBAgAABAgQIECDQQECA3gDNLAQIECBAgAABAgQIECBAoG0BAXrbopZHgAABAgQIECBAgAABAgQaCAjQG6CZhQABAgQIECBAgAABAgQItC0gQG9b1PIIECBAgAABAgQIECBAgEADAQF6AzSzECBAgAABAgQIECBAgACBtgUE6G2LWh4BAgQIECBAgAABAgQIEGggIEBvgGYWAgQIECBAgAABAgQIECDQtoAAvW1RyyNAgAABAgQIECBAgAABAg0EBOgN0MxCgAABAgQIECBAgAABAgTaFhCgty1qeQQIECBAgAABAgQIECBAoIGAAL0BmlkIECBAgAABAgQIECBAgEDbAgL0tkUtjwABAgQIECBAgAABAgQINBAQoDdAMwsBAgQIECBAgAABAgQIEGhbQIDetqjlESBAgAABAgQIECBAgACBBgIC9AZoZiFAgAABAgQIECBAgAABAm0LCNDbFrU8AgQIECBAgAABAgQIECDQQECA3gDNLAQIECBAgAABAgQIECBAoG0BAXrbopZHgAABAgQIECBAgAABAgQaCPx/c5iVh4GbSFMAAAAASUVORK5CYII=\" width=\"500\">"
      ],
      "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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gAABAgQIECBAgAABAgTWEBCgr4FnVgIECBAgQIAAAQIECBAg0JaAAL0tScshQIAAAQIECBAgQIAAAQJrCAjQ18AzKwECBAgQIECAAAECBAgQaEtAgN6WpOUQIECAAAECBAgQIECAAIE1BAToa+CZlQABAgQIECBAgAABAgQItCUgQG9L0nIIECBAgAABAgQIECBAgMAaAgL0NfDMSoAAAQIECBAgQIAAAQIE2hIQoLclaTkECBAgQIAAAQIECBAgQGANAQH6GnhmJUCAAAECBAgQIECAAAECbQkI0NuStBwCBAgQIECAAAECBAgQILCGgAB9DTyzEiBAgAABAgQIECBAgACBtgQE6G1JWg4BAgQIECBAgAABAgQIEFhDQIC+Bp5ZCRAgQIAAAQIECBAgQIBAWwIC9LYkLYcAAQIECBAgQIAAAQIECKwhIEBfA8+sBAgQIECAAAECBAgQIECgLYGDbS3IcrohcPv27eratWvVo0ePRhk6cuRIdfHixerYsWPdyKBcECBAgAABAgQIECBAgMBUAT3oU1n6OfCdd96p7t+/X928ebO6e/dudevWrerpp5+uzp49W7333nv9LJRcEyBAgAABAgQIECBAYJ8ICNAHUtH37t2rvv/+++rSpUvVoUOHRqXK69WrV6v0on/44YdVppEIECBAgAABAgQIECBAoJsCAvRu1svKufr888+rO3fuVLnFfTKdO3duNCjTSAQIECBAgAABAgQIECDQTQEBejfrpXGuHj58+MS86UFP+uabb54YZwABAgQIECBAgAABAgQIdEPAQ+Lm1MPHH39cXb9+ffR97jmT7Y3Kg9k++OCD6osvvqgOHz5c/fDDD9Xx48erCxcujG4z35twA29ya/sLL7xQnTx58omll6D92WeffWKcAQQIECBAgAABAgQIECDQDQEBeq0eEmAnqM53tROcf/3117Wx899m2ldeeaX605/+NHo4W5k6yzl9+nT1/vvvV2fOnCmDN/I6LTjPipKHpJdffnn06h8BAgQIECBAgAABAgQIdE/ALe6/1EmC8hMnTlSvvvpq9e2331bPP//8SrWV4Dy95enJrqd8//v8+fPVm2++WZWe7Pr4Tb9PcJ715qfWyq3um16n5RMgQIAAAQIECBAgQIDA6gIC9F/M0vv84MGD0e3sCbKfe+65pTXzE2bpfS8PY5ucsfRc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zcExigABAgQIECBAgAABAgQIbEtAgL4taeshQIAAAQIECBAgQIAAAQJzBAToc3CMIkCAAAECBAgQIECAAAEC2xIQoG9L2noIECBAgAABAgQIECBAgMAcAQH6HByjCBAgQIAAAQIECBAgQIDAtgQE6NuSth4CBAgQIECAAAECBAgQIDBHQIA+B8coAgQIECBAgAABAgQIECCwLQEB+rakrYcAAQIECBAgQIAAAQIECMwREKDPwTGKAAECBAgQIECAAAECBAhsS0CAvi1p6yFAgAABAgQIECBAgAABAnMEBOhzcIwiQIAAAQIECBAgQIAAAQLbEhCgb0vaeggQIECAAAECBAgQIECAwBwBAfocHKMIECBAgAABAgQIECBAgMC2BATo25K2HgIECBAgQIAAAQIECBAgMEdAgD4HxygCBAgQIECAAAECBAgQILAtAQH6tqSthwABAgQIECBAgAABAgQIzBEQoM/BMYoAAQIECBAgQIAAAQIECGxLQIC+LWnrIUCAAAECBMYEPv744+ro0aOjv7ERK3x455139pZx7969FeY0KQECBAgQ6J6AAL17dSJHBAgQIECAAAECBAgQILAPBQ7uwzIrMgECBAgQIDAQgSNHjlT5Szp8+PBASqUYBAgQILBfBQTo+7XmlZsAAQIECAxA4MKFC1X+JAIECBAgMAQBt7gPoRaVgQABAgQIECBAgAABAgR6LyBA730VKgABAgQIECBAgAABAgQIDEFAgD6EWlQGAgQIECBAgAABAgQIEOi9gAC991WoAAQIECBAgAABAgQIECAwBAEB+hBqURkIECBAgMAABB49elRdv369Onv2bHXixInR75u/+uqr1ddffz2zdIt+Sz3Ly2+tZ3lJWUd+O/306dN7w994443q4cOHM9dhBAECBAgQ2JaAAH1b0tZDgAABAgQIzBRIIJ0g+sqVK6OAPIF00r1790YB++3bt2fOu+yILOvUqVNVgvoSkGc9d+7cGQXsZdiyyzMdAQIECBBoW0CA3rao5REgQIAAAQIrCyQwP3fuXHX37t3qwYMHo9fz58/vLefNN9/cC6r3Bq7wJoF4euOPHz++t45bt25VL7744t5ScpFAIkCAAAECuxQQoO9S37oJECBAgACBkcDFixery5cvV0eOHBl9zuulS5eq999/f09o3QA6y7xx48beOo4dO1ZdvXq1ymvSp59+urcubwgQIECAwC4EBOi7ULdOAgQIECBAYEwgvefT0pkzZ6qTJ0+ORuXW9HXSrHU8//zzo8WW2+rXWYd5CRAgQIDAOgIC9HX0zEuAAAECBAhsXKAeWM97YNyijJRAf3K6Z555Zm+QIH2PwhsCBAgQ2IGAAH0H6FZJgAABAgQILC9QbnvPHOs8yK2+nOXXbkoCBAgQILA9AQH69qytiQABAgQIEGggUA+s1wnQG6zaLAQIECBAYKsCAvStclsZAQIECBAgsKrADz/8sDfLoUOH9t57Q4AAAQIEhiYgQB9ajSoPAQIECBAYmED9e+f5mTSJAAECBAgMVUCAPtSaVS4CBAgQINAjgXov+WS2r127NhqU3vPyk2iT0/hMgAABAgSGICBAH0ItKgMBAgQIEOi5wO3bt6eWIL99XnrQ81vpEgECBAgQGLLAwSEXTtkIECBAgACBfghcuXJllNH8pFp6yhOUf/DBB9WdO3dGw/OguPrPrfWjVHJJgAABAgRWExCgr+ZlagIECBAgQGADAgm+E6SXQL2+igTnN27cqA/yngABAgQIDFLALe6DrFaFIkCAAAEC/RLI7eu3bt2qXnzxxar8rFpez58/X929e3dvWL9KJbcECBAgQGA1gad+fpxWm8XUBAgQIECAAAECBAgQIECAQNsCetDbFrU8AgQIECBAgAABAgQIECDQQECA3gDNLAQIECBAgAABAgQIECBAoG0BAXrbopZHgAABAgQIECBAgAABAgQaCAjQG6CZhQABAgQIECBAgAABAgQItC0gQG9b1PIIECBAgAABAgQIECBAgEADAQF6AzSzECBAgAABAgQIECBAgACBtgUE6G2LWh4BAgQIECBAgAABAgQIEGggIEBvgGYWAgQIECBAgAABAgQIECDQtoAAvW1RyyNAgAABAgQIECBAgAABAg0EBOgN0MxCgAABAgQIECBAgAABAgTaFhCgty1qeQQIECBAgAABAgQIECBAoIGAAL0BmlkIECBAgAABAgQIECBAgEDbAgL0tkUtjwABAgQIECBAgAABAgQINBAQoDdAMwsBAgQIECBAgAABAgQIEGhbQIDetqjlESBAgAABAgQIECBAgACBBgIC9AZoZiFAgAABAgQIECBAgAABAm0LCNDbFrU8AgQIECBAgAABAgQIECDQQECA3gDNLAQIECBAgAABAgQIECBAoG0BAXrbopZHgAABAgQIECBAgAABAgQaCAjQG6CZhQABAgQIECBAgAABAgQItC0gQG9b1PIIECBAgAABAgQIECBAgEADAQF6AzSzECBAgAABAgQIECBAgACBtgUE6G2LWh4BAgQIECBAgAABAgQIEGggIEBvgGYWAgQIECBAgAABAgQIECDQtoAAvW1RyyNAgAABAgQIECBAgAABAg0EBOgN0MxCgAABAgQIECBAgAABAgTaFhCgty1qeQQIECBAgAABAgQIECBAoIGAAL0BmlkIECBAgAABAgQIECBAgEDbAgL0tkUtjwABAgQIECBAgAABAgQINBD4/2ctl+Ki8VPhAAAAAElFTkSuQmCC\" width=\"500\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for net in logits_test:\n",
    "    ece, _, _, ece_p = eceloss_with_prop((logits_test[net]).softmax(dim=1), labels_test, n_bins=15)\n",
    "    uce, _, _, uce_p = uceloss_with_prop((logits_test[net]).softmax(dim=1), labels_test, n_bins=15)\n",
    "    x = (np.array(range(len(ece_p.cpu())))+1).tolist()\n",
    "    data = {\n",
    "        'bin': x*3,\n",
    "        'samples per bin in \\%': (ece_p.cpu().numpy()*100).tolist() + (uce_p.cpu().numpy()[::-1]*100).tolist() + [1/15]*15,\n",
    "        'metric': ['ECE']*15 + ['UCE']*15 + ['ACE']*15\n",
    "    }\n",
    "\n",
    "    df = pd.DataFrame(data)\n",
    "    plt.figure(figsize=(5,3))\n",
    "    sns.barplot(x='bin', y='samples per bin in \\%', hue='metric', data=df)\n",
    "    handles, labels = ax.get_legend_handles_labels()\n",
    "    ax.legend(handles=handles[1:], labels=labels[1:])\n",
    "    plt.semilogy()\n",
    "    plt.title(net)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\"prop_in_bin_\"+dataset+\"_\"+net+\".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
}
