{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 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",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\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_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e954128-4fd2-47cc-8c67-ab75f6023977",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n",
      "4938\n",
      "[[  0 536]\n",
      " [  1 495]\n",
      " [  2 491]\n",
      " [  3 504]\n",
      " [  4 505]\n",
      " [  5 513]\n",
      " [  6 564]\n",
      " [  7 460]\n",
      " [  8 495]\n",
      " [  9 541]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], 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,50000,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": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4827"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([9, 7, 3,  ..., 4, 2, 1])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1964\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 462]\n",
      " [  1 428]\n",
      " [  2 507]\n",
      " [  3 446]\n",
      " [  4 509]\n",
      " [  5 484]\n",
      " [  6 509]\n",
      " [  7 509]\n",
      " [  8 495]\n",
      " [  9 455]]\n",
      "[[  0 462]\n",
      " [  1 434]\n",
      " [  2 507]\n",
      " [  3 454]\n",
      " [  4 509]\n",
      " [  5 506]\n",
      " [  6 509]\n",
      " [  7 509]\n",
      " [  8 495]\n",
      " [  9 570]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 7, 3,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 9,
     "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,50000,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,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if target1[z]==1:\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(9))\n",
    "        \n",
    "        elif target1[z]==9:\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(1))      \n",
    "        \n",
    "        elif target1[z]==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",
    "            noiseyset[1].append(torch.tensor(5))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==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(3))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[1][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[1][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": null,
   "id": "e5839d5a-b137-4a0c-bf96-66260d8811d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.11816000000000002}, {'accuracy': 0.13774}, {'accuracy': 0.14138}, {'accuracy': 0.14372000000000001}, {'accuracy': 0.18658000000000002}, {'accuracy': 0.16155}, {'accuracy': 0.15092}, {'accuracy': 0.20074999999999998}, {'accuracy': 0.21320999999999998}, {'accuracy': 0.21951}, {'accuracy': 0.23991999999999997}, {'accuracy': 0.27503}, {'accuracy': 0.19283}, {'accuracy': 0.24159999999999998}, {'accuracy': 0.25227}, {'accuracy': 0.2278}, {'accuracy': 0.29636}, {'accuracy': 0.26563}, {'accuracy': 0.28465999999999997}, {'accuracy': 0.35985999999999996}, {'accuracy': 0.33459}, {'accuracy': 0.3029700000000001}, {'accuracy': 0.36629000000000006}, {'accuracy': 0.35940000000000005}, {'accuracy': 0.3677}, {'accuracy': 0.33772}, {'accuracy': 0.34967000000000004}, {'accuracy': 0.37198000000000003}, {'accuracy': 0.35562000000000005}, {'accuracy': 0.38315}, {'accuracy': 0.37789}, {'accuracy': 0.38448}, {'accuracy': 0.36933000000000005}, {'accuracy': 0.37433000000000005}, {'accuracy': 0.35998}, {'accuracy': 0.38409}, {'accuracy': 0.39531000000000005}, {'accuracy': 0.3428}, {'accuracy': 0.41798}, {'accuracy': 0.39367}, {'accuracy': 0.41534999999999994}, {'accuracy': 0.40939000000000003}, {'accuracy': 0.41292999999999996}, {'accuracy': 0.40490999999999994}, {'accuracy': 0.44237000000000004}, {'accuracy': 0.37795000000000006}, {'accuracy': 0.43659}, {'accuracy': 0.40602}, {'accuracy': 0.42389}, {'accuracy': 0.472}, {'accuracy': 0.44798}, {'accuracy': 0.45926999999999996}, {'accuracy': 0.45687999999999995}, {'accuracy': 0.45731}, {'accuracy': 0.48562000000000005}, {'accuracy': 0.44489999999999996}, {'accuracy': 0.46892999999999996}, {'accuracy': 0.46395}, {'accuracy': 0.47706}, {'accuracy': 0.47736999999999996}, {'accuracy': 0.48894000000000004}, {'accuracy': 0.5036700000000001}, {'accuracy': 0.47079000000000004}, {'accuracy': 0.50606}, {'accuracy': 0.47025999999999996}, {'accuracy': 0.45962}, {'accuracy': 0.50003}, {'accuracy': 0.48912999999999995}, {'accuracy': 0.51254}, {'accuracy': 0.48767999999999995}, {'accuracy': 0.51418}, {'accuracy': 0.5274300000000001}, {'accuracy': 0.5146300000000001}, {'accuracy': 0.50851}, {'accuracy': 0.5149799999999999}, {'accuracy': 0.52508}, {'accuracy': 0.51776}, {'accuracy': 0.5322300000000001}, {'accuracy': 0.5334}, {'accuracy': 0.52851}, {'accuracy': 0.53171}, {'accuracy': 0.53934}, {'accuracy': 0.52315}, {'accuracy': 0.5207600000000001}, {'accuracy': 0.5182800000000001}, {'accuracy': 0.5361299999999999}, {'accuracy': 0.5397700000000001}, {'accuracy': 0.52708}, {'accuracy': 0.5447}, {'accuracy': 0.5450200000000001}, {'accuracy': 0.55348}, {'accuracy': 0.54977}, {'accuracy': 0.56463}, {'accuracy': 0.5445800000000001}, {'accuracy': 0.53825}, {'accuracy': 0.52617}, {'accuracy': 0.54469}, {'accuracy': 0.5375399999999999}, {'accuracy': 0.53949}, {'accuracy': 0.54895}, {'accuracy': 0.56315}, {'accuracy': 0.5503399999999999}, {'accuracy': 0.55087}, {'accuracy': 0.54661}, {'accuracy': 0.55143}, {'accuracy': 0.54851}, {'accuracy': 0.54481}, {'accuracy': 0.5437399999999999}, {'accuracy': 0.5716599999999998}, {'accuracy': 0.55701}, {'accuracy': 0.5578200000000001}, {'accuracy': 0.55065}, {'accuracy': 0.5666800000000001}, {'accuracy': 0.54599}, {'accuracy': 0.55002}, {'accuracy': 0.55819}, {'accuracy': 0.56048}, {'accuracy': 0.56422}, {'accuracy': 0.5594}, {'accuracy': 0.57704}, {'accuracy': 0.54923}, {'accuracy': 0.54844}, {'accuracy': 0.554}, {'accuracy': 0.55827}, {'accuracy': 0.5658299999999999}, {'accuracy': 0.56199}, {'accuracy': 0.5756}, {'accuracy': 0.55751}, {'accuracy': 0.58433}, {'accuracy': 0.56838}, {'accuracy': 0.5590400000000001}, {'accuracy': 0.57509}, {'accuracy': 0.5852299999999999}, {'accuracy': 0.5641299999999999}, {'accuracy': 0.5781}, {'accuracy': 0.5589000000000001}, {'accuracy': 0.5663199999999999}, {'accuracy': 0.5659700000000001}, {'accuracy': 0.5660399999999999}, {'accuracy': 0.5568000000000001}, {'accuracy': 0.5747899999999999}, {'accuracy': 0.5757100000000002}, {'accuracy': 0.5574399999999999}, {'accuracy': 0.56298}, {'accuracy': 0.56005}, {'accuracy': 0.5579}, {'accuracy': 0.5728500000000001}, {'accuracy': 0.56961}, {'accuracy': 0.57282}, {'accuracy': 0.56221}, {'accuracy': 0.5620399999999999}, {'accuracy': 0.56726}, {'accuracy': 0.5443899999999999}, {'accuracy': 0.5651900000000001}, {'accuracy': 0.5615699999999999}, {'accuracy': 0.5822499999999999}, {'accuracy': 0.57105}, {'accuracy': 0.5694100000000001}, {'accuracy': 0.56497}, {'accuracy': 0.56782}, {'accuracy': 0.5789899999999999}, {'accuracy': 0.57572}, {'accuracy': 0.5632}, {'accuracy': 0.57657}, {'accuracy': 0.57405}, {'accuracy': 0.58102}, {'accuracy': 0.5833299999999999}, {'accuracy': 0.56644}, {'accuracy': 0.55622}, {'accuracy': 0.5686899999999999}, {'accuracy': 0.55964}, {'accuracy': 0.5593300000000001}, {'accuracy': 0.57357}, {'accuracy': 0.5819099999999999}, {'accuracy': 0.567}, {'accuracy': 0.5636099999999999}, {'accuracy': 0.5601900000000001}, {'accuracy': 0.5745199999999999}, {'accuracy': 0.5685200000000001}, {'accuracy': 0.57924}, {'accuracy': 0.5878599999999999}, {'accuracy': 0.58219}, {'accuracy': 0.5621499999999999}, {'accuracy': 0.5834400000000001}, {'accuracy': 0.5730099999999999}, {'accuracy': 0.57551}, {'accuracy': 0.5636599999999999}, {'accuracy': 0.5879399999999999}, {'accuracy': 0.56457}, {'accuracy': 0.54027}, {'accuracy': 0.56917}, {'accuracy': 0.57042}, {'accuracy': 0.55183}, {'accuracy': 0.5765100000000001}, {'accuracy': 0.57322}, {'accuracy': 0.58883}, {'accuracy': 0.59586}, {'accuracy': 0.5992200000000001}, {'accuracy': 0.59339}, {'accuracy': 0.59688}, {'accuracy': 0.59179}, {'accuracy': 0.6062900000000001}, {'accuracy': 0.59997}, {'accuracy': 0.6070599999999999}, {'accuracy': 0.5975699999999999}, {'accuracy': 0.6007800000000001}, {'accuracy': 0.6065}, {'accuracy': 0.6094900000000001}, {'accuracy': 0.6087}, {'accuracy': 0.60004}, {'accuracy': 0.60362}, {'accuracy': 0.5893299999999999}, {'accuracy': 0.60115}, {'accuracy': 0.5949099999999999}, {'accuracy': 0.59779}, {'accuracy': 0.6045400000000001}, {'accuracy': 0.6071799999999999}, {'accuracy': 0.6090399999999999}, {'accuracy': 0.6044700000000001}, {'accuracy': 0.60504}, {'accuracy': 0.60754}, {'accuracy': 0.6062000000000001}, {'accuracy': 0.60858}, {'accuracy': 0.60754}, {'accuracy': 0.60327}, {'accuracy': 0.60017}, {'accuracy': 0.60823}, {'accuracy': 0.5928500000000001}, {'accuracy': 0.58773}, {'accuracy': 0.58956}, {'accuracy': 0.60044}, {'accuracy': 0.60638}, {'accuracy': 0.5967800000000001}, {'accuracy': 0.60298}, {'accuracy': 0.60633}, {'accuracy': 0.6013599999999999}, {'accuracy': 0.6049499999999999}, {'accuracy': 0.6097499999999999}, {'accuracy': 0.6084700000000001}, {'accuracy': 0.6069500000000001}, {'accuracy': 0.60442}, {'accuracy': 0.6033000000000001}, {'accuracy': 0.60557}, {'accuracy': 0.60657}, {'accuracy': 0.60085}, {'accuracy': 0.6031799999999999}, {'accuracy': 0.60447}, {'accuracy': 0.6051}, {'accuracy': 0.60489}, {'accuracy': 0.6073999999999999}, {'accuracy': 0.6043999999999999}, {'accuracy': 0.6064200000000001}, {'accuracy': 0.60703}, {'accuracy': 0.60616}, {'accuracy': 0.60768}, {'accuracy': 0.60658}, {'accuracy': 0.6030200000000001}, {'accuracy': 0.60806}, {'accuracy': 0.60716}, {'accuracy': 0.6050699999999999}, {'accuracy': 0.6035}, {'accuracy': 0.6049900000000001}, {'accuracy': 0.6090699999999999}, {'accuracy': 0.6072500000000001}, {'accuracy': 0.60612}, {'accuracy': 0.60829}, {'accuracy': 0.60641}, {'accuracy': 0.6041400000000001}, {'accuracy': 0.60357}, {'accuracy': 0.60307}, {'accuracy': 0.59248}, {'accuracy': 0.6053200000000001}, {'accuracy': 0.6037100000000001}, {'accuracy': 0.60496}, {'accuracy': 0.60677}, {'accuracy': 0.60673}, {'accuracy': 0.60514}, {'accuracy': 0.60701}, {'accuracy': 0.59904}, {'accuracy': 0.60463}, {'accuracy': 0.5957000000000001}, {'accuracy': 0.59097}, {'accuracy': 0.60192}, {'accuracy': 0.60793}, {'accuracy': 0.6074799999999999}, {'accuracy': 0.6071500000000001}, {'accuracy': 0.60504}, {'accuracy': 0.60727}, {'accuracy': 0.6079100000000001}, {'accuracy': 0.60625}, {'accuracy': 0.60454}, {'accuracy': 0.60553}, {'accuracy': 0.60755}, {'accuracy': 0.60695}, {'accuracy': 0.60529}, {'accuracy': 0.60442}, {'accuracy': 0.6068}, {'accuracy': 0.60649}, {'accuracy': 0.60743}, {'accuracy': 0.60729}, {'accuracy': 0.60368}, {'accuracy': 0.6073500000000001}, {'accuracy': 0.6071}, {'accuracy': 0.6061599999999999}, {'accuracy': 0.60545}, {'accuracy': 0.6034200000000001}, {'accuracy': 0.60185}, {'accuracy': 0.59947}, {'accuracy': 0.6066900000000001}, {'accuracy': 0.6055699999999999}, {'accuracy': 0.60702}, {'accuracy': 0.60533}, {'accuracy': 0.60418}, {'accuracy': 0.6065699999999999}, {'accuracy': 0.6068}, {'accuracy': 0.6021699999999999}, {'accuracy': 0.6055599999999999}, {'accuracy': 0.60329}, {'accuracy': 0.60486}, {'accuracy': 0.6036699999999999}, {'accuracy': 0.60404}, {'accuracy': 0.60538}, {'accuracy': 0.60406}, {'accuracy': 0.60349}, {'accuracy': 0.6029799999999998}, {'accuracy': 0.59764}, {'accuracy': 0.59294}, {'accuracy': 0.5900399999999999}, {'accuracy': 0.5925800000000001}, {'accuracy': 0.60265}, {'accuracy': 0.59639}, {'accuracy': 0.5841000000000001}, {'accuracy': 0.5903400000000001}, {'accuracy': 0.6064}, {'accuracy': 0.60339}, {'accuracy': 0.6029800000000001}, {'accuracy': 0.60705}, {'accuracy': 0.60871}, {'accuracy': 0.6103}, {'accuracy': 0.60431}, {'accuracy': 0.60838}, {'accuracy': 0.60784}, {'accuracy': 0.61021}, {'accuracy': 0.6108100000000001}, {'accuracy': 0.60247}, {'accuracy': 0.6032799999999999}, {'accuracy': 0.60809}, {'accuracy': 0.6104099999999999}, {'accuracy': 0.60778}, {'accuracy': 0.60907}, {'accuracy': 0.6079899999999999}, {'accuracy': 0.60606}, {'accuracy': 0.60963}, {'accuracy': 0.60768}, {'accuracy': 0.60687}, {'accuracy': 0.5949700000000001}, {'accuracy': 0.60765}, {'accuracy': 0.60723}, {'accuracy': 0.59649}, {'accuracy': 0.6071000000000001}, {'accuracy': 0.5920799999999999}, {'accuracy': 0.60255}, {'accuracy': 0.6085200000000001}, {'accuracy': 0.60651}, {'accuracy': 0.6020800000000001}, {'accuracy': 0.6112}, {'accuracy': 0.6090300000000001}, {'accuracy': 0.61063}, {'accuracy': 0.6076900000000001}, {'accuracy': 0.6094699999999998}, {'accuracy': 0.61026}, {'accuracy': 0.61019}, {'accuracy': 0.60854}, {'accuracy': 0.60738}, {'accuracy': 0.6073200000000001}, {'accuracy': 0.6091700000000001}, {'accuracy': 0.6082500000000001}, {'accuracy': 0.60533}, {'accuracy': 0.6068100000000001}, {'accuracy': 0.6075699999999999}, {'accuracy': 0.60941}, {'accuracy': 0.60904}, {'accuracy': 0.60799}, {'accuracy': 0.60833}, {'accuracy': 0.60842}, {'accuracy': 0.6041799999999999}, {'accuracy': 0.60711}, {'accuracy': 0.6086600000000001}, {'accuracy': 0.6068}, {'accuracy': 0.5983400000000001}, {'accuracy': 0.6022100000000001}, {'accuracy': 0.60422}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB3bklEQVR4nO3dd3hTZfsH8G92upLuSelmFwpUsGyhgOJEVMQBIuBAFMQBOHC9ipMfKAqIL+AG5QW3IFZA9i57rzK6S3ebtMn5/ZHmNGnSSduk5fu5rlwm55ycPKepnLv3cz/PIxEEQQARERFRKyF1dAOIiIiIGhODGyIiImpVGNwQERFRq8LghoiIiFoVBjdERETUqjC4ISIiolaFwQ0RERG1KgxuiIiIqFVhcENEREStCoMbImpSGzduhEQiwcaNG8VtjzzyCMLDwx3Wptbk9ddfh0QicXQziJwKgxsiJ3fkyBE89NBDCAkJgUqlQnBwMB588EEcOXLE0U1rcp999hmWL1/epJ9x9OhRvP766zh//nyTfk5zeuedd/DTTz85uhlEDsPghsiJrV69Gj169EBSUhLGjx+Pzz77DBMmTMCGDRvQo0cPrFmzxtFNbFLNFdy88cYbDG6IWhG5oxtARPadOXMGDz/8MCIjI/Hvv//Cz89P3Dd16lT0798fDz/8MA4ePIjIyMhma1dRURHc3Nya7fNaAv5MiJwLMzdETuqDDz5AcXExPv/8c6vABgB8fX2xePFiFBUV4f333wcArFq1ChKJBJs2bbI51+LFiyGRSHD48GFx2/Hjx3HPPffA29sbarUa8fHx+OWXX6zet3z5cvGckydPhr+/P9q0aQMAuHDhAiZPnoz27dvDxcUFPj4+uPfeexstAxIeHo4jR45g06ZNkEgkkEgkGDRokLg/NzcX06ZNQ2hoKFQqFaKjo/Hee+/BaDRanWfFihXo2bMnPDw8oNFoEBsbi/nz54vXd++99wIAbrrpJvFzLOuDqnrkkUfg7u6OM2fOYMSIEfDw8MCDDz4IADAajZg3bx46d+4MtVqNgIAAPP7447h69arVOfbs2YPhw4fD19cXLi4uiIiIwKOPPirut1enBADnz5+HRCKpMZslkUhQVFSEL7/8UryeRx55BABQUFCAadOmITw8HCqVCv7+/hg6dCj27dtX7fmIWiJmboic1K+//orw8HD079/f7v4BAwYgPDwcv//+OwDg1ltvhbu7O3744QcMHDjQ6tiVK1eic+fO6NKlCwBTHU/fvn0REhKCmTNnws3NDT/88APuuusu/O9//8PIkSOt3j958mT4+flh9uzZKCoqAgDs3r0b27Ztw/333482bdrg/PnzWLhwIQYNGoSjR4/C1dX1mq5/3rx5ePrpp+Hu7o6XX34ZABAQEAAAKC4uxsCBA3H58mU8/vjjaNu2LbZt24ZZs2YhNTUV8+bNAwCsX78eY8aMwZAhQ/Dee+8BAI4dO4atW7di6tSpGDBgAJ555hl8/PHHeOmll9CxY0cAEP9bnfLycgwfPhz9+vXDhx9+KF7r448/juXLl2P8+PF45plncO7cOSxYsAD79+/H1q1boVAokJGRgWHDhsHPzw8zZ86Ep6cnzp8/j9WrV1/Tz8vs66+/xsSJE9GrVy889thjAICoqCgAwBNPPIFVq1ZhypQp6NSpE7Kzs7FlyxYcO3YMPXr0aJTPJ3IKAhE5ndzcXAGAcOedd9Z43B133CEAEPLz8wVBEIQxY8YI/v7+Qnl5uXhMamqqIJVKhTfffFPcNmTIECE2NlYoLS0VtxmNRqFPnz5CTEyMuG3ZsmUCAKFfv35W5xQEQSguLrZpz/bt2wUAwldffSVu27BhgwBA2LBhg7ht3LhxQlhYWI3XJgiC0LlzZ2HgwIE229966y3Bzc1NOHnypNX2mTNnCjKZTEhJSREEQRCmTp0qaDQam7Zb+vHHH23aV5Nx48YJAISZM2dabd+8ebMAQPj222+ttq9du9Zq+5o1awQAwu7du6v9DHs/M0EQhHPnzgkAhGXLlonbXnvtNaHqP+Vubm7CuHHjbM6r1WqFp556qg5XSdSysVuKyAkVFBQAADw8PGo8zrw/Pz8fADB69GhkZGRYdWesWrUKRqMRo0ePBgDk5OTgn3/+wX333YeCggJkZWUhKysL2dnZGD58OE6dOoXLly9bfc6kSZMgk8mstrm4uIjPy8rKkJ2djejoaHh6ejZ5N8ePP/6I/v37w8vLS2x/VlYWEhMTYTAY8O+//wIAPD09UVRUhPXr1zd6G5588kmbNmm1WgwdOtSqTT179oS7uzs2bNggtgkAfvvtN5SVlTV6u2ri6emJnTt34sqVK836uUTNjcENkRMyBy3mIKc6VYOgm2++GVqtFitXrhSPWblyJeLi4tCuXTsAwOnTpyEIAl599VX4+flZPV577TUAQEZGhtXnRERE2Hx2SUkJZs+eLda8+Pr6ws/PD7m5ucjLy2vgldfNqVOnsHbtWpv2JyYmWrV/8uTJaNeuHW655Ra0adMGjz76KNauXXvNny+Xy8XaI8s25eXlwd/f36ZdhYWFYpsGDhyIUaNG4Y033oCvry/uvPNOLFu2DDqd7prbVZv3338fhw8fRmhoKHr16oXXX38dZ8+ebfLPJWpurLkhckJarRZBQUE4ePBgjccdPHgQISEh0Gg0AACVSoW77roLa9aswWeffYb09HRs3boV77zzjvgec8Ht888/j+HDh9s9b3R0tNVryyyN2dNPP41ly5Zh2rRpSEhIgFarhUQiwf33329T1NvYjEYjhg4dihdffNHufnMg5+/vj+TkZKxbtw5//vkn/vzzTyxbtgxjx47Fl19+2eDPV6lUkEqt/zY0Go3w9/fHt99+a/c95qJwiUSCVatWYceOHfj111+xbt06PProo/joo4+wY8cOuLu7Vzspn8FgaHCbAeC+++5D//79sWbNGvz111/44IMP8N5772H16tW45ZZbruncRM6EwQ2Rk7rtttuwZMkSbNmyBf369bPZv3nzZpw/fx6PP/641fbRo0fjyy+/RFJSEo4dOwZBEMQuKQDisHGFQiFmOhpi1apVGDduHD766CNxW2lpKXJzcxt8zqqqu8lHRUWhsLCwTu1XKpW4/fbbcfvtt8NoNGLy5MlYvHgxXn31VURHRzfa7L5RUVH4+++/0bdvX7vBYFU33ngjbrzxRrz99tv47rvv8OCDD2LFihWYOHEivLy8AMDmZ3nhwoU6taWmawoKCsLkyZMxefJkZGRkoEePHnj77bcZ3FCrwm4pIif1wgsvwMXFBY8//jiys7Ot9uXk5OCJJ56Aq6srXnjhBat9iYmJ8Pb2xsqVK7Fy5Ur06tXLqlvJ398fgwYNwuLFi5GammrzuZmZmXVqn0wmgyAIVts++eSTa84uWHJzc7MbLN13333Yvn071q1bZ7MvNzcX5eXlAGDzc5NKpejatSsAiN1A5vlprjUou++++2AwGPDWW2/Z7CsvLxfPf/XqVZufW1xcnFWbwsLCIJPJxNohs88++6xObbH3czMYDDbdhf7+/ggODm6WLjGi5sTMDZGTiomJwZdffokHH3wQsbGxmDBhAiIiInD+/Hn897//RVZWFr7//ntxmK+ZQqHA3XffjRUrVqCoqAgffvihzbk//fRT9OvXD7GxsZg0aRIiIyORnp6O7du349KlSzhw4ECt7bvtttvw9ddfQ6vVolOnTti+fTv+/vtv+Pj4NNrPoGfPnli4cCH+85//IDo6Gv7+/hg8eDBeeOEF/PLLL7jtttvwyCOPoGfPnigqKsKhQ4ewatUqnD9/Hr6+vpg4cSJycnIwePBgtGnTBhcuXMAnn3yCuLg4cbh3XFwcZDIZ3nvvPeTl5UGlUmHw4MHw9/evV1sHDhyIxx9/HHPmzEFycjKGDRsGhUKBU6dO4ccff8T8+fNxzz334Msvv8Rnn32GkSNHIioqCgUFBViyZAk0Gg1GjBgBwNQtee+99+KTTz6BRCJBVFQUfvvtN5taqJp+bn///Tfmzp2L4OBgREREoH379mjTpg3uuecedOvWDe7u7vj777+xe/duq+wbUavg2MFaRFSbgwcPCmPGjBGCgoIEhUIhBAYGCmPGjBEOHTpU7XvWr18vABAkEolw8eJFu8ecOXNGGDt2rBAYGCgoFAohJCREuO2224RVq1aJx5iHgtsbtnz16lVh/Pjxgq+vr+Du7i4MHz5cOH78uBAWFmY1DPlahoKnpaUJt956q+Dh4SEAsBoWXlBQIMyaNUuIjo4WlEql4OvrK/Tp00f48MMPBb1eLwiCIKxatUoYNmyY4O/vLyiVSqFt27bC448/LqSmplp9zpIlS4TIyEhBJpPVOix83LhxgpubW7X7P//8c6Fnz56Ci4uL4OHhIcTGxgovvviicOXKFUEQBGHfvn3CmDFjhLZt2woqlUrw9/cXbrvtNmHPnj1W58nMzBRGjRoluLq6Cl5eXsLjjz8uHD58uE5DwY8fPy4MGDBAcHFxEQAI48aNE3Q6nfDCCy8I3bp1Ezw8PAQ3NzehW7duwmeffVbTV0DUIkkEoUp+lIiIiKgFY80NERERtSoMboiIiKhVYXBDRERErQqDGyIiImpVGNwQERFRq8LghoiIiFqV624SP6PRiCtXrsDDw6PRpl0nIiKipiUIAgoKChAcHGyztltV111wc+XKFYSGhjq6GURERNQAFy9eRJs2bWo85roLbjw8PACYfjjmlZSJiIjIueXn5yM0NFS8j9fkugtuzF1RGo2GwQ0REVELU5eSEhYUExERUavC4IaIiIhaFQY3RERE1KowuCEiIqJWhcENERERtSoMboiIiKhVYXBDRERErQqDGyIiImpVGNwQERFRq8LghoiIiFoVBjdERETUqjC4ISIiolaFwQ0REVErVVpmcHQTHOK6WxWciKilKNSVw00pq9MqyOScDEYBq/ZeRLsAD3Rv6wUASM0rwWcbzuBoaj7euKMzuoRoAQCr9l6CIAi4Nz7U6hz6ciOU8vrnIuauP4lFG89gamIMzmQW4sHeYegSosGfh9JwMacYHYI0SOzo3yp/vySCIAiObkRzys/Ph1arRV5eHjQajaObQ0RO5mJOMcYt3QUvNyWeG9oOfaJ9qz1WEAR8tf0Csgp1eDaxHaRSibh96+lshPm4ItTbFQBgNArIKymDl5uyTu3Yl3IV93++A+0C3LFgTA+E+7pd+8XVQBAE/N/6k1ApZJg8KAoAkFmog7+Hukk/tzUrMxgx/YcD+PXAFfh5qLB2an9czi3BtJXJOJtZBAC4t2cbfHBvN/x28AqmfLcfAHBLl0C4KuV4YmAkcor0eOi/O3FXXAjeG9VV/B2rzom0AihkEkT6uSPm5T9QZrC+xfu4KZFdpBdfT+ofgVm3dMS57CK8++dxdG/rifF9IuCilEEQBLy/7gTW7LuMzsEaTOgfAXeVHHklZegcrIW3mxJnMgtxOqMQwzoFNHmQVJ/7N4MbIrquZRbocDqjEAlRPgCAJ7/Ziz8PpwEA3FVyJM8eCrnM/l/Nn244jQ/WnQAAfDOhN/w1Knyx+SyK9Qb8djAVSpkUL9/aEeP6hGP6D8n4OfkK/pzaH+0CPGpt17Mrk7Fm/2UAgNZFgS/GxeOGcG9xvyAIdm8mO85mY9uZbEweFAVdmRF7U3IQ7OmChRvPQKNWYPrQdli29RyWbT2Pe+Lb4Plh7eGmkmPb6Sw88MVOAMC4hDCk5BRj48lMvDyiIyb2j6yxrWczC2EwCoj2d8fhy/nQuijQ1sfV6phzWUUYu3Qn3JRyxId74a64EEgkwPyk0zibWYh37+6KfjG+KNEbMOfPY1DIpBh9QyjaBXigzGDE6YxC6MqNWL3vEiQARvZog5ScYhxLzUdsiBbDOwdCVuXGX6Qrh1wmQU6RHhdzStArwvTzyyspw5XcEkT4ukGtkNX6XTREaZkBU77bh7+PZdR4XPsAD3z/2I0Y+P4GFOjKrfYpZBKr4GRk9xA8P7w9tp7OwtrDabgh3BsP3dgW/57MQr9oX5Qbjej73j8QBOCrR3vh/iU7YO8O7++hQq8Ib/x2MBUA0K2NFifTC1FS0YXVO8Ib8+6Pw8dJp/H9rhS77e4YpMGLw9vjyW/3orTMiEn9I/DSiI5NGuAwuKkBgxsiEgQBs38+Al25AXsuXMXZzCIsG38DNGoFRi3cZnXsumkD0D7QNhjZcTYb93++Q3w9tFMATqYX4EJ2sdVxcqkE22YORq93kgAAE/pF4NXbOgEAdOUGTPpqL0K9XPD2yFh8tf08Vu6+iHmj43Dnp1tRrK+sl3BTyrB22gAoZFK88esR/HM8A58+0AOJnQIAmG6m57OLcM/C7SjUlSPMxxWpeaXQlxut2uPrrkJWoU58fVN7P3wx7gZM/nYv1h1Jt/vz+mRMd9zeLVh8nV9ahsLScgRq1Hj5p0P4ftdFAEC7AHecTC9EsFaNrTMHW93o3lt7HAs3nrH6uShkUvGGqpRLsfDBHvjfvkv441Ca1bYf91zC2iNpVm3yclUgt6RMvHnH+LtjYv8I3NMzFDKpBIW6cgz6YAMEAdCVG1GoK8fTg6PRLsADz/14APpyI27tGoRJ/SMhl0rEriHAlGU7dDkP7QI84KKse/Dz4boT2HQyE1+Mi8cPuy/io/UnoZJL0dbbFacyCsXjFDIJPrinG6atTIZUArwwvAPeW3sc7QM8IEDA2cwidAnRIvlirs1nhHi6QFduFL/DYK0aV/JKMbRTAG7pEojpPxywOt5VKcNnD/ZAkc6Ap7/fhwhfN6x4LAF+Hir8b+8lvPLTYfE7qM4DvdvCaBTw495LYubGnmXjb8BN7f3r/POqrxYV3Hz66af44IMPkJaWhm7duuGTTz5Br169qj0+NzcXL7/8MlavXo2cnByEhYVh3rx5GDFiRJ0+j8ENEeUU6dHjrfVW20b1aAN3lQxfbr+Au7uH4FJuCXady8F7o2JxV/cQqOSVN7nSMgNunvcvzmcXo2OQBsdS820+4+bOgUjLL0XyxVzc07MNVu29BACYclM0nh/eHgDw56FUPPntPgBA0nMDMeSjTQBMN6RivQFtvV2xdlp/PPTFTuxLyUWXEA2yC/VIzSsFAPSP8cWCMT0w589j+OXAFatgyMzPQ4XMAh2CtWoIgPhewBQ86MuNGNopAEnH0mEUgKduisJX2y+goLQcCZE+2H42G65KGRY+1BN9o3wgl0kxYv5mnEgvQO8Ib2w7kw0AkEhglSWY2C8CBaXleHtkF8hlUtwyfzOOpeZjfN9wnMkswr8nMwEA3dt6okRvwPG0Aqt2e7oqkFtsexNN7BiAv49ZB2FaF4V4wx0dH4p3R8Vi48lMjF+22+b91ekUpEFpuQFPDIjCX0fT8PexDET6uuE/d3VB70gfm6yQPeEzfwcAdAv1RGpuCTIKdPjw3m4oMxgxa/UhAMDjAyPx+IAoeLsp0fudv5GeXxlovnpbJzzQqy1KywzQuCjEgHNcQhhuiQ2yCqbtub1bMH49cMVqW99oH3w78UYApi7XAI3aqn7nYk4xfj+UCqkEuLtHG/y45xLeW3scANC1jRbTh7bDoIqApdxghEwqwcs/HcZ3O00ZnZ5hXgjzdsXq/Zfx2IBIPDesHaZ+n4wJ/SOsMo2NoT73b4cWFK9cuRLTp0/HokWL0Lt3b8ybNw/Dhw/HiRMn4O9vG/3p9XoMHToU/v7+WLVqFUJCQnDhwgV4eno2f+OJqMW6fLXEZluxvhw7zppu1LfEBmH7mWzsOpeDGf87hP/8dgz/PD8Ifh4qAMDW01k4n10MX3cVVj5+I+5fvANHU/PhppThi3E3IFCrRpi3K/637xKSL+aKgQ0Aq6zJ9orPA4BpK5It2mIKUu7p2QauSjnm3heHW+ZvxuHL1kHU5lNZGPThBly1CAK0LgqEervg8OV83No1CJ/c3x0n0gsQ4uWCdYfT8MKqgwBMGaS4UE9MXbEf64+agoXhnQPwwvAOmNAvElmFOkT6uuGh/+7EjrM5GLd0FzxdFZjUPxJHK4K5bWeyIZUA79/TDe0C3PHiqoNikPLFlnMAgMEd/dGtjSeOpeZDIgGeHhwDF4UMT367F9mFeiwZGw+NWoFnvt+PtUfS4O2mxDsjYzGkoz9m/3xYzAq9cmtHjO8bAZlUgv9uOYe3fjsKAFgzuQ8ifd3x7a4L+HDdCazccxF+HioYLSKtaYkx0Loo8M4fx1BmENArwhu6ciMOWGRGzNf04v8OitvOZhXhgS92wttNiTG9QvH8sPZiNspoFLB6/2X0jfZBkNbFKkNmPq+vuwp3dAtGdlHldz6hbwS8K+quurbxFH/2Uglwe7cguChlYrZowQM9sOtcDuLDvaCSyxCkVVsFp1WZA8bhnQPELFynoMogwFz/ZSnU2xVPDIwSXz/aLxznsgqhdVHg+eHtrYJ6c/fsg73bisHNG3d0xtHUfKzefxkHLuZi1v8OYe2RNOw+n4PNM26Cq9IxYYZDg5u5c+di0qRJGD9+PABg0aJF+P3337F06VLMnDnT5vilS5ciJycH27Ztg0KhAACEh4c3Z5OJqBW4nGsb3JjrbFRyKfpF+6JQVxkwFOjKsf5oOgQIGNWjDbZXZCuGdvKHRq3A0kduwNHUPNwQ7g0PtUJ8321dg/HOH8esgo8rFTcnQRDwz/HKeoxDl/Ns2jQ2IQwAEO7rhq8n9MLzPx5Aer4Oy8bfgBdWHcDFnBJcLS5DqLcL3h/VDV3baCGVSFBSZsDmU5m4uUsgpFIJOlbc4O7qHoJPN5zGxaslGNWjDToFayCXSvDKT4cxqL0/3h7ZBQDg7aYUb8CfPdgT7/15HH8dTcPV4jKxxggA4kI98dKIjmIty9ppA/Dmr0exdOs58ZizmUXIq7j+rm08xfMuH9/Lqm7o0wd7YOe5bHQO1kLrYvoZzrm7K8b3jcDlqyUY1N5PPHZMr1D8ezIT4T6u4gikyYOi4aqQ4fVfj2LBhtPi578/qivuu8E0+ighygd/H03HmF5t8cfhNKvgxl0lx4jYQOy9cBVRfu54OCEMvx9Mxdojacgp0uPTDWdwZ1yIWC/17a4UvPrTYQRq1Njx0hBkFNgGHWMTwqCUSxGkdcF3E3tDIZfCX1NZoB0XWhnc3NY12KZ4WyGToq9FQXu4j1uNwU1eSRk0ajneurOLGNyE+dSvEF0ll+H9e7rVeEznYC3mjY6Di1KGLiFayGWm72XnuRwAgEwqwf+NjnNYYAM4MLjR6/XYu3cvZs2aJW6TSqVITEzE9u3b7b7nl19+QUJCAp566in8/PPP8PPzwwMPPIAZM2ZAJrPfL6rT6aDTVUbN+fm26WMiat0EQcCZzCJE+rpBKpXgip3gxqxvtK/pH+1grdX2l9aYuhX2nL+Kk+mm7MSNkaYi5ECtGoFa21FFLkoZnhkSgzd+PSpuS8szffbZrCJcqpJB8nRVYGjHAPy49xIm9Y+Ap2vlyKr4cG8kPTcIRfpyaNQKDG7vjy+3XwAAfDfxRqu/yl2UMtwZF2LTHoVMih+eSEBWgR6dgk0Bzy2xQbi5S2C1haDebkq8d09XvFneGZ1nr0O50ZQR6RyswU9P9bU5Pq6tJ7C18vWRK3liQHNjpHU3heVnyqQS9ImyHZnWLsDDpgDbVSnHl4/ali88UpHZefXnI+K2GyIqP7NDoAYdAk3XPbJ7CP46koYuIVo8m9gO5Uajzc24f4wf/nNXF4xfvhubT5mKeM1tSaroGkvLL0WJ3oC0iqAj1NsFX4y9AZeuFmNgOz/xXPZG3T10YxjS8krRKViDu3vYfl9Vhfu6idm++DAv7Llw1eaYLiFa+GvUeGZIDDYcz8BtXYNqPW9D3NW9sr3Rfu5QyaXQVWSvnk2MwQCLa3cEh03il5WVBYPBgICAAKvtAQEBSEtLs/ues2fPYtWqVTAYDPjjjz/w6quv4qOPPsJ//vOfaj9nzpw50Gq14iM0NLTaY4modfo46TQS527CV9vPA7DO3Chk1jf1++LbAAAi/dwR4ulic641+y+LXRgJFcFNTR7sHYYOFgXJqbmmm+BhO5maftG+mH17Jyx4oDtevLmDzX6ZVAJNRWboiUFRuLlzIL6d2Ntud0N1/D3UYmBjVpcRLiq5zGo4ettqPrN7qKfV66NX8nG6opg2xr/2UWLX6uGEcNwVZyp+dlHIEO5jv53uKjm+ntAbM27uAKVcWm2WQS6T4vaupvOZs3sAUG4ximnHuWyk5Zu+10CNGu0DPTCkY0C1o+zMtC4KvHVXF4zp1daq+6c6Eb6V19IrwhtudoqdY/zdAQDTh7bDr0/3swqQm4pcVhnYAMDYPuFN/pm1aVEzFBuNRvj7++Pzzz9Hz549MXr0aLz88stYtGhRte+ZNWsW8vLyxMfFixebscVE5GhZhTr8398nAQCv/3oUr/9yBN/uNGU8nhwUhd+e7g9f98obwPDOgQBMgcSayX0woV+EzTkFAYjyc7PqYqiOUi7F6sl9sPnFmwCYurgKSstwpuKG372tp3jsgBg/eKgVuK1rMBS13BiDtC5Y9HBPq26Lphbt5y4+ry64aePlgjvjgsXrOpddhIOXTIFclF/TztVj9u6orpg8KAqfPti9UYYmJ3YKgEwqwbHUfJzLMs1PY87eAcDmk1li5iZQaxsQN5Zwiy6mcB83RPm72xwTU4dpBpqCeW6k0fGhYgDuSA4Lbnx9fSGTyZCebl31np6ejsDAQLvvCQoKQrt27ay6oDp27Ii0tDTo9Xq771GpVNBoNFYPIrp+fLH5nNXr5dvOo7TM9Fdm91BPtA/0wNsjY9ExSINfp/Szuhn6a9TVjvi4L77uWWBXpRyh3q7QqE3ZgbS8UpzONAU3wzpV/nvXL6b5ApWGiAmovJlWly2SSCSYf393rJncF4EaNQTBNNMyALs346agVsjw4s0dMLhDQO0H14G3mxJ9KuZB+mn/ZeQW65FRYF0YLgY3GlWjfKY9EZaZMx9Xu/MlxTTTz7iqKYOjsfjhnvhPRd2WozksuFEqlejZsyeSkpLEbUajEUlJSUhISLD7nr59++L06dMwGivTXydPnkRQUBCUyqZPvRFRy5N0zP7cLQAQ4mX6K3t450D8ObU/YttobY5p42X/L/HxfW0zOrUJrujmupJXijMZpgxAhyAP/PFMf6yZ3Efc76yiLW6cYdV091jqGeYlPvf3UDnFX/QNNaqHqbtyzf7LOFFl2Pq5rEKx0DegDtm8hmrr4yp2o4b7uOGpm6Lx+IBI3NS+sr7FUZkbV6UcwzsH1ppxbC4ObcX06dOxZMkSfPnllzh27BiefPJJFBUViaOnxo4da1Vw/OSTTyInJwdTp07FyZMn8fvvv+Odd97BU0895ahLICInll2oEydPM9+cLNmrqanpmCCtGmMTwvDXswMatNaPueg4JadY7N6I9nNHp2CNOOrHmUVZdEuFetUe3FhO/NfUy0c0tWGdA+CqlCElp1gcDdY/xhcyqQSlZUYcuJQLwNRd2FRUchk+uKcb3rqzMwK1akT4umHWiI5wVVXWC3nXcXmP1s6hQ8FHjx6NzMxMzJ49G2lpaYiLi8PatWvFIuOUlBRIpZX/gISGhmLdunV49tln0bVrV4SEhGDq1KmYMWOGoy6BiJzY7vOmoantAzww+/ZO8FDLoVbIsGiTaaZc85Djmni6Vh4T7OmCN+9seNq9Y5AGG09k4vudKdAbjFDJpXUKsJyFOXOjlEnFrFdNbupQmVEoqrK0QEvjqpRjVI82+HrHBXGY9Y2RPkjJKcaF7GJx5Fugtum6pQDrUUpmvSO88fvB1DpNNHi9cPiq4FOmTMGUKVPs7tu4caPNtoSEBOzYUfMsjUREALDjrCm46RXhDa2LAq/f0RlGowClXIpIX7c6FZtaHqO8xpT7rbFBWLjxjDjaKtLPvdaFEJ2JWiHDzpeGQALUqftBJZdhUv8ILNl8DpMHRTd9A5vYs0Pb4ZcDV5BXUoYIXzc82jcCO8/lWC250ZQFxdUZ06stBAHNWlzu7Jyjc4yIqIq/j6Zj+spkFJTaX8fm6+3nMfHLPSitYV2c/SmmeUB6Wcx1IpVKMH1oO7t/AVfH/P6Hbgyr83vs6RysQYBFwWnviMadnr45BGjUdRolZjbzlo74e/pAjIi1P1CkJfF2U+K9UbHo1kaLj+/vDhelDGEWhdUBGhWC7cx31NQUMinG9Qm3qom63jk8c0NE10YQBAgCWlQGoC4mfrUHAOChluMNO11Bi/89i0tXS7Av5ardyd8AiF0FlrUiDfHFuHicSCtAfNi11cVIJBLcf0NbzE86hR5tPfHize2v6XwtgUwqaVU33Zu7BOHmLpUT41kWVveP8WvSVbGp7hjcELUghbpy/HUkDYmdAqBRKyAIAkYv3oECXTl+ndK31knDWopifWV9xpbTWXaPMS+qaG9xRcC0uGV2kWmKiKBr/Gtao1Y02iKATw6KQpcQLfpG+zh0enpqHJZzz/R38qH815PW8S8h0XVi9s+HMf2HA5i+MhkAkJ6vw67zOTiWmo8rudWvOdMYDEYBBqNQ+4EVdp7NxqPLd4uz09bH0SuVy6Sczy7GsdR83LNwG35OvgwAKDMYxblTqgtuMipWW1bJpVZFwY6mVsgwtFMAA5tWom2VzA05B/7fRdSCrN5nurn/fcy04OIJi1lSc0v0aIu6T8NfH4IgYORnW1GoK8e6aQNqLSZNzSvB6M9Nhf+hXi52u5XWHk7Dks1nMfe+bjaL+1kuImkwChi1cBuK9QbsuXAVd8aFIK+kMqC5Wmx/As/UijWcgj1d2FVATSbG3x1PDoqCj8Vio+R4DG6IWhC5VCIuXAgApyyCG3MXTFPILy0Xp9A/kVaALiG2k91ZmvPHcfF5VjXteuKbvQCA99eewKcP9rDaV3WF7GJ9ZdGwIAjItQhoLAMdS6l5lWv9EDUViUSCGXbWASPHYrcUUQviUmWhPMuZUs9kFGLbmSwIQt27juoqu7ByqvlLV4utnifO3YQvt50XtxmNAv49lSm+zrWTWSk3VM4ybi84MS8q2TnYdrmUtPxSq66oq9UET+bg5lrrbYio5WFwQ+QEDlzMxRu/Hqk2C2HmahHcGI0CTlrUs/zn92N4YMlOrLVYubix5FgEEGcyi8TnP+y5hNMZhXjtlyNIyyvFxZxi/HYo1Sr4SM/XoSrzukoAoFZY/zNUZjDibMVn2Ftr6VR6odX5c+38zC7mFGNfxTDwQAY3RNcddksROYE7P90KwLTa9Ot3dLbZ/8/xdKw/ar1GUlahzqpbyuy3Q6m4JTbIaltOkR6LNp3B5asl+Oi+blArZDbvq0m2VXBTGZhkWiwe+PE/p7DheIaYMQnxdMHl3BKk59kWOh+8WNntlJZvvf9CdhHKjQLclDJ0Cbbt/nph1QGrBQOrZoZKywy4fcEWMQAKakEzABNR42BwQ+RETtoJVgDg0eV7bLbtS8m1qkUxU9lZ8+i+xdvFUUv33RCKge3qN6oju7AygDhrkbk5axHorNl3GSUWE+rd1i0IizedRYGuHEW6crhZrH9jXocHgDjKq7TMgNGf7xADtih/d/i6205ln56vs8oGVR0tlVmgs9oWxJobousOgxuiJlBaZoBCJq33Wi/2ApPqamjM3S5Vyat8ZoneYDUc2zLbois3YOKXe9Ah0AOCYBp2/dmDPWwWhcwpqnzP2cxCCIIAiUSCs1mVgU5JlZmCb4sNxjfbL6BIb0BGgQ4RFsHNEYuh3jlFepToDTh4KRcHLuaK26P93OHrXvvok6tVgpuqwQ67pYiuPwxuiBpZid6AAR9sQIinC356qm+tx1sW19rrLqquDic5Jdfu9qo3+6xC65oXy+DmwMU8bD6Vhc2nKifKO3Ap12bCOstuqfzScqTll8JNJRfPJZGYutQA04ytH9zTDbFttAjQqHE2qwjp+aWIsFgV+mJOsdX5U/NKkFFg3c4of3f42MncVJVXohcDwOSLuUi36Oa6qb0f2gd6VPdWImqlWFBM1MgOX8lDZoEOyRdza1z3yCzLosvH3gzDF3NK7L4vuSLLUXUtm6rBTEaBdU2LZXBjngvGkr1J9yy7pQDg8a/34nDF0HB/D5XVqKaeYV7iWkz+FesopeeXIrdYD325ESX6ypmD/TxM+6/kluJKrnVbov3d4emigGUi6tDrw3BLF+s1isoMArKL9Hhk2W6M/GwbnvhmHwDTelDLxveq0wKPRNS68P96okZm2SlU9YZtj2XwUWhnkUjLodeW9BUZn05VhktXDUQyq2REMi2CH3uzGp/OMHU7XcwphrFiTh3zaKmJ/SLg7abEwUt5eOv3YwCASD83hHlXZmVCvSwXEjQFXkev5CNhzj94+L87cbniZ+KukqNDRVblSl6JuN0s2t+0Yra3mykAUsmlcFfJEe5rPeEfACzdcg6bTmZabfN0cZ5ZiYmoeTG4IWpkBaWV6yKZg4dtp7Nw76JtdguGMyyKYy3fC5gyK7vP26+tMetUZURRSk4x3vnjGBZtOoOvtp/HjrM5VvszLYIpc+bmrrhgPD04GgBwKqMQi/89i/7vb8DKPRcBVHZL9YvxxXPD2gEAjqWa6mbaBXhYLR4Y6m0b3Pyw5yJKygzYeS4HpzNMP4MQTxeEVIxkupBdhMtXK4ObvtE+4po95robHzclJBIJInxsg5ujqfk225xpyQUial6suSGysGb/JUT7eSC2Tc0z8NYk3yL7Ys7cPPDFTgDA1BXJ+HNqf3F/XnGZ1Y3Z8r0legNu+3iLzczD7iq5uK4SALQLsF1x+fN/z9psi/F3x6mMQqtMjrl9N0R4o12ABz755zTOZBTi34osyOyfD+P3g6liIOPrrkLPMC+8vOaweI5H+oRj9/nKACrUq3LotXl2YMs6oKSKpSNCvFzQo60XVuy+iB/2XIJ7RcHxsvE34Kb2/uLxPhXBjVfF1PYRfrbBTUqObXbL05VT4RNdr5i5Iaqw7UwWnl15ALcv2FLjcav2XsKucznV7s+3KACu2tVi2U2lKzfgzk+3YO76kxbvrQxaDlzKtbukQpcQjdXEd8F1nMfF3H11IbsYvx9Mha7cIGaWgrUuiPZzt2lzmUGwWpXb200JD7UCY3q1BQBMuSkakX7uaGvZLWWRuYn2tw281h9Lr2i3Gnd1D0GIpwsyC3Q4VzHyqk2V6/Gp6JYyr9tjuQqzRm0KiC7ZqUvSsluK6LrF4IaognntJKD64ddnMgvx/I8HMOW7fdWeJ9+qW8r6pmtZ3Prz/is4n22dcbDM3Oy9UH13lOUkdoEaNZ5NbIfeEd5WN/QNzw9CgKZytFGnIFNwU24U8NR3+zBr9SFcsVhc0stNWevQa3OAMfu2TvhuUm9MH2rqooryd4NUYsoqBVjMK2PZTjPzUO0QT1co5VJMqegOM6sarPlYdEsBpm4qL1cFVHIp4tp6AaisP7LE4Ibo+sXghqiCrqzyBmlvcjwAOFcxgV1Ggc4qELFk1S2VV2IVKJnnsSkzGLH43zM27y3WG1BWcaO2DG4s57/RlxutAgg/DxWmJsZg5eMJVsPGw31cxYAGAKL83KG0CK5W77tsMYuv6Xx9o22XO7BkHqruopShT5QvpBVDmfw91Fj4UE98Pran1dw+ARoVPNT2e79DKrqv7unZBqHepueergqryf4AoFsbTwAQF+uUSCTYMmMwdswaYjNSzBJrboiuXwxuiCrkllR2AVUdcWRm2WWTkm1/FJNl19KV3FKrehPzjf+jv05ardFkqbC0HEajIE7St/SRePz17ABxv67cCG+LepLqhjpLJBKrkVT+GpXdDAcAaNSmQGDufXH47el+eG9UrNV+X3clvpnQ2+57zYZ3DkSfKOvgSCKR2O2aAiAWEytkUjw9OAaAqS6oqru6h2DHrCGY0C9C3OamksPLTQltlQDGcgJDTxfW3BBdrxjcEFWw7ELKKrJd7BGwDm6qTkRnZpm5OZdVhB5vrRdfF5SW4UxmIRZtMmVtPnuwByb1j0CkRZFsfqmpyDi3uAwquRT9ov0QZlFnois3YmyfMABA/yoLS45NMG03dxe1D7QIbjxqn6lXJpWgS4gWA6oszzCpf6TdRSzrwkNdGYDcGRcMF4UMEb5u6BhU2WV1b882WPBAd7w3qqvdcwRq1ZBIbGd79qpSNGz5c2Tmhuj6xdFSRBVSLRZ4zKkuc2MxXPlCdcFNDSt755aUYduZbADAjZHeGBEbhBGxQXj51k5ImJOE1LxS5JeU48e9piHYgzv4i0sh3N0jBKv3XcaUm6LROViLf1+4SZwkz+ylER1xS5cg3BBuqkUxFwkDptqVh28Mw9c7LmD+/XGI8HXDU9/tw/03tLVpZ9WgwVxr0xCW3VLz7+8Oo1GARAKrYEUikeC2rsH1PnfVuWwifd1xMt00CSFrboiuXwxuiABkF+qsMjfZdcjc2Bt+DFTOVTOyewh+O3gFZYbKmhtBADadMA2z7lFRDGumUSuQmleKtPxSrNl3GQDwQO/KwOP9UV3x1E3RiKyYxK6txdwyZmqFDAlRPuLrTsEaTB0SA09XBRQyKV4a0RFjE8IQU1Hou/nFwXavQa2QQa2QorSiDsneApZ19WxiDP4+mo4He5uyStJ6rrdVk6rDvS2LkZm5Ibp+Mbih6966I2l4/Ou9Vtuy6lBzU1u31P03hOLW2CBM/Mp6Re8NJ0zzvHQL9bTabs5wrN53CQW6crT1dkVfixoWuUyKKD/79Ss1ebaiiwowFQLH2BnBZI+Xq1LMZl1L5iba3wMHXhtmd92sa1U1gPGxGO3lruI/b0TXK9bc0HVv4UbbUUv2CopLywxWE+BtPpWFDcczsPFEBh78Yoc48665oFjjokB8uJfNeQwVSxrEVQluNBXdKH8eTgMA3NY1qFGzHPVl2TV1LcENYH9B0MZgGdwoZVJxuDgAuzU6RHR94J82dN0r0pXbbLPXLWXOYliugD1++W5x/wNLdmLnS0PEzI2HWl7tLLmBGrXVcG6gckI6s6GdAup+EU3Ay60ycPCpZf4bR7EMwDzUctzeLRhLt55DQqRPDe8iotaOwQ1d14r15TiTWfsq2EDlApZRfu6I8XcXMyxmGQU6/LjnEvTlpjoVcybmmwm98VPyZWQW6MTFHc2rZluyDIT8PFTi/C6OYm6Pi0IGV6Vz/lNhWTTsoZbDTSXHX88OdGCLiMgZsFuKrmtHr+TDKJgmm/tlSl8seKA7ACCr0DZzYx6FE+XnhoUP9cTqyX1sjvnP70cBmLI77hUBQb8YX3x4bzerUUOWhcKW2zpWTLp3X3wbh3ZJARDn0rnWLqmmpFbI4FLR5WU55JyIrm/O+ecYUTPIKCjFzNWHAACxIZ7o2sZTnGTPvKZTTpEeu8/nILFjAI5XLB7ZoWLumO6hnogN0eLQ5Tz83+humP3zEXHpBQ+V3CY4sZwduLedzE27AA/88Uw/XMkrFRecdCSvinoWZ+2SMvN0VaAkzwCNC/85IyIT/mtA163ZPx3B6QxTNqZHmCeAyiHPOUV66MoNmLYyGf+ezMSsWzrgWJopuDFnVyQSCZaMjcfxtHwMau+PU+mF+KyiONneylRTE2OQVaTHM4Ojqy12lUgk4sy9jmZehduZMzeAqfssNa8UHipmbojIhMENXbfOZ5uWPxjYzg+P9AkHAPh7qODnoUJmgQ57L1zFvxU1MnPXnxQDFsv1mgK1agRWrG/01E3ROHwlH/+ezLRbLxPm44avHu3VZNfT2IZ0CMCvB67g/htCHd2UGpkn8qtuDSsiuv7wXwO67pToDZBITAXAADBrRAexYFYikaB/tC9W77+MzaeyxPfoKoqE3ZQytPGyn1lxU8nx1aO9cPhyHkK9bSfYa2na+rhi9eS+jm5GrcyjulhzQ0RmLCimVuuvI2m4/ZMtOJleIG4rLTPg9gVb0O+9f5BTUVdTdc0l8xpKm09l2pyzQ5Cm1kLfLiFaTv3fjMzfn6+Hc3efEVHzYeaGWq3HKmYdnvPHMSwbb+oOWr3vslhnAwAKmUQsnDXrF20Kbg5fzrc554AYP5tt5FiTBkTC201pd40sIro+MXNDrVK5wSg+L9IZAJhmBl78r/VsxH7uKpviXn+N2m5Rb79oX0y+KaoJWkvXIsTTBc8MiXH6wmciaj7M3FCrdDytsivKvaLQNCWnGBeyrdeD8qtmyHWEr5u4jlSgRo05o2LRJ8oHChn/HiAicnYMbqjVOHw5D6/9cgQeajn6W3QfpeeXWv3Xkr+H/dWuw3xcseW06Xmotwtuau/f+A0mIqImweCGWoWrRXqM+XwHCirWiUq+mCvuMwc1GQW2sw5XF9xE+LqJz/2qOYaIiJwTc+zUKhxPKxADGwDILS4Tn2cV6qEvN4oregdoKoOVqiOlzMJ8KoMb88R+RETUMjC4oRZFEAQYjLbz/16pqI9RySt/pePDvMQlDzIKSpFRUFqxvXLpA+9qlhaI8K2cp4bBDRFRy8LghlqUCV/uwU0fbkSJ3mC13Vz8e0e3YET5uUEuleDV2zohQGsKTNLySpGZb8rcdA6pnGHYclSVpTZelcGNzMELWBIRUf2w5oZajNIyA/45ngEAOJaWjx5tvVBmMGLV3ktijU0bL1e8eHMH5JWUIdrfHYEaNS7mlCAtv1SsuQnwUCPa3x2nMwoxuIP9QmF1xUrTAMRVp4mIqGVgcEMthjk7AwAp2cXo0dYLCzeewdz1J8XtwZ5q+FWsDwUAARVDvdPySsWaG3+NCj8/1Rc5Rfoal0l4664u+OtIGkY7+dpKRERkjcENtRgXcyrnqEmpeP7bwStWx4RUWfcpqGJRywOX8sSaGz8PFdxUcripav71f/jGMDx8Y9g1t5uIiJoXa26oxbh4tTJzY56MTym3/hWuOrPw8M6BkEiAXw9cwdWKEVTVjZAiIqLWgcENtRiXLDI3F3OKIQgCLmRZzzgcqLUOXOLDvTGpf6T4WiGTwJOLWhIRtWoMbqjFuHjVulsqNa/Uam4bAFDJbYt/nxvWDh2DTCOkfN1Vta7qTURELRuDG2oxUiwyN2n5pTh4Kc9qf9c2WrvvU8ll+Pj+OARr1bi5S2CTtpGIiByPBcXUYlzMKbF6/c/xdADArV2DMKFfBNrWMPIpJsADW2cOtlkBnIiIWh9mbsjpnc4oQFahDnklpoLgSD/T0gh/HEoDAHQK0qBHW69aZxJmYENEdH1gcENObV/KVSTO/RdPfL0XAKBWSJHYMQAAUFhRb9M32tdh7SMiIufD4Iac2sm0AgDA/ooZiLUuCgxs5yfu91DLERtiv9aGiIiuTwxuyKmZ56YxL5apUSsQH+4lLonQJ8qHaz8REZEVBjfkVATBesXv3GK91WutiwIquUzM3lS3NhQREV2/OFqKnMakr/YgPb8Uq5/sA7nMFHfnVmRuzDQVE/D9Z2QX3No1CLfGBjV7O4mIyLk5Rebm008/RXh4ONRqNXr37o1du3ZVe+zy5cshkUisHmo1p9NvydYfTceZzEKsP5qOg5fykJpXKu67aidzA5gm47u9WzAn5CMiIhsOz9ysXLkS06dPx6JFi9C7d2/MmzcPw4cPx4kTJ+Dvb7/LQaPR4MSJE+JrDvFtuf49mYlJX+2x2lasN4jPq2ZutFw6gYiIauHwzM3cuXMxadIkjB8/Hp06dcKiRYvg6uqKpUuXVvseiUSCwMBA8REQENCMLabGtOlkps028xBvo1Gwydxo1A6Px4mIyMk5NLjR6/XYu3cvEhMTxW1SqRSJiYnYvn17te8rLCxEWFgYQkNDceedd+LIkSPVHqvT6ZCfn2/1IOdhnpjPUrG+HD/tv4zY19fhVEah1T4NMzdERFQLhwY3WVlZMBgMNpmXgIAApKWl2X1P+/btsXTpUvz888/45ptvYDQa0adPH1y6dMnu8XPmzIFWqxUfoaGhjX4d1HD2gpsinQHTViajyKJ7yozdUkREVBuHd0vVV0JCAsaOHYu4uDgMHDgQq1evhp+fHxYvXmz3+FmzZiEvL098XLx4sZlbTDXJryZzUx1mboiIqDYOLWDw9fWFTCZDenq61fb09HQEBtZt9WaFQoHu3bvj9OnTdverVCqoVDWvOUSOU7WmBgCKdOXwcVMiu8h2HzM3RERUG4dmbpRKJXr27ImkpCRxm9FoRFJSEhISEup0DoPBgEOHDiEoiPOdtESpuaU224r0BgR52h/er1EzuCEiopo5fOjJ9OnTMW7cOMTHx6NXr16YN28eioqKMH78eADA2LFjERISgjlz5gAA3nzzTdx4442Ijo5Gbm4uPvjgA1y4cAETJ0505GVQA+SXlqFAZ9sFVawrh0xqP+7WujK4ISKimjk8uBk9ejQyMzMxe/ZspKWlIS4uDmvXrhWLjFNSUiC1uNFdvXoVkyZNQlpaGry8vNCzZ09s27YNnTp1ctQlUAPZy9oApsxNSTV1N+yWIiKi2kiEqov5tHL5+fnQarXIy8uDRqNxdHOuaxuOZ2D88t022++/IRRbTmfh0tUSq+0yqQSn376FkzYSEV2H6nP/bnGjpaj1uHi12O52U+amchh4/xhfAKYJ/BjYEBFRbRjcUJP7flcK/rUzE/HZzCK7xxfrysUlGH58IgHzRsfBXSVH97ZeTdpOIiJqHRxec0Ot26FLeZi1+hAA4Py7t1rtO5dlP7gp0JWjpMwU3IT7uMHHXYUdLw2Bi0LWtI0lIqJWgZkbalIpOfa7noDK4KZjkHXfaXahTnzuqjQFNO4qOWRcAZyIiOqAwQ01qXKjUXxeZqh8ris34FJFzU1siHVwk1VYOXkfszVERFRfDG6oSZUZKgfjmbuaAOBiTjGMgikjE+7rZvUe83pTaoUUUmZriIionhjcUJMqtQhoLEdAnUw3rfYd4esGD5X90i9XJUvCiIio/hjcUJMqKK2cjM88AuqXA1cw+dt9AEzBjVs1wQ27pIiIqCH4pzE1qYLSylW/zat9/7z/srjtru7BKDfYn0fSXExMRERUH8zcUJPKtwhuzF1U5hFUy8ffgMEdAuBebbcUgxsiIqo/BjfUaHady8H/rT+JcotRUfkl1t1SgiCIMxOH+5gKid3VlcGN5QTELgxuiIioAdgtRY3mvsXbAQC+7ko8nBAOoGq3lAGZhTqUlhkhkQDBni4AYFVz4+WqRE6RaSg4C4qJiKghePegRnc0NV98nm9RUPzPsQysO5wGAAjWukApNyUOAzVqeKjk8PNQQQDE4IaZGyIiaggGN9ToSssqu6UsMzcr91wUn7fxchGfu6nkSHpuIFRyGZ5esV+cuZijpYiIqCFYc0ONznJuG8uaG0ttvV2tXvtr1NC6KhDj7y5uY0ExERE1BIMbanSWwY1l5sZSgEZtd3u0RXDDbikiImoIBjfUKATBdpmFcoMRRRazElvycVfa3W6VuVGw15SIiOqPwQ01Css1pMw1N4U6+11S998QijG92trdZ5m5EWB/cj8iIqKa8E9jahSl5ZUZmmJ9OU5nFEAps+1WahfgjndHda32PJ6ulRmd1NzSxm0kERFdFxjcUKOwrLM5mV6IxLn/Ij7My+Y4Txf73VH2RPq51X4QERFRFQxuqFHoLIZ/m+25cNVmm9ZVUeu5/pzaH38fTcfYiokAiYiI6oPBDTWKkjL7hcMAoFZIxTocrzoENx2DNOgYpGm0thER0fWFwQ01ilI7wc1LIzqgd4QPUvNK8cQ3ewFY19QQERE1BQY31ChK7XRLTegXCZlUgoLSLHGb1qX2zA0REdG14FBwahT2MjcyqWmJbxdl5a+ZZx26pYiIiK4FgxtqFFWDG/OimADgorBe9ZuIiKgpMbihRlFabt0t5eNWGcRYrhHlyW4pIiJqYgxuqFFUzdy8NKKj+NwyuKnLUHAiIqJrwYJiahTm4GZYpwDMGtER4T6Vq35bLoDpquSvHBERNS1mbqhB8qus9m0ObtxUckT4ukEikYj7LAOaIK391cCJiIgaC/+MpnpbezgVT3yzD9OHtsMzQ2IAVA4FVyts15OSSSXY80oijEbB7n4iIqLGxMwN1dvM1YcAAHPXnxS3mTM3aoX9XylfdxX8NczaEBFR02NwQ/VWbhBsttWUuSEiImpO7JaieiszVA77PngpF/4eapSWV2Ru5AxuiIjIsRjcUL2VGyszN3cs2AoAuLtHCIDqu6WIiIiaC+9EVG8Go71uKXPNDTM3RETkWAxuqFGU6E3BjQuDGyIicjAGN9QocopN896o2C1FREQOxjsRNYqsAh0AdksREZHjMbihRpFZyOCGiIicA4MbahT6ilXB1XL+ShERkWPxTkSNipkbIiJyNAY3VC+CYDsM3JLlCuBERESOwOCG6kVXbqxxv4ea80ISEZFjMbiheinSlde439dd1UwtISIiso/BDVWrtMxg0w1VXDFZnz3ebkooZPyVIiIix2rQnai8vBx///03Fi9ejIKCAgDAlStXUFhY2KiNI8fJKChF1zf+wmNf77XaXlNw4+/BrA0RETlevQskLly4gJtvvhkpKSnQ6XQYOnQoPDw88N5770Gn02HRokVN0U5qZr8kX4G+3Ij1R9NxLqsIJXoDOgVrUKSvvlvKj8ENERE5gXpnbqZOnYr4+HhcvXoVLi4u4vaRI0ciKSmpURtHjuOqrIx7E+duwoiPNyMluxjFuuozNwxuiIjIGdQ7c7N582Zs27YNSqXSant4eDguX77caA0jx3JTVQ7pNq8C/uL/DmDH2Zxq3+PvoW7ydhEREdWm3pkbo9EIg8H2r/dLly7Bw8OjURpFjqe0UxhcU2ADMHNDRETOod7BzbBhwzBv3jzxtUQiQWFhIV577TWMGDGiMdtGDlRurHmyPntYUExERM6g3t1SH330EYYPH45OnTqhtLQUDzzwAE6dOgVfX198//33TdFGcoAyQ82T9dnD4IaIiJxBvYObNm3a4MCBA1ixYgUOHjyIwsJCTJgwAQ8++KBVgTG1bFWDG6VciicHRmF+0qlq38NuKSIicgYNmudGLpfjoYcewvvvv4/PPvsMEydOvKbA5tNPP0V4eDjUajV69+6NXbt21el9K1asgEQiwV133dXgzyb79AbrbqmbOwfi2aHtanwPgxsiInIG9c7cfPXVVzXuHzt2bL3Ot3LlSkyfPh2LFi1C7969MW/ePAwfPhwnTpyAv79/te87f/48nn/+efTv379en0d1U1ZlDSlvN9PouEhfN5zNKrLaF+7jiuGdA+GhVjRb+4iIiKojEWpb5rkKLy8vq9dlZWUoLi6GUqmEq6srcnJqHlFTVe/evXHDDTdgwYIFAEyjsUJDQ/H0009j5syZdt9jMBgwYMAAPProo9i8eTNyc3Px008/1enz8vPzodVqkZeXB41GU6+2Xk8WbzqDOX8eF19PH9oOzwyJQXp+Kdbsv4wf9lzE2UxTkPP9pBuREOXjqKYSEdF1oD7373p3S129etXqUVhYiBMnTqBfv371LijW6/XYu3cvEhMTKxsklSIxMRHbt2+v9n1vvvkm/P39MWHChPo2n+qoas2NV0XmJkCjxhMDo6yKh1UKridFRETOo97dUvbExMTg3XffxUMPPYTjx4/X/oYKWVlZMBgMCAgIsNoeEBBQ7Xm2bNmC//73v0hOTq7TZ+h0Ouh0OvF1fn5+ndt3PSurUnPj7Wo9aaPlApn25sQhIiJylEa7K8nlcly5cqWxTmdXQUEBHn74YSxZsgS+vr51es+cOXOg1WrFR2hoaJO2sbWomrkx19yYqeSVvzpqZm6IiMiJ1Dtz88svv1i9FgQBqampWLBgAfr27Vuvc/n6+kImkyE9Pd1qe3p6OgIDA22OP3PmDM6fP4/bb79d3GY0mm7CcrkcJ06cQFRUlNV7Zs2ahenTp4uv8/PzGeDUQBAEXLpaAn01BcVmSrll5kYGIiIiZ1Hv4KbqsGuJRAI/Pz8MHjwYH330Ub3OpVQq0bNnTyQlJYnnNRqNSEpKwpQpU2yO79ChAw4dOmS17ZVXXkFBQQHmz59vN2hRqVRQqThEua6WbzuPN349arPdy816JJRlVxRrboiIyJnUO7gxZ0oay/Tp0zFu3DjEx8ejV69emDdvHoqKijB+/HgApqHlISEhmDNnDtRqNbp06WL1fk9PTwCw2U4NYy+wAQAv15oyNwxuiIjIeTRKQfG1GD16NDIzMzF79mykpaUhLi4Oa9euFYuMU1JSIJXy5ulI9/ZsY1VADFgXFDNzQ0REzqROwY1lzUpt5s6dW+9GTJkyxW43FABs3LixxvcuX7683p9HdffKrR0xsX+kzXZmboiIyFnVKbjZv39/nU4mkUiuqTHkWFeL9DbbqmZszMzBjUwqgZzBDREROZE6BTcbNmxo6naQEzibVWizrbrgRlWxnVkbIiJyNrwzXceMRuuJ+s5kFtkco5DZz8aZMzestyEiImfToILiPXv24IcffkBKSgr0euuujNWrVzdKw6jppOaVwEUhw22fbEGMvzuWje8FAOJaUZZq65Zi5oaIiJxNve9MK1asQJ8+fXDs2DGsWbMGZWVlOHLkCP755x9otdqmaCM1oh1ns5Ew5x/Evbkel66WYMOJTHHCviu5JTbHVxfcmLczc0NERM6m3nemd955B//3f/+HX3/9FUqlEvPnz8fx48dx3333oW3btk3RRmpEK3al2GxLzy8FAFwttldQXHO3FDM3RETkbOp9Zzpz5gxuvfVWAKYZhouKiiCRSPDss8/i888/b/QGUuMK8XKx2ZaaZwpu8krKbPYp5NV0S5kzN3IuvUBERM6l3sGNl5cXCgoKAAAhISE4fPgwACA3NxfFxcWN2zpqdIWl5TbbUvNM3VG5xbbBTXWZGRYUExGRs6p3QfGAAQOwfv16xMbG4t5778XUqVPxzz//YP369RgyZEhTtJEaUb6d4OZKrilzk2u3W8p+8BLu4wYACPN2bcTWERERXbt6BzcLFixAaanpZvjyyy9DoVBg27ZtGDVqFF555ZVGbyA1rvyKrqcJ/SJQWmbAtztTsONsNrq10doNfKqruekW6omk5wYixNO2m4uIiMiR6h3ceHt7i8+lUilmzpzZqA2ippVfagpu4sO8kFUxI/Gmk5nYdDLT7vHVZW4AIMrPvfEbSEREdI3qXTCRmJiI5cuXIz8/vynaQ01k7eE03PnpVhy4lAcA0LgoEKxV2xznorAuEK4puCEiInJG9b5zde7cGbNmzUJgYCDuvfde/Pzzzygrsy1EJefyxDd7ceBirjinjUatQJDWtkvJ10MJmbSyK6q6bikiIiJnVe/gZv78+bh8+TJ++uknuLm5YezYsQgICMBjjz2GTZs2NUUbqYGMRgGGKkssmGlc5Aj2tM3ceLooobYY/s3MDRERtTQNunNJpVIMGzYMy5cvR3p6OhYvXoxdu3Zh8ODBjd0+aoD80jKUGYwY8fFmjPxsKwTBNsDRqBXQuihwb882Vts9XRVQWXRNKauZ54aIiMhZNWhtKbO0tDSsWLEC33zzDQ4ePIhevXo1VruogU6lF+DWj7egjZcLzmaZ1oqyNwrKQy2HRCLBB/d2w9BOAXjs670AAK2LwmpuG2ZuiIiopan3nSs/Px/Lli3D0KFDERoaioULF+KOO+7AqVOnsGPHjqZoI9XDH4fSoDcYxcAGqBz+beamlEFuEbQEWwzn9nRVsOaGiIhatHpnbgICAuDl5YXRo0djzpw5iI+Pb4p2UQPZq6O5mGM9c7S72vprb2OxJIOLQgaJRTzDzA0REbU09Q5ufvnlFwwZMgRSKW96zsheAXFKleCm3GB9jNZFIT4v1huqZG74PRMRUctS7zvX0KFDGdg4mdX7LuGW+ZtxMacYeoPRZn/V4KZYb7B6LbFI1ejLjZBZvLYMdIiIiFoCRimtwPQfDuBYaj5e/umwOI+NpQtVgpuSMoPNMY8PjISrUobHB0ZZdUsRERG1NNc0WoqcS0Z+KXQVwU2wVg2VQoZzWUU2NTf2zLqlI54f1h4KmZTZGiIiatEY3LQixXqDmLkZ3NEfxXoDzmUV2XRLyasJXsz1NVKmboiIqAVjcNOKFOvLxZobpUwGudoUrOQWm4aCdwnRoLC0HG+PjK3xPBIGN0RE1ILVu+bmmWeewccff2yzfcGCBZg2bVpjtIkayDJzo5RL4VFlyPeI2CBsfOEm9I32rfE8HCBFREQtWb1vY//73//Qt29fm+19+vTBqlWrGqVR1DBVgxt3lXVw4+2qrNN5ZMzcEBFRC1bv4CY7OxtardZmu0ajQVZWVqM0ihpODG5kEnioFVb7POsY3EhZUExERC1YvYOb6OhorF271mb7n3/+icjIyEZpFDWcWHNjp1sqxGKZhZqwoJiIiFqyehcUT58+HVOmTEFmZqa4CnhSUhI++ugjzJs3r7HbR/VUmbmR2iyzEObrWqdzMHFDREQtWb2Dm0cffRQ6nQ5vv/023nrrLQBAeHg4Fi5ciLFjxzZ6A6l+ivSmFcCVchk0FsGNj5sSmirdVNVh5oaIiFqyBg0Ff/LJJ/Hkk08iMzMTLi4ucHd3b+x2UT24KGTirMNZhToA5m6pymAm3NetzudjcENERC3ZNQ369fPzY2DjBAxC5UKYmQWWwU1l7BruU/fg5o64YABAZD0CIiIiImdRp8xNjx49kJSUBC8vL3Tv3r3GSd727dvXaI2j2gmCgDKLxTLF4EZmPRQ8SKuu8zlHx4ci1MsVXUI0jddQIiKiZlKn4ObOO++ESqUCANx1111N2R6qJ4NRgEXiBsaK5yq5FG5Ki5ob97oNAwdMQ8H7xdQ80R8REZGzqlNw89prrwEADAYDbrrpJnTt2hWenp5N2S6qozKDYHe7Ui61mq8myo/dh0REdH2oV0GxTCbDsGHDcOzYMQY3TkJv0SVlSSk3lVO9f09XnMksRH9mYoiI6DpR79FSXbp0wdmzZxEREdEU7aF6KqsuuKlYIOq++NDmbA4REZHD1Xu01H/+8x88//zz+O2335Camor8/HyrBzWv8hq6pYiIiK5H9c7cjBgxAgBwxx13WI2aEgQBEokEBoOh8VpHtao2c8PghoiIrlP1Dm42bNjQFO2gBqq25kbG4IaIiK5P9Q5uIiIiEBoaajPXjSAIuHjxYqM1jOqmusyNipkbIiK6TtX7DhgREYHMzEyb7Tk5OSwydoCyctbcEBERWar3HdBcW1NVYWEh1Oq6z4JLjaO2oeBERETXmzp3S02fPh0AIJFI8Oqrr8LV1VXcZzAYsHPnTsTFxTV6A6lm5ay5ISIislLn4Gb//v0ATJmbQ4cOQamsnM5fqVSiW7dueP755xu/hVQj8wzFCplEfC6RADIpV/YmIqLrU52DG/MoqfHjx2P+/PnQaLioojMwFxR7uSqRYbFoZk2LmxIREbVm9e67WLZsGTQaDU6fPo1169ahpKQEgCmjQ81PbxHcmBn5XRAR0XWs3sFNTk4OhgwZgnbt2mHEiBFITU0FAEyYMAHPPfdcozeQambO3GhdFBbbGNwQEdH1q97BzbRp06BQKJCSkmJVVDx69GisXbu2URtHtTMHNyoFC4iJiIiABkzi99dff2HdunVo06aN1faYmBhcuHCh0RpGdWOe50bB0VFEREQAGpC5KSoqssrYmOXk5EClUjVKo6juyoymzI2co6OIiIgANCC46d+/P7766ivxtUQigdFoxPvvv4+bbrqpURtHtSsrNwU3Ck7aR0REBKAB3VLvv/8+hgwZgj179kCv1+PFF1/EkSNHkJOTg61btzZFG6kG5uJhTtpHRERkUu87YpcuXXDy5En069cPd955J4qKinD33Xdj//79iIqKaoo2Ug3MQ8EVMnZLERERAQ3I3ACAVqvFyy+/3NhtoQYoE4MbKeRSCcqNHAZORETXtwb1ZZSWlmLXrl347bff8Msvv1g9GuLTTz9FeHg41Go1evfujV27dlV77OrVqxEfHw9PT0+4ubkhLi4OX3/9dYM+tzWwDG64WCYREVEDMjdr167F2LFjkZWVZbNPIpHAYDDU63wrV67E9OnTsWjRIvTu3Rvz5s3D8OHDceLECfj7+9sc7+3tjZdffhkdOnSAUqnEb7/9hvHjx8Pf3x/Dhw+v7+W0eGLNjdwU3BTr6/fzJyIiam3q/af+008/jXvvvRepqakwGo1Wj/oGNgAwd+5cTJo0CePHj0enTp2waNEiuLq6YunSpXaPHzRoEEaOHImOHTsiKioKU6dORdeuXbFly5Z6f3ZrYM7cyKUSDOkQAAAI1qod2SQiIiKHqnfmJj09HdOnT0dAQMA1f7her8fevXsxa9YscZtUKkViYiK2b99e6/sFQcA///yDEydO4L333rN7jE6ng06nE1/n5+dfc7udiWW31Ot3dEL7QHeMiA1ycKuIiIgcp96Zm3vuuQcbN25slA/PysqCwWCwCZQCAgKQlpZW7fvy8vLg7u4OpVKJW2+9FZ988gmGDh1q99g5c+ZAq9WKj9DQ0EZpu7Mwz1CslEvhoVbgsQFRaONlO8kiERHR9aLemZsFCxbg3nvvxebNmxEbGwuFQmG1/5lnnmm0xlXHw8MDycnJKCwsRFJSEqZPn47IyEgMGjTI5thZs2Zh+vTp4uv8/PxWEeAUlJZBIZNaZG44FJyIiAhoQHDz/fff46+//oJarcbGjRshkVTeVCUSSb2CG19fX8hkMqSnp1ttT09PR2BgYLXvk0qliI6OBgDExcXh2LFjmDNnjt3gRqVStbplIUr0BsS+/hc0ajkGtPMDwLWliIiIzOp9R3z55ZfxxhtvIC8vD+fPn8e5c+fEx9mzZ+t1LqVSiZ49eyIpKUncZjQakZSUhISEhDqfx2g0WtXVtHbns4sAAPml5eLoKAY3REREJvXO3Oj1eowePRpSaePcTKdPn45x48YhPj4evXr1wrx581BUVITx48cDAMaOHYuQkBDMmTMHgKmGJj4+HlFRUdDpdPjjjz/w9ddfY+HChY3SnpbAcj6bnCK9aRuDGyIiIgANCG7GjRuHlStX4qWXXmqUBowePRqZmZmYPXs20tLSEBcXh7Vr14pFxikpKVaBVFFRESZPnoxLly7BxcUFHTp0wDfffIPRo0c3SntaAoPFLMS5xabgRs6aGyIiIgCARBCEes3X/8wzz+Crr75Ct27d0LVrV5uC4rlz5zZqAxtbfn4+tFot8vLyoNFoHN2cBjl8OQ+3fWKa18dDLUdBaTk+GdMdt3cLdnDLiIiImkZ97t/1ztwcOnQI3bt3BwAcPnzYap9lcTE1HfNimQBQUFoOgDU3REREZvUObjZs2NAU7aB6KCs32mxTyhlYEhERAQ1cOJMcy7yelCVmboiIiEx4R2yB9HbW8OJoKSIiIhPeEVsgfblt5sbbTemAlhARETkfBjctkGVBsZmve+uahZmIiKihGNy0QFULiuVSCbQuimqOJiIiur4wuGmBqmZufNyVkEo5WoqIiAhgcOP0BEFAXnGZ1bayKsENu6SIiIgqMbhxctNWJqPbm3/hwMVccZu+nMENERFRdRjcOLmfk68AAJZsrlxxvWq3FIMbIiKiSgxuWgjLlcDLqgwF9/XgMHAiIiIzBjcthEouE59XncTPj5kbIiIiEYObFkJlmbmpsvyCnweDGyIiIjMGNy2EZbdU1YJiD3W91z8lIiJqtRjcODFdeWX3k2XmpmpBsdqiy4qIiOh6x+DGiRXrKoMby1W/LWcoDvF0QY8wr2ZtFxERkTNjf4YTK9SVi8+NQmWdjTlz89KIDhjfN8Iq8CEiIrre8a7oxIr1lZmbcosiYvMMxWqFjIENERFRFbwzOjHLzE2ZsbIrSl8xzw0DGyIiIlu8OzqxIsvgpty2W0rJ4IaIiMgG745OrFhfGdyUW2RuzAXFCjm/PiIioqp4d3RihRajpSwn7mPmhoiIqHq8Ozoxy8yNuYg4Pb8UpWWmoEcplzikXURERM6MQ8GdmGVBcbnBiG1nsvDAkp3iNhYUExER2eLd0YkVV+mWmvPHcav97JYiIiKyxbujE7MaCm4wIqtQZ7WfBcVERES2eHd0YtajpQSb4IaZGyIiIlu8OzqxIotuKX250WrEFGC9UjgRERGZ8O7oxIosMjcXcops9jNzQ0REZIt3RydmOUPxxZwSm/2suSEiIrLFu6MTs+yWskch4zw3REREVTG4cWKW3VL2qGSyZmoJERFRy8HgxonlFpfVuF/BGYqJiIhsMLhxUmUGI/JKag5uWFBMRERki3dHJ3W1SF/rMTIpMzdERERVMbhxUlmFtQc3EgmDGyIioqoY3DipnDpkboiIiMgWgxsnlV1kWmohUKO22q51UTiiOURERC0GgxsnlV3RLRWgUVlt93FTOqI5RERELQaDGydlztwEVMncVH1NRERE1uSObgDZZ87cBGqtg5nxfcNxtViPwR38HdEsIiIip8fgxkllF5m7payDGx93FdZOG+CIJhEREbUI7JZyUtmF9guK1Qp+ZURERDXhndJJmYeCV+2WUiu4nhQREVFNGNw4qepGSzG4ISIiqhmDGyeUWaBDgc60Iri/Rg3LiYjVcn5lRERENeGd0gltPZ0FAOgcrIFGrYAgVO5j5oaIiKhmDG6c0L+nMgEA/WP8bPYxuCEiIqoZgxsnIwgCNp8yZW4GxPja7OdK4ERERDVjcONkzmcXI7NAB5Vcip7hXo5uDhERUYvD4MbJnM8qAgBE+LpBJWcXFBERUX0xuHEyF7JNwU2Yj6uDW0JERNQyMbhxMhdyigEAYT5uDm4JERFRy8TgxslcyDYHN8zcEBERNYRTBDeffvopwsPDoVar0bt3b+zatavaY5csWYL+/fvDy8sLXl5eSExMrPH4lkbslvJm5oaIiKghHB7crFy5EtOnT8drr72Gffv2oVu3bhg+fDgyMjLsHr9x40aMGTMGGzZswPbt2xEaGophw4bh8uXLzdzyxmc0Crh4tQQAMzdEREQN5fDgZu7cuZg0aRLGjx+PTp06YdGiRXB1dcXSpUvtHv/tt99i8uTJiIuLQ4cOHfDFF1/AaDQiKSmpmVve+NLyS6EvN0IhkyCoyoKZREREVDcODW70ej327t2LxMREcZtUKkViYiK2b99ep3MUFxejrKwM3t7edvfrdDrk5+dbPZzVxYpi4hBPF8hlDo87iYiIWiSH3kGzsrJgMBgQEBBgtT0gIABpaWl1OseMGTMQHBxsFSBZmjNnDrRarfgIDQ295nY3lcKKxTK1Lgq7+yWcnJiIiKhWLTo98O6772LFihVYs2YN1Gr73TizZs1CXl6e+Lh48WIzt7LuSsuMAABVNetHybn0AhERUa3kjvxwX19fyGQypKenW21PT09HYGBgje/98MMP8e677+Lvv/9G165dqz1OpVJBpVI1SnubWmmZAUD1i2NyXSkiIqLaOTRzo1Qq0bNnT6tiYHNxcEJCQrXve//99/HWW29h7dq1iI+Pb46mNovS8orgRm7/a5GxX4qIiKhWDs3cAMD06dMxbtw4xMfHo1evXpg3bx6Kioowfvx4AMDYsWMREhKCOXPmAADee+89zJ49G9999x3Cw8PF2hx3d3e4u7s77Doag7lbqrrMTXW1OERERFTJ4cHN6NGjkZmZidmzZyMtLQ1xcXFYu3atWGSckpICqbQyk7Fw4ULo9Xrcc889Vud57bXX8Prrrzdn0xudriJzo6qSuVn8cE+89+dxzL+/uyOaRURE1KJIBEEQHN2I5pSfnw+tVou8vDxoNBpHN8fK3PUn8XHSKTx8YxjeuquLo5tDRETkNOpz/27Ro6VaC3N8qRMLivm1EBERNRTvog72/a4U9HhrPQ5eyq11tBQRERHVjsGNg81afQhXi8vw7MrkWguKiYiIqHYMbpxEoa5cHApetaCYiIiI6o53USehLzdCV8sMxURERFQ7BjdOQl9urHUSPyIiIqod76JOQlduZEExERFRI2Bw4yTKjQILiomIiBoBgxsnYs7csKCYiIio4XgXdSL6cmZuiIiIrhWDGwcyGq1XvijSlwPgDMVERETXgndRB9JVZGrM0vN1AJi5ISIiuhYMbhyouCJTU5VazuCGiIiooRjcOFBJRQFxVeyWIiIiajjeRR2otJrgRsXMDRERUYMxuHGgYn01wQ0zN0RERA3Gu6gDldgJbiQSznNDRER0LXgXdSB7NTcquRQSicQBrSEiImodGNw4kL2aGw4DJyIiujYMbhzIXs0Nu6SIiIiuDe+kDmTulvL3UInbmLkhIiK6NgxuHMhcUNwlRCtuK6syazERERHVD4MbByq1k7m5klfqqOYQERG1CgxuHMhcc8OuKCIiosbD4MaBzDU3rkoZNGq5g1tDRETUOjC4cSBzt5SLQoYHeocBAKL93R3ZJCIiohaP6QIHMhcUuyhleHxgFMJ8XDGwnZ+DW0VERNSyMbhxIMuaG6VcijG92jq4RURERC0fu6UcyLLmhoiIiBoHgxsHKtKVAzDV3BAREVHjYHDjIBtPZGBfSi4AoK2Pq2MbQ0RE1IowuHEAXbkBM/93CADw8I1h6BysreUdREREVFcMbhzgf3svIy2/FEFaNV6+taOjm0NERNSqMLhpZoIg4PN/zwAAJvaP5OzEREREjYzBTTPLKtTjfHYxJBLg/htCHd0cIiKiVofBTTPLKtQBALxdlXBTcZohIiKixsbgppllFpiCG193VS1HEhERUUMwuGlm5syNnweDGyIioqbA4KaZmYMbX3elg1tCRETUOjG4aWbsliIiImpaDG6aWVahHgC7pYiIiJoKg5tmVtktxeCGiIioKTC4aWZitxQzN0RERE2CE600M3G0FDM3RERNQhAElJeXw2AwOLopVE8KhQIy2bXP3M/gphkZjAJyikw1N74eHC1FRNTY9Ho9UlNTUVxc7OimUANIJBK0adMG7u7u13QeBjfNKLtIB6MASCWAjxszN0REjcloNOLcuXOQyWQIDg6GUqmERCJxdLOojgRBQGZmJi5duoSYmJhryuAwuGlGWQWmrI23mxIyKf+HIyJqTHq9HkajEaGhoXB1dXV0c6gB/Pz8cP78eZSVlV1TcMOC4mbEkVJERE1PKuWtraVqrEwbfwOakXmkFOe4ISIiajoMbpoRMzdERERNj8FNM6pceoEjpYiIiJoKg5tmxBXBiYiopSgrK3N0ExqMwU0zMq8rxW4pIiKqau3atejXrx88PT3h4+OD2267DWfOnBH3X7p0CWPGjIG3tzfc3NwQHx+PnTt3ivt//fVX3HDDDVCr1fD19cXIkSPFfRKJBD/99JPV53l6emL58uUAgPPnz0MikWDlypUYOHAg1Go1vv32W2RnZ2PMmDEICQmBq6srYmNj8f3331udx2g04v3330d0dDRUKhXatm2Lt99+GwAwePBgTJkyxer4zMxMKJVKJCUlNcaPzS4OBW9GXBGciKh5CYKAkjLHzFTsopDVa/RPUVERpk+fjq5du6KwsBCzZ8/GyJEjkZycjOLiYgwcOBAhISH45ZdfEBgYiH379sFoNAIAfv/9d4wcORIvv/wyvvrqK+j1evzxxx/1bvPMmTPx0UcfoXv37lCr1SgtLUXPnj0xY8YMaDQa/P7773j44YcRFRWFXr16AQBmzZqFJUuW4P/+7//Qr18/pKam4vjx4wCAiRMnYsqUKfjoo4+gUpnufd988w1CQkIwePDgerevrhjcNCN2SxERNa+SMgM6zV7nkM8++uZwuCrrfpsdNWqU1eulS5fCz88PR48exbZt25CZmYndu3fD29sbABAdHS0e+/bbb+P+++/HG2+8IW7r1q1bvds8bdo03H333Vbbnn/+efH5008/jXXr1uGHH35Ar169UFBQgPnz52PBggUYN24cACAqKgr9+vUDANx9992YMmUKfv75Z9x3330AgOXLl+ORRx5p0gkWHd4t9emnnyI8PBxqtRq9e/fGrl27qj32yJEjGDVqFMLDwyGRSDBv3rzma+g1KjcYkVPMbikiIrLv1KlTGDNmDCIjI6HRaBAeHg4ASElJQXJyMrp37y4GNlUlJydjyJAh19yG+Ph4q9cGgwFvvfUWYmNj4e3tDXd3d6xbtw4pKSkAgGPHjkGn01X72Wq1Gg8//DCWLl0KANi3bx8OHz6MRx555JrbWhOHZm5WrlyJ6dOnY9GiRejduzfmzZuH4cOH48SJE/D397c5vri4GJGRkbj33nvx7LPPOqDFDZdTpIdQsfSCtxtHSxERNQcXhQxH3xzusM+uj9tvvx1hYWFYsmQJgoODYTQa0aVLF+j1eri4uNT8WbXsl0gkEATBapu9gmE3Nzer1x988AHmz5+PefPmITY2Fm5ubpg2bRr0en2dPhcwdU3FxcXh0qVLWLZsGQYPHoywsLBa33ctHJq5mTt3LiZNmoTx48ejU6dOWLRoEVxdXcUIr6obbrgBH3zwAe6//36x785Z6MoNuHS1uNrH0dR8AIC3m4pLLxARNROJRAJXpdwhj/p0u2RnZ+PEiRN45ZVXMGTIEHTs2BFXr14V93ft2hXJycnIycmx+/6uXbvWWKDr5+eH1NRU8fWpU6fqtLjo1q1bceedd+Khhx5Ct27dEBkZiZMnT4r7Y2Ji4OLiUuNnx8bGIj4+HkuWLMF3332HRx99tNbPvVYOy9zo9Xrs3bsXs2bNErdJpVIkJiZi+/btjfY5Op0OOp1OfJ2fn99o57Z05Eo+7v5sW63HcY4bIiKqysvLCz4+Pvj8888RFBSElJQUzJw5U9w/ZswYvPPOO7jrrrswZ84cBAUFYf/+/QgODkZCQgJee+01DBkyBFFRUbj//vtRXl6OP/74AzNmzABgGrW0YMECJCQkwGAwYMaMGVAoFLW2KyYmBqtWrcK2bdvg5eWFuXPnIj09HZ06dQJg6naaMWMGXnzxRSiVSvTt2xeZmZk4cuQIJkyYIJ7HXFjs5uZmNYqrqTgsc5OVlQWDwYCAgACr7QEBAUhLS2u0z5kzZw60Wq34CA0NbbRzW5IAUMmlNT5clTKM7B7SJJ9PREQtl1QqxYoVK7B371506dIFzz77LD744ANxv1KpxF9//QV/f3+MGDECsbGxePfdd8XFJQcNGoQff/wRv/zyC+Li4jB48GCrGtaPPvoIoaGh6N+/Px544AE8//zzdVpc9JVXXkGPHj0wfPhwDBo0CIGBgbjrrrusjnn11Vfx3HPPYfbs2ejYsSNGjx6NjIwMq2PGjBkDuVyOMWPGQK1WX8NPqm4kQtVOuGZy5coVhISEYNu2bUhISBC3v/jii9i0aZPV2H17wsPDMW3aNEybNq3G4+xlbkJDQ5GXlweNRnNN10BERM6jtLQU586dQ0RERLPcQKnuzp8/j6ioKOzevRs9evSo9riavsP8/Hxotdo63b8d1i3l6+sLmUyG9PR0q+3p6ekIDAxstM9RqVROV59DRER0PSgrK0N2djZeeeUV3HjjjTUGNo3JYd1SSqUSPXv2tCpCMhqNSEpKssrkEBERUcu0detWBAUFYffu3Vi0aFGzfa5Dh4JPnz4d48aNQ3x8PHr16oV58+ahqKgI48ePBwCMHTsWISEhmDNnDgBTEfLRo0fF55cvX0ZycjLc3d2tJjMiIiIixxs0aJDNEPTm4NDgZvTo0cjMzMTs2bORlpaGuLg4rF27ViwyTklJgVRamVy6cuUKunfvLr7+8MMP8eGHH2LgwIHYuHFjczefiIiInJDDCoodpT4FSURE1HKwoLjla6yCYocvv0BERNSYrrO/2VuVxvruGNwQEVGrYJ6Uri4z75JzMi/rYJ6/p6G4KjgREbUKMpkMnp6e4gRyrq6uTbryNDUuo9GIzMxMuLq6Qi6/tvCEwQ0REbUa5nnSqs6QSy2DVCpF27ZtrzkoZXBDRESthkQiQVBQEPz9/e2uek3OTalUWo2SbigGN0RE1OrIZLJrrtuglosFxURERNSqMLghIiKiVoXBDREREbUq113NjXmCoPz8fAe3hIiIiOrKfN+uy0R/111wU1BQAAAIDQ11cEuIiIiovgoKCqDVams85rpbW8poNOLKlSvw8PBo1Mmd8vPzERoaiosXL7bKNata+/UBrf8aW/v1Aa3/Glv79QGt/xpb+/UBTXeNgiCgoKAAwcHBtQ4Xv+4yN1KpFG3atGmy82s0mlb7Cwu0/usDWv81tvbrA1r/Nbb26wNa/zW29usDmuYaa8vYmLGgmIiIiFoVBjdERETUqjC4aSQqlQqvvfYaVCqVo5vSJFr79QGt/xpb+/UBrf8aW/v1Aa3/Glv79QHOcY3XXUExERERtW7M3BAREVGrwuCGiIiIWhUGN0RERNSqMLghIiKiVoXBTSP49NNPER4eDrVajd69e2PXrl2OblKDvf7665BIJFaPDh06iPtLS0vx1FNPwcfHB+7u7hg1ahTS09Md2OKa/fvvv7j99tsRHBwMiUSCn376yWq/IAiYPXs2goKC4OLigsTERJw6dcrqmJycHDz44IPQaDTw9PTEhAkTUFhY2IxXUbParvGRRx6x+U5vvvlmq2Oc+RrnzJmDG264AR4eHvD398ddd92FEydOWB1Tl9/LlJQU3HrrrXB1dYW/vz9eeOEFlJeXN+el2FWX6xs0aJDNd/jEE09YHeOs1wcACxcuRNeuXcVJ3RISEvDnn3+K+1vy9wfUfn0t/fur6t1334VEIsG0adPEbU73HQp0TVasWCEolUph6dKlwpEjR4RJkyYJnp6eQnp6uqOb1iCvvfaa0LlzZyE1NVV8ZGZmivufeOIJITQ0VEhKShL27Nkj3HjjjUKfPn0c2OKa/fHHH8LLL78srF69WgAgrFmzxmr/u+++K2i1WuGnn34SDhw4INxxxx1CRESEUFJSIh5z8803C926dRN27NghbN68WYiOjhbGjBnTzFdSvdqucdy4ccLNN99s9Z3m5ORYHePM1zh8+HBh2bJlwuHDh4Xk5GRhxIgRQtu2bYXCwkLxmNp+L8vLy4UuXboIiYmJwv79+4U//vhD8PX1FWbNmuWIS7JSl+sbOHCgMGnSJKvvMC8vT9zvzNcnCILwyy+/CL///rtw8uRJ4cSJE8JLL70kKBQK4fDhw4IgtOzvTxBqv76W/v1Z2rVrlxAeHi507dpVmDp1qrjd2b5DBjfXqFevXsJTTz0lvjYYDEJwcLAwZ84cB7aq4V577TWhW7dudvfl5uYKCoVC+PHHH8Vtx44dEwAI27dvb6YWNlzVG7/RaBQCAwOFDz74QNyWm5srqFQq4fvvvxcEQRCOHj0qABB2794tHvPnn38KEolEuHz5crO1va6qC27uvPPOat/T0q4xIyNDACBs2rRJEIS6/V7+8ccfglQqFdLS0sRjFi5cKGg0GkGn0zXvBdSi6vUJgunmaHkjqaolXZ+Zl5eX8MUXX7S678/MfH2C0Hq+v4KCAiEmJkZYv3691TU543fIbqlroNfrsXfvXiQmJorbpFIpEhMTsX37dge27NqcOnUKwcHBiIyMxIMPPoiUlBQAwN69e1FWVmZ1vR06dEDbtm1b5PWeO3cOaWlpVtej1WrRu3dv8Xq2b98OT09PxMfHi8ckJiZCKpVi586dzd7mhtq4cSP8/f3Rvn17PPnkk8jOzhb3tbRrzMvLAwB4e3sDqNvv5fbt2xEbG4uAgADxmOHDhyM/Px9HjhxpxtbXrur1mX377bfw9fVFly5dMGvWLBQXF4v7WtL1GQwGrFixAkVFRUhISGh131/V6zNrDd/fU089hVtvvdXquwKc8//B627hzMaUlZUFg8Fg9WUBQEBAAI4fP+6gVl2b3r17Y/ny5Wjfvj1SU1PxxhtvoH///jh8+DDS0tKgVCrh6elp9Z6AgACkpaU5psHXwNxme9+feV9aWhr8/f2t9svlcnh7e7eYa7755ptx9913IyIiAmfOnMFLL72EW265Bdu3b4dMJmtR12g0GjFt2jT07dsXXbp0AYA6/V6mpaXZ/Z7N+5yFvesDgAceeABhYWEIDg7GwYMHMWPGDJw4cQKrV68G0DKu79ChQ0hISEBpaSnc3d2xZs0adOrUCcnJya3i+6vu+oDW8f2tWLEC+/btw+7du232OeP/gwxuyMott9wiPu/atSt69+6NsLAw/PDDD3BxcXFgy6ih7r//fvF5bGwsunbtiqioKGzcuBFDhgxxYMvq76mnnsLhw4exZcsWRzelSVR3fY899pj4PDY2FkFBQRgyZAjOnDmDqKio5m5mg7Rv3x7JycnIy8vDqlWrMG7cOGzatMnRzWo01V1fp06dWvz3d/HiRUydOhXr16+HWq12dHPqhN1S18DX1xcymcymIjw9PR2BgYEOalXj8vT0RLt27XD69GkEBgZCr9cjNzfX6piWer3mNtf0/QUGBiIjI8Nqf3l5OXJyclrkNQNAZGQkfH19cfr0aQAt5xqnTJmC3377DRs2bECbNm3E7XX5vQwMDLT7PZv3OYPqrs+e3r17A4DVd+js16dUKhEdHY2ePXtizpw56NatG+bPn99qvr/qrs+elvb97d27FxkZGejRowfkcjnkcjk2bdqEjz/+GHK5HAEBAU73HTK4uQZKpRI9e/ZEUlKSuM1oNCIpKcmqr7UlKywsxJkzZxAUFISePXtCoVBYXe+JEyeQkpLSIq83IiICgYGBVteTn5+PnTt3iteTkJCA3Nxc7N27Vzzmn3/+gdFoFP+BamkuXbqE7OxsBAUFAXD+axQEAVOmTMGaNWvwzz//ICIiwmp/XX4vExIScOjQIasgbv369dBoNGLXgaPUdn32JCcnA4DVd+is11cdo9EInU7X4r+/6pivz56W9v0NGTIEhw4dQnJysviIj4/Hgw8+KD53uu+w0UuUrzMrVqwQVCqVsHz5cuHo0aPCY489Jnh6elpVhLckzz33nLBx40bh3LlzwtatW4XExETB19dXyMjIEATBNNyvbdu2wj///CPs2bNHSEhIEBISEhzc6uoVFBQI+/fvF/bv3y8AEObOnSvs379fuHDhgiAIpqHgnp6ews8//ywcPHhQuPPOO+0OBe/evbuwc+dOYcuWLUJMTIzTDJMWhJqvsaCgQHj++eeF7du3C+fOnRP+/vtvoUePHkJMTIxQWloqnsOZr/HJJ58UtFqtsHHjRquhtMXFxeIxtf1emoehDhs2TEhOThbWrl0r+Pn5OcVQ29qu7/Tp08Kbb74p7NmzRzh37pzw888/C5GRkcKAAQPEczjz9QmCIMycOVPYtGmTcO7cOeHgwYPCzJkzBYlEIvz111+CILTs708Qar6+1vD92VN1BJizfYcMbhrBJ598IrRt21ZQKpVCr169hB07dji6SQ02evRoISgoSFAqlUJISIgwevRo4fTp0+L+kpISYfLkyYKXl5fg6uoqjBw5UkhNTXVgi2u2YcMGAYDNY9y4cYIgmIaDv/rqq0JAQICgUqmEIUOGCCdOnLA6R3Z2tjBmzBjB3d1d0Gg0wvjx44WCggIHXI19NV1jcXGxMGzYMMHPz09QKBRCWFiYMGnSJJvg25mv0d61ARCWLVsmHlOX38vz588Lt9xyi+Di4iL4+voKzz33nFBWVtbMV2OrtutLSUkRBgwYIHh7ewsqlUqIjo4WXnjhBat5UgTBea9PEATh0UcfFcLCwgSlUin4+fkJQ4YMEQMbQWjZ358g1Hx9reH7s6dqcONs36FEEASh8fNBRERERI7BmhsiIiJqVRjcEBERUavC4IaIiIhaFQY3RERE1KowuCEiIqJWhcENERERtSoMboiIiKhVYXBDRNeFjRs3QiKR2Kx/Q0StD4MbIiIialUY3BAREVGrwuCGiJyK0WjE+++/j+joaKhUKrRt2xZvv/02Bg8ejClTplgdm5mZCaVSKa5GrNPpMGPGDISGhkKlUiE6Ohr//e9/q/2sLVu2oH///nBxcUFoaCieeeYZFBUVNen1EVHTY3BDRE5l1qxZePfdd/Hqq6/i6NGj+O677xAQEICJEyfiu+++g06nE4/95ptvEBISgsGDBwMAxo4di++//x4ff/wxjh07hsWLF8Pd3d3u55w5cwY333wzRo0ahYMHD2LlypXYsmWLTQBFRC0PF84kIqdRUFAAPz8/LFiwABMnTrTaV1paiuDgYCxatAj33XcfAKBbt264++678dprr+HkyZNo37491q9fj8TERJtzb9y4ETfddBOuXr0KT09PTJw4ETKZDIsXLxaP2bJlCwYOHIiioiKo1eqmvVgiajLM3BCR0zh27Bh0Oh2GDBlis0+tVuPhhx/G0qVLAQD79u3D4cOH8cgjjwAAkpOTIZPJMHDgwDp91oEDB7B8+XK4u7uLj+HDh8NoNOLcuXONdk1E1Pzkjm4AEZGZi4tLjfsnTpyIuLg4XLp0CcuWLcPgwYMRFhZWp/dWVVhYiMcffxzPPPOMzb62bdvW61xE5FyYuSEipxETEwMXFxexQLiq2NhYxMfHY8mSJfjuu+/w6KOPWu0zGo3YtGlTnT6rR48eOHr0KKKjo20eSqWyUa6HiByDwQ0ROQ21Wo0ZM2bgxRdfxFdffYUzZ85gx44dViOeJk6ciHfffReCIGDkyJHi9vDwcIwbNw6PPvoofvrpJ5w7dw4bN27EDz/8YPezZsyYgW3btmHKlClITk7GqVOn8PPPP7OgmKgVYHBDRE7l1VdfxXPPPYfZs2ejY8eOGD16NDIyMsT9Y8aMgVwux5gxY2yKfhcuXIh77rkHkydPRocOHTBp0qRqh3Z37doVmzZtwsmTJ9G/f390794ds2fPRnBwcJNeHxE1PY6WIqIW5fz584iKisLu3bvRo0cPRzeHiJwQgxsiahHKysqQnZ2N559/HufOncPWrVsd3SQiclLsliKiFmHr1q0ICgrC7t27sWjRIkc3h4icGDM3RERE1Kowc0NEREStCoMbIiIialUY3BAREVGrwuCGiIiIWhUGN0RERNSqMLghIiKiVoXBDREREbUqDG6IiIioVWFwQ0RERK3K/wMJOdUbZ6x88gAAAABJRU5ErkJggg==",
      "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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3249552a-eed5-475c-9fe9-d271b4d7aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5183c190-b08b-44d2-802d-c9d613a7ea2b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b51fd015-97b9-4e1d-8cc1-e35f4dd33a54",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96c40280-5bb9-4c00-814b-483f7c808608",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d694fc0-2335-4668-895f-84073d43662c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca42476c-5f0a-4499-8846-a67fe4450ca1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3c0c1bc-ceaa-4502-8f9d-94f38efae249",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d6788ca-edf3-4f07-9fc7-9f66d535d304",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1f0e77c-9e66-4be7-ac44-bcf7948d348a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0c7c843-4d33-4623-b0b1-e1d8f951e214",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb2f2f9e-0f0b-47cc-ac95-88a90b35cb64",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e87dce4e-2191-4e37-adeb-cd82426a1fa5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f3eff55-92c9-4e0b-8776-e2949f10b437",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bfca51a-5c3e-40e1-8018-69602e8b49f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "475e0b2f-2108-4c3e-811b-a9b1c33b462a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
