{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "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",
      "5916\n",
      "[[  0 618]\n",
      " [  1 603]\n",
      " [  2 600]\n",
      " [  3 601]\n",
      " [  4 583]\n",
      " [  5 615]\n",
      " [  6 614]\n",
      " [  7 611]\n",
      " [  8 561]\n",
      " [  9 578]]\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": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5942\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 562]\n",
      " [  1 528]\n",
      " [  2 574]\n",
      " [  3 532]\n",
      " [  4 497]\n",
      " [  5 567]\n",
      " [  6 527]\n",
      " [  7 550]\n",
      " [  8 544]\n",
      " [  9 525]]\n",
      "[[  0 803]\n",
      " [  1 535]\n",
      " [  2 579]\n",
      " [  3 541]\n",
      " [  4 512]\n",
      " [  5 587]\n",
      " [  6 558]\n",
      " [  7 617]\n",
      " [  8 635]\n",
      " [  9 661]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 3,  ..., 4, 7, 4])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "# noiseyset=[],[]\n",
    "# healthset=[],[],[]\n",
    "# import random\n",
    "# for z in range(0,60000,1):\n",
    "#     t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "#     if t<5:\n",
    "#         noiseyset[0].append(dataset1[z])\n",
    "#         healthset[0].append(dataset1[z])\n",
    "#         healthset[1].append(target1[z])\n",
    "#         healthset[2].append(z)\n",
    "#         noiseyset[1].append(torch.tensor(random.randint(0,9)))\n",
    "        \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",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \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": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 3,  ..., 4, 7, 4])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\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": 9,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACOfElEQVR4nO3dd5xU1fk/8M/07QW2w9KWokhTUERFDKBYgyWK2BDF2IgaYoGooOarWKLRxILxp6JJVJTYC4goRAFBmhTpVWB739ndqff3x8y5c++dsjPs7M7u7Of9evECpp65M7v3med5zjk6SZIkEBEREcUJfawHQERERBRNDG6IiIgorjC4ISIiorjC4IaIiIjiCoMbIiIiiisMboiIiCiuMLghIiKiuMLghoiIiOIKgxsiIiKKKwxuiKhNrVixAjqdDitWrJAvu/HGG9GnT5+YjSmePPLII9DpdLEeBlGHwuCGqIPbvn07rrvuOvTo0QMWiwUFBQW49tprsX379lgPrc29/PLLWLhwYZs+xy+//IJHHnkEBw8ebNPnaU9PPPEEPv7441gPgyhmGNwQdWAffvghTjnlFCxfvhzTp0/Hyy+/jJtvvhnfffcdTjnlFHz00UexHmKbaq/g5tFHH2VwQxRHjLEeABEFtm/fPlx//fXo168f/ve//yE7O1u+7u6778bYsWNx/fXXY8uWLejXr1+7jctqtSI5Obndnq8z4DEh6liYuSHqoJ555hk0Njbin//8pyqwAYCsrCy8+uqrsFqtePrppwEAixcvhk6nw8qVK/0e69VXX4VOp8O2bdvky3bu3Inf/e536NatGxISEjBq1Ch8+umnqvstXLhQfsw77rgDOTk56NmzJwDg0KFDuOOOOzBo0CAkJiaie/fuuPLKK6OWAenTpw+2b9+OlStXQqfTQafT4ZxzzpGvr6mpwT333IPCwkJYLBb0798fTz31FNxut+px3nvvPYwcORKpqalIS0vD0KFD8cILL8iv78orrwQA/OY3v5GfR9kfpHXjjTciJSUF+/btw4UXXojU1FRce+21AAC3243nn38eJ510EhISEpCbm4tbb70V1dXVqsdYv349Jk2ahKysLCQmJqJv37646aab5OsD9SkBwMGDB6HT6UJms3Q6HaxWK9566y359dx4440AgPr6etxzzz3o06cPLBYLcnJycO6552Ljxo1BH4+oM2LmhqiD+uyzz9CnTx+MHTs24PVnn302+vTpgy+++AIAcNFFFyElJQXvv/8+xo0bp7rtokWLcNJJJ2HIkCEAPH08Z555Jnr06IHZs2cjOTkZ77//Pi699FL897//xWWXXaa6/x133IHs7GzMnTsXVqsVAPDTTz9h9erVuPrqq9GzZ08cPHgQr7zyCs455xz88ssvSEpKatXrf/755/GHP/wBKSkpePDBBwEAubm5AIDGxkaMGzcOR48exa233opevXph9erVmDNnDoqLi/H8888DAJYtW4apU6diwoQJeOqppwAAO3bswKpVq3D33Xfj7LPPxl133YW///3v+POf/4wTTzwRAOS/g3E6nZg0aRLOOuss/PWvf5Vf66233oqFCxdi+vTpuOuuu3DgwAG8+OKL2LRpE1atWgWTyYSysjKcd955yM7OxuzZs5GRkYGDBw/iww8/bNXxEv71r39hxowZOO200/D73/8eAFBUVAQAuO2227B48WLMnDkTgwcPRmVlJX744Qfs2LEDp5xySlSen6hDkIiow6mpqZEASJMnTw55u9/+9rcSAKmurk6SJEmaOnWqlJOTIzmdTvk2xcXFkl6vlx577DH5sgkTJkhDhw6Vmpub5cvcbrd0xhlnSAMGDJAve/PNNyUA0llnnaV6TEmSpMbGRr/xrFmzRgIgvf322/Jl3333nQRA+u677+TLpk2bJvXu3Tvka5MkSTrppJOkcePG+V3+l7/8RUpOTpZ2796tunz27NmSwWCQDh8+LEmSJN19991SWlqa39iVPvjgA7/xhTJt2jQJgDR79mzV5d9//70EQPrPf/6junzJkiWqyz/66CMJgPTTTz8FfY5Ax0ySJOnAgQMSAOnNN9+UL5s3b56k/VWenJwsTZs2ze9x09PTpTvvvDOMV0nUubEsRdQB1dfXAwBSU1ND3k5cX1dXBwCYMmUKysrKVOWMxYsXw+12Y8qUKQCAqqoqfPvtt7jqqqtQX1+PiooKVFRUoLKyEpMmTcKePXtw9OhR1fPccsstMBgMqssSExPlfzscDlRWVqJ///7IyMho8zLHBx98gLFjxyIzM1Mef0VFBSZOnAiXy4X//e9/AICMjAxYrVYsW7Ys6mO4/fbb/caUnp6Oc889VzWmkSNHIiUlBd999508JgD4/PPP4XA4oj6uUDIyMrB27Voc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kJCA0aNHY926dbEeUsw98sgj0Ol0qj8nnHCCfH1zczPuvPNOdO/eHSkpKbjiiitQWloawxG3n//973+45JJLUFBQAJ1Oh48//lh1vSRJmDt3LvLz85GYmIiJEydiz549qttUVVXh2muvRVpaGjIyMnDzzTejoaGhHV9F+2npeN14441+n7Xzzz9fdZuucrzmz5+PU089FampqcjJycGll16KXbt2qW4Tzs/e4cOHcdFFFyEpKQk5OTm477774HQ62/OltLlwjtU555zj99m67bbbVLfpCscKAF555RUMGzZMXphvzJgx+Oqrr+TrO9rnisFNKy1atAizZs3CvHnzsHHjRgwfPhyTJk1CWVlZrIcWcyeddBKKi4vlPz/88IN83R//+Ed89tln+OCDD7By5UocO3YMl19+eQxH236sViuGDx+Ol156KeD1Tz/9NP7+979jwYIFWLt2LZKTkzFp0iQ0NzfLt7n22muxfft2LFu2DJ9//jn+97//4fe//317vYR21dLxAoDzzz9f9Vl79913Vdd3leO1cuVK3Hnnnfjxxx+xbNkyOBwOnHfeebBarfJtWvrZc7lcuOiii2C327F69Wq89dZbWLhwIebOnRuLl9RmwjlWAHDLLbeoPltPP/20fF1XOVYA0LNnTzz55JPYsGED1q9fj/Hjx2Py5MnYvn07gA74uZKoVU477TTpzjvvlP/vcrmkgoICaf78+TEcVezNmzdPGj58eMDrampqJJPJJH3wwQfyZTt27JAASGvWrGmnEXYMAKSPPvpI/r/b7Zby8vKkZ555Rr6spqZGslgs0rvvvitJkiT98ssvEgDpp59+km/z1VdfSTqdTjp69Gi7jT0WtMdLkiRp2rRp0uTJk4Pepysfr7KyMgmAtHLlSkmSwvvZ+/LLLyW9Xi+VlJTIt3nllVektLQ0yWazte8LaEfaYyVJkjRu3Djp7rvvDnqfrnqshMzMTOn//b//1yE/V8zctILdbseGDRswceJE+TK9Xo+JEydizZo1MRxZx7Bnzx4UFBSgX79+uPbaa3H48GEAwIYNG+BwOFTH7YQTTkCvXr26/HE7cOAASkpKVMcmPT0do0ePlo/NmjVrkJGRgVGjRsm3mThxIvR6PdauXdvuY+4IVqxYgZycHAwaNAi33347Kisr5eu68vGqra0FAHTr1g1AeD97a9aswdChQ5GbmyvfZtKkSairq5O/pccj7bES/vOf/yArKwtDhgzBnDlz0NjYKF/XVY+Vy+XCe++9B6vVijFjxnTIz1WX2zgzmioqKuByuVRvFgDk5uZi586dMRpVxzB69GgsXLgQgwYNQnFxMR599FGMHTsW27ZtQ0lJCcxmMzIyMlT3yc3NRUlJSWwG3EGI1x/oMyWuKykpQU5Ojup6o9GIbt26dcnjd/755+Pyyy9H3759sW/fPvz5z3/GBRdcgDVr1sBgMHTZ4+V2u3HPPffgzDPPxJAhQwAgrJ+9kpKSgJ8/cV08CnSsAOCaa65B7969UVBQgC1btuCBBx7Arl278OGHHwLoesdq69atGDNmDJqbm5GSkoKPPvoIgwcPxubNmzvc54rBDbWJCy64QP73sGHDMHr0aPTu3Rvvv/8+EhMTYzgyijdXX321/O+hQ4di2LBhKCoqwooVKzBhwoQYjiy27rzzTmzbtk3V60aBBTtWyr6soUOHIj8/HxMmTMC+fftQVFTU3sOMuUGDBmHz5s2ora3F4sWLMW3aNKxcuTLWwwqIZalWyMrKgsFg8OsILy0tRV5eXoxG1TFlZGRg4MCB2Lt3L/Ly8mC321FTU6O6DY8b5Ncf6jOVl5fn17DudDpRVVXV5Y8fAPTr1w9ZWVnYu3cvgK55vGbOnInPP/8c3333HXr27ClfHs7PXl5eXsDPn7gu3gQ7VoGMHj0aAFSfra50rMxmM/r374+RI0di/vz5GD58OF544YUO+blicNMKZrMZI0eOxPLly+XL3G43li9fjjFjxsRwZB1PQ0MD9u3bh/z8fIwcORImk0l13Hbt2oXDhw93+ePWt29f5OXlqY5NXV0d1q5dKx+bMWPGoKamBhs2bJBv8+2338Ltdsu/fLuyI0eOoLKyEvn5+QC61vGSJAkzZ87ERx99hG+//RZ9+/ZVXR/Oz96YMWOwdetWVUC4bNkypKWlYfDgwe3zQtpBS8cqkM2bNwOA6rPVFY5VMG63GzabrWN+rqLeotzFvPfee5LFYpEWLlwo/fLLL9Lvf/97KSMjQ9UR3hX96U9/klasWCEdOHBAWrVqlTRx4kQpKytLKisrkyRJkm677TapV69e0rfffiutX79eGjNmjDRmzJgYj7p91NfXS5s2bZI2bdokAZCee+45adOmTdKhQ4ckSZKkJ598UsrIyJA++eQTacuWLdLkyZOlvn37Sk1NTfJjnH/++dLJJ58srV27Vvrhhx+kAQMGSFOnTo3VS2pToY5XfX29dO+990pr1qyRDhw4IH3zzTfSKaecIg0YMEBqbm6WH6OrHK/bb79dSk9Pl1asWCEVFxfLfxobG+XbtPSz53Q6pSFDhkjnnXeetHnzZmnJkiVSdna2NGfOnFi8pDbT0rHau3ev9Nhjj0nr16+XDhw4IH3yySdSv379pLPPPlt+jK5yrCRJkmbPni2tXLlSOnDggLRlyxZp9uzZkk6nk77++mtJkjre54rBTRT84x//kHr16iWZzWbptNNOk3788cdYDynmpkyZIuXn50tms1nq0aOHNGXKFGnv3r3y9U1NTdIdd9whZWZmSklJSdJll10mFRcXx3DE7ee7776TAPj9mTZtmiRJnungDz/8sJSbmytZLBZpwoQJ0q5du1SPUVlZKU2dOlVKSUmR0tLSpOnTp0v19fUxeDVtL9TxamxslM477zwpOztbMplMUu/evaVbbrnF78tFVzlegY4TAOnNN9+UbxPOz97BgwelCy64QEpMTJSysrKkP/3pT5LD4WjnV9O2WjpWhw8fls4++2ypW7duksVikfr37y/dd999Um1trepxusKxkiRJuummm6TevXtLZrNZys7OliZMmCAHNpLU8T5XOkmSpOjng4iIiIhigz03REREFFcY3BAREVFcYXBDREREcYXBDREREcUVBjdEREQUVxjcEBERUVxhcENERERxhcENEXUJK1asgE6n89v/hojiD4MbIiIiiisMboiIiCiuMLghog7F7Xbj6aefRv/+/WGxWNCrVy88/vjjGD9+PGbOnKm6bXl5Ocxms7wbsc1mwwMPPIDCwkJYLBb0798fr7/+etDn+uGHHzB27FgkJiaisLAQd911F6xWa5u+PiJqewxuiKhDmTNnDp588kk8/PDD+OWXX/DOO+8gNzcXM2bMwDvvvAObzSbf9t///jd69OiB8ePHAwBuuOEGvPvuu/j73/+OHTt24NVXX0VKSkrA59m3bx/OP/98XHHFFdiyZQsWLVqEH374wS+AIqLOhxtnElGHUV9fj+zsbLz44ouYMWOG6rrm5mYUFBRgwYIFuOqqqwAAw4cPx+WXX4558+Zh9+7dGDRoEJYtW4aJEyf6PfaKFSvwm9/8BtXV1cjIyMCMGTNgMBjw6quvyrf54YcfMG7cOFitViQkJLTtiyWiNsPMDRF1GDt27IDNZsOECRP8rktISMD111+PN954AwCwceNGbNu2DTfeeCMAYPPmzTAYDBg3blxYz/Xzzz9j4cKFSElJkf9MmjQJbrcbBw4ciNprIqL2Z4z1AIiIhMTExJDXz5gxAyNGjMCRI0fw5ptvYvz48ejdu3dY99VqaGjArbfeirvuusvvul69ekX0WETUsTBzQ0QdxoABA5CYmCg3CGsNHToUo0aNwmuvvYZ33nkHN910k+o6t9uNlStXhvVcp5xyCn755Rf079/f74/ZbI7K6yGi2GBwQ0QdRkJCAh544AHcf//9ePvtt7Fv3z78+OOPqhlPM2bMwJNPPglJknDZZZfJl/fp0wfTpk3DTTfdhI8//hgHDhzAihUr8P777wd8rgceeACrV6/GzJkzsXnzZuzZsweffPIJG4qJ4gCDGyLqUB5++GH86U9/wty5c3HiiSdiypQpKCsrk6+fOnUqjEYjpk6d6tf0+8orr+B3v/sd7rjjDpxwwgm45ZZbgk7tHjZsGFauXIndu3dj7NixOPnkkzF37lwUFBS06esjorbH2VJE1KkcPHgQRUVF+Omnn3DKKafEejhE1AExuCGiTsHhcKCyshL33nsvDhw4gFWrVsV6SETUQbEsRUSdwqpVq5Cfn4+ffvoJCxYsiPVwiKgDY+aGiIiI4gozN0RERBRXGNwQERFRXGFwQ0RERHGFwQ0RERHFFQY3REREFFcY3BAREVFcYXBDREREcYXBDREREcUVBjdEREQUV/4/tGCzdtbTYZEAAAAASUVORK5CYII=",
      "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": 10,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.49688999999999994}, {'accuracy': 0.48043}, {'accuracy': 0.59545}, {'accuracy': 0.56076}, {'accuracy': 0.60123}, {'accuracy': 0.6716099999999999}, {'accuracy': 0.69305}, {'accuracy': 0.6808699999999999}, {'accuracy': 0.68828}, {'accuracy': 0.6899}, {'accuracy': 0.6867000000000001}, {'accuracy': 0.7260800000000001}, {'accuracy': 0.7059}, {'accuracy': 0.70941}, {'accuracy': 0.7268399999999999}, {'accuracy': 0.7315200000000001}, {'accuracy': 0.75897}, {'accuracy': 0.7364600000000001}, {'accuracy': 0.74793}, {'accuracy': 0.75382}, {'accuracy': 0.8062400000000001}, {'accuracy': 0.7769999999999999}, {'accuracy': 0.7805300000000001}, {'accuracy': 0.78096}, {'accuracy': 0.7903499999999999}, {'accuracy': 0.7677400000000001}, {'accuracy': 0.7767700000000001}, {'accuracy': 0.8091700000000002}, {'accuracy': 0.81152}, {'accuracy': 0.8031600000000001}, {'accuracy': 0.78347}, {'accuracy': 0.82833}, {'accuracy': 0.7970900000000001}, {'accuracy': 0.79393}, {'accuracy': 0.80791}, {'accuracy': 0.7808300000000001}, {'accuracy': 0.8312900000000001}, {'accuracy': 0.78777}, {'accuracy': 0.80687}, {'accuracy': 0.80373}, {'accuracy': 0.82047}, {'accuracy': 0.8240599999999999}, {'accuracy': 0.7955}, {'accuracy': 0.79292}, {'accuracy': 0.7706500000000001}, {'accuracy': 0.7794200000000002}, {'accuracy': 0.78864}, {'accuracy': 0.81463}, {'accuracy': 0.8077100000000002}, {'accuracy': 0.80609}, {'accuracy': 0.79941}, {'accuracy': 0.8164}, {'accuracy': 0.7985899999999999}, {'accuracy': 0.7745399999999999}, {'accuracy': 0.7992699999999999}, {'accuracy': 0.76693}, {'accuracy': 0.81037}, {'accuracy': 0.80604}, {'accuracy': 0.80256}, {'accuracy': 0.8282700000000001}, {'accuracy': 0.8164300000000001}, {'accuracy': 0.7960799999999999}, {'accuracy': 0.7822799999999999}, {'accuracy': 0.7946500000000001}, {'accuracy': 0.8136300000000001}, {'accuracy': 0.79152}, {'accuracy': 0.7821}, {'accuracy': 0.8092599999999999}, {'accuracy': 0.8114199999999998}, {'accuracy': 0.78006}, {'accuracy': 0.79315}, {'accuracy': 0.8198000000000001}, {'accuracy': 0.83773}, {'accuracy': 0.8126199999999999}, {'accuracy': 0.8123699999999999}, {'accuracy': 0.8241799999999999}, {'accuracy': 0.8013599999999999}, {'accuracy': 0.75711}, {'accuracy': 0.81827}, {'accuracy': 0.85083}, {'accuracy': 0.79524}, {'accuracy': 0.79644}, {'accuracy': 0.8062099999999999}, {'accuracy': 0.7988099999999999}, {'accuracy': 0.81717}, {'accuracy': 0.7349399999999999}, {'accuracy': 0.8079600000000001}, {'accuracy': 0.7852499999999999}, {'accuracy': 0.7971900000000001}, {'accuracy': 0.8243199999999999}, {'accuracy': 0.80813}, {'accuracy': 0.84199}, {'accuracy': 0.85351}, {'accuracy': 0.78349}, {'accuracy': 0.81822}, {'accuracy': 0.8065199999999999}, {'accuracy': 0.8032299999999999}, {'accuracy': 0.8241100000000001}, {'accuracy': 0.8077}, {'accuracy': 0.7686400000000001}, {'accuracy': 0.85145}, {'accuracy': 0.82264}, {'accuracy': 0.8150300000000001}, {'accuracy': 0.7738700000000001}, {'accuracy': 0.8}, {'accuracy': 0.8139799999999999}, {'accuracy': 0.80815}, {'accuracy': 0.80479}, {'accuracy': 0.77145}, {'accuracy': 0.77774}, {'accuracy': 0.8074}, {'accuracy': 0.81318}, {'accuracy': 0.84224}, {'accuracy': 0.7820699999999999}, {'accuracy': 0.79643}, {'accuracy': 0.7952199999999999}, {'accuracy': 0.8271499999999999}, {'accuracy': 0.8210900000000001}, {'accuracy': 0.8328300000000001}, {'accuracy': 0.7945}, {'accuracy': 0.7945599999999999}, {'accuracy': 0.75274}, {'accuracy': 0.79009}, {'accuracy': 0.8235300000000001}, {'accuracy': 0.8562}, {'accuracy': 0.82575}, {'accuracy': 0.79213}, {'accuracy': 0.8118299999999999}, {'accuracy': 0.79581}, {'accuracy': 0.7867200000000001}, {'accuracy': 0.8311400000000001}, {'accuracy': 0.81519}, {'accuracy': 0.82622}, {'accuracy': 0.8167099999999999}, {'accuracy': 0.8236399999999999}, {'accuracy': 0.79183}, {'accuracy': 0.75034}, {'accuracy': 0.7491899999999999}, {'accuracy': 0.8460300000000001}, {'accuracy': 0.7847200000000001}, {'accuracy': 0.77123}, {'accuracy': 0.8085000000000001}, {'accuracy': 0.8457699999999999}, {'accuracy': 0.8065300000000001}, {'accuracy': 0.80905}, {'accuracy': 0.78034}, {'accuracy': 0.76785}, {'accuracy': 0.82484}, {'accuracy': 0.80152}, {'accuracy': 0.79774}, {'accuracy': 0.75527}, {'accuracy': 0.80777}, {'accuracy': 0.80745}, {'accuracy': 0.8597899999999999}, {'accuracy': 0.8336600000000001}, {'accuracy': 0.77539}, {'accuracy': 0.85413}, {'accuracy': 0.75737}, {'accuracy': 0.82713}, {'accuracy': 0.7981800000000001}, {'accuracy': 0.7374799999999999}, {'accuracy': 0.75415}, {'accuracy': 0.83171}, {'accuracy': 0.8129899999999999}, {'accuracy': 0.8286199999999999}, {'accuracy': 0.8043799999999999}, {'accuracy': 0.78223}, {'accuracy': 0.6582000000000001}, {'accuracy': 0.80101}, {'accuracy': 0.8087099999999999}, {'accuracy': 0.76973}, {'accuracy': 0.8438599999999999}, {'accuracy': 0.81897}, {'accuracy': 0.78914}, {'accuracy': 0.8374}, {'accuracy': 0.80852}, {'accuracy': 0.82248}, {'accuracy': 0.74006}, {'accuracy': 0.7698400000000001}, {'accuracy': 0.7007800000000001}, {'accuracy': 0.85099}, {'accuracy': 0.85908}, {'accuracy': 0.8377699999999999}, {'accuracy': 0.8195799999999999}, {'accuracy': 0.77371}, {'accuracy': 0.76655}, {'accuracy': 0.75847}, {'accuracy': 0.81745}, {'accuracy': 0.81403}, {'accuracy': 0.79661}, {'accuracy': 0.85488}, {'accuracy': 0.7460899999999999}, {'accuracy': 0.8322899999999999}, {'accuracy': 0.8088000000000001}, {'accuracy': 0.8316600000000001}, {'accuracy': 0.8283900000000001}, {'accuracy': 0.8450900000000001}, {'accuracy': 0.82162}, {'accuracy': 0.7657499999999999}, {'accuracy': 0.8579100000000001}, {'accuracy': 0.9011700000000001}, {'accuracy': 0.9014200000000001}, {'accuracy': 0.90107}, {'accuracy': 0.90119}, {'accuracy': 0.9004600000000001}, {'accuracy': 0.90016}, {'accuracy': 0.90133}, {'accuracy': 0.9001800000000001}, {'accuracy': 0.8999400000000002}, {'accuracy': 0.9005700000000001}, {'accuracy': 0.90039}, {'accuracy': 0.90015}, {'accuracy': 0.89993}, {'accuracy': 0.9002399999999999}, {'accuracy': 0.8993800000000001}, {'accuracy': 0.90012}, {'accuracy': 0.89983}, {'accuracy': 0.8995299999999998}, {'accuracy': 0.89944}, {'accuracy': 0.90026}, {'accuracy': 0.90014}, {'accuracy': 0.90037}, {'accuracy': 0.9007399999999999}, {'accuracy': 0.9009799999999999}, {'accuracy': 0.90033}, {'accuracy': 0.9007799999999999}, {'accuracy': 0.8995000000000001}, {'accuracy': 0.89939}, {'accuracy': 0.90025}, {'accuracy': 0.90068}, {'accuracy': 0.90115}, {'accuracy': 0.90016}, {'accuracy': 0.90127}, {'accuracy': 0.90077}, {'accuracy': 0.9006000000000001}, {'accuracy': 0.8994}, {'accuracy': 0.9009599999999999}, {'accuracy': 0.9009}, {'accuracy': 0.90007}, {'accuracy': 0.9005000000000001}, {'accuracy': 0.90151}, {'accuracy': 0.90018}, {'accuracy': 0.9015000000000001}, {'accuracy': 0.9009}, {'accuracy': 0.9014300000000001}, {'accuracy': 0.9016299999999999}, {'accuracy': 0.9006900000000002}, {'accuracy': 0.90105}, {'accuracy': 0.9005700000000001}, {'accuracy': 0.90162}, {'accuracy': 0.90094}, {'accuracy': 0.9013899999999999}, {'accuracy': 0.90109}, {'accuracy': 0.9006000000000001}, {'accuracy': 0.9019700000000002}, {'accuracy': 0.90068}, {'accuracy': 0.90112}, {'accuracy': 0.9018}, {'accuracy': 0.9009199999999999}, {'accuracy': 0.9010400000000001}, {'accuracy': 0.9009199999999999}, {'accuracy': 0.90168}, {'accuracy': 0.90112}, {'accuracy': 0.9009599999999999}, {'accuracy': 0.90058}, {'accuracy': 0.9002699999999999}, {'accuracy': 0.90044}, {'accuracy': 0.9014099999999999}, {'accuracy': 0.90107}, {'accuracy': 0.90108}, {'accuracy': 0.90212}, {'accuracy': 0.90097}, {'accuracy': 0.90105}, {'accuracy': 0.9012800000000001}, {'accuracy': 0.90087}, {'accuracy': 0.90129}, {'accuracy': 0.9023100000000002}, {'accuracy': 0.9019400000000001}, {'accuracy': 0.9011299999999999}, {'accuracy': 0.90123}, {'accuracy': 0.90216}, {'accuracy': 0.9026}, {'accuracy': 0.9012899999999998}, {'accuracy': 0.9008500000000002}, {'accuracy': 0.9013500000000001}, {'accuracy': 0.9010199999999999}, {'accuracy': 0.9009}, {'accuracy': 0.9009899999999998}, {'accuracy': 0.90086}, {'accuracy': 0.9007100000000001}, {'accuracy': 0.9016400000000001}, {'accuracy': 0.9002300000000002}, {'accuracy': 0.89962}, {'accuracy': 0.8999900000000001}, {'accuracy': 0.90099}, {'accuracy': 0.90114}, {'accuracy': 0.9017799999999999}, {'accuracy': 0.90129}, {'accuracy': 0.90069}, {'accuracy': 0.9008800000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b038631a-8c56-436e-81a9-bcf7c4bf36c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c14e55f4-784b-4906-b9f0-413e44b11b08",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfb5119e-99b7-4966-8fc7-4365f3ba66b7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2890e933-2503-44d2-9dfe-1f60a144c8f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5eff440-6906-4efb-af71-dcf4760c2902",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef2f4fd0-f4af-471f-8b84-ebe39e75ea92",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f0552ac-2abb-4e6c-8490-28cd65685242",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0b1a48d-4f16-42b9-a3ec-28162ae8cdf1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81da3426-a31e-4ad9-923f-868dd4028a77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f95c2a56-f436-4396-af05-3adb87376b5e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d79c07bd-cf82-4d25-a38c-a7a9db607012",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b98fc0e-d2d8-42e1-80c3-7e5a0d1d0977",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b9e5096-7127-4478-9d2f-ddb63ba305ac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45769741-e929-40e2-aea7-d2ddb4c0143b",
   "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
}
