{
 "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, 3483.86it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_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": [],
   "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": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9181818181818182"
      ]
     },
     "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=5000, \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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\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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65WFCxcqOTk5ln137txp2fbLL79Y1huNRuWFF15Q9Hq9MmzYMCUlJUVRFEUxGAzKihUrlODgYMs5bzVlyhRFr9cr8+fPt6xLSkpS2rVrp+j1emX69OlKenq65RwrV65U9Hq90rRp0wLXbj52REREgeNv375d0ev1SsuWLZUffvjBsj43N1dZsmSJZdvly5ct2xITEy3X+P777yt5eXmKoihKenq6MmnSJMu5XnzxxSJ/9rfauHGjotfrlWeffbbA+meffVbR6/XKf/7zH+XmzZuW9Tdv3lRee+01Ra/XK61atVJyc3Mt22793T3++ONKVFSUZdvPP/+sNGvWTNHr9cr3339vWZ+fn6/06dNH0ev1yujRo5WEhATLtsjISKVnz56KXq9X3n333QLxdenSRdHr9cru3btLdZ2i8pEaejlTFIW0tDT279/P8OHDSU5OxtPTk5dfftmqraOjIxMnTkSj0QBYbkx+/vnnpKen06dPHyZOnFig19atWzdee+01gAKljqNHjxIeHo6Xlxf/+9//qFq1KgBarZZhw4bxzDPPlPoavv32W1JSUnj44YeZNWsW7u7ugOml1kOHDqVz587k5eXx448/lnis0NBQAN544w2eeuqpAtc+duxYevbsaSlFmK1du5b09HTatm3L66+/bpkT293dnfnz5xdZolHjypUrXL58GRcXF2bOnGkpjYGpTPb6668DcPPmTa5du2a1v0ajYfHixTRs2NCyrkePHpaS0IoVKyzrf/nlF06fPk2DBg1YuHAh1atXt2wLDAxk4cKFaLVa1q5dS1JS0h1fm6g8JKHfY926dbN6sKhNmzaMGDGCEydO4O3tzdKlSwstuej1ekuyvNXu3bsB+Ne//lXoOf/1r3+h0Wg4c+YMCQkJgKlEA6YXShc2Drxfv36lvqa9e/cC8Oyzz1o+bG41c+ZMdu7cyfDhw4s9zsWLF4mMjESr1RZI5rd6+umnAdi/f79l3cGDBwEKrUU7OTkVWaNWo06dOoSFhREWFlboz8vFxcXy5+zsbKvtrVq1snpIC+C5554D4NSpU5bkvGvXLgC6d++Os7Oz1T56vR69Xk9eXh6HDx+27YJEpSQ19Hvs9geLtFotbm5u1KpVixYtWtCzZ0/c3NwK3bdGjRpW69LT07l69SoA//vf//jkk08K3Ven05Gfn09MTAw1atTgwoUL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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.8974719101123596\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>42.857143</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>8.571429</td>\n",
       "      <td>7.142857</td>\n",
       "      <td>4.761905</td>\n",
       "      <td>3.571429</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>42.857143</td>\n",
       "      <td>21.428571</td>\n",
       "      <td>8.571429</td>\n",
       "      <td>7.142857</td>\n",
       "      <td>4.761905</td>\n",
       "      <td>3.571429</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     42.857143  21.428571  8.571429  7.142857  4.761905  3.571429\n",
       "1           NaN        NaN       NaN       NaN       NaN       NaN\n",
       "mean  42.857143  21.428571  8.571429  7.142857  4.761905  3.571429"
      ]
     },
     "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": "bf4d0a01",
   "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
