{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0b119b7e",
   "metadata": {},
   "source": [
    "### Random Forest Model Training with Betti Vectorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "47d6ddeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import plot_confusion_matrix, roc_auc_score\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from src.utils import enrichment_factor"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc50db6c",
   "metadata": {},
   "source": [
    "## Target KIF11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████| 7109/7109 [00:02<00:00, 2421.57it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_MorganFeatures/target_kif11/'\n",
    "\n",
    "for file in tqdm(os.listdir(path)):\n",
    "    if file.endswith('pkl'):\n",
    "        with open(os.path.join(path, file), 'rb') as f:\n",
    "            X.append(pickle.load(f))\n",
    "        target_label = 0 if \"active\" in file else 1\n",
    "        y.append(target_label)\n",
    "\n",
    "active_ind = [i for i, label in enumerate(y) if label == 0]\n",
    "decoy_ind = [i for i, label in enumerate(y) if label == 1]\n",
    "\n",
    "# shuffle the lists\n",
    "random.shuffle(active_ind)\n",
    "random.shuffle(decoy_ind)\n",
    "\n",
    "# Use 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.9936305732484076"
      ]
     },
     "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": "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22r5tLQ01qxZw7Zt27hw4QIODg4YDAb69evH008/XWhpTGFfJDlrzIULFwCoX79+oXPbt2/njz/+ICAggICAADIyMggMDATyt92ZMGECGRkZuLm5ERoayrVr1/jll1/45ZdfeOWVVxg/fnyB+8XGxjJ06FASEhJwdXUlNDSUpKQk5syZQ/v27VXFvX//fiZOnMitW7dwd3cnJCSE5ORk9u3bx759+5gzZw79+/enfv36tG3blqNHjwLQvHlzXF1d8fLystxr+fLlLF68GAAfHx8MBgPx8fFs3ryZ77//nsWLFxeaWrtjxw5effVVcnJy8PHxoUmTJpw6dYoRI0bQrl07Ve+lKFFRUQwdOpTU1FTc3d0tfQfx8fGW9zl58mRGjhxZ6NrY2FgGDBhAeno6oaGhZGRkcPToUY4ePcqBAweYO3dugfIXL15k2LBhxMXF4ejoSFBQECaTiYiICCIiIti+fTvLly+3uli8sBOKqHDx8fGKwWBQDAaDEh8fX2S569evK/fff79iMBiU2bNnW44vWbLEcv2cOXMUk8mkKIqiXL161XL/tm3bKgaDQVm0aJGSnZ1tufann36ynNuxY4fluMlkUp599lnFYDAow4YNU1JTUxVFURSj0ah88sknSlhYmOWZd5o6dapiMBiU+fPnW45dvXpV6dixo2IwGJQ333xTSUtLszxj9erVisFgUFq0aFHgvZvvffr06QL337Ztm2IwGJS2bdsq3333neV4Tk6OsmzZMsu5S5cuWc6lpKRY3uN//vMfJTc3V1EURUlLS1MmTZpkedYLL7xQ5M/+Tps3b1YMBoPSt2/fAsf79u2rGAwG5V//+pdy69Yty/Fbt24pkydPVgwGg9KuXTslJyfHcu7Oz+7RRx9VYmJiLOd+/PFHpWXLlorBYFC+/fZby/G8vDylT58+isFgUEaPHq0kJydbzkVHRyu9evVSDAaD8u677xaIr1u3borBYFB27txZovcptE3anG1MURRu3rzJnj17ePnll7l27RpeXl4MHz68UFknJycmTpyITqcDsHTKffrpp6SlpdGnTx8mTpxYoDbVvXt3Jk+eDFCgOeHw4cNERETg7e3NwoULqVmzJpC/EPmwYcNUTV398ssvSU1NpXXr1syaNQsPDw8gf/Wvl156ia5du5Kbm8v3339/13stWbIEgNdff51//OMfBd77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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": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAE+CAYAAACdoOtZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABIsklEQVR4nO3deVxU5f7A8c8M+6q4oIAgIOCav9TU6mpqWra5ZKapaS6ZuZTX9KqVXZeulvdauaR5U8syl3LP6qa5b0kq5L4hgqiAIMgOAzPn98c0k8TinFFkGL/v+5rX1XO+58xzIL/zzPc8z3M0iqIoCCGEqPK0ld0AIYQQd4ckdCGEsBOS0IUQwk5IQhdCCDshCV0IIeyEY2U3QAghblVUVIRer1d9nIODA46O93dKu7+vXghhU4qKijh5/AB6xVP1sQ4ODjRr1uy+Tur375ULIWyOXq9Hr3jSoNY/cXZIs/g4nb4GF1NnoNfrJaELIYQtcdCm4uCQYnm8YqjA1lQdktCFEDbHgIIByyexq4m1Z5LQhRA2x/DH/9TEC0noQggbZFAU9CqWmTLIklSAJHQhhA0yoK6MIv1zI0noQgibo0dBqyKh66WGDkhCF0LYIEXlTVFFEjogCV0IYYP0ioJGRV1cTb3dnklCF0LYHAPq6uJSQzeShC6EsDkGFFV1cRmHbiSrLQohhJ2QHroQwuboATWdbvVrM9onSehCCJtjADQq44UkdCGEDTKgQU1KN6hK//ZLEroQwuYYFFSVXAxyTxSQhC6EsEF6NCjSQ1dNEroQwuYYVCZ0NbH2TBK6EMLmGBQNGkVFQlcRa88koQshbI4e0KjqoQuQhC6EsEEGtKib96iVWZJIQhdC2CCDogE1ZRRFY1VCv3r1KgsXLmT//v2kpaXh4+NDx44defPNN6ldu3ax2EuXLrFgwQKOHj3KzZs3CQoKok+fPgwYMACttuS7Jycns3DhQg4cOEBKSgp+fn50796d4cOH4+zsXCI+MzOT//73v2zfvp3ExERq1arFk08+yZgxY/D09LToejSKYr/LlBkMBnJycnByckKjkRqbEPeKoigUFhbi4eFRarIrS0FBASdPnqTAZxSoeEg0+tq4pC+iWbNmuLi4WHTIiRMnGDJkCFlZWURERBAUFMTJkydJSkoiKCiIdevWUa1aNQDOnj3LgAEDyM7OpmXLltSsWZPIyEgyMzPp1q0bc+bMKXbupKQk+vbtS1JSEk2aNCEwMJCoqChSUlJo06YNX3zxBU5OTub47Oxs+vfvz7lz5wgJCSEiIoJTp05x5coVwsLCWLNmDV5eXre9Jrvuoefk5HD+/PnKboYQ962IiAiLEtFfGRQtimL5B4FGRSyATqdjwoQJZGVlMWXKFAYOHAgYP1D+8Y9/sHXrVhYsWMCUKVNQFIWJEyeSnZ3Nv//9b3r06AFAWloagwcPZsuWLTzxxBN07drVfP5p06aRlJTE2LFjGTVqFAC5ubmMHj2agwcPsmLFCoYOHWqOnzt3LufOnaNPnz5Mnz4drVZLUVER77zzDps3b2bu3Lm89957Fvwc7LiHnp+fz6lTp/hs+DdkXs+q7OZUiEmbRzK7x2eV3YyKY7f/dcKk70cyu7t9/u68fb0YufRlmjZtiqurq8XHmXroOdXfQHFItfg4jb4WHjcXWNxD37RpE5MmTSq1d52YmEjv3r1p1KgRy5YtY//+/QwbNow2bdqwYsWKYrFRUVH069eP1q1b88033wAQGxvLM888Q2BgIFu3bi32DeXatWt06dKFunXrsnPnTsBYamnfvj2Ojo7s2bOnWHklJyeHTp06UVBQwK+//oq7u3u512XXPXRTmSXzehbpiZmV3JqKY8/Xhv32NwBIT8yo7CZUKGtLnWonFqkZEQOwbds2AIYMGVJin5+fHwcOHDD/fd++fQB06dKlRKyp/HL06FGys7Px9PRk//79KIpCp06dSpSb/P39adKkCSdOnCAmJoawsDAOHz5Mfn4+Xbp0KVEr9/Dw4JFHHuHnn3/m8OHDdOjQodzrkhvDQgibY1C06FW8DCpLLqdPn8bJyYlGjRqRmJjI559/zpQpU5gzZw7Hjx8vFhsTEwMYy0elCQkJwWAwcPHixWLx4eHhpcaHhoYCmMvBlsafO3futtdl1z10IUTVZECjcjq/5bE6nY7ExETq1q3Lzz//zLvvvkteXp55/5IlSxg2bBgTJ04E4Pr16wAlRr2YmLanpqYWi/f19bUoPiUlxaLz37hx47bXJgldCGE3kpKScHBwKLbN29sbb29v89+zs7MByMjIYNKkSTz11FOMHj2amjVrsn//fqZPn86yZcuoX78+ffv2NSf7su4FmLbn5uYCqI43/b+bm5tF8eWRhC6EsDl6tH9MLrKM8kds//79zT1fkzFjxvDGG2+Y/67T6QBj4m3Xrl2xm6LPPPMM7u7ujBgxgoULF9KnTx/zB8Tt7gcYDMZV2Ss6vjyS0IUQNsegaNCrqYv/MQlp1apVpfbQb3Vrz7lfv34lTtWxY0fq1KlDcnIycXFx5p5zfn5+qW9t2u7h4QFgcbxpxIra+PJIQhdC2ByDyh66aZ5o3bp1bzts0cvLCycnJwoLC6lXr16pMf7+/iQnJ5Oeno6vry9nzpwhNTWVBg0alIj9aw3cVDv/6zeFv8ab4iyNL6vGfisZ5SKEsDl6RaP6ZSkHBwdzYk5OTi41xpRca9asaR59YhqNcitFUYiNjS12zvLiAfNoGNOoGUvjGzZseJsrk4QuhLBBBrToVbzU9OYBHnvsMQB+/vnnEvtiY2O5evUqvr6+BAYG0r59ewB27NhRIjYqKoq0tDRatWplHkNuit+1a1eJuve1a9c4c+YMAQEBhIWFAdC6dWtcXV359ddfS9z4zMnJMU8oatWq1W2vSxK6EMLmGDCOLbf4pTKVvfTSS7i7u7Np0ya2bNli3p6RkcGUKVMwGAzmRbfatGlDeHg4Bw4c4LvvvjPHpqWlMX36dKD4BCXTh0BsbCzz5s0zb8/NzWXKlCno9fpi8e7u7vTs2ZOMjAymT59OUVERAEVFRcyYMYPMzEz69u1r0QJdUkMXQtgcPRr0qmro6maKBgQEMHPmTP7xj38wYcIEvvzyS3x9ffn9999JT0/n4YcfZtiwYQBotVpmzZrFK6+8wnvvvce6devw9fXlt99+IyMjgz59+vD4448XO//UqVPp168fixcvZufOnYSEhJgX53rsscdK3IwdN24ckZGRbNq0iaNHj9KkSRNOnz5NQkICTZs2LTZKpzzSQxdC2ByDyvq5wYonFj3zzDOsW7eOrl27kpiYyMGDB6lZsybjx49n6dKlxVZDbN68OWvXrqVr167Ex8dz4MAB/P39mT59OtOmTStx7sDAQNauXUuvXr1IS0tj9+7dVKtWjfHjx/Ppp5/i6Fi8L129enXWrFnDwIEDKSoqYteuXWi1Wl599VW++uor8wia25EeuhDC5qgd5aK25GLSuHFj5s+fb1FsWFiYxbFgXBPmgw8+sDi+evXqTJkyhSlTplh8zF9JQhdC2BzTGi2W0qpcy8VeSUIXQtgcReVaLmpWZrRnktCFEDZHr3KmqJpx6PZMEroQwuaYxperiReS0IUQNkhROXJFkR46IAldCGGDpIduHUnoQgibY1A0qp5CZM04dHskH2tCCGEnpIcuhLA5BjToVQxFVPe4OvslCV0IYXMMKh/8rPYh0fZKEroQwuboVfbQ1cTaM0noQgibo6jsoSvSQwckoQshbJAelTNFpYcOSEIXQtggg8q1XOSmqJEkdCGEzTEo6iYWyU1RI0noQgibY1BU9tBlYhEgCV0IYYNk6r91JKELIWyO9NCtIwldCGFzjA+4UDFsUW6KApLQhRA2SK+onFgkPXRAEroQwgZJycU6ktCFEDZHUbTqSi4ybBGQhC6EsEGylot1JKELIWyOAXWPoJOZokbyPUUIIeyE9NCFEDbHeFNUxdR/NEgnXRK6EMIGKSoX55Jx6EaS0IUQNkf1OHTpoQOS0IUQNsigctiimlh7JgldCGFzFJUTi6TkYiQJ3QaFN8/lpTHJNGubg7unntQkJyK3e/PdojqkJTuViHdx09P79RQ6dE+nbqCOzHRHzkS5893COlw47l4JVyAsY2DeDxfwCy6gT7Nmld0YmyIPuLCOfE+xMW2fyGDelvO0ezYDrYNC/AVXqtUo4vlXU/l8x1nCm+cWi3fUZjD3+wsMmpBE/YgCkhKcyc3W8thzGcz74TzPvZJaSVcibsfP+zsatcy9feB9yKD8MdLF4ldlt9g2SA/dhtTy0zFpfjwOjrDykzp880ldDHoNLq4Gxsy6wpN903h3cRxD2zXGYDD2SIJ8FlPNL58byY5MHxbCuWgPAJo8lMPUL2J5Y9YVrl1yJmqvd2VemihG4eXxydT1OlbZDbFZUkO3js3+FA4ePMigQYNo27YtLVu2ZODAgezdu7eym1WhHn8+HQ9vA8cOevL1HD8MemPSLsjXMn9yPTLTHfCrr+PBv2UDENYsl2quvwMwc0SwOZkDnD7iwZL3AwB4fdq1e3shokw+tQuZ+kUcA8cnV3ZTbJqiqneuQZHFuQAbTegbNmxgyJAhREdH07x5c1q0aEF0dDTDhw/n22+/rezmVZgbyU7s/aEaP31Ts8S+Qp2Wq5dcAKjlrwOgVccsAM5GuXPqsGeJY3as8yEnS0v9hvk0aCpf7Stbyw5ZLNt/lkefyuRGsiPXMl6q7CbZLFMNXc1L2GDJJTk5malTp+Ll5cWqVauIiIgA4Pjx4wwZMoSZM2fSsWNH6tSpU8ktvft2rK/BjvU1St3n4qanXmgBANfijIndN8CY2GNOupV6jKJoSIx3IaxZHg1b5HLxlNwgrUz1w/Nx8zCwfa0Pi6f588Hu8Mpuks1SvZaLRhI62GAPfeXKleh0OgYPHmxO5gDNmzdn+PDhFBQU2HUvvTSBDfKZuiwOr+p6Tv7mwcnI4r1xB4ey7wg5Ohr31amnq9A2its797s7o7tG8J+xQWSl21xfyqaouyGqLvnbM5tL6Pv27QOgS5cuJfaZttl7Ld1kwLgkvjxwms93n6VVhyx+3erNtKEh5v1Jl50BCG6cX+rxTi4G6tY39uo9q+krvsGiXKePeBB7qvRvU6I4qaFbx6YSuqIoxMTEoNVqCQ0NLbE/ODgYrVZLTEwMimL/45SaP5KNf7AO7R+/Jf9gHf/3SLZ5/287jCNXGrfMpUX7rBLH9xiSiqub8efk6GT/Py9hP2TYonVsKqFnZGSg0+moXr06zs7OJfY7Ojri4+NDXl4eOTk5ldDCe+vjtwJ5LrQ5wx5rxPdf1iIwPJ93/xtHh+7pAMSfdyMt928AvPNZHJ16puPqrsezWhE9hqbwysREMtMdANAXSQ9GVB1yU9Q6NlXIy8vLA8DNreyvpa6urgDk5OTg6VlyZIc9Sb5ivPl55aIrC6fUQ6+H519NZejbiez7oToGg4aEm68Sf/QYLdpnM3lhfLHjt33nQ9ZNR154LYWcLIfKuAQhrKK2Li4J3cimErpWq+YZgpZ/x5q0eaQ1zbE5jtp0YBR1g3TMOTwUnd7X+FUz9L/Epf1KNdejOGqz0OlrkZ73KLX/9gAP+SwCUni0f1fCezxTyVcgijsNgEc1Nz48PLmS22JbFJUJXdZyMbKphO7ubhxWV1BQUGZMfn5+sVhLzO7xGemJmXfWuHvAs1oR/sE64s+7UJBXeo9603ktbh4GPh/+KWejPPjwt0lMbvOfWyIcgZvAT8BPLN5+lhqNYeHrB4nad6LiL+Jus+N7JZ8e6w5ATkYek1t/WMmtubt8/Kox6Xv76EhVJTZVQ/f09MTd3Z309HSKiopK7C8qKiI9PR0XFxe8ve1vKvvnO8+y4KfztH685A1OMCZ8FzcDADeSnPCpXUgtj208PaD09Vp8A3SENM5HV6Dh9FEZgy6qDhm2aB2bSugajYawsDD0ej1xcXEl9l+6dAmDwVBsfLo9OXbQC4Cn+98odX+3walotXDpjCsp15wx6DXUq7acUTOu4uFd8gOwz2jj9PId633Iz5Uauqg6JKFbx6YSOkD79u0B2L59e4l9pm0dOnS4p226V9Z+5ou+CB7qmMWwd67h5GzsjWs0Cs8OTOXlcUkYDLBslj8AGWmOZBc0wdlV4e//ScDFzTjWXOug8MKI63R75QZ5OVpWz7e/WbXCvikYx5Zb/JIaOlBODX3Pnj135Q3UJt9evXqxdOlSlixZQrt27Wj2xzrRJ06cYOnSpbi6utK/f/+70jZbE3vajbn/CGTsvxPoM/o6zw5M5eolF2r7F+JTuwh9EXz2XgCHd/5Zbrp8cwRBLuN47LkMWrY/xbU4F3wDCqleq4iCPA3ThoaQnOBSiVclhHqyHrp1ykzoI0aMQHOH6yNoNBpOnz6t6ph69eoxadIkZsyYwUsvvUTbtm0BiIyMpKioiNmzZ1OzZsnFq+zFtu9qEnvGjb6jr/PAw9mENM4nM82BXZuqs26xLzEnitfCdfrajH46gpffSqJVhyxCm+SRkebI9vU+rJlfh4QY10q6EiGsp/wxsUhNvCgnofv7+9/LdhQzYMAA/P39Wbp0KVFRUTg7O9OyZUtGjhzJI488UmntuldiTrgz8/Vgi+OTE1z4aFz9imuQqBDZuiZ09f+/ym6GTTKVUtTEi3IS+s6dO+9lO0ro1KkTnTp1qtQ2CCEqh+qJRZLQARsbhy6EECA9dGtZndDT0tI4dOgQly5dIjs7m0mTJlFQUEB0dDQPP/zw3WyjEOI+Iz1066hO6IWFhcyZM4fVq1dTWFho3j5p0iQuX77MkCFDaNy4MZ999pldPoRCCHEPKCpvdMpNUUDlOHSDwcDo0aP5+uuvKSoqomHDhlSrVs28PycnB61Wy+nTp+nXrx/p6el3vcFCCPsnqy1aR1VCX79+PXv37iU0NJTvv/+eTZs2FVu3/MEHH+Tnn38mPDycxMREli1bdtcbLISwf6omFckDLsxUJ3SNRsP8+fMJCwsrNSYwMJAFCxag1WorfaSMEKJqMj1T1OKX9NABlTX0CxcuEBoaSoMGDcqNCw4OJjg4mISEhDtqnBDi/qSorKHLxCIjVQldr9dbvGa5k5MTDg6yIJQQQj1jQpeZomqpKrkEBgZy6dIl0tLSyo1LTU0lJiaGwMDAO2qcEOI+pbZ+LjV0QGVC79q1K0VFRfzzn/8sNmTxVjqdjnfffRe9Xk+XLl3uSiOFEELcnqqSy5AhQ/j+++/ZsWMHPXv2pHPnzqSkpADwyy+/cPHiRTZu3Eh8fDx+fn4MHjy4ItoshLBzMrHIOqoSuoeHB19++SVjxozhzJkzxMbGmve9+eabgPFZn/Xr12fRokV2+VQhIUTFk5ui1lE9UzQgIID169fzyy+/sGPHDmJiYsjJycHNzY369evTsWNHnn32WZydnSuivUKI+4Cs5WIdq9Zy0Wq1dO3ala5du97t9gghhCR0K93RaotpaWnExcWRn5+Pl5cXoaGheHh43K22CSHuUwrqlme504rLzZs36datG9evX+fcuXMl9l+6dIkFCxZw9OhRbt68SVBQEH369GHAgAGlDuVOTk5m4cKFHDhwgJSUFPz8/OjevTvDhw8vtXqRmZnJf//7X7Zv305iYiK1atXiySefZMyYMXh6elp8HVYl9J9++olly5aVeBqRVquldevWjB49mtatW1tzaiGEMD9TVE38nZg+fTrXr18vdd/Zs2cZMGAA2dnZtGzZkgceeIDIyEj+9a9/cezYMebMmVMsPikpib59+5KUlESTJk1o2rQpUVFRzJ8/n0OHDvHFF1/g5ORkjs/Ozubll1/m3LlzhISE0LFjR06dOsWXX37Jvn37WLNmDV5eXhZdh+qHRE+ZMoXx48dz6tQpFEXB09MTX19fPDw80Ov1HDp0iFdeeYXly5erPbUQQhgpVrys9MMPP/DTTz+V3gxFYeLEiWRnZ/Pvf/+b1atX8+mnn7J161YaNmzIli1b2Lp1a7Fjpk2bRlJSEmPHjmXjxo3Mnz+fbdu28eijj/Lbb7+xYsWKYvFz587l3Llz9OnTh59++on58+ezdetWevToQUxMDHPnzrX4WlQl9C1btrBu3TqcnJwYO3Yse/bs4fDhw+zZs4cjR46wfft2hg4dikajYfbs2Rw6dEjN6YUQwugeTSxKTk5mxowZtGjRotSZ7QcOHODcuXO0adOGHj16mLfXqFGDadOmARRL0LGxsezevZugoCBef/1183Z3d3dmzpyJg4MD33zzjXl7ZmYma9euxdPTk0mTJpnLN46OjkydOpVq1aqxbt06cnNzLboeVQl99erVaDQaPvroI0aOHFlivfN69eoxceJEpk2bhqIoLFmyRM3phRAC+HPYopqXNd599110Oh2zZ88udf++ffsASp0k2bJlS2rWrMnRo0fJzs4GYP/+/SiKQqdOnUrU1v39/WnSpAlXr14lJiYGgMOHD5Ofn8/DDz9colbu4eHBI488Qn5+PocPH7boelQl9LNnzxIYGMgTTzxRbtyLL76In58fx44dU3N6IYQA7s3yuatWrWLfvn1MmDCB+vVLf8i6KfFGRESUuj8kJASDwcDFixeLxYeHh5cab1pu/Pz586riS7tRWxpVCd3R0RF3d3eLYn18fFBktL8QwhoKxjKKxS91p4+Pj+c///kPjzzyCAMGDCgzznSjtHbt2qXuN21PTU0tFu/r62tRvGmm/e3Of+PGjbIv5haqRrm0adOGXbt2cenSJUJCQsqMS05O5sKFC/JsUSGEVaydKZqUlFSiFu7t7V1s1rperzfXq2fNmoVGU3bvPi8vDwBXV9dS95u2m2rcauNN/+/m5mZR/O2o6qGPHz8ed3d3Ro4caf6q8FfJycmMHj0aR0dHxo8fr+b0QghhZOUol/79+9O5c+dir6+++qrYqZcuXUp0dDSTJ0/G39+/3GaYPhzKS/pgfDznvYi/nTJ76GPHji11e926dblw4QLdu3enVatWNGrUCHd3d/Ly8oiLiyMyMhKdTkf79u3Ztm0bjRo1sqghQghhYu049FWrVpXaQzc5e/YsCxYsoGPHjrz44ou3Pa+p55yfn1/qftN204RKS+NNpWu18bdTZkL/69jKvzIYDBw+fLjMu6979+5l37595kW7hBDCYlZOFa1bty4uLi5lhn3yyScUFhZSWFjIhAkTiu0z9YJN29955x18fX05c+YMqamppT6p7a81cFPt3FQjLyveFGdpfFk19r8qM6GPGTPGohMIIcTdVlFruZhq0QcOHCgzZsuWLQD8/e9/Jzw8nD179hATE0Pbtm3/8p4KsbGxODg4mJO9abRKWSVp02gY06gZS+MbNmx4+4tDEroQ4j7y11mat2rSpAl6vb7YEMH27duzdOlSduzYUWI0TFRUFGlpabRp08Y8hrx9+/YA7Nq1iwkTJhQbi37t2jXOnDlDQEAAYWFhALRu3RpXV1d+/fVXcnNzi5VWcnJy+PXXX3F3d6dVq1YWXZ/qqf9CCFHh7uHU//K0adOG8PBwDhw4wHfffWfenpaWxvTp0wHjg39MAgMDad++PbGxscybN8+8PTc3lylTpqDX64vFu7u707NnTzIyMpg+fTpFRUUAFBUVMWPGDDIzM+nbt6/FC3RZtTiXXq8nOTmZvLy8EmPNi4qK0Ol0XL9+nZ07dzJr1ixr3kIIcV/T/PFSE3/3mYY2vvLKK7z33nusW7cOX19ffvvtNzIyMujTpw+PP/54sWOmTp1Kv379WLx4MTt37iQkJISoqChSUlJ47LHH6NevX7H4cePGERkZyaZNmzh69ChNmjTh9OnTJCQk0LRpU9544w2L26s6oS9ZsoQlS5aQlZVlUbwkdCGEavd6/dxyNG/enLVr1zJ//nwiIyO5cOEC9evX56233ip1pExgYKA5fu/evcTHxxMYGMigQYN45ZVXcHQsnnarV6/OmjVr+PTTT9m+fTu7du3Cz8+PV199lddff13VkuSqEvq2bdv46KOPLIoNCgriqaeeUnN6IYQwqoSE/tflwG8VFhbG/PnzLT6Xn58fH3zwgcXx1atXZ8qUKUyZMsXiY0qjqoZuqiF169aNPXv2cOjQIRwcHOjTpw8nTpzgl19+YcSIETg4OGAwGHjttdfuqHFCiPuUqmn/1q+2aG9UJfTTp0/j5ubGtGnTqFOnDtWrVycsLIwDBw7g5OREYGAg48aNY+zYsVy9erXEDC0hhLDEvVpt0d6oSuiZmZkEBgYWq+mEh4dz7do1MjIyzNsGDRqEq6srO3bsuHstFULcXyp5hEtVpCqhu7u7l1hzIDAwEPhzADwYF5QJDg4mPj7+LjRRCHHfkZKLVVQl9MDAQBISEoqt/FW/fn0UReHMmTPFYvPz881jKoUQQg2Nov4lVCb0du3akZuby3vvvWd+QscDDzwAwPr169HpdAAcP36cuLg4AgIC7nJzhRD3BRuZWFTVqErogwYNwsfHh59++on27duj0+lo0KABbdu25cyZM/Tq1Ys333zTPBOqXbt2FdJoIYSdk5KLVVQl9Jo1a/LFF1/QuHFjnJ2dcXZ2BozP5fP29iYmJoZt27aRk5ODv78/o0aNqpBGCyHsnPTQraJ6pmjjxo3ZsGEDiYmJ5m0RERH8+OOPrF+/nqtXrxIcHMyLL76Il5fXXW2sEOI+YUMzRasSq9ZyAeNMqFvVqlWLESNG3HGDhBBCErp1rE7oQghRcdTWxaWGDuUk9N69e9/xyTUaDWvXrr3j8wgh7i9qhyLKsEWjMhP6yZMn7/jkt3vwqRBCiLunzISuZqUwIYS4q6SGbpUyE/rzzz9/L9shhBDiDt0fN0UV7Hs5Nju+tq3Xfq/sJlSY6Kv2e30FRbU5nWz98VJDt879kdCFEFWLgrpRLpLQAUnoQghbJDV0q0hCF0LYHknoVpGELoSwOVJDt44kdCGEbZIkrZokdCGE7ZGSi1WsTuh6vZ5Tp04RGxtLdnY2L7/8MoWFhSQmJhIUFHQ32yiEuM9IycU6ViX0r7/+ms8//5wbN26Yt7388sskJCTw3HPP0aVLF2bNmoWnp+dda6gQ4j6i9qEV8oALwIqE/u6777JhwwYURaFatWrodDry8/MBSE1NxWAw8Msvv5CQkMCqVatwc3O7640WQtg5KblYRdUTi7Zu3cr69eupXbs2S5YsITIyksaNG5v3t2nThhUrVlC7dm3Onj3LV199ddcbLISwf/KQaOuoSuirV69Go9Ewb9482rdvX2pM69atWbhwIYqi8L///e+uNFIIcZ+RR9BZRVXJ5fTp0wQGBtKiRYty4x544AHq169PfHz8HTVOCHGfUtvrloQOqOyhFxQU4O7ublGs3BAVQtwR6Z2rpiqh+/n5cenSJXJzc8uNy87OJiYmhrp1695R44QQQlhOVULv1KkTBQUFfPjhh+XGzZo1C51OR4cOHe6ocUKI+5TU0K2iqoY+fPhwNm/ezNq1a7l8+TJPP/00GRkZgLG+fvHiRb777juOHDmCt7c3Q4cOrZBGCyHsm0wsso6qhF6jRg2WLFnC6NGjOXToEJGRkeZ9L7zwAgCKouDj48OCBQuoU6fO3W2tEEKIMqmeWNS0aVN++OEHvv32W3bu3ElMTAw5OTm4ublRv359OnbsSP/+/alRo0ZFtFcIcT+QiUVWsWrqv6enJ8OGDWPYsGF3uz1CCCElFyvJaotCCNsjPXSrqEromzZtUv0GPXv2VH2MEOI+JwndKqoS+uTJk9FoLFvVTFEUNBqNJHQhhGpScrGOqoTepEmTMhN6fn4+qampZGRkoNFoeO655+TGqBDCepKkVVOV0Dds2HDbmCNHjjB58mROnjzJunXrrG6YEOL+JT1066iaKWqJhx56iHnz5hEXF8fChQvv9umFEPcDmSlqlbue0ME4Vj00NJRt27ZVxOmFEPZOErpVKmzYooODAykpKRV1eiGEHZOSi3UqpIceFRVFTEwMtWrVqojTCyHsnfTQraKqh75y5cpy9+t0Oi5dusSWLVsA6Ny5s/UtE0Lcv2QculVUJfT333/fonHoiqIQFBTEqFGjrG6YEOL+JSUX66hK6K1bty7/ZI6OeHt706JFC3r37i1PLRJCWE+StGqqEvqKFSsqqh1CCCHukKqbokOHDmXy5MlkZmZWVHuEEMJcclHzEip76MeOHcPT0xNvb++Kao8QQshNUSupHoderVq1imiHEEL8SRK6VVSVXLp3786FCxfYsWNHRbVHCCEA0Kh4CSNVPfTu3btz5swZxowZw4MPPsiDDz6Ir68vzs7OZR4zYMCAO26kEOI+Iz10q6hK6P369UOj0aAoCtHR0fz++++3PUYSuhBCLRmHbp27Og5dCCHuCumhW6XMhH7t2jVcXFyoWbOmeZuMQxdC3BOS0K1S5k3Rxx9/nLFjx97LtgghBPDHzU4149Aru8E2otySi6LIx54QohJID90qFbYeuhBCWEtuilpHEroQwvZID90qktCrII1G4an+aTzZN42GfkP5/mI+l2Nc+XllDX74uiZSUby7DAb4eVVNtn1bg/jzrhQVaggKy+epATd4btANTCtKr5hTl28+rmvROZ/ok0bnf5Qf8+0CX774wJ8n+qQxYe7lUmPizrqyel4djh30JDfLgTpBBbR7JoPnh6fg7aNXc5k2RXro1ik3od+4cYNNmzbd0Rv07Nnzjo4XxTm5GJj2RRwPdcpCrwedPoDMG9cJfyCP8A+v8sAjOXwwMghJ6neHLl/DtKEhHN3tjVarUC8sn/wcB2JOuvPp2+6c+NWTtz+LR6MB3wAdTVtnl3mugjwtMSfdAfCrX1Du+ybEuPDNJ+V/OBz8XzVmjapPYYEWFzc9QRH5pFxzYtXcumxfW4NZqy8SGFb++9gs6aFbpdyEHh8fz9tvv231yTUajST0u2zYu4k81CmL61ed+OegEEZ8PZ3JbT6kbZdM3v4sno49bhL5izc7N/hUdlPtwrKZ/hzd7U1tfx0zvo4ltEk+AId+8eaDkfXZ870PbZ/IpPML6XTtl0bXfmllnuuT8YHEnHSn+aNZvPRmMseTSo8zGODjtwLR5Ze9MkfSZWdmvxFEYYGWR5+6yfhPEvCspkevh28+qsuquXWZ8nIoS3afxdm1CmY7SehWKTehOzs7FxuHLipX3aACug9OpagQpgwIJf68q3lf5HZv1v+3Ni+/lUzXl9Ikod8FifHOfL+8Fg6OCv9aGUtww3zzvoefyOSFESms/KQuW9fUoPML6eWe6+DP3vy8uiYe3nr+Me8yDg5lx27+ohanj3ji4mqgoIykvv6/tcnPdSAoIo93Fsfj5GzMaA4O8MrEJE7+5sHxg15sWlabPqOvq7/4SnYvSi56vZ7Vq1ezceNGYmNj0ev1BAYG8swzz/Dqq6/i4uJSLP7EiRMsXLiQEydOkJubS1hYGIMGDaJbt26lnv/SpUssWLCAo0ePcvPmTYKCgujTpw8DBgxAqy35e01OTmbhwoUcOHCAlJQU/Pz86N69O8OHDy93eZVblZvQmzVrdtvniN4LGzZs4O2332blypU89NBDld2cStOp500cHGHbtz7FkrnJtjU1KCzQcP2qZb98Ub5dm3ww6DU80edGsWRu8uRLaTi5GPANKCz3PAV5Gha+Ww+AIZOvlRufGO/M8g/9qBtUwEOdsvjhq9IftB61xwuA7kNSzcn8Vt0Hp3L8oBc7N/pUyYRe0fR6PaNGjWL37t24u7vzf//3fzg6OnLs2DHmz5/Pnj17+Oqrr3BzcwPgwIEDjBgxAoPBQOvWrXFzc+PXX39lwoQJxMTEMG7cuGLnP3v2LAMGDCA7O5uWLVvywAMPEBkZyb/+9S+OHTvGnDlzisUnJSXRt29fkpKSaNKkCU2bNiUqKor58+dz6NAhvvjiC5ycnG57XTZ/UzQ6Opr333+/spthEx5sZ6zPHtxa+hLGyVecWbOgzr1skl37fb/xEYqPdi39gS51A3X0e/P2yXLDktqkJjoT0jiPZwfdKDd27j8Cyc91YOy/L3FkV9nPHbh+zfihHf5AXqn7/UOMtfP4s67k52pwda+CNYkKbPLatWvZvXs3DRs2ZMmSJdSpY/x3k5aWxqhRo4iOjmbRokWMHz+e/Px8/vEP4x3sL774gocffhiAy5cvM3DgQBYvXswTTzxBs2bNjM1WFCZOnEh2djb//ve/6dGjh/ncgwcPZsuWLTzxxBN07drV3J5p06aRlJTE2LFjzc9izs3NZfTo0Rw8eJAVK1YwdOjQ216XquVz77WtW7cybNgwcnNzK7spNiG4kbGXmHDBBXcvPc+/mkJIjY+Ztfoir0+/SlB4yV6ksF7cWeO3oMDwfHIytWxYUpsZw4J5+6VQPvtnAPHnXW5zBshMd+C7hcZkMXhyIqV80zb76Zua/L7fiyf73qDlY2XfXL2Vvqj0m9+m7QaDhtTEqveNTaMoql9qbNy4EYB33nnHnMwBatSowbRp0wD48ccfAdi8eTM3btygW7du5mQOEBQUxIQJE4Diy6IcOHCAc+fO0aZNG3My/+u5b42PjY1l9+7dBAUF8frrr5u3u7u7M3PmTBwcHPjmm28sui6b7KEnJSXx8ccfs3nzZtzc3KhVqxapqamV3axK5eRioHqtIgBq+xfy4bex1PYvBK7RqgO06pBNt8GpfPp2Pf63Su573CldvoaMG8avuCnXnJjct0GxxBi1F7Ysr8WYDxJ4ZkDZN0L/901NcrMcCG6Ux8NPlP3oxpRrTix53x+f2oW8NvXabdtXN1DH5QuuXDrrStM2OSX231qSy84op2Bvqyr4pqiPjw+hoaE0b968xL7g4GAArl83fvvat28fAJ07dy4R26lTJxwcHNi7d695mym+S5cuJeJbtmxJzZo1OXr0KNnZ2Xh6erJ//34URaFTp04lauv+/v40adKEEydOEBMTQ1hYWLnXZZM99Llz57J582aaNWvGt99+S2hoaGU3qdK5exjMf568KB5dvoZ3+4fw+9WvGNCqMev/WwtHJ3hj9hX+729ZldhS+5Cb8+c/jQ9HBePsqvCvlRfZEnuMb46cotdr19EXaVgwKdBcmvkrvR5++NpYA+/9evmlmfmT6pGb5cDomVfwqn778eNtu2QAsG6xL7qC4r10gwHWL/Y1/72wsOoNYa3oZ4ouXryY//3vf7i7u5fYd+LECQDq1jUOG71w4QIAERERJWI9PT3x9fUlLS3N3OmMiYkpMx4gJCQEg8HAxYsXi8WHh4eXGm/Kf+fPn7/tdZWZ0MeMGUOvXr1ue4KKEBoayuzZs1m7di0NGzaslDbYGmfXPxO6q7uBt/uFcmS3NwrOpCY68/n0AHasr46DAwyZXMZ4OGGxW4cM5udq+WD1RVp3ysLZVaG2fyEjpl3j8V5pGAwavvzQr9RzRG6rxvWrztSoU0in58seBbN9nQ+/7ajGo0/dpP1zGRa17/nXUvD2KSIxzoUpL4cSc8KNokLj+PX3Xw3m6iUXXP74b8bRsYrWz9W+7sbbKgrz5s0D4MknnwQgJSUFgNq1a5d6jGm7KaGbevZq4319fS2KL0+ZJZcxY8bc9uCK8tprr1Xae9uqW4ev7VjnQ3JCyfrtmvl16PzCTRq3yqVazUJzyUCo53LLB2jn3mnUDdKViHnpzWR2bqjB2SgPbqY6mktiJvt+NN68fqzbTRzL+FWkpziyeGoAHt56xsy6YnH7atYpYtryWKYODuXYAS9Gd/2z4+PmoeftRXF8Mj6Ignwt7l5VcMao2l73H7FJSUk4/GVMqLe3t8UPtv/44485fPgwtWrV4tVXXwUgL89449nVteTIslu3m+71VXR8eWyyhi5Kys3SYjCAVguXzriVGnMl1oWiQnB0grqBktDvhLuXAY1GQVE0hDQu/WZzvdACHBwV9EUakhKciyV0vR4O/zFK5bFuZffOP32nHlnpjoz9dwI16xaVGVeapq1zWbr3DD8sr8XZaA8Awh7I5ZkBN/DxLSI705jYaviqO69NsLKG3r9//xI92TFjxvDGG2/c9hTz5s3j888/x9nZmblz51KjRg0AHBwcUBQFjab80pXBYDDHAxUWX577IqFP+n5kZTfhrig0jMVFe50eE5/kb6OfNG//8PDkP/5kQOs4CNAzavkQ8gpDKqWdd1P01cp7bx//xaRdvcmVm0OIvtqqxH6D3gDMAQzEpM8i7+qfU/UvRSeQlb6Sar5eFPgtI/pq6f9Y9/9YHYB5EwOZNzGw1JhfvqvBL9/VoLqfN5O/H1Vif9OXjC+Tq0Dk3iQM+uV41/YkJmcllLxvatOsnVi0atWqUnvo5SkqKmLGjBl8++23uLi4sGDBgmJPZ3NzcyMzM5OCgoISk40A8vONH/geHh7m+Fu336340ur9f3VfJPTZ3T8jPdGy2qQtm7xIR6eecGbrJj4aFwUYk/nk1h8CxpmkXx0yTv9+t8NKsjOq/q9367XfK+29mz9Un91XfciNX0OLgP+U2J8Y74y+qAlarUKHluOL3cy8sMkX8KdVu3ha1utX6vmjr64pd+2X5CvG+yPVaxUSEFJAjTo3aRFgzNwnIj04F+1OszY5NGpZ8qv4qTV1AD9atbtsPuZeKiiqzenkBXd2Eivq4nXr1i016ZYlJyeHsWPHsm/fPry9vVm0aFGJR236+vqSmZlJSkoK9erVK3GOv9bYfX19OXPmDKmpqTRo0MCieCi7Rm6KL6vGfiubHOUiSrfn++oAtHs2g5p1S8427D7YOGnlxK+edpHMK1uH7jcBYy86NbFk+er75cYRLA88kl1iZMrFk8ZeV1gZE39MPt4cU+bL9P6tH8/i480xTPk8znzc2Sh3lswIYMPnJW+85WRp+XGFsW3P3WYik62q6FEuABkZGQwcOJB9+/bh5+fHypUrS31usmn0iWlUyq2ys7O5fv06NWrUoFatWsXiTaNXbqUoCrGxsTg4OJiTfXnxt75vWaNmbiUJvQo5tNWb00fccfc0MOPr2GIr9nXonk63IcZP+NXzb/9JLm7v4a4ZNG6VQ16OA/8cFMK1uD/Hoe/eXJ0tXxr/Afd7M7nEsbGnjQm9filLBtwNjz6VgZOzgb1bqrNrY3Xz9rTrjkwfGkLadSfadM6gWdsqVmsxUQBFUfFSd3qdTsdrr73GqVOnCAsLY82aNWUmzPbt2wOwffv2Evt27tyJXq+nQ4cOJeJ37NhRIj4qKoq0tDRatWqFp6dnsfhdu3aVqJNfu3aNM2fOEBAQcNsx6CAJvUpRFA3/ei2YhBgXwprls2zfWRr5TmT5r2d4Z/FlnF0Uls+uy+/7vSq7qXZBq4Upn8dRr0E+F0+5M6x9Y17v3JBXHm7MByODKdRpeWViIi3alyybpF03fkPyrFYxI0wCQnQMf+8aiqLhw9HBDGrbmFFPRDCoTROOHfAivHkukxfFV8h73wsV3UOfP38+v//+O35+fqxYscI85rw0Xbt2pWbNmmzcuJE9e/aYtyckJPDRRx+h0WgYPHiweXubNm0IDw/nwIEDfPfdd+btaWlpTJ8+HYAhQ4aYtwcGBtK+fXtiY2PNQybBOKplypQp6PX6YvHlke/lVcyNJCdGd43ghREpdOh+k6CIZNw89RzZ5cWGz2txdI9lw7OEZWr5FbJw6znW/9eXPd9X59olF1zdDbTqmEmv11J4qGPJSVx6PeT8McLEowKHDPYYlkot/0I2LqlNzAk30pKd8A8poNPz6fQanoKLWxUcf25SgTNF09PTzVPva9SowaxZs8qMnTNnDp6enrz//vu8+eabjBgxgtatW+Ph4cGhQ4fIy8tj3LhxNGrUyHyMVqtl1qxZvPLKK7z33nusW7cOX19ffvvtNzIyMujTpw+PP/54sfeZOnUq/fr1Y/HixezcuZOQkBCioqJISUnhscceo1+/0u/D/JVGqQJPgh44cCC//fab6tUWCwoKOHnypN3cFC3NrTdF7VFl3hStaNFX11TKDct7wXRTtFmzZqpuUpr+zU5dfIi0TMvLVTW8XZn++sMWvd+2bdssGsYIcO7cOfOfo6KiWLhwIceOHUNRFMLCwhg8eDBPP/10qcfGxMQwf/58IiMj0el01K9fn5deeokXX3yxxEgcgMTERObPn8/evXvJysoiMDCQHj168Morr1j8M5QeuhDC9lRgD/3JJ58slqgt1bJlS5YtW2ZxfFhYGPPnz7c43s/Pjw8++EB1u25VJRL6rSuTCSHsnwaV49ArrCVVi9wUFUIIO1EleuhCiPuMaTiimnghCV0IYXvuxTNF7ZEkdCGE7angB1zYK0noQgibIz1060hCF0LYHqmhW0USuhDC9lj5gIv7nSR0IYTtkRq6VSShCyFsjkwsso4kdCGE7TEoxpeaeCEJXQhhg6TkYhVJ6EIImyPDFq0jCV0IYXtk2KJVJKELIWyO9NCtIwldCGF7pIZuFUnoQgibo0FBo6KMopGMDkhCF0LYIsMfLzXxQh5wIYQQ9kJ66EIIm6NRVJZcZJQLIAldCGGL5KaoVSShCyFsj4xDt4okdCGEzZFx6NaRhC6EsD0KKnvoFdaSKkUSuhDC5mgU0KgYiig9dCNJ6EII2yM1dKtIQhdC2B4Z5WIVSehCCNujchy69NCNJKELIWyPlFysIgldCGF7ZC0Xq0hCF0LYHFlt0TqS0IUQtkdKLlaRhC6EsD2S0K0iCV0IYXukhm4VSehCCJsjy+daRx5wIYQQdkJ66EII2yOLc1lFEroQwvbITVGrSEIXQtgglQlduuiAJHQhhC2SUS5WkYQuhLA5MsrFOpLQhRC2R2roVpGELoSwPQbF+FITLyShCyFskPTQrSIJXQhhg2SUizUkoQshbI9MLLKKXSd05Y//ILx9vSq5JRXLx69aZTehwhQU1a7sJlQoe70+nb4G8Oe/QdWkhm4Vu07ohYWFAIxc+nIlt6RiTfp+ZGU3ocKcTq7sFlSs08kLKrsJFaqwsBBXV1f1ByoG40tNvLDvhO7h4UFERAROTk5oNJrKbo4Q9w1FUSgsLMTDw8PaE8hNUSvYdULXarV4edl3uUUIW2VVz9xESi5WseuELoSoqmSUizUkoQshbI+UXKwiCV0IYXtk2KJV5IlFQghhJ6SHLoSwPQaD8aUmXkhCF0LYIKmhW0USuhDC9khCt4rU0KuogwcPMmjQINq2bUvLli0ZOHAge/furexmCZU2bNhAw4YNOXLkSGU3xbYoyp9j0S15SUIHJKFXSRs2bGDIkCFER0fTvHlzWrRoQXR0NMOHD+fbb7+t7OYJC0VHR/P+++9XdjNskqIYVL+ElFyqnOTkZKZOnYqXlxerVq0iIiICgOPHjzNkyBBmzpxJx44dqVOnTiW3VJRn69atvP322+Tm5lZ2U2yTAZUzRSusJVWK9NCrmJUrV6LT6Rg8eLA5mQM0b96c4cOHU1BQIL10G5aUlMTEiRN58803MRgM1KpVq7KbZJtMNXQ1LyEJvarZt28fAF26dCmxz7RNaum2a+7cuWzevJlmzZrx7bffEhoaWtlNsk2mYYtqXkJKLlWJoijExMSg1WpLTQTBwcFotVpiYmJQFEVWmLRBoaGhzJ49m+7du6PVSn+qTDLKxSqS0KuQjIwMdDodNWrUwNnZucR+R0dHfHx8uHHjBjk5OXh6elZCK0V5XnvttcpuQpWgKAYUFb1uuSlqJF2EKiQvLw8ANze3MmNMS5bm5OTckzYJUSGkhm4V6aFXIWq+olv96C8hbIGMcrGKJPQqxN3dHYCCgoIyY/Lz84vFClElySPorCIJvQrx9PTE3d2d9PR0ioqKcHQs/usrKioiPT0dFxcXvL29K6mVQtw5xaCgqOihq4m1Z1JDr0I0Gg1hYWHo9Xri4uJK7L906RIGg6HY+HQhqibDn710S15ScwEkoVc57du3B2D79u0l9pm2dejQ4Z62SYi77o8euqUveaaokST0KqZXr164uLiwZMkSTp48ad5+4sQJli5diqurK/3796/EFgohKovU0KuYevXqMWnSJGbMmMFLL71E27ZtAYiMjKSoqIjZs2dTs2bNSm6lEHfGu7anqqGI3rVlzgVIQq+SBgwYgL+/P0uXLiUqKgpnZ2datmzJyJEjeeSRRyq7eUJYzcHBAQcHB0YufdnqY+9nGkUGLAshbEhRURF6vV71cQ4ODiVGft1vJKELIYSdkJuiQghhJyShCyGEnZCELoQQdkISuhBC2AlJ6EIIYSckoQshhJ2QhH4PXLlyhYYNG5b6atSoEc2bN+exxx5j5MiRpa7RUhnOnz9vbuOtJk+eTMOGDZk9e/Ydv0dqaiqZmZl3fJ7b+eabb2jYsCEDBw60KH7Dhg00bNiQXr163fF7L1iwgIYNG/Lmm2/e8blu5/HHH6dhw4bs2rWrwt9L2Kb7exR+JWjWrFmxx8cpioJOp+PKlSvs3LmTnTt30r9/f6ZOnVqJrax4y5cvZ8GCBaxevVqW+hXiLpGEfo/NmzePevXqldheWFjIp59+yuLFi1m1ahXt27fn8ccfr4QWlu+tt95i+PDh+Pj43NF5Pvjgg7vUIiGEiZRcbISTkxPjxo2jRYsWAKxataqSW1Q6X19fGjRoQI0aNSq7KUKIv5CEbmM6deoEGJfDFUIINaTkYmM8PY3LgObk5Ji3LViwgE8//ZSJEyfi5ubGZ599RkZGBkFBQSxcuJD69esDkJCQwJIlS9i/fz/Xr1/Hw8ODBx98kMGDB5e5CmNKSgpLlixhx44dpKSkEBAQQL9+/WjTpk2p8ZMnT2bjxo0MHTqUSZMmFduXkJDA119/zZ49e0hKSsLV1ZUHHniAIUOG0K5du2LXYtKtWzcAvv76a/NSwACHDx9m+fLlREdHk5mZSc2aNfnb3/7GiBEjzNf7V2fOnOGzzz4jKiqK7OxsGjduzMiRI8v9eauVmprKihUr2LdvHwkJCeTl5eHl5UWTJk3o06cPXbt2LfPY2NhYPv74Y/NSx40aNaJfv35079691Pjs7GyWL1/O1q1buXz5Mg4ODkRERNCrVy9eeOGF+35lQVGSJHQbc/nyZQD8/PxK7Nu2bRu///47AQEBBAQEkJubS2BgIAD79u3jzTffJDc3Fzc3N8LDw0lLS2P37t3s3r2bN954gzFjxhQ736VLlxgyZAiJiYm4uroSHh5OcnIyM2fO5KGHHlLV7gMHDjB27FiysrJwd3cnLCyMlJQU9u/fz/79+5k5cya9e/fGz8+Pli1bEhUVBUCTJk1wdXXFy8vLfK5FixYxb948AHx8fIiIiCAhIYH169fz008/MW/evBJPZfrll19466230Ol0+Pj40KBBA86ePcvw4cNp1aqVqmspy5kzZxgyZAjp6em4u7ub74UkJCSYr3P8+PG89tprJY69dOkSffr0IScnh/DwcHJzc4mKiiIqKopDhw4xa9asYvFXrlxh6NChxMfH4+joSHBwMAaDgejoaKKjo9m2bRuLFi0qdoNdCBRR4RISEpSIiAglIiJCSUhIKDPu5s2bysMPP6xEREQo77//vnn7/PnzzcfPnDlTMRgMiqIoyo0bN8znb9mypRIREaHMnTtXKSgoMB+7fft2875ffvnFvN1gMCh9+/ZVIiIilKFDhyrp6emKoiiKXq9Xli1bpjRs2ND8nreaNGmSEhERoXz44YfmbTdu3FDatm2rREREKFOmTFGys7PN7/Hll18qERERStOmTYtdu+nc586dK3b+rVu3KhEREUrLli2VH3/80bxdp9MpCxcuNO+7evWqeV9qaqr5Gv/zn/8ohYWFiqIoSnZ2tjJu3Djze7388stl/uxvtX79eiUiIkJ5/vnni21//vnnlYiICOXvf/+7kpWVZd6elZWljB8/XomIiFBatWql6HQ6875bf3dPPPGEEhMTY973888/K82aNVMiIiKUH374wby9qKhI6dmzpxIREaG8/vrrSkpKinnfhQsXlKefflqJiIhQ/vWvfxVrX6dOnZSIiAhl586dFl2nsD9SQ69kiqKQmZnJ3r17efXVV0lLS8PLy4thw4aViHVycmLs2LFoNBoA843JL774guzsbHr27MnYsWOL9do6d+7M+PHjAYqVOo4cOUJ0dDTe3t588sknVK9eHQCtVsvQoUPp0aOHxdfw3XffkZ6ezoMPPsiMGTPw8PAAjA+1Hjx4MB07dqSwsJCffvrptueaP38+AO+88w7PPPNMsWsfNWoUTz/9tLkUYbJ69Wqys7Np06YNEyZMMK+J7eHhwYcfflhmiUaNa9eucfXqVVxdXZk+fbq5NAbGMtmECRMAyMrKIjk5ucTxGo2GBQsW0KBBA/O2rl27mktCy5YtM2//5ZdfOH36NCEhIcydO5datWqZ94WFhTF37ly0Wi2rV6/mxo0bd3xtwn5IQr/HOnfuXGJiUevWrRk+fDjHjx/Hx8eHRYsWlVpyiYiIMCfLW+3cuROAZ599ttT3fPbZZ9FoNJw5c4aUlBTAWKIB4wOlSxsH3rt3b4uvaffu3QA8//zz5g+bW02fPp3t27fz6quvlnuey5cvc+HCBbRabbFkfqvnnnsOgL1795q37d+/H6DUWrSzs3OZNWo1/P39iYyMJDIystSfl6urq/nP+fn5Jfa3atWqxCQtgBdeeAGAU6dOmZPzjh07AOjSpQsuLi4ljomIiCAiIoLCwkIOHTpk3QUJuyQ19HvsrxOLtFot7u7u1KlThxYtWvD000/j7u5e6rG1a9cusS07O5vExEQAPvnkEz777LNSj3VwcKCoqIhLly5Ru3Zt4uLiAGOPrzSlJZ+yJCQkABAeHl7q/rp161p0npiYGODPbwmlMSXL+Ph4FEVBo9GYr+XW3u+tGjVqZNH7W8LV1ZWLFy9y/Phx4uPjSUhI4MKFC+a2AxgMhhLHNW7cuNTz1alTBy8vL7Kysrh06RI1a9bk4sWLAPz8888cPXq01OOSkpIAY21eCBNJ6PdYWROLLFFab+3W0TCnT5++7TmysrIA4wcBgJubW6lxXl5eaDQaFAseaHXz5k2AUr89qGFqU1FRkfmmaVkMBgM5OTl4enqajyvrg/DWG6534ty5c8yaNatErzggIIBevXqxdu3aMo8tq22mfVlZWeYPK9P1JCQkmD8sy2L6fQoBktCrvFsT8q+//mrxhB9T2SA3N7fU/QUFBRYlczD2WrOzs8s8l6VMSS88PJwffvjB4uO8vb25ceNGsQ+3W5VWAlErJSWFQYMGcfPmTRo1akTv3r1p3LgxDRo0wMfHB51OV25CL+9nY2q36Xdi+p3OmzePp5566o7bLu4fUkOv4ry9vc1JPDY2ttQYvV7PwYMHiY+PNz98NyQkBDAOxSuN6Wu/JYKDg8s9ZteuXQwYMKDYTdnSmG5eXrlyBZ1OV2pMamoqR44cKXbj0XQtZ8+eLfWYsn4uaqxfv56bN2/SoEEDvv32WwYOHMhDDz1kXgKhtBuhtzKVhf4qISGB7OxstFotoaGhwJ8/h/LaHR0dzfnz5+/Kh5WwH5LQ7YBpTPaaNWtK3b9lyxaGDBlCz549zT3Fzp07A8abi6Ulo40bN1r8/qZJQ5s3by7z/Y8cOUJGRoZ5m+nm6a3fAsLCwggICCAvL6/Mc3300UcMGDCAcePGmbeZrmX9+vUl6tcGg6HMc6lx9epVAEJDQ4vdADVZt26d+c+lPbE+MjLSfK/jVqtXrwbgoYceMo+c6dixIwCbNm2ioKCgxDEJCQm8/PLLdOvWjejoaPUXI+yWJHQ78Oqrr+Li4sKWLVv45JNPiiWBffv2MWPGDABefPFFcz25WbNmdOrUiby8PMaMGWO+yQawdu1aVWvJDBgwAG9vbw4fPsysWbPM768oCitWrODHH3/EycmJAQMGmI8xlVeuXbtm3qbRaBg1ahQAs2bN4scffzTvKyoqYunSpWzYsAGg2E3TPn36UKdOHU6dOsV7771n7rUWFBQwbdq0Mr+FqGH6FnLgwAGOHz9u3p6Xl8fnn3/OkiVLzNtKS8I6nY4xY8YU+/Bcu3Yty5cvR6PRMHr0aPP25557juDgYOLj43njjTfMI5PA2NMfNWoURUVFNG7cuMwZwOL+JDV0OxAWFsbs2bOZOHEiixcvZsWKFYSEhJCenm7uWT766KPmsdIm77//PkOHDuX48eN06dKFiIgI0tLSSExMpFOnThavq+3r68vHH3/MG2+8wVdffcWGDRuoX78+iYmJ3LhxAwcHB2bMmGFOimAcRRMVFcVbb71FaGgo48aNo127dvTu3ZsLFy6wfPly3nrrLT744APq1KnDlStXzDdfR48eTZcuXczn8vT05JNPPmHEiBGsW7eObdu2Ub9+feLj48nMzFR1LWV58cUXWblyJVevXqVPnz4EBwfj6upKfHw8ubm5BAQEoNVqSUhI4Pr16yWOb9++PYcPH6Zz586Eh4eTnp5u7rFPnDiRhx9+2Bzr7OzMwoULGTZsGHv27KFjx46EhYVRWFhIXFwcer2eunXrsmjRoju6JmF/pIduJ55++mk2bdpE7969qV69OufOnSM9PZ0HHniAd955h88//7zENPHatWuzatUqRo8eTUBAADExMWi1WsaMGcOcOXNUvX/79u3ZvHkzvXv3xtPTk3PnzqHX6+nSpQurV68u8bCIWbNm0bZtWxRFIS4ujvj4ePO+t99+m2XLlvH4449jMBjMtfF27dqxaNGiUh8W0apVKzZs2ECvXr1wd3fn/PnzBAQEMGfOHPr376/qWkrj7e3NunXrGDhwIMHBwVy9epX4+Hjq16/PmDFj2Lx5M08//TRAqR8eTZs2ZfXq1bRt25a4uDgyMzN59NFH+fLLL0udRBYWFsbmzZsZOXIkoaGhxMXFcfnyZYKCghg6dCgbN27E39//jq9L2BeNYulQBiGEEDZNeuhCCGEnJKELIYSdkIQuhBB2QhK6EELYCUnoQghhJyShCyGEnZCELoQQdkISuhBC2AlJ6EIIYSckoQshhJ2QhC6EEHbi/wERCrNY66Sl2gAAAABJRU5ErkJggg==\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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\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.999659511472983\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>97.5</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>97.5</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      97.5   50.0   20.0    10.0  6.666667     5.0\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   97.5   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
}
