{
 "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 KIF11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 7110/7110 [00:01<00:00, 5593.33it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti/target_kif11/'\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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting 3 folds for each of 100 candidates, totalling 300 fits\n"
     ]
    }
   ],
   "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.9971751412429378"
      ]
     },
     "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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\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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Ou7u7txxxx2YTCbi4+OJjo5m5syZPP7445XWceHCBZ588kmOHj1KkyZN6N27NykpKfzyyy/s3LmTVatW0alTpwrruKZV1LKzszl16hRFRUX4+voSGhpKvXr2bZAohBDlUVC3HITabERGRgYzZszA19eX2NhY676V+/fvJyoqilmzZtGnT59K17+ZM2cOR48e5YEHHmDu3LnWDMDy5ct58803efnll/nmm28qrKNKe8z98MMPPProo9x5551ERkYyZswYhg4dSrdu3Rg1ahR79pTdfFIIIexV03vMrVq1Cr1ez6hRo0ptHNypUyeio6MpLi5mzZo1FdZx5swZ1q9fT3BwcKkADDBmzBg6dOhAYWFhpUN6VQfhl19+mcmTJ/PXX3+hKAo+Pj4EBgZSr149jEYju3fv5qmnnmLFihVqqxZCCDOlCg8VduzYAWBzGK3l2Pbt2yusY+PGjSiKQmRkpM17YHFxcWzatImAgIAK61GVjvj222/58ssvcXd3Z9y4cQwePLhUd/306dPExsbyySefMG/ePNq1aydrCwsh1FO7KI+q/LFCYmIiWq221AJkFiEhIWi1WhITE1EUpdy9Ni37Z958883k5+fzww8/cPDgQVxdXenRowf9+vWza59OVUF49erVaDQa3n77be65554y51u0aMGUKVNo3bo1r7zyCkuXLpUgLIRQrSaHqOXm5qLX6wkICLDZg3V1dcXf35+srCzy8/Px8fGxWU9KSgpgvjn30EMPkZaWZj332Wef0aNHD957771yr7dQlY44cuQIwcHBNgPw1R577DGCgoL4v//7PzXVCyEEUPWlLNPT0zl9+nSpx8WLF0vVXVhYCICXl1e5z+/p6QmYh5+V59KlSwBMnz6dBg0a8Pnnn/PHH38QGxtLeHg4v/32GzNmzKj0taoKwq6urnh7e9tV1t/fn3I2chZCiIopmFMMdj/Mlw0fPpx+/fqVenzyySelqrZ3ETKgwhim1+sB82JlK1asoHPnzvj4+NC1a1eWL19OvXr1+P7770lKSqrwOVSlI7p168Yvv/xCUlISrVu3LrdcRkYGx48fl1SEEKJKqpqOiI2NLbN6499n7lo6ksXFxeXWV1RUVKqsLZbe8oMPPljmORo3bkzfvn359ttv+f333yuMl6p6wpMnT8bb25tx48aRmJhos0xGRgYTJkzA1dWVyZMn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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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1Zb/ViSS0CuYnj174uDgwOLFi/nzzz/N20+cOMGSJUtwdHSkb9++5dhCIWybqfy3evXqJZb/3rhxo8JVi8lN0QrmoYceYsqUKcyYMYN//etftG7dGoCIiAgKCgqYM2cONWvWLOdWCnF33DxcVZUiunkY51wkJCSg0+kK73NzK3RPSW35b0WazyEJvQLq168fdevWZcmSJRw/fhx7e3uCg4MZOXIkTz75ZHk3Twir6XQ6dDodI5e8ovrY/Px8XnrppSK96jFjxjB27Fjznytz+a9GqWgtFkJUagUFBej1etXHZWdnWxwiub2Hfv36dR5//HFq1apFeHi4xXM99dRTpKSkcOTIkQpVMSY9dCGETbGzs8POTn1qcnBwoEaNGneMu7389/b3qsjlv3JTVAjxQKnM5b+S0IUQD5zKWv4rCV0I8cCprOW/clNUCPFAWrZsGTNmzKBKlSoWy3+7d+9ezi1UTxK6EOKBtXv3bpYsWcLJkyext7cnKCioQpf/SkIXQohKQsbQ74OLFy8SFBRk8dWoUSOaN29OmzZtGDlypMWbNOXhzJkz5jbe6o033iAoKIg5c+bc9XskJyeTkZFx1+e5kx9++IGgoCD69+9fqvh169YRFBREz5497/q958+fT1BQEOPGjbvrc91J+/btCQoKYvfu3WX+XsI2SR36fdasWbNC60coikJeXh4XL15k165d7Nq1i759+zJ16tRybGXZ+/bbb5k/fz4rVqyocLW+QtgqSej32bx583jooYeKbM/Pz2fBggUsWrSI5cuXExISQvv27cuhhSWbOHEiw4YNK9UEjpK8//7796hFQggTGXKxEVWqVGHChAk89thjACxfvrycW2SZp6cnDRs2xN3dvbybIoS4jSR0G9OuXTvAWA8rhBBqyJCLjTEt1XnrIkPz589nwYIFTJ48GScnJ7744gvS09Px9fVl4cKF1KtXD4D4+HgWL17MgQMHuHr1Ki4uLjz66KMMGjSo2DKspKQkFi9ezM6dO0lKSsLb25s+ffrQqlUri/FvvPEG69evZ8iQIUyZMqXQvvj4eL7//nv27t1LQkICjo6OPPzwwwwePJhnnnmm0LWYdO3aFYDvv//eXAsMcOTIEb799lsiIyPJyMigZs2aPP3007z22mvm671dVFQUX3zxBcePHyczM5PGjRszcuTIEn/eaiUnJ7N06VL2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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": "iVBORw0KGgoAAAANSUhEUgAAAWEAAAFGCAYAAAC7Vi5ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABIJklEQVR4nO3de1xUZf7A8c8M96vi/S4iDppmiiVZoZK2dv8VmZWkiYatirrlrpcua9Gq2c3ULm5iWSZmJmVtbV4yL2lSKi2aiqIIiIIiyB2GmTm/P4hJYoA5CM6MfN/7mtdrPec5z3xHmy8P3/Oc59EoiqIghBDCJrS2DkAIIZozScJCCGFDkoSFEMKGJAkLIYQNSRIWQggbkiQshBA2JElYCCGA+Ph4goKC2L9/v6rrsrOz+ec//8mIESPo378/o0aN4p133kGv11t1vSRhIUSzl5iYyMsvv6z6uqysLMaMGcP69evx9fVl+PDhFBcXs2zZMiZNmkRFRUW9fUgSFkI0a5s3b2bSpEmUlJSovvbFF18kKyuLmTNn8sUXX7Bs2TK2bNnCLbfcws8//8yaNWvq7UOSsBCiWcrKymL27NnMmDEDk8lEmzZtVF1/6tQpduzYQbdu3fjrX/9qPu7p6cmCBQtwcnLik08+qbcfScJCiGbprbfeYtOmTfTr14/169cTEBCg6voff/wRRVEICwtDq62eSjt16sR1111HZmYmKSkpdfYjSVgI0SwFBASwePFiNmzYQFBQkOrrq5Jrr169au0f4Pjx43X246z6nYUQ4howefLkK7r+/PnzALRr187i+bZt2wKQk5NTZz+ShIUQdsVgMGA0GlVfV1JSQnFxcY3jvr6++Pr6NkZo1ZSWlgLg7u5u8XzV8fpu+EkSFkLYDYPBwOGkPRgVb9XXVlRUMHXq1BqJODo6munTpzdWiGZOTk4AaDSaOtuZTKY6z0sSFkLYDaPRiFHxpmebf+LqlGv1dXpjK07mxPDFF1+Yk2OVphgFA3h4eABQVlZm8XzVcU9Pzzr7kSQshLA7TtocnJwuWN9eqRxtdujQATc3t6YKq5qqWnBtNd8LFy5Ua1cbScJCCLtjQsGE9Zv+qGnbWKpmRdQ2Be3kyZMA6HS6OvuRKWpCCLtjasD/rrbQ0FAAfvjhhxp137Nnz3L06FE6d+5MYGBgnf1IEhZC2B2TomBU8TI18VaZZ8+e5eTJk+Tm/lGn7tq1K6GhoZw6dYqlS5eaj5eUlPD8889jNBqJjIyst29JwkIIu2Pij5KEda+mNWfOHO6++27Wrl1b7fj8+fNp27YtK1as4L777mPGjBn85S9/Yc+ePQwdOpTHHnus3r4lCQsh7I4RRfXLFrp27cqGDRsIDw8nNzeXHTt20KJFC2bNmsXbb7+Ns3P9t900suW9EMJelJeXc/jwYTq1fRJn5/NWX2cwtOPshVj69et31WZHNBaZHSGEsDtGRUGjYnxodOCxpCRhIYTdMf3+UtPeUUkSFkLYHZPKOq8t5gk3FrkxJ4QQNiQjYSGE3TECaga36tdcsx+ShIUQdscE1L02Wc32jkqSsBDC7pjQoCYNm1SlbPsiSVgIYXdMCqrKESbHvS8nSVgIYX+MaFBkJCyEELZhUpmE1bS1N5KEhRB2x6Ro0CgqkrCKtvZGkrAQwu4YAY2qkbDjkiQshLA7JrSoe5ZM67BPnkkSFkLYHZOiATUlBkUjSdgemUwmiouLcXFxqXdbaiFE41EUhYqKCry8vNBq1adHo8p5wqBx2GTmqHFbpbi4mOPHj9s6DCGaLZ1Oh4+Pj+rrTIoWRbE+eWtUtLU313QSdnFxASCwzXxcnXLrae2YjmQv57r2020dRpN5IuQ6W4fQZOZ8NYXF979n6zCahG87H6bEPm7+DqpVOUVNRRKWKWr2qaoE4eqUi5vzBRtH03Su5c+Wdy7f1iE0qWv98zW0DKj2YQ1JwkII0YhMihaTihKDVsoRQgjReExoVD6K7LgjYcf98SGEENcAGQkLIeyOEe3vD2xYR81NPHsjSVgIYXdMigajmjqvrB0hhBCNx6RyJOy4z8tJEhZC2CGjosGo8rFlRyVJWAhhd0xoMcpIWAghbMOEunnCakoX9kaSsBDC7hjRqBwJSzlCCCEajUllTVgrNWEhhGg8amdHSDlCCCEakVHRqponLGtHCCFEI1JUrh0huy0LIUQjMqp8Yk7VnGI7I0lYCGF3jCrnCatpa28kCQsh7I6iaCo3+1TR3lFJEhZC2B0ZCQshhA2ZFI26J+YceCTsuD8+hBDiGiAjYSGE3TGhwahi2pm6rZD+sHfvXlasWEFycjIVFRX07duXqKgohg4danUfv/76K++99x6JiYmUlJTQoUMHbr/9dqZNm0aLFi3qvV5GwkIIu1O10aeal1rx8fFERkaSmJhI//79GThwIImJiURFRbF+/Xqr+ti2bRsRERHs2LEDf39/hg4dSnl5OR999BEPP/wwubm59fYhI2EhhN0xqhwJq2kLkJ2dzfz58/Hx8SEuLg6dTgdAUlISkZGRLFiwgOHDh9O+ffta+zAYDMyfPx+TycTy5cv5y1/+AkB5eTkzZ87khx9+4J133uGFF16oMxYZCQsh7I6ichSsqBwJr127Fr1ez4QJE8wJGKB///5ERUVRXl5e72g4OTmZnJwcevfubU7AAG5ubkydOhWAX375pd5YJAkLIeyOEY15/QirXipHwrt37wZg5MiRNc5VHdu1a1edfWi1lenz4sWLGAyGaufy8vIApCYshHBMpt/XjlDzspaiKKSkpKDVagkICKhx3t/fH61WS0pKCoqi1NpPYGAgHTt2JDs7m9mzZ5Oenk5paSk//fQTL730ElqtlsjIyHrjkZqwEMLumBR1D2tU3ZjLysrCycmp2jlfX198fX3Nf87Pz0ev19OqVStcXV1r9OXs7Iyfnx8XL16kuLgYb29vi+/p4uLCsmXLiI6O5ptvvuGbb74xn2vXrh2xsbHceuut9cYuSVgIYXdMirrRbdXDGmPHjiUnJ6fauejoaKZPn27+c2lpKQAeHh619ufu7g5QZxIG6NatG/fddx8ffvghffv2pXXr1hw+fJjz588TGxtL3759admyZZ2xSxIWQtidhj62HBcXZ3EkfLmqWq416ipH5OXlMXbsWLKzs/nwww8JCQkBQK/XExMTw4YNG4iOjuaTTz6p8z0kCQsh7E5DR8IdOnTAzc2tzraenp5A5VSy2pSVlVVra8mqVas4deoU//jHP8wJGMDV1ZX58+ezf/9+fvnlF/bv38+NN95Yaz9yY04IYXcqF3XXWv1Ss6i7t7c3np6e5OXl1ZjVAJXzf/Py8nBzc6sxir7czz//DGCx7uvi4sItt9wCwJEjR+qMR5KwEMLuGH/f6FPNy1oajYbAwECMRiOnT5+ucT41NRWTyVRt/rAlBQUFADXKH1WqjldUVNTZjyRhIYTdMf2+nrCalxqhoaFA5WPHf1Z1bNiwYXX2UTW9befOnTXOGY1G9u3bB0Dv3r3r7EeSsBDC7jT1E3Ph4eG4ubmxcuVKDh8+bD5+6NAhYmNjcXd3Z+zYsebj6enpnDx5ksLCQvOxRx55BIAVK1Zw4MAB83GDwcCrr77K8ePH6dWrFzfffHOdsciNOSGE3WnqtSO6dOnCnDlziImJ4dFHHzXfWEtISMBgMLB48WJat25tbj9hwgQyMzNZtGgR4eHhQOVIefLkybz//vtEREQwYMAAWrVqxdGjRzl79ixt2rThrbfeqrVcUUWSsBDC7phQV2JoyFKWERERdOrUidjYWA4ePIirqyvBwcFMmTKFIUOGWNXHrFmzCA4OZs2aNRw6dIjDhw/Trl07Hn/8cZ566inatWtXbx+ShIUQzVZYWBhhYWH1ttu+ffsV91EbScJCCLtTOU9YxWPLaGjguu42J0lYCGF3FLWL8jhqBkaSsBDCDhmVBtyYc9A8LElYCGF3TIpWZTnCcWfbShIWQtgdReXaEVKOEDZjMinMuKcX5067seG3w/VfIGzKu4WBx5/J5pa78mnb6XHWHtCwf4cva99sz/nMmmvbNldqF2pv6G7L9sBxx/ACgC3v7SI50cvWYQgreLcwsOSrFB6MysG7hZGyim64uSvc+Vgu7249To8+pbYO0W6YFLWPLts64oaTJOygFAXWvN6BHat/snUowkp/e+0M3XqVk7DNh4jg60i+sJDHgq9jy3o/fFoamfdeGlqtA2eTRnQ1try3F3Yb+d69exk/fjwhISEEBwczbty4ejfeay5yzzvz0sQefPJmB1uHIqzUNbCMW+/Op6RIy2szulFa/PsKW+ValszqStpxN7rryrnlrnwbR2ofFJWL9ygqF/CxJ3aZhOPj44mMjCQxMZH+/fszcOBAEhMTiYqKqncb6mvdgR0+TLqtDz9tbkGrdhXcOa3ulZ6Efbg9PA+tFhK2+lJ4qfqtGJNJw5b1rQAYdv8lG0Rnf5pyo097Y3c35rKzs5k/fz4+Pj7ExcWZ1/RMSkoiMjKSBQsWMHz4cNq3b2/jSG0j7YQ7pcVaRozO5a8vZrLlx/G2DklYoXdwCQBH9luu3x87ULmDQ7+Q4qsWkz1TvXaExnGTsN2NhNeuXYter2fChAnVFlXu378/UVFRlJeXN+vRcNCAYt7ZfJzZy9LxbWW0dTjCSp389QBkpVueAZH9+8yIVu0MuHvKv2tTrydsT+wuCe/evRuAkSNH1jhXdaw514b73lRCz35yF93RtGhduY1OQZ7lZQ0LLzveQn64NquasF2VIxRFISUlBa1Wa161/nL+/v5otVpSUlJQFAWNA/8KIpoXV3cTAPoyy+Oey49XtW3OqqaoWd2+CWNpanY1Es7Pz0ev19OyZUtcXWv+2ubs7Iyfnx+lpaUUF0vtTDgOk7HuhKKxq2+i7TWnG3N29U9fWlr5a7aHh0etbdzd3QEkCQuHUlZS+VVzcbM8ZnNx/eN4ealdfS1tojnVhO2qHKHVWv8fn6JYP6n9SPbyhoTjINIAMJh8SMz81MaxNL5XfrF1BI3D1ftvQDYzP3qIgvIB5uOv/DIXABenC8AMAGZtmoOiuF31GO2JojKxytoRjcTTs3KaTnl5ea1tysrKqrW1xnXtp+PmfOHKgrNTJw8sBsBZW8jAzo/aOJrGN6rTAFuH0ChiPioh5A749vVP+M/H3wGVCXjuTa8A0C+kiDe+gItZzsy5cYktQ20Ufh1bMOerKbYOwyHY1e893t7eeHp6kpeXh8FgqHHeYDCQl5eHm5sbvr6+NohQiIY5nlQ5aKiaL/xnfQZVHj+WaP3g4lrWnMoRdpWENRoNgYGBGI1GTp8+XeN8amoqJpOp2vxhIRzBnm9bAHDLnfn4tKw+wNBqFe4YkwvA9o1+Vz02eyRJ2IZCQ0MB2LZtW41zVceGDZNHdYVjST3qQcJWH7x8TTz/fho+fpWJ2MXNxNNvZNBdV05Giht7/tvCxpHaB4XKub9Wv67FmvDOnTsb5Q3UJszw8HBiY2NZuXIlt912G/369QPg0KFDxMbG4u7uztixYxslNiGupmVzu/BG7xQG3FbEJ78cxeT8LOsOpuPjZ6QoX8tLE/0d+qGDxtSc1hOuNQk/9dRTV/wwhEaj4ciRI6qu6dKlC3PmzCEmJoZHH32UkJAQABISEjAYDCxevJjWrVtfUVxC2ELOOVei79QR8XQ2Q0bl065LOgVGDT980ZKPX+/A2dTmPSPicorKhzVUTJayO7Um4U6dOl3NOKqJiIigU6dOxMbGcvDgQVxdXQkODmbKlCkMGTLEZnHZo56DurP57K+2DkNYqTDPmRX/7MyKf3auNjtCVFdVZlDT3lHVmoS3b99+NeOoISwsjLCwMJvGIISwDbU32xz5xpxdzRMWQgiQkbBVcnNz2bdvH6mpqRQVFTFnzhzKy8tJTEzk5ptvbswYhRDNjIyE61BRUcHrr7/OunXrqKioMB+fM2cO6enpREZG0qdPH957771mu/C6EOIKKSpvtjnwjTlV84RNJhPTpk3j448/xmAwEBQURIsWf8xrLC4uRqvVcuTIER577DHy8vIaPWAhxLVPVlGrxcaNG9m1axcBAQF89dVXfPnll9XW/R0wYADfffcdvXr14ty5c6xatarRAxZCXPtUPajh4Iu6q07CGo2GZcuWERgYaLFN165dWb58OVqt1uYzLIQQjqlqjzmrXw48ElZVEz5x4gQBAQH07Nmzznb+/v74+/uTkZFxRcEJIZonRWVN+Jp8WMMSo9Fo9Zq/Li4uODlZ3k9LCCHqUpmEm8cTc6rKEV27diU1NZXc3Nw62+Xk5JCSkkLXrl2vKDghRDOlth7cXGrCo0aNwmAw8M9//rPa9LTL6fV6nnvuOYxGo8Udk4UQQvxBVTkiMjKSr776iu+//54HHniAESNGcOFC5Y4VW7du5eTJk3zxxRekpaXRsWNHJkyY0BQxCyGucfKwRi28vLz48MMPiY6O5ujRo5w6dcp8bsaMyv2xFEWhe/fuvPvuu7L7hRCiQeTGXB06d+7Mxo0b2bp1K99//z0pKSkUFxfj4eFB9+7dGT58OPfcc4/FLeuFEMIaV2vtiL1797JixQqSk5OpqKigb9++REVFMXToUKv7KC4uZtWqVfz3v//lzJkzeHh4EBwczLRp07j++uvrvb5Ba0dotVpGjRrFqFGjGnK5EELU6Wok4fj4eObNm4erqys333wzJpOJhIQEoqKiiImJ4ZFHHqm3j0uXLjF+/HiSk5Np3749w4YNIz09nR9++IE9e/awdu1a+vfvX2cfV7SKWm5uLqdPn6asrAwfHx8CAgLw8vK6ki6FEAIFdctBqK1GZGdnM3/+fHx8fIiLizPvW5mUlERkZCQLFixg+PDh9a5/s2jRIpKTk7nnnnt45ZVXzBWAVatW8eqrr/L888/z1Vdf1dlHg/aY+/bbb3nooYe49dZbiYiIYNKkSYwZM4bBgwczYcIEfvnll4Z0K4QQQNPvMbd27Vr0ej0TJkyotnFw//79iYqKory8nPXr19fZx9mzZ9m0aRNdu3atloABJk2aRN++fSktLa13Sq/qJPz8888za9YsfvvtNxRFwdvbm3bt2uHl5YXRaGTfvn088cQTrF69Wm3XQghRSWnAS4Xdu3cDWJxGW3Vs165ddfaxZcsWFEUhIiLC4j2w+Ph4tm7dSqtWrersR1U54uuvv+bzzz/H1dWVKVOmEB4eXm24fubMGeLi4vjoo49YvHgxvXv3lrWFhRDqqV2UR1X9WCElJQWtVlttAbIq/v7+aLVaUlJSUBSl1r02q/bPvP766ykuLubbb7/l8OHDODs7M2TIEEaMGGHVPp2qkvC6devQaDS88cYb3HHHHTXOd+nShdmzZ9OjRw9eeOEFVq5cKUlYCKFaU05Ry8/PR6/X06pVK4sjWGdnZ/z8/Lh48SLFxcV4e3tb7Cc9PR2ovDl33333kZmZaT73ySefMGTIEN5+++1ar6+iqhxx7NgxunbtajEBX+7hhx+mY8eO/O9//1PTvRBCAA1fyjIrK4szZ85UexUUFFTru7S0FAAPD49a39/d3R2onH5Wm8LCQgDmzZtHy5Yt+fTTTzlw4ABxcXEEBQXx008/MX/+/Ho/q6ok7OzsjKenp1Vt/fz8UBx5BrUQwnYUKksMVr8qLxs7diwjRoyo9vroo4+qdW3tImRAnTlMr9cDlYuVrV69moEDB+Lt7c2gQYNYtWoVXl5efPPNN6Smptb5HqrKEYMHD+aHH34gNTWVHj161NouOzubEydOSClCCNEgDS1HxMXF1Vi98c9P7lYNJMvLy2vtr6ysrFpbS6pGy/fee2+N92jbti233347X3/9NT///HOd+VLVSHjWrFl4enoyZcoUUlJSLLbJzs5m2rRpODs7M2vWLDXdCyFEpQbOjujQoQNdunSp9vpzgvT29sbT05O8vDwMBkONtzYYDOTl5eHm5lbn0gtVsx46d+5s8XzV8fq2eat1JDxz5kyLxzt06MCJEye4//77GTRoEL1798bT05PS0lJOnz5NQkICer2e0NBQtmzZQu/evesMQAgh/qxqnrCa9tbSaDQEBgaSlJTE6dOna+wSlJqaislkqjZ/2BKdTse+ffs4f/68xfNVi5u1bt26zn5qTcKbN2+u80KTycQvv/xS64MZu3btYvfu3eaFfYQQwmpN/MhcaGgoSUlJbNu2rUYS3rZtGwDDhg2rs4+hQ4fy8ccfs23bNp5++mmcnf9Ip3q9noSEBAAGDRpUZz+1JuHo6Oi6P4UQQjSRpl47Ijw8nNjYWFauXMltt91Gv379ADh06BCxsbG4u7szduxYc/v09HQqKipo164dPj4+ANxyyy307t2bY8eOsXDhQp577jmcnJwwmUy8+uqrnDlzhltvvdXiXOTLSRIWQjQ7Xbp0Yc6cOcTExPDoo48SEhICQEJCAgaDgcWLF1crI0yYMIHMzEwWLVpEeHg4AE5OTrz55ps88cQTrF27lh07dtCnTx+OHz9Oeno6HTt2JCYmpt5YGrR2hBBCNKkmfmwZICIighUrVnDDDTdw8OBBDh8+THBwMB9++CH/93//Z1UfPXv25Msvv2TcuHEA7Ny5E4PBQEREBBs2bKBLly719tGgVdSMRiPZ2dmUlpbWmEdnMBjQ6/WcP3+e7du3s3Dhwoa8hRCiWdP8/lLTXr2wsDDCwsLqbbd9+/Zaz7Vp04bnn3+e559/vkExqE7CK1euZOXKleanReojSVgIoVpTr2VpR1Ql4S1btvDGG29Y1bZbt27ceeedDQpKCNHMNaMkrKom/NlnnwFw3333sXPnTvbt24eTkxNjxozh0KFDbN26laeeesp8h3Dy5MlNErQQ4hqn6pHlZrTl/ZEjR/Dw8ODFF1+kffv2tGzZksDAQPbs2YOLiwtdu3bl6aefZubMmWRmZtZ4ZlsIIaxR9diympejUpWECwoK6Nq1a7UtjHr16sXZs2fJz883Hxs/fjzu7u58//33jRepEKJ5acKZEfZEVRL29PSssUhx165dATh58qT5mLu7O/7+/qSlpTVCiEKIZkfKEZZ17dqVjIwMSkpKzMe6d++OoigcPXq0WtuysjKLi2MIIUR9NIr6l6NSlYRvu+02SkpKeOGFFygqKgIqt/YA2Lhxo3l9zaqFMWpbXUgIIep0FR7WsBeqkvD48ePx8/Pj22+/JTQ0FL1eT8+ePQkJCeHo0aOEh4czY8YMIiMjgcqkLYQQqkk5wrLWrVvzwQcf0KdPH1xdXc37Mz333HP4+vqSkpLCli1bKC4uplOnTkydOrVJghZCXOOa0UhY9RNzffr0IT4+nnPnzpmP6XQ6vvnmGzZu3EhmZib+/v48/PDD5tWGhBBClWb0sEaD1o4A6NixY7U/t2nThqeeeuqKAxJCCEnCQghhU2rrvI5bE641CY8ePfqKO9doNGzYsOGK+xFCNC9qp5058hS1WpPw4cOHr7jzPz/YIYQQorpak/CiRYuuZhxCCPEHqQnDgw8+eDXjEEKIZqlZ3Jh74q/h5OWW2jqMJvHKchgVPt7WYTSZe3/baesQmk4J3Ptbnq2jaBJuJqCs4ddLTVgIIWxJQd3sCEnCQgjRiKQmLIQQNiRJWAghbEdqwkIIYWsOnFjVkCQshLA/Uo6on9Fo5LfffuPUqVMUFRXx+OOPU1FRwblz5+jWrVtjxiiEaGakHFGPjz/+mPfff5+LFy+ajz3++ONkZGRw7733MnLkSBYuXIi3t3ejBSqEaEbULtTuwIu6q07Czz33HPHx8SiKQosWLdDr9ZSVVc7KzsnJwWQysXXrVjIyMoiLi8PDw6PRgxZCXOOaUTlC1c4amzdvZuPGjbRt25aVK1eSkJBAnz59zOcHDx7MmjVraNu2LceOHeOjjz5q9ICFENc+2eizFuvWrUOj0bB06VJCQ0Mttrnpppt45513UBSF//73v40SpBCimZHtjSw7cuQIXbt2ZeDAgXW2u/766+nevTtpaWlXFJwQoplSO7p14CSsaiRcXl6Op6enVW3lppwQ4oo0g1EwqEzCHTt2JDU1lZKSkjrbFRUVkZKSQocOHa4oOCGEuNapSsJhYWGUl5fzyiuv1Nlu4cKF6PV6hg0bdkXBCSGaKakJWxYVFcWmTZvYsGED6enp3HXXXeTn5wOV9eKTJ0/y2WefsX//fnx9fZk4cWKTBC2EuLbJwxq1aNWqFStXrmTatGns27ePhIQE87mHHnoIAEVR8PPzY/ny5bRv375xoxVCiGuM6oc1+vbty3/+8x/Wr1/P9u3bSUlJobi4GA8PD7p3787w4cMZO3YsrVq1aop4hRDNQTN6WKNBjy17e3szadIkJk2a1NjxCCFEsypHqLoxJ4QQV8VVujG3d+9exo8fT0hICMHBwYwbN45du3ZdUehPPvkkQUFB1cq1dVE1Ev7yyy9VB/TAAw+ovkYI0cxdhXJEfHw88+bNw9XVlZtvvhmTyURCQgJRUVHExMTwyCOPqO4zLi6O3bt3q7pGVRKeO3cuGo11qxUpioJGo5EkLIRQranLEdnZ2cyfPx8fHx/i4uLQ6XQAJCUlERkZyYIFCxg+fLiqyQVpaWm89tpr6gJBZRK+7rrrak3CZWVl5OTkkJ+fj0aj4d5775Wbc0KIhmvCOu/atWvR6/U89dRT5gQM0L9/f6KioliyZAnr169nxowZVvVnNBqZM2cOLi4u6HQ6jh8/bnUsqpJwfHx8vW3279/P3LlzOXz4MJ9//rma7oUQAmj6kXBVyWDkyJE1zo0cOZIlS5awa9cuq5NwbGwsiYmJvP7662zcuFFVLI1+Y+7GG29k6dKlnD59mnfeeaexuxdCNAdNeGNOURRSUlLQarUEBATUOO/v749WqyUlJQVFqb/jY8eOsXz5ckaNGsV9991nfSC/a5LZEX379iUgIIAtW7Y0RfdCiGtdEybh/Px89Ho9LVu2xNXVtcZ5Z2dn/Pz8KC0tpbi4uM6+9Ho9//jHP/D19eXFF1+0PojL369BV1nBycmJCxcuNFX3QohrWEPLEVlZWTg5OVU75+vri6+vr/nPpaWlAHXu+uPu7g5AcXFxnStCLl26lOPHj/POO+80+B5YkyThgwcPkpKSQseOHZuieyHEta6BU9TGjh1LTk5OtVPR0dFMnz7d/Get1voCQF3liAMHDvDBBx9w//33W6wtW0tVEl67dm2d5/V6PampqXz99dcAjBgxosGBCSGasQYm4bi4OIsj4ctVrYleXl5ea3dV+2bWtn56SUkJc+fOpW3btrzwwgsqAq1JVRJ++eWXrZonrCgK3bp1Y+rUqQ0OTAjRfDW0HNGhQwfc3NzqbOvt7Y2npyd5eXkYDAacnaunQYPBQF5eHm5ubjUSeJV169aRnp5OUFAQMTEx1c6lpKQAsGLFCjZs2MCjjz7KjTfeWGs8qpLwTTfdVOd5Z2dnfH19GThwIKNHj5bdNYQQDddE84Q1Gg2BgYEkJSVx+vRpAgMDq51PTU3FZDJVmz/8Z1UbWyQnJ5OcnGyxzd69ewG45ZZbGi8Jr1mzRk1zIYSwS6GhoSQlJbFt27YaSXjbtm0AdW5KMX369Gp15stNmDCBn376iY8//piQkJB6Y1E1RW3ixInMnTuXgoICNZcJIYQqTb3lfXh4OG5ubqxcuZLDhw+bjx86dIjY2Fjc3d0ZO3as+Xh6ejonT56ksLCwsT6imaqR8P/+9z+8vb1rrZMIIUSjaOIFfLp06cKcOXOIiYnh0UcfNY9YExISMBgMLF68mNatW5vbT5gwgczMTBYtWkR4eLi6N6uH6ilqLVq0aNQAhBCihquwilpERASdOnUiNjaWgwcP4urqSnBwMFOmTGHIkCHqO2wgVUn4/vvv59NPP+X777+X6WdCiCZl3XqNVyYsLIywsLB6223fvt3qPlevXq0qBtVJ+OjRo0RHRzNgwAAGDBhAu3btLD76VyUiIkJVQEIIIdsb1eKxxx5Do9GgKAqJiYn8+uuv9V4jSVgIoVZz2t6oUecJCyFEo5CRMJw9exY3N7dqdwhlnrAQ4qpoRkm41nnCt99+OzNnzryasQghBFB5U07VPGFbB3wF6ixHWLOgsRBCNLpmNBJusvWEhRCioeTGnBBC2JKMhEVT8PYq5/FHkrglJINWLUvJL3Bjf2In1m7oz/kLV7binEaj8Nai/9KxQxFjJoypcf7xR/7HuEeSrOpry/YA3nj71iuK51qkz9dw4l13sr53oeyCFtdWCu1uq6DXlDI8O5lU95efXUDSx55c2O1M2QUtzt4KrQYY6DmpjFbBRovXVBRCSqw7WVtdKT2rxdlHoeX1BnpElNP2VsOVfkS7ISPh3128eJEvv/zyit7ggQceuKLrrxXeXuUsWfQd3boUUFziQmpaSzq2L+LOkSe59eYM/vHCX0hN82tw/xPG/kpv3UXyCyyvpXr+gheHj7at9Xo3NyO9AnIBOJft0+A4rlX6fA17H/eh6JQTzl4KvkFGSjK0ZMS7kbXNhSGri/ANspw4LSlM0bLsiQ8pvuSG1k3BO8BI2Xkt2TtcOb/bhetfLKFbuL7aNRUFGn4c60NxqhMaZwXvHiYMRXB+pyvnd7rS66lSgmaUNfZHtw0ZCVdKS0tj3rx5De5co9FIEv7d36buo1uXAhIOdGbRG6GUlrng4mJkxlMJ/OX2k8x7Zjd/ffpeTCa1e68qPP7I/3j0ocN1ttqyPZAt2wNrPf+3qT/RKyCX/x1qz6cb+6mM4dqXNN+TolNOtBtaQfDrRTh7gbEcDsV4cuZLNw7+3YthXxagcaq/L4Bf53lRfKmU1oMrCH6jGLdWCooRkt92J+V9Dw7HeNJmsAHPLn+MsP/3gifFqU60vN7AoCVFeHSszDxZ21048LQXJ/7tQevBBtrcfA2MiCUJV3J1da02T1g0TNfO+dwakk5JqTOvLb2V0jIXACoqnFjy7s0E9cqhe9d8bgnJ4Mefulvdr1/LUnq0epOBVpYZajPkpgzuGplCUbELry27tQE/CK5tRae0ZG1zwclTYcCiYpy9Ko87ucENMSVcSnKm6JQT57a50GlURb39FaZoyT/ijEYDAxdXJmAAjRP0nlnGhb0u5B92JvNbV3pNrhzZll3QkLXdBbQKwa8XmxMwQIfbK+j2cDlp69xJj3e9JpKwlCN+169fv3r3lbsa4uPjmTdvHmvXrq1zhXp7dfvQU2i1kPBLFwqLqpcLTCYtW7b3JOqJgwy79bTVSTj4hrM8/49deHlUcDHPgy//05tJ4xJVx+bqamDa5J8B+HDtQC5c9FLdx7XuzNeuoGhoP1yPa8vq33aNE3R9sJyjb3hy7jtXq5Jw2fnKH3KeLTxwb5dX43yL64zkH3am9NwfPwwrCjR0e0iPYqDa6LiKb6/KUkhZlvwAdTR2f2MuMTGRl19+2dZhXJHeusrdX48kW67JHjveBoB+fc5b3Wf3rvl4uFeQWxLKUzM70qN7zS+zNcLvO0rb1iWcOt2SbzbXvp1Lc3bpUOXXxG+A5RFmyxsqE2DuAeu+Tu7tK5No8aVSSrM1eLSvntiLUioTqUfHP5KtT08T/V8sqT3G3yrf26ub+huEdsuBR7dq2PWPzc2bNzNp0iTzfk6OqlOHytX4s85bngGR/fvMiFZ+Zbi71z+SAkg+0Zppf7+HtLypNUbX1vLxLmfMA78BsHrtQBTFkZ87ajrF6b+PXLtYvvHm2bHyePlFLYbi+vvz6WkyJ/T/PeuFPq/y711RICXWjdyDlaWPLvfXvhtwFUMxpKx0I+MLV7RuCj3GXxs35jSKovrlqOxyJJyVlcWbb77Jpk2b8PDwoE2bNuTk5Ng6rAZr4Vv5ZSootJwsC4v+WAq0hU85Zb/XjOtyJLndFcd11x0n8PKqIDWtJQkHulxxf9cqfW5lEv5zKaKKS4s/jusvaXH2qn80euOyIlL/PoCUfafZNrIF3t2NlOdoKb+oxTvAyA0vF+PRofbEcumwE/97wZOSDCeMpRo8Ohrp/3IJvrprZCTcjG7M2eVI+K233mLTpk3069eP9evXExAQYOuQroira+VISa+3fOv88uNVbZuaVmvi3juPA/D5puuuyns6KuPvA1KnWn7hcHK/rK2VA1Gtq0K3fp3QuiuYyjQUJDtTfrHy6+jezoS29iW6ASg66UThcWeMpZWj6IoCLed3umDU132do2jqPebsSa0j4ejoaDp27Hg1YzELCAhg8eLF3H///Wi1dvlzQhWTSYOTU+3/lWhsUAUIufEM7dsWczHXgx9297j6ATgQjRaUOgaYl5+z5t+yokDDT5HeFBzbS9tbDPR+phSfnpXzhE+tceP0J+7sHe/MzbGF+A2w/EO57W0VjNqXh6lCw4U9LhxZ7EHqGneK05wY/F6Ryk9oh5rRSLjOJGwrkydPttl7N4WycmdcXPS4uFj+Ql1+vLyW0XJjCx2SDsCuvd0xGh3/B11TcvZUqCjQ1DrKNF12XOtuuc3lTn7gRsExZzoEtiX43eNof68+eXYx0W9eKVoXOPWhO4f+5cnQzy3v7uvWuirrKHS5T493DyN7xvpwfpcLOfucHX+amtrRrQMnYfn2XQWFv9eCfbwtf4t9ff64AZOfb8W3+ApptSZuCs4EYNce6+clN1dVNd+KfMvDXH3+H18jN7/6a7LntlbWGoaOCzEn4MsFRpWhcVIoOOpMcZp1X9GW/Yy0CalMvBf32+WtHnWUBrwc1DXwr1W/OS/Vv5FfU/LyOwwk8tfp/uQU31HzvOtR4AsqjC156Y37Vff/yvK78XY9AmzFy8uFV5bfXXc8rsfw9dGjN7RifPQT2PVqrCV1f5arIaX7Bo5lnKRT6kPcPCi4xvlTp9LZThw+bbwZpsyFeibzfHf2NcBI2+6t6VqyuGYDF/ip5XIKLxbTM/UpAtv6Y6gwkpd5Ca2zltZdLD/efrHzFi5wkFbZQ7it5M4GfFL7IQ9rXGMWz/+BvNxSm73/448YGfcIHEvcwevLa05Be/iB39CNh5/3+xCz+FtVfb+y/G7mTv+W/n2zeO1lKC6uYO70uvuoer/de1rw6tL/qnq/q+3eVTttHQLG/u7wowf7j36NwXN9jfMpyW6AJ5435PKj55x6+9N6t4BcLYU5RRbbG8uhMK8loOFY6/fJ8jRy7C13UlZ60G6YnsHvWp4HdyrXC3Alr+NP/Oj5g7oP2cjcTH7cVDb3yjpx4MSqhpQjroI9+7oBcMvgDHy8q8/91GpN3BF2EoDtO6/ODbKePSoX6kk51eqqvJ+j6ziy8gdn1nZX9Jeq/9agGOHMl5Xlpi73Wjc1ofVNlWWD/V9bftw882tXMGlw9jGZFwVqPbjymgt7XCg5W/NrW5yu5cLuytpGu2HWzTW3Z81pdoQk4asgNc2PhP2d8fKq4Pl/7DQnYhcXI09P3Uf3rvlknPFlT0K3atf5+pTRtXM+HdtbvjnTUAH+lU/XpWW0bNR+r1W+QUbaDdNjKNJw4GkvcyI2lsP//lm5sI9XDyMdRlZPfvo8DUWntOaHPar0nFSGxlnhyM4THHndA8Nl5Yuzm1048ponAIGTysxT1doMMdCinwHFoOHA37yq1YoLjmv5eao3Jr2GTnfpadn36kxzbFIKlU+vWP2ydcAN1yzKEfZg2b9DeKPbZgZcn80n728k/UwLOrYvwsdHT1GxCy8tHl7jibX7705m3CNJZJ334om/hjdaLK38KkszRUX1TEYVZtf/s4S945y4+LML349sgXdA5VKWFQVanH1M3Li0CM2fhjSpcW6ceNcDj05GRmwtMB9v2ddI/xdLODTfh1MfupO23g1vfyOlWVrzgyFd/q+cnk/+8VuTRgODlhSzb6I3+b85s+M+X7z8TaBAUaoWFA2tQyro/5IVj+w5gOZUE5aR8FWSc9GL6L/fwxf/6c2lAnd6dL+E0aThh13+TJ99NxmZLa5KHFqtCS/Pyl+bi0vqfzJPVPLooBC6oRD/x8tw9TNRkOyExhk63a3ntvWF+PRU96Ra1wf1RH/8BJ3vK8fFR6HguBOKAdoMqSD4zSIGLCypMefYs5OJ0M8KCZxcild3EyUZWsqytfgNMHL9i8XcvLLIvMKbw5PZEaIpFBa5seKDm1jxwU1Wtf9k/Q18sv4Gq9om/daBUeHj6m1nMmm5a3T97URNri0V+s0rpd88627yBk0rI2ha7Y/QddK1Z+Ar6tZFcfFV6D2zjN4zr401ImqjMVW+1LR3VJKEhRD2R56Ysy9r1qyxdQhCiKtIg8qacJNF0vSkJiyEEDbkECNhIUQzUzX1TE17ByVJWAhhd5rTFDVJwkII+yM35oQQwnZkJCyEELYkNWEhhLChZrSouyRhIYT9kZqwEELYTnN6WEOSsBDC/piUypea9g2wd+9eVqxYQXJyMhUVFfTt25eoqCiGDh1qdR87d+7k448/5tChQ5SUlNC2bVtCQ0OZOnUqHTp0qPd6eWJOCGF/rsIqavHx8URGRpKYmEj//v0ZOHAgiYmJREVFsX59zR1ULHn//feZPHkye/fupUePHubkvX79eh588EFOnjxZbx8yEhZC2J2mnqKWnZ3N/Pnz8fHxIS4uDp1OB0BSUhKRkZEsWLCA4cOH0759+1r7SElJYcmSJXh6evLBBx8wcOBAACoqKli4cCFxcXE8++yz9SZ0GQkLIeyPql01VE5nA9auXYter2fChAnmBAzQv39/oqKiKC8vrzd5btq0CZPJRGRkpDkBA7i4uPDss8/SqlUrfv31VzIzM+vsR5KwEMLuNPUec7t37wZg5MiRNc5VHdu1a1edfbi4uBAUFMRNN9VcH9zFxYUuXboAcP78+Tr7kXKEEML+NOEUNUVRSElJQavVEhAQUOO8v78/Wq2WlJQUFEVB8+ctTn43Y8YMZsyYYfFcSUkJKSkpAPXenJMkLISwOxoUNCpKDJrfs3BWVhZOTk7Vzvn6+uLr62v+c35+Pnq9nlatWuHqWnOfRWdnZ/z8/Lh48SLFxcV4e3urjn/lypWUlJRw/fXX07FjxzrbShIWQtgf0+8vNe2BsWPHkpOTU+1UdHQ006dPN/+5tLRyeyoPD49au3N3dwdoUBLeuXMn//73v9FqtfzjH/+ot70kYSHENSMuLs7iSPhyWq31t8IUlTf8duzYwYwZMzAajcyaNYuQkJB6r5EkLISwOxpFZTni97YdOnTAzc2tzraenp4AlJeX19qmrKysWltrfP7558yfPx+DwUB0dDSTJ0+26jpJwkII+9OEN+a8vb3x9PQkLy8Pg8GAs3P1NGgwGMjLy8PNza3GKLo2S5YsYcWKFWg0GubNm8eECROsjkemqAkh7E8TzhPWaDQEBgZiNBo5ffp0jfOpqamYTKZq84drD1PhueeeY8WKFbi6uvLmm2+qSsAgSVgIYYeaep5waGgoANu2batxrurYsGHD6u3nlVde4fPPP8fb25tVq1Zx9913qwsEScJCCHukoHIkrK778PBw3NzcWLlyJYcPHzYfP3ToELGxsbi7uzN27Fjz8fT0dE6ePElhYaH52K5du1i9ejXOzs78+9//ZvDgwQ36qFITFkLYHY0CGhVT1NSOhLt06cKcOXOIiYnh0UcfNc9iSEhIwGAwsHjxYlq3bm1uP2HCBDIzM1m0aBHh4eEALFu2DIDWrVvz6aef8umnn1p8rylTptCzZ89aY5EkLISwP1dhe6OIiAg6depEbGwsBw8exNXVleDgYKZMmcKQIUPqvPbSpUscOnQIqFwM6Ouvv6617cMPPyxJWAjhYK7SzhphYWGEhYXV22779u3V/tyyZUuSk5Mb9qZ/IklYCGF/VM4Tlo0+hRCiMcluy0IIYUMNXDvCEUkSFkLYnYauouaIJAkLIeyPlCOEEMKGJAkLIYQNSU1YCCFsp6FLWToiWTtCCCFsSEbCQgj7U7WAj5r2DkqSsBDC/siNOSGEsCWVSdiBh8KShIUQ9kdmRwghhO00p9kRkoSFEPZHasJCCGFDJqXypaa9g5IkLISwPzISFkIIW5LZEUIIYTvysMa1Qfn9H9G3pbuNI2lafq08bB1Ck3Ez+dk6hCZ1rX4+V1ML4I/voGpSE742VFRUADDl6bp3TnV0c16qf6NCh1V2DX824KayubYOoUlVVFTg7t6AQZBiqnypae+grukk7OXlhU6nw8XFBY1GY+twhGg2FEWhoqICLy+vhnYgN+auBVqtFh8fH1uHIUSz1KARcBUpRwghhC3J7AghhLAdKUcIIYQNNaMparKzhhBC2JCMhIUQ9sdkqnypae+gJAkLIeyP1ISFEMKGmlESlpqwg9q7dy/jx48nJCSE4OBgxo0bx65du2wdllApPj6eoKAg9u/fb+tQ7Iui/DFX2JqXJGFxNcXHxxMZGUliYiL9+/dn4MCBJCYmEhUVxfr1620dnrBSYmIiL7/8sq3DsEuKYlL9clRSjnAw2dnZzJ8/Hx8fH+Li4tDpdAAkJSURGRnJggULGD58OO3bt7dxpKIumzdvZt68eZSUlNg6FPtkQuUTc00WSZOTkbCDWbt2LXq9ngkTJpgTMED//v2JioqivLxcRsN2LCsri9mzZzNjxgxMJhNt2rSxdUj2qaomrObloCQJO5jdu3cDMHLkyBrnqo5Jbdh+vfXWW2zatIl+/fqxfv16AgICbB2Sfaqaoqbm5aCkHOFAFEUhJSUFrVZr8cvr7++PVqslJSUFRVFk5Tg7FBAQwOLFi7n//vvRamUMVKtmNDtCkrADyc/PR6/X06pVK1xdXWucd3Z2xs/Pj4sXL1JcXIy3t7cNohR1mTx5sq1DcAiKYkJRMbqVG3PiqigtLQXAw6P2nTSqlg+UJCwc2lUaCe/du5cVK1aQnJxMRUUFffv2JSoqiqFDh1rdR2pqKsuXL+fAgQNcunSJbt26MWbMGCIiIqz6bUd+H3Igan59bfC2MkLYg6rZEVa/1L9FY0z1PHbsGKNHj+abb76hU6dOhIaGkpWVxb/+9S9mz55tVR8yEnYgnp6eAJSXl9fapqysrFpbIRxSE29v1BhTPRVFYfbs2RQVFfHqq6/yf//3fwDk5uYyYcIEvv76a+644w5GjRpVZywyEnYg3t7eeHp6kpeXh8FgqHHeYDCQl5eHm5sbvr6+NohQiMahmBTVLzUaY6rnnj17SE5OZvDgweYEDNCqVStefPFFANasWVNvLJKEHYhGoyEwMBCj0cjp06drnE9NTcVkMlX7j0oIx2T6YzRszUtlPaIxpnrW1UdwcDCtW7fmwIEDFBUV1dmPJGEHExoaCsC2bdtqnKs6NmzYsKsakxCNTu0oWMVIWO1Uz9qkpKQA1Dro6dGjByaTiZMnT9YZjyRhBxMeHo6bmxsrV67k8OHD5uOHDh0iNjYWd3d3xo4da8MIhbBvVVM9W7ZsWedUz9LSUoqLi2vt5/z58wC0bdvW4vmq4zk5OXXGIzfmHEyXLl2YM2cOMTExPProo4SEhACQkJCAwWBg8eLFtG7d2sZRCnFlfNt6q5p25tu2cjpmVlYWTk5O1c/5+la7R9JYUz2r+qltV+mq4/WtDyJJ2AFFRETQqVMnYmNjOXjwIK6urgQHBzNlyhSGDBli6/CEaDAnJyecnJyYEvu46msrKip48MEHa4xeo6OjmT59uvnPjTXVsyrZ1/dkqqmeh04kCTuosLAwwsLCbB2GuELW3D1vTpydnenXrx9Go1H1tSUlJXz11Vc1jv95plBjTfWsGklXta2tDy8vrzqiliQshLAzzs7OODurT01ubm74+fnV2+7PUz3//F7WTvVs164dR48eJScnh549e9Y4f+HCBaD2mnEVuTEnhGhWGmuqZ69evYA/ZklcTlEUTp06hZOTk8UEfTlJwkKIZqcxpnpW9fH999/XOHfw4EFyc3MZNGhQvWu4SBIWQjQ7aqd6pqenc/LkSQoLC83HBg8eTK9evdizZw+fffaZ+Xhubi4vvfQSAJGRkfXGolFkpRchRDO0du1aYmJicHFxsTjV8/JHkW+//XYyMzNZtGgR4eHh5uNJSUk88cQTlJSUcMMNN9CuXTt+/vln8vPzGTNmjFV7CMqNOSFEs9QYUz379+/Phg0bWLZsGQkJCZw4cYLu3bvzzDPP8PDDD1vVh4yEhRDChqQmfBWcOXOGoKAgi6/evXvTv39/hg4dypQpUyzeKLCF48ePm2O83Ny5cwkKCmLx4sVX/B45OTkUFBRccT/1+eSTTwgKCmLcuHFWtY+PjycoKKjar50NtXz5coKCgpgxY8YV91Wf22+/naCgIH744Ycmfy/ReKQccZX169ev2vPqiqKg1+s5c+YM27dvZ/v27YwdO5b58+fbMMqmt3r1apYvX866detk2U3RrEkSvsqWLl1Kly5dahyvqKjg7bffZsWKFcTFxREaGsrtt99ugwjr9swzzxAVFWXVpPi6LFq0qJEiEsKxSTnCTri4uPD0008zcOBAAOLi4mwckWXt2rWjZ8+etGrVytahCHFNkCRsZ6rWgzh06JCNIxFCXA1SjrAzVU/XXL4S1PLly3n77beZPXs2Hh4evPfee+Tn59OtWzfeeecdunfvDkBGRgYrV67kxx9/5Pz583h5eTFgwAAmTJhQ65SbCxcusHLlSr7//nsuXLhA586deeyxxxg8eLDF9nPnzuWLL75g4sSJzJkzp9q5jIwMPv74Y3bu3ElWVhbu7u5cf/31REZGctttt1X7LFXuu+8+AD7++GPzXE2AX375hdWrV5OYmEhBQQGtW7fm1ltv5amnnjJ/3j87evQo7733HgcPHqSoqIg+ffowZcqUOv++1crJyWHNmjXs3r2bjIwMSktL8fHx4brrrmPMmDF17id26tQp3nzzTfNc1N69e/PYY49x//33W2xfVFTE6tWr2bx5M+np6Tg5OaHT6QgPD+ehhx6qsWSjcEyShO1Meno6AB07dqxxbsuWLfz666907tyZzp07U1JSQteuXYHKrVZmzJhBSUkJHh4e9OrVi9zcXHbs2MGOHTuYPn060dHR1fpLTU0lMjKSc+fO4e7uTq9evcjOzmbBggXceOONquLes2cPM2fOpLCwEE9PTwIDA7lw4QI//vgjP/74IwsWLGD06NF07NiR4OBgDh48CMB1112Hu7s7Pj4+5r7effddli5dCoCfnx86nY6MjAw2btzIt99+y9KlS2s8Urp161aeeeYZ9Ho9fn5+9OzZk2PHjhEVFcWgQYNUfZbaHD16lMjISPLy8vD09DTX9jMyMsyfc9asWUyePLnGtampqYwZM4bi4mJ69epFSUkJBw8e5ODBg+zbt4+FCxdWa3/mzBkmTpxIWloazs7O+Pv7YzKZSExMJDExkS1btvDuu+9aXJRcOBhFNLmMjAxFp9MpOp1OycjIqLXdpUuXlJtvvlnR6XTKyy+/bD6+bNky8/ULFixQTCaToiiKcvHiRXP/wcHBik6nU9566y2lvLzcfO22bdvM57Zu3Wo+bjKZlEceeUTR6XTKxIkTlby8PEVRFMVoNCqrVq1SgoKCzO95uTlz5ig6nU555ZVXzMcuXryohISEKDqdTnn++eeVoqIi83t8+OGHik6nU/r27Vvts1f1nZycXK3/zZs3KzqdTgkODla++eYb83G9Xq+888475nOZmZnmczk5OebP+NprrykVFRWKoihKUVGR8vTTT5vf6/HHH6/17/5yGzduVHQ6nfLggw9WO/7ggw8qOp1O+dvf/qYUFhaajxcWFiqzZs1SdDqdMmjQIEWv15vPXf5vd8cddygpKSnmc999953Sr18/RafTKf/5z3/Mxw0Gg/LAAw8oOp1O+etf/6pcuHDBfO7EiRPKXXfdpeh0OuVf//pXtfjCwsIUnU6nbN++3arPKeyD1IRtTFEUCgoK2LVrF08++SS5ubn4+PgwadKkGm1dXFyYOXOmeRHpqptjH3zwAUVFRTzwwAPMnDmz2uhoxIgRzJo1C6BaGWD//v0kJibi6+vLkiVLaNmyJVC54PXEiROrPbJZn88++4y8vDwGDBhATEyMef1UjUbDhAkTGD58OBUVFXz77bf19rVs2TIAnn32We6+++5qn33q1Kncdddd5l/Tq6xbt46ioiIGDx7M3//+d/PShF5eXrzyyiu1li/UOHv2LJmZmbi7u/PSSy9VW5TF29ubv//97wAUFhaSnZ1d43qNRsPy5currag1atQoc7lk1apV5uNbt27lyJEj9OjRg7feeos2bdqYzwUGBvLWW2+h1WpZt24dFy9evOLPJmxLkvBVNmLEiBoPa9x0001ERUWRlJSEn58f7777rsVyhE6ns7hA9Pbt2wG45557LL7nPffcg0aj4ejRo+Y1Tqt2ih02bJjFebqjR4+2+jPt2LEDgAcffNDiLgMvvfQS27Zt48knn6yzn/T0dE6cOIFWq62WgC937733AtV3wv3xxx8BLNZWXV1da625qtGpUycSEhJISEiw+Pd1+RY3lhb5HjRoUI0HXwAeeughAH777TdzQq1alWvkyJG4ubnVuEan06HT6aioqGDfvn0N+0DCbkhN+Cr788MaWq0WT09P2rdvz8CBA7nrrrtqXc3f0uLQRUVFnDt3DoAlS5bw3nvvWbzWyckJg8FAamoqbdu2Na+jGhgYaLG9pYRRm4yMDOCP9VX/rEOHDlb1U7Uua9Vo3JKqBJeWloaiKGg0GvNnqW3d1t69e1v1/tZwd3fn5MmTJCUlkZaWRkZGBidOnKi2pqyl7Wz69Oljsb/27dvj4+NDYWEhqamptG7d2rw773fffceBAwcsXpeVlQVU1pqFY5MkfJXV9rCGNSyNii6fRXHkyJF6+6haiq+oqAiofbNDHx8fNBpNnXtsVbl06RJQ/zYu9amKyWAwmG/c1cZkMpk3Yay6rrYfXpff9LsSycnJLFy4sMbos3PnzoSHh7Nhw4Zar61rmxxPT08KCwvNP2CqPk9GRob5B1xtLl9aUTgmScIO7vIk+tNPP1n9EEXVr9S17QRbXl5uVQKGytFhUVFRvbvK1qcqUfXq1Yv//Oc/Vl/n6+vLxYsXa92evLY9wNS4cOEC48eP59KlS/Tu3ZvRo0fTp08fevbsiZ+fH3q9vs4kXNffTVXcVf8mVf+mS5cu5c4777zi2IV9k5qwg/P19TUn3lOnTllsYzQa2bt3L2lpaeYNFHv06AFUTruypOpXYmv4+/vXec0PP/xAREREtRuDllTdQDtz5gx6vd5im5ycHPbv31/t5lfVZzl27JjFa2r7e1Fj48aNXLp0iZ49e7J+/XrGjRvHjTfeaH5829LNuMtZ2kYHKke7RUVFaLVaAgICgD/+HuqKOzExkePHjzfKDxhhW5KErwFVc2Y//fRTi+e//vprIiMjeeCBB8wjshEjRgCVN7gsJZAvvvjC6vevehBj06ZNtb7//v37yc/PNx+ruoF3+Wg7MDCQzp07U1paWmtfb7zxBhERETz99NPmY1WfZePGjTXqsSaTqda+1MjMzAQgICCg2k24Kp9//rn5/1vaKTghIcFcu7/cunXrALjxxhvNMy6GDx8OwJdffmlxR+CMjAwef/xx7rvvPhITE9V/GGFXJAlfA5588knc3Nz4+uuvWbJkSbUv7u7du4mJiQHg4YcfNtdH+/XrR1hYGKWlpURHR5tv9ABs2LBB1doVERER+Pr68ssvv7Bw4ULz+yuKwpo1a/jmm29wcXEhIiLCfE1V6eHs2bPmYxqNhqlTpwKwcOFCvvnmG/M5g8FAbGws8fHxANVu3I0ZM4b27dvz22+/8cILL5hHh+Xl5bz44ou1jvbVqBrt79mzh6SkJPPx0tJS3n//fVauXGk+Zilx6vV6oqOjq/3A27BhA6tXr0aj0TBt2jTz8XvvvRd/f3/S0tKYPn26eUYLVI6op06disFgoE+fPlYvPi7sl9SErwGBgYEsXryY2bNns2LFCtasWUOPHj3Iy8szj+BuueUW81zWKi+//DITJ04kKSmJkSNHotPpyM3N5dy5c4SFhVm9Lm27du148803mT59Oh999BHx8fF0796dc+fOcfHiRZycnIiJiTEnMqicfXHw4EGeeeYZAgICePrpp7ntttsYPXo0J06cYPXq1TzzzDMsWrSI9u3bc+bMGfMNwGnTpjFy5EhzX97e3ixZsoSnnnqKzz//nC1bttC9e3fS0tIoKChQ9Vlq8/DDD7N27VoyMzMZM2YM/v7+uLu7k5aWRklJCZ07d0ar1ZKRkcH58+drXB8aGsovv/zCiBEj6NWrF3l5eeaR8ezZs7n55pvNbV1dXXnnnXeYNGkSO3fuZPjw4QQGBlJRUcHp06cxGo106NCBd99994o+k7APMhK+Rtx11118+eWXjB49mpYtW5KcnExeXh7XX389zz77LO+//36NR1zbtm1LXFwc06ZNo3PnzqSkpKDVaomOjub1119X9f6hoaFs2rSJ0aNH4+3tTXJyMkajkZEjR7Ju3boaC6QvXLiQkJAQFEXh9OnTpKWlmc/NmzePVatWcfvtt2Mymcy13ttuu413333X4gLpgwYNIj4+nvDwcDw9PTl+/DidO3fm9ddfr7ZhY0P5+vry+eefM27cOPz9/cnMzCQtLY3u3bsTHR3Npk2buOuuuwAsJvy+ffuybt06QkJCOH36NAUFBdxyyy18+OGHFh/MCQwMZNOmTUyZMoWAgABOnz5Neno63bp1Y+LEiXzxxRd06tTpij+XsD3Z3kgIIWxIRsJCCGFDkoSFEMKGJAkLIYQNSRIWQggbkiQshBA2JElYCCFsSJKwEELYkCRhIYSwIUnCQghhQ5KEhRDChiQJCyGEDf0/VgbHVSe9L9QAAAAASUVORK5CYII=\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.9812796912114015\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>70.0</td>\n",
       "      <td>37.5</td>\n",
       "      <td>17.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>6.666667</td>\n",
       "      <td>5.0</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>70.0</td>\n",
       "      <td>37.5</td>\n",
       "      <td>17.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>6.666667</td>\n",
       "      <td>5.0</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      70.0   37.5   17.0     9.0  6.666667     5.0\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   70.0   37.5   17.0     9.0  6.666667     5.0"
      ]
     },
     "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": "548daef6",
   "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
}
