{
 "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 KIF11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 7110/7110 [00:01<00:00, 3781.04it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/partial_charge_superlevel_betti/target_kif11/'\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.9971751412429378"
      ]
     },
     "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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//3vfyt5eXmKoihKenq6MmnSJOu9Bg0aVOTf/d02b96sGAwG5dlnny2w/9lnn1UMBoPyf//3f8qdO3es++/cuaNMnjxZMRgMSps2bZTc3Fzrsbv/7Z544gklJibGeuzHH39UWrRooRgMBuW7776z7s/Pz1d69+6tGAwG5dVXX1WSk5Otx86fP6/06NFDMRgMynvvvVcgvi5duigGg0HZtWtXiT6n0DapOduZoiikpaWxb98+XnnlFW7evImPjw8vv/xyobYuLi5MnDgRnU4HYH0o98UXX5Cenk7v3r2ZOHFigd5U165dmTx5MkCBcsKRI0eIjo7G19eXjz76iOrVqwPmhciHDx+uaurql19+SWpqKq1atWLmzJl4eXkB5tW/hg4dSufOncnLy+P777+/57UWLVoEwBtvvMHf/va3Ap99zJgx9OjRw/rrvsWGDRtIT0+nffv2vP7669YlIL28vJg7d26RZRA1rl27xtWrV3F3d+fdd98t8HYMb29vXn/9dcC8VnBSUlKh83U6HYsXL6ZJkybWfd27d7eWXT7//HPr/h07dnDq1CkaN27MggUL8PPzsx4LCQlhwYIF6PV6NmzYQEpKyn1/NqFNkpwrWNeuXQtNQmnXrh0jRozg2LFj1KhRg6VLl9osaxgMBmviu9uuXbsAePrpp23e8+mnn0an03H69GmSk5OBP94+/Nhjj9kcZ9y3b98Sf6Y9e/YA8Oyzz1q/OO727rvv8tNPP/HKK68Ue53Lly9z/vx59Hp9gcR8t2eeeQYo+GbkAwcOANis3bq6uhZZ01XD39+fqKgooqKibP59WV5rBJCdnV3oeJs2bQpN6AF47rnnADh58qQ10e7cuRMwvwXazc2t0DkGgwGDwUBeXh6HDh0q3QcSmic15wr250koer0eT09P6tatS+vWrenRoweenp42z61du3ahfenp6SQkJADw0Ucf8cknn9g818nJifz8fGJjY6ldu7Z1HduQkBCb7W0lkqLEx8cDEBoaavN4vXr1SnSdmJgY4I/euy2WxBcXF4eiKOh0OutnubtXeremTZuW6P4l4e7uzoULFzh27BhxcXHEx8dz/vx5a+wAJpOp0HnNmjWzeb26devi4+PDnTt3iI2NpVatWly4cAGAH3/8kV9//dXmeYmJiYC5li0ckyTnClbUJJSSsNWLuntUx6lTp+55jTt3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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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K6SovNnWgG/MqZonbDKZmDJlCh999BEGg4GwsDCaNr00r7GoqAitVsvBgwd5+OGHycvLq/OAhRDXPllFrQobN25k586dhISE8OWXX/LFF19UWPf3hhtu4LvvvqNLly6cPn2aVatW1XnAQohrn6oHNRr4ou6qk7BGo2Hp0qWEhobabBMUFMSyZcvQarUOn2EhhGiYLHvM2f1qwCNhVTXho0ePEhISQufOnattFxwcTHBwMBkZGVcUnBCicVJU1oSvyYc1bDEajXav+evm5oaLi+39tIQQojrmJNw4nphTVY4ICgoiNTWV3Nzcatvl5OSQkpJCUFDQFQUnhGik1NaDG0tNeNiwYRgMBl544YUK09Mup9frefbZZzEajTZ3TBZCCHGJqnJEVFQUX375Jd9//z333XcfQ4YM4exZ844VW7du5dixY3z++eekpaXRtm1bxo0bVx8xCyGucfKwRhWaNGnCBx98QExMDIcOHeL48ePWc9OmmffHUhSFjh078s4778juF0KIWpEbc9Vo164dGzduZOvWrXz//fekpKRQVFSEl5cXHTt2ZNCgQdx11102t6wXQgh7XK21I3bv3s2KFStITk6mvLyc7t27Ex0dzW233WZ3H0VFRaxatYpvv/2WkydP4uXlRXh4OFOmTOH666+v8fparR2h1WoZNmwYw4YNq83lQghRrauRhOPj45kzZw7u7u7cfPPNmEwmEhISiI6OZt68eTz00EM19nH+/HkeffRRkpOTad26NQMHDiQ9PZ0ffviBn3/+mbVr19KzZ89q+7iiVdRyc3M5ceIEpaWl+Pr6EhISQpMmTa6kSyGEQEHdchBqqxHZ2dnMnTsXX19f4uLirPtWJiUlERUVxfz58xk0aFCN698sXLiQ5ORk7rrrLhYtWmStAKxatYpXXnmF5557ji+//LLaPmq1x9w333zDAw88wC233EJkZCQTJkxg1KhR9OnTh3HjxvHbb7/VplshhADqf4+5tWvXotfrGTduXIWNg3v27El0dDRlZWWsX7++2j5OnTrFpk2bCAoKqpCAASZMmED37t0pKSmpcUqv6iT83HPPMWPGDP78808URcHHx4dWrVrRpEkTjEYje/bs4bHHHmP16tVquxZCCDOlFi8Vdu3aBWBzGq3l2M6dO6vtY8uWLSiKQmRkpM17YPHx8WzdupWAgIBq+1FVjvjq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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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iTz55JP069eP8+fP89VXX/H6668zf/586taty+XLl403X8eOHUvXrl2N53JxceHjjz9m1KhRrF+/nh07dtCgQQPi4+PJzMy06FpK079/f7799luuXLlCWFgYDRs2xMHBgfj4eHJycvDx8UGtVpOQkMD169dLHB8aGsqxY8fo0qULQUFBpKenG3vsU6ZM4dFHHzXG2tnZsWTJEl5++WX2799Px44dCQwMpLCwkIsXL6LVaqlXrx6ffvrpHV2TqH6kh15N9OjRg82bN9OvXz/c3Nw4e/Ys6enptGzZkrfeeovPP/+8xDRxDw8PVq9ezdixY/Hx8SEmJga1Ws24ceP48MMPLXr/0NBQtmzZQr9+/XBxceHs2bNotVq6du3KmjVrSjwsYt68ebRv3x5FUbh48SLx8fHGfW+++SYrVqygc+fO6HQ649j4k08+yaeffmryYRFt2rRh48aN9O3bFycnJ86dO4ePjw8ffvjhXXnYr6urK+vXr2fIkCE0bNiQK1euEB8fT4MGDRg3bhxbtmyhR48eACY/PJo3b86aNWto3749Fy9eJDMzk8cff5wvv/zS5CSywMBAtmzZwujRowkICODixYtcunQJPz8/hg8fzqZNm/D29r7j6xLVizyCTgghqgnpoQshRDUhCV0IIaoJSehCCFFNSEIXQohqQhK6EEJUE5LQhRCimpCELoQQ1YQkdCGEqCYkoQshRDUhCV0IIaoJSehCCFFN/D8+irL3jPOhqgAAAABJRU5ErkJggg==\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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\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.9786371733966746\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>55.0</td>\n",
       "      <td>30.0</td>\n",
       "      <td>17.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.666667</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>55.0</td>\n",
       "      <td>30.0</td>\n",
       "      <td>17.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.666667</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      55.0   30.0   17.0     9.5  6.666667     5.0\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   55.0   30.0   17.0     9.5  6.666667     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)"
   ]
  },
  {
   "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
}
