{
 "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 CXCR4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 3537/3537 [00:00<00:00, 9339.16it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti/target_cxcr4/'\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.9954128440366973"
      ]
     },
     "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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yVljzp07B0C9evWKle3YsYPffvuNwMBAAgMDycrKIigoCCh87c6ECRPIysrC3d2d0NBQUlJS+OGHH/jhhx8YP34848aNK3K+uLg4hg0bxqVLl3BzcyM0NJTExETmzJlDu3btVMUdGRnJxIkTSU9Px8PDg5CQEJKSkvjpp5/46aefmDNnDv369aNevXqEh4dz6NAhAO644w7c3Nzw9va2nmv58uUsXrwYAF9fX4xGIwkJCWzatIlvvvmGxYsXF5tau3PnTiZPnkxeXh6+vr40bdqUkydPMnLkSNq2bavqXkpy4sQJhg0bRmpqKh4eHtZnBwkJCdb7fOGFF3juueeKHRsXF8eAAQPIzMwkNDSUrKwsDh06xKFDh9i3bx9z584tUv/8+fMMHz6c+Ph4nJycaNy4MWazmejoaKKjo9mxYwfLly+3uVi8qCIUYXcJCQmK0WhUjEajkpCQUGK9a9euKXfffbdiNBqV2bNnW/cvWbLEevycOXMUs9msKIqiXL161Xr+8PBwxWg0KosWLVJyc3Otx3733XfWsp07d1r3m81m5YknnlCMRqMyfPhwJTU1VVEURTGZTMqqVauUsLAw6zVvNG3aNMVoNCpvvvmmdd/Vq1eVjh07KkajUXnllVeUjIwM6zU++ugjxWg0KnfeeWeRe7ec+9SpU0XOv337dsVoNCrh4eHK119/bd2fl5enLFu2zFp24cIFa1lycrL1Ht9++20lPz9fURRFycjIUCZNmmS91lNPPVXiz/5GmzZtUoxGo/LYY48V2f/YY48pRqNRef7555X09HTr/vT0dOWFF15QjEaj0rZtWyUvL89aduNn16NHDyU2NtZa9u233yotWrRQjEaj8tVXX1n3FxQUKI8++qhiNBqVf//730pSUpK1LCYmRunVq5diNBqV119/vUh8Xbp0UYxGo7J79+4y3afQNulzdjBFUbh+/To//vgjzz77LCkpKXh7ezNixIhidZ2dnZk4cSI6nQ7A+lDuww8/JCMjg0cffZSJEycWaU1169aNF154AaBId8KBAweIjo7Gx8eHhQsXUrNmTaBwIfLhw4ermrq6fv16UlNTad26NbNmzcLT0xMoXP1r6NChdO7cmfz8fL755pubnmvJkiUAvPTSSzz00ENF7n3MmDH06tXL+nXfYu3atWRkZNChQwemTJliXQLS09OTN998s8Ru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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.9969053934571176\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>92.307692</td>\n",
       "      <td>46.153846</td>\n",
       "      <td>20.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>6.666667</td>\n",
       "      <td>5.0</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>92.307692</td>\n",
       "      <td>46.153846</td>\n",
       "      <td>20.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>6.666667</td>\n",
       "      <td>5.0</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     92.307692  46.153846   20.0    10.0  6.666667     5.0\n",
       "1           NaN        NaN    NaN     NaN       NaN     NaN\n",
       "mean  92.307692  46.153846   20.0    10.0  6.666667     5.0"
      ]
     },
     "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
}
