{
 "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",
      "6049\n",
      "[[  0 592]\n",
      " [  1 587]\n",
      " [  2 641]\n",
      " [  3 645]\n",
      " [  4 578]\n",
      " [  5 644]\n",
      " [  6 570]\n",
      " [  7 586]\n",
      " [  8 593]\n",
      " [  9 590]]\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": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "18053\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 433]\n",
      " [  1 416]\n",
      " [  2 396]\n",
      " [  3 425]\n",
      " [  4 390]\n",
      " [  5 388]\n",
      " [  6 433]\n",
      " [  7 457]\n",
      " [  8 415]\n",
      " [  9 442]]\n",
      "[[   0 1152]\n",
      " [   1  431]\n",
      " [   2  405]\n",
      " [   3  444]\n",
      " [   4  432]\n",
      " [   5  441]\n",
      " [   6  535]\n",
      " [   7  613]\n",
      " [   8  666]\n",
      " [   9  889]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 9, 8,  ..., 0, 7, 7])"
      ]
     },
     "execution_count": 3,
     "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<5:\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(random.randint(0,9)))\n",
    "        \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",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \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": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([9, 9, 8,  ..., 0, 7, 7])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "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",
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAADJAUlEQVR4nOydd5wV5fX/PzO3bWOXsiy9CNhBEBDEXlCMXRMldrHERix8NdFYiJpINNFgYo0/W4pKNJqoMViwA4qIiIUmSoels31vmfn9ce8z88wzz8yduWXv7t3zfr14LffeKc/MnTvPmXM+5xxF13UdBEEQBEEQRYJa6AEQBEEQBEHkEjJuCIIgCIIoKsi4IQiCIAiiqCDjhiAIgiCIooKMG4IgCIIgigoybgiCIAiCKCrIuCEIgiAIoqgg44YgCIIgiKKCjBuCIAiCIIoKMm4Igsgr77//PhRFwfvvv2+8d/HFF2Pw4MEFG1Mx8etf/xqKohR6GATRriDjhiDaOd988w3OP/989OvXD5FIBH379sV5552Hb775ptBDyzuPPPIInnnmmbzu49tvv8Wvf/1rrF69Oq/7aUvuuece/Pvf/y70MAiiYJBxQxDtmJdffhmjR4/GnDlzMGXKFDzyyCO49NJL8d5772H06NF45ZVXCj3EvNJWxs2dd95Jxg1BFBHBQg+AIAg5q1atwgUXXIAhQ4bgww8/RM+ePY3PrrvuOhx++OG44IILsGTJEgwZMqTNxtXY2Ijy8vI2219HgM4JQbQvyHNDEO2U3//+92hqasJf/vIXi2EDANXV1Xj88cfR2NiI++67DwDw0ksvQVEUfPDBB7ZtPf7441AUBV9//bXx3rJly/CTn/wE3bt3R0lJCcaOHYtXX33Vst4zzzxjbPPqq69GTU0N+vfvDwBYs2YNrr76auy9994oLS1Fjx49cNZZZ+XMAzJ48GB88803+OCDD6AoChRFwVFHHWV8vmvXLlx//fUYMGAAIpEIhg0bhnvvvReaplm288ILL2DMmDHo0qULKisrMWLECDz44IPG8Z111lkAgKOPPtrYD68PErn44otRUVGBVatW4cQTT0SXLl1w3nnnAQA0TcPMmTOx//77o6SkBL169cIVV1yBnTt3WraxcOFCTJo0CdXV1SgtLcUee+yBSy65xPhcplMCgNWrV0NRFFdvlqIoaGxsxLPPPmscz8UXXwwAqK+vx/XXX4/BgwcjEomgpqYGxx13HBYtWuS4PYLoiJDnhiDaKa+99hoGDx6Mww8/XPr5EUccgcGDB+O///0vAOCkk05CRUUF/vnPf+LII4+0LDtr1izsv//+GD58OICkjufQQw9Fv379cPPNN6O8vBz//Oc/cfrpp+Nf//oXzjjjDMv6V199NXr27Ik77rgDjY2NAIDPPvsM8+bNw09/+lP0798fq1evxqOPPoqjjjoK3377LcrKyrI6/pkzZ+LnP/85KioqcOuttwIAevXqBQBoamrCkUceiQ0bNuCKK67AwIEDMW/ePNxyyy3YtGkTZs6cCQB4++23cc455+DYY4/FvffeCwBYunQp5s6di+uuuw5HHHEErr32WvzpT3/Cr371K+y7774AYPx1Ih6PY9KkSTjssMPwhz/8wTjWK664As888wymTJmCa6+9Fj/88AMeeughfPHFF5g7dy5CoRC2bNmC448/Hj179sTNN9+Mrl27YvXq1Xj55ZezOl+Mv/3tb7jsssswbtw4/OxnPwMADB06FABw5ZVX4qWXXsLUqVOx3377Yfv27fj444+xdOlSjB49Oif7J4h2gU4QRLtj165dOgD9tNNOc13u1FNP1QHodXV1uq7r+jnnnKPX1NTo8XjcWGbTpk26qqr6XXfdZbx37LHH6iNGjNBbWlqM9zRN0w855BB9zz33NN57+umndQD6YYcdZtmmrut6U1OTbTzz58/XAeh//etfjffee+89HYD+3nvvGe9ddNFF+qBBg1yPTdd1ff/999ePPPJI2/t33323Xl5erq9YscLy/s0336wHAgF97dq1uq7r+nXXXadXVlbaxs7z4osv2sbnxkUXXaQD0G+++WbL+x999JEOQP/HP/5heX/27NmW91955RUdgP7ZZ5857kN2znRd13/44QcdgP70008b702fPl0Xb+Xl5eX6RRddZNtuVVWVfs0113g4SoLo2FBYiiDaIfX19QCALl26uC7HPq+rqwMATJ48GVu2bLGEM1566SVomobJkycDAHbs2IF3330XZ599Nurr67Ft2zZs27YN27dvx6RJk7By5Ups2LDBsp/LL78cgUDA8l5paanx/1gshu3bt2PYsGHo2rVr3sMcL774Ig4//HB069bNGP+2bdswceJEJBIJfPjhhwCArl27orGxEW+//XbOx3DVVVfZxlRVVYXjjjvOMqYxY8agoqIC7733njEmAHj99dcRi8VyPi43unbtik8//RQbN25s0/0SRFtDxg1BtEOY0cKMHCdEI+iEE05AVVUVZs2aZSwza9YsjBo1CnvttRcA4LvvvoOu67j99tvRs2dPy7/p06cDALZs2WLZzx577GHbd3NzM+644w5D81JdXY2ePXti165d2L17d4ZH7o2VK1di9uzZtvFPnDjRMv6rr74ae+21F370ox+hf//+uOSSSzB79uys9x8MBg3tET+m3bt3o6amxjauhoYGY0xHHnkkfvzjH+POO+9EdXU1TjvtNDz99NNobW3NelzpuO+++/D1119jwIABGDduHH7961/j+++/z/t+CaKtIc0NQbRDqqqq0KdPHyxZssR1uSVLlqBfv36orKwEAEQiEZx++ul45ZVX8Mgjj6C2thZz587FPffcY6zDBLc33ngjJk2aJN3usGHDLK95Lw3j5z//OZ5++mlcf/31mDBhAqqqqqAoCn7605/aRL25RtM0HHfccfjFL34h/ZwZcjU1NVi8eDHefPNN/O9//8P//vc/PP3007jwwgvx7LPPZrz/SCQCVbU+G2qahpqaGvzjH/+QrsNE4Yqi4KWXXsInn3yC1157DW+++SYuueQS3H///fjkk09QUVHhWJQvkUhkPGYAOPvss3H44YfjlVdewVtvvYXf//73uPfee/Hyyy/jRz/6UVbbJoj2BBk3BNFOOfnkk/HEE0/g448/xmGHHWb7/KOPPsLq1atxxRVXWN6fPHkynn32WcyZMwdLly6FrutGSAqAkTYeCoUMT0cmvPTSS7joootw//33G++1tLRg165dGW9TxGmSHzp0KBoaGjyNPxwO45RTTsEpp5wCTdNw9dVX4/HHH8ftt9+OYcOG5ay679ChQ/HOO+/g0EMPlRqDIgcffDAOPvhg/Pa3v8Vzzz2H8847Dy+88AIuu+wydOvWDQBs53LNmjWexuJ2TH369MHVV1+Nq6++Glu2bMHo0aPx29/+lowboqigsBRBtFNuuukmlJaW4oorrsD27dstn+3YsQNXXnklysrKcNNNN1k+mzhxIrp3745Zs2Zh1qxZGDdunCWsVFNTg6OOOgqPP/44Nm3aZNvv1q1bPY0vEAhA13XLe3/+85+z9i7wlJeXS42ls88+G/Pnz8ebb75p+2zXrl2Ix+MAYDtvqqrigAMOAAAjDMTq02RrlJ199tlIJBK4++67bZ/F43Fj+zt37rSdt1GjRlnGNGjQIAQCAUM7xHjkkUc8jUV23hKJhC1cWFNTg759+7ZJSIwg2hLy3BBEO2XPPffEs88+i/POOw8jRozApZdeij322AOrV6/Gk08+iW3btuH555830nwZoVAIZ555Jl544QU0NjbiD3/4g23bDz/8MA477DCMGDECl19+OYYMGYLa2lrMnz8f69evx5dffpl2fCeffDL+9re/oaqqCvvttx/mz5+Pd955Bz169MjZORgzZgweffRR/OY3v8GwYcNQU1ODY445BjfddBNeffVVnHzyybj44osxZswYNDY24quvvsJLL72E1atXo7q6Gpdddhl27NiBY445Bv3798eaNWvw5z//GaNGjTLSvUeNGoVAIIB7770Xu3fvRiQSwTHHHIOamhpfYz3yyCNxxRVXYMaMGVi8eDGOP/54hEIhrFy5Ei+++CIefPBB/OQnP8Gzzz6LRx55BGeccQaGDh2K+vp6PPHEE6isrMSJJ54IIBmWPOuss/DnP/8ZiqJg6NCheP31121aKLfz9s477+CBBx5A3759sccee2DvvfdG//798ZOf/AQjR45ERUUF3nnnHXz22WcW7xtBFAWFTdYiCCIdS5Ys0c855xy9T58+eigU0nv37q2fc845+ldffeW4zttvv60D0BVF0detWyddZtWqVfqFF16o9+7dWw+FQnq/fv30k08+WX/ppZeMZVgquCxteefOnfqUKVP06upqvaKiQp80aZK+bNkyfdCgQZY05GxSwTdv3qyfdNJJepcuXXQAlrTw+vp6/ZZbbtGHDRumh8Nhvbq6Wj/kkEP0P/zhD3o0GtV1Xddfeukl/fjjj9dramr0cDisDxw4UL/iiiv0TZs2WfbzxBNP6EOGDNEDgUDatPCLLrpILy8vd/z8L3/5iz5mzBi9tLRU79Kliz5ixAj9F7/4hb5x40Zd13V90aJF+jnnnKMPHDhQj0Qiek1NjX7yySfrCxcutGxn69at+o9//GO9rKxM79atm37FFVfoX3/9tadU8GXLlulHHHGEXlpaqgPQL7roIr21tVW/6aab9JEjR+pdunTRy8vL9ZEjR+qPPPKI21dAEB0SRdcF/yhBEARBEEQHhjQ3BEEQBEEUFWTcEARBEARRVJBxQxAEQRBEUUHGDUEQBEEQRQUZNwRBEARBFBVk3BAEQRAEUVR0uiJ+mqZh48aN6NKlS87KrhMEQRAEkV90XUd9fT369u1r6+0m0umMm40bN2LAgAGFHgZBEARBEBmwbt069O/f33WZTmfcdOnSBUDy5LBOygRBEARBtG/q6uowYMAAYx53o9MZNywUVVlZScYNQRAEQXQwvEhKSFBMEARBEERRQcYNQRAEQRBFBRk3BEEQBEEUFWTcEARBEARRVJBxQxAEQRBEUUHGDUEQBEEQRQUZNwRBEARBFBVk3BAEQRAEUVSQcUMQBEEQRFFBxg1BEARBEEUFGTcEQRAEQRQVZNwQBEEQBFFUkHFDEARBFB0tsQR0XS/0MIgCQcYNQRAEkTNW1NbjV698hWn/XIxn560uyBhW1tbjgF+/hWueWwRNy8zA2dEYxZyltWQgdVDIuCEIgujEtMQSuODJT3HuE5/g8zU7jPdjCc11vfqWGJ76+Afc/fq3eOWL9QCAV75Yj1P+/DGe+3QtXl60AdNf/QZfb9jtup1vNu7Gkb9/D49/sCrtWJ/48Htc89witMQSts827W7GJc98hv8s3oA3v9mMaELDG19txhMffW8ss7Mxigue/BR/nrPS1ehpbI3jrMfm4dJnF+Ktb2uN95ujCcQdzoum6Vi7vQkJj8ZUSyyBOUtrHbf35bpdWLJ+l6dt8exujmHdjiY0tsZ9rff91gZc8beFePXLjcZ7HdmwCxZ6AARBEETheGruD/ho5TYAwLxH5+NP5xyIuuYYpr/6DX4xaW9cceRQ7G6K4bUlG1HTJYLj9+8NAHj8g+/x0HvfAQAUBThkaDVu/tdXaI1rOHzPajRFE/h8zU68vGgDhverMvb33Kdr8d2WBpx38EAM7VmBp+euxprtTZjxv2VobI3jhuP2gqIotnGu3d6EGf9bCk0Hjt+vF04b1c/4TNd13PLyV3h/+VYs31yPYTUVxmf3vbkc3cvDOGvsADw7fzU+WrkNH63chhVbGvDA2SMRCqjQdR3/WrQBW+pbUBIMYN6q7Vi1tREAMH/Vdkzavzfe+GoT/u+fX2J4v0o8f/nBCAZM34Cm6Zj6/CK88dVmdIkEcdEhg3HjpL1dz/tNLy3Ba19uxC0/2gdXHDkUAPDuslqUhoIYWlOOsx6fj1hCw+0n7Ycphw62nBNd17GrKYauZSHjfU3T8Ye3luOxD1ZB04Ee5WG8ecMRqK6I4PutDfjd/5bh0sP2wPghPQAAi9buxMZdzThpRB/Ut8Zx2bML8f22Rrz5TS3mr9qOrfWtWLxuJ0pCAbxy9aHo2SUiPY7V2xqxZkcTjtizWvq9FQoybgiCIDop2xta8eh7SY/JAf2rsGT9btz7v2VoisaR0HTM+N8yzFm6BV+u34XWuAZFAd66/gjs2asL5n+/3diOrgMfrNiK1riGikgQz04Zh/dXbMElzyzEq19uwK9O3AfBgIov1u7Er175CgDw9LwfcPtJ++HNbzYb2/nTu99h/a5m3HPGCJSEApax/uWj5KQNAG9/W2sxbl79ciPeX74VALBhVzNq61oAAOMGd8eC1Ttw00tL8N3WBryyaIOxzmtfbsTogV0x5dA98O6yLbjxxS+l5+iLdbvwn8UbcP2sxdB14LPVO/H3T9bgtFH9EAwoCKoq7p29DG98lTyO+tY4Hnn/O1x++BDUtcSg6ToG9Si3bPPLdbvwWspD8soXG3DFkUPx4sJ1uOmlJQgFFFw0YTCi8aRH567Xv0VTNI6px+wJXdfxu/8tw6yF67CrKYa9e3XB1GOG4ZSRfXHDPxfjP4uT21QVYHtjFI++vwq/OGFvXPPcF1i6qQ5fbdiNOf93JAKqgoufWoC6ljiWHl2HRWt24fttjSgNBdAcS+D5BWst431+wVpce+yeiCc0zFq4DocOrcbg6nK8820tfv78F2iOJXDvj0dg8kED5RdaASDjhiAIopPy1/lrUN8ax/B+lXjhZwfjiPvex4ZdzQBgTHQLVu+wvH7ove9w748PMEImfatKsHF3Cz5ckTQuBvUog6oqOHzPnqiuCGNbQxRTn/sCg6vLMW9V0kPUqzKC2rpW3PX6twCAmi4RXHP0MNz1+rd4edEGbK1vxSWH7oHf/PdbjOzfFROG9sA/F643xv3B8q2IxjVEExqe+ND0IEWCKlrjGuKajvJwAP+4fDweevc7PDhnJR7/IBmeqq6I4KqjhuLu17/Fw++twuSDBuClz5PbHtm/CgN7lCMaT2BEvyr84a0V+Hbjbtw3ezl0HRjRrwpfbdiN376xFL9+LTn2cFA1DJE/Th6JR95bhZVbGvD8Z2vx4Dsr0RxLYGD3MpSGAjh8z2rcdMLemPG/pcaxLNtcj398ugbT//MNACCW0PH/Pv4BADBuj+5Y8MMO/OGtFRjaswJxTcfjH5phtuW19fj5819gV1MU/1m8EUFVwe/POgDdysK4+OnP8LdP1qC2rgVLN9UBADbtbsEj763C2MHdUNeSDFs9nDJuS0Iq/nnFBHy2egcWr9uFA/pXoaE1jpnvrMTzC9bi6qOG4pl5q/Gb/y5FdUUYFxw8GA/OWWEYnL95fSlG9OuKwdVlKAsX3rQo/AgIgiCIgrAxZcj8aHgflIWDuPLIIfjNf5MT729OH46EpmNnUxSH79kTmq7j5D9/jNe+3IhDh1YjltDRs0sEh+/ZE7MWrsPH3yUNl0E9ygAAoYCKU0f2w1Nzf8BszjtTFg7g1amHYepzi/DZ6p0AgBNH9MFFhwzGsJoKXPbsQiN0BACrtjbi5S+SHpcDB3bFuh3N2NbQiqnPLcK8VdvRkNKWnDqyL0b0q8Jv30iOf/SgbggFVNxw3F4ojwRwzxvLAADnjhuACw4ehGfm/YB1O5rxwFsrMGfpFgDAvT85APv0rgSQDP08M28NtjW0YsOuZpSHA3jhZwfj3Cc+wZfrTR1RNK5hQPdS/PzoPXHGgf2xdFM9Vm5pwANvrUA0padZu6MJQNIYeX3JJmyua0E4oGJYTQW+3VSHW1/5GgAwvF8lvt6QNESCqoLHzh+DP81ZiWfmrca1L3yB8khyyr76qKG49LA98Mt/LcE7S7fgjleThtGZo/vhjAP7Q9d1w2v1+pJNAIBzxg3A8wvW4S8ffo8lG5KhqeqKCLY1tGJYTQX+fM6B2LdPJUb0N0OILbEEnp23Gpt2t+Ctb2vxZMro2tYQxR/fWQEAmDx2AJbX1mPxul048U8fIRRQcMLwPjhv/ECM36N7wUJVZNwQBEF0UthTd1BNTkDnjR+E/yzeiIpIEKeN6mvRlQDAsfvUYM6yLZiemkzHDe6OwdXJkMuuphgAWEIw1x47DKVhFUFVxYraesz9bht++aN90KuyBHeeOhwn//kjaDpw0gF9AACHDqvGI+ePxmXPLkRC0zFp/14IBwNYv7MJYwd1wxVHDsUf3lyOFz5bZwh9h1SX4/rj9sKpI/ti7fYmw7gZO6i7MY6fHTEUmg58tHIrLjpkMMJBFdcfuxf+78UvDS/Jfn0qDcMGABRFwYEDu+Lt1H4m7d8b5ZEgnrz4IMz9bhvG79EDkaCKbQ2tGNqzAmrqHB61V0/85cPvDcPmvp8cgH5dS7FmexPu+M/XScMmqOKBs0eioSWOm19OhumG96vES1cegtMfnotlm+tx1N490b08jNtO2hfbGlrx+pJN2NUUQ/9upbj22D1REgrgFyfsg3eWbgHT/V562BBj7Heetj9u//fX6F1VghNH9MGPhvfG+p3N+GjlNsPL9oezDkDfrqUY1KMMkaA1DAgAJaEAzj5oAB7/4HvcMGsxWuMaqisiKAmpWL+zGTcevxeuOXoYVm1txKXPfoZNu1sQjWt47cuNWLRmJz78xdEIFEiGQ8YNQRBEJ0VLzYqB1MRcGg7gtZ8f5rj8jZP2xvsrtqI5la00dnA39K4ssSwzOOW5AYCuZWHcNGkf6bb261uJP51zIDbvbsHYQd2M94/euwb/uGw81mxvxE/GDDDGxjj7oAH416L12KO6HDf/aB8cvXeN4R0Y2KMM+/TugmWb63HYnj0s61155FBcmRLuAkkvx/LaevwlFeY5c3Q/iIwe2M0wbk47MPl5dUXEovfpVh62rDN2cHeUhwNojCZQ0yWCMw7sh1BAxaHDgD5dS/Dcp2tx5ZFDMGZQd+xsjOK3byxFQFXw6HljUBIK4K7ThuPe2ctw/cS9AADBgIo/n3MgDt+zGi99vh43TdrH0CPt1asLfjS8N/739WYcvmc19u7dxRjHvn0q8dJVh1jGNv2U/XHCzA8R13RURIKYMLSH1Kjh+dnhQ/DB8q1YtrkeAHDJYYNx4YTB2FLXgiE9k8LtYTUV+OCmowEAX2/YjX98uhbDaips311bQsYNQRBEJ4WlLXsNHezbpxKXHraHYRAcNLg7VGFdUTzrxskH9JW+f/CQHjh4SA/pZ6MHdsOS6ZMQCaqGt4TniQvH4vttjRjDeW5kKIqCX524L0YP7Ir5q7bj3PF2Mey4PZJGV3VFBIcOlY9HJBxUccRePfG/rzfjp+MGIsR5v47euwZH711jvO5WHsZbNxyBUEBFdUUktc/u+JdglCiKgskHDZQKdu88dX/0qSrFxYcMTju2YTUVuPSwPfD4h9/juP16pTVsAKBHRQSvXH0ofv/mcmzc1YwLDh6EikgQFT0rpMsP71eFGWeOSLvdfEPGDUEQRCfF8Nz4eMC+fuKe+HjlNoQCCvbp3QUtcWudlsE+jJtMKQ07T8oDupdhQPcyx89FThjeBycM7yP9bMyg7vjj5JEY1rOLLUTnxq9P3R+HDqvGWWP7p122T1Wp5+3KqKkswR2n7Od5+Zsm7Y1RA5Iiba+UhgO+9tEeIOOG6HAs31yP95dvwcWHDvb05EEQhBwxLOWFsnAQ/732MMPbU5HyOmxraEVJSEWNQz2UjsoZB6Y3UER6VZbg/IMH5WE02RMMqPjRCLkxV0yQcUN0OCbN/BBAsnDYz44YmmZpgiCc8BuWYojLD+5Rhm0NrRjUvVwaKiKItobaLxAdluWbGwo9BKIAfLBiKw6ZMQdzU6nHROawyv/ZCj+ZzmZgD+/hIILIJwU3bh5++GEMHjwYJSUlGD9+PBYsWOC6/MyZM7H33nujtLQUAwYMwA033ICWlpY2Gi3RnqgqDRV6CEQB+GD5VkvROCJzdENzk51xM2pAVepv12yHRBA5oaBhqVmzZmHatGl47LHHMH78eMycOROTJk3C8uXLUVNTY1v+ueeew80334ynnnoKhxxyCFasWIGLL74YiqLggQceKMAREG0N38iNjJvOCdOJeG1QSDiT0FlYKrvtnDt+EA4c2M2SikwQhaSgnpsHHngAl19+OaZMmYL99tsPjz32GMrKyvDUU09Jl583bx4OPfRQnHvuuRg8eDCOP/54nHPOOWm9PUTxwEqGA0BVKUnGOiPMqImTcZM17FxmG5YKqAqG96uypD0TRCEp2JUYjUbx+eefY+LEieZgVBUTJ07E/Pnzpesccsgh+Pzzzw1j5vvvv8cbb7yBE0880XE/ra2tqKurs/wjOi47GqPG/wN0I+2UkOcmdzBHaCGLrRFEPijYo++2bduQSCTQq1cvy/u9evXCsmXLpOuce+652LZtGw477DDouo54PI4rr7wSv/rVrxz3M2PGDNx55505HTtROHjjRqPJrVPCjBvy3GQPMxDFQnwE0dHpUI++77//Pu655x488sgjWLRoEV5++WX897//xd133+24zi233ILdu3cb/9atW9eGIyZyDW/c0OTWOWETckLT0ixJpINpbsi4IYqNgnluqqurEQgEUFtba3m/trYWvXv3lq5z++2344ILLsBll10GABgxYgQaGxvxs5/9DLfeeitU1W6rRSIRRCLFVVSqM7OTPDedHva1k3GbPUa2VId6zCWI9BTskg6HwxgzZgzmzJljvKdpGubMmYMJEyZI12lqarIZMIFAskItn0VDFC/bOeMmQd95p0TTSHOTKygsRRQrBU03mTZtGi666CKMHTsW48aNw8yZM9HY2IgpU6YAAC688EL069cPM2bMAACccsopeOCBB3DggQdi/Pjx+O6773D77bfjlFNOMYwcorjZ2cQZNzS5dUoSpLnJGYnUKSTjhig2CmrcTJ48GVu3bsUdd9yBzZs3Y9SoUZg9e7YhMl67dq3FU3PbbbdBURTcdttt2LBhA3r27IlTTjkFv/3tbwt1CEQbs72BjJvOjqG5SdD3ny1ajlLBCaK9UfBCIVOnTsXUqVOln73//vuW18FgENOnT8f06dPbYGREe4Q8N4ROmpucwTLPqB8UUWyQjIzoUPCaG400N50SZtTS9589puamwAMhiBxDxg3RoeCzpchz0zkhzU3u0HLUW4og2htk3BAdCjJuCI3q3OQM9hOisBRRbJBxQ3QYWuMJ1LeavaXcjJsv1+3Cr1/9BrubYm0xNKINMSoUk6A4a0hQTBQrZNwQHYZdgqHiVufmLx9+j2fmrcZb327O97CINobZNOS5yx6zQnGBB0IQOYaMG6LDwKeBA+4ViptjCQBAS+ovUTyw7500N9mjUfsFokgh44boMNS1WD03bpNbgqrYFi3UFTx3MNkShaWIYoOMG6LDIHpq3FKBqXN08ZIgz03OoPYLRLFCxg3RYRDnMrcnd6qFUryYnhvKlsoW6gpOFCtk3BAdBlFAnHCZ28ywVD5HRBQC8tzkDrMrOBk3RHFBxk0n5LoXvsB5/+8TV0Fue0Qcr9uTOz3dFy/sMiDNTfZQhWKiWCl4bymibdF1Hf9ZvBEAsK2hFTWVJQUekXfEEJNbmRPy3BQvVOcmdxjGDVk3RJFBnptOBm8fuNWJaY+IT+punifz6Z6sm2KD9FS5g51Car9AFBtk3HQyeIOmo7n1/QiKjbBUG0+ACU3HkvW7ECeXUd4gzU3uSJDmhihSyLjpZPBPux3NqWEPS3mpc5PXIdl47tM1OPWhuXh67uq23XEnQifNTc5g55AcN0SxQcZNJ4M3aDpaWMpm3Hgq4te21s36nc0AgA27mtt0v50Joys4eceyxghLkeeGKDLIuOlkaJawVMeaHERjxlNYqo0PMZYgPUi+MbuC0znOFiMsRa4bosgg46aTYdXcFHAgGSDaC24GRKE8N/HU/mjizR9UfTp3mGEpMm6I4oKMm06Gzoel2snk8Lf5q3HWY/NsvaNE/HluUsu0sQfF9Ny06W47FQmdPDe5gM82pLAUUWyQcdPJ4Cf79hI6eX7BOny2eic++2GH63LieL01zsx+fH5gnqKOViCxI8GccXFNNyrsEv7hf08UliKKDTJuOhn8Da29uPVZKKcxmnBdTjRu3AyIgoWlEt5T0OMJDS0x92Mm7PAem3ZyCXdI+GtUoZmAKDLoku5k8AZBe3HrM4OgORp3XU70wrgZEHqhBMWswJyHc3vW4/Nx5O/f6zQGzu6mGN7+thaxLL8Uq4HewYRj7Qj+1JHnhig2yLjpZPBzbnsJS8VSd9kmj56bcCB52bp6bgrUW4rtL6Hr2NUUxVMf/4Ct9a3SZb9avxu1da3Y1iD/vNj44zsrcPlfF+L1JRuz2o414699XMMdEUtYijQ3RJFBxk0ng/d2tJfePInUOLwaN6FA8kbsrrlJ/W3jQ+QFxS98tg53vf4tnp77g3RZ9l10FufD1pQRt6UuO2OON2jaS2i1I8LfC1Ty3BBFBhk3nQzNoldoHxMDC+U0pQlLsbGHgsnL1kudm7YW9rLCcpqmo645mf1V32I/Ll3XzUq77eR7yDfsu8jWILFobsi4yRj+3JHjhig2yLjpZLRHlz4zCNJ5bpgXJqimwlIe6ty0tSYjbgiZdTM0JhlnwqJ9Kpzr5l+fr8fFTy9AfZo0/FzAvq9sNTf86STPTebwp47CUkSxQcZNJ4O/obUXjwGboJpa3Y0b3dDcJG/Erp6bAqWC89lSmou4uL0UU/zr/NV4f/lWLFy9M+/7YseZrXHTkZu/tif4vlJUxI8oNsi46WRYPAbtRHPDDIKmNFlDbOxhD2GpQgmK41ydGzaHyzxMWjsppsgMy0wNDj91ZozKwlled6S5yQ3s+yC9DVGMkHHTyeAno/bjuUlOrOlSwdk8FkxlS3nqCt7Gh8gmW03XXftbtZdiikYl5wyMhKfn/oBx98zBqq0NHveV3Ec0h2Gp9mKgd0TYd05p4EQxQsZNJ8MyqWYwod312rc445G5iMbtE9Supiim/XMx5q/a7nl7uq4bGUaNacJSZrYUSwVPv2zbC4pNo4pNHjLvRnvxPrCxZTKG95Zvxdb6VnzuMaRl6KCy9dxQnZucYHhuaBYgipBgoQdAtC2WcEgGHoOnUmnNH6zYiuP262X57N1lW/Dyog3Y3RTDhKE9vI2HG0K6sJSRLeVFc5P6qK0nvxiXLeUmKG4vxRTZ0DLxHrGQX6tHT0yuBMWJdnLuOjrsp0FhKaIYIZu9k5FNthTvgZAlV7D2Ca0Sr44T/ESXtkKx4Lnx0luqrR/szbYPOidqdhcUFzYslbk3hR1XzOP3rRmC4syPV/TEkeYmc9g1SGEpohgh46aTkYlxc+srX+H0h+daUrUjwYBtORaq8vNkzk9OacNSgufGySjQLCGf/Fo3C1fvwOdrzIafvObGDEulGWMBdSOai3cp7bqpU+tVQ5MwQmCZfyfid06em8wxw1Jk3BDFB4WlOhl+Xfq6ruPFhesRTWj4asNu4/2SkN0uZsaNnwmHF4Q2pwtLpRZlnhun/VhShfM497XEErjgyQVQFWDx9OMRCqhmWErnwlLt2HPD9pyJkcCOwbvnJvuwlGiEkecmc9j3QbYNUYyQcdPJ0HxOqnUtcePJfAvXI0nmyW6NJ42TmI8JJ8Y9xTe2+gtLOYmF26pAXn1L3DDIonENoYAqD0ulLeJXeM1NJkYCW8er58bU3GQTlrK+LmQBxI6OEZYi64YoQigs1cng5zAvE9p2rqnjlroW4/+y+cz03PgIS3ETXWtc89RSIV1vKWvozfNQfMN3804IE3dCN71GsmypbIXduSKbrDK2jixzTgY7Hzn13OTANTf3u2145Yv1AIDf/W8ZLn56QacId5GgmChmyHPTyfDbl2dbQ9T4P9/dWnbzZ5OcnwlH1F80xxKoiMgvS1Nz417npq16DzFPFWCG1/gifl4FxYWs1WIIijMJS/n13OQgFdymucmBYXje//sUALBfnyr8df5qNEUT+GFbA4bVdMl62+0ZjTw3RBFDnptOhl9BMe+54Y0bWUiLTXJ+JkpxomtyCU2xzYbThKV4eymfguKWmLltQ19jdAU3BcWyYVrCUoXU3KR2nZHnhhXl86q5yUERP3GcufSw/LCtwRDNR+PF77lh5448N0QxQsZNJ8M68Xvx3HBhqTSem9aYf0GxaHy4Nc9MePXcWHRFnofiG0tYiollNfMcsHFI2y9kWUwxV2SjuTGO2Wu2lOG5ySIslcdU8K2clzLbWjwdAXZ9UhE/ohihy7qT4VdQ7BiWcvHc+JkYRHHp60s24hcvfYkmSc0bpl0JBZXUa7lhwB9Xm3luhJCLpqcJS7UTz43ZIsL/eTLCUj49N9kYJOKq2Yb0eD0Uf31n2yLCC63xBDbvbkm/YJ5gx051bohihIybTobfbtTbG3nPDScolkwqGaWCC8v+4a0V+OfC9Xh+wTr7skK2FP/e+8u34PtUjyPe4MlnMo3oudF13Zi403lu2ku2lFv/q3QkfIaZ2GF6NYbk28it54ZfnfdSek1vz4Zzn/gUE343B99t8dabK9ckSFBMFDFk3HQydL+em3rTc7OzKWb8X+ZtaDWK+HmfcJy8PC2SmjdinRsgaRh8tnoHLn76Mxxz/we2seXTcGiJW40bi5BZd6+SnE2l6FzChpGd58bb+A1BcRbHK56rbM8d79lrS8/Ntxvr8PmandB14Iu1O/O6LycMzQ0JiokihIybTgZ/z/aStcJ7bnhk4SCWPeQrFdxhcupVWeK4T5YKDiSNBLFRZ1s1peTDUnFNt+yL7wrevj03qTFkVKHYn+fGTJfPpeYmOyOE/w3wxk02tXi88Oy81cb/S0L2at9tAYWliGKGjJtOhsVj4FNzwyPV3GSSCu6wbFnYfsMXu4IDycmurjlmXU6zr5MPeO+SpluNG96TI22c2W48N5l7U3xXKM6ijxVDPJXZe24cNDd5DEvtbIzi34s3tMm+3GDfH9k2RDFCxk0nw6pH8ZctxSOtc5NJKrjDk7dchJv8Kxo3uwXjhjcmssnMSQdv3MQTumVfyTo35v9F+GG1B0FxJhlb/uvcwNfy0n3mWHPDX2cWzU0er5vF63ZZmssWKjOLHTvVuSGKETJuOhn8XJBuUm2JJVDfIq87I/OIsFRwP6ECp6d4t/RpPiyV0HTUtQjGjaB9yRf8BKXpuiWUkdB5QbF93bYqNJgOtuusivh5rVCch1TwXGpu+O8zn5qbVuF8tUVmlgz2EyPjhihGyLjpZPgR2+5olIekkuva38vMcyNfVtpJm9XlUBTDlZ7Q7Z6btgr5iNlSVh2NuW/ZGNpbWCqjxpk+69zkIiyV62wpp+POpzdF3GfBwlJUxI8oYsi46WToPiZVp5BUcl37DZndpHUuU+jh977Djx+dJ61bAzg/xbvVhgmoCoKpp01NA+qa447rtpVxE9d0y4So+xAUF7KztZktlYGgOLVKm1YoFtsvZGmEOBla+TQ4RM9moTw3RhE/sm2IIoSMm06Gn4l/e0pMXCrJ5nBrnAmYN/CXPl+Pz9fsxNcb6qT7cOogLjMI2FuqohhPm3FNs4Wl/IqmM4XPlrIJii3tFyTGjc+U/Hyh5cBz47fOTU5TwbM8dR3NcxONa7js2YV48uMfsh6Hxj0sEESxQcZNJ8OiuUkzyWxNeW4G9SizfSavc2MV2AKmkcOK3In1a5zSxmXzPV+XI8B5bmxhKc26jqwrN8/v31yG5xesdV1Ghigo5o/Fki0lC0sJIaxCYaSCt6HmJqHpGeuMxMslk/o8PE76sHymgovGnR9D6ttNdXhnaS2enpsD44Z7WCCIYqNdGDcPP/wwBg8ejJKSEowfPx4LFixwXPaoo46Coii2fyeddFIbjrjjogneBTeY5mZAd7txI5ucrJ6b1ETGtSP4vxe/xOi738bGXc3Gck6TiFv6dEBRjNocCV23iZ7Fdd3m0Q27mvHwe6twzxtLnRdyoMVFUKxpZljKzVBj6xYKHVl4bvxWKOb2EcvQKMm15sZp/XyGpbLx3DBjLhvdkrEtTsNGEMVGwY2bWbNmYdq0aZg+fToWLVqEkSNHYtKkSdiyZYt0+ZdffhmbNm0y/n399dcIBAI466yz2njkHRM/DRt3pSoS9+taavvMLRUcMLU07AYa13QsXrcLTdEEPlu9g1vOe1hK4zQCgVTGVLq+TU7LMFpT3hcxg8ULouaGPxaN0x2lq3OTi4kqU3KRLeW3zg2QuWdEPJfZ9pZy1Nzk0Z0m6sz8GTepbeSgrwiFpYhipuDGzQMPPIDLL78cU6ZMwX777YfHHnsMZWVleOqpp6TLd+/eHb179zb+vf322ygrKyPjxiN+sqV2Nyc9N93Lw7aieqLxoWlCKrQRgjA/ZzfT1duajOWcbtKyoRludNX03DS02oXKNtGpy3Gyz9KFrmRYivhpuuVYErruGvJpL3VujGwpn2PgDWO/FYqBzNPBRYM8b9lSeRUUC54bHwaakU6fAxG68bBAxg1RhBTUuIlGo/j8888xceJE4z1VVTFx4kTMnz/f0zaefPJJ/PSnP0V5ebn089bWVtTV1Vn+dWb8aG6Y56ZrWQjlkaDlM5trXZis2M2XF6yyyW319kZzudSNfZ/eXazjdPHIqIpi3JC3Cxlduq7bPTcuEzff6NIvrW7tFzjNjTQs5cODlk8MA8ynB4Q/1lgiva4JsOplMvbc5LzOTccSFBvGaC7CUsbvKetNEUS7o6DGzbZt25BIJNCrVy/L+7169cLmzZvTrr9gwQJ8/fXXuOyyyxyXmTFjBqqqqox/AwYMyHrcHRk/mhtm3FSVhlAhGDfipCCGdQxBMReeYpPbD9s44yb15r59KvHZrRPxo+G9k+N009yoZj8cMV1dJlZ1mwjihibIv/dGbJzJT4h8tlQ6QXFhU8Ez9NwIy3vx3ljDUplqbqyv8+W58eNN8Us2gmI+zJstvIaNIIqNgoelsuHJJ5/EiBEjMG7cOMdlbrnlFuzevdv4t27dujYcYfvDT/G4Xc3McxNGeUQIS6V5+mRGC1uMD9vwxg17gg+qCnp2iRitFeRhKdNzw3QCYu8rvjIw/54TfCjJ73whFvHj9Rt8rZ90dW4Kmwqe/OvXA5KJ98EalsrsmO0hx/xkS7VfQTEzbrIfH7OpKCxFFCPB9Ivkj+rqagQCAdTW1lrer62tRe/evV3XbWxsxAsvvIC77rrLdblIJIJIJJL1WIsFP5Pq7qak4dC1NISysBCWEtbl08ABe7gn6clIbbc5hp2NUXQrDxufB1MCYTPF2z0sZRo3Vs+NptknDy+aG/Z/P+JKvs5NQhIOMw08ybG0gwrFvKfKrydA/P7ThZl0XbeE5zIV7NrPcZZhKYdx5zMsFecM+rim+zoXGnluCMITBfXchMNhjBkzBnPmzDHe0zQNc+bMwYQJE1zXffHFF9Ha2orzzz8/38MsKvgJJt3Ts+m5sYel0npuEtZwR4JLjQaAH1K6Gxa2CqrJS5HdZ+VhqeTfdJ4bP52j41l4UERBsTghsgk/fZ2bwhg3/G796n7Sff9u+wIy9zzYvHL5EhTnVXOT3DYT6fvZFzttup69VssUFGe1GYJolxT8sp42bRqeeOIJPPvss1i6dCmuuuoqNDY2YsqUKQCACy+8ELfccottvSeffBKnn346evTo0dZD7tB4rYzbGk+gKZqcvJNhKXfPjV1QbBbvY3/5iWR1KjTFKhQzz43K1a8RMVNXTRGkKCgW9+O0LX552f+9YEsFd9BSyDbb/jw3/iZzv7oR8Rhj8cyOWdRF5avOTT6NG3bNM2+onzIE/HWTaa0gY1ucJ5Qgio2ChqUAYPLkydi6dSvuuOMObN68GaNGjcLs2bMNkfHatWuhCo8Wy5cvx8cff4y33nqrEEPu0HjV3OxOiYlVBegSCaJC0NyI93675kYISzkYN+w9prVhLnK3xpmKa1hKorlxExT7EFiLWIr4uRk36Tw3BdLcWD03PtdNIyi370s4N5l6bsQKxRlqd8yGofJxZFL3yCvsmi/NyHPj3Sh+f/kWPPHR9/jdmQfIC3GmVqc6N0QxUnDjBgCmTp2KqVOnSj97//33be/tvffeGdUlIcRJ1Xk5FpKqKg1BVRWUC5obcbKSZUvx+9IETcoP25O1btiNnd1gmR0r1dywm7GiIJBaUBaWsmVLuXpurAaKVzRNt1VkFmu3xIxMLPt2xbTxQqBl4bmxee58GjeZCopzpbm58u+fY832Jlx55FDp522huWE92/wIivnDTXfsFz/9GQDgd7OX4eFzR9u3RZ4boohpF8YN0Xbw90O3TBOzxk0YAGxhKXFykmVLWbwimnVCZJ4btp1QyrhRXMJSzKANqApSjh6jRQRDk2VLuWluJIUHvSAacwldd5ywZcfSVp3L3dAt14K/MdjCTH7DUhkaD+JDTaaZZu8t24poQsO6HU3Sz/PZW4r97pjnxle2FO959ThGp+1T+wWimCHjppPhdVLdlcqUqioNAYBdUJzmyT2esAqIRY/KD9saoetmenhQCEtJdSoaC0s5Z3hklS3lY6JsFhuAJjTEXcZke689aG6QeWhMPKZ0GT/i8pkaN+I4M/XcsO20CFl+jLx6bgzNTXZhKbfQHt9MdrCk8S1grRtFEMUGXdadDP7JV9OAv32yBjPfWWFbjs+UAoDxQ7qjqjSEHuVJT444Ids8GYLGJpHQLBNTQ2sc2xqihrfDCEsp9nEa4+U0Ak61OZJtD3x4bjTr+fCKrbu57tZKQua54dctvObGb5hIPNZ07QpsmpucVSjOLqW8OWpdnxnxbVHnJrOwlDejeGVtvfH/cFB+m6ewFFHMkHHTybAUUtM0/Ob1bzHznZXYUtdiWY4JirumPDcH9O+KxXcchwsmDLJtB7DXuYkJxkxcM1O02RPr6u2NhnERCghhKRcRrqooCDoYN8m2B8Ix58FzYzNuNC2jDufpxpctmqZjztJa2/crjsFveMemuUoXlrJpbnLUFTwDI4n3fjAPXEkoeSscPagbgPw2zmTXCfsdZNJbCnA/9hW1Dcb/+TYh1m0l/1IRP6IYIeOmkyEKEpnHpSmawAcrtuKVL9YDAHalmmYyzQ2QylJiYaM0dU4Smm7RBPAT/9CeFQCSoamYUOfGKOInuW/zFYqdnjal7Rc89JaSHZMbLTHxeJ29CLpu90S1VYXiT37YjkufXYjpr35jHxc3XN9F/MQwUzrPjXi9ZNw4UxyH/3PHHyszUo/ZpwZf3H4crp+4J4C2qXNTGmZeInloTIYmPDA4sYLz3Dida/a7oCJ+RDFCmptOhia5sQPJsNJFTy0AAAzvW2VpmskTCMg9K+INNCakZPOTxdCe5fhqw26s3tZoq1DsFpYyBZDO6avysJTzRMV/5meiFLUaCU2DpjtPEpoOBBR+eesTeDyRFGCXhAKStTNna30yVX67kFUGCJqbLAXFaTU3wuYzzpbKgeaGvz6aU7WcAqqKbuVhbNjVDCDzOjxeYGM2wlJ+ekvx4UyX65o3bpw8N7xAnyCKDfLcdDL4GzvvfeANnZVbGkzNTalg3DhkM9k9N5pV/MjdlYfVJD03q7c3cr2lkpei6iEslcyWcglL2Ywb6aIAMq9zYw9LuU/Y4vGIIaFzn/gUh9/3nm272RJ3SUe3Zs5lF5ZKpxuxGyWZem6866kcx8Ib+CkjlWXrMX1KPsNSbP+moNj7MeTUc8MJ9Ami2CDjppPB3+f4jJ/6lrjx/51NUSNbig9LAeZTXjpBcTxhNTL4yc8MSzVx2VKszo1bWCr5ly/iZzs+WZ0bj5obP2Ep8Wk42VvKeUJcuaUelz7zGb5Yu9O234SmY/H6Xdha34otda1Om8gIt/5W2eh+/FYotoelMvOM2DxAGRhJCannJnk9sWKS6cJs2WB4blLGjayqthMW48bhHO5ojFrqP6VLBaewFFGMkHHTybB6bkzjpq7FTB3d2Rg1wlJVQljKybMiq1DM33x542co89xsazTr3AhhKbdO2gFVcbwhS9sveK1zk62g2GU/17+wGHOWbcEZj8yz7YsvAJjrzCmzkKD9s2yMG7+dre1C4LbrLbVk/S4c/8cP8N7yLcl1uO+cVZlmxjW7DtvScwN4z5iyhDMdjn3zbqt4nIn9xVAve0lhKaIYIeOmk8FPMrz3oY6ri7GtwTRubGEpw7OS3rjhl+Gf7Af1KENAVdAcS2BjSuPAKg6bdW7sN252c1YVe4YHmyh03V55OR+9peyaG/cJW5xweE9GsiZQ6v0cGzfsmKTbzWVYKo0nJldF/Nh5C6c8LF40N+8u24IVtQ148+vNybFYPDdJj2VACEu1ZZ0bwLsx5aUIp3httsY1zPpsLUbe+RY+X7OTW5+Fpci4IYoPMm46GfykxN9Qec/Nxl3NRuXfbkJYSnUMS1lvqPGEZlmGTRaKAkSCAfTvVgoA+D5VqVisUCz13HDZUqLnhjUhlGZLSSaB/y7ZhM/X7LAUQvNX58auMXKbaLuVW88jP5fxk1GuWzGYzTvTaG58GlX+PTfiuDIUFDPjJmWEeDHK2Dlg348sFZxpvpjRpOmZe5fSwbbLi8e9em5Eo1iG6FVsjWv4cOU21LXEsXD1DuN90xPqbdwE0ZGgy7qT4XS/5iuaLlq7E82xBEIBBf1SRgjDEBSLFWolqeAWQyr1OVtfNJpYhWLVpUIxX8QvELAaN6xOSULafsG6ndq6Flzz3CJMfe4LS4gin4LibkJ4z0nYneuwlOG5SVcl2aexkW1YKmPPjW4NY3rJumKGVFwwcgDz3IuaG369XMP2H1RVw5jyej7EcKYMUQ8WjWtoTV2v/DpGthR5bogihIybToZTw9G6ZlNQzMSIQ3tWWG72AIziefawhJAKnrB2yWYTBfP8iO0c2HbZ7tw6aYuem0hQNcflQXPDQm67mmJC/ys/xo3Mc+M8QfGem5ZYwrKvVovnxvMQPGF4K9IIiv3XufFnrNgaXmYsKGbGjWp57YboubFkS0WZ58Zu3ORLd8NrxwyNj1fPjRfjRhKWYtcr/z0xQ4nCUkQxQsZNJ8NpAufDUoy9e3exvecclrJP9tYJ3Oq5KY9Y67kEA+nDUnwvHF4EWRIKWMaVLluKTSRxYYx+9C729gvOjTMBq75ia32r5Qmcf9LOtebGLSxlaZzpNywlLL9kw2488NZyNLTGpcvbPDcZt01I/mVhKS9GmWHcSNLiWUhQFBTz6+Ua03Oj+E491yzGuIPmJsYKYzLDKWGE3yzGTeq/JCgmihEq4tfJcJoL+LAUQ2bcGJ4VW/sFu+eGv/ealYiZcSN6bsQ6N/Yx8gJIVfDc8PV3xGO01eRJsKdY3TLJZico1l0n2ihXFG5LfYtlkrJ4bvImKLZ/ZjFu/AqKheU/XLEVH67YioSu46ZJ+0iWt77OtEgeOz++NDepfTHPmlULxgzm5PYURUE4oCKa0PLWX4oZJYEAZ9x4zpYy/59Oc1NZGsKOxiiiCc14j1+HrxtFEMUGeW46GU6TZ53MuOkl8dwocq0Duznzk46sQrFjWCpgDUvJwmdG6qrQW6okFDCzuDRZurBoeJmvM/WasONlNlZC012f9PnPautaraGRWGYGlhdirkX8rCE5p5ClDKdxfr+1Ub58FkX8rM1eU8aNkS2VfjtuYSkGfz0x703ePDes/IGqGmEwr54bL5obZshUpTIdW2OmccPvh29nQhDFBhk3nQxH46bFHk7YS2LcGEX8HFLBy1nVVU2zGBWGoNjRc8Pq3HjLluJTwSNB1fT4SIv4WbfDPyXL9C7N0QTmfrfNdXJjE2SEC4+4GSb8PmvrWiznjw9x+bVt0hkk7DuQLSaeYz/7djrWXpUl0vczFRRrmo7THp6Lc5/4BDonFjeMaC+CYo0JilPGjeRk8N6LUJ7TweOcx8RIPffoudG9GDepbVWWpHpXJUzNjayuEzluiGKEjJtOhqPmRvDclIfNdG2edI0zjZTshLU7t+G5UeSeG/YEa3QFlwyTjV1VremrVs+NPVtKHCs/ackylW595Suc9/8+xQNvr7APIkVc8CBomu6aXSN6biwpvRnqflbW1uOg376DZ+b+4LJfZ2+F+I4fb4qTRqe6Iix93/4deDvObQ2tWLJ+N+at2o4VtQ0Z1bmJcRorIL3nhm27Na7l3JPG7z8YUIx9MY/K0k110hCxuG7y/06aGzMsBVg9N/x1SGEpopgh46aT4TR3ijfUvXp3kWZRqA6eG+YBYcJZ0ZPBirwZmpuwVVDMbrBMz+kmgBWzpUpCqqWysTiRihMg70Vh5fcB82b/8hcbAACPvr/KNgYG8xiEg6kS+rq7ccCHA7bUtUiNN8BfWOrzNTuxrSGK95ZvdVzGrf2C6PXxo/HNtqKxV68Ir+Wa+902w7uUUZ0bF0PP4rlJGRyXP7sQh9/7LpqicpF0prDvhPfcROMavttSjx89+BGuff4Lx3WtoV6nsFTKc5MybnjNDb+Oxv2eCKLYIOOmk+E0GYiC4HGDu0uX41OuedjkXZbyyMQ1TahzY+3hI4alQkJvKbeu4AFVDEtZs6VsqeAuaeu8MNjPhM0Mpogxybo/5VvCUoKgmMeP54aFW9zEqGxM8rCU9bUfz43TOJ0qFdv2xS23pa4Ff5u/WpppxX9Xc7/bZnyXIc5zky40F/WpuWEGx8bdLdi4uwXzvtvuun2/JDhDn69zs2FXsor1+p1Njut6EYEbnpuSkLFckyxbisJSRBFDxk0nI93kefqovnht6mGYdvxe0s+dPDei5ibuWOcm+bpLiTxbyghLyercGHU5IAiKVUvbBpugWPAS8MYAr3dh65UJXiUZsqydTAXFlu368Z6ktukmRvUqKPa9b4dlnQwtN83Nn95didv/8w1eWrjOth4v+P7k++3Ga3bedzfHMOqut/H2t7WOY2WGlJsXK8jFOUNCgUjxWs0WXnMTsoTA7EUGRbz0lmJe1CqudQo7ZN6ApbAUUcyQcdPJSGfclIYDGNG/CpGgfIJ3qlDcKmhu4kK9GbFCsU1QzLKlHCoU67puyZZy9tzYvUqiM4F3zfOaG7Zezy4Ry35l2D037nVuohbjpsVRs+LHcxP34bmRam6y8Nw46T2cDDy3sNSa7UlPRW29vSM6L/hujCbwxbqdAEzjBkgaONP/87XjWO1hKfsyMs8NIxTM7W3S0NyoKtfLyrx+3MTFFs2Nw7k2w1J2o8walmIPHGTcEMUHGTedjHSRFyejhmFkSwmTW1NKu1IRYZ4beW8p1SEsZda5Sb626UG4l2JX8EjIWufGn6DY7rnpzlUT3iqZcAHz+HnPjdsTN1/Xpb4ljkaHYnd+iul5MW7MIn72z0RDyk9Yzslz42Tc2LqCc/tiTUUbJBl7Yrj0i7W7AJiiX0avKnmWFj8mtk+ZESfT3DByLSo2ivgFTM9NNG6Gcd26y3vKloqx32LQFnKSFfEjzQ1RjJBx08lId6OOhNwvCVUSNoonNGxvSBoBfbsmM6ziQtYS81ywJ2SnOjdOFZD514qiWCajSNCaLWXXkjgLii3GDSt4xy2/zkH/wJ6y+awdr4JiAEZjUpF0+hFd17Fk/S60xBJGryS3sBQbp1vdIIaTYbV+ZxP+s3iDUf15W4NZYblEuF68Gjf8d7C5Lmnc1EuqZIvGDUMMHe1VYy9bYOxL6C0l+5qCAWfjJtcp4XHutxAxBMUJ4zp1LUHgw7gpCQZsXqi4xHNDvaWIYoQqFHcy0oU9vHpu+PvqtoYoND35GatzIgp7xVRwm6BYqFAs3rf5cQdURWi/oLq2X3Drg9UiKeLHT6jrdzZjzCDYEDU3Wpr2C6J3xWnSTjePvrd8Cy55ZiEunDDI8DC5eW689pYCnCveHv2H9xFL6IjGNXyzsQ7Pzl+NMw/sDyCZhs+fw6hD5WHxuNi4mqJx1Kc8NjJBcavQ5oIhTtpuHi+xYaa8zo25vYiLQZALpHVuEubvxW1//Hl0FhQnF4qEko05Ld+PxXNDYSmieCHPTScjvXHjfkkEJJ4V9uTdsyIivVkD9iJ+FWGrccO6fPMp3U7jVhUIqeABI4U8oduzpZyqKQNitlTyL294rNthem7W72zCH95cji31LTbNDS+glj0Ii94VsTeVOQb378fMqGk2jsvJUALca7uIl4LTtcF0GovW7sS3m+qg68CyzXUArKn0yWU9hqVSy7GQFCAvJOl0bOGA1QiPu1iFtt5SabKl8h2W4jU3RuPMhGaMz80TZ6mP5GAEMZ1SSSiASMj5PJkViv0eAUG0f8i46WSk04yWhLxqbswba23KuOlVVWJMEgkhFZwtbqaCC40zja7g8grF/Pwiq1DsVsRPfM1PwLI6N7zhsX5ns/H/Z+etxkPvfYcXF643jt/quUnpcAL2n5U46TsZN+nCUmyMsYTGaW7k2wLSpYI762CM97hx96yIGJ4U1oiR1yexcbmNm8FCRcwwBmB4cHgcjRvBCHfTqcSMbCnrXx6r5sY622calmqJJXDf7GVYtHan8Z6u61LPTZQrGOhmqFm7grsLiiNB1XYtygTFlC1FFCNk3HQy0glW03puJO0RmHHTuzJiaBfiDtlD7EYaFG66YoVi8b7NG1OqIoalAlw3cftE6lRNGbBOnglJWOqdpVsw850V2N7Qaky+ja1xU3MTNIsWxhJWg4dHPO18qMBynGnbKZihCy+aG7eu4OIcL/NQbOI8K11KQsa4WUr2hKE9cOuJ++LUkX0t+7ON28FzU8sZNw2tMs2N3HDrUhLET8b0t21PhlnnxtmL5ea58VIFWcbc77bhkfdX4f63lhvv8ZsKcqngUc5Y1XRnb5EnzQ3vuRGNQFlYijQ3RBFCxk2R0xpP4N1ltYanIJ1nIJ1xw6QJlrDUbmbclBhZT/GE3YMCOIsX2dziGJbi9hdQrY0zxa7gzKZiuxIngXTpyrzOY1tDK2a+sxIvfr7eMIp4PRHffoFNnul0S4C9q7hxnGnmUXZe4hrvuUkvKJZ9F+K1IJtQec9VNKEZ42bXU1BVcPkRQ3DU3j1Ty8gPgG1abEq5ebeZjSb13DgYgQFVwR/OGonfnTkCgLtOxRaWSlPnxuYVytBzwzII+Sww3tsSDIieG/MzLx4wx4KcqXNWEpIIirl1RG8qQRQTZNwUOb96+Wtc8sxCzHxnJYD0+oFMwlKbJWGpuKZJtQ18OIl3mTPPi8wzJL5WFevTpthbSuw/ZBcUO03AzhqW+paY4QGIcYYbyy7j202kMxAB5zYYTpWLxTHy2VluT/q8N8A2BuG13LgxNUctsYRh1LC/7LwzD4RTjRZ2XCUpw495uSyem5a4zeBi34UYXmHXCTNK3MJSYhE/mcdD1luKkanmRnY98UZYUFUtFYr5cTl5Zfi3nQwgI1sqpLp6bth3QrYNUYyQcVPk/GvRegBJvQjgpc6Nt7AU7wnYUpd8+u7VpcSYbMRUcHF9p30pDtlSbFuKIksFV6XtF4w0bRdBsWUfWjLUwyaW207aF31T9VOicY3z3JjLsH0kuLCUF+PGiXSCbzY3xRPWsJ/TMbEJXeaxs3dPty+zjvPctMbN7tJMc8OMzBA3ScvHbTUGTc+NadzENd0WrmNhKbEgHbuMDE+Qi/cqKnpu0mpucpMtxY6Z/254oyXAtV/gNTeA8/Hwv6l07RdKggGbF1HeFZysG6L4IOOmHaBpOq574QvMfMe5C3Um8E/F44cke0WlzZZK47mR1aFhnpvevOcmYc9aAqz1RGQ1ddgcI67LN83kxwFYs6U0XTeOMRSUe27cJmBev3Lu+IH4cUrXEY1rlmJwCSMEJREUZ2HcpPMSGIXehCd9R+PGCMXItiUs68NzI4Y0wkFruMlp3BFOowRYBcUAUC/obpjXg/VJYogeIydxra7rlu9Nl2TTAe6am1gaFb6Tt40do0XXxS0b5AXFwvfptE+nbvI8LXHnsBR/fVNYiihmyLhpByzdXIf/LN6Ime+sdNVP+OUDrls0K5qXzrgpSTMxyxpn1qaevntVllgExbJJRLV4buyGFLvROulBjHCEW50bVoOG86rwuPU/4jUe4YAZNogmNGNi4FstsMkjGSayvpcJ6QoUs/Me13SLiLY1IdfwuDWL9Ku5aY4mbCE70XOTLuTHjEHmmagVjRtBd9MqdLhmGMJ0lRlV8v0mNN3WbFJe58a8nqLCuXQzOG/+1xJM+N0c7G62i6E1w7gxt8eMMEVJGughB8+Nk7eI//0mJMvEuMrgJSFVUsRPFpYi44YoPsi4aQfwT4prdzTmbLvvLd9i/L/VCKm4r5PWcyOEpRpb46hPFV/rXVViTBJi+wWGJZwk9dy4F/FjguaAYCRZBMUa89yYhhaPs+fGPE9BVUEwoBren1YuLBVL6LbJWuOMG7ewVLqQVdpsKaa58ey5Md93a2kBOBg3XJ2fOkkF4aCouXH03CT/Mk1Xa+r62JJqb8GMSLEFgxmWsho3olHl5LkRv3snozvIFfGra7aOwclwAoAPV2xFbV0rvttSb/tMln1n1rhhHi/TuOENGrdr1FhGcsx8iQF5tpQ9rEVF/IhihIybdgB/s/1uS26MG03T8fHKbcZrdoPNNlvKFO4mX7OwQkUkiIpI0JgkeA8KTzrPjVP7BbY/eVhKrHOTfJ/PZOJxSp3WdN2YTNl54DURzCth0dxIiha6eW5K03QcTxuW0lhYyqvmxlxG3LQuSIplHi4+bCTzTojhITc9E2AefzSebNmR0HSoCjCwRxkAu+cmaoSlrJob1RAUm2FQGeJ37WTc8Ea32AbCLc28lTN4RUzPjV1QzH4nvKDYmi3lwXMjOQ5esxQJ2j03FkExtV8gihgybtoB/E1q1daGnGyzMWp6VAAzvTln2VKpG6NRwK8y2UmbTTYxTZNqAng5g8yQSlehmN2IrduRdwUPceJmHrcJmE1EzINlGi+m54afIPmwFT8eJ0rTnN90xqfhuRHOr5PBJuslZL6Wb5uxaXezZZldTXbjhp33cFrPTXJDZZxxt6Mp2V+rPBJE15RnRjQsDM2NLSyV/MuMBKf9isLceEKTGt184T7RwBKvn9XbGo0HB9Mjat8mLyhm36uj50bU3Hjori77fTHPTSSoQlEUSRE/qlBMdA6ot1Q7gL/h5Mq4aRLK4rObcLbtF/jGmbqum5lSqZ5SRoXihL3HU/Jzc/ti00V++05NHdlDZkDYDm8UJQTjxo+guJWr7gpYwwYxqeYmOVnz4QBZhWJzrFl6blIfJ9s9mMfhxXOT0HTwu7d3BbduY+Muqx5G6rlh4aF0gmJDB2IOgIV/SkIBVKQ8M/WtDmGpEqewlDz0yBA9IOmKS/LbNtYRlj/qD+8DAP5zzaHG9y47bn61aEJDJBgwvjPWbsQwnuNWj5IXzY3Mo8S3XgDsoV9NT34XqqpQWIooashz0w6wem5yE5ZyNm7c1/MalmLbYk/aVakna+NJWtOl+h5r2wRJWEqSag6YHg22fyfNjaabglFe7MvjJywV4Z6sec2NGILi2zi4hZ7SGTfpvh9L+wUfqeCA3WAUvUTihCp6UWTGjeo1LJXaNH991aW2Fwmq6FLCPDeicZPcXpWD5ibokO7PEI2OeEIeLuWN7rtO3x8Du5ehS0qE76TnWbhmp6tgmzfuWzmvX3J/1vPW6jVbymNYij04iD24+G1TthRRzJBx0w7gny6/39KQNjThhaaomHXCUnizDEtxRkVC0416JyzcwsJSjlkp3H1U7rmBdJxsjlJlYSmHruDsqV70IMUcO1dzYamU4WXR3HB1bowifoIBpSruBmKp5Jh5NF3Hv7/YgAdTRRdlY2R/PXluXMJS6RpnNqauIfaViwYzwIVXjLCUg8eBm9TZ+WEC5UhQNbL5bIJiI1tKaLQqZEs5Gaw240ZzELpzF+Y+vSvx4S+OxlljB6TW0fH5mp146fP1lnUaOS+T7Lj5698IaSasRrrRONNrnRuHsFQsoWHK0wtw35vJVg9Onht+rGZYiowbovigsFQ7gL9h1bfGsbW+FTWpME+miN2a3bQBPGk9NwHec2MWXWMaFbPOjWYLcwD2+jROn9vCUoILnZ+zknVu+PYL1rCUTSjrktFjeG5CzmEpi+ZGOF8loYCrmz+doFjTddz1+rfY0RjFmaP7YUD3Msvn7NhiQnjFUXPDfQfpNDeih4sZGj3KI9jW0AoZtgrFaTQ3asq4aY1rnOcmYAiG7Zobh7CUoFlxEv3awlIObUGCku/MFCtr+L9/Lsbq7U0YO6ib8XlDq7ytAiMh8dzwHcEBTheW0Czb8FKhmN/+vFXb8R5X+qFEMM554gnrWMhxQxQj5LlpB4gu6O9yoLthT9nsxsUmCbfy/oFU+rMboueGL/UOmDftuENYip9EfjS8DwCgZ5eI8R6v6eERxY/8RCB2BWeril4Vhpc6N2xdI2xg8dw4F+zj+1zJKEnTdyqhmYaprGkkm5e9p4JznhthEbt3TDBuWpP7r66wdv7mYd8XHwKUXWN8NVxmCNeljKdIiPPc2DQ3yUFXCNlSYr0jz2EpTZfWh5GFZvgaOrtShhgfNuP/ny4sFRXDUgHr+PnK2oCLAe4gOhaF6iWCcc7Dts22RWEpohgh46YdIN5sc6G7YcZNt7LkxMQmbTfHjZe2AZw0AQndOSwVd0gF52+kk/bvhecvPxhvXn+EuX2P2VL8E3k4oLpmS9l7S3nIlgpas6X4In6WPlIB0bgJuE4W6TU3OpcRJTESNBZSsBo0smPSdR3WVHC5jkncNoOFXXq4GDfs8PlsI5lexJhIFS4sZdHcMM+N3LhJthIwzzU7xYbHyEGjYk8F13x4brjWGsyw5dblvUzpwlLMUE0IBkWQG78XQbFT+wXxmYQZkLLftFi1msJSRDGSkXETj8fxzjvv4PHHH0d9fbJ41caNG9HQkJtMn86G6NKukwg3/cI0N13Lku78VsnNmcEMk3QTL2D13GiazgkYZWEp+774G6miKJgwtAe6l4dtn9v1IOY6gPWpVVEUq6BYCBn56Qpuq3PDhaXMHkWc5kbQNERCKtzmirTGDef5kKYXcyeG7ywu89w4eb8YTqE/BvOi9CiPwImAEF4BHGq+sIlUorlJZkulBMUO2VIRoQmkahgH7p4b8f24UxafxGPJN4Flx8SfI97LJAvBSj03CbNIJMBleyWshqhTmI0fulVzYz0mURDPY2T9keaGKGJ8Gzdr1qzBiBEjcNppp+Gaa67B1q3JOO+9996LG2+8MecD7AyIk6+sK7VfmOeGGQ7RRLJLN3ta52PxzOXvxXPDeyWSqdNCWMrwlshv0Olc4LKu4/xrvgIyj6z9guG5sQmK3bKlmIbIWmStJZYwjAFrc06rsZIuLFUaTl+hmE06aTNwuIJtMuNGvK7EzYmvHY0bN8+N4EEB5OeX13ew9HmWCs57brY3tOK95VuM4+HDhHz1bDMsZRqwMiG+LCyVriu48Z4h9jV7jvEGIi9+Tu+5sYalmFFo1unxH5biDTfRiCsR6jTxGIJiCksRRYxv4+a6667D2LFjsXPnTpSWlhrvn3HGGZgzZ05OB9dZ8Nq12g/NQlgKSN4wDUEjF0ZgKa9ejBtFUQzPhCxbytqjx79xw7btFEJh64s9jKTtF3wKiq11bqxufT5c4tZHKl1YKl0RP74XkltYCjA7cwPyY7IbN+6vxeVZWKq6ws1zoxh/A6rdqybuKyDNlgoY1+A3G+sw5enPjMwkPkzIX59itpFs/IAkLJWQh6Vk31koZXjwHjL+t2r13Mi+K/P/7LoSi/iZdXo0wXPjEJZyyJYSvb9GtpRE48WWTRjfiXRXBNGh8X1Zf/TRR7jtttsQDluf5gYPHowNGzbkbGCdCbvnRt4E0Q+i5gZI3mDZrkISz42XsBRgNSSMiqipdfnJhvcsiOs6oXLhJR52U2er96kqEdZL/tX5OjcBuxco2SVaPnFI2y9wvaUYsYRmGCAyQbFrtlSacxyzCICdwzuAtXCg1HMjTOzpjBvxdYNh3LgIii3dtJ3Tsvm0Y1kqeBchG+rTH7YDgOX74K9Pdh3w4SSZQWCrUOwgeJZdl+wBgM88tHhuLKngzscMJJtxrtneaPwuRc1NPGEVOqfLOgOsoTCb50a4fnlYKQTN+E2R54YoPnyngmuahoSkA/H69evRpUuXnAyqsyHG63MSloolb7xdSoIIpKqRtsYTNrEtAJSHvXtugOSNmYlqRc0N/wQsOw6vYSmnEAqbhE7YvzeuPXZPjB7YFQAc6tykPDeWScb53FoFxXYtiey4xHPGp6XLEBuTBlPnksFPajJPBD+58Z4b2blOF5ayLZ+QGzdVpWGoinx9/lhDARUtMU0eouHqFBnZUs1ctpSQDRVUVehCmFDmuQkKnsJSWM+vrXFmwp7FpyryKr1s23zNKH57ojdPhDeqv1i7C5c8s9AIc4aEbKmYrYifswEu26ez58Z6zhKabi/iR8YNUYT49twcf/zxmDlzpvFaURQ0NDRg+vTpOPHEE3M5tk6DOBnIPB7piCc0fL1htzGxN6XSeMvCpju/JWb21QlzHhZTc+PRc8M1zxTDUiEunUrmgUpX6j1dthTfOHPacXvhqL1rLGNKaHCtUOzW4ZnvCu6mWeC/H6nnxuUQRc+NaDzxxo1bvyLAKgiWe26Ec+gzTMXCUl1Kgo5ePd5YdesvpXEhEFlYql/XUgypLjeW39UURSxhhuhsYSmhK3jyeO37FceSzEqyvsdXJ7a8H7BXn+b3kT4sZb737cY6AKZxLdYHSj4scN5BL0X8Es7XtSwVnOmajMwv0twQRYxv4+b+++/H3Llzsd9++6GlpQXnnnuuEZK699578zHGoserJsSN376xFCf/+WM8+fEPAMywVFkkaEwKrfGEMfHz7nxDc5Omei5DFpZiN1NVNTU5Us+Nx7CUY50bhxsxny3F5giZoNhNz5SscyMPS/HwRpvoueGrJYsoiv0c82E8IL3nRqYXAZw0N2nCUsIqds1N8jjLuWtIJKBaPTeA/Byz78ASlmpm2VLJ7tXvTDsSj5w3GgCwsylqO8+88c1CKQFV4WofSTQ3wlgSkiJ+TpO76bkxx+FkfKYLS7Emoea2mQDfvN7dPDHmNrlj4V7IOroDQuKA0U5Ct4yPeksRxYjvsFT//v3x5Zdf4oUXXsCSJUvQ0NCASy+9FOedd55FYEx4R7wxtsb8a26enrsaADDznRW4/IghaE6FpZKemwCAGFrjvOYmc88NHwISPR1AclKIJfSMwlKOjTO5bJt0Y9IEz026SYjfh60reJqwlFRQ7GDABVXF4tlKrh8AYHoAolxrCJk2xKk1hyfPjS3UJ9c1MZhnoiISSH2/ksaZvHETdNbcJLiJlJ0ztjt23amqYoiXdzXFLMeUzJayh6WApKHOV5DmsTfO1GxhKVmmVHK7duNGFLIbx5fGc7Oz0WrcGJ4b7nrgNVRuujAGbwCJx74ttT8+DMqMGzHzi2wbohjJSCcfDAZx/vnn47777sMjjzyCyy67LGPD5uGHH8bgwYNRUlKC8ePHY8GCBa7L79q1C9dccw369OmDSCSCvfbaC2+88UZG+24viDdGv5ob/sa2f78qAOYNuTQUMCYFR82NX8+NanpJmqPWsBRgPpVmY9w4FvFz9Nwk//LZUmFJtpSb5yah2zU36Ywb0VhxExQHVMUwAPjledKV4HdqnyGb2NN5bsQtfbRyK+587ZtU2rvOGTchx7CUqtg9N7KQirWInz19ntEtVZdpR1PUOM/hoApFUSzVnfmvJeRSpVg8BzJBcTDgZIyaZQAYTuEiuc6I89w0ip4ba52e5H6cjRXZNi2p4MIxbatPtstg1284YKbSs/US3HdCEMWGb8/NX//6V9fPL7zwQs/bmjVrFqZNm4bHHnsM48ePx8yZMzFp0iQsX74cNTU1tuWj0SiOO+441NTU4KWXXkK/fv2wZs0adO3a1e9htCvYjak8HEBjNOE7W+qbVDwfAPp3TRqZRlgqzIWleM1N6r2AqqDMpZqpDDahxRO6kSbLN8FkN26ZByqtcZPajC0slbrXO2V2WNsvMAPODJ8x3EJ+mqajVbeGpVRVQSigWCYv3oukplKgjYrFXCsI2xgVxaaxcQtLyQrDOQ3fS50b0esjvv7k+x345Psd6FNVggsnDDaOqTwScLw2eK+HW/NMNhRZY1H+dddUdt/u5phxDRsF6bhrjDeqkiHWhDSUI54XsVgeYNacEQlJPDfORod7EcU6ofJyQGrcyFPOeSx1biyGjnX/JwzvDcDU2VSWBg2dXczw3CSXpbAUUYz4Nm6uu+46y+tYLIampiaEw2GUlZX5Mm4eeOABXH755ZgyZQoA4LHHHsN///tfPPXUU7j55pttyz/11FPYsWMH5s2bh1Ao+YQ3ePBgv4fQ7mA3srJIEI3RhO86NwtX7zD+z552m6O8oDhpvLTEE8YNja+zccRePfGvResxaf/envbH5meNTwXnnqqDLinB6aqhOoaljPYLDutJevSwYnF+wlKmkWIeTzigIibJEGRP9gFFQSLlB4mEAo5u/oAqM26sr/mwlGyoTl3dvYSlxO05ZU9t3t1qEcuWh50FxdZUcGdBMR+Wsld1NrfNKmrrOrA15X0Qaw4BoseITdr2A7KHpextQZzCUszoSVdPyGnfTvqo5JhTWVMWAX56z42T5obt//A9q3HRhME4au+eAIAB3ctwx8n7YUD3MjyV0uPFUgU9GVShmChGfIeldu7cafnX0NCA5cuX47DDDsPzzz/veTvRaBSff/45Jk6caA5GVTFx4kTMnz9fus6rr76KCRMm4JprrkGvXr0wfPhw3HPPPdLU9I4Ee+IsT3WM9huWWrR2p/F/5vVpTKWvlgrZUgzj5hpQMXJAV7x/09GejRu+KizbJt/tmk0Ksqwvp4mE4RSW0g19QHpBsVnEzy5OTisoFioUA0DIwWvB5iXeU1MSVB3HGAyotjCXW7aUzBPhZNy05qCIH6MiEjAypcrCyS7nJQ4hy4DEyJDWufEYlgoFVEPgXlvXYvk8YglLcZ4bdj1KjRtJET+b58Zdc8Pj2KA0TfsFEbZPlRNEe9HcJBw0N+yYelZEMHG/XpaEgUsO2wPH7dfLuI7FzugUliKKEd+eGxl77rknfve73+H888/HsmXLPK2zbds2JBIJ9OrVy/J+r169HLfx/fff491338V5552HN954A9999x2uvvpqxGIxTJ8+XbpOa2srWltbjdd1dXXS5QoJm4TKUvVm/Bg3uq5j4WrTuGHGBvPc8E/dvHs97KIpSQeb1PkUWf7Jnk1ysuNImwrOwlI2sav7+qZRZD7dZiYotoZCAOdzZHhuuDFFQs4VimWeG1GQLJuwxDHKyKSIn5NjoTwSNGq4MBGql1RwN88Nn5kTEc6PuO1u5WHUt8axaXfKuEkZViWOYSlno8qeCq7bzqGT5kbUUyW350NQ7GzbWIx8Joi2hKWcsqWcUsE1a4q5DKZNigkGnkNUjiA6NDm7rIPBIDZu3JirzUnRNA01NTX4y1/+gjFjxmDy5Mm49dZb8dhjjzmuM2PGDFRVVRn/BgwYkNcxZgKbhMojzHPj3RNV1xLHlnrTeGM3SENQzHluePc677nxC3vSa+RCFyXcJM1usLLjcAorMfiwFK8JEbuC29aThKVk7RfcDMeEbi33z5ClgwPW1gOM9Job62eiJytmCUvJtCvejRtxImarzlu1Db9/c5mjoVcWCRrfbUWa1hy8scnOkzQsxRfxc9HcAKaomHlumHHp5Llhn8vr3AhGcpaeG6dzJtUZefDcAKbR0eIhLGX13Jj9tJihI2sAauzH6ECuWwxbCksRxYhvz82rr75qea3rOjZt2oSHHnoIhx56qOftVFdXIxAIoLa21vJ+bW0teveWh0f69OmDUCiEANescN9998XmzZsRjUZtLSEA4JZbbsG0adOM13V1de3OwBE9N340Ny2CaFequQmxYmSmMWJoboL+b2xsQmOhr1BAsdxUw0YYLANBMXej1XV7rymnp0xeB8QmAL5AGsOtiJ+m6ZZGjQwn4yboYNy4iZ5DghEoeqJ470O2nhun5qP3zl6OL9ftwokjnMOQ7LstT+O5kQqK4/Yxmr3BZIJi67aZqHiz4bmRaW64MRj9mTyEpTR7nRvHVHDJ+16ymNzeM7bNGU5MEB21GDfpBcVA0ksZUEzDTjSeZfuMxa39taiIH1GM+DZuTj/9dMtrRVHQs2dPHHPMMbj//vs9byccDmPMmDGYM2eOsU1N0zBnzhxMnTpVus6hhx6K5557DpqmQU3NcitWrECfPn2khg0ARCIRRCLOjf/aA+wmyJ6S/YSlRAOiJZZALKEZkyQvKObDUmySzc5zk8qUsmkokq9lN2inzBRx20DyKVWFVYPj9JTJF/9jE0DECEvZK7/yGU7G/viwFBcCcQpLqVLjJiCdZIHk5MJvK6Aods9N2vYL0k3LQzIOqeBNKa8Mfz3wxBMaGlLfrRGWcqiBJEsFd61zI9PchOSem82i5oYPS0k0N/I6Nx5SwdNUKOZxFhQ7H7MMazjPuxElfv+xhIaAal5zTscCcB4uTQhLkeeGKEIy6i2VK6ZNm4aLLroIY8eOxbhx4zBz5kw0NjYa2VMXXngh+vXrhxkzZgAArrrqKjz00EO47rrr8POf/xwrV67EPffcg2uvvTZnYyoEzAgoY4JiH+0XWoRlW+IJy6RlCUvxmhuu/oVf2I2ZhS7EfkluKeXpdqdwn1ubBCb/OgqKJUX8IpyAksEbffVCeq61zo15TOnSoHmDLBJSoXMGJ29EiZobVbU/Nadrv+AU6pB6bhyK+LGJ0CndOJbQ0NAiem7cQ3OAaTDLw1KccSNmSwnnl3luREEx7z2SCZm9CopFo9G5zo13QbGf7yq5bVX6f3Oc3rQ97LVh3Hjx3CR0S8iXPDdEMZITQXGmTJ48GVu3bsUdd9yBzZs3Y9SoUZg9e7YhMl67dq3hoQGAAQMG4M0338QNN9yAAw44AP369cN1112HX/7yl4U6hJzAPAvlQgVRL9jCUjHNMGKCatJTINfcsFTwDATFzHNjZGS5T1aydZ0ICGEpRvoifqaHx6h8m5oMY5JKruXhoM240TR7ET/A+Rw5aW74CTDIGTdBVbFMPgFFsZ0PWT0dHsf2C9I6N9b3DH1G6n03/UgjV50YcBMUm/8PCXVUrPtmy8s0N9Ztdy9PGjeGoDhNKniQ80jIjoVHlgqeL82Nm+eGN5xk+/fSFRwwjRq2vFs2Ii/4tnpuHFchiA6LJ+OG16yk44EHHvA1gKlTpzqGod5//33bexMmTMAnn3ziax/tnbjguUloOuIJzVUcyGDGjaIkJ5CWWMLoYlwaDkDhujDzHp2gISj2f2cTy9KLIQsnjQrgT3PD34DN3kQO66nmUylD5rlhxktZ2D5ZJyy9pdILiqWam1DAmpUWUI19qoo1LKWq9rAUb6T48tx4EdMKHhun8Fk8oSMat3pueO8cu9bYMTHcivjxhQ9FY0b0CrGwFIN5evj1eGdHUPLdM+yeG93iSUtouovmRpItJdETAXLDyk1zE+B+d/7CUu7fqRdBMZ8KrijOhTEJoiPjybj54osvPG2MfiSZYVQojphfR2vco3GTmgyrSkPY1RRDS1zjqhNbn3gtnhujiF/mnhtW6E18qnfrUZXOuOEvIf5GrkkmU8t2FbvXwDBuUlkliqIYn5dF7GO0eG54zU2abKmg4LmxhWpSyWzBgDUsJRMUp2u/4Ki58SAoZi+ZESDLLmJjYNcQ6zvGGyAV4SDqU989bwC4Nc6U9ZZiOAmKzc9Vy19AnoIu99wk3wunPGoxzQxLlQRVNEYTjtekzOhw8qr6yWwD7KngIk6Gp7gf9h2y5UMuvy/TCNRMTxrds4kixZNx89577+V7HJ0asYgfkDRuyjkdtK7ruOXlr9C1LIybf7SP8T7z3HRNGTdRi3FjTeNl4SpVMYW9bl4WJ9hk0GQYN8Jk5dKjKp1xw3/Oz1WJNILigCoxbjijK67pCAUUY+Jl54YnypXm91Lnhi/EZuwzGLCGTCzhB9UyYQYUxTa58N4H2eTomC3lQUzLwlIJIyzlpLnhwlJhe1PVLiWmccM7N9zq3BjZUp5SwUXjJmWk840zJXVuZMfDKj6XhQOIxjUkEqaguCSUbHfiJMKVXau+BMWuqeC85sa7tkfcpKmfSoWl3Dw3hiZKt2igCKIYofJN7QDmUg4HA8aNTry5fbOxDi98tg6PfbDKIgZkxk0VNyHsbEo26Ss1UmiTf03jRjG0ElllS7GwlB9Bscf2C4DgueFCCTLYavwExxsl7Bybmhu754bXL3mrc5N83yIoFioU8+c3KKSCs75UPHxjRpmo1E+dGyfPjRmWcvDcJDTDKycTFHcpMcNG0q7gLmPxki3VVQxLMUFxkA+N2c+xW/NQ9lvgU8HZdevsuZGFpfwIiqWLArAaNLL9SL12LunmZraUi+aGewCQacsIopjISFC8cOFC/POf/8TatWsRjVq73b788ss5GVhngr8xRYIq4pLmmRt2NVuWZx4Aw7gpNSeEnakOxCwsxSamptSyKhcOyURzwx46Gx3DUi6C4rSaG/P/1rCUqRGQIfPc8EZJTNNQigCXmWa/9Ju4OkD8un40NyUhVSqyZcuJqeDixGqtc+PdG8AMisbWOLY3RDGwRxliYmZN6hwygbVTRk5c4zw3JdZU8FDA2oohINXcyMJSyb+y3lKiZ4wJihnsehJrBDG8ZEuZxo3ZV4mNw+k34KfOjW9BsaXOjX0/spChbHtsPIag2OX3zIfvjJ5wDkJxgujo+DbbX3jhBRxyyCFYunQpXnnlFcRiMXzzzTd49913UVVVlY8xFj1xzivBbjZirZutXBVi/gbLUsErImbZ/x0pz01ZxBpSYEX8VIVvnJl9KrgvzU0az42iKIYBw9/ME2k8N26aG8BMi2bntVTiuWnisszEDCjpPh3q3Dh5bsSu4AGZ5yZtnRvre8zQYEbRSX/6CEf8/j2sqK13bL8gPu2LpzSW0IwaRuVhaxG/kmDAdgzisUYlE71TEb9kBpn1/PapKrEUGGSGqCXEZwn92Y2qL9ftwkl/+ghzv9tuGT/fFZwZbI7ZUj7bL8QTGnY3xSzvOWHx3Ej2IzuH/Hcv9k3zIigOGpoos+GtU4o/QXR0fF/Z99xzD/74xz/itddeQzgcxoMPPohly5bh7LPPxsCBA/MxxqInzj11sadYsdbNtgbeuLGHpUqCAaMFguG5CVm1Cmzy5rUemdW5Sa7DwlKlaeqWWNb14CmSdQZPJ4CUZUvxxxYT0p/5sJToBRPH7zcVXDbhA8nvN6CajRJV1a554OdD2ZO6OF+yiZ+1nVi9vQkA8N8lm2yTq64nhdWioFicEGMJzWjEadaYSYl6Q+mNm7R1bjjjV5ZirigKHj53NB47fwzOOLAfzjiwn2X7gJAtJalQ/N+vNuGbjXXGa+bFjHPtOdjvwrmInz/NzdX/WISD7nnHqKzsJii2aG48em54R55ZkM9qqLoJig0Pl6YZyQVOKf4E0dHxPbOtWrUKJ510EoBkleHGxkYoioIbbrgBf/nLX3I+wM4AX100YjyJW8NSW9J4biKhgHGj2pl6ehSzpdjkrSp8WCoTzU3yb1MGYSkv2Rns/mwp4meEpdIIijmPl6oqtpAFC9+UcMaNmMIshqHSCYrFVHDVMuErtuXZOQ9w2icZYhE+wO4N4FPaea1LfUvc5mXQNKGJaOr/4vHFE7pxHkOGcWOGOC26IUkxvfTGjbm+07WiKApOGN4bf5w8CgN7lCXH6bRfoyu4uV/e0wmYnrp4QjOuq9I0mhs/dW7imo5vN9UhGtfw/dYGAN49NzJvS7qKx2JTWKYtcm2cyRmf7OGplIwbokjxPbN169YN9fX1AIB+/frh66+/BgDs2rULTU1NuR1dJ8Eo8hYwb/yi52YTp7mxGDdx071sGDcpz02pYdxY69yoqoL9+1ZBUYDh/f2HEtkN1CkVPJs6N4C1lQJD48IabuuI3ZGDxsRnFRRHAmbmkqg7sBk3PntLuQmKAdOYSAqKnc+VLCzl1bipa4nZNDsJXbdskxkDtrCUphseCjbWwdXlCKgKhvasQFhisAHujTP5In5hD8aNDKfCd7JsqS31LZZ12SQe08xzwN7z1xXcWVBs9HVLPUSI31VlianzkjXOtO7H/bsXzzW7vt0eVkKcEU9hKaLY8S0oPuKII/D2229jxIgROOuss3Ddddfh3Xffxdtvv41jjz02H2MseozwgGq67EXNzcZdLdzy9rBUachss7A9ZdyUCx2dm2NmKvhx+/XCkunHWzJfvMIm7ybHbCnnp0EvqaeysJTGPfnLMAXFZsoxkJq4YqbRwwyAcFBFUFURSyRsnguvxo3huRGypQJOmhuVGxPSe240PSnsbWyNo6ayxHiPhz/3rZy3r645JukKLhg3qf+LLTziCY2rD5Mca7+upfj4l0ejW1kYN8xabDsmwDSEopJCd2Yqv9Wg8SNoreRE8/xlIKtz4+S54VPBJw3vjcZoHD8e3V+6P1VVLAULAecifrGEZlxb7HyK31VNZQnqWpJenaDEOOORZbLpLp4bL4JiI3yXoLAUUfz4Nm4eeughtLQkJ9pbb70VoVAI8+bNw49//GPcdtttOR9gZ8DsC6MaNy0xW2rjbtNzE5WEpUpCAWOiYDd29qTIQl380zOAjAwbfn1DmOmjzo3bzZchC0sZRfzSCIqN8IeQ6m6EpYzuyUnPTXMsfRgqbRG/1DGFUx3BZXoQfnkjLKXa69zwxDUdR/7+PWxriOLTXx2LXpUltgkzmPKEROOaLSwlTpCabg3diOeEEePDUty56FNVahyneEz8sunCUsGAalQH9uO5qa6I4Nen7IdQULUY0MxQiFs8N4Jxw2VLMUNrz5oKvPCzCa77DKmq5fy4FfFjv1lmOIiet16VEXy3JWncWBp/SsNSaTw3gubGbPHhfD7DFs+Ned8giGLEt3HTvXt34/+qquLmm2/O6YA6A99s3I2XPl+Pa4/ZE93Kw2amg8qFpYynwATqWmKWPkiWdgIxPiyVXNcwblJPuqInJdtK0qKBYe8KbjcO2MTryXOj2sNSfPl++TrW14bnRkgRj8Z540Y1xmcdvxCmcnCvsG2zY2LHLUuPBkwRKdtvst6Q82SUSOjY1pD0wn28cht+PKY/xLk1qKqIBJLnl2+MWtcSs02uCU303DhXKDbCUhLjQ8wAM953DUtZs90iQRVN0YTvOisXH7qHfTxBa8ZYazyBXVzWEsBpbjTdEOZ6CZEGAwr45ulOxfViCd3ymwXsdWlqupQY/+d/w/KwlLPmRlHM78Dw3DBBsafGmRoXliLjhihOfBs3EydOxPnnn48zzzwTlZWV+RhT0XPSnz4GAOxujuGBs0cZk4xo3LTEEjjivvdsT6FyzY0ZlmI3+SrDuLFOINmWXBfXF9OqZZ4QNin40dzwcwNf4dZtHeO14CURQzCl4YDpcckyLBU0Jmy7QNVSz4RpbpgRpKYRFHNeGtak1Oa5CaQ0LK0wqgYDKePG1hVct7zHvAORoGoJgyZ7S9k9Nwxr1hJvyLkIioUK04Zxk4PJNSR4bphByFNqSQX3bmi7perztMQShmeUGQ5itlt1RdiyPMOroJjv5yXWdWIeOa+CYiMsRUX8iCLF95W9//7745ZbbkHv3r1x1lln4T//+Q9isVj6FQkbK2uTLmozLGXV3Gypa7UZNoBDWCoYsD2FVabCTuL7XgwMN8TiZrawlOD5EFsOpIONT88gW0p8zesMADPcVxJy9tx4zZZiIQA2wbPzIKuey4+JnQ++mKIM3nPFPHeiSJUX6DZw3r265rgkFVzurTln3EBcetgeOGfcAADJyc/IHJMcu5Og2K3ODbtkVcEQzEWFXLEruKi3AUzhdbIjtn3sTojGnZNx08gVgGQeNPFUV0TMMHALF3aWeVtkBQmNWk+KWRto0ZqdWL+zyaOg2AwnM4+vrN4TQRQDvu8sDz74IDZs2IB///vfKC8vx4UXXohevXrhZz/7GT744IN8jLFoYZMhuzEFVE5zE0tYboA8MkFxJKTawkOVpVZBMSPbdjKZhKXMdT1sP7V5axG/5F+nCUl8CreHpZLbao6aAmznsFSmnhvV8j4AW0VigE8Fdzf2+ImUFUwUPTehgGrslw9d1rXEbLot0XPDiARV3H7yfjhyrxpjvxmFpZhnQBK60TlBMb9dN/G5V8RsqS11SU2gtXJ0SlCs6cY5dGtVYGzb5rmRC4r5r4X9bkXjspxr1sqLuGU6GdbslYfXk7Fx/end73DZswst3l/nY2GCb81ouEthKaJYyeixSVVVHH/88XjmmWdQW1uLxx9/HAsWLMAxxxyT6/EVNSWcyBGwhqWiCauGgoef9PisB1HIyzw34gSSredGnJBLwqJxI3pu+HTo9Jcc83zwT77i5Ggbk/CBIhgS7ByziScSCthSsxl+BcWiN0LW1BEwCxjygmLRMOLhQ0WGcSPx3LD91reYHlRdB7bUWT0YSc2N3fAwz1XybzShGROpNCyVhaA4IOiT3MTnXhHr3GxNFbwc0c8sc2AYuVwRv3StQPj1GKKgWJZK3RxNLiOGpVj2ImBq5QBnkb092y35V2zbsWxzvSUpwQk+RMvuLRSWIoqVjHpLMTZv3owXXngBf//737FkyRKMGzcuV+PqFPBPk0AqLBVinhvNEpfnccqWEj0ohuZGuAFn2wk4nefGLazjpWZgwNDcSATFabKlxP2YYSm75yaYQViK16fYPDchFqYy13Wtc8MVUxR1L4BVl8H0NOKEyfd64j03ALC5zlrrJRmWsnse2Cll56Mp6h4ycapQzNLGXTU3wrnKTVjKNFwA06jbt08lVAXY1RxD/27JQoAJTbMZWu7bto5PFBSXh4NoiVk1PsyAFg3RsnAAe1SX44dtjThhuNlegj+fvPg+rmkIc8+fvG5J/K75pAQnQjJBMYWliCLF952lrq4OTz/9NI477jgMGDAAjz76KE499VSsXLkSn3zyST7GWLQw4yZm3JhUi+aGuY737tUF/7pqAg5IFdyTZksFVdtTJMuWEj0RWTpubAaKXXPjEpbKsEKxxj21StcRxmR6R6zehBauMms4A0ExXzTPKOInZktJvBn8+6x7Np8KLhPW8oUcmZ5GdLzw1wzvuQGAWsG4cQpLsVPKhLm8x1DmteI1N/y1ZGhupGEptryouclFWEruuanpEsG/rjoEb11/hKW3VLo+ZdZtuy9TUWJ/PmyJygXF5eEg3rj2cLx341E4cGA3cx98+Ixv9irU1OEN/KWb6oz3A6rir3FmQjfDUjk4/wTRHvHtuenVqxe6deuGyZMnY8aMGRg7dmw+xlW08Dd+diMza1SY4tDWeMKYZMojAYwZ1N24EVnbL5hhKT5+Hua0GKqqoCISNCoKZ+u5EQ2Mioj1MrJ1fXYIYzhhhKX4In5Cto1tTMJ2mRFiZNIY2VLm+XL03LgYO2XhoNHewiksJWtJAJiTGAvNBThBsUy4y2uuGhw0N0HV9PbVCU/zYtaQpsu9Kmy8Us+NJIxoprJbxdPmtesSlkptTuxZlQ1ithTz3PTsEoGiKAgGFEv/KWZ0eDJu0ixTLukuL2puhtVUYNXWBgzpWY7SlPfGsg/eMxgKAKnvMWarU2SO+5xxA/D8gnXGfth17SYo5lPBmx0KcBJEseDbuHn11Vdx7LHHQvWiDCVs8E/XbFIyNDdc+4VoXDMEoSyjIShJteWFgbzHpLI0aJl4upSYxk22mhsxNNS7qsTy2k1z42XfbBlZ+wWvYSmxtD4zbpq5is5iajbDzdjhs0ucBMVO7RfE9HRVUTB2UDdURII4dFgP/HPhest++bAUq9siegP4a6auxT1rMaHrNpErYNfcNKUyf4IO2Vxs/KJ+ip1zWThVNE4NzU0OPAdmlpbdc8MwC/1p/jw3ae5zvEiYYWZLJffzyHmjURYOGKEx2/h5T19KhxXXdJshqnG6s5t/tC9OHNEHFzy5AIDZxNbNGDOL+GmWrEGCKEZ8X9nHHXccGTZZwMfK2TwTdwpLcR2/AWtvGAbfI4YPbfCl6gGrdyXbIn78DbQiErRVOhaNA1nzSDfYIrpMc+OwujgJMyMkxIUsdN3aU4eNM20RP+5zvtGg6LlhT8HWOjcSzQ0Xlho/pAeWTD8ekw8aaDsmPqNmV1M01dXbukxANb93UYchwncE52HDFa8vJy9AyPAIWt9nx98i8dyI7TPMbKncaW6MOjf1pufGXMY8toTm7gXkcSqKN6hHGcrCARw2rKftM/a9MUO0NORs2ACm0Jz9XzweBj/uqtIQDh1abfvM3XNjngO+bQtBFCNkpbQx1krDmqXfj6VxZtzuOhazUayTtTUsVSkYHF0sTfuyOwbekBC9NoB9wnJKHXbcvjQs5b6+OFEZnhsuZBFNaMZ2SsIu2VIunpxSiebGlgpuqVDMG3bJz3nPDcAaaNqPi/eA7GyKSb0uIe6aETU3IppTthRYWMo6BqcsMXZMtqy5oCmQF70OYijI0NzkIizFZcTpum7Uuekp8dzw4/KUCu7wY9m/byWWTD8e1x47zPZZs1GhOPk6nUHPh/6Cqmr7nTPE7amqYrt23fbFQrXNsQT1liKKHjJu2pj6VnMC4p8iAavmJhpP2GpRGEW4Uje9WEI3J2tbWErw3HDGTi41N308GDf8ay/pt7L2C5rmLyxVltJCGE+rmmbxhJQETc1Nuro2/ARSZglLWY0Ur9lSptjZXE52WLxxw09IPHwqeF2zu+dGS5ctpTobpTxhw3NjHTRvqIhjNXqDpc7V4XtWo6o0hPF7dHcdsxf4WkZxrqM571FkhhuvB/JyLbrVVQoGkr3ERCNJrFCczrgR+4/JPLSAXHcmGodugmL2wJPQdOxI6bFyYVwSRHskq1Rwwj+85yaW0CyTTZATAVvCUiHrEz+rAMsLTpO9pcyJt6rU2XOTtXHDe24qZcaNW52bzMJS6QTFTiGSEOfiZ+czOYEoxmd+ivjJsqXE9gv8GPknf1njTGP8kuMSwzs7Gu1tBfhzywznypKgRVwcDqgpr5U8W8rUAgmeG4eJUjZ+IHneWBftlljC4j00jdPk67PGDsBPxvTPOkTKjyeuaZbjs3TeVplxY/5mvFUoTi9gDwYUy+/YMG48hr/E0GVIoq0D+HR6871IMIB6mN+1TADOKAmpxrXAKp9TWIooVshsb2NcjRtVMfQTrTHN5joWBcXsJqooyQmMFwdWCimqXSK8cZPdMfA3a1lYSpwQ+Ju3J8+NJCyV4MSUMsSJqjRsFb1aanukunczY0R0zYuuft5Y45dlxzJxv17Ys6YCx+3XyzYWWasC9h5/HmUToJhSLeuZZC3il7y2Rg3sZvn+mXGWNG5kRfySf8UQjFNYyhQUW8esKIoRmuLT2AHOi8EdZy4MG8CqueHDbhYDhKvOa3zupc6Ng7FgKdQoLNMcS1hq3KQPS1mvkaBQvoDBtsnvWxQEu3luFEUxqpaz+w6FpYhixbdxc+211+JPf/qT7f2HHnoI119/fS7GVNTwuoh4QkciYb0Jmp6bhDFBsKcrNukafZK4vlL8ZA24C4qzrlCcRnOTHIs5AfL3Wz+aGz4zyLixu4QJeMywVGri03QzUyrlffnpQQNw7D41+BFXUA2wT+rVFWGceWA/TDl0sMWrwyb3g4f0wNvTjsTBQ3rYxiITFMs8H16+k+0N9p5JIe6aqWtOXlslQdUYS3J/prEoC0sxzY3YndoxLCVohnjYZGsLS/moCuwX3hjgQ5kWjyF3DhjZpIKrgueGpyWmWa7ddNe8eI2w60/8rsTQHmD3MqbL7hLvC2TcEMWKb+PmX//6Fw499FDb+4cccgheeumlnAyqmLF4bjTdUsvCorlJeAhLCZ9bPTdiWMp8ne0TMz8pyDQ3AJcWLaQTe8qWSh2GrIif18aZRliKK83PNDfMCBw/pAeevPggDOphrTsiGjeKouCByaMw/ZT9PRkk6Yv42YXHXub87ZKwVDJbinlmzPEfMtQ0btjxarpcUCxmS8nGLntfdvxO6eCyiTlX8A0heZ0KPzzZpJ9NET+r58a6THMsYTGyAi7eFMCeTSgTPwPyKt2icZKu6KAYrqawFFGs+DZutm/fjqqqKtv7lZWV2LZtW04GVczwnptY3Fpzg/d4uIWlmOdG/NxNc8NXUvXiPXHDqrkplS7DwmsBRREmcQ8iztQysq7gTvfudHVuYgmzn47YCVmc45y6gAPWSdLpqd7aTNI+CUo1Nx4mWpnmJhhQpO0vJnBpwmw4muaUCq4Y2xK3IyMkCasxjHRwMSzlo+WBXwzROPd7CqZ+T+Yy9v16MSidsqUsnhvBcIrGreHmtJ4bx2wpuaDYGpYSjJs0ByU+9FCdG6JY8X1lDxs2DLNnz7a9/7///Q9DhgzJyaCKGUsquKaZZdMFUapVUGwNS4mtBAzjxhKWEjQ3vKA4y/sZ/1Tq5LkJc7oMq/Yh/YzCJiX+wVVPk3kiGgdlYp0bTTME2OLTqqIolonOaVIXx+80FsUhW4plV7Gx8ZkqXoy+bZKwFF+hmBEJqtirV4U5ntRfTbd3qga49gtpGogyWIp1dUXY9hkzau3ZUnYxbK4wBLhcqrv43YjXnap482A6GrDcccgMp6ZW83ee7pjt2VLWhxiGzHMjhknTHZP40ENhKaJY8Z0tNW3aNEydOhVbt241uoDPmTMH999/P2bOnJnr8RUdvHET5VLBxVoprfGEzXjhvRBTn1uExet2WdaJuIWlIrnLlmJ1RACga1lIuoyZFm0NS3kTFCf/yhpnut28A6piLCerc9MStYbxxHW11JOyW2G5gEQgbFvGoUIx++/po/ph/c4mXDhhsHQdJ7ZLBMXJDDu7IFpRFPy/C8fi0x+2o6E1jucXrHMRFKc8N6LmJigf05CeFXj2knEY3MNemK40dW7tYSnvhfP8whdqjDsUIBQ9MF6607st5xaWAsx2GeKyMizevQCfCu5coZjBGyfpQlKA/aEnF0UUCaI94tu4ueSSS9Da2orf/va3uPvuuwEAgwcPxqOPPooLL7ww5wMsNuosgmKNK+CXMlC49gvNQhVRdtPbsKsZb39ba2xH7rlx1tzk0rhxMjbYhMtrCLwKmdlyukRz47YNVQHYlGq2rDBd/C1x58JlyXOS3IlXz43zU708LMU8N72rSvCb00dY9+9hjtneKBEUc13BGWz8E/frhYn79cId//kaAOst5VznRjy3buG5I/eyV+YF+LCU1bjx0/LAL7wBG3fYj81z43FOd0oFtwqK7RtrbPWecs4bUAHOEyeG9jSJ99LquUl/ULznpiSk5ixjjSDaGxnVubnqqqtw1VVXYevWrSgtLUVFRUX6lQgA1ie6GPekKYalWmKa2fFbEBQ3CGX2ZYJiV81NlhMMb9w4wfdZYsaUV72FLCxllu93Xo83UGyeG01Dc9TqCeOxpG+7Gjf2MJN8HEm81vjxYnDKivTxqeAMcfxGar0m7y3FPleUZEgkXfsFN5yMm/wKilMGrKbZPKEM8bXXa9GLd072vTam+nMpHsJfQUGXFQokf6t8A1PA/D3w59Cv58Zq3FBIiihesvJJ9uzZkwwbn1jbL+iWppmAaYQ0xxKoTxlCYkE63kDiP7ekggt1bipyWOfmFyfsDQC48sihjsuE+VRwn54bWVjKS1iD377YbNSSCi4zblzSa3msmhv5MuGgion71mDCkB6WsJ3b8Xs5N3wBOkZIVW3jDQdEwXTKuNF1W6fp5Ofm/3njLZRByKJUIijma77kwXEjrXMjTvTi+fV6LToZeGIRP5FG1qTWU/8qq+emPHXtsgamDFlYyq/nhg9Xi0J0gigmPHluRo8ejTlz5qBbt2448MADXZ9EFi1alLPBFSOWbClNszTNBKxGyda6pIdE7C0l9hBiN6mKkiAGdE9mL3Uts4o9+e1m64oeO7g7vrlzEsojzpeP0WcpA+OGLWfR3Hh48ucnElnjTDF1nocPM4jGgWUfkjCTjP930UEAgOWb64333Dw3Xr6SVklDSr42EsPuuUn+1XRY6irJdh4MKEDq8opk4LmJSDQ3lpoveaxzE9d02++JIXqlvI7DU50byXXAunR70ZgFhW2VpX5X4kOMrNYT731xCqHx8J4bMWuQIIoJT8bNaaedhkgkmSFx+umn53M8RY+lzk3c2jQz+VdFl0gQ9a1xznOjGp8B9pseu0kFVAVvXn8EFNgbMfJhKTFkkAluhg3AtSJQuQaRHuc13tPASJctldwXZ9zIBMVunhvPYan0mhvLmLhF3CY6L0/4bPyqYoZ5ggHFXmFZNG44DVPMpbcUYNXZZBOW4rOl+O8xH0X8+Emdb7Eh0qUkZKTTezZunDw36cJSGXpuVFUxvKy2sJSstxTvufEkKDaNGxITE8WMJ+Nm+vTpAIBEIoGjjz4aBxxwALp27ZrPcRUl8YRmuWEle+HYU1crS0OGYQPwqeDJZeoEzQ0frmCVeUX4CV28aeYD9gQfUBQjfON1QlEMjYj5npkt5bwev/0yUVCs6bbUeh5+wvCuufFg3Hg0htw8UqwfEPPcRIIBw3gIckX8GOKkZVR81uTZUqrouUnhlC3lhjwsJd9XruANENaPSzbRV5YEDePG6zi8iMZdw1JePDeC5oZdu42i50ZWoZjX3PgWFJPnhihefJnugUAAxx9/PHbu3Jmv8RQ1osclGpcLIJ2qiBoVioXwxKotjWn3zYeixJtmPmAhjWRYiv3f2+XG7vUJSSq4e7aU3XPD1wwRix5a1zX/72rcSIryucE/uXv1Ookwzx1rt8EbM8GAF0Fx8q9TnRsnzY1beC7dWB3DUnmsUAzAKNQo+254r4WX7w5wqVCcLizVanrZ0u5DMJjLw3LPjSwsJWsH4gavuaHqxEQx49svOXz4cHz//ff5GEvRUy94XOKaGSbgb3BOhbacXOQyoakbbeq5Uc0KxV6jHMxI0SXGjdsNPMG5CEqY58boO6Qb3gSZ1sBpwnBbzk8TUH4s6bYrwrxx7HsOCxlYoobIyXOj6fIKxQrMfYey9NyUGNl+TmEp35tMC98J2wxL2XfET+xew2PsgUI8x2k9N1HvnhuxinVZJHkOxYehdO0XnO4PPGIqOEEUK76v7t/85je48cYb8frrr2PTpk2oq6uz/COcsRk3Cd2YkPkbpN24SX5NYclNtF/XUsw48wBf4xCzMPKBobnhw1Ien9rZzZt3MkRT4RQ3rwovuBXbL8Q1znMj2Yb3sJRPzY0q/799/86fsTAFX+uHTZpORfxk29YdekvxXws/QbrVuXGCGY4W48aSLZV7z42qmhWmW2Junhv/5RDYcqKXQ3XQ3IghJW9hKavnxtTcCMaNpAUJb8h6ERR3KQka3zeFpYhixnedmxNPPBEAcOqpp1pCHbquQ1EUJBL59wp0VNjTXJeSIOpb4ogmNONJ2i0sxZ6GxSf/Hw3vjUfPH+N7HG3iueGypZix4vVpmS3Gh1BYKM5N5MobN2y5EJcmzOoGpfPcuE3qAb+aG4+eG7dJX5yEVCVZGDGh6cn2C+mypVLjTOg6JFEpx4k6E0FxRKK5sTSRzFPRuGBARZRrWSLzpnSJcGn5PjU3ye/AzFK0tF8QvK5N0YRh3Hgx5kKCwcw8dXwhQMD0ZDrVufGqAauIJO8/FJYiihnfxs17772Xj3F0CpibuWtZyPDisAmZv0HytVHCQdWYnMS6I5k+ebWFcWOpc2OEpbwaN/awlOG5cZlwZXoSMyylQU8V+EtbxM9lH9YQQvrJ30sXccB9EhSNsWT/IRWtcc2bcWOEpez9igCrR4k3aNw8WE4wr5g1W8r8PF8FcUOqgiiA5pi1VxtPJp4bMyzl4rkRvK6bdrcYqeD+PTeqUedG1MYZRfwcQqghjzG/qtLk/SdCxg1RxPg2bvbYYw8MGDDAVitF13WsW7cuZwMrRlhl4a6lYaxDMwAY/Y74GyQvfCxxcTu355i5UaE4gzo3srAU67Pjt7Cc4bnRzLR7N0FxKKC4p2xbNDfp9+/kFXHbrkiZxLgxSwcoCAZUBFXFOD7XsJQfzU2OKhTzxefyVe4/aSAkXFPBec2N12txcHU5AGBoz3L8sM0U7js1g2W/XT+eG1G/U54mFdypK7iXVHCAnYfmdn3/IIhsyci42bRpE2pqaizv79ixA3vssQeFpVxo5Dw3DNbviL/BORXaEicbUWvRnjB6S2XQfoFPXWawsJRfHYhR4I0LAbp5btJtXyy4lg5+Dk3XF8sJexdzc9/sbySoIp6aDEWPC59aH5d4t5w1N/4NESMVnAsRynoi5RpmlLHfk8ww4x8avGp/jtyrJ9678SgAwDtLtxjvWw0SezKAH8+Ntf+YgvKUoLhR0NwYYSnu0Kx1brx7bgDKliKKG9+mO9PWiDQ0NKCkpCQngypWWFiqG1c9mKWuhiQ3SECsQJqbsFRbEOY8N+yJMpv2C8ww8Rsq4Tups4lPdlNnk1267fvV3HgNSymK4hiysYWlFAVDepYjFFDQt2uyIjUfYhCPge034SAotvbC8iasdoJdk618KriHju7Zwoy8Fhejgg9LefVyAMAe1eU2r6mTR65K8Nx4Cktx1xSvuWkSNDdGtpSD5ybk8ffFxtie7x8EkS2ePTfTpk0DkLxB3X777SgrKzM+SyQS+PTTTzFq1KicD7CYYALBipIgAilBaLPEjW4xbjjvjBjW8Pvk9ewl43DNPxbhnjNHpF84SyKc5sasUOwxQ8XQ3JjvZe250TRj4pO54w3PTZoJ3W+dG69F/IDk+eFrwjBkYalnp4xDXUsMPbskK4fz4Ut7Knjyr1MquJPoObOwlERzk7Kn8iUmBsy09Wa3bKkS/54bhltvKv6a6GoLS6Xfts1zkzJuogkN0bhmXJOyWk/8d+314WFYTQXwDTCoR1n6hQmig+LZuPniiy8AJD03X331FcJh0/sQDocxcuRI3HjjjbkfYRHB3MwVkaCR7SK7GVuMm7DzE7nfmPmRe/XEkunH56UEvgjrbVURCXJpy972a3QFlwiK/Wpu+KaKro0zvRo3Hj0xDH4STbd8QFGQgN34KA1Zf6aqoqA0HLB4dCyeG4fGmbpDET9+ns+15iaW0LBsc7JERF7DUsxzE7ML9Bl8WMrvWETDLOBgEGbiuVEUxXjY4evcAMl08HAw+VtiPwdHz43H7+vaY/fECcN7Y/++lZ6WJ4iOiGfjhmVJTZkyBQ8++CAqK+mH4ReWIVUeDiKcynYxBcXybCmroDj7sFRbGDYAcPQ+PXHbSfviqL17YtGaXcl9e9bcJP+ysJSu6748N/yEwguK2cTn1n4hnY7Ja5jJWMZjKjiQ0lJIJGulYecCcgz+Cd5Rc6PrhjDbsl9ec6M6b8cLJUIq+B/fXoFH3l/lezt+YUasISiWtl/wnwpuLC+ccyePXFWZqLnxdg7Zw05AVREKqAgHk6ntjdEEuqYcLLLeUiVCtWovhIMqhver8rQsQXRUfN+9nn76aVRWVuK7777Dm2++iebmZNaPLnGnE1bY01xFSdC4EaX13IScw1LtOdshEgzgssOHYFhNF2Mi8Fs4jV1SvAjWi3FjreBrpoK7tV/wLii26iPSwc+hsgmXx8n4E/uFyXbrZtwY7Sw0h2wph7TmTIr4iWGprzbsNj7bt08X39vzCvteXMNSnObGb6Vke1iK27dEL2eGkLxtnz24sHGzdPAmLh1cts2IJWzdfu8HBNHW+P417NixA8ceeyz22msvnHjiidi0aRMA4NJLL8X//d//5XyAxYRh3EQCxs1MVpeji0P/F3tYqmMIAv1WKDbCUqmbOd9Ly4s3Qey9BFhrhkiL+HkUFAcFfUQ6LJ6eNMfv9LmtOq7Mc+NynaicsSjvLSU3aDIJS7GxRuMaNE3H9oZko8oZZ47APy472Pf2vMI8dKz/VrpUcLE/WzrEcy4TFPN6GYbnYoGC6J4ZtHwLBk0qKPZnbBNEZ8H33ev6669HKBTC2rVrLaLiyZMnY/bs2TkdXLHBblTlkaBp3Ejq3ARUBV1Kkjc3t5tXRzFumCha7F7thBiW4kMpXkrMRyShPH6SkLZfSL3lR3PjqYifD82Nn2wpEYvnRjBKLGEpWfsF7v/BHGVLAckClawL9/59KzPanleY98RIBZd8N7ww228hS5vmRiIoDgfsHdq9hoGN1P7UtioktW6MruAWQbH/OjcE0RnwXefmrbfewptvvon+/ftb3t9zzz2xZs2anA2sGGGC4qRxY9UIiBMlqyJqEQx2UM/N4Xv1xLnjB+LkA/p4Wp5NHOxmzp6yVcVbLY+IJMOMbSuUKnrntE+3ppn8coC30IaiACP7V2F3cwzdykKuyzoZP548N0FeWCp6GZJ/NYcifvxxBC2eG/+TJX9NNscShnHDlz/IB+x7Zg8LshAgH34Tm1KmwxaWsqTPp2oNhex9vrx6bti5Zl4ZJirmPY6yIn4yQ54giAyMm8bGRovHhrFjxw5EIpGcDKpYYRWKKyJBYxKRpYIDSeNm/c5my2QhPpHLPBDtkYpIEPec4T393GgXwMJSifR9pXjCbiJsB8GwUefGl+Ym/XgURcG/rjoEmp7eMHPS3ESCKhSFz5axL2M0Vw2qtnoyASPM51TEj5uoVfuk7YeAqiAcUBFNaNje0Gp8dz0q8mvchATPTboQjV/Pjfjd8AYmbxjb0vC9em5YxWlDc5PqLxW1h6XEzvTsfFNYiiBMfN+9Dj/8cPz1r381XiuKAk3TcN999+Hoo4/OaBAPP/wwBg8ejJKSEowfPx4LFixwXPaZZ55JFTwz/3WU4oENrM5NKhUcMD034lMyy5hyFxR3DM+NX1QujAJwNW48GnMWQbFwXvk0W55M6tx4FUgHU9kv6XCaCEMB1RJmkWdLpUJ/EoOE79Ul7S1lERQ718vxCgvNbNiVTDYoCak2UXSuYb+f5qhzKjhPLj03Qe7aEX+Tnj03qfGy/RhVilv5sBQrhmhdl51vrxWKCaIz4PuOc9999+HYY4/FwoULEY1G8Ytf/ALffPMNduzYgblz5/oewKxZszBt2jQ89thjGD9+PGbOnIlJkyZh+fLlthYPjMrKSixfvtx4nc/Kp7nEFBQHjcnO9NzYw1KAVXMTUBXLE3zxGjfJvwlDcyPvmeSERVDscF5FPAuKfRTl84vTRJjsH6WAORtkHh52zDJdE1tc03V5nRthX4xMwxwloQDqW+LYuKsFANA9zyEpwJzYW126gvP4FhQLm5P1looEAzaD0LsBrFj+Ms9NU9Q9LMX2W484eW4IgsP33Wv48OFYsWIFDjvsMJx22mlobGzEmWeeiS+++AJDhw71PYAHHngAl19+OaZMmYL99tsPjz32GMrKyvDUU085rqMoCnr37m3869Wrl+/9tjV8wb5y3nMTlXtu9u6VrCM0pGeF8Z6iKJYn+GLtDcNn9wDePTdH7NUTADDl0D2M98Tz6mTcsH2mM6DEkEAucdpcOKBaDA23Ojey8Ru9unRIBcWW9gt8heIMPTfsutyY8tx0z3NICuA8Ny6NM7NBURTL92Opc8M0N8HsBcXsIadM5rmRhKUA8wGIBMUEYZKRr7iqqgq33npr1juPRqP4/PPPccsttxjvqaqKiRMnYv78+Y7rNTQ0YNCgQdA0DaNHj8Y999yD/fffX7psa2srWltbjdd1dXVZjzsT+Nh5uSUVXH4z/vkxw3DqqL4YLJRID3FP8O25zk02ZKq5+X8XjsXaHY0YyhmEoqs+necmXUaX3zo3fnCaCIMB1WKkyTw3zIsnMwDNukEOgmJuc/w5zqTOTXIsyfUM46Y8/1o8s81G8vi89lnyuw92Lco8eOGgatN0ebU3Qk6aGz4VPPXViZ5qZtiSoJggTDIyblpaWrBkyRJs2bIFmvAkeOqpp3rezrZt25BIJGyel169emHZsmXSdfbee2889dRTOOCAA7B792784Q9/wCGHHIJvvvnGlsEFADNmzMCdd97peUz5gomJQwEFkaDduBEnSlVVsEd1uW07oaAKZt1EitVzYwtLefPchIMqhtVYC8WJ55WvdcJjFvHLbYViP/BGi6qYk1kwoFiMKmlYinluJOeID0ulExRnW8QPMA0tprnpUd4WYSlBE5OHgnZ8BWmZTknmufF6jfSqLAGwG70qk4ZgeYQJiu0NSMWvhZ1vCksRhIlv42b27Nm48MILsW3bNttniqIgkfCXheCXCRMmYMKECcbrQw45BPvuuy8ef/xx3H333bblb7nlFqPpJ5D03AwYMCCvY5TB620Avlx86knQ40TCT3LF7rkRw1KZPJmK61SmC0ulMaDYOQ+oSu41N9z2wkHVuDbCAVUQMtvXZYJi2fhNTxikgmLH3lLBzI6PTbYbdyeNm3yngQP2ujZOIZr9+1bim411jjWF3HCqWTSspgKKAuzdq4vNIPTacmTGmSNw8aGDMXpgNwBmTR5ec6M5am6sYmSCIDIwbn7+85/jrLPOwh133JG11qW6uhqBQAC1tbWW92tra9G7d29P2wiFQjjwwAPx3XffST+PRCLtIkWdL+AH2CddrxNlOHXTVpTMn6zbO8zQEIv4ZVIETjytjpqb1HLp9tGlJIRbT9wXJSE159kp/JwVDqic4atYvmvZJGakgrtqbpzCUnyIJfu6KYZxkxIU5zsNHJB5buS/p8fOH4N7Zy/D5YcP8b0Pa/q3+f6oAV3x6a+ORXV5BGrK6I076GOc6FERwSEV5n3K8Ny02j03YliKnW8KSxGEie9fQ21tLaZNm5YTEW84HMaYMWMwZ84c4z1N0zBnzhyLd8aNRCKBr776Cn36eCsQVygauTRwwC50lbUEkMEm1NJQoMNkifnFCEsJ7RfCGQgmFUWxnOu0mhsPBtTlRwzBBRMG+x5LOvgnct7ICqpWz43se3fz3LA5T3cIS1k1N6bxnKlnqkvqGmffX/c2CEt5fVgY0L0MD507GiMHdPW9D4uYXPgOarqUGMYPn8WYqeiceW5kmhvRYGLXLAmKCcLEt3Hzk5/8BO+//37OBjBt2jQ88cQTePbZZ7F06VJcddVVaGxsxJQpUwAAF154oUVwfNddd+Gtt97C999/j0WLFuH888/HmjVrcNlll+VsTLli8bpd+OVLS/D3T9Zg/c4mAM6eGyctiAibfIo1DRzg69wkX0ez8NwAVm+Ek3Ezbo/uKA0FcODArhntIxfwE6ZYcZg/BlnKePfy5HHJQkAKdz7jsvYLEv1IKGAvBuiVkQOsHafbxrixjjUf+hOvrTR4A9lv93GG2X7BvYgfAPxoRB8M7lGGg4f0yGhfBFGM+A5LPfTQQzjrrLPw0UcfYcSIEQiFrJPFtdde62t7kydPxtatW3HHHXdg8+bNGDVqFGbPnm14htauXQuVu7Hv3LkTl19+OTZv3oxu3bphzJgxmDdvHvbbbz+/h5J3Hnt/FWZ/sxmzFq4z3mPGjVh/hfWSSgczijpKdeJM4LN7gOw0N0DqiTaW/L+T5uan4wbiJ2P6F7QQmqrKPTehgGpJy5ZNrEfvU4O7T9sfh+/Z075drhFpTNoV3Py/kfmTxXmYMKTa8rotjBvxewvk4XtUXTw3PJE035UX2H2irsVe50bc99ljB+DssW2vIySI9oxv4+b555/HW2+9hZKSErz//vuWpztFUXwbNwAwdepUTJ06VfqZ6CX64x//iD/+8Y++91EI+PRvBnPZhwWxptOkK2IYN0XsuWGXFAtr+C3iJ8IbRU6eG6DwFV753fOeiGBAsaQ2y7OlAo6hMraqzGsjbo+dq2yaXO7XtxKVJUFjYm4Tz41gROQjFdyz54YPS2Xoueldmay6vnl3C3RdT1aCN4ybjDZJEJ0K38bNrbfeijvvvBM333yzxaNC2JFVg2Vl1UXPjd+wVLGmgQPmJGI2zkwVOsw4LJVec9MeUB00NyE1fbaU63ZTx+9UlVdW5yaTppmMgKpg1MBu+HDFVgBtlQqeWQq2H7yWAbB6bjLbV++qpHHTHEtgV1MM3crDjmEpgiDs+P7pRaNRTJ48mQwbD7DMlCE9zXo15UIqOKPSY1jKFBQX7/nneyEBpudG1jfJC149N4XGYtzw3bmD1grFfr0BbHln48Ze5ybbzJt9epv1hrwa7tkg/p7yIa51ExTz8A8emRoiJaEAqlNZZqxeEIsoZuoNIojOhO872EUXXYRZs2blYyxFByt1f+Repg6CCQXFEIvXsFS4M4WlmObGZ1dwkVZuUm/fxo35f2u2lGI1bnxOmGxxmd5GhHlssglLAcCPhpulHHLdpkKGrc5NHh6+MvHcZGOI9O1aCgDYtDuZUk9hKYLwju+wVCKRwH333Yc333wTBxxwgE1Q/MADD+RscB0d5rkZv0d3PD13NQDzRiVWgvXagbkzZEuxiUMTivhlOuHyGSftufChtYgfny2lWkJrfjNw2PK8kcc3YOUnYHZdZdu37MCB3fD0lIMM7Ui+sXlu8mAB8Jt0+w5KcuC5AYC+VaVYsn630caCwlIE4R3fxs1XX32FAw88EADw9ddfWz4r1rormcJqipSFzdM8sHuyVxT/JN6lJOj53AUNz037naSzJdPeUk40cSXs2/M1qkjCUqqSnMzSNc70st3WuNnHTFVMTw7v5Bg7qDvOHT8QR+1lz7ryy9F712S9Da+0tebGzTGUi2wpwPTcMOOGafjawhNGEB0d38bNe++9l49xFCVxrsne2zccgdeXbMKUQwcDsE7UXkNSABeWChav54bdu40KxVl6bjoKvDfALMxmF/j6tc/MsJTY9NGeWhwOqrjnjBH+dtAOEAs85kNzo3rNlspBnRsA6Ns16fVimhuNNDcE4ZmMGmcS3mCem2BAxZ69uuCG40yRJe8291rjJrmtVFjKY0XjjojYfsEo4lfkFVh5bwAzZlhKM++Z8DthitlSQVUBr74phrMqamzyrrlxrXOTo7CU4Llx6i1FEISd4n4ULjDGk7JkUrZ4bnxkk4Q6heeGFZ1Lvs6mt1RHgh13MhTl7LnxO2GKFZ+DAdUyQbbnUJ1X2kJzYw1LuWluMhd/84iCYgpLEYR3inu2KDBMUCxmcgDWyaqy1LvnJtQpNDfJvywVvDXLCsWM9j6Hs8kzqJoCYrPuTPbZUoxQQBGq7WYy2vaFeG3kQ3NjCUt59dzkICxVW9eCWELD9sZWANmLvQmiM1C8M2Q7wAxLuXtuukS8e27265MMbe3XtzLL0bVfTE+DUKE4S89Nebh9R2ENz40KBIx6M6bBYy6X2XYZAVXxXLOloyB6avJRbdqr5yaSI89NdXkEoYACTQdW1Nbj2411AIDRg7pmvE2C6Cy077t9B4eVu5e5yIMWQbH3r+GCCYNx0gF926SkfaEwwlJiheIsJ6yydq5TYscdUBTjiT8oGDns80y2ywiqKhKaNS28o+O1K3g2ZFShOIuTq6oK+lSVYu2OJvz7iw3QdGBIdTn6VJVmvE2C6CyQ5yaPsLCU7CnSEpbyWcG1mA0bwBTWihWKs/XcsAKK7RU2X6qcZyUnYSnhtIUCiqUtQFF4bgJ271SuCXgMS1nr3GS3T1Y64oXPks13DxlGnb8Jwgtk3OQRe+qtiVjnhjARw1JGEb8MZ4rbTtoXJSEVfzh7ZG4GmCdMzY1iam4MYXEOPTc2QXFGw21XiNlR2Xr5ZGRUoThLI+vc8QMBAPWpJqSHDK12W5wgiBQ0q+YRlt0gu9HyBo+fOjedATNbSkgFz9Bzc9nhQ3DxIYML3vU7HUZYivPcyHo9+RcU2zOJ1CLT3ISD+ffcqJ6Nm9wIioFkG4sxg7rh8zU7AQAHDyHPDUF4oX3f7Tswuq4bgmLZjZDvcN2lDRoLdiSc2i9k8zTe3g0bwJw8VcUelgpmYYyIl18wYBUUF4FtI6lzk4+wlPl/t83zmYzZGlmKouC2k/ZFOKhiwpAeRR+SJohcQZ6bPMEMG8CqrzHe427GXjuCdxbEVPDOUueGXSaWsJTEc+PXThM9PUHVGpYqBs9Nm2huDOPTvTYQ77nJxbk9cGA3fHjT0RS+Jggf0K8lT8S5DsxpBcUUlrKgiGEpw3PT8SdhN8xUcDNsxDwS/LH799xYlxfr3BSBbWPz6uVDc8OHDd3IVW8pnt5VbdOAlCCKheJ+FC4gMS7VNl0qOD2RWQkYguLka8Nz0wFCS9nADI4A57lhHgn+esk2LFUSChSf50ZtS89NGuMmR3VuCILInOKeLQpIIsGHpeynmYVcAPLciIip4NFO0jiTzYMBRTHaL4QlqeCZtl9glIUDVs9NJoNtZ7RFnRve+HTDkgpeBIYjQXREinu2KCC850Z2L2yOJYz/V7TzyrltjRGWMhpnOmedFRMBbvJkhyor4ue/zo1o3ASLvs5NPrqCM4MpncFiDUvlfBgEQXiAfnp5wugrFVCk4kO+oBy5rq2wSYSdQ1ahuNg9Nwqn6TC1NixbKouu4J0iLNUGXcE5TZQbuRYUEwThH3IZ5AmjOrHDTXbUgK647tg9MaRneVsOq0PAJnRW38aoUFzkj8HG5KkoOGafGvzv60348ej+AIQifn6zpdKFpYrgtIpi83zWuSmEoJggCH+QcZMnjL5SDu5xRVFww3F7teWQOgzMQ8O0NtkW8esosHkwGFAwuLocL155iPEZb9i5pSHLEBcvC1s9N8Uw/bZJbynO+HTD2n6hGM4uQXQ8inu2KCBxl+rEhDtsIo/GNSQ03bXSczGhumTjZNN+QVy+JBQougrFQUuqfH5Cvabnxn25SJEb4QTREaBfYZ5g6cv05OYfVuE1mtCM8wgUv+cm4FJHxaK5yUG2VLFpbviimPnQ2wCmUZNWUMylgvP1rgiCaDuKe7YoIIagmIwb34QDSbd+NK4ZISmgExTxc8nG4XsnZdtbqjQUKLr2C6qqmKn0efrNZSIojnNZkwRBtB1k3OQJU3NDp9gvvOaG6W6A4hcUu1XA5b0RfuduUTBcKgqKi8C4AczfWj7SwAHvgmL+8xh5bgiiIBT3bFFAjGypIvc25ANm3MQ1Ha1c6wW/QtqOhpvnIZeam7JwUGgCWRznlXlJ8yEmBriwoY/zxYdVCYJoO8i4yROGoDhP8f9ihtfWNLbGk+8VudcG4Mr7SyZn/vhzHZYqFuOGeW4C+dLcBLyFpXhIc0MQhaH4Z4wCQYLizOEn8vqWpHETKnIxMcAV8ZNcMnx406/nRly8NBywGDTFcomGJNWcc0lGnhvS3BBEQSj+GaNA8BWKCX/w56xTeW4MzY39WPlQi1/HhDRbyqK5KY5rNGR4bvJk3Lh41pzIV4iMIAh3in/GKBAkKM4cRVGM0FRDyrgp9ho3AJdqLDlU/vj9hpHEyb6Uq3NTJHYNAK6Dep4MClPwnX7ZX56wDw4c2BXnjh+Ul7EQBOEOVSjOE0xzQ09umREJqIjGNcO46QyF0RSXbKmQpf1Cdr2l+Do3xaK3AUx9W74eKMzGpum3f9VRQ3HVUUPzMg6CINJT/DNGgYh3kk7W+YJ5bgzNTSc4j26TZ3aaG6FCMReWKibbO9+eG+P7KaJzRhDFSvHPGAWCBMXZwYybuuYYgOSEXOwEXATFvOcmW41MWcgUFCtF0VkqCasFlK/fnFsdIoIg2hdk3OQJs7cU3QgzgRk3u5lx0wnCUofvVY29elXghOF9bJ/xnqtsJ9dgQDV0I0UUlTJ+a/nz3CT/FlMojyCKFdLc5AlTc1P8k3I+YNlRdS0p4yZU/J6bfXpX4q0bjpR+xk/YuYjQmWGp4pmozQrF+dLc5NczRBBE7qCZN0/EEyxbim6EmcCaD9Y1JzU3pZ3AuHFDURTDwMmFQaIqRai58dgeIVPYT5mMG4Jo/5BxkydIUJwdhueGhaVCdB6ZoZzN5CoaAMVS4wYwQ5n5FhQXk7eLIIoVmjHyBKtMSk95mWEIijtRWCodzFDOZnJlKfWGoLiILk9m1OQrLOW1cSZBEIWHjJs8QRWKsyMcTBozpueGjJtwDowbdh6L0QthaG7yZHzsUV0OABjcozwv2ycIIneQoDhPkKA4O9hEvpuMG4PJBw3AF2t3YVhNRcbbYJ6bYqxzE8pB2M6NQ4ZW46NfHI2+XUvzsn2CIHIHGTd5ggTF2cEm4cZoAgBpbgDgFyfsk/U2mJFohqWK5/pkDxL59JYO6F6Wt20TBJE7aMbIE9R+ITvCQl2bzp4tlSvChucm+bqYLk9TcE23NYLo7NBdIE/EEtQ4MxvELuAUlsoNEaa5KULPjdFbqpgsNoIgMoJm3jyRYBWK6UabEaLnhsJSuYFVelaLUHOTi1R5giCKA5ox8kQslS1FnpvMsBs35LnJBTbPTRH1lmKp8pShSBAEzbx5ggTF2UHGTX6IFLHnJt/ZUgRBdBzIuMkTJCjODtLc5Aexzk0xaW7YsYUDdK0QRGeHUsHzhCEopsyNjKBsqfxg1LlhvaWK6PI8/cB++H5rI84a27/QQyEIosC0i1vbww8/jMGDB6OkpATjx4/HggULPK33wgsvQFEUnH766fkdYAYYgmIKS2VEhATFeYGdRxaWKibNzdCeFXj4vNHYt09loYdCEESBKfiMMWvWLEybNg3Tp0/HokWLMHLkSEyaNAlbtmxxXW/16tW48cYbcfjhh7fRSP1BguLssBs35LnJBZEgExQnX1PUlCCIYqTgM+8DDzyAyy+/HFOmTMF+++2Hxx57DGVlZXjqqacc10kkEjjvvPNw5513YsiQIW04Wu/ENRaWotkjE2yC4iAZN7mgT1UJgOLsLUUQBMEoqHETjUbx+eefY+LEicZ7qqpi4sSJmD9/vuN6d911F2pqanDppZem3Udrayvq6uos/9qCuOG5ockjE2zGTbjgdniH5sGfjsKZB/bDBRMGAeDCUnR5EgRRhBRUULxt2zYkEgn06tXL8n6vXr2wbNky6Toff/wxnnzySSxevNjTPmbMmIE777wz26H6xvTc0KScCWLGC4WlsuO0Uf1w2qh+xutirFBMEATB6FAzb319PS644AI88cQTqK6u9rTOLbfcgt27dxv/1q1bl+dRJmGeGxIUZwaFpfJLMda5IQiCYBTUc1NdXY1AIIDa2lrL+7W1tejdu7dt+VWrVmH16tU45ZRTjPc05iEJBrF8+XIMHTrUsk4kEkEkEsnD6N2JGXVuOpT92G7gjZuAqpCRmGOMVHDy3BAEUYQUdOYNh8MYM2YM5syZY7ynaRrmzJmDCRMm2JbfZ5998NVXX2Hx4sXGv1NPPRVHH300Fi9ejAEDBrTl8F2hCsXZwRfxKwmqFD7JMcVYxI8gCIJR8CJ+06ZNw0UXXYSxY8di3LhxmDlzJhobGzFlyhQAwIUXXoh+/fphxowZKCkpwfDhwy3rd+3aFQBs7xcaQ1BMnpuM4D03pLfJPWadG4IgiOKj4MbN5MmTsXXrVtxxxx3YvHkzRo0ahdmzZxsi47Vr10LtgAaCISgmz01GRMi4ySvFWKGYIAiCUXDjBgCmTp2KqVOnSj97//33Xdd95plncj+gHBCnCsVZYfXc0Ayca1jUjzQ3BEEUI+3CuCkm3lu2Bf/4dC1q61oAUFgqUyyaG/Lc5JxA6rokzQ1BEMUIGTc5Zsozn1leU1gqM3jPDTXNzD1jBnXDyP5V+PHofukXJgiC6GCQcZNnyHOTGaS5yS/dy8P4z9TDCj0MgiCIvEAzb54hz01mkOaGIAiCyBSaNfJMiDw3GUGp4ARBEESm0MybZ8hzkxkkKCYIgiAyhYybPEPGTWYoimIYOBSWIgiCIPxAs0aeIUFx5rDQFGVLEQRBEH6gmTfHlIetEzF5bjKHGTcUliIIgiD8QMZNjikNW7PrSVCcOWZYiowbgiAIwjs08+aYRKqnFIM8N5lDnhuCIAgiE8i4yTGxVDdwRlAl4yZTTOOGLlOCIAjCOzRr5Jhowuq5od49mWOEpYLkuSEIgiC8Q8ZNjokJxg2ROZGUx6Y0TMYNQRAE4R3qLZVDEpoOXU+/HOGNcw4aiKCq4OAhPQo9FIIgCKIDQcZNDiGvTW45+6ABOPugAYUeBkEQBNHBoLBUDhH1NgRBEARBtD1k3OSQWJyMG4IgCIIoNBSWyiF8GnhpKIAj9+pZwNEQBEEQROeEjJscwjQ3paEAvrjjOEtna4IgCIIg2gYybnIIM25CAYWq6hIEQRBEgSDXQg5hYSlWWZcgCIIgiLaHZuEcwjw3QWqWSRAEQRAFg2bhHMJSwUNBarlAEARBEIWCjJscEk+FpUIkJCYIgiCIgkGzcA5hYSnKkiIIgiCIwkGzcA5hYalggMJSBEEQBFEoyLjJIaxCMYWlCIIgCKJw0CycQ2KkuSEIgiCIgkOzcA6Ja6S5IQiCIIhCQ7NwDonGzQrFBEEQBEEUBjJucggLSwXJc0MQBEEQBYNm4RxCqeAEQRAEUXhoFs4hfONMgiAIgiAKAxk3OYSypQiCIAii8NAsnEMMzw11BScIgiCIgkGzcA4xjBuVwlIEQRAEUSjIuMkhRldwCksRBEEQRMGgWTiHGF3BKSxFEARBEAWDZuEcEiPPDUEQBEEUHJqFcwhpbgiCIAii8JBxk0OicQpLEQRBEEShoVk4h1BYiiAIgiAKD83COcTsCk5hKYIgCIIoFGTc5BAjLEWeG4IgCIIoGDQL5xAWlqKu4ARBEARROGgWziHUOJMgCIIgCg8ZNzmEFfELk+eGIAiCIAoGzcI5hNovEARBEEThoVk4h1BXcIIgCIIoPO1iFn744YcxePBglJSUYPz48ViwYIHjsi+//DLGjh2Lrl27ory8HKNGjcLf/va3NhytM1ShmCAIgiAKT8GNm1mzZmHatGmYPn06Fi1ahJEjR2LSpEnYsmWLdPnu3bvj1ltvxfz587FkyRJMmTIFU6ZMwZtvvtnGI7cTo8aZBEEQBFFwFF3X9UIOYPz48TjooIPw0EMPAQA0TcOAAQPw85//HDfffLOnbYwePRonnXQS7r777rTL1tXVoaqqCrt370ZlZWVWYxc57N53sX5nM/59zaEYNaBrTrdNEARBeEPXdcTjcSQSiUIPhfBJKBRCIBCQfuZn/g7mY3BeiUaj+Pzzz3HLLbcY76mqiokTJ2L+/Plp19d1He+++y6WL1+Oe++9V7pMa2srWltbjdd1dXXZD9wBSgUnCIIoLNFoFJs2bUJTU1Ohh0JkgKIo6N+/PyoqKrLaTkGNm23btiGRSKBXr16W93v16oVly5Y5rrd7927069cPra2tCAQCeOSRR3DcccdJl50xYwbuvPPOnI7biRilghMEQRQMTdPwww8/IBAIoG/fvgiHw1AUetjsKOi6jq1bt2L9+vXYc889HT04XiiocZMpXbp0weLFi9HQ0IA5c+Zg2rRpGDJkCI466ijbsrfccgumTZtmvK6rq8OAAQPyMq5YnCoUEwRBFIpoNGpIG8rKygo9HCIDevbsidWrVyMWi3Vc46a6uhqBQAC1tbWW92tra9G7d2/H9VRVxbBhwwAAo0aNwtKlSzFjxgypcROJRBCJRHI6bieiFJYiCIIoOKpKD5gdlVx52gp6BYTDYYwZMwZz5swx3tM0DXPmzMGECRM8b0fTNIuuplDENQpLEQRBEEShKXhYatq0abjoooswduxYjBs3DjNnzkRjYyOmTJkCALjwwgvRr18/zJgxA0BSQzN27FgMHToUra2teOONN/C3v/0Njz76aCEPAwlNR0KjruAEQRAEUWgKbtxMnjwZW7duxR133IHNmzdj1KhRmD17tiEyXrt2rcXF2NjYiKuvvhrr169HaWkp9tlnH/z973/H5MmTC3UIAMxMKQAIUliKIAiCIApGwevctDX5qnNT3xLDiF+/BQBYdvcJKAllLoQiCIIg/NPS0oIffvgBe+yxB0pKSgo9nA5PLBZDKBRq0326fYd+5m+Kn+QIlgYOUFiKIAiC8M/s2bNx2GGHoWvXrujRowdOPvlkrFq1yvh8/fr1OOecc9C9e3eUl5dj7Nix+PTTT43PX3vtNRx00EEoKSlBdXU1zjjjDOMzRVHw73//27K/rl274plnngEArF69GoqiYNasWTjyyCNRUlKCf/zjH9i+fTvOOecc9OvXD2VlZRgxYgSef/55y3Y0TcN9992HYcOGIRKJYODAgfjtb38LADjmmGMwdepUy/Jbt25FOBy26G1zTcHDUsVCPBWWCqgKAtRbiiAIol2g6zqaY4WpVFwaCvjK/mlsbMS0adNwwAEHoKGhAXfccQfOOOMMLF68GE1NTTjyyCPRr18/vPrqq+jduzcWLVoETUvOPf/9739xxhln4NZbb8Vf//pXRKNRvPHGG77HfPPNN+P+++/HgQceiJKSErS0tGDMmDH45S9/icrKSvz3v//FBRdcgKFDh2LcuHEAkiVXnnjiCfzxj3/EYYcdhk2bNhm16i677DJMnToV999/v5G5/Pe//x39+vXDMccc43t8XiHjJkdQGjhBEET7ozmWwH53FKb34Ld3TUJZ2Ps0++Mf/9jy+qmnnkLPnj3x7bffYt68edi6dSs+++wzdO/eHQCMkigA8Nvf/hY//elPLUVrR44c6XvM119/Pc4880zLezfeeKPx/5///Od488038c9//hPjxo1DfX09HnzwQTz00EO46KKLAABDhw7FYYcdBgA488wzMXXqVPznP//B2WefDQB45plncPHFF+e1wCLFT3KE0TST6isQBEEQGbBy5Uqcc845GDJkCCorKzF48GAAycSaxYsX48ADDzQMG5HFixfj2GOPzXoMY8eOtbxOJBK4++67MWLECHTv3h0VFRV48803sXbtWgDA0qVL0dra6rjvkpISXHDBBXjqqacAAIsWLcLXX3+Niy++OOuxukGemxxh9JWijuAEQRDthtJQAN/eNalg+/bDKaecgkGDBuGJJ55A3759oWkahg8fjmg0itLSUvd9pflcURSI+UOxWMy2XHl5ueX173//ezz44IOYOXMmRowYgfLyclx//fWIRqOe9gskQ1OjRo3C+vXr8fTTT+OYY47BoEGD0q6XDTQT5whqmkkQBNH+UBQFZeFgQf75Cbts374dy5cvx2233YZjjz0W++67L3bu3Gl8fsABB2Dx4sXYsWOHdP0DDjjAVaDbs2dPbNq0yXi9cuVKT81F586di9NOOw3nn38+Ro4ciSFDhmDFihXG53vuuSdKS0td9z1ixAiMHTsWTzzxBJ577jlccsklafebLWTc5AgjLEWZUgRBEIRPunXrhh49euAvf/kLvvvuO7z77ruWvojnnHMOevfujdNPPx1z587F999/j3/961+YP38+AGD69Ol4/vnnMX36dCxduhRfffUV7r33XmP9Y445Bg899BC++OILLFy4EFdeeaWnNO8999wTb7/9NubNm4elS5fiiiuusLRMKikpwS9/+Uv84he/wF//+lesWrUKn3zyCZ588knLdi677DL87ne/g67rliyufEEzcY5IaDpKQwHfbkiCIAiCUFUVL7zwAj7//HMMHz4cN9xwA37/+98bn4fDYbz11luoqanBiSeeiBEjRuB3v/ud0VzyqKOOwosvvohXX30Vo0aNwjHHHIMFCxYY699///0YMGAADj/8cJx77rm48cYbPTUXve222zB69GhM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",
      "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": 10,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.27802999999999994}, {'accuracy': 0.38682}, {'accuracy': 0.35936}, {'accuracy': 0.49108999999999997}, {'accuracy': 0.49036}, {'accuracy': 0.48094000000000003}, {'accuracy': 0.52866}, {'accuracy': 0.57098}, {'accuracy': 0.45470000000000005}, {'accuracy': 0.49509}, {'accuracy': 0.6365199999999999}, {'accuracy': 0.6207800000000001}, {'accuracy': 0.5393800000000001}, {'accuracy': 0.5027299999999999}, {'accuracy': 0.57019}, {'accuracy': 0.56459}, {'accuracy': 0.58594}, {'accuracy': 0.47348}, {'accuracy': 0.5419700000000001}, {'accuracy': 0.52928}, {'accuracy': 0.5988000000000001}, {'accuracy': 0.6095200000000001}, {'accuracy': 0.53711}, {'accuracy': 0.5758099999999999}, {'accuracy': 0.63217}, {'accuracy': 0.6406700000000001}, {'accuracy': 0.563}, {'accuracy': 0.51936}, {'accuracy': 0.77052}, {'accuracy': 0.5779500000000001}, {'accuracy': 0.6836399999999999}, {'accuracy': 0.60436}, {'accuracy': 0.68012}, {'accuracy': 0.65765}, {'accuracy': 0.67185}, {'accuracy': 0.70661}, {'accuracy': 0.7346199999999998}, {'accuracy': 0.68581}, {'accuracy': 0.7395}, {'accuracy': 0.53881}, {'accuracy': 0.56137}, {'accuracy': 0.62892}, {'accuracy': 0.6524599999999999}, {'accuracy': 0.7391500000000001}, {'accuracy': 0.5982}, {'accuracy': 0.5169}, {'accuracy': 0.7100700000000001}, {'accuracy': 0.51013}, {'accuracy': 0.7055100000000001}, {'accuracy': 0.68876}, {'accuracy': 0.6716000000000001}, {'accuracy': 0.62327}, {'accuracy': 0.7573399999999999}, {'accuracy': 0.7018699999999999}, {'accuracy': 0.72283}, {'accuracy': 0.45524000000000003}, {'accuracy': 0.36627}, {'accuracy': 0.4338}, {'accuracy': 0.5307999999999999}, {'accuracy': 0.7782899999999999}, {'accuracy': 0.8090399999999999}, {'accuracy': 0.61465}, {'accuracy': 0.6881600000000001}, {'accuracy': 0.72071}, {'accuracy': 0.50269}, {'accuracy': 0.56336}, {'accuracy': 0.7814800000000001}, {'accuracy': 0.59658}, {'accuracy': 0.46873999999999993}, {'accuracy': 0.5062}, {'accuracy': 0.57228}, {'accuracy': 0.6702600000000001}, {'accuracy': 0.55077}, {'accuracy': 0.7064900000000001}, {'accuracy': 0.49322}, {'accuracy': 0.5817399999999999}, {'accuracy': 0.66021}, {'accuracy': 0.64089}, {'accuracy': 0.64264}, {'accuracy': 0.55066}, {'accuracy': 0.64595}, {'accuracy': 0.49711}, {'accuracy': 0.6641}, {'accuracy': 0.73379}, {'accuracy': 0.55219}, {'accuracy': 0.6295}, {'accuracy': 0.7645500000000001}, {'accuracy': 0.5390400000000001}, {'accuracy': 0.75024}, {'accuracy': 0.5094700000000001}, {'accuracy': 0.67562}, {'accuracy': 0.65131}, {'accuracy': 0.54443}, {'accuracy': 0.75286}, {'accuracy': 0.5601499999999999}, {'accuracy': 0.6778000000000001}, {'accuracy': 0.43145}, {'accuracy': 0.62485}, {'accuracy': 0.4544}, {'accuracy': 0.57354}, {'accuracy': 0.54037}, {'accuracy': 0.42169}, {'accuracy': 0.6487200000000001}, {'accuracy': 0.52069}, {'accuracy': 0.65966}, {'accuracy': 0.56848}, {'accuracy': 0.49248000000000003}, {'accuracy': 0.5817399999999999}, {'accuracy': 0.5540200000000001}, {'accuracy': 0.54444}, {'accuracy': 0.6815200000000001}, {'accuracy': 0.40235000000000004}, {'accuracy': 0.46159999999999995}, {'accuracy': 0.5970599999999999}, {'accuracy': 0.38743}, {'accuracy': 0.74584}, {'accuracy': 0.57055}, {'accuracy': 0.60527}, {'accuracy': 0.4823700000000001}, {'accuracy': 0.58211}, {'accuracy': 0.6294799999999999}, {'accuracy': 0.64897}, {'accuracy': 0.5778}, {'accuracy': 0.64852}, {'accuracy': 0.5448599999999999}, {'accuracy': 0.74123}, {'accuracy': 0.64573}, {'accuracy': 0.6655300000000001}, {'accuracy': 0.56175}, {'accuracy': 0.49415}, {'accuracy': 0.48445}, {'accuracy': 0.5148299999999999}, {'accuracy': 0.5142200000000001}, {'accuracy': 0.7516700000000001}, {'accuracy': 0.6355999999999999}, {'accuracy': 0.5552900000000001}, {'accuracy': 0.63227}, {'accuracy': 0.65557}, {'accuracy': 0.6123}, {'accuracy': 0.6162099999999999}, {'accuracy': 0.58341}, {'accuracy': 0.5818999999999999}, {'accuracy': 0.6613}, {'accuracy': 0.65199}, {'accuracy': 0.57546}, {'accuracy': 0.8064499999999999}, {'accuracy': 0.64528}, {'accuracy': 0.6547700000000001}, {'accuracy': 0.53119}, {'accuracy': 0.40888}, {'accuracy': 0.55541}, {'accuracy': 0.58115}, {'accuracy': 0.5650000000000001}, {'accuracy': 0.6742}, {'accuracy': 0.53653}, {'accuracy': 0.497}, {'accuracy': 0.6890499999999999}, {'accuracy': 0.5768000000000001}, {'accuracy': 0.7290599999999999}, {'accuracy': 0.68397}, {'accuracy': 0.7296199999999999}, {'accuracy': 0.62882}, {'accuracy': 0.6581100000000001}, {'accuracy': 0.52393}, {'accuracy': 0.62461}, {'accuracy': 0.42279999999999995}, {'accuracy': 0.62932}, {'accuracy': 0.55848}, {'accuracy': 0.6352399999999999}, {'accuracy': 0.4979099999999999}, {'accuracy': 0.57997}, {'accuracy': 0.51412}, {'accuracy': 0.438}, {'accuracy': 0.64436}, {'accuracy': 0.5614699999999999}, {'accuracy': 0.61273}, {'accuracy': 0.56469}, {'accuracy': 0.7163}, {'accuracy': 0.7220200000000001}, {'accuracy': 0.6264299999999999}, {'accuracy': 0.4992599999999999}, {'accuracy': 0.6585099999999999}, {'accuracy': 0.54203}, {'accuracy': 0.49078}, {'accuracy': 0.46963}, {'accuracy': 0.4652200000000001}, {'accuracy': 0.47472999999999993}, {'accuracy': 0.70833}, {'accuracy': 0.56127}, {'accuracy': 0.56727}, {'accuracy': 0.4934}, {'accuracy': 0.62516}, {'accuracy': 0.6052600000000001}, {'accuracy': 0.67584}, {'accuracy': 0.69036}, {'accuracy': 0.6049100000000001}, {'accuracy': 0.67275}, {'accuracy': 0.55689}, {'accuracy': 0.51897}, {'accuracy': 0.5866200000000001}, {'accuracy': 0.81986}, {'accuracy': 0.82433}, {'accuracy': 0.82295}, {'accuracy': 0.818}, {'accuracy': 0.8229200000000001}, {'accuracy': 0.82036}, {'accuracy': 0.82105}, {'accuracy': 0.8220699999999999}, {'accuracy': 0.81702}, {'accuracy': 0.81304}, {'accuracy': 0.8235300000000001}, {'accuracy': 0.82377}, {'accuracy': 0.8061400000000001}, {'accuracy': 0.8236899999999998}, {'accuracy': 0.8254699999999999}, {'accuracy': 0.8254300000000001}, {'accuracy': 0.8187199999999999}, {'accuracy': 0.8189399999999999}, {'accuracy': 0.81802}, {'accuracy': 0.8222999999999999}, {'accuracy': 0.8211299999999999}, {'accuracy': 0.81699}, {'accuracy': 0.8243300000000001}, {'accuracy': 0.8219}, {'accuracy': 0.81989}, {'accuracy': 0.81714}, {'accuracy': 0.8193999999999999}, {'accuracy': 0.8182600000000001}, {'accuracy': 0.81889}, {'accuracy': 0.82415}, {'accuracy': 0.81616}, {'accuracy': 0.81753}, {'accuracy': 0.8185499999999999}, {'accuracy': 0.82026}, {'accuracy': 0.8241400000000001}, {'accuracy': 0.8156800000000001}, {'accuracy': 0.8262500000000002}, {'accuracy': 0.8229600000000001}, {'accuracy': 0.82096}, {'accuracy': 0.81828}, {'accuracy': 0.82415}, {'accuracy': 0.82201}, {'accuracy': 0.8172600000000001}, {'accuracy': 0.8152999999999999}, {'accuracy': 0.82196}, {'accuracy': 0.8219099999999999}, {'accuracy': 0.82179}, {'accuracy': 0.82508}, {'accuracy': 0.81389}, {'accuracy': 0.8208399999999999}, {'accuracy': 0.82305}, {'accuracy': 0.81898}, {'accuracy': 0.81978}, {'accuracy': 0.8192999999999999}, {'accuracy': 0.82021}, {'accuracy': 0.82309}, {'accuracy': 0.8225200000000001}, {'accuracy': 0.81393}, {'accuracy': 0.8199799999999999}, {'accuracy': 0.81921}, {'accuracy': 0.8192499999999999}, {'accuracy': 0.8167500000000001}, {'accuracy': 0.8188599999999999}, {'accuracy': 0.8234199999999999}, {'accuracy': 0.8159599999999999}, {'accuracy': 0.81913}, {'accuracy': 0.82196}, {'accuracy': 0.81663}, {'accuracy': 0.82345}, {'accuracy': 0.82134}, {'accuracy': 0.81837}, {'accuracy': 0.81662}, {'accuracy': 0.8208200000000001}, {'accuracy': 0.8213700000000002}, {'accuracy': 0.8204}, {'accuracy': 0.8153500000000001}, {'accuracy': 0.82088}, {'accuracy': 0.82294}, {'accuracy': 0.8230299999999999}, {'accuracy': 0.8183}, {'accuracy': 0.81884}, {'accuracy': 0.82241}, {'accuracy': 0.8181499999999999}, {'accuracy': 0.8140699999999998}, {'accuracy': 0.8219799999999999}, {'accuracy': 0.81922}, {'accuracy': 0.8210200000000001}, {'accuracy': 0.82409}, {'accuracy': 0.8217599999999999}, {'accuracy': 0.8222799999999999}, {'accuracy': 0.82284}, {'accuracy': 0.8168599999999999}, {'accuracy': 0.8150000000000001}, {'accuracy': 0.8203400000000001}, {'accuracy': 0.8175699999999999}, {'accuracy': 0.8198400000000001}, {'accuracy': 0.82187}, {'accuracy': 0.81814}, {'accuracy': 0.8180400000000001}, {'accuracy': 0.8170400000000001}]\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": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b038631a-8c56-436e-81a9-bcf7c4bf36c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c14e55f4-784b-4906-b9f0-413e44b11b08",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfb5119e-99b7-4966-8fc7-4365f3ba66b7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2890e933-2503-44d2-9dfe-1f60a144c8f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5eff440-6906-4efb-af71-dcf4760c2902",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef2f4fd0-f4af-471f-8b84-ebe39e75ea92",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f0552ac-2abb-4e6c-8490-28cd65685242",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0b1a48d-4f16-42b9-a3ec-28162ae8cdf1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81da3426-a31e-4ad9-923f-868dd4028a77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f95c2a56-f436-4396-af05-3adb87376b5e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d79c07bd-cf82-4d25-a38c-a7a9db607012",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b98fc0e-d2d8-42e1-80c3-7e5a0d1d0977",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cd54fb9-aa79-40cf-bb29-d8f0966ea334",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b800465-b3e4-4aa5-b189-47046060d821",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e28e00d9-cf9b-42c7-a8df-8277eaa868f3",
   "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
}
