{
 "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 HIVPR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 37674/37674 [00:15<00:00, 2417.74it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/partial_charge_superlevel_betti/target_hivpr/'\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.9832669322709163"
      ]
     },
     "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": "iVBORw0KGgoAAAANSUhEUgAAAWEAAAE+CAYAAABcJ6H1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABMO0lEQVR4nO3deVyU5drA8d8MOwIKLoiKIiJoKm9q5lLm2rHVzKzMpSMWdlS0zJNLy7EstzYz0zypZZqYmZTtLllqmZRJR01FMXYVARHZh5l53j9GRokB5kFwZuD6vp/5vMdnued+mObi5ro3jaIoCkIIIWxCa+sKCCFEQyZBWAghbEiCsBBC2JAEYSGEsCEJwkIIYUPOtq6AEEJcTa/XYzAYVN/n5OSEs7PjhTTHq7EQot7S6/UcPfwzBsVL9b1OTk507drV4QKxY9VWCFGvGQwGDIoXHZr9B1enC1bfpzP4cTprPgaDQYKwEEJcKydtFk5OmdZfrxjrsDZ1S4KwEMLuGFEwYv1kXjXX2hsJwkIIu2O8/H9qrndUEoSFEHbHqCgYVCxrY3TgJXAkCAsh7I4RdSkGx20HSxAWQtghAwpaFUHYIDlhIYSoPYrKjjlFgrAQQtQeg6KgUZHnVZM/tjcShIUQdseIujyv5ISFEKIWGVFU5XkdeZywrKImhBA2JC1hIYTdMQBqGrfq11yzHxKEhRB2xwhoVF7vqCQICyHsjhENasKwUVXIti8ShIUQdseooCodYXTcfjkJwkII+2NAgyItYSGEsA2jyiCs5lp7I0FYCGF3jIoGjaIiCKu41t5IEBZC2B0DoFHVEnZcEoSFEHbHiBZ1c8m0DjvzTIKwEMLuGBUNqEkxKBoJwvbIaDRSUFCAi4sLGo3j5oyEcDSKolBaWkqjRo3QatWHR4PKccKgcdhg5qj1tkpBQQEnT560dTWEaLBCQ0Px9vZWfZ9R0aIo1gdvjYpr7U29DsIuLi4ABDd9AVenCzauTd04cX4FnVpMtXU16kxE3662rkKdmb1tMkvue9fW1agTPi28mbx6nPk7qJZpiJqKICxD1OxTWQrC1ekCrs6ZNq5N3anPz5Zz9pKtq1Cn6vvz1TQNqHayhgRhIYSoRUZFi1FFikEr6QghhKg9RjQqpyI7bkvYcX99CCFEPSAtYSGE3TGgvTxhwzpqOvHsjQRhIYTdMSoaDGryvLJ2hBBC1B6jypaw486XkyAshLBDBkWDQeW0ZUclQVgIYXeMaDFIS1gIIWzDiLpxwmpSF/ZGgrAQwu4Y0KhsCUs6Qgghao1RZU5YKzlhIYSoPWpHR0g6QgghapFB0aoaJyxrRwghRC1SVK4dIbstCyFELTKonDGnakyxnZEgLISwOwaV44TVXGtvJAgLIeyOomhMm32quN5RSRAWQtid69US3r9/P6tWrSI+Pp7S0lK6dOlCZGQkt912m9Vl/PHHH7z77rvExcVRWFhIy5YtGTx4MFOnTqVx48bV3u+4bXghRL1lVDTm3TWse6lvCcfExBAREUFcXBzh4eF0796duLg4IiMj2bx5s1Vl7Nq1i7Fjx/Ljjz8SFBTEbbfdRklJCR9++CEPPvggFy5Uv7eltISFEA1ORkYG8+bNw9vbm+joaEJDQwE4fPgwERERLFiwgIEDB+Lv719pGXq9nnnz5mE0Glm+fDn/+Mc/ACgpKeHJJ5/khx9+YMWKFbzwwgtV1kVawkIIu2NEc3nqsnUvdVshwcaNG9HpdEyYMMEcgAHCw8OJjIykpKSk2tZwfHw8WVlZdOrUyRyAAdzc3JgyZQoAv/32W7V1kSAshLA76lIR6hb7Adi3bx8AQ4cOrXCu7NjevXurLEOrNb1ndnY2er2+3LmcnBwAyQkLIRyTmlZw2ctaiqKQkJCAVqslODi4wvmgoCC0Wi0JCQkoilJpOSEhIQQEBJCRkcGsWbNISUmhqKiIX375hZdeegmtVktERES19ZGcsBDC7igqW7eKimtzc3PR6XT4+fnh6upa4byzszO+vr5kZ2dTUFCAl5eXxXJcXFx4++23iYqK4uuvv+brr782n2vRogVr1qzhlltuqbY+0hIWQtgdAxrz+hFWvS63hM+dO0daWlq516VLl8qVXVRUBICHh0el7+/u7g5AQUFBlfVs27Yt9957L05OToSHhzNo0CCaN2/O+fPnWbNmDRcvXqz2WaUlLISwO0aVnW1l144ZM4asrKxy56Kiopg2bZr532W5XGtUlY7IyclhzJgxZGRk8MEHH9C7d28AdDod8+fPZ8uWLURFRfHRRx9V+R4ShIUQdseoqJusUZa6iI6OxsnJqdw5Hx+fcv/29PQETEPJKlNcXFzuWkvWrl3LX3/9xTPPPGMOwACurq7MmzePgwcP8ttvv3Hw4EFuuummSsuRICyEsDtGRWVL+PJkjZYtW+Lm5lbltV5eXnh6epKTk4Ner8fZuXwY1Ov15OTk4ObmViGAX+3XX38FsJj3dXFxoV+/fiQmJnLs2LEqg7DkhIUQdqds2rKal7U0Gg0hISEYDAaSkpIqnE9MTMRoNJYbP2xJWa757y3vMmXHS0tLqyxHgrAQwu4YLy/go+alRv/+/QHTtOO/Kzs2YMCAKssoG962Z8+eCucMBgMHDhwAoFOnTlWWI0FYCGF3TIu6a61+qV3UfeTIkbi5ubF69WqOHj1qPn7kyBHWrFmDu7s7Y8aMMR9PSUnh9OnT5OXlmY89/PDDAKxatYrff//dfFyv1/Pqq69y8uRJOnbsSJ8+faqsi+SEhRB2x6Com4ChdlH3Nm3aMHv2bObPn8/o0aPNHWuxsbHo9XqWLFlC06ZNzddPmDCB9PR0Fi1axMiRIwFTS3nSpEm89957jB07lhtvvBE/Pz+OHz/OmTNnaNasGW+99Val6YoyEoSFEHanph1zaowdO5ZWrVqxZs0aDh06hKurKz169GDy5Mn07dvXqjJmzpxJjx492LBhA0eOHOHo0aO0aNGCcePG8cQTT9CiRYtqy5AgLISwO4qibrdlNTPmrjZo0CAGDRpU7XW7d+++5jIqI0FYCGF31K4HoeZaeyNBWAhhd4yoG/GgdilLeyKjI4QQwoakJSyEsDumjjkV05bR4KiNYQnCQgi7o6hcwEftOGF7IkFYCGF3VI8TlpawEELUHqPKIWpqrrU3EoSFEHZHUTlZQ9IRwip5F52IfjOA/d81Jue8C42b6uk58BKPzDiHfxud6vKSTrizack2lsR1ozDPCf+2Jdxy10VGPH4eb1+DxXtKijTE/NefvV/4cjbZDScnhaBORdw1PoshD1641kes17wa6xn39Dn63ZGLXws9udnOHPzRm41LW3I+veI2OdVx0uTzr5fSVJXn6m5kxMRMbrv3Iq2DS3ByUjif7sovOxqzZWULLuXUj690TRd1d0SO24Z3MHkXnfj3fWFsW9uC/FxngjoXUVKsZcfHzZj2j04kHqt8qxVL9n/XmCfv6sT/dhynMF9LYGgRly44s+mtAKKGdSItoeKaqkUFWmaPCmXDa61IPeWOfxsd3r56jv/uxRtPBbH06ba19bj1jldjPUu3neL+x7Pwamwg8bg7bu5G7njkAit3xNO+c5Hq8kKbz1NVnncTPcu+PMljz52lQ1fT552R5kpAuxIemnKeFdvjaRVU+ULljsSoqF1JzdY1rjkJwtfJ28+0JTXBnV6Dc9nw+xHe/jaej34/wtCHssnPdWbxlCAMlhuvFZxLceX1aUGUlmi5YWBHNvx+lLe/jWfDoSM88tRZMtPd+M/4EHTF5VsHH70ewMk/GtG0pY5l357gv3uOsS72T/7zwWmcXY3s3NyMH2J86+DpHd9Tr6XStmMJsd/7MLZnF6bdFcYjPbuwY7Mf3k0MzF2ZhFZrfSR46rVU3F3OqCpv2qI0gm8oJuWUG5NvD+OffW8gcmBnJvS7gaO/NqJF61KefTcJcOCIdFldb3lvT+y25vv37+fRRx+ld+/e9OjRg/Hjx7N3715bV6tGUhPc2P9tEzwaGfj320l4ehkBcHVXePL1ZAI7FpF6yoNfvm1iVXmfvdeC4kIn2oYWMWbhCLwam6K3kxOMf+Ys4X3zOJfixrb3yy8esnurHwCP/yedDl2vtLT6/COX+yZmArBrS1NEeYEdirnlzlwK87W8Nr0tRQWXF+su0bL034Ekn3SjXWgJ/e7MVVWewehudXnNAnT0v+ciBgMsiWpH0okrfzllnnHllUlBFOZr6RheRLc+VW9O6QgUlWsJKzVYwMde2GUQjomJISIigri4OMLDw+nevTtxcXFERkayefNmW1dPtd1b/VAUDTffnlshV+vkBLc/nA3A3i+sa4Ue2mPacuXeCZk4u1RcJu+eCaaA+uNVrVp9KeRmuwAQ1Knin7oh4YUAZNYgt1nfDX4gB60WYnf6kHexfM7VaNSwY7PpF9eA4Tmqysst7mF1ed365KPVmv4KSjhacd+znEwXTh02HQ/pVmj9w9mpspywmpejsrssfkZGBvPmzcPb25vo6GjzFiOHDx8mIiKCBQsWMHDgQPz9/W1cU+vFxzUC4IabLLdQOvUwHf/zVy+ryss8YwqUHboVYqk7r1V7U14wOd6D4iIN7h4Kzi7QpFkpF7Nc+OtPD9qFFZe7JznetMV389bqOwjru07dTZ/PsYONLJ4/ccgU/LrebF0LtKy8Al0o8IdV5R054MXLk4JQjJWX6+5hOlnN8rUOQfXaERrHDcJ21xLeuHEjOp2OCRMmlNvjKTw8nMjISEpKShyuNXw2ydRJ5h9oudOkxeWRETmZLhQVWP+RGAyW/8PT603HjUYNWWeutGyHPWJqcX+wsHW5jsA/9nnz2Xum1MXd/8y0+v0bilZBps/nXKrlvxIy0kzH/VrocfesPrFfVp5O39zq8rLOuvLT1034uZKUVYvWOtrfYPoLJ+VU1RtdOoK63t7InthdEN63bx8AQ4cOrXCu7Jij5YZzs01/cPj46i2e925y5Yt76UL1f5yUBfOk45ZHVKSedDf/7/zcK82icc+c4d6I8+RkujDtjk48MeAGHrvlBp4d3RG3y/npfndYl9dsSBo3NX1ulQ3/yrt45Wfc2M/yZ2ypPL3Ru1bKA3jsuTO4uilcOO9M3E+Wy3UkkhO2EUVRSEhIQKvVmjfRu1pQUBBarZaEhAQUxXF6gHXFph+zq7vlOru6X/kbs6S4+o/k5qGmXV5j/tsCva78l9RohK3/vZKq0Zde+Y9TqzXlg/38dRgNGlIT3DmbZArYXk30eHpZOTyjgSn7fHSVfDZXH6/sM7ZUnqJYblmrLW/UE+cZeN9FAD5YHEBpiV19rWtEhqjZSG5uLjqdjiZNmuDqWvE/UGdnZ3x9fSkqKqKgwHF6gLVOVf8XcnWeT6Op/r+m+yMz8PHVczbJnfef/ITTRz3Ql0JaghsLIoM5k+iG2+UvurPzlfKWzmjH8tntcHFReGlDAp8lxLHpyP+YsiCFCxkuLPpXMNvWWv4TuSEzVpL2KaO5+ltkRTCozfKGR2QS+Z8zAOza6mvu1HN0Daljzq6CcFGRKafl4VH5xAV3d1PLzZGCsLvn5ZZUieX/UEp16lo+fv56/vPBabyb6PnrYArThnVmeFAPJg3owh/7vJm9MhG3y500nt6m/39ojze7tjTFzcPAK5sS6DX4Em4eCo39DNwzIYu5qxIBU744J9Pu+mttqrjQ9Pm4uFnuFXNxVfeXTFl5Gk3pNZU3dsY5pr6SDkDsLh+Wzgys9r0dRUPKCdvVt02rVbOnlPV/f5w4v6Im1ak1bt6ryM+9yJHTL6Br2aHC+ZyzucC7AKTqPiDjjEv1hbaGJz8p5MCnh0g9amoJterUkt73/x9uTb3Iv/Q6oHDG+B4Xz7jzxZbvgD/odnt3zjs/x/kzf6tjZ2jd6QPST2Swdctsbh7xf9f20LVk8a+2rgG4ej0FZPDkupFcKrmxwnkXp0xgOgAzP5+FolTdMVZWnrM2n8W/zq5BeUYCm6yhWaM/ALhY1Au3ztN55We7+jpfE0VlYJW1I2qJp6dpaE5JSeVTL4uLi8tda41OLabi6my7Xv/gsA5kpzXGs/ANwltlVTh/JMULCMXPX8dNwWOtL7gVePl+Qnirh8odPnXYA6OhM01b6ujT6VEAtuR0ABoTHv4N4a3WWSwuJCyI9BN+uOa/T3irs9bXow7d1aanravA/A+L6D0UvnljI1+t317hfNfe+bwRA9nnnJnd6y2ry3N1zmTO/y1RVZ6Lq5G5K5Npdnkix3eb/Fg2S4fR+EaNnq2u+Ab4MHvbZFtXwyHYVTrCy8sLT09PcnJy0Osr9grr9XpycnJwc3PDx8fHBjWsmY7/Zxo8f+JQZeNMTcfDuls3yP5obCNiVrUwjyf9u193NQagW9988zGPy7P0LmRU3so+f3lolKe3dNBd7eT/TOmxsvHcf9f58vETcZY/38rK83Q9pao8rVZh9jvJ3HI5AG9+pwVL/90Wo9FxW4GVaUjpCLsKwhqNhpCQEAwGA0lJSRXOJyYmYjQay40fdgS33HkRgF+2NyEvp/xIeoMBdn1imk48aKR1q5jFxzVizctt+Hx1iwrnCvO0fLPB1Ll296NXWv/hffMA2Pelr8WxyCkn3Tl1xBTUu/XJr3C+ISsbm9tvWC7eTco3DrRahdsfMn1uu61cd6OsvCbuB1WVN27mOfrfbQrAHywO4P1FrVQ9hyORIGxD/fv3B2DXrl0VzpUdGzBgwHWt07Vqf0MRvYbkUpjnxIJJwVy6YArEumINy/7djtRTHrTpUEy/y8G6TO4FJ1IT3DibVH6kSN9huTi7Gtn3pS9/bD9mPn7hvDPzJ3Yg57wLvQbn0uWqGVdDH7pAswAd2edceeXxYLLOXmkRJx7zYMGk9uh1WnoOzLW6Rd5QJB73IHaXD418jDz/XhLel8d7u7gZmfF6Ku1CS0hNcOPnbxuXu8/HV09gh2IC2pVYLM9JW2R1eYEhxYyOygDg22g/Pl7uODNGa0LBNPbX6pcD54Q1SiU9XHv27KmVN1AbMNPS0rjrrrtwcXHhww8/pGvXrgAcOXKECRMmoNfr2b17N02bVj8Up6SkhKNHj9o8JwyQdcaFf98fyvk0N9w8DAR2LOZcihv5F51p5KPnjS9O0rZj+anEH70RQPSbAbRoU8K62D/Lnfvi/easesHUG+4fWEIjHwMpp9zR67SEhBew+JNT5pERZU4f9eCFsSFczHLByVmhbcciigqcyEh1RVE0dOhayCubTtHYz37SEfaQEwbTAjpvfHaKloGlFBdqSTnlRkBbHd6+BvJztTw1PJTUBPdy94x7+izjZ2ZwLtWFf/bpUqG89w+cx805y6rypi9O5e7xphmPpw57VDlqYvvHfjYfqlaWE+7atStubtbP4Cv7zs6/9CU5RutHQPlqG/Efn3tVv589qLRj7oknnkBzjfOxNRoNx44dq/7Cq7Rp04bZs2czf/58Ro8eTe/evQGIjY1Fr9ezZMkSqwKwvWnWqpS3vz1B9FsBHNjemKTjHjTyMTBgxAXGzTxL62B168AOn5hJswAdG1cM5NzJJLIzXGjdvoSBIy4wIvI8bh4Vf7d26FrEil3HiVnlz4EdjUn7yx0nJ4UO3QoZeF8Od/8z0+J9wjRtOOrOMMY+dY6+w3Jp37mYgktO/PBZE9a/EcCZRHVf/KyzrsRnLuT0189aVV6XXlcCUsfwqtcujttn3Rok9ky5PFlDzfWOqtKW8ODBg2vlDXbv3l2j+3744QfWrFnDsWPHcHV1JSwsjMmTJ9O3b1+ry7CnlnBdOXym4uiI+sReWsJ1YfGvs5lzc8XREfXBtbaEX7z4FReM1qfF/LSevNjknvrVEq5p8KwtgwYNYtCgQTatgxDCNtR2tjlyx5xdjRMWQgjA3OGm5npHVeMgfOHCBQ4cOEBiYiL5+fnMnj2bkpIS4uLi6NOnT23WUQjRwEhLuAqlpaW8/vrrbNq0idLSK3PfZ8+eTUpKChEREXTu3Jl3333XoRZeF0LYEUVlZ5sDd8ypGidsNBqZOnUq69evR6/XExYWRuPGV8YyFhQUoNVqOXbsGI888gg5OdZt9yKEEFeTVdQqsXXrVvbu3UtwcDBffPEFn3/+ebl1f2+88Ua+++47OnbsyNmzZ1m7dm2tV1gIUf+pmqjRkBZ137p1KxqNhrfffpuQkBCL1wQGBrJ8+XK0Wq3NR1gIIRxT2R5zVr8cuCWsKid86tQpgoOD6dCh4nKMVwsKCiIoKIjU1NRrqpwQomFSVOaEHXmyhqogbDAYrF7z18XFBaf6sO2rEOK6MwXhhjFjTlU6IjAwkMTERC5cqHq1r6ysLBISEggMrD8r/QshriO1+eCGkhMeNmwYer2e//znP+WGp11Np9Px3HPPYTAYLO6YLIQQ4gpV6YiIiAi++OILvv/+e0aMGMGQIUPIzDStybBz505Onz7NZ599RnJyMgEBAUyYMKEu6iyEqOdkskYlGjVqxAcffEBUVBTHjx/nr7/+Mp+bPt20J5aiKLRr146VK1c61O4XQgj7cb065vbv38+qVauIj4+ntLSULl26EBkZyW233WZ1GQUFBaxdu5Zvv/2WtLQ0PDw86NGjB1OnTqVbt27V3q96xlzr1q3ZunUrO3fu5PvvvychIYGCggI8PDxo164dAwcO5O6777a4Zb0QQljjeqwdERMTw9y5c3F1daVPnz4YjUZiY2OJjIxk/vz5PPzww9WWcfHiRR599FHi4+Px9/dnwIABpKSk8MMPP/Dzzz+zceNGwsPDqyyjRmtHaLVahg0bxrBhw2pyuxBCVKmug3BGRgbz5s3D29ub6Oho85Zphw8fJiIiggULFjBw4MBql15YtGgR8fHx3H333SxevNjc+Fy7di2vvvoqzz//PF988UWVZVzT9kYXLlzg0KFD7N+/nyNHjlBQYP1K+EIIURmlBi81Nm7ciE6nY8KECeX2rAwPDycyMpKSkhI2b95cZRlnzpxh27ZtBAYGlgvAAI899hhdunShqKio2tFkNWoJf/PNN6xdu7bCrhlarZZevXoxdepUevXqVZOihRDCvMecmuvV2LdvH4DFEVxDhw5l6dKl7N2719zXZcmOHTtQFIWxY8daTL/GxMRYVRfVQfj5559n69atlG3I4e3tjaenJwUFBeTn53PgwAF+/fVXZs2aJaMjhBA1o7Z5q6oTTyEhIQGtVltu7ZsyQUFBaLVaEhISUBSl0m3eyhqh3bp1o6CggG+++YajR4/i7OxM3759GTJkiFVbxKkKwl9++SWffvoprq6uTJ48mZEjR5bLmaSlpREdHc2HH37IkiVL6NSpk6wtLIRQT+2iPCquzc3NRafT4efnZ7EF6+zsjK+vL9nZ2RQUFODlZXnPvpSUFMDUOXfvvfeSnp5uPvfRRx/Rt29f3nnnnUrvL6MqJ7xp0yY0Gg1vvPEGkydPrpC0btOmDbNmzeLFF19EURRWr16tpnghhACuDFFT8wI4d+4caWlp5V6XLl0qV3ZRkWmjVA8Pj0rf393dtNN1Vf1ceXl5AMydO5cmTZrw8ccf8/vvvxMdHU1YWBi//PIL8+bNq/ZZVQXhEydOEBgYyO23317ldQ8++CABAQH873//U1O8EEIANV/KcsyYMQwZMqTc68MPPyxXtrXr35jqUXmeQ6fTAaZ1ctatW0f37t3x8vKiZ8+erF27lkaNGvH111+TmJhY5XuoSkc4Ozvj6elp1bW+vr4VfgMJIYRVFNStB3E5VkZHR1dYOOzvk8bKYlhJSUmlxRUXF5e71pKy1vI999xT4T2aN2/O4MGD+fLLL/n1119p3759peWoCsI333wzP/zwA4mJiVUWmpGRwalTpyQfLISokZrOmGvZsmW1W957eXnh6elJTk4Oer0eZ+fyYVCv15OTk4Obm1uVs379/PwA0wQ2S8qOV7fDkKp0xMyZM/H09GTy5MkkJCRYvCYjI4OpU6fi7OzMzJkz1RQvhBAmdThQWKPREBISgsFgICkpqcL5xMREjEZjufHDlpSdP3/+vMXzZevqNG3atMpyKm0JP/nkkxaPt2zZklOnTjF8+HB69uxJp06d8PT0pKioiKSkJGJjY9HpdPTv358dO3bQqVOnKisghBB/V9fjhPv378/hw4fZtWtXhV2Cdu3aBcCAAQOqLOO2225j/fr17Nq1ixkzZpRrUet0OmJjYwHo2bNnleVUGoS3b99e5Y1Go5HffvuN3377zeL5vXv3sm/fvioHOwshhEV1OE4YYOTIkaxZs4bVq1dz66230rVrVwCOHDnCmjVrcHd3Z8yYMebrU1JSKC0tpUWLFnh7ewPQr18/OnXqxIkTJ1i4cCHPPfccTk5OGI1GXn31VdLS0rjlllssjkW+WqVBOCoqSt1TCSFELanrtSPatGnD7NmzmT9/PqNHj6Z3794AxMbGotfrWbJkSbk0woQJE0hPT2fRokWMHDkSACcnJ958803++c9/snHjRn788Uc6d+7MyZMnSUlJISAggPnz51dbFwnCQogGaezYsbRq1Yo1a9Zw6NAhXF1d6dGjB5MnT6Zv375WldGhQwc+//xzVq1axe7du9mzZw/Nmzdn7NixTJ48mebNm1dbRo3WjhBCiDpVx+mIMoMGDWLQoEHVXlfVzvHNmjXj+eef5/nnn69RHWoUhA0GAxkZGRQVFVUYzKzX69HpdJw/f57du3ezcOHCGlVMCNGQaS6/1FzvmFQH4dWrV7N69WrzlL3qSBAWQqh2nVrC9kBVEN6xYwdvvPGGVde2bduWO+64o0aVEkI0cA0oCKuarPHJJ58AcO+997Jnzx4OHDiAk5MTDz30EEeOHGHnzp088cQT5mEakyZNqpNKCyHqubJt7NW8HJSqIHzs2DE8PDx48cUX8ff3p0mTJoSEhPDzzz/j4uJCYGAgM2bM4MknnyQ9Pb3CwhlCCGGNmq6i5ohUBeFLly4RGBhIo0aNzMc6duzImTNnyM3NNR979NFHcXd35/vvv6+9mgohGpa62tvIzqgKwp6enhVWig8MDATg9OnT5mPu7u4EBQWRnJxcC1UUQjQ4ko6wLDAwkNTUVAoLC83H2rVrh6IoHD9+vNy1xcXF6PX62qmlEKJB0SjqX45KVRC+9dZbKSws5IUXXiA/Px8w7a8EsHXrVvMix4cPHyYpKanSJd6EEKJKdb3dsh1RFYQfffRRfH19+eabb+jfvz86nY4OHTrQu3dvjh8/zsiRI5k+fToRERGAKWgLIYRqko6wrGnTprz//vt07twZV1dX8yZ5zz33HD4+PiQkJLBjxw4KCgpo1aoVU6ZMqZNKCyHquQbUElY9Y65z587ExMRw9uxZ87HQ0FC+/vprtm7dSnp6OkFBQTz44IPmJd+EEEKVBjRZo8YL+AQEBJT7d7NmzXjiiSeuuUJCCCFBWAghbEptntdxc8KVBuFRo0Zdc+EajYYtW7ZcczlCiIZF7bAzRx6iVmkQPnr06DUX/veJHUIIIcqrNAgvWrToetZDCCGukJww3H///dezHkII0SA1iI65iD5dyTmbW/2FDmjxb3BX6x62rkad2X4mztZVqDNx6bA9vX4+X4m+Occyan6/5ISFEMKWFNSNjpAgLIQQtUhywkIIYUMShIUQwnYkJyyEELbmwIFVDQnCQgj7I+mI6hkMBv7880/++usv8vPzGTduHKWlpZw9e5a2bdvWZh2FEA2MpCOqsX79et577z2ys7PNx8aNG0dqair33HMPQ4cOZeHChXh5edVaRYUQDYjahdodeFF31UH4ueeeIyYmBkVRaNy4MTqdjuLiYgCysrIwGo3s3LmT1NRUoqOj8fDwqPVKCyHquQaUjlC1s8b27dvZunUrzZs3Z/Xq1cTGxtK5c2fz+ZtvvpkNGzbQvHlzTpw4wYcffljrFRZC1H+y0WclNm3ahEajYdmyZfTv39/iNb169WLFihUoisK3335bK5UUQjQwsr2RZceOHSMwMJDu3btXeV23bt1o164dycnJ11Q5IUQDpbZ168BBWFVLuKSkBE9PT6uulU45IcQ1aQCtYFAZhAMCAkhMTKSwsLDK6/Lz80lISKBly5bXVDkhhKjvVAXhQYMGUVJSwuLFi6u8buHCheh0OgYMGHBNlRNCNFCSE7YsMjKSbdu2sWXLFlJSUrjzzjvJzTWt03vs2DFOnz7NJ598wsGDB/Hx8WHixIl1UmkhRP0mkzUq4efnx+rVq5k6dSoHDhwgNjbWfO6BBx4AQFEUfH19Wb58Of7+/rVbWyGEqGdUT9bo0qULX331FZs3b2b37t0kJCRQUFCAh4cH7dq1Y+DAgYwZMwY/P7+6qK8QoiFoQJM1ajRt2cvLi8cee4zHHnustusjhBCSjhBCCJuSlrBln3/+ueo3GDFihOp7hBAN3HUKwvv372fVqlXEx8dTWlpKly5diIyM5LbbbqtZgcDjjz/Ovn37WL9+Pb179672elVBeM6cOWg01q1WpCgKGo1GgrAQQrXrkY6IiYlh7ty5uLq60qdPH4xGI7GxsURGRjJ//nwefvhh1WVGR0ezb98+VfeoCsI33HBDpUG4uLiYrKwscnNz0Wg03HPPPdI5J4SouTpMMWRkZDBv3jy8vb2Jjo4mNDQUgMOHDxMREcGCBQsYOHCgqhFeycnJvPbaa6rroioIx8TEVHvNwYMHmTNnDkePHuXTTz9VXSEhhKjrlvDGjRvR6XQ88cQT5gAMEB4eTmRkJEuXLmXz5s1Mnz7dqvIMBgOzZ8/GxcWF0NBQTp48aXVdVM2Ys8ZNN93EsmXLSEpKYsWKFbVdvBCiIajjGXNlKYOhQ4dWOFd2bO/evVaXt2bNGuLi4njhhRdo2rSpqrrUehAG01ji4OBgduzYURfFCyHquzoMwoqikJCQgFarJTg4uML5oKAgtFotCQkJKEr1BZ84cYLly5czbNgw7r33XusrclmdBGEAJycnMjMz66p4IUQ9VpeLuufm5qLT6WjSpAmurq4Vzjs7O+Pr60tRUREFBQVVlqXT6XjmmWfw8fHhxRdfVPmUl9+vRndV49ChQyQkJBAQEFAXxQsh6rsaDlE7d+4cTk5O5U75+Pjg4+Nj/ndRURFAlVuvubu7A1BQUFDlsrzLli3j5MmTrFixosYDEVQF4Y0bN1Z5XqfTkZiYyJdffgnAkCFDalQpIUQDV8MgPGbMGLKyssqdioqKYtq0aeZ/a7XWJwCqSkf8/vvvvP/++wwfPtxibtlaqoLwyy+/bNU4YUVRaNu2LVOmTKlxxYQQDVdNR0dER0dbbAlfrWxjipKSkkrLK9u8uLJNLAoLC5kzZw7NmzfnhRdesL6iFqgKwr169aq6MGdnfHx86N69O6NGjZLdNYQQNVeDccItW7bEzc2tymu8vLzw9PQkJycHvV6Ps3P5MKjX68nJycHNza1CAC+zadMmUlJSCAsLY/78+eXOJSQkALBq1Sq2bNnC6NGjuemmmyqtj6ogvGHDBjWXCyGE3dFoNISEhHD48GGSkpIICQkpdz4xMRGj0Vhu/PDfle0uFB8fT3x8vMVr9u/fD0C/fv2qDMKqRkdMnDiROXPmcOnSJTW3CSGEKnW95X3ZbvG7du2qcK7sWFU7A02bNs0cgP/+6tu3LwDr168nPj6ekSNHVlkXVUH4f//7H7/88kulTXQhhKgVdTxZY+TIkbi5ubF69WqOHj1qPn7kyBHWrFmDu7s7Y8aMMR9PSUnh9OnT5OXlXctTWaR6nHDjxo1rvRJCCFFOHQfhNm3aMHv2bPLz8xk9erR5ffRHHnmEgoIC5s+fX27m24QJE7jrrrvYuXNnLTxceaqC8PDhwzl16hTff/99rVdECCGuplHxqomxY8eyatUq/u///o9Dhw5x9OhRevTowQcffMB9991XC09gHVUdc8OHD+f48eNERUVx4403cuONN9KiRQuLs07KjB079porKYRoYK7TesKDBg1i0KBB1V63e/duq8tct26dqjqoCsKPPPIIGo0GRVGIi4vjjz/+qPYeCcJCCLVke6NKVDdOWAghaoVsbwRnzpzBzc2tXHJaxgkLIa6LBhSEK+2YGzx4ME8++eT1rIsQQgCXO9zUjBO2dYWvQZXpCGvW0hRCiFrXgFrCsuW9EMLuSMecEELYkrSExbXwaqxn3NMZ9LszF78WenKznTj4ow8b3/TnfHrlY6prUp61hkdkMXVBOv95tD2xu6yfdv5QVAaPPXuOHZt9eWNGW9V1r0/yLjrx0Zst2f9tYy6cd6ZxUz03Dcxj7NPn8G9Tqrq8cwmZLHqlHf/b70VhnhP+bUu49a5c7o/MxMfXYPGe3GwnPn7Hn1++a0zWORea+pfSrU8+D0edJzCk8qUZHY20hC/Lzs7m888/v6Y3GDFixDXd72i8GutZ+kUCbTuWUJCnJfG4OwFtddzxyAVuuTOXZx7oQOLxylf0V1teWklytWWEdCskYu5Z1c/SpkMx42ZkqL6vPsq76MSM4R1JTXDH08tA+87FnE1xZfvHTfn528a8tjWB4BuKrS5v/7eNeWfyOvQ6X9w8DLQNLSbzjAvRb7Vk1xY/Fm46XSGopp12Y87DHcg844pWqxDUqZiiQi07P2nKni98mbsimX535tb2o9uGtIRNkpOTmTt3bo0L12g0DS4IP/VaGm07lhC7y5tFk9tRVOCEi5uR6YvT+MfDOcx9N5l/DQ7DaLSuP7e68oJKl6PVNq20vLAbC5m/PhFPL6Oq59BoFJ5+MxU3Dwf+r7sWvfVMIKkJ7tw8JJe57ybj6WVEV6zh7Tlt2PlJUxZNDmLV7hP8bT1xi86luLJkWlv0OgP97rjIzKWpeDU2YDDAR2+0JPqtljw/LpjVP57A1d308zcY4OXIIDLPuBIYUsy89xPNQXr/dz4snhLEK08E8e6uE7QLrQct4gYUhKtcO8LV1ZWAgIAav1q2bHm9nsMuBIYUc8tduRTma3lteluKCkzfyNISLUtnBpJ80o12oSVWt1asKc/DJd1ieVqtwvCJmbwek0CTZnrVz3LfxCy69CqkuMiRB//UjpRTbvz8TWM8Ghl45u0U8y80V3eFGW+k0rZjMSmn3Nn/rXWLW239b3OKC51o0b4Zz65KxquxKfXg5AT/nHWO8H55nEtx4/O1zc337P+uMUknPHBxMzJ//V/lWsn97rjEQ1MzMOg1rJ7fuhaf3HbqeilLe1JlS7hr167V7it3PcTExDB37lw2btxY5eLItjZ4ZA5aLcTu9CHvYvkfrdGoYcdmPyJfOMuA4Rf56esmdVaei5uRZV+dokOXYoxG+OhNf4Y+eIGWgdblLVu2LWHCnHOcTXbl4A/e3Dsh26r76qvdMb4oiobet1+qkKt1coJ/PJzNmldas+cLX/rfU/0v2EN7vAHo91APXFwrrmc7fEIWh/d7s/szXx6aer7cPX3/kUurIF2Fe+6dkMWGNwL4/UdvcrOdaNzUck5Z2J862/K+tsTFxfHyyy/buhpW6dTDtNr+sYONLJ4/8btpv6quvaveRvtay3N1U+jQpZjkeDeeeaADG15X9xfJU6+l4dHIyLJZbSgptvv/ROrciUOmn/8NN1n+3Dr1NH1OR2Mtf05/d/6MqXO2VSfLn0ur9qZWbvIJd4oLTX+JlHXohnQrsnhP46YGvBrrMRo1nDpieV80h1NHy1jaG7v+hm3fvp3HHnvMvJWIvStroZxLsTwCIuPyF8mvhR53z+pbKjUtr1Sn4dVpgfxraBhHY9Xt83fn2Gy6989n+8e+xO3zVnVvfXUmyfRzbtm2YgsUwL+16XhOpgtFBdZ/pYwGy3l6g94UeI1GDVlny3/2BkPl6aGy+86nqR+BY280iqL65ajsMgifO3eOWbNmMX36dIxGI82aNbN1lazSuKkp93opx3LvTN5Vxxv7VR+Ea1qerljL91v9MFbxhbWkWYCOyBfOcOG8M++91ErVvfVZbrYpFeTjazm37n1ViiL3QvWjPlsGXv7lmpBp8XzySXfz/87PNX3GZb8Ako67W7znfJqLuc8g76IVvYP2ro4XdbcndhmE33rrLbZt20bXrl3ZvHkzwcHBtq6SVVzdTS0bXSV/wl99vOza61ledaYvSaORj5EVz7UmP1eGkJcp+zlX9jO++riuuPpffL2HmvLG+z6KRVdS/nqjEbauamH+d2mpptw9P3/bmJRTFXcT/mTFlXv0pY7fmdqQOuYqDcJRUVHVblBXV4KDg1myZAlbtmwhLCzMJnWoiepanhqVv/Jqu7yqDHngAr2H5vHztz5WdRo2JFqnqr/hisrff/dPysTHV0922kWeHxdMwhEP9KWQmuDGy48HkZ7ohtvlwO7sbHrvXoPz6NIrH32plufHdiB2lw+6Yg05mc58+GpLvlrfDO/LLfWyexxaA2oJV9rciYqKup71KGfSpEk2e+9rUVyoxcXVgIub5W+li+uV4yVF1UfQ2i6vMk2alfKvl86Qn6vlnWfb1Lic+srd00h+rpbSEss/41LdleNuHtVH5Kb+el5c9xfPPxrO/36GqcOuNDQ8GhmYuzKJpTPbUlKsxdPblOrQaOD51Uk8N6YDfx3z4D+PXvnrUKNRGD09g9QEd376uon5HoemtnVbH4OwUC8vxwnvJga8m1j+EviozB3WdnmViVqYjo+fgbeeacOFDJcal1NfefsayM91rjTXeqlcbt66MdldehXy9JZJJG+fy4k406iKkG6F3DU2G98WevIvmcr0a3GlPL8Wet7+5iQ7P/Hj4A/eFOY70Tq4hNsfukCn7oXMvD/EdJ2/+nHhdqcBTdZoEEF49heTr8v7NGr6KhDHv1YMIqvg9ornXY8D8yk1NOGlvc9e1/J8/acBWfxz6SjuL+5R7lz31o8ApqFpT72WZvH+fzycwz8ezqFE34xjGcurrXttiUu/bm9VqcZttnA26TQHj0zGOaxHhfN/xaUA0Xg38+J4zibIsa5cL1/oMnoZXUZfOZYOxO49h9GwDp/mXiQUbIS/jYwLGAT3XrUtWhHwe6pCwp9vASUUNllEXLqfuoe0M7J2RD2zZPi75Jyt+zn142aeY/xMOLHjM15/6vcK5x+ccp7Q5+HXHUbmP7b4upb3YWwuLQPhwxmfErtrR7lzb3xe+bhS/zalNG9VSk6mM+mJrlzIKGXBE9XXvbZsP/PHdXuvyhy9uSUnfmpJ/l8f0731qxXOn/q8BdCKbjel0b316IoF/M2R2EbEx3ni0n4u9w17usL5Pz/2BwLoeWuKubz0RFcO7vahSXM9A4ZfrHDP4V8aUZzfkWYBOm7vO0XtI9a6En3za/9l7cCBVY0GEYSvl5+/acz4mRn0uyMX7yb6crPctFqF2x+6AMDurb42Ka8yM0d0rPRc5H/OMOpfmfy227vBrqJ2y10XTaunfdeYSzlO5dJABgPs/MTU6hz8gHVN4BOHPFnzcmvCb/+N+4aVP1eQp+XrDaYhmfc8emWmYsElJ1a+0IZmATpuvesiTn/75m5ZaRodcff4+jG7sSG1hO1yiJqjSjzuQexObxr5GHn+vWRzb7WLm5EZb6TSLrSE1AQ3fv7bGgM+fnoCQ4oJaFeiurzi0lYVyhO1K/iGYm4emkthnhOvTAri0gVTvlZXrGHpzEBSTrnTpkMxt/xtDY/cbCdSTrmZJ3uU6XdHLi6uRo7sOs4PnzUxH79w3pmXJrbnwnkXbh6SW24mZMfwIlq1LyHrrCv/fbE1+ssz0HXFGv77Uit+/b4xfi1Kue8xy2OPHY4CKIqKl60rXHPSEq5lb89pwxudErjx1nw++u04KafcCGiru9y5o+WliUEoSvmhZ8Mjshg/M4NzqS78s/cNqspLKX4aRZENWOva9MVpzBzhwf9+9mZcrxto27GEsymu5F90ppGPgXnvJ6L9W5Pmiw+a89GbLfFvo2P9r8fMx1u3N02KWflCGxZPDeKDxSV4+RhIOeVOqU5Lx/BC5qwsv0SpRgNzViQx8/6ObHu/OT9+7kuLNjrOJLlRcMkJb189CzedppH3tY8XtwfSEhY1lnXWlag7QvlsTTMuZjvRvnMxBoOGHz5rwrS7QklNsDzjqabllejrx6pZ9q55q1Le+S6eEY9l0qSpgcTj7jg5KQwckcPyb+Jp21Hd8pH3PZbFuFfvp1uffC5dcCbllDut2pcwYc4Z3vjslMVgGnZjEcu+Osmtd18E4K9jHjTyNnD3o1m8uzOe9p2tX8/Y7jWgccIaxQF28xw/fjy//vqr6lXUSkpKOHr06HXrmLOFxb/NYU6v69dRdr3ZQ8dcXYlL/9iqjjxHVNYx17VrV9zcKs7wq/S+y9/ZeasOcOGS9b9U/HzceelffVS/nz2QdIQQwv7IOGH7smGD5DyFaEg0qMwJ11lN6p7khIUQwoYcoiUshGhgyoaeqbneQUkQFkLYnYY0RE2CsBDC/kjHnBBC2I60hIUQwpYkJyyEEDYki7oLIYQNSU5YCCFspyFN1pAgLISwP0bF9FJzvYOSICyEsD+SjhBCCNu5XkPU9u/fz6pVq4iPj6e0tJQuXboQGRnJbbfdZnUZe/bsYf369Rw5coTCwkKaN29O//79mTJlCi1btqz2flk7Qghhf1TtqqFyONtlMTExREREEBcXR3h4ON27dycuLo7IyEg2b95sVRnvvfcekyZNYv/+/bRv394cvDdv3sz999/P6dOnqy1DWsJCCLtT1y3hjIwM5s2bh7e3N9HR0YSGhgJw+PBhIiIiWLBgAQMHDsTf37/SMhISEli6dCmenp68//77dO/eHYDS0lIWLlxIdHQ0zz77bLUBXVrCQgj7U8c7a2zcuBGdTseECRPMARggPDycyMhISkpKqg2e27Ztw2g0EhERYQ7AAC4uLjz77LP4+fnxxx9/kJ6eXmU5EoSFEHZHg4JGUfFSGYX37dsHwNChQyucKzu2d+/eKstwcXEhLCyMXr16WTzXpk0bAM6fP19lOZKOEELYH+Pll5rrraQoCgkJCWi1WoKDgyucDwoKQqvVkpCQgKIoaDSWRyFPnz6d6dOnWzxXWFhIQkICQLWdc9ISFkI0KLm5ueh0Opo0aYKrq2uF887Ozvj6+lJUVERBQUGN3mP16tUUFhbSrVs3AgICqrxWWsJCCLtTlmZQcz3AuXPncHJyKnfOx8cHHx8f87+LiooA8PDwqLQ8d3fTrugFBQV4eXlZXQ8wDVn773//i1ar5Zlnnqn2egnCQgj7U8PJGmPGjCErK6vcqaioKKZNm2b+t1ZrfQJA7Wb0P/74I9OnT8dgMDBz5kx69+5d7T0ShIUQ9qeGS1lGR0dbbAlfzdPTE4CSkpJKiysuLi53rTU+/fRT5s2bh16vJyoqikmTJll1nwRhIYTdqek44ZYtW+Lm5lbltV5eXnh6epKTk4Ner8fZuXwY1Ov15OTk4ObmViGAV2bp0qWsWrUKjUbD3LlzmTBhgtV1l445IYT9UVA5Y876ojUaDSEhIRgMBpKSkiqcT0xMxGg0lhs/XGk1FYXnnnuOVatW4erqyptvvqkqAIMEYSGEHdIooDGqeKmcrNG/f38Adu3aVeFc2bEBAwZUW87ixYv59NNP8fLyYu3atdx1113qKoIEYSGEParjtSNGjhyJm5sbq1ev5ujRo+bjR44cYc2aNbi7uzNmzBjz8ZSUFE6fPk1eXp752N69e1m3bh3Ozs7897//5eabb67Ro0pOWAhhf+p4Kcs2bdowe/Zs5s+fz+jRo82jGGJjY9Hr9SxZsoSmTZuar58wYQLp6eksWrSIkSNHAvD2228D0LRpUz7++GM+/vhji+81efJkOnToUGldJAgLIeyPynHCNVlFbezYsbRq1Yo1a9Zw6NAhXF1d6dGjB5MnT6Zv375V3nvx4kWOHDkCmBYD+vLLLyu99sEHH5QgLIRwMNdpt+VBgwYxaNCgaq/bvXt3uX83adKE+Pj4Gr3n30kQFkLYnzpcO8LeSBAWQtidslXU1FzvqCQICyHsz3VKR9gDCcJCCPsjQVgIIWxIcsJCCGE7NV3K0hHJjDkhhLAhaQkLIexP2QI+aq53UBKEhRD2RzrmhBDCltQuyiNBWAghao+MjhBCCNtpSKMjJAgLIeyP5ISFEMKGjIrppeZ6ByVBWAhhf6QlLIQQtiSjI4QQwnZkskb9oFz+EH1aeNu4JnXLN6CxratQZ0r0zW1dhTpVX59PZ/ADrnwHVZOccP1QWloKwOQ142xck7o1+4vJtq5CnTmWYesa1K1jGcttXYU6VVpairu7u/obFaPppeZ6B1Wvg3CjRo0IDQ3FxcUFjUZj6+oI0WAoikJpaSmNGjWqaQHSMVcfaLVavL3rdypCCHtVoxZwGUlHCCGELcnoCCGEsB1JRwghhA01oCFqsrOGEELYkLSEhRD2x2g0vdRc76AkCAsh7I/khIUQwoYaUBCWnLCD2r9/P48++ii9e/emR48ejB8/nr1799q6WkKlmJgYwsLCOHjwoK2rYl8U5cpYYWteEoTF9RQTE0NERARxcXGEh4fTvXt34uLiiIyMZPPmzbaunrBSXFwcL7/8sq2rYZcUxaj65agkHeFgMjIymDdvHt7e3kRHRxMaGgrA4cOHiYiIYMGCBQwcOBB/f38b11RUZfv27cydO5fCwkJbV8U+GVE5Y67OalLnpCXsYDZu3IhOp2PChAnmAAwQHh5OZGQkJSUl0hq2Y+fOnWPWrFlMnz4do9FIs2bNbF0l+1SWE1bzclAShB3Mvn37ABg6dGiFc2XHJDdsv9566y22bdtG165d2bx5M8HBwbaukn0qG6Km5uWgJB3hQBRFISEhAa1Wa/HLGxQUhFarJSEhAUVRZOU4OxQcHMySJUsYPnw4Wq20gSrVgEZHSBB2ILm5ueh0Ovz8/HB1da1w3tnZGV9fX7KzsykoKMDLy8sGtRRVmTRpkq2r4BAUxYiionXryB1z8qvYgRQVFQHg4eFR6TVlywcWFBRclzoJUScaUE5YWsIORM2frzXeVkYIe9CARkdIEHYgnp6eAJSUlFR6TXFxcblrhXBIsr2RsEdeXl54enqSk5ODXq/H2bn8x6fX68nJycHNzQ0fHx8b1VKIa6cYFRQVLWE119obyQk7EI1GQ0hICAaDgaSkpArnExMTMRqN5cYPC+GYjFdaw9a8HDgfIUHYwfTv3x+AXbt2VThXdmzAgAHXtU5C1LrLLWFrX468x5wEYQczcuRI3NzcWL16NUePHjUfP3LkCGvWrMHd3Z0xY8bYsIZCCDUkJ+xg2rRpw+zZs5k/fz6jR4+md+/eAMTGxqLX61myZAlNmza1cS2FuDY+zb1UDTvzae64Y+IlCDugsWPH0qpVK9asWcOhQ4dwdXWlR48eTJ48mb59+9q6ekLUmJOTE05OTkxeM67G9zoajSIDSoUQdkSv12MwGFTf5+TkVGHEkCOQICyEEDYkHXNCCGFDEoSFEMKGJAgLIYQNSRAWQggbkiAshBA2JEFYCCFsSILwdZCWlkZYWJjFV6dOnQgPD+e2225j8uTJFteEsIWTJ0+a63i1OXPmEBYWxpIlS675PbKysrh06dI1l1Odjz76iLCwMMaPH2/V9TExMYSFhTFy5Mhrfu/ly5cTFhbG9OnTr7ms6gwePJiwsDB++OGHOn8vUXscb2Szg+vatWu5rYkURUGn05GWlsbu3bvZvXs3Y8aMYd68eTasZd1bt24dy5cvZ9OmTbLspmjQJAhfZ8uWLaNNmzYVjpeWlvLOO++watUqoqOj6d+/P4MHD7ZBDav29NNPExkZia+v7zWVs2jRolqqkRCOTdIRdsLFxYUZM2bQvXt3AKKjo21cI8tatGhBhw4d8PPzs3VVhKgXJAjbmUGDBgGmpSmFEPWfpCPsTNk29Vfvlrx8+XLeeecdZs2ahYeHB++++y65ubm0bduWFStW0K5dOwBSU1NZvXo1P/30E+fPn6dRo0bceOONTJgwodLV1TIzM1m9ejXff/89mZmZtG7dmkceeYSbb77Z4vVz5szhs88+Y+LEicyePbvcudTUVNavX8+ePXs4d+4c7u7udOvWjYiICG699dZyz1Lm3nvvBWD9+vXmZTkBfvvtN9atW0dcXByXLl2iadOm3HLLLTzxxBPm5/2748eP8+6773Lo0CHy8/Pp3LkzkydPrvLnrVZWVhYbNmxg3759pKamUlRUhLe3NzfccAMPPfQQw4YNq/Tev/76izfffNO87GinTp145JFHGD58uMXr8/PzWbduHdu3byclJQUnJydCQ0MZOXIkDzzwgEOuGCYqkiBsZ1JSUgAICAiocG7Hjh388ccftG7dmtatW1NYWEhgYCAA+/btY/r06RQWFuLh4UHHjh25cOECP/74Iz/++CPTpk0jKiqqXHmJiYlERERw9uxZ3N3d6dixIxkZGSxYsICbbrpJVb1//vlnnnzySfLy8vD09CQkJITMzEx++uknfvrpJxYsWMCoUaMICAigR48eHDp0CIAbbrgBd3d3vL29zWWtXLmSZcuWAeDr60toaCipqals3bqVb775hmXLllXYPWTnzp08/fTT6HQ6fH196dChAydOnCAyMpKePXuqepbKHD9+nIiICHJycvD09DTn9lNTU83POXPmTCZNmlTh3sTERB566CEKCgro2LEjhYWFHDp0iEOHDnHgwAEWLlxY7vq0tDQmTpxIcnIyzs7OBAUFYTQaiYuLIy4ujh07drBy5cpynbzCQSmizqWmpiqhoaFKaGiokpqaWul1Fy9eVPr06aOEhoYqL7/8svn422+/bb5/wYIFitFoVBRFUbKzs83l9+jRQwkNDVXeeustpaSkxHzvrl27zOd27txp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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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5cWmzwJY/2kAZnPVz+WeX30Y3TuWoeNPc8Md52kbW0ZBrisbVvrx2btBVb48HJ1yYbCGmuOdVbUt4TvuuKNBLrB58+Z6nffjjz+SmJjI/v37cXd3JzY2ljFjxtCjR486l+FILeHGkpJdtXfE1eRKtoSvtNk7n7tivRWutMttCb907hvyzLZvNNoSoPXipeb3Xl0t4foGz4bSu3dvevfubdc6CCHsQ/UEPk58Y86h+gkLIQRgveGm5nhnVe8gnJeXx44dO0hLS6OoqIgpU6ag1+tJSUnhppscY7SVEMI5SUu4BuXl5bzxxhusWLGC8vKLszJNmTKFzMxM4uPj6dixI++9955TTbwuhHAgisqbbU58Y05VP2Gz2czYsWP5+OOPMRqNxMbG0qzZxX6OxcXFaLVa9u/fz9ChQ8nPd541rYQQjkNmUavG6tWr2bp1K5GRkXz11Vd8+eWXleb9ve666/j++++Jjo7m5MmTLFmypMErLIS4+qkaqNGUFvpcvXo1Go2Gt99+m6ioKJvHhIWFsWDBArRard17WAghnFPFGnN1fjhxS1hVTvjIkSNERkbSvn3V6RgvFRERQUREBFlZWZdVOSFE06SozAk782ANVUHYZDLVec5fNzc3XJry8CshRL1ZgnDTGDGnKh0RFhZGWloaeXl5NR539uxZUlNTCQurfvluIYSoltp8cFPJCffr1w+j0ci///3vSt3TLmUwGHjhhRcwmUw2V0wWQghxkap0RHx8PF999RU//PADAwcOpE+fPpw5Y5mTYePGjRw9epQvvviCjIwMWrVqxciRIxujzkKIq9yVGqyxfft2Fi1axKFDhygvL6dTp04kJCRw22231bmM4uJilixZwnfffcfx48fx9PSkW7dujB07lmuvvbbW81UFYW9vbz788EPGjRvHgQMHOHbsmHXfhAmW9bIURaFt27YsXLjQqVa/EEI4jitxY27NmjVMnToVd3d3brrpJsxmM8nJySQkJDBjxgwefvjhWss4d+4cjz76KIcOHSI4OJjbb7+dzMxMfvzxR3755ReWL19Oly5daixD9Yi51q1bs3r1ajZu3MgPP/xAamoqxcXFeHp60rZtW3r16sU999xjc8l6IYSoi8aeOyInJ4fp06fj6+tLUlKSdbWePXv2EB8fz8yZM+nVq1eto35fffVVDh06xD333MPs2bOtcW/JkiW89tprvPjii3z11Vc1llGvuSO0Wi39+vWjX79+9TldCCFq1NhBePny5RgMBp544olKy6V16dKFhIQE5s+fz8qVK62/8G05ceIEa9euJSwsrFIABnjsscdYt24dhYWF5OXlERAQUG05l7W8UV5eHrt372b79u3s3buX4uK6z4QvhBDVUerxUGPbtm0ANjsPVGzbunVrjWVs2LABRVEYPny4zV/+a9asYePGjTUGYKhnS/jbb79lyZIlVVbN0Gq13HjjjYwdO5Ybb7yxPkULIYR1jTk1x9f5WEUhNTUVrVZbadqFChEREWi1WlJTU1EUpdoVhiri37XXXktxcTHffvst+/btw9XVlR49etCnT586rU6kOgi/+OKLrF69mooFOXx9ffHy8qK4uJiioiJ27NjBb7/9xrPPPiu9I4QQ9aO2eXvh2FOnTlUZJObn51epk0BBQQEGg4GAgACbLVhXV1f8/f3Jzc2luLgYHx+fKscAZGZmApabc/fddx/Z2dnWfZ988gk9evTgnXfeqfb8CqrSEV9//TWff/45bm5uTJw4kS1btrBz5062bNnCrl272LRpE6NGjUKj0TBnzhx27NihpnghhLCo52CNYcOG0adPn0qPjz76qFLRpaWlAHh6elZ7eZ3OsiZfTSnWwsJCAKZOnUrz5s359NNP+f3330lKSiI2NpZff/2V6dOn1/pUVbWEV6xYgUajYe7cudx5551V9rdp04Znn32Wdu3aMW3aNBYvXiwTvAshVKtvF7WkpCSbLeFL1XXqBUu51VfCYLAszuvm5sbSpUut17n++utZsmQJ/fr1Y926dYwbN4527dpVW46qlvDBgwcJCwuzGYAv9eCDD9KqVSv+/PNPNcULIQRQ/6ksQ0JCaNOmTaXHX4Owl5cXYFlUtDplZWWVjrWlorV87733VrlGYGAgd9xxB4qi8Ntvv9X4XFUFYVdX1xordSl/f/8av0WEEKJaCpYUQ50fdS/ax8cHLy8v8vPzMRqNVfYbjUby8/Px8PCoccBZRa+H1q1b29xfsb22xS1UBeHu3btz5MgR0tLSajwuJyeHI0eO0K1bNzXFCyEEcDEdoeZRVxqNhqioKEwmE+np6VX2p6WlYTabK/UftqVi/+nTp23ur5jSoUWLFjWWoyoIT548GS8vL8aMGUNqaqrNY3Jychg7diyurq5MnjxZTfFC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t27d2L17NwDXXHMNOp0OX19fa1kLFy7krbfeAsDf35+YmBiysrJYvXo13377LW+99VaV1UM2btzI008/jcFgwN/fn/bt23Pw4EESEhK4/vrrVT2X6hw4cID4+Hjy8/Px8vKy5vazsrKsz3Py5MmMHj26yrlpaWk89NBDFBcXEx0dTUlJCbt372b37t3s2LGDWbNmVTr++PHjjBo1ioyMDFxdXYmIiMBsNpOSkkJKSgobNmxg4cKFlW7yCieliEaXlZWlxMTEKDExMUpWVla1x507d0656aablJiYGOWVV16xbn/77bet58+cOVMxm82KoihKbm6utfxu3bopMTExyptvvqno9XrruZs2bbLu27hxo3W72WxWHn74YSUmJkYZNWqUkp+fryiKophMJmXJkiVKbGys9ZqXmjJlihITE6PMnj3bui03N1eJi4tTYmJilBdffFEpKiqyXuPDDz9UYmJilE6dOlV67hVlHzp0qFL569evV2JiYpRu3bop69ats243GAzKu+++a92XnZ1t3Xf27Fnrc3z99deV8vJyRVEUpaioSJk0aZL1WiNGjKj2tb/U6tWrlZiYGGXQoEGVtg8aNEiJiYlRnnrqKaWwsNC6vbCwUJk8ebISExOjXH/99YrBYLDuu/S9u/POO5XU1FTrvu+//17p3LmzEhMTo3zzzTfW7UajURk4cKASExOj/N///Z9y5swZ674jR44od999txITE6P85z//qVS/3r17KzExMcrmzZvr9DyFY5CcsJ0pisL58+fZunUrjz/+OHl5efj6+vLYY49VOdbNzY2JEyei0WgArDfHPvjgA4qKihg4cCATJ06s1Drq06cPkydPBqiUBti1axcpKSn4+fkxf/58mjdvDoBWq2XUqFH84x//qPNz+Oyzz8jPz+e6665jxowZeHt7A5aFSUeOHEmvXr0oLy/n22+/rbWst99+G4Dnn3+e/v37V3ruTz75JHfffbf1Z3qFFStWUFRURPfu3fnXv/5lnVPW29ub2bNnV5u+UOPEiRNkZ2ej0+l4+eWXrWkjsKSQ/vWvfwFQWFhITk5OlfM1Gg0LFiygffv21m39+vWzpkuWLFli3b5x40b2799Pu3btePPNN2nZsqV1X1RUFG+++SZarZYVK1aQm5t72c9N2JcE4SusT58+VQZr3HjjjSQkJLBnzx78/f1ZuHCh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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.9859343389023036\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>86.428571</td>\n",
       "      <td>47.142857</td>\n",
       "      <td>19.285714</td>\n",
       "      <td>9.714286</td>\n",
       "      <td>6.52381</td>\n",
       "      <td>4.892857</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>86.428571</td>\n",
       "      <td>47.142857</td>\n",
       "      <td>19.285714</td>\n",
       "      <td>9.714286</td>\n",
       "      <td>6.52381</td>\n",
       "      <td>4.892857</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     86.428571  47.142857  19.285714  9.714286  6.52381  4.892857\n",
       "1           NaN        NaN        NaN       NaN      NaN       NaN\n",
       "mean  86.428571  47.142857  19.285714  9.714286  6.52381  4.892857"
      ]
     },
     "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)"
   ]
  }
 ],
 "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
}
