{
 "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 HIVRT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 19774/19774 [00:03<00:00, 6462.08it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_bond_strength_superlevel_betti/target_hivrt/\"\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.9660869565217391"
      ]
     },
     "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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hx56iHvuucfq9fn5+axatYrvvvuOtLQ0XFxc0Ol0jBw5kvvvv98pVwwTFUkQdjBpaWkABAYGVji3ZcsWfvvtN1q1akWrVq0oLCykTZs2AOzevZtp06ZRWFiIl5cXHTt2JDs7mx07drBjxw6mTp1KTExMufKSk5OJiorizJkzeHp60rFjRzIzM5k3bx69e/dWVe+ffvqJ6dOnc+nSJby9vQkJCeH8+fP8+OOP/Pjjj8ybN49Ro0YRGBhIWFgYBw4cAOCmm27C09MTX19fS1nvvPMOb775JgD+/v7odDrS09PZuHEj33zzDW+++WaF3UO2bt3KE088gV6vx9/fnw4dOnDs2DGio6Pp1auXqnex5ejRo0RFRZGTk4O3t7clt5+enm55z5kzZzJx4sQK9yYnJ/PAAw9QUFBAx44dKSws5MCBAxw4cIC9e/cyf/78ctefOnWK8ePHk5qaiqurK0FBQZhMJhISEkhISGDLli2888475Tp5hZNSRJ1LT09XdDqdotPplPT0dJvXXbx4UenXr5+i0+mUl156yXL8rbfestw/b948xWQyKYqiKFlZWZbyw8LCFJ1OpyxevFgpKSmx3Ltt2zbLua1bt1qOm0wm5cEHH1R0Op0yfvx4JScnR1EURTEajcrKlSuV0NBQyzOvNmvWLEWn0ykvv/yy5VhWVpbSt29fRafTKc8995ySn59vecYHH3yg6HQ6pUuXLuXevazsxMTEcuV/9913ik6nU8LCwpSvv/7aclyv1ytLly61nMvIyLCcu3DhguUdX331VaW0tFRRFEXJz89XZsyYYXnWww8/bPNrf7WNGzcqOp1Oue+++8odv++++xSdTqc8/vjjyqVLlyzHL126pMycOVPR6XRKr169FL1ebzl39ffu73//u5KUlGQ59+233ypdu3ZVdDqd8tVXX1mOGwwG5d5771V0Op3yf//3f8r58+ct506cOKEMHz5c0el0yn//+99y9QsPD1d0Op2yffv2ar2ncAySE7YzRVHIy8tj165dPProo2RnZ+Pr68uECRMqXOvm5sb06dPRaDQAls6x999/n/z8fO69916mT59ernU0ZMgQZs6cCVAuDbB//34SEhLw8/Nj0aJFNGrUCACtVsv48eP55z//We13+PTTT8nJyaFHjx7MnTuXBg0aAOaNSceNG8egQYMoLS3lm2++qbKst956C4BnnnmGO++8s9y7P/bYYwwfPtzyz/Qya9euJT8/nz59+vDvf//bsqZsgwYNePnll22mL9Q4ffo0GRkZeHp68uKLL1rSRmBOIf373/8G4NKlS2RmZla4X6PRsGTJEjp06GA5NmzYMEu6ZOXKlZbjW7du5ciRI7Rv357FixfTpEkTy7mQkBAWL16MVqtl7dq1ZGVlXfO7CfuSIHydDRkypMJkjZtvvpno6GgOHjyIv78/77zzjtV0hE6nswS4q23fvh2Au+66y+oz77rrLjQaDUePHuX8+fOAOX0B5k1BrY3THTVqVLXfaceOHQDcd999ll8QV3vxxRfZtm0bjz76aKXlpKWlceLECbRabbkAfLW7774bgF27dlmO/fjjjwBWc6vu7u42c65qtGzZkvj4eOLj461+vTw9PS3/XVxcXOF8r169Kkx8Abj//vsB+OOPPywB9fvvvwdg6NCheHh4VLhHp9Oh0+koLS1l7969NXsh4TAkJ3yd/XWyhlarxdvbm+bNm9OzZ0+GDx+Ot7e31XubNm1a4Vh+fj5nzpwBYNGiRSxbtszqvS4uLhgMBpKTk2natCkpKSmAuWVljbWAYUt6ejoAHTt2tHq+RYsW1SonKSkJuNIat6YswKWmpqIoChqNxvIuV7cyr9apU6dqPb86PD09OXnyJAcPHiQ1NZX09HROnDhhqTuAyVRx+/XOnTtbLa958+b4+vpy6dIlkpOTady4MSdPngTg22+/5ddff7V639mzZwFzrlk4NwnC15mtyRrVYa1VdPUoiiNHjlRZxqVLlwBz8Abw8vKyep2vry8ajQalGhuvXLx4EcBqK12NsjoZDAZLx50tJpOJgoICfHx8LPfZ+uV1dafftUhMTGT+/PkVWp+tWrVi5MiRrF+/3ua9tupWdu7SpUuWXzBl75Oenm75BWdL2fdTOC8Jwk7u6iD6888/V3sSRdk/qQsLC62eLykpqVYABnPrMD8/32ZZ1VUWqDp27MhXX31V7fv8/PzIysoq9wvpatbSA2qdP3+eRx55hIsXL9KpUydGjRpF586d6dChA/7+/uj1+kqDcGVfm7J6l31Pyr6nb775Jnfcccc11104NskJOzk/Pz9L4P3zzz+tXmM0GtmzZw+pqamWDRTbt28PmIddWVP2T+LqCAoKqvSeH374gcjIyHIdg9aUdaCdOnUKvV5v9ZoLFy6wf//+cp1fZe9y7Ngxq/fY+rqosXHjRi5evEiHDh1Yt24dY8eOpXfv3pbp29Y6465WljL5q/T0dPLz89FqtQQHBwNXvg6V1TshIYHjx4/Xyi8YYV8ShG8AZWNmP/nkE6vnv/zyS6Kiorj33nstLbIhQ4YA5g4uawHks88+q/bzyyZibN682ebz9+/fT25uruVYWQfe1a3tkJAQWrVqRVFRkc2yXn/9dSIjI5kxY4blWNm7bNy4sUI+1mQy2SxLjYyMDACCg4PLdcKV2bBhg+W/re0UHB8fb8ndX23t2rUA9O7d2zLiYtCgQQB8/vnnlJSUVLgnPT2dhx9+mBEjRpCQkKD+ZYRDkSB8A3j00Ufx8PDgyy+/ZNGiReV+cHfv3s3cuXMBGD16tCU/2rVrV8LDwykqKiImJsbS0QOwfv16VWtXREZG4ufnx759+5g/f77l+Yqi8NFHH/H111/j5uZGZGSk5Z6y1MPp06ctxzQaDY899hgA8+fP5+uvv7acMxgMxMbGsmnTJoByHXcPPPAAzZs3548//uD555+3tA5LSkp44YUXbLb21Shr7f/0008cPHjQcryoqIj33nuPFStWWI5ZC5x6vZ6YmJhyv/DWr1/PqlWr0Gg0TJkyxXL87rvvJigoiNTUVKZOnWoZ0QLmFvVjjz2GwWCgc+fONmdCCuchOeEbQEhICAsXLuSpp55i+fLlfPTRR7Rv356cnBxLC+6WW26xjGUt89JLLzF+/HgOHjzI0KFD0el0ZGdnc+bMGcLDw6u9Lm2zZs144403mDp1Kh9++CGbNm2iXbt2nDlzhqysLFxcXJg7d64lkIF59MWBAwd44oknCA4OZsaMGdx2222MGjWKEydOsGrVKp544gkWLFhA8+bNOXXqlKUDcMqUKQwdOtRSlo+PD4sWLWLSpEls2LCBLVu20K5dO1JTU8nLy1P1LraMHj2aNWvWkJGRwQMPPEBQUBCenp6kpqZSWFhIq1at0Gq1pKenc+7cuQr3DxgwgH379jFkyBA6duxITk6OpWX81FNP0a9fP8u17u7uLF26lAkTJrBz504GDRpESEgIpaWlpKSkYDQaadGiBe+88841vZNwDNISvkEMHz6czz//nFGjRtGoUSMSExPJycmhW7duPPPMM7z33nsVprg2bdqUuLg4pkyZQqtWrUhKSkKr1RITE8Nrr72m6vkDBgxg8+bNjBo1Ch8fHxITEzEajQwdOpS1a9dWWCB9/vz59O3bF0VRSElJITU11XJu9uzZrFy5ksGDB2MymSy53ttuu4133nnH6gLpvXr1YtOmTYwcORJvb2+OHz9Oq1ateO2114iIiFD1Ltb4+fmxYcMGxo4dS1BQEBkZGaSmptKuXTtiYmLYvHkzw4cPB7Aa8Lt06cLatWvp27cvKSkp5OXlccstt/DBBx9YnZgTEhLC5s2bmTx5MsHBwaSkpJCWlkbbtm0ZP348n332GS1btrzm9xL2p1Gq2wUuhBCi1klLWAgh7EiCsBBC2JEEYSGEsCMJwkIIYUcShIUQwo4kCAshhB1JEBZCCDuSICyEEHYkQVgIIexIgrAQQtiRBGEhhLCj/wfzBA1dcB+kpAAAAABJRU5ErkJggg==\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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x6qbzJ07lxEjRnDq1Cm6d+9OaGgoqampxMfH06VLlxKvK+/n58cHH3zAq6++ypdffsnWrVupU6cO8fHxpKSk4ODgwJw5c8w3UTCOMjp58iSvv/46wcHBTJw4kQ4dOtCvXz8uXLjA6tWref3113n77bepXr06V65cMXc2jx07lu7du5vz8vDw4MMPP+Tll19m8+bN7Nq1izp16hATE0NGRoaqaynKs88+y7p164iLi6N///7UrVsXFxcXYmJiyM7OJiAgAK1WS2xsLNeuXStwfMeOHTl27BjdunWjfv36pKWlmWsEU6ZMoX379ua0Tk5OLFu2jBdffJGff/6Zzp07ExISQn5+PtHR0ej1emrUqMHHH398V9ckhNQAyolevXqxbds2+vXrh7e3N+fOnSMtLY0HHniAN954g88//7zAsgHVqlVj/fr1jB07loCAACIjI9FqtYwbN4733ntP1fk7duzI9u3b6devHx4eHpw7dw69Xk/37t3ZsGFDgZerLFiwgHbt2qEoCtHR0cTExJj3TZ8+nZUrV9K1a1cMBoO5bb9Dhw58/PHHhb5cpVWrVmzdupW+ffvi5ubG+fPnCQgI4L333mPQoEGqrqUwXl5ebN68maFDh1K3bl3i4uKIiYmhTp06jBs3ju3bt9OrVy+AQoNNkyZN2LBhA+3atSM6OpqMjAwefvhhVq1aVeikv5CQELZv387o0aMJDg4mOjqay5cvU7t2bUaMGME333xDzZo17/q6RMWmUUo61EMIIUS5IjUAIYSooCQACCFEBSUBQAghKigJAEIIUUFJABBCiApKAoAQQlRQEgCEEKKCkgAghBAVlAQAIYSooCQACCFEBSUBQAghKqj/B1ObA9omF1r1AAAAAElFTkSuQmCC\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": "iVBORw0KGgoAAAANSUhEUgAAAWEAAAE+CAYAAABcJ6H1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABMQ0lEQVR4nO3deVyU1f7A8c8MOwIKuKCIIuKgueRWpmWp2bU9M+2aS1cs7Kpot7xptlzLfm5tpmZZYJklZi5lZeWSpZZJmpSaimJsoqIgIvswM8/vj5FRYoB5EJwZ+L57zesVzznPmTMz8p3D9znnPBpFURSEEELYhdbeHRBCiIZMgrAQQtiRBGEhhLAjCcJCCGFHEoSFEMKOXO3dASGEuJLBYMBoNKo+z8XFBVdX5wtpztdjIUS9ZTAYOHTgZ4yKj+pzXVxc6NKli9MFYufqrRCiXjMajRgVH9o3/R/uLudtPk9vDOBE1myMRqMEYSGEuFou2ixcXM7ZXl8x1WFv6pYEYSGEwzGhYML2xbxq6joaCcJCCIdjuvSfmvrOSoKwEMLhmBQFo4ptbUxOvAWOBGEhhMMxoS7F4LzjYAnCQggHZERBqyIIGyUnLIQQtUdReWFOkSAshBC1x6goaFTkedXkjx2NBGEhhMMxoS7PKzlhIYSoRSYUVXleZ54nLLuoCSGEHclIWAjhcIyAmsGt+j3XHIcEYSGEwzEBGpX1nZUEYSGEwzGhQU0YNqkK2Y5FgrAQwuGYFFSlI0zOe11OgrAQwvEY0aDISFgIIezDpDIIq6nraCQICyEcjknRoFFUBGEVdR2NBGEhhMMxAhpVI2HnJUFYCOFwTGhRt5ZM67QrzyQICyEcjknRgJoUg6KRIOyITCYTBQUFuLm5odE4b85ICGejKAqlpaU0atQIrVZ9eDSqnCcMGqcNZs7ab5sUFBRw7Ngxe3dDiAZLp9Ph6+ur+jyTokVRbA/eGhV1HU29DsJubm4AtPCfgatLtp17UzcysmIJbvq4vbtRZ568/WZ7d6HOTF8Tyav//NDe3agTfs18+PfbIyy/g2qZp6ipCMIyRc0xlaUgXF2ycXM9a+fe1J36/NounMmzdxfqVH1/fTVNA6pdrCFBWAghapFJ0WJSkWLQSjpCCCFqjwmNyqXIzjsSdt6vDyGEqAdkJCyEcDhGtJcWbNhGzUW8K+3evZtly5aRmJhIaWkpnTt3JioqiltvvdXmNn7//XfeffddEhISKCwsJCgoiEGDBjF58mQaN25c7fkyEhZCOByTosGoaG1+mGqwd8SGDRuIjIwkISGBbt260aNHDxISEoiKimLNmjU2tbFt2zZGjx7Njz/+SGhoKLfeeislJSV89NFHjBgxgvPnz1fbhoyEhRAOx6RyJKx2vVxmZiazZs3C19eXuLg4dDodAAcOHCAyMpI5c+YwYMAAWrRoUWkbBoOBWbNmYTKZWLJkCf/4xz8AKCkp4cknn+SHH35g6dKlvPjii1X2RUbCQgiHY1Q0qh9qrFq1Cr1ez7hx4ywBGKBbt25ERUVRUlJS7Wg4MTGRrKwsOnbsaAnAAB4eHkyaNAmAvXv3VtsXCcJCCIdjQotRxUPNqBlg165dAAwePLhCWdmxnTt3VtlG2XLs7OxsDAZDubKcnBwAyQkLIZyTCa1lrrBNDzUX8RSFpKQktFotYWFhFcpDQ0PRarUkJSWhKJVvkhkeHk7Lli3JzMxk+vTppKWlUVRUxC+//MLLL7+MVqslMjKy2v5ITlgI4XCMaDDWYNnymTNncHFxKVfm5+eHn5+f5efc3Fz0ej0BAQG4u7tXaMvV1RV/f3+ys7MpKCjAx8fH6nO6ubmxePFioqOj2bRpE5s2bbKUNW/enNjYWG6+ufpl9xKEhRAOx6Qyz6u9VHfUqFFkZWWVK4uOjmbKlCmWn4uKigDw8vKqtD1PT0+AKoMwQJs2bbjvvvv48MMP6dy5M4GBgRw6dIizZ88SGxtL586dadKkSZV9lyAshHA4amdHlNWNi4uzOhK+kpqtNatKR+Tk5DBq1CgyMzP58MMP6dOnDwB6vZ7Zs2ezdu1aoqOj+eSTT6p8DgnCQgiHUzb/11Zle0cEBQXh4eFRZV1vb2/APJWsMsXFxeXqWrN8+XL++usvnnnmGUsABnB3d2fWrFns27ePvXv3sm/fPnr37l1536vsrRBC2IFyae8IWx9qdlzz8fHB29ubnJycCrMawDz/NycnBw8Pjwqj6Cv9+uuvAFbzvm5ubvTr1w+Aw4cPV9kfCcJCCIdjVLliTk3+WKPREB4ejtFoJCUlpUJ5cnIyJpOp3Pxhay5evAhQIf1Rpux4aWlple1IEBZCOBw1c4TLHmr0798fMC87/ruyY7fddluVbZRNb9uxY0fF/huN7NmzB4COHTtW2Y4EYSGEw1EUDSYVD0Xlirlhw4bh4eFBTEwMhw4dshw/ePAgsbGxeHp6MmrUKMvxtLQ0Tpw4QV7e5U34//nPfwKwbNkyfvvtN8txg8HAq6++yrFjx+jQoQM33XRTlX2RC3NCCIejdnSrdiTcunVrZsyYwezZsxk5cqTlwlp8fDwGg4EFCxYQGBhoqT9u3DgyMjKYN28ew4YNA8wj5QkTJvD+++8zevRounfvTkBAAEeOHOHUqVM0bdqUt956q9J0RRkJwkIIh2Me4aqYolaDXdRGjx5Nq1atiI2NZf/+/bi7u9OzZ08mTpxI3759bWpj2rRp9OzZk48//piDBw9y6NAhmjdvzpgxY3jiiSdo3rx5tW1IEBZCNFgDBw5k4MCB1dbbvn37VbdRGQnCQgiHY0KDUcW0M3W3QnIsEoSFEA5H7Y0+1dR1NBKEhRAOx6hyJKymrqORICyEcDiKypGwIiNhIYSoPUY0qvaOkJGwEELUorI9IdTUd1YShIUQDsekqFusIRfmhBCiFpkUlSPhGizWcBQShIUQDqeuly07EgnCQgiHIyNhIYSwI/Om7iqmqMmFOSGEqD1GReViDRkJCyFE7ZF0hBBC2JGiqLvbsqyYE0KIWiR7RwghhB2Z0KhKMTjzijnnHcMLIUQ9ICNhIYTDMV+YU7FsGQ3OOhiWICyEcDiKyg18ZJ6wEELUItXzhGUkLIQQtcekcoqamrqORoKwEMLhKCoXa0g6Qtgk/4IL698KYe93geScdcMvoJTrB1zgof+cpFnrEtXtZZ925/P533Eivhc5Z93w9jGi65XH/ZMyiLghz+o5xYVavn6vFb981ZSzaR74Bhjo0DOP+ydm0P76gqt9ifWej5+B0VPS6fuP8wQ0KyX3vCu/7WpC3JIQzp7yuKq2NRqFN9ceomWbYkbeeEO19dt1LGDx5wfZ+FEQsfNDr+q5HU1D2tTdecfwTib/ggv/e7Ar3y5vRUGuC207FqIv1vLjmhY8e+f1pB7xVtVeeqIXz955PfEbfic3y5Xg8CIAftsWwMsjuvDDp80rnJOb5cb/HujKujfbkHHcm+ZtSvDyMRK/qSkv3N+NLR8F1cprra98/Ay88dkhhkaewbexkeREbzw8TQwZcY63v/qD0Iir+xJ79Ol0OnbPt7kv0988jqubclXP6ahMyqUZEjY/7N3jmpOR8DXy/oxwTiV502NQDlOXJuLlY0JfrGH5c+3ZsbY5iyfreG3r72hdbGvvnac6kHfejbDebXg2dh1+gQZMRlj7RgifLwlh+fNhdO6XS/M2l0fY7z4dTtrRRjRprmda7FE69DD/wifu8+X1xzrywQthtAgt4vrbcuviLXB6T849QZvwIn79oQnz/6OjqMAFN3cT0bP/4h/DzzFz0XEm3n09JpPaUZnC6KknGTkxw6baTQL1zHovkVBdkfoX4SQaUk7YYXu+e/duHn30Ufr06UPPnj0ZO3YsO3futHe3aiQjyYu93wbg2cjI5LeO4+VjAsDdU+GJ15II7lBIxnFvfv0u0Kb2Th7zIvmgDxqNwsjZ9+EXaABA6wL/nJ5O++vzMOi1/LyxqeWc5ION+P0HfwD+826iJQADRPTOY8wLKQB8PLtdbbzkeqd1WBH9/nGewnwtr/03nKIC87dlqV7Loufak5bkRZtwcx01/JvqefHdRMZMPWlT/e79LrBk40GbR8zOSlE1CtagOPEGPg4ZhDds2EBkZCQJCQl069aNHj16kJCQQFRUFGvWrLF391T7aUNTFEVDz8Hn8fE3lCvTusCAh88C8MtXtgXh82fcAfDxN+DXzLdCebuu5j+Ls6/IUf6xowkA7bvn0fHGivni/g+dw8vHwMlj3iQfamRTPxqSQQ+cQ6uF+O3+5Oe6lSszmTRsWdcMgFvvybK5TV+PA8Ru+51+d+Rw/qwbH7zWpsr6U145wbyVR2gapCd+uz8/fReg/oU4ibKcsJqHs3K4IJyZmcmsWbPw9fVl/fr1xMTEsHz5cuLi4vDx8WHOnDlkZmbau5uqJP1uDpS63tYvloX3MB8/+qufTe0FttQDkHfejdyzFdtMTzTnlwNbXU5FZGWYA3K7LtbzllottGhbDMCJ331s6kdDEnG9eeR5JKHilx7A0UufcedKPmNrPF1P4ultZNvnTfn33ddztJr3PeL6fHLPu7L4+TBemtDRMhqvj8r2jrD5IUG49qxatQq9Xs+4cePQ6XSW4926dSMqKoqSkhKnGw2fSfEEoHmI9RkQZTMjcs+5U1xQ/UcS3KEIXe+LAKx96Wsunjen9hUFNr4TTOJePzwbGbl1+LkK55qMlf9jNZSan/vcyau7yl8ftbr0BXUm3dNq+dlLX3IBzUrx9Dba1GZhaThTHujGG890IO+CW7X118e24rHbe/DtmhY29tp5qbsop26zH0fjcEF4165dAAwePLhCWdkxZ8sNX8w2/4L5+pdaLfdpcjlFcfF89b+MANNiEuna/wJJe1OJ7tOLGUOu59+9erN6XluCOxTy3Ko/LSNmgOZtzEEk7aj1WRj6Yg1n08yBpCBXrtf+XeMA82eXd8H6e5N3xXvmV8nn/HcFeh1/HbE99fPDl80oyGsYn43khO1EURSSkpLQarWEhYVVKA8NDUWr1ZKUlISiOM+cFH2x+W129zRZLb/yeGmxbR+Jm7uJ8B55uHm4oi92IfVwI3LPmXPF/i30uLmXf396DMoBICnBl4O7Gldob/OKluiLzX/eGkqd9x90XSn7jEoq+Xz0Vxz3qORzFrZrSFPUHCoI5+bmotfradKkCe7u7hXKXV1d8ff3p6ioiIIC51lYoHWp+l9IuSlNNsS/glwXZj/cmc8XhxDaI4T53/3OJyd+YfHPv3Hn+FMc+qkJLw3vwrHfLucYQyKKuHmoOT2xaJKOnz5vSnGBlvwLLnz7QRBrXmuDTxPzCK6+zj29GlWlcQA02svvmTOPyhxFQ7ow51B/2xQVmec9enl5VVrH09OckysoKMDHxzkuIHl6myjI1aIvsf6dZ9Bf/gdU2Wj5Sl++G0zKnz606VjAuIXDCW29CoDmbUoY93IKbu4KXy0L5oMXwpj/7QHLeVHzT5Cb5cahn5rw9lRduTZvHX4WnyYGvolthZePbTnNhqS4SIubuxF3D+ufz5V/eeht/GtGVE5tnleCcC3RatXcU8r20VpGVmxNulNrPH2XUZB7gb/+egW3lu0rlOeczgXeNf+/IY6CM1XnhX/+6n3gPDc98k9cXF1IOfNlufIeI4rZFLOIlEM+7Nv7EU1D/C1lo95QOLD1CId3HKfwQiFNWjbm+n9cR4c+oayZ9RXwJyavsaScufFqX3atmLvD3j0wc2/0HyCTKe/dw8WS7hXK3VzOAb8C8NSnU1EU2y5uzt0x1fL/Pu6HgcM0auxZ7nhl2jR5FzjHLf/sSdhdY2x6PmehqAzCsndELfH2Nl80KimpfB+F4uLicnVtEdz0cdxcz15d565Cm4iOZJ8MQFMwn9CgitPrilL8gC74N9ejC32o2vZyM28CtFzfcy4QR2jQ/eUrBIFfYG8unHXHo2QqoUHlV8CF/QuG/qtiu1knrgcacX3vJRXOsZdRERUv0NrDS++X0GcQfLv4MzbFVbww3OWGi7y2GrIz3Zh563s2tTl3x1Seu22x5eeufXJ5dRUU5BaXO16ZpxckccdD8NOa/cTOV7dIpK41CfJl+ppIe3fDKTjU300+Pj54e3uTk5ODwWCoUG4wGMjJycHDwwM/P9vm1DqCsG7m/HVSJXNMjyeY0ypl84WrU5YuyDlrfcSsL9aQm2Uu875U98JZNzavCGLbKuvTm86d9CA9sRGu7iZ0vWyf69pQHD9k/owqW6nWsbv5PUv8wzlSZI5OpqjZiUajITw8HKPRSEpKSoXy5ORkTCZTufnDzuDGu7IB2Ls5gPyc8n98mIywY615s51bhlWc12vNdX3No9Qf11TcpAfgp8+boZg0ePsZaHud+QtA66Kw4n/t+GhWOwpyK07y//KdYAD6DzuHZyO5uv93P282r07re8d5fBqXn4Km1Src8ZD5s9u+sdk171t9JEHYjvr37w/Atm3bKpSVHbvtttuuaZ+uVttOhfS4/TxFea4s/HcEeZcCsb5Yw3vPhJNx3JtW7Qu54c7yf1JePO9KRpIXZ1LK5xfvn5iBi6uJfVsC+WbxDxQXXv4Y92wK5ONXQgF4YFIGrpcuGPkFGriuXy6lJVren9Heco7RAF+/14qtHwfh4W3kwSm27WHQ0KQkNiJ+exMa+Rp5/u1j+F6aSeLmbrJs7JN+wpPdW8ovJfbzL6V1WBEtL83TFrZRMM/9tflRH3PCO3bUzhURtQFz2LBhxMbGEhMTwy233EKXLl0AOHjwILGxsXh6ejJq1Kha6du19Pi8v5g1zJs/dzcmuk8vgsOLyEzzoCDXDW8/A9NiEvn7dcnNK1qyfmEITVsX8/Yv+y3Hw7oVELXgBDEz2rPz43h+3XADLcOKyD7lYVkYcuvws9w/qfyuXE+8doKZd3UjflNTDu5qQlDbYrIunePmYeS/y4+W23VNlPf2/8II1f1J974XWblzP2knvGgZUoxvEyP5F114ZVJEhelp9409w5ipJ8k86cG4AT3t1HPn05D2E640CD/xxBNoNFf3wjQaDYcPH1Z1TuvWrZkxYwazZ89m5MiR9OnTB4D4+HgMBgMLFiwgMNC2jW4cSWBLPfO+OcD6t1qzb0sAqUe9aeRnpN8D5xgxLZ2W7dSNlAY8fI52XQr49K3RpCbsJ+2oN57eRrr2v8DtozO56Z7sCuc0Dylh3jcHWLcwhAM7m5B6xBvfAAO3DDvLg9EZBHeov1sj1oasMx5MGdqVUdEn6Ts4h3YRhRTkufDDl4F8siiEU6mVT60U6iiXFmuoqe+sNEolc70GDRpUK0+wffv2Gp33ww8/EBsby+HDh3F3dyciIoKJEyfSt29fm9soKSnh0KFDdp8dUZdSznxZcXZEPeIosyPqwt9nR9QnZbMjunTpgoeH7XuRlP3OvnTha86bCm0+L0DrzUtN7lX9fI6g0pFwTYNnbRk4cCADBw60ax+EEPaherGGE1+Yc6h5wkIIAVguuKmp76xqHITPnz/Pnj17SE5OJj8/nxkzZlBSUkJCQgI33XRTbfZRCNHAyEi4CqWlpbz++uusXr2a0tLL8yVnzJhBWloakZGRdOrUiXfffZcWLer/vqdCiDqgqLzY5sQX5lTNEzaZTEyePJmVK1diMBiIiIigcePL2yIWFBSg1Wo5fPgwjzzyCDk5ObXeYSFE/deQdlFTFYTXr1/Pzp07CQsL48svv+SLL74ot+9v9+7d+e677+jQoQOnT59m+fLltd5hIUT9p2qhRkPa1H39+vVoNBoWL15MeHi41TohISEsWbIErVZr9xkWQgjn1JDuMacqJ3z8+HHCwsJo377idoxXCg0NJTQ0lPT09KvqnBCiYVJU5oRrulhj9+7dLFu2jMTEREpLS+ncuTNRUVHceuutNrdRUFDA8uXL+fbbbzl58iReXl707NmTyZMn07Vr12rPVzUSNhqNNu/56+bmhotL/b0brBCi7piDsJp0hPrn2LBhA5GRkSQkJNCtWzd69OhBQkICUVFRNt9M+MKFCzzyyCMsXbqUgoICbrvtNoKCgvjhhx8YNWoUBw4cqLYNVUE4JCSE5ORkzp+veu/SrKwskpKSCAkJUdO8EEKYqc0Hq8wJZ2ZmMmvWLHx9fVm/fj0xMTEsX76cuLg4fHx8mDNnDpmZFff+/rt58+aRmJjIPffcw7Zt23j77bf58ssvmT59Onq9nhdeeKHaNlQF4SFDhmAwGPjf//5XbnralfR6Pc8//zxGo9HqHZOFEMLeVq1ahV6vZ9y4ceW2xu3WrRtRUVGUlJRUOxo+deoUGzduJCQkhPnz55e7L+Zjjz1G586dKSoqqnbQqioIR0ZG0qZNG77//nuGDh3Km2++yblz5n1Ut27dyrJly7jvvvvYsWMHQUFBjBs3Tk3zQggB1P1+wrt27QKwOlAsO7ZzZ8U7qFxpy5YtKIrC6NGjrd6YeMOGDWzdupWAgAArZ1+m6sJco0aN+PDDD4mOjubIkSP89ddflrKpU833xFIUhbZt2/LOO+841d0vhBCOoy4vzCmKQlJSElqtttwU2zKhoaFotVqSkpJQFKXS3STLdojs2rUrBQUFfPPNNxw6dAhXV1f69u3L7bffbtNOlKpXzAUHB7N+/Xq2bt3K999/T1JSEgUFBXh5edG2bVsGDBjAPffcY/WbQQghbFGXe0fk5uai1+sJCAiwGqdcXV3x9/cnOzu7yru6p6WlAeaLc/fddx8ZGZf37/7kk0/o27cvb7/9drV3ha/R3hFarZYhQ4YwZMiQmpwuhBBVqmkQPnPmTIVZWX5+fuX+Ki8qMu+b7eVV+f7Pnp6eAFUG4bw8830FZ86cSUhICG+88QYdOnQgMTGRl19+mV9++YVZs2bxxhtvVNn3q9pF7fz586SkpFBcXIyvry9hYWE0atToapoUQggU1G0HUVZ31KhRZGVllSuLjo5mypQplp9tnWYL5tRFZfR6PWCejrtixQpLoO/VqxfLly9nyJAhbNq0iejoaNq1a1dpOzUKwt988w3Lly+vcNcMrVbLDTfcwOTJk7nhhhtq0rQQQljuMaemPkBcXJzVkfCVvL29AfMG8pUpLi4uV9eastHyvffeW+E5mjVrxqBBg/jqq6/49ddfazcIv/DCC6xfv97yDeHr64u3tzcFBQXk5+ezZ88efv31V6ZPny6zI4QQNVPDoXBQUFC1d9bw8fHB29ubnJwcDAYDrq7lw6DBYCAnJwcPD48qJxeUzXoIDg62Wl52vLqNzFRNUfvqq69Yt24dbm5uPPnkk+zYsYO9e/eyY8cO9u3bx7Zt2xg/fjwajYYFCxawZ88eNc0LIYRZHS7W0Gg0hIeHYzQaSUlJqVCenJyMyWQqN3/YmrLys2et3zqtbPpudffEVBWEV69ejUaj4Y033mDixIkV9gtu3bo106dP56WXXkJRFGJiYtQ0L4QQwOUpamoeavTv3x+Abdu2VSgrO1bdneLL9pfYtm0bBoOhXJleryc+Ph4w54iroioIHz16lJCQEO64444q640YMYKWLVvyxx9/qGleCCGAut/KctiwYXh4eBATE8OhQ4csxw8ePEhsbCyenp6MGjXKcjwtLY0TJ05YZkQA9OvXj44dO5KSksLcuXMxGo2Aed/1V199lZMnT3LzzTdbnYt8JVU5YVdX1yoT1Vfy9/fn4sWLapoXQggzBXX7QagcCbdu3ZoZM2Ywe/ZsRo4cSZ8+fQCIj4/HYDCwYMGCcmmEcePGkZGRwbx58xg2bBgALi4uvPnmm/zrX/9i1apV/Pjjj3Tq1Iljx46RlpZGy5YtmT17drV9UTUSvvHGGzl+/DjJyclV1svMzOT48eP07NlTTfNCCAHUfToCYPTo0Sxbtozrr7+e/fv3c+jQIXr27MmHH37IAw88YFMb7du354svvmDs2LEA7NixA4PBwOjRo1m7di2tW7eutg1VI+Fp06YRHx/PxIkTefvtt61u7J6ZmcnkyZNxdXVl2rRpapoXQgizmk4UVmngwIEMHDiw2npV3aCiadOmvPDCCzbtmGZNpUH4ySeftHo8KCiI48ePc//999OrVy86duyIt7c3RUVFpKSkEB8fj16vp3///mzZsoWOHTvWqGNCiIarpvOEnVGlQXjz5s1Vnmgymdi7dy979+61Wr5z50527dpl2dhHCCFsdo1Gwo6g0iAcHR19LfshhBAWdbmBj6ORICyEEHZ0VRv4CCFEnZB0RNWMRiOZmZkUFRVV2GXIYDCg1+s5e/Ys27dvZ+7cubXSUSFEQ6K59FBT3zmpDsIxMTHExMSUWzlSFQnCQgjVZCRs3ZYtW6rdoLhMmzZtuPPOO2vUKSFEA9eAgrCqFXOfffYZgOVmnnv27MHFxYWHH36YgwcPsnXrVp544glcXFwwmUxMmDChTjothKjnynZGU/NwUqqC8OHDh/Hy8uKll16iRYsWNGnShPDwcH7++Wfc3NwICQnhqaee4sknnyQjI4OPPvqorvothKjHrsWyZUehKghfvHiRkJCQcrcw6tChA6dOnSI3N9dy7NFHH8XT05Pvv/++9noqhGhYFBUPJ6YqCHt7e1e4hXNISAgAJ06csBzz9PQkNDSU1NTUWuiiEKLBkXSEdSEhIaSnp1NYWGg51rZtWxRF4ciRI+XqFhcXV9joWAghbKFR1D+claogfMstt1BYWMiLL75Ifn4+AF27dgVg/fr1lruPHjhwgJSUlErvvSSEEFVSk4pw8pSEqiD86KOP4u/vzzfffEP//v3R6/W0b9+ePn36cOTIEYYNG8bUqVOJjIwEzEFbCCFUk3SEdYGBgXzwwQd06tQJd3d33N3dAXj++efx8/MjKSmJLVu2UFBQQKtWrZg0aVKddFoIUc81oJGw6hVznTp1YsOGDZw+fdpyTKfTsWnTJtavX09GRgahoaGMGDECX1/fWu2sEKKBaECLNWq8gU/Lli3L/dy0aVOeeOKJq+6QEEJIEBZCCLtSm+d13pxwpUF4+PDhV924RqNh7dq1V92OEKJhUTvtzJmnqFUahA8dOnTVjf99YYcQQojyKg3C8+bNu5b9EEKIyyQnDA8++OC17IcQQjRIDeLC3NR+vcg5nVt9RSc0fy+MDOln727Umc2ndtu7C3UmIWMq3ybVz9dXYmjG4czIGp8vOWEhhLAnBXWzIyQICyFELZKcsBBC2JEEYSGEsB/JCQshhL05cWBVQ4KwEMLxSDqiekajkT///JO//vqL/Px8xowZQ2lpKadPn6ZNmza12UchRAMj6YhqrFy5kvfff5/s7GzLsTFjxpCens69997L4MGDmTt3Lj4+PrXWUSFEA6J2o3Yn3tRddRB+/vnn2bBhA4qi0LhxY/R6PcXFxQBkZWVhMpnYunUr6enpxMXF4eXlVeudFkLUcw0oHaHqzhqbN29m/fr1NGvWjJiYGOLj4+nUqZOl/MYbb+Tjjz+mWbNmHD16lI8++qjWOyyEqP/kRp+VWL16NRqNhkWLFtG/f3+rdW644QaWLl2Koih8++23tdJJIUQDI7c3su7w4cOEhITQo0ePKut17dqVtm3bkpqaelWdE0I0UGpHt04chFWNhEtKSvD29raprlyUE0JclQYwCgaVQbhly5YkJydTWFhYZb38/HySkpIICgq6qs4JIUR9pyoIDxw4kJKSEubPn19lvblz56LX67ntttuuqnNCiAZKcsLWRUVFsXHjRtauXUtaWhp33XUXubnmfXoPHz7MiRMn+Oyzz9i3bx9+fn6MHz++TjothKjfZLFGJQICAoiJiWHy5Mns2bOH+Ph4S9lDDz0EgKIo+Pv7s2TJElq0aFG7vRVCiHpG9WKNzp078/XXX7NmzRq2b99OUlISBQUFeHl50bZtWwYMGMCoUaMICAioi/4KIRqCBrRYo0bLln18fHjsscd47LHHars/Qggh6QghhLArGQlb98UXX6h+gqFDh6o+RwjRwEkQtu7ZZ59Fo7FttyJFUdBoNBKEhRCqSTqiEtddd12lQbi4uJisrCxyc3PRaDTce++9cnFOCFFzThxY1VAVhDds2FBtnX379vHss89y6NAh1q1bV+OOCSEaroY0Ela1Ys4WvXv3ZtGiRaSkpLB06dLabl4I0RA0oBVztR6EwTyXOCwsjC1bttRF80KI+u4aBeHdu3fz6KOP0qdPH3r27MnYsWPZuXPnVXX98ccfJyIiotxitqrUSRAGcHFx4dy5c3XVvBCiHrsWm7pv2LCByMhIEhIS6NatGz169CAhIYGoqCjWrFlTo37HxcWxa9cuVefUyTzh/fv3k5SURMuWLeuieSFEfVfHU9QyMzOZNWsWvr6+xMXFodPpADhw4ACRkZHMmTOHAQMGqNp6ITU1lddee01dR1AZhFetWlVluV6vJzk5ma+++gqA22+/XXWHhBCiroPwqlWr0Ov1PPHEE5YADNCtWzeioqJYuHAha9asYerUqTa1ZzQamTFjBm5ubuh0Oo4dO2ZzX1QF4VdeecWmecKKotCmTRsmTZqkpnkhhADqfnZEWcpg8ODBFcoGDx7MwoUL2blzp81BODY2loSEBF5//XXWr1+vqi+qgvANN9xQdWOurvj5+dGjRw+GDx8ud9cQQtRcHc14UBSFpKQktFotYWFhFcpDQ0PRarUkJSVZFp1V5ejRoyxZsoQhQ4Zw33331W0Q/vjjj1U1LoQQjiY3Nxe9Xk9AQADu7u4Vyl1dXfH39yc7O5uCgoIqB5N6vZ5nnnkGPz8/XnrppRr1R1UQHj9+PM2bN+e5557Dz8+vRk8ohBDVqWk64syZM7i4uJQr8/PzKxevioqKAPDy8qq0PU9PT4Bqg/CiRYs4duwYS5curfEKYVVB+I8//sDHx0cCsBCibtXwwtyoUaPIysoqVxQdHc2UKVMsP2u1ts/MVZTKO/Hbb7/xwQcfcP/991vNLdtK9RS1xo0b1/jJhBDCJjUMwnFxcVZHwlcqu2N8SUlJpc0VFxeXq/t3hYWFPPvsszRr1owXX3xRRUcrUhWE77//fj799FO+//57mX4mhKhTtu3XWF5QUBAeHh5V1vHx8cHb25ucnBwMBgOuruXDoMFgICcnBw8Pj0r/6l+9ejVpaWlEREQwe/bscmVJSUkALFu2jLVr1zJy5Eh69+5daX9UB+EjR44QHR1N9+7d6d69O82bN7ea3C4zevRoNU8hhBB1Ok9Yo9EQHh7OgQMHSElJITw8vFx5cnIyJpOp3PzhvyssLAQgMTGRxMREq3V2794NQL9+/WovCD/yyCNoNBoURSEhIYHff/+92nMkCAsh1KrrecL9+/fnwIEDbNu2rUIQ3rZtGwC33XZbpedPmTKlXJ75SuPGjeOXX35h5cqV9OnTp9q+1Oo8YSGEqBV1vGJu2LBhxMbGEhMTwy233EKXLl0AOHjwILGxsXh6ejJq1ChL/bS0NEpLS2nevDm+vr7qnqwalQbhU6dO4eHhQWBgoOWYzBMWQlwTdRyEW7duzYwZM5g9ezYjR460jFjj4+MxGAwsWLCgXOwbN24cGRkZzJs3j2HDhql7smpUGoQHDRpE7969+eSTT2r1CYUQojoaVKYjavAco0ePplWrVsTGxrJ//37c3d3p2bMnEydOpG/fvjVosWaqTEdUNUdOCCHqzDW60efAgQMZOHBgtfW2b99uc5srVqxQ1Qe55b0QwuE0pNsbSRAWQjgeueW9uBo+jQ2MeTqTfnflEtDcQG62C/t+9GPVmy04m1H5nOqatFcZrVbh3n9lc8fD52nTwbwyKP2EB9+v9Wfjh00xGa1n0bx9jIyYdJab784lKESPoVRD4u/erH2nOft31u5VYWeTd8GFT94MYve3jTl/1pXGgQZ6D8hj9NNnaNG6VHV7Z5LOMe//2vLHbh8K81xo0aaEW+7O5cGoc/j5G21q4/2XW7H+vea8t/0ooR2LVffBUclI+JLs7Gy++OKLq3qCoUOHXtX5zsansYGFXybRpkMJBXlako940rKNnjsfOc/Nd+XyzEPtST5S+cYhats7WZJa4Ryti8KsD1K46Y6LAJxKccdo1NC+cxEduhbRe9BF/vdoGEZD+UDcorWeV9edIKiNnuIiDeknPGjeqpSet+bT/ZZ83nkhmK9WNL26N8hJ5V1w4an7O5Ce5Im3j5F2nYo5nebO5k8D+fnbxry2Pomw62wPgru/bczbE1dg0Pvj4WWkja6Yc6fciHsriG1rA5i7+gQh4ZUvqwXYu92XL5Y3u9qX5phkJGyWmprKzJkza9y4RqNpcEH4P6+dpE2HEuK3+TJvYluKClxw8zAxdf5J/vHPHGa+m8q/B0VgMtl2Pbe69kJLl6DVBpZr795/ZXHTHRcpyNPycmQ7/tht3gXqut4FvLwimd4D8nl40llWL748ktZqFV6MTSGojZ79O32YP6ktuedd0WgURv0nk0efyWTCrFPs3e7LmbSql4XWR289E0J6kic33p7LzHdT8fYxoS/WsPjZ1mz9LJB5E0NZtv0of9u2wKozae4smNIGg95IvzsvMG1hOj6NjRiN8MkbQcS9FcQLY8KI+fEo7p7Wo0v8Nj/mTAit8EVabzSgIFzldkLu7u60bNmyxo+goKBr9TocQkh4MTffnUthvpbXprahqMD8G1laomXhtBBSj3nQVldCv7tya609L7eMCu0NfigHgE+XNLcEYIDD+xqx8nXzZzJ4xPly5wx6KIcO3Yo4nerOrHHtyD1v/n5WFA2rFgZx4JdGuHso3H6p7YYk7bgHP3/TGK9GRp5ZnIa3jwkAd0+Fp95Ip02HYtKOe7L7W9s2t1r/XjOKC11o3q4pzy1LxaexOfXg4gL/mn6Gbv3yOJPmYXWUqy/R8NGrQbw0rh0lxXV2n167uxY3+nQUVY6Eu3TpUu195a6FDRs2MHPmTFatWlXlGmx7GzQsB60W4rf6kXeh/FtrMmnYsiaAqBdPc9v9F/hpU5M6ay8wyJyfTLGS9jh+wHyseXD5HGZZcP3kzRborfxyf/JGEB2uL+TY79Z3larPtm/wR1E09LnjYoVcrYsL/OOf2cT+XzA7vvSn/73Vf8Hu32HOrfd7uCdu7tsqlN8/LosDu33Z/rk/D08+azmefcaVp4d24EyaB27uJqb830kWTQ+5ylcn7M3hv0oTEhJ45ZVX7N0Nm3Tsad7U4/C+RlbLj/5mDmBd+hTUaXtZp80X/9p3LqpwTtsIc97ybIab5ZjWRbG0sWeL9V2j/tjtw7p3m3Pgl4Z3y6qj+83v/3W9rX9uHXuZP6dD8dY/p787e8r8+bTqaP0vxVbtzLng1KOeFBdeTjdcyHLjTJoHnXoVsOTbY9w9Jtu2F+CsFBUPJ+bQsyM2b97MzJkzLTsWObpWoXrAnPOzJvPSzIiA5gY8vY0UF1adQKxpe9/FBdCxZyEjJp/l0K+NOLjHHDjbdynkX9PPAPD1R5cvsLUOK8HdQyE705X8XFdati1hyMjztO9ShKLAkd8a8fXKQPJyHPqfS505lWJ+n4Pa6K2Wtwg2H88550ZRgRavRiab2jUZrdcry/OaTBqyTrvTur05KDcONPDSh3/Rd8hFVf13RhpFQaNisZiauo7GIX+rzpw5w5tvvsnGjRvx8vKiadOmFXbLd0SNAw0AXMyxHlzzrjjeOKD6IFzT9r6NC6RJUwMjn8zk1XUnOJPqjsGgITisBH2xlhXzg/g89nK+sfmlIHLxvCuDh59n6oKTeHhd/kfdZ3AeQx/L4sWx7Tj2R8NLR+Rmm39N/PwNVst9r0hR5J53xauR9WBdJihET9pxT84knbNannrM0/L/+bmXP+OmLUtp2lL9VDinJBfm7Outt95i48aNdOnShTVr1li9I6ojcvc0j2ys5VT/frysbl21d/IvDzLT3NFqoVU7PW06lODiAoV52gpB3evShaZmrfQ89UY6B/f48O/bddzTtitPDNLx2w4fmjQ1MHtlMo0DG0gQuELZ+1zZZ3blcX1x9bMV+gw25413fRKPvqR8fZMJ1i9rbvm5tLSezn6oRkO6MFdpEI6Ojq713YJsFRYWxoIFC1i7di0RERF26UNNVLYAooxG5VdeTdsbM+0ML7yfil+Akbn/bsPQDl14MKIL8ye3wcUVpi7IYMKsDEt9dw9zEPFpbCI9yZMXH21H8hEvDKVaUo568b9H23EqxR3/ZgYeesL66K0+07pU/Ruu2JZ9sHhwwjn8/A1kn7zAC2PCSDrohaEU0pM8eOXxUDKSPfC4FNhdXZ04ulwNNflgJ88LVxmEH3rooWvZF4sJEyYwdOhQVTfkcwTFheb+unlY/610c798vKSo+tdWk/ZCwosZ9Z9MjEZ4eXwoO770p6jAhcI8F3743J+ZI8MwlMJDT2QRdp35wt2VU50+XdK8QvA3lGpZ/545fVG2AKQh8fQ2v8+lJdY/s1L95eMeXtVH5MAWBl5a8RfejT3542dfJg+J4J623Xn81k4k7PJl5jsplna8fW1bOVfvqB0FO3EQdsicsLPKy3HBt4kR3ybWf3H8/pY7rIv2+t2Zi4sLJOzy4chvFa/W/3XYiz1bGnPLPbn0v/cCfx32ouDi5fRE8mHrq/lSE815yhaVXJyqz3z9jeTnupJ3wXpu/mK53Lz1vPHfdb6hkKfXTiB180yOJpg/p/Cuhdw9Ohv/5gbyL30mAc1ta6/eaUA54QYRhGd8OfGaPE+jwFeBBP69dCBZBXdULHc/Asym1NiEl3c+VyfthTSJBc7Qukdf5u8db7Xdln6rgS+5c4KOTiMm4+aSDUQD8NSaxyg2VJx72sj9KPAybh6ezN/7bLV9ry0JGdXXqWuNW6/ldMoJ9h2ciGtEzwrlfyWkAXH4NvXhSM5qsHE9i48/dB65iM4jLx/LAOJ3nsFkXIFfMx+SClZBlTMa5wNwJPM1cnzrzxJm2Tuinllw/7vknLZtldrVGDPtDGOnwdEtn/P6f36rUD5i0ll0L8CvW0zMfmx+nbT32AuneHgSJO78lVceP1vhHIBnl6YS9CD89NkRlj5nPi9uvyuBQQa+nruEbWsDKpzzj5HZTHsTkg8rPPuP6vteWzaf+v2aPVdlDt0YxNGfgsj/61N6BL9aofz4F82BVnTtfZIewSMrNvA3B+MbkZjgjVu7mTww5OkK5X9+2gJoSa9b0mxorzsAnVo8Q2iw42zgU2JoxuHMJVfXiBMHVjWcK+nq4H7+xrxstd+dufg2Kf9npFarcMfD5qXC29f711l7By4tU+49IM+ycu5KjQNL6XVbHgAHr1h4sfOrJgA8MD4LTYVhhcJ9/zIvDLB1aW59cvPdFwDY/V3jCjNLjEbY+pn5S2uQjUu6j+73JmZ2MD/F7a1QVpCnZdPH5jnc9z5azxdjVEFmR4gaST7iRfxWXxr5mXjh/VR8L80rdfMw8dQb6bTVlZCe5MHPfwtkfgEGQsKLadm2RHV7xaWtyrW3d7svx/7wwtPbxMsfJdO6/eXRUYvWemZ9kIJfgJGUo5789M3l89a83Zy8Cy7ori/iv4vSLReEXFwVov53Gt31ReSed+HrlZfvu9VQhF1XzI2DcynMc+H/JoRy8bw5EOuLNSycFkLacU9aty/m5r/t4ZGb7ULacQ/LYo8y/e7Mxc3dxMFtR/jh8yaW4+fPuvLy+HacP+vGjbfn2ryysl5SAEVR8bB3h2uuQaQjrqXFz7bmjY5JdL8ln0/2HiHtuAct2+gvXdzR8vL4UBSl/OyD+yOzGDstkzPpbvyrz3Wq2ksrfhpFufIGrBpeeTyU+WtO0KFrETE7EklP8rg0X9g8V/h0qjsvRYaWmwWRc86N2Y+F8vJHyQwenmPeJvOEB82C9TQJNFJUoGXB5DbkZrvREE2df5JpQ73442dfxtxwHW06lHA6zZ38C6408jMy64Nk/j6Z58sPm/HJm0G0aK1n5a+HLceD2+mJevEU77zYmvmTQ/lwfgk+fkbSjntSqtfSoVshz75TcYvShqQh5YRlJFzLsk67E32njs9jm3Ih24V2nYoxGjX88HkTptytIz3Js/pGVLRXYgiucM7ZDPM5K19rQcoRT1qE6GkWrCf9uCerFrZg8hAdp1Mrbkd54BcfJgyMYNPKQC7muNA2opjSEi1b1vgz5a4O/LbD+r4SDUGzVqW8/V0iQx87R5NAI8lHPHFxURgwNIcl3yRaNs631QOPZTHm1QfpelM+F8+7knbck1btShj37Cne+Pw4jXxVTj6ubxrQPGGN4gR38xw7diy//vqr6l3USkpKOHTo0DW7MGcP8/c+y7M3XLsLZdeaI1yYqysJGZ/adCHPGZVdmOvSpQseHrbvP132Oztr2R7OX7T9QmOAnycv//sm1c/nCCQdIYRwPDJP2LF8/PHH1VcSQtQbGlTmhOusJ3VPcsJCCGFHTjESFkI0MGVTz9TUd1IShIUQDqchTVGTICyEcDxyYU4IIexHRsJCCGFPkhMWQgg7Urspj/PGYAnCQggHJDlhIYSwn4a0WEOCsBDC8ZgU80NNfSclQVgI4XgkHSGEEPYjU9SEEMKeZIqaEELYj4yEhRDCniQnLIQQ9qNBQaMixaBx4igsQVgI4XhMlx5q6jsp2dRdCCHsSEbCQgiHo1FUpiNkdoQQQtQiuTAnhBB2JPOEhRDCfmSesBBC2JOCypFwnfWkzkkQFkI4HI0CGhXTzmQkLIQQtUlywkIIYUcyO0IIIexI5Tzhmo6Ed+/ezbJly0hMTKS0tJTOnTsTFRXFrbfeanMbO3bsYOXKlRw8eJDCwkKaNWtG//79mTRpEkFBQdWeLyvmhBCOpywdoeah0oYNG4iMjCQhIYFu3brRo0cPEhISiIqKYs2aNTa18f777zNhwgR2795Nu3btLMF7zZo1PPjgg5w4caLaNmQkLIRwPHW8d0RmZiazZs3C19eXuLg4dDodAAcOHCAyMpI5c+YwYMAAWrRoUWkbSUlJLFy4EG9vbz744AN69OgBQGlpKXPnziUuLo7nnnuu2oAuI2EhhMMp20XN5ofKpPCqVavQ6/WMGzfOEoABunXrRlRUFCUlJdUGz40bN2IymYiMjLQEYAA3Nzeee+45AgIC+P3338nIyKiyHQnCQgjHU8fpiF27dgEwePDgCmVlx3bu3FllG25ubkRERHDDDTdYLWvdujUAZ8+erbIdSUcIIRxPHU5RUxSFpKQktFotYWFhFcpDQ0PRarUkJSWhKAoajcZqO1OnTmXq1KlWywoLC0lKSgKo9uKcBGEhhOOpYU74zJkzuLi4lCvy8/PDz8/P8nNubi56vZ6AgADc3d0rNOXq6oq/vz/Z2dkUFBTg4+OjuvsxMTEUFhbStWtXWrZsWWVdCcJCCIdT060sR40aRVZWVrmy6OhopkyZYvm5qKgIAC8vr0rb8/T0BKhREN6xYwfvvfceWq2WZ555ptr6EoSFEPVGXFyc1ZHwlbRa2y+FKSpzzT/++CNTp07FaDQybdo0+vTpU+05EoSFEI6nhhv4BAUF4eHhUWVVb29vAEpKSiqtU1xcXK6uLdatW8esWbMwGAxER0czYcIEm86TICyEcDx1eGHOx8cHb29vcnJyMBgMuLqWD4MGg4GcnBw8PDwqjKIrs3DhQpYtW4ZGo2HmzJmMGzfO5v7IFDUhhANSOz1NRf5YoyE8PByj0UhKSkqF8uTkZEwmU7n5w5X2UlF4/vnnWbZsGe7u7rz55puqAjBIEBZCOCJTDR4q9O/fH4Bt27ZVKCs7dtttt1Xbzvz581m3bh0+Pj4sX76cu+++W11HkCAshHBAqlbLqd3sBxg2bBgeHh7ExMRw6NAhy/GDBw8SGxuLp6cno0aNshxPS0vjxIkT5OXlWY7t3LmTFStW4OrqynvvvceNN95Yo9cqOWEhhOOp4/2EW7duzYwZM5g9ezYjR460zGKIj4/HYDCwYMECAgMDLfXHjRtHRkYG8+bNY9iwYQAsXrwYgMDAQD799FM+/fRTq881ceJE2rdvX2lfJAgLIRyPSTE/1NRXafTo0bRq1YrY2Fj279+Pu7s7PXv2ZOLEifTt27fKcy9cuMDBgwcB82ZAX331VaV1R4wYIUFYCOFkrtGdNQYOHMjAgQOrrbd9+/ZyPzdp0oTExMQaPeffSRAWQjggtZvyOO+tNSQICyEcj9xtuX4oW3Lo19zXzj2pW/4tG9u7C3WmxNDM3l2oU/X19emNAYD6Zb8W1yAn7CjqdRAuLS0FYGLsGDv3pG7N+HKivbtQZw5n2rsHdetw5hJ7d6FOlZaWWjbDUUUxmR9q6jupeh2EGzVqhE6nw83NrdI9QYUQtU9RFEpLS2nUqFFNG5Bb3tcHWq0WX9/6nYoQwlHVaARcRtIRQghhTzI7Qggh7EfSEUIIYUcNaIqabOAjhBB2JCNhIYTjMZnMDzX1nZQEYSGE45GcsBBC2FEDCsKSE3ZSu3fv5tFHH6VPnz707NmTsWPHsnPnTnt3S6i0YcMGIiIi2Ldvn7274lgU5fJcYVseEoTFtbRhwwYiIyNJSEigW7du9OjRg4SEBKKiolizZo29uydslJCQwCuvvGLvbjgkRTGpfjgrSUc4mczMTGbNmoWvry9xcXGWmxEeOHCAyMhI5syZw4ABA2jRooWdeyqqsnnzZmbOnElhYaG9u+KYTKhcMVdnPalzMhJ2MqtWrUKv1zNu3Lhyd4Pt1q0bUVFRlJSUyGjYgZ05c4bp06czdepUTCYTTZs2tXeXHJOaOy2rzR87GAnCTmbXrl0ADB48uEJZ2THJDTuut956i40bN9KlSxfWrFlDWFiYvbvkmMqmqKl5OClJRzgRRVFISkpCq9Va/eUNDQ1Fq9WSlJSEoiiyc5wDCgsLY8GCBdx///1otTIGqlQDmh0hQdiJ5ObmotfrCQgIwN3dvUK5q6sr/v7+ZGdnU1BQgI+Pjx16KaoyYcIEe3fBKSiKCUXF6NaZL8zJV7ETKSoqAsDLy6vSOmXbBxYUFFyTPglRJxpQTlhGwk5EzZ+vNb6tjBCOoAHNjpAg7ES8vb0BKCkpqbROcXFxubpCOCW5vZFwRD4+Pnh7e5OTk4PBYMDVtfzHZzAYyMnJwcPDAz8/Pzv1Uoirp5gUFBUjYTV1HY3khJ2IRqMhPDwco9FISkpKhfLk5GRMJlO5+cNCOCfT5dGwLQ8nzkdIEHYy/fv3B2Dbtm0VysqO3Xbbbde0T0LUuksjYVsfznyPOQnCTmbYsGF4eHgQExPDoUOHLMcPHjxIbGwsnp6ejBo1yo49FEKoITlhJ9O6dWtmzJjB7NmzGTlyJH369AEgPj4eg8HAggULCAwMtHMvhbg6fs18VE0782vmvHPiJQg7odGjR9OqVStiY2PZv38/7u7u9OzZk4kTJ9K3b197d0+IGnNxccHFxYWJsWNqfK6z0SgyoVQI4UAMBgNGo1H1eS4uLhVmDDkDCcJCCGFHcmFOCCHsSIKwEELYkQRhIYSwIwnCQghhRxKEhRDCjiQICyGEHUkQvgZOnjxJRESE1UfHjh3p1q0bt956KxMnTrS6J4Q9HDt2zNLHKz377LNERESwYMGCq36OrKwsLl68eNXtVOeTTz4hIiKCsWPH2lR/w4YNREREMGzYsKt+7iVLlhAREcHUqVOvuq3qDBo0iIiICH744Yc6fy5Re5xvZrOT69KlS7lbEymKgl6v5+TJk2zfvp3t27czatQoZs2aZcde1r0VK1awZMkSVq9eLdtuigZNgvA1tmjRIlq3bl3heGlpKW+//TbLli0jLi6O/v37M2jQIDv0sGpPP/00UVFR+Pv7X1U78+bNq6UeCeHcJB3hINzc3Hjqqafo0aMHAHFxcXbukXXNmzenffv2BAQE2LsrQtQLEoQdzMCBAwHz1pRCiPpP0hEOpuw29VfeLXnJkiW8/fbbTJ8+HS8vL959911yc3Np06YNS5cupW3btgCkp6cTExPDTz/9xNmzZ2nUqBHdu3dn3Lhxle6udu7cOWJiYvj+++85d+4cwcHBPPLII9x4441W6z/77LN8/vnnjB8/nhkzZpQrS09PZ+XKlezYsYMzZ87g6elJ165diYyM5JZbbin3Wsrcd999AKxcudKyLSfA3r17WbFiBQkJCVy8eJHAwEBuvvlmnnjiCcvr/bsjR47w7rvvsn//fvLz8+nUqRMTJ06s8v1WKysri48//phdu3aRnp5OUVERvr6+XHfddTz88MMMGTKk0nP/+usv3nzzTcu2ox07duSRRx7h/vvvt1o/Pz+fFStWsHnzZtLS0nBxcUGn0zFs2DAeeughp9wxTFQkQdjBpKWlAdCyZcsKZVu2bOH3338nODiY4OBgCgsLCQkJAWDXrl1MnTqVwsJCvLy86NChA+fPn+fHH3/kxx9/ZMqUKURHR5drLzk5mcjISE6fPo2npycdOnQgMzOTOXPm0Lt3b1X9/vnnn3nyySfJy8vD29ub8PBwzp07x08//cRPP/3EnDlzGD58OC1btqRnz57s378fgOuuuw5PT098fX0tbb3zzjssWrQIAH9/f3Q6Henp6axfv55vvvmGRYsWVbh7yNatW3n66afR6/X4+/vTvn17jh49SlRUFL169VL1Wipz5MgRIiMjycnJwdvb25LbT09Pt7zOadOmMWHChArnJicn8/DDD1NQUECHDh0oLCxk//797N+/nz179jB37txy9U+ePMn48eNJTU3F1dWV0NBQTCYTCQkJJCQksGXLFt55551yF3mFk1JEnUtPT1d0Op2i0+mU9PT0SutduHBBuemmmxSdTqe88sorluOLFy+2nD9nzhzFZDIpiqIo2dnZlvZ79uyp6HQ65a233lJKSkos527bts1StnXrVstxk8mk/POf/1R0Op0yfvx4JScnR1EURTEajcry5cuViIgIy3NeacaMGYpOp1Pmz59vOZadna306dNH0el0ygsvvKDk5+dbnuPDDz9UdDqd0rlz53KvvaztxMTEcu1v3rxZ0el0Ss+ePZVNmzZZjuv1emXp0qWWsoyMDEtZVlaW5TW+9tprSmlpqaIoipKfn6889dRTlucaM2ZMpe/9ldavX6/odDrlwQcfLHf8wQcfVHQ6nfKf//xHycvLsxzPy8tTpk2bpuh0OqVXr16KXq+3lF352d1xxx1KUlKSpey7775TunTpouh0OuXrr7+2HDcYDMrQoUMVnU6n/Pvf/1bOnTtnKTt+/Lhy1113KTqdTvm///u/cv0bOHCgotPplO3bt9v0OoVjkJywnSmKwsWLF9m5cyePP/4458+fx9fXl8cee6xCXTc3N5588kk0Gg2A5eLYBx98QH5+PkOHDuXJJ58sNzq6/fbbmTZtGkC5NMC+fftISEjAz8+PhQsX0qRJEwC0Wi3jx4/ngQcesPk1fPbZZ+Tk5NC9e3dmz55No0aNAPONSceNG8eAAQMoLS3lm2++qbatxYsXA/Dcc89x9913l3vtkyZN4q677rL8mV5m9erV5Ofnc+ONN/Lf//7Xsqdso0aNmD9/fqXpCzVOnTpFRkYGnp6evPzyy5a0EZhTSP/9738ByMvLIzMzs8L5Go2GJUuW0L59e8uxIUOGWNIly5cvtxzfunUrhw8fpl27drz11ls0bdrUUhYeHs5bb72FVqtl9erVZGdnX/VrE/YlQfgau/322yss1rjhhhuIioriwIED+Pv7884771hNR+h0OkuAu9L27dsBuOeee6w+5z333INGo+HIkSOcO3cOMKcvwHxTUGvzdIcPH27za/rxxx8BePDBBy1fEFd6+eWX2bZtG48//niV7aSlpXH8+HG0Wm25AHyle++9F4CdO3dajv30008AVnOr7u7uleZc1WjVqhXx8fHEx8dbfb88PT0t/19cXFyhvFevXhUWvgA89NBDAPz555+WgPr9998DMHjwYDw8PCqco9Pp0Ol0lJaWsmfPnpq9IOEwJCd8jf19sYZWq8Xb25sWLVrQo0cP7rrrLry9va2e26xZswrH8vPzOX36NAALFy7k3XfftXqui4sLBoOB5ORkmjVrRkpKCmAeWVlj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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.9486227101293103\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>64.0625</td>\n",
       "      <td>35.15625</td>\n",
       "      <td>16.875</td>\n",
       "      <td>8.90625</td>\n",
       "      <td>6.041667</td>\n",
       "      <td>4.53125</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>64.0625</td>\n",
       "      <td>35.15625</td>\n",
       "      <td>16.875</td>\n",
       "      <td>8.90625</td>\n",
       "      <td>6.041667</td>\n",
       "      <td>4.53125</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     64.0625  35.15625  16.875  8.90625  6.041667  4.53125\n",
       "1         NaN       NaN     NaN      NaN       NaN      NaN\n",
       "mean  64.0625  35.15625  16.875  8.90625  6.041667  4.53125"
      ]
     },
     "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
}
