{
 "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 CXCR4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "94acb9fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████| 3537/3537 [00:00<00:00, 8883.54it/s]\n"
     ]
    }
   ],
   "source": [
    "X, y = [], []\n",
    "path = '../data/DUDE-Diverse_TopologyFeatures/bond_strength_superlevel_betti/target_cxcr4/'\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.981651376146789"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# clf = RandomForestClassifier(n_estimators=rs.best_params_[\"n_estimators\"], \n",
    "#                              min_samples_split=rs.best_params_[\"min_samples_split\"],\n",
    "#                              min_samples_leaf=rs.best_params_[\"min_samples_leaf\"],\n",
    "#                              max_depth=rs.best_params_[\"max_depth\"], \n",
    "#                              bootstrap=rs.best_params_[\"bootstrap\"],\n",
    "#                              criterion=rs.best_params_[\"criterion\"],\n",
    "#                              random_state=0,\n",
    "#                              n_jobs=1)\n",
    "\n",
    "# clf = RandomForestClassifier(n_estimators=100, max_depth=9, random_state=0, criterion=\"gini\")\n",
    "\n",
    "# Very large numbers of base estimators may take a long time to prepare, but will not overfit the training data.\n",
    "clf = RandomForestClassifier(n_estimators=1000, \n",
    "                             min_samples_split=2,\n",
    "                             min_samples_leaf=2,\n",
    "                             max_depth=8, \n",
    "                             bootstrap=True,\n",
    "                             criterion=\"gini\",\n",
    "                             random_state=0,\n",
    "                             n_jobs=1)\n",
    "clf.fit(train_x, train_y)\n",
    "clf.score(train_x, train_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1315b8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(style=\"whitegrid\", color_codes=True, font_scale=2)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(5, 5))\n",
    "plot_confusion_matrix(clf, train_x, train_y, ax=ax)  \n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26957a38",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/demiran1/anaconda3/envs/tda/lib/python3.9/site-packages/sklearn/utils/deprecation.py:87: FutureWarning: Function plot_confusion_matrix is deprecated; Function `plot_confusion_matrix` is deprecated in 1.0 and will be removed in 1.2. Use one of the class methods: ConfusionMatrixDisplay.from_predictions or ConfusionMatrixDisplay.from_estimator.\n",
      "  warnings.warn(msg, category=FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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OGGj0cj48eNZvXo1er2eyMhImjRpYj5fVFSEVqvlyJEjPPbYY+TkWLcflxBCXElWUavGxo0b2bVrF2FhYXz55Zd88cUXldb9vemmm/juu+/o0KEDZ86cYeXKlfVeYSHE9U/VRI3GtKj7xo0b0Wg0LFq0iPDwcIvXhISEsHjxYrRarc1HWAghHFPFHnNWPxy4JawqJ3zixAnCwsJo377qcoxXCg0NJTQ0lPT0xr1vmRCibhSVOWFHnqyhKggbDAar1/x1cXHByan6/c2EEKI6piDcOGbMqUpHhISEkJyczMWLF2u87sKFCyQlJRESUvMKUEIIYZHafHBjyQnfdddd6PV6/vOf/1QannYlnU7Hiy++iMFgsLhjshBCiMtUpSOioqL48ssv+f7773nwwQcZNGgQ58+b1mTYtm0bJ0+e5PPPPyc1NZWWLVsyevTohqizEOI6J5M1quHl5cWHH35ITEwMR48e5dSpU+ZzEydOBEx7v7Vt25alS5c61O4XQgj7ca065vbs2cOyZctITEykvLyczp07Ex0dze233251GUVFRaxcuZJvv/2WjIwMPDw86N69O+PHj+fGG2+s9X7VM+aCg4PZuHEj27Zt4/vvvycpKYmioiI8PDxo27Yt/fv3595777W4Zb0QQljjWqwdERcXx4wZM3B1deWWW27BaDQSHx9PdHQ0s2bN4tFHa9/vMTc3lyeffJLExEQCAwO54447SEtL44cffuDnn39m7dq1dO3atcYy6rR2hFar5a677uKuu+6qy+1CCFGjhg7CWVlZzJw5Ex8fH2JjY81bph08eJCoqChmz55N//79a116Ye7cuSQmJnLvvffy+uuvmxufK1eu5I033uCll17iyy+/rLGMq9re6OLFixw4cIA9e/Zw6NAhioqsXwlfCCGqo9ThocbatWvR6XSMHj260p6VXbt2JTo6mrKyMtavX19DCXD69Gk2bdpESEhIpQAM8NRTT9G5c2dKSkpqHU1Wp5bwN998w8qVK6vsmqHVaunVqxfjx4+nV69edSlaCCHMe8ypuV6N3bt3A1gcwTV48GDmz5/Prl27zH1dlmzduhVFURg1apTF9GtcXJxVdVEdhF966SU2btxIxYYcPj4+eHp6UlRURGFhIXv37uXXX39l6tSpMjpCCFE3apu3qjrxFJKSktBqtZXWvqkQGhqKVqslKSkJRVGq3eatohF64403UlRUxDfffMPhw4dxdnamT58+DBo0yKot4lQF4a+++orPPvsMV1dXxo4dy7BhwyrlTDIyMoiNjeWjjz5i3rx5dOzYUdYWFkKop3ZRHhXX5uXlodPp8Pf3t9iCdXZ2xs/Pj+zsbIqKivD29rZYTlpaGmDqnLv//vvJzMw0n/v444/p06cP7777brX3V1CVE163bh0ajYa3336bsWPHVklat27dmqlTp/LKK6+gKArLly9XU7wQQgCXh6ipeQCcPXuWjIyMSo/8/PxKZZeUlADg4eHx16c1c3c3bepaUz9XQUEBADNmzKBp06Z88skn/Pbbb8TGxhIZGckvv/zCzJkza32tqoLwsWPHCAkJ4c4776zxuocffpiWLVvyxx9/1HidEEJYUtelLEeOHMmgQYMqPT766KNKZVu7/o2pHtXnOXQ6HWBaJ2fVqlV069YNb29vevTowcqVK/Hy8mLz5s0kJyfX+Byq0hHOzs54enpada2fn1+VbyAhhLCKgrr1IC7FytjY2CoLh/110lhFDCsrK6u2uNLS0krXWlLRWr7vvvuqPEdAQAADBw7kq6++4tdff6Vdu3bVlqMqCN9888388MMPJCcn11hoVlYWJ06ckHywEKJO6jpjLigoqNYt7729vfH09CQnJwe9Xo+zc+UwqNfrycnJwc3NrcZZv/7+/oBpApslFcdr22FIVTpiypQpeHp6MnbsWJKSkixek5WVxfjx43F2dmbKlClqihdCCJMGHCis0WgIDw/HYDCQkpJS5XxycjJGo7HS+GFLKs6fO3fO4vmKdXWaNWtWYznVtoQnTZpk8XhQUBAnTpzggQceoEePHnTs2BFPT09KSkpISUkhPj4enU5Hv3792Lp1Kx07dqyxAkII8VcNPU64X79+HDx4kO3bt1fZJWj79u0A3HHHHTWWcfvtt7N69Wq2b9/O5MmTK7WodTod8fHxAPTo0aPGcqoNwlu2bKnxRqPRyL59+9i3b5/F87t27WL37t01DnYWQgiLGnCcMMCwYcNYsWIFy5cv57bbbqNLly4AHDp0iBUrVuDu7s7IkSPN16elpVFeXk6LFi3w8fEBoG/fvnTs2JFjx44xZ84cXnzxRZycnDAajbzxxhtkZGRw6623WhyLfKVqg3BMTIy6VyWEEPWkodeOaN26NdOmTWPWrFmMGDGC3r17AxAfH49er2fevHmV0gijR48mMzOTuXPnMmzYMACcnJx45513+Oc//8natWv58ccf6dSpE8ePHyctLY2WLVsya9asWusiQVgI0SiNGjWKVq1asWLFCg4cOICrqyvdu3dn7Nix9OnTx6oy2rdvzxdffMGyZcvYsWMHO3fuJCAggFGjRjF27FgCAgJqLaNOa0cIIUSDauB0RIUBAwYwYMCAWq+raef45s2b89JLL/HSSy/VqQ51CsIGg4GsrCxKSkqqDGbW6/XodDrOnTvHjh07mDNnTp0qJoRozDSXHmqud0yqg/Dy5ctZvny5ecpebSQICyFUu0YtYXugKghv3bqVt99+26pr27Rpw913312nSgkhGrlGFIRVTdb49NNPAbj//vvZuXMne/fuxcnJiUceeYRDhw6xbds2nn32WfMwjWeeeaZBKi2EuM5VbGOv5uGgVAXhI0eO4OHhwSuvvEJgYCBNmzYlPDycn3/+GRcXF0JCQpg8eTKTJk0iMzOzysIZQghhjbquouaIVAXh/Px8QkJC8PLyMh/r0KEDp0+fJi8vz3zsySefxN3dne+//77+aiqEaFwaam8jO6MqCHt6elZZKT4kJASAkydPmo+5u7sTGhpKampqPVRRCNHoSDrCspCQENLT0ykuLjYfa9u2LYqicPTo0UrXlpaWotfr66eWQohGRaOofzgqVUH4tttuo7i4mJdffpnCwkLAtL8SwMaNG82LHB88eJCUlJRql3gTQogaNfR2y3ZEVRB+8skn8fPz45tvvqFfv37odDrat29P7969OXr0KMOGDWPixIlERUUBpqAthBCqSTrCsmbNmvHBBx/QqVMnXF1dzZvkvfjii/j6+pKUlMTWrVspKiqiVatWjBs3rkEqLYS4zjWilrDqGXOdOnUiLi6OM2fOmI9FRESwefNmNm7cSGZmJqGhoTz88MPmJd+EEEKVRjRZo84L+LRs2bLSv5s3b86zzz571RUSQggJwkIIYVNq87yOmxOuNggPHz78qgvXaDRs2LDhqssRQjQuaoedOfIQtWqD8OHDh6+68L9O7BBCCFFZtUF47ty517IeQghxmeSEYejQodeyHkII0Sg1io65Z/vcRM6ZvNovdECv74OhrW+2dTUazJbTv9q6Cg0mIRO+S70+X1+ZPoAjWXW/X3LCQghhSwrqRkdIEBZCiHokOWEhhLAh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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": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAE+CAYAAACdoOtZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABGb0lEQVR4nO3deVxU5f7A8c8MyC6KCooIAsK4ZqmpdX9ZmpbXW5qZWmquZeZ+1a5a2XVLzW6Le91cWswt98xu7ismqZCaC4oi4oIioMgOM+f3xzSjxABzRpFh/L7va15dz/meM88B/c4z3/Oc59EoiqIghBCi3NOWdQOEEELcH5LQhRDCQUhCF0IIByEJXQghHIQkdCGEcBDOZd0AIYS4W35+Pnq9XvVxTk5OODs/3Cnt4b56IYRdyc/P549jEegVL9XHOjk50ahRo4c6qT+8Vy6EsDt6vR694kWdav/GxSnF6uNy9VU4d2MKer1eEroQQtgTJ+0NnJySrI9XDKXYmvJDEroQwu4YUDBg/UPsamIdmSR0IYTdMfz5PzXxQhK6EMIOGRQFvYpppgwyJRUgCV0IYYcMqCujSP/cSBK6EMLu6FHQqkjoeqmhA5LQhRB2SFF5U1SRhA5IQhdC2CG9oqBRURdXU293ZJLQhRB2x4C6urgtNXS9Xs+yZctYs2YNcXFxuLu706hRI/r06UPr1q0LxcfFxTF37lyOHDnCzZs3CQoKonv37vTq1QuttvC0WNeuXWP+/PlERESQlJSEv78/nTp1YuDAgbi4uBSKT0tL47///S/bt2/n6tWrVKtWjeeff55hw4bh5WXdk7MaWbFICGEvcnJy+OOPP6habQBOztetPk6f70fyjSU0atQIV1dXq44ZO3YsGzduxMvLi2bNmpGXl8ehQ4fIy8tjxIgRDB061Bx7+vRpevXqRXp6Ok2bNqVq1apERkaSlpZGx44d+eSTTwqcOzExkVdffZXExEQaNGhAYGAgUVFRJCUl0aJFC5YsWUKFChXM8enp6fTs2ZOYmBhCQkLQ6XScOHGCS5cuERYWxsqVK6lYsWLJF6UIIYSdyM7OVg4fPqzEXWisXLxUw+pX3IXGyuHDh5Xs7Gyr3mfz5s2KTqdT2rdvryQlJZm3nzlzRmnWrJlSr149JS4uTlEURTEYDErHjh0VnU6nbNiwwRybnJxs3v7LL78UOP+gQYMUnU6nzJ8/37wtIyND6devn6LT6ZTFixcXiJ86daqi0+mUCRMmKHq9XlEURcnLy1P+9a9/KTqdTpkyZYpV1yXT5woh7I4e0CsqXirP/+OPPwLwzjvvUK1aNfP28PBwOnbsiMFgICIiAoCIiAhiYmJo0aIFL730kjm2SpUqTJo0CYClS5eat58/f57du3cTFBTE22+/bd7u4eHBtGnTcHJy4vvvvzdvT0tLY/Xq1Xh5eTFu3Dhz+cbZ2ZmJEydSqVIl1qxZQ2ZmZonXJQldCGF3DDa81JgzZw6bNm3i6aefLrQvIyMDMM7eCLBv3z4A2rVrVyjWVH45cuQI6enpAOzfvx9FUWjTpk2h2nrNmjVp0KABly9fJjY2FoBDhw6RnZ3NE088UahW7unpyZNPPkl2djaHDh0q8bokoQsh7I4BDXoVLwMaVed3cXFBp9MVujm5a9cufvnlFzw8PMwJ3JR4dTqdxXOFhIRgMBg4d+5cgfjw8HCL8aGhoQCcOXNGVXxMTEyJ1yWjXIQQdseggJqh5YZ7GNqRnZ3N2LFjiY2N5dy5c9SsWZOPP/7YXIq5ft14c9bX19fi8abtN27cKBDv5+dnVXxSUpJV509OTi7xWiShCyHsjh4Niopet6mHnpiYaC6VmHh7e+Pt7V3ksVeuXGHLli0FtsXExNC8eXMAsrKyAHBzc7N4vGm7qcatNt70X3d3d6viiyMJXQhhdwwqE7optmfPnuaer8mwYcMYPnx4kcfWqFGDgwcPotVqOXDgANOmTWPq1KlkZmby1ltvmT8gNJri22MwGCv5pR1fHEnoQgi7Y1A0aBQVCf3P2OXLl1vsoRfHw8MDDw8PADp06IC/vz+vvfYa//3vf+nbt6+555ydnW3xeNN2T09PAKvjTe+pNr44ktCFEHZHD2hU9dCNatSoYfWDRUV57LHHCAoKIj4+noSEBPz8/Dh16hQ3btygTp06heL/WgM31c7/+k3hr/GmOGvji6qx301GuQgh7I4BLXoVL4OKVKYoCh9//DGjRo0iPz/fYoxp9Et+fr559IlpNMpfz3X+/HmcnJzMyb64eMA8GsY0asba+Lp165Z4bZLQhRB2x6BoVL+spdFo2LFjBz///LP54aG7JSQkEBcXh4eHByEhIbRq1QqAHTt2FIqNiooiJSWFZs2amceQm+J37dpVqO595coVTp06RUBAAGFhYQA0b94cNzc3fv3110I3PjMyMvj111/x8PCgWbNmJV6bQ5dcDAYDGRkZVKhQocQbDkKI+0dRFPLy8vD09LQ4cVVJ9GhA1dhyjapk1r17dz7++GM+/PBD6tatS40aNQDjhFqjR48mPz+ffv364erqSosWLQgPDyciIoIffviB7t27A5CSksLkyZMB6N+/v/ncgYGBtGrVin379jF79mxGjRoFGEepTJgwAb1eXyDew8ODzp07s3LlSiZPnsy0adNwdnYmPz+fKVOmkJaWRv/+/a2aoMuhJ+e6ffu2efC+EOLB0+l01k0q9SfT5FxZlYehOCVZfZxG74v7zXlWT86Vl5fH0KFD2bNnDx4eHjRt2hS9Xs/Ro0fJzMzkmWeeYd68eebSy7Fjx+jbty+ZmZk8+uij+Pn58dtvv3Hr1i26d+/O1KlTC5w/ISGBHj16kJSUhE6nIyQkxDw519NPP80XX3yBs/Odj6CbN2/y2muvERcXR2BgIA0aNODkyZMkJCTQsGFDli5dar7pWuzPwZETenZ2NidOnOCLN78n7frtsm5OqRj342BmdvqirJshbODIvztvv4oMXvQ6DRs2LHI8tiWmhJ5ReTiKk+WbhJZo9NXwvDlX1WyLer2e5cuXs27dOs6dO4dWq0Wn09GlSxe6d+9e6JtFbGwsc+bMITIyktzcXGrXrs1rr71Gt27dCo2sAbh69Spz5sxh79693L59m8DAQF566SX69u1rsY03b95k3rx5bN++neTkZPz9/Xnuued4++23rf5QdOiSi6nMknb9NqlXb5Vxa0qPI1+bo3P0352tpU61DxapGRFj4uTkRO/evendu7dV8WFhYcyZM8fq8/v7+zNjxgyr4ytXrsyECROYMGGC1cf8lUMndCFE+WRQtBhUTAarlYljAUnoQgg7ZFA94ZYMegAZtiiEEA5DeuhCCLuj+mEh6ZsCktCFEHbIoGjQq6mLq3iwyJFJQhdC2B2Dyh66RnrogCR0IYQd0isa9Gp63dJDByShCyHskGlyLmtJD91IEroQwu4YUDcOXU15xpFJQhdC2B3j4s9qeuhScgFJ6EIIO2RQWUPXSg0dkIQuhLBDake5SMnFSBK6EMLu6BWtqnHoMpeLkSR0IYTdUVTO5aJmZkZHJgldCGF39CqfFFU1Zt2BSUIXQtgdvcpx6GpiHZkkdCGE3VFULvysSA8dkIQuhLBD0kO3jSR0IYTdMSgadU+KSg8dkAUuhBDCYUgPXQhhdwxo0KsYiqhuuTrHJQldCGF31C4SrSbWkUlCF0LYHb3KHrqaWEcmCV0IYXcUlT10RXrogCR0IYQd0qPySVHpoQOS0IUQdsigci4XuSlqJAldCGF3DIq6B4vkpqiRJHQhhN0xKCp76PJgESAJXQhhh+TRf9tIQhdC2B3podtGEroQwu4YF7hQMWxRbooCktCFEHZIr6h8sEh66IAkdCGEHZKSi20koQsh7I6iaNWVXGTYIiAJXQhhh2QuF9tIQhdC2B0D6pagkydFjeR7ihBCOAjpoQsh7I7xpqiKR//RIJ10SehCCDukqJycS8ahG0lCF0LYHdXj0KWHDkhCF0LYIYPKYYtqYh2ZJHQhhN1RVD5YJCUXI/lYKyc0GoXZP53lhz/+KDE2tEEWm+OPMvDfVx5Ay4QagWHZjP7sIt9GnuTRmr1Ze+o4/1kbS9tXUsq6aXbFtMCFmpeQHnq50W9cIvWaZnIrxanYOK9K+YybdxHnCg+oYcJqLZ+7xftfxuPqrpCTpSEnP5DcnCs0fjKDxk9m8Hib28wcFoQUg8GgqBtbbijFtpQn0kO3ewqvj0nktRHXS4ysXC2PacviCK6X/QDaJdSoXC2PcfMu4uqu8PP3VejWqBGnr8+kx2MNmTQgmIzbWp7tcpOX3rhR1k21C4Y/F4lW8xJ2nNAPHDhAnz59aNmyJU2bNqV3797s3bu3rJv1QPn45jFxyQV6j7lWYmyTVreZ98tZ6jXNfAAtE2p16JmCZ0UDZ4+5M2dcLXKy7vzT+/WXSnw9wx+ALgMlocOfNXQVL0Um5wLsNKGvW7eO/v37Ex0dTePGjWnSpAnR0dEMHDiQVatWlXXzHoimz9xm8f7T/O3vaSRfc2bx9BpFxo6YmcBHq87jWzOPg9u82fdTpQfYUmGNxn9LByDi50oWk0/kNm8AagTl4lUp/4G2zR5JDd02dldDv3btGhMnTqRixYosX74cnU4HwLFjx+jfvz/Tpk2jdevWVK9evYxbWrpqh2fj7mlg+2ofvpxUk5Biyiim2vrXM/z537KqjPn84gNsqbDGtx/XYMfaHM4e9bC4383jThXYqfjbJA8F1XO5aCShgx320JctW0Zubi79+vUzJ3OAxo0bM3DgQHJych6KXnrM7x4Mba/jPyODuJ1a/Ofu6gV+9P9bff63rOoDap1Q63SUJ9tXVyH+jJvF/U+2vwXAzRvOJd74fhioKbeYXsIOE/q+ffsAaNeuXaF9pm0PQy395GFPzp9wtyp213ofMtIkCZRXPr55dBuSBMCu9ZWRUS5SQ7eVXZVcFEUhNjYWrVZLaGhoof3BwcFotVpiY2NRFAWNfM0S5Zyru56JSy5QsbKem8lOrJzrV9ZNsgsGRd0qRDJs0ciueui3bt0iNzeXypUr4+LiUmi/s7MzPj4+ZGVlkZGRUQYtFOL+0WqymfpdHPWbZaLPh4+HBXHzhjxAAHJT1FZ21UPPysoCwN296FKDm5uxBpmRkYGXl9cDaZcQ91ulKvmEVfsQz5oZ6PXw6ahAjuzxLutm2Q21dXFJ6EZ2ldC1WjVrCCpWx477cbAtzbErXi4ngal4VnLno0PjC+z765+DKn8B7KVVrxbU6fj6g2uksIqL0zXCqs3A1fkaiuJEwq3BPDf+/3hufMnHPiwUlQld5nIxsquE7uFhHNKVk5NTZEx2dnaBWGvM7PQFqVdv3VvjyljjJ9P5z1rIuJXF+OYfmbd/dGh8gT8DjPn8Is+/CvuW/cbCKZcedFNFMULqZzFt+XlcnfPRG1yZ2Kcmh3buA/aVddPuKx//Sg7RkSpv7KqG7uXlhYeHB6mpqeTnF364Ij8/n9TUVFxdXfH2lq+nonypGZLDjJXnqVo9n9upTsQmv8ehnfL32BIZtmgbu0roGo2GsLAw9Ho9Fy5cKLQ/Li4Og8FQYHy6EOWBq7uBKd/G4eObz81kJ/7VtQ6ZufL3uCiS0G1jVwkdoFWrVgBs37690D7TtmeeeeaBtkmIe9VjxDUCw3LQ62HaW8HEnbLuGYOHlYJxbLnVL6mhA8XU0Pfs2XNf3kBt8u3SpQuLFi1i4cKFPPXUUzRq1AiA48ePs2jRItzc3OjZs+d9aZsQD0IFFwMd+xkn3crJ0tJ33FUAgqtN4tMNCYXiPxwYTGrSwz18Ue1QRBnlYlRkQh80aNA9P7ij0Wg4efKkqmNq1arFuHHjmDJlCq+99hotW7YEIDIykvz8fGbOnEnVqvKIuyg/gutl41XJ+OiLh5eBRi1MM2LG0KhF4XgXV+tHcDkqReWDRSoGvTm0IhN6zZo1H2Q7CujVqxc1a9Zk0aJFREVF4eLiQtOmTRk8eDBPPvlkmbWrLB371Yv2NR+1KvbTUUF8OiqolFskrHX2mIfF352lEUrCyFRKURMviknoO3fufJDtKKRNmza0adOmTNsghCgbqh8skoQO2Nk4dCGEAOmh28rmhJ6SksLBgweJi4sjPT2dcePGkZOTQ3R0NE888cT9bKMQ4iEjPXTbqE7oeXl5fPLJJ6xYsYK8vDzz9nHjxnHx4kX69+9P/fr1+eKLLxx+EQohRClRVN7olJuigMpx6AaDgaFDh/Ldd9+Rn59P3bp1qVTpznJnGRkZaLVaTp48SY8ePUhNTb3vDRZCOD6ZbdE2qhL62rVr2bt3L6Ghofz4449s2LChwLzljz32GL/88gvh4eFcvXqVxYsX3/cGCyEcn6qHimSBCzPVCV2j0TBnzhzCwsIsxgQGBjJ37ly0Wm2Zj5QRQpRPpjVFrX5JDx1QWUM/e/YsoaGh1KlTp9i44OBggoODSUgo/BScEEKURFFZQ7flwSK9Xs+KFStYv34958+fR6/XExgYyD/+8Q/efPNNXF1dC8QfP36c+fPnc/z4cTIzMwkLC6NPnz507NjR4vnj4uKYO3cuR44c4ebNmwQFBdG9e3d69eplcarwa9euMX/+fCIiIkhKSsLf359OnToxcOBAiwv+WKIqoev1eqvnLK9QoQJOsny5EMIGxoReek+K6vV6hgwZwu7du/Hw8ODRRx/F2dmZo0ePMmfOHPbs2cO3335rXmwnIiKCQYMGYTAYaN68Oe7u7vz666+88847xMbGMmrUqALnP336NL169SI9PZ2mTZvyyCOPEBkZyYcffsjRo0f55JNPCsQnJiby6quvkpiYSIMGDWjYsCFRUVHMmTOHgwcPsmTJEipUKHk6CFUJPTAwkLi4OFJSUqhSpUqRcTdu3CA2NtbiuqBCCFEitXVxlTX01atXs3v3burWrcvChQvNI/JSUlIYMmQI0dHRLFiwgDFjxpCdnc2//vUvAJYsWWIeln3x4kV69+7Nl19+yXPPPWeed0pRFMaOHUt6ejoff/wxL730kvnc/fr1Y9OmTTz33HO0b9/e3J5JkyaRmJjIyJEjGTJkCACZmZkMHTqUAwcOsHTpUgYMGFDidamqobdv3578/Hz+/e9/FxiyeLfc3Fzef/999Ho97dq1U3N6IYR4INavXw/Ae++9V2B4dZUqVZg0aRIAmzdvBmDjxo0kJyfTsWPHAs/YBAUF8c477wCwdOlS8/aIiAhiYmJo0aKFOZn/9dx3x58/f57du3cTFBTE22+/bd7u4eHBtGnTcHJy4vvvv7fqulT10Pv378+PP/7Ijh076Ny5M23btiUpKQmAbdu2ce7cOdavX098fDz+/v7069dPzemFEAIo/QeLfHx8CA0NpXHjxoX2BQcHA3D9+nUA9u0zribVtm3bQrFt2rTBycmJvXv3mreZ4i11aJs2bUrVqlU5cuQI6enpeHl5sX//fhRFoU2bNoVK2jVr1qRBgwYcP36c2NjYIgejmKhK6J6ennz99dcMGzaMU6dOcf78efO+ESNGAMavG7Vr12bBggWyqpAQwialfVP0yy+/LHLf8ePHAahRowZgHAwCWFxYx8vLCz8/P65evcqNGzeoVq0asbGxRcYDhISEkJyczLlz53j00UfN8eHh4RbjQ0NDOX78OGfOnLm/CR0gICCAtWvXsm3bNnbs2EFsbCwZGRm4u7tTu3ZtWrduzQsvvGD1XVkhhPgrW+dySUxMLDQYw9vb2+rOpaIozJ49G4Dnn38ewFyF8PX1tXiMr69vgYRu6tkXFw/Ge41w55uAn5+fVfHFsWkuF61WS/v27QsU9YUQ4n6xNaH37NmzUOIbNmwYw4cPt+o8n332GYcOHaJatWq8+eabAGRlZQHg5uZm8RjT9szMzAcSX5x7mm0xJSWFCxcukJ2dTcWKFQkNDcXT0/NeTimEECiom57FFLt8+XKLPXRrzJ49m6+++goXFxdmzZplHsnn5OSEoiglLvhjMBjM8UCpxRfHpoT+888/s3jx4kKrEWm1Wpo3b87QoUNp3ry5LacWQgjzmqJq4sFY9/7rA0Elyc/PZ8qUKaxatQpXV1fmzp1bIH+5u7uTlpZGTk6OxXNnZ2cDmDuzprHrpu33K97Dw6PEa1G9SPSECRMYM2YMJ06cQFEU800BT09P9Ho9Bw8epG/fvnzzzTdqTy2EEEaKDS8bZGRk8Pbbb7Nq1Sq8vb1ZvHhxoXWQTbVtUy39r/5aYzfFF1XztjW+qBr73VQl9E2bNrFmzRoqVKjAyJEj2bNnD4cOHWLPnj0cPnyY7du3M2DAADQaDTNnzuTgwYNqTi+EEEZqJ+ayYXKuW7du0bt3b/bt24e/vz/Lli2zWFkwjT45d+5coX3p6elcv36dKlWqUK1atQLxptErBS5LUTh//jxOTk7mKVSKi7/7fYsaNXM3VQl9xYoVaDQaPv30UwYPHlxovvNatWoxduxYJk2ahKIoLFy4UM3phRACuDNsUc1LjdzcXN566y1OnDhBWFgYK1euLDJhtmrVCoDt27cX2rdz5070en2BXr0pfseOHYXio6KiSElJoVmzZnh5eRWI37VrV6E6+ZUrVzh16hQBAQElDlkElQn99OnTBAYG8txzzxUb161bN/z9/Tl69Kia0wshBFD60+fOmTOH33//HX9/f5YuXWoec25J+/btqVq1KuvXr2fPnj3m7QkJCXz66adoNJoCD1G2aNGC8PBwIiIi+OGHH8zbU1JSmDx5MmB8SNMkMDCQVq1acf78efOQSTCOapkwYQJ6vb5AfHFU3RR1dna2qjAPxiex0tLS1JxeCCGMFNSVUVT00FNTU82P3lepUoXp06cXGfvJJ5/g5eXF1KlTGTFiBIMGDaJ58+Z4enpy8OBBsrKyGDVqFPXq1TMfo9VqmT59On379uWDDz5gzZo1+Pn58dtvv3Hr1i26d+/Os88+W+B9Jk6cSI8ePfjyyy/ZuXMnISEhREVFkZSUxNNPP02PHj2sujZVCb1Fixbs2rWLuLg4QkJCioy7du0aZ8+elbVFhRA2Kc0nRQ8dOmQeOXLixAlOnDhRZKxpVsS2bduydOlS5s+fz9GjR1EUhbp169KvXz86dOhQ6LjGjRuzevVq5syZQ2RkJGfPnqV27dqMHj2abt26FYoPDAw0x+/du5f4+HgCAwPp06cPffv2xdnZulStKqGPGTOGyMhIBg8ezLx58yzWdK5du8bQoUNxdnZmzJgxak4vhBBGtg5Et8Lzzz9PTEyM2hbRtGlTVauwhYWFMWfOHKvj/f39mTFjhup23a3IhD5y5EiL22vUqMHZs2fp1KkTzZo1o169enh4eJCVlcWFCxeIjIwkNzeXVq1asXXr1gJfRYQQwhq2jkN/2BWZ0Lds2VLsgQaDgUOHDnHo0CGL+/fu3cu+ffvMk3YJIYTVSrGH7siKTOjDhg17kO0QQggzW+dyedhJQhdCCAdxT5NzCSFEqZCSi01sSuh6vZ5r166RlZWF8pfxQvn5+eTm5nL9+nV27txZ7BhPIYSwTPPnS028UJ3QFy5cyMKFC7l9+7ZV8ZLQhRCqSQ/dJqoS+tatW/n000+tig0KCuLvf/+7TY0SQjzkJKHbRNVcLqZ5CTp27MiePXs4ePAgTk5OdO/enePHj7Nt2zYGDRqEk5MTBoOBt956q1QaLYRwcKYZFNW8hLqEfvLkSdzd3Zk0aRLVq1encuXKhIWFERERQYUKFQgMDGTUqFGMHDmSy5cv8+2335ZWu4UQDqy0Z1t0VKoSelpaGoGBgQWWmQsPD+fKlSvcunXLvK1Pnz64ublZnD5SCCGsUsqLWzgiVQndw8Oj0Lp3gYGBQMHJ393c3AgODiY+Pv4+NFEI8dCRkotNVCX0wMBAEhISCqw+Xbt2bRRF4dSpUwVis7Ozyc/Pvz+tFEI8VDSK+pdQmdCfeuopMjMz+eCDD0hPTwfgkUceAWDt2rXk5uYCcOzYMS5cuEBAQMB9bq4Q4qHwgNYUdTSqEnqfPn3w8fHh559/plWrVuTm5lKnTh1atmzJqVOn6NKlCyNGjDCvrvHUU0+VSqOFEA5OSi42UZXQq1atypIlS6hfvz4uLi64uLgA8P777+Pt7U1sbCxbt24lIyODmjVrMmTIkFJptBDCwUkP3SaqnxStX78+69at4+rVq+ZtOp2OzZs3s3btWi5fvkxwcDDdunWjYsWK97WxQoiHhDxYZBObJ+fy9/cv8Odq1aoxaNCge26QEEJIQreNzLYohLBDauviUkOHYhJ6165d7/nkGo2G1atX3/N5hBAPF7VDEWXYolGRCf2PP/6455P/9SEkIYQQpafIhH6vq08LIYTNpIZukyIT+ssvv/wg2yGEEOIePRQ3RTXubmg98sq6GaVG6+FR1k0oNf+LPVDWTSg10Zdhy5Xfy7oZpSIn35eT12w/XmrotnkoEroQopxRUDfKRRI6IAldCGGPpIZuE0noQgj7IwndJpLQhRB2R2rotpGELoSwT5KkVZOELoSwP1JysYnNCV2v13PixAnOnz9Peno6r7/+Onl5eVy9epWgoKD72UYhxENGSi62sSmhf/fdd3z11VckJyebt73++uskJCTw4osv0q5dO6ZPn46Xl9d9a6gQ4iGidtEKWeACsCGhv//++6xbtw5FUahUqRK5ublkZ2cDcOPGDQwGA9u2bSMhIYHly5fj7u5+3xsthHBwUnKxiaoVi7Zs2cLatWvx9fVl4cKFREZGUr9+ffP+Fi1asHTpUnx9fTl9+jTffvvtfW+wEMLxySLRtlGV0FesWIFGo2H27Nm0atXKYkzz5s2ZP38+iqLwv//97740UgjxkJEl6GyiquRy8uRJAgMDadKkSbFxjzzyCLVr1yY+Pv6eGieEeEip7XVLQgdU9tBzcnLwsHIiKLkhKoS4J9I7V01VQvf39ycuLo7MzMxi49LT04mNjaVGjRr31DghhBDWU5XQ27RpQ05ODh999FGxcdOnTyc3N5dnnnnmnhonhHhISQ3dJqpq6AMHDmTjxo2sXr2aixcv0qFDB27dugUY6+vnzp3jhx9+4PDhw3h7ezNgwIBSabQQwrHJg0W2UZXQq1SpwsKFCxk6dCgHDx4kMjLSvO+VV14BQFEUfHx8mDt3LtWrV7+/rRVCCFEk1Q8WNWzYkJ9++olVq1axc+dOYmNjycjIwN3dndq1a9O6dWt69uxJlSpVSqO9QoiHgTxYZBObHv338vLijTfe4I033rjf7RFCCCm52EhmWxRC2B/podtEVULfsGGD6jfo3Lmz6mOEEA85Seg2UZXQx48fj0Zj3axmiqKg0WgkoQshVJOSi21UJfQGDRoUmdCzs7O5ceMGt27dQqPR8OKLL8qNUSGE7SRJq6Yqoa9bt67EmMOHDzN+/Hj++OMP1qxZY3PDhBAPL+mh20bVk6LWePzxx5k9ezYXLlxg/vz59/v0QoiHgTwpapP7ntDBOFY9NDSUrVu3lsbphRCOThK6TUpt2KKTkxNJSUmldXohhAOTkottSqWHHhUVRWxsLNWqVSuN0wshHJ300G2iqoe+bNmyYvfn5uYSFxfHpk2bAGjbtq3tLRNCPLxkHLpNVCX0qVOnWjUOXVEUgoKCGDJkiM0NE0I8vKTkYhtVCb158+bFn8zZGW9vb5o0aULXrl1l1SIhhO0kSaumKqEvXbq0tNohhBDiHqm6KTpgwADGjx9PWlpaabVHCCHMJRc1L6Gyh3706FG8vLzw9vYurfYIIYTcFLWR6nHolSpVKo12CCHEHZLQbaKq5NKpUyfOnj3Ljh07Sqs9QggBgEbFSxip6qF36tSJU6dOMWzYMB577DEee+wx/Pz8cHFxKfKYXr163XMjhRAPGemh20RVQu/RowcajQZFUYiOjub3338v8RhJ6EIItWQcum3u6zh0IYS4L6SHbpMiE/qVK1dwdXWlatWq5m0yDl0I8UBIQrdJkTdFn332WUaOHPkg2yKEEMCfNzvVjEMv6wbbiWJLLooiH3tCiDIgPXSblNp86EIIYSu5KWqbUpkPXQgh7kkZzIe+bt066taty+HDhy3uj4uLY/To0TzzzDM8+uijdOzYkaVLl2IwGCzGX7t2jX//+9+0bduWxo0b0759e+bPn09ubq7F+LS0NP7zn//Qvn17GjduzLPPPstHH31Eenq61dcgPXQ7VTs8k9eGXKLxE2l4eOm5dsmViF+qsP4bf9JvVbB4zILNvxNSN6vIc544XJF3XmtUWk12SGeOurNybnX+iPQkM92JajXyaNkuje5Dr1G1Rn6h+JwsDRsW+7J3U2Uun3dFr9fgF5DLk8/fotuQ61Sqqi/xPZMTnXnzmfo0ffo2Hyy8UGL8xiXVWDChFpO/Pc8TzznGPEsPuoceHR3N1KlTi9x/+vRpevXqRXp6Ok2bNuWRRx4hMjKSDz/8kKNHj/LJJ58UiE9MTOTVV18lMTGRBg0a0LBhQ6KiopgzZw4HDx5kyZIlVKhw599xeno6r7/+OjExMYSEhNC6dWtOnDjB119/zb59+1i5ciUVK1Ys8TqKTejJycls2LChxJMUp3Pnzvd0/MPoyXYpjJ99BhdXhexMLRdj3fH1z6Xn8Mu07ZLE+/0acDnOvcAxTs4GaoVkk5+nIeao5WmL42I8HkTzHcbBrd5MfiMEg15DRZ98aodncyXelQ2Lfdm+1ocZK86he/TOB2haqhNju4URd9IdjUbBr1YuLq4KVy64svqL6uze6MPM1bEEhFjuoQHk5miYObw2mbedrGrj2WPufD3D/56v1e48wBr6li1bePfdd8nMzLR8akVh7NixpKen8/HHH/PSSy8BkJKSQr9+/di0aRPPPfcc7du3Nx8zadIkEhMTGTlypHldiMzMTIYOHcqBAwdYunQpAwYMMMfPmjWLmJgYunfvzuTJk9FqteTn5/Pee++xceNGZs2axQcffFDitRSb0OPj43n33XdL/okUQaPRSEJXqXqtbP716VlcXBUObPXhs3FhZNx2RqtV6DU8gZ7DLzN18SkG/f0x8nLvVMwC62RRwUUhLsZdeuH3QdKVCswcXhuDXkPPfyby+uhEnJwhO1PDvPdqse2HqkwbFMySiFM4/Zl7546vRdxJdwLDsnn/vxcIqZ8NwPVLFfhoaG1OHPJi+tvBzPvlDJbWicnK0DJ9cG2ORpTcEwM4He3Bv/uEkJVhXfIvVx5AQk9MTOSzzz5j48aNuLu7U61aNW7cuFEoLiIigpiYGFq0aGFO5gBVqlRh0qRJ9OjRg6VLl5oT+vnz59m9ezdBQUG8/fbb5ngPDw+mTZtGu3bt+P77780JPS0tjdWrV+Pl5cW4cePQao3/rp2dnZk4cSK7d+9mzZo1jBkzBg+P4jtlxdbQXVxc8Pf3t/lVo0YNK3+0wqTLgKu4exqIP+vOjJE6Mm4bP3MNBg1LZwdx9KA3/kE5vNT3aoHjQuoaexcXz0ov/H7Yuc6HzNtONP7bbfqONSZzADcPhREzL1HRJ5/Ei678vt/4bSjpSgX2/VQZrVZh3Lx4czIH8KuVx4SFF3D31BN73IPjBz0Lvd/ZY+6M+IeO37aXPPmdXg8bF1fjnS5h3Eq2XH4r7x7E9LmzZs1i48aNNGrUiFWrVhEaGmoxbt++fQC0a9eu0L6mTZtStWpVjhw5Yq5179+/H0VRaNOmjTk5m9SsWZMGDRpw+fJlYmNjATh06BDZ2dk88cQThRYF8vT05MknnyQ7O5tDhw6VeE3F9tAbNWpU4jqiD8K6det49913WbZsGY8//nhZN6dUNX3qJgCbltYgP6/w5+1P39fg0SfSaNPpBmsWBpi3B/+Z0OMlod8XVWvk0erFm/xfh5uF9rm4KgSE5HA61ZkbV4zzGB0/6IWiaPAPziG8ceH7GFX88gl/NJNjByoSe9yDxk9mmPctn12dpf+pgcGgoV7TDOo0ymLzd5YXWM/N1jDyRR3n/yzr9BqVyPbVVbh2qej5lIRloaGhzJw5k06dOhVKvHczJV6dTmdxf0hICMnJyZw7d45HH33UHB8eHl7k+x4/fpwzZ84QFhZmVTxATEwMzzzzTLHXZPc3RUu6WeFofGvmABB7onAvDuDyBTcAausycXW7c4MtxJzQ3S0eJ9Rp1zWVdl1TLe7LztRy6ZwrADVDjL+vR55IZ8JXcWiK+c6bnWncqf/LvdQzv3tQwdXAayOu8+rQayyfVfQ329wcLedPuhOky2LER5d45IkMtq+uouLKypFSHor41ltvWRV3/fp1AHx9fS3uN203lWtM8X5+flbFJyUlWXX+5OTkEttq1wm9pJsVjszJyfLfZmdn5c/9UK3GnZtrph76zRsVeOWNKzRsnoabu4GrF13Z/VM1jkfKPPb3w8WzrnzxQQDpt5xp2DydR54w9rR9a+bhW/NWkcddu1SBuJPGD9sgXU6Bfe26pTD8owSqVi88auavKrgY+NeceNp0TjWXgRyRRlHQqHiw0RSbmJiIk1PBewre3t73tChPVpbxG5ebm5vF/abtpjylNt70X3d3y52xv8YXxy7/Slh7s8IRXbvkRlBYFsF1MzkZVfgvYVDYna/zXpWMCcCzYj6+/sbkPnXJKTy87oyLbfJ/8I8e19m62pfZE+pg0MtD0rb4/tPqbF9ThcSLLiiKhieev8WYzy5affziD2uSl6vFxzePJk/dLrDvqX8U/UHwV67uSpHfHByKjTdFe/bsWShXDBs2jOHDh9vcFNMHhMbSney7mMajl3Z8cewyod99s2L69Ol8+OGHD01Cj9zpQ1BYFq+8eYVta/0KjGTRaBReefOK+c/OFYx/i0Pq3fnkPnPci+8+C+LcSQ88K+p5puMN+o25yPPdkki76czimcEP7FocybGDXlyNdzX/+coFF47+6kWrF0pOxqu/8GXPjz4A9B9/FRc3eayxJLaOQ1++fLnFHvq9MPWcs7OzLe43bff09FQVbxqxoja+OEUm9GHDhuHvXzbjW629WeGI1n/tz/Ndr1Ozdg5TFp9i0YxgLpxxp0ZgDgP+FU/N4Cyys7S4uRvQ5xs/0W/fdGb91/5otQpfTQvGYDBuz81xYsPXNUm64sqE+Wfo3C+Rjd/5c+Oqa3FNEBaM/iyBKr55XLvkwsYl1fjp22pMeyuY8Qviaf3SzSKP27i4GoumGm9et30lhfY9Uh5Qi8s5G3voNWrUwNX1/v799vPz49SpU9y4cYM6deoU2v/XGripdl5UJ9QUb4qzNr6oGvvdik3oZcXamxWOKDXJhcmD6jHpq9M89mQa8348Zt6Xma7lo3/q+Of0c7i5G8hMN/ZE4s968NW04CLPGbGlKpfOu1ErNJvHn77JL6uql/ZlOJwagcaSVmBYDsOmX8bJCTYs9mXJdH9avXgTJwtDwb//tDpLPzV2ilq0u8WoTxMeZJPLN7VDEUvxS094eDh79uwhNjaWli1bFnxbReH8+fM4OTmZk71ptIpp9MpfnTt3Drgzasba+Lp165bY1oer+1tOnIquyFvtH2Pp7Foc2l2ZQ7srs2J+AG93eIzDeyrj5W2snadct36o2rlTxq+DfjVzSogU1ug+7BoA1xJcSbpc8Peg18Pn7wSak/n/dbjJvxddoIKLlFqsVgZzuRSlVatWABbXUo6KiiIlJYVmzZqZx5Cb4nft2lWo7n3lyhVOnTpFQEAAYWFhgHHhIDc3N3799ddCNz4zMjL49ddf8fDwoFmzZiW21S5r6Pfb2FX9y7oJ96xeONTrDO4VzuPkHEmu3of3No0GYPqeEYABDQaUIn6lwT6zgGRa936Sep1feVDNvmfRl0eUyftmpmWTnJBK9dCquLhb/uB0cf+U3Kw8Ik/OIMjJWFbJz81n+fsbObn7LACPd2rMC+/9nT+SLPedoi+vLLTt6u19QAQ3s1oSffmjEtuao18ApHE+eSyul8Osu0A7Z0+zLbZo0YLw8HAiIiL44Ycf6N69O2B89H/y5MkA9O9/J8cEBgbSqlUr9u3bx+zZsxk1ahRgHKUyYcIE9Hp9gXgPDw86d+7MypUrmTx5MtOmTcPZ2Zn8/HymTJlCWloa/fv3L/TQkSUPRUL/+NWvuZl4u+RAO9Dw8TTqPprOicMViTla+BHwnsMTqDcSIn5y4uMxc5i+ZwQ3jwzj6X8ks2W1H3M/KFzjA1i49Sg+obDk/WPs/9/l0r6M++Z/sQfK5H17vNiQlGsVmPBVHC1fLHzj8/ZNJ/KyGwEanmw0Hr+APPR6mP52MCd3Vwag+9BrvPH+d8B3Ft8j+vJKmgS8Vmj7HxVrADWo7B5Jk4BVJbbV1akB4EJo1Y9pEmAfk3Pl5Pty8trcezuJnXyh0Wq1TJ8+nb59+/LBBx+wZs0a/Pz8+O2337h16xbdu3fn2WefLXDMxIkT6dGjB19++SU7d+4kJCSEqKgokpKSePrpp+nRo0eB+FGjRhEZGcmGDRs4cuQIDRo04OTJkyQkJNCwYUOrR+lIycXO1Hs0nYHvxvNy/6uF9nl45fNCD+NX/c3L79TB42I8cXKGJ9ql4uFVeCxzy2dTqBWaTWa6E1H7ZDy6NR79m7ED8L9lVS3u3/RNNRRFQ3C9LPxq5QHw/ac12L+5MgD9xl/hjfcL/w6FdR7Eo/9qNG7cmNWrV9O+fXvi4+OJiIigZs2aTJ48mUmTJhWKDwwMZPXq1XTp0oWUlBR2795NpUqVGDNmDPPmzcPZuWBfunLlyqxcuZLevXuTn5/Prl270Gq1vPnmm3z77bfmETQleSh66OXJge0+9B1zkVb/SObX7TfY85PxEXCfarmM/fwsVfzy+G1XZU4cuTMUa8sPfnQbeJkqvnmMn3WWT8eGcSvFOMdH01Y3GfOx8WbL8rm1yEyXX7k1ug25zp4ffTiyx5tFH/rT51+JuLgqGAzw8/dV+f6zGmg0Cm+8bxxGevGsKyvnGj9k/94jmR4jrpdl88s/BVCzYtp9SOglrZkcFhbGnDlzrD6fv78/M2bMsDq+cuXKTJgwgQkTJlh9zF/Jv247czXenUUzajN44gXGzzpLvzEXybjtRFCYcTbFM8c9mTmq4JwPaakVmDFSxwcLYmje+ibf7TvCpfPuuHvq8Q8y3gTdvLw6axc74DSrpaROw2z++Z8EZo8NZPWC6mxeWo2AkBySrlTg5o0KaJ0UBk+9TIu2xp78+kW+5oe2Yv9wZ/RLRdey278mwxdLYk819PJEErod+nGpPzcSXejc/yp1GmRQtXouly+4sXtTNdYv8Sc3p/AYueiIygzt1Jhub12h6VM3CayTRVaGE1H7K/HT9zX4dbuDzvdRitq/lkJogyxWzffj+K9exJ1yw7uKntYvpdJ18PUCk3Cd+O3OV+LY48U/ANKklfUr0Dy0ZE1Rm0hCt1MHtlXlwDbL9duiXI13Z877lm+KCtuEN85iwn/jS4z7alfMfXvP3u8k0vudRKvjv/vt5H17b3uhMRhfauKFJHQhhD2SHrpNykVCL+lmhRDCsWhQWUMvtZaULzJsUQghHES56KELIR4yiqJy2KLUXEASuhDCDsmwRdtIQhdC2B+5KWoTSehCCLsjPXTbSEIXQtgfqaHbRBK6EML+2NECF+WJJHQhhP2RGrpNJKELIeyOPFhkG0noQgj7Y1CMLzXxQhK6EMIOScnFJpLQhRB2R4Yt2kYSuhDC/siwRZtIQhdC2B3podtGEroQwv5IDd0mktCFEHZHg4JGRRlFIxkdkIQuhLBHhj9fauKFLHAhhBCOQnroQgi7o1FUllxklAsgCV0IYY/kpqhNJKELIeyPjEO3iSR0IYTdkXHotpGELoSwPwoqe+il1pJyRRK6EMLuaBTQqBiKKD10I0noQgj7IzV0m0hCF0LYHxnlYhNJ6EII+6NyHLr00I0koQsh7I+UXGwiCV0IYX9kLhebSEIXQtgdmW3RNpLQhRD2R0ouNpGELoSwP5LQbSIJXQhhf6SGbhNJ6EIIuyPT59pGFrgQQggHIT10IYT9kcm5bCIJXQhhf+SmqE0koQsh7JDKhC5ddEASuhDCHskoF5tIQhdC2B0Z5WIbSehCCPsjNXSbSEIXQtgfg2J8qYkXktCFEHZIeug2kYQuhLBDMsrFFpLQhRD2Rx4ssolDJ3Tlz78Q3r5eZdyS0lW5RsWybkKpycn3LesmlCpHvb5cfRXgzr9B1aSGbhOHTuh5eXkAvD2vWxm3pHSNXdW/rJtQak5ec9xrAzh5bW5ZN6FU5eXl4ebmpv5AxWB8qYkXjp3QPT090el0VKhQAY1GU9bNEeKhoSgKeXl5eHp62noCuSlqA4dO6FqtlooVHbccIYQ9s6lnbiIlF5s4dEIXQpRXMsrFFpLQhRD2R0ouNpGELoSwPzJs0SayYpEQQjgI6aELIeyPwWB8qYkXktCFEHZIaug2kYQuhLA/ktBtIjX0curAgQP06dOHli1b0rRpU3r37s3evXvLullCpXXr1lG3bl0OHz5c1k2xL4pyZyy6NS9J6IAk9HJp3bp19O/fn+joaBo3bkyTJk2Ijo5m4MCBrFq1qqybJ6wUHR3N1KlTy7oZdklRDKpfQkou5c61a9eYOHEiFStWZPny5eh0OgCOHTtG//79mTZtGq1bt6Z69epl3FJRnC1btvDuu++SmZlZ1k2xTwZUPilaai0pV6SHXs4sW7aM3Nxc+vXrZ07mAI0bN2bgwIHk5ORIL92OJSYmMnbsWEaMGIHBYKBatWpl3ST7ZKqhq3kJSejlzb59+wBo165doX2mbVJLt1+zZs1i48aNNGrUiFWrVhEaGlrWTbJPpmGLal5CSi7liaIoxMbGotVqLSaC4OBgtFotsbGxKIoiM0zaodDQUGbOnEmnTp3QaqU/VSQZ5WITSejlyK1bt8jNzaVKlSq4uLgU2u/s7IyPjw/JyclkZGTg5eXYC3uUR2+99VZZN6FcUBQDiopet9wUNZIuQjmSlZUFgLu7e5ExpilLMzIyHkibhCgVUkO3ifTQyxE1X9FtXvpLCHsgo1xsIgm9HPHw8AAgJyenyJjs7OwCsUKUS7IEnU0koZcjXl5eeHh4kJqaSn5+Ps7OBX99+fn5pKam4urqire3dxm1Uoh7pxgUFBU9dDWxjkxq6OWIRqMhLCwMvV7PhQsXCu2Pi4vDYDAUGJ8uRPlkuNNLt+YlNRdAEnq506pVKwC2b99eaJ9p2zPPPPNA2yTEffdnD93al6wpaiQJvZzp0qULrq6uLFy4kD/++MO8/fjx4yxatAg3Nzd69uxZhi0UQpQVqaGXM7Vq1WLcuHFMmTKF1157jZYtWwIQGRlJfn4+M2fOpGrVqmXcSiHujbevl6qhiN6+8swFSEIvl3r16kXNmjVZtGgRUVFRuLi40LRpUwYPHsyTTz5Z1s0TwmZOTk44OTkxeNHrNh/7MNMoMmBZCGFH8vPz0ev1qo9zcnIqNPLrYSMJXQghHITcFBVCCAchCV0IIRyEJHQhhHAQktCFEMJBSEIXQggHIQldCCEchCT0B+DSpUvUrVvX4qtevXo0btyYp59+msGDB1uco6UsnDlzxtzGu40fP566desyc+bMe36PGzdukJaWds/nKcn3339P3bp16d27t1Xx69ato27dunTp0uWe33vu3LnUrVuXESNG3PO5SvLss89St25ddu3aVervJezTwz0Kvww0atSowPJxiqKQm5vLpUuX2LlzJzt37qRnz55MnDixDFtZ+r755hvmzp3LihUrZKpfIe4TSegP2OzZs6lVq1ah7Xl5ecybN48vv/yS5cuX06pVK5599tkyaGHxRo8ezcCBA/Hx8bmn88yYMeM+tUgIYSIlFztRoUIFRo0aRZMmTQBYvnx5GbfIMj8/P+rUqUOVKlXKuilCiL+QhG5n2rRpAxinwxVCCDWk5GJnvLyM04BmZGSYt82dO5d58+YxduxY3N3d+eKLL7h16xZBQUHMnz+f2rVrA5CQkMDChQvZv38/169fx9PTk8cee4x+/foVOQtjUlISCxcuZMeOHSQlJREQEECPHj1o0aKFxfjx48ezfv16BgwYwLhx4wrsS0hI4LvvvmPPnj0kJibi5ubGI488Qv/+/XnqqacKXItJx44dAfjuu+/MUwEDHDp0iG+++Ybo6GjS0tKoWrUq//d//8egQYPM1/tXp06d4osvviAqKor09HTq16/P4MGDi/15q3Xjxg2WLl3Kvn37SEhIICsri4oVK9KgQQO6d+9O+/btizz2/PnzfPbZZ+apjuvVq0ePHj3o1KmTxfj09HS++eYbtmzZwsWLF3FyckKn09GlSxdeeeWVh35mQVGYJHQ7c/HiRQD8/f0L7du6dSu///47AQEBBAQEkJmZSWBgIAD79u1jxIgRZGZm4u7uTnh4OCkpKezevZvdu3czfPhwhg0bVuB8cXFx9O/fn6tXr+Lm5kZ4eDjXrl1j2rRpPP7446raHRERwciRI7l9+zYeHh6EhYWRlJTE/v372b9/P9OmTaNr1674+/vTtGlToqKiAGjQoAFubm5UrFjRfK4FCxYwe/ZsAHx8fNDpdCQkJLB27Vp+/vlnZs+eXWhVpm3btjF69Ghyc3Px8fGhTp06nD59moEDB9KsWTNV11KUU6dO0b9/f1JTU/Hw8DDfC0lISDBf55gxY3jrrbcKHRsXF0f37t3JyMggPDyczMxMoqKiiIqK4uDBg0yfPr1A/KVLlxgwYADx8fE4OzsTHByMwWAgOjqa6Ohotm7dyoIFCwrcYBcCRZS6hIQERafTKTqdTklISCgy7ubNm8oTTzyh6HQ6ZerUqebtc+bMMR8/bdo0xWAwKIqiKMnJyebzN23aVNHpdMqsWbOUnJwc87Hbt28379u2bZt5u8FgUF599VVFp9MpAwYMUFJTUxVFURS9Xq8sXrxYqVu3rvk97zZu3DhFp9MpH330kXlbcnKy0rJlS0Wn0ykTJkxQ0tPTze/x9ddfKzqdTmnYsGGBazedOyYmpsD5t2zZouh0OqVp06bK5s2bzdtzc3OV+fPnm/ddvnzZvO/GjRvma/zPf/6j5OXlKYqiKOnp6cqoUaPM7/X6668X+bO/29q1axWdTqe8/PLLBba//PLLik6nU/75z38qt2/fNm+/ffu2MmbMGEWn0ynNmjVTcnNzzfvu/t0999xzSmxsrHnfL7/8ojRq1EjR6XTKTz/9ZN6en5+vdO7cWdHpdMrbb7+tJCUlmfedPXtW6dChg6LT6ZQPP/ywQPvatGmj6HQ6ZefOnVZdp3A8UkMvY4qikJaWxt69e3nzzTdJSUmhYsWKvPHGG4ViK1SowMiRI9FoNADmG5NLliwhPT2dzp07M3LkyAK9trZt2zJmzBiAAqWOw4cPEx0djbe3N59//jmVK1cGQKvVMmDAAF566SWrr+GHH34gNTWVxx57jClTpuDp6QkYF7Xu168frVu3Ji8vj59//rnEc82ZMweA9957j3/84x8Frn3IkCF06NDBXIowWbFiBenp6bRo0YJ33nnHPCe2p6cnH330UZElGjWuXLnC5cuXcXNzY/LkyebSGBjLZO+88w4At2/f5tq1a4WO12g0zJ07lzp16pi3tW/f3lwSWrx4sXn7tm3bOHnyJCEhIcyaNYtq1aqZ94WFhTFr1iy0Wi0rVqwgOTn5nq9NOA5J6A9Y27ZtCz1Y1Lx5cwYOHMixY8fw8fFhwYIFFksuOp3OnCzvtnPnTgBeeOEFi+/5wgsvoNFoOHXqFElJSYCxRAPGBaUtjQPv2rWr1de0e/duAF5++WXzh83dJk+ezPbt23nzzTeLPc/Fixc5e/YsWq22QDK/24svvgjA3r17zdv2798PYLEW7eLiUmSNWo2aNWsSGRlJZGSkxZ+Xm5ub+f9nZ2cX2t+sWbNCD2kBvPLKKwCcOHHCnJx37NgBQLt27XB1dS10jE6nQ6fTkZeXx8GDB227IOGQpIb+gP31wSKtVouHhwfVq1enSZMmdOjQAQ8PD4vH+vr6FtqWnp7O1atXAfj888/54osvLB7r5OREfn4+cXFx+Pr6cuHCBcDY47PEUvIpSkJCAgDh4eEW99eoUcOq88TGxgJ3viVYYkqW8fHxKIqCRqMxX8vdvd+71atXz6r3t4abmxvnzp3j2LFjxMfHk5CQwNmzZ81tBzAYDIWOq1+/vsXzVa9enYoVK3L79m3i4uKoWrUq586dA+CXX37hyJEjFo9LTEwEjLV5IUwkoT9gRT1YZA1LvbW7R8OcPHmyxHPcvn0bMH4QALi7u1uMq1ixIhqNBsWKBa1u3rwJYPHbgxqmNuXn55tvmhbFYDCQkZGBl5eX+biiPgjvvuF6L2JiYpg+fXqhXnFAQABdunRh9erVRR5bVNtM+27fvm3+sDJdT0JCgvnDsiim36cQIAm93Ls7If/6669WP/BjKhtkZmZa3J+Tk2NVMgdjrzU9Pb3Ic1nLlPTCw8P56aefrD7O29ub5OTkAh9ud7NUAlErKSmJPn36cPPmTerVq0fXrl2pX78+derUwcfHh9zc3GITenE/G1O7Tb8T0+909uzZ/P3vf7/ntouHh9TQyzlvb29zEj9//rzFGL1ez4EDB4iPjzcvvhsSEgIYh+JZYvrab43g4OBij9m1axe9evUqcFPWEtPNy0uXLpGbm2sx5saNGxw+fLjAjUfTtZw+fdriMUX9XNRYu3YtN2/epE6dOqxatYrevXvz+OOPm6dAsHQj9G6mstBfJSQkkJ6ejlarJTQ0FLjzcyiu3dHR0Zw5c+a+fFgJxyEJ3QGYxmSvXLnS4v5NmzbRv39/OnfubO4ptm3bFjDeXLSUjNavX2/1+5seGtq4cWOR73/48GFu3bpl3ma6eXr3t4CwsDACAgLIysoq8lyffvopvXr1YtSoUeZtpmtZu3Ztofq1wWAo8lxqXL58GYDQ0NACN0BN1qxZY/7/llasj4yMNN/ruNuKFSsAePzxx80jZ1q3bg3Ahg0byMnJKXRMQkICr7/+Oh07diQ6Olr9xQiHJQndAbz55pu4urqyadMmPv/88wJJYN++fUyZMgWAbt26mevJjRo1ok2bNmRlZTFs2DDzTTaA1atXq5pLplevXnh7e3Po0CGmT59ufn9FUVi6dCmbN2+mQoUK9OrVy3yMqbxy5coV8zaNRsOQIUMAmD59Ops3bzbvy8/PZ9GiRaxbtw6gwE3T7t27U716dU6cOMEHH3xg7rXm5OQwadKkIr+FqGH6FhIREcGxY8fM27Oysvjqq69YuHCheZulJJybm8uwYcMKfHiuXr2ab775Bo1Gw9ChQ83bX3zxRYKDg4mPj2f48OHmkUlg7OkPGTKE/Px86tevX+QTwOLhJDV0BxAWFsbMmTMZO3YsX375JUuXLiUkJITU1FRzz/Jvf/ubeay0ydSpUxkwYADHjh2jXbt26HQ6UlJSuHr1Km3atLF6Xm0/Pz8+++wzhg8fzrfffsu6deuoXbs2V69eJTk5GScnJ6ZMmWJOimAcRRMVFcXo0aMJDQ1l1KhRPPXUU3Tt2pWzZ8/yzTffMHr0aGbMmEH16tW5dOmS+ebr0KFDadeunflcXl5efP755wwaNIg1a9awdetWateuTXx8PGlpaaqupSjdunVj2bJlXL58me7duxMcHIybmxvx8fFkZmYSEBCAVqslISGB69evFzq+VatWHDp0iLZt2xIeHk5qaqq5xz527FieeOIJc6yLiwvz58/njTfeYM+ePbRu3ZqwsDDy8vK4cOECer2eGjVqsGDBgnu6JuF4pIfuIDp06MCGDRvo2rUrlStXJiYmhtTUVB555BHee+89vvrqq0KPifv6+rJ8+XKGDh1KQEAAsbGxaLVahg0bxieffKLq/Vu1asXGjRvp2rUrXl5exMTEoNfradeuHStWrCi0WMT06dNp2bIliqJw4cIF4uPjzfveffddFi9ezLPPPovBYDDXxp966ikWLFhgcbGIZs2asW7dOrp06YKHhwdnzpwhICCATz75hJ49e6q6Fku8vb1Zs2YNvXv3Jjg4mMuXLxMfH0/t2rUZNmwYGzdupEOHDgAWPzwaNmzIihUraNmyJRcuXCAtLY2//e1vfP311xYfIgsLC2Pjxo0MHjyY0NBQLly4wMWLFwkKCmLAgAGsX7+emjVr3vN1CceiUawdyiCEEMKuSQ9dCCEchCR0IYRwEJLQhRDCQUhCF0IIByEJXQghHIQkdCGEcBCS0IUQwkFIQhdCCAchCV0IIRyEJHQhhHAQktCFEMJB/D9uvG5/77QNgAAAAABJRU5ErkJggg==\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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oqKi+Oqrr/jxxx+55557GD58OOfOnQNg06ZNHD9+nC+++IK0tDRat27NhAkTGqLNQohG7mo9rLFr1y6WLl1KUlIS5eXldO/enejoaG688Uab6ygqKmL58uV89913nDx5Ek9PT/r27cuUKVPo2bNnrcerCsLe3t58+OGHxMTEcPjwYU6cOGHZN23aNMC89luHDh1YsmSJU61+IYRwHFfjxlx8fDyzZs3Czc2NAQMGYDKZSEhIIDo6mjlz5nD//ffXWkdeXh4PPfQQSUlJBAUFcdNNN5Gens5PP/3Ezp07WbVqFb169aqxDtVPzLVt25Z169axadMmfvzxR5KTkykqKsLT05MOHTowdOhQ7rzzTqtL1gshhC0aeu6IrKwsZs+eja+vL3FxcZbVevbv309UVBRz585l6NChtT71+8orr5CUlMSdd97J/PnzLXFv+fLlvPrqqzz33HN89dVXNdZRp7kjtFott956K7feemtdDhdCiBo1dBBetWoVer2eSZMmVVourVevXkRHR7Nw4ULWrFlj+YZvzalTp1i/fj0hISGVAjDAww8/zIYNGygoKOD8+fMEBARUW88VLW90/vx59u3bx65duzhw4ABFRbI2mRDiyil1eKmxfft2AKuDByq2bdu2rcY6Nm7ciKIojBs3zuo3//j4eDZt2lRjAIY69oS//fZbli9fXmXVDK1Wy3XXXceUKVO47rrr6lK1EEJY1phTU97msopCcnIyWq220rQLFUJDQ9FqtSQnJ6MoSrUrDFXEv549e1JUVMS3337LwYMHcXFxYeDAgQwfPtym1YlUB+HnnnuOdevWUbEgh6+vL15eXhQVFVFYWMju3bv59ddfmTFjhoyOEELUjdrurYqy+fn56PV6AgICrPZgXVxc8Pf3Jycnh6KiInx8rC+cmp6eDphvzt19991kZmZa9n3yyScMHDiQd999t9rjK6hKR3z99dd8/vnnuLq68vjjj7N161b27NnD1q1b2bt3L5s3b2bixIloNBoWLFjA7t271VQvhBBmdXxY48yZM5w8ebLS68KFC5WqLikpAcDT07Pa03t4eADUmGItKDAvsDpr1iyaN2/Op59+ym+//UZcXBxdunThl19+Yfbs2bVeqqogvHr1ajQaDW+88QaTJ0+ucuewXbt2zJgxgxdeeAFFUVi2bJma6oUQArg0RE3NC2Ds2LEM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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.9695192889385268\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>84.615385</td>\n",
       "      <td>42.307692</td>\n",
       "      <td>18.461538</td>\n",
       "      <td>9.230769</td>\n",
       "      <td>6.153846</td>\n",
       "      <td>4.615385</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>84.615385</td>\n",
       "      <td>42.307692</td>\n",
       "      <td>18.461538</td>\n",
       "      <td>9.230769</td>\n",
       "      <td>6.153846</td>\n",
       "      <td>4.615385</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     84.615385  42.307692  18.461538  9.230769  6.153846  4.615385\n",
       "1           NaN        NaN        NaN       NaN       NaN       NaN\n",
       "mean  84.615385  42.307692  18.461538  9.230769  6.153846  4.615385"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "factors = [0.01, 0.02, 0.05, 0.1, 0.15, 0.2]\n",
    "pred_labels = clf.predict_proba(test_x)\n",
    "\n",
    "print(\"AUC score:\", roc_auc_score(test_y, pred_labels[:, 1]))\n",
    "\n",
    "list = []\n",
    "for factor in factors:\n",
    "    list.append(enrichment_factor(test_y, pred_labels, ratio=factor))\n",
    "\n",
    "df = pd.concat(list, axis=1)\n",
    "df = pd.concat([df, df.agg(['mean'])]) \n",
    "display(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "548daef6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tda",
   "language": "python",
   "name": "tda"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
