{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "24eb25c8-c636-46a9-b29a-799a5e0c3c15",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch \n",
    "import pickle\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "from __future__ import absolute_import\n",
    "from __future__ import division\n",
    "from __future__ import print_function\n",
    "from __future__ import unicode_literals\n",
    "\n",
    "import torch.optim as optim\n",
    "from torch.optim.lr_scheduler import CosineAnnealingLR\n",
    "\n",
    "import argparse\n",
    "import torch.nn.functional as F\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib as mpl\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "import numpy as np\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "import torch\n",
    "from torch import nn, Tensor\n",
    "from torch.nn import TransformerEncoder, TransformerEncoderLayer\n",
    "from torch.utils.data import dataset\n",
    "import math\n",
    "\n",
    "from torch_geometric.nn import GCNConv\n",
    "from torch_geometric.nn import global_mean_pool\n",
    "from torch_geometric.nn import global_max_pool\n",
    "from torch_geometric.data import Data\n",
    "from torch_geometric.loader import DataLoader\n",
    "\n",
    "import lightning as L\n",
    "import wandb\n",
    "\n",
    "import scipy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "878365b0-6cc1-468b-9a6c-341b4e37ea01",
   "metadata": {},
   "source": [
    "For processing data we used the code at: https://github.com/liyaguang/DCRNN/tree/master/scripts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "035581a8-b88e-4d2a-84d8-b798291380ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 0.0 # Treshohold\n",
    "\n",
    "colors = ['w' , '#F601FF'] # first color is black, last is red\n",
    "cm = LinearSegmentedColormap.from_list(\n",
    "        \"Custom\", colors, N=4000)\n",
    "\n",
    "df = pd.read_csv('graph_sensor_locations.csv')\n",
    "DIST = np.array( df[['latitude' , 'longitude']] )\n",
    "\n",
    "DIST = torch.tensor(DIST)\n",
    "\n",
    "d = (DIST[:,0:1] - DIST[:,0:1].T)**2 + (DIST[:,1:2] - DIST[:,1:2].T)**2\n",
    "A = torch.exp(-d/torch.var(d , 0))\n",
    "A[A<k] = 0\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ec0ae3d3-26eb-4725-8c41-3fc5bd734d22",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████| 23974/23974 [00:01<00:00, 20294.76it/s]\n"
     ]
    }
   ],
   "source": [
    "X = np.load('train.npz')\n",
    "\n",
    "Y = X['y']\n",
    "X = X['x']\n",
    "\n",
    "\n",
    "vy = np.std(Y,0)\n",
    "X = scipy.stats.zscore(X , axis = 0)\n",
    "Y = scipy.stats.zscore(Y , axis = 0)\n",
    "\n",
    "\n",
    "dataset = []\n",
    "\n",
    "for i in tqdm(range(len(X))):\n",
    "\n",
    "    dataset.append(   (torch.tensor(X[i]).transpose(0,1) , torch.tensor(Y[i]).transpose(0,1)  ,\n",
    "                       DIST)    )\n",
    "\n",
    "\n",
    "train_dataloader = DataLoader( dataset , batch_size = 16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "230f3bac-6231-49aa-ba88-b3b2f281e47f",
   "metadata": {},
   "outputs": [],
   "source": [
    "class TransGraph (L.LightningModule):\n",
    "\n",
    "    def __init__(self, dist , d_model: int, num_heads, dropout = 0.1 ):\n",
    "        \n",
    "        super().__init__()\n",
    "\n",
    "        torch.set_float32_matmul_precision('high')\n",
    "        \n",
    "        self.num_heads = num_heads\n",
    "        self.timepoints = 3\n",
    "        self.d_model = d_model\n",
    "        self.dropout = nn.Dropout(p = dropout)\n",
    "        self.dist = dist\n",
    "\n",
    "        self.emb = nn.Linear(2,self.d_model)\n",
    "        self.time_enc = TimePositionalEncoding(self.d_model)\n",
    "        self.node_enc = nn.Linear(2,self.d_model)\n",
    "\n",
    "        self.qkv1 = torch.nn.Linear(self.d_model , 3*self.d_model )\n",
    "        self.dropout = torch.nn.Dropout(p=dropout)\n",
    "        self.Matt1 = torch.nn.MultiheadAttention(self.d_model , self.num_heads , batch_first=True )\n",
    "        self.fc11 = torch.nn.Linear(self.d_model , self.d_model )\n",
    "        self.fc12 = torch.nn.Linear(self.d_model , self.d_model )\n",
    "        self.qkv2 = torch.nn.Linear(self.d_model , 3*self.d_model )\n",
    "        self.Matt2 = torch.nn.MultiheadAttention(self.d_model , self.num_heads , batch_first=True )\n",
    "        self.fc2 = torch.nn.Linear(self.d_model , self.d_model )\n",
    "\n",
    "        self.proj = torch.nn.Linear(self.d_model , 2 )\n",
    "\n",
    "        self.node_time_proj = torch.nn.Linear(207*self.timepoints , 207 )  # Proj p\n",
    "\n",
    "       \n",
    "\n",
    "    def forward(self, x , pos) :\n",
    "\n",
    "        x = x.float()\n",
    "        # x = x.unsqueeze(-1)\n",
    "        \n",
    "        \n",
    "        _ , num_ch , time_step , num_features = x.size()\n",
    "\n",
    "        \n",
    "        out =  self.time_enc( self.emb(x) )  + self.node_enc( pos.float() ).unsqueeze(2).repeat(1, 1,time_step ,1 )\n",
    "        \n",
    "        out = out.transpose(1,2).reshape(-1,num_ch*time_step,self.d_model)\n",
    "        \n",
    "        qkv =  self.qkv1(out )\n",
    "        q,k,v = torch.split(qkv ,self.d_model, dim=-1 )\n",
    "        \n",
    "        attn_output , att_weight = self.Matt1(q,k,v  , attn_mask =  A.cuda().repeat(time_step,time_step).float())\n",
    "        out = out + attn_output\n",
    "        out = out + self.fc12( F.relu(self.fc11(out)) )\n",
    "        out = self.dropout (out)\n",
    "\n",
    "        qkv =  self.qkv2(out )\n",
    "        q,k,v = torch.split(qkv ,self.d_model, dim=-1 )  \n",
    "        \n",
    "        attn_output , att_weight = self.Matt2( q,k,v , attn_mask =  A.cuda().repeat(time_step,time_step).float() )\n",
    "        out = out + self.fc2( (attn_output) )\n",
    "        out = self.dropout(F.relu( out) )\n",
    "        #, attn_mask =  A.cuda().repeat(time_step,time_step).float()\n",
    "        \n",
    "        out = self.proj(out)\n",
    "        \n",
    "        out = self.node_time_proj(out.transpose(-1,-2)).transpose(-1,-2)\n",
    "\n",
    "        return out , att_weight\n",
    "\n",
    "\n",
    "    def training_step(self, data  , batch_idx):\n",
    "\n",
    "        T = self.timepoints ## either 3 or 6 or 12 only train for 12\n",
    "\n",
    "        T_after = 3\n",
    "\n",
    "        x_orig , y , pos = data  \n",
    "        x = x_orig.float()[:,:,12-T:12,:] \n",
    "        \n",
    "        pred , _ = self(x , pos)\n",
    "        \n",
    "        pred = pred.unsqueeze(2)\n",
    "         \n",
    "        \n",
    "        for t in range(1,T_after):\n",
    "\n",
    "\n",
    "            eps = torch.rand(1)\n",
    "            tau = torch.tensor(1)\n",
    "            tresh = tau\n",
    "\n",
    "            if eps<tresh:\n",
    "                label = y\n",
    "            else:\n",
    "                label = pred\n",
    "                \n",
    "            x = torch.cat( (x_orig[:,:,12-T+t:12,:].cuda() , label[:,:,0:t,:].cuda()) , dim = -2)  # teacher forcing\n",
    "            \n",
    "            out  , _ = self(x .cuda(), pos.cuda() ) \n",
    "            out = out.unsqueeze(2)\n",
    "            \n",
    "            pred = torch.cat( (pred,out) , dim=2)\n",
    "        \n",
    "        loss = F.torch.nn.functional.mse_loss (pred.float()  , y[:,:,0:T_after,:].cuda().float() )\n",
    "\n",
    "\n",
    "        return loss\n",
    "\n",
    "    def configure_optimizers(self):\n",
    "        \n",
    "        optimizer = optim.Adam(params=self.parameters(),\n",
    "                           lr = 1e-3)\n",
    "        \n",
    "        scheduler = CosineAnnealingLR(optimizer, T_max = 1000)\n",
    "        \n",
    "        return [optimizer], [{\"scheduler\": scheduler, \"interval\": \"epoch\"}]\n",
    "        \n",
    "    \n",
    "model = TransGraph(DIST , 32 , 16, 0.1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5388b05-b472-476e-afd7-e1a1dc4391bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "trainer = L.Trainer(max_epochs = 20  , devices= [0,1,2,3], accelerator=\"gpu\" , precision=\"bf16-mixed\"  \n",
    "                   )\n",
    "\n",
    "\n",
    "trainer.fit(model=model, train_dataloaders = train_dataloader)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "be6e9d50-3f61-43af-b9eb-7401b23a573b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.save(model.state_dict() , 'transformer_trafic_best_30.pt' )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "68389c81-f0f7-4d2d-b0db-599fdd02891c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# model.load_state_dict(torch.load('transformer_trafic_best.pt'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "91e413f3-923a-4a3c-8ddd-b52000c7267f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████| 6850/6850 [00:00<00:00, 22395.50it/s]\n"
     ]
    }
   ],
   "source": [
    "X = np.load('test.npz')\n",
    "\n",
    "Y = X['y']\n",
    "X = X['x']\n",
    "\n",
    "# X = (X-m)/v\n",
    "vy = np.std(Y,0)\n",
    "X = scipy.stats.zscore(X , axis = 0)\n",
    "Y = (Y - np.mean(Y,0))/vy\n",
    "\n",
    "dataset = []\n",
    "\n",
    "for i in tqdm(range(len(X))):\n",
    "\n",
    "    dataset.append(   (torch.tensor(X[i]).transpose(0,1) , torch.tensor(Y[i]).transpose(0,1)  ,\n",
    "                       DIST)    )\n",
    "\n",
    "test_dataloader = DataLoader( dataset , batch_size = 4 , shuffle = False )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ccffe66b-62c8-4a9b-bca9-fa8398dadfab",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████| 1713/1713 [00:13<00:00, 124.23it/s]\n"
     ]
    }
   ],
   "source": [
    "from torchmetrics.regression import MeanAbsolutePercentageError\n",
    "from torchmetrics.functional import mean_absolute_error\n",
    "\n",
    "mape = MeanAbsolutePercentageError().cuda()\n",
    "\n",
    "Loss = []\n",
    "model.cuda()\n",
    "\n",
    "\n",
    "self = model\n",
    "T = 3\n",
    "for data in tqdm(test_dataloader):\n",
    "\n",
    "\n",
    "    x_orig , y , pos = data  \n",
    "    x = x_orig.float()[:,:,12-T:12,:] # it uses only the last three samples of input\n",
    "    pred , _ = self(x.cuda() , pos.cuda())\n",
    "    \n",
    "    pred = pred.unsqueeze(2)\n",
    "     \n",
    "    \n",
    "    for t in range(1,T):  # 3 or 12 or 6\n",
    "\n",
    "        x , y , pos = data \n",
    "    \n",
    "        x =  torch.cat( (x_orig[:,:,12-T+t:12,:].cuda() , pred[:,:,0:t,:].cuda()) , dim = -2)  # teacher forcing y change to \"pred\" for non teacher forc\n",
    "        \n",
    "        out  , _ = self(x .cuda(), pos.cuda() ) \n",
    "        out = out.unsqueeze(2)\n",
    "        \n",
    "        pred = torch.cat( (pred,out) , dim=2)\n",
    "        \n",
    "    # x_orig = pred\n",
    "    # out , _ = self(x_orig.cuda() , pos.cuda())\n",
    "    # out = out.unsqueeze(2)\n",
    "    # pred = torch.cat( (pred,out) , dim=2)\n",
    "\n",
    "    # for t in range(7,12):  # 3 or 12 or 6\n",
    "\n",
    "    #     x =  torch.cat( (x_orig[:,:,t-6:6,:].cuda() , pred[:,:,6:t,:].cuda()) , dim = -2)  # teacher forcing y change to \"pred\" for non teacher forc\n",
    "        \n",
    "    #     out  , _ = self(x .cuda(), pos.cuda() ) \n",
    "    #     out = out.unsqueeze(2)\n",
    "        \n",
    "    #     pred = torch.cat( (pred,out) , dim=2)\n",
    "        \n",
    "    \n",
    "    loss = F.torch.nn.functional.l1_loss (pred.float() +vy[:,:,0;3]  ,  \n",
    "                                          y[:,:,0:3,:].cuda() +vy[:,:,0;3] )  # change 3 to 6 and 12\n",
    "\n",
    "    # loss = mean_absolute_error(pred.float()  ,  \n",
    "    #                                       y[:,:,0:12,:].cuda()  ) \n",
    "\n",
    "    \n",
    "    Loss.extend([loss.item()])  # above the loss is MAE we need also RMSE and MPAE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "ec65e7b6-b57b-48b6-89ff-ec282cacc572",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApQAAAHzCAYAAACe1o1DAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACTKUlEQVR4nOz9eXTje3rfd75/2FcCBIgd4L6z7u1NrW51q1ur5UWxLSt2ZE8cjZOceDLJTCaeM/GZ5IwTO5ksTpzVWRyviWI7UeJYsS17bNltSZa61ft2b3HfQADERhAEsa+/+YMFXLK4gSvI4vM6555blwSBL1l1WR9+v8/3eRRVVVWEEEIIIYS4Jc2gFyCEEEIIIZ43CZRCCCGEEOJOJFAKIYQQQog7kUAphBBCCCHuRAKlEEIIIYS4EwmUQgghhBDiTiRQCiGEEEKIO5FAKYQQQggh7kQCpRBCCCGEuBMJlEIIIYQQ4k4kUAohhBBCiDuRQCmEEEIIIe5EAqUQQgghhLgTCZRCCCGEEOJOJFAKIYQQQog7kUAphBBCCCHuRAKlEEIIIYS4EwmUQgghhBDiTiRQCiGEEEKIO5FAKYQQQggh7kQCpRBCCCGEuBMJlEIIIYQQ4k4kUAohhBBCiDuRQCmEEEIIIe5EAqUQQgghhLgTCZRCCCGEEOJOJFAKIYQQQog7kUAphBBCCCHuRAKlEEIIIYS4EwmUQgghhBDiTiRQCiGEEEKIO5FAKYQQQggh7kQCpRBCCCGEuBMJlEIIIYQQ4k4kUAohhBBCiDuRQCmEEEIIIe5EAqUQQgghhLgTCZRCCCGEEOJOJFAKIYQQQog7kUAphBBCCCHuRAKlEEIIIYS4EwmUQgghhBDiTiRQCiGEEEKIO5FAKYQQQggh7kQ36AUIIYQQ4vGpKmRX4HADFA34Pg7OyKBXJZ4rRVVVddCLEEIIIcTjOdyCr/3XcJw4+/aROfihfx0s7oEsSzxjEiiFEEKIF6QQg3/0b0G7cbJLeYYCFhf81H8MRvtAlieeKamhFEIIIV6QD/8XaL0Jkwpn/0GFyiGs/92BLlE8QxIohRBCiBeiXoLEt4A3YfJt3VC5848fd13i+ZNAKYQQQrwQlQNQO9c/rlp4+LWId4sESiGEEOKFMNj6e5xO/7DrEO8eCZRCCCHEC6EfamDx10G5+D6uCqBA+AcfdVniHSCBUgghhHjHdTod9vf3ef36NcOfS4KqoPImQL7RDZMaDcz+7sGsUzxf0thcCCGEeIflcjkSiQStVgufz4f/fT+bVvjuXz15f691kAJaPXz2X4PhiYEtVzxT0odSCCGEeAeVSiVisRiVSoXh4WHC4TAGg+Gj96dg8+9DbgsULfiWYPq3g3FogIsWz5YESiGEEOIdUq/XSSQS5PN5rFYr4XAYm63P2zhC3JIESiGEEOId0G63SaVSpNNpdDod4XAYl8s16GWJF0JqKIUQQohnTFVVDg4O2N/fp9PpEAgE8Pl8aDRy71Y8HgmUQgghxDN1fHxMPB6nWq3idrsJhULo9dJEUjw+OfIWQgghnplarUY8HqdQKGCz2QiHw1it1kEvS7xgEiiFEEKIZ6LVapFMJslms+j1esLhMMPDw4NelhASKIUQQoinTlVVstks+/v7APj9frxer9RJiidDaiiFEEKIJ6xQKBCPx6nVaoyMjBAMBqVOUjw5skMphBBCPEHVapV4PM7x8TF2u51IJILZbB70soS4kARKIYQQ4glptVrs7++TzWYxGo2Ew2GcTueglyXElSRQCiGEEE+AqqpkMhmSySQAwWAQj8eDoigDXpkQ15MaSiGEEGLA8vk8iUSCRqOBx+MhEAig08lf0eL5kB1KIYQQYkAqlQqxWIxSqYTD4SAcDmMymQa9LCFuTAKlEEII8ciazSaJRIJcLofJZCISiTA0NDToZQlxaxIohRBCiEfS6XRIp9OkUik0Gg3BYJCRkRGpkxTPnhRoCCGEEI/g8PCQRCJBs9nE6/USCATQarWDXpYQ90ICpRBCCPGAyuUysViMcrmM0+kkHA5jNBoHvSwh7pUceQshhBAPoNFokEgkODw8xGKxEA6Hsdvtg16WEA9CAqUQQghxjzqdDqlUinQ6jVarJRQK4XK5pE5SvNPkyFsIIYS4B6qqksvl2N/fp91u4/P58Pl8UicpXgQJlEIIIcQdFYtF4vE4lUoFl8tFKBTCYDAMellCPBo58hZCCCFuqV6vE4/HOTo6wmq1EolEsFqtg16WEI9OAqUQQghxQ+12m2QySSaTQa/X9+okhXip5MhbCCGE6JOqqhwcHLC/v0+n0yEQCODz+dBoNINemhADJYFSCCGE6MPx8THxeJxqtYrb7SYUCqHX6we9LCGeBDnyFkIIIa5Qq9WIx+MUCgVsNhuRSASLxTLoZQnxpEigFEIIIS7QarVIJpNks1kMBgOhUIjh4eFBL0uIJ0kCpRBCCHGKqqpks1n29/cBCAQCeL1eaUwuxBWkhlIIIYR44+joiHg8Tr1ex+PxEAwG0enkr0ohriM7lEIIIV68arVKLBajWCwyNDREOBzGbDYPellCPBsSKIUQQrxYzWaT/f19Dg4OMJlMhMNhHA7HoJclxLMjgVIIIcSL0+l0yGQypFIpAILBIB6PR+okhbglKQwRQgjxouTzeeLxOM1mE4/HQyAQkDpJIe5IdiiFEEK8CJVKhVgsRqlUwuFwEA6HMZlMg16WEO8ECZRCCCHeac1mk0QiQS6Xw2w2Ew6HGRoaGvSyhHinSKAUQgjxTup0OqTTaVKpFBqNhmAwyMjIiNRJCvEApGhECCHEO+fw8JB4PE6r1cLn8+H3+9FqtYNelhDvLAmUQggh3hmlUol4PE65XGZ4eJhQKITRaBz0soR458mRtxBCiGev0WgQj8fJ5/NYLBYikQg2m23QyxLixZBAKYQQ4tlqt9ukUinS6TQ6nY5QKITb7R70soR4ceTIWwghxLOjqiq5XI79/X3a7TZ+vx+/349Goxn00oR4kSRQCiGEeFaKxSKxWIxqtYrL5SIUCmEwGAa9LCFeNDnyFkII8SzU63Xi8ThHR0dYrVYikQhWq3XQyxJCIIFSCCHEE9dut0kmk2QyGfR6PaFQCJfLNehlCSFOkSNvIYQQT5KqqhwcHLC/v0+n0yEYDOL1eqVOUognSAKlEEKIJ+f4+JhYLEatVmNkZIRgMIherx/0soQQl5AjbyGEEE9GrVYjFotxfHyM3W4nHA5jsVgGvSwhxDUkUAohhBi4VqvF/v4+BwcHGAwGwuEwTqdz0MsSQvRJAqUQQoiBUVWVTCZDMpkEIBAI4PV6URRlwCsTQtyE1FAKIYQYiKOjI+LxOPV6HY/HQzAYRKeTv5aEeI5kh1L0rXUEB38banugNYPrp8D63qBXJZ6DdBF2cqDVwLwP7MZBr0gMUqVSIR6PUywWGRoaIhwOYzabB70sIcQdSKAUfUn9j7D7F6GqA7SACro6jMzC1J8Bg7SEExdIH8Nf/hqsxUHT/U6jg89Mw//5B8Akw01elGaz2auTNJlMhMNhHA7HoJclhLgHEijFtTK/CGt/FtpaMFdPgoEKNPVQN4PHDUt/DTTS0UOcki3Bv/N3oVmEphY6b1oHatug64DPD//27wCDnHC+8zqdTq9OUqPREAgE8Hg8UicpxDtEvpWLK3WaEPtL0NKBrfzR2xXA0ARFhcMW5H8F3D89sGWKJ+h/+Q40S1AzcPIH5o2WBjpt2E/DP1yHn14c2BLFI8jn88TjcZrNJl6vl0AggFarHfSyhBD3TMYNiCsVvgylGphqF79f3zrZuTz4O4+7LvG0levw7R1oKZwJk10d7ckPI7+69uhLE4+kXC6ztrbG9vY2FouFxcVFwuGwhEkh3lGyQymu1Do4OarUti9/jKYN9dzjrUk8fakS8OaHjcu0tZArPtqSxCNpNBokEgkODw8xm83Mzs5it9sHvSwhxAOTQCmupHODpnPyl7/uklDZ0YJ++HHXJZ42kw5U5WQX8rIibUUFnWxWvTM6nQ6pVIp0Oo1Go2FsbAy32y11kkK8EC83UKrQ/MfQ+GvQSYPGDYafA/3vRAoBTnF8Hix6KCugq5x/f0t7snvp+V2PvzbxdAWHYHgIjvPQuCg0qicXc15FHn1p4gHkcjkSiQStVgufz4ff75ejbSFemBcZKNUiFP8glL8FLQMobUAL2l8ByzzY//eTgClAY4DRPwJrfx4q5pNaym77l4YeamYVp6XJ8O/Qc2GxnHiRFAV+xyv4xS+Drgmt0x0AVNC/edvvXBjYEsU9KJVKxGIxKpUKw8PDhEIhjEZpMirES/Qi2wYVfw4KXwF9/eRSSVdLCw0zDM3D0K8Mbn1P0f5/D9H/CapvbuwqCmjr4Ai2aP3RZRxjFiYnJ9FoZHtXnFBV+B+/Ab/2+qRcovPm5w2NqtLWK/z85+DHZga7RnE79XqdRCJBPp/HYrEQiUSw2WyDXpYQYoBeXKBsr8DBj57UdRma59/ffFP7NfJLoPvcY6/uaWtk4eCX3kzKsYDrJ8H2aSgWj9na2sJmszE1NSWhUpzxOgm/sg7RLLRaDaZcVf7ADzoIOwe9MnFT7Xa7Vyep0+kIhUK43XKcI4R4gYGy+u9C7i+AuXzxAa0KVG3g+lmw/BePvLgbiDfhr+VhrQo6BT5ng9/vANuAypaOjyVUiuslEglyuRzvv//+oJcibkBV1V6dZKfT6dVJyv/nQoiuF1dDqRY4ObK95P3dt6tPuJ3Jn8/BX9gBe/EkACsqrGrhLwzDfzoFn7U+/pqGhoaYnp5mc3OTra0tCZXiQlarlVQqRaPRwGCQuYvPQbFYJBaLUa1WcbvdBINB+b0TQpzz4v7G14yeXMLpXJIoVQBVRRN+zFX17/8owF9eB2MVMiOQ8ULaB0dOMB7AH9uAaGMwa7Pb7UxPT1Mqldjc3KTT6QxmIeLJslpPftopl8vXPFIMWq1WY3Nzk/X1dbRaLfPz84yPj0uYFEJc6MUFSsMfBoMKjUu+JzYMoG9A5w9WH3dhfVBV+PNpMNcg7wL11O9eWwcZD1jy8FcOB7dGu93OzMwM5XJZQqU4R6/XYzQaKZVKg16KuESr1SIWi7G8vEy1WmVycpK5ubneDwNCCHGRFxcoNW6w/99Ojomrpo92KjsK1IwnU2GaP33IWnWFVCrFUyox3WxA7hCKl1ymVDVQ18GvHTzuut5ms9l6oXJjY4N2+4oxO+LFsVqtskP5BKmqSiaT4fXr1xwcHBAMBllaWmJ4WKYWCCGu9+JqKAFM/yYMG6D0Z6EOqNqTY3CDArZ/EYz/zjBKqkYikeDo6Ijx8XFMJtOgl02hfdJEvH5Fm7eWDlqty9//WGw2G7Ozs2xsbLC5ucn09LQ0OhbAyZ+NfD5Pp9OROtsnolAoEI/HqdVqjIyMEAwG0ev113+gEEK88eJueZ+mlqD5f0AnCcoI6H8WNI6P3l8ul9nd3aVerxMMBvH5fAMdI5Zswu/9DqBC+ZJdypEsmP3w9+cfdWmX6u5SmkwmZmZmJFQKKpUKKysrzM3NSe/CAatWq8TjcY6Pj7Hb7UQiEcxm86CXJYR4hl50oOxHp9Nhf3+fdDqN1Wod+G7lz+9CYhvSnrM1lHAykcR5pPJzr+BfGXk6U2skVIrTVFXlu9/9LoFAAL/fP+jlvEitVov9/X2y2SxGo5FwOIzT6Rz0soQQz5icN11Do9EQDoeZm5uj3W6zvLxMOp0eWG3l/9MPpWHwHoCxdvI2pQOWMozkVBRXnc9k12k2L+jaPiBWq5XZ2VlqtZrUVAoURZE6ygFRVZV0Os2HH37I4eEh4XCYpaUlCZNCiDuTHcobOL1babPZGBsbG8hu5VfL8Cf2oHwIxsbJZJ+KGWa88P91lynubgEwNTX1pG5mVioVNjY2MBgMzMzMoNO9yBJegTQ4H4SjoyPi8TiNRqNXJyn/Dwoh7osEylsolUrs7u7SbDYJhUJ4vd5HX4Oqwq+X4fWbSTk/YoP5N9m22Wyyvb1NuVxmdHSUkZGRR1/fZarVKuvr6xIqX7hCocDm5iavXr3CaLzilpm4s0qlQjwep1gs4nA4CIfDT+KSoRDi3SKB8pY6nQ6JRIJMJoPNZmN8fPxJ/cWoqiqxWIxsNovH4yESiQz0QtFp3VCp1+uZnZ2VUPkCtVotvve97zExMYHL5Rr0ct5JzWaztxNsMpmIRCIMDQ0NellCiHeUBMo7KhaLRKPRge5WXuXg4IC9vT2sViuTk5NPphWIhErx+vVr7HY7o6Ojg17KO6XT6ZBOp0mlUmg0GoLBICMjI0/mB0ohxLtJAuU9OL1babfbGRsbe1K7leVyma2tp1dXWavVWF9fR6fTMTMz82TCrngcu7u7VKtVFhYWBr2Ud8bh4SGJRIJms4nX6yUQCEhXBSHEo5BAeY+KxSK7u7u0Wi3C4TAej2fQS+p5qnWV3VCp1WqZnZ2VUPmCdHfPP/7xj0uD8zsql8vEYjHK5TJOp5NwOPykfqgVQrz7JFDes3a7TSKRIJvNYrfbGR8fx2C4ZHD4I3uqdZUSKl+marXK8vIys7Oz2O32QS/nWWo0GiQSCQ4PD7FYLITDYflaCiEGQgLlAzk+PiYajT7J3cqnWFdZr9dZW1uTUPmCqKrK9773Pfx+vzQ4v6FOp0MqlSKdTqPVagkGg7jd7ifxA6IQ4mWSQPmA2u028Xicg4MDhoaGGBsbezK7laVSie3tbeDp1FXW63XW19dRFIXZ2dkn87USD2djYwNFUZienh70Up6NXC5HIpGg1Wrh8/nw+/1SJymEGDgJlI+gu1vZbrcJh8NPpn6x2WyytbVFpVJhbGwMt9s96CVJqHxhuuP/Pvaxjw16KU9eqVQiFotRqVQYHh4mHA7L/x9CiCdDAuUjeaq7laqqsre3x8HBwZOpq2w0GqytrUmofAGOj4/Z2NhgaWlJmm1fol6vE4/HOTo6wmq1Eg6Hsdlsg16WEEKcIYHykRUKBaLRKJ1Oh0gk8iR2BQGy2SyxWAyr1crU1NTA+0I2Gg3W19dRVZW5uTkJle+odrvNd7/7XcbHx5/M/wtPRbvdJplMkslk0Ov1hEIhaQIvhHiyJFAOQLvdJhaLkcvlcDgcjI2NPYlLKN26SkVRmJqawmKxDHQ9p0Pl7OystEF5R0mD87NUVeXg4ID9/X06nQ5+vx+fzyetlYQQT5oEygF6iruVT62uUkLluy8ajVIul1lcXBz0Ugbu+PiYeDxOtVrF7XYTCoWexA+bQghxHQmUA9ZqtYjFYhweHj6Z3cpOp0MsFuPg4ACv10s4HB5oXWWz2WR9fZ12u83c3JyEynfMwcEB0WiUj3/84y/2tnKtViMej1MoFLDZbEQikYGfEAghxE1IoHwijo6O2Nvbo9PpMDo6+iRqpbp1lTabjcnJyYHWVZ4OlbOzs3KB4x1Sq9V4/fo1MzMzDA0NDXo5j6rVapFMJslmsxgMBkKhEMPDw4NelhBC3JgEyifk9G6l0+lkdHR04LuVpVKJra0tNBrNwOsqJVS+u7773e/i8/kIBAKDXsqjUFWVbDbL/v4+AH6/H6/XK3WSQohnSwLlE3R0dEQ0GgUgEokMfLey0WiwtbVFrVZjdHR0oHWVrVaL9fV1Wq3WOxsqc3n42tdgaxM6bfAF4bM/CONjg17Zw9nc3ERVVWZmZga9lAdXKBSIx+PUajVGRkYIBoMD/8FRCCHuSgLlE9Vqtdjb2yOfzzM8PMzo6OhAj5w7nQ57e3vkcrmB11V2Q2Wz2WR2dhaz2TyQdTyE730f/vbfBF0DOm/eplWhqYVPfB5++nfAuzhdL5lMkk6n+fjHPz7opTyYarVKLBajWCxit9uJRCLv1J9dIcTLJoHyicvn8+zt7QEwOjo68PqqTCZDPB4feF1lq9ViY2ODRqPxzoTK/ST8pT8H2gbUjUA3OKqga4FGhR/7PfC5zwxylQ+jWCyyvr7+TjY4bzab7O/vc3BwgMlkIhwO43A4Br0sIYS4V1Kw88QNDw+ztLSE3W5ne3ub7e1tWq3WwNbj9XqZmZmhWq2ysrJCpVIZyDp0Oh0zMzMYDAbW19cHto779OXfAv3bYZKTX7f0oHTgq1+Bd/FHwG5tbqlUGvBK7k+n0yGVSvH69Wvy+TyRSITFxUUJk0KId5IEymdAp9MxOTnJxMQExWKR169fc3R0NLD12O12FhYW0Ol0rK2tcXh4OJB16HS63mjGjY2NZx8qt1ahpeFsmDylpYNyDtLpR13Wo9BqtZjNZsrl8qCXci/y+TzLy8vs7+/jdrt59eoVXq934GNNhRDioUigfEZcLheLi4vYbDa2trbY2dkZ2G6lwWBgbm6O4eFhdnZ2iMfjDKJ6QqvV9hqeP/edynYL1CvyhqqAokKj8Xhrekw2m+3Z71BWKhXW1tbY3t7GZDKxuLhIJBIZ+ChTIYR4aBIonxm9Xs/U1BQTExMUCgWWl5cHtlup0WgYHx8nEomQyWTY2NgYSMDVarXMzMxgMplYX19/trtcdhfo2pe/X9MBVQeuwQ9UehBWq5VarUa7fcUX4YlqNpvs7u6ysrJCu91mZmaG6enpd64eVAghLiOB8plyuVwsLS1hsVgGvlv5dl1ltVp99DV0Q6XZbGZjY+NZhspP/QB0FNBclKdU0LdhcgFs1kdf2qOw2WzA86qj7HQ6JJNJPvzwQwqFAqOjoywsLDzLBu2tGux/B2Jfg2Jy0KsRQjw3csv7HZDL5YjFYmg0GsbGxgZW9H+6X+XY2NhA+me22202NzepVqtMT0/3Qspz0GzCX/xLcBSFtuakZlJVTm5469oq2OFf+r8ojLyjO5QA3/ve9/B4PASDwUEv5VqHh4ckEgmazSZer5dAIPAsR0e2W/C9vw6bv/pROYWigm8GPvUvwvDoYNcnhHgeJFC+I5rNJju7UfZSdexDTt6b82MxPf5fbp1Oh2g0yuHhIT6fj1Ao9OgXETqdTu+SzszMzLMKlbU6/PLfhdUPQGkAKnQ04PCW+OEvHPLJT7zbf7s/hwbnpVKJeDxOuVzG6XQSDoef7Xx5tQO//h9D7PVJFwHNm+anqnJSXmHQwm/7UxIqhRDXk0D5Duio8CvfgN/6JnQOTnYXWpY2c69a/P4fM2IdQBlXOp0mkUhgt9uZmJh49EsJnU6Hzc1NyuXyswuVAOUybO9Auw2hIOh0eba3t5mamsLpdA56eQ8mlUqRTCb5+Mc//uRuRDcaDeLxOPl8HovFQjgcxm63D3pZdxL9CvzGf3PyPUPz1t8EKtDRg38SfvJPDmJ1QojnRALlM9dR4S//Mux//eS/K5aT3QVzFQxNleZYkz/2h7UMWR9/t7JYLLK9vY1Wq2VqaurRm4+fDpXT09PP/i//zc1NKpUKS0tLz/JotR/dBueLi4tPpll9u90mlUqRTqfR6XSEQiFcLteTC7y38Y/+FCS3QNe8+P0dDaDC7/nPwO5/1KUJIZ4ZuZTzzH19BWLfOmmGnXdB3QQNIxSccORQ0Ef1/MLfLXB8fPzoa+v2q9RqtayurpLP5x/19TUaTa+OcnNzk2Kx+Kivf99GR0dpt9skEolBL+XBWK1WFEV5EhdzVFXl4OCA169fk8lk8Pv9vHr1Crfb/U6ESYDjJChXXKpXOic/oBZij7cmIcTzJIHymfvyd8HYgMoFN3+bBmjoFfajTpZXNolGo4/ekqXbr9LpdLK9vU0ikXjUfpUajYapqaleqBxEsL4vBoOBcDhMNpt99uH4MhqN5kk0OC8Wi6yurhKNRrHb7SwtLREMBtFo3q1vmRr91b1Pu032tYZHWY4Q4hl7t747vkCH+1C74j5A1Qz6igaTc4LDw0OWl5cfPVRpNBomJiYIh8OkUik2NzcftcVRN1Ta7Xa2traedaj0eDzYbDai0SidTmfQy3kQg2xwXq/X2draYn19HUVRmJ+fZ2JiAoPh3UxU4Y8Dykm95EU6ChiM4Fl4xEUJIZ4lCZTPnKK5dFLfyfvVk78s3G9mghuNRjY2Ntjb23v03Uqfz8fMzAyVSoXV1dVH7Vd5OlQ+953KsbExGo0GyeS72SzQarVSr9cf9YeOdrtNPB7n9evXVCoVJiYmmJ+fx2p9R5t+vjH7u0AHNHUqLc1JgOyGy45ysns58xOgezfztBDiHkmgfOZCE2CqX/5+S0WFYZWg++TIdHZ2ltHRUXK5HMvLy49+dDo0NMT8/DwajebR6yoVRWFqagqHw8Hm5iaFQuHRXvs+mUwmAoEA6XR6IE3kH1r3Rv5jHHurqko2m+XDDz8km80SCARYWloaSA/VQfiVNvzaj0FTr1A1qlRNJyceNcNJoBx7Hz72c4NepRDiOZBb3s/cShT+6v8E+ubJRZzTTNWTQOn/ZJrf83kFr9fbu0xQr9eJRqMUi0U8Hg/hcPhR68M6nQ67u7vk83n8fj/BYPDRLjqoqsr29jaFQoHJycln2YZHVVVWVlZ6x7J3+dqpKhxvQ6sC1gCYRu5xobf0/e9/H7fbTSgUerDXOD4+JhaLUavVeq+l1+sf7PWeml9KwJ/7ALRt0DdgYQVCsZP2QUU71H8A/sQfgHesbFQI8UAkUL4D/t7X4Cu/Apbqye6CqoCxDm0tjHxc5ac/FSd3kMFqtTI2NnamHUsmkyGRSKDX6xkfH3/0fo2pVIpEIoHD4WBiYuLR2uGoqsrOzg5HR0fPNlSWy2VWV1cJh8P4fL5bPUf0b8P234BK7uSoUwE878H8H4WhyXtd7o1sbW3RbreZnZ299+eu1WrE43EKhQI2m41IJILFYrn313nKGm34/b8BrTJUL/jU9Y2TJuf/7mfgB1/GZq0Q4o4kUL4jlnfhV78F+zugtsERgM99Aj63BFrNSfjY3d2lXq/j9/sJBAJndit3d3cplUp4vV5CodCj7lYeHx+zvb2NTqd71H6Vp0PlxMQEw8PDj/K69ykWi3FwcMDi4uKNp7Ws/nnY/FsnP4Bo35TTqgq09WDUwGf/I3DMPcCi+5BOp9nf37/XBuetVov9/X0ODg56N+af4w8S9+FLGfgz34KGHjqX/AxnL8MnJuBPLT3u2oQQz5MEyhdEVVWSySSpVAqj0cj4+PiZSweD3K3s3q6t1+tMTEw82l/0qqr2jt6fY6hst9ssLy9jMpluNK6wsA6/+cdOdiV1b93NUjlpOeUKww//t/e63L6VSiXW1tZYWFi48+6hqqpkMpneJaZAIHCm/ONdp6oqrVaLRqNBs9mk0Wjwv6cN/HLUQcV6+dfAUobRAPx3n3rExQohnq3HnYcnBkpRFILBIMPDw0SjUVZXV8/sSHq9XoaGhohGo6ytreHz+R6t957RaGR+fp7d3V22trYIBAIEg8EHf11FURgfHwdgZ2cH4FmFSq1Wy+joKJubm+RyOdxud18ft/e3oaMD3QUXuhRA24JCFI7WwDmAXUqLxYKiKJTL5TsFyqOjI+LxOPV6HY/HQzAYfPQxoA9JVVWazWYvKJ4Ojd1fN5vNM71fFUVB0/GhKs6TxuWX/O+tUWHo5ZSUCiHu6N35zir6ZjabmZubI5PJsL+/z9HREWNjYwwNDWEymZidne3tVhYKhXM7mQ9Fo9EwOTnZq6vstm956LrKbqhUFIXt7W0mJiae1S1fh8OBy+UiHo/jcDj6CkzH20D78pZTmg60dHC80X+gVFWIbsLGMrRakIyAMg1uE/yECaw3+LlEo9FgsVgolUp4PJ7+P/CNarVKLBajWCwyNDQ0kNGfd9UNi28HxbffdppGo8FgMKDX6zGZTNjtdgwGQ+9tBoMBnU7HdBP+j3+iYqwr1C74smhbJ7//P3G70lwhxAskgfKFUhQFn8+H0+kkGo2ysbGB2+0mHA6j0+nw+Xw4HA52d3dZXV191N1Kv9+P2WxmZ2eHlZUVpqenMZlMD/qaiqIwNjYGfLRT+ZxCZSQS4fXr18RiMSYmJq59vNJnRtf0+bjCIfyN/wGSOUgEYXUOKELne1C2wp9wws954f/t7L9XmdVqvXFrp2az2auTNJlMTE9P43A4bvQcj6HT6ZwLiBftLJ7WDYsGgwGTycTQ0NCZoGgwGPr+4WtIDz/sOOI3M04MdYWGgY+m4rTAUgP7CPzYzbO8EOKFkhpKAcDBwQHxeBxFURgdHe0d+6qq2rsgcVHd5UPq1lU2Gg3Gx8cfra4yGo1ycHDA+Ph430fIT8Hh4SE7Ozt9haj1/wFW/+bJbd6LdilbWtAo8ON/GUzeq1+3VoO/9J/DYRUSfvjOJ8BchYr55LlVoPXm8sePRuC/6LMtUT6fZ3t7m/fff//adj6dTqdXJ9kt7fB4PAOpkzwdFi8Kio1G41zTdq1Wey4cvv3r+9ypr1arfLi8zN/TLvHltAlj880tf/VkZ9IzDP/Jx8H3sD/HCSHeIRIoRU+z2WRvb4+joyOcTiejo6O9v8hrtRq7u7uUy+VH7RvZbrfZ3d3l6Ojo0eoq4aNQOTY2xsjIE2jM2KeNjQ1qtRqLi4tXBpBaDn7tX4BmB3TNs6Gy8+amd/CT8Kk/ef1rfu3X4B98CbRN+OV/6mS2fH6Y3pOaKye7lN3bxH91Fj7Rx+SVRqPBb/zjbY4zEzSqRkxmmP8YzL53MiGqK5/PE4/HaTabeDweAoHAg9VJdjqdK4Nis9k8FxZ1Ot2FQfH02x57RvjOzg6lUolXr16xVVb42/uQroNZe7Ir+YWRkx8ohBCiXxIoxTn5fJ5YLEan0yEcDvcC1SB3K5PJJPv7+4/ar3Jvb49sNvusQmWj0eD169eMjIwQiUSufGz6K/Dt/wiaCmjagAqq5mRWpzMMn/lPFAz261/zL/ynkDqClBe++3Gom6B5akNR1wKlcxIy3UfwwxPwn13z5Ww14W/9Vdh+DQoqKgqKclKn6fLBP/NHQaMrE4/HKZVKOBwOwuHwnUoj2u32lUGx0WicG1eq0+muDIp6vf7Rw+J16vU6r1+/JhwO4/Ves/0shBB9kkApLtRqtYjH4+RyOex2O2NjY70+h9Vqld3dXarVaq+28jF2KwuFAjs7O+j1eqamph68rhI+CpWjo6O3uhwyCJlMhlgsxtzc3LWtn0pR2PmbkP4qtBpgdnfQvpdg4mf0hMb8fb3ef/HvQqkOa7MQG32zO3mK0gFD8+Tt9iKERhr8b77Olb9/f+9/htffOv0kb/6tgqKo2Iab/MBPfYDFYiYcDjM0NHTlGlut1qW1it1fdzqdMx+j1+uvPIJ+imGxH3t7e+Tzed57771nuX4hxNMkgVJc6fj4mGg0SqvVIhgM9vr3qapKKpUimUxiMpkYHx9/lGkj9Xqdzc1Nms0mExMTj3LhIhaLkclknk2oVFWVtbU12u02i4uLNw77e3t7HB4e8t577/W1E/zn/1NI52FnAramoDB0thVNb4fSBa68ikOX5I+8/sfo9Xrsdjs2mw273Y7D4cBut6PBwV/5TwyoHS4u8HzzHevHf7bAJ39o6Mqdxe6vLwqLlwXF7r/fxT6VzWaTDz74gGAwiN/f3w8MQgjRDwmU4lqdTodEIkEmk8FisTA+Pt5rwXJ6t/LtCTwP5XRdZTAYJBAIPOjrAcTjcdLpNJFI5FkcE1arVVZWVnr1rjfRbDb58MMPe7vP1/mtL8E//DVoauFXfjtoOyc1k12m6sl4v6oZrGX4lwNFfnv1gOPjY4rFIsVikVKpRL1+0hSzlFmguP9JQLm0r5GiqvgmCiz90Pa5HotvHz1ftLP4LobFfsTjcQ4ODvr+YUEIIfolbYPEtTQaDZFIBJfLxe7ubi+oBAIBzGYz8/Pzvd3Ko6OjB9+t1Gq1TE1N9eoqK5UK4+PjD/oXZDgcBk52K4EnHyrNZjN+v59UKsXw8PCNejDq9Xo8Hg+ZTAav13vtBZdP/BB847eg0ARfCo4dJ7fEG4aTCzpt3cmIv+ECKB74Iz47JuV8cWaj0eD4+Jiv/EMN6/snYyAvowKoRsLh8Lkeiy81LF6n1WqRzWbx+XwSJoUQ9052KMWNvD2+cWxsrFenV6lU2N3dpVarEQgE8Pv9D/6X+2PXVSYSCVKpFOFwGJ/vaXd97nQ6rKysoNVqmZubu9HvRavV4oMPPuhNUrrOYRb+178C6SJ87TNQM53UTVZNJ5d0GgbQueAXQjB/zQ3v730NfuV/e/Mflxx5Kwq894Pw2/9A35/So1FV+FoZ/s4RFFrg08E/7YbFAfdV39/fJ51O8957771T04KEEE+DBEpxK9VqlWg0SrlcPjO+8XTgNJvNZ47HH0qtVmNra+vR6iq7oTIUCj35OrTuTOzbHNV3A8irV6+u7QMJJ0Fqa+VkUs73LPDNEBw5YMgAv8sOf9AKtj7ugDRq8N/8qQ6tpubKGsp/7v8B/qsvsj+6oxb8qzuwmwZr7aQFE5z05PyhEPyHETAM4B5Mu93mgw8+wO12X3v7XwghbkMCpbg1VVV74xt1Ol1vfCM8/m7lY9dV7u/vk0wmn0Wo3NvbI5fLsbS0hMHQRwPINwYRQjqdDnt7e3z7y1q2vnPqNbsd0gFQmXlf5Wd+/mndUFZV+MObkNmDYysfjTRUT2pHjQ34oRn4D8KPv7Z0Ok0ikeDVq1c3+jMghBD9elrfkcWz0h3fuLi4iNFoZGNjg93dXVqtFhaLhYWFBXw+H/v7+6yurlKtVh9sLd26ymAwyP7+PltbW+d6Bt6nYDBIMBgkkUiQTCYf7HXuQygUQqvVsre3d6OP02q1+Hw+stksjUbjgVb3kVqtxurqKvl8nh/5HRZ+9PeA3nCSIhVVBVQUpYNvMs3sD2zw1H4W/mrpZGfyTJgEUKBsO6kj/dUEpB7+S3lGp9MhnU7jdrslTAohHozsUIp7k8vliMVi58Y3lstldnd3qdfrBINBfD7fg+5WHh0dsbu7i16vZ3p6utc/8yF0LwY91m3z2zo6OmJra4uJiYkbzShvt9t8+OGHDA8PMzo6+mDry+fz7O7uYjAYmJyc7JVJZNJ5vvZPCtQrBpwuM8P+FAZTqzcV5ykd3/5bMfjmGqQv6SyldMCVhz/0Cv6lR7zTlc1m2dvb49WrVw/6/4IQ4mWTHUpxb9xuN0tLS9hsNra3t3t1jVartbdbmUgkWFtbo1arPdg6nE4n8/PzAKysrFAoFB7stQKBAKFQiP39ffb39x/sde7K6XQyPDxMLBY7NxrwKlqtFr/fz8HBQa+tz31SVZVYLMb29jYOh4P5+fkzNbf1RomJhRKf+mKd8Eya0fERGo0GXq+XTCZDLpe79zXd1nH7o5rJi6ga0Kpw9HAb5+df802/WJfLJWFSCPGgJFCKe9W9bT05OUm5XOb169ccHByg0WgIhULMz8/TbrdZXl4mnU4/2LGlyWRifn4em83G5uYmqVTqQV4HwO/3EwqFSCaTJBKJB3udu4pEIqiqSjwev9HHeTwedDrdvR/tNxoN1tbWepOIJicnz7WzKZVK2Gw2rFYrlUqF4eFhdDodqqoyMjJCNBqlUqnc67puy6t7c4fokj/SmvZJr07/9feb7s3h4SGNRuPJ1/kKIZ4/CZTiQQwPD7O0tMTw8DDRaJT19XXq9Xpvt9Lr9RKPxx90t1Kr1TI9PU0gECCRSLC9vX1uYsp98fv9hMNhUqnUkw2Ver2eSCRCLpfj+Pi474/TaDT4/X5yudy9/V4VCgWWl5dpNpvMz89fOIGo3W5TqVSw2WzYbDZUVaVWq+HxeDg4OCAYDGKxWNja2rrRrutD+VkXlM1guSTf2krQtMLvdj7emlKpFE6n88E7LQghhARK8WC0Wi1jY2PMzMzQaDR6u5KKohAOh5mbm6PVarGysvKgu5XBYJCpqSkKhQKrq6sPcnQL4PP5eqHypruAj8XtdmO324lGozcK1x6PB4PBcOdjfVVVSSQSbG5uYrPZWFxcvLQJfrlcBsBms2E2m9FoNJTLZTweD6qqksvlmJycpNPpsL29PfBLOq8s8JkgmOpgK57UTMLJzuTQm6qLn4uA85FaQB4dHVGr1WR3UgjxKCRQigc3NDTE4uIiHo+HeDzeu/HdDRTdt3d3MR+C0+lkYWGh1+z7Jjt0N+Hz+YhEIqTT6ScbKsfGxmi1WjcKh4qiEAgEyOfzt76t32w22djYIJ1OEw6HmZ6evnJiS6lUQqfTYTKZUBQFq9VKqVRCr9fjcrnIZDK9EotSqfQkvt5/evSkNVBHr+I6VPEeqDgL0DHDH5iF//sj9sJPJpPY7XasVuv1DxZCiDuSW97iUZXLZaLRaG/nxO/3o9FoKJVK7O7u0mw2CYVCDzbasN1us7OzQ6FQeNAekt2btV6v90ndRO7qBt75+fm+A4eqqrx+/Rqz2czU1NSNXq9YLLK9vY2iKExOTvamK11lfX291w4KThrK53I53n//farVKsvLy71b65lMhlgsduNb7A9lu1DhF3YOMQx7iVgN/G7n4+1M1hrwpW9U+foH0KiZMJoUXs3Dj34CRh62578Q4gWTQCkeXffmaTKZPDO+sdPpkEgkyGQy2Gw2xsfHH+RmaneaTzKZZHh4mPHxcTSa+9+sf8qhUlVVVldXUVWVhYWFvts4HR4esrOzc6Mg2m2tZLfbmZyc7Gvsn6qqfPe73+21mYKPWh+99957GAwGNjY2aLVaLCwsALC7u0s+n2dubu5BZ8n3I5fLsbu7yyc+8YkH+bN1mWIF/uwvQjlx8m29rVVQVNB1oGmDf/H3w8wAGqsLId59cuQtHl33+HRhYQGtVsva2hqxWAxVVYlEIszOztJsNlleXiaTyTzI6z9GXaXH42FsbIxMJnPjpuIPTVEUxsbGqNVqN7oBPzw8jMlk6uu4vNVqsbGxwf7+PoFAgJmZmb5nSFcqFTqdzpmdzO6vS6UScFJeUKlUKBaLAIyOjmIymZ7EJZ1qtYrRaHzUMAnwC/8/qMVVaiaFsk2hZoaqBYpW0JXgL/5NSPwDOP4KdJqPujQhxDtOAqUYGLPZzNzcHJFIhIODA5aXlzk+PsZut7O4uIjb7SYWiz1YbWW3X+VD1lWOjIwwNjZGNpslGo3e+/PfhcViwefzkUwm+7693Q3jx8fHvWB3kXK5zMrKCpVKhZmZGYLB4I2a2ZdKJTQazZmdRp1Oh9Fo7F3WGRoawmw2k06ngZPb6FNTU0/ikk6lUnn0m9WpHEQ3oWZQaL+V29tayIzAsQb+py/Br/5p+Mrvg/2/eDIyUggh7koCpRgoRVHwer0sLi5iMpl64xs7nQ6jo6PMzs5Sr9dZXl4mm83e++ubzWYWFhawWq29CyP3bWRkhPHxcQ4ODp5cqAwEAhgMhhuta3h4GLPZfOkuZSaTYW1tDYPBwMLCQm+++02USiWsVuu5EGqz2c4EWZ/PR6FQ6AXi7qSdUqk00PZN1Wr10Y/dX++AvqnSeGu6YksLx0Mn/+jaUHCc3ELPGOBrvwy7/+GjLlMI8Y6SQCmeBKPRyMzMDOPj4xwdHfH69Wvy+fyZ3cq9vT3W19fvfa50t1+l3+8nHo+zs7Nz7/0q3W53L1Tu7u4OvMVNl0ajYWxsjFKpdKPAHgqFKBaLveNmOLnwtLW1RSwWw+v1Mjs7e+vZ0d2G5m+zWq1Uq9Xe74/L5UKv15/5QcButxMOh0mn0xweHt7q9e+i2WzSarUefYey3QGNypvu6h+pmqFuAFMNNG/+WJtr4E+BvgkrvwHlDx91qUKId5AESvGkdMc32u12tre32dzcpN1uMzo6yszMDPV6vTd95z4pikIoFGJycpKjo6MHqat0u91MTEyQy+WIRqNPJlTa7XZGRkZIJBI0m/0V1jkcDqxWa28XsFKpsLKyQrFYZGpqinA4fOt57bVajVardWGg7DY4707H6e5w53K5M2v3er24XC6i0eit2xzdVvf1HjtQ+obrNHUKulO/hS0t1I1gaIKingROV/6j9w/noeiE1N941KUKId5BEijFk6PX65mcnGRqaopKpdI77u72s+wGhY2NjXvfrRweHu7VVa6urt57XaXL5WJiYoLDw8MntVMZDofRaDQ3ujwUDAYpl8tsb2+zurqKVqtlYWEBp9N5p7V0j7QvukVuMpl6baa6RkZGUBTl3A7r2NjYQC7pVKtVNBrNo8/OHtIl0Q3VMdfU3vjHjgbampPm6pYKVE2wdGo3UgG0DSg/rUoMIcQzJIFSPFlOp7M3vrF73N1qtXrTd2q1GsvLy/e+W2k2m5mfn8disTxIXWU3VObz+ScTKrVaLZFIhKOjI/L5/PUfwMlu4dHREd/+9rcZGRlhbm7uXkJUqVTCYrFc2PS82+C8ezEHTi7ruN1ustnsmVKF7iWdbu/Rx/o6V6vVR9+dbDQa5POH/O4vlmlaFOwlMNRB1zz5t/0YVAUWV8D51s9IHS3obleZIIQQPRIoxZPWHd84OzvbG9+YSqV6tZXdWeH3vVup0+ketK5yeHi4FyofM+xctyan00ksFqPdbl/52FqtxurqKiaTCZfLhd1uv7cWOZfVT3a9fTEHTi7ntFotcrncmbcbDAYmJiY4Pj6+89jIfg3ihnc6nUar1fLpJSd/9P8E7tmTt1uqJ6MgGwb41LfhB7519uOaupPdy+EfftTlCiHeQRIoxbPQDZAej4dEItGrcRwbG2N6ero3OeXtQHEXb9dVrq2t3WtoHR4e7j33UwmVo6OjdDqdK8cYHh4esrKygqqqfOpTnyISibC/v38v6282m9Tr9SsDpdVqpdVqnalxNRqNOJ3OC/uWDg0N9Was97v7eluqqlKr1R71hnez2eTg4ACv14tGo2EyAP/6z8Ef/5fhn/9n4Z/LwI//Ooy+Vc3Q0kIqCL4qeH7m0ZYrhHhHSaAUz4ZGoyEcDjM/P9+b9JJIJLDb7SwtLeF0Otnd3WVzc7PvyyX96NZVtlqt3sWT++J0OnuhctC9E+GkfjUcDnNwcHDu8+x0Ouzt7bGzs9ObjW4ymQgGg9RqtXsJa92dx+t2KE8/tsvn81Gr1SgUCuc+xufzMTw8zO7u7oNe0qnVaqiq+qg7lJlMpnc56bQRB8yNwg/9G7Boh7IV4hHIeCARgNV5yI1A/nfCt34DSkePtmQhxDtIAqV4dqxWKwsLCwQCAdLpNCsrK1SrVcbHx5menqZSqfD69et73a3s9qvs1lXe5wQfp9PZm9rzFELlyMgINpuNaDTaO+av1+usra1xcHDA2NgYExMTvSNuq9WK0+m8l13KUqmE0WhEr9df+hitVovJZDpTRwknQdNqtV5a89od5bm1tXXtkf5tPfYN73a7TTabxePxXFhzCqC1wNKfgx/+l2DBAUNG2JuGwtBJU/P9Ffj2L8Mv/H/gt375UZYthHgHSaAUz9JF4xv39vaw2WwsLi7icDjY3d1la2vr3nYru3WVXq+XWCx2r3WVDoejFyq3trYGHirHxsZoNBokk0mOjo5YWVmh3W4zPz/PyMjIuccHg0Hq9fqdQ3yxWLxyd7LrojpKONmJLBaLvbZCp3Uv6bRarQcrMahWqxgMhkvD3X3LZDKoqnpud/JtGh2M/FOw8N/C/ntgLZ70ouxooKmFlgbowHf+HnzrHz3K0oUQ7xgJlOJZOz2+MZfLsby8TLlcZmJigqmpKUqlEsvLy/fW4FpRFMLhMBMTE/deV+lwOJienqZYLLK1tXXvzdVvwmQyEQgE+P73v8/r16+x2+29HdqLmM1mhoeHSSaTtw5q7XabarXaV6DsNjh/e6fR6XRiMBgu3aU0Go1MTk5SKBRIJpO3WudVHvOGd6fTIZPJ4Ha7r9zRPW3jm3CchJYC6unv/srJeEZU+NY/gJbM+RZC3JAESvHsdevHlpaWMJlMbG5usrOzg81mY2lpiaGhIXZ2du51t9LlcjE3N3fvdZVDQ0NMTU0NPFQ2Gg0KhQLlcplOp8Pk5OS1u27BYJBGo3HrNk7dHUe73X7tY7s9Kt/eiVQUBZ/PRz6fvzToDw0NEQqFeruv9+kxb3gfHBzQbrfx+/19f8zq10+am6uXfOdva6FVhl2ZnCOEuCEJlOKdYTAYeuMbC4UCr1+/5vj4mImJid585+Xl5Xu76WuxWFhYWMBsNt9rXeXQ0BDT09OUSqWBhMrj42NWVlZoNpt84QtfwGKx9NWL02Qy4Xa7SSaTt1pzqVRCp9P11cvSbDaj1WovPPZ2u91oNJorfz/8fj/Dw8Ps7Oz05oDfVavVotlsPkqgVFWVVCqFy+W60XjLSgmu/Z1RoXK//fyFEC+ABErxzjk9vnFnZ4fNzU2sVuuZkY7b29v3Mj1Fp9MxMzPTq6vc3d29lwBot9t7oXJzc/NRQqWqquzv77OxsdELyz6fD5/PRzKZ7GsUZSAQoNVq3WgueFepVOprd7Lr7QbnXVqtFo/H09vBu0z3kk53vOdddS/kPEbLoO6oyZvsTgJY7Fd/01fezAK3Ou+yOiHESySBUryTLhrfmM/nmZycZHJykmKxyOvXr+9lt/J0XWU+n7+3ukq73c7MzAzlcvnBQ2Wr1WJzc5NkMkkwGGRmZgadTgecHGXrdDqi0evn8xmNRtxuN6lU6kYhTVVVyuVyX/WTXTab7cJACeDxeOh0Olcev799SeeuqtUqiqI8+MjF7u7k8PAwJpPpRh+7+FnoKKBc8kdJ0wG9DcaX7mGhQogXRQKleKe9Pb5xbW0Ns9nM4uIiNpvtXncr366rvOg49qZsNlsvVG5sbDxIqOyWAlQqFWZnZwkEAmfer9FoGBsbo1gs9lUfGQgEaLfbNyoBKJfLqKp6o0DZbXB+0ZG1wWBgeHi4dwv6MkajkYmJCQqFwp0n6XQv5CiKcqfnuU4+n6der994dxJg+hPgjICuo56Eyu6XRgVtC1DgB38atLr7XLEQ4iWQQCneeafHNzabzd5EncnJSSYmJnq7lfdxQeN0XeX6+vq91FV2Q2W1WmVjY+Neeyim02nW19cxGo0sLi5eeuQ8NDSE2+0mHo9fe7HJYDDg8XhIp9N9r7VUKqHRaG5Uf9i9mHPZLqXP56PRaFz7++pwOAgGg3e+pPNYN7xTqRQOh+NWR+taHfzUv1DCFCijqKDvgL4N2jZggB/8GfjYj9z7koUQL4AESvFidMc3er3e3vhGk8nU263c2tpiZ2fnzruV3bpKj8dzb3WVp0PlfdT8tdtttra2iMfj+Hw+Zmdnr209Ew6HURSFWCx27fP7/X5UVe3rMg98NL/7Jrt7Wq0Ws9l86U6wxWLBbrf3tYZAINCbtHSbSzqqqj5KoDw6OqJard5qdxJOWg2lsrv80M8l+Nl/Q2XxJ2H2C/CZfxr+hf8AfuCn7nnBQogXQwKleFEuGt+YyWSYmJjoHX0uLy/febdSURQikQjj4+McHh6yvr5+57pKq9V6LzuV3ZrSYrHI9PQ0oVCoryCn0+mIRCLk8/lrvz56vb63S9lPQO8Gypu67GJOl8/no1wu91V+MD4+jl6vv9UknUajQafTefBAmUqlsNlst/paASQSCZrNJmNjYwQmFL74s/Djfwg+9ZNgst7zYoUQL4oESvEiXTS+0WAwsLS0hMViYWtri93d3TvvBLrdbubn52k2m/dSV2m1WpmdnaVWq90qVGazWVZXV9HpdL2JQjfhcrlwOBzs7e1d+9rdXbRUKnXl47oNym8Tkmw224UNzrscDgcmk6mvXUqtVsvU1BTNZpPd3d0braPbD/Mhb3gXi0XK5fK5Gtd+lUolMpkMwWDwxpd5hBDiOhIoxYvVHd+4uLjYG9+YTCaZmJhgfHyco6MjXr9+TaFQuNPrvF1XeZuWOm8/XzdUrq+v9xUq2+02Ozs77O3t4fF4mJ+fv1H/wtNGR0dpt9skEokrH6fT6fD5fGSz2SvrLkulEoqi9Goib+K6Oko42aU8Ojrqq+2RyWTqTUG6ySSdarWKXq/v3Yx/CMlkEovFwtDQ0I0/ttPpsLu7i81mu3ZMoxBC3IYESvHimUymc+MbdTpdb7dyc3PzzruVp+sq9/b2iEajd5ol3Q2VjUaD9fX1K4+Vq9Uqq6urHB0dMTk5SSQSudNNZIPBQCgUIpvNXrvj6vP5UBTlyl3KUqmExWJBo7n5tyOTyYROp7tyHS6XC51O13c9Z/eSzv7+ft8/TDx0/WS5XKZYLN66drJ71D0+Pv7gt9CFEC+TBEohuHh8YzweZ3x8nLGxsd5u5fHx7UeInK6rzOVyrK2t3WkU5OlQubGxcWGozOVyrK6uoigKCwsLDA8P3/r1TvN6vVitVqLR6JUXjrRaLX6/n2w2e2kN6W3rJ7uuq6PUaDR4vV5yuVzfF666l3T6naTz0IEylUphMplu9fvXPeoOhUIP3iNTCPFySaAU4pTT4xuPj495/fo1Go2GxcXF3ojFaDR6p91Kt9vN3NwcjUbjznWVZrP5wp3KTqdDNBpld3eX4eFh5ufn771ubnx8nHq9fm2NpNfrRavVXniE3Gg0aDQaDxoo4aTROXCjcoN+L+m0223q9fqDBcpqtcrR0dGtdiflqFsI8VgkUApxAbfb3evL2K09HBsbY2xsjHw+z/Ly8p12K7uXgoxG453rKruhstlssr6+TrlcZnV1lcPDQ8bGxhgfH7/VcfJ1TCYTgUCAVCrVGzt4EY1Gg9/vJ5fLnatj7IbpuwRKm81Gu92+cg06nQ6Xy0U2m+27hVO/l3S6O5gPFShTqRQGgwGXy3Xjjz191C2EEA9JAqUQl7hofKOqqiwuLmI0Gu+8W6nX65mdnWVkZOTOdZVms5m5uTkODw/5+3//71Ov15mfn2dkZORWz9cvv9+P0Wi8du0ejwedTndul7JUKvXqIG+rn4s5cFLP2Ww2OTw87Pu5TSZT74LWZTuxlUoFRVEeJFDW63UODw/x+/03rn0sFoty1C2EeDQSKIW4xtvjG3d2dhgdHWV0dJTDw8NeT8fbUBSF0dFRxsbG7lRXqaoq2Wy2N21Gq9U+6I3jLkVRGB8fp1wuX7nLqtFoCAQC5HK5MzWJd62f7D63xWK5tnTAZDLhcDhuPL3I6XQSCARIJBIX7kpXq1VMJtODXHZJpVLo9XrcbveNPq5b8iBH3UKIxyKBUog+XDS+sd1unzm23tvbu/VEnJGRkTN1ldfttp3WaDRYW1sjm80yPT3Nj//4jwOwvr5+p0s//bJarb3pQ1e15hkZGcFgMPRmZrdaLarV6p0DZXcN/XzNfD4f1Wr1xuUKwWAQh8PB9vb2uc/xoS7kNJtNcrkcXq/3xiULctQthHhsEiiFuIG3xzfu7OwQDocZHR3ttRy67W7l6brKtbU1Dg4Orv2YQqHAysoKzWaTubk5vF5vrw1Sp9O5803yfgWDQXQ6HXt7e5c+ptv3M5/PU6lUegHwPgKlzWajVqtde4vbbrdjsVj6biF02sTEBDqdjq2trTM/ODxUoEyn02g0mt6Fon7JUbcQYhAkUApxQ93xjQsLC73xjY1Gg/n5efR6Pevr68RisVvtVp6uq4xGo+zt7V1Ym6iqKolEgs3NzV4QPd0Y3Gg0Mjs7i6qqrK2t3Xns43W0Wi2jo6McHx+Ty+UufZzb7cZoNLK/v0+pVEKv199L6Om3jhJOdimPj4+vvMRzke4lnXq93ruk02g0aLfb9x4oW60W2Wy2d0O+X3KrWwgxKBIohbil7gSc7vjGra0tQqEQkUiEg4MDlpeXb9US6HRd5cHBwbmj62azycbGBqlUilAoxPT09IX1kkajkbm5OVRVvZdZ4tdxOBy4XC7i8filO4WKohAMBikUCmQymXvZnYSTz1Wn0/UVKIeHhzEYDLfapTSbzYyPj5PP50mn071Qet+BslvnedNQ2P3ay1G3EOKxSaAU4g5Oj2/U6/Wsra1Rq9WYm5vr/fdtdyu7dZX1er1XV1ksFllZWaFWqzE7O3ttb0KDwcDc3BzAo+xURiIRAGKx2KWPGR4e7t0Mv69ACSfH3v0E+G4T+8PDw1uVAwwPD+P3+4nH46TTabRa7a3HWF6k3W6TyWR6N+P7VSwWyWazctQthBgICZRC3IO3xzdubm7i8/kIh8N32q3sHmcbDAa+/OUv8/Wvfx2TycTCwgJ2u72v5zAYDMzOzqIoCmtra33NtL4tnU5HOBzm8PDw0rGFiqLgdDoplUp3Gj/5tu7FnH6ec2RkBI1Gc+Mb313BYJChoSE2Njbu/TZ9t1emz+fr+2O6R912u12OuoUQAyGBUoh71B3faDab2draolKpMDMzg06nY21tjXg8fuPdSkVR0Gq1NBoNms1m73j3Jk6HyvX19QcNlW63m6GhIfb29i7t0anVarFYLOTz+Xt7XZvNRqfT6as2UqvVMjIycqNG56cpisLExATNZpN0On3r2/1v63Q6pNNpRkZG0Ov1fX9c96h7bGzsXtYhhBA3JYFSiHvWHd84MTHB8fExW1tbeDwewuEwmUzmRm2ByuUyKysrVCoVvvCFL/ADP/AD5HK5W7UE6h5/azSaBw+Vo6OjtFqtXougt5VKpV7/yrtMHDrNYrGgKErfX1uv10un0+nrNv1FujewFUUhGo3e6jnednBwQKvVutHuZPeoOxwOy1G3EGJgJFAK8UBcLhdLS0sMDQ2xu7tLsVhkenoarVbL6urqtbuVmUyGtbU19Ho9CwsLOBwORkZGmJ2dPVNXeRPdW+QajaZX7/kQjEYjwWCQTCZzbo2qqlIulwkGg1it1ktD50312+C8y2Aw4HQ6yWQytzp6r9VqmEwmZmdnOTw8vNUln9NUVSWdTuNyufoOhu12u3fUfdP2QkIIcZ8kUArxgHQ6HRMTE0xPT1OpVNja2sLlchEKhS7drWy322xvbxOLxfB4PMzNzZ259GGz2Xp1lWtra1e26blIN1RqtVrW19cfLFR6vV6sViu7u7tnAlu1WqXdbmOz2QiFQpTL5UvrLW+q3wbnXT6fj3q9fqvX7x6tB4PB3iWd2/YgBTg8PKTRaFx70eq0RCIhR91CiCdBAqUQj8DhcLC0tITb7SYWi1EoFJiYmECj0bC6ukoikUBVVarVKisrKxwfHzM5OUkkErlwpJ9er2dubg63283u7i6xWOxGu2zdUKnT6R4sVCqKwtjYGPV6/cwc7FKphKIoWCwW7HY7drudRCJxL69ptVqp1+vXNjg//XibzXar3cVKpYLRaESj0fQu6Wxvb9/qJr2qqqRSKZxOZ98tiOSoWwjxlEigFOKRdJt/d8c37uzs4HQ6CQaDpNNpvvKVr/Cd73wHjUbDwsICw8PDVz5fN7CNjo6SzWZZX1/vO0jB2VC5trZ240bf/TCbzfj9fpLJZC+0lkolrFZrb5xgMBikWq3eywWdbhuim9yo9/l8lEqlG5cPnJ6Q072ko9Fozk3S6cfR0RG1Wq3v3Uk56hZCPDUSKIV4ZN3xjT6fj2QySS6XQ1EUkskk+XyeoaGhG/U19Hg8Z+oqK5VK3x+r0+mYnZ3tTfh5iFDp9/sxGo296TKlUulM/0mbzcbQ0BD7+/t3biNkMBjQ6/U3CodOpxOj0XjjXcpqtYrFYun9t06nY2pqilqtduNLOqlUiqGhoTPTjq4iR91CiKdGAqUQD2w3A3/5S/An/2f4U78Iv/hlyBU1hEIhxsfH2d7eZmVlhbm5OT7+8Y/3aitvEgxtNltv9OPq6uqN6iq7odJgMDxIqNRoNIyNjVEul4nH4zSbzXMNzUOhELVajcPDwzu/Xr8Nzk/z+Xzk8/m+b743m01arda542mLxcLY2BiHh4d997gsFApUKpW+dyePj4/lqFsI8eTcb0deIcQZf/Or8I++BVoV2goowMEB/JMP4Gc+XWREE2VychKr1Uo+nyefzxMOh8nlcqyuruL3+wkEAhfWUb6t22tyb2+P3d1dKpUK4XC4r4/V6XTMzMywsbHB+vo6MzMzZ3bf7spms+HxeNjY2MBsNp/bibNYLDidTpLJJC6Xq681X6Z7c1xV1b6fx+12s7+/TyaT6U37ucpVIxddLheVSoV4PI7ZbL62AX0qlcJqtfbVqL7dbhONRu981N0uQfHvQSsLOjfYfxdoh279dEIIITuUQjyU31g+CZMATS10tNDWQlMDtFV+6Ws2KoqXxcVFJiYmeuMbY7EYZrMZj8dDKpViZWWl711DjUbD+Ph4r65yY2Oj77rK7k6l0WhkfX39Rjuk/QiFQtTrdfL5/IWN2YPBIPV6/ca31t92kwbnXd2ekgcHB5c2Yz+tWq2i0Wgu3SEMhULYbLZrL+mUSiVKpRKBQKCvdd51VreqwsF/CWtfgL1/DxJ/Hvb+fVj7ImT+s5P3CyHEbUigFOIBqCr8w++ARj0JkpzeKFOgrVHQduB1JtS7nNId3zg6Otrbreweg66srJBMJvuuMezWVXZvjfcbDrVaLTMzM5hMJtbX1298UeW653Y4HHQ6nQuPts1mMy6Xi2QyeafJM90G5zc99vZ4PKiqSjabvfaxpy/kXERRFCYnJ6+9pJNMJjGbzTgcjmtf8/j4mIODA8Lh8K1nh2f/DCT/ArSboG+CsX7y73YL0n8ZMv/hrZ5WCCEkUArxEDLHcHAE7cv+D1OgrSh8uHv+XR6Ph6WlJSwWC8lkEqPRyMjICMlkktXV1b533rr9Kru3uPutTzwdKjc2Nu4tVLZaLQwGA4FAgFgsduHOaSAQoNFo3Hp6DdBrSXSbpu8ul6uvRueVSuXa9j6nL+ns7e1d+BzHx8d91U7ex1F3Mw3ZXzj5tb710c84ypv/Bsj+dWjeT595IcQLI4FSiAdQ76cVoQKXna4aDAamp6eZmJigVCqRz+d7O2g32a3sjlscHh5mZ2eHeDze18d1Q6XZbL63UNndMZybm0NVVeLx+LnHmEwm3G43qVTqTruUt7mYAyeXc5rN5pUtjFRVpVar9VVjarFYGB0dJZfLndv5TKVSGI3Ga9tDwd2PugEK/zu0NKC7pAJC1zopyTj63279EkKIF0wCpRAPwG0HRQvKFdlN0wHHNfcwTo9vzGQy6HQ6hoeH2d/f73u3sltXGYlEyGQyfddVarVapqene6HyNgHttFKphMFgwGq19i4eXTTHOxAI0Gq1+jp6vozVaqXRaNx43rnZbGZoaOjKFkK1Wg1VVftuQO52u/F6vcRisd7XsFar9Uoarrs4dB9H3QDNBCias9UXpymcvL95Pz3mhRAvjARKIR6A1QQfmzy53c1FoVIFVYEfXrj+uU6Pb6zVahwdHeFyueh0OqysrJBKpfradfR6vczMzNyorrK7U2mxWO4cKk/3nxwZGcFutxONRs/tRHaP+FOpVF8XZC5ymwbnXT6fj0qlcukYxatueF8mHA6fuaSTSqUwGAy43e4rP6571D00NHTnBuYaOyd/7i55v8pJ7a/2+svmQghxjgRKIR7I7/sM6M2ga4PS4c3f2KBpg74DHjf8+Pv9P9/p8Y2Hh4doNBocDgeJRIK1tbW+xifa7fYb11VqNBqmp6exWq1sbGzcal51p9OhUqmc6T85NjZGq9Vif/980Z7f76fdbvfdy/Fter0eg8Fwq6P6oaEhzGbzpbuU1WoVg8GAVqvt+zm7l3QURen1CfX5fNfuTsbjcdrt9r00MB/63aBpvbkkdoGOBrQtGPo9d34pIcQLJIFSiAficcAf/1kYDZ0cfWs7J/8oGliahn/jZ8Ckv9lznh7f2G63KRQKOJ1OWq0Wy8vLpNPpa3cru3WVTqez77rKbqi02Wxsbm7eOFSWy2VUVT0TKI1GI4FAgHQ6fS74GQwGPB4P6XT6RuMkT7Narbeu/fT5fBQKhQtD+nU3vC+j0+mYnJwkFouRyWQYGRm58vH3ddTdZV4Cw3s1Wjr13GWxtgbaBrB9Aswfu/NLCSFeIAmUQjwg/zD88d8Hf+IPwT/7E/Dzvw3+/Z+Hf/m3nxyL39bp8Y2FQqH3tng83tdupUajYWJioldXubm5eW1w02g0TE1N3SpUlkoltFrtuSDm8/mwWCxEo9Fzodbv96Oq6o1HInbZbLZekL0pl8uFXq+/8LX7ueF9GYPBgNlsRqPRXNlv8/RR93XBs1+xWIzjf2UF83QTVQN1EzT00DCBqgH7LET+63t5KSHECySBUohHEHDB5+bhM7Pg7G9c87U0mpPxjfPz82i1Wo6Pj7HZbDQaDVZWVvrarezWVVYqlb4u+bwdKi+6VHORt+d3dymKwtjYGLVa7Vx40+v1eL1eMpnMrXYprVYrqqreqkG7oih4vV5yudyZiz2tVotms3nrKUKZTAaXy8Xs7OyZSzpvu8+jblVV2d3dJZPJML4QYeZvGBj/72Dkx8DxCXD/CIz/1zD+i6C9vh2mEEJcSAKlEM+cxWJhfn6eUCjUO+I1mUzE43HW19evnU/dravUarWsrq5e2TIHPgqVdru9r1CpquqlgbK7fp/Px/7+/rmd1W6dYSqVuvI1LntejUZz64tEIyMjKIpy5rb5bS7kdLVaLTKZDB6Ph/HxcaxWK9vb2+duohcKhXs76lZVlZ2dHQ4PD5mYmHjzOYHtCxD6z2HsFyD0X4LtR+EO0y6FEEICpRDvAkVR8Pv9LC4uYjQae8eytVqN5eXlay+3nK6r3N7eJpFIXLm72Q2VQ0NDbG5u9o7dL1KtVul0OpcGSjhpFWQwGIhGo2fertPp8Hq9ZLPZG7cAum2D89OvPTIyQjab7d1Er1arKIpy6cjFq3SDaTckT05OArC1tdX7Wt/nUXen02Fra4ujoyMmJydxuVx3ej4hhLiKBEoh3iGnxzc2Gg1UVe3NB19bW7tyt7JbVxkOh0mlUtfWVSqKwtTUFA6Hg62trUtDZalUQlEUrNbLz/o1Gg1jY2OUSqVzU3K6ASyZTF7z2Z932wbnXV6vl1ar1at37F7Iue529ts6nU7vIk53jrler2dqaopKpUIsFgNO6hw7nc6dj7rb7XavztVrmmXjf3Xy9/84/IN/E77316B8+0FEQghxIQmUQryDPB4Pi4uL2Gw26vU6er2ecrnM8vLytQ3DfT5f33WV3Z22bqg8Ojo695hisYjVar02hNntdkZGRojH42d2I7VaLX6/n4ODAxqNfkYQfcRqtdJsNm/8cV1GoxGn09nb4b3tDe9sNku73cbn851b3+joKNlslu3tbXK53J2PutvtNhsbG1QqFTrLi/zmn7Kx/Y/hKAr5bVj5O/B3/zWI/uatX0IIIc6RQCnEO+r0+EZVVVEUBY1Gw97e3rW1lUNDQ8zPz6PRaK6tq+yGyu5x+duh8qr6ybeFw+HeGk/zer1otdob71J2d0XvMjrS5/P1GsrfJlB2Oh3S6TRut/vCoDgyMoLL5eIb3/hG75j9tlqtVm8n2nywwMbfPjmaV1XejMIBVOi04av/DeQ2b/1SQghxhgRKId5x3fGN3X6V3Ysq1+1WGo1G5ufn+6qrVBSFiYmJ3mO7AbRWq9FqtbDb+xu/otVqiUQiHB0dnQmxGo2GQCBALpe79pLRaXq9HqPReKdjb5vNhtVq7R1H3zRQdm+Kv707+TaDwdC7RX4bjUaDtbU1Wq0Ws7OzbP29N3We3SDZ1f21Cqu/fKuXEkKIcyRQCvECnB7fqNPp6HQ6dDodotEoGxsblx4JX1RXedk4xG6oHB4eZmdnh3w+3wtyV9VPvm14eBin00ksFjvzWt36w4sm61zlLg3Ou3w+HwcHB9RqtRu1DOr20RweHsZkurjxaKFQ4PDwkM9+9rPo9Xq2t7dv3DuzXq+ztrZGp9Nhbm6O9rGZ46tmcisnu5bJb93oZYQQ4lISKIV4QRwOB4uLi3i93t7bCoUCy8vL5y7DnNatqyyXy6ysrFxaV6koCuPj4wwPD7O9vU08HsdisdxoTCHA6OgonU6HeDzee1t3l/Lw8PDafpmn2Wy2k3rCt2aG34TT6URVVQqFQu9STT/y+Tz1eh2/33/h+7u3uh0OB4FAgMnJScrl8pnP+zq1Wo21tTUURWFubg6j0Uizzy9P63aboUIIcY4ESiFemO74xrm5OcxmM6qq0mw22d3dvXK3cmhoiIWFhWvrKruh0u12945gb0qv1xMKhTg4ODgzkWdkZASDwXCjWsq7NDjvUhSl1zT+Jhd8kskkDofj0l3N7jH66OgocBJ+u9OLrpqk01WpVFhbW0On0zE3N9er0bR6TkZ8XscsnYSEEPdEAqUQL5TNZmNhYYFgMIhWq6XT6ZDL5a7crezWVTocDra3t9nf37/weFZRFILBIBaLhYODg77C0ds8Hg82m41oNNrbXew+bz6f7zsgdkcd3qWOEk5aMpnN5mt7enYdHR1Rq9Uu3Z0sFArkcjkikciZyzoej4eRkRGi0eiVR/WlUon19XWMRiOzs7Po9R8NhjdYwf/JNqDCRafnby7pTP1YX5+KEEJcSwKlEC/Y6fGNdrsdjUZDtVplZ2eHzc3NCy+IaDQaJicnCYVCJJNJtra2LqyrLJfLBINBIpEIu7u7twqVY2NjNBqNMzuSLpcLk8nUdy1ltwfmXeoo2+02zWazt2t6WR3paalUCrvdfuEN99NH3W63+9z7R0dHsVgsbG9vX7jDWywW2djYwGw2MzMzc+4Y/vj4GPOn1tAa2yjKm1B56h9FAZsXZn+636+AEEJcTQKlEKI3vnF0dBSTyUSr1SKbzfL69etLg6Df72dmZoZSqcTKysq5sYmlUgmj0cj09DQej4fd3d0r6zQvYjKZCAQCpNPp3o6koigEAgEKhULfIfGugbL7uUUiETqdzrWfx/HxMeVy+dLdyesamHebxquqeu6STqFQYGNjA5vNxszMzLn61HQ6zcbGBsMRPT/x7yk4J97q/6mA72PwE/8eGG43klwIIc5R1JteJxRCvNNqtRrRaJRCoUCj0cBgMOByuRgbGztzrNpVr9fZ2tqiXq/3WgcBrKysYDabGR8fB2Bvb49sNsvY2NiNei2qqsrKygqKojA/P99rkL68vIxOp2N2dvba5ygUCmxubvLq1atbj02MxWJ84hOfIBqNUiwWefXq1aXN2tfX12m32ywsLFy6lm6d6VW6x9oej4dIJMLh4SG7u7s4HA4mJyfPvH731v7h4SF+v59gMNh7/+Eu5NZBowXfK7Bd3cFICCFuTHYohRBndMc3TkxM9C6ipFIpXr9+zeHh4bnHn66r3NraYn9/n3a7TaVSOXPcOzo6itfrJRqNXjut5zRFURgbG6NSqZypXwwGgxSLxTOXdi5z1wbn1WoVk8mEoih4vV4ajcaFU4G6r1EsFgkEAufe12q1rjzqftvpSzrr6+vs7OzgcrnOhcl6vc7q6mpvbncoFDrzftc4zPwUTP2EhEkhxMOQQCmEuFB3fKPf70ev1/eOWre2ts7VVr5dV/n973+fdrt9rn4wEong9XrZ29vr+3ILnARCn8/H/v5+r7G50+nEYrH0VUup0+kwmUy3vphzekKOxWLBbreTTqcvfGwymcRkMvV2ak+7zaxuj8eDqqp84xvfwGazMT4+fiYsHh8fs7q6SqfTYX5+nuHh4Zt9ckIIcQ8kUAohLtUd3zgzM4PT6aTRaBCPx1leXr5wt9Lv9zM9Pd07Ir5IJBLB5/MRi8VuFCqDwSA6nY5oNHrmbaVSiePj42s//i51lG+PXPT5fJTL5XMBtVqtUigULqydPDo64vDwkEgkcmHpwGWSySSqqhIMBmk0Gmcu6XTrJS0WCwsLC7eaMy6EEPdBAqUQ4lrd8Y3hcBiTyUQul2N9fZ2tra1zt5AdDgfBYBCr1do7hn1bOBzG7/cTi8Uu3el7m0ajYWxsjGKx2Lso5HA4sNlsJBJXjYU5YbPZqFarN25w3mg0aLfbZ8Kaw+HAZDKdW3sqlerVnJ7WarXY29vr+6i7K5FIsL+/Tzgc5vOf/zydToft7W3a7TY7OzvE4/FeiL9p83ghhLhPEiiFEH3pjm+cn5/H4/FQr9fZ29vjww8/PNPkvNso/f3338dut/fqKt8WCoXw+/3E4/G+Q+XQ0BBut5tYLNY7dg8Gg1QqlUtrGru6Dc5vukvZncrz9u6fz+fj6OiodwRfr9d7F2Levqxzm6Puvb09UqkUkUiEQCCAwWBgcnKSw8NDfv3Xf/3SekkhhBiE/meICSEEH41vTCQSJJNJstksxcM6RKc5WndRq6hoDdOYfkrP7I+ZyFiS7O/vU61WGR8fP7OT1g1D8XgcVVUvbbNzWjgcplAoEIvFmJycxG63Y7fb2d/fv7BusctkMqHVaimXy9jt9r4/30qlglarPdN8HE52bROJBOl0mtHRUVKpFHq9/twOZPeoe3x8vK+jblVViUaj5HK5czfiVVWlWq2SzWaZm5uTekkhxJMhO5RCiBvrjm9cWlrCqZkg+j9/gtdfdbGfg3xFQ7po4zf+VxP/4E+C2xFgenqaYrHI6urquX6VwWCQQCDQC6jX0el0RCIR8vl8b1cyGAxSrVYvHQcJHzU4v+nFnGq1euHoRI1Gg9frJZfLUalUyOVy+Hw+NJqPvq3e9KhbVVV2dnY4PDxkYmLiTJjs1kuGw2E+9alPkclkbjTTXAghHpIESiHErZn1NnZ+aYqiTo+lqmCtKFiqYC8p6Juwl4Ov/Lcnu5rz8/MArK6uUigUzjxPMBgkGAyyv7/fV6h0uVw4HA729vZ6t8kdDseloyC7bnMx5+0LOad5PB7gpCemRqM511/zJkfdnU6Hzc3N3lF2tw6z0+mcq5ecnJzEZDJdWMMqhBCDIIFSCHFrO1+Go7qCpaKgeeuui74F+gZsL0MxdXLk3B3xuLm5eS44BgKBXqjspxXQ6Ogo7Xa7dyEnGAxSq9UuvH3eZbPZaLVa53ZJL9PpdKjVapcGSp1O1+u/OTIycuY4v3vUPTo6eu1Rd7vdZnNzk1KpxPT0dO/o/rL+khqNhqmpqd7lHJlPIYQYNAmUQohbS3wb2jrQXjLa2tCAhl4l+rWTB2i1WqampnrB8e054IFAoNfL8rpQaTAYCIVCZLNZSqUSFosFp9PZa7NzkZs2OO8Gz6va8aiqSqvVOjNPu9vA3Ol0nrvx/bZWq8XGxgaVSoWZmRmGhoaA6/tLdi/pHB8f9z3XXAghHooESiHErbXqoFyxOaaooCqwH0ufOeYOBC6vq/T7/YTDYZLJ5LXtgDweD1arlWg0SqfTIRgMUq/XL521rdVqMZlMfQfKy254d7XbbYrFIqOjo2d2RmOxGKqqMjo6euXzN5tN1tfXqdfrzM7O9hrB99tf0m63Ew6HSaVSV9aPCiHEQ5NAKYS4taEAoMBlmbKlBV1boUyS73znO+zu7vZ2JK+qq/T5fL2gFI/HL3397ljGer1OKpXCbDbjcrlIJpOX9pu02Wx9X8ypVCoYjcYzF21Oy2azdDodlpaWqFarHB8f933U3Wg0WFtbo9VqMTc3h8ViubBe8rr+kj6fD5fLxe7urlzSEUIMjARKIcStzfw2MNSgZjr/PhWomcGuV1n6bQ7a7TYffvgh3/3ud3vhsVtXabPZztVV+nw+IpEI6XT6ylBpNpvx+/2kUimq1SqBQIBWq3XpLqXVaqVarZ45ar/MZTe84aS+Mp1OMzIygsvlwmKxkEgk+jrqrtfrrK2toaoqc3NzmEyma+dxX2VsbAyj0SiXdIQQAyOBUghxa84IvP+jgAJly8mOZEeBpg7KtpMayh/6eYXZuWk++clP9hqZf/Ob3+ztVmq1WqanpwkEAufqKr1eby9UXjbKEU6O0I1GI9FoFKPRiNvtvnSXsnus3M+x91U3vA8ODmi32/h8PuAkAK+vr1Or1a486q5Wq6ytraHRaJibm8NoNN55Hrdc0hFCDJoESiHEnXzq5+Fz/xQ4tNA0QNUMbS0ErPBT/wqMffbkccPDw3z84x/nYx/7GADf+973+O53v9ubwx0MBpmamurVVXYn0Hi9XkZHR8lkMpeGSkVRGB8fp1wuk81mCQQCtNvtC2eFn25wfpVms0mr1bowUKqqSjqdxuVyYTQae2+v1WoYjcZLj7orlQrr6+vodDrm5uYwGAz3No/baDQyMTEhl3SEEAMhk3KEEHeiKLD0e2H+d0HqQ2iUwOaFkdmT952m0+kYHx/H5XKxublJLBbj8PCQmZkZIpEITqeT+fl5tra2WFlZYWJiAofDgcfjQVEUotHopZddrFYrXq+XRCKB0+lkZGSEVCqFx+M5V4fYTx3lVRdycrkcjUajN9mn1WoRi8UYHx+n0+nQbDbPhcpSqcTm5iYmk4np6Wk0Gk2vibnf7ycYDN55hOLQ0BChUIhEIoHFYpFJOkKIRyM7lEKIe6HVQ+gTMPEF8MydD5OnDQ0N8bGPfYxPfvKTaDQavv3tb/Ptb3+b4+Pjc3WVqVQKgJGREcbGxshms+zt7V34vMFgEJ1ORzQaJRAIoKrqhbuU/TQ4r1araDSaMzuQcLI7mUqlcDqdmEwnxaPd9XzsYx9Do9Gce83j4+PeLuTMzAztdvvW9ZLX8fv9DA8PyyUdIcSjkkAphBgIrVZLJBLhM5/5DJOTk8TjcX7rt36LaDQK0KurTCQSbG9v0+l0GBkZYXx8nGw223vc2885OjrK8fExxWIRj8dDOp0+d1HFZrPRbrevbHBeqVQu3J08OjqiXq8TCAQAyOfz5PN5IpEIJpOJkZGR3u3v7uM3Nzex2+1MT09TLpfvVC/Zj/Hx8d4lnW49arMNxw1oXXz5XQgh7kSOvIUQA2Wz2Xj//ffxer2srKzwzW9+k1QqxeLiIsFgEIvFws7ODqurq0xNTfVmYu/u7gKcG2vocDhwuVzEYjHm5ubIZrOk02lCoVDvMd2b26VSqbfL+LZqtdprhH5aMplkaGgIi8XSm9V9+la31+slk8lwcHCATqdjd3cXp9PJxMQEmUyGeDzO0NAQExMTZ5qh36fuJZ2VlRV+/fU+X61E+F4M6JzsJH9mHP6ZuZM6VyGEuA+yQymEGDiNRkMwGORzn/sc09PTJBIJfuM3foPd3V2GhoZYWFig0+mwsrLC8fExbrebiYkJDg4O2N3dPXerORKJACfhrxvwms1m7/1arRaz2XzpsbeqqtRqtXMtgwqFAtVqtVc72T3qPl3TaTAYGB4eZm1tje3tbVwuF2NjY+zu7p7pL/lQYbLLaDSSs83w36+FWFtT0TTf9Autwnc+hD/+j2C7cN2zCCFEfyRQCiGeDLPZzPvvv8/nP/95jEYj3/jGN/j6179Os9lkYWEBm83GxsYGqVQKl8vFxMQEuVzuXKjU6XSEw2EODw8xmUwoikI6nT7zWlddzKnVaqiqeu7IO5lMYrPZsNvtvaPuyxqYR6NRTCYTgUCAtbW1B6mXvEq5CX/pAyuGqsKxXaFmfnML3wLHVtAU4M98FaTDkBDiPkigFEI8KYqi4PP5+OEf/mEWFhZIJBL82q/9GrFYjImJCfx+f6+u0ul0Mjk5ST6fPxcq3W43Q0ND7O/vMzIycm6X0mq1UqvVLmxwftEN72KxSLlcxu/39466h4eHz9VAJpPJ3qScbrPyh6yXvMyvREEpQ8WiwFv5VdVAxQT5HHz3/J0lIYS4MQmUQognyWg08urVK37kR34Eq9XK1772Nb761a/icDiYnJykUCiwurqKxWJhYmKCfD5/rqn36OgorVaLVquFVqs9M4nnqgbn1WoVg8Fwpt1Qd7Sjw+G48KgbIB6Ps7+/TygUwu/3s7KyAsD8/Pyt+0ve1moOtB3oXDK5saUHfQs+zD3qsoQQ7ygJlEKIJ21kZIQvfOELvPfee6RSKb70pS+Rz+eZnZ2l0+mwurqKVqtlcnKSo6OjM6HSaDQSDAbJ5XLY7XYODg56DdONRiM6ne7CY++3J+SUy2WOj48JBAJnjrpP10Hu7e31Lv9Uq1WKxSKBQACbzfbg9ZIX6fckW068hRD3QQKlEOLJ0+v1LC4u8mM/9mPY7Xa+/vWv8+1vf5tIJILFYmFjY4N6vd4Lldvb271Q6fV6sVqtVCqVc7uUl/WjfLtlUCqVwmg0YrVazx11q6rKzs4O2WwWv9/P4eFhr17y/fff77UZemxzLlAV0FwyslzXPBmRueR+3HUJId5NEiiFEM+Gy+Xii1/8Ip/4xCfIZDJ86UtfQlEUvF4v8XicfD7PxMQEhUKhFyoVRWFsbIxGo4FGoyGXy/X6T9psNsrl8plj8larRbPZ7N3wrtVqHB0d4ff7e6Mfu0fdqqqyvb1NPp/H4/FwcHBwpl7S7Xaj0+kubK7+0H77GLStYK5ybhtS6YClBg4XfNL76EsTQryDJFAKIZ6V7hzsn/zJn8TlcvH1r3+d7e1tvF4vR0dHJJNJwuEwhUKBra2t3m1tn89HvV5HVdXeLqXVaj3X4PztCznJZBKDwYCiKBwdHfWOujudDpubmxQKBex2O9lsFovFcqZeUqPR9ILmRZd/HpLNAP/qZ6BlgqESGGugb4CpCvYStIfg//WZqycaCSFEvyRQCiGeJYfDwRe/+EU+/elPc3BwwNe//nX0ej2tVotkMonP5+P4+JitrS06nQ6BQACz2Uyr1eLw8LDXuFxRlDN1lNVqFUVRMBqN1Ot18vk8LpeLeDzeO+put9tsbGxwfHyMXq/n+Pj40v6SHo8HVVXJZrOP/SXi8yH4t38cpqZB1YKigmqEjy3Bf/QTMC2jvoUQ90RR3+4ILIQQz0ypVOJb3/oW8Xgcn8/HyMgI7XYbh8NBsVjEZrMxNTVFpVJhdXWVSqVCKBTqTZMxm82Mj48DJ/0jK5UKCwsL7O3tkc/nsVgsVCoVlpaWANjY2KBUKqHRaNBoNIyPj1/ZEigajVIoFHjvvfcepQflRWqtk96UQwbQX3LzWwghbkt2KIUQz57NZuOLX/win/3sZykUCqytrVGpVDg6OkKr1fZ2Ki0WC16vl06nQzabpVKpnGtw3r3h3Ww2OTg4wGAwcHx8zOjoKKqqsr6+Tj6fp91uYzQa++ov6fV6aTabHB4ePvSX4lImHbjNEiaFEA9DAqUQ4p2gKApTU1P8zt/5OwkEAuzt7RGLxSgWi6iqSj6fZ3Nzk0AgwPDwMPl8nv39faxWK/V6nVarhaqqvUCZTqdpt9tUq1WGh4exWq2sra31Ju643e6++0uazWaGhobOTesRQoh3hQRKIcQ7xWKx8IUvfIHPf/7zdDodtre32d/fp9lskslk2NnZIRKJYDKZere24aTXZL1ep9PpYDAYyGazNJtNtFotPp+PlZUV4vE4JpOJsbGxG8/j9vl8vf6UQgjxrnn8brtCCPHAFEVhfHwcv9/PN7/5Tba3t8nlcgQCgV5PyEgkwve//31SqRR6vZ5SqUSn0wFOxiwWCgXMZjNer5fV1VUSiQR+v5+ZmZlbjVAcGhrq7Xza7fZ7/XyFEGLQ5FKOEOKdt7e3x9e//nUymQx2ux2Xy8Xo6Ci5XI5isUg4MsphfRiL0YxaS6LX1jk8PCQcDnN0dEQmk2FiYoK5ubk7jVDM5XLs7u6ytLSEyWS6x89QCCEGSwKlEOJFaDQafPOb3+SDDz6gXC7j8/kwRWb4G+VJsho3+qaCpgOWmsp45YAfDe6gU/OUSiWWlpZufMR9EVVV+eCDD3A4HIyNjd3TZyaEEIMngVII8aIkEgn+yT/5J3wjU+Lb7//z2I9PQmJDfzKq0NAETUfFl23xRfuv8qOfXyAcDt9bu59UKsX+/j7vvfceer3+Xp5TCCEGTQKlEOLFqTea/K5vqpgPDLR00DSceqd6MufaWFf54UqTP/7PGi59nttot9t8//vfx+fzEQwG7/W5hRBiUOSWtxDixfmtip529SQoNt/Oiwq09NDSK6zUDWTy9/vaWq2WkZERstls7xKQEEI8dxIohRAvzrdKJ0fbncu+Ayon76uZIJ65/9f3er20Wi1yudz9P7kQQgyABEohxIvTUU/qJa+qilRU6CjQbjd6b2vUoHAIjfrdXt9oNDI8PEwm8wBpVQghBkD6UAohXpyP2eCXjWC8LBiqoG2Bsd7ig2/8EokPxzlOLJFNWFFVBY0Wphbgh34KvKHbrcHn87G6ukqhUMDhcNz6cxFCiKdAdiiFEC/OjztAb4OOFkzVt96pgqEOCipjtW2aRy42v/4DZOIWVPVkT7PThs1llb/+X0Fs63ZrsFqtWK1WGccohHgnSKAUQrw4Og386TkoDkMHsJRPgqWxBtaiiqYDk7U6f/ALBsqJHwVVA2hQoPeP2lFotVT+1l9p0Wi0b7UOn89HsVikUqnc2+cmhBCDIG2DhBAv1loF/uw2fHDwZldSBXsHfnqkwXvKhxTT43z7V13AxfWW3W+erqkvM/u+ytjYGKFQCI2mv5/VVVXl9evXWK1WJiYm7ueTEkKIAZBAKYR48cptyDfBoQe79uRtmUyGf/CLWjJ7rpPbOZfRqISms5h8X6FUKmEwGAiHw0xMTOD3+69tiJ7JZIjH47x69QqD4X57XgohxGORSzlCiBfPqj355zSv14vBcAyqytX3wcHj9fITP/Mz5HI5tre3icVibG9vYzKZGB0dZWxsDJ/Pd+HHjoyMsL+/TyaTIRwO39NnJIQQj0sCpRBCXGL2lY3Y+snx9aVH3h0FrSVBterC7Xbjdrv59Kc/TTqdJhqNEo1GWV9fx2KxEIlEmJycxO12955Do9Hg8XjIZrMEAgG0Wu0FrySEEE+bHHkLIcQlmk34c/+OSr0OoJwJlSqgKGCxtfnC71+lXq/h8XgIBoPodB/9rK6qKqlUip2dHWKxGM1mE7vdzujoKJOTkzgcDprNJh988AGhUOjSnUwhhHjKJFAKIcQVdtfhl/6iSqdDr20QgKIBvQ7+wP8V/BGVTCZDMpkEIBgM4vF4ztVPdjodEokEu7u7JBIJWq0WDoeDsbExNBoNqqry6tWra+suhRDiqZFAKYQQ18jsw5f+1jHJHRudtgadDuY/Dj/4k+DyfPS4VqvF/v4+2WwWk8lEOBy+tGl5u90mFouxu7vL/v4+tVqNYrHIpz/9aT72sY9htVof55MTQoh7IIFSCCH60Gq1WF5eQaMYWVycQaO9fBexWq0Si8UoFos4HA7C4TAmk+nSxzebTfb29vjN3/xN0ul0b4dzbGyM8fHxKz9WCCGeAgmUQgjRp1KpxPr6Oj6fj1Do+pmLR0dHxONxGo1Gr77yqks3hUKB5eVlTCYTBwcHvVnfPp+vFy71ev29fT5CCHFfJFAKIcQNpFIpEokEMzMzDA0NXfv4TqfTq6/UaDQEg0FGRkYurZN8/fo1JpOJqakpqtUqu7u77O7uksvl0Gg0+P1+JiYmCIfDEi6FEE+GBEohhLihzc1NyuUyi4uLfYe6ZrNJIpEgl8thNpuJRCLY7fZzjzs4OCAajbK0tHTmqLtcLrOzs8Pe3h6Hh4fodDqCwSBjY2OEw2FpNySEGCgJlEIIcUMn9ZTLGI1GZmdnb3Qru1wuE4/HKZVKOJ1OwuEwRqOx9/5Op8MHH3zA8PAwo6OjFz7H8fFxb+fy+PgYvV5PKBRifHycYDDY9+hHIYS4LxIohRDiFkqlEmtrawQCAYLB4I0//vDwkEQiQbPZxOfz4ff7e7uMyWSSVCrFe++9d6an5WXPs7u7SzQapVwuYzAYiEQiTExM4PP5pAWREOJRSKAUQohbSiaT7O/v911P+bZOp0MqlSKdTqPVagmFQrjdblqtFh988AF+v59AIND38x0cHPSOxavVKmazmdHRUcbHx/F4PNc/gRBC3JIESiGEuIONjQ0qlcqN6inf1mg0SCQSHB4e9kY0Hh4ecnR0xKtXr258hK2qKul0mt3dXWKxGPV6HavVyujoKBMTE7hcrlutUwghLiOBUggh7qDZbLKysoLJZGJmZuZOR8ylUolYLEalUsFqtXJ0dMT09DQjIyO3fk5VVdnf32d3d5d4PE6z2WRoaKgXLi9rvC6EEDchgVIIIe6oWCyyvr5OMBi80RH1ZXK5XG9E49DQEF/84hfv5aJNu90mkUgQjUZ7ox+dTidjY2NMTExgs9nu/BpCiJdJAqUQQtyD/f19kskks7OzF7YDuql2u83W1hbf+MY3mJycZG5u7l6PqlutFvF4nJ2dHZLJJJ1OB7fb3WugbrFY7u21hBDvPgmUQghxD1RVZWNjg1qtxuLi4rW3s/v1ve99j4ODA5xOJ1arlUgkcu9zvhuNBnt7e0SjUVKpFAAej6d3oUdGPwohriOBUggh7kmz2WR5eRmLxcLMzMy9POfh4SE7OztEIhEODg6oVqu43W5CodCDTMqp1WpEo1Gi0SjZbBYAv9/P2NgYo6OjGAyGe39NIcTzJ4FSCCHu0fHxMRsbG4RCIfx+/52fT1VVPvzwQ+x2O2NjYxwcHLC/v0+n0yEQCOD1eh+skXmlUun1uOyOfgwEAr3Rj/e1CyuEeP4kUAohxD3r1lPOzc3dy0WXdDpNIpHgvffeQ6/X0263SSaTZDIZDAYDoVCI4eHhe1j55YrFYi9cHh0dodPpCIVCjI2NEQqFrh39eBCH9a9CvQJWByz8MNjdD7pkIcQjkkAphBD3TFVV1tfXqdfr91JP2W63+eCDD/B4PIRCod7ba7Ua8XicQqGA3W4nEolgNpvvuvxrFQqFXgP17ujHcDjcG/14unVSswa/8hch/n1QAEUDagdQYP5H4At/8ORtQojnTQKlEEI8gG49pdVqZXp6+s7PF4/HOTg44P333z93xH18fEwsFqNWqzEyMkIoFHq04+hujWc0GqVSqWA0GolEIoyPj+Pz+fi7/5XC/mtQAVXhJFWqoKgnv1z6Sfj8P/MoSxVCPCAJlEII8UAKhQKbm5uEw2F8Pt+dnqvRaPDhhx8SDofxer3n3q+qKtlslv39fYBefeVjzvLOZDJEo9He6EdtPcTx134MlDdh8i1KBxQt/OE/DZabT64UQjwhEiiFEOIBJRIJ0uk0c3Nzd273s7OzQ7lcZmlp6dKg2Gq12N/fJ5vNYjKZCIfDjz4Npzv68df/qkJh3UNH0ZxsR557IGhU+MwfgI/9tkddohDinknlihBCPKBgMIjVamV7e5tWq3Wn5/L5fNTrdY6Oji59jE6nY3R0tDdbfHNzs9cf87EoioLf72fI4kNBuThMAiigKFA5frSlCSEeiARKIYR4QIqiMDExQbvdJhqN3um5LBYLNpuNdDp97WPNZjOzs7NMTU1Rr9dZXl4mFovdOdTehMkGqqKcFFBeRD3ZzexoSo+6LiHE/ZNAKYQQD8xgMDAxMcHR0RGZTOZOz+Xz+SiXy5TL5b4e73Q6WVpaIhgMksvleP36Ndlslseodpr/HKjqFRuUKqga0Hq2+P73v8/Gxga5XI52u/3gaxNC3C+poRRCiEcSj8fJZDJ3rqd8/fo1ZrOZycnJG31cs9lkf3+fg4MDzGYz4XCYoaGHvQ3zd/5zSK5cfst78cfhs7+/RT6f5/DwkFKphKIoOBwOXC4XDofj2sbtrQZsfAsKGdAbYfpT4PA86KclhHiLBEohhHgkqqqytrZGs9lkcXHx2mbgl8lms+zt7fHq1SuMRuONP75SqRCLxSiVSjidTsLh8K2epx+NGvzKX4DEByf1koryUR/KuS/CF//Q2T6UjUaDfD5PPp+nXC6j0WhwOp0MDw/jcDjOXUZ6/Zvwlb8J9Tq9rVBFhYn34Cf/CBhkDLkQj0ICpRBCPKJ6vc7Kygp2u52pqalbPUen0+GDDz7A5XIRiURuvZZ8Pk88HqfZbOL1egkEArcOudfJxt5MyimDbRjmfxiGrpmUU6/XOTw8JJ/Pn7Qh0mpxOp24XC7sdjurv6Xwpb928tjujmf3LzRVA8EJ+H1/TBqnC/EYJFAKIcQjOzo6Ymtri0gkcmFPyX7s7++TTqd5//337xQCO50O6XSaVCqFRqMhFArhdrsftX9lP6rVau9YvF6vo1F0fPOvL1GvatFc0OSye8T+038UJj72+OsV4qWRn9uEEOKROZ1OvF4v8XicSqVyq+fweDy9ZuZ3odFoCAQCLC0tMTQ0RDQaZXV1lVKpdKfnvW9ms5lgMMirV69YWFiglQ9Rr+pQLuqYzpsxjwosf/lx1ynESyWBUgghBiAcDmM2m9ne3r7VrWa9Xo/b7SaTydzLje3uTfT5+XkURWFtbY3t7W0ajcadn/u+WSwWjMrItY9TVSjmH2FBQggJlEIIMQiKojA5OUmr1bp1f0qfz0ez2eTw8PDe1mW1Wpmfn2d8fJxSqcSHH37I/v4+nU7n3l7jPhhtfTxIAZPlwZcihEACpRBCDIzRaGRsbIx8Pn+ro2uTyYTD4eir0flNud1uXr16hd/vJ5VK8eGHH5LL5e79dW5r4n3Q6y+eEQ5vLueoMPvpx1yVEC+XBEohhBig4eFhPB4PsViMarV644/3+XxUq1WKxeK9r02j0fTqFm02G7u7u6yurvbdVP0hGUzw/o+e/Frl7DAeFUADQ06Y/cHHXpkQL5MESiGEGLBwOIzJZLpVPaXdbsdsNj/ILmWXwWBgcnKSubk5VFVldXWVnZ0dms3mg71mPz77e+HV505+rWqgozn5t6qAwwW/918HnWGgSxTixZC2QUII8QTUajVWVlZwOp1MTEzc6GNzuRy7u7ssLS1hMj1sJ29VVcnlciQSCTqdDn6/H5/Pd+00m4d0mIAPfwOOcyeTcqY+ARMfhwdqqSmEuIAESiGEeCIODw/Z2dlhbGyMkZHrbzF3qarKBx98gMPhYGxs7AFX+JF2u00ymSSTyaDX6wmHwwwPDz/Kawshnh458hZCiCfC5XIxMjJy43pKRVHwer3kcrlHO4bWarWEw2GWlpZ67Y/W1tZu3VdTCPG8SaAUQognJBKJYDQa2d7evlGrHo/Hg6Iod250flNGo5Hp6WlmZmZotVqsrKwQjUYHXl8phHhcEiiFEOIJ0Wg0TE5O0mg02Nvb6/vjtFotIyMjZLPZgfSMHBoaYnFxkdHRUY6Ojnj9+jXpdPpemq4LIZ4+CZRCCPHEmEwmRkdHyeVyN+r96PV6abVaA+sXqSgKHo+HpaUl3G43iUSC169fc3R0NJD1CCEejwRKIYR4gtxuN263m729PWq1Wl8fYzQaGR4eJpPJPPDqrqbT6YhEIiwuLmI0Gtna2mJjY+NWfTaFEM+DBEohhHiiRkdHMRgMN6qn9Pl81Gq1J7EraDKZmJmZYXp6mnq9zvLyMnt7e7RarUEvTQhxz6RtkBBCPGHVapXV1VVcLlffLYFWV1dRFIW5ubkHXl3/VFUlk8mQTCYBCAaDvYtEQojnT3YohRDiCTObzUQiEQ4ODjg8POzrY3w+H6VS6Um18FEUBZ/Px6tXrxgeHiYWi7G8vMzx8fGglyaEuAcSKIUQ4okbGRnB5XIRjUb7qqd0Op0YjcYHHcd4WzqdjrGxMRYWFtDr9WxsbLC5udl3nagQ4mmSQCmEEM/ATeopu43O8/k8jUbjkVZ4MxaLhdnZWSYnJ6lWqywvLxOPx288y1wI8TRIoBRCiGdAq9UyOTlJrVYjHo9f+/iRkRE0Gs3Ab3xfZ3h4mKWlJYLBINlslg8//JBsNiv9K4V4ZiRQCiHEM9Gtp8xms+Tz+Ssfq9Fo8Hg8HBwcPPldP41Gg9/v59WrVzgcDvb29lhZWaFYLA56aUKIPkmgFEKIZ8Tj8TA8PEw0GqVer1/5WK/XS6fT4eDg4JFWdzd6vZ7x8XHm5+fRaDSsr6+ztbV17ecphBg8aRskhBDPTLvdZmVlBa1Wy/z8/JWtd3Z3dykWi7x69erZteg5PDwkkUjQbDbx+Xz4/X60Wu2glyWEuIDsUAohxDPTraesVqvX1lP6fD4ajca1R+RPkcvlYmlpCb/fTyaT4fXr1wMbKymEuJrsUAohxDOVyWSIxWJMTU3hdDovfdzGxgatVouFhYXHW9w9azQaJBIJDg8PsVgsRCIRbDbboJclhHhDdiiFEOKZ8nq9OJ1Odnd3r2wP5PP5qFQqlEqlR1zd/TIYDExMTPSm/6ytrbGzs/Nk2yIJ8dLIDqUQQjxj3XpKnU7H3NzcpXWSy8vLGI3G/397d9Lb2JqQcfzxGCdxBsfxfJxUUkkqTqoRLBqEhETTLaFGoAYEYsGC/hogVixoCRYs+QoIwRYQEmJHA5cFalEVZ6jKUJ5jO4NjO/F0Dot0pe/tTvVNlVM5Hv6/1a1yFo9K9+o+9fo579Hz58+fOOHnUa1Wlcvl1Ov1FI1GFYlE5HRyRgLYhf/6AGCIuVwuraysqNlsKpfLffDnwuGwLi4uRuaNNMFgUNvb2wqHwyoUCnr9+vWDX00J4PFRKAFgyE1PTyuRSKhUKuny8vLenwkGg/J4PAN/0fnHcLlcSiQS2t7e1tTUlI6OjrS3tzdQ7zAHxgWFEgBGQCQS0fz8/Ad3hQ6HQ6FQSNVqVd1u14aEn8/7r/I3NjbuJgDHx8fqdDp2RwPGBoUSAEbE8vKyXC6Xjo6O7n11YSgUkiSVy+WnjvYkZmZmlEqltLS0pMvLS7169UrFYvFr330OoH8USgAYEW63W6urq2o0Gsrn8/d+HgwGdXp6OrIl6/1J7MuXL7W4uKh8Pq+dnR1dXFzYHQ0YaRRKABgh7/eUxWLx3j1lOBxWt9sd+QdYXC6Xksmktra25PP59PbtW+3v7+v6+truaMBIolACwIiJRCKam5u7d0fo8/k0Pz+vUqlkU7qn5fP5tLa2prW1NXU6He3s7Ojdu3cjtyMF7EahBIAR9OzZMzkcDh0eHv7MnjISiejm5uaDT4SPorm5OW1tbSmZTOrs7EyvXr1SqVS6d2sK4ONxsTkAjKh6va79/X1Fo1HF4/GvfJZOp+VyubSxsWFTOvt0u13l83mVy2X5fD4ZhqG5uTm7YwFDjRNKABhRfr9f8XhchUJBtVrtK59FIhFdXV2N5abQ7XZraWlJW1tb8ng8evPmjQ4ODkbm0nfADhRKABhh0WhUs7OzOjo6+sqeMhAIyOv1js2W8j6Tk5Pa2NjQ8+fP1Wq1tLOzo0wmo16vZ3c0YOhQKAFgxK2srMjhcHzlfkqHw6FwOKyzs7OxvwB8fn5e29vbisfjqlQqevXqlcrlMvtK4CNQKAFgxLndbq2srOjq6krFYvHu9xcXF+V0OkfqdYyfyuFwKBqN6uXLl5qfn9e7d++UTqd/ZioA4H4USgAYAzMzM4rH48rn87q6upJ0e1fj4uKiyuXyyF50/rE8Ho+Wl5eVSqXkcrl0cHCgt2/fqtVq2R0NGGgUSgAYE9FoVDMzM1/ZU4bDYZmmqUqlYnO6wTI1NaUXL15odXVVzWZTr1+/VjabZV8JfADXBgHAGHl/uffU1JTW19clSUdHR2o0Gtre3pbD4bA54eAxTVOlUknFYlFOp1OJRELBYJA/K+BLOKEEgDHi8Xi0srKiWq2mQqEg6fYKoVarxfuuP8DpdCoWi2l7e1uzs7M6OTnR7u6u6vW63dGAgcEJJQCMoXw+r0KhoBcvXsjv92tvb1+vryaVdSbVNqWEX/rushSYtDvp4Gk0GspkMmo0GgoEAjIMQ16v1+5YgK0olAAwhizL0v7+vlqtlgLLW/rL/3To/NIld8+S5XBIltSdkP7wG9Ifjd/LdB6kWq0ql8up1+spEokoGo3K6eSLP4wnCiUAjKlOp6P/fZXW32ZT6l55dO2Veu7bzxyW5G1JlkP6/i9Lv71ib9ZBZZqmCoWCSqWS3G63DMPQwsKC3bGAJ8dfpQBgTHk8Hh1513VTd6vp+0mZlG6LZMsnOU3pH3Ykk6OHe71/SGd7e1t+v19HR0fa3d1Vo9GwOxrwpCiUADDGvihNyiHJ/MD/DTpe6bou/aj8pLGGzsTEhFZXV7WxsSHTNLW7u6vj4+OxfwsRxof7638EADCqai3J/DnX35hOSZZ0wb3eDzIzM6NUKnW3rzw/P1c0GlUkEmFfiZFGoQSAMTY/JTXOP/y5s3f79XeQp70fzOFwaHFxUYFAQIVCQYVCQZVKRYZhKBAI2B0P+Cz46xIAjLHfWJJ6ztvieB9vR5qdlb4RfNpco8DlcskwDG1tbWlyclKHh4fa29tTs9m0Oxrw6CiUADDGvrMkBRckX0tydyT9+OEbhyn5rqWuS/rjlxIvhfl0Pp9Pa2trWl9fV7fbVTqd1snJCftKjBSuDQKAMXd+Lf3gC+m4JHm6lhySuk7JOSH9yS869FtcGfRoLMtSuVxWPp+XJMViMYXDYV7jiKFHoQQASJL2qtIPi9J1uyfXVUG/Fm1re2PV7lgjqdvtqlAoqFwuy+v1KplMam5uzu5YwCejUAIAfsbFxYXevn2rZDKpcDhsd5yRdX19rWw2q1qtptnZWRmGoclJnoDC8KFQAgDulclkVC6Xtbm5qampKbvjjLTLy0tlMhm1220tLi4qHo/L7eYiFgwPCiUA4F6WZWl3d1e9Xk+pVEoul8vuSCPNsiydnp6qUChIkuLxuEKhEPtKDAUKJQDgg1qtltLptGZnZ7W6yp7yKXS7XeVyOVUqFfl8PiWTSc3OztodC/i5KJQAgJ/r/Pxch4eHWlpaUigUsjvO2Gg2m8pkMqrX65qbm5NhGPL5fHbHAu5FoQQAfK13796pUqmwp7TB+fm5stmsOp2OwuGwYrEY8wMMHAolAOBrmaapvb099pQ2MU1TpVJJxWJRTqdTiURCwWCQfSUGBoUSAPAgrVZLOzs7mp+f18oKt53bodPpKJfLqVqtanJyUslkUjMzM3bHAiiUAICHOzs709HRkZaXl7W4uGh3nLHVaDSUyWTUaDQUCASUSCQ0MTFhdyyMMQolAOCjnJyc6OzsTJubm1zCbbOzszNls1l1u11FIhHFYjE5nU67Y2EMUSgBAB/FNE3t7u7KsiylUikKjM1M01SxWFSpVJLL5brbVwJPiUIJAPhoNzc3SqfTCgQCevbsmd1xIKndbiubzer8/FzT09NKJpOanp62OxbGBIUSAPBJqtWqjo+P9ezZM07EBki9Xlcmk1Gz2dTCwoISiYS8Xq/dsTDiKJQAgE92fHys8/NzpVIpLt0eIJZlqVqtKpfLyTRNRaNRRSIR5gn4bCiUAIBPZpqm0um0HA6HNjc3KSwDptfr3e0rPR6PEomEFhYW7I6FEUShBAD05fr6Wru7u1pYWNDy8rLdcXCPVqulbDari4sL+f1+JZNJ3niER0WhBAD0rVKp6OTkRCsrK5yADbCrqytlMhldX18rGAwqkUjI4/HYHQsjgEIJAHgUR0dHuri4YE854CzLUqVSUT6fl2maisViikQivMYRfaFQAgAeBXvK4dLr9ZTP51Uul+X1emUYhubn5+2OhSFFoQQAPJr3e8pgMKilpSW74+ABbm5ulMlkVKvVNDMzo2QyyRuQ8NEolACAR/V+T7m6uqpAIGB3HDzQ5eWlstmsbm5uFAqFFI/H5Xa77Y6FIUGhBAA8uqOjI11eXiqVSmliYsLuOHggy7J0enqqQqEgSYrH4wqFQuwr8bUolACAR9fr9ZROp+VyubS5uUkhGTLdbvduX+nz+WQYhubm5uyOhQFGoQQAfBbNZlO7u7sKhUJKJpN2x8EnuL6+ViaT0dXVlebm5mQYBk/w414USgDAZ1Mul/Xu3Ts9f/6cJ4iH2MXFhbLZrNrt9t2+0uVy2R0LA4RCCQD4rA4PD1Wr1dhTDjnTNO/2lU6nU/F4XIuLi8wZIIlCCQD4zN7vKd1ut168eEEBGXKdTke5XE7ValWTk5NKJpOamZmxOxZsRqEEAHx27/eU4XBYhmHYHQePoNlsKpPJqF6va35+XoZhcAI9xiiUAIAncXp6qkwmw55yxJydnSmXy6nT6SgSiSgajbKvHEMUSgDAk3n79q2urq60tbUlr9drdxw8EtM0VSqVVCwW5XK57vaVGB8USgDAk+n1etrZ2ZHH42FPOYLa7bZyuZzOzs40NTWlZDIpv99vdyw8AQolAOBJNRoN7e3tKRKJKJFI2B0Hn0G9Xlcmk1Gz2VQgEJBhGJxIjzgKJQDgyZVKJWWzWa2trfEGlhFWrVaVy+XU6/Xu9pVOp9PuWPgMKJQAAFu8efNGjUZDqVSK06sR1uv1VCwWVSqV5Ha7ZRiGFhYW7I6FR0ahBADYotvtKp1Oy+v1amNjgz3liGu1Wsrlcjo/P9f09LSSyaSmp6ftjoVHQqEEANimXq9rf3+fPeUYubq6UiaT0fX1tYLBoBKJhDwej92x0CcKJQDAVsViUblcTuvr65qdnbU7Dp6AZVl3+0rTNBWLxRQOh9lXDjEKJQDAdgcHB2o2m9ra2uK0aoz0ej0VCgWdnp7K4/HIMAwFAgG7Y+ETUCgBALbrdrva2dmRz+fT+vo6e8oxc3Nzo2w2q8vLS83MzMgwDE1NTdkdCx+BQgkAGAhXV1fa399XLBZTPB63Ow5sUKvVlMlkdHNzo8XFRSUSCbndbrtj4QEolACAgVEoFJTP57WxsaGZmRm748AGlmWpXC4rn89L0t2+klPrwUahBAAMDMuydHBwoJubG6VSKfaUY6zb7Sqfz6tcLmtiYkLJZJJL8AcYhRIAMFA6nY7S6bQmJye1trbGydSYu76+VjabVa1W0+zsrJLJpHw+n92x8FMolACAgfN+TxmPxxWLxeyOgwFwcXGhbDardrutUCikWCzGvnKAUCgBAAMpn8+rUCiwp8Qdy7J0enqqQqEgh8OhWCymUCjEKfYAoFACAAbSl/eUW1tbnEbhTqfTUT6fV6VSkc/nUzKZ5FJ8m1EoAQADq9PpaGdnR1NTU1pfX7c7DgZMs9lUJpNRvV7X3NycksmkJiYm7I41liiUAICBVqvVdHBwoEQioWg0anccDKDz83Nls1l1Oh2Fw2HFYjG5XC67Y40VCiUAYODlcjmVSiVtbGzI7/fbHQcDyDRNlUolFYtFOZ1OJRIJBYNB9pVPhEIJABh4lmVpf39f7XZbqVSKPSU+qNPpKJfLqVqtampqSoZh8FDXE6BQAgCGQrvdVjqd1vT0tNbW1uyOgwHXaDSUyWTUaDQUCARkGIa8Xq/dsUYWhRIAMDQuLy/15s0bGYahSCQiy5JaXcntktxOu9NhEJ2dnSmbzarb7SoSiSgWi8np5F+Wx0ahBAAMlWw2q+N8VQdWSv917NX1jSSntJWQfmdbehmxOyEGjWmaKhaLKpVKcrlcd/tKPB4KJQBgqFQblv78n7pq192y5FDPJTksyd2TOh7p+78qfYcbhnCPdrutbDar8/NzTU9PK5lManp62u5YI4FCCQAYKj/4N+ntO0stj0PWl7+5tCRvW+p5pL/+XSnKPdf4gHq9rkwmo2azqYWFBSUSCfaVfWJEAAAYGsWatJeTus6fKpOS5JDaXsnTlv71wJZ4GBJ+v1+bm5taXl5WrVbT69evVSgUZJqm3dGGFvcuAACGxs6p5OzdFsd7OSTLIe2WnjQWhpDD4dDi4qICgYAKhYIKhYIqlYoMw1AgELA73tChUAIAhsZDRlrWA38OkCSXyyXDMBQKhZTNZnV4eCi/369kMqmpqSm74w0NvvIGAAyNF2Gp55JcvQ/8gCW5JK2HnjIVRsHExISeP3+u9fV19Xo9pdNpnZycqNPp2B1tKHBCCQAYGsactBqTslnpxqmf2VF6O1LHJf3mC3vyYfjNzs4qlUqpUqkon8/r/Pxc0WhUkUjk7jWOvZ6U/R/p5D+k60tpKiCt/roU/yVpXN/0yFPeAIChUryS/uJfpHZd6jkk03l7bZCnJ3Xc0h98U/relt0pMQq63a4KhYLK5bK8Xq8Mw9CEY17//gOpdvLj8mhKct7OLIIb0rf+VPKO4TflFEoAwNCpNqR//D/pvw+lXud2N7kcub3Y/FeSdqfDqLm5uVEmk9HlZU3Zv9vSTd4ny3JIXz6NtG4LZvgXpG//mW1RbUOhBAAMrXZPuryWJjzS7ITdaTDq3n5R1xd/47/9xX1fbVu3v//dv5ICS0+ZzH48lAMAGFpelxTyUybxNCo/8svhtO4vkz/mkHTywyeLNDAolAAAAA/QvdbtRacf4rj92rvTfLJIA4NCCQAA8ADT76+j+tBY0JJMS/KHnyrR4KBQAgAAPMDatz/cJaXbr7sdbmn1W08UaIBQKAEAAB7AH5HWv3v7zw5LP2mX1u2vLUnbvydN+O3JZyee8gYAAHggy5J+9PfS/j9LvbZujyUtyT0pbf2+tP09uxPag0IJAADwkTpN6eQLqXUhTQalpW9Kbp/dqexDoQQAAEBf2FACAACgLxRKAAAA9IVCCQAAgL5QKAEAANAXCiUAAAD6QqEEAABAXyiUAAAA6AuFEgAAAH2hUAIAAKAvFEoAAAD0hUIJAACAvlAoAQAA0BcKJQAAAPpCoQQAAEBfKJQAAADoC4USAAAAfaFQAgAAoC8USgAAAPSFQgkAAIC+UCgBAADQFwolAAAA+kKhBAAAQF8olAAAAOgLhRIAAAB9oVACAACgLxRKAAAA9IVCCQAAgL5QKAEAANAXCiUAAAD6QqEEAABAXyiUAAAA6AuFEgAAAH2hUAIAAKAvFEoAAAD0hUIJAACAvlAoAQAA0BcKJQAAAPpCoQQAAEBfKJQAAADoC4USAAAAfaFQAgAAoC8USgAAAPSFQgkAAIC+UCgBAADQFwolAAAA+vL/4D2tI56ab1UAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import networkx as nx\n",
    "\n",
    "\n",
    "# tresh =  0.0063\n",
    "tresh = 0.00685\n",
    "# tresh = 0.0055\n",
    "\n",
    "\n",
    "def show_graph_with_labels(adjacency_matrix ):\n",
    "    rows, cols = np.where(adjacency_matrix > tresh  )\n",
    "    edges = zip(rows.tolist(), cols.tolist())\n",
    "    gr = nx.Graph()\n",
    "    gr.add_edges_from(edges )\n",
    "\n",
    "\n",
    "    nx.draw(gr , pos = DIST, node_size=40 , node_color = np.random.randn(1,len(gr.nodes)) , cmap = 'cool' , edge_color ='w' , \n",
    "            alpha = 1)\n",
    "    nx.draw(gr , pos = DIST, node_size=40 , node_color = np.random.randn(1,len(gr.nodes)) , cmap = 'cool' , edge_color ='k' , \n",
    "            alpha = 0.2)\n",
    "    plt.show()\n",
    "\n",
    "show_graph_with_labels(a)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
