{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import ot\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as mtick\n",
    "from scipy.stats import multivariate_normal\n",
    "import seaborn as sn\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from sklearn.utils import check_random_state\n",
    "from scipy.spatial.distance import cdist\n",
    "# User functions\n",
    "from utils import W2_dist, BaseTransport, GaussianTransport, get_trajectories_for_plotting, \\\n",
    "                  calc_parsimony, get_desiderata\n",
    "\n",
    "# We will be using data from  the UCI: Gas sensor array under dynamic gas mixtures Data Set\n",
    "# Link: https://archive.ics.uci.edu/ml/datasets/gas+sensor+array+under+dynamic+gas+mixtures\n",
    "data_dir = Path('..') / 'data' / 'adult-income'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Experiment hyperparamters\n",
    "rng = np.random.RandomState(42)\n",
    "split_on_income = False  # if True, split on income, if False, split on sex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting so that the plots look normal even when using dark-reader\n",
    "sn.set_style(\"whitegrid\")\n",
    "sn.set_context(context=\"paper\", font_scale=2)\n",
    "pal = sn.color_palette(\"Set1\")\n",
    "\n",
    "# Setting up specifics for plotting + saving\n",
    "save_figures = True\n",
    "add_legend = False\n",
    "add_title = False\n",
    "add_axis = False\n",
    "save_parms = {'format': 'pdf','bbox_inches':'tight', 'pad_inches':0}\n",
    "line_parms = {'linewidth':4, 'color':'k'}\n",
    "if save_figures:  # saves all figures in a figure directory in the local directory\n",
    "    figure_dir = Path('.') / 'figures' / 'adult-income-experiment'\n",
    "    if not figure_dir.exists():\n",
    "        figure_dir.mkdir(parents=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "adult.data  adult.names\n"
     ]
    }
   ],
   "source": [
    "!dir $data_dir"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Loading and Preprocessing the data\n",
    "Since our data inclues continuous, categorical, and binary data, and for OT we need everything to be in a continous space (at least for now), so we do the following:\n",
    "* we first encode our categorical variabels to a one-hot vector (e.g., martial status goes from being a variable with 7 options to 7 binary variables))\n",
    "* any ordinal variables are interger encoded (e.g. education(HS-grad) < education(Bachelors) < education(Masters))\n",
    "* finally all variables are normalized to 0 mean and unit variance.\n",
    "\n",
    "Note: For eduation, Assoc-acdm and Assoc-voc are equally ranked as well as Doctorate and Prof-school. The ranking is as follows: \n",
    "`Preschool, 1st-4th, 5th-6th, 7th-8th, 9th, 10th, 11th, 12th, HS-grad, Some-college, [Assoc-acdm, Assoc-voc], Bachelors, Masters, [Prof-school, Doctorate]`\n",
    "\n",
    "**However**, for merely calculating distances, we do not need to be in a continuous space. So for both categorical and binary variables, we claim $d(x, y)^2 = \\{2, \\text{if } x \\neq y; ~ 0 \\text{ if } x = y\\}$ since this is the expected squared distance between two samples from a standard normal distribution, and for continuous variables we use the standard squared euclidean cost."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished preprocessing adult income dataset.  Split on sex with resulting source shape: (1000, 3), target shape: (1000, 3).\n"
     ]
    }
   ],
   "source": [
    "from data_utils import load_and_preprocess_adult_income_dataset\n",
    "continuous_variables_indicies = [0, 1]\n",
    "# n_samples = 'balanced'\n",
    "n_samples = 1000\n",
    "X, Y, feature_names = load_and_preprocess_adult_income_dataset(\n",
    "            data_dir, split_on_income, rng, n_samples, return_column_names=True)\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "standardizer = StandardScaler()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Performing Clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_mixed_variable_desiderata(X_continuous, Y_continuous, Z, standardizer, continuous_variables_indicies,\n",
    "                                  n_expectation=10, inter=None, rng=None):\n",
    "    rng = check_random_state(rng)\n",
    "    non_continuous_variables_indicies = np.delete(np.arange(X.shape[1]), continuous_variables_indicies)\n",
    "    fids = np.zeros(n_expectation)\n",
    "    pars = np.zeros(n_expectation)\n",
    "    for loop_idx in range(n_expectation):\n",
    "        # since Z is in a pseudo continuous space, we project it to a discrete space using the phase change graph defined within Z\n",
    "        # since the Z[i, j_descrete] is probability of that point being positive\n",
    "        Z_projected_discrete = Z.copy()\n",
    "        uniform_vars = rng.uniform(size=(Z.shape[0], len(non_continuous_variables_indicies)))\n",
    "        positive_probability = Z[:, non_continuous_variables_indicies]\n",
    "        Z_projected_discrete[:, non_continuous_variables_indicies] = (uniform_vars <= positive_probability).astype(Z.dtype)\n",
    "        Z_projected_continous = standardizer.transform(Z_projected_discrete)\n",
    "        # Calculating fidelity\n",
    "        M = cdist(Y_continuous, Z_projected_continous, 'sqeuclidean')\n",
    "        a,b = ot.utils.unif(X.shape[0]), ot.utils.unif(Z.shape[0])\n",
    "        fid = ot.emd2(a, b, M)\n",
    "        # Calculating parsimony\n",
    "        par = calc_parsimony(X_continuous, Z_projected_continous)\n",
    "        # recording\n",
    "        fids[loop_idx] = fid\n",
    "        pars[loop_idx] = par\n",
    "    fid, par = fids.mean(), pars.mean()\n",
    "    if inter is not None:\n",
    "        print(f'Fid: {fid:.3f}, Par: {par:.3f}, Inter: {inter}')\n",
    "    return fid, par, inter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def mixed_cluster_push_forward(X_cluster, Z_cluster, continuous_vars):\n",
    "    non_continuous_vars = np.delete(np.arange(X_cluster.shape[1]), continuous_variables_indicies)\n",
    "    X_cluster_pushed = X_cluster.copy()\n",
    "    X_cluster_means = X_cluster.mean(axis=0)\n",
    "    Z_cluster_means = Z_cluster.mean(axis=0)\n",
    "    X_cluster_pushed[:, continuous_vars] += Z_cluster_means[continuous_vars] - X_cluster_means[continuous_vars]\n",
    "    X_cluster_pushed[:, non_continuous_vars] = Z_cluster_means[non_continuous_vars]  # sets T(X_discrete) to Pr(Z_discrete = 1)\n",
    "    return X_cluster_pushed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Hyperparameters\n",
    "max_clusters = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fid: 1.070, Par: 0.000, Inter: 0\n",
      "Fid: 0.249, Par: 1683.024, Inter: 1\n",
      "Fid: 0.195, Par: 1397.605, Inter: 2\n",
      "Fid: 0.120, Par: 1109.194, Inter: 3\n",
      "Fid: 0.111, Par: 1028.832, Inter: 4\n",
      "Fid: 0.092, Par: 1026.224, Inter: 5\n",
      "Fid: 0.080, Par: 1035.004, Inter: 6\n",
      "Fid: 0.087, Par: 1031.336, Inter: 7\n",
      "Fid: 0.098, Par: 1025.896, Inter: 8\n",
      "Fid: 0.083, Par: 1050.314, Inter: 9\n",
      "Fid: 0.091, Par: 1040.050, Inter: 10\n"
     ]
    }
   ],
   "source": [
    "# Increasing the number of clusters to see the increase in fidelity and decrease in interpretability\n",
    "\n",
    "cluster_histories = []\n",
    "\n",
    "# fitting standardizer on our source domain\n",
    "standardizer = standardizer.fit(X)\n",
    "\n",
    "# Finding base desiderata values for T=id\n",
    "X_continuous, Y_continuous = standardizer.transform(X), standardizer.transform(Y)\n",
    "fid, par, inter = get_mixed_variable_desiderata(X_continuous, Y_continuous, X, standardizer, continuous_variables_indicies,\n",
    "                                                n_expectation=1, inter=0, rng=rng)  # showing the base desiderata\n",
    "fids = np.zeros(max_clusters+1)\n",
    "fids[0] = fid\n",
    "pars = np.zeros(max_clusters+1)\n",
    "pars[0] = par\n",
    "inters = np.zeros(max_clusters+1)\n",
    "inters[0] = 0\n",
    "T = BaseTransport(X, Y, fit=True)\n",
    "Z = T.forward(X, Y)\n",
    "Z_continuous = standardizer.transform(Z)\n",
    "\n",
    "for n_clusters in range(1, max_clusters+1):\n",
    "     # performs paired clustering in a continuous joint X,Z space\n",
    "    cluster_labels = T._pair_clustering(X_continuous, \n",
    "                                                       Z=Z_continuous,\n",
    "                                                       n_clusters=n_clusters,\n",
    "                                                       rng=rng) \n",
    "    Z_clusters = np.zeros_like(Z)  # the final output of the cluster mean shift transport\n",
    "    for cluster_idx in range(n_clusters):\n",
    "        X_cluster = X[cluster_labels == cluster_idx]\n",
    "        Z_cluster = Z[cluster_labels == cluster_idx]\n",
    "        # A method similar for cluster mean shift transport, but with accounting for binary variables\n",
    "        X_cluster_pushed = mixed_cluster_push_forward(X_cluster, Z_cluster, continuous_variables_indicies)\n",
    "        Z_clusters[cluster_labels == cluster_idx] = X_cluster_pushed\n",
    "        \n",
    "    # getting desiderata information\n",
    "    fid, par, inter = get_mixed_variable_desiderata(X_continuous, Y_continuous, Z_clusters, standardizer, \n",
    "                                                    continuous_variables_indicies, n_expectation=30,\n",
    "                                                    inter=n_clusters, rng=rng)\n",
    "    fids[n_clusters] = fid\n",
    "    pars[n_clusters] = par\n",
    "    inters[n_clusters] = n_clusters\n",
    "\n",
    "    cluster_record = {\n",
    "        'labels': cluster_labels.copy(),\n",
    "        'Z_clusters': Z_clusters.copy(),\n",
    "        'n_clusters': n_clusters\n",
    "    }\n",
    "    cluster_histories.append(cluster_record)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# changing fidelity to be % of shift explained\n",
    "def calc_percent_explained(x):\n",
    "    return 100*(max_fid - x) / max_fid\n",
    "max_fid = fids[0]\n",
    "percent_explained = np.apply_along_axis(calc_percent_explained, 0, fids)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Results with splitting on sex:\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAfsAAAEgCAYAAACzcto+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAB9FUlEQVR4nO3dd3hURdvA4d/2Te+FEGpIo3eRpiBgRUFEVEARFUXA/lnf1/5asaLYERUQBLEjAqKgdEKHhJLQEkjv2Ww/3x+bbLLZTchCNgnJ3NeVi+yc2bNzAuQ5M2fmGZkkSRKCIAiCILRY8qZugCAIgiAIniWCvSAIgiC0cCLYC4IgCEILJ4K9IAiCILRwItgLgiAIQgsngr0gCIIgtHAi2AuCIAhCC6ds6gYIgiAIQn3oDGaWbD5B8pliDp8tJrfEwIiuEbw6qbfL+huSs1i4MY207FK8NUqGxoUxa3QcgT5qp7qpWSV8uPYIe08VIiHRs10gs0bHERvp71DvVF4Zb/6azMGMQkJ9NUy/PIarekY51LFYJe78ZAuD48K474rYBrv+CyF69oIgCMJFoVBn4vO/Uzl8tpj4Nv511l13IJMnlu4B4MGrEpgwoB1/Hspk1sId6E0Wh7qn8sq4d8F2jmSWMG14Z+4dGUtGQTn3LtjO8exSez2LVeLJpXvILtYza1QciW0DeGHlfg6mFzqcb9nWk+iMZu4c3rlBrrshiJ69IAiCcFEI9dPw86OXEe6vBWDQc3+4rGe2WHl3dQpRQV58dOdAtGoFAF2jA3hk0S6+336KyUM62et/tO4o5UYLn0wfSEyEHwCjukVy87x/+WDtEd6a3BeA9HwdadmlfHTnAPp0DObGAe3Yf7qQjSnZdIsOBCCrqJzP/zrGK5N6o1EpPPWjcJvo2QuCIAgXBbVSbg/0dUk6kU9uiYHr+0bbAz3A4NgwooO9+WP/WXuZzmDm38PZ9OsUbA/0ACF+Gq7oFsHWY7kU6YwA9hEBPy8VADKZDF+t0mGk4K1VKQyJC2NQl9ALu9gGJoK9IAiC0KKkZBQD0C06wOlYt+gAUrNKMZmtAKRml2KySHRr66puIBarxJHMEgA6hPjg76Xkq41pnCnQsXrfGY5mltC9XSAAG1Oy2XUin4euSvDQlZ0/MYwvCIIgtCg5JQbANuxfU6ifBotVIq/UQGSgFzkl+lrrhlWU5RTb6mjVCp68vhsv/3CAtQcyAbimVxSjukVSbjTz9qpk7rsilhAX52pqItg3sKSkpKZugiAIwkXntttuc3g9e/Zs5syZc17nMlQMq6sVzoPXGqWtrHLo3WCy9fDVSue6antdq71sZNdILukcyvHcUkJ8NbQJ9ALgs79SCfbVcGP/dmTk63hrVTJHMkuIDvbmoasSSIiqe0Khp4lg7wH9+vU7r/clJyeTmJjYwK1p3lrbNbe26wVxza3FhVxzUlIShw8fbrC2VAZpo8XqdMxQMXxfOXnOXtfsXNdor+t4I+CjVdK9YkIewNHMYlZsP8Xnd1+CBDyyeBcdQ32Ye1sffkpK58FvdrLyweH4aJsu5Ipn9oIgCEKLUjmJL7diOL+63BIDCrmMEF/NOetWPg4I86t9UqAkSbz+yyFuHNCOuDb+HEgv5GRuGQ9eFU9CVAAPXpVgmwR4JPuCr+tCiGAvCIIgtCiVQ+YH04ucjh3KKKJzuK+9Rx8T7otKIeNghnPdg+mFKOQy4tv4OR2r9MPOdLKLDcwY0QWA7OLKOQC2GwStSoG/l4rsYuebicYkgr0gCILQovTtGEyIr5qfd6U7LIvbfDSH03k6xvRoYy/z1igZHBdG0vF80qol0MkrMbD+UBYDY0II8HbOuAeQV2rgo3VHePSaBLw1tiH6ylGAynPllxoo1JlcTgBsTOKZvSAIgnDRWL7tJCV6s/31ydwyFmxIBaBPhyD6dAxGpZTz4FUJPLtiHzMXbGds32gKygws2XySTmE+TBzY3uGc94+KY2daPg98vZNbBnVArZSzfPsprFaJ2aPjam3Le6tT6N0hiMsSI+xl3aMDiA724qUf9jN+QDv+PJCJt1rB4NimXXcvgr0gCIJw0Vi8+QSZhXr767TsUj5dfwyAuy6PoU/HYADG9GiDSiFn4cY03l2dgrdawYiuEdw/KtYh0Q5Ah1AfPp4+kA/XHmHBxlSQoHu7QF6e2Msh0U5121Pz+OdwDt/OGuJQrlTIefO2vrz+yyHmrz1CdIg3cyf3rXV0oLGIYC8IgiBcNH58+LJ61x3RNYIRXSPOXRGIjfTj3an1X0k1MCaEv54Z5fJYpzBfPp4+sN7nagzimX0rZtyzh8xLh3AmNp6Sjz5u6uYIgiAIHiJ69q1Y8SuvYTl1yvb9y/8DGfjdd18Tt0oQBEFoaKJn30pJkoRx926HsuKX/odu+YomapEgCILgKSLYt1LWs5lIOp1TecGjj6Ff92cTtEgQBEHwFBHsWynTsWOuD1gs5N97H4adIse/IAhCSyGe2bdS5rTUWo9Jej15d9xB2A8rUcXVvsZUEGqSJAm9yUKRzkRRuYkinYmj6TqKVbloVAq81Aq0KgVeKgUalRwvtRKVQoZMJmvqpgtCiyaCfStlTk1zeK3q1g3TwYP211JhEXm3TSH0px9Rto1q7OYJzYDZYqW4vCpoF5ebKNIZq76vfF1uorgiuBeXm1xuKMK/ubV+jkIuQ6OS228CtA43BFU3CLYvueNrdcV7XHyvVSnw1ShRudjN7GJltUoUl5vILTWQV2Kw/5lXaiC3xEihzohSLsNLrcBbrcRLbfv5eWuUeKsVeKkr/3Qss9W3fa+QixuvlkgE+1bKXGMY3++hBzEdPEjJu+/Zyyxnz5I3ZSphK1cgDwpq7CYKDajcaKagzFitx22sCN7Vg3nV8eJyE6XVspR5ksUqoTNY0Bks5658Hrw1CgK81AR4qwjwUhHgrcK/2mt/e7naftxHo2zU0QazxUp+qZHcUgO5JVWBPL/ydUUwzy8zYLZIHm2LRiV3vFGofoNQxw2EtcRI69rn7+Iign0rVbNnr4zpjPbqq7Dk5KJbvLiq3pEj5N1xJyHLvkXu5dXYzRTqSWcwk1mk52xhOWcLym1/Vvsq1JmauolNxnYjYfs51JdCLsO/IvBXvxFwuDFwcZOgrLF/ernRXBGsjfYgnldqcOqZN6e/H4PJisFkpKDM/fcmF2l46OqEhm+UcMFEsG+FrDodloyMqgK5HGXHjshkMgJf/R/W/Dz0v6+2HzYmJZF/70xCvvgMmUrVBC0WdAZzjQCud3hd1IyChVopdwiMVqMeldYbvclS9WW0UF7xvad7qufDYpUoKDNSUGZ0632VowhWi4mSlRnojJ4ZrWiulm8/xYNXxYs5GM2QCPatkDntuMNrRft2yDS2HZlkCgXBH8wjd/IUjFu32esY/vyTwv97nMB33hb/kT2gzGAms5kFc5kM/LRKhyFvVz1cxx6wCq1K4fBvJDk5mcTE2gd4zRYrepOFcmPVzYDte2uN17abBL2p4kah2veGGu+xfW+mVG/G2oj3EpWjCJ7ko1ES6qch2FdNqK+GED+N/c9gHzVWSUJntP0MdAaz7U+jhXKjucafFnRGMzqDrayy3oXoHO4rfj80UyLYt0LmVMeZ+MrOMQ6vZVotIQu+IGfCRMzJyfZy3fIVyMPDCXj6qUZp58XObLGiM1ooM5jtX4cydBwoPtnowVwhlxHsqyawMjjXfHbtYkjaV6tqlMlaSoUcX4UcX23DjxpZrRIlepPDJMLKSYYOEw/LjdWOmxy2RW0MMhkEeqsJ9dMQ4qsmxFdT8b2mIrBr7Me81J77tW21ShjMtqBf80ah8nvX5WaUZh33Xt3HY20TLowI9q1QzWCv6hLjVEceEEDo4m/IuWE8ltOn7eWlH85HERqK74x7PN7OpmI0Wx0CtMOXvvJ7WxDX1VbPYKkjYNQ+M/18KeQyIgO0tAn0qvoKqvxeS6iftlXOspbLZRXP19UQUv/3GUwW54mLOscVCA4rFMpNlJSbnEYRVAoZIRW97hDfyuDtGMwre+Q1n/c3BblcVjE7X0mIr3v7rycnJxMVJOb1NFci2LdCTj37GOdgD6CIiCB0yWJyxo3HmpdnLy964UXkoaF43zjeo+30hLOF5fy6O4PTebpag7WpGT5DVipswTyyMpAHiGDuSRqVgnCVgnB/bb3fY7VKlBrMFOmMHD6ayoCeCfh7qcSwttAsiGDfCpmP1Qj2Lnr29mOdOxHyzVfkTpyEVFY1Pbfg4UeQBwWiHTHCY+1sSCdzy/jqnzT+2HcWS2M+xK0np2Be7Ssq0IsQP40I5s2cvGIGv7+XitJsVZPvXy4I1Ylg38pIVmu9e/aV1L16Efz5p+TdPg1MFc+WzWby77mX0O+Woe7bfJ/THTlbzFf/pLH+UBZSI8d4mQy81Up8NEp8tbY/JZOezlEhNYbZvQjxFcFcEATPEcG+lbGczUQqr5otLAsIQB4aes73aYcPJ+i9dyi4f7a9TCovJ+/2Owj9cSWqLl080t7zte9UAQs3prH5qPvPxxVyGT4aZcWXotr3Lr60SrxrqeOlUiCvEcDPNTNdEATBE0Swb2WcZ+J3rvczRe8bbsCam0fRs8/Zy6wFBeTdNoWwn35A0aZNg7bVXZIksSMtn4UbU9l1oqDWeu1CvJk4sD2RgV72YO5dLUhrlHLxnFUQBI9btSfj3JVqcU3vtm7Vb/Jgby0ro/STTzHt3Ydx/z6sWdlor7mGkM8+caqbecmlWNLTnU+i0dA2zXkXN1NKCkX/exXjjh0gSaj79yPg6adRdevq3I6CAopefR39mjVYS4pRxcbhN+t+vMZe1yDX2VzU3ADnXEP4NfneNR1LTg6l8z6wl1kyMsidMpWw71cgDwxsiGa6xWqV+PdIDgs3pnEoo6jWel0ifLljeGdGdo0UQ+aCIDS5l348QPXfRBJwrt9MlXUuvmCfn0/JW28jjwhH3aMn+qx1ddZXtG+P/2OP1ih0XrJiTjtOzvgJyLy0+D0wB5lGQ+mXC8m5cQJhv/zksJubZDCQe8ttmA4fxvfuu1B26kT5L7+Sf99MggwGvG+a0CDX2hzUnJznatndufg/8TjW3Fx03y6tOm/KYfLunE7oksXIGimtrsUq8efBTL7amEZqdmmt9bpHBzBteGeGxIWJHrsgCM3Gf8Z1dypbfzCLzUdzGNg5hF7tgwj2VZNfamTPqQJ2pOUxJC6MEV0j3P6sJg/2ivBwIndutw8BZ7RtV2d9eWAA3hNuPOd5i159DamsjLAfvkeVYMvV7DX2OrKGX07Ry68Q+vVCe92yJd9iOnCAwFdfwef2qQB433oLueNupOiFF/G69ppGC2Ce5u7kPFdkMhmBr72KNS8P/Zq19nLj9h3k3z+L4M8+Rab03D8tk9nK73vP8PW/x0nP19Var3/nYKYN60y/TsEiyAuC0OxcW6N3/tehLHam5fHBHf3p18k5McSOtDweW7yLsX3c69UDNHkWB5lG4/azXslsxlpae0/OWlaGft06NEMG2wM92G4svMZeh+Hvv7EWVD3TLf/xJ2Q+PnjfMqmqXXI5PtPuwJqfj/6ff9xqX3PmzrK7usiUSoLnf4h64ACHcv2atRQ+8SSSB6a+640Wlm09yYT3/uGVnw/WGuiHxofx+d2X8MEdA+jfOUQEekEQLgoLN6ZxRfdIl4EeYEDnEEZ2i2TBhjSXx+vS5MHeXaaUw5yJjedsfCJnunan4NHHsFRL+AJgSk4BoxF1H+clYeo+fcBiwXjAtne7ZLViOnAAVbeuyNTqGnV72863Z69nLqaRWXU6LGfOVBXI5Sg7dDjv88m8vAj5cgHKhHiHct3SZRS//sZ5n7emMr2Zr/9JY/y7G3nn9xSyi/XObZHBqO6RfDNzMHNv60v3doEN9vmCIAiN4URuKWF+dWcuDPPTcDLX/S0Jm3wY3x3K+Hh8brsVZWwskkGPYcNGdMu+w7B1G+GrfkUeEACANSsLAHmE83MNRUWZNTPT9mdhEZJeby+vTh4ZCYClom5N8+bN44MPPnAoW7JkCcnV8sm7Q6/Xn/d760N+LBXfaq+tkZGkpLl/h1iT7Pnn8HngIeTZ2fay0nkfkGu1YBxfd5a9uq65xGBh3ZES1h0pQWdyPVKgkMHgjj5ck+hPpL8Kc0E6ybVPxG9ynv47bo7ENbcOrfGaG5q/VsWOtDxm1nJckiS2p+Xhp3U/dF9Uwb76c3YA7/HjUXXrRtHzL1D62ef2iXuV68hlGucMVpW7u1XWsa85VzvfTdWsW9OcOXOYM2eOQ1lSUtJ5r6P29Bps3ZEjVI+DXomJtGugzzMtX0buuBsdHo9o539Mm27d8L7hhlrf5+qac4r1LNl8gh+TMimvZRcujVLO2L7RTBnSkcjAi2c+RWtcZy+uuXW4kGtOSkpq4NZcnEZ1j2Tp1pM8uXQ3M0fF0SHUx37sRE4pH/95lCNni7nl0o5un/uiCvau+Nw1neI356LfsNEe7O1B2uC8F7VkMNi+0dpyXsu0FUHeaKi1rkxb//zYzZk51bEXr4rp3GDnVnXpUpVWt/LmSJIoePBh5EFBaIcPP+c5zhTo+ObfE/y6O73W/PTeagUTBrbnlks7uL1RhyAIQnN278hYDp8tZkNKNhtTsvH3UhHko6agzEhxuQkJ6NsxmBkj3E9idtEHe5lcjiIqyqFHKa+Y8Fc5nF+dpaJMUTFELw8KAq3GXl5d5VB/Zd2LnfmYYy4CZQNnvVP36WNLq3vHnWA22wpNJvLvuofQFd+h7tXL5fuO55TyzT/H+WN/7Xnr/b1UTBrUnomXdMDfq+G3QhUEQWhqWrWCD6cN4NfdGazed5ZjWSWcytPhq1XSt2MwV/WK4treUec16fiiD/aS2YwlPR1Vj6r1iqrEBFCrMe7e7VTfuHs3KBSoutvqy+Ry1N26Yzp4CMlodJikZ9y9x3a+Xj09exGNpGbPXtmAPftK2ssvJ+idtymY84C9TNLpyJtyO6E//uAwmpByppgP/80hKeNUrXnrQ3zV3Da4E+P7R+Otuej/uQqCINRJJpMxtm80Y/tGN+h5L5rfntaCAlsvvIaS9+chlZejHTXKXib38UF7xUj0a9ZiOnwYVbxttrglO5vyX39Dc9lwFMFV5/K64XqMSUnoli6zr7OXrFbKFn6FPCgIzWWXefjqPM/lBjgeymfvfeN4rLm5FL3wor3Mmp9P3uQpKL/9jg05VtYeyGTPydpn0kUGapk6pBPX9WmLRqXwSDsFQbj4FOmMfP3vcf5JySarWI+vRklspD9Th3Z0WrK2ITmLhRvTSMsuxVujZGhcGLNGxxHo4zifa8vRHD5Ye4QzBeXEhPvy2LWJJEQFONTJLCzn1g838fotfRgY43ppXHPWLIJ96ZcLsRZVpTk1px6j+N33ANAMugTNoEHoVnxP2bJlaC+/HEW7dmAwoN+4EcNff6Pq1ROf6Xc6nNP/yScx/LuJ3Ftvw/eee2wZ9BZ8CRYLAc887VDXZ/Jt6JYuo/C55zGfPo2yY0fKf/kVY1ISgW+/hbwFJNRxuQFOiOf+wfrOuAdLbi6lH86nTO3Ftg59+TdmAPu/3I9VVvuKzw6hPtwxrBNjerRB6SIzoiAIrZfBZGHGF9vJLCpnXL9oOof7UVBm5Odd6cz+aidv3NqHYfHhAKw7kMl/lu8lMcqfB69KIL/UwJItJziUUcQXMwahrehEnCko58mle+jfOYQJA9rz254MHl28i+8eGIZPtdHEuauSGRYf7vFAb7ZY+W7bKdYdOMuJ3DIMJiubnhsD2Hbx/DEpnVsGdaB9tcl79dE8gv3HnzjkvDcfPkLJm3NtLx55GM2gQah690K5aRPlP/2MJd+2rl7ZsSN+jz2K3333OmW4U3WJIWzl9xS98gol775ny43fry/+H893SLQDtgl4IcuWUvzqq+iWfYe1tBRVbCxB8z/E+4brPXvxjeRCNsA5HzqDmS3X3sHq0rbslIdgVtT9Ty0u0o9pwztzWWKEyFsvCIJLW47lcjK3jIevTmDSoKocIVf3asO4dzbyy64MhsWHY7ZYeXd1ClFBXnx050C0altg7xodwCOLdvH99lNMHtIJgG3HcpHJZPzv5l5oVQoGdQnlxnc3cuB0IZd0se0I+ndyFntPFrB0zlCPXl+50cwDXydxML2QAG81Phol+mqTx6OCvPhtTwZ+WhUzR8W6de5mEewjt205Zx3NgAFoFn7p1nlVXRMJXfRNveoqgoMIevMNeLPhksE0JzWD/fnkxD8Xg8nClmO5rN2fyb9HsjGYrKCqO4dzbKiGmVd249LYUJHpThCEOpXqbRN/Q2skngny0aCQy9CqbKOBSSfyyS0xcN8VsfZADzA4NozoYG/+2H/WHuz1Jgtqpdze0w+omACsN9mW/eoMZt5elcL9o+I8vgJo4cY0DqQXMnt0PLcN7sDnf6fy5Yaq392+WhV9OgSzLTXXc8HesHUrinbtULatPSev5cxZzKdOohk0yK1GCJ7XEDnxXZ7XYmV7Wh7r9mfyd0oWOoPrdfHVtc9PZ2jqdq7o0Qb5FTeTGBfWIG0RBKFl69MhCKVCxsd/HsVbrSAmwjaM/9XGNNRKObdWrD9PySgGoFt0gNM5ukUHsO5AJiazFZVSTvd2gRSXm1i86QQju0WwdMsJlAoZCVH+AHy6/hjh/hrG9W/YCXOu/Hkwk/6dQpg8xHYdrro/bYO8OHy22O1z1zvY506chN8jD+P/8EO11tH98APFr71O29Mn3W6I4FkNlRMfbLvN7TmZz9r9maw/lEVxuemc72kXqOHSvX9x6Y7VtC+sSNm7FwwyA7z26nm3RRCE1qNtsDcvTujJW6uSeXjRLnt5ZKCWT6YPJDbSFqBzSmxD3zVHACrLLFaJvFIDkYFe9GgXyNShnfhg7WHmrTmMSiHj4asSiAjw4sjZYlbuPM0X9wxqlJHH7GIDlyfWPRqqVSsoM5jdPnf9h/Hrs7GJxWJLUt7KNcd0uaabb0IaV5XJrigyEpkbnyVJEql5RradKmPHKR1Feus53xPirWBge28GtvehQ5AKrpiA+Vgvco2ONwcH/vkXRejFN7v1fLTGlKLimluHC73m+HjHPTZmz57tlKEUINhXQ2ykH9e18adbdCDZxXoWbzrBI4t28cG0AXQI9cFQMQSvdjHJV6O0lVUO0wPMGh3HpEEdyCwsp12INwHeaqxWidd+OcTEge2JjfRje2oeH/95lJxiPT3bB/HYtYkE+Thnab0Qvlol+aXOyeCqS8/TEXwen9ugz+xNycn2/PStWXNLl2vV6Tg7akxVgVxO1LEj9kyDtZEkiSOZJazdf5Z1BzPJLHTegKamYF81V3SLZHT3SLpHByKvMdnO5OVFzrgbkQoLqwplMoI//QSva65257IuSiKNausgrtk9SUlJHD58+Jz1DqYXMvurHTx+bVeu71c1rD4sPoxbPtjE+38c5q3JfVFXBHSjxblTYjDbymou6Q310ziMBKzccZr8UgN3j4jhTIGORxcnMW14Zy6NDeOd31N4dsU+5t3R/7yutza92wexISWbvFKDy/kBp/PK2Hw0hyt7Rrl97jqDfc7ESQ6vdd8tx7DZxWQ6qwVLZiaWU6fxuuYatxsheJa5xmY3ivbt6wz0x7NLWXcgk7UHznIqr/b94iv5e6kY0TWC0d0j6dMxuM7Z9KrYWEK//orcmych6StuHiSJ/NlzCF2ySMz3EAShVt9vP43ZInFZYrhDeUSAF4lR/uw7ZcvdEe5vS3GeW2KgU5ivQ93cEgMKuazOyXZ5JQY+Xn+UZ8f3wEutZOmWk4T4arjrcltukhkjuzDnq53kFOsJ82+4dOp3DO/Mv0dyuPeL7cwaHWefkHimQMf+04V8uPYoCrmcKRXP9N1RZ7A3bqkW2GUyLKdPYzl92rmiXI48MBCva68h4IXn3W6E4Fn1mZyXka+zB/hjWaXnPKe3RsFlCbYAP6BzCCpl/dfEq/v1JfiTj8mbfpft0Q+AwUDenXcRtnIFqlbWIxIEoX7ySm3P4l1l1bZYJXu67crJdQfTixjQ2fER4aGMIjqH+9p7/668szqFfh2DGZ5gu6nILjY49PorbyayGzjYx7fx58WbevLSDwd45rs9AEjATe/9A9ie1780sScda9zA1Eedwb5t+in79xnR7fF79JE6J+gJzVPNyXmVy+6sVomfd6Xz864MDmUUuXqrA41KztC4MEZ1b8OlsaH2pSrnQzvqCgLffJ3CRx6zl0nFxeROuZ2wn3+sc9WHIAitU8cwH7al5vH73jPcNrijvfxkbhnJZ4rpXjH7vm/HYEJ81fy8K51bLu1g/121+WgOp/N0zBodV+tnbD2Wy+YjOXw7e4i9LMxPw/pDOvsM/tTsEsD1BMALdXliBH06BPHbnjMcyiiiuNyEj0ZJ17YBXNen7XnPE6j3M/vQ5ctsmeuEi05tPftP1h/lq3+O1/lepULGoC6hjO4eydD4cIeMUhfKZ9IkMg8cRLugKn+CNTOTvMlTCfvhe5fpkQVBaL0mDerAqj1n+GDNYdKyS+nWNoDcEgMrdpzCYpW4p2I3OJVSzoNXJfDsin3MXLCdsX2jKSgzsGTzSTqF+TBxYHuX5zeYLMz97RD3jOhCREBVorZR3SP5YkMqzyzfy4DOwSzadII+HYIc6jSkAG+1w81MQ6j3b27NpZe6LLeWl2Patw+ZVlvrrmZC03JadlexGc2qvWdc1pfLoH/nEEZ3j+SyxAiP7jJnvPUWQir2IbC39+hR8qZNJ3TpEqfMiIIgtF5RQd58PXMwCzaksvtEAWv2n0WrktM9OpA7L4uhR7tAe90xPdqgUshZuDGNd1en4K1WMKJrBPePcky0U92CDWl4q5XcXC07H0D7UB9endSb+euOsPN4Hr3bB/Hk9d08eakNrt7BvmzZMsp/+png+R8iDwwEwHT4MHmTp9q3h1UPGkTo1wvFL+hmRLJanSboKbt0Ib/UQE6xwaG8d4cgRnWPZGTXCIIba694mYyAF1/Akp2DftUqe7Fx507y759F8GefIlM2i0SPgiA0A20CvXjmhu7nrgiM6BrBiK51r1uvbuao2Foz0w1PCLc/w/cko9nKhpQsUjKKKdGbXM5PkAHPjKvfz6BSvX+L6pavQCovtwd6gKJnn8eSk4P3LZOw5uSg/3M9pV99jd9997rVCMFzatsA52hqnkO9+Db+fDx9YGM3z9YmhYLgee+Rm5+Hces2e7l+zVoKn/4Pga+/KlLpCoLQ4mXk63jwm52cKSinrsw2Hg325rQ0h21kLXl5GDZvxmfKZAJffQWAnOvHUb7yBxHsmxFz6jGH18qYGGQymVO6xbg2fo3ZLCcyrZaQBV+Qc+MEzClV6211ixejiIzA/5GHm7B1giAInvfO6hQyCsq5tndbru0dRZi/tsE2Bqt3sLcWFqGotiWqcdt2ALTV1tWrB/Sn7NulDdIwoWGYUx2H8FUVz+uPZJY4lMdXpJlsSvKAAEIXfUPO9eOwnKmaT1Dy1tsowsPxmTK5CVsnCILgWbtO5HNJTCj/cbPXXh/1XhytCA7Gkp1tf23YtAlUKjT9+9nLJIulat200CyYj9Xo2XexzVY90sx69pUUbdoQsmQRskDHTIyFTz1N+R9/NFGrBEEQPE8ukxET4f4a+nqdu74VVT17oP9jDabDhzGfOIHux5/QDLrEYTKe5dQpFJGRHmmocH5q9uyVMZ3RGcyczq/KjCeTQZeI5hHswZZlL2ThQtBWmyRotZJ//ywMO3Y0WbsEQRA8qW/HYI6cLTl3xfNQ72Dv98AcrDod2aPGkDXsMqSSEvweqNqkwFpWhmHTZtR9enuincJ5curZx8RwNKvEYV+j9iE+eDfg+vmGoBnQn+CP5oO82j9RvYG8aXdiOnKk6RomCILgIQ9cGc/RzGKWbjnR4Oeu9294de/ehP38E7oVK5DJZHhddx3qfn3tx02HDqEZOgSvG8c3eCOF82PV6bCcPVtVoFCg7NCBI3syHerFRjafXn11XmPGEPjaqxQ+/oS9TCossiXd+elHFFFtmrB1giAIDWvhxjQ6h/vy/h+HWbH9NF0ifPHVOuc58ehsfAB1926ou7tOJKAZMADNgAFufbjgWU4b4LRrh0yjcRomimumwR7AZ/JtWLKzKZn7lr3McuYMuVOnEvb9CoeloIIgCBez3/Zk2L/PKNCRUeB6IzKPB/tKktmMOTUVa0kpcj9f23Iukfik2ak5hK+qnJxXcyZ+m6afiV8Xv4cexJKZhW7RInuZOeUwedPvInTJYmTahtuIQhAEoamsfGi4x87tVoS25BdQ/MorlP/4E5KhKvuaTKPBa9wN+D/9FIrg4AZvpHB+XE3OM1uspGXX6Nk382Avk8kIfOVlrLk56FdXzcg3bttO/pwHCP74I2SK89+URxAEoTloE+i57LP1nqBnyS8gZ+z16JYuQ+bnh3bMaHwm34b2yjHIAvzRLV1GztgbsOTne6yxgntcTc47nlOKyVI1Oy/MX3Peuyg1JplCQfAH81DXeFSkX/U7Rf99FkmqK9+UIAhC61bvnn3Ju+9iOXkSv0cfwe/+mcg0VcuiJKOR0o8+pvjNuZS8+x6BL77gkcYK7nHq2XeJ4bDT8/rm3auvTublRciXX5Bz402Yq83IL/vqaxQREfg9+EATtk4QBME9qyqe0V+WGIGPRml/XR/X9HZvG/B6B3v9H2vQXH6Zy/3sZWo1fg8+gGH7dvR/rAER7Jucyw1wYmI4sj3HoSy+mSTTqS95UBAhi74h5/obsGZWrSoofuNN5BHh+NxySxO2ThAEof5e+vEAMqB7dCA+GqX9dV0kbBP0PBbsLdnZeI0fV2cdVY8eGLZsdasBgmdYzp513AAn0LYBzpFMxxuA5v683hVl2yhClywiZ/wEpKIie3nh408iDwnFa/SoOt4tCILQPDxzQ3dkMgjxs42UeyJNbqV6B3t5UCDmtON11jGnHUdeI82p0DTMqTX2sO8cgyTBkcwaaXKb8bK7uqji4wn58gtyb50MlZNFLRYK7puJ4rtlDjkgBEEQmqPr+jj2zq91s7fujnpP0NMOH45+9Wp0P/zg8rju51/Qr16Ndrjnlg4I9Wc+5hjsVV1iyCjQoTNU7V3gp1V6dPanp2kuuYTgD+c5ZNmT9Hpyb78DU43JiYIgCK1ZvXv2fo89iv7P9RQ88BCln32OZtAg5GFhWHNyMGzbhmnffuSBgfg9+ogn2yvUk1PPPiaGozXW18dG+l30+8R7XX01gf97mcKnnraXSYWFFVn2fhB7NQiCcFEyW6wUlZswma0uj0e62VGrd7BXRkcT+uMPFD7xJMatWzHt2+9wXD1oEIGvvYKyXTu3GiB4Rs2evTKms/NM/Ivweb0rPrdPtWXZe+dde5klPZ3cKbcTtnIFcv+WcZ2CILR8B9ML+WT9MfaeLMBkcR3oZTIZm54b49Z53Uqqo4rpTNiK7zBnnMF08CBSaSkyX19U3bqhbBvl1gcLnuXUs+/ShSPbHJ/XN/fMee7we/QRLFlZ6JZ8ay8zJyeTN/1uQhd/47BUVBAEoTlKOVPE/V/uQKGQMTAmhH+P5BAb4UeIn4bDZ4spKDPSt2MwkQHuZw09rxy3yrZRIrg3Y9ayMtcb4Py4yaHexTo5zxWZTEbgq69gzclBv3advdy4ZQsFDzxE0EcfIpPXe4qKIAhCo1uwIQ2ZTMaXMy6lQ6gPlz7/B5clhnPX5V0wmCx8tO4oq/ed4anrXe9RU5dz/vYreullCv/7LJLJVGsdyWik8L/PUvTKq243QGh4ThvgtG9PvkEir9RoL1Mr5XQI9WnspnmUTKkk6KP5qPv1cygv//VXip57XmTZEwShWdt3qoDhCeEOv5utFb+2NCoFD12dQJtALz5a5/4233UG+/I1ayn99DNUcXHIVM7b7FWSqdWoEhIo/ehj9Ov+dLsRQsOqOYSvionhcI0ldzHhvigVLa+nK/fyInjhlygrNv2pVLbgS0rnf9RErRIEQTg3ndFCm8CqIXqVQk650eJQp1eHIJKOu5+Wvu5gv3Il8rBQvG+79Zwn8r5lEvLwcHTLV7jdCKFhuZqc57StbQt6Xl+TIjiIkMXfII+McCgvfuVVyr5b3kStEgRBqFuwr5oiXdUoeqifhuM5pQ51yvRmh/1N6qvOYG/ctRvNsOH12lFMplCgHTYU4+7dbjdCaFguJ+edbRnJdOpLGR1N6KJvkNWYiV/42P+hX/9XE7VKEAShdrERfqRmVwX3vh2D2ZGWx7oDmeiNFral5rLuYCYxEb5un7vOYG/JzUXRpv7rlOWRkVhyc91uhNCwXG1te7HtYd8QVImJhCz4HNTVdvWzWMifca+4KRUEodkZnhDOkcxizhbaUp1PG94ZL5WCZ1fsZeQr63j4myRMFiv3juxyjjM5qzPYy9Rqh/zq5yKVlyNTN//tUlsyyWp16tkb2nUiPV9nfy2XQZeIlt2zr6S59FKC570P1ZIHSeXl5N0+jfI//nDr37cgCIInje0bzYb/jLZnNo0O9mbBjEGM79+OgTGhXN83mi/uGUS/TiFun7vOpXeK6GhMe/bW+2SmvftQREe73Qih4VjOnkXS6+2vZYEBpBod/5rbh/qgVZ/70UxL4XXdtQS89CJF//mvvcyan0/+9LuReXmhufwyvK68Es0VV6AIDmrClgqCIDhqF+LD/13X9YLPU2ew1w4bSunnX2DYsQPNgAF1nsiwYyfGnTvxnXHPBTdKOH/mGjnhVTFdnIbwL6Y97BuK753TsGRlUTrvA4dyqbwc/e+r0f++GhQK1AMH4HXllWivHIOyffsmaq0gCHUpKDOyYEMq/x7OIbdEj5+XirhIfx68Mp5O4VXPszckZ7FwYxpp2aV4a5QMjQtj1ug4An0cR6C3HM3hg7VHOFNQTky4L49dm0hClOOmbpmF5dz64SZev6UPA2Pc71k3tTqDvc/dd1H61dfk33sfwZ98XGvAN+zYSf6Me0Gjxueu6R5pqFA/Lp/Xn62ZOa91DOHX5P/E40jFxZR99bXrChYLxi1bMW7ZStHzL6BMTMTryjForxyDqkePi34fAUFoCdLzdcz8cjsKmYxre7clMlBLcbmJ5DPFFOiMdKqot+5AJv9ZvpfEKH8evCqB/FIDS7ac4FBGEV/MGIRWZRvdPFNQzpNL99C/cwgTBrTntz0ZPLp4F989MAwfTVWInLsqmWHx4Q0a6FftyTjv9zbofvbKtm0JfPV/FD72OLk33oT6koFoLr3UvrmIJTMTw+bNGLfvACDwrbko23puiz7h3Gr27JUxMU49+9hW2LOHiix7r/wPr+vHUv7Lr5Sv/gNrZmat9c3JyZQkJ1Py7nsooqLQjhmN9soxaAYNEnNTBKGJPPf9PgK8VHw8fSC+Wtf5X8wWK++uTiEqyIuP7hxof2zZNTqARxbt4vvtp5g8xHZbsO1YLjKZjP/d3AutSsGgLqHc+O5GDpwu5JIuoQD8nZzF3pMFLJ0ztEGv5aUfD+BuF0ICZDRwsAfwmTQJeXAIRf99FuPWbRi3bqua7FSRkUzRrh0BL76A1+hRbjZbaGg1e/bWzjGk7XBcp9lae/aVNIMGoRk0iICXX8K0fz/61X9QvmYN5uSUWt9jOXOGsoVfUbbwK2T+/mhHjkB75ZVoR1yO3K91/zwFobEkHc/nYHoRb9zaB1+tCmPFjnBqpeNc86QT+eSWGLjviliH+UmDY8OIDvbmj/1n7cFeb7KgVsrtPf0AL5W9HEBnMPP2qhTuHxVHiG/D7rHxn3HdG/R8dalXbnyv0aPQjhyBYdNmjElJWLOzAZCHh6Pu1w/NkMH1WosveF7NmfjpIdFYrFVDRREBWgK8Ra8UbD19dc+eqHv2xP/x/8N88iT6P9ZQvmYNxm3bwep6xympuJjyH3+i/MefQKVCM2Sw7Tn/mNFiS11B8KCtx2xLu/29VNy3YDt7TxUgSba8IfePjmNQRU88JcP26LJbdIDTObpFB7DuQCYmsxWVUk73doEUl5tYvOkEI7tFsHTLCZQKGQlRthHQT9cfI9xfw7j+DT/5/Fo3e+cXot4b4cgUCrTDh6EdPsyT7REugKsNcFJljr3Olp5M50IoO3TAd8Y9+M64B0t+Pvp1f6JfswbD3xtqX6JnMmH4ewOGvzfAU0+j6t2raoJfXJx4zi80KMlqxVpQgDU7G0tODtbsnIo/K17n5oFSgczLC5mXd8WfWuReXhXfeyHzriqXVS93OOaFTKNpdptHncotA+CpZXvo2jaAl27qRXG5iYUb03h08S7emdKPgTEh5JQYAFsGuppC/TRYrBJ5pQYiA73o0S6QqUM78cHaw8xbcxiVQsbDVyUQEeDFkbPFrNx5mi/uGXTR/18+r13vhLolJyef1/v0ev15vxdsM8tNb821v5ZpNGw7ku5QJ1hpuKDPaGgXes0e1aO77evhh7CWlmItKkYqLkYym8/93t17kB06hNw/AFmAP3Jvb5DJmvf1eoi45nOTrFYwmWz/tkxmJLMJzGYkkxnMNcprZkoNCrJ9xcfXv4FGo+2rqLjOajK5DORyhy+ZTG5L1lG9TC7HLJdzyGI571He+Brtnz17NnPmzHEoKzPa/u91CPVh7m197AF4QOdgbvlgEx//eZSBMSEYKobg1S72/9BUDPlXDtMDzBodx6RBHcgsLKddiDcB3mqsVonXfjnExIHtiY30Y3tqHh//eZScYj092wfx2LWJBPl4ZpQ06Xg+q/ed4VhmCWUGMz4aJV0i/biqZxT9OgWf1zmbPNhby8oo/eRTTHv3Ydy/D2tWNtprriHks09c1i9fvZqS9+dhOnwYuY8v2tGj8H/maRTBzj8AU0oKRf97FeOOHSBJqPv3I+Dpp1F1c16zaC0ooOjV19GvWYO1pBhVbBx+s+7Ha+x1bl9TYmKi2+8B203C+b4XQPfDDxQ8+pj9tXbUKHKG3+dQZ0jPGBITws/7MxrahV5zY5MsFoy7dtme8/+xBsvx4/V6nzwkBO2oK8hNTKBDv/6gqPwlqbD94lQoQK6w9aQUlb9EFcgqv1coQCa3vVYo7L9g7cfk8nr3PCSrFclgQCrXg16PZNAj6Su+DAbn78tt31NXnZrf66vqWwwG5GqV7VqVSltblUpbD7SyTCFHprCVIVcgUypAoXAuUyor3uNY5vieap+jUtneo1bbPlOlspWplMhUatuxyu9VSmRKFahVFXXVyFRKUKqQ2csq36+qOreLn3tycjIJXbpgzc112QO3ZOdgzcm2/ZmdjaTTufibuvhohg8jZMlit3vBSUlJHD58+Jz1KoP31b2iHD6jXYgPPdsHsudkAeVGs/0ZvtHi/CjOUPGcX6NyvCkJ9dM4jASs3HGa/FIDd4+I4UyBjkcXJzFteGcujQ3jnd9TeHbFPubd0d+t6zwXi1XilZ8O8PveM/Z7OrVSjtFsJeVsMb/tzuCa3m15+vpuyOXu/YybPtjn51Py1tvII8JR9+iJPmtdrXV1P/9Cwcz7UfXqSeBzz2HJzaX0k08x7tlD+K+/IPPystc1px0nZ/wEZF5a/B6Yg0yjofTLheTcOIGwX35CFRdnrysZDOTechumw4fxvfsulJ06Uf7Lr+TfN5MggwHvmyZ49GfQUGpOzpPHxHDMaY29GMa/EDKFAs2AAWgGDMD/P89gPnbMHvhNdaTgtebloVv2Hd5AjscaJ3N9I6Cw9cYki8WWcMloPPe5GrJZgKRz7pC2GEpl1Q2AUglqFb7les4UF9snMbcWhk2bPXr+iADbjnAhvs496hBfDZIEpXoz4f62erklBjqFOeaRzy0xoJDL6pxsl1di4OP1R3l2fA+81EqWbjlJiK+Guy63pamdMbILc77aSU6xnjB/ba3ncdfX/6Sxau8ZEqMCuHtEDL3aB+GjUaIzmNlzsoDP/z7Gqj0ZRAd7M214Z7fO3eTBXhEeTuTO7SjatAEgo207l/Ukk4mi559H0b49od+vQF4R2NW9e5M39XZKv/oKv/uqerFFr76GVFZG2A/fo0pIAMBr7HVkDb+copdfIfTrhfa6ZUu+xXTgAIGvvoLP7VMB8L71FnLH3UjRCy/ide01DjcSzVXNyXlZ7WPRHa8aqvL3Utn/swgXTiaToYqNRRUbi9+c2VgyM9GvXUf5mjUY/t3U6EEVSYKKRww1Q0zrCjmNzGy2DbOXl9t/zp580i0LCEARFoY8LAxFeOWf4SjCw5GHhIAkIZWX27+s5eVIOl3FKE2545dOZxu5qVFuLdeB3uB227RXjvHos+2ubQP4YWc62cXObcsq0qOQy/D3Utkn1x1ML2JAZ8d18Ycyiugc7us0g7+6d1an0K9jMMMrRkGziw0Ovf7Km4nsBg72v+zOoH2ID59MH4iqWvu8NUoGx4XRv3MIUz/azM+70i++YC/TaOyBvi6GLVuwZmXj/8Tj9kAPoB05AkXHjpT/8JM92FvLytCvW4dmyGB7oAfbjYXX2OvQLfsOa0EB8iBbatTyH39C5uOD9y2Tqtoll+Mz7Q4K5jyA/p9/8BozpqEu2WNqbm17PLAtUGZ/HRfpd9FPMmnOFJGR+Eydgs/UKVhLSzH89Tfla9agX/cnUnHdz0aFVk6ttgVrewAPRxEeZgvq4WEowsKRR4SjCA1Fpm2cG3bJaq3jBqHc6SbhrCQRNXWKR9s0PCGct39P4edd6Vzfty3KimH9o5nFHEwvpF+nEDQqBX07BhPiq+bnXenccmkH+7K6zUdzOJ2nY9bouFo/Y+uxXDYfyeHb2UPsZWF+GtYf0tln8Kdm20ZMXU0AvBB5JQYmXtLeIdBXp1bKGRofxoptp9w+d5MH+/oy7d0HgKpPH6dj6r59KP/pZySjEZlajSk5BYxG1K7q9umDbsm3GA8cRDtsKJLViunAAVQ9ezglSlH36W377D17m32wl6xWzGmOw/ipcj8cgn0r2OmuuZD7+uI19jq8xl6HZDJh2LoN/Zo1FG3bjpdKaVvWZ7HaJmZZLWCVwGJBqvY9VqvttcVa9X3lMYsFSaqqV9sywVppNci0WtuX5tzfU728+ldd9b1s3x9JSyO+SxfbtZrNSGaL7ZrNZqSKa8Fcce0Oxy1IFrPtWquXmc1V3zuUVZzfYrb9bE0m23tNJtvkt8rJbvbXNcvMSCajfSKcZKycJFdVhrFyspzJfv5ayWTIg4MrgnUY8vAI5wBe8VoWENDsbsRlcjkyb2/w9q5XfXNyssdHQAO81cwaHcfc35KZ+eUORnePpLjcxHfbTqFRKXjgSlsQVynlPHhVAs+u2MfMBdsZ2zeagjIDSzafpFOYDxMHuk6FbTBZmPvbIe4Z0YWIgKprGdU9ki82pPLM8r0M6BzMok0n6NMhyKFOQ2gT5EWZoY5/U9jW/bcJcv9z6x3sCx55FO1VV9YZ9PR/rqf8t98IevsttxtyLpasLAAUkRFOxxQREWCxYMnJQdm2LdaKuvKIWuqCPXOatbAISa+3l1cnr5YpsLmznDlTYwOcQI4WmhzqxLXyZDpNRaZSoR02FO2woZxNTqaDByYkSpJUFfSr3wjYbxqsyBSKqkDcmIElO9s+itbSOM6ir7ppOJqaSvygS2zP8oUGddPA9gR4q1iy6QQfrj2CUiGnT8cg7rsi1mE3zzE92qBSyFm4MY13V6fgrVYwomsE94+KrXUjsAUb0vBWK7l5UAeH8vahPrw6qTfz1x1h5/E8ercP4snruzX4tU0c2J6P/zzKrYM70D7Ex+n4ydwy1h7I5P5RtY9M1KbewV733XIU7drVGexNKSnolq/wSLCvXOfsKk2pTKNxqGOvq6l/XdTOwzE169Y0b948PvjAcWOVJUuWNMnSO8XOnVT/p2GMiiI5vcChjlKXS3Jy0Xmd31Na27Ks1na90Eqv2deHlBqpq1u6xvx7Ht29DaO7n/vx74iuEYzo6tyRq83MUbHMHBXr8tjwhHD7M3xP6RzuS8/2Qdzx8Rau6RVFz/aBBPqoKSwzsvdUIb/vPUO/TsF0CvNh94l8h/f26Vj3krwGHcaXysttS148wB54XUx6kgy2yRqVz7LsdQ2116WyrrYiyBudJ3zUPG9Nc+bMcVoHmpSU1CRL70o3b6F6GDf36EuxoWpoV6OSM2JgDxRuLtfwtItt6d2Fam3XC+KaW4sLueakpKQGbs3F6f6FO2yrV4CVO0/zw87T9mOVkz83Hclh8xHnNT2bn7+yznPXGZnNGY478liLipzKANsQemYm5b+tQhEVVecHnq/KSXyWzCxUsY53XpasLFAoUISFASCvqFs5nO9UF+xpTeVBQaDV2MurqxzqvxhSoNaciX8iOp7q0b9LhF+zC/SCIAhClemXxbi9MU591Rnssy65tGrTG5mMsi8WUPbFgtrfIEn4P/VkQ7bPTtWzBwCm3bvRDnPceci4ew+q+Hh7j16VmABqNUYX656Nu3eDQoGqu20DAplcjrpbd0wHD9kn+FU/L4CqV09PXFKDqrnGPs0/0iHYt8Y97AVBEC4m94zo4rFz1xnsvW+aYAv2koRuxfeounZ1mX0OhQJ5YCCawYPRjhzhkYZqLr0UeXg4Zd8uxfeeu+2zPvXr/8Jy/Dg+zzxtryv38UF7xUj0a9ZiOnwYVUUaRkt2NuW//obmsuEogqsmDHndcD3GpCR0S5fZ19lLVitlC79CHhSE5rLLPHJNDclU4/lgqsyXmsvuBEEQhNapzmAf9O479u8NW7fhPelmfO+a3uCNKP1yIdaiqm6oOfUYxe++B4Bm0CX2/cMDnvsvBbPmkDPhJnxuuQVLXh6ln3yKMi4OnzunOZzT/8knMfy7idxbb8P3nntsGfQWfAkWCwHVbgwAfCbfhm7pMgqfex7z6dMoO3ak/JdfMSYlEfj2Ww7r+psja2mp477sCgVHix2Xb4iZ+IIgCM3bvDWHmXlFrD1/gCvZxXpe/GE/H9wxwK1z13s2nffNE5EHBrp18voq/fgTLOlVG7aYDx+h5M2KDV0eeRjNoEG2Nowbh0ytoeT9eRQ+/wJyHx+8rrka/6efcgrIqi4xhK38nqJXXqHk3fdsufH79cX/4/kOiXbANgEvZNlSil991ZZwp7QUVWwsQfM/xPuG6z1yzQ2p5vr68s6xnCmsWoankMuIiRDBXhAEoTlbsvkEO9PyeWFCDzrWSPMLsP5QJq//cohSfT0246qh3sG+ZN4H+N59l9sfUB+R27bUu67XNVfjdc3V9aqr6ppI6KJv6lVXERxE0JtvwJtv1LstzYXTHvbxjsmEOoT62DNICYIgCM3TjBFd+GJDKtM+2cqcMXFMqEj+U24089aqFFbtySDYV8Nbk/u6fe56B3tldDTW/PxzVxQanVOa3KhYqJZQTTyvFwRBaP7uvCyGS7qE8tz3+3hrVTKbj+YyYUA73v49hYwCHcPiw3nmhm4EeLu/tW79h/FvmUTpZ59jycmxL3ETmoeaPfs03wiolopdpMkVBEG4OHRtG8A39w3mrVXJ/Longy1Hc9CqFDw5ths39Is+7/PWO9h7jb0Ow9at5NwwDr/77kPVswfy0NCqpXnVT9q27Xk3SHBfzWV3qZI3UDVBL15MzhMEQbho5JcZOZFrW00lYdsSw2R2c/+LGuod7LMGD7Uvwyt85j+1V5TJaHvqxAU1Sqi/mhvgGBVKTpY6zsSPFWvsBUEQLgqr9mTw9u8plBstTB3SieGJ4bz0wwHe/j2ZTUdz+M+47oT4ur/bXv2H8SvX3AvNSs0NcE63T8BSbfPyyEAt/l5iMw5BEITm7r/L9/LnwUzC/bW8cWsf+lbku//qvkt59/cUftqVzpT5m3nq+m5u5+mvd7CvvuZeaD7MNZLpnIrt7fA6XvTqBUEQLgrrDmYyqlskT4ztiq+2qpOmVSl48vpuDI4L45WfDvDk0t3nzIVf00Wzn73gWs3n9SciOzu8Fsl0BEEQLg7Pju/B1b1q319meEI43doO4aUfD7h9breDvVWnQ7/6D0wHD2ItKUXu54uqWze0V45B7uO8/67gWU4z8b3DoVq+BTETXxAE4eJQV6CvFOKn4d2p/dw+t1vBvvy3VRQ8/jhScQlI1R4My2TI/P0Jeu1VvMZe53YjhPNXfY29RSYjzeq4Ha8YxhcEQWg5yvRmSvQmIgPdS+NeewLeGgzbt5N//ywwmvCZfifBX3xG2M8/Ebzgc3zumg4mE/mz52DYvt3txgvnz1StZ3/WPwJ9tdUZgd4qwvzdn7UpCIIgNI7Bz//Bgr8dR2jXHjjLE0udd20F+HbLCW58d6Pbn1P/dLnvz0Pm7U3YLz+j6hLjcMxrzBh8pk4l57qxlMz7AM03X7vdEMF9NTfAOR7W0eF4XBt/ZGIFhSAIQrMlARKSQ9nJnDL+Sclu0M+pd8/euHs3XmPHOgX6SqqYzniNvQ7jrl0N1jihbjU3wDnZqZvD61iRJlcQBEHAjWCP3oA8MKDukwUGgt5wgU0S6sspJ354J4fX8WJyniAIgoAbwV7RqSP6P/9EsrpO2SdZrejX/4WiY4cGa5xQt+oz8SUgzSvE4bjYAEcQBEEAN4K9900TMB8+Qt4d0zAdPuxwzHTkCPl33Y358GG8b7qpwRspuFY92Od7B1GMYxKGdiFiKaQgCILgxgQ937vvxrhtO/q168j+ewPygADkYWFYc3KwFhWBJKG94gp8Z9zjyfYK1ZiqDeOnhbZ3OBYb6YdCLibnCYIgNHcyPP+7ut7BXqZUEvLlAsq+W45u+QpMhw5hTktD5uuL5tJL8bppAt4TbxKzvxuJZLViPl41Qe94SDuH42IIXxAE4eLw1b9pLN16wv7aULHD3ZjX/nSqazjP3e/czqDnc/NEfG6eeF4fJjQcS0aGw2TI45GOqyRE5jxBEITmLyJA69Sz96kjPUpdx+oicuNfpGqmyT1RY4292MNeEASh+fvx4csa5XPcDvZly76jfOUPmA4dwlpaitzXF1XXrnhNuFH0+BtR9Q1wSjQ+ZKurgrtCLqNTmG9TNEsQBEFohuod7K3l5eRPm45h82aQJGQBASg7dMCSk4Nh0yYMmzdT/v1KQhYuQOblXs5ewX3Vt7Y9Eez4vL5jmA8alaKxmyQIgiA0U/VPl/vmXAybNqG9cgz+Tz6BKjbWfsx05AjFr7+Bfs1aiue+RcB//+ORxgpVqvfsj9eYiS82vxEEoTU4nlPK1I82Y7ZIzL2tD0Pjwx2Ob0jOYuHGNNKyS/HWKBkaF8as0XEE+qgd6m05msMHa49wpqCcmHBfHrs2kYQoxyRymYXl3PrhJl6/pQ8DYxxzmlwM6r3OXvfTT6h69iDki88dAj2AKi6O4M8/Q9WtG7off2zoNgoumFKrevbHa/TsxR72giC0dJIk8fovh1ApXIexdQcyeWLpHgAevCqBCQPa8eehTGYt3IHeZLHXO1NQzpNL9xAZ4MWcMfFIwKOLd1FmMDucb+6qZIbFh1+UgR7cCPZSYRGaYcNqPS6TydBcNhypqLhBGibUzrYBTpb9dc2evZiJLwhCS/fLrgySzxQxeXBHp2Nmi5V3V6cQFeTFR3cO5MYB7bh7RBdentiL1OxSvt9+yl5327FcZDIZ/7u5FzcOaMdLN/Uir9TIgdOF9jp/J2ex92QBD14V3whX5hn1DvbK2Fis2XXvwmPNykLZpcsFN0qoW/WZ+AaFioyANg7HxRp7QRBassIyIx+sPcKdw2Nc7uuedCKf3BID1/eNRquumr80ODaM6GBv/th/1l6mN1lQK+VoK+Y5BXip7OUAOoOZt1elcP+oOEJ8L94tw+sd7P1m3U/5z7/Uul+9YetWdL/8gt+c2Q3WOMG16s/rTwVHY5VX/TW2DfLCV6ty9TZBEIQW4f0/DhPorXLZqwdIybCNMHeLdt68rVt0AKlZpZgqktN0bxdIcbmJxZtOcLawnE//OopSISMhyjZC+un6Y4T7axjXP9ozF9NI6j1BT9LrUQ8ZQu6EiWguvxzNgP7IQ0Kw5uVh2LEDw98b0I4ciaTToVu+wuG93hNFvvyGVL1n75Q5TwzhC4LQgiUdz2PV3jO8d3s/VErX/dWcElvCsVA/5554qJ8Gi1Uir9RAZKAXPdoFMnVoJz5Ye5h5aw6jUsh4+KoEIgK8OHK2mJU7T/PFPYMaJTvsyz8eYHhCOMMTwmuts/lIDusPZfGfcd3dOne9g33Bw4+ATAaShOGvvzD89ZdTHf2ff6Jfv76qQJJAJmt1wT45Ofm83qfX6+v1XnOP7ljfmmv7rLNeUFh1LFBRv3M0F/W95paitV0viGtuLS70muPjHZ+Hz549mzlz5jiUGc1W3vg1mSu6RXJJTGit5zJUDMGrXUze01TcIFSfpDdrdByTBnUgs7CcdiHeBHirsVolXvvlEBMHtic20o/tqXl8/OdRcor19GwfxGPXJhJUY1b/hfptTwZtArV1BvtjWSWs2pPhuWAf+PZbbp24NUtMTDyv9yUnJ9frvVlzHsRc8Z/q7PVPQ3hn+7GhPWNIjAs7r89vCvW95paitV0viGtuLS7kmpOSkjhcYzdVV77+J42cYj3z7uhfZz11RUA3WpzzyFfmlq+ZiyTUT+MwErByx2nySw3cPSKGMwU6Hl2cxLThnbk0Nox3fk/h2RX7ztkOTzCYrOe1yVm9g73Ijtc8VN8AxyKTczLY8TmSmJwnCEJLlFti4Ot/jzO+fzQGk4XTeWUAFJQZ7cdP55XRJtCLcH+tvaxmNtHcEgMKuazOyXZ5JQY+Xn+UZ8f3wEutZOmWk4T4arjrctsE9BkjuzDnq53kFOsJq/is85VZWO7wukRvdioDsEoS2cUG1h/KJCLA/cR1Ijf+Rab6BjhnAiIwKquGkYJ81C6fUQmCIFzs8ksNGM1Wlm09xbKtp5yOv/bLIQBWPjTcPrnuYHoRAzo7ros/lFFE53Bfe+/flXdWp9CvY7B9OD272ODwu7XyZiK7AYL9+Hc32rfBkQHfbT3Jd1tP1lpfAmZeEVvr8drUO9ibjh7FdOAA2tGjkfva7pQkg4GiV15Fv3YtMq0W33tn4DNpktuNEOqveprc4yE1Mue18RNbDAuC0CJFBXnxys29nMp3nchnxfbT3D60EwlR/gT7qAnz0xDiq+bnXenccmkH+7K6zUdzOJ2nY9bouFo/Z+uxXDYfyeHb2UPsZWF+GtYf0mEyW1Ep5aRmlwCuJwC66+peUciwBfHf954hNsKPWBcjtHK5DH8vFf06BTM41v1HtfVPl/vuexg2b8HrhhvsZcWvv0HZFwuQ+fggGY0UPvY4iqi2aIcNdbshQv04pMmtEezjRJpcQRBaKF+tipHdIp3KdUYLcJqe7QMd0uU+eFUCz67Yx8wF2xnbN5qCMgNLNp+kU5gPEwe2dzoP2Cb2zf3tEPeM6OIwVD6qeyRfbEjlmeV7GdA5mEWbTtCnQ9B5DafX9Oz4Hvbvd58o4No+bZk0qMMFn7emegd74+7daIYMRlaxplsymSj7dinqvn0J/W4p1qIisq+6htJPPxPB3oMcl92JzHmCIAiujOnRBpVCzsKNaby7OgVvtYIRXSO4f1SsQ6Kd6hZsSMNbreTmGsG2fagPr07qzfx1R9h5PI/e7YN48vpuDd7mHx4e3uDnrFT/Xe9yclFERdlfG3fvRiopwef2qci0WhRaLdoxY9CvW+eRhgo2pmO2YC/hqmcvJucJgtC6XNenLdf1aevy2IiuEYzoGlHvc80cFcvMUa6fh59r/XtzV/8JemoVktFof2ncth1kMjSDB9vL5IEBWAsLGrSBgiNzmi3Y5/gGU6r1sZd7qxVEB3s3VbMEQRCEBrD1WC5Lt5wk5UwRJXozkiQ51ZHJZGx6boxb5613sFd26IBx8xb76/LfVqHs3BlFVFVedsuZsyiCL84dgS4G1pIS+wY4NXv1XSL9kJ/H2ktBEASheVi7/yzPfb8PCWgT6EWHUJ/zWlPvSv3X2d96K4VPPU32dWORqdWYDh7E/6knHeoYd+9GGef+kgChfsxpVZPzTojJeYIgCC3KlxvT8FIrmXtbH/p0DG7Qc9c72HtPmYz5xAnKli4DwGfKZHzvnWE/bti8BcuJE/hMvq1BGyhUcZyJ75gTP17sYS8IgnBRS8/XcW3vqAYP9OBGsJfJZAT89z8E/Pc/Lo+r+/ejzaEDyLzFc2NPqWuNvZiJLwiCcHEL9lU32LB9TfXe4vZcZGo1cn9/ZEqRlM9TKnv2JRofcn2r5kYoFTI610gJKQiCIFxcru3Vli1Hcx026WkobkdmyWzGnJqKtbgYLK4bpBk06IIbJjgzpdp69mk1evWdw3xr3epREARBuDjceVln0nJKeeDrndw/Ko7YSD98NA3Tga7/fvZWqy1j3ldfI5WV1Vm37ena8/oK50eyWDAfPw44D+G7Sq0oCIIgXFyGv7QWsOVRuf/L7bXW8+jSu5K5b1H64XzkgYF4TbwJRWQkiCH7RlN9AxzxvF4QBKHl6dUhCE8toK53tNZ9txxFh/aE//Yr8sBADzVHqI1DmtzQmhvgiGAvCIJwsfvozoEeO3e9H/RaCvJtO941YaA3nz5NRtt2Lr9yJ09xql++ejXZ11xLRkwXzvbsTcGjj2HJz3d5blNKCrlT7+BMQlfOxCeSO3kKpoOHPH1J9VY5OU+vVHMmwDH9Y2yEGMYXBEEQalfvnr2qcwzWgkIPNqX+NCNH4j3uBocyRYRjANT9/AsFM+9H1asngc89hyU3l9JPPsW4Zw/hv/6CzKtqtyJz2nFyxk9A5qXF74E5yDQaSr9cSM6NEwj75SdUcbVvh9hYKpfdnQqKRpJV3aNFB3vjoxWPUwRBEFoKo9nKzrQ8TuSWoTdamH55DGDbla/MYCbQW+12xtR6RwnfmfdR+Mx/MJ86hbK96+0BG4sqtgveE26s9bhkMlH0/PMo2rcn9PsVyCsCu7p3b/Km3k7pV1/hd9999vpFr76GVFZG2A/fo0pIAMBr7HVkDb+copdfIfTrhR69nvowVfTs05yG8EWvXhAEoaXYkJzFa78cokhnRAJkYA/2x7JKuOfzbTx7Yw+u6hlV53lqqnewV0S1QTN0KDnXXIfPXdNRdeuG3N91oGmMpXeSXo8kSfZAXp1hyxasWdn4P/G4w3HtyBEoOnak/Ief7MHeWlaGft06NEMG2wM9gCI8HK+x16Fb9h3WggLkQUEev6a6mCuW3dXMnCfS5AqCILQMu0/k8/R3ewn313LX1YnsTy9k7f6z9uPdogNpF+LDX4eyPBfsc2+6GWQykCRK3nrb9n0tPL30rmzRYko//QwkCUXbtvhMvg3fWffbE/qY9u4DQNWnj9N71X37UP7Tz0hGoy3Hf3IKGI2oXdXt0wfdkm8xHjiIdthQj15TXawlJVizsgFXM/FFz14QBKElWLAhjQBvFQvvHUSAt5pCndGpTkKUPwfTC90+d72Dvd/DD9UZ4BuFXI5myBC0V1+Fom0U1pxcdN9/T/Ebb2I8eIiQTz8GwJJl2xlOEem8j7EiIgIsFiw5OSjbtsVaUVceUUtdwJqZ6akrqpfKDXDMMgWngqIdjomevSAIQsuQfKaIUd0iCfBW11on3F/LhhLnm4BzqXew93/0EbdP3tCUbdsS+t1ShzLv224l/+570P/2G4ZNm9EMGYxUXg7YUvjWJNNoAOx17HU1565b07x58/jggw8cypYsWUJycrI7l2Wn1+tdvle1cSNeQEZgJCalyl4eoJWTnZ5G9nl9WvNQ2zW3VK3tekFcc2vRGq+5oZktElq1os46xeUmlAr3O94X/TRumUyG3+xZ6Ff/gX7jRjRDBlcFaaPz3Y9ksCWmkWm1tj8r6xpqr0tF3ZrmzJnDnDlzHMqSkpJITEw8r2tJTk52+d7iX36lBOch/K7tgs/7s5qL2q65pWpt1wvimluLC7nmpKSkBm7NxaldiDf7TxfWetxqldhzsoBO57EXSotIqK5oZ5u0Zi0osL1u0wYAS2aWU11LVhYoFCjCwgCQV9StHM53qgu2bIFNyHTMllBHTM4TBEFoua7s0YbkjCIW/Xvc6ZgkSXyy/iin88q4qmcbt8/tVs/enJ5OyfvzMPzzL5bsLDCanCvJZLQ9dcLthlwI83Hb5ylCQwFQ9ewBgGn3bqeJdcbde1DFx9t79KrEBFCrMe7e7XRe4+7doFCg6t7dg60/N3NaZbAXy+4EQRBaqkmDOvDvkRzmrzvC7/vO2Le7fWHlfg5lFHEqr4x+nYIZ37/dOc7krN49e/Px4+RcdQ26Zd8h8/EBgxFF27YoY2JsOfIlCVViIuqBnkv3Z8kvcCqTzGZK3n4bAO2oUQBoLr0UeXg4Zd8udXjerl//F5bjx/EaP85eJvfxQXvFSAybNmM6fLjqs7KzKf/1NzSXDUcR3HTL7iSLBXPacSTgRM2evUiTKwiC0GKolHLev70/U4Z0IqdYz9HMEiRg9b4z5JYYmDy4I29P7ud2Qh1wo2df/NbbWEtLCf1uKZpLLiEjuj3ek27G/+GHsOTkUPjMfzEdOkTYt4vdbkR9FT7+OFJZGep+/VC0aYM1NxfdTz9hPnwEnztuR93XtnxOplYT8Nx/KZg1h5wJN+Fzyy1Y8vIo/eRTlHFx+Nw5zeG8/k8+ieHfTeTeehu+99xjy6C34EuwWAh45mmPXU99WDIywGAg2zeUMo2PvdxHoyQq0DnHgCAIgnDxUivl3D86jpmjYjmZW0ZxuQkfjZKOYb72nv75qHewN2zejHbUFWguuaSqUJIAUISFEfzhPLJHX0nxK68S9Nbc825QXbRXXIFuxQrKvlmEtagImVaLKjGBoPfexfumCQ51vceNQ6bWUPL+PAqffwG5jw9e11yN/9NPOSXiUXWJIWzl9xS98gol774HkoS6X1/8P57vkGinKVRugFNz85vYSL/zursTBEEQmj+ZTEbH85iIV5t6B3trQaFtyL6SSoWk01U1TKVCM2wo5b/91mCNq8nn1lvwufWWetf3uuZqvK65ul51VV0TCV30zfk2zWPMtU7OE8/rBUEQWpI9Jwv4OzmLqUM6EeKncTqeV2Lgm03HuaJbJD3aBbp17no/s5cHByMVF9tfK0JCMJ844VjJbEYqKXWrAULd7D17sYe9IAhCi/bt5hNsOpLjMtADhPhp2Hwkh6VbTrh97noHe1VcLOa0quUA6v79MPy9wT6L3XQsFd3Pvzj2/oULVrXsTszEFwRBaMmSzxTTu33dE8J7dwjiYHqR2+eud7DXjhqFYetWLNm2fG2+989EslrJuX4cZ3v2JnvkFUhFRfjNnuV2I4TamdNSKdL6ke9T9Q9ApZCdV1IFQRAEofkq1BkJ9nXdq68U5KOhoMyD6XJ9bp+K1/VjkQcEAKDu2ZPQpUsomfchllOnUHXvhs+0aXiNGe12IwTXKjfAOd62q0N553A/lIoWkQ9JEASh3lLOFPPHvjMkHc/nTGE5JouVjqG+3NAvmvH9o5HV2L9lQ3IWCzemkZZdirdGydC4MGaNjiPQxzE9+pajOXyw9ghnCsqJCfflsWsTSYgKcKiTWVjOrR9u4vVb+jAwJsQj1+fvpeJsoa7OOmcLdXhr3E9+W+93yFQqe9a5SpqBA9F847l19a1d7c/rxRC+IAitz6JNx9memsflieGM698Ok9nKuoOZvPHrIQ6fLeap67vZ6647kMl/lu8lMcqfB69KIL/UwJItJziUUcQXMwahVdly0J8pKOfJpXvo3zmECQPa89ueDB5dvIvvHhiGT7WgOndVMsPiwz0W6AF6tQ9iQ0o2p3LLaB/q43T8RE4pG5KzGRIX5uLddat3sM8cPATtiBEE/u9ltz9EOD/mVNtud07P60WaXEEQWqGJl7Tnv+O6o1EpHMpmfbWDn5LSmTSoA53DfTFbrLy7OoWoIC8+unOgfXOZrtEBPLJoF99vP8XkIZ0A2HYsF5lMxv9u7oVWpWBQl1BufHcjB04XckkXW1bWv5Oz2HuygKVzPLvV+e3DOrExJYu7P9/G7UM7MTAmhFA/DbklBral5vHNv8exShK3D+vk9rnrv/QuvwCZr3hO3JjMx44BzsE+VvTsBUFohXq5mLwml8sYkRjB7hMFpGaV0Dncl6QT+eSWGLjviliHXeQGx4YRHezNH/vP2oO93mRBrZTbe/oBXip7OYDOYObtVSncPyqOkHM8T79Q8W38efbGHrzy00HmrzvC/HVVxyRAq1Lw3I09nR4x1Ee9g72qRw/M1dLJCp5nSk2jXKnhbEC4vUwmg9gIEewFQRAq5ZbYdiitfBafkmFbJt4t2jkodosOYN2BTExmKyqlnO7tAikuN7F40wlGdotg6ZYTKBUyEqJsI6ifrj9GuL+Gcf2jG+VaRndvQ9+Owfy2O4OUM8WUGsz4aZUkRgVwde+o877hqP9+9o89Qu4tt6H76We8b7j+vD5McI859RgnQ9ohyaom47UL9j6vyRmCIAgtUV6pgR+TThMZqLUvW8upCP6hLtarh/ppsFgl8koNRAZ60aNdIFOHduKDtYeZt+YwKoWMh69KICLAiyNni1m58zRf3DPIafKfJ3zx9zGigry5ulcUtw/r3KDndiNd7hY0gy6hYPYcSj/7DHXPnshDQ21dzRr8H36oIdt40UlOTj6v9+n1+qr3ShLGe2ewP1cF1XbfjfQ5//M3Rw7X3Aq0tusFcc2txYVec3x8vMPr2bNnM2fOnDrfYzRbeXrZHkr1Zl6e2BuV0tYxMlQMwatdrFrSVNSpHKYHmDU6jkmDOpBZWE67EG8CvNVYrRKv/XKIiQPbExvpx/bUPD7+8yg5xXp6tg/isWsTCaoxq/9CLdyYxqRBHRr0nJXqDPaZlw7B95678Z1+JyVvvW0vN+3Zi2nPXtdvkslafbBPTEw8r/clJyfb32s+dYqshx8lZ9gdED/MXqd/XFsSExv2jq8pVb/m1qC1XS+Ia24tLuSak5KSOOzmY2Kzxcoz3+1h3+lCnriuq8MseXVFQDdarE7vM5htZdUn+YGtx199JGDljtPklxq4e0QMZwp0PLo4iWnDO3NpbBjv/J7Csyv2Me+O/m61+VzaBHpRpHOxdXwDqDPYW06fxlpky9QTunyZRxoguGauNXOemIkvCELrZrFKPPf9Pv45nMMjVycwrsb+7uH+WsD2LL9mArLcEgMKuazOZ995JQY+Xn+UZ8f3wEutZOmWk4T4arjr8i4AzBjZhTlf7SSnWE9YxWc1hOv6tGXp1pPklRoafDJgvYfxNZde2qAfLNTNnJqKWabgVFCUQ3ms2ABHEIRWzGqVeGHlfv48mMWcMfHc7GLYu3Jy3cH0IgZ0dlwXfyijiM7hvvbevyvvrE6hX8dghifYJkdnFxscev2VNxPZDRzsR3WPZPfJAmZ8vo3JQzqREOVPkI8aV7MFIt3c4lzM9GqmTMdSSQ9qg1mhspeF+WnOmUpREAShpbJaJV7+8QBr9p9l5hWxTB7S0WW9vh2DCfFV8/OudG65tIN9Wd3mozmcztMxa3RcrZ+x9Vgum4/k8O3sIfayMD8N6w/p7DP4U7NLANcTAC/EhPf+QYZtmd3c3w7VWk8mk7HpuTFunVsE+2bKnJpKmtjpThAEwW7emsOs2nuGrm39CQ/Q8vveMw7He7YLpG2wNyqlnAevSuDZFfuYuWA7Y/tGU1BmYMnmk3QK82HiwPYuz28wWZj72yHuGdGFiICqnvOo7pF8sSGVZ5bvZUDnYBZtOkGfDkEOdRrC1b2iXPbiG8I5g33p55+j+255/c8og8jNmy6kTQK2YH+880iHMrGHvSAIrVnKWdv6+UMZxbywcr/T8f+M607bYG8AxvRog0ohZ+HGNN5dnYK3WsGIrhHcP8ox0U51Czak4a1WOj0aaB/qw6uTejN/3RF2Hs+jd/sgnqyWmrehPDu+R4Ofs9I5g71UVIylqPhc1YQGZC0pwZqdzfEBomcvCIJQ6aM73duLZUTXCEZ0jah3/ZmjYpk5KtblseEJ4fZn+BejcwZ7v0cfafVL6RqbOTUVKzJOhDjOMBV72AuCILR8eSUG/krO4mRuGXqjhWfGdQegoMzImQIdMRF+9nkI9SWe2TdD5mOpZPuFUq6ueh7kp1XSxs3Zl4IgCMLF5butJ/lw7RF7jgAZ2IN9YZmRez7fxuPXdXVabnguYlP0Zsicmuq8+U2kX6OkaxQEQRCaxt/JWbyzOoUukX7Mva0vN9YI6J3CfekS6cffydlun1v07Jsh07FU0kLF83pBEITWZPGmE7QJ9OLDaQPQqhQkZxQ51ekS4ceuE/lun1v07Jshc5pzz17MxBcEQWjZUrNKGBwbVufz+FBfDQWlRrfPXWfPvm36KbdPKFwYyWLBfPwEx/s6Dt+Inr0gCIKQV2pwyutfH6Jn38xY0tMpkGso9A60l6mVcjqG+jRdowRBEASP6xTuy+4T+UiS5PK40Wwl6Xj+eY30imDfzJhT05yG8GPCfVG62KpREARBaDnG9mlLWk4pb/+egrnGjn16o4XXfj5IdrGe6/tFu31uMUGvmTEfO+a0vl4M4QuCILR8N/SLZkdaPiu2n2LN/rP4aGwh+r4F20nLLqFEb+aqnlGM6dHG7XOLYN/MmFLTnHPii8l5giAILZ5MJuN/N/fihx3BrNhxiuPZpUjA3lMFdAj14d6RsUyoJa//uYhg38yYU49xPHqsQ5nYw14QBKH1GD+gHeMHtENvslBSbsJHo8Rbc2HhWgT7Zqb4ZAaZ3apyOctltnWVgiAIQsuUnq9j4cY0ks/Y1tV3bRvAtGGdaRvs7XZa3NqIYN+clJaRZtE6FLUL9q51hyZBEATh4paRr2P6p1sp1ZuonIOfll3KPynZfHnvpQ2WJl1M8W5G5OmnOV4jc158lBjCFwRBaKkWbkyjRG/i6l5RfHHPID6/+xKu7hVFUbmJhRvTGuxzRM++GVGcTneROU8Ee0EQhJZq5/F84tv4899qe9l3iw4kLbuUHWl5DfY5omffjMhPn+a4WHYnCILQauSVGujbMdipvE+HIHJLDA32OSLYNyPW0xmkB0Y5lIk97AVBEFouk8WKj8Z5XpaPRumUWOdCiGDfjGQUGjArqp6shGvlBHirm7BFgiAIQksgntk3E5LFwgmzxqEsTkzOEwRBaPHWHsjkSGaJQ9nJ3DIAnli626m+DHjtlj5ufYYI9s2EJT2dE4FtHcri24U0UWsEQRCExnIyt8we3GvamJLtVCY7j88Qwb6ZMB9zsYe9eF4vCILQoq18aHijfI4I9s2E8VgqJ4LFTHxBEITWpKGS5pyLmKDXTJxMO4NeXZU9z09mITJAW8c7BEEQBKF+RLBvJo7mOD6v6eKvQCY7nyczgiAIguBIBPtm4pjecZ1lfNugJmqJIAiC0NKIYN8MWIuLSdOGOpQlxEXVUlsQBEEQ3COCfTNgOnbMeQOctoFN0xhBEAShxRHBvhnISjlOkVfVzHu1ZKFdiHcTtkgQBEFoScTSuwqSxULpx59QtmQJljNnUbSJxPvmm/GbPQuZ0rM/ppTj2YCv/XUnuR6lQtyHCYIg1GSxSizedJyfd6WTVaQn3F/LtX3acvvQTg6/N7/59zjf7zhFmd7MgM4hPHZtIsG+jllK1x/M5LVfDrJ09lCnYy2NiCgViv7zX4pfeRV1jx4E/u9lNMOGUzL3LQqfeNLjn300t9zhdWyguAcTBEFw5a1Vycxfd5T4NgE8dm1XBsaE8Nlfx3j9l0P2OmsPnOXDtUe4LCGcu0d0Ye+pAl7+8YDDecoMZt5ZncL9o+JafKAH0bMHwJScTNk3i/C6fizBH80HwOe2W5H7+1E6/yN8pk5B3bu3xz7/mNHxryE+2nm7Q0EQhNbuWFYJP+w8zajukbw8sRcAN/SLxkejZNGmE4wf0I6ubQPYmJxNv07BPHx1ImDbQe6Vnw5gMFnQqGwrnz758yiRAV7c0C+6ya6nMYmePaD76WeQJHymT3co951+p+34jz957LMli4U0jWNwT+zWwWOfJwiCcLFauz8TSYKbL3Gc0HzzINvvzDX7zwKgN1nw01Z1ovy9VFglMJhtW8amnCnip6R0nhzbtdXkMxHBHjDt2wdyOepePR3KFW3aII+MxLR3r8c+uyj1BFl+YfbXcquFLl3EsjtBEISaUs4UIZdBYlSAQ3m4v5Ywfw3JGUUAdI8OZOuxPLYdy+VUXhnfbj5Bh1AfW9C3Srz2yyEmXtKemIjWs/+IGMYHLFlZyIODkamd945XREZgyczy2GefPJ3n8DraWIRWpailtiAIQuuVW2IgwFuNSuncTw3z05BTYgBg0qAO7Dyez4PfJAEQ7KvmtUm9AVix/RSFOiN3X96l0drdHIhgD0jl5S4DPYBMo0EqL3d5bN68eXzwwQcOZUuWLGH3buf9h2tToJaQISFVbFoYHxvq1vsvdlarVVxvCyeuuXW40GuOj493eD179mzmzJnjUKY3WVC7CPQAaqUCvUkPgFat4P3b+3E6T0eZwUyncF+0KgU5xXo+WX+MF2/qiVat4NvNJ/gxKR2TxcqobpHMGNmlxa6EEsEekGm0WMvyXR6TDAZkWtcb0syZM8fpH2NSUhJ9+vRx6/Of0e1i+daThKnMPHbLWAJ8W88GOMnJySQmJjZ1MxpNa7teENfcWlzINSclJXH48OFz1lMr5eh0JpfHjGYLGmXVqKhMJqN9qI9DnXd+T2FgTAhD4sL4fe8ZPll/jGfHd8dHq+T57/fjpVZw52Ux53UNzV3LvIVxk6JNJNb8fCSj0emYJTMLRWSkRz//uiv78tVz47lrfPdWFegFQRDcEe6vpUhnxFQx0a66nBIDYf61L6HbfDSHram5PHx1AgCr9pxhZNcIRnaL5JKYUMb1i2bV3jMea3tTE8EeUPXoAVYrxr37HMotZ89izcxE1bNnLe8UBEEQGktClD9WCZLPFDmUZxfrySk2kBjl7/J9epOFub8lc++IWML9tfb3hPpV3RyE+2vJLtZ7rvFNTAR7wPv660Emo2zBAofy0gVf2o6Pu6EpmiUIgiBUM6p7JDIZfLftlEP5d1tPAjC6RxuX71vwdyp+WhU3VVuyF+anIS2n1P46NbuU0BacXEc8swdU3briPXkyukWLyJckNJddhmnvXsoWLcZ74k2o+7r3DF4QBEFoeLGR/ozrF80PO9ORJLgkJoTkM8X8mHSaa3pH0T060Ok9admlLNt6ko+nD0Qhr1pTf2XPNrzy80He/+MwvlolP+9KZ+qQTo14NY1LBPsKgf97CWV0W8q+/ZbyP9agiIjA79FH8Js9q6mbJgiCIFR49JpEIgO8+HlXOhtTsgj103L35THcMayzU11Jknj9l4OM7RtNYlvHtfnX9m5LdrGeH5PSMVskru8bzR3Dnc/RUohgX0GmVOI3ZzZ+c2Y3dVMEQRCEWigVcu4Y3rlegVkmk/HJXZe4PCaXy7jr8i7c1UrW24tn9oIgCILQwolgLwiCIAgtnEySJKmpG9GSJCUlNXUTBEEQLjr9+vVr6ia0aCLYC4IgCEILJ4bxBUEQBKGFE8FeEARBEFo4EewFQRAEoYUTwV4QBEEQWjgR7AVBEAShhRPBXhAEQRBaOBHsBUEQBKGFE7nxm5DFYuGLL75g+fLlnD17lsjISG688UZmzJiBUtny/moOHjzIL7/8wtatW0lPT8dkMhETE8PEiRO55ZZbkMlk5z5JC5CamsoNN9yAyWTi448/ZsSIEU3dJI/Iz89n/vz5rF+/nuzsbAICAkhMTOTJJ5+kS5eWl4+8oKCAzz77jD///JPMzEz8/PxISEjg7rvvZtCgQU3dvAtSVlbGl19+yYEDBzhw4AA5OTlceeWVvP/++y7rr1u3jo8++oijR4/i4+PDiBEjeOyxxwgODm7klguVWl5EuYi89NJLfPvtt1x99dXMmDGD/fv38/7775Oens4rr7zS1M1rcJ9//jmbN29m9OjRTJo0CaPRyO+//87zzz/PoUOHeOmll5q6iR4nSRLPPvssKpUKk8nU1M3xmFOnTjFlyhQUCgXjx48nKiqKoqIiDhw4QH5+flM3r8EZDAZuu+02zpw5w80330xcXBx5eXksX76cadOmMX/+fEaOHNnUzTxvBQUFzJs3j7CwMLp3785ff/1Va91Vq1bx8MMP0717d5566iny8vJYsGAB+/fvZ/ny5Wi12kZsuWAnCU0iJSVFio+Plx566CGH8jfeeEOKi4uT9u7d20Qt85ydO3dKer3eocxisUhTpkyR4uLipCNHjjRRyxrPd999J/Xs2VOaN2+eFBcXJ61fv76pm+QREydOlMaOHSsVFxc3dVMaxZo1a6S4uDjpq6++cig/c+aMFB8fL82cObOJWtYwDAaDlJmZaX8dFxcnzZkzx6me0WiUhgwZIo0cOVLS6XT28r///luKi4uTPv/880Zpr+BMPLNvIqtWrUKSJKZOnepQfvvttwPw22+/NUWzPKpfv35oNBqHMrlczpgxYwA4cuRIUzSr0eTn5zN37lxmzpxJVFRUUzfHY7Zt28bevXt58MEH8fPzw2g0YjQam7pZHlVSUgJAWFiYQ3lISAhKpRIvL6+maFaDUavVREREnLPe9u3bycnJYeLEiQ7XfNlll9GhQwd+/fVXTzZTqIMI9k3kwIEDyOVyunfv7lAeERFBREQE+/fvb6KWNb7s7GyAFv887/XXXycwMJDp06c3dVM86p9//gEgICCAyZMn07NnT3r06MG4cePsx1qaAQMGoFKpePfdd9m4cSNZWVkcOnSIxx57DLVazbRp05q6iY3iwIEDAPTq1cvpWM+ePTl8+HCLv/FrrkSwbyLZ2dkEBQWhVqudjoWHh5OVldUErWp8ubm5LFu2jLZt27boXa+2bt3Kjz/+yLPPPuvy77wlOX78OABz5szBz8+Pt99+m+eff56CggLuvfdeNm/e3MQtbHjt2rVj7ty5lJWVcc899zB8+HDGjx/PgQMHWLJkCT169GjqJjaKyhv38PBwp2Ph4eFYLBZyc3Mbu1kCYoJekykvL6/1l75Go0Gv1zdyixqf0WjkgQceoKSkhHfffbfFBkGj0cjzzz/P1VdfzZAhQ5q6OR5XVlYGQOfOnfnoo4/sqywGDx7MNddcwzvvvMPgwYObsokeERoaSnx8PDfeeCM9e/YkKyuLL774gnvuuYevvvqKzp07N3UTPa68vBzA5f/lykd4lXWExiV69k1Eo9HUOpxlMBicnm23NGazmQcffJBdu3bxwgsvtMhf/pU+/fRTsrKyeOqpp5q6KY2i8hf9uHHjHJZTdujQgb59+7J//350Ol1TNc8j9u3bx7Rp07jqqqt45JFHGDVqFJMnT2bx4sWUlpbyxhtvNHUTG0Xl7y1Xv9sMBgOAmI3fRESwbyKRkZEUFBS4/E+RnZ1dr8kwFyuLxcKjjz7K+vXreeaZZ7j55pubukkek52dzSeffMJNN92EXq/n5MmTnDx5kry8PABycnI4efIkZrO5iVvacCIjIwFbT7em0NBQJEmyT2hrKRYvXozJZGL06NEO5W3atKF79+4kJSU1UcsaV+XffeVwfnXZ2dkoFAqnSYxC4xDBvol069YNq9Vqn9BSKSsri6ysLKeJey2F1Wrl8ccfZ/Xq1TzxxBNOqxFamry8PIxGI19//TVjxoyxf82dOxeA//73v4wZM4bMzMwmbmnD6dmzJ4DLazp79ixKpZLAwMBGbpVnVT6HtlqtTscsFkuLupmrS7du3QDYu3ev07H9+/cTGxvbYh/XNXci2DeRa665BplMxjfffONQ/vXXXwNw3XXXNUWzPMpqtfLUU0/x66+/8sgjj7T4WekA0dHRvPfee05fkydPBmDGjBm89957hISENHFLG84VV1yBt7c3y5cvdwhyKSkp7N27l4EDB7a4x1SVz+N/+uknh/K0tDT279/fYm/eaxo4cCBhYWEsX77cYd7Rhg0bOHHiRIv8vXaxEBP0mkhCQgI333wzy5YtQ5IkhgwZwoEDB1i2bBnjx493uXTlYvfGG2/w448/0qNHDyIjI51+Mfbt25d27do1Ues8w8/Pj6uuusqpvPKZdd++fVtcutygoCAee+wxXnzxRaZMmcK1115LUVER33zzDVqtlieeeKKpm9jgbr/9dn788UfeeOMNjhw5Qq9evcjOzmbx4sVYrVYeeOCBpm7iBVu0aBHFxcX212lpacyfPx+wLT0cMGAAarWaJ598kkcffZTJkydz0003kZeXx5dffkmXLl2YMmVKUzW/1ZNJkiQ1dSNaK7PZbM+Nn5mZSXh4ODfeeCP33nsvKpWqqZvX4KZOncr27dtrPf7qq69y4403NmKLms7KlSt56qmnWnRu/FWrVvHFF19w9OhRVCoVAwYM4OGHHyY+Pr6pm+YRGRkZzJ8/nx07dnD27Fm8vLzo3bs3M2fOpE+fPk3dvAs2cuRIMjIyXB6bPXs2c+bMsb9es2YNH3/8sVNu/JY0gnWxEcFeEARBEFo48cxeEARBEFo4EewFQRAEoYUTwV4QBEEQWjgR7AVBEAShhRPBXhAEQRBaOBHsBUEQBKGFE8FeEARBEFo4EewFwQ3p6enEx8fz5JNPNnVTLlhWVhaPPvoow4YNIyEhgf79+zf4Z7Skn5cgXMxEsBeaTGUgiI+PrzWd6MqVK4mPj2fhwoWN27hW4IknnuC3335j0KBB3H///cyYMaNe77Narfz666/cd999DB06lO7du9OvXz8mTpzI+++/T1ZWlodbXrupU6e22Ax9gnAhRG58oVlYs2YN+/fvp0ePHk3dlFbBaDSybds2hgwZwptvvlnv9+Xn5zNr1ix27dpFYGAgQ4cOJSoqCr1ez8GDB/noo49YsGABa9euFVuZCkIzIoK90OSio6PJyMjg7bff5ssvv2zq5rQKubm5WK1WtwKyyWTi/vvvZ/fu3dx0000888wzeHt7O9RJS0vj5ZdfxmAwNHSTBUG4AGIYX2hy8fHxjBkzhs2bN7Nly5Z6v2fq1Kn1PlY5vGswGHjzzTe57LLL6NWrF7fccgv79u0Dqp5hDxo0iN69ezNr1ixycnJqbUNycjLTp0+nb9++9O/fnwceeID09HSXdQ8dOsQDDzzA4MGD6d69O6NGjeKtt96irKzMod62bduIj49n3rx57Nixg9tvv52+ffsycuTIev1cli9fzoQJE+jduzd9+/Zl8uTJrFu3zulnUbn5zg8//GB/lDJv3rw6z/3jjz+ye/duBg0axMsvv+wU6MG21evnn39OREREnedy9+8vKyuLF154gdGjR9OzZ08uueQSxo8fz+uvv+7wvsqNliqvydV1/fHHH0ydOpV+/frRs2dPxo0bx7Jly5zaMW/ePOLj49m2bRvLly9n7Nix9OjRwz7/wGAw8NlnnzF27Fj69OlD3759ufLKK3nqqaea9FGGILgievZCs/DQQw+xbt063nrrLVasWOHRz0lLS2P06NEUFhayatUqpk+fztKlS5kxYwaRkZGMGzeOlJQU1q1bR3FxMd98843TeU6fPs2UKVPo3bs3kydP5ujRo/zxxx/s2rWL77//3iHYrV27locffhiVSsWoUaMIDQ3l0KFDfPrpp2zbto1FixahVqsdzr9r1y4++eQThgwZwq233up0U+DKSy+9xKJFi2jbti2TJk3CZDKxevVqZs2axZNPPsmdd94JwPjx40lISODrr78mISGBUaNGAba9yOvy/fffA3Dfffchk8lqrSeXy5HLG64fodPpuPXWW8nOzubyyy/nyiuvRKfTcfz4cRYvXmzfMnf27Nn88MMPZGRkMHv2bPv7q1/X66+/zoIFC2jbti3XXHMNWq2WzZs38+yzz5KamsrTTz/t9PmfffYZSUlJjBw5kuHDh9tHQ/7v//6PP/74g759+zJp0iRkMhnp6emsWbOGCRMmnPOGRxAalSQITeT06dNSXFycNHPmTEmSJOmZZ56R4uLipNWrV9vrfP/991JcXJz05ZdfOrw3Li5OmjJlisvzujo2ZcoUKS4uTpo8ebJUXl5uL//iiy+kuLg4qX///tLrr7/u8J57771XiouLkw4cOODU5ri4OGnevHkO9RcsWCDFxcVJ//d//2cvy8vLk/r06SONHDlSyszMdKj/2WefSXFxcdLnn39uL9u6dav9/D///LPL63Nl27ZtUlxcnDR27FiptLTUXp6dnS0NHTpU6tq1q3Tq1Cmn63jiiSfqdX6TySR169ZN6tq1q2QwGOrdrto+x52/v3Xr1klxcXHSV1995VQ3Pz/f4XXl37MrGzdutP970+v19nKj0SjNnDlTiouLk/bu3Wsvf//996W4uDipb9++0rFjxxzOVVxcLMXHx0uzZs1y+hy9Xi+VlZW5bIMgNBUxjC80G3PmzEGj0fDuu+9isVg88hkPPfQQWq3W/vqaa64BwGw2O+zHDXD11VcDkJKS4nSewMBA7rrrLoeyKVOmEBERwerVqzEajQD89NNPlJWV8X//939OPb3p06cTHBzMb7/95nT+7t27M3bs2Hpf1w8//ADAgw8+iI+Pj708LCyMu+66C7PZzM8//1zv89VUWFiIyWQiKCjIaRSisVT/e6sUFBRU7/cvXrwYmUzGSy+9hEajsZerVCoeeughAH7//Xen9918883ExMQ4lMlkMiRJcjhPJY1G4/IRhyA0JTGMLzQbERERTJ48mQULFvDDDz9w0003NfhnJCQkOLwODQ0FoGPHjnh5eTkcqxyuzc7OdjpPYmKiU32VSkXPnj1Zu3Ytx48fJz4+nr179wKQlJTE0aNHnc6jVCo5fvy4U3n37t3duKqqG5JLLrnE6VhlmaublovBwIEDCQsL48UXX2TTpk0MGzaMfv360alTJ7fOs2/fPnx9fVmyZInTMbPZDNgmGNbkaoWIr68vw4YN49dffyUzM5NRo0bRr18/unXrhkKhcKtdgtAYRLAXmpV7772X5cuX88EHH3D99dc3+Pl9fX0dXiuVSpflgP2XdmUgqC44ONjl+UNCQgAoLS0FoKioCICvv/7arXZWnqe+SktL0Wg0Lq+j8oamsk3nIzAwEJVKRWFhIUajsVF7935+fnz77be89957/P3336xevRqwTQZ85JFHGD16dL3OU1RUhNls5oMPPqi1jk6ncyqr7e/6vffe46OPPuLXX3/ltddeA2wjDdOmTWPGjBkNOm9BEC6UCPZCsxIYGMj06dN57733WLx4MQEBAS7ryWQyl0P9FxLQ3JGfn++yPC8vD6i6eaj8c82aNXTo0KHe569rApwrvr6+nDp1itLSUqeAX7NN50OpVNK9e3d2795NUlISl1566XmfC9z/+2vXrh1z587FbDZz6NAhNm7cyDfffMODDz7IsmXL6pWfwdfXF41Gw8aNG91uqys+Pj489thjPPbYYxw/fpwtW7awaNEi3nnnHbRaLdOmTXPrcwTBk8Stp9DsTJs2jdDQUD755JNaf/n7+/u7XN506NAhTzcPsC27Ky8vdygzmUzs27cPjUZjH2KuDEJ79uzxaHsqH0/s2LHD6VjlcrSajzDcNWHCBAA+/fRTJEmqtZ4kSS5HQ6o7378/pVJJz549mT17Nk8//TQWi4UNGzbYj1f2pl3dSPTo0YOsrCzOnj1b52ecj06dOnHbbbexYMECAP78888G/wxBuBAi2AvNjre3NzNnzqSgoMDlsjeAbt26kZ6ezs6dO+1lOp2Od955p1HaWFhYyBdffOFQtmjRIrKysrjqqqvsw9wTJkzA29ubuXPncuLECafzFBcXN8gNyrhx4wDb2vDqNyF5eXl8/vnnKJVKtyb81fYZffr0YfPmzTz33HNONzsAJ0+e5O677yYzM7POc7nz93fkyBGXAbpyxKL6JLnKkSBXNxKVa/efeeYZSkpKnI6fPn261jwJNeXn57N//36n8tzcXMD1ZEJBaEpiGF9oliZNmsSXX37JqVOnXB6//fbb2bx5M/fccw9jx45FoVCwceNGunbt2ijt69evH19++SV79uyha9euHD16lPXr1xMWFsajjz5qrxcSEsLcuXN5+OGHue666xg+fDgdOnSgvLyc06dPs2PHDsaNG8eLL754Qe255JJLuPXWW/n222+57rrrGD16NCaTid9//528vDz+7//+j/bt21/QZ6hUKubPn8+sWbNYtmwZa9ascUiXm5ycTFJSEhqN5pzBzp2/v82bN/P666/Tv39/OnXqREBAAKmpqfz9998EBwdzww03OPwc/vjjDx5++GGGDRuGWq22Jz267LLLuPfee/nkk08YPXo0Q4cOJTIykvz8fNLS0tizZw9vvfUW0dHR5/xZZGVlcdNNNxEfH0/Xrl0JCwsjNzeXtWvXolAouP32293/AQuCB4lgLzRLKpWKBx54gMcff9zl8REjRvDmm2/yySefsHLlSkJCQhg/fjyzZs1yeyb7+Wjfvj3//e9/efPNN1m0aBEymYwrr7zS5RK7K664gpUrV/L555+zZcsWNm7ciI+PD1FRUdx+++2MHz++Qdr03HPP0bVrV5YuXcq3336LXC4nMTGR559/njFjxjTIZwQHB7N48WJ+++03fv31V7Zu3UphYSFqtZqOHTty7733cuutt9onBdbGnb+/YcOG2UcBVq9ejcFgICIigltvvZW7776b8PBwe92bb76Z06dP8/vvvzN//nwsFguzZ8+27+j3yCOP0K9fPxYvXsw///xDWVkZQUFBdOjQgccff7zecxHatm3LnDlz2LJlC//++y+FhYWEhoZy6aWXcvfdd9OrVy83f7KC4Fkyqa6Hb4IgCIIgXPTEM3tBEARBaOFEsBcEQRCEFk4Ee0EQBEFo4USwFwRBEIQWTgR7QRAEQWjhRLAXBEEQhBZOBHtBEARBaOFEsBcEQRCEFk4Ee0EQBEFo4USwFwRBEIQW7v8BH3nMkQcx7QYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create Plot\n",
    "fig, ax1 = plt.subplots() \n",
    "  \n",
    "ax1.set_xlabel('Number of Clusters') \n",
    "ax1.set_ylabel('Transport Cost', color = pal[0]) \n",
    "ax1.plot(np.arange(max_clusters+1), pars, color = pal[0],\n",
    "         **{k:v for (k,v) in line_parms.items() if k != 'color'})  \n",
    "ax1.tick_params(axis ='y', labelcolor = pal[0]) \n",
    "# Adding Twin Axes\n",
    "ax2 = ax1.twinx() \n",
    "ax2.set_ylabel('Percent Explained', color = pal[1]) \n",
    "ax2.plot(np.arange(max_clusters+1), percent_explained, color = pal[1],\n",
    "         **{k:v for (k,v) in line_parms.items() if k != 'color'}) \n",
    "ax2.tick_params(axis ='y', labelcolor = pal[1]) \n",
    "ax2.yaxis.set_major_formatter(mtick.PercentFormatter())\n",
    "ax2.set_ylim(None, 100)\n",
    "\n",
    "\n",
    "if split_on_income:\n",
    "    dropped_feature = 'income'\n",
    "else:\n",
    "    dropped_feature = 'sex'\n",
    "\n",
    "print(f'Results with splitting on {dropped_feature}:')\n",
    "if save_figures: plt.savefig(\n",
    "    figure_dir / f'adult-income-split-on-{dropped_feature}--clustering-results.{save_parms[\"format\"]}',\n",
    "    **save_parms\n",
    "    )\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting 1 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[39.861 10.099  0.291]\n",
      "\t\tT(female)_mean=[36.632 10.086  0.101]\n",
      "\n",
      "Starting 2 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[31.248  9.406  0.041]\n",
      "\t\tT(female)_mean=[27.837  9.398  0.006]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[49.972 10.913  0.585]\n",
      "\t\tT(female)_mean=[46.957 10.893  0.213]\n",
      "\n",
      "Starting 3 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[29.655  9.727  0.021]\n",
      "\t\tT(female)_mean=[26.204  9.651  0.002]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.965 12.208  0.898]\n",
      "\t\tT(female)_mean=[40.673 12.028  0.345]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[55.246  8.342  0.108]\n",
      "\t\tT(female)_mean=[52.533  8.65   0.008]\n",
      "\n",
      "Starting 4 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.574 12.926  0.   ]\n",
      "\t\tT(female)_mean=[32.098 12.516  0.008]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[29.683  8.913  0.025]\n",
      "\t\tT(female)_mean=[26.279  8.96   0.002]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[56.335  8.415  0.129]\n",
      "\t\tT(female)_mean=[53.661  8.723  0.009]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.474 12.107  0.996]\n",
      "\t\tT(female)_mean=[40.15  11.905  0.383]\n",
      "\n",
      "Starting 5 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[28.705  8.979  0.013]\n",
      "\t\tT(female)_mean=[25.279  8.995  0.003]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[36.317 12.942  0.   ]\n",
      "\t\tT(female)_mean=[32.842 12.6    0.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[54.739  8.304  0.048]\n",
      "\t\tT(female)_mean=[52.     8.63   0.004]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[44.    12.253  0.98 ]\n",
      "\t\tT(female)_mean=[40.788 12.212  1.   ]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[44.101 11.652  1.   ]\n",
      "\t\tT(female)_mean=[40.809 11.376  0.   ]\n",
      "\n",
      "Starting 6 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[44.    12.253  0.98 ]\n",
      "\t\tT(female)_mean=[40.788 12.212  1.   ]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[28.593  9.036  0.014]\n",
      "\t\tT(female)_mean=[25.161  9.1    0.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[54.114  9.53   0.022]\n",
      "\t\tT(female)_mean=[51.384  9.524  0.005]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[53.414  4.328  0.086]\n",
      "\t\tT(female)_mean=[50.534  5.5    0.017]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[44.283 11.622  1.   ]\n",
      "\t\tT(female)_mean=[41.006 11.35   0.   ]\n",
      "\tCluster: 5\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.068 12.974  0.   ]\n",
      "\t\tT(female)_mean=[31.564 12.547  0.   ]\n",
      "\n",
      "Starting 7 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[50.833  4.352  0.074]\n",
      "\t\tT(female)_mean=[48.074  5.167  0.019]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.745 12.286  0.98 ]\n",
      "\t\tT(female)_mean=[40.531 12.245  1.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[25.551  9.055  0.015]\n",
      "\t\tT(female)_mean=[22.147  9.059  0.   ]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[63.108  9.595  0.189]\n",
      "\t\tT(female)_mean=[60.667  9.676  0.018]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[41.911  9.356  0.   ]\n",
      "\t\tT(female)_mean=[38.649  9.382  0.   ]\n",
      "\tCluster: 5\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.481 13.093  0.   ]\n",
      "\t\tT(female)_mean=[31.935 12.759  0.   ]\n",
      "\tCluster: 6\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[42.392 11.633  1.   ]\n",
      "\t\tT(female)_mean=[39.006 11.44   0.   ]\n",
      "\n",
      "Starting 8 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[50.904  4.288  0.038]\n",
      "\t\tT(female)_mean=[48.096  5.096  0.019]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[41.631  9.343  0.   ]\n",
      "\t\tT(female)_mean=[38.343  9.369  0.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.211 13.145  0.987]\n",
      "\t\tT(female)_mean=[39.934 13.105  1.   ]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[40.505 13.176  1.   ]\n",
      "\t\tT(female)_mean=[36.945 12.967  0.   ]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[63.255  9.489  0.043]\n",
      "\t\tT(female)_mean=[60.713  9.691  0.011]\n",
      "\tCluster: 5\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[47.448  9.621  1.   ]\n",
      "\t\tT(female)_mean=[44.517  9.448  0.19 ]\n",
      "\tCluster: 6\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[25.308  9.053  0.011]\n",
      "\t\tT(female)_mean=[21.92   9.065  0.   ]\n",
      "\tCluster: 7\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.409 13.082  0.   ]\n",
      "\t\tT(female)_mean=[31.873 12.718  0.009]\n",
      "\n",
      "Starting 9 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[40.966 13.258  1.   ]\n",
      "\t\tT(female)_mean=[37.438 13.034  0.   ]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[41.758  9.316  0.   ]\n",
      "\t\tT(female)_mean=[38.479  9.358  0.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[62.474  9.874  0.074]\n",
      "\t\tT(female)_mean=[60.053  9.747  0.021]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.68  12.34   0.979]\n",
      "\t\tT(female)_mean=[40.464 12.278  1.   ]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.651 13.113  0.   ]\n",
      "\t\tT(female)_mean=[32.123 12.792  0.   ]\n",
      "\tCluster: 5\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[55.96  4.2   0.06]\n",
      "\t\tT(female)_mean=[53.06  5.66  0.  ]\n",
      "\tCluster: 6\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[24.688  6.229  0.   ]\n",
      "\t\tT(female)_mean=[22.042  6.146  0.021]\n",
      "\tCluster: 7\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[45.99   9.615  1.   ]\n",
      "\t\tT(female)_mean=[42.969  9.479  0.01 ]\n",
      "\tCluster: 8\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[25.904  9.572  0.004]\n",
      "\t\tT(female)_mean=[22.349  9.55   0.   ]\n",
      "\n",
      "Starting 10 cluster results:\n",
      "\tCluster: 0\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[25.926  9.581  0.   ]\n",
      "\t\tT(female)_mean=[22.371  9.559  0.   ]\n",
      "\tCluster: 1\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[43.662 13.485  0.985]\n",
      "\t\tT(female)_mean=[40.382 13.471  1.   ]\n",
      "\tCluster: 2\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[41.594  9.321  0.   ]\n",
      "\t\tT(female)_mean=[38.31   9.364  0.   ]\n",
      "\tCluster: 3\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[39.623 13.377  1.   ]\n",
      "\t\tT(female)_mean=[36.013 13.195  0.   ]\n",
      "\tCluster: 4\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[56.143 10.443  1.   ]\n",
      "\t\tT(female)_mean=[53.629 10.014  0.114]\n",
      "\tCluster: 5\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[58.535  4.302  0.07 ]\n",
      "\t\tT(female)_mean=[55.674  5.884  0.   ]\n",
      "\tCluster: 6\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[35.745 13.123  0.   ]\n",
      "\t\tT(female)_mean=[32.226 12.783  0.009]\n",
      "\tCluster: 7\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[26.655  5.891  0.   ]\n",
      "\t\tT(female)_mean=[23.945  5.909  0.018]\n",
      "\tCluster: 8\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[61.516  9.681  0.   ]\n",
      "\t\tT(female)_mean=[59.121  9.637  0.011]\n",
      "\tCluster: 9\n",
      "\t\t         Names=['age', 'edu', 'inc']\n",
      "\t\t    male _mean=[38.189  9.5    1.   ]\n",
      "\t\tT(female)_mean=[34.662  9.5    0.297]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for record_idx in range(max_clusters):\n",
    "    cluster_record = cluster_histories[record_idx]\n",
    "    Z_clusters = cluster_record['Z_clusters']\n",
    "    labels = cluster_record['labels']\n",
    "    n_clusters = cluster_record['n_clusters']\n",
    "    print(f'Starting {n_clusters} cluster results:')\n",
    "\n",
    "\n",
    "    if split_on_income:\n",
    "        tgt = 'under50k'\n",
    "        src = 'over 50k'\n",
    "    else:\n",
    "        tgt = 'female'\n",
    "        src = ' male '\n",
    "    with np.printoptions(precision=3, suppress=True):\n",
    "        for cluster_idx in range(n_clusters):\n",
    "            print(f'\\tCluster: {cluster_idx}')\n",
    "            print(f'\\t\\t         Names={[name[:3] for name in feature_names]}')\n",
    "            print(f'\\t\\t   {src}_mean={X[cluster_idx==labels].mean(axis=0)}')\n",
    "            print(f'\\t\\tT({tgt})_mean={Z_clusters[cluster_idx==labels].mean(axis=0)}')\n",
    "        print()    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ergonomic blank space : ) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.11 ('py37')",
   "language": "python",
   "name": "python3"
  },
  "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.7.11"
  },
  "vscode": {
   "interpreter": {
    "hash": "5ab0220f0ca30ec7bac8a7e209564eceae6d15412b9f87f3c2f91206aa8b151c"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
