{
 "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%|███████████████████████████████████████████| 3536/3536 [00:00<00:00, 10034.34it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_MorganFeatures/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 80% of the actives for training \n",
    "num_actives = len(active_ind)\n",
    "num_training = int(0.8 * 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": "markdown",
   "id": "87fcb8a3",
   "metadata": {},
   "source": [
    "#### Model Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f08b5f2f",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9845360824742269"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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": "iVBORw0KGgoAAAANSUhEUgAAAVsAAAE+CAYAAAAj9rMEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABBSklEQVR4nO3deVxVdf748de97KsiCigiiHDRUktMrUYntzKbtDJlciuXzFTUTEfNaiY1KRut1DR/qWX5VTP3sZpcJxdKcyE1dxQRF1AWUXa49/z+uHGTuCwHvQvwfvY4j0ee8znnvC/omw+fVaMoioIQQgiL0to6ACGEqA0k2QohhBVIshVCCCuQZCuEEFYgyVYIIazA0dYBCCHEnYqKitDr9arvc3BwwNHRflOa/UYmhKh1ioqK+O1YLHrFU/W9Dg4OtGzZ0m4Trn1GJYSolfR6PXrFk2b1/4mzQ3ql7yvQ1+N86gz0er0kWyGEqCwHbSoODjcqX14xWDCae0OSrRDC7hhQMFD5ya1qytqKJFshhN0x/P6fmvL2TpKtEMLuGBQFvYplWwzVYIkXSbZCCLtjQF3TgP3XayXZCiHskB4FrYpkq5c2WyGEUE9R2UGmSLIVQgj19IqCRkU7rJr2XVuRZCuEsDsG1LXDSputEEJUgQFFVTtsdRhnK6t+CSGEFUjNVghhd/SAmsqq+jXCrE+SrRDC7hgAjcry9k6SrRDC7hjQoCbdGlSlZtuQZCuEsDsGBVXNCAb77x+TZCuEsD96NChSsxVCCMsyqEy2asraiiRbIYTdMSgaNIqKZKuirK1IshVC2B09oFFVs7V/kmyFEHbHgBZ1c660dj9DS5KtEMLuGBQNqGkaUDSSbG3JYDCQnZ2Nk5MTGo39t+kIUVMoikJhYSEeHh5oterToF7lOFvQ2H0ys/f47kp2djZnz561dRhC1Fo6nQ4vLy/V9xkULYpS+SStUVHWVmp0snVycgLA32cKjg5pNo7GMq6kLiWw/su2DsNixnf7i61DsJjJa4bywd+/sHUYFuHdwJNXP+ln+jeolnHol4pkK0O/bKu46cDRIQ0nx+s2jsZyavJnu5l829YhWFRN/3xVbb5TO6lBkq0QQlSBQdFiUNE0oJVmBCGEUM+ARuUUXPuv2dr/jwMhhKgBpGYrhLA7erS/T2yoHDWdabYiyVYIYXcMiga9mnZYWRtBCCHUM6is2dr//DFJtkIIO6RXNOhVTte1d5JshRB2x4AWvdRshRDCsgyoG2erpsnBViTZCiHsjh6NypqtNCMIIYRqBpVttlppsxVCCPXUjkaQZgQhhKgCvaJVNc5W1kYQQogqUFSujVDV3XU3b97MypUrOXv2LAaDgaZNm9KnTx8GDRqEg4NDibIJCQksWLCAw4cPc/PmTZo0aUJUVBQDBw6s1ALpkmyFEHZHr3IGmaoxub/74IMPWLZsGc7OzrRr1w4HBwcOHTpETEwMv/zyC5988olpicjTp08zcOBAsrKyiIyMpFWrVhw4cIB3332Xo0ePMmfOnArfJ8lWCGF39CrH2aopC8bk+fnnn1OvXj1WrVpF06ZNAUhJSaF///7s2LGDbdu20aNHDxRFYfLkyWRlZfHBBx/wzDPPAJCens6QIUPYsmULjz/+OD169Cj3nfbf0CGEqHUURYNBxaGorNn+/PPPKIpC7969TYkWwN/fnwEDBgBw8OBBAGJjYzlz5gzt27c3JVqAevXq8c477wCwYsWKCt8pNVshhN2xdM22uHkgJSWl1LWMjAwA6tatC8DevXsB6N69e6mykZGR+Pr6cvjwYbKysvD09CzznVKzFULYHWONVaviUFez7dSpExqNhh9++IHPPvuM9PR0bt26xbp16/jqq6+oU6cOzz//PADx8fGAcfNKc5o2bYrBYOD8+fPlvlNqtkKIGiM5ObnUKAJvb2+8vb1LnGvWrBkzZ85k1qxZzJ07l7lz55qutWnThvfee4+GDRsCcP26cY+/Bg0amH1n8fnU1NRyY5NkK4SwOwY06FUM5yoeJjZgwIBSSS86OpqxY8eWuicyMpJHHnmE/fv307p1a7RaLUePHuX48eOsWrWKadOmodFoyM3NBcDV1dXsu4vP5+TklBujJFshhN1Ru+FjcdlVq1aZrdn+2a+//sqwYcMIDAzk22+/JTAwEDC24UZHR/PVV1/h6enJ+PHjTc+raKdgg8FQ7nVpsxVC2B397zVbNQdAQEAAjRs3LnGYS7YxMTFkZ2cza9YsU6IF42iEDz/8EEdHR5YvX05ubi5ubm4A5OXlmY21+LyHh0e5n0mSrRDC7iiqOse0KCpqwXl5eRw7dgxvb29at25d6npQUBBNmzYlJyeHxMRE/Pz8gLLbZG/cuAGU3aZbTJKtEMLu6NGY1keo1KGifff27dsoilLuFNvipoPCwkLCw8OBP0Yl3ElRFC5cuICDgwPNmjUr972SbIUQdsfw+9oIao7K8vX1pW7duty8eZNjx46Vup6SksL58+dxcnIiNDSUTp06AbBz585SZY8cOUJ6ejpt27Ytd4wtSLIVQtghg5parcrONK1WS9++fQF48803S0xsSE9PZ9KkSRQWFvL888/j4eFB+/btCQ8PJzY2lm+++aZE2enTpwMwdOjQCt8roxGEEHbHoKirraqd1DBu3DiOHTvGL7/8wuOPP067du3QaDQcPXqUW7du8eCDDzJlyhTAmJxjYmJ46aWXePvtt1m3bh1+fn788ssvZGZmEhUVRdeuXSt8pyRbIYTdsfR0XRcXFz7//HNWrVrF5s2bOXz4MAaDgZCQEEaMGMGQIUNwdnY2lW/dujVr165l/vz5HDhwgHPnzhEcHMzrr79Ov379KvVOSbZCCLtj6ZotgJOTEy+99BIvvfRSpcqHhYUxf/581e8pJslWCGF3jIuHV762WtXFw61Jkq0Qwu7oFXXTdauyeLi1SbIVQtgdazQjWJskWyGE3VEUdbvrqplBZiuSbIUQdufO9Q4qW97eSbIVQtgdAxpVTQNqmhxsxf7r3kIIUQNIzVYIYXeMHWQq1rNFg71XbiXZCiHsjqJycRkZZyuEEFWgepyt1GyFEEI9g8qhX2rK2ookWyGE3VFUTmqQZgRRZUmn3dm4IJATP9ch97YDfk3yad8zjaeGX8PTp6hSz8i66cA/urUh47oz8386jF9QvoWjFhUJb5lF1KtXaNnuFt71XuTzXVoO7PJh7WeBpF93rvgBtYTaBcFl6JeokoM/1GPa06356T8NyMtyoHF4LrfTHdkwL4ipPR/g6nnzWyr/2VfTm5Ih/4DtRoeu6Xy07jgdn0xHq4W8wkC8fYp4dkgyi7//lfCWWbYO0W4YlN9HJFT6sHXEFZNka2euX3Lhk/HhFOZradcjjUUHDxHz/TE+PXSIPuOTSL3iwvsv3kdBXvk/yY/+WJc96/ysFLWoSP2AfP4xNx4HR1i1IJD+Dz/EmRvvMfCRtmxb1wCvunremH8WrbYaZA0rULPZo9ptz23FbiP86aefePHFF+nQoQORkZEMHjyYPXv22Dosi/tuSSPycxxorMth/KKzeNTRA6B1gKhJSdz3SCbXL7nywxcNy3xGbpaWJVOb4eyqt1bYogJdeqfi4aXn6H5vVsxrgkFv/GGZn+fAJ/8M5VaGIw2b5PPAI5k2jtQ+KKpqtRqUarAQjV0m2w0bNjB06FDi4uJo3bo1bdq0IS4ujhEjRrBmzRpbh2dRx/bUBeCJl67h6Fy6lvPES8kA7NtY9rbJK2eFkHrFhX4TkywSo1Av7boze/9bj/9+7V/qWmGBlquJxqahBg0LrB2aXbLkho+2YncdZCkpKfzrX//Cy8uLVatWodPpADh27BhDhw5l1qxZdO7cGX//0n9pa4LUK8Y21qatss1eb9g0F4CkM+7k55b+WXnyZ292rvSneftMug9KZuWsEIvFKipv16YG7Npk/geki5uewN+/r8VJt7ZTvTaCxv6Trd3VbFeuXElBQQFDhgwxJVow7gE0YsQI8vPza3ztFsBQZP4vT1Gh8bxi0JB2rWTnV0Guls8mN8PR2cAr/z5PNfj7V+s1Ds3ln5+ewauOnhOHvPjtoLetQ7IL6jrH1CVmW7G7ZLt3714AunfvXupa8bma3Hbr18Q4POvSaXez16+c++N8dmbJX0y+/qAJyRfdeP61yzQKzbNckOKuDRibxH3+4/l/P/xKZMdMft7hw/RXI2wdlt2QNlsLUxSF+Ph4tFotoaGhpa6HhISg1WqJj49HUWpmr21ktwwAvv1/jSjML/kXyGAwni9WVPDH9XNHPPnv5w0Jvi+bXq9esU6wospatb+Fi+N1tL//C2wUnEfrDrdsG5QdkaFfFpaZmUlBQQF169YtsY1wMUdHR3x8fMjNzSU723ybZnX31MtX8fIpJCXRjfdfvI+E3zwoKtRw9bwrH70SwbUEV9MoA0cn49+wwnwN/+8fYWg0MPLfxuFFwr59NLUZv175kpcff5D/rPAnqFku0xac5a9Ppdo6NLtQEzvI7CrZ5uYaOwnc3NzKLOPqauxAqKnJ1se/kEmfn8azbiEnfqrDGz0fYFDoI7zeOZLj++oyfuFZXNwMALh5GpPu+o+DuHzWnb+NuEpo65r5dalprl9xRcGZKwlufDo9lP98FYBWC0P/cUnG2lIz22ztqg6k1arZc6jyfyGvpC6tSjg249IYXvsmh/3rjpD021UAGjUPoMNzD+Dp60n2rTmAwi2+JONMMv/5tAm+jb1pP3AiF5OdTM/JzykAPgTg8o0l5DjVtf6HuUsxu20dgWXF7B4HgKM2AxhNQFA+H+zpT4G+dk9IUVQmUFkbQSV3d2PnT35+2XP48/LySpStjMD6L+PkeP3ugrO2AGj5dunTF455YNA/gI9/Pvfpoljy9T8w6A2kXb7J253mlvm4D55ZDMCrc8/ROeqGpaK+5wZElO4orY48vYtoFJxHYrwb+bkOgDHRTntsvqnMhqNa3DwMLI1ewulfvWwV6j1RN8CLyWuG2joMu2JXydbT0xN3d3cyMjIoKirC0bFkeEVFRWRkZODi4oK3d80cInPqgBfnf/Uiov0twtuUnit/ZKcPAPc9YuxMqRvgTUQ78x0rBgOcO2z8OoW2zsLJxUCdBoUWilyUZ/F/f8XXv5BZ0Tr2/eBb6rqnd5GpeSgtRdazUNs0UB3abO0q2Wo0GsLCwjh27BgXL14kLCysxPWEhAQMBkOJ8bc1TXycFytnhfBIr1TGLzpb4lrObQd2/F8AAI8PNs4ka9f7Afq9YqYKDORlaxnS/GEAXlt8Rlb9sqFj++vQ5ZlUnvx7itlk+/SgZLRaSDjjxo1rLjaI0L7UxGRrVx1kAJ06dQJgx44dpa4Vn3vsscesGpM1teuRjqOzgf3f+hK7qb7p/M3rTsx9uTk3rzvTpmsGzdvftmGUQq21SxqhL4K2nTIZ9o9EnJyNtViNRuGp/skMHHsZgwG++CDYxpHaBwXj2NlKH9Ug2ZZZs929+970TKhNjH369GHp0qUsWbKEjh070rJlSwCOHz/O0qVLcXV1ZcCAAfckNnsU0DSPQW9dZPk/Q1kwVsfXHzTBw7uIy+fcKSrQEtoqi7GfnK34QcKuJJz2YN6bzRj37gX6jbzKUwNS0LhMY+XPl/GpX4i+CBbPDOHgbh9bh2oXauJ6tmUm25EjR6K5y/meGo2GkydPqrqncePGTJkyhRkzZvDCCy/QoUMHAA4cOEBRURGzZ8/G17f0r2E1yZNDk6kXUMB/lzUk4TdPMlKcCQjJ4y/P3uBvL1/D+fe2PVG9bF/vR8Jpd/qNvEqr9reo43mJXL2WH7f4sn5pI+JPeNo6RLuh/D6pQU15e1dmsm3UqFFZlyxu4MCBNGrUiKVLl3LkyBGcnZ2JjIxk1KhRPPLIIzaLy5ra90ynfc/0u3qGq4eBr5N+ukcRiXsh/oQn740z9jn8eTSC+ENx84Ca8vauzGS7a9cua8ZRSpcuXejSpYtNYxBC2IbqDrLqnGyFEMJWalXNtiLp6ens37+fhIQEsrKymDJlCvn5+cTFxfHwww/fyxiFELWM1GyBwsJC5syZw+rVqyks/GOA/JQpU7h06RJDhw6lRYsWfPrppzV2gW8hhIUpKju9qkEHmapxtgaDgTFjxvDVV19RVFREREQEderUMV3Pzs5Gq9Vy8uRJ+vfvT0ZGxj0PWAhR89X6Vb/Wr1/Pnj17CA0N5T//+Q+bNm0qse7sgw8+yA8//EB4eDjXrl1j2bJl9zxgIUTNp2pCQ01cPHz9+vVoNBrmz59faiptsaCgIBYsWIBWq7X5iAYhRPVUvAdZpY9qULNV1WZ77tw5QkNDadasWbnlQkJCCAkJISlJdncVQqinqGyzrdaTGszR6/WVXnPWyckJBweHKgUlhKjdjMnW8jPIrly5wsKFC9m3bx/p6en4+PjQuXNnxo0bR4MGJXdDTkhIYMGCBRw+fJibN2/SpEkToqKiGDhwYKXyoqpmhKCgIBISEkhPL39mU2pqKvHx8QQFBal5vBBCGKltr61Cm+3x48d55plnWL9+PXXq1OGxxx5Dq9XyzTffMGDAADIzM01lT58+Td++ffnuu+9o1KgRnTp1Ijk5mXfffZfJkydX6n2qkm2PHj0oKirin//8Z4lhX3cqKCjgzTffRK/Xm90hVwghbK2goIBJkyZx+/Zt3nrrLbZs2cLChQvZtm0bPXr04NKlSyxYsAAw7gozefJksrKy+OCDD1i9ejWffPIJW7duJSIigi1btrB169YK36kq2Q4dOpQmTZqwc+dOnn32WT788ENu3DCu+r99+3YWL15Mr1692L17NwEBAQwZMkT9V0EIUetZeg+y77//nosXL9KrVy8GDx5sOu/i4sIbb7xB/fr1SUhIACA2NpYzZ87Qvn17nnnmGVPZevXq8c477wCwYsWKCt+pqs3Ww8ODL774gujoaE6dOsWFCxdM18aNM+6lpCgKwcHBLFq0qMbupiCEsCxLd5Bt27YNMFYg/6xhw4bExsaa/rx3714As7+pR0ZG4uvry+HDh8nKysLTs+yV21TPIAsMDGT9+vVs376dnTt3Eh8fT3Z2Nm5ubgQHB9O5c2f+9re/md2KXAghKsPSayOcPHkSJycnmjdvzrVr19iyZQuXLl2ibt26PPHEE7Ru3dpUNj4+HqDMHWKaNm1KWloa58+f54EHHijznVVaG0Gr1dKjRw969OhRlduFEKJcVU22ycnJpUZBeXt7l/gtu6CggGvXrhEQEMAPP/zAm2++SW5urun6kiVLGD58uKnj6/p142axfx6dUKz4fGpqarkx3tWqX+np6Vy8eJG8vDy8vLwIDQ3Fw8Pjbh4phBAoqFvuoLjsgAEDSiW96Ohoxo4da/pzVpZxI9XMzEymTJnCk08+yZgxY/D19WXfvn1Mnz6dZcuWERwczN///ndTInZ1dTX77uLzOTk55cZYpWT7/fffs2zZslK7MGi1Wtq1a8eYMWNo165dVR4thBCmPcjUlAdYtWqV2ZrtnQoKCgDIzc2lY8eOzJkzx3Ttqaeewt3dnZEjR7Jw4UKioqJMz6to5xqDofwdVFQn27feeov169ej/N4i7eXlhbu7O9nZ2WRlZbF//35++eUXJk+eLKMRhBBVU8WqbUBAAC4u5e9OfGcNtX///qWud+7cGX9/f1JSUrh48SJubm4A5OXlmX1e8fmKfqtXNfRry5YtrFu3DicnJ8aPH8/u3bs5ePAgu3fv5tChQ+zYsYNhw4ah0WiYPXs2+/fvV/N4IYQwsuCkBi8vL5ycnADjnofmFG8LlpGRgZ+fH1B2m2zx8Ney2nSLqUq2q1evRqPRMHfuXEaNGlVqvdrGjRszefJk3nnnHRRFYcmSJWoeL4QQwB9Dv9QcleXg4GBa3yUlJcVsmeLE6uvrS3h4OPDHqISScSpcuHChxDPLoirZnj59mqCgIB5//PFyy/Xr14+GDRty9OhRNY8XQgjA8kss/vWvfwXghx9+KHXtwoULXLlyBT8/P4KCgujUqRMAO3fuLFX2yJEjpKen07Zt23LH2ILKZOvo6Ii7u3ulyvr4+JjadYUQQhUFY9NApQ91j3/hhRdwd3dn06ZNbNmyxXQ+MzOTt956C4PBYFpgpn379oSHhxMbG8s333xjKpuens706dMB85Mj/kxVsm3fvj3nzp0zTWMrS0pKCufOnSMyMlLN44UQArBsMwIYJ2fNmjULrVbLpEmT6NOnD6+++io9evTg8OHDPPzwwwwfPhwwjrKKiYnB3d2dt99+m6ioKKKjo3nyySc5c+YMUVFRdO3atcJ3qkq2EydOxN3dnVGjRpltvwBjoh0zZgyOjo5MnDhRzeOFEMJIqcKh0lNPPcW6devo0aMH165d46effsLX15eJEyeydOlSUycaQOvWrVm7di09evQgMTGR2NhYGjVqxPTp003rI1SkzKFf48ePN3s+ICCAc+fO0bt3b9q2bUvz5s1xd3cnNzeXixcvcuDAAQoKCujUqRPbtm2jefPm6r4CQohar6rjbNVq0aIF8+fPr1TZsLCwSpc1p8xkW9GSYQaDgYMHD3Lw4EGz1/fs2cPevXtNC9QIIUSlVXUKmR0rM9lGR0dbMw4hhDCx9EI0tiDJVgghrOCuFqIRQgiLqE3NCOXR6/WkpKSQm5tbaixtUVERBQUFXL9+nV27dhETE3NPAhVC1Caa3w815e2b6mS7ZMkSlixZwu3btytVXpKtEEK12l6z3bZtG3Pnzq1U2SZNmvDkk09WKSghRC1XA5OtqkkNxVPVijd13L9/Pw4ODkRFRXH8+HG2b9/OyJEjcXBwwGAw8Morr1gkaCFEDadqqm7VtjK3NlXJ9uTJk7i5ufHOO+/g7+9P3bp1CQsLIzY2FicnJ4KCgpgwYQLjx4/nypUrfPnll5aKWwhRg1l6uq4tqEq2t27dIigoqMQiueHh4Vy9epXMzEzTuRdffBFXV1ezq+QIIUSlWHCqri2oSrbu7u6ltoYICgoC4Pz586Zzrq6uhISEkJiYeA9CFELUOrW9GSEoKIikpKQSG5sFBwejKAqnTp0qUTYvL4+ioqJ7E6UQolbRKOoPe6cq2Xbs2JGcnBzefvtt0w6VrVq1AmD9+vWmjdSOHTvGxYsXCQwMvMfhCiFqBSus+mVtqpLtiy++iI+PD99//z2dOnWioKCAZs2a0aFDB06dOkWfPn0YN26caSHdjh07WiRoIUQNV9ubEXx9ffn8889p0aIFzs7OODs7A/Dmm2/i7e1NfHw827ZtIzs7m0aNGjF69GiLBC2EqOFqYM1W9QyyFi1asGHDBq5du2Y6p9Pp+O6771i/fj1XrlwhJCSEfv364eXldU+DFULUEjVwUkOVF6Jp2LBhiT/Xr1+fkSNH3nVAQgghyVYIIaxCbTus/bfZlpls+/bte9cP12g0rF279q6fI4SoXdQO56oOQ7/KTLa//fbbXT/8zxMghBCitioz2b733nvWjEMIIf5Qm9psn3vuOWvGIYQQNVqt6CAb92hbMq5lVlywGnr/ILwQ9Kitw7CYrVd/snUIFhN3ZRz/ja+Zny+/qAEnU4ZW+f5a1WYrhBA2o6BuNIIkWyGEqILa1GYrhBA2I8lWCCEsT9pshRDCWqpBAlVDkq0Qwv5IM8If9Ho9J06c4MKFC2RlZTFo0CAKCwu5du0aTZo0uZcxCiFqGWlG+N1XX33FZ599RlpamuncoEGDSEpK4umnn6Z79+7ExMTg6el5zwIVQtQiahcErwaLh6tOtm+++SYbNmxAURTq1KlDQUEBeXl5AKSmpmIwGNi+fTtJSUmsWrUKNze3ex60EKKGq4HNCKp2ati6dSvr16+nQYMGLFmyhAMHDtCiRQvT9fbt27NixQoaNGjA6dOn+fLLL+95wEKImq/Wb/i4evVqNBoN8+bNo1OnTmbLtGvXjoULF6IoCv/973/vSZBCiFqmtm+Lc/LkSYKCgmjTpk255Vq1akVwcDCJiYl3FZwQopZSW1utBslWVc02Pz8fd3f3SpWVzjEhxF2pQbVaUJlsGzZsSEJCAjk5OeWWy8rKIj4+noCAgLsKTgghagpVybZLly7k5+fz/vvvl1suJiaGgoICHnvssbsKTghRS9X2NtsRI0awefNm1q5dy6VLl+jZsyeZmcZ1Yk+ePMn58+f55ptvOHToEN7e3gwbNswiQQsharZaP6mhXr16LFmyhDFjxrB//34OHDhguvb8888DoCgKPj4+LFiwAH9//3sbrRBCWMDNmzfp1asX169f58yZM6WuJyQksGDBAg4fPszNmzdp0qQJUVFRDBw4EK22cg0Eqic13H///Xz77besWbOGXbt2ER8fT3Z2Nm5ubgQHB9O5c2cGDBhAvXr11D5aCCGMrDypYfr06Vy/ft3stdOnTzNw4ECysrKIjIykVatWHDhwgHfffZejR48yZ86cSr2jStN1PT09GT58OMOHD6/K7UIIUS5rNiN8++23fP/992avKYrC5MmTycrK4oMPPuCZZ54BID09nSFDhrBlyxYef/xxevToUeF7VHWQCSGEVVipgywlJYUZM2bQpk0bHBwcSl2PjY3lzJkztG/f3pRowdik+s477wCwYsWKSr1LVc1206ZNaooD8Oyzz6q+RwhRy1mpGeHNN9+koKCA2bNn07Nnz1LX9+7dC0D37t1LXYuMjMTX15fDhw+TlZVV4dwCVcl26tSpaDSVW11HURQ0Go0kWyGEatZoRli1ahV79+7l7bffJjg42GyZ+Ph4AHQ6ndnrTZs2JS0tjfPnz/PAAw+U+z5Vyfa+++4rM9nm5eWRmppKZmYmGo2Gp59+WjrJhBBVZ8HhXImJifz73//mkUceYeDAgWWWK+40a9CggdnrxedTU1MrfKeqZLthw4YKyxw6dIipU6fy22+/sW7dOjWPF0IIoOo12+Tk5FJtr97e3nh7e5v+rNfrmTJlClqtlpiYmHJ/W8/NzQXA1dXV7PXi8xXNqgULdJA99NBDzJs3j4sXL7Jw4cJ7/XghRG1QxQ6yAQMG0K1btxLHn5d6Xbp0KXFxcUydOpVGjRqVG0Zx4q6o+dRgMFT4kSyyB9n9999PaGgo27ZtY8qUKZZ4hRCiJqtiB9mqVavM1myLnT59mgULFtC5c2f69etX4WOLNz8o3iDhz4rPe3h4VPgsi2346ODgwI0bNyz1eCFEDVbVZoSAgABcXFzKLPfRRx9RWFhIYWEhkyZNKnGtuHZafH7atGn4+flx6tQpUlNTadasWannFee4stp072SRZHvkyBHi4+Np2LChJR4vhKjpLDT0q7htNTY2tswyW7ZsAeC1114jPDyc3bt3Ex8fT4cOHUq+UlG4cOECDg4OZhPxn6lKtitXriz3ekFBAQkJCaZgu3XrpubxQghhZKFkW94EhPvuuw+9Xl9ibYROnTqxdOlSdu7cWWrUwpEjR0hPT6d9+/aVWr9bVbKdOXNmpcbZKopCkyZNGD16tJrHCyEEYD+rfrVv357w8HBiY2P55ptviIqKAozTdadPnw7A0KFDK/UsVcm2Xbt25T/M0RFvb2/atGlD3759ZbcGIUTV2cGyicXDw1566SXefvtt1q1bh5+fH7/88guZmZlERUXRtWvXSj1LVbKt7BxgIYSoKVq3bs3atWuZP38+Bw4c4Ny5cwQHB/P6669XakRDMVXJdtiwYfj5+TFt2rQSwymEEOJeskUzwsmTJ8u8FhYWxvz58+/q+aqS7dGjR/H09JREK4SwLCuvZ2sNqod+1alTxxJxCCHEH2pgslU1Xbd3796cO3eOnTt3WioeIYQAQKPiqA5U1Wx79+7NqVOniI6O5sEHH+TBBx/Ez88PZ2fnMu8pb0UdIYQwqwbWbFUl2/79+6PRaFAUhbi4OH799dcK75FkK4RQy17G2d5L93ScrRBC3BO1qWZ79epVXFxc8PX1NZ2TcbZCCKuogcm2zA6yrl27Mn78eGvGIoQQwO8dX4qKw9YBV0K5zQiKUg1+XAghap4aWLO12Hq2QghRVbW+g0wIIaxCarbC1jzrFDHo9RQe7ZlJPb8iFIfRTJirYeWH/ly/UvZ4Z2E9F0+7snqeP0d/8iTntgP+TfLp+FQmz424gbePvkTZOa81Yfs3lduFetDryQyelGyJkO1OravZpqWlsWnTprt6wbPPPntX94s/eNYp4qP/xNMkPJ/s21oSTrkS2qqAJ/tn85eemfzj+WYknHKzdZi12k//rUPM6GAK87W4uOlposvjxlUnVn0cwI619YhZfZ6gsHxT+cDQPO5vl1Xm827fdOTSOeMOrg1D8sssV+PUtpptYmIib7zxRpUfrtFoJNneQ6/9+zJNwvM5sMOL90YFk5vtwOyDr3N932s88fcM3vg0kVe7RmAwVIe+2Zon+ZIzs8c2oTBfy6NP3mTiR0l41tGj18P/zQ1g1ccBvDUolCU/nsbZ1Zgd+o+7Tv9x180+T1HgjReacemcK936ptO9b4Y1P45t1bZk6+zsXGKcrbCdoLA8/vJUJjlZWv49rgm52cYdRBWc+WhiEBFtcgjW5fNoz0z2fVfXtsHWUuv/XwPychxoostl2uJEnJyNGcDBAV6anMxvv3hw7CcvNi1rQNQY8wn2TpuW1Sdurxf+jQuIjrls6fDtSq1rRmjZsmWF+45Zw4YNG3jjjTdYuXIlDz30kK3DsYmufTLQauHAdm9u3yz5bTMYNGxbU48Rb1/jsd43JdnayJHdXgD0HppqSrR36j0klWM/ebFro0+FyTYtxZHl7xs3TI1+Lwl3T8O9D1hYld13kMXFxTFz5kxbh2FzzSONu4KePGR+f/rTh90BaNkh22oxiZKuXzV2UIa3yjV7vVFTY5tr4mlX8nLKb+pZMSeAvBwH2nfLpH232/c20OqiGtRW1VC1xKK1bd26leHDh5u2H67NGoUUAMZ2QXNSfh+JUM+vCFd3vdkywjr0ReYTafF5g0FD6rWyR45cOufC1q990WgUhk27ZpEY7Z1GUVQf9s4uk21ycjKTJ09m3LhxGAwG6tevb+uQbK6ObxEAtzIczF6/fcf5OvUk2dpCQJDxB2LCaVez1xPP/nE+K9P89xFg49IGGPQa2nW7RdMWefc2yOpCqcJh5+wy2X788cds3ryZli1bsmbNGkJDQ20dks05uxrb7AryzH/L7jxfXFZYV4fumQCsW+xHQX7J2q3BAOsX+5n+XFhovvablenArvU+APQbVXEnWk2lal0ElZ1ptlJmso2OjqZPnz7WjMUkNDSU2bNns3btWiIiImwSg70x6Mtv49PY5Y/N2uW5V27g7VPEtYsuvDUolPjjbhQVQlK8CzNfDuFKggsuv/8gdHQ0nx22fVOPvBwHdA/k0PqRWtz+XgNrtmV2kEVHR1szjhJeeeUVm73bXuXlaHFy1uPkYr7W6uT8x/n8XMm8tuDrX8Q7yy/wryGhHI31YkyPPyoKbh563lh0kY8mNiE/T4u7lx5zDQT7vjXu8delTy0aU2uO2tpqdU62wr7cznDAq64er7rm22PvnAaamS7fVlu5v10OS/ec4tvl9TkdZxw5EtYqh6cGpuHjV0TWLWNbbT2/ItL/VHHNTHPg1GEPNBqFvz5908qR25naNqmhppjyn1G2DuGuefh+AMTx6sIupGY/XuLa+wen4uF8CphBob4u0/dMs0mMlhB3xdYRVM39LxiPYleAA3uSMeiX493Ak/hs4/j1uCtfm8oc+f43DIZvCX6gMUmGN0iqpp/9Xqh1kxpqitm9PyXjWqatw7grgyYmM3ginN62kTmvHTadf//gVKa2e59+o6+jewt+2WZgxvD3bRjpvbX16q+2DqHSjh/w4EycOy3bZ5vGRd/pxNf+QEPadrxEm8AXiLvyNW0C/8jI+y40BurzaOdDtAn81nqBW0B+UQNOpiy4u4dUgwSqhjTuVROx3xvb8h59MhOvukUlrmm1Co9HpQOYerKF9Z0+4s6SGYFs+KxBqWvZt7V8t8I4hPHpF9PM3n/+N+MiQmFlTIqoTWrVaARhXxJOuXFguxce3gbe+iwRLx9jwtVQwIS5SQTr8kmKdyH2v3VsHGnt9eiTmTg5G9izpS7/21jXdD79uiPThzUl/boT7btlljnL78JJ4zjcYF0tHVt7JwXjSjyVPmwdcMVqRTNCTTF/amPmNo/nwY5Z/N/BU1w650Jow9E4/j2brEwt04eFoCiy4petBDYtYMTbV1n0dmPeHxPCF+/n4+mt59I5VwoLtIS3zmHqokSz92bf0pKfa+w8K6sTtDaRNlthU6nXnIl+UsfACSk80iOTpi3yUBQv/rexLl/NCeBqgoutQ6z1nhmeSv1GhWxc0oD4426kpzjRqGk+XZ7LoM+IG7i4mc8KtzL++Kfo7iXJVkYjCJu7neHI4n8GsvifgYCxg+z9MTWnQ6wm+EvPTP7SU12HbMPggmrVGWhpGoPxUFPe3kmyFULYH6nZ2saKFStsHYIQwoo0qGyztVgk946MRhBCCCuoFjVbIUQtUzykS015OyfJVghhd2TolxBCWIN0kAkhhOVJzVYIIaxB2myFEMIKZPFwIYSwAiu02er1elavXs3GjRu5cOECer2eoKAgnnrqKV5++WVcXEpOfz9+/DgLFy7k+PHj5OTkEBYWxosvvkivXr0q9T5JtkIIu2PpSQ16vZ7Ro0fz448/4u7uzgMPPICjoyNHjx5l/vz57N69my+//BI3N+Oyl7GxsYwcORKDwUC7du1wc3Pj559/ZtKkScTHxzNhwoQK3ynJVghhfwyK8VBTXoW1a9fy448/EhERwZIlS/D39wcgPT2d0aNHExcXx6JFi5g4cSJ5eXn84x//AODzzz/n4YcfBuDSpUsMHjyYxYsX8/jjj9OyZcty3ykzyIQQ9sfCu+tu3LgRgGnTppkSLUC9evV45513APjuu+8A2Lx5M2lpafTq1cuUaAGaNGnCpEmTgMotKSA1WyGE3bH00C8fHx9CQ0Np3bp1qWshISEAXL9+HYC9e/cC0K1bt1Jlu3TpgoODA3v27KnwnZJshRD2x8JDvxYvXlzmtePHjwMQEBAAwLlz5wDQ6XSlynp6euLn58e1a9dITU2lfv36ZT5XmhGEEHbHVnuQKYrCvHnzAHjiiScAuHHjBgANGpTeW+7O86mpqeU+W2q2Qgj7U8WhX8nJyTg4OJS45O3tjbe3d6Ue8+GHH3Lw4EHq16/Pyy+/DEBurnEDTldXV7P3FJ/PySm9o/KdJNkKIeyOBgWNiqYBze/ZdsCAAaVqmNHR0YwdO7bCZ8ybN4/PPvsMZ2dnPv74Y+rVqweAg4MDiqKg0ZQ/wMxgKH+7CEm2Qgj7Y/j9UFMeWLVqldmabXmKioqYMWMGa9aswcXFhQULFtCuXTvTdTc3N27dukV+fn6piQ4AeXnG3ZA9PDzKfY8kWyFEjREQEGA2IZYlOzub8ePHs3fvXry9vVm0aFGJRAvg5+fHrVu3uHHjBo0bNy71jIradItJB5kQwu5oFEX1oVZmZiaDBw9m7969NGzYkJUrV5ZKtADh4eEAnD9/vtS1rKwsrl+/Tr169codiQCSbIUQ9sjCkxoKCgp45ZVXOHHiBGFhYXz99ddmh3YBdOrUCYAdO3aUurZr1y70ej2PPfZYhe+UZCuEsD/F42zVHCrMnz+fX3/9lYYNG7JixQrTmFpzevToga+vLxs3bmT37t2m80lJScydOxeNRsOQIUMqfKe02Qoh7I4lZ5BlZGSYptfWq1ePmJiYMsvOmTMHT09PZs6cybhx4xg5ciTt2rXDw8OD/fv3k5uby4QJE2jevHmF75VkK4SwPwoqZ5BVvujBgwdNIwhOnDjBiRMnyiw7Z84cwDhVd8WKFSxcuJCjR4+iKAoREREMGTKEnj17Vuq9kmyFEHZHo4BGxdAvNTXbJ554gjNnzqiOKTIykmXLlqm+r5gkWyGE/ZFtcYQQwgpkd10hhLACtWNnpWYrhBBVIM0IQghhBVVcG8GeSbIVQtidqq76Zc8k2Qoh7I80IwghhBVIshVCCCuQNlshhLA8tcsmVmWJRWuTVb+EEMIKpGYrhLA/FlyIxlYk2Qoh7I90kAkhhDWoXRBckq0QQqgnoxGEEMLyauJoBEm2Qgj7I222QghhBQbFeKgpb+ck2Qoh7I/UbIUQwhpkNIIQQlieTGqoXpTfv1nefl42jsSyfBrWsXUIFpNf1MDWIVhUTf18Bfp6wB//BlWTNtvqpbCwEIBRSwfZOBLLmvKfUbYOwWJOptg6Ass6mbLA1iFYVGFhIa6urupvVAzGQ015O1ejk62Hhwc6nQ4nJyc0Go2twxGi1lAUhcLCQjw8PKr6AOkgq060Wi1eXjW7CUEIe1WlGm0xaUYQQghrkNEIQghhedKMIIQQVlADh37JTg1CCGEFUrMVQtgfg8F4qClv5yTZCiHsj7TZCiGEFdTAZCttttXUTz/9xIsvvkiHDh2IjIxk8ODB7Nmzx9ZhCZU2bNhAREQEhw4dsnUo9kVR/hhrW5lDkq2whA0bNjB06FDi4uJo3bo1bdq0IS4ujhEjRrBmzRpbhycqKS4ujpkzZ9o6DLukKAbVh72TZoRqJiUlhX/96194eXmxatUqdDodAMeOHWPo0KHMmjWLzp074+/vb+NIRXm2bt3KG2+8QU5Ojq1DsU8GVM4gs1gk94zUbKuZlStXUlBQwJAhQ0yJFqB169aMGDGC/Px8qd3aseTkZCZPnsy4ceMwGAzUr1/f1iHZp+I2WzWHnZNkW83s3bsXgO7du5e6VnxO2m7t18cff8zmzZtp2bIla9asITQ01NYh2afioV9qDjsnzQjViKIoxMfHo9Vqzf4jDQkJQavVEh8fj6IostKZHQoNDWX27Nn07t0brVbqOmWqgaMRJNlWI5mZmRQUFFCvXj2cnZ1LXXd0dMTHx4e0tDSys7Px9PS0QZSiPK+88oqtQ6gWFMWAoqK2Wh06yORHazWSm5sLgJubW5llipe1y87OtkpMQliEldpsrTmEUpJtNaLm184qb0cihD0oHo1Q6UP9K6w9hFKaEaoRd3d3APLz88ssk5eXV6KsENWShbfFscUQSqnZViOenp64u7uTkZFBUVFRqetFRUVkZGTg4uKCt7e3DSIU4t5QDIrqQw1bDKGUZFuNaDQawsLC0Ov1XLx4sdT1hIQEDAZDib88QlRPhj9qt5U5VLYj2GIIpSTbaqZTp04A7Nixo9S14nOPPfaYVWMS4p5TW6tVUbNVO4TyXpFkW8306dMHFxcXlixZwm+//WY6f/z4cZYuXYqrqysDBgywYYRC2LfiIZR169Ytdwhlbm7uPR3VIx1k1Uzjxo2ZMmUKM2bM4IUXXqBDhw4AHDhwgKKiImbPno2vr6+NoxTi7ng38FQ1nMu7gXFMeXJyMg4ODiWveXuX6MNQO4TyXo1Xl2RbDQ0cOJBGjRqxdOlSjhw5grOzM5GRkYwaNYpHHnnE1uEJUWUODg44ODgwaukg1fcWFhby3HPPlaqNRkdHM3bsWNOfbTWEUqPIgEwhhB0pKipCr9ervi8nJ8fsr/1/rtnevn2bhx56iPr16xMbG2v2WY8++ihpaWkcPHjwno3skZqtEMKuODo64uioPjW5uLjg4+NTYbk/D6H887ssNYRSOsiEELWKrYZQSrIVQtQ6thhCKclWCFHr2GIIpXSQCSFqpZUrVzJjxgycnJzMDqF85pln7un7JNkKIWqt//3vfyxdupSTJ0/i7OxMRESExYZQSrIVQggrkDZbK7h8+TIRERFmj+bNm9O6dWv++te/MmrUKLMN9rZw9uxZU4x3mjp1KhEREcyePfuu35GamsqtW7fu+jkV+b//+z8iIiIYPHhwpcpv2LCBiIgI+vTpc9fvXrBgAREREYwbN+6un1WRrl27EhERwf/+9z+Lv0uoJ+Nsraxly5Yl5mMrikJBQQGXL19m165d7Nq1iwEDBvCvf/3LhlFa3vLly1mwYAGrV6+W5SBFrSDJ1srmzZtH48aNS50vLCzkk08+YfHixaxatYpOnTrRtWtXG0RYvtdff50RI0ZUavB4ed577717FJEQ1YM0I9gJJycnJkyYQJs2bQBYtWqVjSMyz8/Pj2bNmlGvXj1bhyJEtSLJ1s506dIFMI73E0LUHNKMYGeKl3O7c0GNBQsW8MknnzB58mTc3Nz49NNPyczMpEmTJixcuJDg4GAAkpKSWLJkCfv27eP69et4eHjw4IMPMmTIkDKHsty4cYMlS5awc+dObty4QWBgIP3796d9+/Zmy0+dOpWNGzcybNgwpkyZUuJaUlISX331Fbt37yY5ORlXV1datWrF0KFD6dixY4nPUqxXr14AfPXVV6axjgAHDx5k+fLlxMXFcevWLXx9ffnLX/7CyJEjTZ/3z06dOsWnn37KkSNHyMrKokWLFowaNarcr7daqamprFixgr1795KUlERubi5eXl7cd999REVF0aNHjzLvvXDhAh9++KFpLGfz5s3p378/vXv3Nls+KyuL5cuXs3XrVi5duoSDgwM6nY4+ffrw/PPPl1pKUNg3SbZ25tKlSwA0bNiw1LVt27bx66+/EhgYSGBgIDk5OQQFBQHGbT7GjRtHTk4Obm5uhIeHk56ezo8//siPP/7I2LFjiY6OLvG8hIQEhg4dyrVr13B1dSU8PJyUlBRmzZrFQw89pCru2NhYxo8fz+3bt3F3dycsLIwbN26wb98+9u3bx6xZs+jbty8NGzYkMjKSI0eOAHDffffh6uqKl5eX6VmLFi1i3rx5APj4+KDT6UhKSmL9+vV8//33zJs3r9RUyu3bt/P6669TUFCAj48PzZo14/Tp04wYMYK2bduq+ixlOXXqFEOHDiUjIwN3d3dT23tSUpLpc06cOJFXXnml1L0JCQlERUWRnZ1NeHg4OTk5HDlyhCNHjrB//35iYmJKlL98+TLDhg0jMTERR0dHQkJCMBgMxMXFERcXx7Zt21i0aJHZxa+FnVKExSUlJSk6nU7R6XRKUlJSmeVu3rypPPzww4pOp1NmzpxpOj9//nzT/bNmzVIMBoOiKIqSlpZmen5kZKSi0+mUjz/+WMnPzzfdu2PHDtO17du3m84bDAbl73//u6LT6ZRhw4YpGRkZiqIoil6vV5YtW6ZERESY3nmnKVOmKDqdTnn//fdN59LS0pQOHTooOp1Oeeutt5SsrCzTO7744gtFp9Mp999/f4nPXvzsM2fOlHj+1q1bFZ1Op0RGRirfffed6XxBQYGycOFC07UrV66YrqWmppo+47///W+lsLBQURRFycrKUiZMmGB616BBg8r82t9p/fr1ik6nU5577rkS55977jlFp9Mpr732mnL79m3T+du3bysTJ05UdDqd0rZtW6WgoMB07c7v3eOPP67Ex8ebrv3www9Ky5YtFZ1Op3z77bem80VFRcqzzz6r6HQ65dVXX1Vu3Lhhunbu3DmlZ8+eik6nU959990S8XXp0kXR6XTKrl27KvU5hXVJm62NKYrCrVu32LNnDy+//DLp6el4eXkxfPjwUmWdnJwYP348Go0GwNRJ9fnnn5OVlcWzzz7L+PHjS9R2unXrxsSJEwFK/Pp+6NAh4uLi8Pb25qOPPqJu3bqAcWHlYcOGqZqq+M0335CRkcGDDz7IjBkz8PDwAIyrKw0ZMoTOnTtTWFjI999/X+Gz5s+fD8C0adN46qmnSnz20aNH07NnT9Ov18VWr15NVlYW7du3Z9KkSaYl8zw8PHj//ffLbHZQ4+rVq1y5cgVXV1emT59eYvV+T09PJk2aBBjXSk1JSSl1v0ajYcGCBTRr1sx0rkePHqZmjmXLlpnOb9++nZMnT9K0aVM+/vhj6tevb7oWFhbGxx9/jFarZfXq1aSlpd31ZxPWIcnWyrp161ZqUkO7du0YMWIEx44dw8fHh0WLFpltRtDpdKZEdqddu3YB8Le//c3sO//2t7+h0Wg4deoUN27cAP7YXfSxxx4zO861b9++lf5MP/74IwDPPfec6QfBnaZPn86OHTt4+eWXy33OpUuXOHfuHFqttkSivdPTTz8NlNz5dN++fQBm2z6dnZ3LbBNVo1GjRhw4cIADBw6Y/XoVb6MCkJeXV+p627ZtS00QAXj++ecBOHHihClx7ty5EzDu8uri4lLqHp1Oh06no7CwkP3791ftAwmrkzZbK/vzpAatVou7uzv+/v60adOGnj174u7ubvbeBg0alDqXlZXFtWvXAPjoo4/49NNPzd7r4OBAUVERCQkJNGjQwLSOZ1hYmNny5hJDWZKSkgAIDw83ez0gIKBSz4mPjwf+qF2bU5zIEhMTURQFjUZj+ix31hrv1Lx580q9vzJcXV05f/48x44dIzExkaSkJM6dO2eKHcBgKL2tdosWLcw+z9/fHy8vL27fvk1CQgK+vr6cP38egB9++IHDhw+bvS85ORkwtgWL6kGSrZWVNamhMszVcu4ctXDy5MkKn3H79m3AmKSh7E3vvLy80Gg0ldqD6ebNmwBma91qFMdUVFRk6kAri8FgMG3GV3xfWT+k7ux8uxtnzpwhJiamVG0yMDCQPn36sHbt2jLvLSu24mu3b982/SAp/jxJSUmmH2RlKf5+CvsnybaauzNZ/vzzz5WebFD8q3BOTo7Z6/n5+ZXe7M7V1ZWsrKwyn1VZxQkpPDycb7/9ttL3eXt7k5aWVua20+Z+rVfrxo0bvPjii9y8eZPmzZvTt29fWrRoQbNmzfDx8aGgoKDcZFve16Y47uLvSfH3dN68eTz55JN3HbuwD9JmW815e3ubEuyFCxfMltHr9fz0008kJiaaNtJr2rQpYBzOZE7xr7KVERISUu49//vf/xg4cGCJDjpzijuyLl++TEFBgdkyqampHDp0qEQnVPFnOX36tNl7yvq6qLF+/Xpu3rxJs2bNWLNmDYMHD+ahhx4yTVs21yl2J3Pbr4Cx9pqVlYVWqyU0NBT44+tQXtxxcXGcPXv2nvwgEdYhybYGKB5z+vXXX5u9vmXLFoYOHcqzzz5rqmF169YNMHY0mUsUGzdurPT7iycsbN68ucz3Hzp0iMzMTNO54o60O2vPYWFhBAYGkpubW+az5s6dy8CBA5kwYYLpXPFnWb9+fan2UoPBUOaz1Lhy5QoAoaGhJTrDiq1bt870/+Z2hj1w4ICpbf1Oq1evBuChhx4yjXDo3LkzAJs2bSI/P7/UPUlJSQwaNIhevXoRFxen/sMIm5BkWwO8/PLLuLi4sGXLFj766KMS/0D37t3LjBkzAOjXr5+p/bJly5Z06dKF3NxcoqOjTR0uAGvXrlW1NsPAgQPx9vbm4MGDxMTEmN6vKAorVqzgu+++w8nJiYEDB5ruKW4yuHr1qumcRqNh9OjRAMTExPDdd9+ZrhUVFbF06VI2bNgAUKIDLSoqCn9/f06cOMHbb79tqu3l5+fzzjvvlFl7V6O49h4bG8uxY8dM53Nzc/nss89YsmSJ6Zy5BFlQUEB0dHSJH2xr165l+fLlaDQaxowZYzr/9NNPExISQmJiImPHjjWNIAFjDXn06NEUFRXRokULiyxyLSxD2mxrgLCwMGbPns3kyZNZvHgxK1asoGnTpmRkZJhqZI8++qhpLGixmTNnMmzYMI4dO0b37t3R6XSkp6dz7do1unTpUul1Uf38/Pjwww8ZO3YsX375JRs2bCA4OJhr166RlpaGg4MDM2bMMCUsMI52OHLkCK+//jqhoaFMmDCBjh070rdvX86dO8fy5ct5/fXXee+99/D39+fy5cumjrgxY8bQvXt307M8PT356KOPGDlyJOvWrWPbtm0EBweTmJjIrVu3VH2WsvTr14+VK1dy5coVoqKiCAkJwdXVlcTERHJycggMDESr1ZKUlMT169dL3d+pUycOHjxIt27dCA8PJyMjw1TTnTx5Mg8//LCprLOzMwsXLmT48OHs3r2bzp07ExYWRmFhIRcvXkSv1xMQEMCiRYvu6jMJ65KabQ3Rs2dPNm3aRN++falbty5nzpwhIyODVq1aMW3aND777LNSUzsbNGjAqlWrGDNmDIGBgcTHx6PVaomOjmbOnDmq3t+pUyc2b95M37598fT05MyZM+j1erp3787q1atLLcQdExNDhw4dUBSFixcvkpiYaLr2xhtvsGzZMrp27YrBYDC1xXbs2JFFixaZXYi7bdu2bNiwgT59+uDu7s7Zs2cJDAxkzpw592TjPm9vb9atW8fgwYMJCQnhypUrJCYmEhwcTHR0NJs3b6Znz54AZhP7/fffz+rVq+nQoQMXL17k1q1bPProo3zxxRdmJ7CEhYWxefNmRo0aRWhoKBcvXuTSpUs0adKEYcOGsXHjRho1anTXn0tYj2yLI4QQViA1WyGEsAJJtkIIYQWSbIUQwgok2QohhBVIshVCCCuQZCuEEFYgyVYIIaxAkq0QQliBJFshhLACSbZCCGEFkmyFEMIK/j/yR6Od6oYygQAAAABJRU5ErkJggg==\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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79/P+fPnLZ4vW9yscePGlfZjNQlv3ry50gtNJhMHDhyw+mDG7t272bNnj3lhHyGEqLY6fmSuX79+xMfHs23btgpJeNu2bQAMGDCg0j769+/P559/zrZt23juuedwdv4rner1emJjYwHo1atXpf1YTcKRkZGVfwohhKgjdb12RGhoKFFRUSxbtoy77rqLrl27AnD48GGioqJwd3dn5MiR5vapqamUlJTQrFkzvL29Abjjjjvo1KkTx48fZ/bs2bz88ss4OTlhMpl46623OHPmDHfeeafFuchXkyQshKh32rRpw7Rp05g5cyaPP/44ffr0ASA2NhaDwcC8efPKlRFGjRpFeno6c+bMITQ0FAAnJyfee+89/vWvf7Fq1Sp27txJ586dOXHiBKmpqbRs2ZKZM2dWGUuN1o4QQog6VcePLQOEhYWxdOlSbrnlFg4dOsSRI0fo2bMnn376Kf/85z+r1UeHDh34+uuveeqppwDYtWsXBoOBsLAw1q5dS5s2barso0arqBmNRjIzMyksLKwwj85gMKDX6zl//jzbt29n9uzZNXkLIUS9pvnzpaa9eiEhIYSEhFTZbvv27VbPNWnShFdeeYVXXnmlRjGoTsLLli1j2bJl5qdFqiJJWAihWl2vZWlHVCXhLVu28O6771arbdu2bfnHP/5Ro6CEEPVcPUrCqmrCX331FQAPPvggu3btYv/+/Tg5OTFixAgOHz7M1q1befbZZ813CMeOHVsnQQshbnCqHlmuR1veHz16FA8PD15//XWaN29Oo0aNCAoKYu/evbi4uODv789zzz3H5MmTSU9Pr/DMthBCVEfZY8tqXo5KVRK+fPky/v7+5bYw6tixI2fPniU3N9d87Omnn8bd3Z2ffvqp9iIVQtQvdTgzwp6oSsKenp4VFin29/cH4NSpU+Zj7u7uBAQEkJKSUgshCiHqHSlHWObv709aWhoFBQXmY+3atUNRFI4dO1aubVFRkcXFMYQQoioaRf3LUalKwnfddRcFBQW8+uqr5OXlAaVbewCsX7/evL5m2cIY1lYXEkKISl2HhzXshaok/PTTT+Pr68v3339Pv3790Ov1dOjQgT59+nDs2DFCQ0OZNGkS4eHhQGnSFkII1aQcYVnjxo355JNP6Ny5M66urub9mV5++WV8fHxITExky5Yt5Ofn06pVK8aPH18nQQshbnD1aCSs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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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77U6F/lGkoSFEPVOmzZtmDFjBpGRkYwcOZI+ffoAEBsbi8FgYMGCBaWGEcaMGUNqairz5s0jJCQEAAcHB95//32ee+451qxZw65du+jSpQunT58mOTmZli1bEhkZWWks1do7QgghalUtL1sGCA0NZfny5fzlL3/hyJEjHD9+nMDAQD799FP+7//+r0ptdOzYka+//ppnn30WgN27d2MwGAgNDWX9+vW0adOm0jaqtYua0WgkPT2dgoKCMvPoDAYDer2ey5cvs3PnTubOnVudtxBC1Gua319qyqsXHBxMcHBwpeV27txZ7r0mTZrw2muv8dprr1UrBtVJeMWKFaxYscKyWqQykoSFEKrV9l6WdkRVEt62bRvvvfdelcq2a9eOBx98sFpBCSHquXqUhFWNCX/11VcAPProo+zevZsDBw7g4ODAiBEjOHbsGNu3b+eFF16wPCEcP358rQQthLjNqVqyXI+OvD9x4gRubm68+eabNG/enEaNGuHv78++fftwcnKibdu2vPTSS0ydOpXU1NQya7aFEKIqzMuW1bzqKlVJ+Pr167Rt27bUEUadOnXi4sWLZGdnW66NHj0aV1dXfvjhh5qLVAhRv9TizAh7oioJu7u7l9mkuG3btgCcPXvWcs3V1RVfX1+SkpJqIEQhRL0jwxHWtW3blpSUFPLz8y3X2rdvj6IonDx5slTZwsJCq5tjCCFEZTSK+lddpSoJ33fffeTn5/P666+Tm5sLlBztAbBx40bL/prmjTHK211ICCEqdAsWa9gLVUl49OjReHt789133xEUFIRer6djx4706dOHkydPEhISwpQpUwgLCwNKkrYQQqgmwxHWNW7cmE8++YQuXbrg7OxsOZ/p1VdfxcvLi4SEBLZt20ZeXh6tWrVi4sSJtRK0EOI2V496wqpXzHXp0oWYmBguXbpkuabT6diyZQsbN24kNTUVX19fhg8fbtltSAghVKlHizWqtXcEQMuWLUt93aRJE1544YWbDkgIISQJCyGETakd5627Y8LlJuFhw4bddOMajYb169ffdDtCiPpF7bSzujxFrdwkfPz48Ztu/M8LO4QQQpRWbhKeN2/erYxDCCH+IGPC8MQTT9zKOIQQol6qFw/mnutzB1mXsisvWAfNPwhDWvWwdRi1ZuvFX20dQq2JS719P1+RoSkn0qtfX8aEhRDClhTUzY6Q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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.9999155863732287\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>100.0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>10.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>100.0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>20.0</td>\n",
       "      <td>10.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     100.0   50.0   20.0    10.0  6.666667     5.0\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean  100.0   50.0   20.0    10.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": "8f37d598",
   "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
}
