{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6012\n",
      "[[  0 580]\n",
      " [  1 589]\n",
      " [  2 589]\n",
      " [  3 552]\n",
      " [  4 645]\n",
      " [  5 616]\n",
      " [  6 627]\n",
      " [  7 594]\n",
      " [  8 651]\n",
      " [  9 592]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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([2, 5, 4,  ..., 3, 4, 4])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12058\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 295]\n",
      " [  1 635]\n",
      " [  2 298]\n",
      " [  3 615]\n",
      " [  4 314]\n",
      " [  5 609]\n",
      " [  6 297]\n",
      " [  7 593]\n",
      " [  8 566]\n",
      " [  9 573]]\n",
      "[[   0 1455]\n",
      " [   1  635]\n",
      " [   2  323]\n",
      " [   3  615]\n",
      " [   4  374]\n",
      " [   5  609]\n",
      " [   6  456]\n",
      " [   7  593]\n",
      " [   8  566]\n",
      " [   9  573]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([2, 5, 3,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4d833f7b-f8f3-4217-98da-aafd3ed6d467",
   "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\">161023-00:02:14 </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;36m161023-00:02:14\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": "d5ac1d7372154d8086a91ec8b75ac73a",
       "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\">161023-01:04:06 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3336</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-01:04:06\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3336\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\">4921087056</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;36m4921087056\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.1}, {'accuracy': 0.13116}, {'accuracy': 0.16807}, {'accuracy': 0.18713000000000002}, {'accuracy': 0.2105}, {'accuracy': 0.27666999999999997}, {'accuracy': 0.32936}, {'accuracy': 0.14526}, {'accuracy': 0.21630999999999995}, {'accuracy': 0.26914000000000005}, {'accuracy': 0.20385}, {'accuracy': 0.13501000000000002}, {'accuracy': 0.25138000000000005}, {'accuracy': 0.18958000000000003}, {'accuracy': 0.24992000000000006}, {'accuracy': 0.25015}, {'accuracy': 0.26017999999999997}, {'accuracy': 0.4076099999999999}, {'accuracy': 0.37039999999999995}, {'accuracy': 0.19024000000000002}, {'accuracy': 0.27747}, {'accuracy': 0.30243000000000003}, {'accuracy': 0.29067}, {'accuracy': 0.28249}, {'accuracy': 0.37715}, {'accuracy': 0.27379000000000003}, {'accuracy': 0.36974}, {'accuracy': 0.26198}, {'accuracy': 0.27503}, {'accuracy': 0.4136699999999999}, {'accuracy': 0.27876}, {'accuracy': 0.23198999999999997}, {'accuracy': 0.30479}, {'accuracy': 0.41817000000000004}, {'accuracy': 0.38245000000000007}, {'accuracy': 0.49649}, {'accuracy': 0.43137}, {'accuracy': 0.48519999999999996}, {'accuracy': 0.36689999999999995}, {'accuracy': 0.37126000000000003}, {'accuracy': 0.44159}, {'accuracy': 0.26211999999999996}, {'accuracy': 0.30555999999999994}, {'accuracy': 0.32293000000000005}, {'accuracy': 0.33945}, {'accuracy': 0.28628}, {'accuracy': 0.3171}, {'accuracy': 0.45921}, {'accuracy': 0.39401}, {'accuracy': 0.37268000000000007}, {'accuracy': 0.41692}, {'accuracy': 0.5163800000000001}, {'accuracy': 0.24463}, {'accuracy': 0.4166499999999999}, {'accuracy': 0.31988000000000005}, {'accuracy': 0.46609999999999996}, {'accuracy': 0.37467}, {'accuracy': 0.27304}, {'accuracy': 0.29882000000000003}, {'accuracy': 0.4008}, {'accuracy': 0.2669}, {'accuracy': 0.38392}, {'accuracy': 0.39788}, {'accuracy': 0.25586}, {'accuracy': 0.3372}, {'accuracy': 0.37293000000000004}, {'accuracy': 0.37150000000000005}, {'accuracy': 0.36556999999999995}, {'accuracy': 0.33912}, {'accuracy': 0.5741}, {'accuracy': 0.46676}, {'accuracy': 0.28358}, {'accuracy': 0.47196999999999995}, {'accuracy': 0.43038}, {'accuracy': 0.39609}, {'accuracy': 0.22527999999999998}, {'accuracy': 0.24896999999999997}, {'accuracy': 0.49437999999999993}, {'accuracy': 0.32148000000000004}, {'accuracy': 0.21134}, {'accuracy': 0.34719}, {'accuracy': 0.21773000000000003}, {'accuracy': 0.40964}, {'accuracy': 0.37474999999999997}, {'accuracy': 0.43356000000000006}, {'accuracy': 0.29079}, {'accuracy': 0.29562}, {'accuracy': 0.25863}, {'accuracy': 0.36521999999999993}, {'accuracy': 0.32084999999999997}, {'accuracy': 0.37503000000000003}, {'accuracy': 0.32363}, {'accuracy': 0.38115000000000004}, {'accuracy': 0.51406}, {'accuracy': 0.36252999999999996}, {'accuracy': 0.5262}, {'accuracy': 0.5856199999999999}, {'accuracy': 0.37438000000000005}, {'accuracy': 0.3831300000000001}, {'accuracy': 0.3436}, {'accuracy': 0.39117}, {'accuracy': 0.33585}, {'accuracy': 0.2044}, {'accuracy': 0.40186}, {'accuracy': 0.35677000000000003}, {'accuracy': 0.48984999999999995}, {'accuracy': 0.29291}, {'accuracy': 0.35773}, {'accuracy': 0.29470999999999997}, {'accuracy': 0.31754999999999994}, {'accuracy': 0.46451999999999993}, {'accuracy': 0.37168999999999996}, {'accuracy': 0.36222}, {'accuracy': 0.39383}, {'accuracy': 0.29590000000000005}, {'accuracy': 0.43945999999999996}, {'accuracy': 0.42463999999999996}, {'accuracy': 0.29867000000000005}, {'accuracy': 0.44803999999999994}, {'accuracy': 0.42567999999999995}, {'accuracy': 0.17901}, {'accuracy': 0.28641}, {'accuracy': 0.33986999999999995}, {'accuracy': 0.26908}, {'accuracy': 0.40201000000000003}, {'accuracy': 0.36750999999999995}, {'accuracy': 0.28787999999999997}, {'accuracy': 0.37209}, {'accuracy': 0.23975}, {'accuracy': 0.31855}, {'accuracy': 0.37709}, {'accuracy': 0.32053000000000004}, {'accuracy': 0.55497}, {'accuracy': 0.32544000000000006}, {'accuracy': 0.46586}, {'accuracy': 0.38848000000000005}, {'accuracy': 0.36386}, {'accuracy': 0.3191}, {'accuracy': 0.5154400000000001}, {'accuracy': 0.34122}, {'accuracy': 0.5628400000000001}, {'accuracy': 0.41952999999999996}, {'accuracy': 0.38447000000000003}, {'accuracy': 0.41708}, {'accuracy': 0.37033000000000005}, {'accuracy': 0.4166}, {'accuracy': 0.3537}, {'accuracy': 0.36480999999999997}, {'accuracy': 0.5484799999999999}, {'accuracy': 0.30063000000000006}, {'accuracy': 0.24620999999999998}, {'accuracy': 0.41808999999999996}, {'accuracy': 0.35374999999999995}, {'accuracy': 0.29652}, {'accuracy': 0.24930999999999998}, {'accuracy': 0.41734}, {'accuracy': 0.4553}, {'accuracy': 0.27286}, {'accuracy': 0.36202}, {'accuracy': 0.33890000000000003}, {'accuracy': 0.36366}, {'accuracy': 0.41968000000000005}, {'accuracy': 0.22114000000000003}, {'accuracy': 0.3619}, {'accuracy': 0.42097999999999997}, {'accuracy': 0.31468}, {'accuracy': 0.44711999999999996}, {'accuracy': 0.3578800000000001}, {'accuracy': 0.43369}, {'accuracy': 0.24793000000000004}, {'accuracy': 0.33612000000000003}, {'accuracy': 0.43671}, {'accuracy': 0.31406999999999996}, {'accuracy': 0.37555}, {'accuracy': 0.26348}, {'accuracy': 0.53869}, {'accuracy': 0.42289000000000004}, {'accuracy': 0.40074000000000004}, {'accuracy': 0.38791000000000003}, {'accuracy': 0.38287}, {'accuracy': 0.39349}, {'accuracy': 0.30594}, {'accuracy': 0.39602}, {'accuracy': 0.49661}, {'accuracy': 0.41238}, {'accuracy': 0.4306099999999999}, {'accuracy': 0.44709000000000004}, {'accuracy': 0.4309299999999999}, {'accuracy': 0.4930199999999999}, {'accuracy': 0.31184}, {'accuracy': 0.39423}, {'accuracy': 0.33614}, {'accuracy': 0.27188}, {'accuracy': 0.35785}, {'accuracy': 0.24797000000000002}, {'accuracy': 0.30688}, {'accuracy': 0.54312}, {'accuracy': 0.36733}, {'accuracy': 0.34749}, {'accuracy': 0.44365999999999994}, {'accuracy': 0.42443}, {'accuracy': 0.57724}, {'accuracy': 0.6729700000000001}, {'accuracy': 0.7119000000000001}, {'accuracy': 0.67089}, {'accuracy': 0.6865}, {'accuracy': 0.69445}, {'accuracy': 0.7249800000000001}, {'accuracy': 0.64555}, {'accuracy': 0.67971}, {'accuracy': 0.65093}, {'accuracy': 0.67788}, {'accuracy': 0.7147600000000001}, {'accuracy': 0.70591}, {'accuracy': 0.7588300000000001}, {'accuracy': 0.7263}, {'accuracy': 0.6896899999999999}, {'accuracy': 0.72033}, {'accuracy': 0.66861}, {'accuracy': 0.65379}, {'accuracy': 0.6894899999999999}, {'accuracy': 0.69177}, {'accuracy': 0.6849}, {'accuracy': 0.67571}, {'accuracy': 0.7101}, {'accuracy': 0.65926}, {'accuracy': 0.70191}, {'accuracy': 0.68339}, {'accuracy': 0.66092}, {'accuracy': 0.7267699999999999}, {'accuracy': 0.64583}, {'accuracy': 0.6821200000000001}, {'accuracy': 0.67247}, {'accuracy': 0.6642499999999998}, {'accuracy': 0.68948}, {'accuracy': 0.6750099999999999}, {'accuracy': 0.64817}, {'accuracy': 0.68094}, {'accuracy': 0.72857}, {'accuracy': 0.68005}, {'accuracy': 0.6301500000000001}, {'accuracy': 0.6954}, {'accuracy': 0.6620499999999999}, {'accuracy': 0.69293}, {'accuracy': 0.66376}, {'accuracy': 0.6716299999999998}, {'accuracy': 0.7100500000000001}, {'accuracy': 0.67965}, {'accuracy': 0.73444}, {'accuracy': 0.71689}, {'accuracy': 0.64696}, {'accuracy': 0.70219}, {'accuracy': 0.70058}, {'accuracy': 0.68057}, {'accuracy': 0.66483}, {'accuracy': 0.7014800000000001}, {'accuracy': 0.6871200000000001}, {'accuracy': 0.70809}, {'accuracy': 0.67052}, {'accuracy': 0.7025499999999999}, {'accuracy': 0.71899}, {'accuracy': 0.68247}, {'accuracy': 0.6817399999999999}, {'accuracy': 0.71237}, {'accuracy': 0.68577}, {'accuracy': 0.7336199999999999}, {'accuracy': 0.7253699999999998}, {'accuracy': 0.7173999999999999}, {'accuracy': 0.64745}, {'accuracy': 0.63319}, {'accuracy': 0.65646}, {'accuracy': 0.72486}, {'accuracy': 0.61684}, {'accuracy': 0.73133}, {'accuracy': 0.66162}, {'accuracy': 0.7066600000000001}, {'accuracy': 0.6952499999999999}, {'accuracy': 0.68858}, {'accuracy': 0.68232}, {'accuracy': 0.72918}, {'accuracy': 0.66627}, {'accuracy': 0.72881}, {'accuracy': 0.62436}, {'accuracy': 0.7091100000000001}, {'accuracy': 0.68017}, {'accuracy': 0.63239}, {'accuracy': 0.67321}, {'accuracy': 0.75858}, {'accuracy': 0.65739}, {'accuracy': 0.71539}, {'accuracy': 0.69301}, {'accuracy': 0.7108}, {'accuracy': 0.67052}, {'accuracy': 0.70265}, {'accuracy': 0.70005}, {'accuracy': 0.6843499999999999}, {'accuracy': 0.7001000000000002}, {'accuracy': 0.74089}, {'accuracy': 0.71635}, {'accuracy': 0.7065000000000001}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a043d489-514c-4443-9417-34d8625ec68d",
   "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.71</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.71\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAADHhElEQVR4nOydd5wU9f3/XzNbrxeOO+A4ug2pQiD2hpKoiZqoSGwh6tdoSDR8jdGvUdOxR2OPP3uKJEYTjQmoKMaCFbEgIKJ0rsAd12/LzPz+mP3MfKbuzN3e7t3e+/l48AD2Znc/Ozu3n9e+3k1QFEUBQRAEQRBEniDmegEEQRAEQRCZhMQNQRAEQRB5BYkbgiAIgiDyChI3BEEQBEHkFSRuCIIgCILIK0jcEARBEASRV5C4IQiCIAgiryBxQxAEQRBEXkHihiAIgiCIvILEDUEQ/cqqVasgCAJWrVql3fbd734X48aNy9ma8omf//znEAQh18sgiAEFiRuCGOCsW7cO5557LmpraxGJRDBq1Cicc845WLduXa6X1u/ce++9ePTRR/v1OT799FP8/Oc/x5YtW/r1ebLJb3/7W/zjH//I9TIIImeQuCGIAczTTz+NQw45BCtXrsSiRYtw77334sILL8Qrr7yCQw45BM8880yul9ivZEvc/OIXvyBxQxB5RDDXCyAIwp7NmzfjvPPOw4QJE/Df//4Xw4cP1352+eWX48gjj8R5552Hjz76CBMmTMjaujo7O1FUVJS15xsM0DkhiIEFOTcEMUC55ZZb0NXVhT/84Q8GYQMAVVVVeOCBB9DZ2Ymbb74ZAPDUU09BEAS8+uqrlsd64IEHIAgCPvnkE+22DRs24IwzzkBlZSWi0Shmz56NZ5991nC/Rx99VHvMyy67DNXV1Rg9ejQAYOvWrbjssstwwAEHoKCgAMOGDcOZZ56ZMQdk3LhxWLduHV599VUIggBBEHDMMcdoP9+3bx+uuOIK1NXVIRKJYNKkSbjpppsgy7LhcZ588knMmjULJSUlKC0txdSpU3HnnXdqr+/MM88EABx77LHa8/D5QWa++93vori4GJs3b8ZJJ52EkpISnHPOOQAAWZZxxx134OCDD0Y0GkVNTQ0uueQStLS0GB7jvffew/z581FVVYWCggKMHz8e3/ve97Sf2+UpAcCWLVsgCIKrmyUIAjo7O/HYY49pr+e73/0uAKC9vR1XXHEFxo0bh0gkgurqapxwwglYs2aN4+MRxGCEnBuCGKA899xzGDduHI488kjbnx911FEYN24cnn/+eQDAySefjOLiYvz1r3/F0UcfbTh22bJlOPjggzFlyhQAah7P4YcfjtraWlx99dUoKirCX//6V5x22mn4+9//jtNPP91w/8suuwzDhw/H9ddfj87OTgDAu+++izfffBNnn302Ro8ejS1btuC+++7DMcccg08//RSFhYV9ev133HEHfvjDH6K4uBjXXnstAKCmpgYA0NXVhaOPPho7d+7EJZdcgjFjxuDNN9/ENddcg927d+OOO+4AALz44otYuHAhjj/+eNx0000AgPXr1+ONN97A5ZdfjqOOOgo/+tGP8Pvf/x7/93//h4MOOggAtL+dSCaTmD9/Po444gjceuut2mu95JJL8Oijj2LRokX40Y9+hC+//BJ33303PvjgA7zxxhsIhUJobGzEiSeeiOHDh+Pqq69GeXk5tmzZgqeffrpP54vxxBNP4KKLLsKcOXPwP//zPwCAiRMnAgC+//3v46mnnsLixYsxefJk7N27F6+//jrWr1+PQw45JCPPTxADAoUgiAHHvn37FADKqaee6nrcN7/5TQWA0tbWpiiKoixcuFCprq5Wksmkdszu3bsVURSVX/7yl9ptxx9/vDJ16lSlp6dHu02WZeWwww5T9ttvP+22Rx55RAGgHHHEEYbHVBRF6erqsqxn9erVCgDl8ccf12575ZVXFADKK6+8ot12wQUXKGPHjnV9bYqiKAcffLBy9NFHW27/1a9+pRQVFSmfffaZ4farr75aCQQCyrZt2xRFUZTLL79cKS0ttayd529/+5tlfW5ccMEFCgDl6quvNtz+2muvKQCUP/3pT4bbly9fbrj9mWeeUQAo7777ruNz2J0zRVGUL7/8UgGgPPLII9ptN9xwg2L+KC8qKlIuuOACy+OWlZUpP/jBDzy8SoIY3FBYiiAGIO3t7QCAkpIS1+PYz9va2gAACxYsQGNjoyGc8dRTT0GWZSxYsAAA0NzcjJdffhlnnXUW2tvbsWfPHuzZswd79+7F/PnzsWnTJuzcudPwPBdffDECgYDhtoKCAu3fiUQCe/fuxaRJk1BeXt7vYY6//e1vOPLII1FRUaGtf8+ePZg3bx4kScJ///tfAEB5eTk6Ozvx4osvZnwNl156qWVNZWVlOOGEEwxrmjVrFoqLi/HKK69oawKAf/3rX0gkEhlflxvl5eV4++23sWvXrqw+L0FkGxI3BDEAYaKFiRwnzCLoa1/7GsrKyrBs2TLtmGXLlmHGjBnYf//9AQCff/45FEXBddddh+HDhxv+3HDDDQCAxsZGw/OMHz/e8tzd3d24/vrrtZyXqqoqDB8+HPv27UNra2svX7k3Nm3ahOXLl1vWP2/ePMP6L7vsMuy///74+te/jtGjR+N73/seli9f3ufnDwaDWu4Rv6bW1lZUV1db1tXR0aGt6eijj8a3v/1t/OIXv0BVVRVOPfVUPPLII4jFYn1eVzpuvvlmfPLJJ6irq8OcOXPw85//HF988UW/Py9BZBvKuSGIAUhZWRlGjhyJjz76yPW4jz76CLW1tSgtLQUARCIRnHbaaXjmmWdw7733oqGhAW+88QZ++9vfavdhCbdXXnkl5s+fb/u4kyZNMvyfd2kYP/zhD/HII4/giiuuwKGHHoqysjIIgoCzzz7bktSbaWRZxgknnICrrrrK9udMyFVXV2Pt2rVYsWIF/vOf/+A///kPHnnkEZx//vl47LHHev38kUgEomj8bijLMqqrq/GnP/3J9j4sKVwQBDz11FN466238Nxzz2HFihX43ve+h9tuuw1vvfUWiouLHZvySZLU6zUDwFlnnYUjjzwSzzzzDF544QXccsstuOmmm/D000/j61//ep8emyAGEiRuCGKAcsopp+DBBx/E66+/jiOOOMLy89deew1btmzBJZdcYrh9wYIFeOyxx7By5UqsX78eiqJoISkAWtl4KBTSnI7e8NRTT+GCCy7Abbfdpt3W09ODffv29foxzTht8hMnTkRHR4en9YfDYXzjG9/AN77xDciyjMsuuwwPPPAArrvuOkyaNClj3X0nTpyIl156CYcffritGDTz1a9+FV/96lfxm9/8Bn/+859xzjnn4Mknn8RFF12EiooKALCcy61bt3pai9trGjlyJC677DJcdtllaGxsxCGHHILf/OY3JG6IvILCUgQxQPnJT36CgoICXHLJJdi7d6/hZ83Nzfj+97+PwsJC/OQnPzH8bN68eaisrMSyZcuwbNkyzJkzxxBWqq6uxjHHHIMHHngAu3fvtjxvU1OTp/UFAgEoimK47a677uqzu8BTVFRkK5bOOussrF69GitW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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\")\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecbbe105-9bf7-445c-98fa-8978922c9d1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ef2d273-250d-450a-a662-a7b72def491b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90e437aa-9da1-4ab9-9e45-ba89e95f207a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb4baa5-ba6c-4102-91e4-111c3b0b5fa2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b1dc97-431b-4a8f-ba04-61d4c3cc6abd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8986be3-03f4-4ebc-bfd3-794fbef7f9ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcd47ac2-d80f-4e13-9b76-d03483431081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc113a2c-dfd9-4dae-a973-ba5925b4f9bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6ac9abe-848f-49c2-9fc8-c94e75015695",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22f6eba1-7059-491f-bacd-0739425d9305",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d98f7ea7-9936-4a3b-8585-ecfc1913085e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "746d526e-8881-4cb2-b68d-452746c6d54d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da48ec35-c3a6-40d0-9270-3198f50624fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd1aaa-0b48-4c79-ab96-9e1ae83cc05b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8b3c3b92-ba26-4008-9d3b-9068a9768146",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cbc4ee05-4aec-4c06-8faf-c26966b07332",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f521b66-3f44-4f12-bb99-e91100023532",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cc3491e-ccd3-4127-ae5a-f74cac361803",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0181c8e-beaa-4701-b157-a88a549f8c95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f7572043-4333-441f-b3a4-53c75405e9f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd1643cf-0373-48b9-863d-52c213d93bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "241bf1d6-ef0c-45d0-b8c7-b2a05a865e2e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "42509b96-38aa-491a-89d8-45f4742d61d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05ef107d-a96c-448a-900a-9b1e4caaee10",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86ca87d3-20a4-4825-ac22-386edb54fd18",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bda17628-79d8-4ec1-a3de-2c7a6f137766",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80ff05c3-45d2-4378-ab5a-39412f177e8a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f84758ab-dce5-4218-af41-da07711b15ce",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "695407e9-1e87-46ac-b44f-4e185e980b52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "868cbfd0-1468-4905-9ed7-cad772bbda0b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97ea53b0-dc3d-4845-8322-09f46e991e95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9abda44-f06f-4e11-a6e5-b1986711417f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bac92a89-ab7a-461a-be16-c82b7e4a9bc3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed490103-9935-442f-85d2-8c26446a261d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91a79507-8ee1-43f9-a684-a4abf9965f6d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a34801d-d29b-410b-8188-d3d467a04e0e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac4e23ee-a0fc-4eb6-b601-5ddeff7ab7b3",
   "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
}
