{
 "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 KIF11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 7110/7110 [00:00<00:00, 9212.09it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti/target_kif11/'\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": "1334e946",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9774011299435028"
      ]
     },
     "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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4sEHH6Rnz54Oyz/zzDN8/vnnTJgwgenTp1c4lp6ezkcffcTWrVs5ffo0RqORa6+9ltjYWG655ZYK11Ju6NChAHz00Uf2aTkBdu3axfLly0lMTCQvL48mTZpw880388gjj9iv988OHjzIokWL2LNnDwUFBXTq1IlJkyZV+/NWKysrixUrVrB9+3bS09MpLi4mICCAa665hvvuu4/BgwdXee7x48d544037NOOduzYkQcffJBhw4Y5LF9QUMDy5cv57rvvSEtLQ6fTERUVxfDhw7n33ns9csYwUZkEYTeTlpYGQIsWLSod27hxI7/99hutWrWiVatWFBUVERYWBsD27duZOnUqRUVF+Pj40KFDB86dO8ePP/7Ijz/+yGOPPcaUKVMq1JecnExsbCynTp3CaDTSoUMHMjMzmT17NjfccIOqdv/88888/vjj5Ofn4+vrS2RkJGfPnuWnn37ip59+Yvbs2YwYMYIWLVrQo0cP9uzZA8A111yD0WgkICDAXte7777Lm2++CUBQUBBRUVGkp6ezdu1avv76a958881Kq4ds2rSJJ598EpPJRFBQEO3bt+fQoUPExcVx/fXXq7qWqhw8eJDY2FhycnLw9fW15/bT09Pt1zlt2jQmTpxY6dzk5GTuu+8+CgsL6dChA0VFRezZs4c9e/awc+dO5syZU6H8iRMnmDBhAqmpqXh5eREeHo7VaiUxMZHExEQ2btzIu+++W+Emr/BQiqh36enpSlRUlBIVFaWkp6dXWe78+fPKTTfdpERFRSkvv/yyff9bb71lP3/27NmK1WpVFEVRsrOz7fX36NFDiYqKUhYsWKCUlpbaz928ebP92KZNm+z7rVarcv/99ytRUVHKhAkTlJycHEVRFMVisSjLli1ToqOj7a95qenTpytRUVHKK6+8Yt+XnZ2t9OrVS4mKilKef/55paCgwP4aH3zwgRIVFaV07ty5wrWX13348OEK9X/33XdKVFSU0qNHD2XDhg32/SaTSXnnnXfsxzIyMuzHsrKy7Nf46quvKmVlZYqiKEpBQYHyxBNP2F9rzJgxVf7sL7V27VolKipKueeeeyrsv+eee5SoqCjlH//4h5Kfn2/fn5+fr0ybNk2JiopSrr/+esVkMtmPXfre3XbbbUpSUpL92Lfffqt06dJFiYqKUv773//a95vNZuXuu+9WoqKilL///e/K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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.9548099762470309\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>55.0</td>\n",
       "      <td>27.5</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.333333</td>\n",
       "      <td>4.75</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>55.0</td>\n",
       "      <td>27.5</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.333333</td>\n",
       "      <td>4.75</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      55.0   27.5   16.0     9.5  6.333333    4.75\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   55.0   27.5   16.0     9.5  6.333333    4.75"
      ]
     },
     "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": "99dce9ab",
   "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
}
