{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0b119b7e",
   "metadata": {},
   "source": [
    "### Random Forest Model Training with Betti Vectorization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "47d6ddeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from sklearn.model_selection import RandomizedSearchCV\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.metrics import plot_confusion_matrix, roc_auc_score\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from src.utils import enrichment_factor"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc50db6c",
   "metadata": {},
   "source": [
    "## Target HIVPR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 37674/37674 [00:04<00:00, 8897.82it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_bond_strength_superlevel_betti/target_hivpr/\"\n",
    "\n",
    "for file in tqdm(os.listdir(path)):\n",
    "    if file.endswith('pkl'):\n",
    "        with open(os.path.join(path, file), 'rb') as f:\n",
    "            X.append(pickle.load(f))\n",
    "        target_label = 0 if \"active\" in file else 1\n",
    "        y.append(target_label)\n",
    "\n",
    "active_ind = [i for i, label in enumerate(y) if label == 0]\n",
    "decoy_ind = [i for i, label in enumerate(y) if label == 1]\n",
    "\n",
    "# shuffle the lists\n",
    "random.shuffle(active_ind)\n",
    "random.shuffle(decoy_ind)\n",
    "\n",
    "# Use 90% of the actives for training \n",
    "num_actives = len(active_ind)\n",
    "num_training = int(0.9 * num_actives)\n",
    "active_training_ind = active_ind[:num_training] \n",
    "active_test_ind = active_ind[num_training:] \n",
    "\n",
    "# Use same number of decoys as actives in training (avoid imbalance)\n",
    "decoy_training_ind = decoy_ind[:num_training] \n",
    "decoy_test_ind = decoy_ind[num_training:] \n",
    "\n",
    "# training and test index lists\n",
    "training_ind = active_training_ind + decoy_training_ind\n",
    "test_ind = active_test_ind + decoy_test_ind\n",
    "\n",
    "train_x, train_y = [X[i] for i in training_ind], [y[i] for i in training_ind]\n",
    "test_x, test_y = [X[i] for i in test_ind], [y[i] for i in test_ind]\n",
    "\n",
    "# flatten\n",
    "train_x = [x.flatten() for x in train_x]\n",
    "test_x = [x.flatten() for x in test_x]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5230175d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting 3 folds for each of 100 candidates, totalling 300 fits\n"
     ]
    }
   ],
   "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.9904382470119522"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# clf = RandomForestClassifier(n_estimators=rs.best_params_[\"n_estimators\"], \n",
    "#                              min_samples_split=rs.best_params_[\"min_samples_split\"],\n",
    "#                              min_samples_leaf=rs.best_params_[\"min_samples_leaf\"],\n",
    "#                              max_depth=rs.best_params_[\"max_depth\"], \n",
    "#                              bootstrap=rs.best_params_[\"bootstrap\"],\n",
    "#                              criterion=rs.best_params_[\"criterion\"],\n",
    "#                              random_state=0,\n",
    "#                              n_jobs=1)\n",
    "\n",
    "# clf = RandomForestClassifier(n_estimators=100, max_depth=9, random_state=0, criterion=\"gini\")\n",
    "\n",
    "# Very large numbers of base estimators may take a long time to prepare, but will not overfit the training data.\n",
    "clf = RandomForestClassifier(n_estimators=1000, \n",
    "                             min_samples_split=2,\n",
    "                             min_samples_leaf=2,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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hQsXAPjb3/5m9J7fw/NUHTlyhNGjR6PX62nbti22trYcPXqUadOmERERkS/4AS5evMjAgQNJSUmhdevWNGvWjOPHj/P+++9z5swZPvzwQ/UVLgZVgd64ceNCAz0jI4N79+6RlJSERqPhxRdflBujQgjTlXE3Snh4OAALFiwockReRkYG//rXvwBYs2YNHTp0AODGjRsMHjyYzz77jOeee46mTZvmVltRmD59OikpKXzwwQf07t0bgISEBIYMGcKOHTt47rnn6N69e6lfk6pA37JlyyPLnDx5kpkzZ/L777+zadMmkysmhKi6HkcL/eLFi7i6uj5yePX27duJj4+nT58+hjAHqFOnDtOmTWPatGmsW7eORYsWAbmt+UuXLtGuXTtDmEPusO85c+bQv39/1q1bVyaBXuodOU8++SRLly7l+vXrLF++vLRPL4SoCsr4SdHo6GiSk5Np0qTJI8seOnQIgK5duxbY17lzZywsLDh48GCB8t26dStQvnXr1tSoUYNTp06RkpKirtLFUCY9802aNMHX15ddu3aVxemFEJVdGQd6Xv95jRo1mDdvHs899xzNmjWje/fuLF++nMzMTEPZK1euABAQEFDgPA4ODri7u5OQkMC9e/cAiIiIKLQ8QL169dDr9Vy9elVdpYuhbG61AhYWFsTFxZXV6YUQlVhZL3CR13++ZcsWvv/+e/z8/GjRogWxsbGEhITwxhtvGFZiy8sxNzc3o+fK254X6Hfv3lVVvjSVyTj006dPExERgYeHR1mcXghR2Zk4bDEmJgYLC4t8u5ycnHBycsq3La+F3qNHD4KDgw3Tgt+8eZNx48YRFhbGkiVLmDlzJunp6QDY2NgYfeu87Xmz0KotX5pUBfo333xT5P6srCwiIyPZsWMHYLzPSQghHsnEQB8wYECBlu/48eOZMGFCvm0hISFER0dTp04drKysDNtr167NwoULefnll9m4cSNTp07FwsLCMAy7KHq9HsDwgVLc8qVJVaDPmzevWOPQFUWhTp06jB071uSKCSGqLlNHuaxfv95oC/2vrK2t8fPzM3quRo0aUatWLe7cucP169extbUlOTmZzMxMrK2tC5TP65qxt7cHwNbWNt/2R5UvTaoCvW3btkWfzNISJycnWrVqRd++fWXVIiGE6UwYilirVi2joauWq6srd+7cIT09HXd3d5KTk4mL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9u3LlStXWLt2LVOmTGHBggXUrFmTmzdvGm6+jhs3jm7duhnO5eDgwOLFixk9ejSbNm1i165d1K1bl6ioKJKTk1VdS2H69evHN998w61btwgKCsLHxwcbGxuioqJIS0vDy8sLrVZLdHQ0d+/eLXB8YGAgJ06coGvXrvj7+5OYmGhosU+fPp0OHToYylpZWbF8+XKGDx/OgQMH6NSpE35+fmRnZ3P9+nV0Oh21atVixYoVJbomUflIC72S6NGjB9u2baNv375Ur16dS5cukZiYSLNmzXj77bf5/PPPCzwm7ubmxvr16xk3bhxeXl5ERESg1WoZP348H374oar3DwwMZPv27fTt2xcHBwcuXbqETqejW7dubNiwocBiEcHBwbRv3x5FUbh+/TpRUVGGfW+99RarV6+mS5cu6PV6Q994x44dWbFihdHFItq0acOWLVvo06cPdnZ2XL58GS8vLz788EMGDBig6lqMcXJyYtOmTQwePBgfHx9u3bpFVFQUdevWZfz48Wzfvp0ePXoAGP3waNKkCRs2bKB9+/Zcv36d5ORknn76ab744gujD5H5+fmxfft2xowZg6+vL9evX+fGjRvUqVOHYcOGsXXrVjw9PUt8XaJy0SjFHcoghBDCrEkLXQghKgkJdCGEqCQk0IUQopKQQBdCiEpCAl0IISoJCXQhhKgkJNCFEKKSkEAXQohKQgJdCCEqCQl0IYSoJCTQhRCikvh/xTgAv68nQcAAAAAASUVORK5CYII=\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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Hpo0aUJcXBwZGRmqvktZnn/+eb744gsuXbpE37598fPzw9HRkbi4OHJycvD29kar1RIfH8/Vq1dLHN+xY0eOHTtGly5dCAoKIi0tzVwjmDp1Kg888IA51t7enuXLl/Piiy/y008/0alTJwIDAyksLCQ2NhaDwUCjRo1YsWLFLX0nIaQGcJfo3r07X331FX369KF27dpERESQlpbGPffcw+uvv87HH39cYtmABg0asGHDBsaNG4e3tzeRkZFotVrGjx/Pu+++q+r6HTt2ZOfOnfTp0wdXV1ciIiIwGAx07dqVjRs3lni5yoIFC+jQoQOKohAbG0tcXJx533/+8x/WrFnDY489htFoNLftP/zww6xYsaLUl6u0bduW7du307t3b5ydnTl37hze3t68++67DBw4UNV3KY27uztbt25lyJAh+Pn5cenSJeLi4mjSpAnjx49n586ddO/eHaDUZNOyZUs2btxIhw4diI2NJSMjg4ceeohPP/201El/gYGB7Ny5kzFjxhAQEEBsbCwXLlzA19eXESNGsGPHDry8vG75e4maTaNUdKiHEEKIu4rUAIQQooaSBCCEEDWUJAAhhKihJAEIIUQNJQlACCFqKEkAQghRQ0kCEEKIGkoSgBBC1FCSAIQQooaSBCCEEDWUJAAhhKih/h+PtzHUSHCaiAAAAABJRU5ErkJggg==\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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+vRpdDqdxWMuXrzIgQMHKt38qngux48ft3hOda+LGps3b+bSpUt07NiRDRs28OCDD9KnTx/z8G1LN+OuVJEy+auMjAwKCwvRarWEhYUBf74ONdU7MTGRkydP1ssXjLAtCcKNQEWf2U8//dTi/q+++oqoqCjuvvtuc4ts+PDhgOkGl6UA8vnnn1t9/YqBGFu2bKn2+gcOHCAvL8+8reIG3pWt7fDwcIKDgykpKam2rDfeeIMJEybw+OOPm7dVPJfNmzdXyccajcZqy1IjMzMTgLCwsEo34Sps2rTJ/N+WVgpOSEgw5+6vtH79egD69Olj7nExZMgQAL744gvKysqqnJORkcHEiRO56667SExMVP9khF2RINwIPPLII7i5ufHVV1+xdOnSSh/cPXv2sGDBAgDuvfdec360R48eDB06lJKSEmJiYsw3egA2btyoau6KCRMm4Ovry/79+1m0aJH5+oqisHbtWrZu3YqLiwsTJkwwn1ORejhz5ox5m0ajYdq0aQAsWrSIrVu3mvfp9XpiY2OJj48HqHTj7r777iMoKIj//e9/PP/88+bWYVlZGS+88EK1rX01Klr7P//8M4cOHTJvLykp4f3332fVqlXmbZYCp06nIyYmptIX3saNG1mzZg0ajYbp06ebt995552EhoaSlpbGjBkzzD1awNSinjZtGnq9nq5du1Y7ElI4DskJNwLh4eEsWbKEp59+mpUrV7J27Vo6dOhAbm6uuQU3cOBAc1/WCi+99BKTJ0/m0KFDjBgxgoiICHJycjh79ixDhw61el7ali1b8uabbzJjxgw++ugj4uPjad++PWfPniU7OxsnJycWLFhgDmRg6n1x8OBBnnjiCcLCwnj88ce56aabGDt2LElJSaxZs4YnnniCV155haCgIE6fPm2+ATh9+nRGjBhhLsvb25ulS5cyZcoUNm3axLZt22jfvj1paWnk5+erei7Vuffee1m3bh2ZmZncd999hIaG4u7uTlpaGsXFxQQHB6PVasnIyOD8+fNVzh80aBD79+9n+PDhdOrUidzcXHPL+Omnn+aGG24wH+vq6sq7777Lww8/zK5duxgyZAjh4eGUl5eTmpqKwWCgVatWrFix4qqek7AP0hJuJEaOHMkXX3zB2LFjad68OSdOnCA3N5eePXvyzDPP8P7771cZ4hoYGEhcXBzTp08nODiY5ORktFotMTExvP7666quP2jQILZs2cLYsWPx9vbmxIkTGAwGRowYwfr166tMkL5o0SL69++PoiikpqaSlpZm3jdv3jxWr17NsGHDMBqN5lzvTTfdxIoVKyxOkH799dcTHx/PmDFj8PT05OTJkwQHB/P6668zfvx4Vc/FEl9fXzZt2sSDDz5IaGgomZmZpKWl0b59e2JiYtiyZQsjR44EsBjwu3fvzvr16+nfvz+pqank5+czcOBAPvzwQ4sDc8LDw9myZQtTp04lLCyM1NRU0tPTadeuHZMnT+bzzz+nTZs2V/28hO1pFGtvgQshhKh30hIWQggbkiAshBA2JEFYCCFsSIKwEELYkARhIYSwIQnCQghhQxKEhRDChiQICyGEDUkQFkIIG5IgLIQQNiRBWAghbOj/AffPXxmnSkjAAAAAAElFTkSuQmCC\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.9955966928799843\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>92.142857</td>\n",
       "      <td>46.785714</td>\n",
       "      <td>19.571429</td>\n",
       "      <td>9.857143</td>\n",
       "      <td>6.571429</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>92.142857</td>\n",
       "      <td>46.785714</td>\n",
       "      <td>19.571429</td>\n",
       "      <td>9.857143</td>\n",
       "      <td>6.571429</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     92.142857  46.785714  19.571429  9.857143  6.571429     5.0\n",
       "1           NaN        NaN        NaN       NaN       NaN     NaN\n",
       "mean  92.142857  46.785714  19.571429  9.857143  6.571429     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)"
   ]
  }
 ],
 "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
}
