{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "70cbe109-6ca2-4e45-9d58-d3765bf2a22b",
   "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": [
      "torch.Size([60000])\n",
      "6016\n",
      "[[  0 570]\n",
      " [  1 651]\n",
      " [  2 621]\n",
      " [  3 616]\n",
      " [  4 580]\n",
      " [  5 570]\n",
      " [  6 580]\n",
      " [  7 626]\n",
      " [  8 587]\n",
      " [  9 607]]\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",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([9, 2, 0,  ..., 8, 0, 7])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "29994\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 314]\n",
      " [  1 343]\n",
      " [  2 290]\n",
      " [  3 304]\n",
      " [  4 278]\n",
      " [  5 287]\n",
      " [  6 296]\n",
      " [  7 306]\n",
      " [  8 274]\n",
      " [  9 309]]\n",
      "[[   0 1658]\n",
      " [   1  368]\n",
      " [   2  315]\n",
      " [   3  333]\n",
      " [   4  317]\n",
      " [   5  384]\n",
      " [   6  451]\n",
      " [   7  586]\n",
      " [   8  706]\n",
      " [   9 1014]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 1, 3,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:03:40 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:03:40\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "84aece5e4783482eb3f0deef657c845c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:11:37 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3398</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:11:37\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3398\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\">74212320</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;36m74212320\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10228999999999999}, {'accuracy': 0.10031000000000001}, {'accuracy': 0.10194}, {'accuracy': 0.10380999999999999}, {'accuracy': 0.19441000000000003}, {'accuracy': 0.23243999999999998}, {'accuracy': 0.32408000000000003}, {'accuracy': 0.25193}, {'accuracy': 0.25166}, {'accuracy': 0.30946}, {'accuracy': 0.40212000000000003}, {'accuracy': 0.32443999999999995}, {'accuracy': 0.21858000000000005}, {'accuracy': 0.15224}, {'accuracy': 0.29477000000000003}, {'accuracy': 0.24872}, {'accuracy': 0.32315}, {'accuracy': 0.42268000000000006}, {'accuracy': 0.43298000000000003}, {'accuracy': 0.37053}, {'accuracy': 0.4228700000000001}, {'accuracy': 0.38391}, {'accuracy': 0.3668599999999999}, {'accuracy': 0.37042}, {'accuracy': 0.47361999999999993}, {'accuracy': 0.31782999999999995}, {'accuracy': 0.4903799999999999}, {'accuracy': 0.33951000000000003}, {'accuracy': 0.3638}, {'accuracy': 0.42311999999999994}, {'accuracy': 0.33521999999999996}, {'accuracy': 0.4182600000000001}, {'accuracy': 0.24424}, {'accuracy': 0.32824}, {'accuracy': 0.24384}, {'accuracy': 0.34053000000000005}, {'accuracy': 0.4612900000000001}, {'accuracy': 0.37639999999999996}, {'accuracy': 0.39100999999999997}, {'accuracy': 0.38086000000000003}, {'accuracy': 0.54373}, {'accuracy': 0.28285}, {'accuracy': 0.43004}, {'accuracy': 0.39293999999999996}, {'accuracy': 0.30278}, {'accuracy': 0.28792}, {'accuracy': 0.33219000000000004}, {'accuracy': 0.44016}, {'accuracy': 0.24418}, {'accuracy': 0.23618000000000006}, {'accuracy': 0.40774999999999995}, {'accuracy': 0.39083}, {'accuracy': 0.33094999999999997}, {'accuracy': 0.28290000000000004}, {'accuracy': 0.38255}, {'accuracy': 0.30008}, {'accuracy': 0.39557}, {'accuracy': 0.44408999999999993}, {'accuracy': 0.35837}, {'accuracy': 0.20716}, {'accuracy': 0.39683999999999997}, {'accuracy': 0.22181}, {'accuracy': 0.25913}, {'accuracy': 0.44424}, {'accuracy': 0.34198}, {'accuracy': 0.38122}, {'accuracy': 0.33503999999999995}, {'accuracy': 0.31536000000000003}, {'accuracy': 0.38654}, {'accuracy': 0.36994}, {'accuracy': 0.47112}, {'accuracy': 0.44329}, {'accuracy': 0.36236999999999997}, {'accuracy': 0.27391}, {'accuracy': 0.32283}, {'accuracy': 0.30705}, {'accuracy': 0.28047}, {'accuracy': 0.21608999999999998}, {'accuracy': 0.35036999999999996}, {'accuracy': 0.38655999999999996}, {'accuracy': 0.42397}, {'accuracy': 0.29758000000000007}, {'accuracy': 0.34401}, {'accuracy': 0.33246000000000003}, {'accuracy': 0.30313999999999997}, {'accuracy': 0.40476999999999996}, {'accuracy': 0.20146000000000003}, {'accuracy': 0.42176}, {'accuracy': 0.36507999999999996}, {'accuracy': 0.30196000000000006}, {'accuracy': 0.30308}, {'accuracy': 0.33655}, {'accuracy': 0.30784}, {'accuracy': 0.31019}, {'accuracy': 0.29145999999999994}, {'accuracy': 0.44907}, {'accuracy': 0.29995000000000005}, {'accuracy': 0.37010000000000004}, {'accuracy': 0.34452}, {'accuracy': 0.45159000000000005}, {'accuracy': 0.4338100000000001}, {'accuracy': 0.26702000000000004}, {'accuracy': 0.47928}, {'accuracy': 0.40557}, {'accuracy': 0.34516}, {'accuracy': 0.38898}, {'accuracy': 0.4312}, {'accuracy': 0.39889}, {'accuracy': 0.35080000000000006}, {'accuracy': 0.52218}, {'accuracy': 0.2766}, {'accuracy': 0.19197}, {'accuracy': 0.36335999999999996}, {'accuracy': 0.45663}, {'accuracy': 0.28795000000000004}, {'accuracy': 0.33777}, {'accuracy': 0.40488}, {'accuracy': 0.28132999999999997}, {'accuracy': 0.49985}, {'accuracy': 0.35580000000000006}, {'accuracy': 0.4462}, {'accuracy': 0.40689000000000003}, {'accuracy': 0.31903}, {'accuracy': 0.40504999999999997}, {'accuracy': 0.29847999999999997}, {'accuracy': 0.34458}, {'accuracy': 0.32337000000000005}, {'accuracy': 0.40248}, {'accuracy': 0.28537}, {'accuracy': 0.24416000000000002}, {'accuracy': 0.36235000000000006}, {'accuracy': 0.42578000000000005}, {'accuracy': 0.37527999999999995}, {'accuracy': 0.30155999999999994}, {'accuracy': 0.36411}, {'accuracy': 0.33918}, {'accuracy': 0.22355999999999998}, {'accuracy': 0.4063}, {'accuracy': 0.37836}, {'accuracy': 0.38241}, {'accuracy': 0.4003}, {'accuracy': 0.43200000000000005}, {'accuracy': 0.32357}, {'accuracy': 0.33988}, {'accuracy': 0.36843000000000004}, {'accuracy': 0.45091000000000003}, {'accuracy': 0.36513999999999996}, {'accuracy': 0.3237900000000001}, {'accuracy': 0.54356}, {'accuracy': 0.34740000000000004}, {'accuracy': 0.37545}, {'accuracy': 0.51858}, {'accuracy': 0.66321}, {'accuracy': 0.54229}, {'accuracy': 0.69628}, {'accuracy': 0.7019}, {'accuracy': 0.69648}, {'accuracy': 0.71118}, {'accuracy': 0.72774}, {'accuracy': 0.71211}, {'accuracy': 0.7193799999999999}, {'accuracy': 0.7311}, {'accuracy': 0.69211}, {'accuracy': 0.71251}, {'accuracy': 0.7034800000000001}, {'accuracy': 0.6950000000000001}, {'accuracy': 0.71099}, {'accuracy': 0.7188899999999999}, {'accuracy': 0.7294}, {'accuracy': 0.73652}, {'accuracy': 0.71565}, {'accuracy': 0.72118}, {'accuracy': 0.70662}, {'accuracy': 0.70632}, {'accuracy': 0.7323700000000001}, {'accuracy': 0.73349}, {'accuracy': 0.7207600000000001}, {'accuracy': 0.74654}, {'accuracy': 0.71603}, {'accuracy': 0.70438}, {'accuracy': 0.73786}, {'accuracy': 0.70815}, {'accuracy': 0.71277}, {'accuracy': 0.71106}, {'accuracy': 0.7240099999999999}, {'accuracy': 0.7032499999999999}, {'accuracy': 0.74461}, {'accuracy': 0.74718}, {'accuracy': 0.7102099999999999}, {'accuracy': 0.7377800000000001}, {'accuracy': 0.69519}, {'accuracy': 0.73316}, {'accuracy': 0.7003299999999999}, {'accuracy': 0.73021}, {'accuracy': 0.7114999999999999}, {'accuracy': 0.71877}, {'accuracy': 0.72534}, {'accuracy': 0.71293}, {'accuracy': 0.7243}, {'accuracy': 0.73643}, {'accuracy': 0.73441}, {'accuracy': 0.7430899999999999}, {'accuracy': 0.70671}, {'accuracy': 0.73128}, {'accuracy': 0.74087}, {'accuracy': 0.71865}, {'accuracy': 0.7356100000000001}, {'accuracy': 0.71849}, {'accuracy': 0.7221500000000001}, {'accuracy': 0.71952}, {'accuracy': 0.7386999999999999}, {'accuracy': 0.69804}, {'accuracy': 0.70321}, {'accuracy': 0.69167}, {'accuracy': 0.72312}, {'accuracy': 0.7000399999999999}, {'accuracy': 0.70892}, {'accuracy': 0.72445}, {'accuracy': 0.73896}, {'accuracy': 0.7}, {'accuracy': 0.70001}, {'accuracy': 0.67919}, {'accuracy': 0.6939300000000002}, {'accuracy': 0.73723}, {'accuracy': 0.72059}, {'accuracy': 0.72477}, {'accuracy': 0.71529}, {'accuracy': 0.7059200000000001}, {'accuracy': 0.7418199999999999}, {'accuracy': 0.70961}, {'accuracy': 0.7352700000000001}, {'accuracy': 0.70035}, {'accuracy': 0.70188}, {'accuracy': 0.71509}, {'accuracy': 0.72137}, {'accuracy': 0.70099}, {'accuracy': 0.6922}, {'accuracy': 0.7351599999999999}, {'accuracy': 0.69198}, {'accuracy': 0.7228899999999999}, {'accuracy': 0.7314}, {'accuracy': 0.7243600000000001}, {'accuracy': 0.70408}, {'accuracy': 0.70678}, {'accuracy': 0.7277600000000001}, {'accuracy': 0.70476}, {'accuracy': 0.71011}, {'accuracy': 0.7014400000000001}, {'accuracy': 0.72616}, {'accuracy': 0.7226700000000001}, {'accuracy': 0.7333000000000001}, {'accuracy': 0.71311}, {'accuracy': 0.7156}, {'accuracy': 0.73233}, {'accuracy': 0.71284}, {'accuracy': 0.70815}, {'accuracy': 0.6875600000000001}, {'accuracy': 0.7299599999999999}, {'accuracy': 0.73199}, {'accuracy': 0.7030799999999998}, {'accuracy': 0.72759}, {'accuracy': 0.71784}, {'accuracy': 0.72798}, {'accuracy': 0.6807}, {'accuracy': 0.6931499999999999}, {'accuracy': 0.73419}, {'accuracy': 0.7213299999999999}, {'accuracy': 0.7369}, {'accuracy': 0.7229999999999999}, {'accuracy': 0.7063900000000001}, {'accuracy': 0.70972}, {'accuracy': 0.7093800000000001}, {'accuracy': 0.71058}, {'accuracy': 0.7166399999999999}, {'accuracy': 0.7229800000000001}, {'accuracy': 0.73011}, {'accuracy': 0.71125}, {'accuracy': 0.6862199999999999}, {'accuracy': 0.69987}, {'accuracy': 0.71534}, {'accuracy': 0.7185300000000001}, {'accuracy': 0.75369}, {'accuracy': 0.72491}, {'accuracy': 0.7131299999999999}, {'accuracy': 0.7458}, {'accuracy': 0.7165999999999999}, {'accuracy': 0.72794}, {'accuracy': 0.7245199999999999}, {'accuracy': 0.69784}, {'accuracy': 0.729}, {'accuracy': 0.7268899999999999}, {'accuracy': 0.71056}, {'accuracy': 0.7335299999999999}, {'accuracy': 0.71175}, {'accuracy': 0.73552}, {'accuracy': 0.6885600000000001}, {'accuracy': 0.7060899999999999}, {'accuracy': 0.7085100000000001}, {'accuracy': 0.71689}, {'accuracy': 0.7171200000000001}]\n"
     ]
    }
   ],
   "source": [
    "\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(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "452c60a1-4a30-4745-bad2-89774d9472e8",
   "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.72</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.72\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACtnElEQVR4nOydd3wUZf7HP7M9vZAGIRCaKNJBEBVBiGDvipwniMrZ8FROT/l5gt6p2A/vLKin4p2nopy9YEHBAoo06b2EkoT0ssn2+f2x+8w+Mzuzjd1syH7frxcvktnZmWdmd/N89vMtjyCKogiCIAiCIIhOgi7RAyAIgiAIgoglJG4IgiAIguhUkLghCIIgCKJTQeKGIAiCIIhOBYkbgiAIgiA6FSRuCIIgCILoVJC4IQiCIAiiU0HihiAIgiCITgWJG4IgCIIgOhUkbgiCiAvLly+HIAhYvny5tO26665DaWlpwsbUmXjwwQchCEKih0EQHRISNwTRQdmyZQt+//vfo7i4GGazGd26dcM111yDLVu2JHpoceeFF17AokWL4nqOrVu34sEHH8T+/fvjep725NFHH8WHH36Y6GEQRMIhcUMQHZD3338fw4cPx7JlyzBjxgy88MILuOGGG/Ddd99h+PDh+OCDDxI9xLjSXuLmoYceInFDEJ0QQ6IHQBCEnD179uDaa69F79698f333yM/P1967I477sDYsWNx7bXXYuPGjejdu3e7jctqtSItLa3dznc8QPeEIDom5NwQRAfjySefRGtrK15++WWZsAGAvLw8vPTSS7BarXjiiScAAEuWLIEgCFixYkXAsV566SUIgoDNmzdL27Zv344rrrgCubm5sFgsGDlyJD7++GPZ8xYtWiQd89Zbb0VBQQG6d+8OADhw4ABuvfVW9O/fHykpKejSpQuuvPLKmDkgpaWl2LJlC1asWAFBECAIAsaPHy893tDQgDvvvBMlJSUwm83o27cvHn/8cXg8Htlx3nnnHYwYMQIZGRnIzMzEoEGD8Oyzz0rXd+WVVwIAzjrrLOk8fH6Qkuuuuw7p6enYs2cPzjvvPGRkZOCaa64BAHg8HixYsAAnn3wyLBYLCgsLcdNNN6G+vl52jDVr1mDy5MnIy8tDSkoKevXqheuvv156XC1PCQD2798PQRCCulmCIMBqteKNN96Qrue6664DADQ3N+POO+9EaWkpzGYzCgoKcPbZZ2PdunWaxyOI4xlybgiig/HJJ5+gtLQUY8eOVX38zDPPRGlpKT777DMAwPnnn4/09HS8++67GDdunGzfxYsX4+STT8bAgQMBePN4Tj/9dBQXF+O+++5DWloa3n33XVxyySX43//+h0svvVT2/FtvvRX5+fmYO3curFYrAODXX3/FypUrcfXVV6N79+7Yv38/XnzxRYwfPx5bt25FamrqMV3/ggULcPvttyM9PR33338/AKCwsBAA0NrainHjxuHw4cO46aab0KNHD6xcuRJz5sxBRUUFFixYAAD4+uuvMXXqVEycOBGPP/44AGDbtm346aefcMcdd+DMM8/EH//4R/zjH//A//3f/+Gkk04CAOl/LVwuFyZPnowzzjgDTz31lHStN910ExYtWoQZM2bgj3/8I/bt24fnnnsO69evx08//QSj0YijR49i0qRJyM/Px3333Yfs7Gzs378f77///jHdL8Z//vMf3HjjjRg1ahT+8Ic/AAD69OkDALj55puxZMkSzJo1CwMGDEBtbS1+/PFHbNu2DcOHD4/J+QmiQyESBNFhaGhoEAGIF198cdD9LrroIhGA2NTUJIqiKE6dOlUsKCgQXS6XtE9FRYWo0+nEv/71r9K2iRMnioMGDRJtNpu0zePxiKeddprYr18/advrr78uAhDPOOMM2TFFURRbW1sDxrNq1SoRgPjvf/9b2vbdd9+JAMTvvvtO2jZ9+nSxZ8+eQa9NFEXx5JNPFseNGxew/W9/+5uYlpYm7ty5U7b9vvvuE/V6vVheXi6KoijecccdYmZmZsDYed57772A8QVj+vTpIgDxvvvuk23/4YcfRADif//7X9n2pUuXyrZ/8MEHIgDx119/1TyH2j0TRVHct2+fCEB8/fXXpW3z5s0TlX/C09LSxOnTpwccNysrS7ztttvCuEqC6BxQWIogOhDNzc0AgIyMjKD7scebmpoAAFOmTMHRo0dl4YwlS5bA4/FgypQpAIC6ujp8++23uOqqq9Dc3IyamhrU1NSgtrYWkydPxq5du3D48GHZeWbOnAm9Xi/blpKSIv3sdDpRW1uLvn37Ijs7O+5hjvfeew9jx45FTk6ONP6amhqUlZXB7Xbj+++/BwBkZ2fDarXi66+/jvkYbrnlloAxZWVl4eyzz5aNacSIEUhPT8d3330njQkAPv30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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": "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": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25158f47-204c-497d-bf9a-b15aa83cf750",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa999e-5218-459b-aa18-c368d2b89a07",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d38c6bc-0648-4efd-bd10-c21686f81fb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65522bb9-83a9-4924-9ac4-ba3aeca46882",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd33447b-b31e-4cba-8293-c1aa029a6dfa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2f26062-db15-4120-ba56-68df79685aca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e591656a-baa0-4edc-89e3-049044e98344",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31a4acd0-0632-457b-b301-8b589d990ff8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddf3e669-ee89-4e26-95bb-8e8911c0cd0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "761cde60-3635-4679-bc41-5f47b92e1823",
   "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
}
