{
 "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",
    "from src.utils import enrichment_factor"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc50db6c",
   "metadata": {},
   "source": [
    "## Target AKT1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████| 17001/17001 [00:06<00:00, 2584.78it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/atom_weight_superlevel_betti/target_akt1/'\n",
    "\n",
    "for file in tqdm(os.listdir(path)):\n",
    "    if file.endswith('pkl'):\n",
    "        with open(os.path.join(path, file), 'rb') as f:\n",
    "            X.append(pickle.load(f))\n",
    "        target_label = 0 if \"active\" in file else 1\n",
    "        y.append(target_label)\n",
    "\n",
    "active_ind = [i for i, label in enumerate(y) if label == 0]\n",
    "decoy_ind = [i for i, label in enumerate(y) if label == 1]\n",
    "\n",
    "# shuffle the lists\n",
    "random.shuffle(active_ind)\n",
    "random.shuffle(decoy_ind)\n",
    "\n",
    "# Use 90% of the actives for training \n",
    "num_actives = len(active_ind)\n",
    "num_training = int(0.9 * num_actives)\n",
    "active_training_ind = active_ind[:num_training] \n",
    "active_test_ind = active_ind[num_training:] \n",
    "\n",
    "# Use same number of decoys as actives in training (avoid imbalance)\n",
    "decoy_training_ind = decoy_ind[:num_training] \n",
    "decoy_test_ind = decoy_ind[num_training:] \n",
    "\n",
    "# training and test index lists\n",
    "training_ind = active_training_ind + decoy_training_ind\n",
    "test_ind = active_test_ind + decoy_test_ind\n",
    "\n",
    "train_x, train_y = [X[i] for i in training_ind], [y[i] for i in training_ind]\n",
    "test_x, test_y = [X[i] for i in test_ind], [y[i] for i in test_ind]\n",
    "\n",
    "# flatten\n",
    "train_x = [x.flatten() for x in train_x]\n",
    "test_x = [x.flatten() for x in test_x]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5230175d",
   "metadata": {},
   "outputs": [
    {
     "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": [
       "0.9710526315789474"
      ]
     },
     "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=1,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=2)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26957a38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, normalize='true', ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "141c31e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYAAAAE+CAYAAACEB8e6AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABagklEQVR4nO3deVwU9f/A8dcu9ykeoIAoIod3iVeXeZZZaWYeqVlqHqmkP7U0S/NKy76VV5ZmqWVeeZRfq2+meZuSCqkJHggiHiAIgtzs7vz+oF0jFmSQY5X3s8c+qpn3zHwGdN77OUejKIqCEEKIKkdb2QUQQghROSQBCCFEFSUJQAghqihJAEIIUUVJAhBCiCrKurILIIQQ/6TT6dDr9aqPs7KywtpaHmlqyE9LCGExdDodf508hF5xVn2slZUVzZo1kySggvykhBAWQ6/Xo1ecaVjrXWytkkt8XK6+BheSZqPX6yUBqCA/KSGExbHSJmFllVjyeMVQjqW5f0kCEEJYHAMKBkq+SIGaWHGbJAAhhMUx/P2PmnihniQAIYTFMSgKehXLlBlkSbNSkQQghLA4BtQ168j3/9KRBCCEsDh6FLQqEoBe+gBKRRKAEMLiKCo7gRVJAKUiCUAIYXH0ioJGRbu+mv4CcZskACGExTGgrl1f+gBKRxKAEMLiGFBUtevLPIDSkdVAhRCiipIagBDC4ugBNV/q1a8dKkASgBDCAhkAjcp4oZ4kACGExTGgQU0KMKhKF8JIEoAQwuIYFFQ1ARmkD7hUJAEIISyOHg2K1ADKnSQAIYTFMahMAGpixW2SAIQQFsegaNAoKhKAilhxmyQAIYTF0QMaVTUAURqSAIQQFseAFnXzVLUyq7UUJAEIISyOQdGAmmYdRSMJoBTu6wRgMBjIyMjAxsYGjUbaCIWoKIqikJeXh5OTE1qt+kezXuU8ANDc3w+zcnJf/8wyMjI4d+5cZRdDiCorMDAQFxcX1ccZFC2KUvLEoVERK267rxOAjY0NAJ8P/5a067cquTTlY8p/RzO/5+eVXQxRCvfz787Vw4XRX75k+juoVv4wUBUJQIaBlsp9nQCMzT5p12+Rci21kktTfu7ne7vf3e+/u9I2vaqdCCYJoHTu6wQghLg3GRQtBhXNOlppAioVSQBCCItjQKNyeQepAZSGpE0hhKiipAYghLA4erR/TwYrGTUdxuI2SQBCCItjUDTo1bTrl8FaQFu3bmXq1KmsXbuW1q1bF9q/b98+vvnmG06dOkVmZibu7u60b9+eMWPGUKdOnQKxOp2Oli1bkpuba/ZatWvXZv/+/QW2paWlsXz5cnbt2sW1a9eoVasWTz75JCEhITg7Oxc6R3Z2Nl9//TX//e9/uXz5Mi4uLnTs2JFx48bh4eFRonuWBCCEsDgGlTWAu50HHB4ezpw5c4rc/8UXX/Dxxx+j1Wpp0aIFNWvWJDIyko0bN7Jz506+/fZbGjZsaIqPiooiNzeXevXq8cADDxQ6n5ubW4H/T09P56WXXuLs2bM0aNCAjh07cvr0aVatWsWBAwfYsGFDgfkUeXl5jBkzhkOHDuHp6UmHDh2Ijo5m06ZN7N27l++++w4vL6873rckACGExdErGvQql4IorR07djB16lQyMzPN7o+KimLBggU4OjqycuVKWrZsCeQ/hOfNm8e6det4++232bhxo+mYyMhIAHr37s3o0aPvWIaFCxdy9uxZ+vXrx6xZs9Bqteh0Ot5++222bdvGwoULmT59uin+22+/5dChQ3Ts2JElS5Zga2uLoigsWLCA5cuXM3v2bJYtW3bH60rDmRDC4hjQolfxUVNbMIqPj2fy5MmMGzcOg8FArVq1zMZt27YNg8HA0KFDTQ9/yJ9o+vbbb1OjRg3+/PNPrly5YtoXEREBQNOmTe9YjrS0NDZt2oSzszNTpkwxLZ1hbW3NjBkzqFatGps3bzYlKIPBwKpVq9BoNEyfPh1bW1sgf87F//3f/9GgQQP27NlDXFzcHa8tCUAIYXEMaE1zAUr0KcWjbOHChWzbto1mzZqxceNG/Pz8zMbZ2NgQFBREmzZtzO6rW7cuANevXzdtN9YAmjVrdsdyHD16lOzsbB566KFCbf1OTk48/PDDZGdnc/ToUQDOnTtHQkICjRo1Ml3bSKvV0rlzZ4BCfQzmSBOQEMLi6NGgL+elIPz8/Jg/fz49e/YsdsG6cePGMW7cOLP7MjMziYqKAjB1BCuKQmRkJO7u7vz2229s3LiRCxcuYGdnxyOPPEJISEiBZGM8PiAgoMhyApw9e5YOHTqUOL4k66BJAhBCWByDyj4A7d+x8fHxWFlZFdjn6uqKq6troWNGjhx5d4UEVqxYQWZmJs2bN8fT0xOAuLg40tPTSU9P59133yU4OJh27doRGRnJTz/9xN69e1mxYgWtWrUCIDExEQB3d3ez1zBuv3HjRqniiyMJQAhhcdSOAjLGDhw4kKSkpAL7QkJCeP3118u0fJA/LHT58uVotVrefPNN03Zj+3/t2rVZvnw5jRs3BvKHhn788cesXLmSCRMmsHPnTuzs7Ext+w4ODmavY29vD2CKUxtfHEkAQgiLo1e0quYBGNcCWrdundkaQFnbu3cv48aNQ6/XM2nSJNq1a2fa161bN/bu3YtWq6V27dqm7dbW1rz55puEhoZy+vRpdu3axTPPPGMq750WzjMYDACq44sjCUAIYXEUlWsBGVcOrVOnDnZ2duVVLAA2b97MjBkz0Ol0hISEFGpK0mg0puagf9NqtXTo0IHTp0/z119/8cwzz5i+yWdnZ5s9xrjd0dERQHV8cSQBCCEsjl7lTGBVcwbuwoIFC1i2bBkajYapU6cyZMgQ1ecwDjc1PqiNs3b/3XRl9O82f7XxxZEEIISwOMbx/Wriy5OiKEybNo3Nmzdja2vL/Pnzefrpp83Grl27lqNHj9KvXz8eeeSRQvsvX74M3B41ZBzNYxzd828XLlwAICgoCMh/y1pJ4o1xxZEEIISwOIqiyX8xvIr48vTBBx+wefNmnJ2d+fzzz2nbtm2RsXFxcfzvf//DxsamUALIyclhx44dADz22GMAtGnTBnt7ew4fPkxmZmaBppuMjAwOHz6Mo6OjadRQw4YN8fb2JiIigmvXrhVobjIYDOzevRuNRkP79u3veF8yEUwIYXHUzAJWW1tQa//+/axevRpra2uWL19e7MMfoE+fPlhZWbF9+3bTwx7yl46YM2cOV65c4fHHHzfNEnZ0dKRXr16kpqYya9YsdDodkD9qaPbs2aSlpdG/f/8Ck8RefPFF9Ho977zzToHRPosWLeLixYs88cQT1KtX7473JjUAIYTFMSgaVW8EU1NbUGvx4sUA1KxZkw0bNrBhwwazcaNHj6Zhw4b4+/vz1ltvMW/ePMaNG0fz5s3x8vLixIkTxMfH4+fnxwcffFDg2AkTJhAaGsoPP/zA8ePHadKkCREREcTFxdG0adNCw1iHDBnC3r17OXToEE8++STBwcHExMRw7tw5vL29C6wbVBxJAEIIUYSbN29y6tQpABISEti+fXuRsX379jWtCPryyy8TEBDAl19+ycmTJzl79ixeXl689tprjBw5EicnpwLHurm5sWHDBj799FN27drFnj178PT0ZPjw4bz22muF4m1tbfnqq6/44osv+PHHH9mzZw/u7u7079+fkJAQWQ5aCHHvMqBBr2IYqLrXR5q3Zs2aQtvc3Nw4e/Zsqc738MMP8/DDD5c43s3NjWnTpjFt2rQSxTs4ODB+/HjGjx9fqvKBJAAhhAVS+1J4NbHiNkkAQgiLo1dZA1ATK26TBCCEsDiKyhqAIjWAUpEEIISwOHpUzgSWGkCpSAIQQlgcg8q1gMqiE7gqkgQghLA4BkXd5C7pBC4dSQBCCItjUFTWACpoMbj7jSQAIYTFsbTF4O5XkgCEEBZHagAVQxKAEMLi5L8QRsUwUOkELhVJAEIIi6NXVE4EkxpAqUgCEEJYHGkCqhiSAIQQFkdRtOqagGQYaKlIAhBCWBxZC6hiSAIQQlgcA+peCSkzgUtH6k1CCFFFSQ1ACGFx8juBVSwFgQapBKgnCUAIYXEUlYvByTyA0pEEIISwOKrnAUgNoFQkAQghLI5B5TBQNbHiNkkAQgiLo6icCCZNQKUjafMe0aR1Bj/HneDr0IgSxY949yo7rp6gflBWOZdMqOHjn83ETy7xdWgED3gNZkvkKf6zJYouLyRXdtEsivGFMGo+Qj2pAdwDbOwMTPg4DiurksW37pRGr1cTy7dQQrV2T6TyzrJY7BwUcrI05Oh8yM25SouHM2jxcAatO91ifkg9pDEbDIq6sf2GcizL/UxqAPeAlyYmUC8gp0SxbbukMf3Li1jblHOhhCputfKY8ukl7BwUfv62Bn2bNePM9fkMeLApM4f5knFLS+feN3nu1aTKLqpFMPz9Ung1H6Gexf7Ufv/9d15++WXatWtHcHAwgwcPZv/+/ZVdrArn3zyTPq9dJzur+G9DNrYGXn4znpmrY7B3UCqodKKkug9MxsnFwPmTDiyeUpecrNt/9Q7/Uo1V73sC0HuEJAD4uw9AxUeRxeBKxSITwNatWxk6dCjh4eG0aNGCli1bEh4ezogRI9i4cWNlF6/CWFkrTPokDkXRsG5B7SLjatTOY8W+swyakIBep2Hhm3UrsJSiJFo8kg7AoZ+rmX1Yhe50BaBOvVycq+kqtGyWSPoAKobF9QEkJCQwY8YMXFxcWLduHYGBgQCcPHmSoUOHMnfuXDp27Ejt2kU/EO8XL76egF/TbNYu8ODiGYci49xq6fCsn0vEMUcWTa7LxTMO/N9/LldgScWdfP1hHX7bksP5E45m99s73m7FLmlfz/1M9VpAGkkApWFxNYC1a9eSm5vLkCFDTA9/gBYtWjBixAhycnKqRC2gflAWL467zqXzdqxfVHyyS71hzYwhvkzoGVBsohCV50yYE7s21SD2nL3Z/Q93SwXgZpI1qcmSAdQ0/xg/Qj2LSwAHDhwAoGvXroX2Gbfd730BWm1+04+1jcKCN3zIyy3+13Qj3oYjv1aroNKJslbdPY++Y/JHbe353g0ZBSR9ABXFohKAoihERUWh1Wrx8/MrtN/X1xetVktUVBSKcv92dPYelUhQyyx+/LomEUedKrs4ohzZOeiZsfIiLm56bt6wYsMSj8oukkUwKGprAXd/za1btxIUFMSxY8fM7o+JiWHixIl06NCBBx54gB49erBmzRoMBvODUBMSEnj33Xfp0qULLVq0oFu3bixdupTc3Fyz8WlpafznP/+hW7dutGjRgs6dO/PBBx+Qnp5uNj47O5vly5fzzDPP8MADD/DYY48xbdo0rl+/XuJ7tqgEkJqaSm5uLm5ubtja2hbab21tTfXq1cnKyiIjI6MSSlj+vBrkMPiNeK5fsWHlPM/KLo4oR1pNNnO+iaFxq0z0OvgwpB43k2T8LlR8J3B4eDhz5swpcv+ZM2fo06cPP/30E15eXrRv3574+Hjee+89Jk+eXCg+Pj6efv36sXHjRlxdXenYsSMZGRksXryYV199lby8vALx6enpvPTSS3z55ZdoNBo6duyIRqNh1apV9O/fn1u3bhWIz8vLY8yYMXzyySdkZGTQoUMH3Nzc2LRpE7179+bq1aslum+LSgBZWfmzVh0cim7HtrfPb0O9PxNAftOPvYPC4il1ycqQtuD7VbUaOvxrvccDj2ag18PHE3w4vs+1sotlMSqyD2DHjh28+uqrZGZmmt2vKAqTJ08mPT2dDz/8kPXr1/Ppp5+yY8cOgoKC2L59Ozt27ChwzMyZM4mPj2f8+PF8//33LF68mF9//ZVHHnmEP/74gzVr1hSIX7hwIWfPnqVfv378/PPPLF68mB07dvDcc88RFRXFwoULC8R/++23HDp0iI4dO/Lrr7+yePFitm/fzqhRo0hMTGT27NkluneNYkFtKQkJCTz++ON4e3uze/duszGdO3fmypUr7Nu3jzp16hR7vpycHP7666/yKGq5qOW0Ax+31SRnPkJsyusF9rnah9Gw5n/I0dUiImHJHc/V0nsAAJEJH5Kt8ymX8orSsbVKwL/W+9hZJ6AoVsSmjCYl69HKLla5aNasGXZ2diWON/6dnZ/+PSlKyb/kVdc4McX5eVXXi4+P55NPPmHbtm04ODjg5OREUlISa9eupXXr1qa4gwcP8uqrr9K2bdtCD+6wsDAGDBhAmzZt+PbbbwGIjo7m6aefxsfHhx07dqDV3v6effXqVbp27UqdOnVMz7i0tDTat2+PtbU1+/btw9nZ2RSfkZFBp06dyMnJ4fDhwzg6OmIwGOjYsSPXr19n165d1K17e9i3wWDg6aefJiYmhl27duHjU/zffYsaBuromD9ELien6Fmv2dnZBWJLYn7Pz0m5lnp3hasAH26OwucRqOH4OzUcfzcbY2edZHq4v9y2MRO+f5e32nxQKG7H3zXABS9+SexZGRlkKRo0zmLuumjsrHXoDXbMeNmLo7sPAAcqu2hlqrpnNab8d3RlF6NYCxcuZNu2bTRr1ox58+bx3nvvkZRUeCJecQNTgoODqVmzJsePHyc9PR1nZ2cOHjyIoih06tSpwMMfwMvLiyZNmnDq1CmioqLw9/fn6NGjZGdn07Vr1wIPfwAnJycefvhhfvnlF44ePUqHDh04d+4cCQkJNG7cuMDDH0Cr1dK5c2e++uor9u/fz6BBg4r9GVhUAnB2dsbR0ZGUlBR0Oh3W1gWLp9PpSElJwc7ODlfX+6+6fPGMPVbW5itkLtX01A/KITdbw7mT+Q/03BwZ+XAv8WqQw/sboqnuruNWihVXdW9zdPfWyi6WRVLbrFOaPgA/Pz/mz59Pz549Cz2o/ykqKgqgwLD0f2rQoAE3btzgwoULPPDAA6b4gICAIq976tQpzp07h7+/f4niAc6ePUuHDh1KHH/u3Lki78nIohKARqPB39+fkydPcvHiRfz9/Qvsj4mJwWAwFPmLuNd9Nq3oGbztuqYx+5sYkhOtmdTL/C9eWC47BwOzv46huruOmzeseKtfQ0Z9c3/+OS4LFZEARo4cWaI446gad3d3s/uN2421B2O8h4f5EV3/jk9MTCzR+W/cuFGq+OJYVAIAaN++PSdPnmTXrl2FEsCuXbsA6NChQ2UUTYhSGzAuAR//HPR6mDvSl5hIaZYrjoK6sf3K3zOB4+PjsfrXVGpXV9e7ajEwDk4xDkD5N+N2Yyey2njjv4sa/HK38cUpMgHs27fvjgeXhNqHde/evfnyyy9ZsWIFjz32GM2aNQPg1KlTfPnll9jb2zNw4MAyKZsQFcHG1kCPIfnf9nKytLwy5RoAvrVm8vEPcYXi3xvhS0pi1R4OqnZopzF24MCBhdrxQ0JCeP31180dViLGhKK5w3ITxvkAlhZfnCITwKhRo+54gTvRaDRERJTsBSZGdevWZcqUKcyePZsXX3yRdu3aARAaGopOp2P+/PnUrFnzrsolREXybZSNc7X8v4yOzgaatTV+MztLs7aF423tLGZgXqVR/p4IpiYeYN26dWZrAHfD+E3bOADl34zbnZycVMUbB7KUd3xxikwAXl5edzy4vAwaNAgvLy++/PJLwsLCsLW1JTg4mNGjR/Pwww9XWrkqU+guV7p5PVDieDWxonydP+lo9vfxwdG3zI7gEvlLQahqAvo7tk6dOqqGnZaEh4cHkZGRJCUl0bBhw0L7/90mb2z7Nzei6J/xxriSxqs9f1F9BP9UZAIoahx+RenUqROdOnWq1DIIISqH6k7gclwLKCAggH379hEVFWVqkTBSFIXo6GisrKxMycE4Osc4WuffLly4ANweVVTS+KCgoALHlfT8xbGomcBCCAG3awBqPuWlffv2APz222+F9oWFhZGcnEyrVq1MY/iN8Xv27CnUDn/16lUiIyPx9vY2DXJp06YN9vb2HD58uFDHbUZGhmkCWKtWrQBo2LAh3t7eREREcO3atQLxBoOB3bt3o9FoTOUoTqkTQHJyMj///DNLly5l/vz5QP4EriNHjpT2lEIIAVjWctBt27YlICCAQ4cO8d1335m2JycnM2vWLACGDh1q2u7j40P79u2Jjo5m0aJFpu2ZmZlMmzYNvV5fIN7R0ZFevXqRmprKrFmz0OnyXwik0+mYPXs2aWlp9O/fv8AksRdffBG9Xs8777xTIGksWrSIixcv8sQTT1CvXr073pvqYaB5eXl89NFHrF+/vsCCRlOmTOHSpUsMHTqUxo0b8/nnn1eJl7YIIcqBcrtjt6Tx5UWr1TJv3jxeeeUVpk+fzubNm/Hw8OCPP/4gNTWVfv360blz5wLHzJgxgwEDBrBs2TJ2795NgwYNCAsLIzExkccff5wBAwYUiJ8wYQKhoaH88MMPHD9+nCZNmhAREUFcXBxNmzYtNIppyJAh7N27l0OHDvHkk08SHBxMTEwM586dw9vbm+nTp5fs3tT8IAwGA2PHjuWbb75Bp9MRFBREtWq316HPyMhAq9USERHBgAEDSElJUXN6IYQALO+VkC1atGDTpk1069aN2NhYDh06hJeXF7NmzWLmzJmF4n18fEwrcyYnJ7N3716qVavGpEmT+PTTTwutcuDm5saGDRsYPHgwOp2OPXv2oNVqGT58OF9//bVphJGRra0tX331FWPGjMHBwYE9e/aQkZFB//792bBhQ5GT0P5NVQ1gy5Yt7N+/n4YNG7Jo0SL8/f0ZOHAg4eHhADz44IP88ssvjBkzhqioKL766iveeOMNNZcQQohSjwK6G/9e6O3f/P39Wbx4cYnP5+npyfvvv1/ieDc3N6ZNm8a0adNKFO/g4MD48eMZP358ia/xb6pqAFu2bEGj0bB48eJCs3SNfHx8WLJkCVqtttJHEgkh7k3GdwKX+CNvUSsVVTWA8+fP4+fnZ3Ys7D/5+vri6+tLXFzhWY5CCHEniso+AMtZ1P7eoioB6PX6YlfN+ycbG5tCM/KEEKIk8hOA+pnAQh1VTUA+Pj7ExMSQnJxcbFxSUhJRUVF3fBmBEEKYpXYOgLwUvlRUJYBu3bqh0+l49913C73T0ig3N5d33nkHvV5v9gUKQgghLIOqJqChQ4fy3//+l99++41evXrRpUsX07oTO3fu5MKFC3z//ffExsbi6enJkCFDyqPMQoj7nCUtBXE/U5UAnJycWLVqFSEhIURGRhIdHW3aN27cOCB/bYz69evz2Wef3Zdv7RJClD/pBK4YqmcCe3t7s2XLFnbu3Mlvv/1GVFQUGRkZODg4UL9+fTp27MgzzzyDra1teZRXCFEFVMY8gKqoVG8E02q1dOvWjW7dupV1eYQQQhJABbmrV0ImJydz8eJFsrOzcXFxwc/Pr9CUZSGEUEtB3fI+0gJUOqVKAD///DNfffVVobd9abVa2rRpw9ixY2nTpk2ZFFAIUfWofiewzAQuFdUJYNq0aWzZsgXl714XFxcXHB0dycjIID09nSNHjvDHH38wefJkGQUkhCgdqQJUCFUJYPv27WzevBlbW1tGjx5N7969Cyz5fPnyZdatW8fXX3/N/PnzadSoEQ899FCZF1oIcZ9T+5IX6QMoFVUTwdavX49Go+Hjjz9m9OjRhdb7r1u3LpMnT2bmzJkoisKKFSvKtLBCiKrBOAxUzUeopyoBnDlzBh8fH5544oli4/r27YunpycnTpy4q8IJIaomS3ol5P1MVQKwtrbG0dGxRLHVq1c39RMIIYQqCvnNOiX+VHaB702qEkDbtm05f/48MTExxcYlJCRw/vx5goOD76pwQoiqSZqAKoaqBDBp0iQcHR0ZPXo0UVFRZmMSEhIYO3Ys1tbWTJo0qUwKKYSoYpRSfIRqRY4CKuo1Y3Xq1OH8+fP07NmTVq1a0ahRIxwdHcnKyuLixYuEhoaSm5tL+/bt+fXXX2nUqFG5FV4IcX+SeQAVo8gEsGPHjmIPNBgMHD16lKNHj5rdv3//fg4cOGBaJE4IIUpM5gFUiCITQEhISEWWQwghTGQtoIohCUAIIaqou1oMTgghyoU0AVWIUiUAvV5PQkICWVlZhcb663Q6cnNzuX79Ort372bevHllUlAhRFWi+fujJl6opToBrFixghUrVnDr1q0SxUsCEEKoJjWACqEqAfz66698/PHHJYqtV68eTz31VKkKJYSo4iQBVAhVE8G+++47AHr06MG+ffs4cuQIVlZW9OvXj1OnTrFz505GjRqFlZUVBoOBkSNHlkuhhRD3OVXLQGhkNdBSUpUAIiIicHBwYObMmdSuXRs3Nzf8/f05dOgQNjY2+Pj4MGHCBMaPH8+VK1f4+uuvy6vcQoj7mCwFUTFUJYC0tDR8fHwKvPYxICCAq1evkpqaatr28ssvY29vz2+//VZ2JRVCVC2yDES5U5UAHB0d0WgKVrV8fHwAuHDhgmmbvb09vr6+xMbGlkERhRBVjjQBVQhVncA+Pj7ExMSQmZlpWha6fv36KIpCZGRkgdU/s7Oz0el0ZVtaIUSVoFHyP2riSyooKKhEcd988w3t2rUD4Nq1a3Ts2LHI2ODgYNavX19gW0JCAkuXLuXQoUMkJibi6elJz549GTFiBLa2toXOkZaWxvLly9m1axfXrl2jVq1aPPnkk4SEhODs7FzyG1RBVQJ47LHHOH36NNOnT2fWrFk4OzvTvHlzALZs2ULfvn2xtbXl5MmTXLx4kQYNGpRLoYUQ97lyHAXUo0ePIvddunSJEydO4OLiYmrdgPz+T8hPHoGBgYWO+/ezLj4+nv79+xMfH0+TJk1o2rQpYWFhLF68mCNHjrBy5UpsbGxM8enp6bz00kucPXuWBg0a0LFjR06fPs2qVas4cOAAGzZswMXFpeQ3WUKqEsDLL7/Md999x88//8zu3bsJDQ2lYcOGtGvXjj/++IPevXvj5+fHoUOHgPyEIYQQqqlt1lER+9FHH5ndnpmZSe/evU2vvfXy8jLti4yMBGD48OH07NnzjteYOXMm8fHxjB8/njFjxpjOP3bsWH7//XfWrFnDsGHDTPELFy7k7Nmz9OvXj1mzZqHVatHpdLz99tts27aNhQsXMn369BLfY0mp6gOoWbMmK1eupHHjxtja2pqqMe+88w6urq5ERUXx66+/kpGRgZeXl+nGhRBClUp4H8C8efOIiYnhpZdeokOHDgX2GWsATZs2veN5oqOj2bt3L/Xq1eO1114zbXd0dGTu3LlYWVnx7bffmranpaWxadMmnJ2dmTJlClpt/mPZ2tqaGTNmUK1aNTZv3kxmZubd3+S/qJ4J3LhxY7Zu3cq1a9dM2wIDA/npp5/YsmULV65cwdfXl759+5ZLlUUIUQVU8ESwkydPsnnzZjw9PZk4cWKh/ZGRkTg6OpaoWfvgwYMoikKnTp1MD3MjLy8vmjRpwqlTp4iKisLf35+jR4+SnZ1N165dC7X1Ozk58fDDD/PLL79w9OjRQonpbpV6MThPT88C/1+rVi1GjRp11wUSQoiKTgDz5s1DURTeeOONQu89v3nzJlevXqVp06asWrWKbdu2ERsbi4uLC506dSIkJITatWub4o1vSwwICDB7LT8/P06dOsW5c+fw9/cvUTzA2bNnyzwBqGoCEkKIiqF2CGjph4Hu37+f8PBw/P39eeaZZwrtN7b/nz59mgULFlCzZk3atWuHXq/nu+++44UXXiA6OtoUf/36dQA8PDzMXs/d3R2ApKQkABITEwtsLyr+xo0bpbm9YhVZA+jTp89dn1yj0bBp06a7Po8Qomop7TDQ+Ph4rKysCuxzdXXF1dW1yGONKxaMHDmy0DwnuN3+HxgYyGeffWYaHZSZmcn06dP58ccfeeONN9i6dSsAWVlZQP58KHOM241t+sZ/Ozg4lCi+LBWZAP7666+7Prm5H6YQQpSXgQMHmr5ZG4WEhPD666+bjY+OjubQoUN4eXnx7LPPmo0ZMmQITz75JE5OTtSoUcO03dHRkffee4+jR49y+vRp/vzzTx588EFTArrT889gMACoji9LRSaA999/v8wvJoQQJVLKPoB169aZrQEU5ZdffkFRFHr06FHoOCMrK6sCcwL+ycHBgYceeoht27Zx+vRpHnzwQdM3+ezsbLPHGLcb+xrUxpelIhPA888/X+YXE0KI8lSnTh3s7OxKHL9r1y4As23/JVWrVi3gdtOPse3/3zURI2ObvzGupPFF9RHcjSrxSkhtg3pYuZR9+5mlsApsWNlFKDc/791S2UUoN+FXYMfVPyu7GOUiR+dORELpjy/PpSCMbty4wenTp/H19S12eYhPP/2Uc+fOMXbsWLNxly9fBvKTD9wezWMc3fNvxnXTjDOKSxpf0iUs1JBRQEIIy6OgcjE49Zc4efIkAC1btiw27uzZs+zYsYP//e9/hfbduHHDtBy+cd2g9u3bA7Bnz55C7fZXr14lMjISb29v/P39AWjTpg329vYcPny4UEdvRkYGhw8fxtHRkVatWqm/yTuQBCCEsDwVMBPYONClWbNmxcb1798fgFWrVnH8+HHT9oyMDN5++23S09Pp06ePqYnGx8eH9u3bEx0dzaJFi0zxmZmZTJs2Db1ez9ChQ03bHR0d6dWrF6mpqcyaNcu0iKZOp2P27NmkpaXRv3//clkQrko0AQkh7jEVMBHM2HRjbMMvymOPPcbQoUNZtWoVL730EsHBwVSvXp1jx46RkpJC69atmTJlSoFjZsyYwYABA1i2bBm7d++mQYMGhIWFkZiYyOOPP86AAQMKxE+YMIHQ0FB++OEHjh8/TpMmTYiIiCAuLo6mTZsWOYrpbkkNQAhhcYx9AGo+aiUnJwPFjxIyeuutt1i4cCHBwcFERERw4MAB3N3defPNN1m9enWhMfw+Pj5s2rSJ3r17k5yczN69e6lWrRqTJk3i008/xdq64HdvNzc3NmzYwODBg9HpdOzZswetVsvw4cP5+uuvC7yEqyxJDUAIYZnK+U1fK1asUBXfvXt3unfvXuJ4T09PVcPp3dzcmDZtGtOmTVNVrrshCUAIYXkqeC2gqqrUCUCv13P69Gmio6NNLzPIy8vj2rVr1KtXryzLKISoYipiGKgoZQL45ptv+OKLLwosTvTSSy8RFxfHs88+S9euXZk3b165vcZMCHGfK8cXwojbVCeAd955h61bt6IoCtWqVSM3N9c0VTkpKQmDwcDOnTuJi4tj3bp1RS5wJIQQRZImoAqhahTQjh072LJlC+7u7qxYsYLQ0FAaN25s2t+2bVvWrFmDu7s7Z86cMa2yJ4QQalTEKCChMgGsX78ejUbDokWLTLPd/q1NmzYsXboURVHMzpwTQog7qoRXQlZFqpqAIiIi8PHxuePU6ebNm1O/fn1iY2PvqnBCiCpK7bd6SQCloqoGkJOTU+IlSaUDWAhxV+Tbf7lTlQA8PT2JiYm545tp0tPTiYqKMq2OJ4QQwvKoSgCdOnUiJyeHDz74oNi4efPmkZubW+YvMBZCVBHSB1AhVPUBjBgxgm3btrFp0yYuXbpE9+7dSU1NBfL7By5cuMB3333HsWPHcHV1ZdiwYeVSaCHE/U0mglUMVQmgRo0arFixgrFjx3LkyBFCQ0NN+1544QUAFEWhevXqLFmyhNq1a5dtaYUQQpQZ1RPBmjZtyo8//sjGjRvZvXs3UVFRZGRk4ODgQP369enYsSMDBw4s8PJkIYRQRSaCVYhSLQXh7OzMq6++yquvvlrW5RFCCGkCqiCyGqgQwvJIDaBCqEoAP/zwg+oL9OrVS/UxQogqThJAhVCVAN566y00mpKtuqcoChqNRhKAEEI1aQKqGKoSQJMmTYpMANnZ2SQlJZGamopGo+HZZ5+VjmAhROnJQ73cqUoAW7duvWPMsWPHeOutt/jrr7/YvHlzqQsmhKi6pAZQMcr8pfCtW7dm0aJFXLx4kaVLl5b16YUQVYHMBK4QZZ4AIH+ugJ+fH7/++mt5nF4Icb+TBFAhym0YqJWVFYmJieV1eiHEfUyagCpGudQAwsLCiIqKolatWuVxeiHE/U5qABVCVQ1g7dq1xe7Pzc0lJiaG7du3A9ClS5fSl0wIUXXJPIAKoSoBzJkzp0TzABRFoV69eowZM6bUBRNCVF3SBFQxVCWANm3aFH8ya2tcXV1p2bIlffr0kbeCCSFKTx7q5U5VAlizZk15lUMIIUQFU9UJPGzYMN566y3S0tLKqzxCCGFqAlLzEeqpqgGcOHECZ2dnXF1dy6s8QgghncAVRPU8gGrVqpVHOYQQ4jZJABVCVRNQz549OX/+PL/99lt5lUcIIQDQqPiUxg8//EBQUFCRnwULFhSIP3XqFK+99hqPPvooLVu2pG/fvqYh7+bExMQwceJEOnTowAMPPECPHj1Ys2YNBoPBbHxCQgLvvvsuXbp0oUWLFnTr1o2lS5eSm5tbyju8M1U1gJ49exIZGUlISAgPPvggDz74IB4eHtja2hZ5zKBBg+66kEKIKqYCagCRkZEAPProo2ZXLm7cuLHpvw8dOsSoUaMwGAy0adMGBwcHDh8+zBtvvEFUVBQTJkwocOyZM2cYNGgQ6enpBAcH07x5c0JDQ3nvvfc4ceIEH330UYH4+Ph4+vfvT3x8PE2aNKFp06aEhYWxePFijhw5wsqVK7GxsVF/k3egKgEMGDAAjUaDoiiEh4fz559/3vEYSQBCCLUqYh5AREQEAO+//z61a9cuMi47O5s333wTgJUrV/LQQw8BcOnSJQYPHsyyZct44oknaNasGZA/D2ry5Mmkp6fz4Ycf8txzzwGQnJzMkCFD2L59O0888QTdunUzXWPmzJnEx8czfvx40/ypzMxMxo4dy++//86aNWsYNmyY+pu8gzKdByCEEGWiAmoAZ86coVatWsU+/AG2bdvGjRs36N27t+nhD1CvXj3eeOMN3njjDdasWcP8+fOB/NrC2bNnadu2renhD1CjRg1mzpzJgAEDWLNmjSkBREdHs3fvXurVq8drr71mind0dGTu3Ll07dqVb7/9tmITwNWrV7Gzs6NmzZqmbTIPQAhRIco5AcTFxZGWlkaHDh3uGHvgwAHA/NI2nTp1wsrKiv379xeK79q1a6H44OBgatasyfHjx0lPT8fZ2ZmDBw+iKAqdOnVCqy3YLevl5UWTJk04deoUUVFR+Pv7q7rPOymyE7hz586MHz++TC8mhBAloUHlPACV5ze2/9esWZM5c+bwxBNP0Lx5c1PHa05Ojin2/PnzAAQGBhY6j7OzMx4eHiQnJ5OUlARAVFRUkfEADRo0wGAwcOHChQLxAQEBZuP9/PwAOHfunMq7vLNim4AURcZWCSEqQSlrAPHx8VhZWRXY5erqWmjukrH9f+vWrbi5uREcHEzt2rX566+/WLx4MQcOHGD16tXY29ublrV3d3c3e2l3d3euXbtGUlIStWrV4vr163eMB0wJwxjv4eFRoviyVG7vAxBCiNIqbSfwwIEDCz0oQ0JCeP311wtsM9YAunfvzrx583B0dATg8uXLjB07lvDwcBYuXMhbb71FVlYWAPb29mavbdyemZkJUO7xZUkSgBDC8pSyBrBu3TqzNYB/W7x4MXFxcdSrV6/AMPa6devywQcf8Pzzz7Nx40YmTZqElZUViqLccSVk4/h+4/XLK74sSQKoYBqNwidL91LHO4MBzz1bZJx/YAp9XjxHsweScHHN5WaKPUeP1GHt6kakJDuYPaZ9x8s82yuahgE30WoVrlxxZt9vdflhsz+6PCszRyhs+nE7Ts66Isuxe6cPH82tWqO/DAb4vx4BXLtox6bTf5XoGF0ehDwVREykAx9ujuKBR9ILxWxe5s6K2d7/2PIB8GCBmJWHIvBuUHDiT26Ohh++dGfvD25cibEDwK9JFs+9mkTH526aLU9aihVblrtzeEc14mPtQKPg1SCXx5+9Se+Ridg7lv3DpCyVtgZQp04d7Ozs7hhvZ2dXZIdq48aNqVOnDteuXePixYs4ODiQlpZGTk6O2XNnZ2cD4OTkBICDg0OB7WUVb6yllKViE8CNGzf44Ycf7uoCvXr1uqvj7zcvv3qaoCYppKYWPXnuyacv8vqkcKysFJJv2HH5kgt1693i6Z4xPPToVd4I6Uj8NacCxwwd+Rd9B+Z3El1PcCAzw4Z69W4xbNRpOna5zJT/a09GesFretTJxMlZR1aWFdFRbmbLcuVS1VvSe/V8T86GO+FavejE+G/rF9UhJtJ8Yja6eCZ/f72AbFzcdKTnNsLZ9kyBGDv7gk+9tBQrpr7YkKhTjljbGPAJyCE1yZqIY85EHHMm6mQCw6dfK3BM/CVb3ujtT+JVW7RaBS/fHPR6DbFn7Pk6wpP92934cFMUrjX0Jb6/ClfJS0HUqlWLa9eukZWVhYeHB2lpaSQmJlK3bt1Csf/uI/Dw8CAyMpKkpCQaNmxYongouo3fGF9UH8HdKDYBxMbGMnXq1FKfXKPRSAIwURg0JJL+LxXfk+8fmMLrk8LQaGD5py3475aGKIqGGjWzeHtWKE2aJfP6G2G8M6m96Zh2j1yl78Bz5OZqeX9mW0J/9wKglnsm0987QkDQTV57/SQfv9+6wLUa+KUCcDLcnVlvP1LG93vvURT49uM6bFxS/Ljwf4uJtGfDkjv/5YyJyG/LnbwkloAWWYRfeY+W3i8We8zHE+oRdcqRBk2ymLkqhjo++bWDHetrsPBNHzZ9XpuHnkyjWbsM0z28P6Y+iVdtadI6nbc+i6V23TwALp6xZ+4oX2IiHVj4pg/vfnVR1X1WqHJMAOnp6cyfP5/U1FQ++eQTrK0LPwYvX74M5NcoAgICiIqK4sKFC4USQHp6OtevX6dGjRqmV+AGBASwb98+oqKiaNeuXcFiKgrR0dFYWVmZkoNx9I9xNNC/GUcLFTWq6G4UuxaQra0tnp6epf7UqVOnzAt8L6peI5vp7x1h0JAzd4x9dfQprKxg8/pAtm32R1Hy2wWTbzjw0dw2GAzQslUiHrVvdwg981wMAN+tDTI9/AGSEh359JOWADzeOQ47u4LfaH398pf1jr0oq7smX7dm1rAGfPuJuj+zej18MrEeiqLB2qboZhW9Hi5F2aPRKPj4m6/q/9vJw04c+bUaTq563l9/wfTwB+g2IJnOL6QAsGPD7WUMIo46cSbMCXtHPe8sv/3wB/BtlM07yy8CcOh/biRcLvulBcpKeS4H7eTkxM6dO9mxYwdHjx4ttH/fvn2kpKQQGBiIh4cH7dvnf9natWtXodjdu3ej1+sLzCcwxptbMy0sLIzk5GRatWplemGWMX7Pnj2F2vmvXr1KZGQk3t7eZT4HAO5QA2jWrNkd3wNcEbZu3crUqVNZu3YtrVu3vvMBFqRl6wTemRWKo5OO5Bt2bNviz9CRp83G1nTPpPkDSWRmWLPx26BC++OvObFiaQsMBg063e0Oo/Nn3VAU2Le7cPX0Ykz+w93GRqF6jRzir93+lRsTwKWYqp0Aju914b2RvmSmW1HDI49eryay8n2vOx8IbP7cg3MnHOk3NoFf1tUkLcX8d6or0XbkZmvxrJ+DvWPJnla/bcl/sPcecZ3q7oWbo3qPSKSefzb1Am8nlBOH8x8qjVtlUsszr9Axvo2yqe2TQ0KcHVGnHKldN7VEZbmfaDQa+vXrx/Lly5kzZw6rVq0yzQa+dOkSs2fPBmD06NEAdOvWjY8//pjvv/+erl27mh72cXFxfPzxx2g0GoYMGWI6f9u2bQkICODQoUN899139OvXD8hfCmLWrFkADB061BTv4+ND+/btOXDgAIsWLTKtK5SZmcm0adPQ6/UF4suSxXcCh4eHM2fOnMouRqnV872FvYOO33bU44ulzU0PXXMeaJmIVgsnwt3JyjL/7WzblsLfAtasbFrkOQMCbwKQnWXFjRsFh5kZm4BiL7rc6Tbua7Hn7cnK0NKlTzKvzbxCzJni2/KNLl+w49tP6uDtl83gSfH8sq5mkbHG/oH6gSX79g/w58H8h/nD3cz/mWnYLIuGzbIKbOvQIwWv+jm4uBXdvp+dmZ+k9CXv4qgc5TgNacyYMRw7dozjx4/z1FNP0apVKwBCQ0PJzc1l2LBhPP3000D+ZK85c+Ywbtw4Ro0aRZs2bXBycuLIkSNkZWUxYcIEGjVqZDq3Vqtl3rx5vPLKK0yfPp3Nmzfj4eHBH3/8QWpqKv369aNz584FyjNjxgwGDBjAsmXL2L17Nw0aNCAsLIzExEQef/xxBgwYUC4/B4tOADt27GDq1KnlMv61opyLrM64kZ2L7GT9J98G+X/R42LzH8it28XzWIcruNfOJPWmHb/v9+LgPm9KOu/xgeDrjHsjDIAfNvuTl3t7JJC1jR6vuuno9ZCdZc2AlyMJapyMtbVC3CUXdv1Sjwvnq6u72XtU0IMZLN1xrtDDtDiKAp9M8iEvR8P//ScOW/vin1YXz+QnX5+AbA79rxqHd1TjQvQ6vGr78uBjt+jWP7nAObIztSTE2ZqOSb5uzS/ra3I2zJG8PA3+zbJ49pUkPLwLfsv39svF26/o5YMjjjmSeiP/y0W9wJwi4yqbRlHQqJiIqiYW8sfWr169mtWrV7N9+3ZCQ0OxtbXlwQcfZPDgwTz55JMF4rt06cKaNWtYunQpJ06cQFEUgoKCGDJkCN27dy90/hYtWrBp0yYWL15MaGgo58+fp379+kycOJG+ffsWivfx8THF79+/n9jYWHx8fHj55Zd55ZVXzPZTlAWLTADx8fF88sknbNu2DQcHB2rVqlUus+AqQuTpor8V/pt77fwHUGaGDdPmHOaR9gVHd3TscpmjR2ozb0Y7cnKK/tXNmPc7AUEp1KiZg06n4bt1gaxZ2aRATL36t7C2VtDpNHz61W/Y2d1uewxuc50ez1/gu7VBfPNV0bWL+0XTNuq/YGz7qhan/3Dm6ZeSaPFwxh3jjTWAH7+uxabPjIn4EtG4cfAnN7Z+4cGcb6Kp2zD/oXz9ig2KosHBSc+pw87MG12f9NTbv/Pje13ZtrIWby+LpV3Xkr2iVa+HFbPzm7b8mmThG1Ty2kiFq4BRQLa2towcOZKRI0eWKD44OJivvvqqxOf39/dn8eLFJY739PTk/fffL3F8WVD1QpiKsnDhQrZt20azZs3YuHGjaS2M+52DQ/63uef7naftw/Gs+qIpA3o9zfPdejJvRltSb9rS5qEExvzfn0WeQ6NRaNU2gRo18x8k1tYKAYE3qd+g4EPC9+/mH2trhT8OexIyvDM9n3iOV/o9xfpvglAUeHHwWZ7tdaF8bvYeFh9ny6oPPKlZJ5fh066W6JiYyPwagK2dwsSPL7Hpr1PMOTCJeeujaNA4i6sxdkx7yY/M9Py/klkZ+f/W6TS8N9IXL99cPtl2ju0xJ1j1ewQde6WQnWnF3JG+XDp/53HvAMve9SbimDMajcKId6+U4s4rjrwTuGIU+TUyJCQET0/PiiyLiZ+fH/Pnz6dnz56FVse7n9na5n8Lr+aWy8rlTdm8/nZH8MF9dUlPt2Xexwfp0u0Sm9cHEnepcOetRgPDB3Uj9aYt9RukMXTUX7RsfZ35i/YzcXRHrlzOb16Kv+bE9u/9SEu1Ze3q27WDxOuOrFnZlPR0W0aMOcXgYRH8+rMvubnmJpJVTQvf8CE704opn8bi5FqyCVVdXkjhWqwt/V+/bvrmbZNlQ8sO6QRtjWJU5yCuxdqxfVUt+r9+ndyc/D/3eTlanF3z+GBjlOlaXr65TP0slsSrNpz+w5lvP67D28tii73+F7O8+O+q/HHnA8YnEPx44YlqFkVeCVkhiny6hoSE8MILL1RkWUxGjhxJr169qtTDHzA9ZDMzrflhU+GVAf887sHZyOpotdD24Xiz5zAYNFxPcCQnx5pzZ2rwzqT2nD/rhotLHi8OPmuKizhVi88XPVjg4f9P27c2JDPDGhfXPJo2vzeb38rDz2trEH7AhfY9UnjkqZI1vQC8/GY8Uz69ZLbZxbmanh5D8n/GR3bmJ3U7+9uJpdfwRLOJ5sXXEwA4utuVolYJ0OtgwRs+bFmeP0/h6ZeSeGWy+T87FkXtt39JAKVStZ6wFi49Pb9z7vIlZ3Q687+aS3+P2Knteed2Z8hPCFs35ieT5g8klrgsOp3W1BntUefe7YQvS0nXbPhyjjfObjrGvle2TSgNm+b3/1y/kt/x6+R6exRPg8bm2+rr/51MMtOtSEsuXJnPztQwc1gD0+iknkMTGTf/cpmWu9wopfgI1SyyE7isvbnomcougomzbQRwACdnW+auLTgaoLaLFRCHt1+NQvuM6rklA5do2zUI7zb5MfPXd8HWKpnMPPMTRRxsLgBHqVVb96/zGv7+mP9jUNf9BJBCr1cf4vGBj6u4y7ITfsX8z6E8XUiKBdajM7gQfmWDafux7SfJSPsZgBcfaFbk8ZP75P8euox4lCdG3p6xnZedh419weG9xvNHJV0ANmHQuBN+ZQN6rQErm4/R5+mJvjEZ2yuFf7c3E9KAzwA4nfgljjm3h/lm3cpm9f9tIvbkFVNZHhnZnj9L1mVR6SrilZCiiiSA/4z/iZtJlvEttvmDicxfCBnpubwzaFOBfcFtEnjvP2Clj2XW0A1m290/XHSKmg/A96uusm3LJj7a+BhNak/EYICBzz9DWmrhDsGHHr3Ku3Mh4ZqN6ZofLdlLo6bJfPNlU75bV3jSmbW1gQ3/jQVb+GRqJOfPJpTJ/av1894tFX5Nbawz4I+19laBpRp0gS5Etil6mYgz4U7odRp8G2Xh5KLngUbraem9lCM7XZk7yhcrK4VNp//Cxjb/aRV+ZYPp/GfiPQAv/BtfMm0LbBFA5HEn9JeX0NK78M//z5j8cjpX0/Fo4yGm7dmZGqaObkjsSWe0WoUx712mx5ClwNK7/dGUWI7OnYiEJXd3Enmol7sqkQDuFX+GuZN605Zqbrl07xFTaNJXg4Y3adL8BgYDHD6YP5wvR1ebxOsOuHtk8dQzF808zBWe7RUNwNEjt5c5uBhTjSbNk+nYNY4tGwPQ6ws2OXXvEYOjo45rV5yIOlc15gPcSZvOt2jT+VaR+/s2bUZaijVj3rtSYDXQgOaZ6HI15Bq0HPq5Gh173SxwXFaGlv99m7+OTPtnb8/MfbznTSKPO/G/dTXpM7rwCp7/XZ1/zCNPFZzNu3iKDxHH8h/+kxZeomuflFLdb2WSGkDFkD4AC2LQa03j9YeM/IuOXeIwfg3yqJ3JpKnH0Wphz856XE8wLg2rZdO6/EWiBrwSSYfOcabz2TvoCJkYTnCb66Sl2rLpH8lh2+aG5OVp8PVLY9ybYdg7GKeFKnR+4hKvjj4FwMovmpnWIxKlU7OOjk7P5z+El75TlxO/315h9UaCNTOHNiDhsi0Nm2bSuXeyad/Tg5KoUy+HpGu2zBrmS/L1/O9rigJbV7hz6Gc3bOwM9B1z3XTM8X3OpiUkBr8Rf08+/IG/2/UVFZ/KLvC9SWoAFubn/zbAp/4tnnvhApOnH2XoqL9IvWmLr18a1tYKZyOrs3xJiwLH/PiDH37+qTz17EWmvHuU4WNOcSPJHp/6t3Bw0JOWasvsaQ9xI+n2Egdxl1xZ9J9g/m9yGE88dYn2Ha5wOc4Zt+o51HLP71xcvaIJh/Z5I+7e2LmXibtgx7k/nZjcx5/aPjlYOa7ienQTdHlaPH1zmLk6But/dBHYOyrMWh3D1BcbErbflZfbNaGefzY3b1hzI94WK2uFcR9cpl7A7Rm9xtE+AH/85sqxPUUv8zFgfEKxNZrKJDWAiiEJwOJoWL7kAcKPedDj+QsENkrBxSeXy5dc2L3Th/9u8TfTN6Bh8UfBhB314JnnYvAPTKGBXxrXrzvwx2FPtmwIIPlG4fVtdv9an4vR1ejz4jmaP5hE/QZpZKTbcvigJ99v8uevE+bfaSrUc3I18PH3UWxfXYs931fn0nk7DEoy3n45tH8mlT6jr+PgVHgsp2+jbJbvPsPGT2vz+45qXIqyx6Wankefvkm/MddpFFywb+v0H7ffExF53OnfpysgJTG52P2VSuYBVAhJABXs1J/uPN2x9x3j/jjsyR+H1U3EO7ivLgf3FV4RtDjRUW58+F5bVcfc7x54JJ0dV/9Ufdyd3h5ma6fwwqhEXhiVPxz3n53AxXGtoWfEu1cZ8e6dh/BsizpVssJaOI0h/6MmXqgnCUAIYXmkBlAh7okEsGbNmsoughCiAmlQ2QdQbiW5v8koICGEqKLuiRqAEKKKMQ7vVBMvVJMEIISwODIMtGJIAhBCWB7pBK4QkgCEEBZHagAVQxKAEMLySB9AhZAEIISwPGpf8yjP/1KRBCCEsDzSB1AhJAEIISyOTASrGJIAhBCWx6Dkf9TEC9UkAQghLI80AVUISQBCCIsjw0ArhiQAIYTlkWGgFUISgBDC4kgNoGJIAhBCWB7pA6gQkgCEEBZHg4JGRbOORjJAqUgCEEJYHsPfHzXxKun1etavX8/3339PdHQ0er0eHx8fnn76aYYPH46dnZ0p9tixYwwaNKjIc/Xo0YOPPvqowLaYmBiWLFnC8ePHuXnzJvXq1aNfv34MGjQIrbbwq1gSEhJYunQphw4dIjExEU9PT3r27MmIESOwtbVVf4MlIAlACFHl6PV6xowZw969e3F0dOSBBx7A2tqaEydOsHjxYvbt28fXX3+Ng4MDABEREQC0bNmSunULv3c7ODi4wP+fOXOGQYMGkZ6eTnBwMM2bNyc0NJT33nuPEydOFEoW8fHx9O/fn/j4eJo0aULTpk0JCwtj8eLFHDlyhJUrV2JjY1PmPwdJAEIIi6NRVDYBqRwFtGnTJvbu3UtQUBArVqygdu3aACQnJzNmzBjCw8P57LPPmDRpEgCRkZEAvPnmm7Rq1arYcyuKwuTJk0lPT+fDDz/kueeeM517yJAhbN++nSeeeIJu3bqZjpk5cybx8fGMHz+eMWPGAJCZmcnYsWP5/fffWbNmDcOGDVN1jyUhr4QUQlgepRQfFb7//nsA3n77bdPDH6BGjRrMnDkTgJ9++sm0PSIiAq1WS+PGje947kOHDnH27Fnatm1revj/+9z/fM95dHQ0e/fupV69erz22mum7Y6OjsydOxcrKyu+/fZbdTdYQpIAhBCWxzgPQM1HherVq+Pn50eLFi0K7fP19QXg+vXrAOTm5nLhwgX8/PxwdHS847kPHDgAQNeuXQvtCw4OpmbNmhw/fpz09HQADh48iKIodOrUqVDfgJeXF02aNOHKlStERUWpuseSkAQghLA4xnkAaj5qLFu2jP/9739mH+inTp0CoE6dOgCcP3+evLw8vL29WbBgAd27d6dFixZ07tyZ+fPnk5aWVuB444M6MDDQ7LUbNGiAwWDgwoULBeIDAgLMxvv5+QFw7tw5dTdZApIAhBCWR0FlDaCMLqsoLFq0CIAnn3wSuN0BvG/fPr755ht8fHxo1aoVaWlprFy5kr59+5KcnGw6h7Hm4O7ubvYaxu1JSUkF4j08PEoUX5akE1gIYXE0CmhUDO001gDi4+OxsrIqsM/V1RVXV9cSneeTTz7h6NGj1KpVi+HDhwO3O4Dbtm3LokWLqFGjBpDfqTtx4kQOHz7MjBkzWLJkCQBZWVkA2Nvbm72GcXtmZmap4suSJAAhhOUp5VpAAwcOLPRNOSQkhNdff/2Op1i0aBFffPEFtra2LFy40PSgnzp1KoMHD8bd3R1nZ2dTfI0aNZg/fz5PPfUUO3fu5Pr163h4eJgSkEZT/FsKDIb8DKc2vixJAhBCWJ5SLgWxbt06szWA4uh0OmbPns3GjRuxs7NjyZIltGnTxrTfxsaGBg0amD22du3aNGnShGPHjhEREYGHh4dp7kB2drbZY4zbnZycAEocX5IOaLUkAQghLI/KeQDGGkCdOnUKzOC9k4yMDMaPH8+BAwdwdXXls88+K/DwL4latWoBt5tyPDw8iIyMJCkpiYYNGxaKT0xMBG637Rvb/otq4zfGF9VHcDekE1gIYXnKeRgoQGpqKoMHD+bAgQN4enqydu1asw//OXPmMHbsWG7cuGH2PJcvXwZujxoyjuYxN2xTURSio6OxsrIyJYfi4gHTaKGiRhXdDUkAQgjLYyjFR4Xc3FxGjhzJ6dOn8ff3Z8OGDUU+YMPDw9m1axe7d+8utO/cuXNERkbi5uZG06ZNAWjfvj0Av/32W6H4sLAwkpOTadWqlak/wRi/Z8+eQu38V69eJTIyEm9vb/z9/dXdZAlIAhBCWBzjaqAl/qgcB7p48WL+/PNPPD09WbNmjenbuzn9+/cHYMGCBaZv45A/Cmjq1Kno9XqGDx9uWrCtbdu2BAQEcOjQIb777rsC8bNmzQJg6NChpu0+Pj60b9+e6Oho0xBUyB/1M23aNPR6fYH4siR9AEIIy1OObwRLSUkxLcVQo0YN5s2bV2TsRx99RN++fTl06BA7duzgueeeo3Xr1jg4OBAaGkpGRgbdu3cvsE6PVqtl3rx5vPLKK0yfPp3Nmzfj4eHBH3/8QWpqKv369aNz584FrjNjxgwGDBjAsmXL2L17Nw0aNCAsLIzExEQef/xxBgwYUPKfhQqSAIQQlqccE8DRo0dNI2tOnz7N6dOni4z96KOP0Gq1LFq0iI0bN7Jp0ybCw8PRarX4+/vTr18/+vTpU2gIZ4sWLdi0aROLFy8mNDSU8+fPU79+fSZOnEjfvn0LXcfHx8cUv3//fmJjY/Hx8eHll1/mlVdewdq6fB7VkgCEEJanHN8H8OSTT3L27FlVxdFoNLz44ou8+OKLJT7G39+fxYsXlzje09OT999/X1W57pYkACGExSnv5aBFPukEFkKIKkpqAEIIy2NcDE5NvFBNEoAQwvKUYyewuE0SgBDCAqmd3SsJoDQkAQghLE85jgISt0kCEEJYHBkFVDEkAQghLI/0AVQISQBCCMtjUPI/auKFapIAhBCWR2oAFUISgBDCAskooIogCUAIYXlkIliFuK8TgPL3HyDXGg6VXJLy5Var7N8VailydO6VXYRydb/eX64+/4XqSmmbZqQPoELc1wkgLy8PgFEzOt8h8t725qJnKrsI5SYi4f69N4CIhCWVXYRylZeXh729vfoDFUP+R028UO2+TgBOTk4EBgZiY2NTaL1uIUT5URSFvLw8nJycSnsC6QSuAPd1AtBqtbi4uFR2MYSokkr1zd9ImoAqxH2dAIQQ9yoZBVQRJAEIISyPNAFVCEkAQgjLI8NAK4S8EUwIIaooqQEIISyPwZD/URMvVJMEIISwPNIHUCEkAQghLI8kgAohfQD3qN9//52XX36Zdu3aERwczODBg9m/f39lF0uotHXrVoKCgjh27FhlF8WyKMrtuQAl+UgCKBVJAPegrVu3MnToUMLDw2nRogUtW7YkPDycESNGsHHjxsouniih8PBw5syZU9nFsEiKYlD9EepJE9A9JiEhgRkzZuDi4sK6desIDAwE4OTJkwwdOpS5c+fSsWNHateuXcklFcXZsWMHU6dOJTMzs7KLYpkMqJwJXG4lua9JDeAes3btWnJzcxkyZIjp4Q/QokULRowYQU5OjtQCLFh8fDyTJ09m3LhxGAwGatWqVdlFskzGPgA1H6GaJIB7zIEDBwDo2rVroX3GbdIXYLkWLlzItm3baNasGRs3bsTPz6+yi2SZjMNA1XyEatIEdA9RFIWoqCi0Wq3ZB4evry9arZaoqCgURZEVUC2Qn58f8+fPp2fPnmi18v2rSDIKqEJIAriHpKamkpubS40aNbC1tS2039ramurVq3Pjxg0yMjJwdnauhFKK4owcObKyi3BPUBQDiopv9dIJXDryFeQekpWVBYCDQ9FvODMuwZuRkVEhZRKiXEgfQIWQGsA9RE2TQalfxSeEJZBRQBVCEsA9xNEx/92/OTk5RcZkZ2cXiBXiniSvhKwQkgDuIc7Ozjg6OpKSkoJOp8PauuCvT6fTkZKSgp2dHa6urpVUSiHunmJQUFTUANTEitukD+AeotFo8Pf3R6/Xc/HixUL7Y2JiMBgMBeYHCHFvMtyuBZTkI21ApSIJ4B7Tvn17AHbt2lVon3Fbhw4dKrRMQpS5v2sAJf3IO4FLRxLAPaZ3797Y2dmxYsUK/vrrL9P2U6dO8eWXX2Jvb8/AgQMrsYRCiHuF9AHcY+rWrcuUKVOYPXs2L774Iu3atQMgNDQUnU7H/PnzqVmzZiWXUoi74+rurGpop6u7zHkpDUkA96BBgwbh5eXFl19+SVhYGLa2tgQHBzN69Ggefvjhyi6eEKVmZWWFlZUVo798qdTHipLTKDJgXAhhQXQ6HXq9XvVxVlZWhUbGieJJAhBCiCpKOoGFEKKKkgQghBBVlCQAIYSooiQBCCFEFSUJQAghqihJAEIIUUVJAqgAly9fJigoyOynUaNGtGjRgscff5zRo0ebXeOnMpw7d85Uxn966623CAoKYv78+Xd9jaSkJNLS0u76PHfy7bffEhQUxODBg0sUv3XrVoKCgujdu/ddX3vJkiUEBQUxbty4uz7XnXTu3JmgoCD27NlT7tcS9weZNVHBmjVrVuB1joqikJuby+XLl9m9eze7d+9m4MCBzJgxoxJLWf5Wr17NkiVLWL9+vSxdLUQlkQRQwRYtWkTdunULbc/Ly+PTTz9l2bJlrFu3jvbt29O5c+dKKGHxJk6cyIgRI6hevfpdnef9998voxIJIUpLmoAshI2NDRMmTKBly5YArFu3rpJLZJ6HhwcNGzakRo0alV0UIcRdkgRgYTp16gTkL+8shBDlSZqALIyzc/6ythkZGaZtS5Ys4dNPP2Xy5Mk4ODjw+eefk5qaSr169Vi6dCn169cHIC4ujhUrVnDw4EGuX7+Ok5MTDz74IEOGDClyldDExERWrFjBb7/9RmJiIt7e3gwYMIC2bduajX/rrbf4/vvvGTZsGFOmTCmwLy4ujm+++YZ9+/YRHx+Pvb09zZs3Z+jQoTz22GMF7sWoR48eAHzzzTempa0Bjh49yurVqwkPDyctLY2aNWvy6KOPMmrUKNP9/ltkZCSff/45YWFhpKen07hxY0aPHl3sz1utpKQk1qxZw4EDB4iLiyMrKwsXFxeaNGlCv3796NatW5HHRkdH88knn5iW7m7UqBEDBgygZ8+eZuPT09NZvXo1O3bs4NKlS1hZWREYGEjv3r154YUXZOVLcdckAViYS5cuAeDp6Vlo36+//sqff/6Jt7c33t7eZGZm4uPjA8CBAwcYN24cmZmZODg4EBAQQHJyMnv37mXv3r28/vrrhISEFDhfTEwMQ4cO5dq1a9jb2xMQEEBCQgJz586ldevWqsp96NAhxo8fz61bt3B0dMTf35/ExEQOHjzIwYMHmTt3Ln369MHT05Pg4GDCwsIAaNKkCfb29ri4uJjO9dlnn7Fo0SIAqlevTmBgIHFxcWzZsoWff/6ZRYsWFXrr2c6dO5k4cSK5ublUr16dhg0bcubMGUaMGEGrVq1U3UtRIiMjGTp0KCkpKTg6Opr6cuLi4kz3OWnSJEaOHFno2JiYGPr160dGRgYBAQFkZmYSFhZGWFgYR44cYd68eQXiL1++zLBhw4iNjcXa2hpfX18MBgPh4eGEh4fz66+/8tlnnxUYUCCEaoood3FxcUpgYKASGBioxMXFFRl38+ZN5aGHHlICAwOVOXPmmLYvXrzYdPzcuXMVg8GgKIqi3Lhxw3T+4OBgJTAwUFm4cKGSk5NjOnbXrl2mfTt37jRtNxgMSv/+/ZXAwEBl2LBhSkpKiqIoiqLX65WvvvpKCQoKMl3zn6ZMmaIEBgYqH3zwgWnbjRs3lHbt2imBgYHKtGnTlPT0dNM1Vq1apQQGBipNmzYtcO/Gc589e7bA+Xfs2KEEBgYqwcHByk8//WTanpubqyxdutS078qVK6Z9SUlJpnv8z3/+o+Tl5SmKoijp6enKhAkTTNd66aWXivzZ/9OWLVuUwMBA5fnnny+w/fnnn1cCAwOV//u//1Nu3bpl2n7r1i1l0qRJSmBgoNKqVSslNzfXtO+fv7snnnhCiYqKMu375ZdflGbNmimBgYHKjz/+aNqu0+mUXr16KYGBgcprr72mJCYmmvadP39e6d69uxIYGKi89957BcrXqVMnJTAwUNm9e3eJ7lMI6QOoZIqikJaWxv79+xk+fDjJycm4uLjw6quvFoq1sbFh/PjxaDQaAFNH7MqVK0lPT6dXr16MHz++wLfCLl26MGnSJIACTS/Hjh0jPDwcV1dXFixYgJubGwBarZZhw4bx3HPPlfgevvvuO1JSUnjwwQeZPXs2Tk5OQP5L7IcMGULHjh3Jy8vj559/vuO5Fi9eDMDbb7/N008/XeDex4wZQ/fu3U1NI0br168nPT2dtm3b8sYbb5jWhHdycuKDDz4osslIjatXr3LlyhXs7e2ZNWuWqakO8pvt3njjDQBu3bpFQkJCoeM1Gg1LliyhYcOGpm3dunUzNVF99dVXpu07d+4kIiKCBg0asHDhQmrVqmXa5+/vz8KFC9Fqtaxfv54bN27c9b2JqksSQAXr0qVLoYlgbdq0YcSIEZw8eZLq1avz2WefmW0CCgwMND1c/2n37t0APPPMM2av+cwzz6DRaIiMjCQxMRHIbzKC/BfImxuH36dPnxLf0969ewF4/vnnTcnpn2bNmsWuXbsYPnx4see5dOkS58+fR6vVFnj4/9Ozzz4LwP79+03bDh48CGC2Ld3W1rbINnY1vLy8CA0NJTQ01OzPy97e3vTf2dnZhfa3atWq0KQ6gBdeeAGA06dPmx7mv/32GwBdu3bFzs6u0DGBgYEEBgaSl5fHkSNHSndDQiB9ABXu3xPBtFotjo6O1K5dm5YtW9K9e3ccHR3NHuvu7l5oW3p6OteuXQNgwYIFfP7552aPtbKyQqfTERMTg7u7OxcvXgTyv1GaY+5hVZS4uDgAAgICzO6vU6dOic4TFRUF3K6FmGN8uMbGxqIoChqNxnQv//x2/U+NGjUq0fVLwt7engsXLnDy5EliY2OJi4vj/PnzprIDGAyGQsc1btzY7Plq166Ni4sLt27dIiYmhpo1a3LhwgUAfvnlF44fP272uPj4eCC/b0GI0pIEUMGKmghWEua+Df5ztFBERMQdz3Hr1i0gP3EAODg4mI1zcXFBo9GglOCFcTdv3gQwWztRw1gmnU5n6iQuisFgICMjA2dnZ9NxRSXOf3Yw342zZ88yb968Qt+6vb296d27N5s2bSry2KLKZtx369YtU3Iz3k9cXJwpuRbF+PsUojQkAdzj/vkAP3z4cIknaBmbMTIzM83uz8nJKdHDH/K/Faenpxd5rpIyPiQDAgL48ccfS3ycq6srN27cKJAM/8lck4xaiYmJvPzyy9y8eZNGjRrRp08fGjduTMOGDalevTq5ubnFJoDifjbGcht/J8bf6aJFi3jqqafuuuxCFEX6AO5xrq6upod+dHS02Ri9Xs/vv/9ObGys6WXbDRo0APKHNppjbIYoCV9f32KP2bNnD4MGDSrQCW2OsbP28uXL5Obmmo1JSkri2LFjBTpajfdy5swZs8cU9XNRY8uWLdy8eZOGDRuyceNGBg8eTOvWrU1LYpjr+P0nYzPVv8XFxZGeno5Wq8XPzw+4/XMortzh4eGcO3euTJKbqLokAdwHjGPiN2zYYHb/9u3bGTp0KL169TJ9E+3SpQuQ35lq7uH1/fffl/j6xkle27ZtK/L6x44dIzU11bTN2Fn8z1qGv78/3t7eZGVlFXmujz/+mEGDBjFhwgTTNuO9bNmypVD7u8FgKPJcaly5cgUAPz+/Ah2+Rps3bzb9tzHJ/lNoaKipr+af1q9fD0Dr1q1NI4s6duwIwA8//EBOTk6hY+Li4njppZfo0aMH4eHh6m9GiL9JArgPDB8+HDs7O7Zv386CBQsKPDQOHDjA7NmzAejbt6+pPbxZs2Z06tSJrKwsQkJCTJ2KAJs2bVK1FtGgQYNwdXXl6NGjzJs3z3R9RVFYs2YNP/30EzY2NgwaNMh0jLG55+rVq6ZtGo2GMWPGADBv3jx++ukn0z6dTseXX37J1q1bAQp0Evfr14/atWtz+vRppk+fbvpWnJOTw8yZM4us5ahhrOUcOnSIkydPmrZnZWXxxRdfsGLFCtM2cw/t3NxcQkJCCiTbTZs2sXr1ajQaDWPHjjVtf/bZZ/H19SU2NpbXX3/dNHIL8msSY8aMQafT0bhx4yJneAtREtIHcB/w9/dn/vz5TJ48mWXLlrFmzRoaNGhASkqK6ZvrI488YhqrbjRnzhyGDRvGyZMn6dq1K4GBgSQnJ3Pt2jU6depU4nXlPTw8+OSTT3j99df5+uuv2bp1K/Xr1+fatWvcuHEDKysrZs+ebXqIQv4oo7CwMCZOnIifnx8TJkzgscceo0+fPpw/f57Vq1czceJE3n//fWrXrs3ly5dNnc1jx46la9eupnM5OzuzYMECRo0axebNm/n111+pX78+sbGxpKWlqbqXovTt25e1a9dy5coV+vXrh6+vL/b29sTGxpKZmYm3tzdarZa4uDiuX79e6Pj27dtz9OhRunTpQkBAACkpKaYaweTJk3nooYdMsba2tixdupRXX32Vffv20bFjR/z9/cnLy+PixYvo9Xrq1KnDZ599dlf3JITUAO4T3bt354cffqBPnz64ublx9uxZUlJSaN68OW+//TZffPFFoWUD3N3dWbduHWPHjsXb25uoqCi0Wi0hISF89NFHqq7fvn17tm3bRp8+fXB2dubs2bPo9Xq6du3K+vXrC71cZd68ebRr1w5FUbh48SKxsbGmfVOnTuWrr76ic+fOGAwGU9v+Y489xmeffWb25SqtWrVi69at9O7dG0dHR86dO4e3tzcfffQRAwcOVHUv5ri6urJ582YGDx6Mr68vV65cITY2lvr16xMSEsK2bdvo3r07gNlk07RpU9avX0+7du24ePEiaWlpPPLII6xatcrspD9/f3+2bdvG6NGj8fPz4+LFi1y6dIl69eoxbNgwvv/+e7y8vO76vkTVplFKOtRDCCHEfUVqAEIIUUVJAhBCiCpKEoAQQlRRkgCEEKKKkgQghBBVlCQAIYSooiQBCCFEFSUJQAghqihJAEIIUUVJAhBCiCpKEoAQQlRR/w//O3BRJHqVMgAAAABJRU5ErkJggg==\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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7Kao0yQIX2fz58+nefPmFc6Xlpby3nvvsWjRIhISEujTpw/9+/e3Qw0r9+yzzxITE0NAQMA1lTN79uwaqpEQzk26IxyEm5sbkyZNokuXLgAkJCTYuUaWNWrUiNatWxMYGGjvqghxQ5Ag7GCioqIA09KUQogbn3RHOJiybeqv3i15wYIFvPfee0yZMgUvLy8++OADcnNzadGiBe+//z4tW7YEICMjg7i4OH7++WfOnj2Lj48PnTt3ZtSoUVZXVzt37hxxcXH8+OOPnDt3jmbNmvHoo49y8803W8z//PPP89VXXzF69GimTp1aLi0jI4PPPvuMbdu2cebMGTw9PbnpppuIjo7mtttuK3cvZe69914APvvsM/OynAB79uxhyZIlJCUlcenSJRo0aMCtt97KU089Zb7fvzt8+DAffPAB+/btIz8/n3bt2jF27NhKf99qnT9/nqVLl7Jjxw4yMjIoKirCz8+P9u3b8/DDDzNo0CCr1/7111+888475mVH27Zty6OPPsp9991nMX9+fj5Llixhw4YNpKen4+LiQkREBEOGDOHBBx90yhXDREUShB1Meno6AE2aNKmQtnHjRn7//XeaNWtGs2bNKCwsJCQkBIAdO3YwYcIECgsL8fLyok2bNly4cIGtW7eydetWxo8fT2xsbLnyUlJSiI6O5vTp03h6etKmTRuysrKYOXMm3bt3V1XvnTt3MnHiRPLy8vD29iY8PJxz587x888/8/PPPzNz5kyGDh1KkyZN6Nq1K/v27QOgffv2eHp64ufnZy5r4cKFzJ8/H4CAgAAiIiLIyMhg9erVfPfdd8yfP7/C7iGbNm3i2WefRafTERAQQOvWrTly5AgxMTF069ZN1b1Yc/jwYaKjo8nJycHb29vct5+RkWG+z8mTJzNmzJgK16akpPDwww9TUFBAmzZtKCwsZN++fezbt4/du3cza9ascvlPnjzJ6NGjSUtLw9XVldDQUIxGI0lJSSQlJbFx40YWLlxY7iGvcFKKqHUZGRlKRESEEhERoWRkZFjNd/HiReWWW25RIiIilNdee818/t133zVfP3PmTMVoNCqKoijZ2dnm8rt27apEREQo8+bNU0pKSszXbt682Zy2adMm83mj0ag88sgjSkREhDJ69GglJydHURRFMRgMyuLFi5XIyEjza15t6tSpSkREhPL666+bz2VnZys9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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.9729866713761235\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>62.790698</td>\n",
       "      <td>36.046512</td>\n",
       "      <td>18.139535</td>\n",
       "      <td>9.534884</td>\n",
       "      <td>6.511628</td>\n",
       "      <td>4.883721</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>62.790698</td>\n",
       "      <td>36.046512</td>\n",
       "      <td>18.139535</td>\n",
       "      <td>9.534884</td>\n",
       "      <td>6.511628</td>\n",
       "      <td>4.883721</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     62.790698  36.046512  18.139535  9.534884  6.511628  4.883721\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  62.790698  36.046512  18.139535  9.534884  6.511628  4.883721"
      ]
     },
     "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": "8f37d598",
   "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
}
