{
 "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 CXCR4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 3537/3537 [00:01<00:00, 2648.38it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_bond_strength_superlevel_betti/target_cxcr4/\"\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.9954128440366973"
      ]
     },
     "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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yVljzp07B0C9evWKle3YsYPffvuNwMBAAgMDycrKIigoCCh87c6ECRPIysrC3d2d0NBQUlJS+OGHH/jhhx8YP34848aNK3K+uLg4hg0bxqVLl3BzcyM0NJTExETmzJlDu3btVMUdGRnJxIkTSU9Px8PDg5CQEJKSkvjpp5/46aefmDNnDv369aNevXqEh4dz6NAhAO644w7c3Nzw9va2nmv58uUsXrwYAF9fX4xGIwkJCWzatIlvvvmGxYsXF5tau3PnTiZPnkxeXh6+vr40bdqUkydPMnLkSNq2bavqXkpy4sQJhg0bRmpqKh4eHtZnBwkJCdb7fOGFF3juueeKHRsXF8eAAQPIzMwkNDSUrKwsDh06xKFDh9i3bx9z584tUv/8+fMMHz6c+Ph4nJycaNy4MWazmejoaKKjo9mxYwfLly+3uVi8qCIUYXcJCQmK0WhUjEajkpCQUGK9a9euKXfffbdiNBqV2bNnW/cvWbLEevycOXMUs9msKIqiXL161Xr+8PBwxWg0KosWLVJyc3Otx3733XfWsp07d1r3m81m5YknnlCMRqMyfPhwJTU1VVEURTGZTMqqVauUsLAw6zVvNG3aNMVoNCpvvvmmdd/Vq1eVjh07KkajUXnllVeUjIwM6zU++ugjxWg0KnfeeWeRe7ec+9SpU0XOv337dsVoNCrh4eHK119/bd2fl5enLFu2zFp24cIFa1lycrL1Ht9++20lPz9fURRFycjIUCZNmmS91lNPPVXiz/5GmzZtUoxGo/LYY48V2f/YY48pRqNRef7555X09HTr/vT0dOWFF15QjEaj0rZtWyUvL89aduNn16NHDyU2NtZa9u233yotWrRQjEaj8tVXX1n3FxQUKI8++qhiNBqVf//730pSUpK1LCYmRunVq5diNBqV119/vUh8Xbp0UYxGo7J79+4y3afQNulzdjBFUbh+/To//vgjzz77LCkpKXh7ezNixIhidZ2dnZk4cSI6nQ7A+lDuww8/JCMjg0cffZSJEycWaU1169aNF154AaBId8KBAweIjo7Gx8eHhQsXUrNmTaBwIfLhw4ermrq6fv16UlNTad26NbNmzcLT0xMoXP1r6NChdO7cmfz8fL755pubnmvJkiUAvPTSSzz00ENF7n3MmDH06tXL+nXfYu3atWRkZNChQwemTJliXQLS09OTN998s8Ru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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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\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": "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VlZG165diYmJ4eabb7a7jsLCQlasWMHXX3/NyZMn8fb2plevXkyZMoXu3bvXeLyqIOzj48N7771HbGwsR44c4Y8//rCWTZs2DbCs/da+fXvefvttl1r9QgjhPK7GjbkNGzYwa9YsPDw8uOGGGzCbzSQkJBATE8OcOXN44IEHaqzjwoULPPzwwyQlJRESEsItt9xCeno63333HT/++COrV6+mR48e1dah+om51q1bs379erZu3cq3335LcnIyhYWFeHt70759ewYOHMidd95pc8l6IYSwR33PHZGVlcXs2bPx8/MjPj7eulrPgQMHiI6OZu7cuQwcOLDGp37nz59PUlISd955Jy+//LI17q1YsYJXXnmFZ599ls8//7zaOmo1d4RWq+W2227jtttuq83hQghRrfoOwqtXr8ZgMDBx4sQKy6X16NGDmJgYFi5cyNq1a63f8G05deoUGzdupG3bthUCMMAjjzzCpk2byM/P5/z58wQGBlZZzxUtb3T+/Hn279/P7t27OXjwIIWFhVdSnRBCAJapINS+1Ni1axeAzcED5dt27txZbR1btmxBURTGjBlj85v/hg0b2Lp1a7UBGGrZE/7qq69YsWJFpVUztFot119/PVOmTOH666+vTdVCCGFdY07N/nbvqygkJyej1WorTLtQLjQ0FK1WS3JyMoqiVLnCUHn86969O4WFhXz11VccOnQINzc3+vXrx+DBg+1anUh1EH722WdZv3495Qty+Pn5odfrKSwspKCggD179vDzzz/z5JNPyugIIUTtqO3eqtg3Ly8Pg8FAYGCgzR6sm5sbAQEB5OTkUFhYiK+vr8160tPTAcvNubvvvpvMzExr2Ycffki/fv148803qzy+nKp0xBdffMEnn3yCu7s706dPZ8eOHezdu5cdO3awb98+tm3bxvjx49FoNCxYsIA9e/aoqV4IISxq+bDGmTNnOHnyZIXXxYsXK1RdXGxZGdvb27vK03t5WVY4ry7Fmp+fD8CsWbNo2rQpH330Eb/88gvx8fFERkby008/MXv27BovVVUQXrNmDRqNhtdee41JkyZVunPYpk0bnnzySZ5//nkURWH58uVqqhdCCODPIWpqXgCjR49m8ODBFV7vv/9+hbrtnXrB0o6qu9gGg2V1a3d3d1auXEnPnj3x9fWld+/erFixAh8fHzZt2kRKSkq151CVjjh69Cht27bl1ltvrXa/++67j7fffpvffvtNTfVCCAHUfnREfHx8pTlr/vq8gl5vWTW7tLS0yvpKSkoq7GtLeW/5rrvuqnSO4OBgBg0axBdffMHPP/9Mhw4dqqxHVRB2c3OrtlGXCwgIqPQ1QAgh7KKgbj6ISx3WFi1a1Ljasq+vL3q9ntzcXIxGI25uFcOg0WgkNzcXT0/Pah84Kx/10Lp1a5vl5dtrWtxCVTqiT58+HD9+vMbudVZWFsePH6dXr15qqhdCCKD26Qh7aDQawsPDMZlMpKamVipPSUnBbDZXGD9sS3n52bNnbZaXT+kQFBRUbT2qgvCMGTPQ6/VMmjSJ5ORkm/tkZWUxZcoU3NzcmDFjhprqhRDCop4HCg8YMACAbdu2VSor33bLLbdUW0f5/BLbtm3DaDRWKDMYDCQkJADQu3fvauupMh0xffp0m9tbtGjB8ePHGTZsGL1796Zz587o9XqKi4tJTU0lISEBg8HAgAED2LJlC507d662AUII8Vf1OU4YYMSIEcTFxbF8+XJuuukmunXrBsDBgweJi4vDy8uL0aNHW/dPT0+nrKyM5s2b4+fnB0D//v3p3LkzR48eZd68eTzzzDPodDrMZjOvvPIKJ0+e5MYbb7Q5FvlyVQbhzZs3V3ug2Wxm79697N2712b5zp072bVrV7WP/QkhhE31OE4YLCO5Zs6cyZw5cxg1ahR9+/YFICEhAaPRyIIFCyqkEcaNG0dmZibz589nxIgRAOh0Ol5//XX+8Y9/sHr1ar7//nu6dOnCsWPHSE9Pp2XLlsyZM6fGtlQZhGNjY9VdlRBC1JH6njsCYMyYMbRq1Yq4uDj279+Ph4cHvXr1YtKkSfTr18+uOjp27Mhnn33GsmXL2L59Ozt27CA4OJgxY8YwadIkgoODa6xDgrAQotGKiooiKiqqxv2qW7S4WbNmPPvsszz77LO1akOt5o4QQoh6Vc/pCGdSqyBsMpnIysqiuLi40hMlRqMRg8HA2bNn2b59O/PmzauThgohGhPNpZea/V2T6iC8fPlyli9fbn1uuiYShIUQqklP2LYtW7bw2muv2bVvu3btuP3222vVKCFEI9eIgrCqhzU+/vhjAO6++2527NjBnj170Ol03H///Rw8eJCtW7cyceJE61i5CRMm1EujhRANXPnMaGpeLkpVED58+DDe3t48//zzhISE0LRpU8LDw/nxxx9xd3enbdu2PPbYY0yfPp3MzMxKsxcJIYQ96vOxZWejKghfvHiRtm3b4uPjY93WqVMnTp06RV5ennXbww8/jJeXF99++23dtVQI0bjU19pGTkZVENbr9ZWW62jbti0AJ06csG7z8vIiNDSUtLS0OmiiEKLRkXSEbW3btiUjI4OioiLrtvbt26MoCkeOHKmwb0lJSaVJLYQQwh4aRf3LVakKwjfddBNFRUU899xzFBQUAJZF7gDWr19vnWn+wIEDpKamVjnPphBCVKu+l1t2IqqC8MMPP0xAQABfffUVAwYMwGAw0LFjR/r27cuRI0cYMWIE06ZNIzo6GrAEbSGEUE3SEbYFBQXx7rvv0qVLFzw8PKwrlT7zzDP4+/uTnJzMli1bKCwspFWrVkyePLleGi2EaOAaUU9Y9RNzXbp0YcOGDZw+fdq6LSIigk2bNrF+/XoyMzMJDQ3lvvvus867KYQQqjSihzVqPYFPy5YtK/zcrFkzJk6ceMUNEkIICcJCCOFQavO8rpsTrjIIjxw58oor12g0rFu37orrEUI0LmqHnbnyELUqg/ChQ4euuPK/PtghhBCioiqD8Pz5869mO4QQ4k+SE4Z77rnnarZDCCEapUZxY25W/+vJPZ1X844u6OW9ENOu4T4Us/nUd45uQr1JzJzIV783zOsrNQZzOGtMrY+XnLAQQjiSgrrRERKEhRCiDklOWAghHEiCsBBCOI7khIUQwtFcOLCqIUFYCOF8JB1RM5PJxO+//84ff/xBQUEBY8eOpaysjNOnT9OuXbu6bKMQopGRdEQNPvjgA9555x1ycnKs28aOHUtGRgZ33XUXQ4YMYd68efj6+tZZQ4UQjYjaidpdeFJ31UH4mWeeYcOGDSiKQpMmTTAYDJSUlACQnZ2N2Wxm69atZGRkEB8fj7e3d503WgjRwDWidISqlTU2b97M+vXrCQ4OZvny5SQkJNClSxdreZ8+fVi1ahXBwcEcPXqU999/v84bLIRo+GShzyqsWbMGjUbD4sWLGTBggM19rr/+et566y0UReHrr7+uk0YKIRoZWd7ItsOHD9O2bVt69uxZ7X7du3enffv2pKWlXVHjhBCNlNrerQsHYVU94dLSUvR6vV37yk05IcQVaQS9YFAZhFu2bElKSgpFRUXV7ldQUEBycjItWrS4osYJIURDpyoIR0VFUVpayssvv1ztfvPmzcNgMHDLLbdcUeOEEI2U5IRti4mJYePGjaxbt4709HSGDh1KXp5lnt7Dhw9z4sQJPv74Y/bt24e/vz/jx4+vl0YLIRo2eVijCoGBgSxfvpwpU6awZ88eEhISrGX33nsvAIqiEBAQwJIlSwgJCanb1gohRAOj+mGNrl278uWXX7J27Vq2b99OcnIyhYWFeHt70759ewYOHMjo0aMJDAysj/YKIRqDRvSwRq0eW/b19eWRRx7hkUceqev2CCGEpCOEEMKhpCds22effab6BMOHD1d9jBCikZMgbNtTTz2FRmPfbEWKoqDRaCQICyFUu1rpiN27d7Ns2TKSkpIoKyuja9euxMTEcPPNN9euQuDRRx9l165dfPDBB/Tt27fG/VUF4WuuuabKIFxSUkJ2djZ5eXloNBruuusuuTknhKi9eu7dbtiwgVmzZuHh4cENN9yA2WwmISGBmJgY5syZwwMPPKC6zvj4eHbt2qXqGFVBeMOGDTXus2/fPp566ikOHTrEJ598oqoxQggB9d8TzsrKYvbs2fj5+REfH09ERAQABw4cIDo6mrlz5zJw4EBVw2zT0tL473//q64hqHxizh7XXXcdixcvJjU1lbfeequuqxdCNAb1/MTc6tWrMRgMjBs3zhqAAXr06EFMTAylpaWsXbvW7vpMJhMzZ87E3d29Qn32qPMgDJaxxGFhYWzZsqU+qhdCNHT1HITLUwZDhgypVFa+befOnXbXFxcXR2JiIs899xxBQUGq2lIvQRhAp9Nx7ty5+qpeCNGA1eek7oqikJycjFarJSwsrFJ5aGgoWq2W5ORkFKXmio8ePcqSJUu47bbbuPvuu9VcJlBPQXj//v0kJyfTrFmz+qheCNHQ1WNPOC8vD4PBQNOmTfHw8KhU7ubmRkBAAMXFxRQWFlZbl8Fg4IknnsDf35/nn3/e/kZcfj41O69evbrGBqWkpPDFF18AMHjw4Fo1SgjRyNVynPCZM2fQ6XQVivz9/fH397f+XFxcDFDt+pdeXl4AFBYWVjs3+uLFizl27BhvvfVWrUeDqQrCL774ol3jhBVFoV27dkyePLlWjRJCNG61HR0xevRosrOzK5TFxsYydepU689arf0JgOrSEb/88gvvvvsuw4YNs5lbtpeqIHz99ddXX5mbG/7+/vTs2ZORI0fK6hpCiNqrxTjh+Ph4mz3hy5WvDlRaWlplPeUryFe1klBRURFPPfUUwcHBPPfcc+obehlVQXjVqlVXdDIhhKhPLVq0wNPTs9p9fH190ev15ObmYjQacXOrGAaNRiO5ubl4enpWCuDl1qxZQ3p6OpGRkcyZM6dCWXJyMgDLli1j3bp1jBo1iuuuu67K9qgKwuPHj6d58+Y8/fTTVTZOCCGuVH0+rKHRaAgPD+fAgQOkpqYSHh5eoTwlJQWz2VzteN/yJd6SkpJISkqyuc/u3bsB6N+/f90F4d9++w1fX18JwEKI+lXPE/gMGDCAAwcOsG3btkpBeNu2bQDVLs82derUCnnmy40bN46ffvrJ7rkjVA9Ra9KkidpDhBBCnXp+WGPEiBF4enqyfPlyDh06ZN1+8OBB4uLi8PLyYvTo0dbt6enpnDhxgvz8/Cu5KptUBeFhw4Zx/Phxvv322zpviBBCXE6j4qVWmzZtmDlzJgUFBYwaNcq6SMWDDz5IYWEhc+bMqfDk27hx47jjjjvYunXrlV5WJarSEcOGDePIkSPExsZy7bXXcu2119K8eXObA57LjRkz5oobKYRoZK7CfMJjxoyhVatWxMXFsX//fjw8POjVqxeTJk2iX79+6iusJVVB+MEHH0Sj0aAoComJifz66681HiNBWAih1tWaTzgqKoqoqKga99u+fbvdda5cuVJVG+p0nLAQQtQJWVkDTp06haenZ4W8iIwTFkJcFY0oCFd5Y27QoEFMnz79arZFCCGASzfc1Myi5ugGX4Fq0xH2TOMmhBB1rhH1hGXJeyGE07laN+acgQRhIYTzkZ6wuBK+TYyMfTyL/kPzCGxuJC9Hx77v/Vn9eghnM6seU12b+qqi9zPxQOxZbrrjAs3blFGUryMp0ZvP3g1m/w4/u84bGFJG3I6j7N/px0sTQlW3u6HJv6Djw9dbsPvrJpw/60aTICPXDcxnzONnCGlTprq+M8nnmP9Se37b7UtRvo6QdqXcdEce98Scwz/AVGHfV//Vjq0f2zdf7djHz/DQv8+obo8zkZ7wJTk5OXz22WdXdILhw4df0fGuxreJkYWfJ9OuUymF+VpSjnjRsp2B2x88z41D83ji3o6kHKl6Mmm19Z0sTat0jI+/icVfHqdteCllBg0nT3ii9zPR99Z8+t6az+qFzfngvy2rPa+7h5mZS9Lx8Terfg8aovwLOh4b1omMZC/0viY6dCnhdLoHmz8K4sevm/Df9cmEXVNid327v27Cm5NWYjQE4Oltol1ECedOuRO/qAXb1gUyb80J2ob/OdVi67ASul5fUE373Eg/bpmIvGVo1VM0ugzpCVukpaUxa9asWleu0WgaXRD+139P0q5TKQnb/Jg/qT3FhTrcPc1Me/kkf38gl1lL0/jnoEjMZvvu59ZUX2jZErTaoAr1Pf56Bm3DSzm6X89LE9pz7pSl993vtjye+V8aYx47y2+7ffntR9s9Yi+9iaeXpnHtTVX/0Tc2i55oS0ayF30G5zFraRp6XzOGEg1vPNWGrR8HMX9SKMu2H+UvU9nadCbdgwVT22E0mOh/+wVmLMzAt4kJkwk+fK0F8Yta8OzYMJZ/fxQPL0t0eXDaWR6cdtZmfYoCs0Z1JP24F4NHnmfIyNy6vHTHkCBs4eHhoXrl0MasbXgJN96RR1GBlv9Oa0dxoeUvsqxUy8IZbYnsWUT7iFL6D83jh01N66i+TPoPdbPWF9i8jH635WEywbxJ7awBGOCnzU34enUgw6JzuP3B8zaDcHj3Ip5ckk77iAbQm6oj6cc9+fGrJnj7mHjijXT0vpZvBx5eCo+9lkFSog/px73Y/XUTBtyVV2N96/8XTEmRjuYdmvH0st9w97BEEJ0O/vHkGQ797MOB3X58tiKY+6fYDryX+2xFMxJ3+RHSxkDsvJNXdrFOQtIRl3Tr1q3GdeWuhg0bNjBr1ixWr15d7bycjjZoRC5aLSRs9Sf/QsW31mzWsGVtIDHPneaWYRfsCsK1qc/H38Q38YG4uStkZVSe3Dr1qOUra3CryjnMB6dl8dATZ9Dp4Mgvek4c8uauf+TYefUN1/YNASiKhr63XqyUq9Xp4O8P5BD3Umt2fB5gVxAuz8n3v78X7h7bKpUPG5fNgd1+bP80oMYgnJPlxsqXLaml2PkZ1g8I4Tqc/sZcYmIiL774oqObYZfOvSwTPR/e52Oz/OgvlqVSuvWtfgXXK6kvI9mLN2a2rbLOTj0sixyeSq18gzDi2iLKSrWseqM5a99qzuh/ZdnVzobu6H7L+3/NdbZ/b517W35PhxJs/57+6uylbyetOrewWd6qg+VbSNpRL0qKNHjpq+7mrXq1BSVFOvoMzqPP4LqfZtGhXLh3q0a9LHlfVzZv3swjjzxincXe2bUKNQCWnJ8tWZdGRgQ2N+KlN9ncp77q89KbuD82i7+POk9psYYN7wRX2mfbugCi+3dmzRshmE2u/AxS3Sr/wGrRzmCzPKS1ZXvuOXeKC+3/kzKbbPdaTUbLe282a8g+XfVomvTjnmz+KAiNRmH806ftPq8r0CiK6percsqe8JkzZ3j99dfZuHEj3t7eNGvWrNIKqs6oSZARgIu5tu/O5F+2vUmgiZKi6u/i1EV9nXoU8fhrGbTqYMBLbybrpDsLZ7Ql9WjlERo/ft202vY0Vnk5lj8T/wCjzXK/y1IUeefd8PaxHazLtWhrIP24F2eSz9ksTzvmZf3vgryq/418GheM2aShz5A8OnSxf2SGS2hEN+acsie8aNEiNm7cSLdu3Vi7di1hYWGObpJdPLwsPRtDie239fLt5fvWd33tI0oI61qCl95S7tvERJ/BF3H3kNyhvcrf56re48u3G0pq/gbRd4glb7zrwwQMpRX3N5th/bLm1p/LymzXV5CnY/v6AADum1TzzTtXo2reCJU38ZxNlUE4NjaWESNGXM22WIWFhbFgwQLWrVtHZGSkQ9pQGzV9hdeo/Miri/r2fufHPZHduL9bVxbEtqPMoGHEhGyei0tV15hGTKur/i9cUfl5ds+Ec/gHGMk5eYFnx4aRfNAbYxlkJHvy4qOhZKZ44nkpsLu52T73lo8DKSnSEfG3Inr0s+8eg0up5+WNnEmV6YjY2Nir2Y4KJkyY4LBzX4mSIi3uHibcPW3/VV7e+ywtrjmC1kV9eTnu1v/eviGAjGRPFn95nL5D8vnbjflVjhUWf/LSmynI01JWavs9LjP8ud3Tu+aIHBRi5PmVf/Dswz347UeYctufHQ1vHxOz3k5l4Yx2lJZo0fvZzvX/8KVlrceoEQ1gTLAtanu3DTEIC/Xyc3X4NTXh19T2H47/X3KHV7s+gOMH9CT+4Mt1Awvo0a9QgrAd/AJMFOS5kX/Bdn72YoXcvO288V91vb6Ix9dNIG3zLI4mWkZVhHcv4o4xOQQ0N1Jw0VJnYPPK9eXl6Djyiw8ajcLNd11QeTUuohHlhBtFEJ75+aSrch6foFeARP75VhTZhbdWLvc4AsyhzNSUF3Y+XS/1aTDi4XYWRdFhMNmeW6JNk/eALdw+sRtdH3i0yvO38PsEWE+3wZG8vPexGttbHxIzHXLaCpq0Wcfp1BPsOzgJt8helcr/SEwH4vFr5suR3DVgZ+fUNwC6jlpM11F/bssEEnaewWxaiX+wL8mFq+Ev2Yb9Xx3CbP6S9n9rQ4Z5FhlO8B7VNXlYo4FZMGwpuadrHkR/pcbOOMNDM+Dolk959V+/VCq/b/JZIp6Fn7eYmfPIy/VSX/RTpxk17SwJW/34zz9s39D8z4oUgofCV28fYvXCqttRfv5D3ybx0oSa21sfNp/61SHnvdyhPi04+kMLCv74iJ6tX6lUfvyz5kArul93kp6tR1Wu4C8OJviQlKjHvcMs/u+2xyuV//5RCNCS3jel26zvhz/aAM3oP3AfPVt/WYsrqn+lxmAOZy25skpcOLCq4ZSjI1zVj19Z8nT9b8/Dr2nFr5FarcKt958HsN7Vro/6ftvtC0CvWwpo3rryUKmW7Uu5PsoyqD9hm79d7WjsbrzjAgC7v2lSabigyYR1drNB99rXBT66X8/yOa35IX5vpbLCfC2bVjUD4K6HbT+teOKQZXhhePdiu87nimR0hKiVlCPeJGz1w8ffzLPvpOF3aVypu6eZx17LoH1EKRnJnvz4dZMKx/kHGmkbXkLL9qWq6yspa1Whvv07fUlK9MbdQ+G5uFRaXTajVmjnYl5clYKHl8L3G5uSfFBfX29FgxJ2TQl9huRRlK/jpQmhXDxvCcSGEg0LZ7Ql/bgXbTqWcOPQit+28nJ0pB/3rPR0Yv/b83D3MHNw2xG++7Spdfv5s268ML4D58+602dwXpVPVv5x2DKOuH1EAxsbfDkFy8xEdr8c3eDaaxTpiKvpjafa8FrnZK69qYAP9x4h/bgnLdsZLt3c0fLC+FAUpeLQs2HR2Tw0I4szGe78o+81qupLL3kcRbl8AVYNL00IZcG6E0T8rZi4nUc5ecITNNA2vBStFhJ3+bJwRpur8G40HNNePsmM4d789qMfY6+/hnadSjmd7kHBBTd8/E3MfjcF7V+6NJ+/F8yHr7cgpI2BD34+bN3euoOBmOdO8fZzbXh5SijvvVyKr7+J9ONelBm0dOpRxFNvV56iFKDwopbSYsuHQFU3bBuCxpQTlp5wHcs+7UHs7RF8GteMCzk6OnQpwWTS8N2nTZl6RwQZyV41V6KivlJj60rHnM20HBO/qDmZKZ60bG+gWcsyDu/Ts+jfbXj6wbAan9YTFQW3KuPNb5IY/sg5mgaZSDnihU6nMHB4Lku+SqJdJ3Wzzv3fI9mMfeUeut9QwMXzlrmAW3UoZdxTp3jt0+P4+Nke6nYx989+U1XD1xqERjROWKO4wGqeDz30ED///LPqWdRKS0s5dOjQVbsx5wgv732Kp653zE2zq8EZbszVl8TMj+y6keeKym/MdevWDU/PyrP5VXncpb/Z2cv2cP6i/emWQH8vXvjnDarP5wwkHSGEcD4yTti5rFq1quadhBANhgaVOeF6a0n9k5ywEEI4kEv0hIUQjUz50DM1+7soCcJCCKfTmIaoSRAWQjgfuTEnhBCOIz1hIYRwJMkJCyGEA8mk7kII4UCSExZCCMdpTA9rSBAWQjgfs2J5qdnfRUkQFkI4H0lHCCGE48gQNSGEcCQZoiaEEI4jPWEhhHCkq5QT3r17N8uWLSMpKYmysjK6du1KTEwMN998s9117Nixgw8++ICDBw9SVFREcHAwAwYMYPLkybRo0aLG42UqSyGE09GgoFFUvGoRhTds2EB0dDSJiYn06NGDnj17kpiYSExMDGvXrrWrjnfeeYcJEyawe/duOnToYA3ea9eu5Z577uHEiRM11iE9YSGE8zFfeqnZX4WsrCxmz56Nn58f8fHxREREAHDgwAGio6OZO3cuAwcOJCQkpMo6kpOTWbhwIXq9nnfffZeePXsCUFZWxrx584iPj+fpp5+uMaBLT1gI0eisXr0ag8HAuHHjrAEYoEePHsTExFBaWlpj8Ny4cSNms5no6GhrAAZwd3fn6aefJjAwkF9//ZXMzMxq65EgLIRwOqpSEZdeauzatQuAIUOGVCor37Zz585q63B3dycyMpLrr7/eZlmbNm0AOHv2bLX1SDpCCOF86vHGnKIoJCcno9VqCQsLq1QeGhqKVqslOTkZRVHQaGw/FD1t2jSmTZtms6yoqIjk5GSAGm/OSU9YCOF8yscJq3nZKS8vD4PBQNOmTfHw8KhU7ubmRkBAAMXFxRQWFtaq+cuXL6eoqIju3bvTsmXLaveVnrAQwunUdpzwmTNn0Ol0Fcr8/f3x9/e3/lxcXAyAt7d3lfV5eXkBUFhYiK+vr/0NwTJk7X//+x9arZYnnniixv0lCAshnI+CyifmLP83evRosrOzKxTFxsYydepU689arf0JAEVlrvn7779n2rRpmEwmZsyYQd++fWs8RoKwEMLpaBTQqBh2Vt4Tjo+Pt9kTvpxerwegtLS0yvpKSkoq7GuPTz75hNmzZ2M0GomNjWXChAl2HSdBWAjhfGo5d0SLFi3w9PSsdldfX1/0ej25ubkYjUbc3CqGQaPRSG5uLp6enpUCeFUWLlzIsmXL0Gg0zJo1i3HjxtnddLkxJ4RwPkotXnbSaDSEh4djMplITU2tVJ6SkoLZbK4wfrjKZioKzzzzDMuWLcPDw4PXX39dVQAGCcJCCGekdoywytztgAEDANi2bVulsvJtt9xyS431vPzyy3zyySf4+vqyYsUK7rjjDlXtAAnCQghnVI9D1ABGjBiBp6cny5cv59ChQ9btBw8eJC4uDi8vL0aPHm3dnp6ezokTJ8jPz7du27lzJytXrsTNzY3//e9/9OnTp1aXKjlhIYTzqee5I9q0acPMmTOZM2cOo0aNso5iSEhIwGg0smDBAoKCgqz7jxs3jszMTObPn8+IESMAeOONNwAICgrio48+4qOPPrJ5rkmTJtGxY8cq2yJBWAjhdMpnUVOzv1pjxoyhVatWxMXFsX//fjw8POjVqxeTJk2iX79+1R574cIFDh48CFgmA/riiy+q3Pe+++6TICyEcDFXaWWNqKgooqKiatxv+/btFX5u2rQpSUlJtTrnX0kQFkI4H1neSAghHKiec8LORIKwEMLpqJ2eUu1Uls5EhqgJIYQDSU9YCOF8ajmBjyuSICyEcD5yY04IIRxJ7VNwEoSFEKLuyOgIIYRwnMY0OkKCsBDC+UhOWAghHMisWF5q9ndREoSFEM5HesJCCOFIMjpCCCEcRx7WaBjKl6v2b+7n4JbUr4CWTRzdhHpTagx2dBPqVUO9PoMpEFC/ZLyV5IQbhrKyMgAmxY11cEvq18zPJzm6CfXmcJajW1C/DmctcXQT6lVZWRleXl7qD1TMlpea/V1Ugw7CPj4+RERE4O7ujkajcXRzhGg0FEWhrKwMHx+f2lYgN+YaAq1Wi59fw05FCOGsatUDLifpCCGEcCQZHSGEEI4j6QghhHCgRjRETVbWEEIIB5KesBDC+ZjNlpea/V2UBGEhhPORnLAQQjhQIwrCkhN2Ubt37+bhhx+mb9++9OrVi4ceeoidO3c6ullCpQ0bNhAZGcm+ffsc3RTnoih/jhW25yVBWFxNGzZsIDo6msTERHr06EHPnj1JTEwkJiaGtWvXOrp5wk6JiYm8+OKLjm6GU1IUs+qXq5J0hIvJyspi9uzZ+Pn5ER8fT0REBAAHDhwgOjqauXPnMnDgQEJCQhzcUlGdzZs3M2vWLIqKihzdFOdkRuUTc/XWknonPWEXs3r1agwGA+PGjbMGYIAePXoQExNDaWmp9Iad2JkzZ3jyySeZNm0aZrOZZs2aObpJzqk8J6zm5aIkCLuYXbt2ATBkyJBKZeXbJDfsvBYtWsTGjRvp1q0ba9euJSwszNFNck7lQ9TUvFyUpCNciKIoJCcno9Vqbf7xhoaGotVqSU5ORlEUmTnOCYWFhbFgwQKGDRuGVit9oCo1otEREoRdSF5eHgaDgcDAQDw8PCqVu7m5ERAQQE5ODoWFhfj6+jqglaI6EyZMcHQTXIKimFFU9G5d+cacfBS7kOLiYgC8vb2r3Kd8+sDCwsKr0iYh6kUjyglLT9iFqPn6WutlZYRwBo1odIQEYRei1+sBKC0trXKfkpKSCvsK4ZJkeSPhjHx9fdHr9eTm5mI0GnFzq/jrMxqN5Obm4unpib+/v4NaKcSVU8wKioqesJp9nY3khF2IRqMhPDwck8lEampqpfKUlBTMZnOF8cNCuCbzn71he14unI+QIOxiBgwYAMC2bdsqlZVvu+WWW65qm4Soc5d6wva+XHmNOQnCLmbEiBF4enqyfPlyDh06ZN1+8OBB4uLi8PLyYvTo0Q5soRBCDckJu5g2bdowc+ZM5syZw6hRo+jbty8ACQkJGI1GFixYQFBQkINbKcSV8Q/2VTXszD/YdcfESxB2QWPGjKFVq1bExcWxf/9+PDw86NWrF5MmTaJfv36Obp4QtabT6dDpdEyKG1vrY12NRpEBpUIIJ2I0GjGZTKqP0+l0lUYMuQIJwkII4UByY04IIRxIgrAQQjiQBGEhhHAgCcJCCOFAEoSFEMKBJAgLIYQDSRC+Ck6ePElkZKTNV+fOnenRowc333wzkyZNsjknhCMcO3bM2sbLPfXUU0RGRrJgwYIrPkd2djYXL1684npq8uGHHxIZGclDDz1k1/4bNmwgMjKSESNGXPG5lyxZQmRkJNOmTbviumoyaNAgIiMj+e677+r9XKLuuN7IZhfXrVu3CksTKYqCwWDg5MmTbN++ne3btzN69Ghmz57twFbWv5UrV7JkyRLWrFkj026KRk2C8FW2ePFi2rRpU2l7WVkZb775JsuWLSM+Pp4BAwYwaNAgB7Sweo8//jgxMTEEBARcUT3z58+voxYJ4dokHeEk3N3deeyxx+jZsycA8fHxDm6Rbc2bN6djx44EBgY6uilCNAgShJ1MVFQUYJmaUgjR8Ek6wsmUL1N/+WrJS5Ys4c033+TJJ5/E29ubpUuXkpeXR7t27Xjrrbdo3749ABkZGSxfvpwffviBs2fP4uPjw7XXXsu4ceOqnF3t3LlzLF++nG+//ZZz587RunVrHnzwQfr06WNz/6eeeopPP/2U8ePHM3PmzAplGRkZfPDBB+zYsYMzZ87g5eVF9+7diY6O5qabbqpwLeXuvvtuAD744APrtJwAe/fuZeXKlSQmJnLx4kWCgoK48cYbmThxovV6/+rIkSMsXbqU/fv3U1BQQJcuXZg0aVK177da2dnZrFq1il27dpGRkUFxcTF+fn5cc8013H///dx2221VHvvHH3/w+uuvW6cd7dy5Mw8++CDDhg2zuX9BQQErV65k8+bNpKeno9PpiIiIYMSIEdx7770uOWOYqEyCsJNJT08HoGXLlpXKtmzZwq+//krr1q1p3bo1RUVFtG3bFoBdu3Yxbdo0ioqK8Pb2plOnTpw/f57vv/+e77//nqlTpxIbG1uhvpSUFKKjozl9+jReXl506tSJrKws5s6dy3XXXaeq3T/++CPTp08nPz8fvV5PeHg4586d44cffuCHH35g7ty5jBw5kpYtW9KrVy/2798PwDXXXIOXlxd+fn7Wut5++20WL14MQEBAABEREWRkZLB+/Xq++uorFi9eXGn1kK1bt/L4449jMBgICAigY8eOHD16lJiYGHr37q3qWqpy5MgRoqOjyc3NRa/XW3P7GRkZ1uucMWMGEyZMqHRsSkoK999/P4WFhXTq1ImioiL279/P/v372bNnD/Pmzauw/8mTJxk/fjxpaWm4ubkRGhqK2WwmMTGRxMREtmzZwttvv13hJq9wUYqodxkZGUpERIQSERGhZGRkVLnfhQsXlBtuuEGJiIhQXnzxRev2N954w3r83LlzFbPZrCiKouTk5Fjr79WrlxIREaEsWrRIKS0ttR67bds2a9nWrVut281ms/LAAw8oERERyvjx45Xc3FxFURTFZDIpK1asUCIjI63nvNzMmTOViIgI5eWXX7Zuy8nJUfr27atEREQozz77rFJQUGA9x3vvvadEREQoXbt2rXDt5XUnJSVVqH/z5s1KRESE0qtXL2XTpk3W7QaDQXnrrbesZZmZmday7Oxs6zX+97//VcrKyhRFUZSCggLlscces55r7NixVb73l1u/fr0SERGh3HPPPRW233PPPUpERITyr3/9S8nPz7duz8/PV2bMmKFEREQovXv3VgwGg7Xs8t/drbfeqiQnJ1vLvvnmG6Vbt25KRESE8uWXX1q3G41GZfjw4UpERITyz3/+Uzl37py17Pjx48rQoUOViIgI5aWXXqrQvqioKCUiIkLZvn27XdcpnIPkhB1MURQuXrzIzp07efTRRzl//jx+fn488sgjlfZ1d3dn+vTpaDQaAOvNsXfffZeCggKGDx/O9OnTK/SOBg8ezIwZMwAqpAH27dtHYmIi/v7+LFy4kKZNmwKg1WoZP348//d//2f3NXz88cfk5uZy7bXXMmfOHHx8fADLwqTjxo1j4MCBlJWV8dVXX9VY1xtvvAHA008/zR133FHh2idPnszQoUOtX9PLrVmzhoKCAvr06cO///1v65yyPj4+vPzyy1WmL9Q4deoUmZmZeHl58cILL1jTRmBJIf373/8GID8/n6ysrErHazQalixZQseOHa3bbrvtNmu6ZMWKFdbtW7du5fDhw3To0IFFixbRrFkza1l4eDiLFi1Cq9WyZs0acnJyrvjahGNJEL7KBg8eXOlhjeuvv56YmBgOHDhAQEAAb7/9ts10REREhDXAXW779u0A3HnnnTbPeeedd6LRaDhy5Ajnzp0DLOkLsCwKamuc7siRI+2+pu+//x6Ae+65x/oBcbkXXniBbdu28eijj1ZbT3p6OsePH0er1VYIwJe76667ANi5c6d12w8//ABgM7fq4eFRZc5VjVatWpGQkEBCQoLN98vLy8v63yUlJZXKe/fuXenBF4B7770XgN9//90aUL/99lsAhgwZgqenZ6VjIiIiiIiIoKysjD179tTugoTTkJzwVfbXhzW0Wi16vZ6QkBB69uzJ0KFD0ev1No8NDg6utK2goIDTp08DsHDhQpYuXWrzWJ1Oh9FoJCUlheDgYFJTUwFLz8oWWwGjKhkZGQB06tTJZnmLFi3sqic5ORn4szduS3mAS0tLQ1EUNBqN9Vou72VernPnznad3x5eXl6cOHGCAwcOkJaWRkZGBsePH7e2HcBsrrz8epcuXWzWFxISgp+fH/n5+aSkpBAUFMSJEycA+Oab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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, 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.9850621248080413\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>92.307692</td>\n",
       "      <td>46.153846</td>\n",
       "      <td>18.461538</td>\n",
       "      <td>9.230769</td>\n",
       "      <td>6.153846</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>92.307692</td>\n",
       "      <td>46.153846</td>\n",
       "      <td>18.461538</td>\n",
       "      <td>9.230769</td>\n",
       "      <td>6.153846</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     92.307692  46.153846  18.461538  9.230769  6.153846     5.0\n",
       "1           NaN        NaN        NaN       NaN       NaN     NaN\n",
       "mean  92.307692  46.153846  18.461538  9.230769  6.153846     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
}
