{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0b119b7e",
   "metadata": {},
   "source": [
    "### Random Forest Model Training with Betti Vectorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "47d6ddeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import plot_confusion_matrix, roc_auc_score\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from src.utils import enrichment_factor"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc50db6c",
   "metadata": {},
   "source": [
    "## Target CP3A4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 12304/12304 [00:02<00:00, 5421.54it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/partial_charge_superlevel_betti/target_cp3a4/'\n",
    "\n",
    "for file in tqdm(os.listdir(path)):\n",
    "    if file.endswith('pkl'):\n",
    "        with open(os.path.join(path, file), 'rb') as f:\n",
    "            X.append(pickle.load(f))\n",
    "        target_label = 0 if \"active\" in file else 1\n",
    "        y.append(target_label)\n",
    "\n",
    "active_ind = [i for i, label in enumerate(y) if label == 0]\n",
    "decoy_ind = [i for i, label in enumerate(y) if label == 1]\n",
    "\n",
    "# shuffle the lists\n",
    "random.shuffle(active_ind)\n",
    "random.shuffle(decoy_ind)\n",
    "\n",
    "# Use 90% of the actives for training \n",
    "num_actives = len(active_ind)\n",
    "num_training = int(0.9 * num_actives)\n",
    "active_training_ind = active_ind[:num_training] \n",
    "active_test_ind = active_ind[num_training:] \n",
    "\n",
    "# Use same number of decoys as actives in training (avoid imbalance)\n",
    "decoy_training_ind = decoy_ind[:num_training] \n",
    "decoy_test_ind = decoy_ind[num_training:] \n",
    "\n",
    "# training and test index lists\n",
    "training_ind = active_training_ind + decoy_training_ind\n",
    "test_ind = active_test_ind + decoy_test_ind\n",
    "\n",
    "train_x, train_y = [X[i] for i in training_ind], [y[i] for i in training_ind]\n",
    "test_x, test_y = [X[i] for i in test_ind], [y[i] for i in test_ind]\n",
    "\n",
    "# flatten\n",
    "train_x = [x.flatten() for x in train_x]\n",
    "test_x = [x.flatten() for x in test_x]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5230175d",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_estimators = [int(x) for x in np.linspace(start=100, stop=1000, num=10)]\n",
    "max_depth = [int(x) for x in np.linspace(start=1, stop=15, num=15)]\n",
    "min_samples_split = [int(x) for x in np.linspace(start=2, stop=50, num=10)]\n",
    "min_samples_leaf = [int(x) for x in np.linspace(start=2, stop=50, num=10)]\n",
    "bootstrap = [True, False]\n",
    "criterion = [\"gini\", \"entropy\"]\n",
    "param_dist = {'n_estimators': n_estimators,\n",
    "              'max_depth': max_depth,\n",
    "              'min_samples_split': min_samples_split,\n",
    "              'min_samples_leaf': min_samples_leaf,\n",
    "              'bootstrap': bootstrap,\n",
    "              'criterion': criterion}\n",
    "\n",
    "rfc = RandomForestClassifier()\n",
    "rs = RandomizedSearchCV(rfc, \n",
    "                        param_dist, \n",
    "                        n_iter=100, \n",
    "                        cv=3, \n",
    "                        n_jobs=1,\n",
    "                        verbose=1, \n",
    "                        random_state=0)\n",
    "rs.fit(train_x, train_y)\n",
    "rs.best_params_"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "94d64005",
   "metadata": {},
   "source": [
    "With n_iter = 100 and cv = 3, we create 300 Random Forest models, randomly sampling combinations of the hyperparameters input above. We call “best_params_” to get the best performing model’s parameters (shown at the bottom of the code box above)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5792a9be",
   "metadata": {},
   "outputs": [],
   "source": [
    "rs_df = pd.DataFrame(rs.cv_results_).sort_values('rank_test_score').reset_index(drop=True)\n",
    "rs_df = rs_df.drop([\n",
    "            'mean_fit_time', \n",
    "            'std_fit_time', \n",
    "            'mean_score_time',\n",
    "            'std_score_time', \n",
    "            'params', \n",
    "            'split0_test_score', \n",
    "            'split1_test_score', \n",
    "            'split2_test_score', \n",
    "            'std_test_score'],\n",
    "            axis=1)\n",
    "rs_df.head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0274702c",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(ncols=3, nrows=2)\n",
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=8)\n",
    "fig.set_size_inches(30,25)\n",
    "\n",
    "sns.barplot(x='param_n_estimators', y='mean_test_score', data=rs_df, ax=axs[0,0], color='lightgrey')\n",
    "axs[0,0].set_ylim([.4,.8])\n",
    "axs[0,0].set_title(label='n_estimators', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_min_samples_split', y='mean_test_score', data=rs_df, ax=axs[0,1], color='coral')\n",
    "axs[0,1].set_ylim([.4,.8])\n",
    "axs[0,1].set_title(label='min_samples_split', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_min_samples_leaf', y='mean_test_score', data=rs_df, ax=axs[0,2], color='lightgreen')\n",
    "axs[0,2].set_ylim([.4,.8])\n",
    "axs[0,2].set_title(label='min_samples_leaf', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_max_depth', y='mean_test_score', data=rs_df, ax=axs[1,0], color='lightpink')\n",
    "axs[1,0].set_ylim([.4,.8])\n",
    "axs[1,0].set_title(label='max_depth', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_bootstrap', y='mean_test_score', data=rs_df, ax=axs[1,1], color='skyblue')\n",
    "axs[1,1].set_ylim([.4,.8])\n",
    "axs[1,1].set_title(label='bootstrap', size=20, weight='bold')\n",
    "\n",
    "sns.barplot(x='param_criterion', y='mean_test_score', data=rs_df, ax=axs[1,2], color='wheat')\n",
    "axs[1,2].set_ylim([.4,.8])\n",
    "axs[1,2].set_title(label='bootstrap', size=20, weight='bold')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87fcb8a3",
   "metadata": {},
   "source": [
    "#### Model Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f08b5f2f",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9938650306748467"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# clf = RandomForestClassifier(n_estimators=rs.best_params_[\"n_estimators\"], \n",
    "#                              min_samples_split=rs.best_params_[\"min_samples_split\"],\n",
    "#                              min_samples_leaf=rs.best_params_[\"min_samples_leaf\"],\n",
    "#                              max_depth=rs.best_params_[\"max_depth\"], \n",
    "#                              bootstrap=rs.best_params_[\"bootstrap\"],\n",
    "#                              criterion=rs.best_params_[\"criterion\"],\n",
    "#                              random_state=0,\n",
    "#                              n_jobs=1)\n",
    "\n",
    "# clf = RandomForestClassifier(n_estimators=100, max_depth=9, random_state=0, criterion=\"gini\")\n",
    "\n",
    "# Very large numbers of base estimators may take a long time to prepare, but will not overfit the training data.\n",
    "clf = RandomForestClassifier(n_estimators=1000, \n",
    "                             min_samples_split=2,\n",
    "                             min_samples_leaf=2,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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Oy+++CJAmXLCH3/8QVxcHB4eHnz88cc0btwYAK1Wy4gRI3jkkUeq/Bm++eYbsrKyuO2223j77bdp2LAhYHog7bBhw+jSpQvFxcX8+OOP173X7NmzAXjllVd48MEHy3z20aNH06tXL/PX/VIrV64kJyeHyMhIXnrpJfOevg0bNuS9996rsAyixrlz5zh79izOzs689dZb5vITmEpRL730EgBXrlwhLS2t3PUajYY5c+bQsmVL87GePXuayy5LliwxH9+yZQtHjhwhJCSETz75hKZNm5rPhYWF8cknn6DValm5ciUXL1684c8mbJMk55use/fu5RahdOrUiZEjR3LgwAE8PT2ZP3++xbKGXq83J75rbdu2DYCHHnrI4ns+9NBDaDQajh49Snp6OmAqg4DpYbCW5hn379+/yp9p+/btADz66KPmXxzXeuutt/j55595+umnK73P6dOniY+PR6vVlknM13r44YcB2Llzp/nYr7/+CmCxduvo6FhhTVcNf39/YmNjiY2Ntfjn5ezsbP7/BQUF5c537Nix3IIegH/9618AHD582Jxot27dCkCPHj1wcnIqd41er0ev11NcXMzu3bur94GEzZOa803290UoWq0WV1dXmjVrxu23306vXr1wdXW1eK23t3e5Yzk5OZw/fx6Ajz/+mAULFli8VqfTUVJSQmJiIt7e3iQlJQGmnpgllhJJRVJSUgAIDw+3eN7X17dK90lISACu9t4tKU18ycnJKIqCRqMxf5Zre6XXat26dZXevyqcnZ05efIkBw4cIDk5mZSUFOLj482xAxiNxnLXtWnTxuL9mjVrhru7O1euXCExMZEmTZpw8uRJAH766Sf27t1r8brU1FTAVMsW9kmS801W0SKUqrDUi7p2VseRI0eue48rV64ApqQO4OLiYrGdu7s7Go0GpQoPyrl06RKAxV69GqUxlZSUmAcMK2I0GsnNzcXNzc18XUW/1K4dbLwRx48fZ/r06eV6qwEBAfTr14/Vq1dXeG1FsZWeu3LlivkXT+nnSUlJMf/iq0jpz1PYH0nOddy1yfV///tflReHlH41z8vLs3i+sLCwSokZTL3JnJycCu9VVaUJLDw8nO+//77K13l4eHDx4sUyv6iuZanMoFZ6ejpDhw7l0qVLtG7dmv79+9OmTRtatmyJp6cnRUVFlSbnyv5sSuMu/ZmU/kxnzZrFAw88cMOxi7pJas51nIeHhzkhnzp1ymIbg8HAb7/9RnJysvnBmSEhIYBpepglpV+tqyI4OLjSa3755RcGDx5cZkDSktKBuzNnzlBUVGSxTUZGBn/88UeZQbfSz3Ls2DGL11T056LG2rVruXTpEi1btmTVqlUMGTKEO+64w7yM3dIg4LVKSy9/l5KSQk5ODlqtltDQUODqn0NlccfFxXHixIka+cUjbJMkZztQOuf366+/tnh+48aNDB8+nL59+5p7cN27dwdMA2uWEsv69eur/P6lC0w2bNhQ4fv/8ccfZGdnm4+VDhxe2zsPCwsjICCA/Pz8Cu81c+ZMBg8ezIQJE8zHSj/L2rVry9V7jUZjhfdS4+zZswCEhoaWGfwrtWbNGvP/t/Tk6NjYWPPYwLVWrlwJwB133GGeAdKlSxcAvv32WwoLC8tdk5KSwhNPPEHv3r2Ji4tT/2FEnSDJ2Q48/fTTODk5sXHjRj7++OMy/6B37drF22+/DcCAAQPM9dd27drRtWtX8vPzGTt2rHmACWD16tWq9vYYPHgwHh4e7Nmzh+nTp5vfX1EUli1bxg8//ICDgwODBw82X1Nawjh37pz5mEajYfTo0QBMnz6dH374wXyupKSExYsXs27dOoAyA4bR0dE0a9aMw4cP8/rrr5t7k4WFhbz55psVfjtQo/TbQUxMDAcOHDAfz8/PZ+HChSxatMh8zFJCLSoqYuzYsWV+Ea5evZrPP/8cjUbDmDFjzMcffvhhgoODSU5O5vnnnzfPsAFTD3z06NGUlJTQpk2bCld+irpPas52ICwsjBkzZjBp0iQ+/fRTli1bRkhICFlZWeYe3z/+8Q/zXNxSU6dOZcSIERw4cIAePXqg1+vJzMzk/PnzdO3atcr7Avv4+PDRRx/x/PPP88UXX7Bu3TqCgoI4f/48Fy9eRKfT8fbbb5sTHJhmg+zbt4+JEycSGhrKhAkTuPvuu+nfvz/x8fF8/vnnTJw4kXfffZdmzZpx5swZ88DjmDFj6NGjh/lebm5ufPzxxzz77LOsWbOGzZs3ExQURHJyMpcvX1b1WSoyYMAAli9fztmzZ4mOjiY4OBhnZ2eSk5PJy8sjICAArVZLSkoKFy5cKHd9VFQUe/bsoXv37oSHh5OVlWXuSU+aNIk777zT3NbR0ZF58+bx1FNPsWPHDrp06UJYWBjFxcUkJSVhMBjw9fVl/vz5N/SZhG2TnrOd6NWrF99++y39+/encePGHD9+nKysLNq3b88rr7zCwoULyy319fb2ZsWKFYwZM4aAgAASEhLQarWMHTuWDz/8UNX7R0VFsWHDBvr374+bmxvHjx/HYDDQo0cPVq5cWW7j+unTp9O5c2cURSEpKYnk5GTzuZdffpklS5bQrVs3jEajuZZ89913M3/+fIsb13fs2JF169bRr18/XF1dOXHiBAEBAXz44YcMGjRI1WexxMPDgzVr1jBkyBCCg4M5e/YsycnJBAUFMXbsWDZs2ECvXr0ALP4iuOWWW1i5ciWdO3cmKSmJy5cv849//IPPPvvM4oKjsLAwNmzYwKhRowgNDSUpKYnTp0/TokULRowYwfr16/H397/hzyVsl0ap6pC8EEKIm0Z6zkIIYYMkOQshhA2S5CyEEDZIkrMQQtggSc5CCGGDJDkLIYQNkuQshBA2SJKzEELYIEnOQghhgyQ5CyGEDZLkLIQQNuj/AdRKzq+BmSY1AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=2)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26957a38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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/vtKSUmJpeymTZss5zZu3Gg5bjKZlEcffVTR6XTKyJEjlZycHEVRFMVoNCpLlixRIiIiLO95pUmTJik6nU6ZNWuW5Vh2drbStWtXRafTKa+88oqSn59veY9PP/1U0el0SseOHcvde1ndhw8fLlf/+vXrFZ1Op0RFRSnfffed5bher1fmz59vOZeZmWk5d+7cOcs9vv3220ppaamiKIqSn5+vPPvss5b3evzxx21+7a+0du1aRafTKQ899FC54w899JCi0+mUZ555RsnLy7Mcz8vLUyZOnKjodDrl5ptvVvR6veXcld+7u+66S0lOTrac+/HHH5VOnTopOp1O+e9//2s5bjAYlAcffFDR6XTK//3f/ylnz561nDt69KgyYMAARafTKf/+97/Lta93796KTqdTNm/eXK37FI5BcsJ2pigKFy9eZNu2bTz11FOcP38eX19fnnzyyQrXurm5MWHCBDQaDYBlcOyTTz4hPz+fBx98kAkTJpTrHfXt25eJEycClEsD7N69m6SkJPz8/JgzZw7+/v4AaLVaRo4cyQMPPFDte/jyyy/JycnhpptuYtq0aTRo0AAwb0w6YsQIevXqRWlpKd9//32Vdc2dOxeAl156iXvuuafcvT/99NMMGDDA8md6mZUrV5Kfn8+tt97K888/b1lTtkGDBsyaNctm+kKNkydPkpmZiaenJ2+88YYlbQTmFNLzzz8PQF5eHllZWRXKazQa5s2bR9u2bS3H+vfvb0mXLFmyxHJ848aNHDhwgDZt2vD+++/TuHFjy7nw8HDef/99tFotK1euJDs7+6rvTdiXBOFrrG/fvhUe1rjllluIjY1l7969BAQE8NFHH1lNR+h0OkuAu9LmzZsBuPfee62+57333otGo+HgwYOcPXsWMKcvwLwpqLV5uoMHD672PW3ZsgWAhx56yPIBcaU33niDTZs28dRTT1VaT3p6OkePHkWr1ZYLwFe67777ANi2bZvl2C+//AJgNbfq7u5uM+eqRvPmzUlMTCQxMdHq18vT09Py/4uLiyucv/nmmys8+ALw8MMPA/DXX39ZAupPP/0EQL9+/fDw8KhQRqfTodPpKC0tZefOnTW7IeEwJCd8jf39YQ2tVou3tzdBQUF07tyZAQMG4O3tbbVskyZNKhzLz8/n1KlTAMyZM4ePP/7YalkXFxcMBgMpKSk0adKE1NRU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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, normalize='true', ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "141c31e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, test_x, test_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "985a8881",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWEAAAE+CAYAAABcJ6H1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABJ20lEQVR4nO3deVxU5f7A8c8M+yrgAoogIoJ7uWWa5lpmi9fMrDS9Ylk/l2yxUtssu7m0aGaWN7FcEjOTsrJFzVzKNE26aiqKsomKguzbMDPn98fEJDIsB8GZge/7vuZ18zzPec5zGPjOM892NIqiKAghhLAKrbUrIIQQDZkEYSGEsCIJwkIIYUUShIUQwookCAshhBU5WrsCQghxJb1ej8FgUH2eg4MDjo72F9Lsr8ZCiHpLr9dz9PCvGBRP1ec6ODjQqVMnuwvE9lVbIUS9ZjAYMCietGnyCs4Ol6t9ns7gx+n0uRgMBgnCQghxrRy06Tg4XKp+fsVYh7WpWxKEhRA2x4iCkeov5lWT19ZIEBZC2Bzj3/9Tk99eSRAWQtgco6JgULGtjdGOt8CRICyEsDlG1HUx2G87WIKwEMIGGVDQqgjChhr2Ce/du5fly5cTFxdHSUkJHTt2ZNKkSdx6663VLuPPP//kww8/JDY2loKCAgICAhg0aBBTp06lUaNGVZ4vK+aEEDZH+XtgrrovpQZBOCYmhsjISGJjY+nSpQtdu3YlNjaWSZMmsWHDhmqVsX37dsaOHcvOnTsJCQnh1ltvpbi4mNWrV3P//fdz+XLV0+w0sp+wEMJWFBcXc/ToUfybPIKj48Vqn6fXNyMtfSWdOnXCxcWlyvxpaWkMGTIEFxcXoqOjCQ8PB+Dw4cNERkZSUlLCtm3b8Pf3r+Saevr378/ly5dZsmQJt99+u/kennzySX7++WcefvhhXn755UrrIi1hIYTNMdbgpca6devQ6XRMmDDBHIABunTpwqRJkyguLq6yNRwXF0d6ejrt2rUzB2AAFxcXpkyZAsCBAweqrIsEYSGEzTGiYFDxUjtPeM+ePQAMGTKkXFrpsd27d1dahlZrCp8ZGRno9foyaZmZmQDSJyyEEFdTFIX4+Hi0Wi2hoaHl0kNCQtBqtcTHx1NZb21YWBjNmzcnLS2N559/nuTkZAoLC/ntt9947bXX0Gq1REZGVlkfmR0hhLA5BkBN47Z0z7ULFy7g4OBQJs3b2xtvb2/zv7Ozs9HpdPj5+eHs7FyuLEdHR3x9fcnIyCA/Px9PT8ubCTk5OfHee+8xbdo0tmzZwpYtW8xpzZo1IyoqiltuuaXKuksQFkLYHCOgUZkfYMyYMaSnp5dJmzZtGk888YT534WFhQC4ublVWJ6rqytApUEYIDg4mHvuuYdPPvmEjh070rhxY44ePcrFixeJioqiY8eO+Pj4VFp3CcJCCJtjRIOaMGz8O290dLTFlvCVSvtyq6Oy7ojMzEzGjBlDWloan3zyCb169QJAp9Mxd+5cNm7cyLRp0/j0008rvYYEYSGEzTEqqOqOMP6dNyAgoMopau7u7oBpKllFioqKyuS1ZOXKlZw5c4bnnnvOHIABnJ2dmTNnDgcPHuTAgQMcPHiQHj16VFiODMwJIWyOAY3qV3V5enri7u5OZmZmuVkNYJr/m5mZiYuLS7lW9JV+//13AIv9vk5OTvTp0weAY8eOVVofCcJCCJtjVBmAjSqCsEajISwsDIPBQGJiYrn0hIQEjEZjmfnDluTk5ACU6/4oVXq8pKSk0nIkCAshbI5R0ah+qdGvXz/AtOz4aqXH+vfvX2kZpdPbdu3aVS7NYDCwb98+ANq1a1dpORKEhRA2x4DaLgl1Ro4ciYuLCytWrODo0aPm40eOHCEqKgpXV1fGjBljPp6cnMzp06fJzc01H3vggQcAWL58OX/88Yf5uF6v58033+TkyZO0bduWm2++udK6yN4RQgibUbp3hNHv/0DF440wNEV7eXm1944A09LluXPn4uTkZB5Y279/P3q9noULF/Kvf/3LnHfQoEGkpqYyf/58Ro4caT7+zjvv8NFHH6HRaLjxxhvx8/Pj+PHjnDt3jiZNmrB69WrCwsIqrYfMjhBC2ByjogE1XQyKRvXX+rFjx9KiRQuioqI4dOgQzs7OdOvWjcmTJ9O7d+9qlTFjxgy6devG2rVrOXLkCEePHqVZs2Y8/PDDPP744zRr1qzKMup1S9hoNJKfn4+TkxMajbo+IyFEzSmKQklJCR4eHqrm5Za2hIt9p6huCbtkfqCqJWwr6nVLOD8/n5MnT1q7GkI0WOHh4Xh5eak+z6hoUZTqB2+Niry2pl4HYScnJwDSPOZh0GZauTZ1o0XuW5zzes7a1agz6yYNsnYV6sxzi4bx1jPfW7sadcLb143HXx5g/htUy4gGRUUHg0bVImfbUq+DcGkXhEGbicEhw8q1qTv1+d6y0gusXYU6Vd/vr6bdgAY0KGrm/koQFkKI2mNUtBhVdDFopTtCCCFqj1HlKjh1e67ZFvv9+BBCiHpAWsJCCJtjQItRRRtRzSCerZEgLISwOUZFg0FNP6/KvSNsiQRhIYTNMapsCatfL2c7JAgLIWyOQdFgULls2V5JEBZC2BwjWgzSEhZCCOswom6esJquC1sjQVgIYXNMewTLsmUhhLAKo8o+Ya30CQshRO1ROztCuiOEEKIWGRStqnnCsneEEELUIkXl3hFqdlyzNRKEhRA2x6ByxZyqOcU2RoKwEMLmGFTOE1aT19ZIEBZC2BxF0Zge9qkiv72SICyEsDnSEhZCCCsyKhp1K+bsuCVsvx8fQghRD0hLWAhhc4xoMKiYdqbuUUi2RYKwEMLmqH3Qp5q8tkaCsBDC5hhUtoTV5LU1EoSFEDZHUdkSVqQlLIQQtceAyhVz0hIWQojaY1S5d4QMzAkhRC0yKuoWa8jAnBBC1CKjorIlbMeLNSQICyFsjixbFkIIK5KWsBBCWJFpU3cVU9RkYE4IIWqPQVG5WENawkIIUXukO0IIIaxIUdQ9bVlWzAkhRC2SvSOEEMKKjKh7vJE9r5iz3za8EELUA9ISFkLYHNPAnIply2iw18awBGEhhM1RVG7gI/OEhRCiFqmeJywtYSGEqD1GlVPU1OS1NRKEhRA2R1G5WEO6I0S1FGVrObC0MWe2eVJwyRE3PwPB/fLpMS0D70B9tctZM6A1ualOf/9rARBeYd4Rn6YQ2KuwzLGLR12IXeHHuQNuFGU54N5YT6sB+fR8IgOPZoYa3FnD4OmpY8z4Y/Tpew5fv0Kys13440AA69e05+JFD9XluTim8tSzB7mh60X8/Ioo1jmQcLoRP37Xmh3bW1WrDAcHI+8t/4nWodnMfOZWjvyvmep62CLZ1F3UuqJsLTGjg8g844KTh4HGEcXkpDhx/ItGnNnqyYh1KTRpp6tWWc06F+EZYArazvq26BxPlUnPOetEfpojDs5GPALKBvdjG73Z+bI/ikGDe1M9vqE6Ms8489dnPiT85MnIz1JoFFxSOzddj3h66nj7vZ8JbpVLQb4jiWd8CGiex9BhifTpm8rMZ/qTeMan2uXd1Psc7ZrNpsOwEoqLtaSkeOHjW0TnG9LpfEM63Xte4K35N1FVR+eDY4/TOjT72m7OBhkVdYHVWId1qWsShK+TnS/6k3nGhVb987j93fM4eyroizXseqUZJ2IasfWp5jy4JQmtQ9Vl3bH0vPm/g7JeI8VnovnfhZe1fHZ3CAC3vnoRn1b/BNSLR13Y+ZI/igJ9X7hIl39nodFCfpoDPzzRgguxbux8uRn/Wp1aa/ddX0yf8QfBrXL5fV8AC//Ti8JCJ5ycDEx76hC33ZHErJf2M+XR2zEaqw4cPr5FPD/7d7QaPd9/25qPPriB4mLTn2LvW1KZMfMAA4ekEHfCj6+/bFthOSGtsxk95kSt3aMtaUh9wjZb87179zJ+/Hh69epFt27dGDduHLt377Z2tWok87QTp7d64uRhZMjbF3D2VABwdFEYOC8N3zbFZJ524cxWz2u+1s6X/Cm45Ejo7bl0uD+nTNreBU1RjBq6PZbJDZGmAAzg4W9gyNsXQKNwdq8HOany2XyllkE59OmbSkGBI28vuInCQlNXUEmJA0ve6UFykhfBrXLp3bd6H15DhyXg7qGnQNea99/tZg7AAL/9GsiqlZ0AGHHfqYqKQKtVeOrZg2g0UFJiv1/FK6IophVz1X0pdryBj00G4ZiYGCIjI4mNjaVLly507dqV2NhYJk2axIYNG6xdPdXiNnuDoiFkYB6uPmW/OGkdoN19pmAZ/53XNV0n4ScPzmzzwtnTwK1zLpZJyzvvSOrvbjh5GOj+fxnlzm0UXELfFy7R7+WLODgq11SP+mbQkGS0Wvj9t+bk5TqXSTMaNWz7IQSAWwekVKu8LjdeAiCrsKfF4PH7b80BCGhegKen5S6qkaPjCG+XSczGcAoKnCzmsWelfcJqXvbK5po8aWlpzJkzBy8vL6KjowkPNw06HT58mMjISN544w0GDBiAv7+/lWtafWn/cwUgoFuRxfSAG03Hzx10q/E1jAb47a0mAHSfcrncANvZfW6gaGjZu9DcEr/aDROyanz9+iyi/WUAjv3V2GL6ieN+AHTsnF6t8tZ80pEd24O5c0IP4Pdy6S5u/7x3Wofy71Vgy1zGjj9G6llP1q3uwNA7E6p1XXuieu8Ijf0GYZtrCa9btw6dTseECRPMARigS5cuTJo0ieLiYrtrDWcnm1pP3i0tD3h5BZqOF6Y7osuv2S/TiU3eZJ52wcO/hBvGZ5VLv3zSBQDfNqaWVeJOD36a5c/mfwey9akA4r/3RJEGsEXNW+QBkHbB8gyIi2mm435+xbi6Vj3LJe54Y37aGkKRPshieu8+5wDIynQhJ9v5qlSFJ589iJOTkSXvdKekpBqDCHZITVdE6cte2VwQ3rNnDwBDhgwpl1Z6zN76hgsvm/5QXH0sT/9yafTP8aJM9X9UigJ/rvQFTK1ZB5fy0TT3vOlLj7Onge+mtGDLpEBObGrE2b0enNrizY/TW/DtpEBKCu33l7muNPIpBiAn5+qAaJJ7xXHvRsXXdC1f3yLueyAOgJ07grh6dsTwe+Pp1DmDH75rzdHDTa/pWrasIfUJ21R3hKIoxMfHo9VqCQ0NLZceEhKCVqslPj4eRVHQ2MlXEEORqZ6OrpYn0ji6/hM09UXqPxfP/upO5hkXnL0MdHzA8nSlkjxTuX9+7Isu14Gbn71E+1E5OLkbSdrpwa45zUje5cHuV5sxeGGa6jrUZ87Opg9JXbHlD0id7p/jLi41n2ft4qrn5bl78fIqITvLmc/XtyuT3sw/n38/cpT0dFc+/qhLja9jD4yKuqdl2PMUNZtqCWdnZ6PT6fDx8cHZuXyrw9HREV9fXwoLC8nPz7dCDWtGU0XjVrniN0ijUd8ncGSdDwAdRmfj7GX511GvM73VRZmO9Hoqne6PZ+Le2ICTm0LYsDxuX3wBgBNfenM53nKLr6GqatrZle9ZTbt0XF31vPrGr7TrcBmDQcNb828iK9O1TJ4nZ/yBm5uBD5Z0oyC//g3GXakhDczZVBAuLDSt7HJzq3iAytXV9ItpT0HYyc0UGPXFln/cBt0/v0AOrur+inWFOpJ3uwMQPjy3wnyOLqY6OHkYuSEys1x60C0FNOtSBIqGxJ/Vr/6qz4qK/u7KcbbcynVy+ueDr6LWcmW8GxUz/+1d3HDjJQwGWPxmDw4dDCiTZ+idZ+ja/SJ7drZk394Wqq9hbxpSn7BNdUdotWqeKVX9YNUi962aVKfWeHovpzgnC+/UGQSFtCmXnnk+G/gQgLYOy3DOqn4r5+i+OAw6LU2C/ejWYhZkWc7n6/oNSfyFf3ALQgpegILyeYKCt3Dx8BGU07cTlDW02nWoS2+ssXYNwNltD5DGtNduIqf4xnLpTg6XgK8AeOqdB1AUl2qX/da6voQ1mY+LYyaK4kBK9mQGj7+FweOvKF97mXb+36E3euAT8SJvrPEpU4aH5w+Ajkdn9ydP10Ht7dkkRWVglb0jaom7u6lFV1xc8eBGUVFRmbzVcc7rOQwO5efGXi+eYS3IOOvJmaz3cfcp32d77qQbEIR7Mz1pAY+rKvvEL6MAaHXXqTIr567mHOEHPzRB55hYYb4CV3+gEQUeO0jxsY0ZKMuH32XtKvDqGxpuuhm+/3Qr331zulx6p86XePNdyEh35YVx31a73Heie+Dv+CoujkUUFTowb+7NHPz9ArCpTL4hQxPp9LzpU7Nz88kVlte26esArFvdnnVrOla7HnXBp4k7zy0aZtU62AubCsKenp64u7uTmZmJXq/H0bFs9fR6PZmZmbi4uODt7W2lWqrXrHMxSTs9ufA/VzqNLR+EL/xp6mLxv8HyPOLKJB8xrdK6epOeq5WWfTneGX2RpsxgYKmsRFML3DtI9o640qk4X266+QLtOlzmu2/Kf5Np18E0jzjuhF+1y2wRmEtYk3k4ORSRm+PEnBf7cuKY5XnIWZku/HXEchqY5jE7OioknvEmP9+Jixer30CxVWq7GOy5T9imgrBGoyEsLIzDhw+TmJhIWFhYmfSEhASMRmOZ+cP2IPT2XA4sbUzCNk+Ksi6VWTVnNMCJGNMHSsTwnIqKsKikUMOlJFMAaNqx8gDesncBrr56ijId+euzRuUWZqQfd+b8H26gUWh9W56qetR3v/4SyNh/H6d3n1Q8vW4os2pOq1UYMjQRgJ+3B1erPBcXPXP+sxcnh1yys5yZ/dytlW7+c/D35hz8vXmF6etjvqZRIx0fvn9j/dlFrQEFYZsamAPo168fANu3by+XVnqsf//+17VO16pJOx2tBuShyzNtlFOUafqx64s1/PyCP5mnXfAJ1RF6e9ngV3hZS+ZpJ7KTLPcRXz7pgmJUcG+qL7cc+mpaR+j1lKlL5re3m3Dyay/zSH5OqiPbn28OioaIf+Wq2lazIUg848Pv+wLw8NTz4pzf8PI2dZc5ORl4csZBglvlkpLsxd5fAsuc5+1dTMugHAKal31fHxh7gqDgXBRFw7y5N6vafa2hUDDN/a32y46DcIUt4V27dtXKBdQGzJEjRxIVFcWKFSvo27cvnTqZNjM5cuQIUVFRuLq6MmbMmFqp2/U0YO5FYh5yIXWfO6v7h+LbRkdOihPF2Q44exkYtuyceUOdUkc+9eXA0sZ4BZYwfmf5pan5l0wj8S7e1Zub2vGhbC7HO3NkrS/bZjTnt7ea4Opn4PJJF4x6Dc26FNH3pYtVF9QALV3cjbeX7OSGrpdYHf0dKcneBDTPw8u7hLw8J/4zp3e5BQP3jIhn7L+Pk3bBncixdwLg6GTg7n+Z+pWNigvjI/8C/qrwuvNe603mVVPVGgLZTxh4/PHHr3kxhEaj4dixY6rOadmyJTNnzmTu3Lk8+OCD9OrVC4D9+/ej1+tZuHAhjRtX3D9mqzyb6xn9ZRIH3m9Mwk+eZMS54OJloO3dOdz0ZAY+Ier7YUtX11U0N/hqGg3c+solgvsWcHitDxePuFKU4IBPqI6I4Tl0+XeWxb5iARnp7kyfPJgx445zc59zhIRmkZ/nzM6fgvh0dQfOpVZv86XWrbPx9DS91w7aIjp2rrwbyamCaXH1naJysYY9L7nXKBXM9Ro0aFCtXGDHjh01Ou/nn38mKiqKY8eO4ezsTEREBJMnT6Z3797VLqO4uJijR49afXZEXQrK+rjSWRH2zhZmR9SVN9bcx4vjN1Wd0Q6Vzo7o1KkTLi7Vn7JX+jf7ata3XDZamEdZAT+tO6/63K36eragwpZwTYNnbRk4cCADBw60ah2EENahemCuhos19u7dy/Lly4mLi6OkpISOHTsyadIkbr311mqXkZ+fz8qVK/n+++85e/Ysbm5udOvWjalTp9K5c+cqz7e5gTkhhFA1KFfDDXxqY9/yrKwsHnroIZYtW0Z+fj79+/cnICCAn3/+mTFjxnD48OEqy6jxFLXLly+zb98+EhISyMvLY+bMmRQXFxMbG8vNN99c02KFEKLOW8K1tW/5/PnziYuL46677mLBggXmPW9WrlzJm2++yUsvvcTXX39daRmqW8IlJSXMnz+fAQMGMGPGDN5//31WrVoFQHJyMpGRkYwcOZK0NNmJSwhRQ4ppsK26L1QOzNXGvuXnzp1j8+bNBAUFlQnAAI888ggdO3aksLCQy5cvV1qOqiBsNBqZOnUqa9asQa/XExERQaNGjczp+fn5aLVajh07xkMPPURmZvmNYoQQoip1vYtabexbvnXrVhRFYezYsRZ3fYyJiWHbtm34+VW+klJVEN60aRO7d+8mNDSUr7/+mq+++qrMvr833ngjP/zwA23btuX8+fOsXLlSTfFCCAHUbZ+w2n3LK1I6/bZz587k5+ezceNG5syZw+uvv8727durvcmYqj7hTZs2odFoeO+992jTpvwaeoCgoCCWLl3KXXfdxY4dO3j22WfVXEIIIdQ/Y+7vlvCFCxdwcCi7nai3t3eZvWZK9y338/OrdN/yjIwM8vPz8fS0/BT05ORkwDQ4d88995Ca+s/Ttj/99FN69+7N+++/X+H5pVS1hE+dOkVoaGiFAbhUSEgIISEhnD17Vk3xQggBqOsPNvcLA2PGjGHw4MFlXqtXry5Tdm3tW56ba9q/e/bs2fj4+PDZZ5/xxx9/EB0dTUREBL/99htz5syp8l5VtYQNBkO19/x1cnIq94kkhBDVYQqs6lfMRUdHW2wJX6m29i3X6UwPzXVycmLVqlXm63Tv3p2VK1cydOhQtmzZwrRp02jdunWF5ahqCQcFBZGQkFDlaF96ejrx8fEEBVl+mqwQQlRKbX/w3wE7ICCAli1blnldHYRra9/y0tby3XffXe4aTZs2ZdCgQSiKwu+//17praoKwkOHDkWv1/PKK69QUmJ5rwOdTseLL76IwWCwOPIohBDWdPW+5Ver7r7lpbMeAgMDLaaXHq9qlpiqIBwZGUlwcDA//fQTI0aMYNGiRVy6dAmAbdu2sXz5cu655x527dpFQEAAEyZMUFO8EEIAdfuMudJ9yw0GA4mJieXSq7tveWn6xYuWdx4sjY1VbTimKgh7eHjwySef0K5dO06fPs2KFSvMg2/Tp09nyZIlJCUl0apVK6Kiouzq6RdCCNtR04G56qqNfctL95fYvn17uRa1Tqdj//79gKmPuDKqV8wFBgayadMmlixZwj333EP79u0JDg4mIiKC22+/nfnz5/PNN99UOYNCCCEqUtd7R4wcORIXFxdWrFjB0aNHzccr2rc8OTmZ06dPm2dEAPTp04d27dqRmJjIvHnzMBhM244ajUbefPNNzp49yy233GJxLvKVarR3hFarZejQoQwdahtP5BVC1C/qF2CoC8Jq9y2fMGECqampzJ8/n5EjRwLg4ODAokWL+Pe//826devYuXMn7du35+TJkyQnJ9O8eXPmzp1bZV2u6Rlzly9fJjExkaKiIry8vAgNDcXDw+NaihRCCNRuB1GTPd3Hjh1LixYtiIqK4tChQzg7O9OtWzdV+5a3adOGr776iuXLl7Njxw527dpF06ZNGTt2LJMnT6Zp06ZVllGjIPzdd9+xcuXKck/N0Gq19OzZk6lTp9KzZ8+aFC2EEOZnzKnJXxPV3be8sv3VmzRpwksvvcRLL71UozqoDsIvvfQSmzZtMk9i9vLywt3dnfz8fPLy8ti3bx+///47zz//vMyOEELUzPVoCtsIVUH4m2++4YsvvsDZ2ZnJkyczcuTIMvttnj17lujoaFavXs3ChQtp166d7C0shFBP7WBbDZ+sYQtUzY5Yv349Go2Gd955h8mTJ5fb8Lhly5Y8//zzvPrqqyiKwooVK2q1skKIhqGup6jZElVB+MSJEwQFBXHbbbdVmu/++++nefPm/O9//7umygkhGqbr8XgjW6EqCDs6Ola6lvpKvr6+1d5PUwghylAwdTFU+2XtCtecqiB80003cerUKRISEirNl5aWxqlTp+jWrds1VU4I0TBJd0QFZsyYgbu7O5MnTyY+Pt5inrS0NKZOnYqjoyMzZsyolUoKIRoYpQYvO1Xh7Ignn3zS4vGAgABOnTrF8OHD6d69O+3atcPd3Z3CwkISExPZv38/Op2Ofv36sXXrVtq1a1dnlRdC1E/Xa56wLagwCP/444+Vnmg0Gjlw4AAHDhywmL5792727NnD9OnTr62GQoiGR+YJw7Rp065nPYQQwqyu946wJRKEhRDCiq5pAx8hhKgT0h1ROYPBQFpaGoWFheXmAuv1enQ6HRcvXmTHjh3MmzevVioqhGhINH+/1OS3T6qD8IoVK1ixYkWZzY0rI0FYCKGatIQt27p1K++880618gYHB3PHHXfUqFJCiAauAQVhVYs1Pv/8cwDzwzz37duHg4MDo0eP5siRI2zbto3HH38cBwcHjEYjjz32WJ1UWghRz6lasvzPI+/tkaogfOzYMdzc3Hj11Vfx9/fHx8eHsLAwfv31V5ycnAgKCuLpp5/mySefJDU1ldWrV9dVvYUQ9ZgsW65ATk4OQUFBZR5h1LZtW86dO0d2drb52Pjx43F1deWnn36qvZoKIRqWBrBkGVQGYXd3dzSass3+oKAgAE6fPm0+5urqSkhICElJSbVQRSFEgyPdEZYFBQWRkpJCQUGB+VirVq1QFIXjx4+XyVtUVIRer6+dWgohGhSNov5lr1QF4b59+1JQUMDLL79MXl4eAJ07dwZg06ZN6HQ6AA4fPkxiYiKBgYG1XF0hRIPQgHZRUxWEx48fj6+vL9999x39+vVDp9PRpk0bevXqxfHjxxk5ciTTp08nMjISMAVtIYRQTbojLGvcuDEff/wx7du3x9nZGWdnZwBefPFFvL29iY+PZ+vWreTn59OiRQumTJlSJ5UWQtRzDaglrHrFXPv27YmJieH8+fPmY+Hh4WzZsoVNmzaRmppKSEgI999/P15eXrVaWSFEA9GAFmvUeAOf5s2bl/l3kyZNePzxx6+5QkIIIUFYCCGsSm0/r/32CVcYhEeNGnXNhWs0GjZu3HjN5QghGha1087seYpahUH46NGj11z41Qs7hBBClFVhEJ4/f/71rIcQQvxD+oTh3nvvvZ71EEKIBqlBDMytHRhK5vnG1q5GnVhwAJa1Dbd2NerMj+fq75hCbOp9fPdT/by/Yn1TjqUNq/H50icshBDWpKBudoQEYSGEqEXSJyyEEFYkQVgIIaxH+oSFEMLa7DiwqiFBWAhhe6Q7omoGg4G//vqLM2fOkJeXx8MPP0xJSQnnz58nODi4NusohGhgpDuiCmvWrOGjjz4iIyPDfOzhhx8mJSWFu+++myFDhjBv3jw8PT1rraJCiAZE7Ubtdrypu+og/OKLLxITE4OiKDRq1AidTkdRUREA6enpGI1Gtm3bRkpKCtHR0bi5udV6pYUQ9VwD6o5Q9WSNH3/8kU2bNtG0aVNWrFjB/v37ad++vTn9pptuYu3atTRt2pQTJ06wevXqWq+wEKL+kwd9VmD9+vVoNBqWLFlCv379LObp2bMny5YtQ1EUvv/++1qppBCigZHHG1l27NgxgoKC6Nq1a6X5OnfuTKtWrUhKSrqmygkhGii1rVs7DsKqWsLFxcW4u7tXK68MygkhrkkDaAWDyiDcvHlzEhISKCgoqDRfXl4e8fHxBAQEXFPlhBCivlMVhAcOHEhxcTELFiyoNN+8efPQ6XT079//mionhGigpE/YskmTJrF582Y2btxIcnIyw4YNIzs7GzD1F58+fZrPP/+cgwcP4u3tzcSJE+uk0kKI+k0Wa1TAz8+PFStWMHXqVPbt28f+/fvNaffddx8AiqLg6+vL0qVL8ff3r93aCiFEPaN6sUbHjh359ttv2bBhAzt27CA+Pp78/Hzc3Nxo1aoVAwYMYMyYMfj5+dVFfYUQDUEDWqxRo2XLnp6ePPLIIzzyyCO1XR8hhJDuCCGEsCppCVv21Vdfqb7AiBEjVJ8jhGjgJAhbNmvWLDSa6u1WpCgKGo1GgrAQQjXpjqhAhw4dKgzCRUVFpKenk52djUaj4e6775bBOSFEzdlxYFVDVRCOiYmpMs/BgweZNWsWR48e5YsvvqhxxYQQDVdDagmrWjFXHT169GDJkiUkJiaybNmy2i5eCNEQNKAVc7UehME0lzg0NJStW7fWRfFCiPquAQXhOpui5uDgwKVLl+qqeCFEPSbdEdfo0KFDxMfH06RJk7ooXghR30lL2LJ169ZVmq7T6UhISOCbb74BYPDgwTWvmRCi4ZJ5wpa9/vrr1ZonrCgKwcHBTJkypcYVE0I0XA2pO0JVEO7Zs2flhTk64u3tTdeuXRk1apQ8XUMIUXN2HFjVUBWE165dW1f1EEKIBknVwNzEiROZNWsWOTk5dVUfIYSQR95X5H//+x+//fYb3t7edVUfIYS4brMj9u7dy/jx4+nVqxfdunVj3Lhx7N69+5qq/uijjxIREVHmoReVUT1FrVGjRqorJYQQqlyHIBwTE0NkZCSxsbF06dKFrl27Ehsby6RJk9iwYUONqh0dHc2ePXtUnaMqCA8fPpxTp07x008/qbqIEEKopVHxUistLY05c+bg5eXFpk2bWLFiBStXriQ6OhpPT0/eeOMN0tLSVJWZlJTEW2+9pbouqgbmhg8fzvHjx5k2bRo33ngjN954I82aNcPZ2bnCc8aOHau6UkKIBq6O5wmvW7cOnU7H448/Tnh4uPl4ly5dmDRpEosXL2bDhg1Mnz69WuUZDAZmzpyJk5MT4eHhnDx5stp1URWEH3roITQaDYqiEBsby59//lnlORKEhRBq1fU84dIugyFDhpRLGzJkCIsXL2b37t3VDsJRUVHExsby9ttvs2nTJlV1qdV5wkIIUSvqsCWsKArx8fFotVpCQ0PLpYeEhKDVaomPjzc/nKIyJ06cYOnSpQwdOpR77rmn9oLwuXPncHFxoXHjxuZjMk9YCHFd1DAIX7hwAQcHhzJJ3t7eZWZ0ZWdno9Pp8PPzs9iV6ujoiK+vLxkZGeTn51e66Eyn0/Hcc8/h7e3Nq6++qqLCV1yvooRBgwbRo0cPPv300xoVLIQQNaVBZXfE3/8/ZswY0tPTy6RNmzaNJ554wvzvwsJCANzc3Cosz9XVFaDKILxkyRJOnjzJsmXLavwkoUq7IxTFjmdACyHsVw1bwtHR0RZbwlfSaqs/KayyGPjHH3/w8ccfM3z4cIt9y9Ulj7wXQticmg7MBQQE4OLiUmled3d3AIqLiyvMU1RUVCbv1QoKCpg1axZNmzbl5Zdfrn5FLZAgLISwPXU4MOfp6Ym7uzuZmZno9XocHcuGQb1eT2ZmJi4uLhWuDl6/fj3JyclEREQwd+7cMmnx8fEALF++nI0bN/Lggw/So0ePCusjQfg68myk5+Fn0ugzLBu/ZnqyMxw4uNObdYv8uZha8Vzr6tBoFN79Jp7mIcWM7tSp0rxhnQsYPfUinXrl4+1rICvdkd+3e/PpIn8uX3S6pnrUZ7lZDny6KIC93zfi8kVHGjXW02NALmOfuYB/yxLV5WWn5bDkvZYc3OHN5YuOuHsa6dAjn9FTL9LxpvxqlaEvgWl3RJBw3I03v4jnhj55quthi+pyippGoyEsLIzDhw+TmJhIWFhYmfSEhASMRmOZ+cNXKygoACAuLo64uDiLefbu3QtAnz59ah6EMzIy+OqrryrLUqURI0Zc0/n1hWcjPYu/jie4bTH5uVoSjrvSPFjHHQ9d5pZh2Tx3XxsSjlc8UFCVCTMv0K5bAdmXHSrNN/ShDJ5ceBYHR8hIcyQl3oWgsGLuGp/BzUOzeeZfYVxIrvzrXEOUm+XA08PbkhLvirungdbtizif7MyPnzXm1+8b8dameEI7FFW7vMQ4V957+BPys5rg7GokqG0xGeed2LetEb/v8OapN1MY+tDlKstZvyTgmn5vbFYdL9bo168fhw8fZvv27eWC8Pbt2wHo379/hec/8cQTZQb7rjRhwgR+++031qxZQ69evaqsS6VBOCkpidmzZ1dZSEU0Go0E4b899dZZgtsWs3+7F/Mnt6Iw3wEnFyPTF5zl9gcymf1hEv83KAKjUe0iTIWHZ1zgwekXq8wZ1rmAJ988i0YDy19pwVcrm6AoGvz8S3h5RSIdehTw1FtnmfVAm5rdZD327nNBpMS7ctPgbGZ/mIS7pxFdkYb3ZrVk2+eNmT85hOU7TuBQ+Weg2VvTg8nPKuSGW3J5YXkiPo0NGAyw9u0A1i8JYOnsltxwSx4BwboKy0g47spnS5vV0h3amDoOwiNHjiQqKooVK1bQt29fOv397fHIkSNERUXh6urKmDFjzPmTk5MpKSmhWbNmeHl5qbtYFSoNws7OzmXmCYuaCQor4pY7synI0/LW9GAK801/qSXFWhbPCCKiawGtwovpMyybX7b4VLtc36YltPZbRNcZ1Vvj/tgr53BwgM+WNuPLqKbm45fTnFg4LZhP9p6ga788mgXqrrl7pD5JPuXCr981ws3DwHPvJePuaQTA2VXh6XdSiIv1IPmUK3u/b0S/u7OrLC/ppAvxR9zRaGDm0iR8GhsAcHAwfaP5Y5cXJ//04OevfHiogg9XgwEWPROMomhwdDKiL6mTx0VaTV2vmGvZsiUzZ85k7ty5PPjgg+YW6/79+9Hr9SxcuLBM7JswYQKpqanMnz+fkSNHqrtYFSoNwp06daryuXLXQ0xMDLNnz2bdunWV9q3YqkEjM9FqYf82b3Kzyv7IjUYNWzf4Menl8/QfnlXtINytfy4vfZSIh5uRjDRHvlrZhEdeuFBh/ibNdXTunU9+rpbP3ivferqQ7MJ/57TAqIBeX5MtUeqvHTG+KIqGXrfl4O1rKJPm4AC3P5BB1H8C2fW1b7WCcPp5U7+7eyM3Ggfoy6WHdS7k5J8elX4QfvFhM07+z53RU9P4IboxOZn1KwhfD2PHjqVFixZERUVx6NAhnJ2d6datG5MnT6Z3797XrR42PzAXGxvL66+/bu1qXJN23Uyd+McOelhMP/GHaRpMp17VG4wBaNW2CDcPI5cL+vH4oMu0bld5f+SNt+Sh1cL/fvU0t8Sv9tXKphaPN3QnDpnetw49LL8/7bqb3t+j+y2/v1dr2sI0iJefVUj6eSeaNC87qJcUZ1oo0CzQclfE2dMufLoogMDQIsbNuMAP0fX02+p1WKYwcOBABg4cWGW+HTt2VLvMVatWqaqDTX98/vjjjzzyyCPmkUh71SLE9Md0Idlyyybt7xaPXzM9ru4Gi3muFvenO1OHhpOUOYXczKo/S1v9HaSTT5n+wHsOyuGZRcks2HCaWR8k0e/uLBrMQ71UOpdoen8q6p/1/ztYZl5yojC/6j+p4LbFdOhhmsXw1pPBZGeYPhQVBTa834y/fvfEzcPAkFGZ5c5VFFg0I4iSYg1PvZWCs2v9fM80iqL6Za9ssiV84cIFFi1axObNm3Fzc6NJkyblliLak0aNTV85czItt0BzrzjeyM9AUUHVozsVtaor0izQ1NoqyNXyysoEbhlW9hFVA0dk8ftPXvznsRCKC236s/m6y84w/Zl4+5bvOgDwuqKLIvuyI24eFQ+mlZrzcSIvPno3f/6SyLieHQkMLSbzkiOZl5wIblvE0+8km1vMV9q8sgl//e7JnQ+n06V39b852Z0G9Mh7m/xre/fdd9m8eTOdOnViw4YNFnc6sifOrqaBHF2R5R/3lcdL89Y2Nw9ToBj5+CV6Dclh5bwARnfuwPA2nfnPY63IynDgpsG5TJt3tk6ub89K35+K3psrj+uKqtef7uRsJLhTC1xcjRQXaTlzzI3MS6a+Yj//Epycy0eVCynOfLKgOY0DdDz60jm1t2FXGtIz5ipsCU+bNo3mzZtfz7qYhYaGsnDhQoYPH65qnbetMho0ODhU/FuiuQ636Oxiur5PYwMr32jO58v+GZzb860PedkOLNhwhiH3Z/L5smakxLvWfaXshNZBqXTqoKLyczMv24HnR7Xh9F976d4/j0dePE9weBEZF5z4ckVTvlrZlGdHhjH/s9N06PFPV9y7zwZRVODAzPeT8PCumw9rm9GAWsKVBmFreeyxx6x27bpQVKDFydmAk4vlPxwn53+O11VXQGkLrSBPS8xHTcqlx+7xIi7WjYiuhfS6LUeC8BVc3Y3kZWspKbb83pTo/jnu4lZ1cPz8g2ac/sudgLCmzF3zJ45/L1IMCNYx+fVUnJyNbPzQn2UvtGTZVtMTGr5b50fsHi/63ZNJnzsawNPO1bZu7TgI238z0w6U9vl6+VgedPO+qk+xLuTlmOqQEu9S4ZzSpJOmwBsQVHWfZkNS2uebm2W5rz6nTJ++5X7jK/26xfSw3FvH9TIH4Cs98MRFtA4K8UfdSU1wJv28E1GvB+Lpo2fqf1JrcAd26Do9bdkW2OTAXG2b+fVkq17fo/GbQCz/t2wg6fm3lU93Pg7MpcTgw2u7X1Bd/oIDs/B0Pga8jkcjNxYcmFUuj79XDLCRlh2aW0wHCPb5L7CTXqN60vK2f6uuR12ItYGY06jlRs4nnubgkck4RnQrl34mNhmIxquJJ8cz10P5SQ1lXDj7FmCgaavGxKZ+ZjGPh89ScjPy2fvnXLLScsjP+Q6AB2+oeF+Q50eZlt8OnnQLtz3Wr1r3ZqvqerGGLWkQQXjh8A/JPF/1JPq68vCMC4ybASe2fsnbT/1RLv3+KRcJfwl+32pk7iMLVJW94MAsZvVcQJfeeby1CfKzC5nVs3wZ3fvnMG89OOgTeaXfPIuDhG/HxNP4Zti08DBfrVRXj7ry47k/rV0Fjt4UwIlfAsg78xldA98sl37qq2ZACzr3OEvXwAerLM/DqyPZGU7kpudZzK8r0pCf2QXQ0KX1a+Q0cuR4T/8KyzsR64FBryGkXSEeXgZuaLeeroHL1NxirSvWN+VY2tJrK8SOA6saDSIIW9uv3zVi3Iw0+tyRjZePvsyqOa1W4bbRpo1admzyrbM6xP7iRVaGAz6NDdw5NqPcwozQDoV0vCkfoxH2/tCozuphj265M8u0e9oPjcjJdCjTfWQwwLbPTU9UGHRfFU3gv3Xpk8eeb3w5+M1hxo4pn/7TJl+MRg0e3gZCOxTh5KzQc1BuheXd37ETOZmOTPlPquyiZoekT/g6SDjuxv5tXnh4G3npoyS8/p5v6uRi5Ol3UmgVXkxKvAu/fl82+Hn76QkKK6J5q4o3n64uo0HDmjcDAJj4wnkG3ptJaVOjWaCO55Yko9WaPghk34iyQjsUcdOQbApyHfjPYyHk/L1Tna5Iw+IZQSSfcqVlmyJuGVb221Z2hgPJp1zMiz1KPTD1Ig6OCsd2nSLq9eYUFfzzZ7jn20Z8NDfw73xpFqeqNQgKppUp1X5Zu8I1Jy3h6+S9WS15p108N/bN49MDx0k+5ULzYB1evgbysrW8NjEERSk7DWp4ZDrjZqRxIcWJf/fqcM112LK2McHhxYx4JJ1Zy5J55MXzZGU40rpdIY5OEBfrxoevtLjm69RH0xecZcYIN/73qxcP9+xAcNtizic7k5fliIe3gTkfJ3D1bMqvP2nKp4sC8G+pY83vx8zH23Yp5Km3Ulj8bAgbP/Tn2zVNCAwt5tI5J7IzTCN1t42+zOhpVe+MV19JS1jUuvTzzky7I5wvo5qQleFA6/ZFGAwafv7ShyfuDL9OU8I0fPhyIK+Mb83BnZ64uhkJalNMSrwrK99ozrP3hZGXLZ/LljRtUcL7P8Qx4pFL+DQ2kHDcFQcHhQEjMln6XRzBbdV9W7n9gctMW/NvBt93GQ9vA4knXDEYNHTtl8tLHyXw7LvJVPGk9fpNZkeIupCb6cjyVwJZ/kpgtfJ/+k4An74TUK28h3/zZGiLG6qVd/92b/Zvt/zYFlExbz8Dk19PZfLr1ZuyMe7ZC4x7tuKd7VqE+3PX0uRrrtfGv45ecxm2RmM0vdTkt1cShIUQtkdWzNmWtWvXWrsKQojrSIPKPuE6q0ndkz5hIYSwIrtoCQshGpjSqWdq8tspCcJCCJvTkKaoSRAWQtgeGZgTQgjrkZawEEJYk/QJCyGEFTWgTd0lCAshbI/0CQshhPU0pMUaEoSFELbHqJheavLbKQnCQgjbI90RQghhPTJFTQghrEmmqAkhhPVIS1gIIaxJ+oSFEMJ6NChoVHQxaOw4CksQFkLYHuPfLzX57ZRs6i6EEFYkLWEhhM3RKCq7I2R2hBBC1CIZmBNCCCuSecJCCGE9Mk9YCCGsSUFlS7jOalLnJAgLIWyORgGNimln0hIWQojaJH3CQghhRTI7QgghrEjlPGFpCQshRG2S7gghhLCiBrR3hARhIYTNkV3UhBDCmqQ7QgghrEiCsBBCWJH0CQshhPU0pK0sZVN3IYSwImkJCyFsj2zgI4QQViQDc0IIYU0qg7AdN4UlCAshbI/MjhBCCOtpSLMjJAgLIWyP9AkLIYQVGRXTS01+OyVBWAhhe6QlLIQQ1iSzI4QQwnpksUb9oPz9Jno387JyTeqWb/NG1q5CnSnWN7V2FepUfb0/ncEP+OdvUDXpE64fSkpKAJgc9bCVa1K3Zn492dpVqDPH0qxdg7p1LG2ptatQp0pKSnB1dVV/omI0vdTkt1P1Ogh7eHgQHh6Ok5MTGo3G2tURosFQFIWSkhI8PDxqWoAMzNUHWq0WL6/63RUhhK2qUQu4lHRHCCGENV2f2RF79+5l+fLlxMXFUVJSQseOHZk0aRK33nprtcvYtWsXa9as4ciRIxQUFNC0aVP69evHlClTCAgIqPJ82U9YCGF7Srsj1LxUiomJITIyktjYWLp06ULXrl2JjY1l0qRJbNiwoVplfPTRRzz22GPs3buX1q1bm4P3hg0buPfeezl9+nSVZUhLWAhhe+p4ilpaWhpz5szBy8uL6OhowsPDATh8+DCRkZG88cYbDBgwAH9//wrLiI+PZ/Hixbi7u/Pxxx/TtWtXwDQYOW/ePKKjo3nhhReqDOjSEhZCNDjr1q1Dp9MxYcIEcwAG6NKlC5MmTaK4uLjK4Ll582aMRiORkZHmAAzg5OTECy+8gJ+fH3/++SepqamVliNBWAhhe4xG9S8V9uzZA8CQIUPKpZUe2717d6VlODk5ERERQc+ePS2mtWzZEoCLFy9WWo50RwghbE8dTlFTFIX4+Hi0Wi2hoaHl0kNCQtBqtcTHx6MoSoXTW6dPn8706dMtphUUFBAfHw9Q5eCcBGEhhO2pYRC+cOECDg4OZZK8vb3x9vY2/zs7OxudToefnx/Ozs7linJ0dMTX15eMjAzy8/Px9PRUXf0VK1ZQUFBA586dad68eaV5pTvCTu3du5fx48fTq1cvunXrxrhx46r8+iRsT0xMDBERERw8eNDaVbEtivLPXOHqvP4OwmPGjGHw4MFlXqtXry5TdGFhIQBubm4VXr50jnN+fr7qqu/atYv//ve/aLVannvuuSrzS0vYDsXExDB79mycnZ25+eabMRqN7N+/n0mTJjF37lweeOABa1dRVENsbCyvv/66tathkxTFiKJiKXJp3ujoaIst4StptdVve6rd+2Lnzp1Mnz4dg8HAjBkz6NWrV5XnSBC2M7UxtUZY348//sjs2bMpKCiwdlVskxGVK+ZM/xcQEICLi0ulWd3d3QEoLi6uME9RUVGZvNXxxRdfMGfOHPR6PdOmTeOxxx6r1nnSHWFnamNqjbCeCxcu8PzzzzN9+nSMRiNNmjSxdpVsUx0u1vD09MTd3Z3MzEz0en25dL1eT2ZmJi4uLuVa0RVZvHgxL774IgaDgdmzZ/PEE09Uuz4ShO1MbUytEdbz7rvvsnnzZjp16sSGDRssjs4L6nSKmkajISwsDIPBQGJiYrn0hIQEjEZjmUZORRRF4cUXX2T58uU4OzuzaNEiJkyYoOJGJQjbFbVTa4TtCQ0NZeHChWzcuJGIiAhrV8d21fGy5X79+gGwffv2cmmlx/r3719lOQsWLOCLL77A09OTlStXcuedd6qqB0gQtiulU2t8fHwqnVpTWFhYo1FdUfcee+wxRowYoWpwqCFSFCOKUcVL5X7CI0eOxMXFhRUrVnD06FHz8SNHjhAVFYWrqytjxowxH09OTub06dPk5uaaj+3evZtVq1bh6OjIf//7X2666aYa3asMzNkRtVNrajK/UQibUMf7Cbds2ZKZM2cyd+5cHnzwQfMshv3796PX61m4cCGNGzc2558wYQKpqanMnz+fkSNHAvDee+8B0LhxYz777DM+++wzi9eaPHkybdq0qbAuEoTtSF1OrRHCptRwdoQaY8eOpUWLFkRFRXHo0CGcnZ3p1q0bkydPpnfv3pWem5WVxZEjRwDTjKVvvvmmwrz333+/BOH6oq6m1ghhc67T440GDhzIwIEDq8y3Y8eOMv/28fEhLi6uRte8mgRhO3L11BpHx7JvX02m1ghhixSjgqKiJawmr62R0QE7UptTa4SwbcZ/WsPVedWkP8JGSBC2M7U1tUYIm/Z3S7i6L3t+xpwEYTujdmqNEMK2SZ+wnVE7tUYIe+Td1FPVtDPvpvY7HVOCsB26lqk1QtgyBwcHHBwcmBz1cI3PtTcaRSaUCiFsiF6vx2AwqD7PwcGh3IwheyBBWAghrEgG5oQQwookCAshhBVJEBZCCCuSICyEEFYkQVgIIaxIgrAQQliRBOHr4OzZs0RERFh8tWvXji5dunDrrbcyefJki3tCWMPJkyfNdbzSrFmziIiIYOHChdd8jfT0dHJycq65nKp8+umnREREMG7cuGrlj4mJISIiwrx597VYunQpERERTJ8+/ZrLqsqgQYOIiIjg559/rvNridpjfzOb7VynTp3KPJpIURR0Oh1nz55lx44d7NixgzFjxjBnzhwr1rLurVq1iqVLl7J+/XrZdlM0aBKEr7MlS5bQsmXLcsdLSkp4//33Wb58OdHR0fTr149BgwZZoYaVe+aZZ5g0aRK+vr7XVM78+fNrqUZC2DfpjrARTk5OPP3003Tt2hWA6OhoK9fIsmbNmtGmTRv8/PysXRUh6gUJwjam9FErpc+vEkLUb9IdYWNKn5B85SPrly5dyvvvv8/zzz+Pm5sbH374IdnZ2QQHB7Ns2TJatWoFQEpKCitWrOCXX37h4sWLeHh4cOONNzJhwoQKd1e7dOkSK1as4KeffuLSpUsEBgby0EMPVfj47lmzZvHll18yceJEZs6cWSYtJSWFNWvWsGvXLi5cuICrqyudO3cmMjKSvn37lrmXUvfccw8Aa9asMW/LCXDgwAFWrVpFbGwsOTk5NG7cmFtuuYXHH3/cfL9XO378OB9++CGHDh0iLy+P9u3bM3ny5Ep/3mqlp6ezdu1a9uzZQ0pKCoWFhXh5edGhQwdGjx7N0KFDKzz3zJkzLFq0yLztaLt27XjooYcYPny4xfx5eXmsWrWKH3/8keTkZBwcHAgPD2fkyJHcd999drljmChPgrCNSU5OBqB58+bl0rZu3cqff/5JYGAggYGBFBQUEBQUBMCePXuYPn06BQUFuLm50bZtWy5fvszOnTvZuXMnTzzxBNOmTStTXkJCApGRkZw/fx5XV1fatm1LWloab7zxBj169FBV719//ZUnn3yS3Nxc3N3dCQsL49KlS/zyyy/88ssvvPHGG4waNYrmzZvTrVs3Dh06BECHDh1wdXXFy8vLXNYHH3zAkiVLAPD19SU8PJyUlBQ2bdrEd999x5IlS8o9PWTbtm0888wz6HQ6fH19adOmDSdOnGDSpEl0795d1b1U5Pjx40RGRpKZmYm7u7u5bz8lJcV8nzNmzOCxxx4rd25CQgKjR48mPz+ftm3bUlBQwKFDhzh06BD79u1j3rx5ZfKfPXuWiRMnkpSUhKOjIyEhIRiNRmJjY4mNjWXr1q188MEHZQZ5hZ1SRJ1LSUlRwsPDlfDwcCUlJaXCfFlZWcrNN9+shIeHK6+//rr5+HvvvWc+/4033lCMRqOiKIqSkZFhLr9bt25KeHi48u677yrFxcXmc7dv325O27Ztm/m40WhUHnjgASU8PFyZOHGikpmZqSiKohgMBmXlypVKRESE+ZpXmjlzphIeHq4sWLDAfCwjI0Pp1auXEh4errz00ktKXl6e+RqffPKJEh4ernTs2LHMvZeWHRcXV6b8H3/8UQkPD1e6deumbNmyxXxcp9Mpy5YtM6elpqaa09LT0833+NZbbyklJSWKoihKXl6e8vTTT5uv9fDDD1f4s7/Spk2blPDwcOXee+8tc/zee+9VwsPDlaeeekrJzc01H8/NzVVmzJihhIeHK927d1d0Op057cr37rbbblPi4+PNaT/88IPSqVMnJTw8XPn222/Nx/V6vTJixAglPDxc+b//+z/l0qVL5rRTp04pw4YNU8LDw5X//Oc/Zeo3cOBAJTw8XNmxY0e17lPYBukTtjJFUcjJyWH37t08+uijXL58GS8vLx555JFyeZ2cnHjyySfRaDQA5sGxjz/+mLy8PEaMGMGTTz5ZpnU0ePBgZsyYAVCmG+DgwYPExsbi7e3N4sWL8fHxAUCr1TJx4kT+9a9/VfsePv/8czIzM7nxxhuZO3cuHh4egOnBpBMmTGDAgAGUlJTw3XffVVnWe++9B8ALL7zAnXfeWebep0yZwrBhw8xf00utX7+evLw8brrpJp599lnznrIeHh4sWLCgwu4LNc6dO0dqaiqurq689tpr5m4jMHUhPfvsswDk5uaSlpZW7nyNRsPSpUtp06aN+djQoUPN3SUrV640H9+2bRvHjh2jdevWvPvuuzRp0sScFhYWxrvvvotWq2X9+vVkZGRc870J65IgfJ0NHjy43GKNnj17MmnSJA4fPoyvry8ffPCBxe6I8PBwc4C70o4dOwC46667LF7zrrvuQqPRcPz4cS5dugSYui/A9FBQS/N0R40aVe172rlzJwD33nuv+QPiSq+99hrbt2/n0UcfrbSc5ORkTp06hVarLROAr3T33XcDsHv3bvOxX375BcBi36qzs3OFfa5qtGjRgv3797N//36LPy9XV1fzfxcVFZVL7969e7mFLwD33XcfAH/99Zc5oP70008ADBkyBBcXl3LnhIeHEx4eTklJCfv27avZDQmbIX3C19nVizW0Wi3u7u74+/vTtWtXhg0bhru7u8VzmzZtWu5YXl4e58+fB2Dx4sV8+OGHFs91cHBAr9eTkJBA06ZNSUxMBEwtK0ssBYyKpKSkANC2bVuL6QEBAdUqJz4+HvinNW5JaYBLSkpCURQ0Go35Xq5sZV6pXbt21bp+dbi6unL69GkOHz5MUlISKSkpnDp1ylx3AKOx/OPX27dvb7E8f39/vLy8yM3NJSEhgcaNG3P69GkAfvjhB/744w+L5124cAEw9TUL+yZB+DqraLFGdVhqFV05i+LYsWNVlpGbmwuYgjeAm5ubxXxeXl5oNBqUajx4JSsrC8BiK12N0jrp9XrzwF1FjEYj+fn5eHp6ms+r6MPrykG/axEXF8e8efPKtT4DAwMZOXIkGzdurPDciupWmpabm2v+gCm9n5SUFPMHXEVK309hvyQI27krg+hvv/1W7UUUpV+pCwoKLKYXFxdXKwCDqXWYl5dXYVnVVRqo2rZty7ffflvt87y9vcnIyCjzgXQlS90Dal26dInx48eTlZVFu3btGDVqFO3bt6dNmzb4+vqi0+kqDcKV/WxK6136npS+p0uWLOGOO+645roL2yZ9wnbO29vbHHjPnDljMY/BYGDv3r0kJSWZH6DYunVrwDTtypLSr8TVERISUuk5P//8M2PHji0zMGhJ6QDa2bNn0el0FvOkp6dz8ODBMoNfpfdy4sQJi+dU9HNRY9OmTWRlZdGmTRs2bNjAuHHj6NGjh3n5tqXBuCuVdplcLSUlhby8PLRaLaGhocA/P4fK6h0bG8vJkydr5QNGWJcE4XqgdM7sZ599ZjH9m2++ITIykhEjRphbZIMHDwZMA1yWAsiXX35Z7euXLsTYvHlzhdc/ePAg2dnZ5mOlA3hXtrbDwsIIDAyksLCwwrLeeecdxo4dy9NPP20+VnovmzZtKtcfazQaKyxLjdTUVABCQ0PLDMKV+uKLL8z/belJwfv37zf33V9p/fr1APTo0cM842LAgAEAfPXVVxQXF5c7JyUlhYcffph77rmH2NhY9TcjbIoE4Xrg0UcfxcXFhW+++YbFixeX+cPds2cPc+fOBeD+++8394926tSJgQMHUlhYyLRp08wDPQAbN25UtXfF2LFj8fb25sCBA8ybN898fUVRWLt2LVu2bMHJyYmxY8eazyntejh37pz5mEajYcqUKQDMmzePLVu2mNP0ej1RUVHExMQAlBm4Gz16NP7+/vz111+8/PLL5tZhcXExr776aoWtfTVKW/u//vorhw8fNh8vLCzko48+YsWKFeZjlgKnTqdj2rRpZT7wNm7cyKpVq9BoNEydOtV8/O677yYkJISkpCSeeOIJ84wWMLWop0yZgl6vp3379hWuhBT2Q/qE64GwsDAWLlzI888/z/Lly1m7di2tW7cmMzPT3ILr06ePeS5rqddff52JEydy+PBhhgwZQnh4OJcvX+b8+fMMHDiw2vvSNmvWjEWLFvHEE0+wevVqYmJiaNWqFefPnycjIwMHBwfmzp1rDmRgmn1x6NAhnnnmGUJDQ3n66afp27cvo0aN4tSpU6xatYpnnnmG+fPn4+/vz9mzZ80DgFOnTmXIkCHmsjw9PVm8eDGPP/44X3zxBVu3bqVVq1YkJSWRk5Oj6l4qcv/997Nu3TpSU1MZPXo0ISEhuLq6kpSUREFBAYGBgWi1WlJSUrh48WK58/v168eBAwcYPHgwbdu2JTMz09wyfv7557n55pvNeZ2dnVm2bBmPPPIIu3btYsCAAYSFhVFSUkJiYiIGg4GAgAA++OCDa7onYRukJVxPDBs2jK+++opRo0bh4+NDXFwcmZmZdO7cmRdeeIGPPvqo3BLXpk2bEh0dzdSpUwkMDCQ+Ph6tVsu0adN4++23VV2/X79+bN68mVGjRuHp6UlcXBwGg4EhQ4awfv36chukz5s3j169eqEoComJiSQlJZnTZs+ezcqVKxk0aBBGo9Hc19u3b18++OADixukd+/enZiYGEaOHIm7uzsnT54kMDCQt99+mzFjxqi6F0u8vb354osvGDduHCEhIaSmppKUlESrVq2YNm0amzdvZtiwYQAWA37Hjh1Zv349vXr1IjExkZycHPr06cMnn3xicWFOWFgYmzdvZvLkyYSGhpKYmEhycjLBwcFMnDiRL7/8khYtWlzzfQnr0yjVHQIXQghR66QlLIQQViRBWAghrEiCsBBCWJEEYSGEsCIJwkIIYUUShIUQwookCAshhBVJEBZCCCuSICyEEFYkQVgIIaxIgrAQQljR/wOBHS7xdYtiFQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, test_x, test_y, normalize='true', ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "eaeb5421",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC score: 0.8706379216064967\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>EF 1%</th>\n",
       "      <th>EF 2%</th>\n",
       "      <th>EF 5%</th>\n",
       "      <th>EF 10%</th>\n",
       "      <th>EF 15%</th>\n",
       "      <th>EF 20%</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>48.648649</td>\n",
       "      <td>27.027027</td>\n",
       "      <td>12.432432</td>\n",
       "      <td>6.756757</td>\n",
       "      <td>5.045045</td>\n",
       "      <td>3.918919</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>48.648649</td>\n",
       "      <td>27.027027</td>\n",
       "      <td>12.432432</td>\n",
       "      <td>6.756757</td>\n",
       "      <td>5.045045</td>\n",
       "      <td>3.918919</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          EF 1%      EF 2%      EF 5%    EF 10%    EF 15%    EF 20%\n",
       "0     48.648649  27.027027  12.432432  6.756757  5.045045  3.918919\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  48.648649  27.027027  12.432432  6.756757  5.045045  3.918919"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "factors = [0.01, 0.02, 0.05, 0.1, 0.15, 0.2]\n",
    "pred_labels = clf.predict_proba(test_x)\n",
    "\n",
    "print(\"AUC score:\", roc_auc_score(test_y, pred_labels[:, 1]))\n",
    "\n",
    "list = []\n",
    "for factor in factors:\n",
    "    list.append(enrichment_factor(test_y, pred_labels, ratio=factor))\n",
    "\n",
    "df = pd.concat(list, axis=1)\n",
    "df = pd.concat([df, df.agg(['mean'])]) \n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47ce7d8c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tda",
   "language": "python",
   "name": "tda"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
