{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO on LQR\n",
    "\n",
    "## Define paramters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:08.382424Z",
     "iopub.status.busy": "2022-09-19T14:59:08.381354Z",
     "iopub.status.idle": "2022-09-19T14:59:09.060010Z",
     "shell.execute_reply": "2022-09-19T14:59:09.059504Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import jax\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "\n",
    "# Sample collection\n",
    "max_discrete_state = parameters[\"max_discrete_state\"]\n",
    "n_discrete_states = parameters[\"n_discrete_states\"]\n",
    "max_discrete_action = parameters[\"max_discrete_action\"]\n",
    "n_discrete_actions = parameters[\"n_discrete_actions\"]\n",
    "n_samples = n_discrete_states * n_discrete_actions\n",
    "\n",
    "# Weights collection\n",
    "n_weights = parameters[\"n_weights\"]\n",
    "weights_filtering = True\n",
    "\n",
    "# Q function\n",
    "max_action_on_max = parameters[\"max_action_on_max\"]\n",
    "n_actions_on_max = parameters[\"n_actions_on_max\"]\n",
    "\n",
    "# Trainings\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "training_steps = parameters[\"training_steps\"]\n",
    "fitting_steps = parameters[\"fitting_steps_pbo\"]\n",
    "batch_size_samples = parameters[\"batch_size_samples\"]\n",
    "batch_size_weights = parameters[\"batch_size_weights\"]\n",
    "initial_weight_std = parameters[\"initial_weight_std\"]\n",
    "learning_rate = {\"first\": parameters[\"starting_lr_pbo\"], \"last\": parameters[\"ending_lr_pbo\"], \"duration\": training_steps * fitting_steps * n_samples // batch_size_samples}\n",
    "add_infinity = True\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 5\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/PBO_linear/\"):\n",
    "    os.makedirs(\"figures/data/PBO_linear/\")\n",
    "for file in os.listdir(\"figures/data/PBO_linear/\"):\n",
    "    if int(file.split(\"_\")[0]) == max_bellman_iterations and float(file.split(\"_\")[2]) == initial_weight_std and int(file.split(\"_\")[3][:-4]) > max_used_seed:\n",
    "        max_used_seed = int(file.split(\"_\")[3][:-4])\n",
    "max_used_seed\n",
    "\n",
    "# keys\n",
    "env_key = jax.random.PRNGKey(env_seed)\n",
    "seed = max_used_seed + 1\n",
    "key = jax.random.PRNGKey(seed)\n",
    "shuffle_key, q_network_key, pbo_network_key = jax.random.split(key, 3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:09.062150Z",
     "iopub.status.busy": "2022-09-19T14:59:09.061974Z",
     "iopub.status.idle": "2022-09-19T14:59:09.292836Z",
     "shell.execute_reply": "2022-09-19T14:59:09.292390Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Transition: s' = As + Ba\n",
      "Transition: s' = 0.7204725742340088s + -0.5264108180999756a\n",
      "Reward: Qs² + Ra² + 2 Ssa\n",
      "Reward: -0.13297832012176514s² + -0.8039400577545166a² + 0.2581009864807129sa\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.linear_quadratic import LinearQuadraticEnv\n",
    "\n",
    "\n",
    "discrete_states = np.linspace(-max_discrete_state, max_discrete_state, n_discrete_states)\n",
    "state_box_half_size = max_discrete_state / n_discrete_states\n",
    "discrete_states_boxes = np.linspace(\n",
    "    -max_discrete_state - state_box_half_size, max_discrete_state + state_box_half_size, n_discrete_states + 1\n",
    ")\n",
    "\n",
    "discrete_actions = np.linspace(-max_discrete_action, max_discrete_action, n_discrete_actions)\n",
    "action_box_half_size = max_discrete_action / n_discrete_actions\n",
    "discrete_actions_boxes = np.linspace(\n",
    "    -max_discrete_action - action_box_half_size, max_discrete_action + action_box_half_size, n_discrete_actions + 1\n",
    ")\n",
    "\n",
    "env = LinearQuadraticEnv(env_key, max_init_state=max_discrete_state)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Samples on the mesh"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:09.296477Z",
     "iopub.status.busy": "2022-09-19T14:59:09.296333Z",
     "iopub.status.idle": "2022-09-19T14:59:09.540020Z",
     "shell.execute_reply": "2022-09-19T14:59:09.539533Z"
    }
   },
   "outputs": [],
   "source": [
    "import jax.numpy as jnp\n",
    "\n",
    "from pbo.sample_collection.replay_buffer import ReplayBuffer\n",
    "\n",
    "\n",
    "n_samples = n_discrete_states * n_discrete_actions\n",
    "replay_buffer = ReplayBuffer()\n",
    "\n",
    "for state in discrete_states:\n",
    "    for action in discrete_actions:\n",
    "        env.reset(jnp.array([state]))\n",
    "        next_state, reward, absorbing, _ = env.step(jnp.array([action]))\n",
    "\n",
    "        replay_buffer.add(jnp.array([state]), jnp.array([action]), reward, next_state, absorbing)\n",
    "\n",
    "replay_buffer.cast_to_jax_array()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:09.542256Z",
     "iopub.status.busy": "2022-09-19T14:59:09.542117Z",
     "iopub.status.idle": "2022-09-19T14:59:10.264226Z",
     "shell.execute_reply": "2022-09-19T14:59:10.263867Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.sample_collection.count_samples import count_samples\n",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "\n",
    "samples_count, n_outside_boxes, _ = count_samples(replay_buffer.states, replay_buffer.actions, discrete_states_boxes, discrete_actions_boxes, replay_buffer.rewards)\n",
    "samples_visu_mesh = TwoDimesionsMesh(discrete_states, discrete_actions, sleeping_time=0)\n",
    "\n",
    "samples_visu_mesh.set_values(samples_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Samples repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:10.266156Z",
     "iopub.status.busy": "2022-09-19T14:59:10.265974Z",
     "iopub.status.idle": "2022-09-19T14:59:10.514040Z",
     "shell.execute_reply": "2022-09-19T14:59:10.513543Z"
    }
   },
   "outputs": [],
   "source": [
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.networks.learnable_q import LQRQ\n",
    "from pbo.weights_collection.weights_buffer import WeightsBuffer\n",
    "\n",
    "\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "q = LQRQ(\n",
    "    n_actions_on_max=n_actions_on_max,\n",
    "    max_action_on_max=max_action_on_max,\n",
    "    network_key=q_network_key,\n",
    "    zero_initializer=True\n",
    ")\n",
    "validation_initial_weight = q.to_weights(q.params)\n",
    "\n",
    "weights_buffer = WeightsBuffer()\n",
    "weights_buffer.add(validation_initial_weight)\n",
    "\n",
    "q_random = LQRQ(\n",
    "    n_actions_on_max=n_actions_on_max,\n",
    "    max_action_on_max=max_action_on_max,\n",
    "    network_key=q_network_key,\n",
    "    zero_initializer=False\n",
    ")\n",
    "\n",
    "while len(weights_buffer) < n_weights:\n",
    "    weights = q_random.random_init_weights()\n",
    "    if not weights_filtering or q_random.to_params(weights)[\"LQRQNet\"][\"m\"] < 0:\n",
    "        weights_buffer.add(weights)\n",
    "\n",
    "weights_buffer.cast_to_jax_array()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train linear PBO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:10.516527Z",
     "iopub.status.busy": "2022-09-19T14:59:10.516390Z",
     "iopub.status.idle": "2022-09-19T14:59:16.295390Z",
     "shell.execute_reply": "2022-09-19T14:59:16.294889Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5bf2502ce50745c0a29611d2695b7960",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/3200 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0.]\n",
      "[-0.27813852  0.17268957 -0.51349515]\n",
      "[-0.31478599  0.20363899 -0.76968825]\n",
      "[-0.26662365  0.21447058 -0.84405881]\n",
      "[-0.26358745  0.17540592 -0.91164774]\n",
      "[-0.18357265  0.22515345 -0.83249247]\n",
      "[-0.2948432   0.10528936 -0.99370319]\n",
      "[-0.04834087  0.33602345 -0.65977353]\n",
      "Optimal weights\n",
      "[-0.22707027  0.19779846 -0.8541705 ]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.weights_collection.dataloader import WeightsDataLoader\n",
    "from pbo.networks.learnable_pbo import LinearPBO\n",
    "\n",
    "\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "data_loader_weights = WeightsDataLoader(weights_buffer, batch_size_weights, shuffle_key)\n",
    "pbo_linear = LinearPBO(\n",
    "    q=q,\n",
    "    max_bellman_iterations=max_bellman_iterations,\n",
    "    add_infinity=add_infinity,\n",
    "    network_key=pbo_network_key,\n",
    "    learning_rate=learning_rate,\n",
    "    initial_weight_std=initial_weight_std,\n",
    ")\n",
    "importance_iteration = jnp.ones(max_bellman_iterations + 1)\n",
    "\n",
    "cumulative_l2_loss = np.zeros((training_steps, fitting_steps)) * np.nan\n",
    "\n",
    "for training_step in tqdm(range(training_steps)):\n",
    "    params_target = pbo_linear.params\n",
    "    for fitting_step in range(fitting_steps):\n",
    "        data_loader_weights.shuffle()\n",
    "        for batch_weights in data_loader_weights:\n",
    "            data_loader_samples.shuffle()\n",
    "            for batch_samples in data_loader_samples:\n",
    "                pbo_linear.params, pbo_linear.optimizer_state, l2_loss = pbo_linear.learn_on_batch(\n",
    "                    pbo_linear.params, params_target, pbo_linear.optimizer_state, batch_weights, batch_samples, importance_iteration\n",
    "                )\n",
    "        cumulative_l2_loss[training_step, fitting_step] = l2_loss\n",
    "\n",
    "weights = np.zeros((max_bellman_iterations_validation + 2, q.weights_dimension))\n",
    "\n",
    "\n",
    "batch_iterated_weights = validation_initial_weight.reshape((1, -1))\n",
    "for bellman_iteration in range(max_bellman_iterations_validation + 1):\n",
    "    weights[bellman_iteration] = batch_iterated_weights[0]\n",
    "    print(weights[bellman_iteration])\n",
    "\n",
    "    batch_iterated_weights = pbo_linear(pbo_linear.params, batch_iterated_weights)\n",
    "\n",
    "weights[max_bellman_iterations_validation + 1] = pbo_linear.fixed_point(pbo_linear.params)\n",
    "\n",
    "print(\"Optimal weights\")\n",
    "print(env.optimal_weights)\n",
    "\n",
    "for training_step in range(0, training_steps, max(training_steps // 10, 1)):\n",
    "    plt.plot(cumulative_l2_loss[training_step], label=f\"Training step {training_step}\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:16.297448Z",
     "iopub.status.busy": "2022-09-19T14:59:16.297273Z",
     "iopub.status.idle": "2022-09-19T14:59:16.309754Z",
     "shell.execute_reply": "2022-09-19T14:59:16.309216Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray([-0.20972061,  0.18004306, -0.87737143], dtype=float32)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pbo_linear.fixed_point(pbo_linear.params)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:16.312106Z",
     "iopub.status.busy": "2022-09-19T14:59:16.311960Z",
     "iopub.status.idle": "2022-09-19T14:59:16.390961Z",
     "shell.execute_reply": "2022-09-19T14:59:16.390438Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/PBO_linear/{max_bellman_iterations}_W_{initial_weight_std}_{seed}.npy\", weights)\n",
    "np.save(f\"figures/data/PBO_linear/{max_bellman_iterations}_Pi_{initial_weight_std}_{seed}.npy\", env.greedy_V(weights))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:16.393687Z",
     "iopub.status.busy": "2022-09-19T14:59:16.393512Z",
     "iopub.status.idle": "2022-09-19T14:59:16.789818Z",
     "shell.execute_reply": "2022-09-19T14:59:16.789344Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.utils.lqr_weights_viewer import visualize\n",
    "\n",
    "weights[np.abs(weights) > 20] = np.nan\n",
    "\n",
    "visualize(weights, env.optimal_weights, pbo_linear.fixed_point(pbo_linear.params))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:59:16.791549Z",
     "iopub.status.busy": "2022-09-19T14:59:16.791404Z",
     "iopub.status.idle": "2022-09-19T14:59:16.802683Z",
     "shell.execute_reply": "2022-09-19T14:59:16.802238Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'LinearPBONet/linear': {'b': DeviceArray([-0.27813852,  0.17268957, -0.51349515], dtype=float32),\n",
       "  'w': DeviceArray([[-0.14017892, -0.68088675, -0.7105927 ],\n",
       "               [-1.4628394 , -1.17596   , -2.2825334 ],\n",
       "               [-0.34465852, -0.08694258,  0.116197  ]], dtype=float32)}}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pbo_linear.params"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.10 ('env_cpu': venv)",
   "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.8.10"
  },
  "vscode": {
   "interpreter": {
    "hash": "af5525a3273d35d601ae265c5d3634806dd61a1c4d085ae098611a6832982bdb"
   }
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "0b58a450b47f495a9e63c97b23294d6d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_0bf85838b82843cfbd8e1dc7ca58c513",
       "placeholder": "​",
       "style": "IPY_MODEL_c0be6b87ac1c4e78b02d856758a7e565",
       "value": "100%"
      }
     },
     "0bf85838b82843cfbd8e1dc7ca58c513": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "171fe9160a7e40468790aafb6a3f6813": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "3b87d652f8564d16b9976351fd63b8a8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "DescriptionStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "DescriptionStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "description_width": ""
      }
     },
     "5bf2502ce50745c0a29611d2695b7960": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_0b58a450b47f495a9e63c97b23294d6d",
        "IPY_MODEL_9f68a943306d4d72a466c4d2f1f38348",
        "IPY_MODEL_e40544714f484f4690bf389fb898b25d"
       ],
       "layout": "IPY_MODEL_88f27fb69e6643f98e715368759d66bc"
      }
     },
     "88f27fb69e6643f98e715368759d66bc": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "9f68a943306d4d72a466c4d2f1f38348": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_171fe9160a7e40468790aafb6a3f6813",
       "max": 3200.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_ed81d529bcd54e9db2afb26de21445c2",
       "value": 3200.0
      }
     },
     "c0be6b87ac1c4e78b02d856758a7e565": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "DescriptionStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "DescriptionStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "description_width": ""
      }
     },
     "e40544714f484f4690bf389fb898b25d": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_f9e4168d3a0e4190a90be9a44d5c2e6a",
       "placeholder": "​",
       "style": "IPY_MODEL_3b87d652f8564d16b9976351fd63b8a8",
       "value": " 3200/3200 [00:05&lt;00:00, 698.05it/s]"
      }
     },
     "ed81d529bcd54e9db2afb26de21445c2": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "f9e4168d3a0e4190a90be9a44d5c2e6a": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
