{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2413]\n",
      " [   1   72]\n",
      " [   2   39]\n",
      " [   3   74]\n",
      " [   4  114]\n",
      " [   5  177]\n",
      " [   6  296]\n",
      " [   7  509]\n",
      " [   8  873]\n",
      " [   9 1442]]\n",
      "[[   0 1450]\n",
      " [   1 2382]\n",
      " [   2   57]\n",
      " [   3   37]\n",
      " [   4   58]\n",
      " [   5  128]\n",
      " [   6  184]\n",
      " [   7  339]\n",
      " [   8  514]\n",
      " [   9  888]]\n",
      "[[   0  859]\n",
      " [   1 1486]\n",
      " [   2 2281]\n",
      " [   3   48]\n",
      " [   4   50]\n",
      " [   5   67]\n",
      " [   6   99]\n",
      " [   7  156]\n",
      " [   8  307]\n",
      " [   9  498]]\n",
      "[[   0  510]\n",
      " [   1  848]\n",
      " [   2 1483]\n",
      " [   3 2401]\n",
      " [   4   56]\n",
      " [   5   46]\n",
      " [   6   76]\n",
      " [   7  103]\n",
      " [   8  163]\n",
      " [   9  300]]\n",
      "[[   0  292]\n",
      " [   1  506]\n",
      " [   2  908]\n",
      " [   3 1431]\n",
      " [   4 2386]\n",
      " [   5   58]\n",
      " [   6   40]\n",
      " [   7   61]\n",
      " [   8  112]\n",
      " [   9  181]]\n",
      "[[   0  203]\n",
      " [   1  298]\n",
      " [   2  523]\n",
      " [   3  867]\n",
      " [   4 1452]\n",
      " [   5 2424]\n",
      " [   6   61]\n",
      " [   7   39]\n",
      " [   8   53]\n",
      " [   9  117]]\n",
      "[[   0  105]\n",
      " [   1  197]\n",
      " [   2  305]\n",
      " [   3  484]\n",
      " [   4  915]\n",
      " [   5 1469]\n",
      " [   6 2434]\n",
      " [   7   56]\n",
      " [   8   42]\n",
      " [   9   67]]\n",
      "[[   0   54]\n",
      " [   1   98]\n",
      " [   2  203]\n",
      " [   3  338]\n",
      " [   4  499]\n",
      " [   5  822]\n",
      " [   6 1385]\n",
      " [   7 2376]\n",
      " [   8   70]\n",
      " [   9   42]]\n",
      "[[   0   48]\n",
      " [   1   67]\n",
      " [   2  115]\n",
      " [   3  199]\n",
      " [   4  293]\n",
      " [   5  547]\n",
      " [   6  889]\n",
      " [   7 1484]\n",
      " [   8 2413]\n",
      " [   9   70]]\n",
      "[[   0   66]\n",
      " [   1   46]\n",
      " [   2   86]\n",
      " [   3  121]\n",
      " [   4  177]\n",
      " [   5  262]\n",
      " [   6  536]\n",
      " [   7  877]\n",
      " [   8 1453]\n",
      " [   9 2395]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\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": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "18182\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1694]\n",
      " [   1   46]\n",
      " [   2   22]\n",
      " [   3   46]\n",
      " [   4   76]\n",
      " [   5  130]\n",
      " [   6  206]\n",
      " [   7  375]\n",
      " [   8  630]\n",
      " [   9  957]]\n",
      "[[   0 2425]\n",
      " [   1   63]\n",
      " [   2   31]\n",
      " [   3   67]\n",
      " [   4  112]\n",
      " [   5  198]\n",
      " [   6  313]\n",
      " [   7  538]\n",
      " [   8  873]\n",
      " [   9 1395]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        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(((target1[z] - 1) % 10))\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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hello this is in generate\n",
      "10\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "0\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "1\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "2\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "3\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "4\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "5\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "6\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "7\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "8\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is known nodes\n",
      "range(0, 10)\n",
      "9\n",
      "9\n",
      "9\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\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\">040623-21:51:27 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/simul.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/simul.py#381\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">381</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m040623-21:51:27\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b]8;id=421766;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/simul.py\u001b\\\u001b[2msimul.py\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=851432;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/simul.py#381\u001b\\\u001b[2m381\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "84cc90ae11044333858fe8a5a7efd7bf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "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": 10,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACcPklEQVR4nO3dd5wTdfoH8E96the2siwsHZEOgigIAoK9K6IniMp5IqceVn6ecHrnYRfPhuep6N2pKGcvoCCgIIJSpPdetvfsbur8/khmMjOZ7CbbsmQ/79fLl7vJZPLNsDDPPs/z/X51giAIICIiIooS+kgPgIiIiKg5MbghIiKiqMLghoiIiKIKgxsiIiKKKgxuiIiIKKowuCEiIqKowuCGiIiIogqDGyIiIooqDG6IiIgoqjC4IaIWtWrVKuh0OqxatUp67JZbbkFeXl7ExhRN/vKXv0Cn00V6GERtCoMbojZux44d+N3vfoecnBxYLBZ07NgRN910E3bs2BHpobW4V199FYsWLWrR99i5cyf+8pe/4PDhwy36Pq3p73//Oz799NNID4MoYhjcELVhH3/8MYYMGYIVK1Zg+vTpePXVV3Hbbbdh5cqVGDJkCD755JNID7FFtVZw89hjjzG4IYoixkgPgIi0HThwADfffDO6deuGH374Aenp6dJz99xzD0aPHo2bb74ZW7duRbdu3VptXDabDXFxca32fqcDXhOitoWZG6I26plnnkFNTQ3++c9/KgIbAEhLS8Prr78Om82Gp59+GgCwZMkS6HQ6rF69OuBcr7/+OnQ6HbZv3y49tnv3blx77bVITU2F1WrFsGHD8Pnnnytet2jRIumcM2fOREZGBjp16gQAOHLkCGbOnInevXsjJiYGHTp0wHXXXddsGZC8vDzs2LEDq1evhk6ng06nw9ixY6Xny8vLce+99yI3NxcWiwU9evTAU089BY/HozjPBx98gKFDhyIhIQGJiYno378/XnzxRenzXXfddQCA888/X3ofeX+Q2i233IL4+HgcOHAAF198MRISEnDTTTcBADweDxYsWIAzzzwTVqsVmZmZuOOOO1BWVqY4x6+//opJkyYhLS0NMTEx6Nq1K2699Vbpea0+JQA4fPgwdDpdvdksnU4Hm82Gd955R/o8t9xyCwCgqqoK9957L/Ly8mCxWJCRkYELLrgAmzZtCno+otMRMzdEbdQXX3yBvLw8jB49WvP58847D3l5efjqq68AAJdccgni4+Px4YcfYsyYMYpjFy9ejDPPPBP9+vUD4O3jOffcc5GTk4OHH34YcXFx+PDDD3HllVfif//7H6666irF62fOnIn09HTMnTsXNpsNAPDLL7/gp59+wg033IBOnTrh8OHDeO211zB27Fjs3LkTsbGxTfr8CxYswB//+EfEx8fjkUceAQBkZmYCAGpqajBmzBicOHECd9xxBzp37oyffvoJc+bMwalTp7BgwQIAwHfffYcpU6Zg/PjxeOqppwAAu3btwtq1a3HPPffgvPPOw913341//OMf+L//+z+cccYZACD9PxiXy4VJkyZh1KhRePbZZ6XPescdd2DRokWYPn067r77bhw6dAgvv/wyNm/ejLVr18JkMqGwsBATJ05Eeno6Hn74YSQnJ+Pw4cP4+OOPm3S9RP/+979x++23Y/jw4fj9738PAOjevTsA4A9/+AOWLFmCWbNmoW/fvigpKcGaNWuwa9cuDBkypFnen6hNEIiozSkvLxcACFdccUW9x11++eUCAKGyslIQBEGYMmWKkJGRIbhcLumYU6dOCXq9Xnj88celx8aPHy/0799fqKurkx7zeDzCOeecI/Ts2VN67O233xYACKNGjVKcUxAEoaamJmA869atEwAI7777rvTYypUrBQDCypUrpcemTZsmdOnSpd7PJgiCcOaZZwpjxowJePyvf/2rEBcXJ+zdu1fx+MMPPywYDAbh6NGjgiAIwj333CMkJiYGjF3uo48+ChhffaZNmyYAEB5++GHF4z/++KMAQPjvf/+reHzp0qWKxz/55BMBgPDLL78EfQ+tayYIgnDo0CEBgPD2229Lj82bN09Q/1MeFxcnTJs2LeC8SUlJwl133RXCpyQ6vbEsRdQGVVVVAQASEhLqPU58vrKyEgAwefJkFBYWKsoZS5YsgcfjweTJkwEApaWl+P7773H99dejqqoKxcXFKC4uRklJCSZNmoR9+/bhxIkTiveZMWMGDAaD4rGYmBjpa6fTiZKSEvTo0QPJycktXub46KOPMHr0aKSkpEjjLy4uxoQJE+B2u/HDDz8AAJKTk2Gz2fDdd981+xjuvPPOgDElJSXhggsuUIxp6NChiI+Px8qVK6UxAcCXX34Jp9PZ7OOqT3JyMtavX4+TJ0+26vsStTYGN0RtkBi0iEFOMOog6MILL0RSUhIWL14sHbN48WIMGjQIvXr1AgDs378fgiDg0UcfRXp6uuK/efPmAQAKCwsV79O1a9eA966trcXcuXOlnpe0tDSkp6ejvLwcFRUVjfzkodm3bx+WLl0aMP4JEyYoxj9z5kz06tULF110ETp16oRbb70VS5cubfL7G41GqfdIPqaKigpkZGQEjKu6uloa05gxY3DNNdfgscceQ1paGq644gq8/fbbsNvtTR5XQ55++mls374dubm5GD58OP7yl7/g4MGDLf6+RK2NPTdEbVBSUhKys7OxdevWeo/bunUrcnJykJiYCACwWCy48sor8cknn+DVV19FQUEB1q5di7///e/Sa8SG2/vvvx+TJk3SPG+PHj0U38uzNKI//vGPePvtt3Hvvfdi5MiRSEpKgk6nww033BDQ1NvcPB4PLrjgAjz44IOaz4uBXEZGBrZs2YJly5bhm2++wTfffIO3334bU6dOxTvvvNPo97dYLNDrlb8bejweZGRk4L///a/ma8SmcJ1OhyVLluDnn3/GF198gWXLluHWW2/Fc889h59//hnx8fFBF+Vzu92NHjMAXH/99Rg9ejQ++eQTfPvtt3jmmWfw1FNP4eOPP8ZFF13UpHMTtSUMbojaqEsvvRRvvPEG1qxZg1GjRgU8/+OPP+Lw4cO44447FI9PnjwZ77zzDlasWIFdu3ZBEASpJAVAmjZuMpmkTEdjLFmyBNOmTcNzzz0nPVZXV4fy8vJGn1Mt2E2+e/fuqK6uDmn8ZrMZl112GS677DJ4PB7MnDkTr7/+Oh599FH06NGj2Vb37d69O5YvX45zzz1XMxhUO/vss3H22WfjiSeewHvvvYebbroJH3zwAW6//XakpKQAQMC1PHLkSEhjqe8zZWdnY+bMmZg5cyYKCwsxZMgQPPHEEwxuKKqwLEXURj3wwAOIiYnBHXfcgZKSEsVzpaWl+MMf/oDY2Fg88MADiucmTJiA1NRULF68GIsXL8bw4cMVZaWMjAyMHTsWr7/+Ok6dOhXwvkVFRSGNz2AwQBAExWMvvfRSk7MLcnFxcZrB0vXXX49169Zh2bJlAc+Vl5fD5XIBQMB10+v1GDBgAABIZSBxfZqmBmXXX3893G43/vrXvwY853K5pPOXlZUFXLdBgwYpxtSlSxcYDAapd0j06quvhjQWrevmdrsDyoUZGRno2LFjq5TEiFoTMzdEbVTPnj3xzjvv4KabbkL//v1x2223oWvXrjh8+DDefPNNFBcX4/3335em+YpMJhOuvvpqfPDBB7DZbHj22WcDzv3KK69g1KhR6N+/P2bMmIFu3bqhoKAA69atw/Hjx/Hbb781OL5LL70U//73v5GUlIS+ffti3bp1WL58OTp06NBs12Do0KF47bXX8Le//Q09evRARkYGxo0bhwceeACff/45Lr30Utxyyy0YOnQobDYbtm3bhiVLluDw4cNIS0vD7bffjtLSUowbNw6dOnXCkSNH8NJLL2HQoEHSdO9BgwbBYDDgqaeeQkVFBSwWC8aNG4eMjIywxjpmzBjccccdmD9/PrZs2YKJEyfCZDJh3759+Oijj/Diiy/i2muvxTvvvINXX30VV111Fbp3746qqiq88cYbSExMxMUXXwzAW5a87rrr8NJLL0Gn06F79+748ssvA3qh6rtuy5cvx/PPP4+OHTuia9eu6N27Nzp16oRrr70WAwcORHx8PJYvX45ffvlFkX0jigqRnaxFRA3ZunWrMGXKFCE7O1swmUxCVlaWMGXKFGHbtm1BX/Pdd98JAASdTiccO3ZM85gDBw4IU6dOFbKysgSTySTk5OQIl156qbBkyRLpGHEquNa05bKyMmH69OlCWlqaEB8fL0yaNEnYvXu30KVLF8U05KZMBc/PzxcuueQSISEhQQCgmBZeVVUlzJkzR+jRo4dgNpuFtLQ04ZxzzhGeffZZweFwCIIgCEuWLBEmTpwoZGRkCGazWejcubNwxx13CKdOnVK8zxtvvCF069ZNMBgMDU4LnzZtmhAXFxf0+X/+85/C0KFDhZiYGCEhIUHo37+/8OCDDwonT54UBEEQNm3aJEyZMkXo3LmzYLFYhIyMDOHSSy8Vfv31V8V5ioqKhGuuuUaIjY0VUlJShDvuuEPYvn17SFPBd+/eLZx33nlCTEyMAECYNm2aYLfbhQceeEAYOHCgkJCQIMTFxQkDBw4UXn311fr+CIhOSzpBUOVHiYiIiE5j7LkhIiKiqMLghoiIiKIKgxsiIiKKKgxuiIiIKKowuCEiIqKowuCGiIiIokq7W8TP4/Hg5MmTSEhIaLZl14mIiKhlCYKAqqoqdOzYMWBvN7V2F9ycPHkSubm5kR4GERERNcKxY8fQqVOneo9pd8FNQkICAO/FEXdSJiIioratsrISubm50n28Pu0uuBFLUYmJiQxuiIiITjOhtJSwoZiIiIiiCoMbIiIiiioMboiIiCiqMLghIiKiqMLghoiIiKIKgxsiIiKKKgxuiIiIKKowuCEiIqKowuCGiIiIogqDGyIiIooqDG6IiIgoqjC4ISIioqjC4IaIiE5rHo8Aj0eI9DCoDWFwQ0REYbPZXfhsywlU1TkjPRTc/9FvGPT4tyiorIv0UKiNYHBDRERhe3vtIdzzwRa8svJARMdhd7nx5dZTqKxzYd2BkoiOhdoOBjdERBS2/YXVAID1hyIbUOw4WQmH2wMA2FNQ1WLvIwgCXvhuL5bvLGix92hNG4+U4pttp0I+fuXuQrzw3d7TpvxnjPQAiIjo9HOy3FsC2nGiEnaXGxajISLj2Hy0XPp6b37LBTe/Ha/Aiyv2oUOcGb+eMQE6na7Z3+OjX48h1mzEJQOym/3ccnVON2556xdU2V1Yef9YdE2Lq/d4QRDw0P+2orDKjtE90zAsL7VFx9ccmLkhIqKwnSivBQA43B7sOFkZ1ms3HS3DsL8tx0e/HmvyODYdLZO+3t2Cwc2REhsAoMTmQH5lHZ77dg8+3nS82c6/9Xg5HliyFfd8sLnF+5h+3FeMKrsLALD7VMN/doVVdhRW2QEAR0pqWnRszYXBDRERYfuJCtz5n404VtrwzcvtEZAva96VZ09CsWx7Poqr7fj8t5PhDjPA5iP+4OZEeW2LBQZiMAcAi9Yexkvf78fsD3/Dv9cdbpbzv73Wex6XR8C2ExXNck6RxyNgzb5i1DrcAICl2/Ol5/YXVuOxL3bg+tfXBb12O076x3OszP/zcaqiFnaXO+D4vS1YHgwVgxsiIsLfv96Fb7bnY9FPhxs8trCqDm5Z78VmWfYkFGJvzJ4mZlryK+pwsqIOeh2QEmsCAOzz9QI1B0EQ8O2OfBwoqsaJMn9w896Go9LXj362o95G5h0nK/B/n2xDYZVyJtfGI6X4/bu/4nCxDYVVdfhyqz/Q23o8eHCzJ78Ku0LItsj9d8NR/O7N9fj717vgdHuwfJe/b+i34xV456fD2HCoFEs2HseXW0/iHyv2QRD8f747Tvjf71ip9zqs2lOIc5/8Ho9+ul3xXrtOVWLiCz/g+tfXwenrhYoE9twQEbVzhZV1WHfQe4OW/5YejPxGDwCbjpTB7RFg0AfvQ6m2u/C/jcdxUb8sqTemsMqO8hoHkmPNIY9VEAR8v7sQuamxeG+9N8jolZmA9AQLftxXjL35VRjSOaXB8+RX1CG/sg5nZCdo9gt5PALmfLwNi389hl6Z8eiYHCM9V1XnLemkxZtRXO3ARxuPYWT3DgHncLo9+OP7m3GwyIbKWidevnEIAKCyzomZ/92Egko7MhItyEiwwun2BxNbj5drjnnjkTLc8M91MOr1WDdnXMjX7eut3sbhpTvyMfHMTFTU+jM0q/cWQoxTX111ACXVdngE4Ky8VOkzycuOx8pq4PEIeGrpHngE4Jtt+fj7Vf1hNHhzJa+t8s6eS0+wwGSIXP6EwQ0RUTv3xdZTEH9R33myEoIg1NswK5Zo+uUkYl9BNU5W1OH619ehotYJg06H20Z3xUX9spBg9WZTBEHA/R/+hqU78rF6bxFOVvizGHsLqjG8ayp+/+6v2F9YjU9mnoskXxYG8AZFNXYXMhKtAIB//3wEcz/boRjPHWO6YefJSvy4r7jBvhub3YW739+MFbsLAQB5HWKx+I6RyPSdX/SP7/dhsa8naG9BNap9AY3c/RN74+GPt2H5zgI4XB6Yjcqb+Qe/HMPBIm+vzpdbT+EPYyrQLycJT36zGwWV3h6WNfuKYTV5g6urh+Tg400n8Nsxf4ApCAIe/Ww7DhXbsCe/Gk63AKfbjdV7i3DFoBzpuP2F1SivcWBolxTFn11lnRO/HC4FABRV2fHkN7sBACO6pmL9oVJFUFXk66sBgLX7i/3BzSn/eI6X1mDZjnwpe1Rld2HHyUr0zkrAyfJaKQN155jumte/tbAsRUTUzn2+5YT0dWWdC8dVmRk1caZUr4wEPHvdQFhNemw8Uob9hdXYU1CFB5dsxYDHvsX0tzfA7RHw8aYTWLrD2+fxvS+oEO0pqML2ExX4dmcBDhbb8Mnm45jz8TZc89pPqKpz4sY3fsbop1di+4kK1DrceOn7/dJrdTrgyav746rBndAnKxGAN/i578Pf8OvhUkVpBQBqHC5MeeNnrNhdCL0OiDEZcLikBje+8TMqZf0mgiBg8S/KZmd5QAZ4MxPXDctFWrzFu8aOL/P127Fy7C+swvGyGiz4bi8AICPBAgB4Ztke7M6vlDJOeh1wuKQGu/OroNcBf5rQCzqdN3gsrrZL1+s/Px/F2v0lKK62Q4xbVuzyX8eDRdW47KU1uHbhOlz04o+Knpc1+4rhkpUQxSzMgxf2hsngD4KSZQElAKw9UAwAqKh1SqUoADhVWYd/+P4MxNe//sMBDHzsW4x7bjU8AjC2dzr65SQhkiIe3LzyyivIy8uD1WrFiBEjsGHDhnqPLy8vx1133YXs7GxYLBb06tULX3/9dSuNlogoumw5Vo7fjlfAoNehU4q39KIuTQmCgH+s2IfZi7fgsy0ncNzXVNoxOQaXDeyIz+4ahd+d3RnPXz8Qj1x8BjqnxkIQgJV7irDrVCWe+HpX0PffV1CFD2Wzpl5csQ/vbziKjUfK8NgXO7H1eAXsLg/mfb4Db609hKIqO3KSY7D+/8Zj1f1jccPwzgCAywZ2xMS+mXB7BPxv03Fcu3Adpr61ARU1/qDly99OYevxCqTEmvDxzHPx7Z/OQ3aSFQeKbPh4o3/m04EiG05V1MFs0OPsbsppz6lx3lLQiK6pMOh1mHRmJgDgm22n8M22U7jilbW44IUfcOlLa1Bic6BnRjzemzECRr0Oq/cWYdZ7mwEAlwzIxtAu/vLZsLxU5KbGoptvWvbW4+UQBEEK5i7om4k7x3bHizcMBuDteXG5PXC6PfjT4i2odXobe3fnV2GeLLO10hdMdojzl7DOyE7EkM4pyOvgnwL+zLUDMWV4Ll6aMtj3/hWoqnNipy8YykmOgdWkhyB4+2p0OuD353UDAHy9LR92l7e/Rq8D/jiuZ9A/79YS0eBm8eLFmD17NubNm4dNmzZh4MCBmDRpEgoLCzWPdzgcuOCCC3D48GEsWbIEe/bswRtvvIGcnBzN44mIKDhBEDDfF3hcOSgH53ZPA4CAqd0Himx4/ru9+HjzCdzzwRb815d5EPtQemcl4G9X9sfVQzphxnnd8MOD50tBwaebT6DU5kCMySAFAoA/m7H1eAU+3ezPHJXJgpElsoBj45EyPLNsDwDg7vE9kJloRRfZzdls1OOfU4fhk5nn4NqhnWA16fHjvmJc9dpalNocAIAVu72NtNPOycOg3GTkpsZi+rl5AIDlskzImn1FAICzuqZgsKx/Jy3eguG+NV5G9/Req4v6edek+eCXY7jngy2+6wqU1zjRPT0O/75tBHpkJODWUV0B+Bc/vGtsD4zumS6de2Jf77UZmJsMwDt76tMtJ7DlWDksRj3+flV/PHRhH1zSPxvJsSZU1rmwZn8xHlqyFb8dr0Ci1YgP7xgJvQ5Yd7AE+wur8enmE/jat1DfA5N6S+9144jO0Ol06JERD8CbgRndMw3zrx6AywZ2RF6HWLg9AtYfLJVKWv1zktApJVY6x4CcJFzSv6P0vdWkxyczz8H3941VBG2REtHg5vnnn8eMGTMwffp09O3bFwsXLkRsbCzeeustzePfeustlJaW4tNPP8W5556LvLw8jBkzBgMHDmzlkRMRnf5W7SnC+kOlMBv1uG9iL5yZ4y3tqIObVXu8N34xIBF1TFb2qcj195UlPvIFKP07JWH8Gf7gRlyobsuxclTWuZCTHIOL+2cB8JaLzLJm1PN6eYMAk0GHW8/timuH5gZ938GdU/DsdQPxvzvPQXaSFQeLbPj717tgd7nx4z5vqWWCbBwX9PW+588HS7BsRz4e+2IHvt7mLaGN6pGOM7ITpWNzUmIw7/K+ePa6gbjON4Zze3TAtJFdAHjX/Dm3Rwd88Puzce+Enlh8x0hkJXmv0d3jeyIz0Xv9xvfJQN+OiRjlC5C84/COafo5XRFjMuDHfcX40+LfAABThndGuu/aG/Q6nN87AwBwy9u/4OPNJ2DQ6/D0tQMxvGsqxvXxnud3/1qPexdvgc3hxll5KbhmaCdceGYW+mQl4MpB3qCke7o3uOmbnSj1/QDAOT2841qzv1gqI47pnY7cFH9T9Zhe6eiTlSDNUrt9VDcM7pyCvAYWBGwtEWsodjgc2LhxI+bMmSM9ptfrMWHCBKxbt07zNZ9//jlGjhyJu+66C5999hnS09Nx44034qGHHoLBoL06pt1uh93ub5KqrAxvCh0RUbT61reVwJSzctExOQZndvTeyH85XIr31h/FdcM6wWTQY6UvuLljTHf8uK8Iq/Z4Mxs5shlEamLPhTgzZ3BuMsb28mcqLu6fLa3tAnizMWd2TMLmo+WYObY7fj5Uiq+2nkJavAVvThuGtfuL0TMzod73lDuzYxJeuWkIrnntJyzZeBwZCRbUONzITLRInxMAuqbFoUdGPPYXVuOOf29UnGN0zzRYZE3CnZJjkJ0Ug2uHdpIe0+l0eOyKfrh8UEesO1CCm0fmISnGhLO7KWdPxVuMePGGwXh99QE8cskZAICBnZIxeVguEmOMUhaqf6ck/HPqUNy26Fe4PB5MHZmHhy/qozjX78/rhr0FVdhxshJWkx6v3jRECmpuOrszlu8qQH5lHQx6He4Z3xN3ju0Ok0GPhTcPVZzn0oHZ+N+m47jp7C6Kx8/vnYH31h/Fx5uOS4v9nd87QzEFfUzvdOj1Ovzl8jPx0/4S3Dk2sg3EahELboqLi+F2u5GZmal4PDMzE7t379Z8zcGDB/H999/jpptuwtdff439+/dj5syZcDqdmDdvnuZr5s+fj8cee6zZx09EdLoT1yHJ9gUMfbOTkBpnRqnNgf/7ZBtW7y3E09cOxIZD3tLE+b3TMapHmhTcdKwn0OivaigdmJuMjEQr7hzbHafKazGkcwpuGtEZ209W4pGLz8Dwrt5yz7o54wF4MzC/Hi7FnWO8N+axvmxFOIZ0TsGU4Z3x3vqjeNU3RXlcn4yAmWATzsiUykVGvQ4uj4DUODP6ZifCIwgwG/VwuDzISQn+eYd2ScXQLvVvS3B2tw6KoMeg1+GpawcEHDe6ZzqW/ek86ADNTMgZ2Yn46u7ROFleC6NeJ80kA4DzeqZjeNdUnCirxbPXDdScoi7qk5UoXW+5cX0y0KVDrLQacd/sRGQlWZHrK0slWo0Y2CkZAHDFoBzFrK224rSaCu7xeJCRkYF//vOfMBgMGDp0KE6cOIFnnnkmaHAzZ84czJ49W/q+srISubnBU5pERO2FuAmiwXezjzEbsOze8/C/Tcfx/Ld7sWxHAY6UrIPTLaBLh1h0TYuDTqfDh3eMBADEWYLfQvI6xCHeYkS17zf/Qb5ekocu9Gchnriqf9DX98tJwvr/m9CkzwcAD1/UB/kVdVJ55cJ+gfs2XTYwG//84QDyOsThnVuH4801h3B2t1To9TrooUPvzARsO1ERctaoOTS03xOgHVwa9Dp8MONs6HRo9P5XBr0Ot4/qikd9jcnj+ngDy5HdO0CvA64Z2kla16atilhwk5aWBoPBgIIC5Q6rBQUFyMrK0nxNdnY2TCaTogR1xhlnID8/Hw6HA2Zz4IJGFosFFosl4HEiovbO7ZsqrZctvpeeYMEfxnRH59RY3PXeJmndGHnGQ8yy1Eev16Fvx0RsOFSK9AQLspOC9+e0pESrCW/dcha2n6hAUZUdY2SlMdGZHZPw7Z/GICvJiniLEX+5/EzF87eOysM7Px3BhL6ZAa9ti/T1LKYYqmuH5mLB8n0osTmkz90vJwlb5k1ErCkym6SGI2LBjdlsxtChQ7FixQpceeWVALyZmRUrVmDWrFmarzn33HPx3nvvwePxQK/3Ro179+5Fdna2ZmBDRETBuaXMTeBzF/fPxv/uPAfrD5bC6fbgd6q+jFD0z0nChkOlGJSb3CK7aIejoXVXxJlDWq4a3AlXDe4U9PloFGM24L0ZZ+NEeY2UdQO8weLpIKJlqdmzZ2PatGkYNmwYhg8fjgULFsBms2H69OkAgKlTpyInJwfz588HANx55514+eWXcc899+CPf/wj9u3bh7///e+4++67I/kxiIhOSx6NzI3ckM4pIW1lEMy0kXk4UFTd5ppNKTS9sxLQOysh0sNolIgGN5MnT0ZRURHmzp2L/Px8DBo0CEuXLpWajI8ePSplaAAgNzcXy5Ytw5/+9CcMGDAAOTk5uOeee/DQQw9F6iMQEZ22xMyNvoWyKp07xGLR9OEtcm6i+ugE9frUUa6yshJJSUmoqKhAYmJiwy8gIopSt7/zK5bvKsD8q/tjim+lX6K2Kpz7d9tudyYiohYjlqUMEe6HIWpuDG6IiNopqSzVDLNriNoSBjdERO2UlLnhnYCiDH+kiYjaqZZuKCaKFAY3RETtlLTODctSFGUY3BARtVNsKKZoxeCGiKidYkMxRSsGN0RE7ZTbt8oZMzcUbRjcEBG1Ux723FCUYnBDRNROsSxF0YrBDRFRO8WGYopWDG6IiNopf+YmwgMhamb8kSYiaqfczNxQlGJwQ0TUTrGhmKIVgxsionZKzNywoZiiDYMbIqJ2yuPx/p9lKYo2DG6IiNop7i1F0YrBDRFROyWVpZi5oSjD4IaIqJ1iQzFFKwY3RETtlDQVnHcCijL8kSYiaqfEzA3LUhRtGNwQEbVTHnFXcJalKMowuCEiaqfczNxQlGJwQ0TUTvl7bhjcUHRhcENE1E6x54aiFYMbIqJ2yr/9QoQHQtTM+CNNRNQOCYIAQWwoZuaGogyDGyKidkhsJgbYc0PRh8ENEVE7JJakAO4KTtGHwQ0RUTsk7ggOsCxF0YfBDRFROyTP3LAsRdGGwQ0RUTsk77nhVHCKNgxuiIjaIQ8biimKMbghImqHFA3FjG0oyjC4ISJqh/yrEwM6lqUoyjC4ISJqh7ivFEUzBjdERO0QdwSnaMbghoioHRLXuWHmhqIRgxsionZIKksxc0NRiMENEVE7JJWlmLmhKMTghoioHfKwoZiiGIMbIqJ2iA3FFM0Y3BARtUNicGPgXYCiEH+siYjaIQ8biimKMbghImqH2FBM0YzBDRFRO8SGYopmDG6IiNoht7iIH8tSFIUY3BARtUMsS1E0Y3BDRNQOCWwopijG4IaIqB0St19g5oaiEYMbIqJ2iOvcUDTjjzUR0Wnmgw1HMfaZlThcbGv0OcTZUlyhmKIRgxsiotPM19vzcbikBusOljT6HOJsKQY3FI0Y3BARnWbsTjcAwOHyNPoc/rIUgxuKPm0iuHnllVeQl5cHq9WKESNGYMOGDUGPXbRoEXQ6neI/q9XaiqMlIooshy/t0pTghtsvUDSLeHCzePFizJ49G/PmzcOmTZswcOBATJo0CYWFhUFfk5iYiFOnTkn/HTlypBVHTERN9cVvJzHqqe+x7XhFpIdyWrI7vUGN3eVu9Dn869w0y5CI2pSI/1g///zzmDFjBqZPn46+ffti4cKFiI2NxVtvvRX0NTqdDllZWdJ/mZmZrThiImqq5bsKcLysFj/sK4r0UE5LYlBjb47MDctSFIUiGtw4HA5s3LgREyZMkB7T6/WYMGEC1q1bF/R11dXV6NKlC3Jzc3HFFVdgx44dQY+12+2orKxU/EdEkVXn6xmx2V0RHsnpKdyy1N6CKvzty50otTmkx6TMDctSFIUiGtwUFxfD7XYHZF4yMzORn5+v+ZrevXvjrbfewmeffYb//Oc/8Hg8OOecc3D8+HHN4+fPn4+kpCTpv9zc3Gb/HEQUHjHjUONofFmlPfOXpUILbi5/eQ3+teYQHvrfVukxNhRTNIt4WSpcI0eOxNSpUzFo0CCMGTMGH3/8MdLT0/H6669rHj9nzhxUVFRI/x07dqyVR0xEauLNmZmbxhGDmlB7bup813u9bOo4G4opmhkj+eZpaWkwGAwoKChQPF5QUICsrKyQzmEymTB48GDs379f83mLxQKLxdLksRJR8xFvyszcNI7DFV7mRlTr9F9vaZ0bZm4oCkU0c2M2mzF06FCsWLFCeszj8WDFihUYOXJkSOdwu93Ytm0bsrOzW2qYRNTMxJtyNTM3YRMEodENxU63IH3tZuaGolhEMzcAMHv2bEybNg3Dhg3D8OHDsWDBAthsNkyfPh0AMHXqVOTk5GD+/PkAgMcffxxnn302evTogfLycjzzzDM4cuQIbr/99kh+DCIKg7/nJvqDG49HQJXdhaQYU7Ocz+UR4GuXkcp7jR0XwJ4bik4RD24mT56MoqIizJ07F/n5+Rg0aBCWLl0qNRkfPXoUetlCDGVlZZgxYwby8/ORkpKCoUOH4qeffkLfvn0j9RGIKExi5sFmj/6y1L2Lt2Dp9nysuG8MclNjpccr65w4UlyD/p2SwjqffIaUOGuqMfzr3DC4oegT8eAGAGbNmoVZs2ZpPrdq1SrF9y+88AJeeOGFVhgVEbUUscG1PWRufjteDofbgwNF1Yrg5sqX1+JgsQ3v3joc5/VKD/l88lKU3dn44NDfUNzoUxC1WafdbCkiOv2JN+XqRmRuVu4uxFlPLMcPe1tvAcCSajv2FVQ16rWVtU4Ayn4XADjo29H7403ay1gEI58h1ZRF/Ji5oWjG4IaIWl1Tem5W7y1CUZW9VYObW97+BRe++CMKKuvCep0gCKiq835GZ5ASUrhN1YqyVIjBTazZoBgTwIZiim4MboioVXln+/gX8RMbW0Ml9pnUNWFfpXAdLrbB7RFwvKwmrNfVOt1w+T5fsOCmsi684EZRlgrxGsiDGzGYYkMxRTMGN0TUqtRNsLVh9o2I2YpaR+NLMuHweARU+zJMVWEGIvLjg2VZwj2nfIZUqGUp+RYLFb4yGde5oWjG4IaIWpX6hhzuKsVikFDXhGbacNgcLvgqOGGXkMR+GyD4zKZqu1Pz8WAcbv/n1gqY6pxuXPKPHzHn422a7y0FNyxLURRjcENErUodlNjCXKW4tYMbeUATbiAmLzk5g2RZqps5c3OgqBo7Tlbii99Oar63GNywLEXRjMENEbUq9cJzYWdufFmIcMtZjSUPPsItIVXW+bMy6tlS0vnD/PwN9dzU+oJFb8bJ+57yzE2lKnPDXcEpGrWJdW6IqP1QZxvC3V9K6rlppeBGnn0JNxBR9NzIAgwx6ACCBz3B2FWzpcQG7WsX/oRhXVJxfp8M33t4r22s2aB4j8DMTVhvT3Ra4I81URsgCELI03pPN+rZUOpsgy3M6eD+slTrXC95QBNuCUnecyOfLeVq4JrUR36sR/Cea39hNbafqMSnW06g1qEso6l7fcprxIZirnND0YvBDVEbMOWNn3H+s6tarY+ktfx73WEMfPxb/HasXHqsqQ3Fdncr99w0U+ZGHtyoA9lSmyPkc6qvn93l8e+ybncrMmHVdldAZogNxdQeMLghirCqOid+PliKE+W12F9YHenhNKsf9xWjqs6FTUfLpMfUPTc1Ya5S7J8K3jrBTZWsbybs2VKy19a3+F5JdejBjfq1DpdHCngcbo8iW2SzuwOOZ0MxtQcMbogi7GCRTfo62n6JFksiblkZRr34XrhlKWcrL+KnKEuFnbnRbihWl4pKmpS5UQYwxbJAyZu5CRLc+IbDhmKKRgxuiCLsQJE/W9NafSStRbzpym/sAZmbxjYUt1rmpik9N9oNxYFlKXvI51T359idHkXAU1ztP5fN7gqaueFsKYpmDG6IIkyeuWnKLs9tkXjTdXuCT19u7N5Kdpcn7K0bGqPZMjcuDz7bcgJ3/XeTFGCImlSWcnsUjxVVyYIbR2BDcSVnS1E7wKngRBF2sFiWuWnF/ZJag3jTlc8OCpgK3sh1bgDv9Yo1t+w/Y/IAJfx1bpQNxf/84SB2nKxE/05JiuOa1FDs9KjKUv7gpqqunswNZ0tRFGPMThRhBwr9mZvW2i+ptThcgT03AbOlGlmWAlqnjKdYoTjM/iB5YORwe6S1ecTp2KJwght1sGJ3uVVlKf+5bBo9N+WcLUXtAIMboghyewQcKvEHN9E2FVwsQSl7bpSfsaaR69wArbOQn7rnRr4AX0MUPTcuQeo3ks+iAsJtKFZ+ZofLA4fsMUVZStZzk2j1ZrjKa5yoc7o5W4qiGoMbogg6WV6rzEREaVlK2XPj/dpk8N5Uq8OYCi4IgqIs1RpNxfLMjcsjhLwTN6CeLeVfj0Zd3gqrLOVUZ248ymZl2dfVdrf0fUaiFQkWb4BzvKwGbs6WoijG4IYogvYXKde1ibrZUm6NnhtftiUl1gwgvJ4bdXNsa2S61IFIqH03LrdHUXJzuj3+zI2qobisJoyylFujLBXk50aeuTEb9MhNjQUAHC2tYeaGohqDG6IIOlxsU3wfzs36WGkNLn95DT7bcqK5hxXUq6v2Y+ILq3GyvDak48Wbrssd2HOTGucNbsLpuVH3m7RGcKOe/h3qisrqmVXezI2yLBVnNni/VwU79Wkoc6MYg8O/QrHJqEdnMbgpqWFDMUU1BjdEEaS+cYZzs35m2R5sPV6Bez7Y0syj0rZk43E8vXQP9hZU48d9RSG9xq6VufHd4KXMTRg9N+rgpjV6btRBSqjTweX9NoA3KycGIWIwk5ZgAeDtgwm1lydgnRuXJ+C6iOSZG4tBj84dvMHNkdIaNhRTVGNwQxRB6pks4QQ3Lk/rlbAKK+vwfx9vk74PpXwm3wxUa50bKXPj67nZebIyIJOlps5QtHTPjccjSMFMSqwJQOhlKXXTsDzjI04RT4/3BjcujxDyYoaBZSlP0D4g+Wwpk1EnlaWOKcpSIb0t0WmFP9ZEEWQPCG5CD1iSYszNPZyg9hdVK26qodyI5TOkXBorFHeI946/qs6Jwso6XPyPHzH22VX1njOgLNUCO6mX2Rx4/Iud+Gl/MaplWaWspBgAYWRuVMFNlTy48WVukmNNUmN1eYilKfH6WYzef74d9QQ38nVuzAZZWUqWuWFDMUUjBjdEESTeeMT7SziZm9Q4k/R1S2cw1EFFKKUkeflEqyyVmxIrfb9mf7H0vLueVYcDMl0t8Lm/2nYKb609hBv/tR5/+3InAG9gkOYLxh5c8huueHlNg703YllKbGmRz5wSr4HZqJeC1IqaEIMb32sTrCbf9+6AUpVIvkKxSR3csKGYohiDG6IIEm/W4hTdcHpIzAaD9HVhVR0AYH9hFZZuP9WMI/RSBze2EKZvy1+j2DjT9xkTY4xSwLDjZGXA81rUGYpwe248HgHbT1QEBEly8qDlw1+PAwDirUbE+/6Mymqc+O14BTYfLa/3vYp8KwVnJVoBaGflzAY9kmK851VvyRCMet0a9QrFys/i31TTbNQjJzkGep13LAWV3p8ZBjcUjRjcEEWQdKOK8f4WHk5ZSn6DLqi0o9TmwITnf8Af/rMJ+wqqmnWc8hITANQ6G87cyMtY8rGKAYrFaEC2r9Sz7USF7NzBA5amzpb67LcTuPSlNXjp+/1Bj9Eq8cRb/MGN6HhZDQAEbQQu9AUPnXwZKi3ezI33z76iNrTp4GKWJsH3OvXeUnLyXcHNBj3MRr10zQ8Xe8fPshRFIwY3RBEkBg2JshJD6K/139AKq+rw5De7ZN+Hvst0KBxu5bhCydzIpywrt1/wvtZi1KNjsjersfV4ufR8fQFLU2dLiZuUHlCtL6T1Ht3S4qTHYkwGxAUEN7X486fbcN4zKwP6awBImZFOKTFB38tk0CPZN2ss1MyNXSNzE6znxuHyr7Vj9vXoiKUpMfhk5oaiEYMbogjyZ268N6pwMhHyG9r3uwulEgoQOKOmqRrTcyMfg1bPjcWkR8dk741fnrGqN7hRz5YKM7gRm4Hrm/EkBl/n98mQHttTUIUEqzK4OVZWg//8fBTHSmuxcndhwHnyK70BZqfUUDM34ZWlxPHYXe6APx+ryf9Pe7lvgUCTb1qUeM1FzNxQNGJwQxRB4s1azNyEc7OWZ26+/E3ZZxNsxdrGCgxuwuu5kU9b98/2MaBjUmBWo77NQwM2jQzzc4r9NPUtmie+R6zZgG7p3uxNjMkQEBBtOFQqfa0OfAB5WSp45kYe3Kg30wzGn7kxSeNVB32JVpOUqSnznVf8Xj1WZm4oGjG4IYogh2rmS2N7brSW5G9ODl/5TFxRN5RVhRWzpdyBZSmrLHMjF07PjdYsMbdHgCtI5kosp1VplJGk95D1qPznthEY1ycD/5w6FBaT8p/LUxV1QccF+MtSufX03FgM4WdupJ4bKXPjCfjzjpP1CJXZlJmbOItBcSzXuaFoFPjrBhG1GjFAaUxZSuuGmmA1oqrOFdbmjuG8V3KsGTZHbUj7QcnHoJwtJcvc+Hpu5JpSlhIEAVe9uhY2uwvL7j0PRtWdO6SylDg+X/D11i1nAQD6ZCXiRFktLuibGbAqtHocdU63lDFpqOdG7OUJJbjxeASpT0s+FVz9sxBjMsDtEVBqc0ibcoqZG3XvEMtSFI0YsxNFkENVYggvc6OcpaPXAYM7pwDQnvHTFOI4xSxD+GWpYA3F4WVuGpoKbnd5sPV4BQ4U2aSp2HJir1C9wY0scyOXnmDByzcOweUDOyp6WgBvKe1IiQ0r93h7b4p8Dd0Wox7pvi0WtJiNeiTH+jM3y3cW4FhpTdDj5cGdmLlxaGy/EGv2N0CLm3KafYsFxplZlqLox8wNUQRJPTfSVPDGNRQDQM+MBGmLAHsz77kkzpZKiRODmxAaioP13MimgqfHW2Ay6BSBWjizpdTHyr+vrHUhO0n5+mpfWarW6YbT7ZFKNXL+zI0h4DkA0Ol06JQSi/2F/hlXtU43Lv3HGlTZXXj31uGI8ZXvMhOtmu8hkvfc/LivGD/uK8awLilYcuc5msfLe4z8M+wCZ0vFmA3SwpBScBMkc8O9pSgaMXNDFEHqmS/hBDfqhegGdEqSluRvybIUEGrPjSy40dgV3GLSQ6/XITNRWZqqdbhxtKRGc+dxcRzilgWBwY3/PbWmZ8sX6AuWvXEEydzIqUtNtQ6XtL3Cx5uOS/02mYkWGPS6oNkReXAjOlpP5sbuCzJ1On/vjNbGmfLMjXhNxCArXtVzw13BKRoxuCGKIPVsKVc9zbBq2sGN/4bXnMTMSnKMf4ZOQ+PUWqHY5fZIX4uBmLo0VVrjwIUv/oBznvw+oGG4odlltYrMTUPBjXaPi5j1UjcQywUEN7L33VNQjQLfNHAxcAsWKJkN/rKUqKzGEXRhQPm+UuKftXZZKnDRwaCZGwY3FIUY3BBFkBigyH97D3UzSPUNbVheqixz07xlKbuUufGPs6aBLJPWOjfyoMvqK/uoZxMdLamRenqW7ciHw+WRdrB2qnp/1D1K8mBIq0G3utkyN8oxy3uQ9hZUyTI33uBGzDSpmY16qSQpcroFxSabcvKSnvzPWnxcDFRizQZp13WRf7YUG4op+rHnhiiC1GUpwHuDVv/WrUUMjP58yRnomZmAM7ITpWxDS61zE28xwajXweURUGN3SxkULfK+H7HnRl5GEoOHO8d2R0qsCScravH1tnypGRcA3lxzCM9+uwepcWZ8dte5UuAhbj2gzuzUuYJnblxuZW+KVtnKO+76e24AYFiXFMX38jVq3B4Bvx0rB+AtSwH+rIma2RBYlgK807e1rq18nyjxz7rO6V/nJiXWhOJqh6IsJRKDITYUU3vAzA21K2v2FWPqWxvqnZHSmsRyj9mol24+ofbdiGvP9M5KwJhe6QDQYmUpKZth1EvNsrYGmorlmRu3W5m5MRv0Uq9Hj4x4/PnSvlI2RD7LaduJChwvq8XW4xWwOdwBs7YCem5kwU6lKjOj3jJC3LU76GetJ3MzLC8VvzwyAf93cR8AQLFqZtZ63wJ//sxNkOBGVl6SK7Fp7zNVJ5tpJr5OHqSJPVExZiM6BM3cqNa5YeaGohCDG2pXFv96DD/sLcLyXQWRHgoA2W/iBn/QEGpJyeE7Tn7jFAOkYBspNpb4XmajXvrNX2sBPeVrZBtn+spKYjBi0chkiGWq4iD7YpXXOKTgKGhwU0/mRh2MBeu5kWdH6pOeYEGs71qUVGsHI93T4wHUH9xoKQsS3Ig9Q/EWo5TZkWeNUn3BjbcspZyCbpYailVlKd4FKArxx5raFbFUEs56Mi1Jmv1j1MPq+0081LGJWR+t4Ka5e27E97IY9Ij1/eZva2AhP61F/MTelFhLYLYixhfciJmbeIsR42X7O5XXOGUNxb4Ay+lWNN/Kt25Q99yoxxus50a+Dk9DxDGX2AIDsvsu6IV+Od656MF6boIFPcEyN+JniLMYNctZ4po6STGmwJ4b3+eJNbPnhqIfgxtqV8Q+lWCZDbvLrVhNtyUJgqAogVhN4ZWlxM8ivwmLfSItNRXcZNQh1pdhamghP8U6N76xiq9R930AQIzv84uB1KgeaXjzlrPQK9Ob/aiodQaUpTyC8rMq1rlRZWaqQwxuHK7A6xqMeC3EzE12khUPTOqNJX8YiT+O7ykdZ9YoPXkf977Hxf2zAAA5vpljwTI34jo98RYj4q2Bs6Fmnt8dt43qiov7ZQcEN2LmxmzUK0pu7LmhaNSo4MblcmH58uV4/fXXUVVVBQA4efIkqqurG3glUWSJN05xUTq5OqcbY59ZhetfX9eqYwHE4MZ7Awx180z/mi9amZvA4Mbh8mDB8r3Y4mt2DYe/fGaQfvPfeaoSi9YeCpolUqxz4wsYxdKQVubGqmrgFW/eyTHem3R5jVO23o4/ayEvj9WqFvGTU/fcBJ0KLpuR1BCrL7gRP19SjAl3nd8Dw/JSFceZg82W8v3ZvTB5EFbePxYX9fMGOaXBghvfmOMtRhj0OkUjusWgx5kdk/DopX2RFBuYuTEb/WOQ990wc0PRKOzZUkeOHMGFF16Io0ePwm6344ILLkBCQgKeeuop2O12LFy4sCXGSdQsxEyJ1myiUxV1OFVRh4LKOgiCAF0L/6MvX6fGbPQHN6GWpcTPIi95iJkAsfwmCAL2FlSjc2osfj5YggXL92HDoVK8N+PsBs9f53Rj1nubMf6MDP+WBEa9tHnmM8v2AAA6xFtw2cCOQccH+G/+Nb4AQ10aASD1HInEG3eSbHsCMbiJMRsRYzKg1ulGtd2FFN+NXJ25qXG44HQLSIoxBWRugs2WCrXnBvCXpUTqGUqiYOUnMRi1GA3omhYnfY5gwY24eKIYnCTFmKQMlHq8Kar1c8wG/1jjLEZp7ytmbigahZ25ueeeezBs2DCUlZUhJsa/kNVVV12FFStWNOvgiJqbVJbSWIBO3FLAIwTu29QS5GUbb3AT5mwpjZuwerbUpqPlmLTgB8z5eKvUg6K+yQez4VAplu8qwL9+PCitL2M26hGruoHny3bHlpMHkG5V5ibO3HDmJsEiZm58jbO1DunPzWLQS5kdeXlJfu3Ka5y45B9rMO7ZVahzukPquXF7BCkQC6fnRhSr8bmA0BuKOzQQ3Ihjjrd4r4m870Y9XqNqgUCTLHMjbyrmbCmKRmFnbn788Uf89NNPMJuVKc+8vDycOHGi2QZG1BLq67mRlzfsLndIv7k3x1j0Ou9vz/7MTXg9N+Z6ylKHim0AvEv6i+WjUGdSlfuCoRqHW8pimQw6xKpu6OLeRWqKqeAeAYIgSLuJqwMkIDBQkMpSYuZGVpYyG/VIsBhRVGVXBGvyrNepilqI7VMny2sD9sPSCm7UAWdD1MFMsPWJTEHOpQ56pMxNkGvqny3lz9zUN97UOLM0m0r+cyLPMHG2FEWjsH+sPR4P3Br9CsePH0dCQkKzDIqopThdvp4bjRu8vEG2NWZT2VWZF/9sqYaDG7dHkG7cysyNcrZUre+GXuf0L2AXanBTIQtu5E226tJLWU2w8o7yc7g8gr+sopHhUJel1NmJclVwI46j2u5/f3nPjbwvvMTmkJpxxXKNVs+NvH8olMyNOtukVW4DlD038iAj3MyNGMiJgZ98oT+tHiH5WjfyQEoelLEsRdEo7OBm4sSJWLBggfS9TqdDdXU15s2bh4svvrg5x0bU7MRsh12zLKXM3LTWWMSbjnhzlwdWb/xwELMXb5G2HxDJAxRFQ7E4W8qpnJ1kd7mlx0KdSSWuE1MrC268DcXKm2h5kCyD+n3cHkHKjmkFAVajduYmybd2S3mtw9/7Y9BLWZJgZSm54iq7lPXISvKW09WL/AH+66rXecs6DVEHZOoF8kTyICaxnmxLQz031bKp4EBomRuRPFhjWYqiXdjBzXPPPYe1a9eib9++qKurw4033iiVpJ566qmWGCNRs3HUV5Zyapc3Wnos4k1H3XMjCAKe+HoXPt58AhuPlmm+Fqh/tpQY3HgzN+6A19ZHzNw43B4pI2I26gOCm6BlKdU19mZufGUpzcyN8p+jgJ6bGqfU+2My+ntu5GWpYDPNim0O6bjsJO+qwdqZm9CbibU+R7DMjfzPKCnGf4x6FWQx01JV59L8GZUv4gf4m62DjVmcaaYeg7IsxeCGok/YPTedOnXCb7/9hg8++ABbt25FdXU1brvtNtx0002KBmOitqi+npvWztyop3KLZQVxlV35Hkvq3gynIrjx35zUZSmxz8Tu8kgBm3o3cfG4GJNBMUOsQlZuEmcWeYMb5T8b5RplKa2dql1ujzRbSmtWUdCp4LLZUmKzr9mgl4IfeaNwsD21SqrlmRur7zMFZm7CmQYOBGabtMptgPLPz7tFgrcXSh3cJFpNMOh1cHsElNc4kOHbvkFUrQ5u6mkoBqBYC0fe9yPvb2LmhqJRozbONBqN+N3vftfcYyFqcdI6Nw00FLdG5sbpVmYJpHVufKvsHivz738lX4UXUG7bIA9I1Iv4SWUppztoQ/HRkhpMXLAalw7oiGevGyg9Ll/hV3x7k0EXUHpRZ25eW3UALyzfG37mRh3cSJkb/zo34rUyyzM3dQ1nbkqqHdJ7d/QFNw6XB5e/vAb3T+yN83x7c4UzDRzwZj0sRr10vbUapQF15sYbkBj1uoCsiV6vkza/LLEFD27E4LC+Eheg3JBVHkjJy2nM3FA0Cju4effdd+t9furUqY0eDFFLE8sa2lPBQ8vcLFi+F7FmA35/XvcmjUW+iSQgK0v53vuobHNP9dR0p8YaN4BybylB8Pe42F3BG4q3nahAndODFbsKFOv7lNcGlpu8G2cGNhTLX7d2f7Fm8Oj2CPWvUBxk5pGYuSmvdUiBjsUo67mRl6WCrJpcYrNLi/jJA4atxyvw4a/HpOAmnK0XRLFmg3Rtg2Vu5A3FYnATLIBKiTWjuNqhuUpxdV2YmRtZsCX/WZFnydhQTNEo7ODmnnvuUXzvdDpRU1MDs9mM2NhYBjfUpkmL+GkEL4rgJkjmpszmwILl+wAANwzvrJitEi713lAxqqngR0tqZcd6VK/VzjDIb3B2l0f6TA63/2uXR4DHI0i/sYuZl7IaJ4qq7NLNv0Jj12yLwRCw2q7D5e3JEctV6h2y5WO2SVPBNda5UZV4xGsr9pXUOT2o0vnLY1qZm7ogQWlxtUNqyk60GjGgUxK2Hq8IGG+4mRvA++dWBqfvcwWZLWUMzNzUF9wA2rPQ1D03ifLMjEYpTf7zKc/wsSxF0S7shuKysjLFf9XV1dizZw9GjRqF999/vyXGSNRs6l/nRta7EeQmKS/BHCqyNWks6hupWZZ1AZRlKXWmya7q1xHJe0Ucbo9iJ2x5A638fPLZTrvyq6Sv1btqi2OUl6vEbID8Rhxspk9DmRu9Xqe44YvlrwTfVgOAf4Veec9NtUbmRr06b3G1fz2cWLMRH94xEgt/NwSAMogLt+cG8G/B4P1cDffcSMFNkNlYYgZLXWLzyKfSa82W0jhfcqx28C3u4wVwnRuKTs3yY92zZ088+eSTAVkdorZEvjZMY9e5kd/YDxaHtpfa9hMVWLu/OGA6t3oRPnVwoyhLudSZG0HxGpHJoIP4i7jd6VGUaeR7LdU53fjw12M4UFStCEx2n6qUvlbvqi2+3/gzMhFvMWJcnwxfc6x/o0dBEILOnmqo5wbwZxRiTAZpKrZOpwvYAdscZLaUGJxk+rJP4uvkPTdxFiOsJgM6pcQCAEptTc/ciEKbLWUKeExOa6XqWocb1bJAVdqaQl6WMgWeb2zvDJyVl4Lfnd1Z9R7M3FB0a7aY3Wg04uTJk4167SuvvIK8vDxYrVaMGDECGzZsCOl1H3zwAXQ6Ha688spGvS+1L/LSjmZw42y450Y+w+ZgCJkbQRBw4xs/46Z/rcf451djx8mKgDFImRvfzU7Mqhyvp+fGoerXEel0Oukxu8utCNjkwcqSjcfx4JKtGP/cakUwstuXuXG5PQHbNIgrKafFW7DhkfH419RhUoZEnDFVWecKunWFy+3vAQq2B5MYKKh3vE7WCG7E7I98nRvx/GJwM6RzsvTZxTGKJR1xTZkym1Nq2JYyNyGscSOSB2rBVigW/4x1On9gEqyvR71SdUFlHc56Yjluecv776LB18QMNJy5MRv1+OgP5+BvV/ZXPB7DRfwoyoXdc/P5558rvhcEAadOncLLL7+Mc889N+wBLF68GLNnz8bChQsxYsQILFiwAJMmTcKePXuQkZER9HWHDx/G/fffj9GjR4f9ntQ+yUsxWg3FocyWUmRuQghu7C6PFBAdKrbhPz8fxfyr+yvGIJZ25Jkbu8uNU5X+PZuC9dxo/fYvzt6xuzyK0oZ87JuPlktfy6dy7/JlbrSmScuzGWKGQsrc+AKkkiD9NgDg8sh6boJlbsz+UpRcYj2ZG/lUcLHn5rphneBweXDn2B74YV8x3B5BCoLEcleqb+ze8p0b8RajtFu8VhYkGHkWRKuXCPD/GVtkG6QGyw7FqGa8/XK4FNV2Fzb5/sziLUapfyaxgYbiUMbc0hvEEkVC2MGNOkui0+mQnp6OcePG4bnnngt7AM8//zxmzJiB6dOnAwAWLlyIr776Cm+99RYefvhhzde43W7cdNNNeOyxx/Djjz+ivLw87Pel9kde2tFapVe+91CwlW7lAcKBoobLUurZO/K1a4JlbpxuD06W10E++1sdjDmCNBQDvungdS7YnR7FjV/eQyO/ecszNweKquFwebRLUhqBlD9z4z2HVr+NyaCD0y3A5Zb13ATJcIg36IDMTcAO13ok+LZn0Oq5GZSbjEsHeHcqT40zS9c90WpEli+rE2M2SDuLl1Y7vMFNkIxYfeRlKa1eIkC5lpGY3VGv6yPyLwng/SwHCpVBtHIGlHeXdpvDHVZwo552TxRtwg5uPJ7mW//D4XBg48aNmDNnjvSYXq/HhAkTsG7duqCve/zxx5GRkYHbbrsNP/74Y73vYbfbYbf7byiVlZX1HE3RTF4uaXjjTO2fc3mAcLjEpph1pEXdFFqi0d9h0ui5kffbeMeuCm5cyqyPnHwhP/lnkk+ZljfMHi1Rlr/2FVZplpa0ZuOoZ/aUaAQ3sWYjKmqdqHG4pUX41NO+ReLjwco7ADC+TwasJkPAbCmPR5D+3OSBQwdZcDOqZ5piW4XUODNOlNeitMaBzh1i/WWpMDI38ixUsMyNfy0jPUZ274DJw3Ix8cxMzWMtqp4bdRCtXmcoMcYEmyO8jV47JnPBVYpuEe2TLy4uhtvtRmam8i95ZmYm8vPzNV+zZs0avPnmm3jjjTdCeo/58+cjKSlJ+i83N7fJ46bTk1NVllIvjKdsKA7ScyMLbuqcHpysqNU8ThQQ3FT7b/7q6dxmKSjx4HiZMrhRB2MNlaXE8dUE+RzyniIxIBG3JXjs850orgosL6mngAOBZSmtzI04g6hSNltLvbO4SOq5UQU3fbISAXj7Q164YZDimGqHSxHYyM8DAGnxFunr83qmK86bEufN/ogN0Y3K3MiDmyCfS565sZoMeOraARh/hnZwY1WtVK0ObtTXRuy7CWeGV4+MePz9qv54/eahIb+G6HQSUuZm9uzZIZ/w+eefb/RgGlJVVYWbb74Zb7zxBtLS0kJ6zZw5cxTjr6ysZIDTTslLO4LgzVKYjf4bdk0ImRt1ueZgkU2adaNFXZYq0VhTRQxGTLKG4mpVz0uo69x4z+e9yVXbXXB7tJt7qzR6ap67biDu+PdGbDhcikMlgf1EWu+lbijWCm7Em78YGFqM+qCbUgZrKL5tVFekxZtx1eAcae0WsTFXELzN4PKyozxzIx/36F6q4MYXnBVV27H+YIn0OcKaCu57r/o+l1kKbkLfjLPW4YHHI2hkbrT7kcLJ3ADAjSM6N3wQ0WkqpOBm8+bNIZ0s3Ma0tLQ0GAwGFBQUKB4vKChAVlZWwPEHDhzA4cOHcdlll0mPiWUyo9GIPXv2oHt35aqxFosFFosFRAGlHbdHcUOQZ1lC6bkBgINF1dLqtlrE86TFe1edtTm8paIYsyEg+yKOxekO3Jcp1NlSgL+sobXCrUhr08hheal49npvgFOklbnRDG6UmRutBfzEz1dZp9w6QIu4Zox6ccT0BAtuH91N8ZjFqIdRr4PLI6C6zgWP4N93Sj4DaG+Bf+2eHFU5Rtyo8u21h6Vm6mCfNRgxIKvvc0mZmxDKXVYx8+Zy42RFbUBzuzpzI24nId8BnKi9Cym4WblyZYu8udlsxtChQ7FixQqpUdnj8WDFihWYNWtWwPF9+vTBtm3bFI/9+c9/RlVVFV588UVmZKheTpdGgCCLe2scgeulqImllW7pcThYZMMHvxzDzSPzgk6nFW9MafEWVPp2ei6x2dHJHAu7ep0bMXMj2ypBMVZ4y0mfbj6BI74+mfrKUsHWmwGUa94A3tKR2ajHhDMykWg1NjhbSiQ2+papMjcpsSbpMaOvnCVmboLNlAL8JZn6em5EOp0O8VYjymucqLa7IP4RqAOIByb1xj0fbMEt5+QFnEOcDi4PbIDwt1+Q/1+LuFlnx6SGe13ETJDd6cYBjRl56mvz0EV9cE6PtKA9PETtUaM2zmxOs2fPxrRp0zBs2DAMHz4cCxYsgM1mk2ZPTZ06FTk5OZg/fz6sViv69euneH1ycjIABDxOpBYw40gWQHg8guI35IYyN7PO74G/fL4Du/OrsGTjMUw+SzvFL2aDrCYD0uLMOFlRh5JqBzqlxErBlrhbs3xfKPU6O2KWZ+n2fDz0P3+AX19ZSmv5flGVXfmc2Dtj0OswsnsHLNvhzaaKmREgyGwpX3AgLoQnBjcDOiVj9d4i3znEzI33PYPNKAKAYXkp+GzLCQzpkhz0GLk4sz+4EZur1TOBLhvQEb2zEtAzIyHg9eJ0cLVwMjdiMFLf5xrSORmLf382emYGjkFNvkLx/kJvSSot3iJlxdQZouykGFw/jL/YEck1Krj59ddf8eGHH+Lo0aNwOJS/HX788cdhnWvy5MkoKirC3LlzkZ+fj0GDBmHp0qVSk/HRo0eh5/rg1AyCzTgCAht/tTInBr1OCm66dIjF3eN74m9f7cJz3+7FtUNzNbM34nljTAZ0iLd4gxtfICCuqSIGDSZZ5iZYA/GpijrF4/VlbsrDyNyIjbUAMKpHmhTcZCZacaK8Nuh7dU+PBwAcK61FSbVdapj+3dldoNMBA3KS8NOBEsV7BptRBABThnfGVYNzgk6TVhP7bq58Za30mPq1er1OakhWS41venAjBiP1fS6dTocR3TqEdD4xOK1zeqR+m7G907Fk43EAyp2+iUhb2FHDBx98gHPOOQe7du3CJ598AqfTiR07duD7779HUlJSowYxa9YsHDlyBHa7HevXr8eIESOk51atWoVFixYFfe2iRYvw6aefNup9qX0J7LnxBzQ1qsZfeebG6fZgwvOrcfnLa1Dhy4YkxZhw88gu0OuAwip70MXr6nznjTEb0MF3Iy2u8gYAYuZGPVvK6RYCgiux50bdKxN0nRvUX5ZSn0fcbRsAzu3hb9ZXrICr8V6pcWb0yfJmI9YfKpUCt6xEKxZNH47ZE3tLQZ8YGNaX4QCCr/+iRat8Fc4aLsEyN+E0FIvn6NBMPS/y7RfEafojuqZK17++3h4i8go7uPn73/+OF154AV988QXMZjNefPFF7N69G9dffz06d2b3PbVd6uBGHkCoZzXJnztZXoujpTXYcbJS6kVJjDHBYjQgPcHbtJNfqcyoSOeVZ27ivMcWS5mbIHtLuT1ScCXevMVj1RkXrenZUs+NLXhZSj2JSr5IXte0OOlrkyygCdaHcrYvI7HuQIlUlpJnRPwNxQ333IRLPasK8AcHoUgJEpCEk7k5v08G5lzUBw9e2Cfk19RHDM5qnW7pmqXGmZGb4u3XYXBD1LCwg5sDBw7gkksuAeBtCLbZbNDpdPjTn/6Ef/7zn80+QKLm4tBqKPapcSqDBrti5lRgc7E4m0fcw6igUjtzo+i58d3wxdJNsF3BAaDaLq7k673RidOcK1UZl3rLUrXBMzdqKbIMhk6nw1PX9Mfwrqm45Zwu0uPBbvhnd0sFAHy3s0DKMMmzGGLmRmwobs6bs9a5wsn8BJthFO5WBneM6Y5eIfTThHo+wLvxqbgkQLzFiDM7ejPjYpBDRMGFHdykpKSgqso7tTInJwfbt28HAJSXl6Ompqa+lxJFVH09NzZ78MxNtar5Vr4/kBjcBMvciBmYGLNeKkuJJSyHeiq4LFARy0Zi5sYpZW4aLkuZpdlSwTM3aimq7Q0mn9UZH94xErmyNXyC7WI9oqs3cyNeg1izQRFgGFXBTbDViRvjcHHgbKLmCG7CXTOmOck3zhS3loizGPH4FWfivRkjAhYiJKJAYf8NPu+88/Ddd98BAK677jrcc889mDFjBqZMmYLx48c3+wCJmks4ZSl5z416wTt5H0pmorfUVNhAWcpq9JelStSr4RoDgxvxphbvyxCJGRH1FG3tzI335lhfQ7FacpDeE3kgEmzV3hRZ3w0ADOik7L2TpoKL69w0Y3AjX31Yer8wdrmW7zYuzzaFk7lpbmJZrVYW3CRYjUiONeOc7mn1bvdBRF5h/w1++eWXccMNNwAAHnnkEcyePRsFBQW45ppr8Oabbzb7AImaS32ZG3GNG3E6sbwUJd+YEVAGN+ImjPkVQTI3Wg3FvrKUfxE/73vq9TrpxiwFN76ylJjlCamhWNaYHCr5bCm5mCAr/ardM74nhnZJwaOX9sXbtwxXPCdOBa+WdgRvvrLUY5efiasG52Dl/WOlx9T7ctXHaNCjR0Y8YkwGTJBthxDJ4EbecyM2uoey7g8R+YX9NyY1NVX6Wq/XB925m6itcahX+XUHTgVPjvVusihfZ8ZWT3CTIfbcaKzoKz+vt+fGl7kRy1Kq7RcAbwDhcrilbFFgWUrdUBx8heJQGPQ6uD1C0C0k5IFIfcHNRf2zcVH/7KDvoTxn82Vu8tLi8MLkQYrH9hU2vFu73JI/jES13YXvdvpXSg9ntlRzE2e7ybc+YxMxUXjC/vVkwoQJWLRoEXfXptOOM8iqv4B/KrjYeyLP3KjLUokamZuCIJmbWt95vOvciAveOeDxCJqbX4pf+3tuxLJUsIZirdlSyhtzfcHEgsmD8NpNQzCsS4rm84qyVCOzGUbVGLVmODUHMfNyxaCOYb0uOdaMTimx0p8lEOmeG+V7mwy6iGaSiE5HYf+NOfPMMzFnzhxkZWXhuuuuw2effQanM/TGRaJIqb8sJQY33gDE7nJLu4bXV5aSZktVBQluZGUpsXnV5RHw1692otzXYGtWZW68Y/W+t7hgm9PlDYbU6/GY6ilLiVKC9NMA3t2hL+qfHXRfuNgQem4aou6BaakSywuTB+Lpawbg8csbt1p5RhsJbswGPeSXLM5iDHvfPqL2Luy/wS+++CJOnDiBTz/9FHFxcZg6dSoyMzPx+9//HqtXr26JMRI1i4CGYnlZytdzIwYgHsEfYKh36NbquSmvcWpu2SCWt2JMBliMBlw6wFu6eXvtYWl/KHnQoA4g5OvcaO3krVmWUgc3QfppgIZnFpkMeik71NjgxqDX/kzNLcFqwvVn5SIpNvjnrY+4/xPQ+M/aHHQ6neLPhf02ROFr1N9gvV6PiRMnYtGiRSgoKMDrr7+ODRs2YNy4cc09PqJmE9Bzo5G5kc8aEgMTdeamY7L/JpgYY5SCiUKNtW7EzI1YanhpymA8dU1/xTH1LZQnlnCcbk/ANHBAO8PQQbWlQH2Zm1AWvBMbXBtdllJlbtpq/0i6bOaVzREYSLYmBjdETdOkX0/y8/OxcOFCPPXUU9i6dSvOOuus5hoXUbMLpSwlX6lX7Lup8gU3f5rQCwsmD8JNI/wL2+l0Ouk3fq21buQNxeLxVw3upLhhmTV6bkTyhuJQMzfn9khTfI76gptQGmfFvptm67lpozdr+efr4dszK1KssrG01etF1JaF/a9VZWUl3n77bVxwwQXIzc3Fa6+9hssvvxz79u3Dzz//3BJjJGoWwRqK1x0owao9hQC8a7CI2RMxcyPOluqYbMWVg3MCMg+ZCeIqxcGDG/WU6jG90xXfa30NyIMbIaCZGAi+zs3VgztJ3wdbqA4ILXMjzpgKtohfQ1qr56Y5/PLIBKy4b4yi/yYSrLJep7aa6SJqy8L+1yozMxOPPPII+vXrh3Xr1mHPnj2YO3cuunfv3hLjI2o2gYv4uVFSbcdN//oZh0tqEG8xYnTPdCm4ETM3Ys9NsN2YM5OCBzfydW7kLpCtqaLouQkS3Dhc/rJUomwcWg3FAHDD8Fzp6/qmhoeUuWliWSqg56YN72qdnmCRdjqPJKvsz6UtXy+itirsvzWff/45xo8fD70+cg13RI2h1XNzsrwOHsE7BXz57DHoEG+B1WRAZZ0roOdGnJatluHbPLNQY60brcwNAJzfO0P6ur5VgBU9N77MTde0OPx2vAIAYAgyi6ZXZgLG98nATwdKcHa3Dnh99UEA3mnFYqO0yaALWINGizhjqrHTkdXT1dty5qatkGfUEni9iMIW9t+aCy64oCXGQdQkvxwuRcfkGOQkB99U0Cnbhdvh9sDh9qDUt0VBZqIVHXwNpWKmQ+q5ERfUC/IbtLg2jny7g41HyuBye6RzqGclJcWa8I8pg1FYWSdNJwcCMzHynhtxAb/OHfzBjXrfK7mFNw+F2yPgeFmt9Fii1SRt/2ANcaG6i/tno6jajqFB1sJpiDyAMuq5ZksoYliWImoS/q2h097GI6W4buE6JFiM2PbYJADeYOBoaQ26pcVJa4SIwU2cxQBHjQcOl0cKSOR9KeJNPzBzo/3XRZwaXuErG7ncHlzz2k+KY7SmXF8+MHCxOXXmJk7WcyMu7Cff5FJfz/on3mncyoxLgtUoBTehrmR866iuuHVU15CO1SLvueGaLaFRlKUY3BCFjb9C0Wnvk80nAPhnNQHA37/ehfHPrcYP+4qlx/zBjb+PpdR3o5fPKBJv+nanB4IgNBjcJKqCmzpV4zIQ+k7Y6q0YxD4Xh9sjbTyZaDXh0Uv74pIB2RjXJ0PzPHKKacWy7FNrbTFgNHDmT7g4FZyoafi3hk57e/MD9xLa79tfaF9BFcb08s5Mcri8vSbizcLu9qBMDG5kC93JMzd1Tg/cHt/rgpSl/Jkbb/ChtZifNcRSjLw/xSJbQM/p9kjBU4LViNtGdcVtCC2bYlH0b8g+Zxh7UDWFPHPDG3VoggWkRBQaZm7otLe3sCrgMXHdmvIaf0+KmLmRz0Aq8z2fqpG5qXN6pKyNTgfEBlnNVwxuxNlM6uDGbNArshf1kc9Ispj0UplKEIAyXwlNvrdVKOTZoMSY1s/cGBRlqchtSHk6kQee7LkhCl/Ywc3dd9+Nf/zjHwGPv/zyy7j33nubY0xEIXN7BEUAIxLXpqmoDQxuFGUpX8AgX5lYzNzUOd3+kpTZCH2QmUXqnhv5pptAeBkSRXBjNCjWlimp9gU31vCCG7NBD7HNJcEagcyNvCwV5tjbK3nmhrOliMIX9r9u//vf/3DuuecGPH7OOedgyZIlzTIoolAdLrFJX8szBOLy+drBjffG4XD5y1KKhmKTWJbySGvc1FcaEIObarvLN0NKmbkJtd8GAMwG/7EWo14R3Ij9QfLsSyh0Ov8MJXlZqNV6bhRlKWZuQsHMDVHThP23pqSkBElJSQGPJyYmori4WOMVRC1nx8lK6WuP4F/HpsbuDTDkwY24zk2cb8Vdu8uNWl+WJUUW3PgX8XOjyjfVur5eEXmZSL4+jqihzSnlTEZ/IGA26hU9OMXV3nV0ws3ciGOoc3oUCwC2VubGwJ6bsMWwoZioScL+161Hjx5YunRpwOPffPMNunXr1iyDIgrVjpMV0teCAKn5t1qrLOVSlaXkDcWy6dXiSsTltc6QMjcmgx5xvuxMRa0zoCylXsCvPhaDvCylh06nkwIcu2/84fbciOdSvzacoKsp1FPBqWGcLUXUNGH/rZk9ezZmzZqFoqIiaRfwFStW4LnnnsOCBQuae3xE9dpXoJwp5XR7IAg6KRCo1ChLKRuKA6eCd0qJBQAcL6tFz4x4xWuCSYoxweZw+4IbZebGEkYQoe65AbzBk9PtP2diI2bPiOdKUEwFb/2eG/aPhMbC2VJETRL235pbb70VdrsdTzzxBP76178CAPLy8vDaa69h6tSpzT5AovqIC9KJnG4PHLLYor6G4vIapxQEyctSnVK8qxwfL6uRGpMbCm4SY0w4WVGnmbmpcwRODQ9GaxNNb9+N/xwJjShLpcSacLTUu3eSiJmbtkue7eMMM6LwNepfmjvvvBN33nknioqKEBMTg/j4yG80R+1TRY0yuHG5BdTJel4qap0QBAE6nX9PJfE3YXEvKLOsrAQAuanezM2x0lppYcBQMjfi+6l3Hy9TjbE+JlVZSv2Y1aRv1AaWj13RD5uOlGF41w4B529pip4bZiFCIvZDmQ36Vmv8JoomTfqXJj09vbnGQdQo8swMADg9Htjs/uDG5RFgc7gRbzHCIZWllDeLlDiTYksAMXNTXG1HcZU3MGnopiwPbtQzxrWmqgejXucGAMyypuLGNBMDwKDcZAzKTVbsjN5amRt5UzT7R0IjLkfAYJCocUL6mzNkyBCsWLECKSkpGDx4cL17w2zatKnZBkdUH49HCAxu3AJqHC7FYxW1TsRbjNKNPTnGrHhe3m8DeAOVeIsR1XaX1LDcUK+IfCE/ddDgcAduxxCMfG8p8WuTYhG+pq0TY9TroNN5m6/D6QVqCoOe2y+ES1w+gCUposYJ6V+aK664AhaLt1Z/5ZVXtuR4iEJWZXfBNzkKJoO37ORy+1cVFlXUOJGTHCOVi7qmxaFjkhUnK+oABAY3Op0OnVJisDu/Cr8cLgUAdM+ov/SqXsivsYI1FIsa00ws5519pYfD5Wm9hmL23ITtzI6JyE2NwUX9siM9FKLTUkj/0sybNw8A4Ha7cf7552PAgAFITk5uyXERNUicCWU16WE1GVBe4/RmbuzKBl4x4BB7bsxGPS7om4l31h0BoFzAT9QpJRa786uk4Gl419R6xyIFNzVOaR+pvtmJcLg9mHtp35A/kzxzI5alFMFNEzM3gHe6ucPliUhDMTM3oUmONeOHB87nDupEjRTWr24GgwETJ05EWVlZS42HKGRiL0tyjBlGX+nD6fZIqxOLxKZisTxkMuhxQd8s6XmtgCE3NUb6ulNKDLKTYgKOkUuK9WduxBlY5/bogOWzx+C8XqH3pikzN4E9N42ZKRXsPVpvKjiDm8ZgYEPUeGH/69avXz8cPHiwJcZCFJbyWnFfKJPUtOpyC4qGYsCb4XF5/KsXmw16jOjmz8QcLrZBTVzrBgCG59WftQGUZSlxnZvGZEaCTwX3ampZSn6+1src6HWcLUVErSvs4OZvf/sb7r//fnz55Zc4deoUKisrFf8RtRax3JQYY5KyA06PR7OhWD5LyGT09p2IQctVg3MCzi3OmAKAsxooSYljEN9LXOemUcGNoYGem2YoS4lBU2ttv+CQTY1n5oaIWkPY/9JcfPHFAIDLL79ckTYV1xJxu0NfsIyoMVxuDwqr7LKylEnad8np8gRkbrxrz/gzN2Kw8M6tw/HzoRKc1zOwbJQry9ycFW7mxrfOTmPKPiaNspRitlSzlqVaJ3NTK1uxubVKYUTUvoUd3KxcubIlxkEUskc/2473NxzDhDMyAPjKUr6eG++6NsrMzSur9mPh6gPS92KDa4zZgPN7Z2i+R7f0OHROjUVKnBnd0+MaHJN8KrhYlmrMVGvFVHCNnptwdwTXkpFgwf7CamQmWho+uBlkJFilr9lHQkStIex/Kbt27Yrc3NyAf6QEQcCxY8eabWBEwYg7gf+w17sLfZK8LOX2SFsmJFqNqKxzQRAAl2/HcO86Lw3fYK0mA1bdPxYeX0ayIWJwU2V3oca33YK1EVkKS4NTwZueuXnmuoHYfaoS/XOSmnyuUPTtmIinrxmgKPUREbWkRgU3p06dQkaG8jfe0tJSdO3alWUpanGlvv2kxNlPybFmKQDwLuLn/RnsmByDyvwqxWvljcUN0et10CO0TEOSrBemyLetQ1MbirW2X0hohobcnOQY5CS3bqBx/Vm5rfp+RNS+hf2rpRDkN9nq6mpYrVaNVxA1rzLVZplJMfLZUv5F/LKTWu/n0WTQI9a3qmxBpXdxwMYENyaNslRzNxQTEUW7kH8NnD17NgBvzfzRRx9FbKy/4dLtdmP9+vUYNGhQsw+QSK7O6YZNtct2UozJv86Nx7/9gnwH7Lenn4Vl2/NxRnZii40tKcaEGocbZTX+xQXDpbnOjbHpe0sREbUnIQc3mzdvBuDN3Gzbtg1ms39VV7PZjIEDB+L+++9v/hFSVKmqc2LuZztw6YBsjD8jM+zXa21CmRxrkmYUudz+2VIDOiXjw1+PAwDO65ketHm4uSTFmHDKt6UD0AxlKZPWVHBOpSYiakjI/1KKs6SmT5+OF198EYmJLfcbMEWvd9cdwSebT+CTzSdw+MlLwn59qaokBXhXKDbpAxuKu6XFYem9o5EcY4ZBvVV3C1CXjKyNmGqtuXFmMzcUExFFu7B/DXz77bcBAPv378eBAwdw3nnnISYmJmgvDpGcfIG9xvzMlNUEBjfK2VL+huJYixF9slovCE9SBzeNKUvVs7eU2ahvtVWFiYhOZ2H/61taWorx48ejV69euPjii3Hq1CkAwG233Yb77ruv2QdI0SUz0d/kW+ibVRQOrcxNUqxJCgBcsr2l4i2tGwgEBjfhv79er5PW4VHvLcWsDRFRaMIObu69916YTCYcPXpU0VQ8efJkLF26tFkHR9HHI5uKfbAocE+nhqgzNzodkGAxKqaCi2WpWHPr9qeogxtLI7c3UG9sKX625thXioioPQj7X8tvv/0Wy5YtQ6dOnRSP9+zZE0eOHGm2gVF0ssv2GTpUbMPI7h3Cer2YuYk1G1DjcCMpxqTIdtQ43HC6vQFUXCvvY9QcmRsAuKhfNnbnV6JzqndlZLFZOoHTwImIQhL2v/42m02RsRGVlpbCYmmd5dzp9KUMbqrDfr24xs1ZealYvbcIWb4yl9GX3RA30wQgrTvTWgIyN43cR+m56wcqvmfmhogoPGH/6zt69Gi8++670vc6nQ4ejwdPP/00zj///GYdHEUfu8u/Rs2h4vDLUqW+qeBjeqXjhckD8fz1gwD4+1LKa73Bj9moV8wyag3y4EanUzYHN4UYwHVODfylgoiIAoX9q+DTTz+N8ePH49dff4XD4cCDDz6IHTt2oLS0FGvXrm2JMVIUsTv9mZuDjQhuxMxNapwZVw7OkR6XMje+4Ce+lUtSgDK4sRoNzTZ7cNKZmXj31uEYmJvcLOcjIop2Yf9q2a9fP+zduxejRo3CFVdcAZvNhquvvhqbN29G9+7dW2KMFEXkZamjJTVwuT31HB2oxBfcpMSZFY+LU8Er67zBTUwEpkzL17lpzDTwYIwGPc7rlR5Q9iIiIm2N+vU2KSkJjzzySHOPhdoBeVnK5RFwvKwWeWlxIb9eytzEKoMbsQRUVeedKRXTyv02gCpzw/VoiIgiplHBTV1dHbZu3YrCwkJ4PMrfvC+//PJmGRhFJ3nmBgAOl9hCDm4EQUBpjZi5UWYxxL2lxOCmOTMnoWJwQ0TUNoQd3CxduhRTp05FcXFxwHM6nQ5ut1vjVURe8p4bILyF/Gocbjh8wVFqGyxLyYObxs6UIiKipgv7X+A//vGPuO6663Dq1Cl4PB7FfwxsqCHyshQAFIUR3Ihr3FiM+oDgRSxLVdvFzE3rBzdm2biYuSEiipywg5uCggLMnj0bmZnh7+gczCuvvIK8vDxYrVaMGDECGzZsCHrsxx9/jGHDhiE5ORlxcXEYNGgQ/v3vfzfbWKhliWWp3NQYAEBBZV19hyuIqxOnxpkDZiKJmRvBtwBypIILMXsTibIYERF5hf0v8LXXXotVq1Y12wAWL16M2bNnY968edi0aRMGDhyISZMmobCwUPP41NRUPPLII1i3bh22bt2K6dOnY/r06Vi2bFmzjYlajhjciGu2FFaGn7lJUTUTA/6p4KJIlKUAeXDDzA0RUaSE3XPz8ssv47rrrsOPP/6I/v37w2RSNnbefffdYZ3v+eefx4wZMzB9+nQAwMKFC/HVV1/hrbfewsMPPxxw/NixYxXf33PPPXjnnXewZs0aTJo0KbwPQ61OLEvlpsQCKEFhlTJzY7O7cKqiDj0y4gNeK8/cqImL+IkilTmRghsjgxsiokgJO7h5//338e2338JqtWLVqlWK8oBOpwsruHE4HNi4cSPmzJkjPabX6zFhwgSsW7euwdcLgoDvv/8ee/bswVNPPRXeB6GIEBuKc8XMjarn5prXfsLu/Cp8dte5AYvWldq8zcJawY04W0oUqcxNIstSREQRF3Zw88gjj+Cxxx7Dww8/DL2+af+AFxcXw+12B/TvZGZmYvfu3UFfV1FRgZycHNjtdhgMBrz66qu44IILNI+12+2w2/030MrKyiaNmZpGLEt1SvH23BRW2SEIAnQ6HQRBwO78KgDA8l0FAcGNfHViNaM6cxOBdW4Af+bGwswNEVHEhB2dOBwOTJ48ucmBTVMkJCRgy5Yt+OWXX/DEE09g9uzZQfuA5s+fj6SkJOm/3Nzc1h0sKYhlqU4p3syNw+VBZa13hlNRtT8IzU3R2Jy1JnjPjXofqUiVhZJjmbkhIoq0sP8FnjZtGhYvXtwsb56WlgaDwYCCggLF4wUFBcjKygr6Or1ejx49emDQoEG47777cO2112L+/Pmax86ZMwcVFRXSf8eOHWuWsVPjiJmbpBijtMu12HezN1+2S7jGtkz+zE3gNgTq4CYSKxQDwEX9stAnKwEX9suOyPsTEVEjylJutxtPP/00li1bhgEDBgQ0FD///PMhn8tsNmPo0KFYsWIFrrzySgCAx+PBihUrMGvWrJDP4/F4FKUnOYvFAovFEvK5qGWJPTcWowEZiVZU1lWjsMqOnpkJ2FtQ5T/OFbjnVGmQfaUAjbJUhBbRG5aXiqX3nheR9yYiIq+wg5tt27Zh8ODBAIDt27crnmvMLsizZ8/GtGnTMGzYMAwfPhwLFiyAzWaTZk9NnToVOTk5UmZm/vz5GDZsGLp37w673Y6vv/4a//73v/Haa6+F/d7UugRBkMpSFqMemYkW7C+sljI3+wr9wY1DI7iRZktplaXUDcURytwQEVHkhR3crFy5slkHMHnyZBQVFWHu3LnIz8/HoEGDsHTpUqnJ+OjRo4r+HpvNhpkzZ+L48eOIiYlBnz598J///AeTJ09u1nFR83N5BHh8i+xZjAZkJFgB+Ne62VvgL0tpBTf1ZW5MAVPBGdwQEbVXjdo4s7nNmjUraBlK3Sj8t7/9DX/7299aYVTU3OSlJotJj4wEb7mwoNI7Y0pZllJu0+DxCCirqWcquLqhmMENEVG7xSkd1GrsTn/AYjboke4Lbgqr6pBfWSft6A0EZm6q6lxw+9I+4owkOXXmJlLr3BARUeQxuKFWI2ZuzAY99HodMhJ9ZakqOw4U2jSPBbxZG3EaeLzFqLmGTMBUcAY3RETtVpsoS1H7IAYsFt9MJnHBu+o6FypqnYpjxczNhkOlmPnfjcj0BUIpGtPAAWZuiIjIj8ENtRppppRvgbs434ymGocLNQ6X4liHy4NNR8twy9sbUONwo7g6+EwpQGP7BTOTkkRE7RXvAFQvm93V8EEhkq9xAwCxZm9sbXO4UeNQNhDbXW688N3egMe1ZkoBgEm1rg23PyAiar8Y3FBQK/cU4sx5y/D66gPNcj6HW1mWirP4Mjd2F2zqzI3bI039NssCF62ZUgBg0qvKUlznhoio3WJwQ0H9/t1fAQDzvwm+iWk4xMyNGKyIAUiN0y1liMReGbvTg1rf7KrzeqZJ5whalmJDMRER+TC4oaCcbqFJr/d4lK/399x4A484X1lKEGQL9PmmeTvcHtT5SlLn9UqXzqE1DRxoO9svEBFR5PEOQA1qzA7X+wqqMPDxb/Hy9/ukx9SzpeQzmoqqvMFNsi8zY3d5UOc7fmiXFOk4sbFYzSzL3JgN+oBMDhERtR+8A5Cm8hp/ENE5NTbs1288UoaqOhd+2FcsPSbfVwoA9HodYn2lqaJq7xYM4lRvu8uDWl/mJtFqQq/MeADAhDMyNd/PKOu5sTQiGCMioujBqeCkSb7Pk0EffrBQ7euhqZatOqyeLQV4Z0zVONworvIGN1LmxulGnWzq+Ed3nIP9RVUY0tmfxZEzyIIbrnFDRNS+8Vdc0iTf56nO6a7nSG3iVgrVsqnkUllKllkRZ0wV+YIbsWG4qs4FwdeyE2MyICnWhKFdUoPuPK/T6aTSFJuJiYjaNwY3pCnU4MbtEfD97gKU2ZS9MGJwY1MEN8qyFODPsojTxMWG4so6/4rFoQYrYlMxMzdERO0bgxvStCffH9zU1hPcLN9VgFsX/Yonvt6leLza7g1Oquz1l6XiLMrKqLhInxgcGfW6gH2jghH7bqxc44aIqF1jcEOaDhT5e27qy9wUVNYBAE6W1yoeF8tRDpdH2idKPVsKgNRQLEpRrWMTTolJXD+H08CJiNo33gVIU3mNvyxU5/RAELTXvBGzMTbVNglVskZisTSl3lsK8K91I0pSrWMTTnAj7i/F1YmJiNo3BjcUwOHywBWwAJ9H81gxq1Oj2oNKHtxUS8GNxmwpizIQUa9AHM4GmGLPjZX7ShERtWsMbihArSOwDBWsNCUGLOoNLuWzpKTgxhlYllJnbgLKUmEEKuJsKWZuiIjaNwY3FKDG6W/mFZt0gzUVi6Um9caX1ZqZm8DZUuqem+Q4ZVkqnEBFytxwthQRUbvG4IYCiFmYGJNBmlZd5wxWlvJlbuzqnht/z05AWcqkXMRPZDboAzI54WRuxJ6bxmwXQURE0YN3AQoglqVizAYpEAlelvI+7nD7Z0W5PYKiwVjM4mjNloqzKPtvDLJsERDetG4T17khIiIwuCENYuYm1myQGnqDl6X8GR0xKFKXqAJmSynKUv5MjZi1McueD2dat4krFBMRERjckAYxkIkxG6WyULDMjfxxMaiRz5QCtBqK5Yv4yUtU3q/lwU1jem6YuSEiat+4cSYFqPUFKbFmAxwub8DQ0GwpAKhxBG6WCfiDHa29peSZm1jfasVa2zOEQsrccLYUEVG7xuCGAsjLUgadGNxoNxTbZY/bfE3F4tYL/sd9+0z5gp9gs6ViTYGZm3BKTOkJFgBAVqI15NcQEVH0YXBDAeSzpURaa98AQJ0rtLKUze7C4WIbAKB7erz0nDy4EUtU8rJVOMHNIxefgYv7ZeP8Phkhv4aIiKIPgxsKUCvL3IjkQYycPHMjTgfXCm62naiARwCyk6zIlGVW5BtniiUqs0GeuQm9LaxDvAUT+maGfDwREUUnBjdR4K01h2Ay6nHz2V2a5Xw1sqng4i4MQctSGpmbantgcLPlWDkAYFBusuI5rcyNuZE9N0RERABnS532KmqcePzLnXj00+0BQUV9jpbU4O73N2P7iYqA56TZUiajbBG/UBqKfT03vsyNmHWprnNh89EyAIHBjXzRPjFzY2nkbCkiIiKAwc1pz+H2BxdlNkfIr/t0ywl8/ttJvLvucMBz8tlSYoASfCq4vKFY7LnxNhRnJ8UAUGZuBndOUbxeHrzEaUwF5yaYREQULgY3pzmXxx9clIYR3FTUegOQwip7wHPyspTY0BusoVhRlhJ7bnxBjjhraX9hNQoq7TDodeifk6R4vcWoh8G3InGMlLmRNRQzc0NERGFicHOac7kF6etwghsxy1KkFdw4/Q3FYnATtKG4nnVuspO8wY3L17jTOzMhoMyk0+mkvhv/bKnGrVBMREQEMLg57cnLUiVhBDdV9QQ38tlS1no2zvR4BGk/KSBwKnhmknK9meFdUzXHIvbdsOeGiIiaA4Ob05w8c1NSHRioBCNmbkpsDng8guI5MQMTYzYixhR8byl5YAX4p4KLjc3ZquBmVI80zbHE+jI2mj03nC1FRERhYnBzmnO6G9dzIwY3bo+Ashrl66TMjcmfubFrBDd2VTZHytz4zp2pWil4RDftzE1mgve4jETvCsOcCk5ERE3BdW5Oc87GlqVkC+0VVzvQId4ife/fOFPWUKwR3Kj7cMRGZHG2VFKMSXouLd6CBKsJWv5+dX9sPV6OIb6ZVBZmboiIqAkY3JzmXJ5GNhQ7/MFNUZUdvbMSpO+1Zktp9dwEZG7sLlTbXThSUgMA6JwaKz03KFc5S0qua1ocuqbFSd8ry1JMLhIRUXh45zjNOWUNveH03Mh37i6qrlM8p2wo1isek7NrZG42HimD2yMgNzUGHZNjkGj1xs9ThncOeWzyqeAsSxERUbiYuTnNOWWZm3DKUuKaNABQXKV8nbQruHyFYo2p4Opsjs3hwvqDJQCAEV07AAA+vetcHCiyYfwZoe/5xIZiIiJqCgY3pzl55ibUspTd5VbMdCqSZXw8HkGz50ZdghLPI1djd2P9oVIAwAjftO9u6fHoJtsFPBTKjTMZ3BARUXhYljrNyVcornG4g26TICfP2gDAibJa/OfnIyisqlNkaGLNBmmdGa2GYnEBv3jfzt4lNge2Hi8HAJzdrUN4H0TG4iuFmQ3+1YuJiIhCxeDmNOdwK9eoUZemqu0ufLzpuLTdAuCfBi76atsp/PnT7Xj8i52K3poYk0Ha20kraBIzNylx/llQTreA7CQrOqXENPIT+TM3bCYmIqLG4N3jNOdSLaSnbir+789HMPvD3/Dmjwelx+TTwOW+3HpK6rexGPXQ63X+hmKnG4KgDKTEnpvUWLPi8dE906DTNT7jYvGVorg6MRERNQaDm9OcUx3cqDI34saY8g0y5dPA5QblJkvlJ3G/J3HjSkEIXJFYzNwkxijXr/nd2V3C+gxq/swNgxsiIgofg5vTnFNVliqtVgY3YjlJ3jMjTgPPUq0gXOtw+2dK+fZ5ssqmZatnR4lNxvKp28mxJgzolBz255ATe244DZyIiBqDwc1pTp25Uc+YEgOSGlkvjbj3U26qsi+mvNYh21fKG1iYDDqpqVfddyN+b5H1xtw5pnvjPojMsC4pGN41FTeOCH1tHCIiIhGngp/mXKrMzb9/PoLxZ2RI06/FAEQemIgNxYlWE16YPBC/HavAop8Oo7zGqVjADwB0Oh2sRj1sGjOxxNlSVqMBb04bhp0nK3H76G5N/kwJVhM+vGNkk89DRETtEzM3pzmxD2Z0zzTkpsbgaGkNpr29AW7f4n5iQKKVuYm3GnHV4E64b2IvAN5gRcz8yEtCwfaXEoMbi0mP8Wdk4o/je3LqNhERRRyDm9OcmLnJTY3Fx3eeCwA4VlqLct9O3+K6NbUawU2cb32aeItRCkryK7xbMcSaA4Mbdc+NVJYy8seIiIjaDpalThOCIEjTqwVBwDPL9iDWbJB6bswGPdITLIi3GFFtd6GyzoUO8RYpINFqKE7wBTc6nQ7JMSaU2Bw4KQU3/h8NcTp4sLKUvKGYiIgo0vgr92ng899OYvBfv8O6A959m3acrMSrqw7g2W/3SgGH0Zd5SfJNy670LdonZmzkmRtxKriYuQGApFjv646W2gD4Vx0GEHSVYnEqOBfbIyKitoR3pdPAqj2FKK9xYp1vU8rNx8ql58QSk8lXGkrw7cJdWecNbsSylDgLyuHyoNq3/YI8uEn2BUW7TlUBALKT/dPExengdl9wk19Rh9vf+QXf7SwAwMwNERG1LSxLnQbE2U21vgBl58kK6TkpuPFlbhKlzI33cXEtmjqnB9/vLsCti36VXpsgD258qwyLDcUdk/3TxNWZmy9+O4nluwql59lzQ0REbQnvSqcBcaNLccbT5qPl0nNScONb1TfR6gtufJkbMSBxuD144qtdivNqZW5EnWTBjcWobCg+XGJTHMuVhImIqC1pE8HNK6+8gry8PFitVowYMQIbNmwIeuwbb7yB0aNHIyUlBSkpKZgwYUK9x0eDKjFz43Sj2u7C3oIq6Tkxq2MUg5sYX1nK13MjbwLOVK1IHG/1BzfqLRTkmRtpfylfcHWkpEZxLDM3RETUlkT8rrR48WLMnj0b8+bNw6ZNmzBw4EBMmjQJhYWFmsevWrUKU6ZMwcqVK7Fu3Trk5uZi4sSJOHHiRCuPvPX4y1Ju/HasHB7Zun3iJpgmg68sJcvcCIKgCG7cHuWCf/EW5bYJcllJ/kBIXPNG7N9RZ24sbCgmIqI2JOJ3peeffx4zZszA9OnT0bdvXyxcuBCxsbF46623NI//73//i5kzZ2LQoEHo06cP/vWvf8Hj8WDFihWtPPLWIwY3NQ43Nh0pUz7nUJWlZD03TregCISKqpQ7hsdb/AGNvCyVFm9RlJrk69w4XB6cLK9VnIcNxURE1JZENLhxOBzYuHEjJkyYID2m1+sxYcIErFu3LqRz1NTUwOl0IjU1taWGGXHVsrLU8TJlYFFdp+658ZaaKmqdAVO3C1XBjXyhPrGhGABykpXlK7GhuM7pxvGyGqgSQJwKTkREbUpEZ0sVFxfD7XYjMzNT8XhmZiZ2794d0jkeeughdOzYUREgydntdtjt/pt6ZWVl4wccAYIgKMpS1b5Mjaha6rlRzZaqc0pTt9XHAkDn1FhFD06SrCwl77cBAKvRv4if2G9jMuikHcmZuSEiorbktP6V+8knn8QHH3yATz75BFarVfOY+fPnIykpSfovNze3lUfZNLVOt5QpqXW6UWNXBjdigGH2ZW7ki/ipt0sQfTLzHCyfPQZmWSOwvCyVowpuLOLeUg631G8zsnua9HyNKuAiIiKKpIgGN2lpaTAYDCgoKFA8XlBQgKysrHpf++yzz+LJJ5/Et99+iwEDBgQ9bs6cOaioqJD+O3bsWLOMvbXIsy21Drc0LVzNGNBQ7AooS4kSY0yKwAZQlqXUmRt/Q7FHytyckZ2Ac7p3QKLViMG5KeF8JCIiohYV0bKU2WzG0KFDsWLFClx55ZUAIDUHz5o1K+jrnn76aTzxxBNYtmwZhg0bVu97WCwWWCyW5hx2q5IHMzUOlyLYkTNpTAVX7wUlSrAG/rHLMzcBZSmTv+fmiC9zk9chDg9N6gO7yyP15BAREbUFEV+hePbs2Zg2bRqGDRuG4cOHY8GCBbDZbJg+fToAYOrUqcjJycH8+fMBAE899RTmzp2L9957D3l5ecjPzwcAxMfHIz4+PmKfo6XY5Jkbp1sqASXHmlBe45Se05oKHiy4EY9RPFZPWSrG7O+5OeFraO6SGgu9XsfAhoiI2pyIBzeTJ09GUVER5s6di/z8fAwaNAhLly6VmoyPHj0Kvd5fQnnttdfgcDhw7bXXKs4zb948/OUvf2nNobcKeaamzumR1rVJjTWrghvlVPA6pweVdYFZHqNep7nonkGvw9AuKThWWoPuGXGK56xGf+ZGnHElXweHiIioLYl4cAMAs2bNClqGWrVqleL7w4cPt/yA2pBqVYBSVuPd+yk1zoyDxf7F9Iy+ADDBYoROBwgCUFhVF3C+BKsROp1O870W//5suDxCwHYK4vfVdrcUbKlXNCYiImorTuvZUu2BTTUTSZw5lRpnVjxuNnoDFr1eh3jfnlGFlcp1bQAgQaMkJTIa9Jr7RImPlVT7z6fVt0NERNQWMLhp44I1EHeIVwY3RlnpTuyp0crcxFvCD0rERfqKfcGNxajn2jZERNRmMbhp42wawY1BrwvIwIg9N4B/rZsCzcxN+MGN2DQsZo1YkiIioraMwU0bp+65AYA4s0FaNVgkzpYC/NPBg/XchMuqytKwJEVERG0Zg5s2rlpj0b54i1FaNVgkz9xIZSlf5kbeP1xfz00w6uneWlPJiYiI2goGN22cVlkqzmIMmM5tVGRuxJ4bb3CTJCsjMXNDRETRjsFNG6feKBMAYjWCG7NG5kaUIttaoTENxRbVrt/suSEioraMwU0bp5W5ibcYAmYrGWXBTXqCcruJlFh55ib8wMRi1CtKW4nM3BARURvG4KaNExuKDXp/dBFnNgZkU+QNxZ1SlNsnpMb5g53GlJR0Op2iNMWeGyIiassY3LRx4jo38kX74jXKUvKG4hxVcKPM3DQu6yJvKmbPDRERtWUMbtqIHScrcLysJuBxcYXi9Hh/9iVWoywlD246JaszN/7AqLGBiXzqOXtuiIioLWNw0waU2hy48pW1uPGN9QHP2XxTweV9NOrZUjqdsmyVFm+BWfZ8iiK4aVxgIt+WgZkbIiJqyxjctAEny2vhdAs4WlqDOqdyXRuxLCUPbuJVPTfyrA3g3V8qR5a9SW3ibClAGdyw54aIiNoyBjdtQGWtU/q6qMq/ZYLD5YHD5QGglbnxBxsmfeAu3/Km4uRm6LmxyoKpxmZ/iIiIWgODmzagQhbcFMqCG/k08LR4eXBjUJSlTMbAP0Z55iYlzoy0eAsSLEbFecIhbygWt3cgIiJqi3iXagMq6+SZG/9+UPmV3q8TrEZFxkWduZHvCC6SZ25iTAZ8etc5cLkFRXkpHPKp4MzcEBFRW8bgpg2oCFKW2n6iAgDQNzsRsbLMSZxF2XNjNgSWpeTTwa0mAzqlxDZpjFZOBSciotMEy1JtQGWtv/wkL0vtOFkJAOiXk4QYWcZFvc6N0aCVufEHM+qNLxtDzNzodN6GZiIioraKwU0boOi5qQzM3PTLSVQEKLFm5To3Jo3MTXaSVfrarBH8hEtsKI63GKHXaGAmIiJqK/greBsg77kp9PXcuD0Cdp7yZW46JklTwgFvgCFfx0Y9FRwAspNiEG8xwmTQKVYobiwxc8Rp4ERE1NYxuGkDFFPBq72Zm8MlNtQ43LCa9OiWHo/9hdXSMXEWIwx6HUwGHZxuQTO4Meh1+OWRCXALgmbZKlxiIzL7bYiIqK3jnaoN0CpLyZuJDXqdoqFYXIjPajTA6XbBqFGWApqn10Z9Lm69QEREbR17btqAyjp/yam42g63R1A0EwPetWosRj1Sff8HIM2Y0srcNDfxPROZuSEiojaOd6o2QJ658QhAic2OXb5+mz5ZiQC82ZoP7xiJGLMBOp03UyM2FWs1FDe3YXmpSLAYcV6v9BZ/LyIioqZgcNOCCqvqsP5gKS7sl1VvdkXsudHpAEHwrnWzr8DbY9M7K146bmBusuJ1YjalNTI3g3KT8du8iZwpRUREbR7LUi3oya9344/vb8bynQVBj6lzumH37R8lbplwoMgmrU7cIyMh6GvFGVNaKxS3BAY2RER0OmBw04LEAOVkRV3QY8Rp4Dod0C3dm6X5aX8xACAr0Yqkehp4Lb4ZTGYjgw4iIiIRg5sWJG58Kd8AU01cnTjRakLnVG/mZumOfABAr6zgWRvAX5ZqrcwNERHR6YB3xRZkc7i9/68nuBGbiRNjjBjfJxMAUF7jfaxXRnzQ1wGt23NDRER0uuBdsQXV+IKaKlVw89GvxzDqqe+x8UipVJZKijHhnB4dkGDx93j3ymwoc9N6s6WIiIhOFwxuWlB1kLLU/zYdx/GyWjz0v20oqXYA8JalLEYDxp+RIR3XM7OBzE0rrnNDRER0uuBdsYUIgoAaX1mquk4Z3BwosgEA9hdW4/XVBwBAahy+qH+2dFzPBjM3vp4bZm6IiIgkXOemhTjcHrg8AgAoNr2srHOiqMq/8/c+355R4oaUY3qlY3TPNHRKiZW2WQhGLEs1x67fRERE0YLBTQux2d3S1/Lg5qAva5OeYEFWohXbfHtIJfl27raaDPj3bSNCeo+0eDMA79YMRERE5MVf+VuIvM9G/vUBX6amR3o8HrviTOnxxuzZdNuornjqmv64aUTnJoyUiIgoujC4aSFivw0AVMuyOAeKvMFN94w4DOmcgt+d7Q1MzvRtkBmO5FgzJp/VGQlW7tRNREQkYlmqhchLUdV2/8aYUnDjW434r1f0w13n90BWorV1B0hERBSlmLlpITUOf3BT5/TA5fbuHyX23IjBjU6nQ3ZSjLTTNxERETUNg5sWIm8oFr93uT04XOILbhpYfZiIiIgah2WpFqJeuK/a4UJZjQNOtwCrSY9slqGIiIhaBIObFiIvSwHeYEdc3yY3JRZ6PctQRERELYHBTQuxOZRlqao6F06W1wIAspKYtSEiaimCIMDlcsHtdjd8MLUpJpMJBoOhyedhcNNC1GUpm92FUxV1AICOSTGRGBIRUdRzOBw4deoUampqIj0UagSdTodOnTohPr5pfakMblqIuqG42u7CqQpv5iY7mZkbIqLm5vF4cOjQIRgMBnTs2BFms5kzUU8jgiCgqKgIx48fR8+ePZuUwWFw00LUPTfVdhdOljNzQ0TUUhwOBzweD3JzcxEbGxvp4VAjpKen4/Dhw3A6nU0KbjgVvIVUq2dL1TFzQ0TUGvR63tpOV82VaWPmppntLajC19tOobzGuyqxUa+DyyN4e258mZtsNhQTERG1GAY3zez+j37D1uMV0vcZCRacrKhDfmUdqnzZnGyWpYiIiFoMc3fN6GhJjSKwAYB032J9+3y7gSdajYizMKYkIiJqKQxumtHX208FPJaZYAEA7PcFNx2TmbUhIqK2z+l0NnxQG8Xgphl9tVUjuPFlbkptDgDstyEiIm1Lly7FqFGjkJycjA4dOuDSSy/FgQMHpOePHz+OKVOmIDU1FXFxcRg2bBjWr18vPf/FF1/grLPOgtVqRVpaGq666irpOZ1Oh08//VTxfsnJyVi0aBEA4PDhw9DpdFi8eDHGjBkDq9WK//73vygpKcGUKVOQk5OD2NhY9O/fH++//77iPB6PB08//TR69OgBi8WCzp0744knngAAjBs3DrNmzVIcX1RUBLPZjBUrVjTHZdPE+kgzOVpSg20nKqDTAYLgfzwz0aI4Lov9NkRErUYQBNQ6I7NScYzJENbsH5vNhtmzZ2PAgAGorq7G3LlzcdVVV2HLli2oqanBmDFjkJOTg88//xxZWVnYtGkTPB4PAOCrr77CVVddhUceeQTvvvsuHA4Hvv7667DH/PDDD+O5557D4MGDYbVaUVdXh6FDh+Khhx5CYmIivvrqK9x8883o3r07hg8fDgCYM2cO3njjDbzwwgsYNWoUTp06hd27dwMAbr/9dsyaNQvPPfccLBbv/fA///kPcnJyMG7cuLDHFyoGN83kYHE1UmJN6NsxETtPVqLMN1sqQ7VBZkdmboiIWk2t042+c5dF5L13Pj4JsebQb7PXXHON4vu33noL6enp2LlzJ3766ScUFRXhl19+QWpqKgCgR48e0rFPPPEEbrjhBjz22GPSYwMHDgx7zPfeey+uvvpqxWP333+/9PUf//hHLFu2DB9++CGGDx+OqqoqvPjii3j55Zcxbdo0AED37t0xatQoAMDVV1+NWbNm4bPPPsP1118PAFi0aBFuueWWFl1gkWWpZjK2dwY2PDIBz18/CDkp/uxMpiq4GZqX0tpDIyKi08C+ffswZcoUdOvWDYmJicjLywMAHD16FFu2bMHgwYOlwEZty5YtGD9+fJPHMGzYMMX3brcbf/3rX9G/f3+kpqYiPj4ey5Ytw9GjRwEAu3btgt1uD/reVqsVN998M9566y0AwKZNm7B9+3bccsstTR5rfSKeuXnllVfwzDPPID8/HwMHDsRLL70kpbrUduzYgblz52Ljxo04cuQIXnjhBdx7772tO+B6mAx6ZCZakZ0Ug+0nKgEA3dLipOefuXYAzumeFqnhERG1OzEmA3Y+Pili7x2Oyy67DF26dMEbb7yBjh07wuPxoF+/fnA4HIiJqb+loaHndTodBHnPBLQbhuPi4hTfP/PMM3jxxRexYMEC9O/fH3Fxcbj33nvhcDhCel/AW5oaNGgQjh8/jrfffhvjxo1Dly5dGnxdU0Q0c7N48WLMnj0b8+bNw6ZNmzBw4EBMmjQJhYWFmsfX1NSgW7duePLJJ5GVldXKow2dvGk4NzUW780YgRX3jcF1w3IjOCoiovZHp9Mh1myMyH/hlF1KSkqwZ88e/PnPf8b48eNxxhlnoKysTHp+wIAB2LJlC0pLSzVfP2DAgHobdNPT03HqlH/Sy759+0LaXHTt2rW44oor8Lvf/Q4DBw5Et27dsHfvXun5nj17IiYmpt737t+/P4YNG4Y33ngD7733Hm699dYG37epIhrcPP/885gxYwamT5+Ovn37YuHChYiNjZXSV2pnnXUWnnnmGdxwww1SY1Jb1DlVuafJOd3T0D29aTucEhFR9EpJSUGHDh3wz3/+E/v378f333+P2bNnS89PmTIFWVlZuPLKK7F27VocPHgQ//vf/7Bu3ToAwLx58/D+++9j3rx52LVrF7Zt24annnpKev24cePw8ssvY/Pmzfj111/xhz/8ASaTqcFx9ezZE9999x1++ukn7Nq1C3fccQcKCgqk561WKx566CE8+OCDePfdd3HgwAH8/PPPePPNNxXnuf322/Hkk09CEATFLK6WErHgxuFwYOPGjZgwYYJ/MHo9JkyYIP1hNQe73Y7KykrFfy3thuGd0Tc7ETNGd23x9yIiotOfXq/HBx98gI0bN6Jfv37405/+hGeeeUZ63mw249tvv0VGRgYuvvhi9O/fH08++aS0ueTYsWPx0Ucf4fPPP8egQYMwbtw4bNiwQXr9c889h9zcXIwePRo33ngj7r///pA2F/3zn/+MIUOGYNKkSRg7dqwUYMk9+uijuO+++zB37lycccYZmDx5ckAFZsqUKTAajZgyZQqs1pafWKMT1EW4VnLy5Enk5OTgp59+wsiRI6XHH3zwQaxevVoxd19LXl4e7r333gZ7bv7yl78ousdFFRUVSExMbNTYiYio7amrq8OhQ4fQtWvXVrmBUugOHz6M7t2745dffsGQIUOCHlffn2FlZSWSkpJCun9H/WypOXPmoKKiQvrv2LFjkR4SERFRu+B0OpGfn48///nPOPvss+sNbJpTxGZLpaWlwWAwKGp3AFBQUNCszcIWi6VN9+cQERFFq7Vr1+L8889Hr169sGTJklZ734hlbsxmM4YOHarosPZ4PFixYoWiTEVERESnp7Fjx0IQBOzZswf9+/dvtfeN6Do3s2fPxrRp0zBs2DAMHz4cCxYsgM1mw/Tp0wEAU6dORU5ODubPnw/A24S8c+dO6esTJ05gy5YtiI+PV6zUSERERO1XRIObyZMno6ioCHPnzkV+fj4GDRqEpUuXIjMzE4B3VUa93p9cOnnyJAYPHix9/+yzz+LZZ5/FmDFjsGrVqtYePhEREbVBEZstFSnhdFsTEdHpQ5xpk5eXF9LKudT21NbW4vDhw5wtRUREBEBalC6UlXepbRK3dRDX72msiO8tRURE1BwMBgOSk5OlBeRiY2NbdOdpal4ejwdFRUWIjY2F0di08ITBDRERRQ1xKZFgexRS26bX69G5c+cmB6UMboiIKGrodDpkZ2cjIyNDc9dratvMZrNiIlFjMbghIqKoYzAYmty3QacvNhQTERFRVGFwQ0RERFGFwQ0RERFFlXbXcyOuWVhZWRnhkRAREVGoxPt2KGsPt7vgpqqqCgCQm5sb4ZEQERFRuKqqqpCUlFTvMe1u+wWPx4OTJ08iISGh2RZ3qqysRG5uLo4dO8YtHULA6xU6Xqvw8HqFjtcqdLxW4Wmp6yUIAqqqqtCxY8cGp4u3u8yNXq9Hp06dWuTciYmJ/MEPA69X6HitwsPrFTpeq9DxWoWnJa5XQxkbERuKiYiIKKowuCEiIqKowuCmGVgsFsybNw8WiyXSQzkt8HqFjtcqPLxeoeO1Ch2vVXjawvVqdw3FREREFN2YuSEiIqKowuCGiIiIogqDGyIiIooqDG6IiIgoqjC4aQavvPIK8vLyYLVaMWLECGzYsCHSQ4q4v/zlL9DpdIr/+vTpIz1fV1eHu+66Cx06dEB8fDyuueYaFBQURHDEreeHH37AZZddho4dO0Kn0+HTTz9VPC8IAubOnYvs7GzExMRgwoQJ2Ldvn+KY0tJS3HTTTUhMTERycjJuu+02VFdXt+KnaD0NXa9bbrkl4GftwgsvVBzTXq7X/PnzcdZZZyEhIQEZGRm48sorsWfPHsUxofzdO3r0KC655BLExsYiIyMDDzzwAFwuV2t+lBYXyrUaO3ZswM/WH/7wB8Ux7eFaAcBrr72GAQMGSAvzjRw5Et988430fFv7uWJw00SLFy/G7NmzMW/ePGzatAkDBw7EpEmTUFhYGOmhRdyZZ56JU6dOSf+tWbNGeu5Pf/oTvvjiC3z00UdYvXo1Tp48iauvvjqCo209NpsNAwcOxCuvvKL5/NNPP41//OMfWLhwIdavX4+4uDhMmjQJdXV10jE33XQTduzYge+++w5ffvklfvjhB/z+979vrY/Qqhq6XgBw4YUXKn7W3n//fcXz7eV6rV69GnfddRd+/vlnfPfdd3A6nZg4cSJsNpt0TEN/99xuNy655BI4HA789NNPeOedd7Bo0SLMnTs3Eh+pxYRyrQBgxowZip+tp59+WnquvVwrAOjUqROefPJJbNy4Eb/++ivGjRuHK664Ajt27ADQBn+uBGqS4cOHC3fddZf0vdvtFjp27CjMnz8/gqOKvHnz5gkDBw7UfK68vFwwmUzCRx99JD22a9cuAYCwbt26Vhph2wBA+OSTT6TvPR6PkJWVJTzzzDPSY+Xl5YLFYhHef/99QRAEYefOnQIA4ZdffpGO+eabbwSdTiecOHGi1cYeCerrJQiCMG3aNOGKK64I+pr2fL0KCwsFAMLq1asFQQjt797XX38t6PV6IT8/XzrmtddeExITEwW73d66H6AVqa+VIAjCmDFjhHvuuSfoa9rrtRKlpKQI//rXv9rkzxUzN03gcDiwceNGTJgwQXpMr9djwoQJWLduXQRH1jbs27cPHTt2RLdu3XDTTTfh6NGjAICNGzfC6XQqrlufPn3QuXPndn/dDh06hPz8fMW1SUpKwogRI6Rrs27dOiQnJ2PYsGHSMRMmTIBer8f69etbfcxtwapVq5CRkYHevXvjzjvvRElJifRce75eFRUVAIDU1FQAof3dW7duHfr374/MzEzpmEmTJqGyslL6LT0aqa+V6L///S/S0tLQr18/zJkzBzU1NdJz7fVaud1ufPDBB7DZbBg5cmSb/LlqdxtnNqfi4mK43W7FHxYAZGZmYvfu3REaVdswYsQILFq0CL1798apU6fw2GOPYfTo0di+fTvy8/NhNpuRnJyseE1mZiby8/MjM+A2Qvz8Wj9T4nP5+fnIyMhQPG80GpGamtour9+FF16Iq6++Gl27dsWBAwfwf//3f7jooouwbt06GAyGdnu9PB4P7r33Xpx77rno168fAIT0dy8/P1/z5098LhppXSsAuPHGG9GlSxd07NgRW7duxUMPPYQ9e/bg448/BtD+rtW2bdswcuRI1NXVIT4+Hp988gn69u2LLVu2tLmfKwY31CIuuugi6esBAwZgxIgR6NKlCz788EPExMREcGQUbW644Qbp6/79+2PAgAHo3r07Vq1ahfHjx0dwZJF11113Yfv27YpeN9IW7FrJ+7L69++P7OxsjB8/HgcOHED37t1be5gR17t3b2zZsgUVFRVYsmQJpk2bhtWrV0d6WJpYlmqCtLQ0GAyGgI7wgoICZGVlRWhUbVNycjJ69eqF/fv3IysrCw6HA+Xl5YpjeN0gff76fqaysrICGtZdLhdKS0vb/fUDgG7duiEtLQ379+8H0D6v16xZs/Dll19i5cqV6NSpk/R4KH/3srKyNH/+xOeiTbBrpWXEiBEAoPjZak/Xymw2o0ePHhg6dCjmz5+PgQMH4sUXX2yTP1cMbprAbDZj6NChWLFihfSYx+PBihUrMHLkyAiOrO2prq7GgQMHkJ2djaFDh8JkMimu2549e3D06NF2f926du2KrKwsxbWprKzE+vXrpWszcuRIlJeXY+PGjdIx33//PTwej/SPb3t2/PhxlJSUIDs7G0D7ul6CIGDWrFn45JNP8P3336Nr166K50P5uzdy5Ehs27ZNERB+9913SExMRN++fVvng7SChq6Vli1btgCA4merPVyrYDweD+x2e9v8uWr2FuV25oMPPhAsFouwaNEiYefOncLvf/97ITk5WdER3h7dd999wqpVq4RDhw4Ja9euFSZMmCCkpaUJhYWFgiAIwh/+8Aehc+fOwvfffy/8+uuvwsiRI4WRI0dGeNSto6qqSti8ebOwefNmAYDw/PPPC5s3bxaOHDkiCIIgPPnkk0JycrLw2WefCVu3bhWuuOIKoWvXrkJtba10jgsvvFAYPHiwsH79emHNmjVCz549hSlTpkTqI7Wo+q5XVVWVcP/99wvr1q0TDh06JCxfvlwYMmSI0LNnT6Gurk46R3u5XnfeeaeQlJQkrFq1Sjh16pT0X01NjXRMQ3/3XC6X0K9fP2HixInCli1bhKVLlwrp6enCnDlzIvGRWkxD12r//v3C448/Lvz666/CoUOHhM8++0zo1q2bcN5550nnaC/XShAE4eGHHxZWr14tHDp0SNi6davw8MMPCzqdTvj2228FQWh7P1cMbprBSy+9JHTu3Fkwm83C8OHDhZ9//jnSQ4q4yZMnC9nZ2YLZbBZycnKEyZMnC/v375eer62tFWbOnCmkpKQIsbGxwlVXXSWcOnUqgiNuPStXrhQABPw3bdo0QRC808EfffRRITMzU7BYLML48eOFPXv2KM5RUlIiTJkyRYiPjxcSExOF6dOnC1VVVRH4NC2vvutVU1MjTJw4UUhPTxdMJpPQpUsXYcaMGQG/XLSX66V1nQAIb7/9tnRMKH/3Dh8+LFx00UVCTEyMkJaWJtx3332C0+ls5U/Tshq6VkePHhXOO+88ITU1VbBYLEKPHj2EBx54QKioqFCcpz1cK0EQhFtvvVXo0qWLYDabhfT0dGH8+PFSYCMIbe/nSicIgtD8+SAiIiKiyGDPDREREUUVBjdEREQUVRjcEBERUVRhcENERERRhcENERERRRUGN0RERBRVGNwQERFRVGFwQ0TtwqpVq6DT6QL2vyGi6MPghoiIiKIKgxsiIiKKKgxuiKhN8Xg8ePrpp9GjRw9YLBZ07twZTzzxBMaNG4dZs2Ypji0qKoLZbJZ2I7bb7XjooYeQm5sLi8WCHj164M033wz6XmvWrMHo0aMRExOD3Nxc3H333bDZbC36+Yio5TG4IaI2Zc6cOXjyySfx6KOPYufOnXjvvfeQmZmJ22+/He+99x7sdrt07H/+8x/k5ORg3LhxAICpU6fi/fffxz/+8Q/s2rULr7/+OuLj4zXf58CBA7jwwgtxzTXXYOvWrVi8eDHWrFkTEEAR0emHG2cSUZtRVVWF9PR0vPzyy7j99tsVz9XV1aFjx45YuHAhrr/+egDAwIEDcfXVV2PevHnYu3cvevfuje+++w4TJkwIOPeqVatw/vnno6ysDMnJybj99tthMBjw+uuvS8esWbMGY8aMgc1mg9VqbdkPS0QthpkbImozdu3aBbvdjvHjxwc8Z7VacfPNN+Ott94CAGzatAnbt2/HLbfcAgDYsmULDAYDxowZE9J7/fbbb1i0aBHi4+Ol/yZNmgSPx4NDhw4122ciotZnjPQAiIhEMTEx9T5/++23Y9CgQTh+/DjefvttjBs3Dl26dAnptWrV1dW44447cPfddwc817lz57DORURtCzM3RNRm9OzZEzExMVKDsFr//v0xbNgwvPHGG3jvvfdw6623Kp7zeDxYvXp1SO81ZMgQ7Ny5Ez169Aj4z2w2N8vnIaLIYHBDRG2G1WrFQw89hAcffBDvvvsuDhw4gJ9//lkx4+n222/Hk08+CUEQcNVVV0mP5+XlYdq0abj11lvx6aef4tChQ1i1ahU+/PBDzfd66KGH8NNPP2HWrFnYsmUL9u3bh88++4wNxURRgMENEbUpjz76KO677z7MnTsXZ5xxBiZPnozCwkLp+SlTpsBoNGLKlCkBTb+vvfYarr32WsycORN9+vTBjBkzgk7tHjBgAFavXo29e/di9OjRGDx4MObOnYuOHTu26OcjopbH2VJEdFo5fPgwunfvjl9++QVDhgyJ9HCIqA1icENEpwWn04mSkhLcf//9OHToENauXRvpIRFRG8WyFBGdFtauXYvs7Gz88ssvWLhwYaSHQ0RtGDM3REREFFWYuSEiIqKowuCGiIiIogqDGyIiIooqDG6IiIgoqjC4ISIioqjC4IaIiIiiCoMbIiIiiioMboiIiCiqMLghIiKiqPL/o6dyL29Fmt8AAAAASUVORK5CYII=",
      "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": null,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10986}, {'accuracy': 0.11684000000000001}, {'accuracy': 0.10218}, {'accuracy': 0.15052000000000001}, {'accuracy': 0.10611999999999999}, {'accuracy': 0.10801000000000001}, {'accuracy': 0.12867}, {'accuracy': 0.14364000000000005}, {'accuracy': 0.1398}, {'accuracy': 0.13574000000000003}, {'accuracy': 0.17198000000000002}, {'accuracy': 0.14792}, {'accuracy': 0.14077}, {'accuracy': 0.15457000000000004}, {'accuracy': 0.1665}, {'accuracy': 0.2116}, {'accuracy': 0.15552}, {'accuracy': 0.20224999999999999}, {'accuracy': 0.21273}, {'accuracy': 0.13841}, {'accuracy': 0.24655999999999997}, {'accuracy': 0.21849}, {'accuracy': 0.21642999999999998}, {'accuracy': 0.17943000000000003}, {'accuracy': 0.16048}, {'accuracy': 0.22462}, {'accuracy': 0.16798}, {'accuracy': 0.20867999999999998}, {'accuracy': 0.20073000000000002}, {'accuracy': 0.24512}, {'accuracy': 0.21989}, {'accuracy': 0.22626}, {'accuracy': 0.19297000000000003}, {'accuracy': 0.21272000000000002}, {'accuracy': 0.26755999999999996}, {'accuracy': 0.28121}, {'accuracy': 0.21793}, {'accuracy': 0.15451}, {'accuracy': 0.19305}, {'accuracy': 0.2097}, {'accuracy': 0.19760000000000003}, {'accuracy': 0.26927999999999996}, {'accuracy': 0.21991}, {'accuracy': 0.22538}, {'accuracy': 0.23484999999999995}, {'accuracy': 0.27646000000000004}, {'accuracy': 0.23260999999999998}, {'accuracy': 0.24142000000000002}, {'accuracy': 0.2522}, {'accuracy': 0.32692}, {'accuracy': 0.31128999999999996}, {'accuracy': 0.28758}, {'accuracy': 0.23719}, {'accuracy': 0.28771}, {'accuracy': 0.30149}, {'accuracy': 0.22113}, {'accuracy': 0.28334000000000004}, {'accuracy': 0.28569999999999995}, {'accuracy': 0.27598}, {'accuracy': 0.30572999999999995}, {'accuracy': 0.33535000000000004}, {'accuracy': 0.31894}, {'accuracy': 0.3527}, {'accuracy': 0.36492}, {'accuracy': 0.25271999999999994}, {'accuracy': 0.31476999999999994}, {'accuracy': 0.36319}, {'accuracy': 0.32842000000000005}, {'accuracy': 0.33501000000000003}, {'accuracy': 0.33082}, {'accuracy': 0.4304200000000001}, {'accuracy': 0.34667}, {'accuracy': 0.33916}, {'accuracy': 0.36951}, {'accuracy': 0.37073999999999996}, {'accuracy': 0.42471}, {'accuracy': 0.35486}, {'accuracy': 0.33648}, {'accuracy': 0.34624}, {'accuracy': 0.38919999999999993}, {'accuracy': 0.37457}, {'accuracy': 0.41022}, {'accuracy': 0.39489}, {'accuracy': 0.39077}, {'accuracy': 0.36827000000000004}, {'accuracy': 0.33335}, {'accuracy': 0.29823999999999995}, {'accuracy': 0.36504}, {'accuracy': 0.34451}, {'accuracy': 0.40508999999999995}, {'accuracy': 0.404}, {'accuracy': 0.37696}, {'accuracy': 0.37571999999999994}, {'accuracy': 0.36811000000000005}, {'accuracy': 0.45892}, {'accuracy': 0.47404999999999997}, {'accuracy': 0.40957999999999994}, {'accuracy': 0.32126}, {'accuracy': 0.39873}, {'accuracy': 0.41651}, {'accuracy': 0.31758}, {'accuracy': 0.35436}, {'accuracy': 0.39287}, {'accuracy': 0.36474}, {'accuracy': 0.45832000000000006}, {'accuracy': 0.43479999999999996}, {'accuracy': 0.44615}, {'accuracy': 0.44996}, {'accuracy': 0.37477}, {'accuracy': 0.36884999999999996}, {'accuracy': 0.42188}, {'accuracy': 0.35123999999999994}, {'accuracy': 0.42393000000000003}, {'accuracy': 0.33602999999999994}, {'accuracy': 0.40523}, {'accuracy': 0.38075000000000003}, {'accuracy': 0.41237}, {'accuracy': 0.39942}, {'accuracy': 0.39662}, {'accuracy': 0.38781999999999994}, {'accuracy': 0.42271000000000003}, {'accuracy': 0.36759}, {'accuracy': 0.45556}, {'accuracy': 0.4583799999999999}, {'accuracy': 0.40747}, {'accuracy': 0.42380000000000007}, {'accuracy': 0.39242}, {'accuracy': 0.38316999999999996}, {'accuracy': 0.38429}, {'accuracy': 0.41231999999999996}, {'accuracy': 0.39242}, {'accuracy': 0.47398000000000007}, {'accuracy': 0.33582000000000006}, {'accuracy': 0.37999000000000005}, {'accuracy': 0.43017000000000005}, {'accuracy': 0.5031800000000001}, {'accuracy': 0.45455999999999996}, {'accuracy': 0.43445}, {'accuracy': 0.45439999999999997}, {'accuracy': 0.39361999999999997}, {'accuracy': 0.43583}, {'accuracy': 0.42961}, {'accuracy': 0.4324}, {'accuracy': 0.3991199999999999}, {'accuracy': 0.40174000000000004}, {'accuracy': 0.48778999999999995}, {'accuracy': 0.4263800000000001}, {'accuracy': 0.38337}, {'accuracy': 0.39065}, {'accuracy': 0.37916}, {'accuracy': 0.44165}, {'accuracy': 0.40484}, {'accuracy': 0.42174000000000006}, {'accuracy': 0.39489}, {'accuracy': 0.40335}, {'accuracy': 0.44966}, {'accuracy': 0.41052}, {'accuracy': 0.4119400000000001}, {'accuracy': 0.38257}, {'accuracy': 0.39571999999999996}, {'accuracy': 0.37324999999999997}, {'accuracy': 0.45331}, {'accuracy': 0.45159000000000005}, {'accuracy': 0.44497}, {'accuracy': 0.48673}, {'accuracy': 0.44353999999999993}, {'accuracy': 0.45228}, {'accuracy': 0.43362000000000006}, {'accuracy': 0.44769000000000003}, {'accuracy': 0.38981999999999994}, {'accuracy': 0.43906}, {'accuracy': 0.42839}, {'accuracy': 0.43012000000000006}, {'accuracy': 0.45274000000000003}, {'accuracy': 0.49112999999999996}, {'accuracy': 0.39477}, {'accuracy': 0.46741}, {'accuracy': 0.40191}, {'accuracy': 0.4898300000000001}, {'accuracy': 0.46163999999999994}, {'accuracy': 0.42735}, {'accuracy': 0.43907000000000007}, {'accuracy': 0.41006}, {'accuracy': 0.34593999999999997}, {'accuracy': 0.38987000000000005}, {'accuracy': 0.40465}, {'accuracy': 0.38705}, {'accuracy': 0.43151}, {'accuracy': 0.50934}, {'accuracy': 0.43159000000000003}, {'accuracy': 0.39612}, {'accuracy': 0.4769399999999999}, {'accuracy': 0.42826}, {'accuracy': 0.48159}, {'accuracy': 0.43618000000000007}, {'accuracy': 0.40774999999999995}, {'accuracy': 0.49959999999999993}, {'accuracy': 0.46471000000000007}, {'accuracy': 0.44725000000000004}, {'accuracy': 0.40057}, {'accuracy': 0.60152}, {'accuracy': 0.6058}, {'accuracy': 0.6124399999999999}, {'accuracy': 0.60029}, {'accuracy': 0.5994300000000001}, {'accuracy': 0.59684}, {'accuracy': 0.59664}, {'accuracy': 0.60469}, {'accuracy': 0.60401}, {'accuracy': 0.5998300000000001}, {'accuracy': 0.6196400000000001}, {'accuracy': 0.60907}, {'accuracy': 0.6072900000000001}, {'accuracy': 0.6081399999999999}, {'accuracy': 0.6069700000000001}, {'accuracy': 0.6064499999999999}, {'accuracy': 0.5946699999999999}, {'accuracy': 0.6055999999999999}, {'accuracy': 0.60896}, {'accuracy': 0.60076}, {'accuracy': 0.61433}, {'accuracy': 0.60068}, {'accuracy': 0.6021799999999999}, {'accuracy': 0.60823}, {'accuracy': 0.60214}, {'accuracy': 0.60654}, {'accuracy': 0.60056}, {'accuracy': 0.60697}, {'accuracy': 0.60305}, {'accuracy': 0.60423}, {'accuracy': 0.60878}, {'accuracy': 0.6079}, {'accuracy': 0.6101599999999999}, {'accuracy': 0.62069}, {'accuracy': 0.60723}, {'accuracy': 0.60605}, {'accuracy': 0.60519}, {'accuracy': 0.60324}, {'accuracy': 0.5994599999999999}, {'accuracy': 0.5983499999999999}, {'accuracy': 0.60617}, {'accuracy': 0.60826}, {'accuracy': 0.6085699999999999}, {'accuracy': 0.60617}, {'accuracy': 0.5985999999999999}, {'accuracy': 0.6014900000000001}, {'accuracy': 0.5994999999999999}, {'accuracy': 0.6081300000000001}, {'accuracy': 0.61039}, {'accuracy': 0.59766}, {'accuracy': 0.6168799999999999}, {'accuracy': 0.60443}, {'accuracy': 0.6138300000000001}, {'accuracy': 0.61137}, {'accuracy': 0.6041900000000001}, {'accuracy': 0.6027600000000001}, {'accuracy': 0.6056499999999999}, {'accuracy': 0.6043}, {'accuracy': 0.60653}, {'accuracy': 0.6107499999999999}, {'accuracy': 0.60632}, {'accuracy': 0.60244}, {'accuracy': 0.60729}, {'accuracy': 0.6109}, {'accuracy': 0.60233}, {'accuracy': 0.60989}, {'accuracy': 0.61529}, {'accuracy': 0.6040900000000001}, {'accuracy': 0.6016199999999999}, {'accuracy': 0.60305}, {'accuracy': 0.6078899999999999}, {'accuracy': 0.60739}, {'accuracy': 0.6102900000000001}, {'accuracy': 0.60247}, {'accuracy': 0.6017499999999999}, {'accuracy': 0.6038500000000001}, {'accuracy': 0.60719}, {'accuracy': 0.60615}, {'accuracy': 0.60045}, {'accuracy': 0.6022799999999999}, {'accuracy': 0.6038300000000001}, {'accuracy': 0.61182}, {'accuracy': 0.60361}, {'accuracy': 0.60944}, {'accuracy': 0.6167100000000001}, {'accuracy': 0.6021}, {'accuracy': 0.6127100000000001}, {'accuracy': 0.60722}, {'accuracy': 0.61073}, {'accuracy': 0.60185}, {'accuracy': 0.59676}, {'accuracy': 0.60472}, {'accuracy': 0.61687}, {'accuracy': 0.5987500000000001}, {'accuracy': 0.60702}, {'accuracy': 0.61159}, {'accuracy': 0.60248}, {'accuracy': 0.60676}, {'accuracy': 0.6063599999999999}, {'accuracy': 0.61127}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1e2c586-04af-4b7e-a788-fe249ae77fe1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "741f6832-6cce-4bb8-8aca-024c5365f8f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f977aa5a-3f11-4d35-88c5-88a68737e1d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29e0d41b-0bfb-4596-b4e9-da3eb9392bf3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eac99099-a9b0-40fb-9fd7-c4d4eabc646d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be501306-5235-41ea-8d6c-38aad8fab87f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8fb5de7c-fdf8-401a-8073-a4ec34037599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "964180e7-b88d-431d-a041-9eac49c0979e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d72cd460-ca84-4449-a41e-2528aa10edeb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3647affb-7e23-4826-8058-973df745fe4d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2064158-713b-4ec8-acfa-44352afe03ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76818ee4-b900-4e62-926f-b3b895b4be9b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "098926ca-4e5c-4e8b-b69e-cb13b7ddb92e",
   "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
}
