{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "import torch.multiprocessing as mp\n",
    "mp.set_sharing_strategy('file_system')\n",
    "\n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "from torchvision import models\n",
    "\n",
    "# from models import *\n",
    "import os\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "from data.datasets import input_dataset\n",
    "import argparse\n",
    "import torchvision.transforms as transforms\n",
    "from torch.utils.data import DataLoader, random_split\n",
    "from torchvision.models import resnet34\n",
    "import os\n",
    "import torch\n",
    "import datetime\n",
    "# import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import scipy as sp\n",
    "import cv2\n",
    "import numpy as np\n",
    "from torchvision import datasets, transforms\n",
    "from torch.utils.data import DataLoader\n",
    "from torch import nn, optim\n",
    "from PIL import ImageFile\n",
    "    \n",
    "    \n",
    "\n",
    "\n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5dbef333-022e-40f5-a11a-dff6a51035fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "\n",
    "def conv3x3(in_planes, out_planes, stride=1):\n",
    "    return nn.Conv2d(in_planes, out_planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "\n",
    "\n",
    "class BasicBlock(nn.Module):\n",
    "    expansion = 1\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(BasicBlock, self).__init__()\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=1, padding=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False),\n",
    "                nn.BatchNorm2d(self.expansion*planes)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = self.bn2(self.conv2(out))\n",
    "        out += self.shortcut(x)\n",
    "        out = F.relu(out)\n",
    "        return out\n",
    "\n",
    "\n",
    "class PreActBlock(nn.Module):\n",
    "    '''Pre-activation version of the BasicBlock.'''\n",
    "    expansion = 1\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(PreActBlock, self).__init__()\n",
    "        self.bn1 = nn.BatchNorm2d(in_planes)\n",
    "        self.conv1 = conv3x3(in_planes, planes, stride)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = conv3x3(planes, planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(x))\n",
    "        shortcut = self.shortcut(out)\n",
    "        out = self.conv1(out)\n",
    "        out = self.conv2(F.relu(self.bn2(out)))\n",
    "        out += shortcut\n",
    "        return out\n",
    "\n",
    "\n",
    "class Bottleneck(nn.Module):\n",
    "    expansion = 4\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(Bottleneck, self).__init__()\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv3 = nn.Conv2d(planes, self.expansion*planes, kernel_size=1, bias=False)\n",
    "        self.bn3 = nn.BatchNorm2d(self.expansion*planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False),\n",
    "                nn.BatchNorm2d(self.expansion*planes)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = F.relu(self.bn2(self.conv2(out)))\n",
    "        out = self.bn3(self.conv3(out))\n",
    "        out += self.shortcut(x)\n",
    "        out = F.relu(out)\n",
    "        return out\n",
    "\n",
    "\n",
    "class PreActBottleneck(nn.Module):\n",
    "    '''Pre-activation version of the original Bottleneck module.'''\n",
    "    expansion = 4\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(PreActBottleneck, self).__init__()\n",
    "        self.bn1 = nn.BatchNorm2d(in_planes)\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn3 = nn.BatchNorm2d(planes)\n",
    "        self.conv3 = nn.Conv2d(planes, self.expansion*planes, kernel_size=1, bias=False)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(x))\n",
    "        shortcut = self.shortcut(out)\n",
    "        out = self.conv1(out)\n",
    "        out = self.conv2(F.relu(self.bn2(out)))\n",
    "        out = self.conv3(F.relu(self.bn3(out)))\n",
    "        out += shortcut\n",
    "        return out\n",
    "\n",
    "    \n",
    "    \n",
    "class ResNet(TorchModel):\n",
    "    def __init__(self, block, num_blocks, num_classes=10):\n",
    "        super(ResNet, self).__init__()\n",
    "        self.in_planes = 64\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, 64, kernel_size=3, stride=1, padding=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(64)\n",
    "        self.layer1 = self._make_layer(block, 64, num_blocks[0], stride=1)\n",
    "        self.layer2 = self._make_layer(block, 128, num_blocks[1], stride=2)\n",
    "        self.layer3 = self._make_layer(block, 256, num_blocks[2], stride=2)\n",
    "        self.layer4 = self._make_layer(block, 512, num_blocks[3], stride=2)\n",
    "        self.avgpool = nn.AdaptiveAvgPool2d((1, 1))\n",
    "        self.linear = nn.Linear(512*block.expansion, num_classes)\n",
    "\n",
    "    def _make_layer(self, block, planes, num_blocks, stride):\n",
    "        strides = [stride] + [1]*(num_blocks-1)\n",
    "        layers = []\n",
    "        for stride in strides:\n",
    "            layers.append(block(self.in_planes, planes, stride))\n",
    "            self.in_planes = planes * block.expansion\n",
    "        return nn.Sequential(*layers)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = self.layer1(out)\n",
    "        out = self.layer2(out)\n",
    "        out = self.layer3(out)\n",
    "        out = self.layer4(out)\n",
    "        out = self.avgpool(out)\n",
    "        out = out.view(out.size(0), -1)\n",
    "        out = self.linear(out)\n",
    "        return out\n",
    "    \n",
    "# class ResNet(TorchModel):\n",
    "    \n",
    "#     def __init__(self, block, num_blocks, num_classes=10):\n",
    "#         super(ResNet, self).__init__()\n",
    "#         self.in_planes = 64\n",
    "\n",
    "#         self.conv1 = nn.Conv2d(3, 64, kernel_size=3, stride=1, padding=1, bias=False)\n",
    "#         self.bn1 = nn.BatchNorm2d(64)\n",
    "#         self.layer1 = self._make_layer(block, 64, num_blocks[0], stride=1)\n",
    "#         self.layer2 = self._make_layer(block, 128, num_blocks[1], stride=2)\n",
    "#         self.layer3 = self._make_layer(block, 256, num_blocks[2], stride=2)\n",
    "#         self.layer4 = self._make_layer(block, 512, num_blocks[3], stride=2)\n",
    "#         self.linear = nn.Linear(512*block.expansion, num_classes)\n",
    "\n",
    "#     def _make_layer(self, block, planes, num_blocks, stride):\n",
    "#         strides = [stride] + [1]*(num_blocks-1)\n",
    "#         layers = []\n",
    "#         for stride in strides:\n",
    "#             layers.append(block(self.in_planes, planes, stride))\n",
    "#             self.in_planes = planes * block.expansion\n",
    "#         return nn.Sequential(*layers)\n",
    "#     def init_weights(self, *args, **kwargs) -> None:\n",
    "#         # def _init_weights(m: nn.Module):\n",
    "#         #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "#         #         nn.init.xavier_uniform_(m.weight)\n",
    "#         #         nn.init.zeros_(m.bias)\n",
    "#         #self.apply(_init_weights)\n",
    "#         pass\n",
    "#     def forward(self, x):\n",
    "#         out = F.relu(self.bn1(self.conv1(x)))\n",
    "#         out = self.layer1(out)\n",
    "#         out = self.layer2(out)\n",
    "#         out = self.layer3(out)\n",
    "#         out = self.layer4(out)\n",
    "#         out = F.avg_pool2d(out, 4)\n",
    "#         out = out.view(out.size(0), -1)\n",
    "#         out = self.linear(out)\n",
    "#         return out\n",
    "\n",
    "def PreResNet18(num_classes):\n",
    "    return ResNet(PreActBlock, [2,2,2,2],num_classes=num_classes)\n",
    "\n",
    "def ResNet18(num_classes):\n",
    "    return ResNet(BasicBlock, [2,2,2,2],num_classes=num_classes)\n",
    "\n",
    "def ResNet34(num_classes):\n",
    "    return ResNet(BasicBlock, [3,4,6,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet50(num_classes):\n",
    "    return ResNet(Bottleneck, [3,4,6,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet101(num_classes):\n",
    "    return ResNet(Bottleneck, [3,4,23,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet152(num_classes):\n",
    "    return ResNet(Bottleneck, [3,8,36,3],num_classes=num_classes)\n",
    "\n",
    "\n",
    "def test():\n",
    "    net = ResNet18()\n",
    "    y = net(torch.randn(1,3,32,32))\n",
    "    print(y.size())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "eba576af-0560-4349-bef2-b8ee5a825dec",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dirichlet_distribution(alpha, num_clients):\n",
    "    return np.random.dirichlet([alpha] * num_clients)\n",
    "\n",
    "def partition_dataset(data, targets, num_clients, alpha):\n",
    "    num_classes = 10\n",
    "    data_indices = [[] for _ in range(num_clients)]\n",
    "    labels = np.array(targets)\n",
    "    \n",
    "    for k in range(num_classes):\n",
    "        class_indices = np.where(labels == k)[0]\n",
    "        np.random.shuffle(class_indices)\n",
    "        proportions = dirichlet_distribution(alpha, num_clients)\n",
    "        proportions = (proportions / proportions.sum()) * len(class_indices)\n",
    "        proportions = np.cumsum(proportions).astype(int)\n",
    "        \n",
    "        previous_idx = 0\n",
    "        for i in range(num_clients):\n",
    "            client_indices = class_indices[previous_idx:proportions[i]]\n",
    "            data_indices[i].extend(client_indices)\n",
    "            previous_idx = proportions[i]\n",
    "    \n",
    "    return data_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = torch.load('train_data.pt')\n",
    "train_targets = torch.load('train_targets.pt')\n",
    "test_data = torch.load('test_data.pt')\n",
    "test_targets = torch.load('test_targets.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a87774ad-5779-4118-941d-fd1cae957941",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dirichlet_distribution(alpha, num_clients):\n",
    "    return np.random.dirichlet([alpha] * num_clients)\n",
    "\n",
    "def partition_dataset(data, targets, num_clients, alpha):\n",
    "    num_classes = 10\n",
    "    data_indices = [[] for _ in range(num_clients)]\n",
    "    labels = np.array(targets)\n",
    "    \n",
    "    for k in range(num_classes):\n",
    "        class_indices = np.where(labels == k)[0]\n",
    "        np.random.shuffle(class_indices)\n",
    "        proportions = dirichlet_distribution(alpha, num_clients)\n",
    "        proportions = (proportions / proportions.sum()) * len(class_indices)\n",
    "        proportions = np.cumsum(proportions).astype(int)\n",
    "        \n",
    "        previous_idx = 0\n",
    "        for i in range(num_clients):\n",
    "            client_indices = class_indices[previous_idx:proportions[i]]\n",
    "            data_indices[i].extend(client_indices)\n",
    "            previous_idx = proportions[i]\n",
    "    \n",
    "    return data_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "03a090df-7bdc-4caf-8576-e7954b50bb79",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "dataset = TensorDataset(test_data, test_targets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d4ca134c-9fd9-4a2d-8ba9-cd6918be5639",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_clients = 10\n",
    "alpha = 1.5  # Example alpha value\n",
    "data_indices = partition_dataset(train_data, train_targets, num_clients, alpha)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "fb6d1fb3-90e4-4fe4-8ee1-daa73c3ffe32",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = ResNet18(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "311792f2-7e67-40d3-b9dd-ec25f2eb7b19",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 10])\n"
     ]
    }
   ],
   "source": [
    "dummy_input = torch.randn(32,3, 64, 64)  # Batch size of 32\n",
    "output = model(dummy_input)\n",
    "print(output.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3009e343-a6c5-4a92-9f2c-0bc221b820ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "concatenated_data = []\n",
    "concatenated_targets = []\n",
    "for indices in data_indices:\n",
    "    concatenated_data.append(train_data[indices])\n",
    "    concatenated_targets.append(train_targets[indices])\n",
    "\n",
    "concatenated_data = torch.cat(concatenated_data, dim=0)\n",
    "concatenated_targets = torch.cat(concatenated_targets, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e7efb691-f07a-460a-b0ec-fe5949ffd60d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (concatenated_data, concatenated_targets)\n",
    "Xte, yte = (test_data, test_targets)\n",
    "\n",
    "# print(\"this is\")\n",
    "# print(ytr[1])\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a6b92128-e67f-4930-9dea-e9118fc6fb82",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "43cf1470-065f-4182-a5d6-601ba08f34c0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=model,\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 16,\n",
    "        local_epochs= 2),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=200)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1386b12e-01f2-4760-be89-da59b1433e92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm4AAAHWCAYAAADO2QWWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACEVUlEQVR4nO3dd3RUZf4G8OfOZEp6rySkEXroZelVwUJRVwELStGfLri62JZVQbDg6gq46oq6Arqugl3XAihSpPcOIYQECOm9T72/P2buTSaNDJnJpDyfc3JOcufOzHszQ+bh+zZBFEURRERERNTqKVzdACIiIiJqGgY3IiIiojaCwY2IiIiojWBwIyIiImojGNyIiIiI2ggGNyIiIqI2gsGNiIiIqI1gcCMiIiJqIxjciIiIiNoIBjciarfS0tIgCALWr18vH3vhhRcgCILrGtWOrF+/HoIgIC0tzdVNIeowGNyIiOrx6aefYvXq1U59joyMDLzwwgs4duyYU5+nJf3rX/+yCcpE5FgMbkRE9Wip4LZs2TIGNyJqMgY3ImozqqqqYDabXd2MVqW8vNzVTSCiFsTgRkTXdPToUdx0003w8fGBl5cXJkyYgH379sm3Hzp0CIIg4KOPPqpz382bN0MQBPzwww/ysatXr2Lu3LkIDQ2FRqNBr169sHbtWpv7bd++HYIgYMOGDXjuuefQqVMneHh4oKSkBAUFBXjyySeRmJgILy8v+Pj44KabbsLx48cdcr1jx47Fjz/+iEuXLkEQBAiCgJiYGPl2nU6HpUuXokuXLtBoNIiKisLTTz8NnU5n8zi//PILRo4cCT8/P3h5eaFbt27429/+Jl/f4MGDAQBz5syRn6exapU0Pu/MmTO4++674e/vj5EjR8q3f/LJJxg4cCDc3d0REBCAmTNn4sqVKzaPkZycjDvuuANhYWHQarWIjIzEzJkzUVxcDKD+cYESQRDwwgsvNNi+mJgYnD59Gjt27JCvZ+zYsQAAg8GAZcuWISEhAVqtFoGBgRg5ciR++eWXBh+PiOpyc3UDiKh1O336NEaNGgUfHx88/fTTUKlUeO+99zB27Fjs2LEDQ4cOxaBBgxAXF4fPP/8c999/v839N27cCH9/f0yaNAkAkJ2djT/84Q8QBAELFy5EcHAwfv75Z8ybNw8lJSV4/PHHbe7/4osvQq1W48knn4ROp4NarcaZM2fw7bff4s4770RsbCyys7Px3nvvYcyYMThz5gwiIiKadc3PPvssiouLkZ6ejlWrVgEAvLy8AABmsxlTp07Frl278NBDD6FHjx44efIkVq1ahfPnz+Pbb7+Vf2+33nor+vTpg+XLl0Oj0eDChQvYvXs3AKBHjx5Yvnw5lixZgoceegijRo0CAAwfPvya7bvzzjuRkJCAV155BaIoAgBefvllPP/887jrrrswf/585Obm4q233sLo0aNx9OhR+Pn5Qa/XY9KkSdDpdHj00UcRFhaGq1ev4ocffkBRURF8fX2b9XtbvXo1Hn30UXh5eeHZZ58FAISGhgKwhM4VK1Zg/vz5GDJkCEpKSnDo0CEcOXIEN9xwQ7Oel6hDEYmIGjF9+nRRrVaLKSkp8rGMjAzR29tbHD16tHxs8eLFokqlEgsKCuRjOp1O9PPzE+fOnSsfmzdvnhgeHi7m5eXZPM/MmTNFX19fsaKiQhRFUdy2bZsIQIyLi5OPSaqqqkSTyWRzLDU1VdRoNOLy5cttjgEQ161bJx9bunSp2JQ/fbfccosYHR1d5/h//vMfUaFQiL///rvN8TVr1ogAxN27d4uiKIqrVq0SAYi5ubkNPsfBgwfrtK8xUttnzZplczwtLU1UKpXiyy+/bHP85MmTopubm3z86NGjIgDxiy++aPA56vudSQCIS5culX9et26dCEBMTU2Vj/Xq1UscM2ZMnfv27dtXvOWWW659kUTUKHaVElGDTCYTtmzZgunTpyMuLk4+Hh4ejrvvvhu7du1CSUkJAGDGjBkwGAz4+uuv5fO2bNmCoqIizJgxAwAgiiK++uorTJkyBaIoIi8vT/6aNGkSiouLceTIEZs23H///XB3d7c5ptFooFAo5Dbm5+fLXZG17+9oX3zxBXr06IHu3bvbtH/8+PEAgG3btgEA/Pz8AADfffedw8flPfzwwzY/f/311zCbzbjrrrts2hQWFoaEhAS5TVJFbfPmzaioqHBom67Fz88Pp0+fRnJycos+L1F7w+BGRA3Kzc1FRUUFunXrVue2Hj16wGw2y2Oo+vbti+7du2Pjxo3yORs3bkRQUJAcanJzc1FUVIT3338fwcHBNl9z5swBAOTk5Ng8T2xsbJ3nNpvNWLVqFRISEqDRaBAUFITg4GCcOHFCHqvlLMnJyTh9+nSd9nft2tWm/TNmzMCIESMwf/58hIaGYubMmfj8888dEuJq/06Sk5MhiiISEhLqtOvs2bNym2JjY7Fo0SL8+9//RlBQECZNmoR33nnH6b8zAFi+fDmKiorQtWtXJCYm4qmnnsKJEyec/rxE7Q3HuBGRw8yYMQMvv/wy8vLy4O3tje+//x6zZs2Cm5vlT40UWu699946Y+Ekffr0sfm5drUNAF555RU8//zzmDt3Ll588UUEBARAoVDg8ccfd/qsU7PZjMTERKxcubLe26OiouR279y5E9u2bcOPP/6ITZs2YePGjRg/fjy2bNkCpVJ53W2o/Tsxm80QBAE///xzvY8rjc8DgDfeeAMPPPAAvvvuO2zZsgV//vOfsWLFCuzbtw+RkZENLk5sMpmuu70AMHr0aKSkpMjP++9//xurVq3CmjVrMH/+/GY9NlFHwuBGRA0KDg6Gh4cHkpKS6tx27tw5KBQKOagAluC2bNkyfPXVVwgNDUVJSQlmzpxp83je3t4wmUyYOHHidbfryy+/xLhx4/Dhhx/aHC8qKkJQUNB1P25NDQWY+Ph4HD9+HBMmTLjmDgwKhQITJkzAhAkTsHLlSrzyyit49tlnsW3bNkycONFhOzjEx8dDFEXExsbKlb/GJCYmIjExEc899xz27NmDESNGYM2aNXjppZfg7+8PwPK7rOnSpUtNaktj1xQQEIA5c+Zgzpw5KCsrw+jRo/HCCy8wuBHZgV2lRNQgpVKJG2+8Ed99953NtkbZ2dn49NNPMXLkSPj4+MjHe/TogcTERGzcuBEbN25EeHg4Ro8ebfN4d9xxB7766iucOnWqzvPl5uY2uV2idTal5IsvvsDVq1ftvMKGeXp61tuFeNddd+Hq1av44IMP6txWWVkpr6tWUFBQ5/Z+/foBgLxsiKenJ4C6Iclet99+O5RKJZYtW1bn9yKKIvLz8wEAJSUlMBqNNrcnJiZCoVDIbfLx8UFQUBB27txpc96//vWvJrXF09Oz3uuR2iDx8vJCly5d6iyhQkSNY8WNiBr10ksvyeuR/elPf4Kbmxvee+896HQ6vPbaa3XOnzFjBpYsWQKtVot58+bJkwgkr776KrZt24ahQ4fiwQcfRM+ePVFQUIAjR47g119/rTfw1Hbrrbdi+fLlmDNnDoYPH46TJ0/iv//9r80EiuYaOHAgNm7ciEWLFmHw4MHw8vLClClTcN999+Hzzz/Hww8/jG3btmHEiBEwmUw4d+4cPv/8c2zevBmDBg3C8uXLsXPnTtxyyy2Ijo5GTk4O/vWvfyEyMlJeey0+Ph5+fn5Ys2YNvL294enpiaFDh9Y7rq8x8fHxeOmll7B48WKkpaVh+vTp8Pb2RmpqKr755hs89NBDePLJJ/Hbb79h4cKFuPPOO9G1a1cYjUb85z//kQO1ZP78+Xj11Vcxf/58DBo0CDt37sT58+eb/Ht799138dJLL6FLly4ICQnB+PHj0bNnT4wdOxYDBw5EQEAADh06hC+//BILFy6061qJOjwXzmglojbiyJEj4qRJk0QvLy/Rw8NDHDdunLhnz556z01OThYBiADEXbt21XtOdna2uGDBAjEqKkpUqVRiWFiYOGHCBPH999+Xz5GWA6lv6YqqqirxiSeeEMPDw0V3d3dxxIgR4t69e8UxY8bYLEXRnOVAysrKxLvvvlv08/MTAdgsDaLX68W///3vYq9evUSNRiP6+/uLAwcOFJctWyYWFxeLoiiKW7duFadNmyZGRESIarVajIiIEGfNmiWeP3/e5nm+++47sWfPnqKbm9s1lwaR2t7QEiNfffWVOHLkSNHT01P09PQUu3fvLi5YsEBMSkoSRVEUL168KM6dO1eMj48XtVqtGBAQII4bN0789ddfbR6noqJCnDdvnujr6yt6e3uLd911l5iTk9Ok5UCysrLEW265RfT29hYByK/HSy+9JA4ZMkT08/MT3d3dxe7du4svv/yyqNfrr/FKEFFNgijWqqsTERERUavEMW5EREREbQSDGxEREVEbweBGRERE1EYwuBERERG1EQxuRERERG0EgxsRERFRG8EFeOthNpuRkZEBb29vh21JQ0RERFQfURRRWlqKiIiIOouW18bgVo+MjAyb/ReJiIiInO3KlSuIjIxs9BwGt3p4e3sDsPwCa+7DSERERORoJSUliIqKkvNHYxjc6iF1j/r4+DC4ERERUYtoyvAsTk4gIiIiaiMY3IiIiIjaCAY3IiIiojaCwY2IiIiojWBwIyIiImojGNyIiIiI2ggGNyIiIqI2gsGNiIiIqI1gcCMiIiJqIxjciIiIiNoIBjciIiKiNoLBjYiIiKiNYHAjIiIiaiMY3IiIWomvDqfjoY8PoahC7+qmEFErxeBGRNQKVOiNeOH709hyJhvr96S5ujkOZTaLeGfbBexNyXd1U6iGw5cKsPS7UzifXerqpjiU3mjGP7cm49ujV13dFKdwc3UDiIg6EqPJDIUgQKEQbI5/dywDpTojAGDDgStYOK4L3JTt4//Wu1Py8PrmJHiqldj25FiE+Gid+nwn04uhN5kwMDrA4Y9dZTBBrVTUef3amv8dz8ATnx+H3mTGpwcu409ju+D/xsTBXaWEILTdayutMuCRT45g14U8qJQCJvUKg7ta6epmOVT7+KtARNQGFJTrMeSVrZiz/iBMZlE+Looi/rP3kvxzVkkVfjuX44omOsW5TEtFp1xvwt83JTnscdPyyvHE58fx6GdHUW4NvWcySnDHu3tw13v7kJpX7rDnAoB3t6egx5JNiPvbT+i1ZBMWfnoEBeVtr1v7w12pePSzo9CbzIj0d4fBJOLNrcnouWQzuj73M0b+/Td8d6ztVatySqtw13v7sOtCHgDAYBJxPL3ItY1yAgY3IqIWciK9CAXleuw4n4v3dqbIx49cLsSZzBJoVQrMHBwFAPj0wGVXNdPhknOqu+K+OpKOw5cKcepqMZ7+8jg2HLgMszXEGk1mbD2bjVd/PoeZ7+/FA+sO1NuNV1Shx/PfnsLElTvw1ZF0/O94Bh7bYAlvj22wBBKTWcS63akOvY6fTmZCtObtcr0JP5zIxKTVO7HtXA4MJjMAS3j4ZN8lrNmRgsLrCHXrd6fi6S+Po8pganZ7zWYRT31xHM9/ewqiteEn0ovw4g9nAAAPDI/BjqfG4e27+yPEWwPAEnbSCyvx2IZj+MvGY8gprYIoijCZRRxILcDqX8/jt3PZdrclr0yH+R8duq771ufwpUL88d09OHq5UD72/LencDazBEFeGvSN9JXPa66ckiq88P1pbGgl/ybZVUpE1EJySnTy96t+OY9x3ULQI9xHrrZN7RuBh8fEY8PBK9hxPhdXCioQFeABAMguqcJDHx/CzCGdMWtIZ5e0vzEVeiPOZZViQGf/Orcl55QBACJ8tcgorsK8jw6iqMIAAPj8UDq+PnoVU/pGYO2u1DpVsv0XC7Di9kRM798JAPDrmWws/uYkckstv8sRXQJxKK0Qv57NweQ3d+JKQSU81EpU6E344lA6Ft3QFX4e6mZfn8ksygH06z8Nh8ksYvHXJ3Ehpwxz1h+EUiEgzEeLjOJKOdx9uCsVr93RB+O6hzTpOfRGM175+Rz0RjNig7zwyNj4ZrX5XFYpvjicDgAYmRCESb3C8K9tlv8wTO0bgaVTekIQBNzaJwI39w5Hmd6I0iojPj94BW/9loxvjl7FN0evwkfrBjelwqa6OLVvBJZP69Xk3+3nh67g17PZOHSpADueGgdfd1Wzrm3t7lQculSIv351Ej89NgoXc8uw+bQlFP5n3hDsScnH8fRiHEoruO7nKKrQ463fLuCTfZegM5oR5qPFbQM6QePm2q5XVtyIiFpIdkmV/L3BJGLBf49gwadH8OPJTADAvX+IRkyQJ0YlBEEUbatu/zuegePpxfj7pnPQGa+/GpNVXIWrRZVNPn/n+VxMeWsXzmaWNHreX786idv/tQebT2fZHBdFEReyLcHt9Tv7wlvjJoe2cd2C4aFW4kBqAZ7/9hRS88rh56HCzMFRWHF7IkZ2CUKlwYTHNx5Dv+VbMHzFVsz/+BByS3WID/bEZw/+Af+d/wesvKsfAOBKgeW6/nXPAPQM90GlwYT/7m+4SqIzmrDjfC5e+P40Hlh3AGmNdK1eKahAlcEMjZsCfSP9MDgmAP9bOBIPDI+Bh1oJk1nE1SJLaOsb5Ye4YE/kluowZ/1BLNp4zOa1b8jZzBLojZbK3b+2XUBBuR5VBhMW/PcIZr2/z+4q3OFL1aHltU3nkJRVis1nLK/Po+O72IxlUygE+GhV6OTnjr/c0BVfPDwM3cO8AQAlVUYUlOvho3XDuG7BUCoEfH88Azeu2onvjl2Vq3mNOXa5CABQVGHAv7ZfAGB5b014Y7vdkwhEUcThNEslLSm7FN8cvYp3d1gC6aReoegR7oNB0f7W30GhXNG112MbjuHDXanQGc0Y0NkP/7izL9StYNwpK25ERC0ku9Ty4T1rSBQ2ncrCxbxyXLSGhUHR/ugT6QcAmDm4M35PzsPmU1l4ZnJ3AMCJ9GIAlg++bedyMLl3OKoMJnyy7xIm9ghFTJBno89dpjPizV/PY+3uNHhp3LDjqbFNqpa8ve0CTl4txoe7UvGPO/vWe05+mQ4/WcPn9qRcTOoVJt+WU6pDqc4IpULAoBh/vHPPAPx6NhuzhnRGj3AfXCmowAvfn8bpjBLMHh6N2cNi4KWxfDTdNSgKb25Nxtu/JaOowoAiGKAQgAdHxeEvN3SFVmWpfNzSJxxXi7rjtU1JeGh0HMZ2C0FBuR6LPj+Oj/ak4cFRcVC72X7gVhlMuHHVTlwuqJCPrQ9MwwtTe9V7jUnWLtuEUC8orRMT3NVKvDC1F5ZO6YnsEh0uF1Qg0t8dEX7uqDKY8PrmJKzdnYqvj17FptNZWHRDV8wfFdfg77pmt1+pzoiVvyQhs6gKW63jHfek5GF899AG719bzW7ClNxyzF1/EKJoCTcJod6N3ndgdAA2PT4aVQYT0vLLUa4zIrGTH9RuChy7UoRFnx/DxdxyPLbhGD7eewmv/7EP4oK96n0sURRx9EqR/PO63WnoHuaNxV+fRJXBjPd2XpQrqk1xtagSWTWC8GubziHfWg3809guAICeET5wVylRUmXEhdwydL3G9daWUVSJHedzIQjAh/cPwrhuIa1m0gaDGxFRC8m2dpX2ivDFHwdG4X/HM9DJzx0xQZ4YFh8onzfc+v3FvHIUlOsR4KnGyavF8u1fHk7H5N7h+MfmJPx7Vyo2HryCnx8b1eAs1KSsUsxeu19+/uJKA3acz8W0fo1/WJZUGeQP/x3nc2E2i/XOpvzuWAaM1qpGzfABAMnWalt0oAc0bkqM7hqM0V2D5dujAjzw4QOD631+pULAohu6Yu6IGOSV6VBaZUSQl0buPq7podHxuGdoNDytoe/WPhF49edzyCnV4X/HM3DHwEib8/ddzMflggp4qJXoG+mHvRfzcbCRbrVka3CrLwAIgoAwXy3CfKtny2pVSjx/a09M6RuBZf87jaOXi/DSj2fRv7Nfg7Ndj1nDzbC4QOy9mI9P9tlWC7eezbEruB2yvnbjugVjW1KuXGmVwk1TaFVKdA/zsTnWL8oPP/15FD7clYp3tl3A4UuF+Ns3J7HhoWH1PkZGcRVyS3VwUwjoF+WHQ5cK8ZeNx+Xbz2aWIKOoEhF+7k1qk/Se7B7mjeJKAzKLLSFuZJcg9I3yAwColAr0i7K8rofSCm1et8v5Fdh7MQ/T+nWSw39tP5zIAAAMjgmw63feElxf8yMi6iByrFWCUB8tBkb744WpvfDg6Djc0DNUrjIBgL+nGvHBlgra0cuFKK402Iz92paUi/0X8+X13pJzyrDh4JUGn3fZ/04ju0SH6EAPjO1mCU3bmjBrdXdynjz7NbdUhzMNdJd+aR1HBVgqUyVVBvlnaVxYlwaqMU3h56FGlxBv9O/sX29ok3jW+B2q3RS4Z2g0AODnU1l1zt2elAsAmNYvAm/O7AfAEiBKa7S9piRrAO1mZ+WmX5Qfvn5kOMZYw+rxK8UNnisFt/8bEye/Tm4KAXNGxAAAfjuX06RuScDSLZ9eWAmFAPzjzr6IsIbKmuGmObQqJRaM64KN1rB2Ir24wS5JqZu0e7i3TUVzaGyAPInAnlnUUnAbFh+IxycmyMf/NM52TOCgGEt36aEaXcZHLhdiytu78MxXJ7Hgv0dgtE4qqe3745bgNrVvRJPb1VIY3IiIWohU8Qr10Vzz3IE1xuicslbbogLc0TfKDyaziLnrD8JoFhHkZenuXPXL+XpDx/6L+diTkg+VUsB/5w/FI2MsH247zufaLElSHyncVP9c98P1dEYxzmSWQK1UIMRbA1Gs/qAGqicmJIRef3C7XhN6WCYF7E3Jk2d9Snact1zbmK4hCPHRIjrQA2ax4VmI57MarrhdiyAIckBpaLHbgnI90vIt3bb9ovywfGpvTOwRgjX3DsQzk7tDq1Igs7gKZzObtlhudVXKB4FeGrz2x74YEhOA527tYXf7G9M93BtqpQIVelODYyelKmy/KD/07uSL527pgTsGROLf9w/CpN6WbvWtZ5s+21S6tkHRAbhjQCT+ODASc0bEYFhcoM150r+hQ9bxcDvP5+KeD/ajuNLy72TruRw8+82pOmE4JbcMp66WwE0h4ObE8Ca3q6UwuBERtQCTWURumRTcrr0Abc3gJo1v69PJD3+0dvmV6y0LwW54aBjigj2RX67H279dqFNBWPXreQDAnYOiEOnvgQHR/vDWuqGwwtDoGleiKGL7eUtQm9TL0lUkBbmU3DL8Y3MSdl/IwxeHLNW2G3qGYkSXILnNEmliQkKI/YGnuXqG+yDAU41yvQlHa4TJtLxypOaVQ6UUMKKL5cN+cIyl+7K+7lK90YyUXMt1dA27vuuQ7pfUQHA7bq22xQV5ws9Djc6BHvj3/YMxsWcotColRlp/tzWX0xBFERdySvHzycw6Exek10B6H41MCMLnDw+r0+3ZXCqlAnHW6nBSVv3XJlUS+0dZ2jJ/VBzeuKsvvLUqTLB2Q+5OyUeF3ijfp1xnxM7zuTiZbluhLNMZ5YkyA6P94aZU4B939sXSKb3qjEEbEO0PQQAuF1RgwX+P4P51B1BpMGFUQhDenNkPCgHYeOgK/vbNKeSUVo+Z+/6Ypdo2KiEIAZ7Nn5HsaAxuREQtIL9cB5NZhEIAApvwYSB94B5PL8IRa8WiT6QvpvaJkGe2zR0Ziy4hXlh8k6WK8t7Oi+jy7M/ot3wL/rLxGD7ak4Z9FwugUgpYMM4yrkmlVMhjzBrrLj2bWYrsEh20KoU8QeLI5UJcKajA7A8P4O1tF3DPv/fL3bV3DOyEAZ395PMAS7A4L3WVhrR8xU2hEOTA83tydfVQqhwOig6At9ayLMUQKbil1q24peWXw2gW4aVxk7sc7SV1sSZnl8kVntIqA9ILLVU2afB+vwa6MaVxVluta8at+OkshryyFRNX7sQj/z2CZ746YXO+NL5N6i50pm7WUHq+xnp9Kbll0BvNMJjM8vjMftb3R01dQ73Qyc8deqMZey7k40R6Ee5asxd9l23B7LUHMP1fu3E6ozq8HbtcBLMIdPJztxlTWB8frUr+vf9oXYNPqvRN69cJL07vDQD47MBljPz7Njz95XF8uv+yvPjw1H6tr5sUYHAjImoR0hpuQV6aJm1lFRfkBV93FaoMZjlgJUb6wtdDhedu7YHp/SLw6HhLGJvYIwTT+kVAKjgUVRjwzdGrWPr9aQDAjMFR6FRj4Pe4bpYuxG31dH1KpGrb8PggxAV7ISHEC2YRmPn+PlwtqkSQl0Zei6uTnztGJwRjgDVsHrtcBJNZRH65HkUVBggCEN+MMW7NMSrBEtx2JufJx7ZZK4fSODIAGBxrCW7H0ovqLLeSJHeTel33zMKYIE+olALKdEZkWAfTz1l3EGNe344tp7Oqq1L1hBsAGG9dC+7YlSLc++/9eG/nReSW6qB2U0AQLBNEdlt3DKgymHDaGpbqW1fP0aTuY6k7ed/FfEx4Ywfuem8vjl8pgs5oho/WDbGBdWc+C4Igd2m/te0CZry3DwfSCmA0i3BXWZZZee7bU/L4udqVxGuRZquO6xaM/y0ciTfu6iuvw3bP0Gise2Aw+nf2g95oxueH0vG3b04iLb8CGjcFbugZ1thDuwxnlRIRtYDsGhMTmkKhEDCgsx+2JeXKMzZ7d7KMk5o9LAazh8XI5wqCgDdn9sfKu/pZJzKU4bMDV/D98Qy4q5R1ZhFKA+VPXS1BTklVvXuHbq8VbsZ2C0ZyThmuFlVCpRSw9oFB6B7mg0OXCtA5wANuSgW6hXrDU61Eqc6I5JxSFJZbxhJF+Xu4bL/IUQmW9p9IL0JRhR5alRL7Llo2u6+5MG5MoAeCvDTIK9PhRHoxOgd4YN/FfEzqFSaPS+t2nd2kgLVLMcgLSdmlOJ9VCpVCkKtij204JofuflH1B5IwXy16RfjgdEYJ9qcWwEOtxN/v6IMbeoZixU9n8dHeS3j+u1P4+bFROH6lCEaziFAfDSL9mzZTszmk4CZN4PjZujTMsStFePiTIwAsa9s1tL/r+O4h+HjvJbm7eEzXYLw0vTdUSgUmvLEdRy8X4fNDVzBzSGd5okFTK4n/NzoO9w+LafD9N657CMZ2C8b+1AJsOZ2NlNwyXCmswB0DIm0mDLUmrbNVRETtjD0TEyQDo/3l6lBckCd8tI2vNq9UCAjwVCPAMwADowOwdEpPmMxinfXagr0tWwIdTy/G/I8PIdxXi+5hPpg7Iha+Hip8fvCKXNkY29USbsZ2C8EHv1u2kHpmcnd5zbnh8UHy47opFejX2Q+7L+TbLHzqim5SSZivFgkhXkjOKcPuC/nw0CihM5oRYT0uEQQBQ2L98dPJLKzfk4b9F/ORV6bHxB7VS0Fcz8SEmrqGeSMpuxRJ2aUoqqzehaDSOj5N46ZA9/CGn+OGnqE4nVGCYG8N1j0wWA7yi27shh9PZuFibjke+eSIvDbdwGj/Fll7TOqOTMkpg9FklvcKBSxbXQFA/0Yqf3+IC4S3xg2lOiNmDo7Ci9bQBgB/uaErXvrxLF7ddA77LuZj/0VLcGtqJVEQhGv+p0EQBPwhLhB/qDW5obVicCMiagFSxa2+6lZDBtToDupjnZVoD+9Ggt6k3mE4nl6ME9avzaezsW53KgZE+8vVtql9I9A50LL8xtDYAEzpG4FATzXmjYxt8HEHdvbH7gv5+O5YBlRKS2hIcGFwAyxVt+ScMrz/+0WkW0PN2O51F1QdHBOAn05m4ccTmfKxX2vMdmx2cLP+Hs5nlcpVvHuGdsb+1AJcyClDYidfObDU58FRcQj00mBijxCE+1ZX0nzdVXj+1h54bMMxeVkNhWBZy64lRPq7w12lRKXBhP2pBUjJLYdCAJ69pae8L2r/RpYg0aqUWD93MLKKdbg5MczmdXlgeAy+PJyOc1ml+NY6aaBbqLe8q0NHxOBGRNQCpFlrod5ND259I/2gVAgwmUUkWitcjvLgqDj0CPNBYYUeJZUGfHbgCpKyS7E9KRcKAXjixm7y0iGApZr21qz+13xcKWweSK2endncwNNco7oGYe3uVLkrrmuolzxZoyZpZilgmUk7sUconvqyetC/IypugGVmqVSJujkxHA+Picfrm5MwY3BUo/f31Ljhvj9E13vb1L4RSMoqxdWiSozsEoQxXYPt+k9CcygUArqGeuF4ejHW7bZUZRMj/TBvZCzUbgqcvlqMkQlBjT5GQ4sSuykVeHNmf7y+OQldQ70wtlsI+nf2a9I40faKwY2IqAVkFUtj3JreVeqpcZNX0R8e79huHJVSYTPG675hMfjm6FVsOZ2FB0bE2HSB2mNklyDMHhaNjKJKaFVKdPJzxy19XLsW1tDYAPh5qFBWZcSfxnXBgnHx9W4U3ivCB49PTIC3VoU5w2OgUAjIL9fj1Z/PIdxXK6+Zd72kLsUzmSUQRUvX6MBof2hVSvyzCaG4MYIg4Gnr7F9X6BrqjePpxfL2XCOty6w0FDTt0S3MG/++f1CzH6e9YHAjImoB1WPc7KuCvH13f+SW6q65t2RzKRUC/jgwUl4n7nq5KRVYPq23g1rlGB5qN/zw6EiIIhrdeUEQBDw+savNsf8bHYeYQA9E+ns0e7xYVIAHtCoFqgyWtfaGxAY0uOVSWyNVI6W1bEd2CW7kbGoOBjciohYgdZWG2FFxAyzbPTVlM3hqXKR/w4GtMYIgYHJvx1QMlQoBXUK8cOqqZQFZacHi9qDmwsTuKiUGRPu5rjHtXMftJCYiaiEGkxl5ZZZZhPZW3Kh9qTlObmQ7Cm4193AdEhtQb1c0OQaDGxGRk+WWWrpJVUoBAayedWhSwAnwVKNnuGO3n3KlUB8NfLSWTrz2FEhbIwY3IiInk5cC8dY2uAgpdQwTeoRA46bAjMFR7eq9IAgCbukTDl93FW5KbJ07DrQXHONGRORk0sQEe8e3UfvTJcQb516c7OpmOMWK2/vg5emJ7SqQtkYMbkRETnY9a7hR+9USuxm4CkOb87GrlIjIyar3KWXFjYiah8GNiMjJqrtKWXEjouZhcCMicrJ86/ZGwV6suBFR8zC4ERE5WZnOCADw0nJYMRE1D4MbEZGTlelMACx7jxIRNQeDGxGRk5XpDAAALwY3ImomBjciIicrt1bcGNyIqLkY3IiInEwa4+ap4f6NRNQ8DG5E1CCzWcTuC3mo1Jta5PmKKvQwmMx2309vNOPrI+m4UlDhhFY1j95oht5ouSZW3IiouRjciOpxIacMVYbGw8rpjGJMe2c3vjyc3kKtanmfHriMe/69H2/9luyQxxNFEaIo1ntbVnEVhr6yFfM+OiQfK6rQ46Y3f8f0d3bjoz1pOH6lCOt2p2LR58fw2YHLMJtFVBlM+L//HMKiz49jyXenHNJOe4miiKXfncL7O1Pq3FZurbYBnJxARM3HvyJEtWxLysGcdQdx3x+i8eL03g2e9/nBKzh+pQjHrxQhr0yH+SNjseVMNn5PzsNDo+MQG+QJwPKhnpJbhvhgrza31c2+i/kAgCOXC+u9XdrKKaSJWzmt3Z2Gl388g8//bxgGxQTY3HboUgF0RjP2XcyHySxCqRCwMzkPZzNLAADHrhTZnP/1kav45uhVuCkE7EmxtPNURkmTr82RzmaW4qO9l+CpVuKh0fE2t0ndpBo3BVRK/l+ZiJqHf0Wow7uQU2bTFbj5VBYAYMuZrAarQwBwLL1Y/v7Vn89h6Ctb8af/HsFnBy7jqS+Oy/f9+6YkTFy5Ex/vveSkK3CeM9bQlJJbXue2Cr0Rt/xzF6a8tQs6Y9O6Ur89ehVmEdhyJrvObRdyygBYuhbTCytsjvWK8EGfSF94a90wKiEIc0fEwkOtxIHUAuxJyYeH2jJ2LLdUh+IKg/z9Qx8fwubTWXZetf2Sc0oBAJX1VGnL9dY13FhtIyIHYHCjDm3/xXxMXLkDf/36RPWx1AIAlm2K0gsr672fzmjCWWt154HhMQCA/HI9/D1UULspcOhSIbYn5eJCThn+/ftFAMBnBy478Uocr0JvRGqeJbDllupQXGmwuX1/agFyS3XILtHJAasxVQaTXD1Lyiqtc3vNx0jJtXyfYj02vV8nfL9wJE6+MAn/mTcUS6b0xObHR2Nst2B08nPHf+YNRYSvpep3Idfy2F8dSceWM9lY+OkRuXK4NyUfs97fh39sTkJOaRUMJjM2n87C89+eqrdNTZWcbWmnWQSMtcbolcsTExjciKj5+JeEOrSdybkAgJ9PZeEVnRHluuqwAli676ICPOrc71xmKfQmM/w9VFg6pSfGdgtGQbkeNyeGY+Uv5/H+zov4x5YkhHhrYDRbKm/nskpxIacUXUK8W+bimulcVilqFhwv5pahf2d/+effz+fJ3ydllaJXhG+jj3cms0T+XZzPbjy4Xcgpw/juoXKA6xLiVef8qAAPrJ8zRP45PsQLGcVVuJBThoHRATh11VIRNZhEPPzJYdw7NBrv7kiBySxi78V8vP/7RXhr3JBfrgcAbD2bjR/+PAoBnupGr6M+Na9HbzLDrUaXaGkVK25E5DisuFGHUWUw4YXvT+N3a1gDgJNXLRUgvdGM35PzsM9abZMcTKt/bNfx9CIAQJ9IPwiCgLHdQnD7gEhoVUo8PCYeXho3nM4owbakXLgpBPQM9wEA/O94phOuzDnO1BovVru7tObvMameIFbb8Rpj1DKLq1BSVV3BM5lFXKwRmFNyym2OxQfXDW61JVgDsVT9koJboKcaRRUGvL3tAkxmEZN6haJ/Zz/ojWbkl+sR5KVBuK8WGcVVeGzDUZjMDXePNyS5RuiUZpBKuIYbETkSgxt1GL8n52H9njQs/e40AMukgZPWAAYAv5zJxn5rl1p0oKXKdiitoM7jANUD5ftG+dW5LcBTjXkjY+Wf7x8eI//8w4mMRsfNtSan6wS36nCSWVxpE1aa0s14vNbkguQaYe9KQYVN4EnJLZOPadwU6OTvfs3Hl6pyyTllKKkyIC3fMk7us4f+gKgAdygVApZO6Yk19w7EN38age8WjMAn84Zi7+LxWDdnMLQqBX5PzsM/t9o3g7bKYMKl/OrQWTe4cQ03InIcBjdqU0RRxHs7UvBrPYPbryW/TAcAuJhXjuySKlwtqkRhRXXV57dz2dhrDW4Pj7HMDDyfXYaiCn2dx5JCSL+o+rsH54+KRSc/d3Tyc8efJyTghl6hULspkJJbjnPNGEvVkqSJCYNjLN2jKTWC2u/Jlm5ST+ukgCYFN+tkDg/5PrZdowCgVVn+JKXklsnH4oK9oFRcezZuQqiX/FinrZXUTn7u6Brqjc2Pj8bexeMxZ0SsPLO3b5QfRiYEQaVUoHuYD165LREA8Pa2C3XG89VWqTfJy8VczC1HzSKdrlZwK+MYNyJyIAY3alOSskux4udzWPzNSbvvWzOk7U3Jl7vSuoV6w9ddhcIKAy5auwMn9wpDXLBlOY/Dl2y7S0uqDHIXXp9Iv3qfy1urwq+LxuCXRaPh666Cj1aFsV2DAViqbq2d0WTGOWtwm9I3AoBtxW3neUs36Z2DogBYuj6LKxoOO0UVenns4C2J4QBsx4VJ1btRCZbfUWGFAQet1c76xrfVp4u1O/VqUSUOWLu8e3eydFF7qN2uuWTJ7QMiEeSlgcksNrqQb5nOiAlvbMfUt3fBaDLLM0olelP9wc1by+BGRM3H4EZtSnqBZZZnbqnO7hX2iyqrK2f7LubjpDW49Yvyw7huwfJt3cO84e+pxuBoyzpjtce5nUovhigCkf7uCPLSNPh87molPNTVH9a3WgPQh7tSMe3tXVi08ZjDVvr/9+8XccPKHbjrvb1Y8OkR7EnJu/adGpGWXw6d0QwPtRLju4cAAC7lV8BgMsNkFrHrguXxb+0TLs/mPJ/TcNXthLXaFhPogcGxlt9rzeAmVdcSO/mik5+lW1RaxqNLE8a3AYC/pxpBXpaJBd8dvyo/nj06+VmuJaOo/tnEALA9KQcZxVU4n12GfRcL5DF1kga7StUMbkTUfAxu1KZkllTJ3xeU1+3CbExReY2K28V8eWJC70hf3NAzTL5tqDVYDLJ2Ee66kIuVW5Iw6rXf8NqmczhkrcDVN76tMRN7hCDcV4sqgxnH04vx9dGrmPn+vkZDQlMkZVmqkMk5ZTiQWoAfT2Ti8Q3HmrS2miiKeGfbBTz5xXG5MgRUj2/rHuaNTn7u8FArYTSLuFxQgdMZxSiqMMBb44a+UX7oFmaZFFC7C/jI5UI8+tlRnEwvthkT2C3Ucr5NcLNW8xJCvOQKmzRGLT7Es8m/C2kSg1Q57WVncAv3tYTGzOKqBs/ZfLq6m/6HExl1ZsjW/g8Fu0qJyJH4l4TalOwaH6i5pTqE+jRtxX7AtuJ2Kb8COSWWMW99OvkiPsQLaqUCepMZQ+MCAQCDrSv7n7paglPWkPev7SmQhlv1a6CbtCEeajdse3IsLuSUIb2wEn/fdA6peeW498P9WDqlFw5fKsTVwko8Nakbwnybdl2iKGLp96dgMosY2y0YfxwYiZd+OIuskip8dywDd1m7Mhvy799T8frmJACW7sz37hsEpUKQx7f1ivCFIAiID/bCyavFSMkpk2fUDosPhEqpQLcwH2xLykVSVvVkhpIqAx755DCyS3TYfi5Hvp6+kX7yWLS8Mj3yy3QI8FTL4+e6hHghPtgLO85Xz1htalcpYBnntr/GzODe11iipLYIa7WvoTCtM5qw7VyO/PPPp7Lg4277Z7ShihtnlRKRI7DiRm1KzUpInnWyQVMV1hqDVWkwwU0hoFuYN7w0bnj8hgRM7BGCcd0sXYPRgR6Isc4u7R7mjSdv7ApvrZs8EN3eihsAaFVK9O7ki8m9w/DJfMuisRdzy3H/2gP459ZkfHUkHYu/PmEz89RsFnHqajE+2pOGXcl5Nrf9cCIT+y4WQOOmwIvTeuPWPhGYOzIGAPD+zoswWxtrNtfdI3Tr2Wy88vNZAIBCAH49m4N/bEmSnw8AekZYxojFW8f7HbpUiI/2WHaAmN6/EwCgW5glWNWcoPDapnPItgbjUp1RHsPWN8oPHmo3RAVYAtL57DJklVShTGeEUiEgOtDTpsKmECBvHdYUNbtVw3y0CPZuuCu7PhFSV2kDFbc9F/JRpjMixFuDYG8NiisNuGLtvvf3UAGoG9ykipsXx7gRkQO4/C/JO++8g9dffx1ZWVno27cv3nrrLQwZMqTec9evX485c+bYHNNoNKiqqv4j+8ADD+Cjjz6yOWfSpEnYtGmT4xtPLS6rpLoSkldmX1epNHi+dycfuYLWNdQbWpVlluOfxnaxOV8QBHwyfyiyiqswoLM/FAoB0/p1wjNfnUC5zoi+DcwobapOfu74ZP5Q3PfhAVQaTBgWF4gtZ7KwLSkXW85kY1KvMHy0Jw1vbk226RYeHh+IuSNikZpXjvetuzIsGNdFXih41pDOeGvrBVzIKcNv53KQll+O1b8mw1OjxIguQegc4IHknDJsO5cDUQTuHtoZQ2IC8PjGY3h3ewrW7U5FlcESPqT156QuyLW7UmE0i+gV4YPJvSzdy91CLeckZZVCFEUcvlSIT/ZZdolY98BgrN2dit+T8+CmENDLGgS7hXrjSkElzmeXwmi2PFdMoAfUbgqbNds6B3hA49b0ZTQSQqsXN+5tZzcpUN1V2lDFTRp3d2OvUCgFAR9ZtzHz0boh0t8DhRXF0LGrlIicyKV/STZu3IhFixZhzZo1GDp0KFavXo1JkyYhKSkJISEh9d7Hx8cHSUlJ8s/1bdo9efJkrFu3Tv5Zo7Hvf93UejWn4iZ1ld7UO1wObtcavB7p74FI/+qdE6ICPPDpg3+w63kbExfshV3PjANgeS+/vvkc3tmWguX/O4P9FwuwdncqAMuyG32j/HAorRB7UvLlTdUBS2XwodFx8s/eWhXuHtoZ7+28iIWfHZFDWJnOiK+PXLV5/pFdgrBsai+olAqczy7Fv7anoMpghlqpwMiEIDloxVu7K6WdD56a1A0Ka59xfIgnlAoBJVVGHEgtwOKvLTN+7xoUiXHdQzAsPhCrfjmPmCBPOSR3DfXGr2dzcD67FGZrJVDqEq0Z3OzpJq19vjSj1B5SxS2znuBmMov4xboMzeRe4dCoFHJw6xrqDame2fACvFzHjYiaz6XBbeXKlXjwwQflKtqaNWvw448/Yu3atfjrX/9a730EQUBYWFi9t0k0Gs01z6G2RxRFZNUMbqVND26iKMpdpTf0DMWqX87DaBbRO7J5VTNHqPmfj4XjEvDt0QxcLaqUQ9vTk7vhwVFxUCkVuFJQgZW/nMfBtAJ0D/PBwGh//HFgpByIJHNGxGKttXKmVirw7C090CXEC78n5yG/TIcuIV7oHu6DEfGB8vZMT03qhht7hcHXXYUof3ebbZtqhqkhMQEY07V6Fq7GTYm4IE8k55Rh5gf7IIpAiLcGf7u5BwBL9/Bi6/cSaULD5tPZ8rZjUugK8lLD112F4kpDk3ZMqCnEWwNvrRtKq4x2j28Dqse4ZZVUwWjduuqHExk4mV4Mk1lEfrkevu4qDI0LgFIQEOajRVZJFRJCvZCWZ5lMwVmlRORMLvtLotfrcfjwYSxevFg+plAoMHHiROzdu7fB+5WVlSE6OhpmsxkDBgzAK6+8gl69etmcs337doSEhMDf3x/jx4/HSy+9hMDAwAYfU6fTQaerDgElJSUNnkuuU6ozokJfPVPSnopblcEsf6BG+LljYo9QbD+fg9EJQQ5vZ3O4q5VYOqUnHvrPYbgpBLz2xz64fUCkfHtUgAdWzeh3zccJ89Xibzf3wG/ncvDM5O5yt+GILg1fryAI6NfAuL3oQA9o3BTQGc14anK3OpXubmHeSM4pgygCQ2IDsGpGP/h5NLznp7Svac3XcGC0v9yOhBAvHLpUaNP12RSCIODxiV1xKK0AI6/jtQ320kClFGAwicgp1cFdpcSfPztqs8DuhO4hUFlD7X3DovH65iSM6RqCjCJL93Dt4FbKMW5E5EAu+0uSl5cHk8mE0NBQm+OhoaE4d+5cvffp1q0b1q5diz59+qC4uBj/+Mc/MHz4cJw+fRqRkZYPt8mTJ+P2229HbGwsUlJS8Le//Q033XQT9u7dC6Wy/q6KFStWYNmyZY69QHK4rFoDxvPtWA6k0Lr7gZtCgKdaidUz+6HKYGo0XLjKjb3C8NHcIQj20siTA67HnBGxmDMi9tonNoFWpcSa+waiXGeUZ9vWdFv/TjhyqRD3/CEaD4+Jv+ZOB11CvPCvewYgo6gSwd4axAR6ok+N6uczN3XHTyczcXOi/ZXzeSNjbbYcs4dCISDUR4v0wkpkFFWiymCGWbRMPBjdNRg6gxkLxlePhfzT2HjcOTASIT5afHUkHUDdBXg5q5SIHKlN/SUZNmwYhg0bJv88fPhw9OjRA++99x5efPFFAMDMmTPl2xMTE9GnTx/Ex8dj+/btmDBhQr2Pu3jxYixatEj+uaSkBFFRjS+jQC2vdnDLtaOrtMjaTernoYYgCNCqlHW6F1uTml2RrYU027Y+E3qEYkKP0AZvr8/N1h0U6jM4JqDegNgSIvzcLcGtuEqepDA8Pghvzuxf51xBEBBiXZJGba3C1ay4mc2iXCXm5AQicgSXLQcSFBQEpVKJ7GzbPSezs7ObPD5NpVKhf//+uHDhQoPnxMXFISgoqNFzNBoNfHx8bL6o9ZGCW4h1iQd7ZpVK+436WZdsIGqItBNERlGlvCxKryZMdFC71Q1u5frqRY1ZcSMiR3BZcFOr1Rg4cCC2bt0qHzObzdi6datNVa0xJpMJJ0+eRHh4w/9zT09PR35+fqPnUOvy08lMjH19G05at0mSSDNKpfFaBeU6mMxinfvXp8i6abg/gxtdgzRBIbOoUt5BoikTHeSKW42uUmkpEDeFAI0bl80kouZz6V+SRYsW4YMPPsBHH32Es2fP4pFHHkF5ebk8y3T27Nk2kxeWL1+OLVu24OLFizhy5AjuvfdeXLp0CfPnzwdgmbjw1FNPYd++fUhLS8PWrVsxbdo0dOnSBZMmTXLJNZJ9dEYTXvj+NNLyK/DzqUyb26Q13KQlKsxi9di1a5HO83VvfWPaqHUJ96teHDg1z7p1VhPGGkoVN13NiluNNdzqW7qIiMheLq3dz5gxA7m5uViyZAmysrLQr18/bNq0SZ6wcPnyZSgU1dmysLAQDz74ILKysuDv74+BAwdiz5496NmzJwBAqVTixIkT+Oijj1BUVISIiAjceOONePHFF7mWWxvx1eGryLGOXas9pk36OdLfHf4eKhRWGJBXpmt0o3eJNMaNFTe6Fmmj+YNplq2zIny1CGzCe6y+rtIyeQ03dpMSkWO4/K/JwoULsXDhwnpv2759u83Pq1atwqpVqxp8LHd3d2zevNmRzaMWZDSZ8d7OFPnn2ht9Sz+H+mgR5KWxBLdSPdCEIZHFldLkBAY3apy0e4K02HBTN6qvd4ybXHFrvRNhiKht4aALajV+PJmJS/kV8s/ZJbUqbtafw33d5SpbU9dyKyyXJiewq5QaF2ENbpKmLuRbPcateq3B0iouBUJEjsXgRq2CKIp4d7ul2nb7AMvm5ZnFVfLG6FUGk9zdGearRZC3fcGtiBU3aiIfdzd4qqsrZE3dOqvxihuDGxE5BoMbtQp5ZXqcyyqFIADPTO4OAKg0mFBSafngk8a3uauU8NG6IcjLUjnLbWpwk5YD4eQEugZBEOQJCkDTN6vXNLIcCCtuROQoDG7UKlQZLN1LGjcFQn20cmVM6h6VxreF+2ohCEJ1V2lp02aVcnIC2UNaEiTISyOvG3gtcsWtnuVAWHEjIkdhcKNWQfqwk8YJhVlXo88stiwBIi0FEmZdHDXY3jFu1uDmy+BGTSAtwtu7k0+Tl/Gob+eEMo5xIyIHY3CjVkH6sNNYt6GSApo0QSGr2BLQpEAX5G3p8mxKcBNFEcWVlsqcPycnUBMM6GzZ8N6erccaW8eNwY2IHIV/TahVkD7spKpFuK9UcZOCm23FzZ5ZpeV6EwwmyyQHTk6gprhzUCRGJgTJ78OmaGwdN3aVEpGjsOJGrYJccXOTukotY4ykSQlp1mVCOvlXjz0CgPwyPczX2PZKmpigVirg3oo3lqfWQxAERPi527XbQX1bXlVX3Pi+IyLHYHCjVkEKblLVIszXEsyySixLgpzOsOxb2jPcsjRDoHVWqdEsoqTK0OhjSxMT/DxU3HaInKb+ips1uGlZcSMix2Bwo1ZBZ6yeVQoAYb7VFbecUh3yyvRQKgT0sAY3jZtlWRDg2t2lNYMbkbM0Ftw81QxuROQYDG7UKtSpuPlUj3E7ddVSbYsP9oS2RlentAhv7jWWBCmq5K4J5HyaepYD4eQEInI0BjdqFaQPO42b7azS4koDDl0qBFB36yFpnNu1FuGVlgLxc2fFjZxHrbS8d+utuDG4EZGDMLhRq6Az2FbcfLRu8LBuO7T1bDaAupt9R1onKqTklDX62MUVXAqEnE967xrqWYCXY9yIyFEY3KhV0NVagFcQBLm79Hy2JZj1irDdM7JflB8A4Hh6UaOPXcgxbtQCaq/jJooiu0qJyOEY3KhVqF6At/otGVZrDa2etYJb30g/AMDxK0XyZvT1KeKuCdQCVErLjGXpvVxlMENaqYZdpUTkKAxu1CpIs0qlihtQPUEBAGICPeCjtQ1ePcJ9oFYqUFhhwOWCigYfu4hdpdQCau5VKooiSnXVy9R4cP1AInIQBjdqFWrPKgVsK261x7dJ50pVuGNXihp87KJKTk4g59NYJyeIomV9wXLrrgleGjcoFFw/kIgcg8GNWoX6glvN7YZqj2+TSOPcGgtu0jgjby2DGzlPzfeu3miW33fSJBsiIkdgcKNWQWe0XQ4EAEJrdJXWXgpEIk9QaCy46S0foO78ACUnaii4cWICETkSgxu1CvVX3Nzl7xuquPW1BrdTGSU2yzDUVCFv9M3gRs6jVAhQWrtE9SYzKvTcYJ6IHI/BjVqF2pvMA0CXEC+E+2oxNDYAgdbFdmuLCfSAr7sKeqMZSVml9Z4jVdy47RA5m7zRvNEsv+/YVUpEjsRPMmoVqndOqA5u7moldjw1Dm6NDOwWBAF9o/yw83wujl4pQu9akxhMZhFV1sV9+QFKzqZ2U6DSYIKuRlcpK25E5EisuFGrIC8H4mb7llS7Ka45I69fpCWs1TfOrcJa9QD4AUrOV3Oj+XIdu0qJyPEY3KhVkMe4Ke1/S0rj3HYl59kENQDyOCOFYFvNI3IGuavUZJbfi56s9BKRA/GTjFoFXT07JzTV8PggdPJzR1ZJFf6x+bzNbfIAcbUbBIFraZFzaWpU3MqsFTcPjq0kIgdicKNWQSdX3OyvTrirlXjl9kQAwLo9qTh8qUC+TV5LizNKqQXU7CqVKm5efO8RkQMxuFGrUN9yIPYY0zUYdwyIhCgCT315AlUGS7WjZsWNyNmqt70yyWPcPDjGjYgciMGNWoX6lgOx1/O39kCQlwYXc8uxPSkXQPVSIKy4UUuwWQ5ExzFuROR4DG7UKjQ0q9Qefh5qeSeF/HIdgOrFdznOiFqC9P7V1VjHjbNKiciRGNyoVZDWcWtOcAMAH63lQ7K0yvKhWc6ZfdSCbJcDkRbgZXAjIsdhcKNWoTnLgdTkLQc3AwCgQp6cwA9Pcj7b5UC41RoROR6DG7UK0qxS7XUsB1KTt1YFoGbFTZqcwA9Pcj6bihu7SonICRjcyCUu5JThQk6Z/LO+GcuB1ORdq6u0Qs/uKmo59e6cwPceETkQ/6JQi9MZTbjtX7shADj8/A1QKRXNXg5EUl1xs3SVVm87xIobOZ+m3jFufO8RkeMwuFGLK6owyBWx0iojfN1VMJpFAM3flkqquJWw4kYuII1xkzaaBwAvdpUSkQOxq5RaXHGlQf6+Qm+Uq22AIyputWeVSsuBsOpBzqeyBrfCiur3ONcQJCJHYnCjFlczuFXqTQ4ObrZdpRXyIqisepDzSe/fwnI9AEClFKBxY3AjIsdhcKMWV1IjuJXrTdCZLFUxhQC4KZq3EXztddykJRlY9aCWIAe3CktwYxc9ETkagxu1uNpdpTpD9cQEQWhecJMqbmU6I0RR5F6l1KKk4FZk7SrlMjRE5GgMbtTialbcKnSm6l0Tmrn4LlA9xs1ktoQ2ea9SfoBSC1ArbStuXMONiByNwY1aXHGlUf6+wlA9xk2jan648lArobR2t5ZWGeW9SvkBSi1BU6vixh07iMjRGNyoxZVU1ay4GeVlExxRcRMEQV5+obTKwIobtSh5AV5rFZldpUTkaAxu1OJsx7jVqLg1c0appOZabtX7RbLyQc5Xe1Y033dE5GgMbtTiGlrHrblLgUikCQr5ZTqYrAv7suJGLaH2lm2suBGRozG4UYsrqVVx0xktVTFHV9yyS6rkY1yWgVpC7f98cIwbETkagxu1uIa6Sh1VcZPWcsuyBjetSiFPWCByptrvYW53RUSOxuBGLU5aHBewdpWanNNVmlWsA8A13Kjl1J5gwy56InI0BjdqcbUrbtICvI7aGqh2Vyl3TaCWUmdyAv/TQEQOxuBGLcpoMqNMV7PiZoLOgQvwAnWDGz88qaXUHqfJWaVE5GgMbtSianaTAs6dVSqNcWN3FbWUusuB8L1HRI7F4EYtqmY3KeDcWaVSSGTVg1pK3TFufO8RkWMxuFGLqrlrAuCcWaVSxU3i7oCttIiaghU3InI2BjdqUbUrbpVOCW62VQ5W3KilcHICETkbgxu1qBLrBvMBnmoAQLm+eq9SR80q9akV3DjGjVoKK25E5GwMbtSipIpbmI8WQMt0lbLiRi2l9hg3vveIyNEY3KhFSWPcwn0twU1vNMsbwTt6coKEFTdqKZycQETOxuBGTnEhpwz3fbgfB9MKbI7LFTdrcLMc0wNwZHCrVXHjhye1EIVCgFuN7dW4yTwRORo/0cgpNh68jN+T8xDspcHgmAD5uBTcgrw0cFMIMJpFFFZYjjmqq9RTrYRCAMyi5WfunEAtSe2mgFFvgsZNATcHLSpNRCThXxVyinNZpQCAnFKdzfESa3DzdVfB3VqNKKywVNwctXOCIAg2m3uz4kYtSfoPCMe3EZEzMLiRU5zPloJblc1xqeLm466Sx54VObjiBth2l3KMG7Uk6T8gnFFKRM7A4EYOV1ShR3aJpdJWp+Jm3c3A110lV8KKKqQxbo77oKs5QYGVD2pJcsWNlV4icgIGN3I4qZsUsFTTpC2tgPq7SqWxaI6tuFV/aLLiRi1Jeh/zfUdEzsDgRg4ndZNKcmtU3aq7St3qVCSc1VXKihu1pOquUr7viMjxGNzI4WpW3IDq7lJRFOutuEkctRwIwIobuY6GXaVE5EQMbuRwSbWDm3W8W4XeBKO1X9RHq6ozeNtZXaX8AKWWJHeVcnICETkBgxs1W4XeiHe2XcDVokqIoojz1uAWE+gBAMi1ziyVdk1wUwjwUCvhrqrVVerANa9sZpXyA5RakBTcvNhVSkROwOBGzbbx4BW8vjkJf/rkMDKKq1CqM8JNIeAPcYEAqrtKi2t0kwqCUKcLU6tyfMXNTSE4NBASXYv0fuN2V0TkDPxEo2Y7m1kCADieXoz3dqQAAOKDvRDh5w6guqu0pNKyFIiPu6UaVrsSplY6cjkQ63OolRAE4RpnEzlO9XIgrPQSkeMxuFGzpeSWy99/vPcSAKBrmDdCvDUAqhfhrbn4LgB41O4qdeAYNx9rxY1VD2pp/h5qAECQ9f1PRORI/FSjZhFFERdyygAAggCI1jXZuod5I8RHCm62XaVSqKo9OcEZs0o5vo1a2sLxXdA11BtT+0a4uilE1A6x4kbNkl+uR3GlAYIA3PeHaPl4t1BvhHhrAVQHt5pLgQCosxyIIytu/aL8Eenvjsm9whz2mERNEenvgbkjY7mOGxE5Bf+yULOkWKttkf7u+POEBHx5OB06oxm9O/lCYR1all+mg8ks2kxOAOqur+bI4BbgqcbvT4/j+DYiImpXXF5xe+eddxATEwOtVouhQ4fiwIEDDZ67fv16CIJg86XVam3OEUURS5YsQXh4ONzd3TFx4kQkJyc7+zI6rAu5luDWJdgLQV4afP5/w/CfuUMQ5qtFoJcGCsGypVV+mQ7nsiyTGCL9LcuE1Bx/phAsM0AdiaGNiIjaG5cGt40bN2LRokVYunQpjhw5gr59+2LSpEnIyclp8D4+Pj7IzMyUvy5dumRz+2uvvYZ//vOfWLNmDfbv3w9PT09MmjQJVVVVzr6cDiklxzIxIT7YCwDQu5MvhncJAgAoFQICvarHuR2+VAgAGBTjD8C24qZ2UzBoERERXYNLg9vKlSvx4IMPYs6cOejZsyfWrFkDDw8PrF27tsH7CIKAsLAw+Ss0NFS+TRRFrF69Gs899xymTZuGPn364OOPP0ZGRga+/fbbFriijifFWnGLD/Gq9/Zga3A7lFaAvDI91EoFEjv5ArCtuHGtNSIiomu7rk9Lo9GIX3/9Fe+99x5KSy2r5GdkZKCsrKzJj6HX63H48GFMnDixujEKBSZOnIi9e/c2eL+ysjJER0cjKioK06ZNw+nTp+XbUlNTkZWVZfOYvr6+GDp0aKOPqdPpUFJSYvNFTSPNKO3SQHCTZpb+dCoLAJAY6QutylJps624cfYnERHRtdgd3C5duoTExERMmzYNCxYsQG5uLgDg73//O5588skmP05eXh5MJpNNxQwAQkNDkZWVVe99unXrhrVr1+K7777DJ598ArPZjOHDhyM9PR0A5PvZ85gAsGLFCvj6+spfUVFRTb6OjqxSb8LVokoA1V2ltUlruR1MKwAADIr2l2+ruYeoI5cCISIiaq/s/rR87LHHMGjQIBQWFsLd3V0+ftttt2Hr1q0ObVxtw4YNw+zZs9GvXz+MGTMGX3/9NYKDg/Hee+8163EXL16M4uJi+evKlSsOanH7JnWT+nuoEOCprvccaUkQaX23gTWCW83lQBjciIiIrs3u5UB+//137NmzB2q17Qd1TEwMrl692uTHCQoKglKpRHZ2ts3x7OxshIU1be0tlUqF/v3748KFCwAg3y87Oxvh4eE2j9mvX78GH0ej0UCj4Srn9pKCW0PdpEB1V6mkZnCrPTmBiIiIGmf3p6XZbIbJZKpzPD09Hd7e3k1+HLVajYEDB9pU6cxmM7Zu3Yphw4Y16TFMJhNOnjwph7TY2FiEhYXZPGZJSQn279/f5MekppO2umqomxSo7ioFgLggT3mWKQC4q1hxIyIisofdn5Y33ngjVq9eLf8sCALKysqwdOlS3HzzzXY91qJFi/DBBx/go48+wtmzZ/HII4+gvLwcc+bMAQDMnj0bixcvls9fvnw5tmzZgosXL+LIkSO49957cenSJcyfP19uy+OPP46XXnoJ33//PU6ePInZs2cjIiIC06dPt/dS6RqkxXcbC27B3tXr7NWstgGAQiHI4Y0VNyIiomuzu6v0jTfewKRJk9CzZ09UVVXh7rvvRnJyMoKCgvDZZ5/Z9VgzZsxAbm4ulixZgqysLPTr1w+bNm2SJxdcvnwZCkX1B3phYSEefPBBZGVlwd/fHwMHDsSePXvQs2dP+Zynn34a5eXleOihh1BUVISRI0di06ZNdRbqpeZrUldpjYrb4JiAOrd7apSoNJgY3IiIiJpAEEVp2HjTGY1GbNiwASdOnEBZWRkGDBiAe+65x2ayQltWUlICX19fFBcXw8fHx9XNaZWqDCYkvrAZBpOI358eh6gAjwbP67FkE0QR2PrEmDrVuVGv/YYrBZUY3z0Eax8Y3BJNJyIialXsyR3XtVepm5sb7r333utqHLVNpzOKkZpXjlv7RAAAzmaWwGASEeipRqR/w4Fdq1Lir5O7o1xnRFyQZ53bpSVBuAAvERHRtdkd3D7++ONGb589e/Z1N4Zcp1JvwvIfTuPGXmEY1y2kzu2LNh5HUnYpIvzcMaCzP45dKQIA9I3yu+ZWVf83Jr7B26QlQdhVSkREdG12B7fHHnvM5meDwYCKigqo1Wp4eHgwuLVRvyfn4rMDV3Amo6Te4JZbpgMA7EjKxYDO/jguBbdIv2Y9r7QkCGeVEhERXZvdn5aFhYU2X2VlZUhKSsLIkSPtnpxArUdRhQEAkF2iq/f2Cr0RALD7Qh4A4Hh6MQCgX2e/Zj2vtF8pK25ERETX5pBPy4SEBLz66qt1qnHUdpRUWYJbfrkOZrPtfBWzWUSVwQwAOHalCFeLKpGaZ1nDrW+kb7Oe14NdpURERE3msE9LNzc3ZGRkOOrhqIWVVFkqagaTiOJKg81tlYbqBZeNZhEf7LwIAIgJ9ICfR/1bXTUVK25ERERNZ/cYt++//97mZ1EUkZmZibfffhsjRoxwWMOoZZXUCGt5ZTr419h7tNzaTSrZcPAyAMvEhObqG+mLzw4AvSOaV7kjIiLqCOwObrV3IBAEAcHBwRg/fjzeeOMNR7WLWlhpVXU4yy3VISG0evuySr3tFmdSt2lzJyYAwMwhnXFzn3D4aFXNfiwiIqL2zu7gZjabndEOcjFpjBtQPYNUUmENbu4qJaqMJkhLNjd3YoKEoY2IiKhpOLCIAAClNYNbaf3BLchbjV4RlhWd3RQCeoZzVwkiIqKW1KSK26JFi5r8gCtXrrzuxpDrlFRWd5XmleltbpO6Sj1UbhjRJQinrpagR7gPtNYN4omIiKhlNCm4HT16tEkPdq0V9Kn1KtU1VnGzhDp3tRKzBnfGjqRczB0Z05LNIyIiIjQxuG3bts3Z7SAXs6241d9V6qlRIibIE5seH92ibSMiIiILjnEjiKLYpDFu7iq757IQERGRA13XJ/GhQ4fw+eef4/Lly9DrbcdDff311w5pGLWccr0JNTdLqFtxs1TjpF0OiIiIyDXsrrht2LABw4cPx9mzZ/HNN9/AYDDg9OnT+O233+Dry0VU26Ka1TYAyC/X22x7JU9OYHAjIiJyKbuD2yuvvIJVq1bhf//7H9RqNd58802cO3cOd911Fzp37uyMNpKTSePbvLWWAqzJLKKworqSWmHd8sqdwY2IiMil7A5uKSkpuOWWWwAAarUa5eXlEAQBf/nLX/D+++87vIHkfFLFLcBTjQDrVlc1F+FlxY2IiKh1sDu4+fv7o7S0FADQqVMnnDp1CgBQVFSEiooKx7aOWoS0a4KPVoUgL0twyyutUXGTx7hxcgIREZEr2R3cRo8ejV9++QUAcOedd+Kxxx7Dgw8+iFmzZmHChAkObyA5n7RPqbfWDcHeGgBAblmVfHs5K25EREStgt0llLfffhtVVZYP9WeffRYqlQp79uzBHXfcgeeee87hDSTHM5rMeH1zEoZ3CcKYrsEoqayuuGlUlixfc0kQdpUSERG1DnYHt4CAAPl7hUKBv/71rw5tEDnf3ov5eG/nRfx2LgdjFo1BSY2Km6+7ZcP3mtteVe+cwK5SIiIiV7K7q3TixIlYv349SkpKnNEeagGZRZaKaXphJURRrB7j5q5CkNRVWl/FjXuTEhERuZTdwa1Xr15YvHgxwsLCcOedd+K7776DwWC49h2p1cgptQS3SoMJxZUG2zFuXpbgVnMR3gp2lRIREbUKdge3N998E1evXsW3334LT09PzJ49G6GhoXjooYewY8cOZ7SRHCynRjUto6jKZoxbfRU3ecsrBjciIiKXuq69ShUKBW688UasX78e2dnZeO+993DgwAGMHz/e0e0jJ8gpqQ5lmcWVNhU3eTkQm4qb5XZPDce4ERERuVKzPomzsrKwYcMGfPLJJzhx4gSGDBniqHaRE0ldpQCQUVxlM8ZNWg4kv1wPo8kMN6WixibzrLgRERG5kt0Vt5KSEqxbtw433HADoqKi8O6772Lq1KlITk7Gvn37nNFGcrCaXaWZRbYVtwAPNQQBEEWgoEIPk1mEzmgGwDFuRERErmZ3xS00NBT+/v6YMWMGVqxYgUGDBjmjXeQkoijaBrdi2zFubkoFAj3VyCvTI7dUZ7NbAndOICIici27P4m///57TJgwAQrFdQ2PIxcrqTRCb62gAUBGjYqbj9ayhluQlwZ5ZXrklenlrlNBALQqvuZERESuZPcn8Q033MDQ1obVHN8GAFcKKlBpsIxh83G35PhA6wSFgnKdvIabu0oJQRBasKVERERUGxNYByN1k3pZZ4hmFFcHOelYoKd1gkKZHuU6ruFGRETUWjC4dTBSxa1nhA9qFtA81Uq4KS1vh0B5SRA9Kg2WblSObyMiInI9BrcORlrDrZOfu7xLAgB4W8e3AZYxbgCQX6bjrglEREStCINbByN1lYZ4axDh5y4fl8a3AUCgpzTGTc9dE4iIiFoRu4Pbn//8Z/zzn/+sc/ztt9/G448/7og2kRNJwS3YW4MIP6183KdGxS3AGtzyyvXVG8wzuBEREbmc3cHtq6++wogRI+ocHz58OL788kuHNIqcJ6fEMsYtxEeLcN/qipu3tkbFrZ6uUncVx7gRERG5mt3BLT8/H76+vnWO+/j4IC8vzyGNIufJrdFVGu5bo+LmXnOMm6Xill+ml/cpZcWNiIjI9ewObl26dMGmTZvqHP/5558RFxfnkEaR82RLFbdaY9zqq7hVGkzIL9cDADw1DG5ERESuZnf/16JFi7Bw4ULk5uZi/PjxAICtW7fijTfewOrVqx3dPnKgcp0R5dauzxAfLYqtW10BtmPcPNVKaNwU0BnNuFJQAYBdpURERK2B3Z/Gc+fOhU6nw8svv4wXX3wRABATE4N3330Xs2fPdngDyXGkiQkeaiW8NG61Km7VwU0QBAR6qpFRXIUrhZXyfYiIiMi1rquM8sgjj+CRRx5Bbm4u3N3d4eXl5eh2kRPk1OgmBSzrtbkpBBjNos1yIICluzSjuApXC60VNwY3IiIil2vWOm7BwcEMbW1I9RpulkkJSoWAUB/L9zUrboDt7gkAK25EREStQZMqbgMGDMDWrVvh7++P/v37N7rZ+JEjRxzWOHIseQ03n+odE/pG+eJqUSW6BNsGcGm/UgmDGxERkes1KbhNmzYNGo3lg3z69OnObA85kbRPqdRVCgAr7+qHpydVISbI0+ZcaUkQiTv3KiUiInK5Jn0aL126FABgMpkwbtw49OnTB35+fs5sFzlBboltVykAaFXKOqENqO4qlXiy4kZERORydo1xUyqVuPHGG1FYWOis9pAT5ZZVL757LQG1uko5OYGIiMj17J6c0Lt3b1y8eNEZbSEny7dONKhdTatP7XM82FVKRETkcnYHt5deeglPPvkkfvjhB2RmZqKkpMTmi1qvwgpLcJM2kW9MECcnEBERtTp2l1FuvvlmAMDUqVNtZpeKoghBEGAymRzXOnIYURRRYN2+yt/D/oqbu4rBjYiIyNXsDm7btm1zRjvIySoNJuiMZgBNq7jVPocVNyIiItezO7jFxsYiKiqqzlpuoijiypUrDmsYOZZUbVO7KZoUwrQqJbw1bijVGQFwjBsREVFrYPcYt9jYWOTm5tY5XlBQgNjYWIc0ihyvsNyyoXyAh7rRBZRrCrB2lwoCoFU1a5MNIiIicgC7P42lsWy1lZWVQavV1nMPag0KrBMT/JvQTSoJtJ7roVI2OewRERGR8zS5/2vRokUAAEEQ8Pzzz8PDw0O+zWQyYf/+/ejXr5/DG0iOUVguzShVXePMaoFelpml3DWBiIiodWjyJ/LRo0cBWCpuJ0+ehFpdXblRq9Xo27cvnnzySce3kBzCnhmlEmnbK05MICIiah2aHNyk2aRz5szBm2++CR8fH6c1ihzPnjXcJNJG8wxuRERErYPdY9zWrVsHHx8fXLhwAZs3b0ZlZSUASyWOWq/rqbhJa7lxuysiIqLWwe7gVlBQgAkTJqBr1664+eabkZmZCQCYN28ennjiCYc3kBzjeipu0YGWcYyh3px0QkRE1BrYHdwef/xxqFQqXL582WaCwowZM7Bp0yaHNo4cR6642RHcxnQNwVuz+mPp1J7OahYRERHZwe7pglu2bMHmzZsRGRlpczwhIQGXLl1yWMPIsWqu49ZUSoWAKX0jnNUkIiIispPdFbfy8nKbSpukoKAAGo2mnntQa1C9jlvTlwMhIiKi1sXu4DZq1Ch8/PHH8s+CIMBsNuO1117DuHHjHNo4cgxRFGus49b0ihsRERG1LnZ3lb722muYMGECDh06BL1ej6effhqnT59GQUEBdu/e7Yw2UjOV6owwmi2zfu2ZVUpERESti90Vt969e+P8+fMYOXIkpk2bhvLyctx+++04evQo4uPjndFGaiap2uahVkKr4tIeREREbdV17WXk6+uLZ5991tFtISe5njXciIiIqPW5ruBWVVWFEydOICcnB2az2ea2qVOnOqRh5DjXs4YbERERtT52B7dNmzZh9uzZyMvLq3ObIAgwmUwOaRg5Tn6Z/Wu4ERERUetj9xi3Rx99FHfeeScyMzNhNpttvhjaWie54ubBpUCIiIjaMruDW3Z2NhYtWoTQ0FBntIecoMC6+C4rbkRERG2b3cHtj3/8I7Zv3+6EppCzyGu4cXICERFRm2b3GLe3334bd955J37//XckJiZCpbLtfvvzn//ssMaRY1TvmsDgRkRE1JbZXXH77LPPsGXLFnz11Vd46623sGrVKvlr9erVdjfgnXfeQUxMDLRaLYYOHYoDBw406X4bNmyAIAiYPn26zfEHHngAgiDYfE2ePNnudrUn3DWBiIiofbC74vbss89i2bJl+Otf/wqFwu7cZ2Pjxo1YtGgR1qxZg6FDh2L16tWYNGkSkpKSEBIS0uD90tLS8OSTT2LUqFH13j558mSsW7dO/rmj76EqV9zYVUpERNSm2Z289Ho9ZsyY0ezQBgArV67Egw8+iDlz5qBnz55Ys2YNPDw8sHbt2gbvYzKZcM8992DZsmWIi4ur9xyNRoOwsDD5y9/fv9ltbctYcSMiImof7E5f999/PzZu3NjsJ9br9Th8+DAmTpxY3RiFAhMnTsTevXsbvN/y5csREhKCefPmNXjO9u3bERISgm7duuGRRx5Bfn5+o23R6XQoKSmx+WovTGYRRZXSrFIuB0JERNSW2d1VajKZ8Nprr2Hz5s3o06dPnckJK1eubNLj5OXlwWQy1VlWJDQ0FOfOnav3Prt27cKHH36IY8eONfi4kydPxu23347Y2FikpKTgb3/7G2666Sbs3bsXSmX9+3SuWLECy5Yta1K725riSgNEy/7y7ColIiJq4+wObidPnkT//v0BAKdOnbK5TRAEx7SqHqWlpbjvvvvwwQcfICgoqMHzZs6cKX+fmJiIPn36ID4+Htu3b8eECRPqvc/ixYuxaNEi+eeSkhJERUU5rvEusO1cDt76LRnWzAZvrRtUyuZ3bxMREZHr2B3ctm3b5pAnDgoKglKpRHZ2ts3x7OxshIWF1Tk/JSUFaWlpmDJlinxM2ifVzc0NSUlJiI+Pr3O/uLg4BAUF4cKFCw0GN41G0+4mMKzbk4Yjl4vkn6MDPVzXGCIiInKI69pk3hHUajUGDhyIrVu3ykt6mM1mbN26FQsXLqxzfvfu3XHy5EmbY8899xxKS0vx5ptvNlghS09PR35+PsLDwx1+Da1ZkXUm6UOj4xAd6IHh8Q1XKYmIiKhtcFlwA4BFixbh/vvvx6BBgzBkyBCsXr0a5eXlmDNnDgBg9uzZ6NSpE1asWAGtVovevXvb3N/Pzw8A5ONlZWVYtmwZ7rjjDoSFhSElJQVPP/00unTpgkmTJrXotblasXVCwo09QzEoJsDFrSEiIiJHcGlwmzFjBnJzc7FkyRJkZWWhX79+2LRpkzxh4fLly3YtO6JUKnHixAl89NFHKCoqQkREBG688Ua8+OKL7a4r9FqKKizBzY8byxMREbUbgihKcw5JUlJSAl9fXxQXF8PHx8fVzbGb2Swi/tmfIIrAgWcnIMRb6+omERERUQPsyR2cZtgOlVYZ5SVAfN1ZcSMiImovGNzaoaJKy8QED7USGrf6164jIiKitofBrR2Sxrex2kZERNS+MLi1Q9IWVwxuRERE7QuDWzskLQXCGaVERETtC4NbO1RsXXzXz517kxIREbUnDG7tEMe4ERERtU8Mbu0Qu0qJiIjaJwa3dkienMDgRkRE1K4wuLVD7ColIiJqnxjc2qHiSk5OICIiao8Y3NohjnEjIiJqnxjc2iF2lRIREbVPDG7tEHdOICIiap8Y3NqZKoMJeqMZALtKiYiI2hsGt3ZG6iZVKgR4adxc3BoiIiJyJAa3dqbIOqPU110FQRBc3BoiIiJyJAa3dkaquPlxfBsREVG7w+DWzhRz1wQiIqJ2i8GtnSlmxY2IiKjdYnBrZ2qOcSMiIqL2hcGtnaneNYHbXREREbU3DG7tDHdNICIiar8Y3NoZ7ppARETUfjG4tTPy5ATOKiUiImp3GNzameoxbgxuRERE7Q2DWzvDWaVERETtF4NbO1M9OYGzSomIiNobBrd2xGQWUVplBMCuUiIiovaIwa0dKbGObwPYVUpERNQeMbi1I9JSIJ5qJVRKvrRERETtDT/d25G8Mh0AIMCL49uIiIjaIwa3diSzuAoAEO7j7uKWEBERkTMwuLUj2dbgFuardXFLiIiIyBkY3NqRTAY3IiKido3BrR3JLrEGNx8GNyIiovaIwa0dySyuBMCKGxERUXvF4NaOZJdYZpUyuBEREbVPDG7thNkssquUiIionWNwayfyynUwmkUoBCDYW+Pq5hAREZETMLi1E1nWGaVBXhrumkBERNRO8RO+nZCCWzjHtxEREbVbDG7tRJZ1fFsox7cRERG1Wwxu7QQrbkRERO0fg5uLFVcY5M3h7fXv3y/i++MZAGpU3BjciIiI2i03VzegIxNFEbe89TvKdEbsWzwBWpWyyfe9kFOKl348CzeFgHHdgllxIyIi6gAY3FxIZzQjvdCy20FxpcGu4JacXQYAMJpF7L6QzzFuREREHQC7Sl2oQm+Sv9cZzHbdNyW3TP5+x/mcGhU3d8c0joiIiFodBjcXqjTUCG5GUyNn1pWSWy5/v/l0thwCuWsCERFR+8Xg5kKVeqP8vc54/RW3gnI9AMBH6wZ3ddO7W4mIiKhtYXBzIZuuUjsqbqIoIiXHEtwi/au7RtlNSkRE1L4xuLnQ9Y5xyy7RoVxvglIh4N4/RMvHuRQIERFR+8bg5kKVNhW3pge3i9Zu0s4BHrihZ6h8PJzj24iIiNo1BjcXut7JCdL4tvhgT8QFeSIqwNJFyoobERFR+8bg5kIV11lxk2aUxgd7QRAEzBzcGQAwskuQYxtIRERErQoX4HWh651VWl1x8wIA/GlsPOaOiOWMUiIionaOFTcXuu6Km3VGaXyIJwBAEASGNiIiog6Awc2FbMa4GZo2xq1cZ0SGdZeEuCAvp7SLiIiIWicGNxe6nlmlqXmW8W2Bnmr4e6qd0i4iIiJqnRjcXOh6ukprj28jIiKijoPBzYWuZ+cEeUapdXwbERERdRwMbi5UZbB/5wSpqzQ2iMGNiIioo2Fwc6GK61gO5HK+JbhFBzK4ERERdTQMbi5Us6tU39TgVlABwLLdFREREXUsDG4uZO+WVyVVBhRWGAAwuBEREXVEDG4uZO+s0sv5lmpbkJcanhpuekFERNTRMLi5kL3ruF2xdpNGsdpGRETUITG4uZC9Oydcsga3aAY3IiKiDonBzYXsnVXKiQlEREQdG4Obi5jNIqpqrN1mT1dpZy4FQkRE1CExuLlIVa1ZpE2ZVXopnxU3IiKijozBzUVqzigFrr2Om9FkxtWiSgAMbkRERB2Vy4PbO++8g5iYGGi1WgwdOhQHDhxo0v02bNgAQRAwffp0m+OiKGLJkiUIDw+Hu7s7Jk6ciOTkZCe0vHkq9bUrbo0Ht4yiKpjMIjRuCoR4a5zZNCIiImqlXBrcNm7ciEWLFmHp0qU4cuQI+vbti0mTJiEnJ6fR+6WlpeHJJ5/EqFGj6tz22muv4Z///CfWrFmD/fv3w9PTE5MmTUJVVZWzLuO61K64XWtW6eUaS4EoFILT2kVEREStl0uD28qVK/Hggw9izpw56NmzJ9asWQMPDw+sXbu2wfuYTCbcc889WLZsGeLi4mxuE0URq1evxnPPPYdp06ahT58++Pjjj5GRkYFvv/3WyVdjH2kpECmDXavixhmlRERE5LLgptfrcfjwYUycOLG6MQoFJk6ciL179zZ4v+XLlyMkJATz5s2rc1tqaiqysrJsHtPX1xdDhw5t9DF1Oh1KSkpsvpxNWgrE111laYPRDFEUGzz/UoFlc3kGNyIioo7LZcEtLy8PJpMJoaGhNsdDQ0ORlZVV73127dqFDz/8EB988EG9t0v3s+cxAWDFihXw9fWVv6Kiouy5lOsijXHz91DLx/SmhqtuV1hxIyIi6vBcPjmhqUpLS3Hffffhgw8+QFBQkEMfe/HixSguLpa/rly54tDHr480xs3XQyUfa6y7VFoKJDqQwY2IiKijctlO5UFBQVAqlcjOzrY5np2djbCwsDrnp6SkIC0tDVOmTJGPmc2WoOPm5oakpCT5ftnZ2QgPD7d5zH79+jXYFo1GA42mZWdqShU3qasUAHQGM6Cte64oivIG86y4ERERdVwuq7ip1WoMHDgQW7dulY+ZzWZs3boVw4YNq3N+9+7dcfLkSRw7dkz+mjp1KsaNG4djx44hKioKsbGxCAsLs3nMkpIS7N+/v97HdCVpcoKn2g0aN8vL0NAivCWVRpTqLGPiIv0Z3IiIiDoql1XcAGDRokW4//77MWjQIAwZMgSrV69GeXk55syZAwCYPXs2OnXqhBUrVkCr1aJ379429/fz8wMAm+OPP/44XnrpJSQkJCA2NhbPP/88IiIi6qz35mpSV6m7Wgm1mwI6o7nBRXhzyyxLmfi6q+CuVrZYG4mIiKh1cWlwmzFjBnJzc7FkyRJkZWWhX79+2LRpkzy54PLly1Ao7CsKPv300ygvL8dDDz2EoqIijBw5Eps2bYJWW08fpAtVWmeVuquU0LgpUQpjg2Pc8sv0AIBAT3W9txMREVHH4NLgBgALFy7EwoUL671t+/btjd53/fr1dY4JgoDly5dj+fLlDmid80gVNw+1skZXaf3BraDcEtwCGNyIiIg6tDYzq7S9kca4uauV0Kiswa2B3RPyGNyIiIgIDG4uU2lTcbOMW2uw4iZ1lXoxuBEREXVkDG4uIk9OUDWlq1QHAAj05ObyREREHRmDm4tUyF2l114OJJ9dpURERAQGN5epqtlVqrJ2lRquMauUXaVEREQdGoObi1QYrMuBcFYpERERNRGDm4vUHOOmtgY3PbtKiYiIqBEMbi5S2cR13MxmEYUVluAW5MXJCURERB0Zg5uLVDRxOZCSKgNMZhEA4O/BihsREVFHxuDmIpVNnFWaZ52Y4K11k7tUiYiIqGNiEnABk1mUN5R3V9XcOaFuxU2amMB9SomIiIjBzQUqrBvMA9fuKpUW3+XEBCIiImJwcwFpYoIgABo3RaNdpdKM0kBOTCAiIurwGNxcQBrf5qFSQhCERmeVyovvsuJGRETU4TG4uYC8hpvaDQDknRP09XaVcg03IiIismBwc4Hq4Gb59WuUjVTcGNyIiIjIisHNBeTFd1VSxa3hMW7S5ATuU0pEREQMbi5QvYabpYtUHuNWz3Ig1WPcODmBiIioo2NwcwFpORAPObg1vBwIu0qJiIhIwuDmApU1NpgH0OByIKIoolBeDoTBjYiIqKNjcHOB6skJ1uCmqn9yQkmlEUbrPqWsuBERERGDmwvI67jV7iqtNcYt3zoxwUvjJp9DREREHReDmwsEeanRN8oP0YGeABruKs1nNykRERHV4ObqBnREMwZ3xozBneWfpWpa7QV4pRml7CYlIiIigBW3VkHdwJZX0q4J3O6KiIiIAAa3VkHqKjWaRRhN1eFNWnyXFTciIiICGNxaBWlWKQDoawS37BJp1wQuvktEREQMbq2CWln9MtScWXrsShEAoEe4T0s3iYiIiFohTk5oBdyUCrgpBBjNojzOrVxnxJnMEgDAwGh/VzaPiIhaEZPJBIPB4OpmkJ1UKhWUyuYv7cXg1kpo3BQw6k3ykiDH04tgMosI99Wik5+7i1tHREStQVlZGdLT0yGKoqubQnYSBAGRkZHw8vJq1uMwuLUSGpUS5XqTXHE7nFYIgNU2IiKyMJlMSE9Ph4eHB4KDgyEIgqubRE0kiiJyc3ORnp6OhISEZlXeGNxaCWlmqbSW26FLluA2iMGNiIgAGAwGiKKI4OBguLuzJ6atCQ4ORlpaGgwGQ7OCGycntBI1d08wm0UcuSxV3AJc2SwiImplWGlrmxz1ujG4tRLyIrwGM5JzylBaZYSHWoke4d4ubhkRERG1FgxurYS80bzRjEOXCgAA/aL84KbkS0REREQWTAWtRM2u0sMc30ZERET1YHBrJaTdE3RGsxzcBjC4ERERUQ0Mbq2E1FV6Mr0Yl/IroBCA/p0Z3IiIiBytLS9gzODWSkhdpZ8duAwAmNQrDL7uKlc2iYiIWjFRFFGhN7rky94FgDdt2oSRI0fCz88PgYGBuPXWW5GSkiLfnp6ejlmzZiEgIACenp4YNGgQ9u/fL9/+v//9D4MHD4ZWq0VQUBBuu+02+TZBEPDtt9/aPJ+fnx/Wr18PAEhLS4MgCNi4cSPGjBkDrVaL//73v8jPz8esWbPQqVMneHh4IDExEZ999pnN45jNZrz22mvo0qULNBoNOnfujJdffhkAMH78eCxcuNDm/NzcXKjVamzdutWu3489uI5bKyEFt3K9ZeeE+4fHuLA1RETU2lUaTOi5ZLNLnvvM8knwUDc9QpSXl2PRokXo06cPysrKsGTJEtx22204duwYKioqMGbMGHTq1Anff/89wsLCcOTIEZjNlnVNf/zxR9x222149tln8fHHH0Ov1+Onn36yu81//etf8cYbb6B///7QarWoqqrCwIED8cwzz8DHxwc//vgj7rvvPsTHx2PIkCEAgMWLF+ODDz7AqlWrMHLkSGRmZuLcuXMAgPnz52PhwoV44403oNFoAACffPIJOnXqhPHjx9vdvqZicGslpK5SAOge5o2hsVy/jYiI2oc77rjD5ue1a9ciODgYZ86cwZ49e5Cbm4uDBw8iIMDy2delSxf53JdffhkzZ87EsmXL5GN9+/a1uw2PP/44br/9dptjTz75pPz9o48+is2bN+Pzzz/HkCFDUFpaijfffBNvv/027r//fgBAfHw8Ro4cCQC4/fbbsXDhQnz33Xe46667AADr16/HAw884NS19hjcWglpcgIAzBkRwwUWiYioUe4qJc4sn+Sy57ZHcnIylixZgv379yMvL0+upl2+fBnHjh1D//795dBW27Fjx/Dggw82u82DBg2y+dlkMuGVV17B559/jqtXr0Kv10On08HDwwMAcPbsWeh0OkyYMKHex9Nqtbjvvvuwdu1a3HXXXThy5AhOnTqF77//vtltbQyDWyuhtq7X5uehwrR+nVzcGiIiau0EQbCru9KVpkyZgujoaHzwwQeIiIiA2WxG7969odfrr7l917VuFwShzpi7+iYfeHp62vz8+uuv480338Tq1auRmJgIT09PPP7449Dr9U16XsDSXdqvXz+kp6dj3bp1GD9+PKKjo695v+bg5IRWomuoZYeEeSNiobXzfzJEREStVX5+PpKSkvDcc89hwoQJ6NGjBwoLC+Xb+/Tpg2PHjqGgoKDe+/fp06fRwf7BwcHIzMyUf05OTkZFRcU127V7925MmzYN9957L/r27Yu4uDicP39evj0hIQHu7u6NPndiYiIGDRqEDz74AJ9++inmzp17zedtrrYR1TuAPw6MxKAYf8QGeV77ZCIiojbC398fgYGBeP/99xEeHo7Lly/jr3/9q3z7rFmz8Morr2D69OlYsWIFwsPDcfToUURERGDYsGFYunQpJkyYgPj4eMycORNGoxE//fQTnnnmGQCW2Z1vv/02hg0bBpPJhGeeeQYq1bVXZUhISMCXX36JPXv2wN/fHytXrkR2djZ69uwJwNIV+swzz+Dpp5+GWq3GiBEjkJubi9OnT2PevHny40iTFDw9PW1muzoLK26thEIhIC7Yi2PbiIioXVEoFNiwYQMOHz6M3r174y9/+Qtef/11+Xa1Wo0tW7YgJCQEN998MxITE/Hqq69CqbT0Po0dOxZffPEFvv/+e/Tr1w/jx4/HgQMH5Pu/8cYbiIqKwqhRo3D33XfjySeflMepNea5557DgAEDMGnSJIwdOxZhYWGYPn26zTnPP/88nnjiCSxZsgQ9evTAjBkzkJOTY3POrFmz4ObmhlmzZkGr1TbjN9U0gmjvYiwdQElJCXx9fVFcXAwfHx9XN4eIiAhVVVVITU1FbGxsiwQEapq0tDTEx8fj4MGDGDBgQIPnNfb62ZM72FVKREREZCeDwYD8/Hw899xz+MMf/tBoaHMkdpUSERER2Wn37t0IDw/HwYMHsWbNmhZ7XlbciIiIiOw0duxYu7f+cgRW3IiIiIjaCAY3IiKiNoRzCtsmR71uDG5ERERtgLQ8hrSyP7Ut0usmvY7Xi2PciIiI2gA3Nzd4eHggNzcXKpUKCgVrL22F2WxGbm4uPDw84ObWvOjF4EZERNQGCIKA8PBwpKam4tKlS65uDtlJoVCgc+fOzV5on8GNiIiojVCr1UhISGB3aRukVqsdUiVlcCMiImpDFAoFd07owNhBTkRERNRGMLgRERERtREMbkRERERtBMe41UNaJK+kpMTFLSEiIqL2TsobTVmkl8GtHqWlpQCAqKgoF7eEiIiIOorS0lL4+vo2eo4gcu+MOsxmMzIyMuDt7d3s9VZqKikpQVRUFK5cuQIfHx+HPW5rx+vmdXcEvG5ed0fA63bOdYuiiNLSUkRERFxzyRBW3OqhUCgQGRnptMf38fHpUG94Ca+7Y+F1dyy87o6F1+1416q0STg5gYiIiKiNYHAjIiIiaiMY3FqQRqPB0qVLodFoXN2UFsXr5nV3BLxuXndHwOt2/XVzcgIRERFRG8GKGxEREVEbweBGRERE1EYwuBERERG1EQxuRERERG0Eg1sLeueddxATEwOtVouhQ4fiwIEDrm6Sw6xYsQKDBw+Gt7c3QkJCMH36dCQlJdmcM3bsWAiCYPP18MMPu6jFjvHCCy/Uuabu3bvLt1dVVWHBggUIDAyEl5cX7rjjDmRnZ7uwxY4RExNT57oFQcCCBQsAtJ/XeufOnZgyZQoiIiIgCAK+/fZbm9tFUcSSJUsQHh4Od3d3TJw4EcnJyTbnFBQU4J577oGPjw/8/Pwwb948lJWVteBV2K+x6zYYDHjmmWeQmJgIT09PREREYPbs2cjIyLB5jPreI6+++moLX4l9rvV6P/DAA3WuafLkyTbntLfXG0C9/9YFQcDrr78un9MWX++mfG415W/45cuXccstt8DDwwMhISF46qmnYDQandZuBrcWsnHjRixatAhLly7FkSNH0LdvX0yaNAk5OTmubppD7NixAwsWLMC+ffvwyy+/wGAw4MYbb0R5ebnNeQ8++CAyMzPlr9dee81FLXacXr162VzTrl275Nv+8pe/4H//+x+++OIL7NixAxkZGbj99ttd2FrHOHjwoM01//LLLwCAO++8Uz6nPbzW5eXl6Nu3L9555516b3/ttdfwz3/+E2vWrMH+/fvh6emJSZMmoaqqSj7nnnvuwenTp/HLL7/ghx9+wM6dO/HQQw+11CVcl8auu6KiAkeOHMHzzz+PI0eO4Ouvv0ZSUhKmTp1a59zly5fbvAceffTRlmj+dbvW6w0AkydPtrmmzz77zOb29vZ6A7C53szMTKxduxaCIOCOO+6wOa+tvd5N+dy61t9wk8mEW265BXq9Hnv27MFHH32E9evXY8mSJc5ruEgtYsiQIeKCBQvkn00mkxgRESGuWLHCha1ynpycHBGAuGPHDvnYmDFjxMcee8x1jXKCpUuXin379q33tqKiIlGlUolffPGFfOzs2bMiAHHv3r0t1MKW8dhjj4nx8fGi2WwWRbF9vtYAxG+++Ub+2Ww2i2FhYeLrr78uHysqKhI1Go342WefiaIoimfOnBEBiAcPHpTP+fnnn0VBEMSrV6+2WNubo/Z11+fAgQMiAPHSpUvysejoaHHVqlXObZwT1Xfd999/vzht2rQG79NRXu9p06aJ48ePtznW1l9vUaz7udWUv+E//fSTqFAoxKysLPmcd999V/Tx8RF1Op1T2smKWwvQ6/U4fPgwJk6cKB9TKBSYOHEi9u7d68KWOU9xcTEAICAgwOb4f//7XwQFBaF3795YvHgxKioqXNE8h0pOTkZERATi4uJwzz334PLlywCAw4cPw2Aw2Lzu3bt3R+fOndvV667X6/HJJ59g7ty5EARBPt4eX+uaUlNTkZWVZfP6+vr6YujQofLru3fvXvj5+WHQoEHyORMnToRCocD+/ftbvM3OUlxcDEEQ4OfnZ3P81VdfRWBgIPr374/XX3/dqd1HLWX79u0ICQlBt27d8MgjjyA/P1++rSO83tnZ2fjxxx8xb968Ore19de79udWU/6G7927F4mJiQgNDZXPmTRpEkpKSnD69GmntJObzLeAvLw8mEwmmxcWAEJDQ3Hu3DkXtcp5zGYzHn/8cYwYMQK9e/eWj999992Ijo5GREQETpw4gWeeeQZJSUn4+uuvXdja5hk6dCjWr1+Pbt26ITMzE8uWLcOoUaNw6tQpZGVlQa1W1/kwCw0NRVZWlmsa7ATffvstioqK8MADD8jH2uNrXZv0Gtb371q6LSsrCyEhITa3u7m5ISAgoN28B6qqqvDMM89g1qxZNptv//nPf8aAAQMQEBCAPXv2YPHixcjMzMTKlStd2NrmmTx5Mm6//XbExsYiJSUFf/vb33DTTTdh7969UCqVHeL1/uijj+Dt7V1nyEdbf73r+9xqyt/wrKysev8GSLc5A4MbOdyCBQtw6tQpm7FeAGzGeSQmJiI8PBwTJkxASkoK4uPjW7qZDnHTTTfJ3/fp0wdDhw5FdHQ0Pv/8c7i7u7uwZS3nww8/xE033YSIiAj5WHt8rakug8GAu+66C6Io4t1337W5bdGiRfL3ffr0gVqtxv/93/9hxYoVrWLboOsxc+ZM+fvExET06dMH8fHx2L59OyZMmODClrWctWvX4p577oFWq7U53tZf74Y+t1ojdpW2gKCgICiVyjozUbKzsxEWFuaiVjnHwoUL8cMPP2Dbtm2IjIxs9NyhQ4cCAC5cuNASTWsRfn5+6Nq1Ky5cuICwsDDo9XoUFRXZnNOeXvdLly7h119/xfz58xs9rz2+1tJr2Ni/67CwsDoTkIxGIwoKCtr8e0AKbZcuXcIvv/xiU22rz9ChQ2E0GpGWltYyDWwBcXFxCAoKkt/X7fn1BoDff/8dSUlJ1/z3DrSt17uhz62m/A0PCwur92+AdJszMLi1ALVajYEDB2Lr1q3yMbPZjK1bt2LYsGEubJnjiKKIhQsX4ptvvsFvv/2G2NjYa97n2LFjAIDw8HAnt67llJWVISUlBeHh4Rg4cCBUKpXN656UlITLly+3m9d93bp1CAkJwS233NLoee3xtY6NjUVYWJjN61tSUoL9+/fLr++wYcNQVFSEw4cPy+f89ttvMJvNcphti6TQlpycjF9//RWBgYHXvM+xY8egUCjqdCW2Zenp6cjPz5ff1+319ZZ8+OGHGDhwIPr27XvNc9vC632tz62m/A0fNmwYTp48aRPYpf/I9OzZ02kNpxawYcMGUaPRiOvXrxfPnDkjPvTQQ6Kfn5/NTJS27JFHHhF9fX3F7du3i5mZmfJXRUWFKIqieOHCBXH58uXioUOHxNTUVPG7774T4+LixNGjR7u45c3zxBNPiNu3bxdTU1PF3bt3ixMnThSDgoLEnJwcURRF8eGHHxY7d+4s/vbbb+KhQ4fEYcOGicOGDXNxqx3DZDKJnTt3Fp955hmb4+3ptS4tLRWPHj0qHj16VAQgrly5Ujx69Kg8e/LVV18V/fz8xO+++048ceKEOG3aNDE2NlasrKyUH2Py5Mli//79xf3794u7du0SExISxFmzZrnqkpqksevW6/Xi1KlTxcjISPHYsWM2/96lWXR79uwRV61aJR47dkxMSUkRP/nkEzE4OFicPXu2i6+scY1dd2lpqfjkk0+Ke/fuFVNTU8Vff/1VHDBggJiQkCBWVVXJj9HeXm9JcXGx6OHhIb777rt17t9WX+9rfW6J4rX/hhuNRrF3797ijTfeKB47dkzctGmTGBwcLC5evNhp7WZwa0FvvfWW2LlzZ1GtVotDhgwR9+3b5+omOQyAer/WrVsniqIoXr58WRw9erQYEBAgajQasUuXLuJTTz0lFhcXu7bhzTRjxgwxPDxcVKvVYqdOncQZM2aIFy5ckG+vrKwU//SnP4n+/v6ih4eHeNttt4mZmZkubLHjbN68WQQgJiUl2RxvT6/1tm3b6n1f33///aIoWpYEef7558XQ0FBRo9GIEyZMqPP7yM/PF2fNmiV6eXmJPj4+4pw5c8TS0lIXXE3TNXbdqampDf5737ZtmyiKonj48GFx6NChoq+vr6jVasUePXqIr7zyik3AaY0au+6KigrxxhtvFIODg0WVSiVGR0eLDz74YJ3/fLe311vy3nvvie7u7mJRUVGd+7fV1/tan1ui2LS/4WlpaeJNN90kuru7i0FBQeITTzwhGgwGp7VbsDaeiIiIiFo5jnEjIiIiaiMY3IiIiIjaCAY3IiIiojaCwY2IiIiojWBwIyIiImojGNyIiIiI2ggGNyIiIqI2gsGNiIiIqI1gcCMicpK0tDQIgiDv1UpE1FwMbkTUoWVlZeHRRx9FXFwcNBoNoqKiMGXKFJuNpYmIWgs3VzeAiMhV0tLSMGLECPj5+eH1119HYmIiDAYDNm/ejAULFuDcuXOubiIRkQ1W3Iiow/rTn/4EQRBw4MAB3HHHHejatSt69eqFRYsWYd++fZg7dy5uvfVWm/sYDAaEhITgww8/BACYzWa89tpr6NKlCzQaDTp37oyXX365wec8deoUbrrpJnh5eSE0NBT33Xcf8vLy5Nu//PJLJCYmwt3dHYGBgZg4cSLKy8ud8wsgojaHwY2IOqSCggJs2rQJCxYsgKenZ53b/fz8MH/+fGzatAmZmZny8R9++AEVFRWYMWMGAGDx4sV49dVX8fzzz+PMmTP49NNPERoaWu9zFhUVYfz48ejfvz8OHTqETZs2ITs7G3fddRcAIDMzE7NmzcLcuXNx9uxZbN++HbfffjtEUXTCb4CI2iJB5F8EIuqADhw4gKFDh+Lrr7/Gbbfd1uB5vXr1wv3334+nn34aADB16lQEBgZi3bp1KC0tRXBwMN5++23Mnz+/zn3T0tIQGxuLo0ePol+/fnjppZfw+++/Y/PmzfI56enpiIqKQlJSEsrKyjBw4ECkpaUhOjra8RdNRG0eK25E1CE19f+s8+fPx7p16wAA2dnZ+PnnnzF37lwAwNmzZ6HT6TBhwoQmPdbx48exbds2eHl5yV/du3cHAKSkpKBv376YMGECEhMTceedd+KDDz5AYWHhdVwdEbVXDG5E1CElJCRAEIRrTkCYPXs2Ll68iL179+KTTz5BbGwsRo0aBQBwd3e36znLysowZcoUHDt2zOYrOTkZo0ePhlKpxC+//IKff/4ZPXv2xFtvvYVu3bohNTX1uq+TiNoXBjci6pACAgIwadIkvPPOO/UO/i8qKgIABAYGYvr06Vi3bh3Wr1+POXPmyOckJCTA3d29yUuHDBgwAKdPn0ZMTAy6dOli8yWNsxMEASNGjMCyZctw9OhRqNVqfPPNN82/YCJqFxjciKjDeuedd2AymTBkyBB89dVXSE5OxtmzZ/HPf/4Tw4YNk8+bP38+PvroI5w9exb333+/fFyr1eKZZ57B008/jY8//hgpKSnYt2+fPOO0tgULFqCgoACzZs3CwYMHkZKSgs2bN2POnDkwmUzYv38/XnnlFRw6dAiXL1/G119/jdzcXPTo0cPpvwsiahu4jhsRdVhxcXE4cuQIXn75ZTzxxBPIzMxEcHAwBg4ciHfffVc+b+LEiQgPD0evXr0QERFh8xjPP/883NzcsGTJEmRkZCA8PBwPP/xwvc8XERGB3bt345lnnsGNN94InU6H6OhoTJ48GQqFAj4+Pti5cydWr16NkpISREdH44033sBNN93k1N8DEbUdnFVKRHQNZWVl6NSpE9atW4fbb7/d1c0hog6MFTciogaYzWbk5eXhjTfegJ+fH6ZOnerqJhFRB8fgRkTUgMuXLyM2NhaRkZFYv3493Nz4J5OIXItdpURERERtBGeVEhEREbURDG5EREREbQSDGxEREVEbweBGRERE1EYwuBERERG1EQxuRERERG0EgxsRERFRG8HgRkRERNRG/D9XNE58H9WnMAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "bed888fc-aa73-4099-bf63-3d89231b44c0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.38289999999999996}, {'accuracy': 0.41836}, {'accuracy': 0.3699800000000001}, {'accuracy': 0.37346}, {'accuracy': 0.37995999999999996}, {'accuracy': 0.39796}, {'accuracy': 0.4090599999999999}, {'accuracy': 0.41861999999999994}, {'accuracy': 0.41335999999999995}, {'accuracy': 0.42723999999999995}, {'accuracy': 0.44878}, {'accuracy': 0.44867999999999997}, {'accuracy': 0.4677599999999999}, {'accuracy': 0.4829800000000001}, {'accuracy': 0.4698399999999999}, {'accuracy': 0.4944400000000001}, {'accuracy': 0.4782}, {'accuracy': 0.4607}, {'accuracy': 0.4949}, {'accuracy': 0.48928000000000005}, {'accuracy': 0.49632}, {'accuracy': 0.5057799999999999}, {'accuracy': 0.5027999999999999}, {'accuracy': 0.5113399999999999}, {'accuracy': 0.49601999999999996}, {'accuracy': 0.5024799999999999}, {'accuracy': 0.5255000000000001}, {'accuracy': 0.49216}, {'accuracy': 0.54438}, {'accuracy': 0.5475199999999999}, {'accuracy': 0.5337}, {'accuracy': 0.54138}, {'accuracy': 0.55514}, {'accuracy': 0.5385000000000001}, {'accuracy': 0.53148}, {'accuracy': 0.5292}, {'accuracy': 0.50368}, {'accuracy': 0.5356799999999999}, {'accuracy': 0.5563800000000001}, {'accuracy': 0.55048}, {'accuracy': 0.5579400000000001}, {'accuracy': 0.55308}, {'accuracy': 0.55914}, {'accuracy': 0.55278}, {'accuracy': 0.55352}, {'accuracy': 0.55242}, {'accuracy': 0.5595}, {'accuracy': 0.5581200000000001}, {'accuracy': 0.55878}, {'accuracy': 0.55592}, {'accuracy': 0.55852}, {'accuracy': 0.5541399999999999}, {'accuracy': 0.55396}, {'accuracy': 0.5523799999999999}, {'accuracy': 0.55278}, {'accuracy': 0.55032}, {'accuracy': 0.55166}, {'accuracy': 0.5520600000000001}, {'accuracy': 0.55124}, {'accuracy': 0.55158}, {'accuracy': 0.55408}, {'accuracy': 0.55394}, {'accuracy': 0.5506800000000001}, {'accuracy': 0.5518000000000001}, {'accuracy': 0.5514}, {'accuracy': 0.5516599999999999}, {'accuracy': 0.5534399999999999}, {'accuracy': 0.5516399999999999}, {'accuracy': 0.55188}, {'accuracy': 0.5598000000000001}, {'accuracy': 0.5502599999999999}, {'accuracy': 0.5530999999999998}, {'accuracy': 0.55854}, {'accuracy': 0.5500200000000001}, {'accuracy': 0.55108}, {'accuracy': 0.55342}, {'accuracy': 0.5519799999999999}, {'accuracy': 0.55904}, {'accuracy': 0.5503}, {'accuracy': 0.55044}, {'accuracy': 0.55968}, {'accuracy': 0.5502}, {'accuracy': 0.5595600000000001}, {'accuracy': 0.5590200000000001}, {'accuracy': 0.5594}, {'accuracy': 0.55842}, {'accuracy': 0.55986}, {'accuracy': 0.55068}, {'accuracy': 0.55824}, {'accuracy': 0.5564800000000001}, {'accuracy': 0.55766}, {'accuracy': 0.55698}, {'accuracy': 0.5575600000000001}, {'accuracy': 0.55562}, {'accuracy': 0.54266}, {'accuracy': 0.5503}, {'accuracy': 0.55016}, {'accuracy': 0.5548599999999999}, {'accuracy': 0.5504800000000001}, {'accuracy': 0.55944}, {'accuracy': 0.50456}, {'accuracy': 0.53544}, {'accuracy': 0.5642400000000001}, {'accuracy': 0.57888}, {'accuracy': 0.5767000000000001}, {'accuracy': 0.57692}, {'accuracy': 0.58052}, {'accuracy': 0.57684}, {'accuracy': 0.5702599999999999}, {'accuracy': 0.57757}, {'accuracy': 0.57358}, {'accuracy': 0.5761400000000001}, {'accuracy': 0.57348}, {'accuracy': 0.57336}, {'accuracy': 0.5727399999999999}, {'accuracy': 0.5757000000000001}, {'accuracy': 0.5766}, {'accuracy': 0.57146}, {'accuracy': 0.5714}, {'accuracy': 0.5706}, {'accuracy': 0.57174}, {'accuracy': 0.5769600000000001}, {'accuracy': 0.57174}, {'accuracy': 0.57376}, {'accuracy': 0.57324}, {'accuracy': 0.5772200000000001}, {'accuracy': 0.57062}, {'accuracy': 0.5706800000000001}, {'accuracy': 0.5798000000000001}, {'accuracy': 0.5772599999999999}, {'accuracy': 0.57804}, {'accuracy': 0.57708}, {'accuracy': 0.57782}, {'accuracy': 0.57814}, {'accuracy': 0.577}, {'accuracy': 0.57692}, {'accuracy': 0.57792}, {'accuracy': 0.57872}, {'accuracy': 0.57698}, {'accuracy': 0.5790799999999999}, {'accuracy': 0.57574}, {'accuracy': 0.57028}, {'accuracy': 0.57126}, {'accuracy': 0.57646}, {'accuracy': 0.5769}, {'accuracy': 0.5706399999999999}, {'accuracy': 0.5718799999999999}, {'accuracy': 0.5701599999999999}, {'accuracy': 0.5788599999999999}, {'accuracy': 0.57878}, {'accuracy': 0.57772}, {'accuracy': 0.5775000000000001}, {'accuracy': 0.5779799999999999}, {'accuracy': 0.5769599999999999}, {'accuracy': 0.5761}, {'accuracy': 0.56738}, {'accuracy': 0.5729600000000001}, {'accuracy': 0.5712}, {'accuracy': 0.5781}, {'accuracy': 0.5753999999999999}, {'accuracy': 0.5769799999999999}, {'accuracy': 0.57196}, {'accuracy': 0.57326}, {'accuracy': 0.5736399999999999}, {'accuracy': 0.5712}, {'accuracy': 0.57162}, {'accuracy': 0.57814}, {'accuracy': 0.57536}, {'accuracy': 0.5785}, {'accuracy': 0.57982}, {'accuracy': 0.5788599999999999}, {'accuracy': 0.57878}, {'accuracy': 0.57772}, {'accuracy': 0.5775000000000001}, {'accuracy': 0.5779799999999999}, {'accuracy': 0.5769599999999999}, {'accuracy': 0.5761}, {'accuracy': 0.56738}, {'accuracy': 0.5729600000000001}, {'accuracy': 0.5712}, {'accuracy': 0.5781}, {'accuracy': 0.5753999999999999}, {'accuracy': 0.5769799999999999}, {'accuracy': 0.57196}, {'accuracy': 0.57326}, {'accuracy': 0.5736399999999999}, {'accuracy': 0.5712}, {'accuracy': 0.57162}, {'accuracy': 0.57814}, {'accuracy': 0.57536}, {'accuracy': 0.5785}, {'accuracy': 0.57982}, {'accuracy': 0.57337}, {'accuracy': 0.574138}, {'accuracy': 0.575514}, {'accuracy': 0.57385}, {'accuracy': 0.573148}, {'accuracy': 0.57292}, {'accuracy': 0.57720368}, {'accuracy': 0.5779568}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4812cafe-820d-4a3b-ba74-f3f93540c8b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e21bc33-430f-4bfa-afbc-5eb3470579a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36912f17-4767-42a6-968f-a32bd0727613",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "447c2b68-631d-454b-8a21-eb92bac3b8b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9312507a-3c9c-497c-9ad9-3cbd8c0bb170",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae572b25-cd48-4e51-9750-42aad45ad7ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aceb8a67-0126-4439-9ccc-ee6689c6b779",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "275f81cb-2a57-4007-944f-6c7630e2691b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c7e314d-0c8d-4486-8594-c25293cd2277",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
