{
 "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 AMPC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 2965/2965 [00:00<00:00, 8955.19it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_ampc/'\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.8909090909090909"
      ]
     },
     "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=4,\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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uztpaWkUFxfTrl07tFotGRkZnD9/vsr5gwYNYv/+/dx000107tyZvLw888h49uzZXHfddea6rq6urFq1ikceeYRdu3YxZMgQwsLCKC8vJzU1FYPBQGBgIG+++eYVvSdhH2Qk3EjceuutfPrpp4wePZoWLVqQlJREXl4ePXr04Omnn+btt9+ussTV39+fDRs2MH36dNq1a0dycjJarZaYmBheffVVVdcfNGgQW7duZfTo0Xh5eZGUlITBYGD48OFs3LixygbpCxcupH///iiKQmpqKmlpaeayuXPnsmbNGoYNG4bRaDTnem+44QbefPNNixuk9+7dm/j4eEaNGoWnpycnTpygXbt2vPrqq4wdO1bVe7HEx8eHjz/+mAkTJhASEkJmZiZpaWl06NCBmJgYtm7dyq233gpgMeB369aNjRs30r9/f1JTU7l06RIDBw7k3XfftbgwJywsjK1btzJ16lRCQ0NJTU0lPT2d4OBgJk2axCeffELbtm2v+H0J29Mo1t4CF0IIUe9kJCyEEDYkQVgIIWxIgrAQQtiQBGEhhLAhCcJCCGFDEoSFEMKGJAgLIYQNSRAWQggbkiAshBA2JEFYCCFsSIKwEELY0P8DktSgQpEqUacAAAAASUVORK5CYII=\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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o169ekRHR5OWlqbqWorz4osvsnLlSq5evUrfvn2pX78+jo6OREdHk5mZSZ06ddBqtcTExHD9+vVCx3fo0IEjR47QpUsXgoODSU5ONrfYJ02aRPv27c1l7e3tWbBgAa+++ip79+6lY8eOBAUFkZeXx6VLl9Dr9dSqVYuFCxfe0TWJqkda6FVE9+7d2bx5M3369KF69epERESQnJxMs2bNeOedd/jqq68K3SZeo0YNVq1axdixY6lTpw6RkZFotVrGjRvHxx9/rOr9O3TowJYtW+jTpw+urq5ERESg1+vp2rUrq1evLvSwiNmzZ9OuXTsUReHSpUtER0eb97399tssWbKEzp07YzAYzH3jjz76KAsXLizyYRGtWrVi48aN9O7dG2dnZ/766y/q1KnDxx9/zIABA1RdS1Hc3d1Zv349L7/8MvXr1+fq1atER0dTr149xo0bx5YtW+jevTtAkR8eTZo0YfXq1bRr145Lly6RlpbGww8/zLJly4q8iSwoKIgtW7YwZswYAgMDuXTpEpcvX8bf359hw4axadMmateufcfXJaoWjVLWqQxCCCGsmrTQhRCiipBAF0KIKkICXQghqggJdCGEqCIk0IUQooqQQBdCiCpCAl0IIaoICXQhhKgiJNCFEKKKkEAXQogqQgJdCCGqiP8HFRgzmd/UPqYAAAAASUVORK5CYII=\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.8425210674157303\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>28.571429</td>\n",
       "      <td>14.285714</td>\n",
       "      <td>5.714286</td>\n",
       "      <td>4.285714</td>\n",
       "      <td>3.809524</td>\n",
       "      <td>4.285714</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>28.571429</td>\n",
       "      <td>14.285714</td>\n",
       "      <td>5.714286</td>\n",
       "      <td>4.285714</td>\n",
       "      <td>3.809524</td>\n",
       "      <td>4.285714</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     28.571429  14.285714  5.714286  4.285714  3.809524  4.285714\n",
       "1           NaN        NaN       NaN       NaN       NaN       NaN\n",
       "mean  28.571429  14.285714  5.714286  4.285714  3.809524  4.285714"
      ]
     },
     "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
}
