{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# FQI on LQR\n",
    "\n",
    "## Define paramters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:02.848138Z",
     "iopub.status.busy": "2022-09-19T14:04:02.847980Z",
     "iopub.status.idle": "2022-09-19T14:04:03.456711Z",
     "shell.execute_reply": "2022-09-19T14:04:03.456214Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import jax\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "\n",
    "# Sample collection\n",
    "max_discrete_state = parameters[\"max_discrete_state\"]\n",
    "n_discrete_states = parameters[\"n_discrete_states\"]\n",
    "max_discrete_action = parameters[\"max_discrete_action\"]\n",
    "n_discrete_actions = parameters[\"n_discrete_actions\"]\n",
    "n_samples = n_discrete_states * n_discrete_actions\n",
    "\n",
    "# Q function\n",
    "max_action_on_max = parameters[\"max_action_on_max\"]\n",
    "n_actions_on_max = parameters[\"n_actions_on_max\"]\n",
    "\n",
    "# Trainings\n",
    "fitting_steps = parameters[\"fitting_steps_fqi\"]\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "batch_size_samples = n_samples\n",
    "learning_rate = {\"first\": parameters[\"starting_lr_fqi\"], \"last\": parameters[\"ending_lr_fqi\"], \"duration\": fitting_steps * n_samples // batch_size_samples}\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/FQI/\"):\n",
    "    os.makedirs(\"figures/data/FQI/\")\n",
    "for file in os.listdir(\"figures/data/FQI/\"):\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",
    "env_key = jax.random.PRNGKey(env_seed)\n",
    "seed = max_used_seed + 1\n",
    "key = jax.random.PRNGKey(seed)\n",
    "shuffle_key, dummy_q_network_key, _ = jax.random.split(key, 3) # 3 keys are generated to be coherent with the other trainings"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:03.460335Z",
     "iopub.status.busy": "2022-09-19T14:04:03.460153Z",
     "iopub.status.idle": "2022-09-19T14:04:03.686380Z",
     "shell.execute_reply": "2022-09-19T14:04:03.685832Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Transition: s' = As + Ba\n",
      "Transition: s' = 0.7204725742340088s + -0.5264108180999756a\n",
      "Reward: Qs² + Ra² + 2 Ssa\n",
      "Reward: -0.13297832012176514s² + -0.8039400577545166a² + 0.2581009864807129sa\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.linear_quadratic import LinearQuadraticEnv\n",
    "\n",
    "\n",
    "discrete_states = np.linspace(-max_discrete_state, max_discrete_state, n_discrete_states)\n",
    "state_box_half_size = max_discrete_state / n_discrete_states\n",
    "discrete_states_boxes = np.linspace(\n",
    "    -max_discrete_state - state_box_half_size, max_discrete_state + state_box_half_size, n_discrete_states + 1\n",
    ")\n",
    "\n",
    "discrete_actions = np.linspace(-max_discrete_action, max_discrete_action, n_discrete_actions)\n",
    "action_box_half_size = max_discrete_action / n_discrete_actions\n",
    "discrete_actions_boxes = np.linspace(\n",
    "    -max_discrete_action - action_box_half_size, max_discrete_action + action_box_half_size, n_discrete_actions + 1\n",
    ")\n",
    "\n",
    "env = LinearQuadraticEnv(env_key, max_init_state=max_discrete_state)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Samples on the mesh"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:03.688346Z",
     "iopub.status.busy": "2022-09-19T14:04:03.688211Z",
     "iopub.status.idle": "2022-09-19T14:04:03.920538Z",
     "shell.execute_reply": "2022-09-19T14:04:03.920039Z"
    }
   },
   "outputs": [],
   "source": [
    "import jax.numpy as jnp\n",
    "\n",
    "from pbo.sample_collection.replay_buffer import ReplayBuffer\n",
    "\n",
    "\n",
    "n_samples = n_discrete_states * n_discrete_actions\n",
    "replay_buffer = ReplayBuffer()\n",
    "\n",
    "for state in discrete_states:\n",
    "    for action in discrete_actions:\n",
    "        env.reset(jnp.array([state]))\n",
    "        next_state, reward, absorbing, _ = env.step(jnp.array([action]))\n",
    "\n",
    "        replay_buffer.add(jnp.array([state]), jnp.array([action]), reward, next_state, absorbing)\n",
    "\n",
    "replay_buffer.cast_to_jax_array()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:03.922645Z",
     "iopub.status.busy": "2022-09-19T14:04:03.922512Z",
     "iopub.status.idle": "2022-09-19T14:04:04.619131Z",
     "shell.execute_reply": "2022-09-19T14:04:04.618761Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATsAAAEYCAYAAAAj5FFfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAwpklEQVR4nO2deZicVZX/P1+ysYYAQfZNwAEUDcqmMLIpiwvigAiMQhRFUUEU/DHouCGoqDMowqCRJQrIIvsIiAgBRiGRADGRRbaAEHZI2Akk/f39cW+FN5Xau7q6q/p8nuc+XXXvfc976q3u03c59xzZJgiCoNdZarAVCIIg6ARh7IIgGBaEsQuCYFgQxi4IgmFBGLsgCIYFYeyCIBgWhLHrQSR9R9LZg63HQCPp65JOq9H+75L+2EmdgqFLGLs2Iml7STdJek7Ss5L+ImmrwdarF5C0o6RHinW2v2/7M7l9fUmWNLLQfo7tXTutazA0GVm/S9AIksYCvwcOBS4ARgP/CswfTL0GCkkjbS/o1L06cZ+gt4mRXft4C4Dtc20vtP2K7T/angkgaUNJ10l6RtLTks6RNK50saQHJX1N0kxJL0k6XdJqkq6S9IKkP0laKfctjWIOkfSopMckHVVNMUnb5hHnPEl/k7RjoW2ipAfyPWZL+vcqMr4j6UJJZ0t6HpgoacWs52OS5kg6TtKIgty/SDo5j3TvlrRLQd6nJN2V7/uApM8V2naU9IikoyU9DpwLXAWsKenFXNYsm67fmH/Oy+3vzjr8uSD3PZJuyfrcIuk9hbbrJX0v6/yCpD9KGl/zGw+6ijB27eMeYKGkX0vao2SYCgj4AbAmsCmwDvCdsj57A+8nGc4Pk/7Avw6sSvquDi/rvxOwMbArcLSk95UrJWkt4ArgOGBl4CjgIkmrSloOOAnYw/YKwHuAGTU+40eAC4FxwDnAZGABsBGwRdbjM4X+2wD3A+OBbwMXS1o5tz0JfAgYC3wKOFHSOwvXrp71XQ84ENgDeNT28rk8Wqbbe/PPcbn95rLnsHJ+DicBqwD/DVwhaZVCtwOyLm8ijcyr/gMJuo8wdm3C9vPA9oCBXwFPSbpc0mq5/T7b19ieb/sp0h/bDmVifm77CdtzgP8Dptm+3farwCUkg1Lku7Zfsj0LOBPYv4JqnwCutH2l7T7b1wDTgQ/k9j7gbZKWsf2Y7TtqfMybbV9qu49kpD4AHJF1eBI4Ediv0P9J4Ke2X7d9PvAP4IP5eVxh+34nbgD+SJr2l+gDvp2f1ys1dGqUDwL32j7L9gLb5wJ3k/6plDjT9j35fhcAE9pw32CIEMaujdi+y/ZE22sDbyON4n4KkKek5+Xp3vPA2aQRT5EnCq9fqfB++bL+DxdeP5TvV856wMfyFHaepHkko7yG7ZeAjwOfBx6TdIWkTWp8xOL91gNG5etKcn9JGhWVmOPFI00s0jGPfqfmjZx5JMNZfB5PZSPfLtbM9y/yELBW4f3jhdcvs+TzDrqYMHYDhO27SdO8t+Wq75NGfZvbHksacamft1mn8HpdoHxqB8lAnWV7XKEsZ/uHWc+rbb8fWIM00vlVjfsVDdfDpM2X8QW5Y22/tdBnLUnFz7gu8KikMcBFwE+A1WyPA65k8edRHo6nXnieeu2Pkgx0kXWBOXWuC3qEMHZtQtImko6UtHZ+vw5pWjk1d1kBeBF4Lq+jfa0Nt/2mpGUlvZW01nR+hT5nAx+WtJukEZKWzhsAa+fR5kfy2t38rF9fIze2/Rhp6vlfksZKWkppE6Y4NX8TcLikUZI+RlqrvJK0HjYGeApYIGkP0npfLZ4AVpG0YpX2p7Lub67SfiXwFkkHSBop6ePAZqQd9LoobSBNbKRvMDQJY9c+XiAtyE+T9BLJyP0dODK3fxd4J/AcaaH84jbc8wbgPuBa4Ce2l3Cgtf0waWPh6ySD8DDJ0C6Vy1dJo55nSWuIhzZx/wNJhutOYC5p82KNQvs00gbK08DxwD62n7H9Ammz5YJ83QHA5bVulEfK5wIP5GnzmmXtL+d7/CW3b1vW/gxpQ+RI4Bng/wEfsv10vQ8paTRpU2Nqvb7B0EURvLP7kLQ+MBsY1Slft2bJo6DP2N5+sHXpL5K2B75ou9IGUNAlhLNmENTB9p+BP9ftGAxpYhobBMGwIKaxQRAMC2JkFwTBsCCMXdAWJP1C0jdrtFvSRm2612RJx7VJ1vWSPlO/Z9DthLFrEEkrS7pE6ZD+Q5IOKLS9Q9IdSgf8v1qoHyVpWva56zqaMQS2P2/7ewOgw2KH+YOgVWI3tnFOAV4DViOdmbxC0t/yWdIfkA6NzwRmSvqt7cdJPmwXZV+3tiBphO2F7ZIXBMOFGNk1QD5hsDfwTdsvZleEy4FP5i4bANflA/z3AutKWi9fc2ID8n8n6fEceujGfCKi1DZZ0qmSrszOyjsphTe6SNJTSmGZyqOhFGWvKOk3ue9Dkv5T0lK5bbGIxioEwJR0POlg/slKIZNOVuJESU9Kel7SLElvK+h5XEHW15RCPz0q6dNlOo2R9BNJ/5T0RJ4CL1NB902BXwDvzjrMKzSvpHSW94U8et6wcN0mkq5ROnf7D0n71vkKNpT01/yZLtMbkVmQtGcetc/LI91Nc/3R+b4j8/tDc7+l69wrGCxsR6lTSNFGXi6rOwr43/z6d6ToGWuTDpOvAlwK7NCg/E+TjpONIQUOmFFom0w6dbEd6Z/TssCtwLdIpxfeDDwA7FZF9m+Ay7L89UmhqA7Obd8Bzi70XZ90xnRkfn89yTG41L5bvvc40jnWTUkBBUp6Hpdf70463vU2YDngt1nuRrn9RNI/i5WzXv8L/KCK/hOBP5fVTSadgtiaNDs5Bzgvty1HOiXyqdy2BekEx2ZV5F9POh9b0vWi0jMhhdp6iRR2axTp1MV9+bkvRYqh9x3SKZG5wBaD/bsapXqJkV1jLA88X1b3HOkPFZLhO5T0B/wVkmF6AZidRwo3KJ0NrYjtM2y/YHs+6Y/nHVr8DOhltv/iFFppc2BV28fafs32A6TD+/uVy1UKpLkfcEyW/yDwX7wxIm2W1/Nn3oTktnSX0xnZcvYlhUv6u1Nkle8UdBJwCPAV2886HR37fiX963CJ7b86nSA5hzfCMX0IeND2mU6hnG4nGbCqz58UKKGk6zeBffOz+zhwhVNortdJgQuWAd6Tv4sDScfeLgd+lO8VDFFiza4xXiTFbysylmTQsP0QOT6cpGWBm0kH239OOpx/BfB3SdfafrYoJP9RHU/6Y1yVNw7ijycZVFgytNKaZVO6EaT4d+WMJ41IiqGNysMaNYzt6ySdTFq/XE/SxcBRTrH8iqxJGgEW71liVfLoVG8ERFH+DM1QLRzTesA2Zc9nJHBWDVnlobJGkZ7dYmGhbPdJepj8/Gw/KGkK6bs/pUn9gw4TI7vGuAcYKWnjQt07gEqBLr8F/Mr2E6RR2HTbzwGPkCL6lnMA6aD++4AVSVNJqB7u6GFgthcP2bSC7Q+wJE+TRmPF0EbFsEYvkQxPidXLrl/C49z2SbbfRYoY8hYqR295jCXDTxV1egV4a0H/FW1Xix3XrNf7w8ANZc9nedu1AhyU6/p61nOxsFB5VLoO+flJ+iDwblIghh83qWfQYcLYNUCe3lwMHCtpOUnbkQzUYqMFSZsBOwKn5qrZwM5K0Yo3Bv5ZQfwKpPBKz5AMz/frqPNX4IW8QL6MUtimt6lCFjOnXdsLgOMlrZA3Tb5KCvsEKQT7eyWtm6fNx5SJeIJCyCRJW0naRtIokqF8lcohoS4g5ajYLI90v13QqY807T5R0puy3LUk7Vbl8z4BrK0UeaQRfk8K5fRJJdefUVnvTWtc84mCrscCFxae3Qcl7ZI/85Gk7+ompfwUp5HC0B9ECqNV6R9OMEQIY9c4XyCt1zxJCjV0qJcMYX4K8GW/4RpyDGlN5w7g+07uKOX8hjRVmkMKlVQzjFCW/SHSGtVs0gjkNNKosBKHkQzTA6TD7L8FzsiyriFNs2eSpp3lsd1+Buwjaa6kk0hT91+RFuMfIhnoJUY0tq8ibbRcR1rQv66sy9G5fqpS1OY/Af9SRf/rSM/vcUl1wzHlNcBdSWuAj5KmuyeQNn+qcRZp0+NxYGlyrg/b/yAFWf056Tl/GPiw7deASaS11CudwkcdDJymnNMi7x7/a/mNgsEjzsYGQTAsiJFdEATDgo4bu7zGdLukJcJhZ2fT8yXdlx021++0fkEQtBdJZ2RH9L9Xad9E0s2S5qss/7Gk3bNj+H2S/qNQv0G2Efdlm1F3TXcwRnZfBu6q0nYwMNf2RiTH0xM6plUQBAPFZJKjeTWeJa2T/qRYmd2yTiHlDN4M2D9vAkKyDSdmWzGXZDtq0lFjp5SM5oOkBfVKfAT4dX59IbCLtFh2qiAIugzbN5IMWrX2J23fQnL5KbI1cJ/tB/Km0HnAR7JN2JlkIyDZjL3q6dFpp+Kfko7crFClfS2yg6ftBZKeIx29WmwXTtIhJC98NHr0u0at9qZyOUEw7Hjt4Ueetr1qu+TtttNyfubZ+jEnbp05/w6SG1KJSbYntUGFRfYg8wgpqdUqwDy/kX/lERpwlO+YsZP0IeBJ27dK2rE/svKDnAQwZt11vNaRX+m/gkHQ5cw+4sjyJOD94ulnFzLt6rXr9hu1xv2v2t6ynfceCDo5stsO2DM7Xi4NjJV0tu1PFPrMIXmoP5KjSaxI8uUKgqDjmIVuKI3wQFGyByXWznXPAOMkjcyju1J9TTq2Zmf7GNtr216f5PB5XZmhg3Sg+qD8ep/cJxwBg2AQMLCAhXXLAHILsHHeeR1NshuXZ5swhWQjINmMy+oJG/RAAJKOJZ0fvRw4HThL0n2kBc1mI2EEQdAmjFnYhrGGpHNJxyjHS3qEdHxwFIDtX0haHZhOOqHTJ+kIUkiu5yV9CbiaFCjijMKppaOB85RiKN5Osh01GRRjZ/t6UhwxbH+rUP8qtUPxBEHQQfqajsOwJK6TXDwfo6y4OGj7SuDKCvUPkHZrG2bQR3ZBEAxNDLxeMc5DdxLGLgiCihjaMo0dKoSxC4KgKr0zrgtjFwRBFYxZ2IY1u6FCGLsgCCpiw+u9Y+vC2AVBUA2xkN45mh7GLgiCihjoi5FdEAS9joHXeii+bxi7IAiq0ueYxgZB0OMYYs0uCILex4jX3Wzu8qFLxybkkpaW9FdJf5N0h6TvVujzVUl3Spop6dqc5zQIgkGgNLKrV7qFTq4+zgd2tv0OUs7T3SVtW9bndmBL228nhVz+UQf1C4JgMcRCL1W3dAsdm8bmGFQv5rejcnFZnymFt1NJCYqDIBgEUiCAmMa2RE6jOAN4ErjG9rQa3Q8Grqoi5xBJ0yVNX/jiSwOgaRAEdm+N7Dqqqe2FtieQYldtLeltlfpJ+gSwJfDjKnIm2d7S9pYjll9uwPQNguFOH6pbuoVBMcu255HCKi+RS1LS+4BvAHvant9h1YIgyBjxmkfWLfVoIEm2JJ2UE17PlPTOXL+TpBmF8qqkvXLbZEmzC20T6unRyd3YVSWNy6+XAd4P3F3WZwvglyRD92SndAuCYEkM9LFU3dIAk6mdJHsPYONcDgFOhbSGb3tCng3uDLwM/LFw3ddK7bZn1FOik352awC/zlm+lwIusP37shwUPwaWB36Xc2P/0/aeHdQxCIICC9twgsL2jZLWr9HlI8Bv8ibmVEnjJK1h+7FCn32Aq2y/3KoendyNnQlsUaG+mIPifZ3SJwiC2hixsLGR23hJ0wvvm02SXSkZ9lpA0djtB/x32XXHS/oWcC3wH/WWveIERRAEFTHwegNrcsDTA5kkW9IawOakLGMljgEeB0YDk0jZxo6tJad79o2DIOgoRix0/dIGqiXDLrEvcInt1xfpZj/mxHzgTBrINBbGLgiCqrRpg6IelwMH5l3ZbYHnytbr9gfOLV6QR3soLe7vBVTc6S0S09ggCCpitycQQL0k2aS8sB8A7iPtuH6qcO36pFHfDWViz5G0KiBgBvD5enqEsQuCoCIplWL/R24NJMk28MUqbQ+SNivK63duVo8wdkEQVKXB3diuIIxdEAQV6bV4dmHsgiCoSEq4EyO7IAh6nu4KzlmPMHZBEFQkORX3zjS2k4EA1pE0JYddv0PSl2v03UrSAkn7dEq/IAgWxxZ9Xqpu6RY6ObJbABxp+zZJKwC3SrrG9p3FTjlQwAksHt0gCIJBoJuCc9ajk4EAHiMf7LX9gqS7SP4zd5Z1PQy4CNiqU7oFQbAksRvbBrJX9BbAtLL6tYCPAjtRw9hJOoQU94oRK600YHoGwXAm7cbGBkXLSFqeNHI7wvbzZc0/BY623Zfj2VUkh4+ZBDBm3XVctWMQBP0inIpbRNIokqE7x/bFFbpsCZyXDd144AOSFti+tHNaBkEAaRq7IKaxzZOjE5wO3GW7PAgfALY3KPSfDPw+DF0QDA52eyIVDxU6ObLbDvgkMCunUwT4OrAuLIp+EATBECLW7FrA9p+hcXds2xMHTpsgCOph1FV+dPWIExRBEFQknaDoHWPXO58kCII2054TFK3mjc1tCwu5YS8v1G8gaVq+5nxJo+vpEcYuCIKq9KG6pQEm00Le2MwrhdywxbSqJwAn2t4ImAscXE+JMHZBEFTEhtf7RtQt9eX4RuDZGl0W5Y21PRUYV8oxUYns2bEzcGGu+jUpD0VNwtgFQVCRtEFRv5DzxhbKIU3eqlreWICls8ypkvbKdasA82wvqNC/KrFBEQRBVRqcpg5k3tj1bM+R9GbgOkmzgOdaERQjuyAIKmJgQd+IuqUNVM0ba7v08wHgetKZ+mdIU92R5f1rEcYuCILKNDCFbZPTccW8sZJWkjQGQNJ40sGEO3M2silAKd7lQcBl9W4S09ggCCpiGp7G1qQfeWM3BX4pqY80MPthIf7l0aRz9McBt5OOotYkjF0QBBVJ09jByxtr+yZg8yrXPABs3YweYeyCIKhKL52N7WQOippe1LnPjtlT+g5JN3RKtyAIlqQJ15OuoJMju8nAycBvKjVKGgf8D7C77X9KelPnVAuCYAkMC3robGwno57cmMOxV+MA4GLb/8z9n+yIYkEQVKTXwrIPJbP9FmAlSddLulXSgdU6Sjqk5K298MWXOqhiEAwvYho7MIwE3gXsAiwD3Cxpqu17yjtGDoogGHhKa3a9wlAydo8Az9h+CXhJ0o3AO4AljF0QBJ2hl/LGDqVPchmwvaSRkpYFtgHuGmSdgmDYYsc0tiXqeVHbvkvSH4CZQB9wmu2qbipBEAw87iJjVo9O7sbW9KLOfX4M/LgD6gRBUBexsA0nKIYKQ2nNLgiCIUSvuZ6EsQuCoDJO63a9Qhi7IAgqYnprNzaMXRAEVeiu3dZ6hLELgqAqvTSN7Z0xahAEbcWGvr6l6pZ6tJo3VtIESTfnKEgzJX28cM1kSbMLOWUn1NMjjF0QBFVpk1PxZFrLG/sycKDtt+brf5qjI5X4WiGn7Ix6SsQ0NgiCqrRjGttAxKNFeWOBqZLGSVqjeC7e9qOSngRWBea1okeM7IIgqIhRo9PYgcwbC4CkrYHRwP2F6uPz9PbEUmKeWsTILgiCqjQ4sBvIvLFIWgM4CzjIdl+uPgZ4nGQAJ5ES8BxbS05HR3aSdpf0j7wQ+R8V2teVNEXS7dlif6CT+gVBUMDpbGy90gaq5o2VNBa4AviG7amLVLMfc2I+cCYNJN/pZA6KEcAppMXIzYD9JW1W1u0/gQtsbwHsRwrTHgTBIOE+1S1toFre2NHAJaT1vAuLF+TRHpIE7AXUDRrSyWns1sB9OQUaks4jLUzeWehjYGx+vSLwaAf1C4KgjHZsUPQjb+y+wHuBVSRNzHUT887rOZJWBQTMAD5fT49OGrtKi5DblPX5DvBHSYcBywHvqyQoL4AeAjBipZXarmgQBGnk0Y5paj/yxp4NnF3lmp2b1WOo7cbuD0y2vTbJ0p8laQkdbU+yvaXtLUcsv1zHlQyCYYEBq37pEjo5squ6CFngYLLzoe2bJS0NjAci01gQDAKL9j57gE6O7G4BNpa0QV543I+0MFnkn6SEO0jaFFgaeKqDOgZBsIj6O7HdFMm4KWMnaam8Fdw0thcAXwKuJuWWuMD2HZKOlbRn7nYk8FlJfwPOJS1G9tBR5CDoMtxA6RLqTmMl/Za007GQNDobK+lnOYR6U9i+krTzUqz7VuH1ncB2zcoNgmAAMO1yLRkSNDKy28z28yRflquADYBPDqRSQRAMFdRA6Q4aMXajJI0iGbvLbb9OVw1egyBomR6axjZi7H4JPEjye7tR0nrA8wOpVBAEQwADfapfuoS6a3a2TwJOKlQ9JGmngVMpCIKhQi9tDzayQTEG2BtYv6x/zQgDQRD0AMPJ2AGXAc8BtwLzB1adIAiGEuqiaWo9GjF2a9uuFVI5CIJepMs2IOrRyAbFTZI2H3BNgiAYYjRwLraLTlA0MrLbHpgoaTZpGitSoIK3D6hmQRAMPj10NrYRY7fHgGsRBMHQpIemsY24njwk6R3Av+aq/7P9t4FVKwiCQacU4qlHqLtmJ+nLwDnAm3I5OwfXbJoGclCMkXR+bp9WJ/1aEAQDjFy/1JXRYpLs3HaQpHtzOahQ/y5Js/I1J+Xw7DVpZIPiYGAb29/Kh/a3BT7bwHXlH6iRHBQHA3NtbwScCJzQ7H2CIGgj7TkuNpkWkmRLWpkUwn0bUlqHb0sqhSY/lWSHStfV9RhpxNiJFPGkxEJaO/27KAeF7deAUg6KIh8Bfp1fXwjs0ojFDoJgYGjHyM72jcCzNbosSpKdM4iNywl1dgOusf2s7bnANcDuuW2s7ak5BNxvSGf3a9LIBsWZwDRJl+T3ewGnN3BdOY3koFjUx/YCSc8BqwBPFztFDoog6BCNrdmNlzS98H6S7UlN3KVakuxa9Y9UqK9JIxsU/y3pepILCsCnbN9e77qBJD/ISQBj1l2nh/aLgmAIYRp1PRnQJNntoqqxkzTW9vN53vxgLqW2lW3XGpZWopEcFKU+j0gaSUqn+EyT9wmCoE00Mk1tA9VswxxSCsZi/fW5fu0K/WtSa83ut/nnrcD0Qim9b5ZGclBcDpR2XPYBrouw7EEwiHQmnl3FJNmkFA67Slopb0zsClyd256XtG1e0z+QdIa/JlVHdrY/lH9u0IYPU1qDK+WgGAGcUcpBAUy3fTlpLfAsSfeRFjT3a8e9gyBoHhnUhhMUrSbJtv2spO+RBkoAxxZmlF8g7fIuQ4qgflU9PRoJ8XSt7V3q1TVCAzkoXgU+1qzcIAgGiEFMkp3bzgDOqFA/HXhbM3rUWrNbGliWZI1X4g13k7E0sPMRBEEP0EOLSLVGdp8DjgDWJK3TlYzd88DJA6tWEARDgXZMY4cKtdbsfgb8TNJhtn/eQZ2CIBgKNOg03C00coKiT9K40pu8M/KFgVMpCIIhwzDLLvZZ2/NKb/KxjabPxgZB0H2or37pFhoxdiOK51Pzgf7RA6dSEARB+2nkbOwfgPMl/TK//xwN+LQEQdADdNE0tR6NGLujSYfuP5/fzwRWHzCNgiAYGrTJqXioUHcaa7sPmEY6G7s1sDNw18CqFQTBkKCHNihqORW/Bdg/l6eB8wFs79QZ1YIgGEzE8HE9uZs0ivuQ7e2zr93CGv2rUivsclm//XOo5ZmS/iBpfCv3C4KgTfTQyK6Wsfs34DFgiqRfSdqF1iIUQ5Wwy0VySKefATvlNI0zgS+1eL8gCPqLh4nrie1Lbe8HbAJMIR0de5OkUyXt2uR9qoVdLqJclsuuLmOBR5u8TxAE7WSYjOwAsP2S7d/a/jApSN7tpB3aZqgWXrl4n9eBQ4FZJCO3GVXCv0s6RNJ0SdMXvvhSk6oEQdAo7chBMVRoxKl4Ebbn2p7USninekgaRTJ2W5CCD8wEjqmixyTbW9recsTyy7VblSAI4I2w7PVKl9CUsWsGSV+UNEPSDNLaX72Q7BMAbN+f41tdALxnoPQLgqA+bcobWy9f9HqSrs0bk9dLWjvX71SyIbm8Kmmv3DZZ0uxC24R6egyYsbN9iu0JticAl1I57HKROcBmklbN799P+PMFweDSzzW7BvNF/4S0pv924FjgBwC2pxRsyM6kKMZ/LFz3tVK77Rn1PkojJyjaQcWwywCSZmRlH5X0XeBGSa8DDwETO6RfEAQVaMNu66J80QCSSvmi7yz02Qz4an49hTQ4Kmcf4CrbL7eqyICN7IrkXdgv2t7Q9uY5pHKpbULh9S9sb2r77bY/bDsyiwXBYNHIqC6N7MaXNgxzOaQgpe7mJPA3kqsbwEeBFSStUtZnP+Dcsrrj89T3RElj6n2cjhi7IAi6DzVYyHljC6WZBNkARwE7SLod2IG0pLXoAEN2U9uclKyrxDEkt7itgJVpwEOkU9PYIAi6kDZMY+vmi7b9KHlkJ2l5YO9iDE1gX+CS7J5Wuqa05j9f0pkkg1mTGNkFQVCd/jsV180XLWm8pJItOoYls4ntT9kUtnQoIR9A2Av4ez1FwtgFQVCdfho72wtIxz6vJnlXXFDKFy1pz9xtR+Afku4BVgOOL10vaX3SyPCGMtHnSJpFOoQwHjiu3keJaWwQBJVpUzy7BvJFXwhcWOXaB6mQutX2zs3qEcYuCIKqdNNxsHqEsQuCoDph7IIgGA7EyC4Igt6nFAigRwhjFwRBRXotLHsYuyAIqtNDxq4jfnaSNpF0s6T5kqp6OueoKMdLukfSXZIO74R+QRBUwKA+1y3dQqdGds8Ch5M8nWsxkeRAuIntPklvGmC9giCoQUxjm8T2k8CTkj5Yp+uhwAE5V23puiAIBoseMnZD7bjYhsDHc5iYqyRtXKlT5KAIgs4wLLKLDRJjgFdtbwn8iiUPBAORgyIIOkIDIdm7aZrbkRwUktZs8LJHgIvz60uAtw+MdkEQNEQPpVIcsDU726eQYs83w6XATsBsUhC/e9qsVhAEDSLoqt3WenRkg0LS6sB0UuLrPklHAJvZfl7SlcBncgC/H5JCt3wFeBH4TCf0C4KgMt00Ta1Hp3ZjHydFKK3U9oHC63lAvR3bIAg6QZdNU+sx1DYogiAYQmhh/VJXRot5Y3PbwsLa/+WF+g0kTcsyz89RkGsSxi4Igqr0dze2P3ljM68UcsPuWag/ATjR9kbAXODgep8ljF0QBJUxYNcvtVmUN9b2a0Apb2yRzYDr8uspFdoXI+ed2Jk3ohv/mvqns8LYBUFQnQadigcyb+zSWeZUSXvlulWAeTm/RTWZSxBRT4IgqEgTIZ6ezgcBWuUo4GRJE4EbWTxv7Hq250h6M3BdTrLzXCs3CWMXBEFlGpum1qNfeWNtz8k/H5B0PbAFcBEwTtLIPLpbQmYlYhobBEFV2nBcrOW8sZJWkjSm1AfYDrjTtklre/vkaw4CLqunSBi7IAiq0t9AAP3MG7spMF3S30jG7Ye278xtRwNflXQfaQ3v9HqfJaaxQRBUxkAbjou1mjfW9k3A5lVkPkDa6W2YMHZBEFQnTlA0h6R/z97RsyTdJOkddfqfJOnFTugWBEF1Iix788wGdrA9V9IewCRgm0odJW0JrNQhvYIgqEEvBQLoyMjO9k225+a3U6kSFCAfLfkx8P86oVcQBDVoJJZdFxnDwVizOxi4qkrbl4DLbT+WToRUJntoHwIwYqUYBAbBQCBAC7vImtWho8ZO0k4kY7d9hbY1gY+RtqFrYnsSaSrMmHXX6Z1vIwiGGOq/U/GQoWNh2SW9HTgN+IjtZypcsgWwEXCfpAeBZbMPTRAEg0FMYxujGJZd0rqk3BKftF0x1LrtK4DVS+8lvZjDtwRBMCh0125rPTp1guJbJC/n/8kjvemlBklXNpGQJwiCTtL/EE9Dhk6FZf8MVfJJFMOyl9UvP6BKBUFQG3dXXth6xAmKIAiq00PT2DB2QRBUpZd2Y8PYBUFQnTB2QRD0PAZizS4Igl5HGPX1jrULYxcEQXV6aBobkYqDIKhMaRpbr9Sh1STZkiZIulnSHbnt44VrJkuaXTilNaGeHjGyC4KgKv2dxhaSZL+flPLwFkmXF8KrwxtJsn8taWdSkuxPAi8DB9q+Nx88uFXS1aVkPMDXcpTjhoiRXRAEVWjg9MQAJsm2fY/te/PrR4EngVVb/TRh7IIgqIxp1NgNZJJsACRtDYwG7i9UH5+ntyeWspDVolNh2T+SlZqRH0alEE/LSrpC0t15jv7DTugWBEF1tNB1CzlJdqFMavI2RwE7SLod2IHFk2QjaQ3gLOBTtkvz6mOATYCtgJVJ2cZq0qk1u2tJQTmdQz1dQFK0nJ/YnpLzS14raQ/b1QJ9BkEw0AxykmxJY4ErgG/Ynlq45rH8cr6kM0kGsyadCsv+Yk5sC7AcFaJg2X7Z9pT8+jXgNqqEbw+CoAOUUinWK7XpT5Ls0cAlpM2LC8uuWSP/FLAX8Pd6inRszU7SRyXdTbLSn67TdxzwYdKIMAiCQcHQ11e/1JLQvyTZ+wLvBSZWcDE5R9IsYBYwHjiu3qfpmOuJ7UuASyS9F/ge8L5K/SSNBM4FTsqJcCv1iRwUQdAJ2uBU3I8k2WcDZ1eRuXOzenQsLHup3vaNwJslja9y6STgXts/rSbb9qTSYuiI5Zdrr+JBECTaM40dMnQqLPtGkpQ3KN4JjAGWyEMh6ThgRaoE+gyCoJMY+hbW79YldGoauzdwoKTXgVeAj5c2LCTNsD0hHxH5BnA3cFtOpXiy7dM6pGMQBEVKI7seoVNh2U8ATqjSNiH/fISUqjIIgqFCDwUCiLOxQRBUwXV3W7uJMHZBEFTGhLELgmCYENPYIAiGBWHsgiDoeWy8MFxPgiAYDoTrSRAEw4KYxgZB0PPYENPYIAiGAw7XkyAIep+Gckx0DWHsgiCojOmpaWxHE+5I2krSAkn7VGl/l6RZOb/kSTkKaRAEg4AB97luqUereWNz20GS7s3loEJ907aik5GKR5CCAfyxRrdTgc8CG+eyewdUC4KgEja4r36pQSFv7B6klIn7S9qsrFspb+zbgWNJeWORtDLwbWAbUkrGb0sqRett2lZ0cmR3GHARKffjEuSY8mNtT83hn35Dii0fBMEg4YUL65Y6tJw3FtgNuMb2s7bnAtcAu7dqKzqyZidpLVI+yJ1Iqc8qsRYpp2SJSvklS/IWhWUH5s8+4si6yTYaZDzwdJtktVte6Db4stotr926/UsbZfECc6/+ky+sFlG8yNKSphfeTyqkU6yUN3absutLeWN/xuJ5Y6vlnG3YVhTp1AbFT4Gjbfe1YxkuP8hJAJKm296y30LbLKvd8kK3wZfVbnkDoVu7ZAHY7tQy0lHAyZImAjdSlje2XQyYsZP0RdKcGlKo9fOyoRsPfEDSAtuXFi6Zw+KpE5fILxkEQdfRct5YSXNImceK115Pi7ZiwNbsbJ9ie0IuG9he3/b6pCxCXygzdKWkt89L2jbvrBwIXDZQ+gVB0BFazhtLSr+4q6SV8sbErsDVrdqKjrqeVELSjMLbLwCnAfcB9wNXNSBiUv0uDdNOWe2WF7oNvqx2yxvKurWF/uSNtf0sKe3qLbkcm+ugBVsh95CHdBAEQTUGfWQXBEHQCcLYBUEwLAhjFwTBsCCMXRAEw4KuMnaSdpN0qqTLczlVUsuOj1newZLWL6v/dBt0vae/MtqBpJUlfUvSZ5T4hqTfS/px4Zxhf2Sv3C5ds8xGPPYHhcLu4ZBhIL6DXqVrjJ2knwJfBm4AfpTLDcDhkn7WgrzvA98ANgeulXRYoflLTcp6QdLzubwg6QVgw1J9C7p9qfRHL2kjSTdKmidpmqTNmxR3NrAc8C7SucPVSQEZXgEmt6DbupLOk/QUMA34q6Qnc936TcraQ9JsSX+WtIWkO4Bpkh6RtEuzulWQv5GkvSscPG/k2n8rK3sDk0rvW5C3Tn5G/yfp65JGFdoubVJW276DYYXtrijAPVXqBdzbgrxZwMj8ehxwJXBifn97k7JOIh1GXq1QN7sfn/WOwusrgI/m1zsCf2lS1ozCc5pTqa1JeTcDHwdGFOpGkJxFpzarG7Ap8G7gGWDbXL8pcFsLuk0BxufXnwTuIflizQIOa1LW68DvSQ6uZ+byQv55Rgu6XQN8HpgA/By4CVilxd+3tn0Hw6kMugJNfMEzga0q1G8NzGpB3l1l70cApwO/KxqbJuS9ixS54XDSiPmBfnzWfxRe31L+HFp4bisB6wLPAevn+lWAO1vQreo/lmb/6RQNGvBwWduMFnT7e/G5FYzJsi08t62Aa4FDC3Wz+/Gdzih7/wngDmDDZg17O7+D4VS6KVLxROBUSSvwRsSDdUh/wBNbkHe/pB1s3wBgeyFwsKTjgL2bFWb7VknvI02BbwCWbkGnEhdKmkyK7XWJpCOAS4CdgX82KesHwN359aeB0ySZFFbnuy3odquk/wF+zRsRKdYBDgJub1LWPEmfA8YCcyV9BbgAeB/wYgu6vS5pLdtz8vUv5fr5pH9mDWP7FknvBw6TNAU4mhTPslVGSVra9qtZ/tmSHiedLFiuSVnt/A6GDV13gkLS6rwRzmWO7cdblLMMgO1XKrSV/mBa1XENYAvbV/ZDxkTgUNJ//jGkX+pLgRNsP9ekrBGk73qBpJGkqdQcpzOGzeo1GjiYFHOs9D08AvwvcLrt+U3IWgf4T6CPZHj3z7IfAo6yfVeTuu1IChR5EbAy8E6SMdmedKbyJ83IK8hdkxS5Z0vbb25RxldII7gbyuq3AH5k+/1NyGrbdzCc6Dpj121IWr1Vgxw0j6QVgQOAt5Ci+jwCXGb77poXBj1P1+zG1kLSbUNY3ultlFUa2bZLVruf24cGW5bt52yfavsrtg+zfUK7DZ1S8Nh2yhv05zYc6AljZ/udQ1We7Q+2S1ambcaz3c+N6lGoB1tWuw1UuxNBDdnn1kt09TRW0p62L6/fs2F5K/uNEDI9haTVWHyt84l+yNqExdeL5gCXN7vG1m5Zde7zOdu/bEG3tYBptl8s1O9u+w8t6LA14Lz5sRkpSczd/VnbLcj+je0D+yunl+ma3dgKjpwCTskL7ti+uEl525F8sPpIu5THAW/Oi7/72r65CVmbA78i/WFcRQpBPze3/dX21s3oVudeyxf/8BroPwH4BSladGnTZW1J80hBVJuayko6mrSRcB7w15I84FxJ59n+4WDIaoDXmuks6XDgi6QYbKdL+rLtUoDI7wNNGTtJ3yZl2Bop6RpSHoYpwH9I2sL28U3IKv8HL2AnSeMAbA+5kx5DgsH2fWm00H4nz7+STk+8m5T0ZPtc/06ad9z9M+m/9DhSPP07gA1z2+1tfg7/bLL/DGCbCvXbAn9r4f73AKMq1I+meT+7tskagOc2C1g+v14fmA58udXvNMsbQfL5e56UHQtgGZr3AbyNdDJmR2CH/POx/HqHdj63XipdM7ID3gP8kORkeyokVwPbn2pR3ijbs7Kcp2z/GcD2bSW3lCZYwW9Ma34i6VbgD5I+SQu+WZK+Wq0JWL5JccvZnlZeaXuqpGb9uyCNhNckuYcUWSO3DZYsJM2s1kSKgNsMSzmPoG0/mN1aLpS0Hq2t2S1w8uV8WdL9tp/Psl+R1Oxn3ZJ0dPIbwNdsz5D0isvcWoLF6Rpj5/Y7eRY3Z44paxvdrDBJKzr7v9meks9Slvy9muX7wI+BBRXamt1UukrSFaTjbEUH1ANpciqWOYJ0lvjegrx1gY1o8kxxm2VBMmi7AXPL6kU6ntUMT0iaYHsGgO0X807nGaQZQbO8JmlZ2y+TTtskxZKrTFPGznYfcKKk3+WfT9BFf8uDRVduUBScPN9le8MWZewJ/Cn/8pXqVid5s+9t+0dNyDqAdDxsapms0cA3bX+26sWV5d1EOst5a4W2h22vU+GyWvL2YPFNgEdJvmctLYwrJUfZmsU3FW7JI5fBlHU6cGZplF7W9lvbBzQha23SaGwJH0lJ29n+S5O6jXEFZ1+lgA9rlGYZrSDpg8B2tr/eqozhQFcauxKSbnMb3SfaKa8/siT9C/CM7acLdavbflzSau7HTmp/dQuCbqXb/eza7e/UTnkty7L9j6Khy1yZ2/pl6DLtfm5BMOTpdmP3qyEsr926tdNAtVu3IBjydPU0djgh6Qu2/2ew9QiCbiWMXRAEw4Jun8YGQRA0RBi7IAiGBWHsgkUoZR67Q9JMSTMkbSPpCEnLNnBtQ/2CYLCINbsAAEnvBv4b2NH2/OzsOpp08mDLCq4w5dc/2Ei/IBgsYmQXlFgDeLrk5Z+N1j6ks6tT8hE9lHL1Ts8jwO/musMr9NtV0s2SbpP0O0nL5/ofSrozjx5bCpMeBK0QI7sASKGjSNFblgX+BJxv+4byEVsp5p9SXotrgcNtzyz2y6PCi4E9bL+UQzmNIeWHuAnYxLYljbM9r8MfNRimxMguANJBd9IB9UOAp4DzlZL+lLOvUjj324G3krKUlbNtrv+LpBmkrFfrkTLBvUqKD/dvwMsVrg2CASEiJQSLyIfvrweulzSLZKQWIWkDUry+rWzPVUr3WCllpIBrbO+/REOK1rsLaYr8JVJ6yCAYcGJkFwAp+ICkjQtVE0hx5l4AVsh1Y0m5WJ9TCvO+R6F/sd9UYDtJG2XZy0l6S54qr5ijrXwFeMdAfZ4gKCdGdkGJ5YGf59DeC4D7SFPa/UmBSB+1vZOk20lJtx8GimGOJpX1m0gKrz4mt/8nySBeJmlp0uivWpDSIGg7sUERBMGwIKaxQRAMC8LYBUEwLAhjFwTBsCCMXRAEw4IwdkEQDAvC2AVBMCwIYxcEwbDg/wNNZBk60OBe9gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.sample_collection.count_samples import count_samples\n",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "\n",
    "samples_count, n_outside_boxes, _ = count_samples(replay_buffer.states, replay_buffer.actions, discrete_states_boxes, discrete_actions_boxes, replay_buffer.rewards)\n",
    "samples_visu_mesh = TwoDimesionsMesh(discrete_states, discrete_actions, sleeping_time=0)\n",
    "\n",
    "samples_visu_mesh.set_values(samples_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Samples repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train FQI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:04.621055Z",
     "iopub.status.busy": "2022-09-19T14:04:04.620873Z",
     "iopub.status.idle": "2022-09-19T14:04:06.742712Z",
     "shell.execute_reply": "2022-09-19T14:04:06.742233Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0.]\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "61db5b671e6245068f8e768b47c0481d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/4 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.13299619  0.12905048 -0.80391735]\n",
      "[-0.19128674  0.17163722 -0.83507913]\n",
      "[-0.21398368  0.18821368 -0.84719664]\n",
      "[-0.22237179  0.19434874 -0.85167611]\n",
      "Optimal weights\n",
      "[-0.22707027  0.19779846 -0.8541705 ]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.networks.learnable_q import LQRQ\n",
    "\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "q = LQRQ(\n",
    "    n_actions_on_max=n_actions_on_max,\n",
    "    max_action_on_max=max_action_on_max,\n",
    "    network_key=dummy_q_network_key,\n",
    "    zero_initializer=True,\n",
    "    learning_rate=learning_rate,\n",
    ")\n",
    "\n",
    "weights = np.zeros((max_bellman_iterations + 1, q.weights_dimension))\n",
    "\n",
    "params_target = q.params\n",
    "weights[0] = q.to_weights(q.params)\n",
    "\n",
    "print(weights[0])\n",
    "cumulative_l2_loss = np.zeros((max_bellman_iterations, fitting_steps)) * np.nan\n",
    "\n",
    "for bellman_iteration in tqdm(range(1, max_bellman_iterations + 1)):\n",
    "    q.reset_optimizer()\n",
    "    \n",
    "    for fitting_step in range(fitting_steps):\n",
    "        data_loader_samples.shuffle()\n",
    "        l2_loss = 0\n",
    "        for batch_samples in data_loader_samples:\n",
    "            q.params, q.optimizer_state, loss = q.learn_on_batch(q.params, params_target, q.optimizer_state, batch_samples)\n",
    "            l2_loss += loss\n",
    "        cumulative_l2_loss[bellman_iteration - 1, fitting_step] = l2_loss\n",
    "\n",
    "    weights[bellman_iteration] = q.to_weights(q.params)\n",
    "    print(weights[bellman_iteration])\n",
    "\n",
    "    params_target = q.params\n",
    "\n",
    "print(\"Optimal weights\")\n",
    "print(env.optimal_weights)\n",
    "\n",
    "for bellman_iteration in range(max_bellman_iterations):\n",
    "    plt.plot(cumulative_l2_loss[bellman_iteration], label=f\"Iteration {bellman_iteration + 1}\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:06.744989Z",
     "iopub.status.busy": "2022-09-19T14:04:06.744853Z",
     "iopub.status.idle": "2022-09-19T14:04:06.813510Z",
     "shell.execute_reply": "2022-09-19T14:04:06.812996Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/FQI/{max_bellman_iterations}_W_{seed}.npy\", weights)\n",
    "np.save(f\"figures/data/FQI/{max_bellman_iterations}_Pi_{seed}.npy\", env.greedy_V(weights))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:04:06.815912Z",
     "iopub.status.busy": "2022-09-19T14:04:06.815776Z",
     "iopub.status.idle": "2022-09-19T14:04:07.076038Z",
     "shell.execute_reply": "2022-09-19T14:04:07.075564Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgEAAAHwCAYAAAA/wLxAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAACF+ElEQVR4nO29eZgU5bn3/+29e3r2YYCBYRlWGfZNcSPIIm7BjSg5LmjEqK8m8eT9aSaLHk8SdDTmTeIxRnM0EeOCqFESNURAUaIoICICKoMwMDMMw+xb793P74/JU1ZXV/X03lVd9+e6+pru6p7qquqqur/PvT0GxhgIgiAIgtAfxmxvAEEQBEEQ2YFEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4hEUAQBEEQOsWcge+g8gOCIAiCyB4GpTfIE0AQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE7JRGIgQRAEkSB+vx+NjY3weDzZ3hRC5djtdlRWVsJiscT8P4YMzB1A1QEEQRAJcvToURQUFKCsrAwGg2KSN6FzGGNob29Hb28vqqqqpG9TdQBBEIQW8Xg8JACIQTEYDCgrK4vbY0QigCAIQuWQACBiIZHzhEQAQRAEQegUEgEEQRAEoVNIBBAEQRCETiERQBAEkWN0d3dj6tSp6O7uzsr3d3V14bHHHgtbdtZZZ6Vs/fn5+RHL+PrlvjtZ0r0/2YREAEEQRI7x+uuv4+DBg3jjjTey8v1yRvODDz5I63fy9SciAhhjCIVCiu9nYn+2bduGG264IaXrjAUSAQRBEDnGunXrwv6mgv/3//4fpk2bhmnTpuG3v/0tAKC+vh6nnXYarrnmGkyZMgUrV66Ey+VCTU0NvvrqK8yaNQt33XUXgK9H7/x/brjhBkyaNAnXXHMNtmzZgrPPPhsTJ07Ezp07AQCXXXYZ5s6di6lTp+KPf/zjoNvH1y/33c8++yxOP/10zJo1C7fccguCwSDq6+sxefJkXH/99Zg2bRoaGhoUvzPa/igdlylTpuDmm2/G1KlTcf7558Ptdif5C6QJxli6HwRBEESCHDx4cNDPvPLKK+x73/ue8LDZbAwAs9lsYctfeeWVhLZh9+7dbNq0aayvr4/19vay6upqtmfPHnb06FEGgP3rX/9ijDF24403sl/96lfs6NGjbOrUqWHrcDqdjDHGjh49ykwmE9u3bx8LBoNszpw57MYbb2ShUIi99tpr7NJLL2WMMdbe3s4YY8zlcrGpU6eytra2iHUprV/83QcPHmSXXHIJ8/l8jDHGbrvtNrZu3Tp29OhRZjAY2I4dO4TPKn2n0v5EOy4mk4l98sknjDHGvvWtb7G//OUvUY/xO++8w1avXh2x/M0332SLFi1iP/vZz9jbb7/NFi5cyH74wx8qrkfhfFG00dQ2mCAIQuP4/X784Q9/QCAQCFvu9XrxP//zPwAAs9mMc845J6H1/+tf/8Lll18Op9MJALjiiiuwfft2rFixAqNGjcLZZ58NALj22mvxyCOPYOXKlVHXV1VVhenTpwMApk6diiVLlsBgMGD69Omor68HADzyyCN49dVXAQANDQ2oq6tDWVlZ3Nu+detWfPzxx5g/fz4AwO12Y+jQoVi4cCHGjBmDBQsWCJ+N9zujHZeqqirMmjULADB37lxhv6ScccYZ8Hq96OvrQ0dHh/A/Dz74IJYvX46tW7finXfewUMPPYTf/OY32LJlC1544QUcPHgQ1dXVcR8PKSQCCIIgNM7VV1+N6dOn45vf/Caam5vDXM8OhwMVFRX4+9//nhKjIUXaoCaWhjU2m014bjQahddGoxGBQADbtm3Dli1bsGPHDuTl5WHRokUJz53AGMPq1avxwAMPhC2vr68XjDeAlH4nEL6PJpNJMRzw0UcfCd//9NNP4+mnn47YfgAoLS1FX18fgsGgMIpPBZQTQBAEkQNUV1fj448/hs/nC1vu8/mwZ8+epATAueeei9deew0ulwv9/f149dVXce655wIAjh8/jh07dgAAnn/+eZxzzjkoKChAb29vwt/X3d2NkpIS5OXl4YsvvsCHH34Y8/9Kv3vJkiV4+eWXcerUKQBAR0cHjh07Ftd3Ku1PtOOSKpYuXYolS5bg888/x3333Yfzzz8fu3fvxtSpU1OyfhIBBEEQOcL27duRl5cHs9kMk8kEs9mMvLw8bN++Pan1zpkzBzfccANOP/10nHHGGVizZg1mz54NAJg8eTJ+//vfY8qUKejs7MRtt92GsrIynH322Zg2bZqQSBcPF1xwAQKBAKZMmYKampowl/1gSL+7uroav/zlL3H++edjxowZWLZsGZqbm+P6TqX9iXZcUsWFF16IrVu34te//jUWLlyI9957TwjxpAKaRZAgCELFfP7555gyZUpMn/3Wt76FV155BfPmzcOjjz6KO+64A7t378bKlSuxYcOGlG9bfX09LrnkEuzfvz/l6yYSQ+F8oVkECYIgcp26ujrce++92LFjB04//XTs2LED9957L+rq6rK9aYRKIU8AQRCEionHE0AQ5AkgCIIgCCImSAQQBEEQhE4hEUAQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4hEUAQBEFE5ayzzgIw0Bzo+eefT+m677//ftnvSpaOjg4sW7YMEydOxLJly9DZ2ZmS9eYaJAIIgiCIqHzwwQcAEhMB0pkNpUhFAP+uZKmtrcWSJUtQV1eHJUuWoLa2NiXrzTVIBBAEQeQanlagfdfA3xSQn58PAKipqcH27dsxa9Ys/OY3v0EwGMRdd92F+fPnY8aMGXjiiScADMyId+6552LFihXCxEWXXXYZ5s6di6lTp+KPf/yjsD63241Zs2bhmmuuCfsuxhjuuusuTJs2DdOnT8eLL74orHvRokVYuXIlTjvtNFxzzTWyM+pt3LgRq1evBgCsXr0ar732WkqORc7BpyRM44MgCIJIkIMHD8b3D0efZ2y9g7ENRQN/jz6f9DY4nU7GGGPvvPMOu/jii4XlTzzxBPvFL37BGGPM4/GwuXPnsiNHjrB33nmH5eXlsSNHjgifbW9vZ4wx5nK52NSpU1lbW1vYuqXf9fLLL7OlS5eyQCDATp48yUaNGsVOnDjB3nnnHVZYWMgaGhpYMBhkCxYsYNu3b4/Y5qKiIuF5KBQKe53LKJwvijaaPAEEQRC5gqcV+OgmIOgG/N0Dfz+6KWUeASlvvfUWnnnmGcyaNQtnnHEG2tvbhXkKTj/9dFRVVQmffeSRRzBz5kwsWLAADQ0Ng85n8K9//Qvf/va3YTKZMGzYMHzjG9/Arl27hHVXVlbCaDRi1qxZqK+vj7oug8EAg0Gxc66uMWd7AwiCIIgU0V8PGK0Dxp9jtAwst5en/OsYY/if//kfLF++PGz5tm3b4HQ6w15v2bIFO3bsQF5eHhYtWgSPx5Pw99psNuG5yWSSzTsYNmwYmpubUVFRgebmZgwdOjTh78tlyBNAEASRKzjHAiFf+LKQf2B5CigoKEBvb6/wevny5fjDH/4Av98PADh06BD6+/sj/q+7uxslJSXIy8vDF198gQ8//FB4z2KxCP8v5txzz8WLL76IYDCI1tZWvPfeezj99NNj3tYVK1Zg3bp1AIB169bh0ksvjfl/9QSJAIIgiFzBXg6c8RRgcgCWwoG/ZzyVMi/AjBkzYDKZMHPmTPzmN7/BmjVrUF1djTlz5mDatGm45ZZbZEflF1xwAQKBAKZMmYKamhosWLBAeO+73/0uZsyYISQGci6//HLMmDEDM2fOxOLFi/HQQw9h+PDhMW9rTU0NNm/ejIkTJ2LLli2oqalJfMdzGJpKmCAIQsUkNJWwp3UgBOAcm5YwAKFe4p1KmHICCIIgcg17ORl/IiYoHEAQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4hEUAQBEEQOoVEAEEQBBEVLU4l/NJLL2Hq1KkwGo3YvXt3StaZi5AIIAiCIKKixamEp02bhr/+9a9YuHBhStaXq5AIIAiCyDVoKmFMmTIFkydPTsn+5zLULIggCCKXqH9hYOZAo3VgHoEzngLGfjslq66trcXDDz+M119/HQDwxz/+EUVFRdi1axe8Xi/OPvtsnH/++QCAPXv2YP/+/cJMgn/6059QWloKt9uN+fPn48orr0RtbS0effRR7N27N+K7/vrXv2Lv3r349NNP0dbWhvnz5wuj+k8++QQHDhzAiBEjcPbZZ+P999/HOeeck5J91BvkCSAIgsgVaCphIk7IE0AQBJEr0FTCRJyQJ4AgCCJXoKmEiTghEUAQBJEr0FTCAq+++ioqKyuxY8cOXHzxxRHeCmIAmkqYIAhCxdBUwkQ80FTCBEEQeoemEiZihMIBBEEQBKFTSAQQBEEQhE4hEUAQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQUdHiVMJ33XUXTjvtNMyYMQOXX345urq6UrLeXINEAEEQBBEVLU4lvGzZMuzfvx/79u3DpEmT8MADD6RkvbkGiQCCIIhcg6YSxvnnnw+zeaAVzoIFC9DY2JiSY5FzMMbS/SAIgiAS5ODBg/H9w9HnGVvvYGxD0cDfo88nvQ1Op5Mxxtg777zDLr74YmH5E088wX7xi18wxhjzeDxs7ty57MiRI+ydd95heXl57MiRI8Jn29vbGWOMuVwuNnXqVNbW1ha2bul3vfzyy2zp0qUsEAiwkydPslGjRrETJ06wd955hxUWFrKGhgYWDAbZggUL2Pbt26Nu/yWXXML+8pe/JHkUtIHC+aJoo8kTQBAEkSvQVMIRrF27FmazOWJuAmIAahtMEASRK9BUwmE8/fTTeP3117F161YYDIrt83UNeQIIgiByBZpKWGDTpk146KGH8Le//Q15eXnx7KauIBFAEASRK9BUwgJ33HEHent7sWzZMsyaNQu33npr4juew9BUwgRBECqGphIm4oGmEiYIgtA7NJUwESMUDiAIgiAInUIigCAIgiB0CokAgiAIgtApJAIIgiAIQqeQCCAIgiAInUIigCAIgoiKFqcSvueeezBjxgzMmjUL559/Pk6cOJGS9eYa1CeAIAhCxSTUJyBNbNu2DQ8//DBef/31mP8nEAgIs/nJkZ+fj76+vlRsXhg9PT0oLCwEMDBvwcGDB/H444+n/HvURrx9AsgTQBAEkWvQVMKCAACA/v5+mjtAiWhTDKboQRAEQSQITSWc+FTCP/nJT1hlZSWbOnUqO3XqVNLHQQvQVMIEQRB6haYSDmPt2rVoaGjANddcg0cffTQ1O51jkAggCILIFfhUwmL4VMJpgP17KuG9e/di7969OHr0KM4//3wAUJxK+NNPP8Xs2bMzMpUw55prrsErr7yS8PflMiQCCIIgcgWaSlhA7GnYuHEjTjvttJj/V0/QBEIEQRC5Ap9K+KObBjwAIX/aphK+4YYb8IMf/AD19fWYM2cOGGMoLy/Ha6+9FvF/F1xwAR5//HFMmTIFkydPlp1KeM6cOXjuueeE5Zdffjl27NiBmTNnwmAwCFMJf/HFFzFta01NDb788ksYjUaMGTNGF5UBiUAlggRBECqGphIm4oGmEiYIgtA7NJUwESOUE0AQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4hEUAQBEEQOoVEAEEQBBEVLU4lzPn1r38Ng8GAtra2lK43VyARQBAEQUTlgw8+AJCYCBispa9UBPDvSgUNDQ146623MHr06JStM9cgEUAQBJFr0FTCAID//M//xEMPPUTTCEeBmgURBEHkEvUv/LttsHVgHoEzngLGfjslq66trcXDDz+M119/HQDwxz/+EUVFRdi1axe8Xi/OPvtsYQKhPXv2YP/+/cJMgn/6059QWloKt9uN+fPn48orr0RtbS0effRR7N27N+K7/vrXv2Lv3r349NNP0dbWhvnz52PhwoUAgE8++QQHDhzAiBEjcPbZZ+P999/HOeecE/b/GzduxMiRIzFz5syU7HuuQiKAIAgiVxBPJRx0Dyz76CZg+NK0dBB86623sG/fPrz88ssABiYKqqurg9VqlZ1K+NVXXwUAYSrhsrIyxXUrTSVcWFgoTCUMQJhKWCwCXC4X7r//frz11lsp3+dcg0QAQRBErsCnEuYCAPh6KuE0iAA+lfDy5cvDlm/btk1xKuG8vDwsWrQorVMJf/XVVzh69KjgBWhsbMScOXOwc+dODB8+POHvzUUoJ4AgCCJXoKmEAQDTp0/HqVOnUF9fj/r6elRWVmLPnj0kAGQgEUAQBJEr8KmETQ7AUjjwN01TCf/mN7/BmjVrUF1djTlz5mDatGm45ZZbZKsBLrjgAgQCAUyZMgU1NTWyUwnzxEDO5ZdfjhkzZmDmzJlYvHixMJUwkVpoKmGCIAgVQ1MJE/FAUwkTBEHoHZpKmIgRCgcQBEEQhE4hEUAQBKFyMhC2JXKARM4TEgEEQRAqxm63o729nYQAERXGGNrb22G32+P6P0oMJAiCUDF+vx+NjY1J1dUT+sBut6OyshIWi0X6lmJiIIkAgiAIgshtFEUAhQMIgiAIQqeQCCAIgiAInUIigCAIgiB0CokAgiAIgtApJAIIgiAIQqdQ22CCIJJGXGXEn8e6zGg0wmD4OnlZ6bnca4IgkoNEAEHkEMkY41AoFLaMP8Sv5daRTJkxYwxWqxVGY2xOSZfLhWAwiMLCQgBfiwKDwRAhHmIVEyQsCD1DIoAg0kA0wzuYUU6XMW5ra4PRaERpaani9soZRKVlYgOs9LlYMJlMMf0vYww9PT3weDyCCJA7LkoYDAbZz/T29gLAoMJCbhl5LQitQyKAyGlSZYz5c/HnAoEA+vv7UVBQoLiORLc3FmOsZISVjI/f74fJZILJZEp4+7IJN8Byxpm/H8s6pPT29iIQCCQkLJRgjOHkyZMYMWJExPZLt4O8FkQ2IRFAZIR0GuN0uamB6Ddkj8eD+vp6TJ8+Pey9ZEfGROZJRljIEQqFcOzYsTARIHeuxovH44HL5UJZWVnY9pHXgkgUEgE6I944sdKoKNXGOBAI4MiRI5g0aVLE9sbjoo72N9XwhDa6gWYOLU2iE+3cSPSc8Xg8OHXqlCACUuG14P/f2tqKYcOGCdtHXgt9QCIgS8RqeOXei2Z4vV4v/H4/HA5H2P8mcoMQG+B0G2PGGNxut2Zd1QSRKVLttWCMIRQKob6+XhABqfBa8G3q7+8HAOTn5wvLyGuhHnQtAuSMrPh5MsZYmtAl/Vy82xmrMe7q6kJ3dzfGjRsXNXOaSA1aGpkShBzRQgri9+NBfF10dHQAAJxOp/BessKC4/V6EQqFhHWT1yJ+ck4EMMbw0EMP4Y477lB0lQ12En711VcYP3687LqTHRlnykUda8kVkThavHGQaJFHi7+lmolnpB8P0vO3q6sLfX19wv06VeKCP3e5XHA6nTGLCy16LXJOBADACy+8gFtvvTVieazGuLu7W7NuaaUyKIIg5NHS9aKlbU0HSoOsZAZXcseUL/v0008xf/78hAdV0cSQwWCA3++H2WyO2jBL+jrVwiLnRMBgri1CnZB4IYjY0OJ9LZ3bnOy6B/t/o9GYkAhQEhdiT/SuXbswZ84cmM2xmWKDwQCbzZbS45lzIoAgCCLbKIUL1Uo6tzed4j4TA4dEj0u0/xO/ZzKZYhYZ4nLpVEGB4xyDRtQEQeiJdIotNYuMVEEigCASJNsXL0FoAb16AmJBDQM2CgcQqkCrHgwtbnOq4PXloVAIwWAw4b9GoxFmsxlmsxkmk0l4LrcsGAxme7ezSrrc9ukOX5BgVibbx4ZEgAJai+lxtGpMidShZJhdLhcA4NSpUwkZbLnrgSdN8bhmtL/coMstDwaDCAQCwt9AIACv1xuxzOVyIRAIoLm5OWw7YhEQSsvShRbvH1pEy8dZDfdqEgEEkQH4qDmZEbPcXzl4nwipwXW5XDCZTMLUvdwY2my2QQ14OqttLBZLzOs+ceIEfD4fxo4dKyxjjIUJBfGDL5cTFPzh8/kAAI2NjQCgKBbkBIV0ubiPCDGAVpMO9QKJAEK38FKdRA2w3+9HX18f9u/fj2AwKCznxll644t1xMzd43zGP/FyOeMcK42NjTAajWGT2uQCBoMhqVH98ePHYTAYMGrUKDDGFMUCX84FhdznOIwxuFwu7Ny5M2FRoeURLhE72f6dSQTIwF3q2f5xEiEXwgFyhpk/H2z5YKNm6eyABoNB0RDz5/y1xWIJ+0wwGITb7ca4ceMyNmom0ovBYIDFYoHFYklqPYFAALt378bs2bOjigqxoJB+Too0bBKPqBjsfNTq/U6r250I6bqvkwggYkKcBCY1sLEYYKW/PNYsHjmJ3dlKI2DxX4vFEtPoOtU3C6/XC7PZjLy8vJSul8gNUiUoAAjXzKlTp9DZ2YkRI0aEiQe/3w+Px6MYDpFul1xehMvlwrFjx6IKi3i9T0TqoY6BGUBLo2mpYXa73fD5fOjq6krYzR0t1hyrO1scd472lzfJYIxh9+7dmD9/fiYPH0FoAn6tWK1WWK1WFBcXJ7wufq2LxYLH40FnZydMJpOioOCiQgwPxUTzSvT29sLv9wvt2FMtKEiUJAeJgCQxeNtgcB8Dc4wBsw0BkLrSKam7m68bkO84xV3UfM5xuThzrIaZLqzBoWOUebQiztUMv8bFHgqPxwO73Y7Kysq41iUnKMQeCL/fL0xv7vf7YxIUseZPmEwm+Hw+GI1GXYUFUo2uRECshtnn86GxsVExo5s/L+t7C6d1PYyQwQwjC+Bg4f/FKcdiwZ09mKHl7m5x6ZTUDS5eHktryZ6eHpw4cQKTJk3KwBFNHVq9gMkoEUpo9ZyOBzlBISUYDMLpdGL48OFR1xUKhWTzJ8SCwu12hy3v7e1FKBTCiRMnwtYVTVAMJjL0FvLICRHwwx/+EPX19XC73XC5XGhoaMC8efMAAL/73e9gs9nAGIvZMAMIK6WSftZkMsEU6EDxtv8HA7wwMS8AYFrfb9C/YI3gEcgWZJgIIruk6xrM5REvD3fEg7iyQwwXFEqiQiooxJ8Teyj6+vqwY8eOuMpExcu0ICgyLgI2bdqEH/zgBwgGg1izZg1qamrC3vd6vbj++uvx8ccfo6ysDC+++GJYTbAct99+O0wmE/Ly8uBwOLBw4UK88847CU8H3NbWhmHDhkVVt0b3CcBoAUJu0ULLQGggiyJA7SccQagRum5yC3H+RDJ88MEHOOOMMxQFBe8zoRQOiRbyMJvN8Hg8OHToUEyiIl3naEZFQDAYxO23347NmzejsrIS8+fPx4oVK1BdXS185qmnnkJJSQkOHz6M9evX40c/+hFefPHFqOsdP3582GuTyYRQKJSwCIjlYDPHGCDkD18Y8g8sJwhCM5DnTNsehnRvd6oEBRDpoejs7ERJSUlYySjviiknKMaMGYNx48alYK++JqMiYOfOnZgwYYKwE6tWrcLGjRvDRMDGjRtx3333AQBWrlyJO+64I+4T1Gg0pmXKRTHMNgSeWb+Hfe/t//YI+OGZ9fushwIAuqkRBKEeqGPg10gFhdlsRnl5eUz/mxN9ApqamsJiN5WVlfjoo48UP2M2m1FUVIT29nYMGRK7cU1WBMRaIhgYuRL9QxZFVAdkE62qea2ipZsQnRuZhY43oQVyIjFQSiY8ARxmG6IK409kHrrJE0poLTEw3aN1La5bLwxec5ZCRo4ciYaGBuF1Y2MjRo4cqfiZQCCA7u5ulJWVxfU9mfIEqBUtbztBEASROTIqAubPn4+6ujocPXoUPp8P69evx4oVK8I+s2LFCqxbtw4A8PLLL2Px4sVxK71MegLUBqliItehc5wQQ+dDcmQ0HGA2m/Hoo49i+fLlCAaD+M53voOpU6fi3nvvxbx587BixQrcdNNNuO666zBhwgSUlpZi/fr1CX1XMqNhrXsCCILIXbRo9CgxUL1kPCfgoosuwkUXXRS27Oc//7nw3G6346WXXkrqO/TsCQDowiCU0fq5kY7t19Ix0VquAV83oV4yGg7IFHrOCdDiKIEgsk06rhu6FjMDHefkIBFAEASRYrQ6iEgH6TwWdJyTh0SAAlo+ubS87VqDjjWRC6T7PE7naJ08AclBIkAGLZ9UWt52rUHHmsgG6TrvtHg+kwhPHhIBBEEQGkGrRk+LAkMv5KQISDaxT8uJgYB2bxQEkUuQ4RtAy6EGPZCTIkDPngC6IAgi+2hNiGu1/a7WjrMaIREgg9Y9AQRBxIdWDKAWjTXdS9VNzooAvZ54JGAIglAbNIGQeslZEaDnEkEic9B5knlSfdOn35DQMyQCZCBlScQCnSdErqDl6X7pOkwOEgE5BoUDCILQC3SvSx4SATKQISUIIlnSMUKlGHjmSLcNSGT96fjtc1IEkBEnCCKbaPH+o1VxodXtBtSx7TkrAvTqCdDythMEkR3SPcmPVqcpTqeRVst9OidFgMlk0m1OAEHkMmq5cRLqQasCQy3kpAignACCIOJBDW7ZWNDifYk8AfKoJb8jJ0WAno24nvc909CxJpRI5w1ea+vVKpm4ttVwzHNSBJAngCAiUcMNR43Qta7tY6DVHgRqOeYkAgiCIIi0osVwAHkCNEwqRvJqUWnxQl4MgiASQYuGWsuo5bjkpAigtsEEQeQi6co1UItBihettyRWg63JWREQDAazvRkEQRC6Ry1Z8PGixo6B6SBnRYBeEwO1vO1E+qFzQ550GCktGj4tQp6A5MhZEUA3OyIT0HlGyKHF80INBiletJwYqJa5A8wpX6MK0LMngMgcWrxpphPGGEKhEILBIAKBgOxfuWVGoxEWiwUWiwVWq1V4Ll3Gj3eqj7uWrvV0bauWm+6kEz00CyIRkGOQgCHigTGmaJxjMeahUCjsnDOZTMLDbDZH/LVarXA4HGHLzGYzAoEA/H4/fD4f/H4/XC5X2Gu/3w8A8Pl8MBgMaGlpURQO4tdms1kVN9pUorX90arA0Mt9NGdFQDI/IBlSQs3w0Xa8htvlciEYDKK5uRnA1yORwQy3xWJRfM9oTD6iaLVaY/7s8ePHAQDDhg0TxAEXCl6vF319fWHCIRAICP8r9jiIxUJvby9CoRDy8vKE90wmk+aMrR7RqsDI1PpjISdFQLKzCBJEqgmFQnG5yMXvBYNBwWDzv9wQKxlnm80Wsay1tRUAMGrUqCwfjeQwGAyw2Wyw2Wxx/V8wGIwQDvzR09MDj8cjvBZXF5lMpkFDFfx5KkRRNqD+/pGoMScgHeSkCNB7OIBIHh7fHsxwe71eHDp0SNZwAwiLY0cz3FarVfG9VI1K9T67Jj+Wdrs9bLnP54PT6cTw4cMj/oeHS+SEQ39/Pzo7O8OEBb+x8//Zu3dvVOHAH1oVD7GiVUOdTignII1QYqA+4TfseEbc4ufic8ZgMMBoNEY13Hy0XV5eHvGe0WhUxQVOJAcXb2azGQ6HI+b/6+3txeHDhzFx4sQw4eDz+eB2u8OW+f1+4X7Dv08pz8HlcsFiscDv9+dkvoOaUIuR5qTLJpEIILKKNJu8q6srLsMNIOwGqjSS5s/z8vIU30tkNNbQ0ICSkpKUHhNC+3AR6XQ64/o/7n0Sex18Pp+Q79DV1YVQKIT29vawfAeDwRA1QVK8LBv5Dlqu5U8natj2nBUBlBiYHhItAxM/Fx9fo9EoGGKfz4dTp06FGWez2Qy73a5ouNVwERHaRy3nkdFohNVqVUyWPHbsGEwmEyorK8OWi/MdpF6Hnp6esGVy+Q78+jxy5IiikDCZTAntk1Zr+dPtCVCLjclZEUCegK+JVgYWiwFXKgNTGnFbrVbFEXc0N/muXbswadKkTB4agsgJlPIdoiHOd2htbUVHRwccDoeQ7yDNgxDfU3nViFKCpPg9Qp5ERAY1C4oRk8mkeU+AdLQdj+Hu7+/Hzp07hX0BBjfc4trtdJSBEYRaSde1rvaJfsT5Dnl5eXC73aioqIhpG3hfB6lQ8Hg8sgmUe/bsibkpFH/Ecvy0PoGQGshJEZCNEkE5N3k8hjsUCoXFtgFEjW3zMjC59z755BOcfvrpGd1/giC+Jp2DiGyLC4PBENcof8+ePZgyZQrsdrtiiabL5YpYJv0+OeHg9XrR29srCIxUJktmokRQDSJD1yJAzk0eDAbR398Pl8sVk+EWI84mlzPO0m5p6SgD4/tPEAQRD5lojMPzHeJJmAyFQrLCwev1wuv1oqWlBSdPnlRsDjVYwiTv76DX+2ZOiIBDhw5h//796OnpQW9vL7Zv3w673Y4333wT559/PqqrqwXDDYRnk8sZbq/XKyjKaElpej5xCCJb0DWnLZId8RqNRsXmUN3d3Zg4caKsqJDr7+Dz+YR8B/FDmizJEzP7+vpw5MgRxfBFsqFSNZzLOSECGhoacPDgQRQUFKCwsBBDhgxBRUUFzjnnHEycODGsjjuWH62xsRFGoxEjRozIwNYTBEHEjhoMhxZIJlnS5/Ohp6cHx48fh8PhgM/nC+soKW0OBSCmplBWq1XIs8p23hknayKgo6MDV199Nerr6zF27Fhs2LAhot567969uO2229DT0wOTyYSf/vSnuPrqqyPWtWTJEixZskR43draiqKiorBlBEEQSmjFsKZzFkGtHAMpqdxucbJkMBiE3W6POVlS6l3gQkE6GVYgEAgTG7t3746p0iJdCdpZEwG1tbVYsmQJampqUFtbi9raWjz44INhn8nLy8MzzzyDiRMn4sSJE5g7dy6WL1+O4uLiqOtWk8oiCIIg0oNa7vPifIdY6e7uxvHjxzFp0qQI4cCbQ0nFw/z581Nedpk1EbBx40Zs27YNALB69WosWrQoQgSIa8ZHjBiBoUOHorW1Ne0iQA0lggRBZAYtlQhqEfIyKBMt30FKKBSC2Zx6k521AvCWlhbBzTJ8+HC0tLRE/fzOnTvh8/kwfvz4QddNzYIIIhKt3ojFaEWca2U7tY6WZz9UyzmSVk+AwWDYMnXq1Ijla9eulX4u6g/Z3NyM6667DuvWrYspLpJsnwCaipggCLWSrj4B6TSmWhWg6W4brIbjklYRwBhbCkBW7gwbNgzNzc2oqKhAc3Mzhg4dKruOnp4eXHzxxVi7di0WLFgQ0/cajcawkg+CIIhcQC2jRzWhVU+AWshaOGDFihVYt24dAGDdunW49NJLIz7j8/lw+eWX4/rrr8fKlStjXjflBGgXOu4EQcSK1u8XavAEZE0E1NTUYPPmzZg4cSK2bNmCmpoaAMDu3buxZs0aAMCGDRvw3nvv4emnn8asWbMwa9Ys7N27d9B1U04AQRDZRg03+FihHvyR0CyCaaasrAxbt26NWD5v3jw8+eSTAIBrr70W1157bdzrJhFAEPKo5caT61A9/9doebpfPeQE5OT0cCaTKenEQLpZZh467gRBqAW93ItyUgRQsyCCIOJBDSOyXEXLo/V0Qp6ANJKKEkESEQRB6AW1GKR4Sfd9WovHJF5yUgRQTgBBELFCgp+QIxPNgtQgMnJWBFCJIEEQ2URrTX3SiVbDAVo81vGSsyKAPAHag8QXEQtauDFr7TzWavtdra6brz/eY56O34hEgAxkjAhCndB1SUghT0BykAggCIIg0gZ5GZRRg8jIWRFAOQEEQeQaWs0JICJRi43JSREAqOcAE7FD4ovIJbRkrLUsLrQ6+6FajnlOigAKBxAEESvpuBmTmA1Hi+EAvZCTIoDaBhOEdqBrLbfRakMfNXoCqDogRsgTQBAEETtaFWJa3W41QSJABvIEZAc67gQRnXSOTqnULhK1eQLSAYkAgiAIQrNQvkFy5KwIoBJBgiCI3Ear+QYAeQLSCnkCCILINmq4wceKWgxSIpAnIDlyUgTQSJ4gcpd03PS1UiJI97XcQS3CKydFACUGahM67ulFDTccInnod8wMajHS6YZEgAy58MOTMSWI2KBrhY5BNlCLyCARoABdFARB6Ak1GCQ1oRYjnW7M2d6AdECJgdpEDxdcrhMKhRAIBISH3++PeC5eFggEYDAYYLVaYbPZhL/S52azmc4PIqdQi8jIWRGg5xJBvv1qOMHiRcvHPVfghnwwA86fB4PBsP83m82wWCwwm81hz/Py8iKW8UcgEIDX64XX64XP54Pb7UZXVxd8Ph+8Xi8CgQAAwOfzwWKxoKOjQ1E0mM3Zv62l6/rT6nWtVfRwrLN/taQB8gQQeicYDEYYa25U5Qy72JAbjcYIY83/Op3OiOUmkympm6XRaBQM+WB89dVXMJlMKCkpEURDf38/Ojo6BAHB94WvV8m7YLVaYTKZEt7uXIIxBqMxJ6PDCZPuAYlajnlOigCDwUDVAYSmYYwhFAoputDllksNudSAB4NBGI1G5OfnR4zGkzXkmcJoNMJqtaKoqGjQzwaDwTDvgtfrRU9Pj/Dc6/WCMQaPx4P29nY4nc4woSAVDGq4YRNEqslJEZBsOEDraFXEaMEIxQNjDMFgMCYDzp+HQiHhOIgNuXRk7nA4IpYZjcaox/DkyZPw+XwoLy/P1CHIKiaTCXl5ecjLy4v6uc8//xxlZWVwOp1hgkEcjvD5fMI1ZTabFT0L/G+60OJ1rVXUOItgOshZEUCeAG2ituPOGItqwL1eL7744ouwzzDGwgyGnGvdarUiLy8vInZOo83swEMdTqcz6ucYY/D7/WHeBJ/Ph76+PuG5OOTS19cXNRxhsVhUYQjUdt0RmYNEAJHzcEMebQQufc5vigaDASaTKcK1zkeDJpMJFRUVYcvJkOcuvJLBarUiPz9f8XPt7e1obW1FVVVVmGDgIQkuGPx+f9h6o+Uw8PwFLc4iqEXIE6Bh9C4CctGTES1jXe55MBgMu8jkstItFgscDodsJnusF2dDQ0NM8WlCX/BzjxvwgoKCqJ8PhUJhoQee8NjZ2SmIh2AwCI/Hg7a2toj8BSXBQBCDkbMiQM8lgmpFnLEuNzLv6+tDXV2dMHLniW48i1bJkPPSM2n8XA0qmyBiwWg0wm63w263R/3c559/jvLy8oj8hd7e3jCPAx8EmUymqOEIm81GnisFyBOgYfTuCUgXPGM9Hte6Usa61Gjb7XbYbDZUVFQI2etayVgniEzBGIPJZILD4YDD4Rj084FAICJ/obu7O0xAMMbg9XphNpvR2tqqKBioQiI3IREgg9Y9AdG2n2esx+NaFx9Lk8mkWENut9sjlg2WsS7m5MmTcDqdg46GCIKIDX6tDlYhceTIEVgsFpSUlISJBpfLFSYYOBaLJWo4Qi0Jj8lCngCNkmyfALWjlLHOn7vdbtTV1YW1cBVnrCsluvGMdbkacoIgcheeABst2ZHDKyTE4oCHJPhznvAIAC6XC5999pnmWkKrcSCYjuOUkyJACzkB0oz1aL3V+WuljHWx0eYX1bBhw8JG5uTGI3KFdNwIU71ONRqQVCGukBiMUCiEDz74AGPGjBm0JbS4QkINLaEzYQPUIH5yUgSYTKaMeALEI+1YOrvxjHVg4IRXqiHnjWCkrVljNeQnT55EQUFBWpuWpAOth2EIQowabvCxki6DZDQaYTQaUVhYOOhnxRUSXDDwltB8ubQltNvtxuHDh2UFQyo8mFr6DRMlJ0VAPDkB4tas3Fi7XC643W4cPXpUcdYzftHIxcajTZaih5OKILSEloSnWkaP6SDWCgng65bQu3fvRkFBgRCOaGtrEwRDKBQCY0zwkEbzMigNsCgnQCMEg0G0tLSgs7MTnZ2d+OKLL9Db24v7778fxcXFWLp0aUQNOYeXnokNNcfpdEa43CljnSAIIrvwltA89KkET4SW5i/wCgmlltBWqxX9/f1CHxGxYMi1+39OiICmpib8n//zf1BSUoLi4mIYjUb4fD4UFRWhqqoK5eXlYaP1wTLWeaOOoUOHZnAvUge51Ylchc7r9KCWUWmqEYddY2kJLZ7SurGxEYFAICwc4fP5hM9LxYH0+WAVEvEe83T9PlkVAR0dHbj66qtRX1+PsWPHYsOGDSgpKZH9bE9PD6qrq3HZZZfh0UcfDXtv9OjReP3114XXjY2NWLNmDW6//faEt41uNpmHxAuRS+SiUc1lDAYDLBYLLBYL8vPz0dPTA7vdjoqKiojPiisklGaplLaElraFdrvdcDgc8Pv9MYWK03VvHFQEGAwGBuA5xti1/35tBtAM4CPG2CXJfHltbS2WLFmCmpoa1NbWora2Fg8++KDsZ++55x4sXLgwpvXmeokgQRD6JFdH7GokmtEVG/ZYW0KLwxFutxv9/f3weDxobm4Oq5CIlr9gs9lSuo9AbJ6AfgDTDAaDgzHmBrAMQFMqvnzjxo3Ytm0bAGD16tVYtGiRrAj4+OOP0dLSggsuuAC7d+8edL3ULEjb208QWoeuP+2TKsGllPDo9/tRVlaGIUOGCMtCoVCEd4FXSFgslrTMUxJrOOBNABcDeBnAtwG8AODcZL+8paVFcLUMHz4cLS0tEZ8JhUL4v//3/+LZZ5/Fli1bYlpvsn0CCIIg9AR5GDKP3DE3Go2KLaHT5d2OVQSsB3CvwWB4HcAMAH9CjCJg6dKlOHnyZMTytWvXhr02GAyyJ+Fjjz2Giy66CJWVlTFuKnkCAO2ORLS63VqAbvLK0LEh5NDDeRGTCGCM7TMYDGMx4AV4M54viDZ6HzZsGJqbm1FRUYHm5mbZbPwdO3Zg+/bteOyxx9DX1wefz4f8/HzU1tYqrlfvEwhp9cTV6nYTBJF7UMfASP4G4GEAiwCUpeLLV6xYgXXr1qGmpgbr1q3DpZdeGvGZ5557Tnj+9NNPY/fu3VEFADBQQ6r2tsEEQRDxki7DoRaDpDb0cEziaSj/JwD/zRj7LFVfXlNTg82bN2PixInYsmULampqAAC7d+/GmjVrEl6v3j0BALnVidxFK33+9WBAchnyBEhgjDUCeCSVX15WVoatW7dGLJ83bx6efPLJiOU33HADbrjhhkHXq/cSQTWcWAShZ0iEE1phUBHAGIuYW5Ixtg3AtjRsT0qgxEBtQsc9/dDxJYjYSPdIXS2egJycX5bCAQRB5CKUE0CkmpwVAXpODNT69hOEEhS/JzIFeQI0DHkCCILINmq4wRPEYOSsCNCzJ0Cr0HEncgWtncda295MQZ4AjaJ3Y6L3/SeIeKBrZQA1GCQ1oZfzIidFQLLQxUAQhBpRy+hRDWjdSCfyW6bjt89ZEaD1E0SP0M2NIAi1oBfBlZMiQA8/XDS0HA7Q6nYThJbRqsHT4jZz1HLMc1IEEARBZBs13OCzTTpFvV7a+qYbEgEEQRAagTxluYNaREbOigA1HNxsoeVwAEFkA61MSgSk596mte3NxLozsX41kLMigNAeerjgCEKtaE1cZCIckO71q+GeRyIgB1HDiZUo5MFIH1o+LwhCDvIEJE/OigC9GxO97z+Ru2jFda8HA5JNyBOQGnJWBBAEQeQaWptFUC2GjlCGREAOotWLjhIaiVyBzuPMoOXe/moRSCQCchS6CRFqhzEGn88Hn89H52sOky5DR+dMajBnewPShRoUFkGojXTeOIPBIPx+P3w+H/x+v/AQv/b5fAgGgwAGrlGz2QyDwYBAIAAAsFgssNvtsg+z2Uzxe42RbkOt5ZG6WjwBOSkC+IFVy0HONORWJ5KFMRZmyOWMOX/OzzWTyQSLxQKLxQKr1So8z8vLE55bLBaYTKaw69JisQjnrN/vh8fjER6dnZ3C80AgAK/XC6vVilOnToUJBIfDIQgFIjG0dq/MhXucGo45XTGEaiDxkj6CwSB8Ph+8Xi/a29tjHqWLjbnVag0z6FarFWazGUZjaqKKBoMBVqsVVqsVhYWFsp+pq6uDw+FAYWEhPB4P3G43Ojo6BKHAt99qtUb1KGiVdCbwpQs1GLpEyIQnQA1o92ogCJ3CGEMgEFAcmSuN0kOhEADAbDYLhtzhcIQZeukoXW0YDAZYLBYUFhYqCgWeayD2KLS3t0cIBZvNBrvdjp6eHpw6dQo+n08QCiaTKSXbqne0HA7QCzkrAtSisrIBjai1BY+lRzPmfr9fiJvLjdKlbne5UfqpU6fgcrkwduzYLO1pZjAYDLDZbLDZbCgqKpL9DGMMXq8XHo8HfX19CAQCaG1tFYQCF0xcKPCQg81mE0IP0TwgWrz+tGZQqU9AashZEUAQ2WCwUbr4tVwsXRxP19ooXUsYDIYw4z5ixAgUFBSEfSYUCsHn88HtdsPr9cLtdqO7u1sQCvwmLhYK/OHz+dKy3VoLB6Tb0Gm9Y6AarmcSAQQRBaVROn/tdruxZ8+eiFF6tOS4VMfSifRgNBoFo65EKBQSPAr80d3djc7OTvh8PjQ3N4cJDunDZrPReZAgWvS2iFHL9pMIyEG0Gg5I93bLjdKVjDvfDqPRGJEcJx6ld3d3Y8aMGTRK1ylGoxEOhwMOhyNseVNTE/x+P8aOHYtQKBQmEtxut1D14PV6hdGyXLUDFwp0bmUetbjr003OigA9/Hh6RzxKj+Z2j2eUzh+xjs6MRqOms821iNaubaPRiLy8POTl5Sl+JhgMCiEHj8eD/v5+IZnR6/UK63G73Th8+DDy8/MjPArJHpd0HVcthwPSSTwigw9K0rG/dPciVAFjTLgRdnV1KRp2v98vJG1FG6WLX9Moncg08Y4iTSZTTEJh9+7dKCsrQygUkhUKJpNJMfRgtVoVtymdOQHpIhcS99RwXyIRkIOoIRwQzyidXwh+vx99fX3Iz89PySidIGJFDTfjwTCZTDCZTCgtLYXNZpP9TCAQCAs99Pb2ClUPPFlRLBR42EGcrKqFY8HR0rZKyfY9mpOzIkAtBzgX4LF0qQGXG6WL3VbxjtKPHDmCwsJCDBkyJJu7S6gYuq6jYzabkZ+fj/z8fMXPcKHAQw/d3d3o7+9HXV1dWC8JJY8C7/AYC+kUFbngCVADOSsCCGV46VM8o3S5WLrD4UBRURGN0glNozdhIScU3G43qqqqUFBQIIh+acXDyZMn4fV64ff7AQw+z4MeDGgyqEVkkAjQOHKj9L6+PiEDOZZYOjfufJTOX1MsPTbUcjETRCrgXRktFktE7wROLPM8AAOhB7fbLbR7TnX7Zj3E7NMNiQCVEQqForrco2W8c+PNGIPVakVZWVmYsadROkFkjnQ19VGDYYplngfGGHp7e/H555+jqKgIbrdbtn1zovM8aL1jIBDfOZKu3z1nRYDRaMz6BaMUS5cz7uJRutTtLo6lxzJKP3r0KPLz81FaWprJ3U0aNSQ0EoReSfW9UuxRGDp0qOxnpPM8cKHA8xXk2jfzB2OM5iZIATktAkKhUEpHv9JRutJIXWmUzg243W5HQUFB2kbpZEwJIrto7frL1vbGO8+DuOqhr68P3d3d+OCDDwBAmNdBPL8DfyRyf9Xab5goOS8ClIg2Svf7/XC73fj0009lR+lyCXIUSycIgggnFd5YcTdFMX19ffjqq68wc+bMsHkexMmMsczzkIxQyAVyRgT4fD60tbWhra0Nra2t8Pl8ePjhh9HZ2YkbbrhBcDuJR+kmkymijI2P0tva2jB58mRYrVbdnhwEQRBqhguMROd56OrqEpZJ2ze7XC6cOnUKTqczp+d5yBkR8N3vfhdtbW0oLy/HkCFD4PF44HA4MG7cOAwbNkxoOhNr6YrJZNJsz24KB2QOfqy1cJ5oYRuzgVZ+PyC9swhq5Rhw4r3HKc3zIEY8z0NbWxvcbjd6enrC5nkwGo2CR0EadtCizciqCOjo6MDVV1+N+vp6jB07Fhs2bEBJSUnE544fP441a9agoaEBBoMBb775ZsSc6E8//XTY6w8++AA333xz1KYZ0dDSzT1XIPFC5Ap0Hn+Nlu6h4nkerFYrqqqqIioUgsFgmDdBaZ4HabiB5yuoTShkVQTU1tZiyZIlqKmpQW1tLWpra/Hggw9GfO7666/HT3/6Uyxbtgx9fX0xuWQGywnIdegmRBDZRU03+myRi9n7JpMJTqcTTqdT8TNyQqGtrS2sfXN/fz8+/fTTuOd5SDVZFQEbN27Etm3bAACrV6/GokWLIkTAwYMHEQgEsGzZMgCIeWSf7KhSy6NSuvkQBBEvWrtvqK2OX0wsQuH999/H+PHjB53ngXsQhg8fHjXnIVGyKgJaWlpQUVEBABg+fDhaWloiPnPo0CEUFxfjiiuuwNGjR7F06VLU1tbCZDJFXbfePQEEQeQe6cwJSAda9gRkYttjmefB7XbD7XanbcrytIuApUuX4uTJkxHL165dG/baYDDI/qCBQADbt2/HJ598gtGjR+Pqq6/G008/jZtuuinq9yYrArTsCdAqdMzTTy4cX62NWPWOVicQArJ/rpnNZhQUFCSc2xbTd6Rtzf9my5Ytiu8NGzYMzc3NqKioQHNzs2xXqcrKSsyaNQvjxo0DAFx22WX48MMP0y4CtAwZU4LIPtk2IERy6OUemtWixxUrVmDdunUAgHXr1uHSSy+N+Mz8+fPR1dWF1tZWAMDbb7+N6urqQddtMBh0KwKIzEGCKzcgg52+Y5DOY0u/W/JkVQTU1NRg8+bNmDhxIrZs2YKamhoAwO7du7FmzRoAA4kRDz/8MJYsWYLp06eDMYabb7550HVTOEB70DEnBkMr54dWtpOjxZyATEwgpAeRkdXEwLKyMmzdujVi+bx58/Dkk08Kr5ctW4Z9+/bFtW4KB2jrJkQQxODoxTDFCh2L5Mm9Hoj/hs8imChkSAlCH9B1PoDWwgF6SAzMBDktAvTqCSAIgogHLYYDiNRAIkABLXsCtLztWt1ugiAyjx5G6umGRAChGuiCJnIFmujna7QcDtADOSsCUtE2mCAIQi9oqRMhkTpyVgSkwhOg1RNYy+EArUHHmsgFtHgOa9Erkgzp2lcSAQrQzZ0g9IOejEmmoWOrbnJaBJAR1xYkvAgie2gxHEACI3lyWgToNTGQjClBZB8tJQZq8X6hxW1WIzkrApKdO4AMKUHog3Rc53TvGEBvcXstkrMiwGQy6dYTQBC5ChkVgkPnQmrIWRGg58RArW67VrebIDKJ1tr7EuomZ0UATSVMZAISLkQukM5zmKYSjkRN94ycFgE0gRBBELGgVWOidrQ8lbBeyOpUwumEqgPoAiHCybahC4VC8Pv98Hq98Pl8wsNkMiEvLw95eXlwOBywWCxZ39ZUoLV90Nr2ah21HO+cFgFkCLUH/WbagjGGQCAAn88XYdz5skAgICRxWa1WWK1W2Gw2WK1W5OXlwWg0wuVyob29HW63Gz6fDwaDAQ6HAw6HQxAHDoeDzo80odVZBNViSONFTedxTosASgzUFlrd7lwkGAxGGHOpgQ+FQjAYDDCbzRHGPT8/X1g22Mhe7v1QKASPxwO32w2Xy4WOjg643W50dnaipaUFdrtdEAhikWCz2eI2DFQimF5oAiF1k9MiIBgMZnszCEI18FF7b2+vonEPBAIABkpsuRHnj8LCwrDXRmP6UoqMRqNg4MvKyoTlX375JcrKylBcXAyXyyWIhK6uLrhcLvh8PgCAzWaTFQlmc87e8nSJlj0B8W57uvY1Z68IPXsCCP3AGEMwGFR0xft8Pvj9fuFzABAIBARD7nA4UFRUJIzgTSaTJm6sZrMZhYWFKCwsjHiPMQav1yuIhO7ubpw8eRIulwvBYBAmkyks1ODz+eDxeBLyIuQSWis91PL9WU09DnJWBOjZiOt53zNNui7kUCgU1RXv9XoFdzwftXNDzmPtfBl3t7e1taGnpwfjxo1LyzarBYPBALvdDrvdLvt+MBgUPAg8B6Gurk4QS/z4ifMR8vLyYLFY4t4OraDVnAAieXJWBJAnQHto9ZjHus2MMfj9/qjG3e/3w2AwhCXRcWMujrPzUTsRPyaTCfn5+cjPzwcAtLW1YerUqbDb7WCMwefzCSKhv78fra2tcLvd8Pv9MBqNsNvtESLB4XCkNTxCyKMloaVWSAQQRJIEg0EhHq1k4Ln7z2KxRBh3cazdbDbTjS2LGAwG2Gw22Gw2FBcXR7wfCoXgdrsFkdDe3g6XywWPx4NQKASLxQKHwwGPxwOv1yskMFqtVtX/rlqbmEiLAwYOhQMyQLIlgmr5gRJBqyNqNaFU0y428NytfODAAdjt9jDjLo6zWywWGiWmkHRcm7Gu02g0wul0wul0yr7v9/vhcrlw9OhR+Hw+NDU1CQKRhymkYQaHw5F1r45WOwZqFRIBGSAVngAypLlFPDXtRqNRGLWLa9qLi4vDRu179+5FdXU1rFZrtnePUAEWiwVFRUUoKCiA0+nE8OHDhfcYY/B4PEIuQldXF5qbm+F2u4WERblcBL0nLCqhJkOqZUgEKECj6cyT6DHPZE07QSSKuAGSHIFAICzU0N3dDbfbDa/XC8YYbDYb3G43jh49GiYS1F72SNeTPPEcl3TaInWfPUmg55yAXBAwPEErmnEPBAIwGAwwGo1Zq2mnG1xmyeXGPmazGQUFBSgoKIh4j5c97ty5EzabDb29vWhpaYHb7UYgEIDRaAwre+QiwW63x3zuay0nANDu9aeWcw4gEUBkkMFq2nt7exEIBHDy5MmI7Hgt17QT+iSV5ybPJzCbzRgxYkTE+zw/hT94RYPb7RbKHuVEAvd8qckoxYoWt5lDzYIyQLJTCWv1wsgGqapp7+7uRjAYxJgxY7K9S3FB5wkhJdPnhLTsUbotfr8/rDeCdJ4Gl8uFL7/8MqLsMRUJiyTU1U3OigA9TyCUCgGTjZr2/v5+avVMEClGfH0WFRVFvB8KhfDBBx+gvLwcLpcLnZ2daGpqgtvtRigUgtlslq1oiCVhMd0lgloWGGrZdhIBCuSqJ4Bnx0eLtXMyXdOulouC0B96PveMRiOMRiPKysrC5mngBAKBsHkauru7FedpEP9Ve8JiNlGTbcnZX8lkMukmJ0Ba097Z2Ymenh4cOnRIWMaPhdFoDHPFU007QRDRiGeehp6eHrS0tAjzNASDQSE/SywS7HZ7SoSXVsWbmrwYOSsCtJ4TEGtNO99WcU07YwxmsxlDhw4NG7UTBJE51HKTTyeDzdNw4sQJdHd3o7i4GG63G6dOnYLb7YbH40l6ngY1jaa1TM5aBrVWB8RS085P7kRr2js7O9HW1ibb9lTNZFt4JYIebvS5Ti6XHWYbXr47dOjQiPfk5mloa2uDy+XK+jwN6f79yBOQATIpArRS004QBJFplIxdLPM08A6LcvM0BINBWK1W+P3+MJGghXka1ETOioBkwwHAQEJMf3//oPO0q62mXYsjaoIgco9k7kNGo1HoaSDH0aNH4ff74XQ64Xa70dnZKTtPg7Q3QiyVSukeqavp/pyzIkDJExBLTTtPdrFYLHA6nYPO007oGzVd0AShF0wmE8xmc9j8DBzpPA3d3d2K8zSIRUIm52lQi+3IGRHQ29uLY8eOobm5GSdPnsS7776LUCiEV199Feeffz5mzZoFABHueKWa9vr6euTl5cnGsoj0QB4Mgsgt0jmi5hN9yRHvPA28ooEPAq1Wa1rnaaCcgH/T0dGBq6++GvX19Rg7diw2bNiAkpKSiM/dfffdeOONNxAKhbBs2TL87ne/iziAmzdvxsaNGzF8+HAMHz4cJSUlGDZsGFasWIGqqioUFRWp5qCnGzKmRK6ipfNaL/cbLTLYPA1utxt79uwR5mk4deoUXC5XyuZpUBNZFQG1tbVYsmQJampqUFtbi9raWjz44INhn/nggw/w/vvvY9++fQCAc845B++++y4WLVoU9rkrrrgCV1xxhfD6d7/7HUwmE2bPnp3QtpEhJXKNXDFK6diPXDk2eiJdo2me42WxWGTnaQiFQmEtmOOdp0H8PWogqyJg48aN2LZtGwBg9erVWLRoUYQIMBgM8Hg8Qumc3+/HsGHDBl23WksECYKAcG3ynhactN4Yva0w9B8Dc44BbOXp+x5oy2ORbtRi7FKF0WiE0+mE0+mMeC+WeRp4iaPL5UJra2tK52lIhKyKgJaWFlRUVAAAhg8fjpaWlojPnHnmmTjvvPNQUVEBxhjuuOMOTJkyZdB1G43GsBa48aJlT4BWt12L263FbU4nYuPOjwufPIojHcHxmnAAwlwU0uf8daIYG16E+eNbAYMFYH4E5j6B0KirEl4fERt6uzZimafB4/Ggra0NHo8n5nkaYmmelChpFwFLly7FyZMnI5avXbs27LX0guccPnwYn3/+ORobGwEAy5Ytw/bt23HuuedG/V49TyBEEKlGbNz5X74sWh04nzmS98gQf14aPxWLBv46EAjA6/UKlTzd3d0YMmRIhLCIKhC8rTB/fCsMQTcANwDA/PEt8A09L+0eASJ9pDvpMB3r5mWPRUVF6OnpwaRJk8Le5wmLvDdCd3e30GHxrLPOSosYSLsI2LJli+J7w4YNQ3NzMyoqKtDc3Cybif/qq69iwYIFwhSZF154IXbs2DGoCNB622CCyARKxj3aDZAbd+7G56+VjLscwWBQyMYWPzweD7xerzCbpNlsFhrK2Gw2VFZWoqCgIGK2yWgeBGP/sQEPwL8FwMCHLAOhAVs5XedphI6tPEoiQylhMRQKpS1ckNVwwIoVK7Bu3TrU1NRg3bp1uPTSSyM+M3r0aPzv//4vfvzjH4MxhnfffRd33nnnoOvWsyeABAwhFsDcNR8MBtHb24u2traoiUp85J6IcefuTqlxF4/m+brExp2X6trtdthstrhKsaQeBCkG20hYmF/yT36E8kYjt6LV6kSLOQFqKuFLN1kVATU1Nbjqqqvw1FNPYcyYMdiwYQMAYPfu3Xj88cfx5JNPYuXKlXj77bcxffp0GAwGXHDBBfjmN7856Lr1NIsgoS9iibuL4Ya8sLBQiEe63W4hFs8zmPPy8uB0OmXroXnCUzQDz7dFatyLiooE456OBltiD4AUxhhgK4d35u9h23s7YLQAIT86Jz2M7o4AfL76sAYyqcpB0JMRyRZaPsZq2vasioCysjJs3bo1Yvm8efPw5JNPAhgw5k888UTc6062OoBG05lH78c8Gde8OO6uNHK3Wq2oqqoKWxYMBtHX14eenh50dnaisbERHo9HcLfz9RuNRlgsFmEaWJvNBqfTidLSUsHYZ7tGOhgMhomUcMFSBdOQZ2EPnkTQPgqmwHDYenths9kwefJkGI3GuEIMarmBawEtHis1Gel0kzMdA6XouURQ78ZUbaQi7j5YUp3S9/JW2HKG0e/3C+uy2Wyw2+0oLy8XjLrZbBYMK09Ucrvd6Ovrg9VqFbwGeXl5YIylrVkKb+OtlD/A98NkMoV5IBwOB4qLi4XX8cRUBw0xKAgEvRiOWEnnfUjLhjqRbU/Xvua0CEjmBCRDSgwGNxDBYBDBYDDMPa9EKuLufNZKJaPIe2rwciVuBO12O0pKSoTXibrmeWigv78fLpcrrMwJgDD9q/ih1JOdZ/8rhRn4MZaGGMTGPZMhBvHvK66OCAQC8Pl8Qk+T7u5ulJSUhIk9rRqshPh3Twaj34yguTTbWxM3WhYY8ZLTIkCvngAieeTi7nIG3uFwYP/+/cLkUg6HQ2gkIh4ZxzpClrq0pQ/usrZYLBFJdWVlZcJkV+l0zYtroaVtvvnELf39/ejp6UFHR4cws5u01zsPMdjtdiHE4HA4woRKtkMM4jJF/rtIfx++L1arVdiPiooKFBYWIhQKhZ03evAgiHsyjA36cKrqAWD0bdneLFWhJpGRsyIgFSWCWhURWvViZGK7E02qAxBm0PmyyZMnY9KkSWEjYz5jmcfjAYCwec7NZjOMRiP8fn+YIVFyadtsNhQWFgoj+Wx1FeNIa/flwgxSL8TQoUMFccKrFLxerxBe4HPE5+XlIRgMCjkOVqs1rfsiDpfI5RIEAgEAA2Vb3LjbbDYUFBRgyJAhwuvBbubS81rsQcg5gSDpyWAAMLT+x/BXr0x5T4aYDWkaOkV2d3fjG9/4Bt59913ZpkBaImdFgJ5LBPVIJprZyMFd49xoMMYEA8Zj2X19fejt7RVu+nx0yBPtSkpKkJ+fL5TIZWv0y42idKQrZxTFIQa+D8mM3nnfAP5obW2Fy+USuqhJqxd469Vo61NOEvQKwo8LFW7kxYmOZrM5ZQZYKalQSSBwpKIrGAyqOsRgkOnJwAxmoSdDpkm4U6SnFfm+zwHvaFnh8Oabb+KLL77AP/7xD6xatSru7SJPQAagcEBuIGfcY4m7J9vMBkDEiFfOkAAIi7tLR4rRXPNy3gNxXJ0bPP430ZGxnEtbvE/iHAKpFyJdRlGKyWRSnNXN7/fD5XKhv78fXV1daGpqgsvlEsr6uIjjXgaj0aiYJMiNfbbDDMDXuR1yYQaPxyOILnHop6qqKuYqhmwYGeYcA0h6MhhYYGB5qr9rMEOaYKdIY8OLKNx9K6qZEaZ/hGSFw7PPPiv8TUQEqImcFQHJupa16lIHtLHtSs1s+vr60N7eLtsvW2zEE02q49+tFHMX33zFhsRutyeVbS6HxWJBcXExiouLw5bzqUy54WtubkZ/fz/8fr8wKpaOiLk3QmrklVzavLzPbrenPYcgVsS/i9woXpwPUVRUJPwG/NwJBAJhn+U5CNyIciGVCeMoty/iv2IByX8XnrgpbpgUbVujeRA4GRcItnIE5j4B88e3AAYL2L9zAkqy4AWQ80qIO0XKwoVDyD1gHIMDwmHjbg82b98rfOxf//oXAGD79u344Q9/KCxfuHAhLrvsskG3jTwBGYA8AdkjmWY2fGpOPne32WwWEu3ECXdKjWHksubFI17g6yQusRvY6XRmZMQbCwbDwExj3O3udDqFRj+8XK+jowOhUCgs5GGxWITExLKyMhQVFQ3qNs8UYgMtNYhST4Q0/i7+XWJFLKRcLhdaWlqEBEWDwRBRvZCXlxdzX3alUAP/O9i+pCq3I1rfglgFAg9ZiRMYkz33Q6Ougm/oeTD0H0NDhwmwl6Nk8H9LOXJeCTB/VK+EknCw+Zvxxz/+URDVHK/Xi8ceewzAgNA+66yzUrX5kdtGJYLxkWzHQC2MpjNNIvXu3AAl2szG7/ejr68PfX19aGlpQX9/v3CjFbuB+brlXPO89j1To8DB4KNEpdi7UgVAtDADz8rn3oOenh40NzfD5/PBZDJFxNTz8vJSYoikLm2lXgQmkylsxJtuT4TY0EsJBoNhAqGzszPM08ITOPnx4b+XWESK90VtFQ3AwP7zBEw5TwQ3/LxHxNChQ8MMXNIeBFs5mK0cgZ56WNJ0zQ06mpZ4JXhOQLRQgJJwWLziO9i1awWuuOIKnDx5UgjbAQMVQsOHD8df//rXmGa4jWnbM0jOigA9ewLiFTCp6lTHlwOJueblSuOkyWjcHS/NNOc3dT7Ss1gsgihI91ScHHGSoFLsHZDvm5/oiJfDvQcOhwNlZWVh7/Gku/7+fvT39+PUqVNCq1zuaRALBJ7xzo+tkntezqVts9lS0osg1UjbHkv/8lwCXhXE6/55siRjLOxY8eOVrUROsTdC/Jc/B8KbQMVafjmYB0EqBrKdgzAYYq9ETNUBXDjsvgVBZoTJGBKEw5Qp5dixYwdGjhwZ9i8+nw8ffvihZqsEclYEpKJEUOuegEST6oDkmtnw7xK75qVGcbCJZBJ1zXP3Jjd44ng6z8bPz88Pu4nHsn4lgyhXvy9XTsZHvNm4UUqT7niioMfjESoX2tra0NDQAJ/PJ+wLr3LgFQAFBQUoLCwU9i/b5YocuaoGsUHk+yMNARUVFWHYsGGw2+0xxd95gqLL5UJXVxdOnDghjAh5zoFYJMRSPigHN/BKggWI9EbwCo1kPSvJhBjkBEK6OwbGxL+9ErESGnUVOp2n48ShDzBx9rIw4fD+++8jLy8PbrdbGM07HA68//77uOiii+LadrWIppwVAbnuCYjWzCYUCqGnpwd1dXVhoxY+KkvWuMvViYtHu0ojRJ7MlU7XvMFgEJrPSEfEPBu/v78fnZ2daGhoEGr5+ahV7AL2+XyyYoXvk5rq9zlKBlHqWRGHGsQJj9yIMMYE7wH/29TUhGAwKDRGEnsQYhVT8SInvsT7Iy71ExvFsrKyhGYkVIJ/h9VqlU3k5MJTXN7o9XqF81HsZeHzFEgFCz/XeEKqOF8lU42goiFX2sjFpNvtDtsX8fwTEydOFM47uftNMudNugwpsw6ByzE1wnPw7LPPoq+vD3PmzMFvf/tb3HnnndizZw+ee+65uESAmshpEaDF6oBUNLNxOp2YP3++cFNqb2/HsWPHEAgEhJ7v+fn5QqIdLz0T35iixaqlmeapqBNPB0rd98TubHHogLuBA4EA/H4/GGNwOBxhx4qLqWwgFl9yRl7cpEf8+3ADEo9nxWAwCL0LxEhbBnd0dAiTDgGIyD1wOp2KRlipE5+cS1s6gk9VhUYq4Iaeh6z4OSNO5Ozt7Q1LvuM5LQ6HA3l5eSgvL0dhYWHU45VJxAZeatzFuR5iz5dSdYOcB0E8QJN6EFIlEJJBaaR++PBh/OQnP8FPfvITmEwmvPfee7j//vvx97//PSXrzwbZP9vShNo8AZluZsPjw/y7uWu+v78fvb29OHXqVIQx5CMQnmHOXcDJxKrTgTjUIGfk5RK4+CMed7Y02U4aWhALAz67XiIXtlK8mj+X6yaYrYQ08YhY2jI4FArB7XaHnWP9/f0IBAJh56+4dE+aLKiGEa8UaZ8FqWHkvw8XAXyfBktKlTZIamxsFKpieOhK+kjVMeEGfrD9Ebd0jid8IibeEIOSQBAPePj/ZtqQ7tq1K+y1yWTCPffcg3vuuSej25FK1HFXTwOZmko4m81sojWB4Q+5iWTEmdncDR4IBNDf34++vj4hu7ytrQ0mkynCc5BorDMW4m3QI75BpXrO+mjJduLQQnt7O44fPy64f/kI2Ol0wuFwwGQyKRp5abya7xMf7drtdtUk1wHKDW6kXQV5uIG3DDabzQiFQoJ3xu12C4JB3CqYC4RMCQDxiFdun6QGkf8mhYWFKC8vT+r3iaVBEvci8Ix0xpgQjhF7XMQCVJxTIN0vcciBG3i73S4Ilkyfb7EIhFAoJLsvnZ2dGDJkiHD+RFuX2iBPQAZINhzAjTl34Unj7nKIjXgycXcgvkQ08Ug30dIrpcY1XBxIjZ3RaAwbCfOWt0onNo+bKrnm0zEdbDrh/Qu4cXA6ncL+8A6A4pkFediBu4qHDh0qdLBTC9JKDalHQm5GP7vdnlRXwXgaI3FRFY9IFldrSEe8UsGSTkEZL7whkjTjPBAIoK+vD93d3ejt7UVLS4sgVriAEnv0eEgn28mpSojvC3LChXspxR4JHn6sqqqCzWYbNEkxEYGgJiOdbnJaBCh5AmKJu5vNZpw8eRK9vb0Rbl8+UknEuMvN8R6LMRQnomXSNW82m2VvRsFgUBAHHR0dOHbsGDwej9ATn4sw8XGV7g93L6qplAyQFyxyte9S9280d7Y0tNDZ2YnGxsaUhxaUUCopk3qMxPvDR7zprAbgnpO8vDwMGTIk7L1AICAcL7nRMG+oxMNlYq+Y3+8XhJd4f8QJkNluCiVFPOKVGkXxLIzi0Ts37nwE7/V6wxI6u7q60NLSAqPRGBbmi7dBUiKIRVi0xEH+e4jDKPx1Ih6hWKoY5Eoc+etMoCaRkbMioL+/H42NjTh16lRE7FKMUjObsrIynHPOOUIZVV9fH5qamtDf3w/GmDAyEU/8IpdYxy9ouTne+Umf7rnRE0UqWKQeCalgKSwsFLY/GAwKLnCPxyOEP/ioWSyoMom0gYpctjkQOdrlsfdEjUcqQgtyx0wuJCTn/tVCgxuONOTg9/sFMWk0GgX3PTf0/BjwyYacTqcwKVMqGyMlg7hBlFzogRt4sUFMpOxP6RwT52vwBkk8/0DcTEr8GOyYxZJXIJ0qmu8Pv47SQSwhBrmwrfha6uzsDPu83LpyBUMGMuCzUmz/r3/9C2vXrkVfXx+6urowbNgwTJkyBVOnTsWUKVMwZcoUOJ3OmH5YuTah/GLicVBxpjnP+OXxPjX1Zwfky/ykBl5JsIgNYzzGMBQKhTWs6evrg8vlAgDZDPx4j1W8jXrE+yN+nm1jISYYDKKnpwddXV3C8eJueT6C4Ql2fB4B6X6p3f0rddWLcyTEokX8PJrxEDdG4n/FjZHEoiqZWn4xcmEU8b6JDbx4f8S/VTbvDdzjIn7whE6TySRMfw0MHF9xHwnpvjgcDtUNZjhyuRJKooVX1Yg9oMmGGMQ0NTXB7/dj7NixMX0+FArBarUmc39S3MCcFQFiQqEQTp48ic8++wyfffYZ9u/fjy+++AL9/f0YOnQohg8fjpKSEhgMBni9Xtx0003w+XxRXfNyhoMbOu454Dcgcfycew7SlVynNDmONHFLOh2sdP8ydVMSj1DED8YY7Ha7MJrjNfxSQy92K0pju+LnajOG0np+6V+lBjf8LzembrdbEAhKcy2kM5FzsH0SP5d6WaTGPZ1hLu5dEIsDcS2/XGkjT1SUEyzSmLX0NxLvm1rEP0e8T3KjeLFoEYf2xN49vs9iz0Emz7VY9km8b9JQivQxmGgR20k5mxmvQCARoAIuvvhitLa2oqioCGazWajb7e3thd1ux5AhQzBx4kRMmTIF1dXVqKqqSvgHEMfPuUDwer0Rmff5+fmKxipaJYA4ZsgvTiXBorY4qNw+8ed8BCetwODZ0YWFhSgqKkJhYaFqyheB2EIO4np+OdGS6P6IQwv8EWtoIRpKSYNSYyjdJ/FfNXlZgK+FgcvlQk9PD3p7e+F2u8MS7cR5BQ6HAwUFBcjPzxdGvGrcJ3EYTnwtcXEp/Z0SES3c6Io9B1xUARC8oeIchGS8A9J9Giy3IJNCLBGB0NTUhEAgQCJArfh8Phw6dEjwGhw4cAD19fWwWq2YPHkyqqurUV1djalTp2L48OEJn2A88763txfd3d3o6+sTet+bTKaw5EZxTF3OyKsp3ABEbxssdr9Ju6NJ90+6T+LubNzbwl2XPDlPLKxSnfgkbaAi3TcgMuQg/ZutXvNSj4vL5RJ64otHfQAEj0u00a74rxqNoZxXQuppUXLR86Q0cWMk/tfjGWiMJE604+ddusWoNA4v3ie5OLz0kYnfiSc4SgWC3+8XEhSl5Y38/OS/FRdjPIwn7lkgfahpAMDh5x/fD7nzb/z48Rg6dCiAwT0IJAJUAG+jevDgwTBx0NzcjIKCAlRXVwteg6lTp6K0tBSMMbS2tiIvL08x9g4gbPTOT2revY4bPN7tT+w1yM/Pz8oFIJ0FT2rgpbX8ckYj1TFDsbtXLBB44xVpOSPvkij+f7lQg5xoUTKEahNiwNc35GgjeODrxFheyx8KhWCxWISRb6ZDC9GQjnaVss7l8gpSFXbgYSxp/kEwGJQtbYwl013sQZI+lOr7pcYw27+NFOlvxcOl4vwW8TnIEyLz8/OFqiS1CUwgtvwCfv7xXB2pZ2IwDwIwMCA9ceIEGhoaMH/+/IgKmjggEZAuGGPo6urCAw88gI8//hjHjh1Da2srjEajcAOtqanB0KFDUVFREVZyFa/R8Pl8YfkGfX19wgiYiwJ+w07kwlEKOSiNdOXCDWp0+3q9XnR1dYW5fPmFKk6w44lNcglpak10UjLuchnn8XolooUWpCPgVFV6SJv3SI28uLZfOnJXy8iQN/oRe1y418VisYSdSzzOLlcdIH6oLaeFE48xFF9fch4kcYMk8SMUCkXkH/BE2HQcE7mQinhEr5RfwPctVjHGGENPTw+OHz+OhoYGHD9+HI2NjcJft9sNi8WCESNGYNSoUfj//r//L2Kq9TggEZBu3njjDTgcDowcORIjRoyA0+lES0uLbDLiqFGjwkIKEydOTPgil7rHuUAIhUJCYp3YVSmXQS++uUpr37Uw0lUavYtHunIeCZPJJNzE+PHz+XxCrob4YbenZ4IcJaR1/dL9AiLL/sQGJJ2/VbTQgt0eXgIqDsnItd+V87ZIa/vFz7Uw2pVz/fI4PM+05x4X/r64TbC422Q2r7d4ku14jkQixjCW7eC5G+IHn8GRew/Ej2geK2kHQjmPC6/ykhNkseZMhEIhtLS0CEaeP44fP46TJ08iFAqhoKAAo0ePxujRozFmzBjhMXr0aOTn56fyXCcRoBaCwSDq6+uxf/9+fPbZZzhw4AAOHTqEUCiEcePGCSWMPBkxllGNXAkjT9oRJ9eJy/54khNPrlPjSCPWBjdygiWZWLW4SyIXB17vQJdE7qoU36jjPW5Kfeil3halBDs1ijFgYCTX09Mj5LfwRDHunjcajTCbzUIsnYsrNbuzAYQJZ+mDi2dxFUcicXhxYyRxaSPP2RCLqry8vKSvVzmPizSkkooEwnQjbsLFjxu/XhljgugSz9UizkOSGvpYPX78e6XGvaGhAY2Njejs7ITRaMSwYcMwZswYjBo1KszIV1ZWCiG4DEEiQO34/f6wZMT9+/fjyJEjMBqNGDlyJIYMGQKn0wmPx4NZs2Zhzpw5ihPlSJPrxDchntsg9hy4XC4he1ycc5BOd1u0BDulKVWzbQh5Dbo4IdHtdocdO7E7WpqYJrdfciN4NRrCRPrRi/cLQJiLnIcWuLBKR2ghnv2SM/JySWlyoYd0/l5iT580C1/c5EechW8ymWIa7Wot2Q6Qb7okTSIUe5L4ecRnBuWhQLljZzAYhFkzQ6EQOjs7I1z13Mj7fD7YbDaMGjVKMPBjx47F6NGjMXbsWJSUlKhCJIkgEaA1Xn75Zdx///0oLi5GXl4egIGTm0+8YrFYMHbsWCGsUF1djbKysoRvSOJmPlwccAMnLWOM5hoXVwXIGXlx2CFagp3aDKGcK1v6nI94ga/bUPOQDPe4JNIIKd0oGUKxZ0IqXKSCLNHfSzyTHhekcqEFfqOOp9pDXNYobVurVDuuBUHGww98oq/e3l4h0S4QCETM0sjLabmwV+t+AQPGWi6jXuydUBrFx7pfXFgdP34czc3NQvfEhx56CB6PB729vTAajSguLsbo0aNxxhlnYPz48cIoftSoUWkbIKUREgG5BE9G5CEFXqnQ0dGBoUOHCuEEXrGQTGxJPPrt7e1FT0+PYBjEJWU85CDXZVALMd1EZpITGww5N6K4ERL3HnADJ3aJ84ZI6UiojLcfvdRDkc3mLzxXQ/wQZ9/z88loNEYkSUrLGuX2TW1ijCP2unCDKD0Xldz0XKAn0hgp3YhzDKSGnt9TpN4JsaGPdRsZY+jv75eNxTc2NqKvrw8mk0lIuOMxeD6aN5vNOHLkCA4fPoxDhw7hJz/5iTAtu4YhEaAHGGNhyYgHDhzAwYMHw5IReevkSZMmhSnnQCAg28GOP5c2IuIlduIuYj6fD2azOaxKQa4cL9PHRGkmOWlttZxxT1c5ozixjo+AeTKnNClRyTUrdY0qjXSjjeDVaAgHqxAQzyXAyxpDoZDg4hWXNWZjfopoiLsqKiXbpbMMkHv85EobeRMuaWljrN+nlGPA85LE+UhyOQaxjuJ56bU4m54b+hMnTiAQCMDpdKKyslIw8NxVP2bMGBQVFaluIJIBSATomVAohPr6erz55pt4++23cfjwYTQ3N8Pv96O4uBgGgwGrVq3C4sWLUVpaGlEmF8+oibspxZUK4pnyxAIh2UY+SvXi0tCDNNtcbBTV5JkQj375dLHiHu7i9tS8rFEuTq3UaEktxJJfIB0R8vIyLsqU1puu0EIsxJNsJ2cIsynKxCEGucZI4uuFJ9rxa09OvEj3L9YcAx5ObGxsRGNjI44dO4ampibB0Le3t8NgMGDIkCGKCXdqDndkERIBBLB582Z88cUXqKysRGVlJcrLy9HT04PPP/9c8BwcPXoUFosFkyZNCitjHDFiRFI3KN7jQCwQpD0OuEjgPduVeuvzGyog31ufP1eTgReTSD96fky4V4PPFSBuIMUf2fS8KM2W53a7ZcMP0kc6+jFECy3w0rxY5lqItbRMfC6KS+fUmmwHyIcgxJ4XbuTFszYyNjClszikNVhjJMYYuru7w7Lpxa56j8cDq9WKkSNHhrnqx44dizFjxqC8vFy14lblkAggYoO7qrkw4PkGTU1NyM/PDwspJJqMKDaCPLmpv78/LE4tLk8S32TUfkMVixc5Ix+tx77Y4MeKWFzxh9/vFyYSEguEVJSVRXNly8Xh1TLSVYLXn/Ocl97e3rBkSODrud+V3PQOh0OVzaQ40X43HuoT1/vLCTMlpI2ReBv09957D5s3b0ZJSUnYtW40GlFYWCjUxktd9bHO7ErETW6IgE2bNuEHP/gBgsEg1qxZg5qamrD3vV4vrr/+enz88ccoKyvDiy++KEzQ8MADD+Cpp56CyWTCI488guXLl8e0TmIAruDFJYw8GXHIkCFCMuLkyZNRWFiIlpYWBINBTJ48OcwYxjKTnMlkgsfjCfMc8JkFxdMOc2GQKcMirXyQGvpY+tFnqpuiOCwjLsmTEwc2mw2AckxX6nmRM4SJ9mTIFNH2TVzrLxYswNcxfN5zI1OhhXjgSZFyWfVKiYTikF+s1w/3qMjF4hsaGtDd3S3Uxo8aNUpone52u9HV1YWmpibMnz8fDz74YDoPByGP9kVAMBjEpEmTsHnzZlRWVmL+/Pl44YUXUF1dLXzmsccew759+/D4449j/fr1ePXVV/Hiiy/i4MGD+Pa3v42dO3fixIkTWLp0KQ4dOgQAg66TiM7nn3+Ou+++G1999ZVQOcBn9hs1ahTOPvtsDB8+HOPGjcPkyZOFetxE4DcUqTgAINTpixPC4vkeNfSjTyfizog9PT1CzNzn8wn7xrtFipPrxN3f1IpcCEKadZ6qZLvBQgvSdsrJVldEa2HLvS9K4RWHwxHXvoVCIXR0dES46hsaGtDU1ASfzwe73R5WG88fY8eORXFxseo8PYSA4kmg3itbws6dOzFhwgSMGzcOALBq1Sps3LgxzGBv3LgR9913HwBg5cqVuOOOO8AYw8aNG7Fq1SrYbDZUVVVhwoQJ2LlzJwAMuk4iOqNGjcJvfvMbjBw5MqyMJhQK4dixY0IZ4z//+U98+eWXCAQCGDduXFhYYdy4cTEZGXF5kxhxj4Pe3l40NzeH9Tjgfcb5d0iNvFI/+pKSkrgTm7JBNCPIwyu8zp/HqEeMGBHm7g2FQmHVCt3d3WhpaRGOobicMZM10uJkO7lZ5uRCEA6HQ/jtUl3iaDAY4HA44HA4IiZzEYcW2tvbcfz48bCGSGLPAfdg8d9ObhQvzTPg+1ZeXi68jmcUHwgE0NzcjGPHjgnGnTfAOXXqFBhjKC0tDYvFz549W0jAi6dSgNAO6r2zSWhqasKoUaOE15WVlfjoo48UP2M2m1FUVIT29nY0NTVhwYIFYf/7+uuv489//jP6+vpQW1uLmpqasHUqhRY2b96Mmpoa+Hw+WK1W/OpXv8LixYsBAIsWLUJzc7NgDN966y1hqshcJT8/HxMmTIhYbjQaUVVVhaqqKnzzm98Ulvv9fhw+fBj79u3D/v378corr+DIkSOwWCyYOHFiWDLiyJEjB73JMcaEkSw3dLxdqNvtRnd3Nzo7O4XPcoPI2yaXl5cLkzqp8QbH8yfkjLw4Di/Noo/XCJpMJhQWFqKwsDBsOc+4lxNYYsPGxUG8I8FYZs6TTo1bWloqPFdTCMJqtcJqtaK4uBjA14aXe196enrQ2toqCE8ei+fVAk6nE4WFhRgyZEjcSZLS2nipy76/vx9msxkVFRVCLP60007D8uXLMXbsWAwbNgxGo1GV1wCRXjQjAlJJKBTCU089hXvuuQe7d+/GCy+8gBUrVoR95qmnnkJJSQkOHz6M9evX40c/+hFefPFFDBkyBH//+98xYsQI7N+/H8uXL0dTU5Pwf8899xzmzZuX6V3SDBaLBVOmTMGUKVNw9dVXA/jazf/FF1/gs88+w44dO/Dkk0+isbERdrsdlZWVKCsrg91uh9vtxuzZszFz5kzFtq5FRUVRXb3BYDBsxNvU1BQRL+ePdGbay/UwkAtBSHMnCgoK4h4JJorJZEJBQQEKCgrClou9L/39/WhpaRFi5jxvg/e4NxqNsolpcpUC+fn5CRnBbBBPC1u73Y6SkhJUVFSE/XbS0EJjY2NYaAEAvvzyS0yfPh12ux1NTU0RDXCam5uF2vhRo0YJSXYLFy4U3PWFhYWqPpZE9tCMCBg5ciQaGhqE142NjRg5cqTsZyorKxEIBNDd3Y2ysrKI/z148CDGjBmDOXPm4G9/+5sQBuDrAJRDC7NnzxbWM3XqVMFFyZOriPjho8o5c+Zgzpw5AIDHH38cTzzxBMxmsxD7t9lscLlcqKurwxtvvBHWNnn06NEoKChIatQrTqZrbW3F0aNH4fP5YLFYIqZqjiURTDw/grRtrXTGPK2FILjxBgaOp9VqFYygy+VCT0+PMEe62GXvdDpRXFyMoqIiFBQUqGokL0UchpATaNIwRF5enuCliLUSg+dcFBQUoLGxEadOnRJmmevu7kZPTw/27duH3t5eNDU1weFwYMSIEaiursbNN9+MMWPGYOTIkVQbTySMeu8yEubPn4+6ujocPXoUI0eOxPr16/H888+HfWbFihVYt24dzjzzTLz88stYvHgxDAYDVqxYgf/4j//AD3/4Q5w4cQL19fW45JJLhHUuX74cdXV1+OCDD4R1KoUWxHHAV155BXPmzAkTADfeeCNMJhOuvPJK/OxnP6MLM0FuvfVW3HrrrbLvMcZw6tQpId/g+eefx8GDB9HX14eRI0eG5RtMnjw5Zpe4xWJBcXGx4M7l8BasfX19aG5uRn9/vyAOpNPD8uoBIDIZraCgAEOHDk1LF8JUE2uynbgOvqioCMOHD5dt6MMT6riga2pqEqa85r0iYumSmCrkpskVJ9wBkQ2LuEBzOBxxiRdeWaM0b7y4Np676qdOnSrUxg8ZMkTw+LjdbtTV1eHkyZM477zz0nJsCH2hGRFgNpvx6KOPYvny5QgGg/jOd76DqVOn4t5778W8efOwYsUK3HTTTbjuuuswYcIElJaWYv369QAGRuxXXXUVqqurYTabsWbNGrS0tAjr/M53vgO32427774bU6dOjWl7Dhw4gB/96Ed46623hGVr1qzBL37xC/j9fjzzzDMYM2YMrr/+euF9pTyD+vp6TJkyBZMnTwYALFiwAI8//jgA4OOPP8YNN9wAt9uNiy66CL/73e9UbTwygcFgwLBhwzBs2DAsWbJEWB4KhXD8+HFBHPz+97/Hl19+Cb/fj6qqqrBpmsePH69oaOQMhPg1zyvg/+/3+xEMBuHz+RAKhYR8A7FhU9OIVy7jXK6XQSqT7cQJdeXl5WHbwmfJ6+vrE8QBbyQlzjmIp8tkMBiUHcHzFrYAhPwJvo/FxcVx7x+fovbkyZM4fvx42Gxzx48fR0tLC0KhEAoLC8M63C1fvlxw28dTyeJwODBjxgzMmDEjps8TxGBopkQwlezYsQP33Xcf/vnPfwIY6CEAAD/+8Y+Fzyxfvhz33XcfzjzzTAQCAQwfPhytra0wGAxobGzE4sWL8ec//xlnn302gMgSxgkTJuCcc84J81YolTByz8T+/fsjtvX000/HI488gjPOOAMXXXQRvv/97+PCCy9M5+HJOQKBAOrq6oQ5FT755BPU1dUhGAyiqKgIZWVlcLvdGDVqFNasWZPUPOrcqInbJvMRL0/+4mGFdPU4kGvLGy0MIX2oQbDwngziigUuDsxms9Cgh29rtBa20tr4eLwMPF9FbiIacW388OHDhVG8uMvdiBEjMj1vPJFCOjo6cPXVV6O+vh5jx47Fhg0bUFJSEvaZvXv34rbbbkNPTw9MJhN++tOfCvlOR48exapVq9De3o65c+fiL3/5S7Y6emq/T0AqCQQCmDRpErZu3YqRI0di/vz5eP7558O8AL///e/x2WefCQb7r3/9KzZs2ICuri584xvfwH/913/hiiuuED6/fft23HvvvXjnnXfg9/sxe/ZsTJgwAa+99prwGSVhcezYMVkR0NzcjPPOOw9ffPEFAOCFF17Atm3b8MQTT6T3AOUw7733Hn7xi1+gsrISFRUVsFgs8HgGpg+tr69HY2MjnE6nkLzIOyOWl5cnXe8t7XHA+9rzHgfiBkjRpmoWVwtIZ5nLRlveVCMnYvh+8qx6aQvbUCgEi8US5oHhiZ3R9pfXxsvNG9/U1AS/3y8kp3IDL36UlJSo/ngSiXP33XejtLQUNTU1qK2tRWdnZ0Szo0OHDsFgMGDixIk4ceIE5s6di88//xzFxcW46qqrcMUVV2DVqlW49dZbMXPmTNx2223Z2BXt9wlIJcmEFh599FEcPnwYP//5z/Hzn/8cwEAp4LFjx/DZZ59hxowZCAaDGDlyZETiolKeATCgGGfPno3CwkL88pe/xLnnnoumpiZUVlYK/19ZWRlWiUDEz8KFC7F582bF9xlj6OnpEboi/uMf/8DDDz+MtrY2lJaWhgmDKVOmxJx1Ha3HARcH4pwDxljYSDcYDAqJdtJGRbwaQs2TBnF4KEJpzni5FraFhYUYOnTooI19eGJnf38/2tracOzYMXi9XuzduxdvvfWWkM/j9/vR2dmJ1tZWAEBJSUnYCH7u3LkYPXo01cYT2LhxI7Zt2wYAWL16NRYtWhQhAiZNmiQ8HzFiBIYOHYrW1lYUFRXh7bffFrzBq1evxn333ZctEaCILj0B6eDll1/Gpk2b8OSTTwIA/vKXv+Cjjz7Co48+Knxm2rRp2LRpk2DYx48fj48++ggFBQXo6+tDWVkZPv74Y1x22WU4cOAADh06hJtvvhkulwvBYBBLlixBU1MTXn/9dWGdSnkGzz33HH71q18Jn9u3bx/27NmDWbNm6bKfQbLw6Uv379+Pffv24cCBAzhw4AD6+vqEbG1xMqKc8Ygl2Y4no/G4tDh+7/P5YDQaw+Lk+fn5KW+IkwzSSXbExl6phS03+PGKGMYY+vr6ZDvciWvjR4wYgbKyMgQCAfT09KCjowOdnZ245JJLUFtbq5pjR6iP4uJidHV1ARg430pKSoTXcuzcuROrV68WWqovWLAAhw8fBgA0NDTgwgsvlA37ZgDyBKSbZEoYeRIWAMydOxfjx4/HoUOHMHz4cBw4cECY+W/ixIk444wzwtap1M/gmmuuwTXXXAMA+Oyzz3DZZZdh1qxZwv9RP4P4MBgMGDp0KBYvXiw0hwIGjF5DQwP279+PnTt34tVXX8WhQ4fgdruRn5+PoqIi9PT0YOXKlVi8eHFYIloiJWXiHgednZ1oaGiAx+PJSI8DpYRCXv4o18KWN2RKpPkNrwKRZtNLa+PFsfhFixYJI/rBvDQ8AZLQN0uXLsXJkycjlq9duzbstcFgiHq+NDc347rrrsO6detU75ETQyIgRSRTwtja2orS0lKYTCYcOXIEdXV1GDduHL788ks4HA6cOnUKVVVVQl93MUr9DMQn6wsvvIBVq1al/RjoEaPRKMSH6+rqUFFRgTPOOEPodtjX14eWlhZ88cUXeOONN2A0GsM6I/IeB7EaI6UeB7wznVKPA7FAUMqwT6SFLW/sE2/jIp74x1vXSg19R0cHDAYDysvLw2acO+usswRXfbJTRWvpRp0rxJJoBwAXXHABPvzwQ5xzzjlhns8bbrgB7777LoqKigAATz/9dNjgJhG2bNmi+N6wYcPQ3NyMiooKNDc3K3pMe3p6cPHFF2Pt2rVCd9qysjJ0dXUJyaxyA0M1QCIgRSSTZ/Dee+/h3nvvhcVigdFoxOOPP47S0lI0NTXhvPPOw5o1a+B2uzFu3Dihixgnln4GL774otAMCRi4EHlVw8KFC/HWW2+F3Uzfe+893Hnnndi3bx/Wr1+PlStXCu+tW7cOv/zlLwEAP/vZz7B69WoAVMoIAHfeeWfU93mt/JdffonPPvsMO3fuxJ///Gc0NDQgLy8vIhlx6NChMR9D/tvzmyPH7/cL0+Q2Nzejp6cHfr8fRqNRSK7jMztKR/FOpxNlZWUJTZXLGENXV5esq76xsRFerzeiNn7WrFm49NJLMXbsWJSVlZGRzkFqa2uxZMkSIdGutrZWdlbBu+66Cy6XSzYJ+le/+lXYPSmd8IFbTU0N1q1bh0svvTTiMz6fD5dffjmuv/76sO0yGAw477zz8PLLL2PVqlWK/59tKCdAxSSTZ8BFwEcffYQ1a9bgs88+AzDgTh4/fjzefvttFBUVYezYsfjJT34SVh5ZX1+Pnp4ePPzww1ixYoVwYnd0dGDevHnYvXs3DAYD5s6di48//hglJSVUypgEjDH09vbiwIEDwlTNBw4cQGtrK0pKSsL6G1RXV8u6uePJN+CTKfHMeq/XC5fLhUAgILTuFdfmS0sG+XwNLS0tEZPR8Np4xlhEbTx/jB49OqnZJAntMnnyZGzbtk0YWS9atAhffvml7Ge3bduGhx9+OMITcMkll2RMBLS3t+Oqq67C8ePHMWbMGGzYsAGlpaXYvXs3Hn/8cTz55JN49tlnceONN4ZVl3EPxZEjR7Bq1Sp0dHRg9uzZePbZZ7PVXZZyArRIMnkGnPXr1+Pb3/628Hrnzp2YPHmyMHPi8uXL8be//S1MBIwdOxZApLv0n//8J5YtW4bS0lIAwLJly7Bp0yYsWrQIPT09ghvs+uuvx2uvvUYiIEYMBgMKCwtx5pln4swzzxSWi5MRd+/ejT/84Q84cOAAenp6YLPZUFZWhr6+Ppx++um4/vrrk843EPc46OzsRH19Pbq6unD33XejuLgYgUBAmJWQt6/lo/hx48bhvPPOw5gxY6g2nlCkpaUFFRUVAIDhw4ejpaUl7nX89Kc/xc9//nMsWbIEtbW1aTWqZWVl2Lp1a8TyefPmCYOza6+9Ftdee63s/48bN06YsVatkAhQMcnkGQADo8MNGzZg+/btwuePHz8udGzz+/04duxYRIhBCbmZHJuamqiUMU2IkxG7urqwf/9+XHnllaisrEReXh5cLhdaW1tx6NAh1NTUwO/3Y+zYsUJIYcqUKZgwYYKs16C9vT3CVd/Y2BhWG88no/ne974Hp9MJl8uFzs5OfPXVVzhx4gTeeOMNMvREBKlKtJPjgQcewPDhw+Hz+fDd734XDz74IO69996ktlfvkAhQMcnkGQADsf1Ro0YJo35gwPBv2rQprJ/BxIkTU7K9mzZtwg9+8AP09/cjPz8/4n2lXINoHbfSkQikRa644oqw5lRyBAIBfPXVV0Lb5I0bN+Lw4cMwGo3w+/0oLy8X+lKUlpaGZdXPnTtXcN2rqeSQ0B6pSLRTgnsRbDYbbrzxRjz88MNJbStBIkD1XHTRRbjooovClvEmRQBgt9vx0ksvyf7vokWL8OGHH4YtGz9+PObOnRvRMjkWRo4cKTTOAAbCE4sWLRJCErfffjs2b96M999/H3feeScOHjyI6upq4fOjR4/G008/HXHh5uXl4ZlnngnruLV8+XJhIp9MJgJpGbPZjMmTJ2Py5Mm48sorAXydhf/Pf/4T8+fPx7BhwxIagRHqItks+2y1s40l0S4aXEAwxvDaa69h2rRpadpS/UDptzpDHGLw+XxYv349VqxYEdP/Ll++HG+99RY6OzvR2dmJt956C8uXL0dFRQVMJhPKy8tRVVWF559/Ht/85jfDKhKAgVyDGTNmROQaTJo0SfBGiDtuEcnDe1CsWLECFRUVMBqNJAByAJ5lX1dXJ8TG5bjrrrvwl7/8JWL5j370I/znf/4nDh8+jJKSEjz11FPp3mQAQE1NDTZv3oyJEydiy5YtqKmpAQDs3r0ba9asET537rnn4lvf+ha2bt2KyspKYdByzTXXYPr06Zg+fTra2trws5/9LCPbndPwphxpfBAq44033mATJ05k48aNY7/85S8ZY4zdc889bOPGjYwxxnbu3MlGjhzJ8vLyWGlpKauurhb+96mnnmLjx49n48ePZ3/605+E5bW1tay4uJiNGzeO3X777WzdunXs9ttvl/3+1atXs5deekn2vY8++oiddtppLBgMCp+dNGkSmz59OrvzzjuZx+NJyTEgCC0zadIkduLECcYYYydOnGCTJk1S/Ow777zDLr74YuF1KBRiZWVlzO/3M8YY++CDD9j555+f3g0mso2ijSYRQKSEl156id10003C62eeeSZuEcBvZjt27Ahb9uabb7KJEyeygoICtnTp0oj/e/fdd9ns2bOZyWSKWK/RaGQzZ85kM2fOZN/85jeF5UeOHGGnn346Gz9+PLvqqquY1+uNe58JIlsUFRUJz0OhUNhrKVIR0NraysaPHy+8Pn78OJs6dWo6NpNQD4o2msIBREqIpZwxGnIdtwBg6NChuOOOO7Bp0ya88sor+Oijj3Dw4MGw/+W5Bv/xH/8RsV6Hw4G9e/di7969+Nvf/iYsz5Y7lCBiZenSpZg2bVrEQxpmoxwPIhkoMVAn5Ofno6+vL23rj6WcUQmljlsA8Oabb2LChAmoqqrCI488gtmzZ2Pjxo1hCYdKfQ2UYIxpYnYvQt+kK8teK+1sicxAngAiJYjLGadMmYKrrrpKKGfkI/Bdu3ahsrISL730Em655Rahw9aGDRvw3nvvCeV/s2bNwt69ewEAP/7xj7Fr1y4hEejaa6+NqweBx+PBvHnzsGDBArz22msABrqAFRcXw2we0MDU10CfdHR0YNmyZZg4cSKWLVuGzs5O2c+tW7cOEydOxMSJE7Fu3Tph+aJFizB58mThnD116lSmNl3IsufbF0+WvbidbSL/T+QY0WIFKXoQKsDpdGZ7ExIi2VyDxsZGxhhjX331FRszZgw7fPiwEBP9xz/+wSZNmsTGjBnDhg4dGrE+pVyDt99+W8gzmDlzJrPZbOzVV18VtmHs2LHCe5988kmSR4BIF3fddRd74IEHGGOMPfDAA+zuu++O+Ex7ezurqqpi7e3trKOjg1VVVbGOjg7GGGPf+MY32K5duzK6zZy2tja2ePFiNmHCBLZkyRLW3t7OGGNs165dYdfLOeecw4YMGcLsdjsbOXIk27RpE2Ns4HqYP38+Gz9+PFu5ciUl3OY+lBiod7QqAqSZy/fffz+7//77ZT8brepA/H4oFGKlpaVs3Lhx7KuvvmLvvvsuy8/PZwcOHAj7/NGjR9mnn37KrrvuOsX1tre3s5KSEtbf3x/TNhDqIZYM++eff55997vfFV5/97vfZc8//zxjLLsiIBuI7yG8wqi+vj6LW0TEASUGEtokmb4GnZ2dwuQ5bW1teP/991FdXQ2DwYCZM2ciPz8f48aNw/PPP4/FixfH3NdAzMsvv4wLL7wwYopnQv3E0sdeqVU258Ybb8SsWbPwi1/8YmBUpQO2bt2K73//+/jHP/6BMWPGZHtziCQhEUCommRyDT7//HPMmzcPM2fOxHnnnYeamhohofDKK6/EiRMnMGHCBLS3t+PSSy9NKC9AOkETMDDByYwZM/Cf//mfggghskM6M+yfe+45fPbZZ9i+fTu2b98u25Qn13jvvfdw88034/XXX8f48eOzvTlEKojmJkjRg1ABWg0HpItU9TUYMmQI8/l8YctCoRDzeDxsyZIlrKysjI0fP16IPYv59a9/zaZMmcKmT5/OFi9eHOZaffrpp9mECRPYhAkT2NNPPy0s3717N5s2bRobP348+973vsdCoVBC+08kHw4Q8+c//1nx/MkVzGYzKykpYZ9++mm2N4WIHwoHEISYZPsaAANVDZdffjksFouwrKKiAgaDAWazGZ9//jlmzJiBgwcP4oUXXojobzB79mzs3r0b+/btw8qVK3H33XcDGMha/+///m989NFH2LlzJ/77v/9byFy/7bbb8L//+7+oq6tDXV0dNm3alOghSIhNmzZh8uTJmDBhgmyrWq/Xi6uvvhoTJkzAGWecgfr6euG9Bx54ABMmTMDkyZOFNrDZJJYMe6VW2YFAAG1tbQAGJuV6/fXXc76PvcViwVlnnUU9NXKNaAohRQ+CUB1+v59VVVWxI0eOMK/Xy2bMmMH2798v+1klT8AZZ5zB3n777bBlfGT5/vvvs9GjR7Mf/ehHjLHoCY2MMbZnzx521llnMcaUR58nTpxgkydPFpZLP5duAoGAkEzJj5k0mfL3v/89u+WWWxhjjL3wwgvsqquuYowxduDAATZjxgzm8XjYkSNH2Lhx41ggEMjYtssRa4a9XKvsvr4+NmfOHDZ9+nRWXV3Nvv/972d9f9KN0+lk/f39bMGCBWzt2rXZ3hwiPhRtNDULInRJLNM079q1C5dffjk6Ozvx97//Hf/1X/+FAwcOAADq6+vR0NCAb3zjG2Hrveaaa9Da2oquri7YbDZhgpPKykp89NFHitvz1FNP4cILLwSgnIzW1NSEysrKiOWZYufOnZgwYYIwNfWqVasiGjdt3LgR9913HwBg5cqVuOOOO8AYw8aNG7Fq1SrYbDZUVVVhwoQJ2LlzJ84888yMbb+UsrIybN26NWL5vHnz8OSTTwqvv/Od7+A73/lO2GecTic+/vjjtG+j2sjLy8Mbb7yBc889F8OGDcNNN92U7U0ikoREAKFbBpumef78+WhsbJT937Fjx8oa4LfffhvAQNXApk2bkJ+fP+h2PPvss9i9ezfefffdeDY/48iJE6mwEX/GbDajqKgI7e3taGpqCmsHTQ2atEtpaSk2bdqEhQsXory8POZqHUKdkAggiDQQa87Bli1bsHbtWrz77ruw2WzC/27bti3sfxctWoSRI0eGiRJq90pkEnHb8VGjRuHo0aNZ3BoiVVBiIEGkgVj6G3zyySe45ZZb8Le//S2s97tSMlpFRQUKCwvx4YcfgjGGZ555JqPtXmMRNuLPBAIBdHd3o6ysLCWJmARBpB4SAQSRBmLpb3DXXXehr68P3/rWtzBr1ixBJJSWluKee+7B/PnzMX/+fNx7770oLS0FADz22GNYs2YNJkyYgPHjxwt5BJkgFmEjzrh/+eWXsXjxYhgMBqxYsQLr16+H1+vF0aNHUVdXh9NPPz1j204QhDwGlv4uV/poo0UQOuDNN9/EnXfeKSRT/vSnPw1LpvR4PLjuuuvwySefoLS0FOvXrxcSCdeuXYs//elPMJvN+O1vf5tRAUMQOkexExaJAIIgCILIbRRFAIUDCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqJAIIgCILQKeYMfIchA99BEARBEESckCeAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0Cn/P5h2ctsB6TvmAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.utils.lqr_weights_viewer import visualize\n",
    "\n",
    "\n",
    "visualize(weights, env.optimal_weights)"
   ]
  }
 ],
 "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": {
     "12d17d70ebfc415581f140b7ccf61043": {
      "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
      }
     },
     "16f1352a99494d4b90cc1451f9ac1de8": {
      "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_865b532bcbcc43ee81a40e9dc3f97648",
       "max": 4.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_ed37efd90bb4419d9083c812f31c62f2",
       "value": 4.0
      }
     },
     "61db5b671e6245068f8e768b47c0481d": {
      "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_83b5eddbb6954effb911413ebac693c0",
        "IPY_MODEL_16f1352a99494d4b90cc1451f9ac1de8",
        "IPY_MODEL_9df326f15d06497d8ca569248e781391"
       ],
       "layout": "IPY_MODEL_f7e673ccfe5549dfb9800de233d4486a"
      }
     },
     "83b5eddbb6954effb911413ebac693c0": {
      "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_12d17d70ebfc415581f140b7ccf61043",
       "placeholder": "​",
       "style": "IPY_MODEL_eaae0e1c70f044e0a728442bbf17ffec",
       "value": "100%"
      }
     },
     "865b532bcbcc43ee81a40e9dc3f97648": {
      "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
      }
     },
     "893ca7550afe434d8524c34ef6b9b23e": {
      "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": ""
      }
     },
     "9df326f15d06497d8ca569248e781391": {
      "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_d10560f8f7504ff0a8284b7ea618fa0e",
       "placeholder": "​",
       "style": "IPY_MODEL_893ca7550afe434d8524c34ef6b9b23e",
       "value": " 4/4 [00:01&lt;00:00,  2.37it/s]"
      }
     },
     "d10560f8f7504ff0a8284b7ea618fa0e": {
      "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
      }
     },
     "eaae0e1c70f044e0a728442bbf17ffec": {
      "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": ""
      }
     },
     "ed37efd90bb4419d9083c812f31c62f2": {
      "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": ""
      }
     },
     "f7e673ccfe5549dfb9800de233d4486a": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
