{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "from tianshou.data import Batch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n"
     ]
    }
   ],
   "source": [
    "from argo.models.protagonist import DQNPolicy\n",
    "from argo.datasets.sepsis import get_patient_dataset, get_judge_dataset\n",
    "from argo.library.evaluation import wis_clinician, jstf, full_vs_partial_context, get_action_counts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "_ = sns.set_style(\"darkgrid\")\n",
    "_ = torch.manual_seed(5568)\n",
    "_ = np.random.seed(5568)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "discount = 0.99\n",
    "action_dim = 25\n",
    "device = torch.device(\"cuda:0\")\n",
    "seeds = [202302, 667495, 114159, 965751, 448102]\n",
    "train_dict = torch.load(\"./assets/data/sepsis/train_dict.pt\", map_location=device)\n",
    "val_dict = torch.load(\"./assets/data/sepsis/val_dict.pt\", map_location=device)\n",
    "test_dict = torch.load(\"./assets/data/sepsis/test_dict.pt\", map_location=device)\n",
    "clinician = torch.load(\"./assets/models/clinician/clinician.pt\", map_location=device)[\"model\"]\n",
    "results_dir = Path(\"./results/\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evaluation of Sepsis Treatment Policy\n",
    "\n",
    "This section evaluates the effectivness of policies in treating sepsis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Judge models (6 and 4 arguments versions)\n",
    "judge = torch.load(\"./assets/models/judge/judge.pt\", map_location=device).eval()\n",
    "judge_4arg = torch.load(\"./assets/models/judge/judge.4.pt\", map_location=device).eval()\n",
    "\n",
    "# Argumentator model (6 arguments version)\n",
    "argumentator = torch.load(\"./assets/models/argumentator/6/argumentator.debate-minimax.pt\", map_location=device)[\"model\"].eval()\n",
    "argumentator._deterministic_eval = True\n",
    "\n",
    "# Argumentator model (4 arguments version)\n",
    "argumentator_4arg = torch.load(\"./assets/models/argumentator/4/argumentator.debate-minimax.pt\", map_location=device)[\"model\"].eval()\n",
    "argumentator_4arg._deterministic_eval = True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Results of task policy training using 6-arguments debate (apart from l00, which is the *baseline*)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "protagonist_l00_jstf  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/6/l00/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l25_jstf  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/6/l25/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l50_jstf  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/6/l50/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l75_jstf  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/6/l75/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l100_jstf = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/6/l100/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Results of task policy training using 4-arguments debate (apart from l00, which is the *baseline*, same as in 6-arguments case, copied here for convenience)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "protagonist_l00_jstf_4arg  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/4/l00/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l25_jstf_4arg  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/4/l25/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l50_jstf_4arg  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/4/l50/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l75_jstf_4arg  = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/4/l75/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l100_jstf_4arg = [torch.load(f\"./assets/models/protagonist/ddqn/justifiable/4/l100/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Results of task policy training using judge with access to the full state (apart from l00, which is the *baseline*, same as in 6-arguments case, copied here for convenience)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "protagonist_l00_full_state  = [torch.load(f\"./assets/models/protagonist/ddqn/full_state/l00/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l25_full_state  = [torch.load(f\"./assets/models/protagonist/ddqn/full_state/l25/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l50_full_state  = [torch.load(f\"./assets/models/protagonist/ddqn/full_state/l50/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l75_full_state  = [torch.load(f\"./assets/models/protagonist/ddqn/full_state/l75/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]\n",
    "protagonist_l100_full_state = [torch.load(f\"./assets/models/protagonist/ddqn/full_state/l100/protagonist-s{s}.pt\", map_location=device)[\"model\"].eval() for s in seeds]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Qualitative Analysis\n",
    "\n",
    "In this section, we perform different analysis pertaining to patient mortality, justifiability and overall policy quality."
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Dose Excess for Different Justifiability Levels\n",
    "\n",
    "To start with, we first show the dose excess for each of the values of lambda in a single plot for intravenous fluids (IV) and vasopressors (VC)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_raw = pd.read_csv(\"./assets/data/sepsis/sepsis_final_data_raw.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_filtered = data_raw[(data_raw[\"r:reward\"] != 0) & (data_raw[\"o:SOFA\"] >= 0) & (data_raw[\"o:SOFA\"] <= 15)]\n",
    "data_ids = data_filtered[\"traj\"].tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, filter_ids=data_ids, batch_size=128, use_dem=True, mask=False, num_workers=0)\n",
    "iv_median = torch.tensor([0.0, 30.0, 85.0, 320.0, 946.0]).repeat_interleave(5).to(device)\n",
    "vc_median = torch.tensor([0.0, 0.04, 0.13, 0.27, 0.68]).repeat(5).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_excess_mortality(protagonist: DQNPolicy, label: str, seed: int, medication: str = \"iv\", bins: int = 7):\n",
    "    excess_count = torch.empty((0, ), dtype=torch.float32, device=device)\n",
    "    excess_mortality = torch.empty((0, ), dtype=torch.float32, device=device)\n",
    "\n",
    "    for s, a_true, r, _, _ in dataloader:\n",
    "        s, r = s.to(device), r.to(device)\n",
    "        a_true = a_true.argmax(dim=-1).float().to(device)\n",
    "        a_prot = torch.tensor(protagonist(Batch(obs=s.flatten(end_dim=1), info={})).act.reshape(a_true.shape), device=device).float()\n",
    "\n",
    "        mask = (r == 0)\n",
    "        s, r, a_true, a_prot = s[~mask], r[~mask], a_true[~mask], a_prot[~mask]\n",
    "\n",
    "        # calculate dose excess of clinician from the AI policy \n",
    "        doses = iv_median if medication == \"iv\" else vc_median\n",
    "        for a in range(action_dim): a_true[a_true == a], a_prot[a_prot == a] = doses[a], doses[a]\n",
    "        excess = (a_true - a_prot)\n",
    "        excess_count = torch.cat((excess_count, excess))\n",
    "\n",
    "        # calculate observed mortality\n",
    "        mortality = (r == -1.0).int()\n",
    "        excess_mortality = torch.cat((excess_mortality, mortality))\n",
    "\n",
    "    df = pd.DataFrame(torch.cat((excess_count[:, None], excess_mortality[:, None]), dim=-1).cpu().numpy(), columns=[\"excess\", \"mortality\"])\n",
    "    df[\"excess\"] = pd.cut(df[\"excess\"], bins=bins, include_lowest=True, precision=2)\n",
    "    df[\"excess\"] = df[\"excess\"].map(lambda x: x.mid)\n",
    "    df[\"label\"], df[\"seed\"] = label, seed\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# IV (6-arguments case)\n",
    "mortality_vc_l00 = [get_excess_mortality(protagonist=protagonist_l00_jstf[i], medication=\"vc\", bins=5, label=\"λ=0.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l25 = [get_excess_mortality(protagonist=protagonist_l25_jstf[i], medication=\"vc\", bins=5, label=\"λ=0.25\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l50 = [get_excess_mortality(protagonist=protagonist_l50_jstf[i], medication=\"vc\", bins=5, label=\"λ=0.50\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l75 = [get_excess_mortality(protagonist=protagonist_l75_jstf[i], medication=\"vc\", bins=5, label=\"λ=0.75\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l100 = [get_excess_mortality(protagonist=protagonist_l100_jstf[i], medication=\"vc\", bins=5, label=\"λ=1.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc = pd.concat(mortality_vc_l00 + mortality_vc_l25 + mortality_vc_l50 + mortality_vc_l75 + mortality_vc_l100)\n",
    "mortality_vc.to_csv(results_dir / \"protagonist_mortality_vc.csv\", index=False)\n",
    "\n",
    "# VC (6-arguments case)\n",
    "mortality_iv_l00 = [get_excess_mortality(protagonist=protagonist_l00_jstf[i], medication=\"iv\", bins=7, label=\"λ=0.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l25 = [get_excess_mortality(protagonist=protagonist_l25_jstf[i], medication=\"iv\", bins=7, label=\"λ=0.25\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l50 = [get_excess_mortality(protagonist=protagonist_l50_jstf[i], medication=\"iv\", bins=7, label=\"λ=0.50\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l75 = [get_excess_mortality(protagonist=protagonist_l75_jstf[i], medication=\"iv\", bins=7, label=\"λ=0.75\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l100 = [get_excess_mortality(protagonist=protagonist_l100_jstf[i], medication=\"iv\", bins=7, label=\"λ=1.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv = pd.concat(mortality_iv_l00 + mortality_iv_l25 + mortality_iv_l50 + mortality_iv_l75 + mortality_iv_l100)\n",
    "mortality_iv.to_csv(results_dir / \"protagonist_mortality_iv.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# IV (4-arguments case)\n",
    "mortality_vc_l00_4arg = [get_excess_mortality(protagonist=protagonist_l00_jstf_4arg[i], medication=\"vc\", bins=5, label=\"λ=0.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l25_4arg = [get_excess_mortality(protagonist=protagonist_l25_jstf_4arg[i], medication=\"vc\", bins=5, label=\"λ=0.25\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l50_4arg = [get_excess_mortality(protagonist=protagonist_l50_jstf_4arg[i], medication=\"vc\", bins=5, label=\"λ=0.50\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l75_4arg = [get_excess_mortality(protagonist=protagonist_l75_jstf_4arg[i], medication=\"vc\", bins=5, label=\"λ=0.75\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_l100_4arg = [get_excess_mortality(protagonist=protagonist_l100_jstf_4arg[i], medication=\"vc\", bins=5, label=\"λ=1.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_vc_4arg = pd.concat(mortality_vc_l00_4arg + mortality_vc_l25_4arg + mortality_vc_l50_4arg + mortality_vc_l75_4arg + mortality_vc_l100_4arg)\n",
    "mortality_vc_4arg.to_csv(results_dir / \"protagonist_mortality_vc_4arg.csv\", index=False)\n",
    "\n",
    "# VC (4-arguments case)\n",
    "mortality_iv_l00_4arg = [get_excess_mortality(protagonist=protagonist_l00_jstf_4arg[i], medication=\"iv\", bins=7, label=\"λ=0.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l25_4arg = [get_excess_mortality(protagonist=protagonist_l25_jstf_4arg[i], medication=\"iv\", bins=7, label=\"λ=0.25\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l50_4arg = [get_excess_mortality(protagonist=protagonist_l50_jstf_4arg[i], medication=\"iv\", bins=7, label=\"λ=0.50\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l75_4arg = [get_excess_mortality(protagonist=protagonist_l75_jstf_4arg[i], medication=\"iv\", bins=7, label=\"λ=0.75\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_l100_4arg = [get_excess_mortality(protagonist=protagonist_l100_jstf_4arg[i], medication=\"iv\", bins=7, label=\"λ=1.0\", seed=seed) for i, seed in enumerate(seeds)]\n",
    "mortality_iv_4arg = pd.concat(mortality_iv_l00_4arg + mortality_iv_l25_4arg + mortality_iv_l50_4arg + mortality_iv_l75_4arg + mortality_iv_l100_4arg)\n",
    "mortality_iv_4arg.to_csv(results_dir / \"protagonist_mortality_iv_4arg.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Action Distribution\n",
    "\n",
    "To better understand the peculiarities of learned policies, we plot their action distribution."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_raw = pd.read_csv(\"./assets/data/sepsis/sepsis_final_data_raw.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, batch_size=128, use_dem=True, mask=True, shuffle=False, num_workers=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_filtered = data_raw[(data_raw[\"r:reward\"] != 0) & (data_raw[\"o:SOFA\"] >= 5) & (data_raw[\"o:SOFA\"] <= 15)]\n",
    "ids = data_filtered[\"traj\"].tolist()\n",
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, filter_ids=ids, batch_size=256, use_dem=True, mask=True, num_workers=0, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3377Zfjw4Rk7dmx++9vftj1eLpdzzTXXpKmpKcOHD89JJ52UZ555puo1/vjHP+bss8/O3nvvnX333Tfnn39+Xn311ao1jz/+eI499tgMGzYsY8aMycyZM7vi8gAAAACgx+pwQwRgk1WqwdEOL730Uo455pj07ds3M2fOzLx583Luuedm6623blszc+bM3Hrrrbn44otz++23Z8stt8yECRPyxhtvtK0555xzsnTp0syePTs33HBDHn744Vx44YVtj69evToTJkzIDjvskDvvvDOTJ0/Oddddl+9973vtThEAAAAA9BYdumUWwCati2+ZNXPmzGy//faZNm1a27mdd9657f+Xy+XMmTMnp556ag466KAkyZVXXpnRo0fnxz/+cQ499NAsW7Ys999/f77//e9n2LBhSZILLrggp5xySiZPnpztttsuP/zhD7NmzZpcfvnlqa+vz8c//vE89thjmT17do466qguvWYAAAAA6ClMiADF1cUTIj/96U8zdOjQnHHGGRk1alT+7u/+Lrfffnvb43/4wx+ycuXKjB49uu1c//79s9dee2XhwoVJkoULF2arrbZqa4YkyejRo1NXV5fFixcnSRYtWpR999039fX1bWuampry9NNP56WXXmpf0AAAAADQS2iIAIVVKnX8aG1tzerVq6uO1tbWDX6+5cuX57vf/W4++tGPZtasWTnmmGMyderU3HXXXUmSlStXJkkaGhqqntfQ0JDm5uYkSXNzcwYMGFD1+GabbZatt9667fnNzc1pbGysWvPWx2+9DgAAAAAUjVtmAXTAjBkzct1111WdmzRpUk4//fR3rS2Xyxk6dGjOOuusJMkee+yRJ598MnPnzs24ceO6JF4AAAAAKCoNEaCwSjXYQ2TixIkZP3581bm336rq7QYOHJhBgwZVndtll13yL//yL22PJ0lLS0u23XbbtjUtLS0ZMmRIkvWTHqtWrap6jTfffDMvvfRS2/MbGxvfNQny1sfvnBwBAAAAgKJwyyygsGpxy6z6+vr069ev6nivhsjee++dp59+uurcM888kx133DFJstNOO2XgwIFZsGBB2+OrV6/Ob37zm4wcOTJJMnLkyLz88stZsmRJ25oHH3ww69aty/Dhw5MkI0aMyMMPP5w1a9a0rXnggQfysY99LFtvvXVtkgcAAAAAmxgNEaCw6kqlDh/tceKJ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z3L11Vfn1ltvzQsvvFA1hr127dpMnDgxa9asydy5c3PFFVfkrrvuyrXXXtu2Zvny5Zk4cWL222+//OAHP8iJJ56YCy64IPfff//GJakDxo8fn9tvvz133XVXli1blosvvjivvfZaDj/88CTJ5MmTc9VVV7WtP+aYY/LHP/4xl112WZ5++un8/Oc/z4wZM3Lcccd1eewA9CxqCgC1oJ4A4JZZQGFtbEOjI1599dV8+ctfztSpU/Otb32r7fwrr7ySO+64I9OnT8+oUaOSrG+QHHLIIVm0aFFGjBiRX/7yl1m6dGlmz56dxsbG7L777jnzzDMzffr0TJo0KfX19Zk7d2522mmnnHfeeUmSQYMG5ZFHHsnNN9+c/fffv0uv9ZBDDsmqVaty7bXXZuXKldl9991z0003tY2jP/fcc6mrq/TlP/zhD2fWrFmZNm1aDjvssGy33XY54YQTcvLJJ3dp3AD0PGoKALWgngCgIQIUVnc0RC655JKMGTMmo0ePrmqILFmyJGvWrMno0aPbzg0aNCg77LBDW0Nk0aJF2W233arub9vU1JSLL744S5cuzR577JFFixa1NVTevubyyy/v/IvbgOOPPz7HH3/8Bh+79dZb33Vu5MiRuf322zs7LAA2QWoKALWgngAUm4YIQAe0tramtbW16lx9ff0G7yc7b968/O53v8v3v//9dz3W3Nycvn37Zquttqo639DQkJUrV7ateedmf299/OfWrF69Oq+//nq22GKLdl4hAAAAAPQOGiJAYZXS8QmRGTNm5Lrrrqs6N2nSpJx++ulV55577rlcdtll+ed//udsvvnmHf68AAAAAED7aIgAhVWLW2ZNnDgx48ePrzq3oemQRx99NC0tLW2b9SXrN0n/9a9/ndtuuy2zZs3KmjVr8vLLL1dNibS0tGTgwIFJ1k96LF68uOp1m5ubk6RqzVvn3r6mX79+pkMAAAAAKDQNEaCwatEQea/bY73TJz/5ydxzzz1V577yla9kl112ycknn5wPf/jD6du3bxYsWJCDDz44SfLUU09lxYoVGTFiRJJkxIgRueGGG9LS0pKGhoYkyQMPPJB+/fpl1113bVvzi1/8ourzPPDAA22vAQAAAABFpSECFFZXbqrer1+/7LbbblXnPvCBD+RDH/pQ2/kjjjgiV1xxRbbeeuv069cvU6dOzciRI9uaGU1NTdl1110zefLkfPnLX87KlStz9dVX57jjjmtryhx99NG57bbbcuWVV+aII47Igw8+mHvvvTczZszosmsFAAAAgJ5IQwSghzj//PNTV1eXM844I62trWlqaspFF13U9nifPn1yww035OKLL85RRx2VLbfcMuPGjcsZZ5zRtmbnnXfOjBkzMm3atMyZMyfbb799pk6dmv333787LgkAAAAAegwNEaCwunBAZINuvfXWqo8333zzXHTRRVVNkHfacccdM3PmzPd93f322y933313LUIEAAAAgF5DQwQorK68ZRYAAAAA0L00RIDC0hABAAAAgOKo6+4AAAAAAAAAOpsJEaCwSjEhAgAAAABFoSECFJZbZgEAAABAcWiIAIWlIQIAAAAAxWEPEQAAAAAAoNczIQIUlgkRAAAAACgODRGgsEoaIgAAAABQGBoiQGHV6YcAAAAAQGHYQwQAAAAAAOj1TIgAhVUXIyIAAAAAUBQaIkBh2VQdAAAAAIpDQwQoLJuqAwAAAEBxaIgAhWVCBAAAAACKw6bqAAAAAABAr2dCBCgsEyIAAAAAUBwaIkBh2UMEAAAAAIqj3bfMev311/Pwww9n6dKl73rsjTfeyN13312LuAA6XV2p1OEDAAAAANg0tKsh8vTTT+eQQw7J8ccfn7Fjx+b444/PCy+80Pb4K6+8kq985Ss1DxIAAAAAAKAj2tUQmT59ej7+8Y/ngQceyI9+9KN88IMfzDHHHJMVK1Z0VnwAnaauBgcAAAAAsGlo1+/zFi5cmLPOOisDBgzIX/3VX+WGG25IU1NTjjvuuCxfvryzYgToFKVSqcMHAAAAALBpaFdD5PXXX89mm1X2YS+VSpkyZUoOOOCAHH/88XnmmWdqHR9Ap7GHCAAAAAAUx2Z/fknFLrvskt/+9rcZNGhQ1fkLL7wwSXLqqafWLjIAAAAAAIAaadeEyKc+9anMmzdvg49deOGFOfTQQ1Mul2sSGEBnqyt1/AAAAAAANg3taohMnDgxM2fOfM/HL7744jz++OMdDgqgK5Rq8D8AAAAAYNPQrltmAfQm9gABAAAAgOJo14QIAAAAAADApsiECFBY9gABAAAAgOLQEAEKyx4gAAAAAFAcGiJAYdlDBAAAAACKQ0MEKCy3zAIAAACA4rCpOgAAAAAA0OuZEAEKq+SWWQAAAABQGBoiQGHV2VQdAAAAAApDQwQoLHuIAAAAAEBx2EMEAAAAAADo9UyIAIVlDxEAAAAAKA4TIkBh1aXU4aM9vvOd72Ts2LHZe++9s/fee+eoo47Kfffd1/b4G2+8kSlTpmS//fbLyJEjc/rpp6e5ubnqNVasWJFTTjkle+21V0aNGpWvf/3refPNN6vWPPTQQxk3blyGDh2aT33qU7nzzjs3PkkAAAAA0EtoiACFVVfq+NEe22+/fc4555zceeedueOOO/LJT34yp512Wp588skkyeWXX56f/exnufrqq3PrrbfmhRdeyKRJk9qev3bt2kycODFr1qzJ3Llzc8UVV+Suu+7Ktdde27Zm+fLlmThxYvbbb7/84Ac/yIknnpgLLrgg999/f01yBgAAAACbKg0RgC5y4IEHZsyYMfnoRz+aj33sY/nSl76UD3zgA1m0aFFeeeWV3HHHHTnvvPMyatSoDB06NJdffnkWLlyYRYsWJUl++ctfZunSpfmf//N/Zvfdd8+YMWNy5pln5rbbbktra2uSZO7cudlpp51y3nnnZdCgQTn++ONz8MEH5+abb+6+CwcAAACAHkBDBCisUqnU4WNjrV27NvPmzcuf/vSnjBw5MkuWLMmaNWsyevTotjWDBg3KDjvs0NYQWbRoUXbbbbc0Nja2rWlqasrq1auzdOnStjWjRo2q+lxNTU1trwEAAAAARWVTdaCw6mqwqXpra2vbdMZb6uvrU19fv8H1TzzxRI4++ui88cYb+cAHPpDrr78+u+66ax577LH07ds3W221VdX6hoaGrFy5MknS3Nxc1QxJ0vbxn1uzevXqvP7669liiy02/mIBAAAAYBOmIQIUVi1G5GbMmJHrrruu6tykSZNy+umnb3D9xz72sdx999155ZVX8i//8i8599xz8+1vf7sGkQAAAAAA70dDBKADJk6cmPHjx1ede6/pkLce+6u/+qskydChQ/Pb3/42c+bMyWc/+9msWbMmL7/8ctWUSEtLSwYOHJhk/aTH4sWLq16vubk5SarWvHXu7Wv69etnOgQAAACAQrOHCFBYtdhDpL6+Pv369as63q8h8k7r1q1La2trhg4dmr59+2bBggVtjz311FNZsWJFRowYkSQZMWJEfv/736elpaVtzQMPPJB+/fpl1113bVvz4IMPVn2OBx54oO01AAAAAKCoTIgAhVWLPUTa46qrrsp//a//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lJ7D+6SafFTIRYVcdJ4e1RApfXqP7g6h5sr/+rskK7o7jE6wQ3rfdfXGa0p693XRW914442ZP39+5syZk80337zdz1+16pWsW9cJgW1CSqX130C1tLyScrm7o+l+8lEhF9Xko6Kurnf+sqYjNUU9Wc/7pEIuqslHhVxUqCcbpqZ4n7yTfFTIRYVcVOuMmtKjGiIAXcktszrPNttskz59+rxrc8KWlpY0Nja+73NnzZqVG2+8MbNnz86QIUM26vOXy/GNw3+Si2ryUSEX1eSj515/d9YU/y6qyUeFXFSTjwq56LnX72eUnkMuqslHhVxUyMV6nZEDm6oDhWVT9c5TX1+fPffcs2qzwbc2Hxw5cuR7Pm/mzJn55je/mZtuuinDhg3rilAB6OHUFABqQT0BIDEhAhSYhkbnGj9+fM4999wMHTo0w4cPzy233JLXXnsthx9+eJJk8uTJ2W677XL22WcnWT+Cfu211+aqq67KjjvumJUrVyZJPvCBD+SDH/xgt10HAN1PTQGgFtQTADREAOgUhxxySFatWpVrr702K1euzO67756bbrqpbRz9ueeeS11dZVBx7ty5WbNmTc4444yq15k0aVJOP/30Lo0dgJ5FTQGgFtQTAErlcs+5G5lN1TclvXGj7t54TUnvvq6OWfn63R1+jYFb/F2HX4Paa2mxYWGplDQ29k9zs43YEvl4O7moJh8VdXXrN3CkQj1Zz/ukQi6qyUeFXFSoJxumpnifvJN8VMhFhVxU64yaYkIEKCy3zAIAAACA4tAQAQpLQwQAAAAAiqPuzy8BAAAAAADYtJkQAQqrZEAEAAAAAApDQwQoMB0RAAAAACgKDRGgsEpGRAAAAACgMDREgMLSDgEAAACA4rCpOgAAAAAA0OuZEAEKq2RGBAAAAAAKw4QIUFilUqnDR3v8+te/zhe+8IU0NTVl8ODB+fGPf1z1eLlczjXXXJOmpqYMHz48J510Up555pmqNX/84x9z9tlnZ++9986+++6b888/P6+++mrVmscffzzHHntshg0bljFjxmTmzJkblR8AAAAA6E00RIDCKtXgaI8//elPGTx4cC666KINPj5z5szceuutufjii3P77bdnyy23zIQJE/LGG2+0rTnnnHOydOnSzJ49OzfccEMefvjhXHjhhW2Pr169OhMmTMgOO+yQO++8M5MnT851112X733ve+2MFgAAAAB6F7fMAugiY8aMyZgxYzb4WLlczpw5c3LqqafmoIMOSpJceeWVGT16dH784x/n0EMPzbJly3L//ffn+9//foYNG5YkueCCC3LKKadk8uTJ2W677fLDH/4wa9asyeWXX576+vp8/OMfz2OPPZbZs2fnqKOO6rJrBQAAAICexoQIUFilGvyvVv7whz9k5cqVGT16dNu5/v37Z6+99srChQuTJAsXLsxWW23V1gxJktGjR6euri6LFy9OkixatCj77rtv6uvr29Y0NTXl6aefzksvvVSzeAEAAABgU2NCBCis9u4BsiGtra1pbW2tOldfX1/VkPhLrFy5MknS0NBQdb6hoSHNzc1Jkubm5gwYMKDq8c022yxbb7112/Obm5uz0047Va1pbGxse2zrrbduV1wAAAAA0FuYEAEKqxYTIjNmzMg+++xTdcyYMaO7Lw0AAAAAeAcTIgAdMHHixIwfP77qXHunQ5Jk4MCBSZKWlpZsu+22bedbWloyZMiQJOsnPVatWlX1vDfffDMvvfRS2/MbGxvbJkre8tbHb02KAAAAAEARmRABCqtU6vhRX1+ffv36VR0b0xDZaaedMnDgwCxYsKDt3OrVq/Ob3/wmI0eOTJKMHDkyL7/8cpYsWdK25sEHH8y6desyfPjwJMmIESPy8MMPZ82aNW1rHnjggXzsYx9zuywAAAAACk1DBCisrt5U/dVXX81jjz2Wxx57LMn6jdQfe+yxrFixIqVSKSeccEK+9a1v5Sc/+UmeeOKJTJ48Odtuu20OOuigJMmgQYOy//7752tf+1oWL16cRx55JJdeemkOPfTQbLfddkmSsWPHpm/fvvnqV7+aJ598MvPnz8+cOXPeNcUCAAAAAEXjlllAgXV8U/X2WLJkSU444YS2j6dNm5YkGTduXK644oqcfPLJee2113LhhRfm5Zdfzj777JObbropm2++edtzpk+fnksvvTQnnnhi6urq8ulPfzoXXHBB2+P9+/fPrFmzcskll+Twww/PNttsky9+8Ys56qijuu5CAQAAAKAH0hAB6CL77bdfnnjiifd8vFQq5cwzz8yZZ575nms+9KEP5aqrrnrfzzNkyJB85zvf2eg4AQAAAKA30hABCsxdAwEAAACgKDREgMJq7x4gAAAAAMCmS0MEKDANEQAAAAAoCg0RoMDcMgsAAAAAiqLdDZFVq1bljjvuyKJFi9Lc3JwkaWxszMiRI3P44YdnwIABNQ8SAAAAAACgI9r159GLFy/OZz7zmdx6663p379/9t133+y7777p379/br311nz2s5/Nb3/7286KFaC2SqWOHwAAAADAJqFdEyJTp07NZz7zmUyZMiWld/wisFwu56KLLsrUqVPzve99r6ZBAnQGm6oDAAAAQHG0a0Lk8ccfz4knnviuZkiSlEqlnHjiiXnsscdqFhxA56qrwQEAAAAAbAra9du8xsbG970l1m9/+9s0NjZ2OCgAAAAAAIBaatctsyZMmJCvfe1rWbJkSUaNGtXW/Ghubs6CBQvyv//3/87kyZM7JVCA2nPLLAAAAAAoinY1RI477rhss802ufnmm/Pd7343a9euTZL06dMne+65Z6ZNm5ZDDjmkUwIFqD23vAIAAACAomhXQyRJDjnkkBxyyCFZs2ZNXnzxxSTJNttsk759+9Y8OIDOZFN1AAAAACiOdjdE3tK3b99su+22tYwFAAAAAACgU2x0QwRg02dCBAAAAACKQkMEKDB7iAAAAABAUWiIAAVmQgQAAAAAisKfRwMAAAAAAL2eCRGgsEp6wgAAAABQGBoiQIG5ZRYAAAAAFIWGCFBcJQ0RAAAAACgKDRGgwNwyCwAAAACKwm8DAQAAAACAXs+ECFBYJXuIAAAAAEBhaIgABaYhAgAAAABFoSECFJi7BgIAAABAUfhtIAAAAAAA0OuZEAEKzC2zAAAAAKAoNESAwioZkgMAAACAwtAQAQrMhAgAAAAAFIU/jwYAAAAAAHo9EyJAgZkQAQAAAICi0BABCsyQHAAAAAAUhYYIUFilkgkRAAAAACgKfx4NAAAAAAD0eiZEgAIzIQIAAAAARaEhAhSYITkAAAAAKAq/DQQKrFSDg/dz22235cADD8ywYcNy5JFHZvHixe+7/t57781nPvOZDBs2LGPHjs19993XRZEC0NOpKQDUgnoCUGwaIkBhlVLX4YP3Nn/+/EybNi2nnXZa7rrrrgwZMiQTJkxIS0vLBtf/3//7f3P22Wfn7//+73P33Xfnb/7mb3Laaafl97//fRdHDkBPo6YAUAvqCQB+mwdAp5g9e3Y+//nP54gjjsiuu+6aKVOmZIsttsgdd9yxwfVz5szJ/vvvn//+3/97Bg0alP/xP/5H9thjj3z729/u4sgB6GnUFABqQT0BwB4iQIG55VVnaW1tzaOPPpqJEye2naurq8vo0aOzcOHCDT5n0aJFOemkk6rONTU15cc//nG7P3+plNQVvOVf+s9/3nV1SbncvbH0BPJRIRfV5KOi1EPLYnfWFPVkPe+TCrmoJh8VclGhnmyYmuJ98k7yUSEXFXJRrTNqSo9qiJT/9XfdHUIn2aG7A+gkvfG6euM1Jb33ujpKXjrLiy++mLVr16ahoaHqfENDQ5566qkNPqe5uTmNjY3vWt/c3Nzuzz9gQP92P6e3kotq8lEhF9Xko+fqzpri30U1+aiQi2ryUSEXPZefUXoOuagmHxVyUSEXnafgvWkAAAAAAKAINEQAqLltttkmffr0edfmhC0tLe/6C6u3NDY2vusvrd5vPQDFoKYAUAvqCQCJhggAnaC+vj577rlnFixY0HZu3bp1WbBgQUaOHLnB54wYMSIPPvhg1bkHHnggI0aM6MxQAejh1BQAakE9ASDREAGgk4wfPz6333577rrrrixbtiwXX3xxXnvttRx++OFJksmTJ+eqq65qW3/CCSfk/vvvzz//8z9n2bJl+V//639lyZIlOf7447vrEgDoIdQUAGpBPQGgR22qDkDvccghh2TVqlW59tprs3Llyuy+++656aab2sbLn3vuudTVVfrye++9d6ZPn56rr7463/jGN/LRj340119/fXbbbbfuugQAegg1BYBaUE8AKJXL5XJ3BwEAAAAAANCZ3DILAAAAAADo9TREAAAAAACAXk9DBAAAAAAA6PU0RAAAAAAAgF6vUA2R2267LQceeGCGDRuWI488MosXL+7ukDrs17/+db7whS+kqakpgwcPzo9//OPuDqnDZsyYkSOOOCIjR47MqFGj8sUvfjFPPfVUd4fVYd/5zncyduzY7L333tl7771z1FFH5b777uvusGruxhtvzODBg3PZZZd1dyj0Uu39Wn7vvffmM5/5TIYNG5axY8f2qvdde3Jx++2359hjj80nPvGJfOITn8hJJ53UK+rg221snZ83b14GDx6cL37xi50cYddpby5efvnlTJkyJU1NTRk6dGgOPvjgwr5XkuTmm2/OwQcfnOHDh2fMmDG5/PLL88Ybb3RRtJ1nY75vfOihhzJu3LgMHTo0n/rUp3LnnXd2QaRdQz2ppqZUqCcV6kk19WQ99eTd1JQK9aRCPammplSoJ+t1Wz0pF8S8efPKe+65Z/n73/9++cknnyxfcMEF5X333bfc3Nzc3aF1yM9//vPyN77xjfK//uu/lnfbbbfyv/3bv3V3SB32j//4j+U77rij/Pvf/7782GOPlU8++eTyf/tv/6386quvdndoHfKTn/yk/POf/7z89NNPl5966qnyN77xjfKee+5Z/v3vf9/dodXMb37zm/IBBxxQHjt2bHnq1KndHQ69UHu/lj/yyCPl3XffvTxz5szy0qVLy//0T/9U3nPPPctPPPFEF0dee+3NxVlnnVX+9re/Xf7d735XXrp0afm8884r77PPPuX/9//+XxdH3jk2ts4vX768vP/++5ePPfbY8qmnntpF0Xau9ubijTfeKB9++OHlk08+ufzwww+Xly9fXn7ooYfKjz32WBdH3jnam48f/vCH5aFDh5Z/+MMflpcvX16+//77y3/9139dvvzyy7s48tpr7/eNzz77bHmvvfYqT5s2rbx06dLyrbfeWt59993Lv/jFL7oo4s6jnlRTUyrUkwr1pJp6UqGeVFNTKtSTCvWkmppSoZ5UdFc9KUxD5O///u/LU6ZMaft47dq15aampvKMGTO6Mara6i0NkXdqaWkp77bbbuVf/epX3R1KzX3iE58o33777d0dRk2sXr26/OlPf7r8//1//1/5+OOP1xChU7T3a/mZZ55ZPuWUU6rOHXnkkeWvfe1rnRpnV+hoXXvzzTfLI0eOLN91112dFGHX2ph8vPnmm+WjjjqqfPvtt5fPPffcXvMDR3tz8Z3vfKf8N3/zN+XW1tauCrFLtTcfU6ZMKZ9wwglV56ZNm1Y++uijOzXOrvaXfN945ZVXlg899NCqc//jf/yP8j/+4z92ZmhdQj2ppqZUqCcV6kk19WTDil5PymU15e3Ukwr1pJqaUqGebFhX1pNC3DKrtbU1jz76aEaPHt12rq6uLqNHj87ChQu7MTL+Eq+88kqSZOutt+7mSGpn7dq1mTdvXv70pz9l5MiR3R1OTVxyySUZM2ZM1fsMamljvpYvWrQoo0aNqjrX1NSURYsWdWaona4Wde21117Lm2++2Su+tm5sPq6//vo0NDTkyCOP7Iowu8TG5OKnP/1pRowYkUsuuSSjR4/O5z73udxwww1Zu3ZtV4XdaTYmHyNHjsyjjz7aNra+fPny3HfffRkzZkyXxNyT+Bpa0Vtzkagpb6eeVKgn1dSTjvE1tFpvzYd6UqGeVFNTKtSTjqnV18/NahhTj/Xiiy9m7dq1aWhoqDrf0NDQK/am6M3WrVuXyy+/PHvvvXd222237g6nw5544okcffTReeONN/KBD3wg119/fXbdddfuDqvD5s2bl9/97nf5/ve/392h0IttzNfy5ubmNDY2vmt9c3Nzp8XZFWpR16ZPn55tt922VzQxNyYfDz/8cL7//e/n7rvv7oIIu87G5GL58uV58MEHM3bs2Nx444159tlnM2XKlLz55puZNGlSV4TdaTYmH2PHjs2LL76YY489NuVyOW+++WaOPvrofOELX+iKkHuUDX0NbWxszOrVq/P6669niy226KbIOkY9qaamVKgnFepJNfWkY3prPUnUlLdTTyrUk2pqSoV60jG1qieFaIiw6ZoyZUqefPLJfOc73+nuUGriYx/7WO6+++688sor+Zd/+Zece+65+fa3v71JN0Wee+65XHbZZfnnf/7nbL755t0dDvAXuPHGGzN//vzMmTOnkO/b1atXZ/Lkybn00kszYMCA7g6n25XL5TQ0NOTSSy9Nnz59MnTo0Dz//POZNWvWJv3DxsZ66KGHMmPGjFx00UUZPnx4nn322Vx22WW5/vrrc9ppp3V3eNDjFLmmqCfV1JNq6gm0j3qinrydmlKhntReIRoi22yzTfr06ZOWlpaq8y0tLe/qKtFzXHLJJfn5z3+eb3/729l+++27O5yaqK+vz1/91V8lSYYOHZrf/va3mTNnTi655JJujmzjPfroo2lpacnhhx/edm7t2rX59a9/ndtuuy2//e1v06dPn26MkN5iY76WNzY2vusvrXrD1/6O1LVZs2blxhtvzOzZszNkyJDODLPLtDcfy5cvz3/8x3/k1FNPbTu3bt26JMkee+yRH/3oR/nIRz7SuUF3ko35tzFw4MBsttlmVV+rd9lll6xcuTKtra2pr6/v1Jg708bk45prrslhhx3WdquCwYMH509/+lMuvPDCnHrqqamrK8QdZ5Ns+Gtoc3Nz+vXrt0n/Na96Uk1NqVBPKtSTaupJx/TWepKoKW+nnlSoJ9XUlAr1pGNqVU8KkbH6+vrsueeeWbBgQdu5devWZcGCBb1m/4bepFwu55JLLsm//du/5ZZbbsnOO+/c3SF1mnXr1qW1tbW7w+iQT37yk7nnnnty9913tx1Dhw7N2LFjc/fdd2uGUDMb87V8xIgRefDBB6vOPfDAAxkxYkRnhtrpNrauzZw5M9/85jdz0003ZdiwYV0Rapdobz522WWXd33dOvDAA7Pffvvl7rvv3qSb8Bvzb2PvvffOs88+2/ZDV5I888wzGThw4Cb7g8ZbNiYfr7/++rt+qHirlpXL5c4LtgfyNbSit+YiUVPeTj2pUE+qqScd42totd6aD/WkQj2ppqZUqCcdU7Ovn+3agn0TNm/evPLQoUPLd955Z3np0qXlr33ta+V99923vHLlyu4OrUNWr15d/t3vflf+3e9+V95tt93Ks2fPLv/ud78r/8d//Ed3h7bRLrroovI+++xTfuihh8ovvPBC2/Haa691d2gdMn369PKvfvWr8vLly8uPP/54efr06eXBgweXf/nLX3Z3aDV3/PHHl6dOndrdYdAL/bmv5V/+8pfL06dPb1v/yCOPlPfYY4/yrFmzykuXLi1fe+215T333LP8xBNPdNcl1Ex7czFjxozynnvuWf7Rj35U9bV19erV3XUJNdXefLzTueeeWz711FO7KtxO1d5crFixojxy5MjyJZdcUn7qqafKP/vZz8qjRo0qf/Ob3+yuS6ip9ubj2muvLY8cObL8f/7P/yk/++yz5V/+8pflgw46qHzmmWd20xXUzp/7vnH69OnlL3/5y23rn3322fJee+1V/vrXv15eunRp+dvf/nZ59913L//iF7/orkuoGfWkmppSoZ5UqCfV1JMK9aSamlKhnlSoJ9XUlAr1pKK76kkhbpmVJIccckhWrVqVa6+9NitXrszuu++em266aZMfSVyyZElOOOGEto+nTZuWJBk3blyuuOKK7gqrQ7773e8mSf7hH/6h6vy0adOqbsu0qWlpacm5556bF154If3798/gwYMza9as/PVf/3V3hwabjD/3tfy5556r+suJvffeO9OnT8/VV1+db3zjG/noRz+a66+/Prvttlt3XULNtDcXc+fOzZo1a3LGGWdUvc6kSZNy+umnd2nsnaG9+ejN2puLD3/4w5k1a1amTZuWww47LNttt11OOOGEnHzyyd11CTXV3nyceuqpKZVKufrqq/P8889nwIABOeCAA/KlL32puy6hZv7c940rV67Mc8891/b4zjvvnBkzZmTatGmZM2dOtt9++0ydOjX7779/l8dea+pJ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RN5y6KGHZp999smSJUuyww471ComgK5hug0AAAAACqNDDZEk2X777bP99tvXIhaArqUfAgAAAACF0e49RAAAAAAAADY1HZ4QAdhkuWUWAAAAABSGhghQXPohAAAAAFAYGiJAYRkQAQAAAIDi0BABCqukIwIAAAAAhWFTdQAAAAAAoNczIQIUlgERAAAAACgODRGgsOp0RAAAAACgMDREgMLSDwEAAACA4rCHCAAAAAAA0OuZEAEKy4AIAAAAABSHhghQWCX3zAIAAACAwnDLLKCwSqWOH+2xdu3aXH311TnwwAMzfPjwHHTQQbn++utTLpfb1pTL5VxzzTVpamrK8OHDc9JJJ+WZZ56pep0//vGPOfvss7P33ntn3333zfnnn59XX321as3jjz+eY489NsOGDcuYMWMyc+bMjU0TAAAAAPQKGiIAXWTmzJn57ne/mwsvvDDz58/POeeck5tuuim33npr1Zpbb701F198cW6//fZsueWWmTBhQt544422Neecc06WLl2a2bNn54YbbsjDDz+cCy+8sO3x1atXZ8KECdlhhx1y5513ZvLkybnuuuvyve99r0uvFwAAAAB6Eg0RoLC6ekJk4cKF+Zu/+Zv8t//237LTTjvlM5/5TJqamrJ48eIk66dD5syZk1NPPTUHHXRQhgwZkiuvvDIvvPBCfvzjHydJli1blvvvvz9Tp07NXnvtlX333TcXXHBB5s2bl+effz5J8sMf/jBr1qzJ5Zdfno9//OM59NBD8w//8A+ZPXt2TfMHAAAAAJsSDRGgsEqlUoeP1tbWrF69uupobW3d4OcbOXJkHnzwwTz99NNJ1t/W6pFHHsl//a//NUnyhz/8IStXrszo0aPbntO/f//stddeWbhwYZL1TZWtttoqw4YNa1szevTo1NXVtTVWFi1alH333Tf19fVta5qamvL000/npZdeqm0SAQAAAGATYVN1oLBqsaf6jBkzct1111WdmzRpUk4//fR3rT3llFOyevXqfPazn02fPn2ydu3afOlLX8phhx2WJFm5cmWSpKGhoep5DQ0NaW5uTpI0NzdnwIABVY9vttlm2Xrrrdue39zcnJ122qlqTWNjY9tjW2+99cZeLgAAAABssjREADpg4sSJGT9+fNW5t09mvN29996be+65J1dddVV23XXXPPbYY5k2bVq23XbbjBs3rivCBQAAAIDC0hABCqtUgxGR+vr692yAvNOVV16ZU045JYceemiSZPDgwVmxYkVmzJiRcePGZeDAgUmSlpaWbLvttm3Pa2lpyZAhQ5Ksn/RYtWpV1eu++eabeemll9qe39jY2DZR8pa3Pn5rUgQAAAAAisYeIkBhdfWm6q+//vq7mjB9+vRJuVxOkuy0004ZOHBgFixY0Pb46tWr85vf/CYjR45Msn4fkpdffjlLlixpW/Pggw9m3bp1GT58eJJkxIgRefjhh7NmzZq2NQ888EA+9rGPuV0WAAAAAIWlIQIUVl0NjvY44IADcsMNN+TnP/95/vCHP+Tf/u3fMnv27Bx00EFJ1k+snHDCCfnWt76Vn/zkJ3niiScyefLkbLvttm1rBg0alP333z9f+9rXsnjx4jzyyCO59NJLc+ihh2a77bZLkowdOzZ9+/bNV7/61Tz55JOZP39+5syZ865bewEAAABAkbhlFlBYtbhlVntccMEFueaaazJlypS222IdddRROe2009rWnHzyyXnttddy4YUX5uWXX84+++yTm266KZtvvnnbmunTp+fSSy/NiSeemLq6unz605/OBRdc0PZ4//79M2vWrFxyySU5/PDDs8022+SLX/xijjrqqC69XgAAAADoSTREALpIv3798tWvfjVf/epX33NNqVTKmWeemTPPPPM913zoQx/KVVdd9b6fa8iQIfnOd76z0bECAAAAQG/jlllAYXX1HiJFdNttt+XAAw/MsGHDcuSRR2bx4sXvu/7mm2/OwQcfnOHDh2fMmDG5/PLL88Ybb3RRtAD0ZGoKALWgngAUm4YIUFgaIp1r/vz5mTZtWk477bTcddddGTJkSCZMmJCWlpYNrr/nnnty1VVXZdKkSZk/f34uu+yyzJ8/P9/4xje6OHIAeho1BYBaUE8A0BABCqtUKnX44L3Nnj07n//853PEEUdk1113zZQpU7LFFlvkjjvu2OD6hQsXZu+9987YsWOz0047pampKZ/73Of+7F9sAdD7qSkA1IJ6AoA9RACoudbW1jz66KOZOHFi27m6urqMHj06Cxcu3OBzRo4cmR/+8IdZvHhxhg8fnuXLl+e+++7L3/7t37b785vgqVx/0fPwFvmokItq8lHRU3PQnTVFPVnP+6RCLqrJR4VcVPTUHPgZpft5n1STjwq5qJCLap2Rhx7VEKkr7dLdIXSSHbo7gE5RV/p4d4dQc73132ApH+nuEHokxaXzvPjii1m7dm0aGhqqzjc0NOSpp57a4HPGjh2bF198Mccee2zK5XLefPPNHH300fnCF77Q7s8/YED/jYq7N2pokIu3k48KuagmHz1Xd9YU9aSa90mFXFSTjwq56Ln8jNJzeJ9Uk48KuaiQi87Toxoirese6O4Qaq6+bnTKeba7w6i5Uj6SdeWl3R1GTdWVds2b5d90dxg1t1lpr5SzvLvDqLlSdu74a+iI9CgPPfRQZsyYkYsuuijDhw/Ps88+m8suuyzXX399TjvttHa91qpVr2Tduk4KdBNRKq3/Bqql5ZWUy90dTfeTjwq5qCYfFXV1veeXNbWqKerJet4nFXJRTT4q5KJCPdkwNcX75J3ko0IuKuSiWmfUlB7VEAHoSvohnWebbbZJnz593rU5YUtLSxobGzf4nGuuuSaHHXZYjjzyyCTJ4MGD86c//SkXXnhhTj311NTV/eXbXpXL8Y3Df5KLavJRIRfV5KPnXn931hT/LqrJR4VcVJOPCrnoudfvZ5SeQy6qyUeFXFTIxXqdkQObqgNQc/X19dlzzz2zYMGCtnPr1q3LggULMnLkyA0+5/XXX3/XDxR9+vRJkpR9FwBQWGoKALWgngCQmBABCsyASOcaP358zj333AwdOjTDhw/PLbfcktdeey2HH354kmTy5MnZbrvtcvbZZydJDjjggMyePTt77LFH2zj6NddckwMOOKDthw4AiklNAaAW1BMANESAwrKHSOc65JBDsmrVqlx77bVZuXJldt9999x0001t4+jPPfdc1V9bnXrqqSmVSrn66qvz/PPPZ8CAATnggAPypS99qbsuAYAeQk0BoBbUEwBK5R4042dT9U2HTdU3HTZVf287XnhAh1/jPy75WYdfg9prabFhYamUNDb2T3OzjdgS+Xg7uagmHxV1des3cKRCPVnP+6RCLqrJR4VcVKgnG6ameJ+8k3xUyEWFXFTrjJpiDxEAAAAAAKDXc8ssoLDq3DELAAAAAApDQwQoLHuIAAAAAEBxaIgAhaUfAgAAAADFoSECFJYJEQAAAAAoDpuqAwAAAAAAvZ4JEaCwDIgAAAAAQHFoiACFpR8CAAAAAMWhIQIUlj1EAAAAAKA47CECAAAAAAD0eiZEgMIyIAIAAAAAxaEhAhRWqU5HBAAAAACKQkMEKCx7iAAAAABAcdhDBAAAAAAA6PVMiACFZUIEAAAAAIpDQwQoLP0QAAAAACgODRGgsEyIAAAAAEBx2EMEAAAAAADo9UyIAIVVqjMhAgAAAABFoSECFJZbZgEAAABAcWiIAIWlIQIAAAAAxaEhAhSWhggAAAAAFIdN1QEAAAAAgF7PhAhQWCUtYQAAAAAoDA0RoLDcMgsAAAAAiqPdDZFly5Zl0aJFGTFiRAYNGpRly5Zlzpw5aW1tzWGHHZZRo0Z1RpwANachAgAAAADF0a4bxvziF7/I3/7t3+bKK6/MuHHj8otf/CLHH398nn322axYsSITJkzIggULOitWAAAAAACAjdKuCZFvfvObmTBhQr70pS9l3rx5Oeecc3LMMcfkS1/6UpLkqquuysyZM02JAJsGEyIAAAAAUBjtmhB58sknc/jhhydJPvvZz+bVV1/NwQcf3Pb42LFj88QTT9Q2QoBOUiqVOnwAAAAAAJuGdu8h8tYvAOvq6lJfX5/+/fu3PfbBD34wr7zySu2iA+hEpXa1hAEAAACATVm7fh2444475plnnmn7+Hvf+14+/OEPt3383HPPZeDAgTULDgAAAAAAoBbaNSFyzDHHZN26dW0f77bbblWP/+IXv8gnP/nJ2kQG0Mnc8goAAAAAiqPdDZH3c9ZZZ3UoGICupCECAAAAAMXR7j1EAHoLDREAAAAAKA5bCgMAAAAAAL2eCRGgsEp1JkQAAAAAoCg0RIDCcsssAAAAACgODRGgsPRDAAAAAKA4NESAwjIhAgAAAADFYVN1AAAAAACg1zMhAhSWCREAAAAAKA4NEaCwSnUaIgAAAABQFBoiQGGZEAEAAACA4rCHCAAAAAAA0OuZEAEKy4AIAAAAABSHhghQWG6ZBQAAAADFoSECFJZN1QEAAACgOOwhAgAAAAAA9HoaIkBhlUqlDh/t9fzzz+ecc87Jfvvtl+HDh2fs2LH57W9/2/Z4uVzONddck6ampgwfPjwnnXRSnnnmmarX+OMf/5izzz47e++9d/bdd9+cf/75efXVV6vWPP744zn22GMzbNiwjBkzJjNnztyoHAEAAABAb6EhAhRXqdTxox1eeumlHHPMMenbt29mzpyZefPm5dxzz83WW2/dtmbmzJm59dZbc/HFF+f222/PlltumQkTJuSNN95oW3POOedk6dKlmT17dm644YY8/PDDufDCC9seX716dSZMmJAddtghd955ZyZPnpzrrrsu3/ve9zqeMwAAAADYRNlDBCisrt5TfebMmdl+++0zbdq0tnM777xz2/8vl8uZM2dOTj311Bx00EFJkiuvvDKjR4/Oj3/84xx66KFZtmxZ7r///nz/+9/PsGHDkiQXXHBBTjnllEyePDnbbbddfvjDH2bNmjW5/PLLU19fn49//ON57LHHMnv27Bx11FFde9EAAAAA0EOYEAHogNbW1qxevbrqaG1t3eDan/70pxk6dGjOOOOMjBo1Kn/3d3+X22+/ve3xP/zhD1m5cmVGjx7ddq5///7Za6+9snDhwiTJwoULs9VWW7U1Q5Jk9OjRqaury+LFi5MkixYtyr777pv6+vq2NU1NTXn66afz0ksv1fT6AQAAAGBToSECFFZdqdThY8aMGdlnn32qjhkzZmzw8y1fvjzf/e5389GPfjSzZs3KMccck6lTp+auu+5KkqxcuTJJ0tDQUPW8hoaGNDc3J0mam5szYMCAqsc322yzbL311m3Pb25uTmNjY9Watz5+63UAAAAAoGjcMgsorI3ZFP2dJk6cmPHjx1ede/tkxtuVy+UMHTo0Z511VpJkjz32yJNPPpm5c+dm3LhxHY4FAAAAAHhvJkSAwqrFhEh9fX369etXdbxXQ2TgwIEZNGhQ1blddtklK1asaHs8SVpaWqrWtLS0tE14NDY2ZtWqVVWPv/nmm3nppZfant/Y2PiuSZC3Pn7n5AgAAAAAFIWGCFBYtWiItMfee++dp59+uurcM888kx133DFJstNOO2XgwIFZsGBB2+OrV6/Ob37zm4wcOTJJMnLkyLz88stZsmRJ25oHH3ww69aty/Dhw5MkI0aMyMMPP5w1a9a0rXnggQfysY99LFtvvXX7kgQAAAAAvYSGCEAXOfHEE/Ob3/wmN9xwQ/793/8999xzT26//fYce+yxSdbfwuuEE07It771rfzkJz/JE088kcmTJ2fbbbfNQQcdlCQZNGhQ9t9//3zta1/L4sWL88gjj+TSSy/NoYcemu222y5JMnbs2PTt2zdf/epX8+STT2b+/PmZM2fOu27t1RVuu+22HHjggRk2bFiOPPLIto3f38vLL7+cKVOmpKmpKUOHDs3BBx+c++67r4uiBaAnU1MAqAX1BKDY7CECFFZ7Jzw6avjw4bnuuuvyjW98I9dff3122mmnnH/++TnssMPa1px88sl57bXXcuGFF+bll1/OPvvsk5tuuimbb75525rp06fn0ksvzYknnpi6urp8+tOfzgUXXND2eP/+/TNr1qxccsklOfzww7PNNtvki1/8Yo466qguvd758+dn2rRpmTJlSvbaa6/ccsstmTBhQn70ox+9a+P4JGltbc348ePT0NCQa665Jtttt11WrFiRrbbaqkvjBqDnUVMAqAX1BAANEaCwarGpensdcMABOeCAA97z8VKplDPPPDNnnnnme6750Ic+lKuuuup9P8+QIUPyne98Z6PjrIXZs2fn85//fI444ogkyZQpU/Lzn/88d9xxR0455ZR3rb/jjjvy0ksvZe7cuenbt2+S9bcRAwA1BYBaUE8A0BABCqsuXd8QKYrW1tY8+uijmThxYtu5urq6jB49OgsXLtzgc376059mxIgRueSSS/KTn/wkAwYMyOc+97mcfPLJ6dOnT7s+f6m0/iiyt66/6Hl4i3xUyEU1+ajoqTnozpqinqznfVIhF9Xko0IuKnpqDvyM0v28T6rJR4VcVMhFtc7IQ49qiNTXje7uEDpFKR/p7hA6RV1p1+4OoeY2K+3V3SF0ilJ27u4QKJgXX3wxa9eufdfYeUNDQ5566qkNPmf58uV58MEHM3bs2Nx444159tlnM2XKlLz55puZNGlSuz7/gAH9Nzr23qahQS7eTj4q5KKafPRc3VlT1JNq3icVclFNPirkoufyM0rP4X1STT4q5KJCLjpPj2qIvL72J90dQs1t0edvsq684cK6Kasr7ZJ15aXdHUZN1ZV2zbryk90dRs3VlT6eteXHujuMmutT2r3Dr1Gn296jlMvlNDQ05NJLL02fPn0ydOjQPP/885k1a1a7f9hYteqVrFvXSYFuIkql9d9AtbS8knK5u6PpfvJRIRfV5KOirq73/LKmVjVFPVnP+6RCLqrJR4VcVKgnG6ameJ+8k3xUyEWFXFTrjJrSoxoiAF2pO/YQKYptttkmffr0SUtLS9X5lpaWNDY2bvA5AwcOzGabbVY1er7LLrtk5cqVaW1tTX19/V/8+cvl+MbhP8lFNfmokItq8tFzr787a4p/F9Xko0IuqslHhVz03Ov3M0rPIRfV5KNCLirkYr3OyEFd7V8SYNNQVyp1+GDD6uvrs+eee2bBggVt59at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VerTp4+vTgEA0EKQKQAAM5AnAACby+Vy+boTAAAAAAAAAAAAzYklswAAAAAAAAAAgN+jIAIAAAAAAAAAAPweBREAAAAAAAAAAOD3KIgAAAAAAAAAAAC/Z6mCyNq1a3XrrbcqOjpav/jFL1ReXu7rLjXZhx9+qIcfflgOh0N9+/bVtm3bfN2lJsvLy9OIESMUFxenhIQETZ48WYcOHfJ1t5rs5ZdfVkpKigYNGqRBgwZp5MiReu+993zdLdO98MIL6tu3r55++mlfdwV+qrGf5Vu3btVdd92l6OhopaSk+NXPXWPGYv369Ro1apR+/OMf68c//rHGjRvnFzn4bVeb85s3b1bfvn01efLkZu6h9zR2LE6dOqX58+fL4XAoKipKd955p2V/ViTpd7/7ne68807FxMRo2LBhWrRokc6ePeul3jafq/m98YMPPlBqaqqioqJ0++23a8OGDV7oqXeQJ+7IlAbkSQPyxB15cgF5cikypQF50oA8cUemNCBPLvBZnrgsYvPmza4BAwa4XnvtNdf+/ftdmZmZrvj4eJfT6fR115rk3XffdT377LOu//3f/3X16dPH9dZbb/m6S032H//xH67XX3/d9emnn7r27NnjmjBhgutnP/uZ6/Tp077uWpO8/fbbrnfffdd1+PBh16FDh1zPPvusa8CAAa5PP/3U110zze7du1233HKLKyUlxZWdne3r7sAPNfazfNeuXa5+/fq58vPzXQcOHHD913/9l2vAgAGuffv2ebnn5mvsWDz22GOul156yfXJJ5+4Dhw44HryySddgwcPdv1//9//5+WeN4+rzfmjR4+6hg4d6ho1apRr0qRJXupt82rsWJw9e9Y1fPhw14QJE1w7d+50HT161PXBBx+49uzZ4+WeN4/GjsemTZtcUVFRrk2bNrmOHj3q2r59u+vf/u3fXIsWLfJyz83X2N8bP/vsM9fAgQNdOTk5rgMHDriKiopc/fr1c73//vte6nHzIU/ckSkNyJMG5Ik78qQBeeKOTGlAnjQgT9yRKQ3Ikwa+yhPLFETuu+8+1/z5843H9fX1LofD4crLy/Nhr8zlLwWR76qqqnL16dPH9de//tXXXTHdj3/8Y9f69et93Q1T1NTUuO644w7X//t//881evRoCiJoFo39LJ8+fbpr4sSJbvt+8YtfuObMmdOs/fSGpubauXPnXHFxca433nijmXroXVczHufOnXONHDnStX79etcTTzzhNxccjR2Ll19+2XXbbbe5amtrvdVFr2rseMyfP981ZswYt305OTmu+++/v1n76W0/5PfGJUuWuJKTk932/frXv3b9x3/8R3N2zSvIE3dkSgPypAF54o48uTyr54nLRaZ8G3nSgDxxR6Y0IE8uz5t5Yokls2pra/Xxxx8rMTHR2Ge325WYmKjS0lIf9gw/xFdffSVJCg4O9nFPzFNfX6/Nmzfr66+/VlxcnK+7Y4oFCxZo2LBhbj9ngJmu5rO8rKxMCQkJbvscDofKysqas6vNzoxcO3PmjM6dO+cXn61XOx6rVq1SSEiIfvGLX3ijm15xNWPx5z//WbGxsVqwYIESExP185//XLm5uaqvr/dWt5vN1YxHXFycPv74Y2Pa+tGjR/Xee+9p2LBhXulzS8JnaAN/HQuJTPk28qQBeeKOPGkaPkPd+et4kCcNyBN3ZEoD8qRpzPr8bG1in1qsf/7zn6qvr1dISIjb/pCQEL+4N4U/O3/+vBYtWqRBgwapT58+vu5Ok+3bt0/333+/zp49q+uvv16rVq1Sr169fN2tJtu8ebM++eQTvfbaa77uCvzY1XyWO51OhYaGXtLe6XQ2Wz+9wYxcW7p0qTp37uwXRcyrGY+dO3fqtdde08aNG73QQ++5mrE4evSoSkpKlJKSohdeeEGfffaZ5s+fr3PnzmnKlCne6HazuZrxSElJ0T//+U+NGjVKLpdL586d0/3336+HH37YG11uUS73GRoaGqqamhp98803uu6663zUs6YhT9yRKQ3IkwbkiTvypGn8NU8kMuXbyJMG5Ik7MqUBedI0ZuWJJQoiuHbNnz9f+/fv18svv+zrrpiiR48e2rhxo7766iv96U9/0hNPPKGXXnrpmi6KfP7553r66af14osvqk2bNr7uDoAf4IUXXtCWLVtUWFhoyZ/bmpoaZWRkaOHCherUqZOvu+NzLpdLISEhWrhwoVq1aqWoqCh98cUXWrNmzTV9sXG1PvjgA+Xl5Wnu3LmKiYnRZ599pqefflqrVq3SI4884uvuAS2OlTOFPHFHnrgjT4DGIU/Ik28jUxqQJ+azREGkY8eOatWqlaqqqtz2V1VVXVJVQsuxYMECvfvuu3rppZfUtWtXX3fHFIGBgfqXf/kXSVJUVJQ++ugjFRYWasGCBT7u2dX7+OOPVVVVpeHDhxv76uvr9eGHH2rt2rX66KOP1KpVKx/2EP7iaj7LQ0NDL/lLK3/47G9Krq1Zs0YvvPCCCgoKFBkZ2Zzd9JrGjsfRo0f1j3/8Q5MmTTL2nT9/XpLUv39//fGPf9RNN93UvJ1uJlfzbyMsLEytW7d2+6zu2bOnKisrVVtbq8DAwGbtc3O6mvFYsWKF7r33XmOpgr59++rrr79WVlaWJk2aJLvdEivOSrr8Z6jT6VS7du2u6b/mJU/ckSkNyJMG5Ik78qRp/DVPJDLl28iTBuSJOzKlAXnSNGbliSVGLDAwUAMGDNCOHTuMfefPn9eOHTv85v4N/sTlcmnBggV666239Pvf/17du3f3dZeazfnz51VbW+vrbjTJT37yE7355pvauHGjsUVFRSklJUUbN26kGALTXM1neWxsrEpKStz2FRcXKzY2tjm72uyuNtfy8/P129/+VqtXr1Z0dLQ3uuoVjR2Pnj17XvK5deutt2rIkCHauHHjNV2Ev5p/G4MGDdJnn31mXHRJ0pEjRxQWFnbNXmhcdDXj8c0331xyUXExy1wuV/N1tgXiM7SBv46FRKZ8G3nSgDxxR540DZ+h7vx1PMiTBuSJOzKlAXnSNKZ9fjbqFuzXsM2bN7uioqJcGzZscB04cMA1Z84cV3x8vKuystLXXWuSmpoa1yeffOL65JNPXH369HEVFBS4PvnkE9c//vEPX3ftqs2dO9c1ePBg1wcffOA6ceKEsZ05c8bXXWuSpUuXuv7617+6jh496tq7d69r6dKlrr59+7r+8pe/+Lprphs9erQrOzvb192AH/q+z/LHH3/ctXTpUqP9rl27XP3793etWbPGdeDAAddzzz3nGjBggGvfvn2+OgXTNHYs8vLyXAMGDHD98Y9/dPtsramp8dUpmKqx4/FdTzzxhGvSpEne6m6zauxYHD9+3BUXF+dasGCB69ChQ6533nnHlZCQ4Prtb3/rq1MwVWPH47nnnnPFxcW5/ud//sf12Wefuf7yl7+4kpKSXNOnT/fRGZjn+35vXLp0qevxxx832n/22WeugQMHup555hnXgQMHXC+99JKrX79+rvfff99Xp2Aa8sQdmdKAPGlAnrgjTxqQJ+7IlAbkSQPyxB2Z0oA8aeCrPLHEklmSdM899+jkyZN67rnnVFlZqX79+mn16tXX/JTEiooKjRkzxnick5MjSUpNTdXixYt91a0meeWVVyRJDz30kNv+nJwct2WZrjVVVVV64okndOLECQUFBalv375as2aN/u3f/s3XXQOuGd/3Wf7555+7/eXEoEGDtHTpUi1fvlzPPvusbr75Zq1atUp9+vTx1SmYprFjsW7dOtXV1WnatGlurzNlyhRNnTrVq31vDo0dD3/W2LH40Y9+pDVr1ignJ0f33nuvunTpojFjxmjChAm+OgVTNXY8Jk2aJJvNpuXLl+uLL75Qp06ddMstt+jRRx/11SmY5vt+b6ysrNTnn39uHO/evbvy8vKUk5OjwsJCde3aVdnZ2Ro6dKjX+2428sQdmdKAPGlAnrgjTxqQJ+7IlAbkSQPyxB2Z0oA8aeCrPLG5XBabWwMAAAAAAAAAACzHOqVIAAAAAAAAAABgWRREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL9HQQQAAAAAAAAAAPg9CiIAAAAAAAAAAMDvURABAAAAAAAAAAB+j4IIAAAAAAAAAADwexREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL9HQQQAAAAAAAAAAPg9CiIAAAAAAAAAAMDvURABAAAAAAAAAAB+j4IIAAAAAAAAAADwexREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL9HQQQAAAAAAAAAAPg9CiIAAAAAAAAAAMDvURABAAAAAAAAAAB+j4IIAAAAAAAAAADwexREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL9HQQQAAAAAAAAAAPg9CiIAAAAAAAAAAMDvURABAAAAAAAAAAB+j4IIAAAAAAAAAADwexREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL9HQQQAAAAAAAAAAPg9CiIAAAAAAAAAAMDvURABAAAAAAAAAAB+j4IIAAAAAAAAAADwexREAAAAAAAAAACA36MgAgAAAAAAAAAA/B4FEQAAAAAAAAAA4PcoiAAAAAAAAAAAAL/X2tcdAABfsd3Rv8mv4frfT0zoCQDgWkaeAADMQqYAAMxAnnjWogoi512HfN0F09ltPSUd93U3mkE3ufSZrzthKptu8rtzki6e1xFfd8N0Nt1sxovAT9WeL/Z1F0wXaE+U/+bJEV93wnQ23SyXDvu6G6azqYfOu/b7uhums9t6N+0FyBO/9fW5P/m6C6a7vvWdcumor7thOpu6++31pL+eV71rr6+7YbpWtsimvwiZ4rdOn/ujr7tguhta3+W3n1HnXQd83Q3T2W29/O53ebutt9+dk2TC9YlEnlxBiyqIAIBX2UgHAIAJyBMAgFnIFACAGcgTj7iHCAAAAAAAAAAA8HvMEAFgXRTLAQBmIE8AAGYhUwAAZiBPPKIgAsC6mD4IADADeQIAMAuZAgAwA3niEQURANZFNgAAzECeAADMQqYAAMxAnnjEPUQAAAAAAAAAAIDfY4YIAOuyUy4HAJiAPAEAmIVMAQCYgTzxiIIIAOsiGwAAZiBPAABmIVMAAGYgTzyiIALAurjBFADADOQJAMAsZAoAwAzkiUfcQwQAAAAAAAAAAPg9ZogAsC6K5QAAM5AnAACzkCkAADOQJx5REAFgXYQDAMAM5AkAwCxkCgDADOSJRyyZBcC6bLambwAAkCcAALN4OVM+/PBDPfzww3I4HOrbt6+2bdvmdtzlcmnFihVyOByKiYnRuHHjdOTIEbc2X375pWbMmKFBgwYpPj5es2bN0unTp93a7N27V6NGjVJ0dLSGDRum/Pz8S/qydetW3XXXXYqOjlZKSoree++9Rp0LAOBbuEbxiIIIAOuymbABAECeAADM4uVM+frrr9W3b1/NnTv3ssfz8/NVVFSkefPmaf369Wrbtq3S0tJ09uxZo83MmTN14MABFRQUKDc3Vzt37lRWVpZxvKamRmlpaerWrZs2bNigjIwMrVy5Uq+++qrR5m9/+5tmzJih++67Txs3btRtt92mRx55RJ9++mnjTggAcAHXKB5REAEAAAAAALCgYcOG6dFHH9Xtt99+yTGXy6XCwkJNmjRJSUlJioyM1JIlS3TixAljJsnBgwe1fft2ZWdna+DAgYqPj1dmZqY2b96sL774QpK0adMm1dXVadGiRerdu7eSk5P10EMPqaCgwHivwsJCDR06VL/61a8UERGhX//61+rfv79eeukl7wwEAMAyKIgAsC6mDwIAzECeAADMYkKm1NbWqqamxm2rra1tdFeOHTumyspKJSYmGvuCgoI0cOBAlZaWSpJKS0vVvn17RUdHG20SExNlt9tVXl4uSSorK1N8fLwCAwONNg6HQ4cPH1Z1dbXRJiEhwe39HQ6HysrKGt1vAIC4RrkCCiIArIvpgwAAM5AnAACzmJApeXl5Gjx4sNuWl5fX6K5UVlZKkkJCQtz2h4SEyOl0SpKcTqc6derkdrx169YKDg42nu90OhUaGurW5uLjb7/Od9t8+30AAI3ENYpHrX3dAQDwGT+udgMAvIg8AQCYxYRMSU9P1/jx4932fXt2BgDAArhG8YiCCAAAAAAAgJ8IDAw0pQASFhYmSaqqqlLnzp2N/VVVVYqMjJR0YabHyZMn3Z537tw5VVdXG88PDQ29ZKbHxccXZ4Vcrk1VVdUls0YAAGgqlswCYF12EzYAAMgTAIBZWlCmhIeHKywsTDt27DD21dTUaPfu3YqLi5MkxcXF6dSpU6qoqDDalJSU6Pz584qJiZEkxcbGaufOnaqrqzPaFBcXq0ePHgoODjbalJSUuL1/cXGxYmNjzTshALCSFpQnLY0fnxoAfA/WUwQAmIE8AQCYxcuZcvr0ae3Zs0d79uyRdOFG6nv27NHx48dls9k0ZswYPf/883r77be1b98+ZWRkqHPnzkpKSpIkRUREaOjQoZozZ47Ky8u1a9cuLVy4UMnJyerSpYskKSUlRQEBAZo9e7b279+vLVu2qLCw0G1ZrzFjxmj79u168cUXdfDgQf3mN79RRUWFRo8efXXjCABWxzWKRyyZBcC6WE8RAGAG8gQAYBYvZ0pFRYXGjBljPM7JyZEkpaamavHixZowYYLOnDmjrKwsnTp1SoMHD9bq1avVpk0b4zlLly7VwoULNXbsWNntdt1xxx3KzMw0jgcFBWnNmjVasGCBhg8fro4dO2ry5MkaOXKk0WbQoEFaunSpli9frmeffVY333yzVq1apT59+nhhFADAD3GN4hEFEQAAAAAAAAsaMmSI9u3b5/G4zWbT9OnTNX36dI9tOnTooGXLll3xfSIjI/Xyyy9fsc3dd9+tu++++8odBgCgiVgyC4B1MX0QAGAGH+TJhx9+qIcfflgOh0N9+/bVtm3b3I67XC6tWLFCDodDMTExGjdunI4cOeLW5ssvv9SMGTM0aNAgxcfHa9asWTp9+rRbm71792rUqFGKjo7WsGHDlJ+ff0lftm7dqrvuukvR0dFKSUnRe++91/gTAgBcwDUKAMAM5IlHFEQAWJfN1vQNAAAf5MnXX3+tvn37au7cuZc9np+fr6KiIs2bN0/r169X27ZtlZaWprNnzxptZs6cqQMHDqigoEC5ubnauXOnsrKyjOM1NTVKS0tTt27dtGHDBmVkZGjlypV69dVXjTZ/+9vfNGPGDN13333auHGjbrvtNj3yyCP69NNPG31OAABxjQIAMAd54hEFEQDWRbUcAGAGH+TJsGHD9Oijj+r222+/5JjL5VJhYaEmTZqkpKQkRUZGasmSJTpx4oQxk+TgwYPavn27srOzNXDgQMXHxyszM1ObN2/WF198IUnatGmT6urqtGjRIvXu3VvJycl66KGHVFBQYLxXYWGhhg4dql/96leKiIjQr3/9a/Xv318vvfRS408KAMA1CgDAHOSJRxREAAAAAD9y7NgxVVZWKjEx0dgXFBSkgQMHqrS0VJJUWlqq9u3bKzo62miTmJgou92u8vJySVJZWZni4+MVGBhotHE4HDp8+LCqq6uNNgkJCW7v73A4VFZW1lynBwAAAABXjZuqA7AuP57+BwDwIhPypLa2VrW1tW77AgMD3YoRP1RlZaUkKSQkxG1/SEiInE6nJMnpdKpTp05ux1u3bq3g4GDj+U6nU+Hh4W5tQkNDjWPBwcFyOp3Gvsu9DwCgkbhGAQCYgTzxyJQZIi6Xy4yXAQDvYvpgi0OeALgmmZAneXl5Gjx4sNuWl5fn/XPxE+QJgGsW1ygtDpkC4JpEnnhkSkEkOjpaBw8eNOOlAMB7uMFUi0OeALgmmZAn6enp2rVrl9uWnp5+Vd0JCwuTJFVVVbntr6qqMmZzhIaG6uTJk27Hz507p+rqauP5oaGhl8z0uPj426/z3Tbffh9fIU8AXLO4RmlxyBQA1yTyxKNGLZmVk5Nz2f319fV64YUX1KFDB0nSU0891eSOAUCz89/P9haPPAHgV0zIk6tdHutywsPDFRYWph07dqhfv36SpJqaGu3evVsPPPCAJCkuLk6nTp1SRUWFoqKiJEklJSU6f/68YmJiJEmxsbFavny56urqFBAQIEkqLi5Wjx49FBwcbLQpKSnRuHHjjPcvLi5WbGysKefyfcgTAH6HaxSfIVMA+BXyxKNGFUR+//vfKzIyUkFBQW77XS6XDh48qLZt28rmx9UjAIA5yBMAaJrTp0/rs88+Mx4fO3ZMe/bsUXBwsLp166YxY8bo+eef17/8y78oPDxcK1asUOfOnZWUlCRJioiI0NChQzVnzhzNnz9fdXV1WrhwoZKTk9WlSxdJUkpKilatWqXZs2drwoQJ2r9/vwoLC92+CBozZoweeughvfjiixo2bJi2bNmiiooKLViwwCvjQJ4AAMxCpgCANTSqIPLYY4/p1Vdf1RNPPKGEhARj/4ABA7R48WL16tXL9A4CQLMxZdFAXA3yBIBf8UGeVFRUaMyYMcbji3/VmpqaqsWLF2vChAk6c+aMsrKydOrUKQ0ePFirV69WmzZtjOcsXbpUCxcu1NixY2W323XHHXcoMzPTOB4UFKQ1a9ZowYIFGj58uDp27KjJkydr5MiRRptBgwZp6dKlWr58uZ599lndfPPNWrVqlfr06eOFUSBPAPghrlF8hkwB4FfIE48aVRCZOHGifvKTn+jxxx/Xrbfeqscee8yYPg8A1xz+usdnyBMAfsUHeTJkyBDt27fP43Gbzabp06dr+vTpHtt06NBBy5Ytu+L7REZG6uWXX75im7vvvlt33333lTvcTMgTAH6HaxSfIVMA+BXyxKNG14piYmK0YcMGnTx5UiNGjNCnn37KlEEA1yabCRuuGnkCwG+QJz5FngDwK2SKT5EpAPwGeeJRo2aIXHTDDTfomWee0ebNmzV+/HjV19eb3S8AgAWQJwAAM5AnAACzkCkA4N+uqiByUXJysgYPHqyKigp169bNrD4BgHfwlz4tBnkC4JpGnrQY5AmAax6Z0mKQKQCuaeSJR00qiEhS165d1bVrVzP6AgDeRTa0KOQJgGsWedKikCcArmlkSotCpgC4ZpEnHjW5IAIA1yyq5QAAM5AnAACzkCkAADOQJx41+qbqAAAAAAAAAAAA1xpmiACwLorlAAAzkCcAALOQKQAAM5AnHjFDBIBl2WxN3wAAIE8AAGYhUwAAZvB2ntTX12v58uW69dZbFRMTo6SkJK1atUoul8to43K5tGLFCjkcDsXExGjcuHE6cuSI2+t8+eWXmjFjhgYNGqT4+HjNmjVLp0+fdmuzd+9ejRo1StHR0Ro2bJjy8/Mb1VcKIgAsy2azNXkDAIA8AQCYhUwBAJjB23mSn5+vV155RVlZWdqyZYtmzpyp1atXq6ioyK1NUVGR5s2bp/Xr16tt27ZKS0vT2bNnjTYzZ87UgQMHVFBQoNzcXO3cuVNZWVnG8ZqaGqWlpalbt27asGGDMjIytHLlSr366qs/uK8URAAAAAAAAAAAwFUpLS3Vbbfdpp/97GcKDw/XXXfdJYfDofLyckkXZocUFhZq0qRJSkpKUmRkpJYsWaITJ05o27ZtkqSDBw9q+/btys7O1sCBAxUfH6/MzExt3rxZX3zxhSRp06ZNqqur06JFi9S7d28lJyfroYceUkFBwQ/uKwURAJbFdHQAgBnIEwCAWcgUAIAZzMiT2tpa1dTUuG21tbWXfb+4uDiVlJTo8OHDki4sa7Vr1y799Kc/lSQdO3ZMlZWVSkxMNJ4TFBSkgQMHqrS0VNKFokr79u0VHR1ttElMTJTdbjcKK2VlZYqPj1dgYKDRxuFw6PDhw6qurv5BY8NN1QFYlp2rBQCACcgTAIBZyBQAgBnMyJO8vDytXLnSbd+UKVM0derUS9pOnDhRNTU1uvvuu9WqVSvV19fr0Ucf1b333itJqqyslCSFhIS4PS8kJEROp1OS5HQ61alTJ7fjrVu3VnBwsPF8p9Op8PBwtzahoaHGseDg4O89LwoiACyLaw0AgBnIEwCAWcgUAIAZzMiT9PR0jR8/3m3ft2dmfNvWrVv15ptvatmyZerVq5f27NmjnJwcde7cWampqU3vjIkoiACwLK41AABmIE8AAGYhUwAAZjAjTwIDAz0WQL5ryZIlmjhxopKTkyVJffv21fHjx5WXl6fU1FSFhYVJkqqqqtS5c2fjeVVVVYqMjJR0YabHyZMn3V733Llzqq6uNp4fGhpqzCi56OLjizNFvg/3EAEAAAAAAAAAAFflm2++ke0701JatWoll8slSQoPD1dYWJh27NhhHK+pqdHu3bsVFxcn6cJ9SE6dOqWKigqjTUlJic6fP6+YmBhJUmxsrHbu3Km6ujqjTXFxsXr06PGDlsuSKIgAsDCbzdbkrTE+/PBDPfzww3I4HOrbt6+2bdvmdtzlcmnFihVyOByKiYnRuHHjdOTIEbc2X375pWbMmKFBgwYpPj5es2bN0unTp93a7N27V6NGjVJ0dLSGDRum/Pz8S/qydetW3XXXXYqOjlZKSoree++9Rp0LAKCBt/MEAOC/yBQAgBm8nSe33HKLcnNz9e677+rYsWN66623VFBQoKSkJKM/Y8aM0fPPP6+3335b+/btU0ZGhjp37my0iYiI0NChQzVnzhyVl5dr165dWrhwoZKTk9WlSxdJUkpKigICAjR79mzt379fW7ZsUWFh4SVLe10JBREAlmWzNX1rjK+//lp9+/bV3LlzL3s8Pz9fRUVFmjdvntavX6+2bdsqLS1NZ8+eNdrMnDlTBw4cUEFBgXJzc7Vz505lZWUZx2tqapSWlqZu3bppw4YNysjI0MqVK/Xqq68abf72t79pxowZuu+++7Rx40bddttteuSRR/Tpp5827oQAAJK8nycAAP9FpgAAzODtPMnMzNSdd96p+fPn65577tEzzzyjkSNHavr06UabCRMmaPTo0crKytJ9992nr7/+WqtXr1abNm2MNkuXLlXPnj01duxYTZw4UYMGDdKCBQuM40FBQVqzZo2OHTum4cOHa/HixZo8ebJGjhz5g/vKPUQAWJa3LxaGDRumYcOGXfaYy+VSYWGhJk2aZFTGlyxZosTERG3btk3Jyck6ePCgtm/frtdee03R0dGSLgTOxIkTlZGRoS5dumjTpk2qq6vTokWLFBgYqN69e2vPnj0qKCgwwqGwsFBDhw7Vr371K0nSr3/9axUXF+ull15yCxkAwA/Dl08AALOQKQAAM3g7T9q1a6fZs2dr9uzZHtvYbDZNnz7drUjyXR06dNCyZcuu+F6RkZF6+eWXr7qvzBABgCaora1VTU2N21ZbW9vo1zl27JgqKyuVmJho7AsKCtLAgQNVWloqSSotLVX79u2NYogkJSYmym63q7y8XJJUVlam+Ph4t5teORwOHT58WNXV1UabhIQEt/d3OBwqKytrdL8BAAAAAACAawUzRABYlhnr6+bl5WnlypVu+6ZMmaKpU6c26nUqKyslSSEhIW77Q0JC5HQ6JUlOp1OdOnVyO966dWsFBwcbz3c6nQoPD3drExoaahwLDg6W0+k09l3ufQAAjcN67QAAs5ApAAAzkCeeURABYFlmZEN6evolN2769uwMAID/41oDAGAWMgUAYAbyxDMKIgAsy4xqeWBgoCkFkLCwMElSVVWVOnfubOyvqqpSZGSkpAszPU6ePOn2vHPnzqm6utp4fmho6CUzPS4+vjgr5HJtqqqqLpk1AgD4YfjrKwCAWcgUAIAZyBPPuIcIALQA4eHhCgsL044dO4x9NTU12r17t+Li4iRJcXFxOnXqlCoqKow2JSUlOn/+vGJiYiRJsbGx2rlzp+rq6ow2xcXF6tGjh4KDg402JSUlbu9fXFys2NjY5jo9AAAAAAAAwOcoiACwLJut6VtjnD59Wnv27NGePXskXbiR+p49e3T8+HHZbDaNGTNGzz//vN5++23t27dPGRkZ6ty5s5KSkiRJERERGjp0qObMmaPy8nLt2rVLCxcuVHJysrp06SJJSklJUUBAgGbPnq39+/dry5YtKiwsdFvWa8yYMdq+fbtefPFFHTx4UL/5zW9UUVGh0aNHmzOwAGAx3s4TAID/IlMAAGYgTzxjySwAluXtinBFRYXGjBljPM7JyZEkpaamavHixZowYYLOnDmjrKwsnTp1SoMHD9bq1avVpk0b4zlLly7VwoULNXbsWNntdt1xxx3KzMw0jgcFBWnNmjVasGCBhg8fro4dO2ry5MkaOXKk0WbQoEFaunSpli9frmeffVY333yzVq1apT59+nhhFADA//AXRgAAs5ApAAAzkCeeURABYFneXk9xyJAh2rdvn8fjNptN06dP1/Tp0z226dChg5YtW3bF94mMjNTLL798xTZ333237r777it3GADwg7A+LwDALGQKAMAM5IlnFIsAAAAAAAAAAIDfY4YIAMuiWA4AMAN5AgAwC5kCADADeeIZBREAlkU4AADMQJ4AAMxCpgAAzECeeEZBBIBlsZ4iAMAM5AkAwCxkCgDADOSJZxREAFgW2QAAMAN5AgAwC5kCADADeeJZiyqI2G09fd2FZtLN1x1oFjbd5OsumM4fz0mSbLrZ110AvCrQnujrLjQTf82Tm33dhWZhUw9fd6FZ2G29fd0FwGuub32nr7vQLGzq7usuNAt/vZ701/NqZYv0dRcAr7qh9V2+7kKz8NfPKLutl6+70Cz88Xd5fzwnNK8WVRCpO7/L110wXYB9sKTjvu5GM+gmlz7zdSdMZdNNOu864OtumO5CiP/D191oBjc2+RWYPui/as//P193wXSB9n+Tv/4sn3ft93UnTGe39ZZLR3zdDdPZdLPf5b/U9D+IIE/819nz7/u6C6ZrY/+p/PX6xH/zxD8/d/01J5v8GmSK3zp97o++7oLpLhR5/DNT6l0f+7oTpmtlG+B3n7023ezH3+U1DXniWYsqiACAN5ENAAAzkCcAALOQKQAAM5AnnlEQAWBZZAMAwAzkCQDALGQKAMAM5Ilndl93AAAAAAAAAAAAoLkxQwSAZbGeIgDADOQJAMAsZAoAwAzkiWcURABYFtkAADADeQIAMAuZAgAwA3niGQURAJZlJxwAACYgTwAAZiFTAABmIE884x4iAAAAAAAAAADA7zFDBIBlsZ4iAMAM5AkAwCxkCgDADOSJZ8wQAWBZNlvTNwAAyBMAgFm8mSn19fVavny5br31VsXExCgpKUmrVq2Sy+Uy2rhcLq1YsUIOh0MxMTEaN26cjhw54vY6X375pWbMmKFBgwYpPj5es2bN0unTp93a7N27V6NGjVJ0dLSGDRum/Pz8pgwTAOB7cI3iGQURAJZls9mavAEAQJ4AAMzizUzJz8/XK6+8oqysLG3ZskUzZ87U6tWrVVRU5NamqKhI8+bN0/r169W2bVulpaXp7NmzRpuZM2fqwIEDKigoUG5urnbu3KmsrCzjeE1NjdLS0tStWzdt2LBBGRkZWrlypV599VVzBg0AcAmuUTyjIAIAAAAAAGAxpaWluu222/Szn/1M4eHhuuuuu+RwOFReXi7pwuyQwsJCTZo0SUlJSYqMjNSSJUt04sQJbdu2TZJ08OBBbd++XdnZ2Ro4cKDi4+OVmZmpzZs364svvpAkbdq0SXV1dVq0aJF69+6t5ORkPfTQQyooKPDZuQMArIuCCADLYvogAMAM5AkAwCxmZEptba1qamrcttra2kveKy4uTiUlJTp8+LCkC8ta7dq1Sz/96U8lSceOHVNlZaUSExON5wQFBWngwIEqLS2VdKGo0r59e0VHRxttEhMTZbfbjcJKWVmZ4uPjFRgYaLRxOBw6fPiwqqurzR9EAADXKFfATdUBWJYff7YDALyIPAEAmMWMTMnLy9PKlSvd9k2ZMkVTp0512zdx4kTV1NTo7rvvVqtWrVRfX69HH31U9957rySpsrJSkhQSEuL2vJCQEDmdTkmS0+lUp06d3I63bt1awcHBxvOdTqfCw8Pd2oSGhhrHgoODm3K6AIDL4BrFMwoiACzLn9dDBAB4D3kCADCLGZmSnp6u8ePHu+379uyMi7Zu3ao333xTy5YtU69evbRnzx7l5OSoc+fOSk1NbXI/AAC+wzWKZxREAFgW2QAAMAN5AgAwixmZEhgYeNkCyHctWbJEEydOVHJysiSpb9++On78uPLy8pSamqqwsDBJUlVVlTp37mw8r6qqSpGRkZIuzPQ4efKk2+ueO3dO1dXVxvNDQ0ONGSUXXXx8caYIAMBcXKN4xj1EAAAAAAAALOabb7655C+IW7VqJZfLJUkKDw9XWFiYduzYYRyvqanR7t27FRcXJ+nCfUhOnTqliooKo01JSYnOnz+vmJgYSVJsbKx27typuro6o01xcbF69OjBclkAAK+jIALAsmx2W5M3AADIEwCAWbyZKbfccotyc3P17rvv6tixY3rrrbdUUFCgpKSkC32x2TRmzBg9//zzevvtt7Vv3z5lZGSoc+fORpuIiAgNHTpUc+bMUXl5uXbt2qWFCxcqOTlZXbp0kSSlpKQoICBAs2fP1v79+7VlyxYVFhZesqwXAMA8XKN4xpJZACyL9RQBAGbwdp7U19frN7/5jTZt2iSn02ms9T558mSjLy6XS88995z++7//W6dOndKgQYM0b9483XzzzcbrfPnll1q4cKHeeecd2e123XHHHZo9e7ZuuOEGo83evXu1YMECffTRR+rUqZNGjx6tCRMmePV8AcBKvJkpmZmZWrFihebPn28sizVy5Eg98sgjRpsJEybozJkzysrK0qlTpzR48GCtXr1abdq0MdosXbpUCxcu1NixY408yczMNI4HBQVpzZo1WrBggYYPH66OHTtq8uTJGjlypNfOFQCshu+8PKMgAsCyCAcAgBm8nSf5+fl65ZVX9Mwzz6hXr16qqKjQU089paCgII0ZM8ZoU1RUpMWLFys8PFwrVqxQWlqatmzZYnyJNXPmTFVWVqqgoEB1dXWaNWuWsrKytGzZMkkXlkVJS0tTQkKC5s+fr08//VSzZs1S+/bt+RILAJqJNzOlXbt2mj17tmbPnn3F/kyfPl3Tp0/32KZDhw5GdngSGRmpl19++ar7CgBoHL7z8owlswAAAIBrSGlpqW677Tb97Gc/U3h4uO666y45HA6Vl5dLujA7pLCwUJMmTVJSUpIiIyO1ZMkSnThxQtu2bZMkHTx4UNu3b1d2drYGDhyo+Ph4ZWZmavPmzfriiy8kSZs2bVJdXZ0WLVqk3r17Kzk5WQ899JAKCgp8du4AAAAA0BQURABYls3W9A0AAG/nSVxcnEpKSnT48GFJF5a12rVrl376059Kko4dO6bKykolJiYazwkKCtLAgQNVWloq6UJRpX379oqOjjbaJCYmym63G4WVsrIyxcfHKzAw0GjjcDh0+PBhVVdXX9VYAQCujGsUAIAZyBPPWDILgGUxfRAAYAYz8qS2tla1tbVu+wIDA92KERdNnDhRNTU1uvvuu9WqVSvV19fr0Ucf1b333itJqqyslCSFhIS4PS8kJEROp1OS5HQ61alTJ7fjrVu3VnBwsPF8p9Op8PBwtzahoaHGseDg4Ks9XQCAB1yjAADMQJ54RkEEgGXZ7IQDAKDpzMiTvLw8rVy50m3flClTNHXq1Evabt26VW+++aaWLVumXr16ac+ePcrJyTFurg4AuHZxjQIAMAN54hkFEQAAAMDH0tPTNX78eLd9l5sdIklLlizRxIkTlZycLEnq27evjh8/rry8PKWmpiosLEySVFVVpc6dOxvPq6qqUmRkpKQLMz1Onjzp9rrnzp1TdXW18fzQ0FBjRslFFx9fnCkCAAAAANcS7iECwLJsNluTNwAAzMiTwMBAtWvXzm3zVBD55ptvLsmgVq1ayeVySZLCw8MVFhamHTt2GMdramq0e/duxcXFSbpwH5JTp06poqLCaFNSUqLz588rJiZGkhQbG6udO3eqrq7OaFNcXKwePXqwXBYANBOuUQAAZiBPPKMgAsCyCAcAgBm8nSe33HKLcnNz9e677+rYsWN66623VFBQoKSkJKM/Y8aM0fPPP6+3335b+/btU0ZGhjp37my0iYiI0NChQzVnzhyVl5dr165dWrhwoZKTk9WlSxdJUkpKigICAjR79mzt379fW7ZsUWFh4SUzWQAA5uEaBQBgBvLEM5bMAmBZ/vzhDgDwHm/nSWZmplasWKH58+cby2KNHDlSjzzyiNFmwoQJOnPmjLKysnTq1CkNHjxYq1evVps2bYw2S5cu1cKFCzV27FjZ7XbdcccdyszMNI4HBQVpzZo1WrBggYYPH66OHTtq8uTJGjlypFfPFwCshGsUAIAZyBPPKIgAAAAA15B27dpp9uzZmj17tsc2NptN06dP1/Tp0z226dChg5YtW3bF94qMjNTLL7981X0FAAAAgJaEgggAy7KxaCAAwATkCQDALGQKAMAM5IlnFEQAWBbTBwEAZiBPAABmIVMAAGYgTzxrdEHk4MGDKisrU2xsrCIiInTw4EEVFhaqtrZW9957rxISEpqjnwBgOsLBt8gTAP6CPPE9MgWAvyBTfIs8AeAvyBPPGlUQef/99zV58mTdcMMNOnPmjFauXKknnnhCkZGROn/+vNLS0rRmzRoCAsC1gXDwGfIEgF8hT3yKTAHgV8gUnyFPAPgV8sSjRq0m9tvf/lZpaWn64IMPlJOTo5kzZ+qXv/ylCgoK9Pvf/15paWnKz89vrr4CAPwEeQIAMAuZAgAwA3kCANbQqILI/v37NXz4cEnS3XffrdOnT+vOO+80jqekpGjfvn3m9hAAmonNZmvyhqtDngDwJ+SJb5EpAPwJmeI75AkAf0KeeNboe4hcHAy73a7AwEAFBQUZx2644QZ99dVX5vUOAJqRrVElYZiNPAHgL8gT3yNTAPgLMsW3yBMA/oI88axRQ3PjjTfqyJEjxuNXX31VP/rRj4zHn3/+ucLCwkzrHAA0J6rlvkOeAPAn5IlvkSkA/AmZ4jvkCQB/Qp541qgZIg888IDOnz9vPO7Tp4/b8ffff18/+clPzOkZAMBvkScAALOQKQAAM5AnAGANjS6IXMljjz3WpM4AgDf5c7W7pSNPAPgT8sS3yBQA/oRM8R3yBIA/IU88YzUxAJbl7emD9fX1Wr58uW699VbFxMQoKSlJq1atksvlMtq4XC6tWLFCDodDMTExGjdunNu0bUn68ssvNWPGDA0aNEjx8fGaNWuWTp8+7dZm7969GjVqlKKjozVs2DDl5+df9TgBAK6M6egAALOQKQAAM5AnnlEQAWBZNrutyVtj5Ofn65VXXlFWVpa2bNmimTNnavXq1SoqKnJrU1RUpHnz5mn9+vVq27at0tLSdPbsWaPNzJkzdeDAARUUFCg3N1c7d+5UVlaWcbympkZpaWnq1q2bNmzYoIyMDK1cuVKvvvpq0wcNAHAJb+cJAMB/kSkAADOQJ55REAEALyktLdVtt92mn/3sZwoPD9ddd90lh8Oh8vJySRdmhxQWFmrSpElKSkpSZGSklixZohMnTmjbtm2SpIMHD2r79u3Kzs7WwIEDFR8fr8zMTG3evFlffPGFJGnTpk2qq6vTokWL1Lt3byUnJ+uhhx5SQUGBz84dAAAAAAAA8DUKIgAsy4zpg7W1taqpqXHbamtrL/t+cXFxKikp0eHDhyVdWNZq165d+ulPfypJOnbsmCorK5WYmGg8JygoSAMHDlRpaamkC0WV9u3bKzo62miTmJgou91uFFbKysoUHx+vwMBAo43D4dDhw4dVXV1t7iACAJiODgAwDZkCADADeeJZo26qDgD+xIzP9ry8PK1cudJt35QpUzR16tRL2k6cOFE1NTW6++671apVK9XX1+vRRx/VvffeK0mqrKyUJIWEhLg9LyQkRE6nU5LkdDrVqVMnt+OtW7dWcHCw8Xyn06nw8HC3NqGhocax4ODgqz1dAMBl+PG1AgDAy8gUAIAZyBPPKIgAsCwzqt3p6ekaP368275vz8z4tq1bt+rNN9/UsmXL1KtXL+3Zs0c5OTnq3LmzUlNTm9wXAIBv+PNfTwEAvItMAQCYgTzxjIIIADRBYGCgxwLIdy1ZskQTJ05UcnKyJKlv3746fvy48vLylJqaqrCwMElSVVWVOnfubDyvqqpKkZGRki7M9Dh58qTb6547d07V1dXG80NDQ40ZJRddfHxxpggAAAAAAABgNdxDBIBleXs9xW+++eaS57Rq1Uoul0uSFB4errCwMO3YscM4XlNTo927dysuLk7ShfuQnDp1ShUVFUabkpISnT9/XjExMZKk2NhY7dy5U3V1dUab4uJi9ejRg+WyAKAZsD4vAMAsZAoAwAzkiWcURABYls1ua/LWGLfccotyc3P17rvv6tixY3rrrbdUUFCgpKSkC/2x2TRmzBg9//zzevvtt7Vv3z5lZGSoc+fORpuIiAgNHTpUc+bMUXl5uXbt2qWFCxcqOTlZXbp0kSSlpKQoICBAs2fP1v79+7VlyxYVFhZesrQXAMAc3s4TAID/IlMAAGbwRZ588cUXmjlzpoYMGaKYmBilpKToo48+Mo67XC6tWLFCDodDMTExGjdunI4cOeL2Gl9++aVmzJihQYMGKT4+XrNmzdLp06fd2uzdu1ejRo1SdHS0hg0bpvz8/Eb1kyWzAFiWt6vdmZmZWrFihebPn28sizVy5Eg98sgjRpsJEybozJkzysrK0qlTpzR48GCtXr1abdq0MdosXbpUCxcu1NixY2W323XHHXcoMzPTOB4UFKQ1a9ZowYIFGj58uDp27KjJkydr5MiRXj1fALAKf/7rKQCAd5EpAAAzeDtPqqur9cADD2jIkCHKz89Xx44d9fe//91tpZL8/HwVFRVp8eLFCg8P14oVK5SWlqYtW7YY33vNnDlTlZWVKigoUF1dnWbNmqWsrCwtW7ZM0oWVVNLS0pSQkKD58+fr008/1axZs9S+ffsf/L0XBREAluXta4127dpp9uzZmj17tsc2NptN06dP1/Tp0z226dChgxEEnkRGRurll1++6r4CAH44vrsCAJiFTAEAmMHbeZKfn6+uXbsqJyfH2Ne9e3fjv10ulwoLCzVp0iRjFZQlS5YoMTFR27ZtU3Jysg4ePKjt27frtddeU3R0tKQLf1w8ceJEZWRkqEuXLtq0aZPq6uq0aNEiBQYGqnfv3tqzZ48KCgp+cEGEJbMAAAAAAAAAAIChtrZWNTU1blttbe1l2/75z39WVFSUpk2bpoSEBP37v/+71q9fbxw/duyYKisrlZiYaOwLCgrSwIEDVVpaKkkqLS1V+/btjWKIJCUmJsput6u8vFySVFZWpvj4eAUGBhptHA6HDh8+rOrq6h90XhREAFgWN5gCAJiBPAEAmIVMAQCYwYw8ycvL0+DBg922vLy8y77f0aNH9corr+jmm2/WmjVr9MADDyg7O1tvvPGGJKmyslKSFBIS4va8kJAQOZ1OSZLT6VSnTp3cjrdu3VrBwcHG851Op0JDQ93aXHx88XW+D0tmAbAsbjgIADADeQIAMAuZAgAwgxl5kp6ervHjx7vt+/bMjG9zuVyKiorSY489Jknq37+/9u/fr3Xr1ik1NbXJfTETBREAlsVfTwEAzECeAADMQqYAAMxgRp4EBgZ6LIB8V1hYmCIiItz29ezZU3/605+M45JUVVWlzp07G22qqqoUGRkp6cJMj5MnT7q9xrlz51RdXW08PzQ09JKZIBcff3fmiCcsmQUAAAAAAAAAAK7KoEGDdPjwYbd9R44c0Y033ihJCg8PV1hYmHbs2GEcr6mp0e7duxUXFydJiouL06lTp1RRUWG0KSkp0fnz5xUTEyNJio2N1c6dO1VXV2e0KS4uVo8ePRQcHPyD+kpBBIB12WxN3wAAIE8AAGYhUwAAZvBynowdO1a7d+9Wbm6u/v73v+vNN9/U+vXrNWrUqP/rjk1jxozR888/r7ffflv79u1TRkaGOnfurKSkJElSRESEhg4dqjlz5qi8vFy7du3SwoULlZycrC5dukiSUlJSFBAQoNmzZ2v//v3asmWLCgsLL1na60pYMguAZXGtAAAwA3kCADALmQIAMIO38yQmJkYrV67Us88+q1WrVik8PFyzZs3Svffea7SZMGGCzpw5o6ysLJ06dUqDBw/W6tWr1aZNG6PN0qVLtXDhQo0dO1Z2u1133HGHMjMzjeNBQUFas2aNFixYoOHDh6tjx46aPHmyRo4c+YP7SkEEgGXZudoAAJiAPAEAmIVMAQCYwRd5csstt+iWW27xeNxms2n69OmaPn26xzYdOnTQsmXLrvg+kZGRevnll6+6nyyZBQAAAAAAAAAA/B4zRABYlo2/vgIAmIA8AQCYhUwBAJiBPPGMgggAy2I6OgDADOQJAMAsZAoAwAzkiWcURABYFuEAADADeQIAMAuZAgAwA3niGfcQAQAAAAAAAAAAfo8ZIgAsi2o5AMAM5AkAwCxkCgDADOSJZxREAFgWN5gCAJiBPAEAmIVMAQCYgTzxjIIIAMuyi3AAADQdeQIAMAuZAgAwA3niWYsqiATYB/u6C82km6870CxsusnXXTCd3dbL111oJjf6ugMtkp1s8FuB9n/zdReaiX/+LNttvX3dhWZh082+7kKz8Mf8byryxH+1sf/U111oJv55feK/eeKfn7v+mpNNRab4rxta3+XrLjQT/8yUVrYBvu5Cs/DHz17//S6vacgTz1pUQeSftf/j6y6YrmPgz+XSUV93w3Q2dZd03NfdMFk3+d85SVI3P/43CFze8a9f93UXTNft+hGS/uHrbjSDG+Wvn73+el5kCqzk8FfrfN0F0/UIut+Pf47983OX87qW+OcXwzCH/2bKZ77uhukuFKL99TPK387LH89JIk+aV4sqiACAN7GeIgDADOQJAMAsZAoAwAzkiWcURABYlp1wAACYgDwBAJiFTAEAmIE88YyCCADLIhwAAGYgTwAAZiFTAABmIE88s/u6AwAAAAAAAAAAAM2NgggAy7LbbE3eAAAgTwAAZvF2pnzxxReaOXOmhgwZopiYGKWkpOijjz4yjrtcLq1YsUIOh0MxMTEaN26cjhw54vYaX375pWbMmKFBgwYpPj5es2bN0unTp93a7N27V6NGjVJ0dLSGDRum/Pz8qx4jAMD34xrFMwoiACzLZsL/AAAgTwAAZvFmplRXV+uBBx5QQECA8vPztXnzZj3xxBMKDg422uTn56uoqEjz5s3T+vXr1bZtW6Wlpens2bNGm5kzZ+rAgQMqKChQbm6udu7cqaysLON4TU2N0tLS1K1bN23YsEEZGRlauXKlXn31VXMGDQBwCa5RPOMeIgAsy5+r3QAA7yFPAABm8Wam5Ofnq2vXrsrJyTH2de/e3fhvl8ulwsJCTZo0SUlJSZKkJUuWKDExUdu2bVNycrIOHjyo7du367XXXlN0dLQkKTMzUxMnTlRGRoa6dOmiTZs2qa6uTosWLVJgYKB69+6tPXv2qKCgQCNHjvTa+QKAlXCN4hkzRAAAAAAAACzmz3/+s6KiojRt2jQlJCTo3//937V+/Xrj+LFjx1RZWanExERjX1BQkAYOHKjS0lJJUmlpqdq3b28UQyQpMTFRdrtd5eXlkqSysjLFx8crMDDQaONwOHT48GFVV1c392kCAOCGGSIALItqOQDADOQJAMAsZmRKbW2tamtr3fYFBga6FSQk6ejRo3rllVc0fvx4Pfzww/roo4+UnZ2tgIAApaamqrKyUpIUEhLi9ryQkBA5nU5JktPpVKdOndyOt27dWsHBwcbznU6nwsPD3dqEhoYax769RBcAwBxco3hGQQSAZREOAAAzkCcAALOYkSl5eXlauXKl274pU6Zo6tSpbvtcLpeioqL02GOPSZL69++v/fv3a926dUpNTW1yPwAAvsM1imcURABYFtkAADADeQIAMIsZmZKenq7x48e77fvu7BBJCgsLU0REhNu+nj176k9/+pNxXJKqqqrUuXNno01VVZUiIyMlXZjpcfLkSbfXOHfunKqrq43nh4aGGjNKLrr4+OJMEQCAubhG8Yx7iAAAAADXmC+++EIzZ87UkCFDFBMTo5SUFH300UfGcZfLpRUrVsjhcCgmJkbjxo3TkSNH3F7jyy+/1IwZMzRo0CDFx8dr1qxZOn36tFubvXv3atSoUYqOjtawYcOUn5/vjdMDADRBYGCg2rVr57ZdriAyaNAgHT582G3fkSNHdOONN0qSwsPDFRYWph07dhjHa2pqtHv3bsXFxUmS4uLidOrUKVVUVBhtSkpKdP78ecXExEiSYmNjtXPnTtXV1RltiouL1aNHD5bLAgB4HQURAJZlt9mavAEA4O08qa6u1gMPPKCAgADl5+dr8+bNeuKJJ9y+VMrPz1dRUZHmzZun9evXq23btkpLS9PZs2eNNjNnztSBAwdUUFCg3Nxc7dy5U1lZWcbxmpoapaWlqVu3btqwYYMyMjK0cuVKvfrqq00fNADAZXkzU8aOHavdu3crNzdXf//73/Xmm29q/fr1GjVqlCTJZrNpzJgxev755/X2229r3759ysjIUOfOnZWUlCRJioiI0NChQzVnzhyVl5dr165dWrhwoZKTk9WlSxdJUkpKigICAjR79mzt379fW7ZsUWFh4SWzWAAA5uE7L89YMguAZfnzhzsAwHu8nSf5+fnq2rWrcnJyjH3du3c3/tvlcqmwsFCTJk0yvrBasmSJEhMTtW3bNiUnJ+vgwYPavn27XnvtNUVHR0uSMjMzNXHiRGVkZKhLly7atGmT6urqtGjRIgUGBqp3797as2ePCgoKNHLkSK+eMwBYhTczJSYmRitXrtSzzz6rVatWKTw8XLNmzdK9995rtJkwYYLOnDmjrKwsnTp1SoMHD9bq1avVpk0bo83SpUu1cOFCjR07Vna7XXfccYcyMzON40FBQVqzZo0WLFig4cOHq2PHjpo8eTJZAgDNiO+8PKMgAsCybCIcAABN5+08+fOf/yyHw6Fp06bpww8/VJcuXTRq1Cj98pe/lCQdO3ZMlZWVSkxMNJ4TFBSkgQMHqrS0VMnJySotLVX79u2NYogkJSYmym63q7y8XLfffrvKysoUHx/vtsyKw+FQfn6+qqurWeYEAJqBtzPllltu0S233OLxuM1m0/Tp0zV9+nSPbTp06KBly5Zd8X0iIyP18ssvX3U/AQCNw3denlEQAWBZVMsBAGYwI09qa2tVW1vrti8wMPCya74fPXpUr7zyisaPH6+HH35YH330kbKzsxUQEKDU1FRVVlZKkkJCQtyeFxISYtzE1ul0qlOnTm7HW7dureDgYOP5TqdT4eHhbm0u3vzW6XRSEAGAZsA1CgDADOSJZxREAAAAAB/Ly8vTypUr3fZNmTJFU6dOvaSty+VSVFSUHnvsMUlS//79tX//fq1bt06pqale6S8AAAAAXIsoiACwLKrlAAAzmJEn6enpl9xc9nKzQyQpLCxMERERbvt69uypP/3pT8ZxSaqqqlLnzp2NNlVVVYqMjJR0YabHyZMn3V7j3Llzqq6uNp4fGhpqzCi56OLjizNFAADm4hoFAGAG8sQzu687AAC+YrfZmrwBAGBGngQGBqpdu3Zum6eCyKBBg3T48GG3fUeOHNGNN94oSQoPD1dYWJh27NhhHK+pqdHu3bsVFxcnSYqLi9OpU6dUUVFhtCkpKdH58+cVExMjSYqNjdXOnTtVV1dntCkuLlaPHj1YLgsAmgnXKAAAM5AnnlEQAWBZNputyRsAAN7Ok7Fjx2r37t3Kzc3V3//+d7355ptav369Ro0aZfRnzJgxev755/X2229r3759ysjIUOfOnZWUlCRJioiI0NChQzVnzhyVl5dr165dWrhwoZKTk9WlSxdJUkpKigICAjR79mzt379fW7ZsUWFh4SUzWQAA5uEaBQBgBvLEM5bMAgAAAK4hMTExWrlypZ599lmtWrVK4eHhmjVrlu69916jzYQJE3TmzBllZWXp1KlTGjx4sFavXq02bdoYbZYuXaqFCxdq7NixstvtuuOOO5SZmWkcDwoK0po1a7RgwQINHz5cHTt21OTJkzVy5Eivni8AAAAAmIWCCADLsvtvsRsA4EW+yJNbbrlFt9xyi8fjNptN06dP1/Tp0z226dChg5YtW3bF94mMjNTLL7981f0EADQO1ygAADOQJ55REAFgWXaRDgCApiNPAABmIVMAAGYgTzyjIALAsvz5BlEAAO8hTwAAZiFTAABmIE8846bqAAAAAAAAAADA7zFDBIBl2aiWAwBMQJ4AAMxCpgAAzECeeEZBBIBlMX0QAGAG8gQAYBYyBQBgBvLEM5bMAmBZdputyVtjffHFF5o5c6aGDBmimJgYpaSk6KOPPjKOu1wurVixQg6HQzExMRo3bpyOHDni9hpffvmlZsyYoUGDBik+Pl6zZs3S6dOn3drs3btXo0aNUnR0tIYNG6b8/PyrGiMAwPfzRZ4AAPwTmQIAMAN54hkFEQDwkurqaj3wwAMKCAhQfn6+Nm/erCeeeELBwcFGm/z8fBUVFWnevHlav3692rZtq7S0NJ09e9ZoM3PmTB04cEAFBQXKzc3Vzp07lZWVZRyvqalRWlqaunXrpg0bNigjI0MrV67Uq6++6tXzBQAAAAAAAFoSlswCYFneXk8xPz9fXbt2VU5OjrGve/fuxn+7XC4VFhZq0qRJSkpKkiQtWbJEiYmJ2rZtm5KTk3Xw4EFt375dr732mqKjoyVJmZmZmjhxojIyMtSlSxdt2rRJdXV1WrRokQIDA9W7d2/t2bNHBQUFGjlypFfPGQCsgPV5AQBmIVMAAGYgTzxr9AyRb775Rjt37tSBAwcuOXb27Flt3LjRjH4BQLMzY/pgbW2tampq3Lba2trLvt+f//xnRUVFadq0aUpISNC///u/a/369cbxY8eOqbKyUomJica+oKAgDRw4UKWlpZKk0tJStW/f3iiGSFJiYqLsdrvKy8slSWVlZYqPj1dgYKDRxuFw6PDhw6qurjZ1DJuCPAHgL5iO7ntkCgB/Qab4FnkCwF+QJ541qiBy+PBh3XPPPRo9erRSUlI0evRonThxwjj+1Vdf6amnnjK9kwDQHOwmbHl5eRo8eLDblpeXd9n3O3r0qF555RXdfPPNWrNmjR544AFlZ2frjTfekCRVVlZKkkJCQtyeFxISIqfTKUlyOp3q1KmT2/HWrVsrODjYeL7T6VRoaKhbm4uPL76Or5EnAPyJGXmCq0emAPAnZIrvkCcA/Al54lmjzm3p0qXq3bu3iouL9cc//lE33HCDHnjgAR0/fry5+gcAzcZmszV5S09P165du9y29PT0y76fy+XSgAED9Nhjj6l///4aOXKkfvnLX2rdunVePnPfI08A+BMz8gRXj0wB4E/IFN8hTwD4E/LEs0YVREpLS/XYY4+pU6dO+pd/+Rfl5ubK4XDowQcf1NGjR5urjwDQYgUGBqpdu3Zu27eXqvq2sLAwRUREuO3r2bOn8Qt2WFiYJKmqqsqtTVVVlTHDIzQ0VCdPnnQ7fu7cOVVXVxvPDw0NvWQmyMXH35054ivkCQDALGQKAMAM5AkAWEOjCiLffPONWrduuA+7zWbT/Pnzdcstt2j06NE6cuSI2f0DgGbj7fUUBw0apMOHD7vtO3LkiG688UZJUnh4uMLCwrRjxw7jeE1NjXbv3q24uDhJUlxcnE6dOqWKigqjTUlJic6fP6+YmBhJUmxsrHbu3Km6ujqjTXFxsXr06KHg4ODGDVIzIU8A+BPW5/UtMgWAPyFTfIc8AeBPyBPPGlUQ6dmzpz766KNL9mdlZem2227TpEmTTOsYADQ3u63pW2OMHTtWu3fvVm5urv7+97/rzTff1Pr16zVq1ChJF37hHjNmjJ5//nm9/fbb2rdvnzIyMtS5c2clJSVJkiIiIjR06FDNmTNH5eXl2rVrlxYuXKjk5GR16dJFkpSSkqKAgADNnj1b+/fv15YtW1RYWKjx48ebOn5NQZ4A8CfezhO4I1MA+BMyxXfIEwD+hDzxrFEFkdtvv12bN2++7LGsrCwlJyfL5XKZ0jEAaG42E/7XGDExMVq5cqU2b96sn//85/rtb3+rWbNm6d577zXaTJgwQaNHj1ZWVpbuu+8+ff3111q9erXatGljtFm6dKl69uypsWPHauLEiRo0aJAWLFhgHA8KCtKaNWt07NgxDR8+XIsXL9bkyZM1cuTIpg+aScgTAP7E23kCd2QKAH9CpvgOeQLAn5AnntlcLejT/J+1/+PrLpiuY+DP5ZL/rTVpU3dJ/nZjsW7yv3OSpG5+/G+waeb9dU7TX+NfFzb5NWC+41+/7usumK7b9SMk/cPX3WgGN8pfP3v99bzIlEuRJ/7r8FfrfN0F0/UIut+Pf47983OX87qWdGvyK5Ap/st/M+UzX3fDdDbdJP/9jPK38/LHc5LIk+bV+vubAIB/8uf1EAEA3kOeAADMQqYAAMxAnnhGQQSAZfnzeogAAO8hTwAAZiFTAABmIE88oyACwLL8eT1EAID3kCcAALOQKQAAM5AnnjXqpuoAAAAAAAAAAADXImaIALAs1lMEAJiBPAEAmIVMAQCYgTzxjIIIAMtiPUUAgBnIEwCAWcgUAIAZyBPPKIgAsCwb1XIAgAnIEwCAWcgUAIAZyBPPuIcIAAAAAAAAAADwe8wQAWBZdlEtBwA0HXkCADALmQIAMAN54hkFEQCWxXqKAAAzkCcAALOQKQAAM5AnnlEQAWBZrKcIADADeQIAMAuZAgAwA3niGQURAJbF9EEAgBnIEwCAWcgUAIAZyBPPuKk6AAAAAAAAAADwexREAFiW3db0DQAA8gQAYBYyBQBgBl/myQsvvKC+ffvq6aefNvadPXtW8+fP15AhQxQXF6epU6fK6XS6Pe/48eOaOHGiBg4cqISEBD3zzDM6d+6cW5sPPvhAqampioqK0u23364NGzY0un8URABYls1ma/IGAAB5AgAwC5kCADCDr/KkvLxc69atU9++fd32L1q0SO+8846WL1+uoqIinThxQlOmTDGO19fXKz09XXV1dVq3bp0WL16sN954Q88995zR5ujRo0pPT9eQIUP0hz/8QWPHjlVmZqa2b9/eqD5SEAFgWXabrckbAADkCQDALGQKAMAMvsiT06dP6/HHH1d2draCg4ON/V999ZVef/11Pfnkk0pISFBUVJQWLVqk0tJSlZWVSZL+8pe/6MCBA/rP//xP9evXT8OGDdP06dO1du1a1dbWSpLWrVun8PBwPfnkk4qIiNDo0aN155136ne/+13jxqbRZwYAAAAAAAAAAPxWbW2tampq3LaLxYnLWbBggYYNG6bExES3/RUVFaqrq3PbHxERoW7duhkFkbKyMvXp00ehoaFGG4fDoZqaGh04cMBok5CQ4PbaDofDeI0fqnWjWgOAH6EiDAAwA3kCADALmQIAMIMZeZKXl6eVK1e67ZsyZYqmTp16SdvNmzfrk08+0WuvvXbJMafTqYCAALVv395tf0hIiCorK4023y6GSDIef1+bmpoaffPNN7ruuut+0HlREAFgWayvCwAwA3kCADALmQIAMIMZeZKenq7x48e77QsMDLyk3eeff66nn35aL774otq0adPk921uFEQAWBbr6wIAzECeAADMQqYAAMxgRp4EBgZetgDyXR9//LGqqqo0fPhwY199fb0+/PBDrV27VmvWrFFdXZ1OnTrlNkukqqpKYWFhki7M9CgvL3d7XafTKUlubS7u+3abdu3a/eDZIRIFEQAAAAAAAAAAcBV+8pOf6M0333Tb99RTT6lnz56aMGGCfvSjHykgIEA7duzQnXfeKUk6dOiQjh8/rtjYWElSbGyscnNzVVVVpZCQEElScXGx2rVrp169ehlt3n//fbf3KS4uNl7jh6IgAsCy7PzxFQDABOQJAMAsZAoAwAzezJN27dqpT58+bvuuv/56dejQwdg/YsQILV68WMHBwWrXrp2ys7MVFxdnFDMcDod69eqljIwMPf7446qsrNTy5cv14IMPGrNU7r//fq1du1ZLlizRiBEjVFJSoq1btyovL69R/aUgAsCybOJqAwDQdOQJAMAsZAoAwAwtLU9mzZolu92uadOmqba2Vg6HQ3PnzjWOt2rVSrm5uZo3b55Gjhyptm3bKjU1VdOmTTPadO/eXXl5ecrJyVFhYaG6du2q7OxsDR06tFF9oSACwLL46ysAgBnIEwCAWcgUAIAZfJ0nRUVFbo/btGmjuXPnuhVBvuvGG29Ufn7+FV93yJAh2rhxY5P6Zm/SswEAAAAAAAAAAK4BzBABYFl2G39+BQBoOvIEAGAWMgUAYAbyxDMKIgAsq6WtpwgAuDaRJwAAs5ApAAAzkCeetaiCSMfAn/u6C83Cpu6+7kIz6ebrDjQDfzwnf/432DS+Xk8Rzafb9SN83YVmcqOvO9BM/POz11/Pi0y5FHniv3oE3e/rLjQL//059s/PXc7LWsgU/+W/mXKTr7vQTPz1M8ofz8sfz6npyBPPWlRBZEnpfF93wXQZcXPl0me+7obpbLpJ512f+robprLb+silo77uhukuXPAe93U3mkHTA4/pg/5r3FtTfd0F0/3u9t/ovOuQr7thOrutp9/mpP9+9vrreV098sR/PfjHR3zdBdOtvWuVzrv2+7obprPbest/P584r2sH1yjwLCI7ydddMN3BzG1+992QxPdD15Zufvz/VdOQJ55xU3UAAAAAAAAAAOD3KIgAsCybzdbkDQAA8gQAYBZfZsoLL7ygvn376umnnzb2nT17VvPnz9eQIUMUFxenqVOnyul0uj3v+PHjmjhxogYOHKiEhAQ988wzOnfunFubDz74QKmpqYqKitLtt9+uDRs2XHU/AQDfj2sUzyiIALAsuwkbAADkCQDALL7KlPLycq1bt059+/Z1279o0SK98847Wr58uYqKinTixAlNmTLFOF5fX6/09HTV1dVp3bp1Wrx4sd544w0999xzRpujR48qPT1dQ4YM0R/+8AeNHTtWmZmZ2r59+1X2FgDwfbhG8cyfzw0ArshuszV5AwCAPAEAmMUXmXL69Gk9/vjjys7OVnBwsLH/q6++0uuvv64nn3xSCQkJioqK0qJFi1RaWqqysjJJ0l/+8hcdOHBA//mf/6l+/fpp2LBhmj59utauXava2lpJ0rp16xQeHq4nn3xSERERGj16tO6880797ne/M2PIAACXwTWKZxREAAAAAAAA/ERtba1qamrctovFictZsGCBhg0bpsTERLf9FRUVqqurc9sfERGhbt26GQWRsrIy9enTR6GhoUYbh8OhmpoaHThwwGiTkJDg9toOh8N4DQAAvImCCADLYj1FAIAZfJ0nrPkOAP7DjEzJy8vT4MGD3ba8vLzLvt/mzZv1ySefaMaMGZccczqdCggIUPv27d32h4SEqLKy0mjz7WKIJOPx97WpqanRN998c3UDBQC4Il9fo7RkrX3dAQDwFSrCAAAz+DJPrrTm+3vvvafly5crKChICxcu1JQpU7Ru3TpJDWu+h4aGat26dTpx4oSeeOIJBQQE6LHHHpPUsOb7/fffr6VLl2rHjh3KzMxUWFiYhg4d6vVzBQArMCNT0tPTNX78eLd9gYGBl7T7/PPP9fTTT+vFF19UmzZtTHhnAEBLwXdenjE2ACyLajkAwAy+yhPWfAcA/2NGpgQGBqpdu3Zu2+UKIh9//LGqqqo0fPhw9e/fX/3799df//pXFRUVqX///goNDVVdXZ1OnTrl9ryqqiqFhYVJujDT47szEC8+/r427dq103XXXWfa2AEAGvCd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XQHalN0yhTzpOMgTwF7Ik46BTOm4yBP4C7vliWTPTCFPOjYyxR78piCyadMmLV26VI888ojeeustDRo0SElJSaqrq/N111rlxIkTGjhwoBYuXOjrrhjz2WefaeLEiVq3bp0KCgp0+vRpJSUl6cSJE77uWqv06tVLc+fO1fr16/Xmm2/qhz/8oR555BHt2bPH110zpqKiQsXFxRo4cKCvuwK0KTtmCnnScZAngH2QJx0HmdIxkSfwF3bME8memUKedFxkio24/cTPfvYzd0ZGhvW6ubnZ7XK53Hl5eT7slVkDBgxwv/fee77uhnF1dXXuAQMGuD/77DNfd8W4H/zgB+5169b5uhtGNDQ0uO+88073//2//9c9adIk95IlS3zdJaDN2D1TyJOOhzwBOibypOMiU65+5An8id3zxO22b6aQJx0DmWIvfjFCpLGxUV9++aXi4+OtdQEBAYqPj1dZWZkPe4bLcezYMUlSSEiIj3tiTnNzszZu3KgTJ04oJibG190xIjMzU6NGjfL4ewbYEZnScZEnHQN5An9BnnRsZMrVjzyBvyBPOjbypGMgU+yls6870B7++7//W83NzQoNDfVYHxoaaot5+uzszJkzysrK0rBhwzRgwABfd6fVdu/erQceeECnTp3StddeqxdeeEH9+vXzdbdabePGjfrzn/+sN954w9ddAdocmdIxkScdA3kCf0KedFxkytWPPIE/IU86LvKkYyBT7McvCiLouDIyMrRnzx6tXbvW110xom/fvnr77bd17Ngx/eEPf9ATTzyhV199tUMHxN///nc988wz+t3vfqcuXbr4ujsAcFHkydWPPAHQUZApVzfyBEBHQZ5c/cgUe/KLgsj111+vTp06XfAwqbq6OoWFhfmoV/gumZmZ+uijj/Tqq6+qV69evu6OEU6nU//0T/8kSRo8eLC++OILFRYWKjMz08c9u3Jffvml6urqNHbsWGtdc3OzPv/8c61Zs0ZffPGFOnXq5MMeAmaRKR0PedIxkCfwN+RJx0SmXP3IE/gb8qRjIk86BjLFnvyiIOJ0OvX9739fW7du1ejRoyWdHZa2detWTZo0yce9w7e53W4tXrxY7733noqKitSnTx9fd6nNnDlzRo2Njb7uRqv88Ic/1Lvvvuux7qmnntItt9yi6dOnEwywHTKl4yBPOhbyBP6GPOlYyJSOgzyB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",
      "text/plain": [
       "<Figure size 2000x2000 with 26 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(4, 4, figsize=(20, 20))\n",
    "\n",
    "# plots clinician's distribution (first row)\n",
    "counts = get_action_counts(dataloader, None, device=device)\n",
    "_ = sns.heatmap(data=counts.reshape((5, 5)), annot=False, linewidth=0.5, fmt=\"d\", cmap=\"YlGn\", ax=ax[0, 0])\n",
    "_ = ax[0, 0].invert_yaxis()\n",
    "\n",
    "# plots baseline policy (second row)\n",
    "counts = get_action_counts(dataloader, protagonist_l00_jstf, device=device)\n",
    "_ = sns.heatmap(data=counts.reshape((5, 5)), annot=False, linewidth=0.5, fmt=\"d\", cmap=\"YlGn\", ax=ax[1, 0])\n",
    "_ = ax[1, 0].invert_yaxis()\n",
    "\n",
    "# plots justifiable (partial-context) policies (third row)\n",
    "for act_ind, policy in enumerate([protagonist_l25_jstf, protagonist_l50_jstf, protagonist_l75_jstf, protagonist_l100_jstf]):\n",
    "    counts = get_action_counts(dataloader, policy, device=device)\n",
    "    _ = sns.heatmap(data=counts.reshape((5, 5)), annot=False, linewidth=0.5, fmt=\"d\", cmap=\"YlGn\", ax=ax[2, act_ind])\n",
    "    _ = ax[2, act_ind].invert_yaxis()\n",
    "\n",
    "# plots aligned (full-context) policies (fourth row)\n",
    "for act_ind, policy in enumerate([protagonist_l25_jstf, protagonist_l50_jstf, protagonist_l75_jstf, protagonist_l100_jstf]):\n",
    "    counts = get_action_counts(dataloader, policy, device=device)\n",
    "    _ = sns.heatmap(data=counts.reshape((5, 5)), annot=False, linewidth=0.5, fmt=\"d\", cmap=\"YlGn\", ax=ax[3, act_ind])\n",
    "    _ = ax[3, act_ind].invert_yaxis()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Full vs Partial Context\n",
    "\n",
    "In this section we showcase the judge's preference over policies trained with full-state vs. partial (6 arguments) judge. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_judge_dataset(data_dict=None, load_path=\"./assets/data/sepsis/test_preferences.pt\", batch_size=256, num_workers=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Evaluate the 6-arg case."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 145/145 [00:02<00:00, 59.19it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 75.14it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 65.98it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 85.87it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 71.20it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 80.30it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 74.13it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 78.92it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 75.48it/s]\n",
      "100%|██████████| 145/145 [00:03<00:00, 48.19it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 77.40it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 95.46it/s] \n",
      "100%|██████████| 145/145 [00:02<00:00, 59.34it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 63.96it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 64.66it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 56.52it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 53.64it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 76.46it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 58.46it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 71.88it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 59.46it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 60.16it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 55.85it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 50.27it/s]\n",
      "100%|██████████| 145/145 [00:03<00:00, 45.10it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 53.48it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 54.43it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 52.10it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 57.81it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 78.62it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 68.23it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 66.35it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 71.20it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 78.11it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 69.68it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 83.27it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 51.31it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 54.77it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 59.29it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 67.36it/s]\n"
     ]
    }
   ],
   "source": [
    "data = pd.DataFrame(\n",
    "    [{\"label\": \"λ=0.25\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l25_jstf[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.25\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l25_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.50\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l50_jstf[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.50\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l50_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.75\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l75_jstf[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.75\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l75_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=1.0\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l100_jstf[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=1.0\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l100_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)])\n",
    "data.to_csv(results_dir / \"protagonist_full_vs_partial_context.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Evaluate the 4-arg case."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/145 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 145/145 [00:01<00:00, 78.60it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 68.84it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 110.05it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 111.34it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 98.36it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 65.78it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 85.79it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 101.86it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 93.62it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 84.69it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 79.88it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 63.91it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 75.05it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 102.35it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 65.72it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 60.05it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 71.45it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 63.17it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 107.90it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 72.73it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 70.75it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 83.33it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 87.81it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 87.45it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 75.37it/s] \n",
      "100%|██████████| 145/145 [00:01<00:00, 75.97it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 74.84it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 100.53it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 67.07it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 75.21it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 69.19it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 62.00it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 71.22it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 59.29it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 74.37it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 55.28it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 74.12it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 51.10it/s]\n",
      "100%|██████████| 145/145 [00:02<00:00, 68.50it/s]\n",
      "100%|██████████| 145/145 [00:01<00:00, 77.27it/s]\n"
     ]
    }
   ],
   "source": [
    "data = pd.DataFrame(\n",
    "    [{\"label\": \"λ=0.25\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l25_jstf_4arg[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.25\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l25_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.50\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l50_jstf_4arg[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.50\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l50_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.75\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l75_jstf_4arg[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=0.75\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l75_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=1.0\", \"kind\": \"partial context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l100_jstf_4arg[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)] +\n",
    "    [{\"label\": \"λ=1.0\", \"kind\": \"full context\", \"seed\": seed, \"preference\": full_vs_partial_context(policy=protagonist_l100_full_state[i], dataloader=dataloader, device=device)} for i, seed in enumerate(seeds)])\n",
    "data.to_csv(results_dir / \"protagonist_full_vs_partial_context_4arg.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Qualitative Evaluation\n",
    "\n",
    "In this section, we review agents trained with different levels of $\\lambda$ parameter, showcasing their target performance in terms of WIS evaluation as well as the level of justifiability compared to the baseline policy trained with $\\lambda=0.0$."
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Justifiability Comparison\n",
    "\n",
    "In this section, we calculate the judge's preference over the baseline policy."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Evaluate the 6-arg case."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, batch_size=256, use_dem=True, mask=True, shuffle=False, num_workers=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data += [\n",
    "        {\"label\": \"λ=0.25\", \"justifiability\": jstf(justifiable=protagonist_l25_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device)},\n",
    "        {\"label\": \"λ=0.50\", \"justifiability\": jstf(justifiable=protagonist_l50_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device)},\n",
    "        {\"label\": \"λ=0.75\", \"justifiability\": jstf(justifiable=protagonist_l75_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device)},\n",
    "        {\"label\": \"λ=1.0\", \"justifiability\": jstf(justifiable=protagonist_l100_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device)},\n",
    "    ]\n",
    "data = pd.DataFrame(data).round(decimals=2)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_per.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data = []\n",
    "    data += [{\"label\": \"λ=0.25\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l25_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=0.50\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l50_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=0.75\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l75_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=1.0\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l100_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "data = pd.DataFrame(data).round(decimals=2)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_dist.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We also record discrepancy between actions proposed by the justifiable and baseline agent."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def eval_equivalent(justifiable, baseline, dataloader, device=\"cuda\"):\n",
    "    result = torch.empty((0, ), dtype=torch.int, device=device)\n",
    "\n",
    "    for s_t, _, _, _, _ in dataloader:\n",
    "        s_t = s_t.to(device)\n",
    "        a_justifiable = torch.tensor(justifiable(Batch(obs=s_t, info={})).act, device=device)\n",
    "        a_baseline = torch.tensor(baseline(Batch(obs=s_t, info={})).act, device=device)\n",
    "        result = torch.cat((result, (a_justifiable == a_baseline).int()))\n",
    "\n",
    "    return result.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data = []\n",
    "    data += [{\"label\": \"λ=0.25\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l25_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=0.50\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l50_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=0.75\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l75_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=1.0\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l100_jstf[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "data = pd.DataFrame(data).round(decimals=2)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_eq.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Evaluate the 4-arg case by repeating all previous evaluations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data += [\n",
    "        {\"label\": \"λ=0.25\", \"justifiability\": jstf(justifiable=protagonist_l25_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator_4arg, judge=judge_4arg, device=device)},\n",
    "        {\"label\": \"λ=0.50\", \"justifiability\": jstf(justifiable=protagonist_l50_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator_4arg, judge=judge_4arg, device=device)},\n",
    "        {\"label\": \"λ=0.75\", \"justifiability\": jstf(justifiable=protagonist_l75_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator_4arg, judge=judge_4arg, device=device)},\n",
    "        {\"label\": \"λ=1.0\", \"justifiability\": jstf(justifiable=protagonist_l100_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator_4arg, judge=judge_4arg, device=device)},\n",
    "    ]\n",
    "data = pd.DataFrame(data)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_per_4arg.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data = []\n",
    "    data += [{\"label\": \"λ=0.25\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l25_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=0.50\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l50_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=0.75\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l75_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "    data += [{\"label\": \"λ=1.0\", \"justifiability\": j} for j in jstf(justifiable=protagonist_l100_jstf_4arg[act_ind], baseline=protagonist_l00_jstf_4arg[act_ind], dataloader=dataloader, argumentator=argumentator, judge=judge, device=device, report_percentage=False)]\n",
    "data = pd.DataFrame(data).round(decimals=2)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_dist_4arg.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = []\n",
    "for act_ind in range(len(seeds)):\n",
    "    data = []\n",
    "    data += [{\"label\": \"λ=0.25\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l25_jstf_4arg[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=0.50\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l50_jstf_4arg[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=0.75\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l75_jstf_4arg[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "    data += [{\"label\": \"λ=1.0\", \"equal\": j} for j in eval_equivalent(justifiable=protagonist_l100_jstf_4arg[act_ind], baseline=protagonist_l00_jstf[act_ind], dataloader=dataloader, device=device)]\n",
    "data = pd.DataFrame(data).round(decimals=2)\n",
    "data.to_csv(results_dir / \"protagonist_jstf_vs_baseline_eq_4arg.csv\", index=False)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Training WIS Evaluation\n",
    "\n",
    "In this section, we calculate (or rather, preprocess) the off-policy weighted importance sampling evaluation for different values of the $\\lambda$ justifiability parameter during the course of training."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/6/l00/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l25 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/6/l25/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l50 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/6/l50/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l75 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/6/l75/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l100 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/6/l100/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, batch_size=256, num_workers=0, shuffle=False, mask=False)\n",
    "eval_clinician = wis_clinician(clinician=clinician, patients=dataloader, discount=discount, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).mean(axis=0).tolist()\n",
    "eval_l00_std = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).std(axis=0).tolist()\n",
    "eval_l00_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.0\"} for i, x in enumerate(eval_l00_mean)]\n",
    "eval_l00_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "eval_l00_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "\n",
    "eval_l25_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).mean(axis=0).tolist()\n",
    "eval_l25_std = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).std(axis=0).tolist()\n",
    "eval_l25_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.25\"} for i, x in enumerate(eval_l25_mean)]\n",
    "eval_l25_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "eval_l25_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "\n",
    "eval_l50_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).mean(axis=0).tolist()\n",
    "eval_l50_std = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).std(axis=0).tolist()\n",
    "eval_l50_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.50\"} for i, x in enumerate(eval_l50_mean)]\n",
    "eval_l50_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "eval_l50_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "\n",
    "eval_l75_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).mean(axis=0).tolist()\n",
    "eval_l75_std = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).std(axis=0).tolist()\n",
    "eval_l75_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.75\"} for i, x in enumerate(eval_l75_mean)]\n",
    "eval_l75_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "eval_l75_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "\n",
    "eval_l100_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).mean(axis=0).tolist()\n",
    "eval_l100_std = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).std(axis=0).tolist()\n",
    "eval_l100_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=1.0\"} for i, x in enumerate(eval_l100_mean)]\n",
    "eval_l100_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "eval_l100_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "\n",
    "eval_clinician_mean = [eval_clinician for _ in range(len(eval_l100_mean))]\n",
    "eval_clinician_data = [{\"wis\": x, \"time_step\": i, \"label\": \"clinician\"} for i, x in enumerate(eval_clinician_mean)]\n",
    "\n",
    "eval_wis_data = pd.DataFrame(eval_l00_data + eval_l25_data + eval_l50_data + eval_l75_data + eval_l100_data + eval_clinician_data)\n",
    "eval_wis_data.to_csv(results_dir / \"protagonist_wis.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Repeat the preprocessing for the 4-arg case."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/4/l00/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l25 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/4/l25/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l50 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/4/l50/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l75 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/4/l75/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l100 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/justifiable/4/l100/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, batch_size=256, num_workers=0, shuffle=False, mask=False)\n",
    "eval_clinician = wis_clinician(clinician=clinician, patients=dataloader, discount=discount, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).mean(axis=0).tolist()\n",
    "eval_l00_std = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).std(axis=0).tolist()\n",
    "eval_l00_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.0\"} for i, x in enumerate(eval_l00_mean)]\n",
    "eval_l00_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "eval_l00_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "\n",
    "eval_l25_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).mean(axis=0).tolist()\n",
    "eval_l25_std = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).std(axis=0).tolist()\n",
    "eval_l25_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.25\"} for i, x in enumerate(eval_l25_mean)]\n",
    "eval_l25_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "eval_l25_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "\n",
    "eval_l50_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).mean(axis=0).tolist()\n",
    "eval_l50_std = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).std(axis=0).tolist()\n",
    "eval_l50_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.50\"} for i, x in enumerate(eval_l50_mean)]\n",
    "eval_l50_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "eval_l50_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "\n",
    "eval_l75_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).mean(axis=0).tolist()\n",
    "eval_l75_std = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).std(axis=0).tolist()\n",
    "eval_l75_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.75\"} for i, x in enumerate(eval_l75_mean)]\n",
    "eval_l75_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "eval_l75_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "\n",
    "eval_l100_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).mean(axis=0).tolist()\n",
    "eval_l100_std = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).std(axis=0).tolist()\n",
    "eval_l100_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=1.0\"} for i, x in enumerate(eval_l100_mean)]\n",
    "eval_l100_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "eval_l100_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "\n",
    "eval_clinician_mean = [eval_clinician for _ in range(len(eval_l100_mean))]\n",
    "eval_clinician_data = [{\"wis\": x, \"time_step\": i, \"label\": \"clinician\"} for i, x in enumerate(eval_clinician_mean)]\n",
    "\n",
    "eval_wis_data = pd.DataFrame(eval_l00_data + eval_l25_data + eval_l50_data + eval_l75_data + eval_l100_data + eval_clinician_data)\n",
    "eval_wis_data.to_csv(results_dir / \"protagonist_wis_4arg.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Repeat the evaluation for policies trained with a full-state jude case."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/full_state/l00/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l25 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/full_state/l25/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l50 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/full_state/l50/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l75 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/full_state/l75/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]\n",
    "eval_l100 = [pickle.load(open(f\"./assets/models/protagonist/ddqn/full_state/l100/evaluations-s{s}.pkl\", \"rb\")) for s in seeds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, dataloader, _ = get_patient_dataset(data_dict=test_dict, batch_size=256, num_workers=0, shuffle=False, mask=False)\n",
    "eval_clinician = wis_clinician(clinician=clinician, patients=dataloader, discount=discount, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_l00_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).mean(axis=0).tolist()\n",
    "eval_l00_std = np.array(list(map(lambda x: x[\"wis\"], eval_l00))).std(axis=0).tolist()\n",
    "eval_l00_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.0\"} for i, x in enumerate(eval_l00_mean)]\n",
    "eval_l00_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "eval_l00_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.0\"} for i, (x, sd) in enumerate(zip(eval_l00_mean, eval_l00_std))]\n",
    "\n",
    "eval_l25_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).mean(axis=0).tolist()\n",
    "eval_l25_std = np.array(list(map(lambda x: x[\"wis\"], eval_l25))).std(axis=0).tolist()\n",
    "eval_l25_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.25\"} for i, x in enumerate(eval_l25_mean)]\n",
    "eval_l25_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "eval_l25_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.25\"} for i, (x, sd) in enumerate(zip(eval_l25_mean, eval_l25_std))]\n",
    "\n",
    "eval_l50_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).mean(axis=0).tolist()\n",
    "eval_l50_std = np.array(list(map(lambda x: x[\"wis\"], eval_l50))).std(axis=0).tolist()\n",
    "eval_l50_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.50\"} for i, x in enumerate(eval_l50_mean)]\n",
    "eval_l50_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "eval_l50_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.50\"} for i, (x, sd) in enumerate(zip(eval_l50_mean, eval_l50_std))]\n",
    "\n",
    "eval_l75_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).mean(axis=0).tolist()\n",
    "eval_l75_std = np.array(list(map(lambda x: x[\"wis\"], eval_l75))).std(axis=0).tolist()\n",
    "eval_l75_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=0.75\"} for i, x in enumerate(eval_l75_mean)]\n",
    "eval_l75_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "eval_l75_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=0.75\"} for i, (x, sd) in enumerate(zip(eval_l75_mean, eval_l75_std))]\n",
    "\n",
    "eval_l100_mean = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).mean(axis=0).tolist()\n",
    "eval_l100_std = np.array(list(map(lambda x: x[\"wis\"], eval_l100))).std(axis=0).tolist()\n",
    "eval_l100_data =  [{\"wis\": x, \"time_step\": i, \"label\": \"λ=1.0\"} for i, x in enumerate(eval_l100_mean)]\n",
    "eval_l100_data += [{\"wis\": x + sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "eval_l100_data += [{\"wis\": x - sd, \"time_step\": i, \"label\": \"λ=1.0\"} for i, (x, sd) in enumerate(zip(eval_l100_mean, eval_l100_std))]\n",
    "\n",
    "eval_clinician_mean = [eval_clinician for _ in range(len(eval_l100_mean))]\n",
    "eval_clinician_data = [{\"wis\": x, \"time_step\": i, \"label\": \"clinician\"} for i, x in enumerate(eval_clinician_mean)]\n",
    "\n",
    "eval_wis_data = pd.DataFrame(eval_l00_data + eval_l25_data + eval_l50_data + eval_l75_data + eval_l100_data + eval_clinician_data)\n",
    "eval_wis_data.to_csv(results_dir / \"protagonist_wis_full_state.csv\", index=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "argo",
   "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.9.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
