{
 "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",
      "5967\n",
      "[[  0 600]\n",
      " [  1 633]\n",
      " [  2 623]\n",
      " [  3 562]\n",
      " [  4 600]\n",
      " [  5 613]\n",
      " [  6 586]\n",
      " [  7 575]\n",
      " [  8 568]\n",
      " [  9 558]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 3, 5,  ..., 6, 4, 2])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2425\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 514]\n",
      " [  1 592]\n",
      " [  2 568]\n",
      " [  3 620]\n",
      " [  4 534]\n",
      " [  5 559]\n",
      " [  6 528]\n",
      " [  7 646]\n",
      " [  8 605]\n",
      " [  9 592]]\n",
      "[[  0 751]\n",
      " [  1 592]\n",
      " [  2 572]\n",
      " [  3 620]\n",
      " [  4 543]\n",
      " [  5 559]\n",
      " [  6 560]\n",
      " [  7 646]\n",
      " [  8 605]\n",
      " [  9 592]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 3, 5,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.82</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.82\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAADGXklEQVR4nOydeZgU1fX3v1XVy+zDsMywDSCLC7IpiLuioiRG45IoIUYILjEqRkNMoj8VYowSNRpN1Gh8XZMYMUYTExNccIkKioq4giKK7MMyzMJsvVS9f3Tfqntv3equnumZ7mnO53l4mOmu5dYydU+d8z3naJZlWSAIgiAIgigQ9FwPgCAIgiAIIpuQcUMQBEEQREFBxg1BEARBEAUFGTcEQRAEQRQUZNwQBEEQBFFQkHFDEARBEERBQcYNQRAEQRAFBRk3BEEQBEEUFGTcEARBEARRUJBxQxBEt/LKK69A0zS88sor9mff//73MWLEiJyNqZD4xS9+AU3Tcj0MgsgryLghiDzn448/xve+9z0MGTIE4XAYgwcPxjnnnIOPP/4410Prdu655x48/PDD3bqPTz75BL/4xS+wfv36bt1PT3LTTTfhH//4R66HQRA5g4wbgshjnnrqKRx88MFYunQp5s6di3vuuQfnn38+Xn75ZRx88MF4+umncz3EbqWnjJvrr7+ejBuCKCACuR4AQRBq1q1bh3PPPRcjR47E//73PwwYMMD+7vLLL8fRRx+Nc889Fx988AFGjhzZY+NqaWlBaWlpj+2vN0DnhCDyC/LcEESecuutt6K1tRV//OMfBcMGAPr374/77rsPLS0tuOWWWwAATz75JDRNw6uvvura1n333QdN0/DRRx/Zn61Zswbf/va30bdvXxQVFWHKlCl45plnhPUefvhhe5uXXHIJqqurMXToUADAV199hUsuuQT77bcfiouL0a9fP5x11llZ84CMGDECH3/8MV599VVomgZN0zBt2jT7+4aGBlxxxRWora1FOBzG6NGjcfPNN8M0TWE7jz/+OCZPnozy8nJUVFRg/PjxuPPOO+3jO+usswAAxx13nL0fXh8k8/3vfx9lZWVYt24dTj75ZJSXl+Occ84BAJimiTvuuAMHHnggioqKUFNTg4suugi7d+8WtvHOO+9gxowZ6N+/P4qLi7HPPvvgvPPOs79X6ZQAYP369dA0LaU3S9M0tLS04JFHHrGP5/vf/z4AoLm5GVdccQVGjBiBcDiM6upqnHjiiVi5cqXn9giiN0KeG4LIU/71r39hxIgROProo5XfH3PMMRgxYgSeffZZAMA3vvENlJWV4YknnsCxxx4rLLt48WIceOCBGDduHICEjufII4/EkCFDcNVVV6G0tBRPPPEETj/9dPz973/HGWecIax/ySWXYMCAAViwYAFaWloAAG+//TaWLVuG73znOxg6dCjWr1+PP/zhD5g2bRo++eQTlJSUdOn477jjDlx22WUoKyvDNddcAwCoqakBALS2tuLYY4/F5s2bcdFFF2HYsGFYtmwZrr76amzduhV33HEHAOCFF17ArFmzcMIJJ+Dmm28GAKxevRpvvPEGLr/8chxzzDH40Y9+hN/97nf4v//7PxxwwAEAYP/vRSwWw4wZM3DUUUfhN7/5jX2sF110ER5++GHMnTsXP/rRj/Dll1/irrvuwnvvvYc33ngDwWAQ27dvx0knnYQBAwbgqquuQp8+fbB+/Xo89dRTXTpfjD/96U+44IILMHXqVPzgBz8AAIwaNQoA8MMf/hBPPvkk5s2bh7Fjx2LXrl14/fXXsXr1ahx88MFZ2T9B5AUWQRB5R0NDgwXAOu2001Iu981vftMCYDU1NVmWZVmzZs2yqqurrVgsZi+zdetWS9d165e//KX92QknnGCNHz/eam9vtz8zTdM64ogjrDFjxtifPfTQQxYA66ijjhK2aVmW1dra6hrP8uXLLQDWo48+an/28ssvWwCsl19+2f5szpw51vDhw1Mem2VZ1oEHHmgde+yxrs9vuOEGq7S01Prss8+Ez6+66irLMAxrw4YNlmVZ1uWXX25VVFS4xs7zt7/9zTW+VMyZM8cCYF111VXC56+99poFwPrLX/4ifL5kyRLh86efftoCYL399tue+1CdM8uyrC+//NICYD300EP2ZwsXLrTkR3lpaak1Z84c13YrKyutSy+91MdREkTvhsJSBJGHNDc3AwDKy8tTLse+b2pqAgDMnDkT27dvF8IZTz75JEzTxMyZMwEA9fX1eOmll3D22WejubkZO3fuxM6dO7Fr1y7MmDEDa9euxebNm4X9XHjhhTAMQ/isuLjY/jkajWLXrl0YPXo0+vTp0+1hjr/97W84+uijUVVVZY9/586dmD59OuLxOP73v/8BAPr06YOWlha88MILWR/DxRdf7BpTZWUlTjzxRGFMkydPRllZGV5++WV7TADw73//G9FoNOvjSkWfPn3w1ltvYcuWLT26X4Loaci4IYg8hBktzMjxQjaCvva1r6GyshKLFy+2l1m8eDEmTZqEfffdFwDw+eefw7IsXHfddRgwYIDwb+HChQCA7du3C/vZZ599XPtua2vDggULbM1L//79MWDAADQ0NKCxsbGTR+6PtWvXYsmSJa7xT58+XRj/JZdcgn333Rdf//rXMXToUJx33nlYsmRJl/cfCARs7RE/psbGRlRXV7vGtWfPHntMxx57LL71rW/h+uuvR//+/XHaaafhoYceQkdHR5fHlY5bbrkFH330EWprazF16lT84he/wBdffNHt+yWInoY0NwSRh1RWVmLQoEH44IMPUi73wQcfYMiQIaioqAAAhMNhnH766Xj66adxzz33oK6uDm+88QZuuukmex0muL3yyisxY8YM5XZHjx4t/M57aRiXXXYZHnroIVxxxRU4/PDDUVlZCU3T8J3vfMcl6s02pmnixBNPxM9+9jPl98yQq66uxqpVq/Dcc8/hv//9L/773//ioYcewuzZs/HII490ev/hcBi6Lr4bmqaJ6upq/OUvf1Guw0ThmqbhySefxJtvvol//etfeO6553Deeefhtttuw5tvvomysjLPonzxeLzTYwaAs88+G0cffTSefvppPP/887j11ltx880346mnnsLXv/71Lm2bIPIJMm4IIk855ZRTcP/99+P111/HUUcd5fr+tddew/r163HRRRcJn8+cOROPPPIIli5ditWrV8OyLDskBcBOGw8Gg7anozM8+eSTmDNnDm677Tb7s/b2djQ0NHR6mzJek/yoUaOwZ88eX+MPhUI49dRTceqpp8I0TVxyySW47777cN1112H06NFZq+47atQovPjiizjyyCOVxqDMYYcdhsMOOww33ngjHnvsMZxzzjl4/PHHccEFF6CqqgoAXOfyq6++8jWWVMc0aNAgXHLJJbjkkkuwfft2HHzwwbjxxhvJuCEKCgpLEUSe8tOf/hTFxcW46KKLsGvXLuG7+vp6/PCHP0RJSQl++tOfCt9Nnz4dffv2xeLFi7F48WJMnTpVCCtVV1dj2rRpuO+++7B161bXfnfs2OFrfIZhwLIs4bPf//73XfYu8JSWliqNpbPPPhvLly/Hc8895/quoaEBsVgMAFznTdd1TJgwAQDsMBCrT9NVo+zss89GPB7HDTfc4PouFovZ29+9e7frvE2aNEkY0/Dhw2EYhq0dYtxzzz2+xqI6b/F43BUurK6uxuDBg3skJEYQPQl5bggiTxkzZgweeeQRnHPOORg/fjzOP/987LPPPli/fj0eeOAB7Ny5E3/961/tNF9GMBjEmWeeiccffxwtLS34zW9+49r23XffjaOOOgrjx4/HhRdeiJEjR6Kurg7Lly/Hpk2b8P7776cd3ymnnII//elPqKysxNixY7F8+XK8+OKL6NevX9bOweTJk/GHP/wBv/rVrzB69GhUV1fj+OOPx09/+lM888wzOOWUU/D9738fkydPRktLCz788EM8+eSTWL9+Pfr3748LLrgA9fX1OP744zF06FB89dVX+P3vf49JkybZ6d6TJk2CYRi4+eab0djYiHA4jOOPPx7V1dUZjfXYY4/FRRddhEWLFmHVqlU46aSTEAwGsXbtWvztb3/DnXfeiW9/+9t45JFHcM899+CMM87AqFGj0NzcjPvvvx8VFRU4+eSTASTCkmeddRZ+//vfQ9M0jBo1Cv/+979dWqhU5+3FF1/E7bffjsGDB2OfffbBfvvth6FDh+Lb3/42Jk6ciLKyMrz44ot4++23Be8bQRQEuU3WIggiHR988IE1a9Ysa9CgQVYwGLQGDhxozZo1y/rwww8913nhhRcsAJamadbGjRuVy6xbt86aPXu2NXDgQCsYDFpDhgyxTjnlFOvJJ5+0l2Gp4Kq05d27d1tz5861+vfvb5WVlVkzZsyw1qxZYw0fPlxIQ+5KKvi2bdusb3zjG1Z5ebkFQEgLb25utq6++mpr9OjRVigUsvr3728dccQR1m9+8xsrEolYlmVZTz75pHXSSSdZ1dXVVigUsoYNG2ZddNFF1tatW4X93H///dbIkSMtwzDSpoXPmTPHKi0t9fz+j3/8ozV58mSruLjYKi8vt8aPH2/97Gc/s7Zs2WJZlmWtXLnSmjVrljVs2DArHA5b1dXV1imnnGK98847wnZ27Nhhfetb37JKSkqsqqoq66KLLrI++ugjX6nga9assY455hiruLjYAmDNmTPH6ujosH76059aEydOtMrLy63S0lJr4sSJ1j333JPqEhBEr0SzLMk/ShAEQRAE0YshzQ1BEARBEAUFGTcE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vn1RVlaG5557Dhs2bAAArF69Gh0dHZ77LioqwrnnnosHH3wQALBy5Up89NFH+P73v9/lsaaCPDdZwk4Dpxo3BEEQeUNx0MAnv5yRs31nwqmnnorhw4fj/vvvx+DBg2GaJsaNG4dIJILi4uLU+0rzvaZpsCxL+EwlGC4tLRV+v/XWW3HnnXfijjvuwPjx41FaWoorrrgCkUjE136BRGhq0qRJ2LRpEx566CEcf/zxGD58eNr1ugLNxFmCqhMTBEHkH5qmoSQUyMm/TMIuu3btwqeffoprr70WJ5xwAg444ADs3r3b/n7ChAlYtWoV6uvrletPmDAhpUB3wIAB2Lp1q/372rVrfTUXfeONN3Daaafhe9/7HiZOnIiRI0fis88+s78fM2YMiouLU+57/PjxmDJlCu6//3489thjOO+889Lut6uQcZMlqIAfQRAE0VmqqqrQr18//PGPf8Tnn3+Ol156CfPnz7e/nzVrFgYOHIjTTz8db7zxBr744gv8/e9/x/LlywEACxcuxF//+lcsXLgQq1evxocffoibb77ZXv/444/HXXfdhffeew/vvPMOfvjDHyIYDKYd15gxY/DCCy9g2bJlWL16NS666CLU1dXZ3xcVFeHnP/85fvazn+HRRx/FunXr8Oabb+KBBx4QtnPBBRfg17/+NSzLErK4ugsybrJEzLRQEjJQEiLjhiAIgsgMXdfx+OOP491338W4cePw4x//GLfeeqv9fSgUwvPPP4/q6mqcfPLJGD9+PH7961/bzSWnTZuGv/3tb3jmmWcwadIkHH/88VixYoW9/m233Yba2locffTR+O53v4srr7zSV3PRa6+9FgcffDBmzJiBadOm2QYWz3XXXYef/OQnWLBgAQ444ADMnDkT27dvF5aZNWsWAoEAZs2ahaKioi6cKX9olhyEK3CamppQWVmJxsZGVFRU5Ho4BEEQRJZob2/Hl19+iX322adHJlDCP+vXr8eoUaPw9ttv4+CDD/ZcLtU1zGT+JkExQRAEQRDdQjQaxa5du3DttdfisMMOS2nYZBMKSxEEQRAE0S288cYbGDRoEN5++23ce++9PbbfvDBu7r77bowYMQJFRUU49NBDhTihzP3334+jjz4aVVVVqKqqwvTp01MuTxAEQRBEbpg2bRosy8Knn36K8ePH99h+c27cLF68GPPnz8fChQuxcuVK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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.21559999999999996}, {'accuracy': 0.29667000000000004}, {'accuracy': 0.29594}, {'accuracy': 0.44021}, {'accuracy': 0.31455}, {'accuracy': 0.53916}, {'accuracy': 0.49347}, {'accuracy': 0.31284999999999996}, {'accuracy': 0.4010699999999999}, {'accuracy': 0.4729900000000001}, {'accuracy': 0.37173}, {'accuracy': 0.56052}, {'accuracy': 0.52311}, {'accuracy': 0.52768}, {'accuracy': 0.60937}, {'accuracy': 0.37361999999999995}, {'accuracy': 0.5819799999999999}, {'accuracy': 0.5869199999999999}, {'accuracy': 0.59449}, {'accuracy': 0.45508000000000004}, {'accuracy': 0.5771599999999999}, {'accuracy': 0.42867999999999995}, {'accuracy': 0.43423999999999996}, {'accuracy': 0.56016}, {'accuracy': 0.46523000000000003}, {'accuracy': 0.6963400000000001}, {'accuracy': 0.70059}, {'accuracy': 0.50935}, {'accuracy': 0.60355}, {'accuracy': 0.6163200000000001}, {'accuracy': 0.70282}, {'accuracy': 0.5603100000000001}, {'accuracy': 0.5811}, {'accuracy': 0.54559}, {'accuracy': 0.54614}, {'accuracy': 0.51711}, {'accuracy': 0.5629299999999999}, {'accuracy': 0.5635000000000001}, {'accuracy': 0.64659}, {'accuracy': 0.5155900000000001}, {'accuracy': 0.5926199999999999}, {'accuracy': 0.7565100000000001}, {'accuracy': 0.5315799999999999}, {'accuracy': 0.5701}, {'accuracy': 0.5980000000000001}, {'accuracy': 0.67155}, {'accuracy': 0.5071499999999999}, {'accuracy': 0.6958599999999999}, {'accuracy': 0.67095}, {'accuracy': 0.65718}, {'accuracy': 0.55476}, {'accuracy': 0.6836900000000001}, {'accuracy': 0.59376}, {'accuracy': 0.4896400000000001}, {'accuracy': 0.6034999999999999}, {'accuracy': 0.6929799999999999}, {'accuracy': 0.58824}, {'accuracy': 0.7355499999999999}, {'accuracy': 0.6436}, {'accuracy': 0.6914200000000001}, {'accuracy': 0.67779}, {'accuracy': 0.6555}, {'accuracy': 0.47202}, {'accuracy': 0.60208}, {'accuracy': 0.70982}, {'accuracy': 0.47382}, {'accuracy': 0.6636}, {'accuracy': 0.48385999999999996}, {'accuracy': 0.59724}, {'accuracy': 0.39279}, {'accuracy': 0.5235700000000001}, {'accuracy': 0.4879900000000001}, {'accuracy': 0.60864}, {'accuracy': 0.58567}, {'accuracy': 0.7001000000000001}, {'accuracy': 0.29679}, {'accuracy': 0.47009}, {'accuracy': 0.68679}, {'accuracy': 0.4769}, {'accuracy': 0.43369}, {'accuracy': 0.7174800000000001}, {'accuracy': 0.5687399999999999}, {'accuracy': 0.70198}, {'accuracy': 0.5281}, {'accuracy': 0.44759000000000004}, {'accuracy': 0.5403800000000001}, {'accuracy': 0.48507}, {'accuracy': 0.7432799999999999}, {'accuracy': 0.43014}, {'accuracy': 0.6116599999999999}, {'accuracy': 0.54798}, {'accuracy': 0.43949}, {'accuracy': 0.62802}, {'accuracy': 0.64929}, {'accuracy': 0.70285}, {'accuracy': 0.739}, {'accuracy': 0.64035}, {'accuracy': 0.5251300000000001}, {'accuracy': 0.58097}, {'accuracy': 0.4534200000000001}, {'accuracy': 0.6976800000000001}, {'accuracy': 0.61369}, {'accuracy': 0.5880099999999999}, {'accuracy': 0.64039}, {'accuracy': 0.5809900000000001}, {'accuracy': 0.56894}, {'accuracy': 0.49388999999999994}, {'accuracy': 0.6725599999999999}, {'accuracy': 0.5259599999999999}, {'accuracy': 0.72961}, {'accuracy': 0.42427000000000004}, {'accuracy': 0.6536199999999999}, {'accuracy': 0.6124799999999999}, {'accuracy': 0.51458}, {'accuracy': 0.6562699999999999}, {'accuracy': 0.75815}, {'accuracy': 0.63855}, {'accuracy': 0.5245900000000001}, {'accuracy': 0.54843}, {'accuracy': 0.5223800000000001}, {'accuracy': 0.5020100000000001}, {'accuracy': 0.60076}, {'accuracy': 0.6441399999999999}, {'accuracy': 0.62747}, {'accuracy': 0.44674}, {'accuracy': 0.57677}, {'accuracy': 0.6113500000000001}, {'accuracy': 0.62965}, {'accuracy': 0.6059599999999999}, {'accuracy': 0.6720499999999999}, {'accuracy': 0.7147800000000001}, {'accuracy': 0.57392}, {'accuracy': 0.6545099999999999}, {'accuracy': 0.6063}, {'accuracy': 0.6511100000000001}, {'accuracy': 0.589}, {'accuracy': 0.47674000000000005}, {'accuracy': 0.6853400000000001}, {'accuracy': 0.5566}, {'accuracy': 0.77801}, {'accuracy': 0.57141}, {'accuracy': 0.66124}, {'accuracy': 0.6890599999999999}, {'accuracy': 0.50973}, {'accuracy': 0.57809}, {'accuracy': 0.60396}, {'accuracy': 0.6257699999999999}, {'accuracy': 0.44891}, {'accuracy': 0.6818}, {'accuracy': 0.52448}, {'accuracy': 0.62525}, {'accuracy': 0.49254999999999993}, {'accuracy': 0.41264}, {'accuracy': 0.51095}, {'accuracy': 0.7006399999999999}, {'accuracy': 0.54913}, {'accuracy': 0.61032}, {'accuracy': 0.66469}, {'accuracy': 0.5823600000000001}, {'accuracy': 0.56058}, {'accuracy': 0.63278}, {'accuracy': 0.5427799999999999}, {'accuracy': 0.7306699999999999}, {'accuracy': 0.71853}, {'accuracy': 0.5896899999999999}, {'accuracy': 0.65888}, {'accuracy': 0.6449200000000002}, {'accuracy': 0.74981}, {'accuracy': 0.7198599999999999}, {'accuracy': 0.63932}, {'accuracy': 0.7037199999999999}, {'accuracy': 0.64812}, {'accuracy': 0.7276}, {'accuracy': 0.5941699999999999}, {'accuracy': 0.58095}, {'accuracy': 0.7250499999999999}, {'accuracy': 0.5852900000000001}, {'accuracy': 0.58453}, {'accuracy': 0.7538699999999999}, {'accuracy': 0.47467999999999994}, {'accuracy': 0.61714}, {'accuracy': 0.7109399999999999}, {'accuracy': 0.7323000000000001}, {'accuracy': 0.6165499999999999}, {'accuracy': 0.7164}, {'accuracy': 0.6734700000000001}, {'accuracy': 0.5731400000000001}, {'accuracy': 0.44948}, {'accuracy': 0.7323500000000001}, {'accuracy': 0.65185}, {'accuracy': 0.46690000000000004}, {'accuracy': 0.57555}, {'accuracy': 0.6397799999999999}, {'accuracy': 0.5197}, {'accuracy': 0.69441}, {'accuracy': 0.6546000000000001}, {'accuracy': 0.53822}, {'accuracy': 0.76993}, {'accuracy': 0.56456}, {'accuracy': 0.6900099999999999}, {'accuracy': 0.5428099999999999}, {'accuracy': 0.75501}, {'accuracy': 0.68764}, {'accuracy': 0.84573}, {'accuracy': 0.8419799999999998}, {'accuracy': 0.8337299999999999}, {'accuracy': 0.82294}, {'accuracy': 0.8263999999999999}, {'accuracy': 0.82538}, {'accuracy': 0.83729}, {'accuracy': 0.82582}, {'accuracy': 0.8339500000000001}, {'accuracy': 0.8350299999999999}, {'accuracy': 0.8324499999999999}, {'accuracy': 0.82826}, {'accuracy': 0.82986}, {'accuracy': 0.8312899999999999}, {'accuracy': 0.8336499999999999}, {'accuracy': 0.81233}, {'accuracy': 0.8347899999999999}, {'accuracy': 0.8302099999999999}, {'accuracy': 0.8416699999999999}, {'accuracy': 0.842}, {'accuracy': 0.83819}, {'accuracy': 0.83797}, {'accuracy': 0.8382499999999998}, {'accuracy': 0.8250499999999998}, {'accuracy': 0.83119}, {'accuracy': 0.83725}, {'accuracy': 0.8270099999999999}, {'accuracy': 0.8342699999999998}, {'accuracy': 0.84231}, {'accuracy': 0.8338700000000001}, {'accuracy': 0.83323}, {'accuracy': 0.83301}, {'accuracy': 0.84016}, {'accuracy': 0.8356299999999999}, {'accuracy': 0.83681}, {'accuracy': 0.8321500000000001}, {'accuracy': 0.8378399999999999}, {'accuracy': 0.8276600000000001}, {'accuracy': 0.83614}, {'accuracy': 0.8323599999999999}, {'accuracy': 0.83626}, {'accuracy': 0.82927}, {'accuracy': 0.83759}, {'accuracy': 0.8251900000000001}, {'accuracy': 0.83253}, {'accuracy': 0.82193}, {'accuracy': 0.83715}, {'accuracy': 0.8360999999999998}, {'accuracy': 0.83087}, {'accuracy': 0.8349500000000001}, {'accuracy': 0.8240000000000001}, {'accuracy': 0.8428099999999998}, {'accuracy': 0.8347999999999999}, {'accuracy': 0.8295299999999999}, {'accuracy': 0.8260099999999999}, {'accuracy': 0.8299199999999999}, {'accuracy': 0.8288300000000002}, {'accuracy': 0.84443}, {'accuracy': 0.83012}, {'accuracy': 0.83151}, {'accuracy': 0.81525}, {'accuracy': 0.8293200000000001}, {'accuracy': 0.8331099999999999}, {'accuracy': 0.83941}, {'accuracy': 0.8303800000000001}, {'accuracy': 0.82934}, {'accuracy': 0.8230600000000001}, {'accuracy': 0.82796}, {'accuracy': 0.8334699999999999}, {'accuracy': 0.83185}, {'accuracy': 0.8413400000000001}, {'accuracy': 0.8319699999999999}, {'accuracy': 0.83363}, {'accuracy': 0.8300600000000001}, {'accuracy': 0.82089}, {'accuracy': 0.8341800000000001}, {'accuracy': 0.83757}, {'accuracy': 0.8389299999999998}, {'accuracy': 0.8325400000000001}, {'accuracy': 0.83736}, {'accuracy': 0.8360099999999999}, {'accuracy': 0.8359500000000001}, {'accuracy': 0.8367000000000001}, {'accuracy': 0.84045}, {'accuracy': 0.83779}, {'accuracy': 0.8397300000000001}, {'accuracy': 0.83356}, {'accuracy': 0.82736}, {'accuracy': 0.84206}, {'accuracy': 0.83798}, {'accuracy': 0.8435699999999999}, {'accuracy': 0.82758}, {'accuracy': 0.8244}, {'accuracy': 0.8321799999999999}, {'accuracy': 0.83604}, {'accuracy': 0.8397}, {'accuracy': 0.82488}]\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecbbe105-9bf7-445c-98fa-8978922c9d1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ef2d273-250d-450a-a662-a7b72def491b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90e437aa-9da1-4ab9-9e45-ba89e95f207a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb4baa5-ba6c-4102-91e4-111c3b0b5fa2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b1dc97-431b-4a8f-ba04-61d4c3cc6abd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8986be3-03f4-4ebc-bfd3-794fbef7f9ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcd47ac2-d80f-4e13-9b76-d03483431081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc113a2c-dfd9-4dae-a973-ba5925b4f9bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6ac9abe-848f-49c2-9fc8-c94e75015695",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22f6eba1-7059-491f-bacd-0739425d9305",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d98f7ea7-9936-4a3b-8585-ecfc1913085e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "746d526e-8881-4cb2-b68d-452746c6d54d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da48ec35-c3a6-40d0-9270-3198f50624fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd1aaa-0b48-4c79-ab96-9e1ae83cc05b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b075f14c-fd7b-4ec5-b1fa-2a28849415e3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "daae2304-0047-45a4-a66b-9a6326ac7fb9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "445c866f-406f-4428-9c9d-82b831e82c0b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ae621b8-b5f9-4d9b-8efc-94579ce23f6a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b439c38a-b8f4-4f3f-8f93-d63d7ccacd99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b17f69e3-9695-4872-a543-b6222b14419c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39794712-7caf-45d3-9ac5-914c20831a10",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edd6d83e-1ff4-40df-b758-3ba2df4796f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1318dd27-348e-4db1-8107-a5ed86a52381",
   "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
}
