{
 "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 AKT1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 17000/17000 [00:06<00:00, 2601.02it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/partial_charge_superlevel_betti/target_akt1/'\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.9947368421052631"
      ]
     },
     "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=1,\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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28jISLvt7SWSkiQmJgIQFRVl93zdunXLdJ+4uDjgRu/dHmviS0hIQFEUdDqd7bPc3Cu9WaNGjcr0/mXh4eHB6dOnOXToEAkJCSQmJnLq1Clb7ABms7nYdY0bN7Z7v4CAAHx8fLh+/Trx8fHUqlWL06dPA/Djjz+yf/9+u9clJSUBllq2cE6SnO+ykiahlIW9XtTNozqOHj16y3tcv34dsCR1KHmTSx8fH3Q6XZn2ULt69SqA3V69GtaYCgsLbQ8MS2I2m22bb1qvK+mX2s0PG2/HiRMnmD59erHeanBwMN27d2fVqlUlXltSbNZz169ft/3isX6exMRE2y++kli/n8L5SHKu5G5Orv/973/LPDnE+qd5dna23fN5eXll3tzSw8ODzMzMEu9VVtYEFhUVxXfffVfm63x9fbly5UqJ29jbKzOolZKSQv/+/bl69SqNGjWiR48eNG7cmAYNGuDn50d+fn6pybm0r401buv3xPo9nTNnDk888cRtxy4qJ6k5V3K+vr62hHzmzBm7bUwmE7/88gsJCQm2jTPr168PWIaH2WP907oswsPDS71m+/bt9O3bt8gDSXusD+7Onz9Pfn6+3Tapqan89ttvRR66WT/L8ePH7V5T0tdFjTVr1nD16lUaNGjAypUr6devH/fff79tGru9h4A3s7cdElh6x5mZmej1eiIiIoAbX4fS4o6NjeXkyZN35BeP0CZJzk7AOub3P//5j93zGzZsYODAgTz77LO2HlzHjh0By4M1e4ll3bp1ZX5/6wST9evXl/j+v/32GxkZGbZj1geHN/fOIyMjCQ4OJicnp8R7zZw5k759+zJ27FjbMetnWbNmTbF6r9lsLvFealy4cAGAiIiIIg//rFavXm37b3s7R+/du9f2bOBmK1asAOD++++3jQBp164dAN988w15eXnFrklMTOTFF1+ka9euxMbGqv8wolKQ5OwEXnnlFdzd3dmwYQOzZ88u8gO9e/dupkyZAkDPnj1t9demTZvSvn17cnJyGDlypO0BE8CqVatUre3Rt29ffH192bdvH9OnT7e9v6IoLF26lO+//x5XV1f69u1ru8Zawrh48aLtmE6nY/jw4QBMnz6d77//3nausLCQRYsWsXbtWoAiDwx79epFQEAAR44c4a233rL1JvPy8pg0aVKJfx2oYf3rICYmhkOHDtmO5+Tk8Omnn7Jw4ULbMXsJNT8/n5EjRxb5Rbhq1Sq++OILdDodI0aMsB1/+umnCQ8PJyEhgVGjRtlG2IClBz58+HAKCwtp3LixJhaFFxVDas5OIDIykhkzZjBhwgQ++eQTli5dSv369UlPT7f1+B566CHbWFyrqVOnMmjQIA4dOkSnTp0wGo2kpaVx6dIl2rdvX+Z1gf39/Zk1axajRo1iyZIlrF27lrCwMC5dusSVK1cwGAxMmTLFluDAMhrkwIEDjBs3joiICMaOHcvDDz9Mjx49OHXqFF988QXjxo3j3XffJSAggPPnz9sePI4YMYJOnTrZ7uXt7c3s2bMZOnQoq1evZvPmzYSFhZGQkMC1a9dUfZaS9OzZk2XLlnHhwgV69epFeHg4Hh4eJCQkkJ2dTXBwMHq9nsTERC5fvlzs+rZt27Jv3z46duxIVFQU6enptp70hAkTeOCBB2xt3dzcmD9/Pi+//DI7d+6kXbt2REZGUlBQwNmzZzGZTNStW5cFCxbc1mcS2iY9ZyfRpUsXvvnmG3r06EGNGjU4ceIE6enp3Hvvvfz973/n008/LTbVt06dOixfvpwRI0YQHBxMXFwcer2ekSNH8sEHH6h6/7Zt27J+/Xp69OiBt7c3J06cwGQy0alTJ1asWFFs4frp06fTpk0bFEXh7NmzJCQk2M698cYbLF68mA4dOmA2m2215IcffpgFCxbYXbi+ZcuWrF27lu7du+Pl5cXJkycJDg7mgw8+uCMbdfr6+rJ69Wr69etHeHg4Fy5cICEhgbCwMEaOHMn69evp0qULgN1fBPfccw8rVqygTZs2nD17lmvXrvHQQw/x+eef251wFBkZyfr16xk2bBgRERGcPXuWc+fOERoayqBBg1i3bh1BQUG3/bmEdsk2VUIIoUHScxZCCA2S5CyEEBokyVkIITRIkrMQQmiQJGchhNAgSc5CCKFBkpyFEEKDJDkLIYQGSXIWQggNkuQshBAaJMlZCCE06P8Bd/KXZq9YS/8AAAAASUVORK5CYII=\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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3nu0atWq3PGSkhLef/99lixZQmxsLH379mXAgAF2iLByzz33HFFRUTZNiq/M3LlzaygiIeo2KUc4CBcXF5599lm6desGQGxsrJ0jss7f35927drh5+dn71CEuClIEnYw5vUgDh48aOdIhBA3gpQjHIz56ZprV4JatGgR77//PtOmTcPDw4MPP/yQ3NxcWrduzeLFi2nTpg0A6enpLF26lJ9//plz587RoEEDunbtyujRoyuccnP+/HmWLl3K1q1bOX/+PC1btuSJJ56gZ8+eVtu/8MILfP3114wZM4bp06eXOZeens5nn33Gjh07yMzMxN3dnVtvvZXIyEjuuuuuMp/F7KGHHgLgs88+s8zVBNi7dy/Lly8nISGBy5cv07hxY+68806eeeYZy+f9qyNHjvDhhx9y4MAB8vLy6NixI+PHj6/0663WhQsXWLFiBbt27SI9PZ3CwkK8vb255ZZbGDZsWKX7iZ08eZJ3333XMhe1Q4cOPPHEEzz88MNW2+fl5bF8+XI2btxIWloaTk5O6HQ6wsPDeeyxx8ot2SjqJknCDiYtLQ2AFi1alDu3adMmfv/9d1q2bEnLli0pKCggMDAQKN1qZfLkyRQUFODh4UH79u3Jzs5m+/btbN++nUmTJhEdHV2mv5SUFCIjIzl79izu7u60b9+erKwsZs+ezW233aYq7l9++YUpU6Zw5coVPD09CQkJ4fz58/z888/8/PPPzJ49myFDhtCiRQu6d+/OgQMHALjllltwd3fH29vb0tcHH3zAe++9B4Cvry86nY709HTWrl3L999/z3vvvVfukdLNmzfz3HPPodfr8fX1pV27dhw9epSoqCh69Oih6rNU5MiRI0RGRpKTk4Onp6eltp+enm75nFOnTmXcuHHlrk1JSWHYsGHk5+fTvn17CgoKOHDgAAcOHGDPnj3MmTOnTPvTp08zZswYUlNTcXZ2JigoCJPJREJCAgkJCWzatIkPPvjA6qLkoo5RRK1LT09XdDqdotPplPT09ArbXbp0SbnjjjsUnU6nvP7665bjCxcutFw/e/ZsxWQyKYqiKBcvXrT03717d0Wn0ykLFixQiouLLddu2bLFcm7z5s2W4yaTSXn88ccVnU6njBkzRsnJyVEURVGMRqOybNkyJTQ01PKe15o+fbqi0+mUN954w3Ls4sWLSq9evRSdTqe8/PLLSl5e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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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Ii1atDCN4TfG7927N187/NWrV4mIiMDb29s0zL1Vq1bY29tz6NChfB23aWlppglgLVq0AKBevXp4e3sTHh7OtWvX8sTr9Xr27NmDRqMxlaMwqhNATk4OH330ER06dGDChAl8/vnnrFq1CoBLly4xZMgQevXqRVxcnNpTCyGEgWLo2C3qpzQXu23dujX+/v6EhISwadMm0/bExERmzpwJwJAhQ0zbfXx8aNeuHVFRUSxYsMC0PT09nalTp6LT6fLEOzo60rNnT5KTk5k5c6ZpEmxubi6zZs0iJSWFfv365Zkk9vLLL6PT6XjvvffyJI0FCxZw4cIFunbtSq1aBb8oykjVRDC9Xs/o0aM5ePAgGo2GwMBAYmNjSU42LLOQlpaGVqslPDyc/v37s3XrVipXloktQgh1ijsMtDRotVrmzJnDa6+9xrRp09iyZQseHh78+eefJCcn07dvX9PsW6Pp06fTv39/li5dyp49e6hbty7Hjx8nPj6eJ598kv79++eJHzduHKGhoXz//fccO3aMhg0bEh4eTkxMDI0aNco3imnw4MHs27ePkJAQnnrqKYKCgoiOjubs2bN4e3vnWTeo0HtT84PYunUrBw4cwNfXlx9++IHvv/8+z/TpRx55hF9++QV/f3+uXbvG119/reb0QggBWFYfABjeSLh582a6devGxYsXCQkJwcvLi5kzZzJjxox88T4+PqaVORMTE9m3bx+VKlUytZpYW+f97u3m5saGDRsYNGgQubm57N27F61Wy7Bhw/jmm29MI4yMbG1t+frrrxk1ahQODg7s3buXtLQ0+vXrx4YNGwqchHY3VTWArVu3otFoWLhwodnecOONL1q0iGeffZY9e/YwceJENZcQQgj17wQugRrA3Qu93c3Pz4+FCxcW+Xyenp589NFHRY53c3Nj6tSpTJ06tUjxDg4OjB07lrFjxxb5GndTlQDOnTuHr69vgQ9/ozp16lCnTh1iYmKKXTAhRMVlattXES/UU5UAdDpdkdfst7GxyTchQwghisKQANTPBBbqqOoD8PHxITo6msTExELjEhISiIyMvOda1EIIYZba9n9ZQ6lYVCWAbt26kZuby/vvv5/vlWZG2dnZvPfee+h0OrPrZwshhLAMqpqAhgwZwg8//MBvv/1Gz5496dy5s2na8a5duzh//jzfffcdFy9exNPTk8GDB5dG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jAy++uorli1bZtpm7qGdnZ1NcHBwnmS7efNmVq1ahUajYfTo0abtzz33HHXq1OHixYu89dZbppFbYKhJjBo1itzcXBo0aFBhXlwiSof0ATwE/Pz8mDt3LpMmTWLp0qWsXr2aunXrkpSUZPrm+vjjj5vGqhvNnj2boUOHcuLECbp06UJAQACJiYlcu3aNjh07FnldeQ8PDz777DPeeustvvnmG7Zt20bt2rW5du0aN27cwMrKilmzZpkeomAYZXT8+HHGjx+Pr68v48aNo23btvTu3Ztz586xatUqxo8fz0cffUT16tW5fPmyqbN59OjRdOnSxXQuZ2dn5s2bxxtvvMGWLVv49ddfqV27NhcvXiQlJUXVvRSkT58+rF27litXrtC3b1/q1KmDvb09Fy9eJD09HW9vb7RaLTExMVy/fj3f8e3atePIkSN07twZf39/kpKSTDWCSZMm8eijj5pibW1tWbx4Ma+//jr79++nQ4cO+Pn5kZOTw4ULF9DpdNSoUYMlS5bc1z0JITWAh0T37t35/vvv6d27N25ubpw5c4akpCSaNGnCu+++y1dffZVv2QB3d3fWrVvH6NGj8fb2JjIyEq1WS3BwMJ988omq67dr147t27fTu3dvnJ2dOXPmDDqdji5durB+/fp8L1eZM2cObdq0QVEULly4wMWLF037pkyZwtdff02nTp3Q6/Wmtv22bduyZMkSsy9XadGiBdu2baNXr144Ojpy9uxZvL29+eSTT0rk5d6urq5s2bKFQYMGUadOHa5cucLFixepXbs2wcHBbN++ne7duwOYTTaNGjVi/fr1tGnThgsXLpCSksLjjz/OypUrzU768/PzY/v27YwcORJfX18uXLjApUuXqFWrFkOHDuW7777Dy8vrvu9LVGzySkghhKigpAYghBAVlCQAIYSooCQBCCFEBSUJQAghKihJAEIIUUFJAhBCiApKEoAQQlRQkgCEEKKCkgQghBAVlCQAIYSooCQBCCFEBfX/+QC7P8lv+hsAAAAASUVORK5CYII=\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.9952359825462942\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>86.046512</td>\n",
       "      <td>45.348837</td>\n",
       "      <td>19.069767</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>86.046512</td>\n",
       "      <td>45.348837</td>\n",
       "      <td>19.069767</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     86.046512  45.348837  19.069767    10.0  6.666667     5.0\n",
       "1           NaN        NaN        NaN     NaN       NaN     NaN\n",
       "mean  86.046512  45.348837  19.069767    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": "47ce7d8c",
   "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
}
