{
 "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",
    "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.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 = 100\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": [
    "class Args:\n",
    "    def __init__(self):\n",
    "        self.dataset = 'cifar100'\n",
    "        self.noise_type = 'noisy100'\n",
    "        self.noise_path = None\n",
    "        self.is_human = True\n",
    "\n",
    "args = Args()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fb6d1fb3-90e4-4fe4-8ee1-daa73c3ffe32",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = ResNet18(100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "311792f2-7e67-40d3-b9dd-ec25f2eb7b19",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 100])\n"
     ]
    }
   ],
   "source": [
    "dummy_input = torch.randn(32,3, 32, 32)  # Batch size of 32\n",
    "output = model(dummy_input)\n",
    "print(output.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3009e343-a6c5-4a92-9f2c-0bc221b820ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Loaded noisy_label from ./data/CIFAR-100_human.pt.\n",
      "The overall noise rate is 0.402\n",
      "noisy labels loaded from noisy_label\n",
      "The noisy data ratio in each class is [0.01144 0.01222 0.00968 0.01362 0.00598 0.00944 0.00882 0.01198 0.0088\n",
      " 0.01128 0.00816 0.01028 0.00616 0.01088 0.00916 0.00826 0.00784 0.0103\n",
      " 0.00826 0.01016 0.01318 0.01144 0.0089  0.01488 0.00946 0.00782 0.00916\n",
      " 0.00772 0.00926 0.0067  0.01246 0.00978 0.01132 0.01464 0.01274 0.00902\n",
      " 0.01622 0.0134  0.00694 0.0095  0.00992 0.01118 0.00698 0.01108 0.01002\n",
      " 0.0044  0.0173  0.0055  0.01018 0.01158 0.01464 0.00928 0.01316 0.01068\n",
      " 0.00938 0.01356 0.0097  0.00876 0.01324 0.00682 0.01128 0.01138 0.01206\n",
      " 0.00398 0.00942 0.0091  0.01098 0.00722 0.01    0.01346 0.0108  0.01202\n",
      " 0.00732 0.01002 0.00756 0.00624 0.00884 0.00886 0.01126 0.00782 0.00902\n",
      " 0.005   0.01162 0.00904 0.00952 0.01446 0.01016 0.008   0.0094  0.013\n",
      " 0.00864 0.00848 0.00866 0.00992 0.00918 0.01016 0.00966 0.01016 0.01238\n",
      " 0.0093 ]\n",
      "over all noise rate is  0.402\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Seed\n",
    "torch.manual_seed(42)\n",
    "torch.cuda.manual_seed(42)\n",
    "\n",
    "# Hyper Parameters\n",
    "batch_size = 16\n",
    "learning_rate = 0.001\n",
    "noise_type_map = {'clean':'clean_label', 'worst': 'worse_label', 'aggre': 'aggre_label', 'rand1': 'random_label1', 'rand2': 'random_label2', 'rand3': 'random_label3', 'clean100': 'clean_label', 'noisy100': 'noisy_label'}\n",
    "args.noise_type = noise_type_map[args.noise_type]\n",
    "# load dataset\n",
    "if args.noise_path is None:\n",
    "    if args.dataset == 'cifar10':\n",
    "        args.noise_path = '.\"your path\"/CIFAR-10_human.pt'\n",
    "    elif args.dataset == 'cifar100':\n",
    "        args.noise_path = '.\"your path\"/CIFAR-100_human.pt'\n",
    "    else: \n",
    "        raise NameError(f'Undefined dataset {args.dataset}')\n",
    "\n",
    "# args.noise_path = './data/CIFAR-100_human.pt'\n",
    "train_dataset,test_dataset,num_classes,num_training_samples = input_dataset(args.dataset,args.noise_type, args.noise_path, args.is_human)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9dbaf964-41a4-4c51-811f-9dde142aedf8",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True, num_workers=2)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False, num_workers=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "529f2aa4-07f9-40f4-9254-fe3e653be984",
   "metadata": {},
   "outputs": [],
   "source": [
    "# train_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a624c3a3-a34c-4222-9a87-4f1153471283",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data1, train_targets1 = [], []\n",
    "for batch in train_loader:\n",
    "    images, labels = batch\n",
    "    train_data1.append(images)\n",
    "    train_targets1.append(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9bd080c9-df1a-4777-a132-7eb43fd0f6ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = torch.cat(train_data1, dim=0)\n",
    "train_targets = torch.cat(train_targets1, dim=0)\n",
    "\n",
    "test_data1, test_targets1 = [], []\n",
    "for batch in test_loader:\n",
    "    images, labels = batch\n",
    "    test_data1.append(images)\n",
    "    test_targets1.append(labels)\n",
    "\n",
    "test_data = torch.cat(test_data1, dim=0)\n",
    "test_targets = torch.cat(test_targets1, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a0f72684-6656-489b-81c4-3925cd50135f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# test_data[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "68493130-c3a3-4e0b-a860-83a39141e48c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# train_data = torch.load('CIFAR100train_data.pt')\n",
    "# train_targets = torch.load('CIFAR100train_targets.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "4325cdfe-398a-4c77-bce8-15f202a5ff0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# test_data = torch.load('CIFAR100test_data.pt')\n",
    "# test_targets = torch.load('CIFAR100test_targets.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "87d7a05d-0110-4858-a5df-6aa81b177e8e",
   "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 = 100\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": 16,
   "id": "141547d5-271d-4acd-8be9-eb2f33a9f9a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "dataset = TensorDataset(test_data, test_targets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "254a4610-304b-402d-b081-642c113e048c",
   "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": 18,
   "id": "394b4bfc-3f95-4760-9586-3051f012aa97",
   "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": 20,
   "id": "f12bab92-1044-4baf-8f75-c649576df04c",
   "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": null,
   "id": "4b547e59-5530-4847-abe1-a4ec9fa5dd3a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1744b0d5-0fb8-47d5-9528-550f9f3c26e5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=5, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(5),\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= 3),\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=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "26f21b95-1788-47fe-ad79-3eafeb6ae26e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm4AAAHWCAYAAADO2QWWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAClQ0lEQVR4nOzdd3hUdfY/8Pf09B5SIBB6b9JEERBQdF17QezYfhZ2ddFV+VpQRMHOurri6tpdwa5rQRQBG0Wa9N5LOunJ1Pv7Y+beuffOnZZMMhPyfj0Pj8nMZObemcg9nPM556MTBEEAEREREcU8fbQPgIiIiIhCw8CNiIiIqI1g4EZERETURjBwIyIiImojGLgRERERtREM3IiIiIjaCAZuRERERG0EAzciIiKiNoKBGxEREVEbwcCNiE5aBw4cgE6nw1tvvSXd9uijj0Kn00XvoE4ib731FnQ6HQ4cOBDtQyFqNxi4ERFp+O9//4v58+e36GscO3YMjz76KDZu3Niir9Oa/vWvfykCZSKKLAZuREQaWitwe+yxxxi4EVHIGLgRUZvR2NgIl8sV7cOIKXV1ddE+BCJqRQzciCioDRs24Nxzz0VKSgqSkpIwceJErFq1Srp/7dq10Ol0ePvtt31+9rvvvoNOp8NXX30l3Xb06FHceOONyMnJgcViQf/+/fHGG28ofm758uXQ6XRYuHAhHnroIXTs2BEJCQmorq5GRUUF7r33XgwcOBBJSUlISUnBueeeiz/++CMi5zt+/Hh8/fXXOHjwIHQ6HXQ6HQoLC6X7rVYrZs2ahR49esBisaCgoAD33XcfrFar4nm+//57jBkzBmlpaUhKSkLv3r3xf//3f9L5jRgxAgAwbdo06XUCZavE9Xnbtm3DVVddhfT0dIwZM0a6/7333sOwYcMQHx+PjIwMXHnllTh8+LDiOXbv3o1LL70Uubm5iIuLQ6dOnXDllVeiqqoKgPa6QJFOp8Ojjz7q9/gKCwuxdetWrFixQjqf8ePHAwDsdjsee+wx9OzZE3FxccjMzMSYMWPw/fff+30+IvJljPYBEFFs27p1K8444wykpKTgvvvug8lkwquvvorx48djxYoVGDVqFIYPH45u3brhww8/xPXXX6/4+UWLFiE9PR2TJ08GABQXF+PUU0+FTqfD9OnTkZ2djW+//RY33XQTqqurcffddyt+/vHHH4fZbMa9994Lq9UKs9mMbdu24fPPP8fll1+Orl27ori4GK+++irGjRuHbdu2IT8/v1nn/OCDD6KqqgpHjhzBCy+8AABISkoCALhcLlxwwQX45ZdfcOutt6Jv377YvHkzXnjhBezatQuff/659L79+c9/xqBBgzB79mxYLBbs2bMHv/76KwCgb9++mD17Nh555BHceuutOOOMMwAAp512WtDju/zyy9GzZ088+eSTEAQBAPDEE0/g4YcfxhVXXIGbb74ZpaWl+Oc//4mxY8diw4YNSEtLg81mw+TJk2G1WvGXv/wFubm5OHr0KL766itUVlYiNTW1We/b/Pnz8Ze//AVJSUl48MEHAQA5OTkA3EHn3LlzcfPNN2PkyJGorq7G2rVrsX79epx11lnNel2idkUgIgrgoosuEsxms7B3717ptmPHjgnJycnC2LFjpdtmzpwpmEwmoaKiQrrNarUKaWlpwo033ijddtNNNwl5eXlCWVmZ4nWuvPJKITU1VaivrxcEQRCWLVsmABC6desm3SZqbGwUnE6n4rb9+/cLFotFmD17tuI2AMKbb74p3TZr1iwhlL/6zjvvPKFLly4+t7/77ruCXq8Xfv75Z8XtCxYsEAAIv/76qyAIgvDCCy8IAITS0lK/r/H777/7HF8g4rFPnTpVcfuBAwcEg8EgPPHEE4rbN2/eLBiNRun2DRs2CACEjz76yO9raL1nIgDCrFmzpO/ffPNNAYCwf/9+6bb+/fsL48aN8/nZwYMHC+edd17wkySigFgqJSK/nE4nlixZgosuugjdunWTbs/Ly8NVV12FX375BdXV1QCAKVOmwG6349NPP5Uet2TJElRWVmLKlCkAAEEQ8Mknn+D888+HIAgoKyuT/kyePBlVVVVYv3694hiuv/56xMfHK26zWCzQ6/XSMZaXl0ulSPXPR9pHH32Evn37ok+fPorjnzBhAgBg2bJlAIC0tDQAwBdffBHxdXm33Xab4vtPP/0ULpcLV1xxheKYcnNz0bNnT+mYxIzad999h/r6+ogeUzBpaWnYunUrdu/e3aqvS3SyYeBGRH6Vlpaivr4evXv39rmvb9++cLlc0hqqwYMHo0+fPli0aJH0mEWLFiErK0sKakpLS1FZWYl///vfyM7OVvyZNm0aAKCkpETxOl27dvV5bZfLhRdeeAE9e/aExWJBVlYWsrOzsWnTJmmtVkvZvXs3tm7d6nP8vXr1Uhz/lClTcPrpp+Pmm29GTk4OrrzySnz44YcRCeLU78nu3bshCAJ69uzpc1zbt2+Xjqlr166YMWMGXn/9dWRlZWHy5Ml4+eWXW/w9A4DZs2ejsrISvXr1wsCBA/H3v/8dmzZtavHXJTrZcI0bEUXMlClT8MQTT6CsrAzJycn48ssvMXXqVBiN7r9qxKDlmmuu8VkLJxo0aJDie3W2DQCefPJJPPzww7jxxhvx+OOPIyMjA3q9HnfffXeLd526XC4MHDgQzz//vOb9BQUF0nH/9NNPWLZsGb7++mssXrwYixYtwoQJE7BkyRIYDIYmH4P6PXG5XNDpdPj22281n1dcnwcAzz33HG644QZ88cUXWLJkCf76179i7ty5WLVqFTp16uR3OLHT6Wzy8QLA2LFjsXfvXul1X3/9dbzwwgtYsGABbr755mY9N1F7wsCNiPzKzs5GQkICdu7c6XPfjh07oNfrpUAFcAdujz32GD755BPk5OSguroaV155peL5kpOT4XQ6MWnSpCYf18cff4wzzzwT//nPfxS3V1ZWIisrq8nPK+cvgOnevTv++OMPTJw4MegODHq9HhMnTsTEiRPx/PPP48knn8SDDz6IZcuWYdKkSRHbwaF79+4QBAFdu3aVMn+BDBw4EAMHDsRDDz2E3377DaeffjoWLFiAOXPmID09HYD7vZQ7ePBgSMcS6JwyMjIwbdo0TJs2DbW1tRg7diweffRRBm5EYWCplIj8MhgMOPvss/HFF18otjUqLi7Gf//7X4wZMwYpKSnS7X379sXAgQOxaNEiLFq0CHl5eRg7dqzi+S699FJ88skn2LJli8/rlZaWhnxcgqebUvTRRx/h6NGjYZ6hf4mJiZolxCuuuAJHjx7Fa6+95nNfQ0ODNFetoqLC5/4hQ4YAgDQ2JDExEYBvkBSuSy65BAaDAY899pjP+yIIAsrLywEA1dXVcDgcivsHDhwIvV4vHVNKSgqysrLw008/KR73r3/9K6RjSUxM1Dwf8RhESUlJ6NGjh88IFSIKjBk3Igpozpw50jyyO+64A0ajEa+++iqsViuefvppn8dPmTIFjzzyCOLi4nDTTTdJTQSiefPmYdmyZRg1ahRuueUW9OvXDxUVFVi/fj1++OEHzYBH7c9//jNmz56NadOm4bTTTsPmzZvx/vvvKxoommvYsGFYtGgRZsyYgREjRiApKQnnn38+rr32Wnz44Ye47bbbsGzZMpx++ulwOp3YsWMHPvzwQ3z33XcYPnw4Zs+ejZ9++gnnnXceunTpgpKSEvzrX/9Cp06dpNlr3bt3R1paGhYsWIDk5GQkJiZi1KhRmuv6AunevTvmzJmDmTNn4sCBA7jooouQnJyM/fv347PPPsOtt96Ke++9Fz/++COmT5+Oyy+/HL169YLD4cC7774rBdSim2++GfPmzcPNN9+M4cOH46effsKuXbtCft9eeeUVzJkzBz169ECHDh0wYcIE9OvXD+PHj8ewYcOQkZGBtWvX4uOPP8b06dPDOleidi+KHa1E1EasX79emDx5spCUlCQkJCQIZ555pvDbb79pPnb37t0CAAGA8Msvv2g+pri4WLjzzjuFgoICwWQyCbm5ucLEiROFf//739JjxHEgWqMrGhsbhXvuuUfIy8sT4uPjhdNPP11YuXKlMG7cOMUoiuaMA6mtrRWuuuoqIS0tTQCgGA1is9mEp556Sujfv79gsViE9PR0YdiwYcJjjz0mVFVVCYIgCEuXLhUuvPBCIT8/XzCbzUJ+fr4wdepUYdeuXYrX+eKLL4R+/foJRqMx6GgQ8dj9jRj55JNPhDFjxgiJiYlCYmKi0KdPH+HOO+8Udu7cKQiCIOzbt0+48cYbhe7duwtxcXFCRkaGcOaZZwo//PCD4nnq6+uFm266SUhNTRWSk5OFK664QigpKQlpHEhRUZFw3nnnCcnJyQIA6fOYM2eOMHLkSCEtLU2Ij48X+vTpIzzxxBOCzWYL8kkQkZxOEFR5dSIiIiKKSVzjRkRERNRGMHAjIiIiaiMYuBERERG1EQzciIiIiNoIBm5EREREbQQDNyIiIqI2ggN4NbhcLhw7dgzJyckR25KGiIiIyB9BEFBTU4P8/HyfweVyDNw0HDt2TLH/IhEREVFrOHz4MDp16uT3fgZuGpKTkwG43zz5PoxERERELaG6uhoFBQVSDOIPAzcNYnk0JSWFgRsRERG1mmBLtNicQERERNRGMHAjIiIiaiMYuBERERG1EQzciIiIiNoIBm5EREREbQQDNyIiIqI2goEbERERURvBwI2IiIiojWDgRkRERNRGMHAjIiIiaiMYuBERERG1EQzciIiIiNoIBm5EREREbQQDNyKidmBHUTWu/c9qrD90ItqHQkTNwMCNiKgd+HT9Ufy8uwyL1hyO9qG0Cw6nC+sPnYDN4Yr2oVAI7J7Py+6M/c+LgRsRUTtwvKoRAFBc0xjlI2kfFq09jEv+9RteWb432odCIXj7twO45F+/4c1f90f7UIJi4EZE1A4Ui4FbtTXKR9I+bD1WDQDYXVIT5SOhUGwTP6/i2igfSXAM3IiI2oGianfgVlLNjFtrOF7ZAAAor7VF+UgoFMeqPJ9XXex/XgzciIhOcoIgSIFbeZ2N665agViarmgDgQB5Py8GbkREFHWV9XZFsFZay3JpSzsmZtzq+F7HOkEQvIFbG/h/g4EbEdFJrkhVHmW5tGXVWR2obnQAAE7U2+FyCVE+IgpEnoVuCxlSBm5ERCc5deDGBoWWc6yyAT/vLpW+d7oEVDXYo3hEFMiRE/X4dU+Z9H29zYkGmzOKRxScMdoHQERELUvsKBWVcCRIi7nsld9wTPV+l9dZkZ5ojtIRkT+CIODP//wFlfXKwLq8zopO5oQoHVVwzLgREZ3kfDNuDNxaQqPd6RO0AewsjVVVDXafoA2I/XIpAzciopNckSeYiDcZAMReqfREiBfK4upGTP/vevy2113a2lNSi3dXHoBDY9p9ndWBl37cjT2eOWqr95XjgU82oawFF5/7e+5IdirWWh3459Ld2Fvqnjf2294yzPx0U9BgY+2BCny+4WizX18QBOwvq4MzQuv27E5XyKXkLzYexQOfbEJNo/vxn284irUHKjQfu+HQCbyyfG/A4yyt8fN5xXigzcCNiCjGNdicWH/oBAQh+MXyo7WHMerJH7D5SJV021FPh+OAjikAgBLPBWtHUTXuWrgBs/+3DfvL6lBS04hdxc0bGLt4SxHufH+934ui2hcbj2Lo49/jtZ/2BX3se6sO4qtNx3HVa6txsLwOj3+1DQ9/sRU/7y7zeezrP+/Hs0t2YdLzPwEAZn62GQt/P4wrXl0Z3gkFUVzdiHdXHkCd1eH3nMtqrdh2rBrLdpZg85EqfLj2sBRQhkoQBLhcAl5ZvgfPfb8LE59bAQC4/5NN+GDNYVz9+mrNn6uzOiAIAu5auBF3L9qIg+V1WH/oBBrtwddx/XG4EqfNXYoPf/duk/beqoM489nlePu3Az6Pdzhd+L/PNmPBitB3i5jy6koMn/N9SN2cdy3ciIW/H8Yt76zF4Yp63L1oI+5auFHzsRf/6zc8tXgH3lt1UHH70coGvLvqIBrtTr+fV2mtFVuOVmH5zhJsOlKJD9cexv6yupDPqaVxjRsRUYy775NN+N8fx/D0ZYNwxfAC6faD5XWY/8NuzDirFzqlx8PuFPD3jzcBAOb/sAv/uWEEGu1OrD3g3lj+rH45+P3ACRw5UQ8A+PdP+/DFxmMAgMMn6rH2QAVO1Nvx09/PROdM7xqfZTtL8MO2Yjxyfj9YjAbp9s1HqvDWbwfw0Hl9kZ5ohiAIuO29dQCAvaW1EATggiH5uPPMHn7PTbzwPvHNdtwytlvA90Gcbg8AD362RcpkaV2A1QHovtI66b+r9pXj1G6ZAV8rVP/8cTfeW3UI0OmQk2xR3KfXAS4BeOSLrT4/Z9Dr0CHZgoxEMz66bTQSzP4vx4Ig4M7/rsf6g5XomB6vuO9whTso3368GmsPVGB4YYZ038bDlbjkX7/itnHdpXWNLy7dg0/WH8H5g/Pxz6lDpcc22JyY/dU2nDcwD2N6ZkEQBFzzn9WoaXTgvk824YoR7t+7hz3nMvurbbA6XLAY9bhxTFcAwE+7S/Hf1YcAAHtLavH7gQr854YR6J6dpHleLpeA9YcqAQArdpXiklM6+X0P5OsyV+2rwLuegCzYPxB+2F6M608rlL5/bslOfLr+KOJNBpgMOsVjjXodHC4B93n+H5IzGXS4aUw3/HVij4CfVWtgxo2IKMb97w93cPX8kl2K219etgefbTiKV3/aiwtf/hW9HvpWuq/ME9Ss2leOBrsTuSlx+POgfADAwfJ6WB1ORRZhf1kdTnjW+6zYVaJ4ndn/24b3Vx/CD9uUtz+7ZCc+WX8EH/zuvlhvkmX5dhTVYGdxDZ75bieOVjbg1z1lIWUM1RpsTqnctUuWpdp+vFoqmdVaHT4/10kW4JTUNCJbFlR96Xk/Q+V0CX6HFhdVuQOHkupGaT5ejw5JePjP/fD/xnWXHmc26NGjQxKSLEb0yU2G0+WeHbb1WDU2HqqEIAh4/ed9+HVPGexOl1Te3nK0CvMW78A3m4tQVN2IOtm5nqizIT3BJH0vBuGix/63FS4B+NfyvbA73e/hJ+uPAPD+Tok+33gUH6w5hGe+24H/+2wzus78BjWN3teyO10+5dinFu/A7K+2odrzOXy7uUi676N1R3CgvB6frT+K3/aUSf9YkJPPE0y0aAdD4vluP64MxFfvd5dIbU4XrA7/2cNDFcrXFdd3Flc3SkFf37wUPHp+P1w7uov0OLNRj+7ZiUj2fF52p4CP1x2GIwZGuzDjRkTURlTUKy+cGzzZiqXbS6QBoqKdRdVwOF1YtsMdbJ3ZpwPyUuOQbDGixurA/rI6HCr3XtT2lXr3aJSvgTtRZ5MCvAPl3kBPEARsPOx+/YNl7uf5dov3wi13yb9+RXG1FRcP7Yh5lw5UZO0COVxRj0te+Q0F6fF468aRUnYJAKob7dJFVCtwk19etx2rVgQd8oBEzeUS4HAJMBvdeY39ZXW48a3f4XC5sHTGeOl2+XGIz2nQu9+3EYUZuGlMV8WG5VeN6oxHL+gvfb/laBWmvLoSdTYn9pXVQQAw5+vtAIA+ucnYVVyDv03qhee+VwbrDbIS5+ajVVKwDfh2Cwcba+F0CTDo3VmnDYdOSOf7hywAF+0sqvG77+qh8nr0zk3G99uLfe77cO1hvLRsDxLNBsy/cijO6pcj3ScP5rSO9fWf9+HJb7bjmcsG+wyNPnrC+7tQZ3X6/Z06WK4M3Kob3J99TaMD1Z5/SJzWPRM3nN4VLy/bIz3uxtO74oFz+0jfL91eDLtTQEqcCdHGjBsRUQyTD2+1OVw49x8/Y+6321HdaMceT7AlD9r657vXsTXaXdhZXIMftrsDtwl9OkCn06Fnjrtstf5gpWLRvDyR8N81h3D6vB/x9abj2HikUrpdHujtL6uTFpUfrHAHdN9tdQduj180AH+f3Bsd09xZLzEQ/GzDUXdZ0UOegTPqlWWrE3U2THvrd5TWWLH+UCW2e8qkqfHuC6fd6Z2PVqcRuMlvW7mvXLFIXevxgHu93WnzfsRp85airNaKijobLl+wEvvL6nC4okGzG7facwzVjXapOUHM7smDvEtO6aj4uQEdUzF1ZGcA7vLtyr3l0n07imrgEuATtAFAiSyo/nWvcm2felF9nc1/gAoAZ72wAte9sQZOlyD9I6BaFtR2TItHcpw7v7PpSJVPxlV0sLwea/ZXoLLejsxEM965cSSu92SvxPWUdTYnpv93PapkgaY8EBezp4D7d37VvnLM+Xo7XALw1aZjUplc/PzljSDqz1M98Lha9tw1UqBtl4JB8fPSyX4FL1V9XhP75uCcAbma59/aGLgREcUwdUfi9uPVeHXFPmw6XAV15fGSoR3x9V/PwKnd3OucnvWUKVPijDi9h3tNV6+cZADA99vcQVZmotkni1RRZ8PRygb8bdFGbPRc0AFvgAZ4s32AO6ATBEHKyJ3VNwd3ntkD52pc6Fbs8g6nlXcTpsTLS35HMWzO99hT4s0CimXY4V3SoYrxUBMkcPtF1byglaHbfKQKdy3ciKLqRpTV2vDDtmJ8vfm4IkDQ6n4Us3c1jd7mBDEQGNwpDYB7rdvAjqk+P9vNs/ZrX1kt1uzX7o4EgG/+eoaUqZJn3NTnpf5dqbcGzrjtK63DT7tKse1YtfSPAOnYshLx6wMTcM2p7gDs2y3HsdgTmIvBnOhgRZ302Q/tnIaxvbLx8J/7IcGszIJZHS6s3u8NUOUZNzFgFAQBV7++Glf+e5V0X3ayBduOuwM38XdbTp1BrVc1XuyQlVmrNT6vrCT35zXSsz4w2WJET8//J7GIgRsRUQzzN3Nt+U7f7EfXrEQA3oBh2U53kHT9aYXSgmrxgiTe1yUzATkpFmhxysqhgDLjJr/9eHUjaq0OKZCM91ywh3VJlx5znScDs/ZABeye8R3yjIt8DdnnG47CJQC5KXE+r9cvP0UR5AF+Mm6y0ttWWVMDANRrZKIW/KTshFyxqxTfqUq/WiXWankGRwzcPIHAgI6p+OCWU7Fy5kTodDqfn+2W7f68th+vls7v+7+Nxe4nzkXPDu6grm9eCvrlpyBJYw2YeF5itrJMtVC/PsQdAL7846jPPwK8v0vugPPn3WVwugSM6ZGFi4cqs1GHyuvRaHd/fvGe3zOjQY8hBWnu20wGXOppPFi5zxu4KTNu7vf2WFUjVu4rV2S/qhrsUil/VFffphJ1ZrFe9fuw7Zg76BcEQcqQKj4vT6A9vDAD7988Csv+Pt7nNWIJAzciohjmL3DTWmDf1RMIXDS0o5RFizPpcYOsq65XjrLDrzAzUREgyRl0Op8ATVwILr9dEIDdsuxYnMn92sO6pEOnc2ec7jyzB9ITTKi3ObHJU36VZ1xqrQ44XYKi0/DVa4dJF3BxpEluapzPOqNajYBKKzgT1akyUQfL6/Dt5uMAgHmXDATgXq/3i2crJLEBQF7OA9wlOTF7V2t1+JTeAGB090zk+Hl/xcCtuNoKm9OF7GQLenRIgsmgx51n9oBOB9w+3t3gkGjxvy5QzKLWWB3SmA9BEBTZuUDUTQ2AN3A7rUcWCjK8jR53jO/uk406WF4vvW6cLHs7wpPBGt87G2f2yQYARUn4SKU84+Z+b9cddK+1G9gxFXMuGgDA/f64BPfvUfcOvh2q6s+/ThWwHvf8P9RgdyrWRUql7STv53V6jywpAxer2JxARBTD1LseiMS1Q+kJJmmBunix7ZuXghV/H48Pfz+CQZ1SkSm7EPVWXXS7ZCbCqjHAFnB37NkaXDAb9TDqdai3OXG4ogGd0uOx3VO6ykg0o6LOhl1F7nKUXufuoASADilxeGnqKTDodchJicOorplYvLUIq/ZVYFiXDBxWdRrWemahVTXYEWfSo19+CixGPRrt3iGt8SYDUuKNPj+nVqtRJuyckYBDFfWKDJ0gCJj1pbv7cnzvbFw+vABPLd4hvae9c5LRIcWCn3eXKdZ/Ae5AScxUyUtvHZJDu/BnJ1mQZDFKxz+qa4aUmbtoaEdcMDgfek82zV/XJeAO2HeX1MDuFFBRZ0N+WnxY0/81f5c8QWVKnAnf3jUWH/5+GGajHqO7ZyI/LR5xJj06pSdgT0ktDlV4A7d4WXn0lrHdoNfpMGVEgdQEsaOoxt0Nm2jWzLit9wRup3ROR5xnYLT8s0+N920OUH/+6gysvJwtOlFvl0rL2SF+XrGCGTciohgm7jM6dWRnvHnDCFwwOF+6z2TQ4ex+3nVkYuAGAHmp8bhrUk+c2aeD4vk6pMQpnqNLZoIi4/bYBf3x3k2j0E32XAPyU9Al0/39oYo6bD1WBYdLQFaSRVoXtNMzNy3OZFCUBc8blCct6hbX2b356wEcOVGPI7LOQMCd0RIv3IM7pcFk0EsX70pPR228yYBkiyrjphG4qctlgDtwA5QX9u+2FmH5zlKYDXo8dF4/GPQ6nDMgD4D7/b35jK5Shk+dcauWrXk7XtkolQtDzdjodDpF08T0Ccp5d3rZYr6kALPDshLNyEx0v6aYRVJ3Gas9fmF/3D2pp+K28wblSV/Lf5eSLEbcOKYrrjm1C3Q6HQqzErHh4bPx/s2jAADHqhqkoEj8vMSfu2tST+SmxiE72SL9o2Hut9vhdAk4VunbnLDe0906rEu6lLmVPnuzwWd9HRA8cBMzcvLP62B5HQRPFi+jje0jy8CNiCiGiRm3/NQ4nNmnA/rkeTNmffNSpC7RvNS4kAeDPnXpIIwoTIfFqMewLumKNW69cpIxpmcWCmUX7iEF6ejiCXoOltdLjQlDCtLQxTOod5cscPPnklM6oU9uMspqrbhiwUqfLZiqGxxSqUxcHxdnVGZd4jQyboG6SnvISmsFnnOotzulzsOfPAv8rxrVWXrsw3/ui49uG431D5+Fy4cXSK+nXuMm/97myVomWYyKrFMwN43pCr0OeOayQeiTm+L3cUmqgEV+XplJFmQmuYMPsbM02H6043p1UKwXM+p1+NNAb+DWLUt7aK4o3mxAh2QLEswGCAKkRpI4o/+w4oE/9YFeB3y49gj+/M9fFDPRahodqLc5pHV7w7qk+3z2FqNBcxyH+vNXr3kTg0J5d6k41y4j0SJlA9sKBm5ERDGsyDP+ISfVnRUrzJQHVGkY7FkALjYkhCLebMCiW0dj3cNnoSAjQbEGK9fzOl1kOycM6ZyGfM9oj6LqRml921DZ7Qc8s9wCXbgTLUa8ccMIdM5IwLGqRlQ3OjCsSzryPK9Z02jHhsPeUhngXS8nXuPjTL4Xb62Mm7jOaVAnbzeneE6C4O3OFDNz8oG9CWYjRhRmINnzOuJ/q1VdpdWqDBwAdPDT6OHPPWf3kgLEQNSlUvl5ZSaZpXK4mHHzV2IXJccZUZjl/Yz75qWgf34q4k0G5KbE+W1YkdPpdNLnL876swQI3M/s3QGPXzQAeh2kUruY5atptGPL0Wo4XQJyU+I85Vj3c7lkTS9aGTd1QK1ewyj+fogz3ORCOc9YwzVuREQxTCyViuVMdeA2ojADX9x5urQmKVR6vU7qVFQEbp6v5aWyoQVp2OPJqDXYnFLgNqQgTSrJiWuq4oJkm/LT4rH47jPw+s/7caLehvsm98GV/16J41WNKK6xSpkbMTBRD1aNM+l9uko1S6WerMvgTmn4dL07s9cxLV7ahqrO5kCixSithQu0hizZop1xUwdyAJCTrN2I4I9Op0NaQvBSnbqrVH5emYkWZHkybmWejFtRkFJposWI1HgT4kzuNYRDCtKQGm/CV38dg3hVuTvY8wDezz8+QOAGAFeP6oKhBen4zy/7cVa/DuiYloCvNx1HdYNDalqRPnuT8h8BcSZ36dxi1MMq60JWZ9zEz95s0MPmdEmfm1ag7a9xJJYxcCMiilGCIEjdlPlp3kyYTufOGg31ZKXErFtTdc1KhF7nXhcnlvnEwC0ryYxO6fHSmIdjlQ3S2rRBnVKlMlaD1FUYvEyYYDbirxO966vEjNbqfeVwCe4sSAfPBTVOdfGON/tm3BrtLjicLhg9TRFWh1MqhSkyU4lmJJrdO0fUWZ1Asvcir545JicGijVWdcbNN2AUM5aRFizjJq6rEzdrV68flLMY9VLXcWFmInYU1WBo5zQA8LuvqD8JnkBN+vyDBG6Ae6TLc1cMBgAc8GTq3Bk399gOcead+ndJDApT4k2KPUrVgbsYjOekWnC4okEWuGll3Bi4ERFRhBw50YBaqwMmg05qDki0GDH7wgGobXQosmLNkZMSh/dvPlXK2gDAad2zcPOYrhhe6O50FMdRHK10Z3KSLUYkx5l8Ah51oBUKsfwljoqQD6tVl960ukoBd3ksNcH92vLBs33zvOvG4s0GJFgMnsDNfREXS6qJAdYHisenLrVpZdzCLZWGKkk2DkSnU55XotmITM8Ce7FTcoeny7dDskXqGhXJy40z/9QXP24vVjQmhEM9piTcz188ljpZJneAJyhVP5cYFKbEGQMGbmL5OzclDocrGmSlUq2MG0ulRETUDMcqG/DR2iM4d2CuNPC2e7Z7tpfo2lO7+PvxJhvdXTnY1KDX4aE/95O+F7Md4gUzwXPBVjdEhJJxURMv3vs82ZcBssBN/XxxJoOUoZOrsdqR6pm3Ji5OtxjdpbWHzuuLvaW1GFKQ5slcWb2Bm+e/AUulfrpKtQby+puJ11zy40s0GxFnMuCBc/vgyIl69M1LltaMHT3RALvThb2ekvOIwgx87ZlRJ5KXXcf1ysa4XtlNPq74Zn7+8s/ygOf3Xcq4aXz26p8BNLpKPcG4mE1zD4cWNEulLfV5tSQGbkREMWTBir14Z+VBvPDDLumi0ic3+tvviAFaRZ07cBMzVOqMW7A1TlrUpU95xk3d7OBuTtDOuKm/FoOdm8/oJt0nHrcY3NVLgVuAUmmcnzVurbhmSh5sie/5beO6S7eJDR5rDlRg/DPLYXO6kGg2oG9esk/gphX4NlWCRkY0HGajXlpnB7jPQyz7qte4yUulcj5dpbKMGwA4Xe5hxFqBdlsslbKrlIgohhyQbSsldgb2ioXAzaLs8BODIt9SaVMybv4DN+1SaeAhrGJQphWMibeJwZ2YnQk0SkXqKg0wx03UGoGb1vZXo7pl4u5JPWE26qV1kb1yk5Gq0fig9fNNlaB6j9XBVijkn7/is9doTAHgE7irhy2Ln39WskXa17am0dGqn1dLYuBGRBRDjlf6LiqPiYybKoASAzZ1wNO0C7f3OfrkJkuNCYAy46bXuYfias3yemrxDqw/dAKfbziK6e+vB6C9bk3KuHkCPbE5IVAwI61xCynj1jJrpuSlUnWwBLhL23dP6oVLT/HuI9onN1kzO6meCdcckQncvcdzhqxs69OY4ifjtv14NZ5fshM1jXbc+9EfUrdtosUofa41jQ4/zQlc40ZERE0kCN5p8mf2zpY2gu8dYDBra1EHaOIFUT1strkX7rP65fh9PnFMhbw5waB37z6wZn8FLvnXb6pj1sq4eRfDy7tPtYIhkRgo2BwuWB1OKROkNResQ5jjQEJlMrg7QW0OV8Ds4GXDOuGDNYcBAJ3SExRBjvheJUcy46Ze4xZCV7Ga1e4d7XFWX+/nbzbopQ5qQN6c4D4n8XwA4MUf9+DbLUWKPXMTze71kNWNDtQ02jUzbm1t1wSAGTciophR3eCQSnfiuIy0BBPyW2jERDjUgU2Cn1JpU9a4ycuhvoGbXva17+L0nAD7TGo1HHhLpQ5F96k6oygnz8bJ10mpx4MAkMZstATxOAJlB0/pnC7dP6ZHliLjJu6hqjXEtql8Pv8wdo0QHZVlmeXjVHQ6nSIQ9H7+nvmDqs9eHrQB7s9ffGyt1eHTXCK+RlvDwI2IKEYcq3JfwDISzRjaOR2f33k6Prn9tJi4uKgv0OJ4CpNBL20qDzRtHIh8DIl8jZP7+TQu3BajtHYp0Ny0gKVSm0NaCxVn0ksz4LQYZMOKxaxNSU0j9pXWST/fGhKlTl7/wZFOp8P3M8big1tOxWDPUF3xZ8SvW7ZUGv57Ic6Q0xpJIn8+MSgUz0PctUGk3rkq0ewN3HYW1eBwgNl2bQlLpUREMeKYatjukGYO1o0kdUlM/n282QBbg7vc1ZRS2ehumXji4gEY2DHVJ0i1GH0v3HrPeq6SmkZp31TNY9Yof4qZwjpxCC8Cz3ATpcQZPVkbd7D3wve7UG9zYnBBGrpnJ0rrqlpSksUEoCHo8ealxiMv1R3UdMtKwhXDO6F7dhJ+2F4se57IiESp9MUrh+K7rUW4drTvmBt3WdqzT63nd+GsfjlYtqMEV5/aGTe+tVZ6rGzrU/exWQxSwD3n6+0AgFFdM5ASb8L324rDPs5YwcCNiChGiIGbeNGNJerMSqLs+wSzQbEJfLh0Oh2uHqU9m06ZcfMGcWIp+ZJ//RrWa4mZwnqrU8q4BVrfJkqOMwFVjahpdKC81opFv7vXkT18Xl8UZiVCEICpIzuHdSzhEo890Mw5Nb1eh6cvc+9SsGqfe8BxrDUnFGQkKEa2KJ/PN3DPSYnDf24YEfR5kyxGJKkaWR46rx+yky1INBtw/WmFYR9rLGCplIgoSvaW1uKWd9ZKezSKuxJ0TIu9wM1k0MNk8GbDEjXmigHB9yoNl0XVnKD26AX9MaIwXfNnD1fU+9wmZohqZWvcQsm4pXmG+5bVWvH7gQq4BKB3TjKGF2YgK8mCF6YMwciuGcFPqBnE9zzQzLlArhzZGaO7ZWJinw4ROyb1mjZLhNf4aZXK5f4yoYdUOlVLUG1KP7ggDQM7pSI3NQ7zrxwqbRnX1jBwI6KY9fG6I3jgk0348PfD+HVPGexOV/AfakM+XX8E328rlroAj1cpS6WxRl4WS1AEbt6v1QNzm0v+fFoX7kGd0vDRbadheBffi7B6DhjgXdhfb3PK5r0FD9x6dHDv4bmjqAar91cAQIsHampJUuDWtIzZ5P65+ODWU33WhjWHPOi1GPXQqxeaNZMlSOB2z9m9sfDWU/0em7yDdlQrf14thaVSIopJVfV2zPx0E+xOAQs9Zam/TOiBe87uHeUji5yyGve+kpX17v/GcqkUUJZE5XtnyrMuTSmVBRIs4yLKlDU45KXGIS81Do+c38/ncWJ2sFa2X2mgxf6iPp69QXcUVaPMs5H7iFYOBC4b1gnHqxp9Om+jKaEFP3tAGbj761iWf/aAu8Gld24y0hPNiozbiEIGbkRELWbJtiJpxpZo7YETUTqallHu2T5KDIbKat0BXIcAIy6iKV6xrk2+d2bLXbwtIVy4AUjbJAHAxUM74r5z+mg+TiyrVdTZQtpgXtQvzz0Eee2BE9LQ3pGtHAiM790B43tHrswZCcqgPfJFvGAZNwDISDAr5r29eu0wKatoc3iz9FpZ2baIpVIiikni/oozzuqFL+48HYDvnKZI2VNSgxLP9lKtSQzUxAn84qgJcbP0WJOoCNa0S6VNmeMWiL/mBLVMWeAm/1qtW7a75HnkRD0qPO9/KKVHcQhyrdUBlwAUZMQHHEXSXiS24GcPhJZxMxr0SJdt7SUfqivvUk5vg8N2tTBwI6KoEgTB57aqBjt+2V0GAPjTwDxpfVFZrRUn6mwRff09JTU49x8/46KXf5UyKf5U1ts0j7ep5Bk3QRCkAE5rS6dYIM+uJPotlbbc4vRAgUG2rFyWleT/Ap2VZEZaggkuAdh8tApAaIv9kyxGFGR4S9jnD8oP+jPtQUuWydXPGeh3S/zMk+OMip+5/rRCnNUvBwuuGRbxY4sWBm5EFDXF1Y0YPfdHPP/9LsXte0tr4XAJyEuNQ48OSUi0GKVOy0hn3d5ZeRB2p4BjVY1445f9fh+3bGcJhs/5AU945kFFQrkn41NVb0ej3SWVhrU2UY8FCYrArXVKpYqdEwKsRZNn2bICZNx0Oh16dXCXPTcergQQeIN5OXnMfouf8RXtjcWolwbfWlokcAvcnCLKTHR/5urPPiPRjNeuG45zBuRG/NiihYEbEUXNmv0VKKpuxNLtymGYRVXusqW8+61njjvr9uOOEhwoq4vI69dZHYrBqQtW7MN+P8897c3f4XAJeD1AcBeOepsD9Z41VjVWB054GhQMep0iEIolilKpLHCLl3eVtmDGLdBw1yxFqTRwSaxHjjeDCygbLQK5bVx3AMA9Z/U6acpuzaXT6aTfi0h3FAOhN6dkedaFZraDz4WBGxFFjXjhdKiaEI57Ajf5GqJeOe4syYIVe3HBS7/A6nCiOUqqG3Htf1aj1upAYWYCTumchlqrA9e9sRoVqnLsH57MDAB0yUxo1uuKxGwb4M7kiPs1psQZY2KLKy2KUqlqAK+oRZsTAmbc5KXSwM0dPT2ld1GoGberRnbG8nvHY/qEHiE9vr0QP5em7FMaTMifvydgC/bZnwwYuBFR1IjBi92lnM9WJM4zkwVuPbK9F9vqRuUG4U3x8rI9WH+oEkkWIx69oD9evXY4Omck4HBFA95fdVB63I6iavy/d9dJ32dH6MJQrgoOj5xwD4uN1TIpoAzQFDPdWmscSICMTl5qHBLMBqQnmBQL1bWI/wgQhTrQVq/XoTArMWYD62gRP/+mbHcVTKiff3dPMN4tOzHixxBrOA6EiKLGX8btmJRx85ZKR3bNgFGvg8OzIaFDvTFhmA55pur/35/6SiMWpk/ogfs+3oQv/jiG6RN6QKfT4Z4P/0CRrOPUGaHmhHLPuYsOV7iDVX9T4GOBGKyZDXqYZRdRxQDeSAdusmAgUMYlwWzEJ7efBpNBD0OQIbBNzbiRNvH9a4lxIOLvk8mgg9Hg//mnDC9Al4wEDPezi8bJhBk3IooaMXBT74ggrnHLk2XcCrMS8cv9E6Tvnc0M3MRyaLZsZto5A3JhNuqxp6QW24/X4HBFPbYeq4ZBr8PTlw2KyOuK5KVSwBtIxmpHKeDNrKj39lRk3CK8zskS4uJ0AOiblyJ1IAeSnWzBeYPypO8juXdne5TQCqXSYJ+92ajH2F7Z7SIIP/nPkIhiVqlYKlVl3Io01riJ35uNetgcLjhczdv+SixVymc+pcSZMKF3ByzeWoS3ftuPvp5p+cO7pCMnxX0skQrcyurUGTexVBq7fy2LF2j1wFrx9mBZkaawBNnyqil0Oh1evHIoBnVMxaYjVSfNVkjRIgZsWluMNZf4mbfEqJG2Knb/hiCiVlNS0wir3YWCDO2F9412J/67+hDG986WBphGQlmNp1QqC8KcLgHFntJkvsbWT0a9DjZELuOm7kK74fRCLN5ahA/XHpFuO6tfDgyedU0tlXE7cqLtlErVa8KkUlkLXLh1Oh0sRj2sDldEB7wa9Dr8P0+XKDWP1FXaAsGVGLi3xHDftoqlUqJ2zuF0YeQTSzHxuRXSAFi1Z77bidlfbcPt762HK0KBiyAI3lKpbFuaslorHC4BBr1OUcYUieuXmrPGrdHulEZxZKhGR5zaLRP/b5xyRtfEvjnQe/62jFzgpsy4ebtKYzlw82TcVDsNSBmXFrq4igFBS5TiqPmk5oQWXOPGwM0rJgK3l19+GYWFhYiLi8OoUaOwZs0av4/99NNPMXz4cKSlpSExMRFDhgzBu+++q3iMIAh45JFHkJeXh/j4eEyaNAm7d+9u6dMgapPWHKgAANicLhzxLJCX21FUjbd+OwAA2FlcgyXbiiLyurVWB6yegM0uC4bEUSAdki2ai8yN+uZnvsRsm8mgQ7LGdkf3nt0bD53XFxcOycdD5/VF16xEGD2RW8QCN88xpKjWV8VyV+kpndORlWTBBNV+mb1zk9E5IwGT+rbMPppiFjKWg9r2bFzvbKQlmHBqt8yIP7f02cfwEoLWFvV3YtGiRZgxYwYWLFiAUaNGYf78+Zg8eTJ27tyJDh18/xLIyMjAgw8+iD59+sBsNuOrr77CtGnT0KFDB0yePBkA8PTTT+PFF1/E22+/ja5du+Lhhx/G5MmTsW3bNsTFcW85in2CIGD6BxtQUt2I924e1SJrR0RLtnqH3+4qrsG7qw7imlM7o39+KgDg9Z/3w+kSkGwxosbqwCsr9uGcAXn+ni5k8lKhQ9acII4C8bcPpMETQKk7UcNRIVvfpjXawWTQ42bVZHxx6VakukrFjF9+Wjyqi2qk22M5cOucmYDfH5zo854lWYxY8ffxLTYmY/aF/bH9eA165USuTE+Rc+GQjrhgcH6LfP6ju2firok9MbZXVsSfu62Kesbt+eefxy233IJp06ahX79+WLBgARISEvDGG29oPn78+PG4+OKL0bdvX3Tv3h133XUXBg0ahF9++QWA+4I3f/58PPTQQ7jwwgsxaNAgvPPOOzh27Bg+//zzVjwzoqZbvKUIX286jt8PnMC2Y9URfe5fdpfhleV7IQgCBEHA99u8gdu/f9qHD9Ycwnkv/oK9pe6tpVbvLwcA3Du5NwBglyzIaI4yWanQJXgzWaWedW8dNMqkQGQybt7GhNBnshkinHETAzd1gKrOwMUafxfnlpxtNr53B9w+vjvnp8WwlvpsTAY9/nZWLwzrwgYSUVQDN5vNhnXr1mHSpEnSbXq9HpMmTcLKlSuD/rwgCFi6dCl27tyJsWPHAgD279+PoqIixXOmpqZi1KhRfp/TarWiurpa8YcoWhxOF55ZslP6fl9pZLZ3El3zn9V4avEOrNxbjp3FNdLaKgDYXuT93X/0y604XtWAwxUN0OuAsb2yAQANdmdENlovU63xEkeCVNa719n5G6Iqlk+bk/mq8HR0hrM9TqSbExo8G9rnqQK3WG5OIKLoi2rgVlZWBqfTiZycHMXtOTk5KCryv46mqqoKSUlJMJvNOO+88/DPf/4TZ511FgBIPxfOc86dOxepqanSn4KCguacFlGzrD9UqQjW9pRGblP1GlnzQb3NibUHTijul8dCu4prsGa/e/1b//xURaNAo715ozgA7ygQkdhsUNngPsbUBO0AxmgQA6imH4NYpg1nv0lDBDJ9clLGLUXZORvLpVIiir6ol0qbIjk5GRs3bsTvv/+OJ554AjNmzMDy5cub/HwzZ85EVVWV9Ofw4cORO1iiMP3uaRYQ7S2JXOAm30DdYtJj3cETfh9bWmPFqn3uYxlRmKHo6mqwN2+7KcA7CkQkdpaKGbe0+MAZN601bt9sPo5z//Ez9gR5z/yNAgkk0oFbgydwG16YLpV/AS7AJ6LAohq4ZWVlwWAwoLi4WHF7cXExcnNz/f6cXq9Hjx49MGTIENxzzz247LLLMHfuXACQfi6c57RYLEhJSVH8IYqEppQUxSzXxD7u5pzV+yvw5DfbpQGtzbFXlr2zO11S4NYnN9nnsS4BWLLVnaUe2TUdBr1O2uYoIoGbulTqyaBVNbiDqjR/GbcAAdSXG49h+/FqrNhVGvC1KzSG7wYTyeYEQRBQ73kPu2cn4YoR3iw/S6VEFEhUAzez2Yxhw4Zh6dKl0m0ulwtLly7F6NGjQ34el8sFq9V9EejatStyc3MVz1ldXY3Vq1eH9ZxEzfWXDzZgzFPLUGt1hPwzTpeA9Z5g6sqRnQEAVQ12/PunfXjg003NPiZ5CfZoZSMOVdRDpwPGedavqYmL+Pvkuv8xI2bdxGxRc6gDNzGD5s24aQcwUlepRuBmdTg9xxf4PdfaNSEYqTmhGd2sIpvTJQWeCRYD/jqhJwD3Vkz+AlYiIiAGxoHMmDED119/PYYPH46RI0di/vz5qKurw7Rp0wAA1113HTp27Chl1ObOnYvhw4eje/fusFqt+Oabb/Duu+/ilVdeAeDubLn77rsxZ84c9OzZUxoHkp+fj4suuihap0ntTFW9Hf/74xgAYNPhSpzWI7RW9h1F1aixOpBkMeLM3spg6tc95Wi0O5s1nVyecVu1z90t2jsnGR3TleusspLMKPOsAzPqdejkuT/eZEBVgx2NIWbcBEGA0yVoboOk3jlAak7wrHFL89OcECjjJq69qw8SWDapVKprflOESB74JpgMSIkz4bcHJkCv08EU4S2jiOjkEvXAbcqUKSgtLcUjjzyCoqIiDBkyBIsXL5aaCw4dOgS93vsXWV1dHe644w4cOXIE8fHx6NOnD9577z1MmTJFesx9992Huro63HrrraisrMSYMWOwePFiznCjVqNYpxZGl/zGw5UAgKGd0zSDnZ93l+Gsfjk+t4dqb4k343aw3P119w5JSFaNoOidm4yyPe7AriAjQToWcXJ9sMAIcAcnN739O3aX1OKHGeOkEqDLJUCAVlepKuPmJ/MUaOcEKeMWJLA8Ud+E5gRD5Na4ie+f2aCX3tv8NN/tvYiI1KIeuAHA9OnTMX36dM371E0Hc+bMwZw5cwI+n06nw+zZszF79uxIHSJRWNbIArd6a+hlxQOe5oGeHdxrzuZeMhBv/3YAOSlxWLGrFO+sPICRhRl+Oy4DcboE7C/3Bm41je5yYpzRoFgQr9O5X/9XT+DWJdO7f6lUKg0h4zbjw434ba/7OfaW1uKUzukAgKtfX42jlQ04VqncpcHhckEQBFTWh7rGzberVNyJIVgp1+rJzCWEsYVSJMeBiIEbt3AionAxJ0/UAlbv9wZudUHWW8kd8jQgdM5wZ1+mjuyMxXePxYyzekGnc2fcRs9bike+2AKbI7xxGGW1VsXP1HoCN4tJrxhBkRpvQn6aNztdmJkofS0GGsECo6KqRny7xTt+R/66K/eV41BFvZQxE7ecsjsE1Nmc0u1Bu0o1S6Xu4wqWERQzc+HsSBGJ+XEi8f0LJ3AkIgIYuBFFXJ3VgS1Hq2Tfh55xO+TZK7SLLFgCgMEFaXh72kj0yU1Gvc2Jd1YexG97y4I+37urDuLif/2Kijob6lRNEjWe780GvSLjlp5gRm6qt2zXNUsWuHkybsHWuKnLoGLgpt6g3mzUIy3R/dp2l0vKtpmNer8bVhsDlCyljFuQ4xMzbmKXbCjEwE0QfM8jXPWeYJ4ZNyIKFwM3ogjbV1qnCCrqQ8y4CYKAQ55SZkFGgs/9Y3tl49u7zsAEz5gQ+Uw2f95fdRAbDlXi592lPlkoMZhyZ9y8qyZS403ITZFl3GSBm9gYESyjVdVgV3wvNh7YVeXNrESztBjf4RQUHaX+ttAJtFdpyKVS8dzDCdxkx9PcrJs4CoQZNyIKFwM3ogg7pJq3FmrGraLOhjqbEzodpC5ONZ1Oh56ejbYPlgef6yZmvoqqGv1moSyqNW5pCSbFNkxdZdk/MdAIltESAzCRGCSqg62sZAtMnkDM7nRJAV+gkRiBu0rFUqn/YFkQBNicTQjcDLLArZkZN6lUaoqJZcZE1Ibwbw2iCDtYocyEhZpxO+gJ+HJT4gKO/BDXnB0oD5xxczhd0ryyoupGv1koi1GPBLMBBr0OTpfgKZXGIT81DgaDTjEqJNRSaWWDctSHGCiJmTdRVpIFxdWN0n1ikOtvfRsQrKtULJX6X/9nla23s4QxWkWRcWtm4CaWrVkqJaJwMXAjijD1DgehNieIP6dVJpUTuzyDZdzK62zS3qPF1Y1+y5sWox46nQ4pcUacqLcjNd4Ek0GP72eMg16nkwIlIPTmBHXGTQyWbD6Bm1maqeZwClLAF6hr1l9XqSAIUmYv0ABeReDWhDVuQPNLpQ0slRJRE7FUSuTH6z/vw81vrw152KxILJWK20iFOg5EDMS6BAncxIzbkRP1cDj9Z5ZKqr0NAu5SqXYwIy7QT/aUS8UyZaLF6JMRauoaN3+lUovRAJOnBGl3uoLumgD4z7jJA7J6mxMNNqdmE4HYUarXQbFHaDCKwK2ZuydwHAgRNRUDNyIZh9OFV1fsxW97yzDn6+34YXsxvt1yPKznUAduoWbcjpxw/1yn9MCBW25KHMxGPexOAcerGv0+rrTWe19xtTVgxg2A1KAQKGgKdY6b2B0qEgM3dam0zuqAUVzj5go+ww3wv8bNKiuPltRYMfLJH3Dbe+vw7qqDOGf+T1JJVnycxWjw2wChRR7jNbs5geNAiKiJGLgRyXy87gjmfrsD17y+WrrtWKX/4EjN7nRJj++T597fM9TmBDFjlGgJfDHX63VSVi7QOjd5xq24utFnHIhIzLh1SHY3JOSm+t9hRAw0gq5xUzcnSGvclAHPoE6p0ngPm8Mlzb/LTrb4fW5/e5WKmTRRTaMD6w6ewCfrjmBHUQ1+2V3meZy3mzYcOlnZuPnNCe7PIsHM1SpEFB4GbkQyH687AgCQX5d3F9eE/PPHKhvgdAmwGPVSSTPUjJsYDOhDyAJ1kRoU/K9zK63xBm4Ol4CjJxo0HycOof2/P/XBQ+f1xYQ+/rfUigtzjVtKnDhc1zfj9tB5fXHVqC4we8aBLFxzCJuOVCHJYsRFQzr6fW5/GbdGjYaE6kY7qj1lW3GbK+/w3fD/+mtu4La3tBY2h8tbKm3GvrNE1D7xn3tEHvvL6rD24Amf23cV16Le5ggpO+Ld+SBB2v8z1DVuLk/5zRDCuitxXIc8OFMrUd23zzP3Ld5kUJQ6xQCmR4dk9PBsteWPGGjUh9hV2iElDtWNtVLGTVzjlpcah5vP6AbAO1BXfO//OrEHOqT4z/qJYznU6+XUGTfAneEr8pRIvYGbt1QaruZse7V4y3Hc9t56nDsgV3ofWSolonAx40bk8c1m91q2MT2ycGbvbAzulAoA2Ha8GgMfXYIXl+4O+hxFnjVneWnx0kU51Iyb2CQZynp5cVcBa4AASh3UiQN71evHwtk9QBoHEmLGrYOn5GlTdZWKQ3cBSJusi0Z1zQz43P66Sq1+tgATs1sVde5j8q5xa92M2+s/7wcAfLuliGvciKjJGLgReZTXujMygzql4s1pI/HpHadLF3enS8Dz3+8K+hzixu2p8SYkevbgDNaBKRIXvOtDiNzEbJG/YAUASj3Dd8Vg44inVJqqaj4IJ/MUygBeQRBQ2aAM3KxSV6n7v0bZMFuzKnALFsz46yoNtu7uRJ2qVBrmGjf5azelOSE90TubTsxYxnONGxGFiYEbkYcYjIgjLwx6nSIwGuTJwAVS3ehd2yVl3Pw0BaiJoysMIaxxEzNugYKVkhp39q9XjrL8qQ7cwsm4xYXQVdpod0kZNrHJQN2cIA/W1CM5Ag0flj/ep6s0QBALABWRKJU2I+OWkeAN3MR1d8y4EVG4GLgReVilwM37v8VFQ/Klr9UBj5bqBneQlhxnQqInm2J1uALOWxO5IphxEwRBKpX283S3inwzbmGUSkNoThDXtxn1OinLJI0Dcflm3NSl0uAZt9C6StW8GbfolErlv1f7SmsBcI4bEYWPgRuRh5hFknf6/d95fTGyawYA7U3N1aSMW7wRCbKxHsEW8wOA+PShdJUGy7jZnYLUZdk1SzkXLhJr3AJl3KQhugkmKbMmBW4O3zVuZoPyfIM1gYTTVSonNSd4jj2c8xY1pzlB/p5Ve0rqCewqJaIwMXAj8hCDIPn+lR2S43DDaYUAQrtY10ilUnfQIgYZoZRLpVJpCP9XisfoL+PWKMs+5acpN6xvTsYtIZSMmydwS403Sc8t7ZzgOUdxY3nAN+MW7Hi8a9zUzQlBMm71drhcQtQyblprHTnHjYjCxcCNyEMr4waEtyBdLJWmxJug0+lk69xCyLiFMcdNDDr8ZdzE23U6IEc1WiMtQbmBezhrveRr3ASN92N3cQ0e+WILACA9wSxlteyqTeZNRnmpVLYXqskQtFQcys4JWpwuATWNjoiscdPa4D4YrWCXpVIiChcDNyIPsdSmXhxvDONiLZZKxRluSVJnqTugW/T7Iby6Yq/mz0pr3EIqlQbOuIlBTJzRgIxEZaDWnOYEeaCh9dqLfj+M3SW1SI4zYtrpXaXnVjcnGPXyUqn361AW6/ub4xbKnrIV9baIDOB1NaGrVJ1xSzAbkJ/mf14dEZEWBm5EHo0azQmAvDwWvMFAHAeS4tmwPcETuNVZnahptOP+TzZj7rc7NAfnhjOAN9SMW5xJHzRwC6s5QRbUapX+xBLtjad3xXmD8qS1bFbVzgmKOW6yIC5YR6n78U3rKgWAijqbd45bM8aBhLLeUU29zvHCIR1ZKiWisPFvDSKPRj+lUjGwCKc5IdWzYXuiJ4O0dHsxamXr3LQCrnBKpcEybvLsoboZwac5IZRFdR4GvQ5mox42h0uzQcHu8Iz78ASD6uYEhxS4aZdKQ8q4+e0qDR64naizRWTnhKZk3BpUg5ivHtU57OcgImLGjdqVJ7/ZjqtfXyUFEnL+SqWhLkgXBEGazyVm3MTM0uu/7Mct76yVHqsVZIhPH5GMm8M7k85iNEglW0CZcTMb9CGNH5GTOks1Mm52VWBmVjUn2DzBr7KrNLxSqf+MW+uVSpvbnHDB4HwM6Bh8LiARkRoDN2pzNhw6gdveXYddYWz+DgA/7SrFv3/ah1/3lGPrsSqf+9UDeEViRijYxbrO5pSCr2RP4OYveaYVcHnXuAV8GcUx+s+4KYMT+do0eeDWlOBF2vZK4xzUW1r5rnHTmuPm/TqUUqm/rtJg40CACGTcmhG4iYHud3ePxYtTh4b980REAAM3aoNeXrYHi7cW4ewXfpJKk8E4XQJmf7VN+l6ryzPYGrdgzQniKBCTQSc9xzWndkGvnCSfx2oFXFKpNCJr3JTZQ3n5V5Fxa0rg5gkCtda4qdew+YwD8dxv9rNXaUtl3MSttyrqbdKxNGvLqyYEbuKetdwtgYiag4EbtTklsoX9877dEdLP7C2txZ6SWun7WtVcNfl8L59SqWroqsslaDYXSKNA4tyjQAD3AvQlfxuHq1TrmbSCDPH5Q9vyKrSMmxhAyoNR+fk1JeMWaNsr9ZZWZoPBc7uyVKrcq1S+xi34slt/gXSgcSDiLLt6qzMic9zCHQficnkHInMECBE1BwM3anPssiaB/208FtIYiANldYrv1QNx5QGQvzluYmnuvk82YcQTP+Dn3aWKx6lHgcjdPq67ItOlFXCJ693DmeNmc7ikwb1yjaqyrzxYU6wva0LwEmgIr7oUql7j5ohAV6m/rFej5zXumtgTf53QAwtvPVW6LyfFnXFrsDulnRNasjmhqsGOO95fh683HZdeV8SMGxE1BwM3anPKa73ZrhqrA8t3lgZ4tNvB8nrF93WqDj958Od/jZv7+4/XHQEAvPD9LsXjpF0TNPY0LchIwKqZEzG0cxoA7eyQU9qrNOCp+ByjVhAoBjFxRt/AzaDXScFPU4KXQGvc1KVSsUmhvM6Gm976HT95gl1F4BZ2V6n2SA4xIOuQYsGMs3tjSEGadF+uZwhxg611Mm4PfrYZ32wuwp3/XQ9AWVaOa8J7TkQkYuBGMc/pEvDvn/Zi85EquFwCKjybhZ8/2L0B/P82HQv6HAfKlRk3dalUzIiYDXqfrk6jnzlu8ouxyyXgcEUDAG9HqVq82SAFJlqlUlcYpVJ50KH1XFafUqkyWDCrmgfCEUqpVN2cAABLd5Rgy9Fqz/3yUmm4a9zcj/c3x00erHbLSkRqvAldsxKlY5a6Spuxxk0ryyn3lSfTJhKzk6HsDEFEFAgDN4p5q/aV48lvdmD2V1tR3WiXsh3XeNaNrdxbHvQ5xIxbsjQQVzvjpnUx9zc3rNbqQEl1I2wOF+796A/M+nIrAPcG8/6IGS6tjFs4A3iNsn1Qtbop1aXSeNV5iQFVk7pKQ2hOMBuVpVKf4/ezV2nzukp9P8Mvpp+OZfeOR0aSp1Qqy7iFM79O/dqBmhPkGWFRvZ2NCUQUGQzcKOaJGbbyWhvKPBfFlDijtOA80IbnIjHj1r9jCgDfrlJ/+5QC/rsYj5xowMgnl+La/6zGpxuOSrcnW7QzboA3UNJsTvAEbroQMm7BnkvdVXrNqV0AACMK0wHIuj6bkHVKCDQOxKHqKjVoByrygC7cUmmwnRPk5d/kOBMyEs3e2XN2p2znhJYZB7J0R4n0tXfLM8/vFwM3Imom7pxAMU8MqmqtDpTVuoO4rCSLz4ww0W97ylCYlYj8tHjYHC5sOHQCR064y5j981Oxal+FT6nU3/BdIPi6ptX7K6DXeQfoltQ0+j2XQN2gYgIplIyb+Fx1NmfAjJsYmJ3RMxs/zBiLTukJ7ttVOxuEIz6E5gStUqlcc0ql0l6lfgM339eUr8sTj7FZA3gDNCfIu5frbA4IgiC9V4nc4oqImol/i1DMEy96tVYHyj2BW2aSWbrgO10CHE4XjAY91h6owFWvrwYAHJh3Hhas2IvnPU0EJoMOhZnuwMWnq9TPDDfAf4ZHLiPRImUD/zwo3+/jAs1fC2cciPy5NDNu4s4JsuxTjw7J0tfeUmn4GaDQ1riFUSqVBarxIQQ2fjNufgYou59XLx2z+HNNCtx0wZsT5LtyCII728aMGxFFCgM3inniRa/e5pSyWZmJFkWZz+YJ3P44otwRYdlOb9kqLcGMRE/pyl9zglapVC8LFAQ/mRYxEPvP9cNxZu8Ofs/FG2z5X+MWYtwmBSjaGTf/GUSgec0J4nuktcZNPe7DoNcpspEik6JU6v1a6/1X81eulNauaZxTnMYxN2fnhEDNCXZVBrjO6kA9h+8SUYRwjRvFPPnm3Icq3E0G8owb4M1yZCWZpdsa7U7FGJDbx3X3G7g1Blj3JM8I+cu6iYFf//zUgF2DlkCl0jCaEwBvgKK9xs1/BhEATEZxHEjT57hpb3mlsRepxmuY9E0vlYrZumOVDXh52R5pGHKgOXriYN9Gm2yOWzO6SgNl3NRjSmqtDilgZOBGRM3FwI1inrwkJwZimUkWGA16aV9PMRCSX7S3HK1CRZ0Neh2w4/FzcOOYrtJicXWpNFDGTR5I+VvbJAZ0wTJGUsYtUKk0jDVuQGhdpWrNGgcSxho3+WvJ+ZvjFkopUXx/6mxOPPPdToyeuxRWhxM1je7PNE1jjp6iOSECc9zCybjJA7dQSsFERIEwcKOYJy9vHfR0h2Z7MmtiuUvMuMmvmeJg3m7ZSVIAkygFbsqgI1CGSr4ey+kSAl7wg2VxAjYnhLFzAhBqV6n28TRnjVt8wDVugfci9d7mPUd5o0IopVKjKrB1uAQ8+91O6fvUAIGbQ7a1WbM2mQ/QnGDXGBsjZo0TmtDJSkQkx8CNYp48syMOuc30zOUyq9aMyUuZy3e517f1zUuRbkuyuC+cvqVS/xkqeQbM4RL8bnek0wXP4gRqThCzOKHOZw0p4+YnOGnOOBApcAuUcTN6T0LrXOWBnSncrlKNN+iT9e5xLEkWo2agGGf2va1JpVKd9vo6OYfPGjc2JxBR5DBwo5gnz7iJoz8yE90ZN/U6L3lQJU7p7ycL3BJlpVJ5o0FjCHPcAPf6JbtT+6IdZzQEncEWqDnBGeYaNzGbFrCr1E+Gp3njQLwdmnKCIPjsnABoNzEY/WTkQgls5Nk6kTjrTyvbBrjPU/22NqlUaggeuGk3J3CNGxFFBgM3inn1GhkbMeMm32wd0F403jfPOwZDDNzkJTMgcBemXq+TOj0DbWgfStAh7ZygFbhJGbdQS6XBu0r9ZZWkUmmTMm7u91AduMnfe1OQDVfl5VH5+JOmlErl0hK0AzedTqd4boNe17SdE0IYB6IO7N2lUgZuRBQZDNwo5jVqZGzE7lGzKnDTWjQ+tCBd+lo+AFXeoNAQZDG/GCxoZY9EcSFkcCwBsmRiAjDUvSzFjJtWMBmsOSE9wf3+ZSSYNe8PxN8AXnmmSV4q1SLPyMnXi4Wym4EhQFDoL3ADlI0BafGmkHeoUL526M0JYnBaZ3VIn3coW3oREQXCFieKeeI+jyKjXidt5K7OYKkzIT07JCFVdjE36HVIMBtQb3OizupEZpL79mDjMwx6HexOIWDGLS6cjJtGlkwqlYaZcdPK3kkZRD9r3P46sSf656fiwiEdQ3otOfkuBHJ2hyzjFiSbJb8/PzUOp/fIRLzJiMQwtrzSkhbvPxCNl61zCxTgBRLOOJDUeDPKaq2oszo0S8hERE3BwI1injrLlZlklrJSwTJuwwvToZZoMaLe5lQ0KATLuInBlFYnpchfkCQnZtwatfYqFUulIV7bpTVuGscUaCcIAMhJicNVozqH9kIq/gbwyrceCxRcAcp1ajqdDu/ffGrIrx9oDWBqoIyb7LNNb0KmUf7a/hpUAO/7kJ5gQlmtFTVWh3QbAzciai7+LUIxT12Sy0y0SF9bDMr9StVjGk7p7Bu4SbPcZIN9xQyYvzVW4gU70Ib2oa1xE4MtZZZM3igRkYxbC5bmpFKp3ak4bvkokGBlyKasLxOpg0L5ujGtGW4i+Web1szALWBXqUsM3NyvUWd1SJ2mWo0VREThYOBGMU8r4yZSrxlTl7CGFKT5PF+iOBKk0Ru4BSuVip2P4uMSzQZ8esdpGN7FGxj6+1k5f8GWPBAItTnB3xo3p8vb3dmSgRugPA/12q5AmhPAqDNuBekJ0teBSqBxioxbE0ulIYwDEUvG4rHUWZ3S59GcgJWICGDgRm2AujyZleTNuIkXQq1S6XWju6BHhySf5xMbFMIqlep1Po87pXO6YvxEKB2R/kZ4yDOFoTYn+AsC5YFcKMFkuORNGPIMpBicaM1RU2tOydCoqiUXZMRLXwde4yYL3BJbLuNm92TcxMCtlqVSIoog/i1CMc3pEqSgTJQpu+iq17iJF9QLBudj9oUDNEt2SRr7lQabpm9UlUrFC7C8ISGUjkh/wZZL9m24c9zUGTdF4NaE3QGCMRr0UsAsH9Witd0VALxxw3Cc0jkNfXK9Y1mCjQsJxKDK1nWSZdxSApRKFSXVFmxOEN+HNJZKiagFMHCjmFZvc/jclinLuKkH2oay32dBhvtC//PuUuk2W5D9K9UZN3HchTwwCiXj5m/nBPli91B3TvDOcVMFbg7vWrNQs3fh0hoJ4l3jpnzNCX1y8Okdp6NfvncQcrBxIYGo17jlpsZJX4deKm1mc4JG4CYIAlwuQeoqlWfcWColokhhVynFNK1mgKwk34ybFLgJwYfYXjmyAG/9dgDfbS3G0coGdEyLl0qX/jZdN6oCN/ECLB8xEdIaN5P3eAXBPQT46tdXK3421DVu4rGqB76KgVxThuuGKt5kQFWDXRE0ere70n5deWCrLneGQx2UyzOwAee4RWKNW4CM2zX/WY3yWpv0nohl2zqbQyrPs1RKRM3Fv0XIhyAIim5BAHj7twN4/vtd2HDoRKsei9b4DcUaNz+l0kDjKPrkpmB0t0w4XQLeXXlQ8fP+Ajd1V6l4AZYHA6Fl3NyPEQR3wPXRuiNYd/AEft1T7vNawYjHoN5iKdjw3UiQd5aKbI7As8rktzcn8yTvurUY9Yrfh4Br3CLRVarTHgdid7rw655y7CiqwYl6OwBvcFjb6JA+I5ZKiai5GLiRgs3hwrn/+BnX/meNFLztKq7BrC+34sWlu3HJK79h6fbiVjserZ0KFF2lqjVj3llogS+Q004vBAB8sOYQGmxOb+DmJ6AQM0Ri4CYGePJgIJRASZ5Zszqc+HLjUZ/HhDoORAwCfPfGDNwhGwlxGrPc/K1xE8m7TZsTwMg/W4tRr/h9CLxzQuRKpeqMW73V9/fUu8bNyQG8RBQx/FuEFPaW1mJHUQ1+2VOGkhorAKC4ulG6XxCAuxZuxOYjVa1yPGJgIM9CZYaQcQt2fZzYNwcFGfGoarDj841Hpa4/fxk3vXqNm0Hc6zO8wE0eGB6rbMTvB3wzmKHuxCQ+lzqIWL3Pnb3rnZPi8zOREm9SBrLu4wg8DkTebRqpAMZsNCAvNR56nTtoC/QZRGQciJ81bnUaazFT4t3lUZvT5S3FM3Ajombi3yKkcLC8Tvp66zF3cFbV4C79nNI5DaO6ZqDW6sDU11bhpR93o6zW2qLHIwYGuSlx0OncJVBFV6k0gNf9OLGEFWwNlUGvw/WjCwEAC9ccknWVhrbGTQxOws246XQ66TV+21vmc79eh5D30BSzVuqu2x92lAAAJvXtENLzNEWCZ81WYzilUlnwHcqst1BYjHpkJ1uw4JpheO264QEfK3+fIj2AV77vrUjsXnbf736fWColouZi4EYK+8vqpa+3HK0GAFR61uxkJVnwnxtGYHS3TNRaHXh2yS789YMNLXo8YldpdrIFcy4agHmXDlIESNJif7tyr9JQFvif2i0TAFBU3RjyGjfxdcyeEq28/BbKGjfAGxzKBwCrXycUJo2MW2mNFX8crgQATOjTcoGbeN7yTFOwAbzyjFtTNnjXIr6XZ/fPxYjCjICPlW8z5u9zDsZfqbROo6SfKA/cPO8TS6VE1Fz8W4QUAmXc0hJMSLIY8daNIzDz3D4AgO3H3cGdIAg4XtXg09TQXGKGK95kwNWjuuCyYZ0U93szbsoBvKFcH71z0FxBS6Vixk0MJM2aGbfQ/neS1odpNF6EE9CYNNa4rdjlHnEyqFMqOqTEaf5cJCTHuYOSmkatwM3f7hORzzaFE4CptxlrCn97ldZrZNziTAap7C0+PFKZRiJqvxi4kcL+Mnng5g7KvIGbu7xkMRpw9aldAAAn6u2oarDj6e92YvTcH/HVpuMRPR6xVJrgZx9Qi981bqFvP1VrdUgXVoshtJ0TpAG8YXaVAt4sodaok1AbE+TH4JCNAzle2QAA6JfXcuvbACAlzr1GrNrzuwEo9yrV0pyhu/74K21ryUttfiArfj6hZNxMBp3Pe8GMGxE1F+e4tWNWh9NnQ/CD5d5S6ZETDaist6Gy3gYAiu2dkixGZCWZUVZrw4pdpXhl+V4A7rEh5w/Oj9gxis0J/jZwV3eVOsLIuIkBlHy9kt+Mm0EM3JRZJXmWLdTxG+Ixa62LCqdUKq7js8kybi25ubycuENBdaM3cLMF6ZxsiYybv50utFx/WiEOn6jHpL45TX49v80JGp+lSa+H2ahX7JLBwI2Imot/i7RTpTVWjJjzA2Z8+Id0W4PNiSJPB6m4sHp/WZ20xi1VtZ1Ql8xEAFCscyuvs0X0OMUMl7+Mm7qrVCxhhZK50gpu/K9x85RVA8xxCz1w82wXpZGlCWejA7Nn9wGHPHDzBJYtHrh5SqXVDd6AxRFkAK+/z7A5wimVxpkMmHPRQIzv3fS1f941bqoRLKquUoNeB71e55MRZKmUiJqLgVs79d6qg6hudOCzDUfx654yzPpiC1Z5xkikxBnRIcU9csPqcKFStsZNrktmAtT2l9WhvNYasbVu4poyf2VIdanUEVapVPkYg17nN+Pls3OCOMfNHP4aN2/g5pulCWeLKjHjJt85wTt8t2X/107VyLhJa9z8nMOFQzpiUKdU/L+x3SJ2HOGUSiPBm3FT3q6e4yb+vrBUSkSRxlJpOyUPGp5bshPrD1Xibc8uAl2zk2D1BAB2p0tax6SeSt8lI1H6OifFgjiTAQfL6zFszg84s3c23pw2stnHKY5RSIrT/lX1bnnlGQcSRqnUXSb2LhwPNGPLIDUniPO4fJsT/JVz1cSAS73RPBDmGjdpyyvv8zS0wq4JgKxUqljjFrhUGmcy4MvpYyJ6HC25rZcWaRyI6h8mtapSqfi7pM4IMnAjoubi3yLtlLxMd6iiQfq6Y1o87p7UU5HJ8lcqLczyZtzG9MjGgI6p0vfLdpb6bH7eFOIFMcmiPTDVZ6/SMDJu8plq8ufSIgZUjQGaE+JCXG8lXvzVOx4A4WXcTBrPI3ZOxrVwJkpqTpB1lYpZz+ZsIB+u1h5o6685QZ09Fdfz+QZuLJUSUfPEROD28ssvo7CwEHFxcRg1ahTWrFnj97GvvfYazjjjDKSnpyM9PR2TJk3yefwNN9wAnU6n+HPOOee09Gm0KfKORqen7vPUpQOx/O/jcWbvDlJgYnO4UNngXremLpV2zvAGbmN7ZWFwp1TF/fIO1aYSZ50lWQI3J4gL9EPdOUH98+6vAwRuBmWpVMx2xTUl4+ZncC4Q3ho3cS6aS/CetxhYhnosTSXuCqDVVdqaWaVwmhMiQfw98N05QfmPFJNGxs2o10Vsfh0RtV9RD9wWLVqEGTNmYNasWVi/fj0GDx6MyZMno6SkRPPxy5cvx9SpU7Fs2TKsXLkSBQUFOPvss3H0qHLPx3POOQfHjx+X/nzwwQetcTpthry0I26KPaprps8Fp8bqkBa8p6oCt65Z3lLpad2zMGVEZ1wytKN0277SpgduNY12lNdavRm3YKVSzzGKJaxQBvACyrVggTJuRtXEfDHTo1jjFmIQIR5bs0ulsuyNGDS1WldpnP81bq2ZBeuUHt9qrwUEGAeiKpVK/x+1wDZfRNS+RX2N2/PPP49bbrkF06ZNAwAsWLAAX3/9Nd544w088MADPo9///33Fd+//vrr+OSTT7B06VJcd9110u0WiwW5ubkte/BtWIVG96d80rsYxJR69is16HVItih/XdISzFhwzTAY9DpkJ7ubGZ6fMgTQAZ+uP4p9pbVNOjZBEDDumeWwOVzomOa+MPstlaoG8IqBlTHE1JU8YxOwVKp6PvGxSRYjLhicD6dLkLJQwYjHpplxa8LOCYA3kBAzqS2diRLXuDXa3ftwWoyGVt1IfcE1w7BkaxFuiWCjQyj8jwNRZ9x8S6Xc7oqIIiGqgZvNZsO6deswc+ZM6Ta9Xo9JkyZh5cqVIT1HfX097HY7MjKU290sX74cHTp0QHp6OiZMmIA5c+YgMzNT8zmsViusVu+em9XV1U04m7alVGOP0WRZVksMiMTALSXOqFnmOWeAb3DcPTsJALCviaXSg+X1UmC5s7gGgHLfRzlxcbrvAN4mZNwCBBzqQFCe7Xpx6tCQXkskbZ+llXFrYuBmd7gAi3wcSMsGT8kWo9TYUdPogCXJIGXcWiNAOWdArubvXksTP59GhxNVDXZY7U48u2QnVu8vVzzOKGWuZf8wYMaNiCIgqn+TlJWVwel0IidHORAzJycHRUVFIT3H/fffj/z8fEyaNEm67ZxzzsE777yDpUuX4qmnnsKKFStw7rnnwunUXiw/d+5cpKamSn8KCgqaflJthBiQiQyqmVMmVcYtnE25u3lKqE3NuG307LUp5y9wEy+GYlepGLiFmrkKeY2bqtmhOVkl8eJv02pOCKNUatDrpC2V7C5lqTTUXRyaSq/XSZ+JuM4tGmvcWpv42R0sr8epTy7FPR/9gQ/XHlFs/QVojwNhxo2IIiHqpdLmmDdvHhYuXIjly5cjLs67nc2VV14pfT1w4EAMGjQI3bt3x/LlyzFx4kSf55k5cyZmzJghfV9dXX1SB2+1VofP8NckizKjZlFl3NQdpYF0zfYEbmV1EAQh7AXZmoGbnzVu8u5XQRCkAbyhl0rDW+Mmikjg1szmBPE4bA6XVKa0ttIAXsC9zq2m0SF1lorHcDJnluQZ0Qa7Ez/vLtN8nPi7pPjH0En8vhBR64nq3yRZWVkwGAwoLi5W3F5cXBx0fdqzzz6LefPmYcmSJRg0aFDAx3br1g1ZWVnYs2eP5v0WiwUpKSmKPyczdbYN8M1oSWvcasMP3AozE6HTuUtoZbXh76QQTsZNzJi5BPc6L3GtV+jNCc1b49YUgQK3cEqlgHckiLhrQWvNcQN8Z7nZpIzbyZtZUjeP+DtXKeNmDK0UT0QUqqj+TWI2mzFs2DAsXbpUus3lcmHp0qUYPXq03597+umn8fjjj2Px4sUYPnx40Nc5cuQIysvLkZeXF5HjbuvCCdzKPYFbsp+Ml5Y4kwFpnou6VhNEIDaHC9uO+a4x9FsqlV0YbQ5X2GvcLCFeWNUZt+ZchCNVKgV8h/C21s4JgGzbK09nqV2a43byBijq3yt/AbJWVylLpUQUCVH/G3bGjBl47bXX8Pbbb2P79u24/fbbUVdXJ3WZXnfddYrmhaeeegoPP/ww3njjDRQWFqKoqAhFRUWorXWvp6qtrcXf//53rFq1CgcOHMDSpUtx4YUXokePHpg8eXJUzjHWlNQ0+tyWqJqTJl54ajxjDsLN4Ihrwpyu8La+2lta6xPQGPQ6v4GIOnCT9ioNuTmhaRm35pS91KNF5MIN3OTbXgmC4J3j1qoZN/fviJjtPJlLgurfA63N5QHtOW4n8/tCRK0n6mvcpkyZgtLSUjzyyCMoKirCkCFDsHjxYqlh4dChQ9DLFoa/8sorsNlsuOyyyxTPM2vWLDz66KMwGAzYtGkT3n77bVRWViI/Px9nn302Hn/8cVgsllY9t1ilmXGLU5ZCxQuOuLNPuBmcQMFJIOpF3oDv+js5g14Ho14Hh0uA1eGCw9mMjFuAERq+gVvTsyeBji3cUqm49Zbd6V7nJr7dllZa4wbIMm7toFSqzrz6+/XWGgfCwI2IIiHqgRsATJ8+HdOnT9e8b/ny5YrvDxw4EPC54uPj8d1330XoyE5OWuVL9c4E6lJgqMNlRf72dAymQWObLH9lUpHZqIfD5kSt1eHNuIWYuZLvdRmoq9SnOSECa9y0hDPHDfCOnbA7BcV71yqlUtXuCdKWVydxgBLq52PUzLidvAEtEbWek/dvWPJLO3DTXuMmCr9UKmbcfNdxBdJg0864BdLN08X62P+2SsFD6Bm3UEulyvsszSqV+v/Z8LtKvRk3qydw0+laZyG8mHGrakfjQNSDd/0xa6xxO5nfFyJqPU36m8ThcOCHH37Aq6++ipoa94DUY8eOSevMKLaJm8bnp3pHqCSqAzfVRSZQNkqLt1Qa3rFpZtyCNEY8felgxJsM+Hl3Gf44UgUgjMAt1AG8hshl3AKtYwtnyyvAGww4nII0fDfeZGiVPTEzk9yz/co9ncPi75V6h42TSWZSaMsttDaZZ+BGRJEQ9t8kBw8exMCBA3HhhRfizjvvRGlpKQB308C9994b8QOkyBMzbp3SvZvEqy+2zc24iSUlhyrj9u3m47hr4QbUa2TWAKDB5n68fEP7YBm3fvkpGNMzS/P1g4kLeQBvBJsTApTMwi2VmqRSqavV9ikV5aa4A//j1Y2wO104VFEPACiU7WF7sslINOPrv47BJad0DPg4MatqYamUiCIs7KvPXXfdheHDh+PEiROIj/du8HzxxRcrxnpQ7DpRLwZu3s/PJ+PmE7g1LeOmrpTe/v56fLHxGP67+pDmz4kZNzEoAIIHboBvtizkAbxhbjIvas5FOFDGLdxSqVFWKpVGgbTSOI5cT8a2qKoBR040wOESEG8yKD67k1H//FT0zVXOerx1bDc8c5l3nqTZyIwbEbWMsGsaP//8M3777TeYzcotkAoLC3H06NGIHRi1HCnjluHNuKnLkT6l0nAzbp7gZG9pLd74dT/uGN8dgwvSpPvVm3KLxOAjPy0eO4oC71Mqpw6kQm5OCHEvSZ8BvBEYBxLK6wRjkjcn2Fo54+YJ3EpqrNjl2VO2MCsx7KxhW5Sgaua5bnQXaecIwJtxU85xY+BGRM0XduDmcrk09/w8cuQIkpOTI3JQ1HIEQdDMuAVrTgh7jZsnkJr15VYAwI87SvDDjHHS/eq5cSKxhJojz7iFMPxXnc1o0ibzYWTcLGF22coF7CoNe42btyTd6Gi97a4AICvRIo1iWb2vAoC3UeRkl2hW/k4mmI3SPzoAf3PcTv6AlohaXtj/BDz77LMxf/586XudTofa2lrMmjULf/rTnyJ5bNQC6mxOKTNQIFvjpg7c1IFQU7tK5fbKNp2v1pjXBijXuIlBVUgZN2PTArdQu0rVWaTUhNC3AFOL5Bw38XOyOVytumsC4H5PxAD7t73uPTu7ncTr2+QSzAaf7+X/uBH/9+GWV0QUaWH/TfLcc8/h119/Rb9+/dDY2IirrrpKKpM+9dRTLXGMFEEnPGXSeJMBWUnecrc6OFJn2MIO3DQyR3tKZIGbZ4SEWoNs8n9avFnz2LSoL4ohNyc0IeNm0Ouk7Z6aIpIZN7Ek53AJssCtdTJuAJDnKZeKZe12k3GT/U4a9DpYjHrFcgJxfCG3vCKiSAv76tOpUyf88ccfWLhwITZt2oTa2lrcdNNNuPrqqxXNChSbxPVt6QkmxcUnaHNCmKVSzYybLHCrarBj3cEK9OiQrNjAXr5lU2q8CUXVjSGWSpWvF3JzgqKrNNDOCd7zT08wNWvchtZ6OXGbr3ADN3ERvLs5wX1bawZuuanKRoSuWUmt9trRJM+4JZjd41fk/9gRB0+zOYGIIq1JaQOj0Yhrrrkm0sdCraDCs74tPdGsWKej3kQ+UgN45eSl0s82HMVnG46ib14Kvr3rDOl2cYF9vNmADikW7CyuQUai2ee51NQXxVADIOWWV6Fl3NISgh9PID4b1hu9gVu413blXqXeOW6tRd5Bqte1z4ybGMTJP1cp48ZSKRFFWNiB2zvvvBPw/uuuu67JB0MtTyyVZiSakWgxwGTQwe4UFFkvwDcQsoS5bko7cKvzuW378WoUVTWiqLoRQwrSUC/LuN1/Th+MLCzB+N7ZQV+v6c0J4XeVpjdjfZv6uQDPxd2zfWz4zQneOW6eMW5hf1bNIc+4nd0vV9pN4WQnz7iJ/wCSZ2HFrdfk/zBgqZSIIiHswO2uu+5SfG+321FfXw+z2YyEhAQGbjHuhGe6fXqCGUaDHnMvGYQ6q8Mni9TcvUq1SpW1Vu2GhKmvrcL+sjp8cvtoNMoybgM6pmJAx9SQXk+dLQu9VBr+XqXpzcy4qQM3+euGP4DX01XqdEm7VLRmqVSeDb3utC6t9rrRJs9Wq0eDAN7AzWzw3sdSKRFFQtiB24kTJ3xu2717N26//Xb8/e9/j8hBUcuRZ9wA4LJhnTQf1xKlUn/2l7kzca/9tF/RnBAO9Rq30JsTQt2rtOUCN/nrNnXLK7tTgFUcB9KMUSXhOqVzOgx6HQrS4zG6W2arvW60yYO1BLPvX6NiEM01bkQUaRHZVLBnz56YN28errnmGuzYsSMST0ktRFzjlhak3OfbVdr8UmkwP+0uRX5avOf1wg3cVKXSSK9xkwWGaYnNKwf6zoSTj5EIs6tUY+eEeHPrBQiFWYn4/m9jkZlkaZX9UWOF2aCXZtglmjUybi6t5oT28/4QUcuJ2G7QRqMRx44di9TTUQs5IXWVBs4a+axxCzOL05TArd7mlLJv6jlZwTR1jVuom8wru0qbl3FTr2OTv7fhxj7iMTtcAqziXqWtmHEDgG7Z7aOTVE6n0yHBbEB1o0Mz46a1xo0ZNyKKhLADty+//FLxvSAIOH78OF566SWcfvrpETswahnlte7ALSvJEvBxzd05QR7oyKUlmFBZr5zhptN5u/CcnkxFfJiBmzroCrk5IcQBvPIMXkZzu0oNkSuVis/lHsDbujsntHeJFqMncPN9v7XGgXDLKyKKhLADt4suukjxvU6nQ3Z2NiZMmIDnnnsuUsdFLaSszt2+mJkUOPgwq0qI4S6a99cckGAywGZ2od7m3R5IEHwfF/YaN6Nqr9IIbzJvUIwDaV6p1Dfj1vRSqUnKuLmk7cJaa+eE9k4M2NQzEAEg2/MPI+U4EJZKiaj5mrRXKbVd3oxbkMBNlh0Id/gu4H+shcVkgL3WGvTnm73GrSlbXgXIiMizZOkhzJULxKjKRsov7uGuE5OaExwCDlU0AFDu80otRwzY5Bm3BdcMw5d/HMWdE3oAUP5OsVRKRJEQsTVuFPtsDheqPFtNZSYGLpXKF1I3pfTmL+NmMeqlvVIDCbdU2tTmBINeh07p8ThRZwuYhWzRrlKDPOMW3nOJn1OD3SntTNEnN6VZx0eh0cq4nTMgF+cMyJW+V255xcCNiJovpMBtxowZIT/h888/3+SDoZYlbndl0Ot8Bu6q6XQ6aSumpgx09VdaDTUIDLdU2tS9SgHg0ztOg9Xu0lxkriXSA3jle1yGvcbNk73bXVILm9OFBLMBndK59VxrEGe5Bfpd1et10pBrlkqJKBJCulJt2LAhpCdrT+MA2qIyT4kyM9EcUmAjbsXUlC7FQBm3UF63qWu9gr2+lg7JwUuLtY3e4cHBgt5gAo0DCXsAr+dntx+vBgD0ykkO+zmoac7ql4Mtx6pwapD5dWaDHnank6VSIoqIkAK3ZcuWtfRxUAvbXVyDLUerAACZQTpKReJWTE0plfoLvEJ5LksTLnDqGVlNGUcSiPy4m1vyUgdWisAt3DVuqufqk5vc9AOjsFw5sjOuHNk56OPMRj3qbE6WSokoIrjGrR0orm7E+S/9Io2LCNaYIBLLj03pUvQXOFmMetw8pite/2W/4vasJDPKPI0T4n6l4TAZm9acEKoRhem4bVx39M5t/swyrU3mRc3NNPZm4BZzxM+XA3iJKBKaFLitXbsWH374IQ4dOgSbzaa479NPP43IgVHkrNlfIQVtgLtUGgpxxEa4w3cB/6XKOJMBD5zbB+cPzsdlC36TGhXkGS1xlls4fOa4Rbhsr9Pp8MC5fSLyXIG2vAo346aeCcfALfaIv9vhzkIkItIS9t8kCxcuxGmnnYbt27fjs88+g91ux9atW/Hjjz8iNTW0DcGpdW04VKn4PtjwXVFzMm7+mxP0MBr0GFyQFvI+oaFQZ55ieZ2X7ybz3vch3MNWB6zd2+EuBrHupjFdMalvDgZ05N+PRNR8YV8tn3zySbzwwgv43//+B7PZjH/84x/YsWMHrrjiCnTuHHy9B7W+jYdPKL4PfY2bJ1MQ0XEgBtnXes3bm0JehgqnMSEafAO35uxVKn8P9eiQHNpnS63nutGFeP364c3+HSciApoQuO3duxfnnXceAMBsNqOurg46nQ5/+9vf8O9//zviB0jNY3O4sOVYteK2YLsmiMQsWFO6Sv2V/OL87A1qNuoDDsANRp5xi+VsGxCkq7QZpdKCjAR2dhMRneTCvlKmp6ejpqYGANCxY0ds2bIFAFBZWYn6+vrIHh012/bj1bA5lLtdhLrGTZw71ZQ5bqFk3OTlUYtBj+S4pvfKyAO3SK9vi7RIbnklD3Y7ZyQ078CIiCjmhX1FHjt2LL7//nsAwOWXX4677roLt9xyC6ZOnYqJEydG/ACpeXZ7pumPKEyXbgu1ZNOcjJvBTwddnJ+9Qc1GPa45tQsAYHiXdJ+fC0ZeKo3xhFvATebDPXZ5gMzAjYjo5Bd2iuOll15CY2MjAODBBx+EyWTCb7/9hksvvRQPPfRQxA+Qmqem0b3FVYfkONw+vjs2H6nCyK4ZIf1ss8aB+C2V+sm4GfWYPqEH+uWnYFSIxycnHwfShKbUVqV+bxTNCU0cwAu4S6VERHRyCztwy8jwXlT1ej0eeOCBiB4QRVad1T3xP9FiwP3nhDfOQsq4RXAAr7wsaFKtcTMZ9JjcP1frx4KSlwydQmxHboHGgYRb5jXJNqwv4FZXREQnvbBTKZMmTcJbb72F6urq4A+mqKu1uofZyjfCDpXYVRrRAbzyjJtBu2zaFPIgUIjxwM2oV55rs3ZOMMpKpZnMuBERnezCvlr2798fM2fORG5uLi6//HJ88cUXsNvtLXFsFAFixi2pCYHb+YPy0D8/BWf27hD2zwYawCtSrHFr5nZA8kCxKQN8W5MqbmtWqbTB5t1loiCdgRsR0cku7KvlP/7xDxw9ehSff/45EhMTcd111yEnJwe33norVqxY0RLHSM3gLZWGH7id3T8XX//1DPTMCX8av0EdnXhYVOvaRM3NuMnFeNzmk3FTlkrDe67uHdwDd1PijE36jImIqG1p0tVSr9fj7LPPxltvvYXi4mK8+uqrWLNmDSZMmBDp46Nmqm1G4NYc/hJo/psT2s9wUt+MW9PHgaTEmbDuoUlY9X/s6CYiag+adTUvKirCwoUL8d5772HTpk0YOXJkpI6LIqTOJpZKWzcwCiXjFsk1bm1JoIxbUwbohroTBhERtX1hXy2rq6vx5ptv4qyzzkJBQQFeeeUVXHDBBdi9ezdWrVrVEsdIzSA1J5hjO+PWngK3gF2lsT6EjoiIoirsq3lOTg7S09MxZcoUzJ07F8OHD2+J46IIaU5zQnP4y7j5G8BraceBm6UZ40CIiKh9Cftq/uWXX2LixInQ+7kwU2xpTnNCc4S05ZVBezTIyc53r1Lv+8C4jYiIAgn7an7WWWe1xHFQC4lWc0JIm8zLM25NmBXXVskzbjqdcruuGG+IJSKiKGs/V8t2SBCEqJVK/c5x87PJfHvKuMnLoUa9Tlk6ZeRGREQBtJ+rZTvUaHdJM80SW72r1N/OCfJgzfuY9tScoNfrpJKoXqdTdJkKjNyIiCiA9nO1bIfEMikQja7SENa4tdOuUsCbdVNn3GJ9eDAREUVX+7patjNimTTBbAh7K6Xm0iqVmgzKIEVeHm1PA3gBb2Cr1+sU75UrxvdZJSKi6Ao7cPvrX/+KF1980ef2l156CXfffXckjokiJFqNCYD2nptxquDM7Cf71h6IwZpBr1O8V4zbiIgokLCvlp988glOP/10n9tPO+00fPzxxxE5KGqaBpsTd76/Hl9sPAogejPcAO2Mm8WkDtzaZ3MC4A1s1e+TwMiNiIgCCPtqWV5ejtTUVJ/bU1JSUFZWFpGDoqb5/UAFvt58HK8s3wvAu91VazcmANoZN/WQ3fa8xk0M2NRjUxi2ERFRIGFfLXv06IHFixf73P7tt9+iW7duETkoapp6T6AmBmzR2u4K0M645aQo99RUrnFrX4GbQVYqlWPCjYiIAgn7ij5jxgxMnz4dpaWlmDBhAgBg6dKleO655zB//vxIHx+FocHuDtQabO7/RrNUKg9IkuOMeHHqUHTPSlI8xtJOt7wC/AdubE4gIqJAwr6i33jjjbBarXjiiSfw+OOPAwAKCwvxyiuv4Lrrrov4AVLoGmwuAECdVRm4RaM5QR6QGPU6nNm7g89j2nep1H2+voFbNI6GiIjaiiZd0W+//XbcfvvtKC0tRXx8PJKSkoL/ELU4KeNmd8LlEqLaVSovlfrbcL49B27iW+JbKmXkRkRE/jXrip6dnR2p46AIaPQEboA7ePOWSqPQnKDa1kmLyRDZrlK9ru1krKSMG3eVJyKiMIQUuJ1yyilYunQp0tPTMXToUOgCXGzWr18fsYOj8Ihr2wCg3ubEiXo7ACAlztTqxyLfxsnfLgqK5gRT84NLg14Hl7NtRG7+1rgN7ZwejcMhIqI2IqTA7cILL4TF4u4IvOiii1ryeKgZGuzywM2BnUU1AICeOa1fyjbI9iE1GvwEbhGe4+bO8rWRwE2nDNx+uf9MHKqox7AuDNyIiMi/kAK3WbNmAQCcTifOPPNMDBo0CGlpaS15XNQE8sCtusGBncXuwK1fnu/cvZYmLwH637fUG6yZ/AR34fh/Y7vhxR/34E8Dc5v9XC1NnXHrlJ6ATukJ0TwkIiJqA8Ja42YwGHD22Wdj+/btDNxiUKOsVLr5aBVsDheSLEZ0So9v9WNRd5VqyU62IC3BhOwkS8Dye6jumtQLY3tlY0DH1g9Uw2XwM4CXiIgokLCbEwYMGIB9+/aha9euLXE81AzyjNvagxUAgL55ya2+wTygDNz8dZXGmQxYfu94RZNCc19zeGFGRJ6rpRn8bHlFREQUSNhXzDlz5uDee+/FV199hePHj6O6ulrxh6JHEbgdOAEA6JeXEpVjCSXjBgBpCeaojCuJNmnLKwZuREQUhrCvmH/6058AABdccIGivCUIAnQ6HZxOp78fpRYm7yo9VFEPAOiXH53ATTnHjcGJmr9N5omIiAIJO3BbtmxZSxwHhaHW6sBbv+7HuQPz0D07CXtKarB8ZymqGuw+j+2WHZ3hyKFm3Noro59xIERERIGEXSrt2rUrxo4di3Hjxin+jB07tsnr3l5++WUUFhYiLi4Oo0aNwpo1a/w+9rXXXsMZZ5yB9PR0pKenY9KkST6PFwQBjzzyCPLy8hAfH49JkyZh9+7dTTq2WPSvZXvw7JJdmPjcCgDApOd/wpyvt2OHZ/yHXGaiubUPD4B6jRuDEzU2JxARUVM0KXArLS31ub2ioqJJgduiRYswY8YMzJo1C+vXr8fgwYMxefJklJSUaD5++fLlmDp1KpYtW4aVK1eioKAAZ599No4ePSo95umnn8aLL76IBQsWYPXq1UhMTMTkyZPR2NgY9vHFom3HQ19LmJlkacEj8U8+DsTfHLf2jM0JRETUFGEHbuJaNrXa2lrExcWFfQDPP/88brnlFkybNg39+vXDggULkJCQgDfeeEPz8e+//z7uuOMODBkyBH369MHrr78Ol8uFpUuXSsc3f/58PPTQQ7jwwgsxaNAgvPPOOzh27Bg+//zzsI8vFuWlesd71DT6lkdFJoMOKXHRWfiv1+sg/pr46yptz9icQERETRHyVX3GjBkAAJ1Oh4cffhgJCd5hoU6nE6tXr8aQIUPCenGbzYZ169Zh5syZ0m16vR6TJk3CypUrQ3qO+vp62O12ZGS4x0Ds378fRUVFmDRpkvSY1NRUjBo1CitXrsSVV17p8xxWqxVWq1X6Pta7Y5NlwdjPu8v8Pi4j0RyR+WhNZdTrYHcKzCppEEukfG+IiCgcIQduGzZsAODOaG3evBlms3ftlNlsxuDBg3HvvfeG9eJlZWVwOp3IyclR3J6Tk4MdO3aE9Bz3338/8vPzpUCtqKhIeg71c4r3qc2dOxePPfZYWMceTfU2h/T10u3aJWUAyEyMTplUJG5BxTVuvsTyMTNuREQUjpADN7GbdNq0afjHP/6BlJTojJmQmzdvHhYuXIjly5c3qUwrmjlzppRRBNwZt4KCgkgcYouol439+HFHsd/HZSZFpzFBZNTrYAWzSlrE8rGBzQlERBSGsBcfvfnmm0hJScGePXvw3XffoaGhAYA7ExeurKwsGAwGFBcrg4/i4mLk5gbeb/LZZ5/FvHnzsGTJEgwaNEi6Xfy5cJ7TYrEgJSVF8SeWyee1naj3v8YtWh2lIj1HXvgl9mswqCUionCEHbhVVFRg4sSJ6NWrF/70pz/h+PHjAICbbroJ99xzT1jPZTabMWzYMKmxAIDUaDB69Gi/P/f000/j8ccfx+LFizF8+HDFfV27dkVubq7iOaurq7F69eqAz9mWyDNugUSro1RkZOekX2LGjaVSIiIKR9iB29133w2TyYRDhw4pGhSmTJmCxYsXh30AM2bMwGuvvYa3334b27dvx+233466ujpMmzYNAHDdddcpmheeeuopPPzww3jjjTdQWFiIoqIiFBUVoba2FoC7eeLuu+/GnDlz8OWXX2Lz5s247rrrkJ+fj4suuijs44tFDSEHbtHNuEnlQHaV+hC3Z2WplIiIwhH2rIglS5bgu+++Q6dOnRS39+zZEwcPHgz7AKZMmYLS0lI88sgjKCoqwpAhQ7B48WKpueDQoUPQyy78r7zyCmw2Gy677DLF88yaNQuPPvooAOC+++5DXV0dbr31VlRWVmLMmDFYvHhxs9bBxZJ6u7s54frRXfDuqoNw+alSR7tUKgYnJs5x8yEFtXxviIgoDGEHbnV1dYpMm6iiogIWS9NKc9OnT8f06dM171u+fLni+wMHDgR9Pp1Oh9mzZ2P27NlNOp5YJ5ZKzx2Yh1vGdsOJOjvOf+kXn8dFu6vUKGXcGJyoSVteMeNGRERhCLuGdcYZZ+Cdd96RvtfpdHC5XHj66adx5plnRvTgSJtYKk00G9EpPQEDO6VqPi7apVIxUco1br4MbNwgIqImCDvj9vTTT2PixIlYu3YtbDYb7rvvPmzduhUVFRX49ddfW+IYSUXMuMWbDQEfFzsZN65xU2PgRkRETRH2FXXAgAHYtWsXxowZgwsvvBB1dXW45JJLsGHDBnTv3r0ljrFd2nasGq/9tA92p8vnPnEAb0KQwC090dQixxYqaT9OruPykZ7g/mzS4qP7GRERUdvSpI0sU1NT8eCDD0b6WEhm7rfb8fPuMvTKTca4XtnS7XanC3anuxvBX+D2wpTB0Ot0SI6LcuCmY1bJn2tHFyI72YJzBuRF+1CIiKgNaVLg1tjYiE2bNqGkpAQulzIjdMEFF0TkwNq76ga74r8i+Qw3f6XSi4d20ry9tRk4x82v1HgTpozoHO3DICKiNibswG3x4sW47rrrUFbmu7m5TqeD0xnajDEKzObJqqlLpWJjgkGvg9kQ22vHuI6LiIgossK+8v/lL3/B5ZdfjuPHj8Plcin+MGiLHIcnYKuos+GuhRuweEsRqhrs2F1SAwBIMBmgk42SyIryLglamHEjIiKKrLAzbsXFxZgxY4Y0IJdahphpW/j7YewpqcUXG4+hV04SdhW7d4hQl0nfvnEEHvliK+6b3LvVj9UfaVYZu0qJiIgiIuzA7bLLLsPy5cvZQdrCxAYEl+DdFkEM2gDfxoT++an45PbTWufgQqRnxo2IiCiiwg7cXnrpJVx++eX4+eefMXDgQJhMys7Fv/71rxE7uPZMzLjp/UzWjzc3qa+kVRm5xo2IiCiiwr76f/DBB1iyZAni4uKwfPlyxTornU7HwC1CHJ4NSOutDs37g81wiwWc40ZERBRZYQduDz74IB577DE88MADis3fKbLEjFvtSRC4MeNGREQUGWFHXjabDVOmTGHQ1sLEwK3Opt2pG2+K/cAtI8Gs+C8RERE1T9jR1/XXX49Fixa1xLGQjMPTnOD0lExP656JN6eNkO5vCxm3+8/tg/lThmBiX3YgExERRULYpVKn04mnn34a3333HQYNGuTTnPD8889H7ODaK0EQpDVuou7ZSRjeJd37mNY+qCbISYnDRUM7RvswiIiIThphB26bN2/G0KFDAQBbtmxR3Kfz0wFJ4RFHgciZjXrF3qMn6u0+jyEiIqKTW9iB27Jly1riOEhGvc0V4A7c5E7U2VrrcIiIiChGsMMgBjk0Mm4m1b6k6kCOiIiITn68+scgu8s342bxBGqvXjsMfXKTMeeiAa19WERERBRlsT9+vx3SLJV6Mm6T++dicv/c1j4kIiIiigHMuMUg7VIpGz+IiIjaOwZuMcim2ZwQ+3PbiIiIqGUxcItBWhk3NiMQERERo4EYpLXGjaVSIiIiYuAWg7QCNwszbkRERO0eo4EYpN7uCmCplIiIiBi4xSS7Q6tUyo+KiIiovWM0EIPsWhk3Bm5ERETtHqOBGKSVcWOplIiIiBgNxCCHxpZXLJUSERERo4EYZNOY48auUiIiImI0EIMcmjsn8KMiIiJq7xgNxCDtvUr5UREREbV3jAZikPZepfyoiIiI2jtGAzGIpVIiIiLSwmggBtm1NplnqZSIiKjdYzQQg+wa40AYuBERERGjgRhkdygzbka9Dnq9LkpHQ0RERLGCgVsMUg/gZUcpERERAQzcYpJ6jRsbE4iIiAhg4BaT7KquUgZuREREBDBwi0nqcSBsTCAiIiKAgVtMUu9VyowbERERAQzcYhIzbkRERKSFEUEMUq9xMxk5CoSIiIgYuMUku0tVKmXGjYiIiMDALSb5lEq5xo2IiIjAwC0mqee4cQAvERERAQzcYpJ6jZuFGTciIiICA7eYxAG8REREpIURQQxyeEqlCWYDADYnEBERkRsjghgkZtzEwI1r3IiIiAhg4BaT7FLGzQiApVIiIiJyY0QQgxwuZcaNgRsREREBDNxikphx65yRAADIS42L5uEQERFRjDBG+wDIl7jG7eYzuuGG0wsxrEt6lI+IiIiIYgEDtxgkb04Y0DEjykdDREREsYKl0hgkjgNhNykRERHJMTKIQTZPxs1k0EX5SIiIiCiWMHCLMZuPVKGm0QGAGTciIiJSinpk8PLLL6OwsBBxcXEYNWoU1qxZ4/exW7duxaWXXorCwkLodDrMnz/f5zGPPvoodDqd4k+fPn1a8AwiZ19pLc5/6RfpewZuREREJBfVyGDRokWYMWMGZs2ahfXr12Pw4MGYPHkySkpKNB9fX1+Pbt26Yd68ecjNzfX7vP3798fx48elP7/88ovfx8aSXcU10tdmgx7JcewdISIiIq+oBm7PP/88brnlFkybNg39+vXDggULkJCQgDfeeEPz8SNGjMAzzzyDK6+8EhaLxe/zGo1G5ObmSn+ysrJa6hQi6lhlIwCgMDMBn95xGhItDNyIiIjIK2qBm81mw7p16zBp0iTvwej1mDRpElauXNms5969ezfy8/PRrVs3XH311Th06FDAx1utVlRXVyv+RMPxqgYAwKS+ORjQMTUqx0BERESxK2qBW1lZGZxOJ3JychS35+TkoKioqMnPO2rUKLz11ltYvHgxXnnlFezfvx9nnHEGampq/P7M3LlzkZqaKv0pKCho8us3x7Eqd8YtLy0+Kq9PREREse2kW/1+7rnn4vLLL8egQYMwefJkfPPNN6isrMSHH37o92dmzpyJqqoq6c/hw4db8Yi9jle6M2753OKKiIiINERtEVVWVhYMBgOKi4sVtxcXFwdsPAhXWloaevXqhT179vh9jMViCbhmrrUcZ8aNiIiIAohaxs1sNmPYsGFYunSpdJvL5cLSpUsxevToiL1ObW0t9u7di7y8vIg9Z0twOF0ornYHbsy4ERERkZaoti3OmDED119/PYYPH46RI0di/vz5qKurw7Rp0wAA1113HTp27Ii5c+cCcDc0bNu2Tfr66NGj2LhxI5KSktCjRw8AwL333ovzzz8fXbp0wbFjxzBr1iwYDAZMnTo1OicZopIaK1yCe7eErKToZ/+IiIgo9kQ1cJsyZQpKS0vxyCOPoKioCEOGDMHixYulhoVDhw5Br/cmBY8dO4ahQ4dK3z/77LN49tlnMW7cOCxfvhwAcOTIEUydOhXl5eXIzs7GmDFjsGrVKmRnZ7fquYVL7CjNSYmDXs+troiIiMiXThAEIdoHEWuqq6uRmpqKqqoqpKSktMpr/u+PY/jLBxswsjADH94WuVIxERERxb5QY4+Trqu0rRLXt+VwfRsRERH5wcAtRlgdLgBAnJEfCREREWljlBAjHE53xdrIjeWJiIjID0YJMcLhcmfcTAY2JhAREZE2Bm4xwi5m3PT8SIiIiEgbo4QY4XAy40ZERESBMXCLEQ6XuMaNgRsRERFpY+AWI+yejBtLpUREROQPo4QYIXaVslRKRERE/jBwixHeUik/EiIiItLGKCFGiONAjNynlIiIiPxg4BYjvKVSfiRERESkjVFCjJCaE7jGjYiIiPxg4BYjxDVuJnaVEhERkR+MEmIEM25EREQUDAO3GMFN5omIiCgYRgkxQtpknl2lRERE5AcDtxhhZ8aNiIiIgmCUECM4x42IiIiCYeAWI7xr3Bi4ERERkTYGbjGCm8wTERFRMIwSYoQ0x40ZNyIiIvKDgVuM4DgQIiIiCoZRQozwlkqZcSMiIiJtDNxihLdUyo+EiIiItDFKiBHc8oqIiIiCYeAWI8Q1btxknoiIiPxhlBAjpAG8zLgRERGRHwzcYoAgCLItrxi4ERERkTYGbjHA6WlMAFgqJSIiIv8YJcQAhyxwY8aNiIiI/GHgFgPkgRvHgRAREZE/jBJigMMzCgTgAF4iIiLyj4FbDBAbEwDAwMCNiIiI/GDgFgPEUSAmgw46HQM3IiIi0sbALQaIw3eZbSMiIqJAGLjFAHG7K44CISIiokAYKcQAsauUo0CIiIgoEAZuMcC7wTw/DiIiIvLPGO0DaO9+3FGMLzYeAwCYuMaNiIiIAmDgFkUHyupw41trpe+ZcSMiIqJAGClE0dxvtyu+5xo3IiIiCoSBW5SU1DTiu63FitvYVUpERESBMFKIksp6u89tzLgRERFRIAzcoqTR7vS5jWvciIiIKBBGClHSaHf53MauUiIiIgqEgVuUNGhm3Bi4ERERkX8M3KJEq1RqYqmUiIiIAmCkECWaa9xYKiUiIqIAGLhFCZsTiIiIKFyMFKJEszmBa9yIiIgoAAZuUSJm3BLMBuk2IwfwEhERUQCMFKJE7CrNSrJIt7GrlIiIiAJh4BYlYqk0M8ks3cbmBCIiIgqEgVuUNGpm3PhxEBERkX+MFKJEK3DjzglEREQUCAO3KPEGbuYgjyQiIiJyY+AWJdIat0Rv4GZ1+I4IISIiIhIxcIuSRoc745ZoMXpv0xjKS0RERCRi4BYlDTZ3kBZn8s5xY8aNiIiIAol64Pbyyy+jsLAQcXFxGDVqFNasWeP3sVu3bsWll16KwsJC6HQ6zJ8/v9nPGS2NniAtnoEbERERhcgY/CEtZ9GiRZgxYwYWLFiAUaNGYf78+Zg8eTJ27tyJDh06+Dy+vr4e3bp1w+WXX46//e1vEXnOaLHafTNuLJUSEVEwTqcTdrs92odBYTIYDDAajdDpmjdBIqqB2/PPP49bbrkF06ZNAwAsWLAAX3/9Nd544w088MADPo8fMWIERowYAQCa9zflOaOlQQrcvElPZtyIiCiQ2tpaHDlyBIIgRPtQqAkSEhKQl5cHs7npEyWiFrjZbDasW7cOM2fOlG7T6/WYNGkSVq5c2arPabVaYbVape+rq6ub9PrhaNTIuHHnBCIi8sfpdOLIkSNISEhAdnZ2szM31HoEQYDNZkNpaSn279+Pnj17Qt/E/cmjFriVlZXB6XQiJydHcXtOTg527NjRqs85d+5cPPbYY016zaYSx4HEmQx4/orB+OePezDnogGtegxERNR22O12CIKA7OxsxMfHR/twKEzx8fEwmUw4ePAgbDYb4uLimvQ8UW9OiAUzZ85EVVWV9Ofw4cMt/pryUuklp3TCsnvHo2dOcou/LhERtW3MtLVdTc2yyUUt45aVlQWDwYDi4mLF7cXFxcjNzW3V57RYLLBYLH7vjzSXS4DN4c24EREREYUiahk3s9mMYcOGYenSpdJtLpcLS5cuxejRo2PmOVuCvAkhnoEbERERhSiqXaUzZszA9ddfj+HDh2PkyJGYP38+6urqpI7Q6667Dh07dsTcuXMBuJsPtm3bJn199OhRbNy4EUlJSejRo0dIzxkLGmRjP5hxIyIiolBFNXCbMmUKSktL8cgjj6CoqAhDhgzB4sWLpeaCQ4cOKerBx44dw9ChQ6Xvn332WTz77LMYN24cli9fHtJzxgKxo9Rk0MHATlIiIiIKkU7gMBgf1dXVSE1NRVVVFVJSUiL+/PtKazHhuRVIjjNi86OTI/78RER08mlsbMT+/fvRtWvXJnckkpvdbofJZGr11w30GYYae7CrNAoaNGa4ERERhUMQBNTbHFH5E27OZ/HixRgzZgzS0tKQmZmJP//5z9i7d690/5EjRzB16lRkZGQgMTERw4cPx+rVq6X7//e//2HEiBGIi4tDVlYWLr74Yuk+nU6Hzz//XPF6aWlpeOuttwAABw4cgE6nw6JFizBu3DjExcXh/fffR3l5OaZOnYqOHTsiISEBAwcOxAcffKB4HpfLhaeffho9evSAxWJB586d8cQTTwAAJkyYgOnTpyseX1paCrPZrFhrH2lRLZW2V94ZboybiYioaRrsTvR75LuovPa22ZORYA49hKirq8OMGTMwaNAg1NbW4pFHHsHFF1+MjRs3or6+HuPGjUPHjh3x5ZdfIjc3F+vXr4fL5b5Wfv3117j44ovx4IMP4p133oHNZsM333wT9jE/8MADeO655zB06FDExcWhsbERw4YNw/3334+UlBR8/fXXuPbaa9G9e3eMHDkSgHtc2GuvvYYXXngBY8aMwfHjx6W5sDfffDOmT5+O5557TppM8d5776Fjx46YMGFC2McXKgZuUSDuU8qOUiIiag8uvfRSxfdvvPEGsrOzsW3bNvz2228oLS3F77//joyMDACQGg4B4IknnsCVV16pGJQ/ePDgsI/h7rvvxiWXXKK47d5775W+/stf/oLvvvsOH374IUaOHImamhr84x//wEsvvYTrr78eANC9e3eMGTMGAHDJJZdg+vTp+OKLL3DFFVcAAN566y3ccMMNLTprj4FbFDQ6WColIqLmiTcZsG12dNZJh5t42L17Nx555BGsXr0aZWVlUjbt0KFD2LhxI4YOHSoFbWobN27ELbfc0uxjHj58uOJ7p9OJJ598Eh9++CGOHj0Km80Gq9WKhIQEAMD27dthtVoxceJEzeeLi4vDtddeizfeeANXXHEF1q9fjy1btuDLL79s9rEGwsAtChpsnlKpkYEbERE1jU6nC6tcGU3nn38+unTpgtdeew35+flwuVwYMGAAbDZb0O27gt2v0+l81tzZ7XafxyUmJiq+f+aZZ/CPf/wD8+fPx8CBA5GYmIi7774bNpstpNcF3OXSIUOG4MiRI3jzzTcxYcIEdOnSJejPNQcXWUWBtMG8mYEbERGd3MrLy7Fz50489NBDmDhxIvr27YsTJ05I9w8aNAgbN25ERUWF5s8PGjQo4GL/7OxsHD9+XPp+9+7dqK+vD3pcv/76Ky688EJcc801GDx4MLp164Zdu3ZJ9/fs2RPx8fEBX3vgwIEYPnw4XnvtNfz3v//FjTfeGPR1m6tthOonmTN6ZeG/N49CUhzffiIiOrmlp6cjMzMT//73v5GXl4dDhw7hgQcekO6fOnUqnnzySVx00UWYO3cu8vLysGHDBuTn52P06NGYNWsWJk6ciO7du+PKK6+Ew+HAN998g/vvvx+Au7vzpZdewujRo+F0OnH//feHNOqjZ8+e+Pjjj/Hbb78hPT0dzz//PIqLi9GvXz8A7lLo/fffj/vuuw9msxmnn346SktLsXXrVtx0003S84hNComJiYpu15bCjFsUdEiOw2k9sjCoU1q0D4WIiKhF6fV6LFy4EOvWrcOAAQPwt7/9Dc8884x0v9lsxpIlS9ChQwf86U9/wsCBAzFv3jwYDO6q1Pjx4/HRRx/hyy+/xJAhQzBhwgSsWbNG+vnnnnsOBQUFOOOMM3DVVVfh3nvvldapBfLQQw/hlFNOweTJkzF+/Hjk5ubioosuUjzm4Ycfxj333INHHnkEffv2xZQpU1BSUqJ4zNSpU2E0GjF16tRWma/HAbwaWnoALxERUbg4gDc2HThwAN27d8fvv/+OU045JeBjIzGAl7U6IiIiojDZ7XaUl5fjoYcewqmnnho0aIsUlkqJiIiIwvTrr78iLy8Pv//+OxYsWNBqr8uMGxEREVGYxo8fH/bWX5HAjBsRERFRG8HAjYiIqA1hT2HbFYnPjoEbERFRGyCOxxAn+1PbIw4GDmXOnD9c40ZERNQGGI1GJCQkoLS0FCaTCXo9cy9thSAIqK+vR0lJCdLS0qQgvCkYuBEREbUBOp0OeXl52L9/Pw4ePBjtw6EmSEtLQ25ubrOeg4EbERFRG2E2m9GzZ0+WS9sgk8nUrEybiIEbERFRG6LX67lzQjvGAjkRERFRG8HAjYiIiKiNYOBGRERE1EZwjZsGcUBedXV1lI+EiIiI2gMx5gg2pJeBm4aamhoAQEFBQZSPhIiIiNqTmpoapKam+r1fJ3DvDB8ulwvHjh1DcnIydDpdRJ+7uroaBQUFOHz4MFJSUiL63LGsPZ43z7l9nDPQPs+7PZ4z0D7Pm+fcOucsCAJqamqQn58fcLgyM24a9Ho9OnXq1KKvkZKS0m7+B5Brj+fNc24/2uN5t8dzBtrnefOcW16gTJuIzQlEREREbQQDNyIiIqI2goFbK7NYLJg1axYsFku0D6VVtcfz5jm3H+3xvNvjOQPt87x5zrGFzQlEREREbQQzbkRERERtBAM3IiIiojaCgRsRERFRG8HAjYiIiKiNYODWyl5++WUUFhYiLi4Oo0aNwpo1a6J9SBHz6KOPQqfTKf706dNHur+xsRF33nknMjMzkZSUhEsvvRTFxcVRPOKm+emnn3D++ecjPz8fOp0On3/+ueJ+QRDwyCOPIC8vD/Hx8Zg0aRJ2796teExFRQWuvvpqpKSkIC0tDTfddBNqa2tb8SzCE+ycb7jhBp/P/pxzzlE8pq2d89y5czFixAgkJyejQ4cOuOiii7Bz507FY0L5nT506BDOO+88JCQkoEOHDvj73/8Oh8PRmqcSslDOefz48T6f9W233aZ4TFs651deeQWDBg2SBq2OHj0a3377rXT/yfYZi4Kd98n2OWuZN28edDod7r77bum2NvF5C9RqFi5cKJjNZuGNN94Qtm7dKtxyyy1CWlqaUFxcHO1Di4hZs2YJ/fv3F44fPy79KS0tle6/7bbbhIKCAmHp0qXC2rVrhVNPPVU47bTTonjETfPNN98IDz74oPDpp58KAITPPvtMcf+8efOE1NRU4fPPPxf++OMP4YILLhC6du0qNDQ0SI8555xzhMGDBwurVq0Sfv75Z6FHjx7C1KlTW/lMQhfsnK+//nrhnHPOUXz2FRUVise0tXOePHmy8OabbwpbtmwRNm7cKPzpT38SOnfuLNTW1kqPCfY77XA4hAEDBgiTJk0SNmzYIHzzzTdCVlaWMHPmzGicUlChnPO4ceOEW265RfFZV1VVSfe3tXP+8ssvha+//lrYtWuXsHPnTuH//u//BJPJJGzZskUQhJPvMxYFO++T7XNWW7NmjVBYWCgMGjRIuOuuu6Tb28LnzcCtFY0cOVK48847pe+dTqeQn58vzJ07N4pHFTmzZs0SBg8erHlfZWWlYDKZhI8++ki6bfv27QIAYeXKla10hJGnDmJcLpeQm5srPPPMM9JtlZWVgsViET744ANBEARh27ZtAgDh999/lx7z7bffCjqdTjh69GirHXtT+QvcLrzwQr8/09bPWRAEoaSkRAAgrFixQhCE0H6nv/nmG0Gv1wtFRUXSY1555RUhJSVFsFqtrXsCTaA+Z0FwX9DlFzq1tn7OgiAI6enpwuuvv94uPmM58bwF4eT+nGtqaoSePXsK33//veI828rnzVJpK7HZbFi3bh0mTZok3abX6zFp0iSsXLkyikcWWbt370Z+fj66deuGq6++GocOHQIArFu3Dna7XXH+ffr0QefOnU+q89+/fz+KiooU55mamopRo0ZJ57ly5UqkpaVh+PDh0mMmTZoEvV6P1atXt/oxR8ry5cvRoUMH9O7dG7fffjvKy8ul+06Gc66qqgIAZGRkAAjtd3rlypUYOHAgcnJypMdMnjwZ1dXV2Lp1aysefdOoz1n0/vvvIysrCwMGDMDMmTNRX18v3deWz9npdGLhwoWoq6vD6NGj28VnDPiet+hk/ZzvvPNOnHfeeYrPFWg7/09zk/lWUlZWBqfTqfiwASAnJwc7duyI0lFF1qhRo/DWW2+hd+/eOH78OB577DGcccYZ2LJlC4qKimA2m5GWlqb4mZycHBQVFUXngFuAeC5an7N4X1FRETp06KC432g0IiMjo82+F+eccw4uueQSdO3aFXv37sX//d//4dxzz8XKlSthMBja/Dm7XC7cfffdOP300zFgwAAACOl3uqioSPN3QbwvlmmdMwBcddVV6NKlC/Lz87Fp0ybcf//92LlzJz799FMAbfOcN2/ejNGjR6OxsRFJSUn47LPP0K9fP2zcuPGk/oz9nTdwcn7OALBw4UKsX78ev//+u899beX/aQZuFDHnnnuu9PWgQYMwatQodOnSBR9++CHi4+OjeGTU0q688krp64EDB2LQoEHo3r07li9fjokTJ0bxyCLjzjvvxJYtW/DLL79E+1Bajb9zvvXWW6WvBw4ciLy8PEycOBF79+5F9+7dW/swI6J3797YuHEjqqqq8PHHH+P666/HihUron1YLc7feffr1++k/JwPHz6Mu+66C99//z3i4uKifThNxlJpK8nKyoLBYPDpTikuLkZubm6UjqplpaWloVevXtizZw9yc3Nhs9lQWVmpeMzJdv7iuQT6nHNzc1FSUqK43+FwoKKi4qR5L7p164asrCzs2bMHQNs+5+nTp+Orr77CsmXL0KlTJ+n2UH6nc3NzNX8XxPtilb9z1jJq1CgAUHzWbe2czWYzevTogWHDhmHu3LkYPHgw/vGPf5zUnzHg/7y1nAyf87p161BSUoJTTjkFRqMRRqMRK1aswIsvvgij0YicnJw28XkzcGslZrMZw4YNw9KlS6XbXC4Xli5dqlhTcDKpra3F3r17kZeXh2HDhsFkMinOf+fOnTh06NBJdf5du3ZFbm6u4jyrq6uxevVq6TxHjx6NyspKrFu3TnrMjz/+CJfLJf3l2NYdOXIE5eXlyMvLA9A2z1kQBEyfPh2fffYZfvzxR3Tt2lVxfyi/06NHj8bmzZsVQev333+PlJQUqSQVS4Kds5aNGzcCgOKzbkvnrMXlcsFqtZ6Un3Eg4nlrORk+54kTJ2Lz5s3YuHGj9Gf48OG4+uqrpa/bxOfdKi0QJAiCexyIxWIR3nrrLWHbtm3CrbfeKqSlpSm6U9qye+65R1i+fLmwf/9+4ddffxUmTZokZGVlCSUlJYIguNusO3fuLPz444/C2rVrhdGjRwujR4+O8lGHr6amRtiwYYOwYcMGAYDw/PPPCxs2bBAOHjwoCIJ7HEhaWprwxRdfCJs2bRIuvPBCzXEgQ4cOFVavXi388ssvQs+ePWN6NEagc66pqRHuvfdeYeXKlcL+/fuFH374QTjllFOEnj17Co2NjdJztLVzvv3224XU1FRh+fLlipEI9fX10mOC/U6LowPOPvtsYePGjcLixYuF7OzsmB2ZEOyc9+zZI8yePVtYu3atsH//fuGLL74QunXrJowdO1Z6jrZ2zg888ICwYsUKYf/+/cKmTZuEBx54QNDpdMKSJUsEQTj5PmNRoPM+GT9nf9Tds23h82bg1sr++c9/Cp07dxbMZrMwcuRIYdWqVdE+pIiZMmWKkJeXJ5jNZqFjx47ClClThD179kj3NzQ0CHfccYeQnp4uJCQkCBdffLFw/PjxKB5x0yxbtkwA4PPn+uuvFwTBPRLk4YcfFnJycgSLxSJMnDhR2Llzp+I5ysvLhalTpwpJSUlCSkqKMG3aNKGmpiYKZxOaQOdcX18vnH322UJ2drZgMpmELl26CLfccovPP0ja2jlrnS8A4c0335QeE8rv9IEDB4Rzzz1XiI+PF7KysoR77rlHsNvtrXw2oQl2zocOHRLGjh0rZGRkCBaLRejRo4fw97//XTHfSxDa1jnfeOONQpcuXQSz2SxkZ2cLEydOlII2QTj5PmNRoPM+GT9nf9SBW1v4vHWCIAitk9sjIiIioubgGjciIiKiNoKBGxEREVEbwcCNiIiIqI1g4EZERETURjBwIyIiImojGLgRERERtREM3IiIiIjaCAZuRERERG0EAzciohZy4MAB6HQ6aZ9HIqLmYuBGRO1aUVER/vKXv6Bbt26wWCwoKCjA+eefr9homogoVhijfQBERNFy4MABnH766UhLS8MzzzyDgQMHwm6347vvvsOdd96JHTt2RPsQiYgUmHEjonbrjjvugE6nw5o1a3DppZeiV69e6N+/P2bMmIFVq1bhxhtvxJ///GfFz9jtdnTo0AH/+c9/AAAulwtPP/00evToAYvFgs6dO+OJJ57w+5pbtmzBueeei6SkJOTk5ODaa69FWVmZdP/HH3+MgQMHIj4+HpmZmZg0aRLq6upa5g0gojaHgRsRtUsVFRVYvHgx7rzzTiQmJvrcn5aWhptvvhmLFy/G8ePHpdu/+uor1NfXY8qUKQCAmTNnYt68eXj44Yexbds2/Pe//0VOTo7ma1ZWVmLChAkYOnQo1q5di8WLF6O4uBhXXHEFAOD48eOYOnUqbrzxRmzfvh3Lly/HJZdcAkEQWuAdIKK2SCfwbwQiaofWrFmDUaNG4dNPP8XFF1/s93H9+/fH9ddfj/vuuw8AcMEFFyAzMxNvvvkmampqkJ2djZdeegk333yzz88eOHAAXbt2xYYNGzBkyBDMmTMHP//8M7777jvpMUeOHEFBQQF27tyJ2tpaDBs2DAcOHECXLl0if9JE1OYx40ZE7VKo/2a9+eab8eabbwIAiouL8e233+LGG28EAGzfvh1WqxUTJ04M6bn++OMPLFu2DElJSdKfPn36AAD27t2LwYMHY+LEiRg4cCAuv/xyvPbaazhx4kQTzo6ITlYM3IioXerZsyd0Ol3QBoTrrrsO+/btw8qVK/Hee++ha9euOOOMMwAA8fHxYb1mbW0tzj//fGzcuFHxZ/fu3Rg7diwMBgO+//57fPvtt+jXrx/++c9/onfv3ti/f3+Tz5OITi4M3P5/O/cPkloYh3H8SSRskUgc1MCSGsRNQRBXUVsk3JpCaBAaA50MHGwTJBBH/+zq7BoIRWFTOISLQw2GiLQ4KE1X6FLcC5eQc/1+4CyHH+e85x0OD+e8vxfAWtrZ2VEsFlO5XP5y8f9kMpEk2Ww2HR8fq1qtqlarKZVKLWsODw+1tbX111uH+P1+PT09aW9vTwcHB5+OX+vsNjY2FA6Hlc/n9fj4qM3NTbXb7X9/YAD/BYIbgLVVLpc1n88VDAbVbDb1/Pysfr+v6+trhUKhZd3Z2Znq9br6/b5OT0+X5y0Wi7LZrDKZjBqNhgaDgW5vb5cdp787Pz/XeDzWycmJ7u/vNRgM1Ol0lEqlNJ/PdXd3p6urKz08PGg4HKrVamk0Gsnr9f74XAAwBvZxA7C2PB6Per2eCoWCLi4u9Pr6KrvdrkAgoEqlsqyLRCJyOBzy+XxyOp2frpHL5WQ2m3V5eamXlxc5HA6l0+kv7+d0OtXtdpXNZhWNRjWbzeR2uxWPx2UymWS1WnVzc6NSqaTpdCq3261isaijo6MfnQcAxkFXKQD8wfv7u1wul6rVqpLJ5KqHA2CN8cUNAL6xWCz09vamYrGo7e1tJRKJVQ8JwJojuAHAN4bDofb397W7u6tarSazmVcmgNXiVykAAIBB0FUKAABgEAQ3AAAAgyC4AQAAGATBDQAAwCAIbgAAAAZBcAMAADAIghsAAIBBENwAAAAM4gO2Fu7/RHvdiAAAAABJRU5ErkJggg==",
      "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": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "935e58c9-1777-4f91-85e7-3545357ba3b8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.09137999999999999}, {'accuracy': 0.11505999999999998}, {'accuracy': 0.11657999999999999}, {'accuracy': 0.10003999999999999}, {'accuracy': 0.14464}, {'accuracy': 0.15226}, {'accuracy': 0.15181999999999998}, {'accuracy': 0.19254}, {'accuracy': 0.15675999999999998}, {'accuracy': 0.18986}, {'accuracy': 0.18634}, {'accuracy': 0.18952000000000002}, {'accuracy': 0.1824}, {'accuracy': 0.2024}, {'accuracy': 0.19696}, {'accuracy': 0.19618}, {'accuracy': 0.20238}, {'accuracy': 0.19018000000000002}, {'accuracy': 0.2124}, {'accuracy': 0.19318}, {'accuracy': 0.20338000000000003}, {'accuracy': 0.20800000000000002}, {'accuracy': 0.225}, {'accuracy': 0.22898000000000002}, {'accuracy': 0.22464}, {'accuracy': 0.23458}, {'accuracy': 0.24574000000000001}, {'accuracy': 0.25484}, {'accuracy': 0.23748}, {'accuracy': 0.25384}, {'accuracy': 0.25324}, {'accuracy': 0.25364}, {'accuracy': 0.25971999999999995}, {'accuracy': 0.25524}, {'accuracy': 0.22252}, {'accuracy': 0.24764}, {'accuracy': 0.26012}, {'accuracy': 0.25996}, {'accuracy': 0.2589}, {'accuracy': 0.2581}, {'accuracy': 0.25782000000000005}, {'accuracy': 0.25160000000000005}, {'accuracy': 0.25476}, {'accuracy': 0.25632}, {'accuracy': 0.2522}, {'accuracy': 0.25342}, {'accuracy': 0.24772}, {'accuracy': 0.18624}, {'accuracy': 0.24125999999999997}, {'accuracy': 0.2116}, {'accuracy': 0.2372}, {'accuracy': 0.24264000000000002}, {'accuracy': 0.22928}, {'accuracy': 0.23812000000000003}, {'accuracy': 0.20612}, {'accuracy': 0.23671999999999999}, {'accuracy': 0.23388}, {'accuracy': 0.22498}, {'accuracy': 0.24664000000000003}, {'accuracy': 0.25070000000000003}, {'accuracy': 0.23822000000000002}, {'accuracy': 0.25432}, {'accuracy': 0.27488}, {'accuracy': 0.25859999999999994}, {'accuracy': 0.26836}, {'accuracy': 0.27853999999999995}, {'accuracy': 0.2774}, {'accuracy': 0.27490000000000003}, {'accuracy': 0.24484}, {'accuracy': 0.24378000000000002}, {'accuracy': 0.20674}, {'accuracy': 0.27264}, {'accuracy': 0.2641}, {'accuracy': 0.26789999999999997}, {'accuracy': 0.27258}, {'accuracy': 0.27174}, {'accuracy': 0.27786}, {'accuracy': 0.27934000000000003}, {'accuracy': 0.26244}, {'accuracy': 0.26044}, {'accuracy': 0.25844000000000006}, {'accuracy': 0.23210000000000003}, {'accuracy': 0.2632}, {'accuracy': 0.28666}, {'accuracy': 0.28896}, {'accuracy': 0.28724}, {'accuracy': 0.28985999999999995}, {'accuracy': 0.28472}, {'accuracy': 0.28654}, {'accuracy': 0.22969999999999996}, {'accuracy': 0.24114}, {'accuracy': 0.27671999999999997}, {'accuracy': 0.26515999999999995}, {'accuracy': 0.27392}, {'accuracy': 0.25136}, {'accuracy': 0.27460000000000007}, {'accuracy': 0.27294}, {'accuracy': 0.28702}, {'accuracy': 0.29348}, {'accuracy': 0.29702}, {'accuracy': 0.27880000000000005}, {'accuracy': 0.27964}, {'accuracy': 0.27724000000000004}, {'accuracy': 0.28128}, {'accuracy': 0.25438}, {'accuracy': 0.19326}, {'accuracy': 0.25876}, {'accuracy': 0.26112}, {'accuracy': 0.2081}, {'accuracy': 0.28952000000000006}, {'accuracy': 0.29594}, {'accuracy': 0.29957999999999996}, {'accuracy': 0.3012}, {'accuracy': 0.29568000000000005}, {'accuracy': 0.29744000000000004}, {'accuracy': 0.29474}, {'accuracy': 0.29426}, {'accuracy': 0.29392}, {'accuracy': 0.28776}, {'accuracy': 0.26188}, {'accuracy': 0.22160000000000002}, {'accuracy': 0.22813999999999995}, {'accuracy': 0.23308}, {'accuracy': 0.25698}, {'accuracy': 0.25986}, {'accuracy': 0.28436000000000006}, {'accuracy': 0.2934}, {'accuracy': 0.28519999999999995}, {'accuracy': 0.27434}, {'accuracy': 0.29466000000000003}, {'accuracy': 0.30023999999999995}, {'accuracy': 0.26714000000000004}, {'accuracy': 0.29628}, {'accuracy': 0.30007999999999996}, {'accuracy': 0.30284}, {'accuracy': 0.28891999999999995}, {'accuracy': 0.301}, {'accuracy': 0.30004}, {'accuracy': 0.292}, {'accuracy': 0.29798}, {'accuracy': 0.30158}, {'accuracy': 0.303}, {'accuracy': 0.30124}, {'accuracy': 0.27926}, {'accuracy': 0.25804}, {'accuracy': 0.24423999999999996}, {'accuracy': 0.23632}, {'accuracy': 0.23836}, {'accuracy': 0.24410000000000004}, {'accuracy': 0.282}, {'accuracy': 0.28243999999999997}, {'accuracy': 0.29466000000000003}, {'accuracy': 0.29563999999999996}, {'accuracy': 0.26336000000000004}, {'accuracy': 0.27574}, {'accuracy': 0.25486}, {'accuracy': 0.29494}, {'accuracy': 0.28891999999999995}, {'accuracy': 0.29829999999999995}, {'accuracy': 0.30826}, {'accuracy': 0.2668}, {'accuracy': 0.28748}, {'accuracy': 0.28894000000000003}, {'accuracy': 0.30114}, {'accuracy': 0.30898}, {'accuracy': 0.31155999999999995}, {'accuracy': 0.31132}, {'accuracy': 0.31126}, {'accuracy': 0.30604}, {'accuracy': 0.30708}, {'accuracy': 0.25148000000000004}, {'accuracy': 0.27066}, {'accuracy': 0.26946}, {'accuracy': 0.25939999999999996}, {'accuracy': 0.27177999999999997}, {'accuracy': 0.29833999999999994}, {'accuracy': 0.27762000000000003}, {'accuracy': 0.28934}, {'accuracy': 0.27578}, {'accuracy': 0.2892}, {'accuracy': 0.27816}, {'accuracy': 0.25644}, {'accuracy': 0.26806}, {'accuracy': 0.29594}, {'accuracy': 0.3065}, {'accuracy': 0.30708}, {'accuracy': 0.30918}, {'accuracy': 0.30757999999999996}, {'accuracy': 0.30662}, {'accuracy': 0.30416}, {'accuracy': 0.30297999999999997}, {'accuracy': 0.3029}, {'accuracy': 0.30574}, {'accuracy': 0.30648}, {'accuracy': 0.30838}, {'accuracy': 0.24402}, {'accuracy': 0.24925999999999998}, {'accuracy': 0.23090000000000002}, {'accuracy': 0.24964000000000003}, {'accuracy': 0.2432}, {'accuracy': 0.26114000000000004}, {'accuracy': 0.23316000000000003}, {'accuracy': 0.27368000000000003}, {'accuracy': 0.27646000000000004}, {'accuracy': 0.25966000000000006}, {'accuracy': 0.22820000000000001}, {'accuracy': 0.26742}, {'accuracy': 0.28732}, {'accuracy': 0.28014}, {'accuracy': 0.28226}, {'accuracy': 0.3023}, {'accuracy': 0.31232}, {'accuracy': 0.29916}, {'accuracy': 0.29754}, {'accuracy': 0.31106}, {'accuracy': 0.3185}, {'accuracy': 0.31806}, {'accuracy': 0.31576000000000004}, {'accuracy': 0.32067999999999997}, {'accuracy': 0.32888}, {'accuracy': 0.32422000000000006}, {'accuracy': 0.32654}, {'accuracy': 0.3204600000000001}, {'accuracy': 0.32438}, {'accuracy': 0.32848}, {'accuracy': 0.32216000000000006}, {'accuracy': 0.32796}, {'accuracy': 0.32732}, {'accuracy': 0.32936}, {'accuracy': 0.32518}, {'accuracy': 0.32476}, {'accuracy': 0.3266}, {'accuracy': 0.32954}, {'accuracy': 0.33768}, {'accuracy': 0.3291199999999999}, {'accuracy': 0.324}, {'accuracy': 0.3229799999999999}, {'accuracy': 0.32916}, {'accuracy': 0.329028}, {'accuracy': 0.32067999999999997}, {'accuracy': 0.32888}, {'accuracy': 0.32422000000000006}, {'accuracy': 0.32654}, {'accuracy': 0.3204600000000001}, {'accuracy': 0.32438}, {'accuracy': 0.32848}, {'accuracy': 0.32216000000000006}, {'accuracy': 0.30266000000000004}, {'accuracy': 0.3204600000000001}, {'accuracy': 0.32438}, {'accuracy': 0.32848}, {'accuracy': 0.32216000000000006}, {'accuracy': 0.30266000000000004}, {'accuracy': 0.326564}, {'accuracy': 0.329214}, {'accuracy': 0.327628}, {'accuracy': 0.32862600000000003}, {'accuracy': 0.32478}, {'accuracy': 0.32752}, {'accuracy': 0.32682}, {'accuracy': 0.3234}, {'accuracy': 0.3224}, {'accuracy': 0.32188}, {'accuracy': 0.32267999999999997}, {'accuracy': 0.329482}, {'accuracy': 0.31494}, {'accuracy': 0.31774}, {'accuracy': 0.322048}, {'accuracy': 0.325864}, {'accuracy': 0.326078}, {'accuracy': 0.327352}, {'accuracy': 0.30224}, {'accuracy': 0.325274}, {'accuracy': 0.329892}, {'accuracy': 0.32875}, {'accuracy': 0.31478}, {'accuracy': 0.329734}, {'accuracy': 0.31334}, {'accuracy': 0.31643999999999994}, {'accuracy': 0.30663999999999997}, {'accuracy': 0.31652}, {'accuracy': 0.31192000000000003}, {'accuracy': 0.329774}, {'accuracy': 0.325138}, {'accuracy': 0.31972000000000006}, {'accuracy': 0.329878}, {'accuracy': 0.328422}, {'accuracy': 0.31082}, {'accuracy': 0.3056}, {'accuracy': 0.30494}, {'accuracy': 0.32293}, {'accuracy': 0.32429800000000003}, {'accuracy': 0.326176}, {'accuracy': 0.326638}, {'accuracy': 0.323568}, {'accuracy': 0.32382}, {'accuracy': 0.326532}, {'accuracy': 0.327328}, {'accuracy': 0.31289999999999996}, {'accuracy': 0.30814}, {'accuracy': 0.30986}, {'accuracy': 0.31346}, {'accuracy': 0.31500000000000006}, {'accuracy': 0.32902}, {'accuracy': 0.31412}, {'accuracy': 0.3224600000000001}, {'accuracy': 0.33172}, {'accuracy': 0.32902}, {'accuracy': 0.33662}, {'accuracy': 0.32632}, {'accuracy': 0.328666}, {'accuracy': 0.328896}, {'accuracy': 0.328724}, {'accuracy': 0.328986}, {'accuracy': 0.328472}, {'accuracy': 0.328654}, {'accuracy': 0.32297}, {'accuracy': 0.324114}, {'accuracy': 0.327672}, {'accuracy': 0.326516}, {'accuracy': 0.327392}, {'accuracy': 0.325136}, {'accuracy': 0.32746000000000003}, {'accuracy': 0.327294}, {'accuracy': 0.328702}, {'accuracy': 0.31192000000000003}, {'accuracy': 0.329774}, {'accuracy': 0.325138}, {'accuracy': 0.31972000000000006}, {'accuracy': 0.329878}, {'accuracy': 0.328422}, {'accuracy': 0.3185}, {'accuracy': 0.31806}, {'accuracy': 0.31576000000000004}, {'accuracy': 0.32067999999999997}, {'accuracy': 0.32875}, {'accuracy': 0.31478}, {'accuracy': 0.329734}, {'accuracy': 0.31334}, {'accuracy': 0.32888}, {'accuracy': 0.32422000000000006}, {'accuracy': 0.32654}, {'accuracy': 0.3204600000000001}, {'accuracy': 0.32438}, {'accuracy': 0.32848}, {'accuracy': 0.32216000000000006}, {'accuracy': 0.32796}, {'accuracy': 0.32732}, {'accuracy': 0.32936}, {'accuracy': 0.32518}, {'accuracy': 0.32476}, {'accuracy': 0.3266}, {'accuracy': 0.32954}, {'accuracy': 0.32438}, {'accuracy': 0.32848}, {'accuracy': 0.32216000000000006}, {'accuracy': 0.30266000000000004}, {'accuracy': 0.326564}, {'accuracy': 0.329214}, {'accuracy': 0.327628}, {'accuracy': 0.32862600000000003}, {'accuracy': 0.32478}, {'accuracy': 0.32752}, {'accuracy': 0.32682}, {'accuracy': 0.3234}, {'accuracy': 0.3224}, {'accuracy': 0.32188}, {'accuracy': 0.32267999999999997}, {'accuracy': 0.329482}, {'accuracy': 0.31494}, {'accuracy': 0.31774}, {'accuracy': 0.322048}, {'accuracy': 0.325864}, {'accuracy': 0.326078}, {'accuracy': 0.327352}, {'accuracy': 0.30224}, {'accuracy': 0.325274}, {'accuracy': 0.329892}, {'accuracy': 0.32875}, {'accuracy': 0.31478}, {'accuracy': 0.329734}, {'accuracy': 0.31334}, {'accuracy': 0.31643999999999994}, {'accuracy': 0.30663999999999997}, {'accuracy': 0.31652}, {'accuracy': 0.31192000000000003}, {'accuracy': 0.329774}, {'accuracy': 0.325138}, {'accuracy': 0.30986}, {'accuracy': 0.31346}, {'accuracy': 0.31500000000000006}, {'accuracy': 0.32902}, {'accuracy': 0.31412}, {'accuracy': 0.3224600000000001}, {'accuracy': 0.33172}, {'accuracy': 0.32902}, {'accuracy': 0.33662}, {'accuracy': 0.32632}, {'accuracy': 0.328666}, {'accuracy': 0.328896}, {'accuracy': 0.328724}, {'accuracy': 0.328986}, {'accuracy': 0.328472}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
