{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bbd277d-e9f9-454e-88ee-e22fc4b0f958",
   "metadata": {},
   "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",
    "    \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()\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",
    "\n",
    "\n",
    "tag1\n",
    "\n",
    "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<1:\n",
    "        if 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(9))\n",
    "        \n",
    "        elif target1[z]==1:\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]==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(1))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==3:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \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(3))      \n",
    "        \n",
    "        elif target1[z]==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(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif 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(5))     \n",
    "\n",
    "\n",
    "\n",
    "        elif target1[z]==7:\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]==8:\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(7))      \n",
    "        \n",
    "        elif target1[z]==9:\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(8))\n",
    "        \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",
    "\n",
    "\n",
    "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)\n",
    "\n",
    "\n",
    "\n",
    "\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",
    "\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n",
    "\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c49c03a4-166f-46b0-8e6b-619dd1880b25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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44+47LLL0LFjR2g0Gvz3v/+VPC8IAubNm4cOHTogISEBEydOxIEDByTbVFZW4oYbbkBqairS09Nx6623or6+vhXPovUIdr1uvvlmv8/ahRdeKNkmXq7XggULcNZZZyElJQW5ubm44oorsH//fsk2ofztHT9+HJdccgkSExORm5uLhx56CE6nszVPpcUJ5VqNGzfO77N1++23S7aJh2sFAK+//joGDhwoNuYbNWoUvvnmG/H5tva5InHTTJYtW4Y5c+Zg/vz52LZtGwYNGoTJkyejtLQ02kOLOmeeeSaKiorEn3Xr1onP3X///fjyyy/xySefYO3atTh9+jSuuuqqKI629bBYLBg0aBBeffVVxeefe+45/OMf/8DixYuxadMmJCUlYfLkybBareI2N9xwA3bv3o2VK1fif//7H3788Uf88Y9/bK1TaFWCXS8AuPDCCyWftQ8//FDyfLxcr7Vr1+Kuu+7Czz//jJUrV8LhcGDSpEmwWCziNsH+9lwuFy655BLY7XZs2LAB77zzDpYuXYp58+ZF45RajFCuFQDMmjVL8tl67rnnxOfi5VoBQKdOnfDMM89g69at+OWXXzB+/Hhcfvnl2L17N4A2+LkSiGYxYsQI4a677hJ/d7lcQseOHYUFCxZEcVTRZ/78+cKgQYMUn6uurhYMBoPwySefiI/t3btXACBs3LixlUbYNgAgfPbZZ+LvbrdbyM/PF55//nnxserqasFkMgkffvihIAiCsGfPHgGAsGXLFnGbb775RtBoNMKpU6dabezRQH69BEEQpk+fLlx++eWqr4nn61VaWioAENauXSsIQmh/e19//bWg1WqF4uJicZvXX39dSE1NFWw2W+ueQCsiv1aCIAhjx44V7r33XtXXxOu1YmRkZAj/+te/2uTnipybZmC327F161ZMnDhRfEyr1WLixInYuHFjFEfWNjhw4AA6duyI7t2744YbbsDx48cBAFu3boXD4ZBct759+6Jz585xf92OHDmC4uJiybVJS0vDyJEjxWuzceNGpKenY/jw4eI2EydOhFarxaZNm1p9zG2BNWvWIDc3F3369MEdd9yBiooK8bl4vl41NTUAgMzMTACh/e1t3LgRAwYMQF5enrjN5MmTUVtbK96lxyLya8V4//33kZ2djf79+2Pu3LloaGgQn4vXa+VyufDRRx/BYrFg1KhRbfJz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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.3085}, {'accuracy': 0.3797499999999999}, {'accuracy': 0.39239}, {'accuracy': 0.4021}, {'accuracy': 0.45402}, {'accuracy': 0.38834}, {'accuracy': 0.47491000000000005}, {'accuracy': 0.42934}, {'accuracy': 0.50118}, {'accuracy': 0.40245999999999993}, {'accuracy': 0.4787}, {'accuracy': 0.54203}, {'accuracy': 0.50082}, {'accuracy': 0.5227199999999999}, {'accuracy': 0.493}, {'accuracy': 0.55772}, {'accuracy': 0.5374}, {'accuracy': 0.50916}, {'accuracy': 0.57989}, {'accuracy': 0.5417}, {'accuracy': 0.64751}, {'accuracy': 0.57056}, {'accuracy': 0.58024}, {'accuracy': 0.57173}, {'accuracy': 0.5961000000000001}, {'accuracy': 0.65686}, {'accuracy': 0.65942}, {'accuracy': 0.59471}, {'accuracy': 0.65606}, {'accuracy': 0.5883299999999999}, {'accuracy': 0.6415599999999999}, {'accuracy': 0.61438}, {'accuracy': 0.64819}, {'accuracy': 0.6025500000000001}, {'accuracy': 0.66429}, {'accuracy': 0.6084799999999999}, {'accuracy': 0.6235899999999999}, {'accuracy': 0.5943400000000001}, {'accuracy': 0.66408}, {'accuracy': 0.5982799999999999}, {'accuracy': 0.64371}, {'accuracy': 0.64307}, {'accuracy': 0.68891}, {'accuracy': 0.62531}, {'accuracy': 0.6715099999999999}, {'accuracy': 0.6315200000000001}, {'accuracy': 0.58562}, {'accuracy': 0.6967000000000001}, {'accuracy': 0.6397999999999999}, {'accuracy': 0.6488099999999999}, {'accuracy': 0.60062}, {'accuracy': 0.63243}, {'accuracy': 0.6607200000000001}, {'accuracy': 0.59372}, {'accuracy': 0.6413899999999999}, {'accuracy': 0.6195799999999999}, {'accuracy': 0.6358699999999999}, {'accuracy': 0.5914499999999999}, {'accuracy': 0.5983500000000002}, {'accuracy': 0.65339}, {'accuracy': 0.6355899999999999}, {'accuracy': 0.65998}, {'accuracy': 0.6620900000000001}, {'accuracy': 0.4655}, {'accuracy': 0.63908}, {'accuracy': 0.66114}, {'accuracy': 0.62678}, {'accuracy': 0.58937}, {'accuracy': 0.65359}, {'accuracy': 0.68228}, {'accuracy': 0.64112}, {'accuracy': 0.64716}, {'accuracy': 0.72967}, {'accuracy': 0.67877}, {'accuracy': 0.61845}, {'accuracy': 0.68293}, {'accuracy': 0.63275}, {'accuracy': 0.66548}, {'accuracy': 0.6692899999999999}, {'accuracy': 0.60891}, {'accuracy': 0.6520100000000001}, {'accuracy': 0.6043799999999999}, {'accuracy': 0.6657299999999999}, {'accuracy': 0.68791}, {'accuracy': 0.6900700000000001}, {'accuracy': 0.73684}, {'accuracy': 0.63453}, {'accuracy': 0.61015}, {'accuracy': 0.57243}, {'accuracy': 0.59351}, {'accuracy': 0.49659999999999993}, {'accuracy': 0.5948399999999999}, {'accuracy': 0.5423199999999999}, {'accuracy': 0.54751}, {'accuracy': 0.66242}, {'accuracy': 0.6584800000000001}, {'accuracy': 0.72763}, {'accuracy': 0.7199500000000001}, {'accuracy': 0.6489300000000001}, {'accuracy': 0.62144}, {'accuracy': 0.5788200000000001}, {'accuracy': 0.68229}, {'accuracy': 0.64334}, {'accuracy': 0.60981}, {'accuracy': 0.65749}, {'accuracy': 0.62588}, {'accuracy': 0.59556}, {'accuracy': 0.5835999999999999}, {'accuracy': 0.68246}, {'accuracy': 0.68568}, {'accuracy': 0.67675}, {'accuracy': 0.67601}, {'accuracy': 0.6621599999999999}, {'accuracy': 0.6633899999999999}, {'accuracy': 0.5598799999999999}, {'accuracy': 0.69294}, {'accuracy': 0.58197}, {'accuracy': 0.67566}, {'accuracy': 0.5694000000000001}, {'accuracy': 0.68329}, {'accuracy': 0.66128}, {'accuracy': 0.62138}, {'accuracy': 0.60008}, {'accuracy': 0.58149}, {'accuracy': 0.6497400000000001}, {'accuracy': 0.61946}, {'accuracy': 0.66973}, {'accuracy': 0.73652}, {'accuracy': 0.6656199999999999}, {'accuracy': 0.63042}, {'accuracy': 0.6399299999999999}, {'accuracy': 0.6897200000000001}, {'accuracy': 0.52714}, {'accuracy': 0.6511500000000001}, {'accuracy': 0.5598}, {'accuracy': 0.73433}, {'accuracy': 0.6458199999999998}, {'accuracy': 0.67843}, {'accuracy': 0.72244}, {'accuracy': 0.67031}, {'accuracy': 0.6345400000000001}, {'accuracy': 0.6422200000000001}, {'accuracy': 0.73108}, {'accuracy': 0.64437}, {'accuracy': 0.55932}, {'accuracy': 0.5848800000000001}, {'accuracy': 0.67271}, {'accuracy': 0.6419}, {'accuracy': 0.61918}, {'accuracy': 0.6889500000000001}, {'accuracy': 0.7341799999999999}, {'accuracy': 0.73587}, {'accuracy': 0.5480500000000001}, {'accuracy': 0.70498}, {'accuracy': 0.72046}, {'accuracy': 0.6601700000000001}, {'accuracy': 0.69551}, {'accuracy': 0.5396}, {'accuracy': 0.62416}, {'accuracy': 0.63485}, {'accuracy': 0.6820700000000001}, {'accuracy': 0.6241199999999999}, {'accuracy': 0.5452999999999999}, {'accuracy': 0.49634}, {'accuracy': 0.61508}, {'accuracy': 0.57643}, {'accuracy': 0.68065}, {'accuracy': 0.63955}, {'accuracy': 0.67075}, {'accuracy': 0.70984}, {'accuracy': 0.7012700000000001}, {'accuracy': 0.59113}, {'accuracy': 0.662}, {'accuracy': 0.6500600000000001}, {'accuracy': 0.6804}, {'accuracy': 0.6548}, {'accuracy': 0.69784}, {'accuracy': 0.6471499999999999}, {'accuracy': 0.7267300000000001}, {'accuracy': 0.6914999999999999}, {'accuracy': 0.6536899999999999}, {'accuracy': 0.62614}, {'accuracy': 0.7141200000000001}, {'accuracy': 0.61844}, {'accuracy': 0.65842}, {'accuracy': 0.6139600000000001}, {'accuracy': 0.57297}, {'accuracy': 0.58893}, {'accuracy': 0.6305799999999999}, {'accuracy': 0.72696}, {'accuracy': 0.65629}, {'accuracy': 0.5995100000000001}, {'accuracy': 0.7300699999999999}, {'accuracy': 0.68538}, {'accuracy': 0.5693400000000001}, {'accuracy': 0.58346}, {'accuracy': 0.66149}, {'accuracy': 0.58792}, {'accuracy': 0.5859500000000001}, {'accuracy': 0.58536}, {'accuracy': 0.84414}, {'accuracy': 0.84864}, {'accuracy': 0.84777}, {'accuracy': 0.85085}, {'accuracy': 0.84947}, {'accuracy': 0.8507300000000001}, {'accuracy': 0.85046}, {'accuracy': 0.8526199999999999}, {'accuracy': 0.85015}, {'accuracy': 0.8494200000000001}, {'accuracy': 0.8496900000000001}, {'accuracy': 0.84731}, {'accuracy': 0.84878}, {'accuracy': 0.85259}, {'accuracy': 0.8500300000000001}, {'accuracy': 0.8520700000000001}, {'accuracy': 0.85107}, {'accuracy': 0.8544}, {'accuracy': 0.84566}, {'accuracy': 0.8478899999999999}, {'accuracy': 0.84717}, {'accuracy': 0.84813}, {'accuracy': 0.8493600000000001}, {'accuracy': 0.85312}, {'accuracy': 0.84995}, {'accuracy': 0.8495900000000001}, {'accuracy': 0.8499399999999999}, {'accuracy': 0.85137}, {'accuracy': 0.8489199999999999}, {'accuracy': 0.8481400000000001}, {'accuracy': 0.85045}, {'accuracy': 0.85024}, {'accuracy': 0.8494399999999999}, {'accuracy': 0.84687}, {'accuracy': 0.8486600000000001}, {'accuracy': 0.84886}, {'accuracy': 0.84996}, {'accuracy': 0.85128}, {'accuracy': 0.84993}, {'accuracy': 0.85063}, {'accuracy': 0.85045}, {'accuracy': 0.8519300000000001}, {'accuracy': 0.8531299999999999}, {'accuracy': 0.8502000000000001}, {'accuracy': 0.8533399999999999}, {'accuracy': 0.8442299999999999}, {'accuracy': 0.8485799999999999}, {'accuracy': 0.84955}, {'accuracy': 0.8498699999999999}, {'accuracy': 0.8483499999999999}, {'accuracy': 0.85132}, {'accuracy': 0.8487600000000001}, {'accuracy': 0.851}, {'accuracy': 0.8510199999999999}, {'accuracy': 0.84924}, {'accuracy': 0.84914}, {'accuracy': 0.8505900000000001}, {'accuracy': 0.85016}, {'accuracy': 0.8538}, {'accuracy': 0.85283}, {'accuracy': 0.85023}, {'accuracy': 0.8481}, {'accuracy': 0.85113}, {'accuracy': 0.8518100000000001}, {'accuracy': 0.84927}, {'accuracy': 0.8493599999999999}, {'accuracy': 0.8506}, {'accuracy': 0.85075}, {'accuracy': 0.8511200000000001}, {'accuracy': 0.8487199999999999}, {'accuracy': 0.85029}, {'accuracy': 0.84984}, {'accuracy': 0.8470700000000001}, {'accuracy': 0.8469899999999999}, {'accuracy': 0.8475100000000001}, {'accuracy': 0.85192}, {'accuracy': 0.84731}, {'accuracy': 0.8495100000000001}, {'accuracy': 0.8514099999999999}, {'accuracy': 0.85139}, {'accuracy': 0.85172}, {'accuracy': 0.8539300000000001}, {'accuracy': 0.84948}, {'accuracy': 0.8523}, {'accuracy': 0.85147}, {'accuracy': 0.84764}, {'accuracy': 0.85315}, {'accuracy': 0.8534200000000001}, {'accuracy': 0.8520999999999999}, {'accuracy': 0.8531299999999999}, {'accuracy': 0.8516199999999999}, {'accuracy': 0.85247}, {'accuracy': 0.85358}, {'accuracy': 0.8533299999999999}, {'accuracy': 0.85501}, {'accuracy': 0.85}, {'accuracy': 0.84974}, {'accuracy': 0.8472200000000001}, {'accuracy': 0.85204}, {'accuracy': 0.8484999999999999}]\n"
     ]
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n",
    "\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92e3f9cc-c762-4f66-86b4-82e67a4c71d9",
   "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
}
