{
 "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, configure_plot_axes\n",
    "from helpers.constants import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_ber_ours(filename, snr_tar):\n",
    "    ber_no_adapt = None\n",
    "    ber_adapt = None\n",
    "    with open(filename, 'r') as fp:\n",
    "        cr = csv.reader(fp, delimiter=',')\n",
    "        for i, row in enumerate(cr):\n",
    "            if i == 0:\n",
    "                # header\n",
    "                continue\n",
    "\n",
    "            snr = float(row[0])\n",
    "            if abs(snr - snr_tar) < 1e-6:\n",
    "                ber_no_adapt = float(row[3])\n",
    "                ber_adapt = float(row[4])\n",
    "                \n",
    "    return ber_no_adapt, ber_adapt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_ber_finetune(filename, snr_tar):\n",
    "    ber_no_adapt = None\n",
    "    ber_adapt = None\n",
    "    with open(filename, 'r') as fp:\n",
    "        cr = csv.reader(fp, delimiter=',')\n",
    "        for i, row in enumerate(cr):\n",
    "            if i == 0:\n",
    "                # header\n",
    "                continue\n",
    "\n",
    "            snr = float(row[0])\n",
    "            if abs(snr - snr_tar) < 1e-6:\n",
    "                ber_no_adapt = float(row[1])\n",
    "                ber_adapt = float(row[2])\n",
    "                \n",
    "    return ber_no_adapt, ber_adapt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_ber_retrained(filename, snr_tar):\n",
    "    snr_list_, ber_list_ = load_perf_metrics(filename)\n",
    "    ber_retrained = None\n",
    "    for s, b in zip(snr_list_, ber_list_):\n",
    "        if abs(s - snr_tar) < 1e-6:\n",
    "            ber_retrained = b\n",
    "                \n",
    "    return ber_retrained"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/Users/jr/Documents/research/code/domain_adaptation/expts_icml22/autoencoder_new'\n",
    "source_ch = 'AWGN'\n",
    "source_snr = 14\n",
    "target_ch = 'fading'\n",
    "target_snr = 20\n",
    "n_adapt_per_class = np.array([5, 10, 20, 30, 40, 50])\n",
    "type1 = 'standard_iter'\n",
    "\n",
    "metric_fname = 'ber_vs_snr_adaptation.csv'\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": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Read the results of our adaptation method\n",
    "ber_no_adapt = np.zeros(6)\n",
    "ber_no_adapt1 = np.zeros(6)\n",
    "ber_adapt1 = np.zeros(6)\n",
    "for i, nad in enumerate(n_adapt_per_class):\n",
    "    fname = os.path.join(base_dir, \"{}_{:d}dB\".format(source_ch, source_snr), \n",
    "                         \"adapt_{}_{:d}\".format(target_ch, nad), type1, metric_fname)\n",
    "    ber_no_adapt1[i], ber_adapt1[i] = read_ber_ours(fname, target_snr)\n",
    "\n",
    "ber_no_adapt += ber_no_adapt1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Read the results of the fine-tuning baseline\n",
    "ber_no_adapt3 = np.zeros(6)\n",
    "ber_no_adapt4 = np.zeros(6)\n",
    "ber_finetune = np.zeros(6)\n",
    "ber_finetune_last = np.zeros(6)\n",
    "for i, nad in enumerate(n_adapt_per_class):\n",
    "    fname = os.path.join(base_dir, \"{}_{:d}dB\".format(source_ch, source_snr), \n",
    "                         \"finetune_{}_{:d}\".format(target_ch, nad), type1, metric_fname)\n",
    "    ber_no_adapt3[i], ber_finetune[i] = read_ber_finetune(fname, target_snr)\n",
    "    \n",
    "    fname = os.path.join(base_dir, \"{}_{:d}dB\".format(source_ch, source_snr), \n",
    "                         \"finetune_last_{}_{:d}\".format(target_ch, nad), type1, metric_fname)\n",
    "    ber_no_adapt4[i], ber_finetune_last[i] = read_ber_finetune(fname, target_snr)\n",
    "\n",
    "ber_no_adapt += (ber_no_adapt3 + ber_no_adapt4)\n",
    "ber_no_adapt /= 3."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Read the performance of the retrained autoencoder on the target channel\n",
    "fname = os.path.join(base_dir, \"{}_{:d}dB\".format(target_ch, target_snr), 'outputs', type1, \n",
    "                     'metrics_autoencoder.csv')\n",
    "ber_retrained = read_ber_retrained(fname, target_snr) * np.ones(n_adapt_per_class.shape[0])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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,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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",
    "fs = 13\n",
    "fig = plt.figure()\n",
    "y_vals = []\n",
    "plt.plot(n_adapt_per_class, ber_no_adapt, linestyle='-', linewidth=0.75, color=COLORS[0], marker=POINT_STYLES[0],\n",
    "         label='No adapt')\n",
    "y_vals.extend(ber_no_adapt)\n",
    "\n",
    "plt.plot(n_adapt_per_class, ber_adapt1, linestyle='-', linewidth=0.75, color=COLORS[1], marker=POINT_STYLES[1],\n",
    "         label='Affine adapt (ours)')\n",
    "y_vals.extend(ber_adapt1)\n",
    "\n",
    "plt.plot(n_adapt_per_class, ber_finetune, linestyle='-', linewidth=0.75, color=COLORS[2], marker=POINT_STYLES[2],\n",
    "         label='Finetune')\n",
    "y_vals.extend(ber_finetune)\n",
    "\n",
    "plt.plot(n_adapt_per_class, ber_finetune_last, linestyle='-', linewidth=0.75, color=COLORS[3], marker=POINT_STYLES[3],\n",
    "         label='Finetune last')\n",
    "y_vals.extend(ber_finetune_last)\n",
    "\n",
    "plt.plot(n_adapt_per_class, ber_retrained, linestyle='-', linewidth=0.75, color=COLORS[4], marker=POINT_STYLES[4],\n",
    "         label='Retrained autoenc')\n",
    "y_vals.extend(ber_retrained)\n",
    "\n",
    "# plt.yscale('log')\n",
    "# Increase the upper y-limit a bit\n",
    "y_bot, y_top = plt.ylim()\n",
    "plt.ylim((0.9 * y_bot, 1.1 * y_top))\n",
    "\n",
    "plt.xlabel('#target samples per-class', fontsize=fs, fontweight='normal')\n",
    "plt.ylabel('Symbol error rate', fontsize=fs, fontweight='normal')\n",
    "plt.xticks(fontsize=fs)\n",
    "plt.yticks(fontsize=fs)\n",
    "# plt.ticklabel_format(axis='y', style='sci', scilimits=(0,0), useMathText=True)\n",
    "plt.grid(True, axis='both', linestyle='dashed', linewidth=0.75, alpha=1.)\n",
    "# plt.legend(loc='best')\n",
    "plt.legend(loc='upper center', frameon=True, bbox_to_anchor=(0.5, 1.15), ncol=3, \n",
    "           fontsize=10, fancybox=False)\n",
    "\n",
    "# Save the figure\n",
    "fig.tight_layout()\n",
    "plot_filename = os.path.join(plots_dir, 'plot_{}_{:d}dB__to__{}_{:d}dB'.\n",
    "                             format(source_ch, source_snr, target_ch, target_snr))\n",
    "fig.savefig(plot_filename + '.png', dpi=600, bbox_inches='tight')\n",
    "fig.savefig(plot_filename + '.pdf', dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
