{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e367ee61",
   "metadata": {},
   "source": [
    "## enter model path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "48d0756b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path = './log/nbody/version_1/checkpoints/best_model_valid-epoch=217.ckpt'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f791b5ed",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  | Name          | Type    | Params\n",
      "------------------------------------------\n",
      "0 | vel2node_feat | Linear  | 32    \n",
      "1 | egnn          | EGNN    | 5.5 K \n",
      "2 | criterion     | MSELoss | 0     \n",
      "------------------------------------------\n",
      "5.5 K     Trainable params\n",
      "0         Non-trainable params\n",
      "5.5 K     Total params\n",
      "0.022     Total estimated model params size (MB)\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning.utilities.model_summary import ModelSummary\n",
    "import matplotlib.animation as animation\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib notebook\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "from visualize import plot_traj_step_3d\n",
    "from data.nbody import NBodyDataset\n",
    "from data.boids import BoidsDataset\n",
    "from models import SimulatorEGNCA\n",
    "\n",
    "\n",
    "device = 'cuda'\n",
    "\n",
    "model = SimulatorEGNCA.load_from_checkpoint(path).to(device)\n",
    "dataset = BoidsDataset() if model.args.dataset == 'boids' else NBodyDataset()\n",
    "num_nodes = dataset.coord_dataset.size(2)\n",
    "\n",
    "print(ModelSummary(model, max_depth=1))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc3a41a0",
   "metadata": {},
   "source": [
    "## Animation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "617b5176",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_steps = 100\n",
    "coord_traj_true, vel_traj_true = dataset.simulator.sample_trajectory(n_steps, num_nodes, to_torch=True)\n",
    "# coord_traj_true, vel_traj_true = coord_traj_true[100:], vel_traj_true[100:]\n",
    "with torch.no_grad():\n",
    "    coord_traj_pred, vel_traj_pred = model(\n",
    "        coord_traj_true[0].to(device), vel_traj_true[0].to(device), len(coord_traj_true)-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c9b9cd12",
   "metadata": {
    "scrolled": true
   },
   "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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OBJmZpAQgAAEIAABCEAAAhCAAAQggABmDkAAAhCAAAQgAAEIQAACEIBAJAgggCNhZgYJAQhAAAIQgAAEIAABCEAAAghg5gAEIAABCEAAAhCAAAQgAAEIRIIAAjgSZmaQEIAABCAAAQhAAAIQgAAEIIAAZg5AAAIQgAAEIAABCEAAAhCAQCQIIIAjYWYGCQEIQAACEIAABCAAAQhAAAIIYOYABCAAAQhAAAIQgAAEIAABCESCAAI4EmZmkBCAAAQgAAEIQAACEIAABCCAAGYOQAACEIAABCAAAQhAAAIQgEAkCCCAI2FmBgkBCEAAAhCAAAQgAAEIQAACCGDmAAQgAAEIQAACEIAABCAAAQhEggACOBJmZpAQgAAEIAABCEAAAhCAAAQggABmDkAAAhCAAAQgAAEIQAACEIBAJAgggCNhZgYJAQhAAAIQgAAEIAABCEAAAghg5gAEIAABCEAAAhCAAAQgAAEIRIIAAjgSZmaQEIAABCAAAQhAAAIQgAAEIIAAZg5AAAIQgAAEIAABCEAAAhCAQCQIIIAjYWYGCQEIQAACEIAABCAAAQhAAAIIYOYABCAAAQhAAAIQgAAEIAABCESCAAI4EmZmkBCAAAQgAAEIQAACEIAABCCAAGYOQAACEIAABCAAAQhAAAIQgEAkCCCAI2FmBgkBCEAAAhCAAAQgAAEIQAACCGDmAAQgAAEIQAACEIAABCAAAQhEggACOBJmZpAQgAAEIAABCEAAAhCAAAQggABmDkAAAhCAAAQgAAEIQAACEIBAJAgggCNhZgYJAQhAAAIQgAAEIAABCEAAAghg5gAEIAABCEAAAhCAAAQgAAEIRIIAAjgSZmaQEIAABCAAAQhAAAIQgAAEIIAAZg5AAAIQgAAEIAABCEAAAhCAQCQIIIAjYWYGCQEIQAACEIAABCAAAQhAAAIIYOYABCAAAQhAAAIQgAAEIAABCESCAAI4EmZmkBCAAAQgAAEIQAACEIAABCCAAGYOQAACEIAABCAAAQhAAAIQgEAkCPw/d8dPAXF+aLIAAAAASUVORK5CYII=\" width=\"800\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def animate(t):\n",
    "    ax1.clear()\n",
    "    plot_traj_step_3d(coord_traj_true, t, tail_len=10, box_dim=5, title='true | $t=%d$' % t, ax=ax1)\n",
    "    # plot_traj_step_3d(coord_traj_true, t, box_dim=25, title='true | $t=%d$' % t, ax=ax1)\n",
    "    ax2.clear()\n",
    "    plot_traj_step_3d(coord_traj_pred, t, tail_len=10, box_dim=5, title='pred | $t=%d$' % t, ax=ax2)\n",
    "    # plot_traj_step_3d(coord_traj_pred, t, box_dim=25, title='pred | $t=%d$' % t, ax=ax2)\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5), dpi=80)\n",
    "fig.tight_layout()\n",
    "ax1 = fig.add_subplot(1, 2, 1, projection='3d')\n",
    "ax2 = fig.add_subplot(1, 2, 2, projection='3d')\n",
    "ani = animation.FuncAnimation(fig, animate, frames=range(300), interval=25, repeat=False)\n",
    "# ani.save('evolve.gif', dpi=300, writer=animation.PillowWriter(fps=2))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b1ee73c8",
   "metadata": {},
   "source": [
    "## SampEn & CorrDim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "23f7b6a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import nolds\n",
    "\n",
    "def avg_measure(trajectory, measure_fn, **kwargs):\n",
    "    measures = []\n",
    "    for i in np.random.permutation(trajectory.shape[1]):\n",
    "        measures.append(measure_fn(trajectory[:, i], **kwargs))\n",
    "    mu, std = np.mean(measures), np.std(measures)\n",
    "    print(f\"{measure_fn.__name__} {mu} +- {std}\")\n",
    "    return np.array(measures)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b95500f0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sampen 0.07159743591297821 +- 0.011971379738806704\n",
      "sampen 0.06455903544339787 +- 0.011863704020155214\n",
      "corr_dim 1.6266308078119753 +- 0.08901444270019966\n",
      "corr_dim 1.5821816246157319 +- 0.1970308338552457\n"
     ]
    }
   ],
   "source": [
    "n_steps = 500\n",
    "coord_traj_true, vel_traj_true = dataset.simulator.sample_trajectory(n_steps, num_nodes, to_torch=True)\n",
    "with torch.no_grad():\n",
    "    coord_traj_pred, vel_traj_pred = model(\n",
    "        coord_traj_true[0].to(device), vel_traj_true[0].to(device), len(coord_traj_true)-1)\n",
    "    \n",
    "full_traj_true = torch.cat([coord_traj_true, vel_traj_true], -1)\n",
    "full_traj_pred = torch.cat([coord_traj_pred, vel_traj_pred], -1)\n",
    "\n",
    "avg_measure(full_traj_true.cpu().numpy(), nolds.sampen);\n",
    "avg_measure(full_traj_pred.cpu().numpy(), nolds.sampen);\n",
    "\n",
    "avg_measure(full_traj_true.cpu().numpy(), nolds.corr_dim, emb_dim=10);\n",
    "avg_measure(full_traj_pred.cpu().numpy(), nolds.corr_dim, emb_dim=10);"
   ]
  }
 ],
 "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.9.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
