{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "dfb5f10d-85f3-4545-baa7-80139855cbac",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "import matplotlib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "from typing import List\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from scipy.interpolate import griddata\n",
    "from matplotlib import cm\n",
    "import matplotlib.colors as mcolors\n",
    "matplotlib.rcParams[\"legend.framealpha\"] = 1\n",
    "matplotlib.rc('font', **{'size': 20})\n",
    "from matplotlib.colors import ListedColormap\n",
    "from display_plot_utils import display_pcp_fail_results, read_methods_results, process_methods_df, methods, method_to_error_type, \\\n",
    "    color_palette\n",
    "\n",
    "plt.rcParams['text.usetex'] = True\n",
    "\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b0b91ca8-072d-41f5-9bd9-3ab8c59281f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_base_path = '../src/results'\n",
    "paper_figures_path = 'figures/paper_figures'\n",
    "figure_path = paper_figures_path\n",
    "seeds = 30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0cd6f58e-e880-4a88-94fb-d79b6977eafb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "corruption type: missing_y\n"
     ]
    }
   ],
   "source": [
    "total_df = pd.DataFrame()\n",
    "original_dataset_names = ['nslm']\n",
    "# original_dataset_names = [ 'meps_19']\n",
    "corruption_type = 'missing_y'\n",
    "print(f\"corruption type: {corruption_type}\")\n",
    "\n",
    "\n",
    "dfs = []\n",
    "for dataset_name in [f\"{corruption_type}_{d}\" for d in original_dataset_names]:\n",
    "    methods_to_keep = ['naive', 'pcp xgb', 'full + linear', 'pcp oracle', 'weighted']\n",
    "    methods_to_exclude = ['Naive CP (only clean)', 'kmean clustering'] # ['nn errors', 'cvae errors', 'oracle',  'use z=true']\n",
    "    def keep_method(method_name):\n",
    "        return any([a in method_name for a in methods_to_keep]) and not any([a in method_name for a in methods_to_exclude])\n",
    "    try:\n",
    "        data_df = read_methods_results(results_base_path, dataset_name, methods, apply_mean=False, seeds=seeds,\n",
    "                                      display_errors=False)\n",
    "        data_df = process_methods_df(data_df)\n",
    "        data_df['Dataset'] = dataset_name.replace(f\"{corruption_type}_\", \"\").replace(\"meps_19\", \"meps19\")\\\n",
    "                                            .replace(\"facebook_1\", \"facebook1\").replace(\"facebook_2\", \"facebook2\")\n",
    "        data_df = data_df[data_df['Method'].apply(keep_method)]\n",
    "        # data_df['y2 length'] -= data_df['y2 length'].min()\n",
    "        # data_df['y2 length'] /= data_df['y2 length'].max()\n",
    "        dfs.append(data_df)\n",
    "    except Exception as e:\n",
    "        print(f\"data: {dataset_name}, error: {e}\")\n",
    "total_df = pd.concat(dfs) \n",
    "original_total_df = total_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "48283d23-f084-407d-ae33-41043019a68f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABPkAAAFYCAYAAAAhoSntAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAXJpJREFUeJzt3X98W/Wd5/u34kD4YR+7hbah8SED7YzBcoZtp9mple5lp6TYzt3dmTolMjNlNgY74e52IzrYj7ndYsM47PZ2bDp1lp2tY4MzS1uitONZHjNNJAjsdreRp83s9NJYoty20OSYQltobdkUSIl1/zDncGRLtmzrWJb8ej4eeUQ/vjr6SJaOvudzPt/v15dKpVICAAAAAAAAULQ2FDoAAAAAAAAAACtDkg8AAAAAAAAociT5AAAAAAAAgCJHkg8AAAAAAAAociT5AAAAAAAAgCJHkg8AAAAAAAAociT5AAAAAAAAgCJHkg8AAAAAAAAochsLHQDmS6VSmplJFToMAAAAAAAAFNCGDT75fL6c2pLkW4NmZlL6xS9eLXQYAAAAAAAAKKB3vvNylZXlluRjuC4AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEVuY6EDAAAAALC6XnhhXNPT04UOA3lSXl6uLVuqCx0GAKDASPIBAAAA68jExIRuvbVZMzMzhQ4FeVJWVqbHHouqqqqq0KEAAArIl0qlUoUOAukuXJjRL37xaqHDAAAAQIlaD5V8Z88+r56eLnV3H9TWrdcUOhxPUckHAKXrne+8XGVluc22RyUfAAAAsM6sp4TQ1q3XqKbmukKHAQCA51h4AwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyJPkAAAAAAACAIkeSDwAAAAAAAChyGwsdAAAAAAAAWH9eeGFc09PThQ4DeVJeXq4tW6oLHca6tupJvunpaU1MTKi6mj88AAAAAADr0cTEhG69tVkzMzOFDgV5UlZWpscei6qqqqrQoaxbq5Lke+ihhxSLxRSLxSRJPp9PiUQirU0ikVBXV5fGx8f1V3/1V7ruuutWIzQAAAAAALDKqqqq9OijIyVfyXf27PPq6elSd/dBbd16TaHD8VR5eTkJvgLzNMn3+OOPq6urS8lkUpKUSqWytq2trVUqldLk5KRCoZCi0aiXoQEAAAAAgAJaT0M7t269RjU1FDPBW54tvHHs2DGFQiElk0mlUilVVFSotrZ2wcfs27dPknTu3DmNjo56FRoAAAAAAABQUjxJ8lmWpe7ubqVSKaVSKR08eFDf+c531NnZueDjGhsbZRiGJCkSiXgRGgAAAAAAAFByPEnyhcNhSbNz7w0PD+uWW27J+bF1dXVKpVIaHx/3IjQAAAAAAACg5HiS5ItGo/L5fKqtrVV9ff2SHmuvujs2NuZFaAAAAAAAAEDJ8WThDcuy5PP5VFdXt+xt2It1AAAAAKvlpZde0uTkRKHDQB6cPft82v8ofpWVVdq8eXOhwwCANcuTJJ9hGJqamtLk5OSSH2tX8Jmmme+wAAAAgKxeeukl/eEf7db5N94odCjIo56erkKHgDy5eNMmffUrf02iDwCy8CTJV11drUQiseQVci3LUiKRcIb6AgAAAKtlcnJC5994Q7/xwY/r0oorCx0OAJfXpl7Wj//xbzQ5OUGSDwCy8CTJFwwGde+99yqZTOq+++7Tfffdl9PjQqFQ2jYAAACA1XZpxZW6rOqqQocBAACwJJ4svBEMBlVRUSFpdqXdT3/60wu2Hx8f1+7du9Oq+Ja6YAcAAAAAAACwXnlSySdJR44c0e7du+Xz+RSJRBSJRBQIBJz7R0dHlUgkdObMGUWjUed2wzDU39/vVVgAAAAAAABAyfEsyef3+/Xwww8rFAppampKkhSLxeTz+SRJt99+u9M2lUpJmk3wDQ8Pq7q62quwAAAAAAAAgJLjyXBdWyAQ0OnTp3XHHXdImk3mZfonSXv27NGTTz7JghsAAAAAAADAEnlWyefW2dmpO++8UydOnNDY2JjGx8clSRUVFdqxY4eampqcOfwAAAAAAAAALM2qJPmk2YTenj17tGfPntV6SgAAAAAAAGBd8HS4LgAAAAAAAADveVLJ99BDD+nMmTPasWOHbrnllhVta3x8XJZlyTRNFuQAAAAAAAAAMvAkyTcwMKCpqSlt27Zt2dsYHR3VvffeK8uynNsCgYD6+/tVXl6ejzABAAAAAACAkuDJcF274s4wjGU9PhqN6vbbb5dlWWmr8MZiMe3evTufoQIAAAAAAABFz5Mkn2maK3p8V1eXUqmUcz0QCMgwDKVSKZ07d05f+MIXVhoiAAAAAAAAUDI8SfIFAgGlUiklk0k988wzeuCBB7R7927dfPPNuuuuu/S1r30t62OPHTumZDLpXH/iiSf08MMP6zvf+Y5qa2uVSqUUDoe9CBsAAAAAAAAoSp4k+Xbt2iVJOnz4sJqbmzU0NKREIiHLshSNRtXd3a1PfOITeuGFF+Y9dmxsTJLk8/nU1taWVhV45MgRSVIymVwwUQgAAAAAAACsJ54k+SoqKmSapiYnJ9Pm1HP/GxsbU3Nzs6anp9MeOzo66ly2k4U2wzAUCAQkSadOnfIidAAAAAAAAKDoeJLks6v2fD6fTNNUf3+/nnjiCZ0+fVrDw8Pas2ePpNmKvK6urrTHulfTzTS3nz0U2N0OAAAAAAAAWM82erHRgYEBSbOVd0888UTaffX19aqvr5dpmnrggQcUiUR08OBBlZeXz9tOptvsxN/4+LgHkQMA4K0XXhifV8WO4lZeXq4tW6oLHQYAAADWOU+SfIlEQj6fT/v27cvapr29XQ888IAk6cyZM6qvr89p24ZhSFLa4hwAABSDiYkJ3Xprs2ZmZgodCvKorKxMjz0WVVVVVaFDQZ68NvVyoUMAMAffSwBYnCdJPvdQ3YWYpqnx8fElVeXZw3QX2zYAAGtNVVWVHn10pOQr+c6efV49PV3q7j6orVuvKXQ4nisvLyfBV2J+/I9/U+gQAAAAlsyTJJ+dvBsbG9PNN9+csc3U1JSTDKyrq8t52+fOnXOeAwCAYrOehnVu3XqNamquK3QYwJL9xgc/rksrrix0GABcXpt6mQQ8ACzCkyRffX29jh07pnA4rGAwqC1btsxrc8899ziXr7/++ozbmZ6enjcvXzQalc/nU3V1bgdJlmXp6NGjikajmpyclCTV1dWpvb3dWal3MclkUgMDA0okEjJNUxMTE5KklpaWnLcBAACA4nBpxZW6rOqqQocBAACwJJ4k+To7O3Xs2DElk0nt3LlT7e3tqqurU0VFhRKJhI4fP+7M29fW1uY87tixY5Ikn88nSRodHdXHPvYx5/7R0VGn+q+lpWXROAYHB9XX16e2tjaNjIw48/lFIhGFQiE1NTWpp6dnwW3EYjGFQiEdPHhQnZ2dzu2WZSkUCqmurm7RbQAAAAAAkIuXXnpJk5MThQ4DeXL27PNp/6P4VVZWafPmzYUOIyNPknwVFRX64he/qLvuuks+n0+Dg4Pz2qRSKUmziT3LsmRZlpP4S6VS8vl8uueee1RRUaEPf/jDGh0ddbZnmmbW6j+bneDr6elRMBhMu6+xsVGmaaq5uVkVFRVpyTu3eDyu1tZW9ff3q7GxMe0+0zR15MgR3XTTTQtuAwAAAACAXLz00kv6wz/arfNvvFHoUJBnPT1dhQ4BeXLxpk366lf+ek0m+jxJ8kmzibSHH35Yd911V8aVcAOBgCoqKhSNRhWJRObdF4vFlEwm1dra6txuJ/86OjoWfG7LstTX1ye/3z8vwWfz+/1qaGjQ0NCQdu3aJb/fP69NKBSSaZrzEnw2wzC0b98+9fX1aceOHQzdBQAAAAAs2+TkhM6/8Ybe/y9/W5decXmhwwEwx2uvvKof/u33NDk5sb6SfNJssu473/mOotGozpw5I8uyZJqmdu3apdraWklyKvjs+2pra2WapgYHB/XAAw/M22ZbW1vWxTxsoVBIkrRv374F27W0tCgajWpgYECHDh1Kuy8Wi8myrEUTisFgUH19fRocHCTJBwAAAABYsUuvuFzlmysLHQaAIuNpks/W0NCghoaGjPeZpplxpdz29nb5/X4NDQ1pbGxM1dXV2r9/f9bt2CzLUjwel6SM1Xlu9qq+0WhUyWTSmbNPkjPEeLFtGIYhwzCcykP3NgAAAAAAAIDVsCpJvuUKBAJLro6LxWLO5crKhc982Am6ZDKpWCyWNizX3k6mBORcpmkqHo/P2wYAAAAAAACwGjYUOoB8O3funHM5l6o6O4l35swZ5za7EtB9/0Kqq6vnbQMAAAAAAABYLSWX5Fsqu9ovkUg4t1mWJSm3JKEkVVVVzdsGAAAAAAAAsFrW9HDd5bATbpJymiNvcnIy7f+5l3NRUVEh6e3k4EqlUinNZFsyfYNPGy662LmatZ0k+XzacLEHbSVt2LRpeW3Pn5dSqfy3/fV5aSY/bX0XXyyfz/dW219LMzP5aXvRRfJtmM2rp958U6kLF9Z2240b5SsrW3rbCxeUevPN7G3LyuTbuHHpbWdmlPr1r9d0W23YoA0XXTTbNpVS6vz5PLVdwveefUTmtuwj8t92oX3E+fO62OeTzp/XzBtvsI+wsY94O4y1uo9467P7ZvJn+nXq7c/0r31lzuWy1Iw2KPt2f60N0lvfe6/abkjNqCxPbd/UBqXWUFtfKqWNyr6vvCCfZnwb1kxbpVK6KE9tZ+TTBa/bSroolX3fvpS2KUlvur4bS2m7MXVBviW2fXPqlbTfFlvJ9SPe2g9tvJCajc/+Hl1IacMC8b5Z5nu77UxKGxaIYSltL5T53v4uL6GtbyalsoXabvAptWENtU2lVHYhe9uZDT7NLKOtUqnZv2U+2vp8minLf9uUz6cLZW9/Ize+mX1/slpty96cWXAfcWHjhuW1vZCSb6HvUQ5tN15Ize6LXLzeR6RSl2VtPy++nFuuwPj4uBKJxJKGs27btm3RVXQzWeocfnZiLplMOre5Ly/FUpOD2bz58sv64b/9NxnvK//tG3T1n9ztXH/m3/y7rB3/y2qu02985t8715/9dIcuTE1lbHvJNdfo2nv/zLn+gz/9rH79yssZ22567xa97z9+zrn+o+4evfGTFzK2veiKK/WbD3zBuf7cf/icXn/++YxtyyoqVPOf/rNz/ce9X9Cvnv1+xra+iy/W9YeHnOvnDv1nTX/v6YxtJan2yH91LltfGtTUP5zO2va6gUHnS/jC8F9p8tS3srb9rUMPauNbieQXv3pUv3zqyaxt39/7gC5617skST/9+l/rlciJrG2v/Q//UZdsmR0G/rO//Tu9/Nh/y9r2mu77dOm110qSXn78Cf3sWDhr261/+hldfv31kqRf/I//qZe+/F+ztjXv+hNV/JN/IkmaGP22fvLQYNa21f/mUzL+6T+VJCX/8R80/pcPZm373jvaVfXP/pkkaWrse7K++IWsbTd/8o/1zp07JUmvPvOszn7+c1nbvntPUFfu+j8lSa8992M933Nf1rZX/v4f6N0fb5Ykvf7CT/TcZ/991rZXNDbpPS23SpLO//wV/bDz7qxt3/HRm3TVH/9rSdKbyaR+cOBTWdtW7viItrTPrgA+88Yb+v6/3Z+1bcWHtsv81L9zrifasrdlHzGLfcTbCrGP8En6Uo1f6v+Cfij2ETb2EbPW8j7C+ey+9qPZf2+5/ftjzuX/672mthvZ532+89m4zr91UHD7VVv0kcp3ZG0b+sEzmnorQf7J91ylj77jiqxtO3/0rF55K4l8y7veo6Yr3pW17T3P/UA/OT+bBPn9K9+t37/y3Vnb9vz4R/rx669JkhrfeaX2vHtz1rafP/e8nv3Vq5Kkj1a9U5/c/N6sbb9o/Vjfe3VakrSjskp3XFWdte1fvnBO/zA12//+UIWhf7Pl6qxtH3pxXKcmJyRJv315ue4yfyNr2y+/9BM9NfELSVLNZZer4+prsrY99rOXFPnF7Gf2Ny65VN2/8b6sbR97+Wd67OWfSZLee/Em3X/tb2Zte+KVn+trP/+pJOmKiy5S7/tqsrZ96pev6Ms/fVGSVFFWpv7fvD5r229N/lIPvzj7vbnY55v93GZxOjmp//KTt4sRHr6uLmvbp6en1D9+1rn+X36rVps2ZB789f1fvao/P/f297H//depYmPmw8vnX/uVDp59zrn+5+/7LV3pOuHg9sIbr6vr+R861w9e835t2XTJ7BXXb4tUmv0IZz90elqPNFXo9U2zCc8Pj03I//yrWbf76Mc2a/ry2ff/Q4lJ3fDD6axtv/7R9+iXxuyJpH/ybFK/82zmfbsk/c2N79bL75j9W9X9aFq/G89+zPt3O67Ui++a/Vtd/+NXteN7E1nbRj58hazNl0qS3m/9Sv/8u7/M2vbk9nfq+S2zSY7fePE17Tz9i6xt/8cH3qEfbL1cklT9s9fV+PevZG176rerlLi2XJK0+eU39C9OZf7dkqRv+yv1vd+cLe65YuLX+vg3f5a17f+uqdA/Xj/7O/GOqTf1iad+mrXt0+8v13fqqiRJ5b+6oFufeClr2/g1lyt2w+xvyiXnZ3TbiReztv3/zMv0zd95p6TZpFTr3/0ka9vn3nupnvynb//+LNT23HsuUbT+Suf6J0+8qIuyJBB/csXF+sY/e/v3p+Xxl3Tp+cyJvp9XXaT/9s/f41y/5cmfquK1zCcOflmxUV+/6e3fqo9/82d6x1Tmk8JTl5bpaMNVzvV/+b9+pndNZD4h+9rFG/TlXW//rjXGfq73vpK5j/TGb16vsjKfNr6VFPR6H1E58JfauPk9WR/j5mmSb3x8XKFQaFnDWBsaGpaV5PP7/TJNU5ZlLboQhmVZTkLPnaCbmJiQtPjCHTZ39aDXLrqoTO94x+XOdZ/Pl/W86MYMbbPZWLYhre2GsuxtN5T5lt12Y1n2EeI+X3rb8YvKcm774gJtJaW1/enFC3/sq6ouU9klsz9OL29avO1FlbPb/sWmixZsW1l5mS55K46JSxZpa1yqy95qO3Vp5g6QrcK4VBVvtX11sbYVl6jyrbavX7Zw2/KKS5z37fzlC7e9vHyT0/ZC+aYF2152+cVO21TFJQu3veztthsWaXvppW+33WhcmnPbX00t3HbTJRc5bV8/n71jJUmbNr3d9tcbslcfzbbd+PZ79vrCn9+LL96Y9hleCPuIzG3ZR7CPYB8xi31E5raL7SNGRkacy69+Naxfj8Wztn300Ufle6uq8dWvj+jX//j/Zm07PHxEG8rf+qw99nc6/+3vZG37pS99SWXvmD24e+1EVG/8r1NZ2/b396vsPbMHVq+dfEpvPPU/srb98z//c22s3iJJev1/fkuvRx7P2ranp0cXXTubKHtj9Nt67W+/kbXtZz/7WV103WxC643//V299td/k7VtR0eHLt42m3g6f2ZMv3r0WNa2n/rUv9Pdv/MBSdKvv/+sXv2vX8na9g8+/nE9NfyQent7dbVvg14dGs7a9o//+I+17//4iCTpzfEXNP2XA1nb7tmzR/9650clSRd++jNN9Wc/cfEHf/AHurWpYbbtL3+pqd6/yNq2sbFJzb//LyRJM9OvKvkfP5+17e/93u/pX3xi9mRE6vx5Td53f9a2gUBAH/vDoHN94t93Z237O7/zQY0cejvGiXsPSlkqlP1+v0a++IBzffL+/0epX/0qY9v3v//9GvmLvrfb/vkXlHrrmGsu0zQ18sCfO9eTX/xPmvnZzzO2XSv7CK/6EQDWLsO41Pnur6V9hC+VWqBWcQVGR0d1++23S5odZpJTMD6f07axsVFf/OIXl/XcsVhMra2tamho0KFDh7K26+3t1ejoqOLxuAzD0OnTp53bh4aGZJqmTp48uejzDQ4Oqq+vL20bK3HhzQuaeDnLGRKvhs4U+zCbPLZlKN5bbRmuu+S2ng3FWwvfe/YRDvYRb7VdYB/x7LPf1/79t2tg4GHV1FzHPsLGPsLBPmIZbdfC977I+hHP/vAHar3jj3XkyFdU81s17CPewj6isG0X+97bv6H+T/6uLnlvJcN1V6stw3Wd6wzXXbjt9E+Tin/52zo8/GVdd91sxbXX+4iqKytVtnHhRKLNs1MHoVAoLbkXCARUXV2tyclJRaNR+Xw+3XLLLZJmq+gsy1IikZDP51NDQ4OampqW/dyBQEANDQ2KRqOyLCvjCrn2MN3q6mrF4/Gcq/YymchyFmrZfD7NlGWv4phxfzkWaLcm225Y+CO3FtrqQkqy6xp8ZVLZAl+mpbSdketHfIO0wJnGNdE2JenN5bT1LfqZWF5bFUXbNfedK7a27CPsIIp6HzFTdpHOp1KaKbto9veMfYRjzX3niq0t+wg7iKLeRyzcNn/7iJm31hi8cCGlCzNiH7Ee2pbAPsL+DZ2aeHU2GQdgTXlt4lWdT6V04UJKb9rffa/3EQuMppjLkyRfX1+fksmkk8jr7Ox0FqeQpOuuu07SbMm/W29vrx566CFJs8N1V+LQoUPq7e1Va2urhoeH0xJ9lmWpt7dXhw4dUmtrq6TcV9JdyEoShQAAAAAASNIP/zb3+ewBwOZJks+eg880zXmJPGk2oTY1NaXx8XFVV789CW9nZ6ceeughRaPRefctR2dnp3bs2KHe3l5n3jzTNGUYhjOM156Lz/1cdtulLqSRj0QhAAAAAGB9e/+/3KZLrygvdBgA5njtlek1nYT3JMk3NjbmDLvNpLKyUlNTU7Isa14ir6GhQY8//rii0ajuuOOOFccSCAQWXHHXXnhjx44dzm121V+uq+xOvbXSHJV8AAAAAICVuvSKcpVv5vgSwNIsMDmGd2prayUp46q7pmkqlUopFoutSiz23Hx1dW8vJe8e2ptLos/eRqa5/wAAAAAAAACveZLksyvasiXItm3bljWRZz9mbGzMi9DSxONxSbPJOb/f79zuvpzLkF07yed+HAAAAAAAALBaPEny2dV42RJ19vDZWCym6enptPtGR0cl5T5UdiWOHz8uSWpvb593nx2jncBbiJ0IXMmKwAAAAAAAAMByeZLksxNkiURiXhJPmh2uay9S0dfX59x+7NgxJ6m2kkUsBgcHtX37doXD4QXbHTt2TKZpKhgMzruvsbFRknTq1KkFt2FZlpLJpAKBAAtvAAAAAAAAoCA8SfK5k2aHDx/O2OaWW25RKpVSOBzWzTffrN27d+vee++Vz+eTz+dTfX39sp//xIkTSiaTCyb5ent7lUwmM67+a78GwzAUjUYXfK6jR49Kkjo6OpYdLwAAAAAAALASniT5KioqtGfPHqVSKUUikYzVfJ2dnaqoqJA0Ww1nL8KRSqVkGMaKkmZ1dXUKBAI6ePBgxvsjkYiGhobU09Oz4Mq7/f39sixLg4ODGe+3LEtDQ0MKBoPMxwcAAAAAAICC8Wx13Z6eHn3/+9/X448/rvLy8oxtRkZGtGXLFqVSKedfIBDQ17/+dVVXVy/7uTs6OjQ5OTlvPj3LstTd3a2uri719/dnHKbrFggENDw8rMOHD8+rCrQsS62trQoGg1mrAQEAAAAAAIDVsLGQT26apk6ePOkstlFXV+dU962EYRg6cuSIBgYGnDn/JicnVVlZqWAwqCeffDLn+fMCgYBGRkZ09OhRtba2yjRNTUxMSNKilYAAAAAAAADAaihoks+2kvn3sjEMQ52dners7FzxtkzTzMt2AAAAAAAAAC94kuS79957NTk5qauvvlp/8id/4sVTAAAAAAAAAHiLJ0m+WCwmy7Lk8/lI8gEAAAAAAAAe82ThjdraWufy+Pi4F08BAAAAAAAA4C2eJPlaWlqcy0NDQ148BQAAAAAAAIC3eJLkq6+vV21trVKplMLhsP7+7//ei6cBAAAAAAAAII+SfJJ05MgRVVRUKJVKqbW1VV/72te8eioAAAAAAABgXfNk4Q1JMgxDIyMj2r17t5LJpLq7u3X06FHt2rVLtbW1Mk1z0W1UV1d7FR4AAAAAAABQMjxJ8jU3N+uZZ55xrvt8PqVSKcXjcSUSiZy24fP5cm4LAAAAAAAArGeeVfKlUilJs8k69//u+wAAAAAAAACsnCdJvsrKShmGsaJtuJOCAAAAAACsF6+98mqhQwCQwVr/bnqS5BseHvZiswAAAAAAlKzKyipdvGmTfvi33yt0KACyuHjTJlVWVhU6jIw8G64LAMBSvPTSS5qcnCh0GMiDs2efT/sfpaGyskqbN28udBgAUNI2b96sr37lr+kTlZCzZ59XT0+XursPauvWawodDvJgLfeJSPIBAArupZde0h/9YbPeOH++0KEgj3p6ugodAvJo08UX6ytfHVmznVoAKBWbN29mX1uCtm69RjU11xU6DJS4VU/yTU9Pa2JiQtXV1av91IBeeGFc09PThQ4DeVJeXq4tW9iXlILJyQm9cf68Pra1Qu+4pKzQ4QCY45evX9ATZ6c0OTnBgScAAMAatSpJvoceekixWEyxWEzS7KIaiUQirU0ikVBXV5fGx8f1V3/1V7ruOjLcyK+JiQndemuzZmZmCh0K8qSsrEyPPRZVVVVVoUNBnrzjkjK9+7KLCh0GAAAAABQdT5N8jz/+uLq6upRMJiVJqVQqa9va2lqlUilNTk4qFAopGo16GRrWoaqqKj366EjJV/KtpzkfysvLSfABAAAAACAPk3zHjh3TvffeK2k2uWcYhqqrq+dV8Lnt27dPd911l86dO6fR0VHV19d7FR7WqfU0tJM5HwAAAAAAWD82eLFRy7LU3d2tVCqlVCqlgwcP6jvf+Y46OzsXfFxjY6MMw5AkRSIRL0IDAAAAAAAASo4nSb5wOCxpdu694eFh3XLLLTk/tq6uTqlUSuPj416EBgAAAAAAAJQcT5J80WhUPp9PtbW1Sx5ya6+6OzY25kVoAAAAAAAAQMnxZE4+y7Lk8/lUV1e37G3Yi3UAAAAAyK8XXhhfF4uRuf8vZeXl5etq7mkAQGaeJPkMw9DU1JQmJyeX/Fi7gs80zXyHBQAAAKx7ExMTuvXWZs3MzBQ6lFXR09NV6BA8V1ZWpscei6qqqqrQoQAACsiTJJ+9iu7o6OiSHmdZlhKJhDPUFwAAAEB+VVVV6dFHR0q+km89KS8vJ8EHAPAmyRcMBnXvvfcqmUzqvvvu03333ZfT40KhUNo2AAAAAOQfQzsBACg9niy8EQwGVVFRIWl2pd1Pf/rTC7YfHx/X7t2706r4lrpgBwAAAAAAALBeeVLJJ0lHjhzR7t275fP5FIlEFIlEFAgEnPtHR0eVSCR05swZRaNR53bDMNTf3+9VWAAAAAAAAEDJ8SzJ5/f79fDDDysUCmlqakqSFIvF5PP5JEm333670zaVSkmaTfANDw+ruprhAwAAAAAAAECuPBmuawsEAjp9+rTuuOMOSbPJvEz/JGnPnj168sknWXADAAAAAAAAWCLPKvncOjs7deedd+rEiRMaGxvT+Pi4JKmiokI7duxQU1OTM4cfAAAAAAAAgKVZlSSfNJvQ27Nnj/bs2bNaTwkAAAAAAACsC54M152envZiswAAAAAAAAAy8CTJt337dt1xxx164oknvNg8AAAAAAAAABdPhuumUinFYjHFYjFJUmNjo/bs2aP6+novng4AAAAAAABY1zybk89eNVeSIpGIIpGIDMNQMBjUnj17VF1d7dVTAwAAAAAAAOuKJ0m+J554QpFIRMeOHZNlWU7Cb3JyUoODgxocHJRpmmppadGePXtUXl7uRRgAgCLzy9ffLHQIADLguwkAALD2eZLkM01T7e3tam9vVyKR0De+8Q197WtfUzKZdBJ+lmWpt7dXvb29CgQCamlp0cc+9jEvwgEAFIknzrJwEwAAAAAsh2fDdW21tbWqra1VZ2enRkdHdeLECUUiESWTSacN8/cBACTpY1vL9Y5LPP9pArBEv3z9TZLwAAAAa9yqHknV19ervr5ePT09WRN+7vn7vv3tb69meACAAnvHJRv17ssuKnQYAAAAAFB0ClYuMTfhd+rUKcViMSUSCUlKS/wBAAAAAAAAyG5DoQOQpG3btmnr1q0yTVOGYRQ6HAAAAAAAAKCoFKySb3x8XOFwOK16DwAAAAAAAMDSrWqSb3p6WuFwWOFwWJZlObfbK+5KsyvzBoNBBYPB1QwNAAAAAAAAKFqeJ/mmp6d14sQJHT16NK1iz53YMwxDjY2NamlpUW1trdchAQAAAAAAACXFsyTf448/7gzHtbkTe5LU0NCglpYW1dfXexUGAKCI/PL1C4UOAUAGfDcBAADWPk+SfNdff71zeW5iLxAIqLGxUXv27PHiqbFML730kiYnJwodBvLg7Nnn0/5H8ausrNLmzZsLHYanKiurtOnii/XE2alChwIgi00XX6zKyqpChwEAAIAsPEnypVIp+Xw+J8HnnmevoqLCi6fECrz00kv6oz/crTfOv1HoUJBHPT1dhQ4BebLp4k36ylf/uqQTfZs3b9ZXvjrCyYYScfbs8+rp6VJ390Ft3XpNocNBnqyHEw4AAADFzLPhuhUVFcyzVyQmJyf0xvk39Mn3/abefemlhQ4HgMvPXntNX/7RDzQ5OVHyB9ebN28u+de43mzdeo1qaq4rdBgAAADAuuBJkm94eJh59orQuy+9VObl5YUOAwAAAAAAAEu0wYuNkuADAAAAAAAAVo9nw3WzmZ6e1sTEhKampmSapsrLqRwDAAAAAAAAVmJVknzT09MaGBhQNBqVZVlp9xmGoaamJnV0dJDwAwAAAAAAAJbBk+G6btFoVNu3b9fQ0JAsy1IqlUr7Nzk5qXA4rO3bt+vhhx/2OhwAAAAAAACg5Hia5HvggQd01113pSX1MrHv6+3t1X333edlSAAAAAAAAEDJ8Wy4bjQa1eDgoHw+nySpoaFBLS0tqqurU0VFhSTJsiwlEgkNDAwokUgolUopHA7L7/frlltu8So0AAAAAAAAoKR4kuSbmppSV1eXc314eDjjirumaco0TTU0NCgcDuvee+9VKpVSd3e3mpqamKMPAAAAAAAAyIEnw3XD4bCSyaR8Pp/uvvvujAm+uYLBoO644w7n+rFjx7wIDQAAAAAAACg5niT5jh8/Lml25dy2tracH9fZ2elc/sY3vpH3uAAAAAAAAIBS5Mlw3fHxcfl8vpwq+Oaqra1VIpHQ+Pi4B5EBAAAAAIC14IUXxjU9PV3oMDx19uzzaf+XsvLycm3ZUl3oMNY1T5J89lDdysrKJT/WNE0lEgklk0kPIgMAAAAAAIU2MTGhW29t1szMTKFDWRU9PV2LNypyZWVleuyxqKqqqgodyrrlSZLPNE2Nj48vqxovkUhImh3qCwAAAAAASk9VVZUefXSk5Cv51pPy8nISfAXmSZKvtrZWlmUpFotpeno651VyLcuSZVnLHuoLAAAAAACKA0M7gfzyZOGNYDDoXO7qyr0kNRQKOZd37dqV15gAAAAAAACAUuVJJV8gEFBtba2eeeYZRSIRSdLBgwezVvSNj48rFAopkUjI5/PJNE3dfPPNXoSGBfz0tV8VOgQAc/C9BAAAAADkwpMknyT19/dr9+7dmpqaUiQSUSwWU2Njo3bs2KGKigpNTU3pzJkzSiQSisVi8x6L1feVH/2w0CEAAAAAAABgGTxL8pmmqeHhYe3du1dTU1NKJpM6duyYjh07Nq9tKpVyLj/88MO6/vrrvQoLC/ij971f77n0skKHAcDlp6/9igQ8AAAAAGBRniX5JMnv9+upp57SZz/7WT3++OMLtg0EAvqzP/szmabpZUhYwHsuvUzm5bktkgIAAAAAAIC1w9MknyRVVFTo0KFDsixL0WhUsVhMlmU59wUCAe3atUu1tbVehwIAAAAAALAqLly4oKef/q5eeeVlXXHFlbrhhg+orKys0GGhhHme5LOZpqm2tja1tbWt1lMCAAAAAACsum9+8yk9+OAX9eKLP3Fuu+qq9+pTn7pLN9740QJGhlK2odABAAAAAAAAlIpvfvMp3XPPn+raa9+nL31pWI8//j/1pS8N69pr36d77vlTffObTxU6RJQoknwAAAAAAAB5cOHCBT344BcVCHxEn/vcA6qr26bLLrtMdXXb9LnPPaBA4CN68MF+XbhwodChogQtKcn3zDPP6JlnnvEkkKGhId1xxx36xCc+oenpaU+eAwAAAAAAwCtPP/1dvfjiT3Tbbbdrw4b0lMuGDRt0222tevHFF/T0098tUIQoZUtK8h04cEDNzc26/vrr9dBDD+U1kEAgoFOnTikej6urqyuv2wYAAAAAAPDaK6+8LEm69tr3Zbzfvt1uB+RTzkk+y7JkWZZSqZQkKRgM5jWQ2tpa3XzzzUqlUopEIhofH8/r9gEAAAAAALx0xRVXSpKee+5HGe+3b7fbAfmUc5IvHA5Lknw+n9ra2lReXp73YO688855zwcAAAAAAFAMbrjhA7rqqvfqkUce1szMTNp9MzMzeuSRYV111RbdcMMHChQhStnGXBsmEgnn8v79+z0Jpra2VoZhaGpqSrFYTHfffbcnzwMAAAAAAJBvZWVl+tSn7tI99/yp/u//+2797u/Wa9OmTXrjjTf07W+PanT0W7r//s+rrKys0KGiBOWc5JuYmJAkmabpSRWfra6uTrFYLC2pCAAAAAAAUAxuvPGjuvXWTyoc/qpisf/l3F5WVqZbb/2kbrzxowWMDqUs5yTf+Pi4fD6fTNP0Mh5VV1d7un0AAAAAAACvfPObT+nRR7+s+vod+t3f3aFLLtmk119/Q9/+9ik9+uiX5fdvI9EHT+Sc5Esmk/L5fKqoqPAynjTT09Mrrhq0LEuDg4MaGxtTMpmUNFuN2NjYuOjiIeFwWKdOnVJnZ2fW5GYsFtPg4KDa29sVCARWFCsAAAAAACheFy5c0IMPflGBwEf0uc89oA0b3l4K4eMf363PfOZuPfhgvz7ykRsZsou8yznJZ8+VZ1mWl/FocnLSubzSBF9vb69GR0fV0dGhnp4e5/Z4PK6+vj4NDg6qv79ffr8/4+OTyaSi0aii0aj8fr/q6+t19dVXq7KyUmfOnFE0GpVlWQoGgyT4AAAAAABY555++rt68cWf6N57/0Nagk+SNmzYoNtua9Wdd96up5/+rj74wQ8VKEqUqpyTfNXV1UokEhofH/cyHieJaBjGirYzODioqakpjYyMzLvP7/dreHhY4XBYe/fu1cjIyKLDkOPxuOLx+LzbOzo61N7evqJYAQAAAABA8XvllZclSdde+76M99u32+2AfMo5yVdXV6dEIqFkMqlnnnlG119/fd6DmZqaUiKRkM/nW9HcfPF4XOFwWCdPnlywXTAY1KlTp9Td3a3h4eGMbRoaGpwKRsuyZBiGTNNUfX299u/fv+Jk5Frys9deK3QIAObgewkAAAAUjyuuuFKS9NxzP1Jd3bZ59z/33I/S2gH5lHOSr6mpSceOHZMkHT58WH/xF3+R92AGBgacyy0tLcveTjgcznn47K5duxQKhRa8v7GxcdmxFIPKyiptuniTvvyjHxQ6FAAZbLp4kyorqwodBvLkhRfGNT09XegwPHX27PNp/5e68vJybdnCwmEAAEC64YYP6Kqr3qtHHnl43px8MzMzeuSRYV111RbdcMMHChglSlXOSb76+npnXr5IJKJdu3bpYx/7WN4CSSQSGhoacq43NTUte1uWZeW8QIg9H18ymSypqryl2Lx5s77y1b/W5OREoUNBHpw9+7x6errU3X1QW7deU+hwkAeVlVXavHlzocNAHkxMTOjWW5s1MzNT6FBWRU9PV6FDWBVlZWV67LGoqqqqCh0KAAAosLKyMn3qU3fpnnv+VJ/5zN267bZWXXvt+/Tccz/SI48MKxb7lu6///MsugFP5Jzkk6S7775b9957ryTpwIEDGh4e1oc//OEVB/HMM8+otbVVkuTz+XT33XevaNGNiooKRaPRnBJ38XhchmGs2wSfbfPmzSQRSszWrdeopua6QocBwKWqqkqPPjpS8pV86015eTkJPgAA4Ljxxo/q/vs/rwcf/KLuvPN25/arrtqi++//vG688aMFjA6lbElJvmAwqEgkotHRUaVSKbW2tqqzs1O333774g/OIhqN6q677pI0m+AzTVNtbW3L3p4kbdu2TdFoVHv37tWRI0cWTOCFw2Ht2bNnRc8HAECuGNYJAABQ+m688aP6yEdu1NNPf1evvPKyrrjiSt1wwweo4IOnNizeJN2hQ4dUXV0tn8+nVCql3t5eNTQ06IknnljSdkZHR7V7927dddddSqVSSqVSMgxDDz/88FJDmicYDMowDMXjcd10002KRCIZ2w0ODsqyLHV2dq74OQEAAAAAAGxlZWX64Ac/pI99rFEf/OCHSPDBc0uq5JNmh8KOjIyoublZ4+PjkqSzZ8/qwIEDMgxDjY2NqqurU319vaqqqlReXq7p6WlNTEwokUjo1KlTikQiSiaTkqRUKiVJMgxDX//611e0qq7NMAz19/ertbVVyWRSoVBIgUBA/f39TlVfOBzWiRMnNDIyktM2w+Gw4vG4pNk5laamphQIBNTe3r7ieAEAAAAAAICV8KXsLNsSTU1N6bOf/awef/xxp6pPmh1yu5i5T2kn4HJdLCNX8XhcoVBIlmU5t3V0dOjMmTPatm3bogm6wcFBGYahc+fOadeuXc4iHbYDBw4okUhoeHhYpmnmLe4LF2aUTL6Wt+1hffn+95/R3r1/pCNHvqLrrru+0OEAAAAAAIBlMoxLVVaW20DcZSf5bLFYTH19fUokErMbfCvJl2mzc+8zTVMdHR1qaGhYSQiL6u7uVjgcdq77/f5F5+qTZpN8i1X77dy5U5OTkzp9+nTe4k2lUjklS4FM4vG4mpubNTIyMi8xDQBeu3Dhgv7hH/5BP//5z/Wud71LH/oQQ1MAAACA1bDiJJ8tkUjo6NGjaUNxMzEMQ/X19dq1a5fnyT1pNgk5ODioQCCgcDicVtXX39+vxsbGrI+1LEuVlZULJgMjkYhCoZDa2tryNrcflXxYCSr5ABTKf//vT+rQob/Qiy/+xLntqqveqwMHPq3f+72bChgZAAAAUJxWtZIvE8uyND4+rmQyqcnJSUmzVXvV1dV5Hda6mO7ubklST0+Pc1tvb6+Ghoac6w0NDTp06NCKnqempkaSdPr06UWrA3Nx4cKMfvGLV1e8HaxPzz77fd1xxyf10ENfVk3NdYUOB8A68c1vPqV77vlTBQIf0W233a5rr32fnnvuR3rkkYcVi31L99//ed1440cLHSYAAABQVN75zssLm+RbC5qbm1VfX5+xum7uXH0rTfTt3LlTlmWpo6MjLwtxkOTDSpDkA7DaLly4oJaWj+vaa9+nz33uAW3Y8HYnZGZmRp/5zN167rnndPToCEN3AQAAgCVYSpIvt1ZFxq7gyzZ81u/36+TJkwoGg5KkaDSqSCSy7Oezq/fOnDmz7G0AAFCsnn76u3rxxZ/otttuT0vwSdKGDRt0222tevHFF/T0098tUIQAAABA6Su5JF88Hlc4HNbBgwcXbdvT06OOjg5J0uHDh5f9nJWVlZKk8fHxZW8DAIBi9corL0uSrr32fRnvt2+32wEAAADIv5JL8oXDYRmGkfOqou3t7fL7/YrH485tyWRSzc3N2rlz54KLiNgqKiqWHS8AAMXuiiuulCQ999yPMt5v3263AwAAAJB/JZfksyxLdXV1S3qMPWzXTuidOHFC8XhclmUpFost+vipqSlJUnV19RKjBQCg+N1wwwd01VXv1SOPPKyZmZm0+2ZmZvTII8O66qotuuGGDxQoQgAAAKD0lVySr6KiwlnRN1f2cFt7bj3TNGUYhgKBgAKBwKKPHxsbkyTt2LFjidECAFD8ysrK9KlP3aVY7Fv6zGfu1tjY9/SrX72qsbHv6TOfuVux2Lf0qU+FWHQDAAAA8NDGQgeQb9u2bVM0Gl3SY2KxWFoyr66uTnV1dRoeHl70sZZlORWATU1NSwsWAIASceONH9X9939eDz74Rd155+3O7VddtUX33/953XjjRwsYHQAAAFD6Si7JFwwGdfjwYXV3d6unp2fR9slkUidOnNCRI0ec2wzDkGmaisfji87tNzg4KEnq7+93KgEBAFiPbrzxo/rIR27U009/V6+88rKuuOJK3XDDB6jgAwAAAFZBySX5DMPQkSNH1NzcLNM01d7enrWtvcBGR0fHvGReT0+Pdu7cqf7+/qyJvkgkonA4rIaGBjU2Nub1dQAAUIzKysr0wQ9+qNBhAAAAAOtOyc3JJ0l+v18jIyMKh8Nqbm5WJBJJWyXXsiz19vY6CT574Y25hoeH1dfXp+7ublmWNe/xoVBIHR0dOnTokOevCQAAAAAAAMim5Cr5bH6/XydPnlQkEtHx48fV19fnLMhhmqaampp08uTJBbdhmqaGh4cVDocVCoWcRF9lZaUCgYBOnjwp0zQ9fy0AAAAAAADAQnypVCpV6CCQ7sKFGf3iF68WOgwUqWef/b7uuOOTeuihL6um5rpChwMAAAAAAJbpne+8XGVluQ3ELcnhugAAAAAAAMB6QpIPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAiR5IPAAAAAAAAKHIk+QAAAAAAAIAit7HQAQCr6YUXxjU9PV3oMDx19uzzaf+XsvLycm3ZUl3oMAAAAAAAKDhfKpVKFToIpLtwYUa/+MWrhQ6j5ExMTOhf/aubNTMzU+hQkCdlZWV67LGoqqqqCh0KAAAAAAB59853Xq6ystwG4pLkW4NI8nlnPVTyrSdU8gEAAAAAStlSknwM18W6QkIIAAAAAACUIhbeAAAAAAAAAIocST4AAAAAAACgyJHkAwAAAAAAAIocST4AAAAAAACgyJHkAwAAAAAAAIocST4AAAAAAACgyPlSqVSq0EEgXSqV0swMfxYAAAAAAID1bMMGn3w+X05tSfIBAAAAAAAARY7hugAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAMA6093drdbWVoXD4UKHAnimt7dXra2tGhwcLHQoALAqfKlUKlXoIIDlOHDggKLRaNptIyMj8vv9iz7Wsizt3LlTkuT3+zUyMuJJjOtRJBLR8ePHNT4+LsuylEwmZZqmDMNQdXW1du3apcbGxqyP7+7uzumAwzAM1dXVqbGxUcFgMJ8vAQCAkmb/1tIHQqlLJpO66aablEwm1dPTQ58RQMmjkg8lpa+vr9AhpAmHw6qpqVFNTY2am5sLHY6nwuGwtm/frlAopGg0qng8rmQyKWk2qRqPxxWNRhUKhVRTU7PiyoFkMqlYLKbu7m7t3LlTsVgsHy8DcBw4cMD5/tr/4vF4To+1LGvdfPe90Nra6rx/VF8A+RUOh53f4CNHjhQ2GMBjhmE4n/Pu7u6cf8fXKnffpLe3d0mPbW5udh5r99GBhdAfK04bCx0AkE+xWEzxeDynaj7kRzKZVCgUSkuyGYah+vp6maapqqoqnTlzRuPj40vuWLW1tamlpWXe7fF4XJZl6cSJE87l1tZWtbW1qbOzc8WvCcimr69Pw8PDhQ7DEQ6H1d3dLYmqZJSuQlV4l2JlumVZzj6jp6dHhmF4+nwoLfF43DlxFQwG1dPTU+CIcuP3+xUMBhUOhxUKhXTy5MlChwTQh4NnSPKhJAQCASfJNDAwoEOHDhU4ovUhmUxq7969acm7hYZCJJNJDQwM6NixY6qrq1t0+1VVVTJNc97t9m3t7e0Kh8Pq6+tTMpnU0NCQrr76aoZiwDOcSADWLrvCOxaLaXBwUD09PQoEAkvejvt3ZS7LsiTJqU6XFv7dW824c2EfUJqmyW9lCSFZsLiOjg6Fw2FZlqXe3l5OCgMoWST5UBKCwaDGxsaUTCYVjUZlWVbG5NBqa2pqcpJZpXi23J3gM01Tw8PDC77vhmGos7Mzrx2rYDCoyspKhUIhSbOVVk1NTSX5fqNwOJEArA1eVniXemW6nUiUZk+SAeuJYRhONd/Q0JD2799PXxFASSLJh5JgGIb27dvnzMlnnwkvNMMwSrbiZ3Bw0DnIMQxj0QSflxobG50kTDKZ1IkTJ6hQQF5xIgFYG7yq8F4PlenueYv5jcR6ZCf5pNnvw1o4VsD6RR8OXmHhDZQMd4c1HA4zoayHkslk2sHCwYMHC57wcA9tOnXqVAEjQSmyTyTY1srkw/aJBL/fX/DvILBWBINBHTx40Lmebeit29zK9JMnTy6YCLMr00+fPp23k3nLiTtX9gJY9vOgtDQ1NWlkZEQjIyPq7+8vdDhrlv17KWnFC8ChtMRiMbW2tqq1tXXVFmehDwevkORDyTAMQ21tbc71gYGBAkZT2twdI7/fv+DE46vFfZA1NTVVwEhQqjiRABQPu8JbklPhnc1arEyXFo97KY4ePepcXutJvkIcbBe7YkwWFOrv7D5hR6IPNvfcqPbcq0CxIsmHkrJ//37n8tDQUAEjKW2HDx92Lq+VgwX3D3JFRUUBI0Gp4kQCUFxyqfBeL5Xp9iIhxTCNCAfb60Oh/s6M/ABQ6kjyoaTYk+ra1sqQulJiWVZaBdNaSfK5O2rbtm0rYCQoZZxIAIpHLhXe66EyPZlMOkmUXOYPBEqZYRjO/Gejo6MFjgYA8o8kH0qOe8U4d8XZcsViMXV3d6u5uVnbt29XTU2Nmpub1d3dvehwvXg8rpqaGtXU1Ki7u9u5PRKJOLe3trbmFIPd/sCBA1nbHDhwwIlx+/bt6u7uzvsQCPeqg2ulGiAejztVCtLaSTyi9HAiASgeuVR4r4fKdPeQ39ra2hVvDyh29fX1kmYT4AwJB1BqWF0XJcc0TTU0NCgajSqZTCocDi+r425ZllpbWzMOIYjH44rH4wqHw+rv71/ymf/GxkYZhuEMVUgmkwuuquSeS6elpWXe/b29vfOqiuzXHg6H1dHRkZb8XIlz5845l6urq/OyzZWIx+Pau3evc72trY0VquApexVMaTZBsNLvViwWUyQS0djYmFMp6/f7VVdXp46OjgU/z/F4XM3NzZJmExT2SoGRSEShUEjS7NCk4eHhRWOwTzg0NDTo0KFDGdscPXpUo6Ojzj6rqalJwWCwIAl/y7Kc19jU1KT29nZZlqXBwUFn+JdhGKqrq1N7e3vaEK1M7err69XZ2Zl1qGYymdQ999wjabZauL293dnPxmIxZ/Vl0zQVDAbzts/F8i1W4b1eKtPdSYwdO3aseHtAsdu2bZtzcnhsbGzNnLQutKX8rnZ0dOT0vlmW5fQd7H2uvY1AIKBgMLhgP2c5fQ97tXRpdr9u79vtY7dYLKZAIKBAIOC8XrdMtw0PD6f1I9zx5bsPZ/Pi7+EF+mNrD0k+lKT9+/c7P96Dg4PL7rjbCb6Ghgbt2LFDlZWVMgxDp06dcpJqoVBIIyMjS96xNjU1OYmCEydOLBijey6duT8wra2tTnWdneDctm2bzpw5o2PHjjnzDZmmmZdhSO6hQ1VVVSve3nIkk0mNjY0pEomkDbUKBALq7OwsSExYPziRMMurEwm5cldg1NXVpSU23W3sOZ96enoUDAY1ODiYNgeb3S4ajSoajWbtyE9OTqZVDGfajjT7d+3r61MsFls0uQrv5FLhvV4q0937mOUM111ugt99QD05Oek81jRN1dfXq6WlxTmIy/T9lZZ2sO0Fd1yZDsIztWtra8vaF3Ef1OfzhMpiyQK3cDjsJCWk2c9EMBhUY2Oj4vG4jh8/rkQiIcuyNDk5qdOnT2fdlpT5ID1b0mGlf+elfKYW4o7LffJ6vZv7u+o+AehuE4vF1NzcvGj/JNvvpPu3ua+vL+t2ltv3mJycdF7HuXPnnKSQe9+6Ul724Wz5/nt4hf7Y2kOSDyXJ7/crEAg4HY5IJLLknV5lZaXa2tq0f//+eQfHgUBAO3bscHa0XV1dGhkZWdL2g8Ggk6BaKEkQiUScy3v27Em7z+7oSPM7i42Njdq/f7/27t2reDyurq6uvO/4vV7goq+vL+NOO5NCJBmwfnEiwbsTCcsRi8UUDofT4rMsS4cPH3Yqtbq7u3Xu3DkNDQ3J7/erqalJpmmmvQ673cmTJxd8PrsDaj9fVVWVzpw54xyU2zH19vZy4qEAcq3wXi+V6XYyR9KSt7fcg+yFDu7tA+ChoSGdPHmy4AudLMS9Pzxx4kTW5Nnx48edy9FoNOv33t1u165d8+738oSKXd00d3iqfeBtnxiay7KsrH+j1Uw65PMz5b4/kUjkJb5Sk8vv6kLHFnM/y3blnDT7mbIsy+lbZEqU5avvMTU1pebmZuc5TNNUbW2tGhsbVVdX5xy/HT9+3Im3o6NjXl8oUx/Myz7cXCv9e6wW+mNrA0k+lKz29nbnx+Hw4cNL3ukZhrHgziAQCMg0TVmWtaz5PPx+f9rjs3Wi3JVq7gqbZDLpzPPn9/szng02DEP9/f3auXOnksnkspKdc7kTe4Ve9S6Xkm7AC5xIWJ0TCbmy958jIyNp72UwGEzr3A8NDc0bvtzY2KiWlhY1Nzc7CxTE4/FFO+T2mWi3uQfRQ0ND66pTWUjLqfBeL5Xp9oHOUhN8yz3IjkQiTjLGMAzt27dPfr9fyWRSk5OTOnXqlHNiwf7tDgQCKzrY9op94sOuiM62b4hGo06SzE5gZOqXuKtP5u4vvT6hEgqFnH1TR0eHGhsb0xKI9vC2np4eVVZWSpqtmLEvz3XixIklJx2W+3dezmdqIe7XVOi+7FplWZb8fv+8vof7d9VO6GaquLT/toZh6MiRIxm/N8lkUgMDA/Men8++h71fNQxDHR0d83637bjcJ0NM01x0P+N1H26ulfw9VhP9sbWBJB9K1twknBc7vdraWmdnlctOaK5gMOh0Wo4ePTpv52PvrKW3k4I298FAMBjMughIZWWl8z7EYrEVH4RfffXVzuXx8fEVbWsxDQ0NaauZupmmydx7KChOJHhzImG5+vv75+0T7IVS3NUfmSpxTNNMq3y0O9PZ2PMIzWUYhkZGRrR9+3Znnzw4OEiVcR55VeG9HirTsyVrMlnJQbZ7n/Lkk0/O+17a3x33cGnDMJZ9sO01O8knzcY8Nx77vrq6OmcuqFgsNm8fYSf/7G26eX1CJRKJONufe0Bs7xPD4bAsy1JlZWVO77k999hSkg7L/Tsv5zO1EPfjJycnc3rMenTw4MF5txmGoYaGBieJF4/H532eu7q6nMsjIyNZE6+Z+kFe9T0WimM5vO7DZbLcv8dqoz9WeKyui5LW0dHhXPZiFUz3mf/ldBLcO6Vjx47Nu39uIs/N3ZHp7u7W9u3bs/6zO5XuDtVyuefz8XpFMrvTl+kfCT4Umt2Bk+ScSMg390qYy/m+ufcb7nn3bEs9kZDpn30iQcr9ACvf3AeOc7lf09zXmK3dSg/63B3xQr0n65V9wHPy5MlFO/NrrTI917iXwn0CMNffzaUcZNvt3RXB9vfHMIwFn7PQB6K5cicP3CsV2+zXbpqm00dyvx82977Avc2Vvt+5cA8TznRA7L5tKfushZIOtnz0Fb38TGU7Sb7eLfS76j7hPzExkXZfLBZz/uYNDQ1LTqx50ffo6ekpyIiflfbh3Jb791ht9MfWBir5UNIaGxvTqtiWU20nvX0gfObMGVmWpfHxcaeMeCUWGwbi/qFrampKe+xynjsfHRk7wWZvq5CVO0ChdXR0OJMLDw4O5v2gNR8nEuyzpseOHZt31nkpJxLsg9CF5ONEwnLk2nlfrXnX3PvEQiePSk0+K7zXQ2W6e7+RayXfSkcKVFdXKx6PK5lMlkTlhGmaaRU5cxcysveVgUDAeS8yHUy6E3PuPt1qjMyw553Ltq909z3PnDmT0zZXM+ngxWcq2xyEpWwpr3eh39WF9iXuz3mmeScX40Xfo1Arp6+0D+e23L/HaqM/tjaQ5EPJa29vd34gBgYGMp4hzSYejzur8nglGAw62w+Hw07psntYR0NDQ9YDAMMwFl35LN/27NnjlIWHw2GSfFi3OJGQrlAHTLl2cFdz3jX3/FzIn3wO3yxEZfpqW853cqUH2S0tLc78aH19fTp8+LDq6+u1bds2Zz7TYuMeDudeyGjuEFz3933uSVB31XSmJKHk3QkV+/my7Y/ct+d6kL6aSQcvPlOVlZVFmeRz/4655xVdqsVOLCz3b7icz1K2x+dqob/jaux3verDua2lRN5C6I+tDST5UPLsShZ7Se5cv+DhcDitoxUIBJyVmOyz7t3d3WkHycvR2Njo7HzcK7e5h9a558my2YkFe6e1mmXo+/fvdzq79hnrYuy0A/nAiYTCy3U+Na/nXUNxWQ+V6cupEFzpQbY9mbo96bzd/3Kv4p1pAvy1bNeuXU6/59SpU07s7qG6dmWb/ZlyV9tlq+KTVueESlNTk5PIztRnc8e3Y8eOnLa5mkkHLz5TxToXn/t3bKnJXvuzlst+odC/l/nqe3hZMbYafThbof8euaI/tjYwJx/WhX379jmXc5mbz7KstPlRTp8+reHhYQWDQU/mg7M7fO75sdwdl0wJNPdtqz3HgGEYamtrc66HQqGiPBsK5EMwGHT2CUs9kdDc3Jw21Kunp0cjIyM6ffq0nn322bwcBNsnEqT0+aRyOZEgad2d/cwHe84gaXlJFqwe94rSKz1ptxa5EzFLTWoYhqFnn302p38nT55Me2wgENDp06fV0dEx7ySkPQfdgQMHlv/CVpm77zc6Ourc7l4sw1ZfXy8pfX+bbT4+t5W834tx/065V9mV0leuDQQCOZ+0Xe2D9Hx/poq13+pOwi6lAtnd1v6MesH9t1lO36FY+h6r1YfDyqzX/hhJPqwL7p2svXrYQtxnNPft25d1p5CvyU3d8UUikbQKG/cByNzH2HHZlYqrqbOz0ymBt5cpX0oMXg+NAlYTJxLg5j64dw8Jxdrjnicv21xqxcy9L8n1NzpfB9mGYai9vV0nT57U6dOn1d/fn9bfiUajRZVYde9H3VVxUnrixZ6HzP3+2fsEwzDmJahWI6kx93PQ3NzsLM5mzytrmqazuMda5cVnqtgO/AOBQFrMuS7CMjAw4Fxezlx5uVpp36EY+h6r3YfD8q3X/hhJPqwLcyvPFjsId3fA3CuSuVmW5Rwkr5R7haFYLJb2g52pwkaafU32ikF2ki1b5zCZTKq3tzfvKwwfOXIkbXXRm266adEf5Hg8rtbWVqdTCZQCTiSsLwtVRCWTSacqRirchN/IzXqqTM+1ks+Lg2zDMNTY2OhUutiWukpsIc2dX8/93rjfM/dle39rf6bmDtWd296rpEY4HFYymVQwGHSqDu0KF/s7cPLkyaJKTqzkM+X+jhfLXGduHR0dzuWurq5F28diMeeYxTRNT6clsOcqlnLrD821Fvoei+0rV7sPh+zoj2VGkg/rxtyz9Qtxd7ii0aiam5s1ODioSCSicDis1tZW7dy5M6/xuSdxts86LLS8uDT7Q2p31uLxuHbu3OnMExgOh9Xb26vW1lZt375dQ0NDeT9DbBiGRkZG0s5C2+9Nb2+vwuGw85719vaqubnZKW1fyyX4wFJxIsGbEwlrVTwez3ggaVlWWlWz3+8vuTneSlGpV6bbB6C5viavD7LdlS6LHUyvpXnT5ibj7L+7e6iulL7q7NxkYKb9wWokNU6dOuU8/6FDh5whv3ZF3NyV11fbSv/OS/lMzbWac1rnSzAYdD6Pdt872+cmFoulnVhfjWpNe+5fSWptbc26j8w0zLpQfQ93stf+vtjcJ0al1e/DITv6Y5mx8AbWDcMwFAwGcyrjNwxDPT09Til2PB6f9wNlmqZM08zbWVd7gRD7+ezbFnPo0KG0RUKyvT7TND05g2EYhk6ePKnBwUEnfsuynAmqs8XiPgsJlIK5C9IsJNOJhKamJpmmqcnJSUUikbxXdNj7mOWcSIhGo86JBHs4iiSdO3dOiUTCiXU9nSUNhUJqaGhwhunF4/F5+1/7QGUu96JNHR0dam9v9zZYLOrIkSNqbm6WZVlOZXp/f/+C85PZk65blrXkOdJWU11dnfMdtSu3FmIfZNtVjXv37lV/f3/GfUUymdTAwICqqqqcz3F3d7dM08z6ubZX+7Zjm2vuwbZ7v2IfaBcqMWPvD+0V1aXMC1XYC12MjY05sWabGmGl7/dSRCIRJ4ZCJ7eW8nde6WdqLveCFYV+H5ZreHhYzc3NisfjisViuummm7Rv3z7ndz0ej+v48eNpiabh4eFVWW02EAiora3NKTBobm5Om+/RsiyNjY05xztzYypE38MdQzQadT5zZ86cUTQaVTAYdJKXhejDITv6Y/OR5MO60t7envNcHcFgUJWVlQqHw86O2jRNZ5XdQCCQduZgpZ0Eu/Pn/lHINKwjW6yBQEBHjx51Op/2vC91dXVOvF5qb293kqgnTpxIG54izb6+uro6BYPBdXUmBesHJxK8OZGwFvn9ftXX12toaCjjmXrDMHTkyJFVOZhCftiV6Xaiz66OMU1TDQ0Nuvrqq1VZWanJyUmdO3dOo6Oja76Cz+bun4yNjeXUH1jJQbZdrd/X16dAIODsywzDmHfwlemAaikH27bVOlDbtWuX08+yK8YWGoLrngd1ocUOvE5q7Nixw5mv7sSJE/P6rJWVlTJNU36/3/mbeW0pf+eVfqbmcn93i3k/PTIyot7eXg0NDc0bmuhmz7e4mq+1s7NT27ZtU1dXl/M9yNSfMU0zbV5j22r3PezPv/3ZmPt87qG3hejDITP6Y5mR5EPROnTo0JIfY5qmnn322ZzbNzY2LpiQWux+v9+/pOcbHh7Oue1cpmmqs7OzoEMu7AmRV9K57unpmdd5B4oFJxLWh8rKSnV2dmrXrl0aGBjQ6OioUyHV1NSkjo6OoprbCrNKtTLdfXATj8dz/q4u9yA7EAg4bRc6wM20Sqq9vVwPtleb+71LJpNZJ9m3b3cvprHYYgdeJjWCwaCzXffCIdkEAgH19/d7uh9byt95pZ+puc6cOeNcLvbJ+Ds7O9XS0qKjR49qdHTUOUlhmqZqa2u1a9eugp1ct/sGAwMDTt9BUs6xrXbf48iRIwqFQorFYk6Srra2Vi0tLfM+V6vdh0Nm9Mcy86VSqVShgwAAAFjLLMty5mINBAIrOimDpXFXabW1ta3KyaxkMrniyvRCxJ3JSj+7lmUt+SDbfv/sCqy5B/f79+9fsLIimUzmfLAtre6Qq9bWVuegfqHncsckKeeTvst5v+PxuJqbmyUpY6XjgQMHljw/mGma84ahu5+noaEh6wn3SCTizAO30Gd/KX/nlX6m3Hbu3Ok8fikn4wEUHv2xxZHkAwAAWASdShQzO6lhGIZOnz5d6HCwityVqcFgUO3t7RkTpfbcbocPH3aS2qU0R5VbTU2NJPblQDGiP7Y4VtcFAAAASph7jjhWt19fDh8+LGm24q2npyfrsEG/36/29naNjIw4t5XifGKLrXYMAMWOJB8AAABQwtzVWIODgwWMBKvNrsrLdV4qdxLQXlyklBw9etS5vF4WiwKwvpDkAwAAAEqYvciBlH1BB5Qmu4ozHo+nLQSQTW9vr3M518WZiok9NyEJPgCliiQfAAAAUOLcqwCT6Fs/+vv7neq8UCik1tZWhcNhxeNxZ/h2PB7X4OCgdu7c6awmbQ/fLSXuKtZSe20AYNtY6AAAAAAAeCsQCCgQCCgWi2lwcJBKpnXCMAydPHnSWWE3FostOtdeIVeD9pI9P2EwGMw6NyEAFDtW1wUAAADWAfeqhD09PST61plkMqlwOKxYLCbLspwVl03TVHV1tXbs2FGyn4ne3l4NDQ3JMAw9+eSTOc9RCADFhiQfAAAAsE6Ew2F1d3eT7MC6EY/H1dzcLEkaHh525ikEgFLEnHwAAADAOhEMBhUMBpVMJrV3795ChwN4KplMKhQKSZqdl5IEH4BSR5IPAAAAWEd6enrU0NAgiUU4UNoGBgZkGIba2tpYbAPAusBwXQAAAAAAAKDIUckHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFDmSfAAAAAAAAECRI8kHAAAAAAAAFLmNhQ4AAAAA2cViMbW2tqbdFggENDw8vKLt7ty5U5Zlpd12+vRpGYaxou16oaamxrm8VmPMVTweV3NzsyTJNE2dPHmywBEBAIBSQSUfAABAkYnFYkomk8t+fDwen5fgAwAAQHEjyQcAAFCETpw4sezHHj9+PI+RAAAAYC0gyQcAAFCEwuHwsh977NgxSSrqYa8AAABIR5IPAACgSBiGoUAgIGl2yO1yhuy6h/rW19fnNT4AAAAUDkk+AACAImIn+aTlVfNFIhHn8q5du/ISEwAAAAqPJB8AAEARaWxsdC4vZ14++zGGYcjv9+ctrlzV1NSopqZG27dvX/XnBgAAKGUk+QAAAIqIaZoyTVPS0lfJdQ/V3bNnjyfxAQAAoDBI8gEAABSZhoYG5/LRo0dzfpy7LUN1AQAASgtJPgAAgCLT0tLiXI5Gozk/zm5bqKG6AAAA8A5JPgAAgCLjHrJrWZbi8fiij3EvuNHU1ORZbAAAACiMjYUOAAAAAEvX0NCgoaEhSdLx48cXrcxzr8TrXrxjOcLhsMLhsCzLUjKZlGmaamhoUEtLi5N8tMViMbW2ts7bRjKZVE1Nzbzbh4eH01YQziYej2tgYECJREKWZckwDNXV1SkYDC7p9cViMR09ejRtO6ZpqqmpScFgUIZh5Lwte3uDg4MaGxtz3ptAIKDGxsacXhcAAMByUckHAABQhNxDdo8dO7Zg22QyqVgsJml2qO5yk03xeFzbt29Xd3e34vG4s4iHZVkaGhrSzp0705KJXhkcHFRzc7Oi0aiz8Ij9GkOhkHp7exfdhmVZam5uVmtr67ztxONx9fX16aabbkqrgFxMd3e3Wltb0xY4sSxL4XBYra2tam5uXtJCKQAAAEtBJR8AAEARMk1Tfr/fSbbF4/Gs1XwnTpxwLi93qO7cijzDMFRfX6+qqiqNjY05Q4a7u7tVWVnpVNOZpqmenh5Jswm0vr4+5/EdHR3znqeurm7BOEKhkGKxmAzDcF6LZVlOElOShoaGMlYV2uLxuPbu3esk4iQpEAjINE1NTExodHRUyWRSyWRSoVBIbW1t6uzsXDCu3t7eeQlOv9+v6urqtPcoFAotuB0AAIDlIskHAABQpJqampzkWjgcdpJpc7mTT8FgcFnP5U5OBYPBec/lTgJ2dXWlJfns53Qn+ZYbSywWk9/v18jISNbnl2ZXEs6UmEsmk2kJvoaGBt1///3zhuUODg46sQ4NDWnbtm1ZhwHblYw2O7E5t2IyEomQ5AMAAJ5huC4AAECRcifJ3NV6bnaVn7T8VXV7e3vTkmKZkomBQCCtYm9wcHDJz5OrI0eOZHx+9/sxOjqa8bH33HNP2ms5dOhQxnn32tvbNTw87FwPhUJplX9u7tdqmqZGRkYyDolubGzMmogFAABYKZJ8AAAARcqdtHPPu+fmTv7t2bNnyc+RTCbTqtQOHTqUta17oYpMseTDQothuCvtMiXkLMtSNBqVNPve3X///Qs+VyAQUENDg3N9YGBgXptkMplWKdnT07PgYh3ZhhADAACsFEk+AACAIuauXjt69Oi8+90JKPdiHblyJwkDgYBisdiC/+wklldJvlwXDZmcnJx3m3sRjaamppxWznW/Z3aC0M39OleyqAkAAMBKMScfAABAEWtqalJ3d7ek+UNU3UN1TdNcVhWZ/XhJTiIvV8lkMqdE2lIs9BoqKysXfKw79lyTce6FQCzLmveazpw541yur6/PaZsAAABeoJIPAACgiLmrx+YO2XVX4S13wQ3LspYdW6ZqukJyv5Zck49z2819TVNTU85lhuICAIBCopIPAACgyDU2NjrJvUgk4iT93MNTs60MuxTDw8MFH46ar8rAbItoePU4AAAAr1HJBwAAUOSampqcy3b1nruqz+/3L7vKrKKiwrnsHrpbjLINs13I3ErGue+j+/1xV/UBAACsNpJ8AAAARW7ukN14PJ42bHe5Q3UlaceOHc7lXBNja5V7zrxEIpHTY9yJTcMw5lUSbtu2zbns1WIjAAAAuSDJBwAAUALcibzjx4/r+PHjznV3pd9SuR8bjUZXNEdfoe3atcu5HIvFcnothw8fdi5neh/dw5cty1q02pHhvgAAwCsk+QAAAEqAe8690dFRZ6XdQCCwonnsDMNISyCGQqGcHrcWk11+vz8tKbfYawmHw2mvo6OjY14bwzDU0NDgXO/q6lpwm+7kKwAAQD6R5AMAACgRdrIpHo87SbSVDNW1dXR0OInCeDyu5ubmrFVwkUhEzc3NGZNdc5ON4XA47frg4GDaYiFe6OnpcS4v9Fp6e3vV3d3tXHe/B3N1dnYuus1kMqnu7m5Fo9GVvgQAAICMWF0XAACgRLS0tMxLIuVjVV3DMHTkyBHt3bvXmfNv586d8vv9qqurkzQ7VHVsbMxJLmZLiAUCAWfuuu7ubiepZz+2oaEhLzFnY5qmhoeH1draKknOazFNU7W1tRofH59XhRgMBtXe3r7gNoPBoJO0tLcZCARkmqYmJiY0OjqqZDIpwzAYsgsAADxBkg8AAKBEuIeiSkobRrpSfr9fIyMjCoVCThIsHo9nHJZrmqb6+/szbicYDKYtUDF3sYqqqqq8xZxNIBBwXotdcWdZVsaKvp6enpyqIXt6ejQxMZGWZJ372tra2rRt27achzwDAAAsBUk+AACAEjI8POxUivn9/rxu2zRNjYyMKBaL6ejRo0okErIsS4ZhqK6uTqZpqrGxcV6y0a2xsVE9PT0aHByUZVlOBd22bdsUDAZXNH/gUvj9fp08eVKRSETHjx9Pq7QzTVNNTU1LjufQoUOKRCIKh8MaGxuTNPue1dfXq6WlRaZpKh6PO8nX1UhoAgCA9cOXSqVShQ4CAAAAAAAAwPKx8AYAAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEWOJB8AAAAAAABQ5EjyAQAAAAAAAEXu/weU5dCoxV1GqAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "curr_method_name_to_display_name = {\n",
    "    'naive cqr': 'Naive CP',\n",
    "    'full + linear': 'Naive Imp.',\n",
    "    # 'rf': 'Naive Imp.',\n",
    "    # 'rf imputation': 'Naive Imp.',\n",
    "    # 'weighted oracle masker': 'WCP',\n",
    "    'pcp xgb use z=true masker': 'PCP (est. weights)',\n",
    "    # 'pcp oracle masker': 'PCP (oracle weights)',\n",
    "    'full + linear with linear clustering errors': 'Uncertain Imp.',\n",
    "    'full + linear with kmeans clustering errors': 'Uncertain Imp.',\n",
    "    # 'triply robust full + linear with linear clustering errors pcp network use z=true masker': 'Triply Robust',\n",
    "    # 'triply robust full + linear with kmeans clustering errors pcp rf use z=true masker': 'Triply Robust',\n",
    "}\n",
    "curr_methods_order = list(curr_method_name_to_display_name.values())\n",
    "total_df = original_total_df.copy()\n",
    "\n",
    "sns.set(font_scale=2.5)\n",
    "plt.figure(figsize=(15, 3))\n",
    "\n",
    "total_df = total_df[total_df['Method'].apply(lambda m: m in curr_method_name_to_display_name)]\n",
    "total_df['Method'] = total_df['Method'].apply(lambda x: curr_method_name_to_display_name[x])\n",
    "\n",
    "def f7(seq):\n",
    "    seen = set()\n",
    "    seen_add = seen.add\n",
    "    return [x for x in seq if not (x in seen or seen_add(x))]\n",
    "\n",
    "curr_methods_order = [m for m in f7(list(curr_method_name_to_display_name.values())) if m in pd.unique(total_df['Method'])]\n",
    "\n",
    "ax = sns.boxplot(data=total_df, x='Method', y='full y2 coverage', hue='Method',  palette=color_palette,\n",
    "           order=curr_methods_order)\n",
    "\n",
    "plt.ylabel(\"Coverage\")\n",
    "# plt.xlabel(\"Dataset\")\n",
    "# sns.move_legend(ax, \"upper left\", bbox_to_anchor=(0.985, 1.1))\n",
    "plt.axhline(y=90, color='r', linestyle='--')\n",
    "save_dir = os.path.join(figure_path, \"nslm\")\n",
    "os.makedirs(save_dir, exist_ok=True)\n",
    "plt.savefig(os.path.join(save_dir, \"coverage.png\"), dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "plt.figure(figsize=(15, 3))\n",
    "sns.set(font_scale=2.5)\n",
    "\n",
    "for dataset in pd.unique(total_df['Dataset']):\n",
    "    curr_len_df = total_df[total_df['Dataset'] == dataset]['y2 length']\n",
    "    # curr_len_df -= curr_len_df.min()\n",
    "    curr_len_df /= curr_len_df.mean()\n",
    "    total_df.loc[total_df['Dataset'] == dataset, 'y2 length'] = curr_len_df\n",
    "ax = sns.boxplot(data=total_df, x='Method', y='y2 length', hue='Method', palette=color_palette,\n",
    "                order=curr_methods_order, showfliers=False)\n",
    "plt.ylabel(\"Interval length\")\n",
    "plt.savefig(os.path.join(save_dir, \"length.png\"), dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c79f28e9-49aa-4303-bc69-ce59c0adbc67",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
