{
 "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:08<00:00, 1965.36it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_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": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9960526315789474"
      ]
     },
     "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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duygb9++vP322zaMsuJ99dVXzJ07l+XLl8vypkJYIcn5DpszZw5169Ytcjw/P59PP/2Uzz//nGXLltGuXTs6depkgwhLNmHCBIYNG1aqwf4leffdd8spIiEck5Q17ISzszPjx4+nRYsWACxbtszGEVnn5+dHgwYN8PHxsXUoQjg0Sc52pmPHjoBpvKUQouqSsoadMS9PePMCLnPnzuXTTz9l0qRJVKtWjc8++4yrV69Sr1495s2bR0hICACJiYksXLiQPXv2cOnSJapXr84999zDoEGDih0alJKSwsKFC9m+fTspKSkEBQXRp08f2rRpY7X9lClTWLduHUOGDGHy5MmFziUmJvLNN9/wyy+/kJSUhJubG82aNWPw4ME89NBDhT6L2ZNPPgnAN998YxlrCrBv3z6++uorYmJiuHbtGrVq1eLBBx9k+PDhls/7T8eOHeOzzz7jwIEDZGRk0LhxY0aMGFHiv7daqampLFmyhN27d5OYmEh2djaenp40adKE3r1707Vr12KvPX36NB999JFlLG2jRo3o06cP3bt3t9o+IyODr776ii1btnD27Fl0Oh16vZ4ePXrw7LPPFlkaUzgWSc525uzZswAEBAQUObd161b+/PNPgoKCCAoKIisri+DgYMC07c7YsWPJysqiWrVqREREkJaWxs6dO9m5cydjxoxh9OjRhe4XHx/P4MGDuXjxIm5ubkRERJCcnMzMmTO59957VcUdFRXFuHHjuH79Ou7u7oSHh5OSksKePXvYs2cPM2fOpGfPngQEBNCyZUsOHDgAQJMmTXBzc8PT09Nyr/nz5zNnzhwAvL290ev1JCYmsmbNGjZv3sycOXOKTK3dtm0bEyZMIC8vD29vbxo0aMDx48cZNmwYrVq1UvVZinPs2DEGDx5Meno67u7ulmcHiYmJls85ceJEXnrppSLXxsfH07t3bzIzM4mIiCArK4sDBw5w4MAB9u7dy6xZswq1P3fuHEOGDCEhIQEnJydCQ0MxGo3ExMQQExPD1q1bmT9/vtXF4oWDUESFS0xMVPR6vaLX65XExMRi2125ckW57777FL1er8yYMcNyPDIy0nL9zJkzFaPRqCiKoly+fNly/5YtWyp6vV755JNPlNzcXMu1P/30k+Xctm3bLMeNRqPy3HPPKXq9XhkyZIiSnp6uKIqiGAwGZfHixUrDhg0t73mz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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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rFEPPz8/4uPjmTZtGnv37iU5Odlcds899wCgKAq+vr6sWLGCTp06NW9thRDiCqP6YY0+ffrw3//+l3Xr1rFjxw7S0tIoKyvDw8ODbt26MWLECCZOnIifn19L1FcI0Rq0ooc1mvTYspeXFw8//DAPP/xwc9dHCCGkO0IIIWxKWsKWff7556pf4K677lJ9jhCilZMkbNnTTz+NRmPdbEWKoqDRaCQJCyFUk+6Ielx11VX1JuHKykry8/MpLi5Go9Fw++23y805IUTTXYbEumfPHlauXElqairV1dX06dOHmJgYbrzxxibHfOSRR9i9ezcffvghQ4YMafR4VUk4KSmp0WP279/P008/zeHDh9mwYYOa8EIIAVyelnBSUhJz587F1dWV6667DqPRSHJyMjExMcyfP5/7779fdczExER2796t6hxVT8xZY/DgwSxfvpyMjAzeeuut5g4vhGgNWviJuby8PObNm4e3tzcbN24kPj6eVatWkZiYiJeXFwsWLCAvL09VzMzMTF555RV1FaEFkjCYxhKHhoaydevWlggvhLjStXASXrNmDTqdjqioKMLDw837+/fvT0xMDFVVVaxbt87qeAaDgTlz5uDi4lIrnjVaJAkDODk5ce7cuZYKL4S4grX0pO41XQajR4+uU1azb9euXVbHS0hIICUlheeff5727durqkuLJOEDBw6QlpZGhw4dWiK8EOJK14ItYUVRSEtLQ6vVEhoaWqc8JCQErVZLWloaitJ44GPHjrFixQrGjBnDHXfcYX1F/qDqxtyaNWsaLNfpdKSnp/Pll18CMGrUKNUVEkKIpo4Tzs3NxcnJqVaRj48PPj4+5n8XFxej0+nw8/PD1dW1TihnZ2d8fX0pKCigrKyswbnRdTodTz31FD4+PrzwwgsqKnzR66k5+KWXXrJqnLCiKHTt2pXHHnusSZUSQrRuTR0dMXHiRPLz82uVxcXFMX36dPO/KyoqABpchNjd3R2g0SS8fPlyjh8/zltvvdXkIbmqkvA111zTcDBnZ3x8fBg4cCDjx4+X1TWEEE3XhGFniYmJFlvCF9Nqre+Fbag74pdffuG9997jzjvvtNi3bC1VSfijjz5q8gsJIURLCwgIwM3NrcFjapZoq6qqqveYysrKWsf+VXl5OU8//TT+/v48//zzTaytiaokPGXKFDp27MgzzzxT59tFCCGa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2dnZxMfH88MPP3D27FnatGnDgAEDiIqKqnd2tXPnzhEfH8+3337LuXPnCAwM5IEHHuDaa6+1ePzTTz/NZ599xpQpU5gzZ06tsuzsbD788EN27txJbm4u7u7u9OvXj+joaG644YZa11LjjjvuAODDDz80T8sJsG/fPlavXk1KSgoXLlygffv2XH/99Tz66KPm6/2ro0eP8s4773DgwAFKS0vp3bs3sbGxDb7fauXn5/PRRx+xe/dusrOzqaiowNvbm6uuuor77ruPMWPG1Hvu77//zuuvv26edrRXr1488MAD3HnnnRaPLy0tZfXq1WzZsoWsrCycnJwIDw9n3Lhx3HPPPQ45Y5ioS5KwncnKygKgc+fOdcq2bt3Kr7/+SmBgIIGBgZSXlxMcHAzA7t27mTFjBuXl5Xh4eNCzZ08KCwv5/vvv+f7775k+fTpxcXG14qWnpxMdHc2ZM2dwd3enZ8+e5OXlsWDBAgYPHqyq3j/++CMzZ86kpKQET09PwsLCOHfuHD/88AM//PADCxYsYPz48XTu3JlBgwZx4MABAK666irc3d3x9vY2x3r77bdZvnw5AL6+voSHh5Odnc3GjRv56quvWL58eZ3VQ7Zt28aTTz6JTqfD19eXHj16cOzYMWJiYrj66qtVXUt9jh49SnR0NEVFRXh6epr79rOzs83XOWvWLKZOnVrn3PT0dO677z7Kysro2bMn5eXlHDhwgAMHDrB3714WLlxY6/hTp04xZcoUMjMzcXZ2JiQkBKPRSEpKCikpKWzdupW333671k1e4aAU0eKys7OV8PBwJTw8XMnOzq73uPPnzyvXXXedEh4errz00kvm/W+88Yb5/AULFihGo1FRFEUpKCgwxx80aJASHh6uLFu2TKmqqjKfu337dnPZtm3bzPuNRqNy//33K+Hh4cqUKVOUoqIiRVEUxWAwKKtWrVIiIiLMr3mxOXPmKOHh4crixYvN+woKCpQhQ4Yo4eHhynPPPaeUlpaaX+P9999XwsPDlT59+tS69prYqampteJv2bJFCQ8PVwYNGqRs3rzZvF+n0ylvvfWWuSwnJ8dclp+fb77GV155RamurlYURVFKS0uVJ554wvxakydPrve9v9jGjRuV8PBw5e677661/+6771bCw8OVxx9/XCkpKTHvLykpUWbNmqWEh4crV199taLT6cxlF392N998s5KWlmYu++abb5S+ffsq4eHhyn//+1/zfr1er9x1111KeHi48s9//lM5d+6cuezEiRPK2LFjlfDwcOXf//53rfpFRkYq4eHhyo4dO6y6TmEfpE/YxhRF4cKFC+zatYtHHnmEwsJCvL29efjhh+sc6+LiwsyZM9FoNADmm2PvvfcepaWl3HXXXcycObNW62jUqFHMmjULoFY3wP79+0lJScHHx4elS5fSrl07ALRaLVOmTOHvf/+71dfw6aefUlRUxIABA5g/fz5t2rQBTAuTRkVFMWLECKqrq/nqq68ajfXGG28A8Mwzz3DrrbfWuvbHHnuMsWPHmn+m11i7di2lpaVce+21/Otf/zLPKdumTRsWL15cb/eFGqdPnyYnJwd3d3defPFFc7cRmLqQ/vWvfwFQUlJCXl5enfM1Gg0rVqygR48e5n1jxowxd5esWrXKvH/btm0cOXKE7t27s2zZMjp06GAuCwsLY9myZWi1WtauXUtBQcElX5uwLUnCl9moUaPqPKxxzTXXEBMTw8GDB/H19eXtt9+22B0RHh5uTnAX27FjBwC33Xabxde87bbb0Gg0HD16lHPnzgGm7gswLQpqaZzu+PHjrb6m77//HoC7777b/AVxsRdffJHt27fzyCOPNBgnKyuLEydOoNVqayXgi91+++0A7Nq1y7zvhx9+ALDYt+rq6lpvn6saXbp0ITk5meTkZIvvl7u7u/l/V1ZW1im/+uqr6zz4AnDPPfcA8Ntvv5kT6rfffgvA6NGjcXNzq3NOeHg44eHhVFdXs3fv3qZdkLAb0id8mf31YQ2tVounpyedOnVi4MCBjB07Fk9PT4vn+vv719lXWlrKmTNnAFi6dCnvvPOOxXOdnJzQ6/Wkp6fj7+9PRkYGYGpZWWIpYdQnOzsbgJ49e1osDwgIsCpOWloa8Gdr3JKaBJeZmYmiKGg0GvO1XNzKvFivXr2sen1ruLu7c/LkSQ4ePEhmZibZ2dmcOHHCXHcAo7Hu8uu9e/e2GK9Tp054e3tTUlJCeno67du35+TJkwB88803/PLLLxbPy83NBUx9zcKxSRK+zOp7WMMallpFF4+iOHLkSKMxSkpKAFPyBvDw8LB4nLe3NxqNBsWKhVfOnz8PYLGVrkZNnfR6vfnGXX2MRiNlZWV4eXmZz6vvy+vim36XIjU1lYULF9ZpfQYGBjJu3DjWr19f77n11a2mrKSkxPwFU3M92dnZ5i+4+tR8nsJxSRJ2cBcn0Z9++snqhyhqflKXl5dbLK+qqrIqAYOpdVhaWlpvLGvVJKqePXvy3//+1+rzfHx8KCgoqPWFdDFL3QNqnTt3joceeojz58/Tq1cvxo8fT+/evenRowe+vr7odLoGk3BD701NvWs+k5rPdPny5dxyyy2XXHdh36RP2MH5+PiYE+/vv/9u8RiDwcCePXvIzMw0L6DYvXt3wDTsypKan8TWCAkJafCc7777jkmTJtW6MWhJzQ20U6dOodPpLB6Tn5/P/v37a938qrmWY8eOWTynvvdFjY0bN3L+/Hl69OjBunXrePDBBxk8eLD58W1LN+MuVtNl8lfZ2dmUlpai1WoJDQ0F/nwfGqp3SkoKx48fb5YvGGFbkoSvADVjZj/55BOL5V9++SXR0dHcdddd5hbZqFGjANMNLksJ5LPPPrP69WsexNi0aVO9r79//36Ki4vN+2pu4F3c2g4LCyMwMJCKiop6Y7322mtMmjSJJ554wryv5lo2btxYpz/WaDTWG0uNnJwcAEJDQ2vdhKuxYcMG8/+2tFJwcnKyue/+YmvXrgVg8ODB5hEXI0aMAODzzz+nqqqqzjnZ2dlMnjyZO+64g5SUFPUXI+yKJOErwCOPPIKbmxtffvklS5curfWHu3v3bubPnw/Avffea+4f7du3L5GRkVRUVBAXF2e+0QOwfv16VXNXTJo0CR8fH/bt28fChQvNr68oCh999BGbN2/GxcWFSZMmmc+p6Xo4ffq0eZ9Go+Gxxx4DYOHChWzevNlcptfrSUhIICkpCaDWjbv77ruPTp068dtvv/H888+bW4dVVVW88MIL9bb21ahp7f/4448cPHjQvL+iooJ3332X+Ph48z5LiVOn0xEXF1frC2/9+vWsXr0ajUbDtGnTzPtvv/12QkJCyMzMZPr06eYRLWBqUT/22GPo9Xp69+5d75OQwnFIn/AVICwsjCVLljB79mxWrlzJRx99RPfu3SkqKjK34IYNG2Yey1rjpZdeYsqUKRw8eJDRo0cTHh5OYWEhZ86cITIy0up5aTt27Mjrr7/O9OnT+eCDD0hKSqJbt26cOXOGgoICnJycmD9/vjmRgWn0xYEDB3jyyScJDQ3liSee4IYbbmD8+PGcOHGC1atX8+STT7Jo0SI6derEqVOnzDcAp02bxujRo82xvLy8WLp0KY8++igbNmxg69atdOvWjczMTC5cuKDqWupz7733smbNGnJycrjvvvsICQnB3d2dzMxMysvLCQwMRKvVkp2dzdmzZ+ucP3z4cPbt28eoUaPo2bMnRUVF5pbx7Nmzue6668zHurq68tZbb/Hwww+zc+dORowYQVhYGNXV1WRkZGAwGAgICODtt9++pGsS9kFawleIsWPH8vnnnzN+/HjatWtHamoqRUVF9OvXj2eeeYZ33323ziOu/v7+JCYmMm3aNAIDA0lLS0Or1RIXF8err76q6vWHDx/Opk2bGD9+PF5eXqSmpmIwGBg9ejRr166tM0H6woULGTJkCIqikJGRQWZmprls7ty5rFq1ipEjR2I0Gs19vTfccANvv/22xQnSr776apKSkhg3bhyenp4cP36cwMBAXn31VSZOnKjqWizx8fFhw4YNPPjgg4SEhJCTk0NmZibdunUjLi6OTZs2MXbsWACLCb9Pnz6sXbuWIUOGkJGRwYULFxg2bBjvv/++xQdzwsLC2LRpE7GxsYSGhpKRkUFWVhZdu3ZlypQpfPbZZ3Tp0uWSr0vYnkax9ha4EEKIZictYSGEsCFJwkIIYUOShIUQwoYkCQshhA1JEhZCCBuSJCyEEDYkSVgIIWxIkrAQQtiQJGEhhLAhScJCCGFDkoSFEMKG/j/EcgUwpaKCxAAAAABJRU5ErkJggg==\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.9883914764577421\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>90.697674</td>\n",
       "      <td>45.348837</td>\n",
       "      <td>19.069767</td>\n",
       "      <td>9.534884</td>\n",
       "      <td>6.511628</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>90.697674</td>\n",
       "      <td>45.348837</td>\n",
       "      <td>19.069767</td>\n",
       "      <td>9.534884</td>\n",
       "      <td>6.511628</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     90.697674  45.348837  19.069767  9.534884  6.511628  4.883721\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  90.697674  45.348837  19.069767  9.534884  6.511628  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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
