{
 "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 HIVRT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 19774/19774 [00:02<00:00, 9548.18it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_hivrt/'\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.9530434782608695"
      ]
     },
     "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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\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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JQi7oAkTJtC2bVtiYmI4cOAAnp6e9OnTh6lTpzJw4EBHV0+IWnNzc8PNzY2pMRNrfa6r0SjSoVQI4UQMBgNGo1H1eW5ublV6DLkCCcJCCOFA8mBOCCEcSIKwEEI4kARhIYRwIAnCQgjhQBKEhRDCgSQICyGEA0kQvgJOnz5NRESE1VfXrl3p1asXN954I1OnTrU6J4QjHD9+3FLHS82ZM4eIiAiWLFly2de4cOEC+fn5l11OTT788EMiIiJ44IEH7Do+Li6OiIgIxowZc9nXXrFiBREREcyYMeOyy6rJ8OHDiYiI4Lvvvqv3a4m643o9m11cjx49Ki1NpCgKer2e06dPs3PnTnbu3Mn48eOZN2+eA2tZ/9auXcuKFStYv369TLspGjUJwlfY8uXLad++fZXt5eXlvP7666xatYrY2FgGDx7M8OHDHVDD6j3++ONERUURGBh4WeUsWrSojmokhGuTdIST8PDw4LHHHqN3794AxMbGOrhG1rVs2ZLOnTsTFBTk6KoI0SBIEHYyw4YNA8xTUwohGj5JRziZimXqL10tecWKFbz++us8+eST+Pj48Oabb5KXl0eHDh1444036NixIwDp6emsXr2aH374gXPnztGkSROuueYaJk2aZHN2tfPnz7N69Wq+/fZbzp8/T7t27bj//vvp37+/1ePnzJnDJ598wuTJk5k9e3alfenp6bz//vvs2rWLzMxMvL296dmzJ5GRkdxwww2V7qXCHXfcAcD7779vmZYTYN++faxdu5aEhATy8/Np3rw5119/PY888ojlfv/u6NGjvPnmmxw4cIDCwkK6devG1KlTq32/1bpw4QIffPABe/bsIT09nZKSEvz9/bnqqqu49957ufnmm22ee+rUKV599VXLtKNdu3bl/vvv584777R6fGFhIWvXruWbb74hLS0NNzc3dDodY8aM4e6773bJGcNEVRKEnUxaWhoAbdq0qbJv27Zt/Pbbb7Rr14527dpRXFxMSEgIAHv27GHGjBkUFxfj4+NDly5dyMnJ4fvvv+f7779n+vTpREdHVyovOTmZyMhIzp49i7e3N126dCErK4sFCxZw7bXXqqr3jz/+yMyZMykoKMDX15fw8HDOnz/PDz/8wA8//MCCBQu45557aNOmDX369OHAgQMAXHXVVXh7e+Pv728pa+XKlSxfvhyAwMBAdDod6enp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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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\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.9724794585129309\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>64.0625</td>\n",
       "      <td>38.28125</td>\n",
       "      <td>17.1875</td>\n",
       "      <td>8.75</td>\n",
       "      <td>6.25</td>\n",
       "      <td>4.6875</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>64.0625</td>\n",
       "      <td>38.28125</td>\n",
       "      <td>17.1875</td>\n",
       "      <td>8.75</td>\n",
       "      <td>6.25</td>\n",
       "      <td>4.6875</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     64.0625  38.28125  17.1875    8.75    6.25  4.6875\n",
       "1         NaN       NaN      NaN     NaN     NaN     NaN\n",
       "mean  64.0625  38.28125  17.1875    8.75    6.25  4.6875"
      ]
     },
     "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
}
