{
 "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 GCR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 15749/15749 [00:01<00:00, 9463.89it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/partial_charge_superlevel_betti/target_gcr/'\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.9871541501976284"
      ]
     },
     "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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1+uVu+++u9RnN9/7xIkTpe6/ZcsWRa/XKxEREcrmzZstx4uKipRFixZZzp07d85yLisry/IZ33nnHaW4uFhRFEXJyclRJk6caHmvZ5991uaf/Y3Wrl2r6PV65amnnip1/KmnnlL0er3yz3/+U7l+/brl+PXr15XJkycrer1ead++vVJUVGQ5d+PfXY8ePZTExETLue+//15p3bq1otfrlW+//dZyvKSkRHnyyScVvV6vvPjii0pmZqbl3KlTp5RevXoper1emT17dqn4unTpouj1emX79u2V+pzCvknNuYYpisK1a9fYtWsXzz//PNnZ2dSrV4/nnnuuTFtHR0cmTJiARqMBsDyU+/TTT8nJyeHJJ59kwoQJpXpT3bp1Y/LkyQClygn79+8nISEBT09P3n//ferXrw+AVqtl+PDhPPHEE5X+DKtWreLy5cvce++9zJw5E3d3d8C0Ie3QoUPp3LkzxcXFfPfddxXeKzo6GoBXXnmFv//976U+++jRo+nVq5fl132zFStWkJOTQ8eOHZkyZYplTV93d3feeustm2UQNc6fP8+5c+dwcXFhxowZlvITmEpRU6ZMAeD69etcvHixzPUajYaFCxfSvHlzy7GePXtayi6ffPKJ5fjWrVs5evQozZo1Y/78+TRs2NByLjQ0lPnz56PValmxYgWXLl266c8m7JMk59usW7duZSahdOjQgREjRnDo0CEaNGjA4sWLrZY19Hq9JfHdaPv27QA8+uijVt/z0UcfRaPRcOzYMTIzMwFTGQRMm8FaG2fct2/fSn+mHTt2APDUU09ZfnDcaMaMGfz44488//zz5d7nzJkznDp1Cq1WWyox3+ixxx4DYNeuXZZjP//8M4DV2q2Tk5PNmq4a/v7+xMXFERcXZ/XPy8XFxfL/BQUFZc63b9++zIQegKeffhqA3377zZJot23bBkD37t1xdnYuc41er0ev11NcXMzevXur9oGE3ZOa823250koWq0WNzc3GjVqRLt27ejVqxdubm5Wr/Xx8SlzLCcnhwsXLgDw/vvv8+GHH1q9VqfTUVJSQnJyMj4+PqSkpACmnpg11hKJLWlpaQCEhYVZPd+4ceNK3ScxMRH4o/dujTnxpaamoigKGo3G8llu7JXeqEWLFpV6/8pwcXHh9OnTHDp0iNTUVNLS0jh16pQldgCj0VjmupYtW1q9X6NG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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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V4yp9bnORqNIh1IhhAMxGAwYjUbV57m4uFTqMeQMJAgLIYQdyYM5IYSwIwnCQghhRxKEhRDCjiQICyGEHUkQFkIIO5IgLIQQdiRB+BrIyMigXbt2Vl/t27enS5cu3H777UycONHqnBD2cPz4cUsdr/Tcc8/Rrl075s+ff9XXuHDhAvn5+VddTk0+/vhj2rVrx9ixY206fvPmzbRr147hw4df9bUXL15Mu3btmDp16lWXVZMBAwbQrl07du7cWe/XEnXH+Xo2O7lOnTpVWJpIURT0ej0ZGRns2LGDHTt2MGrUKGbOnGnHWta/VatWsXjxYtatWyfTbooGTYLwNfbWW2/RokWLStvLysp45513WLZsGXFxcfTp04cBAwbYoYbVe/rpp4mNjSUwMPCqypk7d24d1UgI5ybpCAfh5ubGU089RdeuXQGIi4uzc42sa9asGW3atCEoKMjeVRHiuiBB2MH0798fME9NKYS4/kk6wsGUL1N/5WrJixcv5p133uHZZ5/Fy8uLd999l7y8PFq2bMmSJUto1aoVAOnp6SxfvpyffvqJc+fO4ePjw4033si4ceOqnF3t/PnzLF++nB9++IHz58/TvHlzHn74YW6++Warxz/33HN89tlnjB8/nunTp1fYl56ezurVq9m1axdnz57F09OTzp07ExMTw2233VbhXsrde++9AKxevdoyLSfAvn37WLVqFQkJCeTn59O4cWNuvfVWHn/8ccv9/tXRo0d59913OXDgAIWFhXTo0IGJEydW+36rdeHCBdasWcOePXtIT0+npKQEPz8/brjhBh588EEGDx5c5bmnTp1iwYIFlmlH27dvz8MPP8zQoUOtHl9YWMiqVav47rvvSEtLw8XFhejoaIYPH87999/vlDOGicokCDuYtLQ0AEJDQyvt+/777/njjz9o3rw5zZs3p7i4mPDwcAD27NnD1KlTKS4uxsvLi7Zt23Lx4kV+/PFHfvzxR6ZMmcLkyZMrlJecnExMTAxnzpzB09OTtm3bkpWVxezZs7nppptU1fvnn3/mySefpKCgAG9vb6Kiojh//jw//fQTP/30E7Nnz2bEiBGEhobSrVs3Dhw4AMANN9yAp6cnfn5+lrKWLl3KW2+9BUBgYCDR0dGkp6ezadMmvv76a956661Kq4ds27aNp59+Gr1eT2BgIG3atOHYsWPExsbSvXt3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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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tFqtzWdYCCEcU0u6x5yqnHBycjLBwcH06FFzO8aqgoKCCAoKIjNT7uYrhFBPUZkTbuhijT179rBy5UqOHz9ORUUFvXv3Jjo6mptuusnqNoqLi1m9ejVff/01p06dwsPDg4iICKZOnUrfvn3rPV/VSNhgMFi956+LiwtOTpZvxSKEEHUxBWE16Qj1z5GQkEBUVBRJSUn069ePAQMGkJSURHR0tNU3E75w4QIPPfQQK1asoLi4mJtvvhl/f3++++47xo4dy8GDB+ttQ1UQDgwMJDU1lbw8y7s1VcrJySElJYXAwEA1zQshhInafLDKnHB2djZz587F29ub+Ph4YmNjWb16NXFxcXh5eTF//nyys+u/E8nChQs5fvw4d9xxB9u3b+ett97if//7H7NmzUKn0/H885Y3569KVRAeMWIEer2ef//739Wmp1Wl0+l47rnnMBgMFu+YLIQQtrZu3Tp0Oh0TJ06stjVuv379iI6Opry8vN7R8OnTp9m8eTOBgYEsWrSo2n0xH330UXr37k1paWm9g1ZVQTgqKoquXbvy7bffcs899/DGG29w/rxpT4Zt27axcuVK7rrrLnbu3Im/vz8TJ05U07wQQgBNv5/w7t27ASwOFCuP7dq1q842tm7diqIojBs3zuKNiRMSEti2bRt+fn51tqPqwlyrVq14//33iYmJ4ejRo/zxxx/msunTTffLUhSFbt268fbbbzvU3S+EEPajKS/MKYpCSkoKWq222hTbSkFBQWi1WlJSUlAUpdbdJCt3iOzbty/FxcV89dVXHD58GGdnZ66//npuueUWq3aiVL1irkuXLsTHx7Nt2za+/fZbUlJSKC4uxsPDg27dujFkyBDuuOMOi98MQghhjabcO6KgoACdToefn5/FOOXs7Iyvry+5ubkUFxfj5eVlsZ2MjAzAdHHurrvuIisry1z20Ucfcf311/PWW2/Ver75+azueRVarZYRI0YwYsSIhpwuhBB1amgQPnv2bI1ZWT4+PtX+Ki8tNd3z0cPDo9b23N1Nm/fXFYQLC023mpozZw6BgYG8/vrrhIaGcvz4cV566SV++ukn5s6dy+uvv15n3y9rF7W8vDzS0tIoKyvD29ub4OBgWrVynPtYCSHsk4K67SAq644dO5acnJxqZTExMUybNs38s7XTbMGUuqiNTme6EYOLiwtr1qwxB/qrr76a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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.9505198623261151\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>43.859649</td>\n",
       "      <td>28.947368</td>\n",
       "      <td>15.438596</td>\n",
       "      <td>8.77193</td>\n",
       "      <td>6.081871</td>\n",
       "      <td>4.736842</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>43.859649</td>\n",
       "      <td>28.947368</td>\n",
       "      <td>15.438596</td>\n",
       "      <td>8.77193</td>\n",
       "      <td>6.081871</td>\n",
       "      <td>4.736842</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     43.859649  28.947368  15.438596  8.77193  6.081871  4.736842\n",
       "1           NaN        NaN        NaN      NaN       NaN       NaN\n",
       "mean  43.859649  28.947368  15.438596  8.77193  6.081871  4.736842"
      ]
     },
     "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": "47ce7d8c",
   "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
}
