{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO on Car On Hill\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:27.787574Z",
     "iopub.status.busy": "2022-09-20T19:07:27.786783Z",
     "iopub.status.idle": "2022-09-20T19:07:28.428931Z",
     "shell.execute_reply": "2022-09-20T19:07:28.428434Z"
    }
   },
   "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 jax.numpy as jnp\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "gamma = parameters[\"gamma\"]\n",
    "\n",
    "# Sample collection\n",
    "oriented_states = jnp.array(parameters[\"oriented_state\"])\n",
    "n_random_samples = parameters[\"n_random_samples\"]\n",
    "n_oriented_samples = parameters[\"n_oriented_samples\"]\n",
    "n_samples = n_random_samples + n_oriented_samples\n",
    "n_weights = parameters[\"n_weights\"]\n",
    "\n",
    "# Trainings\n",
    "layers_dimension = parameters[\"layers_dimension\"]\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_fqi\"], \"last\": parameters[\"ending_lr_fqi\"], \"duration\": training_steps * fitting_steps * n_samples // batch_size_samples}\n",
    "add_infinity = False\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "n_states_x = parameters[\"n_states_x\"]\n",
    "n_states_v = parameters[\"n_states_v\"]\n",
    "horizon = parameters[\"horizon\"]\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 10\n",
    "plot_freq = 100\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 int(file.split(\"_\")[2][:-4]) > max_used_seed:\n",
    "        max_used_seed = int(file.split(\"_\")[2][:-4])\n",
    "max_used_seed\n",
    "\n",
    "# keys\n",
    "seed = max_used_seed + 1\n",
    "sample_key = jax.random.PRNGKey(env_seed)\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-20T19:07:28.431163Z",
     "iopub.status.busy": "2022-09-20T19:07:28.430989Z",
     "iopub.status.idle": "2022-09-20T19:07:28.506321Z",
     "shell.execute_reply": "2022-09-20T19:07:28.505827Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.car_on_hill import CarOnHillEnv\n",
    "\n",
    "\n",
    "env = CarOnHillEnv(gamma)\n",
    "\n",
    "states_x = jnp.linspace(-env.max_position, env.max_position, n_states_x)\n",
    "boxes_x_size = (2 * env.max_position) / (n_states_x - 1)\n",
    "states_x_boxes = (np.linspace(-env.max_position, env.max_position + boxes_x_size, n_states_x + 1) - boxes_x_size / 2)\n",
    "states_v = jnp.linspace(-env.max_velocity, env.max_velocity, n_states_v)\n",
    "boxes_v_size = (2 * env.max_velocity) / (n_states_v - 1)\n",
    "states_v_boxes = (np.linspace(-env.max_velocity, env.max_velocity + boxes_v_size, n_states_v + 1) - boxes_v_size / 2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Samples on the mesh and with a uniform policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:28.509727Z",
     "iopub.status.busy": "2022-09-20T19:07:28.509585Z",
     "iopub.status.idle": "2022-09-20T19:07:33.711166Z",
     "shell.execute_reply": "2022-09-20T19:07:33.710656Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of episodes: 173\n"
     ]
    }
   ],
   "source": [
    "from pbo.sample_collection.replay_buffer import ReplayBuffer\n",
    "\n",
    "\n",
    "replay_buffer = ReplayBuffer()\n",
    "\n",
    "env.reset()\n",
    "n_episodes = 0\n",
    "n_steps = 0\n",
    "for idx_sample in range(n_random_samples):\n",
    "    state = env.state\n",
    "    \n",
    "    sample_key, key = jax.random.split(sample_key)\n",
    "    action = jax.random.choice(key, env.actions_on_max)\n",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing or n_steps > horizon:\n",
    "        env.reset()\n",
    "        n_episodes += 1\n",
    "        n_steps = 0\n",
    "\n",
    "\n",
    "env.reset(oriented_states[1])\n",
    "n_episodes += 1\n",
    "n_steps = 0\n",
    "for idx_sample in range(n_oriented_samples):\n",
    "    state = env.state\n",
    "    \n",
    "    sample_key, key = jax.random.split(sample_key)\n",
    "    action = jax.random.choice(key, env.actions_on_max)\n",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing or n_steps > horizon:\n",
    "        sample_key, key = jax.random.split(sample_key)\n",
    "        alpha = jax.random.uniform(key)\n",
    "        env.reset(alpha * oriented_states[0] + (1 - alpha) * oriented_states[1])\n",
    "\n",
    "        n_episodes += 1\n",
    "        n_steps = 0\n",
    "\n",
    "replay_buffer.cast_to_jax_array()\n",
    "assert sum(replay_buffer.rewards == 1) > 0, \"No positive reward has been sampled, please do something!\"\n",
    "print(f\"Number of episodes: {n_episodes}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:33.713029Z",
     "iopub.status.busy": "2022-09-20T19:07:33.712893Z",
     "iopub.status.idle": "2022-09-20T19:07:33.786925Z",
     "shell.execute_reply": "2022-09-20T19:07:33.786460Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray([[-1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [-1]], dtype=int32)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "replay_buffer.actions[(replay_buffer.rewards == 1).flatten()]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:33.788832Z",
     "iopub.status.busy": "2022-09-20T19:07:33.788700Z",
     "iopub.status.idle": "2022-09-20T19:07:37.322747Z",
     "shell.execute_reply": "2022-09-20T19:07:37.322287Z"
    }
   },
   "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, rewards_count = count_samples(replay_buffer.states[:, 0], replay_buffer.states[:, 1], states_x_boxes, states_v_boxes, replay_buffer.rewards)\n",
    "samples_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False)\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.\", xlabel=\"x\", ylabel=\"v\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:37.324573Z",
     "iopub.status.busy": "2022-09-20T19:07:37.324388Z",
     "iopub.status.idle": "2022-09-20T19:07:37.501764Z",
     "shell.execute_reply": "2022-09-20T19:07:37.501314Z"
    }
   },
   "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": [
    "samples_visu_mesh.set_values(rewards_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Rewards repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=\"x\", ylabel=\"v\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:37.503658Z",
     "iopub.status.busy": "2022-09-20T19:07:37.503525Z",
     "iopub.status.idle": "2022-09-20T19:07:37.828692Z",
     "shell.execute_reply": "2022-09-20T19:07:37.828179Z"
    }
   },
   "outputs": [],
   "source": [
    "from pbo.weights_collection.weights_buffer import WeightsBuffer\n",
    "from pbo.networks.learnable_q import FullyConnectedQ\n",
    "\n",
    "\n",
    "weights_buffer = WeightsBuffer()\n",
    "\n",
    "# Add the validation weights\n",
    "q = FullyConnectedQ(\n",
    "    state_dim=2,\n",
    "    action_dim=1,\n",
    "    actions_on_max=env.actions_on_max,\n",
    "    gamma=gamma,\n",
    "    network_key=q_network_key,\n",
    "    layers_dimension=layers_dimension,\n",
    "    zero_initializer=True,\n",
    ")\n",
    "validation_weights = q.to_weights(q.params)\n",
    "weights_buffer.add(validation_weights)\n",
    "\n",
    "# Add random weights\n",
    "while len(weights_buffer) < n_weights:\n",
    "    weights = q.random_init_weights()\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": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:07:37.830743Z",
     "iopub.status.busy": "2022-09-20T19:07:37.830609Z",
     "iopub.status.idle": "2022-09-20T19:09:34.814785Z",
     "shell.execute_reply": "2022-09-20T19:09:34.814313Z"
    }
   },
   "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"
    },
    {
     "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": [
    "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",
    "q_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False, zero_centered=True)\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 = 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",
    "l2_losses = np.ones((training_steps, fitting_steps)) * np.nan\n",
    "\n",
    "for training_step in range(training_steps):\n",
    "    params_target = pbo.params\n",
    "\n",
    "    for fitting_step in range(fitting_steps):\n",
    "        cumulative_l2_loss = 0\n",
    "\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.params, pbo.optimizer_state, l2_loss = pbo.learn_on_batch(\n",
    "                    pbo.params, params_target, pbo.optimizer_state, batch_weights, batch_samples, importance_iteration\n",
    "                )\n",
    "                cumulative_l2_loss += l2_loss\n",
    "        \n",
    "        l2_losses[training_step, fitting_step] = cumulative_l2_loss\n",
    "\n",
    "    if (training_step + 1) % plot_freq == 0 or training_step + 1 == training_steps:\n",
    "        if not pbo.add_infinity:\n",
    "            q_weight = validation_weights                \n",
    "            for _ in range(max_bellman_iterations + 3):\n",
    "                q_weight = pbo(pbo.params, q_weight)\n",
    "        else:\n",
    "            q_weight = pbo.fixed_point(pbo.params)\n",
    "        q.params = q.to_params(q_weight)\n",
    "        diff_q = env.diff_q_mesh(q, q.params, states_x, states_v)\n",
    "\n",
    "        q_visu_mesh.set_values(diff_q)\n",
    "        q_visu_mesh.show(f\"Q differences, \\nl2 loss: {str(jnp.round(cumulative_l2_loss, 3))}, training step {training_step + 1}, fitting step: {fitting_step + 1}\", xlabel=\"x\", ylabel=\"v\")\n",
    "\n",
    "\n",
    "for training_step in range(0, training_steps, max(training_steps // 10, 1)):\n",
    "    plt.plot(l2_losses[training_step], label=f\"Training step {training_step + 1}\")\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel(\"fitting step\")\n",
    "plt.ylabel(r\"$\\sum_{k} \\left(\\Gamma^*Q_{\\Gamma_{\\phi_i}^k(w)} - Q_{\\Gamma_{\\phi_{i + 1}}^{k + 1}(w)} \\right)^2$\")\n",
    "plt.title(\"Training losses\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:09:34.816698Z",
     "iopub.status.busy": "2022-09-20T19:09:34.816482Z",
     "iopub.status.idle": "2022-09-20T19:09:34.994777Z",
     "shell.execute_reply": "2022-09-20T19:09:34.994312Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZ4AAAEYCAYAAABslZDKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA2TUlEQVR4nO3deZxcVZn/8c+3OwlbEkIIECBhUUD2XQE3REFAHXDcAB0BByYuoOL2U9QX7oozOiojiKgIKAqMGxkImyAgsgYIu0BkkQRihBAgQCDd/f39cU+TSqeWW31rTT3vvO4r1ffec+rp6u46de495zmyTQghhNAqfe0OIIQQQm+JhieEEEJLRcMTQgihpaLhCSGE0FLR8IQQQmipaHhCCCG0VDQ8YZUj6UpJR6fH75N0abtjykvSRZKOaHMMSyS9rJ0xhFVbNDyhJSQdKekOSc9JWiDpFElrN/t5bZ9t+83NfA5J75F0bfrerixz3JKeTW/oSyT9tEq8B9o+M5U7UtI1TQx9hUa6JIbxth9o5vOG3hYNT2g6SZ8Cvg18Blgb2BPYDLhU0tg2htYoi4DvAydWOWen9IY+3vbRVc5rGEljWvE8IdQrGp7QVJImAl8BPmr7YtvLbD8EvAd4GfDeCuXOkHSqpMskPSPpKkmblhx/taSbJD2V/n91hXpW6DVI2i7VuUjSPyR9XtLU1FtZt+S8XSX9M0/DaPuPts8DHs35slQ03AORtA1wKrBX6iUtTsdXk/QdSX9P8Z8qaY107A2S5kn6rKQFwM8lrSPpgvS9PJkeT0vnfwN4HfDD9Bw/TPstaYv0eG1JZ6XyD0v6oqS+0tc2xfOkpAclHVjyvRwp6YH083tQ0vuKvj5h1RANT2i2VwOrA78r3Wl7CTALqHYZ7H3A14ApwBzgbABJk4ELgZOAdYH/Bi4sbTjKkTQB+CNwMbARsAVwue0FwJVkjeGw9wPn2F6W43vM4+p0ifF3kjardbLte4APAdelXtKkdOhEYCtg5xT/xsAJJUWnApOBTYEZZH/jP09fbwI8D/wwPccXgD8Dx6bnOLZMKP9D1kt9GbA3cDjwgZLjewD3kv2M/hP4mTJrkf18DrQ9gez3YE6t7zv0hmh4QrNNAR63PVDm2GPAelXKXmj7atsvAF8g+/Q/HXgrcL/tX9gesP1r4K/Av9SI5W3AAtvftb3U9jO2b0jHzgT+DUBSP3AY8Iu832QNe5NdWtyarFd0wWgug0kSWWPyCduLbD8DfBM4tOS0IeBLtl+w/bztJ2z/1vZz6fxvpHjyPF9/qvv49Fo9BHyXrFEe9rDtn9geJHsNNwQ2KIlle0lr2H7M9l31fs9h1RQNT2i2x4EpFd5oN0zHK3lk+EHqIS0i66lsBDw84tyHyT79VzMd+FuFY+cD20raHNgPeMr2jTXqyyU1ni/aXgx8HNgc2GYUVa0HrAncLGlxuvx2MSs23v+0vXT4C0lrSvpxukz2NHA1MCk1KrVMAcay4ms98nVeMPzA9nPp4XjbzwKHkPXaHpN0oaSt836jYdUWDU9otuuAF4B3lO6UNB44kOwSVyXTR5w/mazH8CjZpaNSmwDza8TyCNklo5WkN+vzyHo976dxvZ2yTwco53mlHie7VLad7UlpW9v2+CplPgW8AtjD9kTg9Wm/Kpw/8vmWseJrned1ziq2L7G9H9kHjL8CP8lTLqz6ouEJTWX7KbLBBf8j6QBJY9M9jvPI3tjOrlL8LZJeK2kc2b2e620/QnZvaCtJ75U0RtIhwLbABTXCuQDYUNJx6Sb9BEl7lBw/CzgSOIiShkfSZumG+2blKpXUL2l1YAzQJ2n14UEJaTDDzumc8WSXquYD99SIFeAfwLT0/WN7iOzN+3uS1k/1byxp/yp1TCBrrBane2NfKvMclRrjQbKf0zfSa7Up8Engl7UCl7SBpIPTvZ4XgCVkl95CiIYnNJ/t/wQ+D3wHeAZ4kOyS0b7pkkwlvyJ7o1wE7Ea6B2P7CbL7NZ8CngD+H/A229Uu25HucexHdi9oAXA/sE/J8b+QvTneYrv08tJ0sktMlT7pv5/szf1HZKPEnmf5p/sNgHOBp4EHyO71vC3noIUrgLuABZKGv7fPAnOB69Olsz+S9Wgq+T6wBlkjfz3ZpblSPwDelUalnVSm/EeBZ1Ps15D9TE7PEXsfWSP1KNnPb2/gwznKhR6gWAgutJqkDwBfBV5j++8VzjkDmGf7iy2O7QrgV7Z/WrLvi2T3Tn7cylhCWFXFBLPQcrZ/LmmAbIht2YanHSS9EtgVOLh0v+2vtyeiEFZNPd3wpOvyVwOrkb0Wv7H9pRHnrEZ27X83sss6h6RhpaEA2828eV83SWcCbwc+ni7JhRCapKcvtaV5EWvZXpJuBl9D9sZzfck5HwF2tP0hSYcC/2r7kDaFHEIIXa+nBxc4syR9OTZtI1vig8kmxgH8BnhTarBCCCGMQk9faoOXZmffTJZ+5OSSmezDNiZNZLQ9IOkpsjQtj4+oZwbZrHJWX3P13TbdYjrV9Klom9+Itq94b3fZULmEBPmN6x9XOIai+hryWhangp8DG/N5qFgd/bnmpVY36MHCdXSG6n9ft996x+O2q2XuqElTVjcvVhml/syyS2wfUOQ5mqHnG540V2FnSZOA30va3vado6jnNOA0gK132sqnXXxK1fPXHLPmKKJdbkxf8R/dQMFGA2DBcwtqn1TFZhM3KxxDUav1rdbuEAAYq2KNcNHyAP0FE1pPHLNO4RieGVxcuI5OMOTq05Y2mjB9ZPaN+i0bQnttUPGwL503pfBzNEFPX2orldKZ/AkY+elgPmkGfUr7sjbZIIMQQmgz0Temr+JWs7R0uqSFksp+2FaW8fwpSXPSdkK58+rV0w2PpPVSTwdlqeX3I0vtUWomMLwi5LuAK9zLIzJCCJ1DoD5V3HI4g5U/bI/0Z9s7p+2rhWMmLrVtCJyZ7vP0AefZvkDSV4HZtmcCPwN+IWku2QzsQytXF0IIrSNB35jR31ezfXWeZToaracbHtu3A7uU2X9CyeOlwLtbGVcIIeSTu2dTxF6SbiNLf/TpRixv0dMNT7MMeJBFLyyqek6t47WM6yt+I3niuImF6yg6SOK+xfcVjmGHyTsUKt+Im/INqaPgIIexDVhF3AVHOj43uGrMvW3E1XS3ICeqBP3V7+VMkTS75OvT0kCovG4BNk1zHd8C/AHYsv5IVxQNTwghdLEaPZ7Hbe8+2rptP13yeJakUyRNqZWQt5aWDS6QNF3SnyTdLekuSR+vcN4b0uiJuyRdVbL/AEn3Spor6XMl+zeXdEPaf+5wCvmU9v7ctP+G0uuYko5P++8tTSlf5TmOTfssqSOHJ4YQepCKjWqrXb2mDk+Yl/Qqsjaj8KjeVo5qGwA+ZXtbYE/gGEnblp6QRpidAhxkezvSvZV08/9ksoXDtgUOKyn7beB7trcAngSOSvuPAp5M+7+XziOVOxTYjmw0xylprZRqz/EXYF9WXvUyhBDaRoK+sX0Vt9rl9WuyxRpfIWmepKMkfUjSh9Ip7wLuTPd4TgIObcSo3pZdarP9GPBYevyMpHvIsgLcXXLae4HfDafKt70w7X8VMNf2AwCSzgEOTnW8MZWDLLXNl8nWRTk4PYYs1c0PU8t9MHCO7ReAB9NotVel81Z6DuBu27emfY15MUIIoRFU81JbVbYPq3H8h8APR/0EFbRlHk+67LULMDI9zVbAOpKulHSzpMPT/pfS1iTz0r51gcW2B0bsX6FMOj6c6qZSXZX25/2eZkiaLWn20088XbtACCEUJvrG9FfcOlXLBxcoW/73t8BxpTeuSuLZDXgT2aqJ10m6ni5QmjJnix1fHhNMQwjNV7DH0y4tbXjS0gO/Bc62/bsyp8wDnkjLIT8r6Wpgp7S/NOvmNLJUNk8AkySNSb2a4f2wPNXNvBGpbuZXqIsq+0MIoeNkE0i7LwFNK0e1iSwLwD22/7vCaecDr5U0RtKawB7APcBNwJZpBNs4ssEBM9NNrj+R3QCDLLXN+elxpVQ3M4FD06i3zcnGpN9Y6Tka9f2HEELjVU6X08k9oVb2eF4DvB+4Q9KctO/zwCYAtk+1fY+ki4HbgSHgp8OZoiUdC1wC9AOnl8ye/SxwjqSvA7eSNW5QIdWN7bsknUc2qGEAOCZlqK74HJI+Bvw/YCpwu6RZto9u9AsUQgh16dIeT0+vQNosr9hpK/9o1klNfY6hBsyKbkT2g6Lr6bw4+GLhGJYsW1L7pCp2X3fPwjGM7y+eBUIdsi5QES8MLW13CEDxrAG1ljRoRAzrjZ96c5HJnQDjpq7lKYdvV/H4Y/91U+HnaIbIXBBCCN1Kor+DR69V0n19tAbKk01B0vsk3S7pDknXStqpHbGGEMJIAvr7VHHrVL3e4xnOpnCLpAnAzZIus106qfVBYG/bT0o6kGzI9B7tCDaEEEpJYuyY7nsb776IGyhPNgXb15YUuZ5smHUIIbSfoK+/c3s2lfR0w1OqSjaFUkcBF1UoPwOYAbD+xus3OrwQQlhJ9Hi6WI1sCsPn7EPW8Ly23PHSzAWv2GmrGCoYQmg6AWO7cHBBzzc8ObIpIGlH4KfAgbYLpwQPIYRGkERfX/eNEevphidPNgVJmwC/A95vu/hymSGE0CBS9Hi6Uc1sCsAJZFmtT0nLIgx04oSsEEIvEv3R4+kutq+B6tPFU2qcutLj9KufSatNqnpOn9r/yzJxbPHZ9mv0jS9Yfq3CMQy+tCrG6Pzt2XsLx7D1+O0L1zG2b7VC5b2s+K3FwRcGC5UfO654NoxGKLp2lhowUmwZLxSuoxYJxo6NHk8IIYQWEd15j6f7Im4wSadLWijpzgrH15H0+5S94EZJxT/ahhBCA2TDqfsrbjnK13r/k6STJM1N74G7NiLunm94gDOAA6oc/zwwx/aOwOHAD1oRVAgh1KTCKXPOoPr734FkS8dsSTZP8UeFYyYaHmxfTbZsQiXbAlekc/8KbCZpg1bEFkII1QxPIK201ZLj/e9g4CxnridbeHPDonH3fMOTw23AOwAkvQrYlEibE0LoACJLmVNpa4CNgUdKvp6X9hUSgwtqOxH4QRpufQfZYnMrDf0pTZkzddrUVsYXQuhROVLmTJE0u+Tr01KWlbaKhqeGlELnA/DShNMHgQfKnPdSypxtd94mUuaEEFqixr2cxwvOO5wPTC/5elraV0hcaqtB0iRJw5MTjgaurpTPLYQQWqnoPZ4cZgKHp9FtewJPpaz+hfR8j0fSr4E3kHVJ5wFfAsbCS5kLtgHOlGTgLrJEoSGE0HZ9EuP6x466fI73v1nAW4C5wHOkqz9F9XzDY/uwGsevA7ZqUTghhFCX/r7RZy7I8f5n4JhRP0EFPd/wNEutlDhrjlmzUP3jVCy9CsAa/cXT1UzsX6dQebn4yBtT7Jba9hOLz4m78+lbCtex3YSdC5Xva0DqFBV8R+ineAxF0/YADA4UqyN7vy2o+J9XTZIYN2b0PZ52iYYnhBC6lBD9HZD3sV7dF3GD5UgZ8QZJT0mak7YTWh1jCCGUM9zjqbR1qujxZCkjfgicVeWcP9t+W2vCCSGEfESxezzt0vMNj+2rJW3W7jhCCKFeKjiqrV16/lJbTntJuk3SRZK2K3eCpBmSZkuavfiJxS0OL4TQi5QWgqu0daqe7/HkcAuwqe0lkt4C/IEsU+sKInNBCKHVosezirL9tO0l6fEsYKykKW0OK4QQgOweT6WtU0WPpwZJU4F/2HbKTt0HPNHmsEIIIctc0JjUOC3VfRE3WI6UEe8CPixpAHgeONQNmV0WQgjFdOultp5veHKkjPgh2XDr3Mb0jWGdcZOrnjNOq9dT5UrGqvgv2xp9LZhaXYPVgDa8YPIDFa0A2Hp88RXRb1h0TaHyW0wsntmpaCaKAQYKx8C42qfU4nFDhco/P/Rs4Rj6/17sbzwfdfQltUp6vuEJIYRu1delKXN6fnBBjswFW0u6TtILkj7d6vhCCKGafvVV3DpV50bWOmcAB1Q5vgj4GPCdlkQTQgg5SWJs/9iKW6fq+YbH9tVkjUul4wtt3wQsa11UIYRQmxB96qu4daq4x9MgkmYAMwA2nr5Rm6MJIfQCkQ1m6jad2yR2Gdun2d7d9u6Tp1Qf0RZCCA2h7uzxdG5kIYQQqhJijMZU3HLVIR0g6V5JcyV9rszxIyX9s2RpmKOLxt19fbQQQggvKdKzkdQPnAzsB8wDbpI00/bdI0491/axo49yRT3f8NTKXJBS5swGJgJDko4DtrX9dHsiDiGEjFDRezyvAubafgBA0jnAwcDIhqeher7hyZG5YAEwrUXhhBBCfirW4wE2Bh4p+XoesEeZ894p6fXAfcAnbD9S5pzcer7haYY++lirb0LVc9QBt9f61H2pNjrV2L7VCtex6zrl/t7zmzX//MIxbL9usdQ/G6+2aeEYBhksXMdzg88UKj917PTCMTyx8T8K11HL8D2eKqZIml3y9WlpCZd6/B/wa9svSPogcCbwxjrrWEE0PCGE0KVyXGp73PbuVY7PB0pb2Wlp30tsl2bj/ynwn/XGOVL7P3a3WY4RHZtI+pOkWyXdnhaDCyGEjlBwOPVNwJaSNpc0DjgUmFl6gqQNS748CLinaMw93ePJOaLji8B5tn8kaVtgFrBZy4MNIYQRpJqX2qqyPSDpWOASoB843fZdkr4KzLY9E/iYpIOAAbIsL0cWjbunGx7yjegw2Yg2gLWBR1saYQghVCAKDy4YXll51oh9J5Q8Ph44vtCTjNDrDU+eER1fBi6V9FFgLWDfchWVpsyZNj0GwYUQWqHwcOq26Pl7PDkcBpxhexrwFuAX0sofMUpT5qwbKXNCCC0QSUK7U80RHcBRpGUTbF8naXVgCrCwJRGGEEIFEoXu8bRL5zaJrVFzRAfwd+BNAJK2AVYH/tnSKEMIoazo8XSdnCM6PgX8RNInyAYaHGnb7Ys6hBAyAvq7cCJ4Tzc8kGtEx93Aa+qrVU3PTDBWnbu6YBid1fpWL1T+zRsdWDiGCx4Z2eGvz6KJFddUzG3ridsVrmPK2KmFyv9jYF7hGFqTnUSUueXc8Xq+4QkhhG7WT/f1eLqvqWywWpkLSs57pyRLqpZ+IoQQWkaxEFz3KclccCCwLXBYyk4w8rwJwMeBG1obYQghVCf6Km6dqnMja42XMhfYfhEYzlww0teAbwNLWxlcCCFUI0R/lX+dqtcbnnKZCzYuPUHSrsB02xdWq0jSDEmzJc1+4vEnqp0aQggNI6ni1ql6veGpKmUo+G+yIdVVrZi5YN3mBxdCCIg++itunarXR7XVylwwAdgeuDJ9epgKzJR0kO3SxZVCCKEtOrlnU0mvNzwvZS4ga3AOBd47fND2U2TpcQCQdCXw6Wh0QgidQMRw6q5jewAYzlxwD9m6O3dJ+mpafyKEEDqYunJUW6/3eGpmLhix/w156hxikGeHqq/5PqF/7ZwRlteNs5WbRS52qaERGZAakUTpBT1XqPxamlj7pBoO3uQdhcqf//ffFY5h6WDxwaM7TNqpUPlOftMu1Yj1eNqh5xueEELoXs1Pz9UM3Rdxg9XKXCBpNUnnpuM3SNqsDWGGEMJKhpOEVtpy1dGG98CebnhyZi44CnjS9hbA98gmkoYQQgdQ1X81S7fpPbBmwyPpk5I2rnVel8qTueBg4Mz0+DfAm9SN4xdDCKseQZ/6K245tOU9ME+PZwJwqaQ/SzpW0gZFnrDD1MxcUHpOGgX3FLDSDNHSzAWLHi+eGj6EEGqRRZ/7Km7AlOH3pbTNGFFFw94D61FzcIHtrwBfkbQjcAhwlaR5tvct8sSrGtunAacB7LjrDrFQXAih6Yxrjcp83HbHZdSv5x7PQmAB8ASwfnPCablamQtWOEfSGGBtstcghBDazoOuuOXQlvfAPPd4PpJm7F9O1r36D9s7FnnSDvJS5gJJ48gyF4xcgnEmcER6/C7gilj6OoTQEZzNQ6u05dCW98A883imA8fZnlPkiTqR7QFJw5kL+oHThzMXALNtzwR+BvxC0lxgEdkPJoQQOkLOnk35sm16D8xzj+f4ok/SyWplLrC9FHh3q+MKIYSaXDxrRjveAyNzQRM8uXQxv7mveuqQD233kULPYQ8VKg/gwcJVwFCx3/qGpKsp8Ikvi6FwCA2x2pprFCrvZcW/kdX71yxU/s3T9i8cw7eu/V7hOm4cP6dQ+SN2eG/tk2pYv7/5s1CM8WDx94JWi4YnhBC6WKd8cKpHr2cukKSTUiqI29Nqo9XOnynpzlbFF0IIVbnwqLa26PUez4HAlmnbA/hR+n8lkt4BLGldaCGEkEPBy93t0NM9HrJUEGc5cz0wSdKGI0+SNB74JPD1VgcYQgiV2DA05Ipbp+r1hidPugiArwHfBSoumFKaMufZJ6NjFEJoBWc9nkpbh+r1hqcmSTsDL7f9+2rn2T7N9u62d19rnfGtCS6E0Nu6tMfTc/d4JB0D/Ef68iZqp4vYC9hd0kNkr9f6kq7MuxppCCE0UycPIqik53o8tk+2vbPtnYE/AIen0W17Ak/ZfmzE+T+yvZHtzYDXAvdFoxNC6AimKy+19VyPZ4RZwFuAuWT3bz4wfEDSnNQ4hRBCRzJ09CW1Snq64UmJ7o6pcGznMvseAravVe+EceN542avr3rOoAdyxVjJ0FPFf9nUX3zGc//YfMvrVtKNfzTl9K9Z/OKBXyz2Wqi/eAzP+KlC5ftV/C3lY3scXbiO/5t7UaHyty2aUziG13hy4Tpy6b7EBb3d8IQQQlezGerClDk9d4+nVN7MBZIOk3RHOudiSVNaHWsIIZTTjaPaerrhYcXMBTPIMhesIC189ANgn7QO0e3Asa0MMoQQyrFhcHCo4taper3hyZO5QGlbS5KAicCjLY4zhBDKMB6qvHWqXr/HUylzwUtDqm0vk/Rh4A7gWeB+ygxIkDSDrNfEhtOmNjHkEELI2DA40Lk9m0p6vcdTk6SxwIeBXYCNyC61rbQ4XmnmgknrTmptkCGE3tSlmQt6ruGRdIykOZLmkPVsamUu2BnA9t/S8OvzgFe3INQQQqjKuGn3eCRNlnSZpPvT/+tUOG9w+D1V0sw8dfdcw1Nv5gKyhmhbSeulr/cD7mlZwCGEUIlhaGCo4lbQ54DLbW8JXJ6+Luf54fdU2wflqbjX7/HUzFxg+1FJXwGulrQMeBg4sh3BhhBCqSZnLjgYeEN6fCZwJfDZRlTc0w1P3swFtk8FTs1bb/8LY5l4f/UBBl9+ttjSPl/YaqXbTHUberb4Tcm+cYOFyo9ZvVjmA4D+1QrW0YB7swNDLxauY4zGFSq/2P9sewxDLv5ibjRu08J1fHi7sn/Wud329E2FYzhvwdmF66jJrjW4YIqk2SVfn2b7tJy1b1ByBWgBsEGF81ZPzzEAnGj7D7Uq7umGJ4QQul32+bmix23vXumgpD8C5T4lf2HEc1hSpSfa1PZ8SS8DrpB0h+2/VQuq5+7xDJO0taTrJL0g6dNVzjs2ZTZwZCwIIXSS4eHUlbba5b2v7e3LbOcD/xie15j+X1ihjvnp/wfILsftUut5e7bhARYBHwO+U+O8vwD7kt3bCSGEztHc4dQzgSPS4yOA80eeIGkdSaulx1OA1wB316q4Zxse2wtt3wQsq3HerSkrdQghdBTjZo5qOxHYT9L9ZB++TwSQtLukn6ZztgFmS7oN+BPZPZ6aDU/c4wkhhG7l5o1qs/0E8KYy+2cDR6fH1wI71Ft3NDwNUpoyZ6OpG7c5mhBCLzB0dDLQSnrqUltp1gJJGzWy7tKUOZMntWgBqBBCb3MkCe14tk8GTm53HCGE0AiRJLTLSJoqaR7wSeCLkuZJmpiOzRruEUn6WDpvGnB7yU21EEJou6GhoYpbp+qpHk8p2wvIGpNyx95S8vgk4KRWxRVCCHm5duaCjtSzDU8zvbh0gIfvLTvX6iU77LFloedYMunJQuUBJi0tPh82WxuvvYrGsHTcc4VjeOi5uYXrWPDcgkLlN5mwSeEY1uxfs1D5if1lExjXRSp+Iea5wSWFyq+/+vqFYxg3ZmzhOmoyDC4rlraqHaLhCSGELmXc0ZfUKunlezx5U+acIenBktFwO7cwzBBCqKxgypx26eUez3DKnLfnOPcztn/T3HBCCKE+dnf2eHq24bG9EFgo6a3tjiWEEEZrcKD77vH07KW2On1D0u2SvjecEG8kSTMkzZY0+6lnit/4DyGEWtzcJKFNEw1PbccDWwOvBCZTYQW+0swFa08oPrInhBBqshkcGKy4daqeanhGkzLH9mPOvAD8HHhVc6MMIYR8hpe+7rYeT0/d4xlNyhxJG9p+TNlkkbcDdzYjthBCqFvq8XSbnmp4SkmaCswGJgJDko4DtrX9tKRZwNG2HwXOlrQeIGAO8KE2hRxCCCtxF2an7tmGp46UOW8cReU1u7lv2njfuqstte/3jyxUHuAvnzyvcB1DFOvOm/b/0Zx11y8L13HTQ3cVruO413+gUPmFz1XPlpHH1DWnFir/9LLiC/X2NSBzQdE6+hpwF2L6xLJvLw1lm4EOnq9TSc82PCGE0O1scBfO4+mpwQWl6shc8EZJt0i6U9KZkqKxDiF0iOaNapP0bkl3SRqStHuV8w6QdK+kuZI+l6funm14WJ654DuVTlCWrfBM4FDb2wMPA0e0JrwQQqjOKUlopa2gO4F3AFdXOkFSP9mArQOBbYHDJG1bq+KebXhsL7R9E7CsymnrAi/avi99fRnwzqYHF0IIeTRxAqnte2zfW+O0VwFzbT9g+0XgHODgWnX3bMOT0+PAmJJu5ruA6eVOLM1csHjJ4lbFF0LoYbYZenGw4gZMGX5fStuMBoewMfBIydfz0r6q4n5FFbYt6VBgOFXOpUDZ/qvt04DTAF6x2TadO3MrhLDqMAxVH079uO1q92f+CJQbyvgF2+cXDa+Snmp4JB0D/Ef68i1pnk5Vtq8DXpfKvxnYqnkRhhBCfrYL3cuxXWxeB8xnxatA09K+qnrqUpvtk23vnLaajQ6ApPXT/6uR5Wk7tZkxhhBCfsaDQxW3FrgJ2FLS5pLGAYcCM2sV6qmGp5SkqZLmAZ8EvihpnqSJ6disklxun5F0D3A78H+2r2hTyCGEsKImjmqT9K/pPXIv4EJJl6T9G6XsLtgeAI4FLgHuAc6zXXM2dU9daitVR+aCzwCfaVVcIYSQlw0ebM4tZdu/B35fZv+jQOl75CxgVj1192zD00xDQ2bpsy9UPWe9MRsWeo7vHv7xQuUBbnziusJ17LTOLoXKz3/+kdon1fDlWScVKr/0xYHCMZx52HcL1zFW4wqVHyo/7qUuzw4+U6j80sGlhWMYcvtn4jcibc9Ga+VKgF+MzeCLkSQ0hBBCq0TKnO4i6X1pVdE7JF0raacK552d0kHcKel0SWNbHWsIIZTj1OOptHWqnm14gAeBvW3vAHyNNAenjLPJViDdAVgDOLo14YUQQnXDw6mblDKnaXr2Upvta0u+vJ7KAw1eumkm6cZK54UQQjvEejzd6yjgomonpEts7wfK3tVPqShmAKy3zgaNji+EEFY2FIMLupKkfcgantfWOPUU4Grbfy53sDRlzpabbB0pc0IITWe6c3BBTzU8I1PmAFOAnwIH2n6iSrkvAesBH2x6kCGEkFcMp+58tk8mWzsCSZsAvwPeX7LswUokHQ3sD7zJ7oAJBiGEMKyJE0ibqZdHtZ1Att7OKZLmSJo9fGBEypxTgQ2A69J5J7Qh1hBCWIkxA4MDFbdO1VM9nlK2j6bC0OgRKXPqf40EfX2qesqSBc/WXW2pR56pmQC2pp9edmHhOo7e762Fyv/yqksLx7D0xWpr+dV26Yd+UTiG1fvWKFzHCy4263+ZXywcw/j+tQuVL5p9AWDp0POF63hu4LlC5RuRPeHFweI/j1psGIp7PCGEEFrFmGWDxT54tUNLLrXVkSVAkr4h6T5J90j6WMn+kyTNTfXsWlLmCEn3p+2Ikv27peebm8oq7Z8s6bJ0/mWS1snxHBdLWizpgma9RiGEULfU46m0dapW3ePJmyXgSLJFhba2vQ3Z+t0ABwJbpm0G8CPIGhHgS8AeZGt/f2m4IUnn/EdJuQPS/s8Bl9veErg8fV3xOZL/IpvDE0IIHaNb7/G0pOGxfa3tJ9OXFbMEAB8Gvjo8esz2wrT/YOAsZ64HJknakGy02WW2F6X6LwMOSMcm2r7etoGzgLeX1HVmenzmiP3lngPblwPF0vaGEEKj2QwNDVbcOlU7RrVVyxLwcuAQSbMlXSRpy7R/Y6A0f/68tK/a/nll9gNsYPux9HgB2Yi1as+Ri6QZKe7ZTy9ZnLdYCCGMWrf2eFo6uCBHloDVgKW2d5f0DuB04HXNise2JTVkEPwKmQs2jcwFIYTms2FgoHMbmEqa1uORdEya9zInLZW6I1mWgIOrZAmYRzapE7KV73ZMj+eT3fsZNi3tq7Z/Wpn9AP8YvoSW/h++nFeprhBC6FBm0IMVtyIkvVvSXZKGJO1e5byH0kCuFeZDVtO0hsf2ybZ3tr0zWc+qZpYA4A/APunx3sDwuTOBw9PIsz2Bp9LlskuAN0taJw0qeDNwSTr2tKQ902i2w4HzS+oaHv12xIj95Z4jhBA6km0GBgYqbgXdCbwDuDrHufuk9/uKDVSpVl1qK80SADAwHKCkWcDRaR3vE4GzJX0CWMLyCZ6zyHKrzQWeAz4AYHuRpK8BN6Xzvmp7UXr8EeAMsjV0LmL5faUTgfMkHQU8DLyn2nOkGP9MtibPeEnzgKNsX1L8ZQkhhNEzzVsq3PY9AOk9u6GUDfoKjbTdVtv71//zu6rnvHyv3OMWynrHb44sVB4aM+P5j+feUKj8hz/1jsIxfOd13y5UfkAvFI5hiOJ/R4Mu9gm1EZkLhujckVD1eHGo2M+0FdkTdltvr5vz9hAqmdS/rt+w5gEVj5+/5FcPA4+X7Dot3Y/OTdKVwKdtl72MJulB4EmydvDHeeqPzAUhhNC1XOsD5OPVGjdJfwSmljn0Bdvnl9lfzmttz5e0PnCZpL/arnp5rqcbHkkHk01oHQIGgONsX1PmvN1YftluFvBxR1cxhNBmNiwrMGza9r7FY/D89P9CSb8nm8xfteHp5ezUkGUu2CkNgPh3slF35VTKghBCCG3ktqbMkbSWpAnDj8kGeN1Zq1xPNzy2l5T0XNaClS/U18iCEEIIbWObgcFlFbciJP1rGky1F3ChpEvS/o3SoDDIJuBfI+k24EbgQtsX16q7py+1QfbiAt8C1gfK5fivlgUhhBDaxjRvWQTbvyebTzly/6NkI4Cx/QBQNulzNTGqLZH0euCEkdc808SpE4f3S3od8Fnbbxtx3gyy5KIA25Oju1nDFFYcjdKOOiKGxtXRCTE0oo6IoXF1vML2hCIBSLo4xVHJ47Y779aA7Z7agGOAOWnbaMSxB4ApI/ZtCPy15OvDyIYMVnuO2Q2Is+11RAzxfUQMnf19dOvWc/d4vGJGhTVL1unZlSxX3BMjzq+WBSGEEEKdev0ezzvJ0uQsA54HDnH6KCJpTmqcoHIWhBBCCHXq6YbH9reBstPeSxodnM3Y3b6OquuaGdzBdUQMjaujE2JoRB0RQ+PqaEQMXSkGF4QQQmipnrvHE0IIob2i4QkhhNBS0fCEEEJoqWh4QmgiSZMlTW53HI2Sph208/knStotLfxYpJ5qky7zlF+/SPleFw1PQZLGSPqgpIsl3Z62iyR9SNLYAvWeVce5kyWdIOnotILqFyRdIOm/8v6BprxMk9Pj9SSdlZazPVfStBzlp4z4+t8knSRpxvBcqdGQdMUoyuwv6ShJm43Y/++jjSOVPyHneZtIOkfSP4EbgBslLUz7NqtRPE/9d+Q4Z3p6vj9L+nzp76KkP+R8nl1HbLsBMyXtkqcBKn29JU2TdLmkxZKulbRVzhh+Ofy7JWl/sowg3wbmSHp3zjoOlPSgpGtS7HcBN0iaJ+lNOcpPHrGtS/YzXafeDxWSNih5PTeop+yqJEa1FSTp18Bi4EyW53SbRras9mTbh+SoY+bIXWRLgF8BYPugGuVnAXcAE4Ft0uPzgP3Ism8fnCOGu21vmx6fC1wP/C+wL/A+2/vVKH+L7V3T4y8CrwN+BbwNmGf7EzliuH3kLmAr4F4A2zvmqOObwGuBW4B/Ab5v+39Gxjgakv5ue5Mc510HfB/4jZ0tfC+pH3g32dIbe+aoo9IKeQJOtb1ejfKXAb8l+zkeBewG/IvtJyTdanuXHDEMpfKlq6rtmfbZ9htrlC/9nTgP+CNZBviDgWNt53nTv8P2DunxtcB7bT+UGqPLbdfMEyZpDlnGkUnABcBbbV8vaRvg7Fq/E+l1eHjE7mlkf++2/bIcMewMnAqsDcwvqWMx8BHbt9SqY5XS7tQJ3b4B943m2IjzbgF+CbwB2Dv9/1h6vHeO8nPS/wLmlzuWo457Sx7fXG8dwK0jvp+10uOxwB05Y5iZXoetgU2BzYBH0uNNc9ZxBzAmPZ5Etn7S90bGWKX80xW2Z8iWbM8Tw/2jOTbivGVkk5Z/XmZ7Ju/vRMnX/wbcBbwcuCVnDO8ErgIOLNn3YJ6yw78HVeKp+bNI591Flh0e4Bqgr/TYKOJ4pNrrVKH8p4CLgR1G8zoMPw+wR5n9ewK31VPXqrD19ATSBlmUuvy/tbPFzyX1kX26fTJnHbsDHwe+AHzG9hxJz9u+Kmf5vnRJbQIwXtJmzj4VrguMy1nHlZK+Spap+0pJ/2r795L2AZ7KUX4NSbuQXb7tt/0sgO1lknKtp2z7IGXZwk8DvmN7pqRltkd+2qxmjJ2tIW17saR/AU6T9L/key0WA6+0/Y+RByQ9kjOGmyWdQtYLHi4znawXfGvOOm4new1WSjYrKc/iXWMlrW57KYDtX0paAFxCtgRITbZ/qywV/tfSZbNPUWbpkCqmSTqJ7APRepLG2h7O1Z/3MvRXgD9JOhn4C/C/6QrBPmSNQR6LJX2Q7IrAk5I+QXZFYF9gSa3Ctr+brgJ8L/0OfIn6XgfIPoittE68s55Xrp/HKqXdLV+3b2Sfys8F/gncl7aFad/mddY1jezy1snA3+sodxjwj7S9k+ySxmVkXfoZOesYC3wZ+Hvahsg+5f8K2CRH+T+N2DZM+9elzmSIZG+M/02WE29enWUvoEwvEfg6MJSj/NeBV1U49u2cMYwDPkz2xnhH2i4iS720Ws46XlfpdQd2z1H+ExVeh12Ay0bxe75L+rkurKPMESO2ddL+qcA366hnC7L7Or8H/o9sYcb96yg/HfhxKjc1vTZ3AhcC29T5OhxMdqlxQZ3lTkrPdwjw6rQdkvb9sN6fR7dvcY+ngVIPA9tP1Dq3Rj1vBV5j+/N1lOknu2c3IGkMsDPZZbfHRvH8a5P1HAp9HyVxrWb7uVGU3QnYy/apdZRZA8D282WObey0TG+oXxokMsH20+2OpZ3S79jLXaY3WqPcgWQN1/B6XvOBmbZnVS61aoqGp4kkTbW9IOe5IlurvPSX8kbHD2iVIultti9oZx0RQ/11pBF1b2fFv8/znWO1zbCyGE7dXD/Lc5KkNwP3k13qekvavgLcn46NmqTCo2WK1tEJMTSijkbEALyyA+qIGOqoQ9L3ye7BXgX8Z9quAj4m6QdFA1C2iGRPiR5PB5B0D9nIoYdG7N8cmGV7m7YEFkZN0taUv6xyT6vqiBgaU4ek+2yvNO8oXaW4z/aWeeOoUP8Hbf+4SB3dJno8TSRpfM5Tx7B8DlCp+eQf/dOQyWlF6+iEGBpRR5Hykj4LnEM2muvGtAn4taTPtaKOiKGhdSyVVK5n9EpgaZ4YanixAXV0lejxNJHyTzg8HngP2R9H6fDbQ4HzbH+rRvmdKTg5rWgdnRBDB30f9wHbefnQ4eH948jmntT8hFy0joihod/HrmQj4iaw/APidLJpBsfYvrlWDDXqz/U+sSqJeTwFSfpkpUNArh6P7W9JOh84CNgr7Z5PljHg7hxVnAF80CPmCUjak2zCYc3Z3Q2ooxNiaEQdjYhhCNiIlWe7b5iO5VG0joihQXWkDxt7SJpKyaW6vAOHgHJZOV46BPRc6pxoeIr7JvBfwECZY7kvZaYG5m6l3E+2F9URQyMmpxWtoxNiaEQdjYjhOOBySfezvAe7Cdl8lGNbVEfE0MA6lE0x2JuShkfSJbYX54xhA2B/Vp5ULuDanHWsMuJSW0HK8kd9tFx3W9IjtqfnqGMTspEybyTrvotslvUVwOdGDjooU/4kslQoZ7HipbrDyVJ71PzjKlpHJ8TQKd9HqqePlYfH3+SUu60VdUQMjalD0uFk2QouZcXLr/sBX7FdM6GvpJ8BP7d9TZljv7L93lzfyCoiGp6CJL0CeML24yX7ptpeIGkDl0m9UqaORiSVHDk57VGyeQa5J6cVraMTYmhEHY2IIaw6JN1Llmdt8Yj96wA3lBvxFqqLhqcJVGcWZEn3V7rBWe1YI2NoRh2dEEMj6mhEDKF7pcEJr7T91Ij9a5Olgyo0nLoXxT2e5qh3/ZlGJJUsGkMz6uiEGBpRRyNiCN3rG8Atki5lxXtE+wFfa1tUXSwanub4SZ3nH062ZspXGDHBjZzZDxoQQzPq6IQYGlFHI2IIXcr2mcoyYu/P8r/PK4HjbefNQB9KxKW2EELIIU0kLh1OXfP+bSgvGp4OoCyb9FGUSUII/GzkxLcQQuuMmFQ8j+zSa++uHtoA0fB0ADVg+ewQQnMoWzq70qTiHzvH8tthRdHwdABVSEJY61gIoflqjDqda3uLVsfU7WJwQWdoxPLZIYTmuEjShZSfVBzr8YxC9Hg6gKTNyJb2fSNZQyNgEsszFzzYtuBCCOUmFffs6qGNEA1Ph1GDls8OIYROFQ1Ph1D5harOt/3X9kUVQkgZCo4n+/vcADCwkGzU6Yl1JAoNSSwE1wGqLFR1Tt7FrkIITXMe2SXwfWxPtr0usA/ZSNTz2hlYt4oeTwdoxGJXIYTmkHSv7VfUeyxUFj2ezjC8UNVI9Sx2FUJojocl/T+VLIGubGn0z7J8lFuoQwyn7gzHUXyxqxBCcxwCfA64qqTxWUCWS/E9bYuqi8Wltg7RiMWuQgihG0SPp3O4ZBv+Oi6zhdABJO1PmVyKtmMC6ShEj6cDSHozcApwPysurbsFWRLCS9sVWwi9TtL3ga3IMheU5lI8HLjf9sfbFFrXioanA0i6BzjQ9kMj9m8OzLK9TVsCCyFUzJcoScB9Meq0fjGqrTOMYfknqVLzgbEtjiWEsKKlkl5ZZv8rgaWtDmZVEPd4OsPpwE2SzmHFJISHMvoVSEMIjXEk8CNJE1j+AXE68FQ6FuoUl9o6hKRtgYNYOQnh3e2LKoQwTNJUVlyBdEE74+lm0fB0GEmTAWwvancsIYRMytd2ACt+MLwk8rSNTtzj6QCSNpF0jqSFwA3AjZIWpn2btTm8EHqapMOBW4A3AGumbR/g5nQs1Cl6PB1A0nXA94HfDE8YldRPthDccbb3bGN4IfQ0SfcCe4zs3UhaB7ghVgiuX/R4OsMU2+eWZimwPWj7HGDdNsYVQsgyxZf7hD6UjoU6xai2znCzpFOAM1lxVNsRwK1tiyqEAPAN4BZJl7JiLsX9gK+1LaouFpfaOkBa/uAoyiytC/zM9gvtii2E8NJltf1ZeXDBk+2LqntFwxNCCDmlBmjQ9tPtjqWbRcPTISTtA7yT7BLbIHAf8FPbc9saWAg9TtJGwIlkVyTGszyf4unAN0Yu4Bhqi8EFHUDSt8gSDl4PLAP+lrb/lfTudsYWQuCXwOm21yYbafpbYBuye+QntzOwbhU9ng4g6Q7bO6THY4CrbL8mdev/bHv79kYYQu+SdJvtnUq+vtn2bunxX21v3b7oulP0eDrD0HDGArIlsPsB0o3LGK4ZQnv9U9K/SdpY0keBh+Cl7NTxHjoK8aJ1hm8Ct0q6DLiGNERT0nrAbe0MLITAv5PlUbwE2IPly9FPBo5vV1DdLC61dYjU43kZMDfyP4UQVmXR8IQQwihJepvtC9odR7eJS20dTtIt7Y4hhFBRuQXiQg3R4wkhhBokbU2ZzCK272lfVN0rejwdRNIGknZN2wbtjieEAJI+C5xDNsL0xrQJ+LWkz7Uztm4VPZ4OIGln4FRgbZbPip4GLAY+Yjsut4XQJpLuA7YbmaEg5Vi8y/aW7Ymse0V26s5wBvBB2zeU7pS0J/BzYKdyhUIILTFENr/u4RH7N0zHQp2i4ekMa41sdABsXy9prXYEFEJ4yXHA5ZLuZ8VlEbZg+ZyeUIe41NYBJJ0EvBw4ixXX4zkceNB2/HKH0EaS+oBXseLggptKF28M+UXD0yEkHciKo2YeBc63Pat9UYUQQuNFw9OhJN1ie9d2xxFCCI0Ww6k7VyQHDSGskqLh6Vw/aXcAIYTQDHGpLYQQQktFjyeEEEJLRcMTQgihpaLhCSGE0FLR8IQQQmipaHhCaCJJr5R0u6TVJa0l6S5J27c7rhDaKUa1hdBkkr4OrA6sAcyz/a02hxRCW0XDE0KTpfT5NwFLgVdHfq/Q6+JSWwjNty4wHphA1vMJoadFjyeEJpM0k2wFy82BDSPbeOh1sR5PCE0k6XBgme1fSeoHrpX0RttXtDu2ENolejwhhBBaKu7xhBBCaKloeEIIIbRUNDwhhBBaKhqeEEIILRUNTwghhJaKhieEEEJLRcMTQgihpf4/wAIyl1zGpGAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "if not pbo.add_infinity:\n",
    "    test_bellman_iterations = max_bellman_iterations\n",
    "\n",
    "    q_weight = validation_weights\n",
    "    for _ in range(test_bellman_iterations):\n",
    "        q_weight = pbo(pbo.params, q_weight)\n",
    "else:\n",
    "    test_bellman_iterations = float(\"inf\")\n",
    "    q_weight = pbo.fixed_point(pbo.params)\n",
    "\n",
    "q.params = q.to_params(q_weight)\n",
    "diff_q = env.diff_q_mesh(q, q.params, states_x, states_v)\n",
    "\n",
    "q_visu_mesh.set_values(diff_q)\n",
    "q_visu_mesh.show(f\"Q policy, {test_bellman_iterations} iterations\", xlabel=\"x\", ylabel=\"v\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:09:34.996572Z",
     "iopub.status.busy": "2022-09-20T19:09:34.996400Z",
     "iopub.status.idle": "2022-09-20T19:09:35.008423Z",
     "shell.execute_reply": "2022-09-20T19:09:35.007984Z"
    }
   },
   "outputs": [],
   "source": [
    "# env.simulate(q, horizon, jnp.array([-0.5, 0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:09:35.010136Z",
     "iopub.status.busy": "2022-09-20T19:09:35.009952Z",
     "iopub.status.idle": "2022-09-20T19:09:35.263559Z",
     "shell.execute_reply": "2022-09-20T19:09:35.263080Z"
    }
   },
   "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": [
    "q_visu_mesh.set_values((diff_q > 0).astype(float))\n",
    "q_visu_mesh.show(f\"PBO Q policy, {test_bellman_iterations} iterations\", xlabel=\"x\", ylabel=\"v\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:09:35.265373Z",
     "iopub.status.busy": "2022-09-20T19:09:35.265200Z",
     "iopub.status.idle": "2022-09-20T19:09:41.000295Z",
     "shell.execute_reply": "2022-09-20T19:09:40.999819Z"
    }
   },
   "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": [
    "v_mesh_pbo = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "v_mesh_weighted_average = v_mesh_pbo * samples_count\n",
    "\n",
    "q_visu_mesh.set_values(v_mesh_weighted_average)\n",
    "q_visu_mesh.show(r\"$V^{\\pi_{pbo}}, \\mathbb{E}\\left[ V^{\\pi_{pbo}} \\right] =$\" + str(np.round(np.mean(v_mesh_weighted_average), 2)), xlabel=\"x\", ylabel=\"v\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:09:41.002202Z",
     "iopub.status.busy": "2022-09-20T19:09:41.002011Z",
     "iopub.status.idle": "2022-09-20T19:18:39.672568Z",
     "shell.execute_reply": "2022-09-20T19:18:39.672078Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4c2cf8b2ebc14b009015d5ee0d9d4e72",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/25 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "\n",
    "\n",
    "iterated_q = np.zeros((max_bellman_iterations_validation + 2, n_states_x, n_states_v, 2))\n",
    "iterated_v = np.zeros((max_bellman_iterations_validation + 2, n_states_x, n_states_v))\n",
    "q_weights = validation_weights\n",
    "\n",
    "q.params = q.to_params(q_weights)\n",
    "iterated_q[0] = env.q_mesh(q, q.params, states_x, states_v)\n",
    "iterated_v[0] = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "for iteration in tqdm(range(1, max_bellman_iterations_validation + 1)):\n",
    "    q_weights = pbo(pbo.params, q_weights)\n",
    "\n",
    "    q.params = q.to_params(q_weights)\n",
    "    iterated_q[iteration] = env.q_mesh(q, q.params, states_x, states_v)\n",
    "    iterated_v[iteration] = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "q.params = q.to_params(pbo.fixed_point(pbo.params))\n",
    "iterated_q[max_bellman_iterations_validation + 1] = env.q_mesh(q, q.params, states_x, states_v)\n",
    "iterated_v[max_bellman_iterations_validation + 1] = env.v_mesh(q, horizon, states_x, states_v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T19:18:39.674891Z",
     "iopub.status.busy": "2022-09-20T19:18:39.674748Z",
     "iopub.status.idle": "2022-09-20T19:18:39.686194Z",
     "shell.execute_reply": "2022-09-20T19:18:39.685709Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/PBO_linear/{max_bellman_iterations}_Q_{seed}.npy\", iterated_q)\n",
    "np.save(f\"figures/data/PBO_linear/{max_bellman_iterations}_V_{seed}.npy\", iterated_v)"
   ]
  }
 ],
 "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": {
     "06a26cb15bda4819a28ea6d0f3843793": {
      "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": ""
      }
     },
     "26a1634cb4c34611b3ab538f76ec85ec": {
      "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
      }
     },
     "30818f422653488cb8deaf1d438ef9ef": {
      "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_c17d7b994a8d41798ccbf00b4c16c83e",
       "placeholder": "​",
       "style": "IPY_MODEL_7cd08f442a2b442d895ee2dcfca46846",
       "value": "100%"
      }
     },
     "309682f50048434287e2efe1733d3565": {
      "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_7f9f985bb7fc4a4ba28f9061697e9d67",
       "max": 25.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_5a5733595b594957b00a0059688cc93a",
       "value": 25.0
      }
     },
     "4c2cf8b2ebc14b009015d5ee0d9d4e72": {
      "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_30818f422653488cb8deaf1d438ef9ef",
        "IPY_MODEL_309682f50048434287e2efe1733d3565",
        "IPY_MODEL_f5d357808da84995bc84aa0646313765"
       ],
       "layout": "IPY_MODEL_26a1634cb4c34611b3ab538f76ec85ec"
      }
     },
     "5a5733595b594957b00a0059688cc93a": {
      "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": ""
      }
     },
     "7cd08f442a2b442d895ee2dcfca46846": {
      "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": ""
      }
     },
     "7f9f985bb7fc4a4ba28f9061697e9d67": {
      "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
      }
     },
     "ac56432850054c6d9c965ccf4a3a31ef": {
      "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
      }
     },
     "c17d7b994a8d41798ccbf00b4c16c83e": {
      "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
      }
     },
     "f5d357808da84995bc84aa0646313765": {
      "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_ac56432850054c6d9c965ccf4a3a31ef",
       "placeholder": "​",
       "style": "IPY_MODEL_06a26cb15bda4819a28ea6d0f3843793",
       "value": " 25/25 [08:19&lt;00:00, 30.69s/it]"
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
