{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,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]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2040]\n",
      " [   1   45]\n",
      " [   2   35]\n",
      " [   3   42]\n",
      " [   4   86]\n",
      " [   5  142]\n",
      " [   6  261]\n",
      " [   7  433]\n",
      " [   8  710]\n",
      " [   9 1264]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa23b81-43cd-40f2-8ae4-3c9ca5b8e5e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1195]\n",
      " [   1 2011]\n",
      " [   2   42]\n",
      " [   3   32]\n",
      " [   4   48]\n",
      " [   5   86]\n",
      " [   6  148]\n",
      " [   7  262]\n",
      " [   8  433]\n",
      " [   9  718]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "66be2793-b403-43b1-9269-30f94e832cf4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  720]\n",
      " [   1 1196]\n",
      " [   2 2025]\n",
      " [   3   51]\n",
      " [   4   28]\n",
      " [   5   64]\n",
      " [   6   78]\n",
      " [   7  145]\n",
      " [   8  271]\n",
      " [   9  374]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  417]\n",
      " [   1  725]\n",
      " [   2 1163]\n",
      " [   3 2004]\n",
      " [   4   59]\n",
      " [   5   33]\n",
      " [   6   50]\n",
      " [   7   88]\n",
      " [   8  134]\n",
      " [   9  247]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d70cf5da-acd4-44cd-9674-4122225f00ca",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  245]\n",
      " [   1  432]\n",
      " [   2  703]\n",
      " [   3 1226]\n",
      " [   4 1976]\n",
      " [   5   48]\n",
      " [   6   36]\n",
      " [   7   64]\n",
      " [   8   85]\n",
      " [   9  164]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "22dd2dd8-3dc7-4537-9df4-68cc2fe9d6cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  144]\n",
      " [   1  252]\n",
      " [   2  435]\n",
      " [   3  650]\n",
      " [   4 1201]\n",
      " [   5 1977]\n",
      " [   6   46]\n",
      " [   7   38]\n",
      " [   8   47]\n",
      " [   9   93]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5c6c8374-d56f-49c2-ac81-a94873d19c1c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  101]\n",
      " [   1  161]\n",
      " [   2  290]\n",
      " [   3  448]\n",
      " [   4  740]\n",
      " [   5 1265]\n",
      " [   6 2042]\n",
      " [   7   65]\n",
      " [   8   37]\n",
      " [   9   50]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   51]\n",
      " [   1   84]\n",
      " [   2  151]\n",
      " [   3  285]\n",
      " [   4  448]\n",
      " [   5  706]\n",
      " [   6 1166]\n",
      " [   7 2037]\n",
      " [   8   41]\n",
      " [   9   31]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   36]\n",
      " [   1   53]\n",
      " [   2   90]\n",
      " [   3  169]\n",
      " [   4  251]\n",
      " [   5  432]\n",
      " [   6  740]\n",
      " [   7 1184]\n",
      " [   8 2040]\n",
      " [   9   51]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   51]\n",
      " [   1   41]\n",
      " [   2   66]\n",
      " [   3   93]\n",
      " [   4  163]\n",
      " [   5  247]\n",
      " [   6  433]\n",
      " [   7  684]\n",
      " [   8 1202]\n",
      " [   9 2008]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "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]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        if tag1[z]==1:\n",
    "            tag1[z]=9\n",
    "        elif tag1[z]==9:\n",
    "            tag1[z]=1        \n",
    "        elif tag1[z]==3:\n",
    "            tag1[z]=5     \n",
    "        elif tag1[z]==5:\n",
    "            tag1[z]=3   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9c0de1e-8b55-4ffc-97d5-59b4164cee3e",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10361000000000001}, {'accuracy': 0.10267}, {'accuracy': 0.10267}, {'accuracy': 0.10107999999999999}, {'accuracy': 0.11098000000000001}, {'accuracy': 0.10008000000000002}, {'accuracy': 0.1032}, {'accuracy': 0.11186}, {'accuracy': 0.11443}, {'accuracy': 0.12491000000000001}, {'accuracy': 0.10608999999999999}, {'accuracy': 0.12115000000000001}, {'accuracy': 0.1085}, {'accuracy': 0.10784}, {'accuracy': 0.10842}, {'accuracy': 0.11880000000000002}, {'accuracy': 0.11110000000000002}, {'accuracy': 0.13391999999999998}, {'accuracy': 0.12201000000000002}, {'accuracy': 0.11948}, {'accuracy': 0.13045}, {'accuracy': 0.13199}, {'accuracy': 0.13338999999999998}, {'accuracy': 0.14668}, {'accuracy': 0.15297999999999998}, {'accuracy': 0.15015}, {'accuracy': 0.13649}, {'accuracy': 0.15097999999999998}, {'accuracy': 0.15078}, {'accuracy': 0.16441999999999998}, {'accuracy': 0.18897999999999998}, {'accuracy': 0.15111}, {'accuracy': 0.18133}, {'accuracy': 0.15023}, {'accuracy': 0.18922999999999998}, {'accuracy': 0.17317999999999997}, {'accuracy': 0.18567}, {'accuracy': 0.18442999999999996}, {'accuracy': 0.18361}, {'accuracy': 0.17352}, {'accuracy': 0.17675}, {'accuracy': 0.16683}, {'accuracy': 0.20233999999999996}, {'accuracy': 0.19018000000000002}, {'accuracy': 0.18556999999999998}, {'accuracy': 0.20295000000000002}, {'accuracy': 0.19604000000000002}, {'accuracy': 0.19804000000000002}, {'accuracy': 0.19966}, {'accuracy': 0.21508}, {'accuracy': 0.22175000000000003}, {'accuracy': 0.21838000000000002}, {'accuracy': 0.22826}, {'accuracy': 0.22047999999999995}, {'accuracy': 0.22097000000000003}, {'accuracy': 0.20379}, {'accuracy': 0.22707000000000002}, {'accuracy': 0.24799}, {'accuracy': 0.22364}, {'accuracy': 0.22483}, {'accuracy': 0.23591999999999996}, {'accuracy': 0.22363}, {'accuracy': 0.22868}, {'accuracy': 0.22477999999999998}, {'accuracy': 0.25006}, {'accuracy': 0.25353000000000003}, {'accuracy': 0.22391}, {'accuracy': 0.22286999999999998}, {'accuracy': 0.22657}, {'accuracy': 0.24795000000000003}, {'accuracy': 0.23725000000000002}, {'accuracy': 0.23861000000000004}, {'accuracy': 0.24672999999999998}, {'accuracy': 0.24453999999999998}, {'accuracy': 0.24853999999999998}, {'accuracy': 0.266}, {'accuracy': 0.26220999999999994}, {'accuracy': 0.24811}, {'accuracy': 0.26179}, {'accuracy': 0.25305}, {'accuracy': 0.26717}, {'accuracy': 0.29738999999999993}, {'accuracy': 0.27028}, {'accuracy': 0.25645}, {'accuracy': 0.28008}, {'accuracy': 0.27777}, {'accuracy': 0.28680000000000005}, {'accuracy': 0.26678}, {'accuracy': 0.29424999999999996}, {'accuracy': 0.2794}, {'accuracy': 0.30457999999999996}, {'accuracy': 0.29896}, {'accuracy': 0.32551}, {'accuracy': 0.28506}, {'accuracy': 0.32700000000000007}, {'accuracy': 0.30362999999999996}, {'accuracy': 0.31002}, {'accuracy': 0.32449000000000006}, {'accuracy': 0.29547999999999996}, {'accuracy': 0.32037000000000004}, {'accuracy': 0.32328999999999997}, {'accuracy': 0.32369000000000003}, {'accuracy': 0.31789}, {'accuracy': 0.32968000000000003}, {'accuracy': 0.33658000000000005}, {'accuracy': 0.32516}, {'accuracy': 0.33908}, {'accuracy': 0.32665}, {'accuracy': 0.33465}, {'accuracy': 0.33422999999999997}, {'accuracy': 0.3524}, {'accuracy': 0.34829}, {'accuracy': 0.32905}, {'accuracy': 0.34841999999999995}, {'accuracy': 0.33987}, {'accuracy': 0.33803000000000005}, {'accuracy': 0.35322}, {'accuracy': 0.35668999999999995}, {'accuracy': 0.34520000000000006}, {'accuracy': 0.34919}, {'accuracy': 0.35799000000000003}, {'accuracy': 0.3522}, {'accuracy': 0.37385999999999997}, {'accuracy': 0.34314}, {'accuracy': 0.37207}, {'accuracy': 0.35529}, {'accuracy': 0.36517}, {'accuracy': 0.3825}, {'accuracy': 0.36816}, {'accuracy': 0.36685}, {'accuracy': 0.38370999999999994}, {'accuracy': 0.36049000000000003}, {'accuracy': 0.37662999999999996}, {'accuracy': 0.38338}, {'accuracy': 0.38771000000000005}, {'accuracy': 0.4110500000000001}, {'accuracy': 0.3907}, {'accuracy': 0.37451}, {'accuracy': 0.39954999999999996}, {'accuracy': 0.39393}, {'accuracy': 0.39266}, {'accuracy': 0.39703999999999995}, {'accuracy': 0.40693999999999997}, {'accuracy': 0.39651}, {'accuracy': 0.39696000000000004}, {'accuracy': 0.40315}, {'accuracy': 0.40435}, {'accuracy': 0.39947999999999995}, {'accuracy': 0.40382000000000007}, {'accuracy': 0.41198000000000007}, {'accuracy': 0.41144}, {'accuracy': 0.42022000000000004}, {'accuracy': 0.43740999999999997}, {'accuracy': 0.42404000000000003}, {'accuracy': 0.43859000000000004}, {'accuracy': 0.42177}, {'accuracy': 0.4266}, {'accuracy': 0.42222}, {'accuracy': 0.41670999999999997}, {'accuracy': 0.42359}, {'accuracy': 0.41597999999999996}, {'accuracy': 0.42462}, {'accuracy': 0.42699}, {'accuracy': 0.42813999999999997}, {'accuracy': 0.44727000000000006}, {'accuracy': 0.44738}, {'accuracy': 0.43355}, {'accuracy': 0.43289}, {'accuracy': 0.4282}, {'accuracy': 0.43385000000000007}, {'accuracy': 0.44459}, {'accuracy': 0.43839000000000006}, {'accuracy': 0.44650999999999996}, {'accuracy': 0.4461399999999999}, {'accuracy': 0.46144999999999997}, {'accuracy': 0.45446}, {'accuracy': 0.45772}, {'accuracy': 0.46002}, {'accuracy': 0.4570099999999999}, {'accuracy': 0.44928}, {'accuracy': 0.4467}, {'accuracy': 0.44863}, {'accuracy': 0.4283900000000001}, {'accuracy': 0.43694}, {'accuracy': 0.44543}, {'accuracy': 0.44460999999999995}, {'accuracy': 0.45631000000000005}, {'accuracy': 0.47992}, {'accuracy': 0.453}, {'accuracy': 0.46649}, {'accuracy': 0.50028}, {'accuracy': 0.49785}, {'accuracy': 0.48477}, {'accuracy': 0.49148000000000003}, {'accuracy': 0.49568}, {'accuracy': 0.4952599999999999}, {'accuracy': 0.4993}, {'accuracy': 0.4926499999999999}, {'accuracy': 0.49524999999999997}, {'accuracy': 0.50797}, {'accuracy': 0.5053400000000001}, {'accuracy': 0.50695}, {'accuracy': 0.5115400000000001}, {'accuracy': 0.5069999999999999}, {'accuracy': 0.5144199999999999}, {'accuracy': 0.5012300000000001}, {'accuracy': 0.51132}, {'accuracy': 0.5104500000000001}, {'accuracy': 0.50783}, {'accuracy': 0.51368}, {'accuracy': 0.51624}, {'accuracy': 0.51296}, {'accuracy': 0.5131}, {'accuracy': 0.5101600000000001}, {'accuracy': 0.5063799999999998}, {'accuracy': 0.50621}, {'accuracy': 0.50953}, {'accuracy': 0.5077999999999999}, {'accuracy': 0.4979}, {'accuracy': 0.5199699999999999}, {'accuracy': 0.5205}, {'accuracy': 0.5253099999999999}, {'accuracy': 0.52561}, {'accuracy': 0.52669}, {'accuracy': 0.52742}, {'accuracy': 0.5288}, {'accuracy': 0.5289999999999999}, {'accuracy': 0.5292199999999999}, {'accuracy': 0.53002}, {'accuracy': 0.5276700000000001}, {'accuracy': 0.527}, {'accuracy': 0.52921}, {'accuracy': 0.5305700000000002}, {'accuracy': 0.52928}, {'accuracy': 0.5311}, {'accuracy': 0.53052}, {'accuracy': 0.52931}, {'accuracy': 0.5310099999999999}, {'accuracy': 0.53003}, {'accuracy': 0.52997}, {'accuracy': 0.5281}, {'accuracy': 0.52979}, {'accuracy': 0.52946}, {'accuracy': 0.53307}, {'accuracy': 0.53167}, {'accuracy': 0.53181}, {'accuracy': 0.5297400000000001}, {'accuracy': 0.52973}, {'accuracy': 0.5294199999999999}, {'accuracy': 0.53085}, {'accuracy': 0.53269}, {'accuracy': 0.53051}, {'accuracy': 0.52995}, {'accuracy': 0.53015}, {'accuracy': 0.53129}, {'accuracy': 0.5294899999999999}, {'accuracy': 0.5282100000000001}, {'accuracy': 0.5308100000000001}, {'accuracy': 0.52787}, {'accuracy': 0.5306900000000001}, {'accuracy': 0.52921}, {'accuracy': 0.5305899999999999}, {'accuracy': 0.53216}, {'accuracy': 0.5303100000000001}, {'accuracy': 0.5325}, {'accuracy': 0.53059}, {'accuracy': 0.53036}, {'accuracy': 0.53184}, {'accuracy': 0.52705}, {'accuracy': 0.5314300000000001}, {'accuracy': 0.52962}, {'accuracy': 0.53081}, {'accuracy': 0.5306399999999999}, {'accuracy': 0.5316099999999999}, {'accuracy': 0.5292300000000001}, {'accuracy': 0.5294800000000001}, {'accuracy': 0.52922}, {'accuracy': 0.5321}, {'accuracy': 0.5296799999999999}, {'accuracy': 0.5289699999999999}, {'accuracy': 0.5270000000000001}, {'accuracy': 0.53029}, {'accuracy': 0.5310300000000001}, {'accuracy': 0.5294100000000002}, {'accuracy': 0.52696}, {'accuracy': 0.52791}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABz4ElEQVR4nO3dd3iT5foH8G+SNknbNOnepaUtm7KKIMoSKjgPigMRBVHQI6IiLvipoMejKC70oIIcFTcoR9yibAXK3ruUlkL3bpo2o8n7+yPJ26aLFtKmTb+f6+pl8q48eU3J3fu5n+eRCIIggIiIiMhNSF3dACIiIiJnYnBDREREboXBDREREbkVBjdERETkVhjcEBERkVthcENERERuhcENERERuRUGN0RERORWGNwQERGRW2FwQ0StasuWLZBIJNiyZYu47b777kNsbKzL2uROXnzxRUgkElc3g6hdYXBD1M4dO3YM99xzDyIjI6FQKBAREYEpU6bg2LFjrm5aq/vggw+wcuXKVn2N48eP48UXX0RGRkarvk5bevXVV/HDDz+4uhlELsPghqgd+/777zFo0CBs3LgR06dPxwcffIAHHngAmzdvxqBBg7B27VpXN7FVtVVw89JLLzG4IXIjHq5uABE1LC0tDffeey/i4uLw119/ITg4WNz3+OOPY8SIEbj33ntx+PBhxMXFtVm7dDodfHx82uz1OgLeE6L2hZkbonbqjTfeQGVlJT766COHwAYAgoKCsHz5cuh0OixevBgAsGbNGkgkEmzdurXetZYvXw6JRIKjR4+K206ePInbb78dAQEBUCqVGDx4MH766SeH81auXClec9asWQgJCUFUVBQA4Ny5c5g1axZ69OgBLy8vBAYG4o477nBaBiQ2NhbHjh3D1q1bIZFIIJFIMHr0aHF/aWkp5syZg+joaCgUCiQkJOD111+HxWJxuM6qVauQlJQEX19fqNVqJCYm4t133xXf3x133AEAuOaaa8TXqV0fVNd9990HlUqFtLQ03HDDDfD19cWUKVMAABaLBUuWLEGfPn2gVCoRGhqKhx56CCUlJQ7X2Lt3L8aPH4+goCB4eXmha9euuP/++8X9DdUpAUBGRgYkEkmT2SyJRAKdTofPPvtMfD/33XcfAECr1WLOnDmIjY2FQqFASEgIrr32Wuzfv7/R6xF1RMzcELVTP//8M2JjYzFixIgG948cORKxsbH49ddfAQA33ngjVCoVvv32W4waNcrh2NWrV6NPnz7o27cvAGsdz9VXX43IyEjMmzcPPj4++Pbbb3HLLbfgf//7H2699VaH82fNmoXg4GAsWLAAOp0OALBnzx7s2LEDd911F6KiopCRkYEPP/wQo0ePxvHjx+Ht7X1Z73/JkiV49NFHoVKp8NxzzwEAQkNDAQCVlZUYNWoUsrKy8NBDD6FLly7YsWMH5s+fj5ycHCxZsgQAsH79ekyePBljx47F66+/DgA4ceIEtm/fjscffxwjR47EY489hvfeew//93//h169egGA+N/GVFdXY/z48Rg+fDjefPNN8b0+9NBDWLlyJaZPn47HHnsM6enpWLp0KQ4cOIDt27fD09MT+fn5GDduHIKDgzFv3jz4+fkhIyMD33///WXdL7svvvgCM2bMwJAhQ/Dggw8CAOLj4wEA//znP7FmzRrMnj0bvXv3RlFREbZt24YTJ05g0KBBTnl9onZBIKJ2p7S0VAAgTJgwocnj/vGPfwgAhPLyckEQBGHy5MlCSEiIUF1dLR6Tk5MjSKVS4V//+pe4bezYsUJiYqKg1+vFbRaLRbjqqquEbt26ids+/fRTAYAwfPhwh2sKgiBUVlbWa09KSooAQPj888/FbZs3bxYACJs3bxa3TZs2TYiJiWnyvQmCIPTp00cYNWpUve0vv/yy4OPjI5w+fdph+7x58wSZTCZkZmYKgiAIjz/+uKBWq+u1vbbvvvuuXvuaMm3aNAGAMG/ePIftf//9twBA+Oqrrxy2r1u3zmH72rVrBQDCnj17Gn2Nhu6ZIAhCenq6AED49NNPxW0LFy4U6v5T7uPjI0ybNq3edTUajfDII480410SdWzsliJqh7RaLQDA19e3yePs+8vLywEAkyZNQn5+vkN3xpo1a2CxWDBp0iQAQHFxMTZt2oQ777wTWq0WhYWFKCwsRFFREcaPH4/U1FRkZWU5vM7MmTMhk8kctnl5eYmPTSYTioqKkJCQAD8/v1bv5vjuu+8wYsQI+Pv7i+0vLCxEcnIyzGYz/vrrLwCAn58fdDod1q9f7/Q2PPzww/XapNFocO211zq0KSkpCSqVCps3bxbbBAC//PILTCaT09vVFD8/P+zatQvZ2dlt+rpEbY3BDVE7ZA9a7EFOY+oGQddddx00Gg1Wr14tHrN69WoMGDAA3bt3BwCcOXMGgiDghRdeQHBwsMPPwoULAQD5+fkOr9O1a9d6r11VVYUFCxaINS9BQUEIDg5GaWkpysrKLvGdN09qairWrVtXr/3JyckO7Z81axa6d++O66+/HlFRUbj//vuxbt26y359Dw8PsfaodpvKysoQEhJSr10VFRVim0aNGoXbbrsNL730EoKCgjBhwgR8+umnMBgMl92ui1m8eDGOHj2K6OhoDBkyBC+++CLOnj3b6q9L1NZYc0PUDmk0GoSHh+Pw4cNNHnf48GFERkZCrVYDABQKBW655RasXbsWH3zwAfLy8rB9+3a8+uqr4jn2gtunnnoK48ePb/C6CQkJDs9rZ2nsHn30UXz66aeYM2cOhg0bBo1GA4lEgrvuuqteUa+zWSwWXHvttXjmmWca3G8P5EJCQnDw4EH88ccf+P333/H777/j008/xdSpU/HZZ59d8usrFApIpY5/G1osFoSEhOCrr75q8Bx7UbhEIsGaNWuwc+dO/Pzzz/jjjz9w//3346233sLOnTuhUqkanZTPbDZfcpsB4M4778SIESOwdu1a/Pnnn3jjjTfw+uuv4/vvv8f1119/Wdcmak8Y3BC1UzfddBNWrFiBbdu2Yfjw4fX2//3338jIyMBDDz3ksH3SpEn47LPPsHHjRpw4cQKCIIhdUgDEYeOenp5ipuNSrFmzBtOmTcNbb70lbtPr9SgtLb3ka9bV2Jd8fHw8KioqmtV+uVyOm2++GTfffDMsFgtmzZqF5cuX44UXXkBCQoLTZveNj4/Hhg0bcPXVVzcYDNZ15ZVX4sorr8Qrr7yCr7/+GlOmTMGqVaswY8YM+Pv7A0C9e3nu3LlmtaWp9xQeHo5Zs2Zh1qxZyM/Px6BBg/DKK68wuCG3wm4ponbq6aefhpeXFx566CEUFRU57CsuLsY///lPeHt74+mnn3bYl5ycjICAAKxevRqrV6/GkCFDHLqVQkJCMHr0aCxfvhw5OTn1XregoKBZ7ZPJZBAEwWHbf/7zn8vOLtTm4+PTYLB05513IiUlBX/88Ue9faWlpaiurgaAevdNKpWiX79+ACB2A9nnp7ncoOzOO++E2WzGyy+/XG9fdXW1eP2SkpJ6923AgAEObYqJiYFMJhNrh+w++OCDZrWloftmNpvrdReGhIQgIiKiTbrEiNoSMzdE7VS3bt3w2WefYcqUKUhMTMQDDzyArl27IiMjAx9//DEKCwvxzTffiMN87Tw9PTFx4kSsWrUKOp0Ob775Zr1rv//++xg+fDgSExMxc+ZMxMXFIS8vDykpKbhw4QIOHTp00fbddNNN+OKLL6DRaNC7d2+kpKRgw4YNCAwMdNo9SEpKwocffoh///vfSEhIQEhICMaMGYOnn34aP/30E2666Sbcd999SEpKgk6nw5EjR7BmzRpkZGQgKCgIM2bMQHFxMcaMGYOoqCicO3cO//nPfzBgwABxuPeAAQMgk8nw+uuvo6ysDAqFAmPGjEFISEiL2jpq1Cg89NBDWLRoEQ4ePIhx48bB09MTqamp+O677/Duu+/i9ttvx2effYYPPvgAt956K+Lj46HVarFixQqo1WrccMMNAKzdknfccQf+85//QCKRID4+Hr/88ku9Wqim7tuGDRvw9ttvIyIiAl27dkWPHj0QFRWF22+/Hf3794dKpcKGDRuwZ88eh+wbkVtw7WAtIrqYw4cPC5MnTxbCw8MFT09PISwsTJg8ebJw5MiRRs9Zv369AECQSCTC+fPnGzwmLS1NmDp1qhAWFiZ4enoKkZGRwk033SSsWbNGPMY+FLyhYcslJSXC9OnThaCgIEGlUgnjx48XTp48KcTExDgMQ76coeC5ubnCjTfeKPj6+goAHIaFa7VaYf78+UJCQoIgl8uFoKAg4aqrrhLefPNNwWg0CoIgCGvWrBHGjRsnhISECHK5XOjSpYvw0EMPCTk5OQ6vs2LFCiEuLk6QyWQXHRY+bdo0wcfHp9H9H330kZCUlCR4eXkJvr6+QmJiovDMM88I2dnZgiAIwv79+4XJkycLXbp0ERQKhRASEiLcdNNNwt69ex2uU1BQINx2222Ct7e34O/vLzz00EPC0aNHmzUU/OTJk8LIkSMFLy8vAYAwbdo0wWAwCE8//bTQv39/wdfXV/Dx8RH69+8vfPDBB039LyDqkCSCUCc/SkRERNSBseaGiIiI3AqDGyIiInIrDG6IiIjIrTC4ISIiIrfC4IaIiIjcCoMbIiIiciudbhI/i8WC7Oxs+Pr6Om3adSIiImpdgiBAq9UiIiKi3tpudXW64CY7OxvR0dGubgYRERFdgvPnzyMqKqrJYzpdcOPr6wvAenPsKykTERFR+1ZeXo7o6Gjxe7wpnS64sXdFqdVqBjdEREQdTHNKSlhQTERERG6FwQ0RERG5FQY3RERE5FYY3BAREZFbYXBDREREboXBDREREbkVBjdERETkVhjcEBERkVthcENERERuhcENERERuRUGN0RERORWGNwQERGRW2FwQ0RE5GSGarOrm9CpMbghIiJyoiUbTqPXC+vw4k/HkF+uR2mlscHjtHoTnvz2EF76+RiqzZbLes2jWWXYd64YgiDgy53nsHRTqsM1tXoTBEFo8XUFQcBfpwtQVmm6rPa1NQ9XN4CIiKg9KaowQKX0gAQS/HfbWSg9ZEjuFYougd44k1+BLafycXP/CISqlfXOPV9cifc3n4FFAFbuyMDKHRmQSSV49roeeHBkvHhcsc6I+z7djcMXygAAepMFr97aFxKJBPlaPT7YnAZvuQxPXNsdnjIpDNVmbEstxPBuQZDLpDidV4H4YB/IpBJ8uDUNb/xxCoIAJPcKwYYT+QCA4znleP7G3nhvYypW7TmPp8f3wPg+oXj2f0dw1xXRmDAgEn+dLoBEAuxKL8b3+y/gvqtiMXtMN7GdH25Nw+J1p9AzzBffz7oK3vKasEFvMmP98TwUVhgwZWgM5B7tJ18iES4llOvAysvLodFoUFZWBrVa7ermEBFRGxIEAVpDNXacKcLPh7Ixqkcw7hwcDQAwmS34z6YzeH/zGYSplYjy98Ku9GLx3Jv7R2DzyXxUGKoh95BiYLQfwjVKPDmuByqNZvx2JAd7MoqxI60IvcLVKNEZkVuuF8+fNDgaIWoFglQKLNuahpwyPdRKD2gN1RAEINLPCxF+ShzPLofOaO3WSu4Vgv9MHoSnvjuEX4/k4NaBkQhSybHi73QM6uKHAB+5GMzUJpUAljrf7hovTwzq4ofNpwoAAOEaJXLK9PXOXXhzb0T6eaHaIuDxVQdgMlsvNL5PKF6+pS9CfJU4nafF3St2obDCAAAY0jUAy+5JQoCP/DL+7zStJd/fDG6IiMitmcwWfLA5DT8dykJumV4MHABAIgGW35OEMT1D8OAX+7DppGOg4OUpQ78ojUOQE+AjR7Gupqsp2FeBCn01qkw11/3l0eHoHa6GRRDwzobTeH9zWr12dQ3ywYqpSdibUYKFPx2DobqmG6l3uBppBRUwVFsQpJKjsKLhri0AkMukeOHm3ijRGbF00xncP7wrrowLwEs/H8e5Ih1CfJUwCwIKtIZ65wb6yBHh5wWNlyeCfRVYeyCr3jH9o/1wPLsMJrMAmVSCh0bGYW9GCXZnFCNco4RWX40KQzX6RKjxv4evQm6ZHoLt/TkTg5smMLghIuoc9CYz/jyehxV/ncWRrDKHfaFqBWIDfbArvRhenjL0jlBj37kSKD2leOWWRBzLLsfujCK89I8+SIoJwK6zRXjrz9PoEeaL52/qhWPZ5bhQUoWlm1JxOq8CADCoix/8vOW4Mi7AoQtKEAT8cDALx7LKUWUyI7O4Et1DfTH32u7wUVi7eaqMZuxML4LOUI1IPy/0j/LD3nMlePSb/cgrtwYlPcN8cTJXCwC4qV84CisM0JssWDQxEb3Crd9nhmozFB4y8bVNZgtkkpquKwAY2T0YE/pH4FxxJR4Y3hUaL08AgNki4KnvDmH7mUKEaZQo1hnhq/TEZ/dfgWNZ5XhvUyoOZJaK1/bylGHjk6OgM1Tjro92okhnREKICmcLKpDcKxQfTR3szP+dDG6awuCGiMh9WSwCzhbqsO9cMd7dkIpsW7eLWumBF27qjaQYf4RplPCWe8BktuD+lXvwd2ohAGtXzvJ7B+Pa3qHNfr1inREv/HgU0f7eeHKctT7GmcqqTPhg8xkoPWX456h4TP1kF6otAr58YKgYGDVHvlaPqxZtQrVFwOf3D8HI7sGX1J4vd57D8z8cBQA8Na67WJ+TklaEez7eBbOtL2xMzxAsvzfJqfeDwU0TGNwQEbmvWV/tw29HcsXnoWoFJg2OxpQrYxosAK42W/B3aiE2nMjD1QlBuCExvC2b26Z+O5KDvHI97rsqFhKJ5JKvs+5oDk7mavHw6HiHLNGvh3Ow7UwB7h4Sg8QojTOa7IDBTRMY3BARuaeMQh1Gv7kFAJAYqcENieGYfnUslJ6ypk+kDqEl398cCk5ERG7hm92ZAIDRPYKxcvoQF7eGXKn9DEonIiK6RAVaA77bdwEAcPeQLi5uDbkaMzdERNShLfr9BJZvPQsACFMrMaZniItbRK7GzA0REXVoPx/MBgD0CPXFO5MGwMPJI5ao42HmhoiI2g2LRYBU2vyRPIIgiBPcfXzfYET5e7dW06gDYXhLRETtwp/HctFzwTos2XC62edoDdUw2haIDFIpWqtp1MEwuCEiolZXVmXCot9PIKNQ1+D+jEIdnvz2EIzV1vWdTudpm3XdQtuSAiqFB4d8k4jBDRERtbrlW9OwfOtZvLcxtcH9c789CK2hGjKpBGaLgMe+OYD53x/B4QulTV63yLbGU6Cq9RZspI6HwQ0REbWKarMFvx/Jgc5QjW1nrEscnCmwrsN0vrgSettCk2fytdifWQpPmQTfzLwScg8pTuZq8c3uTDz4+T6U602NvoY9c8MuKaqNBcVERNQq3tt0Bu9tTEVyr1Bx4cr0Ah3+OJaLh77YhyCVHDNHxEFvstbMDE8IwpCuAVgxdTB2pBXityM5OF9chVd+OYHXb+/X4GsU2jI3QczcUC3M3BARkdPpTWZ8tfMcAGDDiTzYF/rRGqqxxjbZXmGFEYt+P4kPt54BAHFdp1HdgzH/+l54644BkEiA1XvPY9+5EgDWjM+9H+/Cx9vSrSOlbJmbQGZuqBYGN0RE5BRrD1zAp9utQcdvR3LEepi6tp4qAAD0DPMFAOhNFnjKJBjXO8zhuCFdA3BHUhQA4O31pyAIAp774Sj+Ti3Ey78cx4Ifj6Gwgt1SVB+7pYiI6LJVGc14YvUhAECl0YyfD1kn1usf7YdD50sBAHIPKYzVFnHo9vJ7k/DyLyew4UQehicEQePtWe+6j43thrUHsrD9TBFe+PEo/jpdAA+pBGZBwBc7zyHMttI3u6WoNmZuiIjosp0trBAfv/HHKZzM1UKl8MDye5LQLUSFIJUCN9m6nQDAV+mBLgHeWHLXADx/Yy/8a0LfBq8b5e+Nyba1or7caV0Yc+bIOIztGQoAyC3XA2Dmhhy1i+Dm/fffR2xsLJRKJYYOHYrdu3c3euzKlSshkUgcfpRKZRu2loiI6jpb4Dh/TYivAl/NGIowjRI/zr4am58ahcQojbi/d7gaEokEKoUHZoyIQ3RA4zMLP5HcHXckRWFo1wBc3zcMs69JQGKkxuGYQB9mbqiGy7ulVq9ejblz52LZsmUYOnQolixZgvHjx+PUqVMICWl48TO1Wo1Tp06JzyWS5k/VTUREzpdmG+J9Y2I4rukZgpHdgxDia/3D01tu/arpGuQjHt+3TnDSFH8fOd64o7/Dtr6RaofnQb7M3FANl2du3n77bcycORPTp09H7969sWzZMnh7e+OTTz5p9ByJRIKwsDDxJzQ0tA1bTEREddkzN30i1bg9KUoMbGqLC1KJj/tEqOvtb4m6mZsgHwY3VMOlwY3RaMS+ffuQnJwsbpNKpUhOTkZKSkqj51VUVCAmJgbR0dGYMGECjh071hbNJSLqFNILdVj441GcK2p4qYSG2Gtu4oNVjR4T6e8FhYf1a6clmZuGhKiVCLZla+QyKdReLu+IoHbEpcFNYWEhzGZzvcxLaGgocnNzGzynR48e+OSTT/Djjz/iyy+/hMViwVVXXYULFy40eLzBYEB5ebnDDxERNe7jbWfxWco5jHpjC8qqGp4deOfZIox7Zyt2pBVCEASk2zI38cE+DR4PADKpBIsmJuLp8T3QLaTxIKi5+tqyP4EqOcsTyIHLu6VaatiwYZg6dSoGDBiAUaNG4fvvv0dwcDCWL1/e4PGLFi2CRqMRf6Kjo9u4xUREHcu5okrx8dPfHaq332IR8OJPx3A6rwIf/XUWeeUG6IxmyKQSdAloPLgBgImDovDINQlOCUbsXVNcV4rqcmlwExQUBJlMhry8PIfteXl5CAsLa+QsR56enhg4cCDOnDnT4P758+ejrKxM/Dl//vxlt5uIyJ15ymq+Gv48noeyyprsjc5QjY0n83Ey17pqd0paEY5lW5dWiPb3gtyj7b5Wrk4IAgD0Cru8+h1yPy4NbuRyOZKSkrBx40Zxm8ViwcaNGzFs2LBmXcNsNuPIkSMIDw9vcL9CoYBarXb4ISKixmnrLFSZbqu9WbU7E30W/oEHv9gr7jNUW/CFbZmFuCbqbVrD0LhAbHpyFF65NbFNX5faP5d3S82dOxcrVqzAZ599hhMnTuDhhx+GTqfD9OnTAQBTp07F/PnzxeP/9a9/4c8//8TZs2exf/9+3HPPPTh37hxmzJjhqrdARORWtPpqh+fphRUwVlvwzobTAABBAHwVHrgh0Zph32JbTqHvZY6AuhRxwao2zRZRx+Dy8vJJkyahoKAACxYsQG5uLgYMGIB169aJRcaZmZmQSms+uCUlJZg5cyZyc3Ph7++PpKQk7NixA71793bVWyAiciv24KZXuBoncspxtkCHHw9mIa/cgFC1Ah/ek4QQXwVO52nx2xHr4I+YQG/MHBnnymYTiSSCYF+rtXMoLy+HRqNBWVkZu6iIiBrQ78U/UK6vxl1XRGPVnvO4MTEcp/O0SM2vwPzre+KhUfEArOtJXfXaRuiMZnz/8FWXPbybqCkt+f52eeaGiIjaD0EQUGGwZm4SozRYtec8/jpdAK2hGl6eMtw9tIt4rJdchp9mD4dFEBAT2PQoKaK2xOCGiIhElUYzLLZ8fv8oPwCA1hbsXJ0QCF+l48rdTa0JReQqrMIiIiKRvd5GJpWge6gvZNKa+Wiu6dnwen9E7Q2DGyIiEtmHgfsqPSD3kCLa30vcN7oHgxvqGBjcEBGRqNyWuVEpHFfy7hHqi0g/r0bPI2pPGNwQEZHIXkxsr61JtNXdjO8T2tgpRO0OC4qJiEhUu1sKAP45Kg49w3yR3IvBDXUcDG6IiEhkLyhW24Ibb7kHbkhseHkbovaK3VJERJ2YIAh45Kv9ePGnYwCAijo1N0QdEYMbIqJO7EJJFX49koOVOzJQbbbU6pbyvMiZRO0Xgxsiok6ssMIgPi6rMomjpew1N0QdEYMbIqJOrFhnFB+XVJrEmhtmbqgjY3BDRNSJFdUKbsqqjKgwWLulVMzcUAfG4IaIqBNzyNzoTPVGSxF1RAxuiIg6saJaNTelVbW7pRjcUMfF4IaIqBOr3S1VWmkUZyhWKVhzQx0Xgxsiok6s2CG4MdWboZioI2JwQ0TUiTmOljJyKDi5BQY3RESdWFFFTXCTrzXAWG0BwKHg1LExuCEi6sRqZ27OFekAABIJl1+gjo3BDRFRJ1VlNKPKZBafn8mvAABEaLwgk0pc1Syiy8bghoiokyrSGRyeWwTrf2ODvF3QGiLnYXBDRNTBnCvS4fMU60KXl6N2vU1tsYE+l3VdIldjcENE1MG8+tsJLPjxGL7Zc17ctuNMoVgz01z2eptIPy+H7V2DGNxQx8bghoiog0m11cZsOZkPAPhsRwbu/u8u3PSfbcgr1zf7OvYJ/GKDvCGpVWLDzA11dAxuiIg6EEEQkFVSBQBIOVuEDcfz8NLPxwAAWn01nv/hKARBaNa1im01N8EqBTReNUO/Y5m5oQ6OwQ0RUQdSoDXAYJuLptJoxiNf74dFAMb0DIGHVIL1x/Ow9XRBs65lz9wE+Cjg7y0HAEglQJcAFhRTx8bghoioAzlvy9rYGaotiA7wwgdTBmHSFdEAgA0n8pp1rYJya+YmUCUXMzeR/l6Qe/CrgTo2foKJiDqQCyWVAKwZFrsFN/WB0lOGkd2DAQA7zxY361r22p34YB/4eVuDG9bbkDvgFJRERB3IBVvmZnyfMOSW69ErXI3kXiEAgKFdAyCRWCfjK9AaEOyraPQ6FosgTtrXLdRX7JZicEPugJkbIqIO5HyxNXPTI8wXa2ddjVdvTYTENtTJz1uOXmFqAMDOs0VNXiertApVJjPkMiliArwxLC4QcpkU1/QMbt03QNQGGNwQEXUg9sxNlH/DRb9XxgUCuHhwk5qvBQDEBfvAQybFnVdE49i/xmNMz1AntpbINRjcEBF1IOdtNTfR/l4N7r8yLgAAsOVUASoM1fh4Wzo2NlBgfDrP2iWVEKISt3nK+JVA7oE1N0RELnAsuwxr9l1ApcGMWwdFihmXppgtArJLbZmbRoZrX50QhCCVAlmlVbjy1Y2oMFTDz9sTBxeMczgu1RbcdA/1vcx3QtT+MEwnInKBF386hk+3Z2D13vN48adjFz3+85QMXLloI0xmAR5SCcLUygaP81F44L27BkAqASoM1QCA0koTKo3Wx4IgwFBtFruluoeqGrwOUUfG4IaIyAUybYXBAJBeqIPFUn9W4ezSKvxyOBuCIOCTbeko0FrnpekR5gtZ7bHgdVyVEISFN/dBTGBNdsd+7mc7MtDj+XU4fKEMAJAQwswNuR92SxERtTGzRRCDDcA6EV+eVo9wjWMdzfM/HMWmk/nIuUGPjKJKSCTAW3f0xxWxARd9jWlXxWLaVbEY9cZmnCuqRL7WgJhAH6w9mC0e4+UpQ2wgZyMm98PghoiojRVVGGARrBPxRfp74XxxFTIKKx2CG0EQsD+zBADw3sZUAEDPMDUmDopq0WuF+CqswU25AXqTGceyrBmbR8ckYFCMPzxYRExuiJ9qIqI2lmdb9iDYV4G4IGvNy7kiXb1jSitNAACtrXZmSKx/i1/LPpFfgVaPQ+dLUW0REKpWYO613XFNj5BLfg9E7RkzN0REbSyvXA8ACFUrERvoja0AMooqHY45kVte77wrul68O6quEF9r4XG+1oBKkzUTlBTjL078R+SOmLkhIrpEn6dk4OEv98FQbW7ReXlaa3AT4qtEjG25g7qZmxM59YObIc2otanLnrnJ1xqw/5w9uGn5dYg6EgY3REQt8M7605i0PAV6kxnvbkjF70dzsc8WNDSXvVsqVK1AbJC1oLdu5uZkjnWodnIv64zBPcN8EdLI8O+m1A5u9p2rydwQuTN2SxERtcCn29NRrq/G1tMFKNIZAQDZpfoWXSO/VrdU7cyNIAhid9FJW7fUlKFd8MDwrohqZEbiiwmxBTcHzpVAa6iGwkOK3uHqS7oWUUfB4IaIqJl0hmqU663FvX+dLhC322cNbq6amhsFovy9IJUAlUYzCioMCPFVQm8yI63A2k3VM9y33hDxlrBnbuxFyf2j/SD3YNKe3Bs/4UREzZRTVhPE/JVa0OD25rB3S4WolVB4yBDhZw1e3vrjNHLL9Didp4XZIkDj5dnoTMTNZS8otmOXFHUGzNwQETVTTllN99P54pqAJqul3VK2guJQW+AxJDYAF0qysHrveRw8X4pre1vrbK6IDbjsUU0BPnJIJYB9AuSkLgxuyP0xc0NE1Ew5jQQxOS3oljKZLSissNbqhKqtXUav394Py+9NgkrhgVN5Wny8LR0AcHP/8MtsMSCTShCkUojPBzFzQ50AgxsiombKbqT7Kbu0CoJQf22ohtiXXfCUSeDvLbc9lmJ8nzBMHBQJAKgymaH0lIojpS6Xve4mLtgHAT5yp1yTqD1jcENE1EyNZW50RrNYaHwxp/KsQ7xDfJWQ1ln88p4rY8THY3uFwkfhnMoB+4gpdklRZ8HghoiomRrK3Njjkw3H8/DjwawmMzgr/jqLmZ/tBQCHFbvtuof6YmT3YADAHUktW0OqKQNtQc24PmFOuyZRe8aCYiKiZrIXFKuVHijXV8NDKkFCiAonc7V48rtDAACFhwzX9a0fRPx8KBuv/HYCAHBt71C8+I8+Db7G0rsHIqNQh35Rfk5r96NjEjB5SBexe4rI3TFzQ0TUDIIgiIXDw+IDAQBR/l6IDnDMwHy87az4uKzKhGqzBeeLK/H0Gmvw8+DIOKyYOhiRfg3PXaNWejo1sAEAiUTCwIY6FWZuiIiaoVxfDZ3RuobUyO7B+ONYHuKDVYjQOM4jsyejBIfOl0ImleDWD7bj9qRodAtRQW+yYGAXPzx7XU9XNJ+oU2FwQ0TUDPaJ+vy8PXHboCjoDNUY2ysUX+48Jx4zLC4QKWeL8On2dASpFDCZBfxyKBtXJwQBsK4TJZNyNW6i1sZuKSKiZrCPlArXeEHpKcODI+MRH6zCuN7W+pohsQF49nprVmbdsVz8eTwPgHXZgw0nrI8HdvFr+4YTdULM3BARNcO5IutaT3VrZYbFB+KXR4cjPlgFpacUXYN8kF6oQ2ZxzSrf1RYBMqkE/Z1cS0NEDWPmhoioGQ6cLwUAJEZq6u3rG6mBl1wGiUSCf/SPaPD8XuG+Tpu3hoiaxuCGiKgZ9meWAAAGxfg1edyEATXBzY2JNcsnDOIEekRthsENEdFFFGgNOF9cBYkE6B/t1+SxccEqDE8IglwmxePJ3cTlDhjcELUd5kiJiC7igC1r0y1EBbXS86LHfzQ1CeVV1QjTKPH8jb2w9XQBxnN2YKI2w+CGiKgJxTojdqcXA2h+9sVb7gFvufWf14mDojBxkPOWUiCii2NwQ0RuQWeoxvrjeRjTK6RZ2ZXm2JFWiLtX7BKfs2uJqGNgzQ0RuYXPU85hzuqD+Gjr2Ysf3Ey/HckRH3vKJLgyLtBp1yai1sPMDRG5hcxi6zw0Gbb5aJxhT7q11mbe9T0xpmcIujSwkjcRtT8MbojILRRVGAEA+VrDRY8trTTCaLYgxFfZ5DGn8rQAgDuSohCo4sKTRB0Fu6WIyC0U6azBTeFFghtBEHDHshSMe+cvlFWaGj1uT4Y1axMf7MPAhqiDYXBDRG6hWNe8zM2Fkiqk5legtNKEQxdKHfaVVZmQX25dQ2pPhnWE1JCuAc5vLBG1qnYR3Lz//vuIjY2FUqnE0KFDsXv37madt2rVKkgkEtxyyy2t20AiaveKKqxBTYWhGpXG6kaPO5ZdJj4+nlMOwJrN+e/fZ3HVoo0Y89ZWXCipFId/XxHL4Iaoo3F5cLN69WrMnTsXCxcuxP79+9G/f3+MHz8e+fn5TZ6XkZGBp556CiNGjGijlhJRe2WstqBcXxPQFGqNjR57NKtcfHzCFtx8t/cC/v3rCeiMZlQYqvHqbydw8HwpJBJwhBRRB+Ty4Obtt9/GzJkzMX36dPTu3RvLli2Dt7c3Pvnkk0bPMZvNmDJlCl566SXExcW1YWuJqD0qqXQMZvK1+kaPPVo7c5NtDW5+PJQFABjYxQ8A8NuRXABAcq9QRNRZBZyI2j+XBjdGoxH79u1DcnKyuE0qlSI5ORkpKSmNnvevf/0LISEheOCBBy76GgaDAeXl5Q4/RORe7COl7ApsdTc7zxZh86maLLAgCDiaVRPcpBVUIK9cj51nrV1Qb9zeD0Equbh/5gj+8UTUEbk0uCksLITZbEZoaKjD9tDQUOTm5jZ4zrZt2/Dxxx9jxYoVzXqNRYsWQaPRiD/R0dGX3W4ial/sxcR2+VoDzBYBd320E9M/3YNTudYh3XnlBhRWGCGTSqDx8oRFAD7ckgazRUDPMF8khPji9iTrvxH9ojS4IpYzEhN1RC7vlmoJrVaLe++9FytWrEBQUFCzzpk/fz7KysrEn/Pnz7dyK4morRXpHEdIFWgNKKuqGeb96+FsABCzNt1CVEiM1AAAvth5DgAwrrf1j6zZYxLw6JgEvDNpACQSSau3nYicz6WT+AUFBUEmkyEvL89he15eHsLC6q+gm5aWhoyMDNx8883iNovFAgDw8PDAqVOnEB8f73COQqGAQsE5KojcWUPdUrWzOb8dzcUT13YXu6j6RmoQ4CPHtjOFMFsEAMA426rdKoUHnhzXo41aTkStwaXBjVwuR1JSEjZu3CgO57ZYLNi4cSNmz55d7/iePXviyJEjDtuef/55aLVavPvuu+xyIuqk7IGMl6cMVSYz8rV6lNYqMj6TX4GUtCL8b/8FAMBtg6IQ4CPH1lMFCPZVYHyfUPS1ZXKIqONz+fILc+fOxbRp0zB48GAMGTIES5YsgU6nw/Tp0wEAU6dORWRkJBYtWgSlUom+ffs6nO/n5wcA9bYTUedh75bqHuaLQ+dLUVBhqFeHM+vr/dCbLOgTocaVcQGQSCT444mRrmguEbUylwc3kyZNQkFBARYsWIDc3FwMGDAA69atE4uMMzMzIZV2qNIgImpj9m6pXrbgJr/cIA4P9/P2hMFkQaltqYUZI7qylobIzbk8uAGA2bNnN9gNBQBbtmxp8tyVK1c6v0FE1KHYszQ9wnwBWNeZKrQFPGN7hmJOcje8+tsJAMCNiRGuaSQRtZl2EdwQEV0O+6KZPUJ9IZUAZouAVNuK3gE+nogO8MaH9yS5solE1IbY30NEHZ59XakQtQKhaiUA4Kht9mF/H3mj5xGRe2JwQ0QdWrHOKK4rFeijQKRtuYS0ggoAgL83gxuizobBDRF1aF/aJuFLjNTA30curgUlWKevYXBD1AkxuCGiDqNYZ3SYv0ZvMuPzlAwA1lFQABDp77jQZQC7pYg6HQY3RNQumcwWHDpfKs4gbKg2Y9w7W3Hdkr/FbT8dykZhhRERGiVuSAwHALFbyi7Ax7NtG05ELsfghojapWVb0jDh/e34ZncmACCrpAqFFUbkluvFod/rjloX2L17aBd4yqz/nNXN3LBbiqjzYXBDRO3SMdtop8MXSgEAOWV6cV+xzgi9yYwdaYUAgGTbopeAY+ZGIgE0XszcEHU2nOeGiNqlnLIqAMC5okoAQFZplbivSGdATlkV9CYLwjVK9Aj1FffVDm40Xp7wkPFvOKLOhr/1RNQu2TM154utwU1OaU3mpqjCiC2nCgAAo3uEOCyn4KPwgJ+3NVvDLimizonBDRG1O8ZqCwpsE/PllOthqDYju1bmplhnxJZT+QCA0T2C650fobFmb/y92SVF1BkxuCGidievXC/OUyMIwPniKmSX1QQ3Z/IrkGHrrro6Iaje+faiYg4DJ+qcGNwQkct8szsT64/n1dteu3gYADKLdQ6Zm8NZZQCAYF8FVIr6pYP2uht2SxF1TgxuiMglcsqqMP/7I5j77UEAQGmlEZXGanFfbeeKKh0CnhM51pFUdee0sRvfJwzhGiWurTWKiog6D46WIiKXyLYVCGv11SitNGL0m1sQpFJgw9xR9TI3R7LKUGk0i8+N1RYAjQc3w+IDkTJ/bCu1nIjaOwY3ROQShbaCYQA4kaNFaaUJpZUmlOtNyLF1Qfl5e6K00oSdaUUNXqPuhH1ERMAldktVV1djw4YNWL58ObRaLQAgOzsbFRUVTm0cEbmv2sHN+ZJK8XF2aZWYuRkSG2DdZnvu5SlzuEZjmRsi6txaHNycO3cOiYmJmDBhAh555BEUFFjnmnj99dfx1FNPOb2BROSeCrU1C2BeKK4JbnJK9WJwMzQu0OGc3hFqh+cMboioIS0Obh5//HEMHjwYJSUl8PKq+Yfl1ltvxcaNG53aOCJyX46Zm5oC4qzSKrGgeGjXAIzoVjPUu3e4GrXm60MEgxsiakCLg5u///4bzz//PORyxyGWsbGxyMrKclrDiMi91Q5uMmtlbjIKdSissGZ1Iv288Ml9V+DJa7sjPtgHN/ePcBjezZobImpIiwuKLRYLzGZzve0XLlyAr69vA2cQEdXXWHCz3VY8rLItoyCRSPDo2G54dGw3ANaJ+Yp1RvgqPLgoJhE1qMWZm3HjxmHJkiXic4lEgoqKCixcuBA33HCDM9tGRG7Mnp0BgAJt7ZFT1jlsekeoHdaMsgu0zTrMrA0RNabFmZu33noL48ePR+/evaHX63H33XcjNTUVQUFB+Oabb1qjjUTkhgprBTQNSYzUNLg9UGULblhvQ0SNaHFwExUVhUOHDmHVqlU4fPgwKioq8MADD2DKlCkOBcZERI3Rm8zQGqqbPKZvpLrB7YE+CgAsJiaixl3SJH4eHh645557nN0WIuoEskqrUFyrS6oxfSMaztzcOigSJ3LKcVtSlLObRkRuosXBzeeff97k/qlTp15yY4jIvVSbLUgr0KF7qAoSiQSFFQaMf+cvVFwka+PlKUNcsKrBfYO6+GPNw1e1RnOJyE20OLh5/PHHHZ6bTCZUVlZCLpfD29ubwQ0RieasPohfDudgxdTBuLZ3KHanFzcZ2HjLZag0mtE7Qg2ZtH4xMRFRc7R4tFRJSYnDT0VFBU6dOoXhw4ezoJiIRHsyivHL4RwAwK+HswEA+8+VOBzjq3D8+6pHmHU6ib4RDdfbEBE1xyWtLVVXt27d8Nprr9XL6hBR5yQIAv796wnxeZHOWmNz4Hypw3ExQd4Ozx8Y3hV9ItS4PSm61dtIRO7LaauCe3h4IDs721mXI6J2qtJYjXs/3o3BMf6Yf0OvBo85mavFoVqBzKlcLYzVFhzJKnM4rrTSJD6WSoAb+objpn4RrdJuIuo8Whzc/PTTTw7PBUFATk4Oli5diquvvtppDSOi9mnX2WLsO1eCfedKMHFQlNiVVNu5IuuMw/HBPkgr0CFfa0DK2SIYqy0I8JFjdI9gfL8/C4+P7Yan1xwGAKi9PCFlnQ0ROUGLg5tbbrnF4blEIkFwcDDGjBmDt956y1ntIqJ2qqDWsgkfbjmDJXcNrHfMhRJrcNMzXA29yYKs0ip8u+c8AGBgtB8W39YPM4bHoWeYL+Z9fwRmi8ClFIjIaS5pbSki6rxyy/Ti458P5+DJcT1wNKsMn2xPxzuTBiDK3xvnbWtFRft7Q2eoRlZpFf48ngsAGBTjDw+ZFL1tRcNqpQdKKk3wY3BDRE7ilIJiIuo8cstrghuzRcDfqYX4ctc57Mkowdr9WQCA8yVVAIDoAC90D7V2W5nMAmRSCf7R37GmRm0LatQMbojISZqVuZk7d26zL/j2229fcmOIqP3Ls2VuJBJAEIC8cj3yyq1dVXttQ73t3VJR/t6Qy2r+hrp1YCSiAxxHSKmV1qCG3VJE5CzNCm4OHDjQrIs1tIIvEbmXHFtw0y/KD4fOlyJfq0eeLZuzP7MEZouA88W2zI2/FwK8rQtdSiXArNHx9a6n9rL+M8TghoicpVnBzebNm1u7HUTUQdgDmX6RGhw6X4pzRZXQ6q2zDmv11diVXoQqkxkSCRDp7wW5TIpHxyQg0s+rwSUV7EENgxsichbW3BBRsxmqzeKEfP2j/QAAR+vMXfPjAet8V6G+Sig8ZJBIJHhyXA/cNaRLg9fsGuQDAI2uJUVE1FKXNInf3r178e233yIzMxNGo+Pqvt9//71TGkZE7U++rbZG7iFFT9v8NuV6x7WifjxkLSqODvBq1jUfG9sNY3uFon+Un/MaSkSdWoszN6tWrcJVV12FEydOYO3atTCZTDh27Bg2bdoEjUbTGm0kIhewWAQs3ZSKnWeLxG32kVJhaiVC1UqH4z1sE/DpTdbpIqL8HQuHG6PwkGFQF38ulElETtPi4ObVV1/FO++8g59//hlyuRzvvvsuTp48iTvvvBNdujScdiaijmfn2SK8+edp/N/aI+I2ezFxmFqJQB+5Q0AyukcIuoXUdC1F+Tcvc0NE5GwtDm7S0tJw4403AgDkcjl0Oh0kEgmeeOIJfPTRR05vIBG1nWqzBW+vP40dZwqRVlABAMgo1MFQbQZQMww8VKOEVCpBsEohntslwBurHrxS7K5iNxMRuUqLa278/f2h1WoBAJGRkTh69CgSExNRWlqKyspKpzeQiNrOr0dy8N7GVPwS7INreoQAACyCda2oULUSqfnW3/1wjbVLKlStELuqQtUKBKoU+HH21UjL16FXeP01p4iI2kKLg5uRI0di/fr1SExMxB133IHHH38cmzZtwvr16zF27NjWaCMRtZGtpwsAWLM1p/204vYtp/Lx9vrTYj2Nvd4mRK0EUOawTeEhE5dWICJyhRYHN0uXLoVeb/1L7bnnnoOnpyd27NiB2267Dc8//7zTG0hEbcNiEfCXLbixCNbVv+0+2ZYhBjYAMLCLHwBrtsYuxLfmMRGRK7U4uAkICBAfS6VSzJs3z6kNIiLXOJ5TjsKKmqkdjOaaYMbe9fTgyDjce2WMuIRCqG/NiKmQOqOniIhcpcUFxcnJyVi5ciXKy8tboz1E5CL2LqmmJPcKdVgbKqRW5qZ2FoeIyJVaHNz06dMH8+fPR1hYGO644w78+OOPMJlMrdE2ImpD21ILAUAc7QTAYdFLuYcU/aMd57KyZ2u8PGVQKS5pTlAiIqdrcXDz7rvvIisrCz/88AN8fHwwdepUhIaG4sEHH8TWrVtbo41E1ELniythqtWt1Byn8qwFxHcOjha3XdG1ZnK9gdF+UHjIHM7pGeYLD6kEfSLUXDiXiNqNS1pbSiqVYty4cVi5ciXy8vKwfPly7N69G2PGjHF2+4iomezBzL5zJRixeDOeX3u02ecWVhhQrDNCIgGuTwwTtycEqxBj64Ya2jWg3nnhGi9seXo0Vt4/5DJbT0TkPJeVR87NzcWqVavw5Zdf4vDhwxgyhP/AEbnCiZxyTPxgB/45Kl6cg+Z4Tk1dXLnehLwyPbqFNjz3TGqedcK+aH9vhGu8EOyrQIHWgJhAH3grPPDp9nTc1D+iwXObu8wCEVFbaXFwU15ejv/973/4+uuvsWXLFsTFxWHKlClYvXo14uPjW6ONRHQRe8+VoMpkRsrZQozvY828FOtqRj498tV+/J1aiA1zRyIhxBrg/J1agG2phbAIgjhHjX35hCFdA/Dr4RwM6OKHQV388dS4Hlz7iYg6jBYHN6GhofD398ekSZOwaNEiDB48uDXaRUQtUGoLZCqNZlQarUslFOmsK3gLgoCDmaUAgLQCHRJCfLF6Tyae/V/NmlH+3p4AIGZ23ry9P+aM7SY+Z2BDRB1Ji4Obn376CWPHjoVUeknlOkTUCkoqrSMWKwzV0BmqAVhX5640VsNgskBr21ZWZUJWaRVe/uUEACAuyAdnC3Xi+fbMjZdc1mgXFhFRe9fiCOXaa69lYEPUzpRW2jI3hprMDQAUVRiRWVyz5lt5lQmLfjuBCkM1kmL8sWKaY+a1W6gKREQdHaMUIjdQWmXNvOiM1ag0Vovbi3SOwU1ZlQlHs6xrQc29tjvig1XoU2sdqPhgBjdE1PExuCFyAyWVNTU3OkNN5qZYZ6gX3NgLje1FxDf2CwcARPl7wYcT8RGRG+C/ZERuoNRWM2O2CA6jpAorjMgsqgluiiqMKNdbMzsBPnIAwKTB0dhyqgA39A0DEZE7YHBD5AbsmRsAKKgwiI+L63RLZRTpAAASCaDxso6QClQp8O1Dw9qopUREra/F3VKPPfYY3nvvvXrbly5dijlz5jijTUTUAhaLgLKqmvXdCrRNBDeF1uDGz8uTw7uJyG21OLj53//+h6uvvrre9quuugpr1qxxSqOIqPnK9SYIQs3z2oFObpke2WVV4nOdbSSVv61LiojIHbU4uCkqKoJGo6m3Xa1Wo7Cw0CmNIqLms89R05DDF0odAh+7AG8GN0Tkvloc3CQkJGDdunX1tv/++++Ii4tzSqOIqPlq19vUlWErJrbX19gxc0NE7qzFBcVz587F7NmzUVBQIK4CvnHjRrz11ltYsmSJs9tHRBdR1kTmxu7KuAD8cSxPfM7MDRG5sxYHN/fffz8MBgNeeeUVvPzyywCA2NhYfPjhh5g6darTG0hETWsqc2N3U78IbDqZD5PZ2kfFzA0RubNLGgr+8MMP4+GHH0ZBQQG8vLygUnFWUyJXaarmxm5Uj2BovOQotA0TD/DxvMgZREQd12XNUBwcHOyUwOb9999HbGwslEolhg4dit27dzd67Pfff4/BgwfDz88PPj4+GDBgAL744ovLbgNRR1NYYcC9H+/Cd3vP19un8Kj51e4a5AO10hMar5q/ZfzZLUVEbqxZmZtBgwZh48aN8Pf3x8CBAyGRND4/xv79+1vUgNWrV2Pu3LlYtmwZhg4diiVLlmD8+PE4deoUQkJC6h0fEBCA5557Dj179oRcLscvv/yC6dOnIyQkBOPHj2/RaxN1ZB9vS8ffqQ2PUFQpPGCotnZXXRUfCMCxqDiA3VJE5MaaFdxMmDABCoUCAHDLLbc4tQFvv/02Zs6cienTpwMAli1bhl9//RWffPIJ5s2bV+/40aNHOzx//PHH8dlnn2Hbtm0MbqhTqTvEW+kphd5kAQB4K2S458pu2HwqH0+O6wHAMbhhzQ0RubNmBTcLFy4EAJjNZlxzzTXo168f/Pz8LvvFjUYj9u3bh/nz54vbpFIpkpOTkZKSctHzBUHApk2bcOrUKbz++uuX3R6ijkRvMjs8j/TzQlqBdQZiH7kHnri2O564tru43yFzw24pInJjLSoolslkGDduHE6cOOGU4KawsBBmsxmhoaEO20NDQ3Hy5MlGzysrK0NkZCQMBgNkMhk++OADXHvttQ0eazAYYDDUTEdfXl5+2e0mag9K64ySiqgV3HjLZfWOZ+aGiDqLFhcU9+3bF2fPnm2NtjSbr68vDh48iD179uCVV17B3LlzsWXLlgaPXbRoETQajfgTHR3dto0laobSSiOyS6sufmAtxXVGSXUJ8BYfe8vr/92isWVrZFIJ1EqumUtE7qvFwc2///1vPPXUU/jll1+Qk5OD8vJyh5+WCAoKgkwmQ15ensP2vLw8hIWFNd5oqRQJCQkYMGAAnnzySdx+++1YtGhRg8fOnz8fZWVl4s/58/VHlhC52u3LUjD2ra0o1198WLddic6aufnnqHj8+5a+uCo+SNzXVObG31ve5KAAIqKOrsV/vt1www0AgH/84x8O/0AKggCJRAKz2dzYqfXI5XIkJSVh48aNYqGyxWLBxo0bMXv27GZfx2KxOHQ91aZQKMRiaKL2yGwRcCa/AgBwobgKvSOaNweNffK+cX1CMaiLPzafyhf3+SgayNzYghvOcUNE7q7Fwc3mzZud2oC5c+di2rRpGDx4MIYMGYIlS5ZAp9OJo6emTp2KyMhIMTOzaNEiDB48GPHx8TAYDPjtt9/wxRdf4MMPP3Rqu4jaSoW+Wnxct46mruzSKjz7v8O476pYMXNjLw72qdUV1VDmJiHEOidVtxDfy24zEVF71uLgpmvXroiOjq6X1hYE4ZK6fCZNmoSCggIsWLAAubm5GDBgANatWycWGWdmZkIqrek90+l0mDVrFi5cuAAvLy/07NkTX375JSZNmtTi1yZqD8qqarqiSqua7pbacCIPf6cWQm8yQ2e0ZkntxcE+ipqApqHMzYBoP/z22AjEBHrX20dE5E4uKbjJycmpN8FecXExunbt2qJuKbvZs2c32g1Vt1D43//+N/7973+3+DWI2qvadTalF1lKoURn3X80y1rfVrs4+GKZGwDoHaG+rLYSEXUELS4ottfW1FVRUQGlUumURhF1JrUzNxdbBLO0yrq/yjbHjb+3p/j76F0rc9NYcENE1Bk0O3Mzd+5cAIBEIsELL7wAb++a1LbZbMauXbswYMAApzeQyN2V1wpuyi7SLVU3s1N7jSjHzA2HehNR59XsfwEPHDgAwJq5OXLkCOTymn9U5XI5+vfvj6eeesr5LSRycw41N41kbiwWAVKppN7+2pPxeXnKIJFYl2WoXX9DRNTZNDu4sY+Smj59Ot59912o1ey7J3KG2jU3JQ3U3BzILME9/92FJ8f1qFdwXHsZBalUAm9PGXRGMzM3RNSptbjm5tNPP4VarcaZM2fwxx9/oKrKOquqUHcVPyJqltqZm7IGgptfD+dAZzRj86n8evv968xZ462oX1xMRNTZtDi4KS4uxtixY9G9e3fccMMNyMnJAQA88MADePLJJ53eQCJ3V15Va56bqvrdUgfPlwIACrSGepkb/zoLYEb5ewEAIvxY3E9EnVeLg5s5c+bA09MTmZmZDkXFkyZNwrp165zaOKLOwHG0lGPwYjJbcCSrDACQV66vV3MTUGcBzA+mDMK3Dw1DXLCqlVpLRNT+tTh3/eeff+KPP/5AVFSUw/Zu3brh3LlzTmsYUWdRu+amrNLkMN3CqVwtDNUWAA3X49TN3IRrvBCu8WrF1hIRtX8tDm50Op1DxsauuLiYazgRXYLamRuj2YIqkxlFFUbM+/4wGiplk0klMFusO+rW3BAR0SV0S40YMQKff/65+FwikcBisWDx4sW45pprnNo4os6gvE4dTUmlCT8ezML2M0XYkVZU7/gQXwX8vO2LYPIPCiKiulqcuVm8eDHGjh2LvXv3wmg04plnnsGxY8dQXFyM7du3t0YbidxaWa2CYsA6103dyfzs89cA1tW9Hx3TDQcyS5AYqWmrZhIRdRgtztz07dsXp0+fxvDhwzFhwgTodDpMnDgRBw4cQHx8fGu0kcit2WtufGxLJpRVmlCsqwluYgO9cWXXQPG5n7cn7h7aBW/c0R8yaf2lUIiIOrtLmgxDo9Hgueeec3ZbiDodvckMo61gODrAGydztSipNKFYZwAAvDYxEZOuiMZzPxxFyllrF5Wfl7zR6xER0SUGN3q9HocPH0Z+fj4sFovDvn/84x9OaRhRZ2Cvt5FKrHPUnMzVorTKiGKddch3oEoBiUSCYFVNbY293oaIiBrW4uBm3bp1mDp1KgoLC+vtk0gkMJvNTmkYUWdgr61Re3mKw7pLK00osgU39nlsQtQ1wY2GwQ0RUZNaXHPz6KOP4o477kBOTg4sFovDDwMbopax19uolZ5iRqa00oiiClvmxh7c+NbMOMxuKSKiprU4uMnLy8PcuXMRGhraGu0h6lTsmRuNlyf8bJmb7DI9qkzWPxQCVPbght1SRETN1eLg5vbbb8eWLVtaoSlEnY99XSm1lwfCNdbszJEL1uUWPGUS+NoWwqzdLeXnxeCGiKgpLa65Wbp0Ke644w78/fffSExMhKen4z+0jz32mNMaR+TuamduYgJ9AACZxZUArPU29mUYglQKca4bP292SxERNaXFwc0333yDP//8E0qlElu2bBH/8QWsBcUMbogcPbf2CIoqjHhv8kDIPRyTpQVa65Bvf285ugb5OOyrPfuwp0yKcLUS2WV6hywOERHV1+Lg5rnnnsNLL72EefPmQSptca8WUaei1Zvw1a5MAMDXu87hvqu7Ouw/Z8vSdAnwhr+3J3yVHtDqrV1VgXVW/H7rzgFIL9Qhnit+ExE1qcXRidFoxKRJkxjYEDVDbplefLz8r7PQmxxHFGYW6QAAMYE+kEgkiA2syd4E1AluhsUH4u6hXVqxtURE7qHFEcq0adOwevXq1mgLkdvJrhXc5JTp8d3e8yirNOG130/iQkmlmLmJCfR2+C9QP7ghIqLmaXG3lNlsxuLFi/HHH3+gX79+9QqK3377bac1jqijyy2rcni+M70YJZUmLNuahlO55SittBYUdwmwBjW1Mzd1u6WIiKh5WhzcHDlyBAMHDgQAHD161GFf7eJiIgKyS62ZmyCVHIUVRmQWVUJm+z3ZerrAtk8BH9uQb4fMjYrBDRHRpWhxcLN58+bWaAeRW7LX3AyNC8Svh3NwrkgH+0LeFsH639oBTWwQMzdERJeLVcFErSjb1i01tGsAAKBcX40TuVqHY2oHN441NxzyTUR0KRjcELUie+YmLkglLqFgrLY4HBMTUJOtCVYpoFZaE6r2GYuJiKhlWtwtRdQZFVUYIPeQwlfZsqUPcmzBTZhGidhAH+TbJu2rrXa2RiKR4L3JA5Fdqkd0gHe9Y4mI6OKYuSG6iKzSKoxcvBk3/2cbBEFo9nlavQkVBuuEfOEaJbrUCmJqZ2VqbweA0T1COJ8NEdFlYHBDdBGv/noCOqMZGUWV0BnNFz/Bxp61USs94KPwQEytTMzIbsHoGeaLIJUC3UN9nd5mIqLOjN1SRE04mlWGX4/kiM/Lq0xQKZr3a2MPbiL8vAAAMbVGQnUN9sELN/eG2SI0+3pERNQ8zNwQNeG7vecdnttX8W6OnFLrSKkwWxdU7cxNbKA3VAoPaLxaVsNDREQXx+CGOh1jtQV3Lk/Bgh+PXvTYugXAtYMbQRAw++v9mLPqQIO1OCdtQ77DNbbMjcOQb596xxMRkXMwuKFOJzVfi93pxVi1+/xFC4SLdUaH57WDm8IKI345nIMfDmaLXVDbzxRi+Oub8N+/z+JbW9ZnXO9QAICftxzD4gLRPVTFlb2JiFoRO/up0ymwZWOMZgt0RnOTNS/2tZ88ZRKYzIJDcFNQK6tzIqccEX5e+GZ3Ji6UVOHfv54AAPSNVGN0j2DxuK9nDoUgAFIplyohImotzNxQp1M7KCmpk5mpq7jSut/ejVTukLmpuc7JXC0EQcDu9GKH82df081hzTWJRMLAhoiolTFzQ51OQa2gpEhnbHSyPEEQxOAnNtAHZ/IrGg1ujueUI7O4EvlaAzxlEtyeFAVAInZJERFR22FwQ51OczM3FYZqVNtWt+waZA2AGuuWOplTLmZt+kf5YdHEfk5tMxERNR+7pajTqR2UFDUR3JTorIGMl6cMIb7W4dxljWRu0gt1+Cu1EABwhW2RTCIicg0GN9Tp1A5Kmsrc2OttAnzk4nw0dUdL2VkE4OdD2QCAIbEMboiIXInBDXU6zc7c2IIbfx9PqL2sPbjl+mpxf+0gyU7pKcWgGH9nNZWIiC4BgxvqdBqquTlfXImlm1IdMjP2ff7ecqgbyNzYr5MYqQEAyKQSfDglibMOExG5GAuKqVPRm8wO2Rd719M7G07j+/1ZkEmleHh0vHVfreCm4W4pa3Dz3I29kF6oQ3KvUAT7KtrkfRARUeMY3FCnUrcryR7AHM8uBwCcztOK++wT+DVUc2O2COK5ccE+uDIusHUbTkREzcbghjqVgjprRZXojDCZLUgrqAAAnMmvEPfZszq1MzfGagv0JjO0+mpYBEAiAQK85W3UeiIiag7W3FCnYh/h5COXAbAWFJ8t0MFkts5nk1ZQIa43Jdbc+HjCR+4B+8TC5VUmMUgK8JbDQ8ZfIyKi9oT/KlOnYg9Kuof5ArB2Mx3LLhP3VxrN4iKYJbUyN1KpxKGo2N69xRobIqL2h8ENuaXUPC3eXn8aepPZYbs9uEkIVsG+5NOus47rQS3dfAYjF2/GTtv2AB9rt5OmgeAmSMXghoiovWHNDbmlf/96AltPF0Ct9MCMEXHi9oIKa1YmTKOExssTpZUm7Dhb6HDu17syHZ77eVuDmoaDG9bbEBG1N8zckNsRBAGHLpQCAFLSihz2FWqtXU1BKoWYkTlfXAUASGpk8r26mZtyvQmpedbCY3ZLERG1PwxuyO1klVaJw7h3pxfDbFv8EgCKdNaMS6BKXm+U0w2J4Q1ez992nFppDW6OZZXjh4NZAIAxPbnqNxFRe8PghtzO0ayaAmGtoVqcwwaoWW4h0EchdjcBwJCuAQ6Zm2X3JCFCo0RipAZKT+vIKo3t+JU7MmAyCxjRLQjD4jm/DRFRe8OaG3IbZ/K1+PN4HooqHNeL2nm2CIlR1iUS7BPvBarkGNsrFClpRZhyZQweH9sNHjIJ+kaqEeCjwPg+oRjVPRhyj5r4f0L/CPx2JEfMCj09vkcbvTMiImoJiWCf1KOTKC8vh0ajQVlZGdRqtaubQ040aXkKdqUXQyIBBAGIDfRGRlElVAoP+Hl74r/TBuO6JX8DAPY+n4wglQKCIEBiHzbVDGVVJnyzOxNBKgVuT4pqrbdCRER1tOT7m91S5BbKKk3Ye64EgDWwAYAHR1rXiKowVONCSRW+3XMBgHVWYXsdTUsCG8BaVPzPUfEMbIiI2jEGN+QWtqYWOBQOy6QSTBwUiRVTByPSzwtATS2Ov7ccMmnLghoiIuo4GNyQW9hyMh8AcH3fMAT6yHFNjxAoPWW4tneouMq3fSZi+9BuIiJyTywopg7PbBGw5XQBAGDaVbFYctcAyGut9xThpwQA6IzW2YoDGdwQEbk1BjfU4Z3MLUexzghfhQeSYvzhWWchy3CNl8PzQM4qTETk1tgtRR1eRmElAKBbqKpeYAMAEXWDGx/OKkxE5M4Y3FCHd6HEGtxEB3g3uF/t5QFvuUx8zpobIiL3xuCGOrwLJda1oaL8vRrcL5FIEK5Ris/ZLUVE5N4Y3FCHd96WuYnybzhzAwARfjWBD7uliIjcG4Mb6vDsmZvoJoKb2pkbdksREbk3BjfUoQmCINbcNNYtBTiOmGK3FBGRe2NwQx1akc4IvckCiQQI91M2elxErX2c54aIyL21i+Dm/fffR2xsLJRKJYYOHYrdu3c3euyKFSswYsQI+Pv7w9/fH8nJyU0eT+7tfLE1axOmVkLhIWv0OHvmRiIB/LwZ3BARuTOXBzerV6/G3LlzsXDhQuzfvx/9+/fH+PHjkZ+f3+DxW7ZsweTJk7F582akpKQgOjoa48aNQ1ZWVhu3nFrbmXwtvth5TlwzqqzKhOuW/IVFv58Qj7nYSCm7uGAfSCTWuhyuK0VE5N5cHty8/fbbmDlzJqZPn47evXtj2bJl8Pb2xieffNLg8V999RVmzZqFAQMGoGfPnvjvf/8Li8WCjRs3tnHLqbXd8O42vPDDUXyekgEA2J1ejJO5Wny6PQNVtqUUaoKbxouJ7fs/v38IVkwd3KptJiIi13NpcGM0GrFv3z4kJyeL26RSKZKTk5GSktKsa1RWVsJkMiEgIKDB/QaDAeXl5Q4/1DEYzRYAwO9HcwEAOWXWQMZYbcHOs0UAak3gd5HMDQCM6BaMHmG+rdFUIiJqR1wa3BQWFsJsNiM0NNRhe2hoKHJzc5t1jWeffRYREREOAVJtixYtgkajEX+io6Mvu93UtvLL9QCAnDK9uG3r6QLsOFOInw9lAwC6BPq4pG1ERNT+uLxb6nK89tprWLVqFdauXQulsuGRMvPnz0dZWZn4c/78+TZuJV2uXHtwU1olblt7IAtTP9mNcn01BkT74YbEMFc1j4iI2hmXrgoeFBQEmUyGvLw8h+15eXkIC2v6y+rNN9/Ea6+9hg0bNqBfv36NHqdQKKBQcEbajkYQBPGx3mSBxSIgu1bmpqzKBAC4qV843ryjP5SejY+UIiKizsWlmRu5XI6kpCSHYmB7cfCwYcMaPW/x4sV4+eWXsW7dOgwezAJRd1RlMjs8zyqtQq4tuPHz9gQA3NgvHEsmDWBgQ0REDlyauQGAuXPnYtq0aRg8eDCGDBmCJUuWQKfTYfr06QCAqVOnIjIyEosWLQIAvP7661iwYAG+/vprxMbGirU5KpUKKpXKZe+DnKtCX+3w/Ex+hRjcfHTvYOSV63Fd3zB4yDp0zyoREbUClwc3kyZNQkFBARYsWIDc3FwMGDAA69atE4uMMzMzIZXWfIF9+OGHMBqNuP322x2us3DhQrz44ott2XRqRVqDY3CzK70YRrN1JuIB0X6QezCoISKihrk8uAGA2bNnY/bs2Q3u27Jli8PzjIyM1m8QuVzdzM22MwUAgCCVgoENERE1id8S5HRmiwCt3lRve2GFAfszS5p1jYo6mZujWdb5iSI0ja8fRUREBDC4oVbw0Bf7MOSVjcjX6h22z/56PyZ+sAOncrUXvYbWlrkJUyshqbVaQu3VvYmIiBrC4Iacbn9mCapMZpzJr3DYfr7YOk/NiZyLzxJtz9z0CPPFmB4h4vYwZm6IiOgiGNyQU5ktAkorjQAAncFxOLfOaA1YskqrsDejGEs3paKssn73FQBU2Lq1VEoPTL0qVtyu8fJshVYTEZE7aRcFxeQ+yqtMsC3iDV2duhn78wslVfjp4FGcytPi3Y2peOkffXHrwEh4yWvmq7FnbnwVHhiRECRujw/hcH8iImoaMzfkVEU6o/i4dlGwodoMk9ka9Zwr0uFUnrXuxmQW8H9rj2DE4k3IqrW8gn0ouErhAalUgvVPjMTzN/bCjYnhbfE2iIioA2NwQ05VUlkT3OgM1TBUm5FfrnfoorKPmPKQSvD8jb0QpJKjsMKIv08XiMfYh4KrlNbkYrdQX8wYEQeZtFZ1MRERUQMY3JBTFescg5uHvtiHq17bhNS8mhFSepMFgLVYeMaIOEwcFAUAOJZdU2hcUStzQ0RE1BIMbsipShy6pcw4kVOOaouAQxdK6x0bH2ytn+kToQYAHMsuqznXlrnxVTK4ISKilmFwQ05VVCdzY1+9O7tUX+/YusHNiRwtzLZq5JqaG46OIiKiluGfxeRUtTM3xZVGsQvKvuhlbfEhPgCArkEqeHnKUGUy46td55BVUiUOJ1cxc0NERC3Ebw5yquJaBcU5ZVUNPrazZ25kUgl6hftif2YpFvx4zOEY1twQEVFLsVuKnKp2QXHtrqjsOpkbiQToGuQjPu8ToWnweqy5ISKilmJwQ07l0C1V63FhhcHhuEg/Lyg9aybt6xupbvB6zNwQEVFLMbghp6rdLVWbYJu1uE+EGhIJMCwu0GH/tb3D0D9KgwkDIhy2s+aGiIhait8c5FTFFQ0HN3ZXxAbgs/uHwN9b7rA9wEeOH2cPh7Hagh8PZovbVXJ+RImIqGWYuSGn0ZvM0BnNTR6jUnggSKVodKZhuYfUoc5GyhmJiYiohRjckNOUNrLCd20+zaihiQ30uegxREREjWFwQ05jLyD292584j0fhazRfXaxQQxuiIjo0jG4IaexBzfBvgooPBr+aPk0o4bm6XE94OUpw11XRDu1fURE1DmwWpOcxj5Syt9bjqIKIwzV9YuLm9Mt1SXQGwcWXNtogERERNQUfnuQ02SVWGchDtMoGw1imjtvjdJTBomExcRERNRyDG7IaTIKdQCsBcGNBTfNqbkhIiK6HAxuyGkyiqzBTdcgH/g2GtywJ5SIiFoXgxtymnNFlQCAmEBvhwyNvFbtDIMbIiJqbQxuyCmqjGbkllsXx+wa5NgtFeXnJT7mjMNERNTaGNyQU5wrtnZJabw84ectdygcjgrwFh+z5oaIiFobgxtyCrGY2DYBnz1zI5dJEaxSAAAUHlJ4yPiRIyKi1sVvGmqRCkM18rX6etszbPU2sYHWLI09uFF7eULj5emwjYiIqDUxuKFmEwQBd32UgpGLN+PIhTKHfeeKaoaBA4DK1v2k9vKA2ssa1LBLioiI2gKDG2q2U3laHM0qh95kwdxvD0JvMkOrN+GFH45i88kCAEBskGPmRuPlCbXSlrlhMTEREbUBfttQs60/lic+Ts2vwIdb0hDsq8AXO8+J27uF+AKwjpgCgLggFdS2bqnmzk5MRER0OfhtQ822/oQ1uBkc44+950qQklaEflEaAMCgLn64LSkKfSOtz4fFBeKXR4cjLtgHRRVGRPp54bq+YS5rOxERdR4MbqhZcsv0OHyhDBIJ8PDoeDzw2V5kFOmg8bZmZW4ZGIkpQ2PE4yUSiRjoeAd4YPu8MS5pNxERdT6suaFm2Xo6HwAwMNoPg2MCAAD5WgNO5WoBAF1qzWVDRETkSgxuqFlS8yoAAAOi/aHx9oS/LWOTWWwdAs7ghoiI2gsGN9Qs6bZJ+roGWwuFY2xDvgFAIgEi/b0aPI+IiKitMbihZkm3r/htC2rso6EAIFythMKDc9gQEVH7wOCGLqrabMF5W/dTTeamphuqSyC7pIiIqP1gcEMXlVVaBZNZgMJDinC1EoBj5ob1NkRE1J4wuKGLstfbxAb6QCqVAHCsuWFwQ0RE7QmDG7ooMbgJqgliutYObmo9JiIicjUGN3RRGWJwUxPEaLw9EegjB+AY6BAREbkaZygm6E1m/Hk8DyO7BcHPW15v/1lbcBMX5BjEvDoxESdztOgbqW6TdhIRETUHMzeE7/aex2PfHMA760/X23euSIdj2eUArDU3tY3vE4bHk7tBIpG0STuJiIiag5kbwrki6zDvI1llDtvXHc3B098dhtZQjTC1UlwrioiIqD1jcEMo0hkBAKn5FRAEARKJBEs3peLNP62ZnKQYf/xn8kD4KPhxISKi9o/fVoTCCgMAQKuvRr7WAH9vOd7dmAoAmDmiK565ric8ZezBJCKijoHBDaHYlrkBgDP5FQjwkcNkFuCr9MD/3dCLNTVERNShMLghFFXUBDepeVpxxFTPMF8GNkRE1OGwr8ENVRiq8cOBLGj1poseKwgCinQG8XlqfgVO5moBAD3CfFutjURERK2FwY0b+uivs5iz+iD++3f6RY8t11fDZBbE59bgxjr0u0cY568hIqKOh91SbuhAZgmAmmUTmlJUYXB4npZfAbmHNebtxcwNERF1QMzcuKETOdZupbxyPUorjfh4W7o4IqouezFxiK8CEol1WHhOmR4A0J3BDRERdUAMbtxMvlYvBjJ55Xqs3JGBl385jmVb0ho8vtBWTBzl74WxPUPE7RovT6iVnq3fYCIiIidjt5SbsWdtACCv3IAz+RUAIBYJ2xVoDXh7/Wn4yGUAgECVAq/f1g+DXl4PwHGRTCKijkQQBFRXV8NsNru6KdRCnp6ekMlkl30dBjdu5rhtHSgAqDKZcTzH+vxsQYXDcR9vS8c3uzPF50EqOQJ85Ph59nC88ttxPHJNQts0mIjIiYxGI3JyclBZWenqptAlkEgkiIqKgkqluqzrMLhxMydyyh2eny2wFhVnl+lRaayGt9z6v/xYtuM6UgE+1rltEqM0WPXgsDZoKRGRc1ksFqSnp0MmkyEiIgJyuZxzdXUggiCgoKAAFy5cQLdu3S4rg8Pgxs0crxPc1Ha2QIe+kRoIguCQ4QGAQB9FazeNiKhVGY1GWCwWREdHw9vb29XNoUsQHByMjIwMmEymywpuWFDsRk7klIvdTz1C6490OmsbGl6gNYiLZdoFquSt30AiojYglfKrraNyVqaNnwA3UWGoxiNf7YdFAMb0DEFilKbeMfbA51gD2Z0gFTM3RETkHhjcdFBr9l3AL4ezxecr/jqLs4U6hKmVePOO/ghV1w9W0mz1N/YuqZjAmrStvzczN0RE5B4Y3HRA2aVVeOq7Q5iz6iAqDNUAgJSzRQCAx5O7IcBHjjC1Ujw+zjas2565sdfl3JEUJR4T6e/VJm0nIiJqbSwo7oCOZFlHOlVbBJzO0yIxUoPDF0oBAFfE+gMAQmoFN6N6BONsoQ5pBRX4+VA29p+zLs/QL8oPW58ejUqjGRovTthHREQ1TCYTPD075ncDMzcd0LGsmmHcJ3O0OJFTDr3JArXSA3FB1rkBamduro4Pgq/CA3qTBY9+cwA5ZXrIpBL0iVAjJtAHvcK5QCYRkautW7cOw4cPh5+fHwIDA3HTTTchLa1mdvkLFy5g8uTJCAgIgI+PDwYPHoxdu3aJ+3/++WdcccUVUCqVCAoKwq233iruk0gk+OGHHxxez8/PDytXrgQAZGRkQCKRYPXq1Rg1ahSUSiW++uorFBUVYfLkyYiMjIS3tzcSExPxzTffOFzHYrFg8eLFSEhIgEKhQJcuXfDKK68AAMaMGYPZs2c7HF9QUAC5XI6NGzc647Y1iJmbDuhorWHcp3LLYay2zsI5KMYfUqm10jy0VnATG+SD1Q8Nw9e7z2FvRgl6hasxcVAkAllETERuThAEVJlcM1Oxl6esRaN/dDod5s6di379+qGiogILFizArbfeioMHD6KyshKjRo1CZGQkfvrpJ4SFhWH//v2wWCwAgF9//RW33nornnvuOXz++ecwGo347bffWtzmefPm4a233sLAgQOhVCqh1+uRlJSEZ599Fmq1Gr/++ivuvfdexMfHY8iQIQCA+fPnY8WKFXjnnXcwfPhw5OTk4OTJkwCAGTNmYPbs2XjrrbegUFi/c7788ktERkZizJgxLW5fczG46YCO1MrcnMjVoqTSBABI6uIvbg/2VSBMrYTJbEF0gBcUHjL8+5bENm8rEZErVZnM6L3gD5e89vF/jRcnTm2O2267zeH5J598guDgYBw/fhw7duxAQUEB9uzZg4CAAABAQkLNTPKvvPIK7rrrLrz00kvitv79+7e4zXPmzMHEiRMdtj311FPi40cffRR//PEHvv32WwwZMgRarRbvvvsuli5dimnTpgEA4uPjMXz4cADAxIkTMXv2bPz444+48847AQArV67Efffd16oTLLq8W+r9999HbGwslEolhg4dit27dzd67LFjx3DbbbchNjYWEokES5YsabuGuoDeZMZ9n+7GlP/uxJ/HcnE0qwzphToUaGtW+D6ZU459thqaQTE1wY1MKsHvj4/An0+MhMLj8tfpICKi1pWamorJkycjLi4OarUasbGxAIDMzEwcPHgQAwcOFAObug4ePIixY8dedhsGDx7s8NxsNuPll19GYmIiAgICoFKp8McffyAz07p8z4kTJ2AwGBp9baVSiXvvvReffPIJAGD//v04evQo7rvvvstua1NcmrlZvXo15s6di2XLlmHo0KFYsmQJxo8fj1OnTiEkJKTe8ZWVlYiLi8Mdd9yBJ554wgUtblufp2Rgy6kCAMD2M0UO+2IDvXG+pArl+mqU66vhIZWgf7SfwzH+PhzeTUSdm5enDMf/Nd5lr90SN998M2JiYrBixQpERETAYrGgb9++MBqN8PJqekTrxfZLJBIIguCwzWQy1TvOx8dx0eQ33ngD7777LpYsWYLExET4+Phgzpw5MBqNzXpdwNo1NWDAAFy4cAGffvopxowZg5iYmIuedzlcGty8/fbbmDlzJqZPnw4AWLZsGX799Vd88sknmDdvXr3jr7jiClxxxRUA0OB+VzJUmx0yKpdLbzLj/c3WQrLRPYJxJr8CWn01yqqsH8b+0X4wCwLOF1cBAO67KhYqBXsZiYhqk0gkLeoacpWioiKcOnUKK1aswIgRIwAA27ZtE/f369cP//3vf1FcXNxg9qZfv37YuHGj+H1aV3BwMHJycsTnqampzVpcdPv27ZgwYQLuueceANbi4dOnT6N3794AgG7dusHL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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10cac05a-3465-44d2-a6c4-886155bea207",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44838feb-d270-45ae-978e-dd690dda0873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c388d09c-45de-4164-967b-d806de19c6d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd6db00b-3f9c-47ad-a85b-3563330cd089",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43da28a5-aa6e-430f-bbfc-0c5c892963f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d5c2ced-8f71-424b-838b-be0b6b1dc218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "468a557f-50d8-4a23-8601-2caae9d7331f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb4a33f1-94f8-43a1-9328-db531554561e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15fdde62-149d-43b7-a205-fd0edbb60aba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66c0a656-acfc-4061-b2d3-73a933703ff2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b5dce62-6d44-4282-b5ba-0352fc3fbcbe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d10f4d8d-ce05-4465-9d7b-23aed749707d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62121d33-ca98-491d-bb17-576c2741fb8f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c6504c5-a45d-433a-b945-acd895a881af",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1be750c8-fa0e-4cad-b51a-5fe93d7cf37f",
   "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
}
