{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2326]\n",
      " [   1   64]\n",
      " [   2   42]\n",
      " [   3   69]\n",
      " [   4  113]\n",
      " [   5  181]\n",
      " [   6  332]\n",
      " [   7  559]\n",
      " [   8  831]\n",
      " [   9 1417]]\n",
      "[[   0 1451]\n",
      " [   1 2695]\n",
      " [   2   62]\n",
      " [   3   46]\n",
      " [   4   55]\n",
      " [   5   96]\n",
      " [   6  195]\n",
      " [   7  331]\n",
      " [   8  491]\n",
      " [   9  868]]\n",
      "[[   0  856]\n",
      " [   1 1618]\n",
      " [   2 2310]\n",
      " [   3   67]\n",
      " [   4   60]\n",
      " [   5   54]\n",
      " [   6  108]\n",
      " [   7  213]\n",
      " [   8  299]\n",
      " [   9  503]]\n",
      "[[   0  526]\n",
      " [   1  979]\n",
      " [   2 1487]\n",
      " [   3 2450]\n",
      " [   4   56]\n",
      " [   5   31]\n",
      " [   6   55]\n",
      " [   7  125]\n",
      " [   8  192]\n",
      " [   9  316]]\n",
      "[[   0  285]\n",
      " [   1  562]\n",
      " [   2  853]\n",
      " [   3 1465]\n",
      " [   4 2324]\n",
      " [   5   51]\n",
      " [   6   43]\n",
      " [   7   64]\n",
      " [   8  106]\n",
      " [   9  171]]\n",
      "[[   0  198]\n",
      " [   1  362]\n",
      " [   2  527]\n",
      " [   3  846]\n",
      " [   4 1371]\n",
      " [   5 2166]\n",
      " [   6   54]\n",
      " [   7   38]\n",
      " [   8   59]\n",
      " [   9  101]]\n",
      "[[   0  121]\n",
      " [   1  224]\n",
      " [   2  332]\n",
      " [   3  550]\n",
      " [   4  870]\n",
      " [   5 1349]\n",
      " [   6 2282]\n",
      " [   7   71]\n",
      " [   8   48]\n",
      " [   9   66]]\n",
      "[[   0   59]\n",
      " [   1  124]\n",
      " [   2  176]\n",
      " [   3  339]\n",
      " [   4  495]\n",
      " [   5  737]\n",
      " [   6 1495]\n",
      " [   7 2517]\n",
      " [   8   58]\n",
      " [   9   40]]\n",
      "[[   0   40]\n",
      " [   1   79]\n",
      " [   2  111]\n",
      " [   3  177]\n",
      " [   4  304]\n",
      " [   5  491]\n",
      " [   6  820]\n",
      " [   7 1488]\n",
      " [   8 2389]\n",
      " [   9   52]]\n",
      "[[   0   61]\n",
      " [   1   35]\n",
      " [   2   58]\n",
      " [   3  122]\n",
      " [   4  194]\n",
      " [   5  265]\n",
      " [   6  534]\n",
      " [   7  859]\n",
      " [   8 1378]\n",
      " [   9 2415]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 2])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:54:12 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:54:12\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1f1a10370b8f48b9b4f80d53d05b5514",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:38:02 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3484</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:38:02\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3484\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">76090560</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m76090560\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "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=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.96</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.96\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABpTklEQVR4nO3dd3yT1f4H8E+SZnWkg+4BbdmzLEFkCggqLnAgegVBEEQUxQFcFRw/L46rF70qICrovSooV9yCgIAClV3Zq7S00L3TtE3S5Pz+SPO0oS200CRt+nm/Xn3ZPs+T5OShmA/nfM85MiGEABEREZGHkLu7AURERERNieGGiIiIPArDDREREXkUhhsiIiLyKAw3RERE5FEYboiIiMijMNwQERGRR2G4ISIiIo/CcENEREQeheGGiJxq27ZtkMlk2LZtm3TswQcfRGxsrNva5ElefPFFyGQydzeDqFlhuCFq5o4ePYq//e1viIqKglqtRmRkJO6//34cPXrU3U1zug8++ACrV6926mscO3YML774IlJTU536Oq70j3/8A99++627m0HkNgw3RM3YN998g759+2LLli2YOnUqPvjgAzz00EPYunUr+vbti/Xr17u7iU7lqnDz0ksvMdwQeRAvdzeAiOqWnJyMBx54APHx8fj9998REhIinZs7dy6GDh2KBx54AIcOHUJ8fLzL2mUwGODj4+Oy12sJeE+Imhf23BA1U2+++SbKysrw4YcfOgQbAAgODsaKFStgMBjwxhtvAADWrVsHmUyG7du313quFStWQCaT4ciRI9KxEydO4K677kJQUBA0Gg369++P77//3uFxq1evlp5z9uzZCA0NRXR0NADg3LlzmD17Njp37gytVos2bdrg7rvvbrIekNjYWBw9ehTbt2+HTCaDTCbDiBEjpPNFRUV44oknEBMTA7VajQ4dOuD111+H1Wp1eJ41a9agX79+8PPzg06nQ8+ePfHOO+9I7+/uu+8GAFx//fXS69SsD7rYgw8+CF9fXyQnJ+Pmm2+Gn58f7r//fgCA1WrF0qVL0b17d2g0GoSFhWHmzJkoLCx0eI59+/Zh7NixCA4OhlarRVxcHKZNmyadr6tOCQBSU1Mhk8ku2Zslk8lgMBjw6aefSu/nwQcfBADo9Xo88cQTiI2NhVqtRmhoKG644QYcOHCg3ucjaonYc0PUTP3www+IjY3F0KFD6zw/bNgwxMbG4qeffgIAjBs3Dr6+vvjqq68wfPhwh2vXrl2L7t27o0ePHgBsdTyDBw9GVFQUFixYAB8fH3z11Ve444478L///Q/jx493ePzs2bMREhKCRYsWwWAwAAD27t2LXbt24d5770V0dDRSU1OxbNkyjBgxAseOHYO3t/dVvf+lS5fiscceg6+vL5577jkAQFhYGACgrKwMw4cPx4ULFzBz5ky0bdsWu3btwsKFC5GZmYmlS5cCADZt2oRJkyZh1KhReP311wEAx48fx86dOzF37lwMGzYMjz/+ON599138/e9/R9euXQFA+m99KisrMXbsWAwZMgT//Oc/pfc6c+ZMrF69GlOnTsXjjz+OlJQUvPfeezh48CB27twJpVKJnJwcjBkzBiEhIViwYAECAgKQmpqKb7755qrul91//vMfTJ8+HQMGDMDDDz8MAGjfvj0AYNasWVi3bh3mzJmDbt26IT8/Hzt27MDx48fRt2/fJnl9omZBEFGzU1RUJACI22+//ZLX3XbbbQKAKCkpEUIIMWnSJBEaGioqKyulazIzM4VcLhcvv/yydGzUqFGiZ8+eoqKiQjpmtVrFddddJzp27CgdW7VqlQAghgwZ4vCcQghRVlZWqz2JiYkCgPjss8+kY1u3bhUAxNatW6VjU6ZMEe3atbvkexNCiO7du4vhw4fXOv7KK68IHx8fcerUKYfjCxYsEAqFQqSlpQkhhJg7d67Q6XS12l7T119/Xat9lzJlyhQBQCxYsMDh+B9//CEAiM8//9zh+IYNGxyOr1+/XgAQe/furfc16rpnQgiRkpIiAIhVq1ZJxxYvXiwu/l+5j4+PmDJlSq3n9ff3F48++mgD3iVRy8ZhKaJmSK/XAwD8/PwueZ39fElJCQBg4sSJyMnJcRjOWLduHaxWKyZOnAgAKCgowG+//YZ77rkHer0eeXl5yMvLQ35+PsaOHYvTp0/jwoULDq8zY8YMKBQKh2NarVb63mw2Iz8/Hx06dEBAQIDThzm+/vprDB06FIGBgVL78/LyMHr0aFgsFvz+++8AgICAABgMBmzatKnJ2/DII4/UapO/vz9uuOEGhzb169cPvr6+2Lp1q9QmAPjxxx9hNpubvF2XEhAQgN27dyMjI8Olr0vkagw3RM2QPbTYQ059Lg5BN954I/z9/bF27VrpmrVr16J3797o1KkTAODMmTMQQuCFF15ASEiIw9fixYsBADk5OQ6vExcXV+u1y8vLsWjRIqnmJTg4GCEhISgqKkJxcfEVvvOGOX36NDZs2FCr/aNHj3Zo/+zZs9GpUyfcdNNNiI6OxrRp07Bhw4arfn0vLy+p9qhmm4qLixEaGlqrXaWlpVKbhg8fjjvvvBMvvfQSgoODcfvtt2PVqlUwGo1X3a7LeeONN3DkyBHExMRgwIABePHFF3H27Fmnvy6Rq7HmhqgZ8vf3R0REBA4dOnTJ6w4dOoSoqCjodDoAgFqtxh133IH169fjgw8+QHZ2Nnbu3Il//OMf0mPsBbdPP/00xo4dW+fzdujQweHnmr00do899hhWrVqFJ554AoMGDYK/vz9kMhnuvffeWkW9Tc1qteKGG27As88+W+d5e5ALDQ1FUlISNm7ciF9++QW//PILVq1ahcmTJ+PTTz+94tdXq9WQyx3/bWi1WhEaGorPP/+8zsfYi8JlMhnWrVuHP//8Ez/88AM2btyIadOm4a233sKff/4JX1/fehfls1gsV9xmALjnnnswdOhQrF+/Hr/++ivefPNNvP766/jmm29w0003XdVzEzUnDDdEzdQtt9yClStXYseOHRgyZEit83/88QdSU1Mxc+ZMh+MTJ07Ep59+ii1btuD48eMQQkhDUgCkaeNKpVLq6bgS69atw5QpU/DWW29JxyoqKlBUVHTFz3mx+j7k27dvj9LS0ga1X6VS4dZbb8Wtt94Kq9WK2bNnY8WKFXjhhRfQoUOHJlvdt3379ti8eTMGDx5cZxi82LXXXotrr70Wr776Kr744gvcf//9WLNmDaZPn47AwEAAqHUvz50716C2XOo9RUREYPbs2Zg9ezZycnLQt29fvPrqqww35FE4LEXUTD3zzDPQarWYOXMm8vPzHc4VFBRg1qxZ8Pb2xjPPPONwbvTo0QgKCsLatWuxdu1aDBgwwGFYKTQ0FCNGjMCKFSuQmZlZ63Vzc3Mb1D6FQgEhhMOxf//731fdu1CTj49PnWHpnnvuQWJiIjZu3FjrXFFRESorKwGg1n2Ty+Xo1asXAEjDQPb1aa42lN1zzz2wWCx45ZVXap2rrKyUnr+wsLDWfevdu7dDm9q1aweFQiHVDtl98MEHDWpLXffNYrHUGi4MDQ1FZGSkS4bEiFyJPTdEzVTHjh3x6aef4v7770fPnj3x0EMPIS4uDqmpqfj444+Rl5eHL7/8Uprma6dUKjFhwgSsWbMGBoMB//znP2s99/vvv48hQ4agZ8+emDFjBuLj45GdnY3ExEScP38ef/3112Xbd8stt+A///kP/P390a1bNyQmJmLz5s1o06ZNk92Dfv36YdmyZfi///s/dOjQAaGhoRg5ciSeeeYZfP/997jlllvw4IMPol+/fjAYDDh8+DDWrVuH1NRUBAcHY/r06SgoKMDIkSMRHR2Nc+fO4d///jd69+4tTffu3bs3FAoFXn/9dRQXF0OtVmPkyJEIDQ1tVFuHDx+OmTNnYsmSJUhKSsKYMWOgVCpx+vRpfP3113jnnXdw11134dNPP8UHH3yA8ePHo3379tDr9Vi5ciV0Oh1uvvlmALZhybvvvhv//ve/IZPJ0L59e/z444+1aqEudd82b96Mt99+G5GRkYiLi0Pnzp0RHR2Nu+66CwkJCfD19cXmzZuxd+9eh943Io/g3slaRHQ5hw4dEpMmTRIRERFCqVSK8PBwMWnSJHH48OF6H7Np0yYBQMhkMpGenl7nNcnJyWLy5MkiPDxcKJVKERUVJW655Raxbt066Rr7VPC6pi0XFhaKqVOniuDgYOHr6yvGjh0rTpw4Idq1a+cwDflqpoJnZWWJcePGCT8/PwHAYVq4Xq8XCxcuFB06dBAqlUoEBweL6667Tvzzn/8UJpNJCCHEunXrxJgxY0RoaKhQqVSibdu2YubMmSIzM9PhdVauXCni4+OFQqG47LTwKVOmCB8fn3rPf/jhh6Jfv35Cq9UKPz8/0bNnT/Hss8+KjIwMIYQQBw4cEJMmTRJt27YVarVahIaGiltuuUXs27fP4Xlyc3PFnXfeKby9vUVgYKCYOXOmOHLkSIOmgp84cUIMGzZMaLVaAUBMmTJFGI1G8cwzz4iEhATh5+cnfHx8REJCgvjggw8u9UdA1CLJhLiof5SIiIioBWPNDREREXkUhhsiIiLyKAw3RERE5FEYboiIiMijMNwQERGRR2G4ISIiIo/i1kX8fv/9d7z55pvYv38/MjMzsX79etxxxx2XfMy2bdswb948HD16FDExMXj++efx4IMPNvg1rVYrMjIy4Ofn12TLrhMREZFzCSGg1+sRGRlZa2+3i7k13BgMBiQkJGDatGmYMGHCZa9PSUnBuHHjMGvWLHz++efYsmULpk+fjoiIiHo3ALxYRkYGYmJirrbpRERE5Abp6emIjo6+5DXNZhE/mUx22Z6b+fPn46effsKRI0ekY/feey+KioqwYcOGBr1OcXExAgICkJ6eLu2kTERERM1bSUkJYmJiUFRUBH9//0te26L2lkpMTKy1C/DYsWPxxBNP1PsYo9HosCmcXq8HAOh0OoYbIiKiFqYhJSUtqqA4KysLYWFhDsfCwsJQUlKC8vLyOh+zZMkS+Pv7S18ckiIiIvJsLSrcXImFCxeiuLhY+kpPT3d3k4iIiMiJWtSwVHh4OLKzsx2OZWdnQ6fTQavV1vkYtVoNtVrtiuYRERFRM9Ciem4GDRqELVu2OBzbtGkTBg0a5KYWERERUXPj1nBTWlqKpKQkJCUlAbBN9U5KSkJaWhoA25DS5MmTpetnzZqFs2fP4tlnn8WJEyfwwQcf4KuvvsKTTz7pjuYTERFRM+TWcLNv3z706dMHffr0AQDMmzcPffr0waJFiwAAmZmZUtABgLi4OPz000/YtGkTEhIS8NZbb+Gjjz5q8Bo3RERE5PmazTo3rlJSUgJ/f38UFxdzKjgREVEL0ZjP7xZVc0NERER0OQw3RERE5FEYboiIiMijMNwQERGRR2G4ISIiIo/CcENEROQipkprkzxPcbkZzXmys9Xq3ra1qO0XiIjIPaxWAYOpEkqFHBqlAlarwIksPdr4qhCm01z28UIInM0zoG2QN5QKuXSszGSB2WKFv1ZZa7dng7ES3irFJXeBrjBboPaSQyaTIbO4HKt3piK9sAyjuoShuNyMcrMF9/SPQYhf9TY8QgicySnF9lO5iAv2wYC4IGw+no2cEiO81V64o3ck8kpNOJFZghu6hcFLIUd6QRmmrt4LP40X7hvQFj2i/JFVXIFT2XqYLVb0bRuIHtH+WPn7WZQaK+GnUeLLPWmQARjTPQwju4Ti633nselYNh68LhbP3tgFKi85So2VKDSYYLZYcaGoHL5qL8QEeePHvzKQVWKEQg4kpRdBCKBXdABC/dTYfDwbu5LzcW18EKYPiUegjxLfHsxAmcmC/rGB+PVoFpJzDfBWKTCuZwRu6x2JAoMJOXojrFaByAAtIgO08FYpkFFUji0ncmA0WzGhbxTKTBak5BlQZqpE+xBfxIX4oMhgRr7BiNM5pThyoRixbXxwfZdQtAvyRpnZgjV70rBqZyoGxgXhrv7R+PD3sxgQF4TZIzpc2S9bE+A6N0REzUxmcTkOnS9G13Ad2rbxBgCk5BnwV3oRbu4ZAZVX7U73HH0Fvk/KwPFMPWYNj0fHMD/oK8z4+XAmhAC0KgVW70qFEMDNPcNx38B28FXX/vdtSYUZJeVmhOs08FLIYaq0Yv3B81i6+TQyiyugkMvwwLXtkJJnwPZTuQAAlZccCpkMCrkMQT4qdAj1xZmcUlSYLegc7odr49sgMTkfO87koW2QNx68LhZ+Gi989EcKTmbrAQAJMQEY3zsSAOCt8sLvp3Px0+FMDOkQjOfGdcXp7FLsTS1AdkkFArQqKBQynM7WY9+5QrTxUSHUT4MTWSWoq8PAR6VAfIgv9BVmlFRUQl9hhtlSfaFcBofH+Wm8YDBWwiqA4Z1C8Py4rnjsy4M4kaW/5J+bTuOFkorKS//hVgnTqdGujQ8OphU6tKUlUSpk9bY92FeFXQtG1fm7eqUa8/nNcENE5CaFBhM2HM1CgFaJfu0CkVZQhqWbT2PHmTwAttAwa3h7WKxWrPwjBaZKK8Z2D8NNPSKw8WgWLhSVQy6TodJqxdGMEtj/b672kqN/bCAOpRdDb6z7wzZMp8a4npEoLDPhaEYx2vio0S1Sh893n0OF2QqlQoaOoX7ILC5HYZm5zudQKmSwWEWdgcJdBsYFoW+7QPx2PAchfmqUVJhx6HxxreuUChkGxAVJ9yg+2Ae9YwKQdL4IZ3MN0jU1P7xD/NSYNKAttp/MwbmCMgR6q9Ajyh9CCPxyJAsWq0B0oBbDOoUgs6gct/WORKC3ChuPZmHbyVxEBWhxe+9I/GvzaRQYTNLzapS2cBgRoEVeqRFFZWZ0jdBhYFwQjJUWdI/0h0Iuw9GMYhQYTIj012Jcrwj878B57D5bgKySCgzrGIJQnRr7zxViQGwQbugWhvTCcnz4ezJS8gwI8VUjRKeBXAZkFJUjR2+EELbfsYFxQai0CCSezYdWqUDncD9olQocyyxBcbkZGqUcbXzUiAzQoGdUAI5kFCMpvUgaYosO1OJv17bDV/vSkZpnwB29o/D4qI6IDfZp0j9bhptLYLghoquVXlCGv68/jAh/DW7oFo6hHYOhUSqQll+GpZtPoWOYHyYNiIG/VonU/DLsPJOHvakFqLQKqL3kMFZakac34q/zRagw167BkMuAyAAtzheWN6pdfdoGQOOlQOLZfOlY+xAftPFVI6OoHBP6RCFEp8HHf5xFan5Zvc+jkNtCi12onxoPD4vHxGtisCelAE9//RcUchk+mnINOoX5orDMDKtVwGIVOF9YjjM5erQP9YWP2guHzxdj55k8+Ki98PCweOw4nYddyXnI0Rsxsksopg6Og8Uq8J/EVBzP0kOlkKPMVIlAbxVu6hmBpZtP4XhmCbpF6tC/XRDign1QUm6GABDoo8KITiG4UFSO/FIT+scG1hois1oF/kzJR4XZAj+NEjqNEn4aLwT5qKBRKqCvMCO7xIj2IT6QyWSotFix5UQOYgK9UWm14umv/8L5wnKE6zR4654E9GkbWOc9O5Wtx84zeZjQNxr+WuUl/5zKTRYcTC9Eal4ZBsQFokOon3TOYhXINxgR4qu+5HBcYwghaj2XqdIKk8UKnxrDfgUGE/w0XtKwodUqYKy0QqtS1HpOi1Ugo6gcOq1Ser+VFitKKioR5KNqknZfjOHmEhhuiKihcvVGbDqWjcEd2qC43IzXN5zA2O7h+PGvTOxJLZCu0yoVuCYuCIfOF6GoRi+Hj0oBg8lyydfoGqFDuakSqfll8NcqcX3nEDw1pjOiA7X4al86Nh7NhlalwOiuofDXKjHrvwfgo1Jg8qBYdI/UQQAwW6wYEBuEUJ0GVqvApuPZKCozoWOYH3pHB0Aud/xgq6iqk8goroC/VolOYX44nlmCwxeKcVtCJG7uGYGMonIczSiGTqPEwPg2UNR4jgqz7T1plLU/9JzBVGlt0uENapkYbi6B4YaI6mO1CuxMzsNPhzKRXliGvamFMFVaoVHKIZfJUFYjqPioFJjQNxq/ncjBhaLqHpbukTpYqoptAdvQRr92gbiufTB81V4wVj1fG1814oN90D1SJ/UYeCku/wFeVGaCRqlwWbAgai4a8/nN2VJE1KSEEDBZrFB7Ne8P38PnizF3zUH4qL3QPzYQkwfFYt5XSTiYVuRwXaifGjl6IwCgU5gvTueUQghg4c1d8bdr2+FlYQsyu5LzoVTIcE//GGiUChSXmZFbakRkgAbeqsv/r7YhwQYAAryd0+VP5EnYc0NETertX0/iva1n8PWsQejXLshpr1NXHUFjPPr5Afx0OLPWcV+1F8b3iUKftgHoGOqHHlE6fHPgAjKLyzFjWDz+Si9GekEZxveJqjXcQ0TOw54bInKLUmMlPt6RAqsAfj6c5bRwU2G2YMIHu6CQy7B+9nUN7vWwKy4zY9PxbADA8+O64r9/nkNqfhmiArT4z0MDEB/i63D9nf2ipe8HxAVhQJzzQhsRXT2GG6JWzmyxYsnPJzCsUzBGdA697PVWq6i3x+K7pAtSAW1SetFVtWv/uQK8vekUnh/XDV0jHP+V9tW+dBzLLAEAHL5QXO8MlotlFVfgg21nUGG2wFRpRecwPzw0JA73DWyLzcdzMLh9G7TxVV/+iYioWWP5OVErt+lYNj7ZmYJn1h1ymP5bl/d+O43eL/+K09m1FzMTQuCL3WnSz0cuFMNsqT3NOa/UiJKKutdNqen1X05i55l8vPzDMYfjpkorlm9Lln7eWbUmjBACp7L19b4HIQTmfZWEzxLP4at95wEAd/aLgkwmg7fKC7clRDLYEHkIhhuiVu5ohm2Bs1y9EftqTG+uy0+Hs1BSUYltJ3NRUmHGgbRC6VxybimOZpRApZBLs4JOZDqGoLxSI0b+cxvuWZ5Y7744Qgik5ZdJU60Tz+bjrxq9QN8evICM4grpZ/uCd5/vTsOYf/2OVTtT6nzeb5MuYFdyPlRecqi85NBpvHBH76hLvl8iapkYbohaueM1AsjPhzNx5EIxispMta4TQuBcvm3l1jM5pXjx+6OY8MEubDyaBcA2PAQACTH+6NM2AACQlF7o8BxbT+SgpKISJ7L0OJpRUus11h88j2te3YzH1xx0OP7kV0mY+Z99SM4txQ+HMgAAd1fVwRw4V4QyU6XUDnvYqelcvkHqAZo7qiN2LxyFzU8NR2gD9kQiopaH4YaohTuVrcfHO1Lw5Z40bDuZg9yqacsNdTyzOmT8d3cabvn3Dsz+/AAA24qlxkpbDU2O3iit85KcW4pdZ2yr4G48YgsV9l6arhE69IkJAAAcvKju5vfT1cFj64kch3Nlpkr834/HkVdqkup1HhnRHjIZcDbXgI1Hs/HyD8ew+6ytR2fm8PaICtDCZLHiz7P5OHDOFqROXrT/T3G5GVNX70VhmRm9ov0xY2g8Aqv2IiIiz8SCYqI6VFqs+NvHuxHip8G/J/Vxd3MuafbnB3Amp1T6WeUlx7anRyAyQHvZxxaVmZBZNcTjq/ZCadU+RLuS83EyS49b39uBvm0D8MX0a5GSZ5AedySjWNo24PfTeRBC4HhVqOgSrkO4v612peaaMRarwI7TudLPv53MwWOjOko/f7E7DfkGE/y1SpRUmKHTKPHYyA4YEBuEg+lFeHfLaWmjxtg23mgf4oPBHdrgq33n8e6WM1Ihc2ZxBYrLzPD3ti0J//W+dJzNNSDCX4OPJvfnSrdErQD/lhPV4UxuKf48W4Af/spAZR1Fsc1FhdmC5FxbsBnROQR+Gi+YKq21FqKrj33GUUyQFk+M7ohuNWYlvbPlFEyVVvx5tgDf/5WB1BrhpuZ+SHmlRhzP1ONE1XN1ifBDv3ZBUCnkSMkzSD1DRy4Uo7DMtgkfYJtNlV9q62UyVVrx4e9nAQALbuqCH+YMwfrZ18Fb5YXru4Ri3g2dkBDtL73myC5hkMlkUs3MxTOzTuVU997Ye7LG9YzgMBRRK8FwQ1QH+67AAKCvsPVmWK0CqXmGegthneGzxFQ8t/4wDBft7Pzh78mYu+YgknNtq+X6qb2w6sFrMKZbOAAgJa8URy4UY93+81J7rVaBtXvTsPVkDqxVM4rs9TZdw3WYPjQeP88dipFdbNPBf6kabgKA1zeccBi+uth3SRekVXw7h/nBX6uUnufbgxcAAFtP2oahhncKQdcIHYQA1uxNBwDsSy1Ajt6IYF8V7uwbjR5R/rXWmpl4TVvp+1Fdbc89qH0bdAn3w8VO1BiasvdG+ajZUU3UWjDcENXhbG71MI893Hy04yxG/HMbvtqX3uSvl19qdNifCAAuFJXjxe+P4vPdaZjyyR7oq6ZPny8sw2u/nMB3SRlYs8fWlthg247G8SE+tvbnGTB3zUE8/fVf2HjUtljdd39dwPz/HcbUVXtx87t/IL/UKAWWmuvI9K6ql7FnOD+1FzKLK/DlntrvOzrQNvS1oqrXpV0bbylE3NHH1qvyXZKt1+ejP2yzmEZ3DcOkATEAgDc3nsRXe9OxrWq4aXin0HqHjW5NiEC4ToOYIC2uibUtoieTyTBtSJx0zcCqxfVOZlUHMXsw9GW4IWo1GG6I6nC2xhCMfU0WeyHr1S5OdzEhBO5ZkYgb//W7QzHwZ4mpsC/Zsu9cIV6qmu3z+e406fgvR2zbB8QG20JNXNV/k9KKkFzV+7R2r23tmZ8OVW81cCJLj2XbkrGramZRt8jqcJNQFW4AwF+rxONVdTGmquG5jqHVPSpzru/gsFt0zV6U67uEQKfxQlZJBcZ/sBOlxkpcExuICX2j8cC17TC9KpQ8/+0RqW3DO4fUe5/8NEr8Om8Yfpk7zCEA3ZYQiU5hvogP8cFdVTOoTjr03NhqcdhzQ9R6MNwQ1aHmsJQ93JyuKtpNLyiv8zEv/XAU89cdcli4zmIVmPLJHkxckVjngnaArYcmOdcAvbESf1QV3JabLFKvzIyhthDw/V8ZyCmpwJo91Qvl5ZXapmzHtfG2/Te4uufGbvupXJzO1kszlZ66oRMA4KMdKcgorkConxrDO1WHit7RAdL3A+OCMKFvFLxqBJhRXcOk72/sEY7nbu4q/dyhRvBReylwd39bD01hmRl+ai/8a2JvKOQyyGQyPDeuKwbEBcFkseJCUTnkMmBoh+A675GdTqOs1QOjUSrw0+NDsfnJ4egRZavLOZGll4bjDNKwVPPeyJOImg7DDdFFhBC1hqUqzBakF5YBgPTfmnL0FVi1MxVr96XjX5tOScc3HMnC9lO52J1SUOe6LoCt0NbOvkbLyj/OorjcjJggLRbc1BWdw/xgqrRKU5oVF21/YO+5iW3jU+v5rQJ4fE0STJVWxAf7YPb1HRBbFYYAYPaI9tAoqz/4/b2ViK96vkFV2xHY62cUchlu6mGr62kf4oMAbxWmDo7F5EHtoPaS48buEQ6v/dzNXfH9nMH496Q+WP/odYgOrH5dmUyGp8d0ln5OiAlAoM+V7XitVMghl1cPy+krKlFgsAU/g4nDUkStDcMN0UUKDCaUVFQX8OorKqXCXQDIKCqvtcR/zZ6eZduTsftsPoQQ+GDbGen4/nOOC9rZHblQHXp2nM7DrjN5WLrZFpCeGNUJCrkME6+x9YDYA9KCG7s4PIc93GhVCkT6V88Isg8x2WtrbuoZDoVchoeGxgMAwnRq3DugLS721JjOuLF7OCb0tQ3z2F+/Y6gvEmICsHJyfyz7Wz8AtpDy8u09cPSlsehZY0YTAMjlMvSKDsCtCZHoEFq78HdAXBCGVfUaja7RI3Sl1F4K+FWFGPufIQuKiVof/m0nukjNIR0A0FeYHdaRMVsEsksqHNaRqRluhLAthmestDr01hxIK8RDqC5+tTtco+cmR2/EjM/2wSqAu/pFY0JfW1Hu+D5ReO2XEzBZrLhvYFvMGBaPVTtTpG0I7D0tABAf4isdnz+2M1LyDVi6+TRKKyoxvo8trEy6JgamSisGxgU59NrYjesVgXG9qnthRnYJxbuT+kj1Njd0qx1EGrszt907E3vjlyNZ0nu9WjqtEnpjJYrLbcOJLCgman34t51apbO5pfBReyGsjnVPag5JAUBJeSXySx23IzhfWO4QblLybI/pHqnD0YwSJCbnwT5w1C1Ch2OZJdIKuoBt6Esmk0EIIQ1LBfuqkFdqgsFkQc8of7xyew/IZLZnCfRRYcmEnjiZrcdTY2w1M90i/ZFRXIEAbyUCvKuHc+KCfaThre5R/riuQzDu7heDikoLdBrbwnZeCjkeGlI7aNVHJpPhtoTIBl/fGIE+Ktw3sHbv0ZXSaZW4UFSOEincsKCYqLXhsBS1OvmlRox8azsGLdlS5w7Sl+u5AYD0Ase6G3vPzYS+0dAqFcgrNeHnw7YZQAtv7gK5zLZy7m8nsvHYlwfRddEG/N+Px3ChqBz5BhMU8uopzfEhPlg99RpoVY49Knf2i8bfb+4KtZfteI8o2wyni+ts4qT6G2/4a21hxrZRpLKBd6hl02lsIaa43AwhhFRzw4JiotaD4YZatO+SLuDOZbuQUVT3DKa6nMy2TRO2CuBgWu06mDPZtiATprNtIaCvqMTpqhVvo6p6a84XOr6ePRB1CffDNVVrrVRaBYJ91RjcPhhdwm1BZNrqffjhrwxUmK34aEcKJq74E4CtlmX6kHgsndgbX88chDa+6su+jxt7hCPQW4lbejkW8Y7uGoZwnabOWprWQFcV6EoqzCgzWaRaKQ5LEbUeDDfUoq3Zk4795wqxbv/5Bj/GPosGADYdy6513r50f/92tpCSbzDhXL6tp8a+DkvNGVNmixVpVT058SE+GNy+jXTuhm5hkMtl6NcuUDp2Y/dwvHRbd2iUcmnhvj5tA6HykuOOPlENCjaAbQ+nAy/cgOlVxcF2bdt448+/j8Ks4e0b9Dyext5bVVJeKdXbyGWAto7aIiLyTPynDLVoRVV1FX+czpUWm7uc7JLqhfI2HcvGwhrrtJSZKqV1bPq0DcBPhzNxMrsElVYBjVKOa2ID8cXuNJyvEW7SCspgsQpolQqE+WkwuMZaLWO62wpvJw9qh/TCMozvE4Xbq/ZDGtklFHtSClBmtmBcT8fel4ay1+RQNfvwW3G5uXqmlMqL94qoFWG4oRatuMzWC3MwrQj6CjP8GlBXklNSIX1/Ns+AMzml0uJzp6uGpIJ9VVItiz3sRPpr0TbI2+EYAKRU1dvEBftALpehW4QOfdoGoNxkwXVVvTgdw/yweuoAh3bEBHkjJsgb1LT8awxLsZiYqHXisBS1aPaem0qrwJ9nC1BSYcbYf/2Op776S7rm58OZuGvZLqkIOKtGuAEgrQoMAKeq6nE6hvpJtRt2EQEaaRG6zOJylJssWPC/Q1jwzWEAQFzVAnJyuQzrZw/GhieGScW/5Do6bXVBcSlXJyZqlfjPGWqxjJUWlJks0s87TufCYhU4ma3HyWw97r+2LWICvTF/3SHojZVYf/ACHh/VEdlV4SbCX4PM4gqkFZThXL4B3xy4gMxiW49MpzBf+Gkc/3pE+msR6qdGuE6DrJIKfJqYKu1qDQDX1KirIfexD0uVlJu5xg1RK8W/8dRslZssSM03OOxYXZN9kTa7P87kOQw/LNuWjICqBd0A4FjVgno5VTU3fdsG4qfDmThfWI7XfjmBX45kSY/tFO5XK9xEBGghk8kwpGMw1u0/j/d/s60+PCi+DZ4b1xXdI+tuJ7lW9bBUZY1p4PxfHVFrwmEpapZMlVbc9M7vuOmdP3DofJHDuUKDCbvO5KGozBZutEoFFHIZzuYasOFodUDZdCwbX9eYRXWsagsCe89Nn7YBAIALheXYciLH4TU6hdUelrJvazC0o61g2B6abusdiR5R/ixYbSakqeAOw1IMN0StCcMNNUvvbjmN1Krp18cu2nDyuW8P476PduPHQ7ZF8sJ0aiRU7WlkX0yvS7htHyNvlQIPD7NNlU4rKENmcTkMVUNZ9unZ5wvLoPFy/KvQKdQPviov1Mwr9hWJB1+0c/X1nUOv7s1Sk/LXcliKqLXj33hqdlLyDA4bTuorKnEwrRCbjmXj8VEd8Ve6bbuCvSkFAGwfZkM7huBAWhEAQO0lx9ezBuF0Tim6ReigUSrw418ZyCiuwPaTtuJhP40XOobZAlDNTTLbBnmjU5gv/L1tH5C+Ki+phyYywNZzE+yrRtcIHY5nlqB7pA7h/rW3cCD3cSwots+WYkExUWvCcEPNzpELxai5K0JRuQlvbDiJxLP5iA70lha+s6807O+twtCOwXhny2kAtv2d/DRK9G1bXeDbLVKHjOIKbD1pG34K02ngq/ZCgLdSGt6K8Ndg+zMjHIaXdDVqdiL8q/eSuqlHOI5nljhtvyW6cvaC4kqrQK7eVl/FYSmi1oV/46nZydEbHX4uLDNLdTI/Hc6QjttXGg7QKpEQEwBftRdKjZXoFR1Q6zm7Reiw+XgOtlb13Ni3VogK0ErhJraNT626GXtRsb9W6fABOXtEe1zXvo1DgKLmwVulgJdchkqrkGa/+ar4vzqi1oQ1N9Ts2BfZ85LbgkZRmQl5pbbAk5icX+t6f60SSoUcY7rZVgMe1im41jXdqmYymSqtAIAwP9tQUnRgdW9MbLBPrcfZw03ERUNPXgo5+scGQS5nEXFzI5PJpKJi+55j7Lkhal0YbqjZsffcdKqqicnVG6W6mDo28UZAVX3MK3f0wPdzBmNkl7Ba1/RpGwiVovrXPUTqualeITguuPZqwfYVj+3FxNQy2IuKM4tsQZkFxUStC8MNNTv2IajOVTOekqtmQNXH/kHmo/aqc0gKsNXYrHign/SzfWuFqJo9N21q99zoqnpu7MXE1DLY/9z0nApO1Crxbzy5lNUq8PmeNAyKbyPt5wQA5/INePrrv3BLr8haPTc1d/GuS4C3qkGvfX2XUGx7egR+P52LO6o2r7zcsFT7EFsbe0T6N+g1qHm4eI0izpYial0YbuiKHcsoQXphGcZ2D2/wY345koUXvj2CLuF++GXuUMhkMpQaK3HD27/DZLFib2qhVOdiX6vmcvy1l98s0y422MchxERVDTfJZJA2xazpkRHtcX2X0HpXSabm6eJww2EpotaFw1J0xeZ8cQAz/7MfZ3NLG/yYvam2tWlOZOlxPNM2lfu59Ydhslila/RV9TWd6gk3CrnModfHXnNzJTqH+6F/u0Dc1TcaGmXtf917KeToEeUPBQuHWxSd5uKeG4YbotaEf+PpigghcL5qJkpyrgHxIb51Xme1CpSbLdKHy181tlL4LukCTBYrvkvKgEwGiBrFwhqlHJH+GijkMliqqojtG1bGB/sgOlCLMzm2UBXQiJ6biykVcqx75Lorfjw1Txf35rHnhqh14d94uiIVZqs0rfpCYVm9183+/AB+O5mDZ8d2xgOD2uFoja0UvkvKwMGqVYUn9InGhaIy/HnW1rMTptNAJpMhQKtEflXNzY09wtE+1Be9ovyxZm+a9DyNGZai1mFU11Cs2ZuGojIz2vioEOKndneTiMiFGG7oihSVVxf5ZhRXSN/rK8zQKBVQKuSotFiljSz/76fj+PVoNkyVVvhrlbAKgaySCmSVVEDlJce8MZ2wYnuyFG5Cqz6MAryrw00bHxUeuLYdAEgrDQO16yuIrokNwoHnb0BqvgFBPqo6hxyJyHMx3NAVsa/qC9h21QaApPQijP9gJ3xVXripZzgmD4p1eMyeqnqb3jEBuDUhEv/58xwMxkr8bWBbRAVopb2eACBUZ5t6HeitAmCbCt7Gt/pf3+FV57VKBT+4qE5yuaze4VIi8mwMN3RFCsuqe27sez1tPpYNIWxri3y17zwMVZsWXhMbiHZtfLBu/3kAtnBzV79o3NUv2uE5O9UoEq7uuame5h3kU/19WNWKwRySIiKii3G2FF2R4po9N1Xh5kiGbbdutZft1+qXI5kAbPs6PXtjZ6mos2+7uvdj6lSj5yZM6rmpDi/BvtXhpl+7QHQK88XtfbhxJREROWK4oQa5UFSOyZ/swcaqGpqi8upwk6s3wlhpwZELtnAzbUgcgOqtErpH+iPUT4NPHrwGz93cFcM61t77CQACfVQIrhp6qllzY1ez50anUeLXJ4dj4U1dm+gdEhGRp2C4oQZZuycNv5/Kxcz/7Mfh88UONTcAcDCtCHmlJijkMkwbHOewLox908oBcUGYMSy+1s7bNY3oHAKlQoaEmAAAjsNSNWtuiIiI6sNwQw2SnFe9v9Os/+6X9n+ys/fodAz1RYifGn2qwomXXIaOYQ0v6nzjzl7Y/8IN0rYHgVXhRqmQSfsFERERXQrDDTVIck71KsQXisqx40yew/lfj2YDAHpE2fZgGtoxBADQMcwPaq+Gz2aSy2UOq8vaa26CfFSX7PEhIiKyY7ihyzJbrEiu2mLBvtGk/WevquEne1Fxj6ohqHsHxODa+CDMGh5/Va8dF2LbB6rmdgtERESXwn5+uqxz+QaYLQLeKgUGxrXB+cLz0lYJHUJ9cSJLL13bq2o4KkynwZqHB131a3cJ1+HbRwfXuaklERFRXdhzQ5d1KtvWS9Mx1Bft2jiGjGGdbMNP/lolnhzdSaq1aUq9YwIcZkoRERFdCntu6LJOZdt6ZjqG+dXqQbktIRL3XhODCH8ttCquFExERO7HcEOXdbqq56ZTmC9igrQO5/y1SsRwyIiIiJoRDkvRZZ2s0XMTE+gYZAI5XERERM0Mww1d0pELxTiTUwqFXIYekf4I8VNL2yt4yWXw4VAUERE1Mww3dEnLticDAG7tFYEQPzVkMpk0DBXgreTaM0RE1Oy4Pdy8//77iI2NhUajwcCBA7Fnz55LXr906VJ07twZWq0WMTExePLJJ1FRUXHJx9CVSckz4JfDts0vZ41oLx2PqVrrhjtyExFRc+TWcLN27VrMmzcPixcvxoEDB5CQkICxY8ciJyenzuu/+OILLFiwAIsXL8bx48fx8ccfY+3atfj73//u4pa3Dr+dyIFVAEM7BqNLuE46bp8xFejNehsiImp+3Bpu3n77bcyYMQNTp05Ft27dsHz5cnh7e+OTTz6p8/pdu3Zh8ODBuO+++xAbG4sxY8Zg0qRJl+3toStTaDABAOKCfRyOVw9LMdwQEVHz47ZwYzKZsH//fowePbq6MXI5Ro8ejcTExDofc91112H//v1SmDl79ix+/vln3HzzzfW+jtFoRElJicMXNUxxuW3n74uHn27rHYlxPSMwbUisG1pFRER0aW5b5yYvLw8WiwVhYWEOx8PCwnDixIk6H3PfffchLy8PQ4YMgRAClZWVmDVr1iWHpZYsWYKXXnqpSdveWtQXbkL9NHj//r7uaBIREdFlub2guDG2bduGf/zjH/jggw9w4MABfPPNN/jpp5/wyiuv1PuYhQsXori4WPpKT093YYtbhi3Hs9HzxY34fPc5h+MlFbZwo2PhMBERtSBu67kJDg6GQqFAdna2w/Hs7GyEh4fX+ZgXXngBDzzwAKZPnw4A6NmzJwwGAx5++GE899xzkMtrZzW1Wg21Wt30b8BDFJWZMP9/h6CvqMRrP5/AzT0ipIX56uu5ISIias7c1nOjUqnQr18/bNmyRTpmtVqxZcsWDBpU927SZWVltQKMQmFbRE7Yt6mmRvnHz8eRV2orHNYbK6V1bQCGGyIiapncOiw1b948rFy5Ep9++imOHz+ORx55BAaDAVOnTgUATJ48GQsXLpSuv/XWW7Fs2TKsWbMGKSkp2LRpE1544QXceuutUsihhhNC4NuDGQCAR6rWsVm9MxXrD54HAJQw3BARUQvk1o0zJ06ciNzcXCxatAhZWVno3bs3NmzYIBUZp6WlOfTUPP/885DJZHj++edx4cIFhISE4NZbb8Wrr77qrrfQopksVpgsVgDArOHtkZZfhp8OZ+LJtX/BamXPDRERtUwy0crGc0pKSuDv74/i4mLodLrLP8CDFZWZ0PvlTQCA06/eBLlMhufWH8aavekY2jEYf5zOAwAceWksfNXcQJ6IiNynMZ/fLWq2FDWtcrMFAKBUyKBUyKGQyzCySygA4GSWbSdwBTfHJCKiFobhphUrM9nCjVZZHV7C/TUAgBy9EYBtSIqbYxIRUUvCcNOKldvDTY2emXCdxuEa1tsQEVFLw3DTitmHpbxV1fU0bXzVUMire2q4gB8REbU0DDetRIXZIvXU2NmHpTQ1hqUUchnC/KoXPWTPDRERtTQMN62AEALj3v0Do97aBlOlVTpuDzveFxUMh/lXD00x3BARUUvDcNMK6I2VSM41IKO4ArmlRul4ubkSgGNBMeBYd6PTcAo4ERG1LAw3rYB9pWEAKC6r/r7cZOvF0V7cc6Njzw0REbVcDDetQHHNcFPj+zKTrefm4mGpcA5LERFRC8Zw0wrUF27K61jnBnAclmK4ISKilobhphWoOSxV83v7VPCLh6XYc0NERC0Zw00rULO3pqjcJH1f1wrFAHtuiIioZWO4aQXqG5aqMNc9Fbxmzw0X8SMiopaG4aYVKCmvlL53LCiuvYif/ee4YB+oFHJEBWhd00giIqImwkVMWgHHnpvqoFNmqr39gt2ah69FSbkZgT4q5zeQiIioCTHctAKNHZYCbGvdhF20iSYREVFLwGGpVsAh3JTVLCi29eJcPCxFRETUkjHctAL1rnNjtq1QXFfPDRERUUvFcNMKlNS7iF/V3lIMN0RE5EEYblqBkooai/hVVEIIAaDGIn4cliIiIg/CcOPhhBAOvTUWq0Cp0dZjIy3ix54bIiLyIJwt5eHKzRaYLbaeGpkMEAJYti0Z/lqltLcUa26IiMiTMNx4OHuvjUIuQ5CPCrl6Iz7YluxwjbeSvwZEROQ5OCzl4ezhxl+rrHefKI2KvwZEROQ5+Knm4YrLLh1uFHIZVAr+GhARkefgp5oHO5hWiN9O5gCwbYBZV7jRKhWQyWSubhoREZHTsNjCQ1WYLfjbR7thqCoarm9IijOliIjI07DnxkNlFJVLwQYAVAoZTmbpa13HmVJERORpGG481PnCcoeflQo5bkmIAAD4qqs77LiAHxEReRoOS3mo9MIyAECQjwpdwv0wc3h7dArzRZdwP/RrG4Rhb251cwuJiIicg+HGQ9l7bm7tFYGXbu8hHR/fJ9rhunyDCURERJ6Ew1Ieyh5uogO9L3ldXqnRFc0hIiJyGYYbD3W+algqJkh7yeuq9tAkIiLyGAw3HupyPTeB3nVPDSciImrpGG48UIXZgly9bbgpOrDunpvPpg1EtwgdPps2wJVNIyIicjoWFHsge6+Nr9qr3sX7ekb74+e5Q13ZLCIiIpdgz40HstfbRAdqubUCERG1Ogw3HuZCUTk2HcsGcPmZUkRERJ6Iw1IexFhpwbh3/0BR1U7g7dow3BARUevDcONBknMMKCozQ6OUY3yfaDw0JM7dTSIiInI5hhsPcirbtjFmzyh/LJnQ082tISIicg/W3HgQe7jpGObn5pYQERG5D8ONBzmVXQoA6MxwQ0RErRjDTQuWo6/Aiu3JKKja/PJ0jr3nxtedzSIiInIr1ty0YB/9kYIPfz+LCrMVDw+LR1qBbX2bTuy5ISKiVow9Ny1YelWYySwux5mcUggBBPmoEOyrdnPLiIiI3IfhpgXLLqkAAOSVmqRi4k4ckiIiolaO4aYFy6naHLPAYMSZXFsxccdQDkkREVHrxnDTQgkhkFNiCzf5BhMyi2ybZcYE1b0LOBERUWvBcNNCFZebYbJYAQAFpSZkVwWdMJ3Gnc0iIiJyO4abFsoeZgBAb6xEetVO4KF+DDdERNS6Mdy0UPZiYrvzhbZhqTAdZ0oREVHrxnDTQtmLiS8WymEpIiJq5RhuWqiLe24AwFftBV8112UkIqLWjeGmhcqto+eGQ1JERERXGG4qKyuxefNmrFixAnq9bfG4jIwMlJaWNmnjqH519dxwphQREdEV7C117tw53HjjjUhLS4PRaMQNN9wAPz8/vP766zAajVi+fLkz2klVthzPxqLvjuJC1bo2Ef4aZBbbgg7DDRER0RX03MydOxf9+/dHYWEhtNrqBePGjx+PLVu2NGnjqLYV289KwQYAukbopO9DOSxFRETU+J6bP/74A7t27YJKpXI4HhsbiwsXLjRZw6hugT5Kh5+7RvjhtxM5AIAwrnFDRETU+J4bq9UKi8VS6/j58+fh58d9jZytalFiSZfw6p4bDksRERFdQbgZM2YMli5dKv0sk8lQWlqKxYsX4+abb27KtlEdys2VAICBcUH496Q+iPCvDjScLUVERHQFw1JvvfUWxo4di27duqGiogL33XcfTp8+jeDgYHz55ZfOaCPVUGay9ZpNGxKHsd3DkZJnkM6x54aIiOgKwk10dDT++usvrFmzBocOHUJpaSkeeugh3H///Q4FxuQc5VXhxlulAACE+qmhVMggl8kQ4seeGyIioitaztbLywt/+9vfmrot1ABlF4UbH7UXPnygPxRyGTRKhTubRkRE1Cw0Otx89tlnlzw/efLkK24MXZ493GiV1X9013cJdVdziIiImp1Gh5u5c+c6/Gw2m1FWVgaVSgVvb2+GGycrN9kKiu09N0REROSo0bOlCgsLHb5KS0tx8uRJDBkyhAXFTiaEQJnZcViKiIiIHDXJxpkdO3bEa6+9VqtXpyHef/99xMbGQqPRYODAgdizZ88lry8qKsKjjz6KiIgIqNVqdOrUCT///POVNr1FMVZaIYTtey3DDRERUZ2uqKC4zify8kJGRkajHrN27VrMmzcPy5cvx8CBA7F06VKMHTsWJ0+eRGho7ToSk8mEG264AaGhoVi3bh2ioqJw7tw5BAQENNG7aN7s9TYA4K1qsj86IiIij9LoT8jvv//e4WchBDIzM/Hee+9h8ODBjXqut99+GzNmzMDUqVMBAMuXL8dPP/2ETz75BAsWLKh1/SeffIKCggLs2rULSqVtG4LY2NjGvoUWq6yq3kblJYdCLnNza4iIiJqnRoebO+64w+FnmUyGkJAQjBw5Em+99VaDn8dkMmH//v1YuHChdEwul2P06NFITEys8zHff/89Bg0ahEcffRTfffcdQkJCcN9992H+/PlQKOoepjEajTAajdLPJSUlDW5jc3PxGjdERERUW6PDjdVqvfxFDZCXlweLxYKwsDCH42FhYThx4kSdjzl79ix+++033H///fj5559x5swZzJ49G2azGYsXL67zMUuWLMFLL73UJG12N2mNG65nQ0REVK8mKSh2FavVitDQUHz44Yfo168fJk6ciOeeew7Lly+v9zELFy5EcXGx9JWenu7CFjctaY0b9twQERHVq0E9N/PmzWvwE7799tsNui44OBgKhQLZ2dkOx7OzsxEeHl7nYyIiIqBUKh2GoLp27YqsrCyYTCaoVKpaj1Gr1VCrPWNbAvummSwmJiIiql+DPiUPHjzYoCeTyRpe5KpSqdCvXz9s2bJFquOxWq3YsmUL5syZU+djBg8ejC+++AJWqxVyua3T6dSpU4iIiKgz2Hga9twQERFdXoPCzdatW53y4vPmzcOUKVPQv39/DBgwAEuXLoXBYJBmT02ePBlRUVFYsmQJAOCRRx7Be++9h7lz5+Kxxx7D6dOn8Y9//AOPP/64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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10358}, {'accuracy': 0.1303}, {'accuracy': 0.16906000000000002}, {'accuracy': 0.23586000000000001}, {'accuracy': 0.29619999999999996}, {'accuracy': 0.31394}, {'accuracy': 0.38154}, {'accuracy': 0.5128600000000001}, {'accuracy': 0.43249999999999994}, {'accuracy': 0.44150999999999996}, {'accuracy': 0.41708999999999996}, {'accuracy': 0.4625699999999999}, {'accuracy': 0.49126000000000003}, {'accuracy': 0.52882}, {'accuracy': 0.5721}, {'accuracy': 0.5338300000000001}, {'accuracy': 0.546}, {'accuracy': 0.6361899999999999}, {'accuracy': 0.6296999999999999}, {'accuracy': 0.66838}, {'accuracy': 0.62231}, {'accuracy': 0.66019}, {'accuracy': 0.68307}, {'accuracy': 0.6835500000000001}, {'accuracy': 0.7142499999999999}, {'accuracy': 0.7085800000000001}, {'accuracy': 0.76732}, {'accuracy': 0.70958}, {'accuracy': 0.7251899999999999}, {'accuracy': 0.69562}, {'accuracy': 0.78915}, {'accuracy': 0.79514}, {'accuracy': 0.7878999999999999}, {'accuracy': 0.7848200000000001}, {'accuracy': 0.7483500000000001}, {'accuracy': 0.80702}, {'accuracy': 0.81523}, {'accuracy': 0.8381700000000001}, {'accuracy': 0.8332599999999999}, {'accuracy': 0.8035799999999998}, {'accuracy': 0.8577899999999999}, {'accuracy': 0.8254300000000001}, {'accuracy': 0.8271499999999999}, {'accuracy': 0.84673}, {'accuracy': 0.84558}, {'accuracy': 0.83147}, {'accuracy': 0.85179}, {'accuracy': 0.84903}, {'accuracy': 0.8424400000000001}, {'accuracy': 0.86054}, {'accuracy': 0.8496900000000001}, {'accuracy': 0.84946}, {'accuracy': 0.85667}, {'accuracy': 0.86143}, {'accuracy': 0.8384600000000001}, {'accuracy': 0.87736}, {'accuracy': 0.8829699999999999}, {'accuracy': 0.8302999999999999}, {'accuracy': 0.8761299999999999}, {'accuracy': 0.8554}, {'accuracy': 0.88057}, {'accuracy': 0.84405}, {'accuracy': 0.8997999999999999}, {'accuracy': 0.8854099999999999}, {'accuracy': 0.8713199999999999}, {'accuracy': 0.8899100000000001}, {'accuracy': 0.8816599999999999}, {'accuracy': 0.8828900000000001}, {'accuracy': 0.8895500000000001}, {'accuracy': 0.8688800000000001}, {'accuracy': 0.8657199999999999}, {'accuracy': 0.9035499999999999}, {'accuracy': 0.89103}, {'accuracy': 0.85946}, {'accuracy': 0.8863300000000001}, {'accuracy': 0.8797499999999999}, {'accuracy': 0.9026500000000001}, {'accuracy': 0.9282299999999999}, {'accuracy': 0.86374}, {'accuracy': 0.89742}, {'accuracy': 0.9212300000000001}, {'accuracy': 0.8908000000000001}, {'accuracy': 0.87645}, {'accuracy': 0.88948}, {'accuracy': 0.88949}, {'accuracy': 0.9151100000000001}, {'accuracy': 0.90981}, {'accuracy': 0.89503}, {'accuracy': 0.90732}, {'accuracy': 0.91551}, {'accuracy': 0.89831}, {'accuracy': 0.9010400000000001}, {'accuracy': 0.90277}, {'accuracy': 0.8995200000000001}, {'accuracy': 0.89917}, {'accuracy': 0.91881}, {'accuracy': 0.90434}, {'accuracy': 0.9085300000000002}, {'accuracy': 0.9135800000000002}, {'accuracy': 0.92254}, {'accuracy': 0.9187700000000001}, {'accuracy': 0.9087999999999999}, {'accuracy': 0.9136600000000001}, {'accuracy': 0.9227700000000001}, {'accuracy': 0.9028599999999999}, {'accuracy': 0.9295}, {'accuracy': 0.9293099999999999}, {'accuracy': 0.9287699999999999}, {'accuracy': 0.90283}, {'accuracy': 0.9220200000000002}, {'accuracy': 0.9121500000000001}, {'accuracy': 0.91014}, {'accuracy': 0.9219799999999999}, {'accuracy': 0.92034}, {'accuracy': 0.9117099999999999}, {'accuracy': 0.91935}, {'accuracy': 0.9403900000000001}, {'accuracy': 0.9287699999999999}, {'accuracy': 0.9316800000000001}, {'accuracy': 0.9136199999999999}, {'accuracy': 0.9288200000000002}, {'accuracy': 0.92201}, {'accuracy': 0.9118300000000001}, {'accuracy': 0.9386700000000001}, {'accuracy': 0.9144500000000001}, {'accuracy': 0.9343499999999999}, {'accuracy': 0.9202999999999999}, {'accuracy': 0.9155200000000001}, {'accuracy': 0.9369699999999999}, {'accuracy': 0.9465800000000002}, {'accuracy': 0.9286000000000001}, {'accuracy': 0.9178200000000001}, {'accuracy': 0.9172800000000001}, {'accuracy': 0.92271}, {'accuracy': 0.9366099999999999}, {'accuracy': 0.92341}, {'accuracy': 0.9194099999999998}, {'accuracy': 0.91191}, {'accuracy': 0.9255800000000001}, {'accuracy': 0.9335100000000001}, {'accuracy': 0.9301800000000002}, {'accuracy': 0.94069}, {'accuracy': 0.9324}, {'accuracy': 0.93276}, {'accuracy': 0.92289}, {'accuracy': 0.9359299999999999}, {'accuracy': 0.9438700000000001}, {'accuracy': 0.92933}, {'accuracy': 0.9205499999999999}, {'accuracy': 0.93672}, {'accuracy': 0.9146700000000001}, {'accuracy': 0.8543800000000001}, {'accuracy': 0.8536199999999999}, {'accuracy': 0.92954}, {'accuracy': 0.93407}, {'accuracy': 0.94031}, {'accuracy': 0.9381299999999999}, {'accuracy': 0.9486100000000001}, {'accuracy': 0.9480299999999999}, {'accuracy': 0.9453699999999999}, {'accuracy': 0.9488999999999999}, {'accuracy': 0.9504400000000001}, {'accuracy': 0.9508399999999998}, {'accuracy': 0.95257}, {'accuracy': 0.95}, {'accuracy': 0.9535199999999999}, {'accuracy': 0.95021}, {'accuracy': 0.95604}, {'accuracy': 0.95482}, {'accuracy': 0.95365}, {'accuracy': 0.95268}, {'accuracy': 0.9558}, {'accuracy': 0.95407}, {'accuracy': 0.95368}, {'accuracy': 0.95475}, {'accuracy': 0.9557299999999997}, {'accuracy': 0.95551}, {'accuracy': 0.95564}, {'accuracy': 0.9560599999999999}, {'accuracy': 0.95778}, {'accuracy': 0.9566100000000001}, {'accuracy': 0.9569799999999999}, {'accuracy': 0.9591200000000001}, {'accuracy': 0.9600899999999999}, {'accuracy': 0.95739}, {'accuracy': 0.95766}, {'accuracy': 0.9602499999999999}, {'accuracy': 0.9562799999999999}, {'accuracy': 0.9581600000000001}, {'accuracy': 0.95863}, {'accuracy': 0.95831}, {'accuracy': 0.95942}, {'accuracy': 0.9608500000000001}, {'accuracy': 0.95809}, {'accuracy': 0.9586599999999998}, {'accuracy': 0.96038}, {'accuracy': 0.9594099999999999}, {'accuracy': 0.9614499999999999}, {'accuracy': 0.9601600000000001}, {'accuracy': 0.9578200000000001}, {'accuracy': 0.95802}, {'accuracy': 0.95882}, {'accuracy': 0.9572499999999999}, {'accuracy': 0.95953}, {'accuracy': 0.9590400000000001}, {'accuracy': 0.9582600000000001}, {'accuracy': 0.9596600000000001}, {'accuracy': 0.96175}, {'accuracy': 0.9617700000000001}, {'accuracy': 0.9589000000000001}, {'accuracy': 0.96235}, {'accuracy': 0.9615500000000001}, {'accuracy': 0.9616}, {'accuracy': 0.9614699999999999}, {'accuracy': 0.9606600000000001}, {'accuracy': 0.96154}, {'accuracy': 0.9608399999999999}, {'accuracy': 0.95976}, {'accuracy': 0.96219}, {'accuracy': 0.96022}, {'accuracy': 0.9596600000000001}, {'accuracy': 0.9616900000000002}, {'accuracy': 0.96187}, {'accuracy': 0.9600399999999999}, {'accuracy': 0.9601799999999999}, {'accuracy': 0.9599300000000002}, {'accuracy': 0.9619199999999999}, {'accuracy': 0.9590400000000001}, {'accuracy': 0.9600200000000001}, {'accuracy': 0.9608699999999999}, {'accuracy': 0.96057}, {'accuracy': 0.9606100000000002}, {'accuracy': 0.9618699999999999}, {'accuracy': 0.96082}, {'accuracy': 0.96181}, {'accuracy': 0.96362}, {'accuracy': 0.9620900000000001}, {'accuracy': 0.9631500000000001}, {'accuracy': 0.9609799999999998}, {'accuracy': 0.96112}, {'accuracy': 0.9612700000000001}, {'accuracy': 0.96168}, {'accuracy': 0.9630099999999999}, {'accuracy': 0.96118}, {'accuracy': 0.96273}, {'accuracy': 0.96286}, {'accuracy': 0.9607899999999999}, {'accuracy': 0.9626899999999999}, {'accuracy': 0.95939}, {'accuracy': 0.9594000000000001}, {'accuracy': 0.9641500000000001}, {'accuracy': 0.9624599999999999}, {'accuracy': 0.9619199999999999}, {'accuracy': 0.9628}, {'accuracy': 0.96288}, {'accuracy': 0.96054}, {'accuracy': 0.9634}, {'accuracy': 0.9624}, {'accuracy': 0.96431}, {'accuracy': 0.96295}, {'accuracy': 0.96183}, {'accuracy': 0.9644}, {'accuracy': 0.9616}, {'accuracy': 0.9606899999999999}, {'accuracy': 0.96196}, {'accuracy': 0.96194}, {'accuracy': 0.9624600000000001}, {'accuracy': 0.9614499999999999}, {'accuracy': 0.9630700000000001}, {'accuracy': 0.9628}, {'accuracy': 0.96376}, {'accuracy': 0.96289}, {'accuracy': 0.9625999999999999}, {'accuracy': 0.9644999999999999}, {'accuracy': 0.9624900000000001}, {'accuracy': 0.9618800000000001}, {'accuracy': 0.96355}, {'accuracy': 0.9621799999999998}, {'accuracy': 0.96386}, {'accuracy': 0.9637499999999999}, {'accuracy': 0.9618}, {'accuracy': 0.96221}, {'accuracy': 0.9625600000000001}, {'accuracy': 0.9619800000000002}, {'accuracy': 0.9616499999999999}, {'accuracy': 0.9619500000000001}, {'accuracy': 0.9632099999999999}, {'accuracy': 0.96146}, {'accuracy': 0.9623800000000001}, {'accuracy': 0.96261}, {'accuracy': 0.9616800000000001}, {'accuracy': 0.9619900000000001}, {'accuracy': 0.9623100000000001}, {'accuracy': 0.96326}, {'accuracy': 0.9620599999999999}, {'accuracy': 0.9614300000000002}, {'accuracy': 0.96198}, {'accuracy': 0.9641}, {'accuracy': 0.96144}, {'accuracy': 0.9634199999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b6fe361-f901-46d7-9d2c-4115348e2c32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7841fd69-ca01-4606-a24f-d738656aec1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "807d7f2a-82f0-4eb0-87b3-16c12b858658",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bae54dd6-b750-4d0f-b7d7-dbfd6d47b477",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fed96cb2-6162-4f95-98dc-751d7df92bdd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef600db7-d683-4505-a56a-445e421b20b1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e4c9bc5-ba07-4a7e-a6e2-04890ab79090",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e40e221b-8dcb-46ab-9553-28b6acfb655d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6387fa3c-e415-460f-a720-e27c58a65b95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "991bb160-bf53-469f-a389-59087784fe27",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "424a29ca-3388-457c-9aab-e4b6067a2758",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc9e6763-7fec-4cb5-b6b3-13415edefbb0",
   "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
}
