{
 "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:01<00:00, 6247.02it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = \"../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti_partial_charge_superlevel_betti_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": [
    {
     "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": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "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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Ja6/a9cuxWAwKN26dVO++eYb6/7CwkJl9erV1mOJiYnWY2lpadbP+K9//UspKipSFEVRsrOzlZkzZ1rvNWbMmDK/9rfasWOHYjAYlEcffbTE/kcffVQxGAzK3//+dyUrK8u6PysrS5k1a5ZiMBiU7t27K4WFhdZjt37vHnzwQSU2NtZ67Pvvv1c6deqkGAwG5euvv7buLy4uVoYNG6YYDAblueeeU1JTU63Hzp8/rwwePFgxGAzKm2++WSK+/v37KwaDQdm7d69dn1Nom9ScHUxRFDIzM9m/fz/PPvssN27cwNfXl2eeeaZU2zp16jBjxgx0Oh2A9aHcJ598QnZ2NsOGDWPGjBklelMDBgxg1qxZACXKCUePHiU6Oho/Pz/effdd6tWrB5gXIp8wYYKqqaufffYZ6enpdOnShQULFuDt7Q2YV/8aP348/fr1o6ioiG+//fa211q5ciUAL730En/9619LfPapU6cyePBg65/7Flu3biU7O5t77rmHF1980boEpLe3N4sXLy6zDKLG1atXSUxMxMPDgzfeeKPE2zF8fHx48cUXAfNawSkpKaXO1+l0rFq1irZt21r3DRo0yFp2+fjjj6379+zZQ0xMDG3atGH58uU0atTIeiw4OJjly5ej1+vZunUr169fr/RnE9okyfkOGzBgQKlJKD179mTixIkcP36c+vXr8/7779ssaxgMBmviu9XevXsBePjhh23e8+GHH0an03H69GlSU1OBP94+fP/999scZzxixAi7P9O+ffsAePTRR62/OG71xhtv8MMPP/Dss8+We53Lly9z/vx59Hp9icR8q0ceeQQo+WbkgwcPAtis3bq5uZVZ01WjefPmREVFERUVZfPrZXmtEUB+fn6p4927dy81oQfgscceA+DUqVPWRPvjjz8C5rdAu7u7lzrHYDBgMBgoKiri8OHDFftAQvOk5nyH/e8kFL1ej5eXF02aNKFr164MHjwYLy8vm+c2bty41L7s7GySkpIAePfdd/nggw9snuvi4kJxcTFxcXE0btzYuo5tcHCwzfa2EklZEhISAAgJCbF5vGnTpnZdJzY2Fvij926LJfHFx8ejKAo6nc76WW7tld6qXbt2dt3fHh4eHly4cIHjx48THx9PQkIC58+ft8YOYDKZSp3Xvn17m9dr0qQJvr6+ZGVlERcXR8OGDblw4QIA33//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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": "iVBORw0KGgoAAAANSUhEUgAAAWEAAAFGCAYAAAC7Vi5ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABAbUlEQVR4nO3de1xUZf7A8c8MVxFQvN9FxEHTXMXSslBRW7PbFqmZVAsatirqlr/10mUtWm9tZWqWG1imiZmJWWu7XjIvaZIXWjQVRREQFUUQ5SLDzJzfHzSTxABzEJwZ+b73dV6v9ZznPPMdza8P3/Oc59EoiqIghBDCLrT2DkAIIeozScJCCGFHkoSFEMKOJAkLIYQdSRIWQgg7kiQshBB2JElYCCGAhIQEgoKCOHDggKr7srOz+fvf/86QIUPo2bMnw4YNY+nSpej1epvulyQshKj3kpKSePPNN1Xfd+HCBUaNGsXatWvx9fVl0KBBFBYWsnjxYsaNG0dpaWm1fUgSFkLUa5s3b2bcuHEUFRWpvvf111/nwoULTJ06lQ0bNrB48WK2bNlC//79+emnn1i1alW1fUgSFkLUSxcuXGD69OlMmTIFk8lEs2bNVN1/+vRpduzYQYcOHfjLX/5iOe/l5cWcOXNwcXHhs88+q7YfScJCiHrpvffeY+PGjfTo0YO1a9cSEBCg6v4ffvgBRVEIDQ1Fqy2fStu0acMdd9xBVlYWqampVfYjSVgIUS8FBASwYMEC1q1bR1BQkOr7zcm1S5culfYPcOLEiSr7cVX9yUIIcRsYP378Td1/8eJFAFq0aGH1evPmzQHIycmpsh9JwkIIh2IwGDAajarvKyoqorCwsMJ5X19ffH19ayO0coqLiwHw9PS0et18vroHfpKEhRAOw2AwcCR5D0bFW/W9paWlTJw4sUIijo6OZvLkybUVooWLiwsAGo2mynYmk6nK65KEhRAOw2g0YlS86dzs77i75Np8n97YhFM5MWzYsMGSHM3qYhQM0KBBAwCuX79u9br5vJeXV5X9SBIWQjgcF20OLi6XbG+vlI02W7VqhYeHR12FVY65FlxZzffSpUvl2lVGkrAQwuGYUDBh+6Y/atrWFvOsiMqmoJ06dQoAnU5XZT8yRU0I4XBMNfjfrRYSEgLA999/X6Hue+7cOY4dO0bbtm0JDAyssh9JwkIIh2NSFIwqDlMdb5V57tw5Tp06RW7ub3Xq9u3bExISwunTp1m0aJHlfFFREa+++ipGo5HIyMhq+5YkLIRwOCZ+K0nYdtStGTNm8NBDD7F69epy52fPnk3z5s1ZtmwZjz76KFOmTOGPf/wje/bsYcCAATz99NPV9i1JWAjhcIwoqg97aN++PevWrSMsLIzc3Fx27NhBo0aNmDZtGu+//z6urtU/dtPIlvdCCEdRUlLCkSNHaNP8eVxdL9p8n8HQgnOX4ujRo8ctmx1RW2R2hBDC4RgVBY2K8aHRiceSkoSFEA7H9Ouhpr2zkiQshHA4JpV1XnvME64t8mBOCCHsSEbCQgiHYwTUDG7Vr7nmOCQJCyEcjgmoem2yiu2dlSRhIYTDMaFBTRo2qUrZjkWSsBDC4ZgUVJUjTM77XE6SsBDC8RjRoMhIWAgh7MOkMgmraetoJAkLIRyOSdGgUVQkYRVtHY0kYSGEwzECGlUjYeclSVgI4XBMaFH3LpnWad88kyQshHA4JkUDakoMikaSsCMymUwUFhbi5uZW7bbUQojaoygKpaWlNGzYEK1WfXo0qpwnDBqnTWbOGrdNCgsLOXHihL3DEKLe0ul0+Pj4qL7PpGhRFNuTt0ZFW0dzWydhNzc3AAKbzcbdJbea1s7paPYS7mg52d5h1Jk/97vD3iHUmRlfT2DBYx/aO4w64dvChwlxz1j+DqpVNkVNRRKWKWqOyVyCcHfJxcP1kp2jqTu383fLO59v7xDq1O3+/WpaBlT7soYkYSGEqEUmRYtJRYlBK+UIIYSoPSY0Kl9Fdt6RsPP+8yGEELcBGQkLIRyOEe2vL2zYRs1DPEcjSVgI4XBMigajmjqvrB0hhBC1x6RyJOy878tJEhZCOCCjosGo8rVlZyVJWAjhcExoMcpIWAgh7MOEunnCakoXjkaSsBDC4RjRqBwJSzlCCCFqjUllTVgrNWEhhKg9amdHSDlCCCFqkVHRqponLGtHCCFELVJUrh0huy0LIUQtMqp8Y07VnGIHI0lYCOFwjCrnCatp62gkCQshHI6iaMo2+1TR3llJEhZCOBwZCQshhB2ZFI26N+aceCTsvP98CCHEbUBGwkIIh2NCg1HFtDN1WyH9Zu/evSxbtoyUlBRKS0vp3r07UVFRDBgwwOY+fv75Zz788EOSkpIoKiqiVatWDB48mEmTJtGoUaNq75eRsBDC4Zg3+lRzqJWQkEBkZCRJSUn07NmT3r17k5SURFRUFGvXrrWpj23bthEeHs6OHTvw9/dnwIABlJSU8OmnnzJy5Ehyc3Or7UNGwkIIh2NUORJW0xYgOzub2bNn4+PjQ3x8PDqdDoDk5GQiIyOZM2cOgwYNomXLlpX2YTAYmD17NiaTiSVLlvDHP/4RgJKSEqZOncr333/P0qVLee2116qMRUbCQgiHo6gcBSsqR8KrV69Gr9cTERFhScAAPXv2JCoqipKSkmpHwykpKeTk5NC1a1dLAgbw8PBg4sSJAOzfv7/aWCQJCyEcjhGNZf0Imw6VI+Hdu3cDMHTo0ArXzOd27dpVZR9abVn6vHz5MgaDody1vLw8AKkJCyGck+nXtSPUHLZSFIXU1FS0Wi0BAQEVrvv7+6PVaklNTUVRlEr7CQwMpHXr1mRnZzN9+nQyMjIoLi7mxx9/5I033kCr1RIZGVltPFITFkI4HJOi7mUN84O5Cxcu4OLiUu6ar68vvr6+ll/n5+ej1+tp0qQJ7u7uFfpydXXFz8+Py5cvU1hYiLe3t9XPdHNzY/HixURHR7Np0yY2bdpkudaiRQvi4uK47777qo1dkrAQwuGYFHWjW/PLGmPGjCEnJ6fctejoaCZPnmz5dXFxMQANGjSotD9PT0+AKpMwQIcOHXj00Uf55JNP6N69O02bNuXIkSNcvHiRuLg4unfvTuPGjauMXZKwEMLh1PS15fj4eKsj4RuZa7m2qKockZeXx5gxY8jOzuaTTz6hX79+AOj1emJiYli3bh3R0dF89tlnVX6GJGEhhMOp6Ui4VatWeHh4VNnWy8sLKJtKVpnr16+Xa2vN8uXLOX36NH/7298sCRjA3d2d2bNnc+DAAfbv38+BAwe46667Ku1HHswJIRxO2aLuWpsPNYu6e3t74+XlRV5eXoVZDVA2/zcvLw8PD48Ko+gb/fTTTwBW675ubm70798fgKNHj1YZjyRhIYTDMf660aeaw1YajYbAwECMRiNnzpypcD0tLQ2TyVRu/rA1V69eBahQ/jAzny8tLa2yH0nCQgiHY/p1PWE1hxohISFA2WvHv2c+N3DgwCr7ME9v27lzZ4VrRqORffv2AdC1a9cq+5EkLIRwOHX9xlxYWBgeHh7ExsZy5MgRy/nDhw8TFxeHp6cnY8aMsZzPyMjg1KlTXLt2zXLuqaeeAmDZsmUcPHjQct5gMPDWW29x4sQJunTpwj333FNlLPJgTgjhcOp67Yh27doxY8YMYmJiGD16tOXBWmJiIgaDgQULFtC0aVNL+4iICLKyspg3bx5hYWFA2Uh5/PjxfPTRR4SHh9OrVy+aNGnCsWPHOHfuHM2aNeO9996rtFxhJklYCOFwTKgrMdRkKcvw8HDatGlDXFwchw4dwt3dneDgYCZMmMC9995rUx/Tpk0jODiYVatWcfjwYY4cOUKLFi145plneOGFF2jRokW1fUgSFkLUW6GhoYSGhlbbbvv27TfdR2UkCQshHE7ZPGEVry2joYbrutudJGEhhMNR1C7K46wZGEnCQggHZFRq8GDOSfOwJGEhhMMxKVqV5QjnnW0rSVgI4XAUlWtHSDlC2I3JpDDl4S6cP+PBul+OVH+DsCvvRgaeeSmb/sPzad7mGVYf1HBghy+r323JxayKa9vWV2oXaq/pbsuOwHnH8AKALR/uIiWpob3DEDbwbmRg4depPBGVg3cjI9dLO+DhqfDg07l8sPUEnboV2ztEh2FS1L66bO+Ia06SsJNSFFj1dit2rPjR3qEIG/31n2fp0KWExG0+hAffQcqluTwdfAdb1vrh09jIrA/T0WqdOJvUolux5b2jcNjI9+7dy3PPPUe/fv0IDg7m2WefrXbjvfoi96Irb4ztxGfvtrJ3KMJG7QOvc99D+RQVaPnnlA4UF/66wlaJloXT2pN+woOOuhL6D8+3c6SOQVG5eI+icgEfR+KQSTghIYHIyEiSkpLo2bMnvXv3JikpiaioqGq3ob7dHdzhw7j7u/Hj5kY0aVHKg5OqXulJOIbBYXlotZC41ZdrV8o/ijGZNGxZ2wSAgY9dsUN0jqcuN/p0NA73YC47O5vZs2fj4+NDfHy8ZU3P5ORkIiMjmTNnDoMGDaJly5Z2jtQ+0k96UlyoZciIXP7yehZbfnjO3iEJG3QNLgLg6AHr9fvjB8t2cOjRr/CWxeTIVK8doXHeJOxwI+HVq1ej1+uJiIgot6hyz549iYqKoqSkpF6PhoN6FbJ08wmmL87At4nR3uEIG7Xx1wNwIcP6DIjsX2dGNGlhwNNL/lzrej1hR+JwSXj37t0ADB06tMI187n6XBvufncRnXvIU3Rn06hp2TY6V/OsL2t47YbzjeQf13pVE3aocoSiKKSmpqLVai2r1t/I398frVZLamoqiqKgceIfQUT94u5pAkB/3fq458bz5rb1mXmKms3t6zCWuuZQI+H8/Hz0ej2NGzfG3b3ij22urq74+flRXFxMYaHUzoTzMBmrTigah/qbaH/16cGcQ/3RFxeX/ZjdoEGDStt4enoCSBIWTuV6UdlfNTcP62M2N/ffzpcUO9RfS7uoTzVhhypHaLW2/8enKLZPaj+avaQm4TiJdAAMJh+Ssj63cyy1b/5+e0dQO9y9/wpkM/XTJ7la0styfv7+mQC4uVwCpgAwbeMMFMXjlsfoSBSViVXWjqglXl5l03RKSkoqbXP9+vVybW1xR8vJeLheurngHNSpgwsAcNVeo3fb0XaOpvYNa9PL3iHUiphPi+j3AHz79mf8e+V/gbIEPPPu+QD06FfAOxvg8gVXZty10J6h1gq/1o2Y8fUEe4fhFBzq5x5vb2+8vLzIy8vDYDBUuG4wGMjLy8PDwwNfX187RChEzZxILhs0mOcL/163PmXnjyfZPri4ndWncoRDJWGNRkNgYCBGo5EzZ85UuJ6WlobJZCo3f1gIZ7Dn20YA9H8wH5/G5QcYWq3CA6NyAdi+3u+Wx+aIJAnbUUhICADbtm2rcM18buBAeVVXOJe0Yw1I3OpDQ18Tr36Ujo9fWSJ28zDx4juZdNSVkJnqwZ7/NLJzpI5BoWzur83H7VgT3rlzZ618gNqEGRYWRlxcHLGxsdx///306NEDgMOHDxMXF4enpydjxoypldiEuJUWz2zHO11T6XV/AZ/tP4bJ9WXWHMrAx89IQb6WN8b6O/VLB7WpPq0nXGkSfuGFF276ZQiNRsPRo0dV3dOuXTtmzJhBTEwMo0ePpl+/fgAkJiZiMBhYsGABTZs2vam4hLCHnPPuRD+oI/zFbO4dlk+LdhlcNWr4fkNjVr7dinNp9XtGxI0UlS9rqJgs5XAqTcJt2rS5lXGUEx4eTps2bYiLi+PQoUO4u7sTHBzMhAkTuPfee+0WlyPq3Kcjm8/9bO8whI2u5bmy7O9tWfb3tuVmR4jyzGUGNe2dVaVJePv27bcyjgpCQ0MJDQ21awxCCPtQ+7DNmR/MOdQ8YSGEABkJ2yQ3N5d9+/aRlpZGQUEBM2bMoKSkhKSkJO65557ajFEIUc/ISLgKpaWlvP3226xZs4bS0lLL+RkzZpCRkUFkZCTdunXjww8/rLcLrwshbpKi8mGbEz+YUzVP2GQyMWnSJFauXInBYCAoKIhGjX6b11hYWIhWq+Xo0aM8/fTT5OXl1XrAQojbn6yiVon169eza9cuAgIC+Prrr/nqq6/Krfvbq1cv/vvf/9KlSxfOnz/P8uXLaz1gIcTtT9WLGk6+qLvqJKzRaFi8eDGBgYFW27Rv354lS5ag1WrtPsNCCOGczHvM2Xw48UhYVU345MmTBAQE0Llz5yrb+fv74+/vT2Zm5k0FJ4SonxSVNeHb8mUNa4xGo81r/rq5ueHiYn0/LSGEqEpZEq4fb8ypKke0b9+etLQ0cnNzq2yXk5NDamoq7du3v6nghBD1lNp6cH2pCQ8bNgyDwcDf//73ctPTbqTX63nllVcwGo1Wd0wWQgjxG1XliMjISL7++mu+++47Hn/8cYYMGcKlS2U7VmzdupVTp06xYcMG0tPTad26NREREXURsxDiNicva1SiYcOGfPLJJ0RHR3Ps2DFOnz5tuTZlStn+WIqi0LFjRz744APZ/UIIUSPyYK4Kbdu2Zf369WzdupXvvvuO1NRUCgsLadCgAR07dmTQoEE8/PDDVresF0IIW9yqtSP27t3LsmXLSElJobS0lO7duxMVFcWAAQNs7qOwsJDly5fzn//8h7Nnz9KgQQOCg4OZNGkSd955Z7X312jtCK1Wy7Bhwxg2bFhNbhdCiCrdiiSckJDArFmzcHd355577sFkMpGYmEhUVBQxMTE89dRT1fZx5coVnnvuOVJSUmjZsiUDBw4kIyOD77//nj179rB69Wp69uxZZR83tYpabm4uZ86c4fr16/j4+BAQEEDDhg1vpkshhEBB3XIQaqsR2dnZzJ49Gx8fH+Lj4y37ViYnJxMZGcmcOXMYNGhQtevfzJs3j5SUFB5++GHmz59vqQAsX76ct956i1dffZWvv/66yj5qtMfct99+y5NPPsl9991HeHg448aNY9SoUfTt25eIiAj2799fk26FEAKo+z3mVq9ejV6vJyIiotzGwT179iQqKoqSkhLWrl1bZR/nzp1j48aNtG/fvlwCBhg3bhzdu3enuLi42im9qpPwq6++yrRp0/jll19QFAVvb29atGhBw4YNMRqN7Nu3jz//+c+sWLFCbddCCFFGqcGhwu7duwGsTqM1n9u1a1eVfWzZsgVFUQgPD7f6DCwhIYGtW7fSpEmTKvtRVY745ptv+PLLL3F3d2fChAmEhYWVG66fPXuW+Ph4Pv30UxYsWEDXrl1lbWEhhHpqF+VRVT9WSE1NRavVlluAzMzf3x+tVktqaiqKolS616Z5/8w777yTwsJCvv32W44cOYKrqyv33nsvQ4YMsWmfTlVJeM2aNWg0Gt555x0eeOCBCtfbtWvH9OnT6dSpE6+99hqxsbGShIUQqtXlFLX8/Hz0ej1NmjSxOoJ1dXXFz8+Py5cvU1hYiLe3t9V+MjIygLKHc48++ihZWVmWa5999hn33nsv77//fqX3m6kqRxw/fpz27dtbTcA3GjlyJK1bt+Z///ufmu6FEAKo+VKWFy5c4OzZs+WOq1evluu7uLgYgAYNGlT6+Z6enkDZ9LPKXLt2DYBZs2bRuHFjPv/8cw4ePEh8fDxBQUH8+OOPzJ49u9rvqioJu7q64uXlZVNbPz8/FGeeQS2EsB+FshKDzUfZbWPGjGHIkCHljk8//bRc17YuQgZUmcP0ej1QtljZihUr6N27N97e3vTp04fly5fTsGFDNm3aRFpaWpWfoaoc0bdvX77//nvS0tLo1KlTpe2ys7M5efKklCKEEDVS03JEfHx8hdUbf//mrnkgWVJSUml/169fL9fWGvNo+ZFHHqnwGc2bN2fw4MF88803/PTTT1XmS1Uj4WnTpuHl5cWECRNITU212iY7O5tJkybh6urKtGnT1HQvhBBlajg7olWrVrRr167c8fsE6e3tjZeXF3l5eRgMhgofbTAYyMvLw8PDo8qlF8yzHtq2bWv1uvl8ddu8VToSnjp1qtXzrVq14uTJkzz22GP06dOHrl274uXlRXFxMWfOnCExMRG9Xk9ISAhbtmyha9euVQYghBC/Z54nrKa9rTQaDYGBgSQnJ3PmzJkKuwSlpaVhMpnKzR+2RqfTsW/fPi5evGj1unlxs6ZNm1bZT6VJePPmzVXeaDKZ2L9/f6UvZuzatYvdu3dbFvYRQgib1fErcyEhISQnJ7Nt27YKSXjbtm0ADBw4sMo+BgwYwMqVK9m2bRsvvvgirq6/pVO9Xk9iYiIAffr0qbKfSpNwdHR01d9CCCHqSF2vHREWFkZcXByxsbHcf//99OjRA4DDhw8TFxeHp6cnY8aMsbTPyMigtLSUFi1a4OPjA0D//v3p2rUrx48fZ+7cubzyyiu4uLhgMpl46623OHv2LPfdd5/Vucg3kiQshKh32rVrx4wZM4iJiWH06NH069cPgMTERAwGAwsWLChXRoiIiCArK4t58+YRFhYGgIuLC++++y5//vOfWb16NTt27KBbt26cOHGCjIwMWrduTUxMTLWx1GjtCCGEqFN1/NoyQHh4OMuWLeMPf/gDhw4d4siRIwQHB/PJJ5/wpz/9yaY+OnfuzFdffcWzzz4LwM6dOzEYDISHh7Nu3TratWtXbR81WkXNaDSSnZ1NcXFxhXl0BoMBvV7PxYsX2b59O3Pnzq3JRwgh6jXNr4ea9uqFhoYSGhpabbvt27dXeq1Zs2a8+uqrvPrqqzWKQXUSjo2NJTY21vK2SHUkCQshVKvrtSwdiKokvGXLFt555x2b2nbo0IEHH3ywRkEJIeq5epSEVdWEv/jiCwAeffRRdu7cyb59+3BxcWHUqFEcPnyYrVu38sILL1ieEI4fP75OghZC3OZUvbJcj7a8P3r0KA0aNOD111+nZcuWNG7cmMDAQPbs2YObmxvt27fnxRdfZOrUqWRlZVV4Z1sIIWxhfm1ZzeGsVCXhq1ev0r59+3JbGHXp0oVz586Rn59vOffcc8/h6enJd999V3uRCiHqlzqcGeFIVCVhLy+vCosUt2/fHoBTp05Zznl6euLv7096enothCiEqHekHGFd+/btyczMpKioyHKuY8eOKIrCsWPHyrW9fv261cUxhBCiOhpF/eGsVCXh+++/n6KiIl577TUKCgqAsq09ANavX29ZX9O8MEZlqwsJIUSVbsHLGo5CVRJ+7rnn8PPz49tvvyUkJAS9Xk/nzp3p168fx44dIywsjClTphAZGQmUJW0hhFBNyhHWNW3alI8//phu3brh7u5u2Z/plVdewdfXl9TUVLZs2UJhYSFt2rRh4sSJdRK0EOI2V49GwqrfmOvWrRsJCQmcP3/eck6n07Fp0ybWr19PVlYW/v7+jBw50rLakBBCqFKPXtao0doRAK1bty7362bNmvHCCy/cdEBCCCFJWAgh7Eptndd5a8KVJuERI0bcdOcajYZ169bddD9CiPpF7bQzZ56iVmkSPnLkyE13/vsXO4QQQpRXaRKeN2/erYxDCCF+IzVheOKJJ25lHEIIUS/Viwdzf+53B3nn86tv6ITm74dhbXrZO4w6s/ncz/YOoc4kZd2+36/E0Jyj2TW/X2rCQghhTwrqZkdIEhZCiFokNWEhhLAjScJCCGE/UhMWQgh7c+LEqoYkYSGE45FyRPWMRiO//PILp0+fpqCggGeeeYbS0lLOnz9Phw4dajNGIUQ9I+WIaqxcuZKPPvqIy5cvW84988wzZGZm8sgjjzB06FDmzp2Lt7d3rQUqhKhH1C7U7sSLuqtOwq+88goJCQkoikKjRo3Q6/Vcv34dgJycHEwmE1u3biUzM5P4+HgaNGhQ60ELIW5z9agcoWpnjc2bN7N+/XqaN29ObGwsiYmJdOvWzXK9b9++rFq1iubNm3P8+HE+/fTTWg9YCHH7k40+K7FmzRo0Gg2LFi0iJCTEapu7776bpUuXoigK//nPf2olSCFEPSPbG1l39OhR2rdvT+/evatsd+edd9KxY0fS09NvKjghRD2ldnTrxElY1Ui4pKQELy8vm9rKQzkhxE2pB6NgUJmEW7duTVpaGkVFRVW2KygoIDU1lVatWt1UcEIIcbtTlYRDQ0MpKSlh/vz5VbabO3cuer2egQMH3lRwQoh6SmrC1kVFRbFx40bWrVtHRkYGw4cPJz+/bJ3eo0ePcurUKb744gsOHDiAr68vY8eOrZOghRC3N3lZoxJNmjQhNjaWSZMmsW/fPhITEy3XnnzySQAURcHPz48lS5bQsmXL2o1WCCFuM6pf1ujevTv//ve/Wbt2Ldu3byc1NZXCwkIaNGhAx44dGTRoEGPGjKFJkyZ1Ea8Qoj6oRy9r1Oi1ZW9vb8aNG8e4ceNqOx4hhKhX5QhVD+aEEOKWuEUP5vbu3ctzzz1Hv379CA4O5tlnn2XXrl03Ffrzzz9PUFBQuXJtVVSNhL/66ivVAT3++OOq7xFC1HO3oByRkJDArFmzcHd355577sFkMpGYmEhUVBQxMTE89dRTqvuMj49n9+7dqu5RlYRnzpyJRmPbakWKoqDRaCQJCyFUq+tyRHZ2NrNnz8bHx4f4+Hh0Oh0AycnJREZGMmfOHAYNGqRqckF6ejr//Oc/1QWCyiR8xx13VJqEr1+/Tk5ODvn5+Wg0Gh555BF5OCeEqLk6rPOuXr0avV7PCy+8YEnAAD179iQqKoqFCxeydu1apkyZYlN/RqORGTNm4Obmhk6n48SJEzbHoioJJyQkVNvmwIEDzJw5kyNHjvDll1+q6V4IIYC6HwmbSwZDhw6tcG3o0KEsXLiQXbt22ZyE4+LiSEpK4u2332b9+vWqYqn1B3N33XUXixYt4syZMyxdurS2uxdC1Ad1+GBOURRSU1PRarUEBARUuO7v749WqyU1NRVFqb7j48ePs2TJEoYNG8ajjz5qeyC/qpPZEd27dycgIIAtW7bURfdCiNtdHSbh/Px89Ho9jRs3xt3dvcJ1V1dX/Pz8KC4uprCwsMq+9Ho9f/vb3/D19eX111+3PYgbP69Gd9nAxcWFS5cu1VX3QojbWE3LERcuXMDFxaXcNV9fX3x9fS2/Li4uBqhy1x9PT08ACgsLq1wRctGiRZw4cYKlS5fW+BlYnSThQ4cOkZqaSuvWreuieyHE7a6GU9TGjBlDTk5OuUvR0dFMnjzZ8mut1vYCQFXliIMHD/Lxxx/z2GOPWa0t20pVEl69enWV1/V6PWlpaXzzzTcADBkypMaBCSHqsRom4fj4eKsj4RuZ10QvKSmptDvzvpmVrZ9eVFTEzJkzad68Oa+99pqKQCtSlYTffPNNm+YJK4pChw4dmDhxYo0DE0LUXzUtR7Rq1QoPD48q23p7e+Pl5UVeXh4GgwFX1/Jp0GAwkJeXh4eHR4UEbrZmzRoyMjIICgoiJiam3LXU1FQAli1bxrp16xg9ejR33XVXpfGoSsJ33313ldddXV3x9fWld+/ejBgxQnbXEELUXB3NE9ZoNAQGBpKcnMyZM2cIDAwsdz0tLQ2TyVRu/vDvmTe2SElJISUlxWqbvXv3AtC/f//aS8KrVq1S01wIIRxSSEgIycnJbNu2rUIS3rZtG0CVm1JMnjy5XJ35RhEREfz444+sXLmSfv36VRuLqilqY8eOZebMmVy9elXNbUIIoUpdb3kfFhaGh4cHsbGxHDlyxHL+8OHDxMXF4enpyZgxYyznMzIyOHXqFNeuXautr2ihaiT8v//9D29v70rrJEIIUSvqeAGfdu3aMWPGDGJiYhg9erRlxJqYmIjBYGDBggU0bdrU0j4iIoKsrCzmzZtHWFiYug+rhuopao0aNarVAIQQooJbsIpaeHg4bdq0IS4ujkOHDuHu7k5wcDATJkzg3nvvVd9hDalKwo899hiff/453333nUw/E0LUKdvWa7w5oaGhhIaGVttu+/btNve5YsUKVTGoTsLHjh0jOjqaXr160atXL1q0aGH11T+z8PBwVQEJIYRsb1SJp59+Go1Gg6IoJCUl8fPPP1d7jyRhIYRa9Wl7o1qdJyyEELVCRsJw7tw5PDw8yj0hlHnCQohboh4l4UrnCQ8ePJipU6feyliEEAIoeyinap6wvQO+CVWWI2xZ0FgIIWpdPRoJ19l6wkIIUVPyYE4IIexJRsLCUXk3MvDMS9n0H55PkxYGFJeJvPiOhtXvtuRiVuXztYXjMZkUpjzchfNnPFj3y5Hqb6hHZCT8q8uXL/PVV1/d1Ac8/vjjN3W/+I13IwMLv06lQ5cSCq9pSTvmScCdeh58upD7hufztyc7k3as8i1bhGPZ8uEuUpIa4utnsHcojkdGwmXS09OZNWtWjTvXaDSShGvRX/95lg5dSkjc5sO8CR0pLnRhwf6XuPjDX/njU3nM+jCdvwwOwmRy5mfFtz9Fgc/eacWOFT/aOxTHJUm4jLu7e7l5wsJ+2gde576H8ikq0PLPKR0oLizbwkXBnYXT2hPUu4iOuhL6D8/nh02N7RusqFTuRVcWz2jPj5tlIayqSDniVz169Kh2X7lbISEhgVmzZrF69eoqV6i/nQ0Oy0OrhcStvly7Uv6PzWTSsGVtE6JeO8/Ax65IEnZQB3f48I/x/hQVuNCkRSl9Rw7lv0t32jssYWeqFnW3h6SkJN588017h2F3XYPLtlM5eqCh1evHD5ZtSNijX+Eti0mok37Sk+JCLUNG5PKv7cdpf2cbe4fk2BQVhxNz6NkRmzdvZtasWZb9nOqzNv56AC5kWJ8Bkf3rzIgmLQx4ehm5XuRitZ2wn6BehSzdfILOPYrtHYrD0ygKGhUvi6lp62gcMglfuHCBd999l40bN9KgQQOaNWtGTk6OvcOyq0ZNy56gX82znlyv3XC+URNJwo6o+90ymLBZPXow55DliPfee4+NGzfSo0cP1q5dS0BAgL1Dsjt3TxMA+uvW/8huPG9uK4Szqus95hxJpSPh6OhoWrdufStjsQgICGDBggU89thjaLUO+e/ELWcyanBxqfy/NI38NonbST0aCVeZhO1l/PjxdvtsR3W9SIubuxE3D+ujXDf3386XFEtGFk5O7ejWiZOw/G11Euaar09jo9Xrvn6/nc/PdchSvxC2UzMzwslnSNSLv60zvp5g7xBuWsOmbwFJ/GVpKDmFD5S7Nn//TBq6HwNiKDU25o1dL9slxrqQlGXvCOpSOgAGkw9JWZ/bORbHIi9r3GYWPPYheefz7R3GTXlm2gWenQbHt2zg7b8etJyfv38mM++ez8iJF9G9Cj9tMREzbr4dI61dm8/9bO8Q6sypgwsAcNVeo3fb0XaOpnaVGJpzNHvJzXXixIlVDSlHOIk935a95tr/wXx8Gpdf8EWrVXhgVC4A29f73fLYhKht9Wl2hCRhJ5F2rAGJW31o6Gvi1Y/S8fl15S0Nel58J5OOuhIyUz3Y8x9Zk0DcBhTKVjqy+bB3wDVXL8oRt4vFM9vxTtdUet1fwGf7j5Fx0oOA1hNxfaqQgnwtb4z1R1FkBTXh/OpTTVhGwk4k57w70Q/q2BDXjCuXXejU7TqK4sL3Gxoz+SEdmame9g5RiNohsyOEo7qW58qyv7dl2d/bAmUP5uZPun0exNUnnft0vK0fPN4MjansUNPeWUkSFkI4HnljzrGsWrXK3iEIIW4hDSprwnUWSd2TmrAQQtiRU4yEhRD1jHnqmZr2TkqSsBDC4dSnKWqShIUQjkcezAkhhP3ISFgIIexJasJCCGFH9WhRd0nCQgjHIzVhIYSwn/r0soYkYSGE4zEpZYea9jWwd+9eli1bRkpKCqWlpXTv3p2oqCgGDBhgcx87d+5k5cqVHD58mKKiIpo3b05ISAgTJ06kVatW1d4vb8wJIRzPLVhFLSEhgcjISJKSkujZsye9e/cmKSmJqKgo1q5da1MfH330EePHj2fv3r106tTJkrzXrl3LE088walTp6rtQ0bCQgiHU9dT1LKzs5k9ezY+Pj7Ex8ej0+kASE5OJjIykjlz5jBo0CBatmxZaR+pqaksXLgQLy8vPv74Y3r37g1AaWkpc+fOJT4+npdffrnahC4jYSGE41G1q4bK6WzA6tWr0ev1REREWBIwQM+ePYmKiqKkpKTa5Llx40ZMJhORkZGWBAzg5ubGyy+/TJMmTfj555/Jyqp6t1pJwkIIh1PXe8zt3r0bgKFDh1a4Zj63a9euKvtwc3MjKCiIu+++2+q1du3aAXDx4sUq+5FyhBDC8dThFDVFUUhNTUWr1RIQEFDhur+/P1qtltTUVBRFQaOxPvdiypQpTJkyxeq1oqIiUlNTAap9OCdJWAjhcDQoaFSUGDS/ZuELFy7g4uJS7pqvry++vr6WX+fn56PX62nSpAnu7u4V+nJ1dcXPz4/Lly9TWFiIt7e36vhjY2MpKirizjvvpHXr1lW2lSQshHA8pl8PNe2BMWPGkJOTU+5SdHQ0kydPtvy6uLgYgAYNGlTanadn2X6NNUnCO3fu5F//+hdarZa//e1v1baXJCyEuG3Ex8dbHQnfSKu1/VGYovKB344dO5gyZQpGo5Fp06bRr1+/au+RJCyEcDgaRWU54te2rVq1wsPDo8q2Xl5eAJSUlFTa5vr16+Xa2uLLL79k9uzZGAwGoqOjGT9+vE33SRIWQjieOnww5+3tjZeXF3l5eRgMBlxdy6dBg8FAXl4eHh4eFUbRlVm4cCHLli1Do9Ewa9YsIiIibI5HpqgJIRxPHc4T1mg0BAYGYjQaOXPmTIXraWlpmEymcvOHKw9T4ZVXXmHZsmW4u7vz7rvvqkrAIElYCOGA6nqecEhICADbtm2rcM18buDAgdX2M3/+fL788ku8vb1Zvnw5Dz30kLpAkCQshHBECipHwuq6DwsLw8PDg9jYWI4cOWI5f/jwYeLi4vD09GTMmDGW8xkZGZw6dYpr165Zzu3atYsVK1bg6urKv/71L/r27Vujryo1YSGEw9EooFExRU3tSLhdu3bMmDGDmJgYRo8ebZnFkJiYiMFgYMGCBTRt2tTSPiIigqysLObNm0dYWBgAixcvBqBp06Z8/vnnfP7551Y/a8KECXTu3LnSWCQJCyEczy3Y3ig8PJw2bdoQFxfHoUOHcHd3Jzg4mAkTJnDvvfdWee+VK1c4fPgwULYY0DfffFNp25EjR0oSFkI4mVu0s0ZoaCihoaHVttu+fXu5Xzdu3JiUlJSafejvSBIWQjgelfOEZaNPIYSoTbLbshBC2FEN145wRpKEhRAOp6arqDkjScJCCMcj5QghhLAjScJCCGFHUhMWQgj7qelSls5I1o4QQgg7kpGwEMLxmBfwUdPeSUkSFkI4HnkwJ4QQ9qQyCTvxUFiSsBDC8cjsCCGEsJ/6NDtCkrAQwvFITVgIIezIpJQdato7KUnCQgjHIyNhIYSwJ5kdIYQQ9iMva9welF//EH1b+Ng5krrl17qRvUOoMyWG5vYOoU7drt9Pb2wC/PZ3UDWpCd8eSktLAZgQ94ydI6lbM76eYO8Q6szRbHtHULeOZi+xdwh1qrS0FE9PT/U3KqayQ017J3VbJ+GGDRui0+lwc3NDo9HYOxwh6g1FUSgtLaVhw4Y17UAezN0OtFotPj63dylCCEdVoxGwmZQjhBDCnmR2hBBC2I+UI4QQwo7q0RQ12VlDCCHsSEbCQgjHYzKVHWraOylJwkIIxyM1YSGEsKN6lISlJuyk9u7dy3PPPUe/fv0IDg7m2WefZdeuXfYOS6iUkJBAUFAQBw4csHcojkVRfpsrbMshSVjcSgkJCURGRpKUlETPnj3p3bs3SUlJREVFsXbtWnuHJ2yUlJTEm2++ae8wHJKimFQfzkrKEU4mOzub2bNn4+PjQ3x8PDqdDoDk5GQiIyOZM2cOgwYNomXLlnaOVFRl8+bNzJo1i6KiInuH4phMqHxjrs4iqXMyEnYyq1evRq/XExERYUnAAD179iQqKoqSkhIZDTuwCxcuMH36dKZMmYLJZKJZs2b2DskxmWvCag4nJUnYyezevRuAoUOHVrhmPie1Ycf13nvvsXHjRnr06MHatWsJCAiwd0iOyTxFTc3hpKQc4UQURSE1NRWtVmv1L6+/vz9arZbU1FQURZGV4xxQQEAACxYs4LHHHkOrlTFQperR7AhJwk4kPz8fvV5PkyZNcHd3r3Dd1dUVPz8/Ll++TGFhId7e3naIUlRl/Pjx9g7BKSiKCUXF6FYezIlbori4GIAGDRpU2sa8fKAkYeHUbtFIeO/evSxbtoyUlBRKS0vp3r07UVFRDBgwwOY+0tLSWLJkCQcPHuTKlSt06NCBUaNGER4ebtNPO/LzkBNR8+NrjbeVEcIRmGdH2Hyo/4jamOp5/PhxRowYwaZNm2jTpg0hISFcuHCBf/zjH0yfPt2mPmQk7ES8vLwAKCkpqbTN9evXy7UVwinV8fZGtTHVU1EUpk+fTkFBAW+99RZ/+tOfAMjNzSUiIoJvvvmGBx54gGHDhlUZi4yEnYi3tzdeXl7k5eVhMBgqXDcYDOTl5eHh4YGvr68dIhSidigmRfWhRm1M9dyzZw8pKSn07dvXkoABmjRpwuuvvw7AqlWrqo1FkrAT0Wg0BAYGYjQaOXPmTIXraWlpmEymcv9RCeGcTL+Nhm05VNYjamOqZ1V9BAcH07RpUw4ePEhBQUGV/UgSdjIhISEAbNu2rcI187mBAwfe0piEqHVqR8EqRsJqp3pWJjU1FaDSQU+nTp0wmUycOnWqyngkCTuZsLAwPDw8iI2N5ciRI5bzhw8fJi4uDk9PT8aMGWPHCIVwbOapno0bN65yqmdxcTGFhYWV9nPx4kUAmjdvbvW6+XxOTk6V8ciDOSfTrl07ZsyYQUxMDKNHj6Zfv34AJCYmYjAYWLBgAU2bNrVzlELcHN/m3qqmnfk2L5uOeeHCBVxcXMpf8/Ut94yktqZ6mvupbFdp8/nq1geRJOyEwsPDadOmDXFxcRw6dAh3d3eCg4OZMGEC9957r73DE6LGXFxccHFxYULcM6rvLS0t5Yknnqgweo2Ojmby5MmWX9fWVE9zsq/uzVRTNS+dSBJ2UqGhoYSGhto7DHGTbHl6Xp+4urrSo0cPjEaj6nuLior4+uuvK5z//Uyh2prqaR5Jm9tW1kfDhg2riFqSsBDCwbi6uuLqqj41eXh44OfnV22730/1/P1n2TrVs0WLFhw7doycnBw6d+5c4fqlS5eAymvGZvJgTghRr9TWVM8uXboAv82SuJGiKJw+fRoXFxerCfpGkoSFEPVObUz1NPfx3XffVbh26NAhcnNz6dOnT7VruEgSFkLUO2qnemZkZHDq1CmuXbtmOde3b1+6dOnCnj17+OKLLyznc3NzeeONNwCIjIysNhaNIiu9CCHqodWrVxMTE4Obm5vVqZ43voo8ePBgsrKymDdvHmFhYZbzycnJ/PnPf6aoqIg//OEPtGjRgp9++on8/HxGjRpl0x6C8mBOCFEv1cZUz549e7Ju3ToWL15MYmIiJ0+epGPHjrz00kuMHDnSpj5kJCyEEHYkNeFb4OzZswQFBVk9unbtSs+ePRkwYAATJkyw+qDAHk6cOGGJ8UYzZ84kKCiIBQsW3PRn5OTkcPXq1ZvupzqfffYZQUFBPPvssza1T0hIICgoqNyPnTW1ZMkSgoKCmDJlyk33VZ3BgwcTFBTE999/X+efJWqPlCNusR49epR7X11RFPR6PWfPnmX79u1s376dMWPGMHv2bDtGWfdWrFjBkiVLWLNmjSy7Keo1ScK32KJFi2jXrl2F86Wlpbz//vssW7aM+Ph4QkJCGDx4sB0irNpLL71EVFSUTZPiqzJv3rxaikgI5yblCAfh5ubGiy++SO/evQGIj4+3c0TWtWjRgs6dO9OkSRN7hyLEbUGSsIMxrwdx+PBhO0cihLgVpBzhYMxv19y4EtSSJUt4//33mT59Og0aNODDDz8kPz+fDh06sHTpUjp27AhAZmYmsbGx/PDDD1y8eJGGDRvSq1cvIiIiKp1yc+nSJWJjY/nuu++4dOkSbdu25emnn6Zv375W28+cOZMNGzYwduxYZsyYUe5aZmYmK1euZOfOnVy4cAFPT0/uvPNOIiMjuf/++8t9F7NHH30UgJUrV1rmagLs37+fFStWkJSUxNWrV2natCn33XcfL7zwguX7/t6xY8f48MMPOXToEAUFBXTr1o0JEyZU+futVk5ODqtWrWL37t1kZmZSXFyMj48Pd9xxB6NGjapyP7HTp0/z7rvvWuaidu3alaeffprHHnvMavuCggJWrFjB5s2bycjIwMXFBZ1OR1hYGE8++WSFJRuFc5Ik7GAyMjIAaN26dYVrW7Zs4eeff6Zt27a0bduWoqIi2rdvD5RttTJlyhSKiopo0KABXbp0ITc3lx07drBjxw4mT55MdHR0uf7S0tKIjIzk/PnzeHp60qVLF7Kzs5kzZw533XWXqrj37NnD1KlTuXbtGl5eXgQGBnLp0iV++OEHfvjhB+bMmcOIESNo3bo1wcHBHDp0CIA77rgDT09PfHx8LH198MEHLFq0CAA/Pz90Oh2ZmZmsX7+eb7/9lkWLFlV4pXTr1q289NJL6PV6/Pz86Ny5M8ePHycqKoo+ffqo+i6VOXbsGJGRkeTl5eHl5WWp7WdmZlq+57Rp0xg/fnyFe9PS0hg1ahSFhYV06dKFoqIiDh06xKFDh9i3bx9z584t1/7s2bOMHTuW9PR0XF1d8ff3x2QykZSURFJSElu2bOGDDz6wuii5cDKKqHOZmZmKTqdTdDqdkpmZWWm7K1euKPfcc4+i0+mUN99803J+8eLFlvvnzJmjmEwmRVEU5fLly5b+g4ODFZ1Op7z33ntKSUmJ5d5t27ZZrm3dutVy3mQyKU899ZSi0+mUsWPHKnl5eYqiKIrRaFSWL1+uBAUFWT7zRjNmzFB0Op0yf/58y7nLly8r/fr1U3Q6nfLqq68qBQUFls/45JNPFJ1Op3Tv3r3cdzf3nZKSUq7/zZs3KzqdTgkODlY2bdpkOa/X65WlS5darmVlZVmu5eTkWL7jP//5T6W0tFRRFEUpKChQXnzxRctnPfPMM5X+3t9o/fr1ik6nU5544oly55944glFp9Mpf/3rX5Vr165Zzl+7dk2ZNm2aotPplD59+ih6vd5y7cY/uwceeEBJTU21XPvvf/+r9OjRQ9HpdMq///1vy3mDwaA8/vjjik6nU/7yl78oly5dslw7efKkMnz4cEWn0yn/+Mc/ysUXGhqq6HQ6Zfv27TZ9T+EYpCZsZ4qicPXqVXbt2sXzzz9Pbm4uPj4+jBs3rkJbNzc3pk6dallE2vxw7OOPP6agoIDHH3+cqVOnlhsdDRkyhGnTpgGUKwMcOHCApKQkfH19WbhwIY0bNwbKFrweO3ZsuVc2q/PFF1+Ql5dHr169iImJsayfqtFoiIiIYNCgQZSWlvLtt99W29fixYsBePnll3nooYfKffeJEycyfPhwy4/pZmvWrKGgoIC+ffvyf//3f5alCRs2bMj8+fMrLV+oce7cObKysvD09OSNN94otyiLt7c3//d//wfAtWvXyM7OrnC/RqNhyZIl5VbUGjZsmKVcsnz5csv5rVu3cvToUTp16sR7771Hs2bNLNcCAwN577330Gq1rFmzhsuXL9/0dxP2JUn4FhsyZEiFlzXuvvtuoqKiSE5Oxs/Pjw8++MBqOUKn01ldIHr79u0APPzww1Y/8+GHH0aj0XDs2DHLGqfmnWIHDhxodZ7uiBEjbP5OO3bsAOCJJ56wusvAG2+8wbZt23j++eer7CcjI4OTJ0+i1WrLJeAbPfLII0D5nXB/+OEHAKu1VXd390prrmq0adOGxMREEhMTrf5+3bjFjbVFvvv06VPhxReAJ598EoBffvnFklDNq3INHToUDw+PCvfodDp0Oh2lpaXs27evZl9IOAypCd9iv39ZQ6vV4uXlRcuWLenduzfDhw+vdDV/a4tDFxQUcP78eQAWLlzIhx9+aPVeFxcXDAYDaWlpNG/e3LKOamBgoNX21hJGZTIzM4Hf1lf9vVatWtnUj3ldVvNo3BpzgktPT0dRFDQajeW7VLZua9euXW36fFt4enpy6tQpkpOTSU9PJzMzk5MnT5ZbU9badjbdunWz2l/Lli3x8fHh2rVrpKWl0bRpU8vuvP/97385ePCg1fsuXLgAlNWahXOTJHyLVfayhi2sjYpunEVx9OjRavswL8VXUFAAVL7ZoY+PDxqNpso9tsyuXLkCVL+NS3XMMRkMBsuDu8qYTCbLJozm+yr7x+vGh343IyUlhblz51YYfbZt25awsDDWrVtX6b1VbZPj5eXFtWvXLP/AmL9PZmam5R+4yty4tKJwTpKEndyNSfTHH3+0+SUK84/Ule0EW1JSYlMChrLRYUFBQbW7ylbHnKi6dOnCv//9b5vv8/X15fLly5VuT17ZHmBqXLp0ieeee44rV67QtWtXRowYQbdu3ejcuTN+fn7o9foqk3BVvzfmuM1/JuY/00WLFvHggw/edOzCsUlN2Mn5+vpaEu/p06ettjEajezdu5f09HTLBoqdOnUCyqZdWWP+kdgW/v7+Vd7z/fffEx4eXu7BoDXmB2hnz55Fr9dbbZOTk8OBAwfKPfwyf5fjx49bvaey3xc11q9fz5UrV+jcuTNr167l2Wef5a677rK8vm3tYdyNrG2jA2Wj3YKCArRaLQEBAcBvvw9VxZ2UlMSJEydq5R8YYV+ShG8D5jmzn3/+udXr33zzDZGRkTz++OOWEdmQIUOAsgdc1hLIhg0bbP5884sYGzdurPTzDxw4QH5+vuWc+QHejaPtwMBA2rZtS3FxcaV9vfPOO4SHh/Piiy9azpm/y/r16yvUY00mU6V9qZGVlQVAQEBAuYdwZl9++aXl/1vbKTgxMdFSu7/RmjVrALjrrrssMy4GDRoEwFdffWV1R+DMzEyeeeYZHn30UZKSktR/GeFQJAnfBp5//nk8PDz45ptvWLhwYbm/uLt37yYmJgaAkSNHWuqjPXr0IDQ0lOLiYqKjoy0PegDWrVunau2K8PBwfH192b9/P3PnzrV8vqIorFq1ik2bNuHm5kZ4eLjlHnPp4dy5c5ZzGo2GiRMnAjB37lw2bdpkuWYwGIiLiyMhIQGg3IO7UaNG0bJlS3755Rdee+01y+iwpKSE119/vdLRvhrm0f6ePXtITk62nC8uLuajjz4iNjbWcs5a4tTr9URHR5f7B2/dunWsWLECjUbDpEmTLOcfeeQR/P39SU9PZ/LkyZYZLVA2op44cSIGg4Fu3brZvPi4cFxSE74NBAYGsmDBAqZPn86yZctYtWoVnTp1Ii8vzzKC69+/v2Uuq9mbb77J2LFjSU5OZujQoeh0OnJzczl//jyhoaE2r0vbokUL3n33XSZPnsynn35KQkICHTt25Pz581y+fBkXFxdiYmIsiQzKZl8cOnSIl156iYCAAF588UXuv/9+RowYwcmTJ1mxYgUvvfQS8+bNo2XLlpw9e9byAHDSpEkMHTrU0pe3tzcLFy7khRde4Msvv2TLli107NiR9PR0rl69quq7VGbkyJGsXr2arKwsRo0ahb+/P56enqSnp1NUVETbtm3RarVkZmZy8eLFCveHhISwf/9+hgwZQpcuXcjLy7OMjKdPn84999xjaevu7s7SpUsZN24cO3fuZNCgQQQGBlJaWsqZM2cwGo20atWKDz744Ka+k3AMMhK+TQwfPpyvvvqKESNG0LhxY1JSUsjLy+POO+/k5Zdf5qOPPqrwimvz5s2Jj49n0qRJtG3bltTUVLRaLdHR0bz99tuqPj8kJISNGzcyYsQIvL29SUlJwWg0MnToUNasWVNhgfS5c+fSr18/FEXhzJkzpKenW67NmjWL5cuXM3jwYEwmk6XWe//99/PBBx9YXSC9T58+JCQkEBYWhpeXFydOnKBt27a8/fbb5TZsrClfX1++/PJLnn32Wfz9/cnKyiI9PZ2OHTsSHR3Nxo0bGT58OIDVhN+9e3fWrFlDv379OHPmDFevXqV///588sknVl/MCQwMZOPGjUyYMIGAgADOnDlDRkYGHTp0YOzYsWzYsIE2bdrc9PcS9ifbGwkhhB3JSFgIIexIkrAQQtiRJGEhhLAjScJCCGFHkoSFEMKOJAkLIYQdSRIWQgg7kiQshBB2JElYCCHsSJKwEELYkSRhIYSwo/8H43/av+fZBi8AAAAASUVORK5CYII=\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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fn5m+3bt2sWvv/6Kv78//v7+5OfnExAQAMDBgweZOHEi+fn5uLi4EBYWRmZmJvv372f//v288sorTJgwocz54uLiiIiIIDk5GWdnZ8LCwkhNTWXu3Lncf//9qtodGRnJpEmTuH79Oq6uroSGhpKWlsahQ4c4dOgQc+fOZcCAAfj5+dG+fXuioqIAaNWqFc7Oznh4eJjOtWzZMhYtWgSAl5cXOp2OxMRENm3axI4dO1i0aJHZU5l2797Nq6++SlFREV5eXjRv3pyzZ88yevRoOnTooOpaKnLmzBkiIiLIysrC1dXVdC8kMTHRdJ1TpkzhpZdeMjs2Li6OQYMGkZeXR1hYGPn5+URFRREVFcXhw4eZN29emfjLly8zcuRIEhISsLe3Jzg4GIPBQHR0NNHR0ezatYtly5aVucEuBIqocomJiYpOp1N0Op2SmJhYYdy1a9eULl26KDqdTpkzZ45p++LFi03Hz507VzEYDIqiKEpGRobp/O3bt1d0Op2ycOFCpbCw0HTsnj17TPt2795t2m4wGJRnn31W0el0ysiRI5WsrCxFURRFr9crK1euVMLDw03vebPp06crOp1Oee+990zbMjIylM6dOys6nU6ZMWOGkpuba3qPzz77TNHpdErr1q3LXHvpuc+dO1fm/Dt37lR0Op3Svn175bvvvjNtLyoqUpYuXWral5SUZNqXnp5uusb//Oc/SnFxsaIoipKbm6tMnjzZ9F7PP/98hT/7m23atEnR6XTK008/XWb7008/reh0OuX//b//p1y/ft20/fr168qUKVMUnU6ndOjQQSkqKjLtu/mze+yxx5SYmBjTvu+//15p06aNotPplG+//da0vaSkROnXr5+i0+mUl19+WUlLSzPtu3DhgvLkk08qOp1Oeeedd8q0r3v37opOp1P27dtn0XWK2kdq6NVMURRycnI4cOAAL774IpmZmXh4eDBq1CizWAcHByZNmoRGowEw3Zj89NNPyc3NpV+/fkyaNKlMr61Hjx5MmTIFoEyp49ixY0RHR+Pp6ckHH3xA/fr1AdBqtYwcOZK+fftafA1ff/01WVlZ3HfffcyePRs3NzfA+FDrESNG0K1bN4qLi9mxY8ctz7V48WIA3njjDf7+97+XufZx48bx5JNPmkoRpdauXUtubi6dOnVi6tSppoccuLm58d5771VYolHjypUrJCUl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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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VtXtzDfAcfvESxB2QGPHjqVNmzasWLGCffv24erqSq9evZg8eTL9+/e3dfWEqDcnJyecnJyYvOLBep/raDSKdCgVQtgRvV6PwWBQfZ6Tk1O1HkOOQIKwEELYkNyYE0IIG5IgLIQQNiRBWAghbEiCsBBC2JAEYSGEsCEJwkIIYUMShK+A48ePExkZafHRuXNnunfvzk033cTkyZMtzglhC0ePHjXX8VJPP/00kZGRLFy48LKfIzc3l/Pnz192OXX5+OOPiYyMZNy4cVYdn5CQQGRkJFFRUZf93IsXLyYyMpLp06dfdll1GTJkCJGRkXz//feN/lyi4Thez2YH161btypLEymKgk6n4/jx42zfvp3t27czZswY5s6da8NaNr5Vq1axePFi1q5dK9NuiiZNgvAV9tZbb9GuXbtq2ysqKnjnnXdYtmwZ8fHxDBw4kCFDhtighrV78skniYmJwc/P77LKWbBgQQPVSAjHJukIO+Hi4sITTzxBz549AYiPj7dxjSxr1aoVHTt2xN/f39ZVEeKqIEHYzgwePBgwTU0phLj6STrCzlQuU3/pasmLFy/mnXfeYdasWXh4ePDuu+9SUFBASEgIS5YsoX379gBkZWWxfPlyfvzxR06fPo2Xlxc9evRgwoQJNc6udubMGZYvX853333HmTNnaNu2LQ888AB9+/a1ePzTTz/N559/zsSJE5k9e3aVfVlZWXz00Ufs2LGDU6dO4e7uzrXXXkt0dDQ33nhjlWupNHLkSAA++ugj87ScAHv27GHVqlUkJSVx/vx5WrRowQ033MCjjz5qvt6/O3z4MO+++y779u2jqKiILl26MHny5Fpfb7Vyc3NZvXo1u3btIisri9LSUnx8fLjmmmu49957GT58eI3n/vXXX7zxxhvmaUc7d+7MAw88wKhRoyweX1RUxKpVq/j222/JzMzEycmJiIgIoqKiuPvuux1yxjBRnQRhO5OZmQlA69atq+3bsmULv//+O23btqVt27aUlJQQHBwMwK5du5g+fTolJSV4eHjQqVMnzp49yw8//MAPP/zAtGnTiI2NrVJeWloa0dHRnDx5End3dzp16kROTg7z5s2jT58+qur9008/MWPGDAoLC/H09CQ8PJwzZ87w448/8uOPPzJv3jxGjx5N69at6dWrF/v27QPgmmuuwd3dHR8fH3NZS5cu5a233gLAz8+PiIgIsrKy2LBhA19//TVvvfVWtdVDtm7dypNPPolOp8PPz4+OHTty5MgRYmJi6N27t6prqcnhw4eJjo4mPz8fT09Pc24/KyvLfJ0zZ85k0qRJ1c5NS0vj3nvvpbi4mE6dOlFSUsK+ffvYt28fv/zyC/Pnz69y/PHjx5k4cSIZGRk4OzsTGhqK0WgkKSmJpKQktmzZwtKlS6vc5BUOShGNLisrS4mIiFAiIiKUrKysGo87d+6ccv311ysRERHKSy+9ZN7+9ttvm8+fN2+eYjQaFUVRlLy8PHP5vXr1UiIiIpQ333xTKS8vN5+7bds2876tW7eatxuNRuW+++5TIiIilIkTJyr5+fmKoiiKwWBQVq5cqURGRpqf81KzZ89WIiIilJdfftm8LS8vT+nXr58SERGhPPfcc0pRUZH5OT744AMlIiJC6dq1a5Vrryw7OTm5SvnffvutEhERofTq1UvZvHmzebtOp1OWLFli3pednW3el5uba77GV199VamoqFAURVGKioqUJ554wvxcDz74YI2v/aU2bNigREREKHfddVeV7XfddZcSERGhPP7440phYaF5e2FhoTJz5kwlIiJC6d27t6LT6cz7Ln3vbrnlFiU1NdW875tvvlG6deumREREKF999ZV5u16vV+68804lIiJCeeyxx5QzZ86Y96WkpCgjRoxQIiIilP/85z9V6jd48GAlIiJC2b59u1XXKeyD5IRtTFEUzp8/z86dO3nkkUc4e/YsPj4+PPzww9WOdXFxYcaMGWg0GgDzzbH333+foqIi7rzzTmbMmFGldTR06FBmzpwJUCUNsHfvXpKSkvD19WXRokU0b94cAK1Wy8SJE/nnP/9p9TV8+umn5Ofn06NHD+Li4vDy8gJMC5NOmDCBQYMGUVFRwddff11nWW+//TYAzzzzDLfddluVa58yZQojRoww/0yvtHbtWoqKiujbty//+te/zHPKenl58fLLL9eYvlDjxIkTZGdn4+7uzosvvmhOG4EphfSvf/0LgMLCQnJycqqdr9FoWLx4MR07djRvGz58uDldsnLlSvP2rVu3cujQITp06MCbb75Jy5YtzfvCw8N588030Wq1rF27lry8vMu+NmFbEoSvsKFDh1YbrHHdddcRExPD/v378fPzY+nSpRbTEREREeYAd6nt27cDcPvtt1t8zttvvx2NRsPh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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.9754082541567697\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>75.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.333333</td>\n",
       "      <td>4.75</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>75.0</td>\n",
       "      <td>40.0</td>\n",
       "      <td>16.0</td>\n",
       "      <td>9.5</td>\n",
       "      <td>6.333333</td>\n",
       "      <td>4.75</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      75.0   40.0   16.0     9.5  6.333333    4.75\n",
       "1       NaN    NaN    NaN     NaN       NaN     NaN\n",
       "mean   75.0   40.0   16.0     9.5  6.333333    4.75"
      ]
     },
     "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
