{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "desired_directory = os.path.abspath('../..')\n",
    "os.chdir(desired_directory)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<script type=\"esms-options\">{\"shimMode\": true}</script><style>*[data-root-id],\n",
       "*[data-root-id] > * {\n",
       "  box-sizing: border-box;\n",
       "  font-family: var(--jp-ui-font-family);\n",
       "  font-size: var(--jp-ui-font-size1);\n",
       "  color: var(--vscode-editor-foreground, var(--jp-ui-font-color1));\n",
       "}\n",
       "\n",
       "/* Override VSCode background color */\n",
       ".cell-output-ipywidget-background:has(\n",
       "    > .cell-output-ipywidget-background > .lm-Widget > *[data-root-id]\n",
       "  ),\n",
       ".cell-output-ipywidget-background:has(> .lm-Widget > *[data-root-id]) {\n",
       "  background-color: transparent !important;\n",
       "}\n",
       "</style>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "(function(root) {\n  function now() {\n    return new Date();\n  }\n\n  const force = true;\n  const py_version = '3.6.2'.replace('rc', '-rc.').replace('.dev', '-dev.');\n  const reloading = false;\n  const Bokeh = root.Bokeh;\n\n  // Set a timeout for this load but only if we are not already initializing\n  if (typeof (root._bokeh_timeout) === \"undefined\" || (force || !root._bokeh_is_initializing)) {\n    root._bokeh_timeout = Date.now() + 5000;\n    root._bokeh_failed_load = false;\n  }\n\n  function run_callbacks() {\n    try {\n      root._bokeh_onload_callbacks.forEach(function(callback) {\n        if (callback != null)\n          callback();\n      });\n    } finally {\n      delete root._bokeh_onload_callbacks;\n    }\n    console.debug(\"Bokeh: all callbacks have finished\");\n  }\n\n  function load_libs(css_urls, js_urls, js_modules, js_exports, callback) {\n    if (css_urls == null) css_urls = [];\n    if (js_urls == null) js_urls = [];\n    if (js_modules == null) js_modules = [];\n    if (js_exports == null) js_exports = {};\n\n    root._bokeh_onload_callbacks.push(callback);\n\n    if (root._bokeh_is_loading > 0) {\n      // Don't load bokeh if it is still initializing\n      console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n      return null;\n    } else if (js_urls.length === 0 && js_modules.length === 0 && Object.keys(js_exports).length === 0) {\n      // There is nothing to load\n      run_callbacks();\n      return null;\n    }\n\n    function on_load() {\n      root._bokeh_is_loading--;\n      if (root._bokeh_is_loading === 0) {\n        console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n        run_callbacks()\n      }\n    }\n    window._bokeh_on_load = on_load\n\n    function on_error(e) {\n      const src_el = e.srcElement\n      console.error(\"failed to load \" + (src_el.href || src_el.src));\n    }\n\n    const skip = [];\n    if (window.requirejs) {\n      window.requirejs.config({'packages': {}, 'paths': {}, 'shim': {}});\n      root._bokeh_is_loading = css_urls.length + 0;\n    } else {\n      root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length + Object.keys(js_exports).length;\n    }\n\n    const existing_stylesheets = []\n    const links = document.getElementsByTagName('link')\n    for (let i = 0; i < links.length; i++) {\n      const link = links[i]\n      if (link.href != null) {\n        existing_stylesheets.push(link.href)\n      }\n    }\n    for (let i = 0; i < css_urls.length; i++) {\n      const url = css_urls[i];\n      const escaped = encodeURI(url)\n      if (existing_stylesheets.indexOf(escaped) !== -1) {\n        on_load()\n        continue;\n      }\n      const element = document.createElement(\"link\");\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.rel = \"stylesheet\";\n      element.type = \"text/css\";\n      element.href = url;\n      console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n      document.body.appendChild(element);\n    }    var existing_scripts = []\n    const scripts = document.getElementsByTagName('script')\n    for (let i = 0; i < scripts.length; i++) {\n      var script = scripts[i]\n      if (script.src != null) {\n        existing_scripts.push(script.src)\n      }\n    }\n    for (let i = 0; i < js_urls.length; i++) {\n      const url = js_urls[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      const element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (let i = 0; i < js_modules.length; i++) {\n      const url = js_modules[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (const name in js_exports) {\n      const url = js_exports[name];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) >= 0 || root[name] != null) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onerror = on_error;\n      element.async = false;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      element.textContent = `\n      import ${name} from \"${url}\"\n      window.${name} = ${name}\n      window._bokeh_on_load()\n      `\n      document.head.appendChild(element);\n    }\n    if (!js_urls.length && !js_modules.length) {\n      on_load()\n    }\n  };\n\n  function inject_raw_css(css) {\n    const element = document.createElement(\"style\");\n    element.appendChild(document.createTextNode(css));\n    document.body.appendChild(element);\n  }\n\n  const js_urls = [\"https://cdn.holoviz.org/panel/1.5.5/dist/bundled/reactiveesm/es-module-shims@^1.10.0/dist/es-module-shims.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-3.6.2.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-gl-3.6.2.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-widgets-3.6.2.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-tables-3.6.2.min.js\", \"https://cdn.holoviz.org/panel/1.5.5/dist/panel.min.js\"];\n  const js_modules = [];\n  const js_exports = {};\n  const css_urls = [];\n  const inline_js = [    function(Bokeh) {\n      Bokeh.set_log_level(\"info\");\n    },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n  ];\n\n  function run_inline_js() {\n    if ((root.Bokeh !== undefined) || (force === true)) {\n      for (let i = 0; i < inline_js.length; i++) {\n        try {\n          inline_js[i].call(root, root.Bokeh);\n        } catch(e) {\n          if (!reloading) {\n            throw e;\n          }\n        }\n      }\n      // Cache old bokeh versions\n      if (Bokeh != undefined && !reloading) {\n        var NewBokeh = root.Bokeh;\n        if (Bokeh.versions === undefined) {\n          Bokeh.versions = new Map();\n        }\n        if (NewBokeh.version !== Bokeh.version) {\n          Bokeh.versions.set(NewBokeh.version, NewBokeh)\n        }\n        root.Bokeh = Bokeh;\n      }\n    } else if (Date.now() < root._bokeh_timeout) {\n      setTimeout(run_inline_js, 100);\n    } else if (!root._bokeh_failed_load) {\n      console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n      root._bokeh_failed_load = true;\n    }\n    root._bokeh_is_initializing = false\n  }\n\n  function load_or_wait() {\n    // Implement a backoff loop that tries to ensure we do not load multiple\n    // versions of Bokeh and its dependencies at the same time.\n    // In recent versions we use the root._bokeh_is_initializing flag\n    // to determine whether there is an ongoing attempt to initialize\n    // bokeh, however for backward compatibility we also try to ensure\n    // that we do not start loading a newer (Panel>=1.0 and Bokeh>3) version\n    // before older versions are fully initialized.\n    if (root._bokeh_is_initializing && Date.now() > root._bokeh_timeout) {\n      // If the timeout and bokeh was not successfully loaded we reset\n      // everything and try loading again\n      root._bokeh_timeout = Date.now() + 5000;\n      root._bokeh_is_initializing = false;\n      root._bokeh_onload_callbacks = undefined;\n      root._bokeh_is_loading = 0\n      console.log(\"Bokeh: BokehJS was loaded multiple times but one version failed to initialize.\");\n      load_or_wait();\n    } else if (root._bokeh_is_initializing || (typeof root._bokeh_is_initializing === \"undefined\" && root._bokeh_onload_callbacks !== undefined)) {\n      setTimeout(load_or_wait, 100);\n    } else {\n      root._bokeh_is_initializing = true\n      root._bokeh_onload_callbacks = []\n      const bokeh_loaded = root.Bokeh != null && (root.Bokeh.version === py_version || (root.Bokeh.versions !== undefined && root.Bokeh.versions.has(py_version)));\n      if (!reloading && !bokeh_loaded) {\n        if (root.Bokeh) {\n          root.Bokeh = undefined;\n        }\n        console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n      }\n      load_libs(css_urls, js_urls, js_modules, js_exports, function() {\n        console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n        run_inline_js();\n      });\n    }\n  }\n  // Give older versions of the autoload script a head-start to ensure\n  // they initialize before we start loading newer version.\n  setTimeout(load_or_wait, 100)\n}(window));",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n  window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n    function JupyterCommManager() {\n    }\n\n    JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n      if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        comm_manager.register_target(comm_id, function(comm) {\n          comm.on_msg(msg_handler);\n        });\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n          comm.onMsg = msg_handler;\n        });\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n          var messages = comm.messages[Symbol.asyncIterator]();\n          function processIteratorResult(result) {\n            var message = result.value;\n            console.log(message)\n            var content = {data: message.data, comm_id};\n            var buffers = []\n            for (var buffer of message.buffers || []) {\n              buffers.push(new DataView(buffer))\n            }\n            var metadata = message.metadata || {};\n            var msg = {content, buffers, metadata}\n            msg_handler(msg);\n            return messages.next().then(processIteratorResult);\n          }\n          return messages.next().then(processIteratorResult);\n        })\n      }\n    }\n\n    JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n      if (comm_id in window.PyViz.comms) {\n        return window.PyViz.comms[comm_id];\n      } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n        if (msg_handler) {\n          comm.on_msg(msg_handler);\n        }\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n        comm.open();\n        if (msg_handler) {\n          comm.onMsg = msg_handler;\n        }\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        var comm_promise = google.colab.kernel.comms.open(comm_id)\n        comm_promise.then((comm) => {\n          window.PyViz.comms[comm_id] = comm;\n          if (msg_handler) {\n            var messages = comm.messages[Symbol.asyncIterator]();\n            function processIteratorResult(result) {\n              var message = result.value;\n              var content = {data: message.data};\n              var metadata = message.metadata || {comm_id};\n              var msg = {content, metadata}\n              msg_handler(msg);\n              return messages.next().then(processIteratorResult);\n            }\n            return messages.next().then(processIteratorResult);\n          }\n        })\n        var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n          return comm_promise.then((comm) => {\n            comm.send(data, metadata, buffers, disposeOnDone);\n          });\n        };\n        var comm = {\n          send: sendClosure\n        };\n      }\n      window.PyViz.comms[comm_id] = comm;\n      return comm;\n    }\n    window.PyViz.comm_manager = new JupyterCommManager();\n    \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n  var div = document.createElement(\"div\");\n  var script = document.createElement(\"script\");\n  node.appendChild(div);\n  node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n  var output_area = handle.output_area;\n  var output = handle.output;\n  if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n    return\n  }\n  var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n  var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n  if (id !== undefined) {\n    var nchildren = toinsert.length;\n    var html_node = toinsert[nchildren-1].children[0];\n    html_node.innerHTML = output.data[HTML_MIME_TYPE];\n    var scripts = [];\n    var nodelist = html_node.querySelectorAll(\"script\");\n    for (var i in nodelist) {\n      if (nodelist.hasOwnProperty(i)) {\n        scripts.push(nodelist[i])\n      }\n    }\n\n    scripts.forEach( function (oldScript) {\n      var newScript = document.createElement(\"script\");\n      var attrs = [];\n      var nodemap = oldScript.attributes;\n      for (var j in nodemap) {\n        if (nodemap.hasOwnProperty(j)) {\n          attrs.push(nodemap[j])\n        }\n      }\n      attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n      newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n      oldScript.parentNode.replaceChild(newScript, oldScript);\n    });\n    if (JS_MIME_TYPE in output.data) {\n      toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n    }\n    output_area._hv_plot_id = id;\n    if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n      window.PyViz.plot_index[id] = Bokeh.index[id];\n    } else {\n      window.PyViz.plot_index[id] = null;\n    }\n  } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n    var bk_div = document.createElement(\"div\");\n    bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n    var script_attrs = bk_div.children[0].attributes;\n    for (var i = 0; i < script_attrs.length; i++) {\n      toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n    }\n    // store reference to server id on output_area\n    output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n  }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n  var id = handle.cell.output_area._hv_plot_id;\n  var server_id = handle.cell.output_area._bokeh_server_id;\n  if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n  var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n  if (server_id !== null) {\n    comm.send({event_type: 'server_delete', 'id': server_id});\n    return;\n  } else if (comm !== null) {\n    comm.send({event_type: 'delete', 'id': id});\n  }\n  delete PyViz.plot_index[id];\n  if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n    var doc = window.Bokeh.index[id].model.document\n    doc.clear();\n    const i = window.Bokeh.documents.indexOf(doc);\n    if (i > -1) {\n      window.Bokeh.documents.splice(i, 1);\n    }\n  }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n  delete PyViz.comms[\"hv-extension-comm\"];\n  window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n  handle_clear_output(event, {cell: {output_area: handle.output_area}})\n  handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n  function append_mime(data, metadata, element) {\n    // create a DOM node to render to\n    var toinsert = this.create_output_subarea(\n    metadata,\n    CLASS_NAME,\n    EXEC_MIME_TYPE\n    );\n    this.keyboard_manager.register_events(toinsert);\n    // Render to node\n    var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n    render(props, toinsert[0]);\n    element.append(toinsert);\n    return toinsert\n  }\n\n  events.on('output_added.OutputArea', handle_add_output);\n  events.on('output_updated.OutputArea', handle_update_output);\n  events.on('clear_output.CodeCell', handle_clear_output);\n  events.on('delete.Cell', handle_clear_output);\n  events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n  OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n    safe: true,\n    index: 0\n  });\n}\n\nif (window.Jupyter !== undefined) {\n  try {\n    var events = require('base/js/events');\n    var OutputArea = require('notebook/js/outputarea').OutputArea;\n    if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n      register_renderer(events, OutputArea);\n    }\n  } catch(err) {\n  }\n}\n",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.holoviews_exec.v0+json": "",
      "text/html": [
       "<div id='43786612-e930-4202-97a7-d109d4c80a05'>\n",
       "  <div id=\"f8dec50d-1aec-4c3c-a448-cb3f2ec125af\" data-root-id=\"43786612-e930-4202-97a7-d109d4c80a05\" style=\"display: contents;\"></div>\n",
       "</div>\n",
       "<script type=\"application/javascript\">(function(root) {\n",
       "  var docs_json = {\"1a8d9004-2244-4fde-90a0-f47c6d960794\":{\"version\":\"3.6.2\",\"title\":\"Bokeh Application\",\"roots\":[{\"type\":\"object\",\"name\":\"panel.models.browser.BrowserInfo\",\"id\":\"43786612-e930-4202-97a7-d109d4c80a05\"},{\"type\":\"object\",\"name\":\"panel.models.comm_manager.CommManager\",\"id\":\"165927b1-3e13-4b60-9f18-747f835762f5\",\"attributes\":{\"plot_id\":\"43786612-e930-4202-97a7-d109d4c80a05\",\"comm_id\":\"1204c17806a74c2d89fd772f138696bd\",\"client_comm_id\":\"f8a7603743524ee6b25a13f50c848ea6\"}}],\"defs\":[{\"type\":\"model\",\"name\":\"ReactiveHTML1\"},{\"type\":\"model\",\"name\":\"FlexBox1\",\"properties\":[{\"name\":\"align_content\",\"kind\":\"Any\",\"default\":\"flex-start\"},{\"name\":\"align_items\",\"kind\":\"Any\",\"default\":\"flex-start\"},{\"name\":\"flex_direction\",\"kind\":\"Any\",\"default\":\"row\"},{\"name\":\"flex_wrap\",\"kind\":\"Any\",\"default\":\"wrap\"},{\"name\":\"gap\",\"kind\":\"Any\",\"default\":\"\"},{\"name\":\"justify_content\",\"kind\":\"Any\",\"default\":\"flex-start\"}]},{\"type\":\"model\",\"name\":\"FloatPanel1\",\"properties\":[{\"name\":\"config\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}},{\"name\":\"contained\",\"kind\":\"Any\",\"default\":true},{\"name\":\"position\",\"kind\":\"Any\",\"default\":\"right-top\"},{\"name\":\"offsetx\",\"kind\":\"Any\",\"default\":null},{\"name\":\"offsety\",\"kind\":\"Any\",\"default\":null},{\"name\":\"theme\",\"kind\":\"Any\",\"default\":\"primary\"},{\"name\":\"status\",\"kind\":\"Any\",\"default\":\"normalized\"}]},{\"type\":\"model\",\"name\":\"GridStack1\",\"properties\":[{\"name\":\"mode\",\"kind\":\"Any\",\"default\":\"warn\"},{\"name\":\"ncols\",\"kind\":\"Any\",\"default\":null},{\"name\":\"nrows\",\"kind\":\"Any\",\"default\":null},{\"name\":\"allow_resize\",\"kind\":\"Any\",\"default\":true},{\"name\":\"allow_drag\",\"kind\":\"Any\",\"default\":true},{\"name\":\"state\",\"kind\":\"Any\",\"default\":[]}]},{\"type\":\"model\",\"name\":\"drag1\",\"properties\":[{\"name\":\"slider_width\",\"kind\":\"Any\",\"default\":5},{\"name\":\"slider_color\",\"kind\":\"Any\",\"default\":\"black\"},{\"name\":\"value\",\"kind\":\"Any\",\"default\":50}]},{\"type\":\"model\",\"name\":\"click1\",\"properties\":[{\"name\":\"terminal_output\",\"kind\":\"Any\",\"default\":\"\"},{\"name\":\"debug_name\",\"kind\":\"Any\",\"default\":\"\"},{\"name\":\"clears\",\"kind\":\"Any\",\"default\":0}]},{\"type\":\"model\",\"name\":\"FastWrapper1\",\"properties\":[{\"name\":\"object\",\"kind\":\"Any\",\"default\":null},{\"name\":\"style\",\"kind\":\"Any\",\"default\":null}]},{\"type\":\"model\",\"name\":\"NotificationAreaBase1\",\"properties\":[{\"name\":\"js_events\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}},{\"name\":\"position\",\"kind\":\"Any\",\"default\":\"bottom-right\"},{\"name\":\"_clear\",\"kind\":\"Any\",\"default\":0}]},{\"type\":\"model\",\"name\":\"NotificationArea1\",\"properties\":[{\"name\":\"js_events\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}},{\"name\":\"notifications\",\"kind\":\"Any\",\"default\":[]},{\"name\":\"position\",\"kind\":\"Any\",\"default\":\"bottom-right\"},{\"name\":\"_clear\",\"kind\":\"Any\",\"default\":0},{\"name\":\"types\",\"kind\":\"Any\",\"default\":[{\"type\":\"map\",\"entries\":[[\"type\",\"warning\"],[\"background\",\"#ffc107\"],[\"icon\",{\"type\":\"map\",\"entries\":[[\"className\",\"fas fa-exclamation-triangle\"],[\"tagName\",\"i\"],[\"color\",\"white\"]]}]]},{\"type\":\"map\",\"entries\":[[\"type\",\"info\"],[\"background\",\"#007bff\"],[\"icon\",{\"type\":\"map\",\"entries\":[[\"className\",\"fas fa-info-circle\"],[\"tagName\",\"i\"],[\"color\",\"white\"]]}]]}]}]},{\"type\":\"model\",\"name\":\"Notification\",\"properties\":[{\"name\":\"background\",\"kind\":\"Any\",\"default\":null},{\"name\":\"duration\",\"kind\":\"Any\",\"default\":3000},{\"name\":\"icon\",\"kind\":\"Any\",\"default\":null},{\"name\":\"message\",\"kind\":\"Any\",\"default\":\"\"},{\"name\":\"notification_type\",\"kind\":\"Any\",\"default\":null},{\"name\":\"_rendered\",\"kind\":\"Any\",\"default\":false},{\"name\":\"_destroyed\",\"kind\":\"Any\",\"default\":false}]},{\"type\":\"model\",\"name\":\"TemplateActions1\",\"properties\":[{\"name\":\"open_modal\",\"kind\":\"Any\",\"default\":0},{\"name\":\"close_modal\",\"kind\":\"Any\",\"default\":0}]},{\"type\":\"model\",\"name\":\"BootstrapTemplateActions1\",\"properties\":[{\"name\":\"open_modal\",\"kind\":\"Any\",\"default\":0},{\"name\":\"close_modal\",\"kind\":\"Any\",\"default\":0}]},{\"type\":\"model\",\"name\":\"TemplateEditor1\",\"properties\":[{\"name\":\"layout\",\"kind\":\"Any\",\"default\":[]}]},{\"type\":\"model\",\"name\":\"MaterialTemplateActions1\",\"properties\":[{\"name\":\"open_modal\",\"kind\":\"Any\",\"default\":0},{\"name\":\"close_modal\",\"kind\":\"Any\",\"default\":0}]},{\"type\":\"model\",\"name\":\"ReactiveESM1\",\"properties\":[{\"name\":\"esm_constants\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}}]},{\"type\":\"model\",\"name\":\"JSComponent1\",\"properties\":[{\"name\":\"esm_constants\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}}]},{\"type\":\"model\",\"name\":\"ReactComponent1\",\"properties\":[{\"name\":\"esm_constants\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}}]},{\"type\":\"model\",\"name\":\"AnyWidgetComponent1\",\"properties\":[{\"name\":\"esm_constants\",\"kind\":\"Any\",\"default\":{\"type\":\"map\"}}]},{\"type\":\"model\",\"name\":\"request_value1\",\"properties\":[{\"name\":\"fill\",\"kind\":\"Any\",\"default\":\"none\"},{\"name\":\"_synced\",\"kind\":\"Any\",\"default\":null},{\"name\":\"_request_sync\",\"kind\":\"Any\",\"default\":0}]}]}};\n",
       "  var render_items = [{\"docid\":\"1a8d9004-2244-4fde-90a0-f47c6d960794\",\"roots\":{\"43786612-e930-4202-97a7-d109d4c80a05\":\"f8dec50d-1aec-4c3c-a448-cb3f2ec125af\"},\"root_ids\":[\"43786612-e930-4202-97a7-d109d4c80a05\"]}];\n",
       "  var docs = Object.values(docs_json)\n",
       "  if (!docs) {\n",
       "    return\n",
       "  }\n",
       "  const py_version = docs[0].version.replace('rc', '-rc.').replace('.dev', '-dev.')\n",
       "  async function embed_document(root) {\n",
       "    var Bokeh = get_bokeh(root)\n",
       "    await Bokeh.embed.embed_items_notebook(docs_json, render_items);\n",
       "    for (const render_item of render_items) {\n",
       "      for (const root_id of render_item.root_ids) {\n",
       "\tconst id_el = document.getElementById(root_id)\n",
       "\tif (id_el.children.length && id_el.children[0].hasAttribute('data-root-id')) {\n",
       "\t  const root_el = id_el.children[0]\n",
       "\t  root_el.id = root_el.id + '-rendered'\n",
       "\t  for (const child of root_el.children) {\n",
       "            // Ensure JupyterLab does not capture keyboard shortcuts\n",
       "            // see: https://jupyterlab.readthedocs.io/en/4.1.x/extension/notebook.html#keyboard-interaction-model\n",
       "\t    child.setAttribute('data-lm-suppress-shortcuts', 'true')\n",
       "\t  }\n",
       "\t}\n",
       "      }\n",
       "    }\n",
       "  }\n",
       "  function get_bokeh(root) {\n",
       "    if (root.Bokeh === undefined) {\n",
       "      return null\n",
       "    } else if (root.Bokeh.version !== py_version) {\n",
       "      if (root.Bokeh.versions === undefined || !root.Bokeh.versions.has(py_version)) {\n",
       "\treturn null\n",
       "      }\n",
       "      return root.Bokeh.versions.get(py_version);\n",
       "    } else if (root.Bokeh.version === py_version) {\n",
       "      return root.Bokeh\n",
       "    }\n",
       "    return null\n",
       "  }\n",
       "  function is_loaded(root) {\n",
       "    var Bokeh = get_bokeh(root)\n",
       "    return (Bokeh != null && Bokeh.Panel !== undefined)\n",
       "  }\n",
       "  if (is_loaded(root)) {\n",
       "    embed_document(root);\n",
       "  } else {\n",
       "    var attempts = 0;\n",
       "    var timer = setInterval(function(root) {\n",
       "      if (is_loaded(root)) {\n",
       "        clearInterval(timer);\n",
       "        embed_document(root);\n",
       "      } else if (document.readyState == \"complete\") {\n",
       "        attempts++;\n",
       "        if (attempts > 200) {\n",
       "          clearInterval(timer);\n",
       "\t  var Bokeh = get_bokeh(root)\n",
       "\t  if (Bokeh == null || Bokeh.Panel == null) {\n",
       "            console.warn(\"Panel: ERROR: Unable to run Panel code because Bokeh or Panel library is missing\");\n",
       "\t  } else {\n",
       "\t    console.warn(\"Panel: WARNING: Attempting to render but not all required libraries could be resolved.\")\n",
       "\t    embed_document(root)\n",
       "\t  }\n",
       "        }\n",
       "      }\n",
       "    }, 25, root)\n",
       "  }\n",
       "})(window);</script>"
      ]
     },
     "metadata": {
      "application/vnd.holoviews_exec.v0+json": {
       "id": "43786612-e930-4202-97a7-d109d4c80a05"
      }
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "\n",
       "<div class=\"logo-block\">\n",
       "<img src='data:image/png;base64,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\n",
       "roTBs2RqAAAAAElFTkSuQmCC'\n",
       "     style='height:25px; border-radius:12px; display: inline-block; float: left; vertical-align: middle'></img>\n",
       "\n",
       "\n",
       "\n",
       "\n",
       "  <img src='data:image/png;base64,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'\n",
       "       style='height:15px; border-radius:12px; display: inline-block; float: left'></img>\n",
       "  \n",
       "\n",
       "\n",
       "</div>\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/algc/anaconda3/envs/env-jax/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<script type=\"esms-options\">{\"shimMode\": true}</script><style>*[data-root-id],\n",
       "*[data-root-id] > * {\n",
       "  box-sizing: border-box;\n",
       "  font-family: var(--jp-ui-font-family);\n",
       "  font-size: var(--jp-ui-font-size1);\n",
       "  color: var(--vscode-editor-foreground, var(--jp-ui-font-color1));\n",
       "}\n",
       "\n",
       "/* Override VSCode background color */\n",
       ".cell-output-ipywidget-background:has(\n",
       "    > .cell-output-ipywidget-background > .lm-Widget > *[data-root-id]\n",
       "  ),\n",
       ".cell-output-ipywidget-background:has(> .lm-Widget > *[data-root-id]) {\n",
       "  background-color: transparent !important;\n",
       "}\n",
       "</style>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "(function(root) {\n  function now() {\n    return new Date();\n  }\n\n  const force = false;\n  const py_version = '3.6.2'.replace('rc', '-rc.').replace('.dev', '-dev.');\n  const reloading = true;\n  const Bokeh = root.Bokeh;\n\n  // Set a timeout for this load but only if we are not already initializing\n  if (typeof (root._bokeh_timeout) === \"undefined\" || (force || !root._bokeh_is_initializing)) {\n    root._bokeh_timeout = Date.now() + 5000;\n    root._bokeh_failed_load = false;\n  }\n\n  function run_callbacks() {\n    try {\n      root._bokeh_onload_callbacks.forEach(function(callback) {\n        if (callback != null)\n          callback();\n      });\n    } finally {\n      delete root._bokeh_onload_callbacks;\n    }\n    console.debug(\"Bokeh: all callbacks have finished\");\n  }\n\n  function load_libs(css_urls, js_urls, js_modules, js_exports, callback) {\n    if (css_urls == null) css_urls = [];\n    if (js_urls == null) js_urls = [];\n    if (js_modules == null) js_modules = [];\n    if (js_exports == null) js_exports = {};\n\n    root._bokeh_onload_callbacks.push(callback);\n\n    if (root._bokeh_is_loading > 0) {\n      // Don't load bokeh if it is still initializing\n      console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n      return null;\n    } else if (js_urls.length === 0 && js_modules.length === 0 && Object.keys(js_exports).length === 0) {\n      // There is nothing to load\n      run_callbacks();\n      return null;\n    }\n\n    function on_load() {\n      root._bokeh_is_loading--;\n      if (root._bokeh_is_loading === 0) {\n        console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n        run_callbacks()\n      }\n    }\n    window._bokeh_on_load = on_load\n\n    function on_error(e) {\n      const src_el = e.srcElement\n      console.error(\"failed to load \" + (src_el.href || src_el.src));\n    }\n\n    const skip = [];\n    if (window.requirejs) {\n      window.requirejs.config({'packages': {}, 'paths': {}, 'shim': {}});\n      root._bokeh_is_loading = css_urls.length + 0;\n    } else {\n      root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length + Object.keys(js_exports).length;\n    }\n\n    const existing_stylesheets = []\n    const links = document.getElementsByTagName('link')\n    for (let i = 0; i < links.length; i++) {\n      const link = links[i]\n      if (link.href != null) {\n        existing_stylesheets.push(link.href)\n      }\n    }\n    for (let i = 0; i < css_urls.length; i++) {\n      const url = css_urls[i];\n      const escaped = encodeURI(url)\n      if (existing_stylesheets.indexOf(escaped) !== -1) {\n        on_load()\n        continue;\n      }\n      const element = document.createElement(\"link\");\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.rel = \"stylesheet\";\n      element.type = \"text/css\";\n      element.href = url;\n      console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n      document.body.appendChild(element);\n    }    var existing_scripts = []\n    const scripts = document.getElementsByTagName('script')\n    for (let i = 0; i < scripts.length; i++) {\n      var script = scripts[i]\n      if (script.src != null) {\n        existing_scripts.push(script.src)\n      }\n    }\n    for (let i = 0; i < js_urls.length; i++) {\n      const url = js_urls[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      const element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (let i = 0; i < js_modules.length; i++) {\n      const url = js_modules[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (const name in js_exports) {\n      const url = js_exports[name];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) >= 0 || root[name] != null) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onerror = on_error;\n      element.async = false;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      element.textContent = `\n      import ${name} from \"${url}\"\n      window.${name} = ${name}\n      window._bokeh_on_load()\n      `\n      document.head.appendChild(element);\n    }\n    if (!js_urls.length && !js_modules.length) {\n      on_load()\n    }\n  };\n\n  function inject_raw_css(css) {\n    const element = document.createElement(\"style\");\n    element.appendChild(document.createTextNode(css));\n    document.body.appendChild(element);\n  }\n\n  const js_urls = [\"https://cdn.holoviz.org/panel/1.5.5/dist/bundled/reactiveesm/es-module-shims@^1.10.0/dist/es-module-shims.min.js\"];\n  const js_modules = [];\n  const js_exports = {};\n  const css_urls = [];\n  const inline_js = [    function(Bokeh) {\n      Bokeh.set_log_level(\"info\");\n    },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n  ];\n\n  function run_inline_js() {\n    if ((root.Bokeh !== undefined) || (force === true)) {\n      for (let i = 0; i < inline_js.length; i++) {\n        try {\n          inline_js[i].call(root, root.Bokeh);\n        } catch(e) {\n          if (!reloading) {\n            throw e;\n          }\n        }\n      }\n      // Cache old bokeh versions\n      if (Bokeh != undefined && !reloading) {\n        var NewBokeh = root.Bokeh;\n        if (Bokeh.versions === undefined) {\n          Bokeh.versions = new Map();\n        }\n        if (NewBokeh.version !== Bokeh.version) {\n          Bokeh.versions.set(NewBokeh.version, NewBokeh)\n        }\n        root.Bokeh = Bokeh;\n      }\n    } else if (Date.now() < root._bokeh_timeout) {\n      setTimeout(run_inline_js, 100);\n    } else if (!root._bokeh_failed_load) {\n      console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n      root._bokeh_failed_load = true;\n    }\n    root._bokeh_is_initializing = false\n  }\n\n  function load_or_wait() {\n    // Implement a backoff loop that tries to ensure we do not load multiple\n    // versions of Bokeh and its dependencies at the same time.\n    // In recent versions we use the root._bokeh_is_initializing flag\n    // to determine whether there is an ongoing attempt to initialize\n    // bokeh, however for backward compatibility we also try to ensure\n    // that we do not start loading a newer (Panel>=1.0 and Bokeh>3) version\n    // before older versions are fully initialized.\n    if (root._bokeh_is_initializing && Date.now() > root._bokeh_timeout) {\n      // If the timeout and bokeh was not successfully loaded we reset\n      // everything and try loading again\n      root._bokeh_timeout = Date.now() + 5000;\n      root._bokeh_is_initializing = false;\n      root._bokeh_onload_callbacks = undefined;\n      root._bokeh_is_loading = 0\n      console.log(\"Bokeh: BokehJS was loaded multiple times but one version failed to initialize.\");\n      load_or_wait();\n    } else if (root._bokeh_is_initializing || (typeof root._bokeh_is_initializing === \"undefined\" && root._bokeh_onload_callbacks !== undefined)) {\n      setTimeout(load_or_wait, 100);\n    } else {\n      root._bokeh_is_initializing = true\n      root._bokeh_onload_callbacks = []\n      const bokeh_loaded = root.Bokeh != null && (root.Bokeh.version === py_version || (root.Bokeh.versions !== undefined && root.Bokeh.versions.has(py_version)));\n      if (!reloading && !bokeh_loaded) {\n        if (root.Bokeh) {\n          root.Bokeh = undefined;\n        }\n        console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n      }\n      load_libs(css_urls, js_urls, js_modules, js_exports, function() {\n        console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n        run_inline_js();\n      });\n    }\n  }\n  // Give older versions of the autoload script a head-start to ensure\n  // they initialize before we start loading newer version.\n  setTimeout(load_or_wait, 100)\n}(window));",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n  window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n    function JupyterCommManager() {\n    }\n\n    JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n      if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        comm_manager.register_target(comm_id, function(comm) {\n          comm.on_msg(msg_handler);\n        });\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n          comm.onMsg = msg_handler;\n        });\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n          var messages = comm.messages[Symbol.asyncIterator]();\n          function processIteratorResult(result) {\n            var message = result.value;\n            console.log(message)\n            var content = {data: message.data, comm_id};\n            var buffers = []\n            for (var buffer of message.buffers || []) {\n              buffers.push(new DataView(buffer))\n            }\n            var metadata = message.metadata || {};\n            var msg = {content, buffers, metadata}\n            msg_handler(msg);\n            return messages.next().then(processIteratorResult);\n          }\n          return messages.next().then(processIteratorResult);\n        })\n      }\n    }\n\n    JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n      if (comm_id in window.PyViz.comms) {\n        return window.PyViz.comms[comm_id];\n      } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n        if (msg_handler) {\n          comm.on_msg(msg_handler);\n        }\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n        comm.open();\n        if (msg_handler) {\n          comm.onMsg = msg_handler;\n        }\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        var comm_promise = google.colab.kernel.comms.open(comm_id)\n        comm_promise.then((comm) => {\n          window.PyViz.comms[comm_id] = comm;\n          if (msg_handler) {\n            var messages = comm.messages[Symbol.asyncIterator]();\n            function processIteratorResult(result) {\n              var message = result.value;\n              var content = {data: message.data};\n              var metadata = message.metadata || {comm_id};\n              var msg = {content, metadata}\n              msg_handler(msg);\n              return messages.next().then(processIteratorResult);\n            }\n            return messages.next().then(processIteratorResult);\n          }\n        })\n        var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n          return comm_promise.then((comm) => {\n            comm.send(data, metadata, buffers, disposeOnDone);\n          });\n        };\n        var comm = {\n          send: sendClosure\n        };\n      }\n      window.PyViz.comms[comm_id] = comm;\n      return comm;\n    }\n    window.PyViz.comm_manager = new JupyterCommManager();\n    \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n  var div = document.createElement(\"div\");\n  var script = document.createElement(\"script\");\n  node.appendChild(div);\n  node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n  var output_area = handle.output_area;\n  var output = handle.output;\n  if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n    return\n  }\n  var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n  var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n  if (id !== undefined) {\n    var nchildren = toinsert.length;\n    var html_node = toinsert[nchildren-1].children[0];\n    html_node.innerHTML = output.data[HTML_MIME_TYPE];\n    var scripts = [];\n    var nodelist = html_node.querySelectorAll(\"script\");\n    for (var i in nodelist) {\n      if (nodelist.hasOwnProperty(i)) {\n        scripts.push(nodelist[i])\n      }\n    }\n\n    scripts.forEach( function (oldScript) {\n      var newScript = document.createElement(\"script\");\n      var attrs = [];\n      var nodemap = oldScript.attributes;\n      for (var j in nodemap) {\n        if (nodemap.hasOwnProperty(j)) {\n          attrs.push(nodemap[j])\n        }\n      }\n      attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n      newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n      oldScript.parentNode.replaceChild(newScript, oldScript);\n    });\n    if (JS_MIME_TYPE in output.data) {\n      toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n    }\n    output_area._hv_plot_id = id;\n    if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n      window.PyViz.plot_index[id] = Bokeh.index[id];\n    } else {\n      window.PyViz.plot_index[id] = null;\n    }\n  } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n    var bk_div = document.createElement(\"div\");\n    bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n    var script_attrs = bk_div.children[0].attributes;\n    for (var i = 0; i < script_attrs.length; i++) {\n      toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n    }\n    // store reference to server id on output_area\n    output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n  }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n  var id = handle.cell.output_area._hv_plot_id;\n  var server_id = handle.cell.output_area._bokeh_server_id;\n  if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n  var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n  if (server_id !== null) {\n    comm.send({event_type: 'server_delete', 'id': server_id});\n    return;\n  } else if (comm !== null) {\n    comm.send({event_type: 'delete', 'id': id});\n  }\n  delete PyViz.plot_index[id];\n  if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n    var doc = window.Bokeh.index[id].model.document\n    doc.clear();\n    const i = window.Bokeh.documents.indexOf(doc);\n    if (i > -1) {\n      window.Bokeh.documents.splice(i, 1);\n    }\n  }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n  delete PyViz.comms[\"hv-extension-comm\"];\n  window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n  handle_clear_output(event, {cell: {output_area: handle.output_area}})\n  handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n  function append_mime(data, metadata, element) {\n    // create a DOM node to render to\n    var toinsert = this.create_output_subarea(\n    metadata,\n    CLASS_NAME,\n    EXEC_MIME_TYPE\n    );\n    this.keyboard_manager.register_events(toinsert);\n    // Render to node\n    var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n    render(props, toinsert[0]);\n    element.append(toinsert);\n    return toinsert\n  }\n\n  events.on('output_added.OutputArea', handle_add_output);\n  events.on('output_updated.OutputArea', handle_update_output);\n  events.on('clear_output.CodeCell', handle_clear_output);\n  events.on('delete.Cell', handle_clear_output);\n  events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n  OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n    safe: true,\n    index: 0\n  });\n}\n\nif (window.Jupyter !== undefined) {\n  try {\n    var events = require('base/js/events');\n    var OutputArea = require('notebook/js/outputarea').OutputArea;\n    if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n      register_renderer(events, OutputArea);\n    }\n  } catch(err) {\n  }\n}\n",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<script type=\"esms-options\">{\"shimMode\": true}</script><style>*[data-root-id],\n",
       "*[data-root-id] > * {\n",
       "  box-sizing: border-box;\n",
       "  font-family: var(--jp-ui-font-family);\n",
       "  font-size: var(--jp-ui-font-size1);\n",
       "  color: var(--vscode-editor-foreground, var(--jp-ui-font-color1));\n",
       "}\n",
       "\n",
       "/* Override VSCode background color */\n",
       ".cell-output-ipywidget-background:has(\n",
       "    > .cell-output-ipywidget-background > .lm-Widget > *[data-root-id]\n",
       "  ),\n",
       ".cell-output-ipywidget-background:has(> .lm-Widget > *[data-root-id]) {\n",
       "  background-color: transparent !important;\n",
       "}\n",
       "</style>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "(function(root) {\n  function now() {\n    return new Date();\n  }\n\n  const force = false;\n  const py_version = '3.6.2'.replace('rc', '-rc.').replace('.dev', '-dev.');\n  const reloading = true;\n  const Bokeh = root.Bokeh;\n\n  // Set a timeout for this load but only if we are not already initializing\n  if (typeof (root._bokeh_timeout) === \"undefined\" || (force || !root._bokeh_is_initializing)) {\n    root._bokeh_timeout = Date.now() + 5000;\n    root._bokeh_failed_load = false;\n  }\n\n  function run_callbacks() {\n    try {\n      root._bokeh_onload_callbacks.forEach(function(callback) {\n        if (callback != null)\n          callback();\n      });\n    } finally {\n      delete root._bokeh_onload_callbacks;\n    }\n    console.debug(\"Bokeh: all callbacks have finished\");\n  }\n\n  function load_libs(css_urls, js_urls, js_modules, js_exports, callback) {\n    if (css_urls == null) css_urls = [];\n    if (js_urls == null) js_urls = [];\n    if (js_modules == null) js_modules = [];\n    if (js_exports == null) js_exports = {};\n\n    root._bokeh_onload_callbacks.push(callback);\n\n    if (root._bokeh_is_loading > 0) {\n      // Don't load bokeh if it is still initializing\n      console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n      return null;\n    } else if (js_urls.length === 0 && js_modules.length === 0 && Object.keys(js_exports).length === 0) {\n      // There is nothing to load\n      run_callbacks();\n      return null;\n    }\n\n    function on_load() {\n      root._bokeh_is_loading--;\n      if (root._bokeh_is_loading === 0) {\n        console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n        run_callbacks()\n      }\n    }\n    window._bokeh_on_load = on_load\n\n    function on_error(e) {\n      const src_el = e.srcElement\n      console.error(\"failed to load \" + (src_el.href || src_el.src));\n    }\n\n    const skip = [];\n    if (window.requirejs) {\n      window.requirejs.config({'packages': {}, 'paths': {}, 'shim': {}});\n      root._bokeh_is_loading = css_urls.length + 0;\n    } else {\n      root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length + Object.keys(js_exports).length;\n    }\n\n    const existing_stylesheets = []\n    const links = document.getElementsByTagName('link')\n    for (let i = 0; i < links.length; i++) {\n      const link = links[i]\n      if (link.href != null) {\n        existing_stylesheets.push(link.href)\n      }\n    }\n    for (let i = 0; i < css_urls.length; i++) {\n      const url = css_urls[i];\n      const escaped = encodeURI(url)\n      if (existing_stylesheets.indexOf(escaped) !== -1) {\n        on_load()\n        continue;\n      }\n      const element = document.createElement(\"link\");\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.rel = \"stylesheet\";\n      element.type = \"text/css\";\n      element.href = url;\n      console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n      document.body.appendChild(element);\n    }    var existing_scripts = []\n    const scripts = document.getElementsByTagName('script')\n    for (let i = 0; i < scripts.length; i++) {\n      var script = scripts[i]\n      if (script.src != null) {\n        existing_scripts.push(script.src)\n      }\n    }\n    for (let i = 0; i < js_urls.length; i++) {\n      const url = js_urls[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      const element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (let i = 0; i < js_modules.length; i++) {\n      const url = js_modules[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (const name in js_exports) {\n      const url = js_exports[name];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) >= 0 || root[name] != null) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onerror = on_error;\n      element.async = false;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      element.textContent = `\n      import ${name} from \"${url}\"\n      window.${name} = ${name}\n      window._bokeh_on_load()\n      `\n      document.head.appendChild(element);\n    }\n    if (!js_urls.length && !js_modules.length) {\n      on_load()\n    }\n  };\n\n  function inject_raw_css(css) {\n    const element = document.createElement(\"style\");\n    element.appendChild(document.createTextNode(css));\n    document.body.appendChild(element);\n  }\n\n  const js_urls = [\"https://cdn.holoviz.org/panel/1.5.5/dist/bundled/reactiveesm/es-module-shims@^1.10.0/dist/es-module-shims.min.js\"];\n  const js_modules = [];\n  const js_exports = {};\n  const css_urls = [];\n  const inline_js = [    function(Bokeh) {\n      Bokeh.set_log_level(\"info\");\n    },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n  ];\n\n  function run_inline_js() {\n    if ((root.Bokeh !== undefined) || (force === true)) {\n      for (let i = 0; i < inline_js.length; i++) {\n        try {\n          inline_js[i].call(root, root.Bokeh);\n        } catch(e) {\n          if (!reloading) {\n            throw e;\n          }\n        }\n      }\n      // Cache old bokeh versions\n      if (Bokeh != undefined && !reloading) {\n        var NewBokeh = root.Bokeh;\n        if (Bokeh.versions === undefined) {\n          Bokeh.versions = new Map();\n        }\n        if (NewBokeh.version !== Bokeh.version) {\n          Bokeh.versions.set(NewBokeh.version, NewBokeh)\n        }\n        root.Bokeh = Bokeh;\n      }\n    } else if (Date.now() < root._bokeh_timeout) {\n      setTimeout(run_inline_js, 100);\n    } else if (!root._bokeh_failed_load) {\n      console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n      root._bokeh_failed_load = true;\n    }\n    root._bokeh_is_initializing = false\n  }\n\n  function load_or_wait() {\n    // Implement a backoff loop that tries to ensure we do not load multiple\n    // versions of Bokeh and its dependencies at the same time.\n    // In recent versions we use the root._bokeh_is_initializing flag\n    // to determine whether there is an ongoing attempt to initialize\n    // bokeh, however for backward compatibility we also try to ensure\n    // that we do not start loading a newer (Panel>=1.0 and Bokeh>3) version\n    // before older versions are fully initialized.\n    if (root._bokeh_is_initializing && Date.now() > root._bokeh_timeout) {\n      // If the timeout and bokeh was not successfully loaded we reset\n      // everything and try loading again\n      root._bokeh_timeout = Date.now() + 5000;\n      root._bokeh_is_initializing = false;\n      root._bokeh_onload_callbacks = undefined;\n      root._bokeh_is_loading = 0\n      console.log(\"Bokeh: BokehJS was loaded multiple times but one version failed to initialize.\");\n      load_or_wait();\n    } else if (root._bokeh_is_initializing || (typeof root._bokeh_is_initializing === \"undefined\" && root._bokeh_onload_callbacks !== undefined)) {\n      setTimeout(load_or_wait, 100);\n    } else {\n      root._bokeh_is_initializing = true\n      root._bokeh_onload_callbacks = []\n      const bokeh_loaded = root.Bokeh != null && (root.Bokeh.version === py_version || (root.Bokeh.versions !== undefined && root.Bokeh.versions.has(py_version)));\n      if (!reloading && !bokeh_loaded) {\n        if (root.Bokeh) {\n          root.Bokeh = undefined;\n        }\n        console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n      }\n      load_libs(css_urls, js_urls, js_modules, js_exports, function() {\n        console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n        run_inline_js();\n      });\n    }\n  }\n  // Give older versions of the autoload script a head-start to ensure\n  // they initialize before we start loading newer version.\n  setTimeout(load_or_wait, 100)\n}(window));",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n  window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n    function JupyterCommManager() {\n    }\n\n    JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n      if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        comm_manager.register_target(comm_id, function(comm) {\n          comm.on_msg(msg_handler);\n        });\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n          comm.onMsg = msg_handler;\n        });\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n          var messages = comm.messages[Symbol.asyncIterator]();\n          function processIteratorResult(result) {\n            var message = result.value;\n            console.log(message)\n            var content = {data: message.data, comm_id};\n            var buffers = []\n            for (var buffer of message.buffers || []) {\n              buffers.push(new DataView(buffer))\n            }\n            var metadata = message.metadata || {};\n            var msg = {content, buffers, metadata}\n            msg_handler(msg);\n            return messages.next().then(processIteratorResult);\n          }\n          return messages.next().then(processIteratorResult);\n        })\n      }\n    }\n\n    JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n      if (comm_id in window.PyViz.comms) {\n        return window.PyViz.comms[comm_id];\n      } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n        if (msg_handler) {\n          comm.on_msg(msg_handler);\n        }\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n        comm.open();\n        if (msg_handler) {\n          comm.onMsg = msg_handler;\n        }\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        var comm_promise = google.colab.kernel.comms.open(comm_id)\n        comm_promise.then((comm) => {\n          window.PyViz.comms[comm_id] = comm;\n          if (msg_handler) {\n            var messages = comm.messages[Symbol.asyncIterator]();\n            function processIteratorResult(result) {\n              var message = result.value;\n              var content = {data: message.data};\n              var metadata = message.metadata || {comm_id};\n              var msg = {content, metadata}\n              msg_handler(msg);\n              return messages.next().then(processIteratorResult);\n            }\n            return messages.next().then(processIteratorResult);\n          }\n        })\n        var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n          return comm_promise.then((comm) => {\n            comm.send(data, metadata, buffers, disposeOnDone);\n          });\n        };\n        var comm = {\n          send: sendClosure\n        };\n      }\n      window.PyViz.comms[comm_id] = comm;\n      return comm;\n    }\n    window.PyViz.comm_manager = new JupyterCommManager();\n    \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n  var div = document.createElement(\"div\");\n  var script = document.createElement(\"script\");\n  node.appendChild(div);\n  node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n  var output_area = handle.output_area;\n  var output = handle.output;\n  if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n    return\n  }\n  var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n  var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n  if (id !== undefined) {\n    var nchildren = toinsert.length;\n    var html_node = toinsert[nchildren-1].children[0];\n    html_node.innerHTML = output.data[HTML_MIME_TYPE];\n    var scripts = [];\n    var nodelist = html_node.querySelectorAll(\"script\");\n    for (var i in nodelist) {\n      if (nodelist.hasOwnProperty(i)) {\n        scripts.push(nodelist[i])\n      }\n    }\n\n    scripts.forEach( function (oldScript) {\n      var newScript = document.createElement(\"script\");\n      var attrs = [];\n      var nodemap = oldScript.attributes;\n      for (var j in nodemap) {\n        if (nodemap.hasOwnProperty(j)) {\n          attrs.push(nodemap[j])\n        }\n      }\n      attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n      newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n      oldScript.parentNode.replaceChild(newScript, oldScript);\n    });\n    if (JS_MIME_TYPE in output.data) {\n      toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n    }\n    output_area._hv_plot_id = id;\n    if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n      window.PyViz.plot_index[id] = Bokeh.index[id];\n    } else {\n      window.PyViz.plot_index[id] = null;\n    }\n  } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n    var bk_div = document.createElement(\"div\");\n    bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n    var script_attrs = bk_div.children[0].attributes;\n    for (var i = 0; i < script_attrs.length; i++) {\n      toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n    }\n    // store reference to server id on output_area\n    output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n  }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n  var id = handle.cell.output_area._hv_plot_id;\n  var server_id = handle.cell.output_area._bokeh_server_id;\n  if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n  var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n  if (server_id !== null) {\n    comm.send({event_type: 'server_delete', 'id': server_id});\n    return;\n  } else if (comm !== null) {\n    comm.send({event_type: 'delete', 'id': id});\n  }\n  delete PyViz.plot_index[id];\n  if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n    var doc = window.Bokeh.index[id].model.document\n    doc.clear();\n    const i = window.Bokeh.documents.indexOf(doc);\n    if (i > -1) {\n      window.Bokeh.documents.splice(i, 1);\n    }\n  }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n  delete PyViz.comms[\"hv-extension-comm\"];\n  window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n  handle_clear_output(event, {cell: {output_area: handle.output_area}})\n  handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n  function append_mime(data, metadata, element) {\n    // create a DOM node to render to\n    var toinsert = this.create_output_subarea(\n    metadata,\n    CLASS_NAME,\n    EXEC_MIME_TYPE\n    );\n    this.keyboard_manager.register_events(toinsert);\n    // Render to node\n    var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n    render(props, toinsert[0]);\n    element.append(toinsert);\n    return toinsert\n  }\n\n  events.on('output_added.OutputArea', handle_add_output);\n  events.on('output_updated.OutputArea', handle_update_output);\n  events.on('clear_output.CodeCell', handle_clear_output);\n  events.on('delete.Cell', handle_clear_output);\n  events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n  OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n    safe: true,\n    index: 0\n  });\n}\n\nif (window.Jupyter !== undefined) {\n  try {\n    var events = require('base/js/events');\n    var OutputArea = require('notebook/js/outputarea').OutputArea;\n    if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n      register_renderer(events, OutputArea);\n    }\n  } catch(err) {\n  }\n}\n",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<script type=\"esms-options\">{\"shimMode\": true}</script><style>*[data-root-id],\n",
       "*[data-root-id] > * {\n",
       "  box-sizing: border-box;\n",
       "  font-family: var(--jp-ui-font-family);\n",
       "  font-size: var(--jp-ui-font-size1);\n",
       "  color: var(--vscode-editor-foreground, var(--jp-ui-font-color1));\n",
       "}\n",
       "\n",
       "/* Override VSCode background color */\n",
       ".cell-output-ipywidget-background:has(\n",
       "    > .cell-output-ipywidget-background > .lm-Widget > *[data-root-id]\n",
       "  ),\n",
       ".cell-output-ipywidget-background:has(> .lm-Widget > *[data-root-id]) {\n",
       "  background-color: transparent !important;\n",
       "}\n",
       "</style>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "(function(root) {\n  function now() {\n    return new Date();\n  }\n\n  const force = false;\n  const py_version = '3.6.2'.replace('rc', '-rc.').replace('.dev', '-dev.');\n  const reloading = true;\n  const Bokeh = root.Bokeh;\n\n  // Set a timeout for this load but only if we are not already initializing\n  if (typeof (root._bokeh_timeout) === \"undefined\" || (force || !root._bokeh_is_initializing)) {\n    root._bokeh_timeout = Date.now() + 5000;\n    root._bokeh_failed_load = false;\n  }\n\n  function run_callbacks() {\n    try {\n      root._bokeh_onload_callbacks.forEach(function(callback) {\n        if (callback != null)\n          callback();\n      });\n    } finally {\n      delete root._bokeh_onload_callbacks;\n    }\n    console.debug(\"Bokeh: all callbacks have finished\");\n  }\n\n  function load_libs(css_urls, js_urls, js_modules, js_exports, callback) {\n    if (css_urls == null) css_urls = [];\n    if (js_urls == null) js_urls = [];\n    if (js_modules == null) js_modules = [];\n    if (js_exports == null) js_exports = {};\n\n    root._bokeh_onload_callbacks.push(callback);\n\n    if (root._bokeh_is_loading > 0) {\n      // Don't load bokeh if it is still initializing\n      console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n      return null;\n    } else if (js_urls.length === 0 && js_modules.length === 0 && Object.keys(js_exports).length === 0) {\n      // There is nothing to load\n      run_callbacks();\n      return null;\n    }\n\n    function on_load() {\n      root._bokeh_is_loading--;\n      if (root._bokeh_is_loading === 0) {\n        console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n        run_callbacks()\n      }\n    }\n    window._bokeh_on_load = on_load\n\n    function on_error(e) {\n      const src_el = e.srcElement\n      console.error(\"failed to load \" + (src_el.href || src_el.src));\n    }\n\n    const skip = [];\n    if (window.requirejs) {\n      window.requirejs.config({'packages': {}, 'paths': {}, 'shim': {}});\n      root._bokeh_is_loading = css_urls.length + 0;\n    } else {\n      root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length + Object.keys(js_exports).length;\n    }\n\n    const existing_stylesheets = []\n    const links = document.getElementsByTagName('link')\n    for (let i = 0; i < links.length; i++) {\n      const link = links[i]\n      if (link.href != null) {\n        existing_stylesheets.push(link.href)\n      }\n    }\n    for (let i = 0; i < css_urls.length; i++) {\n      const url = css_urls[i];\n      const escaped = encodeURI(url)\n      if (existing_stylesheets.indexOf(escaped) !== -1) {\n        on_load()\n        continue;\n      }\n      const element = document.createElement(\"link\");\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.rel = \"stylesheet\";\n      element.type = \"text/css\";\n      element.href = url;\n      console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n      document.body.appendChild(element);\n    }    var existing_scripts = []\n    const scripts = document.getElementsByTagName('script')\n    for (let i = 0; i < scripts.length; i++) {\n      var script = scripts[i]\n      if (script.src != null) {\n        existing_scripts.push(script.src)\n      }\n    }\n    for (let i = 0; i < js_urls.length; i++) {\n      const url = js_urls[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      const element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (let i = 0; i < js_modules.length; i++) {\n      const url = js_modules[i];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) !== -1 || existing_scripts.indexOf(escaped) !== -1) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onload = on_load;\n      element.onerror = on_error;\n      element.async = false;\n      element.src = url;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      document.head.appendChild(element);\n    }\n    for (const name in js_exports) {\n      const url = js_exports[name];\n      const escaped = encodeURI(url)\n      if (skip.indexOf(escaped) >= 0 || root[name] != null) {\n        if (!window.requirejs) {\n          on_load();\n        }\n        continue;\n      }\n      var element = document.createElement('script');\n      element.onerror = on_error;\n      element.async = false;\n      element.type = \"module\";\n      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n      element.textContent = `\n      import ${name} from \"${url}\"\n      window.${name} = ${name}\n      window._bokeh_on_load()\n      `\n      document.head.appendChild(element);\n    }\n    if (!js_urls.length && !js_modules.length) {\n      on_load()\n    }\n  };\n\n  function inject_raw_css(css) {\n    const element = document.createElement(\"style\");\n    element.appendChild(document.createTextNode(css));\n    document.body.appendChild(element);\n  }\n\n  const js_urls = [\"https://cdn.holoviz.org/panel/1.5.5/dist/bundled/reactiveesm/es-module-shims@^1.10.0/dist/es-module-shims.min.js\"];\n  const js_modules = [];\n  const js_exports = {};\n  const css_urls = [];\n  const inline_js = [    function(Bokeh) {\n      Bokeh.set_log_level(\"info\");\n    },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n  ];\n\n  function run_inline_js() {\n    if ((root.Bokeh !== undefined) || (force === true)) {\n      for (let i = 0; i < inline_js.length; i++) {\n        try {\n          inline_js[i].call(root, root.Bokeh);\n        } catch(e) {\n          if (!reloading) {\n            throw e;\n          }\n        }\n      }\n      // Cache old bokeh versions\n      if (Bokeh != undefined && !reloading) {\n        var NewBokeh = root.Bokeh;\n        if (Bokeh.versions === undefined) {\n          Bokeh.versions = new Map();\n        }\n        if (NewBokeh.version !== Bokeh.version) {\n          Bokeh.versions.set(NewBokeh.version, NewBokeh)\n        }\n        root.Bokeh = Bokeh;\n      }\n    } else if (Date.now() < root._bokeh_timeout) {\n      setTimeout(run_inline_js, 100);\n    } else if (!root._bokeh_failed_load) {\n      console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n      root._bokeh_failed_load = true;\n    }\n    root._bokeh_is_initializing = false\n  }\n\n  function load_or_wait() {\n    // Implement a backoff loop that tries to ensure we do not load multiple\n    // versions of Bokeh and its dependencies at the same time.\n    // In recent versions we use the root._bokeh_is_initializing flag\n    // to determine whether there is an ongoing attempt to initialize\n    // bokeh, however for backward compatibility we also try to ensure\n    // that we do not start loading a newer (Panel>=1.0 and Bokeh>3) version\n    // before older versions are fully initialized.\n    if (root._bokeh_is_initializing && Date.now() > root._bokeh_timeout) {\n      // If the timeout and bokeh was not successfully loaded we reset\n      // everything and try loading again\n      root._bokeh_timeout = Date.now() + 5000;\n      root._bokeh_is_initializing = false;\n      root._bokeh_onload_callbacks = undefined;\n      root._bokeh_is_loading = 0\n      console.log(\"Bokeh: BokehJS was loaded multiple times but one version failed to initialize.\");\n      load_or_wait();\n    } else if (root._bokeh_is_initializing || (typeof root._bokeh_is_initializing === \"undefined\" && root._bokeh_onload_callbacks !== undefined)) {\n      setTimeout(load_or_wait, 100);\n    } else {\n      root._bokeh_is_initializing = true\n      root._bokeh_onload_callbacks = []\n      const bokeh_loaded = root.Bokeh != null && (root.Bokeh.version === py_version || (root.Bokeh.versions !== undefined && root.Bokeh.versions.has(py_version)));\n      if (!reloading && !bokeh_loaded) {\n        if (root.Bokeh) {\n          root.Bokeh = undefined;\n        }\n        console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n      }\n      load_libs(css_urls, js_urls, js_modules, js_exports, function() {\n        console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n        run_inline_js();\n      });\n    }\n  }\n  // Give older versions of the autoload script a head-start to ensure\n  // they initialize before we start loading newer version.\n  setTimeout(load_or_wait, 100)\n}(window));",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/javascript": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n  window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n    function JupyterCommManager() {\n    }\n\n    JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n      if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        comm_manager.register_target(comm_id, function(comm) {\n          comm.on_msg(msg_handler);\n        });\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n          comm.onMsg = msg_handler;\n        });\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n          var messages = comm.messages[Symbol.asyncIterator]();\n          function processIteratorResult(result) {\n            var message = result.value;\n            console.log(message)\n            var content = {data: message.data, comm_id};\n            var buffers = []\n            for (var buffer of message.buffers || []) {\n              buffers.push(new DataView(buffer))\n            }\n            var metadata = message.metadata || {};\n            var msg = {content, buffers, metadata}\n            msg_handler(msg);\n            return messages.next().then(processIteratorResult);\n          }\n          return messages.next().then(processIteratorResult);\n        })\n      }\n    }\n\n    JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n      if (comm_id in window.PyViz.comms) {\n        return window.PyViz.comms[comm_id];\n      } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n        var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n        var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n        if (msg_handler) {\n          comm.on_msg(msg_handler);\n        }\n      } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n        var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n        comm.open();\n        if (msg_handler) {\n          comm.onMsg = msg_handler;\n        }\n      } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n        var comm_promise = google.colab.kernel.comms.open(comm_id)\n        comm_promise.then((comm) => {\n          window.PyViz.comms[comm_id] = comm;\n          if (msg_handler) {\n            var messages = comm.messages[Symbol.asyncIterator]();\n            function processIteratorResult(result) {\n              var message = result.value;\n              var content = {data: message.data};\n              var metadata = message.metadata || {comm_id};\n              var msg = {content, metadata}\n              msg_handler(msg);\n              return messages.next().then(processIteratorResult);\n            }\n            return messages.next().then(processIteratorResult);\n          }\n        })\n        var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n          return comm_promise.then((comm) => {\n            comm.send(data, metadata, buffers, disposeOnDone);\n          });\n        };\n        var comm = {\n          send: sendClosure\n        };\n      }\n      window.PyViz.comms[comm_id] = comm;\n      return comm;\n    }\n    window.PyViz.comm_manager = new JupyterCommManager();\n    \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n  var div = document.createElement(\"div\");\n  var script = document.createElement(\"script\");\n  node.appendChild(div);\n  node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n  var output_area = handle.output_area;\n  var output = handle.output;\n  if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n    return\n  }\n  var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n  var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n  if (id !== undefined) {\n    var nchildren = toinsert.length;\n    var html_node = toinsert[nchildren-1].children[0];\n    html_node.innerHTML = output.data[HTML_MIME_TYPE];\n    var scripts = [];\n    var nodelist = html_node.querySelectorAll(\"script\");\n    for (var i in nodelist) {\n      if (nodelist.hasOwnProperty(i)) {\n        scripts.push(nodelist[i])\n      }\n    }\n\n    scripts.forEach( function (oldScript) {\n      var newScript = document.createElement(\"script\");\n      var attrs = [];\n      var nodemap = oldScript.attributes;\n      for (var j in nodemap) {\n        if (nodemap.hasOwnProperty(j)) {\n          attrs.push(nodemap[j])\n        }\n      }\n      attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n      newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n      oldScript.parentNode.replaceChild(newScript, oldScript);\n    });\n    if (JS_MIME_TYPE in output.data) {\n      toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n    }\n    output_area._hv_plot_id = id;\n    if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n      window.PyViz.plot_index[id] = Bokeh.index[id];\n    } else {\n      window.PyViz.plot_index[id] = null;\n    }\n  } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n    var bk_div = document.createElement(\"div\");\n    bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n    var script_attrs = bk_div.children[0].attributes;\n    for (var i = 0; i < script_attrs.length; i++) {\n      toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n    }\n    // store reference to server id on output_area\n    output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n  }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n  var id = handle.cell.output_area._hv_plot_id;\n  var server_id = handle.cell.output_area._bokeh_server_id;\n  if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n  var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n  if (server_id !== null) {\n    comm.send({event_type: 'server_delete', 'id': server_id});\n    return;\n  } else if (comm !== null) {\n    comm.send({event_type: 'delete', 'id': id});\n  }\n  delete PyViz.plot_index[id];\n  if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n    var doc = window.Bokeh.index[id].model.document\n    doc.clear();\n    const i = window.Bokeh.documents.indexOf(doc);\n    if (i > -1) {\n      window.Bokeh.documents.splice(i, 1);\n    }\n  }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n  delete PyViz.comms[\"hv-extension-comm\"];\n  window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n  handle_clear_output(event, {cell: {output_area: handle.output_area}})\n  handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n  function append_mime(data, metadata, element) {\n    // create a DOM node to render to\n    var toinsert = this.create_output_subarea(\n    metadata,\n    CLASS_NAME,\n    EXEC_MIME_TYPE\n    );\n    this.keyboard_manager.register_events(toinsert);\n    // Render to node\n    var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n    render(props, toinsert[0]);\n    element.append(toinsert);\n    return toinsert\n  }\n\n  events.on('output_added.OutputArea', handle_add_output);\n  events.on('output_updated.OutputArea', handle_update_output);\n  events.on('clear_output.CodeCell', handle_clear_output);\n  events.on('delete.Cell', handle_clear_output);\n  events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n  OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n    safe: true,\n    index: 0\n  });\n}\n\nif (window.Jupyter !== undefined) {\n  try {\n    var events = require('base/js/events');\n    var OutputArea = require('notebook/js/outputarea').OutputArea;\n    if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n      register_renderer(events, OutputArea);\n    }\n  } catch(err) {\n  }\n}\n",
      "application/vnd.holoviews_load.v0+json": ""
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from experiments.downstream.utils.gradient_int import shortest_path, plot_curve_euclidean_2d\n",
    "from experiments.downstream.utils.autodecoding_import import autodecoding_import"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Homogenous 2D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Seed set to 0\n",
      "Precomputing data:   0%|          | 0/500 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Precomputing data: 100%|██████████| 500/500 [00:05<00:00, 94.80it/s]\n",
      "Precomputing data: 100%|██████████| 100/100 [00:01<00:00, 96.31it/s]\n",
      "Precomputing data: 100%|██████████| 100/100 [00:01<00:00, 95.73it/s]\n",
      "Fitting val: 100%|██████████| 100/100 [03:47<00:00,  2.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting time 227.24270009994507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "solver, test_autodecoder,test_loader, (vmin, vmax), (x_min, x_max) = autodecoding_import(\"yn1g91gf\",  aux_out=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time 0.36231231689453125\n"
     ]
    }
   ],
   "source": [
    "solver, test_autodecoder,test_loader, (vmin, vmax), (x_min, x_max) = autodecoding_import(\"yn1g91gf\",  aux_out=True)\n",
    "\n",
    "idx_vel = 0\n",
    "latents = test_autodecoder([idx_vel])\n",
    "vel = test_loader.dataset.base_dataset[idx_vel][0]\n",
    "points =shortest_path(\n",
    "    start=[0.5, 0.5], goal=[-0.5, -0.5], solver=solver, latents=latents, step_size=0.01, epsilon=0.05, max_iter=500\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<img src='data:image/png;base64,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' style='max-width:100%; margin: auto; display: block; '/>"
      ],
      "text/plain": [
       ":Overlay\n",
       "   .Image.I       :Image   [X,Y]   (Velocity)\n",
       "   .Path.Path     :Path   [x,y]\n",
       "   .Scatter.Start :Scatter   [x]   (y)\n",
       "   .Scatter.Goal  :Scatter   [x]   (y)"
      ]
     },
     "execution_count": 126,
     "metadata": {
      "application/vnd.holoviews_exec.v0+json": {}
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "plot_curve_euclidean_2d(points, vel, x_min=x_min, x_max=x_max, vmin=vmin, vmax=vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env-jax",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
