{
 "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, 8510.28it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_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": [],
   "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.9858757062146892"
      ]
     },
     "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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hIUQwoYkCAshhA1JEBZCCBuSICyEEDYkQfgKOHXqFJGRkRZfXbt2pXfv3tx4441MnjzZ4p4QtnDs2DFzHy81a9YsIiMjWbRo0WW/R05ODhcvXrzsdury4YcfEhkZyfjx462qn5iYSGRkJCNHjrzs9162bBmRkZFMmzbtstuqy9ChQ4mMjOSHH35o9PcSDcfxZjY7uJ49e1Z5NJGiKOh0Ok6dOsXWrVvZunUrY8aMYc6cOTbsZeNbtWoVy5YtY+3atbLtpmjWJAhfYUuXLiU4OLja8YqKCt544w1WrFhBQkICAwcOZOjQoTboYe2eeOIJYmJi8PPzu6x2FixY0EA9EsKxSTrCTri4uPD444/Tt29fABISEmzcI8vatGlD586d8ff3t3VXhGgSJAjbmSFDhgCmrSmFEE2fpCPsTOVj6i99WvKyZct44403mDFjBh4eHrz11lsUFBTQoUMHli9fTseOHQHIzMwkLi6OH3/8kXPnzuHl5UWfPn2YMGFCjburnT9/nri4OL7//nvOnz9P+/bteeCBB7jmmmss1p81axaffvopEydOZObMmVXKMjMz+eCDD9i+fTtnz57F3d2dXr16ER0dzQ033FDlWirdeeedAHzwwQfmbTkB9uzZw6pVq0hOTubixYu0atWK66+/nkceecR8vX93+PBh3nrrLfbt20dRURHdunVj8uTJtf681crJyWH16tXs3LmTzMxMSktL8fHxoXv37tx3330MHz68xnNPnjzJ4sWLzduOdu3alQceeIC77rrLYv2ioiJWrVrFd999R0ZGBk5OTkRERDBy5Ejuueceh9wxTFQnQdjOZGRkABAUFFStbNOmTfz222+0b9+e9u3bU1JSQkhICAA7d+5k2rRplJSU4OHhQZcuXbhw4QLbtm1j27ZtTJ06ldjY2CrtpaamEh0dzZkzZ3B3d6dLly5kZ2czb948+vXrp6rfP/30E4899hiFhYV4enoSHh7O+fPn+fHHH/nxxx+ZN28eo0aNIigoiKioKPbt2wdA9+7dcXd3x8fHx9zWm2++ydKlSwHw8/MjIiKCzMxMNmzYwNdff83SpUurPT1k8+bNPPHEE+h0Ovz8/OjcuTNHjhwhJiaGq666StW11OTw4cNER0eTl5eHp6enObefmZlpvs7p06czadKkauempqZy3333UVxcTJcuXSgpKWHfvn3s27eP3bt3M3/+/Cr1T506xcSJE0lPT8fZ2ZnQ0FCMRiPJyckkJyezadMm3nzzzSo3eYWDUkSjy8zMVCIiIpSIiAglMzOzxnr5+fnKtddeq0RERCgvvvii+fjrr79uPn/evHmK0WhUFEVRcnNzze1HRUUpERERymuvvaaUl5ebz92yZYu5bPPmzebjRqNRuf/++5WIiAhl4sSJSl5enqIoimIwGJSVK1cqkZGR5ve81MyZM5WIiAhl4cKF5mO5ublK//79lYiICOWZZ55RioqKzO/x3nvvKREREUqPHj2qXHtl20ePHq3S/nfffadEREQoUVFRyldffWU+rtPplOXLl5vLsrKyzGU5OTnma3z55ZeViooKRVEUpaioSHn88cfN7zVu3Lgaf/aX2rBhgxIREaHcfffdVY7ffffdSkREhPKf//xHKSwsNB8vLCxUpk+frkRERChXXXWVotPpzGWXfnY333yzkpKSYi779ttvlZ49eyoRERHKl19+aT6u1+uVESNGKBEREcq///1v5fz58+ay48ePK7feeqsSERGhvPTSS1X6N2TIECUiIkLZunWrVdcp7IPkhG1MURQuXrzIjh07ePjhh7lw4QI+Pj489NBD1eq6uLjw2GOPodFoAMw3x959912KiooYMWIEjz32WJXR0U033cT06dMBqqQB9u7dS3JyMr6+vixZsoSWLVsCoNVqmThxIv/3f/9n9TV8/PHH5OXl0adPH+bOnYuXlxdgejDphAkTGDx4MBUVFXz99dd1tvX6668D8NRTT3HbbbdVufZHH32UW2+91fxneqW1a9dSVFTENddcw3//+1/znrJeXl4sXLiwxvSFGqdPnyYrKwt3d3deeOEFc9oITCmk//73vwAUFhaSnZ1d7XyNRsOyZcvo3Lmz+djw4cPN6ZKVK1eaj2/evJlDhw7RqVMnXnvtNVq3bm0uCw8P57XXXkOr1bJ27Vpyc3Mv+9qEbUkQvsJuuummaos1rr76amJiYti/fz9+fn68+eabFtMRERER5gB3qa1btwJw++23W3zP22+/HY1Gw+HDhzl//jxgSl+A6aGglubpjho1yupr2rZtGwB33323+QviUi+88AJbtmzh4YcfrrWdjIwMjh8/jlarrRKAL3XHHXcAsGPHDvOxH3/8EcBibtXV1bXGnKsa7dq1IykpiaSkJIs/L3d3d/P/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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.9744507125890737\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>70.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>6.333333</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>70.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>6.333333</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      70.0   40.0   16.0     9.0  6.333333     5.0\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   70.0   40.0   16.0     9.0  6.333333     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
}
