{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b2672f55",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3/dist-packages/ipykernel_launcher.py:8: MatplotlibDeprecationWarning: Support for setting the 'text.latex.preamble' or 'pgf.preamble' rcParam to a list of strings is deprecated since 3.3 and will be removed two minor releases later; set it to a single string instead.\n",
      "  \n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append(\"code\")\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['text.latex.preamble'] = [r'\\usepackage{lmodern}']\n",
    "\n",
    "from sklearn.metrics.pairwise import euclidean_distances\n",
    "from scipy import optimize\n",
    "\n",
    "from scipy.io import savemat\n",
    "\n",
    "from sklearn.metrics import silhouette_score\n",
    "from sklearn.metrics import calinski_harabasz_score\n",
    "from sklearn.metrics import davies_bouldin_score\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "scaler = StandardScaler()\n",
    "\n",
    "\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "neigh = KNeighborsClassifier(n_neighbors=1)\n",
    "\n",
    "dataset = 2\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def print_stats(X):\n",
    "    print('Mean:', np.mean(X))\n",
    "    print('Max: ', np.max(X))\n",
    "    print('Min: ', np.min(X))\n",
    "    print('STD: ', np.std(X))\n",
    "    \n",
    "    return\n",
    "\n",
    "    \n",
    "%matplotlib notebook\n",
    "\n",
    "%matplotlib notebook\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb28218f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "591e86db",
   "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_dpi_ratio', { dpi_ratio: fig.ratio });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = 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",
       "    // 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",
       "    var cursor = msg['cursor'];\n",
       "    switch (cursor) {\n",
       "        case 0:\n",
       "            cursor = 'pointer';\n",
       "            break;\n",
       "        case 1:\n",
       "            cursor = 'default';\n",
       "            break;\n",
       "        case 2:\n",
       "            cursor = 'crosshair';\n",
       "            break;\n",
       "        case 3:\n",
       "            cursor = 'move';\n",
       "            break;\n",
       "    }\n",
       "    fig.rubberband_canvas.style.cursor = cursor;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_message = function (fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function (fig, _msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function (fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.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",
       "            /* FIXME: We get \"Resource interpreted as Image but\n",
       "             * transferred with MIME type text/plain:\" errors on\n",
       "             * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "             * to be part of the websocket stream */\n",
       "            evt.data.type = 'image/png';\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src\n",
       "                );\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                evt.data\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 http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function (e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e) {\n",
       "        e = window.event;\n",
       "    }\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",
       " * http://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys(original) {\n",
       "    return Object.keys(original).reduce(function (obj, key) {\n",
       "        if (typeof original[key] !== 'object') {\n",
       "            obj[key] = original[key];\n",
       "        }\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.which === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.which;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.which !== 17) {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    if (event.altKey && event.which !== 18) {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    if (event.shiftKey && event.which !== 16) {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k';\n",
       "    value += event.which.toString();\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, 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, CTRL fixes aspect\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* 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.close = function () {\n",
       "        comm.close();\n",
       "    };\n",
       "    ws.send = function (m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function (msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(msg['content']['data']);\n",
       "    });\n",
       "    return ws;\n",
       "};\n",
       "\n",
       "mpl.mpl_figure_comm = function (comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = 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",
       "    var manager = IPython.notebook.keyboard_manager;\n",
       "    if (!manager) {\n",
       "        manager = IPython.keyboard_manager;\n",
       "    }\n",
       "\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which === 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "};\n",
       "\n",
       "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,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAgAElEQVR4XuydB3hUVfrG30khoSWhCmjoYEGkF8suImDvAva6Arrq/t1VQdTV4NoAd+0NsK1lVbAvawFEFFEIBKQoAgGk1xRqQtr/fHcySQgpd+bMvXPv3Pc8z31m5s757j3nd7/J9+ZUX4lKYCIBEiABEiABEiABEvAMAR8FoGeeNStKAiRAAiRAAiRAAgYBCkA6AgmQAAmQAAmQAAl4jAAFoMceOKtLAiRAAiRAAiRAAhSA9AESIAESIAESIAES8BgBCkCPPXBWlwRIgARIgARIgAQoAOkDJEACJEACJEACJOAxAhSAHnvgrC4JkAAJkAAJkAAJUADSB0iABEiABEiABEjAYwQoAD32wFldEiABEiABEiABEqAApA+QAAmQAAmQAAmQgMcIUAB67IGzuiRAAiRAAiRAAiRAAUgfIAESIAESIAESIAGPEaAA9NgDZ3VJgARIgARIgARIgAKQPkACJEACJEACJEACHiNAAeixB87qkgAJkAAJkAAJkAAFIH2ABEiABEiABEiABDxGgALQYw+c1SUBEiABEiABEiABCkD6AAmQAAmQAAmQAAl4jAAFoMceOKtLAiRAAiRAAiRAAhSA9AESIAESIAESIAES8BgBCkCPPXBWlwRIgARIgARIgAQoAOkDJEACJEACJEACJOAxAhSAHnvgrC4JkAAJkAAJkAAJUADSB0iABEiABEiABEjAYwQoAD32wFldEiABEiABEiABEqAApA+QAAmQAAmQAAmQgMcIUAB67IGzuiRAAiRAAiRAAiRAAUgfIAESIAESIAESIAGPEaAA9NgDZ3VJgARIgARIgARIgAKQPkACJEACJEACJEACHiNAAeixB87qkgAJkAAJkAAJkAAFIH2ABEiABEiABEiABDxGgALQYw+c1SUBEiABEiABEiABCkD6AAmQAAmQAAmQAAl4jAAFoMceOKtLAiRAAiRAAiRAAhSA9AESIAESIAESIAES8BgBCkCPPXBWlwRIgARIgARIgAQoAOkDJEACJEACJEACJOAxAhSAHnvgrC4JkAAJkAAJkAAJUADSB0iABEiABEiABEjAYwQoAD32wFldEiABEiABEiABEqAApA+QAAmQAAmQAAmQgMcIUAB67IGzuiRAAiRAAiRAAiRAAUgfIAESIAESIAESIAGPEaAA9NgDZ3VJgARIgARIgARIgAKQPkACJEACJEACJEACHiNAAeixB87qkgAJkAAJkAAJkAAFIH2ABEiABEiABEiABDxGgALQYw+c1SUBEiABEiABEiABCkD6AAmQAAmQAAmQAAl4jAAFoMceOKtLAiRAAiRAAiRAAhSA9AESIAESIAESIAES8BgBCkCPPXBWlwRIgARIgARIgAQoAOkDJEACJEACJEACJOAxAhSAHnvgrC4JkAAJkAAJkAAJUADSB0iABEiABEiABEjAYwQoADUeeHFxMbZs2YKGDRvC5/NpXImmJEACJEACJEACdhEoKSnB3r170apVK8TExNh1W0fdhwJQ43Fs2rQJqampGlegKQmQAAmQAAmQQKQIbNy4Ecccc0ykbh/R+1IAauDPzc1FSkoKxIGSkpI0rkRTEiABEiABEiABuwjs2bPHaMDJyclBcnKyXbd11H0oADUehziQOI4IQQpADZA0JQESIAESIAEbCTB+AxSAGg5HB9KAR1MSIAESIAESiBABxm8KQC3XowNp4aMxCZAACZAACUSEAOM3BaCW49GBtPDRmARIgARIgAQiQoDxmwJQy/HoQFr4aEwCJEACJEACESHA+E0BiLVr12LatGlo37698X7kyJHGzF4ziQ5khhLzkAAJkAAJkICzCDB+UwCiV69eWLRokeGZMh182LBhmDFjhilPpQOZwsRMJEACJEACJOAoAozfHheAGRkZGDFiRJkAFO9s1KgR1q1bZ6oVkA7kqN8zC0MCJEACJEACpggwfntcAE6aNAlTp049rMWvQ4cOeOWVVzB48OAjnCg/Px9yBFJgIUmuA2jq98ZMJEACJEACJOAIAhSAHheAEyZMMMRfxS5f6RIeO3Yshg4deoSTpqWlYdy4cUecpwB0xO+ZhSABEiABEiABUwQoAD0uANkCaOp3wkwkQAIkQAIkEFUEKAA9LgCrGwMok0JkVnBtiQ5UGyF+TwIkQAIkQALOI8D47XEBKC4pY/4yMzMN75RZwIMGDTpsUkhNbksHct6PmiUiARIgARKIDgIlJSUoLgFiY3xhrxDjNwUgpBVw5syZRotfeno6Ro0aZar1T7yRDhT23yQvSAIkQAIkYAMBEVcFRXIU41ChOiq9lp1X3+Wr7woq5Al8l6/OyTX89kXGq3z2n694+O9TKHlL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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.optimize import newton\n",
    "\n",
    "a = 1.576943460405378\n",
    "b = 0.8950608781227859\n",
    "\n",
    "attr_shape_umap = lambda dist: -2*a*b*dist**(2*(b-1)) / (1+a*dist**(2*b))\n",
    "\n",
    "\n",
    "\n",
    "umap_a = [-1, -1]\n",
    "umap_x = [0.0, 4.0]\n",
    "\n",
    "#umap_point = newton(umap_eq,0.5)\n",
    "#print(umap_point)\n",
    "\n",
    "#humap_point = newton(humap_eq,0.5)\n",
    "#print(humap_point)\n",
    "\n",
    "humap_a = [-4/3, -4/3]\n",
    "humap_x = [0.0, 4.0]\n",
    "\n",
    "dists=np.arange(0.01,4,0.01)\n",
    "gcs = attr_shape_umap(dists)\n",
    "gcs2 = attr_shape_umap(dists) - 0.2 * dists\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(dists,gcs, lw=2.0, label=r'$f_a^U(\\zeta)$')\n",
    "plt.plot(dists,gcs2, lw=2.0, label=r'$f_a^M(\\zeta)$')\n",
    "\n",
    "plt.plot(umap_x,umap_a, c='g', ls=':', label=r'$f_a=-1$')\n",
    "\n",
    "plt.xlabel(r'$\\zeta$', fontsize=18)\n",
    "plt.ylabel(r'$f_a(\\zeta)$', fontsize=18)\n",
    "plt.legend(loc='lower right',fontsize=14)\n",
    "\n",
    "plt.savefig('fig_random/f_a_random.svg', dpi=400, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ff367cf",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
