{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experiments: Utility-based Adaptive Teaching Strategies using Bayesian Theory of Mind\n",
    "## Utility of the Bayesian ToM-teachers\n",
    "\n",
    "In this notebook, we evaluate the utility over multiple trials of the ToM-teachers compared with baselines teachers."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pygame 2.4.0 (SDL 2.26.4, Python 3.11.3)\n",
      "Hello from the pygame community. https://www.pygame.org/contribute.html\n"
     ]
    }
   ],
   "source": [
    "from __future__ import annotations\n",
    "import warnings\n",
    "\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "\n",
    "from minigrid.core.actions import Actions\n",
    "from minigrid.core.constants import IDX_TO_COLOR, DIR_TO_VEC\n",
    "\n",
    "import numpy as np\n",
    "import pickle\n",
    "import csv\n",
    "from matplotlib import patches\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import trange, tqdm\n",
    "import progressbar\n",
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "\n",
    "from matplotlib.backends.backend_agg import FigureCanvasAgg\n",
    "import matplotlib.gridspec as gridspec\n",
    "from IPython.display import clear_output\n",
    "from PIL import Image\n",
    "\n",
    "from environment import MultiGoalsEnv, MultiRoomsGoalsEnv \n",
    "from learner import BayesianLearner\n",
    "from bayesian_ToM.bayesian_teacher import AlignedBayesianTeacher, BayesianTeacher\n",
    "from tools.utils import *\n",
    "from tools.utils_viz import *\n",
    "\n",
    "warnings.filterwarnings(\"ignore\", category=RuntimeWarning)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Parameters\n",
    "\n",
    "GRID_SIZE = 11\n",
    "GRID_SIZE_DEMO = 33\n",
    "\n",
    "num_colors = 4\n",
    "\n",
    "rf_values_basic = [3, 5]\n",
    "rf_values = np.array(rf_values_basic + [GRID_SIZE])\n",
    "rf_values_demo = np.array(rf_values_basic + [GRID_SIZE_DEMO])\n",
    "\n",
    "num_rf = len(rf_values)\n",
    "num_rf_demo = len(rf_values_demo)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Statistics on the utility of the teachers - Rationality Principle based / Aligned"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MultiGoalsEnv observation nvironment: \n",
      "       GRID_SIZE 11\n",
      "       (max_steps=121) \n",
      "\n",
      "MultiRoomsGoalsEnv demonstration environment: \n",
      "       GRID_SIZE 33\n",
      "       (max_steps=544) \n",
      "\n",
      "Teacher: \n",
      "       Boltzmann temperatire lambda=0.01\n"
     ]
    }
   ],
   "source": [
    "print(f'MultiGoalsEnv observation nvironment: \\n \\\n",
    "      GRID_SIZE {GRID_SIZE}\\n \\\n",
    "      (max_steps={GRID_SIZE ** 2}) \\n')\n",
    "\n",
    "print(f'MultiRoomsGoalsEnv demonstration environment: \\n \\\n",
    "      GRID_SIZE {GRID_SIZE_DEMO}\\n \\\n",
    "      (max_steps={GRID_SIZE_DEMO ** 2 // 2}) \\n')\n",
    "\n",
    "lambd = 0.01\n",
    "\n",
    "print(f'Teacher: \\n \\\n",
    "      Boltzmann temperatire lambda={lambd}')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Teaching cost"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = 0.8\n",
    "def cost_fun(x: int, l: int) -> float:\n",
    "    return alpha * (x / l)\n",
    "\n",
    "N = 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Maximal numer of observations of the learner accessible to the teacher"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "max_obs = GRID_SIZE ** 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Trials run"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [4:15:38<00:00, 153.39s/it] \n",
      "100%|██████████| 100/100 [4:17:49<00:00, 154.69s/it] \n",
      "100%|██████████| 100/100 [3:58:11<00:00, 142.92s/it] \n",
      "100%|██████████| 100/100 [4:01:17<00:00, 144.77s/it] \n",
      "100%|██████████| 100/100 [3:59:38<00:00, 143.79s/it] \n",
      "100%|██████████| 100/100 [4:16:58<00:00, 154.18s/it] \n",
      "100%|██████████| 100/100 [4:07:03<00:00, 148.24s/it] \n",
      "100%|██████████| 100/100 [4:28:48<00:00, 161.29s/it] \n",
      "100%|██████████| 100/100 [4:51:17<00:00, 174.77s/it] \n",
      "100%|██████████| 100/100 [4:35:54<00:00, 165.55s/it] \n",
      "100%|██████████| 100/100 [4:27:12<00:00, 160.32s/it] \n",
      "100%|██████████| 100/100 [4:19:01<00:00, 155.41s/it] \n"
     ]
    }
   ],
   "source": [
    "if max_obs == GRID_SIZE ** 2:\n",
    "    save_filename = f'./outputs/eval_utility/obs_{GRID_SIZE}_demo_{GRID_SIZE_DEMO}_norm_linear_{alpha}_N_{N}.pickle'\n",
    "else:\n",
    "    save_filename = f'./outputs/eval_utility/obs_{GRID_SIZE}_demo_{GRID_SIZE_DEMO}_norm_linear_{alpha}_N_{N}_max_obs_{max_obs}.pickle'\n",
    "\n",
    "DICT_UTIL = {}\n",
    "DICT_UTIL[lambd] = {}\n",
    "DICT_UTIL['omniscient'] = {}\n",
    "DICT_UTIL['aligned'] = {}\n",
    "DICT_UTIL['utility_opt_non_adaptive'] = {}\n",
    "DICT_UTIL['reward_opt_non_adaptive'] = {}\n",
    "DICT_UTIL['uniform_sampling'] = {}\n",
    "DICT_UTIL['uniform_model'] = {}\n",
    "\n",
    "for rf_idx, receptive_field in enumerate(rf_values):\n",
    "    for goal_color in range(num_colors):\n",
    "\n",
    "        DICT_UTIL[lambd][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['aligned'][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['omniscient'][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['utility_opt_non_adaptive'][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['reward_opt_non_adaptive'][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['uniform_sampling'][goal_color, receptive_field] = []\n",
    "        DICT_UTIL['uniform_model'][goal_color, receptive_field] = []\n",
    "\n",
    "        for _ in trange(N):\n",
    "            # print(f'Learner: rf={receptive_field} goal_color={IDX_TO_COLOR[goal_color+1]}')\n",
    "            # Test teacher utility\n",
    "            learner = BayesianLearner(goal_color=goal_color, receptive_field=receptive_field, grid_size=GRID_SIZE, env_type='MultiGoalsEnv')\n",
    "            teacher = BayesianTeacher(env=learner.env, lambd=lambd, rf_values=rf_values_basic)\n",
    "            aligned_teacher = AlignedBayesianTeacher(env=learner.env, rf_values=rf_values_basic)\n",
    "\n",
    "            # Teacher observes the learner during one full episode on the first simple env\n",
    "            ii = 0\n",
    "            learner_pos_list = []\n",
    "            learner_dir_list = []\n",
    "            learner_action_list = []\n",
    "            while not learner.terminated and ii < max_obs:\n",
    "                \n",
    "                agent_pos = learner.env.agent_pos\n",
    "                learner_pos_list.append(agent_pos)\n",
    "\n",
    "                agent_dir = learner.env.agent_dir\n",
    "                learner_dir_list.append(agent_dir)\n",
    "\n",
    "                teacher.update_knowledge(learner_pos=agent_pos, learner_dir=agent_dir, learner_step_count=ii)\n",
    "                aligned_teacher.update_knowledge(learner_pos=agent_pos, learner_dir=agent_dir, learner_step_count=ii)\n",
    "\n",
    "                traj = learner.play(size=1)\n",
    "                learner_action_list.append(traj[0])\n",
    "\n",
    "                teacher.observe(action=traj[0])\n",
    "                aligned_teacher.observe(action=traj[0])\n",
    "\n",
    "                ii += 1\n",
    "\n",
    "            # Teacher use ToM to predict the utility of each demo for this particular learner --> select the more relevant demo\n",
    "            learner = BayesianLearner(goal_color=goal_color, receptive_field=rf_values_demo[rf_idx], \\\n",
    "                                      grid_size=GRID_SIZE_DEMO, env_type='MultiRoomsGoalsEnv')\n",
    "            aligned_teacher.init_env(learner.env)\n",
    "            teacher.init_env(learner.env)\n",
    "            \n",
    "            # Compute all the demonstrations\n",
    "            all_demos = []\n",
    "            l_max = 0\n",
    "            # Random demos\n",
    "            for n_obj in range(3, 9):\n",
    "                demo = generate_random_demo(learner.env, n_obj=n_obj)\n",
    "                all_demos.append(demo)\n",
    "                l_max = np.max([len(demo), l_max])\n",
    "            # Learner-specific demos\n",
    "            for gc in range(num_colors):\n",
    "                 for rf in rf_values_demo[:-1]:\n",
    "                      demo = generate_demo(learner.env, rf, gc)\n",
    "                      all_demos.append(demo)\n",
    "                      l_max = np.max([len(demo), l_max])\n",
    "            all_demos.append([]) # Full obs\n",
    "\n",
    "            ## Rationality principle teacher\n",
    "            selected_demo, demo_idx, predicted_best_utility, demos = teacher.select_demo(l_max, cost_fun, all_demos)\n",
    "\n",
    "            # Learner \"observes\" the demo\n",
    "            learner.observe(selected_demo)\n",
    "\n",
    "            # Reset step count in the env\n",
    "            learner.env.step_count = 0\n",
    "            # Learner play after seen the demo\n",
    "            _ = learner.play()\n",
    "\n",
    "            utility = learner.reward - cost_fun(len(selected_demo), l_max)\n",
    "\n",
    "            DICT_UTIL[lambd][goal_color, receptive_field].append(utility)\n",
    "        \n",
    "            ## Utility map        \n",
    "            true_utility = np.zeros((num_colors, len(rf_values_demo), len(all_demos)))\n",
    "            true_reward = np.zeros((num_colors, len(rf_values_demo), len(all_demos)))\n",
    "\n",
    "            for gc in range(num_colors):\n",
    "                 for ii, rf in enumerate(rf_values_demo):\n",
    "                    for jj, demo in enumerate(all_demos):\n",
    "                        reward = aligned_teacher.predicted_reward(demo, gc, ii)\n",
    "\n",
    "                        true_reward[gc, ii, jj] = reward\n",
    "                        true_utility[gc, ii, jj] = reward - cost_fun(len(demo), l_max)\n",
    "\n",
    "            ## Aligned teacher\n",
    "            weighted_utility = true_utility.copy()\n",
    "            for gc in range(num_colors):\n",
    "                for ii in range(num_rf_demo):\n",
    "                    weighted_utility[gc, ii, :] *= aligned_teacher.beliefs[gc, ii]\n",
    "            selected_demo_idx = np.argmax(weighted_utility.sum(axis=0).sum(axis=0))\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['aligned'][goal_color, receptive_field].append(utility)\n",
    "\n",
    "            ## Omnicient teacher\n",
    "            selected_demo_idx = np.argmax(true_utility[goal_color, rf_idx, :])\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['omniscient'][goal_color, receptive_field].append(utility)\n",
    "            \n",
    "            ## Utility optimal non-adaptive but goal omniscient\n",
    "            mean_util_per_demo = true_utility.mean(axis=0).mean(axis=0)\n",
    "            selected_demo_idx = np.argmax(mean_util_per_demo)\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['utility_opt_non_adaptive'][goal_color, receptive_field].append(utility)\n",
    "\n",
    "            ## Reward optimal non-adaptive but goal omniscient\n",
    "            mean_reward_per_demo = true_reward.mean(axis=0).mean(axis=0)\n",
    "            selected_demo_idx = np.argmax(mean_reward_per_demo)\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['reward_opt_non_adaptive'][goal_color, receptive_field].append(utility)\n",
    "\n",
    "            ## Uniform sample\n",
    "            selected_demo_idx = np.random.randint(0, len(all_demos))\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['uniform_sampling'][goal_color, receptive_field].append(utility)\n",
    "\n",
    "            ## Uniform model\n",
    "            pred_goal = np.random.randint(0, num_colors)\n",
    "            pred_rf_idx = np.random.randint(0, len(rf_values))\n",
    "            pred_rf = rf_values_demo[pred_rf_idx]\n",
    "\n",
    "            selected_demo_idx = np.argmax(true_utility[pred_goal, pred_rf_idx, :])\n",
    "\n",
    "            utility = true_utility[goal_color, rf_idx, selected_demo_idx]\n",
    "            DICT_UTIL['uniform_model'][goal_color, receptive_field].append(utility)\n",
    "\n",
    "with open(save_filename, 'wb') as f:\n",
    "        pickle.dump(DICT_UTIL, f)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Display results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Parameters\n",
    "\n",
    "GRID_SIZE = 11\n",
    "GRID_SIZE_DEMO = 33\n",
    "\n",
    "num_colors = 4\n",
    "\n",
    "rf_values_basic = [3, 5]\n",
    "rf_values = np.array(rf_values_basic + [GRID_SIZE])\n",
    "rf_values_demo = np.array(rf_values_basic + [GRID_SIZE_DEMO])\n",
    "\n",
    "num_rf = len(rf_values)\n",
    "num_rf_demo = len(rf_values_demo)\n",
    "\n",
    "lambd = 0.01\n",
    "\n",
    "alpha = 0.6\n",
    "\n",
    "N = 100\n",
    "\n",
    "max_obs = 10 #GRID_SIZE ** 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "if max_obs == GRID_SIZE ** 2:\n",
    "    load_filename = f'../outputs/eval_utility/obs_{GRID_SIZE}_demo_{GRID_SIZE_DEMO}_norm_linear_{alpha}_{N}.pickle'\n",
    "else:\n",
    "    load_filename = f'../outputs/eval_utility/obs_{GRID_SIZE}_demo_{GRID_SIZE_DEMO}_norm_linear_{alpha}_{N}_{max_obs}.pickle'\n",
    "\n",
    "with open(load_filename, 'rb') as f:    \n",
    "    DICT_UTIL = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "p-value =  0.634597696259694\n",
      "p-value =  0.1606428368704078\n",
      "p-value =  5.301509108229924e-10\n"
     ]
    },
    {
     "data": {
      "image/png": "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/aRJkybds27jxo21fv16nT592jrCJykpSStXrsxwv4AjIXEDAAAAADnQ5s2bdfLkSU2ZMkUhISGpzgcHB+v999/XggUL0pW4yZUrlyIiIjR48GB17txZ/fr108WLFxUREaGAgADlyvVgK3XMmzdPrVu3VsuWLRUWFqbChQvr/PnzOnTokH744Qfr7levvfaa1q9fryZNmmj8+PHy8PDQrFmzZLFYHqhfwFGwxg0AAAAAPCjTQY4HsGDBArm6uqpv375pns+fP786duyojRs3pjn9KS2DBg3SBx98oJ9++kkdO3ZURESEXn31VVWpUkV58uR5oDgbN26s7777Tnny5NHw4cPVrFkzPffcc9q2bZuaNWtmrRccHKxt27bJx8dHffr0sW5L/vrrrz9Qv4CjMEzTzHH7OMbHx8vX11eXLl2Sj4+PvcMBAAC4J8MwsqWfbNveO8f97ROOLD3fDRISEnT06FEFBQXJ3d09myN89F28eFFlypTRk08+qQ8++MDe4QAOI72fLUyVAgAAAABkitjYWL311ltq3Lix/Pz8dOzYMf3nP//R5cuX9eKLL9o7POCRROIGAAAAAJAp3NzcFBMToyFDhuj8+fPy8PBQ7dq1NXfuXD3++OP2Dg94JJG4AQAAAABkirx582rDhg32DgP4V2FxYgAAAAAAAAdF4gYAAAAAAMBBkbgBAAAAAABwUCRuAAAAAAAAHJRDJG5mz55t3be8WrVq+vrrr+9Zf9myZXriiSfk4eGhgIAA9e3bV3FxcdkULQAAAAAAQPawe+Jm5cqVGj58uMaNG6cDBw6oQYMGat26tY4fP55m/W+++Ua9e/dW//799euvv2r16tXat2+fBgwYkM2RAwAAAAAAZC27J26mT5+u/v37a8CAASpfvrxmzJihokWLas6cOWnW37t3r0qUKKFhw4YpKChI9evX1+DBg7V///5sjhwAAAAAACBr2TVxc+PGDX3//fdq0aKFTXmLFi20Z8+eNK+pW7eu/vnnH23atEmmaer06dP65JNP1LZt27v2c/36dcXHx9scAAAAAAAAjs7Znp2fO3dOSUlJKlSokE15oUKFFBsbm+Y1devW1bJly9S1a1clJCQoMTFR7du313//+9+79jN58mRFRERkauwAAAD497BYLPLy8pIkXblyRZ6ennaOCI+MAa3sHcEt87fYOwIAWcTuU6UkyTAMm9emaaYqS/Hbb79p2LBhGj9+vL7//ntt2bJFR48e1bPPPnvX9seMGaNLly5Zj7///jtT4wcAAACAR1VkZKQMw7Aezs7OCggIULdu3fTnn38+UJt79uxReHi4Ll68eNf+YmJiHi7wTJDRWCZOnKgKFSooOTnZpjwhIUHOzs7y9vbWCy+8kAWRpu3KlSsaPny4AgMD5e7ursqVK+vjjz/O9OsvX76sUaNGqUWLFipQoIAMw1B4eHiqegsWLFDhwoVlsVge5rZwB7smbvLnzy8nJ6dUo2vOnDmTahROismTJ6tevXp65ZVXVKlSJbVs2VKzZ8/WwoULderUqTSvcXNzk4+Pj80BAAAAAPg/ixYtUnR0tLZt26ahQ4dq/fr1ql+/vi5cuJDhtvbs2aOIiIg0Ezdt27ZVdHS0AgICMiHq7HPy5ElNnTpVEydOVK5ctl+lDcNQVFSUatasqffff19//PFHtsTUqVMnLV68WBMmTNDmzZtVo0YNde/eXcuXL8/U6+Pi4vTBBx/o+vXrevLJJ+/aXp8+feTp6ampU6c+zG3hDnZN3Li6uqpatWraunWrTfnWrVtVt27dNK+5evVqql8SJycnSbdG6gAAAAAAMi44OFi1a9dWSEiIxo0bp1dffVVnzpzR2rVrM7WfAgUKqHbt2nJzc8vUdrPazJkzlSdPHnXq1CnVOTc3NzVs2FCjRo2SJH3//fdZHs+mTZu0detWzZ49W4MHD1bjxo314Ycfqnnz5nrllVeUlJSUadcXL15cFy5c0K5duzR58uS7tuns7KzBgwdr5syZunr1aqbda05n96lSI0aM0Pz587Vw4UIdOnRIL730ko4fP26d+jRmzBj17t3bWr9du3Zas2aN5syZo7/++ku7d+/WsGHDVLNmTQUGBtrrNgAAAADgX6V69eqSpNOnT1vLjhw5or59+6p06dLy8PBQ4cKF1a5dO/3yyy/WOuHh4XrllVckSUFBQdYpWDt37pSU9vSkb775Rk2bNpW3t7c8PDxUt25dff7556liCg8Pl2EY+vXXX9W9e3f5+vqqUKFC6tevny5dupShODPixo0bWrBggXr06JFqIMHtypUrJ0n68ccfH6ifjPjss8/k5eWlp59+2qa8b9++OnnypL799ttMuz7lPUyPnj17Kj4+PkNTtnBvdk/cdO3aVTNmzNDEiRNVuXJlffXVV9q0aZOKFy8uSTp16pSOHz9urR8WFqbp06fr/fffV3BwsJ5++mmVLVtWa9assdctAAAAwAEZGTi8brvOK4PXAv9WR48elSSVKVPGWnby5En5+fnp7bff1pYtWzRr1iw5OzurVq1aOnz4sCRpwIAB1nVe1qxZo+joaEVHR6tq1app9rNr1y41adJEly5d0oIFC7RixQp5e3urXbt2WrlyZZrXPPXUUypTpow+/fRTvfrqq1q+fLleeumlDMWZEd9++63i4uLUuHHje9abMmWKpPsnbkzTVGJiYrqOuzl48KDKly8vZ2fbPYcqVapkPX8vD3v93fj7+6tcuXJpJt7wYOy6q1SKIUOGaMiQIWmei4yMTFX2wgsvZOuCTwAAAADwb5eUlKTExEQlJCRo9+7devPNN9WwYUO1b9/eWqdhw4Zq2LChzTVt27bV448/rnnz5mn69OkqUqSIihUrJkmqUqWKSpQocc9+X331VeXNm1c7d+607u4WGhqqypUra+TIkerSpUuq0R79+/e3jupp1qyZjhw5ooULF2rBggUyDCNdcWZEdHS0JN01+SRJX375pebMmaO8efPqwIED92xv165d900CpTh69GiazzAuLk4lS5ZMVZ4vXz7r+Xt52OvvpWrVqtq2bdsDXw9bDpG4AQAAAADYV+3atW1ely9fXuvWrbMZkZGYmKipU6dq6dKlOnLkiG7evGk9d+jQoQz3abFY9O233+q5556zJm2kW+uY9urVS6NHj9bhw4etU5BS3J5Mkm6NEklISLBudJPZcZ48eVKGYSh//vxpnr948aL69eunDh06KDg4WG+99ZZOnjx51+U8qlWrpn379qWr73stCXKv6Uvpmdr0sNffTcGCBXXmzBklJiamGtGDjOMJAgAAAAC0ZMkSlS9fXpcvX9bKlSs1b948de/eXZs3b7bWGTFihGbNmqXRo0erUaNGyps3r3LlyqUBAwbo2rVrGe7zwoULMk0zzR2mUhIWaY388PPzs3mdstBxSgyZHee1a9fk4uJi3RjnTs8//7xu3rypDz/8UF999ZWkW9Ol7pZ08fLyUuXKldPV990SH35+fmk+m/Pnz0v6v5Ezd/Ow19+Lu7u7TNNUQkKCTUIOD4bEDQAAAODpKbFDKXK48uXLWxckbty4sZKSkjR//nx98skn6ty5syRp6dKl6t27tyZNmmRz7blz55QnT54M95mSUDl16lSqcydPnpSku45yuZfMjjN//vy6ceOGLBaLPD09bc598sknWr58uTZs2KACBQpYp1P9+OOPatOmTZrtZcZUqYoVK2rFihWpRrWkLMAcHBx8z3Yf9vp7OX/+vNzc3EjaZBK7L04MAAAA4NFksVisu81YLBZ7h4NMNnXqVOXNm1fjx49XcnKypFvTZ+7cxvvzzz/XiRMnbMruHAFzN56enqpVq5bWrFljUzc5OVlLly5VkSJFbBZHTq/0xpleKVO1/ve//9mUx8bG6tlnn9WgQYMUGhoq6dZOWnny5LnnOjcpU6XSc9xt1E7Hjh115coVffrppzblixcvVmBgoGrVqnXPe3rY6+/lr7/+UoUKFR74ethixA0AAAAAIJW8efNqzJgxGjVqlJYvX65nnnlGoaGhioyMVLly5VSpUiV9//33mjZtmooUKWJzbcWKFSVJM2fOVJ8+feTi4qKyZcvK29s7VT+TJ09W8+bN1bhxY40cOVKurq6aPXu2Dh48qBUrVjzQWivpjTO9QkJCJEl79+617rokSQMHDlTevHlTLXZcpUqVe+4s5e3tbR3d9KBat26t5s2b67nnnlN8fLwee+wxrVixQlu2bNHSpUttpnXt2rVLTZs21fjx4zV+/PgMXy9JmzdvlsVi0eXLlyVJv/32mz755BNJUps2beTh4SHpVtLtu+++U//+/R/q/vB/SNwAAAAAwIOav8XeEWSpF154Qe+//74mTpyo7t27a+bMmXJxcdHkyZN15coVVa1aVWvWrNFrr71mc11ISIjGjBmjxYsX68MPP1RycrJ27NhhTYDcrlGjRoqKitKECRMUFham5ORkPfHEE1q/fr11FEtGpTfO9CpatKgaNGigdevWadCgQZKk+fPna/Pmzfrmm29STZ+qUqWKdu7cqcuXL6eZrMosa9as0bhx4zR+/HidP39e5cqV04oVK9StWzebeqZpKikpyTpyKqPXS9Jzzz2nY8eOWV+vXr1aq1evlmQ7nWvnzp26dOmSevbsmcl3m3MZppnzJvPGx8fL19dXly5dko+Pj73DAQAAuKeH2dkjI0xl018Ls6mb7Hlq2XY7DslisVjXsLhy5UqqL6+PgvR8N0hISNDRo0cVFBQkd3f3bI4QjuLTTz9V165ddezYMRUuXNje4TisXr166a+/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FcvOnTtlGIZWrFihcePGKTAwUD4+PmrWrJkOHz6cqv7ChQv1xBNPyN3dXfny5VPHjh116NAhmzphYWHy8vLSkSNH1KZNG3l5ealo0aJ6+eWXdf369Qw9q/S+d5L0+eefq3LlynJzc1NQUJDeeeedNNucNWuWGjZsqIIFC8rT01MVK1bU1KlTdfPmTZt6ISEhCg4O1tdff63atWsrd+7cKly4sF5//XUlJSVJkmJiYqyJmYiICOvzT5k+d+dUqeHDh8vT01Px8fGp4uratasKFSpkE8fKlStVp04deXp6ysvLSy1bttSBAwcy9AzvhcQNAAAAACCVo0ePSpLKlCkjSdqxY4fq1aunixcvau7cuVq3bp0qV66srl27KjIyUpLk4+OjGjVqaNu2bdZ2tm/fLjc3N12+fNkmibJt2zY1adLEurbJ//73P9WpU0dz5szRl19+qfHjx+vbb79V/fr1U31Zl6ROnTrpscce0+rVqzV37lxJ0sCBA/XOO++od+/eWrdunZ566il16tRJFy5cyNC9m6apJ598Uu+884569eqlzz//XCNGjNDixYvVpEmTVImNH3/8UcOHD9dLL72kzz77THXr1tWLL75oTUpUrVpVixYtkiS99tprio6OVnR0tAYMGJChuMaOHatjx45p/vz5+uCDD/Tnn3+qXbt21gSFJE2ePFn9+/fX448/rjVr1mjmzJn6+eefVadOnVRrFt28eVPt27dX06ZNtW7dOvXr10//+c9/NGXKlAzFld73bvv27erQoYO8vb318ccfa9q0aVq1apX12dzZZo8ePfTRRx9p48aN6t+/v6ZNm6bBgwenqhsbG6tu3bqpZ8+eWrdunTp37qw333xTL774oiQpICBAW7ZskST179/f+vxff/31NO+nX79+unr1qk1SUpIuXryodevW6ZlnnpGLi4skadKkSerevbsqVKigVatW6aOPPtLly5fVoEED/fbbbxl6jndl5kCXLl0yJZmXLl2ydygP5MqVK6YkU5J55coVe4cDIAuk/I5n9QHg0ZBtnwkys+fIgIf5e48D3s4j4ZdffsmWw1Gk57vBtWvXzN9++828du1aqnOSYxwPY9GiRaYkc+/evebNmzfNy5cvm1u2bDH9/f3Nhg0bmjdv3jRN0zTLlStnVqlSxfo6RWhoqBkQEGAmJSWZpmmar732mpk7d24zISHBNE3THDBggNmqVSuzUqVKZkREhGmapnnixAlTkvnBBx+kGVNycrJ58+ZN89ixY6Ykc926ddZzEyZMMCWZ48ePt7nm0KFDpiTzpZdesilftmyZKcns06dPup/Jli1bTEnm1KlTbcpXrlyZKu7ixYubhmGYP/74o03d5s2bmz4+PqbFYjFN0zT37dtnSjIXLVqU7jhS7Nixw5RktmnTxqZ81apVpiQzOjraNE3TvHDhgpk7d+5U9Y4fP266ubmZPXr0sJb16dPHlGSuWrXKpm6bNm3MsmXLZjjGFPd672rVqmUGBgba/C7Fx8eb+fLlu+ffTZOSksybN2+aS5YsMZ2cnMzz589bzzVq1ChVP6ZpmgMHDjRz5cplHjt2zDRN0zx79qwpyZwwYUKq9lN+B44ePWotq1q1qlm3bl2berNnzzYlWT/Djh8/bjo7O5svvPCCTb3Lly+b/v7+ZpcuXe56T6Z578+W2zHixkHcvor7/Y6U9W0kycvLK0PXAgAAAEBaateuLRcXF3l7e6tVq1bKmzev1q1bJ2dnZx05ckS///67evbsKUlKTEy0Hm3atNGpU6esU3aaNm2qa9euac+ePZJujaxp3ry5mjVrpq1bt1rLJKlZs2bW/s+cOaNnn31WRYsWlbOzs1xcXFS8eHFJSjXNR5Keeuopm9c7duyQJGuMKbp06SJn54wt7xoVFSVJqXaievrpp+Xp6ant27fblD/++ON64oknbMp69Oih+Ph4/fDDDxnq+17at29v87pSpUqSpGPHjkmSoqOjde3atVRxFy1aVE2aNEkVt2EYateuXao2U9pLr/S8dxaLRfv27VOnTp3k7u5uvdbb2ztVDJJ04MABtW/fXn5+fnJycpKLi4t69+6tpKQk/fHHHzZ1vb29Uz2bHj16KDk5WV999VWG7iVF3759tWfPHpupaIsWLVKNGjUUHBwsSfriiy+UmJio3r172/xOuLu7q1GjRmnuYPUgSNwAANLFYrFYk8AWi8Xe4QAAgEy2ZMkS7du3T1FRURo8eLAOHTqk7t27S/q/dW5GjhwpFxcXm2PIkCGSZF3PpG7duvLw8NC2bdt05MgRxcTEWBM33377ra5cuaJt27apZMmSCgoKkiQlJyerRYsWWrNmjUaNGqXt27fru+++0969eyVJ165dSxXvnTsAxcXFSZL8/f1typ2dneXn55ehZxEXFydnZ+dUC9YahiF/f39rXynu7PP2sjvrPow778PNzU3S/z2flL7S2h0pMDAwVSweHh42SZSUNhMSEtIdU3rfuwsXLig5OfmezyrF8ePH1aBBA504cUIzZ87U119/rX379mnWrFk2baYoVKjQXdt80Offs2dPubm5WacB/vbbb9q3b5/NQt0pvxc1atRI9XuxcuXKNNf4eRDsKgUAAAAAUPny5a0LEjdu3FhJSUmaP3++PvnkE1WsWFGSNGbMGHXq1CnN68uWLStJcnV1Vf369bVt2zYVKVJE/v7+qlixokqWLCnp1kK727dvV2hoqPXagwcP6qefflJkZKT69OljLT9y5Mhd471zRkFKUiM2NlaFCxe2licmJmb4y7ufn58SExN19uxZm+SNaZqKjY21LjScIjY2NlUbKWUZTRo9jJS+Tp06lercyZMnlT9//kzvM73vXd68eWUYxj2fVYq1a9fKYrFozZo11pE70q21hNJy+wLad7b5oM8/b9686tChg5YsWaI333xTixYtkru7uzWZKcn6PD/55BObODMbiRsAAABkrwGt0l/35v/tQKMhHSSXDPz1df6W9NcFkMrUqVP16aefavz48Tp48KBKly6tn376SZMmTbrvtc2aNdOYMWPk7e1tnQ7l6emp2rVr67///a9OnjxpM00qJQmTMoIkxbx589Idb0hIiCRp2bJlqlatmrV81apVNrtZpUfTpk01depULV26VC+99JK1/NNPP5XFYlHTpk1t6v/666/66aefbKZLLV++XN7e3qpataqk1KNjskKdOnWUO3duLV26VE8//bS1/J9//lFUVJQ6d+6c6X2m973z9PRUzZo1tWbNGk2bNs060ufy5cvasGHDfds0TVMffvhhmjFcvnxZ69evt5kutXz5cuXKlUsNGza0aSsjz79v375atWqVNm3apKVLl6pjx47KkyeP9XzLli3l7Oys//3vf6mm7mUmEjcAAAAAgFTy5s2rMWPGaNSoUVq+fLnmzZun1q1bq2XLlgoLC1PhwoV1/vx5HTp0SD/88INWr15tvbZp06ZKSkrS9u3btXjxYmt5s2bNNGHCBBmGoSZNmljLy5Urp1KlSunVV1+VaZrKly+fNmzYYF0TJz3Kly+vZ555RjNmzJCLi4uaNWumgwcP6p133pGPj0+G7r158+Zq2bKlRo8erfj4eNWrV08///yzJkyYoCpVqqhXr1429QMDA9W+fXuFh4crICBAS5cu1datWzVlyhR5eHhIkkqVKqXcuXNr2bJlKl++vLy8vBQYGKjAwMAMxXYvefLk0euvv66xY8eqd+/e6t69u+Li4hQRESF3d3dNmDAh0/pKkZH37o033lCrVq3UvHlzvfzyy0pKStKUKVPk6emp8+fPW+s1b95crq6u6t69u0aNGqWEhATNmTPnrruD+fn56bnnntPx48dVpkwZbdq0SR9++KGee+45FStWTNKtdXCKFy+udevWqWnTpsqXL5/y58+vEiVK3PXeWrRooSJFimjIkCGKjY21mSYl3doKfuLEiRo3bpz++usv69pQp0+f1nfffSdPT09FREQ8wFO1xRo3AAAAAPCA7L+f1K0jq7zwwgsqVqyYJk6cqIYNG+q7775Tnjx5NHz4cDVr1kzPPfectm3bZjN6RpKqVKlinUZy+7mUn6tUqWIzhcXFxUUbNmxQmTJlNHjwYHXv3l1nzpyx2VY8PRYsWKARI0YoMjJS7du316pVq/Tpp58qb968GWrHMAytXbtWI0aM0KJFi9SmTRvr1uBRUVGpRpdUrlxZ06dP17vvvqsOHTpo9+7dmj59ukaNGmWt4+HhoYULFyouLk4tWrRQjRo19MEHH2QorvQYM2aM5s+fr59++klPPvmkhg4dqscff1x79uxR6dKlM72/jLx3zZs319q1axUfH6+uXbtqxIgReuqpp9SvXz+beuXKldOnn36qCxcuqFOnTnrhhRdUuXJlvffee2nG4O/vr+XLl2vx4sXW933s2LGp6i9YsEAeHh5q3769atSoofDw8HveW65cudS7d2/9888/Klq0aKqRVtKt5/3JJ5/ojz/+UJ8+fdSyZUuNGjVKx44ds472eViGaWblr7ljio+Pl6+vry5dupThzGtWya4dn3Lg2w08khzxM8FisVh3tbty5Yo8PT2zKiwAd8i2zwRl098T+qd/qpTlZqK8ltzaBeVK76byzMBUKSObpkr92/52dfDgwWzpJ2VXFntLz3eDhIQEHT16VEFBQakWcgVKlCih4OBgbdy40d6h5EghISE6d+5ctn12Zab0frYw4gYAAAAAAMBBscYNAORkD/qP+F4ZrP9v++doAADwyLrfQsW5cuVSrlzZM8bBNE0lJSXds46Tk1O2jby8U1JS0j1HaBuGIScnp2yMKGdixA0AAAAAIMdwcXG553Hneiv3ExMT88DTpHbt2nXfeG5f3Dm7NW3a9J6xlSpVym6xpdi5c+cjOU0qIxhxAwAAAADIMfbt23fP8ymLKmeHatWq3TeeoKCgbIomtXnz5uny5ct3PX/nIs3IGg6RuJk9e7amTZumU6dO6fHHH9eMGTPUoEGDu9a/fv26Jk6cqKVLlyo2NlZFihTRuHHjMpwZBQAAAADkLNWrV7d3CFbe3t4OFc+dypYta+8QIAdI3KxcuVLDhw/X7NmzVa9ePc2bN0+tW7fWb7/9Zt1v/U5dunTR6dOntWDBAj322GM6c+bMfecpAgAAAAAAPGrsnriZPn26+vfvrwEDBkiSZsyYoS+++EJz5szR5MmTU9XfsmWLdu3apb/++kv58uWTdGv7NQAAAAAAgH8buy5OfOPGDX3//fdq0aKFTXmLFi20Z8+eNK9Zv369qlevrqlTp6pw4cIqU6aMRo4cqWvXrt21n+vXrys+Pt7mAABkjKc8Zf7//zzlae9wAAAAgBzBriNuzp07p6SkJBUqVMimvFChQoqNjU3zmr/++kvffPON3N3d9dlnn+ncuXMaMmSIzp8/r4ULF6Z5zeTJkxUREZHp8QMAAAAAAGQlh9gO/M496U3TvOs+9cnJyTIMQ8uWLVPNmjXVpk0bTZ8+XZGRkXcddTNmzBhdunTJevz999+Zfg8AAADIfJ4uzjL7t5TZv6U8Xew+y/+RYbFYZBiGDMOQxWKxdzgAgIdg1//75c+fX05OTqlG15w5cybVKJwUAQEBKly4sHx9fa1l5cuXl2ma+ueff1S6dOlU17i5ubFNGQAAAAAAeOTYNXHj6uqqatWqaevWrerYsaO1fOvWrerQoUOa19SrV0+rV6/WlStX5OXlJUn6448/lCtXLhUpUiRb4gYAAAAASQ6zJMOECRMe6Lrw8HBFRETo7Nmzyp8/f6rzwcHByp8/v3bu3JnhtsPCwrRz507FxMRYy86fP68hQ4YoKipKZ8+eVYcOHbR27doHih13V6JECYWEhCgyMlKSFBMTo6CgIC1atEhhYWF2jQ0ZZ/fxpiNGjFCvXr1UvXp11alTRx988IGOHz+uZ599VtKtaU4nTpzQkiVLJEk9evTQG2+8ob59+yoiIkLnzp3TK6+8on79+il37tz2vBUAAAAAwP/3+uuv68UXX7Qpe+ONN/TZZ59p4cKFKlWqlHWnYGStgIAARUdHq1SpUvYOBQ/A7ombrl27Ki4uThMnTtSpU6cUHBysTZs2qXjx4pKkU6dO6fjx49b6Xl5e2rp1q1544QVVr15dfn5+6tKli95880173QIAAAAA4A5pJQkOHjyoUqVKqWfPnpnSh2maSkhI4B/x78PNzU21a9e2dxh4QA6xOPGQIUMUExOj69ev6/vvv1fDhg2t5yIjI1MNyytXrpy2bt2qq1ev6u+//9a7777LLyoAAAAAZLGdO3fKMAytWLFC48aNU2BgoHx8fNSsWTMdPnzYpm5YWJhKlCgh6dZUHcMwtG3bNh06dMi6eHbKd72UKVSFCxeWq6urSpYsqXHjxun69es2bRqGoaFDh2ru3LkqX7683NzctHjxYkVGRsowDEVFRWngwIHy8/OTj4+PevfuLYvFotjYWHXp0kV58uRRQECARo4cqZs3b973fqOiohQSEiI/Pz/lzp1bxYoV01NPPaWrV69a60RERKhWrVrKly+ffHx8VLVqVS1YsECmadq0VaJECYWGhmrjxo2qUqWKcufOrfLly2vjxo2Sbn33LV++vDw9PVWzZk3t378/1fP08vLSr7/+qqZNm8rT01MFChTQ0KFDbeJJS8rzT5k6Jd2aJmcYhn799Vd1795dvr6+KlSokPr166dLly7ZXH/x4kX1799f+fLlk5eXl9q2bau//vpLhmEoPDz8vs8RD8fuI24AAAAA3F9G1lK5ceOG9edJkybJ1dU13dc+9dRTGYoLOdPYsWNVr149zZ8/X/Hx8Ro9erTatWunQ4cOycnJKVX9lKk6Q4YM0aVLl7Rs2TJJUoUKFZSQkKDGjRvrf//7nyIiIlSpUiV9/fXXmjx5sn788Ud9/vnnNm2tXbtWX3/9tcaPHy9/f38VLFhQ+/btkyQNGDBAnTp10scff6wDBw5o7NixSkxM1OHDh9WpUycNGjRI27Zt05QpUxQYGKgRI0bc9R5jYmLUtm1bNWjQQAsXLlSePHl04sQJbdmyRTdu3JCHh4e13uDBg1WsWDFJ0t69e/XCCy/oxIkTGj9+vE2bP/30k8aMGaNx48bJ19dXERER6tSpk8aMGaPt27dr0qRJMgxDo0ePVmhoqI4ePWozSOHmzZtq06aNBg8erFdffVV79uzRm2++qWPHjmnDhg0P8E7e+p3v2rWr+vfvr19++UVjxoyRJC1cuFDSrZ2d27Vrp/379ys8PFxVq1ZVdHS0WrVq9UD9IeNI3AAAAAAAMqRChQpaunSp9bWTk5O6dOmiffv2pTklJ2Wqjo+Pj27cuGFTZ968efr555+1atUqPf3005Kk5s2by8vLS6NHj9bWrVvVvHlza/0rV67ol19+Ud68ea1lKYmb0NBQvfPOO9Y2oqOjtWLFCk2fPl0vvfSSJKlZs2b64osvtGzZsnsmbr7//nslJCRo2rRpeuKJJ6zlPXr0sKm3aNEi68/JyckKCQmRaZqaOXOmXn/9dRmGYT0fFxenvXv3qnDhwpKkwMBAVa5cWR9++KGOHDliTQYZhqEnn3xS27ZtU7t27azX37hxQy+//LKGDRtmvUcXFxeNGzdOu3fvVr169e56P3fTv39/vfLKK9Znc+TIES1cuFALFiyQYRjasmWLvvnmG82ZM8e6Fm3z5s3l6upqTfIgaznEVCkAAAAAwKOjffv2Nq8rVaokSTp27FiG24qKipKnp6c6d+5sU56y+9H27dttyps0aWKTtLldaGiozevy5ctLktq2bZuq/H6xVq5cWa6urho0aJAWL16sv/76667xN2vWTL6+vnJycpKLi4vGjx+vuLg4nTlzJlWbKUmb2+MLCQmxJm1uL08rxjvXB0pJJO3YseOe93M3ab2XCQkJ1th37dolSerSpYtNve7duz9Qf8g4EjcAAAAAkEM5O9+ahJGUlJTm+cTERLm4uKQq9/Pzs3nt5uYmSbp27VqGY4iLi5O/v7/NyBRJKliwoJydnRUXF2dTHhAQcNe27tylKmWaYFrlCQkJ94yrVKlS2rZtmwoWLKjnn39epUqVUqlSpTRz5kxrne+++04tWrSQJH344YfavXu39u3bp3HjxklK/TwyEp+kVDE6Ozunevb+/v6SlOo5pdf93su4uDg5OzunirFQoUIP1B8yjsQNAAAAAORQKV++T5w4keqcaZo6depUln9B9/Pz0+nTp1Mt5nvmzBklJiYqf/78NuV3JniyUoMGDbRhwwZdunRJe/fuVZ06dTR8+HB9/PHHkqSPP/5YLi4u2rhxo7p06aK6deuqevXqWRZPYmJiqgRNbGyspNQJmMzi5+enxMREnT9/Ps1+kfVI3AAAAABADtWkSRMZhqGVK1emOrdlyxbFx8erWbNmWRpD06ZNdeXKFa1du9amfMmSJdbz9ubk5KRatWpp1qxZkqQffvhB0q0kkrOzs82CzNeuXdNHH32UZbGkLOycYvny5ZJuTbfKCo0aNZKkVH9GUpJXyHosTgwAAAAAOVSpUqU0dOhQTZs2TRcvXlSbNm2UO3du7du3T2+//baqV6+eajHezNa7d2/NmjVLffr0UUxMjCpWrKhvvvlGkyZNUps2bbI8cXQ3c+fOVVRUlNq2batixYopISHButNSSkxt27bV9OnT1aNHDw0aNEhxcXF65513rNONMpurq6veffddXblyRTVq1LDuKtW6dWvVr18/S/ps1aqV6tWrp5dfflnx8fGqVq2aoqOjrYm1XLkYD5LVSNwAAAAA/zKurq4KDw+3dxh4RMycOVMVKlTQggULtHTpUiUmJqp48eJ6/vnn9dprr2VoO/kH4e7urh07dmjcuHGaNm2azp49q8KFC2vkyJGaMGFClvZ9L5UrV9aXX36pCRMmKDY2Vl5eXgoODtb69eut69o0adJECxcu1JQpU9SuXTsVLlxYAwcOVMGCBdW/f/9MjyllWtawYcP05ptvKnfu3Bo4cKCmTZuW6X2lyJUrlzZs2KCXX35Zb7/9tm7cuKF69epp6dKlql27tvLkyZNlfeMWw7xzImEOEB8fL19fX126dEk+Pj72DkdS9s3TzIFvN/BIyrbPBGXTZwIfPcBD+dd9JvRvlS3dGPO3ZEs/2fURFxERkS39PPXUU9nST3BwcLb0cz/p+W6QkJCgo0ePKigoSO7u7tkcIXBLWFiYPvnkE125csXeoUi6NUWrZ8+e2r17t+rWrWvvcB5J6f1sYcQNAAAAAAC4qxUrVujEiROqWLGicuXKpb1792ratGlq2LAhSZtsQOIGAAAAAADclbe3tz7++GO9+eabslgsCggIUFhYmN588017h5YjkLgBAAAAAMDBRUZGKjIy0i59h4aGKjQ01C594wG2A69YsaLmzZunq1evZkU8AAAAAAAA+P8ynLgpUKCAnnvuORUuXFgvvfSS/vzzz6yICwAAAAAAIMfLcOImKipKBw8eVPfu3bVgwQKVL19erVq10saNG7MiPgAAAAAAgBwrw4kbSapQoYJmz56tEydOaPr06Tp27Jg6dOigkiVL6p133tGFCxcyO04AAAAAAIAc54ESNym8vb01bNgw7dixQyEhIYqJidGoUaNUtGhRvfzyy6yDAwAAAAAA8BAeKnETHR2tZ555RiVKlNB3332n5557Tjt37tTgwYM1Z84c9evXL7PiBAAAAAAAyHEyvB14QkKCli9frlmzZunHH39U8eLF9dZbb2nAgAHy9fWVJDVs2FBPPPGEnn/++UwPGAAAAAAAIKfIcOKmcOHCunjxoho2bKhPP/1UHTp0kGEYqeqVLVtWFoslU4IEAAAAAADIiTKcuOnYsaNefPFFVaxY8Z71atWqpeTk5AcODAAAAAAc3cGDB+0dgiQpODj4ga4LDw9XRESEzp49q/z586fZbv78+bVz584Mtx0WFqadO3cqJibGWnb+/HkNGTJEUVFROnv2rDp06KC1a9c+UOw5Qcr7Y5pmhq9N6/nj0ZThxE3v3r0VFBSU5rkrV67ohx9+UMOGDR86MAAAAADAo+v111/Xiy++aFP2xhtv6LPPPtPChQtVqlQp5cuXz07RAY+ODCduGjdurOjoaNWsWTPVucOHD6tx48ZKSkrKlOAAAAAAAI+mUqVKpSo7ePCgSpUqpZ49e2ZKH6ZpKiEhQblz586U9gBHlOFdpe41ROvmzZvKleuhNqoCAAAAADionTt3yjAMrVixQuPGjVNgYKB8fHzUrFkzHT582KZuWFiYSpQoIUmKiYmRYRjatm2bDh06JMMwZBiGdQpWyhSqwoULy9XVVSVLltS4ceN0/fp1mzYNw9DQoUM1d+5clS9fXm5ublq8eLEiIyNlGIaioqI0cOBA+fn5ycfHR71795bFYlFsbKy6dOmiPHnyKCAgQCNHjtTNmzfve78lSpRQaGioNm7cqCpVqih37twqX768Nm7cKEmKjIxU+fLl5enpqZo1a2r//v2p2li/fr3q1KkjDw8PeXt7q3nz5oqOjk5V7/PPP1flypXl5uamoKAgvfPOO2nGZJqmZs+ercqVKyt37tzKmzevOnfurL/++uu+94NHU7pG3MTHx+vixYvW17GxsTp+/LhNnWvXrmnx4sXy9/fP1AABAAAAAI5l7NixqlevnubPn6/4+HiNHj1a7dq106FDh+Tk5JSqfkBAgKKjozVkyBBdunRJy5YtkyRVqFBBCQkJaty4sf73v/8pIiJClSpV0tdff63Jkyfrxx9/1Oeff27T1tq1a/X1119r/Pjx8vf3V8GCBbVv3z5J0oABA9SpUyd9/PHHOnDggMaOHavExEQdPnxYnTp10qBBg7Rt2zZNmTJFgYGBGjFixH3v9aefftKYMWM0btw4+fr6KiIiQp06ddKYMWO0fft2TZo0SYZhaPTo0QoNDdXRo0etI4CWL1+unj17qkWLFlqxYoWuX7+uqVOnKiQkRNu3b1f9+vUlSdu3b1eHDh1Up04dffzxx0pKStLUqVN1+vTpVPEMHjxYkZGRGjZsmKZMmaLz589r4sSJqlu3rn766ScVKlQoY28mHF66Ejf/+c9/NHHiREm3MpwdO3ZMs55pmho7dmzmRQcAAAAAcDgVKlTQ0qVLra+dnJzUpUsX7du3T7Vr105V383NTbVr15aPj49u3LhhU2fevHn6+eeftWrVKj399NOSpObNm8vLy0ujR4/W1q1b1bx5c2v9K1eu6JdfflHevHmtZSmJm9DQUOtIlZSRLStWrND06dP10ksvSZKaNWumL774QsuWLUtX4iYuLk579+5V4cKFJUmBgYGqXLmyPvzwQx05ckQeHh6Sbn1XfvLJJ7Vt2za1a9dOycnJeuWVV1SxYkVt3rzZOjulTZs2KlWqlEaPHq3du3dLksaNG6dChQpp69atcnd3lyS1bNnSOmIpxd69e/Xhhx/q3XfftYm9QYMGKlOmjKZPn64pU6bc957waElX4qZFixby8vKSaZoaNWqUXnjhBRUrVsymjpubmypWrKhGjRplSaAAAAAAAMfQvn17m9eVKlWSJB07dizNxM29REVFydPTU507d7YpDwsL0+jRo7V9+3abxE2TJk1skja3Cw0NtXldvnx5rV27Vm3btk1V/uWXX6YrvsqVK1uTNinXSlJISIg1aXN7+bFjxyTdWgP25MmTGj58uM2SIl5eXnrqqac0b948Xb16VaZpat++fRoyZIg1aSNJ3t7eateunRYvXmwt27hxowzD0DPPPKPExERrub+/v5544okH2v0Lji9diZs6deqoTp06kiSLxaKBAwcqMDAwSwMDAAAAAGQtZ+dbXwnvtsFMYmKiXFxcUpX7+fnZvHZzc5N0awmNjIqLi5O/v78Mw7ApL1iwoJydnRUXF2dTHhAQcNe27tylytXV9a7lCQkJ6YovI21KsrabEnda8QYGBio5OVkXLlyQaZpKTk5Oc9mRO8tOnz4t0zTvOh2qZMmS6bklPGIyvKvUhAkTsiIOAAAAAEA2S0kAnDhxIlUywDRNnTp1StWrV8/SGPz8/PTtt9/KNE2b5M2ZM2eUmJio/Pnz29S/M8HjqFKSW6dOnUp17uTJk8qVK5fy5s1rve/Y2NhU9e4sy58/vwzD0Ndff21Nlt0urTI8+tKVuFmyZInatm0rPz8/LVmy5L71e/fu/dCBAQAAAACyVpMmTWQYhlauXKmqVavanNuyZYvi4+PVrFmzLI2hadOmWrVqldauXWuznmrKd8+mTZtmaf9ZpWzZsipcuLCWL1+ukSNHWhNOFotFn376qXWnKUmqWbOm1qxZo2nTplmnS12+fFkbNmywaTM0NFRvv/22Tpw4oS5dumTvDcFu0pW4CQsL0969e+Xn56ewsLB71jUMg8QNAAAAADwCSpUqpaFDh2ratGm6ePGi2rRpo9y5c2vfvn16++23Vb16dfXo0SNLY+jdu7dmzZqlPn36KCYmRhUrVtQ333yjSZMmqU2bNlmeOMoquXLl0tSpU9WzZ0+FhoZq8ODBun79uvVZv/3229a6b7zxhlq1aqXmzZvr5ZdfVlJSkqZMmSJPT0+dP3/eWq9evXoaNGiQ+vbtq/3796thw4by9PTUqVOn9M0336hixYp67rnn7HG7yELpStwcPXrUOi/v6NGjWRoQAAAAADwqgoOD7R3CQ5s5c6YqVKigBQsWaOnSpUpMTFTx4sX1/PPP67XXXrOu3ZJV3N3dtWPHDo0bN07Tpk3T2bNnVbhwYY0cOfKRX6qjR48e8vT01OTJk9W1a1c5OTmpdu3a2rFjh+rWrWut17x5c61du1avvfaaunbtKn9/fw0ZMkTXrl1TRESETZvz5s1T7dq1NW/ePM2ePVvJyckKDAxUvXr1VLNmzey+RWQDwzRN095BZLf4+Hj5+vrq0qVL8vHxsXc4krJvnmYOfLuBR1K2fSYomz4T+OgBHsq/7jOhf6ts6caYvyVb+smuj7g7v7xllaeeeipb+nGUhEd6vhskJCTo6NGjCgoKstn1BwAeRno/W3Ld9QwAAAAAAADsKl1Tpfr165fuBg3D0IIFCx44IAAAAAAAANySrsRNVFRUuofoPipbswEAAAAAADi6dCVuYmJisjgMAAAAAAAA3Ik1bgAAAAAAABwUiRsAAAAASAd2aAWQmdL7mZKuqVIlS5bUZ599pieeeEJBQUH3XMfGMAz973//S1+UAAAAAODgXFxcJElXr15V7ty57RwNgH8Li8UiwzCsnzF3k67ETaNGjeTj42P9mQWIAQAAAOQUTk5OypMnj86cOSNJ8vDw4DsRgAdimqYSExMVHx+v+Ph45cmTR05OTve8Jl2Jm0WLFll/joyMfKggAQAAAOBR4+/vL0nW5A0APAwnJycFBATI19f3vnXTlbi53ZIlS9S2bVv5+fmlOnf+/Hlt3LhRvXv3zmizAAAAAOCwDMNQQECAChYsqJs3b9o7HACPMGdnZzk5OaV75F6GEzd9+/ZVdHR0mombo0ePqm/fviRuAAAAAPwrOTk53XdaAwBkpgzvKnWvVY8TEhL4EAMAAAAAAMgk6Rpxc/z4ccXExFhfHzhwQAkJCTZ1rl27pg8++EDFihXL1AABAAAAAAByqnQvThwRESHDMGQYhoYMGZKqTspInJkzZ2ZuhAAAAAAAADlUuhI3Xbp0UXBwsEzTVJcuXTRp0iSVLl3apo6bm5uCg4NVokSJrIgTAAAAAAAgx0lX4qZ8+fIqX768pFujb0JDQ9NcnBgAAAAAAACZJ8O7SvXp0ycr4gAAAAAAAMAdMpy46dev3z3PG4ahBQsWPHBAAAAAAAAAuCXDiZuoqCgZhmFTFhcXpytXrihPnjzKkydPZsUGAAAAAACQo2U4cXP7tuC3i4qK0pAhQ7R69eqHjQkAAAAAAACScmVWQ02aNNHQoUP14osvZlaTAAAAAAAAOVqmJW4kqUKFCvruu+8ys0kAAAAAAIAcK1MTN7t27VL+/Pkzs0kAAAAAAIAcK8Nr3EycODFV2fXr1/Xzzz9r8+bNeuWVVzIlMAAAAAAAgJwuw4mb8PDwVGVubm4qUaKEJk6cSOIGAAAAAAAgk2Q4cZOcnJwVcQAAAAAAAOAOmbrGDf5dLBaLDMOQYRiyWCz2DgcAAAAAgByHxA0AAAAAAICDcojEzezZsxUUFCR3d3dVq1ZNX3/9dbqu2717t5ydnVW5cuWsDRAAAAAAAMAO7J64WblypYYPH65x48bpwIEDatCggVq3bq3jx4/f87pLly6pd+/eatq0aTZFCgAAAAAAkL3snriZPn26+vfvrwEDBqh8+fKaMWOGihYtqjlz5tzzusGDB6tHjx6qU6dONkUKAAAAAACQveyauLlx44a+//57tWjRwqa8RYsW2rNnz12vW7Rokf73v/9pwoQJ6ern+vXrio+PtzkAAAAAAAAcnV0TN+fOnVNSUpIKFSpkU16oUCHFxsamec2ff/6pV199VcuWLZOzc/p2M588ebJ8fX2tR9GiRR86dgAAAAAAgKyW4cTNzZs39eabb6pChQry9PSUk5OTzZHeZMrtDMOweW2aZqoySUpKSlKPHj0UERGhMmXKpLv9MWPG6NKlS9bj77//znCMAIB/F4vFIsMwZBiGLBaLvcMBAAAA0pThLMuYMWP0n//8R61bt9aTTz4pNze3B+48f/78cnJySjW65syZM6lG4UjS5cuXtX//fh04cEBDhw6VJCUnJ8s0TTk7O+vLL79UkyZNUl3n5ub2UHECAAAAAADYQ4YTN6tWrdL48ePTvb7Mvbi6uqpatWraunWrOnbsaC3funWrOnTokKq+j4+PfvnlF5uy2bNnKyoqSp988omCgoIeOqZ/vdQDmdLHK4P1zQfsBwAAAAAAWGU4cXPhwgU1bNgw0wIYMWKEevXqperVq6tOnTr64IMPdPz4cT377LOSbo3wOXHihJYsWaJcuXIpODjY5vqCBQvK3d09VTkAAAAAAMCjLsOJm4YNG+rHH39U48aNMyWArl27Ki4uThMnTtSpU6cUHBysTZs2qXjx4pKkU6dO6fjx45nSFwAAAAAAwKMkw4mb9957Tx06dFDx4sUVGhoqV1fXhw5iyJAhGjJkSJrnIiMj73lteHi4wsPDHzoGAAAAAAAAR5PhxE3lypV18+ZNPf300zIMQx4eHjbnDcPQpUuXMi1AAAAAAACAnCrDiZunnnoqza26AQAAAAAAkLkynLi539QlAAAAAAAAZI5c9g4AAAAAAAAAacvwiJsUBw8e1KFDh3Tt2rVU53r37v1QQQEAAAAAAOABEjdXr15V+/btFRUVJcMwZJqmJNmse0Pi5t/BU54yZdo7DABItwddgc0rg/X5ZAQAAEB2yfBUqTfeeEMxMTHatWuXTNPUmjVrtHXrVnXq1EmlS5fWDz/8kBVxAgAAAAAA5DgZTtysW7dOo0ePVt26dSVJxYoVU9OmTbV69WpVrVpVc+bMyfQgAQAAAAAAcqIMJ25iYmJUrlw5OTk5yTAMXb161XquZ8+eWrt2bWbGBwAAAAAAkGNlOHGTJ08eWSwWSVLBggX1559/Ws/dvHnTeg4AAAAAAAAPJ8OJm4oVK+qPP/6QJDVu3FiTJk3SN998o++++04TJ07UE088kelBAgAAAAAA5EQZ3lWqf//+1lE2b731lurXr69GjRpJujUaZ9OmTZkbIQAAAAAAQA6V4cRNly5drD8HBQXpjz/+sG4NXrduXeXLly9TAwQAAAAAAMipMpy4uZOnp6fatWuXGbEAAAAAAADgNhle40aSrl+/rnnz5ql79+5q3ry5derUunXr9Ndff2VqgAAAAAAAADlVhkfcnDt3To0bN9avv/4qf39/nT59WpcvX5YkrV27Vl988YVmz56d6YECAAAAAADkNBkecTNq1ChdvHhR+/fv1/Hjx2WapvVc48aNtWvXrkwNEAAAAAAAIKfK8IibjRs3asqUKapataqSkpJszhUpUkT//PNPpgUHAECW8fSUbvvHBwAAAMARZXjETXx8vIoXL57muZs3byoxMfGhgwIAAAAAAMADJG6CgoIUHR2d5rnvvvtOZcuWfeigAAAAAAAA8ACJm549e2rKlClat26ddX0bwzC0b98+zZw5U7169cr0IAEAAAAAAHKiDK9xM3r0aO3evVsdO3ZU3rx5JUktW7ZUXFycWrVqpRdffDHTgwQAAAAAAMiJMpy4cXFx0aZNm7Ry5Up9/vnnOn36tPLnz6/Q0FB169ZNuXJleBAPAAAAkCNYLBZ5eXlJkq5cuSJPT087RwQAcHQZTtxIt6ZGdevWTd26dcvseAAAAIBHimE82HX/P3+TbuHhD9YPAODRxvAYAAAAAAAAB5WuETdNmjRJd4OGYWj79u0PHBAAAADw7+UpybR3EACAR0i6Ejc7d+6Uj4+PihYtmtXxAAAAAAAA4P9LV+KmZMmS+uuvv+Tr66t+/fqpa9euLKQGAAAAAACQxdK1xs2RI0e0Y8cOlSxZUi+88IICAgI0YMAA7dmzJ6vjAwAAAAAAyLHSvThxo0aNtGTJEp06dUpTp07VL7/8ovr166t8+fKaNm2aTp8+nZVxAgAAAAAA5DgZ3lXKx8dHzz77rL799lv9/PPPatq0qcaOHashQ4ZkRXwAAAAAAAA51gNvB37o0CEtXrxYn3zyiUzTVNmyZTMzLgAA/hUsFosMw5BhGLJYLPYOBwAAAI+YdC1OnOLKlStasWKFFi5cqG+//ValSpXSsGHDFBYWpsDAwKyKEQAAAAAAIEdKV+Lmq6++0oIFC/Tpp5/KNE117txZb7/9tho1apTV8QEA4HAM48Gu8/LKWH3TfLB+AAAA8O+RrsRNSEiIfHx81LNnT3Xv3l0+Pj6SpB9++CHN+lWrVs28CAEAAAAAAHKodE+Vio+P1/z58zV//vy71jFNU4ZhKCkpKVOCAx5FFotFXv//n9WvXLkiT09PO0cEAAAAAHhUpStxs2jRoqyOAwCAfylPScx5AgAAwINJV+KmT58+WR0H4NBYzwIAAAAAYA8PvB04AAAAAAAAslaGtgMHkB5MiwAAAAAAZA5G3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAD/AhaLRYZhyDAMWSwWe4cDAACATELiBgAAAAAAwEGRuAEAAAAAAHBQJG4AAAAAAAAcFIkbAAAAAAAAB0XiBgAApBuLIAMAAGQvEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOyiESN7Nnz1ZQUJDc3d1VrVo1ff3113etu2bNGjVv3lwFChSQj4+P6tSpoy+++CIbowUAAAAAAMgedk/crFy5UsOHD9e4ceN04MABNWjQQK1bt9bx48fTrP/VV1+pefPm2rRpk77//ns1btxY7dq104EDB7I5cgAAAAAAgKxl98TN9OnT1b9/fw0YMEDly5fXjBkzVLRoUc2ZMyfN+jNmzNCoUaNUo0YNlS5dWpMmTVLp0qW1YcOGbI4cAAAAAAAgaznbs/MbN27o+++/16uvvmpT3qJFC+3ZsyddbSQnJ+vy5cvKly/fXetcv35d169ft76Oj49/sIABAMhGERER6a5748YN68+TJk2Sq6truq+dMGFChuICAABA9rHriJtz584pKSlJhQoVsikvVKiQYmNj09XGu+++K4vFoi5duty1zuTJk+Xr62s9ihYt+lBxAwAAAAAAZAe7T5WSJMMwbF6bppmqLC0rVqxQeHi4Vq5cqYIFC9613pgxY3Tp0iXr8ffffz90zAAAAAAAAFnNrlOl8ufPLycnp1Sja86cOZNqFM6dVq5cqf79+2v16tVq1qzZPeu6ubnJzc3toeMFAGQ9i8UiLy8vSdKVK1fk6elp54gAAAAA+7HriBtXV1dVq1ZNW7dutSnfunWr6tate9frVqxYobCwMC1fvlxt27bN6jABAAAAAADswq4jbiRpxIgR6tWrl6pXr646derogw8+0PHjx/Xss89KujXN6cSJE1qyZImkW0mb3r17a+bMmapdu7Z1tE7u3Lnl6+trt/sAAOBRdfDgwXTXvXr1qvXnX3/9VR4eHum+Njg4OENxAQAAwAESN127dlVcXJwmTpyoU6dOKTg4WJs2bVLx4sUlSadOndLx48et9efNm6fExEQ9//zzev75563lffr0UWRkZHaHDwAAAAAAkGXsnriRpCFDhmjIkCFpnrszGbNz586sDwgAAAAAAMABOMSuUgAAAAAAAEiNxA0AAAAAAICDInEDAAAAAADgoEjcAAAAAAAAOCgSNwAAAAAAAA7KIXaVAgAAD8fV1VXh4eH2DgMAAACZjBE3yDEsFosMw5BhGLJYLPYOBwAAAACA+yJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisWJAQBAunl4eOiXX36xdxgAAAA5BiNuAAAAAAAAHBSJGwAAAAAAAAfFVCkAQNYb0Cr9dW8m/t/PQzpILhn4X9X8LemvCwAAADwCGHEDAAAAAADgoEjcAAAAAAAAOCgSNwAAAAAAAA6KxA0AAAAAAICDYnFiPNKMB7zOK1OjAAAAAAAgazDiBgAAAAAAwEGRuAEAAAAAAHBQJG4AAAAAAAAcFIkbAAAAAAAAB0XiBgAAAAAAwEGRuAEAAAAAAHBQJG4AAAAAAAAcFIkbAAAAAAAAB0XiBgAAAAAAwEGRuAEAAAAAAHBQzvYOAMg2np6Sado7CgAAAAAA0o0RNwAAAAAAAA6KETcAAIfi6eIss39Le4cBAAAAOARG3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQN8IiyWCwyDEOGYchisdg7HAAAAABAFiBxAwAAAAAA4KBI3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxA7tjkV0AAAAAANLmEImb2bNnKygoSO7u7qpWrZq+/vrre9bftWuXqlWrJnd3d5UsWVJz587NpkiBnIfEGgAAAADYj90TNytXrtTw4cM1btw4HThwQA0aNFDr1q11/PjxNOsfPXpUbdq0UYMGDXTgwAGNHTtWw4YN06effprNkQMAAAAAAGQtuydupk+frv79+2vAgAEqX768ZsyYoaJFi2rOnDlp1p87d66KFSumGTNmqHz58howYID69eund955J5sjBwAAAAAAyFp2TdzcuHFD33//vVq0aGFT3qJFC+3ZsyfNa6Kjo1PVb9mypfbv36+bN2+mec3169cVHx9vcwAAAAAAADg6Z3t2fu7cOSUlJalQoUI25YUKFVJsbGya18TGxqZZPzExUefOnVNAQECqayZPnqyIiIjMCzwLmKZp7xAy14BW6a97M/H/fh7SQXJJ/x9Lc/6WDAT1ELLp7cnIn9MbN25Yf540aZJcXV3Tfe1TTz2V7rpXr161/vzrr7/Kw8Mj3dcGBwenuy5s/es+E5Q9v6vZ9tSyraMJ2dURHByfCQ+GzwQAwL+B3adKSZJhGDavTdNMVXa/+mmVpxgzZowuXbpkPf7++++HjBgAAAAAACDr2XXETf78+eXk5JRqdM2ZM2dSjapJ4e/vn2Z9Z2dn+fn5pXmNm5ub3NzcMidoIAtNmJD+f0mzWCyaNGmSJGns2LHy9PRM97UHDx7McGwAAAAAgOxn1xE3rq6uqlatmrZu3WpTvnXrVtWtWzfNa+rUqZOq/pdffqnq1avLxcUly2IFAAAAAADIbnafKjVixAjNnz9fCxcu1KFDh/TSSy/p+PHjevbZZyXdmubUu3dva/1nn31Wx44d04gRI3To0CEtXLhQCxYs0MiRI+11CwAAAAAAAFnCrlOlJKlr166Ki4vTxIkTderUKQUHB2vTpk0qXry4JOnUqVM6fvy4tX5QUJA2bdqkl156SbNmzVJgYKDee++9DC22CgAAAAAA8CgwzH/fNgX3FR8fL19fX126dEk+Pj72DuffKQO7SlluJspryXZJ0pXeTeWZgV2llF27Sjkgi8UiLy8vSdKVK1cytMaNI/YDAABgD3w3AODo7D5VCgAAAAAAAGkjcQMAAAAAAOCgSNwAAAAAAAA4KLsvTox/qYysPWOxSEturaGi2esk1lABAAAAAEASI24AAAAAAAAcFokbAAAAAAAAB0XiBgAAAAAAwEGxxg3wiPL09JRpmvYOAwAAAACQhRhxAwAAAAAA4KAYcQPgnhjZAwAAAAD2w4gbAAAAAAAAB0XiBgAAAAAAwEGRuAEAAAAAAHBQJG4AAAAAAAAcFIkbAAAAAAAAB0XiBgAAAAAAwEGRuAEAAAAAAHBQJG4AAAAAAAAcFIkbAAAAAAAAB+Vs7wAAT09PmaZp7zAAAAAAAHA4jLgBAAAAAABwUCRuAAAAAAAAHBSJGwAAAAAAAAdF4gYAAAAAAMBBkbgBAAAAAABwUCRuAAAAAAAAHBSJGwAAAAAAAAdF4gYAAAAAAMBBkbgBAAAAAABwUCRuAAAAAAAAHBSJGwAAAAAAAAdF4gYAAAAAAMBBkbgBAAAAAABwUCRuAAAAAAAAHBSJGwAAAAAAAAdF4gYAAAAAAMBBOds7AHswTVOSFB8fb+dIAAAAANhTyneClO8IAOBocmTi5vLly5KkokWL2jkSAAAAAI7g8uXL8vX1tXcYAJCKYebA1HJycrJOnjwpb29vGYZh73D+deLj41W0aFH9/fff8vHxsXc4AOyMzwQAt+MzAY7GNE1dvnxZgYGBypWLlSQAOJ4cOeImV65cKlKkiL3D+Nfz8fHhL2QArPhMAHA7PhPgSBhpA8CRkVIGAAAAAABwUCRuAAAAAAAAHBSJG2Q6Nzc3TZgwQW5ubvYOBYAD4DMBwO34TAAAIGNy5OLEAAAAAAAAjwJG3AAAAAAAADgoEjcAAAAAAAAOisQNAAAAAACAgyJxg0zx448/qm3btipWrJhy586tfPnyqU6dOlq6dKm9QwNgBzt37pRhGGkee/futXd4AP6/lStX6vHHH1fu3LllGIZ+/PHHdF9rGIbCw8Otr1N+73fu3JnpccbExMgwDL3zzjuZ3jYAAI7O2d4B4N/h4sWLKlq0qLp3767ChQvLYrFo2bJl6tWrl2JiYvTaa6/ZO0QAdjBp0iQ1btzYpiw4ONhO0QC43dmzZ9WrVy+1atVKs2fPlpubm8qUKWPvsAAAwB1I3CBThISEKCQkxKYsNDRUR48e1QcffEDiBsihSpcurdq1a9s7DABp+OOPP3Tz5k0988wzatSokb3DAQAAd8FUKWSp/Pnzy9mZ/CAAAI4kLCxM9evXlyR17dpVhmFY/xHmzn+ISalfokSJLInl+PHjeuaZZ1SwYEG5ubmpfPnyevfdd5WcnJyqbnJyst566y0VK1ZM7u7uql69urZv325T5+zZsxo0aJCKFi0qNzc3FShQQPXq1dO2bduyJH4AALIaiRtkquTkZCUmJurs2bOaPXu2vvjiC40ePdreYQGwk+eff17Ozs7y8fFRy5Yt9c0339g7JACSXn/9dc2aNUvSrSmN0dHRmj17drbHcfbsWdWtW1dffvml3njjDa1fv17NmjXTyJEjNXTo0FT133//fW3ZskUzZszQ0qVLlStXLrVu3VrR0dHWOr169dLatWs1fvx4ffnll5o/f76aNWumuLi47Lw1AAAyDUMhkKmGDBmiefPmSZJcXV313nvvafDgwXaOCkB28/X11YsvvqiQkBD5+fnpyJEjmjZtmkJCQvT555+rZcuW9g4RyNFKlSqlChUqSLLvlMbp06frxIkT+vbbb1WzZk1JUsuWLZWUlKS5c+dq+PDhNuvuJCUlaevWrXJ3d7fWLVGihMaPH6+tW7dKknbv3q0BAwZo4MCB1us6dOiQjXcFAEDmInGDTDV27FgNGDBAZ86c0YYNGzR06FBZLBaNHDnS3qEByEZVqlRRlSpVrK8bNGigjh07qmLFiho1ahSJGwCSpKioKFWoUMGatEkRFhamOXPmKCoqyiZx06lTJ2vSRpK8vb3Vrl07rVixQklJSXJyclLNmjUVGRkpPz8/NWvWTNWqVZOLi0u23RMAAJmNqVLIVMWKFVP16tXVpk0bzZkzR4MGDdKYMWN09uxZe4cGwM7y5Mmj0NBQ/fzzz7p27Zq9wwHgAOLi4hQQEJCqPDAw0Hr+dv7+/qnq+vv768aNG7py5YqkW1uc9+nTR/Pnz1edOnWUL18+9e7dW7GxsVlwBwAAZD0SN8hSNWvWVGJiov766y97hwLAAZimKUkyDMPOkQBIi7u7u65fv56q/Ny5c1nSn5+fn06dOpWq/OTJk5JubXJwu7SSL7GxsXJ1dZWXl5f1mhkzZigmJkbHjh3T5MmTtWbNGoWFhWX+DQAAkA1I3CBL7dixQ7ly5VLJkiXtHQoAO7tw4YI2btyoypUr20x1AOA4SpQooT/++MMmeRMXF6c9e/ZkSX9NmzbVb7/9ph9++MGmfMmSJTIMQ40bN7YpX7NmjRISEqyvL1++rA0bNqhBgwZycnJK1X6xYsU0dOhQNW/ePFUfAAA8KljjBpli0KBB8vHxUc2aNVWoUCGdO3dOq1ev1sqVK/XKK6+oQIEC9g4RQDbq0aOHdepk/vz59eeff+rdd9/V6dOnFRkZae/wANxFr169NG/ePD3zzDMaOHCg4uLiNHXqVPn4+GRJfy+99JKWLFmitm3bauLEiSpevLg+//xzzZ49W88995zN+jaS5OTkpObNm2vEiBFKTk7WlClTFB8fr4iICEnSpUuX1LhxY/Xo0UPlypWTt7e39u3bpy1btqhTp05Zcg8AAGQ1EjfIFHXq1NGiRYu0ePFiXbx4UV5eXnriiSf00Ucf6ZlnnrF3eACyWaVKlbRy5UrNnTtXV65cUb58+VS/fn199NFHqlGjhr3DA3AX9erV0+LFi/X222+rQ4cOKlmypCZMmKBNmzZp586dmd5fgQIFtGfPHo0ZM0ZjxoxRfHy8SpYsqalTp2rEiBGp6g8dOlQJCQkaNmyYzpw5o8cff1yff/656tWrJ+nWVK9atWrpo48+UkxMjG7evKlixYpp9OjRGjVqVKbHDwBAdjDMlAUHAAAAAAAA4FBY4wYAAAAAAMBBMVUKAAAAmco0TSUlJd2zjpOTEzvMAQCQDoy4AQAAQKbatWuXXFxc7nksXrzY3mECAPBIYI0bAAAAZKrLly/r8OHD96wTFBQkPz+/bIoIAIBHF4kbAAAAAAAAB8VUKQAAAAAAAAdF4gYAAAAAAMBBkbgBAAAAAABwUCRuAPwrRUZGyjAM6+Hs7KyAgAB169ZNf/75p73Dy5DffvtN4eHhiomJSXUuLCxMJUqUyPaYJOm///2vHnvsMbm6usowDF28ePGh4snItYZhKDw8/IH6uV3Kn5O0nq0jOHDggBo1aiRfX18ZhqEZM2akWe/q1asKDw/Xzp07U50LDw+XYRg6d+5clsbq6M8SAADgUeVs7wAAICstWrRI5cqVU0JCgnbv3q233npLO3bs0O+//668efPaO7x0+e233xQREaGQkJBUiY3XX39dL774YrbH9OOPP2rYsGEaMGCA+vTpI2dnZ3l7e9stngfVtm1bRUdHKyAgwN6hpKlfv36yWCz6+OOPlTdv3rsmtq5evaqIiAhJUkhISPYFCAAAgCxH4gbAv1pwcLCqV68u6dYX2qSkJE2YMEFr165V37597RzdwytVqpRd+v31118lSQMHDlTNmjXtHs+DKlCggAoUKGDvMO7q4MGDGjhwoFq3bm3vUBzWzZs3raPqssO1a9eUO3fubOkLAABAYqoUgBwmJYlz+vRpm/L9+/erffv2ypcvn9zd3VWlShWtWrUq1fUnTpzQoEGDVLRoUbm6uiowMFCdO3e2aS8+Pl4jR45UUFCQXF1dVbhwYQ0fPlwWi8WmLcMwNHToUM2bN09lypSRm5ubKlSooI8//thaJzIyUk8//bQkqXHjxtapX5GRkZJSTy+qUqWKGjRokCrupKQkFS5cWJ06dbKW3bhxQ2+++abKlSsnNzc3FShQQH379tXZs2fv+QxDQkL0zDPPSJJq1aolwzAUFhaWZjySZJqmZs+ercqVKyt37tzKmzevOnfurL/++uue/Ui3nuXAgQPl5+cnLy8vtWrVSn/88cd9r5Ok5ORkvfnmmypbtqxy586tPHnyqFKlSpo5c6a1zp3Te3bu3Gkzxe724877WrlyperUqSNPT095eXmpZcuWOnDgQLpiO3jwoDp06KC8efPK3d1dlStX1uLFi1PFlZiYqDlz5lhjSEtMTIw1+RQREWGtm/KepDh9+rS6d+8uX19fFSpUSP369dOlS5ds6jzMe3U327ZtU9OmTeXj4yMPDw/Vq1dP27dvt6lz5MgR9e3bV6VLl5aHh4cKFy6sdu3a6ZdffrGpl/L+fPTRR3r55ZdVuHBhubm56ciRIwoLC5OXl5eOHDmiNm3ayMvLS0WLFtXLL7+s69ev27ST3j/7JUqUUGhoqNasWaMqVarI3d3dOrIJAAAguzDiBkCOcvToUUlSmTJlrGU7duxQq1atVKtWLc2dO1e+vr76+OOP1bVrV129etX6BfjEiROqUaOGbt68qbFjx6pSpUqKi4vTF198oQsXLqhQoUK6evWqGjVqpH/++cda59dff9X48eP1yy+/aNu2bTZfwNevX68dO3Zo4sSJ8vT01OzZs9W9e3c5Ozurc+fOatu2rSZNmqSxY8dq1qxZqlq1qqS7j2zp27evXnzxRf35558qXbq0tfzLL7/UyZMnraOMkpOT1aFDB3399dcaNWqU6tatq2PHjmnChAkKCQnR/v377zqqYPbs2VqxYoXefPNN61S0e41aGTx4sCIjIzVs2DBNmTJF58+f18SJE1W3bl399NNPKlSoUJrXmaapJ598Unv27NH48eNVo0YN7d69O92jT6ZOnarw8HC99tpratiwoW7evKnff/9dFy9evOs1VatWVXR0tE3Zn3/+qf79++vxxx+3lk2aNEmvvfaa+vbtq9dee003btzQtGnT1KBBA3333XeqUKHCXfs4fPiw6tatq4IFC+q9996Tn5+fli5dqrCwMJ0+fVqjRo2yTuGqU6eOOnfurJdffvmu7QUEBGjLli1q1aqV+vfvrwEDBkhSqvfkqaeeUteuXdW/f3/98ssvGjNmjCRp4cKF1joP+l7dzdKlS9W7d2916NBBixcvlouLi+bNm6eWLVvqiy++UNOmTSVJJ0+elJ+fn95++20VKFBA58+f1+LFi1WrVi0dOHBAZcuWtWl3zJgxqlOnjubOnatcuXKpYMGCkm6Nvmnfvr369++vl19+WV999ZXeeOMN+fr6avz48ZIy/mf/hx9+0KFDh/Taa68pKChInp6eGXoGAAAAD80EgH+hRYsWmZLMvXv3mjdv3jQvX75sbtmyxfT39zcbNmxo3rx501q3XLlyZpUqVWzKTNM0Q0NDzYCAADMpKck0TdPs16+f6eLiYv7222937Xfy5Mlmrly5zH379tmUf/LJJ6Ykc9OmTdYySWbu3LnN2NhYa1liYqJZrlw587HHHrOWrV692pRk7tixI1V/ffr0MYsXL259fe7cOdPV1dUcO3asTb0uXbqYhQoVst7jihUrTEnmp59+alNv3759piRz9uzZd71H0/y/53vnfd4ZT3R0tCnJfPfdd23q/f3332bu3LnNUaNG3fXazZs3m5LMmTNn2lz71ltvmZLMCRMm3DPG0NBQs3Llyum6j6NHj6Z5/vTp02bJkiXNxx9/3Lxw4YJpmqZ5/Phx09nZ2XzhhRds6l6+fNn09/c3u3Tpcs8+u3XrZrq5uZnHjx+3KW/durXp4eFhXrx40VomyXz++efv2Z5pmubZs2fv+kwmTJhgSjKnTp1qUz5kyBDT3d3dTE5ONk0zY+9VWu58lhaLxcyXL5/Zrl07m3pJSUnmE088YdasWfOubSUmJpo3btwwS5cubb700kvW8h07dpiSzIYNG6a6pk+fPqYkc9WqVTblbdq0McuWLWt9nZE/+8WLFzednJzMw4cP3/PeAQAAshJTpQD8q9WuXVsuLi7y9vZWq1atlDdvXq1bt866HsaRI0f0+++/q2fPnpKkxMRE69GmTRudOnVKhw8fliRt3rxZjRs3Vvny5e/a38aNGxUcHKzKlSvbtNWyZUsZhpFq15+mTZvajGJwcnJS165ddeTIEf3zzz8Zvl8/Pz+1a9dOixcvVnJysiTpwoULWrdunXr37m29740bNypPnjxq166dTZyVK1eWv79/mrsTPYiNGzfKMAw988wzNv34+/vriSeeuGc/O3bskCTre5OiR48e6eq7Zs2a+umnnzRkyBB98cUXio+Pz1DsFotFbdu2VUJCgjZv3qw8efJIkr744gslJiaqd+/eNvfk7u6uRo0a3ffZRUVFqWnTpipatKhNeVhYmK5evZpqxE9mad++vc3rSpUqKSEhQWfOnJH0cO9VWvbs2aPz58+rT58+Nu0lJyerVatW2rdvn3X6YGJioiZNmqQKFf5fe3ceEtXXxgH8azozOpM/t0lEo8nMGl9cCCojY0SthjKJarA9y6KIosXC0KwgKMoKhFYjmjZbUKmgjVKiLIiwQIK0lcqsBtMGKirSnveP3pl3xpkxy5bh1/cD/uG55557zr3nn/vMuef5D5RKJfz8/KBUKvHgwQPU19e7tD1p0iS31/Tx8UFWVpbLOJ8+fWr//3vnfmJiotMKPSIiIqLfjZ9KEdG/2qFDhxAXF4e3b9/ixIkTKC0txdSpU3H+/HkA/9/rZuXKlVi5cqXbNmxplJubm9G7d+9Or2exWPDw4UMoFIpO27KJiIhwqWMra2lp+eb13MnNzUVlZSUuXboEo9GIY8eO4dOnT057nlgsFlitViiVyi7180dZLBaIiMdPbPr16+fx3JaWFvj5+SEsLMyp3N09c6egoAAajQZHjhzBnj174OvrC4PBgM2bN9v3OvKkra0NJpMJ9+/fx9WrV52CLLY5M2TIELfn9ujR+W8iLS0tbrNYRUZG2o//Ch3vo0qlAvB1s12ge8/KHdt9MplMHuu0trZCo9EgLy8PO3fuxKpVq5CamoqQkBD06NED8+bNs/fPkacsYGq1Gv7+/k5lKpUKHz9+dOrX98x9b804RkRERH8PBm6I6F8tLi7O/pKelpaG9vZ27Nu3DxUVFTCZTNBqtQC+vuQ7btzryLa/Rq9evb65Ckar1SIgIMBp35COxx29evXKpY6trOOLdlcZjUZERkbCbDbDaDTCbDYjOTnZad8VrVaLsLAwXLhwwW0bgYGBP3TtjrRaLXx8fFBTU2MPFDhyV2YTFhaGtrY2tLS0ON0Ld/fMHT8/P+Tl5SEvLw9WqxVVVVUoLCyE0WhEY2Mj1Gq1x3Pnz5+P6upqnDt3DklJSS5jAoCKigrodLou9aXjuF6+fOlS/uLFC6f2f7fuPCtP7QHA9u3bMWzYMLd1bEEi2144GzdudDr++vVr+0onR542au5qv75n7nfnWkREREQ/AwM3RPRXKS4uRmVlJdauXYuJEydi4MCBiI2NRV1dnctLY0djxozB4cOHce/ePZfNUm3GjRuHjRs3IiwsDNHR0d/sT3V1NSwWi/0Ftr29HSdOnEBMTIx9tU3HlRHf4uvri5kzZ6KkpAQ1NTWora1FaWmpSz+PHz+O9vZ2JCcnd6ndHzFu3Dhs2rQJTU1NyM7O/q5z09LSUFxcjLKyMixZssRefvTo0e/uR3BwMEwmE5qamrBs2TI8efLE4wbCRUVFMJvNOHjwIEaOHOly3Gg0ws/PD48ePfL4yU5nMjIycPLkSbx48cK+ygb4ujpMrVZ7DHJ05nvniDvdeVbupKSkIDg4GHfv3sXixYs7revj4+MSGDp79iyamprQv3//bvfF0e+a+0REREQ/CwM3RPRXCQkJQUFBAfLz83H06FHMmDEDpaWlGDNmDIxGI2bPno2oqCi0traivr4et2/fRnl5OQBg/fr1OH/+PAwGAwoLC5GQkACr1YoLFy4gLy8Per0ey5YtQ2VlJQwGA5YvX47ExER8+fIFz549w8WLF7FixQqnl0WtVov09HSsWbPGnlWqoaHBKSV4fHw8AGDv3r0IDAyEv78/oqOjO12Rk5ubi82bN2PatGkICAjA5MmTnY5PmTIFZWVlGDt2LJYuXYqhQ4dCoVDg+fPnuHz5MsaPH48JEyZ0+36npKRg/vz5mDNnDmpra2EwGKDRaPDy5Utcu3YNCQkJWLhwodtzR48eDYPBgPz8fLx//x6DBw/G9evXcfjw4S5dOysrC/Hx8Rg8eDB69eqFp0+foqSkBDqdzinjlqPy8nJs2LABJpMJAwYMwI0bN+zHVCoVBg0ahL59+2L9+vVYvXo1Hj9+bN87yWKx4ObNm9BoNJ2mjF63bh3OnDmDtLQ0rF27FqGhoSgrK8PZs2dRXFyMoKCgLo3PUWBgIHQ6HU6fPo2MjAyEhoZCq9W6pDDvTHeelTs9e/bE9u3bkZOTg9bWVphMJoSHh6O5uRl1dXVobm7G7t27AXwNphw4cAB6vR6JiYm4desWtmzZ8kOfCn7L75r7RERERD/Nn94dmYjoV/CU9UhE5MOHD9KnTx+JjY2VtrY2ERGpq6uT7OxsCQ8PF4VCIREREZKeni579uxxOrexsVFyc3MlIiJCFAqFREZGSnZ2tlgsFnudd+/eSVFRkQwcOFCUSqUEBQVJQkKCLF++3CmDFP6XMWjXrl0SExMjCoVC9Hq9lJWVufS5pKREoqOjxdfXVwCI2WwWEddMTI6GDx8uAGT69Oluj3/+/Fm2bt0qSUlJ4u/vLz179hS9Xi8LFiyQBw8e/ND99dSf/fv3S3Jysmg0GgkICJCYmBiZNWuW1NbWdnqu1WqV3NxcCQ4OFrVaLaNGjZKGhoYuZZXatm2bDB8+XLRarSiVSunTp4/MnTtXnjx54jIOWyYkWwYmd38d+3bq1ClJS0uTf/75R1Qqleh0OjGZTFJVVdVpv0RE7ty5I1lZWRIUFCRKpVKSkpLsz9QRuphVSkSkqqpKBg0aJCqVSgBITk6O05iam5ud6nvKqNWVZ+WOp/auXLkimZmZEhoaKgqFQqKioiQzM1PKy8vtdd68eSNz586V8PBwUavVMmLECKmpqZHU1FRJTU2117NllXI81yYnJ0c0Go1LuW38jro693U6nWRmZnY6biIiIqJfzUdE5PeGioiICPj6eciiRYuwY8eOP90VIiIiIiLyUkwHTkRERERERETkpRi4ISIiIiIiIiLyUtycmIjoD+GXqkRERERE9C1ccUNERERERERE5KUYuCEiIiIiIiIi8lIM3BAREREREREReSkGboiIiIiIiIiIvBQDN0REREREREREXoqBGyIiIiIiIiIiL8XADRERERERERGRl2LghoiIiIiIiIjISzFwQ0RERERERETkpf4LRlXG+2XuE/wAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bayesien_all_utility_mean = []\n",
    "aligned_all_utility_mean = []\n",
    "omniscient_all_utility_mean = []\n",
    "utility_opt_non_adaptive_all_utility_mean = []\n",
    "reward_opt_non_adaptive_all_utility_mean = []\n",
    "uniform_sampling_all_utility_mean = []\n",
    "uniform_model_all_utility_mean = []\n",
    "\n",
    "bayesien_all_utility_std = []\n",
    "aligned_all_utility_std = []\n",
    "omniscient_all_utility_std = []\n",
    "utility_opt_non_adaptive_all_utility_std = []\n",
    "reward_opt_non_adaptive_all_utility_std = []\n",
    "uniform_sampling_all_utility_std = []\n",
    "uniform_model_all_utility_std = []\n",
    "\n",
    "for rf_idx,receptive_field in enumerate(rf_values):\n",
    "    bayesien_all_utility = []\n",
    "    aligned_all_utility = []\n",
    "\n",
    "    omniscient_all_utility = []\n",
    "    utility_opt_non_adaptive_all_utility = []\n",
    "    reward_opt_non_adaptive_all_utility = []\n",
    "    uniform_model_all_utility = []\n",
    "    uniform_sampling_all_utility = []\n",
    "\n",
    "    for goal_color in range(num_colors):\n",
    "        \n",
    "        bayesien_all_utility += list(np.array(DICT_UTIL[lambd][goal_color, receptive_field]))\n",
    "        \n",
    "        aligned_all_utility += list(np.array(DICT_UTIL['aligned'][goal_color, receptive_field]))\n",
    "\n",
    "        # Baselines\n",
    "        omniscient_all_utility += list(np.array(DICT_UTIL['omniscient'][goal_color, receptive_field]))\n",
    "\n",
    "        utility_opt_non_adaptive_all_utility += list(np.array(DICT_UTIL['utility_opt_non_adaptive'][goal_color, receptive_field]))\n",
    "        reward_opt_non_adaptive_all_utility += list(np.array(DICT_UTIL['reward_opt_non_adaptive'][goal_color, receptive_field]))\n",
    "        \n",
    "        uniform_sampling_all_utility += list(np.array(DICT_UTIL['uniform_sampling'][goal_color, receptive_field]))\n",
    "        uniform_model_all_utility += list(np.array(DICT_UTIL['uniform_model'][goal_color, receptive_field]))\n",
    "\n",
    "    \n",
    "    bayesien_all_utility_mean.append(np.mean(bayesien_all_utility))\n",
    "    aligned_all_utility_mean.append(np.mean(aligned_all_utility))\n",
    "\n",
    "    omniscient_all_utility_mean.append(np.mean(omniscient_all_utility))\n",
    "    utility_opt_non_adaptive_all_utility_mean.append(np.mean(utility_opt_non_adaptive_all_utility))\n",
    "    reward_opt_non_adaptive_all_utility_mean.append(np.mean(reward_opt_non_adaptive_all_utility))\n",
    "    uniform_sampling_all_utility_mean.append(np.mean(uniform_sampling_all_utility))\n",
    "    uniform_model_all_utility_mean.append(np.mean(uniform_model_all_utility))\n",
    "\n",
    "    bayesien_all_utility_std.append(np.std(bayesien_all_utility))\n",
    "    aligned_all_utility_std.append(np.std(aligned_all_utility))\n",
    "\n",
    "    omniscient_all_utility_std.append(np.std(omniscient_all_utility))\n",
    "    utility_opt_non_adaptive_all_utility_std.append(np.std(utility_opt_non_adaptive_all_utility))\n",
    "    reward_opt_non_adaptive_all_utility_std.append(np.std(reward_opt_non_adaptive_all_utility))\n",
    "    uniform_sampling_all_utility_std.append(np.std(uniform_sampling_all_utility))\n",
    "    uniform_model_all_utility_std.append(np.std(uniform_model_all_utility))\n",
    "\n",
    "    ## Student T-test to assess that two teachers select demonstrations with significantly different utilities in average\n",
    "    t_statistic, p_value = stats.ttest_ind(uniform_model_all_utility, bayesien_all_utility)\n",
    "\n",
    "    print('p-value = ', p_value)\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(10, 5))\n",
    "colors = [np.array([149, 183, 226]) / 255, 'blue', np.array([52, 85, 156]) / 255, 'yellowgreen']\n",
    "\n",
    "# plt.title(f'Utility')\n",
    "\n",
    "bar_width = 0.1\n",
    "x_pos = np.arange(len(np.array(rf_values_basic + ['full_obs']).astype(str)))\n",
    "\n",
    "plt.bar(x_pos, omniscient_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(omniscient_all_utility_std) / np.sqrt(len(omniscient_all_utility)), color=['k']*4, label=f'Omniscient')\n",
    "\n",
    "plt.bar(x_pos + bar_width, aligned_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(aligned_all_utility_std) / np.sqrt(len(aligned_all_utility)), color=['fuchsia']*4, label=f'Aligned')\n",
    "plt.bar(x_pos + 2 * bar_width, bayesien_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(bayesien_all_utility_std) / np.sqrt(len(bayesien_all_utility)), color=['tomato']*4, label=f'Rational ($\\lambda={lambd}$)')\n",
    "\n",
    "plt.bar(x_pos + 3 * bar_width, utility_opt_non_adaptive_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(utility_opt_non_adaptive_all_utility_std) / np.sqrt(len(utility_opt_non_adaptive_all_utility)), color=['cyan']*4, label=f'Utility_opt_non_adaptive')\n",
    "plt.bar(x_pos + 4 * bar_width, reward_opt_non_adaptive_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(reward_opt_non_adaptive_all_utility_std) / np.sqrt(len(reward_opt_non_adaptive_all_utility)), color=['blue']*4, label=f'Reward_opt_non_adaptive')\n",
    "\n",
    "plt.bar(x_pos + 5 * bar_width, uniform_sampling_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(uniform_sampling_all_utility_std) / np.sqrt(len(uniform_sampling_all_utility)), color=['gray']*4, label=f'Uniform sampling')\n",
    "plt.bar(x_pos + 6 * bar_width, uniform_model_all_utility_mean, width=bar_width, align='center', yerr=1.96 * np.array(uniform_model_all_utility_std) / np.sqrt(len(uniform_model_all_utility)), color=['lightgray']*4, label=f'Uniform model')\n",
    "\n",
    "plt.xticks(x_pos + 1.5 * bar_width, np.array(rf_values_basic + ['full_obs']).astype(str), fontsize=12)\n",
    "plt.xlabel('Receptive field size of the learner', fontsize=12)\n",
    "plt.ylabel('Mean utility', fontsize=12)\n",
    "plt.legend(loc='upper left', bbox_to_anchor=(1, 1.02), fontsize=12);"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ISIR",
   "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.11.3"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
