{
 "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:04<00:00, 8348.02it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_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": [],
   "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.9896414342629483"
      ]
     },
     "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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\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.9862694152581086\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>87.857143</td>\n",
       "      <td>46.785714</td>\n",
       "      <td>18.857143</td>\n",
       "      <td>9.714286</td>\n",
       "      <td>6.47619</td>\n",
       "      <td>4.892857</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>87.857143</td>\n",
       "      <td>46.785714</td>\n",
       "      <td>18.857143</td>\n",
       "      <td>9.714286</td>\n",
       "      <td>6.47619</td>\n",
       "      <td>4.892857</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     87.857143  46.785714  18.857143  9.714286  6.47619  4.892857\n",
       "1           NaN        NaN        NaN       NaN      NaN       NaN\n",
       "mean  87.857143  46.785714  18.857143  9.714286  6.47619  4.892857"
      ]
     },
     "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
}
