{
 "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:07<00:00, 2123.29it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_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.9407114624505929"
      ]
     },
     "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",
    "# 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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C62e3717NwB9+vQpd65z5874+Phw4MABcnNzAfjll19QFIWePXuWq0U3b96cdu3acfbsWRITEyttmyRnIYTdMf65toaal1orVqxg9+7dTJ8+naCgIKsx5iSq1+utng8ODsZoNHLq1Kky8WFhYVbjQ0JCADhx4kSl7ZOasxDC7hgVdZNQ1D4QTE1N5a233uLuu+8mMjLSZpz5IaGvr6/V8+bjmZmZZeL9/PyqFF8RSc5CCLtjVNT1hs2TUNLT08vVjr28vPDy8rL82mAwMHPmTLRaLQsWLECjsf0+BQUFALi4uFg9bz6en59frfiKSHIWQtid6k7ffvLJJ8v1SidOnMikSZMsv/7444+Jj49n3rx5NG/evML7mhN9RQkcwGg0Viu+IpKchRB2p7o95xUrVljtOZsdO3aMxYsX06NHD4YMGVLpfV1dXQEoLCy0et583N3dXVW8m5tbpe8tyVkIYXdMi+1XvedsXmy/adOmODs724x79913KSkpoaSkhOnTp5c5Z+7Nmo+/9NJL+Pn5kZCQQGZmJq1atSp3v4yMDOCvWrK51myrpmyOt1WTvpYkZyGE3TEoKiehVHHhI3OtNyYmxmbM5s2bAfi///s/wsLC2LlzJ4mJiXTv3r1MnKIoJCUlodPpLInbPErD1lA586gOW6M/riVD6YQQdsf453rOal5VER0dzfHjx62+zOUQ869btGhBeHg4ANu2bSt3r7i4OLKysujSpQseHh4Alviff/65XF353LlzJCQk4O/vT2hoaKVtleQshLA7N2uGYGW6detGWFgYMTExrF692nI8KyuL2bNnAzBq1CjL8YCAAMLDw0lKSmLRokWW4/n5+bzyyisYDIYy8RWRsoYQwu7czLU1KmIebjdixAheffVV1q5di5+fH7/99hs5OTlERETQq1evMte89tprDB06lA8//JDt27cTHBxMXFwcGRkZ3HfffQwdOrRK7y3JWQhhd4yo26bqepcMrUjHjh1Zs2YNUVFRxMbGcvLkSYKCgpg2bZrVER8BAQGW+F27dpGamkpAQADDhw9nxIgRODhULe1KchZCCODo0aM2z4WGhhIVFVXlezVr1ozXX3/9utojyVkIYXdM45xVTN9GQw12nmuFJGchhN1RVC5mpNS3zIwkZyGEHVI9zll6zkIIUfOMilZlWaP+jQqW5CyEsDuKyrU1pKwh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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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X6+nFgnh2CQdYSdcXFyYMmUKPXr0ACA+Pt7GLbKsefPmtG/fHn9/f1s3RYirggRhOxMVFQWYlqYUQlz9JB1hZyq2qb90t+QFCxbw3nvv8eyzz+Lh4cEHH3xAXl4ebdq0YeHChbRt2xaAjIwMFi9ezM8//8zZs2fx8vKie/fujBkzptrV1c6dO8fixYv58ccfOXfuHK1ateLBBx/k2muvtVj+ueee46uvvmLs2LFMmzat0rmMjAyWLVvG9u3bOXPmDO7u7nTt2pWYmBhuuOGGSq+lwrBhwwBYtmyZeVlOgD179rB06VISExPJz88nICCA66+/nnHjxplf7z8dPnyYDz74gH379lFYWEinTp0YP358jT9vtbKzs1m+fDk7d+4kIyODkpISfHx8uOaaa7jvvvu45ZZbqr32xIkTvP322+ZlRzt27MiDDz7I8OHDLZYvLCxk6dKlbNy4kfT0dJycnIiIiGDkyJHcc889DrlimKhKgrCdSU9PB6BFixZVzm3atIk//viDVq1a0apVK4qLiwkJCQFg586dTJ48meLiYjw8POjQoQPnz59n27ZtbNu2jUmTJjFx4sRK9aWkpBATE8Pp06dxd3enQ4cOZGVlMWvWLHr37q2q3b/88gtPPvkkBQUFeHp6Eh4ezrlz5/j555/5+eefmTVrFqNGjaJFixb07NmTffv2AXDNNdfg7u6Oj4+Pua7333+f+fPnA+Dn50dERAQZGRmsWbOG7777jvnz51fZPWTz5s089dRT6HQ6/Pz8aN++PUeOHCE2NpZevXqpei3VOXz4MDExMeTm5uLp6WnO7WdkZJhf59SpU3n88cerXJuSksJ9991HUVERHTp0oLi4mH379rFv3z52797N7NmzK5U/efIkY8eOJS0tDWdnZ0JDQzEajSQmJpKYmMimTZt4//33Kw3yCgeliAaXkZGhREREKBEREUpGRka15S5cuKBcd911SkREhPLqq6+aj7/77rvm62fNmqUYjUZFURQlJyfHXH/Pnj2ViIgI5Z133lHKysrM127ZssV8bvPmzebjRqNRuf/++5WIiAhl7NixSm5urqIoimIwGJQlS5YokZGR5ue81LRp05SIiAhlzpw55mM5OTlK3759lYiICOXFF19UCgsLzc/xySefKBEREUrnzp0rvfaKupOSkirVv3HjRiUiIkLp2bOnsmHDBvNx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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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jSIDSoUQTsRgMGA0GlUfp9PpqowYcgUShIUQwoHkxpwQQjiQBGEhhHAgCcJCCOFAEoSFEMKBJAgLIYQDSRAWQggHkiB8FZw+fZrIyEirrw4dOtC1a1f69+9PTEyM1TkhHOH48eOWNl5q5syZREZGsmDBgss+R2ZmJvn5+ZddT00+/PBDIiMjuf/+++0qv2nTJiIjIxk9evRln3vJkiVERkYybdq0y66rJoMHDyYyMpIffvihzs8lrhzXG9ns4rp06VJpaSJFUdDr9Zw+fZrt27ezfft2xo4dy+zZsx3Yyrq3atUqlixZwrp162TaTVGvSRC+yt544w1atmxZZXt5eTlvvfUWy5YtIy4ujn79+jF48GAHtLB6Tz75JNHR0QQGBl5WPfPnz79CLRLCtUk6wkm4u7vzxBNP0L17dwDi4uIc3CLrmjRpQrt27QgKCnJ0U4S4JkgQdjKDBg0CzFNTCiGufZKOcDIVy9RfulrykiVLeOutt3j66afx9vbmnXfeIS8vj9atW/P222/Tpk0bANLS0li+fDk//fQT58+fx9fXl27dujFx4kSbs6tduHCB5cuX8/3333PhwgVatGjBfffdR69evayWnzlzJp9++imTJ09mxowZlfalpaWxevVqduzYwblz5/Dy8uK6665j0qRJ3HTTTZWupcKIESMAWL16tWVaToC9e/eyatUqEhISyM/Pp1GjRtx4441MmTLFcr1/d+TIEd555x32799PYWEhHTt2JCYmptqft1qZmZmsWbOGXbt2kZaWRklJCf7+/nTq1Im7776bYcOG2Tz21KlTLFy40DLtaIcOHbjvvvsYOXKk1fKFhYWsWrWK7777jtTUVHQ6HREREYwePZo777zTJWcME1VJEHYyqampADRr1qzKvi1btvD777/TokULWrRoQXFxMa1atQJg165dTJs2jeLiYry9vWnfvj3Z2dn8+OOP/Pjjjzz66KPExsZWqi8pKYlJkyZx9uxZvLy8aN++PRkZGcydO5eePXuqavfPP//MY489RkFBAT4+PoSHh3PhwgV++uknfvrpJ+bOncuYMWNo1qwZPXr0YP/+/QB06tQJLy8v/P39LXUtXbqUN954A4DAwEAiIiJIS0tj48aNfP3117zxxhtVVg/ZunUrTz75JHq9nsDAQNq1a8fRo0eJjo7m+uuvV3Utthw5coRJkyaR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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.959474640279172\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>54.385965</td>\n",
       "      <td>30.701754</td>\n",
       "      <td>16.140351</td>\n",
       "      <td>8.596491</td>\n",
       "      <td>5.964912</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>54.385965</td>\n",
       "      <td>30.701754</td>\n",
       "      <td>16.140351</td>\n",
       "      <td>8.596491</td>\n",
       "      <td>5.964912</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     54.385965  30.701754  16.140351  8.596491  5.964912  4.736842\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  54.385965  30.701754  16.140351  8.596491  5.964912  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": "4060a023",
   "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
}
