{
 "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%|██████████████████████████████████████████████████| 2965/2965 [00:00<00:00, 8183.48it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_bond_strength_superlevel_betti/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 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": 4,
   "id": "f08b5f2f",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9454545454545454"
      ]
     },
     "execution_count": 4,
     "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=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": 5,
   "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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smUL48aNY/bs2RXKUlNT+fjjj9m/fz9paWk4Oztz9913M3bsWB544IEKn8VkyJAhAHz88cfm5SIBjhw5wtq1a0lISOD69et4e3tz//33M3HiRPPn/b3Tp0/z3nvvcfz4cfLy8ujUqROTJk2q9t9brczMTGJjYzl48CCpqakUFhbSvHlz7rzzTqKiohg0aFCV154/f563337bvBxmx44dGT58OI888ojF+nl5eaxdu5Zdu3Zx8eJFdDoder2eoUOH8sQTT9j1CleiMkm2dubixYsAtGrVqlLZ7t27+f7772ndujWtW7emoKCAwMBAAA4ePMi0adMoKCjAxcWF0NBQsrOz+frrr/n666+ZOnUq0dHRFe6XnJzM2LFjuXLlCs7OzoSGhpKens6iRYu49957VcUdHx/P888/z40bN3B1dSUkJISMjAy++eYbvvnmGxYtWsSwYcNo1aoVERERHD9+HIA777wTZ2dnmjdvbr7XypUrWbZsGQCenp7o9XpSU1PZtGkTO3fuZNmyZZV2o9izZw8zZsygpKQET09POnTowJkzZxg/fjzdunVT9Vmqcvr0acaOHUtOTg6urq7mvvfU1FTz53zhhReYMGFCpWuTk5OJiooiPz+f0NBQCgoKOH78OMePH+fQoUMsXry4Qv1Lly4xbtw4UlJScHBwICgoCKPRSEJCAgkJCezevZuVK1dWeNkq7Jwi6lxqaqqi1+sVvV6vpKamVlnv2rVrSq9evRS9Xq8sWLDAfD4mJsZ8/aJFixSj0agoiqJkZWWZ7x8REaHo9Xpl6dKlSnFxsfnaL7/80ly2Z88e83mj0aj8z//8j6LX65Vx48YpOTk5iqIoisFgUNasWaOEhYWZn3mz2bNnK3q9Xnn99dfN57KyspSePXsqer1e+dvf/qbk5eWZn/HPf/5T0ev1yl133VXhs5vuffbs2Qr337Vrl6LX65WIiAhlx44d5vMlJSXKihUrzGWXL182l2VmZpo/49///neltLRUURRFycvLU6ZPn25+1lNPPVXlv/3NNm3apOj1euXxxx+vcP7xxx9X9Hq98r//+7/KjRs3zOdv3LihvPDCC4per1e6deumlJSUmMtu/toNHDhQSUpKMpd98cUXSnh4uKLX65XPP//cfL6srEx57LHHFL1erzz33HNKRkaGuSwxMVEZPHiwotfrlYULF1aIr2/f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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": 6,
   "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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ABYsWMB7771n9VwXFxcMBgNpaWkEBgaSnp4OmFtW1lgLGLXJysoCICIiwur+4OBgm8pJTU0FzrfGrakKcBkZGSiKgkajsTyXC1uZF+ratatN17eFh4cHR44cYc+ePWRkZJCVlcXhw4ctdQcwmWouv96tWzer5QUFBeHr60tRURFpaWm0atWKI0eOAPDdd9/x+++/Wz3v5MmTgDnXLJybBOFLrLbBGraw1iq6sBfF/v376y2jqKgIMAdvAE9PT6vH+fr6otFoUGxYeOXMmTMAVlvpalTVyWAwWG7c1cZkMlFSUoKPj4/lvNq+vC686XcxUlJSmDt3bo3WZ/v27Rk5ciSrV6+u9dza6la1r6ioyPIFU/V8srKyLF9wtal6P4XzkiDs5C4Mor/++qvNgyiqflKXlpZa3V9RUWFTAAZz67C4uLjWsmxVFagiIiL4+uuvbT7Pz8+PvLy8al9IF7KWHlDr9OnTPPTQQ5w5c4auXbsyatQounXrRpcuXfD390ev19cZhOt6barqXfWeVL2nb775JrfeeutF1104NskJOzk/Pz9L4D169KjVY4xGI9u3bycjI8OygGLnzp0Bc7cra6p+EtsiNDS0znN+/PFHYmJiqt0YtKbqBtqxY8fQ6/VWj8nNzWXXrl3Vbn5VPZeDBw9aPae210WNNWvWcObMGbp06cKqVat48MEH6dOnj2X4trWbcReqSpn8XVZWFsXFxWi1WsLCwoDzr0Nd9U5OTubQoUON8gUj7EuC8GWgqs/sp59+anX/V199RWxsLMOHD7e0yAYPHgyYb3BZCyBffPGFzdevGoixbt26Wq+/a9cuCgsLLduqbuBd2NoODw+nffv2lJWV1VrW66+/TkxMDI899phlW9VzWbNmTY18rMlkqrUsNbKzswEICwurdhOuyueff275b2srBSclJVly9xdauXIlAH369LH0uBg4cCAAa9eupaKiosY5WVlZPPDAA9x1110kJyerfzLCoUgQvgw88sgjuLu789VXX7FgwYJqH9xt27Yxe/ZsAO655x5LfrRHjx5ER0dTVlZGfHy85UYPwOrVq1XNXRETE4Ofnx87d+5k7ty5lusrisLy5ctZv349bm5uxMTEWM6pSj0cP37csk2j0TBp0iQA5s6dy/r16y37DAYDS5YsITExEaDajbt7772XoKAg/vrrL5577jlL67CiooIXXnih1ta+GlWt/V9++YU9e/ZYtpeVlfH++++zePFiyzZrgVOv1xMfH1/tC2/16tUsW7YMjUbD5MmTLdvvvPNOQkNDycjIYMqUKZYeLWBuUU+aNAmDwUC3bt1qHQkpnIfkhC8D4eHhzJs3jyeffJJFixaxfPlyOnfuTEFBgaUFd/3111v6slZ56aWXGDduHHv27GHIkCFERkaSn5/PiRMniI6Otnle2jZt2jB//nymTJnCRx99RGJiIp06deLEiRPk5eXh4uLC7NmzLYEMzL0vdu/ezeOPP05YWBiPPfYYN954I6NGjeLw4cMsW7aMxx9/nJdffpmgoCCOHTtmuQE4efJkhgwZYinLx8eHBQsWMGHCBD7//HM2bNhAp06dyMjI4OzZs6qeS23uueceVqxYQXZ2Nvfeey+hoaF4eHiQkZFBaWkp7du3R6vVkpWVxalTp2qcP2DAAHbu3MngwYOJiIigoKDA0jJ+8skn6devn+VYnU7HO++8w8MPP8yWLVsYOHAg4eHhVFZWkp6ejtFoJDg4mHffffeinpNwDNISvkzcdtttrF27llGjRtGyZUtSUlIoKCjgyiuv5Omnn+b999+vMcQ1MDCQhIQEJk+eTPv27UlNTUWr1RIfH89rr72m6voDBgxg3bp1jBo1Ch8fH1JSUjAajQwZMoSVK1fWmCB97ty59O3bF0VRSE9PJyMjw7Jv5syZLF26lEGDBmEymSy53htvvJF3333X6gTp11xzDYmJiYwcORIvLy8OHTpE+/btee211xgzZoyq52KNn58fn3/+OQ8++CChoaFkZ2eTkZFBp06diI+PZ926ddx2220AVgN+9+7dWblyJX379iU9PZ2zZ89y/fXX8+GHH1odmBMeHs66deuYOHEiYWFhpKenk5mZSceOHRk3bhxffPEF7dq1u+jnJexPo9h6C1wIIUSjk5awEELYkQRhIYSwIwnCQghhRxKEhRDCjiQICyGEHUkQFkIIO5IgLIQQdiRBWAgh7EiCsBBC2JEEYSGEsCMJwkIIYUf/D5SPWQDVsrkeAAAAAElFTkSuQmCC\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": 7,
   "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": 8,
   "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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\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": 9,
   "id": "eaeb5421",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC score: 0.8583968699839486\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>28.571429</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>11.428571</td>\n",
       "      <td>7.142857</td>\n",
       "      <td>4.761905</td>\n",
       "      <td>3.571429</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>28.571429</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>11.428571</td>\n",
       "      <td>7.142857</td>\n",
       "      <td>4.761905</td>\n",
       "      <td>3.571429</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     28.571429  21.428571  11.428571  7.142857  4.761905  3.571429\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  28.571429  21.428571  11.428571  7.142857  4.761905  3.571429"
      ]
     },
     "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": "2ec875d6",
   "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
}
