{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "import sys\n",
    "from collections import Counter\n",
    "sys.path.append('..')\n",
    "from unlabeled_extrapolation.datasets import domainnet\n",
    "import pandas as pd\n",
    "from scipy.stats import pearsonr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [],
   "source": [
    "domains = ['real', 'sketch', 'painting', 'clipart']\n",
    "single_base_dir = 'connectivity_checkpoints/single-domain/domainnet'\n",
    "between_base_dir = 'connectivity_checkpoints/between-domains/domainnet'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "These are the results, pulled from our spreadsheet, for [pre-train on all of DomainNet-S] ==> [fine-tune on S]\n",
    "'''\n",
    "\n",
    "all_domains = {}\n",
    "\n",
    "all_domains[('real', 'sketch')] = 40.93\n",
    "all_domains[('real', 'painting')] = 57.27\n",
    "all_domains[('real', 'clipart')] = 52.41\n",
    "\n",
    "all_domains[('sketch', 'real')] = 59.80\n",
    "all_domains[('sketch', 'painting')] = 48.50\n",
    "all_domains[('sketch', 'clipart')] = 52.29\n",
    "\n",
    "all_domains[('painting', 'real')] = 70.73\n",
    "all_domains[('painting', 'sketch')] = 44.56\n",
    "all_domains[('painting', 'clipart')] = 41.83\n",
    "\n",
    "all_domains[('clipart', 'real')] = 59.37\n",
    "all_domains[('clipart', 'sketch')] = 42.43\n",
    "all_domains[('clipart', 'painting')] = 38.88"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "These are the results, pulled from our spreadsheet, for [pre-train on S + T] ==> [fine-tune on S]\n",
    "'''\n",
    "\n",
    "s_t = {}\n",
    "\n",
    "s_t[('real', 'sketch')] = 38.39\n",
    "s_t[('real', 'painting')] = 58.96\n",
    "s_t[('real', 'clipart')] = 51.55\n",
    "\n",
    "s_t[('sketch', 'real')] = 55.41\n",
    "s_t[('sketch', 'painting')] = 30.42\n",
    "s_t[('sketch', 'clipart')] = 38.74\n",
    "\n",
    "s_t[('painting', 'real')] = 69.78\n",
    "s_t[('painting', 'sketch')] = 34.76\n",
    "s_t[('painting', 'clipart')] = 30.82\n",
    "\n",
    "s_t[('clipart', 'real')] = 56.55\n",
    "s_t[('clipart', 'sketch')] = 28.93\n",
    "s_t[('clipart', 'painting')] = 23.17"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# cells"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{('real', 'real'): 74.98, ('real', 'sketch'): 25.67, ('real', 'painting'): 37.09, ('real', 'clipart'): 44.8, ('sketch', 'real'): 25.72, ('sketch', 'sketch'): 63.23, ('sketch', 'painting'): 18.59, ('sketch', 'clipart'): 31.87, ('painting', 'real'): 29.13, ('painting', 'sketch'): 14.25, ('painting', 'painting'): 45.89, ('painting', 'clipart'): 20.48, ('clipart', 'real'): 19.34, ('clipart', 'sketch'): 12.71, ('clipart', 'painting'): 10.79, ('clipart', 'clipart'): 59.34}\n"
     ]
    }
   ],
   "source": [
    "# source on columns, target is rows\n",
    "erm_results = np.asarray([[74.98, 25.72, 29.13, 19.34],\n",
    "[25.67, 63.23, 14.25, 12.71],\n",
    "[37.09, 18.59, 45.89, 10.79],\n",
    "[44.80, 31.87, 20.48, 59.34],])\n",
    "\n",
    "erm = {}\n",
    "for i, d1 in enumerate(domains):\n",
    "    for j, d2 in enumerate(domains):\n",
    "         erm[(d1, d2)] = erm_results[j,i]\n",
    "print(erm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** real **********\n",
      "********** sketch **********\n",
      "********** painting **********\n",
      "********** clipart **********\n",
      "********** real sketch **********\n",
      "********** real painting **********\n",
      "********** real clipart **********\n",
      "********** sketch painting **********\n",
      "********** sketch clipart **********\n",
      "********** painting clipart **********\n",
      "********** real sketch **********\n",
      "********** real painting **********\n",
      "********** real clipart **********\n",
      "********** sketch painting **********\n",
      "********** sketch clipart **********\n",
      "********** painting clipart **********\n"
     ]
    }
   ],
   "source": [
    "####################  cell\n",
    "domains = ['real', 'sketch', 'painting', 'clipart']\n",
    "cs = {}\n",
    "from unlabeled_extrapolation.datasets import domainnet\n",
    "for domain in domains:\n",
    "    for split in ['train']:\n",
    "        domainnet_ds = domainnet.DomainNet(domain, split=split, version='sentry', verbose=False)\n",
    "        ys = [item[1] for item in domainnet_ds.data]\n",
    "        cs[domain] = Counter(ys)\n",
    "\n",
    "s_df = []\n",
    "for domain in domains:\n",
    "    print('*' * 10, domain, '*' * 10)\n",
    "    direct = os.path.join(single_base_dir, f'{domain}-sentry-swav-simclr')\n",
    "    counter = 0\n",
    "    data = []\n",
    "    for file_name in os.listdir(direct):\n",
    "        if file_name.endswith('-final'):\n",
    "            cls_1 = file_name.split('-')[1]\n",
    "            cls_2 = file_name.split('-')[2]\n",
    "            counter += 1\n",
    "            data_dict = torch.load(os.path.join(direct, file_name))\n",
    "            if len(data_dict['test_accs']) < 80:\n",
    "                print(file_name, len(data_dict['test_accs']))\n",
    "                continue\n",
    "            s_df.append({'cls1': cls_1, 'cls2': cls_2, 'domains':(domain, domain), 'acc': data_dict['test_accs'][-1]})\n",
    "s_df = pd.DataFrame(s_df)\n",
    "        \n",
    "sd_df = []\n",
    "for i in range(len(domains)):\n",
    "    for j in range(i + 1, len(domains)):\n",
    "        print('*' * 10, domains[i], domains[j], '*' * 10)\n",
    "        direct = os.path.join(between_base_dir, f'{domains[i]}-{domains[j]}-sentry-swav-simclr')\n",
    "\n",
    "        for file_name in os.listdir(direct):\n",
    "            if file_name.startswith('same-class') and file_name.endswith('-final'):\n",
    "                cls = file_name.split('-')[2]\n",
    "                data_dict = torch.load(os.path.join(direct, file_name))\n",
    "                if len(data_dict['test_accs']) < 80:\n",
    "                    print(file_name, len(data_dict['test_accs']))\n",
    "                    continue\n",
    "                sd_df.append({'cls1': cls, 'cls2': cls, 'domains':tuple(sorted((domains[i], domains[j]))),\n",
    "                             'acc': data_dict['test_accs'][-1]})\n",
    "sd_df = pd.DataFrame(sd_df)\n",
    "                              \n",
    "dd_df = []\n",
    "for i in range(len(domains)):\n",
    "    for j in range(i + 1, len(domains)):\n",
    "        print('*'*10, domains[i], domains[j], '*'*10)\n",
    "        direct = os.path.join(between_base_dir, f'{domains[i]}-{domains[j]}-sentry-swav-simclr')\n",
    "        for file_name in os.listdir(direct):\n",
    "            if file_name.startswith('different-class') and file_name.endswith('-final'):\n",
    "                cls_1 = file_name.split('-')[2]\n",
    "                cls_2 = file_name.split('-')[3]\n",
    "                data_dict = torch.load(os.path.join(direct, file_name))\n",
    "                if len(data_dict['test_accs']) < 80:\n",
    "                    print(file_name, len(data_dict['test_accs']))\n",
    "                    continue\n",
    "                dd_df.append({'cls1': cls_1, 'cls2': cls_2, 'domains':tuple(sorted((domains[i], domains[j]))),\n",
    "                             'acc': data_dict['test_accs'][-1]})\n",
    "dd_df = pd.DataFrame(dd_df)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pearson r: 0.5616236927151071\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAloAAAEuCAYAAABWALygAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAC1ZklEQVR4nOzdd1zT1/oH8M9JIIO9V5gyAiqJgMU6qQu1rRPrbd3V1tZqHbQqvdZq7dSfolDrqF5tq7XVqlXrvepVrN6qtc4CDlAUEWUjKxACSc7vjxAKyAgrAT3v1ysvku843yepJQ/nnO9zCKUUDMMwDMMwTNvjGDoAhmEYhmGYpxVLtBiGYRiGYdoJS7QYhmEYhmHaCUu0GIZhGIZh2glLtBiGYRiGYdoJS7QYhmEYhmHaCUu0GIZhGIZh2glLtBiGYRiGYdqJkT4vRgh5HsBwAM8DcAEgBJAHIBnAGQAHKaUF+oyJYRiGYRimvRB9VIYnhEwD8D6AbgBKAMQDyAUgB2ADwAuAHwAFgL0APqaUprZ7YAzDMAzDMO2o3Xu0CCEJAOwBfA9gKoC/aD3ZHSHEEsDLACYBuEkImU4p3dPe8TEMwzAMw7SXdu/RIoTMB7CFUlrejHOkAJwopcfbLzKGYRjGUK5evTrMyMhoOaXUCWy+MNM5qQkhWUql8uPg4OAG8xW9DB0yDMMwjNbVq1eH8fn8DZ6enhVCobCcw+GwLyKm01Gr1UQulwvu37/PUygUcxtKtvT6VwQhZDshxKuBfR6EkO36jIdhGIbRPyMjo+Wenp4VpqamcpZkMZ0Vh8Ohpqamck9PzwojI6PlDR6nz6AATIdmvlZ97ABM018oDMMwjCFQSp2EQqHO00kYpiMTCoXlVUPg9TLEuHhDf704QXMXIsMwDPN047CeLOZpUfVvucF8Sh93HY4FMLbGpo8JIXl1DhMC6A/gSnvHwzAMwzAMoy/66NFyhyaJ6g9Nb1aPGq+1j0AA5wHM0kM8DMMwDNOpxMbG2hJCQpKTk3nt0ZZIJAqMiIjwbG3bLbFz506rFStWOBri2vrQ7j1alNIYADEAQAhJBTCGUhrf3tdlGIZhGEY3e/fuTbGyslIb4toHDx60Onv2rMWKFSuyDXH99qbXJXgopfXeccgwDMMwTxO5XE6EQmGnmYfWt29fvc+R7myfUUvpfTI8IURECIkmhFwmhKQSQrpXbV9ACOml73gYhmGYp0P64zJjQ1w3MjLShRAScunSJUG/fv18TUxMgl5++eUuJSUlnNmzZ4tEIlGgsbFxsEgkClyyZImTSqWqPresrIzMnDnTzdfXt5uJiUmQnZ2ddNCgQT7Xrl0TtDSe4uJizjvvvCNyc3PrzuPxgu3s7KTDhg3zTk9Pb7Bzpe7QoXZ48ejRo2ZDhgzxNjExCbKysuoxZcoUd5lMRmqeu3DhQpeuXbsGmJmZBVlbW0uff/55v7i4ONOaxxw5csScEBLy3XffWb366qse1tbWUgcHB2lERITngQMHbHNycowJISGEkBCRSBTY0vfeEel7UeluAH4HoALwB4AgANoxYg8AoQAm6jMmhmEYpvM7nZxjNn3HJfF3M0KTw/zsZYaIYdy4cT6TJk3KW7x4cZZarcYLL7zge/fuXWFkZGSGVCqVnz9/3nT9+vUujx8/Ntq6detDAJDL5RyZTMZZtGhRhkgkqszPzzfavHmzfVhYmP/169evu7u7K5sTQ3l5OQkLC/NLSkoSzp07N6tPnz6lhYWF3OPHj1vk5eUZubm5Nau9GTNmeI0cObLgnXfeuXvhwgXTdevWOZeVlXH2799/X3tMRkaG8Zw5c7Ld3d0rZTIZ54cffrAdPny4+Ny5c7dCQ0Nr9ZQtWrTIfeDAgUVbt25NlcvlnODgYHl+fr5RQkKC6c8//5wCAAKBwCBDmO1Fr4kWgLUAbgEYBqAcQEWNfecBrNJzPAzDMEwnV6lSI2p/oicARO1P8Pzf4oHXjbn6r140a9asnGXLluUAwNdff21z9epVs//85z/JI0aMkAHA6NGjSwAgOjraZcWKFVkikUhpa2ur2rNnT5q2DaVSibFjxxY7OTlJd+zYYbN8+fKc5sSwefNmm7/++st0165dKZMmTSrSbn/99dcLWvKeBg4cWPTNN988BIBx48YVE0LomjVrRAkJCZkSiUQBAHXjHz9+fJGvr2/3TZs22YWGhqbXbE8qlZbWPB4AbG1tlcbGxnTw4MGlLYmxo9P3v8R+AL6klMrwZD2tbGhqaTEMwzCMzr7+LcWhoKzCGAAKSiuMN/6W4mCIOF599dVC7fPjx49buri4VAwZMkRWWVkJ7ePFF18sViqV5PTp09VDa9u2bbOWSCT+5ubmPYyNjUMsLCyCysrKOMnJyQ0OH6pUKtRsVzscefLkSUs7O7vKmklWK99TrQRt6tSpBWq1GmfPnq2O/+DBg+a9evXys7Ky6mFsbBzC4/FC0tLS+CkpKU/EP3r06MK2iKsz0Xei1Vh3oB1YwVKGYRimGTIK5UabT98VKZRqDgCUK9WcTafvijKL5PoesYG7u3ul9nleXp5RRkYGj8fjhdR8vPDCCwHa/QCwe/duyzfffLOLr69v+bZt21JPnTp168yZM7esra2VCoWiwe/oCRMmeNZsd8KECZ4A8PjxY66jo2NlQ+c1l4uLS622XF1dKwHg0aNHPAA4e/asySuvvOJramqq/uqrr+7HxcUlnTlz5pZYLJbXF79IJGqz2DoLff9DvAjgdQC/1rNvAoBz+g2HYRiG6cz2Xk63UVFaa3K2ilKy91K6zfwhfs0admutmtXubWxsVCKRqGL37t136zvW19e3AgB++uknG3d3d0XNOU8KhYIUFxc3+v38+eefZ8yfP7/6/Tk6OioBzTDcnTt3hK18K9UyMjKMoZnqAwB4+PChMQCIRKIKANizZ4+1kZERPXr06F0+n1/9/ouLi7kWFhaquu0RQp76uwzr0nei9QmAk4SQ/wLYDc3w4RBCyHxoqscP0HM8DMMwTCf2j+fcHm8+fVdUib+TLS4hdMJzbo8NGVd4eHjRsWPHrMzNzdVBQUENrusol8s5XC63VvKxadMmm5p3JtZHLBZXiMXiirrbhwwZUnzkyBGb3bt3W06cOLHVw4c//fST9ahRo0q0r7///ntrDoeD/v37lwJAWVkZh8Ph1EoyDx8+bJ6ZmclzdXV9Ir768Pl82ljvXWen1zdGKT0DYAwALwDbARAAX0JTHX4MpfRPfcbDMAzDdG7OlkLl2y94P+IbcdQAIDDiqGe/4P3I2VLYrLvr2tpbb731OCgoqHTYsGF+K1ascDx06JD53r17LT7//HP7vn37+paUlHAATUKWmpoqmDlzptuhQ4fMly5d6vTFF1+IzM3NG8+0GvD2228/7tGjR+kbb7zRZcmSJU4HDx40//77760mTpzo3pKSEb/99pvlW2+95frLL79YLFmyxCk6Otpl7Nix+YGBgQoAePHFF4vKyso448eP9zp06JD5qlWr7N944w0vBwcHnYcIAwIC5EVFRdxVq1bZnzlzxuTixYtt1iPXEeh9DJtS+m8A/yaE+ABwAJBPKU3WdxwMwzDM02HOQJ+cPZfSHTKLyvnWprzKdwb66HXIsD58Pp+eOXPm9ocffuj83Xff2X3++ed8oVCodnNzU4SHhxdpSxhERkbmpaen83766Se73bt323Xv3r3swIEDdyZMmODT0uuePn369uLFi1127txpHx0d7WJlZaUMCQmROTg4NDv53L59e+qaNWscJ02a5G1sbExfffXVvE2bNlXfSRgREVH86aefpm/cuNHx+PHj1j4+PvJvvvkm9fPPP3fR9Rrz58/Pu3jxoulnn30mKikp4bq4uFQ8evQosbmxdlSE0mduuJRhGIYxoPj4+PtSqTSvLdvsCHW0niaxsbG28+fP90xMTLzevXt3haHj6eji4+PtpFKpZ3379F2wdGoju9UAigBco5Q+1FNIDMMwzFPgBbGD7PfFAxPcbEyeubvamI5N30OH3+Lv+lk17xKpuU1NCNkD4HVKqU4T6RiGYRiGJVlMR6TvWf59AaQB2AAgDIB/1c+NAB4AeAlAFDR3IK7Qc2wMwzAMwwCYN29ePqX0Chs2bD1992i9D+AnSuk/a2y7DeB3QkgJgFmU0rGEEEsAkwD8s75GGIZhGIZhOgN992iFA4hrYN8pAIOrnv8PgEgvETEMwzAMw7QTffdoKQCEoP5kKwR/LzLNAWDwxSXt7Oyop6enocNgGIbpVK5cuZJHKbU3dBwM0xHoO9H6GcDHhBAVgH0AcqCppfUKNHOytlcd1wOAwWtreXp64vLly4YOg2EYplMhhKQZOgaG6Sj0nWhFAjAHsLrqUdNuAO9VPb8O4A89xsUwDMMwDNPm9JpoUUrlACYTQlYC6AXAGUAmgIs1q8NXVY9nGIZhGIbp1PSWaBFCeAAuAIiilP4XmrsNGYZhGIZhnlp6u+uwqvioFwCDLvTJMAzDMPp05MgRc0JIyMGDB81b21ZsbKzt+vXrbVtybkREhKejo6OktTE0RiQSBUZERHhqX8fGxtoSQkKSk5N57Xnd+uTl5XEjIyNdzp49a6Lva9ek7/IOJ6Ap8cAwDMMwTDPt2rXLbufOnXaGjkNX48ePLzp58mSSu7u73qv25+fnc9etW+d88eJFgyZa+p4M/xWAXYQQIwAHoZmfVWtVa0rpPT3HxDAM06TkkJ5Qlz5ZdYZjagrxFXZ3MsPUx8XFReni4qL3kSy5XE6aPko/9N2jdQaAGzR3H56BZp7WnToPhmGYDqe+JKux7YwBFNw3NtSlExIS+EOHDvW2sbGR8vn8YGdn58ARI0Z0qaysvyPn5s2bPA8Pj+7BwcH+ubm5XAD4448/hIMGDfKxsLDoIRAIgoODg/2PHTtmpj0nNDRUfOnSJbOrV6+aEUJCCCEhoaGhYu3+pKQk3pgxY7zs7OykPB4v2NXVNfD11193q3vtc+fOCUNCQsRCoTDIw8Oj++rVq3Wuefbvf//brE+fPr7m5uY9hEJhkFgs7rpu3boGe9jqGzoUiUSBo0eP9lq7dq2du7t7dz6fH9y1a9eAX3/9tdbQ6pkzZ0yGDx/exdHRUSIQCII9PT27z507VySTyWolUaGhoeKQkBDx7t27LQMCArryeLzg1atX2/v7+wcCwHvvveeh/bxiY2NbNOzaGvru0Xpdz9fr8CoqKvDgwQOUlZUZOhS94XK5sLOzg4ODAwjpMH90MAzTmd05aYYfxosxeX8yfAbL9H35kSNH+lpYWKiio6PT7O3tlenp6byjR49aqlSqJ37JnTt3Tjh69Gg/iURSevjw4btmZmb07NmzJkOHDhV37dq1LCYmJs3ExES9ZcsW+1GjRvnFxcUl9e/fv2zTpk1pU6ZM8VKpVGTjxo1pAGBlZaUCNElW7969A4RCoToqKuqRWCxW3L9/n3fixAmLmtcuLS3lTpkypcvs2bOzfXx8Mrdv3267ZMkS94CAgPKRI0eWNPYed+3aZTV9+nTvoKAg2dq1a9McHByUiYmJwrS0tGbPv7pw4YJ5YmKiybJlyx4JBAK6du1ap/Hjx/tevHjxhlQqVQBAamoqTyKRyKdNm5ZvYWGhSkxMFK5Zs8bl/v37/CNHjtQa/UpNTRUsWrTIfdGiRRk+Pj4Vtra2Si8vr7vTpk3znjNnTtbYsWMLASAgIEDvazfqu7zDd/q8XkdGKcWJ/x7HpYvn4GRvBTMT4TOTdChVKmTm5IPHN0PEK6/BxcXF0CExDNOZqSqBX9/1BChw+F1PzI+/Dq7+OrcyMzONHjx4wN+1a1fKpEmTirTb33777cd1jz106JD5pEmTfF588cXHu3fvTjMy0nwNL1q0yNXZ2bni3LlztwUCAQWAiIiIIj8/v24ff/yx88mTJ++GhISUm5mZqVUqFQYPHlyrK/WDDz5wUSgUnGvXrt309PSs7kZ7991382seV1payomJiXmgTaqGDx9e4uzsbLl7926bxhIttVqNJUuWuPn7+5dduHAhmcvlAgDGjBnTaHLWkMePHxudO3fulo+PTyUAvPzyy8Wenp6S5cuXuxw8eDAVAKZPn14IoFB7/fDwcJmFhYVq7ty5XllZWVwnJyeVtr3CwkKjI0eO3OzTp49cu83GxkYFAF26dFHU/bz0Sd89WkyVU3Encf9OAt55fRxMTQ06T88gKKW4lZSCnd9tw9vvzIelpaWhQ2IYprP6fa0Dyh5rMquyfGP8Hu2AF5bk6Ovyjo6OSldXV8VHH33kmpWVZRweHl4SGBj4RM/J3r17bfbt22c7a9as7A0bNjzSbpfJZOTSpUvmc+fOzeRyubTmcGP//v2LDx482ORw1++//245aNCgoppJVn0EAoG6ZkIlFAqpp6dn+cOHD6t7peoOdxobGyM+Pl6QkZHBmz9/fpY2yWoNqVRaqk2yAMDa2lo9cODAoqtXr5pqtz1+/JizdOlS5yNHjlhnZWXxlEpldW/EjRs3BE5OTtXJk4uLS0XNJKsj0fccLRBCHAgh8wkhGwkh2+s8/qXveAxBrVbj0sXzGPPywGcyyQIAQgi6BvjCv4szEhISDB0OwzCdVdFDI5xdJ4KyXPN9pizn4Gy0CEWP9NaRwOFwcPz48dsSiaT0008/FUkkku6urq6Bq1atqjX36ejRo1Z8Pl89a9asvJrbc3NzjVQqFWJiYpx5PF5Izcf333/vUFxczFWpVGhMYWEh18XFpaLRgwBYWFg80RCPx6MKhYIDAMnJyby6MSQnJ/O088jc3NyavIYu7O3tn0gIHRwcKnNycqoTvtdee81r165d9rNmzco5ePDg7TNnztz64osvHgCAXC7n1D23LeJqD3rt0SKEiKFZWscIgCmAPAA2ALgACgAUNXz20yM7OxumQmNYWVo0ffBTzruLGy5fT0b//v0NHQrDNIpjatrgXYeMAV3bZQOqrj3vgqoJru20wQtReuvV6tq1a8Uvv/xyX61W48KFC8KYmBiHqKgody8vL4WJiQkFgPXr16etX7/eaciQIeITJ04ka+ci2draqjgcDqZMmZIzY8aM/Prab6oXydraWpmZmdnq8VIPD4/KM2fO3Kq7rby8nADAw4cP22RMNjc394l2cnJyjB0cHCoAoKysjMTFxVlFRkZmLFu2rPq/47Vr14T1tUcIofVt7wj0PXT4fwAuARgDoBTACAAJAKYC+BjAWD3HYxDl5eUwEQoMHUaHYCIUorz82bkRgOm8WAmHDipoymOcXScC8HeyRTgUQVOemB+lDxwOB3369JH7+/un79271y4xMVHYq1evMgCwtLRUnTp16vaQIUN8hwwZIj5+/Pjt4ODgcgsLC3VISIjsxo0bJn379k1vLKni8XjqgoKCJ767+/fvX3z8+HHrtLQ0Yw8Pjxb37ggEAjpgwIAnfikHBgYqXFxcKr777jv79957L4/Dad2AWHx8vGlKSoqxdviwoKCA89tvv1kOHDiwCND0WKlUKhgbG9dKoHbt2qVzDTHtXLe6vV/6pu9E6zkAbwPQjl1zKKVKANsJIfYA1gMYqOeYDOLZmPbetGflBgCGYdqJpUiJfgsfVQ8fGgnU6Bf5CJYivdVu+vPPP4Xz5s1zi4iIKPDz8ytXqVTk22+/teVyuTQ8PLykqKioOnOytrZWnzp16s6QIUN8w8PDxcePH08OCQkpj46OTg8PDxf379/fd/r06XkikagyNzfX6MqVK6YqlQobN258BABisbh8586d9lu3brUWi8UKS0tLlVQqVXzxxRcZv/32m2WfPn38IyMjM/38/BTp6enGx48ftzx06FBqa98jh8PBqlWr0qdNm+bdu3dvvzfeeCPX0dFReePGDUFOTo7xunXrMprTnq2trTI8PNzvgw8+yNDedSiXyzkrV67MqNqvkkqlpZs2bXJ0dnautLe3V+7YscM2Oztb5x41V1fXSisrK+X+/fttevToUWZubq728/NT1JxErw/6zvLMADymlKqhGSasmZlegiYRY/Rk8792w6/HYFg4S/D8wHE4+0fjf7F/8uVX4Nv413q4+/d74rjMrBzMfGcJRL69YeEsgfT5l/C/cxfb620wDPOs6/9eDkxsNb04JraV6B+ptyFDQPOFLhKJKjZu3Oj42muv+cyYMaNLVlYWb8+ePSn9+/d/onfI0tJSHRcXd8fHx0ceHh4uvnTpkqBfv35lZ8+evWVjY6OKiopyHzt2rN+SJUvcb9y4IQwLC6suV7F8+fLM3r17Fy9YsMAzLCws4M033/QEALFYXHH27Nmk4OBg2aeffioaP3687xdffOFS31yolpo8eXLhL7/8chsA5s+f7/nqq6/6fPvtt/aenp7NLpnQq1evkrlz52avXLlSNHPmzC4KhYKzb9++OxKJpLqtPXv23OvevXvZkiVL3GfPnu3p4OCgXL16dbqu1+ByuYiNjU0rKirijh492i8sLCxg7969Vs2NtbUIpfob1iSEJAJYSSn9mRByAcANSunMqn3RACZQSl31FlATevbsSS9fbvvhgtTUVPx2/BdM/sdLOh2vVCqhvQW4rfx84D+Y/vZixP7fR+jzfAi2bN+N73f/gr/+OAJ31/rLLXzy5VfY+8t/cOLw99XbuFwu7O1sql8XFhWj1wvj0Pf5EMx+YxLs7GyQej8dzk4OCBB7P9Hmo4xsHP/fX3h79rw2fX8MwxgOIeQKpbRnQ/vj4+PvS6XSvIb2t4iB62gxuhOJRIE9e/aUtUVPW0cRHx9vJ5VKPevbZ4i1DodWPY8G8DohJJkQcgPAfADb9RxPh/PwURb4Nv7Yu//fGDZ6GiycJdj106E2v07Mxm8x9bWxmDltAgLE3li/ahmcHO3xzfYfGz3PiGsEJ0f76kfNJAsA1sZug7OjPbZvWoXnQiTw8nDFoLDe9SZZDMMwbcZ3iAzz/0pgSRbT0eh7jtYHAPgAQCndSwiRA/gHABMAMQC26jmeDifhRhIAYE3sNnz84QJs9PGCleWTC76vit6MVeu+abStw3u/Qb/eT/5RWVFRgavxN7Bw7oxa24cM7IsLF6812mZqWjo8u/YHj8dDaIgUK5ctRBfPv1d4OPzvOIQP7odJMxbizNk/4ezkgNenjMfsNyax+VgMw7Qv68ZrSDGMIei7MrwCf0+EB6X0VwC/6jOGji4hMQkCAR+7d6yHTxePBo978/VXETFmRKNtiZwd692el18AlUoFB4faNfAc7W1x6kzDvfnPhUixbcMXEPt1QU5uPr5cuwkvDH8N187/ClsbawCaRGzL9h8xb/Y0LFrwJuITb2Fh1GcAgHfenNxovAzDMMzT79GjR4mGjkGf9F1H6x6AsZTS+Hr2dQdwmFLaRZ8xdTQJ15MwfMiARpMsALCxtoKNtZV+gqoyfOiAWq979ZTCP3godv54EAvmaJaxVKspQnp0w6cfvQcA6CHpipR7adi8bTdLtBiGYZhnjr7naHmiauiwHgIAjWcXz4D467fQv2/TN1+uit4MG7fgRh8N3UVoZ2sNLpeLnJzadfGyc/Ph5KBziRKYmZmiq78PUu6lVW9zdrRHgNin1nH+ft5If5Spc7sMwzAM87QwxFqHDd3m2BNVi0c+q0pLy3AvNR1B0m5NHtuaoUMej4dgaTecPH0OEWOGV2+PO30OY0eG6xxvebkCyXdSEdavV/W23r2CcDul9o0kd1LuN3gnI8MwDMM8zdo90SKELASwsOolBfArIaTuWklCaJbi+am94+nIEm8kAwCk3f2bPLa1Q4fz35mO12cvwXPBEvTuFYytO35CZlYu3nz91epjNm7dhU3bfkDin0cBAEuWrcJLwwfCzdUFubn5+HzNRpSWlmHya2Oqz5k3ezrChr+GL9duxvixIxCfcAtff7MTK5ctrBsCwzAMwzz19NGjdQ9AXNXzaQAuA8itc4wCwE0A2/QQT4eVcCMZPt4eMDNr/7XTXhn3IvILCvHl2k3IzM5FtwBfHNqzBR5uoupj8vMLcPvO371TjzKyMfXN95CXXwh7O2uEhkjx+3/31DqnZ3Agft61AR99sg6fr9kIN1dnLP/nPLw9c2K7vyeGYRiG6Wj0XbB0BzQFSztFkbKOUrD0acYKljLM08cgBUsZxoAaK1iq7/IOr+vzegzDMAzDMIZk0BWtn1WEEKj12JPYkanVanA4Da9UzzAM8yyJjY21JYSEJCcn81py7vr1623r297SNvVBJBIFRkREeGpfGzLevLw8bmRkpMvZs2dN2qpNQ9x1+MyzsLBAQWEJKKXPfLX0gsIiWFhYGToMhmGYDmH8+PFF3bp1S3J3d292lftdu3bZqVQqLFiwoFbtnta0aQiGjDc/P5+7bt06Z1dX14p+/fo9sSB4SzQr0SKEOAFwh6bmVS2U0v+1RUDPAhsbG5iYWeLe/XR4e7kbOhyDoZQi4WYKQp4fYuhQGIZhOgQXFxeli4uLsqO32Z4MFa9cLm+Xng+dhg4JISJCyCkAjwD8AeC3Go/TVT+ZZggf/jIOHz2LvxJuQi4vN3Q4ekUpRWZWDn759QQo1wxdu3Y1dEgMwzwFHpY8NDbEdSMjI10IISEXL14U9urVy08oFAbZ29tLFixY4KJSqQAAZWVlZObMmW6+vr7dTExMguzs7KSDBg3yuXbtWq2Oi/qGzUQiUeDo0aO9vvnmG+suXbp0EwqFQd27dw84fvy4mfaY0NBQ8aVLl8yuXr1qRggJIYSEhIaGilvTptbKlSsdRCJRIJ/PDw4MDAw4ceKEad3hvsb8+9//NuvTp4+vubl5D6FQGCQWi7uuW7euwerYjcW7du1aO3d39+58Pj+4a9euAb/++mutxYDPnDljMnz48C6Ojo4SgUAQ7Onp2X3u3LkimUxWK4kKDQ0Vh4SEiHfv3m0ZEBDQlcfjBa9evdre398/EADee+89D+3nGBsb+8RwbHPo2qO1CUAggMUAElFjvUKmZXx9ffGPSa/jj/Nncfz0XlC1+pkZRlSp1LC2tkHXwB4YOyAMxsYG+d3IMMxT5Oyjs2azT84Wbx6yObmvqK/MEDFERER4T5w4MW/JkiVZR48etYiJiXHmcDiIjo7OkMvlHJlMxlm0aFGGSCSqzM/PN9q8ebN9WFiY//Xr16+7u7s32oNz6dIls7t37wqWLVuWIRAI1CtXrhSNHz/eJzU1NdHOzk61adOmtClTpnipVCqycePGNACwsrJStaZNAIiOjrZbvny524QJE/ImTJhQcOfOHf706dO7FBcX6zS5dteuXVbTp0/3DgoKkq1duzbNwcFBmZiYKExLS2v2/KsLFy6YJyYmmixbtuyRQCCga9eudRo/frzvxYsXb0ilUgUApKam8iQSiXzatGn5FhYWqsTEROGaNWtc7t+/zz9y5Mi9mu2lpqYKFi1a5L5o0aIMHx+fCltbW6WXl9fdadOmec+ZMydr7NixhQAQEBDQqpxH10SrP4B5lNKdrbkYABBCggAsAzAAgBWAUErpVULI5wD+Ryk91tprdBaenp7w9PQEpRRKpRL6LLVhSFwuF1wumwDPMEzbqFRXYsX5FZ4AsPz8cs+jEUevG3P0/wfclClT8j7//PMsABg3blxxSUkJd8uWLY7//Oc/s+3s7FR79uypXq9MqVRi7NixxU5OTtIdO3bYLF++PKextmUyGTc+Pv6mvb29CgBEIlFlWFhYwL59+yzffvvtxyEhIeVmZmZqlUqFwYMHl+oSb1NtqlQqrF692mXAgAFFNWN3dnaunD59undT7avVaixZssTN39+/7MKFC8na3/tjxowp0SW+uh4/fmx07ty5Wz4+PpUA8PLLLxd7enpKli9f7nLw4MFUAJg+fXohqlaZUavVCA8Pl1lYWKjmzp3rlZWVxXVycqpOPgsLC42OHDlys0+fPnLtNhsbGxUAdOnSRaHr59gUXe86lANo9B+BLggh/aAZevQHsLvO9dUA3m7tNTojQgiMjY3B4/GeiQdLshiGaUtbE7Y6FCoKjQGgUFFovC1xm4Mh4pg8efLjmq9fe+21x2VlZZwrV64IAWDbtm3WEonE39zcvIexsXGIhYVFUFlZGSc5OfmJec91BQUFybQJEQA899xzcgB48OBBi+/Ma6rNe/fu8bKzs43HjRtXUPO8SZMmFXK53Fo9A5WVlbUeABAfHy/IyMjgTZ06Na8tfu9LpdJSbZIFANbW1uqBAwcWXb16tbrK9+PHjzmzZ88Wubm5defz+cE8Hi9kzpw5XpRS3Lhxo9bn7OLiUlEzyWovuiZaWwFMaYPrfQngOIBuACLr7LsKIFiXRgghwwghpwghWYQQBSHkISFkLyGka53j3Agh+wghRYSQYkLIAULIszv7nGEY5imTWZpptP36dpFCpeAAgEKl4Pwr8V+irNIsvd9V7+rqWmv4z8XFpRIAHjx4YLx7927LN998s4uvr2/5tm3bUk+dOnXrzJkzt6ytrZUKhaLJ7+K6w4BCoZACQHl5eYvLNDXVZnp6ujEAODo61npfRkZGsLa2rt6WnJzM4/F4ITUfycnJvNzcXC4AuLm51V12r0Xs7e2fuAvRwcGhMicnpzrZfO2117x27dplP2vWrJyDBw/ePnPmzK0vvvjiAQDI5XJO3XPbIq6m6PoP8RGAKYSQOABHATyuewCldLsO7QQDGEcppYSQuuNkeQDsdYzHBsAVABuhWc7HHUAUgAuEkEBKaRohxATAKWjmk02DZp3FTwH8RgiRUErbpEuQYRiGMZxf7vxio6bqWhNc1VRNfkn5xWa2dHarR2Ka4+HDh0Zdu3atTioyMjKMAcDd3b3y66+/tnd3d1fs37//vna/QqEgxcXFHbbMkpubWyUAZGdn14pRqVSioKCgepuHh0flmTNnbtU8xsPDo7K8vJwAwMOHbXOTQm5u7hPt5OTkGDs4OFQAmhsO4uLirCIjIzOWLVtW/d/+2rVrwvraqycPaRe6ZsKbAXgCGAhgNTRrEtZ8bNWxnXIADRUBcwZQpEsjlNIfKaWLKKX7KKVnquaOjQNgDmB81WFvAugCYAyl9CCl9BCAUQA8ALylY7wMwzBMBzbOd9xjDuHU+sLkEA4d6zP2iQ6B9rZr1y6bmq9//PFHGxMTE3XPnj3lcrmcU3e4bdOmTTbauxLbAo/HU7emh6uuLl26VDg6OlYeOHDAuub2Xbt2WalUqurkViAQ0AEDBpTVfAgEAhoYGKhwcXGp+O677+zVanWr44mPjzdNSUmpTrYKCgo4v/32m2VwcHApoOmxUqlUMDY2rvU579q1q8E7HOsSCARU21arA66iaybt1UbXOwtgASHkUI1t2g9kJjQ9UC2lLdCm7c4cBeACpTSl+kKUphJCzgEYDSC6FddiGIZhOgAnUyfljO4zHmmHD/lcvnpm4MxHTqZOeq/DtHPnTju1Wo1evXqVHT161GLPnj12kZGRGba2tqrw8PCixYsXW82cOdNt1KhRhRcvXjTdtm2bg7m5eZtlWmKxuHznzp32W7dutRaLxQpLS0uV9m68luByuVi8eHHGe++95/GPf/zDY8KECQUpKSn8mJgYJzMzMxWH03guwuFwsGrVqvRp06Z59+7d2++NN97IdXR0VN64cUOQk5NjvG7duozmxGNra6sMDw/3++CDDzK0dx3K5XLOypUrM6r2q6RSaemmTZscnZ2dK+3t7ZU7duywzc7O1rlHzdXVtdLKykq5f/9+mx49epSZm5ur/fz8FDUn0TeXTokWpTSt6aN0sgzAOQDxAPZBk2RNI4REAwgB8FxzGiOEcAFwoeml+hJAFoAfq3Z3A3ContNuAHilJcEzDMMwHc+bkjdzDtw54JBdls234ltVvhH4hl6HDLUOHDiQMnfuXPf169e7mJmZqebNm5e5evXqTACIjIzMS09P5/300092u3fvtuvevXvZgQMH7kyYMMGnra6/fPnyzJSUFP6CBQs8y8rKOM8995zs4sWLya1pMzIyMk8mk3E2b97sePDgQVtfX1/59u3bUydMmOBjYWHRZPIxefLkQgsLi9ufffaZ8/z58z0BwM3NTfHOO+9kNzeWXr16lYSFhZWsXLlSlJ2dzfP29i7ft2/fHYlEUp1M7tmz596bb77psWTJEnc+n69++eWXC6ZPn57+2muv6fQ5c7lcxMbGpq1YsUI0evRoP5VKRWJiYu7Pmzcvv+mz60f0XVKAEBIM4P+gKe/AheZuw98BRFJKrzWzrcvQJGgAkAJgFKX0VtW+CgDRlNKoOud8CiCKUlpvkkkImQVgFgC4u7uHpKW1VY7JMAzzbCCEXKGU9mxof3x8/H2pVJrXltc0ZB2tyMhIl3Xr1jlXVFRceRbqAv7vf/8zCQsLC9iwYUPqnDlz9DJEKxKJAnv27Ck7dOhQqj6u11zx8fF2UqnUs759DfZoEULuARhLKY0nhKTi7yG++lBKaZM1NaoOvApgMCFEAM2k9kJKaUvXE5oCwAKauVjvAzhBCOlHKb3fwvZAKf0GwDcA0LNnz2ejsBXDMEwn10/UT3Z03NEEV3PXTrGeX2eRlJTEi46OdhgwYIDM0tJSdePGDcG6deucRSJRxdSpUwsNHV9n0NjQ4RkAxTWet2nSQSktB9Cs8dl62tDe5fAnIeQogPvQ3H34NoACANb1nGZTtY9hGIZ5irAkq+2ZmJiob926Jdy3b59tcXEx18LCQtW3b9/i6OjoR+bm5q2f4f4MMMTQYQA0dwa64cnFqSmldFor2r4MTQ/ZkKq1GXmU0n51jjkNzfsOa6q9nj170suXL7c0HIZhmGeSIYYOGcaQWjR02B4IIVMBbIemdywHQN0iZi3O+gghjtBUnP+hatNhAGsIIV0opfeqjvEE0BeaXi+GYRiGYZh21axEixAiBSDGkz1RoJR+r0MTy6C5E3AmpbSwOdeuE8cv0FSST4BmeNMPwEJoSjusrTpsK4C5AA4RQj6EJon7BEA6gC0tvTbDMAzDMIyudEq0CCFWAP4N4HntpqqfNXugdEm0nAC83Zokq8oFABMAvAeAB03ydBrAF9qJ8JTSUkLIIADrAOysijkOwAJKqUFWdmcYhmEY5tmia4/W5wBsoSnJ8DuAsdBUcZ8BoDeAV3Vs5xyAAGgSnhajlK4CsEqH4x4AiGjNtRiGYRiGYVpK1xLzw6BJti5UvX5IKT1NKZ0K4CSA+Tq2MxfALELIa4QQW0IIp+6jeeEzDMMwDMN0XLr2aDkDuEcpVRFCyqFZU1DrAICfdGznIYBrAHY1sJ82IyaGYRiGYZgOTdekJguAVdXzNGiGC09XvW7O8gFbAfwDwEEASXjyrkOGYRiGYZinhq5DdWfx90T4nQCWE0K2EEK+hmY5neM6tjMawCJKaQSldCml9OO6j+aFzzAMwzBPv9jYWFtCSEhycjJP39cmhIRERka6NPe88+fPCyMjI12ys7O5bdVmZ6Rrj9bHALQfyP9BMzH+HwBMoKlX9a6O7ZQCuNmcABmGYRiGMZyTJ08meXp6NnsE6vLlyybr1q1znjFjRr6jo2OtBahb2mZnpFOiRSm9C+Bu1fNKaMoqvNeC6+0AMBHAiRacyzAMwzCdglwuJ0Kh8KlYL3fw4MGlnaHNjkrfd/mlAXiBEHKCEPIeIWRG3Yee42EYhmGYVomMjHQhhIRcunRJ0K9fP18TE5Ogl19+uUtJSQln9uzZIpFIFGhsbBwsEokClyxZ4qRS/d25U1ZWRmbOnOnm6+vbzcTEJMjOzk46aNAgn2vXrj1RGFwXycnJPEJIyJdffmn/xhtvuNrY2EiFQmHQwIEDfeoOO37zzTfWzz//vJ+1tbXUxMQkKCAgoOtXX31lW7fNusN82vebmJjIf+GFF3xMTEyCXFxcAt9//31n7XuLjY21nT9/vicABAYGdieEhNQc+mxJm1pnz541CQkJEQsEgmAnJydJVFSU08KFC10IISEt+czam64FSz9qZLcamppaVyml55poalPVTw8Ag+vZT6FZoodhGIZhOpVx48b5TJo0KW/x4sVZarUaL7zwgu/du3eFkZGRGVKpVH7+/HnT9evXuzx+/Nho69atDwFALpdzZDIZZ9GiRRkikagyPz/faPPmzfZhYWH+169fv+7u7q5sSSzr16937tq1a9nGjRvvZ2dnG3366aeiYcOG+SUnJ9/g8/kUAO7du8cfM2ZMgZ+fXxaHw6GnT582X7hwoYdcLucsXrw4V5f3O3HixLwFCxZkHzp0yGrt2rUubm5uFfPnz88fP3580d27dzNjY2Odt2/ffs/d3b0CANzd3Rtd+LuxNgEgMzPT6MUXX/RzcHCo3LBhQyqfz6exsbGOjx490vvcNV3pOkdrBTRJEKlnn3Y7JYT8AeAlSmlRA+14NTtChmEYhmlAUlBwEJXLnxidIUKh2v/a1Wv6jGXWrFk5y5YtywGAr7/+2ubq1atm//nPf5JHjBghA4DRo0eXAEB0dLTLihUrskQikdLW1la1Z8+eNG0bSqUSY8eOLXZycpLu2LHDZvny5TkticXU1FR14sSJFC5XMw89ICCgfNiwYf4bN260XbhwYR4AfPnll1na41UqFV566aWSrKws43/961/2uiRac+fOzdImQGPGjCk5d+6c+d69e23mz5+f7+LiovT29lYAwHPPPVfWvXt3hS5xN9YmAHz22WeO5eXlnOPHj9/29vauBICxY8cWeXh4SJr1AemRrkOHAQBSoJmX5QHNWoceABZVbe8DzeT4AGgKm9aLUprW1KM1b4ZhGIZ5ttSXZDW2vT29+uqrhdrnx48ft3RxcakYMmSIrLKyEtrHiy++WKxUKsnp06dNtcdu27bNWiKR+Jubm/cwNjYOsbCwCCorK+MkJyc3OHyoUqlQs926w2sjR44s0CZZABAeHl7q6OhYeeHCherrJiYm8keOHOnl4OAg4fF4ITweL2TPnj129+/f12nYcvz48bU6VcRisTwjI6NVPUtNtXn58mVTqVRaqk2yAMDMzIwOGjSooQ4eg9O1R+trAP+ilK6rsS0dwFpCCBfAZ5TSwYSQLtDcgTinjeNkGIZhmA6t5rBYXl6eUUZGBo/H49U7bygvL88IAHbv3m355ptvdhk3blz+0qVLMx0cHCq5XC7GjBnjq1AoGkwWJ0yY4HngwIHq+VTjxo3L379//33ta0dHxyeG6Ozs7CozMzN5AFBUVMQZPny4n0AgUC9fvvyhn5+fgs/n0w0bNtj//PPPdrq8XwcHh1rDmjwej1ZUVLQqwW2qzZycHGOxWCyv57xGhyQNSddEqzeALxrYdxXA8qrnlwE4NNYQISQcwGwAYmh6xmqhlHbRMSaGYRiG6TA4HE71XYY2NjYqkUhUsXv37rv1Hevr61sBAD/99JONu7u7omaSpFAoSHFxcaPfz59//nnG/Pnzq4cVHR0dayUo2dnZxnXPycvLM+7WrVsZAJw6dcosIyODd+zYseRhw4bJtMesX7++vilCHYaDg0NlXl7eE+8tJyfniW0dha6JVhE0k9frWwx6SNV+QJM4FTfUCCHkRQC/QrM+oj+AY9DU4uoLzR2Jv+sYD8MwDMN0WOHh4UXHjh2zMjc3VwcFBZU3dJxcLudwudxaZSA2bdpkU3cosC6xWFwhFosbrEP166+/Wq9duzZDO3z43//+1zQ7O9v4+eefLwWA0tJSDgAYGxtXXzs3N5d74sQJKx3enk60k+7LysrabBi3Z8+epVu2bHG8e/eusXb4UCaTkVOnTlm21TXamq6J1nYAHxBCzAHsA5ADTc/VKwDext+9Xb0AXG+knWXQDEMuBFAJ4ENK6VVCiB801eWPNvsdMAzDMEwH89Zbbz3euXOn3bBhw/zeeeed7KCgoDKFQkFSUlL4//73v62OHTt219zcXB0eHl60ePFiq5kzZ7qNGjWq8OLFi6bbtm1zMDc3bzzTakJpaSl36NChPrNmzcrNyckx+uSTT0QeHh6Kd955Jx8ABg0aJDMzM1PNmzfP/cMPP8yQyWSc1atXO1tbWytlMtkTldxbQiKRyAFg/fr19jNmzMjn8Xg0NDRULhAIWlxfbOnSpdnff/+9/bBhw/yioqIyBAIBjYmJceTxeGpCOmZnnK6Jlra8w3wA71Q9J9BUev+ixv5/A9jTSDv+VceqUWMBaUrpbULICmgSsb06xsQwDMM844hQqG7orkNDxKPF5/PpmTNnbn/44YfO3333nd3nn3/OFwqFajc3N0V4eHiRQCBQA0BkZGReeno676effrLbvXu3Xffu3csOHDhwZ8KECc1ZR/gJCxYsyExJSeHPnj3bs7y8nNOrV6+SzZs3P9D2Mrm4uCh/+OGHu0uWLHGbPn26t729fcVbb72V8/jxY6N169Y5t8Vn0Lt3b3lkZGTGzp077ffs2WOvVquRlJSU2FhPXFOcnZ2V//nPf27Pnz/fbc6cOV6WlpbKadOm5ebl5Rnt37//iRpgHQGhVPfEkhBiBSAQgDOATACJlNLCZpyfD2A8pfQ3QkgWgLmU0n1V+4YCOEQpNdE9/PbVs2dPevnyZUOHwTAM06kQQq5QSns2tD8+Pv6+VCrN02dMz4rk5GSev79/4Nq1a9MiIyOfic9YqVSiW7duXW1sbJR//PHHbUPEEB8fbyeVSj3r26drjxYAoCqpas08qmQA2kAuA1hACDkHQAlN6Yj7rWibYRiGYZin3Pz58118fHwUXl5eFXl5edzt27fb3759W7hnz547ho6tPs1KtNrAD9DU2gI0dyqeBPCw6rUKmnUQGYZhGIZh6kUIwerVq51zc3N5hBDq5+cn37lz590JEyY0eDOeIek10aKUfl3j+RVCSCCAEQCEAE5SSm/qMx6GYRiGeZqIxeIKSukVQ8fRntavX5+xfv36DEPHoSt992jVQil9CGCrIWNgGIZhGIZpL3pdooAQ4kcICa3xWkgI+YIQ8ishZK4+Y2EYhmEYhmlvOiVapO2KU2wAML7G68+gmQTvAmAdIYQt3cMwDMMwzFND1x6tNELIMkKISyuvJwVwDgAIIRwAUwEsoZSGAPgUwKxWts8wDMMwDNNh6JponQIQBeA+IeRA1XqFLWEJIL/qeRAAa2gqzQPAaQBsnUOGYRiGYZ4aOiValNLp0AzvvQ/AD8AxQshdQsgSQoh9M66XDUBb7TYcwF1KaXrVazNo6mkxDMMwDMM8FXSeDE8pLaKUxlJKuwMIA3AewAoA6YSQnwghL+jQzGEAXxBC1kAzN+vnGvsCAdzTNR6GYRiGYZiOrqV3HZ4D8AuAvwDwAIwEEEcIuUgICWjkvCgARwAMgybp+qzGvlEA/tvCeBiGYRimQzpy5Ig5ISTk4MGD5q1tKzY21nb9+vUtWtMvIiLC09HRUdLaGNpKZGSkCyEkpCXnrly50uG7776zass220uzEi1CiBshZCWAB9As/lwIYDQAcwDDoSk8+l1D51NKSymlb1JKAymlMyilZTX29aGUftCC98AwDMMwz4Rdu3bZ7dy5087QcbSFOXPm5J48eTKpJedu2bLF8cCBA9Zt2WZ70algKSFkJIC3oOmJKgKwA8AmSmnNob4ThJBIAP9u8ygZhmEYhnmqeHt7V3p7e1d29DZbS9cerUMA7AG8AUBEKV1UJ8nSugvNeoYMwzAM88xISEjgDx061NvGxkbK5/ODnZ2dA0eMGNGlsrL+7/ybN2/yPDw8ugcHB/vn5uZyAeCPP/4QDho0yMfCwqKHQCAIDg4O9j927JiZ9pzQ0FDxpUuXzK5evWpGCAkhhISEhoaKtfuTkpJ4Y8aM8bKzs5PyeLxgV1fXwNdff92t7rXPnTsnDAkJEQuFwiAPD4/uq1ev1ummNu3Q44kTJ0y7d+8ewOfzg0UiUeBnn33mUPO4jIwMo4kTJ3p4enp2FwqFQU5OTpKRI0d6paamGtc8rr5hPkJIyLx581w+/fRTB5FIFGhqahr03HPPiS9fvizQHiMSiQIzMjJ4hw8fttF+DhEREZ6taRMAlEol5s2b52Jvby8RCoVBzz//vN+1a9cEhJCQyMjIFpe30nUJnp6U0qtNHVSVfL3e0mAYhmEYpjMaOXKkr4WFhSo6OjrN3t5emZ6ezjt69KilSqV6ouD3uXPnhKNHj/aTSCSlhw8fvmtmZkbPnj1rMnToUHHXrl3LYmJi0kxMTNRbtmyxHzVqlF9cXFxS//79yzZt2pQ2ZcoUL5VKRTZu3JgGAFZWVipAk2T17t07QCgUqqOioh6JxWLF/fv3eSdOnLCoee3S0lLulClTusyePTvbx8cnc/v27bZLlixxDwgIKB85cmRJU++z6nzvefPmZfr5+Sl+/PFHmw8//NDN3NxcNW/evHwAyM3N5fL5fPWKFSseOjo6KtPT041jY2Od+vXr53/nzp3rJiYmtLFr7N+/39bLy6t89erVDyoqKjgffvih67hx43zu3r173djYGHv37k0ZM2aMr7+/v3zFihUZAODk5NRo1YKm2gQ0SdqGDRuc33rrrazw8PCSS5cumYwdO9ansXZ1oWuilU4I8aOU3q67gxDiB+AxpTSvtcEwDMMwTHNsmXc6SFmhfmJ0xojHUb8V+8I1fcSQmZlp9ODBA/6uXbtSJk2aVKTd/vbbbz+ue+yhQ4fMJ02a5PPiiy8+3r17d5qRkeZreNGiRa7Ozs4V586duy0QCCgAREREFPn5+XX7+OOPnU+ePHk3JCSk3MzMTK1SqTB48ODSmu1+8MEHLgqFgnPt2rWbnp6e1d1o7777bn7N40pLSzkxMTEPtEnV8OHDS5ydnS13795to2OixYmOjr4/a9asAgAYP358cZ8+fYy//PJLl7lz5+ZzOBxIpVLFjh07tKWboFQqMWjQIJmvr69k3759llOnTi1s7BpGRkY0Li4uhc/nVydkM2bM6HL69GnToUOHlvbt21fO4/GojY2Nsu7n0NI2c3Nzudu2bXOcOHFi7qZNmx4BwNixY4t5PB79+OOPXXW5RkN0HTrcCE05hvosrNrPMAzDMHpVX5LV2Pb24OjoqHR1dVV89NFHrmvXrrVLTEzk13fc3r17bV555RXf6dOn5+zdu7c6yZLJZOTSpUvmo0aNKuByubSyshKVlZWglKJ///7Fly5davJuxd9//91y0KBBRTWTrPoIBAJ1zYRKKBRST0/P8ocPH/K027TX1z5q4nK5mDZtWmHNba+88kpBZmYmr+bQ4KpVq+zFYnFXExOTIGNj4xBfX18JACQlJdUarqtP//79i2smRMHBwWUAkJqaymv4rNa1efnyZaFcLuf84x//KKh53qRJkwrQSrr+Q+wH4HgD+/4LoG9rA2EYhmGYzojD4eD48eO3JRJJ6aeffiqSSCTdXV1dA1etWlVr7tPRo0et+Hy+etasWbVGgHJzc41UKhViYmKceTxeSM3H999/71BcXMxVqVSNxlBYWMh1cXGpaCpWCwuLJxri8XhUoVBwACA5OZlXN4bk5OTqBMfc3FxZM2EBACcnp0oASEtL4wHAZ5995hAVFeU+YMCA4l27dt09ffr0rbi4uCQAKC8vbzLvsLGxqTUMqO3h0+Xclrb58OFDYwBwdnaulVm6urq2emK9rkOH1tDcbVifYgA61/QghIQBeA2AO4C6mS2llA7WtS2GYRiG6Qi6du1a8csvv9xXq9W4cOGCMCYmxiEqKsrdy8tLoZ2TtH79+rT169c7DRkyRHzixIlkqVSqAABbW1sVh8PBlClTcmbMmJFfX/tcLrfR61tbWyszMzONGz1IBx4eHpVnzpy5VXeb9nlJSYmRQqEgNZOtrKws46rjKgBg//79Nr179y7ZunXrQ+0xSUlJLe6N0gdtQlX1GZZrt2sTsNbQNdF6CKAXgLh69vUCkKlLI4SQtwBsAvAYwG0AirqH6BgPwzBMh5BVVA4nyyZHQ5hnBIfDQZ8+feT+/v7pe/futUtMTBT26tWrDAAsLS1Vp06duj1kyBDfIUOGiI8fP347ODi43MLCQh0SEiK7ceOGSd++fdMbS6p4PJ66oKDgie/u/v37Fx8/ftw6LS3NuGZi1FwCgYAOGDCgrKH9KpUK3333nZV2jhYA/Pzzz9bOzs4VXl5elQAgl8s5ZmZmtXrONm/e3Ka1v4yNjWlrerjq6tmzp1woFKr37NljXXNoddeuXU/U6mouXROtfQA+IITEU0qr62QRQl6Cptr7Jh3beQ/AbgAzKKVNdnEyDMN0ZBdTH+MfW/7A3rd74zlPG0OHwxjIn3/+KZw3b55bREREgZ+fX7lKpSLffvutLZfLpeHh4SVFRUXVmZO1tbX61KlTd4YMGeIbHh4uPn78eHJISEh5dHR0enh4uLh///6+06dPzxOJRJW5ublGV65cMVWpVNi4ceMjABCLxeU7d+6037p1q7VYLFZYWlqqpFKp4osvvsj47bffLPv06eMfGRmZ6efnp0hPTzc+fvy45aFDh1Lb6r2ampqqly9f7pqXl2ckFosVu3fvtvnjjz8sYmNj73M4mrxn0KBBRZs2bXKKiopyev7550tPnjxpceTIkVYnLDX5+vrKL126ZPbjjz9aikSiSkdHR6VYLG5xXmFvb6964403sjds2OBsbm6uCg8PL7l8+bLJDz/8YAcAHA6n0TslG6NrorUSwAAAhwkhWQAeARABcAJwAcDHOrYjArCDJVkMw3R2SpUa7/0cDwrgvb3xOPVeGIy4ept/zVQx4nHUDd11qK8YXF1dK0UiUcXGjRsds7OzjXk8HvXz85Pv2bMnpX///mVHjhypNZnd0tJSHRcXdyc8PNwnPDxcfOzYseR+/fqVnT179tZHH33kEhUV5S6TybjW1tbKbt26lb311lu52nOXL1+emZKSwl+wYIFnWVkZ57nnnpNdvHgxWSwWV5w9ezYpKirK5dNPPxWVlZVxHRwcKoYNG1bYlu/V1NRU9f33399buHCh+507d4S2traVn3zySXrNuxtXrVqVUVhYyN2yZYvjV199xQkNDS05duzY7YCAgMC2imP16tWP3njjDY8ZM2Z0KS8v54wbNy5///7991vTZnR0dAallPz44492O3bscJRIJKVbt25NDQ8P97e0tGx8klwjCKW6JWmEEGMAUwAMhWZOVh40E+F3UUobrV9Ro43/AdhJKd3asnCr2xkPzTyvngAcoFkS6ACAzymlJTWOswbwfwDGQLM80B8AFlJKE3W5Ts+ePenly5dbEyrDME+pf/1+D2tO3Ia8QgUTHhfvh/thRr8uhg6rQyCEXKGU9mxof3x8/H2pVMpKAnUyERERnmfPnrXIzs5OMHQs+rJjxw7rGTNmdDl69Gjy8OHDZQ0dFx8fbyeVSj3r26drjxYopZUAtlc9WmoegB8IIcmU0v+1op33oUmu/gnN/LEgACsADCSE9KGUqgkhBMCvADwBvAugAMAHAH4jhPSglD6sr2GGYZim5JSUY21VkgUAZRUqrPnvbYyUimBvXu+d/QzDdHCnTp0yPXz4sOXzzz9fKhQK1ZcuXTL56quvnKVSaWl4eHiDSVZTdE60WooQkg6gZreZJTTJThk0yU9NlFLqoUOzIymluTVenyGEPIZmQesXAJwCMAqashODKKW/VcXyB4BUAIuhSfoYhmGa7fBfGVCpa48GqNQUh+MzMLOfl4GiYhimNSwsLFTnz583//bbbx1kMhnHxsZG+dJLLz2OiYl5pJ1/1hI6J1qEkHAAswGIUX9ZBu8GTo1D7USr1eokWVqXqn6Kqn6OApChTbKqzisihPwKYDRYosUwTAuN7iFC9InaC2VwOQSjpC1eDo1hOrzWzoHq6Hr27Fl+8eLF5LZuV6dEixDyIjTDcCcB+AM4BsAEmh6jNAC/N3QupXR6q6PUTVjVT239j24Artdz3A0AUwkhZpTSFncFMgzz7LI35+O9oX5/z9Ey1szRYsOGDMPUpWtf2DIAXwN4ser1h5TSF6BJZrgAjurSCCHkI0JIvX/yEUKcCSEf6RhP3XNF0NwZeZJSqp29boMnhyYBTQ0vQFOElWEYpkWm9fGEvZkmsbIz52Nqb0/DBsQwTIeka6LlD02PlhqaYUAjAKhaZHoFNImYLpYDaGhxRpeq/c1CCDEDcAiAEsDrzT2/nvZmEUIuE0Iu5+bWN0LJMAwDGHE5WPOKFATA2glSVtqBYZh66fqbQQ1ASTW1IHKhWT5HKwNAQ/Oz6mqs8rs1nqwU33hjhAihSQC7ABhW507CAtTfa2VTY/8TKKXfUEp7Ukp72tvb13cIwzAMACDUywZ/fDCYFStlGKZBuk6GT4amTAIAXAawgBByDppepPcA3G/oRELICwAG1dj0FiHk5TqHCQG8BM38KZ1U1fXaB00traH11Ma6ASC8nlO7AnjA5mcxDNMW2PI7DMM0RtdE6wcAAVXPl0MzKV7be6QCMLGRc8MAfFj1nKL+4b0KADeh452AhBBOVUyDALxMKb1Qz2GHAbxOCAmjlJ6pOs8CwEholgFiGIZhGIZpVzolWpTSr2s8v0IICQQwHJo7D09SSm82cu7HqFqihxCiBvA8pfRiq6LWTMx/BcBnAEoJIc/X2PewagjxMDSV4HcRQhbh74KlBMDqVl6fYRiGYRimSU3O0SKE8Agh8wkh3bXbKKUPKaXbKKWxjSVZdVFKOW2QZAHAiKqfS6FJpmo+3qi6lhrAywBOANgI4Bdoet8GUkrT2yAGhmGYp4pSqcTNmzeRns5+Rba10NBQcWhoqFj7+siRI+aEkJC66yDqS2RkpMvhw4cNcm3gyc9DV3l5edzIyEiXs2fPmrRVm+2tyR4tSmkFIeRLAMNacgFCiDuATEppZdXzpq73QIdjPHW5NqX0MYAZVQ+GYRimDkop0tLSkJCQgJs3b0KhUEAqlcLNzc3QoT3V+vTpU3ry5MmkoKAguSGuv27dOmelUolRo0aVNH1029u0aVNaS87Lz8/nrlu3ztnV1bWiX79+ZW3RZnvTdY7WLWju7GvJ+oSpAHoDuAjNpPmmqsRzW3ANhmEYpgV27tyJ1NRUGBsbo2vXrggMDISXF1tGqL3Z2NioBw8eXKrv68rlciIUCtt0tZaWCAkJKe8MbbYFXcs7fARgWdXcrOaaAeBujedNPRiGYZh2IJPJcOHCBXz//fdQqTQLYgcFBWHcuHF4//33MWbMGHh7e6M167o9y/744w/h0KFDva2srHoIBIJgT0/P7h988IFTfcfWN3QYGhoqDgkJEe/atcvK19e3G4/HC/by8uq2bdu2WqWKrl+/zh8zZoyXSCQKFAgEwa6uroGTJk1yz83NrdVRERER4eno6Cg5efKkaVBQkL9AIAh+5513XAkhIQDw1VdfORNCQgghIZGRkY2uHyUSiQJHjx7ttXbtWjt3d/fufD4/uGvXrgG//vprreHHM2fOmAwfPryLo6OjRPsZzJ07VySTyWqVd2poKPWHH36wnDp1qru1tbXU2tpaOnr0aK+8vDwuACQnJ/P8/f0DAeC9997z0MYeGxtr29I2tTIyMoxGjhzpZWZmFmRhYdFj/Pjxnj/88INlWwzv6tqjtQSAGYBrhJD7ADJRu2eKUkrD6juRUvpdjefftixMhmEYpiUqKiqQlJSEhIQE3Lt3D5RSODs7o7i4GNbW1ggMbMnfz0xdv/32m8mLL74odnNzU3z66afp7u7uFcnJyfyEhIQn5hI1Ji0tTbB48WK3JUuWZDg6Oiq3bNliP2vWrC6Ojo63R44cWQIA6enpxq6urhXjx49Pt7W1Vd65c4cfHR3tPHToUJO//vorqWZ7MpmMO3Xq1C5z5szJlkqlj0xMTNSTJ09+PGTIEP+IiIj82bNn5wKAp6dnRVOxXbhwwTwxMdFk2bJljwQCAV27dq3T+PHjfS9evHhDKpUqACA1NZUnkUjk06ZNy7ewsFAlJiYK16xZ43L//n3+kSNH7jV1jcWLF7sPGTKk8F//+lfqrVu3BJ988onrrFmz6IEDB+67u7tXfvfdd3enTZvmPWfOnKyxY8cWAkBAQECjNTgba1N7zMiRI71v374tXLp06UM/Pz/Fvn37rBctWtTkdCdd6JpoqaApv9AqhJARAP5HKdV7dynDMMyzQq1Wo6KiAgKBAFlZWfjll19gaWmJfv36ITAwEE9TMeaYqRFBSoXiiS44Iz5fPf/7/df0FceiRYvcLC0tVVeuXEkyNzdXV21u9vyn/Px8o5MnTyZphxXHjx9f5Ovr223FihUuI0eOTAaAESNGyEaMGFFdC3LIkCEysVisGD58uPjcuXPCvn37Vs/7Kisr42zZsiV98uTJhXWv5eLiUtGc4cvHjx8bnTt37paPj08lALz88svFnp6ekuXLl7scPHgwFQCmT59eCKAQ0Pw7DA8Pl1lYWKjmzp3rlZWVxXVyclI1do1evXqVfPfdd9q7MYqTk5MFe/bssVOr1feFQiHt1atXGQB06dJFoWvsjbXJ4XBw4MABi6tXr5pt3br13htvvFEAABEREcWDBg3yyczM5On6+TRE1/IOL7T2QlX+DaCSEHIFwG8ATgE4RyntkOOqDMMwnQWlFFlZWUhISMD169fh7++Pl156CW5ubpgxYwZcXV1BSGOLc3RO9SVZjW1vDyUlJZxr166ZvfXWW1k1kqwWcXJyqpX8GBkZYdSoUQWbNm1yUqlU4HK5KC8vJytWrHDcs2ePbWZmJl+hUFT/h71x44agZqJlZGREX3311UJdrq1Wq6uHlAGAEAIjo7/TBKlUWqpNsgDA2tpaPXDgwKKrV6+aarc9fvyYs3TpUucjR45YZ2Vl8ZRKZa3YnJycGk2OXnzxxaKarwMDA8t27txJHj58aOTu7q7U5X00t83z58+bcrlcTJkypbDmcePGjSv47bffLFtyzZp07dFqK34ABgN4AcBMaOpaKQghF6FJun6jlLZkwj3DMMwz6+LFi7h8+TJyc3PB4XDg5+cHPz8/AJovS3YHYfvKy8vjqtVquLq6Njn81hRbW9snkglHR8fKyspKkpGRYeTm5qZ89913Rd9++63DwoULM/v16yeztLRUpaWl8aZNm+ZdXl5eK8G0trZW1kyWGrNhwwbb+fPne2pfu7i4VDx69Kh61RV7e/vKuuc4ODhU5uTkVPf6vPbaa17nz583X7x4cUZwcHCZubm5+vz586YffPCBu1wubzL5tbOzq/X++Xw+BQBdzm1pm5mZmcbm5uZK7XYtZ2fnJ95vS+j06RNCBjR1jC4JEqU0BUAKgC1V7XaFprr7WFRNuNc1JoZhmGdVeXk57ty5g+7du4MQguzsbAgEArz00kvo1q0bhEKhoUN8ptjZ2ak4HA4ePXrU6mGm/Pz8J74Ds7OzjY2NjamLi4sSAA4dOmQzbty4/NWrV2dqj/n111/rvWO/Ob2YEyZMKOzRo8ct7WuBQFAr8cjNzTWue05OTo6xg4NDBQCUlZWRuLg4q8jIyIxly5blaI+5du1ah/4H6ezsXFlSUmKkUChIzWQrMzPziffbEromNafRhmUZCCEmAPoDGAhND1cQgGIAZ3Rtg2EY5lmiUqmQkpKChIQEJCcnQ6VSwdbWFi4uLnjppZfYnYIGZG5urg4ODpbt37/fdtWqVRlmZmYtLp+QlZXFi4uLM9UOHyqVShw+fNg6MDCwlMvVfM2Wl5dzjIyMal1j+/btts25jrGxMa3bS+Tk5KRycnIqa+ic+Ph405SUFGPt8GFBQQHnt99+sxw4cGARoOkhUqlUMDY2rhXbrl277JoTW2O0yV9rerjq6tOnT+natWuxc+dOK+0cLQA4cOCAdWPn6UrXRGtgPdtsoam8HgZgri6NEEJWQtOD9Rw06xueBbAXwNsArlVVc2cYhmFqyMzMxM6dOyGXy2FiYoKQkBBIJBI4OzsDAEuyOoA1a9akDx8+XNyzZ8+Ad999N8vd3b0yJSWF/9dffwlrTMRukq2trXLKlCldoqKiMhwcHJRbtmyxT0tLE8TGxt7WHhMWFlZ04MAB2y+//FJedYec1ZUrV8yaE6+3t3f5yZMnLX/55ZdiW1tbpbu7e6Wnp2ejQ2W2trbK8PBwvw8++CBDe9ehXC7nrFy5MqNqv0oqlZZu2rTJ0dnZudLe3l65Y8cO2+zs7DbpGQIAV1fXSisrK+X+/fttevToUWZubq728/NTNDXJvjHjxo0rDg4Oli1cuNAjLy/PyM/PT/Hzzz9b37p1SwgAXC63VXXHdPq/k1J6pp7HAUrpDGjWFByp4/U+BNADQCyALpTSEZTS/6OUXmFJFsMwjEZ+fj5Onz6NK1euAADs7e3h5+eHiRMnIjIyEiNGjIBIJHoqJ7c3lxGfX+93R0Pb20tYWFjZyZMnk1xcXCqioqLcX3nlFd/Y2FhHV1fXZs3z8fDwKP+///u/B1999ZXT1KlTvVNTUwVbtmy5py3tAADffPNN+uDBg4s+//xz0fTp07vIZDLuzp07myydUFNMTEyaiYmJ+tVXX/UJCwsLiI2NbfJW1F69epXMnTs3e+XKlaKZM2d2USgUnH379t2RSCTV5RX27Nlzr3v37mVLlixxnz17tqeDg4Ny9erVbbamE5fLRWxsbFpRURF39OjRfmFhYQF79+61am27v/76692wsLDiTz75xHXatGldysvLyT//+c8MALCysmpxEgcAhNLWFYglhAwB8BOltMmuQULIu9D0joUBsAQQD80k+FMAfqeUyho5Xe969uxJL1++bOgwGIZ5BpSWluLGjRtISEjAo0ePAADBwcEYOVLXv2M7DkLIFUppz4b2x8fH35dKpXn6jKkzCA0NFatUKly5ciXZ0LHUJRKJAnv27Ck7dOhQqqFj0ZepU6e6//zzz7aPHz/+q6lq+vHx8XZSqdSzvn1tMfFcDECnvxwopV8B+Ipo/gwLgubuw0EA3gRgQgi5RCnt2wYxMQzDdHja2/UB4Ndff0VycjIcHR0xdOhQdO/eHRYWFgaOkGGeDbGxsbZFRUXcwMBAuUKh4Bw9etTihx9+sH/rrbeyWrtkka53HU6tZzMPQHdoyjQcaM5FKaWUEHIdgAUAawB2AEIBPN+cdhiGYTobSinu37+PhIQE3Lp1C2+//TasrKzwwgsvYODAgXB0dDR0iAzzzDEzM1Nv3LjRMT09nV9RUUFEIlFFVFTUo5UrV2a1tm1de7S+bWC7AsAeAPN1aYQQ0geaHqyB0Cw0zQeQD81djd9BU8SUYRjmqaNdZzAxMRHFxcXg8Xjo2rUrtNM3nJzqXRKPeYZcvHixww0ZatWsp/U0mjFjRsGMGTMKmj6y+XRNtOpbyr2cUprdzOudhaY0//8AREFToPSp/o/HMMyzq6SkBHK5HA4ODiCE4M8//4SXlxeGDh0KsVgMY+M2uxmLYZgOStcleNLa6Ho9oSnj0LoZ+AzDMB2UQqGoXsQ5NTUVHh4emDZtGkxNTfH++++Dz+cbOkSGYfRI1zlaLwPwpJRuqGffHACplNL/NNUOpfRq80NkGIbpHE6fPo1z585BqVTCysoK/fv3R2BgYPV+lmQxzLNH16HDZWh4wruwan+TiRbDMMzTglKKzMxMJCQkYODAgeDz+bCwsIBUKoVUKn1qF3FmGKZ5dE20/AE01Bv1FzSFSBmGYZ56hYWFSEhIQEJCAvLz88HlciEWi+Hl5YXg4GAEBwcbOkSGYToQXRMtDoCGyvubA2AzOplnRkJCAuLi4lBUVARLS0sMHjwYEonE0GEx7YhSCkIICgoKEBsbCwDw8PBA79690bVrV7aIM8MwDdI10YoHMAnAL/XsmwQgoc0iYpgOLCEhAb/++isqKzWrahQVFeHXX38FAJZsPWWUSiXu3LmDxMRE8Pl8jB49GtbW1njppZfg4+MDKysrQ4fIMEwnoOtKpGsBjCOE/EwICSeEdCWEDCWE/AxgLID/a6oBQgiPEHKVEBLemoAZxpDi4uKqkyytyspKxMXFGSgipq09evQIR44cwdq1a7F37148ePAAZmZ/d+j37NmTJVlMsxw5csScEBJy8OBB89a2FRsba7t+/XrblpwbERHh6ejo2OH/IoyMjHQhhIQYOo62omt5h18IIfMBfAZgXNVmAkAGYB6ltMnK8JTSCkKIFwBlS4NlGEMrKipq1namc8jPz4e1tTU4HA5u3ryJhIQE+Pv7QyKRoEuXLuBwdP2blGHa165du+xUKhUWLFiQb+hYGN3ovNYhpfQrQsi3APoAsAWQB+B8MxeCPgEgHJpFpBmm07G0tKw3qbK0tDRANExrlJaW4vr160hISEBGRgYmT54Mb29v9O3bFwMGDGClGBhGB3K5nLR2LcCnXbP+TKOUllBKj1NKd1NK/9vMJAsAvgLwGiFkDSGkHyHEmxDSpeajme0xjF4NHjz4iWrexsbGGDx4sIEiYpqrtLQUu3fvxtq1a3Hs2DGo1WqEh4dXL4FjYmLCkiym2RISEvhDhw71trGxkfL5/GBnZ+fAESNGdKk71UDr5s2bPA8Pj+7BwcH+ubm5XAD4448/hIMGDfKxsLDoIRAIgoODg/2PHTtWPW4dGhoqvnTpktnVq1fNCCEhhJCQ0NBQsXZ/UlISb8yYMV52dnZSHo8X7OrqGvj666+71b32uXPnhCEhIWKhUBjk4eHRffXq1fa6vEft0OPJkydNg4KC/AUCQfA777zjCgAZGRlGEydOdHdwcJDweLxgLy+vbmvWrLGreX7VMR6enp7dhUJhkJOTk2TkyJFeqampT/UNdboWLF0CwJVS+m49+2IBpFNKm5ynBeBM1c9IAAsbOIarS0wMYwjaCe/srsPOQ61W4/79+5DL5ejWrRuEQiHkcjn69OkDiUQCBwcHQ4fIPAVGjhzpa2FhoYqOjk6zt7dXpqen844ePWqpUqmeKKZ27tw54ejRo/0kEknp4cOH75qZmdGzZ8+aDB06VNy1a9eymJiYNBMTE/WWLVvsR40a5RcXF5fUv3//sk2bNqVNmTLFS6VSkY0bN6YBgJWVlQrQJFm9e/cOEAqF6qioqEdisVhx//593okTJyxqXru0tJQ7ZcqULrNnz8728fHJ3L59u+2SJUvcAwICykeOHFnS1PuUyWTcqVOndpkzZ062VCp9ZGJion78+DGnT58+/gqFgixZsiTD29tbcfToUcslS5Z4KBQKztKlS3MAIDc3l8vn89UrVqx46OjoqExPTzeOjY116tevn/+dO3eum5iYPJU9Y7oOHb4OzYT4+vwF4H3oMCG+qh2G6dQkEglLrDqB7OxsxMfH4/r16ygpKYGdnR26du0KDoeDmTNnGjo8pg3JLmTYFMeli9QlFTyOOa/CYrDbI7PnXR7r6/qZmZlGDx484O/atStl0qRJ1XML3n777SdiOHTokPmkSZN8Xnzxxce7d+9OMzLSfA0vWrTI1dnZueLcuXO3BQIBBYCIiIgiPz+/bh9//LHzyZMn74aEhJSbmZmpVSoVBg8eXFqz3Q8++MBFoVBwrl27dtPT07O6G+3dd9+tNZertLSUExMT80CbVA0fPrzE2dnZcvfu3Ta6JFplZWWcLVu2pE+ePLlQu23RokXOmZmZvMuXL98IDAxUAMCYMWNKioqKuGvWrHFevHhxjrGxMaRSqWLHjh3p2vOUSiUGDRok8/X1lezbt89y6tSphU9esfPTNdFyB3CngX33AHjo0gil9Dsdr8cwDNNiJ0+exLlz58DhcODr64vAwED4+fmxSu1PIdmFDJvCI6keUKo5AKAuqeAVHkn1AAB9JVuOjo5KV1dXxUcffeSalZVlHB4eXqJNOGrau3evzb59+2xnzZqVvWHDhkfV70EmI5cuXTKfO3duJpfLpTWHG/v371988ODBJu8y/P333y0HDRpUVDPJqo9AIFDXTKiEQiH19PQsf/jwIU+7re5wZ83pEkZGRvTVV18trLk/Li7OUiKRlPr7+ytqnjts2LDiPXv22F29elXYq1cvOQCsWrXKfvv27fbp6el8uVxePX0pKSlJ0NR77Kx0TbTKAIga2OcK4Il/UAzDMPqgUChw8+ZNJCYmYtiwYXB0dIS/vz8sLS3RrVs3mJiYGDpEph0Vx6WLtElWNaWaUxyXLtJXosXhcHD8+PHbS5cudfn0009F77//vpFIJKp49913s5YsWZKrPe7o0aNWfD5fPWvWrLya5+fm5hqpVCrExMQ4x8TEONd3DZVKBS634Zk1hYWFXBcXl4qmYrWwsFDV3cbj8ahCoeAAQHJyMs/f3z+w5v6kpKREsVhcAQDW1tZKbS+cVn5+vtGDBw/4PB6v3pIMOTk5RgDw2WefOXz44Ydub7zxRvaIESOKbW1tlSqVigwePNi/vLz8qb21V9dE63cAiwgh+yil1UkVIYQP4L2q/fUihGwH8AmlNLXqeWMopZT16TMM0yi1Wo2UlBQkJCQgOTkZSqUS1tbWkMlkcHR0hKurK1xdXQ0dJqMH6pIKXnO2t5euXbtW/PLLL/fVajUuXLggjImJcYiKinL38vJSaOcerV+/Pm39+vVOQ4YMEZ84cSJZKpUqAMDW1lbF4XAwZcqUnBkzZtRbtqGxJAvQJECZmZmtnlTu4eFReebMmVt1t2mf19crbGVlpbS1tVWuX7/+QX1tBgYGlgPA/v37bXr37l2ydevWh9p9SUlJev3vZAi6JlorAJwHcJsQsgvAI2h6uCZDU+pheiPnDgQQU/V8EIDGJrs9lRPhGIZpPUopysrKYGpqisrKSvz8888wNjZGUFAQJBIJRCIRGxp8BnHMeRX1JVUcc16TvTvtEg+Hgz59+sj9/f3T9+7da5eYmCjs1atXGQBYWlqqTp06dXvIkCG+Q4YMER8/fvx2cHBwuYWFhTokJER248YNk759+6Y3llTxeDx1QUHBE9/d/fv3Lz5+/Lh1Wlqacc3EqLkEAgEdMGBAWXPOGTx4cPH27dsdvL29K0QiUYO1MuVyOcfMzKxWj9rmzZvtGjr+aaFrwdJ4QshAAGsALIGmLIQawFkAEZTS+EbO9arx3LNV0TIM88wpKCioXsSZx+PhrbfeAp/Px4wZM+Dg4NDkX/rM081isNujmnO0AABGHLXFYLdHjZzWpv7880/hvHnz3CIiIgr8/PzKVSoV+fbbb225XC4NDw8vKSoqqv5Ham1trT516tSdIUOG+IaHh4uPHz+eHBISUh4dHZ0eHh4u7t+/v+/06dPzRCJRZW5urtGVK1dMVSoVNm7c+AgAxGJx+c6dO+23bt1qLRaLFZaWliqpVKr44osvMn777TfLPn36+EdGRmb6+fkp0tPTjY8fP2556NCh1PZ8/0uXLs0+ePCgdd++ff3feeed7ICAgHKZTMa5deuW4Ny5c2ZxcXF3AWDQoEFFmzZtcoqKinJ6/vnnS0+ePGlx5MgR6/aMrSNoTsHSiwAGEEKEAKwBFFBK5e0WGcMwz7Tbt2/j7NmzSE/X3KTk6ekJiURSvcCzs3O9U1mYZ4x2HpYh7zp0dXWtFIlEFRs3bnTMzs425vF41M/PT75nz56U/v37lx05cqTW0juWlpbquLi4O+Hh4T7h4eHiY8eOJffr16/s7Nmztz766COXqKgod5lMxrW2tlZ269at7K233qqe57V8+fLMlJQU/oIFCzzLyso4zz33nOzixYvJYrG44uzZs0lRUVEun376qaisrIzr4OBQMWzYsML2fv+2traqP//8MykqKsolJibGKScnx9jc3Fzl5eVVPnr06ALtcatWrcooLCzkbtmyxfGrr77ihIaGlhw7dux2QEBAYGPtd3aEUsOM1hFCHAA8cZcBpbTeMV5D6NmzJ718+bKhw2CYZ4JSqcTt27fh4eEBU1NT/PXXXzh//jwkEgkCAwNZ9f1OhBByhVLas6H98fHx96VSaV5D+xmms4mPj7eTSqWe9e3TuUeLEMIDMAKAGE8mSJRS+okObXAAfArgLQBWDRzGxgEY5hlBKUVaWhoSEhJw8+ZNKBQKjBgxAqGhoZBKpZBKpWzeFcMwnZquleFdoJmP5QnNhHXtb76a3WFNJloAFgCYA2AVNAnXZ9DM9ZpU9fNLXeJhGKbzq6ysxMaNG1FYWAhjY2MEBARAIpHAy0szrZMlWAzDPA107dH6PwC5AAYAeACgV9XrGQD+Ac1C0bp4HcBKAOuhSbR+oZReJYR8CuC/0BRGZRjmKSSTyXD9+nUUFRVh2LBhMDY2Rrdu3eDo6AixWAwe76m/y5thmGeQrolWf2iW2cmoeq2mlN4H8BEhhAsgFsBoHdrpAuAypVRFCFECEAIApbSSELIemkWnV+gcPcMwHVpFRQWSkpKQkJCAe/fugVIKV1dXqNVqcDgcDBkyxNAhMgzDtCtdEy1bABmUUjUhpBSauw61TgGYq2M7Rfh7flcGNPO9ztWIxUbHdhiG6aDUajUATT2hixcvIi4uDpaWlujXrx8CAwNhb29v4AgZhmH0R9dE6yEAbVGxu9AMFZ6seh0KoFzHdq4B6ArgeNXjY0KIHIASmvlaV3VphBDiCk09r54ApND0jHlV9bLVPE4AzdyxydBMvv8LwBJK6f90jJdhGB1QSpGVlYWEhARcv34dw4cPR7du3dCjRw+4ubnB3d2dzbliGOaZpGui9RuAMAAHAWwB8DUhpAeASgDDqrbpYj00w4cAsBxAMIAfql6nQfeeMR8AEwBcgWb5n4bmiP0LwEsAFkGz+PUcAMcJIb0ppX/peC2GYRqgUqnwxx9/ICEhAbm5ueBwOPDz84O5uaZskJmZGczMzAwcJcMwjOHommh9iKphPUrpJkKIETST4E0ArIZmgnuTKKUnajzPIoSEAvCuaucWpVTXZQP+Ryl1BABCyBuoJ9EihEgBTAQwg1K6o2rbGQA3quIdpeO1GIapoby8HNnZ2fDw8ACHw0F8fDyEQiFeeukldOvWDUKh0NAhMgzDdBi6LsGTByCvxuuvoJm43ipUUy01pQXnqXU4bBQ0PW57apynJIT8BCCKEMKvuUA2wzANU6lUtRZxNjIywvvvvw8jIyO8+eab7I5BhmGYBuhcsLStEEKsACwE0BuahakfQbNg9XpKaWEbXqobgFRKad3FMW8A4EEz/HijDa/HME+lGzdu4N///jfkcjlMTEwQEhICiURSvcYgS7IYhmEaxmn6kLZTNZx3B8AH0Nx9eLPq5z8B3CaEtOV6RzYACurZ/rjGfoZh6sjPz8fp06fx6JFmTV5ra2t4e3tj4sSJiIyMxIgRIyASidjkdoZpB7GxsbaEkJDk5ORm/wUTGxtru379etu2bLOziIyMdCGEhBg6jvrou0crFkA+gJ6U0jTtRkKIJ4Bj0AxHvqDnmGohhMwCMAsA3N1Z/VTm2VBaWoobN24gISEBjx49AgVQyTWCSCSCi4sLIiIiDB0iwzwTxo8fX9StW7ckd3d3XecsV9u1a5edSqXCggUL8tuqTab19J1oPQdgWs0kCwAopfcJIcsB7GjDaxUA8Khnu7Ynq96V3Sml3wD4BtAsKt2G8TBMh0IpBSEElFJs3rwZMpkMDg4OqJA+hz0Ca5Q7uGKooYNkmGeMi4uL0sXFRdnR22wNuVxOhELhM/P9qtehQ2h6sxqagF5etb+t3ADgRQgxqbO9K4AKtGASPsN0dpRSpKam4tChQ/jmm2+qk62XXnoJb7/9NsbNeAM/WIsg4wvxU9Zj5CjYH8AM0xTtsNXFixeFvXr18hMKhUH29vaSBQsWuKhUKgBAWVkZmTlzppuvr283ExOTIDs7O+mgQYN8rl27JqjZVn3DfCKRKHD06NFe33zzjXWXLl26CYXCoO7duwccP368unZKaGio+NKlS2ZXr141I4SEEEJCQkNDxa1pU2vlypUOIpEokM/nBwcGBgacOHHCVCQSBUZERHg29dlERER4Ojo6Sk6ePGkaFBTkLxAIgt955x1XAMjIyDCaOHGiu4ODg4TH4wV7eXl1W7NmjV3N86uO8fD09OwuFAqDnJycJCNHjvRKTU011vW/j6Hpuqj0dgCfUEpT69nnAWA5pXSGDk1tArCIEPJfSml1kVNCiBCaJX6+1i1snfwK4GMArwD4ruo62rIU/2V3HDLPkoKCAly5cgWJiYkoLi4Gj8dDQEAAKioqwOfz4e/vDwBYkpwONdX8oammFNH3s/Cl2M2QoTNMpxEREeE9ceLEvCVLlmQdPXrUIiYmxpnD4SA6OjpDLpdzZDIZZ9GiRRkikagyPz/faPPmzfZhYWH+169fv+7u7t5oj9OlS5fM7t69K1i2bFmGQCBQr1y5UjR+/Hif1NTURDs7O9WmTZvSpkyZ4qVSqcjGjRvTAMDKykrVmjYBIDo62m758uVuEyZMyJswYULBnTt3+NOnT+9SXFzM1fVzkclk3KlTp3aZM2dOtlQqfWRiYqJ+/Pgxp0+fPv4KhYIsWbIkw9vbW3H06FHLJUuWeCgUCs7SpUtzACA3N5fL5/PVK1aseOjo6KhMT083jo2NderXr5//nTt3rpuYmHT4njFdhw6nA9gM4IlEC5qK8dOgWWC6KSbQDOc9IIT8B0A2AEcALwKQAzAlhGhrclFK6fKGGiKEjK96qp38NoIQkgsgl1J6hlJ6jRCyB8B6QohxVeyzAXgBmKRDrAzTqZWUlIDD4cDU1BTZ2dk4f/48fHx8MHToUIjFYhgb1/6DMFtRiT1Zj1FR9WurggI/ZT1GpKcTHPid5o9H5hl06dIlmzNnzohkMhnPzMysIiws7NFzzz1X7/SQ9jRlypS8zz//PAsAxo0bV1xSUsLdsmWL4z//+c9sOzs71Z49e6qnzSiVSowdO7bYyclJumPHDpvly5fnNNa2TCbjxsfH37S3t1cBgEgkqgwLCwvYt2+f5dtvv/04JCSk3MzMTK1SqTB48OBSXeJtqk2VSoXVq1e7DBgwoKhm7M7OzpXTp0/31vVzKSsr42zZsiV98uTJhdptixYtcs7MzORdvnz5RmBgoAIAxowZU1JUVMRds2aN8+LFi3OMjY0hlUoVO3bsSK/5uQ0aNEjm6+sr2bdvn+XUqVMLn7xix9KcOVoNZY1O0CRJuvhnjedT69m/tM71Gky0APxc5/XGqp9n8PeE+tehWdrnU2iW4IkHMJxSqtNSPwzT2VRUVODWrVtISEhAamoqBgwYgBdeeAG+vr547733YGpq2uC50fezqnuztFivFtPRXbp0yeb48eMeSqWSAwAymYx3/PhxDwDQd7I1efLkWtd77bXXHu/Zs8fuypUrwmHDhsm2bdtmHRsb65iamiqQyWTVPULJycmCJ1urLSgoSKZNiADgueeekwPAgwcPWnwnYVNt3rt3j5ednW38wQcf1LqDf9KkSYUzZ86s9cuisrL2NIOaf8gZGRnRV199tbDm/ri4OEuJRFLq7++vqHnusGHDivfs2WN39epVYa9eveQAsGrVKvvt27fbp6en8+VyefWUp6SkpCY/t46gwUSLEDIWwNgamz4mhOTVOUwIoD80S+E0iVLaZnPCKKVN3ltOKZUDiKx6MM+64gzAwsXQUbQLSikOHz6MGzduoLKyElZWVujfvz8kEgkAgMvlNppkAcDxvOLq3iytCgocyyvGl+L2ipxhWufMmTMibZKlpVQqOWfOnBHpO9FydXWtNfzn4uJSCQAPHjww3r17t+Wbb77ZZdy4cflLly7NdHBwqORyuRgzZoyvQqFo8rux7jCgdjJ5eXl5i79Xm2ozPT3dGAAcHR1rvS8jIyNYW1tXb0tOTub5+/vXKs+UlJSUKBaLKwDA2tpaaWRUO93Iz883evDgAZ/H49VbkiEnJ8cIAD777DOHDz/80O2NN97IHjFiRLGtra1SpVKRwYMH+7fmvetTYz1a7tAkUYCmd6kHnpzIroCm2OgHbR4Zw7SltPPAjheB148CHr0NHU2rUUqRmZmJtLQ09O7dG4QQEEIgkUggkUjg5ubW7DpXf/Xt1k7RMkz7kclk9fboNLS9PT18+NCoa9euFdrXGRkZxgDg7u5e+fXXX9u7u7sr9u/ff1+7X6FQkOLiYr0XDteVm5tbJQBkZ2fXilGpVKKgoKB6m4eHR+WZM2du1TzGw8Ojupuqvt9FVlZWSltbW+X69esf1HftwMDAcgDYv3+/Te/evUu2bt36ULsvKSmpU9UDa/A/MKU0BkAMABBCUgGMoZTG6yswhmkzKiVwcDYAqvk59zLA7bC/2xpVWFiIhIQEJCYmIi8vD1wuFxKJBKamphg1ii3fyTx7zMzMKupLqszMzCrqO7497dq1y0Y7RwsAfvzxRxsTExN1z5495XK5nMPlcmv1GW/atMlGe1diW+DxeOqaCVBrdenSpcLR0bHywIED1vPnz6+uCrBr1y4rlUpVnT0JBAI6YMCAuquwNGrw4MHF27dvd/D29q4QiUQN3gggl8s5ZmZmtT6kzZs32zV0fEek61qHXu0dCMO0m4tbAFnVPFNZNnDxG6D3O4aNqQVu3ryJn3/WTE10d3fHyy+/jK5du7JFnJlnWlhY2KOac7QAwMjISB0WFvZI37Hs3LnTTq1Wo1evXmVHjx612LNnj11kZGSGra2tKjw8vGjx4sVWM2fOdBs1alThxYsXTbdt2+Zgbm7eZpmWWCwu37lzp/3WrVutxWKxwtLSUiWVSlt8hz2Xy8XixYsz3nvvPY9//OMfHhMmTChISUnhx8TEOJmZmak4nJaP3C1dujT74MGD1n379vV/5513sgMCAsplMhnn1q1bgnPnzpnFxcXdBYBBgwYVbdq0ySkqKsrp+eefLz158qTFkSNHrFt8YQPQOfMlhIgAvAdgAABbACMppdcJIQsA/EEp/bN9QmSYVijJBk59ClRW/bFVWQac+gQIHA+YORg2tkYolUrcuXMHiYmJ8PX1RVBQEDw9PTFw4EBIJBJYWVkZOkSG6RC087A6wl2HBw4cSJk7d677+vXrXczMzFTz5s3LXL16dSYAREZG5qWnp/N++uknu927d9t179697MCBA3cmTJjg01bXX758eWZKSgp/wYIFnmVlZZznnntOdvHixeTWtBkZGZknk8k4mzdvdjx48KCtr6+vfPv27akTJkzwsbCwaHGSaGtrq/rzzz+ToqKiXGJiYpxycnKMzc3NVV5eXuWjR4+unny/atWqjMLCQu6WLVscv/rqK05oaGjJsWPHbgcEBLTlkn3tilDadAkKQkg3AL8DUAH4A8BLAJ6jlF4lhKwD4EgpndiukRpAz5496eXLlw0dBtMaf3wNxH0MKGv8UWckAAYv75C9Wg8ePEBCQgJu3LiB8vJymJqaIiwsDM8995yhQ+u0vpl/BpWKJ78PjPlczIoJM0BETz9CyBVKac+G9sfHx9+XSqV1b67qtCIjI13WrVvnXFFRcaVu2ZSn0f/+9z+TsLCwgA0bNqTOmTNH7wltRxQfH28nlUo969una4/WWgC3AAyDpoJ7zbHv8wBWtSZAhmk3ga9oerRqIhxNj1YHIZPJYGamKcZ84sQJZGdnw9/fHxKJBF26dEFruucZ1JtkNbadYZi/JSUl8aKjox0GDBggs7S0VN24cUOwbt06Z5FIVNEZalh1BLomWv0AvEYplRFC6laDzYamllaTCCEqAL0ppRfr2RcC4CKlVOdqswzTJDMHYNCHfw8fGpsAg5YZfNiwtLQU169fR0JCArKzs/H+++9DIBBg9OjRMDc3B5/PN2h8DMMwAGBiYqK+deuWcN++fbbFxcVcCwsLVd++fYujo6MfmZubqw0dX2ega6LV2IdpB90LljZ2vzkXDRdFZZiWC30LuLgVKEgFzByB0FkGCyU7OxtxcXFISUkBpRROTk4YPHhw9e3Pdnad6mYahmEAREdHZ0RHR2cYOo724O7urvz999/vGDqOzkzXROsiNFXWf61n3wQA5xo7mRDCwd9JFqfqdU1CACMAPDVj9kwHwjUCxmzU1NEas0mvpR3UajXu378PoVAIZ2dnGBkZITs7G3369IFEIoGDQ8edkM8wDMO0nq7fOJ8AOEkI+S+A3dD0PA0hhMyHpnr8gIZOJIQsB/BR1UuKxpOyjY3sY5iW8+gDRN7UW2X47OxsxMfH4/r16ygpKYFEIsHYsWNha2uLBQsWNLuYKMMwDNM56VpH6wwhZAyA9QC2V23+EsB9aAqZNlba4XTVTwJNwvUvAA/rHKMAcBPAEV3iYZgW0VOS9eOPP+L27dvgcDjw8fHBsGHD4OfnV72fJVn6ZcznNnjXIcMwTHvTeQyFUvpvAP8mhPgAcACQTyltsj4HpfQMNAs9gxBCAWyjlOq9kBzDtAeFQoGbN2/i9u3bGD9+PLhcLsRiMXx8fNCtWzeYmJgYOsRnHivhwDCMITV7sgqlNAVASksuRin9uO42QkhXAAHQFD19KicTMk8XlUqFu3fvIiEhAcnJyVAqlbC2tkZRURFsbGwQHBxs6BAZplVyissxfvMf2De7NxzMBYYOh2E6NZ0SLULI1EZ2qwEUAbhGKa07JFi3nQ0AjCilb1e9HgdgDzR3HBYTQoZSSi/pFDnD6BGlFEqlEsbGxkhPT8ePP/4IoVCIHj16QCqVQiQSsSFB5qkRG3cH6QVliI1Lwadjuhs6HIbp1HTt0foWf5deqPltUnObmhCyB8DrlNKGFvMcAaBmr9bH0MzL+giaoqjLAbysY0wM0+4KCgqQkJCAhIQE+Pr6Yvjw4fDw8MDEiRPRpUsXcLlsng/zdMkpLsfPVx6CUmDf5XTMG+zDerUYphV0LTndF0AagA0AwgD4V/3cCOABNEvyREFzB+KKRtpxhmYCPQghrgC6AfiCUpoIIBYAW2eE6RD++usvbN++HbGxsTh9+jQsLCzg5uYGQDOZ3dfXlyVZzFMpNu4O1FVLs6koRWxci2aKMHWEhoaKQ0NDxdrXR44cMSeEhBw5csTcEPFERka6HD582CDXbkzdz+lpoGuP1vsAfqKU/rPGttsAfieElACYRSkdSwixBDAJwD/rawRAGQCzqudhAIoBaBcTlAHocP/RmWeDUqlEamoqfHx8QAhBWloaysvLMXjwYAQGBsLS0tLQITJMu9P2ZlWqNIlWpYqyXq120qdPn9KTJ08mBQUF6Vrwu02tW7fOWalUYtSoUSWGuP6zRNdEKxwN17g6BWBu1fP/AVjcSDtXAcwhhDwAMAfACUqptuq8F4BMHeNhmFajlOLBgweIj4/HzZs3oVAoMGvWLDg7O+PFF1+EkZERm3fFPFNq9mZpaXu12FyttmVjY6MePHhwqb6vK5fLiVAobPUqLGq1GhUVFUQgELAVXZqg69ChAkBIA/tC8Pci0xwAjf3DWQrgeQDxAMTQFELVGgNNBXqGaXfZ2dmIiYnBt99+i+vXr8Pf3x+TJ0+Go6MjAMDY2JglWcwz58St7OreLK1KFcWJm1kGiqhz+eOPP4RDhw71trKy6iEQCII9PT27f/DBB/WuBVzf0GFoaKg4JCREvGvXLitfX99uPB4v2MvLq9u2bdusa557/fp1/pgxY7xEIlGgQCAIdnV1DZw0aZJ7bm5urfkMERERno6OjpKTJ0+aBgUF+QsEguB33nnHtWptYXz11VfOhJAQQkhIZGRko4UGRSJR4OjRo73Wr19v6+Xl1Y3H4wXv3bvXUvu+Bw0a5GNhYdFDIBAEBwcH+x87dsys5vlnzpwxGT58eBdHR0eJ9rOZO3euSCaTPfW/aHXt0foZwMdVi0LvA5ADTS2tV6CZk6UtYtoDQIO1tSillwgh7tDM8bpDKS2usfsbAGw9JaZdyGQyXL9+HSYmJpBIJLCxsYGzszMGDRoEf39/8Hg8Q4fIMAb35z+HGDqETuu3334zefHFF8Vubm6KTz/9NN3d3b0iOTmZn5CQ0KxiemlpaYLFixe7LVmyJMPR0VG5ZcsW+1mzZnVxdHS8PXLkyBIASE9PN3Z1da0YP358uq2trfLOnTv86Oho56FDh5r89ddfSTXbk8lk3KlTp3aZM2dOtlQqfWRiYqKePHny4yFDhvhHRETkz549OxcAPD09G7qJrdoff/xhfvPmTZOoqKhMJyenSh8fn4qzZ8+aDB06VNy1a9eymJiYNBMTE/WWLVvsR40a5RcXF5fUv3//MgBITU3lSSQS+bRp0/ItLCxUiYmJwjVr1rjcv3+ff+TIkXvN+Yw6G10TrUho5k+trnrUtBvAe1XPrwP4o74GCCE8ABcARFFK/1t3f1VBVIZpMxUVFUhKSkJiYiLu3r0LSikCAwMhkUhgbGyMf/zjH4YOkWGYNvDw4Q82qfc3iCoqcnk8nn2Fl+fcR66ukx7rM4ZFixa5WVpaqq5cuZJkbm6unRLT7PlP+fn5RidPnkzSDiuOHz++yNfXt9uKFStcRo4cmQwAI0aMkI0YMUKmPWfIkCEysVisGD58uPjcuXPCvn37Vs/7Kisr42zZsiV98uTJhXWv5eLiUtGc4cuSkhLu5cuXb7q7uyu123r37u3n7Oxcce7cudvaYcSIiIgiPz+/bh9//LHzyZMn7wLA9OnTCwEUApphx/DwcJmFhYVq7ty5XllZWVwnJ6cnl294Sui6BI8cwGRCyEoAvaC5ezATwMWa1eEbS5YopRWEEC8AyoaOYZjWopRWD/kdOHAAycnJsLS0RN++fSGRSGBvb2/gCBmGaUsPH/5gcyflMw+1WsEBgIqKHN6dlM88AEBfyVZJSQnn2rVrZm+99VZWjSSrRZycnGolP0ZGRhg1alTBpk2bnFQqFbhcLsrLy8mKFSsc9+zZY5uZmclXKBTVw283btwQ1Ey0jIyM6Kuvvlqoy7XVajVUqr/zHUIIjIz+ThOkUmlpzSRLJpORS5cumc+dOzeTy+XSysrK6mP79+9ffPDgQVvt68ePH3OWLl3qfOTIEeusrCyeUqmsFbOTk5Pe56vpS5OJVj09Ubdbcb0T0EysP9WKNhimFkopsrKykJCQgBs3buCNN96AhYUF+vXrh969e8Pd3Z3Nt2KYp1Tq/Q0ibZKlpVYrOKn3N4j0lWjl5eVx1Wo1XF1dmxx+a4qtre0TnRGOjo6VlZWVJCMjw8jNzU357rvvir799luHhQsXZvbr109maWmpSktL402bNs27vLy81mdhbW2trJksNWbDhg228+fP99S+dnFxqXj06FGi9rWDg0NlzeNzc3ONVCoVYmJinGNiYpzra1ObHL722mte58+fN1+8eHFGcHBwmbm5ufr8+fOmH3zwgbtcLtd1vnin1OSn38Y9UV8B2EUIMQJwEJpesVozLymlT/VYLdN25HI5rly5goSEBOTm5oLD4cDPzw8VFZrfda6urgaOkGGY9lZRkVvvBMuGtrcHOzs7FYfDwaNHj1p9zfz8/Ce+l7Ozs42NjY2pi4uLEgAOHTpkM27cuPzVq1dX36n/66+/1lvYrzl/ZE6YMKGwR48et7Sv695RWLctW1tbFYfDwZQpU3JmzJiRX1+bXC4XZWVlJC4uzioyMjJj2bJlOdp9165dE+ocXCem6xyttuqJOlP1MxLAwgaOYVUgmQaVl5ejrKwMNjY2UCqVOHXqFFxdXfHSSy+ha9eubBFnhnnG8Hj2FRUVOU8kODyefat7l3Rlbm6uDg4Olu3fv9921apVGWZmZi0ueZCVlcWLi4sz1Q4fKpVKHD582DowMLBUWyS5vLycY2RkVOsa27dvt62nuQYZGxvTuj1JTk5OKicnpzJd27CwsFCHhITIbty4YdK3b9/0hoo4y+VyjkqlgrGxca2Yd+3aZdecmDsrXROttuqJer1Z0TEMNF3PKSkp1Ys4e3p6YvLkyTA3N0dkZCTMzMyaboRhmKeSl+fcRzXnaAEAh8NXe3nOfaTPONasWZM+fPhwcc+ePQPefffdLHd398qUlBT+X3/9Jfzuu+/SdW3H1tZWOWXKlC5RUVEZDg4Oyi1bttinpaUJYmNjq6fthIWFFR04cMD2yy+/lPv5+Sn27dtndeXKlWb9IvT29i4/efKk5S+//FJsa2urdHd3r/T09Kxs+szaoqOj08PDw8X9+/f3nT59ep5IJKrMzc01unLliqlKpcLGjRsf2draqqRSaemmTZscnZ2dK+3t7ZU7duywzc7ONm7u9TojXROtNumJopR+p+P1GAYAcO7cOZw7dw5yuRwmJiYICQmBRCKp3s+SLIZ5tmnnYRn6rsOwsLCykydPJi1btkwUFRXlXllZyXF2dlZMnDix3iG1hnh4eJRHRkZmrVixwjUtLY3v4uJSsWXLlnva0g4A8M0336S/+eab5PPPPxcBwAsvvFC0c+fOey+88EKArteJiYlJW7hwofurr77qU1FRQRYuXJgZHR2d0ZxYAaBfv35lZ8+evfXRRx+5REVFuctkMq61tbWyW7duZW+99Vau9rg9e/bce/PNNz2WLFnizufz1S+//HLB9OnT01977TWf5l6zsyGUNt3DSQiZ1tQxzUmiiGagtysAGwCPAdykugSiZz179qSXL19u+kCmzeTn5yMxMRF9+vQBj8fDxYsXkZ6ejsDAQHh7e7P1BRmmEyCEXKGU9mxof3x8/H2pVJqnz5g6g9DQULFKpcKVK1carEfJdEzx8fF2UqnUs759upZ3aLOeKELIGwA+BVDzPvscQsiHlNJ/tdV1mM6jtLQUN27cQEJCAh490vT2u7m5wdvbG6GhoQgNDTVwhAzDMAzTMroOHbYJQsgkaCrAxwHYBSALgBM0C1F/Qwgpo5T+qM+YGMMqKCjAhg0boFar4ejoiKFDh6J79+6wsLAwdGgMwzAM02o6J1qEEAcAr0GzRmHdZdwppXSmDs0sBvADpXRKne3fEUJ2AlgCgCVaTylKKe7fv4+EhATweDyMGDECVlZWGDRoEHx8fKrXGWQYhnkWXbx4kQ0ZPoV0SrQIIWJoltYxAmAKIA+a+VVcAAUAinS8nhiaZKs+u6C5o5F5yuTm5iI+Ph6JiYkoLi4Gj8eDVCoFoKnL0rdvXwNHyDAMwzDtQ9cerf8DcAnAGAClAEYASAAwFcDHAMbq2E4JgIaqSLqiBetCMR1TSUkJTE1NweFwcPXqVfz555/w8fHB0KFDIRaLYWz8TNzVyzAMwzzjdE20ngPwNgBF1WsOpVQJYDshxB7AegADdWjnKIDPCSG3KaW/azcSQnpDM0H+qK6BMx1PRUUFbt26hYSEBKSmpmLKlCnw8vJC37590a9fP5iamho6RIZhGIbRK10TLTMAjymlakJIEYCa1VwvAVimYzuLATwP4DQh5BE0hU+doOnNSkHDw4pMB1ZWVoZjx44hKSkJlZWVsLKyQv/+/WFjYwOA1bpiGIZhnl26Jlr3oUmIACAZwCsAjlW9fhlAoS6NUEqzCCE9AMwA0B+aeV73oSmI+i2lVOfS/4zhUEqRmZkJmUwGPz8/CAQCZGZmQiKRQCKRwM3NjS3izDAMwzBoJNEihNwDMJZSGg/NWodDAfwMIBrAT4SQftAsNO0P4DNdL1iVTG2oejCdSGFhIRISEpCYmIi8vDzY2NjA19cXHA4H77zzjkGSq8ysQ7h3dw3KFZkQ8J3Rxft9ODuN1nscDMMwDFOfxnq0PAHwq55/oH1OKd1LCJED+AcAEwAxALbqcjFCyCpoamidZb1Xncvp06dx5oxmJSYPDw88//zz6Nq1a3VyZagkKylpKdRqOQCgXJGBpKSlAMCSLYZhGKZD4DR9CEApVVBKi2u8/pVSOplSOo5S+k0zls+ZBM2QYwEh5Bwh5BNCyCBCCL+pExn9USqVuHXrFvbu3YvcXM1SVV5eXhg0aBDmz5+P6dOnIyQkBEKh0KBx3ru7pjrJ0lKr5bh3d42BImIYhmkfsbGxtoSQkOTkZF5r2xKJRIGjR4/2am0758+fF0ZGRrpkZ2c3e220I0eOmBNCQg4ePGje2jg6uqbmaLXp+oOUUldCiB+AQdDcpTgLwFIACkLIBQCnKKWftOU1CSFuANZBM/RJAJwEsIBS+qAtr9PZUUqRnp6OhIQE3LhxA+Xl5TA1NUVBQQHs7e3h4eEBDw8PQ4dZS7kis1nbGYZhmLZz+fJlk3Xr1jnPmDEj39HRUWXoeDqqphKtjwkhuiz8SSmlTS48XXXgbQC3AWwGAEJIXwArAAwGMABAmyVahBATAKegKUsxDZrE8VMAvxFCJJTS0ra6VmdVUVEBHo+HiooK7Ny5EwAQEBAAiUSCLl26gMPRqdPTIAR8Z5QrnlxsXsB3NkA0QHZpNhxNWXV7hmEAuVxOhEJhm3ZWMJ1TU9+iPaC5O1CXh04IIUJCyFBCyBdVvVi/QVOn6wiA95r7BprwJoAuAMZQSg9SSg8BGAXAA8BbbXytTqO0tBR//vkntm7diu++06wXzufzMWnSJLz//vsYN24cfHx8OnSSBQBdvN8Hh1N7+JLDEaKL9/t6j+VK9hUM3TcUV7Ov6v3aDMMYVmRkpAshJOTSpUuCfv36+ZqYmAS9/PLLXUpKSjizZ88WiUSiQGNj42CRSBS4ZMkSJ5Xq786fsrIyMnPmTDdfX99uJiYmQXZ2dtJBgwb5XLt2re5SdzqprKzE/PnzXdzc3Lrz+fxga2traUhIiPj48eMN1tlRKpV47bXXPMzMzIK0Q3lNxR4bG2s7f/58TwAIDAzsTggJqTm0WVlZiaVLlzp5e3t308bRv39/37rvq7S0lDN16lT3/2/vzsOirNo/gH9vYGDYZBvWgQFBxA0QUHw1ExLFLTc0MpcyLXvT9FVK1NA0U+xH7pmGmqWYSyWZpmlhLi32amimGaQoioIoKJtss5zfH88M74DswgzC+VzXXDDPPM9z7jmCc3NWGxsbfxsbG/+RI0e2z8nJaXBXZEtWV4vWKMbYmaYqjIhOAQgGIAfwC4CvAcwEkMwYUzVVOVpGAPiNMXZVc4Axdp2IfgEwEsIMyib18PxdFBxNhzKvDIbWJmg3yAPmAQ5NXUyjXL9+HadPn8bVq1fBGIOTkxP8/PzAGAMRwcPDQ98hNohmwPsfZ+ZBZC6HvMgImf+1wblNWwBsgbHYFDO3f9nscShUCiz8eSEYGGJ+jsHB0QdhZFDlV6vwDrBtEDDle8CSt3pxXGsUERHRYcKECTnR0dF3VCoVQkNDvdPS0kyjoqIy/f39S3799VfztWvXuty/f99oy5YttwCgpKTEoKioyGDu3LmZUqlUnpuba/Txxx/bh4SEdLp06dIlmUymaEgMCxcudNqyZYvjggULbgcGBhbn5+cbnj171rym5KWoqIhGjRrlef78eYsjR46k9u3bt1gul9cZ+9ixY/PT0tKy1q9f77xt27ZrMpmsHABkMpkcAIYPH+6ZlJRkM2XKlOzw8PCCkpISg5MnT1rcunVLFBAQUKopPzo6WjZgwIC8Tz755Prff/8tfu+991ynTZvGEhMT0xv9D9HC1HtT6SbSF0AJgB0AjgI4yRir7z6JjdEVwDfVHP8LwlpgTerh+bvIS7wCJhdyRmVeGfISrwCAXpItlUqF9PR0ODk5wczMDA8ePEB2djb69OkDPz8/ODi0jATwcTg7jcSuz6uf9FpeWlLt8aa26+9dyC3NBQDkluZid8puTOpSZd/0k3FA3k3g5P8BzzZ5fs9xbd6t0nLR8HNXfL4N9E6Rio0blJw0lWnTpt1dtGjRXQD46KOPbM+dO2dx+PDh1CFDhhQBwMiRIwsBYPXq1S5Lliy5I5VKFXZ2dsq9e/fe0NxDoVBg9OjRBU5OTv6ffvqp7eLFi+82JIYzZ85Y9O3bt0ATBwCMHz++2s/Ze/fuGQ4ePLjD3bt3RadOnUrp2rVrGQBs3ry5XrF7eXmVAUDPnj2Lu3Xrptk5BgcOHLA8evSozXvvvZexcOHCijgmTZqUVzWGXr16FW7fvj1D/bQgNTVVvHfvXolKpUpv6b0q9aXrd+EHYakIFwCfAcghorNE9H9ENFg9pqop2ULY9Lqq+wBsmrgsFBxNr0iyNJhchYKj6U1dVK2ys7Px/fffY+3atUhISMClS5cAAP7+/pg9ezYGDBjQKpKsliCnJAcb/tiAEoWQ1JUoSvDh+Q+RU6I1tLHwDvDH5wBTCV8Ls/UULce1XiuuZTnfKZObrLiW5aKvGMaNG5en+f7o0aNWLi4u5QMGDCiSy+XQPIYOHVqgUCjoxIkTFXuSbd261cbPz6+TpaVld5FIFNSuXbuA4uJig9TU1Bq7D5VKJbTvq+nSCwwMfHjy5EmrmTNnSo8ePWpRWlpa7do72dnZot69e3cqKSkx+PXXXyuSrIbGXp0jR460IyLMnj37Xl11NnTo0EpJoK+vb3F5eTndunVL1w1BzUanb4QxdgnAJQDrSVh4KQDCDMRnAbwFoUuxUf3STYWIpkGYDQmZTNaga5V5ZQ063tTkcjk++eQTZGdnw8DAAN7e3vD19UXHjh0BAIaGrarbu0U4fO0wlKrKk22UTInvrn/3v1atk3FCkgUIX3mrFsc1qVul5aKDd/MkDMCBu3mSBZ7Omfpo1dJ0mwFATk6OUWZmprGxsXFQdefm5OQYAcCuXbusXn31Vc+IiIjcmJiYLAcHB7mhoSFGjRrlXVZWVmNjSGRkpEdiYqKd5nlERETuvn370mNjY++IxWL25Zdf2m7YsMHJzMxMNWTIkAcffvjhLWdn54o6SU1NNc3LyzN6++23b7u5uVWqq/rGXpP79+8bWVlZKSwsLOqcDCCRSCqVbWJiwgChS7Wua58UNVYWY6zZ3iQRiQD0gbDEQ38AvSAsvVBd69PjeIDqW65qaukCY2wzgM0A0KNHjwbNGDG0Nqk2qTK0bp5lwsrKynD58mXk5+cjNDQUIpEIbm5uCAwMRLdu3WBm1tQNhFxVQz2HYsMfGwCthkxDMsSQ9kOEJ5rWLGW58FxZLjwPmcfHanFcE1lxLctZpV6NSAWGFdeyXDZ0cdf5Ej4GBgYVnxm2trZKqVRavmvXrrTqzvX29i4HgD179tjKZLKyffv2pWteKysro4KCglqTmdjY2Mz//Oc/Fd1yjo6OCkBIVJYvX35n+fLld27evGn01VdfWb/zzjtur7zyisGhQ4euac7v169fgZ+fX/Hy5ctdxWKxSrursb6x18TOzk6Rn59vVFRURPVJtlo7nbZoEdHbEBKr3gBMAeRC2OdwDoDjjLG/m7jIvyCM06qqC4DLTVwW2g3yqDRGCwBIZIB2gzyarAylUom0tDRcvHgRKSkpUCgUkEgkePrpp2FoaIhhw4Y1WVlc3SSmErzR/Y2K7kNTI1PMDJgJial633Xt1iwN3qrFcU1G05qlYCAAUDCQPlu1NMLDw/OPHDlibWlpqdIe/F1VSUmJgaGhYaVkZNOmTbbaMxOr4+PjU+7j41NrwiOTyRRRUVE5R44csUpNTX1khen33nsv29DQEO+8846bSqWCZjxYfWPXtD4VFxdXapgZPHhwwcaNG53WrVtnHxMT06AxZq2RrvtA5wI4BWGR0h8ZY382c3kHAKwkIk/G2DUAICIPAE8BmN/UhWkGvDf1rEPNwvtEhNOnT+PYsWMwNTVF9+7d4e/vD6lU2qY3cTYWm1Y78N1YrJuV68d3Ho/dKbtxq+gWJGIJXuj0wv9eTD38v9YsDWW5cJwnWhz32LRbszT02aql8dprr91PSEiQDBo0qOP06dOzAwICisvKyujq1asmhw4dsj5y5EiapaWlKjw8PD86Otp66tSpbiNGjMg7c+aM+datWx0sLS0btQBoWFiYl6+vb0lQUFCxra2tIjk52eynn35qN378+GrXxFyyZEm2oaEhW7x4sZtKpaJ33303u76x+/n5lQDA2rVr7adMmZJrbGzMgoODS4YPH144aNCgB4sXL3bNyMgwHjBgQEF5eTmdPHnScvjw4fnPPvts4ePU7ZNG14mWXTMt41CTLQDeAPANES2EsGDpewAyAMQ3R4HmAQ5NNsPwwYMHFZs4h4WFoXPnzvD19YW9vT06dOjAx1yp6WIJh9oYGRhhWd9lePnIy1jWd1nlpR3eTNFfYBzXBpy8X2itac3SUDDQifuF1gD0lmiZmJiwkydP/rNw4ULn7du3S2JjY01MTU1Vbm5uZeHh4flisVgFAFFRUTkZGRnGe/bskezatUvSrVu34sTExCuRkZEdGlNu3759i/bv32/z2WefOZSWlho4OTmVv/7669krVqyoccuMRYsW3TUyMmIxMTEypVKJZcuWZdcn9t69e5dERUVlJiQk2O/du9depVIhJSXloo+PT/nBgwevLVy40Gnv3r2STz75xMHCwkLp5+f3cPr06XUOkG9tqP7bFD6ZiEiGylvwHIOwBU96Xdf26NGD/f77780bYBUqlQrJycm4ePEiMjKEGa8eHh54+umn4enpqdNYuIbhK8NznICIkhljPWp6/cKFC+n+/v712XWE454IFy5ckPj7+3tU91qrmT5ZE/WehmP0HUdtFAoF7t27B2dn54ruQSMjI4SFhcHX1xdWVlb6DpGrB55kcRzHcVW1+kSrpWKM4ebNm/jzzz9x+bIwLv+tt96CoaEhpk6dCjMzszY97orjOI7jWgOeaOlBamoqvvvuO+Tn50MkElWMvdIkVubmta4Fx3Ecx3HcE0LXyztYAShljOlmBc8WoqioCJcuXYKHh0fFdjj29vYICwuDj48PjI2N9R0ix3Ecx3HNQGeJFhEZQVg3azSAg7oqV1/Ky8uRkpKCixcvIi0tDYwx9O/fH05OTnBzc8OECRP0HSLHcRzHcc1MZ4kWY0xBRNkAGrU2yJOEMYaPPvoIBQUFsLKywlNPPQU/Pz/Y29vrOzSO4ziO43RI12O0dgJ4BcBhHZerU0SEsLAwWFlZQSaT8UHtHMdxHNdG6TrRSgcwnojOAvgGQBZQeUlfxtg2HcfULPz8/PQdAsdxHMdxeqbrROsj9VcpgOp2BWcAWkWixXEcx3Ecp+tEq72Oy+M4juM4jtMbg7pPaTqMsRt1PXQZD8dxHMe1JOvXr7cjoqDU1NQGr/uzfv16u7Vr19o15T2bmya2S5cumTzuvZYuXeqwfft268ZcGxwc7BMUFOTzuDFUR6eJlgYR+RHRG0S0mIic1Mc6EJGlPuLhOI7juJZg7Nix+UlJSSkymUze0Gt37twpSUhIkDTlPZ8k8fHxjomJiTb6jqMqXS9YagJh5mEEhA2eGYQ1te4AiAPwD4D5uoyJ4ziO41oKFxcXhYuLi6Kl35OrP123aC0HMADAJACOEJItje8ADNJxPBzHcRz3WKKiolyIKOjMmTOmvXr16mhqahpgb2/vN3v2bBelUlg6sri4mKZOnerm7e3d1czMLEAikfj379+/w/nz58Xa96qum08qlfqOHDmy/ebNm208PT27mpqaBnTr1q3z0aNHLTTnBAcH+5w9e9bi3LlzFkQURERBwcHBPo9zT42lS5c6SKVSXxMTk0BfX9/OP/zwg7lUKvUdM2aMR111c/LkSbM+ffp4W1tbdxeLxYGurq6+EydOlNV2zalTp8zs7Oz8w8PDvYqLiwkADh06ZNG7d++O5ubmAaampgF9+/b1Pnv2bEXdSaVS38zMTOMDBw7Yat6/dnynT582HThwoJcmDg8Pj24LFixwqlr2/v37Lbt06dLZ1NQ0wNvbu+uOHTus63qPddH1YPgXACxkjO0iIsMqr10H4KHjeDiO4ziuSYwZM8Zr/PjxOfPmzbvz3XfftVu3bp2zgYEBVq9enVlSUmJQVFRkMHfu3EypVCrPzc01+vjjj+1DQkI6Xbp06ZJMJqu1xens2bMWaWlp4kWLFmWKxWLV0qVLpWPHju1w/fr1ixKJRLlp06YbkyZNaq9UKmnjxo03AMDa2rrWBcLruicArF69WrJ48WK3yMjInMjIyAdXrlwxmTx5smdBQUHVz/BH5OfnG4wYMaKjn5/fw40bN15v166d6tq1a8anT59+JJnTSExMbDdp0iSvkSNH5u7YseOmkZER9uzZYzVx4sQOISEhefHx8dcBYNWqVU5hYWGdzp0791eHDh3kX3zxxdVRo0Z5d+rUqWTJkiWZAODk5KQAgOPHj5sNHTrUx83NrWzZsmUZMpmsPDU11eTPP/800y775s2bJm+99ZYsKioqy8HBQbF69WrHKVOmeAUGBl7q1q1bo7cO1HWiZQfg7xpeMwDw2IPhOI7juLbn9oMS0ZiPf/VJfL1Piou1qV66ySZNmpQTGxt7BwAiIiIKCgsLDePj4x3ffvvtbIlEoty7d2/FhC+FQoHRo0cXODk5+X/66ae2ixcvvlvbvYuKigwvXLhw2d7eXgkAUqlUHhIS0vmrr76y+ve//30/KCio1MLCQqVUKhEWFvawPvHWdU+lUom4uDiXfv365WvH7uzsLJ88ebJXXfe/cOGCuKCgwHDlypW3evXqVaI5PmvWrNzqzt+0aZPtrFmzPN544407a9asydQcj46OduvZs2fhsWPH0jTHhg4dWuDl5eUbGxvrtG3btoynnnqqxNjYmNna2iqqvv+5c+e6WVlZKZOTk1MsLS1V6sOFVct/8OCB0Y8//pjq6+tbBgC9e/culslk/jt37rR5//3379T1fmui60TrOoDeAH6s5rVgAKm6Dad2ycnJOUTU1mdCSgDk6DuIJwivr4bh9dUwT0p9ueu6wA+Opjhn55eafHA01WXN891v6rp8AJg4ceJ97ecvvPDC/b1790qSk5NNBw0aVLR161ab9evXO16/fl1cVFRU0SKUmpoqfvRulQUEBBRpEiIA6NmzZwkA3Lx5s9EzCeu657Vr14yzs7NFCxYseKB93YQJE/KmTp1aabFxubzyOHuRSISuXbuWWVpaKl977TX3adOm3Q0PDy/s0KFDtQPy4+LiHHft2iVZvnx5xrx58+5pjl+8eNEkIyPDJCoqKku7DEtLS1VAQMDD3377rcbWMQAoLCw0OH/+vMVrr712RyvJqpa7u3uZJskCAKlUqrC1tZU/Th0Duk+0dgB4m4jSAexTH2NE9AyAOQCW6DieWjHG2vzmhET0O2Osh77jeFLw+moYXl8Nw+urercflIgOX7wjYQAOXcySzB3kk6mPVi1XV9dKZbq4uMgB4ObNm6Jdu3ZZvfrqq54RERG5MTExWQ4ODnJDQ0OMGjXKu6ysrM7x0lW7AU1NTRkAlJaWNnqsdV33zMjIEAGAo6NjpfdlZGQEGxubimOpqanGnTp18tU+JyUl5aKPj0/5kSNHUt99912X6Oho9xkzZhh06NChNCYm5vbkyZPztM8/ePCgjaOjo3zixImVkrqsrCwjAJgzZ47HnDlzPKq+B2dn5/La3mNOTo6hSqWCq6trrecBgLW19SM/M8bGxqw+/z610XWiFQfAH0ACgK3qYz8DEAPYwxj7UMfxcBzHcU+4D46mOKuY0MCiUjHoq1Xr1q1bRl26dKn4QM/MzBQBgEwmk3/00Uf2MpmsbN++fema18vKyqigoEDXn8P15ubmJgeA7OzsSjEqFAo8ePCg4pi7u7v85MmTlYYFubu7ywGgT58+JUePHk2Ty+U4deqUeWxsrNPUqVO9unbt+lfPnj1LNefv3LkzbcaMGR79+vXzOX78eKpmzJqmxW3BggW3Bw8eXFA1RhMTE1b1mDaJRKI0MDDA7du39baGmK4XLFUyxsYBCAGwCkKytR5Af8bYBF3GwnEcxz35NK1ZChUjAFCoGB26mCXJzCvReQKzc+dOW+3nu3fvtjUzM1P16NGjpKSkxMDQ0LBSUrBp0yZbzazEpmBsbKx6nBauqjw9PcsdHR3lVdem2rlzp7VSqaxYNUAsFrN+/foVaz/EYnGl9yoSiRAWFvYwNjY2U6VS4eLFi6bar6uTtVSVSoXQ0FCfGzduiADA39+/1MXFpfzy5cumVcvo169fsfbYL5FIxKq+f0tLS1VgYGDRvn377IqKirRXOtAZvWTSjLGfAPykj7K5Btus7wCeMLy+GobXV8Pw+qpCuzVLQ1+tWgkJCRKVSoVevXoVf/fdd+327t0riYqKyrSzs1OGh4fnR0dHW0+dOtVtxIgReWfOnDHfunWrg6WlZZNlWj4+PqUJCQn2W7ZssfHx8SmzsrJS+vv7N3q2nKGhIaKjozPffPNN9+eff949MjLywdWrV03WrVvnZGFhoTQwqD2n2717t9WWLVvsR4wY8cDLy6u8qKjIYMOGDQ7m5uaqkJCQoqrna5KtZ555xic0NLTj8ePH//Hw8JCvXr365oQJE7yGDRtGzz333H17e3tFVlaW6Ndff7WQyWTlS5YsyQYAb2/vkrNnz1rs3r3bSiqVyh0dHRU+Pj7lK1euzBg8eLBPjx49Os+cOfOOTCaTX7161eSPP/4w3b59e0Zj66e+dL1g6XkA2wHsZoxl67JsrnEYY/w/9gbg9dUwvL4ahtfXo366kmOtac3SUKgYnfrnnjUAnSZaiYmJV9944w3Z2rVrXSwsLJSzZs3KiouLywKAqKionIyMDOM9e/ZIdu3aJenWrVtxYmLilcjIyA5NVf7ixYuzrl69ajJ79myP4uJig549exadOXPmsSaZRUVF5RQVFRl8/PHHjvv377fz9vYu2bZt2/XIyMgO7dq1qzVJ7NKlS6mpqanqgw8+cMnJyRGZmZkp/fz8Hh44cOAfLy+vagfFy2QyxalTp1KfeeaZjqGhoT7Hjx9Pff755/Pt7OxSly9f7jxr1iyPsrIyA4lEIg8ICHg4fvz4igkIcXFxt1955RX3KVOmeJaWlhpERETk7tu3Lz0kJKQ4KSkpZdGiRdL58+fL5HK5gbOzc9n48eOrnf3Y1IixWrs3m7YwosMABkJYEf4YhKRrP2OstNYLOY7juFbjwoUL6f7+/k/C7Ml6iYqKclmzZo1zeXl5skgk0nc4ze7UqVNmISEhnTds2HB9xowZ9+u+ovW7cOGCxN/f36O613Q9RmsoACmAaAD2AHYByCaibeqZh5wOEJErEX1IRKeJqJiIGBF51PPaKCI6SERZ6uuWNG+0+tfY+iKijkS0joj+JKIidZ0dICJ/HYStN49RX5ZE9AURXSWih0SUR0RniGiiDsLWm8f5faxyn3Hqa281Q5hcG5WSkmI8bdo01507d1ofPHjQ8v3337d/7rnnOkil0vIXX3wxT9/xPQl0vqk0Y+wuY2yteopyVwAfAegPIImvWaUzHQBEAniAho+VexWAA4D9TRxTS9bY+goH8AyEltvhAKZD+APjNyIKauogW5DG1pcxAAWAFQBGABgPYYHjBCKa09RBtiCP8/sIACAiawBrIewby3FNxszMTPX333+bzpo1y3306NHecXFxLsHBwYXHjx9PrWtdKk6g067DagMgEgMYA+B9AC6MsTqX9eceDxEZMMZU6u9fAbAFQHvGWHp9ryUiIwByAO8yxpY0Z7z61tj6IiIJgFym9UtGRFYA0gEcZIy92GxB69Hj/HzVcL/TACwYY751nvwEaor6IqLNEBYJzQIwgDHm2hyxNpXW1nXIcS2m61AbEfUnok8BZENYyPQWgJn6iqct0fynrutrn1SNfc+MsRxW5S8Zxlg+gH8gdKG3Ss3wM5ILoaWrVXrc+iKipwBMBDCjaSLiOK4p6XrWYTcI/yGMB+AK4S/7dQASGGNXdBkLx+kDEdkC6AbgU33H0lIREQEwBGAFobV7EICpeg2qhSIiEYQlHz5gjF0Vqo7juJZE1+to/QkgH8CXAHYwxn7Wcfkcp28fAiAI42m46s2AUE+A0D39H8bYDj3G05LNA2ACYVwbx3EtkK4TrUgIY1MavYAaxz2piGgBhNbcqYyxq/qOpwXbC+A3CBsojwDwIREpGWPx+g2rZSGiDgBiAIzmS+RwXMul00SLMfaV5nsisgBgA+ABY+yRFWI5rjUhon8DiAWwkDG2Td/xtGSMsXsA7qmfHiEiMwAriWgbY6zaRQ7bqPUAfoQwi9VafcwYQu+rNYAyxlhJDddyHKcjOh8MT0SDiOh3AHkQxmhp1soZqOtYOE4XiGgSgI0AVjHGlus7nifQ7wAsADjqO5AWpguAoRCWhdA8XgDgov6edydyXAug68HwgwAcAnAVwHsQ1nxxBvA8gMNENJQx9oMuY+K45kREoyEMfN/KGHtL3/E8oUIAFAG4q+9AWphxAMRVjs0HEATgOQgzuTmO0zNdt2gtAfA9gC6MsXcZY/HqNZi6AvgBwLs6jqfNIqKxRDQWwn/KADBEfSxE6xwFEX1S5boe6usi1Ie6aO6l7uJplRpTX0TUD8BuABcAfEZE/9J6BOj0DehYI+vrNSL6lIgmEFEIEUUQ0R4AYwEsY4yV6/Zd6E5j6osx9htj7IT2A8Ifr2Xq53wcYAsSHBzsExwc7KN5/u2331oSUdC3335rqY94oqKiXA4cONBkZY8ZM8bD0dHR73Hvk5OTYxgVFeXy888/N+rzhIiCZs2a5fK4cTQlXQ+G9wfwXNV1Y9QLYG4E8IWO42nLvqzyfKP660kAoervDdUPbW8AeEnr+XPqBwC0h9Ad3Bo1pr76Q5gRFgjglyrX3wDg0aQRtiyNqa+LAEYCWAnAFkAOhJXhn2WMHWq2SFuGxv4+ck+oPn36PExKSkoJCAjQyzi6NWvWOCsUCowYMaJQH+XXJDc313DNmjXOrq6u5X379i3WdzxNQdeJVhmAdjW8Zql+ndMBxlidC+5Udw5jbDKAyc0QUovWmPpSt9YuaaaQWrRG1tevEMYctTmN/X2s5pzJTRIQ1+xsbW1VYWFhD3VdbklJCZmamup3S5g2RtddhycAvEdE7bUPEpEMwgfScR3Hw3Ecx3FN4vTp06YDBw70sra27i4WiwM9PDy6LViwwKm6c6vrOgwODvYJCgry2blzp7W3t3dXY2PjwPbt23fdunWrjfa1ly5dMhk1alR7qVTqKxaLA11dXX0nTJggu3fvXqUWT013XlJSknlAQEAnsVgcOH36dFfNXqsffvihMxEFEVFQVFRUrd1tH3/8sW3nzp27mJmZBVhYWAR07NixywcffCCp7Zp169bZiUSiwLfffruiDlauXCnx8fHpYmJiEmhjY+MfGRnpnp2dbQgAqampxp06dfIFgDfffNNdE9v69evtNNfv2LHDOjAwsJMmDl9f386ff/65VdWyly1b5iCVSn3Nzc0Devbs6fP7779XHc+oM7pu0ZoHoQsllYh+g7AvlxOAf0GYhThPx/FwHMdx3GM7fvy42dChQ33c3NzKli1bliGTycpTU1NN/vzzzwaNNbpx44Y4Ojrabd68eZmOjo6K+Ph4+2nTpnk6Ojr+M3z48EIAyMjIELm6upaPHTs2w87OTnHlyhWT1atXOw8cONDsjz/+SNG+X1FRkeGLL77oOWPGjGx/f//bZmZmqokTJ94fMGBApzFjxuS+/vrr9wDAw8OjxjGQR48etZg+fXr7yZMn312xYkWGSqWiy5cvi/Py8mrMIebPn++0atUql1WrVt2YNWtWLgBMnz5dunnzZseXX3757ooVK25lZGSIli9fLh04cKDpuXPnUmQymXz79u1pL730kteMGTPujB49Og8AOnfuXAYAy5cvd1i4cKHbgAED8jZu3HjH0tJS9fvvv5tdv37dRLvsffv22bVv3740Li7uZnl5ucHChQtdIyIiOqSlpV0SiUQN+edoErpeR+sfIvID8CaApyGMXbkPYRueNYyxLF3Gw3Ecx7USeRkibAv3wdQfUmDlqvO9MefOnetmZWWlTE5OTrG0tNSMQ27w+Kfc3FyjpKSkFE234tixY/O9vb27LlmyxGX48OGpADBkyJCiIUOGVKw/OWDAgCIfH5+ywYMH+/zyyy+mTz31VMW4r+LiYoP4+PiMiRMn5lUty8XFpbw+3Ze//PKLuaWlpXLbtm0ZmmMREREF1Z2rVCoxZcoUty+++EKSkJCQNm7cuHxAaK2Kj493mjNnTubKlSsrPus7d+5cOmjQoE67d++2njRpUl6vXr2KAcDT07NMO7b79+8bxMbGSgcOHJj3/fffp2mOjxkz5pE4jIyM2LFjx66amJhUdJFOmTLF88SJE+YDBw7UeXetztfRYoxlMcbeYoz1Yox5q79G8ySL4ziOa7QflzqjIMsEx5bqfMZZYWGhwfnz5y0iIiJytZKsRnFycqqU/BgZGWHEiBEPLl68aK5UKgEApaWlNH/+fKf27dt3FYvFgcbGxkGDBw/2AYC//vqrUheZkZERGzduXF59ylapVJDL5RUPhULIV3v16vWwoKDAcOTIke13795tlZOTU+2kDKVSScOHD/f85ptv7A4ePPiPJskCgG+//badSqXCyy+/fF+7jGeeeeahubm56uTJkxa1xfbjjz9aFBcXG0ybNu1ebecBwNNPP12gnWQFBgYWA8D169eN61MPTU3niRbHcRzHNam8DBH+2i8BGPDXfgnyb+m0tyYnJ8dQpVLB1dX1sZcgsbOze6Q1ztHRUS6XyykzM9MIAGbOnCldtWqVy3PPPXf/iy++uHLixIm/t2/fngYApaWllT7XbWxsFEZG9auODRs22BkbGwdpHu7u7r4AMGzYsKJt27Zdy8zMNJ40aZKXk5OTf58+fTr+97//NdW+/uHDhwbHjx+3CgwMLAoNDa3UcnT37l0jAOjWrVs37TKMjY2DHj58aHD//v1ag7x3754RALi7u9dZx7a2tpXqUCwWM+DRutGVZv9hJKIDABYzxs7X83wxgOkAihljHzdrcBzHcdyT78elzmDqBgymAo4tdUHE5pu6Kl4ikSgNDAxw+/btx24xyc3NfeRzOTs7WyQSiZiLi4sCAL755hvbiIiI3Li4uIqeoIMHD1bbykRU52TVCpGRkXndu3f/W/Nck6AAwMsvv/zg5ZdffpCfn29w+PBhy0WLFrkOHz7cOysr609DQ6Hodu3aKT/55JPrkZGRHUaOHOm5f//+a5oxUXZ2dkoASExMvFJdMung4FBrd6/m9Zs3bxr37NnzidrbUxfZXTqEvbj+S0SziCiQiCr9IBGRCxGNUi/GlwVgKoBzOoiNa+OIqDcRfUFEmURUTkS5RPQDEb1ERK1izSL171ZUNcdDiYgRUWgD7/fIdUQ0m4giar6K45qJpjVLJRcyCpWcdN2qZWlpqQoMDCzat2+fXVFRUf0zm2rcuXPH+NixY+aa5wqFAgcOHLDx9fV9qEloSktLDYyMjCot0bBt2zY7NIBIJGIlJSWVcgAnJydlv379ijWP4ODgR9b4srKyUr3wwgv5kydPvnfv3j1RdnZ2pXp+9tlnCxMTE6+cOHHCasSIEZ5yubA96bBhwwoMDAyQnp5urF2G5tGpU6dy4H/JXdXY+vfvX2RmZqbavHmzfUPeZ0vQ7D+IjLFZRLQOwGwISzhYAWBEVABh3SxrqDdCBXBGfd5OxpiyuWPj2jYimg1gNYSNeedBWETUBkA4gE0QZsJ+o6fwmtIoAAMgvFdt5wD0BnC5gfer7rrZAH4GkNioCDmusbRbszT00Kq1cuXKjMGDB/v06NGj88yZM+/IZDL51atXTf744w/T7du3Z9R9B4GdnZ1i0qRJnvPnz890cHBQxMfH29+4cUO8fv36fzTnhISE5CcmJtq9//77JR07diz76quvrJOTk2sd41SVl5dXaVJSktXXX39dYGdnp5DJZHIPD49qN22fPXu2y927d0WhoaEFbm5u8hs3bhhv3rzZoVOnTiWaVjZtgwcPLvr666//iYiI6Pjss896HThw4FrXrl3LXn/99TsLFiyQpaamikNDQwtNTU1VN27cME5KSmr36quv5gwfPrzQ1dVVbm1trdi3b59t9+7diy0tLVUdO3Ysc3JyUsbExNyKiYmRDRo0yGv8+PG57dq1U507d85ULBazmJiYFrtFl04yfsZYGoCZRPQmhP+ge0HY+FQMIBdACoBTjLEbuoiH49Tb46wGsIExNqvKy98Q0WoA5o9e2XowxgoA/Kar6ziuWaQdt65ozdJQyQlpP1oD0FmiFRISUpyUlJSyaNEi6fz582VyudzA2dm5bPz48bkNuY+7u3tpVFTUnSVLlrjeuHHDxMXFpTw+Pv6aZmkHANi8eXPGq6++SrGxsVIACA0NzU9ISLgWGhraub7lrFu37sacOXNk48aN61BeXk5z5szJWr16dWZ15/7rX/96uGHDBoeYmBi3/Px8I1tbW0W/fv3y4+Liqj0fAMLDwx/u37//n9GjR3sPGzbM89tvv722YcOG2507dy7ZvHmzw/bt2+2JCE5OTuV9+/Yt7NKlSykAGBoaYv369TeWLFkiHTlyZEelUknr1q1LnzVrVu7bb799z9nZWbFmzRrH1157zdPIyIh5enqWLFiwoEVPpiNW9S8BjmsDiOgQhITflTFWa38/EQUDiIWw3htBSDIWMMbOaJ3zGYRWo+EA1kPYs+42gFXaYw2JaDKETaZ7A5ipPr8IwFcAorVjUe8duRhAJACp+n5bAazQ3saKiOwh7BM6HIADhM2XTwB4BUA8Km+ZBAA3GGMe6q6/4wCeYYydIKKPIOwrKGWMVfyVSkQmEPbQ28EY+08116UDcK9SxnYAB9Xvqztj7EKVOj0BQMwY+xe4NufChQvp/v7+OfqOo6UJDg72USqVSE5OTtV3LFzDXLhwQeLv7+9R3Wt81iHX5qjHXj0D4Pt6JFl+EPabs4Gw9dCLELaROklE/lVObwdgF4CdEPbsOwtgExE9U82tEwCkQdicexOAGQAWaJVrBOAohGRpHYAhEJKsRQA+0DrPBsCvAJ6H0EI3FEA0ABGELvn3ABwGcA9CctcbwOga3m4ChEQtvMrxZyF08e+o4brREBKxo1plvAeh2zUTwGvaJxNRJwAhAPhkF47jWj1drwzPcS2BBIAphDFZdXkHwljCMMZYHgAQ0Q8QJnkshpAoaVgCmM4YO64+7xSAQQBewKPbS+1ijC1Wf59ERL3U52mOvQCgL4AQxtgp9bFj6hlEi4no/xhjdwHMAeAJoEeVmb271V8LiegegHLGWK3dfYyx34joCoBJEJIzjUkA/maMJddw3XkiKgOQU7UMItoCYA4RzWWMaaZ7T4Mw/m1vbfFwHMe1BrxFi+Nq1w/At5okC6gYo3QAQquMtmJNkqU+rwzAPwBk1dz3UJXnF6ucNxhCIvgrERlpHgC+h9BapelyCwdwtr7Lp9RDAoCRRGQJAERkB6GVLKGR99sMwAxC4qhZvuUlCN2Qj8xo4ri27MyZM6m827D14YkW1xblAijBo+OKqmMLYcmRqu5A6E7U9qCa88ogTPqo6n4152nv1+Wgjk9e5aEZF2an9fVWDbE3xk4I8Y5VP38eQsv3zsbcjDGWCaEL8d/qQ89BqNP4xwuT4zjuycC7Drk2hzGmUA/GHkhEJuqWp5rch7DxeVVOqD6xaiq5AK5DGAhfnXT11xwIA+WbBGPsOhH9AmAihEH7EwGcYIzVe3p6NTZC6PYMgjBe6yfGWEOXlOA4jnsi8RYtrq16H0JrUFx1LxJRe62B8EM1XWnq1ywhzPA70YzxHQHgBqCIMfZ7NQ/NjK3vAQRXMzBfWxmEMWn1tQNAqHp2YW/Ur9uwxjIYYz9CWMJlNYCnwAfBc4CKz3jnWgv1z3KNe1zyRItrk9QDzKMgrO/2AxFNIKKniWiEeoHdSwDaQ5g9ZwahRWaMevXzJPWxpc0Y4ucQZhMeI6IoIgojoiFE9AYRfa9e+gEA1gC4BmFA/X+IqD8RRRLR51rJ4WUAtkT0OhH1JCLfOsr+EkI35U4IXaxf1SPeywCeJqJniagHEXlUeX0ThPFuOQD21eN+XCtGRHlyuZz3qHCtglwuNyKiGns4eKLFtVmMsbUQZvblAVgJYYX4zwB0htDFdZAx9ieAUAAFENaGSoCw7lVI1bWhmjg2OYQZi1sgzNI7DCH5eglCAlauPi8PQivR1wDmQ2gJWwVAoTkHwrIQeyCsBXYGwvpWtZWdpz5HCmA/Y6ywtvPVFgBIBfAFhGUtllR5/Uv118/q6Krl2gDG2IWCgoJWvSAw13YUFBRY1PZ5wBcs5Tiu2RHRqxAGwHdkjF3VdzycfiUnJ3ubmJgc8vDwUJibmxc3ZONjjmspGGN4+PChWXp6ulFZWdmwoKCgK9WdxxMtjuOaDRF1AeAFIcn6jTHGN57mAADJycmDRSJRNGOsPYQdFzjuScOI6LpcLo8LCgo6UtNJPNHiOK7ZqGd39oHQ3TlevdwDx3Fcm8ETLY7jOI7juGbCB8NzHMdxHMc1E55ocRzHcRzHNROeaHEcx3EcxzUTnmhxHMdxHMc1E55ocRzHcRzHNROeaHEcx3EcxzWT/we8zxBhlY1tvwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'font.size': 16})\n",
    "\n",
    "def weighted_score(df, paired=True):\n",
    "    score = {}\n",
    "    for domain_pair in list(df['domains'].unique()):\n",
    "        d1, d2 = domain_pair\n",
    "        curr_df = df[df['domains'] == domain_pair]\n",
    "        curr_score = []\n",
    "        curr_weights = []\n",
    "        for i in range(len(curr_df)):\n",
    "            row = curr_df.iloc[i]\n",
    "            count1, count2 = cs[d1][row['cls1']], cs[d2][row['cls2']]\n",
    "            weight = min(count1, count2) / max(count1, count2)\n",
    "            curr_score.append(weight * row['acc'])\n",
    "            curr_weights.append(weight)\n",
    "        curr_score = np.sum(curr_score) / np.sum(curr_weights)\n",
    "        if paired:\n",
    "            score[domain_pair] = curr_score\n",
    "        else:\n",
    "            assert(d1 == d2)\n",
    "            score[d1] = curr_score\n",
    "    return score\n",
    "\n",
    "sd_means = weighted_score(sd_df)\n",
    "dd_means = weighted_score(dd_df)\n",
    "s_means = weighted_score(s_df, paired=False)\n",
    "\n",
    "def func(a, b, c):\n",
    "    return (a/b) * (a/c)\n",
    "\n",
    "accs = {}\n",
    "connectivity = {}\n",
    "\n",
    "\n",
    "temp_df = []\n",
    "for key in sd_means.keys():\n",
    "    for i in range(2):\n",
    "        if i == 0:\n",
    "            k = key\n",
    "        else:\n",
    "            k = (key[1], key[0])\n",
    "        accs[k] = s_t[k]\n",
    "        connectivity[k] = func(dd_means[key], sd_means[key], s_means[k[1]])\n",
    "        temp_df.append({'d1':k[0], 'd2': k[1], 'a': dd_means[key], 'b':sd_means[key], 'c_source':s_means[k[0]], 'c_target':s_means[k[1]], 'acc':accs[k]})\n",
    "temp_df = pd.DataFrame(temp_df)\n",
    "\n",
    "######\n",
    "temp_df = temp_df.sort_values('d2')\n",
    "domain_means = {}\n",
    "domain_mins = {}\n",
    "for domain in domains:\n",
    "    domain_means[domain] = temp_df[temp_df['d2'] == domain]['acc'].mean()\n",
    "    domain_mins[domain] = temp_df[temp_df['d2'] == domain]['acc'].min()\n",
    "\n",
    "for k in accs.keys():\n",
    "    domain_mean = domain_means[k[1]]\n",
    "    # accs[k] -= domain_mean\n",
    "    # print(accs[k], erm[(k[1], k[1])], erm[k], domain_mean)\n",
    "    # accs[k] -= erm[k]\n",
    "    # accs[k] = (100 - erm[k]) / (100 - accs[k])\n",
    "    # accs[k] = (100 - erm[(k[1], k[1])]) / (100 - accs[k])\n",
    "    accs[k] -= domain_mins[k[1]]\n",
    "\n",
    "# print(accs)\n",
    "######\n",
    "\n",
    "shapes = ['o', '^', 's', 'd']\n",
    "shapes = {k: shapes[i] for i, k in enumerate(domains)}\n",
    "accs_ls = np.asarray([accs[k] for k in accs.keys()])\n",
    "connectivity_ls = np.asarray([connectivity[k] for k in accs.keys()])\n",
    "for (d1, d2) in zip(temp_df['d1'], temp_df['d2']):\n",
    "    k = (d1, d2)\n",
    "    plt.scatter(connectivity[k], accs[k], label=f\"{k[0]}-{k[1]}\", marker=shapes[k[1]])\n",
    "\n",
    "m, b = np.polyfit(connectivity_ls, accs_ls, 1)\n",
    "x = np.linspace(min(connectivity_ls), max(connectivity_ls))\n",
    "y = m * x + b\n",
    "plt.plot(x, y, color='gray', linestyle='dashed')\n",
    "\n",
    "\n",
    "\n",
    "plt.xlabel('Connectivity')\n",
    "plt.ylabel('Target accuracy gain \\n(over worst pair with same target)')\n",
    "plt.legend(bbox_to_anchor=(1,1.15))\n",
    "r = pearsonr(connectivity_ls, accs_ls)[0]\n",
    "print(\"Pearson r:\", r)\n",
    "\n",
    "props = dict(boxstyle='round', facecolor='wheat', alpha=0.5)\n",
    "\n",
    "# place a text box in upper left in axes coords\n",
    "plt.text(1.05, 35, f'$r$ = {r:.2f}', fontsize=14, verticalalignment='top', bbox=props)\n",
    "plt.savefig('figures/trend_plot.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[78.46632762 78.88442227 61.65430758]\n",
      " [78.46632762 78.88442227 75.49446873]\n",
      " [77.10297614 66.03465624 75.49446873]\n",
      " [77.10297614 66.03465624 66.17521043]\n",
      " [81.85300879 76.81181029 75.49446873]\n",
      " [81.85300879 76.81181029 63.90732304]\n",
      " [81.92019075 75.85358468 61.65430758]\n",
      " [81.92019075 75.85358468 66.17521043]\n",
      " [71.44649861 68.48989319 61.65430758]\n",
      " [71.44649861 68.48989319 63.90732304]\n",
      " [72.60312029 68.8361324  66.17521043]\n",
      " [72.60312029 68.8361324  63.90732304]] [ 9.46  0.   14.37 35.79  1.14 20.73  5.83  7.25  0.    7.92  0.    0.  ]\n",
      "[ 2.43101038 -1.97873797 -0.53549216]\n"
     ]
    }
   ],
   "source": [
    "X = []\n",
    "y = []\n",
    "for key in sd_means.keys():\n",
    "    for i in range(2):\n",
    "        if i == 0:\n",
    "            k = key\n",
    "        else:\n",
    "            k = (key[1], key[0])\n",
    "        accs[k] = s_t[k]\n",
    "        X.append([dd_means[key], sd_means[key], s_means[k[1]]])\n",
    "        y.append(accs[k] - domain_mins[k[1]])\n",
    "        # y.append((100 - erm[(k[1], k[1])]) / (100 - accs[k]))\n",
    "\n",
    "X = np.asarray(X)\n",
    "y = np.asarray(y)\n",
    "print(X, y)\n",
    "theta = np.linalg.pinv(X.T @ X) @ X.T @ y\n",
    "print(theta)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# cells"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Get the off-limits classes for each domain\n",
    "# These numbers were selected visually by looking at the notebook `check_dataset_imbalance`\n",
    "size_cutoff = {\n",
    "    'real': 100,\n",
    "    'sketch': 100,\n",
    "    'painting': 100,\n",
    "    'clipart': 50\n",
    "}\n",
    "off_limits = {}\n",
    "for domain in domains:\n",
    "    domainnet_ds = domainnet.DomainNet(domain, split='train', version='sentry', verbose=False)\n",
    "    ys = [item[1] for item in domainnet_ds.data]\n",
    "    cntr = Counter(ys)\n",
    "    off = [cls for cls in cntr if cntr[cls] < size_cutoff[domain]]\n",
    "    off_limits[domain] = off"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** real **********\n",
      "Counter is: 92!\n",
      "********** sketch **********\n",
      "Counter is: 54!\n",
      "********** painting **********\n",
      "Counter is: 39!\n",
      "********** clipart **********\n",
      "Counter is: 67!\n"
     ]
    }
   ],
   "source": [
    "'''\n",
    "This is the same-domain-different-class connectivity.\n",
    "The counter number is more of a sanity check number: I ran 100 pairs, but we filter out the pairs that use\n",
    "small classes\n",
    "'''\n",
    "\n",
    "single_domain = {}\n",
    "for domain in domains:\n",
    "    print('*' * 10, domain, '*' * 10)\n",
    "    direct = os.path.join(single_base_dir, f'{domain}-sentry-swav-simclr')\n",
    "    counter = 0\n",
    "    data = []\n",
    "    for file_name in os.listdir(direct):\n",
    "        if file_name.endswith('-final'):\n",
    "            cls_1 = file_name.split('-')[1]\n",
    "            cls_2 = file_name.split('-')[2]\n",
    "            if (cls_1 in off_limits[domain]) or (cls_2 in off_limits[domain]):\n",
    "                continue\n",
    "            counter += 1\n",
    "            data_dict = torch.load(os.path.join(direct, file_name))\n",
    "            if len(data_dict['test_accs']) < 80:\n",
    "                print(file_name, len(data_dict['test_accs']))\n",
    "                continue\n",
    "            data.append(data_dict['test_accs'][-1])\n",
    "    single_domain[domain] = data\n",
    "    print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'real': 75.65397828434031,\n",
       " 'sketch': 60.656934301149306,\n",
       " 'painting': 65.46127543219825,\n",
       " 'clipart': 65.44953913915585}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "single_domain_means = { key: np.mean(val) for key, val in single_domain.items() }\n",
    "single_domain_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** real sketch **********\n",
      "Counter is: 26!\n",
      "********** real painting **********\n",
      "Counter is: 25!\n",
      "********** real clipart **********\n",
      "Counter is: 30!\n",
      "********** sketch painting **********\n",
      "Counter is: 17!\n",
      "********** sketch clipart **********\n",
      "Counter is: 22!\n",
      "********** painting clipart **********\n",
      "Counter is: 18!\n"
     ]
    }
   ],
   "source": [
    "'''\n",
    "Here, I ran 40 pairs (since there's 40 classes)\n",
    "'''\n",
    "\n",
    "same_class_diff_domains = {}\n",
    "for i in range(len(domains)):\n",
    "    for j in range(i + 1, len(domains)):\n",
    "        print('*' * 10, domains[i], domains[j], '*' * 10)\n",
    "        direct = os.path.join(between_base_dir, f'{domains[i]}-{domains[j]}-sentry-swav-simclr')\n",
    "        counter = 0\n",
    "        data = []\n",
    "        for file_name in os.listdir(direct):\n",
    "            if file_name.startswith('same-class') and file_name.endswith('-final'):\n",
    "                cls = file_name.split('-')[2]\n",
    "                if (cls in off_limits[domains[i]]) or (cls in off_limits[domains[j]]):\n",
    "                    continue\n",
    "                counter += 1\n",
    "                data_dict = torch.load(os.path.join(direct, file_name))\n",
    "                if len(data_dict['test_accs']) < 80:\n",
    "                    print(file_name, len(data_dict['test_accs']))\n",
    "                    continue\n",
    "                data.append(data_dict['test_accs'][-1])\n",
    "        key = tuple(sorted((domains[i], domains[j])))\n",
    "        same_class_diff_domains[key] = data\n",
    "        print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{('real', 'sketch'): 78.9339040419667,\n",
       " ('painting', 'real'): 67.00469841236831,\n",
       " ('clipart', 'real'): 80.13223494326954,\n",
       " ('painting', 'sketch'): 76.56445420040252,\n",
       " ('clipart', 'sketch'): 71.5583239364658,\n",
       " ('clipart', 'painting'): 71.27767696032544}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "same_class_diff_domains_means = { key: np.mean(val) for key, val in same_class_diff_domains.items() }\n",
    "same_class_diff_domains_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** real sketch **********\n",
      "Counter is: 31!\n",
      "********** real painting **********\n",
      "Counter is: 28!\n",
      "********** real clipart **********\n",
      "Counter is: 35!\n",
      "********** sketch painting **********\n",
      "Counter is: 18!\n",
      "********** sketch clipart **********\n",
      "Counter is: 23!\n",
      "********** painting clipart **********\n",
      "Counter is: 26!\n"
     ]
    }
   ],
   "source": [
    "'''Also ran 40 pairs here'''\n",
    "\n",
    "diff_class_diff_domains = {}\n",
    "for i in range(len(domains)):\n",
    "    for j in range(i + 1, len(domains)):\n",
    "        print('*'*10, domains[i], domains[j], '*'*10)\n",
    "        direct = os.path.join(between_base_dir, f'{domains[i]}-{domains[j]}-sentry-swav-simclr')\n",
    "        counter = 0\n",
    "        data = []\n",
    "        for file_name in os.listdir(direct):\n",
    "            if file_name.startswith('different-class') and file_name.endswith('-final'):\n",
    "                cls_1 = file_name.split('-')[2]\n",
    "                cls_2 = file_name.split('-')[3]\n",
    "                if (cls_1 in off_limits[domains[i]]) or (cls_2 in off_limits[domains[j]]):\n",
    "                    continue\n",
    "                counter += 1\n",
    "                data_dict = torch.load(os.path.join(direct, file_name))\n",
    "                if len(data_dict['test_accs']) < 80:\n",
    "                    print(file_name, len(data_dict['test_accs']))\n",
    "                    continue\n",
    "                data.append(data_dict['test_accs'][-1])\n",
    "        key = tuple(sorted((domains[i], domains[j])))\n",
    "        diff_class_diff_domains[key] = data\n",
    "        print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{('real', 'sketch'): 79.48053748722857,\n",
       " ('painting', 'real'): 70.58404931668227,\n",
       " ('clipart', 'real'): 80.93354774687705,\n",
       " ('painting', 'sketch'): 81.8920917110717,\n",
       " ('clipart', 'sketch'): 72.29423236024664,\n",
       " ('clipart', 'painting'): 71.28558046820616}"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diff_class_diff_domains_means = { key: np.mean(val) for key, val in diff_class_diff_domains.items() }\n",
    "diff_class_diff_domains_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "The connectivity ~ 1 - accuracy = error of domain classifier\n",
    "'''\n",
    "\n",
    "single_domain_conn = {key: 1 - value for key, value in single_domain_means.items()}\n",
    "same_class_diff_domains_conn = {key: 1 - value for key, value in same_class_diff_domains_means.items()}\n",
    "diff_class_diff_domains_conn = {key: 1 - value for key, value in diff_class_diff_domains_means.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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DodV/iZrDJmZma4bOogcWdatW8e5554bePmXV27mkYUb+OqbUk5v05KpI7s0aPxbDhRrf5jZCnfPrLmsxsBFpF4u63mGAvsIoSEUEZGQUoCLiISUAlxEJKQU4CIiIaUAFxEJKQW4iITOjBkzWLx48SGXWbZsGe+9917V6yeeeIJnnnkm0aUFsmnTJrp169bg7eg0QhEJnVhXTNa0bNkyTjjhBC644AIAbrrppoTUUl5eTrNmTROlOgIXkfpJwH1qN23axDnnnMM111zDueeey49//GP27t3LzJkzOf/88+nWrRsTJ06suoT++uuvJzc3F4jc+OHee+8lIyOD7t27s379ejZt2sQTTzzBo48+So8ePXj77bfJysqqmgRr0KBB3HnnnfTu3Zuzzz6bt99+G4C9e/dyxRVXcN5553H55ZfTp0+fmDdmePrppxkzZgxDhgxh6NChMae5rezXhRdeSEZGBhkZGQf8jyAeFOAiElwC71O7YcMGJk+ezLp16zjppJN4/PHHufnmm/noo49Yu3YtpaWl/O1vf4u5bvv27cnPz2fSpEnMmjWL1NRUbrrpJm677TYKCgqqZjesrry8nA8//JBf//rX3HfffQA8/vjjtG3blsLCQu6//35WrFhRa735+fnk5uby1ltvxZzmtqSkhA4dOrBo0SLy8/PJycnh5z//eYN/TtUpwEUkuATep7ZTp05V84lce+21vPPOOyxdupQ+ffrQvXt3lixZwscffxxz3R/+8IdAZIrYTZs2Bfq8WOu88847XHnllQB069btkFPDDh8+nJNPPhmITHP70EMP0aNHDwYNGlQ1zW1ZWRk33ngj3bt3Z9y4cRQWFgaqLSiNgYtIcAm8T23NO7KbGZMnTyYvL49OnTqRlZVV63Stxx13HPDdFLFB1GedefPmVR2lP/XUUwC0atWq6v3aprnNysrilFNOYdWqVXz77bckJycHqi0oHYGLSHAJvE/tF198wfvvvw/Ac889x4ABA4DI8MiePXuqxryDqjnFbBD9+/dn7tzIcFBhYSFr1qwB4PLLL6+acjYz86A5pWqd5nb37t2cdtppfO973+NPf/pT3O+vGfSmxm3MLNfM1pvZOjPrZ2Y9zGy5mRWYWZ6Z9Y5rZSJy5EngfWq7dOnCY489xrnnnsuuXbuYNGkSN954I926dWPkyJFVd8QJavTo0cyb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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = []\n",
    "y = []\n",
    "for d1 in domains:\n",
    "    for d2 in ['real']: #domains: # we probably should fix the target to reduce variance due to intrinsic difficulty\n",
    "        if d1 == d2:\n",
    "            continue\n",
    "\n",
    "        same_class_diff_domain = same_class_diff_domains_conn[tuple(sorted((d1, d2)))]\n",
    "        diff_class_diff_domain = diff_class_diff_domains_conn[tuple(sorted((d1, d2)))]\n",
    "        single_domain = single_domain_conn[d1]\n",
    "        \n",
    "        # this is the function we care about\n",
    "        func = same_class_diff_domain / single_domain\n",
    "        \n",
    "        x.append(func)\n",
    "#         y.append(all_domains[tuple((d1, d2))])\n",
    "        y.append(s_t[tuple((d1, d2))])\n",
    "        plt.scatter(x[-1], y[-1], label=f'{d1}-{d2}')\n",
    "plt.legend(bbox_to_anchor=(1, 1))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD4CAYAAAD1jb0+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAAA3jUlEQVR4nO3deVyU5f7/8dclIpAobmkYFeopXGAYEMglTcUt90rTtMzqaJ7y2PLV1Eolq5Ol36/LqX5lm3qOlmaZopbmQrkVoiAq4jEMS0XFBQIFHeD6/TEwB2SbcVhm4PN8PHwMc819X3NdM/rh9pp73rfSWiOEEML51KnuAQghhLg5UsCFEMJJSQEXQggnJQVcCCGclBRwIYRwUnWr8smaNWumfX19q/IphRDC6e3fv/+C1vrWG9urtID7+voSExNTlU8phBBOTyl1sqR2WUIRQggnJQVcCCGclBRwIYRwUlW6Bi6EqDwmk4lTp06RnZ1d3UMRN8nd3R0fHx9cXV2t2r7cAq6U8gNWFWpqDcwClue3+wLJwCNa68s2jlcIUUFOnTpFgwYN8PX1RSlV3cMRNtJac/HiRU6dOkWrVq2s2qfcAq61PgYYAZRSLsBpYC0wHdimtZ6rlJqef3/aTY7dIVyJPc+fm5PJTbuGSyM3GvbzpX5Q8+oelhBWyc7OluLtxJRSNG3alNTUVKv3sXUNPBxI0lqfBIYCy/LblwHDbOzLoVyJPU/aN8fJTbsGQG7aNdK+Oc6V2PPVPDIhrCfF27nZ+v7ZWsBHAV/k/9xCa52S//NZoEUpA5qglIpRSsXY8pulqv25ORltyivSpk15/Lk5uXoGJIQQ5bC6gCul6gFDgK9ufEybQ8VLDBbXWi/RWodorUNuvbXYF4kcRsGRt7XtQoiK5+vry4ULF6zaNioqikGDBlnd99KlSzlz5ky520yaNMnqPqubLUfgDwAHtNbn8u+fU0p5A+TfOvVag0sjN5vahRBl01qTl5dX/oZVxJoC7mxsKeCP8t/lE4D1wBP5Pz8BrKuoQVWHhv18Ua5FXw7lWoeG/XyrZ0BCVLJvY0/Tde52Wk3fSNe52/k29rTdfSYnJ+Pn58fYsWPx9/fnjTfeIDQ0FIPBwOzZsy3bDRs2jI4dO9KhQweWLFlSbr8//vgjRqMRo9FIUFAQGRkZRR7ft28fQUFBJCUlsX//fu6//346duxIv379SElJYc2aNcTExDBmzBiMRiNZWVns27ePLl26EBgYSFhYmKXPM2fO0L9/f+6++25efvllu1+TSqW1LvcPUB+4CHgVamsKbAOOA1uBJuX107FjR+3IMg+c02fe/kX/Me0nfebtX3TmgXPVPSQhrJaQkGD1tmsPnNJtX/tO3zVtg+VP29e+02sPnLJrDL/99ptWSum9e/fqzZs36/Hjx+u8vDydm5urBw4cqH/88UettdYXL17UWmt99epV3aFDB33hwgWttdZ33XWXTk1NLdbvoEGD9K5du7TWWmdkZGiTyaR37NihBw4cqHfv3q2Dg4P1yZMn9fXr13Xnzp31+fPntdZaf/nll/rJJ5/UWmt9//3363379mmttb527Zpu1aqVjo6O1lprnZ6erk0mk/788891q1atdFpams7KytJ33nmn/v333+16TWxV0vsIxOgSaqpVX+TRWl/JL9iF2y5iPiulxqgf1FxOGxS1wrzNx8gy5RZpyzLlMm/zMYYF3W5X33fddRedOnViypQpbNmyhaCgIAAyMzM5fvw43bt3Z/HixaxduxaAP/74g+PHj9O0adNS++zatSsvvfQSY8aM4aGHHsLHxweAo0ePMmHCBLZs2ULLli05fPgwhw8fpk+fPgDk5ubi7e1drL9jx47h7e1NaGgoAA0bNrQ8Fh4ejpeXFwDt27fn5MmT3HHHHXa9JpVFvokpRC10Ji3LpnZb1K9fHzD/737GjBk888wzRR6Piopi69at7N27l1tuuYUePXoU+/bo+++/z8cffwzApk2bmD59OgMHDmTTpk107dqVzZs3A+Dt7U12djaxsbG0bNkSrTUdOnRg7969Nz1+N7f/fu7l4uJCTk7OTfdV2SQLRYhaqGUjD5vab0a/fv347LPPyMzMBOD06dOcP3+e9PR0GjduzC233EJiYiI///xzsX2fe+454uLiiIuLo2XLliQlJREQEMC0adMIDQ0lMTERgEaNGrFx40ZmzJhBVFQUfn5+pKamWgq4yWTiyJEjADRo0MCyzu3n50dKSgr79u0DICMjw6ELdWmkgAtRC03t54eHq0uRNg9XF6b286uw5+jbty+jR4+mc+fOBAQEMHz4cDIyMujfvz85OTm0a9eO6dOn06lTp3L7WrhwIf7+/hgMBlxdXXnggQcsj7Vo0YINGzbw3HPPERsb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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = []\n",
    "y = []\n",
    "for d1 in domains:\n",
    "    for d2 in domains:\n",
    "        if d1 == d2:\n",
    "            continue\n",
    "        across = same_class_diff_domains_means[tuple(sorted((d1, d2)))]\n",
    "        between = single_class_means[d1]\n",
    "        func = across / between\n",
    "        x.append(func)\n",
    "        y.append(s_t[tuple((d1, d2))])\n",
    "        plt.scatter(x[-1], y[-1], label=f'{d1}-{d2}')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x, y)\n",
    "plt.xlabel('Distinguishability of source and target (same class)')\n",
    "plt.ylabel('Target Accuracy')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "x axis: (average same-class-diff-domain) / (average source-domain-diff-class)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Below this is BREEDS stuff, unrelated"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Look at the BREEDS stuff\n",
    "result = torch.load('' + \\\n",
    "                    'data_selection/breeds/living17-living17-sentry-swav-simclr/result-final',\n",
    "                    map_location='cpu')\n",
    "plt.plot(result['test_accs'])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "single_base_dir = 'connectivity_checkpoints/single-domain/breeds'\n",
    "between_base_dir = 'connectivity_checkpoints/between-domains/breeds'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** living17 **********\n",
      "Counter is: 17!\n",
      "********** living17 **********\n",
      "Counter is: 17!\n",
      "********** entity30 **********\n",
      "classes-7-29-final 20\n",
      "classes-4-19-final 20\n",
      "classes-0-26-final 20\n",
      "classes-13-25-final 20\n",
      "classes-18-22-final 20\n",
      "classes-24-29-final 20\n",
      "classes-23-24-final 20\n",
      "classes-9-17-final 20\n",
      "classes-12-29-final 20\n",
      "Counter is: 30!\n",
      "********** entity30 **********\n",
      "Counter is: 12!\n"
     ]
    }
   ],
   "source": [
    "single_class = {}\n",
    "for domain in ['living17', 'entity30']:\n",
    "    for split in ['source', 'target']:\n",
    "        print('*' * 10, domain, '*' * 10)\n",
    "        direct = os.path.join(single_base_dir, f'{domain}-{split}-swav-simclr')\n",
    "        counter = 0\n",
    "        data = []\n",
    "        for file_name in os.listdir(direct):\n",
    "            if file_name.endswith('-final') and 'save-model' not in file_name:\n",
    "                counter += 1\n",
    "                data_dict = torch.load(os.path.join(direct, file_name), map_location='cpu')\n",
    "                if len(data_dict['test_accs']) < 100:\n",
    "                    print(file_name, len(data_dict['test_accs']))\n",
    "                    continue\n",
    "                data.append(data_dict['test_accs'][-1])\n",
    "        single_class[(domain, split)] = data\n",
    "        print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{('living17', 'source'): 79.29411560058594,\n",
       " ('living17', 'target'): 77.44117428050322,\n",
       " ('entity30', 'source'): 81.60714031401135,\n",
       " ('entity30', 'target'): 83.52083063761394}"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "single_class_means = { key: np.mean(val) for key, val in single_class.items() }\n",
    "single_class_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** living17 **********\n",
      "Counter is: 17!\n",
      "********** entity30 **********\n",
      "Counter is: 30!\n"
     ]
    }
   ],
   "source": [
    "same_class_diff_domains = {}\n",
    "for domain in ['living17', 'entity30']:\n",
    "    print('*' * 10, domain, '*' * 10)\n",
    "    direct = os.path.join(between_base_dir, f'{domain}-{domain}-sentry-swav-simclr')\n",
    "    counter = 0\n",
    "    data = []\n",
    "    for file_name in os.listdir(direct):\n",
    "        if file_name.startswith('same-class') and file_name.endswith('-final') and 'save-model' not in file_name:\n",
    "            counter += 1\n",
    "            data_dict = torch.load(os.path.join(direct, file_name), map_location='cpu')\n",
    "            if len(data_dict['test_accs']) < 100:\n",
    "                print(file_name, len(data_dict['test_accs']))\n",
    "                continue\n",
    "            data.append(data_dict['test_accs'][-1])\n",
    "    same_class_diff_domains[domain] = data\n",
    "    print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'living17': 63.41176217471851, 'entity30': 60.76666447448731}"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "same_class_diff_domains_means = { key: np.mean(val) for key, val in same_class_diff_domains.items() }\n",
    "same_class_diff_domains_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "********** living17 **********\n",
      "Counter is: 17!\n",
      "********** entity30 **********\n",
      "Counter is: 2!\n"
     ]
    }
   ],
   "source": [
    "diff_class_diff_domains = {}\n",
    "for domain in ['living17', 'entity30']:\n",
    "    print('*'*10, domain, '*'*10)\n",
    "    direct = os.path.join(between_base_dir, f'{domain}-{domain}-sentry-swav-simclr')\n",
    "    counter = 0\n",
    "    data = []\n",
    "    for file_name in os.listdir(direct):\n",
    "        if file_name.startswith('different-class') and file_name.endswith('-final') and 'save-model' not in file_name:\n",
    "            counter += 1\n",
    "            data_dict = torch.load(os.path.join(direct, file_name), map_location='cpu')\n",
    "            if len(data_dict['test_accs']) < 100:\n",
    "                print(file_name, len(data_dict['test_accs']))\n",
    "                continue\n",
    "            data.append(data_dict['test_accs'][-1])\n",
    "    diff_class_diff_domains[domain] = data\n",
    "    print(f'Counter is: {counter}!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/python3.8/site-packages/numpy/core/fromnumeric.py:3440: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/python3.8/site-packages/numpy/core/_methods.py:189: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'living17': 79.9999979355756, 'entity30': nan}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diff_class_diff_domains_means = { key: np.mean(val) for key, val in diff_class_diff_domains.items() }\n",
    "diff_class_diff_domains_means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
