{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abad3122-0e23-4672-bd8f-a2cc6bd22835",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "import dynamo as dyn\n",
    "import anndata\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import scipy.sparse\n",
    "from anndata import AnnData\n",
    "from scipy.sparse import csr_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f34c3e5-ba55-4ced-9efe-68d09d28953c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "rpe1 = dyn.sample_data.scEU_seq_rpe1()\n",
    "dyn.convert2float(rpe1, ['Cell_cycle_possition', 'Cell_cycle_relativePos'])\n",
    "\n",
    "rpe1_kinetics = rpe1[rpe1.obs.exp_type=='Pulse', :]\n",
    "rpe1_kinetics.obs['time'] = rpe1_kinetics.obs['time'].astype(str)\n",
    "rpe1_kinetics.obs.loc[rpe1_kinetics.obs['time'] == 'dmso', 'time'] = -1\n",
    "rpe1_kinetics.obs['time'] = rpe1_kinetics.obs['time'].astype(float)\n",
    "rpe1_kinetics = rpe1_kinetics[rpe1_kinetics.obs.time != -1, :]\n",
    "rpe1_kinetics.layers['new'], rpe1_kinetics.layers['total'] = rpe1_kinetics.layers['ul'] + rpe1_kinetics.layers['sl'], rpe1_kinetics.layers['su'] + rpe1_kinetics.layers['sl'] + rpe1_kinetics.layers['uu'] + rpe1_kinetics.layers['ul']\n",
    "del rpe1_kinetics.layers['uu'], rpe1_kinetics.layers['ul'], rpe1_kinetics.layers['su'], rpe1_kinetics.layers['sl']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "569ebf9c-2921-47b4-a313-01a5567fa6d6",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "rpe1_genes = ['UNG', 'PCNA', 'PLK1', 'HPRT1']\n",
    "rpe1_kinetics.obs.time  = rpe1_kinetics.obs.time.astype('float')\n",
    "rpe1_kinetics.obs.time = rpe1_kinetics.obs.time/60 # convert minutes to hours\n",
    "dyn.tl.recipe_kin_data(adata=rpe1_kinetics,\n",
    "                       keep_filtered_genes=True,\n",
    "                       keep_raw_layers=True,\n",
    "                       del_2nd_moments=False,\n",
    "                       tkey='time',\n",
    "                      )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb97f65b-68d3-40d7-aa49-4e75e9996e86",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def streamline(adata):\n",
    "    dyn.tl.reduceDimension(adata, reduction_method='umap')\n",
    "    dyn.tl.cell_velocities(adata, enforce=True, vkey='velocity_T', ekey='M_t', basis='RFP_GFP', method = \"cosine\")\n",
    "    dyn.pl.streamline_plot(adata, color=['Cell_cycle_possition', 'Cell_cycle_relativePos'], basis='RFP_GFP')\n",
    "    return adata\n",
    "rpe1_kinetics.obsm['X_RFP_GFP'] = rpe1_kinetics.obs.loc[:, ['RFP_log10_corrected', 'GFP_log10_corrected']].values.astype('float')\n",
    "streamline(rpe1_kinetics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "78c9b458-b302-41f1-88d1-47a568b56915",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dyn.pl.streamline_plot(rpe1_kinetics, color=['cell_cycle_phase'], basis='pca')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "afc5a8e8-3839-4b23-a92c-08eb796f9e36",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dyn.tl.cell_velocities(\n",
    "    rpe1_kinetics,\n",
    "    enforce=True,\n",
    "    vkey='velocity_T', ekey='M_t',\n",
    "    method=\"cosine\",\n",
    "    neg_cells_trick = True,\n",
    "    basis = \"pca\",\n",
    ");"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96857b60-33be-4c9f-8a1b-2416191e3e78",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dyn.vf.VectorField(rpe1_kinetics, basis='RFP_GFP', M=50)\n",
    "dyn.vf.VectorField(rpe1_kinetics, basis='pca', M=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbbabcc0-c871-4f3a-8f89-4174712787d0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "rpe1_kinetics.write_h5ad(\"rpe1_kinetics.h5ad\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d4f7216-e352-4f29-b369-ccd6a0128524",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# data = {\"x\" : torch.tensor(rpe1_kinetics.obsm[\"X_RFP_GFP_SparseVFC\"]).float(),\n",
    "#         \"v\" : torch.tensor(rpe1_kinetics.obsm[\"velocity_RFP_GFP_SparseVFC\"]).float()}\n",
    "dim = 30\n",
    "data = {\"x\" : torch.tensor(rpe1_kinetics.obsm[\"X_pca_SparseVFC\"][:, range(dim)]).float(),\n",
    "        \"v\" : torch.tensor(rpe1_kinetics.obsm[\"velocity_pca_SparseVFC\"][:, range(dim)]).float()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "111b0700-aa03-4fd4-a35c-95c5fb950e95",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sklearn as sk\n",
    "import torch\n",
    "from sklearn import linear_model\n",
    "_X = data['x']\n",
    "_v = data['v']\n",
    "\n",
    "# Fit linear field\n",
    "lr = linear_model.RidgeCV()\n",
    "lr.fit(_X, _v)\n",
    "A, b = lr.coef_, lr.intercept_\n",
    "mu = -torch.tensor(np.linalg.pinv(A.T @ A + 1e-3*np.eye(_X.shape[1])) @ A.T @ b, dtype = torch.float32)\n",
    "A = torch.tensor(A, dtype = torch.float32)\n",
    "\n",
    "_v_fit = (_X - mu.numpy()) @ A.T.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e08fe1c-70ae-40e7-85ce-cfe9cde7f17c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "t = rpe1_kinetics.obs.Cell_cycle_relativePos\n",
    "t_bin = np.digitize(t, np.histogram_bin_edges(t, 5)[:-1])-1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc369af4-1a6b-459f-95af-41795db3aa68",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# t_bin = np.array([{'M' : 0, 'M-G1' : 1, 'G1-S' : 2, 'S' : 3, 'G2-M' : 4}[x] for x in rpe1_kinetics.obs.cell_cycle_phase])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "adf81224-a365-47cf-abc8-457c4d87cff0",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.figure(figsize = (10, 5))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.scatter(_X[:, 0], _X[:, 1], alpha = 0.25, c = t_bin)\n",
    "plt.quiver(_X[:, 0], _X[:, 1], _v[:, 0], _v[:, 1],)\n",
    "plt.scatter(mu[0:1], mu[1:2], marker = 'x', color = 'red')\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.scatter(_X[:, 0], _X[:, 1], alpha = 0.25, c = t_bin)\n",
    "plt.quiver(_X[:, 0], _X[:, 1], _v_fit[:, 0], _v_fit[:, 1])\n",
    "plt.scatter(mu[0:1], mu[1:2], marker = 'x', color = 'red')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "953b1624-dd7c-44c9-9e96-70340673a828",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data['A'] = A\n",
    "data['mu'] = mu\n",
    "data['t_idx'] = t_bin\n",
    "torch.save(data, \"data_cellcycle_pca.pkl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0b5c7c4-1c57-4c2f-8893-c2e87b08f8c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1780f48b-4037-4b06-acf7-acce07d09462",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dynamo",
   "language": "python",
   "name": "dynamo"
  },
  "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.21"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "00ab0c42fb35450aacf06f8e44ad9823": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_1d58eea5fa1a4f72b14977f334041895",
       "style": "IPY_MODEL_0ce5eac76f2b4e83a29f3717c2477008",
       "value": "100%"
      }
     },
     "01d97f35b55b4523859e198cf7a6a0d9": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "03b8042f7b644570a1a540f015b8b8f7": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "0417a6a2c3fa42daade55ae95d180115": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_441b24e8604f422282d5b2ea02340619",
        "IPY_MODEL_5748a531aa2c41128022256d363a8cf0",
        "IPY_MODEL_7142a66962f34f72894cdfe824867d67"
       ],
       "layout": "IPY_MODEL_c823e9bf87044e669c838db998f9548f"
      }
     },
     "0436c98cbc0f47e29986887bd79b1a95": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "0496891da627416a8a4d9f15b819b542": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_8cd8a4824c764c7a8c07f730a8b66635",
       "style": "IPY_MODEL_230ba94625794fc484231c465bf8c180",
       "value": " 2793/2793 [00:22&lt;00:00, 131.83cell/s]"
      }
     },
     "0678acc959b1474dbae097303e7b9290": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "06b4adcc45394a3fa577ef044105c4fd": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "0a503339339b455aaba557dcd41a7f82": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "0b5ed637ce5a474dbf9b59f217e47cf9": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_7d680988978149398eb2c9461388ddb6",
       "style": "IPY_MODEL_0a503339339b455aaba557dcd41a7f82",
       "value": "100%"
      }
     },
     "0c60f363941f40a4814c9af0bc7630da": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_7410ce09ce9f46988d605541eb00b87c",
       "max": 2793,
       "style": "IPY_MODEL_7b94397f20ce4a44acc5781f810010f3",
       "value": 2793
      }
     },
     "0ce5eac76f2b4e83a29f3717c2477008": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "0f8ea59aa120404fa9df7904c48d97c0": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "0ff0b30d52f44050b283cb85f20d6633": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "1090ac4558ae46f88ab4fff53c2586f8": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "130eb018407b45eaa463e0c0af6e8cf4": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "13c2034538c14a20a42a55f09dc5dac8": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "18870d05148f4fc4b9c74a19903379fa": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_d3d0de357997441eb28f125ce4c55386",
       "style": "IPY_MODEL_8449f9861b46441a836b55819ce5cb8e",
       "value": " 2793/2793 [00:30&lt;00:00, 83.51cells/s]"
      }
     },
     "19b5003573394b4487acb0dc5d7f041f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_13c2034538c14a20a42a55f09dc5dac8",
       "max": 2793,
       "style": "IPY_MODEL_b58a36455ad243f0a07531aa8241ec1f",
       "value": 2793
      }
     },
     "1b5c371d7c44482c8a36cb24c896494e": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "1d03fffcfe4140a9840f70bcb59e0bf8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_f689231a1ecb4da8972fedc7d62a53fb",
       "style": "IPY_MODEL_235f30bd43074a288832dc86343dbe89",
       "value": "100%"
      }
     },
     "1d58eea5fa1a4f72b14977f334041895": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "1d90ed0ff5f14a50903fa3c05e95cb8c": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_403482bdd8b743c08d35e55a52549c0d",
       "style": "IPY_MODEL_130eb018407b45eaa463e0c0af6e8cf4",
       "value": "100%"
      }
     },
     "230ba94625794fc484231c465bf8c180": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "235f30bd43074a288832dc86343dbe89": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "27cae7a3fdbb4624a3cdc3f7c34694d3": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "2cae154a0e184709a91817c352904e8c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "2fc19fd886b14523ad1c13e685ff69ff": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_762436d5cb114720b9131692404ab7fb",
       "style": "IPY_MODEL_d012105d8461492a955cd95f77046914",
       "value": " 2793/2793 [00:31&lt;00:00, 70.09cell/s]"
      }
     },
     "33103b370e354b999ea9e654ff67945f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "353ac094c5a44714a88359a5df6cb328": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_2cae154a0e184709a91817c352904e8c",
       "max": 2793,
       "style": "IPY_MODEL_06b4adcc45394a3fa577ef044105c4fd",
       "value": 2793
      }
     },
     "3a91a15a35074ada919ce747e4a02a02": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_00ab0c42fb35450aacf06f8e44ad9823",
        "IPY_MODEL_dee9a4b57abd43029b7d739503d17733",
        "IPY_MODEL_18870d05148f4fc4b9c74a19903379fa"
       ],
       "layout": "IPY_MODEL_ba1055a6fff24e938595e9e4da0c52dc"
      }
     },
     "3ae5f157b54f407c91e12727bc8b5ff8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_8ea2e1d1627c43faa0916bffe4faba1f",
        "IPY_MODEL_7deca04b762246d6910d68403af9fe6b",
        "IPY_MODEL_61897b6e8b804fb0bb507d236dad6e6f"
       ],
       "layout": "IPY_MODEL_b000a6fa93c54a888eaf4089cdb31369"
      }
     },
     "3d7773d971784e51912f2d404badcf64": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "403482bdd8b743c08d35e55a52549c0d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "4337d17568b248e298410850ad7190e5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "43a76cdc39fd42fb9da851bcab17685d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_be10e97a14184d8e9029a041935f39ea",
       "style": "IPY_MODEL_85f34f713ec64bcaaf18e0329d6cc7ea",
       "value": " 2793/2793 [00:36&lt;00:00, 77.25cell/s]"
      }
     },
     "441b24e8604f422282d5b2ea02340619": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_9093f1e260274246801759a5e4576751",
       "style": "IPY_MODEL_70d2d4b8fbd04e5f9c2591b8c027828b",
       "value": "100%"
      }
     },
     "563203d5c7c54b4b9de5818b30aeb01c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "5748a531aa2c41128022256d363a8cf0": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_1090ac4558ae46f88ab4fff53c2586f8",
       "max": 2793,
       "style": "IPY_MODEL_de2cdc6dfc5a49479863d941334b19ee",
       "value": 2793
      }
     },
     "57d462af07e846389053adfda2854f15": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "5a90524b708e40a4ad082807cbdce847": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "5abbaf00bf2b4a01b9bc5af739e466f4": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "5c29a17b2da446ed974f4477062df7d5": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "61897b6e8b804fb0bb507d236dad6e6f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_c894b6f7d405405fb286746130b82afb",
       "style": "IPY_MODEL_d03915cbb99e451a8d6582337893a3b3",
       "value": " 2793/2793 [00:29&lt;00:00, 84.27cells/s]"
      }
     },
     "6a3afa07e6d84a679a417d52a4116198": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_a1d35387233945a99d609235ee47737b",
       "style": "IPY_MODEL_7c099a149ea64bc78c1a579d4cc160c1",
       "value": " 2793/2793 [00:30&lt;00:00, 81.79cells/s]"
      }
     },
     "6a613e5ff19c454d86437060eeea95f9": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "6cd78833003f43ae8f64f7599c4a7268": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_d4d72478dcf34dfd9d6fd6605a880ee1",
       "max": 2793,
       "style": "IPY_MODEL_f6066a2b4ebd48878b283dd61e995ccc",
       "value": 2793
      }
     },
     "70d2d4b8fbd04e5f9c2591b8c027828b": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "7142a66962f34f72894cdfe824867d67": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_98e7984a4bdc47ada5bf2ec504f5d54e",
       "style": "IPY_MODEL_89cf7acad9314c7b8240265702890698",
       "value": " 2793/2793 [00:30&lt;00:00, 84.07cells/s]"
      }
     },
     "7410ce09ce9f46988d605541eb00b87c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "741ad4464f9e4fe18fd691eb033407fb": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "762436d5cb114720b9131692404ab7fb": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "762516606aef4cda9d4997a904f1771e": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_0b5ed637ce5a474dbf9b59f217e47cf9",
        "IPY_MODEL_7e0c95432c574c62a2402bb11f601bf2",
        "IPY_MODEL_a9944f59caca4427b9d912b80b4eb337"
       ],
       "layout": "IPY_MODEL_57d462af07e846389053adfda2854f15"
      }
     },
     "78f227c6a5bb4b46a711f5a53cae1d6a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_563203d5c7c54b4b9de5818b30aeb01c",
       "max": 2793,
       "style": "IPY_MODEL_0436c98cbc0f47e29986887bd79b1a95",
       "value": 2793
      }
     },
     "7b243f8d01234880a6fbe570e9b0be07": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "7b94397f20ce4a44acc5781f810010f3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "7c099a149ea64bc78c1a579d4cc160c1": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "7d680988978149398eb2c9461388ddb6": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "7deca04b762246d6910d68403af9fe6b": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_7f1175d7a8764515873e1974e54f3c15",
       "max": 2793,
       "style": "IPY_MODEL_741ad4464f9e4fe18fd691eb033407fb",
       "value": 2793
      }
     },
     "7e0c95432c574c62a2402bb11f601bf2": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_9e1205bf09d345ae86de0df7801b9cf1",
       "max": 2793,
       "style": "IPY_MODEL_4337d17568b248e298410850ad7190e5",
       "value": 2793
      }
     },
     "7ee1435c223f49faafe4f1fd8227e21c": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "7f1175d7a8764515873e1974e54f3c15": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "817780b6aafc439a805481e0fe7ff677": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_af1b8e664dd1495894d9e37ac89eab6c",
       "style": "IPY_MODEL_6a613e5ff19c454d86437060eeea95f9",
       "value": "100%"
      }
     },
     "819a9b9bbf9c48e7875d014e39112108": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_d1dde26f59d349c49d0179db9bbb7f99",
       "style": "IPY_MODEL_0f8ea59aa120404fa9df7904c48d97c0",
       "value": "100%"
      }
     },
     "8449f9861b46441a836b55819ce5cb8e": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "85f34f713ec64bcaaf18e0329d6cc7ea": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "878a786bbe97467bacd9a75761c8a290": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_817780b6aafc439a805481e0fe7ff677",
        "IPY_MODEL_78f227c6a5bb4b46a711f5a53cae1d6a",
        "IPY_MODEL_e243de9be1cd41ec8ee43a59725a8b8d"
       ],
       "layout": "IPY_MODEL_aa5c843232b3441a922ab082855e17f3"
      }
     },
     "89cf7acad9314c7b8240265702890698": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "8cd8a4824c764c7a8c07f730a8b66635": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "8e091ad07ecd40d3a300bb141ac0cd7e": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "8ea2e1d1627c43faa0916bffe4faba1f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_8e091ad07ecd40d3a300bb141ac0cd7e",
       "style": "IPY_MODEL_5c29a17b2da446ed974f4477062df7d5",
       "value": "100%"
      }
     },
     "9093f1e260274246801759a5e4576751": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "9869908d38884e6db7499e7ad9c76219": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_0678acc959b1474dbae097303e7b9290",
       "style": "IPY_MODEL_9e94b69442364894b326a16cfd95328c",
       "value": "100%"
      }
     },
     "98e7984a4bdc47ada5bf2ec504f5d54e": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "9e1205bf09d345ae86de0df7801b9cf1": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "9e94b69442364894b326a16cfd95328c": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "9fa5b671bf8745d5b3653d2cdaa61100": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "a1d35387233945a99d609235ee47737b": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "a3150c7e90394cec81e96f5fd1e34db8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_1d03fffcfe4140a9840f70bcb59e0bf8",
        "IPY_MODEL_0c60f363941f40a4814c9af0bc7630da",
        "IPY_MODEL_f7a666757d8f4c1389308a8c4bb1a254"
       ],
       "layout": "IPY_MODEL_33103b370e354b999ea9e654ff67945f"
      }
     },
     "a9944f59caca4427b9d912b80b4eb337": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_5abbaf00bf2b4a01b9bc5af739e466f4",
       "style": "IPY_MODEL_5a90524b708e40a4ad082807cbdce847",
       "value": " 2793/2793 [00:33&lt;00:00, 91.79cell/s]"
      }
     },
     "aa5c843232b3441a922ab082855e17f3": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "ae99fcaa22f04021bc286b28aad73c79": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "af1b8e664dd1495894d9e37ac89eab6c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "b000a6fa93c54a888eaf4089cdb31369": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "b4ec337527ab4da987ced286abdc912d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "b58a36455ad243f0a07531aa8241ec1f": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "ba1055a6fff24e938595e9e4da0c52dc": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "bcd8845372cb47f2a9d094a57b5da88d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "be10e97a14184d8e9029a041935f39ea": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "bf3b97f96d784cc9aa4f2f78d46317db": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_ae99fcaa22f04021bc286b28aad73c79",
       "max": 2793,
       "style": "IPY_MODEL_b4ec337527ab4da987ced286abdc912d",
       "value": 2793
      }
     },
     "bf9b9cd482be4a76a3b4556fd48e29e7": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_e34eb50d11c54b73bdf726eb9d8f1030",
       "style": "IPY_MODEL_7ee1435c223f49faafe4f1fd8227e21c",
       "value": "100%"
      }
     },
     "c823e9bf87044e669c838db998f9548f": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "c894b6f7d405405fb286746130b82afb": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "d012105d8461492a955cd95f77046914": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "d03915cbb99e451a8d6582337893a3b3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "d1dde26f59d349c49d0179db9bbb7f99": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "d36bd7797ff0439cb94d0e977243dacc": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_9869908d38884e6db7499e7ad9c76219",
        "IPY_MODEL_19b5003573394b4487acb0dc5d7f041f",
        "IPY_MODEL_6a3afa07e6d84a679a417d52a4116198"
       ],
       "layout": "IPY_MODEL_27cae7a3fdbb4624a3cdc3f7c34694d3"
      }
     },
     "d3d0de357997441eb28f125ce4c55386": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "d4d72478dcf34dfd9d6fd6605a880ee1": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "de01432c99d74204a98386c8f91096b4": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_bf9b9cd482be4a76a3b4556fd48e29e7",
        "IPY_MODEL_6cd78833003f43ae8f64f7599c4a7268",
        "IPY_MODEL_2fc19fd886b14523ad1c13e685ff69ff"
       ],
       "layout": "IPY_MODEL_f489652c7210493e8964a6751b7efc91"
      }
     },
     "de2cdc6dfc5a49479863d941334b19ee": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "dee9a4b57abd43029b7d739503d17733": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_3d7773d971784e51912f2d404badcf64",
       "max": 2793,
       "style": "IPY_MODEL_0ff0b30d52f44050b283cb85f20d6633",
       "value": 2793
      }
     },
     "df9835b2953845c780c2adbe819946f7": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_1d90ed0ff5f14a50903fa3c05e95cb8c",
        "IPY_MODEL_353ac094c5a44714a88359a5df6cb328",
        "IPY_MODEL_43a76cdc39fd42fb9da851bcab17685d"
       ],
       "layout": "IPY_MODEL_9fa5b671bf8745d5b3653d2cdaa61100"
      }
     },
     "e243de9be1cd41ec8ee43a59725a8b8d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_7b243f8d01234880a6fbe570e9b0be07",
       "style": "IPY_MODEL_01d97f35b55b4523859e198cf7a6a0d9",
       "value": " 2793/2793 [00:35&lt;00:00, 76.31cell/s]"
      }
     },
     "e34eb50d11c54b73bdf726eb9d8f1030": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "e761caec156d4d7eba3fb596be9280e9": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_819a9b9bbf9c48e7875d014e39112108",
        "IPY_MODEL_bf3b97f96d784cc9aa4f2f78d46317db",
        "IPY_MODEL_0496891da627416a8a4d9f15b819b542"
       ],
       "layout": "IPY_MODEL_bcd8845372cb47f2a9d094a57b5da88d"
      }
     },
     "f489652c7210493e8964a6751b7efc91": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "f6066a2b4ebd48878b283dd61e995ccc": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "f689231a1ecb4da8972fedc7d62a53fb": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "f7a666757d8f4c1389308a8c4bb1a254": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_1b5c371d7c44482c8a36cb24c896494e",
       "style": "IPY_MODEL_03b8042f7b644570a1a540f015b8b8f7",
       "value": " 2793/2793 [00:23&lt;00:00, 120.38cell/s]"
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
