{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "470ca150-469d-4674-86f0-8db1d4241971",
   "metadata": {},
   "outputs": [],
   "source": [
    "from hypnettorch.data.special.regression1d_data import ToyRegression\n",
    "from hypnettorch.utils import misc\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.datasets import make_moons\n",
    "from sklearn.gaussian_process.kernels import RBF\n",
    "import sys\n",
    "from time import time\n",
    "import torch\n",
    "\n",
    "# Pretend that notebook is located in base directory of this repo.\n",
    "curr_dir = os.path.basename(os.path.abspath(os.curdir))\n",
    "base_dir = os.path.abspath('../..')\n",
    "if curr_dir == 'nngp' and base_dir != sys.path[0]:\n",
    "    sys.path.insert(0, base_dir)\n",
    "\n",
    "from nngp import MLPKernel\n",
    "\n",
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "device = 'cpu'\n",
    "\n",
    "ts, lw, ms = 15, 8, 140 # text fontsize, line width, marker size\n",
    "figsize = (12, 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "57e552b3-9dda-4a84-9d90-ef2aa1c98fcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_kernels(data, config_dict):\n",
    "    # Compute kernel matrices.\n",
    "    for k in config_dict:\n",
    "        start = time()\n",
    "        if k['name'] == 'rbf':\n",
    "            rbf_kernel = RBF()\n",
    "            K = rbf_kernel(data.detach().cpu().numpy())\n",
    "        else:\n",
    "            mlp_kernel = MLPKernel(sigma2_w=1., sigma2_b=1., **k['params'])\n",
    "            if k['name'].startswith('analytic'):\n",
    "                K = mlp_kernel.kernel_analytic(data, **k['kernel_params']).numpy() \n",
    "            elif k['name'].startswith('efficient'):\n",
    "                K = mlp_kernel.kernel_efficient(data, **k['kernel_params']).numpy()\n",
    "            else:\n",
    "                K = mlp_kernel.kernel_mc(data, **k['kernel_params']).numpy() \n",
    "        k['kernel'] = K\n",
    "        print('Kernel \"%s\" computation took %f seconds.' % (k['name'], time()-start))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "84d2a7b0-62df-4fbf-ad5a-ee851262e094",
   "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": [
    "X, Y = make_moons(n_samples=100, shuffle=True, noise=.1, random_state=42)\n",
    "\n",
    "plt.title('Two Moons')\n",
    "plt.scatter(X[:,0], X[:,1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d6bce34e-45ca-4d56-806c-c88f6019e981",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kernel \"rbf\" computation took 0.000413 seconds.\n",
      "Kernel \"analytic_relu_1l\" computation took 0.001001 seconds.\n",
      "Kernel \"analytic_relu_2l\" computation took 0.000459 seconds.\n",
      "Kernel \"tanh_1l\" computation took 1.699099 seconds.\n",
      "Kernel \"tanh_2l\" computation took 3.131495 seconds.\n"
     ]
    }
   ],
   "source": [
    "kernels = [\n",
    "    ######################\n",
    "    ### Common Kernels ###\n",
    "    ######################\n",
    "    {'name': 'rbf', 'plot_lbl': 'RBF'},\n",
    "    ####################\n",
    "    ### NNGP Kernels ###\n",
    "    ####################\n",
    "    ### Relu ###\n",
    "    {'name': 'analytic_relu_1l', 'params': {'n_layer': 1, 'nonlinearity': torch.nn.ReLU()},\n",
    "     'kernel_params': {}, 'plot_lbl': 'ReLU 1-layer'},\n",
    "    {'name': 'analytic_relu_2l', 'params': {'n_layer': 2, 'nonlinearity': torch.nn.ReLU()},\n",
    "     'kernel_params': {}, 'plot_lbl': 'ReLU 2-layer'},\n",
    "    ### Tanh ###\n",
    "    {'name': 'tanh_1l', 'params': {'n_layer': 1, 'nonlinearity': torch.nn.Tanh()},\n",
    "     'kernel_params': {'num_samples': 100000}, 'plot_lbl': 'Tanh 1-layer'},\n",
    "    {'name': 'tanh_2l', 'params': {'n_layer': 2, 'nonlinearity': torch.nn.Tanh()},\n",
    "     'kernel_params': {'num_samples': 100000}, 'plot_lbl': 'Tanh 2-layer'},\n",
    "]\n",
    "\n",
    "X_moon = torch.Tensor(X).to(device)\n",
    "kernels_moon = [dict(k) for k in kernels]\n",
    "compute_kernels(X_moon, kernels_moon)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "bee49af6-a6bd-4fd7-ad7d-28fbc8376b3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAysAAAG/CAYAAABYP0ggAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACxPUlEQVR4nOzdeZwcVbk38N+pXpLMvs9kspCEhAQkLLKIiIoLuwpIZOdCSBBB4Ub27QIqhD0sUSEkEHhVFg1ClAgEFK4KVwVXBBIwC4Ess/esSWam67x/1NJV1VXdVT093T0zv+/9eMl0V1ed7umZOU8/53mOkFKCiIiIiIio0Cj5HgAREREREZEbBitERERERFSQGKwQEREREVFBYrBCREREREQFicEKEREREREVJAYrRERERERUkBispCCEmCeEeEMI0SaE2CWEWC+EuEEIEc332IiIiIiIRrtwvgdQ4KoBvArgLgAxAIcCuBlAA4Dv5G1URERERERjgOCmkMEIIW4F8G0AlZIvHhERERHRsOEysODaAHAZGBERERHRMOMyMB+EECEA4wB8EsClAB50y6oIIVJmWqSUYnhGSEREREQ0+nAZmA9CiF3QghUA+H8A5kspVZfjGKwQEREREWUJgxUfhBCfBFAErcD+RgBPSCkvdjku0It50EEHZWeAREREREQWf/3rX1ullLX5HsdQMVgJSAjxXwAeBzBTSrnBcV+gF5OvPRERERENByHEX6WUB+d7HEPFAvvg/qb/d7rzDimlSPW/HI+TiIiIiGhEY7AS3Gf0/27K6yiIiIiIiEY5dgNLQQjxIoBXALwDIA4tULkcwNPOJWBERERERJRdDFZSexPAeQCmARgEsBHAtQAeyt+QiIiIiIjGBhbY55CzAJ+vPRERERENBxbYExERERERDSMGK0REREREVJAYrBARERERUUFisEJERERERAWJwQoRERERERUkBitERERERFSQGKwQEREREVFBYrBCREREREQFicEKEREREREVJAYrRERERERUkBisEBERERFRQWKwQkREREREBYnBChERERERFSQGK0REREREVJAYrBARERERUUFisEJERERERAWJwQoRERERERUkBitERERERFSQGKwQEREREVFBYrBCREREREQFicEKEREREREVJAYrRERERERUkBisUE71N2/E5uvm4v3zo9h83Vz0N2/M95BcjZRxEhEREY1mDFYop7bddyL6t68D1Dj6t6/DtvtOzPeQXI2UcRIRERGNZgxWKKf6d6wHpKp9IVXt6wI0UsZJRERENJoxWKGcijbMBoT+thOK9nUBGinjJCIiIhrNGKxQTjUuWo3oxDmAEkJ04hw0Llqd8vhUtSPDWVcSdJxERERElH1CSpnvMYwZQgjbi83XPr3N183VakekqmU4Js7BtMVvp73Pqr95o1aDsmM9og2ztUCkbkaunwoRERFRzggh/iqlPDjf4xgqZlaooKWqHfFbV+KnWJ7dv4iIiIgKD4MVKmipakf81pX4CWrY/YuIiIio8DBYoYKWqnbEb12Jn6CG3b+IiIiICg9rVnKINSv50fvea9h6z3HAYD8QjmLS5S+geO8jbcf4rX8hIiIiGglYs0I0QrT85BIgPqh9ER/UvnZg9y8iIiKiwhPO9wCIhpufJV7RuhnMpBAREREVGGZWaFTrb94IKKHEDdzgkYiIiGjEYLBCo9q2+04EBgcSN4TCw7rEiy2QiYiIiLKHwQplXSYT9uGa5GtLviyNDNT4sG4IyRbIRERERNnDYIWyLpMJ+3BN8v3uxZItbIFMRERElD0MViilVBkPr/v8TNiTHrt9eCb52ejyFSTrk+vgiIiIiGg04z4rOTQS91lJtf+I131+9ixxHoNQWGsvXID7nATZg6W/eaOWJdqxHtGG2VqwNIzLzoiIiIjcjJZ9Vti6mFJKlSXxuq9x0eqkCXu68yI+iOjEOSkf4zq+HAQHQZZ25bIFMgMjIiIiGu0YrJDJdfLbMNueVbAsa/K6z8+EPemxATIp1nFCCZkZGaPWJdvBQqrXIJ/MOp9hfO5ERERE+cSaFTK5Fbmnqvlwuy9dfYdxf//2dYn9T6QKOdgfoGvYJ9C/7V1AjQOD/cNe0F6ou9snZXy2r2PbZCIiIhpVWLOSQ4Ves/L++VEtADAoIez1aH+gc6Sr79h83Vz0b3sPtnbCgO/sivb4d93vLLBal+E2kup+iIiIKLdGS80KMytkykYnq3T1HUn7nhh8ZkVcjwlHs571GAmbOzozPojH2TaZiIiIRhUGK2RqXLQakVq9QDvA0iyrdAGPZwDkIzjqb96YWDpmCEcxbfE72OvRfkxb/HbWCsxHwuaORm2Q+dwnsm0yERERjS4MVsgUrZsBEY6aE96Blo1Jk/R0GYd0dSxysB8IRZKv7SMrsu2+E4HBgcQNeqBiDVCylREZyuaO+crKFGptDREREVGmWLOSQ4VeswKkr1sJsueI12MitVpQFLTlrp+amkzG52fMQc6TrTG4Gentikf6+ImIiEYK1qzQqJRuGVdSxmHbu2kzCM7HDDT/B42LVgdeuuWnpiZoRsQrCzKULMVQsjLpjITlaamM9PETERFRbjFYIZt0k3RbwGBIM/F0CyoymaT6CSCCNgnwmjwn1YN4BFRuwU42GhV4ydbytE1Xzcamq2bnfKnacAZyRERENPpwGVgOjYRlYOnYNmS0LskCPFsd9zdvxOarZvk6Npvj81pmlMlz8GJb8qWL1M0EAAy0bsr6UqesLU+zcjnPcC3XGs4lckRERJTAZWA0JlkzDtHGfXxlEKJ1M3wfm4qfwnVnRgRA0mOs2RSbDMZlyxToBlo2QoSjWe9QBmRxeZqVS4ZjuJZrsQkAERERBcHMSg6NhsyKVbpP3633R2qmAxhatiEbxf3RiXM8MyqZjMszWzFMmaOhCJJZSWpmAGDanR+wGJ6IiGiEGC2ZFQYrOTTagpV0sr3kx083MD+PiTbMztq4zIBs27uJGzM853B3ygoSPG6+bq79OQGINu7DJVtEREQjxGgJVsL5HgCNXtkupk4KMnws2XJ7TOOi1UlBgTnm5o3YevdxGGj+j3aDEgbUQQBaLcqkK16wTeqNZWdugYZTumDEXHolVXPpVTaDA2OsfjQuWp1UZ8RieCIiIso1ZlZyiJmVoWVWMsk8BH2MW0bBaijZhXSvRyaZo+HEYngiIqKRi5kVojRSZTAy4TczMJTlVGn3Zckgu+C6VMwl05RJ5igbvF6vbH//iIiIiIJiZiWHRnNmpZB2Jh9ye1+fmRW/z9m1sD1Nu+BsNCTwa6RnUArpvUdERFQoRktmhcFKDo3mYKWQJrxDWU5l1Ky0tXZjbckN6FQmoVzdiqN7bkF1TamtZsXPc3bdYwYAwlFMuvwFFO99pOs47AGOAMIRQI1nfTKeyz1whkshvfeIiIgKxWgJVrjPCmWF32L6ttZe3H37a7j68jW4+/bX0NbaO/RrG/uvzI/g/YUT7IGKvpzKzx4t5kPCUawtuQExZRKkCCGmTMLakhsw/c719tbMPp6z5/4k8UG0/OQSz+fSv+1dSyZGAoP9Wd/zxGt8uVp+li1J34dt76b8/hIREdHIwWCFsiLaMNvXpo8rV7yJluYeSFWipbkHK1e8OeRrW7toYdCeEYhOnIPac5Zi83Wf0AIAlwl/73uv4f2FE/D+eSFsvmoW+re9i05lEiBC+vMJoTM0OSngidRMT/ucPWtcUgQ3/dvXeT/ZLHRVs3I710irTXF73bMZ0BEREVH+MFihrPC7M3lLSy+M1W9Sal8b3LIfqTIxxn0P9t2CVaX3o0upt19MCWHa4rfxn8dvxKqie/BIxS+xqmwpukStbZK+9e5jk4KccnUrILUMjYCK2prxSbu6A0j7nG1BnJVLcNPfvNGRUdGFo7agKFIz3XeWKJ2kILNxH9clZkEyU7nm2iaabZaJiIhGBQYrlBVGp669Hu3HtMVve9ZU1NYWQwjt30JoXxucwcC2+05MmYkx77Ms1TJZgoE1facnLemyBQrxAXQp9VhVttQMaA7vfQgV6lYIGUdtfRnmX/iZpOVGA62b0j5nM4gTChCKmLdHamfoGZ9EALD17uOSX7BwFNMWv2MLigAkvU6Z8htkun1vCkW0bgaijfv4yuwRERHRyMJghXJq/sJDUFtXAqEI1NaVYP7CQ8z7kmoPtq9DS1OXZybGmqWBCGlLt8JRQNgn3rHQZNuSrpgyCf3b19syBM4alTeKv4V5XZdgQfdpuOKaI1FdU6xPgEXiySihtBkGI4iLTpyTqKURCkQ4iuaVFyaWpm17N7ERpdXgYFKnq4HWTVnbbNNvkJntDT6zzW/QRURERCML91mhnKquKcYV1xwJQG85u+QwtOkT8UjNdAy0bDS7OiEURnn8Y8T0+hEBFbW1Zea5amuLtcyK1LM09eXY65qdtuvtWL8OgIB5kJRQEAdkIkMQrt4DnXFHjYoySft3fNA8V+Oi1dh83ScSS8big753mXed7FsbAXgJh5N2tc/Hfiz52gPGL7978BAREdHIwmCFsq6ttVdbotXSi9raYsxfeAiqa7TlXuaeGI59R1qbOvBy2c2IVdShPP4xThj3E0xo+QuO7rnF1kJ4/sJzzcfMX3hI0nWcVi57HZB1sK49k1IPSvSgYdrt61Bx+6voUGu0gEXGtZoVQGsZrIvWzbAHGC4ZBq/n7jbZd9vPJVI3M5FhCUXstTR6wBKpnWG+dpHaGSmzCEYrZuOckbqZmHTFCwAQaG+SdBtEFupeJ4U6LiIiIvKH+6zk0EjcZyVV4GHe19yDCrkDR3XeiDK1Cc9ULkNMNCQyHnUlZjbFdYNEAKvKliYyKAKoQBNOaf+m7Rjrhox+Xb1oNaSRMQEAKVGhfoR5XZfY9uRoa+3FymWvo6Vlp7mvSpnaBIgQqu/qMF8D7XnehLL4dtc9Pe6+/TV7tkd/7m6TZmsQAWiBxPQ713u/Tnq2CfFB33uKuG1yGW3cBwCyujdJrvc6yWhDTu7BQkREY8ho2WeFmRVKySxilzAL3I3Aw3pfh6zF2pIbMK/rEsRkLYwwLKnjl74cqkupt2VMrK2CpQRisiZpLEadiXVimiqYAoAKpdWSMZFQxCBOKHoK6AnZMgTVNcWY13s5+mOOif3E2bbnGRP1eLn8ezgldpFrhsGr25nbMqVJV7zgma2wLRszxzIH/dsTt3eJWqztuQidlz1v1v9Yn7t5nqTXcZ2+JC59DYrfoCDXNS3W7JyxPM4tCCn0WhsiIiJKjcEKmdwm/qlaDbsWuENr++tVZ7Kz7jC9O9cU/XECMWUSFKiACGkZCaiJZVhWep3Je0vOw8sV30dLSy8UAaiqdA2mAGD+hZ/BymWvI6bWoEJpxfwLP4OG2b93ff5ee4603PGe7TWIKQ2eO7wn1dHUFrseB6Sus0haNqZnBKyZEqMpAPTnvuKhPyMUVmzfv0jN9OTC/VAY0bqZycvSXAITP0FBf/NGQAnZGggMd02L3yAkW7U2XE5GRESUH+wGRia3NsGpWg1b7zPqPLqUesQRAqAAUqI0vsOsJelv3ojf7P4vPZARljqSEFSEUYZWCAGUxz/G0T23uI6xS9TiyV2L0NykjTMel67BlLEvSNcd++GM8ffhB9fNxbVLFqBh9hzP5++150iq18BgXO/ID85BBZrMJWBudTR+eHW3smZfnNmotrY+rXuaKtHS1KXV67iJx13P79ae2LYUTQ9YnLbddyIwOJC4IRQ2xzlc+7P43YQ0W13CCrl1MxER0WjGmpUcKvSalasvXwOp2sd04cWH4dln/m1+Wn/yKfuaX1dVTgAE0N7Whwq5HUd13pT4tF8vVK9UWvHN607XAqGmLkhpCVKs9FqSM0seBGCvpzCXPSn1WFX2Q6iI2M+hpzGEAKqqirTsQlOXGfSUyRZftQrWT8931h2Gl0tvQEv7QOJ5tu90XWoG2GsjukIT8XL59xATDZ7HD4VxrVWl99vqfLT3U+J1EVCxoHNeUtcxr9qf98+P2o9VQtr/rEX+4Sj2WrEz7eOMzNNw1YzkOtOR6jkSEREVItas0KhTW1uM5qYe223PPvNv27IqawF5W1sfQiEj+FAAodg+7YcIIYZ6rFzxpn5eBYBMtBG2EgKdyiSzO5d1Itq/bR0AFWtLbnANVBQMQMoQKkQrIKZr44NibgA5r+sSX7UK1mVZ1ufZ3t6HCjRhQewiRMfNRqm6GoB9YmzNQKwtvg4xtQYQ0nVp2lC0tfZiVfE9aKnYhZL4dpQrHehCDWrrSrBr2/voUuptHc201+89wKgiCkc9swuuHcu2O163eHK7ZdfHGcGEtbhfqmhtimHV7a951hj5NRytilMFQIXeupmIiGi0YrBCpvkLD8Edt75qu81ao2J8bU0IxePaFx2yBmuLr7PXq+hLoWzn0Pc6SQQsejbAMrl2TkSNT+c7jeVjBj1Qmdf1Ha1zlxLCI+JZ1zoaqHGzOL9bqTdrc7yyJs5anZissS0BMsZn1Pk0l6+CgjgkQpBQzHE663yGauWKN9HS1g8JBT3hSaitK8Ederexf11/LtZOuNpsWnBC0VO2lsNmtuiO91BVuTnpeTuP/VXxDWip2OXIUCVP0t3aGpvLpqyEgpfLb0bMo2FDvqWqz0nXupmIiIiGB4OVMcjrE+TqmmLU1ZekLBC3FpDb6IHBN7ou0rp8hSajqqoE8biatLTMDFgAhEICaly1Ta6djIliaU8TupSJls0dBzGv+1K9xbD2aXdtmaXAHSpK1B1YVbZUm8D3bMUJRnG+JTtksE6ebc/Tuu+Ko5jbqPOBCEGVSlIwlq7IPiivhgfb7jsRZQNbMW/gEvPYyPiZAOCaLdKetxYoGvUtV1x/tO1YIxsWC03BqrIf4ozx92HaoseSxuQMLvubN7ruIROdOAexXfWeDRvyLVXRPjedJCIiyg8W2I8hRrHz5qtmaZNJl2Lhs09u0ArEZRwVaMLZJzfYzjF/4SGorSuBUARCIQDQJncCKipEC8rQijPG349vRa5EvHkd2luty8qMWaqKCvUjXBS5HBdGr8WCznk4s+RB7H3ZY651B8ZEUcIe9BSrzaipr7QVT1vHV1tfBgGt25gUIcSUSVjTd3pSdsgcnQSam3u0iXpzDxRFy44oQqJTmYRVZUvRFZpoWwJk74hmqcIX0MZgKbJva+3F3be/hqsvX4O7b38Nba32iXq6+wF4FvtrE2v7kxpo2Wj73iY/bz37AwUtrbtsj7UHEQKqiOI3/edi8zVz0hbKuxWfG3UytXUlaZsVZFOQAn+/RfvZvi4RERF5Y4F9DuW7wN5rQ8ZMC6L/ec3nsKbvdNuyo/1v/715jkfKVyVtyGi0JU5suqj4Lr6++ru/0pZY6QRU3HHv15KOs7ZglqoKZ9F5bX2Za3ZICEBRhLm0LYlUUam04PJrvmAGVdZshZGpEFBRWzMeV1x/tG081nog52aZznO53e98btZla36+t7axGk9eaEvwFMQhQ+PMc65c9jqaW3fbXzsZx4LY19N+r5KK0aFteDnpihdsS/Cy1Xwg1V47Qd7P2Sza52aURESUbyywpxHHbaNBAIAax/vnhYBQRJtk+txEb0LznzBP1drjdin1WIMb8MTla1A+cBGOFrck1a9UiGac0vGtRJcv/RrWa6WaMNbWjEdL6y4tYNGXZjk3iQTsm1Vqk217EDF/4SGeNSstzfYGAzZCQUw02DakjA+q5rxfCSmQqkRtXVlSNsUZABlZHCvnEq/mph5cffkaX93IzJoK6/IrR3bA+rxL1VYg3q8V5ENAFRHA0rL6qO5b8KRclGhoIFXXpXCu3y9nUT8SWZ5pi98OVKPiJ4Bwblz68OKnzE07rZtoWt9jW+8+ztx/xgiksrnUi5tREhERZQczKzlUsJkVJ5/ZDuv5VpUtRWdoMiQULXuiF2Vbd6k/YdxPUCbaMdC6CdGG2ZCD/Rho2Wi7FgDPT6TNT9AdbYl31n8aL1d8H81NPVAwCFWG3Nsj66prirDwwk+ZE/4NH7RixbI/6wGF1GMb98eHQgKq1JYvxeMq2tv6UmZCErUf7ue67e4TfB1r8LqOIdVE3HnctvtOxBM9FyEWmgJbBkURWNBxMrpQY37/StQdEBDoVupds2jW71fjotXYfN0n7C2PgYza/frJUCS13JYSp3ZdiDLZAoTCQHww+T3mqKnxauecKWZWiIgo30ZLZoU1K2OIbYO8xn0SLYYd/G6iZz2fEagAWg1EZ2gyytCKeX2XY0HnPMzrugQTWt+CCEex16P9mLb4bW0SrT8+UjsDnQMleKLnIjxSvkqrDxG1tk+kq2uKccU1R5rnK1ObAKlqdShNXQCQCFT0QFAILSiwamvtw8oVb5pfL3/oz4nMR5r4UVWluWlmW6t7sbtVqgLyeFzaalS+9OWZqS8Oe12NW21LtG4GRDhqZq6cdSvW46YtfhudkT1gDVQALRCLNsxGmWzBvK5LsKBzHsKhELpDDZBC+16/XHoDAPcMQrRuRtIyMAAZ1YD4yVC41b2sLblBe1x8MOn97HaObGc+srUZJRER0VjHZWBjiHOZy6arZpufwJvCUd+fAFvPV5tUb1GGve7t1+oXfHRY2nzdXKzpOcdcNhZTJuGFkpsQDocRu3wNaqsiOCp2Eya0/CVpHJ3KpEQti7V6W0qUxLehO9QI54S8uUmb8M9feAhU66fyqTIqqrQFJ1pgo31yLqCiQrbg/fOjtuVKtbXFaN7Rqe99Yt9fRlFgZlKam3rw9JP/TP+iQ4WiDmobbEJxbf8bZAmSbW8dKaGIOM4+uQFVlZb2w0oIMVkLKRLBaEu7tmO91/4j6fZ38VsfYjs/YGtBbRyf1HJb37PHK6Ohje3dpNuyid3DiIiIsoPLwHIo38vAnNyClUlX/xbFex8Z6Dxtrb1Y8dCfzTbA1mVWzuUw5pKt5h4oAlD1OWhZfBu6lXp7Qb6xBwsAQEVF/GPM67oETqvKlppBjhkQyDgq9BqLmDLFNQgxllQlLb1y7AFTV19i1nvYjjU2pERIaxrQuxhl8e22SXJbay8eXvwUOtS6lEvT/JEQcgDSsTGmUATuuCexnMz6mneFJuLFslvQhRoAie8NoNV6NDf3QJGDkFKYz6GmvtKcaBtNFGLKFPNFM5oUXKHv77LtvhPR2tSBtcXXo1NpRIXSinNOm47B1f/tGYz4XSblurmk5X1kFNXbluTpyxDn9V2OLlmj7e2CerMzW6na5GupXNIYslB4T0RElCujZRkYg5UcKrRgJalrUwY1BYB7rYURCJx9cgN2Pf4Nc6K3qvgebVPDpKcuocgBqAjpy9PMfsCWQyQq1I8SncR0XUo91pbcgJgyydyY0eg49ouyBx0BkJ1QBMrLxyHWYbTutQZImluu3UefkMfw87If2+4XMo4FnfNSduHqb96Ie25/FR1qjW2zzHT1Ka6sXbx01dVFuPqGL5pfWyfXPy9/2AxUrMeHwoptH5kK/fUyalRqG8oxf+EhWPb9x+2BIIAK9SNceOO5Zs1PW2sv7rr1ZcsSPK1r2rVLFiQN31lT4/Z6uXG+V1eVLUVneKoZV5bKFijxnehUJqFCtOD48COY0PoWVpXen7RJadBNKDdfN1cPxq7Tzq+04pvXnT7kLma5wECLiGjsGi3BCpeBjWFeS3iCcqvLMDoz/fTZHbjCUiDfbF2uY6N1pCqLb0dXaKJ5m+2EQiCmTMGLJTfj1K6LsLP2UKzZ/V/oVBpRrm7Fqd3fNrMC/7zmc1iDG/TOYYkNGhUlsZzL2OfDnjWxByqhkDCXQ5VJFRXxj+yNBNStiE6cg86BEqzZfY6tjbP5OtfNwDevS27Zu2LZn9HWmtiUsqJyPEKKYtuo0vEKQUIkZ2j0L+0tfJdi/mWHoMvl9W5r64NQhGV/GG1DTyPggwiZy8tiocmAdYmdjOPMkgdRXXOxeb6VK960NzUQCmJqjcuYinFU7EZMcAYqACI1012fs/kaOt6rnaHJtiV53bIKC7q+nvS4TiPQQuabUPbvWI+1JfeZr02HWpO09K5QmUv5pGruqcTlaURENJKwwH4My1YRsNfGfs7JobWo3Z3A+Ma9IBQFboGKdohAlzIRz1Q+hOcHv4mY0mhu+Phy+ffM5/By6Q3oDE2GsUEjoAUqp56+f2LTSH1ZkFG4L5TkZVoLL/wUWptiWFV6Px6p+CXiCKE0vsPcdPLCG8/FtMVv48XSmxELTdHHMgW/6jvLthmgcY077jkBV1xzJKprirHwwk+hriaq1bvEt+CEvu/ju9+chjvv/QoqRRMg44nnD4namvEoV9rgTEu1t+80WyQ3N/WYDQBWLnsdXh0DamuLIWDUtWhtoN0m9qGQkjiHlFCEmvQ+aWnptQdQUqJEbcLiS3+MO279HZqburUxNXVhTd/pnt/9VJzv1dqa8YlL6uNPIhTtdv11TLcJpdemnNGG2bbXBiKUUdCTqaFsMMkWykRENNIxszKGmJsTNvcgpGcYauu0T+CtS3qCbtqXVOBskhDxfvzzms9h78seS72Hic64bnNTF2BkRZyEQAz1kNKSZRAhxNQabLvvRDQuWo2W9gHLBpLaMaoq8dtX/uP5ibixz4q17iF+64lYW/ZDxJRGQITQrTSgUmm11YgAQFvHgHkdCIFupTHtJ9nVNcWY13s5+mN6xqBbMY8/qvNmrC2+1szUHN17Gw6+96OkfVuMCfjKFW/a9nKREmhu3Y2SeDN6FHu9THVNEU4+ZV8s/9HvIRGBgjgO730IbxR/y7a0KrHvTOJ5qYjggUe3YP7CevN94SzSFxhAr1ILFWFYg04JRZv0uxho3eR6u8FZsD5frwWKyRpzyZ+NEkakZhoOb1+OF0tvggpAyEEc/J/vYvN1g+n3a2nqwrLvP44zSx5E7TlLUbF8g30ZX4qgB7D8HDX3oAJNOKrzZtTUV2S0DGso2ZFsZU+JiIjyhcHKGGJMniBhTmybm3rMQEMJCZSXjUcsttNcxpVquYs1sFGURLG8Rqv9UBHGmr7TMeGqWRCVz0Ba3nKKAgghbBPvqsoJiA+qMAKVMnU7VISSJtxaICJtBfXl6lZzMldbuzRpl3pjEtrfvNGcMFrX9B9Vdxherr4BLa27zH1cAKBTD1S0QYYQQ72/F9zHJ9len3zX1Fdg3vb/TtofxMjQOAPKO297zeX6gMAgStVt6FYatcfXahmdlSvehBRaMKHKEN4o/hZOKHrKLFqvKg9jd9MmSKnXuxjtoIVAS1MXHr71SZzSeTF21h2GeNH15gXL1O0AgC5lYvJyNSlRrm5FpG6mvWYlxSTaK3iurinGKbGLklokG/VLncokVAy2Qpk+HbKtD5CAKgXeKLoAJU2L8dPbfo8uvKu/plrTAdumnHpg1b99HVp+cgm+ed2fksaRijXw6ZA1WFt8LeZt/++MlmENJTvSuGh1okZIqpCD/bb3PxERUaFjsDKGWCdjbtS4REfHTvNr6zIut0LdlY9uMSdkEokNE7UN+iz1C8oUPFLxS0ip2FZ3acFNYkCKoi3ZajdrNlQoGMSxPTdr9RS2zQtlYgItJRTEcUDf01hVej86+yahqkhFVXWRXhOij0cPaLbdd705YbR+aj3QshEDu7cAstb2upSrW5OKtJ2T6MrKCYnXTg+yjEl4qmyV1yff5o70ltfbYAQsVrbshkHP8BgbJEYnzsG0699OvBfMWhRt75S9L3sM++uT2NsuewSdssb2GhvBh4SCmKwF1DjW9J2Ozt27oQWX2vdLWzLl3vnshKKnMP329dixfh1WLnsdMbUGFUor5p/7GdfjnbvTW4PnpLbGgK3upkOtASw1QWZtTvF16JLVllofbd8da2bNXFqmBwdur3kqtp81/bqZLsMKmh1x/qxqY1DM9zjrVoiIaCRhzcoYUltb7Kt7rnWrEmO5izmpV+Nm9sIZ/KjxOH5w9d6oqy+x1ENoB5gduSybNTrF4xJtrX1Jk7wytQknFD2FirKIdZSJQerLk14ruRwxZTKkCKGtrQ+xjp2AABQ5AGHpeNW/PTFhtH5qvbb4OnTIWrMGZm2JtvHh0T23oELdCiHjZp2LOYnW60OklObmk4qI44i+B806INux+vKizdfNRe97r0EO9pvXj9TOMIMSY9mTsYFmtG6GZ00FoC3Fq6svcflmahP4SO0MyMF+s+6htipi+x4ooRD+5473zPPG9CVPtm+WmXZQzRoR+x43Wr2OQDx5+Z6UqBRN2PuyxwAAP312h7aUT89U/XTVFte6DFu2Qyb2x2lr7TXrWLpCjXi67EGsqHhOb1OdyILZU2vW2hz7G7ClpRfzFx6i1TNBNd8rEAp21h3m+bq76W/eiAq5w1JzpAc+GS7DClpbZv1ZbW3qwJO7/ttzo1UiIqJCx2BlDDEmY3DZ1d2gKEgqQAfcl6IkFWnHP8a2+07UrlMzPnGfNfoRMM9dXVPkHjxZZqcSClaVLdUK2LsGvZ+cENBPbt4Uj2spH1VvZWzueh9KtDKONsw2H+Msok6qr7AM1jmJjsV2mZtLShHGWzPvNYMMr+VFW+85DgMterG0UCDCUXN5jltg4gyQrA0LjE/+r77+C84XBp2RPSDCUe1aerB5VPctqKoqMl5wxAdVPZjqwcOLn7IVpptZFT3LomDQXCJXrm61B6ZCaO2njSV6+u0KBnD8uP+HbqUed9zyO60RgOX1a2ndlRQMJ036jddef+5GQPfarJ9oG39axmgbt65SacXRvbehXN3mCKYkamuLzdfwB9fuizNLHkQZWhGdOAcvl95ge90fXvxUymL3bfediKM6bzID3Ap1G47uvS3jJhbdSj1WlS3FI5XPYlXZUnQrqZchOgPwmDLJFoCzboWIiEYS7rOSQ4W2z8rVlz2f9AH4hRcfhj1n1SQd67aJX+llf8Ky7z+eKALvuQVlaMVej/YnivmbemAswxJQUVszHldcfzQAez2CVJM/iQeAxOaMgLOtcBBCxrEgZmltG44C8TgitVrL3IHWTXim4kFtp3ZHYb+CQagiBECBEEAFmiAHdydaGAskvY4AbJtJOvc0MTa3tNZYlKtbzf1L7r79tUSxv770zPk6WTeDtC79eabiQb0BQWIsFfEt9v1plBB+tddatDR1WRoRJF6rb3RdpC+pSt5QUyCOb0WuwkDrJuysOwwvl96A5lbHHimO109C68ylIuxaz6LIfpwf+4blhhCiDbPN/U2c4xCKwHe/uSdWLnvdfcNNR6ACAdTpr2HJwMeQCGt1UADK1O246MazUF1TjP7mjXhvyXna8rbQZNTWjE/aF8h8L3lsZmndE8b8/kb28N2wwsntvZBqSdrm6+aam2g+UvHLpI1WL/vWLDTMnhNoDERENPKMln1WmFkZw2rrSmxJj7r6EtdABXBfilJdU4wzSx7Egs55WtZCtpif2prF/NrZAWhLjU4+9ZPmOa3tfOvqS+zzTQHLZFNo8YqzWt6jLS9gZI4SWR+BOB6p+KW2FEapBwb7ARlHW1svnhq8Co9UPgulajrKyqL2QEkIqCIM40dFSiCm1uDonltQHv8YQsZRPrgF5aI1ab5sZAC8lhchHDVrLKReN2JkS5yZG6PexW2JHmBf+nNU502oQJNtLJ2hyeayNmM5kq1uxXxdE22A43DfTFMoIfy8/EE8UvksXq74PuZf+BmPJWh6FzaE9U/2J7sX3gPaa2xkxfTx9e9Yj7L4dszrugQV6kdJLYi1QMVSV+NkLDmEipAizOxId2gi+pRK/fvxEY7deStK9SBu230nYk3f6dr3BApaWndBUYR7m2SPGpSddYdpmZCKX2JV2Q8RC012zYb55fZe8NLfvBGdAyXm9ZOX5An89NkdgcdARESULwxWUhBCfEMI8SshxFYhRI8Q4q9CiDPyPa5sMSfRjiVfbryWoow/9xd4pvIhPFLxSzxT+RDGn/sLAO7F/Koq8ewz/7bdZuwhceQH56ACTRDmEjXnxoeWugmZOtMiBHDFNUeiQg8mFKhQETH3QHmx5Gbz2LXF16FDrYFUJdrb+9Ddtct+Ped19MlqmdqEeV2XYEHs65jXdQmO6bwhKUAwJpZGUPbdb+0FER6HX5Q9iGcqH8LAGb/WmgYYe5tAQcuOTrx/XggV6vZEYAIV5QMf4qjYjaitjprfr7NPbjDrPPq3vWsu/SmLb8cpsYts+8ZIJBodGN8nLdixLOGSEiVqK1SE8fOyZVoHMbfAIi7Rpmd5rAGZ6/fLWJoFJIIRl8CiunJc0vvIOumPI4RypUN77tVRHBW70b2uxnl9KVEe/9jcCFSjWN4Pk7B2wtXYdt+JAIDWppit7kVCQVyV5s9JmeiAirAZ+O6sO8x22f7mjfjN7v8yA1AVEVgD3Uz2Z3EGqRVyh+cytPeWnIcnB65ETJliub5dLveIISIiGip2A0vtMgCbAHwXQCuA4wE8IYSokVIuzevIssBPhyNjedETPReZy56sXZkShdLQCqWf3YErrplj76ykc5usGW1VywCc0v5NROpm4qH4kuSB6CdSMACJEATi+j4eRgtjmC2MK0QrqmuKcULRU/qn5FNsk+cuZSIerfgFJEJaZsHociUBad2J3UWZ6MAgxmFFxXP6eBJLnI7uvBmvzfqJfcmOJfuR9Fq9sBv2QEian9of1XkjXq74AWKoNdsoT+huwTzlcky7R1t2ZF2a51xOdkLRU6itKE4s87I0OjC+T/MXHoK7b39Vq+0RWiZqZ6QO8bia8jWwtZC2BGRpJWXGtKdfVRkFQhHztelQa/Doj34H4Ax0hrQMR09oImqrx+OO64/WnnfTOojyuN5hzpJZsS390m4/vPchvDXrAfv70bo/jzIFrU0dwHVzsbb4WuegUVdXav6c3PW9NWjpGNQfpwU6+1uOfm/JeeiQV9qDNf3N4Gd/FjfmUsKWXpSqLYjH43ik7Bco79mKE+46C+WRHrPz15q+i6AqEfv1LRnITMdARESULwxWUvuqlLLV8vXvhBCN0IKYER+s+KGt379Im/AjMak3gg6vJSrGBMvaTtdtovRh2zi8WPELqIhAwQCObbsZtbOSAx3t0gKq1CZiEgKhkAJVChQN7MBOpRqqDENBHJ/u+iGABdou9rt3AS5ZGuM8tqVkroXZer2NXiuAeBTNLbsTS5xkGBACMWUSXi6/Gd+0TCyd+3E4XyvrJo6GmDIFKyqeQ5m6Hcd23gRIFWtLbsAvyh7UAqKm2zANWhDZuqMNa0vvR6cyKRG8CQWdocl4ufQGzF94CH78/Z+ae6xYgzIjwFCl9bXRsggQLsu/rMGA7d8qamvLAGj7lbRZWwU7WSbuxjkq4h/huL6n8MTA1bYucNr7DTDfc1DQ0j4AAFodS+n9WtbAGRS4eLHse7jS8n1RBLSAzPK+WFP8Pezsq7RP9PXrW7+HrbG4rQlDa8xe/P+rvrPc89VSora+NO3+LG6sHyosvvTHZmvmmDIJTwxcCTkQAcqAsp7tWsYzKdDUvhaK8LVHjBuv9tuZbCJLREQUBJeBpeAIVAx/B1CX67Hki7F+3zoZtAYdXnUU1u5UdfXeS81eLL3ZnHSqiODF0ptty9MStSzWT4oBQAtU7rjnBETDAqqeIVERwv+VfQcAHLvYO1jrYYCkOhXLgdrz1Mfe0j6Q/Ok9AGOzSGsdzhXXHGmbuDlfq1DIUgsB+/W7lIl4ofhGreZBX9ITUybj5fKbAWhBpPU+7TXUlxvpE3vt2smT+VTfP9syO+PfzmJ12/kEdjdvxo7167Dwwk+51664ve7684wpk7Cm73R7W23r9VzG/ELxjYlsmUfnL+v1VESSvi+2AFYI9Cp1ieDHck3j+Rid2aS1dkpKCJnoULdj/Tr3pXN6F7xsTOQ7Q5NtwZI0xqy/ZwTiMJf2IfE8qquLtGxnixZctLX2Ysf6dbjtskdw9aLVuO2yR7Bj/TrP665c9rqWpdPbb69c9nrK24mIiLKFmZXgDgf0ra8dnN2+Ripbly7rRox6JkJRFJx8yr4A7BkUIQfRsqMTt132COZf+Bk0zJ6TdqmZKiK281snlgZrNySDdfIaQ31i7mnZYd5tKZrJ8gm/IuKQQvEMbKprinDFNUfind++Ahl3tGO2KC8N47bLHkGHWgNFSEgRNoOc6hrtU+cVD/0ZbW3aXjKlZeMQCiloa+sDpLAngIRAtzLRfi2hoEPWo621F2v6TndZ7mM+OdTWapPsbmtBu/58rZ/wz3dkgrRlY8lLmOzjsP+3U63EymWv49olC3DFNUeirbUXd9z6qvMFR1KGCzCzKOd/qRrP/xZo3tGdNF5nRiDpOXl8P7TLSoTC9u9rdU0x6upLXLJ39usqIW3J4123vaq3pRba/4T9/XrHLb8DBNLsvyKw4qE/4+obvmjeEiQrYRwrjWWPEMkBmhBQEUZdfRmam3sQUhSoer3NYP9utDTthoSC5qauxPI/qXVS61Br9O+he5ewltZd5s+H0Xgg1e1ERETZwtbFAQghvgTgZQDnSykfc7k/0ItZqK/93beutUxCLMXsxtp7RwviHevX4b4H39OXIWlLgyqVFly7ZEHaa117xfP6cihjSZYwW/4aEzezDXJzD0KKMCdgxjHOYCYUElAlUFU5ARBAe/tO1NYW4+RT9sWqp/+lTSqtkzwZR13tBDS3WmtIEmOqKIsgOmG8NpEGHEuhYB6nIK4tqzI2IxTJz2nlstfN19Z4HQfjEu0d/ZZrwztTAIm6mnG2SWLyIdLMZDU3ddvPC4k77/2q5/fj7lvXorl1F2DUuaSqXbEQMo479CJ1ANjwQStWLPsz4nEJRR9mYsJvqTEyxivikMZnJ5ZAMhQSuO2er9iuddV3f+14TsnPPxFowTxWCQlI/b1z8in74tln/m1rre1couZcCph0ftvtHsGYw9XXf8EMWK2MZYbO4NF4j99xy++SHuM2ruqqKELRcUnLEO+49Xdwvg+c43V+D62sy8+M9tvXPXCx5+1DkSqIc95nfB+5DI2IKNloaV3MYMUnIcQ0AH8G8IaU8mSPY0ZFsHL1d3/lmAi7dd9SUVdfhpaWXgh1AKqjMD3VxMfKOqk1HyvS7yVhZZ3AKAJm5ye389x9+2v2CbyUqFSa8c3rTnd8gm4lISBd2vw6JvMpJvfGWJL3NTFqJ/ydx3iMon9qbn0ebnU2QtiDBEURuPLaL7hO6Npaey0T6VSTb5n4jxCAjKNSaU0KTq3fF2vgWF42DrGOnb5eO+sk3qiRsH2f3L4HOkUYTRhS8Xieqb4HAYI45+NCYcW1VgmAmUFyZnxCIeHxGEvQp2cIK2vK0K5n7myPH7Q0TXAbv8f30PDPaz6n7T1jaeCw/+2/97x9KLSf0UStWygkzCWVzj1nhBDmZqyAlgW9+vovup2WiGjMGS3BCpeB+SCEqALwAoAtAM7O83CGXXn846RPSwHYblMQNycNSR20pESF0uprmcues2q0WgLLsiEptT1KvCa7znNZl41ZN7qUEmhu6sHdt79mHq/t/WJdOgPMv/AzqK4phlRVJJVxyTgABVK4BCqQ0DbJTLwmWtAWSpoQGs9JyMFEnYFtXZvl3M7lV8YJLI9RVceDXOpsjHKTUEgxs1dSwuzk5rRyxZtob++zncN2bf3fFepHOP/bX8TKZa8jptagQmnF/As/YztXW2sv7r79NXOS3d7eh9q6Etxxzwm4+/bXHB/yewcqxutmjHnlijftz935MP08QujND9LykaFxG5gzO5SO/n3zClQACanCNkk3eD/GGIf23pMy5NrgINHtzXo5bXNXY1yVLt9Dq70vewzl+qaj0YbZaFy0OuXtqaTLnDhfg3hcmu2xrfdp72/pOHeKBg9pxmTNeFXXFGHhhZ9iloaIqAAwWElDCFEE4HkAUQAnSCk9F6ZLKVPOXEZKTYvR8tf6aSkA222docn2NrDWGhAMYv6Fn7F1AzOCBmfROQB9ozx7lqBCNNt2frcugbHu7eGc9FSgCR2yxhYwWCe79vu1T5MbZmvLouxBmvbkFMS14n1HsKBgEF8QP8Vf418yX5PPRX+NP6jztJoVxLWOY+bro7VU7hC1iefpLPI3uGXcfNRmJH1yrj+/mFpvO6y5SQsErd8Ht0li0nl1sdAUPL5qG7553em2Sebdt79mLtVzTrCNoAOAS8Do8vwFYPw4WYPOxEaj5oM9Xw635Wa+g4u0xxmBgs9zpjrGtqTQB9syNO2BRic4/QCXk7ncZs1CVU9HpHoKvBj7LLXs7kVtWTHmK/WoTnF7Ktafa+vPpnGfG6MxwHBZueJN2++YttY+z6CeiIhyi8vAUhBChAGsBnAogM9IKd8f4vlsL3ahvvbG3iqtTTG8XH4zYqjXNuLrvgUTmv+EaMNs/GLc7WiNxfUlTfpSJqktvTnvzD0x55C5WvckNfk5OmtSko6TEqd2X4xfVDzk+nhAu1xdXYl9T5O6Ehz5wTlYW3ytfW8VaEts7rjnBLy1YArWFl9rBhhH996Ggx/5CEDyUhcVYXSHGmz7lFSoH5lLXYzXyfqpcrdSb9allMS3Q0CgW6k3r/Xq1IfMfTqcNRVJHQTcuNVLuGRhBFSUq1txeN9yvFB6kyP7pT22snICOmI7LcGF45zGODwm5NXVRQiFlaTld97jBurqS9Ha2gvV0TrYepyCwUT9k4UQgKIAalx1r9dxLoWzLJECkDivcTK3x/kNPpLqWgLycx2vJW6uwZ37UjjPLJDLuazfT2d74rtue811uZVzWVZVlfs5rJw/78bPptt9xhBr60q0hh+O+8rLwujsGoARPFZXRrHw4iMCt1N2va4icNW1R/rK7gbBds9ElCujZRkYg5UUhBAPA7gAwH8D+Ivj7r9LKXcHPN+ICFYMzomItf7DOrEXiEMV2gaN1uPu+P5LaHMWjiP5XHff/ppl80Jt2dmZJQ9iVfE97oX+kHoRvUia9Fw07hr0b1+HVaX3J7Ik+vFXXPMFdC85zNxIEUJBdOIcTFusbbK4Y/0629KmGOrt8z4Zx0VFNySCEpei/3hcNWsGBFSUxz/GvK5LzGt1qpXm62bdkNIkVa3WQir25WRuE1Xn+0dvblChatfsCk3EqrIfJtUTZZNzNZurdBN7SyaoVN3h3v43cXDirWAdgI+J/6ldF+KFkpsS+85Yz5FqvB6vfbGIoVdWuF/b+X1LOp9xTkcjA8/lf9pyxKDLzny/Ph6862W0Dx1cs3FIXNr6c242ynDuvaQ3PHDWrpkBbs04M1Nr1vPoWcPjQyvwq93nmd/TcqUN4eqpiZ9BnwGUs07GeH4AXDsKBq2rc17L6/cqEVE2jZZghfuspHa0/t/7Afyf438T8zWoXHFuYmgsxWlr7cWE5j9hXtclWBD7OiRCMN5KUiY2hhyMbbdPLAHbMebSoaYeCMQh9EDlhHE/QeOi1Tiq+xaUxz+GkHH9PIllU2pcRW1VBELfU0JARVV5GKuK78EjFc8gjhAUqPqkTSAeV7FyxZtoXLQa0YlzACWE6MQ5tjX2iR3mQ+iQ9UnzzNqGckxb/DaidTMSky6pralP1NkkipsltA0ardeyvm4V6kf6JNRCKFARQYW6LSkKUDCYOF7GoWDAPkD9+E5lElaVLcVvyha7ZigCSxGNpAxUjKIZY3yJO2B7Y+n/LVFb0avUpV4OZWYIVO35B5iI/7xsmS0Qsr1+VtbAIUWg1SdLvMdq+X4IDCbfB4lSdXvy+N0CHCnNujEbrxffOeYhfP+962Xc62ucwzB+FwCJ5V9WRvMEe6CSeN0VOYjDupaarb9LZat+n4L4YBwDbR8iZOwtIwQ61Ur7z6DUlpA2N/Voe8Hoy86c5i88BNXVRebX1TVF2r5Klt+BqZ5bEF4b6aZj/L68+vI15u9hIqKxgDUrKUgpp+V7DPnk1pnI+GM/r2G2maEwa1iMzIq+/0mXWun6KbFxjHXyokoFFepWzOv+b0RL5qBbqU9aktWl1MOoNSlXt+Ko7qewJp44ZjBWhHbUQEJBt9IA+yfR2ier0boZZibF4PaJr42UEIjj7JMbEq+DywTD+WE2oAUsK6uehbpLourhzRiseBhdaqW+ROth/F/pd9CBenMSLgRQgSac0nUJVlQ8g8QGgAKqDEPBoP6Bczw5EBHaUjwpFHSGp6bPePjlMdn1vWN98h16gsyeUehR6hL3pxuLCEGVChQMaIX0lmLxxHGWZW3O5yBEoqbILeDxymZZ7pcyrJ3fmkVxOY+UYfv9ZtMK4Z3Vceg0NmZ1Hpdq7J6BnOV1GWZSlbjqu8+73icUYWYU7EGR/r3T3/O/2v1N/PH7L6G9YwCQVfoh2iaYL5bcjG7j9wJg/tfrrScl0Nys1z85Mi3WPXAMtbXFrr8XrL/ngrL+Xg1ynlS1PrnCJWxElA9cBpZDI20ZmOckXgB11VG0tO5CefxjHDT+j3hNPRNxR5JAwaC+nElb3iWgQgptglhdU5TUYlXIOBbEvg4oIfxqr7VobuqCsd+HwACK1Q5zQluutOGYzv9BWXyb+fhHKn4JaUxagKQahrr6UnPTQusfXOvSLU9S4mvjHsafKi83azTcPnU21v2n+9QZUms1e0b4Dgy0f2zWBlVVFWGg+T/oVur1zRlF0iRVwUBit3XHOX3VQQCw1coEud/KiAfSGcIypLTndFufk+m5/BxnXMPtMX6WXkmJUnUblFAUnaiB7TXWg+Jxahd2KZZAX0oIDGr70OjnVjCIIrVd+3nwWoZmGKYlgENhLJE8s+RBNC5ajRvveC9RE+O6FE57lNt9FepH5pJPARVV1SWeP4Na3ZOwtTcvLx+P7u7diMe15aILL/wU9pxVAyC5q53B2k45qEwn/NZOh8ZzuWPJV7wfMAy4hI1oZBkty8CYWSEAHntitPWhAk0oi8fNQnOhz52bW/sBKIiFpuK3A2ci8Wlt4lNbFWEIDEDr6qQkCtWFQHtbn23SYGRLIBREG2brmQt9laIQkIigT6mCttwjhC5ZgxfLfgAZ322uVxfCuaTKOkkT5gZ5K5b92cwIeAUViqItNbOe41e7LwD04+MujwmFBE48phbPPvkXGDuDexICKkJYs/scHC1vgRzcDYRUxGI7EQ/pWSGPT81VaQQq1k/IpcttFsayGgzg2O6b8UbxtxALTYbrSlAzCEg1iZeA1K8nLY/xDKCy/Gm+c4lTymv7PFfigTAnxsb9+utRorZYMkAu55FSW7aIOKSM2F8XvZ4IADpRnbiGJegqVZtxRO8P8ZvSW23nlY42zCrCyYGK9fkGqOVxfw2Gk/YaHd77EFp7O/DT234PFTXehzuzhw6DGAfj50XqWTujU6Dz57uq2v4hiZRALLbLvD8+qGL5j/+I71+7H6J1M7TbXD6UiMcl7lz8qm0PIL+srda9uAU0iqPLnqLkPgjNdAkbEdFQMLOSQ4WaWfH69BAAjKJnAOgONSLwhDPlUhqto5c2oRgEZAjQP/ksKRmHri5H/wLXyZf/SbBQBKoqJ7jsBJ5MUeCyQaT3tYxPWh9e/BQ6VHvr5JSkRInabJl4pnk+GWUp7AGFLWBR9Ha1Xp/OuxZ7u9xu8Jo8Zzz2ALJxfktwVRRvw65QhRZ0y35bZs/9dbH8rBhF/JZgSsEAPte7FK+VXAZnRsV5XFLmzE8w5vhZ0zKbAtZW3J7HB8kupcy6+fx51DMiAJI69yWu4+d76R0sV1SMtwUiRiYAgC07kPRrWEos7DkV0xa/g3sf3pzy94Wf7EKQTIpXNru6pkgbh2OsV1/vvsHrcPHKrIy05WEjbbxEmRotmRUGKzlUSMGKc9f3VIW0mS8psUwk3M45lIllkMennWC5PgjOTJGva3g931SPg9/HWD7xz3hyB3NCPK/rOwCAX5T9MLFRZdLYjE0v07wH9CVMEsktktOPz+U1disACpqhSVVL4nWceZ1EANq95DA80XORpbucY+z6wzxbIyc9J/P/eX4vbcu+nONMNXbz2hJF6MQuWaQFPhgAYN33J4OfP8eyyqFmyoTeLEImvaaW6wFDe687r6kInH7G/njyZ/8wb7NlUfWfjfNj30C0cR/8eOdtvs55xz0neE6Agyydsh7r5FYj5mw3ffIp++LZZ/49bJNwr+d4x62/s43NaG1dqLicjcaK0RKscBnYGOD8A+NsE+q2pMkm08lNqqKGoX7AHmQsQ5qUpXqsI3jwOzl2ji1d0Gqez7H0ye08Ppc9qTKCn5c9BAFtTxZzBJbnIDCIUrUFXUq9vjmmS0BjHSack06PCXmaSa+QKorUZvQp1YnlT9bvhx4YKoqAVAchvVozB80Y2K6T2Dn9azvWo7PMLVDRxyO0x6fuvJYiKHWO0WXZl3Ep1zFbHmc9uE+Wa9cVArBuUOo2jqTXyfF9SbrfKyB1G6gbiWK1FT0hjyV1bmNMd7ufq6rSFqgAegZV/x4aWUcA6N+xHihPf05FWH7HuhTAey2d2vBBq/l72KiV8eo+BmhL1JysWZ/mph4s+/GfzLd9c1MP7rj1VQBa8LDwwk8NOXDxWsLmDKLaWvuSNp7NpqFmRricjWhkYWYlh/KVWUn1aR0Nk0DBnfdSliFfN9X5Ui3rsnzKXGQsf/KbpYDxXLS9MKDGtY5nbkvjpESp6EA3qowbAGnJUgjrRFg7p6JncCqUVny664d4o+iC1MvZLMrQii5ZnSbzYb+vIv4RYspky/PKIFPn9bqlW1rnJyOU6f2244wvjODZESA7z5eFJXd+4vRcKo1vw2ldFwEAtoXn4sXSmxOZshSMT+adm1YaGRe3T/HnLzzEDCQMoZBAdY1797FsSLXpZ9Blas5j3Tq+1dV7ZyuGGmxkmhlJtdcPMys0Go2WzAr3WRnl2lp7tT0GCmhSMGplvFxOeH/iHZQ1Y+G1bMh5rPMYy+0qIvZC7nTjs05moaBDrUYHJsJsGOAYS6m6Dd2y0noC/bpubZm1T/FVRLS9cNQ6/Kb0+zi872Ftvx23yb7jej0yxUflQiSfQ0otULE9L32c+v3WY53XE3IQQsb1PXIsxzozLdaZuzMoSDVel2umvN/rPBDakKSEtmRMTU6KOr8fvlrBeRuO30mKApjv/cSVfD22O9SIFZXP4dGKVXjBFqikfryRxVAcL4/Rknj+wkNQW1cCoQjU1pXg7JMb8PDip5JegHhcumZPssW630xzUw9WLPszAEtL5BT70BiMib5xDmO/F+seNQbr/W7nMa5pHBdk/5hMMyOp9vohosLFzEoO5SOz4rYzM40hmSxN8zpHJsen+jReOpsLpDmPwXGsgkGUxJvRFZqIRGYAyYFHutfBWSfjZ8mWR72L6/nM+7WgSyuAD9mv53p+JJ6X7Rhjtua4hnUcbsFLuufvPEcQKd8rQZaMyRT3pRxA4vUYTj6ya0IAVVVFgADa23eaGYSP7z4OP9t1pesYc51tqqsvcW/xrAjU1hbjS1+eiZ8/9U9zqZrZvdF6rABKSqPo7upPPo8lk2TNpHhl+p1ZjqB1QOkyNldfvsY1+2XV1tqLFQ/92VxiZyyhA8CifBpxRktmhcFKDuUjWHH+cs6Mc+KQ6URijMnCUplRze9Sp3THJA6GbTJsPC7QcqgAx2VjyZ4xxqE+LlVWz3Jf0vI6r/MP1/tWH0uR2oY+xWM5XvCTYqT8PqquLkK8eZ29A1qa17vQlssFZQQ+1uDC1rbe5XgjgEgXlDQ39yCkn6u2rsS2Z5bb8i4/y8fcPuCrq7d3kbPezqCFChmDFQosX5kV6y/YUEhAlUjfASyJMSEYORMDGis83pOZTLrTBiKproXk+zKe+Gfp58wtu2Pwk0FKkxmznSvQmIxzZen7NqKMrd+hoZBw/VvjFYQZf6O8MjDWds3O4CPpLe7InLg1NTA2ADXP7/IBn9DX+CXd7hHwDFU2WyuzTfPYNlqCFdasjHLW9dJGweMd95yAK645EnX1idsv+9ZMnDXuTpTGt8J9jbb2yzoUUgDn+nvr/6y3BeJyvEfdQWbnzxLz2gzyC4fHxC/dhDfV+8h1Up4iUAFQFG9D0vvCT9bIfQAp7gvAWofj/Lf1v16BjMEtgHCp7wk0rky/b5kqmA/mchuoKIqAUASqq4tQXZNcWzLcvD4U8/p2xOPSrJ9x2/jyLktdizWYcXsLG3VDhmef+be+f5bWBe7ZZ/6ddH7nY4zbamuLXZOWw9FJLEgdUS7PRZQvzKzkUCHts+K0+bq56N++DpAqAIFVZUvthcVIfEp11aLVsLVxlXGc2nUR1pbcgE5lEkrUHRAQWstboUJFSJ/DCfvkyPpJtGUJvn5A4mvLxKlC/QiH9z6EPxR/W9+kUjtUEXFteYvbR2yWOgGbdJ/gpvrU2TwvjWjZqOXJRq1HQciw3iPQa5gqq5Am45Aqy+N6DsvzMX9mAYyxJa3OPU+uvuz5wonbMqRt2pv6GKPGxqiZqa4p9qxZsS4rE3Av9QIAJSSgWoIvr8zKULMZfmprMj0XoC1f87MnD7MyI99oyaxwnxUCoO8pII3f/hJH9/wAq8p+CFVqe2tYP6WqULchpjRqAYuMo0LdijK1CfO6LvE8f5dSj1+X3IqdSiLlfmTPvTh++e8AuK0T1gMMx4REhMehBB0Ih8OWAAhaoTLc/sKkmIClqztIdftw/7XPdAkTMIIny3kwlNfKmZ0IaijL1IaFSJ63+7menwyWeYzPsbu9l71qcWy3W7M92v8TUkW5uhWH9y3Hb0p/AHuAMvp/Vpx7niiK+7KsQuS1hCxdoKIdo9XEtDT3YMVDf0YorCRN2qUqccctv0NHbKcZhDivZv1Vr8alawtog1trZGO/G7f6Fq9gwFnj45bt8cttOV1Ls9YNzniNjI5sxvI7YxxeewcR5RozKzlUSJkV5y/Jwzruwe93HodOZRLK1a04uucWADCzJbUN5eYvsLcWTMELxTegW9EyG2XqdhzbczPK1CZ0KfXmY4zzlKlNrmOINu6DaYvfBuC/EYCAitqa8Whp60+OF9wmVn4mW14Fy2N50p/N5z/WX8ts85VhCHxSeE7cUwXBwzKWAHxkRxUM4tie76Gypgw/231V7saWdZlngYQAqqqL0N6+MwsNV3Inm58LZfNc1dXJXd6qa4pxx62/S9og020cRpc467HG7aGwktQ4wG9Gwy34AZAUQKUbn5EtymaGh/JjtGRWGKzkUCEFK8kbRbosmdAJDEIKLQlXFt+OI3Y9hBeLbkjsaC5VKBiERAgC+nIsoUDbwE+FhOIauETqZqKtrQ8vl92EDlmvX8zHH2MZ1wOjiemDE1/ZBvclYtW1xWn/8LifLguTNrfnwQk/5cpoer9JCSHiqK0pQnNrcntd4xgA/rNEhfD6FMIYhtGFFx+GZ5/5d0at941uY7niZ1laJkIhgSuuOdL30itnsKSEBK7UH+9sRiCE95hTbWjqlllxBkl+lpilwyVo2cFghQIrpGAlKZORanLs+LeCgUSg4jze6zz6c52gttqWggnEIaHowY1lwuD8t+X6AgMABKSzBatXdyKvc5njg32pmH6NH1x3AG675XfoVertj023Xl6v+/GcSLidx7PWhsa8UT4pzQlnjZzXMUDaTE3aY9KorinK7EOQgmF8uOOe6REiO0vNhCJQXjYOnV27zBXKRhCSLjioqByPWMcu9/OK1K2TC40zYEkVGHhlzdxqVAb64+jo2Jl0rDUo8RswJH/46X6+IPwGSk6ZBDmjOTBisEKB5StY6W/eiG33nYjWphheLr85kcUwJ9cBJ0N+j/dalgWkXjrinLj7Wqvu43Yrry5IuiN77kad+gFeKLnJXO7m5zkLGcc3ui7Cz8uWpV824yVVMENjz1j93vt5/wf5XQT4/9nL8BxpJ9EV4wEAsZj7RNpJKJZSwqQxZL4sbMgK5D3pLHgHgDPOOgBPPfnPlBN362aXigKUl09ArHMXqionoL2jz/6aFwiv95YSEpBpAi9jsm/dnDPVckDr8W6Tduc+N+kCUyGAO5Z8xfbYdIFBJkvQ2lp7cfftr5njcQtyrNevqpyQtBwPSG5KkalCCIIYrFBg+QpWjE5fq0rvR0yZBK2TlyVQMf6dLhOg/9s1szIUufjDly4r4pbVMaQLnGyvzSCK1Hb7ruxeWRM/tTJuWaEgS1EKZFJB5CldrZmPupS0SybTBSF+zu8rWMne8iMFg1ClgK3zojGeNOPIiQL93eIWwFiFQgJlZeMRi+10/dTeOeGlRKMDr4YHfpWVjUNX925YuxiUlkYxoSialClyLv+z7r9jrcVJFXQAyUGOn7oiALjz3q9k+CwTMs0OZdNoCVbYDWwMMDp9dZqBCmB+IqfXnJSq290zCI4/1GXqdhzR+0P8pvTW9Bf2+8fM70Qh0z+M1sd6ncN6u9sxPh+nyrA9ULEe45bNsX5C6vYcnedxPpd0r8tQPo0myoV0P2/p3qupfmb8nMPv+X38zGSzTkLrcIjCzLAW8IecqQIVQNvHxbr8SUqtG9aGD1rNZVLm5LetD0ntwcYgI0AZagDX1bU76bbu7n709GgNc1qae7D8oT+7/hwZ17buFWMEAm1t3sGHs5NaLpdgtrT0mj8qUg7PnjxjBTeFHAOiDbMBoRW5Q8a1G82fIK318GldF2Nh7CRUqB/Zj7H8oRZQcWrXRWiMv5N8nBs/y7HSsX6i6ffxbscN1x9XtyxMOkmTnwDBmJ+JWSoZvQ4y+XEFPFmhDPD7WXiESPzPelveGZmd/I4i25b9+E9obtI2T2xr60Nba99oe4oFy/onPl3Ab0z6rYGAl1BI2FpL+1VdnZ3NU60biQoxtBbUYx2DlTGgcdFqRCfOwdE9t6BCD1gUDEDogYrRphiAeYzQjzEX78q4Fuw4jtMCFn0y6zahtfwWUjCYdFvS45y3yTgq1I9wZM/d9uu4BTDm7db7VRSrTfpz8bi2n/Gk+7flePN5enE+zjlmz+eF5PP6uY5tbAMoU7e7BK0u3z/9diEHUKI2u2SEvK/jMaAsTIqzMKnmxDxZQUyC0+D3LSGvr4URQI2A98wQ8S2XGwGSlwC0Sb81EHBTV1/i2knNGYgoigCEFtgIoT1u4bc+FWT4nuYvPAS1dSUQijBrgCgzrFnJoXx3A3v//Cigxn0fH2TPlC6l3l6MDkBgEMVqO3qVGte9W8rVrYnd6C17thzR+0O8Ufwtz+sa44opk/RuYhHzscf23Jx0DePxbs8n3XhK1GYoiKNbqUeJugMCAt1Kve3x1udtjN96DicFg1ChQPtjL6BgAJ/ruR9vFp2jdR5zKFLbEEY/upR68zFpa2CkqrWc1l8bt9cnpkyCgjgkQihRd6BXqdPbTtuXqx3ffT1KZKu2SajZrlqmH4ONRHG8CTuVKu0ctmNkIgZxO6dxDJzPMUU2yu1ny1hx58bv+YxlexJICtj8FnqPhMCAaJQbav0FDZ0SEjjt9P3x21f+Y9as9PcPenZyM1x9/RcAJNesOPe9cVMIRe+5NFpqVhis5FA+ghWjE1j/jvWAEgLigyjIVifkizPgOrz3ITOwcwumvIJLr3OvKfm+GTApGMSx3TehMf6O7doxZRKsgdYhvY/hzeLzoCKiB15L8bfSc9Elq81zl6nbcezOW1E2uA1dolYL8EKNAATK4tuSAtTDex/CH8u+iy7UAtC6syy88FP4+O7jsKbvdNsY3Cb/ZfFt5kalhml3fqD9LGx7D0bUYn9OccAS3NmDm0EICH0voQGMU3uwS6lMfhF9FmJrpD14yiT4cR4fJJjL5PxEo0AoJBBXpfeHF6NIdY2WSci0VsP43Rvr2IllP/6T7b7i4gh27RpMGfRV1xRh3qn7+d53xRlMWDu3hUICCy/8FPacVeP6WErGYKXACCHmAjgUQAOA8QDaAbwP4A0pZUc+x2bIR7BidAIz9/4IR7TsihICBj02SCMaLqEIoKqITpyNxkWrAQCbr/uE63sxUjcTk654wQy2IzXTofb3IR7blnTc9DvX2257f340sdTNoIQQqZmOgbYPgfiA+9jcbvfBGkSWqDsgoTdagBaofbXop9j7ssfQrdQn/hBXRXBU9y0YaP5PUlbSJlVGyEaiSMTQJy1BlDUxZRMHEHLemLK5hnm/Mxhzy4S5PcZPV71UxeRux/iR7trO4wLTs36ZnMfPsSMha+e1RLQAKSGBCy78VMYbTrqeU9GecyYNFr76tb3xxusfpiwSP+OsA7D2xfc9j6muKcLRx+zlOalva+3Fiof+bD7eaHdsXZrkJ9uQKisx1jIWIwWDlQIghJgB4CIAZwGoB6ACiAHYDaACQJF+2/8CWAHgaSnzl1bIR7CStPRLCWGvR/sDLwkjyiqhIDpxDuRgPwaa/+N9XDgKDA4g3WzdzJrsWI9ow2ztvC0bCzeLqD//xkWrsfmqWemPV0KINsxG7TlL0fKTS8zn6fza7fWM1M2ECEe1Dy1CYe8PKcJR7LViJ3rfew3vLTkXaydc7ZnBcwZjzqWP1uWczuWG1seaT09fGmku6/QMsiSAQdgyYOZrav4/JGWtIFGsNqNXqYZnE8yUj09FBYSxrFNaYhcfQUjSGCznyDZ9TMUlEfT2ZBaUe55aDuLzPffal7L6CFoqKvV9Z1yW/RgtiL2Wa1VUjkc8rqK7K/n9bLSJ9dpJvb95I95bch5+1XeWmeF17mnjHJuRIVj19L/MSb+RdaiuKcaGD1qxYtmfzWDh+BPm4Ddr1tmCh4rKCWkn9Jz0UzYxWMkzIcQKaEHKHwE8A+ANAO9Imfg4VQhRA+AQAMcAOAVAH4AFUso/5n7EBZBZ0SdI0xa/7Xp746LV9k+59dv7m//DLAxlX9KOd5mLNu6D/m3v2m4LVTQmZWEKi57pDPCzZWSbtt59nBmUGLcBcA989A8oDJuump06QBwGkbqZAICB1k2INmhZtc1Xz0nOfgFAOIppi9+xPceUjPeR/vsKQNJ7we8YjQzd++e5ZJ2c17NyvMbp9DdvdP1e7fVY3P2DpHAUiMfdXy+/Ao4xiPfnR+yviVCw18rsBkRW1uXNxvspWjfD9+O9/i4SjTYMVvJMCPFDAHdJKT/0ebwC4BsAIKV8ejjHlmIMea1Zsf5ST3u78SlsPI5w1WQMxrZpS2TCUYRKamyTwEjdTFSdfBOalp0z7M8nmxNcGkWU0NjOFIajiFRNdZ3cRxv3sU3Ecp5V9Zi4br5urkdQETyIsz88NLRJvd/lgOaSNAWR2hla9srn5Nn1ueuZLdf79MxaJkGYwcyw+fxb4MbrWG3MiVowI+AMEkAEMdRgw2vFAdFow2CFAst3N7AgUv3xSffHzbw/yB9WJQyog2kPizbuY1/iY50oDOEPeRD1F/4kN4EZ5Zz5/sog82BOBq0/NxkJQaspGToj62L9+cxaZiUUQbiiEYNtqT8vSjVJ9rUEDsCQA5jhZLwO7R/5njy7BYyTrv4tivc+UntdHBnuSK32/cv4+xaOIlw+0fa9MjJJQSb+Xse6jTnVeYaaGRlqsMHMCo0VoyVYGbX7rAgh5ghR4JV+Bax/x3rYJlyD/dh234m+Hhutm4Fpi9/GtDs/QLRxH62wuW4mIOxrxcPVe2Cvx+La/x7djWl3fmAuFwGgBTAWkbqZmLb4bW3yNXGO9mnjxDmYdMUL9usJRVs2kaFw9R72cVivf+cHKP/0mdqnrzSyKWGEq/ew3dS/7V3vCaFI8esyHDXfhwh51ET4FK6ePKTHO229+zi8f35Um6A1b0w+IMh72fozqWcf3H5WTPrPYf/2dYAaR//2ddh234nofe81bXLrV6pam3yLD2hBgLknlYr+be+mfM2NjXoBaJPlxn0QqZ6KzdfNxeZr5iBSNVV7XfXfcQC0D2gyoX/Q5Awqjfd5/4719rHvWO88gynp2G3vor95oxZoWIOHNOcxs/eW90QQSa9fw+xAjzf2HjNeX6PZBxEVplGbWRFCvA5gfwD/AvB3y//ellLm5a/eyMusJC9F2OvR/ow/lQr6adpQP32zPj5SMx2A/08mp935gXmt/uaNSTUCA80bofVuoJHMrdYlJZflZtHGfWzvzZT1DumE9U+Mh2uZlt6NzbZMSv/k3vqzYa2DMSeWSsh1eZTxs5KUjfUiQkBorHQjTHRgNH6HAbDX4xjfk5Cltbzj9+pQlu5F6mZioHWT6+P3eiwePLPi+HkxlhkGOc9QMyOZ/m0Y6t8UopFmtGRWRnOwsgrAagD/BnAAgOsBNAGYDqBVSrlfHsY0YoKVVGn9XK33TfWHJegfnd73XsPWu4/135o2FEGkeg8MNG+A6+RrCG1uaZQIRTDttneT3ncZByvhKOoXPIKmRxaknciHq/dIu/wqJUdL4sTyN8v73fgZaN2UstW5EawlTcC9fj7G6s+OtQGA2U4+BcvvVXsL+uDXdXucsQwsyO/Z2nOWYusdX0o6/14rB1zrHY0W5c6fkXwtw+LyLxprGKwUOCHE36SUn7R8PRnArVLKc4UQk6SUW/MwphETrABpiilz8As/1XW8amoAJP1xbfnJJTmrZ8m7sToRzBe98DkrmZVw1Fe2YdqdH2DzNXOym30ZSuMKo/g708n0WCIULVBM971z/L5zZneHxKMNtmvWx1FLGKmbiYH2LUnvU1vwHNL38krx98E1623pFJdptiPdh1gsrKexhsFKgRNCrAHwgJTyJctt70gpAyyUzvqYRlSw4mUoqfTBj2LouPiXiG9uR2haFSp//HWEp1R4foIndlWh6P1zoeyqhTqhBfXP3YDwlAq8f34Uoq88cd/4Fgx8+jX0737Hlg3S1rqn2adjlHQY0yYMWzAmtmUeo8LVe0CEIjlvPZxSIQXIljbGvn72C4p9yZifPXSCnT59QTyQWdvnlJQQpt2+zvNvRqoPpYL+rUn3QRozKzTWMFgpcEKISQCeANAN4C0AewNokFJ+Po9jKuhgxS2QAOAaXHgdH55S4Xk7ALR89VHEN7UDlp1+Q3tWo6/hZwj/9UAz8Ojb63HI8e0o/td3oeyqhYACCRXhPWtR++vzsfm6uYi8eIztPnV8C3r3u9f2nMSuKhS9txDKgL6rt4ijd69HoJZvSj7OEvjs3OM5TPjwpKTxEGVNJpP8QgoMMuHsnKUb8rI2AICCaOMczw0za89Ziq33HFegtTIKEE4snao9Zym23nUsoGbhe63XQSW3GnYJSoba9jnpfC5L39LV43gtf8uky5ojc+I3+HE7DgDrXWjEYbAyQgghjgdwIIA2AE9IKbvyOJaCCVbcfhl3LngN8Y1tiQ8iIwpCE8sQ/7hTCy4UAWVyOUQkhPjmdm1H5MHEc1CmVqBq+TfQ+pVHgAF9IiIARQ9U1C0xz/FISAAyKfAo/ctiCEvTOgkJoe8Mbf238XXPfnfZgority+DsrPW9hiIOLoPucF2fWdQBKECUkn6Ol3g4gx6GOQQ2YWr94AyrjhpImj7pN/YDd7K2KTWmmkwWpjrnM0OnLK+x4zPlutpDSUITbN80NosxOD5OvhcihhkbNMWv5O8bNFnQBI0+HC2tc8kc5Iy68SsDI0wDFYKiBCiLFUQIoSYKaXM+7qJQgpWnH8gIrUzMH7N+RDSRzdrRdgyI9mQHHio6D70OkcQoV3TGaBYAxE12gYocX3ZWCtCu+qS5jwSEur4Zu2YqBZ0KburPc9r/dorg2NwBj2pjh0qBkY0YjnrJgIuPYrUzUTd/GWpHxuKYNIVL6J47yPNm7K2xwww/J3b3FiCGnNJoCNgc3IGK0mTcSuXznBDYgSYLt8jI7AE4Fm/ki74cPs7FmRzTjdenTABpO0ESFRoGKwUECHEFgALpZRrXe5bBOAWKWVJzgeWPJaCCVbcPlnTJtp1SZN0a8ZDCxXct69xTvCDSgQE0lyuNWHTKVD6q81j0p3fGtBIS5Riy6zo/3IGQNbrpw5ctEBK7KpC0brzE+MTcUCG0mZ7hsIaoDizP2q0PRGouQQvDG4oOxS4tu1WItlZtuST0TI3ZbZE3xXekNVgJR8sNTlGlildsGS8ToZ0Laajjfugv+kDn5kelwyYVTiaom4oua2z2U3MEnwAsLWNt25yOhwF827vp2jjPgBcurgxw0IFjsFKARFCqNB+Gy4HcIWUskcIMR3AYwCOAAAp5RA2P8iOfAcrZi3JpjZIxAFV2CatYlcVSv51GYCQOWlXox2AMmBOcCFDUHZXeU70bc8vQPDiDCy8vna7htvtqcaQalzpxmwdlzM48bqWthu54+3nqJ2J1M1Ew5m/QPc1f4a6Jaa99uPa0Df7UQDwCFCSgyq3pXQGr6VunoGNJRAzxsLghgqKj2VLez2WmHhmfRlYLjkbgfjtwuaYwKd9Dfw2HFFCKVtaB+W6H4zxHF06Pw5XZ8q0nSY99h8jKkQMVgqIEOL/AHwK2m+XLQB+CmARgGL9kCellGflZ3QJ+Q5W3IrbbZNvxKFGeqAMlFuClTb0HnC3eYTt0/lIDMpgWVI2wXlur2DG7Xi/x9jHnTrjMpTgJNXxfh/r9hgziBEAZAgQcajhxGtvHGuVKuvjlvUyMkAGr/of78CmzjYWdXzzkJe0MbtDOeXIrHgWlhc485N9xyQ67b486ZZOpeLsrGZsWGkZU//29dktyLddXyA6cW/XaxjZoiB7uwD+CuzTHcOOYjSSjJZgxUeBwohwOID/BtADYA8A10ELVD4G8LVCCFQKQXxze1KtibD8HxCyTZYFBJT+Ku3fu6pQ/K/vouRfVwAAeva7GwgN6J/yJwcPxuMB7wDD7Xg/xzj/7fY4tyVg6c6XjjNQcF7X7d9uj0n8N5QI9KT9tTeOsR/v/VzV8S1Qx7XpQQvMAETsqkLx369C6V9uAyyPtY5LQIGyqw6lf7kNxf+8AmJXlZ6BsY9F2VXr+7XyYgQq2jVrUfT+uUM+J5GnwX5sumo2+ps3or95I2SOO4GFq/dwvy0cTbo92riPHpTYfydF6mai9pyl+tgtP/vxQT1QcS7XUrTzixCiE+eYdSGG2nOWahN7g/D4HWgEJkoIGBy0Pwb6kqhQhgsWhI/HSamN1SUY6t++Dpuvm4vNV89Gf/N/tLEO9gMyjv7tWptkN2Zgo3ofF62bgWmL38Zej/Zj2uK3k4KZxkWrtYJ7xf31zQatrmgu3j8/qgVHzRuzfg2ikWRUZFYAQAgxDcBPoAUuxkLaJwFcnM8OYFaFmFlxSlpKZNZB1AEwJsvaRNiYdFofmy6L4gxcUtWGuD0uleCZHBWyuAfKrjJtpVaaczvPmyq7Y97nUsfiHKvzGunG4fa4nv3usrdoBrQlfACU/kqXMWtL0zyfk8sSt8QTTW7/7DdjkpzdsWd/MsFsDaUTqZupFV67ZRRSFIG7S1OnYUixUW3zygtttTNGLUZS16zAY9Oui/igZ6bBd2bFyXV5WJrXwu0x+o73fuqHoo37uD934zl6PQcRwl4rkwPTkbIpJLM3lC2jJbMyKoIVIcSVAG4CMAHab891AOZA+y26DcB3pJTZ//gjoHwHKzv/8S90XPg0RHeZXq+gfbpln5DGoUZjjqJxxTbB1I41ApY6X5P3xOMSk2E10mWbSOeSfVLuXgOS9rFIV0+jBXtKf3KnMY0KIDkz5ZaRSle3o3U3c2uO4FXnkwhW3J+jtqzM+TytDRCM9s9iVxVK3r7MDG6s9TDac9TeZ+q4NgCw1Dxlp1taUsc4EUfP3CVmHRYDGQKgZQhS1Wqkax8ciqB+4aPo+PVtGQQPiaBBq3uwL+eadPkLyZ3N0m1sad6ffrIdqZuJ6XeuB5Dlup1wFNG6mcGCn1AEez2yK2m5VVJR/1C6rYUiiNbPSlrK5RUEpFpOBuR+f5WRElRR4WOwUkD0AnsA+AhaV7CXhRDfBnA7tOVgqpQy7HmCHMl3sOL8RE3pnI7i9QtgfsIu4ujda4W5GWLKCXxYIK60JE3EAffJvFkDM64NvftrNTBaQf+Vro8PUgviXdjur3tY0GApSNG+8ZyNCbohNLUCctcg4s3dnsGeMf5US9rSLXdzL8L3Pt7Pc0qcR2rB2EBFUvbIKxOlRjoAodo6vA21eN+tFseor3FrJd231+NsHjCa+OxC5vkpvUnvTpWi/sOtdgOAFuioaur6jVQdvFwyBVpNSIogwKhZWXZOiueUYBawK6HUWYkgRAjT7liXNNFHKPU19nosnhSsVH712kT9jVcAF2hsindQkiqIsQpFtP8aQVSOshzZzKz43QiTRicGKwVED1YeBXCZdcmX3hFsJYDPshtYik/ULJ/avH9+FKV/+kHS5M99kpxo/+uWVTA+VbdPuKXtE+7SN29xnegCyYFO8jGJLlteE+V05/F6fk5Blrglv04wl1U5x5ruem7nSvdc0z+HRNYkk6yW83UNch6vDJKz65y1Q51bZiSpbTScr4u2vMxt2ZlbRlAd36wFMT6uxeAmx0IRLbHgFpCkbI1roUQw7fZ3sfmqWemvJxR9Qu+zDbPesSqp9W6KY/1MwKfd+YH3fijaQFMHV34JAUhpTorN57FjvfZaWF+HkNZqON0kOl32Jum5eZzLbYPG9I0B9Odju82+oah1wt7fvNHf+8LgI8sx1AAhmwEGl5SNbQxWCogQ4jgp5Qsp7r9ESrk0l2PyGEdBZVa0Qdl/eW2+bi4iLx6TlFmxTUqFNnaveotUy5KsNS99ez1u1lkEzYw4MxZ+sizmUx5idsJL6kDGrVtXsIm+c6ypHptuzF575mSSaQoiVQbKGvwCgBpts2VtzNvHN0NroZ3I6rkFUM4AMXWGyl6HZV2ilklnNC4/y6JUy7P8ttmFS2YlVabE61pexzsn+m7BiOWYpAm4S3CkjXcdXPe0GTZ6ABSPI1I7PbmmJMWk3yplXUyq76cl8LMGE6l2qXe7RqRupv0Y6/fNsXlk0PbLzn1r3BRSgOC1bwwzLGMDgxUKLN/ByrYP/4gf/e4ctEXjqOqL46S/t6OuYibqT/0Zuq/5M1q7PsRPzlyN9iotOVXVXo6vPf8FrDn+f9FaHUNNWwVO+M3nza/LOovRXdoHNeT9x1RRFahChaIKqCHv5ytUgbKuEnSV96CmrQKnP/MZiIEy/PTM583xlHYVo6e4D9JyHhEXnl8b43/2a6+gs6JHG09c4JyffQ0ztkwBoE88w53oqIzhqVNeR0t1h+tYq9rLcc4TX0NlrMx14mvNHHlnmzIrqndKdx5fNS5mJsM9oAw6Hr9NDdKdw3mb+/hTb07qNS6v1yURXDsbRrhnZ6z3eUmqowHM7A2DlizzG7A4jos27oPac5ZqS418bq5oHu8WjFg+ce9v3oitdx/nWkQfrZuRNAFXd/disO3DpPO5TqTTPF9tor4p9ZK0IbBOdL1qPVK+TkhflJ9qcp9U6+JyjWl3fmA/xq3FcoBA12TZ4yXl2FzGlK8Awc+HlDR6MVihwPIVrBibQd5/1FK0VndAKjL1qgljDigdt3l9bfzb+jjnv73uh+U2t+u4jcf6WOe5nNdJ9ZwMWp27+3Nxji+g0i5tq5/usl7b7UpcwVGvfBovf/kNMzAq7p6A3qKdSftHOs/XXdxrO0ZIkRRI1rRV4MynvoLKWBnaKzrx5Olr0FLdgZCqQFUkKjtKASHRUdFjO1Z7CQTaKzqTAtdznvgaqmLlruPyqlPyI0gdjfUxQ8kA2TNUcfTOfiSpVgvQmwJIxbWjWqrgwyvAyaShALM0aaQrjPeif4rv1p3LyZhomsujXAKbpGOUkH2JmrUOw5GZ8Pr02y07Ea7eA4PtH7lOtG1jSLFL/ZBYMxMpMkjTFr+dlGHwHRwEKCh/f+EEe0CnBxRBszF+GHU/XlmllB3OXAKEXNSTeAZQPrJkrHcZ+RisUGD5CFZ2fPBv3P/SmWiv6tQH4TjAbWIe5P6Rzi0ASne817HpgjC32633OY/1CvS8jrGez95wzH67W6DpJVWQB6A8VgoA6KzoTnESy+kcmTDjHCf/6ktJgVZVrNw1G5JpoGI8rq0ihp+e+StbIHb2E1+1BWJuTQ/cxmHdNFXpnI7i9xeYS8+s50mMIXirZmeTAKPTmhptB6AFUgBraTISoKOWdrxLPYTO/DQ/TVG863Ik50TSOuF2uS9aN9NzV3fAPbOTdakm/Xqw4bqEK+2Y9KVoatzXBLn3vdew9Z7jkgvzLUGSddlXUvBiuV6kxmXpm/FcbUsA3cf4/nk+SmNFyN4ZLsU4sxkcJAWOPp5PIS1no8wwWKHA8hGs/M+DB6O5vCV1VoNGr6Dfbz/Hpwqe0p0nXdYqXfAE2AOwoXAJxJS4AqlnnuKKdA3CSruLcf7jXzeDKTXaBghA2V2tn1bYAqMnT19jBmGnP3sYxtU/EyhT4tbtzHM5W1RvD21pPGBtRMGAZgTQJ9zFex8ZqPh72p0fAIAjs5OHdrcuhfp+M1gA7EX8jkACQMrMhiFdnUaqjEFSpsbn8522+G1/wYr2IO/mCC5dzPxK9bySls+5LY1zPh+2UB7xGKyMEEKIzwFollKuK4Cx5DxY+dbPpmnLvohGi0wDbrdMVapjAPcgP5MfJ+s5JczleEYAE91juedD+z+8AE+d/Ce0Vse05XsQ6KjsSgqoqtrL8dXnj8Svv/KqmTUybnfWnp34j22o6JNcXlaoLJmSwJPnfFPCCFdOstfgBG1mkE6aifxQ6jR633sNW+/40tDHmA0Bg4MgmZCUTRD06zKzMvIxWBkh9LbGEsBrAJZIKdfkcSyFk1lJVeuRDrMzRJn9HDh//tL+CrBETV7L91LVaLndLoGqjmKctepzZhCULmiKTQjhuU/WoL0ojKq+QZz0t1ZU7ByeAm6yECGEqyZjMLYts7ocL8YeLZZ9TXy1gC4oCqKN3u2IXZfQ+Zz8p5zI51Kagn6n9+dH7dkSEcJeK92frzXTYtt7x8e+NDRyMFgZIYQQnwdQBOBTAD4tpTwmj2PJS83KA787B22lAT8x9VvX4Jx4pSp291qKFrQOxOv2IMcSFaJcvVc9l95J+zG2sSQCJiElSnYNontC2DxIiQvM+9NOTOltTXnpVIFPbEIIzxxUg1hRYg/fir5BnPLXMR4chaOIVE211FkM7VxmPYxnDUN6tvbA6WQ7s+LB2XEr7Y71HpPwVF29bJRQ2i5yQxYgYHHLwk2784O0jy2kfWEouxisUGD5bl1s1fLVRxHf1A6o0jZZaa/oxBOnP5+05MQseu6pBEqiaEcTnjj9ebRUdwzr5MqtIDvv0gVo1uPc+FmORJQPUtqLyIXHG1Tq/896v1vAY1G0O45d0RBU4yGW65TuHETv+LD9PsuYjIDFGshU9A3i0//pxEv7VkNVAEUFTvlrC8p2xfHcJ2vQVhSGIgGpAFW9hZ0Nqj7jHrT94trsL/cSivZautQdJNUjGN2h3CbojsYAafeUcYg27mPfoR5I2awgY46lSr52rE+xvGnzdXNTPj+zqYKP18DP2L0COeveLinrbeZHXM/h1jaZG0+ODQxWRgAhRA2ASgAbpRympvPBxpPXYMVoYRzf1Da0fcbCCjCYpU/HQkILmIK8FCFoNcM5ZgRyRgvguKImBRtV7eX4wmuH4tkTX0m5r8yQuS0Dskp3H4MkGg4ps6QpAqC0wZHlZ8k4xnlb0q7lIjn4gnumxpnRMY4BYGaBSnYlAiojMJrakb3gQmuLuxlQB7NzQn3SCMC1c1hSt7CQPtF1yRSEq/cwa1Cs+8UAyZ3HwtV7QIQiGGjdZCuKty01cnbgavswu8vcLG2pfbWK9lgelq7BgbH3zta7jx36+MPRlMGqrS21Rwcxz6YKLgFENgMMz8CXmZa8Y7BS4IQQ3wNwCYAdAKoAPADgNpnHJ5zvYMWWTaERyZn58uxY1VUMRVVc7xtytsqr5sLta0Oq4IkoU0Yw4vW112O8uAVCxu3WgEr/dyZBS7plcEZWyPqzUrYzjm+81RIoMxSpm4m6+cv8deDykmb3d+dE1NlGOFw+0XNPGGs9he9lV0MZu8E5rjQT9aQ6ECdr1ilTzg5oQWuH/Owd4wjI3DqmGUFe0OAiZVvkDAMhLi3LDgYrBU4IsQnAJ6WUHUKIKgB3QOsKdn0ex5TXYGXH3LuBeBauGVGAgTwXHlLOWTNLxkQqFFfw5Vc+jVe+/H+Ih1SE4gpOWv0lvPLF/0NnRY/5WD8bXnpy+9udaikeUbakC36G8jtcD3oUCcz/4w5U7Izjsc/Uo70oDKkI+7WlRPGuQfRFw5B6F+uynXEc8+92/G6fStuSt/I+LTMTm2BfBvfFdzvwu30qs9MkwaO97vsLxgfLMDgmx4Efn6lQBNH6Wb4mwumWgmUmzd4uqZbkZci6lAxI3UQgXL0HZtyz0fe5rYGF6/PJoOUxl5ZlB4OVAieEeENKebjlawHg31LKT+RxTIWXWVEElMnlAAB1SyztOUJTK1D2/WPQcd7TwzRKIo01i2TUTAHISa0UAO8gicgqVUDjJ/PjlsXxOpf1frdlcG4ZICEgVAkhASkAqWhfV/UN4rzXm5IyPdagpnynPfBRFdj2OVIkcMpbLdgzMlVb6jWEYvNI3UxUnXwTmpadk/E5gjDrTSz7wLgtGetv3ojN130i+/VE1vbAjqDEXF6WxRbKxj48fjcLdatz8cPr+QQNNLjHS3YwWClwQohVAHoAfFfPrpQDWCOlPCKPYyqcmpWQAsQlQtOrUPnjryM8pcJ+zOZ2QBFabYoEoAiEpleh9tfnA9ADnw1tOR0/US64BUmdZd147KznMssMufG73wuNHX6yOOmWuAU5v1uQZDRcMb52CXycGR8jYHnmoFpbo4OM6nlc6jYidTMzX8aWQrRxn7TtiSN1MwFA63omlKzXE7luvAgtsMhegJTI4gTeKNSjE5mZSdm+Tl/yFUd0ohbgbb5mTtLzmXT1b1G895H2x6bJamWaWclk+dhoXnLGYKXACSF+COCTAPYG0AygDsAyAE8DeFtKmaXfOoHGVDDdwPywBi6haR5BzcY27+W1CgBFL8aPKKhc/g2EJpbZA6ZBVSuyH7ScJKwAcXuQVHzhYei6Km9b5BBlhXUpnaKK4W3CADDgGU2yEawAyQHHUK+TotGBkEDprji6xoeyuiTNq+4n0H5AIpS6FiUXUtTPvH9egE9GHLVESY0NhrqHTjgKDA4CYS0wgaIkL9ezNXSwZ1YidTMx/c71APwHIZkGEJkEOaN5yRmDlRFCX/41B8CB0IKXAwHsI6WcmIexjKhgJV9SBUm2+ze16dkf7XUMTa1A5fJvAIDt8cUXHoau61/IXZ1NNrulEWVg09SPs5sJMrBGaPhkEiQMJXgJeh23zEq6cXhlZgzO4EaFWZNjtKZ+Yd9qc9kZABTvjiMSl+icYKntgZbRKdkdR/f4UNJSN4O1gUGqttY53QRVCesf6vWbm3W2P/u9QNkkswNby0a961oO6n7cKCFMu32dZwe1UEUj4rFt9huz2DnMtXtbiuVjno0dUmymOdIwWCkgQogyKWVXivtnSimzn0cOiMFK4XEGRmX/82V0/eAV16+VSeUQAOJbO80gCgDaL/iFWe9j1PR03viSrxogopHAmhESKiCzuRwOcG+W4AyKGCSNXh5LzExuy9e8an8cx1ZbMjltxeHEMZZ6nvKdgwhJoK0orNX2GMGRvjSuWg9Yhm//ngw6gJkP1btvZbumJgOhikYo0aJgy/aUiJbh8tFtzsot8+IWeDjrZayPs7fTtghHsdeKnYGee6FisFJAhBBbACyUUq51uW8RgFuklCU5H1jyWBisjCGDH8VsgYy5vC3s6KYWUVB263Hovu/3kNtcWg3XlUAZH0acwQ+NEu0VnfjJmavRXqV9xqTEFaiKmt1ACAiWCWIwVHi8sjZ+lrF5ZXK8HmPcn64JguPcigrMf31HVjMzOc3sFDhjXx/XwMSsOdLrclwCtml3fmALdlJ1QTMJBXutzFN2KssYrBQQIYQK7U/NcgBXSCl7hBDTATwG4AgAkDKrfwIzwmCFhmLwoxja5j9lD2hCwrUdtagrgQgLqJZjjWVy2hK6gPvtcGkbjSCbpn6Mn5z1K8RDQ3jPpvuwm4FN4QqyRC7dhqQ+Hm9dvmbjtlkp4BoYKyrMBgWqJbPjtpwtCK+lb1ltZT1UllbYafeLEQLRiXtrmZFU3ec8ak/S7puTxZqVQijcZ7BSQIQQ/wfgU9B+BWwB8FMAiwAU64c8KaU8Kz+jS2CwQoXArSucMrkcGIzbghtD2Z0nILp/I1q/8gj316HRL6Kg4Z+XAwB6Hn8LPXe8art709SP8fhZzyUyQEHnuG6/9hn4ZE+uanls14Rl+aKP66fqsuaR2TFaT7sxAxxLW2lAay2tGucSibEJVQLGcjfLfj8SSG5YcEgjOiYIVPb046S/BduY1BfHnje+9pbR9+dJlSHxar38/sIJyRkYcyPLRFezbAQVhVC4z2ClgOhF9N8BcAuAUiR+dXwM4GIp5fN5HJ6JwQoVusAd4CKK9m8/WRdmZ2ik0LsQpm3PLoDQjGqzpbsftv2uHC3hBz+KYcOVj+CxIx4zl8hZr2ULdBjgjF1eAU7QjJJbowSpT58EoIgwpIxDQkJAoKqnPznDE44iFomby9bKdw4iLoDuCVp9UOVugdM2RFG8dbNrbciky18w2xoDwKarZqeteTECEdfakzRBwfvzI/ZxDOOSr0LYK4bBSoERQkwD8BMAhyPxa/1JaMGKZ/F9LjFYodFo91+2oOOCX2hZF73+pueHr9saDBiNB7p+8Ar356FRp/Kx02xNNYwll+EpFWmbeFg/EHDduDeFmpcusHVK9KOlZwuW/PZ0tPdtBQAoCGNCpBS9Ax2BzpNsCEXiNDJI8//phEuTDK8GCEDJ7kFAhNEzTrspJCI497B78MI7S9HUvRH1pTPwzX1vRv+yi9Dc+R+sPrgBbdF40jI1Zx2KdblV75RZeO6gajT3fYz60hn49ucfRW3JVPPYXGY7mFnJnlERrAghrgRwE4AJ0H5c1kFrVywBbAPwHSnl6vyNUMNghcg9ewMgaUJn66gWVrQJXEhwKRoVHo+sYWjPamAgjvjHna6ZFKcdc+92rUHzokytgIiEUm70my8tPVtw/6vnoKVns+cxFePr0bWrDSqStz0LiQjichBhJYxBNbuffB+7zyV4+b0HEc/9dmvkQkCBhAoBBZVFE9G1q9n+PbfMlSqjNbj82OcAAD/63/PR1L0R1cVTIKC95yRUy3kFGspm4uYTXjFv2/bhH/Gj352DtmgcFQMKwhWNaNm5DUYQFlYiuPTIn2J2/WFDfl6sWcme0RKsGO/Oj6B1BXtZCPFtALdDq1tRpZThvA1Qx2CFaGg8P6Xe1KZ9TGFk3MMKKld8A+MOnWp7/O6/bEHHwp/bNyElGi6KSM6SKIAyuSIp85hx8wsngUTnQUsAkyqjM1K19GzBj/73fGzv+g+sn/gLKGgo2xNnHHwLnnzrBvNTe+un7C09W3DXy/PQucu9cL04Wone/k4A/HCk0Ews0/ZS2dG1wRacuFFECA+evtH8+n9+/Xk0pwigAS1g+dFpQ9/twnh/ur3/coXBSgHRg5VHAVxmXfKldwRbCeCz7AZGRE62ZgMA5yWUP2EFUFXbRrdWoroIsq0vs3MrItE50JHhSbcJr1WQY8ea9U1/wgOvnR04CzTvwBvxvx/8v5QZKC38UqAieHG7gjAgJNRUHbDyzJpZSRd8AFoAAsDXc5pYNsuWWbnwyT18jWnZGR/6Oi6Vm9d82QyojADaOpZcYLBSQIQQx0kpX0hx/yVSyqW5HJPHOBisEI1Q1okahGCzABrZQgINb1+RsuDfyetYBjG5s77pT7j/1bNsS9jqSqbh7EPvSJlFcluSpyAECUCmCYK0JXnDU4ReMb4eE6Jl5ribuzenvZbfzEpYieDmE35ny2b4CVaylVm56KkZtoDKmeXJBQYrFBiDFaLRwTo5UybZ2z4rjaVQm3sZzBSaiDJ2653MpWHJmZWkOhkFCE2vNt/bAkD845i2pMzl9at56QJ0XPAL26a1oakVqH3xguF+VlRAUi15st5n1Je09n7kujTKmqEKKxGctP+1ePYfi83grKpoMi770pMA3GtWQkoIcRlHQ+mersuubvj1521Bm1EbNRw1K8ysZM+IDVaEEOcAeEJK/7lNIcRMABOllH8YvpGlvD6DFaIxwOuTZtuyM2uNDQ27ysdOQ8d5T+d7GHkj6ooh23dqQXREQeVyrabLmS2xLRfzQZlqr78xNLx7ZZafAdHQ5bKOhDUr2TOSg5V/AKiA1q54lZTynx7HVQM4FsDpAI4EsEBK+fPcjDJpLAxWiMiVGciwtXP2KfDMDIxpEb2LWThRiD/kAn9dJm2ViSi7GKwUACHEaQAugba3Sg+A9wC0AtgNLZCZDmAqgA5ou9rfJaXcmpfBgsEKEWWPbX8bQPtUvKYIaO7N78BoZNKzLbb3lF9h96YAoT2rh6V+hTUyRP4wWCkgQoi9AHwBwCcBNAAYD6AdwHoArwN4Tcphqg4LgMEKEeUCWzSPUAo8u4HlhNHyOFuX9yjYH2qwEaQpANFYxmClgAghlkgpL8v3ONJhsEJEhYJtm4eBUe9RaBQBZbJeLO9SXzL814dtzxfbRplG8b8qfQcuSU0B9M5mfoMgZmZorGCwUkCEEK0ArpZSPuJx/39JKf9fjoflNg4GK0RU8JzdzuSuAUguL0ur8rHTtI0XU9Udeex2P6zCCmrWLEB4SgWaj13uWhBfEByBi9dGll6ZlXQZF9e6MGZmaBRjsFJAhBBfBPArAMdLKX9vuV0BcB+Ab0kpo3kanonBChGNRoMfxdB+wS/MSXBoagXKvn8MOm98qXAnxmORQPaWeA03ozPZoGVZWkRBzfMLACCRFQylaA6gZ1wMtmDGynEc0WjBYKXACCG+A+AmAIdKKTfpXcBWAdgHwOlSylfzOkAwWCGisceZpcnbUqSRqFCXleWTJUvUcuxy+3tJz8p4ZVaSlo8BqTMwlowOAC4doxGHwUqeCSFCzj1WhBAPAzgCwLcBPAagBcDXpZRbcj/CZAxWiIjcObMzNAKEkJ+9gjy6jwHQ2jHrmRZnQJEU3CC5Y9ngRzG0fuWRREc0AYRmVANAUlZmuLqdEWULg5U8E0LsAvAOgL8D+If+3/cAPAstYPkJtOVfu/I1RicGK0REwXEzzTFKERnt+aI0lkJMiCZlQZz1OsrUCtS9eIHtsS1ffTS55igktP/6yMoQFRIGK3kmhDgdwH4ADgCwP4CJ0PrZdED7c3Y/gH8BeFtKuTFPw7RhsEJENPy4B00ByEJ9TGjP6sw3STUCHaMTWiTkGoTYuohtanPvihdJsaEo612ogDFYKTBCiBokApf99X/PARAG0COlLMvb4HQMVoiICgP3oil8ytQKqFs7s1O345GlUaZWQN3WlVmHNmZWqMAxWBkBhBARAPsC2E9K+XgBjIfBChFRATM/Zd/YNnI6Z41WAnpHMP0bYWxaGUqzceZwtodWgND06mEttOc+MJQtDFYoMAYrRESjS9KSM8qJ0NQK1L54AXbsc1fSfUpjKdRt3e4PzLAOxnbtNIX1Qw020u0XQ+QXgxUKjMEKEdHYwg02c0s0lkI29XguHQvtWQ0MxBH/uDPzoMWxeaURjKRaWqhMrdB6Q2ztTNsOOanF8hDqYpilGdsYrFBgDFaIiMjJGdBgMO6dGaDUUi0B0yf9tmxYWECpK4Xa1A1lUnnw1tnOpWp+HxN2FO1bMijZzKy4bYTJlstjB4MVCozBChERDQX3oxmiiAKltgTqjm7XYMDZ3jgf48OgqtfnuO8XE4TXRphmhzRmXEY1BisUGIMVIiLKBa/lP33Pv4uuq9bke3iFxbLMqqCCwYiCmucX+A4i3L7nWkvmdvclb0b9jseyNi4hG/kYrFBgDFaIiKjQuNZauO2TkoW9UwqG13MxJu5xCWVyBsvChoOe/UlV5wIALccuR9w63rCCyhXfQNcPXrHvMZOqycAwLUej/GCwQoExWCEiopHOmX0ITa1A2fePGVn71gxne+Nci2jBlVcAEtqzGmX/82UtaNGDHLmz37suSs80ZbPQn/JjtAQr4XwPoNAJIWYCuBLAYdD2bPmDlPLIvA6KiIgoT8JTKlD34gVJt9esWRhsj5p8BgyjJVAB0rbNjm9sQ9cPXrFlRVqOXe5+sCIQmlYFAAhNq7JnVvTbnbhcjIYbMytpCCFOBPBDAH+CFqw0ZRqsMLNCRESkMSe5m9qAkKWw3PjvMO1do0ytKIzlXUDuAraQQM1vFvqrxxFAaEZyNsYrCLEtF3N0RwtNrUDl8m8weMmT0ZJZYbCShhBCkVKq+r9XAahhsEJERDS8nJ/YWyfPme5ZY0yeC6aIXoFWQ1Joy+cC1Ki4dhyzCO1ZzVqXPGGwMgYxWCEiIiosSRkaveVvqszA4EcxtB6/HIjnd+wACrpxQeVjpyW9hgDsr3e6DFgGtS5cWpYdDFbGoHTBijMYSScXr/2H3W0466VHsbm7Lf3BaZw7+zDcevhJQx8UERFRntmCHGd2I8jyrLACSJkyuzBmRJKDl9DUCtS61Dilwk5k2cFgZQwaicHKF55dgg9izcN+HTc3HXICLtj3s3m5NhERUaa8Ptn3ut21/fMYJBpLIT26jIm6EgAysXRPb6087tCpScdm2omMGRk7Bitj0EgMVvZ47FrEC/h7zGwNERGNNrv/sgUdF/xCyzKEBURVMWRzj/2gsIKyxceh6/oXUi6lUhpLobb0DlvDgbwKaV3GnMFFJpmVwY9iaP3KI4nXSW8UMJYzMgxWxqCRGKzkM7MyVMzMEBHRaGfNBiiTyoHBuLkHitEQANDrRDYEWNKtT/IxELdvFllojE0qFQHRUAJpDcwUAWVyOQSA+NbO5LoZS5Dj+vqkyMiYr7u11XZEQeVy92zPSMRgZQwaiQX22axZKRRFoQhePnkR9iitzvdQiIiIcsZtuZmxKWeqZgJD6X4WmlqBCWcciJ47Xs3CMwh6cdibIOjZEgD2dskera6dncisgaFWp6QmNzeIKGj45+VZfyr5wGBlDBqJwcpQLf/3H/C9N9fkexi+zK1sxAsnXZrvYRARERUkt5oOIDlL4Vbn0XzscnvAU1cMdOwc2vK0sKIFHHpmBaqPeVFIaP9N19AgoqDm+QW252JbXpZCw7tXph/HCMBgZYwQQhQBOF7/8nIAZQBu0r/+jZSyL8C5RlywEtQZLyzHH3ZsyPcwTMdM3huPHHVuvodBREQ0oqUqXk9VY5K0aaQeoDj3zglNq0L8w460XdhCezoyKx7HuAVdO/a9O31AxMxKwWGwkoYQYhqATR53T5dSbg5wrlEfrKRTCJkaZmCIiIiyJ1UgE6RDl60xQUTRlmg5gpeal7Q2yK7LudIU4+/Y/57kTJB1n5ss1qwUQmcyBisUGIOV1J7d8Hdc8vun83LtpZ87DSfveWBerk1ERETJnMGLWyARJCjYse9dgDVWUYCGfw/Pkq9C2CuGwQoFxmAlcyf9+sd4q3VLzq53cM1UPPfVi3N2PSIiIhpeuQwgMt0rJpsYrFBgDFayK5dLylj7QkRENLLlcmkWMyvZw2AlhxisDL83tm/AqS8uH/brMPNCREREXlizkj0MVnKIwUp+5KIW5rMNe+LJ4y4Y1msQERER+cVghQJjsFI4hrvF8qVzv4CrDj5m2M5PRERElAqDFQqMwUrhGs7sS1EogpdPXoQ9SquH5fxERERETgxWKDAGKyPHcNa+sFifiIiIhhuDFQqMwcrINVyZl8lFFfjTaddk/bxEREQ0tjFYocAYrIwew5V5+fmxF+DwiXtm/bxEREQ0tjBYocAYrIxed771Eh54+9WsnpMdxoiIiChTDFYoMAYrY8eXnlmC9V3NWT3n0s+dhpP3PDCr5yQiIqLRicEKBcZgZWwajiVjDFyIiIgoFQYrFBiDFQKAS197Cr/c9I+snY+BCxERETkxWKHAGKyQU7ZrXeZWNuKFky7N2vmIiIhoZGKwQoExWKFUsr1cjAX6REREYxeDFQqMwQoFkc0i/ZsOOQEX7PvZrJyLiIiICh+DFQqMwQplasHLj+Olj9/Lyrm4ESUREdHox2CFAmOwQtlwxgvL8YcdG7JyrmMm741Hjjo3K+ciIiKiwsFghQJjsELZls3AZXZZHX57ymVZORcRERHlF4MVCozBCg2nbBboH1wzFc999eKsnIuIiIhyj8EKBcZghXLl2Q1/xyW/fzor56qJFuMfZ/1PVs5FREREucFghQJjsEL5kM3AhRkXIiKikYHBCgXGYIXyLZtLxS6d+wVcdfAxWTkXERERZReDFQqMwQoVkmxmXH5+7AU4fOKeWTkXERERDR2DFQqMwQoVquX//gO+9+aarJzr9XlXYo/S6qyci4iIiDLDYIUCY7BCI0G2Mi4N40vx1hnXZ2FEREREFBSDFQqMwQqNNHN/+j10DOwc8nm4+SQREVFuMVihwBis0Ej2pWeWYH1X85DPc+7sw3Dr4ScNfUBERETkicEKBcZghUaLw56+HR/3xYZ8nqWfOw0n73ng0AdERERENgxWKDAGKzQaHfCzH6C1v3fI52HgQkRElD0MVigwBis0mn3Y3YbPrLpryOcpC4/Du+d8LwsjIiIiGrsYrFBgDFZorFjw8uN46eP3hnwedhQjIiLKDIMVCozBCo1Fl772FH656R9DPs/cyka8cNKlQx8QERHRGMBghQJjsEJjXbYCl0vnfgFXHXzM0AdEREQ0SjFYocAYrBAlZKuj2E2HnIAL9v3s0AdEREQ0ijBYocAYrBC5++wv7sKmnrYhnUMA+OO8K7FHaXV2BkVERDSCMVihwBisEKV351sv4YG3Xx3SOYqUCN4/9wdZGhEREdHIw2CFAmOwQuTf8n//Ad97c82Qz3NwzVQ899WLszAiIiKikYPBCgXGYIUoM9kqzD9m8t545Khzhz4gIiKiAsdghQJjsEI0dHs9/j/oUweGfB4W5hMR0WjGYIUCY7BClF1zf/o9dAzsHPJ5ln7uNJy854FZGBEREVFhYLBCgTFYIRoeb2zfgFNfXD7k8ygQ+MO8K9hRjIiIRjwGKxQYgxWi4Zetwvyy8Di8e873sjAiIiKi3GOwQoExWCHKrWc3/B2X/P7pIZ9nclEF/nTaNVkYERERUW4wWKHAGKwQ5c9xzz2Atzu2Dfk8cysb8cJJl2ZhRERERMOHwQoFxmCFqDAc9vTt+LgvNuTzNIwvxVtnXD/0AREREWUZgxUKjMEKUeHJVkexS+d+AVcdfEwWRkRERDR0DFYoMAYrRIUrWx3FAOCzDXviyeMuyMq5iIiIMsFghQJjsEI0MnzY3YbPrLorK+dijQsREeUDgxUKjMEK0ciTrVbIAHBwzVQ899WLs3IuIiKiVBisUGAMVohGtjvfegkPvP1qVs719ekH4IEjT8/KuYiIiJwYrFBgDFaIRo9sBi7nzj4Mtx5+UlbORUREBDBYoQwwWCEanRa8/Dhe+vi9rJxrekk1/vCNK7NyLiIiGrsYrFBgDFaIRr8zXliOP+zYkJVzsasYERFlisEKBcZghWhsyeZSseJwFGtP+m/sUVqdlfMREdHoxmCFAmOwQjR2ZbOrGAD8/NgLcPjEPbN2PiIiGl0YrFBgDFaICND2cfncqrsQz9L52BKZiIicGKxQYAxWiMjpw+42fOGZJeiX2QldaqLF+MdZ/5OVcxER0cjFYIUCY7BCROnM+X83oifen5VzKRD4w7wrWOdCRDQGMVihwBisEFEQxz33AN7u2Ja183G5GBHR2MFghQJjsEJEmbr0tafwy03/yNr5ysLj8O4538va+YiIqLAwWKHAGKwQUTZku7MYAFw69wu46uBjsnpOIiLKHwYrFBiDFSLKtje2b8CpLy7P6jlZpE9ENPIxWKHAGKwQ0XA76dc/xlutW7J6TmZdiIhGHgYrFBiDFSLKpTNeWI4/7NiQ9fPedMgJuGDfz2b9vERElD0MVigwBitElE/DkXURAP4470q2RyYiKjAMVigwBitEVCiGI3ABgK9PPwAPHHl61s9LRETBMFihwBisEFGhOuBnP0Brf2/Wz3vu7MNw6+EnZf28RESUGoMVCozBChGNBMPRGtnAYn0iotxgsEKBMVghopHouOcewNsd24bl3LPL6vDbUy4blnMTEY1lDFYoMAYrRDQafOmZJVjf1Tws5z64Ziqe++rFw3JuIqKxhMEKBcZghYhGo+FqkWw4ZvLeeOSoc4ft/EREoxGDFQqMwQoRjXbDWe9imFvZiBdOunRYr0FENNIxWKHAGKwQ0VjzxvYNOPXF5cN6jZBQ8OQxC3D4xD2H9TpERCMJgxUKjMEKEY11H3a34Yu/vBe71cFhvY4A8PSxFzCAIaIxi8EKBcZghYgo2T4/uQldg7uH/Trc84WIxhIGKxQYgxUiovQWvPw4Xvr4vZxci62TiWi0YrBCgTFYISIKLhd1L05LP3caTt7zwJxek4gomxisUGAMVoiIsuP6N57D4+v/lNNrfrZhTzx53AU5vSYRUaYYrFBgDFaIiIbPpa89hV9u+kfOr3vTISfggn0/m/PrEhGlwmCFAmOwQkSUW8O9YWUql879Aq46+Ji8XJuIiMEKBcZghYgo//KxhMyKmRgiygUGKxQYgxUiosKU7wAGAGrHl+C5r1yEPUqr8zoOIhodGKxQYAxWiIhGjly2UPaDGRkiCoLBCgXGYIWIaOQrhCyMG7ZbJiIrBisUGIMVIqLRq9AyMVaKEHjqmIU4fOKe+R4KEeUIgxUKjMEKEdHY9OyGv+OS3z+d72GkdO7sw3Dr4SflexhElCUMVigwBitERGT1YXcbjl39ALoHdud7KL6xJTPRyMBghQJjsEJERH4t//cf8L031+R7GEPCwIYofxisUGAMVoiIKFvyueHlcGH7ZqLsYbBCgTFYISKiXBkJdTLZxCwOkR2DFQqMwQoRERWSN7ZvwKkvLs/3MApGQ1EZnjn+QmZ2aFRgsDJGCCH2AbAUwKcBxACsAPA9KWU8g3MxWCEiohHnw+42HP3c/egd7M/3UEYsbupJucZgZQwQQlQCeAfAuwDuALAngHsA3CulvCGD8zFYISKiUW00NAYYTSYXV+Dp4y5gtmgMYrAyBgghrgVwFYA9pJRd+m1XAbgZQINxW4DzMVghIiKyeGP7Bpz+4nKo+R4IDTsFsH2fbzrkBDzxwZvY2NmCGeW1uHS/L+CyP67CgOq+eMUIvADgvFcex8bOFkwpqQIAbOlugyIUDErtCtNKq/GzY84f00Eag5UxQAjxewDbpJSnW26bCuBDAF+TUv7acXygF5OvPRERUWY+7G7D1379Y7Tt7s33UGgIFAiokOZ/05lVUQcA2BBrSXv8rIo6vHryZebXb2zfgLPWPooBNY6wUNBQVIatvTHzLBElhJ8dfT4On7hnxs/H8GF3mxlQzSivxWNfPjfngRODlTFACNEM4MdSypsdt/cCuFlKeZfjdgYrREREI8iH3W34+pqH0LSzO99DIR9CQgAA4j7mUCEh8OF5t5lfT3/8es+sjSGihLDp3FuHNkgAX3h2iRlQKRDYs6LWFjjlwmgJVsL5HkCBq4RWVO/Uod9HREREI9gepdX46+nXD8u573zrJTzw9qvDcu7RImhmZUZ5LQB/mRXjWEO6QMXvMX5s7EyMT4XExs6WrJx3LGKwkp7bT4LwuJ2IiIgIAHDVwcfkde+XN7ZvwBkvrkC8QKYs2ahZeezL5wLwV7NiHGuIKCFfmZVsmFFea8usOAMn8o/LwFLQl4H9SEr5PcftPdDaF9/l/kjP87HAnoiIiCgPWLMyMjFYSUEvsN8qpTzDctsUAFvgUmDv43wMVoiIiIho2I2WYEXJ9wAK3AsAjhFClFpuOw3ATgD/m58hERERERGNDQxWUnsIwG4AvxRCfFkI8U1oe6wsCbrHChERERERBcMC+xSklB1CiC8B+CGAX0PrDHYvtICFiIiIiIiGEYOVNKSU7wL4Yr7HQUREREQ01nAZGBERERERFSQGK0REREREVJC4DCyPhBD5HgIRERERUcFiZoWIiIiIiAoSgxUiIiIiIipIDFaIiIiIiKggsWYlt1oBfDjM1zjI8fVfh/l6RNnG9zCNdHwP02jA9/HIt0e+B5ANQkqZ7zFQFgkhbN9QKSWr+GlE4XuYRjq+h2k04PuYCgWXgRERERERUUFisEJERERERAWJwQoRERERERUkBitERERERFSQGKwQEREREVFBYrBCREREREQFia2LiYiIiIioIDGzQkREREREBYnBChERERERFSQGK0REREREVJAYrIwiQoh9hBC/FUL0CSG2CSG+L4QI5XtcRH4JIWYKIZYJIf4phIgLIV7L95iIghBCfEMI8SshxFYhRI8Q4q9CiDPyPS4iv4QQ84QQbwgh2oQQu4QQ64UQNwghovkeG41N4XwPgLJDCFEJ4BUA7wI4EcCeAO6BFpDekMehEQXxCQDHA/gTAP5hpJHoMgCbAHwXQCu09/MTQogaKeXSvI6MyJ9qAK8CuAtADMChAG4G0ADgO3kbFY1Z7AY2SgghrgVwFYA9pJRd+m1XQf8FY9xGVMiEEIqUUtX/vQpAjZTyyPyOisg/PShpddz2BIBPSymn52lYREMihLgVwLcBVEpOHCnHuAxs9DgOwEuOoOQpABMAfD4/QyIKxghUiEYqZ6Ci+zuAulyPhSiL2sBsN+UJg5XRYw6AddYbpJRbAPTp9xERUX4cDm2JLtGIIYQICSGKhBBHALgUwIPMqlA+sGZl9KiEtrbUqUO/j4iIckwI8SVodYTn53ssRAH1Ahin//v/Abgyj2OhMYyZldHF7RMP4XE7ERENIyHENABPAFgtpXwsv6MhCuxwAJ8FcDm0gPuH+R0OjVXMrIweHQAqXG4vh3vGhYiIhokQogrACwC2ADg7z8MhCkxK+Tf9n38UQrQCeFwIcY+UckM+x0VjDzMro8c6OGpThBBTABTDUctCRETDRwhRBOB5aAXJJ0gpe/M8JKKhMgIXdrSjnGOwMnq8AOAYIUSp5bbTAOwE8L/5GRIR0dgihAgD+AWAWQCOk1I253lIRNnwGf2/m/I6ChqTuAxs9HgIWreOXwoh7gAwA9oeK0u4xwqNFPon0sfrX04CUCaEmKd//RspZV9+Rkbk24+hvYf/G0CVEOIwy31/l1Luzs+wiPwRQrwIbZPpdwDEoQUqlwN4mkvAKB+4KeQoIoTYB1oB3Keh1amsAHCzlDKez3ER+aUXJHt9cjddSrk5d6MhCk4IsRnAHh538z1MBU8I8QMAJwOYBmAQwEYAKwE8JKUcyOPQaIxisEJERERERAWJNStERERERFSQGKwQEREREVFBYrBCREREREQFicEKEREREREVJAYrRERERERUkBisEBERERFRQWKwQkREREREBYnBChERAdA25RRCSH1zTs/bRpux+ryJiEYCBitERERERFSQGKwQEREREVFBYrBCRES+CSGO15dHSSHE1fptihDi//TbPhZCVIy1sRAR0fBgsEJERL5JKX8DYKX+5U1CiOkAvg3gMP22C6SUsbE2FiIiGh7hfA+AiIhGnO8C+DKAKQB+AmA//fYVUsoXxvBYiIgoyxisEBFRIFLKTiHEQgAvAfiMfvMWAJcHPZcQohzARB/XXDfcY0lFCDEFwGMAGgGoANYAuFpKKbN5HSIismOwQkREmXgZwDoAc/Svfyql7MrgPN8AsNzHcSIHY0llEFpw8pYQIqpf8+sAnsnydYiIyII1K0RElImLkQgOAGCREGJP4wshxI+EEM/oxe4fCiG+73YSKeUKKaVI97+hjEUfz2QhxG+EEP/Qx/WGEGIfv09WSrldSvmW/u9+AP+CtvSMiIiGEYMVIiIKRAgxA8Ad+pdPAtgKoAjAY0II4+/KJwH0ATgCwIEALhFC1OVjLEIIAeAJAD+UUh4AYDWAAwCsz/Ca1QBOgrb0jIiIhhGDFSIi8k2f+D8KoBjAdmhZjYv0u48A8N96kLA3gO9KKeNSynYAOwBU5nos+r+PB9Cjdw8DgH8D+JeUMp7BNccBWAXgPinle0MYPhER+cBghYiIgrgEwOf1f39HShmTUv4awFP6bbcC2BdAi5SyFQCEEFUAqgFszPVYhBB7QcvsvGV53AEA/h70YkKIEICfAfi7lPKejEdNRES+MVghIiLfpJQPWGpJfmm5/Qz9tiIAcwHUCSEq9ezHnQCWSikHcj0WKeX7ANqgZXoghJgM4HpkEKwAWAagG1nuNEZERN4YrBARUbZ9EtrE/nkA7wJoAbA4j+N5AkC9EOI9ALcBaEbAYEUI8RkACwAcDODveqH+pVkfKRER2bB1MRERZduBAK6UUl6V74EA2l4sAD5nfC2E2A7g7YDneB2p2ycTEdEwYGaFiIiy7RMIGAzkir4MrE1KuSvfYyEiovQEN98lIiIiIqJCxMwKEREREREVJAYrRERERERUkBisEBERERFRQWKwQkREREREBYnBChERERERFSQGK0REREREVJAYrBARERERUUFisEJERERERAWJwQoRERERERUkBitERERERFSQGKwQEREREVFBYrBCREREREQFicEKEREREREVJAYrRERERERUkBisEBERERFRQWKwQkREREREBYnBChERERERFSQGK0REREREVJAYrBARERERUUFisEJERERERAWJwQoRERERERUkBitERERERFSQGKwQEREREVFBYrBCREREREQFKZzugL/97W/HhMPhm6SUDWBwQ0REREREQ6cKIWJSyn8ODg4uPuiggz5wO0hIKT3P8Le//e2YcePG/XDatGn9EyZM2KUoivfBREREREREPkgpMTAwEO7q6iresWOH3L1796UHHXTQi87jUmZKwuHwTdOmTesvLi7eyUCFiIiIiIiyQQiBaDQ6WFNT0zlt2rTBSCRyldtxKYMVKWXDhAkTdg3PEImIiIiIaKwrLi7uk1JOd7svXQ2KwowKERERERENFyEEAAi3+1gwT0REREREBYnBChERERERFaQxF6w88MAD1UKIg4z/RSKRT06ZMmXf73znO5P6+vrM9NPzzz9faj1OCHFQTU3N/p///Odnvvrqq0XWc7oda/xvyZIlNbl/lqOH3++XX+vXr4+m+r4Y38vnnnuu1O3+SZMmzT3xxBNd11QaOjo6lG9+85uTDz300NklJSUHCiEOev75513P5+ayyy5rFEIc5Pd4Knwj8X28evXq0hNPPHH6lClT9h0/fvwnp0yZsu9ZZ501devWrWlb3gN8H482Xn/jrP+bNGnS3GxdL917PJ2XXnqp5JRTTpk2a9asT4TD4cBjmzRp0txTTjllWibXpsIzkt6/g4ODuPHGG+sPO+ywvaqrq/cvLi4+cJ999tn73nvvrYnH477OMdrev77+6IxGjz766MapU6f2d3V1hZ555pmKH/3oRw3d3d3K448//pH1uFtuueWjww47rFdKiS1btkSXLFnS8NWvfnX2W2+99c6cOXP63Y613rb33nvvzsXzGe38fr8KQXNzc/jpp5+u+cQnPtH3mc98pmvt2rUV+R4TFYaR9D5+6KGHant7e0NXXHHF9pkzZ+5ev379+Ntvv73xU5/6VPk777zzTnl5uZrvMVLuvPLKK+usX59++ul7zpkzZ+fNN9+8zbht/PjxBfOeWLt2belf/vKXkv32269PCCF7e3tD+R4T5c9Iev/29vYq995778RTTjml7Tvf+U5zaWlp/Pnnny+//PLL91i3bt34ZcuWfZzvMebamA1WDjnkkL599913NwCcfPLJXRs3bhz385//vObRRx/9KBRK/E77xCc+sfNLX/qSEYD0HnrooX1z587dd/Xq1eVz5sxpsZ7TcSxlkd/vVyGYNWtWf2dn5z8A4LnnnisdTcHKzp07xYQJE9h0I0Mj6X38yCOPbGlsbBw0vj7hhBN69t57713HH3/87JUrV1YuWrSoLZ/jGwq+j4Nz/m2LRqOyqqpqsFD/5t15553b77nnnu0AcOKJJ05/6623SvI9pmzYvXu3iEQiUlHG3MKYIRlJ79/i4mL1P//5z9v19fVmGuXEE0/sjsVi4ccee6zunnvu2VpSUjIif39l+v7lu123//77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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.font_manager import FontProperties\n",
    "from matplotlib.ticker import FuncFormatter, MaxNLocator\n",
    "\n",
    "def kernel_val_vs_distance(data, kernel_dicts):\n",
    "    if isinstance(data, torch.Tensor):\n",
    "        data = data.detach().cpu().numpy()\n",
    "    edits = cdist(data, data, metric='euclidean')\n",
    "    triu_inds = np.triu_indices(edits.shape[0], k=1)\n",
    "    triu_edits = edits[triu_inds]\n",
    "    sorted_inds = np.argsort(triu_edits)\n",
    "\n",
    "    colors = misc.get_colorbrewer2_colors(family='Dark2')\n",
    "    \n",
    "    small_font = FontProperties()\n",
    "    small_font.set_size(16)\n",
    "    \n",
    "    fig, axes = plt.subplots(figsize=figsize)\n",
    "    \n",
    "    #plt.title('Kernel value vs Euclidean distance')\n",
    "    \n",
    "    for i, k in enumerate(kernel_dicts):\n",
    "        plt.scatter(triu_edits[sorted_inds],\n",
    "            k['kernel'][triu_inds][sorted_inds],\n",
    "            c=colors[i], s=lw*2,\n",
    "            label=k['plot_lbl'])\n",
    "    plt.legend(prop=small_font, loc='upper center', \n",
    "               bbox_to_anchor=(0.47, -0.2), ncol=5)\n",
    "    plt.ylabel('$k(\\mathbf{x}_p, \\mathbf{x}_q)$', fontsize=ts)\n",
    "    plt.xlabel('$|| \\mathbf{x}_p - \\mathbf{x}_q ||_2$', fontsize=ts)\n",
    "    \n",
    "    axes.grid(False)\n",
    "    axes.set_facecolor('w')\n",
    "    axes.axhline(y=axes.get_ylim()[0], color='k', lw=lw)\n",
    "    axes.axvline(x=axes.get_xlim()[0], color='k', lw=lw)\n",
    "    plt.xticks([0, 1, 2, 3], fontsize=ts)\n",
    "    plt.yticks([0, 1, 2, 3], fontsize=ts)\n",
    "    axes.tick_params(axis='both', length=lw, direction='out', width=lw/2.)\n",
    "\n",
    "    filename = 'distance_awareness'\n",
    "    if filename is not None:\n",
    "        fpath = filename\n",
    "        plt.savefig(fpath + '.pdf', bbox_inches='tight')\n",
    "        plt.savefig(fpath + '.png', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()\n",
    "\n",
    "kernel_val_vs_distance(X_moon, kernels_moon)"
   ]
  }
 ],
 "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
