{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The performance metrics files need to be generated before running this."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib notebook\n",
    "import os\n",
    "import csv\n",
    "import numpy as np\n",
    "from scipy.stats import norm\n",
    "from scipy.stats import t as tdist\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from context import *\n",
    "from helpers.utils import load_perf_metrics, loadmat_helper, configure_plot_axes\n",
    "from helpers.constants import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_ber_matfile(fname):\n",
    "    return loadmat_helper(fname)[0, 0]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/Users/jr/Documents/research/code/domain_adaptation/expts_icml22/autoencoder_gmm_data2'\n",
    "n_adapt_per_class = np.array([5, 10, 20, 30, 40, 50])\n",
    "n_trials = 50\n",
    "type_autoenc = 'standard'\n",
    "plots_dir = os.path.join(base_dir, 'plots')\n",
    "if not os.path.isdir(plots_dir):\n",
    "    os.makedirs(plots_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "m = n_adapt_per_class.shape[0]\n",
    "ber_no_adapt = np.zeros(n_trials)\n",
    "ber_retrain = np.zeros(n_trials)\n",
    "ber_adapt = np.zeros((n_trials, m))\n",
    "ber_finetune = np.zeros((n_trials, m))\n",
    "ber_finetune_last = np.zeros((n_trials, m))\n",
    "for t in range(n_trials):\n",
    "    # No adaptation\n",
    "    fname = os.path.join(base_dir, 'trial{:d}'.format(t + 1), 'outputs', type_autoenc, 'ber.mat')\n",
    "    ber_no_adapt[t] = read_ber_matfile(fname)\n",
    "    \n",
    "    # Retrained autoencoder\n",
    "    fname = os.path.join(base_dir, 'trial{:d}'.format(t + 1), 'outputs_retrained', type_autoenc, 'ber.mat')\n",
    "    ber_retrain[t] = read_ber_matfile(fname)\n",
    "    for i, num in enumerate(n_adapt_per_class):\n",
    "        # proposed adaptation\n",
    "        fname = os.path.join(base_dir, 'trial{:d}'.format(t + 1), 'adapt_{:d}'.format(num), \n",
    "                             type_autoenc, 'ber_adapted.mat')\n",
    "        ber_adapt[t, i] = read_ber_matfile(fname)\n",
    "        \n",
    "        # Finetuned autoencoder\n",
    "        fname = os.path.join(base_dir, 'trial{:d}'.format(t + 1), 'finetune_{:d}'.format(num), \n",
    "                             type_autoenc, 'ber_finetuned.mat')\n",
    "        ber_finetune[t, i] = read_ber_matfile(fname)\n",
    "        \n",
    "        # Finetuned autoencoder where only the last layer of the MDN is modified\n",
    "        fname = os.path.join(base_dir, 'trial{:d}'.format(t + 1), 'finetune_last_{:d}'.format(num), \n",
    "                             type_autoenc, 'ber_finetuned.mat')\n",
    "        ber_finetune_last[t, i] = read_ber_matfile(fname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Average across trials\n",
    "avg_ber_no_adapt = np.mean(ber_no_adapt) * np.ones(m)\n",
    "avg_ber_retrain = np.mean(ber_retrain) * np.ones(m)\n",
    "avg_ber_adapt = np.mean(ber_adapt, axis=0)\n",
    "avg_ber_finetune = np.mean(ber_finetune, axis=0)\n",
    "avg_ber_finetune_last = np.mean(ber_finetune_last, axis=0)\n",
    "\n",
    "# Standard error of the mean\n",
    "conf = 0.95\n",
    "z_val = norm.ppf((1 + conf) / 2.)\n",
    "t_val = tdist.ppf((1 + conf) / 2., df=(n_trials-1))\n",
    "if n_trials >= 100:\n",
    "    c = z_val / np.sqrt(n_trials)\n",
    "else:\n",
    "    # use the t-distribution for small `n_trials`\n",
    "    c = t_val / np.sqrt(n_trials)\n",
    "    \n",
    "std_ber_no_adapt = c * np.std(ber_no_adapt, ddof=1) * np.ones(m)\n",
    "std_ber_retrain = c * np.std(ber_retrain, ddof=1) * np.ones(m)\n",
    "std_ber_adapt = c * np.std(ber_adapt, axis=0, ddof=1)\n",
    "std_ber_finetune = c * np.std(ber_finetune, axis=0, ddof=1)\n",
    "std_ber_finetune_last = c * np.std(ber_finetune_last, axis=0, ddof=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.13564133 0.13564133 0.13564133 0.13564133 0.13564133 0.13564133]\n",
      "[0.13564133 0.13564133 0.13564133 0.13564133 0.13564133 0.13564133]\n",
      "[0.13525487 0.13525487 0.13525487 0.13525487 0.13525487 0.13525487]\n",
      "[0.01542367 0.01542367 0.01542367 0.01542367 0.01542367 0.01542367]\n",
      "[0.09654253 0.0906178  0.08162073 0.0819744  0.07789467 0.0765922 ]\n",
      "\n",
      "[0.01038073 0.01038073 0.01038073 0.01038073 0.01038073 0.01038073]\n",
      "[0.01038073 0.01038073 0.01038073 0.01038073 0.01038073 0.01038073]\n",
      "[0.01045338 0.01045338 0.01045338 0.01045338 0.01045338 0.01045338]\n",
      "[0.00386081 0.00386081 0.00386081 0.00386081 0.00386081 0.00386081]\n",
      "[0.00822137 0.00823968 0.00699077 0.0072924  0.00681079 0.00674521]\n"
     ]
    }
   ],
   "source": [
    "print(avg_ber_finetune)\n",
    "print(avg_ber_finetune_last)\n",
    "print(avg_ber_no_adapt)\n",
    "print(avg_ber_retrain)\n",
    "print(avg_ber_adapt)\n",
    "print('')\n",
    "print(std_ber_finetune)\n",
    "print(std_ber_finetune_last)\n",
    "print(std_ber_no_adapt)\n",
    "print(std_ber_retrain)\n",
    "print(std_ber_adapt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "/* global mpl */\n",
       "window.mpl = {};\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(\n",
       "            '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",
       "\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 = document.createElement('div');\n",
       "    this.root.setAttribute('style', 'display: inline-block');\n",
       "    this._root_extra_style(this.root);\n",
       "\n",
       "    parent_element.appendChild(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 (fig.ratio !== 1) {\n",
       "            fig.send_message('set_device_pixel_ratio', {\n",
       "                device_pixel_ratio: fig.ratio,\n",
       "            });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = document.createElement('div');\n",
       "    titlebar.classList =\n",
       "        'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n",
       "    var titletext = document.createElement('div');\n",
       "    titletext.classList = 'ui-dialog-title';\n",
       "    titletext.setAttribute(\n",
       "        'style',\n",
       "        'width: 100%; text-align: center; padding: 3px;'\n",
       "    );\n",
       "    titlebar.appendChild(titletext);\n",
       "    this.root.appendChild(titlebar);\n",
       "    this.header = titletext;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = (this.canvas_div = document.createElement('div'));\n",
       "    canvas_div.setAttribute(\n",
       "        'style',\n",
       "        'border: 1px solid #ddd;' +\n",
       "            'box-sizing: content-box;' +\n",
       "            'clear: both;' +\n",
       "            'min-height: 1px;' +\n",
       "            'min-width: 1px;' +\n",
       "            'outline: 0;' +\n",
       "            'overflow: hidden;' +\n",
       "            'position: relative;' +\n",
       "            'resize: both;'\n",
       "    );\n",
       "\n",
       "    function on_keyboard_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.key_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    canvas_div.addEventListener(\n",
       "        'keydown',\n",
       "        on_keyboard_event_closure('key_press')\n",
       "    );\n",
       "    canvas_div.addEventListener(\n",
       "        'keyup',\n",
       "        on_keyboard_event_closure('key_release')\n",
       "    );\n",
       "\n",
       "    this._canvas_extra_style(canvas_div);\n",
       "    this.root.appendChild(canvas_div);\n",
       "\n",
       "    var canvas = (this.canvas = document.createElement('canvas'));\n",
       "    canvas.classList.add('mpl-canvas');\n",
       "    canvas.setAttribute('style', 'box-sizing: content-box;');\n",
       "\n",
       "    this.context = canvas.getContext('2d');\n",
       "\n",
       "    var backingStore =\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        this.context.webkitBackingStorePixelRatio ||\n",
       "        this.context.mozBackingStorePixelRatio ||\n",
       "        this.context.msBackingStorePixelRatio ||\n",
       "        this.context.oBackingStorePixelRatio ||\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        1;\n",
       "\n",
       "    this.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n",
       "        'canvas'\n",
       "    ));\n",
       "    rubberband_canvas.setAttribute(\n",
       "        'style',\n",
       "        'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n",
       "    );\n",
       "\n",
       "    // Apply a ponyfill if ResizeObserver is not implemented by browser.\n",
       "    if (this.ResizeObserver === undefined) {\n",
       "        if (window.ResizeObserver !== undefined) {\n",
       "            this.ResizeObserver = window.ResizeObserver;\n",
       "        } else {\n",
       "            var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n",
       "            this.ResizeObserver = obs.ResizeObserver;\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n",
       "        var nentries = entries.length;\n",
       "        for (var i = 0; i < nentries; i++) {\n",
       "            var entry = entries[i];\n",
       "            var width, height;\n",
       "            if (entry.contentBoxSize) {\n",
       "                if (entry.contentBoxSize instanceof Array) {\n",
       "                    // Chrome 84 implements new version of spec.\n",
       "                    width = entry.contentBoxSize[0].inlineSize;\n",
       "                    height = entry.contentBoxSize[0].blockSize;\n",
       "                } else {\n",
       "                    // Firefox implements old version of spec.\n",
       "                    width = entry.contentBoxSize.inlineSize;\n",
       "                    height = entry.contentBoxSize.blockSize;\n",
       "                }\n",
       "            } else {\n",
       "                // Chrome <84 implements even older version of spec.\n",
       "                width = entry.contentRect.width;\n",
       "                height = entry.contentRect.height;\n",
       "            }\n",
       "\n",
       "            // Keep the size of the canvas and rubber band canvas in sync with\n",
       "            // the canvas container.\n",
       "            if (entry.devicePixelContentBoxSize) {\n",
       "                // Chrome 84 implements new version of spec.\n",
       "                canvas.setAttribute(\n",
       "                    'width',\n",
       "                    entry.devicePixelContentBoxSize[0].inlineSize\n",
       "                );\n",
       "                canvas.setAttribute(\n",
       "                    'height',\n",
       "                    entry.devicePixelContentBoxSize[0].blockSize\n",
       "                );\n",
       "            } else {\n",
       "                canvas.setAttribute('width', width * fig.ratio);\n",
       "                canvas.setAttribute('height', height * fig.ratio);\n",
       "            }\n",
       "            canvas.setAttribute(\n",
       "                'style',\n",
       "                'width: ' + width + 'px; height: ' + height + 'px;'\n",
       "            );\n",
       "\n",
       "            rubberband_canvas.setAttribute('width', width);\n",
       "            rubberband_canvas.setAttribute('height', height);\n",
       "\n",
       "            // And update the size in Python. We ignore the initial 0/0 size\n",
       "            // that occurs as the element is placed into the DOM, which should\n",
       "            // otherwise not happen due to the minimum size styling.\n",
       "            if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n",
       "                fig.request_resize(width, height);\n",
       "            }\n",
       "        }\n",
       "    });\n",
       "    this.resizeObserverInstance.observe(canvas_div);\n",
       "\n",
       "    function on_mouse_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.mouse_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousedown',\n",
       "        on_mouse_event_closure('button_press')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseup',\n",
       "        on_mouse_event_closure('button_release')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'dblclick',\n",
       "        on_mouse_event_closure('dblclick')\n",
       "    );\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousemove',\n",
       "        on_mouse_event_closure('motion_notify')\n",
       "    );\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseenter',\n",
       "        on_mouse_event_closure('figure_enter')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseleave',\n",
       "        on_mouse_event_closure('figure_leave')\n",
       "    );\n",
       "\n",
       "    canvas_div.addEventListener('wheel', function (event) {\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        on_mouse_event_closure('scroll')(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.appendChild(canvas);\n",
       "    canvas_div.appendChild(rubberband_canvas);\n",
       "\n",
       "    this.rubberband_context = rubberband_canvas.getContext('2d');\n",
       "    this.rubberband_context.strokeStyle = '#000000';\n",
       "\n",
       "    this._resize_canvas = function (width, height, forward) {\n",
       "        if (forward) {\n",
       "            canvas_div.style.width = width + 'px';\n",
       "            canvas_div.style.height = height + 'px';\n",
       "        }\n",
       "    };\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n",
       "        event.preventDefault();\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 toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'mpl-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'mpl-button-group';\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",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'mpl-button-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        var button = (fig.buttons[name] = document.createElement('button'));\n",
       "        button.classList = 'mpl-widget';\n",
       "        button.setAttribute('role', 'button');\n",
       "        button.setAttribute('aria-disabled', 'false');\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "\n",
       "        var icon_img = document.createElement('img');\n",
       "        icon_img.src = '_images/' + image + '.png';\n",
       "        icon_img.srcset = '_images/' + image + '_large.png 2x';\n",
       "        icon_img.alt = tooltip;\n",
       "        button.appendChild(icon_img);\n",
       "\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    var fmt_picker = document.createElement('select');\n",
       "    fmt_picker.classList = 'mpl-widget';\n",
       "    toolbar.appendChild(fmt_picker);\n",
       "    this.format_dropdown = fmt_picker;\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = document.createElement('option');\n",
       "        option.selected = fmt === mpl.default_extension;\n",
       "        option.innerHTML = fmt;\n",
       "        fmt_picker.appendChild(option);\n",
       "    }\n",
       "\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\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",
       "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",
       "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], msg['forward']);\n",
       "        fig.send_message('refresh', {});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n",
       "    var x0 = msg['x0'] / fig.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n",
       "    var x1 = msg['x1'] / fig.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / fig.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,\n",
       "        0,\n",
       "        fig.canvas.width / fig.ratio,\n",
       "        fig.canvas.height / fig.ratio\n",
       "    );\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",
       "    fig.rubberband_canvas.style.cursor = msg['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.handle_history_buttons = function (fig, msg) {\n",
       "    for (var key in msg) {\n",
       "        if (!(key in fig.buttons)) {\n",
       "            continue;\n",
       "        }\n",
       "        fig.buttons[key].disabled = !msg[key];\n",
       "        fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n",
       "    if (msg['mode'] === 'PAN') {\n",
       "        fig.buttons['Pan'].classList.add('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    } else if (msg['mode'] === 'ZOOM') {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.add('active');\n",
       "    } else {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    }\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",
       "            var img = evt.data;\n",
       "            if (img.type !== 'image/png') {\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",
       "                img.type = 'image/png';\n",
       "            }\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",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                img\n",
       "            );\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        } else if (\n",
       "            typeof evt.data === 'string' &&\n",
       "            evt.data.slice(0, 21) === 'data:image/png;base64'\n",
       "        ) {\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(\n",
       "                \"No handler for the '\" + msg_type + \"' message type: \",\n",
       "                msg\n",
       "            );\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(\n",
       "                    \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n",
       "                    e,\n",
       "                    e.stack,\n",
       "                    msg\n",
       "                );\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "};\n",
       "\n",
       "// from https://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",
       "    }\n",
       "    if (e.target) {\n",
       "        targ = e.target;\n",
       "    } else if (e.srcElement) {\n",
       "        targ = e.srcElement;\n",
       "    }\n",
       "    if (targ.nodeType === 3) {\n",
       "        // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "    }\n",
       "\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    var boundingRect = targ.getBoundingClientRect();\n",
       "    var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n",
       "    var y = e.pageY - (boundingRect.top + document.body.scrollTop);\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",
       " * https://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",
       "        }\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",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * this.ratio;\n",
       "    var y = canvas_pos.y * this.ratio;\n",
       "\n",
       "    this.send_message(name, {\n",
       "        x: x,\n",
       "        y: y,\n",
       "        button: event.button,\n",
       "        step: event.step,\n",
       "        guiEvent: simpleKeys(event),\n",
       "    });\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",
       "    // Prevent repeat events\n",
       "    if (name === 'key_press') {\n",
       "        if (event.key === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.key;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.key !== 'Control') {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    else if (event.altKey && event.key !== 'Alt') {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    else if (event.shiftKey && event.key !== 'Shift') {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k' + event.key;\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, 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",
       "\n",
       "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n",
       "// prettier-ignore\n",
       "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\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\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pgf\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* global mpl */\n",
       "\n",
       "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.binaryType = comm.kernel.ws.binaryType;\n",
       "    ws.readyState = comm.kernel.ws.readyState;\n",
       "    function updateReadyState(_event) {\n",
       "        if (comm.kernel.ws) {\n",
       "            ws.readyState = comm.kernel.ws.readyState;\n",
       "        } else {\n",
       "            ws.readyState = 3; // Closed state.\n",
       "        }\n",
       "    }\n",
       "    comm.kernel.ws.addEventListener('open', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('close', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('error', updateReadyState);\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",
       "        var data = msg['content']['data'];\n",
       "        if (data['blob'] !== undefined) {\n",
       "            data = {\n",
       "                data: new Blob(msg['buffers'], { type: data['blob'] }),\n",
       "            };\n",
       "        }\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(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 = document.getElementById(id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm);\n",
       "\n",
       "    function ondownload(figure, _format) {\n",
       "        window.open(figure.canvas.toDataURL());\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy, ondownload, element);\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;\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",
       "    fig.cell_info[0].output_area.element.on(\n",
       "        'cleared',\n",
       "        { fig: fig },\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function (fig, msg) {\n",
       "    var width = fig.canvas.width / fig.ratio;\n",
       "    fig.cell_info[0].output_area.element.off(\n",
       "        'cleared',\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "    fig.resizeObserverInstance.unobserve(fig.canvas_div);\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.innerHTML =\n",
       "        '<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 / this.ratio;\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] =\n",
       "        '<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 () {\n",
       "        fig.push_to_output();\n",
       "    }, 1000);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'btn-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'btn-group';\n",
       "    var button;\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",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'btn-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        button = fig.buttons[name] = document.createElement('button');\n",
       "        button.classList = 'btn btn-default';\n",
       "        button.href = '#';\n",
       "        button.title = name;\n",
       "        button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message pull-right';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = document.createElement('div');\n",
       "    buttongrp.classList = 'btn-group inline pull-right';\n",
       "    button = document.createElement('button');\n",
       "    button.classList = 'btn btn-mini btn-primary';\n",
       "    button.href = '#';\n",
       "    button.title = 'Stop Interaction';\n",
       "    button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n",
       "    button.addEventListener('click', function (_evt) {\n",
       "        fig.handle_close(fig, {});\n",
       "    });\n",
       "    button.addEventListener(\n",
       "        'mouseover',\n",
       "        on_mouseover_closure('Stop Interaction')\n",
       "    );\n",
       "    buttongrp.appendChild(button);\n",
       "    var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n",
       "    titlebar.insertBefore(buttongrp, titlebar.firstChild);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._remove_fig_handler = function (event) {\n",
       "    var fig = event.data.fig;\n",
       "    if (event.target !== this) {\n",
       "        // Ignore bubbled events from children.\n",
       "        return;\n",
       "    }\n",
       "    fig.close_ws(fig, {});\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (el) {\n",
       "    el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (el) {\n",
       "    // this is important to make the div 'focusable\n",
       "    el.setAttribute('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",
       "    } else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (event, _name) {\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",
       "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(\n",
       "        'matplotlib',\n",
       "        mpl.mpl_figure_comm\n",
       "    );\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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PnfuXKlYsWKBH0cUgJnpfzl5VUQnkBQdy2J9FxgPOnzVAG/T//3vf81XKiBQ8PZMc4/AVVddZaJ+8axdu3bmJmmN/LjnIL8a8cUPcIRFH1u3bjVTVRg7EOb4FjDEe7iRo/wQTd/f4wlAeECe0scDrjR58mSzuwF2kti2bZsZR/juOfaXxTgqU6ZMTowjCsD09jtejQgQASJABIgAESACGUeAAjDjFNABIkAEiAARIAJEgAikFwEKwPTizasRASJABIgAESACRCDjCFAAZpwCOkAEiAARIAJEgAgQgfQiQAGYXrx5NSJABIgAESACRIAIZBwBCsCMU0AHiAARIAJEgAgQASKQXgQoANOLN69GBIgAESACRIAIEIGMI0ABmHEK6AARIAJEgAgQASJABNKLAAVgevHm1YgAESACRIAIEAEikHEEKAAzTgEdIAJEgAgQASJABIhAehGgAEwv3rwaESACRCBPBPBZqp49e8r48eOJVAII4POEZ511lowbN07wOUMaESACiSFAAZgYTixFBFQg8Je//EW+/vprWbBggfHn6quvNt+FXbx4cYR/O3fulEcffVTw/WX8ZJvhu6kQQPg2Z5MmTbLN/ZT8pQAMBh8FYDC8WJoIWAQoANkXiEAWIXDMMcfIH//4R3n44YeN18cff7xccMEF8thjj0W0wn54ftCgQXLXXXdlUQt/dTWXH+oUgMG6ay73lWBIsTQRiESAApA9gghkCQKbNm2S6tWry6uvvirdu3eXLVu2SNWqVeXFF1+UP/3pT2kVgD/99JMcddRR3pDL5Yd6LglAF/0ol/uKtwHIinMCAQrAnKCZjcxWBH788UfZt2+fcf/NN980OU4rV66USpUqyVtvvWVyxTAFXK1aNSlWrJiUKVPGTJ1iajja2rVrZyJrP//8swwdOlSmT58uX375pezYscMIyQsvvFDuueceqVChQujU8EjiCSecIA888IC5/sUXX2yug7pwbPTo0bJhwwapXbu23HjjjVKqVCnjw3vvvRcxBb1r1y7517/+Ja+88oqsW7dOSpcuLR06dJB7771Xjj32WHNdRCwHDx78O//zy4tDfTh35syZsnnzZvnDH/5g6rzuuuukd+/epr5k237iiScav7/44gupUaOG3HHHHaZ9a9eulb/97W/y7rvvysGDB6Vz587y+OOPGx6sgbMJEybI999/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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the symbol-error-rate vs number of target samples\n",
    "lw = 0.75\n",
    "error_bars = True\n",
    "error_kw = {\n",
    "    'fmt': '', 'elinewidth': 0.75, 'ecolor': 'black', 'capsize': 2\n",
    "}\n",
    "fig = plt.figure()\n",
    "y_vals = []\n",
    "if not error_bars:\n",
    "    plt.plot(n_adapt_per_class, avg_ber_no_adapt, linestyle='-', linewidth=lw, color=COLORS[0], \n",
    "             marker=POINT_STYLES[0], label='No adapt')\n",
    "else:\n",
    "    plt.errorbar(n_adapt_per_class, avg_ber_no_adapt, yerr=std_ber_no_adapt, linestyle='-', linewidth=lw, \n",
    "                 color=COLORS[0], marker=POINT_STYLES[0], label='No adapt', **error_kw)\n",
    "y_vals.extend(avg_ber_no_adapt)\n",
    "\n",
    "if not error_bars:\n",
    "    plt.plot(n_adapt_per_class, avg_ber_adapt, linestyle='-', linewidth=lw, color=COLORS[1], \n",
    "             marker=POINT_STYLES[1], label='Affine adapt (ours)')\n",
    "else:\n",
    "    plt.errorbar(n_adapt_per_class, avg_ber_adapt, yerr=std_ber_adapt, linestyle='-', linewidth=lw, \n",
    "                 color=COLORS[1], marker=POINT_STYLES[1], label='Affine adapt (ours)', **error_kw)\n",
    "y_vals.extend(avg_ber_adapt)\n",
    "\n",
    "if not error_bars:\n",
    "    plt.plot(n_adapt_per_class, avg_ber_finetune, linestyle='-', linewidth=lw, color=COLORS[2], \n",
    "             marker=POINT_STYLES[2], label='Finetune')\n",
    "else:\n",
    "    plt.errorbar(n_adapt_per_class, avg_ber_finetune, yerr=std_ber_finetune, linestyle='-', linewidth=lw, \n",
    "                 color=COLORS[2], marker=POINT_STYLES[2], label='Finetune', **error_kw)\n",
    "y_vals.extend(avg_ber_finetune)\n",
    "\n",
    "if not error_bars:\n",
    "    plt.plot(n_adapt_per_class, avg_ber_finetune_last, linestyle='-', linewidth=lw, color=COLORS[3], \n",
    "             marker=POINT_STYLES[3], label='Finetune last')\n",
    "else:\n",
    "    plt.errorbar(n_adapt_per_class, avg_ber_finetune_last, yerr=std_ber_finetune_last, linestyle='-', \n",
    "                 linewidth=lw, color=COLORS[3], marker=POINT_STYLES[3], label='Finetune last', **error_kw)\n",
    "y_vals.extend(avg_ber_finetune_last)\n",
    "\n",
    "if not error_bars:\n",
    "    plt.plot(n_adapt_per_class, avg_ber_retrain, linestyle='-', linewidth=lw, color=COLORS[4], \n",
    "             marker=POINT_STYLES[4], label='Retrained autoenc')\n",
    "else:\n",
    "    plt.errorbar(n_adapt_per_class, avg_ber_retrain, yerr=std_ber_retrain, linestyle='-', linewidth=lw, \n",
    "                 color=COLORS[4], marker=POINT_STYLES[4], label='Retrained autoenc', **error_kw)\n",
    "y_vals.extend(avg_ber_retrain)\n",
    "\n",
    "# Increase the upper y-limit a bit\n",
    "# y_bot, y_top = plt.ylim()\n",
    "# plt.ylim((y_bot, 1.1 * y_top))\n",
    "\n",
    "# plt.yscale('log')\n",
    "plt.xlabel('#target samples per-class', fontsize=13, fontweight='normal')\n",
    "plt.ylabel('Symbol error rate', fontsize=13, fontweight='normal')\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "# plt.ticklabel_format(axis='y', style='sci', scilimits=(0,0), useMathText=True)\n",
    "plt.grid(True, axis='both', linestyle='dashed', linewidth=lw, alpha=1.)\n",
    "# plt.legend(loc='best')\n",
    "plt.legend(loc='upper center', frameon=True, bbox_to_anchor=(0.5, 1.15), ncol=3, fancybox=False)\n",
    "\n",
    "# Save the figure\n",
    "plot_filename = os.path.join(plots_dir, 'plot_autoencoder_gmm_data.png')\n",
    "fig.tight_layout()\n",
    "fig.savefig(plot_filename, dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "/* global mpl */\n",
       "window.mpl = {};\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(\n",
       "            '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",
       "\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 = document.createElement('div');\n",
       "    this.root.setAttribute('style', 'display: inline-block');\n",
       "    this._root_extra_style(this.root);\n",
       "\n",
       "    parent_element.appendChild(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 (fig.ratio !== 1) {\n",
       "            fig.send_message('set_device_pixel_ratio', {\n",
       "                device_pixel_ratio: fig.ratio,\n",
       "            });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = document.createElement('div');\n",
       "    titlebar.classList =\n",
       "        'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n",
       "    var titletext = document.createElement('div');\n",
       "    titletext.classList = 'ui-dialog-title';\n",
       "    titletext.setAttribute(\n",
       "        'style',\n",
       "        'width: 100%; text-align: center; padding: 3px;'\n",
       "    );\n",
       "    titlebar.appendChild(titletext);\n",
       "    this.root.appendChild(titlebar);\n",
       "    this.header = titletext;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = (this.canvas_div = document.createElement('div'));\n",
       "    canvas_div.setAttribute(\n",
       "        'style',\n",
       "        'border: 1px solid #ddd;' +\n",
       "            'box-sizing: content-box;' +\n",
       "            'clear: both;' +\n",
       "            'min-height: 1px;' +\n",
       "            'min-width: 1px;' +\n",
       "            'outline: 0;' +\n",
       "            'overflow: hidden;' +\n",
       "            'position: relative;' +\n",
       "            'resize: both;'\n",
       "    );\n",
       "\n",
       "    function on_keyboard_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.key_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    canvas_div.addEventListener(\n",
       "        'keydown',\n",
       "        on_keyboard_event_closure('key_press')\n",
       "    );\n",
       "    canvas_div.addEventListener(\n",
       "        'keyup',\n",
       "        on_keyboard_event_closure('key_release')\n",
       "    );\n",
       "\n",
       "    this._canvas_extra_style(canvas_div);\n",
       "    this.root.appendChild(canvas_div);\n",
       "\n",
       "    var canvas = (this.canvas = document.createElement('canvas'));\n",
       "    canvas.classList.add('mpl-canvas');\n",
       "    canvas.setAttribute('style', 'box-sizing: content-box;');\n",
       "\n",
       "    this.context = canvas.getContext('2d');\n",
       "\n",
       "    var backingStore =\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        this.context.webkitBackingStorePixelRatio ||\n",
       "        this.context.mozBackingStorePixelRatio ||\n",
       "        this.context.msBackingStorePixelRatio ||\n",
       "        this.context.oBackingStorePixelRatio ||\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        1;\n",
       "\n",
       "    this.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n",
       "        'canvas'\n",
       "    ));\n",
       "    rubberband_canvas.setAttribute(\n",
       "        'style',\n",
       "        'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n",
       "    );\n",
       "\n",
       "    // Apply a ponyfill if ResizeObserver is not implemented by browser.\n",
       "    if (this.ResizeObserver === undefined) {\n",
       "        if (window.ResizeObserver !== undefined) {\n",
       "            this.ResizeObserver = window.ResizeObserver;\n",
       "        } else {\n",
       "            var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n",
       "            this.ResizeObserver = obs.ResizeObserver;\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n",
       "        var nentries = entries.length;\n",
       "        for (var i = 0; i < nentries; i++) {\n",
       "            var entry = entries[i];\n",
       "            var width, height;\n",
       "            if (entry.contentBoxSize) {\n",
       "                if (entry.contentBoxSize instanceof Array) {\n",
       "                    // Chrome 84 implements new version of spec.\n",
       "                    width = entry.contentBoxSize[0].inlineSize;\n",
       "                    height = entry.contentBoxSize[0].blockSize;\n",
       "                } else {\n",
       "                    // Firefox implements old version of spec.\n",
       "                    width = entry.contentBoxSize.inlineSize;\n",
       "                    height = entry.contentBoxSize.blockSize;\n",
       "                }\n",
       "            } else {\n",
       "                // Chrome <84 implements even older version of spec.\n",
       "                width = entry.contentRect.width;\n",
       "                height = entry.contentRect.height;\n",
       "            }\n",
       "\n",
       "            // Keep the size of the canvas and rubber band canvas in sync with\n",
       "            // the canvas container.\n",
       "            if (entry.devicePixelContentBoxSize) {\n",
       "                // Chrome 84 implements new version of spec.\n",
       "                canvas.setAttribute(\n",
       "                    'width',\n",
       "                    entry.devicePixelContentBoxSize[0].inlineSize\n",
       "                );\n",
       "                canvas.setAttribute(\n",
       "                    'height',\n",
       "                    entry.devicePixelContentBoxSize[0].blockSize\n",
       "                );\n",
       "            } else {\n",
       "                canvas.setAttribute('width', width * fig.ratio);\n",
       "                canvas.setAttribute('height', height * fig.ratio);\n",
       "            }\n",
       "            canvas.setAttribute(\n",
       "                'style',\n",
       "                'width: ' + width + 'px; height: ' + height + 'px;'\n",
       "            );\n",
       "\n",
       "            rubberband_canvas.setAttribute('width', width);\n",
       "            rubberband_canvas.setAttribute('height', height);\n",
       "\n",
       "            // And update the size in Python. We ignore the initial 0/0 size\n",
       "            // that occurs as the element is placed into the DOM, which should\n",
       "            // otherwise not happen due to the minimum size styling.\n",
       "            if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n",
       "                fig.request_resize(width, height);\n",
       "            }\n",
       "        }\n",
       "    });\n",
       "    this.resizeObserverInstance.observe(canvas_div);\n",
       "\n",
       "    function on_mouse_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.mouse_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousedown',\n",
       "        on_mouse_event_closure('button_press')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseup',\n",
       "        on_mouse_event_closure('button_release')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'dblclick',\n",
       "        on_mouse_event_closure('dblclick')\n",
       "    );\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousemove',\n",
       "        on_mouse_event_closure('motion_notify')\n",
       "    );\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseenter',\n",
       "        on_mouse_event_closure('figure_enter')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseleave',\n",
       "        on_mouse_event_closure('figure_leave')\n",
       "    );\n",
       "\n",
       "    canvas_div.addEventListener('wheel', function (event) {\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        on_mouse_event_closure('scroll')(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.appendChild(canvas);\n",
       "    canvas_div.appendChild(rubberband_canvas);\n",
       "\n",
       "    this.rubberband_context = rubberband_canvas.getContext('2d');\n",
       "    this.rubberband_context.strokeStyle = '#000000';\n",
       "\n",
       "    this._resize_canvas = function (width, height, forward) {\n",
       "        if (forward) {\n",
       "            canvas_div.style.width = width + 'px';\n",
       "            canvas_div.style.height = height + 'px';\n",
       "        }\n",
       "    };\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n",
       "        event.preventDefault();\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 toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'mpl-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'mpl-button-group';\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",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'mpl-button-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        var button = (fig.buttons[name] = document.createElement('button'));\n",
       "        button.classList = 'mpl-widget';\n",
       "        button.setAttribute('role', 'button');\n",
       "        button.setAttribute('aria-disabled', 'false');\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "\n",
       "        var icon_img = document.createElement('img');\n",
       "        icon_img.src = '_images/' + image + '.png';\n",
       "        icon_img.srcset = '_images/' + image + '_large.png 2x';\n",
       "        icon_img.alt = tooltip;\n",
       "        button.appendChild(icon_img);\n",
       "\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    var fmt_picker = document.createElement('select');\n",
       "    fmt_picker.classList = 'mpl-widget';\n",
       "    toolbar.appendChild(fmt_picker);\n",
       "    this.format_dropdown = fmt_picker;\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = document.createElement('option');\n",
       "        option.selected = fmt === mpl.default_extension;\n",
       "        option.innerHTML = fmt;\n",
       "        fmt_picker.appendChild(option);\n",
       "    }\n",
       "\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\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",
       "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",
       "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], msg['forward']);\n",
       "        fig.send_message('refresh', {});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n",
       "    var x0 = msg['x0'] / fig.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n",
       "    var x1 = msg['x1'] / fig.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / fig.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,\n",
       "        0,\n",
       "        fig.canvas.width / fig.ratio,\n",
       "        fig.canvas.height / fig.ratio\n",
       "    );\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",
       "    fig.rubberband_canvas.style.cursor = msg['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.handle_history_buttons = function (fig, msg) {\n",
       "    for (var key in msg) {\n",
       "        if (!(key in fig.buttons)) {\n",
       "            continue;\n",
       "        }\n",
       "        fig.buttons[key].disabled = !msg[key];\n",
       "        fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n",
       "    if (msg['mode'] === 'PAN') {\n",
       "        fig.buttons['Pan'].classList.add('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    } else if (msg['mode'] === 'ZOOM') {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.add('active');\n",
       "    } else {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    }\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",
       "            var img = evt.data;\n",
       "            if (img.type !== 'image/png') {\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",
       "                img.type = 'image/png';\n",
       "            }\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",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                img\n",
       "            );\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        } else if (\n",
       "            typeof evt.data === 'string' &&\n",
       "            evt.data.slice(0, 21) === 'data:image/png;base64'\n",
       "        ) {\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(\n",
       "                \"No handler for the '\" + msg_type + \"' message type: \",\n",
       "                msg\n",
       "            );\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(\n",
       "                    \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n",
       "                    e,\n",
       "                    e.stack,\n",
       "                    msg\n",
       "                );\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "};\n",
       "\n",
       "// from https://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",
       "    }\n",
       "    if (e.target) {\n",
       "        targ = e.target;\n",
       "    } else if (e.srcElement) {\n",
       "        targ = e.srcElement;\n",
       "    }\n",
       "    if (targ.nodeType === 3) {\n",
       "        // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "    }\n",
       "\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    var boundingRect = targ.getBoundingClientRect();\n",
       "    var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n",
       "    var y = e.pageY - (boundingRect.top + document.body.scrollTop);\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",
       " * https://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",
       "        }\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",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * this.ratio;\n",
       "    var y = canvas_pos.y * this.ratio;\n",
       "\n",
       "    this.send_message(name, {\n",
       "        x: x,\n",
       "        y: y,\n",
       "        button: event.button,\n",
       "        step: event.step,\n",
       "        guiEvent: simpleKeys(event),\n",
       "    });\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",
       "    // Prevent repeat events\n",
       "    if (name === 'key_press') {\n",
       "        if (event.key === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.key;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.key !== 'Control') {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    else if (event.altKey && event.key !== 'Alt') {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    else if (event.shiftKey && event.key !== 'Shift') {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k' + event.key;\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, 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",
       "\n",
       "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n",
       "// prettier-ignore\n",
       "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\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\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pgf\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* global mpl */\n",
       "\n",
       "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.binaryType = comm.kernel.ws.binaryType;\n",
       "    ws.readyState = comm.kernel.ws.readyState;\n",
       "    function updateReadyState(_event) {\n",
       "        if (comm.kernel.ws) {\n",
       "            ws.readyState = comm.kernel.ws.readyState;\n",
       "        } else {\n",
       "            ws.readyState = 3; // Closed state.\n",
       "        }\n",
       "    }\n",
       "    comm.kernel.ws.addEventListener('open', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('close', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('error', updateReadyState);\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",
       "        var data = msg['content']['data'];\n",
       "        if (data['blob'] !== undefined) {\n",
       "            data = {\n",
       "                data: new Blob(msg['buffers'], { type: data['blob'] }),\n",
       "            };\n",
       "        }\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(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 = document.getElementById(id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm);\n",
       "\n",
       "    function ondownload(figure, _format) {\n",
       "        window.open(figure.canvas.toDataURL());\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy, ondownload, element);\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;\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",
       "    fig.cell_info[0].output_area.element.on(\n",
       "        'cleared',\n",
       "        { fig: fig },\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function (fig, msg) {\n",
       "    var width = fig.canvas.width / fig.ratio;\n",
       "    fig.cell_info[0].output_area.element.off(\n",
       "        'cleared',\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "    fig.resizeObserverInstance.unobserve(fig.canvas_div);\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.innerHTML =\n",
       "        '<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 / this.ratio;\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] =\n",
       "        '<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 () {\n",
       "        fig.push_to_output();\n",
       "    }, 1000);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'btn-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'btn-group';\n",
       "    var button;\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",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'btn-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        button = fig.buttons[name] = document.createElement('button');\n",
       "        button.classList = 'btn btn-default';\n",
       "        button.href = '#';\n",
       "        button.title = name;\n",
       "        button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message pull-right';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = document.createElement('div');\n",
       "    buttongrp.classList = 'btn-group inline pull-right';\n",
       "    button = document.createElement('button');\n",
       "    button.classList = 'btn btn-mini btn-primary';\n",
       "    button.href = '#';\n",
       "    button.title = 'Stop Interaction';\n",
       "    button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n",
       "    button.addEventListener('click', function (_evt) {\n",
       "        fig.handle_close(fig, {});\n",
       "    });\n",
       "    button.addEventListener(\n",
       "        'mouseover',\n",
       "        on_mouseover_closure('Stop Interaction')\n",
       "    );\n",
       "    buttongrp.appendChild(button);\n",
       "    var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n",
       "    titlebar.insertBefore(buttongrp, titlebar.firstChild);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._remove_fig_handler = function (event) {\n",
       "    var fig = event.data.fig;\n",
       "    if (event.target !== this) {\n",
       "        // Ignore bubbled events from children.\n",
       "        return;\n",
       "    }\n",
       "    fig.close_ws(fig, {});\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (el) {\n",
       "    el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (el) {\n",
       "    // this is important to make the div 'focusable\n",
       "    el.setAttribute('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",
       "    } else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (event, _name) {\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",
       "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(\n",
       "        'matplotlib',\n",
       "        mpl.mpl_figure_comm\n",
       "    );\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAAXNSR0IArs4c6QAAIABJREFUeF7snQmUVMX1xi8jMMIgjoKiKJuICIYl0YAKEQOuKCpGIiqobK4oY8AlGkXUuAIOiuKCKCqgorhEMS6AGFQIi+ICInFFRGVG4C/bsAz/8xV5k5mhe+a+7qqe6tdfncNJhNv1qr6quvV7t5ZXbceOHTuEiQpQASpABagAFaACVCBjFKhGAMyYtmZFqQAVoAJUgApQASpgFCAAsiNQASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAZliDs7pUgApQASpABagAFSAAsg9QASpABagAFaACVCDDFCAAWmzwrVu3yvbt2y3myKyoABWgAlSAClCBTFJgt912kxo1ajivMgHQksSAvy+//FJ27NhhKUdmQwWoABWgAlSACmSaAtWqVZPmzZs7h0ACoKWetXnzZvn666+lYcOGkp2dbSlXZkMFqAAVoAJUgApkigJFRUXyww8/SLNmzWT33Xd3Wm0CoCV5AwBMRaNZKjKzoQJUgApQASpABTxSIJUsQQC01PCpbDRLRWY2VIAKUAEqQAWogEcKpJIlCICWGj6VjWapyMyGClABKkAFqAAV8EiBVLIEAdBSw6ey0SwV2dtsmjZtKnl5eeYPExXwRYFjjz1W2rdvL/n5+b4UieWgAk4UeOedd+SPf/yjrFmzRnJzc508A5l+8803Zq/bhx9+aMYWk0gqWYIAaKnHxWu01atXy//93/9Zekrl2dStW1f22Wefyg3/a3HhhRfKxIkT5Y477pDrrruu5HcvvfSS9OzZs0pONbsAwJtvvllQp48++kitDQ3dKJAuY6J87efNmyetWrWSPfbYw5owGH9r1641fZPJjQLp1N9w/QcOEp5yyily++23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6FRo6suYd8kGut5PANTqlLCdy0ZOxnmlYrky05xXKjT1xXlpB4TvfZR6MgIYNgKYynsqM82HEgC1ntWOHSOAdnSMmwsBkNfA8BqYcNfABPesEah3VYBAbddhJ6JnKu9VJABGdxuNSzbQjhICoFapBO1cNnIiziuVk2umOS8CC4ElQTeh/pnvYz4TIqqpvFcx03woI4BqV2DFMGEA7N+/f+gCVKtWTR577LHQv0vnHxAAGQFkBJARQFs+jABoS8md+fiuZ6YA4OY1mzPu848u2UA7ShIGwKysnR9qDpMAgNu3bw/zk7S3ddnIdF52u4dtPVE621frZEKEJZVRaurJPYBh9wCmsn9mCgAue35Zxn3+0SUbaGfGhAFQ+4BMt3PZyLaBxTasZIrzqqiP29aUwEJg8RlY2D/t9s9M8aFBBLC8L43y5x9dsoGWuwiAWqUStHPZyATABBslzs9s68kIoP9LbAQWu8BCPe3qmSkAmIkv0S7ZQDszOgHA9evXyzfffGPK0LRpU6lTp462PJGzc9nItoHFdrSKzotLwL73UQKLXWChnnb1pA+Nrg91yQZakLIKgMuWLZMhQ4bIjBkzpLi42JQBewWPP/54uffee6Vly5backXGzmUj+z650nlF13lpB6jvfZTAYhdYqKddPelDo+tDXbKB1j9bA8Dly5dLhw4dZN26ddK1a1dp06aN7NixQz799FOZNWuW5Obmyty5c6VFixbaskXCzmUj+z650nlF13lpB6fvfZTAYhdYqKddPelDo+tDXbKB1j9bA8DevXvLq6++Km+++aYcffTRZZ7/wQcfyAknnCA9evSQyZMna8sWCTuXjez75ErnFV3npR2cvvdRAotdYKGedvWkD42uD3XJBlr/bA0A9913X8HdgHfeeWfMZ1977bXy+OOPy88//6wtWyTsXDay75MrnVd0nZd2cPreRwksdoGFetrVkz40uj7UJRto/bM1ANx9993NPr9LL7005rPHjRsnV111lWzevFlbtkjYuWxk3ydXOq/oOi/t4PS9jxJY7AIL9bSrJ31odH2oSzbQ+mdrAHjIIYdIu3btZOrUqTGf3atXL1m8eLF88cUX2rJFws5lI/s+udJ5Rdd5aQen732UwGIXWKinXT3pQ6PrQ12ygdY/WwPAv/3tb3LHHXeYKN8NN9wge+21lynDmjVrzN+PGjVK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5s3JydE+P/J2LhvZ98mVziu6zks7cH3vowQWu8BCPe3qSR8aXR/qkg20/tkaAOLTaQBAfDYN3+eNdQoYhTr//PO1ZYuEnctG9n1ypfOKrvPSDk7f+yiBxS6wUE+7etKHRteHumQDrX+2BoBZWVmVPhPXwOAza5mUXDay75MrnVd0nZd2DPveRwksdoGFetrVkz40uj7UJRto/bM1AJw9e7bqmV26dFHZRcXIZSP7PrnSeUXXeWnHp+99lMBiF1iop1096UOj60NdsoHWP1sDQO0DM83OZSP7PrnSeUXXeWnHse99lMBiF1iop1096UOj60NdsoHWP1sDQHwCrnfv3jwAUk55l43s++RK5xVd56V1ML73UQKLXWChnnb1pA+Nrg91yQZa/2wNALEHsE6dOgYCBw4cKB06dNCWIdJ2LhvZ98mVziu6zks7aH3vowQWu8BCPe3qSR8aXR/qkg20/tkaAE6bNk0mTJggb7zxhhQXF0vr1q1l0KBB0qdPH9l777215YmcnctG9n1ypfOKrvPSDlTf+yiBxS6wUE+7etKHRteHumQDrX+2BoDBA1etWiWPP/64+QPnn52dLT179pQBAwZIt27dtOWKjJ3LRvZ9cqXziq7z0g5Q3/sogcUusFBPu3rSh0bXh7pkA61/tg6ApR/8zjvvCPYGIjq4efNmczcgQBBfDNlvv/20ZUxrO5eN7PvkSucVXeelHZS+91ECi11goZ529aQPja4PdckGWv/sFABRiLlz58qoUaPkhRdeKClTjRo1DAjefffdZt9glJPLRvZ9cqXziq7z0o5Z3/sogcUusFBPu3rSh0bXh7pkA61/dgKAhYWF8tRTT5no35IlS6RWrVry5z//WS666CIB/I0ZM0YmTZpk/m7KlCnasqalnctG9n1ypfOKrvPSDkbf+yiBxS6wUE+7etKHRteHumQDrX+2CoBvvvmmjB8/Xl555RXZsmWLtG3b1hwE6du3r9StW7dMmW688Ua57777ZN26ddqypqWdy0b2fXKl84qu89IORt/7KIHFLrBQT7t60odG14e6ZAOtf7YGgNjft2LFipJo38UXXywdO3aMW45nn31WzjnnHHNiOMrJZSP7PrnSeUXXeWnHrO99lMBiF1iop1096UOj60NdsoHWP1sDwPbt25slXlz7Uj7aF6swGzdulNWrV0uTJk20ZU1L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4+foeQmA6clHAExPL9amAp4CBEDaAhUIkAJVqlSRv/71rzJq1Cj11DVq1JD27dvL2LFjo1rhfYx+6NChcv/99weohX88al6e1AmA6ZlrXraV9JRibSoQrQABkBZBBQKiwK5du6RChQry0ksvSceOHeX777+XcuXKyQsvvCCdO3f+UwFw7969UrRoUWvK5eVJPS8BoAk7ysu2Ym0A8sZ5QgECYJ7oZjYyqAr89ttvcuDAAfX4CxYsUDlOn332mZQuXVoWLlyocsWwBFy+fHkpUKCAnHrqqWrpFEvDsaV58+Yqsnbs2DF55JFH5M0335QtW7bIjz/+qEDysssukwcffFBKliyZfWlkJPHMM8+UkSNHqt9/7bXXqt+De+HfJk+eLDt37pTKlStLnz595OSTT1bPsHTp0qgl6J9//lkefvhhmTdvnuzYsUNOOeUUadWqlTz00ENyxhlnqN+LiOUDDzxw3POnyovD/XDt22+/Ld9995385S9/Ufe87bbbpGfPnup+fttep04d9dybN2+WihUryj333KPa9/XXX8s//vEPWbJkiRw+fFg6dOggEydOVP3gFfTZjBkz5IcffpABAwaofty/f780bdpUHnvsMWnYsGFUWxMBINoFrVeuXKlsombNmvL3v/9devXqFXX98uXLVT+uWbNGfvrpJylevLicddZZMmTIELnwwguTDgWkC6DP0Z4777wz215atGihos7Vq1ePuv7333+Xp556Sp5++mnZuHGjnHjiidKoUSP1u5CX55VUdpTooXB/3Bt/NmzYoKpVrVpVvQANGzZM/T0eAKbTz7jHzJkz5YknnpCtW7fKwYMHpVSpUnLeeeepNAqMLRT8ftgl9EVfoo9r166t+hSpCixUIGgKEACD1mN83jylgAcPOo32AG/btm3y6quvqgkcE+XVV1+tLi9btqy0bt1awQMmNUQNAXVFihRRUIFJsFatWiqfsGDBguoab+Ju0KCBAra//e1vCvIAboBAwN6TTz4pzZo1k06dOgkADzAIoMR9IgEQPzv//PMVNN1yyy1St25dQVQTwHT06FH5+OOP1b0BtM8//7wCLsCbBy3VqlVTk3K8cuTIEalXr56CUDwj2vHLL7/I+vXr5dChQ6ptKH7aDkDz7luiRAl55pln5JNPPlH3vPfee6Vly5Zy7rnnyqpVq9TPAIb4bywAnnPO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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Bar plot\n",
    "bar_width = 0.12\n",
    "fig = plt.figure()\n",
    "error_kw = {\n",
    "    'elinewidth': 0.75, 'ecolor': 'black', 'capsize': 2\n",
    "}\n",
    "edgecolor = 'black'\n",
    "alpha = 0.7\n",
    "\n",
    "x1 = 1. * np.arange(n_adapt_per_class.shape[0])\n",
    "plt.bar(x1, avg_ber_no_adapt, yerr=std_ber_no_adapt, color=COLORS[0], label='No adapt', \n",
    "        width=bar_width, edgecolor=edgecolor, alpha=alpha, error_kw=error_kw)\n",
    "\n",
    "x2 = x1 + bar_width\n",
    "plt.bar(x2, avg_ber_adapt, yerr=std_ber_adapt, color=COLORS[1], label='Affine adapt (ours)', \n",
    "        width=bar_width, edgecolor=edgecolor, alpha=alpha, error_kw=error_kw)\n",
    "\n",
    "x3 = x2 + bar_width\n",
    "plt.bar(x3, avg_ber_finetune, yerr=std_ber_finetune, color=COLORS[2], label='Finetune', \n",
    "        width=bar_width, edgecolor=edgecolor, alpha=alpha, error_kw=error_kw)\n",
    "\n",
    "x4 = x3 + bar_width\n",
    "plt.bar(x4, avg_ber_finetune_last, yerr=std_ber_finetune_last, color=COLORS[3], label='Finetune last', \n",
    "        width=bar_width, edgecolor=edgecolor, alpha=alpha, error_kw=error_kw)\n",
    "\n",
    "x5 = x4 + bar_width\n",
    "plt.bar(x5, avg_ber_retrain, yerr=std_ber_retrain, color=COLORS[4], label='Retrained autoenc', \n",
    "        width=bar_width, edgecolor=edgecolor, alpha=alpha, error_kw=error_kw)\n",
    "\n",
    "plt.xlabel('#target samples per-class', fontsize=13, fontweight='normal')\n",
    "plt.ylabel('Symbol error rate', fontsize=13, fontweight='normal')\n",
    "plt.xticks(x3, ['{:d}'.format(v) for v in n_adapt_per_class], fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "# plt.legend(loc='best')\n",
    "plt.legend(loc='upper center', frameon=True, bbox_to_anchor=(0.5, 1.15), ncol=3, fancybox=False)\n",
    "\n",
    "# Save the figure\n",
    "plot_filename = os.path.join(plots_dir, 'barplot_autoencoder_gmm_data.png')\n",
    "fig.tight_layout()\n",
    "fig.savefig(plot_filename, dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
