{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO deep on Car On Hill\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T20:27:25.981312Z",
     "iopub.status.busy": "2022-09-20T20:27:25.981134Z",
     "iopub.status.idle": "2022-09-20T20:27:26.602858Z",
     "shell.execute_reply": "2022-09-20T20:27:26.600807Z"
    }
   },
   "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",
    "\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_max_linear/\"):\n",
    "    os.makedirs(\"figures/data/PBO_linear_max_linear/\")\n",
    "for file in os.listdir(\"figures/data/PBO_linear_max_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-20T20:27:26.612722Z",
     "iopub.status.busy": "2022-09-20T20:27:26.612301Z",
     "iopub.status.idle": "2022-09-20T20:27:26.699175Z",
     "shell.execute_reply": "2022-09-20T20:27:26.698678Z"
    }
   },
   "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-20T20:27:26.701390Z",
     "iopub.status.busy": "2022-09-20T20:27:26.701221Z",
     "iopub.status.idle": "2022-09-20T20:27:32.054530Z",
     "shell.execute_reply": "2022-09-20T20:27:32.054047Z"
    }
   },
   "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-20T20:27:32.056333Z",
     "iopub.status.busy": "2022-09-20T20:27:32.056164Z",
     "iopub.status.idle": "2022-09-20T20:27:32.131944Z",
     "shell.execute_reply": "2022-09-20T20:27:32.131480Z"
    }
   },
   "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-20T20:27:32.133797Z",
     "iopub.status.busy": "2022-09-20T20:27:32.133629Z",
     "iopub.status.idle": "2022-09-20T20:27:35.714576Z",
     "shell.execute_reply": "2022-09-20T20:27:35.714108Z"
    }
   },
   "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-20T20:27:35.716413Z",
     "iopub.status.busy": "2022-09-20T20:27:35.716195Z",
     "iopub.status.idle": "2022-09-20T20:27:35.893752Z",
     "shell.execute_reply": "2022-09-20T20:27:35.893293Z"
    }
   },
   "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-20T20:27:35.895628Z",
     "iopub.status.busy": "2022-09-20T20:27:35.895464Z",
     "iopub.status.idle": "2022-09-20T20:27:36.219993Z",
     "shell.execute_reply": "2022-09-20T20:27:36.219495Z"
    }
   },
   "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-20T20:27:36.222069Z",
     "iopub.status.busy": "2022-09-20T20:27:36.221934Z",
     "iopub.status.idle": "2022-09-20T20:30:19.775833Z",
     "shell.execute_reply": "2022-09-20T20:30:19.775422Z"
    }
   },
   "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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iRMnRgI8y9tW3MqLWY5+EYROzgSyws+XxdKvLr0U1y9SMcX1xyfRcf1r1671devW+emnn+7Lly+PLF+5cqVv3brV3d3fffdd79ChQ2Rd//79ffHixf7tt9/60KFDI3H/5W2rrO8siQTE9V8CTAYuMrMfAFmJK3EiIlXTkOP609LS6NGjR6nlffr0iUT3p6ens3fvXvbv38/HH3/MV199xSmnnIKZMW7cOJ555pkKtxWvWKNidrn7DuA6M7sdKDsfQUQahE9uu4397yU2rr9ZWk+O/dWvKt2vocb1x+Kpp56ib9++NGvWjK1bt5KS8l3ofFGMfzLFOoN5tuiNu18PPJqc4YiIVE5Djes/lNzcXH75y1/ywAMPVLpvosQ0g3H3OSU+///JGY6I1AVVmWkkS0ON669IQUEBP/nJT3j00Uc5/vggTL5jx44UFBQUa5PsGP9KXUVmgYFmdqOZPWhmc8zsCTO7z8yuMrPUZA1URORQGlJcf3l27NjB8OHDuf322yOzIIDjjjuOI488kiVLluDuPProo4wcObKCLcUvpgJjZo3M7GJgGtADmANcD4wCxgO3EiQeDzOz35lZ8vKfRUTKMWXKFG644Qb69OlTqRlHrKLj+vv160erVq046qijSrV7/PHHycjIICsrizVr1jBu3Djatm0bieufPHkygwcP5sILLyQnJ4fevXszatSoSAEqiutPS0vjyy+/LDOu/+mnnyYlJYXFixczfPjwSOz+vffey/r165k6dWrkMu6iwnX//fczYcIEUlNTOf744zn77LMr3Fa8Dhl2aWZtgCHAAnffHtNGgwd8pbv73EM2riUUdilSMYVdBhTXn9iwy53u/o9YiwuAu29w97lmphs5RaReUVx/7BIS129m7YEjgQ/d/WDcG6wBmsGIVEwzGKnsDCauRyab2eXAfwB7gR1ARzPbCUx39/x4ti0iInVbXAUGWO7uxS6yNrMjgA5xbldEROq4uM6RuPtKM/utmX0vatnX7p4X/9BERKQui3cGA/BX4EozawU85u4rE7BNERGp4xJxlddEgkLVCLgrAdsTESlFcf3FVRSxv3r1anJyckhPT6d3797s27cPqKVx/RW9gMuAPwJnxLutmnwprl+kYorrj091xfUfPHjQe/fu7atWrXJ3988//9wLCwvdvfbG9VfkPeAl4FIzW56A7YmIxERx/aUj9hcsWEBmZiYnnXQSAG3btqVx48a1Oq6/TGbWHOgKfAk8EP7EzJq7+764RycitdJrj3/A51t2J3Sb7Tq15NTzTqx0P8X1F/fBBx9gZgwZMoRt27YxZswYpkyZUiNx/fGe5P9D+DMXaA7kmNlVwGPAG3FuW0TkkErG9Y8fP568vDzMjIMHy77vuyiuv1mzZpG4/ug/vvBdXD8Qietv2bJlqbj+GTNmlNp+Tk4Ot956KwUFBZx77rmccMIJpdpEx/VDEEGTl5dH586dS8X133PPPTEXmMLCQl5//XWWL19OixYtOPPMM+nXr1+ZmWnJFleBcfdJYVZZDsGd/IvcfXpCRiYitVZVZhrJorj+4lJSUjjttNNo164dAMOGDWPlypVcdNFFtTuuvyzu/oW7P+tBXpmyVkSkxiiuP9juu+++y549eygsLOSVV16hV69etTeuvyJm9sNEDEREJF6K64fWrVtz7bXX0r9/f7Kysujbty/Dhw8HamFcf5mdzP4BvA0YMNDdR0atOzdc3sPdb0vIKKuBwi5FKqawy4Di+pMfdnm/u78WbjyjxLqP3H2JmfWs4rZFRGqtmTNn8sgjj3DgwAH69OmjuP4KJCSuvz7QDEakYprBSDIeOFau8h6NbGZd4tlu1HaGmtn7ZrbezK4vY/21ZrbWzFab2YvR32tm480sL3yNT8R4REQkdlUqMGbW2czOB8aY2Xkl1h0ZLv9BPAMzs8bAfcDZQC/gAjPrVaLZ20C2u2cCTwJ3hH3bADcBJwMDgJvMrHU84xERkcqp6gzmc2AJ8GH4M8LdvwLmuftLcY5tALDe3Te6+wFgNlDsmjp3X+TuRRkKS4CiO6WGAC+El1B/CbwADI1zPCIiUglVKjDuvsfdNwPPuPuH0evMrBPQ2cyGxTm2jsCWqM8F4bLyXAo8V5m+ZnaZma0wsxXbtm2Lc7giIhIt3geOvV3Gsi3hjZfz4tl2ZZjZRUA2UKkUAXef4e7Z7p7dvn375AxORBJCcf3FTZ48mZ49e5KZmclPfvITduzYEVn3hz/8gdTUVHr06MH8+fMjy59//nl69OhBamoqt99+e2T5vffeS2pqKmbG559/nrAxxhPTPzr8mRG17CSCZ8LcCIyr6rbDbeUA86M+3wDcUEa7HxIkOh8TtewC4IGozw8AF1T0fYrrF6mY4vrjk+i4/vnz50f2ecqUKT5lyhR3d8/NzfXMzEzft2+fb9y40bt37+6FhYVeWFjo3bt39w0bNvj+/fs9MzPTc3Nz3d195cqVnp+f7126dPFt27aV+53VEtdvZgOB3Wb2GyA9atXRwPHATmCEmZW+/TR2y4ETzKybmTUFxgBzS4yjD0HxGOHun0Wtmg8MNrPW4cn9weEyEalHGnJc/+DBg2nSJLiV8ZRTTonkjM2ZM4cxY8bQrFkzunXrRmpqKsuWLWPZsmWkpqbSvXt3mjZtypgxY5gzZw4Affr0oWvXrnH/e5RU1Rst9wGpwEEgcmzJ3V8xs8OAgcBKoHTMaIzcvdDMriYoDI2Bh9w918ymElTMuQSHxFoCT4RhcB+6+wh3/8LMfk9QpACmuvsXVR2LiBS36OEZfLZ5Y0K3eUyX7nz/4ssq3U9x/fDQQw9x/vnnA0Gm2SmnnBJZFx3L36lTp2LLly5dGtsvuYqqVGDcfSWw0syuc/d7S6xbCCxMxOA8OI8zr8Sy30a9LzcHzd0fAh5KxDhEpPZq6HH9t956K02aNGHs2LGx/LqqVbzPg+l+6CYiUt9UZaaRLA05rv/hhx/m3//+Ny+++GKkTceOHdmy5buLaKNj+ctbnizxpil3MbNh0a+EjEpEpAoaUlz/888/zx133MHcuXNp0aJFZPmIESOYPXs2+/fvJz8/n7y8PAYMGED//v3Jy8sjPz+fAwcOMHv2bEaMGJGQ30t5Kl1gzKyDmf2XmV0OPA4cQ3AepuglIlIjGlJc/9VXX82uXbs466yzyMrK4oorrgAgPT2d8847j169ejF06FDuu+8+GjduTJMmTbj33nsZMmQIaWlpnHfeeaSnB9do3XPPPaSkpFBQUEBmZiYTJkxIyO+rUmGXZjYYeAR4GdhPcFlyC+Cn7v5mQkZUQxR2KVIxhV0GFNefvLj+W4BT3X191MZzgBlmdimwx91r329FRCRBFNcfu8rOYFa5e1YZy08E/g3sd/feiRte9dEMRqRimsFIsuP695lZqfMs7v4B8A1wZiW3JyIi9VRlC8x04Bkz6xC90MzaEcxePiu7m4iINDSVOgfj7k+ZWTNgsZm9BbwDNAXOIzg/IyIiAlThMmV3nwWkEZxzOYogLuZCd38kwWMTEZE6LJ7nwTzk7te6+83uvvzQvUREqk5x/cVVFNcPwc2aLVu25I9//GNkWXXH9cd7J7+ISLVo27Ytq1atYtWqVVxxxRVMmjQp8rlp06YV3liZnZ1dLDW5PG++mbzb+RJdYM466yzWrFnD6tWrOfHEE/nDH/5QbP21117L2WefHfn8zTffcNVVV/Hcc8+xdu1a/vGPf7B27VoABg0axMKFC+nSpUvCxgcqMCJShymuv3RcP8AzzzxDt27dInfqA3Uqrh8AM/uRu/8rUYMRkbphx782cOCjrxO6zaYdjuDoHx1f6X6K6y8e1797926mTZvGCy+8UOzw2NatW6s9rj/eGcytCRmFiEgVlYzrHz16NBkZGUyaNInc3Nwy+xTF9bdr1y4S119SUVx/o0aNInH969atKxXXX5acnBxuu+02pk2bxubNmzn88MNLtYmO6+/bty/r1q0jLy8PoFRc/+uvv17u/peM67/55puZNGlSZDZWk+KN6y87Q1pE6rWqzDSSRXH9xeP6ly5dypNPPsmUKVPYsWMHjRo1onnz5vTr16/a4/rjLTCx58yIiCRZdcb1d+3aNaa4/g8//JDVq1dz0kknlYrrv/HGGxk7diwtW7Zk69atkcN0RXH9OTk5h4zrf+WVV4rF9b/22muR9zfffDMtW7bk6quvprCwMBLX37FjR2bPns2sWbMS9aspk07yi0i9obj+8tX6uP5Snc1Wu3tmQkZSwxR2KVIxhV0GFNefvLDLkkqfGRMRqcdmzpxJVlYW6enp7Ny5U3H9FYhrBlOfaAYjUjHNYKS6ZzAiIiJlUoEREZGkSEiBMbP2Zna8mR126NYiItIQxBsVczkwCNgH7AA6mtlOYLq758c/PBERqavincEsBzYAN7r7FHcfC0wm/hs4RUSKUVx/ceXF9R88eJDx48fTu3dv0tLSiqUsV3dcP+4e1wvoBNwE/AnoE+/2aurVr18/F5HyrV27tqaHEHHTTTf59OnTiy07ePBgDY0mNvn5+Z6enp6w7c2fPz+yz1OmTPEpU6a4u/tjjz3m559/vru7f/31196lSxfPz8/3wsJC7969u2/YsMH379/vmZmZnpub6+7uK1eu9Pz8fO/SpYtv27at3O8s638DwAov5+9qIs7BTAQOI5gN3Z2A7YmIxERx/aXj+s2Mr7/+msLCQvbu3UvTpk058sgj615cfygPOBGY4+6Ju51VRGqt5557jk8++SSh2zz22GOLPSArVorrLx7XP2rUKObMmcNxxx3Hnj17uPPOO2nTpk2djOsHeA94CbjUzPToZBGpVorrLx7Xv2zZMho3bsxHH31Efn4+f/rTn9i4cWO5/ZMpETOYbsCXwAPhz4Qws6EEh9waA39x99tLrD8NuAvIBMa4+5NR674B3g0/fujuIxI1LhGhSjONZFFcf/G4/lmzZjF06FAOO+wwjjnmGAYNGsSKFSvo1KlTtcf1xzWDMbPm7v6ou//L3V9399yi5XFutzFwH3A20Au4wMx6lWj2IXAxUFbe9F53zwpfKi4iDUR1xvUDMcX1jxw5ktWrV9OqVatScf0PPfQQu3fvBoInTn722WfAd3H9wCHj+ufOnVssrr9z58689NJLAHz99dcsWbKEnj170r9//0hc/4EDB5g9ezYjRiT3z2O8h8j+YGb/Y2YTzGyUmU02s/uBfnFudwCw3t03uvsBYDYwMrqBu29y99XAt3F+l4jUE4rrh6uuuordu3eTnp5O//79+elPf0pmZmbdi+sHMLM2QA5wJJDn7nEnRprZKGCou08IP/8XcLK7X11G24eBf5c4RFYIrAIKgdvd/Zlyvucy4DKAzp0799u8eXO8QxeptxR2GVBcf+xhl3Gfg3H3L4Bn491OgnVx961m1h14yczedfcNJRu5+wxgBgRpytU9SBGpe2bOnMkjjzzCgQMH6NOnj+L6K5DwO+7NLIXgxDvuPq+Km9lKcANnkZRwWUzcfWv4c6OZvQz0IUgcEBGJy6RJkxI6Yympa9eutXL2UhVVPgdjZqPDnxlRy04CriM4B9MujnEtB04ws25m1hQYA8yNcVytzaxZ+L4dQVba2jjGIiIiVVClAmNmA4HdZvYbID1q1dHA8cBO4EdmVvrMVAzcvRC4GphPcJ/N4+6ea2ZTzWxEOIb+ZlYAjAYeMLOiC97TgBVm9g6wiOAcjAqMiEg1q+ohsn1AKnAQaF+00N1fCSP7BwJvE57fqIrw8Nq8Est+G/V+OcGhs5L93gR6V/V7RUQkMapUYNx9JbDSzK5z93tLrFsILEzE4EREpO6K9z6Y7oduIiISP8X1F3fjjTeSmZlJVlYWgwcP5qOPPgLgscceIzMzk969ezNw4EDeeeedSJ86FddPcHnysOhXPNuryZfi+kUqprj++CQ6rn/nzp2R93fffbdffvnl7u7+xhtv+BdffOHu7vPmzfMBAwa4u9fJuP7HCc7BFL3iuXJMRKRSGnJc/5FHHhl5//XXX0eyyAYOHEjr1q2B4jH+dSKu38w6AGcCLYB17v5KwkclIrXaBx/8nl2730voNlu1TOPEE2+sdL+GHNf/61//mkcffZSjjjqKRYsWlVr/4IMPRoJJa31cv5kNBt4iOByWA9xlZu+bWU4yBicicigNOa7/1ltvZcuWLYwdO5Z77y12vRWLFi3iwQcfZNq0aWX2rQ6VncHcApzq7uuLFoTFZaaZXQp87e714xZUESlXVWYaydKQ4/qLjB07lmHDhvG73/0OgNWrVzNhwgSee+452rZtC0DHjh1rfVx/0+jiAuDui4Fzgb8B/0jUwEREKqshxfUXzXYA5syZQ8+ePSN9zz33XP72t79x4oknRtrUhbj+fWbWvuRCd/8A+Ibg3IyISI1oSHH9119/PRkZGWRmZrJgwQLuvvtuAKZOncr27dv5+c9/TlZWFtnZQdBxrY/rN7P/BK4FRrv7R1HL2wEL3T0rIaOqAdnZ2b5iRdxPGhCptxTXH1Bcf5Li+t39qTBIcrGZvQW8AzQFziM4PyMiUq8prj92VXrgmJm1IEg4zgC+Ap71IBusztIMRqRimsFItTxwzN33AA9Vpa+IiDQMMZ3kN7Mjwp8tkzscERGpL2K9iqy1mV0NlL5WTkREpAyxFpgzgYuB7mZ2TPKGIyIi9UWsBWYZcAmw2d0/S+J4RETKpLj+4sqL64cgrDMrK4v09HROP/30yPI6Fddfn16K6xepmOL641Ndcf1ffvmlp6Wl+ebNm93d/dNPP3X3OhDXb2aXJa60iYjER3H9gei4/lmzZnHuuefSuXNnAI45JjirURfi+q8AZiR8FCJSp9yYV8Ca3XsTus2Mlofz+xNSKt1Pcf3F4/o/+OADDh48yBlnnMGuXbu45pprGDduXO2P6wcqjvQUEalmiusvHtdfWFjIW2+9xbPPPsv8+fP5/e9/zwcffFDRrzBpKjuDqfxt/yJS71RlppEsiusvHtefkpJC27ZtOeKIIzjiiCM47bTTeOedd0hJSan1cf0nmdlXZbx2mdlXSRmhiEiMFNcPI0eO5PXXX6ewsJA9e/awdOlS0tLSan9cv7s3dvcjy3i1cvcjD70FEZHkUVw/pKWlMXToUDIzMxkwYAATJkwgIyOjdsb1m9lxQG93XxDzRoNnxgwC/uXu38Q3xOqhsEuRiinsMqC4/gSGXbr7x2b2jZn9guAczJvASncvdmdTeIf/ycAAYI27lz13FBGpwxTXH7vKPnDsWOBs4AygDUGBcuAAsAmYD7xYsvjUBZrBiFRMMxhJSly/mbVx9y/c/RPgr+GrvLaHm9lp7v5qJcYtInWAux/yiiapnyozGSlyyJP8ZtYW2GZmbWLcZmdgUaVHIiK1WvPmzdm+fXuV/tBI3ebubN++nebNm1eqX6z3wcT1nyxm1rQuHjYTke8UXWW0bdu2mh6K1IDmzZuTklK5+59iLTCl/pPFzC4GrgV+5O6bD9H/d8ANYb9B7v5GLF9qZkOBu4HGwF/c/fYS608D7gIygTHu/mTUuvHAb8KPt7j7I7F8p4iU7bDDDovcwS4Si8reaAmAmf2G4JHJ3YGlZtb/EF3mm9llZjaW4CKBWL6jMXBf2L4XcIGZ9SrR7EOC59TMKtG3DXAT313VdpOZtY7le0VEJDEqm6ZsZvZnYCpwJ3A8wR/5l83sJ+X0eRAYAVwAZLj7b8pqV4YBwHp33xgeXpsNjIxu4O6b3H018G2JvkOAF8ILE74EXgCGxvi9IiKSAJUpMC2AOcDPgCnu/gt3/xQ4neAP+BNmdm3JTu5+KfBrgsNVn5rZAzF+X0dgS9TngnBZsvuKiEgCVOYk/zygBzDO3R8rWuHue8PZy13AdOAHJTu7+17gjfBVa4TPt7kMiDw7QUREEqMyM5guwPDo4lIkfLDZNQQn/RN1KGor0Cnqc0q4LGF93X2Gu2e7e3b79u2rPFARESktlgKzD/gL8H13X1hRQ3e/G/hPIBEhOsuBE8ysm5k1BcYAc2PsOx8YbGatw5P7g8NlIiJSTQ5ZYNz9a3e/zN1XxrJBd5/j7ifFOzB3LwSuJigM7wGPu3uumU01sxEAZtbfzAqA0cADZpYb9v0C+D1BkVoOTA2XiYhINalUFll9piwyEZHKqyiLrEr3wYiIiByKCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCSFCoyIiCRFrS4wZjbUzN43s/Vmdn0Z65uZ2T/D9UvNrGu4vKuZ7TWzVeHrz9U+eBGRBq5JTQ+gPGbWGLgPOAsoAJab2Vx3XxvV7FLgS3dPNbMxwDTg/HDdBnfPqs4xi4jId2rzDGYAsN7dN7r7AWA2MLJEm5HAI+H7J4EzzcyqcYwiIlKO2lxgOgJboj4XhMvKbOPuhcBOoG24rpuZvW1mr5jZqWV9gZldZmYrzGzFtm3bEjt6EZEGrjYXmHh8DHR29z7AtcAsMzuyZCN3n+Hu2e6e3b59+2ofpIhIfVabC8xWoFPU55RwWZltzKwJcBSw3d33u/t2AHd/C9gAnJj0EYuISERtLjDLgRPMrJuZNQXGAHNLtJkLjA/fjwJecnc3s/bhRQKYWXfgBGBjNY1bRESoxVeRuXuhmV0NzAcaAw+5e66ZTQVWuPtc4EHgb2a2HviCoAgBnAZMNbODwLfAFe7+RfXvhYhIw2XuXtNjqBWys7N9xYoVNT0MEZE6xczecvfsstbV5kNkIiJSh6nAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUqjAiIhIUigqJmRm24DNNT2OKmgHfF7Tg6hmDW2fG9r+gva5Luni7mU+70QFpo4zsxXl5QDVVw1tnxva/oL2ub7QITIREUkKFRgREUkKFZi6b0ZND6AGNLR9bmj7C9rnekHnYEREJCk0gxERkaRQgRERkaRQgakDzKyNmb1gZnnhz9bltBsftskzs/FlrJ9rZmuSP+L4xLO/ZtbCzJ41s3Vmlmtmt1fv6CvHzIaa2ftmtt7Mri9jfTMz+2e4fqmZdY1ad0O4/H0zG1KtA49DVffZzM4ys7fM7N3w5w+qffBVFM+/c7i+s5ntNrPrqm3QieDuetXyF3AHcH34/npgWhlt2gAbw5+tw/eto9afC8wC1tT0/iRzf4EWwPfDNk2B14Cza3qfytnPxsAGoHs41neAXiXa/Bz4c/h+DPDP8H2vsH0zoFu4ncY1vU9J3uc+QIfwfQawtab3J9n7HLX+SeAJ4Lqa3p/KvDSDqRtGAo+E7x8BflxGmyHAC+7+hbt/CbwADAUws5bAtcAtyR9qQlR5f919j7svAnD3A8BKICX5Q66SAcB6d98YjnU2wb5Hi/5dPAmcaWYWLp/t7vvdPR9YH26vtqvyPrv72+7+Ubg8FzjczJpVy6jjE8+/M2b2YyCfYJ/rFBWYuuF77v5x+P4T4HtltOkIbIn6XBAuA/g98CdgT9JGmFjx7i8AZnY08CPgxSSMMREOuQ/Rbdy9ENgJtI2xb20Uzz5H+09gpbvvT9I4E6nK+xz+x+Evgd9VwzgTrklND0ACZrYQOLaMVb+O/uDubmYxX1tuZlnA8e4+qeRx3ZqUrP2N2n4T4B/APe6+sWqjlNrIzNKBacDgmh5LNbgZuNPdd4cTmjpFBaaWcPcflrfOzD41s+Pc/WMzOw74rIxmW4Ezoj6nAC8DOUC2mW0i+Pc+xsxedvczqEFJ3N8iM4A8d78r/tEmzVagU9TnlHBZWW0KwqJ5FLA9xr61UTz7jJmlAE8D49x9Q/KHmxDx7PPJwCgzuwM4GvjWzPa5+71JH3Ui1PRJIL0O/QKmU/yk9x1ltGlDcJy2dfjKB9qUaNOVunGSP679JTjX9BTQqKb35RD72YTg4oRufHfyN71Em6sofvL38fB9OsVP8m+kbpzkj2efjw7bn1vT+1Fd+1yizc3UsZP8NT4AvWL4RwqOP78I5AELo/6QZgN/iWp3CcHJ3vXAT8vYTl0pMFXeX4L/OnTgPWBV+JpQ0/tUwb4OAz4guMro1+GyqcCI8H1zgquH1gPLgO5RfX8d9nufWnqlXCL3GfgN8HXUv+sq4Jia3p9k/ztHbaPOFRhFxYiISFLoKjIREUkKFRgREUkKFRgREUkKFRgREUkKFRgREUkKFRiRKjKziWb2npk9ZmYjilJyzezHZtYrqt3FZtYh6vNfotcnYVz/bWYtkrV9kVjpMmWRKjKzdcAP3b2gxPKHgX+7+5Ph55cJ7l9YUU3j2gRku/vn1fF9IuXRDEakCszszwTx68+Z2aRwlnKvmQ0ERgDTzWyVmf2S4AbRx8LPh5vZy2aWHW5nt5ndambvmNkSM/teuPz48PO7ZnaLme0uYwxHhM++ecfM1pjZ+WY2EegALDKzRWG7wWa22MxWmtkTYYAiZrbJzO4Iv2OZmaVWx+9OGg4VGJEqcPcrgI8Inj1zZ9TyN4G5wGR3z3L3acAKYGz4eW+JTR0BLHH3k4BXgZ+Fy+8G7nb33gTpu2UZCnzk7ie5ewbwvLvfEzWu75tZO4I74H/o7n3DsVwbtY2d4XfcC9xVtd+GSNlUYERq1gHg3+H7twjifCAIKX0ifD+rnL7vAmeZ2TQzO9Xdd5bR5hSCh5O9YWargPFAl6j1/4j6mVOVHRApj9KURWrWQf/uROg3VOL/k+7+gZn1Jci5usXMXnT3qSWaGcGD2S4obzPlvBeJm2YwIom3C2hVwedYLCF4qBYE6bqlhFem7XH3vxMkUPct4/uWAIOKzq+E521OjNrM+VE/F1dyjCIV0gxGJPFmAzPDE+6jgIeBP5vZXmI/DPXfwN/N7NfA8wRPOCypN8HFBN8CB4Erw+UzgOfN7KPwPMzFwD+iHi/8G4JkX4DWZrYa2A+UN8sRqRJdpixSC4X3sex1dzezMcAF7l7yOe7xfscmdDmzJJFmMCK1Uz/gXguek7uD4Nk3InWKZjAiIpIUOskvIiJJoQIjIiJJoQIjIiJJoQIjIiJJoQIjIiJJ8f8AWNS0y3TXYa4AAAAASUVORK5CYII=\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 LinearMaxLinearPBO\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 = LinearMaxLinearPBO(\n",
    "    q=q,\n",
    "    max_bellman_iterations=max_bellman_iterations,\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",
    "        q_weight = validation_weights\n",
    "        for _ in range(max_bellman_iterations + 3):\n",
    "            q_weight = pbo(pbo.params, q_weight.reshape((1, -1)))[0]\n",
    "\n",
    "        diff_q = env.diff_q_mesh(q, q.to_params(q_weight), 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-20T20:30:19.777631Z",
     "iopub.status.busy": "2022-09-20T20:30:19.777456Z",
     "iopub.status.idle": "2022-09-20T20:30:19.970998Z",
     "shell.execute_reply": "2022-09-20T20:30:19.970535Z"
    }
   },
   "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": [
    "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.reshape((1, -1)))[0]\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-20T20:30:19.972826Z",
     "iopub.status.busy": "2022-09-20T20:30:19.972651Z",
     "iopub.status.idle": "2022-09-20T20:30:19.983655Z",
     "shell.execute_reply": "2022-09-20T20:30:19.983153Z"
    }
   },
   "outputs": [],
   "source": [
    "# env.simulate(q, horizon, jnp.array([-0.5, 0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T20:30:19.985587Z",
     "iopub.status.busy": "2022-09-20T20:30:19.985324Z",
     "iopub.status.idle": "2022-09-20T20:30:20.196153Z",
     "shell.execute_reply": "2022-09-20T20:30:20.195620Z"
    }
   },
   "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-20T20:30:20.198133Z",
     "iopub.status.busy": "2022-09-20T20:30:20.197935Z",
     "iopub.status.idle": "2022-09-20T20:30:25.590923Z",
     "shell.execute_reply": "2022-09-20T20:30:25.590426Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZsAAAEYCAYAAACKvFuOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA0NUlEQVR4nO3deZxcVZ338c+3OxshQAJhCSQIyiIRBUJY3EYWFXDDGUcFR0GFwQVU1HEEnccZRRRHR5RnQGQEAUURtyEPEwQEUVEW2WQVyLBoWIwBwiKEpNPf5497ilQqtdzuW8st6vfmdV9U3+XUr6o7deqce87vyDYhhBBCJw31OoAQQgjPfVHZhBBC6LiobEIIIXRcVDYhhBA6LiqbEEIIHReVTQghhI6LyiaEEELHRWUTQgih46KyCT0n6WWSHpN0uaTbJd0paYNexzUWkizpr5KOz3l+W16zpMskLZd0xdijDqF7orIJHSVpWNLTkl5c59j3JJ1p+7fAzbb3Ar4LfNz2Y92OtQ12sv3pbr5m2/sA7y8c+er4nqzZVkn6vzXnTJZ0uqT7JD0h6UZJB9Sc811JD0p6PFWkh7crxtCforIJHWV7FfAHYG71fknzgTcCn5K0BfBAOrQTcFPNuetK+tRYn1vSl8YVdOPyzpF0RfogrWwn157Xjteczh/X6y7C9rTKBmwGPA38sOa0CcCfgFcBGwD/Apwnaauqc74IbGV7feBNwOcl7drp+EN5Teh1AGEg3ELNBy/wFeA/bD8gaf90DsCWtu+TtC/wVuBJ4HFgI0lfARYAy4DXA7OAr9m+u1KopLnA3wJTgMWSjgOmAd8EBLyj6uctqp5joe3LGr0ASRsBVwJX2P5GJ15zep5xve4OeQuwBPh19U7bfwX+rWrXBZLuAXYF7k3n3Fp9SdpeAFzXuXBDmUXLJnTDrcCLKj9IeiOwLfDvadeLWf3BOzl9A96D7APt22QfVMcBZwNbAofY/iJwUfq52iHAF4A7gdeRffjdDcwAjqr5ufo5Nm/xGvYFLgGeyveSx/WaYfyvey2SLpC0rMF2QY7XcChwtltk65W0KbBdes3V+0+R9BRZK+9BYGGO5wzPUYqsz6HTJL0B+HfbcyUNk3UZfdn2mU2uOZWsYpgGbERWQawHHM/qexTTgC/aHq267l+Av5K1AP4fMAwstX22pCOByVU/Vz/HcbafaRLPMcDPgC8Df067z7f9w3TcwLa2F433NY/3dUt6N3C47Vc0K3ssJD0vPfc2tu9pct5E4ELgf22/r87xYeClwF7Al2yvbFeMob9EN1rohluBbdMH03uAZ8i+rTfzqO0TGhz7eqOLbH8+PTyxzrHa+yvNnqPWCFmrY7/qyq2J8bzmVjE1fN0d8C6yLsNmFc0Q8B1gBVmrcS3p/tUVkt4JfAA4qQOxhj4QlU3ohnvJPmx3AT4LHNzqA9v2sXkKljSJ7D5M5boz8wY1hud4Plm33PNyVjQwjtc8lpjykHQh8MoGh39t+4AGxyDrjmxYEUsScDqwKfC6HC2WCWT3bMKAisomdJxtS7oNOBW42vblbSx7BXBmu8qTdGYq991Vu19Jdp9kkzHE1bHXPIYYmlUmDUl6GdngidpRaNW+AewAvNr20zXXbwLsA1xANprt1cDBaQsDKiqb0C23AO8E3t7rQFqYA5xbs+/lwEHAkKS9qvaf0WwEG/3zmmsdCvzE9hPVO1NL6dfAOcD7yFpuD2WNHADeZ/scsoENHyCraIeA+4CjbS/oTvihjGKAQAhJ6pL7PfCSsd7IlrSc7MP3JNv/pxPxNXjeS4A9gWts79ut5w1hrKKyCSGE0HEDPc9G0hRJ10j6vaRbJX22zjmTJf1A0iJJV9fMkg4hhJDDQFc2ZN0e+9jeCdgZ2F/SnjXnHEY2HHUbsuG0bU2BEkIIg2CgKxtnnkw/Tkxbbb/igcBZ6fGPgH1VdUc0hBBCawM/Gi3NcL4O2AY42fbVNadsQZZ0ENsjkh4jm9m9tKacI4AjANZdd91dt9t+u06HHkLoYzdcf8NS2xsXKUMzp5gVTaZvPbHyItv7F3mOdhn4yibNcN5Z0nTgp5J2tH1Li8vqlXMacBrAvF3n+Te/+U17Ay0pr9UQHBsRjcQwmKauM/W+woWsHEUv3bThYV+8eGbh52iTge5Gq2Z7GfALoPZbwP1kcy+QNIEspfrDXQ0uhBDqEkMThhpuZVKuaLpM0sapRYOkdYDXkGWorbaAbJIbwN8Dl7XKghtCCF0h0JAabmUy6N1os4Cz0n2bIeA82xdI+hxwbZrxfDrwHUmLgEfIZpKHEELPSTA0YbjXYeQy0JWN7ZvIEiXW7v9M1ePlZItZhRBCyZSvBdPIQFc2g67ozX2A5aN51xKrb0IJ/gQnMrl4IQPdIR16RYLhkt2baaRrUUqaI+kXkm5Ls/U/0uC8vSTdmM75ZdX+/SXdkWbyH1O1f+s0s39Rmuk/Ke1vOPNf0rFp/x2S9svxHEelfZZUmtEdIYQBJ2KAQB0jwMdtzyVLHHhkWi/+Welm/SnAm2y/iNR9le6pnAwcQLau+8FV134JODHN8H+UbMY/NJj5n647iGzJ3v2BUyQNt3iO35ClSS8+VDGEENqm8eCAsnWvda2ysf2g7evT4yeA28kmTFZ7B1lq8z+m85ak/bsDi2zfndYvORc4MM3k34dsZj9kM/3fnB43mvl/IHCu7WfSKoSLUvl1nyPFcYPte9vzToQQQntIMDRxqOFWJj2JJnVp7QLUztbfDpgh6XJJ10k6JO1/dhZ/sjjt2whYZnukZv8a16TjlZn/jcpqtD+EEMophj43Jmka8GOyxZQerxPPrsC+wDrAlZKu6nKI41KdrmbOnDk9jiaEMBhUeOhzun3xLWBHstyQ7wXuAH4AbEW2xPnbbD9a5Hm62rKRNJGsojnH9k/qnLIYuMj2X20vBX4F7ETVLP5kdtr3MDA9zeyv3g+NZ/43KqvR/lxsn2Z7vu35MzeOMQQhhC5oT8vm68DPbL+Q7PP2duAY4FLb2wKXpp8L6eZoNJFNkLzd9lcbnHY+8ApJEyRNBfYge+G/A7ZNI88mkd3gX5Bm8v+CbGY/ZDP9z0+PG838XwAclEarbQ1sC1zT6Dna9fpDCKHdVHA0mqQNgL8h+2zG9oqUuqv6nnf1vfBx62Y32suBdwE3S7ox7fsUsCWA7VNt3y7pZ8BNwCjwrUpSTElHARcBw2Rrv9+ayvgkcK6kzwM3kN40Gsz8t32rpPOA28hGyB2ZknE2fA5JHwb+GdgMuEnSQtuHt/sNCiGEsWnZgpkp6dqqn09LSYMrtgb+Anxb0k5kGfA/Amxq+8F0zkNA42yfeSONNF/t1y9Zn2NSZyYmdYZemLrO1Otszy9SxsTN1vXMd85tePyh/7i26XNImg9cBbzc9tWSvg48DnzI9vSq8x61PaNIrL3/lx7GxSuLVxSP6ZHCZTw9+mTrk5qYOWGzwjGs9MpC108cbkNlE0IPVLrRClgMLK5ax+tHZPdn/ixplu0HJc0CljQsIaf4PhZCCH1LDA0NNdxasf0Q8CdJ26dd+5LdYqi+5119L3zcBrplI2kOcDZZf6TJ+jO/XnPOP5DdFxLwBPAB27/vdqwhhFBLgonFsz5/CDgnDYy6G3gPKQu+pMPIMqe8reiTDHRlw+oUOtdLWg+4TtIltm+rOuce4FW2H5V0ANlqnHv0ItgQQqgmxHCOFkwztm8E6t3X2bdQwTUGurJJoy0eTI+fkFRJoXNb1Tm/rbrkKrL5NyGE0HMSTJwY69n0lSYpdKodBlzY4PrIIBBC6C4p172ZMojKhpYpdCrn7E1W2byi3vE0dv00yIY+dyjUEEJ4lmjLPZuuGPjKJkcKHSS9hCx30AG2H+5mfCGE0IikqGz6QZ4UOpK2BH4CvMv2nd2ML4QQmpGIbrQ+0TKFDvAZsqUJTsnqJkaKzvoNIYR2kBQDBPqB7SvIuj2bnXM4ULo8aMu0tHAZI88uAzR+04anF7r+qdG/Fo5hSMX+sRVNuQMwZWhq4TJCph1plIoaGV1RuIyJQ93JTFF06HO3DHRlE0II/ayf7tn0R5XYQZLOkLRE0i0Njs+Q9FNJN0m6RtKO3Y4xhBDqUcF0Nd1Urmh640xg/ybHPwXcaPslwCFkCw2FEELPVdLVNNrKZOArG9u/IlvvppG5wGXp3D8AW0kqvLZDCCEUpixdTaOtTMoVTTn9Hvg7AEm7A8+jTsoaSUdIulbStUv/UvzmfQghtFJJV9NoK5OobFo7AZiehkZ/iGw10FW1J9k+zfZ82/NnbjyzyyGGEAaRUN90o8VotBZS+pr3wLOTQO8hS8MdQgg91U+TOvsjyh6SND2t8wDZfJtfNcqfFkII3SSJSRMmNtxyljEs6QZJF6Sft5Z0taRFkn5Q9flXyMBXNpK+D1wJbC9psaTDJL1f0vvTKTsAt0i6AzgA+EivYg0hhGpCDGuo4ZbTR4Dbq37+EnCi7W2AR8kSEBc28N1otg9ucfxKYLu2P+/KYrOkH3rmgcIxjIwWzyAwc0qx+1MT2vClaSLFypiofN8Am/nrquKN3anD6xUu47lgVRsyW6zyWrdVx2SoeWKRnDEUfx2tVFo2Ba6fDbweOB74WLpVsA/wjnTKWcC/Ad8oFmlUNiGE0NeGh5oOBJgp6dqqn09Ly6FUfA34Z6DyTWcjYJn9bE25mGxBycIGvrKRdAbwBmCJ7bWyA0jaCzifbGAAwE9sf65rAYYQQgNDEpOGm7ZsljZKHCyp8rl3Xfqc66iBr2zIMgj8J3B2k3N+bfsN3QknhBDyUpHJmy8H3iTpdcAUYH2yDCnTJU1IrZvZwP3tiHTgBwjkyCAQQgilpNSyabQ1Y/tY27NtbwUcBFxm+x+AXwB/n047lKxnp7CBr2xyeqmk30u6UNKL6p0QGQRCCN02RPGhz3V8kmywwCKyezintyPW6EZr7XrgebafTM3N/wa2rT0p3XQ7DWDervN6vyBHCOG5Ty0HCORi+3Lg8vT4bmD3woXWiJZNC7Yft/1kerwQmCgp8tGEEHpOjL8brduiZdOCpM2AP9t2SsQ5BDzc47BCCAGp0ACBrhr4yiZlENiLbDz6YuBfgYkAtk8lu1H2AUkjwNPAQbajmyyE0HNFJ3V208BXNjkyCPwn2dDoEEIoFcFY0tL01MBXNr2yaOVtha5/fEXx9ChbTtuycBlLli8pdP2KVSsKxzBpuFi6mi3WmVM4hvWGpxcu46bHr219UhN/eOSOwjEU/eDafsb2hWOYtU7xCevDKnbTXG24nT1laJ3CZbTSTy2b/qgSO0jSGZKWSLqlwfEXSrpS0jOS/qnb8YUQQiP9NEBg4CsbsgwC+zc5/gjwYeArXYkmhBByygYIDDfcymTgu9Fs/0rSVk2OLwGWSHp996IKIYTWhJgw1B8f4/0RZQghhLqGYoDAYJF0BHAEwJw5xW84hxBCK1L/tGz6o0rsA7ZPsz3f9vyZG0eCgRBCdwxpqOFWJv1RJYYQQliLEBPUHx/j/RFlB7XKIJDS1VxLttbDqKSjgbm2i090CSGEAkTcs+kbOTIIPES2gFAIIZRLwXs2kuaQLRy5KWCyZaO/LmlD4AfAVsC9wNtsP1ok1IGvbDrCwGjzU+5+/O5CT/HUyqcKXQ8wffL0wmUUzQBw/m0XF47h5c+fV+j6dnRDDE0p/u1y7rSXFLq+HZkQnvHywmUUtXy0+N/2pKHJxa7XlMIxTFSxzBZ5tKEbbQT4uO3rJa0HXCfpEuDdwKW2T5B0DHAM2To349Yf7a8QQghrqXSjjXeAgO0HbV+fHj8B3A5sARwInJVOOwt4c9FYB76ykbS/pDskLUo1eO3xLSX9QtINkm5KC6iFEEIJZN1ojbYxlZRNbt8FuBrY1PaD6dBDZN1shQx0ZSNpGDgZOACYCxwsaW7Naf8CnGd7F7J1uk/pbpQhhFCfpFYtm5mV5erTdkSDcqYBPwaOrh38lJZUKbysyqDfs9kdWJSWQUXSuWTNx+qUzCYbiQawAfBAVyMMIYQGRMt7jkttz29ahjSRrKI5x/ZP0u4/S5pl+0FJs4Bi6d0Z8JYNWd/kn6p+Xpz2Vfs34J1pWPRC4EP1CpJ0ROXbw9KlSzsRawgh1GjZsml+tSTgdOB221+tOrQAODQ9PhQ4v2ikg17Z5HEwcKbt2cDrgO9Ia/8W18ggMDMyCIQQOk/F79m8HHgXsI+kG9P2OuAE4DWS7gJenX4uZNC70e4HqseLzk77qh1GWoLA9pWSpgAzaUOzMoQQClGxSZ22r8hKqWvfcRdcx6C3bH4HbCtpa0mTyAYALKg554+kN13SDsAU4C9djTKEEOqozLNptJVJuaLpMtsjko4CLgKGgTNs3yrpc8C1thcAHwf+S9JHyQYLvDuNzgghhJ4SxZfA7paBrmwAbC8ku/Ffve8zVY9vI+vXzG1k+QhLbnu46TnLpxebqf2Kzf6m0PUAty2ruxL2mJx4yXcKXb/fTnsUjmH9Seu3PqmJKROKzxZf4Wd6Xsa04WLvA8DZN32v0PUPPV58cMzH9vxA4TKmDE0tdH07Zv+PelXhMloTdW4hl9LAVzYhhNDPhumPlk1/VIkd1CqDQNV5b5FkSU3HrIcQQreoxX9lMtAtm6oMAq8hm2PzO0kLUtdZ9XnrAR8hS+MQQgjlIBjqk3s2g96yeTaDgO0VQCWDQK3jgC8BvU+JG0IIVfqlZTPolU3LDAKS5gFzbP9Ps4KqMwg88ugj7Y80hBBqCDGs4YZbmQx6ZdNUyhTwVbLhz01VZxDYcMaGnQ8uhBAQQww33MpkoO/Z0DqDwHrAjsDlWQohNgMWSHqT7Wu7FmUIITSQPptKb9Arm2czCJBVMgcB76gctP0YWWoaACRdDvxTVDQhhDIQMfS5L9geASoZBG4nW7fmVkmfk/Sm3kYXQgitCDHUcCuTQW/ZtMwgULN/rzxljkxaycNbLW56zr3/W5vvc2x2nvlkoeuhWAK/iou/f2Wh6zffuPj9rc032KRwGUW9aIOXFC6j6IeDi69vxdE7faTQ9fcsv7NwDBM0sXAZk7VOoetHvKJwDENDkwuX0UplWeh+MPCVTQgh9C+VrgXTSH9E2UGtMghImizpB+n41Wmd7hBC6LlKIs4iQ5/zZlEpaqArm6oMAgcAc4GDJc2tOe0w4FHb2wAnkk3uDCGEEiiWribnZ2BbtKxsJH1MUu1Syc8VeTIIHAiclR7/CNhX/TLWMITw3JbS1TTacsibRaWwPC2b9YCLJf1a0lGSNu1EID3SMoNA9Tlp9NpjwEa1BVVnEHj04WWdiTaEEKrIYshDDTdgZuVzKW1H1BSR5zOwLVoOELD9WeCzkl4CvB34paTFtl/diYD6le3TgNMA5u68QyyuFkLoOGNarOW41HYpMtWPZTTaEuAh4GGg92NN26NVBoHqcxZLmgBsQPYehBBCz3lVoe+2eT4D2yLPPZsPppnzl5J1H/2j7eKTCsrh2QwCkiaRZRBYUHPOAuDQ9PjvgctiWegQQikYbDfccsjzGdgWeVo2c4Cjbd/YiQB6yfaIpEoGgWHgjEoGAeBa2wuA04HvSFoEPEL2ywghhFIo0rJp9BnYrtiq5blnc2wnnrgsWmUQsL0ceGu34wohhJYMRftZ6n0GdkJkEOiA4eUTWf/OWU3P2WKjYre9rnqo+KKh9ywt3jU7a5fNC10/abh4apJRjxaLYWhS4RjaYRWrCl0/5OIj8peMPFDo+o0nbVY4hokq/vsomm5mkoqnmunGCprGeFWxv/9uicomhBD6WL/cQR70DAKSdFJK03BTWpWz2fkLJN3SrfhCCKEpZ/dsGm1lMugtmwOAbdO2B/CN9P+1SPo7oHiq5RBCaBfTN91oA92yIUvLcLYzVwHTJa11s0XSNOBjwOe7HWAIITRism60RluZDHplkzdVw3HAfwBPNSqoOl3NI8seaW+UIYRQV+MutLJ1ow16ZdOSpJ2BF9j+abPzbJ9me77t+RtOL74gWAghtFR8UmfXDNw9G0lHAv+YfvwdrVM1vBSYL+lesvdrE0mX5121M4QQOqlsLZhGBq5lY/tk2zvb3hn4b+CQNCptT+Ax2w/WnP8N25vb3gp4BXBnVDQhhFIwMOrGW4kMXMumxkLgdcAisvsx76kckHRjqpBCCKGUDIyWrFJpZKArm5RQ88gGx3aus+9eYMdW5Y6OjvLUE880P2mtFXHG5rGnnyhWAHDd3X8oXMZx735voes3Xbd4AvHlq5YXun7OulsWjmHEKwuXse7QtELXP+2G41dymzpcLIZ1NLVwDMMq/rFkFfsAbkcMXdMfI58Hu7IJIYS+ZjMa82zKL28GAUkHS7o5nfMzSTO7HWsIIdSyYdXIaMOtTAa6smHNDAJHkGUQWENaMO3rwN5pHZ+bgKO6GWQIITQyajfcymTQK5s8GQSUtnUlCVgfKJYaN4QQ2sB2x1o2kr4s6Q+pR+enkqZXHTs29QjdIWm/POUNemXTMoOA7ZXAB4CbySqZuWQLqq2hOoPAo4892rmIQwihikfdcCvoEmDH1KNzJ3AsgKS5ZItIvgjYHzhFar2ewqBXNi1JmkhW2ewCbE7WjbbWgnLVGQRmbDCjy1GGEAZSB+/Z2L7Y9kj68SqySe+Q9Qida/sZ2/eQTR3ZvVV5A1fZSDpS0o2SbgQepHUGgZ0BbP9vGip9HvCyLoQaQghNmcb3a9I9m5mVHpe0HTHOp3ovcGF6nDen5BoGbuiz7ZOBkwEkvR44StK5ZEsLrJVBgKzymStpY9t/AV4D3N7NmEMIoS7DaPMWzFLb8xsdlPRzoN7yqp+2fX4659PACHBOkVAHrrKp0TKDgO0HJH0W+JWklcB9wLt7EWwIIVSrDH0e//V+dbPjkt4NvAHY16sze95P6x6htQx0ZZM3g4DtU4FT85Y7YdIENn3e9KbnvHRWsZ64Pz5xX6HrAbbfe5vCZRSdvT9hqPif4PPXfX6h69ux3nw7PDyypNchMHloSqHrh4Za3iduSSreuz+ECpfRH9yxdDWS9gf+GXiVvUZ6igXA9yR9lew+9rbANa3KG+jKJoQQ+pkNqzqXQeA/gcnAJdmsD66y/X7bt0o6D7iNrHvtSNurWhU2cAMEKiS9UNKVkp6R9E9NzjsqjSd3ZA4IIZRNp4Y+297G9pxKlnzb7686drztF9je3vaFzcqpGOSWzSPAh4E3tzjvN8AFwOUdjieEEMakMqmzHwxsZWN7CbAkjUhrdt4NAKkZGUIIpdKGyZtdMbCVTbul8etHAMzefHaLs0MIoQ06e8+mrQb2nk27VWcQ2HBGwcVqQgghh8riaY22MhmoyqY6e4CkzXsdTwghFNLBRJztNlDdaNXZA0IIod9lkzpbjjouhYFq2VSTtJmkxcDHgH+RtFjS+unYwkrLR9KH03mzgZskfat3UYcQQhU37kIrWzfaQLVsqtl+iNVZTGuPva7q8UnASWMpe2hYTN6g+az0ey4eaXq8lc32rZfOaGyeGim+Zn3RMqZOKL5m/awpxQZkqA2zzVd6ReEyimYyGFbxf87ThtcvdH073suQn+mfls3AVjYhhND3DF5VrhZMI4PcjZY3g8CZku6pGliwcxfDDCGEhmwzMrKq4VYmg9yyyZtBAOATtn/U2XBCCGHsYlJnyeXNIBBCCGWVpaspVwumkYHtRhuj4yXdJOlEqST56EMIARgdHW24lUlUNq0dC7wQ2A3YEPhkvZMkHVFZenXpww93M74QwoByH03qHKjKZjwZBGw/6MwzwLeB3Ruc92y6mpkbRbqaEELn2XR8gICkj1cvsaLMSWnplZskzctTzkDdsxlPBgFJs2w/qCzt85uBWzoRWwghjJ1xB7vLJM0BXgv8sWr3AWSrc24L7AF8I/2/qYFq2VTLm0EAOEfSzcDNwEzg872JOIQQahhWrVzVcGuDE8mWhq4e8nYgcHbq8bkKmC5pVquCBqplU20MGQT26VpQIYQwBjat0tLMlHRt1c+n2T4tT9mSDgTut/37mvW8tgD+VPXz4rTvwWblDWxl00maICbPmNT0nGkbTCn0HOtOKJ4WZMJQ8V//lAnFXscGE2YUjqEMKVKGNVy4jPWWF3svtG7hEAq/l0NteB9CfjmGPi+1Pb/RQUk/B+rlvvo08CmyLrS2iMomhBD6WJGEm7ZfXW+/pBcDWwOVVs1s4HpJuwP3A3OqTp+d9jU1yPds8qar2UfS9ZJukXSW1IZshyGE0AaVlk2jrUC5N9vexPZWtrci6yqbl24/LAAOSaPS9gQes920Cw0GuLJhdbqarzQ6QdIQcBZwkO0dgfuAQ7sTXgghtND5AQL1LATuBhYB/wV8MM9FA/stPWe6mo2AFbbvTD9fQjbJ8/ROxxdCCK0Zr+r85M3Uuqk8NnDkWMsY5JZNHkuBCZIqN9j+njX7Kp+1RgaBvyztWoAhhMHlUVi1YlXDrUyismki1eAHASdKugZ4Aqj7G1wjg8DGM7sZZghhYBmPNt7KZKC60SQdCfxj+vF1th9odY3tK4FXputfC2zXuQhDCCE/26xaUWzV324ZqMpmnOlqNrG9JGV7/iRwfEeCCyGEseqjlToHqrKpJmkz4FpgfWBU0tHAXNuPS1oIHJ5aPp+Q9AayLsdv2L6sZ0GHEEIVp9Fo/WBgK5sxpKv5BPCJdj//C15e96lze/iORwvHsP626xQuw8PFvlUNqfhtw+zW2viN1r8NNyYTHyj+Xg5tUuy9aMd7GfqMuzMarR0GtrIJIYS+10ctm4H9KiTpH9JaDDdL+q2knRqcd46kO1IGgTMkTex2rCGEUE82QCCGPpfdPcCrbL8YOA5olAn1HLKVOl8MrAMc3p3wQgihNa8abbiVycB2o9n+bdWPV9H4/s3CyuM016bYzZYQQmgT29GN1mcOAy5sdkLqPnsX8LMGxyODQAihu9LQ50ZbmQxsy6ZC0t5klc0rWpx6CvAr27+udzAtSHQawLxd55XrtxxCeE7KWjYxqbN0ajMIkC3z/C3gANsPN7nuX4GNgfd1PMgQQsjLMFqyFkwjA1XZVGcQkLQl8BPgXVVZndci6XBgP2Bf2+W64xZCGGw2oyUbddbIIN+z+QzZEgKnSLqxep1uSQslbZ5+PBXYFLgynfeZHsQaQghrMTA6OtpwK0rShyT9QdKtkv69av+xkhalaSH75SlroFo21WwfToNhzDUZBEr5Hs3YeoPCZax8bGXhMkZnFOsvHnXxb2UrKfY6Ji+dVjiGqVsWzyAQwljZZmRVZ+7ZpPvZBwI72X5G0iZp/1yybPgvAjYHfi5pO7v5P+ZSfpCGEEJozZiVq4p/aWzgA8AJtp+BZxechKwCOjftv0fSImB34MpmhXWlG20Ms/Ul6XhJd0q6XdKHq/aflJptN0maV3XNoZLuStuhVft3Tc+3KF2rtH9DSZek8y+RNCPHc/xM0jJJF3TqPQohhDFzy260mZUpGWk7Ygylbwe8UtLVkn4pabe0fwvgT1XnLU77mupWy6YyW/9RSQeQDRHeo8557yZbCfOFtkcrzTbgAGDbtO0BfAPYQ9KGwL8C88m6L6+TtMD2o+mcfwSuJlsze3+yuTTHAJfaPkHSMennTzZ6jvT8XwamEqPRQgglYlp2oy21Pb/RQUk/Bzarc+jTZPXDhsCewG7AeZKeP95Yu1LZ5J2tT9Zse0dl1FdNs+3stHLmVZKmS5oF7AVcYvsRAEmXAPtLuhxY3/ZVaf/ZwJvJKpsD03UAZwGXk1U2dZ/D9oO2L5VUuSaEEMrBZnR0/Pc9bb+60TFJHwB+kj4Tr5E0SjZd5H6yRkHF7LSvqV6MRms2W/8FwNtTc+9CSdum/Y2abc32L66zH2BT2w+mxw+RjTRr9hy5RAaBEEK3VVo2jbaC/hvYG0DSdsAkYCmwADhI0mRJW5P1Bl3TqrCuDhDIMVt/MrDc9nxJfwecQVqSuRNsW1JbZkRFBoEQQtelezYdcgZwhqRbgBXAoamVc6uk84DbgBHgyFYj0aCDlc04Z+svJptoCfBT4NvpcaNm2/2s7hKr7L887Z9d53yAP1e6x1JXXKWrblxNwxBC6JVOjkazvQJ4Z4NjxwPHj6W8jnWj2T7Z9s62dyar1FrO1qeq2Qa8CqicuwA4JI0Y2xN4LHWFXQS8VtKMNKrstcBF6djjkvZMo9AOAc6vKqsyau3Qmv31niOEEErJNiMjIw23MulWN1r1bH2AkcoICUkLgcNtPwCcAJwj6aPAk6yedLmQrHW0CHgKeA+A7UckHQf8Lp33ucpgAeCDwJlka9BcyOr7RCeQjao4DLgPeFuz50gx/ppsTZtpkhYDh9m+qPjbEkII42dgtE+yaKno+u1hbfN2neff/OY3vQ6jJa8s/rsfGV5R6PpVtCGv0yPFGugaLt7AnzxjUuEywmCZus7U65oNS85j+vBG3mvq/g2Pn//k9wo/R7tEBoEQQuhb7uQAgbYa5EScSDowZQu4MQ1brjtKrlE2ghBC6CUbVq4aabiVyUBXNsClZEnmdgbeSzZarp5KNoJKhoHG7dYQQugadzTrczsNdDea7SerflyX7H7bGtLw6EbZCEIIoWeyrM8dS8TZVgNd2QBI+lvgi8AmwOvrnNIsG0EIIfRMZT2bfjDwlY3tnwI/lfQ3wHFAw1xBzaRsqpWMqs9MXWfqLQVDm0mWGqKXZUQM7SujDDG0o4yIoX1lbF/w+XmSxy66nP+Z2eSU8uTOsj1QG3AkcGPaNq85djcws2bfLOAPVT8fDHyzxXNc24Y4e15GxBCvI2Io9+vop23gBgh4zcwGU6vWuZlHlpvt4Zrzm2UjCCGEkMOgd6O9hSxFzUrgaeDtTl85JN2YKiRonI0ghBBCDgNd2dj+EvClBsd2rnp8LbDjGIo+rVhkpSkjYmhfGWWIoR1lRAztK6MdMfSNSFcTQgih4wbunk0IIYTui8omhBBCx0VlE0IIoeOisgmhgyRtKGnDXsfRLmmKQC+ff/2UGHdGwXKaTYTMc/0mRa4fRFHZFCRpgqT3SfpZyiB9k6QLJb1f0sQC5Z49hnM3lPQZSYenlUY/LekCSV/O+49S0t9WPhQlbSzp7JTp+geSZue4fmbNz+9MGbKPKJIlW9Jl47hmP0mHSdqqZv97xxtHuv4zOc/bUtK5kv4CXA1cI2lJ2rdVi8vzlH9zjnPmpOf7taRPVf8tSvrvnM8zr2bbFVggaZc8lU71+y1ptqRLJS2T9FtJ2+WM4buVvy1J+wG3kI0gvVHSW3OWcYCkeyRdkWK/Fbha0mJJ++a4fsOabSOy3+mMsX6RkLRp1fu56Viu7XcxGq0gSd8HlgFnsTqH2myyJac3tP32HGUsqN1Ftjz2ZQC239Ti+oXAzcD6wA7p8XnAa8iyWh+YI4bbbM9Nj38AXAX8kCx9zz/Yfk2L66+3PS89/hfglcD3gDcAi21/NEcMN9XuArYD7gCw/ZIcZXwBeAVwPfBG4Gu2/29tjOMh6Y+2t8xx3pXA14Af2V6V9g0DbwWOtr1njjL+rtEh4FTbG7e4/hLgx2S/x8OAXYE32n5Y0g22d8kRw2i6/pmq3Xumfba9T4vrq/8mzgN+TpZZ/UDgKNt5Puhvtv3i9Pi3wDts35sqoEtt75SjjBvJMn9MBy4AXm/7Kkk7AOe0+ptI78N9Nbtnk/17t+3n54hhZ+BUYAPg/qoylgEftH19qzL6Xq9TGPT7Btw5nmM1510PfBfYC3hV+v+D6fGrclx/Y/q/gPvrHctRxh1Vj68baxnADTWvZ930eCJwc84YFqT34YXA84CtgD+lx8/LWcbNwIT0eDrZct8n1sbY5PrHG2xPkC1nnieGu8ZzrOa8lWQTib9dZ3si799E1c/vBG4FXgBcnzOGtwC/BA6o2ndPnmsrfwdN4mn5u0jn3UqWdR3gCmCo+tg44vhTs/epwfUfB34GvHg870PleYA96uzfE/j9WMrq122gJ3W2ySOpOf9jO1sMXNIQ2bfYR3OWMR/4CPBp4BO2b5T0tO1f5rx+KHWXrQdMk7SVs29/GwF51yu+XNLnyDJgXy7pb23/VNLewGM5rl9H0i5kXbPDtv8KYHulpFxrP9t+k7Is3KcBX7G9QNJK27XfKpuZYHsklbdM0huB0yT9kHzvxTJgN9t/rj0g6U85Y7hO0ilkrd3KNXPIWrs35CzjJrL3YK2ErpLyJIudKGmK7eUAtr8r6SHgIrLlNFqy/WNJFwHHpS6xj1NnGY4mZks6iexL0MaSJtqu5MPP28X8WeAXkk4GfgP8MPUE7E1WAeSxTNL7yFr+j0r6KFnL/9XAk02vBGz/R2rtn5j+Bv6Vsb0PkH35urpO2VdJyvX76Hu9ru36fSP79v0D4C/AnWlbkvZtPcayZpN1XZ0M/HEM1x0M/DltbyHrrriErLl+RM4yJgL/BvwxbaNk3+a/B2yZ4/pf1Gyz0v6NGGPCQbIPw6+S5aBbPMZrL6BOaxD4PDCa4/rPA7s3OPalnDFMAj5A9mF4c9ouJEt7NDlnGa9s9L4D83Nc/9EG78MuwCXj+DvfJf1el4zhmkNrthlp/2bAF8ZQzjZk92l+Cvw/ssUM9xvD9XOAb6brNkvvzS3A/wA7jPF9OJCsG/GhMV53Unq+twMvS9vb077/HOvvox+3uGfTRqklge2HW53bopzXAy+3/akxXDNMdg9uRNIEYGeyLrUHx/H8G5C1EAq9jqq4Jtt+ahzX7gS81PapY7hmHQDbT9c5toXt+9e+KuSRBnqsZ/vxXsfSS+lv7AWu0+pscd0BZJVVZT2s+4EFthe2OcRSisqmgyRtZvuhnOcK2J01/xCvcfyCnlMkvcH2Bb0sI2IYexlpJNybWfPf5/m283blDbwY+txZp+c5SdJrgbvIurFel7bPAnelY+MmqfAol6JllCGGdpTRjhiA3UpQRsQwhjIkfY3snuovgX9P2y+BD0v6etEAlC28+JwXLZsSkHQ72Yife2v2bw0stL1DTwIL4ybphdTvMrm9W2VEDO0pQ9KdtteaF5R6I+60vW3eOBqU/z7b3yxSRj+Ilk0HSZqW89QJrJ6jU+1+8o/aacuEsaJllCGGdpRR5HpJnwTOJRuFdU3aBHxf0jHdKCNiaGsZyyXVawHtBizPE0MLK9pQRulFy6aDlH8S4LHA28j+QVQPlT0IOM/2F1tcvzMFJ4wVLaMMMZToddwJvMirh/lW9k8imxvS8ptw0TIihra+jnlkI9nWY/WXwjlkUwKOtH1dqxhalJ/rc6LfxTybgiR9rNEhIFfLxvYXJZ0PvAl4adp9P9nM/dtyFHEm8D7XjOOXtCfZJMCWs6zbUEYZYmhHGe2IYRTYnLVnnc9Kx/IoWkbE0KYy0heMPSRtRlU3XN7BP0C97BjPHgIGIm1NVDbFfQH4MjBS51jubspUqdymlGvJ9iNjiKEdE8aKllGGGNpRRjtiOBq4VNJdrG6pbkk2X+SoLpURMbSxDGXTAV5FVWUj6SLby3LGsCmwH2tP9Bbw25xl9LXoRitIWb6mD9VrSkv6k+05OcrYkmyEyz5kTXORzXa+DDimduBAnetPIktDcjZrdsMdQpZWo+U/qKJllCGGsryOVM4Qaw9l/51TrrRulBExtKcMSYeQZQ24mDW7Vl8DfNZ2y6S5kk4Hvm37ijrHvmf7HbleSB+LyqYgSdsDD9teWrVvM9sPSdrUddKe1CmjHYkbayeMPUA2DyD3hLGiZZQhhnaU0Y4YwnOHpDvI8potq9k/A7i63ki1sLaobDpAY8wuLOmuRjcpmx1rZwydKKMMMbSjjHbEEPpXGmCwm+3HavZvQJaKqdDQ50ER92w6Y6zrt7QjcWPRGDpRRhliaEcZ7Ygh9K/jgeslXcya93xeAxzXs6j6TFQ2nfFfYzz/ELI1Rz5LzaQzcmYhaEMMnSijDDG0o4x2xBD6lO2zlGWa3o/V/z4vB461nTez+8CLbrQQQsghTe6tHvrc8n5sWC0qmxJQlqX5MOok+gNOr52MFkLonpqJvovJulUHa5XNNojKpgTUhqWlQwidoWxZ6UYTfb/pHEtTh6hsSkENEv21OhZC6LwWo0UX2d6m2zH1oxggUA7tWFo6hNAZF0r6H+pP9I31bHKKlk0JSNqKbNnbfcgqFwHTWZ1B4J6eBRdCqDfRd6BW2WyHqGxKRm1aWjqEEMokKpuSUP3Fnc63/YfeRRVCSJkCjiX797kpYGAJ2WjRE8aQjHOgxeJpJdBkcadz8y4QFULomPPIurf3tr2h7Y2AvclGkJ7Xy8D6SbRsSqAdC0SFEDpD0h22tx/rsbCmaNmUQ2Vxp1pjWSAqhNAZ90n6Z1UtD65s2fBPsnp0Wmghhj6Xw9EUXyAqhNAZbweOAX5ZVeE8RJa78G09i6rPRDdaSbRjgagQQiiraNmUh6u2ys/RhRZCCUjajzq5C23HpM6comVTApJeC5wC3MWay85uQ5bo7+JexRbCoJP0NWA7sgwC1bkLDwHusv2RHoXWV6KyKQFJtwMH2L63Zv/WwELbO/QksBBCw/yEkgTcGaNF84nRaOUwgdXfmKrdD0zsciwhhDUtl7Rbnf27Acu7HUy/ins25XAG8DtJ57Jmor+DGP9KnSGE9ng38A1J67H6S+Ec4LF0LOQQ3WglIWku8CbWTvR3W++iCiFUSNqMNVfqfKiX8fSbqGxKRtKGALYf6XUsIYRMyo+2P2t+Gbwo8qLlF/dsSkDSlpLOlbQEuBq4RtKStG+rHocXwkCTdAhwPbAXMDVtewPXpWMhh2jZlICkK4GvAT+qTOKUNEy2eNrRtvfsYXghDDRJdwB71LZiJM0Aro6VdPOJlk05zLT9g+psAbZX2T4X2KiHcYUQsgzs9b6Vj6ZjIYcYjVYO10k6BTiLNUejHQrc0LOoQggAxwPXS7qYNXMXvgY4rmdR9ZnoRiuBtJTAYdRZdhY43fYzvYothPBsl9l+rD1A4NHeRdVforIJIYScUqWzyvbjvY6l30RlUxKS9gbeQtZ9tgq4E/iW7UU9DSyEASdpc+AEsp6HaazOX3gGcHztooehvhggUAKSvkiW1O8qYCXwv2n7oaS39jK2EALfBc6wvQHZCNEfAzuQ3fM+uZeB9ZNo2ZSApJttvzg9ngD80vbLU5P917Z37G2EIQwuSb+3vVPVz9fZ3jU9/oPtF/Yuuv4RLZtyGK1kDiBbHnoYIN18jKGVIfTWXyS9U9IWkj4E3AvPZn2Oz9Cc4o0qhy8AN0i6BLiCNJxS0sbA73sZWAiB95LlLbwI2IPVS7VvCBzbq6D6TXSjlURq2TwfWBT5lkIIzzVR2YQQwjhJeoPtC3odRz+IbrSSk3R9r2MIITRUb1G1UEe0bEIIoQVJL6ROhg/bt/cuqv4SLZsSkbSppHlp27TX8YQQQNIngXPJRoZekzYB35d0TC9j6yfRsikBSTsDpwIbsHp28mxgGfBB29GVFkKPSLoTeFFtpoCU0/BW29v2JrL+Elmfy+FM4H22r67eKWlP4NvATvUuCiF0xSjZ/Lf7avbPSsdCDlHZlMO6tRUNgO2rJK3bi4BCCM86GrhU0l2sucTANqyecxNaiG60EpB0EvAC4GzWXM/mEOAe2/EHHUIPSRoCdmfNAQK/q17wMDQXlU1JSDqANUe7PACcb3th76IKIYT2iMqmpCRdb3ter+MIIYR2iKHP5RUJOEMIzxlR2ZTXf/U6gBBCaJfoRgshhNBx0bIJIYTQcVHZhBBC6LiobEIIIXRcVDYhhBA6LiqbEDpI0m6SbpI0RdK6km6VtGOv4wqh22I0WggdJunzwBRgHWCx7S/2OKQQui4qmxA6LKWi/x2wHHhZ5NMKgyi60ULovI2AacB6ZC2cEAZOtGxC6DBJC8hWetwamBVZvMMgivVsQuggSYcAK21/T9Iw8FtJ+9i+rNexhdBN0bIJIYTQcXHPJoQQQsdFZRNCCKHjorIJIYTQcVHZhBBC6LiobEIIIXRcVDYhhBA6LiqbEEIIHff/AYV+9W9XRmt4AAAAAElFTkSuQmCC\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\\_deep}}, \\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-20T20:30:25.592788Z",
     "iopub.status.busy": "2022-09-20T20:30:25.592614Z",
     "iopub.status.idle": "2022-09-20T20:34:44.427437Z",
     "shell.execute_reply": "2022-09-20T20:34:44.427078Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59ddc25c3321428f8c03683dda44fa66",
       "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 + 1, n_states_x, n_states_v, 2))\n",
    "iterated_v = np.zeros((max_bellman_iterations_validation + 1, 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.reshape((1, -1)))[0]\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T20:34:44.429235Z",
     "iopub.status.busy": "2022-09-20T20:34:44.429054Z",
     "iopub.status.idle": "2022-09-20T20:34:44.439777Z",
     "shell.execute_reply": "2022-09-20T20:34:44.439312Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/PBO_linear_max_linear/{max_bellman_iterations}_Q_{seed}.npy\", iterated_q)\n",
    "np.save(f\"figures/data/PBO_linear_max_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": {
     "0563c969cb8f44f188d6d0f08b84d9ee": {
      "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
      }
     },
     "294f7c13121a44ff9a50c1315692942f": {
      "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_0563c969cb8f44f188d6d0f08b84d9ee",
       "placeholder": "​",
       "style": "IPY_MODEL_faf4b99d0f394d699e7c039356782218",
       "value": "100%"
      }
     },
     "3b646ba793314231963714b481b28f8d": {
      "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
      }
     },
     "42b9225db1c94ef0bf9a17aa7830af38": {
      "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
      }
     },
     "59ddc25c3321428f8c03683dda44fa66": {
      "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_294f7c13121a44ff9a50c1315692942f",
        "IPY_MODEL_729723a513324fbe8acdea12625edc6b",
        "IPY_MODEL_ce214779786d491cb0143daa0c97e1a7"
       ],
       "layout": "IPY_MODEL_42b9225db1c94ef0bf9a17aa7830af38"
      }
     },
     "69700b0120414d3bb7bda24e9e0efca7": {
      "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
      }
     },
     "729723a513324fbe8acdea12625edc6b": {
      "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_69700b0120414d3bb7bda24e9e0efca7",
       "max": 25.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_8bf6b052d6904c55a73343f129505271",
       "value": 25.0
      }
     },
     "8bf6b052d6904c55a73343f129505271": {
      "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": ""
      }
     },
     "ce214779786d491cb0143daa0c97e1a7": {
      "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_3b646ba793314231963714b481b28f8d",
       "placeholder": "​",
       "style": "IPY_MODEL_e28c2617c4a44c25aa4eaf827538aab9",
       "value": " 25/25 [04:12&lt;00:00,  5.21s/it]"
      }
     },
     "e28c2617c4a44c25aa4eaf827538aab9": {
      "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": ""
      }
     },
     "faf4b99d0f394d699e7c039356782218": {
      "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": ""
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
