{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import pymongo\n",
    "from pymongo import MongoClient\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "%matplotlib nbagg"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Definitions. Fill in your own values here. If you used all default values for launching the search, only need to change exp_key"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "result_db_name = 'rllab'\n",
    "exp_key = 'test11'\n",
    "host = 'localhost'\n",
    "port = 1234"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Connect to database (make sure mongodb is running)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "client = MongoClient(host, port)\n",
    "db = client[result_db_name]\n",
    "jobs = db.jobs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Retrieve and format results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame(list(jobs.find({'exp_key':exp_key})))\n",
    "param_dicts = []\n",
    "score_curves = []\n",
    "for i in range(df.shape[0]):\n",
    "    res = df.result.iat[i]\n",
    "    if res['status'] == 'ok':\n",
    "        resdict = res['params']\n",
    "        resdict['score'] = -df.result[i]['loss']\n",
    "        resdict['result_index'] = i\n",
    "        score_curves.append(res['scores']) # this only works if your function to process results returns the learning curve\n",
    "        param_dicts.append(resdict)\n",
    "param_df = pd.DataFrame(param_dicts)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Results table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "collapsed": false
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>exp_name</th>\n",
       "      <th>result_index</th>\n",
       "      <th>score</th>\n",
       "      <th>seed</th>\n",
       "      <th>step_size</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>test11_25612_1</td>\n",
       "      <td>0</td>\n",
       "      <td>999.935556</td>\n",
       "      <td>1</td>\n",
       "      <td>0.051536</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>test11_25584_1</td>\n",
       "      <td>1</td>\n",
       "      <td>999.955588</td>\n",
       "      <td>0</td>\n",
       "      <td>0.035537</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>test11_25598_1</td>\n",
       "      <td>2</td>\n",
       "      <td>999.954819</td>\n",
       "      <td>2</td>\n",
       "      <td>0.088319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>test11_26214_1</td>\n",
       "      <td>3</td>\n",
       "      <td>999.947394</td>\n",
       "      <td>0</td>\n",
       "      <td>0.071792</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>test11_26204_1</td>\n",
       "      <td>4</td>\n",
       "      <td>999.956958</td>\n",
       "      <td>0</td>\n",
       "      <td>0.058653</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         exp_name  result_index       score  seed  step_size\n",
       "0  test11_25612_1             0  999.935556     1   0.051536\n",
       "1  test11_25584_1             1  999.955588     0   0.035537\n",
       "2  test11_25598_1             2  999.954819     2   0.088319\n",
       "3  test11_26214_1             3  999.947394     0   0.071792\n",
       "4  test11_26204_1             4  999.956958     0   0.058653"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "param_df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Learning curve of best parameter set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "collapsed": false
   },
   "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",
       "        this.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>')\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option)\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width, fig.canvas.height);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to  previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overriden (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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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.text.Text at 0x7fb090cb2828>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_score_index = param_df.score.values.argmax()\n",
    "plt.figure()\n",
    "plt.plot(score_curves[best_score_index])\n",
    "plt.xlabel('Learning algo iter')\n",
    "plt.ylabel('Average return')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Hyperopt score progression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "collapsed": false
   },
   "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",
       "        this.ws.close();\n",
       "    }\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_header = function() {\n",
       "    var titlebar = $(\n",
       "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
       "        'ui-helper-clearfix\"/>');\n",
       "    var titletext = $(\n",
       "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
       "        'text-align: center; padding: 3px;\"/>');\n",
       "    titlebar.append(titletext)\n",
       "    this.root.append(titlebar);\n",
       "    this.header = titletext[0];\n",
       "}\n",
       "\n",
       "\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
       "\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = $('<div/>');\n",
       "\n",
       "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
       "\n",
       "    function canvas_keyboard_event(event) {\n",
       "        return fig.key_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
       "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
       "    this.canvas_div = canvas_div\n",
       "    this._canvas_extra_style(canvas_div)\n",
       "    this.root.append(canvas_div);\n",
       "\n",
       "    var canvas = $('<canvas/>');\n",
       "    canvas.addClass('mpl-canvas');\n",
       "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
       "\n",
       "    this.canvas = canvas[0];\n",
       "    this.context = canvas[0].getContext(\"2d\");\n",
       "\n",
       "    var backingStore = this.context.backingStorePixelRatio ||\n",
       "\tthis.context.webkitBackingStorePixelRatio ||\n",
       "\tthis.context.mozBackingStorePixelRatio ||\n",
       "\tthis.context.msBackingStorePixelRatio ||\n",
       "\tthis.context.oBackingStorePixelRatio ||\n",
       "\tthis.context.backingStorePixelRatio || 1;\n",
       "\n",
       "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband = $('<canvas/>');\n",
       "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
       "\n",
       "    var pass_mouse_events = true;\n",
       "\n",
       "    canvas_div.resizable({\n",
       "        start: function(event, ui) {\n",
       "            pass_mouse_events = false;\n",
       "        },\n",
       "        resize: function(event, ui) {\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "        stop: function(event, ui) {\n",
       "            pass_mouse_events = true;\n",
       "            fig.request_resize(ui.size.width, ui.size.height);\n",
       "        },\n",
       "    });\n",
       "\n",
       "    function mouse_event_fn(event) {\n",
       "        if (pass_mouse_events)\n",
       "            return fig.mouse_event(event, event['data']);\n",
       "    }\n",
       "\n",
       "    rubberband.mousedown('button_press', mouse_event_fn);\n",
       "    rubberband.mouseup('button_release', mouse_event_fn);\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
       "\n",
       "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
       "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
       "\n",
       "    canvas_div.on(\"wheel\", function (event) {\n",
       "        event = event.originalEvent;\n",
       "        event['data'] = 'scroll'\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        mouse_event_fn(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.append(canvas);\n",
       "    canvas_div.append(rubberband);\n",
       "\n",
       "    this.rubberband = rubberband;\n",
       "    this.rubberband_canvas = rubberband[0];\n",
       "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
       "    this.rubberband_context.strokeStyle = \"#000000\";\n",
       "\n",
       "    this._resize_canvas = function(width, height) {\n",
       "        // Keep the size of the canvas, canvas container, and rubber band\n",
       "        // canvas in synch.\n",
       "        canvas_div.css('width', width)\n",
       "        canvas_div.css('height', height)\n",
       "\n",
       "        canvas.attr('width', width * mpl.ratio);\n",
       "        canvas.attr('height', height * mpl.ratio);\n",
       "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
       "\n",
       "        rubberband.attr('width', width);\n",
       "        rubberband.attr('height', height);\n",
       "    }\n",
       "\n",
       "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
       "    // upon first draw.\n",
       "    this._resize_canvas(600, 600);\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus () {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function() {\n",
       "    var fig = this;\n",
       "\n",
       "    var nav_element = $('<div/>')\n",
       "    nav_element.attr('style', 'width: 100%');\n",
       "    this.root.append(nav_element);\n",
       "\n",
       "    // Define a callback function for later on.\n",
       "    function toolbar_event(event) {\n",
       "        return fig.toolbar_button_onclick(event['data']);\n",
       "    }\n",
       "    function toolbar_mouse_event(event) {\n",
       "        return fig.toolbar_button_onmouseover(event['data']);\n",
       "    }\n",
       "\n",
       "    for(var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            // put a spacer in here.\n",
       "            continue;\n",
       "        }\n",
       "        var button = $('<button/>');\n",
       "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
       "                        'ui-button-icon-only');\n",
       "        button.attr('role', 'button');\n",
       "        button.attr('aria-disabled', 'false');\n",
       "        button.click(method_name, toolbar_event);\n",
       "        button.mouseover(tooltip, toolbar_mouse_event);\n",
       "\n",
       "        var icon_img = $('<span/>');\n",
       "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
       "        icon_img.addClass(image);\n",
       "        icon_img.addClass('ui-corner-all');\n",
       "\n",
       "        var tooltip_span = $('<span/>');\n",
       "        tooltip_span.addClass('ui-button-text');\n",
       "        tooltip_span.html(tooltip);\n",
       "\n",
       "        button.append(icon_img);\n",
       "        button.append(tooltip_span);\n",
       "\n",
       "        nav_element.append(button);\n",
       "    }\n",
       "\n",
       "    var fmt_picker_span = $('<span/>');\n",
       "\n",
       "    var fmt_picker = $('<select/>');\n",
       "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
       "    fmt_picker_span.append(fmt_picker);\n",
       "    nav_element.append(fmt_picker_span);\n",
       "    this.format_dropdown = fmt_picker[0];\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = $(\n",
       "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
       "        fmt_picker.append(option)\n",
       "    }\n",
       "\n",
       "    // Add hover states to the ui-buttons\n",
       "    $( \".ui-button\" ).hover(\n",
       "        function() { $(this).addClass(\"ui-state-hover\");},\n",
       "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
       "    );\n",
       "\n",
       "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
       "    nav_element.append(status_bar);\n",
       "    this.message = status_bar[0];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_message = function(type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function() {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
       "    }\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "}\n",
       "\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1]);\n",
       "        fig.send_message(\"refresh\", {});\n",
       "    };\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
       "    var x0 = msg['x0'] / mpl.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
       "    var x1 = msg['x1'] / mpl.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0, 0, fig.canvas.width, fig.canvas.height);\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
       "    var cursor = msg['cursor'];\n",
       "    switch(cursor)\n",
       "    {\n",
       "    case 0:\n",
       "        cursor = 'pointer';\n",
       "        break;\n",
       "    case 1:\n",
       "        cursor = 'default';\n",
       "        break;\n",
       "    case 2:\n",
       "        cursor = 'crosshair';\n",
       "        break;\n",
       "    case 3:\n",
       "        cursor = 'move';\n",
       "        break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function() {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message(\"ack\", {});\n",
       "}\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = \"image/png\";\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src);\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data);\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig[\"handle_\" + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "}\n",
       "\n",
       "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function(e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e)\n",
       "        e = window.event;\n",
       "    if (e.target)\n",
       "        targ = e.target;\n",
       "    else if (e.srcElement)\n",
       "        targ = e.srcElement;\n",
       "    if (targ.nodeType == 3) // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "\n",
       "    // jQuery normalizes the pageX and pageY\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    // offset() returns the position of the element relative to the document\n",
       "    var x = e.pageX - $(targ).offset().left;\n",
       "    var y = e.pageY - $(targ).offset().top;\n",
       "\n",
       "    return {\"x\": x, \"y\": y};\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys (original) {\n",
       "  return Object.keys(original).reduce(function (obj, key) {\n",
       "    if (typeof original[key] !== 'object')\n",
       "        obj[key] = original[key]\n",
       "    return obj;\n",
       "  }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function(event, name) {\n",
       "    var canvas_pos = mpl.findpos(event)\n",
       "\n",
       "    if (name === 'button_press')\n",
       "    {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * mpl.ratio;\n",
       "    var y = canvas_pos.y * mpl.ratio;\n",
       "\n",
       "    this.send_message(name, {x: x, y: y, button: event.button,\n",
       "                             step: event.step,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.key_event = function(event, name) {\n",
       "\n",
       "    // Prevent repeat events\n",
       "    if (name == 'key_press')\n",
       "    {\n",
       "        if (event.which === this._key)\n",
       "            return;\n",
       "        else\n",
       "            this._key = event.which;\n",
       "    }\n",
       "    if (name == 'key_release')\n",
       "        this._key = null;\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which != 17)\n",
       "        value += \"ctrl+\";\n",
       "    if (event.altKey && event.which != 18)\n",
       "        value += \"alt+\";\n",
       "    if (event.shiftKey && event.which != 16)\n",
       "        value += \"shift+\";\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, {key: value,\n",
       "                             guiEvent: simpleKeys(event)});\n",
       "    return false;\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
       "    if (name == 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message(\"toolbar_button\", {name: name});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to  previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.close = function() {\n",
       "        comm.close()\n",
       "    };\n",
       "    ws.send = function(m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function(msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overriden (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,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAgAElEQVR4XuydB5QUVb7Gv0kwgDBEQaKABJEMIjkMBsSsmDDrCiqGRUXAXdPqShBRWVFUjCgsuJgWjDBkRrIgIAhIBkFAGGCAie98bdV5tW33TM/c6e7q7u+e43n7mLpV9/7uv6p+dVPHQUkEREAEREAEREAERCCmCMTFVG1VWREQAREQAREQAREQAUgAFQQiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgqq4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQYwQkgDHW4KquCIiACIiACIiACEgAFQMiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgqq4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQYwQkgDHW4KquCIiACIiACIiACEgAFQMiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgqq4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQYwQkgDHW4KquCIiACIiACIiACEgAFQMiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgqq4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQYwQkgDHW4KquCIiACIiACIiACEgAFQMiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgqq4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQYwQkgDHW4KquCIiACIiACIiACEgAFQMiIAIiIAIiIAIiEGMEJIAx1uCqrgiIgAiIgAiIgAhIABUDIiACIiACIiACIhBjBCSAMdbgUVTd9wD0BHCmo075AJ4B8LT1b7cDeBdAfQDboqju4ahKIoDnAdwIoBaALwBc6acgZL0WwKXhKKiuKQIRREDPqAhqrGgrqgQw2lrUffWxH3B2yXIB7APwHYC/AdhdzCJLAIsJrpjZBgB4A8DLAFYC2AFgngQwIJo1AZDfZwB+CCiHDooVAhLAWGlpF9ZTAujCRomyItkPuCcBbAWQDKAjAP47e4qaAzhZjDoHIoAJAJIAnALA3kGl4hP4N4CuAGoHcAr1AP4vpPYAlgG4AwDjVkkEbAJ6RikWwkZAAhg29DFzYVsAzwWw3FHrkQCGArgewLRi0AhEAItxWmXxQyANwOmWsBcGKVIFsCyAzMIqV4y/R6IAlgNwvBh1LcksoSwDpzjEA8gqyQroXCLgZgISQDe3TnSUzZ8AXgJgBoDHAYzwqup9AAYBOAvAQQCfWsPFhx3HBSKAvoZXbDmhgI4F0BLAHmve4Ade5eDf/gWgg1WOCdaQ9TsBzCtk+foBaAbgNWu+4hFrHt14AC0AvALgPAAHAAwHMNlx/coWm4usa+UBWARgGIDVjuPetyS6DYCfHP/+jVXuc6z6+YsmvmT/AeA6S/DI5y0AL1q9ppxjyZ5b79QLwFw/Jw2EcQMAWwA8DOAlr/N0turaH8AUq22eAnC2VdY+ALIBfGh9RHj3IN8MYLDF/gSAbwEMAbDTcR2WvSqA26zrU9LeBPBX65hAYtB5DsYJ2+BXAKMAMFaYOE91jg9OBfUGlgfwrDXH8gwAjBu2OT+YOPxuJ8YOuXQCUMri+bYVV/Yxqda82LYWMw7bM4acscI5szwPY+XvAC62eudZH6amAJ4DwHNRkjm/kzHDeaAFJTt2yJ5TP8iWHxFLrfub57GTfb+0su65bgBmO+aZXmuVm/cTxfRri4f3FBIex3nAjK/NAJ4AcIXXfGFnuXIAPGDNJW5nDdGXtu69mwDUAbDfikOei6MJdrrA4sZRDAokyzLdymsfw3PfY93DzMuY53PHvtf9DQEXJf547/KZwnj43Wr/0YW0jf4sApAAKgiCTcCfAFLwXgVwr+NlybLYL6NZAD4H0MQ6hi++LtZLjMeZCCCFoSIAviwpf3daL29K2ToLCBc6rLEkaJz10vmL9QLgS6qwhSUsH3s3fwEwH8CPAPhCodzw5f9PAB9Zc+n4guBLtpFDtigkHHb92Pq36gAGAjjNEhuWm4n14Ln3WiLAFy2Po4DcYkmSvzbm/U/OlDmy4Pw0Cudl1lw/ShQF8SpLwHltiioT53ByLqevRAEMhPFCa0oA6+pMfJmx7DWsHjk7JlhPnptyy2kEFL1JAG51ZOa8UsoTe5UpO9WsF/wxq43tjwjKG2OLQ3DkTBlhfRhzgcYgz8E248uf1/vZEmkOld8FgB8KbDfO/6MwUTAXWGVdbMWGL36MC3488P5YD6CKNfw+1YoZ5qF88AOK7c5Yo3hSkClI/BvT+QC+sq4zEUAZiwXrTCG0F0bZ9eW1Nll8GRv8cKEU8sODcsOPDcoXhYOCdo31ceYvvmzRYrtRal+32vshSwh5v9kxxDrcAGAXAMZFutX2bF/7GcJhdIoTmfIczEtJtduUH5X/te4Hnq8SgPutsvP69oIxu1ysL6eksF0oZ59Y1ycztiH/naLMcvIenekQUnLhM4nPCJaR+fnByo/FHhaQu61z/Me6X3gtflSSIcvP5EsAixp/vOdZ9o1W3FDU+1pt769t9O8iIAFUDASdgP2A48uIvRh8CPJLlS+DCtZDkw99Jr6s+b/5YmUvBHu9mGxZpKhxVS+TiQDWA9Dd8TLmddk7xBfuo9b5KX18efBFaU/cZ68cX5D8v4EIIHuXnD2clDWKGxlwNS1f6EwUkQ1eK5jZC8FeLpsBj+OLi8dRHik5drrQemmz94YvSL6UKHYUt4ISe0a4MIH5eE47UTr5cqfcsMeCye7tYm9HYYliEQhje2EJxYX1YuKcTTLiy5axw2S/ENnjxDLbiaLInhIKOevMa7K8nG/KFct2YplXWb019r+zPnxR88XOxS12KkoM2ud4xOrV4TnYE7cEABd+cL4k27CoQ8AUGvZuMv58JQoc45BDlq0dAsRjKW72fFfWmeUg30PWiSgg/Heen/Hp5MveVva6OhPjiL12nMJh937xGpQ0smrsp4z8Z1u02AvLWLJ76yhJZMSeX/YAM/F+ZnnYM29/ZPDfGQ98JrAXjmWwe3vtEQSKNXsvmRgDlD7Wl8LPxDZmO233IYAZ1vPnN0cd+FFB0WU+1tFO9kcVP0Ip7+zNZPnJgD34vhLvLUphQfeMtwAWJ/74AUQJZWL8sa6Udn5EKImAXwLqAVRwBJuA9ypg+3qUBD5UOTxnJ0oRBcb765UPNT6k2etkP9RMBJBf4PyCdybKKeXhausf2ZvDa/KB70wUQw7rBCqAfHk6XzB8+fKlQPl1Lkzh0A17L5y9WfZ1+cKnPPJ+5bAYexW95Y49fuxZZK8GxYP140uzoETxYU8VX5pHHQeyd409MKwnpZipqAIYCGPWiT1YY6yhOl6HW8eQA3uxKB9MtgCyd9IZL+w1ZQ8NhYHiwB5LDl1TSpzTBXgO9sJSQOzeMdaH9WQ7OOd9FSUGeQ7GB+vhnC9HqeQHDodmvy+GAPLeYMxQdu2eXmc72kLJ+nJVtq/EoWPm5VAgh46dicOnHO6kbDj5UnrIyU780KHcUKjtIW37bxRvDrUy1vyt5LcF0JdYkgu5sQ2ZbAGkxHOFuZ3IkMLF65GpM7HtyZ08KLosBwWfvcDORDFkO3v3APJjkh+VzsQe4IbWkLHz33mP8JlgfyzZzzWOCvA8zg81Ox/rxK2SGHPsvfSVvAWwqPHHdvR+lrAOHLrmx6uSCPglIAEMT3DwxuQ8IX7Rsvue80b4JWx/tfoqFYc9mIe9PXxw8kHNFzR7AuzEBxdfphy+YA8SH/Q8xjlUF8i1fa2Y5YOJQ2WBJH61c84QRY4vY7tXhF/MnHPDhy574Piyd24lwrlJnA/IelBynInixLxkxmQigHxxsIfRmfgyZ705HMrE3g7W1+4lsY990JpjE4gAcgiYw27e12FbspfCmfjS51AZh1+Z2LvDYSK++HgtSqCdOKeMwzzOxOFZxgKHTe25c16H/On/ZXxwyLCu119SLIFiLHH+FlNRBTAQxjwvh075EmObM1EWOLzIMtkvVVsAOa/LOR+RccYeIc5ZpHRxyJJTCvwligB7C+368CVpX9fOU5QYJBO2DaXFmdg2FHX7nilqDyCHWNkLxftmBYAvAXB+qn1PMK4Ym05J9q6zLfH2ULTz77wP2YPFmKFA2XzJ3DlP0u6pKyiO+Dzhvekr2QLo7KWzj2N9WE/2hjPxfuYUCT63nDLFYWHGRG8AXIjkTJwbzGcdRdYWRecogX0sh0dZTm8BpNg6e9J5PD+gvO9N5zX5Acj7kvc1P0j5AUBJZnvzOhzutcvP8/AYTifhfER+vPADl71zdvIWwKLGn69nCVlS5hmbSiLgl4AEMHjBwZcDb0TvbR/4pcr5Rhz+49c7v974f9kT4q/Lnu3Er2AOJ3G4iUMXFEZOhrcnRXOuFl9w7Mmyh0T4cOP1+DLgQynQa1OE2JtEQbATe1QC3a6FAsEHIV/MfGlT6ji3jvn5MqTMcHiFLxwOf9riW5SHn4kA+tqk2F7QwEn7TCUhgGxPvmSdyZ9Iea+cZU8D24/zyPgS4RAe25CxwheOXU773JQmnpviSN4cei4sBVMAA2HM8tk9fnyRUoA5l40iZ4snj/EngJx7x3ayBZC9VBxWptzzw8o7Mc7Y88Tkrx2KEoPBEkCWjz147OXlBx9Fj+3K3mnOTwuWAHoPZ9oSyQ8Bzrv0lTiU6+w9dh5TVAH0db8EUwAZY6ybM3EqAnuE7aFp7zpTkDnXjoltwg9GDkfzWUzho6Syzez443OZMc6/My4pbE4hNhVALmTyHmL29Wws7Fmgv8cgAQlg8BrdnwDyBcUXOx/w9pciJxlT3jhPhl+K3om9aHzo8Ea3Fynw4cOXJV/0nODNhw5fDhyqoCAyUcQ4tMi/cTgt0GtTAPny4RwWf4lf3hQNCh2FhF/jHIrz3jrCfsCxJ429GvYQj7060h6+43UKGv7gcCbrUBJDwIHISUkMAZsIIOcdUvq8e/o4H4ox4hRAvmQo/pxrxQ8F9vqwR8TfsJPdpv6GgDlHk6JkMgQcCGOWgxLHoUrOO6RMMEbsOX12OQMdAuYLnUOe/Khg+xWU/AlgUWIw0CFg9nByC6Ti7gPIaQRccMCPBN53pkPAfE7wHN5DwN4CyOty9CDQDwpv3kUdAvZ1vxQ0BMzeOm7bU9whYF8CyLmnjD/2Dhd171A+izmX1l/PLHt02UtIGeSHIT+IizIE7P0M9BfDEsDgvdej6swSwOA1pz8B5Ev1MesBY1+dc8I4fOfvBWELIo+zJ+UzL79GOfTAhwiHDilhlAF7sjaHUyhkHI7lSzTQa/PBx5cy83PYiT0rnOdiPxA5bEbhYC8VH5h8cXCuGP+NdXAm+wFnL+Tg8LUtqHzhUwj5ouDD0J4Aza9oDh/b1+OwHnuFSmoRSCBywm09WGaTRSAmAsihP3Kyh6TJlFtc2KtbnQJI9pR79tjwQ4HtwF4MrpB0blvhHe32IhDvrXg4vMjhOZNFIIEwtsvD7XA4bM0eQPZocKGCMxW2CIQLIVhnxiXrz951TuZ3vsD5rOOcNm4rxOTv5VmUGCxoEQiH/fgfe+3tuYoFzdmz68veccoBt35xJm6dwjpwCgQ//vgREMgiEH5o8vr2nEh+RJKVr0UgvhY0cLoB24P5OErhTDzeOb/VnwD6WwTC3mwyYbK3gfHuMbcXgfBjl0PSdjyzN41D487eNMYPny+BLgLxJYD8UGVZOD+Zq4CdicO+ZM5nKmPJXlhjH8NnFp+H7PHj/+XqbTve7GP4gcJRHJaTPaf+FoEE8gyUAHpHnP7/IhGQABYJV5EO9ieAnJzP3h2+dPnio7BxCIurLn3ticeL8iHIBz6FiQ8mPoD44OTEd84r4eR4Pox5DEWN52Hb8u9cScgHGfMFem3ud8UHEL+u2XvIyd6UVs5/YWKPo73diA2FPROcz8f6OIeK7Qcch1bYi8F5PnaiILHnx7kVjP2yZ7246pO9OZwHV5LbwAQiJ+wBYK8s5x1SBsmcE75ZNwoHpZWr7fwlfy+0QIeAyZxzlHge9urxI4Ds+CKn+NsCyB5C9ozyeP7HZA8Hc0EE281f4suMeXkuxiDFgO1NMXS+nJm/qHMAA2Fsl8vuIeP/zwUL3nuYeW8Dw6Fr9gxR8jinyhlT9hAumbEHmy9ZzoVijzbvA3vIr6D6BBqDzm1gKJ3sdeTwLO8FCjmZ2vcve2/Ym/aCFUu8l33tr0gxYC8vp1CwPThszRX0FHLnamPe81wsww813vOUM4oe73H+jcneBobPBW7zY28Dw15XMrevb9fXlwByigmna3C0gvXhByGHMcmfC0DsOZW+YszXNjD8qOT8Q8o5Y9qWSn/3C89rP0PIjPMB7W1gyNS5DQw/grkAgiJIJvY2MGREsbTnxDn3AfQeAuY9Qa4UTLYp5+tRysmWbUC27M3l/cF5zBQ9PgfYW8rnFOtFWabA8yOO4spzsO0ppnwe89l2uQWsoG1gCnsGSgALeLjpT4UTkAAWzijQIyhdznlXfNjy658CYSc+TLnCjb0d3AyUvR0UKYoV9z3j5Gwu9PCV+MDmQ5wPXObhi5sPZbahvaCBL2+ulOODjn/jw5LXZO+BPTm+ONemWLD3jVLExKFF9gqwfnZiObhJLK/n3GSWw5EURvbM8Ave7v1jPj5s7aE6ip49b4Y9b3xQskeHX9kcNiHbktwIml/pzuQ9B5B/o+ixbVhuDnOzJ5Tlp7hzsYW/ffCY11QA+aLkcBLbi1JAAeYWNZR6Jkob9zbjy469DBy2dcYa44uT1Tm3zp735iuu+GJkLwrFhQLAYUaKkr0RtJ0nmALIa1AY+YLkvFDvVaW2oDC2WFa+hFlX7pfHXhzvuamcK8cPJHsjY7unnG1px1th9QkkBu1zsNfI3gjaljxuUeNMfOFzKJXTOShg/nr7OUzIHnvey5w/a/f2cbjeexUs25bzfdnzy+M4OkBJs1du8/pcPMH717kRNCXb10bQ/rY0YTl4HZaJvVoULy78YIxzAZu/5BQtPo+cG0Hz/uYHlp0KEkAeQ/mi3NtznjmMzXp4xwrjmPFibwTNFcH8UKAY24s7ChJAXosf3IwfrsjnqAs/hCm+/CCl+PEZwA8vLghjjyyf43w+8AOYnOyFefwI4McJr837jGLPZxnb134O+tsIuijxpzmABQSh/uSfgASw5KKDQwL8z058OfHhyBveTny5Ol/S/JJlzxK/GvlA4IRn9ogVlDivz94WhV/E/Brlw8KZ+EDidShM/ALly5w9D85UlGvbe25xxR6HYPjy4MIEu0fQeV4Krr2tBh+kHLLkw5gPTO/hkJKjH7oz8QVgb8jsa6FB6EoSXVeiUFD2KSzeqaAeqnBSKEwiw1k2N1y7MNEKVRk54sKhansLoFBdV9cRAVcTkAAGr3n8DQH7uiJ719iDwDlD3vuX+Ssh52dxWJW9f8690ZzH28OD/PK1V655ny+Qa/MrmsNPtuBSbimQHGLyl2z5Yzk5j62guULBawWzM7MXl/OX7MTeD/YgsTdOLxMzts7c9qIG9oZwEYgEsOTYhvNMoRZAPnP4Me38yLYXm3lvdh5OLrq2CLiCgAQweM1QkABy+INzlDi/hyLB3jkObzh71Ch3XCHLhR1MXABAiWIPm/07spxjwrmDduKwEnvneBzn6HCokkMrlDc7FXZtzqOh3HHYkENrLB/nyfA/e3sZDv/y79yihMO77MW0f4KK5+eDmHOYOOzEoVbnUCl7eSLlB9fZc8B2JFMy4XA2t9JhL5Vzw9zgRVF0n5lDV5zawPhkrzV7in1tNaQewMiMg1ALIK/HqTFc4MJ5f5y3x/0hOR+PsRYNIxCRGQkqtSsJSACD1ywFCSA3QeWwKueFUPQoV/ZP+dglsvfis/cR5HwTzneiiHDiNM/B7WScMsX5YexFYU8dh5s5Z43zCp2rIQu7Nrco4Fwlzn1hfHACOececW6Rc4NWzn3hHDWKJo/j/CNOmuZO/PaD3xdd9gba8+2CR79kzsy6cKEKJ7uTIXv+OJ/K/oWKkrlK7J6FYseFLuyd5ovauSm4k4oEMDJjJNQCyOkxnL/KuZGcz8gPU+6SwI9r5+4JkUlTpRaBEiYgASxhoDqdCIiACIiACIiACLidgATQ7S2k8omACIiACIiACIhACROQAJYwUJ1OBERABERABERABNxOQALo9hZS+URABERABERABESghAlIAM2Akh9Xhfr7MXSzsyu3CIiACIiACIhAsAhwM32uGC/q7z4HqzwhPa8E0Aw39+3j7u5KIiACIiACIiACkUeAuzx4/6JM5NWiGCWWABYDmiNLBe4xtXPnTlSowP+pJAIiIAIiIAIi4HYCGRkZqFPH8+um3D7I+ROlbi96iZVPAmiG0iOAR44ckQCacVRuERABERABEQgZAQpgSgrdTwIYMuhRdiEJYJQ1qKojAiIgAiIQ/QQkgH/8goNS8QlIAIvPTjlFQAREQAREICwEJIChEcBB1k+Y1QCwGsADAJYW0OL88e6xAM4BsBPAc9bv2Tqz8Hdx+TNo/KmhTQCGAvjScQB/Bq2ej2u8BoDlYaL88me97gZQEcAiAPda5ws0ICWAgZLScSIgAiIgAiLgEgISwOAL4PXWb9bydz6XAPgrAMpbEwD7fcRBfQBrrd+wnQigN4CXrd/N/cY6vjOA+QCGA5gBoL8lgG2tvDyMvwOZ4Dg/fwj8OwDO36GlNPIctwHYagllCwDN/Pwgva+wlQC65GZWMURABERABEQgUAISwOALIKVvGYD7rUaJt3r1/gVgpI+GGmXJHoXNTv+2euj6WP8wFUA5AJc6jvkewA/WD8r7an9KJI9vZO33w94/7v3zIoAxVgbOBt0H4HYAvGYgSQIYCCUdIwIiIAIiIAIuIiABDK4AlgKQCaAfgM8c7f6+JXRX+IgF9uyttHoK7T/fYfUCepbrANhhDRFT6uzEodwrAbTycU6Wg7LHYeXnrb83ALAFQBtLHO1s86z//6EA41QCGCAoHSYCIiACIiACbiEgAQyuAPIXMri5Iods0x2NPhpADwDn+QiEnwG8C2CE4299AcwEUBbACQBZ1rDtFMcx9wF4CkB1H+e8DsBkAHUtEeQhLBPn/LGMex15plk9hBy69pVKA+B/duIu4ru0DYxbbmmVQwREQAREQAQKJyABjA0B5NxBSuNljpAorgA+bYnm/0SXBLDwm01HiIAIiIAIiIBbCEgAgyuAbhgC5krgXwBcDeBzR+AVdwhYPYBuuXtVDhEQAREQAREoJgEJYHAFkM3CRSDc8oVbvzBxEQjn8L1awCIQDvlyNa6dOHxbGYBzEQiHg509eosBrPGxCIQ9dgMB8PdechzntBeBcAEIF4IwcT4fVyZrEUgxbyhlEwEREAEREIFIICABDL4Aci4dF31QwiiC3AaGc/KaWituOdevFoBbrYCxt4EZD+AdAKkAxvnYBoaLNYZZcwNvAPA4AOc2MLZscnsXzhXksd6J28Dw353bwLTUNjCRcOuqjCIgAiIgAiJQfAISwOALIFuHW8AMAcCNoLlVy4NWzyD/9p61mTM3f7YT//dLlojtsvbn43HOxL0EuUG0vRH0Y14bQfPYCwFw/h/3HOTiEu9kbwQ9wFqVvBAAF5P4OtZflGkVcPHvP+UUAREQAREQgbAQkACGRgDD0rghuqgEMESgdRkREAEREIHYIjB34368vXAr7u3REJ3PqlqilZcASgBNA0oCaEpQ+UVABERABETAB4GbJn6PRZsP4i9d6+Pvl/JHukouSQAlgKbRJAE0Jaj8IiACIiACIuBFYP2eDPQdtwAJ8XGYN6Qnalfi2s+SSxJACaBpNEkATQkqvwiIgAiIgAh4EXh42g/4ZOVuXNryDLzan2s8SzZJACWAphElATQlqPwiIAIiIAIi4CCwL+Mkuo5KQ3ZuPj4b1AWt61QscT4SQAmgaVBJAE0JKr8IiIAIiIAIOAiM/noDXpu7BeeeWQkf38Mf7ir5JAGUAJpGlQTQlKDyi4AIiIAIiIBFIDMrB51GpOHIiWxMuLkd+jTnDnIlnySAEkDTqJIAmhJUfhEQAREQARGwCHyQvg1Pfr4O9aqURdojPT2LQIKRJIASQNO4kgCaElR+ERABERABEQCQm5eP3i/OxbaDmXjm8nNwW2f+1kNwkgRQAmgaWRJAU4LKLwIiIAIiIAL86a51v2LgpBVIKZOE9OGpKFsqMWhcJIASQNPgkgCaElR+ERABERABEQBw7YTFWLbtd9zbsyGG9mkaVCYSQAmgaYBJAE0JKr8IiIAIiEDME/hh52FcOX4RkhLisHBoKqpXSA4qEwmgBNA0wCSApgSVXwREQAREIOYJ3D95JWas2Yur29bC2OtaB52HBFACaBpkEkBTgsovAiIgAiIQ0wR2/Z6JHi/M9SwC+fLBbmhWk6/W4CYJoATQNMIkgKYElV8EREAERCCmCTw3Yz0mLtyKLmdVwUd/6RgSFhJACaBpoEkATQkqvwiIgAiIQMwSOHoy27Px87FTOXj39nPRq+npIWEhAZQAmgaaBNCUoPKLgAiIgAjELIGJC37BczN/wlmnn4Zv/9od8UHa+NkbsARQAmh600kATQkqvwiIgAiIQEwSyMnN88z92334BEZc3QI3dqgbMg4SQAmgabBJAE0JKr8IiIAIiEBMEvjv6j14YMoqVClXCouGpSI5KSFkHCSAEkDTYJMAmhJUfhEQAREQgZgjkJ+f79n3b/WuI3iodyMMvqBxSBlIACWApgEnATQlqPwiIAIiIAIxR2DZtkO4dkI6SiXGY/GwVFQ9rXRIGUgAJYCmAScBNIZ9sJkAACAASURBVCWo/CIgAiIgAjFHYOCk5fhm3T7ccG4djLymZcjrLwGUAJoGnQTQlKDyi4AIiIAIxBSBbQeOo9eLc5GfD3w3uDsaVS8f8vpLACWApkEnATQlqPwiIAIiIAIxReCpz9fi/fTt6NmkGt67o0NY6i4BlACaBp4E0JSg8ouACIiACMQMgcOZWZ6Nn09k5+Kjv5yHLmdVDUvdJYASQNPAkwCaElR+ERABERCBmCHw2tzNGP31RjStUR5fPdQNcXFxYam7BFACaBp4EkBTgsovAiIgAiIQEwSycvLQbXQa9mWcwovXtsI17WqHrd4SQAmgafBJAE0JKr8IiIAIiEBMEPhk5S48PG01Ti9fGguHpnq2gAlXkgBKAE1jTwJoSlD5RUAEREAEop4AN37uO24hftqbgSEXNcGgXmeFtc4SQAmgaQBKAE0JKr8IiIAIiEDUE1i8+QD6T1yCMkkJSB+eioplS4W1zhJACaBpAEoATQkqvwiIgAiIQNQTuOPdpZiz8Tfc2qke/nFF87DXVwIoATQNQgmgKUHlFwEREAERiGoCm/cfxflj54MLfuc80hNnVi0X9vpKACWApkEoATQlqPwiIAIiIAJRTWD4J2swZelOXNisOt68tb0r6ioBlACaBqIE0JSg8ouACIiACEQtgYPHTqHTyDRwC5hpAzuhQ/3KrqirBFACaBqIEkBTgsovAiIgAiIQtQRenvUzXp61Ca1qp+CzQV3CtvGzN2AJoATQ9KaTAJoSVH4REAEREIGoJHAyOxddRqbh4PEsjLuxDS5vVdM19ZQASgBNg1ECaEpQ+UVABERABKKSwL+X7sCwT35ErYplMG9ITyQmhG/jZ/UA/jnEwvMjfNET6hLA6GlL1UQEREAERKCECOTl5ePCl+dj8/5j+Fvfs3F39wYldOaSOY16ANUDaBpJEkBTgsovAiIgAiIQdQTmbNyPO95dhtNKJ2Lx8FRUSE5yVR0lgBJA04CUAJoSVH4REAEREIGoI3DTxO+xaPNB/KVrffz90mauq58EUAJoGpQSQFOCyi8CIiACIhBVBNbvyUDfcQuQEB/nmftXu1JZ19VPAigBNA1KCaApQeUXAREQARGIKgIPT/sBn6zcjUtbnoFX+7d1Zd0kgBJA08CUAJoSVH4REAEREIGoIbAv4yS6jkpDdm6+Z9+/1nUqurJuEkAJoGlgSgBNCSq/CIiACIhA1BAY/fUGvDZ3C849sxI+vqeza+slAZQAmganBNCUoPKLgAiIgAhEBYHMrBx0GpGGIyeyMeHmdujTvIZr6yUBlACaBqcE0JSg8ouACIiACEQFgQ/St+HJz9ehXpWySHukp2cRiFuTBFACaBqbEkBTgsovAiIgAiIQ8QRy8/LR+8W52HYwE89cfg5u63ymq+skAZQAmgaoBNCUoPKLgAiIgAhEPIFv1v2KgZNWIKVMEtKHp6JsqURX10kCKAE0DVAJoClB5RcBERABEYh4AtdNSMfSbYdwb8+GGNqnqevrIwGUAJoGqQTQlKDyi4AIiIAIRDSB1TsP44rxi5CUEIeFQ1NRvUKy6+sjAZQAmgapBNCUoPKLgAiIgAhENIEHpqzCf1fvwdVtamHs9a0joi4SQAmgaaBKAE0JKr8IiIAIiEDEEth9+AS6j54DLgKZ+WBXnFMzJSLqIgGUAJoGqgTQlKDyi4AIiIAIRCyBf85cj7cWbEXnhlUw+e6OEVMPCaAE0DRYJYCmBJVfBERABEQgIgkcPZmNziPScPRUDt69/Vz0anp6xNRDAigBNA1WCaApQeUXAREQARGISAITF/yC52b+hIbVyuG7wT0Q7+KNn70BSwAlgKY3nQTQlKDyi4AIiIAIRByBnNw89HhhLjgHcMTVLXBjh7oRVQcJoATQNGAlgKYElV8EREAERCDiCMxYswf3T16FKuVKYdGwVCQnJURUHSSAEkDTgJUAmhJUfhEQAREQgYgikJ+fjytfWwzu//dQ70YYfEHjiCo/CysBlACaBq0E0JSg8ouACIiACEQUgeXbDqHfhHSUSozH4mGpqHpa6YgqvwTwj+aKi7hWc1eBJYDuag+VRgREQAREIMgEBk5ajm/W7cMN59bByGtaBvlqwTm9egAlgKaRJQE0Jaj8IiACIiACEUNg+8Hj6DlmLvLzge8Gd0ej6uUjpuzOgkoAJYCmgSsBNCWo/CIgAiIgAhFD4KnP1+L99O3o2aQa3rujQ8SU27ugEkAJoGnwSgBNCSq/CIiACIhARBA4kpmNjiNm40R2Lj686zx0bVQ1Isrtq5ASQAmgafBKAE0JKr8IiIAIiEBEEHht7maM/nojmtYoj68e6oa4uMhdRiABlACa3nQSQFOCyi8CIiACIuB6Alk5eeg2Og37Mk5hzLWt0K9dbdeXuaACSgAlgKYBLAE0Jaj8IiACIiACrifwycpdeHjaapxevjQWDk31bAETyUkCKAE0jV8JoClB5RcBERABEXA1AW783HfcQvy0NwNDLmqCQb3OcnV5AymcBFACGEicFHSMBNCUoPKLgAiIgAi4msDizQfQf+ISlElKQPrwVFQsW8rV5Q2kcBJACWAgcSIBNKWk/CIgAiIgAhFL4I53l2LOxt9wa6d6+McVzSO2Hs6CSwBDI4CDAAwBUAPAagAPAFhaQAT1BDAWwDkAdgJ4DsB7XsdfC+BZAGcC2ARgKIAvvY6pBWAUgIsBlAWwGcAdAJZbx/Gct3nl+QZAnyJEt3oAiwBLh4qACIiACEQWgc37j+L8sfPBBb9zHumJM6uWi6wK+CmtBDD4Ang9gA8A3ANgCYC/AqC8NQGw30e71AewFsAEABMB9AbwMoBLAFDOmDoDmA9gOIAZAPpbAtjWystjKgFYBWAOgNcB/AagEYAt1n88hgJY3ZJCuyinAPxehOiWABYBlg4VAREQARGILALDP1mDKUt34sJm1fHmre0jq/AFlFYCGHwBpPQtA3C/1Q5cNsRevX8BGOmjbdhjR9lz9jH/G0BFR8/cVAD8BLnUkf97AD9Yosl/5rm7AOhWQPtTAHneKw0iWgJoAE9ZRUAEREAE3Evg4LFT6DQyDdwCZtrATuhQv7J7C1vEkkkAgyuAnCWaCaAfgM8cbfO+JV5X+Ggv9uyttHoK7T9z2Ja9gCnWP+ywhoj5b3Z6xhK5VtY/rLd6DLlRUQ8AuwG8BuAtRx4KIOUvy+r1SwPwdwAHC4ij0gD4n534I4i7jhw5ggoV6IJKIiACIiACIhAdBF6e9TNenrUJrWqn4LNBXSJ642fvFpEABlcAa1rixSHbdAf80ZaUnefjFvkZwLsARjj+1hfATGse3wlL2Dh3b4rjmPsAPGUN6fKfT1p/41zCjwGcC+AVq4eQAsp0gyWoWwE0BPA8gGMAOgHI9XP7Pm1d53/+LAGMjoedaiECIiACIvAHgZPZuegyMg0Hj2dh3I1tcHkrvtKjJ0kAo1cA2avHxR6UTzuNs0SQgucrNbDmB54PYLafY9QDGD33v2oiAiIgAiLgh8C/l+7AsE9+RK2KZTBvSE8kJkT2xs/e1ZQABlcAwzkEvB3AdwD+4mj0e60hXq4O9pe4WITDwG8E+FTQHMAAQekwERABERCByCDAjZ8veGk+Nu8/hr/1PRt3d2f/SHQlCWBwBZDRwkUg3PKFW78w8ROCc/heLWARCId8WzhCbTIAzjy1t2fhIhBu63KZ45jFANY4FoEwTx2vRSAvAeCws7NX0BnRnC/IsnFe4BcBhroEMEBQOkwEREAERCAyCMzZuB93vLsMp5VOxOLhqaiQnBQZBS9CKSWAwRdAbgPDOXcDLRHkNjDXAWgKYJ811489crda7WZvAzMewDsAUgFw6NZ7G5h5AIZZcwM5l+9xAM5tYDjnj1LIeYHTAHSwFoAMAPARgNOsv00H8Ks1B5BzE7mog/LJ7WACSRLAQCjpGBEQAREQgYghcPPEJVi4+QDu6lofT1zaLGLKXZSCSgCDL4BsD24BY28Eza1aHrR6Bvk3rsTlZs7c/NlO/N/srWPU7bI2fPa1ETQ3iLY3gn7Mx0bQ3CaGi0m4/x8XenBBiL0KuIy1MrmNtSJ5D4BvATxhiWmgcSQBDJSUjhMBERABEXA9gfV7MtB33ALExwHzH+uF2pU44BZ9SQIYGgGMvsj5/xpJAKO5dVU3ERABEYgxAo9MW43pK3fhkpZnYHx/DqxFZ5IASgBNI1sCaEpQ+UVABERABFxBYF/GSXQdlYbs3HzPvn+t6/C3EqIzSQAlgKaRLQE0Jaj8IiACIiACriDwwjcbMH7OFrSvVwn/udffeklXFNW4EBJACaBpEEkATQkqvwiIgAiIQNgJZGbloNOINBw5kY0JN7dDn+Y1wl6mYBZAAigBNI0vCaApQeUXAREQAREIO4FJ6dvwxOfrUK9KWaQ90hMJXAUSxUkCKAE0DW8JoClB5RcBERABEQgrgdy8fPR+cS62HczEM5efg9s6c4ON6E4SQAmgaYRLAE0JKr8IiIAIiEBYCXy77lcMmLQCFZITkT68N8qVTgxreUJxcQmgBNA0ziSApgSVXwREQAREIKwErpuQjqXbDuHeng0xtA9/pyH6kwRQAmga5RJAU4LKLwIiIAIiEDYCq3cexhXjFyExPg4Lh6aiRkpy2MoSygtLACWApvEmATQlqPwiIAIiIAJhI/DAlFX47+o9uLpNLYy9vnXYyhHqC0sAJYCmMScBNCWo/CIgAiIgAmEhsPvwCXQfPQdcBDLzwa44p2ZKWMoRjotKACWApnEnATQlqPwiIAIiIAJhIfDPmevx1oKt6NywCibf3TEsZQjXRSWAEkDT2JMAmhJUfhEQAREQgZATOHoyG51HpOHoqRy8e/u56NX09JCXIZwXlABKAE3jTwJoSlD5RUAEREAEQk5g4oJf8NzMn9CwWjl8N7gH4qN842dvwBJACaDpTScBNCWo/CIgAiIgAiElkJObhx4vzAXnAI64ugVu7FA3pNd3w8UkgBJA0ziUAJoSVH4REAEREIGQEpixZg/un7wKVcqVwqJhqUhOSgjp9d1wMQmgBNA0DiWApgSVXwREQAREIGQE8vPzceVri8H9/x7q3QiDL2gcsmu76UISQAmgaTxKAE0JKr8IiIAIiEDICCzfdgj9JqSjVGI8Fg9LRdXTSofs2m66kARQAmgajxJAU4LKLwIiIAIiEDICAyctxzfr9uGGc+tg5DUtQ3Zdt11IAigBNI1JCaApQeUXAREQAREICYHtB4+j55i5yM8HvhvcHY2qlw/Jdd14EQmgBNA0LiWApgSVXwREQAREICQEnvp8Ld5P346eTarhvTs6hOSabr2IBFACaBqbEkBTgsovAiIgAiIQdAJHMrPRccRsnMjOxYd3nYeujaoG/ZpuvoAEUAJoGp8SQFOCyi8CIiACIhB0Aq/N3YzRX29E0xrl8dVD3RAXFxf0a7r5AhJACaBpfEoATQkqvwiIgAiIQFAJZOXkodvoNOzLOIUx17ZCv3a1g3q9SDi5BFACaBqnEkBTgsovAiIgAiIQVAKfrNyFh6etxunlS2Ph0FTPFjCxniSAEkDTe0ACaEpQ+UVABERABIJGgBs/XzJuIdbvzcCQi5pgUK+zgnatSDqxBFACaBqvEkBTgsovAiIgAiIQNAKLNx9A/4lLUCYpAenDU1GxbKmgXSuSTiwBlACaxqsE0JSg8ouACIiACASNwJ3vLUPahv24pWM9PHtl86BdJ9JOLAGUAJrGrATQlKDyi4AIiIAIBIXA5v1Hcf7Y+eCC37RHeqJ+1XJBuU4knlQCKAE0jVsJoClB5RcBERABEQgKgeGf/IgpS3fggmbV8dat7YNyjUg9qQRQAmgauxJAU4LKLwIiIAIiUOIEDh47hc4j03AqJw/TBnZCh/qVS/wakXxCCaAE0DR+JYCmBJVfBERABESgxAm8MmsTXpr1M1rWTsHng7rE/MbP3oAlgBJA05tOAmhKUPlFQAREQARKlMDJ7Fx0HZWGA8eyMO7GNri8Vc0SPX80nEwCKAE0jWMJoClB5RcBERABEShRAlOX7cDQ6T+iZkoy5j3WC0kJ2vhZPYB/DrHY/jFA81tOAmjOUGcQAREQAREoIQLc+PnCl+Zj0/5j+Fvfs3F39wYldOboOo16ANUDaBrREkBTgsovAiIgAiJQYgTmbtyP299dhtNKJ2Lx8FRUSE4qsXNH04kkgBJA03iWAJoSVH4REAEREIESI3DzxCVYuPkA7upaH09c2qzEzhttJ5IASgBNY1oCaEpQ+UVABERABEqEwE97M3DxKwsQHwfMG9ILdSqXLZHzRuNJJIASQNO4lgCaElR+ERABERCBEiHwyLTVmL5yFy5peQbG929bIueM1pNIACWAprEtATQlqPwiIAIiIALGBPZlnPRs/ZKdm4/PBnVB6zoVjc8ZzSeQAEoATeNbAmhKUPlFQAREQASMCbzwzQaMn7MF7etVwn/u7Wx8vmg/gQRQAmga4xJAU4LKLwIiIAIiYEQgMysHnUak4ciJbEy4uR36NK9hdL5YyCwBlACaxrkE0JSg8ouACIiACBgRmJS+DU98vg71qpRF2iM9kcBVIEoFEpAASgBNbxEJoClB5RcBERABESg2gdy8fPR+cS62HczEM5efg9s6n1nsc8VSRgmgBNA03iWApgSVXwREQAREoNgEvl33KwZMWoEKyYlIH94b5UonFvtcsZRRAigBNI13CaApQeUXAREQAREoNoHrJqRj6bZDuLdnQwzt07TY54m1jBJACaBpzEsATQkqvwiIgAiIQLEIrN55GFeMX4TE+DgsHJqKGinJxTpPLGaSAEoATeNeAmhKUPlFQAREQASKReCBKavw39V7cHWbWhh7fetinSNWM0kAJYCmsS8BNCWo/CIgAiIgAkUmsPvwCXQfPQdcBDLzwa44p2ZKkc8RyxkkgBJA0/iXAJoSVH4REAEREIEiE/jnzPV4a8FWdG5YBZPv7ljk/LGeQQIoATS9BySApgSVXwREQAREoEgEjp7MRucRaTh6Kgfv3N4eqU2rFym/DgYkgBJA0/tAAmhKUPlFQAREQASKRGDigl/w3Myf0LBaOXw3uAfitfFzkfjxYAmgBLDIQeOVQQJoSlD5RUAEREAEAiaQk5uHHi/MBecAPn9VC/Q/r27AeXXg/xOQAEoATe8HCaApQeUXAREQAREImMCMNXtw/+RVqFyuFBYPS0VyUkLAeXWgBNAZA/rBQLM7QgJoxk+5RUAEREAEAiSQn5+PK19bDO7/92DvRnj4gsYB5tRh3gTUA6geQNO7QgJoSlD5RUAEREAEAiKwfNsh9JuQjlKJ8Vg0NBXVypcOKJ8O+jMBCaAE0PS+kACaElR+ERABERCBgAjcM2kFvl73K65vXwej+rUMKI8O8k1AAigBNL03JICmBJVfBERABESgUALbDx5HzzFzkZ8PfDu4OxpXL19oHh3gn4AEUAJoen9IAE0JKr8IiIAIiEChBJ7+Yh3eW7wNPRpXw/t3dij0eB1QMAEJoATQ9B6RAJoSVH4REAEREIECCRzJzEankbORmZWLD+86D10bVRUxQwISQAmgYQhBAmhKUPlFQAREQAQKJPD63C0Y9fUGNK1RHl891A1xcdrAwzRkJIASQNMYkgCaElR+ERABERABvwSycvLQbXQa9mWcwphrW6Ffu9qiVQIEJIASQNMwkgCaElR+ERABERABvwQ+XbULg6eu9mz5snBoL5RO1MbPJREuEkAJoGkcSQBNCSq/CIiACIiATwLc+PmScQuxfm8GhlzUBIN6nSVSJURAAigBNA0lCaApQeUXAREQARHwSWDxlgPo/9YSJCfFI31Yb1QqV0qkSoiABFACaBpKEkBTgsovAiIgAiLgk8Cd7y1D2ob9uKVjPTx7ZXNRKkECEkAJoGk4SQBNCSq/CIiACIjAnwhs3n8U54+dDy74TXukJ+pXLSdKJUhAAigBNA0nCaApQeUXAREQARH4E4Hhn/yIKUt34IJm1fHWre1FqIQJSABDI4CDAAwBUAPAagAPAFhaQFv2BDAWwDkAdgJ4DsB7XsdfC+BZAGcC2ARgKIAvvY6pBWAUgIsBlAWwGcAdAJZbx3EjpWcA3A2gIoBFAO61zhdoqEkAAyWl40RABERABAIicPDYKXQemYZTOXmYNrATOtSvHFA+HRQ4AQlg8AXwegAfALgHwBIAfwVAeWsCYL+PpqoPYC2ACQAmAugN4GUAlwD4xjq+M4D5AIYDmAGgvyWAba28PKwSgFUA5gB4HcBvABoB2GL9x2MojTzHbQC2WkLZAkAzACcDDCMJYICgdJgIiIAIiEBgBF6ZtQkvzfoZLWun4PNBXbTxc2DYinSUBDD4AkjpWwbgfqtl4q1evX8BGOmjtdhjR9lzznb9t9VD18c6fioAToa41JH/ewA/WKLJf+a5uwDo5ici2Pu3B8CLAMZYx6QA2AfgdgC8ZiBJAhgIJR0jAiIgAiIQEIGT2bnoOioNB45lYdyNbXB5q5oB5dNBRSMgAQyuAHK9eiaAfgA+czTN+5bQXeGjudizt9LqKbT/zGFb9gJS0Jh2WEPE/Dc7cSj3SgCtrH9Yb/UYcsv0HgB2A3gNwFvW3xtYPYFtLHG0zzPP+v8fCjCUJIABgtJhIiACIiAChROYumwHhk7/ETVTkjHvsV5ISmC/iVJJE5AABlcA+dlC8eKQbbqj8UZbUnaejwb9GcC7AEY4/tYXwExrHt8JAFnWsO0UxzH3AXgKQHXr3+whXM4l/BjAuQBesXoIKaAsE+f8sYx7HeeZBiAfAIeufaXSAPifncoD2HXkyBFUqEAXVBIBERABERCB4hHgxs8XvjQfm/Yfw9/6no27u7OvQikYBCSABQtgIgAuyGgIYDKAo5YwZQA4FkCDhFMAKYlc7EHRs9M4SwQ7GQjg05Zo/k/1JYABRIMOEQEREAERKJDA3I37cfu7y3Ba6UQsHp6KCslJIhYkAhJA/wJYD8DXAOpaPV6NAfxi9aKxB4yLOgpL4RwC3g7gOwB/cRSSK3z/DoCrg4s7BKwewMJaXX8XAREQAREoFoGbJy7Bws0HcFfX+njiUq5HVAoWAQmgfwHknD32+N0F4KA1t44CyB5BzqPjitpAEheBcMsXbv3CxMkMnMP3agGLQDjky9W4dmLvI9fAOxeBcFuXyxzHLAawxiGmzFPHaxHISwA47MxeQXsRCBeAcCEIE8dwuTJZi0ACaVkdIwIiIAIiUGIEftqbgYtfWYD4OGDekF6oU5mvOaVgEZAA+hdASh9FaaMlglxcQQHkvntcYBFoZHIuHefcDbREkNvAXAegqbXilnP92CN3q9XI9jYw4wG8AyAVAIduvbeB4WKNYdbcwBsAPA7AuQ0M5/xRCjkvkPP6OljiOgDAR9a1uA0Mz+HcBqaltoEJ1u2m84qACIiACPgj8Mi01Zi+chcuaXkGxvfn60wpmAQkgP4F8HdrGxXKHnsCbQHsCmC6Y7FFIO3DLWDsjaC5VcuD1p6AzMsNnimV7Fm0E/83e+vY/73L2p/P10bQ3CDa3gj6MR8bQXObGAomeyu5zx8XhNirgHkteyNoSiE3gl4IgItJuBAl0KRVwIGS0nEiIAIiIAI+CezPOIkuo9KQnZuPT+/rjDZ1uZWtUjAJSAD9CyD32jsCgHJEAWTPGDdT/twawuXWLEp/DBsf0SIQhYIIiIAIiEBxCbzwzQaMn7MF7etVwn/uda5dLO4Zla8wAhJA/wLI/fP4yxvsJWMPGlfU8v8eANDdz694FMY7Gv8uAYzGVlWdREAERCBEBDKzcjw/+3Y4MxsTbm6LPs3PCNGVY/syEsDCt4HhHD4O/55mbdDM+XPci0/pDwISQEWCCIiACIhAsQlMSt+GJz5fh7qVy2LOoz2RwFUgSkEnIAH0LYDceOgNa+4d584p+ScgAVR0iIAIiIAIFItAXl4+Ul+ci20HM/H0Zc1wexeug1QKBQEJoP8eQM7/a20tnghFW0TqNSSAkdpyKrcIiIAIhJnAt+t+xYBJK1AhORHpw3ujXGn+/oJSKAhIAP0LILdu4YpdrsZVUg+gYkAEREAERKCECVz3RjqWbj2Ee3o0xLCLuTuaUqgISAD9CyB/MeMRALMBrABw3KtRuDefkuYAKgZEQAREQASKQWDNrsO4/NVFSIyPw8KhqaiRklyMsyhLcQlIAP0LYEFz//Ktn1IrLvdoyqch4GhqTdVFBERABEJE4MEpq/DF6j24qk0tvHQ9Z1wphZKABLDgVcChbItIvZYEMFJbTuUWAREQgTAR2H34BLqPnoPcvHzMeKArmtdKCVNJYveyEsDABNBek86eP6X/JSABVESIgAiIgAgUicDzX/6EN+f/gk4NqmDKgI5FyquDS4aABLBgAeTv8/In3LgBNBN/Iu0FAJNKBn9UnEUCGBXNqEqIgAiIQGgIHD2Zjc4j0nD0VA7eub09UptWD82FdZX/ISAB9C+AD1v7AL4KYJFFjb8DPAgAF4hodfAfUCSAeqiIgAiIgAgETODthVvx7Iz1aFCtHGYN7oF4bfwcMLuSPFACWPAikKcAfOAF/DYATwPQbpUSwJK8F3UuERABEYh6Ajm5eejxwlxwDuDzV7VA//PqRn2d3VpBCaB/ATwJoDmAzV6Nx+HgHwFovboE0K33tcolAiIgAq4kMHPNXgyavBKVy5XC4mGpSE5KcGU5Y6FQEkD/ArgWwGQAz3sFAod/+fvALWIhQAKoo4aAA4CkQ0RABEQg1gnk5+fjqtcW44edh/Fg70Z4+ILGsY4krPWXAPoXwGsATAUwyzEHsAuA3gCuA/BpWFvOPReXALqnLVQSERABEXAtgeXbDqHfhHSUSozHoqGpqFa+tGvLGgsFkwAWvAq4HYDBAM62guEnAC8CWBULwRFgHSWAAYLSYSIgAiIQywTumbQCX6/7Fde3ZlpPkgAAIABJREFUr4NR/VrGMgpX1F0CGNg+gK5oLJcWQgLo0oZRsURABETALQS2HzyOnmPmIj8f+HZwdzSuXt4tRYvZckgA/QtgXwC5AL7xio6LAMQD+Cpmo+Z/Ky4BVCCIgAiIgAgUSODpL9bhvcXb0KNxNbx/ZwfRcgEBCaB/AVxjbQLtLYB9AIwC0MoF7eeGIkgA3dAKKoMIiIAIuJTAkcxsdBo5G5lZufjwrvPQtVFVl5Y0toolAfQvgCesuX/bvELiTADrAJSLrVDxW1sJoAJBBERABETAL4HX527BqK83oGmN8vjqoW6Ii7N/XVXQwklAAuhfAH8F0B9AmlcDnW9tD3N6OBvORdeWALqoMVQUERABEXATgaycPHQbnYZ9Gacw5tpW6NeutpuKF9NlkQD6F8A3AHQCcBWALVaUnAVgOoBlAP4S05Hz/5WXACoQREAEREAEfBL4dNUuDJ662rPly8KhvVA6URs/uyVUJID+BTAFwNcA2gPYZTVYHQDzAVwN4LBbGjHM5ZAAhrkBdHkREAERcCMBbvx8ybiFWL83A0MuaoJBvdiHouQWAhLAgreB4USFC6wFH5wTuBrAArc0nkvKIQF0SUOoGCIgAiLgJgKLtxxA/7eWIDkpHunDeqNSuVJuKl7Ml0UC+GcB5LBvFQAzHNFxG4BnAJQF8BmABwCcivno+QOABFCBIAIiIAIi8CcCd763DGkb9uOWjvXw7JXNRchlBCSAfxZA7u8319rqhc3F3/xdAeB9APwlkCEAOD/waZe1ZbiKIwEMF3ldVwREQARcSmDz/mM4f+w8cMFv2iM9Ub+qNs5wW1NJAP8sgHsBXAZgudVY/wTQA0BX6/+/1uoNbOa2xgxTeSSAYQKvy4qACIiAWwkM/+RHTFm6Axc0q463buVUeiW3EZAA/lkATwJoBGCn1VgLrV/9oAgycR/AHwHod2z+4CEBdNtdrfKIgAiIQBgJHDx2Cp1HpuFUTh6mDuiI8xpwVpWS2whIAP8sgNsB3GKt9uWMVa72ZY/gbKvxOCQ8D0BltzVmmMojAQwTeF1WBERABNxI4JVZm/DSrJ/RsnYKPh/URRs/u7GRAEgA/yyAr1urfocCuBIAF4DUBJBlteFNAP4K4FyXtmmoiyUBDDVxXU8EREAEXErgZHYuuo5Kw4FjWXjlhta4onUtl5ZUxZIA/lkA+SOFn1hz/o5ZAvipI1TYE/g9gL8pfDwEJIAKBBEQAREQAQ+Bqct2YOj0H1EzJRnzHuuFpIR4kXEpAQlgwRtBUwBzvdqOQ7/8d7tH0KVNG7JiSQBDhloXEgEREAH3EuDGzxe+NB+b9h/D432bYkD3hu4trEqmIWAUvBG0QqRwAhLAwhnpCBEQARGIegJzN+7H7e8uQ7lSCUh/vDcqJCdFfZ0juYLqAZQAmsavBNCUoPKLgAiIQBQQuOXtJViw6QDu7FIfT16mndLc3qQSQAmgaYxKAE0JKr8IiIAIRDiBn/Zm4OJXFiA+Dpg3pBfqVOYPZym5mYAEUAJoGp8SQFOCyi8CIiACEU7g0Y9X4z8rduGSFmdg/E1tI7w2sVF8CaAE0DTSJYCmBJVfBERABCKYwP6Mk+gyKg3Zufn49L7OaFO3UgTXJnaKLgGUAJpGuwTQlKDyi4AIiEAEExjzzUa8Omcz2tWrhOn3do7gmsRW0SWAEkDTiJcAmhJUfhEQARGIUAKZWTmen307nJmNCTe3RZ/mZ0RoTWKv2BJACaBp1EsATQkqvwiIgAhEKIFJ32/HE5+tRd3KZTHn0Z5I4CoQpYggIAGUAJoGqgTQlKDyi4AIiEAEEsjLy0fvsfOw9cBxPH1ZM9zepX4E1iJ2iywBlACaRr8E0JSg8ouACIhABBL4dt2vGDBpBSokJyJ9eG+UK50YgbWI3SJLACWAptEvATQlqPwiIAIiEIEErnsjHUu3HsI9PRpi2MVNI7AGsV1kCaAE0PQOkACaElR+ERABEYgwAmt2Hcblry5CYnwcFg5NRY2U5AirgYorAZQAmt4FEkBTgsovAiIgAhFG4MEpq/DF6j24qk0tvHR96wgrvYpLAhJACaDpnSABNCWo/CIgAiIQQQR2Hz6B7qPnIDcvHzMe6IrmtVIiqPQqqk1AAigBNL0bJICmBJVfBERABCKIwPNf/oQ35/+CTg2qYMqAjhFUchXVSUACKAE0vSMkgKYElV8EREAEIoTA0ZPZ6DwiDUdP5eCd29sjtWn1CCm5iulNQAIoATS9KySApgSVXwREQAQihMDbC7fi2Rnr0aBaOcwa3APx2vg5Qlruz8WUAEoATYNXAmhKUPlFQAREIAII5OTmoccLc8E5gM9f1QL9z6sbAaVWEf0RkABKAE3vDgmgKUHlFwEREIEIIDBzzV4MmrwSlcuVwuJhqUhOSoiAUquIEkD/MaAfLjS7PySAZvyUWwREQARcTyA/Px9XvbYYP+w8jAd7N8LDFzR2fZlVwIIJqAdQPYCm94gE0JSg8ouACIiAywms2H4I17yejlKJ8Vg0NBXVypd2eYlVvMIISAAlgIXFSGF/lwAWRkh/FwEREIEIJ3DPpBX4et2vuL59HYzq1zLCa6Pik4AEUAJoeidIAE0JKr8IiIAIuJjA9oPH0XPMXOTnA98O7o7G1cu7uLQqWqAEJIASwEBjxd9xEkBTgsovAiIgAi4m8PQX6/De4m3o0bga3r+zg4tLqqIVhYAEUAJYlHjxdawE0JSg8ouACIiASwkcycxGp5GzkZmVi0l3dUC3RtVcWlIVq6gEJIASwKLGjPfxQRHAzfuP4ZffjpmWTflFwCeBNnUraRK7YkMEAiDw+twtGPX1BjStUR5fPdQNcXHaOCMAbBFxiARQAmgaqEERwJdn/YyXZ20yLZvyi4BPAuWTEzHuxjbo1eR0ERIBEfBDICsnD91Gp2Ffxim80K8lrm1fR6yiiIAEUAJoGs5BEcCpy3Zg6rKdpmVTfhH4E4GDx7Ow/WAm2JHx6IVNcF/PhurVUJyIgA8Cn67ahcFTV3t6yxcO7YXSidr4OZoCRQIoATSN56AIoGmhlF8E/BFgr8Yz/12Hj5bs8BzSt0UNvNCvFcqVThQ0ERABiwA3fr70Xwuxbk8GHr2wMe5PbSQ2UUZAAigBNA1pCaApQeUPC4EpS3fgyc/XIjs3H02ql8ebt7ZDvSrlwlIWXVQE3EZg8ZYD6P/WEiQnxSN9WG9UKlfKbUVUeQwJSAAlgIYhBAmgKUHlDxsB/rrBPR+uxG9HTyGlTJJnXiC3ulASgVgncNd7yzB7w37c3LEunruyRazjiMr6SwAlgKaBLQE0Jaj8YSWwL+MkBk5a4fmN0/g44LE+TTGwewPNCwxrq+ji4STAXRjOHzvPM0929sM90KDaaeEsjq4dJAISQAmgaWhJAE0JKn/YCZzKycWTn63D1OV/LDy6tOUZGN2vJcqW0rzAsDeOChByAo9/+iMmL9mB88+ujom3tQ/59XXB0BCQAEoATSNNAmhKUPldQYCT3j9csgPPfLEOOXn5nn3P3rq1PepULuuK8qkQIhAKAgePnULnkWk4lZOHqQM64rwGVUJxWV0jDAQkgBJA07CTAJoSVH5XEVi69RDu+2gFDhzLQsWySRjfvy26nFXVVWVUYUQgWATGzd6Esd/9jBa1UvDF/V00FSJYoF1wXgmgBNA0DCWApgSV33UE9h45gXsmrcDqXUc88wIf73s27upaXy9D17WUClSSBE5m56LrqDTPx88rN7TGFa1rleTpdS6XEZAAhkYABwEYAqAGgNUAHgCwtIBY6AlgLIBzAHBS0nMA3vM6/loAzwI4EwB/MmMogC8dxzwN4CmvPBsBNHX8G895m9cx3wDoU4Q4lQAWAZYOjRwCfBn+/bO1+M+KXZ5CX9m6JkZc3RJlSmkz3MhpRZW0KAS4Af/Q6T+iZkoy5j3WC0kJ8UXJrmMjjIAEMPgCeD2ADwDcA2AJgL8CoLw1AbDfR7zUB7AWwAQAEwH0BvAygEsAUM6YOgOYD2A4gBkA+lsC2NbKy2MogP0AnO+4Rg6AA14CWB3AHY5/OwXg9yLEsQSwCLB0aGQR4LzAD9K34x8z1iM3Lx/n1KyAN25ph9qVNC8wslpSpS2MAGP9wpfmY9P+Y3i8b1MM6N6wsCz6e4QTkAAGXwApfcsA3G/FCj+p2Kv3LwAjfcTPKEv2mjv+9m8AFR09c1MBcMfaSx3HfA/gB0s0bQG8EkDrAmKUPYA8L48rbpIAFpec8kUMge9/OYj7PlqJQ8ezULlcKbzavw06N9S8wIhpQBW0UAJzN+7H7e8uQ7lSCUh/vDcqJCcVmkcHRDYBCWBwBZBbp2daPXGfOULlfUu8rvARPuzZW2n1FNp/Zg8dewFTrH/gb1hxiJj/ZqdnLJFrZf0DewA57HwEwEkA6VaP4R+/f/VHogBS/rKsXr80AH8HcLCAsC4NgP/ZqTyAXUeOHEGFCnRBJRGITgK7D5/AwEnLsXZ3BhLi4/C3vmfjji5nal5gdDZ3zNXqlreXYMGmA7izS308eVmzmKt/LFZYAhhcAawJYLc1ZEsBs9NoAD0AnOcj6H4G8C6AEY6/9QUwEwDHnU5Ywsa5e1Mcx9xnzfnjkC7TxQC4eyfn/Z1h/Y0zetmzeNQ65gZLULcCYH//8wCOAegEINfPDeFrbiEkgLH4+Ii9OnNe4PBPfsSnq3hbA1e3rYXnr2qB5CTNC4y9aIieGv+0NwMXv7LAs+Bp3pBe2vooepq2wJpIAKNXAL0bnkO92wE8DOBtP1HRAMAWa97gbD/HqAcwRh4OqqZvApwr9c6ibXj+y5888wJb1k7BhJvboWbFMkImAhFJ4NGPV3sWO13S4gyMv4lTyZVigYAEMLgCGM4hYF/xy7mIs6yhYH/x/Zs1DPxGgDeA5gAGCEqHRReBxZsPYNDklfg9MxtVTyvl2S9Qm+ZGVxvHQm32Z5xEl1FpyM7Nx6f3dUabupViodqqIwAJYHAFkEHGRSDc8oVbvzBxEQjn4b1awCIQDvk6f317MoDKXotAOBx8mSOKFwNY41gE4h3gHA7m4hNuDTPOT/TXtsrGeYFfBHiHSAADBKXDoo/AzkOZnt8RXr83A4nxcZ65U7d0rKd5gdHX1FFbozHfbMSrczajXb1KmH4vN5hQihUCEsDgCyC3geGij4GWCHIbmOus/fj2WXP9ODfvVivo7G1gxgN4B0CqJWze28DMAzDMmhvIuXyPA3BuAzMGwH+tYV/OReQiEa4I5uxe9vJRCCmD0wH8as0B5NxELuqgfHI7mECSBDAQSjomagmcyMrF0Olr8MXqPZ46Xte+Nv5xRXPNC4zaFo+eimVm5Xh+9u1wZjYm3NwWfZpzurhSrBCQAAZfABlL3ALG3giaW7U8aPUM8m9cicvNnLn5s534v1+yZI270HLDZ18bQXODaHsj6Me8NoLm1jHdAfCHHCl8CwH8zZrjx+twwhJXJrexViTz7fUtgCcAUEwDTRLAQEnpuKglwHmBExdsxYivfkJePtCqTkW8cXM71EhJjto6q2KRT2DS99vxxGdrUbdyWcx5tKdndbtS7BCQAIZGAKM5oiSA0dy6qluRCCzY9Bvun7wKR05wXmBpT69K+zM5e0NJBNxFIC8vH73HzsPWA8fx9GXNcHsXDj4pxRIBCaAE0DTeJYCmBJU/qgjsOJiJAZOWY8OvR5GUEIenLz8HN51XL6rqqMpEPoHv1u/D3R8sR4XkRKQP741ypRMjv1KqQZEISAAlgEUKGB8HSwBNCSp/1BHg3KohH6/BzB/3eup2Y4c6HhEsnaj9AqOusSO0Qte9kY6lWw/hnh4NMexi50/ER2iFVOwiE5AASgCLHDReGSSApgSVPyoJcF7ghHm/YPQ3G5CfD7StW9GzX+DpFTQvMCobPIIqtWbXYVz+6iLPyvUFQ3vhjBTtYRlBzVdiRZUASgBNg0kCaEpQ+aOaAH9j9cEpq5BxMgenly+NCbe0Q1vttRbVbe72yjEeuWr9qja18NL1Bf1cvNtrovKZEJAASgBN4od5JYCmBJU/6glsO3DcMy/w533HUCohHv+44hzc0KFu1NdbFXQfgT2HT6Db6DmeX7GZ8UBXNK9l/8S8+8qqEgWXgARQAmgaYRJAU4LKHxMEjp3KwaPTVuPrddx2E7i5Y108eek5KJXIveGVRCA0BPgThm/O/wWdGlTBlAEdQ3NRXcWVBCSAEkDTwJQAmhJU/pghwHmB4+dsxovf/eyZF3jumZU8v716ennNC4yZIAhjRfkR0un52Th6Kgdv39Yevc+uHsbS6NLhJiABlACaxqAE0JSg8sccgbQN+/DQlB88L+IaFZI98wJb16kYcxxU4dASeHvhVjw7Yz0aVCuHWYN7IF4bP4e2AVx2NQmgBNA0JCWApgSVPyYJbPntGAZ8sBxbfjvuGQZ+7srmuK59nZhkoUoHn0BObh56jpmLXb+fwD+vaq69KYOP3PVXkABKAE2DVAJoSlD5Y5bA0ZPZeHjaanBTXqbbOtXD3y9thqQEzQuM2aAIUsVnrtmLQZNXolLZJM/Gz8lJ2pMySKgj5rQSQAmgabBKAE0JKn9ME+BPco1L24SXZ23ycOhQvzJeu6mt56fklESgpAhc9doirNpxGA+mnoWHL2xSUqfVeSKYgARQAmgavhJAU4LKLwKApxdw8NQfwIn6NVOS8cYt7dGitrboUHCYE1ix/RCueT3dswXRomGpqFZeHxfmVCP/DBJACaBpFEsATQkqvwhYBDbv/2Ne4C8HjqN0YjxGXN0CV7etLT4iYETg3g9X4Ku1v+K69rUxul8ro3Mpc/QQkABKAE2jWQJoSlD5RcBBIONkNgb/+wfM3rDf8693dqmPx/s2RaLmBSpOikFgx8FM9BwzB3n5wLeDu6Nx9fLFOIuyRCMBCaAE0DSuJYCmBJVfBLwIcF7gy7N+xri0zZ6/dG5YBa/2b4vK5UqJlQgUicDTX6zDe4u3oXvjavjgzg5FyquDo5uABFACaBrhEkBTgsovAn4IfL32Vzwy7Qccz8pFrYpl8MYt7fTTXYqWgAkcycxGp5GzkZmVi0l3dUC3RtUCzqsDo5+ABFACaBrlEkBTgsovAgUQ+HnfUc+8wG0HM5GcFI9R17TEFa1riZkIFErg9blbMOrrDWhaozy+eqgb4uLiCs2jA2KHgARQAmga7RJAU4LKLwKFEGBPzkNTV2Huxt88R97drT6G9tG8QAWOfwJZOXnoNjoN+zJO4YV+LXGtNhlXuHgRkABKAE1vCgmgKUHlF4EACOTm5ePFbzfitblbPEd3Pasq/nVjG1TSvMAA6MXeIZ+u2oXBU1d7tnxZOLQXSidq4+fYi4KCaywBlACa3hMSQFOCyi8CRSDAX3R49OPVOJGdizqVy+DNW9rj7DN4GyqJwB8E8vPzcem/FmLdngw8emFj3J/aSGhE4E8EJIASQNPbQgJoSlD5RaCIBDb8moEBH6zAjkOZKJOUgBeubYlLW9Ys4ll0eLQSWLzlAPq/tcQzZzR9WG/1EkdrQxvWSwIoATQMIUgATQkqvwgUg8DhzCw8MGUVFmw64Ml9T4+GGHJREyTEa6J/MXBGVZa73lvm2Ufy5o518dyVLaKqbqpMyRGQAEoATaNJAmhKUPlFoJgEOC9w9Dcb8Ma8Xzxn4F5v/7qhDVLKJhXzjMoW6QT4azLnj50HLvid/XAPNKh2WqRXSeUPEgEJoATQNLQkgKYElV8EDAl8sXoPHvvPapzMzkO9KmU98wKb1NAvPhhijcjsj3/6IyYv2YHzz66Oibe1j8g6qNChISABlACaRpoE0JSg8otACRBYvycDAyYtx67fT6BsqQS8eG0rXNzijBI4s04RKQQOHjuFziPTcConD1MHdMR5DapEStFVzjAQkABKAE3DTgJoSlD5RaCECBw6noX7J6/E4i0HPWe8v9dZGHxBY80LLCG+bj/NuNmbMPa7n9GiVgq+uL+LNn52e4OFuXwSQAmgaQhKAE0JKr8IlCCBnNw8jPxqAyYu3Oo5a68m1fAy5wWW0bzAEsTsulOdzM5F11FpOHAsC6/c0Fq/FuO6FnJfgSSAEkDTqJQAmhJUfhEIAoHPVu3G0OlrPMOB9auWw1u3tsNZp2teYBBQu+KU05btxGPT1+CMlGTMf6wXkhLiXVEuFcK9BCSAEkDT6JQAmhJUfhEIEoG1u49g4KQV2H34BE4rnYix17XChefUCNLVdNpwEeDGzxe9PB8/7zuGx/s2xYDuDcNVFF03gghIACWApuEqATQlqPwiEEQCXBgwaPJKfP/LIc9VHurdyPNfvPYLDCL10J563s+/4bZ3lqJcqQQsHt5bw/2hxR+xV5MASgBNg1cCaEpQ+UUgyASyc/Pw/Jc/4d1F2zxX4hYhL13fCuWTNS8wyOhDcvpb3l7i2RD8zi718eRlzUJyTV0k8glIACWAplEsATQlqPwiECIC01fswvBPf0RWTh4aViuHN29tj4baKDhE9INzGf4sYJ+XF4AduvOG9EKdymWDcyGdNeoISAAlgKZBLQE0Jaj8IhBCAmt2HfbMC9x75CTKl07ES9e3xvnNqoewBLpUSRJ49OPV+M+KXbikxRkYf1Pbkjy1zhXlBCSAEkDTEJcAmhJUfhEIMYHfjp7CoI9WYum2P+YFPnxBY8+egZoXGOKGMLzc/oyT6DIqDdm5+fjkvs5oW7eS4RmVPZYISAAlgKbxLgE0Jaj8IhAGAhwGfm7menyQvt1z9QubVcfY61t7VgsrRQaBMd9sxKtzNqNdvUqYfm/nyCi0SukaAhJACaBpMEoATQkqvwiEkQD3j/v7Z2uRlZuHRqef5pkXyH0DldxN4ERWLjqNnI3Dmdl4/aa2+tk/dzeXK0snAZQAmgamBNCUoPKLQJgJrNrxO+75cAX2ZZxC+eREjLuxDXo1OT3MpdLlCyIw6fvteOKztahTuQzmPtpLP/encCkyAQmgBLDIQeOVQQJoSlD5RcAFBPYfPYl7P1yJFdt/R1wc8OiFTXBfz4b6PVkXtI13EfLy8tF77DxsPXAcT13WDHd0qe/CUqpIbicgAZQAmsaoBNCUoPKLgEsIcF7gM/9dh4+W7PCUqG+LGnihXyuU07xAl7TQH8X4bv0+3P3Bck9v7ffDe6t9XNU6kVMYCaAE0DRaJYCmBJVfBFxGYMrSHXjy87We1aVNqpfHm7e2Q70qmhfolma6/o10LNl6CAN7NMDwi892S7FUjggjIAGUAJqGrATQlKDyi4ALCazYfgj3fLgS3DImpUySZ15gj8bVXFjS2CrSj7uO4LJXFyIxPg4LhvbCGSllYguAaltiBCSAEkDTYJIAmhJUfhFwKYF9GSc9m0b/sPOw55cmHuvTFAO7N9C8wDC210P/XoXPf9iDq9rU8mzirSQCxSUgAZQAFjd27HwSQFOCyi8CLiZwKicXT362DlOX7/SU8tKWZ2B0v5YoW0r7BYa62fYcPoFuo+cgNy8fMx7oiua1UkJdBF0vighIACWApuEsATQlqPwi4HIC+fn5+HDJDjzzxTrk5OWjaY3yeOvW9vrd2RC32/Nf/oQ35/+CTg2qYMqAjiG+ui4XbQQkgBJA05iWAJoSVH4RiBACS7cewn0frcCBY1moWDYJ4/u3RZezqkZI6SO7mMdO5aDT87Nx9FQO3r6tPXqfrd9vjuwWDX/pJYASQNMolACaElR+EYggAnuPnMA9k1Zg9a4jnnmBj/c9G3d1ra95gUFuw7cXbsWzM9ajQbVymDW4h363Oci8Y+H0EkAJoGmcSwBNCSq/CEQYgZPZuZ6fj/vPil2ekl/ZuiZGXN0SZUolRFhNIqO4Obl56DlmLnb9fgL/vKo5bjqvXmQUXKV0NQEJoATQNEAlgKYElV8EIpAA5wV+kL4d/5ix3rMo4ZyaFfDGLe1Qu1LZCKyNu4s8c81eDJq8EpXKJiF9eG8kJ0m03d1ikVE6CaAE0DRSJYCmBJVfBCKYwPe/HMSgj1bi4PEsVC5XCq/2b4PODTUvsCSb9KrXFmHVjsN4MPUsPHxhk5I8tc4VwwQkgBJA0/CXAJoSVH4RiHACuw+fwMBJy7F2dwYS4uPwt75n444uZ2peYAm0Kzfkvub1dJRKiMeiYamoVr50CZxVpxABQAIoATS9DySApgSVXwSigADnBQ7/5Ed8umq3pzZXt62F569qoeFKw7a998MV+Grtr7iufW2M7tfK8GzKLgL/T0ACKAE0vR8kgKYElV8EooQA5wW+s2gbuF8d5wW2rJ2CCTe3Q82K+rmy4jTxjoOZ6DlmDvLygW8Hd0fj6uWLcxrlEQGfBCSAEkDTW0MCaEpQ+UUgyggs3nzAs2jh98xsVD2tlGe/wPMaVImyWga/Ok9/sQ7vLd6G7o2r4YM7OwT/grpCTBGQAEoATQNeAmhKUPlFIAoJ7DyU6fkd4fV7M5AYH4cnL2uGWzrW07zAANv6SGY2Oo2cjcysXEy6qwO6NaoWYE4dJgKBEZAASgADixT/R0kATQkqvwhEKYETWbkYOn0Nvli9x1NDzmP7xxXN/6+9M4GSqjjb8MO+iQgGBBEVUFGURSAKcUFEceVXE1RckJhE3FCRoIDxN8aYoLgRRAVFY3BhSYzEqGgUEEUW2REUQUBWAQHZGWCYyfma6qTT9jC3p6Z7uue+dY7nyHRV3arnft39dG1X6wID3O+hk5byyLhFkcfujbvrLIlzAGbKkhwBCaAEMLmI+WFuCaAvQZUXgVJMwNYFDv9kOQPGfRlZy9aiwWEMu741dWtULsW99uva3tw8zh44kXXbcnisS3OubNPAr0KVFoEEBCSAEkDfN4YE0JegyotACAh8suQ77hg5hy2RdYGVGHp9K9ocWysEPU++i2PnrKHX6LmRI18m9+1ApfI6+Dl5iipRGAEJoASwsBgp7HUJYGGE9LoIiECEgO1q7fERDHG6AAAbOklEQVTKTBat206FcmV48P9O1mPN4mLDRkwvfXoyC9duo0+nE+h57vGKHhFICQEJoATQN7AkgL4EVV4EQkRg195c7vnrfN75/NtIr685rUFEBDXKdSAIpi7dxDUvTKNyhbJM7deRmtUqhig61NV0EpAASgB9400C6EtQ5UUgZARslGvopGUMfH8R+fnQ6ujDIucF1jlU6wJ/+fIMxi/awPVtj+bhy5uFLDLU3XQSkABKAH3jTQLoS1DlRSCkBD76agN3jpzDtpxc6lSvxNBurWl1dM2Q0oCl3+2g4xOTKFMGxvduT6Pah4SWhTqeegISQAmgb5RJAH0JqrwIhJjANxt3RtYFLl6/I/K824cuO5mupx0dSiL3vfk5r09fyXknHcHw7m1CyUCdTh8BCaAE0DfaJIC+BFVeBEJOYMeeXPqMmcd7C9dFSNj05wOXnkzF8mVDQ2bzzr20GzCePbl5jOrRlrZ6ckpo7n1JdVQCKAH0jT0JoC9BlRcBEcDWBT4z8Wue+GBxZF3gj4+tyTPXtaJO9XCsCxw8fglPfrCYZvVr8FbPM3Tws94TKScgAZQA+gaZBNCXoMqLgAj8h8CEReu5a9RctufkUvfQypF1gS0bHFaqCeXs28+Zj05g4469/KlrSy5rWb9U91edywwCEkAJoG8kSgB9Caq8CIjA/xBY9t0Oerwyi6837IhMAz98+SlcVYqfhjFmxirufWM+9WpU5uN7O1ChXHimvhX6JUdAAigB9I0+CaAvQZUXARH4AYHtOfvoPWYeH3yxPvJa93bHcP+lTUudHNnU9wWDPo5sgul/0Ync3L6xokEE0kJAAigB9A00CaAvQZUXARFISCAvL5/BE5Yw6MMlkddPa1iLZ69rFXmUXGlJkxZ/R/eXPqNaxXJM6d+RGlUqlJauqR8ZTkACmB4BvB24B6gLzAPuAD47SGycAzwJnAysAh4GXo7LfyXwe+BYwD4d+wLvxuR5EPhtXJmvgBNj/lYG+B1wE2CLbD4FbnX1BQ1dCWBQUsonAiJQJAI2Cnj36LnYbuEja1RmWLc2NDuqRpHqyrRC3V6czidLNvKLMxryQOemmdY8tacUE5AApl4ArwZGALcA04FegMlbE2BDgthqCCwAhgLDgY7AIOAS4H2X/yfAx0B/4G3gWieArVxZy2YC2AU4L+YaucDGmH+bNFod3YHlTijt6Hn7FMoJGPcSwICglE0ERKDoBGw9YI8RM1m2cSeVypdlwE+b8dNWRxW9wgwouWjdNi4c9Ally8CkezrQoFbVDGiVmhAWAhLA1AugSd8MoKcLKlvda6N6TwOPJAi0R53snRLz2ig3Qneh+9tooBpwaUyeacBcJ5pRAbwcaFlAMNvo31rgCeBxl8d+UtuCm58Dds0gSQIYhJLyiIAIeBPYlrOPu0fNjTwqzZKNmt138YmUz9JNE33+Oo+/zVrNJc3qRY68URKBdBKQAKZWAO0p3rvcSNzYmBv7Fyd0lyW42TayN9uNFEZfvtGNAkbnPFa6KWIbGYwmm8o14Wvh/mAjgDbtvNWN5k11o31W1lIjYClwqhPHaD2T3L/vKiAQbfFN7AKc6sDqrVu3cuih5oJKIiACIpA6ArYucNCHixk84evIRX7S+HCGXNuKWtXs4zZ70oZtOZzx6AT27c/n77f9JNSPwMueu1a6WioBTK0AHgmssc8owAQsmgYC7YHTE4TTYuDPwICY1y4G3gFsfmA3sNdN246MyXObW/N3hPvbRYA9SNLW/dVzr9nhUjayuN21ydb8WRu/jalnDJAP2NR1opRobSESwNL1waDeiECmE3hvwTp+PWYuO/fup/5hVRjWrTWn1M+edYGPv/8VQyZ+TetjavLGrfYVoSQC6SUgASy9AhgfSbbJYwXQG3jRQwA1Apje96iuJgIiUACBJeu3c9OImXyzaReVK5Tl0Z81z4pDlHfv3U+7R8azZdc+nruuFRc1s9/oSiKQXgISwNQKYElOASeKJFuL+KGbCi7qFHB8vVoDmN73rK4mAiIQQ2Dr7n3cNWoOH331XeSvN53VkL4XZva6wFemreD/xy6gQa0qfNSnA+VsF4iSCKSZgAQwtQJot9M2gdiRL3b0iyXbBGLr8IYcZBOITfnabtxoeh2oBcRuArHp4M4xeaYA82M2gcSHkk0H2+YTOxpmMAf6bZtAbAOIbQSxZDJnq6u1CSTNb0RdTgREoOgE9ufl88S/vuLZj2xZM5x53I94+ppTqZmB6wJtDWPHJyexfONOftu5KTeeYQc/KIlA+glIAFMvgLaWzjZ93OxE0I6Bucqdx2c7bm2tn63Nu8Hd/ugxMM8ALwHnOmGLPwbGNmv0c2sDuwL3AbHHwJjY/dNN+9o6P9skYjuC7YiXAz+VD5wdaHXEHgPTXMfApP+NqCuKgAj4E3hn/rfYztrd+/ZHRtee79aGk+pl1uY0O9PQpq2rVy7PtP4dqVapvH/HVYMIFIGABDD1Ami3xY6AiR4EbUe13OlGBu01O+DZDnO2w5+jyf7/KSdiq935fIkOgrYDoqMHQd8bdxC0HeNyNnC4E77JwG/czt/odaIHQfdwu5Itj20msY0oQZOmgIOSUj4REIGUE7Cz9XqMmMXKzbuoUqEcj13ZnEub22/gzEhXD5vK9OWbubl9I/pfdFJmNEqtCCUBCWB6BLA0B5cEsDTfXfVNBLKQwJZde7lj5JzIEzYs3dK+Mfdc0KTE19p9vnornYdMpnzZMnzStwP1alTJQrpqcmkhIAGUAPrGsgTQl6DKi4AIFDsBWxc48P1FDJu0LFL32SfU5umup1Kjask9a9c2q/xj7loub3kkg7raEaxKIlByBCSAEkDf6JMA+hJUeREQgZQReGveWu792zxy9uVxzOFVI+sCm9S18+vTm9Zu2c1ZAydiYvr2HWdm1ZmF6SWlq6WLgARQAugbaxJAX4IqLwIikFICX6zdRo9XZrL6+91UrViOJ65skfaz9wa8+yXDPl5G20a1GNWjXUr7q8pFIAgBCaAEMEicHCyPBNCXoMqLgAiknMD3O/fSc+RsPv16U+RaPTscx93nn5CWdYE79uTSbsB4tufk8mL3NnQ8KfrAppR3WxcQgQIJSAAlgL5vDwmgL0GVFwERSAuB3P15PDJuEcMnL49cr0OT2pG1eDWqpHZd4EuTl/PQ21/QqHY1Pry7PWV18HNa7rcucnACEkAJoO97RALoS1DlRUAE0kpg7Jw19H1jPnty82j4o2q8cENrjquTmnWBJp3nPP5RZPr5D1ecwnWnH5PWvupiIlAQAQmgBND33SEB9CWo8iIgAmknsGDNVm5+ZRZrtuzmkErlefKqFnQ6uW6xt+Pdz7/lttdmU7NqBab060iViuWK/RqqUASKQkACKAEsStzElpEA+hJUeREQgRIhsGnHHm5/fTbTlm2OXP+ujsdH/ivOKdornv2UOSu3cOe5x9G7U5MS6acuKgKJCEgAJYC+7wwJoC9BlRcBESgxAvv25/HHd7/kz59+E2nDeScdwVNXt6B6Zf91gbNWfM/PnptCxXJlmdyvA3WqVy6xfurCIhBPQAIoAfR9V0gAfQmqvAiIQIkTeGPWavq/+Tl7c/NoXLsaz9/Qhsa1D/Fq162vzmLcgnVc1eYoBnZp4VWXCotAcROQAEoAfWNKAuhLUOVFQAQygsD81Vsi6wK/3ZpD9UrleerqlpzXtGhHtqzctItzHp9IXj683+vsEjl8OiOgqhEZS0ACKAH0DU4JoC9BlRcBEcgYAt9t38Ptr83ms28OrAvsff4JkTMDk10X+OBbC3l5yjeRR9CN+MVpGdM/NUQEogQkgBJA33eDBNCXoMqLgAhkFAGbBn74nS8YMXVFpF2dmh7Bk1e3jOwWDpK27t4XOfh51979EfkzCVQSgUwjIAGUAPrGpATQl6DKi4AIZCSBMTNWcf/YBezdn8fxdQ6JrAu0cwMLS0MnLY0cON3kiOq81+ssypQpU1gRvS4CaScgAZQA+gadBNCXoMqLgAhkLIE5K7/nlldnsX7bHqpXLs/ga06lQ5M6BbbXdhWf9ehE1m3LYWCX5lzVpkHG9k0NCzcBCaAE0PcdIAH0JajyIiACGU1gw/Ycbn11Nnasiw3m9enUhNvOaZxwZM+eMtJr9FxqV6/E5L4dqFReBz9n9M0NceMkgBJA3/CXAPoSVHkREIGMJ2DrAn/3z4W8Nn1lpK0XN6vLY11aUC1mXWB+fj6dh0xmwZpt9Ol0Aj3PPT7j+6UGhpeABFAC6Bv9EkBfgiovAiKQNQRGfraSB/6xgH378yNr/J6/oTXHHH5gXeDUpZu45oVpVK5Qlqn9OlKzWsWs6ZcaGj4CEkAJoG/USwB9Caq8CIhAVhGYtWIzt7w6GzsypkaVCpF1ge1PqM0vX57B+EUbuL7t0Tx8ebOs6pMaGz4CEkAJoG/USwB9Caq8CIhA1hFYvy0ncmj03FVbKFsGbjyjIS9OXh5ZIzi+d3saeT5FJOuAqMFZR0ACKAH0DVoJoC9BlRcBEchKAnty9/PA2IWMnrnqP+23ZwkP794mK/ujRoeLgARQAugb8RJAX4IqLwIikLUEbOPHq9NX8ru3FpKbl8/oHm05vdHhWdsfNTw8BCSAEkDfaJcA+hJUeREQgawnsGT9djbu2Eu7xpK/rL+ZIemABFAC6BvqEkBfgiovAiIgAiIgAmkmIAGUAPqGnATQl6DKi4AIiIAIiECaCUgAJYC+IScB9CWo8iIgAiIgAiKQZgISQAmgb8hJAH0JqrwIiIAIiIAIpJmABFAC6BtyEkBfgiovAiIgAiIgAmkmIAGUAPqGnATQl6DKi4AIiIAIiECaCUgAJYC+IScB9CWo8iIgAiIgAiKQZgISQAmgb8hJAH0JqrwIiIAIiIAIpJmABFAC6BtyEkBfgiovAiIgAiIgAmkmIAGUAPqGnATQl6DKi4AIiIAIiECaCUgAJYC+IScB9CWo8iIgAiIgAiKQZgISQAmgb8hJAH0JqrwIiIAIiIAIpJmABFAC6BtyEkBfgiovAiIgAiIgAmkmIAGUAPqGnATQl6DKi4AIiIAIiECaCUgAJYC+IRcRwFWrVnHoofa/SiIgAiIgAiIgAplOwASwQYMG1swawLZMb28q2lcmFZWGqM76wOoQ9VddFQEREAEREIHSROAoYE1p6lDQvkgAg5JKnM/4HQls96smYenqTi4tOFNRfwqaXGJVilVw9GIlVsEJBM+puBKr4ASC50x1XFn9a4H84E0qPTklgJl7LyPTy2Eenk7i1ohVcFhiJVbBCQTPqbgSq+AEgudUXAVnlXROCWDSyNJWQIEfHLVYiVVwAsFzKq7EKjiB4DkVV2IVnEAKc0oAUwjXs2p9SAQHKFZiFZxA8JyKK7EKTiB4TsWVWAUnkMKcEsAUwvWsuhLQHxgA7PGsq7QXF6vgd1isxCo4geA5FVdiFZxA8JyKq+Csks4pAUwamQqIgAiIgAiIgAiIQHYTkABm9/1T60VABERABERABEQgaQISwKSRqYAIiIAIiIAIiIAIZDcBCWB23z+1XgREQAREQAREQASSJiABTBqZCoiACIiACIiACIhAdhOQAJbM/TsbuAdoDdQDrgDGFtKUc4AngZOBVcDDwMsl0/y0XjVZVsZpYoIWGud1aW15+i9mu8Z/CpwI7AamAH2BrxRbPyBQFFZhja1bAfvvWEdxIfAQMO4gcRXWz6tkWYU1phKFTj936sWfgF6KrdR/gUgAU8840RUuAs4AZgF/DyCADYEFwFBgONARGARcArxfMl1I21WTZRX9QG0S94DvDUBe2lpdMhd6DxgFzADKA38ETgGaAjsLaFJYY6sorMIaW52B/cASwL4zursfsKcCJoPxKawxZRySZRXWmIqPmR8DY9xntv2AL0gAwxxbxf6tIgEsdqRJV2jPICxsBPBRJ3v2ZR5N9kV/GHBh0lfM3gJBWEU/UGsCW7K3q8XS8tqAiW974OMCalRsHQAThJVi679BtNlJ4IsJ4kox9b9QDsZKMQWHALOB24D7gbkHEUDFVrF8NRyoRAJYjDCLWFUQqbEvb3uDxP4qutGNAtYo4nWzsVgQVtEP1BWAHSJqI6cPAp9mY4c923ycG7Vp5jgkqk6xdYBKEFaKLSgHXAn8BbARwC8SBJVi6gCUIKwUUwdiyST5buCjQgRQseX5pRBbXAJYjDCLWFUQqVkM/Nmtj4he5mLgHaCqW+9VxMtnVbEgrGzq1z5UZzoB/BXQDTjdSXRWddijsWWBt9wo8ZkHqUexBUFZhTm27EfEVKAysAO4Fni3gLgKe0wlwyrMMWXh0xX4DWBTwDkBBDDsseXxlfDDohLAYsVZpMqCSI2C/gDaIKwS3YRJwEongkW6SVlY6DnA1k+a/K2WAB70DgZlFebYqggcDdiMQxfAfljZ0oJEI4Bh/7xKhlWYY6qB+6F+PjDfgShsBDDssVWsX0USwGLFWaTKgkiNhr39BPAxJ0LtinSHsq/QEOAywHZQLy+k+WGPrWRYJUIZttiKMvgQWArcnABK2GMqHsnBWIU5pi4H3nQbjKIcbNrcvhNtw54t4bHNR7FJsVWM30cSwGKEWcSqggigLXy1KV+bWoim14Fa2gQSiPoHwHZ3REqgAlmayd7PT7tNRTYNbrs2C0thja2isErEMiyxFd/3CW5U/ecJoIQ1pgp6rx2MVZhjqjpwTBwAW+q0CLAYsvXb8UmxVdgnehKvSwCTgFWMWW3Xky06tzQH6O3OrrOFsDZVOQCoD9zg8kS3vj8DvAScCwwOyTEwybKyjTI26mXHU9h6JZuqugPoBIwvxnuYiVU969Zm2ehf7Nl/W2PWiSq2Dty5orAKa2xZzNiZf/bZZF/atv7Pzpe8ADABVkz999MgWVZhjamCPj/jp4AVWyn8ppEAphDuQaou6PBP2w1lv6jtgGc7dNXyRZP9/1PuTDdb0/X7kBwEnSyre4EeTqB3ubUldmhtosOhS+bup+6qNpqcKNmO8eih4YqtA4SKwiqssWVHvdjZo3aYuv2YsPVaNhJj8mdJMfXfd12yrMIaU0EFULGVuu8LHQOTQraqWgREQAREQAREQAQykoBGADPytqhRIiACIiACIiACIpA6AhLA1LFVzSIgAiIgAiIgAiKQkQQkgBl5W9QoERABERABERABEUgdAQlg6tiqZhEQAREQAREQARHISAISwIy8LWqUCIiACIiACIiACKSOgAQwdWxVswiIgAiIgAiIgAhkJAEJYEbeFjVKBERABERABERABFJHQAKYOraqWQREQAQKIxD/5IPC8ut1ERABESgWAhLAYsGoSkRABAIQsFP9DwPsIfCxKfq0l5rAlgD1ZEOWgvoa33Z7nvc+96xqe+0bYJD7Lxv6qTaKgAhkKQEJYJbeODVbBLKQQKYLYEVgbzFxDSqA8ZcrLgEszr4UExJVIwIikEkEJICZdDfUFhEo3QSCCKCNhn0L/AL4WwwOGzV8DagLHA4sB64B7gRaAV8DtwOTYsqcAjwGnAXsBP4F3A1sdHls+nUBkAtcD3wOdACOBp52z7/NA94D7gDWu3IPulHM54D7XXveBm5yz8q1138bdyutXrtefIqdArb/bx+XIfoZfSYwAGjj2v8m0N/1KzpyaM+hPd617e/uueKlO6LUOxEQgSITkAAWGZ0KioAIJEkgiADaFPDzQH3gkpj6/+Gmh7sDxzoBXA30Ar4AegNXAw2BTW6qeTEwHBgBVAEeBcoD58YIYGvARM7kydISYBaww9Vt+Z9x/7apaksmeH2A6cCvgUNd+c+A64BD3L/t7ze6MpsLGF2MFUCbDp7n+v+CK7cOaOz+brL5DlAbGOL+Fq3fRg5tCv0hYKwruzTJ+6PsIiACISIgAQzRzVZXRaCECZgA2khbTlw7ygGVncCYAJ4GTAEauNHAOsAa4Dw3whcVwH5O6qw6EzUbFbSRu4FuZM5G/i6IudZRwCqgCWByaPJlkmYjiNF0PjDOiaTltdQUWOjaNcMJoMnYMa5dludCJ2cmriZtQaeA4zeBJJoCNondD9wc004bEbTRzmqOp5WbA1xRwvdYlxcBEcgSAhLALLlRaqYIlAICJkUmSLfG9eV04NUYAbSXbSRsJPCIG927zU1v5seMANp06ccxddm0qAmkjYr9FbgswaibCdPFTvJMvmzEz6Zuo8mmlG2a2EYSY9P3wF1uNNFGAG8AGsVkqOGubaOEJmbFKYAmnc3dZpHoJe2zu6qT0y/d5hEbNfxDKYgTdUEERCANBCSAaYCsS4iACEQIBJ0Ctry25s7W9J3o1uaNipGb6AjgwQTQRvF2AX0TsLc1hrYmMNERLJkogCZ4HwCDE/RlpZPc4to8olAVAREICQEJYEhutLopAhlAIBkBtPVsa53APeWmW23Nn6WoAJrc2XSvJZsCXubWxtnfbCTsZ4BtBLFNHolSIgE82BTwj4GZMVPAtlnE2mjJpprfdSOcNgVs6xjrAZ0L4R7fBpuaHgY8EVPONr8c4abAC6pOApgBAa4miEA2EZAAZtPdUltFILsJJCOA1lMTny7ABOCimK5HBdBGv2wTiI2Q2bTttW7q1nb5HgnMddOxJoS2CeM4oCvwK7emLpEA2mfibHcun9VtYvlsAZtAprrNILaO0NbpWTnbmWzpPrdmr5PblLI1bgo32p34NthO5d2ATXnvcTt+bfp3GvCSu46NXtq6RJPVnq4iCWB2vzfUehFIOwEJYNqR64IiEFoCyQqg7dYdD1zl1vRFwUUF0ITPJK2lOwbGZGhiDF07EsV2/toRLJWAFe5IF9sxbGsJC3oKR9BjYGykzjaD2O5dOwamB2BrBS3ZTl0T2HZuV3CQY2CsXFs3AmgbVazN0c9oG320UU2rz/5mO3xHA3+UAIb2/aSOi4AXAQmgFz4VFgERSCGBboBN/9poXuwBzVEBPNWN8qWwCQmrjp4DaOKpJAIiIAJZSUACmJW3TY0WgVJNwHa32vq5t9yZdr+J660EsFTffnVOBEQgHQQkgOmgrGuIgAgkQ8BG2Ez67IgXO8rFDmWOTRLAZGgqrwiIgAgkICABVFiIgAiIgAiIgAiIQMgISABDdsPVXREQAREQAREQARGQACoGREAEREAEREAERCBkBCSAIbvh6q4IiIAIiIAIiIAISAAVAyIgAiIgAiIgAiIQMgISwJDdcHVXBERABERABERABCSAigEREAEREAEREAERCBkBCWDIbri6KwIiIAIiIAIiIAISQMWACIiACIiACIiACISMgAQwZDdc3RUBERABERABERCBfwOlrBYbDZYyNAAAAABJRU5ErkJggg==\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.text.Text at 0x7fb0889602b0>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.plot(param_df.score.rolling(window=2).max())\n",
    "plt.title('Rolling max of hyperopt score progression')\n",
    "plt.xlabel('Hyperopt iter')\n",
    "plt.ylabel('Score')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "anaconda-cloud": {},
  "kernelspec": {
   "display_name": "Python [conda env:rllab3]",
   "language": "python",
   "name": "conda-env-rllab3-py"
  },
  "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
