{
 "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:13<00:00, 2830.11it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_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.9685258964143426"
      ]
     },
     "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",
    "# 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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pYhGl5OTo0RGRiqRkZFKTk6O1f3OnTun3HDDDUpkZKTy8ssvm7e/9dZb5uNnzZqlGI1GRVEUJT8/31x/r169lMjISGXBggVKRUWF+djNmzebyzZt2mTebjQalQceeECJjIxUxo8frxQUFCiKoigGg0FZunSp0qVLF/NzXmzq1KlKZGSkMnfuXPO2/Px8JTo6WomMjFSef/55pbi42PwcH3zwgRIZGal079692rlX1Z2Wllat/g0bNiiRkZFKr169lPXr15u363Q65Z133jGX5ebmmsvOnDljPsdXX31VqaysVBRFUYqLi5Unn3zS/Fxjx461+tpfbM2aNUpkZKRyzz33VNt+zz33KJGRkcq//vUvpaioyLy9qKhImTJlihIZGalcf/31ik6nM5dd/N7dcsstSnp6urns22+/VXr06KFERkYqX331lXm7Xq9X7r77biUyMlL55z//qZw+fdpcduTIEeW2225TIiMjlf/+97/V2hcTE6NERkYqW7Zssek8hWOQnLCdKYrC+fPn2bZtG48++ihnz57Fz8+PRx55pMa+bm5uTJ48GY1GA2C+OPb+++9TXFzM3XffzeTJk6v1joYMGcKUKVMAqqUBdu/eTWpqKv7+/syfP5/mzZsDoNVqGT9+PP/3f/9n8zl8+umnFBQUcN111zFz5kx8fHwA08Kk48aNY9CgQVRWVvL111/XWddbb70FwLPPPsvtt99e7dwff/xxbrvtNvPP9CorV66kuLiYvn378u9//9s8p6yPjw9z5861mr5Q4/jx4+Tm5uLp6clLL71kThuBKYX073//G4CioiLy8vJqHK/RaFi4cCGdOnUybxs2bJg5XbJ06VLz9k2bNnHgwAE6duzIggULaNmypbksIiKCBQsWoNVqWblyJfn5+Zd9bsK+JAhfYUOGDKlxs0afPn2Ii4tj7969BAQEsGjRIovpiMjISHOAu9iWLVsAuOOOOyw+5x133IFGo+HgwYOcPn0aMKUvwLQoqKVxuiNHjrT5nH744QcA7rnnHvMXxMVeeuklNm/ezKOPPlprPdnZ2Rw5cgStVlstAF/szjvvBGDbtm3mbT/++COAxdyqu7u71ZyrGm3atCElJYWUlBSLr5enp6f5v8vLy2uUX3/99TVufAG49957Afjjjz/MAfW7774DYOjQoXh4eNQ4JjIyksjISCorK/n555/r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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.9894496834823466\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>85.0</td>\n",
       "      <td>45.357143</td>\n",
       "      <td>19.0</td>\n",
       "      <td>9.857143</td>\n",
       "      <td>6.619048</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>85.0</td>\n",
       "      <td>45.357143</td>\n",
       "      <td>19.0</td>\n",
       "      <td>9.857143</td>\n",
       "      <td>6.619048</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      85.0  45.357143   19.0  9.857143  6.619048  4.964286\n",
       "1       NaN        NaN    NaN       NaN       NaN       NaN\n",
       "mean   85.0  45.357143   19.0  9.857143  6.619048  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)"
   ]
  }
 ],
 "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
}
