{
 "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 HIVPR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 37674/37674 [00:03<00:00, 9921.92it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_hivpr/'\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.9597609561752988"
      ]
     },
     "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": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAFCCAYAAADhQCbjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABY6klEQVR4nO3deVxU5f7A8c/MsIMoICggLsjiXmpq9Qv3srqpZYapuWtmbtc0bbHcLStLMcvr0mZp7nqtrpqaG+WKpeUGgogLCIIgO8yc3x/jTBIDchBkhO/7vubV9ZzvOfMcwe888z3PeR6NoigKQggh7nvaim6AEEKIsiEJXQghKglJ6EIIUUlIQhdCiEpCEroQQlQSktCFEKKSkIQuhBDAxo0bCQ4O5ujRoxb37927l2HDhtG2bVuaNWtGp06dePfdd4mPj7cYn5CQwLvvvkuXLl1o0aIF3bp1Y/HixeTm5lqMT0tL48MPP6Rbt260aNGCzp078/7775Oenl7ia9DIOHQhRFV3/Phxhg4dSmZmJt999x0PPfRQgf1Lly5l/vz5aLVaWrRogYeHB6dPn+bKlSu4u7vz7bff0rBhQ3N8fHw8ffr0IT4+niZNmuDn50dERASJiYm0bduWL774AltbW3N8eno6/fr14+zZszRo0ICgoCD++usvLl26REBAAN9//z3VqlW784UoQghRhW3btk1p2bKlEhQUpAQFBSlHjhwpsD8yMlJp1KiR8uCDDyoRERHm7bm5ucr06dOVoKAgJTQ0tMAxI0eOVIKCgpTFixebt2VkZCiDBw9WgoKClBUrVhSInzVrlhIUFKRMnTpV0ev1iqIoSl5envL6668rQUFBysyZM0t0LdJDF0JYlfz8fPR6verjdDodNjY2JY6Pj4/n448/ZsuWLTg6OuLs7ExSUlKhHvr8+fNZunQpo0ePZty4cQXOkZeXR/v27UlOTmb37t34+voSHR3N008/jZ+fH9u3b0er/buyfeXKFbp27Urt2rXZvXs3YCy1hISEYGNjw969e3FxcTHHZ2Rk0KlTJ3Jycvjtt99wcnIq9ppKfvVCCFHO8vPz+fNEOHrF5c7B/6DT6WjWrFmJk/qCBQvYsmULzZo1Y+7cucyePZukpKRCcba2tgQHB9OmTRuL++rUqUNycjLXrl3D19eXAwcOoCgKnTp1KpDMAXx8fGjSpAknT54kKiqKgIAAjhw5QnZ2Nl27di2QzAGcnZ155JFH2LZtG0eOHKFDhw7FXpMkdCGE1dDr9egVFxrWfBc7XXKJj8vVu3M+aSZ6vb7ECd3f35958+bRo0ePQon3duPGjSvUMzfJzMwkKioKgNq1awOY/xwYGFjk+548eZJz584REBBQoniAs2fPSkIXQtx/dNokdLrEkscrBsBYRtHpdAX2ubq64urqWuiYl19++e4aCSxbtozMzEyaN2+Ot7c3ANeuXQPAy8vL4jGenp4A5m8DiYmJBbYXFX/9+vU7tkcSuhDC6hhQMFDy23um2H79+hUqm4wZM4axY8eWafvAOIzxP//5D1qtltdff928PSsrCwAHBweLx5m2Z2ZmFvivo6NjieKLIwldCGF1DLf+pyYeYNWqVRZ76GVtz549jBs3Dr1ez8SJE2nXrp15n+n9NRpNsecwGAylii+OJHQhhNUxKAp6FQPwDLdia9eujb29fXk1C4D169czbdo08vPzGTNmTKHSjamnnZ2dbfF403bTiBW18cWRhC6EsDoGUFlyuTc++eQTlixZgkaj4c0332Tw4MGFYky1c0sjZuDvmrkprqTxRdXYbycJXQhhdfQoaFUkdL2K2NJQFIWpU6eyfv167OzsmDdvHk8//bTFWNNoFdPolX86f/48AEFBQarig4OD79hOmctFCGF1lFs3RUv6Uso5ob///vusX78eFxcXVqxYUWQyBwgJCQHgl19+KVT3vnLlCqdPn8bX15eAgAAA2rRpg4ODA7/99luhG58ZGRnmB4pat259x3ZKQhdCWB39rRq6mld52bdvH1999RU2Njb85z//oW3btsXG+/n5ERISQnR0NAsXLjRvz8zMZOrUqej1eoYMGWLe7uTkxLPPPktqaiozZswgPz8fMD5kNXPmTNLS0ujTp0+hh44skZKLEMLqGFBXFy/PGnpYWBgAHh4efP/993z//fcW40aNGmWeoGvatGn07duXJUuWsHv3bho0aGCenKt9+/b07du3wLETJkzg0KFDbN68mWPHjtGkSRNOnTpFXFwcTZs2LfGwS0noQgirY0BRVRdXcwNVjRs3bnDy5EnAOB3u1q1bi4x94YUXzAndz8+PdevWERYWxr59+4iNjcXPz4+BAwcyaNCgQk+z1qhRg++//55PP/2UnTt38ssvv+Dt7c3w4cN55ZVXcHZ2LlF7ZXIuIYTVyMnJ4c8//8Sj5lB0NtdKfJw+34vrSV/QrFmzch+2aM2khy6EsDp6QE2nW/3cjJWTJHQhhNUxAMU/N1k4XkhCF0JYIQMa1KR0g6r0X3lJQhdCWB2DgqqSi0HuBAKS0IUQVkiPBkV66KpJQhdCWB2DyoSuJrYyk4QuhLA6BkWDRlGR0FXEVmaS0IUQVkcPaFT10AVIQhdCWCEDWtRNNaWViamQhC6EsEIGRQNqyiiKRhI6lTyhGwwGMjIysLW1vePyTkKIsqMoCnl5eTg7O6PVqk+1epXj0EFTuZNZCVXqv4OMjAzOnTtX0c0QosoKCgqiWrVqqo8zKFoUpeQfBBoVsZVZpU7otra2APi6v4mt7noFt6Z8XEhcSn3Pl+8ceJ8a1aHdnYPuU1PWD2Ne7xUV3Yxy4erpwqjP+5j/DaplHLaoIqHLsEWgkid0U5nFVncdWxUzt91vKvO13YhPq+gmlKvKfn2lLXWqfbBIErpRpU7oQoj7k0HRYlBRRtFKyQWQhC6EsEIGNCof55ceOsiaokIIUWlID10IYXX0aG89XFQyam6gVmaS0IUQVsegaNCrqYvLXC6AJHQhhBUyqOyhy3OiRpLQhRBWR69o0Kt89F9IQhdCWCEDWvTSQ1dNEroQwuoYUDcOXU15pjKThC6EsDp6NCp76FJyAUnoQggrZFBZQ9dKDR2QhC6EsEJqR7lIycVIEroQwuroFa2qcegyl4uRJHQhhNVRVM7lomZmxspMEroQwuroVT4pqmrMeiUm31OEEFZHf2scuprX3dq4cSPBwcEcPXrU4v6YmBhee+01OnTowAMPPED37t1ZuXIlBoPBYnxCQgLvvvsuXbp0oUWLFnTr1o3FixeTm5trMT4tLY0PP/yQbt260aJFCzp37sz7779Penp6ia9BEroQwuooigaDipdylz3048ePM2vWrCL3nzlzht69e/Pjjz/i4+NDSEgI8fHxzJ49m8mTJxeKj4+PJzQ0lDVr1uDq6krHjh3JyMggLCyMYcOGkZeXVyA+PT2dl156ieXLl6PRaOjYsSMajYYvv/ySPn36cPPmzRJdhyR0IYTVuZc99O3btzNs2DAyMzMt7lcUhcmTJ5Oens4HH3zA6tWr+fTTT9m+fTvBwcFs3bqV7du3Fzhm+vTpxMfHM378eDZt2kRYWBg7duzg0Ucf5fDhw6xcubJA/IIFCzh79iyhoaH89NNPhIWFsX37dnr27ElUVBQLFiwo0bVIQhdCWB1jz1ur4qW+hx4fH8/kyZMZN24cBoOBmjVrWowLDw/n7NmztG3blp49e5q3u7u7M336dIACCTo6Opo9e/ZQt25dXnnlFfN2Jycn5syZg06n49tvvzVvT0tLY926dbi4uDBlyhS0WmNatrGxYdq0aVSvXp3169cX+YFzO0noQogqacGCBWzZsoVmzZqxZs0a/P39Lcbt378fgK5duxba16pVKzw8PDh27Ji51n3gwAEURaFTp07m5Gzi4+NDkyZNuHz5MlFRUQAcOXKE7OxsHn74YVxcXArEOzs788gjj5Cdnc2RI0fueE2S0IUQVseA5tbj/yV7qVuuzsjf35958+axbt06goODi4wzJd6goCCL+xs0aIDBYOD8+fMF4gMDA4t8X4Bz586pij979myx1wMybFEIYYXULhKtJtbk5ZdfLlHctWvXAPD09LS437Q9KSmpQLyXl1eJ4hMTE0t0/uvXr9+xrZLQhRBWx9TzVhMPxrq4TqcrsM/V1RVXV9dStyUrKwsABwcHi/tN2001brXxpv86OjqWKL44ktCFEFZHUdlDV27F9uvXz9zzNRkzZgxjx44tdVtMHxAaTfEfMKbx6OUdXxxJ6EIIq6NH5ZOit3roq1atsthDvxumnnN2drbF/abtzs7OquKdnJxKFV8cSehCCKtjUHmj0xRbu3Zt7O3ty7QtXl5enD59mqSkJBo2bFho/z9r4Kba+T+/Kfwz3hRX0viiauy3k1EuQgirY7g122JJX6W5KVpSptEnptEot1MUhejoaHQ6nTnZFxcPmEfDmEbNlDS+uJE4JpLQhRBWR81j/6ZXeQkJCQFg165dhfZFRESQnJxM69atzWPITfG//PJLobr3lStXOH36NL6+vgQEBADQpk0bHBwc+O233wrd+MzIyOC3337DycmJ1q1b37GtktCFEFanIibnKkrbtm0JDAwkPDyctWvXmrcnJyczY8YMAIYMGWLe7ufnR0hICNHR0SxcuNC8PTMzk6lTp6LX6wvEOzk58eyzz5KamsqMGTPIz88HID8/n5kzZ5KWlkafPn0KPXRkidTQhRBWx6CorKGXYw9dq9Uyd+5cBg0axDvvvMP69evx8vLi8OHDpKamEhoaSufOnQscM23a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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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/v14enrSs2dPYmJi6Nu3r6ObJ0Stubm54ebmRkzcqFof62o0igwoFUI4EaPRiMlkUn2cm5tbpRFDrkCCsBBCOJDcmBNCCAeSICyEEA4kQVgIIRxIgrAQQjiQBGEhhHAgCcJCCOFAEoSvghMnThAREWHz1alTJ7p168att95KTEyMzTkhHOGPP/6wtvFyzz33HBEREcydO/eKz3Hu3DkuXrx4xfXU5JNPPiEiIoLHHnvMrv3Xr19PREQEQ4cOveJzL1y4kIiICCZMmHDFddXk9ttvJyIigu+//77ezyXqjuuNbHZxXbt2rbA0kaIoGAwGTpw4wfbt29m+fTsjRoxg+vTpDmxl/Vu+fDkLFy5k1apVMu2maNAkCF9lCxYsICQkpNL2srIy3n33XZYsWUJ8fDz9+/fn9ttvd0ALqzd58mSio6MJDAy8onpmz55dRy0SwrVJOsJJeHh4MGnSJHr06AFAfHy8g1tkW7NmzejQoQNBQUGObooQ1wQJwk4mMjISsExNKYS49kk6wsmUL1N/+WrJCxcu5N133+XZZ5/F29ubxYsXk5eXR9u2bXnvvfdo164dAJmZmSxdupQff/yRM2fO4OvrS/fu3Rk9enSVs6udPXuWpUuX8t1333H27Flat27No48+Su/evW3u/9xzz/H5558zZswYpk6dWqEsMzOTjz/+mB07dnD69Gl0Oh3XX389UVFR3HLLLRWupdy9994LwMcff2ydlhNg7969LF++nMTERC5evEiTJk24+eabGTdunPV6/+rIkSMsXryY/fv3U1BQQOfOnYmJian2/Vbr3LlzrFixgl27dpGZmUlxcTH+/v5cd911PPzwwwwePLjKY48fP87bb79tnXa0U6dOPProo9x333029y8oKGD58uVs3ryZjIwM3Nzc0Ov1DB06lAcffNAlZwwTlUkQdjIZGRkAtGzZslLZli1b+PXXX2ndujWtW7emqKiINm3aALBr1y4mTJhAUVER3t7edOzYkfPnz/PDDz/www8/8PTTTxMbG1uhvtTUVKKiojh16hQ6nY6OHTuSnZ3NzJkzufHGG1W1+6effmLixInk5+fj4+NDeHg4Z8+e5ccff+THH39k5syZDBs2jJYtW9KzZ0/2798PwHXXXYdOp8Pf399a16JFi1iwYAEAgYGB6PV6MjMzWbduHV9//TULFiyotHrI1q1b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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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rh3Z2dnMnDmTnj17qmr3zz//zJQpUygoKMDHx4eoqCjOnDnDTz/9xE8//cTMmTMZMWIELVq0oHv37uzevRuAq666Ci8vL/z9/a11vf3228ybNw+AwMBAoqOjyczMZM2aNXz99dfMmzev0uohmzdv5oknnsBgMBAYGEjbtm05ePAgcXFx9OjRQ9W5VOXAgQPExsaSl5eHj4+PNbefmZlpPc+pU6cyYcKESsempqZyzz33UFRURLt27SguLmb37t3s3r2bX3/9lVmzZlXY//jx44wfP5709HTc3NyIiIjAbDaTnJxMcnIymzZt4u23365wkVe4KEXUu8zMTCU6OlqJjo5WMjMzq9zv3LlzyjXXXKNER0crL730knX7/PnzrcfPnDlTMZvNiqIoSm5urrX+7t27K9HR0cqbb76p6PV667Fbtmyxlm3evNm63Ww2K/fee68SHR2tjB8/XsnLy1MURVFMJpOybNkyJSYmxvqcF5s2bZoSHR2tvPzyy9Ztubm5Su/evZXo6GjlueeeUwoLC63P8f777yvR0dFKx44dK5x7ed2HDh2qUP/GjRuV6OhopXv37sqGDRus2w0Gg7Jw4UJrWVZWlrUsJyfHeo6vvvqqUlZWpiiKohQWFiqPP/649blGjx5d5Wt/sTVr1ijR0dHKnXfeWWH7nXfeqURHRyv/+c9/lIKCAuv2goICZerUqUp0dLTSo0cPxWAwWMsufu9uvPFGJSUlxVr27bffKp06dVKio6OVr776yrrdaDQqd9xxhxIdHa088sgjypkzZ6xlR44cUYYMGaJER0cr//vf/yq0b8CAAUp0dLSydetWu85TOAfJCTuYoiicP3+ebdu28dBDD3H27Fn8/f158MEHK+3r7u7OlClT0Gg0ANaLY++99x6FhYXccccdTJkypULvaNCgQUydOhWgQhpg165dJCcnExAQwNy5c2ncuDEAWq2W8ePH8+9//9vuc/j000/Jy8uja9euJCQk4OvrC1gWJh03bhz9+/enrKyMr7/+usa65s+fD8AzzzzDrbfeWuHcH330UYYMGWL9mV5u5cqVFBYWcvXVV/N///d/1jllfX19efnll6tMX6hx4sQJsrKy8PLy4sUXX7SmjcCSQvq///s/AAoKCsjOzq50vEajYcGCBbRt29a67eabb7amS5YtW2bdvnnzZvbv30+bNm148803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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.9874010882333745\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>78.571429</td>\n",
       "      <td>42.857143</td>\n",
       "      <td>18.285714</td>\n",
       "      <td>9.571429</td>\n",
       "      <td>6.52381</td>\n",
       "      <td>4.964286</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>78.571429</td>\n",
       "      <td>42.857143</td>\n",
       "      <td>18.285714</td>\n",
       "      <td>9.571429</td>\n",
       "      <td>6.52381</td>\n",
       "      <td>4.964286</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     78.571429  42.857143  18.285714  9.571429  6.52381  4.964286\n",
       "1           NaN        NaN        NaN       NaN      NaN       NaN\n",
       "mean  78.571429  42.857143  18.285714  9.571429  6.52381  4.964286"
      ]
     },
     "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.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
