{
 "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 CP3A4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 12304/12304 [00:01<00:00, 6926.62it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_cp3a4/'\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.9631901840490797"
      ]
     },
     "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": "iVBORw0KGgoAAAANSUhEUgAAAWcAAAE+CAYAAABROdGyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABDKElEQVR4nO3deVxU5f7A8c/MsG8KCAoIIsKgpuaS2u2XpWnXrGwxI5c0tdTcr+nV1ptmWnYtc83r0mZq5paZ3dQ0lyzNhdTcUUBcQBBlh4GZ8/sDmeQyAxwEGYbv+/ea1+v+znnOOd8j8eWZ73me52gURVEQQghhU7TVHYAQQoiSJDkLIYQNkuQshBA2SJKzEELYIEnOQghhgxyqOwAhhLhVQUEBRqNR9XE6nQ4HB/tJafZzJ0KIGq+goIA/j+7FqHioPlan09GiRQu7SdD2cRdCCLtgNBoxKh40qfcvnHSp5T7OYPThXMo7GI1GSc5CCFFVdNoUdLrk8rdXTFUYTfWQ5CyEsDkmFEyUf/KymrY1hSRnIYTNMd38PzXt7Y0kZyGEzTEpCkYVy/6Y7HCJIEnOQgibY0JdqaIi/Waj0ciKFStYu3YtsbGxuLq60qJFCwYOHEjnzp1LtI+NjWXevHkcOnSIGzduEBISQlRUFP3790erLTllJCkpiQULFrB3716Sk5MJCAjgiSeeYOjQoTg5OZUZn0ZWpRNC2Iq8vDz+/PNPgvyG4uhwtdzH5Rf4cyl5CS1atMDZ2blcx0yaNImNGzfi4eFBu3btyM/P58CBA+Tn5zN27FhGjRplbnvq1Cn69+9PZmYmbdu2xdfXl/3795Oenk7Pnj2ZNWtWsXMnJiby3HPPkZiYSPPmzQkODubw4cMkJyfToUMHPv30UxwdHUuNT3rOQgibo6h8IKiofCD4ww8/sHHjRho3bsxXX31FvXr1ADh79ix9+/Zl/vz5PPbYY4SGhqIoCpMmTSIzM5MPPviAJ598EoDU1FQGDRrEpk2bePjhh+nevbv5/FOmTCExMZFx48YxcuRIALKzsxk1ahS//vory5cvZ8iQIaXGKNO3hRA2x3iz5qzmo8Z3330HwMSJE82JGSAiIoKePXtiMpnYu3cvAHv37uX06dN06NDBnJgBfHx8mDJlCgDLly83bz9//jw7d+4kJCSEl19+2bzdzc2N6dOno9Pp+Oqrr8qMUXrOQgibY0JdHVltzXnu3LnExcURGhpaYl9WVhZQOOMQYM+ePQB069atRNuiEsehQ4fIzMzEw8ODX375BUVR6NKlS4ladGBgIM2bN+fYsWPExMQQHh5uNUbpOQshbI4JBaOKj9pxzk5OTuj1+hIP5n7++Wd+/PFH3NzczMk4JiYGAL1eb/FcjRs3xmQyce7cuWLtIyIiLLYPCwsD4MyZM6XGKD1nIUStlpuby6RJk4iJieHcuXMEBgbywQcfmMsdV68WPpj08/OzeHzR9pSUlGLt/f39y9XeGknOQgibYwTUdIaL1rBLTEw0lyOKeHl54eXlZfXYy5cvs2XLlmLbTp8+Tfv27QHIyckBwMXFxeLxRduzs7Mr1N4aSc5CCJtjAjQq2wP069evRI909OjRjBkzxuqxDRo0YN++fWi1Wn799VemT5/OtGnTyM7OZtiwYeZkr9GUHpHJVBiF2vbWSHIWQtgcExrUpGfTzbYrV6602HMujZubG25ubgD06NGDgIAA+vTpw3/+8x9eeOEFXF1dgcLyhyVF293d3QHK3b7omtZIchZC2ByTgqqyhulm2wYNGpR7Eoo1rVu3JiQkhPj4eBISEvD39+fkyZOkpKTQpEmTEu2TkwtXzyuqJRfVmq3VlIvaW6tJF5HRGkIIm2NEo/pTXoqi8MEHHzB+/HgKCgostikaxVFQUGAedVE0CuN/z3X+/Hl0Op05cZfWHjCP6rA2+qOIJGchhM0xqUzMJhXJWaPRsH37dn744QfzRJNbJSQkEBsbi5ubG40bN6ZTp04AbN++vUTbw4cPk5qaSrt27fDwKHx7S1H7n3/+uURd+fLly5w8eZKgoKBSxziDJGchhA0yKRrVHzWioqIAePfdd0lMTDRvT0pK4pVXXqGgoIB+/frh7OxMhw4diIiIYO/evXzzzTfmtqmpqUydOhWAwYMHm7cHBwfTqVMnzp8/z5w5c8zbs7OzefPNNzEajcXaWyMLHwkhbEbRwkf4DEOj4k0oitEPUheXe+Gj/Px8Ro0axa5du3Bzc6Nt27YYjUaOHDlCdnY2Dz74IPPnzzeXN44ePcoLL7xAdnY2d999N/7+/vz++++kpaURFRXFtGnTip0/ISGBvn37kpycjF6vp3HjxuaFjx544AE++eSTMl+nJclZCGEzipKzyedlUJGcMfqhTV2kalU6o9HIypUrWb9+PefOnUOr1aLX6+nVqxdRUVElpl7HxMQwd+5c9u/fj8FgoFGjRvTp04dnn322xAgRgCtXrjB37lx2795NRkYGwcHBPPnkk7zwwgvlilGSsxDCZhQl5wLvEaqTs8P1T1QlZ1tn10PpTCYTWVlZODo6ljkgXAhReRRFIT8/H3d3d4sL0ZfFqHKcM2jsLpnZ2/0Uk5WVVebiIkKIqqPX6/H09FR9nEnRoijlT+oaFW1rCrtOzkVvGgiv9zZOutRqjqZqnEiaR/P61qem1nQvdGxe3SFUmcnfjWDmE59UdxhVwsvfkxFLny/zbR/WmNCgqBhMplHVy64Z7Do5F5UynHSpODuoqF/VMPZ8b9evpFV3CFXK3u+vouVEIxoUNWOXJTkLIUTVMylaTCpKFVopawghRNUzqZz1p+7hYc1gf39uhBDCDkjPWQhhc4xoManoO6p5eFhTSHIWQtgck6LBqKaOrHJtjZpAkrMQwuaYVPacNdJzFkKIqmdUNBjV9Ial5yyEEFXPhBaj9JyFEMK2mFA3zllNCaSmkOQshLA5hW84kenbQghhU0wqa85aqTkLIUTVUztaQ8oaQghxBxgVrapxzrK2hhBC3AGKyrU11KxgV1NIchZC2ByjyhmCqsZE1xCSnIUQNseocpyzmrY1hSRnIYTNURQNJhW9YUV6zkIIUfWk5yzJWQhhg0yKRt0MQTvsOdvfnxshhLAD0nMWQtgcExqMKobHqXulVc0gyVkIYXPUvuBVTduaQpKzEMLmGFX2nNW0rSkkOQshbI6isuesSM9ZCCGqnhGVMwSl5yyEEFXPpHJtDXkgKIQQd4BJUTcJRR4ICiHEHWBSVPac7XASiiRnIYTNkenbkpyFEDZIes6SnIUQNqhwsX0VQ+nkgaAQQlQ9o6JyEor0nIUQoupJWUOSsxDCBimKurdvywxBIYS4A2RtDUnOQggbZELda6rscYag/X0XEEIIOyA9ZyGEzSl8IKhi+jYa7K3zLMlZCGFzFJULH8k4ZyGEuANUj3OWnrMQQlQ9k8qhdGra1hSSnIUQNkdROQlFyhqiUp054srX8+rz5353sjN11GuQT8du6USNSsK3QUGZx2/8tB4L33yfqV94ce/D6VbbZWVoWbPQn70/1CUxwQkHR4XI1tk8OzKJdg9mVuYtCQs0GoWPN8UQEJpHVIsWVtt1653KE4NTCG2aS75Bw7njrqxf7Me+rXXuYLS2QRbbl6F01WbfVi/GPa5n7w91MZk0NIrIJS3VgW+X+THsoaacOeJa6vFnj7ry2XsBZV4nMcGJEd0iWTWnAUkJTgQ3yUXnoBC9x5M3+jXhu8/qVdYtCSsGTU6kadvsUtsMef0y/5ybQMTdOVyOcybtmgN335fF1M/j6PePpDsUqe0wKTdHbJT7U90RVz5JztUg+bIjM8c0wmTU0O8fiaw+8icLtp5hVfSfPBx1jcwbDkwfHorRaPn4U9FuvNE/jJwsXanXMRph2kuhJCU406ZTBl8eOM7CbWf45tifDJh4BUXRsHhqIFfinargLgUoPD8hkT5jr5baqmO3dJ4bnUx6qo5xj0XwctdIhtzfjCmDQzHkahgwMZHm7bPuUMy2wXTzBa9qPvbGZu/o119/ZeDAgXTs2JG2bdsyYMAAdu/eXd1hVYod673JztDR6r4MXpiUiO5mccnFTWHszIt4eheQeMGZP37xKHac0Qgbl9VjYq9w0q45ln2ddd7EHHOjQUgeUz8/T13fwmyv1cLzryTR8t5M8g1atq/zrvR7rO28/fJ5+9M4Bkwou9fbZ2xhm09nBHDmiJt5+29b6vDVR/XRaqHP6NrVe1ZU9Zo1KHa48JFNJuf169czePBgoqOjadWqFW3atCE6OpqhQ4eyevXq6g7vtvk2yKfT4zd4tP+1EvucnBWCGucBkHL5rx6tIVfD6O6RLHyrIQUGDf3HJ1K/oaHU62xf5wPA868k4uxa8nvf8xMSeenNS7S8t3b1yqpa2wczWPbLKe57JJ1rSQ4sm9HAatvA0Dya35NNvkHDjg11S+z/cZXPzXNm4u5l5auUHSqqOav52BubeyCYlJTE22+/jaenJytXrkSv1wNw9OhRBg8ezPTp0+ncuTP169ev5kgrrlvv63Trfd3ivtxsLRfPOQMQeDNJAxjytJw/4UqIPoex71+k5b1Z/LTGx+o1jAXw5353AO79u+WHha3/L5PW/ycPBCtbo4hcXN1N/LTGm0VTAmncNNdq28g2hbXo2JMu5OWULFOlXXPkcpwTgaEGmrXN4uBOryqL25aoXltDI8m5yq1YsQKDwcDw4cPNiRmgVatWDB06lNmzZ7N69WrGjh1bjVFWjQtnnfnkrSAy0xy4q31msR6to5OJf86Np8tT181lkNJcPO9MvkGLj38+nnWNXI5zYsvXPpz70w2NRqFZu2weH5iCl0/t6Y3dKaf/cGNUdz3nj5f+UBf++gOceMF63f/qxcLkHNjYADsrK0rbVlSuKHd76TlXvT179gDQrVu3Evu6devG7Nmz2b17t10l568+rM9Pa31IvOCEomi49+9pTPjoQrE2zq6K1d62JVcvFf6ye/kUsG2NN3MnB2PI/auK9fv2Ony7rB7Tlp8nsnVO5dyIAODEQfdyt63rWzhkMuO69V/FjBuFPWovn7KHV9oLRWVytsdxzjZVc1YUhZiYGLRaLWFhYSX2h4aGotVqiYmJQVHsZ+zM0X0eXIl3Nj/UuBznxJHfPMo4qnQ5mYU/2uTLTsyeEELLezP55KdTfB93hEXbT9H2gXTSrjnyr4Fh3Eixub/RtYaTS+F/x3m51pNL3s0/qs4upjsSky2QoXQ2lpzT0tIwGAzUrVsXJ6eSX/McHBzw9vYmJyeHrCz7eYj1ykcJbDp/hKW7T9JzUDIJZ12YPiyUnRvrVvichrzCH21Wuo7g8FymfXmesOa5ODopNG6WyztfxhLQKI8bKY6s+49fJd2JUMtUjqqSVluYeeyoP1ImeSBoY8k5J6fw67Wrq/VanYuLC4BdJecGwQacXBSCw/MYPeMSTw5JQVE0fDojwOpY57Lc2svqMyapRJ3a0UnhmeGF42/3basdD5lsUW524a+gk7P1zOvoVNS7tqlf1yqlrtesrgRSU9jU91mtVs07w8rfjTiRNK8i4VSb5r0z+XbZfJISnNl5aBE+QXUttsszLgTSOX9tEs6Xwovtu2KIA74ubOc7jehLJXvHBp8LwEquxHsSfenrSr2HyvL+geqO4PZ5OJ0ApuFex5X3D7xabN+9fboAa/i/ZyMI6jbO4vHh9aYBaXR56VFa9v17lcdrC6TmbGPJ2c2tcAB+Xl6e1Ta5ubnF2pZH8/pjcHZIvr3gKlHGDR2X45xopM/Dxc1CHTEIPnJrSW62jkDdKzQLsjz111nXHHAizPcD2gQVHy4X1NGRZdwFQNP6/yQ0qORwLoeL7kAEjk55tAnqc7u3VSW6B7au7hBuW6u/ZfLvdZCVlsOr7d83b3//wKssm/A7by2BpFNHefXx9y0e//lvMXg2goUjdnF41+E7FfZt8Q6ow+TvRlR3GDWaTX1P8vDwwM3NjevXr1NQUPLJdEFBAdevX8fZ2Rkvr5r7VXxYl6aMfTSSAzs8Le7PuKEjL6fwR+NbP79C1/APysfn5rFnrazTcfl84XjqgBDrfwxF1Tp7c0ZgWPMcHJ1L/qGu45tPQCMDRiOc+aPsoXn2QsoaNpacNRoN4eHhGI1G4uLiSuyPjY3FZDIVG/9cE919XwYA/13ha3H/ps/roSgaQpvm4N+wYskZ4IGeNwDY+Kkfpv/5vVcU2PRF4aJH9/VIq/A1xO1JuujE2WOuOLkodH2m5FDJHv1SATiww4vMNJv6olulJDnbWHIG6NSpEwA//fRTiX1F2x588ME7GlNle3bkVbQ6hUO7vFj6bgCGvML/sEwm+P5LX776qAEajcKLb1y+res8NzoJjzoFnD3qxqxxIWSlF/64C/JhyTuBnD3qhpd3AY8PLDmNXNw5X8/1B2DYvy7T6m9/zdi89+9p9B+fhMkE3yyoXSNqFArXyyj3pzbVnHft2lUpF1CbSHv16sXSpUtZsmQJ999/Py1urn977Ngxli5diouLC/369auU2KpLk7ty+ce/E5gzKZg1C+uzeXk9ghrnkXzZkRspjmh1CiOmXaJD14zbuo6PfwH/WhbH2y80Zvs6H/b+tw4Nm+SRfMmJtFQHXNyMTF4QT916tWdygy36ZXNdflyVwSN9U/n3unPEn3ZG56DQsEnh2imfvdeA47/f3rj3mkbWcy4lOQ8fPhzNbc5X12g0nDhxQtUxDRs2ZPLkybzzzjv06dOHjh07ArB//34KCgqYOXMmvr6WywE1Sfc+qYQ1z2H1An+O/eZB7EkXvHyMdH7yOr1HXCWiVeXM2rv7vkwW/3yKVfPqc3CHF/GnXajjW8DDUalEjUoiJELqzbZg9oSGHP/dnccGXCO0aS5oFE4cdOPbZfXYtbH2rRqo3JyEoqa9vbGanAMDA+9kHMX079+fwMBAli5dyuHDh3FycqJt27aMGDGCv/3tb9UWV2WLaJXDm/+Jr/DxX/5+guhLX5c50sK/YT7jZl6s8HXE7Tn6mwfdA+8uo5WGrat92Lra+mJWtUlRuUJNe3tjNTnv2LHjTsZRQpcuXejSpUu1xiCEqB6qFz6qTclZCCGqi/ScbyM5p6amsm/fPmJjY8nMzGTy5Mnk5eURHR3NvffeW5kxCiFqGek5VyA55+fnM2vWLFatWkV+/l9jcCdPnsyFCxcYPHgwzZo145NPPqnRC+ILIaqRovIhnx0+EFQ1ztlkMjFq1Ci+/PJLCgoKiIyMpE6dv17bnpWVhVar5cSJE/Tt25fr18u//rAQQhSRVelUJud169axe/duwsLC+O677/j222+LrbvcunVrfvzxRyIiIrhy5QrLli2r9ICFEPZP1QQUecFrYXLWaDTMnTuX8PBwi22Cg4OZN28eWq222kd8CCFqpqJ3CJb7Y4c9Z1U157NnzxIWFkaTJk1KbRcaGkpoaCgJCQm3FZwQonZSVNacKzIJxWg0smrVKjZs2MD58+cxGo0EBwfz6KOP8tJLL+Hs7Fys/bFjx1iwYAHHjh0jOzub8PBwBg4cSM+ePS2ePzY2lnnz5nHo0CFu3LhBSEgIUVFR9O/fv1zLI6tKzkajsdxrLjs6OqLTlXybsBBClKUwOVfdDEGj0cjIkSPZuXMnbm5u3H333Tg4OHDkyBHmzp3Lrl27+OKLL8wv/ti7dy/Dhw/HZDLRvn17XF1d+e2335g4cSIxMTGMHz++2PlPnTpF//79yczMpG3btrRs2ZL9+/fz7rvvcuTIEWbNmlVmjKqSc3BwMLGxsaSmpuLjY30mU0pKCjExMRbfAyiEEGVSW0dWWXNes2YNO3fuJDIykiVLlphHlqWmpjJy5Eiio6NZuHAhEyZMIDc3l3/+858AfPrpp+ahwhcuXGDAgAEsWrSIhx9+2LwOkKIoTJo0iczMTD744AOefPJJ87kHDRrEpk2bePjhh+nevXupMaqqOXfv3p2CggL+9a9/FRtGdyuDwcAbb7yB0Wi0+AZtIYSobhs2bADg9ddfLzbk18fHhylTpgCwefNmADZu3Mi1a9fo2bNnsTkcISEhTJw4EYDly5ebt+/du5fTp0/ToUMHc2L+33Pf2t4aVT3nwYMH891337F9+3aeeuopunbtSnJy4RtGtm3bxrlz59iwYQPx8fEEBAQwaNAgNacXQgig6ieheHt7ExYWRqtWrUrsCw0NBeDq1cJ3bO7ZsweArl27lmjbpUsXdDodu3fvNm8ram+pc9q2bVt8fX05dOgQmZmZeHhYX21QVXJ2d3fns88+Y/To0Zw8eZLz58+b940dOxYo7NI3atSIhQsX1ui3lQghqk9VPxBctGiR1X3Hjh0DoEGDBkDhQAjA4ks+PDw88Pf358qVK6SkpFCvXj1iYmKstgdo3Lgx165d49y5c9x9t/UFsVTPEAwKCmLdunVs27aN7du3ExMTQ1ZWFq6urjRq1IjOnTvz2GOP4eTkpPbUQggBVN/aGoqiMGfOHAD+/vfCl+kWVQf8/Cy/8MDPz69Yci7qcZfWHgqfzZWmQmtraLVaunfvXmZBWwghKqKiyTkxMbHEKDEvL69yf4v/6KOPOHDgAPXq1eOll14CICencG11FxcXi8cUbc/Ozq5Qe2tua1W61NRU4uLiyM3NxdPTk7CwMNzd3W/nlEIIgYK65TKK2vbr169Ej3T06NGMGTOmzHPMmTOHxYsX4+TkxMcff2wekabT6VAUpcyXj5huvqiz6I9DedtbU6Hk/MMPP7Bs2bISbznRarW0b9+eUaNG0b59+4qcWgghzO8QVNMeYOXKlRZ7zqUpKCjgnXfeYfXq1Tg7OzNv3rxi+cvV1ZX09HTy8vJKTEwByM3NBTB3TIvGRhdtL6u9NaqT85tvvsm6detQblbgPT09cXNzIysri8zMTPbt28fvv//OpEmTZLSGEKJiKth1btCggcUEak1WVhbjxo1jz549eHl5sXDhwhIdS39/f9LT00lOTqZhw4YlzvG/NWl/f39OnjxJSkqKxdnUZdWwi6ga57xp0ybWrl2Lo6Mj48aNY9euXRw4cIBdu3Zx8OBBfvrpJ4YMGYJGo2HmzJns27dPzemFEKKQ2kWPKvBAMC0tjQEDBrBnzx4CAgJYsWKFxW/8ERERAJw7d67EvszMTK5evYqPjw/16tUr1r5o1Eax21IUzp8/j06nK3MZDFXJedWqVWg0Gj788ENGjBhRYr3mhg0bMmnSJKZMmYKiKCxZskTN6YUQAvhrKJ2ajxoGg4Fhw4Zx/PhxwsPD+frrr60OfevUqRMAP/30U4l9O3bswGg08uCDD5Zov3379hLtDx8+TGpqKu3atSt1jDOoTM6nTp0iODiYhx9+uNR2zz77LAEBARw5ckTN6YUQAqj6JUPnzp3LH3/8QUBAAMuXLzePabake/fu+Pr6smHDBnbt2mXenpCQwIcffohGoylWwu3QoQMRERHs3buXb775xrw9NTWVqVOnAoUT+sqiqubs4OCAm5tbudp6e3uTnp6u5vRCCFFIQV2pQkXP+fr16+bp0z4+PsyYMcNq21mzZuHh4cG0adMYO3Ysw4cPp3379ri7u7Nv3z5ycnIYP348TZs2NR+j1WqZMWMGL7zwAm+99RZr167F39+f33//nbS0NKKionjooYfKjFNVcu7QoQM///wzsbGxNG7c2Gq7pKQkzp49K+8SFEJUSFXOEDxw4IB5xMTx48c5fvy41bZFq8d17dqV5cuXs2DBAo4cOYKiKERGRjJo0CB69OhR4rhWrVqxZs0a5s6dy/79+zl79iyNGjXilVde4dlnny1XnKqS84QJE9i/fz8jRoxg/vz5FhfcT0pKYtSoUTg4ODBhwgQ1pxdCiEIVHehcDn//+985ffq02oho27atqrc7hYeHM3fuXNXXKWI1OY8bN87i9gYNGnD27FmeeOIJ2rVrR9OmTXFzcyMnJ4e4uDj279+PwWCgU6dObN26tVh3XwghyqOi45ztidXkvGXLllIPNJlMHDhwgAMHDljcv3v3bvbs2WNeEEkIIcqtCnvONYXV5Dx69Og7GYcQQphV18JHtkSSsxBC2KDbWvhICCGqhJQ1KpacjUYjSUlJ5OTkmNfYKFJQUIDBYODq1avs2LGj1DGEQghhmebmR017+6I6OS9ZsoQlS5aQkZFRrvaSnIUQqknPWV1y3rp1Kx9++GG52oaEhPDII49UKCghRC0nyVnd2hpF88R79uzJrl272LdvHzqdjqioKI4dO8a2bdsYPnw4Op0Ok8nEsGHDqiRoIYSdK1ppTs3HzqhKzidOnMDV1ZUpU6ZQv3596tatS3h4OHv37sXR0ZHg4GDGjx/PuHHjuHTpEl988UVVxS2EsGNVvSpdTaAqOaenpxMcHFxsBf+IiAguX75MWlqaedvAgQNxcXGxuGSeEEKUi6LiY4dUJWc3N7cS78UKDg4Gii9E7eLiQmhoKPHx8ZUQohCi1pGyhrrkHBwcTEJCQrG3xjZq1AhFUTh58mSxtrm5uRQUFFROlEKIWkWjqP/YG1XJ+f777yc7O5u33nqLzMxMAFq2bAnAunXrMBgMABw9epS4uDiCgoIqOVwhRK2gpqRhp6UNVcl54MCBeHt788MPP9CpUycMBgNNmjShY8eOnDx5kl69ejF27FjzKv/3339/lQQthLBzUtZQl5x9fX359NNPadasGU5OTjg5OQHwxhtv4OXlRUxMDFu3biUrK4vAwEBGjhxZJUELIeyc9JzVzxBs1qwZ69ev58qVK+Zter2ezZs3s27dOi5dukRoaCjPPvssnp6elRqsEKKWkEkoFV/4KCAgoNj/X69ePYYPH37bAQkhhCRnWZVOCGGT1NaR7a/mbDU59+7d+7ZPrtFoWLNmzW2fRwhRu6gdHmePQ+msJuc///zztk/+vxNWhBBClI/V5Pzee+/dyTiEEOIvUnO2npyffvrpOxmHEEKIW9SKB4Iv3NeSG4np1R1GlXjvN3gk5J7qDqPKfHfpt+oOocqcuAzfXbL89vqazlDgR8zVih8vNedakpyFEDWMgrrRGpKchRDiDpCasyRnIYQNkuQsyVkIYXuk5izJWQhhq+ww4aohyVkIYXukrFHx5Gw0Gjl+/Djnz58nMzOT559/nvz8fK5cuUJISEhlxiiEqGWkrFHB5Pzll1+yePFirl27Zt72/PPPk5CQwOOPP063bt2YMWMGHh4elRaoEKIWUbuAvh0utq86Ob/xxhusX78eRVGoU6cOBoOB3NxcAFJSUjCZTGzbto2EhARWrlyJq6trpQcthLBzUtZQ9yaULVu2sG7dOvz8/FiyZAn79++nWbNm5v0dOnRg+fLl+Pn5cerUKb744otKD1gIYf/kBa8qk/OqVavQaDTMmTOHTp06WWzTvn17FixYgKIo/Pe//62UIIUQtYy8pkpdWePEiRMEBwfTpk2bUtu1bNmSRo0aER8ff1vBCSFqKbW9YTtMzqp6znl5ebi5uZWrrTwMFELcllrcawaVyTkgIIDY2Fiys7NLbZeZmUlMTAwNGjS4reCEEKK2UpWcu3TpQl5eHu+//36p7WbMmIHBYODBBx+8reCEELWU1JzV1ZyHDh3Kxo0bWbNmDRcuXKBHjx6kpaUBhfXoc+fO8c0333Dw4EG8vLwYMmRIlQQthLBvMglFZXL28fFhyZIljBo1in379rF//37zvmeeeQYARVHw9vZm3rx51K9fv3KjFUKIWkL1JJS77rqL77//ntWrV7Njxw5iYmLIysrC1dWVRo0a0blzZ/r164ePj09VxCuEqA1kEkrFpm97eHjw4osv8uKLL1Z2PEIIIWUNZFU6IYQtkp6zuuT87bffqr7AU089pfoYIUQtJ8lZXXJ+9dVX0WjKt/qToihoNBpJzkII1aSsoTI5N2/e3Gpyzs3NJSUlhbS0NDQaDY8//rg8FBRCVJwdJlw1VCXn9evXl9nm4MGDvPrqq/z555+sXbu2woEJIWov6TmrnCFYHvfccw9z5swhLi6OBQsWVPbphRC1gcwQrPzkDIVjocPCwti6dWtVnF4IYe8kOVfdUDqdTkdycnJVnV4IYcekrFFFPefDhw8TExNDvXr1quL0Qgh7Jz1ndT3nFStWlLrfYDAQGxvLpk2bAOjatWvFIxNC1F4yzlldcp42bVq5xjkrikJISAgjR46scGBCiNpLyhoqk3P79u1LP5mDA15eXrRp04bevXvL21CEEBVnhwlXDVXJefny5VUVhxBCiFuoeiA4ZMgQXn31VdLT06sqHiGEMJc11Hzsjaqe85EjR/Dw8MDLy6uq4hFCCHkgSAXGOdepU6cq4hBCiL9IclZX1njiiSc4e/Ys27dvr6p4hBACAI2Kjz1S1XN+4oknOHnyJKNHj6Z169a0bt0af39/nJycrB7Tv3//2w5SCFHLSM9ZXXLu27cvGo0GRVGIjo7mjz/+KPMYSc5CCLVknHMlj3MWQohKIT1n68n58uXLODs74+vra94m45yFEHeEJGfrDwQfeughxo0bdydjEUII4OaDPjXjnKs74CpQallDUezwz5EQwvZJz7nq1nMWQoiKkgeCkpyFELZIes6SnGsCjUZh9renCGiUx3OtW5frGJ2DwvzNJ2ncLIdJUXqO7vOs2iBrmbNH3Fg7P4AT+z3JztTh28BA+25p9Bp5Bd8G+WUe//1n/ix+833e+rwO7R9Os9ouepcX339anzPR7mSl6/Coa6TpPZk8PTyRZu0zK/OWbIr0nMtIzteuXePbb7+9rQs89dRTt3W8gBf+eZmmbbJJS9WV+5i+Y67QuFlOFUZVe/2+tQ4zXorAZNTgWbeA4IgcEuOd2bSsPj+v82XqytNE3J1t9fhzx9xY/l7DMq/z1cwgvpkbCIB7nQKC9TkkXXBm33+9+X1LXYa9G8+jL9jpq+Ck51x6co6Pj+e1116r8Mk1Go0k59ui8Pz4K/QZnajqqNDIHJ4bpe4YUT4plx35aGwYJqOG5/5xiT7jL6NzgLwcLYteD2H7N3588HITFv1yDJ2Fv6Vnot2Z9kIEOVml/6E9tKMO38wNROdgYti0C/QYWJiEjQWwZl4gK2cFsfitRkS2zaJJS+t/CGosSc6lJ2cnJ6di45zFnePtl8+YGfHc1936V15LtFqFV2bFodEo5Bs0ODrZ4X+11WjXBl+yMxxo+bd0+v/zsnm7s6uJke/H8/tWb5IuuHB0rxdtHvhraV2jEf77hT+fvRtMfl7ZS9p8u7g+AI8NumpOzAA6B+gz/jJxJ135dbMP33/qz7jZcZV3gzZCyhplJOcWLVqU+d7AO2H9+vW89tprrFixgnvuuae6w6lybTul88aic7h7mki96sC3n9ZnyKuXynXsM8OT0N+dzeqF9XmkTwp1fIxVHG3t4lM/n/seS+Vvj14vsc/RWSGgcS4Z0R6kXP5rvRlDroZ/9mxO7Ak3NBqFPuMvsWNNPa5edLZ4DaMRTh4ofEZw3+MlrwPQvtsNft3sw7lj7pVwVwLKzjOxsbHMmzePQ4cOcePGDUJCQoiKiqJ///5otSX/4CYlJbFgwQL27t1LcnIyAQEBPPHEEwwdOrTU9YiKVMnbtytTdHQ006ZNq+4w7qgQfQ6u7iZ+WufD8G53cepw+X4Bgxrn8vz4y1w878xXswOrOMraqUvva7y6+BwPPpVaYl9utpZL510ACAjNNW835GmJPeFGsD6H6WtP0W/i5RLHFqPAa0tiGPl+HI0iLT83yMsu/NU1Gu1x+sVNd/DN22XlmVOnTtG7d282b95MYGAgnTp1IjExkXfffZdJkyaVaJ+YmEhUVBSrV6/Gy8uLzp07k5WVxdy5c3nxxRfJzy/7obFNj9bYsmULr732GtnZdlhTK8XpP9wZ/Wgzzp9wU3GUwvh/x+PopDBncqNyfXUWledijAuL3wohK82BZu0zaHHvXyMpHJ1MjJ9zngeeuoauHL9xOgdo91Dp5az9W70BCI6wz4e+GkVBo2ISnJq2/6usPKMoCpMmTSIzM5MPPviAJ598EoDU1FQGDRrEpk2bePjhh+nevbv5mClTppCYmMi4cePML7rOzs5m1KhR/PrrryxfvpwhQ4aUGpdN/gYnJiYyadIkxo4di8lkol69etUd0h118pCHysQMTw5OpkWHTH5cVY9j+2XY3J2y6qNAht3XklGdW/DH7jp0+Pt13vj0bLE2zq4KXXqXLzGXx6GfvYjeVfjSi869rlXOSW2Nml5zBXvP5c0ze/fu5fTp03To0MGcmAF8fHyYMmUKUHzdofPnz7Nz505CQkJ4+eWXzdvd3NyYPn06Op2Or776qsz4bDI5f/zxx2zcuJEWLVqwevVqwsLCqjskm1a/YR6DJl0iJdGRpTPKHqIlKs+fv3mSGO+CohSWF67EufDnb1X3GreLMS7MHlv4+3DXvel07H6jyq5Vne7EOwTLm2f27NkDQLdu3Ursa9u2Lb6+vhw6dIjMzMJvS7/88guKotClS5cStejAwECaN2/OpUuXiImJKTU+q8l59OjR9OrVq/S7qyJhYWHMnDmTNWvWEBkZWS0x1CTjZsbj6m5i/hshZGeUfyy0uH1jP4pl7bmDLNx1jEcHJXHxrAszhzdhz0afSr/WxRgX3noukvRUR7z9DUyYdx6NvZac70DPubx5piiJ6vV6i/sbN26MyWTi3LlzxdpHRERYvS7AmTNnSo3P6het0aNHl3pgVRo2bFi1Xbum8XXbTkinDHZ/782+bXWrO5xap36wAYCG4bm8PP0COh1sWlafL95ryH2Pp1oc61wRZ/9w552BEaRdc8TTO58pK85QL7Dsh0o1ltrecAWSc3nzzNWrVwHw8/OzuL9oe0pKSrH2/v7+5WpvjU0/EBSl861vILDOSjJu6Fj4r+DqDkcAz4y6wqZl9bma4EzyJScahBhu+5wHt9dh5vAm5OXoqOuXzzurThNq77M/KzgJJTExEd3//EX08vLCy6vipaacnMJ/axcXF4v7i7YXPVBU296aWpGcJ2+o2T1xD6cTwDTc67jy3m8Tzdt93HbhoD2GZ134+vBRq8d/8E3h16cr6c+QmNG7iqOtXCfKGHV2p2Wn53It4Tr1w3xxcrU8VtXJ9UMMOfn8cXIWIQ5BFtsYjAuBdC6kvo775XCr14v+73HWTN2MyWjCJ6guL85/juw63jb371LZKjoJpV+/fiV6pKNHj2bMmDEVjqUo2WvKqCGZTKYKtbemViTnmU8v5kZietkNbVSrezP44BvISsvhtb/NMm+/p3Mary6JJP7oRYvHRbbOwsERYk+5kJ2hY8vqg2z9Ju4ORV05Nsb/Vt0hFDPo8btJTXJi8n9iaG1hgkjmDR35uW0ADe1aTMQv0HLP2UnXCnAmxGcGzQMtD5v79Qdv1kxtgsmooXHzbKasiMbbf1sl3k3VMRT4EXN10e2dpAKlipUrV1rsOd8OV1dXAHJzcy3uL9ru7u6uqr2bW+kjsmpFcrZXB3fW4WzKRF57ZpbF/av/+IM6PkY++VeIrEpXSVrel8GuDb5sXenH/1lIzps/90dRNDRqmo1fUMVLGhdOu/DRmMI1PPRtMpmy4gwedWrPbM+K9pwbNGiAs7PlmZcV5e/vz8mTJ0lJSaFJkyYl9icnF06vL6olF9WardWUi9pbq0kXscmhdELYql4jrqDVKUTvqsPn0xuSn1f41dVkgv9+6cfXswPRaBReeN3yt5nymj8pFEOuFp/6Bt78/GytSszAzZqzouJTdaEUjbqwNPRNURTOnz+PTqczJ+7S2gPmUR3WRn8UkZ6zECo0viuH0f+OY8GkRqxfGMCPy/0IbJxH8mUn0lIc0eoUhk67wD1d1S1YdatTh9w5dbDwm45GA++9ZL0m7e2fz6uLz1X4WrbKlhY+6tSpE0uXLmX79u3079+/2L7Dhw+TmppKhw4d8PDwMLcH+Pnnn5k4cWKxsc6XL1/m5MmTBAUFER5u/ecKkpyFUK3bcymENstm3YIA/tznSdxJV7x8Cuj05DWefjmR8Fa3t9xA0aJHANcSnbiWaH2RHP+Gebd1LZtlQ0uGdujQgYiICPbu3cs333xDVFQUUDh9e+rUqQAMHjzY3D44OJhOnTqxZ88e5syZw/jx44HC0RlvvvkmRqOxWHtrJDnXAEf3efJISDvVx5X3rSlCvfBW2Uz+T8V7rEv3H+XE5XU0D3ymxL6nX07k6Zdr93rcGlPhR037qqLVapkxYwYvvPACb731FmvXrsXf35/ff/+dtLQ0oqKieOihh4od8/bbb9O3b18WLVrEjh07aNy4MYcPHyY5OZkHHniAvn37ln3dqrohIYSosDswQ1CNVq1asWbNGrp37058fDx79+4lMDCQqVOnmtfXuFVwcDBr1qyhV69epKamsnPnTurUqcOECROYP38+Dg5l94trRM/51kVFhBD2T4PKmnMlXLOsPBMeHs7cuXPLfb6AgADee++9CscjPWchhLBBNaLnLISoZYqGyKlpb2ckOQshbI4tDaWrLpKchRC2x4aG0lUXSc5CCJsjPWdJzkIIWyQ1Z0nOQggbdAcW27d1kpyFELZHas6SnIUQtqc6JqHYGknOQgjbY1IKP2ra2xlJzkII2yNlDUnOQgjbI0PpJDkLIWyRDKWT5CyEsD3Sc5bkLISwRVJzluQshLA9GhQ0KkoVGjvMzpKchRC2x3Tzo6a9nZHF9oUQwgZJz1kIYXM0isqyhozWEEKIO0AeCEpyFkLYIBnnLMlZCGF7ZJyzJGchhC1SUNlzrrJIqo0kZyGEzdEooFExPE56zkIIcSdIzVmSsxDCBsloDUnOQggbpHKcs/SchRDiTpCyhiRnIYQNkrU1JDkLIWyPrEonyVkIYYukrCHJWQhhgyQ5S3IWQtggqTlLchZC2B5ZMlQW2xdCCJskPWchhO2RhY8kOQshbJA8EJTkLISwRSqTsx12nSU5CyFsj4zWkOQshLA9MlpDkrMQwhZJzVmSsxDCBpmUwo+a9nZGkrMQwvZIz1mSsxDCFsloDUnOQgjbI5NQ7Ds5Kzd/uF5+HtUcSdWq28CrukOoMoYCv+oOoUrZ6/3lG32Bv34HVZOas30n5/z8fABGLO5XzZFUrckbhlV3CFUm5mp1R1C1Yq4uqu4QqlR+fj4uLi7qD1RMhR817e2MXSdnd3d39Ho9jo6OaDSa6g5HiFpDURTy8/Nxd3ev6AnkgWB1B1CVtFotnp6e1R2GELVShXrMRaSsYd/JWQhRU8loDUnOQgjbI2UNSc5CCBskQ+nkTShCCGGLpOcshLA9JlPhR017OyPJWQhhe6TmLMlZCGGDJDlLzbmm+vXXXxk4cCAdO3akbdu2DBgwgN27d1d3WEKl9evXExkZycGDB6s7FNuiKH+NdS7PR5KzsAXr169n8ODBREdH06pVK9q0aUN0dDRDhw5l9erV1R2eKKfo6GimTZtW3WHYJEUxqf7YGylr1DBJSUm8/fbbeHp6snLlSvR6PQBHjx5l8ODBTJ8+nc6dO1O/fv1qjlSUZsuWLbz22mtkZ2dXdyi2yYTKGYJVFkm1kZ5zDbNixQoMBgODBg0yJ2aAVq1aMXToUPLy8qT3bMMSExOZNGkSY8eOxWQyUa9eveoOyTYV1ZzVfOyMJOcaZs+ePQB069atxL6ibVJ7tl0ff/wxGzdupEWLFqxevZqwsLDqDsk2FQ2lU/OxM1LWqEEURSEmJgatVmvxlzo0NBStVktMTAyKoshKfDYoLCyMmTNn8sQTT6DVSt/IKhmtIcm5JklLS8NgMODj44OTk1OJ/Q4ODnh7e3Pt2jWysrLw8LDvlwzURMOG2e/a25VJUUwoKnrD9vhAUP501yA5OTkAuLq6Wm1TtExjVlbWHYlJiCohNWfpOdckar4GV/j1QELYAhmtIcm5JnFzcwMgLy/Papvc3NxibYWokeQ1VZKcaxIPDw/c3Ny4fv06BQUFODgU//EVFBRw/fp1nJ2d8fKy35e+CvunmBQUFT1nNW1rCqk51yAajYbw8HCMRiNxcXEl9sfGxmIymYqNfxaiZjL91Xsuz8cO6xqSnGuYTp06AfDTTz+V2Fe07cEHH7yjMQlR6W72nMv7scd3CEpyrmF69eqFs7MzS5Ys4c8//zRvP3bsGEuXLsXFxYV+/fpVY4RCiMogNecapmHDhkyePJl33nmHPn360LFjRwD2799PQUEBM2fOxNfXt5qjFOL2ePl5qBoe5+Vnf2P6JTnXQP379ycwMJClS5dy+PBhnJycaNu2LSNGjOBvf/tbdYcnRIXpdDp0Oh0jlj5f4WPthUaRAbFCCBtSUFCA0WhUfZxOpysxgqkmk+QshBA2SB4ICiGEDZLkLIQQNkiSsxBC2CBJzkIIYYMkOQshhA2S5CyEEDZIkvMdcPHiRSIjIy1+mjZtSqtWrXjggQcYMWKExTUzqsOZM2fMMd7q1VdfJTIykpkzZ972NVJSUkhPT7/t85Tlq6++IjIykgEDBpSr/fr164mMjKRXr163fe158+YRGRnJ2LFjb/tcZXnooYeIjIzk559/rvJriapnPyO2a4gWLVoUe8WUoigYDAYuXrzIjh072LFjB/369ePtt9+uxiir3ueff868efNYtWqVLG8qhAWSnO+wOXPm0LBhwxLb8/PzmT9/PosWLWLlypV06tSJhx56qBoiLN0rr7zC0KFD8fb2vq3zvPfee5UUkRD2ScoaNsLR0ZHx48fTpk0bAFauXFnNEVnm7+9PkyZN8PHxqe5QhLBrkpxtTJcuXYDCJUCFELWXlDVsjIdH4dKHt749e968ecyfP59Jkybh6urKJ598QlpaGiEhISxYsIBGjRoBkJCQwJIlS/jll1+4evUq7u7utG7dmkGDBlldrS45OZklS5awfft2kpOTCQoKom/fvnTo0MFi+1dffZUNGzYwZMgQJk+eXGxfQkICX375Jbt27SIxMREXFxdatmzJ4MGDuf/++4vdS5GePXsC8OWXX5qXPwU4cOAAn3/+OdHR0aSnp+Pr68v//d//MXz4cPP9/q+TJ0/yySefcPjwYTIzM2nWrBkjRowo9d9brZSUFJYvX86ePXtISEggJycHT09PmjdvTlRUFN27d7d67Pnz5/noo4/My7s2bdqUvn378sQTT1hsn5mZyeeff86WLVu4cOECOp0OvV5Pr169eOaZZ+xqBTZRkiRnG3PhwgUAAgICSuzbunUrf/zxB0FBQQQFBZGdnU1wcDAAe/bsYezYsWRnZ+Pq6kpERASpqans3LmTnTt3MmbMGEaPHl3sfLGxsQwePJgrV67g4uJCREQESUlJTJ8+nXvuuUdV3Hv37mXcuHFkZGTg5uZGeHg4ycnJ/PLLL/zyyy9Mnz6d3r17ExAQQNu2bTl8+DAAzZs3x8XFBU9PT/O5Fi5cyJw5cwDw9vZGr9eTkJDAunXr+OGHH5gzZ06Jt71s27aNV155BYPBgLe3N02aNOHUqVMMHTqUdu3aqboXa06ePMngwYO5fv06bm5u5mcHCQkJ5vucMGECw4YNK3FsbGwsUVFRZGVlERERQXZ2NocPH+bw4cPs27ePGTNmFGt/8eJFhgwZQnx8PA4ODoSGhmIymYiOjiY6OpqtW7eycOHCYg+XhZ1RRJVLSEhQ9Hq9otfrlYSEBKvtbty4odx7772KXq9Xpk2bZt4+d+5c8/HTp09XTCaToiiKcu3aNfP527Ztq+j1euXjjz9W8vLyzMf+9NNP5n3btm0zbzeZTMpzzz2n6PV6ZciQIcr169cVRVEUo9GoLFu2TImMjDRf81aTJ09W9Hq98v7775u3Xbt2TenYsaOi1+uVN998U8nMzDRf47PPPlP0er1y1113Fbv3onOfPn262Pm3bNmi6PV6pW3btsrmzZvN2w0Gg7JgwQLzvkuXLpn3paSkmO/x3//+t5Kfn68oiqJkZmYq48ePN1/r+eeft/pvf6t169Yper1eefrpp4ttf/rppxW9Xq/84x//UDIyMszbMzIylAkTJih6vV5p166dYjAYzPtu/dk9/PDDSkxMjHnfjz/+qLRo0ULR6/XK999/b95eUFCgPPXUU4per1defvllJTk52bzv7NmzSo8ePRS9Xq+8++67xeLr0qWLotfrlR07dpTrPoVtk5pzNVMUhfT0dHbv3s1LL71Eamoqnp6evPjiiyXaOjo6Mm7cODQaDYD5odynn35KZmYmTz31FOPGjSvWm+ratSsTJkwAKFZOOHjwINHR0Xh5eTF79mzq1q0LgFarZciQITz55JPlvodvvvmG69ev07p1a9555x3c3d2BwhfSDho0iM6dO5Ofn88PP/xQ5rnmzp0LwOuvv86jjz5a7N5HjhxJjx49zF/3i6xatYrMzEw6dOjAxIkTzWv6uru78/7771stg6hx+fJlLl26hIuLC1OnTjWXn6CwFDVx4kQAMjIySEpKKnG8RqNh3rx5NGnSxLyte/fu5rLLsmXLzNu3bdvGiRMnaNy4MR9//DH16tUz7wsPD+fjjz9Gq9WyatUqrl27dtv3JmyTJOc7rGvXriUmobRv356hQ4dy9OhRvL29WbhwocWyhl6vNye+W+3YsQOAxx57zOI1H3vsMTQaDSdPniQ5ORkoLINA4ctgLY0z7t27d7nvaefOnQA8/fTT5j8ct5o6dSo//fQTL730UqnnuXDhAmfPnkWr1RZLzLd6/PHHAdi9e7d52y+//AJgsXbr5ORktaarRmBgIPv372f//v0W/71cXFzM/zs3N7fE/nbt2pWY0APwzDPPAHD8+HFzot2+fTsA3bp1w9nZucQxer0evV5Pfn4++/btq9gNCZsnNec77H8noWi1Wtzc3Khfvz5t2rShR48euLm5WTzWz8+vxLbMzEyuXLkCwOzZs/nkk08sHqvT6SgoKCA2NhY/Pz/i4uKAwp6YJZYSiTUJCQkAREREWNzfoEGDcp0nJiYG+Kv3bklR4ouPj0dRFDQajflebu2V3qpp06blun55uLi4cO7cOY4ePUp8fDwJCQmcPXvWHDuAyWQqcVyzZs0snq9+/fp4enqSkZFBbGwsvr6+nDt3DoAff/yRQ4cOWTwuMTERKKxlC/skyfkOszYJpTws9aJuHdVx4sSJMs+RkZEBFCZ1AFdXV4vtPD090Wg0KOV4Uc6NGzcALPbq1SiKqaCgwPzA0BqTyURWVhYeHh7m46z9Ubv1YePtOH36NDNmzCjRWw0KCqJXr16sWbPG6rHWYival5GRYf7DU3Q/CQkJ5j981hT9PIX9keRcw92aXH/77bdyTw4p+mqenZ1tcX9eXl65EjMU9iYzMzOtnqu8ihJYREQE33//fbmP8/Ly4tq1a8X+UN3KUplBreTkZAYOHMiNGzdo2rQpvXv3plmzZjRp0gRvb28MBkOpybm0f5uiuIt+JkU/0zlz5vDII4/cduyiZpKacw3n5eVlTsjnz5+32MZoNPLrr78SHx9vfnFm48aNgcLhYZYUfbUuj9DQ0FKP+fnnn+nfv3+xB5KWFD24u3jxIgaDwWKblJQUDh48WOyhW9G9nDp1yuIx1v5d1Fi3bh03btygSZMmrF69mgEDBnDPPfeYp7Fbegh4q6LSy/9KSEggMzMTrVZLWFgY8Ne/Q2lxR0dHc+bMmUr5wyNskyRnO1A05vfrr7+2uH/Tpk0MHjyYp556ytyD69q1K1D4YM1SYtmwYUO5r180wWTjxo1Wr3/w4EHS0tLM24oeHN7aOw8PDycoKIicnByr5/rwww/p378/48ePN28rupd169aVqPeaTCar51Lj0qVLAISFhRV7+Fdk7dq15v9t6c3R+/fvNz8buNWqVasAuOeee8wjQDp37gzAt99+S15eXoljEhISeP755+nZsyfR0dHqb0bUCJKc7cBLL72Es7MzmzZtYvbs2cV+offs2cM777wDwLPPPmuuv7Zo0YIuXbqQk5PD6NGjzQ+YANasWaNqbY/+/fvj5eXFgQMHmDFjhvn6iqKwfPlyNm/ejKOjI/379zcfU1TCuHz5snmbRqNh5MiRAMyYMYPNmzeb9xUUFLB06VLWr18PUOyBYVRUFPXr1+f48eO89dZb5t5kXl4eU6ZMsfrtQI2ibwd79+7l6NGj5u05OTksXryYJUuWmLdZSqgGg4HRo0cX+0O4Zs0aPv/8czQaDaNGjTJvf/zxxwkNDSU+Pp4xY8aYR9hAYQ985MiRFBQU0KxZM6szP0XNJzVnOxAeHs7MmTOZNGkSixYtYvny5TRu3Jjr16+be3z33XefeSxukWnTpjFkyBCOHj1Kt27d0Ov1pKamcuXKFbp06VLudYH9/f356KOPGDNmDF988QXr16+nUaNGXLlyhWvXrqHT6XjnnXfMCQ4KR4McPnyYV155hbCwMMaPH8/9999P7969OXv2LJ9//jmvvPIK7733HvXr1+fixYvmB4+jRo2iW7du5nN5eHgwe/Zshg8fztq1a9m6dSuNGjUiPj6e9PR0VfdizbPPPsuKFSu4dOkSUVFRhIaG4uLiQnx8PNnZ2QQFBaHVaklISODq1aslju/UqRMHDhyga9euREREcP36dXNPetKkSdx7773mtk5OTixYsIAXX3yRXbt20blzZ8LDw8nPzycuLg6j0UiDBg1YuHDhbd2TsG3Sc7YTPXr04Ntvv6V3797UrVuX06dPc/36dVq2bMnrr7/O4sWLS0z19fPzY+XKlYwaNYqgoCBiYmLQarWMHj2aWbNmqbp+p06d2LhxI71798bDw4PTp09jNBrp1q0bq1atKrFw/YwZM+jYsSOKohAXF0d8fLx532uvvcayZct46KGHMJlM5lry/fffz8KFCy0uXN+uXTvWr19Pr169cHNz48yZMwQFBTFr1iz69eun6l4s8fLyYu3atQwYMIDQ0FAuXbpEfHw8jRo1YvTo0WzcuJEePXoAWPxDcNddd7Fq1So6duxIXFwc6enp3HfffXz22WcWJxyFh4ezceNGRowYQVhYGHFxcVy4cIGQkBCGDBnChg0bCAwMvO37ErZLo5T3kbwQQog7RnrOQghhgyQ5CyGEDZLkLIQQNkiSsxBC2CBJzkIIYYMkOQshhA2S5CyEEDZIkrMQQtggSc5CCGGDJDkLIYQNkuQshBA26P8Byra7nYXAAOoAAAAASUVORK5CYII=\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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enoyevRoO7ZQCKGG5ISdTIsWLZg1axZz585l1KhR9OnTB4C4uDgMBgMLFy6kUaNGdm6lENfHP8hX1bAz/yDnHRMvQdgJjRkzhmbNmhEdHc3Bgwdxd3enR48eTJw4kb59+9q7eUJUm4uLCy4uLkyMHlvta52NRpEBpUIIB2IwGDAajaqvc3FxKTdiyBlIEBZCCDuSB3NCCGFHEoSFEMKOJAgLIYQdSRAWQgg7kiAshBB2JEFYCCHsSILwDXD69Gnat29v9dWhQwe6du3K7bffzsSJE62uCWEPJ06csLTxWs899xzt27dn4cKF132PCxcucPny5euupyqffPIJ7du357HHHrOpfGxsLO3bt2fEiBHXfe+lS5fSvn17pk6det11VWXQoEG0b9+eH374odbvJWqO841sdnKdO3cuszWRoijo9XpOnz7Nzp072blzJ6NHj2bOnDl2bGXtW716NUuXLmXdunWy7Kao1yQI32Bvv/02LVq0KHe8pKSEd999lxUrVhATE0P//v0ZNGiQHVpYuaeffprIyEgCAgKuq54FCxbUUIuEcG6SjnAQbm5uTJ8+ne7duwMQExNj5xZZ16RJE9q2bUtgYKC9myJEnSBB2MEMHDgQMC9NKYSo+yQd4WBKt6m/drfkpUuX8u677zJz5ky8vLxYvnw5OTk5tGrVivfee4/WrVsDkJaWxsqVK/npp584d+4cPj4+dOvWjXHjxlW4utr58+dZuXIl33//PefPn6d58+Y8+uij9O7d22r55557js8//5zx48cza9asMufS0tL4+OOP2bVrFxkZGXh6etKlSxciIiK47bbbyryXUvfddx8AH3/8sWVZToD9+/ezevVq4uPjuXz5Mo0aNeLWW2/lqaeesrzfvzp27BjLly/n4MGD5OXl0bFjRyZOnFjp563WhQsXWLNmDXv27CEtLY3CwkL8/Py46aabePjhhxk6dGiF1/75558sWrTIsuxohw4dePTRRxk+fLjV8nl5eaxevZqtW7eSmpqKi4sLOp2OESNG8OCDDzrlimGiPAnCDiY1NRWApk2blju3bds2fv/9d5o3b07z5s0pKCigZcuWAOzZs4epU6dSUFCAl5cX7dq149KlS/z444/8+OOPTJkyhaioqDL1JSUlERERwdmzZ/H09KRdu3ZkZmYyb948evbsqardP//8M9OmTSM3Nxdvb2/Cw8M5f/48P/30Ez/99BPz5s1j5MiRNG3alB49enDw4EEAbrrpJjw9PfHz87PUtWzZMt5++20AAgIC0Ol0pKWlsWnTJr755hvefvvtcruHbN++naeffhq9Xk9AQABt27bl+PHjREZGcvPNN6t6LxU5duwYERERZGVl4e3tbcntp6WlWd7njBkzmDBhQrlrk5KSePjhh8nPz6ddu3YUFBRw8OBBDh48yL59+5g/f36Z8qdPn2b8+PGkpKTg6upKaGgoJpOJ+Ph44uPj2bZtG8uWLSvzkFc4KUXUurS0NEWn0yk6nU5JS0ursFx2drZyyy23KDqdTnn11Vctx9955x3L9fPmzVNMJpOiKIpy8eJFS/09evRQdDqdsmTJEqW4uNhy7Y4dOyzntm/fbjluMpmURx55RNHpdMr48eOVrKwsRVEUxWg0KqtWrVLat29vuee1Zs2apeh0OuW1116zHLt48aLSp08fRafTKS+++KKSl5dnuceHH36o6HQ6pVOnTmXee2ndCQkJZerfunWrotPplB49eihbtmyxHNfr9cp7771nOZeenm45d+HCBct7fOONN5SSkhJFURQlLy9PmT59uuVeY8eOrfCzv9amTZsUnU6nPPDAA2WOP/DAA4pOp1P+/e9/K7m5uZbjubm5yowZMxSdTqfcfPPNil6vt5y79md35513KomJiZZz3333ndK5c2dFp9MpX3/9teW4wWBQ7r//fkWn0yn/+te/lPPnz1vOnTx5Uhk2bJii0+mU//znP2XaN3DgQEWn0yk7d+606X0KxyA5YTtTFIXLly+ze/dunnzySS5duoSfnx9PPPFEubJubm5MmzYNjUYDYHk49sEHH5CXl8f999/PtGnTyvSOBg8ezIwZMwDKpAEOHDhAfHw8/v7+LF68mIYNGwKg1WoZP348//jHP2x+D5999hlZWVl069aNuXPn4uPjA5g3Jh03bhwDBgygpKSEb775psq63nnnHQCef/557r777jLvfdKkSQwbNszyNb3UunXryMvLo3fv3jzzzDOWNWV9fHx47bXXKkxfqHHmzBnS09Px9PTklVdesaSNwJxCeuaZZwDIzc0lMzOz3PUajYalS5fStm1by7GhQ4da0iWrVq2yHN++fTtHjx6lTZs2LFmyhMaNG1vOhYeHs2TJErRaLevWrePixYvX/d6EfUkQvsEG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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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aLVa0tLSuHDhQoXr+/Tpw4EDBxg4cCDt27cnJyfH0jOePn06N910k6Wsu7s777zzDhMmTGDXrl3069ePiIgISktLSU5Oxmg0EhISwrvvvntN9yQcg/SE64m77rqLL7/8kuHDhxMQEEBCQgI5OTl07dqV5557jmXLllVY4hocHExsbCyTJ08mNDSUxMREtFotMTExvP7666rev0+fPmzatInhw4fj6+tLQkICRqORQYMGsXbt2gobpM+dO5fevXujKArJycmkpKRYzj377LOsXLmSAQMGYDKZLLne2267jXfffdfqBuk9e/Zk48aNDBs2DG9vb06ePEloaCivv/46o0aNUnUv1vj7+/P555/z8MMPEx4eTnp6OikpKbRu3ZqYmBg2bdrEXXfdBWA14Hfu3Jm1a9fSu3dvkpOTuXz5Mrfccgsffvih1YU5ERERbNq0iYkTJ9K2bVuSk5NJTU2lVatWjB8/ni+++IIWLVpc830J+9Motg6BCyGEqHXSExZCCDuSICyEEHYkQVgIIexIgrAQQtiRBGEhhLAjCcJCCGFHEoSFEMKOJAgLIYQdSRAWQgg7kiAshBB2JEFYCCHs6P8BhoJvBHgBmAYAAAAASUVORK5CYII=\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.9278612232551104\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>40.540541</td>\n",
       "      <td>28.378378</td>\n",
       "      <td>12.972973</td>\n",
       "      <td>7.837838</td>\n",
       "      <td>5.765766</td>\n",
       "      <td>4.324324</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>40.540541</td>\n",
       "      <td>28.378378</td>\n",
       "      <td>12.972973</td>\n",
       "      <td>7.837838</td>\n",
       "      <td>5.765766</td>\n",
       "      <td>4.324324</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     40.540541  28.378378  12.972973  7.837838  5.765766  4.324324\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  40.540541  28.378378  12.972973  7.837838  5.765766  4.324324"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "factors = [0.01, 0.02, 0.05, 0.1, 0.15, 0.2]\n",
    "pred_labels = clf.predict_proba(test_x)\n",
    "\n",
    "print(\"AUC score:\", roc_auc_score(test_y, pred_labels[:, 1]))\n",
    "\n",
    "list = []\n",
    "for factor in factors:\n",
    "    list.append(enrichment_factor(test_y, pred_labels, ratio=factor))\n",
    "\n",
    "df = pd.concat(list, axis=1)\n",
    "df = pd.concat([df, df.agg(['mean'])]) \n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "548daef6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tda",
   "language": "python",
   "name": "tda"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
