{
 "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:07<00:00, 2730.16it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_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.9139130434782609"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# clf = RandomForestClassifier(n_estimators=rs.best_params_[\"n_estimators\"], \n",
    "#                              min_samples_split=rs.best_params_[\"min_samples_split\"],\n",
    "#                              min_samples_leaf=rs.best_params_[\"min_samples_leaf\"],\n",
    "#                              max_depth=rs.best_params_[\"max_depth\"], \n",
    "#                              bootstrap=rs.best_params_[\"bootstrap\"],\n",
    "#                              criterion=rs.best_params_[\"criterion\"],\n",
    "#                              random_state=0,\n",
    "#                              n_jobs=1)\n",
    "\n",
    "# Very large numbers of base estimators may take a long time to prepare, but will not overfit the training data.\n",
    "clf = RandomForestClassifier(n_estimators=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": "iVBORw0KGgoAAAANSUhEUgAAAWcAAAE+CAYAAABROdGyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABQ5klEQVR4nO3dd3gU1frA8e/upjcgDUhIgJCEIiAECeo10o2oWLiQKyBVBSnCpVywoXTFCkHEn4CiUbh0EfEKCFIEQUoEhFACIYSSkEYghZTd+f2x7krMpkwgZLO8H599Hpl5Z/YMIe+efeecMxpFURSEEEJYFW11N0AIIURJkpyFEMIKSXIWQggrJMlZCCGskCRnIYSwQnbV3QAhhLhZUVERer1e9XE6nQ47O9tJabZzJUKIGq+oqIg/juxGr7ipPlan09GyZUubSdC2cRVCCJug1+vRK2408X4TB11GhY8r0HtyJm06er1ekrMQQlQVnTYNnS614vGKoQpbUz0kOQshrI4BBQMVn7ysJramkOQshLA6hj//UxNvayQ5CyGsjkFR0KtY9sdgg0sESXIWQlgdA+pKFbbXb5bkLISwQnoUtCqSs15qzkIIUfUUlTcEFUnOQghR9fSKgkZFHVlNfbqmkOQshLA6BtTVkaXmLIQQd4ABRVUd2RbHOcuqdEIIYYWk5yyEsDp6QE1nWP0adtZPkrMQwuoYAI3KeFsjyVkIYXUMaFCTng2qUnnNIMlZCGF1DAqqyhoG27sfKMlZCGF99GhQpOcshBDWxaAyOauJrSkkOQshrI5B0aBRVCRnFbE1hSRnIYTV0QMaVT1n2yPJWQhhdQxoUTdHTmtzM+okOQshrI5B0YCaUoWiUZ2cv/32WyZPnlzq/pdeeolx48aZ/3z06FEWLFjA0aNHyc3NJTg4mIEDB9KzZ0+LxyckJDB//nwOHjzI1atXCQwMJCoqiv79+6PVlt9am07OBoOBnJwc7O3t0WhsryYlhLVSFIXCwkJcXV0rlIj+Tq9ynDNoVCezuLg4AP7xj3/g6elZYn/z5s3N/797926GDx+OwWCgffv2ODs78+uvvzJx4kTi4+OLJXGAEydO0L9/f7KzswkLC6NVq1bs27ePmTNncvjwYd5///1y22fTyTknJ4dTp05VdzOEuGuFhobi7u6u+jiDokVRKp7UNSpiTY4fPw7A22+/Td26dUuNu3HjBv/5z38A+Pzzz7n//vsBOH/+PAMGDODTTz+le/futGzZEjB+ME2aNIns7GzeffddnnrqKQAyMjIYPHgwGzZsoHv37kRGRpbZPptOzvb29gBcdn0HvTazmltTNRpcn8MF99K/mtV0y4d1ru4mVJn/fPAo7034sbqbUSU86jgz/I2O5t9BtYxD6VQk50oMpTtx4gTe3t5lJmaA9evXk56eTq9evcyJGSAwMJCJEycyceJEYmJimDNnDmDsZZ88eZLw8HBzYgbw9PRk6tSp9O3bl5iYmLs7OZtKGXptJnpdejW3purY8rVdTcut7iZUKVu/vsqWE9VOQlGbnJOSkrh27RodO3YsN3bXrl0AdO3atcS+zp07o9Pp2LlzZ4n4bt26lYgPCwvDy8uLgwcPkp2djZubW6nva2s3OIUQNsCgaNGreBlUljVM9WYvLy9mzJhB9+7dadWqFZGRkSxYsID8/Hxz7OnTpwFjiebv3Nzc8PX1JSMjg7S0NADi4+NLjQdo3LgxBoOBM2fOlNlGm+45CyFqJgMalVOyjbHJycnodLpiezw8PPDw8Ci2zVRvXrt2LbVr1yYsLIy6devyxx9/EB0dza5du1i6dClOTk6kpqYC4OPjY/GdfXx8uHz5MmlpaXh7e3PlypVy4wFzMi+NJGchhM3o169fiaQ3evRoXn755WLbTD3nHj16MHv2bFxcXAC4cOECo0aNIjY2lrlz5/LKK6+Ql5cHgJOTk8X3NG3PzTWWqNTGl0aSsxDC6ujR/jkRpWJMNw+XLVtmsef8d9HR0SQlJREYGIiDg4N5e4MGDXjnnXd45plnWLFiBRMmTECn06EoSrn1c4PBuKq06f0rGl8aSc5CCKtjUDTo1dSR/5ywUq9ePRwdHcsNd3R0JDg42OK+5s2bU69ePS5fvsy5c+dwdnbm2rVr5OfnWzz3jRs3AHB1dQXA2dm52Pby4ksjNwSFEFbH8GfPWc3rdvL29gaMJQpfX18Ac+357/5ekzbFl1ZTLq+GbSLJWQhhdfSKRvWrorKzs5kyZQpjxoyhqKjIYsyFCxcAY088JCQEwOLoiuzsbK5cuYKnp6c5oZviTaM2bqYoCmfPnkWn09GkSZMy2ynJWQhhdQxo0at4qek5u7q6smXLFjZt2sT+/ftL7N+xYweZmZmEhobi6+tLREQEAD/99FOJ2G3btqHX64uNlzbFb926tUT8oUOHyMjIoF27dmWOcQZJzkIIK2TAOHa5wi81swk1GqKiogCYMWMGKSkp5n3nz59n+vTpAIwYMQKAyMhIvLy8WLduHTt27DDHJiUl8cEHH6DRaBg8eLB5e3h4OCEhIezevZuVK1eat2dkZDBt2jQAhgwZUm475YagEMLq6NGgr8Lp2yNHjuTAgQMcPHiQRx99lHbt2gGwb98+CgoKGDp0KI899hhgnGgyY8YMxowZw/Dhw2nfvj2urq7s3buXvLw8xo0bR7Nmzczn1mq1zJ49m0GDBjFlyhRWr16Nr68vv/32G1lZWURFRdGlS5dy2yjJWQhhdQwq68halU9CcXJyYunSpSxdupQNGzawb98+HBwcaNOmDQMGDOCRRx4pFt+1a1diYmJYsGABhw8fRlEUmjZtyuDBg+nRo0eJ87du3ZpVq1YRHR3Nvn37OH36NA0bNmT8+PH06dOnQm2U5CyEsDpqR2BUZrSGg4MDw4YNY9iwYRWKDwsLY8mSJRU+f3BwMNHR0arbZSLJWQhhdUxrZlSUthJLhlo7Sc5CCKujqFxbQ56+LYQQd4Be5QxBNfXpmkKSsxDC6pjGL6uJtzWSnIUQVkdRNMaHvKqItzWSnIUQVkd6zpKchRBWyKBoVD3dRE0vu6awvY8bIYSwAdJzFkJYHQMa9CqGx6l7pFXNIMlZCGF1DCof2qr2Aa81gSRnIYTV0avsOauJrSkkOQshrI6isuesSM9ZCCGqnh6VMwSl5yyEEFXPoHJtDbkhKIQQd4BBUTcJRW4ICiHEHWBQVPacbXASiiRnIYTVkenbkpyFEFZIes6SnIUQVsi42L6KoXRyQ1AIIaqeXlE5CUV6zkIIUfWkrCHJWQhhhRRF3dO3ZYagEELcAbK2hiRnIYQVMqDuMVW2OEPQ9r4LCCGEDZCesxDC6hhvCKqYvo0GW+s8S3IWQlgdReXCRzLOWQgh7gDV45yl5yyEEFXPoHIonZrYmkKSsxDC6igqJ6FIWUNUqeRDTnzb1x+3+kU8tz2xxP68DC2x/1eHhC1u5KTocPHVE9pmIyEv21MnqNDiOQ16iFvhwan17mSccqAoX4tr3SICInIJG56Ju39RVV/WXcfLO5e+/eO4LzyZOp555ObaE3fMi9UrmnH8mLfFY1xcC4l69gT/iLiAr28uOTn2nDrpyfp1wcQerHeHr6D6yWL7kpytRlG+hp9f9UUxWP5HdjXBng2D/Mi+bI9Gq+AZWkBhroaD3x/l9y0BdP8ohcbdc4odo8+HjcP8uLjHBQDXukW4+RVwNcGB48trceYHNx5ffIm6bfKr/PruFoENs5jzwXZq1S4gP19L0nkPvLzzuP/By7TvkEz0R+3Y8mPjYse4uhbw4fxtBARep7BQw8UL7ri4FBF+/2XC77/M8q+bE7O0ZTVdUfUwKOoSrqEK21JdJDlbiQPzPbl61sHiPoMeNo2uR/Zle2oHFfDowsvmnnL2+kksf2M1m8fUo8935/EM+asH/ds8Ly7uccG1bhHdPkzGL/wGADeuatn+mi8JW9zYNLo+fbckYu+sVP1F3gUmTP6NWrULOBzrw9szH+BaliNarcJzg47xbP84Ro85xJHffUlJdjUf8++JBwgIvM7JOE9mTX+AtFTjh+n9D17k1Sm/0ve5OI787svh332r67LuOKk5W/EklD179jBw4EA6dOhAWFgYAwYMYOfOndXdrCqResyRw0tqY+dk+fM/YYsrGacc0TkYeOyzS8VKGPd0DKXNsEwMRRp+nfPXV+aifA3HltUCIGJqqjkxAzjVNtD1gxTc/ArJSbHjzP/cqujK7i4BgdcICb2KwQDvvdOBa1mOABgMGr76oiUnT9TB3sFAx87nzcfU8czj/gcvotfDO7PuNydmgL17/PlxYxAAj/RIuLMXU80UxThDsKIv5RYXPrp69SoRERE0bdrU4v6EhATGjx9Px44duffee+nZsycxMTEYDJZ/Z1NSUnjzzTfp2rUrrVu3JjIykgULFlBQUFDhNlllcl67di1DhgwhNjaW1q1b07ZtW2JjY3nxxRdZsWJFdTfvttIXws+v+IIG2o3KtBhz4RfjL2yjbjnUaliyRtyyfxYASbtcyMsw/khT/3CkMEeLzsFAoy45JY6xd1bwvz8PgLRjjrflWu523t7Gv8/r1xzISHcusf/M6ToA+Prmmre5uRWy6X9BbN3SqFhv2iTxnPED1scnt8Q+W2aqOat53Ypp06Zx5coVi/tOnDhB79692bhxI35+fkRERJCcnMzMmTOZNGlSifjk5GSioqJYsWIFHh4edOrUiZycHKKjo3n++ecpLLR8f+jvrK6skZKSwltvvYW7uzvLli0jNDQUgCNHjjBkyBBmzZpFp06dqFu3bjW39PaI/bQO6SccaTcyA89Qy7Xf65eNPyafFpb3O3sacPDQU3BNR+oxJwIjcqnduIDIBZcpyNaiKeUjuCjP+A/aoL/16xCQlmZMyLVqF+DllUf63xJ0YKNrAFy58lfvOOm8Bx/PbVfqOYNDjR/Yly7dXd9uVK+toal8cv7+++/54YcfLO5TFIVJkyaRnZ3Nu+++y1NPPQVARkYGgwcPZsOGDXTv3p3IyEjzMVOnTiU5OZmxY8cycuRIAHJzcxk1ahR79uwhJiaGoUOHltsuq+s5f/PNNxQUFDB48GBzYgZo3bo1L774Ivn5+TbTe04/5cDBhZ7UDiqg3ciMcuMN+tL/ASp/7su+aEzkzp4Ggh7JoVmv6xbjC7I1XNxrTBKewRX7JBdlSzrvwfE/vAAYP/k3PDxMH6YKvf91gpat0sjNtWPrloblnsvJqYg+z56ge2QC+flavl0TWu4xtkRNScP0qoyUlBSmT59O27Zt0el0Jfbv3r2bkydPEh4ebk7MAJ6enkydOhWAmJgY8/azZ8+yfft2AgMDeemll8zbXVxcmDVrFjqdjq+//rpCbbO65Lxr1y4AunXrVmKfaZst1J4Netj+qi+GIug0+wq6MioLHg2MpYyMU5ZvGF6/ZEdhjvFHmZ9VsR/poYWe3MjUoXM00PiRbHWNF6WaMfVBYg/60jbsCkuXbWT+p5v5euUGhr54lPOJ7rwx+WHS01xKPT4kNIOP/28zy1Z9x5AXjpKe5sK0KQ9xLqHWHbyK6nenas6vv/46BQUFzJkzx+L+svJRWFgYXl5eHDx4kOxs4+/QL7/8gqIodO7cGa22+O+in58fLVq04OLFi8THx5fbNqtKzoqiEB8fj1arJSgoqMT+Ro0aodVqiY+PR1Fq9uiCw5/X5soRJ1r2z6J+uxtlxjbsbKwZn93sRma8fYn9sZ/VNv+/vrD8f6Rn/udK7CLjMW1euIqrr9Q1bpfCQh0n4ry4cUOHk5OeJsFZeHoae9Dp6c4UFpb9KxfQ8BpBTbJwcjb+TNzcCmjf4TJ29nfXz8igqO09q3+PZcuWsWvXLiZOnEjDhpa/zZiS6M3f4m/WuHFjDAYDZ86cKRYfEhJiMd6U106dOlVu+6yq5pyVlUVBQQGenp44OJTsJdrZ2VGnTh3S09PJycnBza1m1uGunrPnQLQnbvUL6TAhvdz4wI651GuXR/JBZza+4EfEW6n4P5hHwXUtmxfv5NiyWjjW1pN/VYfWvux/pWc3ufLThHqgaPDrkMt9o8svp4iKcXUt4J0PdtAk+CoHD9Tli0WtOZ9oHOf8dK9TPNUrnnc/+pnXJ3XkRJyXxXMc3F+P3k89jZ2dgXb3JTNsxO8888/T+De4ztTXI+7wFVWfyk5CSU5OLlGe8PDwwMPDo9i2xMRE3nvvPR544AH69+9f6nlNNwl9fHws7jdtT0tLKxbv62t52OPf48tiVck5L894t9vZueSdbhMnJyeAGpucFQV+ftWXohtaHp6ejINb+R/5Gg1Ezk/m+6F+pJ9w5Idhfjft20PYS5lcPevA2U1uOLiVPhw/bpU7O6b4oug1+LS6waMLk9Fa1b+Amq33v07SJPgqCWdrMfX1h9Drjb3klGRX/u+TthQW6uj9r5OMHHOIMSO6WzxH1lUn8///vLUhF5Lc+XD+NsI7JHNvmyt3zVhntXVkU3Lu169ficQ3evRoXn75ZfOf9Xo9kydPRqvVMnv2bDRl3Ew05SRT3vk70/bc3NxKxZfFqn41/16jKYuaskaD65brSdVhz8qDJB/Ywr2RLXi4zStw9a99uTnxwGp0Bi8aXp1S/EB7CPlcz8ENRzn161nycwvwDqhDu56tCLjHj0+HfQ1coKHLcBpeLTlW86dFv7D9s18AaNjanyHz+uCkdyr2/tZo1pfV3YKKa+5r/PvV1O7P9M9L9nJ1mkdQlOEEh1zlva8fpEAPs77sVe55cwpT8dAdYcybXiRfLz/eFigqk7NpbY1ly5ZZ7DnfbPHixcTGxjJz5kz8/Pwoi+lcZSVwwDzeWW18WawqObu4GG+U5OeXPp34xo0bxWIr4oL7ZPS68ssHd8KBHf6AM4c3HefwpuMWY65evsYr7d8BoP/P58w3BAHqDTW+TAKuRnLO4wUuxTcGdOjbziWx9l+jLxQFfpnuzR9f1wYgsGMO3efvJMV5x+2+tCrx2VOPVXcTKuzbH1IA+GjKSU6fTLUY8/UKBzy9bvD1B+uI+vcI3np+NXXr5aDXa0i+bPmb4IjROfR8GmJ3/M7H80qOKLBGtb1d+M8Hj97x961Xrx6OjqXfXT9x4gTz58+nU6dO9OnTp9zzmb7Fm/LO35m2u7q6qoqvSP6yquTs5uaGi4sLmZmZFBUVYWdXvHlFRUVkZmbi6OhY4tOwpvBsml/quOL8LC2Z8caZgD6tjB9Qdo4KWYn2nN/hgrO3nuDHSo6suLzfiYLrOlzrFlG7UfFhcXtm/5WYQ5+6Rud3rkgpo4rk5tjj4JCPp6flX0x7ez21ahv35eYab+z2H3iMf/U7wW976zP1jYcsHuf15+SWv4+btmWVLWuU56OPPqKwsJDCwkImTpxY/Bx/9mZN21977TV8fX2Ji4sjLS2NJk2alDhfaqrxQ9hUSzbVmkurKZviS6tJ38yqfk01Gg3BwcEcOXKEc+fOERwcXGx/QkICBoOh1DunNUHEm6XfCDi3zYX/DffDxUfPM/+9aN5+5agdv8zwwbVuEUGPZJdIrrGLjDPP7umbVWx73Cp3jiytDUCLZ7N4eHoqtzBWX5Tj6BEfIjpe4JFHE9j3a8mvy126JaLTQXa2PQlnagNw5Hdf/tXvBG3bJePrm8OVK8VnCdarn8194ckA7N9Xv8qvwVpUVXI21Xp3795dasyGDRsA+Pe//01ISAg7duwgPj6eDh06FItTFIWzZ8+i0+nMids0SqO0oXKmUR0VyWFWNZQOICLCWKv76aefSuwzbevYseMdbVN182mZT62GBeSk2LFntjf6PzvHRfkavv9oK+d3uOLiU0SrgVfNx9zI1LJ7lvHTvMGDuZKY74BV/21GUZGGB/5xiaEvHsHR6a9y1D8iLvDCS4dvijP+6sUe8jWuuWGv8Ppbv1Lf769vRo0aZzFt1i84OBjY8XMA8X9O/74bKBjHLlf4VcHkHBMTw8mTJy2+TPVi058bNGhgzkdbt24tca5Dhw6RkZFBu3btzIMTTPE///xzibrypUuXiIuLw9/fv0TH05JSe847dtyemqTaRNqrVy8WL17MokWLeOihh2jZ0rhU4tGjR1m8eDFOTk7069fvtrStptBooNuHKXzb15+jMbU5/b077v6FZCXaU3B9P4619TzxxSUc3P+6SXp8pYd5YkrOFR3f9vUv9fyBHXNpN8Lyuh6i4uJP1yH6w/sYM/4Avf91ksd6nuHiBTd8fPKoXcdYptqyqSGr/nvzDVsNb09/gLff30FI00w+++JHLiS5o9EoNAi4jlYLvx/yZd4H91XPRVUTa1nPOTw8nJCQEHbv3s3KlSuJiooCjNO3p02bBsCQIUPM8QEBAURERLBr1y7mzZvHuHHjAGOP/Y033kCv1xeLL0upyXn48OHl3nEsj0aj4fhxyze9StOgQQMmT57M9OnTefbZZ81fJfbt20dRURFz5szBy8vyGFFb5ts6n16rL3BwgSeXfnMm/YQjLr5FtH3kPkLHrsWtfvFCdvKBv+qTmfFlL2xUK1Cmb98uP21uxJn42vyzz0lat0mlUeMsbuTZEXvQlx++b8LuXQ1KHHPliitjRnTjn1GnePChC9T3y6aoUEvccS9+2tyILT82xlDKOt+2SvlzEoqa+KpgGm43aNAgpkyZwurVq/H19eW3334jKyuLqKgounTpUuyYt956i759+/Lpp5+ybds2GjduzKFDh0hNTeXhhx+mb9++FXrvUpNzeUNMqlL//v3x8/Nj8eLFHDp0CAcHB8LCwhgxYgQPPPBAtbWrqjXqksuI06VP6/RuXkDkx8nFtjW8OoXE2qtKxD626PJtb5+omISztXl/TofyA2+Sk+PAV1+05Ksv7q5F9UtjKleoia8qrVu3ZtWqVURHR7Nv3z5Onz5Nw4YNGT9+vMURHwEBAeb4nTt3kpiYSEBAAAMHDmTQoEElBjqUptSobdu2Vf5qboPOnTvTuXPnam2DEKJ6qL4heBuSc1nf8oODg4mOjq7wuerXr8/bb799S+2xqtEaQggB1tVzri6VTs4ZGRns3buXhIQEsrOzmTx5Mvn5+cTGxnL//fffzjYKIe4y1dFztjaqk3NhYSHvv/8+y5cvL7ai/+TJkzl//jxDhgyhefPmLFy40GYWxBdC3GGKypt8NXuRSotUjXM2GAyMGjWKr776iqKiIpo2bUqtWn+tM5uTk4NWq+X48eP07duXzEwZniWEUO9OP6bKGqlKzmvWrGHnzp0EBQXx3Xff8e233xZbd7lNmzb8+OOPhISEcPnyZZYsWXLbGyyEsH2qJqDchge8WiPVyVmj0RAdHV3qDJeAgADmz5+PVqut9hEfQoiayfQMwQq/bLDnrKrmfPr0aYKCgiwuAHKzRo0a0ahRI5KSkm6pcUKIu5OisuZcwx+MZJGq5KzX6yu85rK9vb3FByYKIUR5jMm5+mcIVidVZY2AgAASEhLIyCj70UZpaWnEx8cTEBBwS40TQtyl1Nab7/aac2RkJEVFRbz55pvFhtHdrKCggNdffx29Xm/xibVCCCHKp6qsMWTIEL777ju2bt3K008/TdeuXc2LR2/ZsoUzZ86wbt06EhMTqV+/PoMHD66KNgshbJxMQlGZnF1dXfniiy8YPXo0cXFxnD171rxvzJgxgHEB6oYNG/LJJ5/U2KeVCCGql9wQrMQMQX9/f9asWcOWLVvYunUr8fHx5OTk4OzsTMOGDenUqROPP/44Dg4OVdFeIcRdQNbWqOTaGlqtlsjISCIjI293e4QQQpIzt7gqXUZGBufOnePGjRu4u7sTFBRkfgqtEEJUloK65TJssKpRueT8ww8/sGTJkhLrn2q1Wtq3b8+oUaNo3779bWmgEOLuY3qGoJp4W6M6Ob/xxhusWbMG5c8KvLu7Oy4uLuTk5JCdnc3evXv57bffmDRpkozWEEJUjnSd1SXnDRs2sHr1ahwcHBgxYgS9evUqtizohQsXWLZsGV9++SVz5syhWbNmsrazEEI9tYsZ2WDNWdUklOXLl6PRaPjggw8YMWJEifWaGzRowKRJk5g6dSqKorBo0aLb2lghxN3BNJROzcvWqErOJ06cICAggO7du5cZ16dPH+rXr8/hw4dvqXFCiLuTLBmqMjnb2dnh4uJSodg6deqY69JCCKGKgrFUUeFXdTf49lOVnMPDwzl9+jQJCQllxqWkpHD69GnCwsJuqXFCiLuTlDVUJucJEybg4uLCiBEjiI+PtxiTkpLCqFGjsLOzY8KECbelkUKIu4xSiZeNKXW0xtixYy1ur1evHqdPn+bJJ5+kXbt2NGvWDBcXF/Ly8jh37hz79u2joKCAiIgINm/eTLNmzaqs8UII2yTjnMtIzps2bSrzQIPBwP79+9m/f7/F/Tt37mTXrl3mBZGEEKLCZJxz6cl59OjRd7IdQghhJmtrSHIWQgirdEsLHwkhRJWQskblkrNeryclJYW8vLwSY5mLioooKCjgypUrbNu2jdmzZ9+Whgoh7iaaP19q4m2L6uS8aNEiFi1axPXr1ysUL8lZCKGa9JzVJefNmzfzwQcfVCg2MDCQRx99tFKNEkLc5SQ5q5uEsnLlSgB69uzJjh072Lt3LzqdjqioKI4ePcqWLVsYPnw4Op0Og8HAsGHDqqTRQggbp2rqtkZWpTt+/DjOzs5MnTqVunXrUrt2bYKDg9m9ezf29vYEBAQwbtw4xo4dy8WLF/nyyy+rqt1CCBsm07dVJudr164REBBQ7FFUISEhXLp0iaysLPO2gQMH4uTkxNatW29fS4UQd5cqnrqt1+v56quvePLJJ2nVqhXh4eEMHTqU7du3W4xPSEhg/PjxdOzYkXvvvZeePXsSExODwWCwGJ+SksKbb75J165dad26NZGRkSxYsICCgoIKtU9VcnZxcUGjKf71ISAgAIAzZ86Ytzk5OdGoUSMSExPVnF4IIYzuQFnj1VdfZdasWVy8eJEHHniAe+65h99++43hw4ezYMGCYrEnTpygd+/ebNy4ET8/PyIiIkhOTmbmzJlMmjSpxLmTk5OJiopixYoVeHh40KlTJ3JycoiOjub555+nsLCw3PapuiEYEBBAQkICubm55qVDGzZsiKIoxMXFFVuF7saNGxQVFak5vRBCAKBRjC818Wr88MMPrF+/nsaNG/P111/j7e0NwOnTp+nbty8ff/wxjz/+OI0aNUJRFCZNmkR2djbvvvsuTz31FGB8wPXgwYPZsGED3bt3JzIy0nz+qVOnkpyczNixYxk5ciQAubm5jBo1ij179hATE8PQoUPLbKOqnvNDDz1Ebm4uU6ZMITs7G4BWrVoBsGbNGnN3/ciRI5w7dw5/f381pxdCCKMqXpXuu+++A2DixInmxAzGMm3Pnj0xGAzs3r0bgN27d3Py5EnCw8PNiRnA09OTqVOnAhATE2PefvbsWbZv305gYCAvvfSSebuLiwuzZs1Cp9Px9ddfl9tGVcl54MCB1KlThx9++IGIiAgKCgpo0qQJHTp0IC4ujl69ejFmzBiGDBkCGJO5EEKoVsVljejoaDZs2MDDDz9cYl9OTg4AOp0OgF27dgHQrVu3ErFhYWF4eXlx8OBBc4f1l19+QVEUOnfujFZbPMX6+fnRokULLl68WOqyyyaqkrOXlxeff/45zZs3x8HBAQcHBwBef/11PDw8iI+PZ/PmzeTk5ODn52fuzgshhCpV3HN2cHAgNDTUnMNMfv75Z3788UdcXFzMydiURENDQy2eq3HjxhgMBvN9N1N8SEiIxfigoCAATp06VWYbVc8QbN68OWvXruXy5cvmbaGhoWzcuJE1a9Zw8eJFGjVqRJ8+fXB3d1d7eiGEqPQklOTkZHOP18TDwwMPD49SD71x4waTJk0iPj6eM2fO4Ofnx7vvvmsud1y5cgUAHx8fi8ebtqelpRWL9/X1rVB8aSq98FH9+vWL/dnb25vhw4dX9nRCCPGXSibnfv36lUh6o0eP5uWXXy710EuXLpVYv/7kyZO0b98egLy8PMA4Cs0S0/bc3NxKxZdGVqUTQlghtXVkY+yyZcss9pzLUq9ePfbu3YtWq2XPnj3MmjWLGTNmkJuby7Bhw8zn+/sw4r8zjXdWG1+aUpNz7969yzywIjQaDatWrbrl8wgh7i6VHUpXr149HB0dVb2Xi4uLeWhwjx49qF+/Ps8++yz/93//x6BBg3B2dgaM5Q9LTNtNk/MqGm96z9KUmpz/+OOPMg+siPI+OYQQwtq0adOGwMBAEhMTSUpKwtfXl7i4ONLS0mjSpEmJ+NTUVOCvWrKp1lxaTdkUX1pN2qTU5Pz2229X4DKEEKIKVOGqdIqi8N5773H58mXee+897OxKpkHTKI6ioiJCQkLYsWMH8fHxdOjQocS5zp49i06nMydu0yiN0obKmUZ1lDb6w6TU5PzMM8+UeaAQQtREGo2GrVu3cu7cOZ5++mk6duxYbH9SUhIJCQm4uLjQuHFjIiIiWLx4MVu3bqV///7FYg8dOkRGRgbh4eG4ubkBEBERARiH5U2cOLHYWOdLly4RFxeHv78/wcHBZbbzrrgh+E3nRmRerlPdzagS7+yHhSFl/5Brsk2XVlZ3E6pM7MVe/PCTbV5ffpEPx1Mqv557VU/fjoqK4t1332XmzJk0bdqUevXqAcbFisaPH09RURGDBw/G0dGR8PBwQkJC2L17NytXriQqKgowTt+eNm0agHniHRiXuYiIiGDXrl3MmzePcePGAcbRGW+88QZ6vb5YfGnuiuQshKhhFNSN1lCZnAcOHMi+ffvYsWMHPXr0ICwsDL1ez+HDh8nNzaVjx46MHTsWAK1Wy+zZsxk0aBBTpkxh9erV+Pr68ttvv5GVlUVUVBRdunQpdv633nqLvn378umnn7Jt2zYaN27MoUOHSE1N5eGHH6Zv377ltlGSsxDC+lTxk1Ds7e1ZuHAhy5YtY+3atezfvx+tVktoaCi9evUiKiqqWDmidevWrFq1iujoaPbt28fp06dp2LAh48ePp0+fPiXOHxAQYI7fuXMniYmJBAQEMHDgQAYNGmSxzv13kpyFENbnDjymSqfTMWDAAAYMGFCh+ODgYKKjoyt8/vr169/SwApJzkIIq1PVNeeaQJKzEMI62WDCVUOSsxDC+sjTtyufnPV6PceOHePs2bNkZ2fz3HPPUVhYyOXLlwkMDLydbRRC3GWkrFHJ5PzVV1/x2WefkZ6ebt723HPPkZSUxBNPPEG3bt2YPXu2eVC2EEKoonYB/Uo8Q9DaqU7Or7/+OmvXrkVRFGrVqkVBQYF5IY+0tDQMBgNbtmwhKSmJZcuWmRcBEUKICpOyhronoWzatIk1a9bg4+PDokWL2LdvH82bNzfvDw8PJyYmBh8fH06cOMGXX3552xsshLB9prKGmpetUZWcly9fjkajYd68eeb543/Xvn17FixYgKIo/O9//7stjRRC3GWq+DFVNYGqssbx48cJCAigbdu2Zca1atWKhg0bkpiYeEuNE0LcpdT2hm0wOavqOefn55e7QLSJ3AwUQtySu7jXDCqTc/369UlISCj32VfZ2dnEx8ebV3oSQgihjqrk3LlzZ/Lz83nnnXfKjJs9ezYFBQUl1kkVQogKkZqzuprziy++yPr161m1ahXnz5+nR48eZGVlAcZ69JkzZ1i5ciUHDhzAw8ODoUOHVkmjhRC2TSahqEzOnp6eLFq0iFGjRrF371727dtn3vfPf/4TMD62pU6dOsyfP5+6deve3tYKIcRdQvUklHvuuYfvv/+eFStWsG3bNuLj48nJycHZ2ZmGDRvSqVMn+vXrh6enZ1W0VwhxN5BJKJWbvu3m5sbzzz/P888/f7vbI4QQUtZAVqUTQlgj6TmrS87ffvut6jd4+umnVR8jhLjLSXJWl5xfeeUVNJqKrf6kKAoajUaSsxBCNSlrqEzOLVq0KDU537hxg7S0NLKystBoNDzxxBNyU1AIUXk2mHDVUJWc165dW27MgQMHeOWVV/jjjz9YvXp1pRsmhLh7Sc9Z5QzBirjvvvuYN28e586dY8GCBbf79EKIu4HMELz9yRmMY6GDgoLYvHlzVZxeCGHrJDlX3VA6nU5HampqVZ1eCGHDpKxRRT3nQ4cOER8fj7e3d1WcXghh66TnrK7n/M0335S5v6CggISEBDZs2ABA165dK98yIcTdS8Y5q0vOM2bMqNA4Z0VRCAwMZOTIkZVumBDi7iVlDZXJuX379mWfzM4ODw8P2rZtS+/eveVpKEKIyrPBhKuGquQcExNTVe0QQghxE1U3BIcOHcorr7zCtWvXqqo9QghhLmuoedkaVT3nw4cP4+bmhoeHR1W1Rwgh5IYglRjnXKtWrapohxBC/EWSs7qyxpNPPsnp06fZunVrVbVHCCEA0Kh42SJVPecnn3ySuLg4Ro8eTZs2bWjTpg2+vr44ODiUekz//v1vuZFCiLvMHeg56/V6li9fzrp16zh79ix6vZ6AgAAee+wxXnjhBRwdHYvFHz16lAULFnD06FFyc3MJDg5m4MCB9OzZ0+L5ExISmD9/PgcPHuTq1asEBgYSFRVF//790WrL7xerSs59+/ZFo9GgKAqxsbH8/vvv5R4jyVkIoVZVj3PW6/WMHDmS7du34+Liwr333oudnR2HDx8mOjqaHTt28OWXX+Ls7AzA7t27GT58OAaDgfbt2+Ps7Myvv/7KxIkTiY+PZ9y4ccXOf+LECfr37092djZhYWG0atWKffv2MXPmTA4fPsz7779fbhtv6zhnIYS4Laq457xq1Sq2b99O06ZNWbRoEXXr1gUgIyODkSNHEhsbyyeffMKECRO4ceMG//nPfwD4/PPPuf/++wE4f/48AwYM4NNPP6V79+60bNnS2BRFYdKkSWRnZ/Puu+/y1FNPmc89ePBgNmzYQPfu3YmMjCyzjaUm50uXLuHo6IiXl5d5m4xzFkLcEVWcnNetWwfAa6+9Zk7MAJ6enkydOpWnnnqKjRs3MmHCBNavX096ejq9evUyJ2aAwMBAJk6cyMSJE4mJiWHOnDmAsZd98uRJwsPDzYn55nP37duXmJiYcpNzqYWPLl26MHbsWHVXLIQQt4EGleOcVZ6/Tp06BAUF0bp16xL7GjVqBMCVK1cA2LVrF2B5raDOnTuj0+nYuXOneZspvlu3biXiw8LC8PLy4uDBg2RnZ5fZxjKr0opig+NThBDWr4pXpfv000/53//+h4uLS4l9R48eBaBevXoAnD59GoDQ0NASsW5ubvj6+pKRkUFaWhoA8fHxpcYDNG7cGIPBwJkzZ8psY5Wt5yyEEJVV2RuCycnJ6HS6Yvs8PDwqPHFOURTmzZsHwCOPPAJgXpfex8fH4jE+Pj5cvnyZtLQ0vL29zT3usuIBczIvjSRnIYT1qWTNuV+/fiWS3ujRo3n55ZcrdJoPP/yQ/fv34+3tzQsvvABAXl4eAE5OThaPMW3Pzc2tVHxpJDnXABqNwtwN8dRvlE/Un3eELQlulUvUqCu07JCDRx09V9Ps+O0nD77+sC4ZV+zvYItt37UMHX1atiozpu/YZAZPTjb/eXiXppw74XxTxDtAG/Of7mmfzYfr44udo6gQNnzpzU8rPUmKd8LFXU9wqzz+OfwKbSPKrlnWZJXtOS9btsxiz7ki5s2bx2effYaDgwNz587F09MTMD7VSVGUcpdLNhgM5nigwvGlKTM5p6en8+2335Z5gvI8/fTTt3S8gMGTk2kWlktWhq7UmMi+6YydcwGdHaSn2JEU70hAcD6PD0zn/sgsxj8VTPJ5x1KPF+ok/JlkPeoUERB8w2KMb4MC8/8XFcKFM47o7BSatc0BILugGW4OJ8wxjVsUP09+noY3BgRxZI87APUb5ePsYuDgdnf2b/PgX6NTGPra5dt6XVajkj3nevXqlZg8Up6ioiKmT5/OihUrcHR0ZP78+cWGDTs7O3Pt2jXy8/MtnvvGDePPzdXV1Rx/8/by4ktTZnJOTEzk1VdfLfMEZdFoNJKcb4nCcxNSeHbMlTKjglvlMvbdC2g08Ombfny7xBtF0eBZt5Api87R4r5c/v3eBV75V5M71G7bl3Dc+NW009OZjJp1sdz486edKCrU0qhZnrl3HHtxJm39ny31mM+m+3NkjzvOrnpeXZhIh27X/jyXI28ODGLFx3WpF1jAY8+l34YrsjJ3aG2NnJwcxo4dy65du/Dw8OCTTz4pMZ/D19eXa9eukZqaSoMGDUqc4+81aV9fX+Li4khLS6NJk5K/c+XVsE3KTM4ODg7FxjmLO6eOTyFj5lzgwUfLX5512JuX0Ongv/N9Wbf4rx94Roo9c0YH8sWeE7SNyMbXv4ArF0ufai8qztRzbtjUcu/o70zljIahFYvPuGLHj8uMX6tffueCOTEDBIbkM/7D8/znnyEsfac+XXpl4ORiWyOr7sSTULKyshgyZAjHjh2jfv36fPbZZxZHWISEhBAfH8+ZM2dKJOfs7GyuXLmCp6en+ZmpISEh7Nixg/j4eDp06FAsXlEUzp49i06ns5i4b1Zmcm7ZsmW5zw28E9auXcurr77KN998w3333VfdzalyYR2v88Zn53B1N5CeYse3S7x5/rVki7H22nRaPJBDznUt/432LbE/+bwj//eWHwYFiopsdYmYO+/cCWPPuaLJOSFOXfzh3W4UFWrxrFtI52cyS+xv/UAODZvmkXjSmYM7PPhHj6wKtlyA8Xmnw4YN49ixYwQHB7NkyRLz0Lm/i4iI4H//+x8//fQTHTt2LLZv27Zt6PX6YtsjIiJYvHgxW7duLbF8xaFDh8jIyCA8PLzcJ0VVydO3b6fY2FhmzJhR3c24oxqG3MDZ1cBPq+owvEtTThwsvTbl7ngMrdb4y5yXY7km/e0SH7773IeMFLkpeDsoyk3JuYI94YQ4dT1t0zecoBZ5lLZGjn/jfABOxpYcq2sTqvDJ29HR0fz+++/Ur1+fmJiYUhMzQGRkJF5eXqxbt44dO3aYtyclJfHBBx+g0WgYPHiweXt4eDghISHs3r2blStXmrdnZGQwbdo0AIYMGVJuG616tMamTZt49dVXyx1yYmtO/u7CqMhQzh5zLjfWyT4JMNY0Adp3uUbEE1fx9S/karodu3+oxa7va2G7CyveeZcTHbiRq8PTt5CraXas+sSXM384g8aYTHv0S8c/qKDYMaaecx3vIlYt9OGPfW6kZS4ntGkDOj19lXsftDzyQl/Gtx3TN6GUC7ZXqtIoChoVk+DUxGZmZpqXovD09GT27Nmlxr7//vu4ubkxY8YMxowZw/Dhw2nfvj2urq7s3buXvLw8xo0bR7NmzczHaLVaZs+ezaBBg5gyZQqrV6/G19eX3377jaysLKKioujSpUu57bTK5JycnMyHH37I+vXrcXZ2xtvbu9wB27bk+IGy7+LezEFnvBmUe13Lm0sS+EeP4jXqzk9f5bet7swc1oj8PKv/olQjnPuzF5xzTcfwLs0w6P9KoAe3e7BukQ8jZ17k8QHGn012lo60y8YE+nr/oJu+4SQSv9+bH7725pF/pfPv95LQ/fkbWS/QmNwTTzlhMGCx95z05wdydlbpo3hqrCq8Ibh//37ziIljx45x7NixUmNNq8d17dqVmJgYFixYwOHDh1EUhaZNmzJ48GB69OhR4rjWrVuzatUqoqOj2bdvH6dPn6Zhw4aMHz+ePn36VKidVpmc586dy/r162nZsiWzZ89m5syZd1VyVkOrNQ547zU8FTcPPUtm12PTck9u5OoI73qN0W9fILzrdUbPvsAH4wKrubW24eyfveD8G1oeH5jGMy+kUi+wgCsX7Fn9f778EOPN/Fca4FWvkPu7XzP3mgFC2+QyaNJlglvmse/UItL2vcoX79Rn8wovPOroefHNSwC0feg6Dk4GMlLs2bTckx79M4q1YeeGWlxONA7rKiq0vW9FVXlD8JFHHuHkyZOq2xQWFsaSJUsqHB8cHEx0dLTq9zEpNTmPHj2a+vXrV/rEtyIoKIg5c+bw5JNPVmhR6ruZlkIAanvpWTKrPisX/HVTcNf3tcnO0vHOirN065PJygW+JMVbnrUkKi64VR6PDUijUdMbPDX0r06Df1ABY+dcwM5O4bsvfFg03Y/7u1/DvbaeZ168gkGvYfi0i5jmSLh7u/HwsFR8/AuY+WJj1i324annU/H1L8TDU0+vYVf4b3Q9Fk5pQGGBls7PZGJnr7Dnx1oseL0B7nWKuJ5ph87OtkZqAPKYKspJztVl2LBh1fbeNY0B49fl3Gwtaz/zLrE/dpc7J2Odado2jw7dr0lyvg3u736N+7uXPsTx2TEpfPeFDxfOOHHxrAONmt3gpWmXSo2PeDyLBkE3uHDWiQPb3Xnsz17ywInJXLngwLa1nix4vQELXv9rGFe7jtdo81A2S2b54eKuv30XZy3UPlH7bkrOombQG4x36pPiHSkqtPwtI/GUE03b5lEvoMDifnF7edUtorZ3IVfT7Em54FDi5qAlQffkceGsE1duurmns4PJH5+n8zOZbF9fh/Rkezx9C3mwRxYPPZbFV+8ZRxh4+RZV2bVUG+k53x3JefJ3I6q7CbfEzeE4MAPXWs68s/+VYvtuFK0FoEGL+iX2mQTW/j9gOx16t6dB90FV3NrbK7b8yXfVQl+kR6PRoNVZ/kAs1EcDuSRkvYnmYiAGg4JBb8DOvvjNu9iL/wUgM+9b4ASpeb2JvfhQsRj7ZtC9WbFN/H4JDh1YBZxBW3cAsRfb3JbrshZ3YhKKtbsrkvOcJxeSebnmDtJv/UA2762BnKw8Xmn/TrF9C44Y7xTris7xZsRsCm6UTBbvr43H635YM+cI3y55p8R+a7bp0u/V3YQS+rdrQdplB15ZcI7Oz1wtsT892Y6cTOMCVV0ffJWFUxqwc0NtHu2bzth3L5jjYi/+1zx9++OzzQAnOrSLoa3/x+TlaNm6pg55OVr6jEgt8R43cjWcO9QS0PHEYx/i729d34ryi3w4njL/1k5igwlXDbnbVsNdz2/J1XQdTi4GHutfco2FoBZ53BOeg8EAe36sVQ0ttD2miSQ/rfa0uH/1/xlvyrZ+IJvaXnqCmudh0Gv4dVMtcq6V/JXbu9mDC2edcHHT067TdQAcHA18PtuPxTP8OX+65GI7333hw41cHW0eul6hsklNo+opKGrr0zWEJOcaT8dX7xprj0Nfu/znVF/jv1Rf/wL+M+88Wi1sW1NH1tW4TXq/ZFyI6sDPHnw+uz6FBcahbHo9rFrow7rPfNDqFJ5/3XgT8NF+6bjVLiIz1Z63RzbiatpfX1gPbHfnvX8bhzj2G5eMq/ufy07awUOPXQVg7n8CyEo3lkMUBbatrcNX79VDq1MYNMmWV6VTVLyqu8G3311R1rB1G2O8CAzN5+nn03hlwXmef/0yV9PtaNwsDzt7OBnrzMI3/aq7mTYj7OFsBr9yiaXv+LHi47p8/5U3fo3yuXLBgawM49C2cR+cp1mYcWZrLS89ry08x/TnG7N/mwfPtW9Bgyb5ZF1dSMYl4+I3jw1Io/dLxcsXw966xJFf3Tj2mxsDwlsQ0CSfq+l2pF12QKtVmDD3PC3us83Zs1JzluRsIzQsnOLPoR3uPDk0lab35hHQJJ+keCe2ra3Dt0u8LdaiReX1HXOF5u1yWbfIh7gDriTEOVHLq4jOz2TQZ+QVmtxTfA2Ndh2z+WTLSVYuqMuhHe4knXbEwSWfsIev0XNQOg9aWLjIrZaeud+f4psP67F3cy0STjjj6q7nHz2u0mek8f1tlozWkORcExz51Y1Iv3vLjdv3kwf7fqrYUx/ErWvzj2za/KPiTyPxb1zAuPeTzH+++YZgaWp76Rk162KF1oy2JRqD8aUm3tZIchZCWB/pOdeM5GxaQUoIcXfQoLLmXGUtqT5SiBRCCCtUI3rOQoi7jGmInJp4GyPJWQhhdWQonSRnIYQ1khuCkpyFENZHes6SnIUQ1khqzpKchRBWSBbbl+QshLBCUnOW5CyEsD4yCUWSsxDCGhkU40tNvI2R5CyEsD5S1pDkLISwPjKUTpKzEMIayVA6Sc5CCOsjPWdJzkIIayQ1Z0nOQgjro0FBo6JUobHB7CzJWQhhfQx/vtTE2xhZbF8IIayQ9JyFEFZHo6gsa8hoDSGEuAPkhqAkZyGEFZJxzlJzFkJYH9M4ZzWvW7V27VqaNm3KgQMHLO5PSEhg/PjxdOzYkXvvvZeePXsSExODwWD5bmRKSgpvvvkmXbt2pXXr1kRGRrJgwQIKCgoq1B5JzkII66PwV++5Qq9be7vY2FhmzJhR6v4TJ07Qu3dvNm7ciJ+fHxERESQnJzNz5kwmTZpUIj45OZmoqChWrFiBh4cHnTp1Iicnh+joaJ5//nkKCwvLbZOUNYQQVkejgEbF8Lhb6Tlv2rSJV199ldzcXIv7FUVh0qRJZGdn8+677/LUU08BkJGRweDBg9mwYQPdu3cnMjLSfMzUqVNJTk5m7NixjBw5EoDc3FxGjRrFnj17iImJYejQoWW2S3rOQgjro6rXrLI+/afk5GQmTZrEmDFjMBgMeHt7W4zbvXs3J0+eJDw83JyYATw9PZk6dSoAMTEx5u1nz55l+/btBAYG8tJLL5m3u7i4MGvWLHQ6HV9//XW57ZPkLISwPkolXirNnTuX9evX07JlS1asWEFQUJDFuF27dgHQrVu3EvvCwsLw8vLi4MGDZGdnA/DLL7+gKAqdO3dGqy2eYv38/GjRogUXL14kPj6+zPZJchZCWJ8/xzlX9FWZnnNQUBBz5sxh1apVNG3atNQ4UxINDQ21uL9x48YYDAbOnDlTLD4kJKTU9wU4depUme2TmrMQwvrcgaF0w4YNq1DclStXAPDx8bG437Q9LS2tWLyvr2+F4ksjyVkIYX0qubZGcnIyOp2u2C4PDw88PDwq3ZS8vDwAnJycLO43bTfdUFQbXxpJzkIIq1PZVen69etXokc6evRoXn755Uq3xZTsNZqyHyNrGu+sNr40kpyFENankmWNZcuWWew53wpnZ2cAbty4YXG/aburq6uqeBcXlzLfV5KzEML6VDI516tXD0dHx9vaFF9fX+Li4khLS6NJkyYl9qempgJ/1ZJNtebSasqm+NJq0iYyWkMIYX0MlXhVEdOoC0tD3xRF4ezZs+h0OnPiLiseMI/qKG30h4kkZyGE1VEzjE7t8qJqRUREALB169YS+w4dOkRGRgbt2rXDzc2tWPzPP/9coq586dIl4uLi8Pf3Jzg4uMz3leQshBBlCA8PJyQkhN27d7Ny5Urz9oyMDKZNmwbAkCFDzNsDAgKIiIjg7NmzzJs3z7w9NzeXN954A71eXyy+NFJzFkJYH9PCR2riq4hWq2X27NkMGjSIKVOmsHr1anx9ffntt9/IysoiKiqKLl26FDvmrbfeom/fvnz66ads27aNxo0bc+jQIVJTU3n44Yfp27dv+e9bVRckhBCVdgfW1lCjdevWrFq1isjISBITE9m9ezd+fn5MmzbNvL7GzQICAli1ahW9evUiIyOD7du3U6tWLSZMmMDHH3+MnV35/WLpOQshrJDahHvryfnmxYssCQ4OJjo6usLnq1+/Pm+//Xal2yPJWQhhfeTp25KchRDWRx7wKslZCGGN5BmCkpyFEFbIoBhfauJtjCRnIYT1kZ6zJGchhDW686M1rI0kZyGE9bGiSSjVxaaTs/LnD9fD172aW1K16tSvVd1NqDL5RZafPmErbPX6CvSewF+/g6pJzdm2k3NhYSEAIxY/V80tqVqTvxtR3U2oMsdTqrsFVet4yvzqbkKVKiwsLPWJIGVSDMaXmngbY9PJ2dXVldDQUOzt7ct9KoEQ4vZRFIXCwkLzAvSVOIHcEKzuBlQlrVaLu7ttlzSEsFaV6jGbSFnDtpOzEKKmktEakpyFENZHyhqSnIUQVkiG0sl6zkIIYY2k5yyEsD4Gg/GlJt7GSHIWQlgfqTlLchZCWCFJzlJzrqn27NnDwIED6dChA2FhYQwYMICdO3dWd7OESmvXrqVp06YcOHCguptiXRTlr7HOFXlJchbWYO3atQwZMoTY2Fhat25N27ZtiY2N5cUXX2TFihXV3TxRQbGxscyYMaO6m2GVFMWg+mVrpKxRw6SkpPDWW2/h7u7OsmXLCA0NBeDIkSMMGTKEWbNm0alTJ+rWrVvNLRVl2bRpE6+++iq5ubnV3RTrZEDlDMEqa0m1kZ5zDfPNN99QUFDA4MGDzYkZjI9uf/HFF8nPz5fesxVLTk5m0qRJjBkzBoPBgLe3d3U3yTqZas5qXjZGknMNs2vXLgC6detWYp9pm9SerdfcuXNZv349LVu2ZMWKFQQFBVV3k6yTaSidmpeNkbJGDaIoCvHx8Wi1Wou/1I0aNUKr1RIfH4+iKLISnxUKCgpizpw5PPnkk2i10jcqlYzWkORck2RlZVFQUICnpycODg4l9tvZ2VGnTh3S09PJycnBzc2tGlopyjJs2LDqbkKNoCgGFBW9YVu8ISgf3TVIXl4eAM7OzqXGmJZpzMnJuSNtEqJKSM1Zes41iZqvwZV+PJAQ1kBGa0hyrklcXFwAyM/PLzXmxo0bxWKFqJHkMVWSnGsSNzc3XFxcyMzMpKioCDu74j++oqIiMjMzcXR0xMPDo5paKcStUwwKioqes5rYmkJqzjWIRqMhODgYvV7PuXPnSuxPSEjAYDAUG/8sRM1k+Kv3XJGXDdY1JDnXMBEREQD89NNPJfaZtnXs2PGOtkmI2+7PnnNFX7b4DEFJzjVMr169cHR0ZNGiRfzxxx/m7UePHmXx4sU4OTnRr1+/amyhEOJ2kJpzDdOgQQMmT57M9OnTefbZZ+nQoQMA+/bto6ioiDlz5uDl5VXNrRTi1nj4uKkaHufhY3tj+iU510D9+/fHz8+PxYsXc+jQIRwcHAgLC2PEiBE88MAD1d08ISpNp9Oh0+kYsfi5Sh9rKzSKDIgVQliRoqIi9Hq96uN0Ol2JEUw1mSRnIYSwQnJDUAghrJAkZyGEsEKSnIUQwgpJchZCCCskyVkIIayQJGchhLBCkpzvgAsXLtC0aVOLr2bNmtG6dWsefvhhRowYYXHNjOpw6tQpcxtv9sorr9C0aVPmzJlzy++RlpbGtWvXbvk85fn6669p2rQpAwYMqFD82rVradq0Kb169brl954/fz5NmzZlzJgxt3yu8nTp0oWmTZvy888/V/l7iapnOyO2a4iWLVsWe8SUoigUFBRw4cIFtm3bxrZt2+jXrx9vvfVWNbay6i1dupT58+ezfPlyWd5UCAskOd9h8+bNo0GDBiW2FxYW8vHHH/Ppp5+ybNkyIiIi6NKlSzW0sGzjx4/nxRdfpE6dOrd0nrfffvs2tUgI2yRlDSthb2/PuHHjaNu2LQDLli2r5hZZ5uvrS5MmTfD09Kzupghh0yQ5W5nOnTsDxiVAhRB3LylrWBk3N+PShzc/PXv+/Pl8/PHHTJo0CWdnZxYuXEhWVhaBgYEsWLCAhg0bApCUlMSiRYv45ZdfuHLlCq6urrRp04bBgweXulpdamoqixYtYuvWraSmpuLv70/fvn0JDw+3GP/KK6+wbt06hg4dyuTJk4vtS0pK4quvvmLHjh0kJyfj5OREq1atGDJkCA899FCxazHp2bMnAF999ZV5+VOA/fv3s3TpUmJjY7l27RpeXl784x//YPjw4ebr/bu4uDgWLlzIoUOHyM7Opnnz5owYMaLMv2+10tLSiImJYdeuXSQlJZGXl4e7uzstWrQgKiqKyMjIUo89e/YsH374oXl512bNmtG3b1+efPJJi/HZ2dksXbqUTZs2cf78eXQ6HaGhofTq1Yt//vOfNrUCmyhJkrOVOX/+PAD169cvsW/z5s38/vvv+Pv74+/vT25uLgEBAQDs2rWLMWPGkJubi7OzMyEhIWRkZLB9+3a2b9/Oyy+/zOjRo4udLyEhgSFDhnD58mWcnJwICQkhJSWFWbNmcd9996lq9+7duxk7dizXr1/HxcWF4OBgUlNT+eWXX/jll1+YNWsWvXv3pn79+oSFhXHo0CEAWrRogZOTE+7u7uZzffLJJ8ybNw+AOnXqEBoaSlJSEmvWrOGHH35g3rx5JZ72smXLFsaPH09BQQF16tShSZMmnDhxghdffJF27dqpupbSxMXFMWTIEDIzM3FxcTHfO0hKSjJf54QJExg2bFiJYxMSEoiKiiInJ4eQkBByc3M5dOgQhw4dYu/evcyePbtY/IULFxg6dCiJiYnY2dnRqFEjDAYDsbGxxMbGsnnzZj755JNiN5eFjVFElUtKSlJCQ0OV0NBQJSkpqdS4q1evKvfff78SGhqqzJgxw7w9OjrafPysWbMUg8GgKIqipKenm88fFhamhIaGKnPnzlXy8/PNx/7000/mfVu2bDFvNxgMyr/+9S8lNDRUGTp0qJKZmakoiqLo9XplyZIlStOmTc3vebPJkycroaGhyjvvvGPelp6ernTo0EEJDQ1V3njjDSU7O9v8Hl988YUSGhqq3HPPPcWu3XTukydPFjv/pk2blNDQUCUsLEzZuHGjeXtBQYGyYMEC876LFy+a96WlpZmv8b333lMKCwsVRVGU7OxsZdy4ceb3eu6550r9u7/ZmjVrlNDQUOWZZ54ptv2ZZ55RQkNDlX//+9/K9evXzduvX7+uTJgwQQkNDVXatWunFBQUmPfd/LPr3r27Eh8fb973448/Ki1btlRCQ0OV77//3ry9qKhIefrpp5XQ0FDlpZdeUlJTU837Tp8+rfTo0UMJDQ1VZs6cWax9nTt3VkJDQ5Vt27ZV6DqFdZOaczVTFIVr166xc+dOXnjhBTIyMnB3d+f5558vEWtvb8/YsWPRaDQA5ptyn3/+OdnZ2Tz99NOMHTu2WG+qa9euTJgwAaBYOeHAgQPExsbi4eHBRx99RO3atQHQarUMHTqUp556qsLXsHLlSjIzM2nTpg3Tp0/H1dUVMD6QdvDgwXTq1InCwkJ++OGHcs8VHR0NwGuvvcZjjz1W7NpHjhxJjx49zF/3TZYvX052djbh4eFMnDjRvKavq6sr77zzTqllEDUuXbrExYsXcXJyYtq0aebyExhLURMnTgTg+vXrpKSklDheo9Ewf/58mjRpYt4WGRlpLrssWbLEvH3Lli0cP36cxo0bM3fuXLy9vc37goODmTt3LlqtluXLl5Oenn7L1yaskyTnO6xr164lJqG0b9+eF198kSNHjlCnTh0++eQTi2WN0NBQc+K72bZt2wB4/PHHLb7n448/jkajIS4ujtTUVMBYBgHjw2AtjTPu3bt3ha9p+/btADzzzDPmD46bTZs2jZ9++okXXnihzPOcP3+e06dPo9VqiyXmmz3xxBMA7Ny507ztl19+AbBYu3VwcCi1pquGn58f+/btY9++fRb/vpycnMz/f+PGjRL727VrV2JCD8A///lPAI4dO2ZOtFu3bgWgW7duODo6ljgmNDSU0NBQCgsL2bt3b+UuSFg9qTnfYX+fhKLVanFxcaFu3bq0bduWHj164OLiYvFYHx+fEtuys7O5fPkyAB999BELFy60eKxOp6OoqIiEhAR8fHw4d+4cYOyJWWIpkZQmKSkJgJCQEIv769WrV6HzxMfHA3/13i0xJb7ExEQURUGj0Ziv5eZe6c2aNWtWofevCCcnJ86cOcORI0dITEwkKSmJ06dPm9sOYDAYShzXvHlzi+erW7cu7u7uXL9+nYSEBLy8vDhz5gwAP/74IwcPHrR4XHJyMmCsZQvbJMn5DittEkpFWOpF3Tyq4/jx4+We4/r164AxqQM4OztbjHN3d0ej0aBU4EE5V69eBbDYq1fD1KaioiLzDcPSGAwGcnJycHNzMx9X2ofazTcbb8XJkyeZPXt2id6qv78/vXr1YtWqVaUeW1rbTPuuX79u/uAxXU9SUpL5g680pp+nsD2SnGu4m5Prr7/+WuHJIaav5rm5uRb35+fnVygxg7E3mZ2dXeq5KsqUwEJCQvj+++8rfJyHhwfp6enFPqhuZqnMoFZqaioDBw7k6tWrNGvWjN69e9O8eXOaNGlCnTp1KCgoKDM5l/V3Y2q36Wdi+pnOmzePRx999JbbLmomqTnXcB4eHuaEfPbsWYsxer2ePXv2kJiYaH5wZuPGjQHj8DBLTF+tK6JRo0ZlHvPzzz/Tv3//YjckLTHduLtw4QIFBQUWY9LS0jhw4ECxm26mazlx4oTFY0r7e1FjzZo1XL16lSZNmrBixQoGDBjAfffdZ57Gbukm4M1MpZe/S0pKIjs7G61WS1BQEPDX30NZ7Y6NjeXUqVO35YNHWCdJzjbANOb3v//9r8X9GzZsYMiQITz99NPmHlzXrl0B4401S4ll3bp1FX5/0wST9evXl/r+Bw4cICsry7zNdOPw5t55cHAw/v7+5OXllXquDz74gP79+zNu3DjzNtO1rFmzpkS912AwlHouNS5evAhAUFBQsZt/JqtXrzb/v6UnR+/bt898b+Bmy5cvB+C+++4zjwDp1KkTAN9++y35+fkljklKSuK5556jZ8+exMbGqr8YUSNIcrYBL7zwAo6OjmzYsIGPPvqo2C/0rl27mD59OgB9+vQx119btmxJ586dycvLY/To0eYbTACrVq1StbZH//798fDwYP/+/cyePdv8/oqiEBMTw8aNG7G3t6d///7mY0wljEuXLpm3aTQaRo4cCcDs2bPZuHGjeV9RURGLFy9m7dq1AMVuGEZFRVG3bl2OHTvGlClTzL3J/Px8pk6dWuq3AzVM3w52797NkSNHzNvz8vL47LPPWLRokXmbpYRaUFDA6NGji30Qrlq1iqVLl6LRaBg1apR5+xNPPEGjRo1ITEzk5ZdfNo+wAWMPfOTIkRQVFdG8efNSZ36Kmk9qzjYgODiYOXPmMGnSJD799FNiYmJo3LgxmZmZ5h7fgw8+aB6LazJjxgyGDh3KkSNH6NatG6GhoWRkZHD58mU6d+5c4XWBfX19+fDDD3n55Zf58ssvWbt2LQ0bNuTy5cukp6ej0+mYPn26OcGBcTTIoUOHGD9+PEFBQYwbN46HHnqI3r17c/r0aZYuXcr48eN5++23qVu3LhcuXDDfeBw1ahTdunUzn8vNzY2PPvqI4cOHs3r1ajZv3kzDhg1JTEzk2rVrqq6lNH369OGbb77h4sWLREVF0ahRI5ycnEhMTCQ3Nxd/f3+0Wi1JSUlcuXKlxPERERHs37+frl27EhISQmZmprknPWnSJO6//35zrIODAwsWLOD5559nx44ddOrUieDgYAoLCzl37hx6vZ569erxySef3NI1CesmPWcb0aNHD7799lt69+5N7dq1OXnyJJmZmbRq1YrXXnuNzz77rMRUXx8fH5YtW8aoUaPw9/cnPj4erVbL6NGjef/991W9f0REBOvXr6d37964ublx8uRJ9Ho93bp1Y/ny5SUWrp89ezYdOnRAURTOnTtHYmKied+rr77KkiVL6NKlCwaDwVxLfuihh/jkk08sLlzfrl071q5dS69evXBxceHUqVP4+/vz/vvv069fP1XXYomHhwerV69mwIABNGrUiIsXL5KYmEjDhg0ZPXo069evp0ePHgAWPwjuueceli9fTocOHTh37hzXrl3jwQcf5IsvvrA44Sg4OJj169czYsQIgoKCOHfuHOfPnycwMJChQ4eybt06/Pz8bvm6hPXSKBW9JS+EEOKOkZ6zEEJYIUnOQghhhSQ5CyGEFZLkLIQQVkiSsxBCWCFJzkIIYYUkOQshhBWS5CyEEFZIkrMQQlghSc5CCGGFJDkLIYQV+n8BlkLZCnHUtAAAAABJRU5ErkJggg==\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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eODr62tpa/ny5SxduhSAgIAAIiIiSEtLY+PGjXz11VcsXbq0yu4hW7du5bHHHkOv1xMQEECnTp04fvw4MTExXHfddapeS3WOHTtGdHQ0OTk5eHl5WXL7aWlpltc5a9YsJk+eXOXcpKQk7rnnHoqKiujcuTPFxcUcPHiQgwcPsnfvXhYsWFCp/pkzZ5g0aRIpKSm4uLgQGhqKyWQiISGBhIQEtmzZwvLlyytd5BVOShENLi0tTYmIiFAiIiKUtLS0auvl5uYqN9xwgxIREaG8+OKLluNvvPGG5fz58+crJpNJURRFycrKsrTfu3dvJSIiQnn99deVsrIyy7nbtm2zlG3dutVy3GQyKffee68SERGhTJo0ScnJyVEURVGMRqOyatUqJTIy0vKcl5s9e7YSERGhLFq0yHIsKytL6devnxIREaE888wzSmFhoeU53nvvPSUiIkLp1q1bpdde0faJEycqtf/tt98qERERSu/evZXNmzdbjuv1euWtt96ylKWnp1vKMjMzLa/x5ZdfVsrLyxVFUZTCwkLl0UcftTzX+PHjq33vL7dx40YlIiJCufPOOysdv/POO5WIiAjlkUceUQoKCizHCwoKlFmzZikRERHKddddp+j1ekvZ5b+7v//970piYqKl7JtvvlG6d++uREREKF9++aXluMFgUO644w4lIiJC+b//+z/l4sWLlrJTp04pt9xyixIREaH897//rdS/oUOHKhEREcr27dttep3CMUhO2M4URSE/P59du3bx4IMPkp2dja+vLw888ECVuq6ursycORONRgNguTj27rvvUlhYyB133MHMmTMrjY6GDx/OrFmzACqlAQ4cOEBCQgJ+fn4sWbIEf39/ALRaLZMmTeJf//qXza/h448/Jicnh2uvvZZ58+bh7e0NmDcmnThxIkOGDKG8vJyvvvqq1rbeeOMNAJ566iluvfXWSq/94Ycf5pZbbrF8Ta+wbt06CgsL6du3L//5z38sa8p6e3uzaNGiatMXapw9e5b09HQ8PDx44YUXLGkjMKeQ/vOf/wBQUFBARkZGlfM1Gg3Lli2jU6dOlmMjR460pEtWrVplOb5161aOHj1Kx44def3112nRooWlLDw8nNdffx2tVsu6devIysq64tcm7EuC8FU2fPjwKjdr9OnTh5iYGA4dOkRAQADLly+3mo6IiIiwBLjLbd++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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": "iVBORw0KGgoAAAANSUhEUgAAAYAAAAE+CAYAAACEB8e6AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABNgElEQVR4nO3deVxU9frA8c8M++qGKCKiCOPuL3GrbiSmZbaYmWmmllpmLuk1S7P05pKW3Sz3LDUtSzOXIqub+4pLKpT7ggKiArIpsjMz5/fHxCixOAdlGOF539e8rp3znDPfYeA857sejaIoCkIIIaocbUUXQAghRMWQBCCEEFWUJAAhhKiiJAEIIUQVJQlACCGqKPuKLoAQQtxKr9djMBhUH2dnZ4e9vVzS1JCflhDCZuj1eo4fDceguKs+1s7OjpYtW0oSUEF+UkIIm2EwGDAo7jT2+g+OdqkWH5dnqMn55GkYDAZJACrIT0oIYXPstMnY2SVZHq8Yy7E0lZckACGEzTGiYMTyRQrUxIqbJAEIIWyO8e//qYkX6kkCEELYHKOiYFCxTJlRljQrE0kAQgibY0Rds47c/5eNJAAhhM0xoKBVkQAM0gdQJpIAhBA2R1HZCaxIAigTSQBCCJtjUBQ0Ktr11fQXiJskAQghbI4Rde360gdQNpIAhBA2x4iiql1f5gGUjawGKoQQVZTUAIQQNscAqLmpV792qABJAEIIG2QENCrjhXqSAIQQNseIBjUpwKgqXYgCkgCEEDbHqKCqCcgofcBlIglACGFzDGhQpAZQ7iQBCCFsjlFlAlATK26SBCCEsDlGRYNGUZEAVMSKmyQBCCFsjgHQqKoBiLKQBCCEsDlGtKibp6q941mtGzZsYOLEiXz33Xe0a9eu0L74+HhCQ0NLPDY4OJjVq1cX2paYmMjChQsJDw8nKSkJHx8fevTowdChQ3F0dCxyjvT0dL744gu2bt1KfHw8Xl5ePPbYY4waNQp3d/ci8Tk5OXz99df8/PPPXLp0CQ8PD0JDQxk9ejTe3t4WfWZJAEIIm2NUNKCmWUfR3FECiIyMZPr06SXuP3nyJABNmjRBp9MV2d+oUaNC/52QkEDfvn1JSEigefPmtGjRgoiICObNm8eBAwf46quvcHBwMMdnZGQwYMAAzpw5Q6NGjQgNDeXEiRMsX76cPXv28P333+Ph4WGOz8/PZ8SIEYSHh+Pj40OnTp24cOECa9euZefOnfzwww/Uq1fvtp+7UicAo9FIZmYmDg4OaDTSRiiEtSiKQn5+Pm5ubmi16i/NBpXzAEBT5ovZpk2bmDhxIllZWSXGnDp1CoBXX32VHj163PacU6ZMISEhgTFjxjBixAgAsrKyGDlyJPv27WPlypUMGTLEHD9nzhzOnDlDnz59mDp1KlqtFr1ez7vvvktYWBhz5sxh8uTJ5vhvv/2W8PBwQkNDmT9/Po6OjiiKwmeffcYXX3zBtGnTWLx48W3LqVGUyruO6o0bNzh79mxFF0OIKkun0xW6c72d3Nxcjh8/Tnb1USh2SRYfpzHUxuXaAlq2bImTk5NFxyQkJPDpp58SFhaGi4sLbm5uJCcnF9sENGLECLZt28Zvv/1G48aNSz3vhQsXeOKJJ/Dz82PTpk2FEuCVK1fo2rUrdevWZfv27YCp6SckJAR7e3t27dpVqLknMzOTzp07k5uby/79+3F1dcVoNBIaGsrVq1fZunUr9evXN8cbjUaeeOIJoqOj2bp1K35+fqWWtVLXAAqqWJ+/+i3pV29UcGnKx4SfhzOrx+cVXQxRBpX5u/P09mD40gGFmjnUMA0DtbzmoKbDuMCcOXMICwujZcuWzJw5kw8++IDk5ORiY0+dOoWrq2uRpp7i7N27F0VR6Ny5c5HaT7169WjevDnHjh0jKiqKwMBADh06RE5ODl27di3S1u/m5sYDDzzA77//zqFDh+jUqRNnz54lMTGRZs2aFbr4A2i1Wh555BGWLVvG7t276d+/f6llrdQJoKDZJ/3qDdLir1dwacpPZf5slV1l/+7K2vSqdiJYWRJAQEAAs2bNokePHqU2U127do0rV67QokULli9fTlhYGLGxsXh4eNC5c2dGjRpFnTp1zPFRUVEABAUFlfi+x44d4+zZswQGBloUD3DmzBk6depkcbwlrR+VOgEIIe5NRkWLUbG8BqBVEVvgtddesyiuoP3/xIkTnD17lvbt21O3bl2OHTvGDz/8wI4dO/jmm2/MF96rV68ClDgSp3bt2gDm2kZSUlKh7SXFp6SklCm+NJIAhBA2x4hG5fIOptiEhATs7OwK7fH09MTT07PMZSkYAaTT6Vi0aJG5XT0rK4vJkyfzyy+/8NZbb7FhwwYAsrOzAXB2di72fAXbCzqdC/7fxcWlXOJLIwlACFFpvPjii0Xa8UeNGsUbb7xR5nMOGjSIxx57DDc3N2rWrGne7urqygcffMChQ4c4ceIEf/75J/fdd585Ad2u+ctoNC1iXd7xpZEEIISwOQa0f08Gs0xBh/GqVauKrQHcCTs7uxJH07i4uHD//fcTFhbGiRMnuO+++8x35jk5OcUeU7Dd1dXVfI7yjC+NJAAhhM0xKhoMatr1/540VrduXYuHgd4tXl5ewM2mn4K2/5JGFBW04RfEWRpf0LavNr408kxgIYTNMf5dA1DzKi8LFixg9OjRnDlzptj9ly5dAkzJB26OzikYrfNP58+fBzDPKLY0vkmTJoWOs/T8pZEEIISwOQZFo/pVXs6cOcOmTZv43//+V2RfSkoK4eHhODg40LFjRwBCQkIA2LFjR5F2+CtXrnDq1Cl8fX0JDAwEoH379jg7O7N///4iHbeZmZnmCWBt27YFoHHjxvj6+nLy5Eni4+MLxRuNRrZv345GozGXozSSAIQQNseIFoOKV3nWAPr27QvA8uXLOXLkiHl7ZmYm7777LhkZGfTu3dvc5OLn50dISAgXLlxg7ty55visrCwmTZqEwWBg8ODB5u2urq707NmT69evM3XqVPR6PQB6vZ5p06aRnp5O3759C00Se+GFFzAYDLz33nuFksbcuXOJiYnh0UcfpUGDBrf9bNIHIISwOUbUzQMozwTw0EMPMXjwYJYvX86AAQMIDg6mRo0aHD58mLS0NNq1a8eECRMKHfP+++/Tr18/Fi9ezPbt22nUqBEREREkJSXx8MMP069fv0LxY8eO5eDBg/z0008cOXKE5s2bc/LkSeLi4mjRokWRUUyDBg1i586dhIeH89hjjxEcHEx0dDRnz57F19e30LpBpZEagBDC5hjQqKoBGMr5iWDvvPMOc+bMITg4mJMnT7Jnzx5q167N22+/zYoVK4qMyffz82Pt2rX06tWL1NRUdu7cSbVq1Rg3bhwLFizA3r7wvXf16tX5/vvvGThwIHq9nh07dqDVann11Vf5+uuvcXNzKxTv6OjIsmXLGDFiBC4uLuzYsYPMzEz69u3L999/L8tBCyHuXUaV7frau9AHsHLlylL3d+/ene7du1t8Ph8fHz788EOL46tXr86kSZOYNGmSRfEuLi6MGTOGMWPGWPwe/yQJQAhhc9SO7CnPJqDKTBKAEMLmGBStqnkAZVkLSEgCEELYIEXlWkBqVg4VN0kCEELYHIPKmcDlOQ+gMpMEIISwOQWje9TEC/UkAQghbI6iaEwPhlcRL9STBCCEsDlSA7AOSQBCCJtjVDTqZgJLDaBMJG0KIUQVJTUAIYTNMaJRtbyDusdHigKSAIQQNkftQ+HVxIqbJAEIIWyOQWUNoLwXg6usJAEIIWyOorIGoEgNoEwkAQghbI4BlTOBpQZQJpIAhBA2x6hyLSDpBC4bSQBCCJtjVNRNBJNO4LKRBCCEsDlGRWUNQCaClYkkACGEzZGlIKxDEoAQwuZIDcA6JAEIIWyO6YEwKoaBSidwmUgCEELYHIOiciKY1ADKRBKAEMLmSBOQdUgCEELYHEXRqmsCkmGgZSIJQAhhc2QtIOuQBCCEsDlG1D0SUmYCl43Um4QQooqSGoAQwuaYOoFVLAWBBqkEqCcJQAhhcxSVi8HJPICykQQghLA5qucBSA2gTCQBCCFsjlHlMFA1seImSQBCCJujqJwIJk1AZSMJ4B7RvF0mn/wYRdIVB17u2Ny8vUH1z9l05S+LzrFydh2+nV23vIooSqDRKMzZGIVPw1z6tGxZaN+AcQkMHJdo0Xk2r6nB7LENyqOINkceCGMdkgDuAQ5ORsbOjsPOrui+XL0Px/9wLfFYj+oG/HW5AMTHOJZXEUUpBk1IoGlwFtdTi36BVy87lPr9ObkoBLXKBiA+1qncymhrjIq6i7qxHMtSmUkCuAcMeDORBkG5xe5LzOjJOz1Pl3CkwoffX8Bfl8vWtTXYtr5m+RVSFENhwLhEXhh9tcSIzd/XYvP3tUrc/+9P4ghqlc1f4W58P8+7PAppk6QPwDpsNgHs27ePxYsXc+bMGfLz82nRogVDhw7l4YcfruiiWVVgqyx6v36VnGwNzi6KqmN7vpJM8MMZJMQ5sOBd33IqoShOjdr5jJ51iQcfTy/zOR7odp3uL6aScV3Lf8c0wGisOs0c0gdgHTaZNjds2MDgwYOJjIykdevWtGnThsjISIYOHcqaNWsqunhWY2evMO7TOBRFw6rP6qg6tqZ3PoPeSQBgwcT6ZGcW034kykVwpxss23uaBx9PJyXRnmUz1fe7ODobGTnjMgDLP/Ih6UrVar4r6ANQ8xLq2VwNIDExkffffx8PDw9WrVqFTqcD4OjRowwePJgZM2YQGhpKnTrqLoj3ohfeSCSgRQ7ffeZNzGkXVccOfCsBFzcjB7d6cGi7ZzmVUBTHPygHFzcjW9fWYPGUejRqmqP6HL2GJlG7Xj4XTjrz6zclNxFVVqrXAtJIAigLm6sBfPfdd+Tl5TFo0CDzxR+gdevWDB06lNzc3CpRC/Bvks0Lo69y8ZwTq+eqS3Z+gTl0eyEVoxG+mulTTiUUJTnzpysju+n475gG3EhTf4/lUV1Pn5GmfoMVH/mgVMG17o2KRvVLqGdzCWDPnj0AdO3atci+gm27d++2apmsTas1Nf3YOyh89pYf+XnqvqZnX03Gzh4ObfNQXXMQd+7kYTcunCj7z737gBTcPI1En3Lm4NaqWXtTVF78q2KSvBtsqglIURSioqLQarUEBAQU2d+wYUO0Wi1RUVEoioKmklb7eg1LokmbbH5eXouTh9xUHevmaeCR59IAWPt51Rk1UllotQpPvZQCwLrFtSu4NBXHqKh7ypcMAy0bm6oBXL9+nby8PKpXr46jY9FOL3t7e2rUqEF2djaZmZkVUMLyV69RLgPfSuDqZYcyNd881icVFzcjZ/504dgB93IooShPHR9Lp079fFIS7NnxY42KLk6FkU5g67CpBJCdbZrw4uJScvXZ2dkZoJImAFPTj7OLwrwJZRu589BT1wDYsaHqXjzuZSFPXgNg98bqGPRV96ImfQDWYVNNQFqtmmeAWj4mfsLPw8tSHKvzctuEX/WjpGY9yHOz3uC5W/Z5OkcA/6WGTzU+OvROoeMK/ttOm06Luq+jKBoeGv4eHYfJxC9b4O54EpiOWzWXEr87EyOtfIYB0KLnG3z0hI6qSlF5UZd5AGVjUwnA1dU0JT43t/hZrwA5OTmFYi0xq8fnpMVfv7PCWcHH66LwexBquu6jpuu+YmOc7JNp49sPgJc6NGPsj//hnfYfAdDluVRaz1c4/ocr43p+abVyi9K1fiCD/66HzOvZ5u8KTBf/W/+7ZYcMZv+UQdIVB95ot557eX3jGj7V7pkbr6rMphKAu7s7rq6upKWlodfrsbcvXDy9Xk9aWhpOTk54ela+0RExp52xsy++ZuNRzYB/k1zycjScPWpqIsvLLXyBaNY2C4Cj+6Tt/17UrN3f399+N+7li//doLZZR/oAysamEoBGoyEwMJCjR48SExNDYGBgof3R0dEYjcZC8wMqk0WT6pe4r2PXdKZ9E01qkj3jegYVG9O4pakPJeqYDP28F938/iyv3VZWkgCsw6Y6gQFCQkIA2Lp1a5F9Bds6depk1TLdKwKam5rHYs86V3BJRFkENDclgNgzVWfVz5IomMb2W/ySBFAmJdYAdu3adVfeQO3FulevXixdupQlS5bw0EMP0fLv9dOPHTvG0qVLcXZ25sUXX7wrZatMXD0MOLuaRkPfuCbr/tyLanrrAci4blMV8wohzwOwjhJ/04YNG3bHE600Gg0nT55UdUz9+vWZMGEC06ZN44UXXqBjx44AHDx4EL1ez6xZs6hVq+qtjXI7njX05n9n3ZAEcK/RahXcPA0AZN6wuYq51SkqJ4KpGBQoblFiAqhXr541y1FI//79qVevHkuXLiUiIgJHR0eCg4MZPnw4DzzwQIWVqyId3OpJt3r/V+L+hItOpe4XFefofvfbfjdGo4bu9eX7K1DQtKMmXqhXYgLYvn27NctRROfOnencuXOFlkEIUTFUdwJLAigTaWwUQtgcqQFYR5kTQGpqKgcOHCA6OpqMjAwmTJhAbm4ukZGR3H///XezjEKIKkZqANahOgHk5+fzySefsHr1avLz883bJ0yYwMWLFxk8eDDNmjXj888/rxIPbRFClANFZceudAKXiarhBkajkZEjR/LNN9+g1+tp0qQJ1apVM+/PzMxEq9Vy8uRJ+vXrR1pa2l0vsBCi8pPVQK1DVQJYv349u3fvJiAggJ9//pmffvqp0Lr99913H7///jtBQUHEx8ezbNmyu15gIUTlp2oSmDwQpsxUJwCNRsO8efOKLNNQwM/Pj/nz56PVait8JJEQ4t5U8Exgi19SAygTVX0A586dIyAggMaNG5ca17BhQxo2bEhcXNwdFU4IUTUpKvsAZCJY2ahKAAaDweI1+x0cHLCzkxmpQgj1TAlAZgKXN1VNQH5+fkRHR5OamlpqXHJyMlFRUfj5+d1R4YQQVZTa9n/pAygTVQmgW7du6PV6/vOf/xQaAnqrvLw83nvvPQwGA127dr0rhRRCCHH3qWoCGjx4MD///DPbtm2jZ8+edOnShaSkJAC2bNnC+fPn+fHHH4mNjcXHx4dBgwaVR5mFEJWcTASzDlUJwM3NjeXLlzNq1ChOnTrFhQsXzPtGjx4NmJ7V6+/vz6JFiyrlU7uEEOVPOoGtQ/VMYF9fX9avX8+WLVvYtm0bUVFRZGZm4uLigr+/P6GhoTz55JM4OjqWR3mFEFWArAVkHWVaC0ir1dKtWze6det2t8sjhBAVkgA2bNjAxIkT+e6772jXrl2R/dHR0cyfP58jR45w7do1GjRoQJ8+fejfv3+xoyMTExNZuHAh4eHhJCUl4ePjQ48ePRg6dGixN8jp6el88cUXbN26lfj4eLy8vHjssccYNWoU7u5Fn/Odk5PD119/zc8//8ylS5fw8PAgNDSU0aNH4+3tbdFnvqMnT6SmphIREcG+ffs4duwYmZmZd3I6IYQATEv7qH3dicjISKZPn17i/tOnT9O7d29+/fVX6tWrR0hICAkJCXzwwQeMHz++SHxCQgJ9+vRhzZo1eHp6EhoaSmZmJvPmzeOVV14pMogmIyODAQMGsHTpUjQaDaGhoWg0GpYvX07fvn25ceNGofj8/HxGjBjBp59+SmZmJp06daJ69eqsXbuWXr16ceXKFYs+d5lqAL/99hvLli0r8rQvrVZL+/btGTlyJO3bty/LqYUQwvxMYDXxZbVp0yYmTpxIVlZW8edWFMaPH09GRgYff/wxzzzzDGC6AR40aBAbN27k0UcfLdQiMmXKFBISEhgzZgwjRowAICsri5EjR7Jv3z5WrlzJkCFDzPFz5szhzJkz9OnTh6lTp6LVatHr9bz77ruEhYUxZ84cJk+ebI7/9ttvCQ8PJzQ0lPnz5+Po6IiiKHz22Wd88cUXTJs2jcWLF9/2s6uuAUyaNIlx48Zx4sQJFEXB3d0db29v3NzcMBgMHDhwgJdffpkVK1aoPbUQQphYoQqQkJDA+PHjGT16NEajES8vr2LjwsPDOXPmDB06dDBf/AFq1qzJlClTAFi5cqV5+4ULF9i5cycNGjTg9ddfN293dXVlxowZ2NnZ8e2335q3p6ens3btWtzd3ZkwYYK5Ocne3p7333+fatWqsW7dOnOCMhqNLF++HI1Gw+TJk83NSRqNhn//+980atSIHTt2WLQSg6oEsHHjRtatW4eDgwNjxoxh165dHDp0iF27dnH48GG2bt3KkCFD0Gg0zJo1iwMHDqg5vRBCmFhhIticOXMICwujZcuWrFmzptDClrfas2cPQLHzmoKDg6lVqxZHjhwhIyMDgL1796IoCp07dy7SN1CvXj2aN2/O5cuXiYqKAuDQoUPk5ORw//33F2nrd3Nz44EHHiAnJ4dDhw4BcPbsWRITE2natCn169cvFK/VannkkUcA2L17921/BqoSwOrVq9FoNMyePZvhw4cXWe+/fv36jB8/nilTpqAoCkuWLFFzeiGEAG4OA1XzUisgIIBZs2axdu1amjRpUmJcwYVap9MVu79Ro0YYjUbOnz9fKD4oKKjE9wXThVxN/JkzZ8p0/tKo6gM4ffo0fn5+PProo6XGPf/88yxatIi//vpLzemFEAKwziig1157zaK4q1evAlC7du1i9xdsT05OLhRf0kicf8YXTKa93flTUlLKFF8aVQnA3t4eV1dXi2Jr1KhBenq6mtMLIYSJgrpmnb9rAAkJCUUWofT09LyjSanZ2dkAODs7F7u/YHtBG73a+IL/d3FxKZf40qhKAB06dGDHjh1ER0fTqFGjEuMSExM5d+6cPBtYCFEmZZ0J/OKLL5rvrAuMGjWKN954o8xlKUgoGk3pCcloNNpkfGlUJYBx48Zx8OBBhg8fzoIFC4p9KExiYiIjR47E3t6ecePGqTm9EEKYqB3Z83fsqlWriq0B3ImCO+2cnJxi9xdsd3NzUxVf0JpS3vGlKTEBjBkzptjtdevW5dy5c/To0YO2bdvStGlTXF1dyc7OJiYmhoMHD5KXl0dISAibN2+madOmty2EEELcqqzzAOrWrYuTk9NdLYu3tzenTp0iOTm52Idh/bNNvqDt/581kX/GF8RZGq/2/CX1EdyqxASwadOmUg80Go0cOnTIPDTpn3bv3s2ePXvMi8QJIYTFylgDKA9BQUHs2rWLqKgoOnbsWPhtFYULFy5gZ2dnTg4Fo3MKRuv8U8FooYJRRZbGF4xUKjjO0vOXpsQEMGrUqNseLIQQ5cGWFoMLCQlh6dKlbNu2jf79+xfaFxERQWpqKh06dDCP4Q8JCQFgx44dvPXWW4XmAly5coVTp07h6+trbkJv3749zs7O7N+/n6ysrEJNN5mZmezfvx9XV1fatm0LQOPGjfH19eXkyZPEx8fj4+NjjjcajWzfvh2NRmMuR2kkAQghRCk6dOhAUFAQ4eHh/PDDD/Tp0wcwLQUxdepUwPSslAJ+fn6EhISwZ88e5s6dy9ixYwHTqJxJkyZhMBgKxbu6utKzZ0++//57pk6dyowZM7C3t0ev1zNt2jTS09MZPHhwoUliL7zwArNnz+a9995jwYIF5qQxd+5cYmJieOyxx2jQoMFtP1uZ1gISQohyZUNNQFqtlpkzZ/Lyyy8zefJk1q1bh7e3N3/88QfXr1+nT58+5tm3Bd5//3369evH4sWL2b59O40aNSIiIoKkpCQefvhh+vXrVyh+7NixHDx4kJ9++okjR47QvHlzTp48SVxcHC1atCgyimnQoEHs3LmT8PBwHnvsMYKDg4mOjubs2bP4+voWWjeoNGVKAAaDgcTERLKzs1H+MVZLr9eTl5fH1atX2b59OzNnzizLWwghqjTN3y818eWndevWrF27lnnz5nHw4EHOnTuHv78/b775Js8//3yReD8/P3P87t27iY2Nxc/Pj5deeomXX34Ze/vCl97q1avz/fffs2DBArZu3cqOHTvw8fHh1Vdf5fXXXzePMCrg6OjIsmXL+PLLL/nll1/YsWMHtWvXpm/fvowaNcri5aBVJ4AlS5awZMmSIsuTlkQSgBBCtQqoAdy6oFtxAgMDmTdvnsXn8/Hx4cMPP7Q4vnr16kyaNIlJkyZZFO/i4sKYMWNKHLFpCVUJYPPmzcyePdui2AYNGvD444+XqVBCiCrOhpqAKjNVi8H98MMPADz99NPs2rWLAwcOYGdnR58+fTh27Bhbtmxh2LBh2NnZYTQaLV5rQwghCilY4VPNS6imKgGcPHkSFxcXpkyZQp06dahevTqBgYGEh4fj4OCAn58fY8eOZcyYMVy+fJmvv/66vMothKjErLEaqFCZANLT0/Hz8yvUIREUFMSVK1e4fv26edtLL72Es7Mz27Ztu3slFUJULdZ6HmQVpioBuLq6FlmAyM/PD7g5+wxMq9E1bNiQ2NjYu1BEIUSVI01AVqEqAfj5+REXF1domVF/f38UReHUqVOFYnNyctDr9XenlEKIKkWjqH8J9VQlgIceeoisrCwmT55sfvxZq1atAFi/fj15eXkAHD16lJiYGHx9fe9ycYUQVYIVngksVCaAl156iRo1avDbb78REhJCXl4ejRs3pmPHjpw6dYpevXoxevRo8zTnhx56qFwKLYSo5KQJyCpUJYBatWrx1Vdf0axZMxwdHc1Po3/vvffw9PQkKiqKzZs3k5mZSb169RgxYkS5FFoIUclJDcAqVM8EbtasGRs2bCA+Pt68TafT8euvv7J+/XouX75Mw4YNef755/Hw8LirhRVCVBEyEcwqyrwY3K1LkAJ4eXkxbNiwOy6QEEJIArAOWQ1UCGGD1LbrSx9AWZSYAHr37n3HJ9doNKxdu/aOzyOEqFrUDu2UYaBlU2ICOH78+B2f/HZPrRdCCFFxSkwAapYxFUKIu0r6AKyixATw7LPPWrMcQgghrKxKdAJr/etj51azootRbuwCG1V0EcrNb7t/rOgilJvIy7Dpyp8VXYxykauvzcnEsh8vfQDWUSUSgBDiHqOgbhSQJIAykQQghLA90gdgFZIAhBC2RxKAVUgCEELYHOkDsA5JAEII2yQX9XInCUAIYXukCcgqypwADAYDJ06c4MKFC2RkZDBgwADy8/OJj4+nQYMGd7OMQogqRpqArKNMCeCbb77hyy+/JCUlxbxtwIABxMXF8dRTT9G1a1dmzpyJu7v7XSuoEKIKUfuQF3kgTJmoTgDvvfceGzZsQFEUqlWrRl5eHjk5OQAkJydjNBrZsmULcXFxrFq1ChcXl7teaCFEJSdNQFah6olgmzZtYv369dSuXZslS5Zw8OBBmjVrZt7foUMHVq5cSe3atTl9+jRff/31XS+wEKLyk4fCW4eqBLB69Wo0Gg1z584lJCSk2Jj27duzcOFCFEXhf//7310ppBCiipFHQlqFqiagkydP4ufnR5s2bUqNa9WqFf7+/sTGxt5R4YQQVZTau3pJAGWiqgaQm5uLq6urRbHSASyEuCNy91/uVCUAHx8foqOjycrKKjUuIyODqKgo6tate0eFE0IIUX5UJYDOnTuTm5vLRx99VGrczJkzycvLo1OnTndUOCFEFSV9AFahqg9g6NChhIWFsXbtWi5evEj37t25fv06YOofOH/+PD/88AOHDx/G09OTIUOGlEuhhRCVm0wEsw5VCaBmzZosWbKEkSNHcuDAAQ4ePGje99xzzwGgKAo1atRg/vz51KlT5+6WVgghxF2jeiJYixYt+OWXX1izZg3bt28nKiqKzMxMXFxc8Pf3JzQ0lBdffJGaNSvvE7iEEOVMJoJZRZmWgnB3d+eVV17hlVdeudvlEUIIaQKyElkNVAhhe6QGYBWqEsBPP/2k+g169uyp+hghRBUnCcAqVCWAd955B43GslX3FEVBo9FIAhBCqCZNQNahKgE0b968xASQk5NDcnIy169fR6PR8NRTT0lHsBCi7OSiXu5UJYANGzbcNubw4cO88847HD9+nHXr1pW5YEKIqktqANahaiawJdq1a8fcuXOJiYlh4cKFd/v0QoiqQGYCW8VdTwBgmisQEBDA5s2by+P0QojKThKAVZTbMFA7OzuSkpLK6/RCiEpMmoCso1xqABEREURFReHl5VUepxdCVHZSA7AKVTWA7777rtT9eXl5REdHs3HjRgC6dOlS9pIJIaoumQdgFaoSwPTp0y2aB6AoCg0aNGDEiBFlLpgQouqSJiDrUJUA2rdvX/rJ7O3x9PSkTZs29O7dW54KJoQoO7molztVCWDlypXlVQ4hhBBWpqoTeMiQIbzzzjukp6eXV3mEEMLcBKTmJdRTVQP466+/cHd3x9PTs7zKI4QQ0glsJarnAVSrVq08yiGEEDdJArAKVU1APXr04Ny5c2zbtq28yiOEEABoVLxE2aiqAfTo0YNTp04xatQo7rvvPu677z68vb1xdHQs8Zj+/fvfcSGFEFWM1ACsQlUC6NevHxqNBkVRiIyM5M8//7ztMZIAhBBqyTwA67ir8wCEEOKukBqAVZSYAK5cuYKTkxO1atUyb5N5AEIIq5AEYBUldgI/8sgjjBkzxpplEUII4O/OXTXzACq6wPeoUpuAFEXSqhCiAkgNwCrK7XkAQghRVtIJbB2SAIQQtkdqAFYhCcDKNBqFTz/fTd16mfTr8UShff0Hn6L/4DMWnWfL//z47MO2hbY1aZ5Kn/5nad4qFVe3fNJSnYn4w5vvv2nC1UTXYs9Tq3Y2vfudo939idSunY3eoCUuxoPtm+vzW1gjDIZyeWaQzTIa4d9PBxEf48TaE8dLjDt31IUfFnpz/KA76Wl2VPfS06FrOgPeTKBWHb05LiHOkZc7Ni/hLB8B9xXasunKnwC8/VwgR/dbtpruuM8u8ljf1ELbtm+ozi/feHHhhAt6vQYf/1w6PX2N3sOv4uxq+1dLqQFYR6kJICUlhZ9++umO3qBnz553dHxl89Krp2jSPI3r14pOnrua6MqJozVLPNbJ2UCg7joACZfdCu0LfTSOcRMjsLNXuJHuwMUYD3zrZ/L407H8q9MVJo79FxfOVS90TFDTND74ZB8envnk52u4HOeOq5ueJs3TaNI8jQcfjuc/4x8gP8/uzj/4PWLFLB/ORLrhWUNfYszvq2oyd4IfRoOGmt75+AXmEhflxG8rvTiwqRqfhp3Dxz8PAEcnIy3aZxR7noy8prg7nub8CRdysuzw8c8172vYNBtDyUUg9aoD8bFOaDRKoeMA5r1Tn1+/MT2Nr3a9PFzcDVw678zK2T7s+70a/10fhZun0dIfScWQGoBVlJoAYmNjmThxYplPrtFoJAGYKfQffJq+A8+WGLHlN3+2/OZf4v4x4yMJ1F3nrwgv1nzbxLy9Rs0cRr/1J3b2Cj+uacxXi1tgMGhxd8/j7f8cof39iUz4z2GGv9wFo9E0XsLB0cB70/7AwzOf/XvrMuejYG6km5JSi9bJTHj/MP8XnMygoSdZsrDVXfoZ2C5FgW9n12XN/Dqlxp076sLc8X4oCgybepmerySh1UJKgj3Thzbi1BE35rztx6wfzgNQ01vPp2FRxZ4r8vIH2Me9wvjegTg5G5myPNq8b+SMyyWWIS9Hw6juOgD6jUmk1f2Z5n0HNnvy6zdeaO0UJsyPJbTnNQBizzrx/ssBnD/hypfTfBn7SZxFP5cKIwnAKkpNAI6OjoXmAYiyqVEzh1Hj/uSBkIQyn+P+h+Lp9lQsGTfsmT0z2HwhB3jw4Ss4uxi4GOPB0kUtURTTvowMR/47vS3fbvgdP/8MmjRP5dRx0/f5r05X8K6bTfJVZz6e1o7cnJu/CieOejH/v/cx9eMDdH8mhhVLmlfqWkDqVXvmTfBj/6bbL3T45bR6GI0a+o5KpNfQJPP2WnX1TFgQy+AHm/HnXg8SLzlQp35+qefKycjl89H+GI0aXnnvMg2b5lhU3q8+9CH2jAtN2mQy4M3Cv1Nb19cA4PEXU8wXfwB/XS7Dp1/mPy8FsOPH6rzxYRz2Dha9XYWwRhPQTz/9xIQJE0rc//rrrzN27Fjzfx87doyFCxdy7NgxsrKyCAwM5KWXXuLpp58u9vjo6Gjmz5/PkSNHuHbtGg0aNKBPnz70798frbZo02piYiILFy4kPDycpKQkfHx86NGjB0OHDi11uZ07UWoCaNmy5W2fA2wNGzZsYOLEiXz33Xe0a9euooujSpv2V3lv2h+4uulJTXEibF1jBg87qeocjo4GRvz7LwC+XtKc5KuF2/NreZkuHLHRHuaLf4GMG44kJrji559Bbe9sTv29vfV9yQAcPlin0MW/QMQhb/LzNTg7G/Dzv1Gk+aiyOLLTgw9ea0hWhh01vfPp+UoSX31Yr9jYpCsOHNvvjqu7gRdGJxbZ7+Ofx7Cpl9FqwN7+9lekrUv2knjJkSZtMnl6cLJF5T1/3IWwZbWxs1cY83Ecdv/46lLiTVf1RsUkk6DWWQDkZtuRnmZPTe9S2piqgFOnTH8N//rXv6hZs2jTa7Nmzcz/Dg8PZ9iwYRiNRtq3b4+Liwv79+/nrbfeIioqqlCiADh9+jT9+/cnIyOD4OBgWrVqxcGDB/nggw/466+/+OSTTwrFJyQk0LdvXxISEmjevDktWrQgIiKCefPmceDAAb766iscHO5+xrb5TuDIyEimT59e0cUoswYN03F20bPtdz++XNCKhgHXVZ+jZ58ovLxziD7vyW9hjYrsT05yAaBhQDoajVIoCbi45FO7TjYASVddzNs3bgjg2J9exF8p3JdQwMHRiFZruojZ2VXe+nXsOWeyM7V06Z3K61MuE33apcTYP8PdURQN//evDFzdi29Df/ZVyy7kCRcd2b82AoARH1ymmBvCYi39wAejUcPTA5No3KLoRd7Lx1TrOH+i6OeIPeMMgKOzkWq17oGLfzn/2p08aboR+/DDD6lTp+Smv5ycHN5++20AvvrqK+6//34ALl68yMCBA1m8eDGPPvooLVu2NBVbURg/fjwZGRl8/PHHPPPMMwCkpqYyaNAgNm7cyKOPPkq3bt3M7zFlyhQSEhIYM2aM+VnqWVlZjBw5kn379rFy5UqGDBly138GNj3EY9OmTbzyyitkZWVVdFHK7OypGox+NZTZM9ua29jVcPfI4/kXzwHw9ZfNi9zhA+zdWY/MDHv8/DMYMvwEWjvTxcnZRc+/34nE2dlA1NlqnDp+8y4n+nw1dmzx4/SJ4judOz6YgJ0d6PWmzuHKqsl9mSzcdJbx8y7iWdNQamzsadMFtEGQ6cL7xzYPZo/1Y0Kfxnw43J/dG6th6dzJrz+uiyHfwENPXqNpG8t+vyN2uxOx2xMnFwMDxhWtgQA83s80Gmjzmprs3nizSSs+1pFFk+oD8MSAFOxsvEVPoyiqX2qdPn0aLy+vUi/+AGFhYaSkpPD000+bL/4ADRo04K233gIKL5MTHh7OmTNn6NChg/niD1CzZk2mTJlSJP7ChQvs3LmTBg0a8Prrr5u3u7q6MmPGDOzs7Pj2229Vfz5L2GQNICEhgU8//ZSwsDBcXFzw8vIiOdmyOytbU9DmXlbde8Tg5q4n5oInf+yvW2xM+nUnJr31IG+9d4TnXoji0e6xXE10pZ5vJq5ueg4f8Oazj4KxdMK8k7Oega+YqseH9tchK9OGG4vvUIv2lt9cXL1sSuCuHgamDmnIvt+rF9q/M6wG7R9JZ9KX0aUOtUy64sCun01t9X1HFX8hL866xd4APNY3lepexd/Btw29wdhPLrLkg3rMGNaIL6fm4eZp4NJ5JwB6vpLEa/8puYPZZpRzJ3BcXBzp6el06tTptrF79uwBoEuXLkX2de7cGTs7O3bv3l0kvmvXrkXig4ODqVWrFkeOHCEjIwN3d3f27t2Loih07ty5SN9AvXr1aN68OceOHSMqKorAwEBVn/N2bLIGMGfOHMLCwmjZsiVr1qwhICCgootUIbRahSefMY0MWf996V98RrojZ06aLiqe1fIJ1F3H1U2PQa8h6aqLxXemWq3C+MmHqVc/k9xcLSu+LGkMe9WTnWn6c9nwhTcHt1ZjyMQrrDl6nLCov3jvi2iq1dRzaLsnC96tX+p5fvmmFga9hoC2DdD9X7ZF733pvBMRuzzQ2ik8Nyyp1Ng6fnn4NTYNDU264kjMaRf0+VqcXY1Ur51v8e9CRSrvZwIXtP/XqlWL6dOn8+ijj9KqVSu6devGwoULyc29ObT23DlTDVyn0xU5j7u7O97e3qSmpppvUqOiokqMB2jUqBFGo5Hz588Xig8KCio2vuD6d/ZsySMIy6rEGsCoUaPw8fG5629oiYCAAGbNmkWPHj2K7S2vKjo+GI933WxSkp3ZuaXki0pA0DU+/CwcD898flzTmLB1jUlNcaZhQDqDh52ge49YWv5fCm+PCiH9ulOJ59HaGXnrvSPm0Uqfz2lNXKw8/7lAXq7pd/F6qj1D3r1C31FXzfsefvo67tUMTHwhkK1ra9Jn5FUaBOUWOYc+H/73nalWGNK/A/CzRe+98WsvFEXDvx6/Zp5jUJxNq2sy520/HJ2NjJ4VR8hT13B0MvJnuAeL/+PLio/qEXXMlUlfxqCx5RXUyrkGUND+v2HDBqpXr05wcDB16tTh+PHjzJs3jz179rBixQqcnZ1JSjIl3Nq1axd7rtq1axMfH09ycjJeXl5cvXr1tvGAOWEUxHt7e1sUfzeVmgAqymuvvVZh721L/hV6BYA9O+qVOiN3xL+P4uGZz68/NSw0Zj/qbHUmj3+Aj+ftpXmrVPoOPMuSBcWP6Xdy1jNxyiE6PGhqkljxZTM2/9rw7n2YSsDR2dS34uJmoNdrRe/Cgx/OQHdfJmf/dOPgFk8aBBWNObrfnespDlSrqUf3gOU1272/mtrzu/RKKzEmPdWOxe/7YjRqGDs7jtBnrpn33f9oOoEtsxnWpQl7f63O/k2ePPh4usXvb3Vq7+r/jk1ISMDuHx0cnp6eeHoWvpEpqAF0796dmTNn4upqGll36dIlRo4cSWRkJHPmzOGdd94hO9tUS3N2di72rQu2F/RVlnf83VR1b69tnFar0K6j6WK8Z4dviXH22jSatzJ1/K35tmiV02jQ8sN3pqplSGjxbb+e1XL5aO5e88V/2aIW/HDLRDNh4u5p6iT2C8zFwbH4q5O/ztRBnBBXfE3r4BbThfzB7tews7fszy/qmAvJ8Y64uhto17nki/aRXR5kZZhmFN968S/g5ZNvXjJizy/VLXrvCqOU4QW8+OKLdOnSpdDr66+/LnL6efPm8euvv/Lxxx+bL/4A9evX56OPPkKj0bBmzRry8/Oxs7NDo9GguU2VyWg03SAUJKDyir+bbLIT+G57e37xEzUqgrvjSSAcNw9HZqzuW2Kcm+NpPKuFkaevyYD3hlNSB66jnal90mB0YuzcwcXGONlfAQ5Sq3YuM1b3Bm7eITnYpRBYaybODtdQFC0Xr71K8DOdCX6m2FNZXeTlkn9G5eF8ciywGr3Rg8jL3xfaZ1c7HNhDVl4AkZenFXt8Ws5vwFFSc7oRefnRIvt3/74YuEa9B0w17H++R3G2bTC9r+6h1pxIea/EuD9P7gd24Vm/OZGX3y82RqkZCWziwoXWRF7++LbvXVHKOhFs1apVxdYA/snJyanEDtVmzZpRt25d4uPjiYmJwcXFhfT0dHJzc3FyKprYc3JMSd/NzTSk2sXFpdD2uxV/a6K6W6pEAvjvGxu5lmwbQ0lb3ZfErHmQeSOP9/qtKTGud79z6IbD3u2ufPLBDyXGzV77LwA05DLj1W+LHbHTpv1VZsyG3Bwt7/VbZ97uWS2XTxbuwdkhg7xcLbOmtmP/3qtAyeWytt92/2jV99PGugOB2Gtv0Mb3hUL7DJ082PJFY5JiLtO8Zj+cXIpeob5NDATcad0ijDa+ywrtu5ZsT+rlltjZK/R8YiInUlYXeY/irD8XAHgS2uV/tPEteWLmJd9agB+G68do47u+2JjIDB+gDt61Tlj03mWVq6/NycT5d3aSMnRW161bt9iLtFpeXl7Ex8eTnZ2Nt7c36enpJCUlUb9+0b64f/YReHt7c+rUKZKTk2ncuLFF8VByG39BfEl9BHdCmoBsVEDQNQDOn61ealyOvh6pKU5otfDoE7HFxnTpdhGAY395mbdpNArvTvuD+g0yyMmx4/0JD7B/b/EzYIVJm4duUK2mntxsO377rujw3vMnnDnxhxsajcKDjxed8Bd13HSn1yAoB0dny69u5/8+LrBV6SOGWj+Y8ff7uBJ1rOhEsLwcjbnp59b1g2xReY4CysjIYPLkyYwePRq9vvjhtJcuXQJMCaVgdE7BqJ1/nuvq1avUrFkTLy/T31dBfMHonlspisKFCxews7MzJ4fS4m9935JGFd0JSQA2KiDQ1NYbG+1xm0gtP/zd9v/y0FN0fjQOzd9/DVo7I/0Hn+KRxy5hMMCab27+Aj32ZCyt26QAsOCT/+OviOJHLIib7OzhpfHxAHw1sx7bN1Q3D6lMvOTAf8f4oygaHnkurdh1gC78PTu3oJ/AEteS7Um96mDRcf66XP7V/RoA04c25HTEzSaD6yl2zHi9IVeinahRO58nB9r4vBoF0wp9Fr8sP7Wbmxtbtmxh06ZNHDp0qMj+Xbt2kZaWhk6nw9vbm5CQEAC2bt1aJHb79u0YDIZC8wkK4rdt21YkPiIigtTUVNq2bYu7u3uh+B07dhRp579y5QqnTp3C19f3rs8BgCrSBHQvqlHL9MeekXH72cM/rw/Av1E63XvE8vbkI7wy4jipKc741s/AxdWAQa9h4Wf/x8lbJqX16mu628jP19C9Rwzde8SUeP7P57autGsBqfXkwBQunnUm7KvazBrVkGUz8qheS0/0aRcMeg26+zIZPq34zvbUq6Y/N/fqpc84vlVKoukYJ2ejRbWGNz+NIynegbN/ujHmKR31GuXi4Gjk0nlnDHoN1WrqmbIi2uaXgy7PxeA0Gg19+vThiy++YPr06Sxfvtw8G/jixYtMm2bq3xk+fDgA3bp1Y/bs2fz444907drVfLGPi4tj9uzZaDQaBg0aZD5/hw4dCAoKIjw8nB9++IE+ffoApqUgpk6dCsDgwTf76/z8/AgJCWHPnj3MnTvXvK5QVlYWkyZNwmAwFIq/myQB2CCtVsHNzXQHmZlhyVekYf4nbTh8oA7dn4lB1zQN/0bppF934uC+umz4PoioW5qSPKvl4udvai5wcFBo0Tq1hPOaFJRFgEZjWrsnuNMNfv7KizN/uRJ33gm/wBwe6ZVGz1eSiu0bAEhPM32Xbh6WJ4AbBcd4WnaMezUDs3+M4teVtdi+oQYXzzpjMGio2yCXDl3SeX74VWrVvUfWASrHeQAjRozg8OHDHDlyhMcff5y2bU0PVzp48CB5eXkMGTKEJ54wPbDJ3d2d6dOnM3r0aIYNG0b79u1xc3PjwIEDZGdnM3bsWJo2bWo+t1arZebMmbz88stMnjyZdevW4e3tzR9//MH169fp06cPjzzySKHyvP/++/Tr14/Fixezfft2GjVqREREBElJSTz88MP069dP3Qe0kEa5B578PnDgQP744w/Vq4Hm5uZy/Phxm+oEvttmrO5bamfyvc7ancDWFHn5+3LtiK1IBZ3ALVu2VNUpW/A3+/7iA6SmW95UVtPTmamv36/q/fLy8lixYgUbN24kJiYGR0dHmjdvzsCBA3nssceKxEdERLBw4UL++usvFEUhMDCQQYMG0b1792LPHxUVxbx588xJxd/fnxdeeIHnn3++yEglgPj4eObNm8fu3bu5ceMGfn5+PPPMM7z88st3pWO7OFIDEELYHis8EMbR0ZHXXnvN4omnwcHBLFu27PaBfwsMDGTevHkWx/v4+PDhhx9aHH833BMJ4NaV84QQlZ8Gle365VaSyk1GAQkhRBV1T9QAhBBVTMHwTjXxQjVJAEIIm2ONZwILSQBCCFtkhU5gIQlACGGDpAZgHZIAhBC2R/oArEISgBDC9pTxgTBCHUkAQgjbI30AViEJQAhhc2QimHVIAhBC2B6jYnqpiReqSQIQQtgeaQKyCkkAQgibI8NArUMSgBDC9sgwUKuQBCCEsDlSA7AOSQBCCNsjfQBWIQlACGFzNChoVDTraCQDlIkkACGE7TH+/VITL1STB8IIIUQVJTUAIYTN0Sgqm4BkFFCZSAIQQtge6QS2CkkAQgjbI/MArEISgBDC5sg8AOuQBCCEsD0KKmsA5VaSSk0SgBDC5mgU0KgY2ik1gLKRBCCEsD3SB2AVkgCEELZHRgFZhSQAIYTtUTkPQGoAZSMJQAhhe6QJyCokAQghbI+sBWQVkgCEEDZHVgO1DkkAQgjbI01AViEJQAhheyQBWIUkACGE7ZE+AKuQBCCEsDmyHLR1yANhhBCiipIagBDC9shicFYhCUAIYXukE9gqJAEIIWyQygQgVYAykQQghLA9MgrIKiQBCCFsjowCsg5JAEII2yN9AFYhCUAIYXuMiumlJl6oJglACGF7pAZgFZIAhBA2SEYBWYMkACGE7ZGJYFZRqROA8vcvkGdNlwouSfmq7uVa0UUoN7n62hVdhHJVWT9fnqEmcPNvUDXpA7CKSp0A8vPzARg2tWsFl6R8vT3/6YouQrk5mVh5PxvAycT5FV2EcpWfn4+zs7P6AxWj6aUmXqhWqROAm5sbOp0OBwcHNBpNRRdHiCpDURTy8/Nxc3Mr6wmkE9gKKnUC0Gq1eHh4VHQxhKiSynTnX0CagKyiUicAIcS9SkYBWYMkACGE7ZEmIKuQBCCEsD0yDNQq5IlgQghRRUkNQAhhe4xG00tNvFBNEoAQwvZIH4BVSAIQQtgeSQBWIX0A96h9+/bx0ksv0bFjR4KDgxk4cCC7d++u6GIJlTZs2ECTJk04fPhwRRfFtijKzbkAlrwkAZSJJIB70IYNGxg8eDCRkZG0bt2aNm3aEBkZydChQ1mzZk1FF09YKDIykunTp1d0MWySohhVv4R60gR0j0lMTOT999/Hw8ODVatWodPpADh69CiDBw9mxowZhIaGUqdOnQouqSjNpk2bmDhxIllZWRVdFNtkROVM4HIrSaUmNYB7zHfffUdeXh6DBg0yX/wBWrduzdChQ8nNzZVagA1LSEhg/PjxjB49GqPRiJeXV0UXyTYV9AGoeQnVJAHcY/bs2QNA165FVzgt2CZ9AbZrzpw5hIWF0bJlS9asWUNAQEBFF8k2FQwDVfMSqkkT0D1EURSioqLQarXFXjgaNmyIVqslKioKRVFkBVQbFBAQwKxZs+jRowdardx/lUhGAVmFJIB7yPXr18nLy6NmzZo4OjoW2W9vb0+NGjVISUkhMzMTd3f3CiilKM1rr71W0UW4JyiKEUXFXb10ApeN3ILcQ7KzswFwcSn5CWcFS/BmZmZapUxClAvpA7AKqQHcQ9Q0GZT5UXxC2AIZBWQVkgDuIa6upmf/5ubmlhiTk5NTKFaIe5I8EtIqJAHcQ9zd3XF1dSUtLQ29Xo+9feGvT6/Xk5aWhpOTE56enhVUSiHunGJUUFTUANTEipukD+AeotFoCAwMxGAwEBMTU2R/dHQ0RqOx0PwAIe5Nxpu1AEte0gZUJpIA7jEhISEAbN26tci+gm2dOnWyapmEuOv+rgFY+pJnApeNJIB7TK9evXBycmLJkiUcP37cvP3YsWMsXboUZ2dnXnzxxQosoRDiXiF9APeY+vXrM2HCBKZNm8YLL7xAx44dATh48CB6vZ5Zs2ZRq1atCi6lEHfGs7a7qqGdnrVlzktZSAK4B/Xv35969eqxdOlSIiIicHR0JDg4mOHDh/PAAw9UdPGEKDM7Ozvs7OwYvnRAmY8VltMoMmBcCGFD9Ho9BoNB9XF2dnZFRsaJ0kkCEEKIKko6gYUQooqSBCCEEFWUJAAhhKiiJAEIIUQVJQlACCGqKEkAQghRRUkCsIJLly7RpEmTYl9NmzaldevWPPzwwwwfPrzYNX4qwtmzZ81lvNU777xDkyZNmDVr1h2/R3JyMunp6Xd8ntv59ttvadKkCQMHDrQofsOGDTRp0oRevXrd8XvPnz+fJk2aMHr06Ds+1+088sgjNGnShB07dpT7e4nKQWZNWFnLli0LPc5RURTy8vK4dOkS27dvZ/v27bz44ou8//77FVjK8rdixQrmz5/P6tWrZelqISqIJAArmzt3LvXr1y+yPT8/nwULFrB48WJWrVpFSEgIjzzySAWUsHRvvvkmQ4cOpUaNGnd0ng8//PAulUgIUVbSBGQjHBwcGDt2LG3atAFg1apVFVyi4nl7e9O4cWNq1qxZ0UURQtwhSQA2pnPnzoBpeWchhChP0gRkY9zdTcvaZmZmmrfNnz+fBQsWMH78eFxcXPj888+5fv06DRo0YOHChfj7+wMQFxfHkiVL2Lt3L1evXsXNzY377ruPQYMGlbhKaFJSEkuWLGHbtm0kJSXh6+tLv3796NChQ7Hx77zzDj/++CNDhgxhwoQJhfbFxcXxzTffsGvXLhISEnB2dqZVq1YMHjyYhx56qNBnKfD0008D8M0335iXtgY4dOgQK1asIDIykvT0dGrVqsW//vUvhg0bZv68/3Tq1Ck+//xzIiIiyMjIoFmzZgwfPrzUn7daycnJrFy5kj179hAXF0d2djYeHh40b96cPn360K1btxKPvXDhAp9++ql56e6mTZvSr18/evToUWx8RkYGK1asYNOmTVy8eBE7Ozt0Oh29evXiueeek5UvxR2TBGBjLl68CICPj0+RfZs3b+bPP//E19cXX19fsrKy8PPzA2DPnj2MHj2arKwsXFxcCAoKIjU1lZ07d7Jz507eeOMNRo0aVeh80dHRDB48mPj4eJydnQkKCiIxMZEZM2bQrl07VeUODw9nzJgx3LhxA1dXVwIDA0lKSmLv3r3s3buXGTNm0Lt3b3x8fAgODiYiIgKA5s2b4+zsjIeHh/lcixYtYu7cuQDUqFEDnU5HXFwc69ev57fffmPu3LlFnnq2ZcsW3nzzTfLy8qhRowaNGzfm9OnTDB06lLZt26r6LCU5deoUgwcPJi0tDVdXV3NfTlxcnPlzjhs3jtdee63IsdHR0fTp04fMzEyCgoLIysoiIiKCiIgIDhw4wMyZMwvFX7p0iSFDhhAbG4u9vT0NGzbEaDQSGRlJZGQkmzdvZtGiRYUGFAihmiLKXVxcnKLT6RSdTqfExcWVGHft2jXl/vvvV3Q6nTJ9+nTz9nnz5pmPnzFjhmI0GhVFUZSUlBTz+YODgxWdTqfMmTNHyc3NNR+7detW874tW7aYtxuNRqVv376KTqdThgwZoqSlpSmKoigGg0FZtmyZ0qRJE/N73mrChAmKTqdTPvroI/O2lJQUpWPHjopOp1MmTZqkZGRkmN9j+fLlik6nU1q0aFHosxec+8yZM4XOv2nTJkWn0ynBwcHKr7/+at6el5enLFy40Lzv8uXL5n3Jycnmz/jf//5Xyc/PVxRFUTIyMpSxY8ea32vAgAEl/uxvtX79ekWn0ynPPvtsoe3PPvusotPplH//+9/KjRs3zNtv3LihjBs3TtHpdErbtm2VvLw8875bv7tHH31UiYqKMu/7/ffflZYtWyo6nU755ZdfzNv1er3Ss2dPRafTKa+//rqSlJRk3nfu3Dmle/fuik6nUz744INC5evcubOi0+mU7du3W/Q5hZA+gAqmKArp6ens3r2bV199ldTUVDw8PHjllVeKxDo4ODBmzBg0Gg2AuSP2q6++IiMjg549ezJmzJhCd4VdunRh3LhxAIWaXg4fPkxkZCSenp589tlnVK9eHQCtVsuQIUN45plnLP4MP/zwA2lpadx3331MmzYNNzc3wPQQ+0GDBhEaGkp+fj6//fbbbc81b948AN59912eeOKJQp99xIgRdO/e3dw0UmD16tVkZGTQoUMH3nrrLfOa8G5ubnz00UclNhmpceXKFS5fvoyzszNTp041N9WBqdnurbfeAuDGjRskJiYWOV6j0TB//nwaN25s3tatWzdzE9WyZcvM27ds2cLJkydp1KgRc+bMwcvLy7wvMDCQOXPmoNVqWb16NSkpKXf82UTVJQnAyrp06VJkIlj79u0ZOnQoR48epUaNGixatKjYJiCdTme+uN5q+/btADz55JPFvueTTz6JRqPh1KlTJCUlAaYmIzA9QL64cfi9e/e2+DPt3LkTgGeffdacnG41depUtm7dyquvvlrqeS5evMi5c+fQarWFLv63euqppwDYvXu3edvevXsBim1Ld3R0LLGNXY169epx8OBBDh48WOzPy9nZ2fzvnJycIvvbtm1bZFIdwHPPPQfAiRMnzBfzbdu2AdC1a1ecnJyKHKPT6dDpdOTn53PgwIGyfSAhkD4Aq/vnRDCtVourqyt16tShTZs2dO/eHVdX12KPrV27dpFtGRkZxMfHA/DZZ5/x+eefF3usnZ0der2e6OhoateuTUxMDGC6oyxOcRerksTFxQEQFBRU7P66detadJ6oqCjgZi2kOAUX19jYWBRFQaPRmD/LrXfXt2ratKlF728JZ2dnzp8/z9GjR4mNjSUuLo5z586Zyw5gNBqLHNesWbNiz1enTh08PDy4ceMG0dHR1KpVi/PnzwPw+++/c+TIkWKPS0hIAEx9C0KUlSQAKytpIpglirsbvHW00MmTJ297jhs3bgCmxAHg4uJSbJyHhwcajQbFggfGXbt2DaDY2okaBWXS6/XmTuKSGI1GMjMzcXd3Nx9XUuK8tYP5Tpw5c4aZM2cWuev29fWlV69erF27tsRjSypbwb4bN26Yk1vB54mLizMn15IUfJ9ClIUkgHvcrRfw/fv3WzxBq6AZIysrq9j9ubm5Fl38wXRXnJGRUeK5LFVwkQwKCuKXX36x+DhPT09SUlIKJcNbFdcko1ZSUhIvvfQS165do2nTpvTu3ZtmzZrRuHFjatSoQV5eXqkJoLSfTUG5C76Tgu907ty5PP7443dcdiFKIn0A9zhPT0/zRf/ChQvFxhgMBvbt20dsbKz5YduNGjUCTEMbi1PQDGGJhg0blnrMjh076N+/f6FO6OIUdNZeunSJvLy8YmOSk5M5fPhwoY7Wgs9y+vTpYo8p6eeixvr167l27RqNGzdmzZo1DBw4kHbt2pmXxCiu4/dWBc1U/xQXF0dGRgZarZaAgADg5s+htHJHRkZy9uzZu5LcRNUlCaASKBgT//333xe7f+PGjQwePJiePXua70S7dOkCmDpTi7t4/fjjjxa/f8Ekr7CwsBLf//Dhw1y/ft28raCz+NZaRmBgIL6+vmRnZ5d4rtmzZ9O/f3/Gjh1r3lbwWdavX1+k/d1oNJZ4LjUuX74MQEBAQKEO3wLr1q0z/7sgyd7q4MGD5r6aW61evRqAdu3amUcWhYaGAvDTTz+Rm5tb5Ji4uDgGDBjA008/TWRkpPoPI8TfJAFUAq+++ipOTk5s3LiRzz77rNBFY8+ePUybNg2A559/3twe3rJlSzp37kx2djajRo0ydyoCrF27VtVaRP3798fT05NDhw4xc+ZM8/srisLKlSv59ddfcXBwoH///uZjCpp7rly5Yt6m0WgYMWIEADNnzuTXX38179Pr9SxdupQNGzYAFOok7tOnD3Xq1OHEiRNMnjzZfFecm5vLlClTSqzlqFFQywkPD+fo0aPm7dnZ2Xz55ZcsWbLEvK24i3ZeXh6jRo0qlGzXrl3LihUr0Gg0jBw50rz9qaeeomHDhsTGxvLGG2+YR26BqSYxYsQI9Ho9zZo1K3GGtxCWkD6ASiAwMJBZs2Yxfvx4Fi9ezMqVK2nUqBFpaWnmO9cHH3zQPFa9wPTp0xkyZAhHjx6la9eu6HQ6UlNTiY+Pp3PnzhavK+/t7c2nn37KG2+8wddff82GDRvw9/cnPj6elJQU7OzsmDZtmvkiCqZRRhEREbz55psEBAQwduxYHnroIXr37s25c+dYsWIFb775Jh9++CF16tTh0qVL5s7mkSNH0rVrV/O53N3d+eyzzxg2bBjr1q1j8+bN+Pv7ExsbS3p6uqrPUpLnn3+e7777jsuXL9OnTx8aNmyIs7MzsbGxZGVl4evri1arJS4ujqtXrxY5PiQkhEOHDtGlSxeCgoJIS0sz1wjGjx/P/fffb451dHRk4cKFvPLKK+zatYvQ0FACAwPJz88nJiYGg8FA3bp1WbRo0R19JiGkBlBJdO/enZ9++onevXtTvXp1zpw5Q1paGq1ateLdd9/lyy+/LLJsQO3atVm1ahUjR47E19eXqKgotFoto0aN4pNPPlH1/iEhIYSFhdG7d2/c3d05c+YMBoOBrl27snr16iIPV5k5cyYdO3ZEURRiYmKIjY0175s4cSLLli3jkUcewWg0mtv2H3roIRYtWlTsw1Xatm3Lhg0b6NWrF66urpw9exZfX18++eQTXnzxRVWfpTienp6sW7eOgQMH0rBhQy5fvkxsbCz+/v6MGjWKsLAwunfvDlBssmnRogWrV6+mY8eOxMTEkJ6ezoMPPsjy5cuLnfQXGBhIWFgYw4cPJyAggJiYGC5evEiDBg0YMmQIP/74I/Xq1bvjzyWqNo1i6VAPIYQQlYrUAIQQooqSBCCEEFWUJAAhhKiiJAEIIUQVJQlACCGqKEkAQghRRUkCEEKIKkoSgBBCVFGSAIQQooqSBCCEEFWUJAAhhKii/h9SoJmFTaFBqAAAAABJRU5ErkJggg==\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.9006583378232759\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>53.125</td>\n",
       "      <td>28.90625</td>\n",
       "      <td>13.4375</td>\n",
       "      <td>7.34375</td>\n",
       "      <td>5.208333</td>\n",
       "      <td>4.296875</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>53.125</td>\n",
       "      <td>28.90625</td>\n",
       "      <td>13.4375</td>\n",
       "      <td>7.34375</td>\n",
       "      <td>5.208333</td>\n",
       "      <td>4.296875</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     53.125  28.90625  13.4375  7.34375  5.208333  4.296875\n",
       "1        NaN       NaN      NaN      NaN       NaN       NaN\n",
       "mean  53.125  28.90625  13.4375  7.34375  5.208333  4.296875"
      ]
     },
     "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": "82ebfe07",
   "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
}
