{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2380]\n",
      " [   1   64]\n",
      " [   2   46]\n",
      " [   3   73]\n",
      " [   4  127]\n",
      " [   5  173]\n",
      " [   6  288]\n",
      " [   7  545]\n",
      " [   8  827]\n",
      " [   9 1436]]\n",
      "[[   0 1453]\n",
      " [   1 2669]\n",
      " [   2   70]\n",
      " [   3   38]\n",
      " [   4   53]\n",
      " [   5  103]\n",
      " [   6  178]\n",
      " [   7  332]\n",
      " [   8  476]\n",
      " [   9  874]]\n",
      "[[   0  862]\n",
      " [   1 1648]\n",
      " [   2 2433]\n",
      " [   3   58]\n",
      " [   4   32]\n",
      " [   5   46]\n",
      " [   6  123]\n",
      " [   7  194]\n",
      " [   8  317]\n",
      " [   9  486]]\n",
      "[[   0  483]\n",
      " [   1  988]\n",
      " [   2 1380]\n",
      " [   3 2471]\n",
      " [   4   71]\n",
      " [   5   29]\n",
      " [   6   72]\n",
      " [   7  120]\n",
      " [   8  179]\n",
      " [   9  315]]\n",
      "[[   0  293]\n",
      " [   1  559]\n",
      " [   2  873]\n",
      " [   3 1508]\n",
      " [   4 2368]\n",
      " [   5   53]\n",
      " [   6   35]\n",
      " [   7   80]\n",
      " [   8  119]\n",
      " [   9  174]]\n",
      "[[   0  180]\n",
      " [   1  342]\n",
      " [   2  520]\n",
      " [   3  843]\n",
      " [   4 1415]\n",
      " [   5 2170]\n",
      " [   6   65]\n",
      " [   7   46]\n",
      " [   8   63]\n",
      " [   9  118]]\n",
      "[[   0  113]\n",
      " [   1  191]\n",
      " [   2  294]\n",
      " [   3  529]\n",
      " [   4  824]\n",
      " [   5 1321]\n",
      " [   6 2431]\n",
      " [   7   57]\n",
      " [   8   32]\n",
      " [   9   62]]\n",
      "[[   0   58]\n",
      " [   1  144]\n",
      " [   2  175]\n",
      " [   3  317]\n",
      " [   4  481]\n",
      " [   5  806]\n",
      " [   6 1391]\n",
      " [   7 2478]\n",
      " [   8   50]\n",
      " [   9   51]]\n",
      "[[   0   31]\n",
      " [   1   98]\n",
      " [   2  108]\n",
      " [   3  178]\n",
      " [   4  280]\n",
      " [   5  448]\n",
      " [   6  836]\n",
      " [   7 1513]\n",
      " [   8 2374]\n",
      " [   9   62]]\n",
      "[[   0   70]\n",
      " [   1   39]\n",
      " [   2   59]\n",
      " [   3  116]\n",
      " [   4  191]\n",
      " [   5  272]\n",
      " [   6  499]\n",
      " [   7  900]\n",
      " [   8 1414]\n",
      " [   9 2371]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\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",
    "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(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \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(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \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(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \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(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[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(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[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(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\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(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[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(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[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(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\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(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[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",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\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": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "11967\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1470]\n",
      " [   1   64]\n",
      " [   2   19]\n",
      " [   3   73]\n",
      " [   4   60]\n",
      " [   5  173]\n",
      " [   6  137]\n",
      " [   7  545]\n",
      " [   8  827]\n",
      " [   9 1436]]\n",
      "[[   0 2679]\n",
      " [   1   64]\n",
      " [   2   33]\n",
      " [   3   73]\n",
      " [   4  108]\n",
      " [   5  173]\n",
      " [   6  279]\n",
      " [   7  545]\n",
      " [   8  827]\n",
      " [   9 1436]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:08:18 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:08:18\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "034396e879814dc6b630007a0c6a763d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:17:19 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3304</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:17:19\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3304\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4873882384</span>                                                        <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m4873882384\u001b[0m                                                        \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10164}, {'accuracy': 0.14057999999999998}, {'accuracy': 0.11542999999999999}, {'accuracy': 0.24634}, {'accuracy': 0.20720999999999998}, {'accuracy': 0.28146}, {'accuracy': 0.27136}, {'accuracy': 0.26776}, {'accuracy': 0.25939999999999996}, {'accuracy': 0.24219}, {'accuracy': 0.31205000000000005}, {'accuracy': 0.29636}, {'accuracy': 0.34513000000000005}, {'accuracy': 0.38976}, {'accuracy': 0.36107999999999996}, {'accuracy': 0.33603000000000005}, {'accuracy': 0.46593}, {'accuracy': 0.4667299999999999}, {'accuracy': 0.46855}, {'accuracy': 0.50625}, {'accuracy': 0.4088}, {'accuracy': 0.5355099999999998}, {'accuracy': 0.49582999999999994}, {'accuracy': 0.473}, {'accuracy': 0.52451}, {'accuracy': 0.59044}, {'accuracy': 0.5158699999999999}, {'accuracy': 0.61534}, {'accuracy': 0.52991}, {'accuracy': 0.59187}, {'accuracy': 0.56673}, {'accuracy': 0.63285}, {'accuracy': 0.5958600000000001}, {'accuracy': 0.5826}, {'accuracy': 0.6588499999999999}, {'accuracy': 0.54993}, {'accuracy': 0.59579}, {'accuracy': 0.56418}, {'accuracy': 0.64261}, {'accuracy': 0.62513}, {'accuracy': 0.5526099999999999}, {'accuracy': 0.5787599999999999}, {'accuracy': 0.6548499999999999}, {'accuracy': 0.62462}, {'accuracy': 0.5570700000000001}, {'accuracy': 0.65919}, {'accuracy': 0.6465599999999999}, {'accuracy': 0.64056}, {'accuracy': 0.63918}, {'accuracy': 0.62873}, {'accuracy': 0.61358}, {'accuracy': 0.6508299999999999}, {'accuracy': 0.7025600000000001}, {'accuracy': 0.60972}, {'accuracy': 0.6661299999999999}, {'accuracy': 0.6337499999999999}, {'accuracy': 0.5927}, {'accuracy': 0.6668900000000001}, {'accuracy': 0.55304}, {'accuracy': 0.6424899999999999}, {'accuracy': 0.7215}, {'accuracy': 0.6607200000000001}, {'accuracy': 0.65933}, {'accuracy': 0.68133}, {'accuracy': 0.6290199999999999}, {'accuracy': 0.7224700000000001}, {'accuracy': 0.60033}, {'accuracy': 0.65704}, {'accuracy': 0.63112}, {'accuracy': 0.6589600000000001}, {'accuracy': 0.66403}, {'accuracy': 0.63844}, {'accuracy': 0.63567}, {'accuracy': 0.6181899999999999}, {'accuracy': 0.6704399999999999}, {'accuracy': 0.6486699999999999}, {'accuracy': 0.75789}, {'accuracy': 0.7305200000000001}, {'accuracy': 0.64187}, {'accuracy': 0.6169100000000001}, {'accuracy': 0.65657}, {'accuracy': 0.6497599999999999}, {'accuracy': 0.73966}, {'accuracy': 0.63823}, {'accuracy': 0.72482}, {'accuracy': 0.72264}, {'accuracy': 0.6668000000000001}, {'accuracy': 0.6831}, {'accuracy': 0.6931200000000001}, {'accuracy': 0.6386499999999999}, {'accuracy': 0.62393}, {'accuracy': 0.65505}, {'accuracy': 0.7570600000000001}, {'accuracy': 0.64857}, {'accuracy': 0.62264}, {'accuracy': 0.72403}, {'accuracy': 0.7221}, {'accuracy': 0.5987399999999999}, {'accuracy': 0.6643399999999999}, {'accuracy': 0.6465}, {'accuracy': 0.6653400000000002}, {'accuracy': 0.7001}, {'accuracy': 0.6779599999999999}, {'accuracy': 0.69804}, {'accuracy': 0.68134}, {'accuracy': 0.7022900000000001}, {'accuracy': 0.64052}, {'accuracy': 0.5900999999999998}, {'accuracy': 0.66198}, {'accuracy': 0.7239300000000001}, {'accuracy': 0.6728799999999999}, {'accuracy': 0.61995}, {'accuracy': 0.62351}, {'accuracy': 0.6845000000000001}, {'accuracy': 0.65887}, {'accuracy': 0.6807000000000001}, {'accuracy': 0.73996}, {'accuracy': 0.68228}, {'accuracy': 0.59575}, {'accuracy': 0.67773}, {'accuracy': 0.6269199999999999}, {'accuracy': 0.6988100000000002}, {'accuracy': 0.62436}, {'accuracy': 0.70177}, {'accuracy': 0.63053}, {'accuracy': 0.6728500000000001}, {'accuracy': 0.69553}, {'accuracy': 0.69139}, {'accuracy': 0.7632800000000001}, {'accuracy': 0.75797}, {'accuracy': 0.5676699999999999}, {'accuracy': 0.71194}, {'accuracy': 0.63588}, {'accuracy': 0.67033}, {'accuracy': 0.7386600000000001}, {'accuracy': 0.6665599999999999}, {'accuracy': 0.6976}, {'accuracy': 0.67584}, {'accuracy': 0.5926099999999999}, {'accuracy': 0.66376}, {'accuracy': 0.67746}, {'accuracy': 0.7565299999999999}, {'accuracy': 0.65319}, {'accuracy': 0.7377499999999999}, {'accuracy': 0.6881}, {'accuracy': 0.7189500000000001}, {'accuracy': 0.71919}, {'accuracy': 0.6626299999999998}, {'accuracy': 0.66093}, {'accuracy': 0.6750900000000001}, {'accuracy': 0.6004}, {'accuracy': 0.67603}, {'accuracy': 0.6211900000000001}, {'accuracy': 0.74672}, {'accuracy': 0.7483}, {'accuracy': 0.6550499999999999}, {'accuracy': 0.6523300000000001}, {'accuracy': 0.76772}, {'accuracy': 0.57718}, {'accuracy': 0.64422}, {'accuracy': 0.65255}, {'accuracy': 0.6620300000000001}, {'accuracy': 0.74616}, {'accuracy': 0.67105}, {'accuracy': 0.67485}, {'accuracy': 0.6788000000000001}, {'accuracy': 0.6950400000000001}, {'accuracy': 0.6940500000000001}, {'accuracy': 0.72484}, {'accuracy': 0.65068}, {'accuracy': 0.79747}, {'accuracy': 0.68297}, {'accuracy': 0.7575700000000001}, {'accuracy': 0.7330099999999999}, {'accuracy': 0.67404}, {'accuracy': 0.74034}, {'accuracy': 0.7078099999999999}, {'accuracy': 0.70744}, {'accuracy': 0.70835}, {'accuracy': 0.72882}, {'accuracy': 0.70852}, {'accuracy': 0.74679}, {'accuracy': 0.76217}, {'accuracy': 0.78617}, {'accuracy': 0.67489}, {'accuracy': 0.69885}, {'accuracy': 0.72}, {'accuracy': 0.65469}, {'accuracy': 0.7498400000000001}, {'accuracy': 0.7354500000000002}, {'accuracy': 0.7225799999999999}, {'accuracy': 0.72304}, {'accuracy': 0.63946}, {'accuracy': 0.5769399999999999}, {'accuracy': 0.7214700000000001}, {'accuracy': 0.79285}, {'accuracy': 0.76129}, {'accuracy': 0.6951799999999999}, {'accuracy': 0.7337}, {'accuracy': 0.63425}, {'accuracy': 0.6875899999999999}, {'accuracy': 0.79966}, {'accuracy': 0.82173}, {'accuracy': 0.78687}, {'accuracy': 0.81182}, {'accuracy': 0.79667}, {'accuracy': 0.8184700000000001}, {'accuracy': 0.8594900000000001}, {'accuracy': 0.8003300000000001}, {'accuracy': 0.8501799999999999}, {'accuracy': 0.845}, {'accuracy': 0.8236700000000001}, {'accuracy': 0.83477}, {'accuracy': 0.84081}, {'accuracy': 0.84108}, {'accuracy': 0.85579}, {'accuracy': 0.83492}, {'accuracy': 0.865}, {'accuracy': 0.84108}, {'accuracy': 0.83599}, {'accuracy': 0.8600199999999999}, {'accuracy': 0.84588}, {'accuracy': 0.83109}, {'accuracy': 0.82263}, {'accuracy': 0.83718}, {'accuracy': 0.8577899999999999}, {'accuracy': 0.8502599999999999}, {'accuracy': 0.8489800000000001}, {'accuracy': 0.8477499999999999}, {'accuracy': 0.8410300000000002}, {'accuracy': 0.8248599999999999}, {'accuracy': 0.83985}, {'accuracy': 0.8437699999999999}, {'accuracy': 0.8396100000000001}, {'accuracy': 0.8302900000000001}, {'accuracy': 0.8465300000000001}, {'accuracy': 0.8499500000000001}, {'accuracy': 0.84437}, {'accuracy': 0.8449300000000001}, {'accuracy': 0.82954}, {'accuracy': 0.8621399999999999}, {'accuracy': 0.8607400000000001}, {'accuracy': 0.8585900000000001}, {'accuracy': 0.8562900000000001}, {'accuracy': 0.84192}, {'accuracy': 0.85268}, {'accuracy': 0.8319899999999999}, {'accuracy': 0.8559600000000002}, {'accuracy': 0.84466}, {'accuracy': 0.86387}, {'accuracy': 0.85394}, {'accuracy': 0.8457100000000001}, {'accuracy': 0.82988}, {'accuracy': 0.8408299999999999}, {'accuracy': 0.83233}, {'accuracy': 0.84799}, {'accuracy': 0.83869}, {'accuracy': 0.8531400000000001}, {'accuracy': 0.8495800000000001}, {'accuracy': 0.84887}, {'accuracy': 0.86364}, {'accuracy': 0.84472}, {'accuracy': 0.8324900000000002}, {'accuracy': 0.84134}, {'accuracy': 0.83301}, {'accuracy': 0.84535}, {'accuracy': 0.84146}, {'accuracy': 0.8481}, {'accuracy': 0.83625}, {'accuracy': 0.8347300000000001}, {'accuracy': 0.8351900000000001}, {'accuracy': 0.8461500000000001}, {'accuracy': 0.8402100000000001}, {'accuracy': 0.84457}, {'accuracy': 0.85449}, {'accuracy': 0.8530899999999999}, {'accuracy': 0.8419799999999998}, {'accuracy': 0.8360199999999999}, {'accuracy': 0.85831}, {'accuracy': 0.84406}, {'accuracy': 0.84161}, {'accuracy': 0.84548}, {'accuracy': 0.8372999999999999}, {'accuracy': 0.82485}, {'accuracy': 0.8463600000000001}, {'accuracy': 0.8439099999999999}, {'accuracy': 0.8514900000000001}, {'accuracy': 0.84162}, {'accuracy': 0.8409500000000001}, {'accuracy': 0.84062}, {'accuracy': 0.85605}, {'accuracy': 0.8483500000000002}, {'accuracy': 0.8579700000000001}, {'accuracy': 0.83722}, {'accuracy': 0.8462299999999999}, {'accuracy': 0.83804}, {'accuracy': 0.8326100000000001}, {'accuracy': 0.8426899999999999}, {'accuracy': 0.8234}, {'accuracy': 0.8333999999999999}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7ea40262-92ce-4927-9b86-47df524fc154",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.83</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.83\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACdHElEQVR4nO3dd3hUZdoG8Hv6pBdSCYHQBJEOgiiIQhTr2kUsIAprw5Z1FVYFyypWFnctuH4ququCuvaCYgSUonTpnRBKekibJFPP98fMOXPOtMwkk0wS7t915ZLMnJl552TMefI8z/u+KkEQBBARERF1EupID4CIiIgonBjcEBERUafC4IaIiIg6FQY3RERE1KkwuCEiIqJOhcENERERdSoMboiIiKhTYXBDREREnQqDGyIiIupUGNwQUatauXIlVCoVVq5cKd126623IicnJ2Jj6kyeeOIJqFSqSA+DqF1hcEPUzu3cuRM333wzsrKyYDAY0LVrV9x0003YuXNnpIfW6l5//XUsXry4VV9j165deOKJJ1BQUNCqr9OWnn32WXzxxReRHgZRxDC4IWrHPvvsMwwfPhz5+fmYPn06Xn/9ddx+++1YsWIFhg8fjs8//zzSQ2xVbRXcPPnkkwxuiDoRbaQHQES+HTx4ELfccgt69eqFX375BampqdJ9999/P8aNG4dbbrkF27ZtQ69evdpsXCaTCTExMW32eh0BzwlR+8LMDVE79eKLL6K+vh7//ve/FYENAKSkpODNN9+EyWTCCy+8AAD49NNPoVKpsGrVKq/nevPNN6FSqbBjxw7ptj179uDaa69FcnIyjEYjRo4cia+++krxuMWLF0vPeffddyMtLQ3dunUDABw5cgR33303+vXrh6ioKHTp0gXXXXdd2DIgOTk52LlzJ1atWgWVSgWVSoXzzjtPur+qqgoPPPAAsrOzYTAY0KdPHzz//PNwOByK51myZAlGjBiBuLg4xMfHY9CgQXjllVek93fdddcBAM4//3zpdeT9QZ5uvfVWxMbG4uDBg7jkkksQFxeHm266CQDgcDiwcOFCnHHGGTAajUhPT8cdd9yBkydPKp5j48aNmDRpElJSUhAVFYWePXvitttuk+731acEAAUFBVCpVAGzWSqVCiaTCe+99570fm699VYAQG1tLR544AHk5OTAYDAgLS0NF1xwATZv3uz3+Yg6ImZuiNqpr7/+Gjk5ORg3bpzP+88991zk5OTg22+/BQBceumliI2Nxccff4zx48crjl26dCnOOOMMDBw4EICzj+ecc85BVlYWZs+ejZiYGHz88ce48sor8b///Q9XXXWV4vF33303UlNTMXfuXJhMJgDAhg0bsHbtWtxwww3o1q0bCgoK8MYbb+C8887Drl27EB0d3aL3v3DhQtx7772IjY3Fo48+CgBIT08HANTX12P8+PE4fvw47rjjDnTv3h1r167FnDlzUFRUhIULFwIAli9fjilTpmDixIl4/vnnAQC7d+/GmjVrcP/99+Pcc8/Ffffdh3/+85/429/+htNPPx0ApP/6Y7PZMGnSJIwdOxYvvfSS9F7vuOMOLF68GNOnT8d9992Hw4cP49VXX8WWLVuwZs0a6HQ6lJaW4sILL0Rqaipmz56NxMREFBQU4LPPPmvR+RL95z//wYwZMzBq1Cj8+c9/BgD07t0bAHDnnXfi008/xaxZszBgwABUVFRg9erV2L17N4YPHx6W1ydqFwQianeqqqoEAMIVV1wR8Lg//elPAgChpqZGEARBmDJlipCWlibYbDbpmKKiIkGtVgtPPfWUdNvEiROFQYMGCY2NjdJtDodDOPvss4W+fftKt7377rsCAGHs2LGK5xQEQaivr/caz7p16wQAwvvvvy/dtmLFCgGAsGLFCum2adOmCT169Aj43gRBEM444wxh/PjxXrc//fTTQkxMjLBv3z7F7bNnzxY0Go1QWFgoCIIg3H///UJ8fLzX2OU++eQTr/EFMm3aNAGAMHv2bMXtv/76qwBA+OCDDxS3L1u2THH7559/LgAQNmzY4Pc1fJ0zQRCEw4cPCwCEd999V7pt3rx5guev8piYGGHatGlez5uQkCDcc889QbxLoo6NZSmidqi2thYAEBcXF/A48f6amhoAwOTJk1FaWqooZ3z66adwOByYPHkyAKCyshI///wzrr/+etTW1qK8vBzl5eWoqKjApEmTsH//fhw/flzxOjNnzoRGo1HcFhUVJf3barWioqICffr0QWJiYquXOT755BOMGzcOSUlJ0vjLy8uRm5sLu92OX375BQCQmJgIk8mE5cuXh30Md911l9eYEhIScMEFFyjGNGLECMTGxmLFihXSmADgm2++gdVqDfu4AklMTMTvv/+OEydOtOnrErU1BjdE7ZAYtIhBjj+eQdBFF12EhIQELF26VDpm6dKlGDp0KE477TQAwIEDByAIAh5//HGkpqYqvubNmwcAKC0tVbxOz549vV67oaEBc+fOlXpeUlJSkJqaiqqqKlRXVzfznQdn//79WLZsmdf4c3NzFeO/++67cdppp+Hiiy9Gt27dcNttt2HZsmUtfn2tViv1HsnHVF1djbS0NK9x1dXVSWMaP348rrnmGjz55JNISUnBFVdcgXfffRdms7nF42rKCy+8gB07diA7OxujRo3CE088gUOHDrX66xK1NfbcELVDCQkJyMzMxLZt2wIet23bNmRlZSE+Ph4AYDAYcOWVV+Lzzz/H66+/jpKSEqxZswbPPvus9Bix4fahhx7CpEmTfD5vnz59FN/LszSie++9F++++y4eeOABjBkzBgkJCVCpVLjhhhu8mnrDzeFw4IILLsDDDz/s834xkEtLS8PWrVvxww8/4Pvvv8f333+Pd999F1OnTsV7773X7Nc3GAxQq5V/GzocDqSlpeGDDz7w+RixKVylUuHTTz/Fb7/9hq+//ho//PADbrvtNrz88sv47bffEBsb63dRPrvd3uwxA8D111+PcePG4fPPP8ePP/6IF198Ec8//zw+++wzXHzxxS16bqL2hMENUTt12WWX4a233sLq1asxduxYr/t//fVXFBQU4I477lDcPnnyZLz33nvIz8/H7t27IQiCVJICIE0b1+l0UqajOT799FNMmzYNL7/8snRbY2Mjqqqqmv2cnvxd5Hv37o26urqgxq/X63H55Zfj8ssvh8PhwN13340333wTjz/+OPr06RO21X179+6Nn376Ceecc47PYNDTWWedhbPOOgvPPPMMPvzwQ9x0001YsmQJZsyYgaSkJADwOpdHjhwJaiyB3lNmZibuvvtu3H333SgtLcXw4cPxzDPPMLihToVlKaJ26q9//SuioqJwxx13oKKiQnFfZWUl7rzzTkRHR+Ovf/2r4r7c3FwkJydj6dKlWLp0KUaNGqUoK6WlpeG8887Dm2++iaKiIq/XLSsrC2p8Go0GgiAobvvXv/7V4uyCXExMjM9g6frrr8e6devwww8/eN1XVVUFm80GAF7nTa1WY/DgwQAglYHE9WlaGpRdf/31sNvtePrpp73us9ls0vOfPHnS67wNHTpUMaYePXpAo9FIvUOi119/Paix+Dpvdrvdq1yYlpaGrl27tklJjKgtMXND1E717dsX7733Hm666SYMGjQIt99+O3r27ImCggK8/fbbKC8vx0cffSRN8xXpdDpcffXVWLJkCUwmE1566SWv537ttdcwduxYDBo0CDNnzkSvXr1QUlKCdevW4dixY/jjjz+aHN9ll12G//znP0hISMCAAQOwbt06/PTTT+jSpUvYzsGIESPwxhtv4O9//zv69OmDtLQ0TJgwAX/961/x1Vdf4bLLLsOtt96KESNGwGQyYfv27fj0009RUFCAlJQUzJgxA5WVlZgwYQK6deuGI0eO4F//+heGDh0qTfceOnQoNBoNnn/+eVRXV8NgMGDChAlIS0sLaazjx4/HHXfcgfnz52Pr1q248MILodPpsH//fnzyySd45ZVXcO211+K9997D66+/jquuugq9e/dGbW0t3nrrLcTHx+OSSy4B4CxLXnfddfjXv/4FlUqF3r1745tvvvHqhQp03n766ScsWLAAXbt2Rc+ePdGvXz9069YN1157LYYMGYLY2Fj89NNP2LBhgyL7RtQpRHayFhE1Zdu2bcKUKVOEzMxMQafTCRkZGcKUKVOE7du3+33M8uXLBQCCSqUSjh496vOYgwcPClOnThUyMjIEnU4nZGVlCZdddpnw6aefSseIU8F9TVs+efKkMH36dCElJUWIjY0VJk2aJOzZs0fo0aOHYhpyS6aCFxcXC5deeqkQFxcnAFBMC6+trRXmzJkj9OnTR9Dr9UJKSopw9tlnCy+99JJgsVgEQRCETz/9VLjwwguFtLQ0Qa/XC927dxfuuOMOoaioSPE6b731ltCrVy9Bo9E0OS182rRpQkxMjN/7//3vfwsjRowQoqKihLi4OGHQoEHCww8/LJw4cUIQBEHYvHmzMGXKFKF79+6CwWAQ0tLShMsuu0zYuHGj4nnKysqEa665RoiOjhaSkpKEO+64Q9ixY0dQU8H37NkjnHvuuUJUVJQAQJg2bZpgNpuFv/71r8KQIUOEuLg4ISYmRhgyZIjw+uuvB/oREHVIKkHwyI8SERERdWDsuSEiIqJOhcENERERdSoMboiIiKhTYXBDREREnUrEg5vXXnsNOTk5MBqNGD16NNavX+/3WKvViqeeegq9e/eG0WjEkCFDwrKUOhEREXUeEQ1uli5diry8PMybNw+bN2/GkCFDMGnSJL9rOTz22GN488038a9//Qu7du3CnXfeiauuugpbtmxp45ETERFRexXRqeCjR4/GmWeeiVdffRWAc2+W7Oxs3HvvvZg9e7bX8V27dsWjjz6Ke+65R7rtmmuuQVRUFP773/8G9ZoOhwMnTpxAXFxc2JZdJyIiotYlCAJqa2vRtWtXr73dPEVshWKLxYJNmzZhzpw50m1qtRq5ublYt26dz8eYzWYYjUbFbVFRUVi9enXQr3vixAlkZ2c3b9BEREQUUUePHkW3bt0CHhOx4Ka8vBx2ux3p6emK29PT07Fnzx6fj5k0aRIWLFiAc889F71790Z+fj4+++yzgHvZmM1mxb4pYqLq6NGj0k7KRERE1L7V1NQgOzsbcXFxTR7bofaWeuWVVzBz5kz0799f2m9l+vTpeOedd/w+Zv78+XjyySe9bo+Pj2dwQ0RE1MEE01ISsYbilJQUaDQalJSUKG4vKSlBRkaGz8ekpqbiiy++gMlkwpEjR7Bnzx7ExsaiV69efl9nzpw5qK6ulr6OHj0a1vdBRERE7UvEghu9Xo8RI0YgPz9fus3hcCA/Px9jxowJ+Fij0YisrCzYbDb873//wxVXXOH3WIPBIGVpmK0hIiLq/CJalsrLy8O0adMwcuRIjBo1CgsXLoTJZML06dMBAFOnTkVWVhbmz58PAPj9999x/PhxDB06FMePH8cTTzwBh8OBhx9+OJJvg4iIiNqRiAY3kydPRllZGebOnYvi4mIMHToUy5Ytk5qMCwsLFdO9Ghsb8dhjj+HQoUOIjY3FJZdcgv/85z9ITEyM0DsgIiKi9iai69xEQk1NDRISElBdXc0SFRERUQcRyvU74tsvEBEREYUTgxsiIiLqVBjcEBERUafC4IaIiIg6FQY3RERE1KkwuCEiIqJOhcENERERdSoMboiIqFXZ7A6YbfZID4NOIQxuiIioVV27aB3Gv7ASDZaOGeDsKa7BKz/tR6O1+eP/eU8JNh05GcZRUSAR3X6BiIg6N5PZhq1HqwAA+0pqMSQ7MaJjue+jLYiP0uHms7pjRI/koB739292Y/WBchh1atwxvnfIr3ukwoTb39uIeKMOmx+/ABq1KuTnoNAwc0NERE36v18P4d01h0N+XFF1g/TvggoTAOBgWR0ufuVXLN9VErbxBeOXfWXI31OKz7ccxzVvrMP9S7agos4c8DGCIGDniWoAwNfbTjTrdX8/VAlBAKobrNI5aE1mmx31Flurv057xuCGiIgCqm6w4u/f7sbT3+wKubR0oqpR+ndBeT0A4Istx7G7qAZv/XLI52Oe+XYXrn9zHWoarc0ftA9F1e6xqFXAl1tP4IJ//IKv//AOWgRBQKPVjtJaM07WO8ex43gNDpXVhfy6G49USv/eU1TbjJEHTxAEXPPGWuS+vAp15pYFOBabA9UNzvc+57PtmPDySlTXh/dn0loY3BARUUDlruyGQ0BQAYcgCLjp/37Dpf/8FUcq66XbxazF4XLnf7ceq/JqNLbZHVi8tgDrD1fig98Kw/UWAAAlNc7g5rZzeuLzu89B/4w4VJosuPejLdhQUKk49rllezD4yR/xycajitu//qMo5NfdWODutdlTXNOMkfu2/nAlvtx6XJGlKa+zYMfxGpyobvR6T6G6/b0NGPv8z1h7sBwfrS/EoTITfj9c0dJhtwkGN0REFFBFnUX6d20Qwc2RinqsOVCBnSdqsGpvqXS7GNwcqXAGPBabA9uPVSseW1BRD6tdAAC8u+YwLDZHi8cvEoOb9HgDhmQn4qtZYzGxfxoA4Oc9pVh/uBJPfr0TjVY7VuwphcXmwKsrDgAAYvQaAMCXW49DEISAr/P99iJc9q9fse5gBSrqzDhU7i5F7S4KT3BTabLg5rd/x/1LtmL0s/lYf9gZyMgzSxsOBxfcNFrtXj/XmkYrVh8oR22jDfd8sFm6fX9p6JmrSGBwQ0REAVWa3H0pNY02fLe9CF9sOe73eHnGYO1B91/6BeUmCIKAAtnFfkOBcgbRgVJ32aa01oxX8veFXJ6y2Bz4fMsxHDtZr7i92BXcZCQYAQB6rRqTBmYAcGZBZv9vG95dU4Cv/jghBWCNVmdwdcuYHMToNThUblK8J1/eXn0YO47X4LbFG/DGyoMAAK2riXh3mMpS3+8okgK/2kYbXsnfBwA4WOY+t+uDCG4cDgE3/Ps3jH1+hRT8AcDWwiqIMdxJWSlqf0nrltXChcENEREFVGFyZ27Kas24+4PNeGDpVvy4s9jn8fIpz/WyHp2T9VYcKjehVtYL4lk62VfizAxEuzIlr604iDP//hNmfbgZhRXKYMUXi82BWR9uxoNL/8DkN39TlGxKapxBWnq8UbptVI5zxtTmwpNShuWXfWUwe2SMRvZIwtXDuwEA3l9X4PW6B0pr8eIPe1BRZ8Y2VzaqwWrH/612NmFPOsMZRB2vapD6WHw5XG7Co59vVzRi+/LVVmef0JRR2QCcTcvVDVZF5mbbseomp6//vKcUW49WobrBKj0n4DwfvjBzQ0REnYK8LHVU1kPz+Jc7fF6oNwZYz2Xl3jIAkKZDbyyohMPhLvPsc2UG7p3QF49dejr6psXCbHPgm21F+PN/NiqO9eWJr3fiR9csrONVDXhh2V5sOlKJOrMNxa6G4gxZcNOjSzRS4wyQV5pWucYo1y8jDreM6QEAWL6rxCv4ePa7PXhtxUHc9d/NsNgdSInV44Yzs5EWZ4Beo8YtY3ogKzEKALC3WJn9qKq34OONR1FntuEvH2/FB78X4p/5+xXH7DhejZv/73dsLjyJ4upGrHcFhbMm9EWftFjYHAJW7i1VlMAsdge2Hq1CTaMVb68+rBjzE1/txLVvrMWC5fuk2776Qx7cVAEAxvTqAgAY3j0RAHCgtA5vrjqIGe9tCHvDdzhxnRsiIgqoUpa5OXbSfYEsqTHj3TWH8UDuadJtJ00WHPDx131anAGltWasdPXgjOiRhJ3Hq1HTaMO+0lr0z4gHAOmx/TPicH7/NNw+tie2HXNe2PcU1+L7HcW4dHCmayz1ePGHvbh4YAYuGpgJh0OQZj5NHdMD7687gsVrC7B4bQHO6pWMBlcWQyxLAYBKpcKonsn4dpu7UVjMLGnVKtgcAmINWnRLinIem5OM9QWVWLajGNPP6QnA2UAtZqvEoGNUz2Q8d81gAIDdIUCjVqF/RhyOVzVg54lqjOrpXmPnxR/24oPfC/HaigNSOWzl3jIIggCVyhkEvvrzAaw+UI7jVQ248Ix0CIIzm5SVGIULBqTjQGkdlu8qwUFX5iY93oCSGjM+3XQMR340YUPBSazeX4Z3p4+CxeZs2hZp1SoIALYfr8bhchN6JEdjiytz8+ilp0OjViE7ORrDn14Os82B55btgSAAS9YX4s/nOtf92V9Si8zEKMQa2kdYwcwNEREFVKEIbpSloR3H3Q3Baw+W45nvdgMAUmL1iuPG9HZmAH7dXw4A6JMWi+E9kgC4G19tdgcOuXpG+qTFAnAGH0OyE3HbWGcg8Y+f9sHuEFBdb8Wt727Al1tPYNaHW7D2YLmz5NVog1GnxtzLBuDq4VkQ18v77ZDzNRKidDDqNIqxiaUplcfaelcNy8LYPim4c3wvKcgY2zcFALD1aBVKaxrxv03HcLCsziuDdWaOO3gRs1Ti+117sAL7Smrx8Kd/oKi6AT/vcQZ8R2Rlt6LqRux1ZbEarXas2ufMJh0uN+HNVc4p9FPPzgEAXDAgHQDw464S6TnudC02+OmmY1Jf08p9ZThSYcIRj7V2pozqjnP6ON9X3sdb8dQ3u6Tz2D8jDqdnxiPWoEXvVOfPRMxy/fe3QjgcAtYcKMcF//gFf/tsO9oLBjdERBSQfKG7o5XKcoyYaTlUVodp76zHp5uOAXD2mCRE6QAAXWL0GNg1QfG4nC7RGOlaIVi8+BZU1MNidyBar5FKOKLbx/VEnFGLA6V12Fx4Eo/8bxsOlNZBrQJsDgF3f7AZ+bud5ahBWQnQatRYcP1Q7Pv7xYg3urMJ8pKUKHdAOuIMWlwxpCtSYg3S7QOzEvDfGaMxa0Jf6bahrhWWtxRW4W+fb8dfPvkD9y/Z6vWc8uBGNP60VADA2gPleOzzHfh44zHc9d/NKKpuhE6jgk6jQrxRK5WAVuxxBjSr95ejwWpXrGw8ZVQ2/jSkq3NM3RLRPTlaajCONWhx69k5eOm6IYjRa6DXqtE3LRaCAPz3tyPSz2xItwSs+ut5eOJPZ+D6kd2k9yVmdYZ0S4RW4w4T+roCTlFhZT1W7SvDx67p8msPlnu950hpH/kjIiJqtyp9ZG4GZsVjx/EaFFbWo9Fqx7Pf7YHVLmBgVjwuHpiJyWdmY29xLTYeOYnMRCOuG9kN//71EMpqnYFSTpcYxLqCjg0FlRAEQZop1SctFmqPLQrijTqc3bsLfthZgt8PVUjZjo9mnoV5X+3EnuJa/Otn57TtId0SpcdpNWoM7Z6EX1yZj/QE7+AmKzEKW+ZeAJVKhZv/73dpXZ+clBivY8XtIwor63Giyhno7TzhnN49skcSNh45iYQoHU7PjPd67IDMeHSJ0aPCZJHKV+LWFGf16oIn/nQG9Bo1VuwtxebCKizfVYyZ43rix13Oxu2bRndHndkGs82BJ/50hvS8arUKsy/uj7tdU7aNOg1UKhWuHdENE/unodFmx64TNbj9vY34eOMx6LXOgKV3Wix6dHG+x0sHZaLr3VHYfOQkDrsyYNNcmSHRaenO4EavUePyIV3xv83H8OqKA9jjmt5eXmdBWa0ZqXEGRBqDGyIiCqhc1lBscs1+6psWhyMV9ahttGHJ+kL8tLsEGrUKCycPRZ+0OOcx6bHO4CYhConRejx71SDMfH8jAKBXagyyEqOhVatQVN2IYycbpFlG/TPifI5jSHYifthZgo/WH3U17Rowqmcypp2dgzmfbZdW5PXcv2p490QpuMmI933hFTMUfdNjse6Qc6p3Tpdor+MSonTonRqDg2Um2Dyam28b2xPTzs5BRoLR5/5RarUK556Wis99TKM/t2+qVPY5v18agJ3YXFiF0c/mS427F52RgbNd5SNPFw/MQLReg3qLHWd0dQdWSTHO8mBanBGZCUYUVTfi443O7FofWSZGpVJhePckDO+e5PP5AWBc31S8vHwfrhvZDXef3wffbj/htRnorqIa1ByyYkL/NMREsP+GZSkiIvLL4RBwst7idXtClE4qU4gzbm44M1sKbABnNgIAhrnKLBcMSMfcywZg1vl90Ds1FlF6DQZmOctVG49USiv5jvSzoeVQV0bmuCtjMqJHIlQqFS4ZlCllIwB36Ugkv2Cn+yhLyfVNd45fq1Z5lcZEw2TPZ9SpZbcn4vIhXX2WpERiaQoAzuvn/ve5stuzk6PxzFUDkezK8ljtAnqnxuDMnv6fV6VS4YcHzsX1I7vhb5ec7nW/Rq2SXlvMnvVJjfU6LpAh2YnY9NgFePJPZyArMQp5F5zmdcz7awtw70dbkLtgVZMz21oTMzdERORXTaMVdh8XqcRoHfqkxWJzYRVqGp0Zk6uHZymOuWJoFkb1TFb0uYiNwaJRPZOx9WgVVu4tw9ZjVQDg9yI+qFsCVCp3Q6sYBCVE6XDBgHR8u60IyTF6dEtSBiXyTE5Twc1AV9ajT1qsot9Ebmh2otRb9MTlZ+DxL3cgp0sMMhN8B0Ny556WinijFnFGHV6ZPAxT3voNyTF6qeQjuml0D1wzvBv+OFqFLrF69OgSA52f8Yiyk6PxwrVD/N4/rm8qlmxwbyfROy204AYAkmPcjeK3ndMT320vxq4TNcgdkIbvthcj31UuPK9fqldpsS0xuCEiIr/kJSm5hCidtNAe4GwaHprtXdJo6oJ/fr80/PuXQ/jStYBcSqzeZzkIAOKMOvRJjZUWkhNnHwHALWf1wPfbizChf5o0s0k+1v4ZcdhTXIvsZN/PLRqanYiFk4ein5/SGACc1SsZapXzvV0/MhvDuichMVoX8HlFyTF6/PjgeOg0KiRE6/Dd/eP8HmvUaTDalf0Kh3P6dIFa5dwjTKdRoUcT56IpWo0aS/58FqobrNhSeBLfbXcv6njZ4K4tHW6LMLghIiK/5M3EconROmk2FABMPD3NZ59JU87qlYxeqTHSFPCRPZK9ghO5IdmJ2F9aB71WjYFZ7t6Ss3p1wa+PTECXGL3Px71w7WD8dqgCY/30rIhUKhWuHJYV8Jg+aXFY8ucxSIszQK1WBQyEfMnw0dTcFhKj9RjcLRFbj1Yhp0uM38xUKIw6DYw6DfpluH8WKbEGqSQZKey5ISIiAM51ZjyJ+0p5Ls6WGKVHn1T3Rf2CARnNek2VSoWbRveQvh+Z47+hFXD3zwztlgiDVrleTVZilNcaNqLB3RLx53N7NysA82VUz2Sfs6naO7G357QQA7KmdE+ORpTr3F86KCNs57m5GNwQERE+3ngUZ8z7AStku3gD7rJUD49SUXyUDt2SotAvPQ45XaKbzIgEcs3wLBhcDcFN/cV/zYgsPJDbF09ecUbA48i3P5/bC7PO74OHLuwX1ufVqFU4p08XaNUqXDsiO6zP3RwsSxEREZbvKoHZ5sCa/eWuqchOYlkqp0uMtJ4L4CxLqdUqfHPfWNgdgt+MSTASo/VYdMsIHD/ZIM2e8seg1Si2e6DQxBq0eGhSeAMb0cIbhuGkydJkX1NbYHBDRETSnkSltWbF7cU1zs0mPTM3Yr+NTqNGC+IaiTygoo4p1qDl3lJERNQ+WO0OFLr2JCqtbVTcd8gV9PRJi1VcuOTNxETtDYMbIqJTXGFlvbTabmmtGQXlJsz5bBtKaxpx0DWLqXdqLOJc2yXE6DVNrrlCFEntI39EREQRc9C1bgwAlNWY8eYvB/HR+qMwWx3Sara9UmMQZ9SiqNrZI0PUnkU89H7ttdeQk5MDo9GI0aNHY/369QGPX7hwIfr164eoqChkZ2fjwQcfRGNjY8DHEBGRf2J2BgBqzTbscjUOf7ejCACQHm9AnFGHOKOzFMWSFLV3EQ1uli5diry8PMybNw+bN2/GkCFDMGnSJJSWlvo8/sMPP8Ts2bMxb9487N69G2+//TaWLl2Kv/3tb208ciKizkNsJhaJs6Iarc51b8QNFsWeGwY31N5FNLhZsGABZs6cienTp2PAgAFYtGgRoqOj8c477/g8fu3atTjnnHNw4403IicnBxdeeCGmTJnSZLaHiIj8O+QR3Hjudi3uVi323AS71QBRpEQsuLFYLNi0aRNyc3Pdg1GrkZubi3Xr1vl8zNlnn41NmzZJwcyhQ4fw3Xff4ZJLLmmTMRMRdTaCIEhlqXij7zZMd3DDshR1DBFrKC4vL4fdbkd6erri9vT0dOzZs8fnY2688UaUl5dj7NixEAQBNpsNd955Z8CylNlshtnsXrehpqbG77FERM11oqoBBRUmnN27+Sv1RkJVvRXVDVYAzi0Fftrt3RYgBjfibtvtYZE2okAi3lAcipUrV+LZZ5/F66+/js2bN+Ozzz7Dt99+i6efftrvY+bPn4+EhATpKzs78stCE1Hnc+9HW3DjW7/jQGld0we3I3VmGwAgSqdRBC1Zie7dvMWem1vPzsFrNw7HrWfntOkYiUIVscxNSkoKNBoNSkpKFLeXlJQgI8P3BmyPP/44brnlFsyYMQMAMGjQIJhMJvz5z3/Go48+CrXaO1abM2cO8vLypO9ramoY4BBR2JW4VvItrWmUgoH2YPuxaiRG6/xmW8w2Z9OwQadGWpx7t+qLB2bgj2NViNJrkR5vAADEGLS4dHBm6w+aqIUilrnR6/UYMWIE8vPzpdscDgfy8/MxZswYn4+pr6/3CmA0Gue634Ig+HoIDAYD4uPjFV9EROFmde2oLQYL7UFFnRlXvb4GN7/9u99jzDY7AMCgVSMtziDd3is1Fp/ceTbev20UVKrI7vBMFKqILuKXl5eHadOmYeTIkRg1ahQWLlwIk8mE6dOnAwCmTp2KrKwszJ8/HwBw+eWXY8GCBRg2bBhGjx6NAwcO4PHHH8fll18uBTlERJFgtTv/wBKDhfaguKYRNoeAIxX1aLTafW5uKQZjeq0aafHu4MZzLymijiSiwc3kyZNRVlaGuXPnori4GEOHDsWyZcukJuPCwkJFpuaxxx6DSqXCY489huPHjyM1NRWXX345nnnmmUi9BSIiAIDVFt7MzYo9peidGovuLQgyTGZ3oFVS04geXWK8jjG71rIxaDWKshSDG+rIIr79wqxZszBr1iyf961cuVLxvVarxbx58zBv3rw2GBkRUfAsYSxLrdpXhumLN0CrVuHAs81f6sJksUn/Lqr2HdyI4zZo1chKikKUToNovQaZCVFexxJ1FBEPboiIOoNw9twsc2174LmYXqjqZZmb4mrf29SYre6em1iDFl/ccw4MWjU0avbZUMfF4IaIqIXsDgFiHGIJQ3Bzoio8++WZzMrMjS/SbCmtsx+nX0ZcWF6bKJI61Do3RETtkZi1AcLTUOwvyxIqeVmquLrB5zHyqeBEnQU/zURELWSRBzfWMGRu/AQioaq3yMpSNf4yN85j9BpeDqjz4KeZiKiFrDZ55qZlwY0gCKhttCm+b646szxz46/nRszccDkN6jwY3BARtZC88belPTdltWbF9y1pKq4PoudGPluKqLPgp5mITkkOh4Dtx6rD0gBssYWv56agol7xfUsyQSZZWaqszqzoDZKe38rghjoffpqJ6JT0zfYiXP7qarySv6/Fz6VsKG5ZsFRQblJ8L07Vbo56i7y8BZR6ZIUA+fYLLEtR58HghojCZteJGpTWhmemT2srrHAGEcdPtrx5V9x6AWh5WaqgwiO4acHz1ZmVgZGvvhv59gtEnQU/zUQUFsXVjbj81dUY9Uw+quutkR5Ok8QgxNrChfKA8E4FD2dwI++5AfwFN+5F/Ig6C36aiSgsjp6sh90VKDzz3a4Ij6ZpYtBg89GHEipLGMtSu4tqFd+3JFgSe27ijc71Wn1NB7dwnRvqhPhpJvKwbEcRznnuZ2w6Utkqz19RZ8aCH/ei0KNxtKOTr6ny8cZj2FJ4skXP12CxY9W+slbbZVsMQuzhyNzIAhqLzYEPfj+C2xdvQIMltLFXmiw47Oq5idFrpOdrLnGF4q6Jzn2i6hptXsd4rlBM1BkwuCHycOd/N+N4VQOmvr2+VZ7/s83H8c+fD+D/Vh9qleePFM8SyI4TNS16vkWrDmLaO+vx8YajLXoef8SLurxfprnkz2G2OfDo5zuQv6cU76w5HNLziAFh79QYpMcbFeNsDrGhOM31XHVm73IhZ0tRZ8RPM5EfphD/6g5WdYPzAlPr46/ojqzOI7hpabnnmKvR90SYtiLwJGaEwpK58dNzc7C0LqTn2ewKboZ3T5IafFuy4rHJ1VCcFmcA4N1gDMhWKGZwQ50IP81EbazRNbW3sQVTfNujeo9gsKVBQ4PVGSy11nmSGorD3HMjLyOV1XlPvQ5k85EqAMDwHklSJsVXWa6s1oxvtp2AI8A5tjsENLjOXXq8M7gxmQOVpXg5oM6Dn2YiD6muv3Jbi3gxaWnjaXsj36QRaHm5RwyWwnGeDpXVYd6XO/D0N7uk7QykhuIwZ24aZZkWz9WGA7HZHfjjWBUAZ+ZG7IHx9f7v/mATZn24BW+sOuj3+eRr3KTFOctSgYMb9txQ58HghshDaqw7uKm3hL90JGYiWqtRNlLqPUoeLS1LicFNSzM3K/eWInfBKry37gjeXn0YJTXOgMPSRHDzf78ewoNLtwbMjojkwU1to7uvJZTgZl9JHeotdsQZtOibFivNXvL1OdlQ4Cxf/TN/v9/nE8+fRq1CcozeOTYfwQ1nS1FnxE8zkQf5L/lwLPDmqVHM3IRh9+j2xDNz09KMSEOYMjebC6sgH4o4TjFo8BeEvbbiAD7fchz7Smt93i9ntblfQOypAoDKekvQZa/CSucsqd5psVCrVe6yVIDPSaBzI/ZARes1iHVNBfedueE6N9T58NNM5EF+MTnWCsGN2Rq+cku4hKPvxPPCaXO0NHPjCkJaGAR6TqVu9Dj//nqDxIZyXwGB12vIzp/86QQBOFHl/AwVVtQHzEKV11kAuMuigcpS3ZKipH+X+li7BnBn0mINWsQaAgU3LEtR58PghsiDvAxw7KTvtWh+3V+G819aid8PVYT8/FLmpp2UpY5XNWD4U8vxxFc7W/Q8YjCg1zh/rdj89Nx8v70IGwuaXkPInblpWXnKO7hxKG73FdjZHYJ0v8nHDCNPgYLDgop67DxRjXNfXIGHPvnD73HlrubjlFgxuFH7HD/gPseAu0TlScxQRes1UnDjc7YUp4JTJ8RPM5EH+V/K/jI3y3eV4HC5CT/vKQ35+T0zB5G2/VgVas02rDlQ3qLnEde5iY/SAfBdliqpacRdH2zG3R9sbvr5xPNkdeCzzccwcN4P+H57UcjjstiVF3TP8+9rnA2yQMpzFpgvgYKbwgoTDrimhO84Xu33ODG4SY119scE6rmRB3ob/ASKYpYmpsnMDctS1Pnw00zkoTGIslRL+kHM7aznpsa13k5L192RlvqPcl5IffWyiA22ZXVmadaSP1JDsc2OjUdOwuYQ/GYpAvFXlpIain1kmOSN5ME0lQeaGVZQUS/1vxTXNPp93+W1zrJUl9imy1KNstt+P+wnuHGdvxi9FjGu4KbBaofJbMOmI5VSOY5lKeqMGNwQeQimLNXQgrVqzO1stlSdFNy0bLNLMQhICJC5ETMHgqAMIj3Z7A4p+DBbHWh0XairGiwhj8szuGnwOP++eoMaLe7bglnMMdAWCUcqTNL7brQ6UNPgO1jyLEtJi/j5eG75tg67i2pQafI+L/VS5kaDGIM7cHn2u9245o11+HLrccXYOVuKOhN+mok8BFOWEi/MzQpu2tk6N2LGxmSxt2j6ttibIgU3PrIZ8hlVnrOr5Opl57XRZpeyODUNoQdgFrtn5kZ5/n01FMvLUg1BZW78n7eyWrNiTyfPzSsrTRbY7A5ZcOMqS0mzpZSfMUEQ0OgKzMQp3msPepcUxaAsWq+FQauR+nS2FFYBcH62bXaHFISyLEWdCT/NRDKCICj+Cq8wWXyuc9KSvpn21nMjz9h4bqEQCjE7IQY3Vh8ZEXlDq+e6OHLyzITZ6pCCjar6ZgQ3TZSlfJWU5KWo5jYUi+ehttGmeN/y4OZgWR1GPfMT7l+6FRWu2VIpccqGYs/PicXugFjZyj09DQB89kvJe26c/3VmbwoqnFPOG612ReDH7ReoM+GnmUjGV8DhsywgK0vVW2z4dlsRqoO88IoXV7tDkC6KDocQ1GJxoWqqrwVQ9tq0pO9GzK6IF3VfGRH55poBMzcWZeamQSpLhR7ceP78vBqKfQQmyoZi/+MsKDdh5d5SnwGSuOVBrdmmaOQtke2V9duhCtgcAlbtLZMW2EtpoudGXs6beHo6AGC1r+DGNW5xd3ExyHEvjuhQ9H3JZ2ARdXT8NFOns7Gg0m+vTFMCBTKK22QXiHfXFOCeDzdjyFM/4oedxSG9hvjvae+ux4i/L8c7qw+HZc0ZAHjy6504+7mfffZjyNXKdoquaWbfjSAI0sU03ui/LCXPDAVaP0YeUMgzN9XNKUu5znGc6+LeaHWW38Tgy+dsKYs8uPGfubn7g8249d0N2F3kvQO6uKt3baMVdRbfZan9Jc5ZVOJ50WvUiHctuOdvtpQYnKlVwNg+KdBpVDha2YBHPt2GFbLZe2JmLNr1vsUZU9Lz2OzS50+rVkHL4IY6EX6aqcP5z7oCTHh5pc8A5tjJely7aB3u+M+mZj23eCFRqdx/yfoKbsSeB7PNjmLZX+L3fLA5YB+OIAiK+8V+il/3l+NkvRVPfbMLC3/a16yxe1q+qwRF1Y3YHmD6MRCezE2j1V0qkcpSPoI0eYknUKNug0fmRgx2quutQWWj5MTSizhFvdHqUJRjmjsVXBAEaYq3r96sDFdw02h1KLJ6JfLgxmP145RYPVQqFQB4rVBcb7Fh54lq6fNj1GkQY9BiWPckAMDSjUfx2Bc7pOeSylKuzI1ncGO2OjgNnDotfqKpw/n6jyIcKjNh3UHvBfTEQKPEz6qtTZEvaBbluig0+Li4NcoyN/JgxeYQAvaF2ByCYgVbs83hVb45UtG8rJMnMRvQVLZDHtA0p2FX/loAEOfKPPgqS8lLUfUBMzfucyoI7unqFrsD6w5V4JJXfsXIvy/HPR9sbjLYETM3YnDTYLUryjF2h+D1HPLX95dhqjBZpCDJ1zkWMzcAUFTtDn7kn819rsyNKEW2aatYlhJf49Z3NuDSf67Gd9ud2cEonfP+uZcNwDl9ugAAqurdWToxAI/yKEvJ73fPlOI0cOpcGNxQh1NvdV5sfDW/es6ECZV8zQ/x4uErEyP13NjsXpmdQKUdz+cy2xxeZYdA04qDJQiCFLQ0HdxYZf9uXuamXrYars6V8bL6CG4UZakAmRvPbIn8ov32r4exq6gG5XUWfLu9yO/UapF4PhOi3GUpzxlUntkb+c/JV+YOgCJj5+uzGGfUItoVWMiPFctSVfUWr401U2LlwY0yc7PetVjfR+sLATgzNwAwMCsB/7h+qDRWMVCzuPa7EjOQ3pkbd1mK/TbU2fATTR2OeOGr83EhbmjhTCR5ml7K3AQIbswemRsg8Hoxnmu7mG12r9s8L7zN0Wh1Z4SaysYoy1LNy9yI5aYYgxZajbOsYvcxW0qeBQnUqNtgVd4nb9j17G9pqk9IKksZfWduAO/+oIYgMjfinlH+RBu0UhZLHsgVVzsDGs+sDQB0cU3tBpQ9N/LPWFK0TnE/ABhdn1WH4P7si2VBnZ/gplFeluIaN9TJ8BNNHY544an1mblxT/MNtTcDkGVudGrpL2PP4MXZN+PeH8ozyxAok+CZpZH3PYjCkbmRNwmHUpZqaeYmRq+BVu3K3NgFbCyoxP1LtkibOyp6bgJMsQ7UxHuiWllybDK48ShLma0Ory0ZPBfyqw+iodhzvRpPMXoN4lwBlVyFyQyr3YF9Jc5+m6xE9yaY8rKUXuOeLXWozOT1PEbZisJRsrKS+HmVghtXBsirLCUL8thzQ50NP9HU4YgXG18XYnkgEmhJfH/cv+w1MLr+mvXsuZFnhRplM3lEgctSnpkbh3fmJgzBjTyrFWiKutWuHL+vgDEY8gXjxMyNze7A4rUF+HLrCSxzzSILNnMTaA0cT00FZO6ylNhQ7J0t88zcNAbRUHyiKnBwI9+wUk4QgNJaM/a7gpsLBqRDo3aeM0VZSude5+ZAmTvLI+4ebpRlW3QaNXSu8y6OVwxu9K7bYw3Kvhr5bCluvUCdTbsIbl577TXk5OTAaDRi9OjRWL9+vd9jzzvvPKhUKq+vSy+9tA1HTJEkXhR9lVDkF6XmlHcUZSmd77KUYoE52Ros4lTjQGUgr8yNR8nBeVsYghtZEBEo2PIs7TW3odgkW+pfJ5Wl3DPD3KsgB7c4XjCbVfZOjQlqzFLmRl6WsgXuuVFmbnwHT8XVTZSl9O6ylEj8/ub/+x0frT8KADijazx6pjjfi7g6MaBcofhAiXtWlbiSsVg2FXl+XsX3LZWljJwtRaeOiH+ily5diry8PMybNw+bN2/GkCFDMGnSJJSW+t5t+bPPPkNRUZH0tWPHDmg0Glx33XVtPHKKBKvdIWVkAjUUA83LgLj/klX7bShu8MgOiRfsNNeibTUBMglemRurw3sF2nBnbgJc/D3PYXPLUmJwE63XQiMrS1lcPysxQAh6nRtr4HHE6DXo6irnNDVmszQVXNZQ7BXc+N5/yjlOP5mbau/MjTybEmPQSAGV6Lx+zhWFD5ebYLE70CslBuNPS8Vd43tjXN8UjD8tVTpWvoifPHMjfl6MHtkWz9l94rkXgxtfs6XkZViizsQ7Z9rGFixYgJkzZ2L69OkAgEWLFuHbb7/FO++8g9mzZ3sdn5ycrPh+yZIliI6OZnDTgW0sqMTqA+WYdX6fJhcSk/9F7auhWJG5aVFwo5GaND3LUp7BTpXJGTykxRlxsMwUMFPiuU+Qsyzl0XMTYsZpx/FqHCyrwxVDs6Tb5OWlQMGN51ib6l9ptNpx7GQ9+qTFKW4Xfy6xBi10rhKLzeGA1eZQ3G8KcoViX9Pv5TISjFIPTaAxy7fTcGduvPucvBqKPWZLORwC1K73JSr2EdzEGnRotDozK56ZG4NWjVcmD8Vd43ujtLYR2cnR6JUSA5VKhWtGdMM1I7opnku+/YK4no6c0WP6drReC8AsjT24hmLOlqLOKaKfaIvFgk2bNiE3N1e6Ta1WIzc3F+vWrQvqOd5++23ccMMNiImJaa1hUit7+tvdWPjTfqw/XNnksfKLnq+/2OUXpebsui0GHwadvCzl/696wB1IiMvtB24o9t4KwCu48ROUbSioxKebjnndftm/VuP+JVuxufCke0xBZm48z2FTWZC5X+5A7oJfvH5WJtlUcI0U3Li3lxB7aORZkEClp6bKUl0To6RgJdD5lvddJUgNxb4yN/5nSwHeP3OHQ/AT3LgDjmi9RhHcxBq0UKtVGNA1Huf1S0Pv1FhpwT5fxGxKvcWGw+XeDcWe2RYx2PHqudE6XyNG76OhmD031ElFNLgpLy+H3W5Henq64vb09HQUFze9jP369euxY8cOzJgxw+8xZrMZNTU1ii9qX8pda30Es/S/vP+hrcpSnhc2fysQy5fb98f3OjfO1xTXRPHXc/PAkq146JM/sK+kFr/uL8PiNYcV56BI1uBa1xjcbCnv4Mb72HdWH8Z5L67AsZP10qydQ2XKTEK9Yiq489eKzS4Lblzrryh7bmxYe6AcO094r6DcZOYm3ihtUxDofMuzYPGyhmKvnhuPbJnn63tmmSrrLT4zbPK+Fmfmxl2W8iwLNUUMOByC7+Z478yNMtNoDabnRhbME3UmES9LtcTbb7+NQYMGYdSoUX6PmT9/Pp588sk2HBWFSmwI9bdYmpz8L3pfwZAyc9OyspTYw+DVc2Px/bxpruAmUM+N55jkDcXxRh3qLXZYfGScrHYHjrvWVdldVIOnv9mN8joz5Jc8eWVBHvTUNtpgdwhSRkVODAy6xOhRYbL4HPt324tQUFGP9Ycr3WsMyZ7/f5uOSRs3Ohfxc8+WknpuzDbXAnPu5y2srMct76xHYpQOGx7NVZR9As2kAoDMBKO0qm6goFge4Io9N0E1FHv8zOvNdsBViauoM+P7Hb7/+JKXfmIM3pmbUDTV5Bul89dQLK7mrOy58Xx9i91dEmVDMXU2Ef1Ep6SkQKPRoKSkRHF7SUkJMjIyAj7WZDJhyZIluP322wMeN2fOHFRXV0tfR48ebfG4KXzsDkEq63g22/oiD17qzDavtWzkPS0tnS0l/mXcVM+NyF2Wcl5sLTYHvtx6XHHxDZS5ES++vsYtzpABgPWHK6XvP97oLlMp1qvxahT2HQCIj3E353ofJwYy9Rb3asxikLPzRDX+8skf2Hq0CoAzO+GzLGWxe2XaiqobYXcIqDBZvNaMaaoslZkYJQUOgUppYnCjUaukskyj1eFdlvKcCu7x+vLxTF+8AY/L9nCSEwMIlcrZ8CsPKEINbvQeAUf/DGWfk9Ej2+JuKPa9iJ9YltPKgkjx3LEsRZ1NRIMbvV6PESNGID8/X7rN4XAgPz8fY8aMCfjYTz75BGazGTfffHPA4wwGA+Lj4xVf1H7Ip/E2VYoAvPcc8rwINsqyHs0qS7kCLKNOts5NgNlSIrUK6BIjzpZyvqd7PtyM+5dsxYIf3RthegU3stKA2EPia9ylNe7g5oed7j8G5Kv1yi/yns3W/kpTYsDRNdG9yaPnhpfiOa632KSGYLFMs6dIufGjQauWLqbK4MYWcOq3Z8OseI7l2Yk4WXCQkWB099wEkbnRa2TBqo8+J2uA2VLi+AHgpMmCbcfcZbRh3RMVx4kBTJROA7Va5VGWCi2A0KpVkCfbBmYlKO73mi0l9dw4x+pe58b58+iWFIVZ5/fBU1cMlB4jfi48Aymiji7in+i8vDy89dZbeO+997B7927cddddMJlM0uypqVOnYs6cOV6Pe/vtt3HllVeiS5cubT1kCiP5RbcxiAbgBotnRsLmcX+4ylLBTQUXRek00l/GtY02OBwClu9yBiHyJmDfZSnnbWImwiF494CUyvYgkmdx5OSZEc8sib+mWzEwyExwr5LreU7Fi2W9xb2mj9hj49nomtMlxp25sbtnS5ks9oBTvw969vC4XkfcagAA0hPcG1FmJhiDy9y4ViLWa9WKTIfn+fHc5FN8ffG9iIsU/nGsyvU+o7Fm9gQ8LQsUAHdfS7QrSxRvlJepQsvcqFQqRUZlYFflH2b+em48VygWAxeVSoWHJvXDjaO7S6VD8f8/lqWos4l4z83kyZNRVlaGuXPnori4GEOHDsWyZcukJuPCwkKo1cr/8fbu3YvVq1fjxx9/jMSQKYwUwU2ImRsAqDNbAbgvei1vKPaeLeUZ3PgqS0XJZsbUNFgVM5fkf937WqFYfE2x4VW8XT4tPphdzj37bOT8ZW7E4xKidIjRa2Cy2FHbaEWybI8jkzTTySb1ooiByqFyZ1DyQG5fjOiRhHN6p+DYSWdvkM3hXuemQVaWijNovcpmnsGNGEQlxeil9WQyE4xShiczIUoae+BFE90XeHkw4Hk+PLNV4s84KVqP8jqzFFSLWZuh2YnISozyCkLFAEbM0sgzN54L+gXDoFNLwfSArh6ZG49F/OSzpQRBkJqQxUBG8bxaDax2myy4YVmKOpeIBzcAMGvWLMyaNcvnfStXrvS6rV+/fs3aN4jaH2XmpulgxHMnac8G2BaXpXw0FAczW8qo07j3LrI58L/Nx93PKQtofK9QLF4I3f87WmwOxLhX4ldkbvwJtiz16/4y/LKvDA9f1F96TJzRObPHZLErsjx2hyC9/5P1VinDIZalxNlTQ7olYlxf5wJ07u0X3GUpk6yklRpvQG2ZcnyeZSnx+eVBVrekKEwd0wN6jRoJUbqQem70Gme5TKtWweYQvIIbeeZGEAQpW5US6wxuxADvD1dv0ZDsRADuDI0oVq/M3Mh/pp5TsUPVKzVGCkABwOiRbYmWfV7ls6t0PrIyRp0adWag0mRRPJaos2gXwQ2duqpD7LnxLEuJF/HD5SZ0idUrnsNzc8RgyDcS9NdQ7Gu2VJROgziDFiqVsxdo6YZC6T5lQ7HzseJxZqsDjVrXNGq9FmqVsyzl2VRcVuuduembFov9sqBAkblx/VuvVcNicyjO8wvL9mL78WqM6d1FaiCONzqDheIaZVOxPLCrkJXD6i3Ohe3EslSvVPc6U1r5In52935H4kU5JdbgtRHkQY/v3WUpd3Bj1Gkw7/IzpO/lPTeCIPhcM8YiKzOKz1FntnkFN/KGYovdATHWce71VIt6i7N5XSxLicGNZx+NuyzlHbCGWpYCgCrZvmBdYvSIMWjdwY2/2VIWuyIT5WuBPjFTIwbNCVE6r2OIOjIWWimiFJmbEKeCA84L+tHKeuQuWIXbF29Q9LS0qCylDX4RP8BZllKrVVJDqbyFo8ZHX5HYHCufLWXQaaT+CM+xyxuKAWcAccXQrorb5EFJnWtXcHHHafl5Fv9aLyiv98jcuDIhfrZIEDdsFG8/Ud0As80BnUal2NlaLKc5BHcmTB5gxRu1XtOYy2rN0v12h3tVYXnPjWd2QRyv1S747a+yePSdiAFBoLKUPJjt4trrqd5ix/GqBpTXWaBVqzAg09n/YtRqII+phndPQrRegzG9nL2AsS2YCu5JpVIpnsMruFFkbtzvR+cjuBH7j8TPgjhTj6izYHBDEaXI3AQR3HhmUWobrdh6tAp2h4ADpXXh235B53+dG39lKQCKvYTETRDlpTMxM5QQLZaw3DN3jDq1Yj8hOfEvbHE6cK/UGNw0ugcuGZSBG0d3B6AsRYn/7pbkHdyIGZ7Cynppld3UOINUSmm02rH2YDnmfblD0bxcJiuNmcx2KfvSo0uMoj9Ivp6OvNwjPj7GoFVkMcQLrbgwoHyNmyRZWcozIBIzXYD/vhvPplrxtTyPl49T/BzqNCrp52my2PHttiIAwOmZ8dLPW61WIVo2rtMz4/HHvAvx0KR+AJwZEvG1PRfRC4UYyMmfw99U8HqLXQrq1Cr4XN/IMzCKZ+aGOhkGNxRRiqxGEOvceGZuahttUjNqTaNNcX+4ZksFs86NeKy8DCH2oNSZbVLjqZi5SZBWy3VIvUbyC6FnYCY2FE86w7n+08icZCTF6PH6TSNw8cAM6XUAZ8+I+G/PzI38vj3FNdLCgL1TYxVluFd+2o/31h3B99vdi9VVmGTBjWxLAHFHa5GvBlbAM7hxvpZWrcKw7CQA7r4bMUMkDy4A7wuyPFNW02hDVb0F//frIZTXmbHpSCUmvLxSmrEmlmb8Zm7kwY2s7BPtGmf+7hI8v2wPAOCqYVmKx0bLAjWdRuWVKRFnTDWnLCXKdM0Uk/fteAZ78tlSVo8F/Dx5zo7y3OCTqKNjLpIiSn6RCWYvKF/BzSHXRdbu0SjarOBGWrE1tHVuxAuL/C/gsX1S8PkWZ2NxndmGxGi9O3MT5c7cmK3urIJ4EZb33NgdgpRBuXF0d1wwIB190mKl+8ULvFhiMtvcO6eLwY3Y99NgtUtZik1HnDO6usTokRSjV5Q1xGzT0ZP10uvIm1TrLXYp0yLvtwEArdr3BVXsG4o1aKUsUXq8Ed2To7HuUIWURdrg2rdqSLdERUDj2bwLOM93TaMNNY1WPP7FDqw7VIEtR6vQIzkah8pM0nOKQWOUn+DGLlvnRvyMRes1UjCx84RzPaHJI7Mx/ZwcxWPFn71Oo/LZ9xNn1KG8zqLYdypU4m7hysyNv3Vu7IpGal88H8ueG+psmLmhiAq5odi1tHyM64JSZ7bhoI8dk4HQylLldWYs3VCoWPdDvuibYgyuccovHOKFRf7X9MicJOnCJ85AMntkbsw2d+bGqNVIf1HLx15hMsMhOEsMKbEGDMxKUFycxOnGYkZGPnsoUwxuXO9LXroSg5XeqbGusbuDOTE7Jd+vSq7ObMORSmfg07OLZ3DTROZGr5V+fl0TjVJ2RDzPvx2qAACc1auLovQSpff+dSVmHGobbVjnetxPu0pkCw+617kB3KUczyBZHriJ7z1Kp1H0+ZzXLxV/v2qgVwAjBl3+siQXnpGOzAQjBndL9Hl/IJ/ffTbuGN8Lf7nQWeaK9VHOE0W5xiFvKPY1U8r5WJalqHNj5oYiKtRF/MSLUlq8EYfLTahusEprrXgKZfuFf+bvx/vrjkjfy9e5sdgccDgEae8j8SKcEK2TLtjimiMnXGUeAOieHC3tFyW+T/k+UoCzB0enca+t46ssJTYTd4k1+OyfEEth4nYUYpATa9BKDbni6/vaO6p3mjM4kdb1sdilvpfjsvcjZ7E5FP06cmrXyroe6+KhpEYsS2mkUk5GQpQUQIjrs8iDG/nnw7MMI3/vxdXucQ7MSvDam8qzLOXJ5pGVApzBQg9X4DYoKwGv3TjcZwATI2VufAcScy4+HbMv6h9wB3B/hnVPwrDuSdL38uDGc20a+Uav4ufHX4lQHhipVMrVn4k6A2ZuKKI8MzfbjlXhjZUHpR6VmkYrrnhtDd5cdRCALLhxXVD3l9T67dUJJXNzwiNDIV/nBlAGXmJpST6TR7ywFFa6yzgqlUqahSKWhcRSmaIsJcvciMGNvERX6irnpHkEESLxgieuSSNmZ2INWul1xPPsayd1MXNjlJWlxPMcaPFAcbE++Vo0Il+lKXH/qNQ4gxQQZCYYFYslHq1swInqRug0KgzvkajoDYnyU5YCgJV7y6TbEqN0Xushec6W8iQvS7m3flBjYv80/O+us/HJnWP89syIgZq/4AZAswIbX+RjiPKYPSbfFdxzXylP8q0b4gxaxaalRJ0BgxuKqGqPhuK/f7Mbzy/bg19du0xvKazCH0er8IlrC4MGWeYGAP6Q7fPjyVcPz84T1Xjq612orlf2XHjOnjFo1YoLgLxkJl78EqO9Z/KIy/E/fJGzjCCtxeKZuZGVpczSbCmNlGE4XG7C7Ys3YM2Bcinj4S+4ida7pyPXNdpQ65oGHmv0Dm58bYzpLku5Myji+/XcLVtODJS6xHiPS+snYwA4gxsxIzIgM14KWuotdilrM6RbIqL1WkUwEihz89Nu935bJosN9R5BnL/gRgyyfJalXNP7R/RI8hsUyZ9DH+A9h4u8b8dzTO4Vim3S+/HXc2OQZW4SolmSos6HuUiKKM91bspcjbPHXBkQ8SIlZmHElWvT/Vzo5TwzN9X1Vlz6z9XOx8cbcMf43tJ9npsvGnRqqNUqGLRqmG0ORd+NFNzI+hTEv6KvPzMb405LQYYr+BKDGM/MjTy40aq9y1J//3Y3ACB/TyluO6cnAKBniruJWE5c/6S20YZas03K3MQZte7Xb7DC4RC8Vi4G3MGN+Jd/baMtYFDjKTnWV+bG/4U+Pd6IBy/oi4sGZmBwVgKWbDgKwHlexUXyRuYkA1BehH2toisGj57Nzp4LmBukhmKPVX1di+LJp4JLZSldcL8epZ6bNtifSdFz42eFYvnmp/5nS7nPJWdKUWfEzA35VFBukpaabw6zzY731hZIM2p8sTsERfNro9UuZTjEEoZYXhCzMGJGIT3eiKZ4BjdPfrNT+vd+jyZkz9kz4i9/X2vdiGNIjPY9TTkzIUoqQyRIwYVN8Tzi9GCz1XdZSk7c+bt/Zpy/typdoOoabYqeG/H1HQJQZ7F57elk0KqR5VoLR8yMiAu7BUOvUUuZCzltgBJNWpwBBq0GQ7MTnevEyMopYk+Q2Mcjz575yp6c1SsZnhWfeovdq2HYX8+NlLmRlaXE853iI2jzRZzWHqgsFS5iWUqrVnmdY6lHzO6QPqM6rb+eG/d54Ewp6owY3JBPt7zzO655Yy1OhnChk/tiy3HM+2onJry8yu8xniWSBqtdCnaKq50ZHLExVAwAxIvWmT2TMTDLvUuyr5KNxe7A++sKsOZAOQor6vGZbL8nz72avIMb5dThBovzgvHr/jJpTL7KUp7EIEbM3DR6TQV3eCziJ+7g7H4OcRNOcVVcX+TTwcWAMMZV1hEDpup6q3R+xfH2So2VmpTFC15FCD/z5Bi9z34Sf5mbaL3Ga6Ve+aw0MVMnBh0GxWwp73N80cBM/PDAubjhzGyc1885XbrebJMyfCLPqeDu8TjHIjYUW+0OfP3HCddzZ/h8D56immgoDiexDOcr0JOfH/Hz5n8quPt2Zm6oM2JZirwIgoDjJxvgEJxTpJN8NIx6WrWvDLtO1ODO8b2gUqlwpMLdWFvbaFXsjizyDCjkeyoV1zibVcUNC8UmXvEv0tQ4A76eNRbrD1fiRHUDDpTW4bUVBxXPt6eoFt9tL0ZanAHPXztYcd/RSvn6LQ6vv/QNHj0aDVY73vr1EBYs3ycdkxhgawCRvCwEuDNQ8rKUGBs4F/FzPo+8rGK2OaBRqxRr23iKlWZMWaUAQZxinRDlnNVV02iVylKXDMpEjEGD3NPTpecQL46VpqY36RT5aiYG/Ac3aXEGH1Op3b0+4uwesUlXnrmJ9hNAnpYeh+euGYyDZXVYuXcVTBY7PItqYnBj8MzcuM6RWIZbtbcMJ+utSIk1YGyfFJ+v50lcC6ctem7EzI2v4MagVUt7lon/b/ltKGbmhjo5Zm7Ii9nm3jgw2IXw5n65A88v24Mdx50pfXkm5bdDlT4fI/4C7uLjAilOMxazJBa7Aza7Qwp+onUaqFQqjO7VBVcN64bEKO/nOOaaxlxaa8a+4loA7uzHsZP1Up+FZ5AFuC+C8uDmo/WFimM8N3X0xb25ow0Wm0PK3CTLHiveJl/Ez1OvlJiATa3+MjcAFE3FYrYsJVaPp64YiHNdi8MBzStLdfFTuvFXlkrzUU6Ul/7EYFZsnG0qcyPnDpJsij2xAECvcd6XnRSluF0MFsTZeZ9vdWb3/jSka8DSmq/XbYvMTVqc8/wlx3gHJCqVSvoZimVQX2VOQNmvw32lqDNicENelFsYBLeztli+EqdCN8qCotX7y3w+RgwqUmIN8PxDX5whJI7Fsz/H80Ln669Pec+NuMDbiB5J0GvUsNoFFLnWRvG1L5FnA2qDxY4cj8XqfDUUe5KmgjdYpWnVeo0aGQneF3n5xpmeTg9QkgLkmRv3hV2euRHHIPbjxPnY50i8MMqbc5viN3PjJ4vhq3wYJZvlI5aTxHJRUrQeaXEG9EyJ8doywJP4GKtd8JryLp7XK4dl4YYzs93jdwWZNoeASpNF2q7h6uHKLRYCiQliKni49MuIwwvXDsYL1w7xeb8YaDWVuTEwc0OdHEN28iJfAM0cxH5PgHsGkRgwyB/36/5yn4856ZqOnRCtg1GnUQRVdWZnY6x8LFWuX9hqlY+9cZr4BS0u6d89ORrdkqJwqNyEwsp6dEuK9pm5EcsqYtBittm9MhrB9dy4syZik3R6gkFRQhAZtGq/F/BAzcSAexG2ukb3OfOZuZE1G3syNpEZEWnUKinrJc9eyfkrS/lqBI+SNRSroFKMXa9VI/8v46FR+97aQE5eGvSc7CUGNzqNGs9dMxjjT0tFrdm9P5bNLuCTjUdhsTkwMCseZ3QNHEzKiUFvN4+sUGu5fmS23/vE7J7YcxPMIn5cnZg6I2ZuyEuom09aZHsZiYvhyRe9O1RuwpEKk9fjyl1NvalxBp/BQXF1o1SmAICT9c7gIlqv9brQyVPrnsvSA+5ZV1lJUejeJRqAu+9GDG66JUVBrQL6pcdJzy/fPFPc3+nqYVl49qpBigDBb3Ajmwpe5Cq1ibOp5I9XuQK25mZuxExMrdkmnTMxo6AsS4mZG+8Lmr++IUAZrMhnEfkqKTqP91OW8pG5kWZLWe1S1ilGtp5LnFHnc18pTzqN//PnefvFgzJx/chs6Fzvy2K340NX2fHm0T1CWnTvrF7J+O6+cXj6yoFBP6a1uLf7aKLnRsvMDXVuDG7IS6CylMls81q1Vr7AnZi58dw5e+FP+71eR1zTJjXW4LOfpKSmUZm5cQU3vkpA8l/QgX5Zd0uKQvdkZ3AjNj3Lg5s/5l2IL2edIx0vjqvObEOl6/VnX9IfN47u3uS+R4B8ET+btEWAuMNzdlK0dJwzk6Py6rmJNWiRFmfAcNkS/L7EGtx7LLkzNxrXGLTS+6xrdC/w58lfgAY4S4ci+XYLvta4AfyXpXxmbmTlsDpx7M3cDsBfgGbwc5HXuIKwX/aV40hFPeKMWvxpaNeQXlOlUmFA1/iAPVFtxXNj0GA2zuRsKeqMGNyQF/nqrp6Zm+vfXIfRz+Yr9hyST7s94cpOiI/LPT0dKhXw+Zbj2FigbCyWZ258ZVs8MzdVrjKWrwuYPKAJ9Ms6K9Ed3Ij9QeLaKglROsQZdT5XxS2qboQgODMsYp+G/Di/DcWy7RfEzI3YbyOOA3Cvq+OZYfj4jjFYM3tCk39dK3tuXLtaB8rc+AgeAgU38oBGHuj4z9yE0HMj+3mKZbpAWaRAYvxkePxldMQgTPwsnN8vLagsUXslnkvxM+2/54YNxdS5MbghL4rMjUfPzc4TztlQX2497vP4oipl5ubMnCRcM7wbAGdg9ODSrVKjb1OZm2KvzI0zuPF1EQ4mcxOl0yA5Ro/sZGVZSkzh+3qceNu+Eudsq6RovTSLRrHvURM9N/UW575JAJDpyl6I5THAXUrzvAgnROuCalSNk2ZLWb0zN1JwY5M1FHu/10A9N/6CG789N7Ixy5uXfc2W0mvUXg3lzQ0w/AVF/oIbz56UxA6+FYF7tpSrLOVnET8Dy1LUyTG4IS/yTIy8LCXIul8Pl7l7aOQBSFmdGRabQ8rcGLRqzLm4P87p0wUOwZnB+Wabc5E0sYclUM+NPHASG4p9laViDVppMTp/DZJZSc5el54pzgbQHSdq8OHvhVIK31fGRwxAthZWAVBmKuTj8HcxjjNqpQv3juPOfbAyE52Np9k+MjeeDcWxQV7k5bOyxAAm2qOhuKbBvc5N6GUp9/uWBzp+p4LLohV5wJAW7525UalUivMXpdP43P08GNF+yln+yjMaj96g5pbD2gvx/Yv9af7XueEiftS5MbghLw1+Gorl/z5U7g5u5KUjQXD2ysg3g+wSa8AHM87CrPP7AAC+214MAChzlaVSPDI34m7bzsyN+7mrxZ4bHxdhlUol9Zb4+0tUnM3SNy0WVw/Lgt0h4G+fb8dnm4/5fZxYOhJnGckv5nFGHe45vzfum9jX71RwrUaN/hnx0vsB3D038rKUv8yNvLE2kATXOj9VDVbpnMV6lKWq6i1ST4uv2VI6jdpvOUke0KTKMjfJPjbNBJSZGzG7E6XT+CyHAcqyXrDv2Rd/C/0Fm7nxdV46EvH8ip+BoHpumLmhTojBDWH7sWpMfHklftzpDDpMfoIbeaBxsKxOyuQ0WJVrihRVN0oL08lr+5cNyQQA/LK/DDWNVlTUOYMVZ8+N+5dt33TntOeSmkZFFknMsDQ1M8lfcJPlypioVCq8fP0QXD3MuZZJuWscvnZH9lzbpkus8mL+10n9kXfBaT5fTzQyR9kMnCE1FLunDks9N7KLkVGnDnohOXl2xt86NydcfUOA73VuAOW5FbMnGrVKUX5KcQU6apX/cy0PkvpnxOHqYVl4ILev31lI8nJSS7In/gIjf8GNZ4aoowc3nuP3l7lJjNJB5fr5tYdGaKJwY3BDyN9TgoNlJnzl2lOnQbHOjTug8ex/kTa3NCtnRhVVN0jlLPmU037pceiVEgOLzYHPNh2TlrzvEqtXpMl7pzoDioo6C+rN3mUpf7+MxQttvMeFW7xgZ8mCCZVKhfP7p/l8vFxWUpTiApgSxFYUnsQdrgFnpiDFle2Qj0csJckvwqFcaMXST7UscyOtc+O6T8yU6TQqv+vpyPtuxOZf+X5QKpW7NJcYrfdbPpIHNwatBgsmD1Xswu4pOogSXzDkj5WPzW/mppOVpTzLjf6Cmy6xBrw6ZTjeuHl4WwyLqM0xuCHpL32xB8Zf5qbBY/8lcasFz9tPVPnO3KhUKlw8yLkZ4X9+OwLAWYLSadSKjIGYLSmrNUvbLQDuzE1TwU2CR5Pr7WN7YkBmPCadodwIcWBWguJ7X+l5nUaNronuJljPzE0wRvZwZ27S441Quy668qZOMfCQBx2hXGjF9261C1LQ6Jm5EcUavNcJEsmDDDHDFKPXSmW3KJ0GfdNjYdSpMSw70e945BfVYBqiFWWpZs6UApTjl5fP/JVnPKesx7agJNYeeGVu/DQUA8ClgzNxdu/g9s8i6mgY3BDqXNkR8QLrr+fGc3NJsUHWcwdmf5kbAJjgypYcdDUkizNv5Be3HFfDrzywAWRlKT9rykwdk4NxfVNw4YB0xe1TRnfHd/ePQ+9U5caTPZKjFRcDfyWWHsnu0pS/BtpAuiZGSSWxTB/bLgAtz9xE6zVe/TJi/4lnw6ivmVIieZDZ1TXmWKNWygJF6zVIizPi97/l4t9TR/p9HnnWJNAFVj5+UUuyJ/LMjXyLC3+ZKs/MU0fP3HiWG/0FdUSdHT/5JF1Yxd4Tk9n3bCnP4EacHi3eLiYDlD03yuBmYFaC4heu2Kgqb8jNiDf6vBhVB5gKDgAXDEjHf24f7bUMvr/+ErVapVhm39+skR6yKdtd/DTQNkXsu8lICLxEv7jBIxDahValUilmJcn7dTwDn0BBkzzIHN83FdeO6Ib7JvaVskDyGViBZjTJMyL+FtCTiwpTQ7H8sfJA0n9DcScrSxmUn2F/75uos+Mnn6RgprrBCrPNjnqr73Vu6j0yNGJQJN4uZmFqGqzSOjeeQYpBq8Ggbu5ykBjcKHcp1vlcHK6qiYZikUqlkn6pq1SBp1PLtzXwm7mRBTepcaFnbgDnLtN6rRrn9lWWAca5vhczO/KLkb+ZRf7Iy2ryxexUKpVUqgKA3mnKDJZclMcsmpeuG4I/DemKYdlJGNOrC245q0dQY5EHU8GUpYKZVh8M+WPlqyH7XcSvszUUB9lzQ9TZdez/kyks5Dsol9dZ/K5Q7Jm5MUnBjfP21FgDymrNMFls0uN89ceM6JGETUdOApCVpWQXt3ijFl1iDdJqxyJxs0bPbJAvBo0aFpsDsQat1OPiS44scPEX3HSXl6WambmZeHo6dj05yWv208LJQ/HmL4ekzRD1zey5AZS7lEd7ZD8So3XSIohzLxvg9zmUQYZGcftHfz4r6LHI36cuiOyBPKhqSYAhH3NKrB5dE4yobbQFWGywc5elGNzQqapj/59MIREEAUcrG5CdHKVoKJWXocpqzX73lmqQrZ1hsTuk48QZTWnxBuwqcs6e8pe5AaDYJ8mduVFulJgcYFZSU5kbwBUkmJteoGyYbCz+/rpXlKWa0XMj8jWtu0usAX+75HTp++Y2FAPK4MxzG4I5F/fHT7tL8dQVZyjWrPEkP7f+1u4Jhi7EzE20n6AqVJ6zrr66dyysdoffJnTPDT6DXTSxvfLM9vnbFZyos+vY/ydTSD7fchx5H/+BRy85HTPP7SXdrsjceAU33mWp1DgDjlc1SI3EYhlLnJ1S2xg4czO8R6L0b8+GYqPOubNzoCAimIuuGKj467cRDclOxDNXDVTMrPHUMyUGGfFGxBm1rV62UJSlmhi7J3lw4xkgTD6zOyaf2b3J5/C1r1ZzyFf+1QdxgTWGbZ0brezfGsVWEb54lqVa0u/THniWpdhQTKcqBjenkP2ldQCAA67/ihSZmzqzordGvru3GMSkxOqdwY1ZzNw4jxeX1hd37wbgc0PMtDgjcrpEo6CiXmr6FGdAiZkWfxsyAiFkbhDc6qs3jQ7cR2LUafDzQ+OhVqn8TqEOF/nFyN8mkP4kykov4dhVuyUZFHnGIKjMjU4WlIQxc9MUeTbNoA1+0cT2KthF/Ig6OwY3pxAxUGmwKntn6gKWpWSZG1cwI5Y1fPXcAFA0rxq0vi9U868ejN8OVWB0T+cCd2JZSsxW+FvWH/C/zo2cWN7xXNCvudpqp2hlWSq0i7y/huJQhKuxVxNyQ7H7GH/7QwVDPuZggjN5z02ombL2yPPnHky/E1FnFPFP/muvvYacnBwYjUaMHj0a69evD3h8VVUV7rnnHmRmZsJgMOC0007Dd99910aj7djE6dny4MVmd0i3A86F/PztCi7eLqb6zTYHbHaHlOnx3PFZrfJf8x/TuwsevOA06S9lcRNJcVPLQGUpX9kgT1LmpoNtCtiSslSghuJghassFXJDsV6euQlPQ3FQmRtZENbRm4kB5/IG8uwNe27oVBXR/5uXLl2KvLw8LFq0CKNHj8bChQsxadIk7N27F2lpaV7HWywWXHDBBUhLS8Onn36KrKwsHDlyBImJiW0/+A5I3EpBXmry3DrBmbnxvc6NuIeUvI+h3mqXVjROjNZBq3ZPOzZoNUGXcQZmJeCrWedIC+a1uCylCa7npr1pyWypQA3FwWqNhuJgem7Ct85NiJkbdfPLgO1VrEHrXhSSZSk6RUX0/+YFCxZg5syZmD59OgBg0aJF+Pbbb/HOO+9g9uzZXse/8847qKysxNq1a6HTOX+R5+TktOWQO7RGm3dZqs5j7ZoT1Y2w2t1lJV9TweVBTL3ZLs2iitFrEWPQyrZJCO0X6+BuidK/5dscqFSQNnwEQmso7mg7Hit6bloQ3DQ3cxPl+plp1aoWLQCnCbXnJlwNxfrQgiR5Waqjr3EjijVqAefOKOy5oVNWxD75FosFmzZtQm5urnswajVyc3Oxbt06n4/56quvMGbMGNxzzz1IT0/HwIED8eyzz8Jut/s8npTEEpN8ewV5MzEAFFaYlI/xEdxE67XSxchksUmzpuQbLAL++22CIc/cJHoEKME1FCt7eDoKrUYNMekR6iJ+8hWKmzulWb6HVEvIN6QMqudGF55G5ijF2jyhlqU69kwpkbIsxeCGTk0R+81fXl4Ou92O9HTlPkDp6enYs2ePz8ccOnQIP//8M2666SZ89913OHDgAO6++25YrVbMmzfP52PMZjPMZrP0fU1NTfjeRAfjM3PjCm7UKsAhACddC72JfO0KHq3XIMagRU2jDfVmuzvoMWgVF4hQMzdy8nVukqL1inEF01Cc4urZyWxiu4P2SK9Vo9HqaGHmpnn/a4vntiUlKaA5DcXhWsRPi3ijFmabA0nRTWftdC3IlLVX8oBeH8S+XkSdUYf6v9nhcCAtLQ3//ve/odFoMGLECBw/fhwvvvii3+Bm/vz5ePLJJ9t4pO1To4/MTV2jM2DJSorC0coGr8eYbQ78uLMYhZX1UhATpddIf13XNFphcWV3onUaxQUimCDEn2i9Bkad8yKfFKMHyt0ZpWAuvLMv6o9z+6Z67QTeEQzKSsD+0jqpyTpYyp6b5p37aNkGmS0hb2QN5gKrzNy0bJbWBzPOgsXuCOp5NEHuudWRMHNDFMHgJiUlBRqNBiUlJYrbS0pKkJHh+4KUmZkJnU4HjWxzwdNPPx3FxcWwWCzQ672bUOfMmYO8vDzp+5qaGmRnZ4fpXXQsvqaCi2WptDgjqkxW1Lq+j9Jp0GC1w+YQ8NdPt6G6wSpdgMTeGsA5u0oUbdAomjL97cQcDJVKhS4xzsUCPZfODyZoSos34sphWc1+/Uj6cOZZsNhCz9zEhyFzI07zD7SKcTDks6Xkm4H6Ex1ir0wg8r3LmiLvueksmRsGN0QR7LnR6/UYMWIE8vPzpdscDgfy8/MxZswYn48555xzcODAATgc7j6Qffv2ITMz02dgAwAGgwHx8fGKr1OJwyFgb3Et7A7BHdxY7NhxvBqX/vNXfLejGIDzF6K4czUARUpfbBAWgyJ55qas1hncaNQq6DVqxYUpmD2gAhGngyfHKMsLxk6+dodOo27Whdao00ilwOZmboZ0S8ArNwzFc9cMbtbjRYqyVDCZG9d41aqW9/uEQj5bqqXZqvYiVlGW6tz/rxD5E9FPfl5eHt566y2899572L17N+666y6YTCZp9tTUqVMxZ84c6fi77roLlZWVuP/++7Fv3z58++23ePbZZ3HPPfdE6i20ex9tKMSkhb/gndWHpbKUxe7A9zuKsPNEDb7+4wQAZ3Bzdm/3jtWJfjYaBFw9N64MTZkrcxOtd077jjGEJ3MDADPG9cLE/mmY0N+9LIBe0/FXkW1NiVHOn1tzSzsqlQpXDM1C71T/O4cHI9QVirMSo3DF0K6YeW6vVl8FWk6euWlJGbU9iWPmhiiyPTeTJ09GWVkZ5s6di+LiYgwdOhTLli2TmowLCwuhlv1llZ2djR9++AEPPvggBg8ejKysLNx///145JFHIvUW2r2Dpc5elUPldYqZT2LGRRRr0GJM7y7S91F6DXQalWJauChar5HKHuLziH/1xoap5wYA/jSkK/40pCs2HamUPSd/WQdy1fAsrNhTGlJppjUo95Zq+memUqnwyg3DWnNIPslndbU0GG8vFJkbBjd0iop4kXnWrFmYNWuWz/tWrlzpdduYMWPw22+/tfKoOo86s7OkVG+xK2Y+lXoENzEGLQZkukt2B8vqYNBqYLUrp4oDzsAnxqMsJWZywtVQLCfv2WjpLJ7O7pGL+uORi/pHehgh7woeKfLyWUvLqO1FrMFdxuUKxXSqar+/dSgsxBWITWa7NBUcAEprPDM3Gqhlv+ir6q1+/5KVNxSLwU2Uj8xNuP4SNsiyNZ2ldNDZKbZfaMcXWPk6N52ll0vM3KhUyuCN6FTSOf5vJr/EdWxqG62KElNZnXfmBgCeuHwAAOCe83v7DU6idO7MTXmdcwdwKXMjy6yEq4QkH0dbNptS82kVDcXt99eMuhNmbsR1bnQadZv2LxG1JxEvS1HrEqd6n6y3KG6v8AhuxL/2pp2dg7N6d0HftDh8t73Y6/mMOjXUapXUcyNOBRczNzFhWqFYTv48zNx0DPJG3Y7S99FZMjdiQ3FHOe9EraFZn36bzYaffvoJb775JmprawEAJ06cQF1dXVgHRy0nZm4qTcrgxuHRJyyWk1QqFfpnxEOjVvnM3ET7yNAA7mnbyobi8Pxy1TNz0+GEukJxe9ARV7P2RVzviM33dCoLOXNz5MgRXHTRRSgsLITZbMYFF1yAuLg4PP/88zCbzVi0aFFrjJOaqU7K3FgDHudrR2RfwY0YXHhONe7uWk1X0VActsyNLLhhQ3GHIAY06g7Q9/HqjcNw/GRDxGeYhUvftFhMHdMD/TLiIj0UoogJObi5//77MXLkSPzxxx/o0sU9dfiqq67CzJkzwzo4ajmxLGX3TNV48LVonK+ykrhIn+cqsr6CG0Mr9Nzwr9GOQey56QhZm8sGd430EMJKpVLhqSsGRnoYRBEVcnDz66+/Yu3atV4rAufk5OD48eNhGxiFR53Zeyq3L752z/YVnERJew8pjxf3QQrnOjcicadsh8Cem45CXPmXfR9EFAkh/+ZxOByw2+1etx87dgxxcUyDtidmm93nIny++M7cuD8eWYnOfoRoXVOZG9n2C2Fs0BSzSOy56RjEPqlwZe+IiEIR8m+eCy+8EAsXLpS+V6lUqKurw7x583DJJZeEc2zUQuIaN/7oNWp0T45GnEGL9HjvjRLlZanTM52Bq7gSsTxzo9eqkRrrfHxrZG4A90WSwU3H0CctFpcOzsSMcb0iPRQiOgWFXJZ6+eWXMWnSJAwYMACNjY248cYbsX//fqSkpOCjjz5qjTFSM9U1Bi5JxRm1+HrWWJhtdp97EckzL6N7dsFPu0uRleTM4MgbkLOToqT1QsK5t5SvsbChuGPQqFV47cbhkR4GEZ2iQg5uunXrhj/++ANLlizBtm3bUFdXh9tvvx033XQToqI6x1TKzqKpfptYoxYJ0ToAOp/3y0sKN53VHf0z4zA0OxEAEC0rP2UlRUv/1mnU0GvVsNgcYV0UTSxzsOeGiIia0qxF/LRaLW6++eZwj4XCzGRpIrjx0WcjJ+9zidZrMa5vqs/HpsQqm8tjDVpU2ixhmwouHwuDGyIiakrIwc37778f8P6pU6c2ezAUXk2VpZoObpzZkqRo78yOvOTUJUYZ3KTFGVBpskgL+4WDVJZicENERE1o1jo3clarFfX19dDr9YiOjmZw0440VZbyNf1bTgwoEqO9gxT5njVdYpXNyC9fPwT7S+pwWnr4Zs/ppZ4bzr4hIqLAQr5SnDx5UvFVV1eHvXv3YuzYsWwobmdMTfXcNJW5cWVJkmJ89+SIRvdMVnx/RtcEXDksK4gRBi+nS4ziv0RERP6EZePMvn374rnnnsPNN9+MPXv2hOMpKQx8ZW5i9BqYLM4p4rFNZG7EzE5anNHn/d/fPw7HTjZgWPekFo60afOvHoR7zu+NPmlcS4mIiAIL267gWq0WJ06cCNfTURj4Cm4So/UwWRoAAHHGwBmZywd3xbGTDbh2RDef95+eGY/TM+NbPtAgGHUaBjZERBSUkIObr776SvG9IAgoKirCq6++inPOOSdsA6OW81WWSorR4XiVM7hpqiyVFKPH3y45vVXGRkRE1FpCDm6uvPJKxfcqlQqpqamYMGECXn755XCNi8KgzscKxUmy5uCmGoqJiIg6opCvbg6HozXGQa1ALEsZdWo0Wp0/N3lw01TmhoiIqCPivNpOxGJTBp5iWUreECxfs4bBDRERdUZBXd3y8vKCfsIFCxY0ezDUfF//cQJ/+fgPLJg8BJcN7grAnblJjzegsLIeAJAgz9ywLEVERJ1QUFe3LVu2BPVk8oXdqG3d+5HzZzTrwy3u4KbRO3OTLMvcxDcxW4qIiKgjCiq4WbFiRWuPg1qBuLdUapx7BeGkGPbcEBFR58aem07CqPP+UUo9N/Hu4CY+SoeEKB10GhWSw7j3ExERUXvRrD/dN27ciI8//hiFhYWwWCyK+z777LOwDIxCE2fUodFqVtxW56Oh2KjV4L3bRqHeYmNZioiIOqWQMzdLlizB2Wefjd27d+Pzzz+H1WrFzp078fPPPyMhIaE1xkhB8FyzxmZ3SNO/02RlKaNOjaHZiTi7d0qbjo+IiKithBzcPPvss/jHP/6Br7/+Gnq9Hq+88gr27NmD66+/Ht27d2+NMVIQ5FkYi82Bmkb36sTp8e7MjUGradNxERERtbWQg5uDBw/i0ksvBQDo9XqYTCaoVCo8+OCD+Pe//x32AVJwovXuoOVkvQXVDVYAzqbh+Ch3VsdXbw4REVFnEvKVLikpCbW1tQCArKws7NixAwBQVVWF+vr68I6OgmazC9K/y+vMUnCTEKVDtF4e3DBzQ0REnVvIDcXnnnsuli9fjkGDBuG6667D/fffj59//hnLly/HxIkTW2OMFASz3b06cUWdBWKoEx+lQ4xeA51GBZtDQAynfxMRUScX8pXu1VdfRWNjIwDg0UcfhU6nw9q1a3HNNdfgscceC/sAKTjyrRcqTGZo1M6kXEKUFlqNGs9fMxj1FjsSojhDioiIOreQg5vk5GTp32q1GrNnzw7rgKh5LDb3DuDltRYYXT04YjBz9fBuERkXERFRWwu55yY3NxeLFy9GTU1N2Abx2muvIScnB0ajEaNHj8b69ev9Hrt48WKoVCrFl9Fo9Ht8ZyYIAk5UNQAALLKyVLnJjBpZzw0REdGpJOTg5owzzsCcOXOQkZGB6667Dl9++SWsVmuzB7B06VLk5eVh3rx52Lx5M4YMGYJJkyahtLTU72Pi4+NRVFQkfR05cqTZr9+RLV5bgLOf+xmfbDyqLEvVWRQNxURERKeSkIObV155BcePH8cXX3yBmJgYTJ06Fenp6fjzn/+MVatWhTyABQsWYObMmZg+fToGDBiARYsWITo6Gu+8847fx6hUKmRkZEhf6enpIb9uZ7DtWDUA4EBpnUdwY0Z1PYMbIiI6NTVr0RO1Wo0LL7wQixcvRklJCd58802sX78eEyZMCOl5LBYLNm3ahNzcXMVz5+bmYt26dX4fV1dXhx49eiA7OxtXXHEFdu7c2Zy30eGV1zm3W2i02j0aipm5ISKiU1eL5gUXFxdjyZIl+O9//4tt27Zh1KhRIT2+vLwcdrvdK/OSnp6OPXv2+HxMv3798M4772Dw4MGorq7GSy+9hLPPPhs7d+5Et27eTbNmsxlms3vPpXD2CkVaWa0Y3DgUPTcVdRbEuNa2iWdwQ0REp5iQMzc1NTV49913ccEFFyA7OxtvvPEG/vSnP2H//v347bffWmOMCmPGjMHUqVMxdOhQjB8/Hp999hlSU1Px5ptv+jx+/vz5SEhIkL6ys7NbfYxtpbzOuWlpg9UOa4BF/IiIiE4lIWdu0tPTkZSUhMmTJ2P+/PkYOXJks188JSUFGo0GJSUlittLSkqQkZER1HPodDoMGzYMBw4c8Hn/nDlzkJeXJ31fU1PTKQIcu0NApcmZuRF3/xaZbQ4cPelcLZrBDRERnWpCztx89dVXOHbsGP7xj3+0KLABnHtTjRgxAvn5+dJtDocD+fn5GDNmTFDPYbfbsX37dmRmZvq832AwID4+XvHVGVSaLHC4kjVilgYAEqOdwUyta+NMBjdERHSqCTm4ueCCC6BWh2/zxby8PLz11lt47733sHv3btx1110wmUyYPn06AGDq1KmYM2eOdPxTTz2FH3/8EYcOHcLmzZtx880348iRI5gxY0bYxtQRiM3EAKQ1bQCgX3qc4jgGN0REdKqJ+EZDkydPRllZGebOnYvi4mIMHToUy5Ytk5qMCwsLFcHUyZMnMXPmTBQXFyMpKQkjRozA2rVrMWDAgEi9hYgQm4kBoKbRGdxo1Sr0TovF74crpfvYUExERKcalSAIQtOHdR41NTVISEhAdXV1hy5Rfbb5GPI+/gMAEKXToMFqR7Reg7wLTsPfv90NAIjRa7DzqYsiOUwiIqKwCOX6Hb76ErUpeVmqwercV0qvVaNXaox0O0tSRER0KmJw00GJ08Dl9Bo1eqbESt+zJEVERKeikIOb++67D//85z+9bn/11VfxwAMPhGNMFAR5z41Ir1UjOykKWrUKADM3RER0ago5uPnf//6Hc845x+v2s88+G59++mlYBkVNk5elRHqtGlqNGt27RANgcENERKemkIObiooKJCQkeN0eHx+P8vLysAyKmuYzc6Nx/jh7pTj7bhjcEBHRqSjk4KZPnz5YtmyZ1+3ff/89evXqFZZBUdN89dwYtM4fZ/8MZxd5ZoKxTcdERETUHoS8zk1eXh5mzZqFsrIyaRfw/Px8vPzyy1i4cGG4x0c+1DRapa0X5HSuzM2McT2RnmDEZYN8r9pMRETUmYUc3Nx2220wm8145pln8PTTTwMAcnJy8MYbb2Dq1KlhHyC5rdhbim/+KEL+nhI4BGemxmp3SNsw6F2Zm8RoPW45q0cER0pERBQ5zVqh+K677sJdd92FsrIyREVFITY2tukHUYvUNFox472NsLsimd6pMXj8sgG454PNMFnc69wQERGd6lq0/UJqamq4xkFNqG20we4QoFWr8PatZ+Kc3l2g1ahh1GncwY2GwQ0REVFQwc3w4cORn5+PpKQkDBs2DCqVyu+xmzdvDtvgyM1icwBwbrUw/jR3UGnUaaR/M3NDREQUZHBzxRVXwGAwAACuvPLK1hwP+SEGNzqPAMagc3/P4IaIiCjI4GbevHkAALvdjvPPPx+DBw9GYmJia46LPIjBjWfpyah1Z24MDG6IiIhCW+dGo9HgwgsvxMmTJ1trPOSHxe4KbjwCGKM8c8OeGyIiotAX8Rs4cCAOHTrUGmOhAKTMjVdww54bIiIiuZCvhn//+9/x0EMP4ZtvvkFRURFqamoUX9Q6xMyNzrMsxeCGiIhIIeSp4JdccgkA4E9/+pNi1pQgCFCpVLDb7eEbHUn8Z27kZSkNiIiITnUhBzcrVqxojXFQE6yuzI0hQEMxMzdERETNCG569uyJ7Oxsr7VuBEHA0aNHwzYwUvKXuTHIylI6jf/1h4iIiE4VIf+p37NnT5SVlXndXllZiZ49e4ZlUORNWufGI4CRl6U4FZyIiKgZwY3YW+Oprq4ORqMxLIMib2a/U8FZliIiIpILuiyVl5cHAFCpVHj88ccRHR0t3We32/H7779j6NChYR8gOVmlspSyaZg9N0REREpBBzdbtmwB4MzcbN++HXq9XrpPr9djyJAheOihh8I/QgIgW8TPayo4Z0sRERHJBR3ciLOkpk+fjldeeQXx8fGtNijy5m4o9uy5YeaGiIhILuSr4bvvvov4+HgcOHAAP/zwAxoaGgA4MzrUevzuLcWNM4mIiBRCvhpWVlZi4sSJOO2003DJJZegqKgIAHD77bfjL3/5S9gHSE7WYBqKubcUERFR6MHNAw88AJ1Oh8LCQkVT8eTJk7Fs2bKwDo7czP7WuWFDMRERkULIi/j9+OOP+OGHH9CtWzfF7X379sWRI0fCNjBS8r+3FNe5ISIikgv5amgymRQZG1FlZSUMBkNYBkXeuCs4ERFRcEK+Go4bNw7vv/++9L1KpYLD4cALL7yA888/P6yDIzer36ng7LkhIiKSC7ks9cILL2DixInYuHEjLBYLHn74YezcuROVlZVYs2ZNa4yR4M7ceJaeOFuKiIhIKeSr4cCBA7Fv3z6MHTsWV1xxBUwmE66++mps2bIFvXv3bo0xEuR7S/nfFdzzPiIiolNRyJkbAEhISMCjjz4a7rFQABbuLUVERBSUZl0NGxsbsX79enzzzTf46quvFF/N8dprryEnJwdGoxGjR4/G+vXrg3rckiVLoFKpcOWVVzbrdTsSfw3FUXpncKNScbYUERER0IzMzbJlyzB16lSUl5d73adSqWC320N6vqVLlyIvLw+LFi3C6NGjsXDhQkyaNAl79+5FWlqa38cVFBTgoYcewrhx40J9Cx2Sv72lEqJ0uHdCH+g1akUWh4iI6FQV8p/69957L6677joUFRXB4XAovkINbABgwYIFmDlzJqZPn44BAwZg0aJFiI6OxjvvvOP3MXa7HTfddBOefPJJ9OrVK+TX7Iiknhsf2Zm/XNgP907s29ZDIiIiapdCDm5KSkqQl5eH9PT0Fr+4xWLBpk2bkJub6x6QWo3c3FysW7fO7+OeeuoppKWl4fbbb2/xGDoKabYUm4aJiIgCCrksde2112LlypVhmRlVXl4Ou93uFSilp6djz549Ph+zevVqvP3229i6dWtQr2E2m2E2m6Xva2pqmj3eSPK3txQREREphRzcvPrqq7juuuvw66+/YtCgQdDpdIr777vvvrANzlNtbS1uueUWvPXWW0hJSQnqMfPnz8eTTz7ZamNqK/4aiomIiEgp5ODmo48+wo8//gij0YiVK1dCpVJJ96lUqpCCm5SUFGg0GpSUlChuLykpQUZGhtfxBw8eREFBAS6//HLpNofDedHXarXYu3evV0Zpzpw5yMvLk76vqalBdnZ20GNsL/xNBSciIiKlkIObRx99FE8++SRmz54NtbplF1q9Xo8RI0YgPz9fms7tcDiQn5+PWbNmeR3fv39/bN++XXHbY489htraWrzyyis+gxaDwdAp9rwy+1nEj4iIiJRCDm4sFgsmT57c4sBGlJeXh2nTpmHkyJEYNWoUFi5cCJPJhOnTpwMApk6diqysLMyfPx9GoxEDBw5UPD4xMREAvG7v6H7cWYznlu3BwslDMbhbot+9pYiIiEgp5CvltGnTsHTp0rANYPLkyXjppZcwd+5cDB06FFu3bsWyZcukJuPCwkIUFRWF7fU6im+2FeFQmQnLdhQD8L+3FBERESmFnLmx2+144YUX8MMPP2Dw4MFeDcULFiwIeRCzZs3yWYYCgJUrVwZ87OLFi0N+vY7gZL0FAHCiqgE2uwMOwXk7e26IiIgCCzm42b59O4YNGwYA2LFjh+I+eXMxtYwY3ByvapCaiQH23BARETUl5OBmxYoVrTEO8nDSZAUAHD/ZAKtNkG5n5oaIiCgwXinbqUqTM3NTXNOIeqsNgHNzTK2a2TEiIqJAGNy0Q41WOxqszn26HAJwtLIBgHOmFEt/REREgTG4aYfEfhvR4fI6AJwGTkREFAxeLdshsSQlOlxeD4D9NkRERMHg1bIdqqq3Kr4vKDcBYHBDREQUDF4t2yHvzA2DGyIiomDxatkOVXn23FQ4gxuucUNERNQ0Xi3boUrXGjc9ukQDcG+9wIZiIiKipvFq2Q6Js6UGZiUobmdZioiIqGm8WrZDYnBzRtd4yJe1YXBDRETUNF4t2yGxoTgj3oiuCVHS7SxLERERNY1Xy3ZIzNwkRevRPTlaup2ZGyIioqbxatkOiZtmJsXopaZigJkbIiKiYPBq2Q6JmZvkaD26d2HmhoiIKBS8WrYzjVY76i3OTTMTY3TokRwj3cd1boiIiJrGq2U7I269oFWrEGfQKstSzNwQERE1iVfLdqaqwVmSSozWQ6VSKcpSVrsjUsMiIiLqMBjctDNi5iYxWgcAiDfqpPuKqxsjMiYiIqKOhMFNOyMFN1E6r/uKqhvaejhEREQdDoObdkbcNFPM3Mh1iTW09XCIiIg6HAY37UxVgzNzkxCll2777O6zkXt6Gp67elCkhkVERNRhaCM9AFLy7LkBgOHdk/B/086M1JCIiIg6FGZu2plqcbaUj54bIiIiahqDm3bGV+aGiIiIgsfgpp0Rg5uEaH0TRxIREZEvDG7aGXdDMTM3REREzcHgpp2prmfPDRERUUswuGlnxMwNe26IiIiah8FNO2K2yXYEj2LPDRERUXNwnZt2QBAEPPvdbkTpnT8OlQqIM/JHQ0RE1By8grYD+0vr8Navh6XvE6J0UKtVERwRERFRx9UuylKvvfYacnJyYDQaMXr0aKxfv97vsZ999hlGjhyJxMRExMTEYOjQofjPf/7ThqMNv0arXfE9m4mJiIiaL+LBzdKlS5GXl4d58+Zh8+bNGDJkCCZNmoTS0lKfxycnJ+PRRx/FunXrsG3bNkyfPh3Tp0/HDz/80MYjDx+TWRnccI0bIiKi5ot4cLNgwQLMnDkT06dPx4ABA7Bo0SJER0fjnXfe8Xn8eeedh6uuugqnn346evfujfvvvx+DBw/G6tWr23jk4VNvsSm+Z+aGiIio+SIa3FgsFmzatAm5ubnSbWq1Grm5uVi3bl2TjxcEAfn5+di7dy/OPffc1hxqq6ozewQ3nAZORETUbBFtKC4vL4fdbkd6erri9vT0dOzZs8fv46qrq5GVlQWz2QyNRoPXX38dF1xwgc9jzWYzzGaz9H1NTU14Bh9GnmUpzx4cIiIiCl6HnC0VFxeHrVu3oq6uDvn5+cjLy0OvXr1w3nnneR07f/58PPnkk20/yBB4lqUOl5siNBIiIqKOL6LBTUpKCjQaDUpKShS3l5SUICMjw+/j1Go1+vTpAwAYOnQodu/ejfnz5/sMbubMmYO8vDzp+5qaGmRnZ4fnDYSJZ1nq3gl9IzQSIiKiji+iPTd6vR4jRoxAfn6+dJvD4UB+fj7GjBkT9PM4HA5F6UnOYDAgPj5e8dXeiKsS33p2Dn7KOxeXDc6M8IiIiIg6roiXpfLy8jBt2jSMHDkSo0aNwsKFC2EymTB9+nQAwNSpU5GVlYX58+cDcJaZRo4cid69e8NsNuO7777Df/7zH7zxxhuRfBstImZuEqN16JMWF+HREBERdWwRD24mT56MsrIyzJ07F8XFxRg6dCiWLVsmNRkXFhZCrXYnmEwmE+6++24cO3YMUVFR6N+/P/773/9i8uTJkXoLLVbvCm5iDRH/cRAREXV4KkEQhEgPoi3V1NQgISEB1dXV7aZENeO9jfhpdwmevWoQbhzdPdLDISIiandCuX5HfBG/U4XZZkeBn1lQ4mypGIOmLYdERETUKTG4aSMLlu/DeS+txCcbj3rdZ3KVpWL0LEsRERG1FIObNvLmqkMAgL9+us3rPrGhOIY9N0RERC3G4KaNdIlxb4Z50mRR3CdOBWdZioiIqOUY3LSRjASj9O8fdhYr7mPmhoiIKHwY3LQRMTsDAJ9tPg6HwzlJTRAEd+aGPTdEREQtxuCmjZhkWyysL6jEk1/vhCAIMNscsLsCHZaliIiIWo7BTRsRszMP5PaFSgW8t+4IPt9yXBH0RDNzQ0RE1GIMbtqAIAgwudayuXF0d2ljzMVrC2AyO4OeKJ0GGrUqYmMkIiLqLBjctAGzzQFxHegYvRbTxvSAXqPGtmPV+O1QhfN2NhMTERGFBYObNiAvPUXpNOgSa8DFgzIAAG/+chAA+22IiIjChcFNGxD7baL1GqhdpaebRvcAABwsc27JwJlSRERE4cHgpg2I/TbyhuHh3RNh1LlPPzM3RERE4cHgpg2ITcPRencAo9WocXqme1dT9twQERGFB4ObNtBg8Q5uAGBQVoL0b5aliIiIwoPBTRsQy1Ke2ZmB8uCGZSkiIqKwYLqgFa3YU4r31xXgrF5dAATO3HABPyIiovDgFbUVTV+8AQCwYm8ZAO/SU9+0WOnfZXXmthsYERFRJ8ayVBvyzNxoNe7TX1bD4IaIiCgcGNy0oWgffTWPXnI69Bo1HrzgtAiMiIiIqPNhWaoN+ZoRNfPcXph6dg8YtGwoJiIiCgdmbtqQv6ZhBjZEREThw+CmDXG6NxERUetjcNOGovQMboiIiFobg5tW5Dk7iqsQExERtT4GN63IqFMGN57BDhEREYUfg5tWZLU5FN9zc0wiIqLWx+CmFZntyuCGmRsiIqLWx+CmlQiCAIvNM7hh5oaIiKi1MbhpJTaH4HUbMzdEREStj8FNK/HM2gDsuSEiImoLDG5aia/ghpkbIiKi1sfgppVYPZqJNWoVDFqebiIiotbWLq62r732GnJycmA0GjF69GisX7/e77FvvfUWxo0bh6SkJCQlJSE3Nzfg8ZFi9mom1kClUkVoNERERKeOiAc3S5cuRV5eHubNm4fNmzdjyJAhmDRpEkpLS30ev3LlSkyZMgUrVqzAunXrkJ2djQsvvBDHjx9v45EHZvHI3KTGGSI0EiIiolOLShAE72k9bWj06NE488wz8eqrrwIAHA4HsrOzce+992L27NlNPt5utyMpKQmvvvoqpk6d2uTxNTU1SEhIQHV1NeLj41s8fn/2FNfgooW/IiVWjyf/NBA9ukRjYFZCq70eERFRZxbK9TuimRuLxYJNmzYhNzdXuk2tViM3Nxfr1q0L6jnq6+thtVqRnJzcWsNsFrGhWKdR49LBmQxsiIiI2khE5yaXl5fDbrcjPT1dcXt6ejr27NkT1HM88sgj6Nq1qyJAkjObzTCbzdL3NTU1zR9wCMTgRs8mYiIiojbVoa+8zz33HJYsWYLPP/8cRqPR5zHz589HQkKC9JWdnd0mY5OCG02HPsVEREQdTkSvvCkpKdBoNCgpKVHcXlJSgoyMjICPfemll/Dcc8/hxx9/xODBg/0eN2fOHFRXV0tfR48eDcvYmyI2FDNzQ0RE1LYieuXV6/UYMWIE8vPzpdscDgfy8/MxZswYv4974YUX8PTTT2PZsmUYOXJkwNcwGAyIj49XfLUFec8NERERtZ2I7weQl5eHadOmYeTIkRg1ahQWLlwIk8mE6dOnAwCmTp2KrKwszJ8/HwDw/PPPY+7cufjwww+Rk5OD4uJiAEBsbCxiY2Mj9j48MXNDREQUGREPbiZPnoyysjLMnTsXxcXFGDp0KJYtWyY1GRcWFkKtdgcIb7zxBiwWC6699lrF88ybNw9PPPFEWw49IHGFYq5KTERE1LYiHtwAwKxZszBr1iyf961cuVLxfUFBQesPKAxYliIiIooMXnlbCWdLERERRQavvK3EYncu/MyeGyIiorbFK28r4SJ+REREkcErbythzw0REVFk8MrbSix2OwDOliIiImprvPK2Eit7boiIiCKCV95W4i5LqSI8EiIiolMLg5tWYpamgmsiPBIiIqJTC4ObVmLl9gtEREQRwStvK+FUcCIiosjglbeVuFcoZs8NERFRW2Jw00pYliIiIooMXnlbiYXBDRERUUTwyttKzFyhmIiIKCJ45W0lUlmKwQ0REVGb4pW3lXC2FBERUWTwyttKGNwQERFFBq+8rcTCshQREVFEaCM9gM7GYnOgsLKemRsiIqIIYXATZvO+2omP1hdK3zO4ISIialu88obZ7qIaxfecCk5ERNS2mLkJswqTWfE9e26IiNqWIAiw2Wyw2+2RHgqFSKfTQaPRtPh5GNyEWXmtRfG9gWUpIqI2Y7FYUFRUhPr6+kgPhZpBpVKhW7duiI2NbdHzMLgJo3qLDQ1W5V8K7LkhImobDocDhw8fhkajQdeuXaHX66FScfPijkIQBJSVleHYsWPo27dvizI4DG7CyDNrA7DnhoiorVgsFjgcDmRnZyM6OjrSw6FmSE1NRUFBAaxWa4uCG155w6jco98GYOaGiKitqdX8vdtRhSvTxk9AGJXXegc3WjVTokRERG2JwU0YVZi8y1Ks9xIREbUtBjdh5CtzQ0RERG2LwU0Y+crcEBERdURWqzXSQ2g2BjdhVFbnzNz0TImJ8EiIiKijWbZsGcaOHYvExER06dIFl112GQ4ePCjdf+zYMUyZMgXJycmIiYnByJEj8fvvv0v3f/311zjzzDNhNBqRkpKCq666SrpPpVLhiy++ULxeYmIiFi9eDAAoKCiASqXC0qVLMX78eBiNRnzwwQeoqKjAlClTkJWVhejoaAwaNAgfffSR4nkcDgdeeOEF9OnTBwaDAd27d8czzzwDAJgwYQJmzZqlOL6srAx6vR75+fnhOG0+cSp4GFW4gpu7zuuNL7cex+ieXSI8IiKiU5sgCF7rj7WVKJ0mpL5Lk8mEvLw8DB48GHV1dZg7dy6uuuoqbN26FfX19Rg/fjyysrLw1VdfISMjA5s3b4bD4dyk+dtvv8VVV12FRx99FO+//z4sFgu+++67kMc8e/ZsvPzyyxg2bBiMRiMaGxsxYsQIPPLII4iPj8e3336LW265Bb1798aoUaMAAHPmzMFbb72Ff/zjHxg7diyKioqwZ88eAMCMGTMwa9YsvPzyyzAYDACA//73v8jKysKECRNCHl+wGNyEUXmdsyzVLTEKH8w4K8KjISKiBqsdA+b+EJHX3vXUJETrg7/MXnPNNYrv33nnHaSmpmLXrl1Yu3YtysrKsGHDBiQnJwMA+vTpIx37zDPP4IYbbsCTTz4p3TZkyJCQx/zAAw/g6quvVtz20EMPSf++99578cMPP+Djjz/GqFGjUFtbi1deeQWvvvoqpk2bBgDo3bs3xo4dCwC4+uqrMWvWLHz55Ze4/vrrAQCLFy/Grbfe2qoTbiJelnrttdeQk5MDo9GI0aNHY/369X6P3blzJ6655hrk5ORApVJh4cKFbTfQIIiZm5Q4Q4RHQkREHc3+/fsxZcoU9OrVC/Hx8cjJyQEAFBYWYuvWrRg2bJgU2HjaunUrJk6c2OIxjBw5UvG93W7H008/jUGDBiE5ORmxsbH44YcfUFhYCADYvXs3zGaz39c2Go245ZZb8M477wAANm/ejB07duDWW29t8VgDiWjmZunSpcjLy8OiRYswevRoLFy4EJMmTcLevXuRlpbmdXx9fT169eqF6667Dg8++GAERuyf1e7AyXpn81WXGH2ER0NERICzNLTrqUkRe+1QXH755ejRowfeeustdO3aFQ6HAwMHDoTFYkFUVFTg12rifpVKBUEQFLf5ahiOiVH2jL744ot45ZVXsHDhQgwaNAgxMTF44IEHYLFYgnpdwFmaGjp0KI4dO4Z3330XEyZMQI8ePZp8XEtENHOzYMECzJw5E9OnT8eAAQOwaNEiREdHSxGepzPPPBMvvvgibrjhBql2116cdM2UUquApGgGN0RE7YFKpUK0XhuRr1DKLhUVFdi7dy8ee+wxTJw4EaeffjpOnjwp3T948GBs3boVlZWVPh8/ePDggA26qampKCoqkr7fv39/UJuLrlmzBldccQVuvvlmDBkyBL169cK+ffuk+/v27YuoqKiArz1o0CCMHDkSb731Fj788EPcdtttTb5uS0UsuLFYLNi0aRNyc3Pdg1GrkZubi3Xr1kVqWM0mzpRKjjFAzVWJiYgoBElJSejSpQv+/e9/48CBA/j555+Rl5cn3T9lyhRkZGTgyiuvxJo1a3Do0CH873//k66X8+bNw0cffYR58+Zh9+7d2L59O55//nnp8RMmTMCrr76KLVu2YOPGjbjzzjuh0+maHFffvn2xfPlyrF27Frt378Ydd9yBkpIS6X6j0YhHHnkEDz/8MN5//30cPHgQv/32G95++23F88yYMQPPPfccBEFQzOJqLRELbsrLy2G325Genq64PT09HcXFxWF7HbPZjJqaGsVXazCZ7YgzapESy6wNERGFRq1WY8mSJdi0aRMGDhyIBx98EC+++KJ0v16vx48//oi0tDRccsklGDRoEJ577jlpc8nzzjsPn3zyCb766isMHToUEyZMUPSwvvzyy8jOzsa4ceNw44034qGHHgpqc9HHHnsMw4cPx6RJk3DeeedJAZbc448/jr/85S+YO3cuTj/9dEyePBmlpaWKY6ZMmQKtVospU6bAaDS24EwFRyV4FuHayIkTJ5CVlYW1a9dizJgx0u0PP/wwVq1apZi770tOTg4eeOABPPDAAwGPe+KJJxTd46Lq6mrEx8c3a+yB2OwOaLkTOBFRm2tsbMThw4fRs2fPNrmAUvAKCgrQu3dvbNiwAcOHD/d7XKCfYU1NDRISEoK6fkfsKpySkgKNRqNIbwFASUkJMjIywvY6c+bMQXV1tfR19OjRsD23LwxsiIiInKxWK4qLi/HYY4/hrLPOChjYhFPErsR6vR4jRoxQNCE5HA7k5+crMjktZTAYEB8fr/giIiKi1rdmzRpkZmZiw4YNWLRoUZu9bkSngufl5WHatGkYOXIkRo0ahYULF8JkMmH69OkAgKlTpyIrKwvz588H4GxC3rVrl/Tv48ePY+vWrYiNjVUsZkRERESRd95553lNQW8LEQ1uJk+ejLKyMsydOxfFxcUYOnQoli1bJjUZFxYWQq12J5dOnDiBYcOGSd+/9NJLeOmllzB+/HisXLmyrYdPRERE7VDEGoojJZSGJCIi6jjYUNzxdfiGYiIiotZwiv3N3qmE62fH4IaIiDoFcVG6YFbepfZJ3NZBXL+nubgrOBERdQoajQaJiYnSAnLR0dGtuvM0hZfD4UBZWRmio6Oh1bYsPGFwQ0REnYa4TprnCrnUMajVanTv3r3FQSmDGyIi6jRUKhUyMzORlpbmc9drat/0er1ilnRzMbghIqJOR6PRtLhvgzouNhQTERFRp8LghoiIiDoVBjdERETUqZxyPTfiAkE1NTURHgkREREFS7xuB7PQ3ykX3NTW1gIAsrOzIzwSIiIiClVtbS0SEhICHnPK7S3lcDhw4sQJxMXFhW1xp5qaGmRnZ+Po0aPcryoIPF/B47kKDc9X8HiugsdzFZrWOl+CIKC2thZdu3Ztcrr4KZe5UavV6NatW6s8d3x8PD/4IeD5Ch7PVWh4voLHcxU8nqvQtMb5aipjI2JDMREREXUqDG6IiIioU2FwEwYGgwHz5s2DwWCI9FA6BJ6v4PFchYbnK3g8V8HjuQpNezhfp1xDMREREXVuzNwQERFRp8LghoiIiDoVBjdERETUqTC4ISIiok6FwU0YvPbaa8jJyYHRaMTo0aOxfv36SA8p4p544gmoVCrFV//+/aX7Gxsbcc8996BLly6IjY3FNddcg5KSkgiOuO388ssvuPzyy9G1a1eoVCp88cUXivsFQcDcuXORmZmJqKgo5ObmYv/+/YpjKisrcdNNNyE+Ph6JiYm4/fbbUVdX14bvou00db5uvfVWr8/aRRddpDjmVDlf8+fPx5lnnom4uDikpaXhyiuvxN69exXHBPP/XmFhIS699FJER0cjLS0Nf/3rX2Gz2dryrbS6YM7Veeed5/XZuvPOOxXHnArnCgDeeOMNDB48WFqYb8yYMfj++++l+9vb54rBTQstXboUeXl5mDdvHjZv3owhQ4Zg0qRJKC0tjfTQIu6MM85AUVGR9LV69WrpvgcffBBff/01PvnkE6xatQonTpzA1VdfHcHRth2TyYQhQ4bgtdde83n/Cy+8gH/+859YtGgRfv/9d8TExGDSpElobGyUjrnpppuwc+dOLF++HN988w1++eUX/PnPf26rt9CmmjpfAHDRRRcpPmsfffSR4v5T5XytWrUK99xzD3777TcsX74cVqsVF154IUwmk3RMU//v2e12XHrppbBYLFi7di3ee+89LF68GHPnzo3EW2o1wZwrAJg5c6bis/XCCy9I950q5woAunXrhueeew6bNm3Cxo0bMWHCBFxxxRXYuXMngHb4uRKoRUaNGiXcc8890vd2u13o2rWrMH/+/AiOKvLmzZsnDBkyxOd9VVVVgk6nEz755BPptt27dwsAhHXr1rXRCNsHAMLnn38ufe9wOISMjAzhxRdflG6rqqoSDAaD8NFHHwmCIAi7du0SAAgbNmyQjvn+++8FlUolHD9+vM3GHgme50sQBGHatGnCFVdc4fcxp/L5Ki0tFQAIq1atEgQhuP/3vvvuO0GtVgvFxcXSMW+88YYQHx8vmM3mtn0DbcjzXAmCIIwfP164//77/T7mVD1XoqSkJOH//u//2uXnipmbFrBYLNi0aRNyc3Ol29RqNXJzc7Fu3boIjqx92L9/P7p27YpevXrhpptuQmFhIQBg06ZNsFqtivPWv39/dO/e/ZQ/b4cPH0ZxcbHi3CQkJGD06NHSuVm3bh0SExMxcuRI6Zjc3Fyo1Wr8/vvvbT7m9mDlypVIS0tDv379cNddd6GiokK671Q+X9XV1QCA5ORkAMH9v7du3ToMGjQI6enp0jGTJk1CTU2N9Fd6Z+R5rkQffPABUlJSMHDgQMyZMwf19fXSfafqubLb7ViyZAlMJhPGjBnTLj9Xp9zGmeFUXl4Ou92u+GEBQHp6Ovbs2ROhUbUPo0ePxuLFi9GvXz8UFRXhySefxLhx47Bjxw4UFxdDr9cjMTFR8Zj09HQUFxdHZsDthPj+fX2mxPuKi4uRlpamuF+r1SI5OfmUPH8XXXQRrr76avTs2RMHDx7E3/72N1x88cVYt24dNBrNKXu+HA4HHnjgAZxzzjkYOHAgAAT1/15xcbHPz594X2fk61wBwI033ogePXqga9eu2LZtGx555BHs3bsXn332GYBT71xt374dY8aMQWNjI2JjY/H5559jwIAB2Lp1a7v7XDG4oVZx8cUXS/8ePHgwRo8ejR49euDjjz9GVFRUBEdGnc0NN9wg/XvQoEEYPHgwevfujZUrV2LixIkRHFlk3XPPPdixY4ei141883eu5H1ZgwYNQmZmJiZOnIiDBw+id+/ebT3MiOvXrx+2bt2K6upqfPrpp5g2bRpWrVoV6WH5xLJUC6SkpECj0Xh1hJeUlCAjIyNCo2qfEhMTcdppp+HAgQPIyMiAxWJBVVWV4hieN0jvP9BnKiMjw6th3WazobKy8pQ/fwDQq1cvpKSk4MCBAwBOzfM1a9YsfPPNN1ixYgW6desm3R7M/3sZGRk+P3/ifZ2Nv3Ply+jRowFA8dk6lc6VXq9Hnz59MGLECMyfPx9DhgzBK6+80i4/VwxuWkCv12PEiBHIz8+XbnM4HMjPz8eYMWMiOLL2p66uDgcPHkRmZiZGjBgBnU6nOG979+5FYWHhKX/eevbsiYyMDMW5qampwe+//y6dmzFjxqCqqgqbNm2Sjvn555/hcDikX76nsmPHjqGiogKZmZkATq3zJQgCZs2ahc8//xw///wzevbsqbg/mP/3xowZg+3btysCwuXLlyM+Ph4DBgxomzfSBpo6V75s3boVABSfrVPhXPnjcDhgNpvb5+cq7C3Kp5glS5YIBoNBWLx4sbBr1y7hz3/+s5CYmKjoCD8V/eUvfxFWrlwpHD58WFizZo2Qm5srpKSkCKWlpYIgCMKdd94pdO/eXfj555+FjRs3CmPGjBHGjBkT4VG3jdraWmHLli3Cli1bBADCggULhC1btghHjhwRBEEQnnvuOSExMVH48ssvhW3btglXXHGF0LNnT6GhoUF6josuukgYNmyY8PvvvwurV68W+vbtK0yZMiVSb6lVBTpftbW1wkMPPSSsW7dOOHz4sPDTTz8Jw4cPF/r27Ss0NjZKz3GqnK+77rpLSEhIEFauXCkUFRVJX/X19dIxTf2/Z7PZhIEDBwoXXnihsHXrVmHZsmVCamqqMGfOnEi8pVbT1Lk6cOCA8NRTTwkbN24UDh8+LHz55ZdCr169hHPPPVd6jlPlXAmCIMyePVtYtWqVcPjwYWHbtm3C7NmzBZVKJfz444+CILS/zxWDmzD417/+JXTv3l3Q6/XCqFGjhN9++y3SQ4q4yZMnC5mZmYJerxeysrKEyZMnCwcOHJDub2hoEO6++24hKSlJiI6OFq666iqhqKgogiNuOytWrBAAeH1NmzZNEATndPDHH39cSE9PFwwGgzBx4kRh7969iueoqKgQpkyZIsTGxgrx8fHC9OnThdra2gi8m9YX6HzV19cLF154oZCamirodDqhR48ewsyZM73+uDhVzpev8wRAePfdd6Vjgvl/r6CgQLj44ouFqKgoISUlRfjLX/4iWK3WNn43raupc1VYWCice+65QnJysmAwGIQ+ffoIf/3rX4Xq6mrF85wK50oQBOG2224TevToIej1eiE1NVWYOHGiFNgIQvv7XKkEQRDCnw8iIiIiigz23BAREVGnwuCGiIiIOhUGN0RERNSpMLghIiKiToXBDREREXUqDG6IiIioU2FwQ0RERJ0KgxsiOiWsXLkSKpXKa/8bIup8GNwQERFRp8LghoiIiDoVBjdE1K44HA688MIL6NOnDwwGA7p3745nnnkGEyZMwKxZsxTHlpWVQa/XS7sRm81mPPLII8jOzobBYECfPn3w9ttv+32t1atXY9y4cYiKikJ2djbuu+8+mEymVn1/RNT6GNwQUbsyZ84cPPfcc3j88cexa9cufPjhh0hPT8eMGTPw4Ycfwmw2S8f+97//RVZWFiZMmAAAmDp1Kj766CP885//xO7du/Hmm28iNjbW5+scPHgQF110Ea655hps27YNS5cuxerVq70CKCLqeLhxJhG1G7W1tUhNTcWrr76KGTNmKO5rbGxE165dsWjRIlx//fUAgCFDhuDqq6/GvHnzsG/fPvTr1w/Lly9Hbm6u13OvXLkS559/Pk6ePInExETMmDEDGo0Gb775pnTM6tWrMX78eJhMJhiNxtZ9s0TUapi5IaJ2Y/fu3TCbzZg4caLXfUajEbfccgveeecdAMDmzZuxY8cO3HrrrQCArVu3QqPRYPz48UG91h9//IHFixcjNjZW+po0aRIcDgcOHz4ctvdERG1PG+kBEBGJoqKiAt4/Y8YMDB06FMeOHcO7776LCRMmoEePHkE91lNdXR3uuOMO3HfffV73de/ePaTnIqL2hZkbImo3+vbti6ioKKlB2NOgQYMwcuRIvPXWW/jwww9x2223Ke5zOBxYtWpVUK81fPhw7Nq1C3369PH60uv1YXk/RBQZDG6IqN0wGo145JFH8PDDD+P999/HwYMH8dtvvylmPM2YMQPPPfccBEHAVVddJd2ek5ODadOm4bbbbsMXX3yBw4cPY+XKlfj44499vtYjjzyCtWvXYtasWdi6dSv279+PL7/8kg3FRJ0Agxsialcef/xx/OUvf8HcuXNx+umnY/LkySgtLZXunzJlCrRaLaZMmeLV9PvGG2/g2muvxd13343+/ftj5syZfqd2Dx48GKtWrcK+ffswbtw4DBs2DHPnzkXXrl1b9f0RUevjbCki6lAKCgrQu3dvbNiwAcOHD4/0cIioHWJwQ0QdgtVqRUVFBR566CEcPnwYa9asifSQiKidYlmKiDqENWvWIDMzExs2bMCiRYsiPRwiaseYuSEiIqJOhZkbIiIi6lQY3BAREVGnwuCGiIiIOhUGN0RERNSpMLghIiKiToXBDREREXUqDG6IiIioU2FwQ0RERJ0KgxsiIiLqVP4fFVjIZCMn/XgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10164}, {'accuracy': 0.14057999999999998}, {'accuracy': 0.11542999999999999}, {'accuracy': 0.24634}, {'accuracy': 0.20720999999999998}, {'accuracy': 0.28146}, {'accuracy': 0.27136}, {'accuracy': 0.26776}, {'accuracy': 0.25939999999999996}, {'accuracy': 0.24219}, {'accuracy': 0.31205000000000005}, {'accuracy': 0.29636}, {'accuracy': 0.34513000000000005}, {'accuracy': 0.38976}, {'accuracy': 0.36107999999999996}, {'accuracy': 0.33603000000000005}, {'accuracy': 0.46593}, {'accuracy': 0.4667299999999999}, {'accuracy': 0.46855}, {'accuracy': 0.50625}, {'accuracy': 0.4088}, {'accuracy': 0.5355099999999998}, {'accuracy': 0.49582999999999994}, {'accuracy': 0.473}, {'accuracy': 0.52451}, {'accuracy': 0.59044}, {'accuracy': 0.5158699999999999}, {'accuracy': 0.61534}, {'accuracy': 0.52991}, {'accuracy': 0.59187}, {'accuracy': 0.56673}, {'accuracy': 0.63285}, {'accuracy': 0.5958600000000001}, {'accuracy': 0.5826}, {'accuracy': 0.6588499999999999}, {'accuracy': 0.54993}, {'accuracy': 0.59579}, {'accuracy': 0.56418}, {'accuracy': 0.64261}, {'accuracy': 0.62513}, {'accuracy': 0.5526099999999999}, {'accuracy': 0.5787599999999999}, {'accuracy': 0.6548499999999999}, {'accuracy': 0.62462}, {'accuracy': 0.5570700000000001}, {'accuracy': 0.65919}, {'accuracy': 0.6465599999999999}, {'accuracy': 0.64056}, {'accuracy': 0.63918}, {'accuracy': 0.62873}, {'accuracy': 0.61358}, {'accuracy': 0.6508299999999999}, {'accuracy': 0.7025600000000001}, {'accuracy': 0.60972}, {'accuracy': 0.6661299999999999}, {'accuracy': 0.6337499999999999}, {'accuracy': 0.5927}, {'accuracy': 0.6668900000000001}, {'accuracy': 0.55304}, {'accuracy': 0.6424899999999999}, {'accuracy': 0.7215}, {'accuracy': 0.6607200000000001}, {'accuracy': 0.65933}, {'accuracy': 0.68133}, {'accuracy': 0.6290199999999999}, {'accuracy': 0.7224700000000001}, {'accuracy': 0.60033}, {'accuracy': 0.65704}, {'accuracy': 0.63112}, {'accuracy': 0.6589600000000001}, {'accuracy': 0.66403}, {'accuracy': 0.63844}, {'accuracy': 0.63567}, {'accuracy': 0.6181899999999999}, {'accuracy': 0.6704399999999999}, {'accuracy': 0.6486699999999999}, {'accuracy': 0.75789}, {'accuracy': 0.7305200000000001}, {'accuracy': 0.64187}, {'accuracy': 0.6169100000000001}, {'accuracy': 0.65657}, {'accuracy': 0.6497599999999999}, {'accuracy': 0.73966}, {'accuracy': 0.63823}, {'accuracy': 0.72482}, {'accuracy': 0.72264}, {'accuracy': 0.6668000000000001}, {'accuracy': 0.6831}, {'accuracy': 0.6931200000000001}, {'accuracy': 0.6386499999999999}, {'accuracy': 0.62393}, {'accuracy': 0.65505}, {'accuracy': 0.7570600000000001}, {'accuracy': 0.64857}, {'accuracy': 0.62264}, {'accuracy': 0.72403}, {'accuracy': 0.7221}, {'accuracy': 0.5987399999999999}, {'accuracy': 0.6643399999999999}, {'accuracy': 0.6465}, {'accuracy': 0.6653400000000002}, {'accuracy': 0.7001}, {'accuracy': 0.6779599999999999}, {'accuracy': 0.69804}, {'accuracy': 0.68134}, {'accuracy': 0.7022900000000001}, {'accuracy': 0.64052}, {'accuracy': 0.5900999999999998}, {'accuracy': 0.66198}, {'accuracy': 0.7239300000000001}, {'accuracy': 0.6728799999999999}, {'accuracy': 0.61995}, {'accuracy': 0.62351}, {'accuracy': 0.6845000000000001}, {'accuracy': 0.65887}, {'accuracy': 0.6807000000000001}, {'accuracy': 0.73996}, {'accuracy': 0.68228}, {'accuracy': 0.59575}, {'accuracy': 0.67773}, {'accuracy': 0.6269199999999999}, {'accuracy': 0.6988100000000002}, {'accuracy': 0.62436}, {'accuracy': 0.70177}, {'accuracy': 0.63053}, {'accuracy': 0.6728500000000001}, {'accuracy': 0.69553}, {'accuracy': 0.69139}, {'accuracy': 0.7632800000000001}, {'accuracy': 0.75797}, {'accuracy': 0.5676699999999999}, {'accuracy': 0.71194}, {'accuracy': 0.63588}, {'accuracy': 0.67033}, {'accuracy': 0.7386600000000001}, {'accuracy': 0.6665599999999999}, {'accuracy': 0.6976}, {'accuracy': 0.67584}, {'accuracy': 0.5926099999999999}, {'accuracy': 0.66376}, {'accuracy': 0.67746}, {'accuracy': 0.7565299999999999}, {'accuracy': 0.65319}, {'accuracy': 0.7377499999999999}, {'accuracy': 0.6881}, {'accuracy': 0.7189500000000001}, {'accuracy': 0.71919}, {'accuracy': 0.6626299999999998}, {'accuracy': 0.66093}, {'accuracy': 0.6750900000000001}, {'accuracy': 0.6004}, {'accuracy': 0.67603}, {'accuracy': 0.6211900000000001}, {'accuracy': 0.74672}, {'accuracy': 0.7483}, {'accuracy': 0.6550499999999999}, {'accuracy': 0.6523300000000001}, {'accuracy': 0.76772}, {'accuracy': 0.57718}, {'accuracy': 0.64422}, {'accuracy': 0.65255}, {'accuracy': 0.6620300000000001}, {'accuracy': 0.74616}, {'accuracy': 0.67105}, {'accuracy': 0.67485}, {'accuracy': 0.6788000000000001}, {'accuracy': 0.6950400000000001}, {'accuracy': 0.6940500000000001}, {'accuracy': 0.72484}, {'accuracy': 0.65068}, {'accuracy': 0.79747}, {'accuracy': 0.68297}, {'accuracy': 0.7575700000000001}, {'accuracy': 0.7330099999999999}, {'accuracy': 0.67404}, {'accuracy': 0.74034}, {'accuracy': 0.7078099999999999}, {'accuracy': 0.70744}, {'accuracy': 0.70835}, {'accuracy': 0.72882}, {'accuracy': 0.70852}, {'accuracy': 0.74679}, {'accuracy': 0.76217}, {'accuracy': 0.78617}, {'accuracy': 0.67489}, {'accuracy': 0.69885}, {'accuracy': 0.72}, {'accuracy': 0.65469}, {'accuracy': 0.7498400000000001}, {'accuracy': 0.7354500000000002}, {'accuracy': 0.7225799999999999}, {'accuracy': 0.72304}, {'accuracy': 0.63946}, {'accuracy': 0.5769399999999999}, {'accuracy': 0.7214700000000001}, {'accuracy': 0.79285}, {'accuracy': 0.76129}, {'accuracy': 0.6951799999999999}, {'accuracy': 0.7337}, {'accuracy': 0.63425}, {'accuracy': 0.6875899999999999}, {'accuracy': 0.79966}, {'accuracy': 0.82173}, {'accuracy': 0.78687}, {'accuracy': 0.81182}, {'accuracy': 0.79667}, {'accuracy': 0.8184700000000001}, {'accuracy': 0.8594900000000001}, {'accuracy': 0.8003300000000001}, {'accuracy': 0.8501799999999999}, {'accuracy': 0.845}, {'accuracy': 0.8236700000000001}, {'accuracy': 0.83477}, {'accuracy': 0.84081}, {'accuracy': 0.84108}, {'accuracy': 0.85579}, {'accuracy': 0.83492}, {'accuracy': 0.865}, {'accuracy': 0.84108}, {'accuracy': 0.83599}, {'accuracy': 0.8600199999999999}, {'accuracy': 0.84588}, {'accuracy': 0.83109}, {'accuracy': 0.82263}, {'accuracy': 0.83718}, {'accuracy': 0.8577899999999999}, {'accuracy': 0.8502599999999999}, {'accuracy': 0.8489800000000001}, {'accuracy': 0.8477499999999999}, {'accuracy': 0.8410300000000002}, {'accuracy': 0.8248599999999999}, {'accuracy': 0.83985}, {'accuracy': 0.8437699999999999}, {'accuracy': 0.8396100000000001}, {'accuracy': 0.8302900000000001}, {'accuracy': 0.8465300000000001}, {'accuracy': 0.8499500000000001}, {'accuracy': 0.84437}, {'accuracy': 0.8449300000000001}, {'accuracy': 0.82954}, {'accuracy': 0.8621399999999999}, {'accuracy': 0.8607400000000001}, {'accuracy': 0.8585900000000001}, {'accuracy': 0.8562900000000001}, {'accuracy': 0.84192}, {'accuracy': 0.85268}, {'accuracy': 0.8319899999999999}, {'accuracy': 0.8559600000000002}, {'accuracy': 0.84466}, {'accuracy': 0.86387}, {'accuracy': 0.85394}, {'accuracy': 0.8457100000000001}, {'accuracy': 0.82988}, {'accuracy': 0.8408299999999999}, {'accuracy': 0.83233}, {'accuracy': 0.84799}, {'accuracy': 0.83869}, {'accuracy': 0.8531400000000001}, {'accuracy': 0.8495800000000001}, {'accuracy': 0.84887}, {'accuracy': 0.86364}, {'accuracy': 0.84472}, {'accuracy': 0.8324900000000002}, {'accuracy': 0.84134}, {'accuracy': 0.83301}, {'accuracy': 0.84535}, {'accuracy': 0.84146}, {'accuracy': 0.8481}, {'accuracy': 0.83625}, {'accuracy': 0.8347300000000001}, {'accuracy': 0.8351900000000001}, {'accuracy': 0.8461500000000001}, {'accuracy': 0.8402100000000001}, {'accuracy': 0.84457}, {'accuracy': 0.85449}, {'accuracy': 0.8530899999999999}, {'accuracy': 0.8419799999999998}, {'accuracy': 0.8360199999999999}, {'accuracy': 0.85831}, {'accuracy': 0.84406}, {'accuracy': 0.84161}, {'accuracy': 0.84548}, {'accuracy': 0.8372999999999999}, {'accuracy': 0.82485}, {'accuracy': 0.8463600000000001}, {'accuracy': 0.8439099999999999}, {'accuracy': 0.8514900000000001}, {'accuracy': 0.84162}, {'accuracy': 0.8409500000000001}, {'accuracy': 0.84062}, {'accuracy': 0.85605}, {'accuracy': 0.8483500000000002}, {'accuracy': 0.8579700000000001}, {'accuracy': 0.83722}, {'accuracy': 0.8462299999999999}, {'accuracy': 0.83804}, {'accuracy': 0.8326100000000001}, {'accuracy': 0.8426899999999999}, {'accuracy': 0.8234}, {'accuracy': 0.8333999999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b7cf3cd-0f2e-4677-a995-3c01ef0af65a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77c0f3cf-2999-40aa-93e7-73924d2c4f26",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e0edaa-0ae8-4e79-8c56-98d960f604bf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc31766d-d70e-4c8b-8918-3533fb21d9bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccc00971-e277-4bc2-a8d5-11829397e40c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "881255e2-5d20-40f8-9ca4-d7951edfc419",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "852e18c7-bf8c-43ec-8a00-3baf3abad300",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67b920fe-6085-4e7b-aa1e-ffee1c7da95d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5077bfe-47be-4497-9357-aae20abd8020",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b8c5d9e-0713-47d6-b65c-ad0cbbdb8381",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ac7c8f3-1533-4f2f-b87f-06f31d57846b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "861fce81-26cd-4816-9e1c-e28c29edf298",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b09100c3-1f82-48be-a690-1ee8dcaf18af",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea5ccc50-d9a7-4c33-98e1-d735d267f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5c3e2be-286e-4579-a75c-e2ccd242744a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ca1d5af-0977-42b7-8b7c-82798f405218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b841f87-f6ff-41ae-8355-bfdd76b7bfdf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "143816ca-5628-4685-b4b6-0d494466f0b0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c03c21d9-b245-4fee-acc6-0ea2c7181435",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8749a4d4-3a47-445b-a1fb-e50cb94b3455",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bb3fac5e-315b-47de-b067-0bf21f0b6d3b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
