{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "\n",
    "import torch\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as mlines\n",
    "from matplotlib.ticker import FuncFormatter\n",
    "import seaborn as sns\n",
    "sns.set_theme()\n",
    "\n",
    "from source.constants import RESULTS_PATH, PLOTS_PATH\n",
    "from source.data.medical_imaging import get_chexpert\n",
    "from source.utils.metrics import auroc, aod, eod, spd\n",
    "\n",
    "os.makedirs(PLOTS_PATH, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_seeds = [42, 142, 242, 342, 442]\n",
    "dseed = 42\n",
    "\n",
    "models = [\"resnet18\", \"resnet34\", \"resnet50\"]\n",
    "\n",
    "pas = [\"age\", \"gender\", \"race\"]\n",
    "pa = 0 # 0, 1, 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# patients general 65401\n",
      "# patients with race 58010\n",
      "24638 24638\n"
     ]
    }
   ],
   "source": [
    "full_ds, _, _ = get_chexpert(load_to_ram=False)\n",
    "\n",
    "run_path = os.path.join(RESULTS_PATH, f\"chexpert_{models[0]}_mseed{method_seeds[0]}_dseed{dseed}\")\n",
    "fair_inds = torch.load(os.path.join(run_path, \"fair_inds.pt\"))\n",
    "val_inds = torch.load(os.path.join(run_path, \"val_inds.pt\"))\n",
    "\n",
    "print(len(fair_inds), len(val_inds))\n",
    "\n",
    "y_fair_t = full_ds.targets[fair_inds]\n",
    "a_fair_t = full_ds.protected_attributes[pa, fair_inds]\n",
    "y_val_t = full_ds.targets[val_inds]\n",
    "a_val_t = full_ds.protected_attributes[pa, val_inds]\n",
    "\n",
    "# switch 0 / 1 in protected attribute\n",
    "pas = [\"young\", \"man\", \"non-white\"]\n",
    "a_fair_t = 1 - a_fair_t\n",
    "a_val_t = 1 - a_val_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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CiYiIqL+x6dAsmjRIsyZMwc6ne6srxMEARaLBRaLBYsWLUJdXV1ARRIREVH/5lMgmTdvns9vMGzYMAwbNsznfkRERBQ9OO2XiIiINBeyQPLNN9+EatdERETUz/g17feHHA4HvvzyS3zxxReorq5GdXU1vvrqK7S3t6O6ujoYNRIREVE/51MgaWho6Agd1dXV+OKLL/DNN99AURSoqgpBECBJEsaNG8c1SIiIiKjXfAokkydP7vhvURSRmpqKa6+9FhdddBEuuOACWK1WrFq1ChMmTAh6oURERNR/+RRIRFGEoijIyMjAf//3fyM+Pr5jW0tLS9CLIyIioujg06DWsrIyXHHFFdixYwfmzJmDbdu2haouIiIiiiI+BZJRo0ahpKQEK1euBADcc889yM3Nxddffx2K2oiIiChK+DXLZtasWZg+fTqef/55rF+/HnPmzEF2djYEQQh2fURERBQF/F6HJCYmBgUFBdi6dStmzJiBt956CwDwr3/9KyiF1dTUYMGCBUhPT4fFYkFhYSHsdnuv+jY1NeHRRx/FlClTMG7cOGRmZqK0tDQodREREVHwBbwOyXnnnYfi4mJUVVXh8ccfR3FxMT788EP86U9/Qlpaml/7lGUZubm5SE5ORnFxMRoaGlBUVISmpiasWLHirH1PnjyJ2267DTExMVi8eDEGDRqEw4cPw+Vy+VULERERhV7AgeSMSZMm4e2338bGjRuxatUq3HDDDdi3b59f+yotLYUsyygrK0NSUhIAQKfTwWq1Ii8v76xBZ82aNbDb7XjttddgMpkAABMnTvSrDiIiIgqPoC4dL4oibr/9drz33nu48cYb/d5PZWUlLBZLRxgBgMzMTBiNRlRUVJy17xtvvIF58+Z1hBEiIiKKfD5dIVm1alWvX3vOOed0ev3dd9/dq742mw1z5871ajMajUhJSYHNZuu235EjR1BfXw9JknDXXXdh165diI2Nxc9//nM88MADDClEREQRyqdA8uabb/r9RoIg9DqQyLIMSZI6tUuShObm5m771dfXAwCeeOIJzJo1C2vXrsXBgwfx5JNPwuVyobCw0L/iAej1wbuYJAgC3IICURAgipyZFDanZ4GJAI97GImiAFEAdKIIUVS1Lof6AJ1O9Po3RQefAsn7778fqjp65czzcrqjKAoAIC0tDUVFRQAAi8UCt9uNJ554Ar/73e8wZMgQn99XFAUkJsb6V3Q3mpQ2xJj0EPjFGDZGow4AYIgxwKRTNK4mesToDTDGGJAQO0DrUqiPkSSz1iVQGPkUSBwOB2JiYkJVSwdJkiDLcqf2lpaWsw5oTUhIAHBqgO0PTZo0CYqiwGaz+RVIFEWFLLf53K87giDA4XDDYXfD4XAHbb90dobTgcTlcMHudGpcTfQQDCKcDheaXG1QVV4hoZ7pdCIkyQxZbofHw18e+jJJMvf6SpdPgeT222/HmjVrOr74QyUtLa3TWBGn04na2tpOY0t+aNiwYTAYDJ3az3wIiqL/l//c7uCdFKIoQFVVKKoKReEHdNic/nugADzuYaQoKhQV8HgUHnfyicejBPWzlyKbT9/Qx44dwy9/+UscOXIkVPUAAKZNm4aqqio0NjZ2tJWXl8PpdCIjI6PbfkajEZMnT8bu3bu92nfv3g29Xo8LL7wwZDUTERGR/3wKJK+++ioMBgN+8Ytf4NNPPw1VTcjJyUFcXBzy8/Oxc+dOlJWVYenSpcjOzva6ZbN48WKMGTPGq+/ChQvx5Zdf4v7778eHH36Iv/71r/jLX/6CW265xWsaMREREUUOnwJJcnIySktLMWrUKOTm5mL79u0hKUqSJJSUlGDAgAEoKCjA8uXLkZWV1WmWjKIo8Hg8Xm2XXHIJ1qxZg4MHD+K3v/0t1q1bh1tvvRX33XdfSGolIiKiwAmqH6PMXC4XHnroIWzduhUPPvggbrvttlDUFjE8HgUNDSeDtj9RFOByeLB/bx0cdg5qDZf4BBNS0yXsPrIHJ+3tWpcTNcwGEyypP0MsBnIMCfWKXi8iMTEWjY0nOYakj0tKig3NoNYzDAYDVqxYgXPPPRfLli3Djh07kJ6ejjFjxuDiiy/G0KFD/dktERERRSm/AonD4cDrr7+Obdu2QVVVfPLJJ9i1a1fHGiGJiYkYO3Ys1q5dG9RiiYiIqH/yKZA0NTVh48aNeOmll9DY2IjLL78cjz32GCZPnowjR47gwIEDOHDgAPbt24f9+/eHqmYiIiLqZ3wKJFdddRXsdjssFgvy8/MxYcKEjm3Dhg3DsGHDkJmZGfQiiYiIqH/zKZBcccUVyM/PR3p6eojKISIiomjkUyB5/vnnQ1UHERERRTE+SpGIiIg051MgycrKQnl5ea9ff/z4cRQWFvLKChEREZ2VT7dsZs2ahfvvvx/x8fHIzs7GFVdcgbFjxyIxMRGCIMBut6O2thaffvop/vGPf+DDDz/ExRdf3GmFVSIiIqIf8imQ3H333fjFL36BkpISvPbaa1i7di0EQYAgCNDr9XC5XABOPV338ssvx5NPPolrr702JIUTERFR/+HzwmjnnHMO7rvvPvz+97/Hp59+ir179+L48eOw2+1ITEzEyJEjMXHiRJx77rmhqJeIiIj6Ib9WagVOLR9/+eWX4/LLLw9mPURERBSFfBrU2traioceegiTJk3CpZdeittuuw3//Oc/Q1UbERERRQmfAslTTz2Ft956C4MGDcLo0aOxb98+/OpXv8LHH38cqvqIiIgoCvgUSD744APccsst2LJlC1555RX84x//wMUXX4wVK1aEqj4iIiKKAj4Fkm+//RazZs3q+DkpKQkPPfQQPv/8czQ3Nwe9OCIiIooOPgUSRVEQExPj1faTn/wEqqriu+++C2phREREFD18Xjr++PHjXj8bjUYA6FiDhIiIiMhXPk/7LSgogMlkwkUXXYTRo0dj1KhREAQhFLURERFRlPApkKxZswYHDhzAgQMHsH//fuzdu7dj2y233IKLLroIY8eO7fhn9OjRwa6XiIiI+iGfAklGRgYyMjI6fm5qasKBAwewb9++jqCyadMmqKoKQRBQXV0d9IKJiIio//F7pVYASEhIwJVXXokrr7yyo621tRX79u1jGCEiIqJeCyiQdGXgwIGYNGkSJk2aFNB+ampqUFhYiD179sBsNmP27NmwWq0wmUxn7Xfbbbd1uVDbu+++i7S0tIBqIiIiotAIeiAJBlmWkZubi+TkZBQXF6OhoQFFRUVoamrq1SJsl112GR544AGvtgsuuCBU5RIREVGAIjKQlJaWQpZllJWVISkpCQCg0+lgtVqRl5fX45UOSZKQnp4ehkqJiIgoGHxehyQcKisrYbFYOsIIAGRmZsJoNKKiokLDyoiIiCgUIvIKic1mw9y5c73ajEYjUlJSYLPZeuz/8ccfIz09HR6PB5deeil+97vfYcKECQHVpNcHL7sJggC3oEAUBIgi13AJm9Pr5YgAj3sYiaIAUQB0oghRVLUuh/oAnU70+jdFh4gMJLIsQ5KkTu2SJPX4zJwJEybghhtuwPDhw3H8+HGsX78ev/rVr/Diiy9i/PjxftUjigISE2P96tudJqUNMSY9BH4x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8Mknn2DmzJnIzs7GX/7yF3z//fcwGAx46623cP311wezTiIiIurH/A4keXl5OH78OADgjjvuQH19Pd555x0AwHXXXYcHHnggOBUSERFRv+fTw/WiFR+u1z/w4Xra4MP1yFd8uF7/4cvD9fweQ/LVV1/525WIiIjIi9+B5Prrr8e8efPw8ssve82wISIiIvKV34FkyZIlEEURf/rTnzB16lTce++92LVrVzBrIyIioijh96DWm2++GTfffDNsNhveeOMNvPPOO9iyZQvOPfdczJkzB3PmzEFKSkowayUiIqJ+KuCn/aalpeH+++/vWDb+0ksvxbp16zBr1qxg1EdERERRIOBA0rEjUURKSgqGDRsGSZLAyTtERETUW37fsjmjtbUVW7duxRtvvIFPP/0URqMRM2fOxNy5c4NRHxEREUUBvwNJVVUV3nzzTZSXl6O9vR3jxo3DkiVLkJWVhbi4uGDWSERERP2c34Fk/vz5GDRoEHJycjB37lxceOGFwawLNTU1KCwsxJ49e2A2mzF79mxYrVaYTKaz9vvzn/+MHTt2oK6uDoIgYMSIEfj1r3+N2bNnB7U+IiIiCh6/A8mqVaswffp06HS6YNYD4NSThHNzc5GcnIzi4mI0NDSgqKgITU1NWLFixVn7tre3IycnByNGjICqqnjvvffwhz/8AYqiIDs7O+i1EhERUeD8DiQzZ84MZh1eSktLIcsyysrKkJSUBADQ6XSwWq3Iy8tDWlpat32XLFni9fPUqVNx8OBBvPXWWwwkREREESrgWTYtLS3YuXMn/va3v6G5uTkYNaGyshIWi6UjjABAZmYmjEYjKioqfN5fQkICXC5XUGojIiKi4Atols3q1auxdu1a2O12CIKA119/HfHx8cjNzcXkyZNx5513+rVfm83WaZaO0WhESkoKbDZbj/1VVYXH40FbWxvef/997Nq1C3/+85/9quUMvT5oM6QhCALcggJRECCKQtD2Sz0QTh1rEeBxDyNRFCAKgE4UIYpcDoB6duZhbL19KBv1D34HkpdeegmrV6/GzTffjKlTp+Kuu+7q2DZ9+nT8/e9/9zuQyLIMSZI6tUuS1KurMLt378avfvUrAIBer8cf//jHgBZqE0UBiYmxfvfvSpPShhiTHgK/GMPGaDw13skQY4BJxyeIhkuM3gBjjAEJsQO0LoX6GEkya10ChVFA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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot p(Y | A) for testset\n",
    "p_y1_a0 = y_fair_t[a_fair_t == 0].float().mean().item()\n",
    "p_y1_a1 = y_fair_t[a_fair_t == 1].float().mean().item()\n",
    "p_y0_a0 = 1 - p_y1_a0\n",
    "p_y0_a1 = 1 - p_y1_a1\n",
    "\n",
    "# barplot\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.bar([-0.2, 0.8], [p_y0_a0, p_y1_a0], color=\"C4\", width=0.4, alpha=0.5, label='$A=0$')\n",
    "plt.bar([0.2, 1.2], [p_y0_a1, p_y1_a1], color=\"C2\", width=0.4, alpha=0.5, label='$A=1$')\n",
    "plt.xlabel('$Y$')\n",
    "plt.ylabel('Prevalence $P(Y | A)$')\n",
    "plt.xticks([0, 1])\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3, 5, 10, 24638, 2])\n"
     ]
    }
   ],
   "source": [
    "# load probits\n",
    "fair_probits = list()\n",
    "\n",
    "for model in models:\n",
    "    for mseed in method_seeds:\n",
    "        path = os.path.join(RESULTS_PATH, f\"chexpert_{model}_mseed{mseed}_dseed{dseed}\")\n",
    "\n",
    "        fair_probits.append(torch.load(os.path.join(path, f\"fair_probits.pt\")))\n",
    "    \n",
    "fair_probits = torch.stack(fair_probits).reshape(len(models), len(method_seeds), fair_probits[0].shape[0], -1, 2)\n",
    "\n",
    "print(fair_probits.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3, 5]) torch.Size([3, 5])\n"
     ]
    }
   ],
   "source": [
    "fair_m_accs = list()\n",
    "fair_m_spds = list()\n",
    "fair_m_eods = list()\n",
    "fair_m_aods = list()\n",
    "\n",
    "for m in range(len(models)):\n",
    "    for s in range(len(method_seeds)):\n",
    "\n",
    "        fair_m_accs.append(auroc(torch.mean(fair_probits[m, s], dim=0)[:, 1], y_fair_t) \\\n",
    "                                - torch.mean(torch.tensor([auroc(fp[:, 1], y_fair_t) for fp in fair_probits[m, s]])))\n",
    "\n",
    "        fair_m_spds.append(spd(torch.mean(fair_probits[m, s], dim=0).argmax(dim=1), a_fair_t) \\\n",
    "                              - torch.mean(torch.tensor([spd(fp.argmax(dim=1), a_fair_t) for fp in fair_probits[m, s]])))\n",
    "        \n",
    "        fair_m_eods.append(eod(torch.mean(fair_probits[m, s], dim=0).argmax(dim=1), y_fair_t, a_fair_t) \\\n",
    "                                - torch.mean(torch.tensor([eod(fp.argmax(dim=1), y_fair_t, a_fair_t) for fp in fair_probits[m, s]])))\n",
    "        \n",
    "        fair_m_aods.append(aod(torch.mean(fair_probits[m, s], dim=0).argmax(dim=1), y_fair_t, a_fair_t) \\\n",
    "                                - torch.mean(torch.tensor([aod(fp.argmax(dim=1), y_fair_t, a_fair_t) for fp in fair_probits[m, s]])))\n",
    "\n",
    "# reshape to (models, seeds)\n",
    "fair_m_accs = torch.stack(fair_m_accs).reshape(len(models), len(method_seeds))\n",
    "fair_m_spds = torch.stack(fair_m_spds).reshape(len(models), len(method_seeds))\n",
    "fair_m_eods = torch.stack(fair_m_eods).reshape(len(models), len(method_seeds))\n",
    "fair_m_aods = torch.stack(fair_m_aods).reshape(len(models), len(method_seeds))\n",
    "\n",
    "print(fair_m_spds.shape, fair_m_spds.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKAAAAEICAYAAABoLoyYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAC0VklEQVR4nOzdeZwU1bk//k9V9b53z8rAzAADDAwCioCyK0SFiNlMDH4TYrwaEkk0QUmimG++SX56MeoVxcQVTbgxNyZqIMGoUTEBl6sI7iLbsA8we0/vXdv5/VHdNd3TPRvM0j3zvF8hMtXV1dXdw6k6zznPczjGGAMhhBBCCCGEEEIIIf2EH+wTIIQQQgghhBBCCCFDGwWgCCGEEEIIIYQQQki/ogAUIYQQQgghhBBCCOlXFIAihBBCCCGEEEIIIf2KAlCEEEIIIYQQQgghpF9RAIoQQgghhBBCCCGE9CsKQBFCCCGEEEIIIYSQfkUBKEIIIYQQQgghhBDSrygARQghhBBCCCGEEEL6FQWgCCGEEJLz9u7di9tuuw2LFi3ClClTcN555+HLX/4yHn/8cfj9fgDAokWL8N3vfrfPXnPnzp2YOHEi7rvvvozHjh07hvPOOw833XRTn71ebz3yyCN49dVXB+31CSGEEEJ6gwJQhBBCCMlpf/nLX3DllVfi448/xnXXXYeNGzfiN7/5DZYsWYKnn34at99+e7+87qxZs7BixQps3LgRH330kb5dVVX89Kc/hcViwS9+8Yt+ee2eePTRRykARQghhJC8YRjsEyCEEEII6cz777+PX/ziF5gzZw4eeughmEwm/bG5c+fi2muvxeuvv95vr3/LLbdgx44d+OlPf4otW7bAbDbjiSeewHvvvYcHH3wQPp+v3167M7FYDBaLZcBflxBCCCHkbNAMKEIIIYTkrEcffRQcx+H/+//+v7TgU5LJZMLixYvTtu3YsQNf/vKXMXXqVCxZsgTPPvtsxvMaGxvx85//HAsWLMA555yDRYsW4Te/+Q1kWU7bz2Kx4K677sKRI0dw3333Yf/+/diwYQOuuOIKXHrppWn7rlixAsuWLcOuXbtw1VVXYerUqZg/fz7uv/9+KIqStq8oinjooYewZMkSnHPOObjwwgtx2223oaWlJW2/ZFrhyy+/jC996UuYMmUKfvOb36C6uhqRSASbN29GdXU1qqursWLFil59toQQQgghA4ljjLHBPglCCCGEkI4URcH555+PCRMm4C9/+Uu3+y9atAiKosDhcOA73/kOCgsL8cwzz+Cll17CU089hZkzZwLQgk9f+9rXwPM8vvvd76KiogLvv/8+Hn74YSxbtgzr1q3LOPY999yDJ598EmVlZRBFEc8//zzcbnfaPitWrMD+/fthMpmwcuVKjBkzBv/+97/xhz/8Ad/4xjfw85//HICWwrdy5Urs3r0b1113HaZPn466ujo8+OCDcDqdeO655/QZTosWLYIoirBYLLjhhhswatQoWK1WqKqKa665BhdccAFWrVoFAHA4HBg3btxZfeaEEEIIIf2FUvAIIYQQkpNaW1sRjUYxatSoXj3nT3/6E8rKygAAM2fOxNtvv42tW7fqAagHH3wQbW1t+Mc//qHvN3v2bFgsFvz617/GddddlxHIuemmm/DnP/8ZJ06cwIYNGzKCT0l+vx8PPfSQPitr3rx5iMfj+NOf/oTrr78eZWVlePHFF/H666/jwQcfTJtFNXHiRHz1q1/FX//6V/yf//N/9O0tLS34xz/+gTFjxqS9Fs/z8Pl8OPfcc3v8+RBCCCGEDBZKwSOEEELIkDFp0iQ9qAQAZrMZo0ePxsmTJ/Vt//73v3HBBReguLgYsizrfxYsWABAW/2uo+eeew7BYBA8z+PNN9/s9PXtdntGSuCyZcugqireffddAMC//vUvuFwuXHzxxWmvP2nSJBQVFWW8fnV1dUbwiRBCCCEk39AMKEIIIYTkJK/XC6vVihMnTvT4OR6PJ2ObyWRCPB7Xf25ubsa//vUvTJ48OesxWltb034+fvw47rnnHlxyySWorq7WV+CbM2dOxnMLCws73eb3+/XXDwQCOOecc3r0+kVFRVn3I4QQQgjJJxSAIoQQQkhOEgQBF154IV5//XWcPn0apaWlfXJcr9eL6upq/OhHP8r6eHFxsf53xhhuu+02mM1m/PKXv4TL5cKrr76Kn/3sZ/j73/8Oh8OR9tympqaM4yW3JYNjXq8XHo8HGzduzPr6drs97WeO43r61gghhBBCchal4BFCCCEkZ333u98FYww/+9nPIIpixuOSJOG1117r1TEvuugi7N+/HxUVFZgyZUrGn5KSEn3fTZs24d1338UvfvELFBQUwGg04q677kJDQwPuvvvujGOHw2Fs27Ytbdvzzz8Pnuf1GlQXXXQR/H4/VFXN+vpjx47t0fswmUyIxWK9eu+EEEIIIYOFZkARQgghJGedd955+MUvfoFf/vKXuPLKK7F8+XKMHz8esixjz549+Mtf/oLx48dj0aJFPT7mTTfdhLfeegvLly/HihUrMGbMGIiiiBMnTmDHjh345S9/idLSUhw+fBjr16/H5ZdfjiVLlujPnzRpEr773e9mTcXzeDz4xS9+gVOnTmH06NHYvn07/vKXv+Dqq6/Wa1Ndfvnl2Lp1K1auXIkVK1Zg6tSpMBqNOH36NN555x0sXrwYl1xySbfvY8KECdi5cydee+01FBUVwW639zh4RQghhBAy0CgARQghhJCcdtVVV2Hq1Kn4/e9/j40bN6KxsRFGoxGjR4/GsmXL8M1vfrNXxysuLsazzz6Lhx56CE888QTq6+tht9sxcuRIzJ8/Hy6XC6qq4rbbboPT6cTPf/7zjGN873vfy5qKV1RUhJ///Of49a9/jf3798PtduN73/sebrzxRv25giDg4Ycfxn//93/jb3/7Gx577DEIgoDS0lLMnDkTEyZM6NH7uP322/HLX/4SN998M6LRKGbNmoU//OEPvfosCCGEEEIGCscYY4N9EoQQQggh+W7FihVobW3F888/P9inQgghhBCSc6gGFCGEEEIIIYQQQgjpVxSAIoQQQgghhPTY4cOHcd111+Hcc8/F7Nmzcccdd/S4IP7mzZuxZMkSTJkyBcuWLcOLL76YsY8kSfiv//ovzJs3D9OmTcOKFSuwd+/etH3eeecdVFdXZ/xZvXp1n7xHQgghfY9qQBFCCCGE9AGqv0SGg0AggGuuuQZlZWXYsGEDWlpasG7dOvj9ftx7771dPvell17CrbfeipUrV2Lu3Ll49dVXsXr1ajidTsybN0/fb926ddiyZQtuvfVWjBw5Ehs3bsS3v/1tbN26FUVFRWnHXLduXVrxfa/X27dvmBBCEg4fPow77rgDu3fvhtVqxeWXX441a9bAYrF0+9zNmzfj0UcfRV1dHSorK/H9738fS5cuTdtHkiRs2LABmzdvRjAYxNSpU3H77bdj4sSJ+j7vvPMOvvWtb2Uc//Of/zzWr19/9m+yn1EAihBCCCGEENIjTz/9NAKBALZs2QKfzwdAK6y/Zs0a3HDDDaiqqur0uQ888ACWLFmCW265BQBw4YUX4vDhw9iwYYMegKqvr8fTTz+N22+/HVdddRUAYNq0aVi8eDE2bdqENWvWpB1z/PjxmDJlSn+8VUII0VHwvW9QCh4hhBBCCCGkR3bs2IHZs2frwScAuOyyy2AymbB9+/ZOn3f8+HEcOnQIy5YtS9u+bNkyfPTRR2hpaQEAvPHGG1AUBZdffrm+j8PhwKJFi7o8PiGE9Kdk8P2hhx7CggUL8KUvfQk/+9nPsHXrVtTW1nb53NTg+4UXXoif/exnmDt3LjZs2KDvkwy+33LLLbjqqqswd+5cPPjgg2CMYdOmTRnHHD9+PM4991z9T2VlZZ+/5/5AAShCCCGEEEJIj9TW1mbMcjKZTKioqOiyE3bo0CEASBuxB4CqqiowxvTHa2trUVhYCI/Hk7Hf4cOHoapq2vaVK1di0qRJWLBgAX7961/3uBYVIYT0BgXf+wal4BFCCCGEEEJ6JBAIwOVyZWx3uVxoa2vr9HnJxzo+1+12pz0eCATgdDoznu92uyFJEiKRCBwOB5xOJ66//nrMnDkTZrMZb7/9Np588kkcOnQIjz76aKfnsXjx4k4fe/XVV8FxXKePE0KGr9raWlx55ZVp2/oq+O7z+boMvm/duhWqqoLn2+cPrVy5En6/H0VFRbj88svxwx/+sEe1qAYbBaAGCWNssE+BENKP6AZ2eKE2nZChi9rznmGM9eiz6rhPsv1M3Z7tOB3b2ZqaGtTU1Og/z549G8XFxfjVr36Fjz76CFOnTu3V+Xf2OoSQoUUURXz+85/v9PFt27Zl3Z7vwfdcQQGoQdTUFOp2H4OBh9drR2trGLKsdrs/yT30HQ4NvfkeCwsdA3RWJJdQmz480HeY/6g9PzsulwuBQCBjezAY7LIAeWpnq7CwUN+ePFayc9bZ8QOBAIxGI2w2W6evsXTpUvzqV7/CJ5980mkAqrPOZRJjjNrzYYS+x/zX2za9ubm5T19/qATfBwoFoAghhBBCCCE9UlVVlZFuIooijh07lpGekiqZfnLo0KG0QFVtbS04jtMfr6qqQnNzM/x+f1oqSm1tLcaMGZOWgkIIIb1VVlbWbSA6m3wPvucKasEJIYQQQgghPbJgwQK8/fbbaG1t1be98sorEEURCxcu7PR55eXlGDt2LF544YW07c8//zymTp2qF/adN28eeJ7Hiy++qO8TDofx2muvdXl8APjHP/4BAJgyZUqv3xchhHSlq+B7VwGo1OB7qq6C7x33G0rBd5oBRQghhBBCCOmR5cuX46mnnsKqVauwatUqNDc346677sIVV1yR1glbu3YttmzZgj179ujbbrrpJqxevRoVFRWYM2cOtm3bhjfffBMbN27U9ykpKcHy5ctx7733wmAwoKysDE8++SQA4JprrtH3W7NmDSorK1FTU6PXQfn973+PxYsXUwCKENLnFixYgIcffhitra3wer0Aeh98v+SSS/TtXQXfr776agDtwfevfe1rXZ5bPgXfKQBFCCEJjKkAYwBTtT+qCoABqgpVAFS7MNinSAghpAcYY+ntecrfVRlQIgoYo+LiZ8LlcmHTpk244447cOONN8JisWDZsmVYs2ZN2n6qqkJRlLRtS5cuRSwWwyOPPIInnngClZWVWL9+PebNm5e236233gqbzYb7778fwWAQ06ZNw6ZNm1BUVKTvM378eGzduhVPPvkkJEnCyJEj8b3vfQ8rV67svzdPCBkUuXCPTsH3vsExWuphUFCBw+GDvsOBxzp2ONT2n1MfY4oCMBlQ5JR9tAsa0y9yWhMp8IC3vAIh1d6jAoe0atLwQm368EHf4cDqKpCU2iHR2nMFUBPtuaq0t/WJTorWvgOCwMHlcSFiLIDCGbt8fWrPhx9qz4cX+h4HVr7fox8+fBh33HEHdu/enRZ8t1gs+j633norNm/ejH379qU9d/PmzXjkkUdQV1eHyspK/OAHP8DSpUvT9hFFERs2bMDmzZv14Pvtt9+OiRMn6vs8+uij2Lp1K+rq6vTg+xVXXIGVK1fCZDKd8XsbKBSAGiR0cRs+6Ds8cyzLKEenFylVbu94dHGRAgPAcdrPHK9dhDgO4PjEn9SfOXCclm/NSSF4y8oQYg4KQJEM1KYPH/Qdnpm0trhDB4SltPN6e84ULYiU0qYzIC2QlI5LtOd8exsOLqNd5zgOPK/CaQYipiIKQJEM1J4PL/Q9nhm6RydnilLwCCH9jqkqgOQoR3rnI/0iJSc6HF1dpACAJS5SSPxflo4Hb0i7eCUvUhnn1mEJVCbFwMJtgGAA7yjQ91PDrQDK+u0zIoSQfMA6mY2kt+eJtpupyQBSYmaSokBru9X0WU0ZEu11akcDWpvOcRxgSHY8sncgGFPT2ns11AzIIjhHATiDlqKhhlvBTO6+/3AIISTP9Os9OkPKvTjdoxMNBaAIIT3GUi84nVykWDL1QZWzjF6ndDpUBvCc9t+sgaTEhaqHF6kkNRoAFAmc1Q1O0Jo4NeKH4j8JzmSHUFip7ysd/F+weBiGsbPAWV3aewy3Qj7xCTiHL+3ixqRYX3+chBAyaNIDSenpEKkpa2mBpGTHIy2QlDJ6nSZLIIkTAM6Q1hnpaiSaySJYPAzwAvhEGw0ASv1BMCkGobgKnMkKAFD9pyGf3APe7oOh8tz2fU/uBRMjMIydCd5kBscBiiJDiscBcx99mIQQMsjy4x49CChiD+/R3waLh+gefQiiABQhw0xX9TQyL1JySsdDaU+XSHZOwDpcnLQhD61DkXmRSu2MZLtIMUUG5Lj2uKk9l1ppOgrIIviCCsCo9RjUttNQ6g+Cs3thGDm5fd9jH4JJMRiqLtAvWBCjUFvqwDl8aRe3xAcCKFL7z0YLOJsHnNmhb+J4DkJK54cQQnJFV4VZ02okJdtxJZne1kUaRJrUQFLyv4LWpqPrQBKTYlr7arSB4xOzj6IBsGAjYLJC8LSPWEuH3gXEKAyjp4OzaO2vGmyEUrcHvLMQfOV5+r5qoB4sHgHvHakHoMDzgKqAKZJ2+eE47VQdHqhxC2KyCjksIhaXIUc4FAsybDQJihCSQ4b+PfoH2j362Fngkg2wGDuze/SUdl4xOqDq75XkOgpAEZKn+rQwa9pFKillpCO1jgZvTKRBtNfT0M8peUEUDPrFi8VCUMOt4EwW8M721Wvko++DSXEYKqaljGCfgnJqL3h3CQzlU/V91eZjYFIMnLsEXOLiBsbAxCiQ7HwkmW3ghPSaHpzFqY2Um21p2w0V52rvK2V/3u6FMG4WOE77aERZQTymQIwLcCoq0PXgDiGEnJGshVnTAkkp9TSYrKW06e15TwJJHetpJEevk50NDhzPp5wP044PltamKv6TgCyB95a1j2C31UNuPgre5oVQOl7fV6p9B5BFGMfNBhJBJRYLQmk4pF0PUgJQkEUwOQ6myPqliDOYwZlsgCF9qhJfUAGoCjijRe+ECK4CcBPnQYaAqChDlBnicRkxQyVkToUSUKGoITAGGHhBP3dCCOlr+X+PnggU9eYe3VWcco+OTu7R7RltL2dxdHKPPi3jHl1w+mB0z4IsM0RFGbG4ilBMglES4GUUgMoXdPUlZJANeGFWJEY8eD7rRYoxlnbBUoNNWkqbq7h9BDvQCNVfB87mTZ8uu3c7oMowjp8LJC4karhVv2ClXtxYLKTlcisSOGgXKE4wAoIBHa8gvLcMTFXSLlqco0AbQTGkB5uMo8/P/AQsDggWR+b2xIWR47URFFXRAk4xSUE0LiEWVyDLKiSFwSEoGc8nhJCOelWYtYcr/LQfHGnpDvoIdmogKWX0OqN+RjwCFgsCRjN4m0c/rHziEzBZhGHUOeAM2go6avMxKKf3g/eMgGHUOfq+yukD2mi3o0DvGDBVBou0gXUM/htMYInPRA8qmR3gfeX6LKckoXwKAK59RhOgzXxyFqYcUHsvxqIKqAyQFRVSarBJVCArEhRFhaKy7HE4Qgjpofy+R/dAKByt79vlPbqruMM9elC7R5fF9nvl7u7RU+7HOYcPhrEz9etJknH09MxPoKt7dI7TJrcyBlFSEYsqCMdExOMqJFmBrGiNvNNAjX0+oQAUIX0stQgrVEXLeIgoUCMhqLKSUsTvTAqzdlzhJ7Uwa5bRDimujUAIBnBme+L8GJTT+wFFgjCiGhyvNQNK8zEo9QfAu0fAMLJGP4Z8/OOMCxaTYlADjeA7TNHlBIPWEVFTRrDNNvCuYnDW9FwHoWyS9nhqZ8NTCpOnNOOdC8VVmZ+GwZRxYetK6mfL8QAHBkVRIUoyRFFBNCYiJspQZAWKomj3FJy2H8c4cHZT4jMnhAwXeucjJb1BlRmUsKy16ZJyBoVZO67w07Ewa2YgKXkuLKbVz4DNq89WUkPNUAP14KxuCN6R+r7Svh2AIsE4YR5g1NIl1GCjHlRKDUAlC3VDFoFku5oM+Kty2mfCO4u095RybrzdB65iGmBMH+02jpud8ZnyNjf4LLlvfMc055T0Cj3YJCntwaa4DFlRoMgyVFUFUxNtPFii3db+C8bAMRWM4wCWnPjFgTO4Et9F9u+eEDL0dLxHB1OhSoBslKCGw1BEcZjdo9u1e/SU6wGQco+eMitpQO7RoWofHxhESYEoSojEZUSjEhRZhiQricEcABwggIExTnstukfPGxSAIqQHsl2w0lb7UWQtRzmlA6KPdPMcRNEMJRiHqmhRjZ4UZgWg5VorEmBuXzJUDbeChVvAWZzgXcX6+ckH3wEUCYZxs/VRCLW1DkpDLXjvSP2CxXEc1NaTgCpDKBqbMrU1kXPWsbNh92jvhUvd5gXKJmVOlx13IcALaZ0m3lGQVihQ3546qt3T70C/+GudDKSOTKXeIKT2KDgOPACe5yGrDJLCEJcZonEZcZFp21RABQ9wFjCBB4wCEr0fMGjfh+K0wODwAGE52+kRQvJEWvHtlHZdr62hKIAqJWYmtae46QVeBQ6iZIUSjEFVUmpqdFOYVa+fwQta6hi0dk1tOgqmSFoKQmIEW2k+DrX5KHh3CYSS9pQ2+dBOgDEYq+cDfOIYsRDUljrwHhVIBKD0Tg5j2vtINPOcyarVzzClt91CyXitjU9JdePdpeDdpRk39amdnyTOZE0bTOjZd9DebmtBI4CDCpUxyLICSZYhSSrEuIy4JENOzGpSZAaWrGnCcdozkzVNwIHxAhh4MF67tjLwAC+k7MvDYBTAu4u0659MEShC8tlZ3aOrDDDwkGQLlGAUTEE/3KMzyAffTtyjX9g+y9RfB6W+l/foqfWQoN2PM6ZkbOv5PboPvMOX8ZkOyj26whBXVMRFhrAoQ5K0e3aFcWCcAHAmMFOiPad79LxGASgybLEsHRAwphVqTV6w9E5IlgtWMiDDoI1Ecyl/EjnYDAycgYdgd4FXIlBFBWrbKTBFBl9Qrl8ElJYTUP0nwbtK9JQ2pqqQ9r0OADBOXKiPSrNIq1Y/wztSv7hxHK8Ve1UTF9nkNFijVj+jY5qaUDRau4CmpLTx7lLwzgJASB+xMKQUfk3qdLpsh/SLtM9bXzkp84KUvGC1X5iydAiSHQyeT9RTTOS984JWfJYXEhdWAYJBAC8IkBWGmMwQlxhCMQlxkUFSVIgKwBgHmJKjVN1jRnPi/dHFjZBcc8ZBJb3OEaAvG60PEmhpEMmC2xA4gKngLWYIdht4JQIl4AeLtgEWO3i7dhPPVAXy0fcBRYZhzIz2tIimI1AaD4MvKIdhxMTEmXNQGmoBxiAUVCRurKGdmxgFk+L6e+Q4LrE4QvoIPGfzaMErizPtMzGOmakdL6X9513F+nUjleDNXL46ed5df96pHY3U2QHJNj2xjz7rK9mv09peBg6yCkiKCkkF4qKCmATIKpf4YwDjzdqTjInOhqVj4InXZjehQ+ewC8zIa0EzrpPrDSFkUA3YPTo48GYjBLsNnGQAaz7ZxT16sZ7S1rt7dC7lHl1un2Vq6It79HMzPrtcv0fnBe2PCiAuMcQkFcGodo8uyto9OjgOMNM9+lBFASgypPTsgpUcCUnmZic6IMkUiQSO63jBMmjHVGRwRqNeaI+pitaBUCQIZTX6KIhy+gCUpiPgSscA3mn6cZW6PQAA3lMGGBINqyxq9TPSVl5LFN5LFidKbre6wfvK09InAMAw+jyto2RsH8EWvCP1lIxUQtGYjG3aBTD7xYll6Vi0j3J0uDjps6W4tM8zOZLUvvpGasqJAAjahQm8kEgtSV7IOtQ6SZvizIFP5MlzHCDJDDFZQTyuIBgUERdViLICWVL18XUtvx5pM7rIwDh8+DDuuOMO7N69G1arFZdffjnWrFkDi8XS7XM3b96MRx99FHV1daisrMT3v/99LF26NG2f3/72t9i1axc++ugjhEIhPPvss5gyZUrGsRobG3HnnXdix44d4HkeixYtwtq1a+HxePrqrZI+os06UtLa9fb2XElpz3sRVOK0m2HGCVpnAGpa+pcaaIQSagZv94J3l2iHUWTIe/8NMAbD1MXt5xds1INKyQAUOB4s4tfaxUTBVwBae86n18/gOA68r7y9XUvg3SXaTKUOxbeN4y7M+Ix4mxvZlnPrOPqd9rlmHa1O3ZaSQtixs8GgLc+N5OyulOAPn2jTE4E7raNhAMfzUMFBVoB4YhAgGpcRFRlkBZAVBlnRuoMQOKDz2BchJE8N/j36pPagUv0BKI1HtIDSqAn6cdvv0Ue0B4oUukc/03t0juP1QQeO4xCTFETiMkIRGeGIBElWIEqKNiicvEenTLohjwJQJOdpDWZ6QT+oHTshiam1itLlBQvgEyMhXPuotiyCSSJ4k7U9B1uRoZz8DEwRYag8r/2CdXo/1KajEApHp6z0w0FtOgogkcag18/Q7qCZ3D5dluN5bUSEF9LOi3cVg7M4MtIijBMXpuWLA12ktHW42KV/hmcwNTbZyUiOJKUttZ28MHEAb9I7dFziT+oFSJ/KnLhYtY9Spx6v59ovZICkMITjMmJxBaGohJioQJK0wuE0pp1bAoEArrnmGpSVlWHDhg1oaWnBunXr4Pf7ce+993b53Jdeegm33norVq5ciblz5+LVV1/F6tWr4XQ6MW/ePH2/P//5z6ioqMDcuXPxz3/+M+uxZFnG9ddfD0mScPfdd0OWZdxzzz1YtWoV/vjHP/b695H0Xs+DSu37ZS/KnS2oxIPFwlr6QspMH8V/EmpbAzhXUfsNvyJDOvAmAMBYs0if8cOibVBbjmtNViIApU/5B9PqJCXPwOLUgkUps484jtNWCOq4wmZBReYS0wAMI6oztnFGi56ml/H5dRo0ytLZ6Gq0OtkGp6awCUJ7pyORqsEJ7ekOXFoHIz1NheM58LygpZAwBklWEZcVxCUV0YiEaGJRB1lRs7TRyXMghOSTvL1HT9RWYkpKe552j55yVq4ScGa6R+8Nnm+/T4/FZETiCoKROOKiVstPUekufTijABQZFJ1esJJpE51esBL7JqfzA8h6wYqHweJhrXOQGBlmigT56AftOdjJC1bTEe3ilHrB4niobae1v6dMl+USI9gsdRSG57XRikTx2CTeVwHeWw7BnD5iYaiYho44iyNjRSAAesM/kFNj26cqd+xspI9qaCMl/T9M0THgFIvLiMYVhCIS4qICSVYgydkKQpJc8vTTTyMQCGDLli3w+bSZIoIgYM2aNbjhhhtQVZVZxDLpgQcewJIlS3DLLbcAAC688EIcPnwYGzZsSAtA/fvf/wbP83jnnXc6DUC9/PLL2Lt3L55//nmMH6/9ey8uLsbVV1+N119/HQsWLOirtzysdBlUStat0NPfehJUSrTnnJZexSKtYIoMwTeqfZZp8zEorSfBe0a0B3YUGfKR3QAAPiWohHgEarARvCklqJNo98AnZkIl9uXsPghAWlFWjuO0Yt6CAZwpNS2ipD1IlSJbmlvqKkZnmr6WcrAOo9XJzoYxcR3kwXEGLXjUMdiU1slI/29POxupI9rJYJMoKohLMqKx7oJNhJBcNjj36HIidVnUapl2uEdnhZUwlCZmKvXJPXo5eO+otDQ3oJN7dLNdD36lbdfb9A6zR4fRPXr7W+DA8xwUlSEuKoiIMkIREdG4NjBM9+kkFQWgSJ/p8oKlFwFMTq+Vu7xgMcaBUxVwJrM+GssifrBoELzdo48uMFmCXPs2mCLBOOmijAsWX1jZvtoOJ2hpEUD6Bcto0epqpFyEOJ6HUDZRW30iNS2icHTWqbFCybiMbVzK8ZiqvX+mdDNarU+N7XiwzkarE1Njk6MaZzA1Nte01wfhtBH0RMApGBUhitpFjC5k+WfHjh2YPXu2HnwCgMsuuwxr167F9u3bOw1AHT9+HIcOHcLNN9+ctn3ZsmW47bbb0NLSoh+T57v/fd6+fTuqq6v14BMATJ8+HSNHjsT27dspAJVCL7qd0q7rHZAeB5USDVoikMIJJj2opLadAlRFq1+UDCo11EJuPg6hoLx9ZR1FhnziEwCA4BnR3lbLorZUtOhpP2le0FLPeIN2XsmgkrMIgtGSMVPJOOniLCPYPiBLUVY9pSMRXGOKDCYnA0Z9n77WcbQ6s7OR8nec3Wh1V7IGm5IzmyjYREhe6P979DawaODM79F5vot7dHta/aK+vEdnjKXco0tam0736N3iOG2WEwO0a0FcQjgqIRyVE6uVKuljS4SkoAAU6VLmEtRK7y5YqceRJe2CZXO1X7CCTVDDrRBcRe2rRcgi5H07AMZgnLxYb4BZxK/NVGKV7dNbBUEr7AekX7DMDnCOgrTpshzPw1BxrnZBSJleKxRUaMVfOxB85Vk/C32pZ72Tpeo/Z+twcAIP1ShrxWRVADkwNTaXJC9iAAdRVttnOCUCTqKsdWpIfqutrcWVV16Zts1kMqGiogK1tbWdPu/QoUMAgLFjx6Ztr6qqAmMMhw4dSgtq9eQ8sgW7xo0b1+V5DBU9Ciqpit6egykp14H2WThMUcApEiAYtXaW48EAqM1HwFQFhpGT9fZJPrUPavMxCMVjwacEldT6gwCg1eBIHYVWpLTUZfACOLtX64Ck3NHynhEZK7pxHKctR91BtjpJyZml2meS2q6rHTocKTOQGMAZBDATS7TpLMtotSExA0nocfparnQ2MoJNSnJmEwWbCMk1g36PXrM4EVABWKQ1+z26HNfOrbt7dG5w7tEBgBkEMDMDk0XtPp3u0bOitDrSVygANQz16IKVvFipSqK4HmvvuAAAODCmgEXD4JgC3lXUfsHyn4IaagbvLtVX1mGyCOnQdgBIv2DFQ2D+k1ANxvaUhbSOSPsFi7d5AK8M3treieA4HoaqC7SOScrzBG9Z1lV9eFeRPlWWKVKHTkfHCxSDXsA2ddQ6ddSC57ULlD5ibWjvcPDaiLXBIMDscyBqjkJWkT6aPQylBpzikoKYpCAWVxCMiBAlBZKkdW7I0BIIBOByuTK2u1wutLW1dfq85GMdn+t2u9Me7815OJ3OjO0ul6vLANTixYs7feyf//wnBGHwqiaztBHtbEtQJ2YqdRdUEmOAHAdntGopwRwPxjgopw8AqgzD6PPbg0on90JpOQ6haEz7Es6KDLXlhPb3ERP1NlkfaVbSg0q8Z0SiRlJKUMk7CryrBEgpvs1xHIxjZmS8b85sB0y29utWWgpb6si1mvYaKQdGZhqboKWxCYaMFLZkZ8NgNMDkdcBgjkJWOh4nf1CwiZDc0//36Kehhpp6dI+OeLibe3QJ4LW2utN79LGzcvoePa1Nt0QhKwx62uAwly2tLhgREYtrhcNpcJicKQpADRGZFyy1wxLUnV+wmKpoN84M2gUr1AIwFYJ3lD6aqzQfhxo4Dd47CoZErQ3tgrULgJZLrQeV5DhYqBkstaaRkBgRFozaefCJoJKjQLsgpNXa4GGcMF8bWU+5AKQuH5264gNnsmp/l8W0PGyWHPnoqNNOh/Ze06bJZqQ9ZP69u04HZ+C14olGFdwwbKy1C5h2f6DNcFIQjcmJGU5aOh0FnIYvxliPOu4d92GJmTBn0unP9pyensdASQ0gZQ8qJQt1py9BzVQFXPKmHACLhQAxApgTtTY4HkwFlBMfg6kKjOPntgeV/KegNieCSq4i7QCqAhZs1P+uB5UMxrQC24AWaBKKxmRs5wsqwRdUpo1qcxwHw6hz0t8vY9o+HKe9HzHWHljLltKWfJ+J9DW9dkay+HdK6oM2cs23d074ztrz7jsdWptuAWdQwGW7xuSgToNNopY6kQw2SYoKhYJNhPSpXLpHRy/u0TmHDwIvgEuZPTrU7tGBRJtuNIMTZHAsP9r0/pCWVicqiMYVhGNaWp0oaTVXKa2O9AUKQOUBpipgUhxMkjtcsBJFAPUaHIm6FLKkNfqCITEQLENtOw1OVbWaGskLVsMhqP6TWs50sZbewmQR0mGtgKtQPE6/uHBMBeIRQI63n5hg0KbPGozaCE1i3UxttQh7h1obPIyTFmVcCDi7Tws+scTU19S8a0nWOlSdTJlNu7gkUyAEA/TVe1I7HcmORUrudXrhVRrp6CvJERMGBlFSERPlxJKrIiRJhSQriREmMpy4XC4EAoGM7cFgsMsC5KkznQoLC/XtyWNlm1V1pufR1bG2bdvW5XFZL+7KVFkEE6NgiTauq6CSqsqALILjjXpQSQ21AvEQOFui1gbHg6kq5MO7AKaktbWpQSXOU6odQDBogSntZPSAkTbzyZkWQOJ4Qau1kVxuOoEvGtteoykFXzS2PWAki2kj12AMamodDT1QxumBpOw1kQS949GXnY6hioJNhAycnLpHT5akANrTow3GRD28xL6uYghmG92jEwDpaXXRmHa/HgyLECUVoqRApbQ60g8oAJUHxNZ6iHWHtUwJgzlxwZKgNh0DGIOhbJI+QqA0HITqPwWhZFzaBUs58h4YAGHk5PYLFi8kan2kpEUIRnAOX6LWhgo9qOQt07Z3yNc2TtBqbSRHaZKjHZzRol1s45G0KbMsOWU2uXQo37FwX0redeqqD0KHi1QnnY/h3OkYLMmAk8oYRElBTFQQicsIRyWIiYCTQgGnYa+qqiojxU0URRw7diyjNlSqZO2nQ4cOpQWqamtrwXFcRm2onpzHZ599lrH94MGDuPjii3t1rDOhSjHE6w5DbG4BE2ztQaW2BrBoG3hnotYGx4MpCuSD/wuO52Gs+Zzevqn+01o7b7Roo8uAdmOfbMtTg0oWJ3hnoZaqlsDxglZrw5CYJZQgFFZCKKxMFGVV9M4G7ywGwLSR85S0Npa105Fl9FoQAM4ECIkUiM4Ka6d2PigFokco2ETI4BL9Z3uPLqXco9cguXInJ5ztPTpH9+gkQ2paXUxMLPKTTKuTKa2ODAwKQOWB+LFPIR36FHzpJAjFySKAEpRQs7aD0axfsHiTBYzjtA5IkmDUam0YTOkXrIJy8N4yvdZGsmNhKJ/WnmstJVIgoF1YmSKBRcXMk+x2ymz2WhrZRq+p05HbsgacYjJCMUmb4USFCEkWCxYswMMPP4zW1lZ4vV4AwCuvvAJRFLFw4cJOn1deXo6xY8fihRdewCWXXKJvf/755zF16tReFSAHgIULF+Jvf/tbWjHyDz74AHV1dV2eR58RYwh+vB2ywsEwKT2oxMKtgM2TFlTikiPHKUEl3ubROhLW9hlbHC/AUHWhlhrHJ1f3UcG7SwFXSaI9j6enRYBpdfhSC2l0VkuD4wGh+1oamR0P6nT0FQo2EZJ74kfP9h7dkHKPnlIPz1cB3kP36OTsZE2ri0oIx9oHiSmtjgw0CkDlAc5oBicYkXYPn6y1kSjQncQXjgFXOBocxyeKsmppD0LxOO3vchxMiqZPmRXl9hvVjrU0aMrssJcacIpLKmJxSZ/hpC21qtIUXdKt5cuX46mnnsKqVauwatUqNDc346677sIVV1yRNrNp7dq12LJlC/bs2aNvu+mmm7B69WpUVFRgzpw52LZtG958801s3Lgx7TV27tyJlpYWHDyora729ttvo66uDiNHjsSUKVMAAJdeeimqq6tx00034eabb4aiKLj77rtx/vnnY/78+f3/QRhMiXbUmFZTiXcWgjMYwdm8+q4cL8BQvUCvnZQsysrZ3BCsLq0DEgulrNYGbcUhOa616Vk7Hcm0ttQ2ndLacg0FmwjJD3SPTnINpdWRXEcBqDxgGVWNKGeDylnAxKh+weKSo9rxsHaxSqmlwTKmzKbW0qAps6Rz2oWLg8pUxCWGWFwbKYnEZAo4kTPmcrmwadMm3HHHHbjxxhthsViwbNkyrFmzJm0/VVWhKEratqVLlyIWi+GRRx7BE088gcrKSqxfvx7z5s1L2+/BBx/Ezp079Z/vvfdeAMCXv/xl3HXXXQAAg8GAxx9/HHfeeSd+/OMfg+M4LFq0CGvXrh2Qto7jBTinXoxgWIQiy2CKVleDM5gARyEABjXa1vFJYBm1NARt9aEsy0NndDpSOh/U6cg9WYNN8cRqdBRsIiSn0T06GWyUVkfyDcd6UzmV9BnGGJqaQt3uZzDwcAhRtJ46pS2KkbxQCQagkyWi0y5OVEtj0BkMPLxeO1pbwzl5EUgGnBSVIS4pWtHwqIxwTIYkK5Ao4AQAcDvNmF5TimAg2u33WFjooJvCYaanbboAGXa1DYG2sFYbLZkGwSUKbXea1tYhDYJ+vwbN2bTpnc5sklRE4hJiFGwaEEYjj5qqIph4Bkmi9pyko3v04SXX79M7SqbVqQwQJS2tLhSVEBnGaXV0j55faAZUHjA4C2CQTJAVRqPX5KxlCziFo7I2w0lWIEmqtlIVAQDIioq9x1pxvCEEh8OMER7LYJ8SyWOcwQSTuxyCIQKmMLoJGsK6mtlEwSZChga6RycDIZlWJ8oM0bh2zx6KUFodyU8UgMoDHMdpKRZq7kflSe7RA06KFnCKijLCMQnRmKwVDZcp4JSNJKv49HALdh9oRDiqrULzSW0zRpw/cpDPjOS7ZN0latOHjp4EmyRZhayoeTHCTgjpGbpHJ/0hW1pdICwiLsoQJe1aQki+ogAUIUNMMuAkqyriorZKXSgqIRpPBpyG39Tc3ohLCj6qbcb7BxoRE7VaRHaLAXOmjMAV88ciFokP8hkSQnKBIHBQVI6CTYQQQs4KpdWR4YQCUITkOZ7XRkkkWU3McFIQjoqIxrROEF20eiYSl/HBgSZ8VNsEMdFpdNlNmDGhCBMrvSjwWGE08IgN8nkSQgae1jngoTKGqKgg2hhCU0s4kbpMwSZCCCG902lanUgL/pChjQJQhOSZ1IBTTFIQiysIRcXEqLsWdKKAU88FIyLeP9CETw43Q1a0D87nNGPGxGJMGOUBz1ONHkKGo2QKhKyoWscgpi1lLSsqzGYjgqGYVkieEEII6UZqDdaoKCNGaXVkmKIAFCE5rL2uCCDJDDFZQTyxvGpcbF9elQJOvecPxbF7XyM+O9qq18Aq9loxs7oYY8tcVByakGEo2UGISwoiMQnBqIhIVEZcal/KWhA4mMzGQT5TcjZiovadmsxUNJoQ0j9S0+rikoJoRE6k1cmQJG3RH7p9J8MRBaAIySFpASeFIRaXEzOcJMREBVKiE0QXrDPX3BbDrn0N2H/cr3+OIwvtmDmxGOXFtDQrIcNJampdLK4gHJe0Eem4gjitLDQkMMbQFhJxsjmMU80RnGoOoyUYh9tuwv0/nDfYp0cIGUJ4ngMSg8bJtLpgRIREaXX9gjGGRn8Unx1rxdhyL4TBPiHSIxSAImQQJQNO4AA5EXCKxhWEIhLiYntKHTl7p1si2LW3AYdOBfRto0udmFFdjLJC+yCeGSFkICXTmEVZRTSmjUjrba6kUIA/z8mKikZ/FKeaI3rQKRqXM/YbVeKEwHOQqUNICDlDqQv/xEQF0ZiMYESitLp+FonL2HesFZ8dbUVTm1ad1eUw44tzRw/uiZEeoQAUIQOoPeCUKBoelxEVtZQ6UUwWDaeLVV9hjKGuKYx39zbgeENI3z5upBszJhaj2GMdxLMjhAyUZCchJsqIRGSEIhLCMRliSmodyU/RuKzPbDrVHEZ9axRKh6ASz3Mo8VpRVmDHiAIbykudmFEzAhzHAAo5EkJ6KHXWbFxSEY2IlFY3QFSV4Wh9EHuOtODwqaBePkPgOUys9OLzc8eA2vP8kNMBqMOHD+OOO+7A7t27YbVacfnll2PNmjWwWCzdPnfz5s149NFHUVdXh8rKSnz/+9/H0qVL0/aRJAkbNmzA5s2bEQwGMXXqVNx+++2YOHGivk9LSwseeughfPjhh/jss89gNBrx/vvv9/l7JUNTsoitqjJIiUK20UTR8OQqF9T56XuMMRw5HcS7extwuiUCQLtpmFjhxfkTiuBzdd+GEELyV9qqdXEZ4UQaRCyuQKTUurzFGIM/JOJUc1if3dQajGfsZzEJerCprNCOIo8VBqG93pPRSLWfzlYu3KN/8sknuO+++7Bv3z60tbWhsLAQc+bMwQ9/+EOUlJT0+Xsmw1PHtLpwVEIoKlFa3QBpDcaw50gr9h5rRTjWPpu12GtFTaUPE8rdKCmww+eyIBiIDuKZkp7K2QBUIBDANddcg7KyMmzYsAEtLS1Yt24d/H4/7r333i6f+9JLL+HWW2/FypUrMXfuXLz66qtYvXo1nE4n5s1rz/dft24dtmzZgltvvRUjR47Exo0b8e1vfxtbt25FUVERAKC+vh4vvPACpk6dinPOOQf79u3r1/dN8ltylF1lDKKkICYqiMsqWHMUbYEoYnGFpuP2I5UxHKxrw669DfqUXIHnUDPah/MnFMFlNw3yGRJC+ktqal0kJiMckRCMSBAlSq3LV8l0upNNifpNLWFE40rGfl6nWQs2FdgxosAOj8NE9fz6Ua7coweDQYwdOxZf+9rXUFBQgGPHjuGhhx7Cxx9/jOeeew4mE13zSe8l7+UlRVttOpoYwEimacu0+mm/EyUFB060Yc/RFpxqjujbLSYBEyu8qBntRaF7cLIYKPh+9nI2APX0008jEAhgy5Yt8Pl8AABBELBmzRrccMMNqKqq6vS5DzzwAJYsWYJbbrkFAHDhhRfi8OHD2LBhg35xq6+vx9NPP43bb78dV111FQBg2rRpWLx4MTZt2oQ1a9YAAKqrq/HWW28BAB588EEKQBFdMp2O5xPpdImAUzSmjbbLyfpNHOBwWBCNy7Rkdz9RVIZ9x1qxa18D/CERAGA08JgytgDnjS+E3UIrVhEyFCVHpuOigkhE6yREYgpEkYL9+UhLpwvr9ZsasqTTCYl0uhGJYNOIAhus5py9nR2ScuUeffbs2Zg9e7Z+7FmzZmHEiBH4j//4D3zyySeYPn16v7x/MrQkY9Ucx0FUmJZWF9HS6kRZS6sj/Y8xhpNNYew52ooDJ/x6oI/jgMoSJyaP9mH0CCcEfvBmsA7H4DtjKpgsgTea++yYOXvF3rFjB2bPnq1f2ADgsssuw9q1a7F9+/ZOL27Hjx/HoUOHcPPNN6dtX7ZsGW677Ta0tLTA5/PhjTfegKIouPzyy/V9HA4HFi1ahO3bt+sXN34Qf8lJbtGCTQCgjbAn6zeFo8mC4SokWQHrEGMSBBqF7S+youLTwy1470AjghEJAGA2Cjh3XCGmjSuAxZSzTRwh5Awkg/6KyhAVtRWGAuE44qJKqXV5Rkuni+Nksn5TUwStocx0OqtZwIgCu55S1zGdjgy8XLlHz8bj8QAAZDmz8DwhqQSBg6ICwagMf6QNDc1hxOIyJEnV6wuR/heMiNh7rBV7jrSiLSzq271OM2oqvZhY4YXdmhsDycMh+K7KIsKfvoHIwfcQO7EXSrgNAMAJBhgLy2EdfQ4c5yyAuWT0Gb9GzvbOamtrceWVV6ZtM5lMqKioQG1tbafPO3ToEABg7NixadurqqrAGMOhQ4fg8/lQW1uLwsJC/UKVut/WrVuhqioFn4a59nQ6FaLEEBMlvX5Tslg41W8aHHFJwceHmvH+gSZ9dSObxYDp44twzhgfTEZaiJWQoUJriwFRZojGJH3VOlHSVhki+UFWVDS0RhP1m7SgU0zMnk6n128qsMNN6XQ5J9fu0RVFgaIoOH78OO655x5MnjyZZj+RrHieA4M22zIYkNAWFCErCswWE0IRkTIVBoisqDh0MoA9R1twrL59kSCjgceEUR7UjPai1GfLubZ/KAffVSmOtv/9G9re/QfUeATGgjJYR0+BYHeDE4xQYiHI/noEP3gVbe9shWVUNXyLVsAyqrrXr5WzAahAIACXy5Wx3eVyoa2trdPnJR/r+Fy32532eCAQgNPpzHi+2+2GJEmIRCJwOBxnfP6LFy/u9LF//vOfEATqIOeSZDodxwGywvR0ukhMQiSm6Ol0HVMByMCKxmV8WNuEDw82Iy5pHRenzYjzJxSjZrSXRsUJGQLaVwuF1g6HtdS6aHLVOuog5IVIXMapprAecGrwRzNmqAk8hxKfLaV+k41mruaBXLtH/+Y3v4n33nsPAHDOOefgscceg8HQ+e8R3aMPL1qqtrYKaigkoS0YRyyu6PeRgsCh75KLSGcYY2j0R7HnSCv2Hffrnz8AjCyyo6bSh3Ej3TAacvdefigH348//APwRgs8866EY/ICGByerPsxxhA7+gmCH76GU0/9PxRcdj1c532uV6+Vd1d5xliPoqEd92GMZWzPdhxGUy6HhWQaB6DNpkkGnNrT6bSAE/065IZQVML7BxrxyaEWSIm6Ll6nGTOqizGh3AOBz60REkJI76Sm1oVFGZGojGA4jrioQKR0iJzHGENrMK6vTHeqOazX40tlNRtQVmDTazcVe62DWs+D9K3Buke/8847EQwGcfToUTz22GO49tpr8ac//emsBpJJfuM4DoLAaff2ERFtIRGRmIy4KNO9/QCLxmXsO+bHnqMt+gJBAOCwGrUUu0ovPI6BDQGePHkSK1as6PTxbdu2Zd2e78H3rngXLIdz6kXg+K4D8BzHwTp6Cqyjp0Ba8HXIgaZev1bOBqBcLhcCgUDG9mAw2GV+ZeoXWVhYqG9PHiv5xXd2/EAgAKPRCJvNdlbn39kvbhIFugZW6up0cUlNpNNpS6lKUiKdjgrW5py2sIj39jXg06Ot+sh5kceCGdXFqBrpBp9jU3MJIT2XmloXiUkIRURtEECioq+5TlZU1CfT6ZrCON0SyZpO53OZ9ZXpRhTY4LZTOt1QkGv36MlZBdOmTcPs2bNx8cUX489//jOuu+66rOdB9+hDE8dptXtlRUUoKqEtLCIcERETqT7gQFNVhmP1QXx6tBWHTwb0QSSB51BV5kLNaB9GFTuGzH38UAi+u87tfGZoZ4zeUhi9pb1+Xs4GoKqqqjKmsomiiGPHjmVMfUuVvAgdOnQo7SJYW1sLjuP0x6uqqtDc3Ay/3582za22thZjxoyh+k95rLN0unBMQjTWPruJLka5qzkQw+59Ddh33K+PVI0osGHmxGJUljipA0NIHtI6BxxUBsQlFZGwiEBYRCwuIy4pVHsjh0ViciKVTpvh1NAazZiVZhA4lHhtiYLhNpRSOt2Qlcv36EVFRSguLsbRo0fP5K2RPCQI2nUlHJMQDEsIhEXEaSXUQdEajGPP0RbsPdqKcKy9FlGxx4qa0V5MKPfkxHWhrKys20B0NvkefM8Vg/8b0IkFCxbg4YcfRmtrK7xeLwDglVdegSiKWLhwYafPKy8vx9ixY/HCCy/gkksu0bc///zzmDp1ql40bN68eeB5Hi+++CKuvvpqAEA4HMZrr72Gr33ta/34zkhfS6ZuMDCIsqrldYsKQhFtJF2mdLq80dAawbt7G1B7sr3xrShxYGZ1MUYW0VR6QvJNsn2WVRWRuIxITEmsWqdAlDJXDSWDjzGGlmBcW5muOYKTTeG0lYmSbBaDHmwaUWBHkcdC6XTDRC7fo9fV1eH06dMoLy8/27dJcphW1wmIxhWtmHg4rq9gRwaWKCk4cKINe4624FRzRN9uMQmYWOFFzWgvCt3WQTzDvkPB976RswGo5cuX46mnnsKqVauwatUqNDc346677sIVV1yR9sWtXbsWW7ZswZ49e/RtN910E1avXo2KigrMmTMH27Ztw5tvvomNGzfq+5SUlGD58uW49957YTAYUFZWhieffBIAcM0116Sdy0svvQQAOHjwIBRF0X+eMmUKRo4c2W+fAckumU6nqMmAUyKdLkbpdPmqrimMd/fWp62EUVXmwoyJxSjxnl06LCFkYCVT6+KSimhcW7EuFJMgitpgAMktsqKiviWir0x3qjmSVhw2qcBlwYiC9hlOLkqnG7Zy5R795z//ObxeL6ZMmQKHw4HDhw/jySefRGFhIb761a8OwCdBBlIy6BQXFYTCMvxBLegkigpoLGNgMcZwsimMPUdbceCEX18chANQWepEzWgfxoxwDrlBCQq+942cDUC5XC5s2rQJd9xxB2688UZYLBYsW7YsY/lBVVWhKOk3SkuXLkUsFsMjjzyCJ554ApWVlVi/fj3mzZuXtt+tt94Km82G+++/H8FgENOmTcOmTZtQVFSUtt8Pf/jDrD+vW7cOX/nKV/rqLZMsUtPpJJkhLidWp4tqQSdJVimdLk8xxnC0PoRde+txMjFiwnHAhHIPZlQXo8BlGeQzJIT0RGpqXUxUEInLCIZFRBMdA1o9NLdEYpIebDrZHEFjZ+l0vvaV6Ub47DCbaGUwosmVe/SpU6fiL3/5C/7nf/4HoihixIgRWLhwIb73ve/pnUOS35J1nURZRSAkoi0cRyQqI0bFxAdFMCJi77FW7DnSmjYz1uswY9JoLyZWeOGwGgfxDPvXcAy+K+E28DYnOK7vgokco0p7g4IxhqamULf7GQw8vF47WlvDkIfByHFGOp2oIBZXEIqKECUVkqxAzrN0OkHg4HBYEArFqMYJtN/92pMBvLu3AY3+KACt81pT6cX5E4rgHuCVMHrCYOBR5LViUlURAm2Rbv8tFhY6aGbAMDPc2nQ9tU5RERVlhGMyAmER4jBIrcunNl1Pp2sK60GnbOl09kQ63YgCLehU6LEO6dVFjUYeNVVFMPGs25Qdas+Hn+HWnueaZNBJURlCMQnBkIhgVEI8LvfLgEY+temDQVZUHDoVwJ4jLTheH9JnmxkNPCaM8qBmtBelPtugtpNupxnTa0oRDET7/R798OHDuOOOO7B79+604LvF0j5wfuutt2Lz5s3Yt29f2nM3b96MRx55BHV1daisrMQPfvADLF26NG0fURSxYcMGbN68WQ++33777Zg4caK+z7PPPou//OUvOHz4sB58nzdvHr73ve+l1Zg6W+F9O9Gw+T7Yqmeh+Es/6rMgFAWgBgld3DSp6XRxSavdFI3LCMUkyEMknY4ubBpFZdh/3I9d+xrQGowD0EbZp4wtwHnji3J2xMRmNaLYa0WR1wqP29ajf4vUYRl+hkObnkx/ECWtnlMoIiEclSBKwyu1LpfbdElWUd8awakepNOVFdgwolBboc5lMw6rNosCUKQrw6E9z0XaADS0WbQRCYFQHDFR6ffPNpfb9MHU4I9iz5EW7DvmT7uOjCy0o2a0F+NGemA05EaK3UAGoIaL8P53Uf/XewFFATgO9kmz+ywIlbMpeGToSUunUxhikoJ4XFudLkbpdEOWrKjYc6QV7+1vQCAiAQDMRgHTqgowbVwhrObcbIZ4noPHZUapzwarSQCj30syzCRT6xgDoqKCSGKWUywuQ5QotS4XhGOSXij8VHMYjf4oOn4tBoFDqc+WmOFkxwifjdLpCCE5ITkQHRUVBINxtIXiiMW1mbRk4EXjMvYd92PPkRY0tcX07Q6rEZMqvZhU6YUnBzMVSN9KznxyTJqD0KdvwF59ASL730XDlvv7JAiVmz0/MiQkUzRUxiDJKmJSSjqdmJJON9gnSvqFKCv45FAL3j/QqC/FajULOG98EaaMLYDZmLsdILNJQJHXhkK3BRwYFIXBYKDREjL0pabWRWIyQjEZwcjwSK3LdYwxNAdiWsCpOYxTTREEIp2n05UV2DGi0IZC99BOpyOE5BftOqMtVBEKi2gLiYjGtJWr6Roz8FSV4Vh9EHuOtuLQyYBeE1DgOYwtc6FmtA/lxQ7wNGto2JDbGmCfNBtFX7gRoU9eh7XqPDinXgz/O38Dk0RwprOr00sBKNIn2mc3cVAUrVh4XFQQiUkIx7TZTbKs6KskkKErJsr4sLYZHx5sQkzURrAcViPOn1CEmtG+nJmumw3HAU67CaU+G5w2IxSFUYCUDHlaah0HUdLa7GBURCQqD7vUulwjySpOt7Sn0p1qCUPMki5W6Lak1W9yDrN0OkJI7kvWdZIUFeGIiEBYRCgqIS4qlPkwSFqDcXx2tAWfHW3VB4oBoMhjRc1oL6rLPbCYKFQwHLlnLcvYZht/Pmzjz++T49NvFTkjemoGAFlhiIlaOl0oJiIW12Y2UTrd8BKOSfjgQBM+OtSsd1o9DhPOry7GxApPzi/FajTw8LktKPHZYOA5qgNAhqxkR0BlDLG4tmpdWziOeFxBXKLOwGAJRSU92HSyOYymLOl0RoFPrE6npdSVFthyejYpIWR4EwQOiqrdI7ZFJITCImKiTPdYg0SUFByoa8NnR1r0FagBwGISMLFCS7Er8lgH8QzJcEABKNIjyRxtlWmr08VFBVFRK0IrJUbJKZ1ueAqERby3vxGfHmnRa8IUui2YUV2McaPceTFl1241othnhc9pgaJQ4JQMPck2XFJURGPaqnXB5Kp1MqU9DDSVMbQEYjjZlJzhFNZr5KWyW416sKmsQEun4ymdjhCSw5ID1NG4jGBAQltQRFyUaUbtIGGM4WRzBHuOtODgiTZIicWdOACVpU7UjPZhzAhnzg8Uk6GDAlAkQzKdTqsDoq1OFxNlRGLaH61YuEKjF8NcazCGXfsase9Yqz5KX+qzYebEYowudeZFCoiQUmjcbBSg5PmKi4SkSgadYpKCaERCMCIiEpMRl/p/VSGSLjWd7mRzGKebIxA7fAccgIJEOl0y6ETpdISQfJBcJTUuKgiFZPhDMcRiStZVOMnACEZE7D2mFRRvC7fXC/Q4TKgZ7cPECm/OrkBNhjYKQJGUdDoOkqwiLsqIiypCUVFb/lRKpNPREDkB0OiP4t29DThY16ZvKy9yYMbEYowqsudNZ8liNqDIY0WhxwIwRrOeSN5LTa2LxrUBg0BE1FcUot/xgROKSolC4VpKXWNbNGOWmVHgtdXpChPpdD5KpyOE5I/kYLUoq2gLxdEWSgxyiDLNqh0ksqLi8KkA9hxpxbH6oJ6ZYjTwGD/KjcmjfSj12fLmXp0MTRSAGobS0ukkBXFJRTQuIxRtT6ejabKko1PNYby7twFHTgf1bWNGuDBzYjFKfbZBPLPe4TjAZTehpMAGp9VEs55IXuP59g5AJCYjHJUQDEtaAXFJobToAaAyhua2WFr9pmCWdDqH1agXCh9B6XSEkDyUHOiQFRWhqIS2sIhwRBuwpkGOwdPgj+KzIy3Yd9yvLwAEAGWFdkwe7UXVSDdMBhrgILmBAlBDXGo6naSoEEUVMYnS6UjPMMZwvCGEd/c1oK4xDEBLExlf7sGM6iIUuvOrUKHRwKPAY0WJ1wqe4yj4RPKSnlonyohE5ERqnQJRVCDT73S/EyUFh0+2ofZ4K+oawzjdkj2drtCTTKfTAk5Om2lwTpgQQs5Ssq5TOCYhGJEQCIuIx+maM5iicRn7jmspdk1tMX27w2rEpEqtoLjHYR7EMyQkOwpADTFasAkAuESxcBmxuIpwYnW6ZLFwSqcjXWGM4dCpAHbtbUB9axQAwHMcJlZ6MGNCMTzO/Lug2a1GlPhs8DrNUBQVjP4NkDyRHHFWVIaYqBUQD4RFxEVKretvkqyi0R9FQ2sU9f4IGlqjaA3GM/YzGrR0umSwqdRng4nS6QgheSxZ1ykaVxCKSPCH44jFZUgSBZ0Gi8oYjtUHsedIKw6dCujXf57nUFXmQk2lD+UljrxYAIgMXxSAynMd0+liiXS6cFSElKjdROl0pKdUleHACT927WtEc0AbTTEIHCaP9mH6hKK8HMEXeA5elxklBXaYDTzNeiJ5QWvbAUlhWmpdRBt1FiUt6ET6niSraGrTgk0N/ijqWyNoDcSzpjG67SaUJgJNZQV2FLgtdMOfJwSeG7K1ttpCcbz0v0fwyaFmtCSu4T6XBVPHFeKyC0fDZc+/azgZWMmB7JikIhwW4Q/FEY3JEEVK6R5M/mAce4624LOjrQjHZH17kceKmkovqis8sJioW0/6XuXq34E3W/r0mPSbmkdS0+lEWYUkJdLpotqIuCxrM5wUGg0nvSQrKvYea8XufY36ShkmA4+pVQU4d1wRbJb8bCosZgOKvFYUuqnQeGeow5I7UlcRikS0WU7RmBZwojSHviUrKpraYmho1WY11bdG0RKMZS2ca7cYUOy1othrQ4nHitJCG0oKnQiFYpS+ngd4noPRwMNkFOCwGmGzGGC3GlHgtiAQiA726fWZD/c3Yt2mnYjEZfAcB5fdBAagriGEDw80YvO/D2Ltt2fhnKrCwT5VkmOSs2wlRUUoIqItFEckKiMuKpQxMYhEWcHBE23Yc6QFJ5sj+naLSUB1uQc1o30o8uRXKYy+xnMcrBYDPE4zDQL1E8Hm7PNj9rpXSZ2VgccYg6SoiMZkxEQFoaiEuKjo9Zvo2kDOlCSr+ORwM9470IRwVCuaazEJOG98IaaOLYTZlJ+jxBwHuBxmlBbY4LAYadZTJ6jDMriSAwqKyhARZURjMgLhOOKiCpFu/PuMrKhoDsQSgSYt4NQSiCFbPNpmTgabrCj22FDstWYsUy0IdJObyzgOMBkEGI087BYj7FYjLGYDLEZemzGuMggCB0HgB/tU+0xbKI5f/2EXbFYjbrzqPJw/qVifDRETZby7px5Pbv0Ud/33u3joJ4vpXp0AAARBS+0OxiQEwyKCEQnxuEwD2YOIMYaTzRF8dqQFB060QUrcv3IAKkudmFTpxZgRLhiGUPt1JnheCzz5XBZ4nWZYTAIt6pFHehWAos7K4FBUhuP1IQTCImRKpyN9IC4q+OhQE94/0KSvlmG3GDB9QhHOGVMAoyF/L2wmo1ZovNhDhca7Qh2WwcMYg6wyhKISglEJ4YiYSK2j39WzpagqmttiaEjWbWqNorktljWYZzEJKPHaUgJOWrCJlqfOLxwAg5GHySDAahHgsJpgNRlgNgkQeA4sMftVmwHLUp41dLz8zlGojOHuH8xHYYcZERaTAfPPHYnqSi9u+q9/45V3juLKReMH6UzJYEt20sNxGcG2GAIhEXFRpnIdgywUlfDZ0VZ8drQF/pCob/c4TKgZ7cPECm/GYMhwxPMcbBYDfG4LPA4zjAIHRaEMh3zT4wAUdVYGl6IyCj6RsxaJyfjgYCM+qm3WV21y2U2YUV2EiRXevB9Rcdi0QuNuhwmqwqjQeBeowzI4OA5o9EdxqK4N0agEmVK4zpiiMrQkZjZpAacIGttiWW9ELSYBxR5reyqdl4JN+cxo4GE0CLCYBThtJljMAixGAQaB1wNOYGzYpEh+sL8Rl8yqyGjLUxV7bfjczAq8t6+B2vNhJlkvNirKCAUl+ENxxOJUT3CwyYqKw6cC2HOkFcfqg3p43CjwGF/uRk2lDyMKbHSdQjLwpKVOexwmCLw2m3W4tPFDTY8DUNRZISR/BSMi3tvfiE+PtOgdXp/LjJnVxRg/ypP301YFgYPXZUFpgQ0mgYdKF6RuUYdlEDEgFpcp+NQLqsrQEkwEm1qjqPdH0eSPZk0VMRtTg01awMllo2BTPjMIPIxGHmaTAKfVBKtFgMVkgFHgwBj0oONwnfF6vD6IZfPGdLvf5LE+7Hj/xACcERlsyWLicUlFOCLCHxQRjUmIS1S6Y7A1+qPYc6QF+4779SwEACgrtKOm0otxo9wwGfKzBEZfE3gOtkTNPre9PfBEM57yW48DUNRZIST/+ENx7N7XiM+OtuopKMVeK2ZWF2NsmWtIdMisZgOKfFYUuiztI9+kW9RhIblKZQytwXgi2BRBgz+KRn80a8DOZOD1IFMy6OS2m4ZE2zacCTwHo1GAycjDYTPBZjHAYhRgMgoA02a3MgYa/U4IRyW4HeZu93M7zHq9RzL0JIuJy4qKYFRCIBRHOCohJip0bzTIonEZ+4/78emRFjS1xfTtdqsRkyq8qKn0wuPs/t/wcCHwHGw2IwpcWqodz4ECT/3s+GM/gm/B1bBPvKBH+8vBVvjf+isMTi88c77Sq9fqcQCKOiuE5I+mtih27WvEgeN+fUrvyCI7ZlYXo7zYMSQ6ZzzHweU0odRng50KjfcadVhILmDJYFOiZlNDawSN/pheeDWV0cCnzWwq8WjptkOhPRvusq1UZzEbYDby4KB1PBgDVGrns5IUtUcp9ALP0YqaQ5AgcFBUIByXEAhrBcXjIs2yHWwqYzhWH8KeIy04dCqgB094nkNVmQuTKn2oKHHQ6m0pBIHTVyl121MCT/Sr3O8ck+agYesG8K844DxnPiwVk2EuHQvepk1YUKU45NZ6xOr2I7J/JyKHPoS5rAqu6Tf0+rV6HICizgohue90SwTv7m3A4VMBfdvoUidmTizGiAL7IJ5Z3zIZBRR4LCj2WsGDCo2fCeqwkIHGGENbSES9P6Kn0jX4o1mL3xoELhFssukFwr1OMwWbhojUlepsFiPsVgOsZiPMRh58YqU6xhilU/fCiYZQt+n0JxpCA3Q2pL/xPAcGIBZXEAxIaAvFEYtTMfFc4A/GsedoKz471prWJy7yWFBT6cOEcg+s5l4vRD+kGQQedpsBBa7kLGYKPA007/yr4Dz3ErS9+zwCH2yD/60t2sUaACcYwBRZ25ExWComoeTLq2GfeOEZvVaPf/ups0JIbmKM4URjGLv2NuB4Y/vN5biRbsycWIyiLtJm85HDZkJJgQ1uu1ErNA66Op0p6rCQ/sIYQ1tYTCsQ3tAa1Rc/SGUQOBQlVq5MBpy8TjONCg8hPV2pjqkMCrXpZ+SBp9/rdh+Gobb+3/DC8xzAaSsZh0Jyopi4jLhIxcQHmygrOHiiDXuOtuJkU1jfbjEJqC73oGa0b8jdj/cFLfDUXuMpdcYrGXgGpxcFi1bAt/BqxE8eQOzEPsihVjBJhGBzwlgwEtbKc2BwFZzd6/RmZ+qsEJI7GGM4cjqId/c24HRLBADAc0B1hRczqovgdVoG+Qz7lkHg4XVZUOKzwmSgQuN9gTospC8wxhCMSKhPBJmS6XTxLCssCTyHQo8VJSmpdD6nJe8XQiCZaKW6gfPDr5832KdA+olWTJyDKKsIhET4w3FEojLiokyd9EHGGMOp5gj2HGnBgRNteuo4B6CixIma0V6MGeHK+xWm+4PRkAw8WbVFQpAIPA32iREA2ownS/kkWMon9cvxexWAos4KIYNPZQwHT7Rh174GvZChwHOYPNqH6ROK4LKbBvkM+57VYkCx14YCl5mKEPYR6rCQM8EYQygqob41mlYkPJZlBJ7nORS5LWkzm3wuCwQKNg1JBiFZOFwLONnMAixmWqluICyeWTHYp0D6kF5MXFURikkIhESEIhJiokz3PzkgFJXw2dFWfHa0Bf6QqG93202oGe3DpEovHFbjIJ5h7jIatIUlCtwWuGzaZ0SBp+GnxwEo6qwQMrgUVcXeY37s3tegX/CMBh5Txxbg3PGFsFuG3sWO5zm4HWaU+mywWQzUcelD1GEh3UkGm9oLhEfR4I8gGs8SbOI4FLgtKEnMair2WFHgtkDgaeR3qKKV6nIXYwyBsAiO4+C0Gal2Wp5I1nUKx2UEw1EEwyJicYVKm+QAWVFx+FQAe4604lh9UA+YGAUe40e5UTPahxEFNvq31gmjkYfTZoLPbYHLakwblCDDT48DUNRZIWRwyIqKTw+3YPf+RoQSxQwtJgHTxhViWlUBLKahWcjQbBRQkOjIcmAUfOpn1GEh4eTMppQi4ZG4nLEfzwE+l7YIQEliZlOBy0JpBkMcrVSX+/YeacGzrx3ARwcb9bpAZpOAqeOK8LXF41Fd6RvkMyQd8TwHjuMQicsIRSX4Q3HE4zJEif4d5YJGfxR7jrRg33F/2kzfskI7aiq9GDfKDZNBGMQzzG0mowCH3YgCl0WbFUaBJ4JepuDFJQVvf3wKDa0RuB1mXDC5tEcr4xFCei8uKfj4UDPeP9CEaKITaLMYMH18Ec4Z49NGmYcgDoDdbkJpgQ1umxGKQlNz+xN1WIanSExCQ2sU9SkFwsOxzGATxwE+Z8rMJq8NhW4KNg0HHAcYDdoMJ1qpLvf9483DeHzLxwCAcaM8KPHZwAA0tESw67N67PqsHt/50hRcPnfM4J4oSdR1AuKSilBYhD8URzQmQxSpBH8uiMZl7D/ux56jLWj0x/TtdosBkyp9qKn0wuOk/m9XTEYBLrsRPrcWeGIqwCjwRBJ6HIBqbovitt++ifqWsN44PrnViF9850JMpA4KIX0mGpfx4cEmfFjbrBfxddmMmD6hGDWjvUO642cQeHjdFpT6bDAKHKVu9DPqsAwPkbiMhtYoGv0RvXZTKGVp6CQOgNdl1mY1JYqEF7qtMBqGbptD2tFKdflr79EWPLblY8yYWIIbrpyKwg6rbTX5o3jouQ/x+JaPMb7cgwkV3kE60+ErWddJUlSEIiIC4TjCEW0FO5WqiQ86VWU4ciqATw63oPZkQJ+lw3Mcxpa5UDPai4oSJ63O2g2zSYDTboLPZYbTaoKqqjRIQTL0OAD11It70dwWxVWfq0Z1pRcnm0J45tUDePjZj/DALRf14ykSMjyEohLeP9CIjw81Q0401l6nGTOqizGh3DPkC/faLAYU+2zwOs1gVGi831GHZWiKiVqwqT6lQHgwkhlsArT2pdhrRYlHS6Mr8lCwabjpbKU6o4FvX/CBVqrLeVv+XYvqCi9uv3ZW1hUlCz1W/OzaC3Drb9/AX/91ELdeM3MQznJ4EgQOigqtmHhEQigsIibK9G8qB0TjMhr9UdQ1hbH3WGvatbLQbcHk0T5MKPfAah6apS76ktkkwGXXajw5LEaoqkqlM0inevwv6oP9Dfja5yZg+SXViS0lGFFgxx1PvoPWYGzILflOyEBpC8Wxe38j9hxt1YMuRR4LZk4sQVWZa8jX4tELjRfYYDMLdFM2QKjDkv9ionbz3L4iXRSBiJh1X4/DhBKvDUUeK0oSwaahmsZLOtfTlepkmToO+WTP4Wb8xxfOydqWJ/E8h8/PGY0nt346gGc2PCWLiUfjMgJt2ip2cVGGRP+uBkVyQY1GfwyN/iga/FE0+jNnAltMAqrLPZg02ofiDoNyJDuLSYDTYUaBywybxaDNkKXAU15SoiE0/uMhOKctgn38jKz7hA/sQvDD11D0+Rsg2Jxn/Fo9DkC1BuOYPLYgbduUqkIwAP5gnAJQhPRScyCGXfsasP+4H8nZ12UFNsyYWILKEseQDzwB2ohJodeKIney0DgFnwYKdVjyS1xStBvn1ijqEzWb2sLZg01uuymtQHiRxwozBZuGpc5WqjMbhcQqdbRS3VAQjEgo6kGHuchr63RGJDk7PM8BHIeYKCMUktAWjCMaVyBKmauGkv7DGENbWGwPNLVG0dgWzbp6K6ANzhR7bZgyrhBlPis4DP17775gMRvgsptQ4LLAahG0zAW6juS14AevQmw4ClvVeZ3uY6s6Dy2v/h6B3S/CO/+qM36tHgegVMYybmCNiZ8VSpUhpMcaWiN4d28Dak8G9G0VJQ7MnFiCkYX2QTyzgcNxgMNuQqnPBhcVGh8U1GHJXWIi2FTfGk38NwJ/KHuwyWUzJYqDt89sGqorY5Lu8RwHo1Fbqc5uNcLeyUp1NEI9tLjsRjS2RgAUdLlfoz8Kl904MCc1jEiKikBYhD8oIhqXERdlUFmn/qeqDK3BuD6jqcEfRZM/CjHLTLPkghrFiUHPIq8VhW4LzEYBgsDB4bAgFIpRML4bFrMBbocJPpcFNrOgpWrTZzYkhPa8Cde5nwPHdz5gyfECnOd+DqE9bw1MAAoATjSE0kbLk1O1TzSEMvYdN8pzxieVdPjwYdxxxx3YvXs3rFYrLr/8cqxZswYWS/ezrTZv3oxHH30UdXV1qKysxPe//30sXbo0bR9JkrBhwwZs3rwZwWAQU6dOxe23346JEyem7dfY2Ig777wTO3bsAM/zWLRoEdauXQuP5+zfIxk+TjSG8M6eehyrb//3UlXmwsyJxSj22gbxzAaWwcDDlyg0buCp0PhgGYwOC7XpmSRZbZ/Z5NdmNrUG41n3ddqMieLgNj3YRLUphjdaqY4AwKQxBXjhrSNYcN6oTme1qirDP944hJoxXbf5PUXtuUZWVByvD8EfjFPtyn4kKyqaA1oKXWNrItjUFss6CULgORS6LSjyaNfJYo8VBbR661mxmg1wO83wucywmrRyGcP1/n2otn1Sy0mYR1R1u5+5dCxa33j2jF4jqVd3rg88/V7W7ev/Z7f+dwZtJZW/3fvFszkvBAIBXHPNNSgrK8OGDRvQ0tKCdevWwe/349577+3yuS+99BJuvfVWrFy5EnPnzsWrr76K1atXw+l0Yt68efp+69atw5YtW3Drrbdi5MiR2LhxI7797W9j69atKCoqAgDIsozrr78ekiTh7rvvhizLuOeee7Bq1Sr88Y9/HBZpUqTnFJUhEpMQirb/icRk1PujeqCW44Dqcg/Ory5GgWt4pa7arEYUe63wucxQFSo0PpgGusNCbbqmviWC9w4048P9DTjVEkFrIJ519p8j8W9FCzRpqXQ2CjYNe6kr1VksApy0Uh0B8KWFVfjpb97Af/5+J1Z9dRp8He4tmtuiePi5j3DguB/f+dKUs349as/TKbRwSp8SJQVNbTF9ZlOjP4qWQAzZPmKjgdeDTEUeLejkdVqG/MI9A4EDYLEY4HGa4XOaYTEZoCjqsA08AUO87VNVQOhBuQZBANSzSy3u8d3sD7/eeT5gf3j66acRCASwZcsW+Hw+AIAgCFizZg1uuOEGVFV1HqF74IEHsGTJEtxyyy0AgAsvvBCHDx/Ghg0b9C+4vr4eTz/9NG6//XZcdZU2hWzatGlYvHgxNm3ahDVr1gAAXn75ZezduxfPP/88xo8fDwAoLi7G1Vdfjddffx0LFizot8+A5BZJVtMCS6GohHDy77H2YFNnBJ5DTaUX0ycUwe0wD+CZDz6e5+BxmVHqs+kjJ2RwDXSHhdp0bQR37WNvQ5TS0wPsFkMijc6GEo+WTmezUJoM0RgMWsDJbBLgtBlhsRhgpZXqSIqJlT5c/4VzsPHvn+C6O17GuFEelPi0lP76ljAOnvBDZcB3vnhOn6xoSu056SvJlegaU9LoOks5t5iElGCT9l+3w0STAfoYx6XMeEoLPFHq9lBu+wSHB1LjCVgrJne5n9R4HILd0+vjp+pxAGrxzIqzeqHe2rFjB2bPnq1/uQBw2WWXYe3atdi+fXunX/Dx48dx6NAh3HzzzWnbly1bhttuuw0tLS3w+Xx44403oCgKLr/8cn0fh8OBRYsWYfv27foXvH37dlRXV+tfLgBMnz4dI0eOxPbt2+niNgQwxhATFYRjEkKR9mBSeqBJRryHhSR5joPdaoDDaoTDaoTTZkKh14bKYjusw7A2i8UkoNBrQ6HbQoXGc8hAd1ioTdeC0AvPHYn61ijsZgEFLi3Y5LBSsIm0MwicllZnopXqSM9dMX8sqka58cy2A/iktgn7jrUCAMxGAedVF+NriyZg0hhfN0fpGWrPSW8xxhCOyWmBpkZ/tNMakw6rUZ/RlAw2OaxGCjb1Iy3wZITHpQWezEaBAk8dDOW2z1IxGYH3XoLz3MXghOz9VabICLz3T1gqz+n18VPlbG+4trYWV155Zdo2k8mEiooK1NbWdvq8Q4cOAQDGjh2btr2qqgqMMRw6dAg+nw+1tbUoLCzMyJOsqqrC1q1boaoqeJ5HbW1t1l+mcePGdXkefUmWZf1PNgaDIW3frgy3fVXGEInJacGkaFRCRGL6z4FwtMtC+jzfflyBAxxWAQ6zUSvwmvjjSAScPE6tJgvHcVBVFaqqphU3TH0Pqeeb3Lcn7627fXmeB8/zg76vIPBw2k0o9lhgtwiQpew3Gblyvsl9gc5+14Ze7YCB7LBQmw5wHIdvLalGRFSwp7YRUmImVMfft1xtT4fivmfS9jLG6dfk1ID6mR6XA4MgcJ2uVMdx2rpMisJyoo3Mt32BbL8TQ689B4CaMQX4f9cXQFUZAolVMl12U5ernZ4Jas/b0T165r6Mab9/yaLgTf4YmkISovHEvbmafly33YQil1VfFXlEoRM2iyHjuIqSORDcF/fS2dr0oX6PnrovYyqsFiO8LjO8jmTgSUE8ruTc+QKDe48+lNs+96xlqHvyp6h/9m4Ufv57MDjT7//lYAsa//EwxOaTKP7ij87oNZLOOgAVjIh47rUDOHo6iAK3BVfMH4vKUtfZHhaBQAAuV+ZxXC4X2traOn1e8rGOz3W73WmPBwIBOJ3OjOe73W5IkoRIJAKHw9Hpfi6Xq8svePHixZ0+9s9//hNCT3IsE/789NM4crINkWhmB95XWIzpM+bqP7/+rxeyNtAA4PEWYMYF7RHRN7f/E5KUfZqrw+nGhXMX6T+//cYriMViWfe12eyYs+BS/eedb72GSCScdV+LxYJ5F7UXW9v1zg6Egtm/T6PRhIWL2yPAH+x+C/7WZv1nNTFzKSYqkGSGidMX60Gl/Z/uREtzozZrKUtsaVTNRfrfm47tQSzUDKOBh9kkwGISYDEatP+aBMy9+HJ4nNrIy75Pd6PhdB0gAhCBeBsQB9CSONaCi5aC47TZDHs//QAn646CFzhYzEbE4lJaIdg5Cy6BzeYAAOzf+zFOHDuU9XMAgFlzLobL5QEA1B7Yg6OHD3S67/mz5sPrKwQAHD28H7UHPut03/POn4OCohIAwIljh7B/78ed7jv1vFkoLhkJADhVdxSfffpBp/uee94sTK4ZjxKfDXXHj+DFt9/udN/p02egqmqcdtxTdXjrrTc73XfatPMwYUI1AKChoR6vv769030nT56KmpoaAEBzczP+/e9tne5bXT0RU6eeCwBobW3Bq6++nLGPIPD47nev6/QY+WqgOizUprfb/NdnUFcfzDqqOJzb9FSCIODiS76g//zRB++gpakh674A8LklX9b//ulHu9DYcKrTfS/63BV6h+HTj3ej/tSJTvddcNFSmBKFRfuqTec5DnMXLEZhYQHsViMOH/wURw8dgEHgwXFa5y11Ba2LLlqs133Yu3cvPv30o07Pd/78hSgtHQEAOHjwAD788P1O950zZy5GjiwHABw+fAjvvber031nzboQlZWjAQDHjx/Dzp353aYP1fY8iec5eJzZU/3bQvGzLgNA7Xm74X6PrjJtJbod21/DydOnEYhICEZEyHJ7I8bxPEZOXAAOgM9lQaT+E/BKCC6bCU6bCQaeA0JAKASEjgNVA9ieA8japg/le/TJU2ZgxMhycBwQ8J/GoX0fwW4xwCDwGYGgfGjPgd636SdPnsSKFSs6fXzbtuznk+9tX1fMJaNRuOR6NL30OI799gaYS6tg9BQDACR/A+KnawHGULhkJUzFlWf0Gkk9DkA98fdP8MaHJ/G7/9veiMXiMm6+fzsaWiJ6H//1D+rwXz9cgFHFmR9KX0iOBnan4z4scTeXuj3bcViWdVM724+mgfYTxiArQEwWcfR0UE+J+/hgE1pamhATFcRFBVJK+gHH82g2ndZ/bgnEERcTF3kOsBi1YJLJKMBqFnDhOaVw2IxwWIw4ur8NoYAVfCffZ2WJU7+40XfePbNJQGmRDaOKHFAUFV0MapAc0lWHpT9Rm06GOo4DBF6AwQCYjAZYTDxGl7lQWuwGz3FoPGHUC4jT0u2kPzDGsHtvA15+5yje3VOPzXdf0W+vQ+350KUylsgcEBGOA/X/OoimtihkhaHhSAPESPsqzxwHOG0muKwmuJ0WXHbxOBS4LDAaeLy3qxEtTfT9DBatVIgRPpcFToMLzSdM3c5CIl0bKm2f67xLYCqqgP/N5xA9+inidfu11zKaYRt7HjxzvwLLyAlnfPykHgeg9h5pwYJzR6Zte/7Nw6hvieCLC6pw9aXVOFYfxLrfv4tnXzuAHy2fflYn5nK5EAgEMrYHg8EuC3ylRhILCwv17cljJSOPnR0/EAjAaDTCZrN1ex7ZIqBJnUVOk7L9InXm68uX4709p9HWydLcqeZf/PkeH3fuwst6vO+F8y7p8b6z5izq9DEtB1wr3h2MSjAV1sBsTxbzlhGKiwhHZUiJmQGH3jysP1c1jYapdDRMKcczCBzsFi2Q5HJa4bBodZcsM0bCkUiPs1kMGcGl1OmyJd7ZXb6f1H0nTzkfkyZ3XpA/dd+Jk8/FhElT01LwOkvXmDBxCsZN6LzoW+q+VeNrMKZqYqf7pk5TrRwzAeWV43q076iKsSgbNbpH+44YWYmSEeVpjwuphcbNRn12R3l5BUaOHNWz444YiS9/+as92re4uKTH+xYUFPR4X6/Xl3Vfg2FopWx8UtuEqlEeWLtZWa0tFMfOT0/jkgvObrSD2vR2X/7K19JS8LqS6216R6kj+N059/w5Pd536rkX9HjfyVNndPn4QLTpk6dMw7Rp53a6Uh3PC/pKdZMnT8GkSZ23/6nt08SJEzFhQuc3f6n7jhs3HmPHdv5vK3XfMWPG6jOcutt3KLTpQ60978yppjBe2XkUr+06jtZADAaBx5ypI876uNSetxtK9+ipJFnFyHHno6E1imZ/FA1tUbSEEivRWbQ/p1siAACjwGPqtAtR5LGiILGQRseV6FLbx1xqzwFkbdOH2j26tg8Hm8WAQo8NPrcVRoGD11GBilH53Z4DvW/Ty8rKum0Hssn3tq8nLKOqUfr1tWBMhRoJAgB4mxMc13fXzR4HoE63RPCFBekf7M5PT8NtN+PbyyZD4DlMrPThSwur8HxK0OBMVVVVZUwhE0URx44dy8i9TJXMrTx06FDaL0JtbS04jtMfr6qqQnNzM/x+f1qeZW1tLcaMGaP/sldVVeGzzzKnRx48eBAXX3zxGb+/3jAYDIk/3RfBTm0EB3pfRVURjsoZBbxDUUkr8J1YNa77lWq1XF+zUdALeWvBJEPazw6rEWajcNajXL35HDrmIfdkX0Hg9O+Q47K/+TM5bi7tazEbUOSxotBjATqM4ufi+XYn2+/EUOuw3P7wm7jnpgV6gXFVZbjy1q2496YFqBrl0fc73RzGb5754KwDUNSmt0u2B4x1H4AazDZ9OOzbV226tlIdD7PJ0PlKdQkdL1m50O4N5X2BzN+JodaepxIlBW98eBKv7DyKPYeawaAtp/7FhePw1UXj4bKbujtEt6g9b5cv9+hd7RsTk8XBY3px8NZsATXOAJtZSCsMXuSxwtPLlehyqT0H0O19ei60Y2ezrxZ4MsLnNsPjMMMocFAUbVGgXDzf7gzmPfrwavu4xA1L8k/f6fG/6nBUSlumW1FUHDjux4XnlKZFuMeOdKM1kD0PuTcWLFiAhx9+GK2trfB6tQ7SK6+8AlEUsXDhwk6fV15ejrFjx+KFF17AJZe0jwg8//zzmDp1ql61ft68eeB5Hi+++CKuvvpq7T2Gw3jttdfwta99TX/ewoUL8be//S2t2NcHH3yAurq6Ls9jqBElJSOYFIrKCEXFxH/biwv2hN1i0GcodQwqOSzaduMQvkEcKjgOcDlMKPHZ4LSaaKWMPNLxFosBUFSWrWRan6A2nQwVWkodB6vZoC22QCvVkRyw/1grXtl5DK+/fwLRuAyzyYDFMyswZ2oZfvXE25hVU9InwSeA2vN8Fo5KepAp+SfQyUp0doshLdCUXLWV0hvzA89zsFmNKHBb4LGbIPAcVJVWoz4bw6Hti53YB/9bmxE9+jFYog4dZzTBOnoKPHMGOAXP4zSjJSWwVFvXBkVVMb7ck7Yfz3F9EjhYvnw5nnrqKaxatQqrVq1Cc3Mz7rrrLlxxxRVpkcO1a9diy5Yt2LNnj77tpptuwurVq1FRUYE5c+Zg27ZtePPNN7Fx40Z9n5KSEixfvhz33nsvDAYDysrK8OSTTwIArrnmGn2/Sy+9FNXV1bjppptw8803Q1EU3H333Tj//PMxf/78s36fg40xhqioJFLgUmYsJVLkktvFHt5E8zzXIZhkgMNqSpu9ZLMY04KWJD8ZDTwKPFaUeLX6WRR8Il2hNp3kA57nwPMcBI7T/87zHAwCD5ORh9EgwGTi4XZaoMoKDDyfqN2kzfykG3syGG689184dlpLx6iu9OGSWRWYf+5IWMwGhLMUxz5b1J7nPsYYAhFJDzI1tEbR2BZFJJZ9sNhlN+mBJi3oZIHNYhzgsyZ9QeA52GxGFLgscDtMEDguYyYuOTNDve1r2/USml/RXs9cOhaGRBFy2d+AyMH3EDn4Hgou+Q+4Zyw549cAehGAGjfKg5ffPop508rAcRz+/d4JcACmji9K2+9EQxBepyX7QXrB5XJh06ZNuOOOO3DjjTfCYrFg2bJlWLNmTdp+qqpmrCixdOlSxGIxPPLII3jiiSdQWVmJ9evXY968eWn73XrrrbDZbLj//vsRDAYxbdo0bNq0SV9tBtCm+T3++OO488478eMf/xgcx2HRokVYu3Ztzo8AqCpLma0kJdLjRO3nmIxQRJvNpPSwQTIZeH3WkrOT2UsW09mnxJHcZ7caUeKzwes0Q1HUXtVLIMMTtelkMHFcIrjEcRBSAku8wMFkEGAyaMElQeBgEDgIiVQ7geMgCNrzGNM6dYLAw+OxobU1TDOcSE44ejoADsCMSaW45vJJqOiD1ai7Qu15blEZgz8Y7zCzKaatBN0BB8DrNKPI2z6zqchthdnU85X/SG4SBG3GU6HbArfdDJ7T+oIq3aP3maHc9sXq9qP55SdgGzcdhUtWwuAqSHtcDjSj6cVH0fzKkzCPqIJl5Pgzeh0A4FgPe477jrbgJ795A6U+G1x2E/Yda0XNmALc9f30D+2XG9+Gw2bELf/n/DM+qeGAMYamplC3+xkMPJwua0aBQ0lW22cpxTJnL4WiEiIxucfpNFZzZn0lR2LWkj1R2NtkpIvTmeisYG0+EngOXpcZJQV2mBO1TYYLg4GH12vvUaezsNCR8ze/X1jzN9ybUgNKURm+/JO/474fLcS4lBpQ+4624CcPvo6/3fvFQTrT/NDTNt1o5CGqXI+LkJPu9WTWkkHgYDDwMPCJ4BIPPbCkdclYIsAE/e+d6U1bQHLTUGvP//56LbbtPI7Dp9rAARhf4cUlsyox/9wyMAZc/X9fwH/eMBfnVBV2eyxy9vfo/UlRVTQH4mhsTcxs8kf1leg64nkOBS5LyswmCwrdVipx0UG+36cbhMSqdh0CT8PJUGvTB0P9c/dCDrWg7Ft3dFpwnDEVJ//7ZzA4fCi5ck3WfXqixzOgqit9+Nm1s/DXfx9EMCzi0gsqcc3lNWn7tAZiaPJH8bmZFWd8QiRdMCLin7tOYE9tE1oCcT3IlG1UIxueQ9pMpWQwqWNxb6EXxd/I8GQxG1DktaLQrRUaH24Xt6HoREMIfCIdNvl9nmgIZexDyGDQZy11DC51NWuJ12Y4dZy1BEBPk0tiKqCAIbMiGiH55Qvzq/CF+VU4cLwVr7xzDDs+qMNvn/0AG//2MWZMKtFKyFKHK+9IsoqmtmjazKbmtnjWGS1GgUehx5JWs8nnMtP9/RBmEHjYbQYUuKxw2U0pM54G+8xIPood/wwFn/t2l6vdcRwP1/lL0PLqprN6rZ4vLQBgZk0pZtaUdvq412XBg2sGZtWJ4eKfO4/j729kX1XQKPAdCnlnzmKymg1000HOilZo3IzSAhscFiPVehpCHnj6vYxt6/9nd9rPyRWUCOlL/T1rSVUYVAoskWFmfLkX48u9uP6L5+gr4b310UkwABv+/D6WzB6NxTMr+qwYOek7cVFJCzQ1+KPwB+NZWzGzUdDrNBV5tRQ6j9OcaBvJUGcw8HAkajy57CZwoMATOXtKLASDu/tZskZ3EZTY2Q1O9yoARQbewmll4AUerYEYDB0KfJsMPAWXSL8yGbVC48UeKjQ+1Pzw6+cN9imQIYhmLREy+ExGAYtmlGPRjHKcagrjlZ1H8dqu4/jd85/iqZf24rm7lg32KQ5r4VhKcXB/DI2tUQQiYtZ9kyvRpc5sctpoJbrhyGjgYbcZUeC2wmUz6oEnuhqSviBYnZDaGmEpn9TlfnJbEwSr86xeiwJQOa7Ia8U1l9cMaH45IQDgsGmFxt0OE1SFUaHxIWYxpUqTXupu1pIpGViiWUuE5IwRhXZ86/M1+OaSSdi1tx6v7jw22Kc0bDDGEEysRJc6uync2Up0NlOiOLhFDzrZaSW6Yc9o4OGwmVDgscBl1X4fKPBE+pqlfCICu1+CY/K8LmtAte16sdsgVXcoAEUISSMIHLwuC0oLbDAJPNQ8LMhICOk5mrVEyNDH8xxm1ZRiVhelNMiZS65E19gWTRQIj6HBH+10JTqP05xSHFwrEG4xUbeMtDMaeThtJvjcFjitRoANv+LiZOC4L/gCTm66HfXP3o3CJd+FwelNe1wOtqDppccQP3UQBZdce1avRS0dIURnNRtQ5LOi0GUBo0LjhOS9nsxaMhg4CALNWiKEkN7wB+N45t+1+GB/I043RyBlKVPAcxwK3Oa0NDpaiY50xWQU4LRrNZ4cNiOYCjC6Hyf9zDJyAgouuRbNr/wOxw5+D+YRVTB6igEAkr8B8VO1AFNRcMm1sIwcf1av1S8BqLZQHG6HuT8OTQjpBzzHweU0odRng50KjROS87qftSTAaOBp1hIhhPSTV3efwNaUhYIMAodCd3utpiKvFQW0Eh3pIZNRgMthhM9lgcOqBZ4oC4EMJPfMz8NcOhb+t/6K6NFPEa/bDwDgjGbYxk6DZ+5XYBk18axfp88CUIwx7N7bgJffOYpdn9Xjr7++oq8OTQjpRyajgAKPBcVeK3hQoXFCBlu3s5aM2gpxNGuJEEIGz6LpI+FymBEKi3BYDLQSHTkjZpMAl90Er9sCp8UIVVUp8EQGjaV8Ikq/vhaMqVAjQQAAb3Om1YVijJ3VQghnHYBKXV2jNRCjJbsJyRMcALvdpBUatxu1QuPUKSVZ0KzWvmc2CjAKPM1aIoQMKGrP+47PZcGVi8bTQkHkjGiBJzN8bjPsFiOYqtIgMMkZHMdDsLsztgc/2QH/G8+g/HsPnvGxzygAJUoK3vjwJF7ZeRR7DjWDAZhQ4cXyS6phNPDY8Of3z/iECCH9zyDw8LosKPFZYTJQoXGSiWa19g/GAKfdiDEj3eAYo1lLhJB+R+05IbnDYhLgcpjhc5lhsxjAVAaVAk8kB6ixMML7d0IJt8HoGwHbhJn6zKfw3rfRsuNpSI0nYHAXndXr9CoAtf9YK17ZeQyvv38CkbgMr9OML180DotnVqC8xAkAePuTU2d1QoSQ/mWzGFDktaHAZYaqUqFxko5mtfY/q9mImEGELKs0a4kQ0m+oPSckd1jMBrgdJvicFtgsgnYPTgPAJEdILadw8r9/BiUS0EZCOQ6WihqUfu2nqN+8HtFDH4C32OBbvALuGZ8/q9fqcQDqxnv/hWOnAxAEHjNrSvC5mRU4f2IJeJ4uZYTkA57n4HaYUeqzwWYx0DRfoqNZrYQQMjRQe05IbrGYDXA7zfA5zbCZtcCTQoEnkmNatv8JqhiFd/5VMI+oguSvh//N51C3aS2kxhNwnrsYvsXfgmCxn/Vr9TgAdfR0ABzH4YsLqvDFBVXwOCl/nJB8YTYKKPBqK7NwYBR8IgBoVishhAwV1J4TklusycCTywyrSYCiUOCJ5K7YsT3wzP0qvHO/om8zektx+uk74Zp+KQqXruyz1+pxAOr6L56DbTuP47l/HcCW7Qdx/sQSfG5WBWZOKoEg0PKihOQiDoDDbkJJgQ1umxGKQmXGiYZmtRJCyNBA7TkhuYEDYEmsiOhzmmExaRkHFHgiuU6JBGApr07bZimfBACw18zt09fqcQDqC/Or8IX5VThwvBWvvHMMOz6ow7t7TsNlN+Oi80dh8cwKjB7h6tOTI4ScOYPAw+u2oNRng1Hg6OJH0tCsVkIIGRqoPSdkcHGcNuPJ47LA6zTDYhQSgSfKOCB5QlXBCaa0TZzBCADgTdY+faler4I3vtyL8eVeXP/Fc/Qc87/vqMXfd9Ri7Eg3RiWm+RJCBo/NYkCxzwav06ytrkGFxkkHNKuVEEKGBmrPCRkcWuDJCI9Lm/FkpsATyWNSSx04XtB/Zkz7PZaa6zL2NY8Ye8av0+sAVJLJKGDRjHIsmlGetspGbV0brbBByCDRC40X2GAzCzTriXSKZrUSQsjQQO05IQOL4wCbxQivywKPw0SBJzIkNG79bdbtDX/f0P5DYoW8sWufOePXOeMAVKoRhXZ86/M1+OaSSdi1tx6v7jzWF4clhPSC2SSg0GtFkTtZaJyCT6R7NKuVEEKGBmrPCelfqYEnr9MMk4GnwBMZEoqu+P6AvVafBKCSeJ7DrJpSzKop7cvDEkK6wHFaofFSnw0uKjROzhDNaiWEkKGB2nNC+hbPcbBaDfAlAk9GgQJPZGhxTr14wF6rTwNQhJCBZTDw8CUKjRt4KjRO+gbNaiWEkKGB2nNCzhzPc7BZtMCTx2nWF/WhwBMhZ44CUITkKZvViBKfFV6nGapChcZJ36NZrYQQMjRQe05Iz2mBJyMK3FqNJ4MeeKJ7bTI0nXzq/3X6GCcIEOweWMdMhWPy/LRC5WeCAlCE5Bme5+BxmVHqs8FqokLjhBBCCCGEnC2e52CzGlHotsBtN0HgOagqBZ7I0KdE2oDOkrRVBfG6Awh9vAOBXS9hxDd/Cd5oPuPXogAUIXnEYhJQ6LWh0G2hQuOEEEIIIYScJZ7n4LCb4HWY4XaYIHBa4ImyC8hwUb7y/m73iRx8D/Wb74P/jWfhu/gbZ/xaFIAiJA9wHOC0m1BaYIPTSoXGCSGEEELI0MRxyf9qf+GS2zhOm6PBARxS/97+GJfYqO2fnNOh/cwBAM+B57TC4hwHGAQexYUOmHiAJYJOKqO7bEI6so2bDs/sLyH0yXYKQBEylBkThcZLqNA4IYQQQgjpB1wiqNMe0En/OS2wAy041G0AKHlcjgPPaYEfjtce4xPbOI4Dn7It9fW4ZOCITzk2x4FH4jE+5Rz0oBRLORcOHMcAaK8F/fw0jAGCwMHttqG1NQyFZjwR0iVz2Xj433zurI5BAShCcpjdakSxzwqf0wJFUWkqMCGEEELIENBtkKens3w6/KzN8kkN8GgBHB5aqlky6MNx7UEfLiWAAw7tjyVfOy2gk3oO6YEoHhzAMf04yWMnZU4sYp1sT93GOtne5Ser76ztz6B0kjvAcXx3BySEJDBZBPiz+zdDAShCcpCQUmjcbBRouVdCCCGEkBxkNPBwOUwAx0HowSyf1ABO2iwfLhm0Qdosn2QgBx2CRMkuYOosn9TjJWUL+nQWxMkW9OldNhpL/E/7b2dBH0JIfoocfA+mwvKzOgYFoAjJMRazAUUeKwo9FoBRAURCCCGEkFxkEHiMLXNBUZge9DmzWT7t+3W2b6dSZvmwDschhJCeUKLBzh9UVcjBFoQ/exPBD15F4ZLvnNVrUQCKkBzBcYDLYUKJzwan1USzngghhBBCcpyqMrpnI4TktaP3XZteIK0TrhlL4Jp+6Vm9FgWgCMkBRiOPArcVJV4reI6jGxlCCCGEEEIIIf3OM/9ryYpzmXgegt0D6+hzYPSWnvVrUQCKkEFmtxpR4rPB6zRDUVQwWvqVEEIIITnsiSeewB//+Ec0NjZiwoQJ+MlPfoILLrig2+c1NjbizjvvxI4dO8DzPBYtWoS1a9fC4/Gk7ffRRx/hP//zP7Fnzx54PB5cddVVWLVqFfhE8dtQKITf/e532LFjBw4fPgyDwYDJkyfj5ptvxuTJk/vjLRNCSKfyvU30Lfh6j9+rEm6DYHf3eP+Ocrrs/xNPPIFFixZhypQpuPLKK/HOO+/06HmNjY340Y9+hOnTp2PGjBn4yU9+Ar/fn7HfRx99hOXLl2Pq1KlYsGABfvOb30BV02eevPDCC7jxxhsxf/58VFdX44knnuiLt0YIBIFDodeK0WUueByUckcIIYSQ3PfEE09g/fr1+MY3voHHHnsMlZWV+M53voN9+/Z1+TxZlnH99ddj//79uPvuu3HHHXdg9+7dWLVqVdrg2/Hjx/Htb38bHo8Hjz76KFauXInHH38cDzzwgL7PyZMn8ec//xlz5szB+vXrsW7dOqiqiuXLl+PTTz/tt/dOCCEdDYc2kTGGyMHdOP3s3Tj64MqzOlbOzoBKfpGrV69GTU0NnnnmGXznO9/BM888g+rq6k6fl/wiJUnC3XffDVmWcc8992DVqlX44x//qK0wgfYvctasWXj00UdRW1uLe+65B5IkYfXq1frxXnrpJRw/fhwXX3wx/vznP/f7+ybDg8VsQJHXikI3FRonhBBCSH4QRREPP/wwvvWtb+G6664DAMyaNQtXXHEFHnnkEaxfv77T57788svYu3cvnn/+eYwfPx4AUFxcjKuvvhqvv/46FixYAADYuHEjXC4XNmzYAJPJhNmzZyMUCuGhhx7CddddB5fLhVGjRuGVV16B1WrVjz9nzhwsXrwYTz31FNatW9ePnwIZDKqqQlHkfjguh1hMgCjGoSh0P56Psn2HBoNR7/f3p6HeJkqtpxH8YBuCH/8bSsgPTjDAPvHCMzpWUk4GoHLliwSA+++/X5/aNpgBKIPAwWo2pK9rwRhSV0tNWTsjbfUMpv9f+/oY6fujfcnUbI+RPqMVGjejtMAGh8VIs54IIYQQkjfee+89BINBLFu2TN8mCAI+//nP48knnwRjrNNO3/bt21FdXa3fnwPA9OnTMXLkSGzfvl2/R9+xYwc+97nPwWQy6ftdccUVWL9+Pf73f/8Xl112GWw2W8bxzWYzqqqq0NDQ0Fdvl+QAxhgCgRZEo6F+e42mJj4jC4bkl47fIcfxKCgohcFg7NfXHYptoiqLCH/2FoIfvIbY8c+0ZTk5Du4LlsEz+ysQbM5eHa+jnAxA5coXCUAPPg0mgedQXuKEojB9Ol56UCnxX8bSAklM34/pQaW0gFUygNUhOMVY5vH1100+L7nca+L1WOLgKtqPyVJeV2Us5biZgS6WemJpP6eeS/pjPQ7GdfysWOZjAxGMMxp4eF0WFHuo0DghhBBC8k9tbS0AYOzYsWnbq6qqEA6HUV9fj9LS7EVqa2trUVVVlbF93Lhx+nEjkQhOnjyZsd/IkSNhtVr1/bKJRCL47LPP8MUvfrFX74nktmTwyeHwwmQy98usFkHgaPZTnkv9DhlT4fc3o62tBT5fcb/OhBpKbWLs5EEEP9iG8J43oIoxcEYznFMvgn3ihTj953WwjZ9x1sEnIEcDULn8RQ4GjuNg4DlAZd0sj9j5Y50/Lf2B3vz7bN+36ydlO2ZqgElNjShxyeAWpweCUgNQjOPag0k5GozTjtcejOM5DlarCSaPGU6rEWpKIJEQQgghJF8EAgGYTCZYLJa07W63VpDW7/d3eo8eCATgdGZ2Xlwul37vHQwG9W3Z9mtra+v03O6//35Eo1F885vf7PI9LF68uNPH/vnPf0IQhC6fTwaOqip68MnhyPyd6CsGAw9ZpoHhfNbxO3Q6PWhra4KqKhCE9JDHyZMnsWLFik6PtW3bth6/7lBoEwHgxOOrITaeAACYR06Ac9oiOGrmgjdZoMbC3T6/N3IyAJXLX2RP5drFrfN4R/oDZxYX6cNgSoeZUFziT8r/tce78iQYZzBwcLls8PsjkCSl5wclhBBCCBkkjDEoSvt9S3IWQbbZBMmBte5mGnT23I7be7pf0tatW7Fp0yb8/Oc/R2VlZZfnQPJH8vfPZDIP8pmQfJMMOqmqir7qdg/lNlFsOA5wHGzjpsN38TdhKirv9jlnatADUPn0RZKhYaCDcRzHJ45Hs54IIYQQkh927tyJb33rW/rPs2bNwpIlSxCPxxGPx2E2twcFAoEAgPbB4mxcLpe+X6pgMKgPCif/m20wOHW/VG+++SZuu+02XHfddfjGN77R7fvqbnYD3a/lHuqbkd7q6nemrKysV7OckoZqmwgABZdei+CH/0LkwG5EDr4Hc9k4OKcthqNmbo+e3xuDHoDKly+yt+jiRgghhBBC8tXkyZPx7LPP6j/b7Xa9mG1tbS1qamr0x2pra2G321FSUtLp8aqqqvDZZ59lbD948CAuvvhiAIDVakVZWVlGOYy6ujpEo9GM8hkfffQRfvCDH2DJkiX48Y9/3Ps3ScgAOX36NK677hv4xz96H/gYTPfc858oL6/A8uVdp3G98MJWvPrqy7jvvgd7/Rovv/wi/vWvbVi37t4zPc0BMZTbRPfMy+GeeTniJw8i8OE2hPe8iaYXHkHzK7+Dbdz0RLpP3wSCBz0AlQ9fJCGEEEIIIcOJw+HAlClT0raNGjUKTqcTL7zwgn6PrigKXnzxRSxcuLDLWQcLFy7E3/72t7R6rR988AHq6uqwcOFCfb8FCxZg27Zt+MlPfqIvFvSPf/wDZrMZs2fP1verra3Fd77zHUyfPh3r1q2jWTJkQH31q1egtbVFX7DK7fbg2We3drp/aWlpzgWfGhrqcdVVX8Rzzz2PgoJCfbuiKPjSl5bijjt+jR//eG2fv+68eTPwt7+9pL/mpZcuxaWXLu3z1+lrw6FNNJeNQ1HZOBRccq2+El5479sAY2j6x0NwnncpnFMvPqti5IMegMr1L5IQQgghhBACmEwm3HDDDVi/fj18Ph9qamrwzDPP4Pjx47jvvvv0/erq6nDJJZdg1apV+MEPfgAAuPTSS1FdXY2bbroJN998MxRFwd13343zzz8f8+fP1597/fXXY+vWrfjRj36EFStW4NChQ3jooYdw7bXX6lkKzc3NuO6662A0GnH99dfj008/TTvH1AFsQvrLAw88gnPOmdL9jt2QZRkGw8B3y4uLSzBlyjRs2/YKrrrqan37u+++A5PJhKlTzx3wc8o3Q7VN5A0mOKdcBOeUiyC1nkbwg20IfvxvtGz7b7Ru/xPG/PRPZ/yZDXoAKptc+SIBbebUwYMH9Z/379+Pl156CVarNS2gRQghhBBCyFD3H//xH2CM4Q9/+AOampowYcIEPPbYY6iurtb3SdZ4TS05YTAY8Pjjj+POO+/Ej3/8Y3Ach0WLFmHt2rVpg8vl5eX43e9+h3Xr1mHlypXweDy47rrrsGrVKn2fgwcP4tSpUwCAb3/722nnN3LkSLz22mv99O4J6Vxbmx+//OX/xb59e8BxPBYuvBg//OEamEwmnDp1Et/4xlfx2mtvAdBmAa1e/RP86U9/QFnZSEybdh5OnqxDPB7HO+/8L8aMGYtf/WodSktHAABqaw/ivvt+jdragygrG4mf/GQtJk6sgaqqWL/+Hrz22suQZRmVlWPw0EMbwfN81u0dA12XXroUf//75rQA1CuvvIRLLlkCjuNw552/QEXFaKxY8W0oioKNGx/BSy/9A4wxLF26DNdf/72MxbVUVcXPfvZTfPTRB1AUBTNnXoAf/3gtnE4nVq/+PgDg61//EjiOw/r1v8WxY0fT0ve2bXsFjz/+MAKBNpx//kz8+Me3weVy4733duHee9fhc5+7DM888zQcDgd+8pO1mDnzwn77TntiqLeJRm8pfBd/A96Lrkbk4HsIfnh27WtOBqCA3PgiAeDFF1/Eb37zG/3nLVu2YMuWLXRxI4QQQgghww7Hcbj++utx/fXXd7rPqFGjsG/fvoztxcXFeOCBB7p9jWnTpuHpp5/u9PELLrgg6/HJ0McYgyipfXpMRWWQZe2YJiN/xumcqspw5ZVXYebMCxAIBPCTn/wQW7Y8lxbcSbVr1078938/DUEQ8NRTm7Bjx79w770b8Itf3Il1636F3/3ucdx2288RiUSwZs1N+NGPfox58xbgrbdex9q1P8af/vRXvP/+bnz22ad45pm/w2y24LPP9oDjOOzc+XbW7R1ddNFirF9/N06cOI5Ro8oRj8fw+uvb8cgjT2Tsu3XrFrz11ut4/PH/BgDccssPUFo6Al/84lcy9l248GL83//7KyiKgp///Db87neP4aabbsH69b/FvHkz8Oc/b9FT8I4dO6o/78iRw7j77jvwX//1G4wfPx53330n7rvvbvziF3cCAOrqTsBms2Hr1pfxwgtbcc896/CXv/yt919WHxoubSLH8bCPnwH7+BlndZycDUDlwhcJADfeeCNuvPHG7k+YEEIIIYQQQki/YIxh3VPv4WBd5kJSfWXcKDdu+8b0HgWhVq/+PgRBqwH1pS99Fd/73g8wd66WcVNYWIgvfOEr2LXrnU4DUCtWfBs2m13/eebMCzFt2nkAgM997lJs3PgoAOCtt15HVdU4LFyo1TOeP/8i/P73T+DTTz+GwWBAJBLGsWPHUF09UU8J7Gx7R06nExdeOBevvPISrr32O3jjjR0YMaIMY8eOy9j3tddewdVXr0BhoRY4Wr78m3jxxeczAlA8z+Oyyz6v//z1r/8fPPbYQ918mpp//etVXHTRYv18v/Od72P58i9BUX4FALDbHfj6178BjuNw6aVLcffddyISicDlcvTo+GTw5WwAihBCCCGEEEII0eVQrfn163+bFtiJRML4r//6Nd57bxfC4TBUVcGkSZM7fX5xcWnaz16vV/+72WxBNBoBANTXn8bu3e9iyZKL9MdlWUZTUxMuvXQJrrjiy7jzzv+HQCCAL3zhy7juuu9ixoxZWbdnc+mlS/D44w/j2mu/g1deeQmXXrok635NTY0oKWk/59LSEWhubsrYT5Zl/Pa3D2DHjn8hGAyCMQaPx9Pp59DVa5SUlEBVVbS1+QEAHo9HDw5aLBYAQDRKAah8QgEoQgghhBBCCCE5jeM43PaN6X2egmcw8H2Sgvf0039EMBjA7373P/B4PNiy5Tm8+uo/O92/py9TVFSMCy+ci3Xr7s36+NVXfxNXX/1NHD9+DD/84Q2YOnUaZs68sNPtHc2ZMx933fX/Ydeundi58x2sXv2TrK9TWFiEhoZ6/ef6+tNpq+clvfLKS/jww/fx6KO/Q2FhEf7/9u48roqy/R/458ARBA5HUBADlwTlFIoCLoiiJIqCYrmlqIELko9o7uLWzydT43nUxKWHDMUlMlPU3LeiwjSVlDTL1EBL1GRTdgUOzu8Pv4wcD0dBOcDg5/168Yq5556Ze+aaruNczMw5c+YUli//qEL7amVljdTUO+J0WloqDAwM0KCBRYWWp9rPoKYHQERERERERPQsMpkMxkaGevt53uITABQUFMDIyBgKhQJ37vyDr7/eWSX73LVrd1y58geOH/8BarUahYUPcPr0T8jLy8Ply5dw+fIfKCkpgUKhgKGhIQwMDHW2l8fIyAheXt4ID/8QTk5tNO5AKqtnz9746qsvcPduJjIzM7Bt2xfw9u5dznHIh5GRERQKc2RlZWHbthiN+ZaWDXH79q1yt+Hl5Y0ffvgOly9fQmFhITZsWAcvr55aLzon6eIdUEREREREREQv4O23A/Dvf8+Hn19PNG/+Knr0eAO//HLuhderUCiwbNkqrF27EuHhH0Iul8PZuT3atm2HvLw8rF69Anfu/AMTE1P07/8mOnTohLNnE8pt16VPHz8cPLgPo0cH6+zz5puDkJp6B2PHjgIA+Pn5Y8CAQVr9fH3746efTmLAAB80bmwDf/+BuHlzuzg/KGgc5s2bBbW6GCtWrNVY1t7eATNnzsEHHyxAdnY2OnToiFmz5lf2kFEtJhPKfoUcVRtBEJCRkffMfnK5ASwtzXDvXr54ayhJC2NYN1QmjlZWihf6CxpJD3P6y4MxlD7mc3oa5vPao7i4CJmZ/6BRo1dQr56R3rZT9hE8kqYnY6jr3GFOr3l8BI+IiIiIiIiIiPSKBSgiIiIiIiIiItIrFqCIiIiIiIiIiEivWIAiIiIiIiIiIiK9YgGKiIiqRXR0NLy9veHs7IwhQ4bgzJkzFVouPT0d06ZNg5ubGzp27IiwsDBkZWVp9Ll48SLmzZsHPz8/vPbaa5gwYYLO9X399dfw9fWFs7Mz/P39cfjw4RfZLSIiIiIiqgAWoIiISO+io6MRERGBUaNGISoqCi1atEBISAiuXLny1OXUajXGjx+Pq1evYtmyZViyZAnOnTuH0NBQlP0S18TERJw9exZOTk6wtbXVub4jR45g7ty58PHxwfr169GlSxdMnz4dJ06cqLJ9JSIiIiIibfKaHgAREdVtRUVF+PTTTxEUFITg4GAAQOfOnTFgwACsW7cOEREROpc9duwYLl++jAMHDqB169YAgMaNG2PEiBH48ccf0aNHDwBAYGAgRo8eLf6uy+rVq+Hr64uZM2cCALp06YLr169jzZo18PT0rJL9JSIiIiIibbwDioiI9CoxMRG5ubnw9/cX2wwNDdGvXz/Ex8dr3Mn0pPj4eKhUKrH4BABubm6ws7NDfHy82GZg8OyPs5SUFFy7dk1jHADg7++PX3/9FXfv3q3MbhERERERUSWwAEVERHqVnJwMALC3t9dod3BwQH5+PlJTU5+6rIODg1Z7q1atxPVW1LVr13SOQxAEcT4RERFRdYiMXAM/P2+EhATV9FCIqgUfwSMiIr3KycmBkZER6tevr9HeoEEDAEBWVhaaNGmic1lzc3OtdqVSWekCVHZ2trhseeMonV+eXr166Zx39OhRGBoaVmosREREJF1Dhw7AvXt3YWBgAFNTM/Tq5YNJk6ZV6t8Dd+78g717d2HnzgPl/luHqC5iAYqIiKqMIAgoKSkRp2UymcZ/n+yra15ZupZ91nIVXV9Fx0FERERUavXqdWjb1hk3bvyFyZMnoHnzFhg4cGiFllWr1UhNvYNGjayeq/ikVqshl/NSnqSHZy0REVWZhIQEBAU9vo28c+fO8PX1RWFhIQoLC2FsbCzOy8nJAfD4DqTyKJVKsV9Zubm5WncyPUvZO52srKy0xvG09cXFxT113U97jxURERHVXc2bv4p27Vxw7Voyvv/+W0RHRyEzMwPt2rXH3Ln/D5aWDZGYeBYrVoTDy8sbe/fuxmuvvY7z539BcXERfHy6Y+jQAEyYMAk7dmxDbOw23L9/Hz16vIGpU2fC2Lg+Dh3aj2PHDqNJk1fw3XffYtq0Wdi4MQpDhgzHvn27cfduJkJCJsLJqS0++mgRMjMzMWZMMIYPHwUAOHEiHlFRkfjnn3/QqJEV/vWvSXjjjUd3dy9d+gGUSiWSkv7EpUu/w9m5HT744CPx30Xnzv2MyMg1SEm5gYYNG2LevIVo394VOTnZWLlyGc6eTYCJiSnGjQuBn5+/zuNEBLAARUREVahNmzbYuXOnOG1mZoa0tDQAj97n5OTkJM5LTk6GmZkZbGxsdK7PwcEBf/zxh1Z7UlISevbsWamxlb776dq1axrvlUpOToZMJtN6NxQRERHVPkJx4aNf5Ebi3ctCiRp4WAIYGEBmWK+cvvUgkz16/bHwUA2UlAAyGWRyI42+snqP/1BWUX/9dR2//noeAQGjsHZtBFasWI3mzV9FVNT/sGJFOJYuXQ4AuHXrJkxMTLBv31GUlKjx+++/YcWKcHz55S4AwJkzp/Dll59jzZpP0bChFRYsCMPmzdGYMGESAOCXX85h3ryFCAtbgOLiImzcGIUzZ37C+vWf4+bNGwgNHY9u3XogMjIaqal3MGHCWPTt2x8WFhYwNTXDkiX/RdOmzXHmzE9YuHA+nJ3bo1GjR3+Qi4v7BitXroWdXTOEhU3D7t07MGbMeNy+fQvz58/CwoVL0KVLV6Snp0OtLgYALF68EC1bOmD37oO4c+c23nvvX2jVyhGtWztW+hjSy4MvIScioiqjUCjg7Ows/tjb28PNzQ3m5uY4dOiQ2K+kpASHDx+Gl5fXUx998/LywtWrVzXe93T+/HncunULXl5elRpbs2bNYG9vrzEOADhw4ADatWuHhg0bVmp9REREVP3yNk1A3qYJEB7kim1FFw4hb9MEFJ6M0ewb896jvnmZYlvx73HI2zQBD45v1Oibv21WpcYxffok+Pq+gdmzp6FfvwFISUnBkCHDYG/fCnK5HGPGhODEieNQq9UAAGPj+hg1ajTkcjmMjetrrS8u7hgGDhyC5s1fhUKhwNix4/Htt8fE+c2aNYevb38YGBiIyw8dGgCFQoHXXnOCpWVD9OzZG0qlEq1bO8LGxgZ//30dAODm1hHNm78KAwMDeHh4wt7eAZcvP/4DX69ePrC3bwVjY2N4eXkjKekqAOCbb47A09ML3bp1h6GhIZo0aYKmTZshMzMDFy6cx4QJk2BkZITmzV+Fj48vjh//vlLHkF4+vAOKiIj0ysjICBMnTkRERAQaNmwIJycnxMbGIiUlBStXrhT73bp1Cz4+PggNDcXkyZMBAH369IFKpcKUKVMwY8YMlJSUYNmyZejQoQO6d+8uLnv37l0kJCSIv+fn5+PIkSMAHhWxTExMAABTpkzB9OnT0bx5c3Tt2hVxcXE4efIkNmzYUF2Hg4iIiOqAiIj/oW1bZ3F61qwp+Oabw4iJ2SS2GRrKcffuo+JXo0aNnvqS8oyMDLi6dhCnmzR5BZmZGeJ048bad4xbWFiKvxsbG8PCwqLMdH3cv38fAHDhwnmsW7cGf/31FwThIe7fv4+cnOwy63n8R7j69eujoODRcunpabC1tdPabmrqHTx4cB/9+z/+kpaSkofo08dX5/4RASxAERFRNRg3bhwEQUBMTAwyMjLg6OiIqKgoqFQqsU/pC8zLvk9JLpdj/fr1WLp0KWbPng2ZTAZvb2/Mnz9f486pP//8E1OnTtXYZul0XFwcmjZtCgDw8/PDgwcPsG7dOkRHR6NFixaIiIiAp6enPnefiIiIqohi7GePfinz+JxR+34wcu4LGGg+4KMIXPt/fR8/llevTS/Ue+0N4Ik7sM1GrHihcVlbN8a7707CsGEjtObdvJnyzC87sbKyQmrqHXG69CXljz3/l6UsWbIQo0ePg6+vP+RyOSZMGFuh91c2bmyDGzf+1mq3tm4MhcIcBw9+yy9xoUphAYqIiPROJpNh/PjxGD9+vM4+TZs2xZUrV7TaGzdujNWrVz91/e7u7uUuW55BgwZh0KBBFepLREREtUt572mSGcoBQ+1L23L7GsgBg4r1rYx+/QZg8eKFcHXtgNatHZGTk40LF35B9+5vVGj5nj17Y/nyj9C7d19YWlpi8+YN8Pbu/UJjKlVQkA9z8wYwNDTEDz/E4coV7fdrlqd3774YO3YkTp06AXf3rkhPT4NarYadXVO89poT1q//FEFB4yCXy5GcnAQjIyO0bMl3apJufAcUERERERER0Qtwdm6PSZOmYsmSf6NPHy+MG/cOLl68UOHlPTy6YfjwkZg6dSKGDx+EJk1ewdixIVUytmnTZiMiYhn8/HrizJnTcHFxq9BytrZ2WLJkGaKiItG37xuYOjUUGRmPHgv8978XIy0tFcOGvYUBA/pgzZqPUVhYWCXjpbpLJvC7o2uEIAjIyMh7Zj+53ACWlma4dy8favXDahgZVTXGsG6oTBytrBS8Hfklw5z+8mAMpY/5nJ6G+bz2KC4uQmbmP2jU6BXUq2f07AWek1xuwBhK3JMx1HXuMKfXPN4BRUREREREREREesUCFBERERERERER6RULUEREREREREREpFcsQBERERERERERkV6xAEVERERERES1kiDwBeFUOfyetdpLXtMDICIiIiIiIipLLq8HmcwA2dmZUCgsYGgo18s3mD18KENJCQsWUlY2hoIgIC8vG4AMhobVU+6Ijo7G1q1bkZ6eDkdHR4SFhcHd3f2Zy6Wnp2Pp0qU4fvw4DAwM4O3tjfnz58PCwkKj36+//oqPPvoIly5dgoWFBYYNG4bQ0FAYGDy+nygwMBAJCQla2zh06BAcHBxeeB+rCgtQRERERERUYbzYouogk8nQqFETZGffRXZ2ht62Y2BggIcPeZeVlGnHUAZLS2uNnKEv0dHRiIiIwPTp0+Hk5ITY2FiEhIQgNjYWKpVK53JqtRrjx49HcXExli1bBrVajeXLlyM0NBRbt24Vi60pKSkYM2YMOnfujM8++wzJyclYvnw5iouLMX36dI11urm5Yc6cORptTZs2rfqdfgEsQBERERERUYXwYouqk1xeDw0bNsbDhyV6KRIZGsrQoIEpsrMLeBeURJUXQ0NDebUUn4qKivDpp58iKCgIwcHBAIDOnTtjwIABWLduHSIiInQue+zYMVy+fBkHDhxA69atAQCNGzfGiBEj8OOPP6JHjx4AgA0bNkCpVGLNmjUwMjKCh4cH8vLyEBkZieDgYCiVSnGdSqUSLi4u+tvhKsACFBERERERPRMvtqgmyGSPHqUyNKz6dcvlBqhfvz7u3y+BWs27oKSoJmOYmJiI3Nxc+Pv7i22Ghobo168fNm7cCEEQdD42Gh8fD5VKJeZD4FFR3c7ODvHx8WJOPH78OHr37g0jIyOx34ABAxAREYFTp06hb9++eto7/eBLyImIiIiI6JmedrEVHx//1Bf/Putiq5Sui63CwkKcOnWqiveIiOj5JScnAwDs7e012h0cHJCfn4/U1NSnLlve48KtWrUS11tQUIDbt29r9bOzs4OJiYnYr1RCQgJcXFzg7OyMd955Bz///PNz7Zc+8Q4oIiIiIiJ6popcbDVp0kTnsvq62CopKUH79u0xdepUdOrU6bn3j4jqvtu3byMwMFDn/Li4uAqvKycnB0ZGRqhfv75Ge4MGDQAAWVlZOnNiTk4OzM3NtdqVSqWY63Jzc8W28vplZ2eL0506dcJbb72FV199FWlpaYiOjsbYsWMRExMDV1fXCu+TvrEAVYOsrBQV7mthYarHkVB1YAzrBsaRdGFOf7kwhtLHGFZeXbjY6tWrl8553377LQDm85cR4yh9FY1ho0aNnmv9giCgpKREnC59tK68R+xK7wZ91rc26lr2yfaK9JsyZYrG/DfeeAP+/v6IjIzE+vXrnzqO6sQCVA2p7FeI6uMrR6l6MYZ1A+NI5WFOf/kwhtLHGD7dy3qxxXz+cmIcpa+iMTQ2Nq7UXU6lEhISEBQUJE537twZvr6+KCwsRGFhIYyNjcV5OTk5AB4X58ujVCrFfmXl5uaKRfjS/5YtvpfXrzympqbw8vLC0aNHn7Fn1YsFKCIiIiIi0lBXL7ae58KTiKhNmzbYuXOnOG1mZoa0tDQAjx4xdnJyEuclJyfDzMwMNjY2Otfn4OCAP/74Q6s9KSkJPXv2BACYmJjA1tZW6/HjW7du4f79++U+1lzW097LV1NYgCIiIiIiIg282CIiekyhUMDZ2VmjrWnTpjA3N8ehQ4fEnFhSUoLDhw/Dy8vrqXdleXl5Ye/evRrvxzt//jxu3boFLy8vsV+PHj0QFxeHsLAw8csZDh48CGNjY3h4eOhcf0FBAeLj47XGXNP4LXhERERERKSh9GKr9Mfe3h5ubm7ixVapylxsXb16VaO49LSLraKiIrFNyhdbRFR3GRkZYeLEidi8eTM2btyI06dPIywsDCkpKfjXv/4l9rt16xacnJzwySefiG19+vSBSqXClClTEBcXh2PHjmHWrFno0KEDunfvLvYbP348srOzMW3aNJw6dQpbt25FZGQkxo4dK94VevbsWUycOBG7d+/G6dOnsW/fPowaNQrp6emYNGlS9R2QCuAdUERERERE9EylF1sRERFo2LAhnJycEBsbi5SUFKxcuVLsd+vWLfj4+CA0NBSTJ08GoHmxNWPGDJSUlGDZsmXlXmzt378f06ZNQ2BgIK5du1buxVZ0dDR8fHxga2uLtLQ0bNq0Cenp6Vi9enX1HhQieqmNGzcOgiAgJiYGGRkZcHR0RFRUFFQqldin9J16Ze/SlMvlWL9+PZYuXYrZs2dDJpPB29sb8+fP1yjmN2vWDJs2bUJ4eDjeffddWFhYIDg4GKGhoWIfa2trFBUVYeXKlcjKyoKJiQlcXV2xaNEitGvXrnoORAXJBN6rSkREREREFSAIAqKjo7F161bxYmv27Nno0qWL2OfmzZvo1asXJk+ejPfee09sT0tLw9KlS/Hjjz9qXGxZWlpqbOPChQsIDw/H77//DgsLCwwbNgyhoaEwNDQEAPz999/48MMPceXKFY2LrcmTJ9e6iy0iInqMBSgiIiIiIiIiItIrvgOKiIiIiIiIiIj0igUoIiIiIiIiIiLSKxagiIiIiIiIiIhIr1iAIiIiIiIiIiIivWIBioiIiIiIiIiI9IoFKCIiIiIiIiIi0isWoOqQtWvXIjExUav90KFDeO+999C9e3eoVCpER0eXu/zNmzcxY8YMeHp6wtXVFYMGDcK+ffv0PWwqQ1cMly9fjv79+8PV1RVubm4YMmQIDh48+NR1LVmyBCqVCh9++KG+hkvl0BXDwMBAqFQqrZ/k5GSNfsXFxfj444/h6emJ9u3bIzAwEJcvX66u4VMtwXwufczn0sd8TlWFOV36mNOljzm9dpDX9ACo6nzyyScwNTWFm5ubRvuRI0eQkpKCnj17Yvv27eUuW1hYiODgYADA/PnzYWFhgQMHDmD27NmoX78++vTpo/fxk+4Y3r9/HwEBAWjZsiUEQcDRo0cxY8YMPHz4EAMGDNBaz5UrV7Br1y4oFIrqGjr9H10xBAA3NzfMmTNHo61p06Ya0+Hh4dizZw/mzp0LOzs7bNiwAWPGjMH+/fthbW2t17FT7cF8Ln3M59LHfE5VhTld+pjTpY85vXZgAeo5CIKA4uJiGBkZ1fRQKmTVqlUwMHh0s5uuD7eLFy/ir7/+wpYtW9ClSxcAQNeuXXHhwgUcOnSozn24SS2GCxcu1Jju3r07kpKS8PXXX5f74bZ48WKMHTsWe/bsqaYRVj+pxRAAlEolXFxcdM5PTU3FV199hQULFmDYsGEAgPbt26NXr17YsmULZs2aVU0jfXlI7TxiPtcmtRgyn2uTWgwB5vPaSmrnEnO6NqnFkDldm9RiCDCnVyc+glcBc+fOhb+/P+Lj4/Hmm2/C2dkZcXFx+OWXXxAUFAQXFxd06NABM2fORGZmpsayUVFR8PHxgbOzMzw8PDBmzBikpKQAeHQ7rUqlwt69e/Hhhx+iU6dO8PT0xH//+1+o1WqN9SQnJ2PixIno0KEDXFxc8O677+LGjRvifJVKBQBYtmyZeNvgmTNnAED8YHua0u2Zm5trtJubm0MQhEoesdpH6jEsj4WFBYqLi7Xa9+3bh5s3byIkJOS5j1dtVBdj+KQTJ06gpKQE/fv3F9sUCgW8vb0RHx9f6WNG2qR+HjGfSz+G5WE+l34Mn8R8Xj2kfi4xp0s/huVhTpd+DJ/EnF51WICqoLS0NCxduhRjx47F+vXrYW1tjcDAQJibmyMiIgKLFy/GxYsXMXHiRHGZPXv2YPXq1Rg6dCg2bNiAxYsX4/XXX0d+fr7Gukv/+rFq1SoMHz4cGzduRGxsrDg/JSUFAQEByM7Oxn/+8x+sWLECd+/exZgxY1BUVATg8V9NAgMDsX37dmzfvh1t2rSp8P516NABrVq1wsqVK5GSkoLc3Fxs374dv/32GwICAl7k0NUaUo+hIAhQq9XIycnBnj17cPLkSYwaNUpjHHl5eVi2bBnCwsJgYmJS5cewpkk9hgkJCXBxcYGzszPeeecd/PzzzxpjSE5OhpWVFSwsLDTaHRwccP36dTx8+LBKjuPLTurn0bMwn9f+GDKfSz+GzOe1h9TPpWdhTq/9MWROl34MmdOrkUDPNGfOHMHR0VG4cOGC2DZq1Chh+PDhwsOHD8W2q1evCiqVSvjhhx8EQRCERYsWCYMGDdK53pSUFMHR0VGYMmWKRntAQIAwevRocTosLEzw9vYWHjx4ILZlZmYKLi4uwhdffCG2OTo6Chs2bHjqvjytT0ZGhvD2228Ljo6OgqOjo9CmTRth//79T12fVNSFGJ48eVKMjZOTk7Bt2zatPuHh4cLIkSPF6Z49ewqLFi3SOX4pkXoMV69eLcTGxgo///yzcPDgQWHw4MFCmzZthMTERLHPggULhL59+2otu2PHDsHR0VHIzc3VuR9UMVI/j8piPpduDJnPpR1D5vPaQ+rnUlnM6dKNIXO6tGPInF69eAdUBVlaWqJdu3YAHr1sLjExEb6+vigpKYFarYZarUbLli1hbW2NixcvAgCcnJxw6dIlhIeH4+zZs+XeigkAnp6eGtOtWrXCnTt3xOmTJ0+iV69eMDQ0FLelVCqhUqnw22+/Vcn+PXjwAFOmTEFJSQk++eQTbN68GSNGjMC8efNw/PjxKtlGTZN6DNu1a4edO3di8+bNCAoKwuLFizWq/0lJSdi6dSvef//9Sh0XKZFyDKdMmYKhQ4eiY8eO6NevH2JiYtC4cWNERkZq9JPJZFrLCnXgFvvaRMrnUUUwn9f+GDKfSzuGzOe1i5TPpYpgTq/9MWROl3YMmdOrF19CXkGNGjUSf8/JyUFJSQnCw8MRHh6u1feff/4BAAwePBj5+fnYsWMHNm/eDHNzcwwcOBCzZs1C/fr1xf5PPtNdr1498XZBALh37x62bNmCLVu2aG2r7HpexM6dO3HhwgUcP34cDRs2BAB4eHjg9u3bWL58OXr06FEl26lJUo+hQqGAs7MzgEexKSoqwn/+8x8MHjwYhoaGCA8Ph6+vL+zs7JCTkwMAePjwIYqLi5GTkwOFQlGhdw3UZlKPYVmmpqbw8vLC0aNHxTalUinGrqycnBzUq1cPpqamld4OaatL51F5mM811cYYMp9LP4ZlMZ/XrLp0LpWHOV1TbYwhc7r0Y1gWc7p+sQBVQWUrnubm5pDJZJgwYQJ69+6t1dfS0hLAoxcLjh49GqNHj0ZqaioOHjyIjz/+GJaWlpg0aVKFt92gQQN4eXlh5MiRWvPMzMyeY2+0JSUlwcbGRvxgK/X666/j5MmTVbKNmlbXYtimTRt88cUXuHv3LqytrXH9+nWcOHEC+/bt0+i3Y8cO7NixA4cOHYKDg8Nzbau2qGsxfPKvJg4ODsjMzERWVpbGM+bJyclo2bKl5P9xUlvUtfPoScznmqQQQ+Zz6ceQ+bzm1LVz6UnM6ZqkEEPmdOnHkDldf1iAeg6mpqZwcXHBtWvXxGr3s9jY2GDcuHE4cOAArl27VqnteXh44M8//4STkxMMDQ119qtXrx4KCwsrte5Stra2SE1NRWZmpkYF+7fffoOdnd1zrbM2qwsxPHfuHBQKhZjEV65cqbXsjBkz4OLigqCgINja2lZqzLWd1GNYUFCA+Ph4jbF7enrCwMAAhw8fxogRIwAA+fn5+O677/D2229XarxUMVI/j8rDfP5stS2GzOfSjiHzee0h9XOpPMzpz1bbYsicLu0YMqfrFwtQzyksLAyjR4/GtGnT0L9/fyiVSty5cwc//fQTBg8eDHd3dyxcuBBKpRIuLi5QKpVITEzE5cuXxZO2okqfSw0ODsawYcNgZWWFjIwMJCQkoGPHjvD39wcA2NvbIy4uDh07doSJiQlatmwJhUKBpKQkJCUlieu7evUqjhw5AhMTE3h5eQEA3nzzTURFRSEkJAQhISFQKpX45ptv8P333+ODDz6osuNWm0glhjdv3sSKFSvEW3cLCgrw/fffY+fOnZg5cybk8kf/G7u4uGht19jYGDY2NnB3d3/h41UbSSWGly9fRnR0NHx8fGBra4u0tDRs2rQJ6enpWL16tbgNGxsbBAQEYMWKFZDL5bC1tcXGjRsBAKNHj666A0capHIeMZ/rJpUYMp/rJpUYMp/XflI5l5jTdZNKDJnTdZNKDJnTqx8LUM/Jzc0NX375JdauXYt58+ahuLgYTZo0QZcuXdCiRQsAgKurK3bs2IHY2Fjcv38fzZo1w7x58ypdJW3RogViY2OxatUqLFq0CAUFBbC2tkanTp2gUqnEfgsXLsRHH32EkJAQPHjwAJ9//jnc3d1x+PBhfPLJJ2K/PXv2YM+ePbCzs8N3330HAGjSpAliYmKwatUqLFmyBAUFBWjRogWWLFmCoUOHVsERq32kEkMHBwcolUpERkYiPT0d5ubmsLe3x//+979yb2t9mUglhk2aNEFRURFWrlyJrKwsmJiYwNXVFYsWLRJf2Fhq7ty5MDU1xapVq5Cbm4v27dtjy5YtsLa2fvEDRuWSynnEfK6bVGLIfK6bVGLIfF77SeVcYk7XTSoxZE7XTSoxZE6vfjKBr24nIiIiIiIiIiI94tuyiIiIiIiIiIhIr1iAIiIiIiIiIiIivWIBioiIiIiIiIiI9IoFKCIiIiIiIiIi0isWoIiIiIiIiIiISK9YgCIiIiIiIiIiIr1iAYqIiIiIiIiIiPSKBSgiIiIiIiIiItIrFqCI/s/u3buhUqmgUqlw5swZrfmCIMDHxwcqlQqBgYFVtl2VSoW1a9dWermbN29CpVJh9+7dVTYWIqK6gjmdiKhuYD4nqjtYgCJ6gpmZGXbu3KnVnpCQgBs3bsDMzKwGRkVERM+DOZ2IqG5gPieSPhagiJ7Qr18/HDt2DHl5eRrtO3fuhKurK2xtbWtoZEREVFnM6UREdQPzOZH0sQBF9IT+/fsDAA4cOCC25ebm4tixYxgyZIhW/6ysLHzwwQfo3r072rZti169eiEiIgJFRUUa/fLy8vD+++/D3d0drq6uCA4OxvXr18sdw19//YWZM2fCw8MDbdu2hZ+fH7Zu3VqFe0lE9HJgTiciqhuYz4mkT17TAyCqbRQKBfr27Ytdu3YhICAAwKMPOgMDA/j5+WHLli1i38LCQgQFBSElJQXvvfceVCoVzp49i6ioKPzxxx+IiooC8OjZ9NDQUPzyyy+YNGkSnJ2dkZiYiJCQEK3tJyUlISAgAK+88grmzJkDa2trnDhxAkuWLMG9e/cwefLk6jkQRER1AHM6EVHdwHxOJH0sQBGVY8iQIQgKCsKff/6J1q1bY9euXfD19YVCodDo9/XXX+PKlStYtWoV/Pz8AADdunWDqakpVqxYgZMnT6Jbt2748ccfcebMGSxYsABBQUFiv3r16iEiIkJjneHh4TAzM8O2bdvE7XXr1g1FRUWIiopCYGAgGjRoUA1HgYiobmBOJyKqG5jPiaSNj+ARlaNz585o3rw5du3ahStXruDixYvl3tp7+vRpmJqawtfXV6N98ODBAIBTp04BgPiNHQMGDNDo5+/vrzFdWFiI06dPw8fHB/Xr14darRZ/evTogcLCQpw/f76qdpOI6KXAnE5EVDcwnxNJG++AIiqHTCbD4MGDERMTg8LCQrz66qvo2LGjVr+srCxYWVlBJpNptDdq1AhyuRxZWVliP7lcDktLS41+1tbWWutTq9WIiYlBTExMuWO7d+/eC+wZEdHLhzmdiKhuYD4nkjYWoIh0GDx4MNasWYOvvvoK06dPL7ePhYUFLly4AEEQND7gMjMzoVarxQ8zCwsLqNVq3Lt3T+MDLj09XWN9SqUShoaGeOuttzBy5Mhyt9m0adMX3TUiopcOczoRUd3AfE4kXXwEj0gHGxsbBAcHo2fPnhg4cGC5fTw8PFBQUIBvv/1Wo33Pnj3ifABwd3cHAOzfv1+jX9lv8QAAExMTuLu749KlS1CpVHB2dtb6efIvNERE9GzM6UREdQPzOZF08Q4ooqeYNWvWU+cPHDgQW7duxZw5c3Dr1i04Ojri3Llz+Oyzz+Dl5YWuXbsCADw9PdGpUycsX74c9+/fR9u2bZGYmIi9e/dqrXPBggUYOXIkRo0ahREjRsDOzg75+fm4ceMGvvvuO3z++ed62VciorqOOZ2IqG5gPieSJhagiF6AsbExPv/8c0RERGDDhg24d+8ebGxsMG7cOI2vYjUwMMCnn36K8PBwbNiwAcXFxXBzc0NUVJT4zRylWrVqhd27dyMyMhKrVq3C3bt3YW5ujhYtWsDLy6u6d5GI6KXBnE5EVDcwnxPVTjJBEISaHgQREREREREREdVdfAcUERERERERERHpFQtQRERERERERESkVyxAERERERERERGRXrEARUREREREREREesUCFBERERERERER6RULUEREREREREREpFcsQBERERERERERkV6xAEVERERERERERHrFAhQREREREREREekVC1BERERERERERKRXLEAREREREREREZFesQBFRERERERERER69f8BXJpXzSw6HmQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x280 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = list(range(len(models)))\n",
    "color = \"C0\"\n",
    "\n",
    "acc_axs = list()\n",
    "f, axs = plt.subplots(1, 3, figsize=(12, 2.8))\n",
    "\n",
    "axs[0].plot(x, torch.mean(fair_m_spds, dim=1), \"-\")\n",
    "axs[0].fill_between(x, \n",
    "                       torch.mean(fair_m_spds, dim=1) - torch.std(fair_m_spds, dim=1), \n",
    "                       torch.mean(fair_m_spds, dim=1) + torch.std(fair_m_spds, dim=1), alpha=0.3)\n",
    "axs[0].set_ylabel(\"$\\Delta$ SPD\", color=color)\n",
    "acc_axs.append(axs[0].twinx())\n",
    "axs[1].plot(x, torch.mean(fair_m_eods, dim=1), \"-\")\n",
    "axs[1].fill_between(x, \n",
    "                       torch.mean(fair_m_eods, dim=1) - torch.std(fair_m_eods, dim=1), \n",
    "                       torch.mean(fair_m_eods, dim=1) + torch.std(fair_m_eods, dim=1), alpha=0.3)\n",
    "axs[1].set_ylabel(\"$\\Delta$ EOD\", color=color)\n",
    "acc_axs.append(axs[1].twinx())\n",
    "axs[2].plot(x, torch.mean(fair_m_aods, dim=1), \"-\")\n",
    "axs[2].fill_between(x, \n",
    "                       torch.mean(fair_m_aods, dim=1) - torch.std(fair_m_aods, dim=1), \n",
    "                       torch.mean(fair_m_aods, dim=1) + torch.std(fair_m_aods, dim=1), alpha=0.3)\n",
    "axs[2].set_ylabel(\"$\\Delta$ AOD\", color=color)\n",
    "acc_axs.append(axs[2].twinx())\n",
    "\n",
    "axs[1].set_title(f\"CheXpert\")\n",
    "\n",
    "for ax in acc_axs:\n",
    "    ax.plot(x, torch.mean(fair_m_accs, dim=1), \":\", c=\"C1\", alpha=0.5)\n",
    "    ax.fill_between(x, \n",
    "                    torch.mean(fair_m_accs, dim=1) - torch.std(fair_m_accs, dim=1), \n",
    "                    torch.mean(fair_m_accs, dim=1) + torch.std(fair_m_accs, dim=1), alpha=0.15, color=\"C1\")\n",
    "\n",
    "handle_1 = mlines.Line2D([], [], color='C0', linestyle=\"solid\", label='Fairness Violation')\n",
    "handle_2 = mlines.Line2D([], [], color='C1', linestyle=\"dotted\", label='Performance')\n",
    "axs[2].legend(handles=[handle_1, handle_2], loc=\"lower right\", fontsize=\"x-small\")\n",
    "\n",
    "plot_negative = False\n",
    "for constraint in (fair_m_spds, fair_m_eods, fair_m_aods):\n",
    "    if torch.mean(constraint) - torch.std(constraint) < 0:\n",
    "        plot_negative = True\n",
    "        break\n",
    "\n",
    "for i, ax in enumerate(axs.flatten()):\n",
    "    ax.yaxis.grid(False)\n",
    "    ax.set_xticks(x)\n",
    "    ax.set_xlabel(\"Model\")\n",
    "    ax.set_xticklabels(models)\n",
    "    ax.yaxis.set_major_formatter(FuncFormatter(lambda x, _: f\"{x:.3f}\"))\n",
    "\n",
    "    y_lims = ax.get_ylim()\n",
    "    y_lim = max(abs(y_lims[0]), abs(y_lims[1]))\n",
    "    if plot_negative:\n",
    "        ax.set_ylim(-y_lim * (1 + ax.margins()[0]), y_lim * (1 + ax.margins()[1]))\n",
    "        ax.hlines(0, 0, len(models) - 1, colors=\"black\", linestyles=\"--\", alpha=0.2)\n",
    "    else:\n",
    "        ax.set_ylim(0, y_lim * (1 + ax.margins()[1]))\n",
    "\n",
    "for a, ax in enumerate(acc_axs):\n",
    "    ax.yaxis.grid(False)\n",
    "    if a == 2:\n",
    "        ax.yaxis.set_major_formatter(FuncFormatter(lambda x, _: f\"{x:.3f}\"))\n",
    "        ax.set_ylabel(\"AUROC ($\\\\rightarrow$)\", color=\"C1\")\n",
    "    else:\n",
    "        ax.set_yticks([])\n",
    "    \n",
    "    y_lims = ax.get_ylim()\n",
    "    y_lim = max(abs(y_lims[0]), abs(y_lims[1]))\n",
    "    if plot_negative:\n",
    "        ax.set_ylim(-y_lim * (1 + ax.margins()[0]), y_lim * (1 + ax.margins()[1]))\n",
    "        ax.hlines(0, 0, len(models) - 1, colors=\"black\", linestyles=\"--\", alpha=0.2)\n",
    "    else:\n",
    "        ax.set_ylim(0, y_lim * (1 + ax.margins()[1]))\n",
    "\n",
    "f.tight_layout()\n",
    "plt.savefig(os.path.join(PLOTS_PATH, f\"compare_models_chexpert_pa{pa}.pdf\"))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABJoAAAEICAYAAAAX/55pAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABYA0lEQVR4nO3deVxUZf//8ffMAAICgoqaa25gpbhkuSEqamlimZpZZpremVl5p1luLVp2U2rulpn209TSguI2bXUv7xbLNlOz0ErN3FkUkGXm94dfJkdgZJiBYYbX8/Hw0cyZc675nIuZ+XR9zjnXMVgsFosAAAAAAAAAJxndHQAAAAAAAAC8A4UmAAAAAAAAuASFJgAAAAAAALgEhSYAAAAAAAC4BIUmAAAAAAAAuASFJgAAAAAAALgEhSYAAAAAAAC4BIUmAAAAAAAAuASFJgAAAAAAALgEhSYAAIAS2L9/vyZPnqzY2Fi1aNFCrVu31u23367XXntNKSkpkqTY2Fg98MADLnvPr7/+Ws2aNdOcOXMKvPbnn3+qdevWGjt2rMvez1FLlizRpk2b3Pb+AADA/Sg0AQAAOOjtt9/WgAED9NNPP2nkyJFatmyZFi1apF69emnt2rWaOnVqqbzvjTfeqKFDh2rZsmX68ccfrcvNZrMmTpwof39/TZs2rVTeuzheffVVCk0AAFRwPu4OAAAAwJN89913mjZtmjp27KiXX35Zfn5+1tc6deqk++67T5999lmpvf9jjz2mHTt2aOLEiUpKSlKlSpW0fPly7d69WwsXLlTVqlVL7b2LkpWVJX9//zJ/XwAAUP5wRhMAAIADXn31VRkMBj333HM2RaZ8fn5+6t69u82yHTt26Pbbb1dUVJR69eqlhISEAtudPHlSTz/9tGJiYtS8eXPFxsZq0aJFys3NtVnP399fL7zwgn7//XfNmTNHBw4c0IIFC9S3b1/ddNNNNusOHTpUcXFx+uabbzRo0CBFRUWpc+fOmjdvnvLy8mzWzc7O1ssvv6xevXqpefPmat++vSZPnqwzZ87YrJd/OeAnn3yifv36qUWLFlq0aJEiIyOVkZGh9957T5GRkYqMjNTQoUMd6lsAAOD5DBaLxeLuIAAAADxBXl6err/+ekVEROjtt9++4vqxsbHKy8tTUFCQ7r//flWvXl3vvPOOPvroI61evVo33HCDpItFpjvuuENGo1EPPPCA6tevr++++06vvPKK4uLiFB8fX6DtWbNm6fXXX1ft2rWVnZ2tDRs2qEqVKjbrDB06VAcOHJCfn59GjRqlhg0batu2bVq1apWGDBmip59+WtLFS+9GjRqlb7/9ViNHjlSbNm109OhRLVy4UMHBwUpMTLSesRQbG6vs7Gz5+/vrwQcfVN26dRUQECCz2axhw4apXbt2GjNmjCQpKChITZo0carPAQCAZ+HSOQAAgGI6e/asMjMzVbduXYe2eeutt1S7dm1J0g033KAvv/xS77//vrXQtHDhQqWmpmrjxo3W9Tp06CB/f3+9+OKLGjlyZIGCzdixY7Vu3TodOXJECxYsKFBkypeSkqKXX37ZepZVdHS0Lly4oLfeekv/+te/VLt2bX344Yf67LPPtHDhQpuzopo1a6aBAwfq3Xff1d13321dfubMGW3cuFENGza0eS+j0aiqVauqVatWxe4fAADgXbh0DgAAoBRdc8011uKRJFWqVElXX321/vrrL+uybdu2qV27dqpRo4Zyc3Ot/2JiYiRdvNvc5RITE5Weni6j0aidO3cW+f6VK1cucClfXFyczGazdu3aJUnaunWrQkJC1K1bN5v3v+aaaxQeHl7g/SMjIwsUmQAAACTOaAIAACi2sLAwBQQE6MiRI8XeJjQ0tMAyPz8/Xbhwwfr89OnT2rp1q6677rpC2zh79qzN88OHD2vWrFnq2bOnIiMjrXe869ixY4Ftq1evXuSylJQU6/unpaWpefPmxXr/8PDwQtcDAACg0AQAAFBMJpNJ7du312effaa///5btWrVckm7YWFhioyM1KOPPlro6zVq1LA+tlgsmjx5sipVqqTp06crJCREmzZt0pNPPqn169crKCjIZttTp04VaC9/WX4RLCwsTKGhoVq2bFmh71+5cmWb5waDobi7BgAAKhgunQMAAHDAAw88IIvFoieffFLZ2dkFXs/JydGWLVscarNr1646cOCA6tevrxYtWhT4V7NmTeu6K1eu1K5duzRt2jRVq1ZNvr6+euGFF3TixAnNnDmzQNvnz5/X5s2bbZZt2LBBRqPROkdU165dlZKSIrPZXOj7N2rUqFj74efnp6ysLIf2HQAAeBfOaAIAAHBA69atNW3aNE2fPl0DBgzQ4MGD1bRpU+Xm5mrv3r16++231bRpU8XGxha7zbFj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v34ObUueAIDyo1QKTY4OIJKTkwscZfDz81P9+vWVnJxc5HYHDx6UJJvTUiWpcePGslgs1teTk5NVvXp1hYaGFljv0KFDMpvNNstHjRqla665RjExMXrxxReLfW03AKBozgwgyBMA4L127dqlSZMmqXPnzpo3b55q1aoli8XiUBvkCQAoP1x26dy5c+e0ceNGJSQk6Oeff9bevXuLvW1aWppCQkIKLA8JCVFqamqR2+W/dvm2VapUsXk9LS1NwcHBBbavUqWKcnJylJGRoaCgIAUHB+tf//qXbrjhBlWqVElffvmlXn/9dR08eFCvvvpqsfenMD4+5eLkMaeYTEab/6Ls0PfuQb+7xq5du5SYmKiPP/5Y/v7+atu2rfbs2eNQG+QJz8B3pvgu7SOTyej039/b+76875fRaPCK73BZOnHihJKSkpSQkKCTJ08qNjZWc+fOVXR0tA4ePKhNmzY51B55wjN4+29VeUbfu0dF7XenC02uGEAUxWKxyGAwXHG9y9fJPwJy6fLC2rn8SMm1116ra6+91vq8Q4cOqlGjhp599ln9+OOPioqKcij+fEajQWFhlUu0bXkUEhLg7hAqLPrePeh3x7l6AFEU8kT5xHfmyipV+ufzFhZWWYGBgS5pl753j6Agf3eH4FFGjx6t//3vf7rxxhv10EMPqWfPnjbfgeL8rhcXeaJ84rfKfeh796ho/V6iQpOrBxAhISFKS0srsDw9Pd3uxH2XHmmoXr26dXl+W/lHJopqPy0tTb6+vnb/565379569tlntWfPnhInBrPZorS0jBJtW56YTEaFhAQoLS1TeXnmK28Al6Hv3cPb+j0kJKBMjqaUxgCCPOEZvO07U5oyMv75e589e14XLjh2mdDlvL3v8/evvDp3Lks5OXnuDsNpZZUntm3bpttuu03Dhw/XNddc45I2yROewdt/q8oz+t49vK3fi5snHC40lcYAonHjxgWunc7Oztaff/6pAQMGFLld/rXUBw8etEkgycnJMhgM1tcbN26s06dPKyUlxea66uTkZDVs2FBGY+kn1Nxcz/9Q5cvLM3vV/ngS+t49nO33zMwMdejQRpL0xRe7FRDgmjMXyqvSGECQJzwLv1VXdun/bLqyv+h79zCbLeQJB7z11ltKTEzUkCFDdNVVVykuLk5xcXGqV69eidskT3gWfqvch753j4o2nnD4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",
      "text/plain": [
       "<Figure size 1200x280 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = [_x - 0.2 for _x in range(len(models))]\n",
    "xacc = [_x + 0.2 for _x in range(len(models))]\n",
    "color = \"C0\"\n",
    "\n",
    "acc_axs = list()\n",
    "f, axs = plt.subplots(1, 3, figsize=(12, 2.8), sharex=True)\n",
    "\n",
    "axs[0].bar(x, torch.mean(fair_m_spds, dim=1), yerr=torch.std(fair_m_spds, dim=1), color=color, width=0.4, label=\"$\\Delta$ Fairness Violation\")\n",
    "axs[0].set_ylabel(\"$\\Delta$ SPD ($\\leftarrow$) / $\\Delta$ AUROC ($\\\\rightarrow$)\", fontsize=\"small\")\n",
    "# acc_axs.append(axs[0].twinx())\n",
    "axs[1].bar(x, torch.mean(fair_m_eods, dim=1), yerr=torch.std(fair_m_eods, dim=1), color=color, width=0.4, label=\"$\\Delta$ Fairness Violation\")\n",
    "axs[1].set_ylabel(\"$\\Delta$ EOD ($\\leftarrow$) / $\\Delta$ AUROC ($\\\\rightarrow$)\", fontsize=\"small\")\n",
    "# acc_axs.append(axs[1].twinx())\n",
    "axs[2].bar(x, torch.mean(fair_m_aods, dim=1), yerr=torch.std(fair_m_aods, dim=1), color=color, width=0.4, label=\"$\\Delta$ Fairness Violation\")\n",
    "axs[2].set_ylabel(\"$\\Delta$ AOD ($\\leftarrow$) / $\\Delta$ AUROC ($\\\\rightarrow$)\", fontsize=\"small\")\n",
    "# acc_axs.append(axs[2].twinx())\n",
    "\n",
    "axs[1].set_title(\"CheXpert\")\n",
    "\n",
    "for ax in axs:\n",
    "    ax.bar(xacc, torch.mean(fair_m_accs, dim=1), yerr=torch.std(fair_m_accs, dim=1), color=\"C1\", width=0.4, label=\"$\\Delta$ Performance\")\n",
    "\n",
    "ymin, ymax = 0, 0\n",
    "for i, ax in enumerate(axs.flatten()):\n",
    "    ax.set_xticks(list(range(len(models))))\n",
    "    ax.set_xlabel(\"Model\")\n",
    "    ax.set_xticklabels(models)\n",
    "\n",
    "    y_lims = ax.get_ylim()\n",
    "    ymin = min(ymin, y_lims[0])\n",
    "    ymax = max(ymax, y_lims[1])\n",
    "\n",
    "    ax.yaxis.set_major_formatter(FuncFormatter(lambda x, _: f\"{x:.3f}\"))\n",
    "\n",
    "for ax in axs:\n",
    "    ax.set_ylim(ymin, ymax)\n",
    "\n",
    "plt.legend(fontsize=\"xx-small\", ncol=2, loc=\"upper center\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(os.path.join(PLOTS_PATH, f\"compare_models_chexpert_pa{pa}_barplot.pdf\"))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3, 50])\n"
     ]
    }
   ],
   "source": [
    "fair_aurocs, fair_spds, fair_eods, fair_aods = list(), list(), list(), list() \n",
    "for m in range(len(models)):\n",
    "    for s in range(len(method_seeds)):\n",
    "        \n",
    "        fair_aurocs.extend([auroc(fair_probits[m, s, a][:, 1], y_fair_t) for a in range(fair_probits.shape[2])])\n",
    "\n",
    "        fair_spds.extend([spd(fair_probits[m, s, a].argmax(dim=1), a_fair_t) for a in range(fair_probits.shape[2])])\n",
    "\n",
    "        fair_eods.extend([eod(fair_probits[m, s, a].argmax(dim=1), y_fair_t, a_fair_t) for a in range(fair_probits.shape[2])])\n",
    "\n",
    "        fair_aods.extend([aod(fair_probits[m, s, a].argmax(dim=1), y_fair_t, a_fair_t) for a in range(fair_probits.shape[2])])\n",
    "\n",
    "# reshape to (models, seeds)\n",
    "fair_aurocs = torch.stack(fair_aurocs).reshape(len(models), -1)\n",
    "fair_spds = torch.stack(fair_spds).reshape(len(models), -1)\n",
    "fair_eods = torch.stack(fair_eods).reshape(len(models), -1)\n",
    "fair_aods = torch.stack(fair_aods).reshape(len(models), -1)\n",
    "\n",
    "\n",
    "print(fair_aurocs.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Tz/FunXrEBoaihUrVmDgwIHafVq1aoUNGzZg5cqVSExMRHl5OUJDQ5GYmIhnn33WKu+RiOrHbLB/LEARkdnYG4OIiIjsTVhYGNatW2dwn+TkZCQnJ+ttHzduHMaNG2fw2MjISHz22WdNaqMlmTolAsAFKojINuyiAHXlyhUkJibi5MmT8PDwwKhRoxAfHw+pVGrwuPT0dOzevRuZmZnIy8vDm2++iWnTpunsc+/ePSQkJCArKwv5+fnw9PTEQw89hDlz5qBHjx46+969exfvvfceDh8+DLFYjGHDhiEhIQF+fn6WfstERERERERNYs6UCAAXqCAi27B5AUqhUGDKlCmQy+VYvXo1CgsLkZSUhOLiYixdutTgsXv27EFubi6GDh2KzZs317uPUqmEu7s74uLi0Lp1a5SWliI1NRVTpkzBf//7X4SFhQEAampq8Morr0CpVGLx4sWoqanBkiVLEBsbi6+++goikcji752IiIiIiMhc5kyJAHCBCiKyDZsXoDZt2gSFQoG0tDTt6hISiQTx8fGYNWuWzmSBD1q5ciXEYjEANFiA8vf3x5IlS3S29e/fH3379sXevXvx6quvAgD27duH8+fPY9euXejUqRMAoGXLlnjhhRfw/fffY/DgwU1+r0RERERERJbEoXRE5CjEtm7A4cOHERMToy0+AcATTzwBNzc3HDp0yOCxdcUnU3l6esLd3R01NX8+KTh06BAiIiK0xScA6NWrF0JCQhptBxERERERERERNczmBaicnBy9Xk5ubm5o164dcnJyLHYdtVqNmpoa5OXlITk5GWKxGE8//bTBdgBAx44dLdoOIiKynCtXrmDatGmIjo5GTEwMEhMTUVlZ2ehx6enpiIuLw6BBgxAREVHvZLVXrlzBokWLMHLkSERHR2Po0KFISEjA3bt3hXgrREREREROzeZD8BQKBWQymd52mUyGkpISi11n1apV+PTTTwEALVq0wJo1a9C2bVuddvj4+NTbDkMFqOHDhzf42t69eyGRcNFHIiIhCD2H4NGjR3HixAk8//zziIyMxO3bt5GSkoIJEyZg586d8PLyEuJtERERERE5JZsXoBqi0WgsOvH3iy++iMceewx3797Fli1bMGPGDKxfvx7dunXT7lPf9SzdDiIisgyh5xAcOXIkJk2apJMBERERePrpp7Fv375Gl+kmIiIiIqI/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THsv76dQKODq6gpPT0+Tr0PUVM70fVcfZkMtZoN9/BtlNpAjcKbvufpYOxcAx7+nzAZmgzNhAcpK7q+g+vj4QCQSYebMmXjsscf09vX39wdQO5HflClTMGXKFNy5cwfffvstli1bBn9/f8yePdvoa/v6+mLIkCF48cUX9V7z8vIy493oy87ORnBwsDZI6kRGRuLo0aMWucb9nO1+duvWDRs3bkRhYSGCgoJw5coVHDlyBDt27NDZb8uWLdiyZQvS09MRHh5u1rUa4mz39MEnFOHh4SgoKEBxcbHOeO6cnByEhYVZPJiJjOFs33cPYjbUYjbYzz1lNpC9c7bvuQdZOxcA57unzAZmgyNjAcoGPD09ER0djcuXL2ur2Y0JDg7G3/72N+zatQuXL1826XoxMTG4dOkSunbtColE0uB+rq6uqKqqMuncdeRyOe7cuYOCggKdinhWVhZCQkLMOqexnOF+njx5Et7e3tof0MuXL9c7du7cuYiOjsZLL70EuVxuUptN5ej3tLy8HIcOHdJp+8CBAyEWi7F792688MILAICysjJkZGTgueeeM6m9REJw9O+7+jAb9DEbjMdsoObO0b/n6mPLXACc454yG5gNjowFKBt58803MWXKFPzjH//AqFGjIJPJcPv2bfzwww/4y1/+gr59++Jf//oXZDIZoqOjIZPJ8Msvv+D8+fPabwJj1Y1znTZtGp5//nkEBgYiPz8fJ06cQJ8+fTB69GgAQIcOHXDgwAH06dMHHh4eCAsLg7e3N7Kzs5Gdna0938WLF7Fnzx54eHhgyJAhAICxY8dizZo1mD59OqZPnw6ZTIb9+/fj4MGDeOeddyx23xriKPfz+vXrWLp0qbabbHl5OQ4ePIitW7fin//8J1xcar8lo6Oj9a7r7u6O4OBg9O3bt8n3yxiOck/Pnz+PdevWYcSIEZDL5cjLy8P//d//4e7du1i1apX2GsHBwZg4cSKWLl0KFxcXyOVyfPHFFwCAKVOmWO7GETWBo3zfMRv0MRvs654yG8hZOMr3nKPkAuA495TZUD9mg2NjAcpGevXqhX//+9/48MMPsWDBAiiVSrRq1Qr9+vVDaGgoAKBnz57YsmULvv76a1RUVKBt27ZYsGCByVXX0NBQfP3111i5ciXeffddlJeXIygoCA8//DAiIiK0+/3rX//C+++/j+nTp6OyshJffvkl+vbti927dyMlJUW7X1paGtLS0hASEoKMjAwAQKtWrbBhwwasXLkSiYmJKC8vR2hoKBITE/Hss89a4I4Z5ij3Mzw8HDKZDB9//DHu3r0LHx8fdOjQAR999FG9XVZtyVHuaatWrVBdXY3ly5ejuLgYHh4e6NmzJ959913t5Ih15s+fD09PT6xcuRKlpaWIiopCamoqgoKCmn7DiCzAUb7vmA36mA32dU+ZDeQsHOV7zlFyAXCce8psqB+zwbGJNJzKnYiIiIiIiIiIBMTZs4iIiIiIiIiISFAsQBERERERERERkaBYgCIiIiIiIiIiIkGxAEVERERERERERIJiAYqIiIiIiIiIiATFAhQREREREREREQmKBSgiIiIiIiIiIhIUC1BERERERERERCQoFqCIiIiIiIiIiEhQLEAREREREREREZGgWIAiIiIiIiIiIiJBsQBFRERERERERESC+v8B6qimWh1ZBBAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x240 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = list(range(len(models)))\n",
    "x_fair = [-0.15, 0.85, 1.85]\n",
    "x_acc = [0.15, 1.15, 2.15]\n",
    "color = \"C0\"\n",
    "\n",
    "bps = list()\n",
    "\n",
    "acc_axs = list()\n",
    "f, axs = plt.subplots(1, 3, figsize=(12, 2.4), sharex=True)\n",
    "\n",
    "bps.append(axs[0].boxplot(fair_spds, positions=x_fair, widths=0.3, boxprops=dict(color=color), flierprops=dict(markeredgecolor=color)))\n",
    "axs[0].set_ylabel(\"SPD\", color=color)\n",
    "acc_axs.append(axs[0].twinx())\n",
    "bps.append(axs[1].boxplot(fair_eods, positions=x_fair, widths=0.3, boxprops=dict(color=color), flierprops=dict(markeredgecolor=color)))\n",
    "axs[1].set_ylabel(\"EOD\", color=color)\n",
    "acc_axs.append(axs[1].twinx())\n",
    "bps.append(axs[2].boxplot(fair_aods, positions=x_fair, widths=0.3, boxprops=dict(color=color), flierprops=dict(markeredgecolor=color)))\n",
    "axs[2].set_ylabel(\"AOD\", color=color)\n",
    "acc_axs.append(axs[2].twinx())\n",
    "\n",
    "for ax in acc_axs:\n",
    "    bp = ax.boxplot(fair_aurocs, positions=x_acc, widths=0.3, boxprops=dict(color=\"C1\"), flierprops=dict(markeredgecolor=\"C1\"))\n",
    "    plt.setp(bp['whiskers'], color=\"C1\")\n",
    "    plt.setp(bp['caps'], color=\"C1\")\n",
    "    plt.setp(bp['medians'], color=\"C1\")\n",
    "for i, ax in enumerate(axs.flatten()):\n",
    "    ax.yaxis.grid(False)\n",
    "    ax.set_xticks(x)\n",
    "    if i >= 3:\n",
    "        ax.set_xlabel(\"Model\")\n",
    "    ax.set_xticklabels(models)\n",
    "\n",
    "for ax in acc_axs:\n",
    "    \n",
    "    ax.yaxis.grid(False)\n",
    "    ax.yaxis.set_major_formatter(FuncFormatter(lambda x, _: f\"{x * 100:.1f}\"))\n",
    "    ax.set_ylabel(\"Accuracy\", color=\"C1\")\n",
    "    ax.set_xlim(-0.4, 2.4)\n",
    "\n",
    "for boxplot in bps:\n",
    "    # Set the color of the whiskers, caps, and medians to match the box color\n",
    "    plt.setp(boxplot['whiskers'], color=color)\n",
    "    plt.setp(boxplot['caps'], color=color)\n",
    "    plt.setp(boxplot['medians'], color=color)\n",
    "\n",
    "f.tight_layout()\n",
    "plt.savefig(os.path.join(PLOTS_PATH, f\"compare_models_absolute_chexpert_pa{pa}.pdf\"))\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "quam",
   "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.10.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
