{
 "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 AMPC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████| 2964/2964 [00:01<00:00, 2093.50it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_MorganFeatures/target_ampc/'\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.9489795918367347"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clf = RandomForestClassifier(n_estimators=1000, \n",
    "                             min_samples_split=2,\n",
    "                             min_samples_leaf=4,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=2)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26957a38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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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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Q0MxGo2kpKRUKE9OTsZkMpUbP2xNWfn58+etlpfNJm7UqFGV9agKwn369OHEiRMkJydXeV5mZiYnTpygR48eaqoXQgig5ukIWw0cOBCALVu2VCgrOzZo0KAq67jtttss5/+1R63X60lISADMOeKqqArC06dPx9vbm+joaJKSkqyek5mZyZQpU3B1dWX69OlqqhdCCLMajo6wVUREBB4eHsTGxnLo0CHL8YMHDxIXF4enpydjxoyxHE9LS+PkyZOWEREA/fv3p2PHjqSkpDBv3jyMRiNg3gbu9ddf5/Tp09x6661WxyJfrdLREU899ZTV482aNePEiROMGDGCnj170rFjR7y9vSkqKiIlJYWEhAT0ej0DBw5k06ZNdOzY0bavihBCXFHTccK2atWqFTNmzGDOnDmMHj2avn37ApCQkIDBYGDBggXl0ggTJ04kIyOD+fPnExERAYCLiwtvv/02jzzyCKtWrWLbtm106tSJ48ePk5aWRvPmzZkzZ061bak0CH///fdVXmgymdi7dy979+61Wr5jxw527txZ5bQ/IYSwqi6nzF0xduxYWrRoQVxcHPv378fd3Z0ePXoQHR3NLbfcYlMd7du358svv2TZsmVs3bqV7du3ExQUxNixY4mOjiYoKKjaOioNwjExMbbfjRBC1KK6XjuiTHh4OOHh4dWeV9V+mY0bN+aFF17ghRdeqFEbJAgLIYQdXdMCPkIIUSeuQzrCUdQoCBuNRjIzMykqKqowFthgMKDX6zl//jxbt25l3rx5tdJQIUR9ornyUnO+c1IdhGNjY4mNjS03VKMqEoSFEKpJT9i6TZs28dZbb9l0bps2bbjrrrtq1CghRD1Xj4Kwqska//3vfwG499572b59O3v27MHFxYUHH3yQgwcPsnnzZh5//HFcXFwwmUxMnjy5ThothLjBqZqyXI+2vD98+DBeXl689NJLNG3alIYNGxIaGsquXbtwc3OjdevWPP300zz11FNkZGRUWMdTCCFsUdfTlh2JqiB8+fJlWrduXW4Low4dOnDmzBlyc3MtxyZMmICnpyc//PBD7bVUCFG/1NGUZUejKgh7e3tX2DOpdevWAJw8edJyzNPTk+DgYFJTU2uhiUKIekfSEda1bt2a9PR0CgsLLcfatm2LoigcOXKk3LnFxcVW1+oUQojqaBT1L2elKggPGDCAwsJCXnzxRfLz8wHzTqMA69ats2z3ceDAAVJSUipd7FgIIapUx6uoORJVQXjChAkEBATw7bffMnDgQPR6Pe3bt6dv374cOXKEiIgIpk2bRmRkJGAO2kIIoZqkI6xr1KgRH374IZ06dcLd3d2yXfTzzz+Pv78/SUlJbNq0iYKCAlq0aMGTTz5ZJ40WQtzg6lFPWPWMuU6dOrF+/XrOnj1rOabT6di4cSPr1q0jIyOD4OBgHnjgAfz8/Gq1sUKIeqIeTdao8QI+zZs3L/fvxo0b8/jjj19zg4QQQoKwEELYldo8r/PmhCsNwqNGjbrmyjUaDWvXrr3meoQQ9YvaYWfOPESt0iB89eZ3NfXXiR1CCCHKqzQIz58//3q2Qwgh/iQ5YbjvvvuuZzuEEKJeqhcP5g7c7ULOWRd7N6NO3L8X9na7Me8N4Iczy+3dhDqTmHE7P3x6Y95fiSGIw5kDa3y95ISFEMKeFNSNjpAgLIQQtUhywkIIYUcShIUQwn4kJyyEEPbmxIFVDQnCQgjHI+mI6hmNRv744w9OnTpFfn4+48aNo7S0lLNnz9KmTZvabKMQop6RdEQ1PvnkEz744AOys7Mtx8aNG0d6ejr33HMPw4YNY968efj6+tZaQ4UQ9YjahdqdeFF31UH4+eefZ/369SiKQoMGDdDr9RQXFwOQlZWFyWRi8+bNpKenEx8fj5eXV603Wghxg6tH6QhVO2t8//33rFu3jqCgIGJjY0lISKBTp06W8j59+rBy5UqCgoI4evQoH3/8ca03WAhx45ONPiuxevVqNBoN77zzDgMHWp+S2Lt3b9577z0UReG7776rlUYKIeoZ2d7IusOHD9O6dWu6d+9e5Xk333wzbdu2JTU19ZoaJ4Sop9T2bp04CKvqCZeUlODt7W3TufJQTghxTepBLxhUBuHmzZuTnJxMYWFhlefl5+eTlJREs2bNrqlxQghxo1MVhMPDwykpKeG1116r8rx58+ah1+sZNGjQNTVOCFFPSU7YuqioKDZs2MDatWtJS0tj+PDh5ObmAuZ88cmTJ/nvf//Lvn378Pf3Z9KkSXXSaCHEjU0ma1QiMDCQ2NhYpkyZwp49e0hISLCU3X///QAoikJAQABLliyhadOmtdtaIYS4waierNG5c2e++eYb1qxZw9atW0lKSqKgoAAvLy/atm3L4MGDGTNmDIGBgXXRXiFEfVCPJmvUaNqyr68vjz76KI8++mhtt0cIISQdIYQQdiU9Yeu+/PJL1W8wcuRI1dcIIeo5CcLWzZw5E43GttWKFEVBo9FIEBZCqCbpiErcdNNNlQbh4uJisrKyyM3NRaPRcM8998jDOSFEzV2HwLp7926WLVvGsWPHKC0tpXPnzkRFRXHbbbfVuM7HHnuMnTt38sknn9C3b99qz1cVhNevX1/tOfv27WPmzJkcOnSIzz//XE31QggBXJ+e8Pr165k1axbu7u7069cPk8lEQkICUVFRzJkzh4ceekh1nfHx8ezcuVPVNapmzNmiV69evPPOO6SkpPDee+/VdvVCiPqgjmfMZWZmMnv2bPz8/Fi3bh2xsbEsX76c+Ph4fH19mTt3LpmZmarqTE1N5Y033lDXEOogCIN5LHFISAibNm2qi+qFEDe6Og7Cq1atQq/XM3HiRHQ6neV4165diYqKoqSkhDVr1thcn9FoZMaMGbi5uZWrzxZ1EoQBXFxcuHDhQl1VL4S4gdX1ou5lKYNhw4ZVKCs7tmPHDpvri4uLIzExkRdffJFGjRqpakudBOH9+/eTlJRE48aN66J6IcSNrg57woqikJSUhFarJSQkpEJ5cHAwWq2WpKQkFKX6io8ePcqSJUu48847uffee21vyBWqHsytWrWqynK9Xk9ycjJff/01AEOHDlXdICGEqMtxwrm5uej1egIDA3F3d69Q7urqSkBAANnZ2RQUFFS5Nrper+ff//43/v7+vPTSSyoafNX7qTn5lVdesWmcsKIotGnThieffLJGjRJC1G81HR1x7tw5XFxcypX5+/vj7+9v+XdRURFAlZsQe3p6AlQbhN955x2OHz/Oe++9V+MhuaqCcO/evauuzNUVf39/unfvzqhRo2R3DSFEzdVg2NmYMWPIysoqdywmJoapU6da/q3V2p6FrSod8euvv/Lhhx8yYsQIq7llW6kKwitXrqzxGwkhRF2Lj4+32hO+WtkWbSUlJZXWU1xcXO7cvyosLGTmzJkEBQXx4osvXkuT1QXhSZMm0aRJE5577rkKNyaEELWlpumIZs2a4eHhUeW5vr6+eHt7k5OTg8FgwNW1fBg0GAzk5OTg4eFRaZxbvXo1aWlphIWFMWfOnHJlSUlJACxbtoy1a9cyevRoevXqVWl7VAXh33//HV9fXwnAQoi6VYcP5jQaDaGhoRw4cICUlBRCQ0PLlScnJ2Mymaoc71u2z+axY8c4duyY1XN2794NQP/+/WsvCAM0aNBA7SVCCKFOHa+iNnDgQA4cOMCWLVsqBOEtW7YAVLlH5tSpU8vlma82ceJEfv75Z5vXjlA1TnjEiBGcOHGCH374Qc1lQgihmkbFS62IiAg8PDyIjY3l0KFDluMHDx4kLi4OT09PxowZYzmelpbGyZMnycvLq/H9VEZVT3jEiBEcOXKEmJgYunXrRrdu3WjSpInVsXZlxo4de82NFELUM3XcE27VqhUzZsxgzpw5jB492tJjTUhIwGAwsGDBgnIz3yZOnEhGRgbz588nIiJC3ZtVQ1UQfvjhh9FoNCiKQmJiIr/99lu110gQFkKodT1WURs7diwtWrQgLi6O/fv34+7uTo8ePYiOjuaWW25RX2EN1eo4YSGEqBXXaWeN8PBwwsPDqz1v69atNte5YsUKVW2oNAifOXMGDw+Pcl1yGScshLgu6tH2RpU+mBsyZAhPPfXU9WyLEEIAVx64qVlFzd4NvgZVpiNsWUFICCFqXT3qCcuW90IIhyMbfQohhD1JT1jUBd8GBsY9k0n/4bkENjGQm+3Cvm3+rHq7KeczKh9rXVV9LRt8zCe/HLa5vpc/Tqbf7ZcrrfPCGTfG9bpJdVvqg7xLLnz6djN2f9eAi+ddadDIQK/BeYx95hxNW5Wqru9c0gXmv9qW33f7UpjnQtM2JQy4O5f7oi7gH2C0es3jQ8JIOVr5Eoyde+fz9oYk1W1xNNITviI7O5svv/zymt5g5MiR13T9jcK3gYGFXyXRpkMJBXlako940ryNnrsevsitw3P59/3tST5S+S9XZfU18f2DAsX2+oI7mtdSPbzPG5OpYr2XstxqfI83srxLLjw9ogPpSZ54+xpp16mYs2nufP9ZI3Z914A31iURclOxzfXt/q4B70avwKAPwMPLSBtdMRfOuBG/qBlb1gYyb/VJWoeWX+XLUAqnT3rg4qrQsXuB1XrbqWiDQ5OesFlqaiqzZs2qceUajUaC8BX/fOM0bTqUkLDFj/nRbSkqcMHNw8S0105zx0M5zFqayhNDwjCZbHvOW1ZfbnE3HulhsKk+b18jzVqXUpCn5ekRHerqVm9Ii/7dmvQkT/oMzWXW0lS8fU3oizUsntmKzf9txPzoYJZtPcpfVlG06lyaOwumtsGgN9L/rktMX5iObwMjRiN8+lYz4hc144VxIcRuO4q755/RJe2EJ4ZSLcEdi26I3m6VJAibubu7q960TlTUOrSYW+/OpTBfyxvT2lBUYP5NLS3RsnB6a8K6F9JWV0L/4bn8tLGhqvpSL0+hqOBdm+oL7mTuJaUd96z1e7yRpZ3wYNe3DfDyMfLvxWl4+5r/hHD3VHj6rXSOJfqQdsKT3d81YOA9udXWt+4/QRQXutCkXWOeW/Y7bu7mCOLiAo88e45Dv/hwYLcfXy4P4sEp5y3XlaUh2upukN5uFSQdcUWXLl2q3Vfueli/fj2zZs1i1apVVS4J56iGROSg1ULCZn/yLpX/kptMGjatCSTqxbMMGnHJpiB8dX0N+5TfvaSq+tpdSUWkShBWZev6ABRFQ9/bL1fI1bq4wB0PZRP3aku2fxVgUxDev90PgP4P9sDNfUuF8hETsziw24+tXwSUC8LJR8zft7ZhN34Qrk/qbMv72pKYmMgrr7xi72Zck449zGuPHt7nY7X86K/m1fu79LWe56ut+tpd6QmnHpMgrMbR/eav8029rH9/OvY0fz8OJVj/fvzV+TPmh6YtOjazWt6inTkXnHrUk+LCP9NJZTn+ehOE62CnZUfk0KMjvv/+e2bNmmVZQNlZtQjWA+ZcoDWZV0YyBDYx4OltpLiw6sRiTesrC8LnT7txz4Qsug3Ix7eBkayzbuz6rgE/fy9rRVtzJsX89WzWRm+1vGlL8/GcC24UFWjx8rHyxNMKk9H6eUaDOfCaTBqyzrrTqr05KJf1hAMaG1i7NIhDCb4UF2ppEVzC4JGX+Fv/fNtvysFpFAWNislias51NA4ZhM+dO8fbb7/Nhg0b8PLyonHjxhU273MmDRoZALicYz245l11vEFg9UG4pvWV9aCmL0q35DXL3P5gDr/84Mfcx9tW+/71TW62+dfEP8BgtdzvqhRF7kVXvHysB+syzVrrSTvhybmkC1bLr04X5ee6WP4/66z5w+D5sSGW5woAv/3kx7efNuaOh7L55xvpuDjkb7VK9ejBnEOmIxYtWsSGDRvo0qULa9asISQkxN5NuibunuaApy+2/uW++njZubVdX1BLPX4NzcHibKo7sx4OYUT7Loy6qTNv/rM1ly+60GdoHtMXpttwR/VL2dezsu/N1cf1xdWPbuk7zJw33vlpAvqS8uebTLBuWRPLv0tLzeVlvWAAXbdC3t5wnK9O/s7q3w7x+EsZuHua2LSmER/Oa2HjXTk2VetGqHyI52gq/cyMiYmhefPm17MtFiEhISxYsIARI0ao2p7aUZmMGlxcKv8p0ai8xZrUp5hg7dIg/BoaWfpiC0tvt6QINv83kLTjniz8+gS33ZvLuv8UWPKgArQuSpVDBxXbsg8W902+wPefNSL79CVeGBfC5P87Q3DHIs6mevDhvOZkJHvg4WmipFiLq6v5++zX0Mh9UecxGTU8/nKGZSich5eBiMkXCGqp59WodnwRF8Q/Hr1Ak5bqJ484lHrUE64yCNvL5MmT7fbedaG4UIubuxE3D+u/rW7ufx4vKao+Itekvqyz7sS9Unkv6dhv3iTu9KXX4Hz63X5ZgvBVPL1N5OdqKS2x/r0p1f953MOr+ojcqKmBl1ac4oUJXfl9F0y5M8xS5uVjZNb7KSyc3oaSYi3efua/XoI7FvPEy2cqrXPg33NpFVLM6VOe7Nvmx91jL9p6e45Jbe/2RgzCovbk5bjg19BoSQf8lf9fcorXu74yp/7wotfgfJq0qjqnWd/4BRjJz3Ul75L1XPnlcjl463njv+rcu5Bn1k4m9ftZHE00f+CF3lzI3WOzCWhiIP+yuc7AJrbVBxDSuYjTpzw5f1r9FHiHIz3hG8uMr6Lt+v4+jV4HEnnivXCyCm6vWO5+BJhDqbEhL+94TmV98NremTbWp6DBgIL1qckt/FcB39Dtrr/x2t4nbL29OpWYYe8WQINWazmbcpJ9B6NxDetRofxUYhoQj19jX47krIYc2+r1DYDOo9+h8+g/j2UACTvOYTKuwD/Il6SCVXBlZJzJpGAymnB1s/5hkFP0JXCUC0WjSMwYoOYWHY5M1rjBLBixlJyz1Q+iryvjpp9j/HQ4uukL3vznrxXKH3jyPLoX4JdNJuY8+pqq+hrfejsze5e/xlp9k547w/2PX+C3Xb48P6a91XrnrT5J00Gw/u3jfL60+nZcD9+f+c3eTeBQn2Yc/akZ+ac+o3vL1yuUn/iyCdCCm3udpnvL0RUr+IuDCT4cS/TGrd0s/nHnMxXK//isKdCcngPSLPXNf7ItO75uyF0PZ/PU66et1vvuqY6AJ317rqR7y3fV3GKtKzEEcThzybVV4sSBVQ3nf+rlBHZ9ax5/2/+uXPwalv/zUqtVuP1Bc/5u67oA1fW5aMqPDa2svpN/eOHqBl37FdCkZcV0Q8hNRXQbkI/RCD9tlPHCV7v17ksA7P5fgwrDAo1G84NNgCH329YFPrrfm9g5Lfkpfm+FsoI8LRtXNgbgngnZluMhnYowGTX8/H0DCi5X/LXds8mf06fMiwv1HFz727Jfb/VpdIQE4esg+YgXCZv98PE38cIHqfhdGW/q5mHi6bfSaasrIT3Jg13flQ9+/oEGWocW07xtSaX1tWu00Kb6dn/XgDPJ7rh7KrwQm0LT1n/WqftbIS+tSMbFBTZ+0ohzaR519aVwSiE3FdNnWC6FeS68OjmYyxfNgVhfrGHh9NaknfCkVftibh1e/q+t3GwX0k54WCZ7lOl/Vy5u7iYObjnCj180tBy/eN6Vlye14+J5N/oMzS034/GuMdn4NjSQc8GN+U8Gcynrzz9i923z441/tgFgzNPn8PFTOVzDESmAoqh42bvBNVcv0hGOYPHMVrzVMYluA/L5dO8R0k540LyN/spDHy0vTwpGUcoPgxoRmcX46ZmcS3fjkb43Wa2vWevDfLpXW219pXotr0QFM/+zU4R1K+LDn46SccoDrQuWJRP3bPbnPy/dGONMa9u0104zfaQXv+/yY1zvm2jToYSzae7kX3LFx9/I7A+T+etoyq8+CuLTt5vRtJWeT345bDnesp2eqBfP8P6LrXhtSjAfvVaCr7+RtBOelOq1dOhayMz3U8vV1aCRkeeWpjDn0Xbs3erPuN430ap9CUX5WsuH5t3jsxj1hPUJIM6mPuWEpSd8nWSddSfmLh1fxDXmUrYL7ToVYzRq+PGLhky9W0d6krr1HMrqO59/l831nTrsxRNDdaz7T2My091pHqwnIKiUQwk+vPV0a2Y/EoyhVH4krAlqUcq7/zvGyEcv0LCRkeQjnri4KAwemcOSb4/RpkNJ9ZVc5R+PZjHu9fu4uV8+ly+6knbCkxbtSpg48wxvfXHCam+256B83t98jLvGZBPQ2ED6CQ8K8lzocdtlZi9P5qkFp9E4846XV1OzboSTrx8hPeHrKC/HlWX/15Jl/9fSpvM/fasZn75lfZGXsvoych9hZt+zNrch54IbH7zckg9etq0N4k/+gUaiX8kg+hXbhmyM/9c5xv/rXKXlXcLDGD9O3brALdvpefrNG39Wo8Zkfqk531lJEBZCOB4ZJ+xYVq5cae8mCCGuIw0qc8J11pK6JwlAIYSwI6foCQsh6pmyoWdqzndSEoSFEA6nPg1RkyAshHA88mBOCCHsR3rCQghhT5ITFkIIO5JF3YUQwo4kJyyEEPZTnyZrSBAWQjgek2J+qTnfSUkQFkI4HklHCCGE/cgQNSGEsCcZoiaEEPYjPWEhhLAnyQkLIYT9aFDQqEgxaJw4CksQFkI4HtOVl5rznZQs6i6EEHYkPWEhhMPRKCrTETUcHbF7926WLVvGsWPHKC0tpXPnzkRFRXHbbbfZXMf27dv55JNPOHjwIIWFhQQFBTFw4ECefPJJmjWrfKPeMtITFkI4nuuw5f369euJjIwkMTGRrl270r17dxITE4mKimLNmjU21fHBBx8wefJkdu/eTbt27SzBe82aNdx3332cPHmy2jqkJyyEcDx1PE44MzOT2bNn4+fnR3x8PDqdDoADBw4QGRnJ3LlzGTx4ME2bNq20jqSkJBYuXIi3tzcffvgh3bt3B6C0tJR58+YRHx/Pc889V21Al56wEMLhlI0TVvNSY9WqVej1eiZOnGgJwABdu3YlKiqKkpKSaoPnhg0bMJlMREZGWgIwgJubG8899xyBgYH89ttvZGRkVFmPBGEhhONR+LM3bNNLXfU7d+4EYNiwYRXKyo7t2LGjyjrc3NwICwujd+/eVstatWoFwPnz56usR9IRQgiHo1FAo2LYmZqesKIoJCUlodVqCQkJqVAeHByMVqslKSkJRVHQaKwvlDlt2jSmTZtmtaywsJCkpCSAah/OSRAWQjieGuaEz507h4uLS7kif39//P39Lf/Ozc1Fr9cTGBiIu7t7hapcXV0JCAggOzubgoICfH19VTc/NjaWwsJCbr75Zpo3b17luRKEhRCOp4bTlseMGUNWVla5opiYGKZOnWr5d1FREQBeXl6VVufp6QlQoyC8fft2/vOf/6DVavn3v/9d7fkShIUQjkflOOGynnB8fLzVnvDVtFrbH4UpKkddbNu2jWnTpmE0Gpk+fTp9+/at9hoJwkIIx1PDdESzZs3w8PCo8lRvb28ASkpKKj2nuLi43Lm2+Pzzz5k9ezYGg4GYmBgmT55s03UShIUQjqcO147w9fXF29ubnJwcDAYDrq7lw6DBYCAnJwcPD48KvejKLFy4kGXLlqHRaJg1axYTJ060uT0yRE0I4XDKVlGz+aUigazRaAgNDcVoNJKSklKhPDk5GZPJVG78cGUUReH5559n2bJluLu78/bbb6sKwCBBWAjhiFSNEVaZugAGDhwIwJYtWyqUlR0bNGhQtfW89tprfP755/j6+rJ8+XLuvvtuVe0ACcJCCEdUx0E4IiICDw8PYmNjOXTokOX4wYMHiYuLw9PTkzFjxliOp6WlcfLkSfLy8izHduzYwYoVK3B1deU///kPffr0qdGtSk5YCOF46ng94VatWjFjxgzmzJnD6NGjLaMYEhISMBgMLFiwgEaNGlnOnzhxIhkZGcyfP5+IiAgAFi9eDECjRo347LPP+Oyzz6y+V3R0NO3bt6+0LRKEhRAO53osZTl27FhatGhBXFwc+/fvx93dnR49ehAdHc0tt9xS5bWXLl3i4MGDgHkxoK+//rrScx944AEJwkIIYU14eDjh4eHVnrd169Zy/27YsCHHjh2rlTZIEBZCOJ6yBXzUnO+kJAgLIRxPHa8n7EgkCAshHJDaEQ8ShIUQovbUo92WJQgLIRzO9dro0xFIEBZCOB7JCQshhB2ZFPNLzflOSoKwEMLxSE9YCCHsSUZHCCGE/chkjRtD2dYk/k387NySuhXQvIG9m1BnSgxB9m5CnbpR709vDATUbw9kITnhG0NpaSkA0XHj7NySujXjq2h7N6HOHM60dwvq1uHMJfZuQp0qLS21bJqpimIyv9Sc76Ru6CDs4+ODTqfDzc0NjUZj7+YIUW8oikJpaSk+Pj41rUAezN0ItFotfn43dipCCEdVox5wGUlHCCGEPcnoCCGEsB9JRwghhB3VoyFqstGnEELYkfSEhRCOx2Qyv9Sc76QkCAshHI/khIUQwo7qURCWnLCT2r17NxMmTKBv37706NGD8ePHs2PHDns3S6i0fv16wsLC2Ldvn72b4lgU5c+xwra8JAiL62n9+vVERkaSmJhI165d6d69O4mJiURFRbFmzRp7N0/YKDExkVdeecXezXBIimJS/XJWko5wMpmZmcyePRs/Pz/i4+PR6XQAHDhwgMjISObOncvgwYNp2rSpnVsqqvL9998za9YsCgsL7d0Ux2RC5Yy5OmtJnZOesJNZtWoVer2eiRMnWgIwQNeuXYmKiqKkpER6ww7s3LlzPPvss0ybNg2TyUTjxo3t3STHVJYTVvNyUhKEnczOnTsBGDZsWIWysmOSG3ZcixYtYsOGDXTp0oU1a9YQEhJi7yY5prIhampeTkrSEU5EURSSkpLQarVWf3mDg4PRarUkJSWhKIqsHOeAQkJCWLBgASNGjECrlT5QperR6AgJwk4kNzcXvV5PYGAg7u7uFcpdXV0JCAggOzubgoICfH197dBKUZXJkyfbuwlOQVFMKCp6t878YE4+ip1IUVERAF5eXpWeU7Z8YEFBwXVpkxB1oh7lhKUn7ETU/Pla421lhHAE9Wh0hARhJ+Lt7Q1ASUlJpecUFxeXO1cIpyTbGwlH5Ovri7e3Nzk5ORgMBlxdy3/7DAYDOTk5eHh44O/vb6dWCnHtFJOCoqInrOZcRyM5YSei0WgIDQ3FaDSSkpJSoTw5ORmTyVRu/LAQzsn0Z2/YlpcT5yMkCDuZgQMHArBly5YKZWXHBg0adF3bJEStu9ITtvXlzHvMSRB2MhEREXh4eBAbG8uhQ4csxw8ePEhcXByenp6MGTPGji0UQqghOWEn06pVK2bMmMGcOXMYPXo0ffv2BSAhIQGDwcCCBQto1KiRnVspxLXxD/JVNezMP8h5x8RLEHZCY8eOpUWLFsTFxbF//37c3d3p0aMH0dHR3HLLLfZunhA15uLigouLC9Fx42p8rbPRKDKgVAjhQAwGA0ajUfV1Li4uFUYMOQMJwkIIYUfyYE4IIexIgrAQQtiRBGEhhLAjCcJCCGFHEoSFEMKOJAgLIYQdSRC+Dk6fPk1YWJjVV8eOHenatSu33XYb0dHRVteEsIfjx49b2ni1mTNnEhYWxoIFC675PbKysrh8+fI111OdTz/9lLCwMMaPH2/T+evXrycsLIyIiIhrfu8lS5YQFhbGtGnTrrmu6gwZMoSwsDB+/PHHOn8vUXucb2Szk+vSpUu5rYkURUGv13P69Gm2bt3K1q1bGTNmDLNnz7ZjK+veihUrWLJkCatXr5ZlN0W9JkH4OnvnnXdo1apVheOlpaW8++67LFu2jPj4eAYOHMiQIUPs0MKqPfPMM0RFRREQEHBN9cyfP7+WWiSEc5N0hINwc3Pj6aefpnv37gDEx8fbuUXWNWnShPbt2xMYGGjvpghxQ5Ag7GDCw8MB89KUQogbn6QjHEzZNvVX75a8ZMkS3n33XZ599lm8vLxYunQpubm5tGnThvfee4+2bdsCkJ6eTmxsLD/99BPnz5/Hx8eHbt26MXHixEpXV7tw4QKxsbH88MMPXLhwgZYtW/Lwww/Tp08fq+fPnDmTL774gkmTJjFjxoxyZenp6XzyySds376dc+fO4enpyc0330xkZCQDBgwody9l7r33XgA++eQTy7KcAHv37mXFihUkJiZy+fJlGjVqxK233srjjz9uud+/OnLkCEuXLmX//v3k5+fTqVMnoqOjq/x6q5WVlcXKlSvZuXMn6enpFBUV4efnx0033cSDDz7InXfeWem1p06d4u2337YsO9qxY0cefvhhRowYYfX8/Px8VqxYwffff09aWhouLi7odDoiIiK4//77nXLFMFGRBGEHk5aWBkDz5s0rlG3atInffvuNli1b0rJlSwoLC2ndujUAO3fuZNq0aRQWFuLl5UWHDh24ePEi27ZtY9u2bUydOpWYmJhy9SUnJxMZGcnZs2fx9PSkQ4cOZGZmMnfuXHr16qWq3bt27eKpp54iLy8Pb29vQkNDuXDhAj/99BM//fQTc+fOZdSoUTRv3pwePXqwf/9+AG666SY8PT3x8/Oz1PX+++/zzjvvABAQEIBOpyM9PZ1169bx7bff8s4771TYPWTz5s0888wz6PV6AgICaN++PUePHiUqKoqePXuqupfKHDlyhMjISHJycvD29rbk9tPT0y33OX36dCZPnlzh2uTkZB588EEKCgro0KEDhYWF7N+/n/3797Nnzx7mzZtX7vzTp08zadIkUlNTcXV1JTg4GJPJRGJiIomJiWzatIn333+/3ENe4aQUUefS09MVnU6n6HQ6JT09vdLzLl26pPTr10/R6XTKK6+8Yjm+ePFiy/Vz585VTCaToiiKkp2dbam/R48eik6nUxYtWqSUlJRYrt2yZYulbPPmzZbjJpNJeeihhxSdTqdMmjRJycnJURRFUYxGo7J8+XIlLCzM8p5XmzFjhqLT6ZTXXnvNciw7O1vp27evotPplBdeeEHJz8+3vMdHH32k6HQ6pXPnzuXuvazuY8eOlav/+++/V3Q6ndKjRw9l48aNluN6vV557733LGUZGRmWsqysLMs9vvHGG0ppaamiKIqSn5+vPP3005b3GjduXKVf+6utW7dO0el0yn333Vfu+H333afodDrln//8p5KXl2c5npeXp0yfPl3R6XRKz549Fb1ebym7+nt3++23K0lJSZay//3vf0qXLl0UnU6nfPPNN5bjBoNBGTlypKLT6ZQnnnhCuXDhgqXs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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.8452101701313057\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>76.923077</td>\n",
       "      <td>38.461538</td>\n",
       "      <td>15.384615</td>\n",
       "      <td>8.461538</td>\n",
       "      <td>5.641026</td>\n",
       "      <td>4.230769</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>76.923077</td>\n",
       "      <td>38.461538</td>\n",
       "      <td>15.384615</td>\n",
       "      <td>8.461538</td>\n",
       "      <td>5.641026</td>\n",
       "      <td>4.230769</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     76.923077  38.461538  15.384615  8.461538  5.641026  4.230769\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  76.923077  38.461538  15.384615  8.461538  5.641026  4.230769"
      ]
     },
     "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
}
