{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\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_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\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",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "5959\n",
      "[[  0 600]\n",
      " [  1 597]\n",
      " [  2 624]\n",
      " [  3 602]\n",
      " [  4 615]\n",
      " [  5 585]\n",
      " [  6 623]\n",
      " [  7 605]\n",
      " [  8 633]\n",
      " [  9 601]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2, 1, 2,  ..., 5, 9, 8])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7113\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 406]\n",
      " [  1 587]\n",
      " [  2 416]\n",
      " [  3 585]\n",
      " [  4 438]\n",
      " [  5 589]\n",
      " [  6 429]\n",
      " [  7 595]\n",
      " [  8 622]\n",
      " [  9 622]]\n",
      "[[   0 1093]\n",
      " [   1  587]\n",
      " [   2  429]\n",
      " [   3  585]\n",
      " [   4  479]\n",
      " [   5  589]\n",
      " [   6  516]\n",
      " [   7  595]\n",
      " [   8  622]\n",
      " [   9  622]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([2, 1, 1,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\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\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.75</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.75\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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+MemMRUXF+O0004TxjR58mQUFBTgjTfe0McEAP/5z38QiUTSPi4nSkpK8MEHH2DPnj3dul+C6G7IuCGIHggzWpiRY4dsBH3rW99CcXExli9fri+zfPlyTJo0CQcffDAAYMuWLdA0Db/+9a8xYMAA4d/ixYsBAPv27RP2c9BBB5n23dbWhkWLFumal7KyMgwYMAANDQ04cOBAB4/cHZs3b8aKFStM458xY4Yw/quvvhoHH3wwvv3tb2Po0KH4wQ9+gBUrVnR6/z6fT9ce8WM6cOAAysvLTeNqbm7Wx3TSSSfhO9/5Dm655RaUlZXh3HPPxWOPPYZQKNTpcSXjtttuw2effYbKykpMnToVN998M77++usu3y9BdDekuSGIHkhxcTEGDRqE9evXOy63fv16DBkyBEVFRQCAYDCI8847D8899xweeOABVFdX491338Uf/vAHfR0muL3hhhswc+ZMy+2OHj1a+J330jCuvfZaPPbYY7j++usxbdo0FBcXQ1EUfPe73zWJetONqqo47bTT8Itf/MLye2bIlZeXY926dXj55Zfxv//9D//73//w2GOPYc6cOXjiiSc6vP9gMAiPR3w3VFUV5eXl+Pvf/265DhOFK4qCZ555Bu+//z5efPFFvPzyy/jBD36AO++8E++//z4KCgpsi/LFYrEOjxkALr74Ypxwwgl47rnn8Morr+D222/HrbfeimeffRbf/va3O7VtguhJkHFDED2Us846Cw8//DDeeecdHH/88abv3377bWzbtg1XXXWV8PmsWbPwxBNPYOXKldi4cSM0TdNDUgD0tHG/3697OjrCM888g7lz5+LOO+/UP2tvb0dDQ0OHtyljN8mPGjUKzc3NrsYfCARw9tln4+yzz4aqqrj66qvx0EMP4de//jVGjx6dtuq+o0aNwmuvvYbjjjvO0hiUOeaYY3DMMcfg97//Pf7xj3/gkksuwVNPPYUrrrgCpaWlAGA6l9u3b3c1FqdjGjRoEK6++mpcffXV2LdvH4488kj8/ve/J+OGyCooLEUQPZSf//znyM3NxVVXXYX9+/cL39XV1eFHP/oR8vLy8POf/1z4bsaMGejXrx+WL1+O5cuXY+rUqUJYqby8HCeffDIeeugh7N2717TfmpoaV+Pzer3QNE347N577+20d4EnPz/f0li6+OKLsXr1arz88sum7xoaGhCNRgHAdN48Hg8mTJgAAHoYiNWn6axRdvHFFyMWi+G3v/2t6btoNKpvv76+3nTeJk2aJIxp+PDh8Hq9unaI8cADD7gai9V5i8VipnBheXk5Bg8e3C0hMYLoTshzQxA9lDFjxuCJJ57AJZdcgvHjx+Pyyy/HQQcdhG3btuGRRx5BbW0tnnzyST3Nl+H3+3HBBRfgqaeeQktLC+644w7Ttu+//34cf/zxGD9+PK688kqMHDkS1dXVWL16NXbt2oVPP/006fjOOuss/PWvf0VxcTHGjRuH1atX47XXXkP//v3Tdg4mT56MBx98EL/73e8wevRolJeXY/r06fj5z3+OF154AWeddRYuu+wyTJ48GS0tLdiwYQOeeeYZbNu2DWVlZbjiiitQV1eH6dOnY+jQodi+fTvuvfdeTJo0SU/3njRpErxeL2699VYcOHAAwWAQ06dPR3l5eUpjPemkk3DVVVdhyZIlWLduHU4//XT4/X5s3rwZTz/9NO655x5ceOGFeOKJJ/DAAw/g/PPPx6hRo9DU1ISHH34YRUVFOOOMMwDEw5IXXXQR7r33XiiKglGjRuE///mPSQvldN5ee+013HXXXRg8eDAOOuggHHLIIRg6dCguvPBCTJw4EQUFBXjttdfw0UcfCd43gsgKMpusRRBEMtavX6/Nnj1bGzRokOb3+7WBAwdqs2fP1jZs2GC7zquvvqoB0BRF0Xbu3Gm5zNatW7U5c+ZoAwcO1Px+vzZkyBDtrLPO0p555hl9GZYKbpW2XF9fr82bN08rKyvTCgoKtJkzZ2pffvmlNnz4cCENuTOp4FVVVdqZZ56pFRYWagCEtPCmpiZt4cKF2ujRo7VAIKCVlZVpxx57rHbHHXdo4XBY0zRNe+aZZ7TTTz9dKy8v1wKBgDZs2DDtqquu0vbu3Svs5+GHH9ZGjhypeb3epGnhc+fO1fLz822///Of/6xNnjxZy83N1QoLC7Xx48drv/jFL7Q9e/ZomqZpa9eu1WbPnq0NGzZMCwaDWnl5uXbWWWdpH3/8sbCdmpoa7Tvf+Y6Wl5enlZaWaldddZX22WefuUoF//LLL7UTTzxRy83N1QBoc+fO1UKhkPbzn/9cmzhxolZYWKjl5+drEydO1B544AGnS0AQvRJF0yT/KEEQBEEQRC+GNDcEQRAEQWQVZNwQBEEQBJFVkHFDEARBEERWQcYNQRAEQRBZBRk3BEEQBEFkFWTcEARBEASRVfS5In6qqmLPnj0oLCxMW9l1giAIgiC6Fk3T0NTUhMGDB5t6u8n0OeNmz549qKyszPQwCIIgCILoADt37sTQoUMdl+lzxk1hYSGA+MlhnZQJgiAIgujZNDY2orKyUp/Hnehzxg0LRRUVFZFxQxAEQRC9DDeSEhIUEwRBEASRVZBxQxAEQRBEVkHGDUEQBEEQWQUZNwRBEARBZBVk3BAEQRAEkVWQcUMQBEEQRFZBxg1BEARBEFkFGTcEQRAEQWQVZNwQBEEQBJFVkHFDEARBEERWQcYNQRAEQRBZBRk3BEEQBEFkFWTcEARBEH2StnAMmqZlehhEF0DGDUEQBNHn2FXfiiN/+ypueHp9poeSVRxojeCDr/djZ11rRsdBxg1BEATR5/hkRwPaIjG8s6UGAPB1TTNaQtEMj6r3s3ZnPWb9+X388K9rMjoOMm4IgiCIPkfVgXYAQHVjCF/sacSpd72JH/0tsxNyNrCvMX5eBxYFMzoOMm4IgiCIPsfehHEDAC9t2ANNAzZVNWVwRNlB1YEQAKCiKCej4yDjhiAIgrClurEdS/63EbXNoUwPReDuV7/CrIdWoz0S69D6VY1t+s/vbK4FAOxvCUNVSWDcGaoSnhsybgiCIIgey92vfoWH3vwaD67amumh6LSEorhn5WZ88E0dVm3a57hsdWM7Lvm/9/HkhzuEz3nPzfrdBwAAMVXDgbZI+gfch9DDUsVk3BAEQRA9lA++qQMAbEgYAD2Bd7fU6j9Hk3harvn7Wry7ZT8WPrtB+LyaM274bPDa5hBi5L3pMIbnhjQ3BEEQRA+kpimEb2pbAAAb9zQmDdksfe0rLPnfxi6vHfPGphr95/pWe0/Ljv2t+Hh7vf47M1piqobqJusw26bqJhz9h9ew8Nn0pIi/t7UWv3xmPfY0tCVfOI3UNofwmxe/sNUR1bWEsWN/+tO1qyksRRAEQfRk1myv039uCkWxs95+MvyquglLX9uMh978Gju6sMaJpmlCKKq+JWy77L2vbxZ+Z14FJ+/MK59Xo7Y5jNc2Ooe73PDaF9W47NGPsPzjnfjFM+u7tWDgE+9tw6PvfoOZS9+y1Etd/NBqzLjrTexPo5YqElNR2xy/HgPJuCEIgiB6Ih9+Uy/8/vmeRtMymqZB0zQ8u3a3/tmWfc2d2u+22hZ8vK3O8rsvq5oEvUydjXFzoC2CFz7dI3y2PeGF4teX+WRn/Jj3N4cQjamuxhuNqaZl9zW14+p/rEU48fk7W2qx4rMqV9tzi6Zptt60D742zt9PnvxEMKz2NbZjy75mhGMqvk6ck511rbh42Wo898kux/19vK0Oje3W3rJ9CW+Y36ugNC+Q8vGkEzJuCIIgCEs+TnhuSvP8AIDP94i6G03TcPFDq3Ha3W/h2bXGpLg5iXGzs64VP3j8I7y9ucby+8uf+AgXLluNV7+oNn3H620AoKHV2rj5z/o9CEVVHFxRgFMOGQAA2JYIw1QdiIeIRvTPsxhb/DtVi2dPJaO2OYRjlqzEkb99Ff/vuQ26IPmNL/chHFUxdlARrjllFADgdy9tdG0wOaGqGpZ/tAPH3/oGvn3P25bbZEYLALy3dT++5MJTvJHKwkjPfbIbH26rw0+Xf4r3tornmPHW5lpcuGw1/t+zG7C7oQ0z7noT9640vGOsdlB5YQ48HqVzB9lJyLghCIIgTLSFY/okOOuoYQDMnpuqxnZ8tK0eW/Y162/tALC52tm4eezdbXj9y3249JEPTVqU9kgMW2viE/MvnvkU//xoJ/76/nbd8/BhQuA8prwAAFBno7l5+uO4sXXR5EoM758PANi+vwXvbqnF+l1xI23c4CLk+r0AAKu5mE38Try0fi9qm8NobI/iHx/s0LOy3vgybrh967CBuHb6GJQVBLC7oQ2vWBhsQNz7c8UTH+Gaf6y1DF9FYyo27DqAaEzFX1Zvwy//FTcwNlU3YbsUBtzX2I7a5hA8CjCpsgQAsG5ng/79Z5w4vLoxft12cSHHa/6+VvDOHGiLQFU1fJG4/u9t3Y8X1u3Bln3NuPPVr/D0xzv1/QKZFxMDZNwQBEEQFuyqb0VM1VAY9OG0ceUAoE9ujG9qWoTfh5bmAgC27HMuhrelxjB+fv7Mp8JkvpszdupbI/jFv9bj189/hte/3BcPiyQEwqcfVhFfxsK7smVfM9btbIDXo+C8I4boHppnP9mNS/7vAzyQSGsfVJyrj/nQgUWm7exrtNejbNzbiJqmEF5avxcAMLIsbkC9u6UWkZiKdxIeppMPGYAcvxezp8YNxGVvbsUVT3yEW178XNjemu31eG3jPry0fq+eofbO5lpMv2MVVm/djydWb8fZ972Dx9/bho17xfMrC4M/S3jYRg0owLRR/QEA63Y0mL6PH2PcINlWa2yjvjWCjxJj+ODr/Tjyt6/itpc3YXdDfJm6ljD+vc4IQ9703GfYWdeqa5oynQYOkHFDEARBWLArYWQMKc3F2EFF8ChxTcU+zpuxNRH6OGZkP9w7+wjc970jAcTDUk7i2a+4EMm7W/bj69oWfLb7AFZurMauesO4UZS4fgMA/vHBDmytaUZdSxg5fg9OHBMPNdVbhKXeSYS7jh3VHwMKgxieMDxqpAypgUU5+PbhA1Ga58f5Rwwxbae6ydpz89SHO/Dte97GaXe/iY8SobubzzkMQNyz9O6WWjSHouifH8D4IcUAgEuOHg6fR8H6XQfw2sZ9eOzdbdhV34r2SAyhaEzIAGPen/+s34Ova1vwwqd7dM/Lht0HsOeA6O3atl80Mj/bHTdCDx9SbOO5MYelWBjr4Iq4R4x5t/7x4Q7EVA1vflWD3dy1YWGu0jw/wjEVb35V02MK+AFk3BAEQRAWsIlsaGku8gI+jCkvBAB8ust462eem8MHF+PsiYNx2OAi+L0KWsMx7LER7e5vDumT4LB+cY/Kjv2t+OFfPsblT3ysGyYzxpbj/YWn4qWfnAAAeH3TPjz/SVwgPKmyBOWJCdTKc/NJYiKfMrwfAGB4P7O2BgAqinOw4PRDsPbXp+HI4SWm76stPDcrN1bj/z0Xr5nT0BqBpgGTh5fihDFlqCgKIhRVcfvLmwAAJx0yQNeeDCzOwdkTBwvbenbtbpx8+yqccc/beOVzQ2z8v8+qUN8S1r1YO+pa9Ay03fVturbl8CFxb9P2hOemPRLD9v0tuiFz2OAiHJEwbr7a14TmUFTYLjvGpvaInlF1TmKMG3YfQHskhtcSYbTt+1sEwxMAAl6PHrL8eFud7uki44YgCILokbAJcEhJPGwzYWjcA7F+VwM++Ho/Pvh6P76ujYeXRg6Iv+37vR4clPCSbK42vDO3vPg5rnjiY9S1hPWQyvD+eThkYNxg+mJvo24M/XdDfJIfWpqHiqIcHFxRiONG94emxUM6ADB1RD/0S2TjtIRjWPjsehz3x9d1rxKb3I8YVqJvi2lqhvXLwz3fnYQzJwzCjLHxcJuiKOifb9aJ7JM0N6qq4bf/+QKqBpw7abAe0jpn4mAoioLjRpcBMLRJsjGz5ILxePSyKVhw2sEAgD+t3IyqxnZsrWnB17Ut8CjAyAH5CEdVvPDpHl2PtK22FTsS3pndDW16ttcxB8VDTtv3t+DHf1uDsYtW4KTbV+H1L+Np7IcPKUZ5UQ4GF+dA04ANuw6YdFPVTe16SKqsIIBjE8ewftcBrNq0Dy3heHuL1nAMW2tELdXhQ4pwfGL5j7fX60ZXptPAATJuCIIgCAuY52ZIYgKfkPAAvPpFNb7/yAf4/iMf4NOEEcEMGgC6h+fDb+qgaRq+rmnGY+9uw2sbq3HxQ6v1iXfcoCLdOOAzoJhRxb4DgKtOHAWvR9GrEU89qD8Kc3y6wbL8o53Y3dCGFz7dg7qWsO7JmJgYc8Dn0Y/j3EmDce6kIbj/e0ciL+DT91FWaGHcNIVQ3xJGOBrPRnpj0z5s29+KohwfllwwHs/86Fjc9p0JuOTouPeCTfQAcMGRQ3DKIeXC9nL8Xkw/tEI3euTqykcOK9U9J5/tPoA9De36OWHFCvceaEdzKAoAOHpk3Lj5eFs9/vdZFTQt7k0BgLKCoB4Sm5Qw8tbtbMDaHXHN0thBca/PvsYQvkkYTgeV5WPcoCJ4PQpqm0P4v7e/EcYnZ51PHl6KScNK4PUo2FXfhjWJbQ+3yELrbnzJFyEIgiD6GobnJj5RTRpaAgBCSjGbcEcNMIybsYMK8dKGvXhg1VZ8vK0eRw4v1b/bsq9Zr4EzblAR8oLxKYivIszgjZsTDx6A/1x7PP63YS+8Hg+OHdUfHk+8lsr+lrA+6a7cuA8jE2MZNSAfxbl+fRsXTa7E8+t268JemfyAF0GfB6GoiqIcHxrbo/h4Wx2OWbISw/vn4R9XHoPH3t0GAPju1GHIC/iQF/Dh4qMq9W2cdPAAFOX4UF6Ug9+ce7jdqcVBZfkYNSAfW2taMLQ0F1MP6odn1+7GWRMGoV9B3Mhas6MebQ5NQYtz/Rg7KG5INiWMnSnDS/H0j6ahtjmMgqAPuYF4JtiRw0rx3w1VeGdLDdoSnpgLjhiC3+9tRHMoqmdPjeifjxy/FwdXFGLj3kb9ugwsytFDif3yA3oPrsnDS1EQ9GHcoCJs2H0A4aiK8ZzOJ5OQcUMQBEGYkD03hwwsRMDr0YvSMfIDXgzgvB5zjx2B2uYwln+0Ex9uq9MFtwtOOxh//2C7rmMZN7hI91wwzwjP0FLx7X/soCLd28AozQ8ItWg+2lanh7omVZYKy/7k1DH4yaljbI9XURSUFQSxu6ENRwwrxZtf1aCxPW40fFXdjOl3rEJjexQeBbj0mOGW2+hfEMTbv5yOgNejGxZ2zJ46DL97aSN+dvrBOGfiEFx6zHBMHFqCL/bGw0ZfS5loMoOKczCoOBd+r4JILH4ejxtdBkVRhOsBADMPG4jfvbQRq7fu1z87c8Ig3LNyM5pDUXzwdfzzgxKG4SEVBdiYGMd3jhyKwhwfHn9vG4C40XnJ0cPwwTd1OOXQuGdq8vBSvffY/OmjoSiZrXEDUFiKIAiCkAhHVT1TiGluAj4Pxg6OGxdBnzF1jBxQIExmhTl+3HzOYVj63UkA4k0pgz4P5h03Ao9dNhU5fg+CPg8mDC0RvDMyTt8xWHFBRlTV9EwjFopJhbKCuI5nynDRMFIUoLE9Cq9HwU9OHYNKG4EyEPeoJDNsAODy4w/CukWn4fwjhsLrUXDEsFJ4PIoQ4nNiUHEOvB5FGMtxXFiMp7JfHo4YVgJVi4eWDh1YiMEluShP1KNhIvGDEvWAmO4m4PXglnMPE8Y0pCQXs44ahrsunoSgL36cLBw3dlARThtb4Wr8XQ15bgiCIAiBqgPtulHCJnwAOHJYCT7d2YAzJwzCzrpWfLSt3nYynnnYQMw8rAIvf16NU8eWozDHj3GD/Vj5s5PREopiQGEQAZ/1+3Vh0CeElOzgS/znB7xoCccQiqrIC3j1qsSpcOHkoWiPqLhg8lDc+epX+ud/v+JobKttxYyx5XqWVmdRFAUlFi0K8oM+VBQFLTO1eAYljM7h/fLwdU0Lcv1ex3DQORMH45NErRvmcakozBE8RKMShRHPP2IIwlEVpxxajoKgDyMk40bm1LHleOjSyZhUWZLxysQMMm4IgiAIgV2JYm1DSnIFr8z8U0ajNC+AS48ZjjXb67Fx7zqcMX6Q7XZuu3Aijhi2A+dNMmrI8JNjca5f17cA8XYI2/a3YkhprqvQRr98wzj4yalj8Oi73+DgikIsPnucKazlhkunjcCl00aYPj92VBmOHZXy5jrMyLIC3bgpzPGhKXF+hvfP08XSgxOF8uLVl2sw9aB+tsYiEA9DsUyvkw+OG358sb1JlSV61We/14Pvc6E35tEBgMEWxo2iKJh52MCOHGqXQcYNQRAEISDrbRj9C4K6bmXGuAp8dstMx+0U5/rxo5OcrYKhpXm6zuSM8YPwwKqtev2bZPCej28dPhBXJdlXRzikojDt20zGQQPysTqhgzlmZH+9x9axo/rrxs3A4vi1uXDyULz/9X5cdeJIx22WF+bglnMPx96GNhw1Il7/x8d5Wa47dYytQTmk1ND2yPdET6VHaG7uv/9+jBgxAjk5OTj66KPx4Ycf2i578sknQ1EU078zzzyzG0dMEASRvbBibVYhiHTDtDVFOT5cecJIXHrMcFw73V74y9MvPx66yvF7UNkBT40TP595CErz/Lj3e0ekdbtuGMmFgY5NtE8A4oYOg3luDh9SjBXXn6jrZJy49Jjh+MW3DtVDR4dyAu2THcJ4Xo+CSZXxlO9xg8xtKnoiGffcLF++HAsWLMCyZctw9NFHY+nSpZg5cyY2bdqE8vJy0/LPPvsswmFDHb9//35MnDgRF110UXcOmyAIImvZ3xIPiZRb1H5JNyx8NLx/PkrzA/jtefYp1DL9EoX3xpQXpl3rcc0po3HNKaPTuk23jORS648cVopvHTYQihL/mTEoDYbn96YOQ3skphchdOLRy45CXUvYUUzdk8i4cXPXXXfhyiuvxLx58wAAy5Ytw0svvYRHH30UN954o2n5fv36Cb8/9dRTyMvLI+OGIAgiTYQi8dTsoD951k9nGZ3QeRzcgfDPKYcMwIyx5bhwcmXyhXsRB5UV6D8PKc3FsksnAwAiMRVlBQFEVQ2D0tCcMjfgdW3AFeb4UZiTXOTdU8iocRMOh7FmzRosXLhQ/8zj8WDGjBlYvXq1q2088sgj+O53v4v8fGvFfigUQihkqM4bGxstlyMIgiDisFo2QQeBarq44Mi42Hj6oWZPfTL6FwTxf3OPSveQMs6wROp2wOtBf0407fd68J9rT4CqacjpBsOzN5NR46a2thaxWAwVFWJefEVFBb788suk63/44Yf47LPP8Mgjj9gus2TJEtxyyy2dHitBEERfgRXV6w7jJsfvxfeOtq4a3FfxehQ8++NjAcAULhqYBo9NX6BHCIo7yiOPPILx48dj6tSptsssXLgQBw4c0P/t3LmzG0dIEATR+wjpxg15BzIFS5YhOkZGPTdlZWXwer2orq4WPq+ursbAgc458y0tLXjqqafwm9/8xnG5YDCIYLDrRXEEQRDZAvPcONVNIYieTEbv3EAggMmTJ2PlypX6Z6qqYuXKlZg2bZrjuk8//TRCoRC+//3vd/UwCYIg+hShaLy5Ihk3RG8l49lSCxYswNy5czFlyhRMnToVS5cuRUtLi549NWfOHAwZMgRLliwR1nvkkUdw3nnnoX///labJQiCIDpId2puCKIryLhxM2vWLNTU1GDRokWoqqrCpEmTsGLFCl1kvGPHDng84h/Ypk2b8M477+CVV17JxJAJgiCymhCFpYheTsaNGwCYP38+5s+fb/ndqlWrTJ8dcsgh0DSti0dFEATRNwmToJjo5ZBZThAEQQiQ54bo7dCdSxAEQQiESHND9HLoziUIgiAEwpQtRfRy6M4lCIIgBPSwlJemCKJ3QncuQRAEoaNpmtFbyk9TBNE7oTuXIAiC0InENLBk1KCXsqWI3gkZNwRBEIQO89oA5Lkhei905xIEQRA6rMYNQJobovdCdy5BEAShw/pK+b0KPB7qSk30Tsi4IQiCIHTClClFZAF09xIEQRA6egE/P4mJid4LGTcEQRCEDnluiGyA7l6CIAhCJ0TViYksgO5egiAIQof6ShHZAN29BEEQhE6YOoITWQDdvQRBEIQOeW6IbIDuXoIgCEKHPDdENkB3L0EQBKFjeG4oFZzovZBxQxAEQeiQ54bIBujuJQiCIHRYKjhpbojeDN29BEEQhA55bohsgO5egiAIQidM2VJEFkB3L0EQBKFDgmIiGyDjhiAIgtAJxygsRfR+6O4lCIIgdEIREhQTvR+6ewmCIAgd3XNDXcGJXgzdvQRBEIROKJLQ3PhpeiB6L3T3EgRB2FDXEsbCZ9fjkx31mR5KtxEizw2RBdDdSxAEYcMrn1fhyQ934v/e+SbTQ+k29FRwP2VLEb0XMm4IgiBsaA3HxbUsVNMXYKng5LkhejN09xIEQdgQUzUAgKppGR5J9xFOtF+gVHCiN0N3L5F17KpvRXMomulhEFlARI17MZiR0xcIUYViIgugu5fIKnbWteL4W9/A0b9/LdNDIbKAaKwvem6oiB/R+6G7l8gqVn+9HwDQktBKEERniMb6sueGBMVE74WMGyKrIBEkkU4iCaOmLxk35LkhsgG6e4mswudVMj0EIotgnps+FJWiruBEVkB3L5FV+DnPDZuY0kFzKIo2CnX1OaLMc9OHrJtQlHpLEb0funuJrIIPSzHtAE9rOIoPv6lLKcwQjqqYfscqnHXv22kZI5GcLfuasLOuNdPD0AXFfTEsRZobojdDxg2RVfBhqfaI2dNyx8tf4eKHVmPFZ1X6Z29s2of1uxpst1nXEsa+phC21rT0qUkuU7SGozj73ndx4bL3Mj0URBOp4H0pWypEmhsiC6C7l8gqeNuj3cJzs6s+7g3Ymfh/f3MIlz/+EX74lzW22+SNpEgaQ12ENY1tUbRFYqhuDKU1tNgRIn3McxNTNT0UR8YN0Zuhu5fIKlRuErLy3LC3UlZWv7E9ClUD6lvDttvkw1udNW6u+ftafOfB9/rMZNkRmLcEAMIZNm76Wip4mLvXSXND9GYyfvfef//9GDFiBHJycnD00Ufjww8/dFy+oaEB11xzDQYNGoRgMIiDDz4Y//3vf7tptERPhw8fWPUDYmJJZvjEXIQdeCOJaTA6gqZpeGnDXqzZXo+aplCHt5Pt8IZE2ML71p1E+lj7Bf58k+eG6M34Mrnz5cuXY8GCBVi2bBmOPvpoLF26FDNnzsSmTZtQXl5uWj4cDuO0005DeXk5nnnmGQwZMgTbt29HSUlJ9w+e6JHwE2N71MlzE2/PEHVRxyRdnpsIZxjx3glCJNqDjJuYXqE4o8PoNli4tjDHB5+HyioQvZeMGjd33XUXrrzySsybNw8AsGzZMrz00kt49NFHceONN5qWf/TRR1FXV4f33nsPfr8fADBixIjuHDLRw+HfsK3CUu0Jb05bOP5/lJu8NE2Dopgf6ILmphOzHB9i6YwHKNsRPDcdMCbvemUTmkMxLDp7XKfHoguK+4h188nOBgDApMoSy78FgugtZMzvGA6HsWbNGsyYMcMYjMeDGTNmYPXq1ZbrvPDCC5g2bRquueYaVFRU4PDDD8cf/vAHxGJUf4SIw8+FbsJSvJfAbv7iPTdOAtdPdtRjzfZ62+8j/Hb6yGTZEXjDL1XPTTSm4t43tuDRd7/BgdZIp8eiC4r7SFjqkx3x+/eIYaUZHglBdI6MeW5qa2sRi8VQUVEhfF5RUYEvv/zScp2vv/4ar7/+Oi655BL897//xZYtW3D11VcjEolg8eLFluuEQiGEQoa+obGxMX0HQfQ4+EkoZBWWiohhqRgXHoqpGrwWrng32VLtkRjOfyCeurzxN99CbsBcI4Rft68IVDtCZzw3MU3TqwmnI/QX7WNdwdftaAAAHDGsJKPjIIjO0qsUY6qqory8HH/+858xefJkzJo1CzfddBOWLVtmu86SJUtQXFys/6usrOzGERPdjZgtZe+5aWOemxjvubGewETNjfUyDZyXwMqoMm+HNDd2CNlSKXpueHsmHfYIu959ISxV3xLG17UtAIBJQ0syOxiC6CQZM27Kysrg9XpRXV0tfF5dXY2BAwdarjNo0CAcfPDB8HqNt+KxY8eiqqoK4bB1Ku/ChQtx4MAB/d/OnTvTdxBEjyOWLBVc19zETMvbvZ3zxoqdVsZqXzLkuXFHZ7KleM+dloZQkp4K3gfCUusSepuRZfkozQ9kdjAE0UkyZtwEAgFMnjwZK1eu1D9TVRUrV67EtGnTLNc57rjjsGXLFqjc69lXX32FQYMGIRCw/mMMBoMoKioS/hHZSyyJoJh5T9osNDd2ExjvAbILk/BeGTvDRcyWyv7JsqN0Jlsq5kJD1ZHt9QVHG+ltiGwio2GpBQsW4OGHH8YTTzyBjRs34sc//jFaWlr07Kk5c+Zg4cKF+vI//vGPUVdXh+uuuw5fffUVXnrpJfzhD3/ANddck6lDIHoYfPhA7i0VUzXdOGmLWHhubLwyoufGepZr4wwpOyMp7FKY3Nfhr0koxfPEe2vSUZuGGaTp8AL1dGqa49rE4f3zMjwSgug8GU0FnzVrFmpqarBo0SJUVVVh0qRJWLFihS4y3rFjBzwew/6qrKzEyy+/jJ/+9KeYMGEChgwZguuuuw6//OUvM3UIRA9D9NyIEyNvXLCwVKqeGzuPS2soqv9sp2MN97CwVNWBdvQvCAid1HsC6fPcpCEspfadsBQLufL92Qiit5JR4wYA5s+fj/nz51t+t2rVKtNn06ZNw/vvv9/FoyJ6K4KgWBL28h4YQ3NjTJ52olF+PbuwFGvnALjz3DjVy1nx2V7srGvDlSeOtF2ms3y6swHn3v8ujhpRiqd/dGyX7acjxDohKObPfTrqJKa7K3g0pqKuNYzywpy0bC+dsGOk4n1ENtCzXtkIopMIIQ3Jc8OHqVojMWia5spzw2/HTlDcEuY9N3aaG95zYz/z/ur5z/D7/27Um3x2Bc+s2QUA+GibfV2eTNGZOjf8JUxLWCrNRfx++s9PccwfVuLrmua0bC+dRHXjhqYFovdDdzEBAGhwaBzpRGs4ij+t3IyvqpvSPKKOwdsesueGFxhrWtzYST1bykZzw3tuXBg3ThWKmxMhrpZQ1xWnzPH33D/9TtW5SXNYKpbmIn6bq5ugasC2/S1p2V46YSE4CksR2UDPfcIR3cZrX1Rj0m9exf+9/XXK677yeTXuevUr3LNycxeMzJr2SAybqposRZ6aQ7aULDBuj8TEOjc282jIRbZUC2fc2E2qYZcVitmYurIWTtBnLjLYU+hJ2VJ648w0XQp2bHb1kjIJu++sClkSRG+DjBsCG/fGqzZ/sSf16s2N7fHidS2coLar+dXzn2Hm0rfwsUWrA8ewlPR7azgmem40DTe/8Dn+/NZWYbl2F3Vu2viwlJ1xE0tu3PChso70VXJLr/HcpFrEr4fXudG31wME5TKkuSGyiZ77hCO6DfZ2Kns23MAmn+58WO/YH9eiWGlSnNovyGGqtkhMMDK+qm7C4+9twx/++6WtkWRX0r9FCEtZj9tNKjg/nkgXdsTO8Ruem55WLTmaYliKP6/8bZiOW9JorJqe+zvSDV65jkKaGyKboLuY0MWtdm0DnGCTT3d2uWb7tHLtO7VfkD03beGYIOzl56+6FkOD1C5kS9l5btxobpIX8RPEtF0ZluKMm+70urmBvybJDO4Vn+3F4Te/jP+s35NYN811bhJj0bT0eILY+HpiV3jS3BDZBBk3hP6gdeO50TTNMmyQjiaFbok4uPZ5e8CsuXH23PCTV02T0WxVzJay8dyEkoel3LRfiHDnsbve7pt7mHGTiuZmzfZ6hKOq3o2dP/dpqXPDGSHp8E725EacpLkhsgkybgjdo+CmP9I1/1iLE297A00JrQ2bgLuznYBhUFkYN7yg2JQtZeW5sfaUsGqt8nbs3rhbI8k9N27CUjEhDbrrzim//1SzsjRNw19Xb8Oa7XXpHhYA8fwlM/CikickJhirnRuH21IBqaCHpbrxZcAtpLkhsgkybgj9bdKN5+a/G6qwu6EN/0rUScmE5kY3qCwmPtVGKwOYPTet4Zitl2BfY7vldmyL+Lnw3LgRFPOTXleGpfjrlarn5s2vavDrf3+O7zy4Ot3DApBanRt2HOyeSKfnRr6n01MUsAd7blTmuaFpgej90F1M6A812Rhw4pvaeJ0O3YvSnZobB4PKyXNjlQruxnMTEjwuNp4bF6ngbsJS/Pa7UlDMG1epam521HVdcUEgtWwpObWaN0A6az/IBmhaPDc9OBVc99yQ5obIAsi4IfS3yVQExV8z4ybN5endEI7ZTxDOgmILz42Nl4DX3PDhOjttUWuK2VJ2k5tg3HST5yZV4ybQxb2oUsmWiknZR7E0em7k85+Oe9wQFPe8sBQ7XgpLEdkAGTdESoJihuy56U4NgSEoNu8zJhg3ciq4pLmJiNlSdsYNf17se0sZBoKbCsV27Re6S1DMG1GphqW6utFmKr2ldM0Na5OQxjo3speus9vjxfjdqVFzS0wPS5FxQ/R+yLghdFe5G0ExY1d9GzRNc8xc6ip0g8rC+yHWuXFOBW+POGhu7Dw3nQhLpeq56UjdIbfwBkTKnhuf8djoiuvOX5Nk54AZNUx8zXvuOjs02WDv7LEKpQB6cliKNDdEFkB3McGFpZwnErl54P6WcEY0N04GlSoZK4LA2CQojtpm5tQmjBtN0yTNjZuwlJ2gOHlacVRNbgClA0FzE04tW4r33HSkNlIyUuktJXtuhDo3nTRG5GvUWc0Nf227s3SCW/QifqS5IbIAMm4IQ1CcLDNFerhv2desTz7d5blRVY2b0Jw9N4B4TOZUcFX0EvCC4oRxI58TuyJ+QljKhaDYTRE/p7DUx9vqsPyjHbbfJ4Pff6phqYDPmPzkc5oORG+as/HENDd6KriguenkOKRr3Vl7hD+unhyWIs0NkQ34Mj0AIvPw6anRmAqfjaZCNmA272vu9jo3Qjq1VSq4NIz2SAy5gXg1XuZl8HkURFUNbZGoII7lw0ZNoSjawjGT58Bqn+GoKnhZ7LQZ7tovuNPcXLgsnoZdWZqHY0eX2S5nBz9xd6ZCcSqhzP3NIbyzpRbfOnygY+POjmRLsevEn/q0C4rTqOHpyYJi0twQ2QB5bvooqqrhs90HEI2prjUOsgGzpbpJX7673OzJvB9yKII/HvZzSZ4fQLyIn9DLSZpwaptDpgwrq322SWEdu3nLjecmYpO9ZceG3QeSLmMFr7lJ1XPDX+pUjJur/roG1z21Dne8vMlxuVRaULDjsKof01njRr5GnQ1zRR2u/5Z9zXjywx0ZrX9Dmhsim6C7uI/yr7W7cNa97+DBVVuFSdfJuIlJbvrdDe1GzZlu0twI3o8k2VKAOPmyn0vyAgBYtpS9MbGvqd0iLGXeZ0tYNA5cVSi2MQZT7S3FurKnSmfq3Ai1hFIIS7Eu7k+s3u68/Q5kS0W6ICyV7lTwCB+Wkv5efvOfL7Dw2Q1YvXV/p/bRGYwifuS5IXo/ZNz0UXbWtyX+b3VMn+aRJ+RQNNbtYalIElGuHDrgC/npnpvcuOdGrlAsC3hrmkImwaxVOKFV8ty4qVCcrt5SjW0dCymJdW5Sb7/AkAslusGtweJmWVOF4g54bt7dUovnP9ltu+1Ut2eH6LmRvIQJjVdDWxiZgh2vnwTFRBZAmps+CnvQRmKaMKk7em4svCLd3X6Bn/CTFfEDxPRvIywV99yYKhRLx17TFMLQ0jzhM6ussFaXnhshLGXj6eI9YBEXvaXS4blJNSzl1Jw0HXSsQjGrc2N857YuzSX/9wEAYHj/PBwxrFT/XL6/7IybUDSGJz/YgRMOHoBRAwqSjhUwX392HjOZIk6aGyKbIM9NH4UXYvJvkU6pvbJ3JhRVOc9N92hueOPL2nMj/s5Pvkw/U5pn7bmRw0ANrRHT+bAKFbn23AhhqeSp4K7CUm0dNG6Expkpam74WkIphKWKEx6zZKRSoTgqeQ7FVHDXQwMAvLGpxnLbDLuhPPLON7j5xS9w6p1vJhmrfbZUW+Le7K5O8FaQ5obIJugu7qPohfCiqlg4zmGycvLcqFrnBZduSFVQzFclZj+X5vOaG3t9R0TVTJqSznlukqcCR1xobniPxIGOGjed0Nzwxk1bCp6bAYVB/ecmB49T1KUGDODCUvp92HFB8fpdDeI45Do3Ntds3Y4Gy89lRK+jVJaAeW4yJCjmO6CT54bIBsi46aMwD0GkE9lS7RHVVafrdJIsndpJUMw8N8yD0O7QW4pt36S5sXAHmD03ycdu135BSAW3uRb8MTa2d15zk3K2lCAodm/c8PVTdje02S7nlMFmtywT66opCop5Q3H9LjHzTN63nbEU9NuntVuNFTDfpyzjLlMp4vxwqM4NkQ2QcdNHYZN6JKZJb8r2k5U8IfOem/j3mffcOBXxY2MtTWhuWiXNjTyZRS08N1ZF/FolQa6dByuZXkj+3M5zwx93h8NSUoXiVPomiZob95Mxfzy76uyNm1Q0N3IjSn5dN8fEn++6ljAaWg1Br+yls7u/c3zuHqNRm+uvqkYVbLsikV0Nb1RThWIiGyDjpo8S0Y0bsQCd02Rl9tzEJM9N5946Q9Hkk2zSIn4uUsGZ5yYcVR31HRErz42l5kYKS3UiW8pNhWJ+zB0NS8UkL0Iqfaw66rnhDZVd9a22y/HHp2rO3gw5FTxVz418z37ChZhMYSlbz41L40Y453y4lO9dlhnPDX/fkeaGyAboLs4wLaEoVm/d3+3Fu8SwlEtBsZzhIVXm7cwxfFPbgkm3vIrFL3zuuFwyUa4pFTxiTgUvyPHp23LyEkRiqq5Byk9UObbS3Mi9mdzUubEzXGJCWMrOABI1KR0RocrnLpXQFG9AppIKzhtQTmEp+fw5iYrlVHB+UTeaG/k8rEnU4ol/J+7XzvDOcai2LOzLRnPFF4HMlOaG3y9pbohsgIybDHPXq19h9sPv46UNe7t1v2wyiMQ0YTJxIygOJtzwsnHgttGj1STxmxc/R1skhr8kKfAmd1YORWPYXN1kGqOSeD7zEwebXAsTxk1U1YSJ06y50XTjKD/oS+zffH7kCsV2k2rEhefGTVhKPs/1ranXRpE9BKmIivmhpxSWEjw37jQ38nrmZQ0jPT621ATFsrG6o67V9js7GyuH09w4eR7tahjxouxMZUvx9yNpbohsgIybDMPc81UH7B/2XYFdWMqNoJhN9DJuPDe7G9pw7B9fx4Ortgqfb6pqsllDRDYQbn7hc5x291t4/+t4ZVc2oRUE4mNsswhLFXLj5z075rCUZvL2RFwIijuTLRV1UZ1X3n5dSweMm054bmJCKnhHw1JOnhtJ5+Siaraqxc8L71VyIyMypXtrGhrbI7jr1a/wpXRP2l3XoI/vku7w92Pj5eTvwUzVuWH3nUcBPGTcEFkAGTcZpi1ieFC6E/ZQD8fUFATFzLixdsO70dx8sqMeew+049UvqoTP9xxoT7ouYG5hsH1/3DhkkyUbAjPA9BRbLiusMMeot8J7XUyeG1XVPRPMILKafOTQjKv2Cy68MnZv8fLndc2pGzfyGFOpUqx1VHPDjXv7/hZb4bV8jp0Mhogqnq9Yip6biDSGWEzDkv9uxJ9WbsayN0UD3D5byniMyoYuj52guC3Mfd5N9aJkqMYNkW1QheIM0554GLppkphO+MquEeEtMnkIIMfnhdejmCZIN56bCGdUMXgDI1m8X049N7QWif810QBj2+bXY14YQJyMzB3ANd3Y0z03FgZHuzShWc2BmqY5Coqf+2QX9jS0JxUU8/VIGPvT4LlJJSwVc3m/CPuLiSHMxvYoPt/TiPFDix23D7jT3ADxYxLbLyQfl9wTLapqppRwu3FZ0RKKol+ijpKMUKGYM2LaeoLnJrFf0tsQ2QKZ6RkmU5VJdc1NVNLcuPDceD2KZfqrGzEke2PltT1f7G3Uf2Zp2naI3g9NT51l+2aTWwHz3CQMD35/OT6P3j+H9zzIdWXCMcNzU6BrbszHKBeys8qqkdeTf1/8789x+8ubsJPLIpKX+eUz63HqXW+iWapt05GwlFVav0xDaxgn3/4GblvxpbRu6oJi3kA5YUwZAGDVpn2Wy6akueG9IVFVMGjceW7MtWxyberW2GVL8ft0KmrIGzS8ESMaNxnKltI9N2TcENkBGTcZJlOVSdnEGZbeqN1obnxeRRBR6t+7eOu08txs4CrDJjPyxDo3qqm3leG5EcNSbBL2eRT4vB74vfFb38pzE0h8xxfxy9fDUhaem8Q+2Lxg9YafrMM0G0dDq5HaLV+LV76owtc1LfiqWtSCdMhzY8p8M0/Kn+xswLb9rVjxuRhC5Od42Sh69YtqbOSMVQZvoJw+rgIAsOqrGtNygIXnxmW/s4gq3stuKmbL5yGqasgNWBs3dmJhfp9OYSk7zRXvuZTDZN0FM3a9VOOGyBLIuMkwbZkKSyUmWznTxzFbSndde6yNm8QDsq4ljC37rAXCUQvPzYbdxmSYmnFjhKXYdmXPDZt82f6Y+DOQ+F/MVElkgyU0FPz28wPJPTdsGatJ1Vwg0PidDzXxNXPkdZgXSfYO1HfIc5PQH+nnyXzeWYFA+d6MCZob47vPdh/AlX/5GN++523Tttg2PAowfWzcuPlkR71QNI9h8ty4qHMDxO+BVOvcmI1O1fLejn9nvQ3+erc6hPfcCIrtqlJ3NYbnhqYEIjugOznDZC4spQn7Z7hpnOnzKJaFy9gD+8d/W4MZdxkZTOJ+VdN+eEMo2XmQw1KG5kb03DDjplXS3DCjhnlurGCTG59JlpfQ8FgJPpkonHl32Bg+3laH6XeswqpN+yzEyry2xviZ177w50LTDP2P7C3pTLYUG7NV1lNTIvwlj92ut9TWmmbb/TEvVMDnwZCSXIwpL4CqAe9sqTUtm1K2lCQoTjUV3Eo3lmfjubHT3PAfO3luYi5SwTNW5yZGYSkiuyDjJsMwz0l3Gzd2mU1OYSlRc2PluYl//8E3dQCAP/x3o2kZPRzG7adZmNA1wf0vhwLC0tsve9M1ukLHv5PDUuz8+hJGTcDRuGFhKUMEnOf3JcZj0b8qzEJX8XPC3uSvffITfF3bgsse+8hSrHygLYJ9Te3CtWi2MW4iMU2fROUJtCnF3lCAcf3ZmNstrntjormlPHbeU8EbRUGffb0X3bhJnPfxQ+JC4p0WbRjcam5kcXW8ZpP4fTLkv4OYaq+5sTOWeE9Wq4PmRq7RxBDCUhnW3JCgmMgWyLjJIJqmcanK3fvGZrc/p9ReNhEk89ww1u86YKqfEtU9N8ZD3Ny/Kf77/W9swXF/fB17uGq2cio4M3bYW7EqeSTYxMHG5k88vAMO/YCY4RbhjCf+bd4ULpJ0OWyyE1o7yKEdVcMFD7yL6Xe8icY24xy1hsUwGTse3tMle9vCKVQJ1vcfE8+T1XVn45JDJXZF/Ph7QjaS2fGzJpPs/Ds1P2WFGO0MbtnJYfbcWK4mrWPW3NiHpWw8N4J+xiEsxQuK+XV6QLYU+/uhvlJEtkDGTQYRmjp28xub3f4647mJSKEfAHjx0z2Wy0RVI0tLnqzZhHP7y5uw50A77n19s2l9QAxL6Z6bxOTGqhC3S4JtJph08tywSTrCtTbIC9obN8yAYgYQm7f6cynB5mwpFVtrWtAcimIvV8BRNgZZGIw3ImSdVEf0WnpYKuCgubHx3NhlS/HF7GTvkizWZmFBKwEtm+CZB8W+gajZGyYIijtQoVhVNVvD1257/OdO9YJEQTFv3McsP+9OKCxFZBtk3GSQTLqj7d4QXWVLeRQ9dMMTU+MhJX6yffWLamGZiIU3Q56sZU+BohgPXDtBMZvUdM9NwtBolTw3TDDp99k/xJnhFlU5zQ3nuZHPnZ2geEBh0HSsjBbuDZ837mSjgO3fqgEoI5WmlwyjIKOT5yaij0Gs/GsthuWR6+aw8BUzgJiHwOq+Z2Nj59zOeJOvQ7gDnhuTgaRqth4a289tNEimfbkKS3Wf5+bf63bj7c3xjDUq4kdkG3QnZxCrTJ3uwlZz4/BwNjw3dtlS5u7Sctdq3nBhXcBNYRZpwuO9LHKV37CsubFJBWeTKNMUuPHc8JqboM+rp3rLE3JIFhQnxlJWYBg3dVJWkJ0nRp5A2fniz6vJK9IJz01BwiNlZSA1cfV0hAKENtlS/NhbpPCMLOjm0+3txsZSst10R2fbsjPC7DD3j7I3buyMJSFbyiEsFRPCUnaC4u55yalrCeP65etw7ZOfADBeOkhzQ2QLZNxkkEw2zLMzptx7bszGTYxrNMmQJ2J+QgpFVcv9yZO1n9MB8JNsJGYISmPS/3IqeIwbe3ybbjQ3hvHk93p0MTLvfYrGVH1MsuaGd/GzhoxBi5CH3FWch22bP6/svvEk0aQ4EZXGbGXUsrAUIN6foubG2jCTwzO65sbkuTHfh8wIYCJutz22IjEt5fYLVoJiOwPDrm6O22wp8b6x9vZ010tOSygKTTMMWNLcENkGGTcZJLNhqQ5obpj3w2sdloqqmkm7IQss5S7c/GSQb/Omzhsidl2z5To3+VxF4QjXV4o9vB0FxQnDjdf0+L2KpbeBzzJi42dj4A25HftbAMAyzdhJhBq28Ny0S2EwJ8/NrvpWnHDb6/jzW2KfpKhsBFqIkhs5rxu/D1UyUJmHhDcmZA8GW19Oxbe672XPjW1YSjJC4kX8jN9TERQzj0Xcc2O9rF2FYqGIn4Pmhr9voqqRFSg2zuye5wD/UqBpGrVfILKODhk30WgUr732Gh566CE0NcVrlOzZswfNzfZ1Lggz7RkMS9l6bhyzpQyPRNBCUBxTXXhupCad7K014PNw9WXEsfmEsJT1+PRsqcSqfOfytkhMKEAIuBQUc8ZNwOux1Inwx8sMFzYJ8ssxz01ewNzOzbmqbcK4sdDlMJGzkxj9/je2YmddG/7wX+sWCvlORfxswlKyR4QZXrw3QvbchFIwbkyaG5vjkz03UamMQCp1bphHKa65cbc/q/24TQXnt5cJzQ1/LHwozk+aGyJLSPlO3r59O8aPH49zzz0X11xzDWpq4oK0W2+9FTfccEOHBnH//fdjxIgRyMnJwdFHH40PP/zQdtnHH38ciqII/3Jycjq030yT0bBUJ+vcWKWCR1XV5AGwE8gC8QmVPdhz/V59wgtz3gAACHgVy/XFfYuam1y/oZFpD8eENHbAneeGL+IX8Hl0sWXEQgya4/fohhO7lPxkvyNRz8WqtL+TccMmdv66sH0yz42TQeq3CDPw9WH0sFQKnhv5VmUGnivPjZ4tFR+XlbA9Khk3dvekvG5EaiXiwrbR/+6YcRMPSyU3Yuw+d5sKHv89Ydxk4DkgNxwlzQ2RbaRs3Fx33XWYMmUK6uvrkZubq39+/vnnY+XKlSkPYPny5ViwYAEWL16MtWvXYuLEiZg5cyb27bNuqgcARUVF2Lt3r/5v+/btKe+3J5CpLIm4K9r6O7cVii2L+MWMsBSbvFrDUcFQ4R/e8caUhnHDDI5wTNTi+GwExTxsglG5hzRLJW6LxEyNAZ00N0GuBguvuQlYTMj8+Nm8wI6Xn8ycw1IOb/tR+2wpN56b4ly/6TN+7maCYtlzE4rGxFIFUXvPDVuXNwpkHVGIE2YDRlaO1dh1b4oeHnSruVFFzY2LuBQbMzNoY6pmu559FpXxs1MquMnTpBs3qumzriCmavj+/32Axf/+zMJzQ5obIrtI2bh5++238atf/QqBgNi9ecSIEdi9e3fKA7jrrrtw5ZVXYt68eRg3bhyWLVuGvLw8PProo7brKIqCgQMH6v8qKipS3m9PIFOeG6t9sUnfsbdUkmwpPizFunurmvjmzRsGoYiqn4PcgFc3iCIxVRgHb4jY1jxhxfw0NkbDS9IWiRmC4hQ0NxGV19wYguKwEJaK/5zr98LD6Tbix2Ge7K3OmxvPTbtFEb88rt+V3YTMGzfMm8IbXXap4E3t9lops3EjirYBc48lk+ZGNyDFbWmaESJhxqndhC9/Hq9ubfzuKhVc8txEHTw3bor4pRKWYvtu565/V2pudta14p0ttfjnx7tMnhvS3BDZRsrGjaqqiMXMf8C7du1CYWFhStsKh8NYs2YNZsyYYQzI48GMGTOwevVq2/Wam5sxfPhwVFZW4txzz8Xnn39uu2woFEJjY6Pwr6fQ3oOMGyM84TZbyk5QLBo3gL1wOhxTubCOV9Bh8JM5/7y1O09ytpRHUQzjJhzjHt7Je0vxnhujMKGiG0b8BMQMjRy/1xClWnhuGJaem4h9KMPQ3Jj3mc9ty87o47Oz9jfH09H5ic3OuGmUUvjFsJQ4SbdZhKVMnpuooa0CjErRTt3S2T0me+ve/3o/vrXU3LssKoWl3GVLMc0NK8BonwputznXYSnpWK36u3WlB5fdjzFVzCrjNTdU54bIFlK+k08//XQsXbpU/11RFDQ3N2Px4sU444wzUtpWbW0tYrGYyfNSUVGBqqoqy3UOOeQQPProo/j3v/+Nv/3tb1BVFcceeyx27dplufySJUtQXFys/6usrExpjF2JMOl3YzdgK50Dy5oJSxMED3Nde+1SwVVV92TkB726voJ/m+XTYUMRQ1Cc6/cYYamoaptibJ854xCWCnOem8SkapWSzWDHxnud4mEpC80Nb9wkig2yMVhNVFZ9ixw9N1FzKrghKDbEyXZGKX/uWINNflwFNoLiRtlzI4SlxH3oVaC57Sb13NhUKOa9JnwxRZ6X1u/Fl1VN+N9ne4XPTWGpFOrcGP3EzPe/TzJaZYTeUi5TwQFOUNxNdW4inHdTrrkjh20JoreTsnFz55134t1338W4cePQ3t6O733ve3pI6tZbb+2KMQpMmzYNc+bMwaRJk3DSSSfh2WefxYABA/DQQw9ZLr9w4UIcOHBA/7dz584uH6Nb+Fi7VRn6rsJKTMx7FJIZEHaem0jM6Fyd4/dynhOuGaRQxM8wYvICPs54UIXJVrXR7PDIXcE9iqi5iUiCYiuhLSOHM3zYxOPns6UsSufnBriwVGK4ViGGoM8Def5wlS1loX/hDaVk1wwwjBvBcxOw9tiZPDd8WEq6V9m1cvLc2Na5sei5xdCL+EXF/TUkxmYlVldT9NywaxnkDFrZuOHFxlaIRfzcpYLHx2sVlupCz43eh00T9hP/PfHiQpobIksw56UmYejQofj000/x1FNPYf369Whubsbll1+OSy65RBAYu6GsrAxerxfV1WKJ/urqagwcONDVNvx+P4444ghs2bLF8vtgMIhgMGj5XaYRJv1uDEtZPUDzBS9AzDKrR0+n9loLinnNTY7fi/yAFwfaIsIDn38zDXO9m3L8Xn3yCEvFAGMqUN3YjnU7G5LWPGGb571LHdXcAEYowu81sqWsBMU5fg/YvGBV58ZYXoXP4xGMBaeqtvoEaKGF8nsVBHwehKOqrRCcH0NtcyjxWXxbisJlJMlhqXb7sJRJcxNlmhvjs2R1bvSaQTYZRACvfRKXaUhUeza17ehI+4UYC0sZ45GvW9DvRUs45rKIn1OF4uSem658Dgh/e1KNKPLcENlGysYNAPh8Pnz/+9/v9M4DgQAmT56MlStX4rzzzgMQ1/SsXLkS8+fPd7WNWCyGDRs2pBwS6wkID7UMh6XiqcwKYqq5hYK+nuC5sW6/wCbhHL9HN5B44ybMC4o5z01uwKs/cCNSWErVNJxz3zuobgzZHpPsufF6FH3iTllzY+GVCghhKXNadi6vuZHCUn+afQSuf+oTqBowvH8efF4F/LxslS2V6/eiLRLTz5eV8eLzeBBMGDduqvjKnhu+u7ucwi8LivljlsMzIV1QbCxjV+cmKDXODMesJ3yA1z6Jy7CWHnKLh3iNGuN32Qj750c7UdMcwjWnjBbWie+Ly5aS1tM9Ny7CUu2ReAsIj4WRYO5ArgoFJvnxdAV2Xep5zQ0JiolsIWXj5i9/+Yvj93PmzElpewsWLMDcuXMxZcoUTJ06FUuXLkVLSwvmzZunb2/IkCFYsmQJAOA3v/kNjjnmGIwePRoNDQ24/fbbsX37dlxxxRWpHkrGyVRvKSvxqd8bnyhbwzHbjCk+W8pKsxLX3MR/zvF59Wwe/m3Wrohfrt+DtrCRjdQuPXydDBtArLgKSILiiFlz4+S5sSpQ6OcExVZF/HL8Xr3BJ5sc2bGWFQSw9ten4YVP9+Dbhw/CPz7cIWzbKpSRF0gYN1F7z43XoyDo86AJ9pobfqzMuOEzY/RWE4mO2mxyk8NS/PblOZ6NTciWSuK5sRJnA4Z3waMYRoXszWhojY8tmedGyJxSNfziX+sBAGdPGIxh/fOE/TMjTw7Z8GO29dxYCKx5T6h8bMZ4zX3VujIsJYj5+QxGLkOMivgR2ULKxs11110n/B6JRNDa2opAIIC8vLyUjZtZs2ahpqYGixYtQlVVFSZNmoQVK1boIuMdO3bAw/3B1dfX48orr0RVVRVKS0sxefJkvPfeexg3blyqh5Jx2sK85iZeuI7vgN1VWIkWfR4l8TYds0+3Ft74rT03MU7DYOW54R/evHA4XucmPiFGYvaCYjvk+iRCWCocM/V7cqpQ7PUo8HkU4U2XTwUX+wIZYTVmGOjGDZswvB6U5AUwZ9oI/XceK+MmN+AFWnjNjXkZv9eoFO3Gc1MrZUv5pZT+dm5SdgpLyddD77zOfWzS3Ng0zrTLlvJ5uF5e0oTPwlJmzY2ULcX9LPTJUsWJHTDEy6pm/vtI5rmRPT0t4ailcWNVobjd4jx11XOAPzchO88NaW6ILCFl46a+vt702ebNm/HjH/8YP//5zzs0iPnz59uGoVatWiX8fvfdd+Puu+/u0H56GvwEriWEjN1RRMvq7dDrEbOVrBCzpYwJmuk+ojENMc0IS+VZGDcRwXPDpYIHxArFcljKzTHxk49XEhSzTCY3mhufJ+6l4Y0bn0fRi/gJYSnOOGP7MMJSoohZH5v0u53nht+GlefG5/UIhQ+t4CfUuhZRc+P1KoIHLhRVkZ+QpzW2ua9z0xyKGw58WMouW0ov4mdhKPK/MwOTH2/8e1XP5DK39tBsNTfM2wMA/NmPSJ4bfqwM3XNjcxvKp96uKKNV0UHZc8OW64rngPxioX+uqroHizQ3RLaQFh/kmDFj8Mc//tHk1SGckR9s3RWashIt8o0h3Xhu+Dd+NhHzdW5y/F5B86LvW+WNm5hgHPi5N3U+NGbluZENBP7tEwAUjzEuvkIxW89Jc+PRvVhxAj4PFEUx2i9I6eyAXbaU4bnhkScQq9oouVJTTKvGlnGDy5MYh7NBCnBhKe46erht8AZlKoLiZr2ztPFZi2TcmOrcJCZv+V7jw4cBi7CUnKIujNEkKDZ+rk94ewBReyL3loqPVRyTnOIvI58Pu4wpcwjOCEvx++8q3Y3wYhET/77kvw+C6O2kLcDq8/mwZ8+edG2uTyC/4TmV0U8nVg9PwQuQJMQh17lhHhK+zk2Oz4tcP9Pc8MJp8e2xTQhLcZ4bbjK3CgfkSWGxqKoKGgvBcyPUuUneONMnGzdee52IXufG5wFbxciWUoX19O1Lv1tVtWXHp/eWsvLceDy6xyFsUVgzPgZzWEquRquLinnjRtLc8BMjs5dY9eOmhCHjXMQvEZaSBMUmzw0XHrHq5dXAGSmmY42JBi7f9oP33PDHwrad45BWr9eHcW3cWBtg5grFmv4MKMzxc8t1zXPArl5UlHsxcDL6CaI3kXJY6oUXXhB+1zQNe/fuxX333YfjjjsubQPrC5jFhN1j3FhlZvm5N3i7h6vYW8p4COZynpuQ7rnxID9ornMTFTw3YraUWOeGC0slhK5yDZQmzjsgV131ehTkcJ4jNka9zo1DWMqrKIJ3hXkZnLKlcgJeeExhKdGgYsi/W0Xd8qQaL5bZUry3zUVzSXO2VHzdHL8XTe1RIfTVnDi3RTk+NLZH0dwexY//tgYnHjxAP89FuT4caIvonhuhiF8SQbFdV3Dec+O3CAM2SEYXT1xQbPzO/yx4brhxsr85vrSB7Llh+7fNlpKMHjvvkjntXUVbJHEuc3xGqr6FB3dnXSte/rwKB9oimD99tKXoPRkRG+OGPDdENpKyccNSthmKomDAgAGYPn067rzzznSNq08gl7zvtrCUTZgnqedGr3PjsfHcaLrHJcdGUMxvOxSR2y9Y95aKqfGMIz5jSq7Dw799AuYifnyNHiC5oJh/g/VLnhuhs3nUmBxN7Rf0vlTOmhsrWPVhq/YLDD50kyx9H4ifh9Zw1DSRMf0Ub0Cx7RXl+tHYHsVf3t+OhtYI/vdZFWaMLQcQ99zsRJtuCPGTfySmIRxVTeMzFfGzyZbirwE/2R9odTJu7Iv48Z6bqIWgWNDcSGMaO6gIm/c1uw5LyV4vfV8WXir2WV7QC0WJG7pyXZ/dDW049c439XEdOrAIZ04YZLkPJ/iXJ8FzE9NIc0NkHSkbN2oXlgfva5g1N90UlrJqnOn16JOwmzo3vEYgn2vgyNe5yWNhKaG8PPf2yAkq8zhBcSiqwucVBcVyXR25jYFVthTzfrRbdAUP+Owf4l6PIoSODOPGoc4N57lh4RBmRPqSaG6skMNSlpobr5GSb99+Qfx8f3PYVNCQeS14zw2b/Fh7Bt44YOsXJUIpunEj7as1HEXAFxC2Z86WMmcQASxbyjCAtuxrxv+9/TUGl9gXCjW3XzC+48NZ/D7ZfcEbu8z7uHTWJIwckI/XNu6Lj80uW0o69bbGjWQc8QLogNcDf6K4o2wEbd/fIhhcsh6KJxJTsa22BaPLC0wZV/z+eUOWPDdENkIB1gySKc2NlYeIVbuNf588W8rn9eiTNPOixDU3ZkExnzkjdAWPxvRUal5zI7dfkMXCgDnbSQ5LeRRDR9HKaW68uubG3q3PZ+rw+xpQEE8lWrezQf+OT2WXw1K650aaMNxkwrBzyoyCZJ4bN2EpIB6akt/SrQr5ycYND7sUuubGQlAMiLobORVc1y/ZVCjmPTeRmIprn/wET320E3e9+pXlcbJt2Wlu6nnPjUVYyu9V9ImdjbWyXx4mDC3hsuCs98vuu0I9jd4mLCV3II+pgtFnaLrEayYbrnbXGgB+/vSnOO3ut/DMGnOvPadsKbkOFEH0dlx5bhYsWOB6g3fddVeHB9PX6M4CXsJ+LOvceBBIUjNF9n7k+L1oDkV1LwqfLRX0mcNSmqYJBlw8LBWfCMRsKUmHoWmmkID8EOY9Nx4lHi7lw1JGkbLkvaV8Ho8Uloove/4RQ3DPys1486sa7KxrRWW/PLH9ApctpaqabgTInhuvi0JpplRwO81N4pq5CUsBcUOEeQvYOJjnhm/BwLZXkGNl3Fh7bkzCWs6olXtL8ZlxfF0XK81NVNXwTVWj5fHxxLdlHicganX4sI+ui/IaFbrZWNn1ZJdPs/XcxD8vyfejKRTVKyibxpdYLjfgRSgar0wc0Y0r42VBDkvJrTGcjJvn18WTOu5+9StcNEVsEmzXfoH33Mj3KkH0VlwZN5988omrjXVHAbpsgk2Meqy92zw3HUsFl0u05wbixk1ekNPc8GEpLhWbX5/Bh6VyBEGx2LVY5R6+DFmUG+U8N17JoxRvv5CYsLzJBcUeDyw1NyPK8nHCmDK8vbkWf/9gB2789qFCV3A2maqqJkxQsqdG9uRYYa5zY50KHnSZ4ab/zhmKvJEa34d58rP23BiCYgCWgmJA9NywMAgTwvKVcKOqZhgyQp0bQ3MzvH8+vqltsTxGhqmIn01YSvDccA1V9ZRvZpQmzo+e4p9Ec1OaF8DOujZbXZAoXo7o7ReAuNFnZ9zLNY7ceHhrW8xZZXaeG1adGiDPDZE9uDJu3njjja4eR58jElP1t8bCYDwjJZNhqbig2FrkyTA8N/GH8JUnHIS12xtw2OBiPLt2d9xzE7UISyUmOXm/cc+NOSwVjqpCpTWrfj+ywcCHrlh4iNfcmNovOKaCeyw1NwDw/WOG4+3NtXj645345bcOEVLZeSOOn0jkkvbJdA0KF1LTw1IWxouPK7xo1zhTvpa8oegkKGb7LbTw3Nhpbtx4bvRsKU7zFImp+jnmDWg/Z2yPLi9IatzIhRxt69xIXgsgfj/ZFVvUw1K2vaXi/5fkxfVFdpoYdk+w881E14DYdd4clrJOq3fCytiVm9bq4+c8SKS5IbKFDjXOJDoP/yZemBPPSOmu5plW4S8f1xjSTZ0bAPjhiaMAAH97f3tiu0aWUzxbSqxzY3K3x8T2C/xkxocAYprZcyM/hKOqKnQEZ2Ng+zcm9ITmxikV3CMaJLwhNG1UfwDA/pYwwtLxMuNU1UTjxuS5SeL693s8KEroWfYn3sAtPTde0XPTHomZhNeyt4FvkWFobpILinn0Ojd5hnGjWuiiWiyy5PSaQdz5jVh5UrxcWCqmWvYyY7AK2eGYKmZLcT/Xt/BhKT6ri50Lj6n1gBGWSlLEL/F5v8T5sAtL6a0euOxC1jiU7zqf1HPTwecEf575In6kuSGykQ4ZNx9//DH++c9/YseOHQiHRffns88+m5aBZTtMTOxRoNeD6cqOwEA8pfT+N7ZYhkX8KaQVyw9ANgnFO4obGpRoTKxzIxtvoQhXoTggpoLzxoHVxCkbCLygmL1p840XjSJlZs9NwOsRvGZe2XPDeRn49fjGh7kBr16VNyaHpZK0X5DxeRWMLMsHAHxd0wJNs+7UzntuPtnRgAm3vIIfnjASN8w8RF9GvqdEfYV4nngDip0Pqx5JsuYGiPdTkvfF17qRBcW85ili4UnxSr2lnLyaOXr7D8lLxQ2HNzj45Ywq0kZYisGuky4Ut/nzZOcjqecmcU/odaEkQTGvMeKRDVsxpKTC51F0SUDQ53HInOOMG0mwT5obIttI+U5+6qmncOyxx2Ljxo147rnnEIlE8Pnnn+P1119HcXFxV4wxK7GszNvFYal/frQT//hgB55Yvd30XTwV3GW2lOkNN6GN4DQ3VoJi+aHdHIrqD9wcU7YUX6FYfGseU15g4bnhwlJSi4VwVDW53XnNjezF8SqK8JC30t8AcWNNTwWXuoKzSZOfeBjJ3o59HgUHJYyb3Q1taGyPWhb683kVBBPj+XBbHcJRFW9vqRWWkcXjfPiOL+IHiN292TJWnhtmROYGvPqxtIRiJs9GSyh+blRV070GzJBSuEKJogbGLCiOh3AdjBs/19ncQlAcjqp66EzeX4Q7F/I9pWtuEh/beW7YuSpNGDdWnhtNM84BE3CbBMU2f3+mbKlENeqG1jCm/O41zH/S0ET2zw9w69kXCQ0LnhvN5JUliN5OysbNH/7wB9x999148cUXEQgEcM899+DLL7/ExRdfjGHDhnXFGLMS0WOReKh1cViqzkJkyOBTwZOlFcuTM/s9pmpC9lBeIizFDAB5u/wkkOv3CmExPjuI14n8/Yqj8e/5x5mzpbiaIXL/KCvBpOC5kY0br9EkU17W61H0yS4cM8YZ5LKlVE4cbpX2nSwV3O/1oF9+QE+13lTVZLkc352dHV/VgTZhGTkEGeMmWT18x+rcRM3XyUpzw+Z4r6Lo2VTNoYhJk8KMYX4i5c+1lTFtpbmJchlMVuRy4mveAGHDaWgT73veq8Yb7LaaG7eC4vz49ZKbjsrrMs1NNGYYN0Gfx9LYA+w9N/9etwcH2iJ4af1e/Tve07aPK3oJyBWKrevcUFiKyBZSNm62bt2KM888EwAQCATQ0tICRVHw05/+FH/+85/TPsBshS/+5rfoodMVyG+U/IPMVYVim7c79nsoohq6Ap8hKG4JR6FZ6GZYfRRv4i3d0Nxopjo3bAIZOSAfeQGfyX0ueG4Sw+M1PBF97GIROflngLVf4CZhyfhh220OGR6VXL9XTxnmJwtZTAyYM71M33vj3h7mvdm41zoNmtdJMWqaQpaCWeN31aS50QXFiXPOX/+CoB8yKncfMM9OU3vUtC92DnjPA2/cWFUpFj03hsjYqis6gxlnEZvGmXL2kljnxrhOHpv72qMbrXbGTfx/Piwle3mignGTGK+qcoJi3piz1tzIf592HcUZ1Y3ttt/JvaWikmeTIHo7KRs3paWlaGqKv0kOGTIEn332GQCgoaEBra2t6R1dFiN0w/ZZFzRLN7Jxw7cw4CdK+7CUGM7Q1008EHnXP99+QdXiE5xd76y8REiHGRGRqByW4jJ8EiEeyzo3mpgtxU+kbHtGhWIHz41UoVg2INjvzVyxtqBPLOIXdfDcJNXcJM7vyAFx4+aLPdbGDa+TYqia0SATMLfaiKlioTw2dsDw3IS4JpwszZ+Hra8oRtiKDzEa+zLCQgwro5I36nXDyyvqnnj9Dh/KBaD3EJNbcLD7ob7Vvgko72FLli1la9zoguK4caNpwJ2vbsLFD63WDSveuNHblXBaIj9XIVx+yWHXpSjhJWPGolX3cd5LViUZNxGbsFQspnJGJWluiOwg5Tv5xBNPxKuvvgoAuOiii3DdddfhyiuvxOzZs3HqqaemfYDZimWWUBeHpWTjJo8zbvjGmXbaH7sS7V4L4ybo8widu9vCMdvtsslJbJwpeh/YvML2JU9EVtlS/ETKPGVswuQFrbKBIHcFlwv+MSOshTtevsKtyoV+rASaycJS7HsmKt5oU8DOK7XBYOzlQlOylybGZ8aw9gtSV3Be5Bq0GD8LaXg9ih62am6PWoSlmOcmvnzA6xH0R5aeGy70yXu9mH7nJ6eOwaOXHYV87t7N5cI8oucm/n+91EmcNzR0D5tXMXlu2ESfrM6NoUEy2mE8uGorPvymDv/9bG9ibMYxsvs9wmlu4hWKjePgYR41JuBm18cqg44/l1UHROPGvkKxZronCKK3k3K21H333Yf29vgfzU033QS/34/33nsP3/nOd/CrX/0q7QPMVlh9lxyhMm/XhqXknjdxTUw8Lu/zepJmS9mli7Lxs8k+4Iu7+D1Q9Eyk1khMf7jKGR3sTZbV2YmnWBsPbv6BrRs30kNY1QzPF/Og8EZJm+S58Xk98Cjx9WQDweORu4LLYamEiDYsTtqC5yYxFqvMNDeCYgAYOaAAgBGWygt4hbd1/prx8OEI/pxHEynxhgEhCorlsFTQZvu6ZkfhwlKhqN6cVN+35LmRt5Vcc2Ocp5aE5+aUQwbgiGGlCW9TRBh/OKYiRzX2wcoJNMjGjYUx5fV4zJ4bRa5zYzoVACB4DIty/ahpCumG1TubazF76jDhbzugGzF8WMoDqy7ogOG5KUxosNhLgtx5Pb6ufVhK7C1lky1FYSkiS0jZuOnXr5/+s8fjwY033pjWAfUV7FKgnVi/qwG5fi/GVBRafq9pGq7++1poGvDg9480ZemYwlKcZ4X3VtgZWXzHZh7Zc5PDTWJ5QS/CrfE2C+z4CoI+hKLGhMPGwQurrfoc8fuycp/LZfN5A4Z5bvjWB35v3Miy8tzYZUvxv7PJha0vCortPTfJ2i+w7TPNDdtWQdAnGjcWYSlAfGM3ul570RKOCWn1suZG99xw3gSrmjzsOiqKggJWyI/z3LCK2yxcozentDFu+Ek3wo2Nv8/YceuNN7lt6e0/YqrUfiH+/35JSG9ZV8ejmK4LywpkH9vXuYn/71EUFCeMG8Y7W2oFY5fPAotxWWQBhzo3zNCXw1LsBUk8Nj4sJQqKbbuCk+aGyEJSDkvNmDEDjz/+OBobrV3lhDvaLMJSTsbNgbYIzrnvXZx291u2D9mWcAz/+6wKKz6vEgqoAXHDR66/kSdobnhBsXW1WzvXNZsk2UOXLySXxxXSYw9yuXYKc9Oz89AeVYUJyMpzY/UQDls8oNk2Zc8NYO5Qze8j4BC2CuieqlhiH2I9lHgquL3mhi1vZySydZhxw5Azl+JF/MyaGH5SY9dMb9bI1eCRix2y68d7Wqw9N8b6VpqbgGS0RKXsLIZu1PNeBG7biiIaAvxxCJobIRXcrLlZmejqzeC1bUadGw9kO85IBU8SluK8TUXSNTrQFsFnuw8Y3jKvYTjzFYqd6tyw6yKHpdoihudG70TP/a1Uy2EpG0GxVXkAgujtpHwnH3bYYVi4cCEGDhyIiy66CP/+978RiVgXrSLsaQ9bGTf2YakmzjCpbQlZLiM/sHjaIjHT9gVBMVcQzm3jTIY8afHGDV9DhT14eaMKAEb0zwNgTFhNkhHGa3WsQk4Mtn1+OAHJy2IlFLYWFDtobqRtst/dZkux8yUbK0xHwoeLRpcX6N/nBXzgnXF+m7ARnw7OJnK2XEzV9PCRXRG/ZMYN+96jGMdgZdyw3/XJ31TvJ3HfW2hg2D1m5zXjDVLDuDH3ltpc3YQ12+vh9Sg4b9LgxHJmw9nntfDcyKngttlSRliKpe/zvL25RrgfWKgyqqqCoNjopSVnSyU8N4leXmELQTHbPn9ssqDYzriJqubCjgTR20nZuLnnnnuwe/duPP/888jPz8ecOXNQUVGBH/7wh3jzzTe7YoxZCd8w0o3nhg8xyUJBhijMtK8pwxAExVzjTDsjK8bpE3jkByILc8SXNetQ5Elz8vDS+Oc2+49Ejd99+oSTPCwFGOJfJlD2WnhuZM1NvIifveaGfcc8N2w7uueGE4pae27iy8vGDfOC8MYjm5CB+Hnlx2InKK6y0dwAouFl1aYCEFslWPXgYtfHI6WCs0k+mLj+zBiwC2fy2XEMvkKxfC4A7pr5eePG+PsR69xoWP7RTgDA9EPLMagkV19O3p/PY5EtJWlubLuCM+PGA71tBmAY7R98Uyd48viil6Kg2CZbShYUx8zGDfO+8MZdbbN9WErU3FD7BSL76JAP0uPx4PTTT8fjjz+O6upqPPTQQ/jwww8xffr0dI8vaxEqFLvQ3PBizb02xo2T58bauDEmV16cmqrnRnZl854b3rjRdShcZhYAHDksbtzY9VwKW4SlrB7CId2jYJ/G7ZM0N4DouVGU+KTtt1hO/p2JXAO658Z4w486am4SnhuphgwL1/EG0XlHDNF/3t8cFo7H77ETFBuTmq65SYSvYpo5BMG8DSxsGeImXCvjKRwzzjMflopy+hHA7Lmx644uhImSeG4CDp4bVRO9QKqm4fl1uwEAs6dWGvuzqlDs9QieJXYfAC6ypTjPFO+5mX5oBYB4MT1eg2U0yHRX54ZlmzHDySpbyqqKc2s4Zur+zZArFNsZoATRW+lUgLWqqgrLli3DrbfeivXr1+Ooo45K17iyHr5svy+JxwQQXeKuPDeycdPq7LnhDY6QjZGVrIgfI8dnNm6iqvHw9Xs9Qtr4oQPjAmm7ZpbsAa0ohgfLyiNi7bmxH6uV5sZrsX27Ojd8dhiAlLOlTGGphKHAT+hDS/P0n7+ubRHG5fUqlp6VvQfadC8De1vXPTcxc2YMKz7H7hFRB2LePj+Z6xWK240Kxex8MCPCroQAX7TRtG2vjXHjICjmx872z2r+TBxaYqRaC5ob4zrx4xMKXCbNlor/7/EoQr+tKSPiRvv+lrAgKNYrEfOeG6+RrWXvubEPS/EeOR7+pSZmU0crFjNn0BFEbyflO7mxsRGPPfYYTjvtNFRWVuLBBx/EOeecg82bN+P999/vijFmJe1W7RecPDfcg8vWc+NQmTZZWMrnUSzDBDxRqWaKvq5kaPAhA7Ys32+Jn7DyA4ZxZ6WjAfjOzdaTD8NJUGz8bv6Onyjl1g3y94BhMDHjxi95bsQ6N1bGDQtLiZ4bZuzIx3bXxRMBANdOHy3W3/EoQgiQ9RVqj6h6CwAjW8oIFck9wpi3oSkUz2gTwlIO3bjlIn4sJMTWYeEa1c7jx3kwGLLhJZ8/q1Aib9zw3gx+suc9JuzaqKqmGyY+r9hbivf+Jc+WMmtufB4FE4YWA4jX2YlYCIqjMaMruFOdG3ZMhXJYintBiMQ04e+WXRehYajN+HnNDXluiGwh5VTwiooKlJaWYtasWViyZAmmTJnSFePKenTNjd+rp3q6NW7k/kEMXpsiP8ga2801MXLlsFRiFatie/xEYNdgkME8AYDh0o8K1ViN5Q8bUqz/nCwsxU84VuGesIuwlKXnxmc2xqyMIPl3lpEmZz/xNXesjqmiKAjA0GQw8gMsLCWuc8GRQ3HMyP4oLwzi2bW7jbF6PQh4jYm9vCgHqqahvjWCvY1tKM7zc1lGRg8q2YDgM3wa2yJJBcUMuf1Cjl6vSPSQGBOntQdM1MCIBqptWMqiQjEgaknkLDu/JNjl/0a8Dp6bpNlSXDd6Jvod1j8PAwqD+nr1iXR0v4fPihLr3AS4z3n0bClJUNzE/U3HC10yIwvolx9AcyiKA1xfLafK4+zY7F4wCKK3kbJx88ILL+DUU0+Fh9yXnaKVC0u1donnJrmgmH/jjT/U7DU3fFhMdl3LkxbfmZhvqmmlQzmXE8xahVgAw5OU1HNjEZYy17DhPDKJBzlvIDBjTNTmOGdLsX0wm0rWF8l8Z/JQDCnNxaTKEvzfO9/on7NWB1YTzOCEGFYIS0l1bkpy/VAQbzewt6Edhw4sshYUS8Jwn9eDwhwfmtqjONAW0e8j1syR1a2R8QiNM6OmMJ9Jc2PjuRHrzsiaG9FQZWFJPgU+6DPqGfHw93G8dlFif3r9HeN7v9R+wWvxs31vKUNQPGFoCQJeD045pBxBnxcFQR+aQ1FUN7Xrx+zlDH6rCsXyy4WeLcWlgquqhuYw77lR9fvP7/XoHqSGVj4s5eC5oTo3RJaRsnFz2mmndcU4+hxGWMrjTnPDe24akwuKTZqbJGEpr0eBAnthM79/rzT5ypNWWQHnudH1CqK+4IX5x2Ht9np8b+owY9mEHkEeu+65cWnc8F/Jb/4d8dwkr3OTCEtxHiMjW8pssPm9HpwwZoA+Vna4hXq2lP2Lg9wWQuXGVpzrR0GOD1/sbcSuhrh3j03gVtlS/DkszvWjqT2KBslzoyhxXY9V1Wqvx9huOGpk3PBp5/ExOGtuBM+NbHjxxijfD8wrXrOAz2Nqril7boywj5r4XjTYPXbGTRLPDV/Eb+ygIny6+HQ9XMg8KKxDt8/jMTxIqiZ4bowwnZjxxc49H5Zq4pq2ymMLeD0oyYsvy//d22ZBqtRbisg+6E7OEG1CnRt7o4LBe072Hmi3TEu16tHDkFsvAHIquHO2lKBfSKK56ZcfNH0Xk9KjJwwtwWXHHWSqosxP3qMGiBV6hQnHoXIuH5Yye13caW6cKxTHl2GeGzbB8+NjrQySufn5bR8ysAgAMEIq3me3vOy5Kc71Y0jCw7O7vk0IJfJhKTn0A8CYDFsjguYGsBd6x4vsGRO1YdwYjSzj+7TWaunrOnlubBqcytfMKWUdiBsoAcl44LU+cio4741M1hVcD0sllssNePX7ujThxdzHeW74nlq8wS+HzQAxzMbCUgD0MBdDEOz7rD03do15Bc0NhaWILCFlzw2RHnjNDXtQO4eljO/CURV1LWH0LwgKyzhmSyVLBfco+gPZMizFTxRJsqX6c54bNkmIoRonz4QCNtTDhxRja02LMEZ9Od4D4433rwpZuNYDUgVfr7QeIIpTrVLNzXVurD03/Jt/SA+lOb8/8F6RM8cPwnGj+6OyNM92ecE483jgVYzrUpznR3lC57GrvlW4BwwdDFdgkNtWSW4iY4oLS9lVcGZ4FQUersqwXRE/e89N4n6z6S0VP0ZrQ1X0tnkS11nUlTEjgaV1y0UD2b48ie9ts6U4LZUVcjd6nn4Jo3F3Q9y4CfoM4TJv8At1brgdhThvFJ+JtV8q5Ck0v/QYwuYGXlBs67nhNDcUliKyBPLcZAir9gvhqM3TE4Bs91jpbqyEmTFVwzuba/WCXkzkCJg9N1aTDYN/67OrNMvgw1JsPuLj+gGf/QOUN0YOG1wkfMdPHvxExEIAlpobUwiN88j4jCwttgo7Nseu4FKdG6uwFKtN4rYDeHw8Cob3zzd1p7baN5uQWf8sQPLcNLQJoQpmwKlcnRveO1Gcx970w7qxZRW24/Fw7RHCMVX3YASlsJRt2w4XnhufjUFj9txYhClj1tvSw1JcjRu2HX6b/HHyx8GjaUbHeqvLxryYG3Y1AIhrp3iPVUgPS3FeMO7vr53rwM5r5Gqa5GagxsuDnwtLNbrJloppJqOSIHo7ZNxkCL39QsDL1b2w99zI31nVuuFd2GzCuG3Fl/j+Ix/g7c21AKBPfkDibZHLStHDUjHVFPaS33J5TJ4bLiwleG5cxPX5TsfjBhUL3wlv1txkxtpIWGVLOWluRibCP8P65Rul9r0Wk6opYycRlpIqFAthKTZpuWySCbjTOzBjwkqLUpTr1+vi7K5vE+4ZlgoulNqXNDcARM2NV8x+kvF4YBOWkjw3NpWtHbOlLOrc8NchKHhurBuIRiRPnhwG42vc8MvJP7MfrYwbQYtmYRj0y4+f1/pEeGh4vzzb2k/6cyBm9twEfXFNELv+Vp4b3gvEPHF8R3S5arm+D0F4TVMCkR2kfCf/5Cc/wZ/+9CfT5/fddx+uv/76dIypTyBUKJbCUktf+wpPfrhDWF62e/ZaiIp5jUFM1bD3QBsee2+bsMyQUsO48Xs9uOqkkfjOkUNRURREMDGZaZr5Lc9JcCh7NsSwlDEe/kFuB1+YTO7TI4YNjG2wFGTLIn4OdW6un3EwXv/ZSZh5WIVuEFl6bmy6WYel4+GNKjYpJfPcOHmInJbnt8v0NMW5fv367msKCedS19zErDNjSjiNRlj23NhcLw+nueGzsOTGmbbZUh4WhrGvcyPWG/JyP3PGjdfauNGPkxVmlPYnd263y8Zzypbi/0ysPG68/gwAKvvl6WMNRY1U8CCXLcWHpZjnRk+zTyyzv1n23PCGkmJ44lx4bkJco1zS3BDZQsrGzb/+9S8cd9xxps+PPfZYPPPMM2kZVF+gzaqIX1TD2h31WPraZix8doOwvNy0b5+lcSNOEve+vsWknxnKeW58XgU/n3ko7rx4YlwcyoWLZP2Pk9ta/qwgyGt5+MnPncgWiNdeke0oK00ELya1qodj1RST/3nkgAIoiqG3MN7yHQwkU/aUktiv8Vk4Jupx7GDj4zVPTsgFA/ltlOT6UZrn18MXO+paTeuJ7RfMguLGtog+9mRhKa9H7MHFMgD1In7JNDc+475nOPWWss+WsuteLul3JM+NfB46EpbiDR5LzU2+aKAP75+v1zNqDkV144gPCwthKabNk67FfrlvlKRpYy8GB1xobvjCh9RbisgWUjZu9u/fj+LiYtPnRUVFqK2tTcugsh1V1fS0VUFzE1OxpbpZWPahN7fi6Y93murW1EnZEoAoBA5FVTzz8S4AwJkTBumfC54bmzCBvC3Avq9U/DNjvVy/V5ikrXpLJZvwAWBUeYGjcJmvasw+Nzw3xjomMbCN2914u/eYlrPT3DAsw1LMc5NksvBbhMHcLM+PgdUVGlySA0VR9Gu8fX+rvo5Qb8jC2LAKS7HQj9318ihilpJs3CTNlrIIxzplSwVtwlJ22VLM2PVJ3i5muMvNTe2MGyfPjRCWsjBuSrmClgAwvH+ernXjM5niIWLmweXCUuxaSAUSa+VsKa5Csd/n0T1xB1xkS4lhKTJuiOwgZeNm9OjRWLFihenz//3vfxg5cmRaBpXt8A+T3IDXEDqqqlDDprY5hCX/+xKLX/jcJChusOgVxXtbWsNR/eG++KxxAOIT2Ij+RpqxlcCTPdtk40bWQvDwz0PmAWBYZYa4mci/ffhA02TB/86HLeRJy0lQbCeYlJskutHcMNjkryiKXkhNz5ZKYsixCc2Nwcdvj5+E7p41Cfd97wiMLo/36GK6qu3745lmXo8iNH80qtFygmJOoyGngvNCVh6PIm6jXQpnMWOgY3VuEtfXznMjhaWczp9HMlyjkkeJfe61Eaw7ZUsJnhuLIfAh2qDPg/LCoN5DjDUqBazvY8AwGINJPTd8WrmiVwl3FZbiMrJIUExkCymngi9YsADz589HTU2N3gV85cqVuPPOO7F06dJ0jy8raePcwDk+ryGsjGpCFlRzorx6WyRm8tzUt1p4biweikC8HcJ7N05HTNWEku1W4SF/IjU5FFURjalYtakGx47u7+i54T01djoZXvDoNBG9OP94vLu1FpcfPxLb9rcI31kJiuOptYaGAXAWFNu9mcop4I69pWw8N0B8goxqmq5jSFrnJol3RCZgYdyMHVSEsYOMzDLmudmW8Nz4PB7Rc2NRN6iE02gMlFLBrzjhIPQrCGBTVRO27DM8i6xlAatgLKeC24V/GMxQW7fzAH72z0/xs9MPtsiWsr4OQak5q1ObCLkwo95+QQqT8oJnt+0X+D9Lq7AU77kZ1i8PiqIgP2Bo2xh+rgkq6+/FFyZkmht23GbNjSHY5ysUH2iLQNM0KIpiH5biMrLchEYJojeQsnHzgx/8AKFQCL///e/x29/+FgAwYsQIPPjgg5gzZ07aB5iNtHFvY/EMCOOhxveNYg8dTTNXF7UKS/HaBb5aq9+r6OX7d1roMHgCvrhxE4mpeOHTPVjwz08xblARbrtwAoDkb3aycWPdONN+G+OHFmN8ouGgyXNj8Tbt93r0dPNk7ResMr2M7yTPjaMo2f53j0cBVC2FOjfm/TlhhLHstzs0YdzsSBiHPq+158YqW0ruLQUAp46twKljK3DxstXCfhROfM17+uwrFFuLuzfubcTGvY3Y3xICG5FlA1MbQ8fnUYQwlYxcmJH9LckeJbm1BYP9yDfObGyPYMl/v8Qphwww1rEwDPjMweGJXmJ5QfGxy9pKsP2/t3U/xt/8Mv533Qm6kax7bhLHUGulueGqHTNjNaZqaA5FUZjjt62jxeo1OZ1DguhtdKiI349//GP8+Mc/Rk1NDXJzc1FQUJDucWU1bVwaOGA85COqiqpG46HFGyhGCfZ4DyCrsBQTggKGASW/jfFiXwXmh3HQ50ET4l6glV/uAwB8sbcR63Y2AEg+WcthKb5xpptUcB4nzQ2b9OIptKKg2GvjuXHaL1vMynPjlHEFiJMu23eq2VIph6UctjuoOAdAvNYNIFbfjaqani1k6blpjRh1bqQx2Qm8A5Jxo9e50Zw9N/Ix76hr1UNq7PgEYbeNoDiZ50b2yukNPSUNmF0dJT20yrlafvPiF3hmzS4hq9HKcC7M8cHrURBTNQzrFw8Jy2E+q/T+UFTF61/u08NLclPSeunvX0wrV5Dj9yKYeFE57a63cOrYctv2Eay7fY5N+JEgeiOdMtUHDBhAhk0HaOfSwAFOexDVBM9NiAstscljQKIqcX1r2FSLhvfusH3IE0oB1wE6YiEw1DOPoqqo63j1KwDJPTesvgbDCIeoguDRDfJkwU8+hw8uxlEjSjHrqEqToJg35qxaK1jBjBKrVHB5kncMSyX24TYsxQuj3WAVlpJhladZJ3ifx6MfF1/EjzeQ2HWLqppuODs1HQUMj4ZsaMmCYmZEyNdTPo9l+UFTtpQ7z43HNl09/r14Tdl42P3vs/CeJcuW+uCb/cI+7C6Hx6OgNGE4DuuXq2+bFZ7kj0W+ByIxzciW8ouaGxmrUgvMG1fV2I6/f7DDVnPTFiHPDZF9uPLcHHnkkVi5ciVKS0txxBFHOMZl165dm7bBZSttNsZNU3sELVxtknbubTicmCzLCoL4urYFoaiKtkhMaKHAvz23R8QHHcPv9WDWlErsbwnpReyE77maO7z+Z38iDJYsfGLy3HCNM9kbs9sS7+ZKyMbvuQEvnv7RsQCA97+OTzRW2VJCyrCDAcEmXqsQhd/nPCnzv7Mh65k6bsNSLj03Vm/5MrkWdX947ZNVUb0cv0dvY8H6IDml0QPGtTUZe3rtG1X4P1lPsv4FAdN9ZlehWCjil0RQLF9TZgTEYqIn0a6OklW21L5GMSzkZDiXF+agtjmMgwYYL4L5AR/aI/Fj5WsF8exvDunHzLQ2sgGS6/eiLRJDJGbORizJ82NfkzhOJ8hzQ2QTroybc889F8Fg3GNw3nnndeV4+gSsuFqOXwxL8YYNIIqC+bCU36sgEtNQ3xoRjRsLQbHVhH5rQj9jBZuYQlHVsgpyMs9NkY3mJqpqejl8tyEYef6208uwMVllS/Fvw06GmanOjZAKLhkzcp0bK89Nio0z0xmWyg2IkxTfrFFVrY1MRYkXfqtpCukTomvjRvrc0NzEf7fLlpK9Lf3yA/q+ra4DP7HLmhs3YSm/KVtKNLoEb41VWIrv+SRlE1qJiRm/Omss3v+6DsePLtM/ywt6wfTy7NpPqixBfsCrPwfqWsJ6403dcyOdswGFQeyoa417RiXPzd4G89+vE+S5IbIJV8bN4sWLAQCxWAynnHIKJkyYgJKSkrQN4v7778ftt9+OqqoqTJw4Effeey+mTp2adL2nnnoKs2fPxrnnnovnn38+bePpamTNzeCSXBTn+k3NLUOC58aYuEvz4pNAfUtYaKcQ4ZbXexulWE6dr57K0tLHlBdgcyJLJplxc8SwEuF3Lz+pppAKDjh7bqw+t2y/IBgeySdAK8+NvF9zKjg3ETLNjctUcMO4cXdO9ArFDtdB1nT4PIp+TqKqqntu5LGV5MaNG+agCHqdjRvdaLAx9vj+ZlZjlu+DHL83SYVi659da26kruBGhWKzcWOVLWXXOJNfxopjR5Xh2FFlwmf53EsJMyrKi3LwyaLT8dwnu/DLf21AbUsYQyPii5B8nGUFAeyoa014bkSDms/KdEOQPDdEFpHSzOf1enH66aejvr4+bQNYvnw5FixYgMWLF2Pt2rWYOHEiZs6ciX379jmut23bNtxwww044YQT0jaW7kLW3OT4vfju1Erb5QBjsmTGDWBOBxfrY7ivBszDJpOaxpBuLEwZUap/b2eYvDj/eNzz3Ummh7hXn1S53jcuvRTJuo/Ln4ctPTfiG77tvqQS/QMKgxhdXoBpI/ubwrB2YRjAeOM3jMtkmhuz3sMJN2EsObzAp4KrqllrwpALzpk1N7LnJv6/3fmQ2y/INZLk9eKZXOI1tKs3FJQ1Ny5SwY2u2wlBsSp6OpIV8QPiRrpqYeWkWh9GblrLCPg8enPbupaQUcTPplp0/4QGL2bhGb1r1iSMHGAOPdtBnhsim0j5bj788MPx9ddfp20Ad911F6688krMmzcP48aNw7Jly5CXl4dHH33Udp1YLIZLLrkEt9xyS68sHNgmvY0BwJxpI0zLCYJibuJmuhY5Y8JtWMoJ9vDcXhf3mZcVBDGyzNAK2Hk/xg8txrmThpg+5+uryL18kuEkKBb3YXib5OVkbYYdbHLycB6Dl68/Ef+48mjTssnq3PBjSdp+oaNhKYfJlBerAmIRP95zI1eoHlAk9kGSJ1L+eiiKIdw2ebZs2i+Ys6XE3yMxzqukC4qtNTesqSc7PtnLZDVudrysJo9c70cQFHP3ED/smKaZ0rDlZdyQz2UtyueZ9aPa3xzmBMVibykAyA94dSMpEjOHpc6ZOBiv/+xk9MsXjVY7SHNDZBMpGze/+93vcMMNN+A///kP9u7di8bGRuFfKoTDYaxZswYzZswwBuTxYMaMGVi9erXter/5zW9QXl6Oyy+/PNXh9wjksBQQryo7eXipsBwflgpxqd3sYdUgeW7CQp2bRLZOimEpZgyw0v0Di4Oo7Mf1o0rxKc7XVzHelNMbljK3X0jdc+OxmKjtipo5CYplzU26U8GNxpnJBcXGOopkZFqPrbzQ2bixCtVYLWduv2BX58bKc2PdD0reT9AvXtdUPDdAwpCSKxTz155bljfqYqqmp9jz2OnB7BA9N+K6rJ3G/pawqYgff5wleQFBD6QXJZQE8HYVpmXIc0NkEynXuTnjjDMAAOecc47w4GdVMGMx93He2tpaxGIxVFRUCJ9XVFTgyy+/tFznnXfewSOPPIJ169a52kcoFEIoZLxppWqAdQVGtpT4MPnr5VPx7pb9+OW/1qOuJWwblmK1L+RCfnxYqq2Dnhs2mbBifwOLcjG0NE//PlX3uzCpRlMTFJsErMk0N0nCUo6p4JLnxglTnRtuUjDaL7jTPFl1+XbCTdE/WVAstF/Q7Ht8lRfmSPuy19zY1RICuDo3STw38rmJquY0daFCsc3PXpfZUvwyUYtGrnaaG/5YVU3DHguhrlUBPyd4zY08dtayIRxVsb8l/uyyCkuV5vsFkXTExiMn3w92kOeGyCZSNm7eeOONrhiHK5qamnDppZfi4YcfRllZWfIVACxZsgS33HJLF48sNWTNDSMv4MNp4yqw6N+exHIWgmLFqJshF/Kz0tykLChOPGhZR+lBxTkY1t8wbuQskWSwt/UYVzzOrfdHDkPZTSBsUmJCWLH9Aj9hJQ9duBmbG8+N0e05iefGZ554nRhYnJv4P8d2mRyfveYmGrPvzp6K54a/FGbBdXz/Md1zYzY649sXf49y3hSr3lK8cDk34OXSpJNpbsyhvGhMNYVJ3WhuYqqGvQfS4LkJGtdIHntewKeneO9OGFJy40wgrpFiHqZoTNONe/leynNp3JDnhsgmUjZuDjroIFRWVprc9ZqmYefOnSltq6ysDF6vF9XV1cLn1dXVGDhwoGn5rVu3Ytu2bTj77LP1z1Q2Yfp82LRpE0aNGiWss3DhQixYsED/vbGxEZWVZvFud8LCUjk2Dx321mrlufF5jbCULCgW69y4KyInI1dAHVicg6IcI727yuLB7gR7zvIaB7eaG5Og2OZYZK+HUOfGreZGYf+nbtxYVSg29pnEc2OhLXHi1EPL8eSVx+DwIUW2y3g8il6dNj4GRSjip1eKlsZWUSR5bhxSwe1aXACGwZbMcyOfR8FzY+Ft4XU1OX4vHvr+5PjnPq+jcSPXMALimVJyKri95obz3KiwDkulqrnhPDdWAvt++QHsbmjDnsS+cpghxy1bkhcQOqsbRTI7FpaStVoE0ZvpkHGzd+9elJeXC5/X1dXhoIMOSiksFQgEMHnyZKxcuVKvn6OqKlauXIn58+eblj/00EOxYcMG4bNf/epXaGpqwj333GNptASDQb1GT09BLuInw940WW8pQBTLuglLuU1FlpEnnIHShFfd6L4oGGB4bqzCAMmQJ4xknhur5YQifi7CUm7CbrLHQehfJU/gSbZnpHa7F1lPG9U/6XI5fq8QyhSL+FkXUyyXBMVBrzm8pY/DokN7/HPjWMyaG+ewFK/LssyWkgyYUw41nkFuKhQriqLXiIq3KxAbfQrHZNNnKh6WMhs3qYal8hzCUkA8xXt3Q5teHqIw8YIhem784t+X1LjU2Jdbzw2FpYjsIWXjhmlrZJqbm5GTY+8qt2PBggWYO3cupkyZgqlTp2Lp0qVoaWnBvHnzAABz5szBkCFDsGTJEuTk5ODwww8X1mf1duTPezLJjBtZlAqIqcV2Yamwi/YLyZAnkEEO4Q83sDkipqXeW0pRFHgUI8RjKyiW7kfewHCruWETmxvjxqnXVKqeGyaMTXdIINfv1SdGH2/cxDTjfJo0N8nCUpwRxx2mfI710FzK2VK85yahMbERFMu4qXPDthuJxRCNGc1N2TVI1jgTiN/HVpqbVMNS+Q5hKQCmDKdJlSWmZUvyAnqiQTSmOoSl3D3myXNDZBOujRsW2lEUBb/+9a+Rl2foMGKxGD744ANMmjQp5QHMmjULNTU1WLRoEaqqqjBp0iSsWLFCFxnv2LEDnhR1Iz2dkJQBIcMmgXaLIn4eTlBsDktxrRv0sFTHsqUYgxJFAvMCXr2ycip4WWn5mHVPo6TrexSoNr2JjGWk8IlNJo9z48zOGDf2nptkx3rG4YOwZnu9ZZ2jzsCLSH1ej6nnldXY5I7uplRwm8aSYqFEsUknYLQ58ErnTdZvxVSz5sZOUCzj9J1X9shE4l5Odi6sPDf8OoqiQFHimq5ITMU3tS2mfTgV8bMimeeG1a8B4pmUTGPFH2dpnh81Taxmj9EV3Ko4ohvIc0NkE66Nm08++QRA3HOzYcMGBALGm0UgEMDEiRNxww03dGgQ8+fPtwxDAcCqVasc13388cc7tM9Mwt6w7N42nTQ3XoXT3JjCUrznJrVqwAz+bbqyXy5GJMTEV5wwEn9auRlHH9Qvpe0J3ahjqQmKATZpJCY8uzo30jHaeW7c1LnpiKA4KEzu0rJJDPNh/fPw8JwpSfeZKvyExntueJG6PDZFUfT+UoBFGIlPj+ZF25JWRW5XYOe5qeSy8NhyRr+n5GEpHrliMd8qgddq6U1qY5r+wsDWFftJmQ3mqKbhiz2NaE500Ra+T7Pnpj/nueFLRPBVhEvzAro2LhozN85kuA1LkeeGyCZcGzcsS2revHm45557UFRkL2gknLF7CDHYg7Xdoiu416vob9gt4RhiqmbqrQQYep2Otl8AgLMnDNZDkD+ZPhqHDy7C1BSNG17IGk2xtxQQn+SYysdOUGzX8wiQxL4uwlJuwgtOXcLlN/hUjct0wZcZ4ENFTp4bAHp/KSvsei/JnivduNGcs6WK8/x4+xenYOXGatz84hfxTC7Jc9ORsJRPMm54o8rH/a0Y1X+9pvFZGsyqhg++qQMATBxajE93HTC+T/Ey5wmCYvPKLB0cECuE8+ejJM8vvTyQ5oYgGCmb6o899hiKioqwZcsWvPzyy2hri4vrNK5jLuGM3ANGxq9PRGbNjVcRC5bxBg3/M7scqWZL8W/250warP/s83pw+mED9ZCYWwQhq03Zfyc8klfACtkjwD/b+cwRN4JiN54befyCoNjUqiEzxg3vufF7PYZInbu+VsdaIoWmeOyq9volw4L33GiaZuu5AYDKfnkoT4jW+SJ+Vm0pHI0b7qLLxrNVTZ6oavbc2Amm+W18kOhAf4wk6k41LJVv036Bwf+d8Z4bWXNj9MsyVyhmuK9zQ54bIntI+W6uq6vDqaeeioMPPhhnnHEG9u7dCwC4/PLL8bOf/SztA8xGkhWzMwTF5vYLPo8iPMhFA8hcgybVbCm+tPyhAzvvnWMP3xiXnZKKN8ku/dhuGcDJc5Ncc+OuiJ+95yZZRlB3wYvV454b8Xufx7r6MmvtYYVtET/pGvEGiarZZ0vxYwESrSFM2VIuNTcOKf9WHpmo4LlhYSl7Q5htg3lrpo3sb/m9W/Ic2i8A4sviIRWFlsuWcp4bp8rT5Lkh+iIpP3mvv/56+P1+7NixQxAVz5o1CytWrEjr4LIVu6wGhqG5sRYU894AO88NI1kqssy100fj0IGFadOBMEMjwrWGSMWb4bURsfLYTUSA6FVw2q/cONMJeTvO2VIZ8twEZM2NvUHG4+SZE4v4WYel+GrIADNYnI1avaEln8mVYraU2GZDyvKy6PAe19zEhO06GdJy0cIpI8TwbLo9N986fBAOHViI+aeMtn1BKckL6McacQhL5XIhsFR6khFEbyblVPBXXnkFL7/8MoYOHSp8PmbMGGzfvj1tA8tmkoWl2EQUsqhzw964Wb0O0bgxhwZTnVxHlxdixfUnprSOE+xhyh9LKm+5HocJx/hcCkPwoYwU2y+4qVfCn/+A1yNM9PL8nWq2WrrgPTd8ET/+MyucwlJ214KffL2K6LkR+0VZb9fqfk/WFVwmKIXGhHFbhqXMnhu79gvyd4cNKUZB0CeUKUjVQZfMc1Oc67f8O2zjMhaLcnySZ9QmLMXdC0GfB1GbrEfy3BDZRMpP3paWFsFjw6irq+txxfJ6KlGbNywG87bYeW74ddnn/CTC4xSK6Q48FseSyoTfEc+N1WRmtZzVON2eL6Phpf0kmGyfXUmOX/RkyGJsu2vAi1dl5GJ9DF4Q6/EowvmPqbxI2Pl+58OqRoVil5obh7CUEG7i2xU4aW6k68bXlJp37IjEtkSjLhV4z42T0SbDl2NQFMXw3AjZUvZhqaCURcefmyB5bogsIuW7+YQTTsBf/vIX/XdFUaCqKm677TaccsopaR1ctqI/hGwe1nraro3nhl+XbcsqJAVkTtDKsPLcpDLh2+k87JYxrcMJXB01Nwpb3t24mHHgVAsGECeT7sSkuXHZYf2iyZVY+O1D8ezVx5q+c5MtJU+YcaPbuQSAkaZu9tzYdQWXCQjhR9mTZw5ZWWVLOWluhidKIsyaUonzjhgS34+DMZSMXIeu4E6cMX4gSvL8OGP8QGGcMS4sJYex+H3l8OJ37m8DIM8NkV2kHJa67bbbcOqpp+Ljjz9GOBzGL37xC3z++eeoq6vDu+++2xVjzDrCSeq9sLdLvkIx88qwydOve240YZumbWXYc2NVXyW1sBT/s/P50rdvkbEUUzVnzY3HI/yfDMNzY2/cBH0e4Q29OzGFpTzyObE+To9HwVUnjbL8zrb9gk0qOMDaPSQRFLP73cJz43Nr3DiEH4XsOea54bKlWFjKKQR650UTsbWmGRdNNootxscWN8hS1dwEvPFmplFVQyAFo6IkL4AP/98M/Th83PGwFxxTKrjf3nOjAHqpBdLcENlEynfz4Ycfjq+++grHH388zj33XLS0tOCCCy7AJ598YmpaSViTrM6NVW8phlz/gxk1EYtMqfg+Muu5keur+L3WWTq269v0MLLaB6MoV7TZ2Xl2MqrOmjgI44cU45RDB7gaFwvFmL0Exj7KCoIpHWs6MQuK3WlunLBrLCkLqlnbDCDegkHV7FPB458nNDcWBjDvHXEK38jp6Dx2nhtzET9742bKiH6YddQwyWOV3Ktoh6IoerioI81t2X1ltNXgNDdS7zO+po5QcFIhzw2RvaTsuQGA4uJi3HTTTekeS59Bz2qwq1CceOBYlQ5i3wWksJSt56bHGDfWhdyS4UZQLE9mgxMtIxhsUnQKh51ySDlOOaTc9nsZNpnK7Sr4N3i+EFt3I3huPB6zcdMBLRBvJPBzuVwdmO0zHFOFho7JUvmZMe/1GAZwYY4fuX4vcvwe1+0XZIOTP1Z23eK9peL70z03Lgxpcbu8xyrp4ibygz40tkcdPVLJ4Ov2RGyKZObaaG68XlEfRZ4bIpvokHHT3t6O9evXY9++fVBVcVI955xz0jKwbIZ5WZLVubGCTfbsbY9ti0+15sl4WEoR9RTJ2hHYrQ/Yu/7lUJLJuNEFo+k7F4bgVfbcGD/3z8+ccWPXfoHRkSwufhW5GaX8udejADHrwnwy7HNmzPPbzg148c+rpiHg8zjqWoTu707tOJinQ7Xw3AiNM5OfH7t2FG5hnptUBMUyVp4bcyq4tebGq4hp++S5IbKJlI2bFStWYM6cOaitrTV9pygKYrHUmyv2FdrCMeQGvFydG7uHvf3DTvbchJN4bjIdlmITgNGJOrXxOKXnGssYPwd8HpNRYZfZ1Bn0bUohAH68fPPD7iZXekOXz11HPHr8hO+xC0vxxg0S2VIx52wpU10aaazjhxYnHRur/xSJaeZjtciWivBdwV0Iiq1wW2bADtZGhU8LTxV27h2L+NlobryS0UueGyKbSPluvvbaa3HRRRdh7969UFVV+EeGjT33v7EF429+GWu21+luers3NseUZZOgWBX+N20rQ3VWGPKElup4+EnUTVfwwcU5Jp0LmwA6MgHZwYxL+Rr2lLCU0H7B4zH3vOqAF0tIBbfJlpKNmyjvuXEZVuzodTLCj/Y6KHb/RS00N27uNZ7Oem5uOP0QXH78QThmZL+U12Wwez8ccxmWkkKIpLkhspWUXxmqq6uxYMECVFRUdMV4spa12+sRVTV8uvMA56ZPPSzlk4Ss7IFmlwqeqTorDFPmUorjceO54T+XQ1IA9GyUdJ4Lu2wpQVCcn0HPTUB8Q5ePvSOhEH7C5zcnGDdSpedYCpobRkevk9/nAcIxxzo3fs7oMrdfsBclWyFobjow5GNHl+HY0WWpr8ih1wji0uitutZ7lLj3NMdvfV94lMx7eQkinaT8hLvwwguxatWqLhhKdsPCRi2hqP6ZbeNMh4cMe0MM6MZNsjo3mfbcSG/lKT5AhQnVxeRoadzonpv0nQt2jZzq3PQYQbE3rq0QWgh0VbYUmyw54yZZnRunujSpwP4m+GwtfkyA8UIRjqn636SuybI4Diesjru7Yftt44wb2XCNZ2bF32Nlzw07H0GfN2OZfQTRFaTsubnvvvtw0UUX4e2338b48ePh94vl2n/yk5+kbXDZBHtLbA7zxo2d58ZJc5MIhzDNTbR3ZEsxUhcU8z+78NwU55i+Z+c5nedCL+LnGJbKnOdGrlAMxM9fVHP2GjphV+fGKiyVCc+NbqQo8fGxFHSh11jiHuDbGOjtF1xUwxbGydf3yZBhwMbAGzdW93luwIvmUNRs3CSOk/Q2RLaRsnHz5JNP4pVXXkFOTg5WrVolWPuKopBxYwMzQprbkxs3Tg93tgp7SOuCYrs6N5nOluqkkNWdoNjZc6MbN+nU3NiGpYyfM5ktlStlSwHx88QMjVTDg4CUucYdp5Vxwyb7qKpymht393uHNTdcGwUPi8NI22djaAnFLNdLZQw+G2OvO2Fj4NsyWN3n7H4QwlJcnRvS2xDZRsrGzU033YRbbrkFN954IzwZnjh7E8z4YGEpWczH45gKbiEovubva/HWVzUA4vVH+Po4mfbcmDNX0i8o5rdprbkxT16dxU37hbKMem5EbQX/P9DBbCmbMIxVeMbIkuM8N3aNYmWNTAfvWWZweqSwlMfiuPnwMFvPjSHNY2XUdTfseHRxtNTIlcHSzslzQ/QVUjZuwuEwZs2aRYZNirCCYc0ho1KvHU7f+SStR3VTO17asFf/PtfvFd/iepjmJlXRovg2nXyZwSUOYak0TkCysJvRxHnm+mXScxMQNTeAtfYkFew8FVYNJI36K8mzpWTvYmc9N3HjxtpQYderJREetqr2C7jLluLv5VR7S6UL+WXB7u+L3Q8+ryEu5l+wyHNDZBspP+Hmzp2L5cuXd8VYshpZUOwULnLS3MiCYj7MBYjhiPh+epbmJtVJVTRurNdtixjnYFCx2XMzurwAADByQEFK+3YiYOO5qW8NG8t0ovJsZ5ErFAOSt6UjYSkb44bXHend1RVeUNxNmhvOA+NRrO8btm32dxi06RrvKltK0Nx0aMidxpQZZvP3pbd68BidxH3cz+S5IbKNlD03sVgMt912G15++WVMmDDBJCi+66670ja4bEIPSyXeGO06ggPOD1b2MGJvoE2ycRPwAi3c8j3Mc5Ny+wV+krLRNTRz+ol8i4Jov5h5CC6dNhxDLEJWHcUQFItjqm+NpG0fncEqLCUWs+uAoFioFm18zk+wvL4HAEKc0N1tnZuOVtXWPTdSZhh/qD7dc5NovcBN6qlqbjrTWypdyOfOTseX64//Xfi8Hr16NN/klDw3RLaRsnGzYcMGHHHEEQCAzz77TPiOUgntkQXFbkJPVrDnPnuQN7WLk2me1IU605qb9IalrNedMbYchw8pwnGjrGuGeDxKWg0bwKhMLE8m9S1hq8W7Ha9HQcAb7+/EzrldVWG3+Gw1N2bPjVVne7vr5/EoeqhE3k8qyNlSxn6N8TGPFfPc2FUZdmNgib2lMqW5EcdZELQ2UopyjFRw3thl5zpInhsiy0jZuHnjjTe6YhxZj27csLCUixYL1t+JnpvGpGGpzD600ikotpsc8wI+/OfaE1IfXCcozPEL/zP4sFSmyfHHjRsrz03HeksZ6yg2YSldc5P4Pyx4bpxLHLBlO1uhWBYU88fNPFoNCQ9bUMoe0n92cXrECsUdGnKnkf++inL9lstddtwIeDwKzpwwCPes3Awgfp7Ic0NkKx1vakKkhKy5caoQ66S5YauxcIjsucnx9yzPjfxGm7rnxvrnTDNn2nAEvB7MPrpS+Lw0L4CqxvYMjUokN+BFY3tUNyo8KXomZLw2IULHsBRXf8VplyxUwm8jVfxcWErIsuN+Lkx4MPa3hACY9UIs29BNIUH+xSFj2VLSftnxyUwYWoI7LioR1vF5KVuKyF7oju4GVNXo+8Ji/U5Gh9N37KFrhKVEz40mNQfPdEn1znpu3AiKM8Gg4lz89LSDUV4oZmc9PGcKpo7oh2evPjZDIzNgXjx2P4mem04Kim3q3OhhqcQCoahLz00aqv0ycbBXUQTPEn/czNPWngiXyeEYn4WXy82YM1fnRhx/YdDac8PDrhF5bohshjw33YBV9eCOhqXYG7MelmoTPTd7DrRJ2+phguJU2y+4EBT3JMYPLcY/fzQt08MAAFxy9HC8trEaExJdta3qvaSC3WQesMg4YrcdX1zSyV6wKrSXKoagWNwXf8/Jng3rCtOaK2NFMOoyVqFYDkslf6TzBhxlSxHZChk33UCqxo3Tmyv7zi9lfTD2NEjGTaYFxWlsnNmDHDe9gitPHIkrTxyp/95ZA8Iu1CMYPTaeG59HcUw48KYhxGNX58ZrEZaS12H4PApCcPd305N6SzFkDZjTOlTnhshmaLroBqxaIzhpbtwYPnY1VA4dWOR6W91Bp+vcKJ1/oyfidDpbyiZzzaorOPue3fvJJn+/hW4nVcQ6N9bjlif/oPR3xIrd5biY7HtCbyn579tOc8PDGzekuSGyFfLcdANWxg1LJbbC2XMT/182jsYNKsLEyhLMO24ETr/7Lf3zdFbl7QisQzNL8011UvUIE2o6R9b3EIS/nWycyc/lVh4M3biJJTRmSe7DVGvMWMHKIMgtCPjtFSXx3Pz6rHH4prYFlf2Slw7gvZCZ+jOT91uUoudGTwUnzw2RZZBx0w1YGjcd1dywVHDJODp0YCGWXDAeUSkElmnPDSCm+aYsKLapV0KkjlWl3tTWtw71KErcAxBVNZNxw+rcJDNYxAKDHbMUzjtiCLbtb8VFUyrx8hdVltsze27ESf3cSUNc709oO5Eh60ZRFPi9ip6w4MZzY2S0eXDiwQPwxqYaHDu6f5eOkyC6GzJuugErzY1z5ohDWEpvvyA+lFm9js524e4KhDTfznhueoGguCfDn/qOGL1OXbD9Xg+iaswwbhLf65qbJPsTDYWOGbEjBxTgT7OPEPYvjzXH79ENMaBzLTKstEaZwOvhjRs3nhuj2OFZEwbjzPGDqAArkXXQq3A3YKm5cQhLOXpu9IaN4jIsZq4oYrfxnqBTSbXbsriu8XMPOJReDX8vdKgruMd+Mpebc7L71K3mJtW+Tsnw2Gi1FEURvBuy5iYVhBo5GbQN+Ho7brKl2LCZkUOGDZGN0HTRDYRSDEs5am5YKrj0ULbqJRTfT+YfXJ3pRk2C4vRhV5vGLWLjTPE7XcyrGGnGABCKdp/mhkfsLWWfUdQpz00P8Sryqe7uNDdMeN1lQyKIjEO3dzeQXs1NQgAorc9nd3S2QWK66Uw3ahIUpw/eOOxsET9zzzCxCrIclkrqubHpzt1RnNp28J6bzoWlMt9bChCva6qaG4LIVuju7gZSLuLnwqtj9txYTw6ZzpYC0ue5yVS6bbbQ2fYLQqNI6VrIVZDlVPBk96FdmnlHcTJueO9GZ7KE/DZFDTOJK82Nnq7f1aMhiMxBt3c3YF3npoOaG6mIH4MPS/EGRM/Ilup4JkxP0w/1ZjrbfoE//fJkzteYAYzr7NZz0xldlhX88Jz6L3VGc+NLQ+HBdNDO9e9Kpc4N/T0R2Qzd3d2AlXHjxjvj9J1c54b33LBlFCWzD12GKO7seFiKnsWdw05k6xZxMpe+kwTFbF+G5yZJtpTguen8hXYOS/GemzRlS2XQc9MaNvrLuXmZYePuKd4mgugKaLroBlghMx6nh5DTW7WeCi5lWwmeG/3NrGc8vMSu0SQozhSdrSXD305WqeCAvaA4Jc1NGkTw/K3SVZobfw/JllK15MvwsGvXE8pEEERXQbNFN5BqWMrpzdUuLMVrB3qa25k3UDpTobiHHE6vxa5lglv4MgOygNYkKJZ7SyW57l2puZGN/KI0haWEthM95EXCDT7Ju0YQ2QhNF91AV2RLyW+cVoLinvJmli5BMRXx6xzp0LUYYSfxc79JUBz/3G2dm/Rrbnij2D4slbYifr3o3jRefnrPmAkiVci46QYs69w4PFSdjBL2PHISFNt5dzJFuor49RRPVG+lM0amvp6U6s1I6rlJct3T3WGb34SzoLgT2VKenhGWShU77xtBZBM0W3QD6Sri5/Uo+hupk3HDvuspb2adCYdQWCp9pKO4IzNq5Kq2suaGXWa3mpvO9r2ScSsoloX5qeBLs0HWWdweC3luiL5Aj5gu7r//fowYMQI5OTk4+uij8eGHH9ou++yzz2LKlCkoKSlBfn4+Jk2ahL/+9a/dONrUsQ5L2T9Y7DwU/APUTbZUT/HcdEZP4XWYpIjU8HXCyGR4pawoxsCiHABARVEw8b3ouUml/UJ6sqWMn7tOUGwf+soEuQF3Xii5FhFBZCMZb5y5fPlyLFiwAMuWLcPRRx+NpUuXYubMmdi0aRPKy8tNy/fr1w833XQTDj30UAQCAfznP//BvHnzUF5ejpkzZ2bgCJKTehE/G88NN9HLD+WgRYXinqK58XTCY5Dusvx9mc5cB4YhRhU/v+mssThn0mBMG9lfWM4wbtyngqdbc+Nk3KSrzk1P0Nzk+t0ZN+xZ0RmvFUH0dDJ+d99111248sorMW/ePIwbNw7Lli1DXl4eHn30UcvlTz75ZJx//vkYO3YsRo0aheuuuw4TJkzAO++8080jd0+6BMWyB4RfzMpz01PczuLElWJYigTFaaMz14Fhp9coyvHjuNFlnOYm/r/rCsVdqrkRj7UrBMU94d7Mc+m5+f4xw3HBEUNw5oRBXTwigsgcGTVuwuEw1qxZgxkzZuifeTwezJgxA6tXr066vqZpWLlyJTZt2oQTTzzRcplQKITGxkbhX3eTaljK7uFul34LyL2lPKbvM4koZCXPTaYQ0qM7qblJ5qmQr1VK2VJp8Dg6NfksSpOgWOgK3gPuzYpEaDAZ44cW465ZkzC4JLeLR0QQmSOjs19tbS1isRgqKiqEzysqKlBVVWW73oEDB1BQUIBAIIAzzzwT9957L0477TTLZZcsWYLi4mL9X2VlZVqPwQ3WdW4civhxb5oBh1oa/FunVbZUTwlLpUNQ7FHMIlYiNdKquUlyLWRPTfLeUumtGePRhc2K6b5Jn+emZ2RL3f+9IzFxaDFuu3BC5gZBED2MjGtuOkJhYSHWrVuH5uZmrFy5EgsWLMDIkSNx8sknm5ZduHAhFixYoP/e2NjY7QaOlebGKRXX41GgKICmxTUBbH2TccNtg9cOGE0Me4rnpuMTl5ebpIjOkY5aMuyeSmZnyp6dVATF6dTcWO03x+9B0OdBKKoiP9hxz026Cw92lDMnDKIQE0FIZNS4KSsrg9frRXV1tfB5dXU1Bg4caLuex+PB6NGjAQCTJk3Cxo0bsWTJEkvjJhgMIhgMpnXcqZJqWAqIPzgjMQ1BvxdNoXjvGLvaIgGfR+r4zLKleoZB0JmGjcx+I+Om86Sjzg3bRPJ2Cql5bryC5iZ92VJW+1UUBYvPPgx7D7RhUHHHQzNi+wW6PwmiJ5HRV/tAIIDJkydj5cqV+meqqmLlypWYNm2a6+2oqopQKNQVQ0wLVnVukmUqsMmD98jYhaVyJNc6mxx6iuemMw0b9fACTR6dJh11btj1S11z43zd/V1U58buvvne0cPws9MP6dQ+emuFYoLoC2Q8LLVgwQLMnTsXU6ZMwdSpU7F06VK0tLRg3rx5AIA5c+ZgyJAhWLJkCYC4hmbKlCkYNWoUQqEQ/vvf/+Kvf/0rHnzwwUwehiMsrJQX8KI1HC9q5lShGIg/7NuhWmZB6cskHq45UgpoT0sF70zDRqqmmj7EsFR6s6VMyykpem7SHOLRPUxd+DfgF8KtXbYbgiA6QMaNm1mzZqGmpgaLFi1CVVUVJk2ahBUrVugi4x07dsDDPURaWlpw9dVXY9euXcjNzcWhhx6Kv/3tb5g1a1amDiEp4USV1sIcn2HcJPPceJnnxly/hsG2IRs3bN2emC2V6ph6Wlp7b6YzDUz1bdi0X7BbTv89hcaZ6dTcdOV9Q54bgui5ZNy4AYD58+dj/vz5lt+tWrVK+P13v/sdfve733XDqNIH09wUBH2oRjx85kZzAwBBznMjvy2zkBXv3eHX7SkGQWfeyj0kKE4bXq9xX3Q088yucaZMqpobn0NWYEdgm+hKo4M0NwTRc+kZr/ZZDgtL8SmoyTwYLGwQ8Hr0zBTXnpse3H7Bn2I4RPcUkHHTaZi3pTPhSr1CcZLr0alsqTSEkjzd4LlJd7NPgiDSR8+Y/bIc5rnhy74nDUtxuhmj5L2NcePr2ZobTycmLhIUpw/d6O2E0Nxjcy/KyJqe1DQ36ciWStw3Xfg3oCgKacIIoodCxk03YG3cuEul9Xk8tt4Lli0VlMNSelfwnnF5SVDcM0iH0Ws0XXReTv4+abYUN6b0aG4S++1io9iu1xZBEJmlZ8x+WY5u3AS5yqhJw1KGW50ZKeZsKeuwVE+rcyM0bEw5LBX/v6foh3ozhjew43/24wYVwetRMKa8MMm+UvXcdF2F4q6E/Q2SZ5EgehY9QlCc7RiaG/dhKWbQ+LyKg+fGOhW8p7Vf6Iznhk1S5LnpPMyA8HfiXN505lhce+oYFOf6HZeTjZnurlBsFPHr2vc3dj/T/UkQPQvy3HQDrIhfAW/cJKlzY6RAe7hQgGTc6Jobu2ypnnF5O1NfxW3qMZEc3QvWCc+NoihJDRvAPNl3f52b7jE63BY1JAiie+kZs1+WY2hujEkh2cOehZS8HsV2gmfeH1lzw7oDDyp21yW4q+HHnarnZuygIgwoDOKEMQPSPaw+h5fzBnY1Js+NS41ZfN3OP5a6o84NAAT0v9Mu3Q1BEClCYakuRtM0IywV7Fy2lDwp+fX2C2JY6tJpwzFuUBEmjyjt3ODThLcTYtGygiA+WHgquf3TALvlOpMt5X5fKda5SbPmprt6kpUX5WDPgXaUFWS2fx1BECJk3HQxkZgGTYv/zDQ3vDfGDl1z41F040B2fZflBwAAAwrFB2vQ58Wxo8s6PfZ04eXeojtSPI4Mm/Sga258XX8+5fs7lV5U6axz09XGzQOXHIndDW0Y3j+/S/dDEERqkHHTxTCvDWBobtxkMemp4F6PYOjwXH78SAzrn4+Zh1Wka7hdQk+ru9NXMYzM7vfcJPNUprsgntJNxs3gklwMLul4Z3GCILoGMm66mDDXEZxpbtxUDuZ7KtnVeinO8+PCyUPTNdQuo6d1Ke+rVBQFhf+7Et4QVxRg2qj+jsuLovN0ZkuRQU0QfREybroYZtz4PIoelsoLeJ1W0ZcH4g/9ntYrKlWMLJ3eOf5sYfLwUvzjiqNxyEDnGjXpgA9DnTdpCA6ucN5nujU31JOMIPo2ZNx0Mcy4Cfg8GFmWj+tnjElaAA3g9BFej63nprdAnpuegaIo3abF4g3462eMSbp8urOl2J8KGTcE0Tch46aLCcdiAOLGjaIouH7Gwa7W41PBdS9OL62loWfpkOemzzByQAFu/PahGNE/z5XYlvdKplNz01u9nQRBdA4ybrqY9kjCc5NiIQyjyaEi6G96I91ZX4XoOfzopFGul02/5obCUgTRl6E4QRfTEooCEKsTu8HQ3BjZUr01LKX3uqKwFGEDL7JPRydvCksRRN+GZpsupqk9btzw1YndoHf29vZ+z43HQ2/RhDNp99xwLwcEQfQ96C+/i2kKRQAARSl6bs6cMAiHDS7CKYeU9/rmfEadG7rdCGvSr7kxb5cgiL4DaW66GMNzk9qpPuWQcpxySDkA9HrPja4fIs0NYQNv+KYnW8q6qjdBEH0DepXuYnTjJphaWIqHGTW99UHtpcwVIgn8vZGO24SK+BFE34aMmy6msT0elkpVUMzT2z03fCsJgrAikGgCG/B6OtR/TEbPliJvIUH0SSgs1cV0NCzFw9z0vVWQy+qcHETNBQkbyguDmDttOMqLctKyveJcv/A/QRB9CzJuupiOZkvx9PYKxZMqS/D2L07BwOL0TFxE9qEoCm459/C0be/ioyoR9Hnw7fGD0rZNgiB6D2TcdDFNibBU5zw3vTssBQCV/fIyPQSiD1GU48el00ZkehgEQWQIEkF0Mc0Jz02qqeA83l4uKCYIgiCI7oSMmy4mHWEp1oQw10U3cYIgCILo61BYqotJR1hq7rEj4PV4cP4RQ9I1LIIgCILIWsi46WKY56Yg2PFTPXJAARadPS5dQyIIgiCIrIbCUl2IqmpoDnc+LEUQBEEQhHvIuOlCmsNRaFr8586EpQiCIAiCcA8ZN10IC0kFvB7k+EkMTBAEQRDdARk3XUg6xMQEQRAEQaQGGTddSDpaLxAEQRAEkRpk3HQhzWmocUMQBEEQRGqQcdOF6B3BO5EGThAEQRBEapBx04VQWIogCIIguh8ybrqQdLReIAiCIAgiNci46UIoW4ogCIIguh8ybrqQpjR0BCcIgiAIIjXIuOlCDM8NhaUIgiAIorsg46YLaSRBMUEQBEF0O2TcdCH7m0MAgP4FwQyPhCAIgiD6Dj3CuLn//vsxYsQI5OTk4Oijj8aHH35ou+zDDz+ME044AaWlpSgtLcWMGTMcl88kNU1x46asIJDhkRAEQRBE3yHjxs3y5cuxYMECLF68GGvXrsXEiRMxc+ZM7Nu3z3L5VatWYfbs2XjjjTewevVqVFZW4vTTT8fu3bu7eeTOaJqG2uYwAGBAIXluCIIgCKK7UDRN0zI5gKOPPhpHHXUU7rvvPgCAqqqorKzEtddeixtvvDHp+rFYDKWlpbjvvvswZ86cpMs3NjaiuLgYBw4cQFFRUafHb8eBtggm3vIKAODL336LuoITBEEQRCdIZf7OqOcmHA5jzZo1mDFjhv6Zx+PBjBkzsHr1alfbaG1tRSQSQb9+/Sy/D4VCaGxsFP51BywkVRj0kWFDEARBEN1IRo2b2tpaxGIxVFRUCJ9XVFSgqqrK1TZ++ctfYvDgwYKBxLNkyRIUFxfr/yorKzs9bjfUJsTEFJIiCIIgiO4l45qbzvDHP/4RTz31FJ577jnk5ORYLrNw4UIcOHBA/7dz585uGRszbsooU4ogCIIgupWMFmApKyuD1+tFdXW18Hl1dTUGDhzouO4dd9yBP/7xj3jttdcwYcIE2+WCwSCCwe43MPRMqULKlCIIgiCI7iSjnptAIIDJkydj5cqV+meqqmLlypWYNm2a7Xq33XYbfvvb32LFihWYMmVKdww1ZfSwFHluCIIgCKJbyXjp3AULFmDu3LmYMmUKpk6diqVLl6KlpQXz5s0DAMyZMwdDhgzBkiVLAAC33norFi1ahH/84x8YMWKErs0pKChAQUFBxo5DprYpngZOYSmCIAiC6F4ybtzMmjULNTU1WLRoEaqqqjBp0iSsWLFCFxnv2LEDHo/hYHrwwQcRDodx4YUXCttZvHgxbr755u4cuiO65oYExQRBEATRrWTcuAGA+fPnY/78+ZbfrVq1Svh927ZtXT+gNFBDYSmCIAiCyAi9OluqJ1PbRJ4bgiAIgsgEZNx0AXzrBeorRRAEQRDdCxk3XUBjWxThmAqABMUEQRAE0d2QcdMFML1NYQ61XiAIgiCI7oaMmy7gQFs8JFWaRyEpgiAIguhuyLjpAppDMQBAfrBHJKMRBEEQRJ+CjJsuoDUUBQAUBCkkRRAEQRDdDRk3XUBzwrjJC5DnhiAIgiC6GzJuuoDWcDwsVUBhKYIgCILodsi46QIMzw2FpQiCIAiiuyHjpgtoDceNGxIUEwRBEET3Q8ZNF9ASorAUQRAEQWQKMm66AD0sRdlSBEEQBNHtkHHTBbCwFHluCIIgCKL7IeOmC2BF/CgVnCAIgiC6HzJuugAq4kcQBEEQmYOMmy6AivgRBEEQROYg46YLYEX8KBWcIAiCILofMm66gJYQCYoJgiAIIlOQcdMFUIVigiAIgsgcZNykmWhMRSiqAiDPDUEQBEFkAjJu0kxLQm8DUBE/giAIgsgEZNykGVbAz+9VEPSRcUMQBEEQ3Q0ZN2mmhdLACYIgCCKj0AycZqhpJkEQRGbRNA3RaBSxWCz5wkSPwu/3w+vtfNSDZuA0wzw3+aS3IQiC6HbC4TD27t2L1tbWTA+F6ACKomDo0KEoKCjo1HbIuEkzVJ2YIAgiM6iqim+++QZerxeDBw9GIBCAoiiZHhbhEk3TUFNTg127dmHMmDGd8uDQDJxmWHViCksRBEF0L+FwGKqqorKyEnl5eZkeDtEBBgwYgG3btiESiXTKuCFBcZqhAn4EQRCZxeOhqa23ki5PG90BaYalgpPnhiAIgiAyAxk3aaY5kS1FBfwIgiAIIjOQcZNmWvVsKfLcEARBEEQmIOMmzbSwsBRlSxEEQRC9mEgkkukhdBgybtKMEZYi44YgCIJwz4oVK3D88cejpKQE/fv3x1lnnYWtW7fq3+/atQuzZ89Gv379kJ+fjylTpuCDDz7Qv3/xxRdx1FFHIScnB2VlZTj//PP17xRFwfPPPy/sr6SkBI8//jgAYNu2bVAUBcuXL8dJJ52EnJwc/P3vf8f+/fsxe/ZsDBkyBHl5eRg/fjyefPJJYTuqquK2227D6NGjEQwGMWzYMPz+978HAEyfPh3z588Xlq+pqUEgEMDKlSvTcdosoRk4zTS2xS3dAtLcEARBZBxN09AWyUyl4ly/N6Xsn5aWFixYsAATJkxAc3MzFi1ahPPPPx/r1q1Da2srTjrpJAwZMgQvvPACBg4ciLVr10JVVQDASy+9hPPPPx833XQT/vKXvyAcDuO///1vymO+8cYbceedd+KII45ATk4O2tvbMXnyZPzyl79EUVERXnrpJVx66aUYNWoUpk6dCgBYuHAhHn74Ydx99904/vjjsXfvXnz55ZcAgCuuuALz58/HnXfeiWAwCAD429/+hiFDhmD69Okpj88tZNykkXBUxdrt9QCAgysKMzwagiAIoi0Sw7hFL2dk31/8ZmZKBV2/853vCL8/+uijGDBgAL744gu89957qKmpwUcffYR+/foBAEaPHq0v+/vf/x7f/e53ccstt+ifTZw4MeUxX3/99bjggguEz2644Qb952uvvRYvv/wy/vnPf2Lq1KloamrCPffcg/vuuw9z584FAIwaNQrHH388AOCCCy7A/Pnz8e9//xsXX3wxAODxxx/HZZdd1qUFFikslUY+3laHplAU/fMDmDi0JNPDIQiCIHoRmzdvxuzZszFy5EgUFRVhxIgRAIAdO3Zg3bp1OOKII3TDRmbdunU49dRTOz2GKVOmCL/HYjH89re/xfjx49GvXz8UFBTg5Zdfxo4dOwAAGzduRCgUst13Tk4OLr30Ujz66KMAgLVr1+Kzzz7DZZdd1umxOkGemzTy+pf7AAAnH1IOj4dKfhMEQWSaXL8XX/xmZsb2nQpnn302hg8fjocffhiDBw+Gqqo4/PDDEQ6HkZub67yvJN8rigJN04TPrATD+fn5wu+333477rnnHixduhTjx49Hfn4+rr/+eoTDYVf7BeKhqUmTJmHXrl147LHHMH36dAwfPjzpep2BPDdp5PVNcePm1LHlGR4JQRAEAcQn9byALyP/Ugm77N+/H5s2bcKvfvUrnHrqqRg7dizq6+v17ydMmIB169ahrq7Ocv0JEyY4CnQHDBiAvXv36r9v3rzZVXPRd999F+eeey6+//3vY+LEiRg5ciS++uor/fsxY8YgNzfXcd/jx4/HlClT8PDDD+Mf//gHfvCDHyTdb2ch4yZNbKttwdc1LfB5FJwwpizTwyEIgiB6EaWlpejfvz/+/Oc/Y8uWLXj99dexYMEC/fvZs2dj4MCBOO+88/Duu+/i66+/xr/+9S+sXr0aALB48WI8+eSTWLx4MTZu3IgNGzbg1ltv1defPn067rvvPnzyySf4+OOP8aMf/Qh+vz/puMaMGYNXX30V7733HjZu3IirrroK1dXV+vc5OTn45S9/iV/84hf4y1/+gq1bt+L999/HI488ImzniiuuwB//+EdomiZkcXUVZNykiZ31rSgrCGLqQf1QmJP8hiEIgiAIhsfjwVNPPYU1a9bg8MMPx09/+lPcfvvt+veBQACvvPIKysvLccYZZ2D8+PH44x//qDeXPPnkk/H000/jhRdewKRJkzB9+nR8+OGH+vp33nknKisrccIJJ+B73/sebrjhBlfNRX/1q1/hyCOPxMyZM3HyySfrBhbPr3/9a/zsZz/DokWLMHbsWMyaNQv79u0Tlpk9ezZ8Ph9mz56NnJycTpwpdyiaHITrZu6//37cfvvtqKqqwsSJE3Hvvffq6WUyn3/+ORYtWoQ1a9Zg+/btuPvuu3H99dentL/GxkYUFxfjwIEDKCoqSsMRGKiqhvrWMPoXBNO6XYIgCCI57e3t+Oabb3DQQQd1ywRKuGfbtm0YNWoUPvroIxx55JG2yzldw1Tm74x6bpYvX44FCxZg8eLFWLt2LSZOnIiZM2eaLD5Ga2srRo4ciT/+8Y8YOHBgN482OR6PQoYNQRAEQSSIRCKoqqrCr371KxxzzDGOhk06yahxc9ddd+HKK6/EvHnzMG7cOCxbtgx5eXl6ypjMUUcdhdtvvx3f/e539WJABEEQBEH0TN59910MGjQIH330EZYtW9Zt+81YKng4HMaaNWuwcOFC/TOPx4MZM2boAql0EAqFEAqF9N8bGxvTtm2CIAiCIOw5+eSTTSno3UHGPDe1tbWIxWKoqKgQPq+oqEBVVVXa9rNkyRIUFxfr/yorK9O2bYIgCIIgeh5Zny21cOFCHDhwQP+3c+fOTA+JIAiCIIguJGNhqbKyMni9XiFfHgCqq6vTKhYOBoOkzyEIguhDZDgJmOgE6bp2GfPcBAIBTJ48WahqqKoqVq5ciWnTpmVqWARBEEQvhRWlc1N5l+iZsLYOrH5PR8lob6kFCxZg7ty5mDJlCqZOnYqlS5eipaUF8+bNAwDMmTMHQ4YMwZIlSwDED/qLL77Qf969ezfWrVuHgoICoTsqQRAE0ffwer0oKSnRy4nk5eV1aedpIr2oqoqamhrk5eXB5+uceZJR42bWrFmoqanBokWLUFVVhUmTJmHFihW6yHjHjh3weAzn0p49e3DEEUfov99xxx244447cNJJJ2HVqlXdPXyCIAiih8FkDXb10oiejcfjwbBhwzptlGa8QnF305UVigmCIIieQSwWs+x6TfRsAoGA4NTgSWX+zqjnhiAIgiC6Aq/X22ndBtF7yfpUcIIgCIIg+hZk3BAEQRAEkVWQcUMQBEEQRFbR5zQ3TD9NPaYIgiAIovfA5m03eVB9zrhpamoCAOoxRRAEQRC9kKamJhQXFzsu0+dSwVVVxZ49e1BYWJi24k6NjY2orKzEzp07Kb3cBXS+3EPnKjXofLmHzpV76FylRledL03T0NTUhMGDB9umizP6nOfG4/Fg6NChXbLtoqIiuvFTgM6Xe+hcpQadL/fQuXIPnavU6IrzlcxjwyBBMUEQBEEQWQUZNwRBEARBZBVk3KSBYDCIxYsXIxgMZnoovQI6X+6hc5UadL7cQ+fKPXSuUqMnnK8+JygmCIIgCCK7Ic8NQRAEQRBZBRk3BEEQBEFkFWTcEARBEASRVZBxQxAEQRBEVkHGTRq4//77MWLECOTk5ODoo4/Ghx9+mOkhZZybb74ZiqII/w499FD9+/b2dlxzzTXo378/CgoK8J3vfAfV1dUZHHH38dZbb+Hss8/G4MGDoSgKnn/+eeF7TdOwaNEiDBo0CLm5uZgxYwY2b94sLFNXV4dLLrkERUVFKCkpweWXX47m5uZuPIruI9n5uuyyy0z32re+9S1hmb5yvpYsWYKjjjoKhYWFKC8vx3nnnYdNmzYJy7j529uxYwfOPPNM5OXloby8HD//+c8RjUa781C6HDfn6uSTTzbdWz/60Y+EZfrCuQKABx98EBMmTNAL802bNg3/+9//9O972n1Fxk0nWb58ORYsWIDFixdj7dq1mDhxImbOnIl9+/ZlemgZ57DDDsPevXv1f++8847+3U9/+lO8+OKLePrpp/Hmm29iz549uOCCCzI42u6jpaUFEydOxP3332/5/W233YY//elPWLZsGT744APk5+dj5syZaG9v15e55JJL8Pnnn+PVV1/Ff/7zH7z11lv44f9v7/5D4q7/OIA/1XmnIe4mOk+3af7KNfzRdEyOcJKKU/pDtiKzKEvO1aaswJUz0FEQkwVBP2Ab/ZhF6VqRCVGRzd2B7hQ1L2eam8ctWXhZls7pPJ33+v7xZR++N93ml03vdvd8wIF+3u/73Pv99P2Rlx/fx+3Zs1pTWFW3ywsA8vPzndZaY2OjU7u35GU0GlFeXo6Ojg60tLRgfn4eeXl5mJ6eVvrc7tpbWFjAo48+irm5OZw9exaffPIJ6uvrUVtb64oprZjlZAUAZWVlTmvryJEjSpu3ZAUAGzduRF1dHXp6etDd3Y3s7GwUFhbi119/BeCG60rojmzfvl3Ky8uV7xcWFiQyMlIOHz7swlG53qFDhyQ1NXXJtomJCfH395cvv/xSOTY4OCgAxGQyrdII3QMAaWpqUr53OByi1WrlrbfeUo5NTEyIWq2WxsZGEREZGBgQANLV1aX0+f7778XHx0f++OOPVRu7K9yYl4hISUmJFBYW3vQ53pzX2NiYABCj0Sgiy7v2vvvuO/H19RWbzab0OXr0qAQHB4vdbl/dCayiG7MSEcnKypKXXnrpps/x1qyuW7dunXz44Yduua545+YOzM3NoaenB7m5ucoxX19f5ObmwmQyuXBk7uHChQuIjIxEbGwsnn76aYyMjAAAenp6MD8/75Tb5s2bERUV5fW5Wa1W2Gw2p2zWrl2LjIwMJRuTyQSNRoNt27YpfXJzc+Hr64vOzs5VH7M7MBgMWL9+PRITE7F3716Mj48rbd6c1+TkJAAgJCQEwPKuPZPJhOTkZISHhyt9du7cicuXLyt/pXuiG7O67vPPP0doaCiSkpJQXV2NmZkZpc1bs1pYWMDJkycxPT0NnU7nluvK6z448276+++/sbCw4PTDAoDw8HD89ttvLhqVe8jIyEB9fT0SExMxOjqK119/HZmZmejv74fNZoNKpYJGo3F6Tnh4OGw2m2sG7Cauz3+pNXW9zWazYf369U7ta9asQUhIiFfml5+fj927dyMmJgYWiwWvvfYaCgoKYDKZ4Ofn57V5ORwOvPzyy3j44YeRlJQEAMu69mw225Lr73qbJ1oqKwB46qmnEB0djcjISPT19aGqqgpDQ0P4+uuvAXhfVufOnYNOp8Ps7CyCgoLQ1NSELVu2wGw2u926YnFDK6KgoED5OiUlBRkZGYiOjsapU6cQGBjowpGRp3nyySeVr5OTk5GSkoK4uDgYDAbk5OS4cGSuVV5ejv7+fqe9brS0m2X1v/uykpOTERERgZycHFgsFsTFxa32MF0uMTERZrMZk5OT+Oqrr1BSUgKj0ejqYS2J/5a6A6GhofDz81u0I/zPP/+EVqt10ajck0ajwQMPPIDh4WFotVrMzc1hYmLCqQ9zgzL/W60prVa7aMP6tWvX8M8//3h9fgAQGxuL0NBQDA8PA/DOvCoqKvDtt9/izJkz2Lhxo3J8OdeeVqtdcv1db/M0N8tqKRkZGQDgtLa8KSuVSoX4+Hikp6fj8OHDSE1NxTvvvOOW64rFzR1QqVRIT0/H6dOnlWMOhwOnT5+GTqdz4cjcz5UrV2CxWBAREYH09HT4+/s75TY0NISRkRGvzy0mJgZardYpm8uXL6Ozs1PJRqfTYWJiAj09PUqf1tZWOBwO5ZevN7t06RLGx8cREREBwLvyEhFUVFSgqakJra2tiImJcWpfzrWn0+lw7tw5p4KwpaUFwcHB2LJly+pMZBXcLqulmM1mAHBaW96Q1c04HA7Y7Xb3XFd3fYuylzl58qSo1Wqpr6+XgYEB2bNnj2g0Gqcd4d6osrJSDAaDWK1WaW9vl9zcXAkNDZWxsTEREXnxxRclKipKWltbpbu7W3Q6neh0OhePenVMTU1Jb2+v9Pb2CgB5++23pbe3V37//XcREamrqxONRiPNzc3S19cnhYWFEhMTI1evXlXOkZ+fL1u3bpXOzk5pa2uThIQEKS4udtWUVtSt8pqampIDBw6IyWQSq9UqP/30k6SlpUlCQoLMzs4q5/CWvPbu3Str164Vg8Ego6OjymNmZkbpc7tr79q1a5KUlCR5eXliNpvlhx9+kLCwMKmurnbFlFbM7bIaHh6WN954Q7q7u8VqtUpzc7PExsbKjh07lHN4S1YiIgcPHhSj0ShWq1X6+vrk4MGD4uPjIz/++KOIuN+6YnFzF7z33nsSFRUlKpVKtm/fLh0dHa4ekssVFRVJRESEqFQq2bBhgxQVFcnw8LDSfvXqVdm3b5+sW7dO7rvvPtm1a5eMjo66cMSr58yZMwJg0aOkpERE/vt28JqaGgkPDxe1Wi05OTkyNDTkdI7x8XEpLi6WoKAgCQ4Olueff16mpqZcMJuVd6u8ZmZmJC8vT8LCwsTf31+io6OlrKxs0R8X3pLXUjkBkBMnTih9lnPtXbx4UQoKCiQwMFBCQ0OlsrJS5ufnV3k2K+t2WY2MjMiOHTskJCRE1Gq1xMfHyyuvvCKTk5NO5/GGrERESktLJTo6WlQqlYSFhUlOTo5S2Ii437ryERG5+/eDiIiIiFyDe26IiIjIo7C4ISIiIo/C4oaIiIg8CosbIiIi8igsboiIiMijsLghIiIij8LihoiIiDwKixsi8goGgwE+Pj6LPv+GiDwPixsiIiLyKCxuiIiIyKOwuCEit+JwOHDkyBHEx8dDrVYjKioKb775JrKzs1FRUeHU96+//oJKpVI+jdhut6OqqgqbNm2CWq1GfHw8Pvroo5u+VltbGzIzMxEYGIhNmzZh//79mJ6eXtH5EdHKY3FDRG6luroadXV1qKmpwcDAABoaGhAeHg69Xo+GhgbY7Xal72effYYNGzYgOzsbAPDss8+isbER7777LgYHB3H8+HEEBQUt+ToWiwX5+fl47LHH0NfXhy+++AJtbW2LCigiuvfwgzOJyG1MTU0hLCwM77//PvR6vVPb7OwsIiMjcezYMTzxxBMAgNTUVOzevRuHDh3C+fPnkZiYiJaWFuTm5i46t8FgwCOPPIJ///0XGo0Ger0efn5+OH78uNKnra0NWVlZmJ6eRkBAwMpOlohWDO/cEJHbGBwchN1uR05OzqK2gIAAPPPMM/j4448BAD///DP6+/vx3HPPAQDMZjP8/PyQlZW1rNf65ZdfUF9fj6CgIOWxc+dOOBwOWK3WuzYnIlp9a1w9ACKi6wIDA2/Zrtfr8dBDD+HSpUs4ceIEsrOzER0dvazn3ujKlSt44YUXsH///kVtUVFR/9e5iMi98M4NEbmNhIQEBAYGKhuEb5ScnIxt27bhgw8+QENDA0pLS53aHA4HjEbjsl4rLS0NAwMDiI+PX/RQqVR3ZT5E5BosbojIbQQEBKCqqgqvvvoqPv30U1gsFnR0dDi940mv16Ourg4igl27dinH77//fpSUlKC0tBTffPMNrFYrDAYDTp06teRrVVVV4ezZs6ioqIDZbMaFCxfQ3NzMDcVEHoDFDRG5lZqaGlRWVqK2thYPPvggioqKMDY2prQXFxdjzZo1KC4uXrTp9+jRo3j88cexb98+bN68GWVlZTd9a3dKSgqMRiPOnz+PzMxMbN26FbW1tYiMjFzR+RHRyuO7pYjonnLx4kXExcWhq6sLaWlprh4OEbkhFjdEdE+Yn5/H+Pg4Dhw4AKvVivb2dlcPiYjcFP8tRUT3hPb2dkRERKCrqwvHjh1z9XCIyI3xzg0RERF5FN65ISIiIo/C4oaIiIg8CosbIiIi8igsboiIiMijsLghIiIij8LihoiIiDwKixsiIiLyKCxuiIiIyKOwuCEiIiKP8h9WZ6LJK++c0gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.11043}, {'accuracy': 0.12016}, {'accuracy': 0.17864000000000002}, {'accuracy': 0.21013}, {'accuracy': 0.25953000000000004}, {'accuracy': 0.36352}, {'accuracy': 0.26511999999999997}, {'accuracy': 0.39122}, {'accuracy': 0.46606999999999993}, {'accuracy': 0.5371300000000001}, {'accuracy': 0.40926}, {'accuracy': 0.40263}, {'accuracy': 0.42552}, {'accuracy': 0.25515999999999994}, {'accuracy': 0.42166}, {'accuracy': 0.2385}, {'accuracy': 0.45156999999999997}, {'accuracy': 0.42546}, {'accuracy': 0.38745000000000007}, {'accuracy': 0.27121}, {'accuracy': 0.35361000000000004}, {'accuracy': 0.33549}, {'accuracy': 0.4526199999999999}, {'accuracy': 0.27523}, {'accuracy': 0.42313999999999996}, {'accuracy': 0.42865999999999993}, {'accuracy': 0.42183000000000004}, {'accuracy': 0.46546000000000004}, {'accuracy': 0.41307}, {'accuracy': 0.55414}, {'accuracy': 0.42845000000000005}, {'accuracy': 0.58244}, {'accuracy': 0.49261}, {'accuracy': 0.3826}, {'accuracy': 0.39086000000000004}, {'accuracy': 0.41733999999999993}, {'accuracy': 0.41154999999999997}, {'accuracy': 0.38930999999999993}, {'accuracy': 0.5727300000000001}, {'accuracy': 0.55518}, {'accuracy': 0.47222}, {'accuracy': 0.58326}, {'accuracy': 0.40815}, {'accuracy': 0.4418099999999999}, {'accuracy': 0.5237499999999999}, {'accuracy': 0.51646}, {'accuracy': 0.45048000000000005}, {'accuracy': 0.24691000000000005}, {'accuracy': 0.39943}, {'accuracy': 0.53456}, {'accuracy': 0.43851000000000007}, {'accuracy': 0.45127999999999996}, {'accuracy': 0.5241500000000001}, {'accuracy': 0.5385500000000001}, {'accuracy': 0.42134}, {'accuracy': 0.43712999999999996}, {'accuracy': 0.5193399999999999}, {'accuracy': 0.27582999999999996}, {'accuracy': 0.49349999999999994}, {'accuracy': 0.4657}, {'accuracy': 0.58077}, {'accuracy': 0.41500000000000004}, {'accuracy': 0.53508}, {'accuracy': 0.34831}, {'accuracy': 0.37308}, {'accuracy': 0.62449}, {'accuracy': 0.54042}, {'accuracy': 0.46875}, {'accuracy': 0.35161}, {'accuracy': 0.52451}, {'accuracy': 0.6132199999999999}, {'accuracy': 0.54262}, {'accuracy': 0.42957}, {'accuracy': 0.6115700000000001}, {'accuracy': 0.37315}, {'accuracy': 0.57979}, {'accuracy': 0.54948}, {'accuracy': 0.40708}, {'accuracy': 0.52777}, {'accuracy': 0.6148300000000001}, {'accuracy': 0.47714000000000006}, {'accuracy': 0.47015}, {'accuracy': 0.34518}, {'accuracy': 0.4601800000000001}, {'accuracy': 0.53632}, {'accuracy': 0.60009}, {'accuracy': 0.34279}, {'accuracy': 0.37612999999999996}, {'accuracy': 0.5230300000000001}, {'accuracy': 0.49670000000000003}, {'accuracy': 0.49376}, {'accuracy': 0.60875}, {'accuracy': 0.44076000000000004}, {'accuracy': 0.5198}, {'accuracy': 0.39238999999999996}, {'accuracy': 0.53013}, {'accuracy': 0.4353000000000001}, {'accuracy': 0.5871500000000001}, {'accuracy': 0.46978}, {'accuracy': 0.45068}, {'accuracy': 0.4429200000000001}, {'accuracy': 0.5288700000000001}, {'accuracy': 0.39892000000000005}, {'accuracy': 0.55843}, {'accuracy': 0.52317}, {'accuracy': 0.42340999999999995}, {'accuracy': 0.46624999999999994}, {'accuracy': 0.4394}, {'accuracy': 0.41590000000000005}, {'accuracy': 0.34082}, {'accuracy': 0.50979}, {'accuracy': 0.47536000000000006}, {'accuracy': 0.26758000000000004}, {'accuracy': 0.41151}, {'accuracy': 0.5882499999999999}, {'accuracy': 0.53176}, {'accuracy': 0.44816}, {'accuracy': 0.40667}, {'accuracy': 0.37756}, {'accuracy': 0.48242}, {'accuracy': 0.5288299999999999}, {'accuracy': 0.42096}, {'accuracy': 0.48091999999999996}, {'accuracy': 0.28132000000000007}, {'accuracy': 0.5717800000000001}, {'accuracy': 0.4908799999999999}, {'accuracy': 0.43818999999999997}, {'accuracy': 0.30755999999999994}, {'accuracy': 0.52593}, {'accuracy': 0.46507000000000004}, {'accuracy': 0.26324000000000003}, {'accuracy': 0.26869}, {'accuracy': 0.45481000000000005}, {'accuracy': 0.55634}, {'accuracy': 0.5332100000000001}, {'accuracy': 0.52312}, {'accuracy': 0.38954999999999995}, {'accuracy': 0.41795}, {'accuracy': 0.24777000000000005}, {'accuracy': 0.4250999999999999}, {'accuracy': 0.6132299999999999}, {'accuracy': 0.50733}, {'accuracy': 0.37029999999999996}, {'accuracy': 0.4768899999999999}, {'accuracy': 0.45958}, {'accuracy': 0.50014}, {'accuracy': 0.3986}, {'accuracy': 0.57659}, {'accuracy': 0.44169}, {'accuracy': 0.33348000000000005}, {'accuracy': 0.60268}, {'accuracy': 0.24639000000000003}, {'accuracy': 0.44551999999999997}, {'accuracy': 0.4528499999999999}, {'accuracy': 0.49208999999999997}, {'accuracy': 0.34608000000000005}, {'accuracy': 0.29739}, {'accuracy': 0.3960600000000001}, {'accuracy': 0.55081}, {'accuracy': 0.53806}, {'accuracy': 0.33551000000000003}, {'accuracy': 0.5338099999999999}, {'accuracy': 0.48073999999999995}, {'accuracy': 0.6329499999999999}, {'accuracy': 0.37572}, {'accuracy': 0.37905999999999995}, {'accuracy': 0.39131}, {'accuracy': 0.41600000000000004}, {'accuracy': 0.27328}, {'accuracy': 0.5488999999999999}, {'accuracy': 0.48369000000000006}, {'accuracy': 0.43933}, {'accuracy': 0.45829999999999993}, {'accuracy': 0.44772999999999996}, {'accuracy': 0.41172}, {'accuracy': 0.43287999999999993}, {'accuracy': 0.58633}, {'accuracy': 0.42755}, {'accuracy': 0.36596}, {'accuracy': 0.4809800000000001}, {'accuracy': 0.55456}, {'accuracy': 0.41078000000000003}, {'accuracy': 0.41679000000000005}, {'accuracy': 0.38257}, {'accuracy': 0.39508999999999994}, {'accuracy': 0.47973}, {'accuracy': 0.48057999999999995}, {'accuracy': 0.37658}, {'accuracy': 0.41551}, {'accuracy': 0.46432}, {'accuracy': 0.30085}, {'accuracy': 0.34881}, {'accuracy': 0.47607}, {'accuracy': 0.44880999999999993}, {'accuracy': 0.4072699999999999}, {'accuracy': 0.41464}, {'accuracy': 0.34684}, {'accuracy': 0.50397}, {'accuracy': 0.30496}, {'accuracy': 0.51467}, {'accuracy': 0.33299}, {'accuracy': 0.4194}, {'accuracy': 0.5936199999999999}, {'accuracy': 0.6067}, {'accuracy': 0.70548}, {'accuracy': 0.72913}, {'accuracy': 0.74129}, {'accuracy': 0.72628}, {'accuracy': 0.7124699999999999}, {'accuracy': 0.7200599999999999}, {'accuracy': 0.7115799999999999}, {'accuracy': 0.7306299999999999}, {'accuracy': 0.728}, {'accuracy': 0.7358800000000001}, {'accuracy': 0.71837}, {'accuracy': 0.71707}, {'accuracy': 0.71253}, {'accuracy': 0.72078}, {'accuracy': 0.71809}, {'accuracy': 0.71485}, {'accuracy': 0.73017}, {'accuracy': 0.72604}, {'accuracy': 0.70313}, {'accuracy': 0.72382}, {'accuracy': 0.7084900000000001}, {'accuracy': 0.73133}, {'accuracy': 0.72653}, {'accuracy': 0.72787}, {'accuracy': 0.7208199999999999}, {'accuracy': 0.7199300000000001}, {'accuracy': 0.7319599999999999}, {'accuracy': 0.7418499999999999}, {'accuracy': 0.7044400000000002}, {'accuracy': 0.7211299999999999}, {'accuracy': 0.7116}, {'accuracy': 0.7133399999999999}, {'accuracy': 0.7266}, {'accuracy': 0.7342000000000001}, {'accuracy': 0.73984}, {'accuracy': 0.71929}, {'accuracy': 0.7274799999999999}, {'accuracy': 0.72351}, {'accuracy': 0.7498099999999999}, {'accuracy': 0.7268399999999999}, {'accuracy': 0.7462899999999999}, {'accuracy': 0.7137100000000001}, {'accuracy': 0.7363700000000001}, {'accuracy': 0.7077500000000001}, {'accuracy': 0.71758}, {'accuracy': 0.7145999999999999}, {'accuracy': 0.71574}, {'accuracy': 0.72238}, {'accuracy': 0.7255}, {'accuracy': 0.7222}, {'accuracy': 0.73077}, {'accuracy': 0.72976}, {'accuracy': 0.7189399999999999}, {'accuracy': 0.72295}, {'accuracy': 0.73293}, {'accuracy': 0.7357500000000001}, {'accuracy': 0.73092}, {'accuracy': 0.7242200000000001}, {'accuracy': 0.72648}, {'accuracy': 0.7170799999999999}, {'accuracy': 0.7232}, {'accuracy': 0.71872}, {'accuracy': 0.72855}, {'accuracy': 0.7213200000000001}, {'accuracy': 0.7021200000000001}, {'accuracy': 0.7266299999999999}, {'accuracy': 0.7061}, {'accuracy': 0.7272999999999998}, {'accuracy': 0.70353}, {'accuracy': 0.72915}, {'accuracy': 0.73065}, {'accuracy': 0.70992}, {'accuracy': 0.72093}, {'accuracy': 0.7213499999999999}, {'accuracy': 0.7208700000000001}, {'accuracy': 0.7356}, {'accuracy': 0.7318999999999999}, {'accuracy': 0.71849}, {'accuracy': 0.7102700000000001}, {'accuracy': 0.7201700000000001}, {'accuracy': 0.7348899999999999}, {'accuracy': 0.70677}, {'accuracy': 0.71261}, {'accuracy': 0.73219}, {'accuracy': 0.7286499999999999}, {'accuracy': 0.71453}, {'accuracy': 0.71853}, {'accuracy': 0.7270800000000001}, {'accuracy': 0.7073699999999998}, {'accuracy': 0.73119}, {'accuracy': 0.7177499999999999}, {'accuracy': 0.7304400000000001}, {'accuracy': 0.72693}, {'accuracy': 0.71465}, {'accuracy': 0.72054}, {'accuracy': 0.74808}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecbbe105-9bf7-445c-98fa-8978922c9d1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ef2d273-250d-450a-a662-a7b72def491b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90e437aa-9da1-4ab9-9e45-ba89e95f207a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb4baa5-ba6c-4102-91e4-111c3b0b5fa2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b1dc97-431b-4a8f-ba04-61d4c3cc6abd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8986be3-03f4-4ebc-bfd3-794fbef7f9ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcd47ac2-d80f-4e13-9b76-d03483431081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc113a2c-dfd9-4dae-a973-ba5925b4f9bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6ac9abe-848f-49c2-9fc8-c94e75015695",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22f6eba1-7059-491f-bacd-0739425d9305",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d98f7ea7-9936-4a3b-8585-ecfc1913085e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "746d526e-8881-4cb2-b68d-452746c6d54d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da48ec35-c3a6-40d0-9270-3198f50624fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd1aaa-0b48-4c79-ab96-9e1ae83cc05b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b075f14c-fd7b-4ec5-b1fa-2a28849415e3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "daae2304-0047-45a4-a66b-9a6326ac7fb9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "445c866f-406f-4428-9c9d-82b831e82c0b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ba0a007-fd24-4f2e-9e71-ae75cec65504",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ec567b0-7b05-4051-b94a-bbe025291136",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dddac513-27c3-4111-9fe8-10392244a207",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
