{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# LSPI on LQR\n",
    "\n",
    "## Define paramters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:07:39.567308Z",
     "iopub.status.busy": "2022-09-19T14:07:39.567103Z",
     "iopub.status.idle": "2022-09-19T14:07:40.180542Z",
     "shell.execute_reply": "2022-09-19T14:07:40.180051Z"
    }
   },
   "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",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/LSPI/\"):\n",
    "    os.makedirs(\"figures/data/LSPI/\")\n",
    "for file in os.listdir(\"figures/data/LSPI/\"):\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",
    "initial_policy_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:07:40.182661Z",
     "iopub.status.busy": "2022-09-19T14:07:40.182485Z",
     "iopub.status.idle": "2022-09-19T14:07:40.407278Z",
     "shell.execute_reply": "2022-09-19T14:07:40.406812Z"
    }
   },
   "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:07:40.410464Z",
     "iopub.status.busy": "2022-09-19T14:07:40.410326Z",
     "iopub.status.idle": "2022-09-19T14:07:40.644184Z",
     "shell.execute_reply": "2022-09-19T14:07:40.643697Z"
    }
   },
   "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:07:40.646181Z",
     "iopub.status.busy": "2022-09-19T14:07:40.646050Z",
     "iopub.status.idle": "2022-09-19T14:07:41.371933Z",
     "shell.execute_reply": "2022-09-19T14:07:41.371474Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.sample_collection.count_samples import count_samples\n",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "\n",
    "samples_count, n_outside_boxes, _ = count_samples(replay_buffer.states, replay_buffer.actions, discrete_states_boxes, discrete_actions_boxes, replay_buffer.rewards)\n",
    "samples_visu_mesh = TwoDimesionsMesh(discrete_states, discrete_actions, sleeping_time=0)\n",
    "\n",
    "samples_visu_mesh.set_values(samples_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Samples repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train LSPI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:07:41.373869Z",
     "iopub.status.busy": "2022-09-19T14:07:41.373651Z",
     "iopub.status.idle": "2022-09-19T14:07:44.644990Z",
     "shell.execute_reply": "2022-09-19T14:07:44.644490Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0. 0. 0.]\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d39b391f3fe547c4a6595d7ff844b6c4",
       "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": [
      "[ 1.95019302 -0.67736644  0.7650494 ]\n",
      "[0.80967368 0.60968212 0.57451562]\n",
      "[ 1.0697097  -0.12070327  0.26497472]\n",
      "[0.80967368 0.60968212 0.57451562]\n",
      "Optimal weights\n",
      "[-0.22707027  0.19779846 -0.8541705 ]\n"
     ]
    }
   ],
   "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, 1, None)\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",
    ")\n",
    "\n",
    "weights = np.zeros((max_bellman_iterations + 1, q.weights_dimension))\n",
    "\n",
    "weights[0] = q.to_weights(q.params)\n",
    "print(weights[0])\n",
    "\n",
    "for bellman_iteration in tqdm(range(1, max_bellman_iterations + 1)):\n",
    "    A = np.zeros((q.weights_dimension, q.weights_dimension))\n",
    "    b = np.zeros(q.weights_dimension)\n",
    "\n",
    "    for batch_samples in data_loader_samples:\n",
    "        state = batch_samples[\"state\"][0, 0]; action = batch_samples[\"action\"][0, 0]\n",
    "        reward = batch_samples[\"reward\"][0, 0]; next_state = batch_samples[\"next_state\"][0, 0]\n",
    "        next_action = q.actions_on_max[q(q.params, next_state, q.actions_on_max).argmax()][0]\n",
    "\n",
    "        if len(np.unique(q(q.params, next_state, q.actions_on_max))) == 1:\n",
    "            initial_policy_key, key = jax.random.split(initial_policy_key)\n",
    "            next_action = jax.random.choice(key, q.actions_on_max.flatten())\n",
    "\n",
    "        phi = np.zeros((q.weights_dimension, 1))\n",
    "        phi[0, 0] = state ** 2; phi[1, 0] = 2 * state * action; phi[2, 0] = action ** 2\n",
    "        next_phi = np.zeros((q.weights_dimension, 1))\n",
    "        next_phi[0, 0] = next_state ** 2; next_phi[1, 0] = 2 * next_state * next_action; next_phi[2, 0] = next_action ** 2\n",
    "\n",
    "        A += phi @ (phi - next_phi).T\n",
    "        b += reward * phi.reshape(q.weights_dimension)\n",
    "\n",
    "    q_weigth_i = np.linalg.solve(A, b)\n",
    "    q.params = q.to_params(q_weigth_i)\n",
    "    \n",
    "    weights[bellman_iteration] = q_weigth_i\n",
    "    \n",
    "    print(q_weigth_i)\n",
    "\n",
    "print(\"Optimal weights\")\n",
    "print(env.optimal_weights)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:07:44.647388Z",
     "iopub.status.busy": "2022-09-19T14:07:44.647103Z",
     "iopub.status.idle": "2022-09-19T14:07:44.721062Z",
     "shell.execute_reply": "2022-09-19T14:07:44.720497Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/LSPI/{max_bellman_iterations}_W_{seed}.npy\", weights)\n",
    "np.save(f\"figures/data/LSPI/{max_bellman_iterations}_Pi_{seed}.npy\", env.greedy_V(weights))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-19T14:07:44.723538Z",
     "iopub.status.busy": "2022-09-19T14:07:44.723357Z",
     "iopub.status.idle": "2022-09-19T14:07:44.988112Z",
     "shell.execute_reply": "2022-09-19T14:07:44.987582Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgEAAAHwCAYAAAA/wLxAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAACMM0lEQVR4nO29eXxU9b3//5otM5N9YUlIAmEVEkAEoiiVi3XBYm/U1qL92oqtttav3Gtv79fb3PqrDx+9V5u2tnZBS630QmsVqbZivZRWqLgBsguCaJQEkhBC9mT27fz+SD/Hz5w5ZzL7nDnn/Xw85pFZTuYsc855vz7vz3sxCIIAgiAIgiD0hzHbG0AQBEEQRHYgEUAQBEEQOoVEAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4xZ2AdlH5AEARBENnDoPQBeQIIgiAIQqeQCCAIgiAInUIigCAIgiB0CokAgiAIgtApmQgMJAiCIBLE7/ejs7MTHo8n25tCqBybzYaamhpYLJaY/8eQgd4BlB1AEASRIG1tbSgqKkJFRQUMBsUgb0LnCIKA/v5+jI6OYvr06dKPKTuAIAgiF/F4PCQAiHExGAyoqKiI22NEIoAgCELlkAAgYiGR84REAEEQBEHoFBIBBEEQBKFTSAQQBEEQhE4hEUAQBKExhoeH0dDQgOHh4aysf2hoCE8++WTYe1dccUXKvr+wsDDiPfb9cutOlnTvTzYhEUAQBKExXnnlFZw8eRL/+7//m5X1yxnNPXv2pHWd7PsTEQGCICAUCil+non92b17N+68886UfmcskAggCILQGJs3bw77mwp+8pOfYP78+Zg/fz5++tOfAgDa29sxd+5c3H777Zg3bx5uueUWuFwuNDc34+OPP8aiRYvwwAMPAPhk9M7+584778ScOXNw++23Y+fOnVi+fDlmz56N/fv3AwBuuukmLFmyBA0NDXjqqafG3T72/XLrfuaZZ3DppZdi0aJFuOeeexAMBtHe3o6LLroId9xxB+bPn4+Ojg7FdUbbH6XjMm/ePHzta19DQ0MDrrvuOrjd7iR/gTQhCEK6HwRBEESCnDx5ctxlXnzxReFf/uVfxIfVahUACFarNez9F198MaFtOHjwoDB//nzB4XAIo6OjQn19vXD48GGhra1NACC89dZbgiAIwle+8hXhRz/6kdDW1iY0NDSEfUdBQYEgCILQ1tYmmEwm4dixY0IwGBQWL14sfOUrXxFCoZDw0ksvCTfeeKMgCILQ398vCIIguFwuoaGhQejr64v4LqXv59d98uRJ4bOf/azg8/kEQRCEe++9V9i8ebPQ1tYmGAwGYe/eveKySutU2p9ox8VkMglHjhwRBEEQvvCFLwi/+93voh7j1157TVi7dm3E+9u3bxdWrlwp/H//3/8n/P3vfxdWrFghfOtb31L8HoXzRdFGU9lggiCIHMfv9+OXv/wlAoFA2Pterxe/+MUvAABmsxmf+tSnEvr+t956CzfffDMKCgoAAJ/73Ofw5ptvoqmpCbW1tVi+fDkA4Etf+hJ+/vOf45Zbbon6fdOnT8eCBQsAAA0NDbj66qthMBiwYMECtLe3AwB+/vOf409/+hMAoKOjA62traioqIh723ft2oVDhw6hsbERAOB2uzFp0iSsWLEC06ZNw7Jly8Rl411ntOMyffp0LFq0CACwZMkScb+kXHbZZfB6vXA4HBgYGBD/5wc/+AFWrVqFXbt24bXXXsMPf/hDPP7449i5cyeee+45nDx5EvX19XEfDykkAgiCIHKcW2+9FQsWLMA///M/o7u7O8z1bLfbUVVVhT//+c8pMRpSpAVqYilYY7VaxedGo1F8bTQaEQgEsHv3buzcuRN79+5Ffn4+Vq5cmXDvBEEQsHbtWnz/+98Pe7+9vV003gBSuk4gfB9NJpPidMA777wjrn/Tpk3YtGlTxPYDQHl5ORwOB4LBoDiKTwUUE0AQBKEB6uvrcejQIfh8vrD3fT4fDh8+nJQAuPLKK/HSSy/B5XLB6XTiT3/6E6688koAwNmzZ7F3714AwLPPPotPfepTKCoqwujoaMLrGx4eRllZGfLz83Hq1Cns27cv5v+Vrvvqq6/GCy+8gAsXLgAABgYGcObMmbjWqbQ/0Y5Lqrjmmmtw9dVX4/3338fDDz+M6667DgcPHkRDQ0NKvp9EAEEQhEZ48803kZ+fD7PZDJPJBLPZjPz8fLz55ptJfe/ixYtx55134tJLL8Vll12Gu+++G5dccgkA4KKLLsITTzyBefPmYXBwEPfeey8qKiqwfPlyzJ8/Xwyki4frr78egUAA8+bNQ3Nzc5jLfjyk666vr8d///d/47rrrsPChQtx7bXXoru7O651Ku1PtOOSKj7zmc9g165d+PGPf4wVK1bgjTfeEKd4UgF1ESQIglAx77//PubNmxfTsl/4whfw4osvYunSpVi/fj3WrVuHgwcP4pZbbsHWrVtTvm3t7e347Gc/i/feey/l300khsL5Ql0ECYIgtE5rayseeugh7N27F5deein27t2Lhx56CK2trdneNEKlkCeAIAhCxcTjCSAI8gQQBEEQBBETJAIIgiAIQqeQCCAIgiAInUIigCAIgiB0CokAgiAIgtApJAIIgiAIQqeQCCAIgiCicsUVVwAYKw707LPPpvS7H330Udl1JcvAwACuvfZazJ49G9deey0GBwdT8r1ag0QAQRAEEZU9e/YASEwESDsbSpGKALauZGlpacHVV1+N1tZWXH311WhpaUnJ92oNEgEEQRBaw9ML9B8Y+5sCCgsLAQDNzc148803sWjRIjz++OMIBoN44IEH0NjYiIULF+JXv/oVgLGOeFdeeSWamprExkU33XQTlixZgoaGBjz11FPi97ndbixatAi333572LoEQcADDzyA+fPnY8GCBXj++efF7165ciVuueUWzJ07F7fffrtsR71t27Zh7dq1AIC1a9fipZdeSsmx0BysJWEaHwRBEESCnDx5Mr5/aHtWELbYBWFrydjftmeT3oaCggJBEAThtddeE2644Qbx/V/96lfCf/3XfwmCIAgej0dYsmSJcPr0aeG1114T8vPzhdOnT4vL9vf3C4IgCC6XS2hoaBD6+vrCvlu6rhdeeEG45pprhEAgIJw/f16ora0Vzp07J7z22mtCcXGx0NHRIQSDQWHZsmXCm2++GbHNJSUl4vNQKBT2WssonC+KNpo8AQRBEFrB0wu8cxcQdAP+4bG/79yVMo+AlL/97W/47W9/i0WLFuGyyy5Df3+/2Kfg0ksvxfTp08Vlf/7zn+Piiy/GsmXL0NHRMW4/g7feegtf/OIXYTKZMHnyZPzTP/0TDhw4IH53TU0NjEYjFi1ahPb29qjfZTAYYDAoVs7VNeZsbwBBEASRIpztgDFvzPgzjJax920TU746QRDwi1/8AqtWrQp7f/fu3SgoKAh7vXPnTuzduxf5+flYuXIlPB5Pwuu1Wq3ic5PJJBt3MHnyZHR3d6Oqqgrd3d2YNGlSwuvTMuQJIAiC0AoFdUDIF/5eyD/2fgooKirC6Oio+HrVqlX45S9/Cb/fDwD48MMP4XQ6I/5veHgYZWVlyM/Px6lTp7Bv3z7xM4vFIv4/z5VXXonnn38ewWAQvb29eOONN3DppZfGvK1NTU3YvHkzAGDz5s248cYbY/5fPUEigCAIQivYJgKXbQRMdsBSPPb3so0p8wIsXLgQJpMJF198MR5//HHcfffdqK+vx+LFizF//nzcc889sqPy66+/HoFAAPPmzUNzczOWLVsmfvb1r38dCxcuFAMDGTfffDMWLlyIiy++GJ/+9Kfxwx/+EJWVlTFva3NzM1599VXMnj0bO3fuRHNzc+I7rmGolTBBEISKSaiVsKd3bAqgoC4t0wCEeom3lTDFBBAEQWgN20Qy/kRM0HQAQRAEQegUEgEEQRAEoVNIBBAEQRCETiERQBAEQRA6hUQAQRAEQegUEgEEQRBEVHKxlfAf/vAHNDQ0wGg04uDBgyn5Ti1CIoAgCIKISi62Ep4/fz7++Mc/YsWKFSn5Pq1CIoAgCEJrUCthzJs3DxdddFFK9l/LULEggiAILdH+3FjnQGPeWB+ByzYCdV9MyVe3tLTgsccewyuvvAIAeOqpp1BSUoIDBw7A6/Vi+fLluO666wAAhw8fxnvvvSd2EvzNb36D8vJyuN1uNDY24vOf/zxaWlqwfv16HD16NGJdf/zjH3H06FG8++676OvrQ2NjoziqP3LkCE6cOIEpU6Zg+fLlePvtt/GpT30qJfuoN8gTQBAEoRWolTARJ+QJIAiC0ArUSpiIE/IEEARBaAVqJUzECYkAgiAIrUCthEX+9Kc/oaamBnv37sUNN9wQ4a0gxqBWwgRBECqGWgkT8UCthAmCIPQOtRImYoSmAwiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIKKSi62EH3jgAcydOxcLFy7EzTffjKGhoZR8r9YgEUAQBEFEJRdbCV977bV47733cOzYMcyZMwff//73U/K9WoNEAEEQhNagVsK47rrrYDaPlcJZtmwZOjs7U3IsNIcgCOl+EARBEAly8uTJ+P6h7VlB2GIXhK0lY3/bnk16GwoKCgRBEITXXntNuOGGG8T3f/WrXwn/9V//JQiCIHg8HmHJkiXC6dOnhddee03Iz88XTp8+LS7b398vCIIguFwuoaGhQejr6wv7bum6XnjhBeGaa64RAoGAcP78eaG2tlY4d+6c8NprrwnFxcVCR0eHEAwGhWXLlglvvvlm1O3/7Gc/K/zud79L8ijkBgrni6KNJk8AQRCEVqBWwhE88sgjMJvNEb0JiDGobDBBEIRWoFbCYWzatAmvvPIKdu3aBYNBsXy+riFPAEEQhFagVsIiO3bswA9/+EO8/PLLyM/Pj2c3dQWJAIIgCK1ArYRF1q1bh9HRUVx77bVYtGgRvvGNbyS+4xqGWgkTBEGoGGolTMQDtRImCILQO9RKmIgRmg4gCIIgCJ1CIoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIKISi62Ev7ud7+LhQsXYtGiRbjuuutw7ty5lHyv1qA6AQRBEComoToBaWL37t147LHH8Morr8T8P4FAQOzmJ0dhYSEcDkcqNi+MkZERFBcXAxjrW3Dy5Els2LAh5etRG/HWCSBPAEEQhNagVsKiAAAAp9NJvQOUiNZiMEUPgiAIIkGolXDirYS/853vCDU1NUJDQ4Nw4cKFpI9DLkCthAmCIPQKtRIO45FHHkFHRwduv/12rF+/PjU7rTFIBBAEQWgF1kqYh7USTgPCP1oJHz16FEePHkVbWxuuu+46AFBsJfzuu+/ikksuyUgrYcbtt9+OF198MeH1aRkSAQRBEFqBWgmL8J6Gbdu2Ye7cuTH/r56gBkIEQRBagbUSfueuMQ9AyJ+2VsJ33nkn7r//frS3t2Px4sUQBAETJ07ESy+9FPF/119/PTZs2IB58+bhoosukm0lvHjxYvz+978X37/55puxd+9eXHzxxTAYDGIr4VOnTsW0rc3Nzfjggw9gNBoxbdo0XWQGJAKlCBIEQagYaiVMxAO1EiYIgtA71EqYiBGKCSAIgiAInUIigCAIgiB0CokAgiAIgtApJAIIgiAIQqeQCCAIgiAInUIigCAIgohKLrYSZvz4xz+GwWBAX19fSr9XK5AIIAiCIKKyZ88eAImJgPFK+kpFAFtXKujo6MDf/vY3TJ06NWXfqTVIBBAEQWgNaiUMAPi3f/s3/PCHP6Q2wlGgYkEEQRBaov25f5QNzhvrI3DZRqDuiyn56paWFjz22GN45ZVXAABPPfUUSkpKcODAAXi9XixfvlxsIHT48GG89957YifB3/zmNygvL4fb7UZjYyM+//nPo6WlBevXr8fRo0cj1vXHP/4RR48exbvvvou+vj40NjZixYoVAIAjR47gxIkTmDJlCpYvX463334bn/rUp8L+f9u2baiursbFF1+ckn3XKiQCCIIgtALfSjjoHnvvnbuAymvSUkHwb3/7G44dO4YXXngBwFijoNbWVuTl5cm2Ev7Tn/4EAGIr4YqKCsXvVmolXFxcLLYSBiC2EuZFgMvlwqOPPoq//e1vKd9nrUEigCAIQiuwVsJMAACftBJOgwhgrYRXrVoV9v7u3bsVWwnn5+dj5cqVaW0l/PHHH6OtrU30AnR2dmLx4sXYv38/KisrE16vFqGYAIIgCK1ArYQBAAsWLMCFCxfQ3t6O9vZ21NTU4PDhwyQAZCARQBAEoRVYK2GTHbAUj/1NUyvhxx9/HHfffTfq6+uxePFizJ8/H/fcc49sNsD111+PQCCAefPmobm5WbaVMAsMZNx8881YuHAhLr74Ynz6058WWwkTqYVaCRMEQagYaiVMxAO1EiYIgtA71EqYiBGaDiAIgiAInUIigCAIQuVkYNqW0ACJnCckAgiCIFSMzWZDf38/CQEiKoIgoL+/HzabLa7/o8BAgiAIFeP3+9HZ2ZlUXj2hD2w2G2pqamCxWKQfKQYGkgggCIIgCG2jKAJoOoAgCIIgdAqJAIIgCILQKSQCCIIgCEKnkAggCIIgCJ1CIoAgCIIgdAqVDSYIImn4LCP2PNb3jEYjDIZPgpeVnsu9JggiOUgEEISGSMYYh0KhsPfYg38t9x3JpBkLgoC8vDwYjbE5JZVEgcFgiBAPsYoJEhaEnqE6AQSRBqIZ3vGMciaMcVdXFwoKClBaWhr2v3IGMZn3YsFiscT0v+PtH/95R0cHjEYjqqurw7ZP6TvkRIFUSMi9R14LIkegLoKEPkmVMWbPpcZYEAQMDAygvLw8ZSNjIDYjyxsrub/RCAQCEAQBJpMp4W3NNOPtl9zxkXoY5L5D+nvJCS4l+vv74ff7ZfvcRxMQ5LUg1AKJACIjpNsYj/e9iW7veKO7UCiEtrY2lJeXJ2SMiewT7Xca7zf0+/3wer0RYkPu3JM7V+Ohu7sbEyZMQF5eXsT2kdeCSBQSAToj3nlipVFRqo3xqVOnMHfuXNntjdcdnQ1jTDdRgider0UsXLhwAaWlpWEiIB6vRTzb4/P5IAgC7HY7eS00DomALBGr4ZX7TPo8FArB6/XCZrNFzCFL/yfebWQXcrqNscvlyinXNEEAytdFupAb8fOfJYLcvaGvrw8+nw91dXUpExfktVAnuhYBckaWfx6vMZb7PBPG2OVyob29HQ0NDWHvR4ucJggtk4GAZ80wnpBP5H6hNB3C/ko/7+7uRiAQQG1tbdzbS7EWyaE5ESAIAn74wx9i3bp1iicd/7qrqyssgni87052ZJwOF7XJZJINgiIIPaO1G3smvQ7Jrive6RB2Px7vHpbKWIuzZ8+iqqpKbLurV6+F5kQAADz33HP4xje+EfG+3A/b09ODqVOnZnT7Uk201Cci/dCxJ4jMkMpYi76+PlRVVUXNGEl1rIXf70coFFJVrIXmRECybiyCiAc9nmOCICAYDCIUCol/+efxvmcwGGA2m2E2m2EymWJ+zjxgBJEM6QjiBOQHB/39/XC5XJg+fXpC32kwGGC1WlN63mtOBBCE3mDBoVIjK2dw2d+hoSG4XC4MDQ1FXU4Jk8kEo9EIo9EoPld6z2w2R13OYrEgGAwiEAggEAiEPfd6vXA6nWHv83+lMKHg8XhgNpvhcDhiFhe5MJ2WyemATJLpAMtMrDNaAGei51q0azJRSARoAJoOUB+xGuV434tW8U5qZOWMstFohNlshsViQX5+PkpLSxWXy9RIO9aKgePBjlEgEMDZs2dhNBpRVlYWJhy8Xq+i4JAeW17EKImH4eFhCIKAoaGhiM9SfewyfY2TlyX1ZEPsjAeJAEIXKI2WYxk1j7ec0+nEgQMHItY5njGWjpZjWS5V01xutxvFxcUoLy9P+rvUAjteFosFVqsVFosFEyZMSOi72PmiJBgCgQD8fj88Hg8CgQC6uroilpPC/87xTn9oPX02W4MYtRnkbEAigMgavFFmxjQZY8z+yqV0MuMZz2g5Ly9vXFe3wWDAoUOH0NjYmK3DSKQBdq6YTKaw4jxSzGYzgsEgpk2bFvX7WByFVCiMN/XBHqFQCC6XCwcPHhS7LkaLlcjFqY9sTAdkGvIEEGkhVdMB442Wk3FrK8EMqtfrRXt7u6pGy7EeM4IYDz74MVEOHTqEhoYG2Gw2hEKhCLEgfe71ehUFh9zUBy8U3G43jEYjgsFghICQExdqM2yxkqvbnUpIBKicWOaWvV4vPB4POjs743Jxy10AzKjGGvAVy2hZ2i9ejgMHDkQUO8oF6CZCZBJ2vhmNxqgeinhg4p8XEOfOnUMwGITdbkcgEIDP54Pb7VYUHFLinfLwer1igGgs94tU7XemIU+ABkjnaJl3XfPPx3Nds+3i1fx4hpxSKPWNHn57re1juowWP/VhtVoBQAx4rKqqivv7lKY++OdMULDXIyMjEAQB58+fj/AcyqWQxiMy1Dj1oSY0IQLYScUeALBnzx643W4sXrw4quH1eDw4depU1NGytKNctkbLSvh8PoyMjGDKlCmpOaAEQcSM1sQGkJzgSGTq48yZMzCZTKipqYn4TOqlUEolVfpcaerD4XDg5MmTsFgs49ajSNXURzKegHSJQE2IgJtvvhmjo6Ow2+3Iz8/HwMAANmzYAJvNhmnTpolqUG5u+cKFC6iqqhKVMI2WCSL3yZSrV8sxIZm890UzjmzqIxXTH8xLEQwGcfDgQdTW1kIQhIhYCqfTqRjIKSUezwSLtfB6vaJdivc453zFwB07duD+++9HMBjE3Xffjebm5rDPz549i7Vr12JoaAjBYBAtLS1YvXp11O/885//HPZ60aJF+O1vfxvTwbJYLCgqKspplxHVCSAI7aPG+eRcg/dSGI1GlJSUJHXvZwJCms3Bv+ZjKdg0y+DgoGzQdLTqmSaTCaWlpbDb7ckehjAyKgKCwSDuu+8+vPrqq6ipqUFjYyOamppQX18vLvPf//3fWLNmDe69916cPHkSq1evRnt7eyY3My4M3j4Y3Gcg2KdBsCaWk0wQBEHkHgaDARaLRWxCNB5nz56FwWBQ7JYYberD7/enZbCXURGwf/9+zJo1CzNmzAAA3Hbbbdi2bVuYCDAYDBgZGQEwFpyi5nluc9cfYDu6DjBagJAfnkVPIFB9S7Y3iyAIIilYoHEm15cNL0c2ahNEO67Rpj6SbWakuM6Uf2MUurq6whRQTU0Nurq6wpZ5+OGH8cwzz6CmpgarV6/GL37xi7jXE497PFFXusHbB9vRdTCE3DAERmAIuWE7eh8M3r64vytZaDqASAQ6Zwg9Q+f/GKqbCH/uuedw5513orOzE9u3b8eXv/zluJsmZMIoGtxnxjwAPEbL2PsEQegCMiREPKgxriOjIqC6uhodHR3i687OTlRXV4cts3HjRqxZswYAcPnll8Pj8aCvL77RtdFojFk4JCoYBPs0IOQPfzPkH3ufIAjdkMmbulYrYeplOiBZ0rG9GRUBjY2NaG1tRVtbG3w+H7Zs2YKmpqawZaZOnYpdu3YBAN5//314PB5MnDgxrvXEIwISRbBOgGfRExCMdgjmYghG+9jrLAQH0nQAQWgf6iKY+6jRE5DRwECz2Yz169dj1apVCAaD+OpXv4qGhgY89NBDWLp0KZqamvDjH/8YX/va1/D444/DYDBg06ZNcR+0THgCACBQfQucE1ZSdgBBEEQSqNE46oWM1wlYvXp1RN7/9773PfF5fX093n777aTWkQlPAEOwTiDjnyLoRkAQhJZR4z1OdYGBqSBTngC1oIV9IIhUo7abbbJk0oCo0VgR6UH3IoAgCCIZyFimBj0cRzWKK02KACD2IBq1/SAEQSQP9Q7ILeg4Zg9NioB4PQG5fgJqZTpAC/tAEAShhBo9AZroIigl3pgAIvvQ76AdBEEQW3JLH3LvG41Gsf662WwOa+1qsViSbt9KxE+mjZUajaNe0L0IAGgESugPZqj9fr+ssY7FePOf8d4og8EgtuPmH9L3zGYzrFYrTCZTWAtXv98vNk5h28fDCwTpc/bX4/HAaDTC7/fDbDZrwsCQocx91PgbkgjQAGo7qYjUEc+IOtoy/PUgCAJ8Ph/MZjPOnTsXYayZwWYtTPPy8mSXYQ+DwZDUOWixWGL+f773u1Qs+P1+eDweBAIBDA0NYXh4GL29vfD7wyt7MgESTURIP8vlVuMEEQ3diwCtzKdrgVz9Hfie4omOpuUMNYCw0bPc6Jo9mNucGW/pskajMczQtrW1obCwMO5qnNmGb90ara/66dOnYbfbUVVVFfa+IAhhLVqZkGB/nU6n7Gf8ucm2gXkczGYzvF5vVCGRa1MaNB2QHtS4n7oXAYQ6SPeFwW7+8Y6m5ZbjvxMAXC4Xjh07pjiiZs+jjajZcmq7QWgNg8EgGuZEYdMogUBA7A9fUFAAv98Pr9cLh8MRISSkUxpyXgj2XOkzgkgHmjyzMtFKmEg9coY6UVc4r7jZ81hG1MxQR1tGaqgPHDiAxYsXZ+OQEVFIl6AyGo2wWq2wWq2w2+2wWCyorKyM+f+Z50jqhWBTGm63O+KzQCAAh8OBffv2ieey0tSFkjdCzVMaerkHkycgQ5AnIH1II79jnZsOBAIRy7KAMgBwOp04fPjwuCNlaUCZ0nJqvuER+oaf0oiHvXv34rLLLoPBYEAwGIyIiWB/vV6v7Ge8oWUZGUreCIfDAYPBAIfDIX5mMplSfSjCUJtx1Au6FwFa8QTw+yAIQtRRdbxucOnFaTQao46UeUM93oiaffehQ4dw8cUXk9uTSAlauKaVSMWUBouLkPNGuN1ueDwe+P1+jI6Oiu/z91S2DfEEV9J0F3kCMobRaMyJmwAzsonOTfPvu1wuHDhwAMDYiSYXGCYXMMYuTqVRtzSgLF2o7cIgCC3Drm+r1Sr7eSgUQlFRESZPnqz4uVJwJUv1lH4WLdVzdHRUjKeIJijoPpF6NCsCUuUJSHZEzS8TbZ46mhtcyfXNL3Pw4EE0Njam5PgRBKFvxhuxGo1G5OXlIS8vL+HvZyIiEAjg448/Rn5+PiwWCwKBgJjqKRUSPLmY6kmegDTBRsJOpxNOp1McFZ88eRILFiyA3W5XNMxDQ0Nwu93iPBtf8IQRreCJUuS33HLp/PFzwfNBEFqEOvvFjzQuwmazoaysDBUVFTH9fypSPZ1OJw4ePBiXkNDilIYmRMC///u/49ChQygoKEBBQQE+/vhjvPLKKygrK0NlZSUqKyvFQBibzRZmmP1+P2pqalBcXCzOdRPZgYQMkWvQOZsa4j2OqYiLePvtt7FgwQLF4MpEUz2jZW3wwdBqIeMiYMeOHbj//vsRDAZx9913o7m5OWKZrVu34uGHH4bBYMDFF1+MZ599Nup3Pv7442Gvv/jFL+Kb3/wm6uvrx90ePi83l1HbiRUvub79BEEkR6bvAQaDQUz1TIR4Uj3Z+w6HA/39/aK9iSfVk3mcU01GLV8wGMR9992HV199FTU1NWhsbERTU1OYsW5tbcX3v/99vP322ygrK8OFCxfiXo9WIv4JIl2Q6CKioaWph3SRSKrnyZMnMWXKFJSWloZNacgJCa/XG/HerFmz4qpJEQsZFQH79+/HrFmzMGPGDADAbbfdhm3btoWJgF//+te47777UFZWBgCYNGlS3OsxGAy6SxEkCEL7aNUw60V0SMtPs5G/zWaL6X/TcYwyOgHe1dWF2tpa8XVNTQ26urrClvnwww/x4YcfYvny5Vi2bBl27NgR93pMJhMVCyIIgiBUhRrFjuomwgOBAFpbW7F79250dnZixYoVOH78OEpLS2P+Dj0WC9IC9DsQhDqga1E/ZNQTUF1djY6ODvF1Z2cnqqurw5apqalBU1MTLBYLpk+fjjlz5qC1tTWu9ZBhzz3Upo7jIVfPtVzd7ljJ1DmVy+duNKiLYHpQ235mVAQ0NjaitbUVbW1t8Pl82LJlC5qamsKWuemmm7B7924AQF9fHz788EMxhiBWyBNAEEQmyNq9Y+QUjO2/A0ZOZWf9REKo0dZkdDrAbDZj/fr1WLVqFYLBIL761a+ioaEBDz30EJYuXYqmpiasWrUKf/vb31BfXw+TyYQf/ehHMReQYFADISKTqE3ZE+q82aYK05FvwnR6g/g6OONeBC95PMp/EGpBjR6PjMcErF69GqtXrw5773vf+5743GAw4Cc/+Ql+8pOfJLwOaiWce9DvQBAxMHIKptMbwJsR0+lfIjjzHqB4bspWk2ljpUbjqBc0WR6PPAEEQWgR48CBuN4n1IfaxI5mRYC0vKMSNAIlCCIZMnlTD5XLNwlTep9QF2q0NapLEUwF5AkgCHUhCILYuIvVYGfPzWYz8vLyxOprFotFdaMlJTJ+Uy+ei+CMe2E6/UvxreCMe1M6FQBkfr/0Mh2gxv3UrAhQo+IilCGPjPrgy5ryRlvur9x70mYprEIaawHLN/IKBALw+Xxi3XX+f3hxYLFYIgQDe08v/eaDlzyO4Mx7YBw4MOYBSLEAYOjhWOYa6fhNNCsCKEWQ0BvRRtvS5wMDAxgcHERvb2/Y59JW2lKDLTXidrtd8fNYO3JGG/mHQiFRGLCHz+cTu7xJP2N4vV5YrVb09PRECAapkMhJ8VA8F6E0Gf9skI1AxGyhtnNN9yKAILJJpkbb7LnFYoHdbofH44HdbsfEiRPDllPbDcpoNCbU6a21tRX5+fkoKSkJ8zAw8cC/FwgEwtY3nteBvW8ymVK9u4TGUeOAU7MigFIEiXTAj7aZMQ4EAujr64s68ubf47/LYDAoGmz2XGm0bTKZYDQaEzLcTqcT+fn5KCgoSOXhSYh0CA82jVBYWBjX/wWDwQjvgt/vh8fjwcjISNh7gUAAXq8XRqMR7e3t405XsOdqFFtS1Dh3nWqytX9qO66aFAHxdBEk1EE6xViio232nD+XDAZD2GibzWcPDw9HjLbl3Oe5YAC0QKLnEvuNYunqBgAff/wxCgoKMHHixLDpCr6nPC8efD5fmBBk50sscQ9aHqzoZTpAjb+hJkUAxQTkNnKj7Wgj62ijbYbSnDY/2lb6fLzR9oEDBzBz5sx0HhJCxTBvTjziAfjkPOdFA3s4nU7Z9/bs2QPgE/EQbbqC9zwQ6kFtgwDdiwAiNbDRdrxz2uy5y+XCsWPHxAvEaDRGdZHLjbb552q70AhCChMPdrsddrt93OX37NmDK664QrzWpMGSUvHA3uPvhSaTadzpCq17HYDsTXckc1zT9ZuQCIA6XTSZIBQKxWWopc/lIsmjRZOzUYncaPvEiROYPXt2TDdDglAL2bh3sOko5sGKFSYe5DwP0mDJ4eFhDAwMiF4Edv3GEvcQa1aIdNv0ItzVtp+aFQHxBAbmCtFG236/H52dnVENulwkeTQXeSZH2zQtQxDphRcP43HixAlUV1ejtLQUgiAgEAjIeh48Hk/E+/x1LDdVoQbPQy56AtKFZkWAWqYDxhttjzfy5k8afu5RapRDoZCY3qRktBONJM8Eat0ugtA7fMGmeODFg9T7MDIyEuF5OHLkiOhFiKdAVCKeh2ySzL2OigXFiMlkSjhFMNpoO5b35CLJo422zWYzbDabYuBarD96b28vpkyZEt+BIlKCGtU9QSRDKkbKvHjIz8+PuuyRI0dw0UUXIT8/H4IgyKZp+nw+uFyuiPf5aUnmwRwvYDJbgw413is0IQKYkhwdHcXo6Cg6OjrgcDgwODiIhoYGVFVVKRptt9sNg8GAs2fPhuVtR8vdZkZbTaNtGkkTRHagay+1GAwG5OXlIS8vL67/Y15XOc8DEw/sfSYo9uzZI1uaOpqQSIU4UhOaEAH/8z//gxdeeAFFRUUoKirCBx98gMmTJ8Pn82HGjBmKo22TyYRz587BarWisrIy27uRFGpUmPGSq/ugtouayBy5es5qEaPRKIqH8Ypg+f1+HDlyBJdeeqlsaWq+uqRSaWpePIyXccFKU6vxfMm4CNixYwfuv/9+BINB3H333WhubpZd7sUXX8Qtt9yCAwcOYOnSpVG/8+tf/zq+/vWvi68fffRRTJ48GWvWrBl3e+gGrg7odyAI/ZKNYkF8OnIipalj7Wvh8/nE0tROpxMHDx6Mqb5DpvpaZFQEBINB3HfffXj11VdRU1ODxsZGNDU1ob6+Pmy50dFR/OxnP8Nll12W0Hr0WCyIjChBhEPXROLoKWUvURIRD++88w4uueQSWQHh9XoxOjoaUZqaX9+SJUviDtAcj4yKgP3792PWrFmYMWMGAOC2227Dtm3bIkTAd7/7XXz729/Gj370o4TWo6bsgEwhCAJduARB5CTZuHdl617JCjbFU10SGJvCiDdOIhYymlvR1dWF2tpa8XVNTQ26urrCljl8+DA6Ojpwww03JLwePTYQIuNPEJ+ghWuaSB+52DsgXZVQVRUYGAqF8K1vfQubNm1K6nviEQGEOtCKGCMILaAHr2K2igWp7bhm1BNQXV2Njo4O8XVnZyeqq6vF16Ojo3jvvfewcuVK1NXVYd++fWhqasLBgwfjWo8eYwIAGv0QsaO2G1EuQ8cyNeihi6AayagIaGxsRGtrK9ra2uDz+bBlyxY0NTWJn5eUlKCvrw/t7e1ob2/HsmXL8PLLL4+bHSBFj62E6UZEEJmHjElq0NNxVNu9OqMiwGw2Y/369Vi1ahXmzZuHNWvWoKGhAQ899BBefvnllK3HaDTKtpNVQk8nIEEQhN6h3gGfkPGYgNWrV2P16tVh733ve9+TXXb37t0JrcNoNIalVkRDK9MBWtiPXN/+XIOON6FENvP2tY7a9lNVgYGpQo8pgrmO2i4MIr2EQiGxdHcgEEBeXl7aop8JQoqeRMd46F4EaGEETRCZhNVo53twKD34z+U6YrIucD6fL2wKj1VPi/bIRDU1vUL3RP2gSRFgMpl05wkgMUPEAt9kRRAEDA4OxmTApd0xWQdMuQffYIt/KLV8lRZAYV3kfD5f2GN0dDTsNT/lZzabwwTC8PAwgE8Ks2S7exwRHT0VC1IbmhQBeiwWpAXod4hOPCNwfjm5EbjP54PFYoHf70/KgKeDeLvI8aKB/R0cHITH40FPT48oGvjmL7w4UHpYLJZx91vLbmWt7hdA9xoeTYoAPaYI5jpavuEA4QY8Hle6kgs92RH4mTNnYLPZMHny5EwehrQgJxqGhoZQUVGBCRMmRCwvCAICgUCYOPD5fHC73RgeHg7zNrDlmadBOk3hdrvhcrng8XiQl5eXUbGkNbR+D1ArmhQBeowJ0Mp+qJHxDLjX60Vra2vSBpw955cjo5J6+Baw47WcBcZEQDAYjJie8Hq9cLvd6OnpQW9vL3w+n/ib821to8U3mEymdO9uQmQjOyCTaNmDEy+aFQFkEAkg8RE4E5EGgyFsDlxppD1hwoSMG3CDtw8G9xkI9mkQrJEjXiI18L9/fn5+2Gc+n0/W4yAnGnw+n9hilr3mzzO56Yi8vDxYrVZYLBa6pxFpQbMiQG+egFxH7ndIxIBL60OMZ8BTMQLv7OxEWVlZSo5DrJi7/gDb0XWA0QKE/PAsegKB6lsyug2EMiaTCXa7HXa7PablQ6GQrGhwuVzilIXL5cKePXsAfOLNUIplYOKB0i6VycXjovkGQqlCj3UC1CZm5Ax4NEM+MjKCwcHBMPdoPAacX07rLnSDtw+2o+tgCLmBkBsAYDt6H5wTVpJHIAuk4sZsNBphs9mitpfds2cPrrjiCgAQ+9FLRYM0piHWtEv2WbYyKLQ+/aBmdC8C1GY81UC8BlxpDlzOQCsZ8La2NkyZMgWlpaXZ2/EcweA+8w8PgPuTN42WsakBEgG6wGg0wmq1wmq1xrR8vGmXLpcLx44dg81mGzeDIhdH1MQnaFYE6NWwZ8OAp2IETm7L2BHs04CQP/zNkH/sfSKj5Mp9Jt60y0OHDmH27NliOil7OJ1ODA4OpjztksoUZw9NigAgvotTLRdyIgacV+5HjhyRdZun24CnArogY0ewToBn0ROwHb0vLCaAvABEqmAxB3a7PakMCmnaJStSBXwiGiwWCzweD86cOQOr1RohHLJ9b9I6mhQB8U4HpIJoBjyaIZduy3iV2JQM+Lvvvou5c+fG7B5UI2oRY7lAoPoWOCespOyAKJCwTJx4R8rRMiiUYLUa/H4/BgYGYDab4fV6I6Yo0pF2SZ6AT9CkCIi3bDCLzE2XAWeKWo0jcCJ3EawTNGH86YasT9h9kD2vqamJeh5IPQ0sxsHpdIa9H0vaJX+/z6WpSMoOUMDlcqGzsxPDw8MYHh7Gvn378PHHH+O//uu/MHv2bCxZskTRgAcCY3XRHQ5HThtwCnAkiE+ga0F7pCrt0u12w+FwYGRkBIcOHQrLoBgve0KLjas0IQKOHDmCX/ziFygpKUFJSQm6u7vh9/sxYcIE1NTUiIVc+Af7Efv7+zE0NISZM2dmeS8IunETuQZ5MdRLtLTLoaEhdHV1oaGhQXwvWtol/z4/iFRz2mWsZFwE7NixA/fffz+CwSDuvvtuNDc3h33+k5/8BE8//TTMZjMmTpyI3/zmN5g2LXrU8/Lly7F8+XLx9fbt2/Hqq6/i3nvvHXd7tDSCzuX9UPNFQhB6Qw9d/aTrS0fapd/vD8ugcDqdOHr0qKrSLjMqAoLBIO677z68+uqrqKmpQWNjI5qamlBfXy8uc8kll+DgwYPIz8/HL3/5S/zHf/wHnn/++bjWo8cUQTKiRDzQ+ULomVTYh0S6Xe7ZswezZ89OKO3SarVi7ty5SW+3lIyKgP3792PWrFmYMWMGAOC2227Dtm3bwkTAVVddJT5ftmwZnnnmmbjXQ8WCCIIgCDXB+pAUFBQklHbJi4NUklER0NXVhdraWvF1TU0N3nnnHcXlN27ciM985jNxr0evhj3X9znXt58gtIIeYh3Uvn/StMt0lcJXbWDgM888g4MHD+L111+P+3/12jsgl8n17c9FSHQReoXO/U/IqAiorq5GR0eH+LqzsxPV1dURy+3cuROPPPIIXn/99YSK39B0AEEQmYIEbO5B9/xPyGiie2NjI1pbW9HW1gafz4ctW7agqakpbJkjR47gnnvuwcsvv4xJkyYltJ5sVAxUA3RiZwc67vqFfvvcRUv3/mTIqAgwm81Yv349Vq1ahXnz5mHNmjVoaGjAQw89hJdffhkA8MADD8DhcOALX/gCFi1aFCESYiHe6QAtXMh0QhO5SCgUSsvUnRau6Wyih5gAYoyMxwSsXr0aq1evDnvve9/7nvh8586dSa9DjymCuQ5Ny+QurG+G3+8P+6v0Hl9sxWg0hv32ZrNZbCLDcrb513l5eTEbJzJihBIkcj5BtYGByaDXmACt7AeRefjeGNGMOXvOl1o1Go1iiW2+3LbZbEZhYWHEe9Ja7aw4iiAICAQC8Hq98Hq98Pl88Hq9cDgc4mufzyf+H58/LRUO0vbYBEHIo0kRYDAYKDuAyBhqOPaCIMQ0ImfPnU4nAIiBuqx1rJwxZ90r+ffT0XSFbYPFYkFhYeG4+8tEARMNXq8XIyMj8Hq9GBwcFDvTsaIucmKBPWeNbIgxtD5S1vr+xYMmz/x4pgO05AkgchtWHETJcMuN1Plzl43IeYPN/tpstrD3uru7YbVaUVVVlcU9ThyDwSAa8qKioojP33//fUyePBnl5eViIxnew+B0OjEwMCC+zzwbrHRstOmIWFrVEkSuoFkRoEdPQC6LmVzffgZvyMebG2fP+XPVZDLJutUtFgvy8/NlR+SJwObi9UC0RjJSgsFg2FSE1+vF8PBw2Gt2nppMJnHZgYGBCNGQl5enqk6jRDiZPv/Ven/TvQjQivEhUgcz5LG41QOBAJxOJw4cOCD+v8lkkjXieXl5yM/Pjxilk6FQDyaTCfn5+cjPz4+6HDtH3nvvPZSXlyMvL0+chuDjF9i9xWKxKE5FWK1W1Xea0xp0z/8E3YsAQpuwILNY3ep8xDqgPCK3Wq0RwW5Hjx5FY2NjlvaUyAaspKvFYkFxcTFKS0sVl2Xd5qQehtHRUfE5XxdeOv3ABzv6/f6M9LOnOfPUo9ZjqlkRoLeYAK3sBw8z5LG61aWGnBlqqQtdLtAtmRG5Gi9sQj3E022OxS/wYsHtdmNoaAherxdHjhwRz3MWF6EUv2C1Wil+QQG1GuRsoFkRQJ4AdcAi1scz4sPDw+jt7UVbW5soZvgGGtJRud1ulx2p04VN5DLR4hcGBwdx6aWXiq9DoVBEOiXrZc/eZ/dB1pI2WoYETUulF7UKDxIBxLhIU8+iFYGR5pADkI1WZ52x2HsmkwnFxcWYPHmyKi8UIvfI1HmUsvV4e2FwnoFQMA2wTgz7SM7LZzQaYbfbYbfbx/3qQCAQkSExPDwc9pov2OR0OvHhhx8qioZcv0bVapCzgSZFQDx1ArTiRh9vP0KhUMxz44FAIMyQy43I2d+CgoKI9xPJIe/r60tL7nmmoJsKkQzGjudhPvQNwGABBD8CS36FUO2alH0/L7yjwabg3nnnHUycOFGMZXA4HKKIiLVgU15eHgU8cqTiHpGOY6lJEaDVssHRqrqNjIzA7/ejq6srbETOThq+GEwiVd0IIpfI1PWfkvV4e2E+9A0Ygm4AbgCA+dA98E26KsIjkG7YfcJkMqG8vDzqFMF4BZt8Pp8Y8MgXbJKLYRAEgYR0ltCkCDCZTKr0BMRa1U1uRG4wGKJWdbNYLCgtLUVpaan4Xq7lgmtRuBHEeBicZ8Y8AP8QAGNvWsamBjgRoLZrebyCTTzjFWxyuVzYu3cvgMiCTXKiIdmAx2wIDrWKHE2KgHTGBChVdZObG49W1U0uqM1ut8uOyGNhdHQUhYWF45ZbVStqvDgIIhMIBdMAwS950z/2PnuZYYGcaoM1XsGmPXv24IorrgAgX7BpdHQUfX194vuhUAiCIIhpu0rBjlSwaXx0KQL4YjAulwterxe9vb1RR+dSQy43ImfFYFJV1Y0gCB1gnYjAkl/BfOiesJiATE8FqIV4CzZJMyQGBwfD4hfkCjaxyo99fX0ZK9hEnoA04nK5sG/fPgwODmJwcBCnT59Gb28vvvKVr6CyshK33nprhCFnVd2MRiN8Ph8cDkfOV3Ujd3r2UOsFTuQGodo18E26SjE7gIiED1guKCiIuqy0YNP58+fh8XjQ398vW7AploZTmb7e07U+TYgAh8OB7du3o6ysDGVlZZgyZQoKCgqwdu1aTJkyBXV1dYqG3Ov14tSpU5g+fXoWtjx1kAEiiOyQsmvPOjEsBiDbaOmeIi3YxMRAXV1dxLIsk4r3MPAFm3w+X9SCTdLnrENlsgOFdA3yxhUBBoNBAPB7QRC+9I/XZgDdAN4RBOGz8a5wx44duP/++xEMBnH33Xejubk57HOv14s77rgDhw4dQkVFBZ5//nnZH4pn0qRJeOyxx8TXXV1dePnll7Fy5cp4N4/IErmcqqmlmyWhXug8Sx3R7jUsMNFqtY77PaxgEx+/wAIepQWbDAYD3G43Tp48qaqCTbF4ApwA5hsMBrsgCG4A1wLoSmRlwWAQ9913H1599VXU1NSgsbERTU1NqK+vF5fZuHEjysrK8NFHH2HLli349re/jeeffz6u9cTbQEgr5KoRJYhcJadSEYmUE0/BJofDgZMnT6KqqiqiYBMTEXzBJqlQsNvtmDx5csr3IdbpgO0AbgDwAoAvAngOwJXxrmz//v2YNWsWZsyYAQC47bbbsG3btjARsG3bNjz88MMAgFtuuQXr1q2L240Sb50ALVxgWhIzBEEQ6SQbMTwsSLysrCzqcqxgkzTgMV0Zb7H6HrYAuM1gMNgALATwTiIr6+rqQm1trfi6pqYGXV1disuYzWaUlJSgv78/rvVQK+HchH4HgiC0SqzCg9WDKSwsREVFBaqqqlBXV4fq6uq0bFdMIkAQhGMA6jDmBdieli1JIXrtHZDLRpQ8GUSq0do5pbX9ySbZyuZR428YTxTCywAew9hUQEJUV1ejo6NDfN3Z2RmhbvhlAoEAhoeHUVFREdd6TCZTThvERFDjyUWoFzpfUkcmjqXe7mdaRK2/YTwpgr8BMCQIwnGDwbAykZU1NjaitbUVbW1tqK6uxpYtW/Dss8+GLdPU1ITNmzfj8ssvxwsvvIBPf/rTcV9kNB1AZBo6h8KLcPEPVnRL+h5fL565QK1WK2w2W8TfeCu/UcAeEQ363T4hZhEgCEIngJ8ntTKzGevXr8eqVasQDAbx1a9+FQ0NDXjooYewdOlSNDU14a677sKXv/xlzJo1C+Xl5diyZUvc64mni6CWyPUTO1e3P1dH1bF0nYxmyNmD7zgp7SjJHoWFhWGv+bodFosFAOD3++HxeCJKxbL3mGBQEgqZqPpGaAfqHTDGuCJAEISIYvSCIOwGsDuRFa5evRqrV68Oe+973/ue+Nxms+EPf/hDIl8tokdPgBpPrnjI9e1XKyzSWGrIBwcHAUDsPsk+Z/8jLY3NHjabDUVFRUm3jpYiLeaiBGtEw4SBx+PB4OCg+JpVffN4PHA6nSgqKhIFAi8WWAEXgtA7mrwS9BoYSGgb1rhKaUTOG3rWYMVgMMBkMoUZcma4LRYLJk+eHGbo1S7GxmtEwzh+/DgmTJgAq9UqCgSWk+31ekXvBZuCkPMqZKt4ixJq/21yCSZ0M71ONf6GmhUBsY7uteIJAHLXna43+NF5NEOuNDqXPvimVbyRj0ZHR4eYgqtFWBGX0tJSxWX4evJMKDidzrB68qFQKKxlrlQoBIPBjFx3dG0T6UKzIkBvngA1KkytwwLhQqEQRkdHI+bRpQadD4STGm1p8yp+7px+2/TAT0EUFRUpLsemIHixMDg4CK/Xi6GhIbz77rswmUxh5WblYhZoCkI9ZGNUTp6ADKJXT0Auk+3fIRQKxTw650d/JpMJbrcb586dQ15enmi8CwoKIoy8mlzLROzwUxBSz8mxY8cwY8YMFBYWim1t+XiF0dFR8TXz6ihlQbDndJ4QmUSTIiDbBiVb6HGfpSilqSlFubP/YSlq0ofVao2IbJcGwh06dAgXXXTRuC54IrNkOn/fZDIhPz8f+fn5UZcPBAJhQoE1nGHvsSmIvLy8sEBGv9+P4eFhMWVSjaPKXIKKBY2hSREQD2r8URJBK/vBI+deVzLmcmlqUre6zWZTTFNLFhJgRCzwYjPaFIQgCGJcAotVCAQCOHv2rFhPnn2fXPYDLx60eG9Ilmxcr6lYZzp+S82KALopqwelQDj+vZGREQSDQXR1dYm/nTQQjhl3u90u62rP1s2ObrLqI9evf2bcWRaEz+dDX18fFixYELYcm4LgpyEcDkdEyiQTwUrTENn0YuX6bxUrFBOQQdR4oDNBJi4mqas92jy6UiAc/5wZ9Ly8PJhMJtTW1ur29yOIeIl1CiIYDIZNQbjdbjG40ePxiPcO1rrW4/Hg7NmzYULBarVq5tpUq0HOBpoUAXok3hOapUeNZ8jlAuHkisjIRbXHM7pwOBwJ7QdBENFhIrywsBCFhRG130QEQRCzIAYGBmAwGMJqK7CqjSwLQmkaIt4pCD0ZZDXuJ4mAHIcPhAuFQhgYGIg6hx5LmhqLbOdLwKrx5CUIPZHua5Cvh2CxWMLavvOEQqGILAhWW8Hj8YhZECaTKWoWRLanILKRIqhGNCsCctFojZemxhtzdqEBYxdbIBCAxWJBMBgMq9cuNfSUfkQQqSNTxkRNBoQVYrLb7VGX47MgvF4v3G43hoaGwrIggLGUSZfLhQ8//DDpxlFqRq0eD82KgGwSb5oaHwgnNzqPJU3t7NmzyMvLQ2VlZbZ2O2nUdKMjCCI5Yp2C8Hg8OHz4MMrKysTaCr29vRFTEHzKZCoaR6nRIGcDEgHjkEiamlK9dtaAhdLUIsn12g65vO0EkS1YPQSTyYSJEycqLsemIKRVG6VZEKywk1LMAqvamK3rVY3CQ7MiQPojR0tT83q9+OCDD8LeU0pTk0a1x1OvPZ2o8eTSC3TsiXSjVldypohnCkIqFuQaR/n9ftjtdgwNDWWscZRaBwqaEQFPPfUUent70d/fLz6WLVuG/Px8tLS0KAbCsSj2yspKqtdOEASRYVIpcMxmM8xmMwoKCqKu74MPPoDdbkd+fn5CjaOYR1cLWRBZFQEDAwO49dZb0d7ejrq6OmzduhVlZWVhyxw9ehT33nsvRkZGYDKZ8OCDD+LWW2+N+C6LxYK5c+eioqIC5eXlOHr0KP76179GPRkYnZ2dmuimplalGSu5vv2EPlHjjZ1Qhk3X2u32cacglBpHeTyesCmIaFkQam8cldWta2lpwdVXX43m5ma0tLSgpaUFP/jBD8KWyc/Px29/+1vMnj0b586dw5IlS7Bq1aqIFqFf+cpXxOdMccUiALRCrt+Icn37CfVB5xQRjfHOj2iNo3jkGkeNjIxENI4CEOZhkIqGbGVBZFUEbNu2Dbt37wYArF27FitXrowQAXPmzBGfT5kyBZMmTUJvb2/UPuEA3QAIQs9kyqtE3qvkyfWc/VirNvb09KC3txcVFRWyjaP4qo1KXgVWRjqVZFUE9PT0oKqqCgBQWVmJnp6eqMvv378fPp8PM2fOjLocO6HUOgeTLuiGRBDaRG/3Mq3BpiCsVismTJiguJy0cZTH48Hw8DA8Hg9KS0ujNp1KlLSLgGuuuQbnz5+PeP+RRx4Je20wGKKe5N3d3fjyl7+MzZs3a6Z4RCqhGwRBELlItjwBarxnShtH8bDiSqkm7SJg586dip9NnjwZ3d3dqKqqQnd3NyZNmiS73MjICG644QY88sgjWLZsWbo2lcgiVCdAO/B9KXw+X9hf/rm06iW7+bGH3W4Xq8ap8YZNEPGgVuGR1emApqYmbN68Gc3Nzdi8eTNuvPHGiGV8Ph9uvvlm3HHHHbjlllti/m493pT1uM9qQI0Xdirhq1/KGXP2PBgMiseC70XBl7Hm32epuBaLBaFQCB6PR+xw53A40NfXB4/HA5/PBwBiRLdULCSSrpWLaH3/MolaDXI2yKoIaG5uxpo1a7Bx40ZMmzYNW7duBQAcPHgQGzZswNNPP42tW7fijTfeQH9/PzZt2gQA2LRpExYtWpS9DVchuT6SJjIDK2nNDHhfX5+iYWfNpljJVqlht9vtYe9LS1nHg8lkQkFBQdSMnkAgALfbLYqF4eFhnD9/PqxpDavKOTIygp6eHvh8PlEopCtVS2+9A4jEUaPwyKoIqKiowK5duyLeX7p0KZ5++mkAwJe+9CV86UtfyvSmEUROIOd6l3PDyzWcYkaRGc6ioqIwo6622Buz2YyioiLF4Ch2LDweD06dOoVQKIT+/n5RNLBqcXyktXTqQW37rAf0EhOgViGn7ioGRFyo9SSLlVzf/lQQj+sdgOhOj9X1zujo6IDZbBazc7QAq0Ofl5cHu92OqqoqFBcXhy3Doq+ZMOBzuj0ej2gcmFCQTj9I87npnCViRa1TEJoVAWo82Okk1/c317dfDqnrPZphz6TrHdDm8ZYit4/Roq8ZrFkNi09wu91hzWrY72Sz2TA6OorOzk4UFRVRIGOCZMs45tJvxMRmOrZZsyKAIFKNkuvd7Xbj448/FkfxfAMq1q+CN+DM9c6/nw03tJZHscnsG9+sRlrGnBEMBuHxeHD8+HGYzWY4nU7ZQEbpdEMygYy5ZLTUDnUR/AQSARoi12/qmd5+Vhs8Wde7yWTChAkTkJ+fL+t6J7QHC2TMy8tDZWWlbHc7uUDGnp6esLrzTBTKxSfwgYy5fm0T6v0NNSsC1HrA00WuG51ktz8e1zsrupEq13tfXx+Ki4thtVqT2gciN1E6N+IJZGRTD6yMrDSQ0WQyweFwoKurK0wwZLN9earQy3QAxQQQRBzEE/WeC653QpskM9jgAxmlAYz893u9XgwNDaG9vR1+vz+pQEZiDL0NEqNBIkBDqPnEHs/17nA44PP5cOHCBQCJR70ThJZggYxFRUWw2Wyoq6uLWCaeQEY1VmTUiycgW+scDxIBGiGTJ1c6XO8jIyPw+XyYPn26Ki8Ugsgm0QR+PIGM7DFeICMT5FqtyJiNAVOy60zX8desCDAajaqdg0kXiZ5k47ne2fN0ut69Xi/8fr+ufi+CiIdkro14KzJ2d3cnFchIRKJWe6TZX81oNCIUCulmPow/uXjXe7QmLnJR77wBJ9c7QegHPpAxLy8Ps2fPDvs81kBGVqxJrseDWgIZ1WqQs4HmRUCsqPWkiNX17nK5EAwGceHChYwVnCHGoGNI6IF4Ahn5qYfR0VFRNEgDGW02GwwGg1hvQ+uBjGq8V5AIyDDpcr0PDg7C7XZj+vTpWd5DfaLmoEwivWTqxq5GAyIlkYqMLNvh/fffjxrIyGc8pCKlmHoHjKFZEWAwGGIWAawDXyInhVpc72pxsyUKdUEkUk0uGM1Y0dK1IQ1kLC4uhsfjCesMG28gYyoqMqYbtXqbNSsCEvEEZLPgDEEQuYeWjHM2kd4bYw1kZN6EeCsyhkIhuh//A02LAJ/Ph3PnzqGoqAiBQEDRsDscDhw8eBAGgwEmkylnC87QDYkgxqBrQfuYzWYUFhaisLBQ9nNpIKPH4xEDGQcGBnDkyBGYTCbk5eXJehPSEcioRuGhGRHw6KOP4tChQ+jt7YXD4UB7ezuuu+46lJSU4Pvf/z5KS0sVXe/vvvsuLrnkkpx2qavx5CIIIvfItIBKl5s8WiDju+++i5kzZ6KgoEAxkNHj8YgeAz6QkRcM8QQyqlWYZlUEDAwM4NZbb0V7ezvq6uqwdetWxWIXIyMjqK+vx0033YT169dHfP75z38eX/ziFzFx4kQUFBTgqquuwm9/+1vF7+MhA6oO1HqREEQ0KDAw92DCI5FARo/Hg6GhoXErMkoDGSkmQIaWlhZcffXVaG5uRktLC1paWvCDH/xAdtnvfve7WLFiheJ3XXTRRWGv44kJ0EpQWi7vgxovjnjI5WNPqB86v7JHqioy+v1+5OXlweFwqCqQMasiYNu2bdi9ezcAYO3atVi5cqWsCDh06BB6enpw/fXX4+DBgzF9t1pTBNNFrhvRXIaOvX7RonHO9IhVC70DYglk/Pjjj2EwGFBUVBR3IKPVak1bRcasioCenh5UVVUBACorK9HT0xOxTCgUwr//+7/jmWeewc6dO2P+7kRSBAmCSA0sKMvn88k+2GfMAJjNZnG0xT9sNpsqg3CJ3CYb93uj0Qir1YqJEyfKfh4tkNHj8aCurg5Tp05N+XalXQRcc801OH/+fMT7jzzySNhrNj8j5cknn8Tq1atRU1MT13r15gkAcn9Ukuvbr3VYTQwlg86eA5/Uw2CBWSwot6CgIOy10WiExWIJS/dyuVzo7e0V519DoVCESGAjJLvdrhuRQB6n3CfabxgtkDGd98a0i4Boo/fJkyeju7sbVVVV6O7uxqRJkyKW2bt3L9588008+eSTYrvZwsJCtLS0RF2v3mICcv0Gkevbn4sIgoBAIKBo0NmDFbpiNTGYAWc14ktKSsT3E+0vwbJ1ioqKZD9nzW3Yo6+vTxQJLDCLFwlerxdutxt2uz2ns34YuX5/ika2qvdRxcAxsjod0NTUhM2bN6O5uRmbN2/GjTfeGLHM73//e/H5pk2bcPDgwXEFAPBJF0GC0BNSN7ycUff7/fB6vQDGpuR4o56Xl4fCwsIwY6+G7nB8cxs5eE+C2+2G1+vFmTNn8NFHH4mNxOSmG7QiElKJWqPYtYAaj2tWr+7m5masWbMGGzduxLRp07B161YAwMGDB7FhwwY8/fTTCX+33jwBgHqVJpEcoVAo6vw632uCza/zbvi8vDzk5+eHGfZz587BaDRiypQp2d69lCAtHDMwMIBZs2aJr4PBYJgnYWBgQPQkBINBRZEQS4tcNd7YieiQJ+ATsioCKioqsGvXroj3ly5dKisA7rzzTtx5550xfbfeYgLoRpRd4r3AWXnqaPPrgUAAAMR5c96oW61WseUrM+x0DoTDHw+TyRS1uhxL8WIiYXBwEOfOnYPb7RZFAh+HwB5qvbHnEnryPKhxP7Pv50sT8XoCiOySy94Ytu1Krnf+NTsnWblSpaC5vLw86jeRQcZL8QqFQqLnwO12Y3h4GOfPn8fIyAjeeecdsZkN8x7k5+eLzy0WS0q2MVPngl6MMnkCxtCsCIjXqKj1B4oHLeyDmpBzw8u9drvdcDqdEUadBc7x79H8c25iNBplRcL+/fvFkuO8J4GJBLfbjUAgIFamk5tyiEUkaPna1pNrXo3iSrMiQG8xAWo8udQI3yUy2vw68EnKjtQVLw2cO3HiBGbMmIH8/Pws7x2RLYxGI/Lz8xXPgVAoJOZ7u91ujI6O4sKFC3C73fD7/WHlaxMRCUT85JrwSNf2kgggchqW5qZk1Nn7LM2N7xLJB82VlpaK7yea5kYQSsQiElhao9vthsPhENMg2TRSMBjEyZMnZUUCna/xQZ6AT9C0CMj10X085Lo3g9/+aNXm+PeZG1E6v86KbfDGntzwRLpIxY2dz06QY3BwEB0dHaiqqhKnn3iRwHe6k4qEvLy8uLZRL2WDM41a78+aFgF6mg5QO+NVm3O5XGJ3rniqzRGJQed87mE2m1FWVibbxEYQhDBPgsvlEtMgWQMbFqMiTYFkXe70hF6ERyxoVgTE0zuAiB9BEMLS3JRG7rFWm3O73ejv74/oBkkQakYtQoqPKVASCT6fT7ZWAhMJFotFbFbj9XoxODgoviaDmTxqFR6aFQEmk0lXnoBU7APvho/mjmfHlRWlSUW1ORYclavk+vlDaBs2XWC1WlFaWhrxObv2WdCiIAjo7u4Wqy8KghDhSeBTIpO5drNx7Wihc2Gq0KwIoMDAMVJZbY4Z+3S44XNZiKnxwibod4kHvnmN3W5Hd3c36uvrxc95kcAeQ0NDYSKBeRKkD6vVOu49Qw+/lVrvb5oVAVpuJSxXbW50dBRDQ0N47733qNocQWiQbF6jvEgoKSmJ+Jxl6fAiYWRkRCywBIx5Z+VEgp4Ga2q8z2paBOSKYY+1m1u0anOsc9qMGTOo2hyhe3Ll2o8Vte8PC+a1WCwRbXAZUk/ChQsX4PF4MDo6ikAggOHhYcX+Dan2PuqpQNF4aFYEZDs7INZqc3JueDZyLy4ujrna3OjoKFwuFxWsIYgMozWxnS4DqSQS+vr60N/fj5kzZ4aJhN7e3qjtovlHrmQKqfFc0bQISLVhT0e1uVSeFGpVmrGgxouDIIj0w+5bsbSL5vs39Pf3i4JBTiTwNROkAyjyBHyCpkXAeJ4A5oYPBAIYHR0V02Wkhl4uzY0PmmNpbtmsNqcFI6rWi4QglKBzNjXEcv8aTyREaxcdCoVgMBhEUeD1etHb24uCggJZkZAu1Hif1pwICAaD6O/vx8jICA4cOIDjx49jyZIlKC4uVqw25/F4YDAYxFE6VZsj4oWMAZFOMjlyVWs++3jE0y76/PnzGBoaEps8sXbRcl4Eu90ec6pzNKh3QJp55JFH8OKLL8JoNKKiogIdHR3weDyYPn06li5dirKyMsVqcx988AGqqqoUA1pyBTJEBEHkGpm6b/Htoi0WC+bMmRNmWFm7aD4Fku8EaTQaFTtBxioS1CiusioCBgYGcOutt6K9vR11dXXYunWrbLWrs2fP4u6770ZHRwcMBgO2b9+Ourq6sGUefPBBPPjgg+Lrf/mXf8H111+PFStWxLQtuW5A1XhyxUMuZXNIyfVjTyQH/f7Jo4YpVKV20QzWCVKuXTSbMpbzIrAmT2q9v2VVBLS0tODqq69Gc3MzWlpa0NLSgh/84AcRy91xxx148MEHce2118LhcMQUCUrFgggiu/Bpr16vN+I5nx1jMpnELnt2u118Hm/zG4JIF7G2i+brJPDtoj0eD1wuF4qKimQ9Cdk6z7MqArZt24bdu3cDANauXYuVK1dGiICTJ08iEAjg2muvBQDF+R4p2U4RzAZa2AdC3bDKcXJGnT3n2zZbrdawIlXMsFutVjE7xmKxiEFdLpcLLpcLw8PDcLlc8Hq9Yl18Xhyw59lODcvkNUcxAepmPJFw7NgxVFVVwWQyieWZmUhgWWVWqzWp6YZEyKoI6OnpQVVVFQCgsrISPT09Ect8+OGHKC0txec+9zm0tbXhmmuuQUtLy7jBenpsJUwQicJXoVQy8Mw4sKBZZuDtdjtKS0vDMmTiJVrktyAI4ijK5XJhcHAQXV1dcLvdCIVCMJvN4s2XCYRQKKSp619L+yJFL6KDiVml7AZpJ0hpu+hLLrkEeXl5Kd+utIuAa665BufPn494/5FHHgl7bTAYZE+EQCCAN998E0eOHMHUqVNx6623YtOmTbjrrruirlePnoBch36D1MJSYJkh5w360NAQAoEAurq6AIxdL9JROytWxUbt2Rp186ldFRUVEZ/7/X64XC7Rk9Df34/h4WEcOXJEjPiWTjOkowodQURjvPtbtE6QrA5COki7CNi5c6fiZ5MnT0Z3dzeqqqrQ3d2NSZMmRSxTU1ODRYsWYcaMGQCAm266Cfv27UupCNAKuWxE9TASSBWhUChipM4beFZimq9EyQw8M+4mkwlmsxm1tbU5f+wtFgtKSkrCatofOXIEc+fOhdVqDfMi9Pf3o6OjQywwwzwZ0mkGi8WSxT3KLpkemevFEwAkfp9L5709q9MBTU1N2Lx5M5qbm7F582bceOONEcs0NjZiaGgIvb29mDhxIv7+979j6dKl43633jwBermI1Eoq2jgHg0FZo84H0gGRRatYQyh+JD/eqMHlcgHQ7nnDfo9o87QsvoEJBKfTid7eXrhcLjElTMmLoNXjRqQPtdqYrIqA5uZmrFmzBhs3bsS0adOwdetWAMDBgwexYcMGPP300zCZTHjsscdw9dVXQxAELFmyBF/72tfG/W49egKI7BDNIPA9JJQMPDtPzWZzmCHny0xbrdasRhBrEb4zXmlpacTnfAU6l8slBnGxWvZWqxVutxtnzpwJ8ySkI4hLT6NlQh5NFguqqKjArl27It5funQpnn76afH1tddei2PHjsX13fG2EtYCalWasZJL28+nv7ndbvT09ODChQuy6W/8iD0vLw8FBQUoLy+nipQqJ1oFOkEQ4PP5sH//fuTl5WF0dBQ9PT1ipDdrmyv1IlitVtXfbzJ9HepF4Kh1PzVTMVBKvNkBuWSA5FDjyRUPatj+RNPfgsEgTCZTRCCdGvaJSA8GgwFWqxUmkwlTpkyJ+K2DwWBYsCIrKuP1egFATJeUxiOoRRDSuZse1HhcSQQQmifd6W/vv/8+JkyYoJj6Q+gPk8kUNeXR6/WG1UTo7u6Gy+USUx6l4oB5lojcRa2/n2ZFgMlk0l1gYK7vQzxI09/kDDwrwKHm9DdCf/CpYOXl5RGfBwKBMC/C4OAghoeH4fF40N/fD5vNJutFSNU5TNMB+kKzIiCemABCPcilv0mfs99VOmrnjXs22zoTRDKYzWYUFxeHNTS7cOEChoeHMXPmTLE0rcvlwsDAQFjhJIvFIisQaHoq+6hV7GhWBOgtRVDNREt/Y6/Ze4cPH45IfyssLERFRUXM6W/ZgM4f9ZGpG24mb+x8ymOshZNcLhf8fr9YdCmWwklqNFZaQI3HlUSARsiGkIk3/Y0ftUvT33w+H9ra2jB//vyM7gNBaAm5wkkMvlWuy+USS9LyhZPy8/PF2vYjIyOiFyGdqHWEnGrUOlDQrAiIN0VQrT9QNuDT3+QMvFz6GzPmiaa/sUI4uYgebmC5Bl3PkURrlcsXThoYGEAgEMCZM2dkCyfxngQqnJT7aFYE6M0TAES/8SXT/Y0VU6H0N4LIHum85nhBbzKZ4HA4sGDBAvHzWAonycUixFI4SS+CTa0eD02LgFhR4w8TKyz9zeVywefzobOzM670t5KSEvF1OttVjgd5YzIPHe/cIdu/VSyFk1jK48jICHp6euByucQaGrw4YAKBL5yUy/fgeFDjfmpaBMTjCcj2RcaTSPqb2WxGMBiE0Wik9DdiXEh0EamCFU6yWq0R3e+AselF3ovQ3d0dVjhJEASYzWYIgqDKwkmpQq3XG4kAZO6GGGv6W7Tub0rpb36/H8ePH8eUKVPSvh8EQWiXVN8LzWZz1MJJbW1t8Hq9MJvNGBoailo4iQmEvLw8VY6qcxESAUkSS/pbtO5vhYWFKC8vF419oqN2uiCyBx37+GHXJhsFMuhYKpPJY5PJ9EqLxQKz2YyampqIz1nhJJb2ODg4KE59sqJL0mDFVBZOSiUUE5BhjEYjfD5fTMvK/TDjpb/5fD4xkC5a+lteXh4F0sWIWt1lsZDL255KeOPOjgnzbjGkN0O/3y/etA0GQ9g8Mb+cnq8hvZ5fcoWTGKFQKOHCSdlCjeewpkWA3IXDj9qZYe/r60MoFML58+fTkv6WKXL5RqHGi4P4BN64s7/sPaXfjhlxk8kEg8EQZuiByOBdXjRE+z7p82jbQMRPoiPW4eFh/NM//RNef/112ToF0daXCLEWTmJeBL5wktPpxJEjR2RTHtPlRVDr/VkzImB0dBRtbW3o7u7G+fPn8be//Q1OpxPbt2/HypUrcfnllwMYi3KVjtpZpGp1dXXOjtpzcZuJ7KNk3KOdT8wAMzc+e61k3GMlWqR4PAKBX06tLlgtsn37dpw6dQp/+ctfcNttt8X1v+n4jaIVTnr77bcxZ84cUSAoFU6SehKymUGVLrK6RwMDA7j11lvR3t6Ouro6bN26VTa69D/+4z/wv//7vwiFQrj22mvxs5/9LOKkeeutt/D888+jsrISVVVVmDBhAqZOnYrbbrsNU6dOlXUnMUKhkDhfTxBagDeWvGueN6YsSttut4s3OovFIo7cU2XcUwHbBuYCZqWmvV5v2Gu23+xaDgQC5EHIEM8884z4N14RkGkMBkNMhZNcLhecTid6e3uTLpykVkGaVRHQ0tKCq6++Gs3NzWhpaUFLSwt+8IMfhC2zZ88evP322zh27BgA4FOf+hRef/11rFy5Mmy5z3zmM/jMZz4jvt64cSP6+vp0VYZWre6mWFDjxaFWYpl355Ez5NXV1aioqAhzlXZ0dMDn88FkMoVFY7NHOkUAa68rfTADz4JrWSEr/lFcXAyr1QqbzRYxRaelKQa1bc9LL72EN954Q3z91ltvAQDefPNNfOtb3xLfX7FiBW666SbF7xEEQVWBfPxUcGlpacTnrHASu3YuXLgAl8slpjzKeRHsdrv43WojqyJg27Zt2L17NwBg7dq1WLlyZYQIMBgM8Hg8YtEbv9+PyZMnj/vdakwRTCdqPLniJdd/g2RJxjXPz7vHOnJXKv4SDAbFURDfhCYYDMJsNsclEPiaF3Ijd6/XGxaDwxv3kpISTJ48OakqlamaYsi2QMjktRHriNXv9+Opp54Sa5YwvF4vnnzySQBjgX1XXHFFWrYzW4xXOMnr9YoigS+cNDIygv3798sGK/KFkzJNVkVAT08PqqqqAACVlZXo6emJWObyyy/HVVddhaqqKgiCgHXr1mHevHnjfrceywYT6iQV8+7jBdWlEpPJpJjXzbtJR0ZG0NXVFVYZjo3EmZfCaDTCbDaLI3U+wJYZ+2yNAhMRCEzU8Om//G+pBTEeK1/4whcwf/58fO5zn8P58+fhdrvFz+x2OyorK/HHP/5x3Pu1lsQ/S1u02WwRU9t79+7F4sWL4fV6RS8Cq4nAMtlY+WWpF0EqQlNJ2kXANddcg/Pnz0e8/8gjj4S9VtrJjz76CO+//z46OzsBANdeey3efPNNXHnllVHXq5QdIEc8zYbUjJYuplyAN+6BQACBQGDc34Cd42qcd2cwj5t0xM5G8eyGxapVsjbPrOpbMBiE3+8Xa8sHAgHxM6PRCIvFIgoCNRlNVsyL32/+ORvxMlFjtVpRV1eHUCgU9rsreRDUtK+pYt68edi7dy+qq6vD3vf5fNi3b1/MWQJaPDZSBEEQS7crFU7yeDyiQBgaGsK5c+fEYMVPfepTadmutIuAnTt3Kn42efJkdHd3o6qqCt3d3Zg0aVLEMn/605+wbNky0fXymc98Bnv37o1JBGjBsMdKrl9Eatt+uXl3JQNfVFSE06dPh0UVFxQUiH/VlE46nmueD6zjXfNFRUWYOHGimFUTz+/F39xcLhd6e3vhdDrFgi/SinAFBQUpz+Vm+61k4PkpCSZQbDYbKioqxGMgrdLJI51S5NMnUyUQMnWNxBvA9vbbbyM/P180Vuw3ffvtt7F69eo0bqm2YMeNxQ/wjOc5TIasTgc0NTVh8+bNaG5uxubNm3HjjTdGLDN16lT8+te/xn/+539CEAS8/vrr+OY3vznud8czulebAdIrmSrdzNaVaFCddN596tSpmDp1qjgf6HQ6xX7tZ8+ehc/nC8tpZgKB9W5P1X4xF7XcCF4psM5ut6O0tFR8nQ6xwt/cpPncrMc9Ewhs5MMKCEnFgfSYseY1Ssad329m3JnLtaysLKVTEkoxA6kQCGr28j3zzDNwOBxYvHgxfvrTn+Kb3/wmDh8+jN///vcxiQC1Rs2nAzXuZ1ZFQHNzM9asWYONGzdi2rRp2Lp1KwDg4MGD2LBhA55++mnccsst+Pvf/44FCxbAYDDg+uuvxz//8z+P+93xTAcAue9KV/uNIt1kopjNePDzgVJjxwfb8SlHwWBQNEq894C5ytlUQzTXvNwoljVzYSPaaKPYbBKtx73P58Pw8DBGRkbCIrCZ+91oNIqpvXa7HQUFBeJcLDsGaqn7EY9AkMuUGBwcRFlZGYLBoOqmGD766CN85zvfwXe+8x2YTCa88cYbePTRR/HnP/8525tGxEBWRUBFRQV27doV8f7SpUvx9NNPAxhT8L/61a/i/m69TQdoFTnjHsu8Ox9Up4Z5d7lgu2AwCI/HA6fTidHRUbHsqdfrRTAYDJtDZ6P2wsJCFBQUiG7qZPpNZAsWc8CP2nmRw8ccMFFTXFyMiRMniq+NRqMYYMWEVX9/f0ShFyasxsvhzhShUEjcXznvBfNKMUHH/tbU1KC4uFj2npbtGIQDBw6EvTaZTPjud7+L7373uxlZP5Ec2it/9A/iGRnrfRSdDaTFbILBIHw+H4aGhhQbgPBGXK1BdcAnLmol17w0sI49Jk2aFPbaaDTC7XaL0wvMg8BS9XjPAR9FnE14Iyfnnmf9NvjgQJYOyJ7HGnNgs9kiAs+kve0HBgbQ0dEBj8cj/o90iiFVHemkcQf8X+ax4X9ztv/8vsczHSM3xSAlEYGQafc83Xuzi2ZFAHkCskci8+4WiwUTJ05EZ2enGGDEbths9JuOgLF4UXLNKwXWSW/0NpstLhe1kquc1T93uVwYHBwUG6cAEAPteJGQ7HHj8/2VDDzwSadM3sAXFRWFBdelE4NBube9NECRTTHIBSiyY2exWGQ9F/xzJur4uAObzZZ2j020ugXJCIRsQKJjfDQZGJhOTCaTrooFZYJE8t3ZjS+WYjazZs0Sn7MbNjN0586dE5t/WCwW0TiyR7LpZmwEq1SxjqWHSQPM7Ha7OAedySwAi8WC0tLSiIpmrKyu9LgFAgGxEiAvDlgkspznQrrvZrM5bN9zbVpCLkCReQ7cbjdGRkbgcDgwNDQEj8cj1gAAPkkLZLEHLFsiXlGXKWIRCOwak/7eo6OjKCoqEr02aotBIFKLZkWAHj0BiV6gqapUx29DsgYhWroMGwWzeeCzZ8/C6/XCYDCIxo097Ha72DlSyT3P1se74tlILpb0MDXBR9QD4S5qt9uN0dFR9Pf3o6urCz6fT/ztWdYAb+QqKytVHVQ4Hrywk5uD5+ff2W/OVylk+y6toOh0OjE4OBhRQZGflsm2IJJmTfB/PR6PaOD5fWfnfFVVFex2u2L8gfRvsgIhG9kBuXg+pwvNioB4UwS14AmQ7kOiQXWAuovZsFFwUVFRxI3d6XSir68PXV1dCAQC4o2ejWJZcN3kyZPF+WA17FO8KMUdKNXaZyP4srIyVFVVhcUd8G5y5kFgIkHJe5DtugcsqFIpuJAZFt5zYbPZUFxcLL4X6z7EWkFxeHhYbMokVzMiVQGKvIGXGnc+7kJa84BVaWTiJpH1MjIlENKBFu71qUSzIkDrngC5efdAIICenh7k5+dHuMelBl2Nxp2h1EyG3eyYgeOjx/mRnLSZDD+1wB59fX0IBAJpmVpIFua5UOqWFy3uIJFa+9Hy+Nko2Ol0wuFwiPPooVBInBLgDV2yx06aEin9y8+/8/vO8v5ZRH2mzmeldrV8gKLT6ZQNUGSCih071vlQznvBnrPfXhpcWFFRIT5PV9xFMjEIUjGgpvuN3tG0CMjF7IBkitnMmjVLbFjh8XjCcrBZcF02I8iTbSbDbnLxzsHyRm7ChAlhnylNLTC3utTIJXPzijXAjEWQ8wInkRFsKlAaBTOhxmct8FUApS7ygoICGI3GCO8F/5fFHrCUSLa/yVQrzBZyAYp8WeLR0VGMjo5ieHh43PiD0tJSsQZCtj0wSsQiEFi8ivS3HxwcxOzZs0UPBn+NpeO31lNxoljQtAhQkycgE8VsqqqqxIZMwCejOIfDgeHhYbEaGz93zouDZAycdP5VOoKX1l1XSzMZpQA7fh6YHwGzrAXec8Cq2Mntv9RFqwUDB4QXRiovLw/7/VnsASvyw++/yWQS3dRaiT0Awg28nItemv9vs9lQWlqKysrKMM8VX0GRTc2cPXtWDOzkPQeprjqZDEwUsn2WGnq2/3z8AfPe1NXVwWq1ivdD/r4tnVqIJjaIxCARgOQ8AWouZqM0iguFQuJNZnR0FOfPn4fL5QIAWXHAz79KR/FKOe9WqxWFhYVhN7hcumjZsSssLER5eXmYgWPHrbe3VwyuEwRBNHB8cN2UKVMSnoNVC9LfX3qDZyMrXtwUFhZiwoQJYb8/84TwdQ8uXLiAs2fPhqXo8d4DNRw3pQDDaAaeCbx4vTe8927ixIlhnylVnQyFQmKAIi8QUhWgKBdkyD/k9p+Pv7DZbAltRzxTDPEIBPIEhJP9KyxNxFs2WIq0mM14TWSA3ClmYzQaUVhYCJvNhsLCwojAOhY9HgwGxQucFXdhefvl5eXiPGauXlDR6u3z7mmp94IfwfHzz2wO2OFwwOVy4fz58zhz5kzY1AJ/k872+SCX+y8tcAOEx16w4MpE6u4zQ5GXlxeRwy8dAQ8ODsLpdIZF4PPiIFHDIkVa3Ehq5OUETqIBhskSS4Ci0+mUDVCUeg9YgKJ0ikr6kAYZ8mWx2fN07X+qYhCyXQNB7WhaBCh5AqTz7qFQSMwPllPPcoY8Wr57tkl1MxlBEOB2u+FwOMK8B7xrnC/oowb3JB97IDeKlcYe8NHzfIBVPDcPZuCUphb4Y8cXRJIGJqZi9Mtu7koBduwc4HP/bTYbioqKMGHCBDHALlM3z2gjYKmBY9NawCcBdrxIYAF2ciV6+edSA88HWPLliXMBpQBFv98vxh4MDQ2hu7tbFLisgqE0c6a0tBR2u13VHqxYBQKrRCoVNwaDIaIPg9x36QF1/sIpwOl0orOzExcuXIgYdfAYjUaUlpbC6XSiq6tLdIuzC4I91JL7G08zGalxY8Y9kcA6Pvec3x6PxyOKg4GBAXH0JicOUmXcoo3e5QROMqPXVBAtuI7PWujq6oLT6UQgEAgbvUmzFqR976V/5XLAmQeDTxHLlRuenIFjngM+9sDtdsPn84k3d765UH5+PoqKinLSwCvBpmmkDz7IlBd5zIPFj+D54E5WZvn8+fPi9IzUg5Dtip08/P0wmhdDTuQVFBTE1YeBvdYihgxExWcl7P6tt97CI488Io7wJ0+ejHnz5qGhoQHz5s3DvHnzUFBQIPvDshuMw+EQDRwTB8ywsUeqGpPwBW3kRrDSwDLpI9OpUdHgW+qy48eMGwsGlCsFrFTUZ7zUOP65Gqu3xQM7Bg6HAyMjI+K55/P5wqoWWiwW8SbNzsN0p4hlCmmKpLTQD1+Dn/di8OcDH/fC/jLvC0sp5EWW2qa1+GMgNfBe71iBKz5NUvpI9jpg90B2/NiDrzwpfaTaA6h0DPipKiZy5B7xXge8LZSzi8kGKe7ZswdXXHFFXNvECIVCyVYkVdxAzYoAnlAohPPnz+P48eM4fvw43nvvPZw6dQoulwtTp07FvHnzUF9fj/nz52P27NmKF1AoFBINGhMIfCoeEwbSVrBs5Co3elUKrONvaLl+Y+dd006nUzRu0sAqadU6dhyzkRqXDqLlv7Mbu5xx4/8KgiAaNfZgxo0PrEul9yWVKBX5Yc8B+WPAXw/JpmkygcqLBJ/PF1ZtkR8Bp/q8k05TyAVa8seAf7BjkE3BEggEIjIYWICixWKJEAdyXlQ+m4AF3PLHhB0Dts92uz3seGRatKVCIJAIUCHBYBDt7e2iODhx4gRaW1sRCoUwc+ZM0WtQX1+P6dOnR/wA7KbO1x1nJ3MgEAhzSbIgPFZQhT3UNgKJF2nNfSXXtDQ1TurBYFHjvOfA7/eL3fJ4z4HajplccJXcFIU0wFB6LJItssOmZniRwE8t8IGJ6TAkvHta7lwAIoMM+efZ9mRJo+/Z82AwKOs9kDuGUuMmNfRyqXKpFDnZhl3HrA4CE/vSWidM8DORID0OuXQMlAQCq4vAzoMzZ85g+fLlCU0xkAjIMD6fDx9++CF2796Nv//972htbUVPTw9CoRAmTJgAr9eLpqYmfPaznw1LA5IaNuY54KcVfD6feFPmPQdqmmsDIgv7SA0bH38g571IlWtaThx4vV5ZcZAOw8ZXL5QzbnKtcaV/sz1F4fP5wjwH7BjyJYH5XgtyN2A5Ay/nxZAadvY82wY+GZg3z+FwiDEIzHvAp5sxbxaLQZE7Frl6DHgScdMzTx77XyawPJ6xCop8B0f2UJvY5+G9m3KPUCgU4c0pLCyMiE+LdYqBRECW2LdvH3bt2oXq6mpUVVWhvLwcw8PDOHPmDE6cOIETJ06gu7sbRUVFqK+vF70GDQ0NKC8vVzyB2Q2FFwhsvpyPN0hXpL20LK/UwCulxqkp/iAQCESIA4/HA5PJFFElUSluQ6rU5WIQpEGWUqGjNnd7PLCR78jIiOjJ4m9gbDrLaDSKIkdq2NTgnk4FiaTKsX3nA9T4uXNWklraXEjNxyobbnppx1D2kFafzGSAIvNwut1uRaHDXxNSb0Ys98bxphiAMVtx7tw5dHR0oLGxMaLiaRyQCEgXgiBgaGhIjDVg0wqDg4NiMGJ9fb0oEpSCEaXBdMy4BYNBMVOBN2xKJ5nS6F2a98yX5ZXe1HMpclxKMBgUU8lY7AGbZ2UFi5iRk/Z/lxq2XI9BACLjEPjnfB1+6f4DiBi1yU0tqHF6Rg4lA8+nS0q9OckEmQGf1I3g4w+kI19eJKTbsCUSTZ9tNz0L8JQ+kglQ5I+DnJFn4l/uGNjt9pR59gRBwMjICM6ePYuOjg6cPXsWnZ2d4l+32w2LxYIpU6agtrYW/+///T9Mnz490dWRCMg0oVAIPT09EcGITqcTtbW1ojBoaGjA7NmzFW+kTCWzXN/R0dGwKmHsf5hCl6bGSZ/nujtSrv4+L3aUDJvFYgmb4nC5XGEllPlpBTWkg46HtNCP9FhIj4Oc2InXePMV//gHC6qTpjRm6jjKpcpJhY60HoLUwGdSxDAPlDQ4kcXASAtLxXocMx1Nn21YgKLUgxAMBsXqnXytk0AgIDuKlz5SIf5Z/Zmenh7RyLPH2bNncf78eYRCIRQVFWHq1KmYOnUqpk2bJj6mTp2KwsLCVJ6XJALUAgtG5L0Gp06dgtfrxcSJE1FRUYGCggK43W780z/9ExYsWBCRGscHFLJiGG63WzRqvDs8lWmM6SZaD3QWbAlEBhlKjX08+8qnkknTQaUllDNV5U+ukx7/XC7QUGrgMh2HwPep4A0bgLBsD3YcYzU4UsMml02QzlS5TMO3JmbH0O12i3PCeXl54rHjM4/UFk2fLpS8GWxEz0/hKQkAm80W4T2I9x7JBmdS497R0YHOzk4MDg7CaDRi8uTJmDZtGmpra8OMfE1NTaZLqZMIUCsbN27E008/jaqqKuTn54sn8ejoKPr7+8VMBd5zUFVVpWiM+GBE9tftdotz5XJpjJlArjyrXA0AaewB783I5IiNz5PmxQFLxZOKg1hHD9KbmPRYKFXyS0boZBNWbZL3HPBz5mx/2PFjXp5cSJVLFbG66c1ms3icQqGQ2HmQj4NJVcfLbCGXPsmMvNSbIZ2Hj2UUz3e/5B/8NI3NZsOOHTtQW1uL4uJiOJ1O0bizvz6fD1arFbW1taKBr6urw9SpU1FXV4eysjK1HX8SAbkIywl///33xSmFEydO4Ny5cygsLBSFAXtUVFQo3hTZXDmLN3A4HGKUPS8MCgsLxbKrsaKU+83fzOXqr+diDQBpCWX2YEVo7Ha7OAoxGAxhng1+7lkpDz6XDHw0YkmVAyAeJ2YIWa8Adk4yo5YLUzRKpNtNz5el5l3j0r4B6UwPjZVoEfWs0iN/TfCGPlXeDHaudXd34+zZs+IcfEdHB4aHhxEMBtHT04NAIIBz584hEAjAbrejrq4OP/vZzzBr1izVB3jKQCJAS7BgRDalwMTBwMAAJk2aFBGMGG1uiU/Bk0tjZIEwJpMpYi6en3dWMvDZziJIFUq1ANhzv98vih3eqAFj7kdWNpiJrVybf+VJpKucVOxEE31MsEoLIgGRUwvZ7lWh5qI3/KiXjz+QRt1LW2InCl/OWhpwx6ZupGKHN/Kp+h0FQYDT6ZSdi+/s7ITD4YDJZBID7tgcPBvNV1ZWhvWGAQCPx4PTp09j3rx5uWb8GSQC9IAgCGHBiCdOnMDJkyfDghFZ6eSZM2eit7cXHR0dmDNnjqxbmilzFuQCQBQHrJZ7YWFhzozilZDm/EqPBR+LoOSiV5qqSLSEcraIlirHx2UwAy/nqk/X+RBtaoEv5pOqrIVcjKaPlWAwGBZUx/4Gg0FZ74HNZhM9fnIR9XKjeOmxSNUoXhAE9Pb2hkXTM0PPRu4FBQWoqakRDTxz1U+bNg0lJSW5asiTgUSAngmFQli3bh2OHTuGjo4OjI6Owmg0YuLEiSguLsaXv/xlTJo0SVTFbKSqVA2NjzdwOp0IhUKw2WxhNQ7UMicpbTgkHb2yyo7SfgT8zSsdsQhsu+TEAcsvl1ZJTAVyBl4aj5DqVLl0wx9L3qixgkhSz4HNNpbHrbdo+miwa5sJA1YQiZ0XfEtxXryWlpam1LPFfsvOzk50dnbizJkz6OrqEg19f38/DAYDJkyYoBhwp5UgyBRDIkDv7N27FxMmTEB1dbXYDdDv96O1tTXMc9DW1gaLxYI5c+aEBSNOmTJF0ajzJWvZg81J8ul3TByk6gKNlk3Aj9Tkiv2o+UYuJw58Pp+iOGDHM9dS5dIJ74FhhZBcLldYbAYfdFhYWIiioiJx1Ks1Q6Lk0XC73WEeDblgOzaKlzYVkgZ5SuseMLHFIwgChoeHw6LpeVe9x+NBXl4eqqurw1z1dXV1mDZtGiZOnKiKwUUOQiKAiA3mcpUGI3Z1dYnBiGxKYbxgRGk3RpapEEsaI2/g5VLDpBXclFz0WiEUCokdMfma7Mw9z/eF5/PLczVVLhqpcNMDCGuCwx6sTwA/T15YWKjq48fHJciJQFYoS2kuPhXXCR9b1Nvbi8HBQRw/fhy//vWvUVRUhNHRUbHY1IQJEzBz5kwxP5531SsVUyOShkQAkRxMwTNhwAcjTpgwISwYsb6+PmowYjAYxNDQEIaGhsKCEYFPamizYCo2MpNz0WsFaVqU9LlSqhx7bTKZxBx9uRLKvOcg3nzobJBNN710aoHvMqjUayHdx5PN38sdDyYCpecGM/KpDMxlHj+5uXgWWS/Nja+trYXZbIbf70d/fz9aW1tht9vx+OOPp2SbiJghEcAzMDCAW2+9Fe3t7airq8PWrVsjGjsAwNmzZ3H33Xejo6MDBoMB27dvR11dXeY3WMWwYESWqXDs2DEcO3YMw8PDKCoqQkVFBaxWKxwOB+644w7U1dVFNB3i0+PYCC/VaYzZIpGuctLnid7E+bRQXhywlrnSKomZEAfShkxK0fTsGKip6E0gEJBt4wwgItI+1qwFqceLN/ZKo3j+kcpA0lAohIGBgQhXfUdHB7q6uuDz+WCz2cJy49mjrq4OpaWl5KpXLyQCeP7jP/4D5eXlaG5uRktLCwYHB/GDH/wgYrmVK1fiwQcfxLXXXguHwyHePAll/u3f/g0fffQRampqUFBQgEAggEAggL6+Ppw+fRo+nw8zZswIm1aYMWNG1NGbNI3R4XDA7/cjLy8vTBgUFhZm1EMQLVWOTVkkkyqXLvjqfrwxS7aEspaj6aMhN1fOphZYPIrZbIbRaAzLRFEaxafjePC58WfOnBGNO8uPv3DhAgRBQHl5uexcfG1tbU54kQhFSATwXHTRRdi9ezeqqqrQ3d2NlStX4oMPPghb5uTJk/j617+Ot956K0tbqU38fj8++ugjHDt2TJxSOH36NCwWC2bPnh0WjFhdXR31Jsi6MfI1DgKBgBjoxbvC4zW2Sqly0rTBbKTKpYvxSiizUTnbL/7Y6C2aHogcxcvVS2D9PFhgXSAQEPt+SKdqkvHGSHPjpS57p9MJs9mMqqqqiFr1dXV1mDx5ckRuPKEpSATwlJaWYmhoCMDYxVNWVia+Zrz00kt4+umnkZeXh7a2NlxzzTVoaWnJuRt7LsCCEU+dOhUWjNjZ2YnCwkLMmzcvLBhxwoQJijcrPo2RH+lK0xhZ5LJc8GGupsolg9RNLzeKZ8WQBEEQvRx2ux1FRUUoLi4et8NlriGXbcEe7BzhvTx8sN14o3jWCpv3HPBTC0wYnD17FnPnzkVhYSEuXLgQ5qJnxr67u1vMja+trY1oRjNt2jQUFxeTgdc3+hMB11xzDc6fPx/x/iOPPIK1a9eGGf2ysjIMDg6GLffCCy/grrvuwpEjRzB16lTceuutWL16Ne666650bzrxD1gwIgtEZOKgv78fFRUVEcGIRUVFYt8FaQEgj8cjpoiFQiGx+BGbjy8oKEBxcTFKSkpQXFysGUMGpM9NH62EMu+NUUNlPyns/FAKuOMr/ckF3KUynZLPjT979izOnTuH4eFhuN1uvPTSSxgYGEBvby9sNhsqKysxffp0NDU1YdasWZg2bRqqq6s1l9JIpBz9iYBoxDIdsG/fPnz729/G66+/DgD43e9+h3379uGJJ54Y9/tjDTwEgJGREdTX1+Omm27C+vXrk985HSAIAi5cuIANGzZg//79OH36NHp6ehAKhVBSUoK8vDx885vfxJw5c1BZWSmO/OUCy8ZLY+SnFdQ6J6q2ojd83QheHIRCIVit1ghxkA6vCjsmckZebhTPG/lUxyYwMavUN57Pjedd9Ww+nnm+zp8/j/fffx+nTp3CN77xDU0JVSLtkAjgeeCBB1BRUSEGBg4MDOCHP/xh2DLBYBCLFy/Gzp07MXHiRHzlK1/B0qVLcd999437/bEGHgLA/fffj97eXpSXl5MIiJNnn30WFotFjFaeNGkSurq6wto0f/DBB/D7/Zg+fToaGhpE78HMmTOjGh++GyMzZiyyng9EZJkK6a7/rmTko3Xay3Y0vZRUlVCW8/Lwxl5pFJ+OmgmspPb58+cjmtGcPXtWFKfFxcVhFe743PhUFtAi0suOHTtw//33IxgM4u6770Zzc3PY516vF3fccQcOHTqEiooKPP/882rJKCMRwNPf3481a9bg7NmzmDZtGrZu3Yry8nIcPHgQGzZswNNPPw0AePXVV/Hv//7vEAQBS5YswVNPPRVTalosngYAOHToEH70ox/h+uuvx8GDB0kEpIlAICBWRuSDEU0mU0QwYk1NTUxzubxAkKYxMkM23rmi12h6KdISyg6HA6Ojo2JuPt9pkC9fKzcXz2I9UrltbrdbthENnxtfWVkZNopnkfVTpkzJdN94Ik0Eg0HMmTMHr776KmpqatDY2IjnnnsO9fX14jJPPvkkjh07hg0bNmDLli3405/+hOeffz6LWy1CIiCTxBJ4GAqF8OlPfxrPPPMMdu7cSSIgwzCXNR+M+N5776GzsxMFBQURwYgTJ06MeiOXS2P0+Xwwm81h/QdYpzU9RtMD8qN4aUS9wWAIG7Uz4+/z+eB2u+H3+8ctoRwrLDde6qpnufF+vx82mw01NTWyAXdlZWVk4HXC3r178fDDD+Ovf/0rAOD73/8+AOA///M/xWVWrVqFhx9+GJdffjkCgQAqKyvR29urhnNEcQO0d5fJENECD3lYBTwpTz75JFavXo2ampqEtyGW2IOjR4/i3nvvxcjICEwmEx588EHceuutCa9TK7DI9ksuuQSXXHKJ+L4gCBgZGRFFwV/+8hc89thj6OvrQ3l5uSgM5s6di5KSEvT09MDpdGLhwoURbnqz2Sy6tFlXRp/Ph1AoJEbVJ5PGqEZCoZCigWfChx/F22w2VFRURKQfjoe0TG17e7voOSgoKIDX60V7ezvmz58Ps9kcNgfP8uMvXLgAYCwwmB/BL1myBFOnTqXceCKMrq4u1NbWiq9ramrwzjvvKC5jNptRUlKC/v5+TJgwIaPbGg8kAhJk586dip9NnjwZ3d3d4nTApEmTIpbZu3cv3nzzTTz55JPiqLGwsBAtLS0xb0NLSwuuvvpqMfagpaUlIvYgPz8fv/3tbzF79mycO3cOS5YswapVq1BaWhrzevSEwWBASUkJli9fjuXLl4vvf/TRR/jP//xP7NmzB3/+85/h9XpRVFSE0tJSVFZWYsWKFaisrMTMmTMxf/78qPO80jRGlsfNxAEfc6CWboxA+PSFXMCddBRvs431MWBGPpVz8RaLBSUlJTCZTBgZGRHT586dO4fR0VEMDg7io48+wtDQEC5cuAC73Y7a2lpcdtll+NrXvoa6ujpMmjSJcuMJ3UMiIA00NTVh8+bNaG5uxubNm3HjjTdGLPP73/9efL5p0yYcPHgwLgEAANu2bcPu3bsBAGvXrsXKlSsjRMCcOXPE51OmTMGkSZPQ29tLIiBOKisr8fDDD6O2thbFxcXi+6FQCB0dHWIw4q5du3Dq1CkxGJF5DubNm4eZM2eKhpAZSX6EIE256+3tjejGyLwG6Qgm43sYSI18tFF8Ooojsb7xFy5ciIiml+bG83PxV155pTii53PjnU4nTp06Bbfbjcsvvzxl20noh+rqanR0dIivOzs7UV1dLbtMTU0NAoEAhoeHUVFRkelNjQuKCUgDsQYeMpgIiDcmIJbYA579+/dj7dq1OHHihGpGl1olEAjgo48+CgtG/Pjjj2E0GsOCEevr6zF16tSov0cq0hiVghCZsed7GMi1k011lgELBmSueamhHxgYgMFgwMSJE0Ujz3ecY41paBSfm4wXZb9p0yY88MADopFdt24d7r777mxsqkggEMCcOXOwa9cuVFdXo7GxEc8++ywaGhrEZZ544gkcP35cDAz84x//iK1bt2Zxq0UoMDBXSbboEYNlKWzevBnLli1L1+YSUWDBiB988AGOHz8upjF2dHQgPz8/Ihhx0qRJUY0c3wNgdHQUIyMj8Hg8ACB6HFhQHXtPrvBNOkocC4KAoaEh2WY0nZ2d8Hq9srnxLH2uoqKChKpGiSXKPtGBUbrZvn07vvnNbyIYDOKrX/0qHnzwQTz00ENYunQpmpqa4PF48OUvfxlHjhxBeXk5tmzZghkzZmR7swESAdok1lTEkZERrFy5Et/5zndwyy23xPz9OZwTm1MIgoDR0VGcOHEizHPQ29uLsrIyNDQ0oK6uDmVlZQgGg+ju7sZ1110Hs9ksphLynQhZamIwGBSr4vl8vrCIevZIpAsdKxvc09MT0YyG5cYLghCRG88eU6dOpdx4HRNLlL1aRUAOQ9kBWiSW2AOfz4ebb74Zd9xxR1wCIBgM4r777gtT601NTWFqfePGjSgrK8NHH32ELVu24Nvf/rZacmJzCoPBgOLiYlx++eVh89Vf+tKXcPz4cbz66qsQBAFWqxUlJSUwGAxoa2tDbW0t6urqUF9fj7lz544byc5H1Pf09ODjjz8O68ZoMpnQ0dGBiy++GDabTbZvfGdnJ0ZGRiJy42fMmIGrrroK06ZNo9x4IiqxRNkDwIsvvog33ngDc+bMweOPPx72P0TqIBGQwzQ3N2PNmjXYuHGjGHsAICz2YOvWrXjjjTfQ39+PTZs2ARhT2YsWLYr63fv378esWbNEV9Ztt92Gbdu2hYmAbdu24eGHHwYA3HLLLVi3bp3YZIZInscffxzl5eURrvpQKITOzk4xGHHDhg1iMGJdXV1YMOKsWbPE0b7FYkFpaSmKi4vR398Pl8uFnp4esVb90NAQ9uzZg8HBQfT09KC4uBi1tbVYsGABmpqaxDn50tJS+o2JtPLP//zP+OIXvwir1Ypf/epXWLt2Lf7+979ne7M0CU0HELK88MIL2LFjhxjE+Lvf/Q7vvPNOmHtu/vz52LFjh1jrYObMmXjnnXdUnROrZQKBAD7++OOwsskfffQRjEYj/H4/Jk6ciP7+fgBAeXl5xFw8c91brVYAYyO2EydOYHR0NC4vEkFEI5bpAJ5gMIjy8nIMDw9nbBs1CE0HEITWMZvNuOiii3DRRRfh85//PIBPovD/+te/orGxEZMnT1YsYCWlpqYmqWJWRHr46le/ildeeQWTJk3Ce++9F/G5IAi4//77sX37duTn52PTpk1YvHhxFrZUnsbGRrS2tqKtrQ3V1dXYsmULnn322bBlWJ0VAHj55Zcxb968bGyqLqDwW0KWeHJiASSdE7tjxw5cdNFFmDVrlmy9hJ/85Ceor6/HwoULcfXVV+PMmTMJrUdvsIDBpqYmVFVVUXEcDXDnnXdix44dip//5S9/QWtrK1pbW/HUU0/h3nvvzeDWjY/ZbMb69euxatUqzJs3D2vWrEFDQwMeeughvPzyywCAn//852hoaMDFF1+Mn//85+JUJpEGWFGOND6IHMTv9wvTp08XTp8+LXi9XmHhwoXCe++9F7bM+vXrhXvuuUcQBEF47rnnhC984QsJrSsQCAgzZswQPv74Y3FdJ06cCFvm73//u+B0OgVBEIQnn3xSWLNmTULrIggt0NbWJjQ0NMh+9vWvf1149tlnxddz5swRzp07l6lNI9SJoo0mTwAhSyxq/a677kJ/fz9mzZqFn/zkJ3FXPGTwQYh5eXliECLPVVddhfz8fADAsmXL0NnZmdwOEoRGkYu+7+rqyuIWEWqGYgIIRVavXo3Vq1eHvfe9731PfG6z2fCHP/wh6fXEmjLE2LhxIz7zmc8kvV6CIAi9QyJAJxQWFsLhcGR7M5LmmWeewcGDB/H6669ne1MIQpXEEs9DEAyaDiCyTqw3rZ07d+KRRx7Byy+/LKaxJcJ4QYiMF198EQaDAQcPHkx4XYS6+OpXv4pJkyZh/vz5sp/v3r0bJSUlWLRoERYtWhTm+coVmpqa8Nvf/haCIGDfvn0oKSkRI+0JIoJoAQMpehAqoKCgINuboEgsQYiHDx8WZsyYIXz44YdJrSuWIERBEISRkRHhyiuvFC677DLhwIEDSa2TUA+vv/66cOjQIcWgutdee0244YYbMrxV8XHbbbcJlZWVgtlsFqqrq4Wnn35a+OUvfyn88pe/FARBEEKhkPB//+//FWbMmCHMnz+fzl9CEKLYaJoOILIOH4TIGnOwIETWmOOBBx6Aw+HAF77wBQDA1KlTxQDFeIilEiIAfPe738W3v/1t/OhHP0p+BwnVsGLFCrS3t2d7M5Liueeei/q5wWDAE088kfL18lOKrJHOq6++imnTpqV8XUTmIBFAqILxghB37tyZkvXEEoR4+PBhdHR04IYbbiARoEP27t2Liy++GFOmTMFjjz0W1iqWAHbt2oV//dd/xV//+lcSABqARABBcIRCIXzrW9+i4iQ6ZfHixThz5gwKCwuxfft23HTTTWhtbc32ZqmGN954A1/72tewfft2zJw5M9ubQ6QACgwkdMV4QYijo6N47733sHLlStTV1WHfvn1oampKKjgwlkDErVu3or6+Hg0NDfg//+f/JLwuIjmKi4tRWFgIYMw75ff70dfXl+WtUgderxc33XQTXnrpJcydOzfbm0OkCBIBhK7g65b7fD5s2bIFTU1N4uclJSXo6+tDe3s72tvbsWzZMrz88stYunRpQutjLZn/8pe/4OTJk3juuedw8uTJsGVaW1vx/e9/H2+//TZOnDiBn/70p8nsYsrp6OjAVVddJYqUn/3sZxHLCIKAf/3Xf8WsWbOwcOFCHD58OAtbmjznz5+H8I+mavv370coFEq4FLbWsFgsuOKKK7Bx48ZsbwqRQkgE6AQt1AhIBbFUQkwlsVRD/PWvf4377rsPZWVlAIBJkyalfDuSwWw248c//jFOnjyJffv24YknnogQMmqvV8/44he/iMsvvxwffPABampqsHHjRmzYsAEbNmwAMNY9c/78+bj44ovxr//6r9iyZQv1WvgHRqMRW7duxf79+/Hoo49me3OIFEExAYTuGC8IkWf37t1JrSuWQMQPP/wQALB8+XIEg0E8/PDDuP7665NabyqpqqoS88yLioowb948dHV1hWVUbNu2DXfccQcMBgOWLVuGoaGhsE5wamG8yPp169Zh3bp1Gdqa3CM/Px//+7//iyuvvBKTJ0/GXXfdle1NIpKERABBZJlAIIDW1lbs3r0bnZ2dWLFiBY4fP47S0tJsb1oE7e3tOHLkCC677LKw95Xq1atNBBDJU15ejh07dmDFihWYOHFi2HQakXuQCCCINBJLNcSamhpcdtllsFgsmD59OubMmYPW1lY0NjZmenOj4nA48PnPfx4//elPUVxcnO3NITIMP6VYW1uLtra2LG4NkSooJoAg0sh4gYgAcNNNN4nTDn19ffjwww/FYkZqwe/34/Of/zxuv/12fO5zn4v4nOrVE0RuQiKAINJILIGIq1atQkVFBerr63HVVVfhRz/6kaoi0gVBwF133YV58+bhW9/6luwyVK+eIHITA0uHSSNpXwFBEOnjrbfewpVXXokFCxbAaBwbNzz66KM4e/YsAOAb3/gGBEHAunXrsGPHDuTn5+N//ud/Ek6rJAgi5SimuJAIIAiCIAhtoygCaDqAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp5AIIAiCIAidYs7AOgwZWAdBEARBEHFCngCCIAiC0CkkAgiCIAhCp5AIIAiCIAidQiKAIAiCIHQKiQCCIAiC0CkkAgiCIAhCp/z/cs31h/+mr/sAAAAASUVORK5CYII=\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": {
     "1bea4f233520406985a7f84f985d56d1": {
      "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
      }
     },
     "1ed7318937a2436e8e584652401f35eb": {
      "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
      }
     },
     "31c78cd763614c119b7c8cd7edc9c595": {
      "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_6d62a930155a4dfa9ef156facf5b90db",
       "placeholder": "​",
       "style": "IPY_MODEL_7f45a2ed26684c17a3230b9f896fec75",
       "value": "100%"
      }
     },
     "493adf287ea24e3e952e2cd406bbca4a": {
      "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_1ed7318937a2436e8e584652401f35eb",
       "placeholder": "​",
       "style": "IPY_MODEL_a18eeb0acf01486dbed20255fa74f59d",
       "value": " 4/4 [00:03&lt;00:00,  1.37it/s]"
      }
     },
     "4d29881331df448ca0e4e444180b23e1": {
      "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_dbc86d0c9cc4418bab7f9a30c9f84581",
       "max": 4.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_b6651f4ac89146da881d8befcb887996",
       "value": 4.0
      }
     },
     "6d62a930155a4dfa9ef156facf5b90db": {
      "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
      }
     },
     "7f45a2ed26684c17a3230b9f896fec75": {
      "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": ""
      }
     },
     "a18eeb0acf01486dbed20255fa74f59d": {
      "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": ""
      }
     },
     "b6651f4ac89146da881d8befcb887996": {
      "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": ""
      }
     },
     "d39b391f3fe547c4a6595d7ff844b6c4": {
      "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_31c78cd763614c119b7c8cd7edc9c595",
        "IPY_MODEL_4d29881331df448ca0e4e444180b23e1",
        "IPY_MODEL_493adf287ea24e3e952e2cd406bbca4a"
       ],
       "layout": "IPY_MODEL_1bea4f233520406985a7f84f985d56d1"
      }
     },
     "dbc86d0c9cc4418bab7f9a30c9f84581": {
      "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
}
