{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import pandas as pd\n",
    "import tqdm\n",
    "import numpy as np\n",
    "\n",
    "import torch\n",
    "import torch.utils.data as data\n",
    "import torch.optim as optim\n",
    "\n",
    "from MINE import controller, datasets, losses, models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "font = {'family' : 'Georgia',\n",
    "#        'weight' : 'bold',\n",
    "        'size'   : 14}\n",
    "matplotlib.rc('font', **font)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def experiment(target_value):\n",
    "    data_loader = data.DataLoader(\n",
    "        datasets.IntegerPairDataset(\n",
    "            number_of_cases=16,\n",
    "            x_encoding='one_hot',\n",
    "            y_encoding='one_hot',\n",
    "            transform=datasets.TransformToTensor()\n",
    "        ),\n",
    "        batch_size=100,\n",
    "    )\n",
    "    loss = losses.imine_loss(target_value=target_value, regularizer_weight=0.1)\n",
    "    network = models.ConcatNet(16, 64)\n",
    "    optimizer = optim.SGD(network.parameters(), lr=0.1)\n",
    "\n",
    "    agent = controller.MINEController(\n",
    "        data_loader=data_loader, loss=loss, network=network, optimizer=optimizer\n",
    "    )\n",
    "    \n",
    "    agent.to(0)\n",
    "    agent.train()\n",
    "    for i in tqdm.tqdm(range(1500)):\n",
    "        agent.step()\n",
    "\n",
    "    return agent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1500/1500 [00:28<00:00, 52.42it/s]\n",
      "100%|██████████| 1500/1500 [00:28<00:00, 53.54it/s]\n",
      "100%|██████████| 1500/1500 [00:25<00:00, 58.23it/s]\n",
      "100%|██████████| 1500/1500 [00:26<00:00, 56.65it/s]\n",
      "100%|██████████| 1500/1500 [00:26<00:00, 57.34it/s]\n"
     ]
    }
   ],
   "source": [
    "cs = [-5, -2, 0, 2, 5]\n",
    "histories = []\n",
    "for c in cs:\n",
    "    histories.append(experiment(c).history)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_t(history, batch_size=100):\n",
    "    t = []\n",
    "    for i in range(0, len(history), batch_size):\n",
    "        t.append(np.average(history.joint_value[i:i+batch_size]))\n",
    "    return np.array(t)\n",
    "\n",
    "def get_et(history, batch_size=100):\n",
    "    et = []\n",
    "    for i in range(0, len(history), batch_size):\n",
    "        et.append(np.log(np.average(np.exp(history.marginal_value[i:i+batch_size]))))\n",
    "    return np.array(et)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "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 / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\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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378fQgg8/fTThrbLQji9sRNNerETTUawtpBerC1kBI8v0cwwLQJ6R0cHhBD46le/qvr6iRMnIITAT3/605jbcbvdcDqdodbe3g4hBOx2u2I62/RodrsdQggMDw9P9S2K4eFhvlemcUvme4Xvl+nfWFvY0vFe4ftl+rdkv1+IKDOZGtAXLVoEIYTuVlBQoLqeVAX0ZcuWGdpftunR7Ha7kbe1quCHJtv0bsl4r/D9MnMaawtbKt8rfL/MnJas9wsRZSZTA/ovfvELPProo7pbTU2N6npSdYl75Bn0oaEhNDU1YXh4OO3fmrIlvw0PD8NutyMQCBh6X6sJBAKw2+18r0zTlsz3Ct8v07+xtrCl473C98v0b8l+vxBRZpoWl7gD5gwSR0RERERERJQq0yag//CHP4QQyX3MGhEREREREVGqTJuAnp+fDyEE7rzzTng8ntD0vLw8zJo1C3fddVcK9pSIiIiIiIgoMRkb0IuKikL3pv/Hf/wHhBC4+eabQ9NeffXVqGWeeOIJCCHwuc99Dk8//TQeeeQRzJ8/H9dccw2qqqrS8FsQERERERER6ZOxAX3dunUxR7C8++67o5YJBAJ4++238fnPfx7z58/HokWL8MADD/DSdiIiIiIiIsp4GRvQiYiIiIiIiGYSBnQiIiIiIiKiDMCATkRERERERJQBGNCJiIiIiIiIMgADOhEREREREVEGYEAnIiIiIiIiygAM6EREbq10HwAAAMxJREFUREREREQZgAGdiIiIiIiIKAMwoBMRERERERFlAAZ0IiIiIiIiogzAgE5ERERERESUARjQiYiIiIiIiDIAAzoRERERERFRBmBAJyIiIiIiIsoADOhEREREREREGYABnYiIiIiIiCgDMKATERERERERZQAGdCIiIiIiIqIMwIBORERERERElAEY0ImIiIiIiIgyAAM6ERERERERUQZgQCciIiIiIiLKAAzoRERERERERBmAAZ2IiIiIiIgoAzCgExEREREREWWA/x89W+qU82+a2QAAAABJRU5ErkJggg==\" width=\"1000\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib notebook\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(10, 3))\n",
    "for i, c in enumerate(cs):\n",
    "    plt.subplot(1, 5, i+1)\n",
    "\n",
    "    t = get_t(histories[i])\n",
    "    et = get_et(histories[i])\n",
    "    mi = t-et\n",
    "\n",
    "    plt.plot(et, alpha=0.5, label='$\\log(\\mathbb{E}_{\\mathbb{P}_X \\otimes \\mathbb{P}_Y}[e^{T}])$' if i == 0 else None, c='C1')\n",
    "    plt.plot(mi, alpha=0.5, label='$\\hat{I}(X; Y)$' if i == 0 else None, c='C2')\n",
    "    plt.plot(t, alpha=0.5, label='$\\mathbb{E}_{\\mathbb{P}_{X Y}}[T]$' if i == 0 else None, c='C0')\n",
    "    plt.hlines(np.log(16), 0, 1500, label='$I(X;Y)$' if i == 0 else None, color='C2')\n",
    "    plt.hlines(c, 0, 1500, label='C' if i == 0 else None, color='C1')\n",
    "    plt.ylim(-10, 10)\n",
    "    plt.title(f'C={c}')\n",
    "\n",
    "    plt.xticks([])\n",
    "    if i != 0:\n",
    "        plt.yticks([])\n",
    "\n",
    "plt.tight_layout()\n",
    "handles, labels = plt.gcf().axes[0].get_legend_handles_labels()\n",
    "order = [2, 0, 4, 1, 3]\n",
    "plt.gcf().legend(\n",
    "    [handles[idx] for idx in order],[labels[idx] for idx in order],\n",
    "    ncol=1, loc='center', bbox_to_anchor=(0.88, 0.5)\n",
    ")\n",
    "plt.gcf().subplots_adjust(right=0.75)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.axes._subplots.AxesSubplot at 0x7fb32c634050>"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plt.gcf().axes[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "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 / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\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+gAAAEsCAYAAABQRZlvAAAgAElEQVR4nO3deXhU5f2/8ScJSSAsQRDRyKKi4MqOu0WrgqIo2qLihrWu36qoqLjVKLjUYmtbXGorFK0tWK3+XOpCrYhYK7ZWWxG0SJHgWlAILTvJ+/cHnadzJnNmTpIzZ84zc7+u61yXzpYzk0+G557VCAAAAAAA5J3J9w4AAAAAAAACHQAAAACAWCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIgaIP9M8++0y//OUvNWHCBB1yyCGqqqqSMUa9e/eOdD9eeeUV3XnnnRo7dqx23XVXGWNkjNEvfvGLQOdfvXq1rr76au2xxx5q27atunbtqpEjR+q5557L7Y4XmQ0bNujuu+/WAQccoE6dOqlt27bq27evrrrqKn355Zdpz7Ns2TI9+OCDuuiiizR06FBVVFTIGKPhw4dHuu8NDQ167rnnNHnyZJ1wwgmqqamxczZ37txAl/Hxxx/roosuUu/evVVZWakddthBJ598sv70pz9lPe+iRYt01llnqaamRhUVFdp555111llnafHixa28Zm5qzX3PmjVrdMstt2jAgAFq37692rdvr/3220+TJ0/WunXrfM/33nvv6b777tO5556r/v37q02bNjLGaPz48eFdsQC++OIL/eIXv9DYsWO12267qbKyUu3atVPfvn118cUX6/333896Ga2Zp9dff10nn3yydthhB1VWVmqXXXbRxRdfrI8//jiMqxc7zz77rL7zne/owAMP1M4776zKykpVVVWpX79+uuiiizLeZq7PWjpbt27VkCFDAv87W2yzFua66M9//rPKysrsbZ3t506cOFF77rmn2rVrp06dOmnYsGH68Y9/rC1btmT8GXfffbfOOOMM9evXTyUlJTLGqLa2ttn72xqrV6/Wo48+qquvvlpHHHGEqqurA11vSaqtrbWn9dsmTZqU8TKee+45jRw5Ul27drVrk2uuuUarV6/O+vMfeeQRHXbYYercubOqqqq077776tZbb9WGDRsCX38A4Sn6QL/77rvT3hFGHejJd+TJW5BAX758uXr27CljjMrLyzVw4EDtsssu9jJuueWW3F+BIrBq1SoNGjTI3q577LGHhg4dahcvO+20k/7xj380Od+ECRPS/m6jDvTVq1f7/sMfJND/+te/qnPnzjLGqKqqSoMHD7aRX1ZWphkzZvie97nnnlPbtm1ljFF1dbWGDBmi7bffXsYYtW3bVi+++GKI19QNLb3v+fDDD+2DeCUlJdp77701aNAg+8DPXnvtpX/9619pz3viiSem/ZlRR1OPHj3sz+7cubMGDRqkPfbYwy7kKysr9cgjj/ievzXz9POf/1ylpaUyxmj77bfXkCFD1KlTJxljtN122+mdd97JxVXOqyOPPFLGGLVp00Y9e/bU0KFD1adPHxvN5eXl+tWvftXkfIUwa+ncfvvtgf+dLcZZC2tdtHnzZu23336ey/CzYMECe7u2adNGAwYM0H777Wdvv8MOO8z3AaEBAwak3d+oA/3JJ5/0/Tc2m0Sg77DDDjrkkEPSbvfff7/v+W+66Sb7s2pqajR48GC1a9dOxhj16tVLK1asSHu+xsZGjR8/3p53l1120cCBA1VeXi5jjAYNGqT6+voW3yYAWqboA3369Ok68sgjNWnSJP3mN7/Rj370o7wE+kEHHaSzzjpLP/rRj/Taa6+pX79+gQP9gAMOkDFGAwYMUF1dnT38scces3eyxRhAYTvuuOPsP6DJzxivXbtWp512ml2wpj7SP2XKFI0aNUrf/e539dRTT+maa67JS6DX19dr4MCB+va3v637779fb775pn1wIVugb9iwQb169ZIxRkcddZR9tUBjY6N+8pOf2EXVe++91+S8n3/+uTp27ChjjM4880y7yNq8ebO9Laqrq30X+oWqJfc9DQ0N6t+/v4wx6tu3r+cZvC+++EJHHHGE/R2lc/HFF2vMmDG69dZb9fzzz+uss87KSzT16dNHF154oRYsWKCGhgZ7+PLly21MlpeXhz5Pf//73+2DAJMmTdLmzZslSevWrdMZZ5whY4x23XVXbdy4MUfXPD8efvhhzZkzR+vXr/cc/vHHH+ukk06ysZn870ehzFqqxYsXq7KyUkOHDrUPFPn9O1ussxbWuigRjSeffHLGUF27dq123HFHGWN00EEHeV5dsHTp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/g4Sm99X6yQ0N5qeeeYZjRkzRt27d7ffB33iiSfqnnvu0QcffOA57YoVK3TVVVdpxIgRgS5bkm688UYZs+0rvV544YUmx7dmniZPnixjjHr27Ol7voaGhkB/w6569dVXdcghh+iggw5S7969VVZWppKSEg0fPrzJg2+FMmvLly9Xx44dteOOOzaJqkyBzqz9T9B1UeI9/hdeeKHn8GyBvnLlSvv1c/vvv7+WLVtmj1u0aJFdDyWeBc6mOYG+detW/epXv9LIkSPVpUsXVVRUqHfv3jrttNM0ffr0Ju/Nfv/993Xeeefp3HPPzXrZzQn0TGbNmmUv5/XXX/ccd+6558qYbV9D5yf5VXDJf6eJT7s/66yzfM+beCVJkNsdQHgI9BRB/yGaOnWqSkpK7GmHDRumnXfe2bNg6dixowYMGKD+/fvbl8Htu+++gfaDZ9Dj56OPPrKfvGvMtu8a3Xfffe3vNvFBLMYY/e1vf/O9nOYE+qWXXmovc4899tCQIUO0ww47eOasS5cuGjx4sPbee2/7LMPo0aMDXSeeQY+PoPc9b731lv2+4JKSEu2yyy7aa6+9bGydc8459jbP9v21zYmmxDPbpaWl2muvvTR48GB16dLFM4vdu3fX0KFDtccee9jDLrnkkkDXP/F1fcYY3XPPPWlPw7Oa4fr000/tAr9Tp0766KOPPMcXwqyNHDlSxhg99thjTY7jGfRggtw3Jd7jX1NTozVr1niOyxbokvT888/br/0sLS1V37591adPH5WUlKhNmzY688wzZcy274/PpjmBnvgKt4qKCu23334aMGCA/dTzxNajRw8NGzbMPmBVUlKiqVOnZr3ssAJdkvbff38ZY3TllVd6DucZdKAwEegpgi6Szz33XJ133nlNHslfvny5HnzwQZ122mnq3bu3KioqtN122+nII4/Uww8/7HlWPZPmvgc93Vd/JfAe9PCsXr1aN910k/bbbz+1a9dOHTp00CGHHKLf/OY3npfBf/HFF76X0ZxAHzlypK6++uomz069//77mjZtmk488UTV1NSovLxc3bp10+jRo/XUU08Fvj5BAv3DDz+01+u1117zPV2696C/9NJL9rzJ322bjPegb9OcV+988sknuuKKK9S3b19VVlaqurpaI0aM0EsvvWRfmty+fXvf978mNCea+vfvr9tvv93zFWmNjY165513NHXqVI0cOVLdu3dXeXm5ampqdOqpp+qVV17JermS9POf/9w+4Jn8AE+q1szTgw8+aBfihfC+4DAlPoDr/PPPb3Kcy7OWeP/sCSeckPbnZAp0Zu1/gtw3JdYZTz75ZJPjggS6JP3jH//Qeeedp1122UUVFRXq2rWrxowZo7feesu+DH7vvffOur/NCfTu3bvr3nvv1b///W972NatW/XGG29o8uTJGj58uLp27ary8nL17t1b3/rWt/T2229nvVwp3EC/4oor0j74nnjV0e677+57Xr/3oCce9DjqqKN8z8t70IH8INBTBF0kN+d9lS3R3E9xv/nmm31Pw6e4RyPxVWxBXn0RNNBzPWfN/RT3mTNnpj1NkE9x94s1PsV9m7A+/yLx9VhB5qs50ZSrWXzooYfsA4133nlnxtO2Zp6SP1k79ZniBJc+WTtM06ZNkzFGgwYNatb54j5rEyZMkDFG1dXV6t69e5MtMXedOnVS9+7dPV+Ryaz9T5D7purqavuqgdRtu+2287zyoXv37vrZz37WrH1IfBVbkPlpTqDn8t/YMAM98beW+tWTYXyK+y677OL7c/kUdyA/CPQULn2Ku/S/R0C//vWvpz2e70GPzuGHHy5jjCZMmJDxdK59irskHXrooTLG+L7vLsj3oE+ePDnteRPfJVzsj9CHcd/T0NCg3XbbTcY0/QT0dPL9Ke6/+tWvbCTddtttgc7T0nlK/m7qhx9+OO15E99N/bWvfa15V8Rxd999t4wx6t+/f+DzuDBriUAPug0YMMBzfmZtm+YEetAtyMwk/Pvf/7YfSJjuGfpULn6KezajRo1K+yqX5Fe4JX8wX7LE2+/OPvtsz+HJrxLJ9j3ovAITiBaBnsK1QH/66adlzLb3bKV7f/B1110nY4yGDRuWoz2FtO0DjRKPYi9ZsiTjaV0M9MT7gzt27Oh52WnCuHHjZIzR2LFjmxx35ZVXyphtnxad+hV1jY2NOvjgg2WM0dVXX92q6+K6MO57Es+Edu3aNdAzQ/kM9EcffdR+OnHyBwtm05p5SnyYY7qvc9q4caP9jIl77723+VfIUY2NjfYBuObMgUuz5ifTS9wlZi2htfdNQV/i7mfixIkyxqhv376B3iZYaIH+9ttv2/vKxx9/vMnxgwcPljFNvypR2vZZRYn31P/ud7/zHLdlyxb7mTbXX399k/MuXrzYPoC6cOHCVl0HAM1DoKdwLdAbGxs1dOhQ++h/8qOgjz32mMrLy2VM5g+RQzBvvvmmnn76ac/LyLZs2aKZM2fa0M32El3JzUBP/hq5o446yn7QTGNjo433Nm3a6N13321y3uSvYzrzzDPtM+ybN2/WNddcI2O2vcQ00/v2i0HQ+57f//73+sMf/uB5b+uGDRs0depUu4ibPXt2oJ+Zr2j6f//v/6lNmzYyxuiWW25p1nlbM0/vvPOOvY0mTZpk/5bXrVtnX43Uu3fvJjHmsj//+c+64YYb9P777zc5bvny5fbBtbKyMv31r3/1HF8Is5ZJtkBn1raJItCfeOIJLViwwHPYmjVrdPXVV8sYo/Ly8oyfgZLMtUBfuHChzj///CZ/f5L07LPPascdd5Qx296Cku7tEIknCIwxmjZtmv17/fLLL+1nAxx44IFpf3bigbaKigpP/NfV1al///4yJvOHyAHIjaIP9Lq6OnXt2tVuiUcaS0tLPYcH/STilrrkkks8Py/xD3uHDh08h6d7GdKyZcvsJ8iXl5dr4MCB9n3nvDQpPL/4xS9kzLaXce+5554aMmSIfVlfaWmp7+382muveX6HiU+qbdOmjefwIHHfWieccILnZyZmpFOnTp7D0/nzn/9sr29VVZUGDx6smpoae/0ffPBB35/7zDPP2PexV1dXa8iQIfbToSsrK/Xcc8/l6irHVkvve2pra+19w7777quBAwfamaqoqNADDzzg+zNnzZrluezEy3ArKys9h8+aNSun1z3xeQWVlZU65JBDfDe/+93WzNNPf/pT+6zQ9ttvryFDhtiveOrcuXPaRbLLkuOoa9euGjRokA444ADtuuuu9oP52rdvnza0C2HWMskW6FJxzlrY66IggT5+/Hh7uwwcONDz7TcdO3bU008/7XveO++807NfiScm2rVr5zk8aOC3RvLPS37Zf/LhqR9a+Pbbb9vTde7cWYMGDdL+++9vvyHAmG1vP8n0VYbXX3+9PW1NTY0GDx6sdu3ayZhtX/e3fPnytOdrbGy0DxglXi0ycOBAexv2798/55+FA6Cpog/0ZcuW2TumTFuuH/VP/OOUbUv+ftBkX375pa666irtvvvuqqysVJcuXTRixIgmL2lCyy1evFgXXHCB9tlnH1VXV6uyslK9e/fWOeeco7/85S++50tenGTaoni0f/jw4YH2xU9dXZ0uvPBC9erVSxUVFerWrZvGjBnT5LtZ03nvvfd0xhlnaKeddlJ5ebl22mknnXHGGVq0aFGYV9EZLb3v+dOf/qSzzz5bffv2VYcOHdSuXTvtscce+s53vqN//OMfGX9m4kGmbFu2V+60VpB9MCbzq0xaM09//OMfNWbMGHXr1k0VFRXq1auXLrrooqzf5e2ir776StOmTdM3vvEN9e3bV9XV1WrTpo26dOmiAw88UDfeeKPv9S6EWcskSKBLxTdrYa+Lgn7N2imnnKLddttNVVVVat++vfbZZx9dc801+vTTTzNefuKBpGxbtleKhaEl92urV6/WrbfequOPP159+vRRp06d7DezHHXUUXrggQcCvdLi2Wef1dFHH60uXbqosrJSu+++u6666ip99dVXWc/78MMP69BDD1V1dbXatWunffbZR1OmTMn4FYMAcqfoAx0AAAAAgDgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBiIJNAbGhq0YsUKrVmzRvX19Wxsqq+v15o1a7RixQo1NDQwa2w53Zg1tqg2Zo0tqo1ZY4tqy8WsAfAXSaCvWLFCxhg2trTbihUrmDW2SDZmjS2qjVlji2pj1tii2sKcNQD+Ign0NWvW2D/sfD8KmPfty5X66qnv6vfTLtH3fvuGVn65OvSfseqrVbpr/l26a/5dWvXVqvxfZ58tsRBYs2YNs5aDOat/5ibVP3OTVv7rC93+5Fu6/cm3Qp03V+aMWcvtfNV/uTLw+VZ+ubpFs8isOTxrLZyVfGwrv1ytKU+8oVMevl53zpvKrDEXOd1WfbVKd86bqlMevl5TnsjNejDOswbAXySBXl9fL2OM6uvro/hx8bZlk7a+dJtef3CifvTCQm3aEv7LhTZv3ax7375X9759rzZv3Rz65YclF3PBrP3Xlk3Sy7dLL9+uTRs36IdzPtAP53wQ6ry5MmcSsxa6pPnSlk2Bz7ZpS0OLZpFZc3jWWjgr+bBpS4OmvrhQZz4+WT956x5mLZccmotc2bx1s37y1j068/HJmvpibtaDYXH6PghwEIEeNQLdcnpxEXcEugezFjIC3RezlsKhECPQCfQoEegA/BDoUSPQLacXF3FHoHswayEj0H0xaykcCjECnUCPEoEOwA+BHjUC3XJ6cRF3BLoHsxYyAt0Xs5bCoRAj0An0KBHoAPwQ6FEj0C2nFxdxR6B7MGshI9B9MWspHAoxAp1AjxKBDsAPgR41At1yenERdwS6B7MWMgLdF7OWwqEQI9AJ9CgR6AD8EOhRI9AtpxcXcUegezBrISPQfTFrKRwKMQKdQI8SgQ7AD4EeNQLdcnpxEXcEugezFjIC3RezlsKhECPQCfQoEegA/BDoUUsE+l1j9aMHHiDQXV1cxN2WTdKMY6UZxxLoYtZCl1hczzhWemlK4LMR6PG5zMikhljiv2OIQM9zoMd4NnKBQAfgh0CPGoFuOb24iDsC3YNZCxmB7otZS0Gg54zTs0agE+gAfBHoUSPQLacXF3FHoHswayEj0H0xaykI9JxxetYIdAIdgC8CPWoEuuX04iLuCHQPZi1kBLovZi0FgZ4zTs8agU6gA/BFoEeNQLecXlzEHYHuwayFjED3xaylINBzxulZI9AJdAC+CPSoEeiW04uLuCPQPZi1kBHovpi1FAR6zjg9awQ6gQ7AF4EeNQLdcnpxEXcEugezFjIC3RezloJAzxmnZ41AJ9AB+CLQo0agW04vLuKOQPdg1kJGoPti1lIQ6Dnj9KwR6AQ6AF8EetQIdMvpxUXcEegezFrICHRfzFoKAj1nnJ41Ap1AB+CLQI8agW45vbiIOwLdg1kLGYHui1lLQaDnjNOzRqAT6AB8EehRI9AtpxcXcUegezBrISPQfTFrKQj0nHF61gh0Ah2ALwI9agS65fTiIu4IdA9mLWQEui9mLQWBnjNOzxqBTqAD8EWgR41At5xeXMQdge7BrIWMQPfFrKUg0HPG6Vkj0Al0AL4I9KgR6JbTi4u4I9A9mLWQEei+mLUUBHrOOD1rBDqBDsAXgR41At1yenERdwS6B7MWMgLdF7OWgkDPGadnjUAn0AH4ItCjRqBbTi8u4o5A92DWQkag+2LWUhDoOeP0rBHoBDoAXwR61Ah0y+nFRdwR6B7MWsgIdF/MWgoCPWecnjUCnUAH4ItAjxqBbjm9uIg7At2DWQsZge6LWUtBoOeM07NGoBPoAHwR6FEj0C2nFxdxR6B7MGshI9B9MWspCPSccXrWCHQCHYAvAj1qBLrl9OIi7gh0D2YtZAS6L2YtBYGeM07PGoFOoAPwRaBHjUC3nF5cxB2B7sGshYxA98WspSDQc8bpWSPQCXQAvgj0qBHoltOLi7gj0D2YtZAR6L6YtRQEes44PWsEOoEOwBeBHjUC3XJ6cRF3BLoHsxYyAt0Xs5YidVZiHGEEOoEeJQIdgB8CPWoEuuX04iLuCHQPZi1kBLovZi0FgZ4zTs8agU6gA/BFoEeNQLecXlzEHYHuwayFjED3xaylINBzxulZI9AJdAC+CG0EuEMAACAASURBVPSoEeiW04uLuCPQPZi1kBHovpi1FAR6zjg9awQ6gQ7AF4EeNQLdcnpxEXcEugezFjIC3RezluKlKfa+iEAPl9OzRqAT6AB8EehRI9AtpxcXcUegezBrISPQfTFrKQj0nHF61gh0Ah2ALwI9agS65fTiIu4IdA9mLWQEui9mLQWBnjNOzxqBTqAD8EWgR41At5xeXMQdge7BrIWMQPfFrKUg0HPGuVlL/r0T6AQ6AF8EetQIdMu5xYVLCHQPZi1kBLovZi0FgZ4zzs0age5BoAPwQ6BHjUC3nFtcuIRA92DWQkag+2LWUhDoOePcrBHoHgQ6AD8EetQIdMu5xYVLCHQPZi1kBLovZi0FgZ4zzs0age5BoAPwQ6BHjUC3nFtcuIRA92DWQkag+2LWUhDoOePcrBHoHgQ6AD8EetQIdMu5xYVLCHQPZi1kBLovZi0FgZ4zzs0age5BoAPwQ6BHjUC3nFtcuIRA92DWQkag+2LWUhDoOePcrBHoHgQ6AD8EetQIdMu5xYVLCHQPZi1kBLovZi0FgZ4zzs0age5BoAPwQ6BHjUC3nFtcuIRA92DWQkag+2LWUhDoOePcrBHoHgQ6AD8EetQIdMu5xYVLCHQPZi1kSfNFoHsxaykI9JxxbtYIdA8CHYAfAj1qBLrl3OLCJQS6B7MWMgLdF7OWgkDPGedmjUD3KOZA37x5szZs2MDGVlDb5s3h/ZtBoEeNQLecW1y4hED3YNZCRqD7YtZSEOg549ysEegexRjo9fX1Wrp0qRYtWsTGVpDb0qVLQ7n/JNCjRqBbzi0uXEKgezBrISPQfTFrKQj0nHFu1gh0j2IL9Pr6ei1atEh1dXWqr6/X+vXr8/6MJxtbWNv69etVX1+vuro6LVq0qNX3oQR61Ah0y7nFhUsIdA9mLWQEui9mLcnLtxPoOeTcrBHoHsUW6EuXLlVdXZ0aGxtD3DMgXhobG1VXV6elS5e26nII9KgR6JZziwuXEOgezFrICHRfzFoSAj2nnJs1At2jmAJ98+bNoTyrCLgg8WqR1rwnnUCPGoFuObe4cAmB7sGshYxA98WsJSHQc8q5WSPQPYop0Dds2KBFixZp/fr1Ie8ZED/r16/XokWLtGHDhhZfBoEeNQLdcm5x4RIC3YNZCxmB7otZS0Kg55Rzs0agexRjoLcmWABXhDHvBHrUCHTLucWFSwh0D2YtZAS6L2YtCYGeU87MWuJ3nrwR6AQ6UKAIdBcR6JYziwsXEegezFrICHRfzFoSAj2nnJk1Aj0tAh0oTAS6iwh0y5nFhYsIdA9mLWQEui9mLQmBnlPOzBqBnhaBDhQmAt1FBLrlzOLCRQS6B7MWMgLdF7OWhEDPKWdmjUBPi0AHChOB7iIC3XJmceEiAt2DWQsZge6LWUtCoOeUM7NGoKdFoBe3O++8U8YYPffcc1lP29DQoP79++vYY48NfT+WLVsmY4zGjx8f+mUnW7JkicrKynTvvffm9OfEAYHuIgLdcmZx4SIC3YNZCxmB7otZS0Kg55Qzs0agp0WgF7exY8fKGKMvvvgi62mnT58uY4wWLFjQ5DhjjPr169fi/Qgr0OfOnStjjGpra31Pc/bZZ6tbt27u/VvWTAS6iwh0y5nFhYsIdA9mLWQEui9mLQmBnlPOzBqBnhaBXtw++ugjffDBB1lPt3XrVvXq1UvDhw9Pe3xrA33z5s1avHixPv300xZfhhQs0N99910ZYzRlSvB1g4sIdBcR6JYziwsXEegezFrICHRfzFoSAj2nnJk1Aj0tAh1BPP300zLG6MEHH0x7fGsDPSxBAl2SBgwYoF69eqmhIb7z3loEuosIdMuZxYWLCHQPZi1kqYEecGFNoMfnMiNBoOeUM7NGoKdFoBevOXPmyBij733ve1lPe/LJJ6ukpESrV69Oe3ymQJ85c6YOOOAAtW/fXu3bt9cBBxygmTNnek7j9xL35OB+6623NGLECHXo0EGdOnXSmDFjtGzZMnva2tpaGWPSbsmnk6TbbrtNxhjNmTMn63V3FYHuIgLdcmZx4SIC3YNZCxmB7otZS0Kg55QzsxYk0NOdpsAR6MXr+9//vowxeuGFFzKerrGxUV26dNFee+3lexq/QL/88stljNHOO++syy67TBMmTFCPHj1kjNEVV1xhT5ct0I877jhVVVVp1KhRmjhxor7+9a/LGKM+ffrY3+fcuXM1fvx4GWM0fPhw1dbW2i31gYWXX35Zxhhde+212W4mZxHoLiLQLWcWFy4i0D2YtZAR6L6YtSQEek45M2sEeloE+jaNjY3atKUh9ltjY2Nrb0Zr3LhxgT4g7r333pMxRmeccYbvadIF+quvvipjjPbaay+tWbPGHr5mzRrtueeeMsZo/vz5krIHujFGs2fP9hx31llnyRijWbNmNTl9tpe4r127VsYYfe1rX8t4OpcR6C4i0C1nFhcuItA9mLWQEei+mLUkBHpOOTNr6eI7MRcEetEHevK/C3Hewvz97Lnnntppp52ynu7FF1+UMUZXXnml72nSBfq5554rY4weffTRJqefNWuWjDH69re/LSl7oKcL6cRxyfsVNNAlqW3bttptt92yns5VBLqLCHTLmcWFiwh0D2YtZAS6L2YtCYGeU87MGoGeFoG+TbEF+rp161RaWqpRo0ZlPe2vf/3rrJ96ni7QBw0a5PsM/WeffSZjjIYMGSIpe6BffvnlTS5jyZIlMsbo3HPPbXL6IIFeU1OjTp06ZT2dqwh0FxHoljOLCxcR6B7MWsgIdF/MWhICPaecmTUCPS0CfZtie4n766+/LmOMrr/++qynffLJJ7OeNl2g9+nTR6WlpWn3ubGxUaWlpdp9990lBfuQuFTpztOcQN9uu+204447Zj2dqwh0FxHoljOLCxcR6B7MWsgIdF/MWhICPaecmTUCPS0CvTjdd999Msbosccey3ra1157TcYYXXTRRb6nae4z6J9//rmMMRo8eLCk6AO9oaFBpaWl2m+//TKezmUEuosIdMuZxYWLCHQPZi1kBLovZi0JgZ5TzswagZ4WgV6czj//fBljtGTJkqynXb16tUpLS3XkkUf6nqa570F/9NFHPS9PDyvQEx9Md+ONN2a8Tu+//76MMTr99NMzns5lBLqLCHTLmcWFiwh0D2YtZAS6L2YtCYGeU87MGoGeFoFenIYOHaqOHTsGfsn8wIEDVV1d7Xv6dIE+b948GWO09957e35n9fX12nvvvWWM0bx58ySFF+gLFy6UMUbnnHNOxuvz0EMPyRijBx54IOPpXEagu4hAt5xZXLiIQPdg1kJGoPti1pIQ6DnlzKwR6GkR6MVny5Ytatu2rQ499NDA57n55ptljNGCBQvSHp8u0CXp0ksvlTFGPXv21OWXX64JEyaoZ8+eMsbosssus6cLK9C3bt2qmpoatW3bVv/3f/+n22+/XXfccYfna94k6cwzz1RZWZk++eSTwLeBawh0FxHoljOLCxcR6B7MWsgIdF/MWhICPaecmTUCPS0Cvfj8/e9/lzFGl1xySeDzfPzxxyorK9Oll17a5LitW7fKGOP7fu4ZM2Zo2LBhqqqqUlVVlYYNG6YZM2Z4ThNWoEvSG2+8oeHDh6tjx44yZtt3qC9btswev27dOnXo0EFjxowJdN1dRaC7iEC3nFlcuIhA92DWQkag+2LWkhDoOeXMrBHoaRHoxWfGjBkyxmjmzJnNOt+4cePUtWtX/ec///EcnvjKtCOOOCLM3cyZ6dOne15eX6gIdBcR6JYziwsXEegezFrICHRfzFoSAj2nnJk1Aj0tAr34HH/88U2eVQ7in//8pyorK3XnnXd6Dv/pT38qY4yuvfbaEPcyN7Zs2aI+ffrohBNOyPeu5ByB7iIC3XJmceEiAt2DWQsZge6LWUtCoOeUM7NGoKdFoBePyZMna/To0TLGaNSoUS26jNmzZ+uee+6RJN12220aN26cysrK1L59+2YHfz4sW7ZMtbW1+vDDD/O9KzlHoLuIQLecWVy4iED3YNZCRqD7YtaSEOg55cysEehpEejF4fPPP1dZWZl69Oihyy67LJS/rc6dO6tjx44aMWKE3nzzzRD2EmEi0F1EoFvOLC5cRKB7MGshI9B9MWtJCPSccmbWCPS0CHSgMBHoLiLQLWcWFy4i0D2YtZAR6L6YNaUPMQI9dM7MGoGeFoEOFCYC3UUEuuXM4sJFBLoHsxYyAt0XsyYCPSLOzBqBnhaBDhQmAt1FBLrlzOLCRQS6B7MWMgLdF7MmAj0izswagZ4WgQ4UJgLdRQS65cziwkUEugezFjIC3RezJgI9Is7MGoGeFoEOFCYC3UUEuuXM4sJFBLoHsxYyAt0XsyYCPSLOzBqBnhaBDhQmAt1FBLrlzOLCRQS6B7MWMgLdF7MmAj0izswagZ4WgQ4UJgLdRQS65cziwkUEugezFjIC3RezJgI9Is7MGoGeFoEOFCYC3UUEuuXM4sJFBLoHsxYyAt0XsyYCPSLOzBqBnhaBDhQmAt1FBLrlzOLCRQS6B7MWMgLdF7MmAj0izsxapkBPnQsCPZYIdCA4At1FBLrlzOLCRQS6B7MWMgLdF7MmAj0izswagZ4WgQ4UJgLdRQS65cziwkUEugezFjIC3RezJgI9Is7MWksDPcazEgYCHShMBLqLCHTLmcWFiwh0D2YtZAS6L2ZNBHpEnJk1Aj0tAh0oTAS6iwh0y5nFhYsIdA9mLWQEui9mTQR6RJyZNQI9LQIdKEwEuosIdMuZxYWLCHQPZi1kBLovZk0EekScmTUCPS0CvfgYY3w3FA4C3UUEuuXM4sJFBLoHsxYyAt0XsyYCPSLOzBqBnhaBDhQmAt1FBLrlzOLCRQS6B7MWMgLdF7MmAj0izswagZ4WgQ4UJgLdRQS65cziwkUEugezFjIC3RezJgI9Is7MGoGeFoGOoBoaGtS/f38de+yx+d6VUCxbtkzGGI0fPz6vl5HNkiVLVFZWpnvvvbdZ5yPQXUSgW84sLlxEoHswayEj0H0xayLQI+LMrBHoaRHoxe3OO++UMUbPPfdc1tNOnz5dxhgtWLDAc3giUo0xOu6449Ked+7cuTLG6MILLwxlv8MQp0BP3D61tbVpjz/77LPVrVu3Zs0+ge4iAt1yZnHhIgLdg1kLGYHui1kTgR4RZ2aNQE+LQC9uY8eOlTFGX3zxRcbTbd26Vb169dLw4cObHJcc6MYYzZs3r8lp4hjomzdv1uLFi/Xpp5/m9TKk7IH+7rvvyhijKVOmBL5MAt1FBLrlzOLCRQS6B7MWMgLdF7Om5gV6jAKMQCfQo0SgF7ePPvpIH3zwQdbTPf300zLG6MEHH2xyXCLQd9llF5WWlurAAw9scpo4BnqcZAt0SRowYIB69eqlhoZgf6MEuosIdMuZxYWLCHQPZi1kBLovZk3ND7GYINAJ9CgR6Aji5JNPVklJiVavXt3kuESgjxw5UuPHj5cxRr/97W89p8kU6DNnztQBBxyg9u3bq3379jrggAM0c+bMJqdLjti33npLI0aMUIcOHdSpUyeNGTNGy5Yta9Z1yvTy9KD7lO4ymruftbW1vl97l3za2267TcYYzZkzJ9D1I9BdRKBbziwuXESgezBrISPQfTFrItAj4sysEehpEejFa86cOTLG6Hvf+17G0zU2NqpLly7aa6+90h6fHOjLly9XZWWl+vXrp61bt9rT+AX65ZdfLmOMdt55Z1122WWaMGGCevToIWOMrrjiCs9pE5dx3HHHqaqqSqNGjdLEiRP19a9/XcYY9enTp1m/W79Ab84+ZQr0oPs5d+5c+8DG8OHDVVtba7fkB0RefvllGWN07bXXBrp+BLqLCHTLmcWFiwh0D2YtZAS6L2ZNBHpEnJk1Aj0tAr14ff/735cxRi+88ELG07333nsyxuiMM85Ie3xyoEvSlVdeKWOMHnjgAXuadIH+6quvyhijvfbaS2vWrLGHr1mzRnvuuaeMMZo/f36TyzDGaPbs2Z59OOuss2SM0axZswJf/3Rx3dx9yhTozdnPIC9xX7t2rYwx+trXvhbo+hHoLiLQLWcWFy5KDvQ5t+qHP5tOoDNr4SHQfTFrItAj4sysEehpEejFa9y4cYE+IO7FF1+UMUZXXnll2uNTA/3LL79UdXW1ampqtG7dOknpA/3cc8+VMUaPPvpok8ucNWuWjDH69re/bQ9LXEa6QE0c57ePmfY7Oa6bu0+ZAr05+xkk0CWpbdu22m233QJdPwLdRQS65cziwkUEugezFjIC3RezJgI9Is7MGoGeFoH+X42N2/5NifvW2NjKW/F/9txzT+20005ZT/frX/864yeIpwa6JN1+++0yxui2226TlD7QBw0a5PsAwWeffSZjjIYMGWIPS1zG5Zdf3uT0S5YskTFG5557rufw5JeLp75sPF1cN3efMgV6c/YzaKDX1NSoU6dOGU+TQKC7iEC3nFlcuIhA92DWQkag+2LWRKBHxJlZI9DTItD/a8umzL//uGxbNrXyVtxm3bp1Ki0t1ahRo7Ke9sknn5QxRtdff33a49MF+vr161VTU6Pq6mqtWrUqbaD36dNHpaWlakzzoENjY6NKS0u1++6728MyRazf+8kzffBauvM0d5+yfUhc0P0MGujbbbeddtxxx4ynSSDQXUSgW84sLlxEoHswayEj0H0xayLQI+LMrBHoaRHo/1Vkgf76669njO5kr732mowxuuiii9Ieny7QJelnP/uZfTl3c59B//zzz2WM0eDBg+1hLQnfTJr7DHq6fYoy0BsaGlRaWqr99tsv0PUj0F1EoFvOLC5cRKB7MGshyrS4zoJAj89l5hSBHglnZo1AT4tA/68ie4n7fffdJ2OMHnvssaynXb16tUpLS3XkkUemPd4v0Ldu3ao999xTlZWVeuihh5r1HvRHH320yUvBowj05u5TWIGe+HC6G2+80Xd/33//fRljdPrppwe6fgS6iwh0y5nFhYsIdA9mLUQEekbMmgj0iDgzawR6WgR6cTr//PNljNGSJUsCnX7gwIGqrq5O+9Jvv0CXpCeeeELGbPtqsdRAnzdvnowx2nvvvT2/0/r6eu29994yxmjevHn28CgCvbn7FFagL1y4UMYYnXPOOb77m3iQI/nT8TMh0F1EoFvOLC5cRKB7MGshItAzYtZEoEfEmVkj0NMi0IvT0KFD1bFjx7TBnc7NN98sY4wWLFjQ5LhMgS5JBx10kH3/d+r3oF966aUyxqhnz566/PLLNWHCBPXs2VPGGF122WWe00YR6M3dp7ACfevWraqpqVHbtm31f//3f7r99tt1xx13eL7q7cwzz1RZWZk++eSTQNePQHcRgW45s7hwEYHuwayFiEDPiFkTgR4RZ2aNQE+LQC8+W7ZsUdu2bXXooYcGPs/HH3+ssrIyXXrppU2OyxboiZdvpwt0SZoxY4aGDRumqqoqVVVVadiwYZoxY0aT00UV6M3Zp7ACXZLeeOMNDR8+XB07dmzygXbr1q1Thw4dNGbMmMDXj0B3EYFuObO4cBGB7sGshYhAz4hZE4EeEWdmrbWBHrM5CQuBXnz+/ve/yxijSy65pFnnGzdunLp27ar//Oc/OdqzaC1evFjGGF1wwQX53pWspk+f3uTl9dkQ6C4i0C1nFhcuItA9mLUQEegZMWsi0CPizKwR6GkR6MVnxowZMsZo5syZzTrfP//5T1VWVurOO+/M0Z5F65lnnpExRpMnT873rmS0ZcsW9enTRyeccEKzzkegu4hAt5xZXLiIQPdg1kJEoGfErIlAj4gzs0agp0WgF5/jjz/e8/Lp5pg9e7buueee8HcqQh988IEmTZqknj17qrS0VH/729/yvUsZLVu2TLW1tfrwww+bdT4C3UUEuuXM4sJFBLoHsxYiAj0jZk0EekScmTUCPS0CvXhMnjxZo0ePljFGo0aNyvfu5M2TTz6ptm3bqn///nryySfzvTs5Q6C7iEC3nFlcuIhA92DWQkSgZ8SsiUCPiDOzRqCnRaAXh88//1xlZWXq0aOHLrvsMnfux9FiBLqLCHTLmcWFiwh0D2YtRAR6RkU5a6m/fwI9Es7MGoGeFoEOFCYC3UUEuuXM4sJFBLoHsxYiAj2jopw1Aj0vnJk1Aj0tAh0oTAS6iwh0y5nFhYsIdA9mLUQEekZFOWsEel44M2sEeloEOlCYCHQXEeiWM4sLFxHoHsxaiAj0jIpy1gj0vHBm1gj0tAh0oDAR6C4i0C1nFhcuItA9mLUQEegZFeWsEeh54cysEehpEehAYSLQXUSgW84sLlxEoHswayEi0DMqylkj0PPCmVkj0NMi0IHCRKC7iEC3nFlcuIhA92DWQkSgZ1SUs0ag54Uzs0agp0WgA4WJQHcRgW45s7hwEYHuwayFiEDPqChnjUDPC2dmjUBPi0AHChOB7iIC3XJmceEiAt2DWQsRgZ5RUc4agZ4XzswagZ4WgQ4UJgLdRQS65cziwkUEugezFiICPaOinDUCPS+cmTUCPS0CHShMBLqLCHTLmcWFiwh0D2YtRAR6RkU5awR6XjgzawR6WgQ6UJgIdBcR6JYziwsXEegezFqICPSMinLWCPS8cGbWCPS0CHSgMBHoLiLQLWcWFy4i0D2YtRAR6BkV5awR6HnhzKwR6GkR6EBhItBdRKBbziwuXESgezBrISLQMyrKWSPQ88KZWSPQ0yLQkUltba2MMZo7d25kP3Pu3Lkyxqi2tjayn1mICHQXEeiWM4sLFxHoHsxaiAj0jIpy1gj0vHBm1gj0tAj04rFs2TIZYzRy5MjA53Eh0MePHy9jjIwxuv/++31Pd9JJJ9nTzZo1y3Nc7969VVlZ2Zrdjh0C3UUEuuXM4sJFBLoHsxYiAj2jopw1Aj0vnJk1Aj0tAr14FHqgt2nTRsOGDUt7mn/9618qLy9XmzZtCPRmINCjRqBbziwuXESgezBrISLQMyrKWWttoMckwAj0kC8z0++aQCfQi0ihB/ro0aNljNG7777b5DQ/+MEPZIzRCSecQKA3A4EeNQLdiv3iwmUEugezFiICPaOinDUCPS9iP2sEekYEevHIFOh1dXU67bTTtN1226l9+/b62te+pnnz5mUM9Hnz5un4449X165dVVFRod1331033HCD1q1b5zndpk2b9JOf/EQjRoxQjx49VFFRoW7duumkk07SX//61yaX29JAf/zxx1VaWqorrriiyWn23XdfDRgwwF4fAj0YAj1qBLoV+8WFywh0D2YtRAR6RkU5awR6XsR+1sIO9BjMSJgI9OLhF+iffvqpdt55Z3vcddddpzFjxqiiokIjR45MG+j333+/SkpK1KVLF40fP15XXXWVhg8fLmOMDj74YG3atMme9rPPPlNpaamGDx+uCy64QJMmTdLYsWNVWVmptm3b6s033/RcdksD/U9/+pOOOeYYdevWTZs3/+9+c8GCBTLG6Mc//jGB3kwEetQIdCv2iwuXEegezFqICPSMinLWCPS8iP2sEegZEejbNDY2avPWzbHfGhsbW3z7+QV6InBvvfVWz+EPPPCA/VC15EB/77331KZNGw0aNEhffvml5zx33HGHjDG666677GEbN27Uxx9/3GR/Fi5cqA4dOuioo47yHN6aQP/Nb34jY4yeeOIJe/wFF1ygiooKrVq1ikBvJgI9agS6FfvFhcsIdA9mLUQEekZFOWsEel7EftYI9IwI9G2S79/jvLXm/iBdoG/atElt27bVDjvs0OR2aWhoUN++fZsE+mWXXSZjjObPn9/kZzQ0NKhbt24aMmRIoH0aPXq0KioqPM94tybQN23apK5du+r444+XJK1fv17V1dUaO3asJBHozUSgR41At2K/uHAZge7BrIWIQM+oKGeNQM+L2M8agZ4Rgb5NsQb63//+dxljNGrUqLTnOeecc5oE+v777y9jjG644QbV1tY22WpqatS+fXvP5bz99tsaN26cevbsqfLycvvMfGL79NNP7WlbE+jStgcQysrK9Omnn+rhhx+WMUbPP/+8JAK9uQj0qBHoVuwXFy4j0D2YtRAR6BkV5awR6HkR+1kj0DMi0Lcp1pe4z58/X8YYnXPOOWnPM2nSpCaBvvvuuzcJ7HRbwh//+EdVVlaqsrJSo0eP1pVXXqmbbrpJtbW1GjBggIwxWrZsmT19awP9nXfekTFG3/ve93T44Ydr5513VkPDtrkm0JuHQI8agW7FfnHhMgLdg1kLEYGeUVHOWlghlmcEOoEeJQK9eIT1DPrgwYNljNHatWsD/dxRo0bJGKPXXnutyXGJD6ELM9AladCgQaqpqVFJSYmuv/56eziB3jwEetQIdCv2iwuXEegezFqICPSMinLWCPS8iP2sEegZEejFI6z3oF988cUyxmjOnDmBfm6/fv3UpUuXJoevW7dO3bp1y0mgT5s2zT6Tv2TJEns4gd48BHrUCHQr9osLlxHoHsxaiAj0jIpy1gj0vIj9rBHoGRHoxcPvU9zPPvvsZn2K+7vvvqs2bdqoX79+qqura/JzVq9e7fl+8xEjRqikpEQLFy60h23dutWGfi4Cfe3atXryySf14osvek5LoDcPgR41At2K/eLCZQS6B7MWIgI9o6KcNQI9L2I/awR6RgR68QjyPejHHHOM53vQR4wY0STQJelnP/uZysrK1K5dO33jG9/QNddco4suukgjRoxQZWWlLrzwQnvaZ555RsYYde7cWRdccIEuu+wy9e/fX127dtXhhx+ek0D3Q6A3D4EeNQLdiv3iwmUEugezFiICPaOinDUCPS9iP2sEekYEevHwC3RJWr58uU499VR17txZVVVVOuywwzRv3jwbtKmBLklvvvmmTjvtNNXU1Ki8vFzbb7+9Bg8erGuvvVaLFy/2nPbxxx/X4MGDVVVVpe23316nnHKKli5dauOaQA8fge4iAt2K/eLCZQS6B7MWysJE+gAAEaBJREFUIgI9o6KcNQI9L2I/awR6RgQ6UJgIdBcR6FbsFxcuI9A9mLUQEegZFeWsEeh5EftZI9AzItCBwkSgu4hAt2K/uHAZge7BrIWIQM+oKGct7BDLEwKdQI8SgQ4UJgLdRQS6FfvFhcsIdA9mLUQEekZFOWsEel7EftYI9IwIdKAwEeguItCt2C8uXEagezBrISLQMyrKWSPQ8yL2s0agZ0SgA4WJQHcRgW7FfnHhMgLdg1kLEYGeUVHOGoGeF7GfNQI9IwIdKEwEuosIdCv2iwuXEegezFqICPSMinLWCPS8iOWsBQ1tAp1ABwoUge4iAt2K5eKiUBDoHsxaiAj0jIpy1gj0vIjlrBHogRHoQGEi0F1EoFuxXFwUCgLdg1kLEYGeUVHOGoGeF7GcNQI9sGIM9PXr14e8Z0D8rF+/nkB3DoFuxXJxUSgIdA9mLQRBFtdZEOjxucxQEeh5EctZI9ADK6ZA37x5sxYtWhTf+zAgRPX19Vq0aJE2b275vyEEetQIdCuWi4tCQaB7MGshINADKcpZI9DzIpazRqAHVkyBLklLly5VXV2dGhsbQ9wzIF4aGxtVV1enpUuXtupyCPSoEehWLBcXhYJA92DWQkCgB1KUs0ag50UsZ41AD6zYAj3xrGJdXZ3q6+u1fv16bdiwgY2tILb169ervr5edXV1obxahECPGoFuxXJxUSgIdA9mLQTNWVz7INDjc5mhItDzIpazRqAHVmyBnricpUuXatGiRWxsBbktXbo0lPtkAj1qBLoVy8VFoSDQPZi1EBDogRTlrBHoeRHLWSPQAyvGQE/YvHlz3p/xZGMLe2vNe85TEehRI9CtWC4uCgWB7sGshYBAD6QoZ41Az4tYzhqBHlgxBzqAzAj0qBHoViwXF4WCQPdg1kJAoAdSlLNGoOdFLGeNQA+MQAfgh0CPGoFuxXJxUSgIdA9mLQQEeiBFOWsEel7EctYI9MAIdAB+CPSoEehWLBcXhYJA92DWQkCgB1KUs0ag50UsZ41AD4xAB+CHQI8agW7FcnFRKAh0D2YtBAR6IEU5awR6XsRy1gj0wAh0AH4I9KgR6FYsFxeFgkD3YNZCQKAHUpSzRqDnRSxnjUAPjEAH4IdAjxqBbsVycVEoCHQPZi0EBHogRTlrBHpexHLWCPTACHQAfgj0qBHoViwXF4WCQPdg1kJAoAdSlLNGoOdFLGYt9XdGoAdGoAPwQ6BHjUC3YrG4KFQEugezFgICPZCinDUCPS9iMWsEeosR6AD8EOhRI9CtWCwuChWB7sGshYBAD6RoZi35d02g50UsZo1AbzECHYAfAj1qBLoVi8VFoSLQPZi1EBDogRTNrBHoeReLWSPQW4xAB+CHQI8agW7FYnFRqAh0D2YtBAR6IEUza7kMsTwh0B0I9AIKdQIdgB8CPWoEuhWLxUWhItA9mLUQEOiBFM2sEeh5F4tZI9BbjEAH4IdAjxqBbsVicVGoCHQPZi0EBHogRTNrBHrexWLWCPQWI9AB+CHQo0agW7FYXBQqAt2DWQsBgR5I0cwagZ53sZg1Ar3FCHQAfgj0qBHoViwWF4WKQPdg1kJAoAdSNLNGoOddLGaNQG8xAh2AHwI9agS6FYvFRaEi0D2YtRAQ6IEUzaxFEWIRI9AJ9CgR6AD8EOhRI9CtWCwuChWB7sGshYBAD6RoZo1Az7tYzBqB3mIEOgA/BHrUCHQrFouLQkWgezBrISDQAymaWSPQ8y4Ws0agtxiBDsAPgR41At2KxeKiUBHoHsxaCAj0QIpm1gj0vIvFrBHoLUagA/BDoEeNQLdisbgoVAS6B7MWAgI9kIKfteaGFIGeM7GYNQK9xRKBfviD12rsT18l0AFYBHrUCHQrFouLQkWgezBrISDQAyn4WSPQYyMWs0agtxiBDsAPgR41At2KxeKiUBHoHsxaCAj0QAp+1gj02IjFrDV3Hgh0i0AH4IdAjxqBbsVicVGIUhY/BDqzFgoCPZCCnzUCPTZiMWsEeosR6AD8EOhRI9CtWCwuChGB3gSzFgICPZCCnzUCPTZiMWsEeosR6AD8EOhRI9CtWCwuChGB3gSzFgICPZCCnzUCPTZiMWsEeosR6AD8EOhRI9CtWCwuChGB3gSzFgICPZCCnzUCPTZiMWsEeov8cM4HmvriQgIdQFoEetQIdCsWi4tCRKA3wayFgEAPpOBnjUCPjVjMGoHeIgQ6gEwI9KgR6FYsFheFiEBvglkLQUiBfspPXyfQY3CZLUagx0ZeZ62lYU6gSyLQAWRGoEeNQLcKfiGbLwR6E8xaCAj0QAp+1gj02CDQ3UWgA8iEQI/afwP9N1NO17g7HiHQC3khmy8EehPMWggI9EAKdtbyEWIRI9AJ9KgkAv2Mx26xgT71hff1wzkf5HvX0orFfRBQRAj0qBHoVsEuZPONQG+CWQsBgR5Iwc5aAQd64nMRpr7wvsb+9FUCnUDPOQIdQCYEetQIdKtgF7L5lrL4+cFPH9Ap35tNoDNrrUOgB1Kws0agx05eZq21YU6gS8oc6IktTmJxHwQUEQI9agS6VbAL2Xwj0Jtg1kJAoAdSsLNWwCFGoDfjMgn0UBDoADIh0KNGoFsFu5DNNwK9CWYtBAR6IAU5awUeYqmBfviD1+qMx27R5q2bYxlLCUUd6I6HOoEOIBMCPWovTdHW6aMIdBXoQjYOCPQmmLUQtDLQEwFEoMfjMpuFQI9kP5qLQCfQo5L3+yCgyBDoUSPQrYJcyMaBT6Cf8tPXCXRmreVCDPRTfvq6pr7wfuAfzawR6LlEoDfjMgn0FkmdoyCBHqfZy/t9EFBkCPSoEehWQS5k44BAb4JZCwGBHkhBzhqBHsl+NBeBTqBHJe/3QUCRIdCjRqBbBbmQjQMCvQlmLQQEeiAFOWsEeiT70VwEujuhTqADaA4CPWoEulWQC9k4INCbYNZCQKAHUpCzFocQy4HUECLQCfRcIdABNAeBHjUC3SrIhWwcEOhNMGshINADKchZi0OI5QCB3oLLJNBbJF14Bw30OMxf3u+DgCJDoEeNQLcKciEbBwR6E8xaC7RmcZ0GgR6vy2yWOISY375kkC1ssgX61BcXxiaQ0ol81sKK81wEeowj3S+6CXQAfgj0qBHoVkEuZOOAQG+CWWuBkAI9NYCSAz3o4pNZI9B99yWD1JcUp/v/oIGe7vz5RqAT6FHJ+30QUGQI9KgR6FZBLmTjgEBvgllrAQK9RQpy1uIQYn77kgGBHvJlEugtQqADaK5IAn3NmjUyxmjFihWqr68v7u2pG/TVPUdr5g1j9c3an2nll6tD/xmrvlqlu+bfpbvm36VVX63K/3X22VasWCFjjNasWcOshbk9c5Pqn7pB9fcepfp7j9Jtd/9IJ908Qyfd/ftQ582VOWPWWjFHflvSfNU/dUPT45Mu5/Yn37LblN/+RSfd/XuddPfvNeW3f7GHM2sxnbVMMxB0yzYrQTe/fcqw/8mzlTpryXOZPJ9j7n5eh067Qqc8dJ2mPPFG2tOlbn4/w+8wZ2ctjHkIey4CzkI+N7+5mfLEGzrloet06LQrNObu5z33iX4zlq8tF7MGwF8kgZ74w2ZjS7etWLGCWWOLZGPW2KLamDW2qDZmjS2qLcxZA+AvkkBvaGjQihUrtGbNmpw+sufKM1ns77ZtzZo1WrFihRoawnvZNbPG/jJrhfW7c21/XZs1135vLu4zs+bm783FfXZp1gD4iyTQc62+3q33xrC/7nLttmB/3eXabcH+usnF28G1fXZtf3PFxdvBtX12bX8BpEeg5wH76y7Xbgv2112u3Rbsr5tcvB1c22fX9jdXXLwdXNtn1/YXQHoEeh6wv+5y7bZgf93l2m3B/rrJxdvBtX12bX9zxcXbwbV9dm1/AaRXEIG+ceNG1dbWauPGjfnelUDYX3e5dluwv+5y7bZgf93k4u3g2j67tr+54uLt4No+u7a/ANIriEAHAAAAAMB1BDoAAAAAADFAoAMAAAAAEAMEOgAAAAAAMUCgAwAAAAAQAwUX6OPHj5cxJu3Wr1+/vO7bm2++qWOPPVadO3dWVVWVhg0bpl/96ld53adMevfu7XtbXnjhhfnevbxj1sLBnGXHrIWDWcuOWQsHs5YdsxYOZg0oPAUb6BMmTFBtba1nmzZtWt72a+7cuaqoqFCHDh103nnnaeLEidp1111ljNFtt92Wt/3KpHfv3qqurm5yO9bW1uqZZ57J9+7lHbMWDuYsO2YtHMxadsxaOJi17Ji1cDBrQOEp2EBftmxZvnfF2rJli/r06aPKykr99a9/tYevXbtW++yzj9q0aaN//OMfedzD9Hr37q3evXvnezdii1kLB3OWHbMWDmYtO2YtHMxadsxaOJg1oPAQ6BF48cUXZYzRt771rSbHzZ49W8YYXXfddXnYs8y408+MWQsHc5YdsxYOZi07Zi0czFp2zFo4mDWg8BRsoN9zzz2644479MMf/lAvvfSStm7dmrd9uu6662SM0axZs5oc99VXX8kYo4MPPjgPe5ZZ7969teOOO2rmzJm67bbbdN999+mdd97J927FBrMWDuYsO2YtHMxadsxaOJi17Ji1cDBrQOEp2EBP3fr27au33norL/v0zW9+U8YY/eUvf0l7/Pbbb69u3bpFvFfZ+X3wyDHHHKOVK1fme/fyjlkLB3OWHbMWDmYtO2YtHMxadsxaOJg1oPAUXKDPmDFDv/3tb7VixQpt2LBBixcv1uWXX66ysjJ17dpVn3zySeT7dPTRR8sYoyVLlqQ9frfddlNFRUXEe5XdLbfcoldeeUUrV67U2rVr9cYbb+jYY4+VMUYHHXSQGhsb872LecWshYM5y45ZCwezlh2zFg5mLTtmLRzMGlB4YhnoXbt29f3KiHTb3Llzs17m9ddfL2OMrrrqqtxfgRQu3uH7aWho0KGHHipjjJ599tl8706rMWvxVGhzJjFrccWsMWtRYdaYtagU4qwBxSSWgX7JJZdo/PjxgbfFixdnvcylS5faRxOj5uJLpjKZPn26jInfB6W0BLMWX4U0ZxKzFmfMGrMWFWaNWYtKoc0aUExiGei5UF9fL2OMBgwYEPnPdvFDRzJ56qmnZMy27y5FU8xaOJiz7Ji1cDBr2TFr4WDWsmPWwsGsAe4qmkCfM2eOjDE68cQTI//ZL7zwgoxx62s7Mkm8/Ozuu+/O967EErMWDuYsO2YtHMxadsxaOJi17Ji1cDBrgLsKKtA/++wzffjhh00O//jjj7XnnnvKGKPZs2dHvl9btmzRbrvtpsrKSr399tv28LVr12qfffZRmzZt9MEHH0S+X5m89957Wr16dZPD58+fr7Zt26qyslLLly/Pw57FA7MWDuYsO2YtHMxadsxaOJi17Ji1cDBrQGEqqECfO3euSkpKdNhhh+n888/XpEmTdOqpp6p9+/Yyxmj8+PF5+zTLl19+WeXl5erQoYPOP/98TZw4UbvuuquMMbr11lvzsk+Z1NbWql27djr++ON1ySWXaOLEiRo5cqRKSkpUVlamn//85/nexbxi1sLBnGXHrIWDWcuOWQsHs5YdsxYOZg0oTAUV6HV1dTrvvPPUv39/bbfddmrTpo26du2qo48+Oi+PxKZasGCBjjnmGFVXV6tdu3YaOnSoHnnkkXzvVlqvvPKKTjnlFO2+++7q2LGjysvL1aNHD5122mlasGBBvncv75i1cDBn2TFr4WDWsmPWwsGsZceshYNZAwpTQQU6AAAAAACuItABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAYINABAAAAAIgBAh0AAAAAgBgg0AEAAAAAiAECHQAAAACAGCDQAQAAAACIAQIdAAAAAIAY+P++p6iycAbxugAAAABJRU5ErkJggg==\" width=\"1000\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib notebook\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(10, 3))\n",
    "for i, start_iter in enumerate((0, 90, 190, 390, 1490)):\n",
    "    plt.subplot(1, 5, i+1)\n",
    "\n",
    "    mid = 0\n",
    "    njs = histories[2][(histories[2].is_joint_case == 0) & (histories[2].index >= start_iter * 100) & (histories[2].index <  start_iter * 100 + 1000)].marginal_value\n",
    "    js = histories[2][(histories[2].is_joint_case == 1) & (histories[2].index >= start_iter * 100) & (histories[2].index <  start_iter * 100 + 1000)].marginal_value\n",
    "\n",
    "    plt.axvline(np.average(js), color='C0', label='$j$ (Joint)' if i == 0 else None, alpha=0.5)\n",
    "    plt.axvline(np.average(njs), color='C1', label='$\\overline{j}$ (Non-joint)' if i == 0 else None, alpha=0.5)\n",
    "    plt.axvline(np.log(16), color='C2', label='Ideal MI' if i == 0 else None, alpha=0.5)\n",
    "    \n",
    "    njs_hst = plt.hist(\n",
    "        njs,\n",
    "        bins=np.arange(mid-7, mid+7, 0.2),\n",
    "        alpha=0.5,\n",
    "        color='C1',\n",
    "    )\n",
    "    js_hst = plt.hist(\n",
    "        js,\n",
    "        bins=np.arange(mid-7, mid+7, 0.2),\n",
    "        alpha=0.5,\n",
    "        color='C0',\n",
    "    )\n",
    "    \n",
    "    plt.title(f'{start_iter+1}~{start_iter+10}')\n",
    "    plt.yticks([])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.gcf().legend(ncol=1, loc='center', bbox_to_anchor=(0.89, 0.5))\n",
    "plt.gcf().subplots_adjust(right=0.78)\n",
    "plt.show()"
   ]
  },
  {
   "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
