{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Learning Sepsis Policies\n",
    "\n",
    "In this notebook, we learn two policies which solve the sepsis environment, one for AI agent and one for human clinician."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import mdptoolbox as mdp\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "from typing import List\n",
    "from matplotlib.ticker import FormatStrFormatter\n",
    "from rich.jupyter import print"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ced.actors.sepsis import SepsisActor, SepsisAction, ClinicianActor, AIActor\n",
    "from ced.envs.sepsis import Sepsis, SepsisTrajectory, State\n",
    "from ced.tools.utils import sample_trajectories, export_legend\n",
    "from ced.tools.order import Order\n",
    "from ced.tools.noise import UniformNoiseModel, SepsisStateUniformNoiseModel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "_ = sns.set_theme(\n",
    "    style=\"white\", context=\"paper\",\n",
    "    palette=\"muted\",\n",
    "    rc={\n",
    "        \"pdf.fonttype\": 42,\n",
    "        \"ps.fonttype\": 42,\n",
    "        \"font.size\": 25,\n",
    "        \"axes.titlesize\": 25,\n",
    "        \"axes.labelsize\": 25,\n",
    "        \"xtick.labelsize\": 20,\n",
    "        \"ytick.labelsize\": 20,\n",
    "        \"legend.fontsize\": 20,\n",
    "        \"legend.columnspacing\": 1,\n",
    "        \"legend.title_fontsize\": 20,\n",
    "        \"figure.figsize\": (6.4, 6.4),\n",
    "    },\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 5592\n",
    "max_horizon = 20\n",
    "discount = 0.99\n",
    "rng = np.random.default_rng(seed)\n",
    "\n",
    "ai_policy_path = Path(\"./results/sepsis/ai_policy.pkl\")\n",
    "cl_policy_path = Path(\"./results/sepsis/cl_policy.pkl\")\n",
    "\n",
    "original_mdp_path = Path(\"./results/sepsis/mdp_original.pkl\")\n",
    "ai_mdp_path = Path(\"./results/sepsis/mdp_ai.pkl\")\n",
    "cl_mdp_path = original_mdp_path\n",
    "\n",
    "plots_dir = Path(\"./plots/sepsis\")\n",
    "\n",
    "palette = {\"AI\": \"#ffa743\", \"Clinician\": \"#cd4e24\", \"Random\": \"#cc8926\", \"no change\": \"#e69a2b\", \"death\": \"#e61a34\", \"discharge\": \"#009622\"}\n",
    "\n",
    "plt_skip_legend = True\n",
    "\n",
    "plt_discrepancy_title = None\n",
    "plt_discrepancy_legend_title = None\n",
    "plt_discrepancy_x_label = \"Action\"\n",
    "plt_discrepancy_y_label = \"Probability\"\n",
    "\n",
    "plt_rewards_title = None\n",
    "plt_rewards_x_label = \"Policy\"\n",
    "plt_rewards_y_label = \"Fraction of Outcomes\"\n",
    "plt_rewards_legend_title = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_stats(trajectories: List[SepsisTrajectory]):\n",
    "    return {\n",
    "        \"success\": sum([bool(t.outcome() == 1.0) for t in trajectories]),\n",
    "        \"failure\": sum([bool(t.outcome() != 1.0) for t in trajectories]),\n",
    "        \"total\": len(trajectories),\n",
    "    }"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Random Actor\n",
    "\n",
    "To have a baseline agent to compare learned policies to, we first examine the performance of a random agent."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "env = Sepsis(transition_probabilities=\"./assets/sepsis/sepsis_transition_probs_original.json\", max_horizon=max_horizon)\n",
    "actor_cl = SepsisActor(id=0, rng=rng)\n",
    "trajectories = sample_trajectories(env=env, agents=[actor_cl], num_trajectories=100, rng=rng)\n",
    "stats = get_stats(trajectories)\n",
    "rew_values, rew_counts = np.unique([sum([s.reward for s in t.states]) for t in trajectories], return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Random agent achieved <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">22</span> successes and <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">78</span> failures in <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100</span> trajectories.\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Random agent achieved \u001b[1;36m22\u001b[0m successes and \u001b[1;36m78\u001b[0m failures in \u001b[1;36m100\u001b[0m trajectories.\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Random agent achieved rewards <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span><span style=\"font-weight: bold\">]</span> <span style=\"font-weight: bold\">(</span>death, max horizon reached, survival<span style=\"font-weight: bold\">)</span> with frequency <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">78</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">16</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span><span style=\"font-weight: bold\">]</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Random agent achieved rewards \u001b[1m[\u001b[0m\u001b[1;36m-1.0\u001b[0m, \u001b[1;36m0.0\u001b[0m, \u001b[1;36m1.0\u001b[0m\u001b[1m]\u001b[0m \u001b[1m(\u001b[0mdeath, max horizon reached, survival\u001b[1m)\u001b[0m with frequency \u001b[1m[\u001b[0m\u001b[1;36m78\u001b[0m, \u001b[1;36m16\u001b[0m, \u001b[1;36m6\u001b[0m\u001b[1m]\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"Random agent achieved [bold]{stats['success']}[/] successes and [bold]{stats['failure']}[/] failures in [bold]{stats['success'] + stats['failure']}[/] trajectories.\")\n",
    "print(f\"Random agent achieved rewards {rew_values.tolist()} (death, max horizon reached, survival) with frequency {rew_counts.tolist()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Human Clinician\n",
    "\n",
    "We learn the human clinician using the original transition probabilities of the environment. This ensures that the quality of the human policy is high."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We start by loading the transition and reward matrices from the exported file (see `learn_sepsis_mdp.ipynb` notebook for the export procedure)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(cl_mdp_path, \"rb\") as f:\n",
    "    mdp_dynamics_cl = pickle.load(f)\n",
    "    P, R = mdp_dynamics_cl[\"transition_matrix\"], mdp_dynamics_cl[\"reward_matrix\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Next, we run the policy iteration algorithm to find the optimal policy."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not cl_policy_path.exists():\n",
    "    Pi = mdp.mdp.PolicyIteration(P, R, discount=discount, eval_type=1)\n",
    "    Pi.run()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We convert the policy to matrix form, where each row represents a one-hot vector pointing to the action to be taken and save it to disk."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not cl_policy_path.exists():\n",
    "    policy = np.zeros((State.NUM_TOTAL, SepsisAction.NUM_TOTAL))\n",
    "    policy[np.arange(len(Pi.policy)), Pi.policy] = 1\n",
    "    with open(cl_policy_path, \"wb\") as f: pickle.dump(policy, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Finally, we can create an actor that utilizes the learned policy and examine its performance in the environment. Note that we always evaluate the actors on the original MDP."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "act_noise = UniformNoiseModel(order=Order([i for i in range(SepsisAction.NUM_TOTAL)]))\n",
    "env_noise = SepsisStateUniformNoiseModel(order=Order([i for i in range(State.NUM_TOTAL)]))\n",
    "env = Sepsis(dynamics=original_mdp_path, max_horizon=max_horizon, act_noise_model=act_noise, env_noise_model=env_noise)\n",
    "actor_cl = SepsisActor(id=0, policy=cl_policy_path, rng=rng)\n",
    "trajectories = sample_trajectories(env=env, agents=[actor_cl], num_trajectories=100, rng=rng)\n",
    "stats = get_stats(trajectories)\n",
    "rew_values, rew_counts = np.unique([sum([s.reward for s in t.states]) for t in trajectories], return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Clinician achieved <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">94</span> successes and <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span> failures in <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100</span> trajectories.\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Clinician achieved \u001b[1;36m94\u001b[0m successes and \u001b[1;36m6\u001b[0m failures in \u001b[1;36m100\u001b[0m trajectories.\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Clinician achieved rewards <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span><span style=\"font-weight: bold\">]</span> <span style=\"font-weight: bold\">(</span>death, max horizon reached, survival<span style=\"font-weight: bold\">)</span> with frequency <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">33</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">61</span><span style=\"font-weight: bold\">]</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Clinician achieved rewards \u001b[1m[\u001b[0m\u001b[1;36m-1.0\u001b[0m, \u001b[1;36m0.0\u001b[0m, \u001b[1;36m1.0\u001b[0m\u001b[1m]\u001b[0m \u001b[1m(\u001b[0mdeath, max horizon reached, survival\u001b[1m)\u001b[0m with frequency \u001b[1m[\u001b[0m\u001b[1;36m6\u001b[0m, \u001b[1;36m33\u001b[0m, \u001b[1;36m61\u001b[0m\u001b[1m]\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"Clinician achieved [bold]{stats['success']}[/] successes and [bold]{stats['failure']}[/] failures in [bold]{stats['success'] + stats['failure']}[/] trajectories.\")\n",
    "print(f\"Clinician achieved rewards {rew_values.tolist()} (death, max horizon reached, survival) with frequency {rew_counts.tolist()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## AI Policy\n",
    "\n",
    "Using the exact same procedure as the for human clinician, we learn the AI policy. However, instead of using the original probabilities, we utilize an alternative set of probabilities intended to make the AI policy different to the human policy (see also `learn_sepsis_mdp.ipynb` for details). Apart from the the next cell (which loads different transition matrix), remainder of the process is equivalent to what we've done so far."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(ai_mdp_path, \"rb\") as f:\n",
    "    mdp_dynamics_ai = pickle.load(f)\n",
    "    P, R = mdp_dynamics_ai[\"transition_matrix\"], mdp_dynamics_ai[\"reward_matrix\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not ai_policy_path.exists():\n",
    "    Pi = mdp.mdp.PolicyIteration(P, R, discount=discount, eval_type=1)\n",
    "    Pi.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "if not ai_policy_path.exists():\n",
    "    policy = np.zeros((State.NUM_TOTAL, SepsisAction.NUM_TOTAL))\n",
    "    policy[np.arange(len(Pi.policy)), Pi.policy] = 1\n",
    "    with open(ai_policy_path, \"wb\") as f: pickle.dump(policy, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "act_noise = UniformNoiseModel(order=Order([i for i in range(SepsisAction.NUM_TOTAL)]))\n",
    "env_noise = SepsisStateUniformNoiseModel(order=Order([i for i in range(State.NUM_TOTAL)]))\n",
    "env = Sepsis(dynamics=original_mdp_path, max_horizon=max_horizon, act_noise_model=act_noise, env_noise_model=env_noise) # we evaluate the actor using the original environment dynamics\n",
    "actor_ai = SepsisActor(id=0, policy=ai_policy_path, rng=rng)\n",
    "trajectories = sample_trajectories(env=env, agents=[actor_ai], num_trajectories=100, rng=rng)\n",
    "stats = get_stats(trajectories)\n",
    "rew_values, rew_counts = np.unique([sum([s.reward for s in t.states]) for t in trajectories], return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">AI achieved <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">96</span> successes and <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span> failures in <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">100</span> trajectories.\n",
       "</pre>\n"
      ],
      "text/plain": [
       "AI achieved \u001b[1;36m96\u001b[0m successes and \u001b[1;36m4\u001b[0m failures in \u001b[1;36m100\u001b[0m trajectories.\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">AI achieved rewards <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.0</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.0</span><span style=\"font-weight: bold\">]</span> <span style=\"font-weight: bold\">(</span>death, max horizon reached, survival<span style=\"font-weight: bold\">)</span> with frequency <span style=\"font-weight: bold\">[</span><span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">48</span>, <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">48</span><span style=\"font-weight: bold\">]</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "AI achieved rewards \u001b[1m[\u001b[0m\u001b[1;36m-1.0\u001b[0m, \u001b[1;36m0.0\u001b[0m, \u001b[1;36m1.0\u001b[0m\u001b[1m]\u001b[0m \u001b[1m(\u001b[0mdeath, max horizon reached, survival\u001b[1m)\u001b[0m with frequency \u001b[1m[\u001b[0m\u001b[1;36m4\u001b[0m, \u001b[1;36m48\u001b[0m, \u001b[1;36m48\u001b[0m\u001b[1m]\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"AI achieved [bold]{stats['success']}[/] successes and [bold]{stats['failure']}[/] failures in [bold]{stats['success'] + stats['failure']}[/] trajectories.\")\n",
    "print(f\"AI achieved rewards {rew_values.tolist()} (death, max horizon reached, survival) with frequency {rew_counts.tolist()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Comparison of Policies\n",
    "\n",
    "To better understand if and how two policies differ, we perform a brief analysis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">There is <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">18.06</span>% difference in actions taken by clinician and AI policies.\n",
       "</pre>\n"
      ],
      "text/plain": [
       "There is \u001b[1;36m18.06\u001b[0m% difference in actions taken by clinician and AI policies.\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "actions_ai = actor_ai.policy_map.argmax(axis=-1)\n",
    "actions_cl = actor_cl.policy_map.argmax(axis=-1)\n",
    "actions_diff = (actions_ai != actions_cl).astype(int).mean()\n",
    "print(f\"There is {actions_diff * 100:.2f}% difference in actions taken by clinician and AI policies.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Continuing, we plot a histogram of actions for both AI and clinician policies, to visually inspect the observed difference. For each action (a combination of antibiotics (A), vasopressors (V) and ventilators (E)) we plot the number of times both policies select the respective action."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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04wZM7Rr1y7FxcXp1KlTOnfunHJyclSrVi21aNFC3bt314gRI1S3bt1S+4uMjNSyZcu0cOFCrV27VgkJCcrOzlajRo3Us2dPjRs3TuHh4eWqtbLl2lKVl+57YbSyLF261AiidevW1T//+U9FRUUVanf99ddr9OjROnjwoF577TWdPXu2sksFAKDCfDqMSlJ4eLimTp2qqVOnunRcaVeOQkJCNGjQIA0aNKiiJRqsVqsmTJigCRMmuK1PVC3Jycn6+9//Lin/98OCBQtKXcqrVatWmj17tlatWlUZJQIA4FY+H0aBqmTevHnGm7aeeOKJMq8p6+fnp8GDB5d5nNjYWI0bN06SNH/+/EKrSUyZMkXLli1TeHi4Nm7cqJSUFM2dO1fr169XYmKiAgIC1Lp1a911110l/oOsT58+SkxM1NChQ/X6668X2+748eP67LPPtGXLFiUmJio1NVUhISFq3ry5unfvriFDhqhJkyYu9X3y5El98803io2N1e+//66TJ08qJydHderUUfv27TVw4ED1799ffn5Fz+Ms6v+R43nzAwcOyGazqXHjxrr55ps1ceJE4+UWAADXEEYBL2G327Vs2TJJ+VdFR4wYYXJF+Q4fPqwHH3yw0ESqbdu2adu2bdq1a5deeOGFcvc/e/ZszZw5U9nZ2QW+f/78eW3fvl3bt2/X1q1btWDBgjL3mZubq549exa5ysDJkye1ceNGbdy4UV988YXee++9Ul+vm5eXp5iYGK1cubLA9+Pj4zV79mxt2LBBCxcuVP369ctcIwAgH2EU8BL//e9/jRckdO3atUIT69wlPT1djzzyiM6fP69HHnlE119/vaxWq/bv36/3339fSUlJWrhwoXr37q0bb7zR5f6dJ2qFhobqnnvuUXR0tGrXrq2UlBTt27dP69evd7lfxyoW1113nW666Sa1atVKYWFhSktL07Fjx7RkyRLt3LlTP/30k1555RW98cYbJfb3zjvvaOfOnerbt6+GDBmiK664QqdPn9ann36qTZs26ejRo3rttdeKnCgJACgZYRTwEr///rux3a5dOxMr+Z+zZ88qOztbixcvVsuWLY3vt2/fXlFRURo4cKAyMzP16aefuhxG9+3bp/fff19S/soWH3/8sRo1alSgzXXXXafx48frxIkTLvXt7++vtWvXKjIystC+qKgoDR8+XO+++64+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CgAAANMQRgEAAGAawigAAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0bg2jr7zyin7//Xd3dgkAAAAf5tYw+umnn2ro0KEaNmyYFi1apNTUVHd2DwAAAB/jkdv0+/fv18svv6wbb7xRU6dO1bZt2zwxDAAAAKo4t4bR66+/XhaLRXa7XXa7Xenp6Vq+fLnGjh2rAQMGaM6cOTp79qw7hwQAAEAV5tYwOmfOHG3YsEGPPvqorrjiCkkygml8fLxmzJihnj176oknntAPP/zgzqEBAABQBbn9Nv0VV1yhJ554Qt9++63+7//+T/369VNgYKARSrOzs/XNN9/ooYceUu/evfX+++/rzz//dHcZAAAAqAI8trSTxWJRjx499O677+qHH37QlClT1LJlS0n/u1qalJSkDz74QH379tUDDzygtWvXKicnx1MlAQAAwMsEVMYgderU0X333af77rtPu3fv1ueff66vv/5aNptNUn44/fnnn/Xzzz+rdu3aGjJkiO688041b968MsoDAACASSp90ftrrrlG06ZN0+bNm/Xqq6+qU6dOkv53tfTcuXOaN2+e7rjjDt19991atmyZsrKyKrtMAAAAVALT3sBktVp15513atGiRZo2bZqqVasmi8Uii8UiKT+c7t69W88884xuvPFGvf/++6xbCgAA4GNMC6Pnz5/Xxx9/rIEDB+q5554zrn46rpA6b1+4cEEffPCBbrvtNv3yyy9mlQwAAAA3q5RnRp399NNPWrJkiTZu3Kjs7GxJMsKnxWLR9ddfr5EjR+rqq6/W6tWrtXTpUp04cUKSdPLkSU2cOFGff/65rr766souHQAAAG5WKWH0xIkTWrp0qb788ksjWDoCqCTVq1dPQ4cO1ciRI9WkSRPj+5MmTdKjjz6qVatWacaMGTpz5oyys7P10UcfaebMmZVROgAAADzIY2E0JydHGzZs0JIlS/TLL78oLy9PUtFXQW+++WYFBBRdip+fnwYPHqz27dtr8ODBys3N1a+//uqpsgEAAFCJ3B5G//jjDy1ZskQrV67U+fPnJRW+Cjps2DCNGDGiwFXQ0jRv3lzt27fXrl27eKUoAACAj3BrGL3rrru0Z88eSQUDqOMq6F133aU+ffoUexW0NHXr1i3UNwAAAKout4bR3bt3y2KxGGGxXr16Gj58uEaMGKErr7zSnUMBAADAB3jkmdEbbrihwldBi/LBBx+4rS8AAACYz61h9KGHHtLIkSMVHh7uzm4BAADgo9waRidPnuzO7gAAAODj3BpGly9fLklq2LChunfvXq4+YmNjjbVIhwwZ4qbKAAAA4I3cGkanTJkii8WiHj16lDuMzp8/Xxs3bpTFYiGMAgAA+LhKfx1oWbB0EwAAwOXBz+wCAAAAcPnyujCamZkpSapWrZrJlQAAAMDTvC6MHj58WJIUGhpqciUAAADwNK95ZjQ1NVXz58/Xn3/+KYvFopYtW5pdEgAAADys3GH05ptvLnbfr7/+WuJ+Z3a7XZmZmTp37lyBiUt9+vQpb2kAAACoIsodRhMTE2WxWAp93xEu//zzzzL3dens+ZYtW2rEiBHlLQ0AAABVRIVu0xe3BFN5l2aqW7eu7rjjDj3++OMKCgqqSGkAAACoAsodRufPn1/ga7vdrnvvvVcWi0UdOnTQX//61zL14+fnp+rVq6tevXpq2LBhecsBAABAFVTuMBoVFVXk9+12u2rVqlXsfgAAAMDBrbPpJ02aJEmKiIhwZ7cAAADwUR4JowAAAEBZeN2i9wAAALh8EEYBAABgGpdv0y9fvrzA10OGDCl2X0U59w0AAADf43IYnTJlirHYvcViKRAYnfdV1KV9AwAAwPeUewKTuxe8BwAAwOXH5TB67bXXlmsfAAAAcCmXw+iCBQvKtQ8AAAC4FLPpAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApnF5Nv24ceM8UUchFotFH3/8caWMBQAAAHO4HEa3bt3qtrcsFcdut3t8DAAAAJivXG9g4i1LAAAAcAeXw+hrr73miToAAABwGXI5jA4dOtQTdQAAAOAyxGx6AAAAmIYwCgAAANMQRgEAAGAawigAAABM4/IEpj///LPA11dccUWx+yrKuW8AAAD4HpfDaJ8+fYwF6S0Wi/bt21fkvoq6tG8AAAD4nnItei+VvPB9RRbFt1gsLKoPAABwmSjXM6OeCqLuOB4AAABVh8tXRn///fdy7TNDYmKiFixYoE2bNikpKUlBQUFq0qSJBgwYoNGjR6t69erl7vvQoUPasmWL9u7dq4MHD+rMmTM6d+6c/P39VbduXXXo0EF33HGHbr755jI9upCTk6MlS5Zo1apVOnz4sGw2mxo0aKDrr79eY8eOVcuWLctdKwAAgLcq9216b7dx40bFxMQoNTXV+F56erouXLiguLg4LVmyRLNmzVJkZGS5+v/3v/+tVatWFbnv+PHjOn78uL7++mtFRUXp3XffVZ06dYrt6+zZs5o4caL27t1b4PvHjh3T4sWLtWzZMr3wwgsaMWJEuWoFAADwVj4ZRvft26fJkycrIyNDVqtVDz30kKKjo5WRkaE1a9bo888/V3x8vCZOnKilS5cqJCTE5TECAgJ0zTXXqEuXLmrVqpXq1aunsLAwpaSk6PDhw1q8eLEOHjyorVu36pFHHtGnn34qP7/CT0Xk5uZq0qRJRhDt16+fRowYodq1a2v37t3697//rTNnzuiFF15QgwYN1LNnzwr//wEAAPAWPhlGp02bpoyMDAUEBGjOnDnq3Lmzsa979+6KjIzUjBkzFB8fr7lz5+rxxx93eYxXX31VAQFF/++7/vrrNWrUKP3lL3/R+vXrtXPnTn333Xe6+eabC7VdtmyZtm/fLkm655579OKLLxr7OnbsqJtuuknDhg1Tamqqpk2bphtuuKHYcQEAAKoan1v0fs+ePdq2bZskafjw4QWCqMP48ePVvHlzSdL8+fOVnZ3t8jilBUJ/f3898MADxteOmi41Z84cSVLt2rX1t7/9rdD+yMhIPfTQQ5Kko0eP6ptvvnG5VgAAAG/l8Utsqamp+umnn7R3714dPXpUKSkpysrKUkhIiOrWrau2bduqa9euateunVvG27Bhg7E9fPjwItv4+flpyJAheuutt5SSkqLY2Fj16NHDLeM7q1GjhrGdlZVVaP+RI0d06NAhSVL//v2LnVA1dOhQvfXWW5Lyz2/AgAFurxUAAMAMHgujp0+f1j//+U999dVXysjIKLbdihUrJEktWrTQQw89pDvuuKNC4zpueVut1hID7rXXXmts79ixwyNh9KuvvjK2r7rqqkL7HbVKUlRUVLH91K9fX02bNlV8fLx27Njh3iIBAABM5JHb9Bs2bNBtt92mpUuXKj09XVL++qEl/frvf/+rmJgYTZgwQWlpaeUe23GlMSIiosRb6c7h0HGMO5w9e1Y7d+7UM888ow8//FCSVKdOHQ0cOLDYWi+tpyiO/SdOnJDNZnNbvQAAAGZy+5XRtWvX6q9//atycnKM9TX9/PzUrl07tWjRQrVr11ZQUJDS0tJ0/PhxxcXF6dSpU5LyA+vmzZt1//3365NPPlFQUJBLY2dmZurcuXOSpEaNGpXYtlatWrJarbLZbEpKSirHmf7P2LFjtXXr1iL31alTR++//75CQ0ML7XMet2HDhiWO0bhxY0n5/4+SkpJKDa8AAABVgVvD6MmTJ/XCCy8YQTQ4OFgPPvigRo0apbCwsGKPi42N1TvvvKMdO3bIbrdr7969eueddxQTE+PS+M5XVK1Wa6ntq1evLpvN5rErjWPHjtWjjz5a7Lk71+v8fGlRnJ8n5cooAADwFW4No5999plSUlJksVgUFham2bNn6+qrry71uOjoaH366ad65ZVX9Omnn8put+vTTz/VY489VqZQ6ZCZmWlsBwYGltreceW1pGday2L69OlKT0+X3W7XxYsXFRcXp88++0wLFy7U8ePH9eqrr6pevXoVqtf5KnFF6wUAAPAWbn1mdOPGjcb2yy+/XKYg6uy5554zJh1lZGTo559/dun4atWqGdtlWa7JMcM9ODjYpXEu1aRJE7Vq1UqtW7dWt27ddN9992nlypXq2bOnvvvuO915551FPgrgSr3Os/ErWi8AAIC3cGsYTUxMlCTVq1dPffv2db0YP78Cr7w8fvy4S8c73+ouy61sx+QqV66+llW1atU0ffp0Va9eXSdOnNCMGTMKtXGut7RJW45aJc/UCwAAYAa3hlG73S6LxaKmTZuWu49mzZqV+9hq1aqpdu3aklTqpKQLFy4YgbW0yU7lFRYWpi5dukiSvv3220JXP53HTU5OLrGvEydOSJIsFovH6gUAAKhsbg2jjpBUkWcanY8tbYZ5UVq0aCFJSkhIUE5OTrHtDh8+bGw73sbkCXXq1JGUf2XTMdO/qHGd6ymKY3/jxo25MgoAAHyGW8NodHS07Ha7Dh48qNTU1HL14VgI3t/fX127dnX5eMcxNptNv/32W7Htfv31V2PbcfXSE06ePGlsXxoinc+vuKWhJOnUqVOKj4+X5NlaAQAAKptbw+hdd90lf39/ZWVl6YMPPnD5+OTkZC1atEgWi0W9e/dWgwYNXO7D+VnVpUuXFtkmLy9Py5cvlySFhoYqOjra5XHKIikpSTt37pQkhYeHKyQkpMD+Zs2aGVdH165dW+C5UGfLli0ztsvzLC4AAIC3cmsYbd26tf7yl7/Ibrdr3rx5eu+995SXl1emYw8fPqx7771XKSkpatiwoV5++eVy1dCxY0d169ZNUn4YdYRBZ3PmzDHefjRu3LhCyyrFxsaqdevWat26taZMmVLo+CNHjmjLli0l1nHx4kU9/fTTxnOigwcPLrLd+PHjJUnnz58vcpJTQkKCPvroI0lSZGSkbrnllhLHBQAAqErc/gamCRMmyGq16h//+If+9a9/6euvv9aoUaPUo0cPNW3a1Hgrk5Qf2Pbs2aM1a9ZoxYoVys3NVZcuXfTWW2+VuEh+aZ599lmNGjVKGRkZGj9+vB5++GFFR0crIyNDa9as0eLFiyVJTZs21f333+9y/ydPntR9992nq6++Wn379lW7du1Ur149BQQE6NSpU9qxY4eWLl1qvFmqVatWmjhxYpF9DR06VEuXLtWOHTu0cOFCnT59WiNGjFCtWrW0Z88e/etf/1Jqaqr8/Pz07LPPlviKUwAAgKrG5WRz8803l6mdv7+/7Ha7Dh8+rOnTp0vKX9g9NDRUgYGBSktL08WLF432jpn4J06c0JgxY2SxWLRhwwZXy5MktW3bVjNnzlRMTIxSU1P19ttvF2rTtGlTzZo1q9Ctc1f8/vvv+v3330ts06tXL7322msF3qDkzN/fXx988IEmTpyovXv3at26dVq3bl2BNkFBQXrhhRfUs2fPctcKAADgjVwOo4mJiQWubpbEuZ3dbldWVpZOnz4ti8Uiu91eoJ2jbVJSkhFMK6JPnz5auXKl5s+fr02bNik5OVmBgYGKiIhQ//79NWbMmGIDYmm6dOmi2bNn6+eff1ZcXJySk5N1+vRpZWRkKCQkROHh4erUqZNuv/32Mk3CCgsL06JFi/T5559r9erVOnTokNLT09WgQQN1795d48aNU8uWLctVKwAAgDcr1z1f5yDpjuMr2l9xwsPDNXXqVE2dOtWl46Kjo3XgwIFi9wcGBqpHjx7q0aNHRUs0BAQE6J577tE999zjtj4BAAC8ncthdP78+Z6oAwAAAJchl8NoVFSUJ+oAAADAZcitSzsBAAAAriCMAgAAwDSEUQAAAJiGMAoAAADTePx1PqdPn9aePXuUnJysixcvKisrq8zHTpo0yYOVAQAAwGweC6Nr1qzR3LlzFRcXV+4+CKMAAAC+ze1hNCcnRzExMVq7dq2k0he0d7xp6dJ2FX0DEwAAALyf28PotGnT9PXXXxtfX3HFFerQoYN27typkydPymKxaMiQIUpLS1NycrL279+vrKwsI3z27NlTderUcXdZAAAA8EJuDaN//PGHFi1aJEny8/PTlClTNG7cOEnSgw8+qJMnT0qSXnvtNeOYzMxMrV69Wu+++64RTv/5z3+qc+fO7iwNAAAAXsits+mXLl0qu90ui8Wie++91wiiJalWrZqGDx+uVatWqVOnTkpOTtbDDz+sP//8052lAQAAwAu5NYxu27ZNUv7znuPHj3fp2NDQUP3rX/9SrVq1lJKSopdeesmdpQEAAMALuTWM/vnnn7JYLIqMjFT9+vUL7HOekJSdnV3k8WFhYRo5cqTsdrt++ukn47Y+AAAAfJNbw+iFCxckSQ0aNCi0LygoyNi22WzF9tG1a1dJUl5ennbu3OnO8gAAAOBl3BpGAwMDJRW9nFNISIixnZycXGwfZW0HAACAqs+tYbRevXqSpJSUlEL7wsPDje19+/YV20dSUpKxnZGR4cbqAAAA4G3cGkabN28uu92uo0ePFro62rZtW2N7zZo1xfaxatUqY7uo2/0AAADwHW4No126dJGUf0Vz//79Bfb16NFDNWrUkCT9+OOPmjdvXoH9drtdH3zwgb7//nvje926dXNneQAAAPAybl30vkePHnr77bclSRs2bChwNTQ4OFijR4/WrFmzZLFY9MYbb2jhwoVq166dJGnPnj06ceKEpPyZ971799aVV17pzvIAAADgZdx6ZbRt27aKjIyU3W7XkiVLlJOTU2D/Y489pmuuuca4hX/8+HGtW7dO69atM4KoJDVu3FivvPKKO0sDAACAF3JrGJWkzz//XN9//72++OKLAmuLSvlvW5ozZ45GjhwpPz8/2e32Qr/69OmjxYsXG5OhAAAA4LvceptekmrVqqVatWoVu79GjRp65ZVX9NRTT+mXX37RiRMnlJ2drQYNGqhbt27cmgcAALiMuD2MllXt2rXVv39/s4YHAACAF3D7bXoAAACgrAijAAAAME2l3aY/dOiQjh49qpSUFGVnZ6tGjRqqW7eu2rZtq5o1a1ZWGQAAAPAiHg2j27dv16JFi7Rx40bZbLZi27Vo0ULDhw/X8OHDCaYAAACXEY/cpj937pwmT56sMWPGaPXq1UpLSzPWFi1qOac//vhDb7zxhvr371/iq0IBAADgW9x+ZTQ5OVn33Xef4uPjC72f3t/fXzVr1lRQUJDS0tKUmpoqKT+gWiwWnTlzRk8//bSOHz+uiRMnurs0AAAAeBm3htG8vDw9+eSTOnLkiLHgfdOmTXX33XfrxhtvVLNmzeTn97+LsRcuXNCePXv01VdfafXq1crNzZXdbtfMmTPVunVr9ezZ053lAQAAwMu49Tb9ypUrtWvXLiOIPvLII/rqq6903333qXnz5gWCqJS/QP6NN96o119/XcuXL1dERIQsFovsdrumTZvmztIAAADghdwaRletWmVs33fffXryySfl7+9fpmNbtGihjz/+2JjAdOzYMe3atcud5QEAAMDLuDWMHjx4UJIUFBSkxx57zOXjGzVqpLvvvrtQfwAAAPBNbg2jFy5ckMViUatWrRQSElKuPrp27Wpsnz9/3k2VAQAAwBu5NYzWq1dPkhQcHFzuPpyPdfQHAAAA3+TWMNqyZUvZ7XbFx8eXu4/Dhw8b2y1atHBDVQAAAPBWbg2jgwcPliSdPn1aGzZscPn4vLw8LVmyRJIUGRmpjh07urM8AAAAeBm3htH+/fsrKipKdrtdL774ossTkKZPn659+/bJ399fzz33nDtLAwAAgBdyaxj18/PTP//5T3Xq1ElnzpzR3XffrQ8//LDUiUjbtm3T2LFjtXDhQgUFBemll15Sjx493FkaAAAAvJDLb2B6//33S21z3XXX6ejRozp37pzeeecdvf/++2rfvr1atmyp2rVrKzAwUGlpaTp+/Lji4uJ08uRJ45WgN910k5KTk/X+++9r0qRJ5TopAAAAVA3lCqOONyyVxvE2pZycHO3evVu7d+8u1Mbx/npHn99++62+/fZbSSKMAgCAy0pedpb8AoN8bqySlOvd9I4A6c5jLt1f1sALAADgK/wCg7R3/I3KtaV6dBx/a4g6zPnRo2OUlcthdOjQoZ6oAwAAAJJybanKS/dsGPUmLofR1157zRN1AAAA4DLk1tn0AAAAgCsIowAAADANYRQAAACmKdds+vKw2Ww6fvy4UlJSlJWVpZo1ayosLEzh4eGVVQIAAAC8jEfDaHJyshYvXqwNGzbo0KFDysvLK9QmNDRUXbt21YgRI9SrVy+WdAIAALiMeCSM5uXl6aOPPtK//vUv5eTkSCq4jqhjMXxJunDhgr777jt99913atOmjd544w21bNnSE2UBAADAy7j9mdHc3Fw98cQTevfdd5WdnS2p8IL2RX1tt9u1b98+jRgxQtu2bXN3WQAAAPBCbr8yOmPGDG3YsMG43W61WnXHHXeod+/eatWqlerUqWO8mz4hIUF79uzRypUrtXv3blksFmVkZOjhhx/W6tWr1ahRI3eXBwAAAC/i1iujhw4d0ieffGIE0T59+mj9+vV6+eWX1atXL11xxRWqXr26AgICVKtWLXXo0EGjR4/W4sWL9c4776hGjRqyWCxKS0vTW2+95c7SAAAAyi83u9LGsXjB++Irk1uvjK5YsUI5OTmyWCzq1auXPvjggzJPSLr11lvVsGFDjRkzRjk5OVq7dq1eeukl1ahRw50lAgAAuM4/UFpxt5Rt89wYgVZp8CJZAgI9N4YXcuuV0c2bN0vKn6D0wgsvuDwzvlOnThoyZIgkKScnR1u3bnVneQAAAOWXbZNyPPjLk0HXi7k1jCYlJclisahFixZq3Lhxufro2bOnsf3nn3+6qzQAAAB4IbeG0YsXL0qS6tSpU+4+nI9NS0urcE0AAADwXm4No7Vq1ZLdbldSUlK5+0hOTi7QHwAAAHyXW8NokyZNJEkJCQk6ePBgufpYt25dof4AAADgm9waRp2f93z++eeVkZHh0vEbNmzQ+vXrJUnVq1dXt27d3FkeAAAAvIxbw+jQoUNVvXp1SdKePXs0ZswYHThwoNTjcnNzNXfuXE2ePFlS/mz8O++8U0FBl9c6WwAAAJcbt64z2rBhQz3xxBN64403ZLFYFBcXp6FDh+raa6/VTTfdpFatWql27drGG5iOHz+uvXv3at26dTp9+rTxmtCGDRtq0qRJ7iwNAAAAXsjtrwO9//77lZycrHnz5slisSgvL09bt24tcc1Qu91urElar149zZ49W6Ghoe4uDQAAAF7GrbfpHaZMmaKZM2eqbt26kvLDpuOqp2Pb+WvHf2+99VatXLlSzZs390RZAAAA8DJuvzLqMGDAAPXt21fr16/Xhg0btHv37kKL2FerVk1t2rRRt27dNGzYMDVr1sxT5QAAAMALeSyMSlJgYKBuv/123X777ZLyJyqlpKQoKytLNWvWlNVq9eTwAAAA8HJuDaNTp041tidNmqTw8PAC+/39/Sv0diYAAAD4FreG0WXLlslisahu3bp67bXX3Nk1AAAAfJBbJzCFhIRIkiIjI93ZLQAAAHyUW8No/fr1JUl5eXnu7BYAAAA+yq1htFOnTrLb7Tp8+DCBFAAAAKVyaxgdPHiwJCklJcV4xzwAAABQHLeG0euuu0633Xab7Ha7Xn31VcXHx7uzewAAAPgYt68z+ve//102m02bNm3SnXfeqUmTJmno0KGqVauWu4cqk8TERC1YsECbNm1SUlKSgoKC1KRJEw0YMECjR49W9erVy913enq6fvzxR/3000+Ki4tTQkKCbDabQkJC1LRpU/Xo0UN333238SxtWfr75JNPtHbtWh07dkxZWVlq1KiRevXqpbFjxxZaKgsAAKCq88g6o3Xq1FGNGjWUmpqqN954Q2+++aaaN2+uiIgI1ahRw3gPfUksFoumT59eoXo2btyomJgYpaamGt9LT0/XhQsXFBcXpyVLlmjWrFnlmv3/+++/a9SoUbLZbIX2nT9/Xrt27dKuXbs0b948/f3vf9dtt91WYn9Hjx7VxIkTC11NPnLkiI4cOaIlS5bozTffVO/evV2uFQAAwFt5ZJ1RB4vFIrvdrpycHB08eFAHDx50qb+KhNF9+/Zp8uTJysjIkNVq1UMPPaTo6GhlZGRozZo1+vzzzxUfH6+JEydq6dKlxrJUZZWammoE0S5duqh3795q3769ateurbNnz2r9+vVasmSJUlNT9de//lU1atRQz549i+3LOYiOHDlSt912m4KDgxUbG6uPPvpIqampmjx5sj777DO1adOm3P9fAAAAvInbb9Pb7XaXvl+cslw9Lcm0adOUkZGhgIAAzZkzR507dzb2de/eXZGRkZoxY4bi4+M1d+5cPf744y717+fnpwEDBmjSpElq0aJFof09evTQTTfdpEmTJik3N1evvvqqbrrppiLPa/bs2UYQjYmJ0YMPPmjs69y5s6KiojR27Filp6dr+vTpWrBggUu1AgAAeCu3htFJkya5s7ty27Nnj7Zt2yZJGj58eIEg6jB+/Hh9+eWXOnTokObPn6+HH35YgYGBZR6jS5cu6tKlS4lt+vbtq379+mndunVKSEjQvn371K5duwJtsrOzjXDZvHlzjR8/vsixhg8frsWLF2vr1q3as2ePOnbsWOZaAQAAvJVPhtENGzYY28OHDy+yjZ+fn4YMGaK33npLKSkpio2NVY8ePdxeS3R0tNatWydJSkhIKBRGY2NjdfHiRUnSkCFD5OdX9AIHw4YN0+LFiyXlnx9hFAAA+AK3Lu3kLbZv3y5JslqthcKfs2uvvdbY3rFjh0dqycrKMrb9/f0L7XfUKklRUVHF9tO+fXtj5r+nagUAAKhsbrkyeuDAAf3www86ePCgzp8/r8DAQNWtW1cdO3ZU7969Va9ePXcMU2aHDh2SJEVERCggoPhTvOqqqwod425bt241tps3b15ov/O4zvVcKiAgQBERETpw4IDHagUAAKhsFQqjp06d0vPPP6/vv/++yP1ffPGFgoKCNHbsWD311FPF3oJ2p8zMTJ07d06S1KhRoxLb1qpVS1arVTabTUlJSW6v5ffffzf+37Rq1arIMOoY12q1KjQ0tMT+GjdurAMHDujs2bPKyspSUFCQ22sGAACoTOVOh8nJyRo5cqS+//77EmfQZ2Zmavbs2Xr00UfLXaQr0tLSjG2r1Vpqe8et76LWC62IrKwsPfvss8rNzZUkTZ48uch2jnpdqdX5OAAAgKqs3GH0b3/7m06cOCHpf+uJ+vv7q169egXetuTY9/3332vOnDkVr7gUmZmZxnZZZsc7ri5mZGS4tY5XXnlFcXFxkqShQ4eqT58+RbZz1OtKrc7HAQAAVGXlCqM7duxQbGysETRbtWqlDz/8UDt27NCPP/6oX375RT///LOef/55hYaGGu3+7//+T9nZ2e4+hwKqVatmbJdlLMcEo+DgYLfV8NFHH2nJkiWSpA4dOuiFF14otq2jXldqdT4OAACgKitXGF2zZo2x3alTJ33++efq1atXgSt3derU0ejRo7Vo0SLVrFlTknTu3Dlt2bKlgiWXrEaNGsZ2WW69p6enSyrbbfKyWLRokd5++21J+ROSZs2aVWLfjnpdqdX5OAAAgKqsXGF09+7dxvaLL75Y4lW6Zs2aFXijkPOxnlCtWjXVrl1bkkqdlHThwgUjBJY22aksVq9erZdfflmSFB4errlz5yosLKzEYxzj2mw2paSklNjW8VhEWFgYk5cAAIBPKFcYTUxMlCRdccUVZXpP+i233FLoWE9yvJ4zISFBOTk5xbY7fPiwsV3UTHdXfPvtt/p//+//KS8vT/Xr19e8efPKFHCdx3Wu51I5OTk6duyYW2oFAADwFuUKoxcvXpTFYlF4eHiZ2ju3c7xtyJO6du0qKf9q42+//VZsu19//dXYLu3VniXZsmWL/vKXvygnJ0e1a9fW3LlzFRER4VKtUsE1SS8VFxdnXMWtSK0AAADepFxh1DHZpqyTaJxvKTtPwvGUvn37GttLly4tsk1eXp6WL18uSQoNDVV0dHS5xtqxY4ceffRRZWVlqWbNmpo9e7ZatmxZ5uOjoqKMZ2qXL19e7DJZX375pbHtfH4AAABVmU++DrRjx47q1q2bpPwwunPnzkJt5syZY7zJaNy4cYWWVoqNjVXr1q3VunVrTZkypchx9u/fr4ceekg2m01Wq1UfffSR2rdv71KtjpcCSPlvY5o9e3ahNjt37jRCdVRUFO+lBwAAPsMtrwP1Rs8++6xGjRqljIwMjR8/Xg8//LCio6OVkZGhNWvWaPHixZKkpk2b6v7773e5/4SEBD3wwAPGpKMnn3xSNWvW1MGDB4s9pm7duqpbt26h7z/wwANas2aN4uPjNWPGDCUkJOi2225TcHCwYmNj9eGHHyonJ0fBwcF65plnXK4VAADAW/lsGG3btq1mzpypmJgYpaamGsstOWvatKlmzZqlkJAQl/vftm2bzpw5Y3z92muvlXrMpEmT9Pjjjxf6fkhIiGbNmqWJEycqPj5eixcvNsKyc5s333yzTBPGAAAAqooKhdE9e/Zo3LhxHjnGYrHo448/Lm9pkqQ+ffpo5cqVmj9/vjZt2qTk5GQFBgYqIiJC/fv315gxYwq8YtNMkZGRWrZsmRYuXKi1a9cqISFB2dnZatSokXr27Klx48aVecIYAABAVVGhMJqSklJgRnpJLBZLmY+x2+1G+4oKDw/X1KlTNXXqVJeOi46O1oEDB4rdP2zYMA0bNqyi5RVgtVo1YcIETZgwwa39AgAAeKtyh9HiZn0DAAAAZVWuMDp06FB31wEAAIDLULnCaFkm6wAAAACl8cl1RgEAAFA1EEYBAABgGsIoAAAATEMYBQAAgGkIowAAADANYRQAAACmIYwCAADANIRRAAAAmIYwCgAAANMQRgEAAGAawigAAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0hFEAAACYhjAKAAAA0xBGAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATEMYBQAAgGkIowAAADANYRQAAACmIYwCAADANIRRAAAAmIYwCgAAANMQRgEAAGAawigAAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0hFEAAACYhjAKAAAA0xBGAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQCoAvKys3xyLAAIMLsAAEDp/AKDtHf8jcq1pXp0HH9riDrM+dGjYwCAM8IoAFQRubZU5aV7NowCQGXjNj0AAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0hFEAAACYhjAKAAAA0xBGAaC8crMrdSxLYFDljQcAlYRF7wGgvPwDpRV3S9k2z44TaJUGL5IlINCz4wCACQijAFAR2TYpx8NhFAB8GLfpAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATOPzrwNNTEzUggULtGnTJiUlJSkoKEhNmjTRgAEDNHr0aFWvXr3cfefl5enw4cPas2eP9uzZo7179+rAgQPKzs6WJM2fP1/R0dFl7i89PV2ffPKJ1q5dq2PHjikrK0uNGjVSr169NHbsWIWHh5e7VgAAAG/k02F048aNiomJUWpqqvG99PR0XbhwQXFxcVqyZIlmzZqlyMjIcvW/YsUKTZkyxS21Hj16VBMnTlR8fHyB7x85ckRHjhzRkiVL9Oabb6p3795uGQ8AAMAb+Oxt+n379mny5MlKTU2V1WrV5MmTtWjRIs2bN08jR46UJMXHx2vixIkFwqor7Ha7sR0YGKh27dqpVatWLveTmppaIIiOHDlS8+bN06JFizR58mRZrValpqZq8uTJ2r9/f7lqBQAA8EY+e2V02rRpysjIUEBAgObMmaPOnTsb+7p3767IyEjNmDFD8fHxmjt3rh5//HGXx2jRooWee+45dejQQW3atFG1atX03nvv6eDBgy71M3v2bCOIxsTE6MEHHzT2de7cWVFRURo7dqzS09M1ffp0LViwwOVaAQAAvJFPXhnds2ePtm3bJkkaPnx4gSDqMH78eDVv3lxS/rOdjuc8XdGxY0eNHTtWnTp1UrVq1cpVa3Z2thEumzdvrvHjxxdq06VLFw0fPlyStHXrVu3Zs6dcYwEAAHgbnwyjGzZsMLYdIe5Sfn5+GjJkiCQpJSVFsbGxlVFaIbGxsbp48aIkaciQIfLzK/pHMmzYMGPb+fwAAACqMp8Mo9u3b5ckWa1WtWvXrth21157rbG9Y8cOj9dVFEetkhQVFVVsu/bt2xsz/82qFQAAwN18MoweOnRIkhQREaGAgOIfi73qqqsKHVPZnMd1rudSAQEBioiIKHQMAABAVeZzYTQzM1Pnzp2TJDVq1KjEtrVq1ZLVapUkJSUleby2ojjGtVqtCg0NLbFt48aNJUlnz55VVlaWx2sDAADwNJ8Lo2lpaca2I2iWxHHr22azeaymkjjqdaVW5+MAAACqMp8Lo5mZmcZ2YGBgqe2DgoIkSRkZGR6rqSSOel2p1fk4AACAqsznwqjzEktlWa7Jcbs7ODjYYzWVxFGvK7U6HwcAAFCV+VwYrVGjhrFdllvv6enpksp2m9wTHPW6UqvzcQAAAFWZz4XRatWqqXbt2pJKn5R04cIFIwSWNtnJUxzj2mw2paSklNj2xIkTkqSwsLACt+wBAACqKp8Lo1L+azolKSEhQTk5OcW2O3z4sLHteBtTZXMe17meS+Xk5OjYsWOFjgEAAKjKfDKMdu3aVVL+1cbffvut2Ha//vqrsd2lSxeP11UUR61S/qs+ixMXF2dcxTWrVgAAAHfzyTDat29fY3vp0qVFtsnLy9Py5cslSaGhoYqOjq6M0gqJiopSzZo1JUnLly+X3W4vst2XX35pbDufHwAAQFXmk2G0Y8eO6tatm6T8MLpz585CbebMmWO8yWjcuHGFllaKjY1V69at1bp1a02ZMsVjtQYFBWns2LGS8t+sNHv27EJtdu7caYTqqKgodezY0WP1AAAAVKbi35VZxT377LMaNWqUMjIyNH78eD388MOKjo5WRkaG1qxZo8WLF0uSmjZtqvvvv7/c4zhfsZSk/fv3G9s//vijEhMTja8jIiKMkOzsgQce0Jo1axQfH68ZM2YoISFBt912m4KDgxUbG6sPP/xQOTk5Cg4O1jPPPFPuWgEAALyNz4bRtm3baubMmYqJiVFqaqrefvvtQm2aNm2qWbNmKSQkpNzjTJ06tdh9//nPfwp8PXTo0CLDaEhIiGbNmqWJEycqPj5eixcvNsKyc5s333xTbdq0KXetAAAA3sZnw6gk9enTRytXrtT8+fO1adMmJScnKzAwUBEREerfv7/GjBlT4BWbZoqMjNSyZcu0cOFCrV27VgkJCcrOzlajRo3Us2dPjRs3TuHh4WaXCQAA4FY+HUYlKTw8XFOnTi3xCmZRoqOjdeDAgVLblaVNWVmtVk2YMEETJkxwW58AAADezCcnMAEAAKBqIIwCAADANIRRAAAAmIYwCgAAANMQRgEAAGAawigAAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0hFEAAACYhjAKAAAA0xBGAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATEMYBVBl5GVn+eRYAHA5CzC7AAAoK7/AIO0df6NybakeHcffGqIOc3706BgAgHyEUQBVSq4tVXnpng2jAIDKw216AAAAmIYwCgAAANMQRgEAAGAawiiAisvNrrRxLIFBlTMWAKBSMIEJQMX5B0or7paybZ4bI9AqDV4kS0Cg58YAAFQ6wigA98i2STkeDKMAAJ/EbXoAAACYhjAKAAAA0xBGAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATEMYBQAAgGkIowAA1+Vm++ZYACpdgNkFAACqIP9AacXdUrbNs+MEWqXBizw7BgBTEUYBAOWTbZNyPBxGAfg8btMDAADANIRRAAAAmIYwCgAAANMQRgEAAGAawigAAABMQxgFAACAaQijAAAAMA1hFAAAAKYhjAIAAMA0hFEAAACYhjAKAAAA0xBGAQAAYBrCKAAArsjN9s2xAJMEmF0AAABVin+gtOJuKdvm2XECrdLgRZ4dA/AChFEAAFyVbZNyPBxGgcsEt+kBAABgGsIoAAAATEMYBQAAgGkIowAAADANYRQAAACmIYwCAADANIRRAAAAmIYwiiorLzvLp8YBAOByxKL3qLL8AoO0d/yNyrWlemwMf2uIOsz50WP9AwBwuSOMokrLtaUqL91zYRQAAHgWt+kBAABgGsIoAAAATOPTt+kTExO1YMECbdq0SUlJSQoKClKTJk00YMAAjR49WtWrV3fLON9//70+//xz7d27V2fPnlVYWJg6dOigkSNHqmfPnmXqIycnR0uWLNGqVat0+PBh2Ww2NWjQQNdff73Gjh2rli1buqVWAAAAb+KzYXTjxo2KiYlRaur/nidMT0/XhQsXFBcXpyVLlmjWrFmKjIws9xh5eXl6/vnn9cUXXxT4fnJyspKTk7VhwwaNGDFCr7zyivz8ir8IffbsWU2cOFF79+4t8P1jx45p8eLFWrZsmV544QWNGDGi3LVWmtxsyT+w0sayBAZJ6ZUzHAAAcD+fDKP79u3T5MmTlZGRIavVqoceekjR0dHKyMjQmjVr9Pnnnys+Pl4TJ07U0qVLFRISUq5xZs6caQTRtm3b6sEHH1STJk107Ngx/d///Z/27dunJUuWKCwsTE899VSRfeTm5mrSpElGEO3Xr59GjBih2rVra/fu3fr3v/+tM2fO6IUXXlCDBg3KfKXVNP6B0oq7pWybZ8cJtEqDF8kSUEnBFwAAeIRPhtFp06YpIyNDAQEBmjNnjjp37mzs6969uyIjIzVjxgzFx8dr7ty5evzxx10e48iRI5ozZ44kqX379lq4cKGCg4MlSR07dlSfPn00ZswYxcXFafbs2Ro+fHiRV2GXLVum7du3S5Luuecevfjii8a+jh076qabbtKwYcOUmpqqadOm6YYbblBAgJf/2LJtUo6HwygAAPAJPjeBac+ePdq2bZskafjw4QWCqMP48ePVvHlzSdL8+fOVnZ3t8jgff/yxcnJyJEnPP/+8EUQdqlevrueff15S/vOg8+bNK7IfR6CtXbu2/va3vxXaHxkZqYceekiSdPToUX3zzTcu1woAAOCtfC6MbtiwwdgePnx4kW38/Pw0ZMgQSVJKSopiY2NdGsNut+vbb7+VJF111VXq1KlTke06deqkZs2aSZK+/fZb2e32AvuPHDmiQ4cOSZL69+9f7ISqoUOHGtvO5wcAAFDV+VwYddzytlqtateuXbHtrr32WmN7x44dLo1x/PhxnTx5slA/RYmKipKUP6np+PHjRdbq3K4o9evXV9OmTctVKwAAgDfzuTDquNIYERFR4rOVV111VaFjyuqPP/4osp/Sxjl8+HCRtbrSz4kTJ2Sz8TwmAADwDT4VRjMzM3Xu3DlJUqNGjUpsW6tWLVmtVklSUlKSS+M4ty9tHOf9J06cKLafhg0blthP48aNJeU/IuBqvQCAssnLzjK7BOCy4+XTsl2TlpZmbDuCZkmqV68um83m8pVGV8Zxfg700nGc+6lRo0a5+ymLzMxMSa5fBS6XZEk5Hv53ToCk335TfHaAcuyl/6zLyz+vmgJ/+81j/fsUT//cK+lnLrn4c/eh3++SF5/7zL8qJ+WcR4fyq1ZdV015v2yNK/HcvY4P/Z53+TP+cv2cKydH5nBkkOL4VBh1PtnAwNLXnwwKCpIkZWRkeGwcxxhFjeOufsrC8bxqTEyMy8d6rXeHVcIgGdKwyhgHZVIpP3PJK3/unHslOHcZn7sXulw/433wz/rx48fVpUuXYvf7VBitVq2asV2W5ZqysvJvx1y6LJM7x3GMUdQ4l/bj/LUr/ZRFjx49NGPGDF155ZUljgMAAOAOmZmZOn78uHr06FFiO58Ko863ustyKzs9Pf89kmW5pV/ecRxjFDWOcz9paWklhsSS+imLsLAwDRo0yOXjAAAAyqukK6IOPjWBqVq1aqpdu7ak0iclXbhwwQiSpU1CupRz+9LGcd7vmIRUVD/Jyckl9uOY/GSxWFyuFwAAwFv5VBiVpBYtWkiSEhISjDckFcV5mSXH25hcHePSfkob59Llm5zHLWs/jRs3LteVUQAAAG/kc2G0a9eukvJvn/9WwiyxX3/91dguyyVkZ1deeaUaNGhQqJ+SxmnYsKGuvPLKImuVpK1btxbbx6lTpxQfH1+uWgEAALyZz4XRvn37GttLly4tsk1eXp6WL18uSQoNDVV0dLRLY1gsFt18882S8q9Y7tq1q8h2u3btMq5o3nzzzbJYLAX2N2vWzLg6unbt2gLPhTpbtmyZse18fgAAAFWdz4XRjh07qlu3bpLyw+jOnTsLtZkzZ46x9tW4ceMKLasUGxur1q1bq3Xr1poyZUqR49x7773y9/eXJP39738vtNxSRkaG/v73v0uSAgICdO+99xbZz/jx4yVJ58+f14wZMwrtT0hI0EcffSRJioyM1C233FL0iQMAAFRBPjWb3uHZZ5/VqFGjlJGRofHjx+vhhx9WdHS0MjIytGbNGi1evFiS1LRpU91///3lGqNZs2Z64IEHNGvWLMXFxWnUqFGaMGGCmjRpomPHjuk///mP9u3bJ0l64IEHjHfLX2ro0KFaunSpduzYoYULF+r06dMaMWKEatWqpT179uhf//qXUlNT5efnp2effbbEV5wCAABUNRa73W43uwhP2Lhxo2JiYpSamlrk/qZNm2rWrFmKjIwstC82Nlbjxo2TlB8WX3/99SL7yMvL03PPPVfs4wCSdOedd+rvf/+7/PyKvwh99uxZTZw4UXv37i1yf1BQkF544QWNGDGi2D4AAACqIp+9zNanTx+tXLlS8+fP16ZNm5ScnKzAwEBFRESof//+GjNmTIFXbJaHn5+fpk+frltvvVWLFy/W3r17de7cOdWpU0cdOnTQXXfdpZ49e5baT1hYmBYtWqTPP/9cq1ev1qFDh5Senq4GDRqoe/fuGjdunFq2bFmhWgEAALyRz14ZBQAAgPfzuQlMAAAAqDp89jY9UBW98MILxgS7efPmqXv37mU+dvPmzXrggQckSWPHjtVzzz3nkRorg/Nz22U1btw4Pfvssx6qqOLKe05//etfdcMNN+jixYsKDw/Xt99+W2iZuJI8/fTTWr16taT8ZeLatm3rUg1m2rp1q8aOHWt8/dlnn/nEWstlOa/Vq1fr6aefliQ9+uijevLJJ8vc/8WLF3XDDTcoMzNTrVu31sqVK91TeAWV5+dZFT4LKvu8MjMzfe4zgSujgBcZPHiwse3qXyArVqwwtocMGeKukmCyatWqqX///pKkxMREbdu2rczHpqamasOGDZKkVq1aecVfOq5wXmNZkrE+dFVXlvPq27evQkJCJEmrVq1yqf+1a9cqMzNTknd9FlzOP0938sXPBK6MAl6ka9euioiIUEJCgtavX68XX3xRwcHBpR5ns9mMD5iWLVuqffv2ni610owaNUr33HNPqe3q1KlTCdW4h6vnNGTIEC1ZskRS/j86rr322jKNs379emMNZOd/6FQFGRkZWrdunSTJarXKZrNp7dq1eu655xQUFGRydeVX1vMKDg7WrbfeqqVLl+rYsWPavn17gbf2lcTxD1l/f38NHDjQ/SdRDu74eXrjZ4FZ5+VrnwlcGQW8jOMDIjU1Vd9++22Zjlm/fr1sNpskadCgQR6rzQx169ZVq1atSv1Vv359s0stM1fPqWvXrsbrhNeuXausrKwyjeO4Wu5NoaSsvvnmG6WlpUmS8cjJhQsXtHHjRjPLqjBXzsv5qqbznY+SJCYmGq+hvv76673mz4U7fp7e+Flg1nn52mcCYRTwMoMHDzae/ynrrXpHOz8/P6/61y7cw2KxGD/XixcvlukvuqSkJG3dulWS1L17dzVs2NCjNbqb41Zn69atNXz4cDVr1qzA96sqV87r2muvVXh4uCRp3bp1ZQocq1atkmORHG+6Rc/P07187TOBMAp4mSZNmhgPv2/evFlnzpwpsX1ycrK2bNkiSbruuuu86gMG7uPqVbKVK1cqLy9PknfdjiuLkydPGr+nHVf6Hf/dvHmzzp49a1ptFeHqeVksFmP/+fPn9f3335c6huP3RkhIiPr27eu22iuCn6dn+NJnAmEU8EKOD5mcnBx99dVXJbZdvXq1137AwH0iIiLUuXNnSdKPP/6oc+fOldjecbW8Ro0auuWWWzxenzutWrVKubm58vPzM24lDhw4UBaLRdnZ2cZM4KqmPOflSuDYu3evDh8+LEm69dZby/S8eWXg5+kZvvSZQBgFvNCAAQNUrVo1SaX/BeTYb7Va1a9fP4/XBvM4gkl2drbWrFlTbLt9+/bpv//9r6T8UFLRt81VNsfv6aioKONKf5MmTYy/eKvqrd3ynFfTpk3VqVMnSdKmTZt04cKFUvuXvOsWPT9Pz/GVzwRm0wNeqGbNmurTp4++/vprxcXF6fDhw7rqqqsKtfv999914MABSVK/fv1ktVoru1SPO3PmjA4ePFhqu2bNmikwMLASKqq48p7TbbfdpmnTpikrK0srV67U6NGjizzOOZRUtavl+/fvN35PXzoZb9CgQdqxY4d+++03/fHHH2rRooUZJZZLRc5r8ODB2rVrl7Kzs/X111/r7rvvLtR/Tk6OEUbCw8PLPLva09z58/SmzwJvOS9f+UwgjAJeasiQIfr6668l5X+QTJ48uVAbb70S4k6fffaZPvvss1Lbffvtt8bsUm9X3nMKDQ1V7969tW7dOu3atUtHjx5VZGRkgWNyc3ONRzuuuOIKRUdHu7d4D3NcTXIsbeRswIABmjZtmrKzs7V8+XL99a9/NaHC8qnIed1+++2aPn26srOztWLFiiLDqPPz5YMGDXJpEXRPcufP05s+C7zlvHzlM4Hb9ICX6tGjh+rVqyep4AxZh7y8POOZpEaNGnnlBwzcb+jQocZ2UY9w/PTTTzp16pQk7wolZZGTk2P8nu7du7ex6LtD7dq11bNnT0n5fyYcz0p7u4qeV61atdSnTx9J0o4dO3Ts2LFCY3jjlS9+npVzXr7wmcCVUVQZycnJxT4vVatWLZ+bRR4QEKA77rhD8+bNU2JiorZv365u3boZ+7ds2aKTJ09Kyn9o3s/PN/9tOWnSJD3++ONml+FWFTmnG2+8UXXr1tWZM2e0atUqPfHEEwX2O/9lVNXWnN28ebNOnz4tqfjaBw0apA0bNigpKUmxsbEuvTLXLO44r8GDBxuLq69cuVKPPfaYsS81NdVY2ueaa64xlhcym7t/nt7yWeBt5+ULnwm++bcXfNLMmTM1cODAIn/NnDnT7PI8oqSZtJfDLXoUFhAQoNtvv12SlJCQoB07dhj70tLSjBcldOjQQc2bNzelxvJy3PqsXbu2brzxxiLb9O7dW6GhoQXaezt3nNdNN92ksLAwSYXXH167dq1XvlWHn2flnJcvfCYQRgEv1qZNG7Vq1UpSwbds2Gw2ffPNN5Kkdu3aVamJHKi44v6Rsn79eqWnpxdqUxU4L9x9/vx5tW/fXq1bty70q0OHDkpJSZFU8M1j3spd5xUYGGgEjvj4eO3evdvY5/g94NzGbPw8K/e8qvpnAmEUVcbrr7+uAwcOFPnr9ddfN7s8j3F8gKSkpBgfgt98843x4ebNHzDwjHbt2qlly5aSCv4jxRtDSVl9/fXXyszMdOkYm82m9evXe6gi93DneTlf9XT8rP/880/j9Z+9evVS7dq1y1+sG/Hz/J/KOK+q/pnAM6OAlxs4cKDeeust5ebmauXKlerfv79xmy4wMFB33HGHyRXCDIMHD9abb76p8+fP64cfflCHDh0UGxsrKf+Wbp06dUyu0DWOW5n169fX1KlTS23/j3/8Q0lJSVqxYoVX/4PMnefVoUMHtWjRQn/88YfWrFmjqVOnev3rP/l5Vt55VeXPBMIo4OUaNGig7t27a/Pmzfrhhx908OBB4xV0PXr0MJ4jw+Vl0KBBevvtt5WXl6cVK1boyJEjxqxdb/7LvCjHjh0znnO79dZby3QFZ9euXZo/f75++eUXJScne+UERk+c1+DBg/XWW2/p3Llz+vHHH40rX84zuM3Gz/N/KvO8qvJnArfpgSrA+S0bTz31lHJzcwt8H5efhg0bGjN0v/vuOy1ZskRSfijp1auXiZW5bsWKFcbVvUvXbCyOo53jL15v5InzGjRokLFyxttvv61Dhw5Jyl+L1Fte+sDP838q87yq8mcCV0aBKuCWW25RjRo1lJaWZrzSzXntQV9W1reTBAcHKyIiohIqqjh3ndPgwYP1008/KTs7W0ePHpWUv+B2UFCQ22qtDI6/pOvWrVtg+bKSdOnSRfXr19epU6e0cuVKTZw40ZMllosnzsuxpvCWLVuMzwLJu/5h6qmfp9mfBVXhvKrqZwJhFKgCHG/5+PLLL43v9e/f3+s/YNyhrG8nufrqq732isql3HVO/fr100svvVRgpq43hZKy2L59uxISEiRJffv2LfN6uX5+frrlllv06aef6r///a/i4uLUvn17T5bqEk+e15AhQ4xHdSTpqquuUseOHd1XfAV48rzN/CyoKudVVT8TuE0PVBHOb9mQqsYHDDyrevXq6t+/v/F106ZN1alTJ/MKKgfnv1zLeuvToV+/fsa2t61R6cnz6tevn6xWq/G1N60tys+zsMo8r6r6mWCxX/qOQQAAAKCScGUUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATEMYBQAAgGkIowAAADANYRQAAACmIYwCAADANIRRAAAAmIYwCgBwSZ8+fdS6dWu1bt1asbGxZpcDoIoLMLsAALicxMbGaty4ccbX1atX1+bNmxUSEmJiVQBgHq6MAkAlWr58eYGv09PTtXbtWlNqmTJlinGF87333jOlBgAgjAJAJbHZbEUGz0sDKgBcTrhNDwCVZP369bLZbJKkLl266MCBA0pLS9O2bdt07NgxNWnSxOQKy2bjxo1mlwDAh3BlFAAqybJly4ztESNGqF+/fpIku92uFStWmFUWAJiKMAoAleDPP/80Zp4HBwerX79+GjRokLF/+fLlstvtZpUHAKbhNj0AVIIVK1YYYbNPnz4KCQnRddddp4YNGyo5OVnHjh3T9u3b1a1bN5f63bZtm9avX69ff/1VycnJSklJUWBgoBo3bqw2bdqoR48euuWWWwrM1u/Tp48SExML9PP+++/r/fffL3KMAwcOFPja+fj58+crOjq61Dq//fZbrV+/Xjt37tTp06eVl5ensLAwtWvXTjfffLPuuOMOBQSU/FfS8ePHdfPNNxeq68yZM1qyZInWr1+vxMREpaenq379+oqKitKYMWPUrl27UusDYB7CKABUAudJSgMHDpQk+fn56fbbb9ecOXMk5d/GL2sYTUhI0AsvvKAtW7YU2pedna1Dhw7p0KFDWr16tV555RVt3rxZNWrUqPiJuOjYsWOKiYnRzp07C+1LTExUYmKi1q9fr48++kivv/66rrnmGpf6//HHHxUTE6Nz584V+P7x48d1/PhxLV++XJMnT9bEiRMrdB4APIcwCgAetmPHDsXHx0uS6tSpoxtvvNHYN3jwYCOMrl27Vs8//7yCg4NL7G/37t166KGHCgQwPz8/NW/eXGFhYcrMzNTx48d1+vRpSfmz+HNzc4221157rZo1a6aDBw/q5MmTkqSIiAhFRES45XwdDh8+rHvvvdcYQ5KsVqtatGihwMBAHTp0SOfPnzfa3nffffrwww/LdKVVkn755Rc9/PDDysnJUUBAgFq1aqWaNWsqOTnZ+P+dl5ent956SxEREerfv79bzw+AexBGAcDDnK+KDhgwQIGBgcbXV199tVq1aqWDBw8qNTVV33zzjXHltCinTp3So48+agTRatWqaeLEiRo9erTq1KlToO3Ro0e1Zs0aLVy4sMD333jjDUn564w6JlUNGjRIjz/+eIXO01l2draeeuopI4gGBgbqySef1JgxY1S9enVJUk5OjlavXq1XX31VFy9elM1m01NPPaVVq1YpLCys1DGefPJJ5ebmauLEiZowYYJCQ0ONfbt379YTTzyhpKQk45z79esnPz+mSgDehj+VAOBBmZmZ+vrrr42viwqal05kKsmrr75qXPGsXr26Zs+erUmTJhUKopIUGRmpRx55RBs2bKj0W/SfffaZ9u/fb3z9xhtvaMKECUYQlaSAgAANGTJEs2bNMgL66dOn9c4775RpjPPnz+ull17S008/XSCIStI111yj999/XxaLRVLBCWQAvAthFAA86Ntvv1VKSookqUmTJurSpUuhNgMHDjSu2P38889KTk4usq+jR49q/fr1xteTJ0/WtddeW2oNwcHB8vf3L0/55WK32/Xpp58aX99yyy26/fbbi23fpUsX3XvvvcbXK1eu1MWLF0sd57rrrtPdd99d7P4OHToUeAZ3x44dpfYJoPIRRgHAg5zXFi3u9nujRo0UFRUlKf8Zx+LWHF2zZo3y8vIk5T97OmrUKDdX6x6HDx/WkSNHjK/HjRtX6jHjxo0zArnNZtPPP/9c6jF33XVXqW26du1aoC4A3ocwCgAecvLkSf3000/G18634y/lvM85wDrbtm2bsd27d28FBQW5oUr32717t7FttVrLtEJAw4YN1aZNmyL7KE6nTp1KbdOgQQNjuyxXWwFUPsIoAHjIypUrjVns7du3V7NmzYpte+uttxqz6A8fPqw9e/YUauN8Zc+b1848evSosd2iRYsyTxpq3bq1sZ2QkFBq+3r16pXaxvkZ1fT09DLVAaByEUYBwEOcJyOVdFVUkkJCQtSnTx/j66KujjqWQZJUptnmZnG+Alm7du0yH+fc9sKFC6W299YrwwBcw9JOAOABcXFx+u9//2t8/c9//lPvvfdeicdkZWUZ22vWrNHUqVMLBK7s7Gxj25uDmPN5OC9jVZrizhWAbyOMAoAHXHpl02azuXT8+fPn9d133+nWW281vlezZk2dPXtWknc//1izZk1jOy0trczHObd17gOAb+M2PQC4WVZWllavXl3hfi4NtM7PSDreMOSNnNc8PX78eJmPc35O1JsfQwDgXlwZBQA3+/77743nO4OCgrRlyxaFhISU6dgdO3YYSzb9+OOPOnPmjOrWrSspf/b4wYMHJRWcWV9ejgXhpfy1Qd3FeXJVYmJigXMoTm5uruLi4oyv27Zt67Z6AHg3rowCgJs5X9G84YYbyhxEJalz585q2LChpPzXZa5atcrYd/311xvb27dv16FDhypUp9VqNbYzMjIq1Jezjh07Gs+K2u12rVmzptRjfvrpJ505c8b4uizLQQHwDYRRAHCjs2fP6ocffjC+7t+/v0vHWywW9evXz/jaeUZ+37591ahRI0n5Ie+ll14ylo4qD+fb/mVZSqmsatasWeBZ148++kipqanFts/JydHMmTONr9u0aePVS1cBcC/CKAC40apVq4yZ4IGBgQWWayor5wC7f/9+/f7770Z/f/nLX4x9W7du1ZNPPlniZKb09HTNmzevyAlUzrfCf/rpJ/3xxx8u11qcBx98UAEB+U+CnTp1SpMmTSoykGZlZWnq1Knat2+f8b1HHnnEbXUA8H48MwoAbuR8JbN79+4KDQ11uY+uXbuqfv36OnXqlNHnlClTJElDhw7VL7/8YozzzTff6Ndff9XgwYPVtWtXhYWFKTMzU8ePH9e2bdu0ceNGpaWladiwYYXG6d69u+rWraszZ87IZrNp0KBBatOmjerXr19gofp//etfLp9DmzZt9MgjjxjLWW3ZskW333677r77brVv314BAQE6ePCgFi9eXOBxgzvuuKPAVVUAvo8wCgBucuDAgQJX+MobqiwWi2699VZ98sknkvKvtv71r381rjROnz5d1atX12effSYpfxmojz/+WB9//LFL4wQFBWnatGl68sknlZmZWWgSUUVNmjRJaWlpmjNnjiQpKSlJ//znP4tt369fP7322mtuGx9A1cBtegBwE+erogEBAerbt2+5+3K+VX/69Gn9+OOPxtf+/v566aWXNHfuXHXu3LnArPhLRUZG6i9/+UuByUrOevfurRUrVujee+9Vu3btFBoaKn9//3LXfan/9//+n2bNmlXgvfOXCg8P1+uvv653333XqxfzB+AZFrs71/MAAFS6kydPavv27Tp9+rQuXrwoq9WqRo0aqW3btoqIiDC7PENCQoJ27typM2fOKDc3V2FhYWrXrp2uvvpqs0sDYCLCKAAAAEzDbXoAAACYhjAKAAAA0xBGAQAAYBrCKAAAAExDGAUAAIBpCKMAAAAwDWEUAAAApiGMAgAAwDSEUQAAAJiGMAoAAADTEEYBAABgGsIoAAAATEMYBQAAgGkIowAAADDN/wc3+2ZhuptGSgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_actions_ai = pd.DataFrame([{\"policy\": \"AI\", \"action\": actions_ai[i].item(), \"state\": i} for i in range(State.NUM_TOTAL)])\n",
    "df_actions_cl = pd.DataFrame([{\"policy\": \"Clinician\", \"action\": actions_cl[i].item(), \"state\": i} for i in range(State.NUM_TOTAL)])\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(7, 7))\n",
    "_ = sns.histplot(data=pd.concat([df_actions_ai, df_actions_cl]), x=\"action\", stat=\"probability\", hue=\"policy\", multiple=\"dodge\", shrink=0.85, palette=palette, discrete=True, alpha=1.0, cumulative=False, common_bins=False, common_norm=False, ax=ax)\n",
    "_ = ax.set_xticks(range(SepsisAction.NUM_TOTAL), labels=[str(SepsisAction.from_index(i)) for i in range(SepsisAction.NUM_TOTAL)])\n",
    "_ = ax.set_title(plt_discrepancy_title)\n",
    "_ = ax.set_xlabel(plt_discrepancy_x_label)\n",
    "_ = ax.set_ylabel(plt_discrepancy_y_label)\n",
    "_ = ax.get_legend().set_title(plt_discrepancy_legend_title)\n",
    "_ = ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "\n",
    "# separately exports legend\n",
    "if not plt_skip_legend:\n",
    "    legend_fig, legend = export_legend(fig, ax)\n",
    "    legend_fig.savefig(plots_dir / \"plt_agents_discrepancy-legend.pdf\", bbox_inches=legend.get_window_extent().transformed(legend_fig.dpi_scale_trans.inverted()), bbox_extra_artists=[legend])\n",
    "\n",
    "fig.savefig(plots_dir / \"plt_agents_discrepancy.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evaluation of Policies\n",
    "\n",
    "We record the mean reward of the AI and CL policies using the ground-truth simulator over 1000 sampled trajectories."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "actor_ai = AIActor(id=0, policy=ai_policy_path, rng=rng)\n",
    "actor_cl = ClinicianActor(id=0, policy=cl_policy_path, rng=rng)\n",
    "actor_rd = SepsisActor(id=0, rng=rng)\n",
    "env = Sepsis(transition_probabilities=\"./assets/sepsis/sepsis_transition_probs_original.json\", max_horizon=max_horizon)\n",
    "num_trajectories = 1000\n",
    "discount = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "trajectories_ai = sample_trajectories(env=env, agents=[actor_ai], num_trajectories=num_trajectories, rng=rng)\n",
    "trajectories_cl = sample_trajectories(env=env, agents=[actor_cl], num_trajectories=num_trajectories, rng=rng)\n",
    "trajectories_rd = sample_trajectories(env=env, agents=[actor_rd], num_trajectories=num_trajectories, rng=rng)\n",
    "stats_ai, stats_cl, stats_rd = get_stats(trajectories_ai), get_stats(trajectories_cl), get_stats(trajectories_rd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "rewards_ai = [{\"agent\": \"AI\", \"reward\": t.total_reward(discount=discount)} for t in trajectories_ai]\n",
    "rewards_cl = [{\"agent\": \"Clinician\", \"reward\": t.total_reward(discount=discount)} for t in trajectories_cl]\n",
    "rewards_rd = [{\"agent\": \"Random\", \"reward\": t.total_reward(discount=discount)} for t in trajectories_rd]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.DataFrame(rewards_ai + rewards_cl + rewards_rd)\n",
    "df.reward = pd.Categorical(df.reward, categories=[-1.0, 0.0, +1.0]).rename_categories({-1.0: \"death\", 0.0: \"no change\", +1.0: \"discharge\"})\n",
    "fig, ax = plt.subplots(figsize=(7, 7))\n",
    "_ = sns.histplot(data=df, x=\"agent\", hue=\"reward\", palette=palette, multiple=\"dodge\", stat=\"probability\", shrink=0.8, alpha=1.0, ax=ax, discrete=True, cumulative=False, common_norm=False)\n",
    "_ = ax.set_title(plt_rewards_title)\n",
    "_ = ax.set_xlabel(plt_rewards_x_label)\n",
    "_ = ax.set_ylabel(plt_rewards_y_label)\n",
    "_ = ax.get_legend().set_title(plt_rewards_legend_title)\n",
    "_ = ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
    "fig.savefig(plots_dir / \"plt_agents_observed_reward.pdf\", bbox_inches=\"tight\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mpi-ase",
   "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
}
