{
 "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 AKT1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 17000/17000 [00:05<00:00, 3153.97it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_akt1/'\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.9907894736842106"
      ]
     },
     "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=1,\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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2msZN25ctaurZWdns3LlSr799luys7Np164djzzyCP369bNZ/qmnnuLTTz9l/PjxzJ49u9K5zMxMPvzwQ3bt2sX58+fx9vamV69eREdHc/PNN1d6LRXuueceAD788EPrspwA+/fvZ/Xq1SQlJXHp0iVatGjBTTfdxKRJk6yv96+OHj3K22+/zcGDBykqKqJ79+5Mnjy5xvdbrZycHNasWcOePXvIzMyktLSUgIAArrnmGh566CGGDRtW7bW///47r732mnXZ0W7duvHII49w77332ixfVFTE6tWr+eabb8jIyMDNzQ2dTsfIkSO5//77XXLFMFGVJGEnk5GRAUCbNm2qnNu2bRu//vor7dq1o127dpSUlBAWFgbAnj17mD59OiUlJfj4+NClSxfy8vL4/vvv+f7775k2bRqxsbGV4qWmphIdHc25c+fw9vamS5cuZGVlMX/+fPr27auq3j/++CMzZsygsLAQX19fIiMjyc7O5ocffuCHH35g/vz5PPDAA7Rp04Y+ffpw8OBBAK655hq8vb0JCAiwxnrrrbd4/fXXAQgKCkKn05GZmcmmTZv48ssvef3116vsHrJ9+3aeeOIJDAYDQUFBdO7cmWPHjhETE8N1112n6rVU5+jRo0RHR5Ofn4+vr6+1bz8zM9P6OmfOnMnEiROrXJuamspDDz1EcXExXbp0oaSkhIMHD3Lw4EH27dvHggULKpU/ffo048ePJz09HXd3d8LDwzGbzSQlJZGUlMS2bdt46623Kt3kFS5KEQ0uMzNT0el0ik6nUzIzM6std/HiReWGG25QdDqd8uKLL1qPv/HGG9br58+fr5jNZkVRFCU3N9cav0+fPopOp1OWLl2q6PV667U7duywntu+fbv1uNlsVv7xj38oOp1OGT9+vJKfn68oiqKYTCZl1apVSteuXa3PebnZs2crOp1OWbRokfVYbm6u0r9/f0Wn0ynPPvusUlRUZH2O999/X9HpdEqPHj0qvfaK2MePH68U/5tvvlF0Op3Sp08fZevWrdbjBoNBWb58ufXcmTNnrOdycnKsr/Hll19WysvLFUVRlKKiIuXxxx+3PteYMWOqfe8vt2nTJkWn0yn33XdfpeP33XefotPplH//+99KYWGh9XhhYaEyc+ZMRafTKdddd51iMBis5y7/7G6//XYlJSXFeu7rr79Wevbsqeh0OuWLL76wHjcajcqIESMUnU6n/Otf/1Kys7Ot506ePKkMHz5c0el0yn//+99K9Rs8eLCi0+mUnTt32vU6hXOQPmEHUxSFS5cusXv3bh577DHy8vIICAhgwoQJVcp6eHgwY8YMNBoNgPXm2HvvvUdRUREjRoxgxowZlVpHt912GzNnzgSo1A1w4MABkpKSCAwMZMmSJTRv3hwArVbL+PHj+fvf/273a/jkk0/Iz8/n2muvZd68efj5+QGWjUnHjRvHoEGDKC8v58svv6w11htvvAHA008/zZ133lnptU+ZMoXhw4dbf6ZXWLduHUVFRfTr14///Oc/1jVl/fz8WLRoUbXdF2qcPXuWM2fO4O3tzQsvvGDtNgJLF9J//vMfAAoLC8nKyqpyvUajYdmyZXTu3Nl6bNiwYdbuklWrVlmPb9++nSNHjtCpUyeWLl1Ky5YtreciIyNZunQpWq2WdevWkZube8WvTTiWJOGr7LbbbqsyWeP6668nJiaG5ORkgoKCeOutt2x2R+h0OmuCu9zOnTsBuOuuu2w+51133YVGo+Ho0aNkZ2cDlu4LsGwKamuc7gMPPGD3a/r+++8BuO+++6xfEJd74YUX2LFjB4899liNcTIyMjh58iRarbZSAr7c3XffDcDu3butx3744QcAm32rnp6e1fa5qtG2bVsSExNJTEy0+X55e3tb/39ZWVmV89ddd12ViS8A999/PwC//fabNaF+++23AAwdOhQvL68q1+h0OnQ6HeXl5ezbt69uL0g4DekTvsr+OllDq9Xi6+tLaGgovXv3Zvjw4fj6+tq8NiQkpMqxoqIizp07B8CSJUt4++23bV7r5uaG0WgkNTWVkJAQ0tLSAEvLyhZbCaM6mZmZAHTp0sXm+datW9sVJyUlBfizNW5LRYJLT09HURQ0Go31tVzeyrxct27d7Hp+e3h7e3Pq1CmSk5NJT08nMzOTkydPWusOYDZX3X69e/fuNuOFhoYSEBBAYWEhqamptGjRglOnTgHw9ddf88svv9i87vz584Clr1m4NknCV1l1kzXsYatVdPkoiiNHjtQao7CwELAkbwAfHx+b5QICAtBoNCh2bLxy8eJFAJutdDUq6mQ0Gq037qpjNpspLi7G39/fel11X16X3/S7EsePH2fBggVVWp/t2rVj5MiRbNiwodprq6tbxbnCwkLrF0zF68nMzLR+wVWn4vMUrkuSsIu7PIn+9NNPdk+iqPhJXVJSYvO8Xq+3KwGDpXVYVFRUbSx7VSSqLl268MUXX9h9XWBgILm5uZW+kC5nq3tArezsbB599FEuXrxIt27deOCBB+jevTudO3cmKCgIg8FQYxKu6b2pqHfFZ1Lxmb7++uvccccdV1x34dykT9jFBQYGWhPv77//brOMyWRi7969pKenWzdQ7NSpE2AZdmVLxU9ie4SHh9d4zXfffcfo0aMr3Ri0peIG2unTpzEYDDbL5OTkcODAgUo3vypey7Fjx2xeU937osamTZu4ePEinTt3Zv369YwdO5a+fftap2/buhl3uYouk7/KzMykqKgIrVZLREQE8Of7UFO9k5KSOHHiRL18wQjHkiTcCFSMmf34449tnv/888+Jjo5mxIgR1hbZbbfdBlhucNlKIJ9++qndz18xEWPLli3VPv+BAwcoKCiwHqu4gXd5azsyMpJ27dpRWlpabaxXX32V0aNH8/jjj1uPVbyWTZs2VemPNZvN1cZS48yZMwBERERUuglXYePGjdb/b2un4MTERGvf/eXWrVsHQN++fa0jLgYNGgTA5s2b0ev1Va7JzMxkzJgx3HPPPSQlJal/McKpSBJuBB577DG8vLz4/PPPWbJkSaU/3D179jBv3jwAHnzwQWv/aM+ePRk8eDClpaXExsZab/QAbNiwQdXaFaNHjyYwMJD9+/ezYMEC6/MrisKaNWvYunUrHh4ejB492npNRdfD2bNnrcc0Gg1TpkwBYMGCBWzdutV6zmg0EhcXR0JCAkClG3cPPfQQoaGh/Pbbbzz33HPW1qFer+f555+vtrWvRkVr/8cffyQ5Odl6vLS0lHfffZeVK1daj9lKnAaDgdjY2EpfeBs2bGD16tVoNBqmTp1qPX733XcTHh5Oeno606ZNs45oAUuLesqUKRiNRrp3717tTEjhOqRPuBGIjIxk8eLFzJo1ixUrVrBmzRo6depEfn6+tQV34403WseyVnjxxRcZP348ycnJDB06FJ1OR15eHufOnWPw4MF2r0vbqlUrXnvtNaZNm8YHH3xAQkICHTt25Ny5c+Tm5uLm5sa8efOsiQwsoy8OHjzIE088QUREBI8//jg333wzDzzwACdPnmT16tU88cQTLFy4kNDQUE6fPm29ATh16lSGDh1qjeXv78+SJUuYNGkSGzduZNu2bXTs2JH09HQuXbqk6rVU58EHH2Tt2rWcOXOGhx56iPDwcLy9vUlPT6ekpIR27dqh1WrJzMzkwoULVa4fOHAg+/fv57bbbqNLly7k5+dbW8azZs3ihhtusJb19PRk+fLlTJgwgV27djFo0CAiIyMpLy8nLS0Nk8lE69ateeutt67oNQnnIC3hRmL48OFs3ryZBx54gObNm3P8+HHy8/Pp1asXTz/9NO+++26VKa4hISHEx8czdepU2rVrR0pKClqtltjYWF555RVVzz9w4EC2bNnCAw88gL+/P8ePH8dkMjF06FDWrVtXZYH0BQsW0L9/fxRFIS0tjfT0dOu5OXPmsGrVKoYMGYLZbLb29d5888289dZbNhdIv+6660hISGDkyJH4+vpy4sQJ2rVrxyuvvMKoUaNUvRZbAgMD2bhxI2PHjiU8PJwzZ86Qnp5Ox44diY2NZcuWLQwfPhzAZsLv0aMH69ato3///qSlpXHp0iVuvPFG3n//fZsTcyIjI9myZQuTJ08mIiKCtLQ0MjIy6NChA+PHj+fTTz+lbdu2V/y6hONpFHtvgQshhKh30hIWQggHkiQshBAOJElYCCEcSJKwEEI4kCRhIYRwIEnCQgjhQJKEhRDCgSQJCyGEA0kSFkIIB5IkLIQQDiRJWAghHOj/A3fi4hb9yos5AAAAAElFTkSuQmCC\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.9833489118714203\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>79.069767</td>\n",
       "      <td>43.023256</td>\n",
       "      <td>18.604651</td>\n",
       "      <td>9.302326</td>\n",
       "      <td>6.20155</td>\n",
       "      <td>4.883721</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>79.069767</td>\n",
       "      <td>43.023256</td>\n",
       "      <td>18.604651</td>\n",
       "      <td>9.302326</td>\n",
       "      <td>6.20155</td>\n",
       "      <td>4.883721</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     79.069767  43.023256  18.604651  9.302326  6.20155  4.883721\n",
       "1           NaN        NaN        NaN       NaN      NaN       NaN\n",
       "mean  79.069767  43.023256  18.604651  9.302326  6.20155  4.883721"
      ]
     },
     "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
}
