{
 "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 CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "5996\n",
      "[[  0 560]\n",
      " [  1 687]\n",
      " [  2 570]\n",
      " [  3 627]\n",
      " [  4 603]\n",
      " [  5 504]\n",
      " [  6 595]\n",
      " [  7 609]\n",
      " [  8 611]\n",
      " [  9 599]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6072\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 557]\n",
      " [  1 599]\n",
      " [  2 512]\n",
      " [  3 573]\n",
      " [  4 558]\n",
      " [  5 482]\n",
      " [  6 506]\n",
      " [  7 567]\n",
      " [  8 517]\n",
      " [  9 522]]\n",
      "[[  0 806]\n",
      " [  1 603]\n",
      " [  2 524]\n",
      " [  3 581]\n",
      " [  4 565]\n",
      " [  5 502]\n",
      " [  6 538]\n",
      " [  7 621]\n",
      " [  8 616]\n",
      " [  9 672]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 9, 4,  ..., 4, 9, 2])"
      ]
     },
     "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([9, 9, 4,  ..., 4, 9, 2])"
      ]
     },
     "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">141023-22:09:36 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m141023-22:09:36\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0a29ec22984348c3bead9a36cf7f6650",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-00:01:55 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3224</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-00:01:55\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3224\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">70412160</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m70412160\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\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.98</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.98\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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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": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.11229}, {'accuracy': 0.29856}, {'accuracy': 0.5407200000000001}, {'accuracy': 0.78086}, {'accuracy': 0.86395}, {'accuracy': 0.83284}, {'accuracy': 0.86448}, {'accuracy': 0.8118700000000001}, {'accuracy': 0.8625399999999999}, {'accuracy': 0.81524}, {'accuracy': 0.89849}, {'accuracy': 0.89611}, {'accuracy': 0.8849}, {'accuracy': 0.90959}, {'accuracy': 0.89563}, {'accuracy': 0.9165400000000001}, {'accuracy': 0.9261600000000001}, {'accuracy': 0.9320200000000002}, {'accuracy': 0.9228500000000001}, {'accuracy': 0.93151}, {'accuracy': 0.9385299999999999}, {'accuracy': 0.92993}, {'accuracy': 0.9309899999999999}, {'accuracy': 0.9403899999999998}, {'accuracy': 0.9371}, {'accuracy': 0.9463600000000001}, {'accuracy': 0.93825}, {'accuracy': 0.9424199999999999}, {'accuracy': 0.9383900000000001}, {'accuracy': 0.95557}, {'accuracy': 0.9509500000000001}, {'accuracy': 0.9433399999999998}, {'accuracy': 0.95107}, {'accuracy': 0.94404}, {'accuracy': 0.9491799999999999}, {'accuracy': 0.93489}, {'accuracy': 0.9477}, {'accuracy': 0.95335}, {'accuracy': 0.9452699999999998}, {'accuracy': 0.9478500000000001}, {'accuracy': 0.9515600000000001}, {'accuracy': 0.95313}, {'accuracy': 0.9489599999999999}, {'accuracy': 0.9468100000000002}, {'accuracy': 0.9575800000000001}, {'accuracy': 0.9544499999999999}, {'accuracy': 0.9445400000000002}, {'accuracy': 0.9360399999999999}, {'accuracy': 0.9559000000000001}, {'accuracy': 0.95618}, {'accuracy': 0.95548}, {'accuracy': 0.9526600000000001}, {'accuracy': 0.9582499999999999}, {'accuracy': 0.96068}, {'accuracy': 0.95536}, {'accuracy': 0.9652200000000001}, {'accuracy': 0.9652000000000001}, {'accuracy': 0.9455899999999999}, {'accuracy': 0.9515499999999999}, {'accuracy': 0.95572}, {'accuracy': 0.9644400000000001}, {'accuracy': 0.9651500000000001}, {'accuracy': 0.95717}, {'accuracy': 0.9617700000000001}, {'accuracy': 0.95665}, {'accuracy': 0.9640200000000002}, {'accuracy': 0.9555400000000001}, {'accuracy': 0.9494300000000002}, {'accuracy': 0.9577899999999999}, {'accuracy': 0.96311}, {'accuracy': 0.9628699999999999}, {'accuracy': 0.9538800000000001}, {'accuracy': 0.96588}, {'accuracy': 0.96003}, {'accuracy': 0.9644299999999999}, {'accuracy': 0.9683399999999999}, {'accuracy': 0.95708}, {'accuracy': 0.96689}, {'accuracy': 0.9627699999999999}, {'accuracy': 0.9575000000000001}, {'accuracy': 0.9665000000000001}, {'accuracy': 0.95957}, {'accuracy': 0.96926}, {'accuracy': 0.9663600000000001}, {'accuracy': 0.96752}, {'accuracy': 0.9606299999999999}, {'accuracy': 0.95954}, {'accuracy': 0.9710699999999999}, {'accuracy': 0.9591200000000001}, {'accuracy': 0.9705999999999999}, {'accuracy': 0.95974}, {'accuracy': 0.96743}, {'accuracy': 0.9709299999999998}, {'accuracy': 0.9677899999999999}, {'accuracy': 0.9582400000000002}, {'accuracy': 0.9678800000000001}, {'accuracy': 0.96237}, {'accuracy': 0.96745}, {'accuracy': 0.96187}, {'accuracy': 0.96305}, {'accuracy': 0.9686900000000002}, {'accuracy': 0.96488}, {'accuracy': 0.9616}, {'accuracy': 0.9699199999999999}, {'accuracy': 0.9581}, {'accuracy': 0.9664300000000001}, {'accuracy': 0.97313}, {'accuracy': 0.9680899999999999}, {'accuracy': 0.96449}, {'accuracy': 0.9602600000000001}, {'accuracy': 0.96486}, {'accuracy': 0.9609099999999999}, {'accuracy': 0.9762500000000001}, {'accuracy': 0.9700300000000001}, {'accuracy': 0.97219}, {'accuracy': 0.9675100000000001}, {'accuracy': 0.9653}, {'accuracy': 0.96395}, {'accuracy': 0.9645300000000001}, {'accuracy': 0.96315}, {'accuracy': 0.9716800000000001}, {'accuracy': 0.9677300000000001}, {'accuracy': 0.9704499999999999}, {'accuracy': 0.97076}, {'accuracy': 0.9757}, {'accuracy': 0.9679}, {'accuracy': 0.95313}, {'accuracy': 0.9684900000000001}, {'accuracy': 0.9680200000000001}, {'accuracy': 0.96763}, {'accuracy': 0.9697699999999999}, {'accuracy': 0.96237}, {'accuracy': 0.9688699999999999}, {'accuracy': 0.9689900000000001}, {'accuracy': 0.9669000000000001}, {'accuracy': 0.96594}, {'accuracy': 0.9673700000000001}, {'accuracy': 0.97219}, {'accuracy': 0.97593}, {'accuracy': 0.9738300000000001}, {'accuracy': 0.97298}, {'accuracy': 0.9709200000000001}, {'accuracy': 0.97779}, {'accuracy': 0.9718199999999999}, {'accuracy': 0.96273}, {'accuracy': 0.97237}, {'accuracy': 0.9719199999999999}, {'accuracy': 0.9714700000000001}, {'accuracy': 0.96594}, {'accuracy': 0.95074}, {'accuracy': 0.9520000000000002}, {'accuracy': 0.96526}, {'accuracy': 0.89069}, {'accuracy': 0.9761200000000001}, {'accuracy': 0.97599}, {'accuracy': 0.9767800000000001}, {'accuracy': 0.97639}, {'accuracy': 0.97818}, {'accuracy': 0.97858}, {'accuracy': 0.97843}, {'accuracy': 0.9790800000000001}, {'accuracy': 0.97905}, {'accuracy': 0.9793200000000001}, {'accuracy': 0.9796299999999999}, {'accuracy': 0.97919}, {'accuracy': 0.97987}, {'accuracy': 0.9796199999999999}, {'accuracy': 0.97991}, {'accuracy': 0.9802199999999999}, {'accuracy': 0.98026}, {'accuracy': 0.9800000000000001}, {'accuracy': 0.9804600000000001}, {'accuracy': 0.98051}, {'accuracy': 0.9802700000000002}, {'accuracy': 0.9808599999999998}, {'accuracy': 0.9805300000000001}, {'accuracy': 0.98081}, {'accuracy': 0.98055}, {'accuracy': 0.98095}, {'accuracy': 0.9808299999999999}, {'accuracy': 0.9803999999999998}, {'accuracy': 0.9808899999999999}, {'accuracy': 0.9808999999999999}, {'accuracy': 0.98145}, {'accuracy': 0.9816499999999999}, {'accuracy': 0.9818000000000001}, {'accuracy': 0.9816899999999998}, {'accuracy': 0.98138}, {'accuracy': 0.9816900000000001}, {'accuracy': 0.9814699999999998}, {'accuracy': 0.9811200000000001}, {'accuracy': 0.98125}, {'accuracy': 0.98188}, {'accuracy': 0.98174}, {'accuracy': 0.9814999999999999}, {'accuracy': 0.9821500000000001}, {'accuracy': 0.98177}, {'accuracy': 0.98177}, {'accuracy': 0.9817600000000001}, {'accuracy': 0.9814299999999999}, {'accuracy': 0.9819700000000001}, {'accuracy': 0.98187}, {'accuracy': 0.98127}, {'accuracy': 0.9813600000000001}, {'accuracy': 0.98173}, {'accuracy': 0.98177}, {'accuracy': 0.9822199999999999}, {'accuracy': 0.9819600000000002}, {'accuracy': 0.9820800000000001}, {'accuracy': 0.98186}, {'accuracy': 0.9817600000000001}, {'accuracy': 0.9819000000000001}, {'accuracy': 0.98192}, {'accuracy': 0.9820499999999999}, {'accuracy': 0.98192}, {'accuracy': 0.98203}, {'accuracy': 0.9821}, {'accuracy': 0.9816699999999999}, {'accuracy': 0.9823000000000001}, {'accuracy': 0.9820499999999999}, {'accuracy': 0.98209}, {'accuracy': 0.98195}, {'accuracy': 0.9821799999999999}, {'accuracy': 0.9821000000000002}, {'accuracy': 0.98214}, {'accuracy': 0.9824099999999998}, {'accuracy': 0.9825200000000003}, {'accuracy': 0.9821099999999999}, {'accuracy': 0.98186}, {'accuracy': 0.9821199999999999}, {'accuracy': 0.9826900000000001}, {'accuracy': 0.98199}, {'accuracy': 0.98271}, {'accuracy': 0.98249}, {'accuracy': 0.98247}, {'accuracy': 0.98245}, {'accuracy': 0.98239}, {'accuracy': 0.98241}, {'accuracy': 0.9823700000000001}, {'accuracy': 0.9825899999999999}, {'accuracy': 0.9825199999999998}, {'accuracy': 0.98253}, {'accuracy': 0.98245}, {'accuracy': 0.9822299999999998}, {'accuracy': 0.98225}, {'accuracy': 0.98238}, {'accuracy': 0.98242}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.9820399999999999}, {'accuracy': 0.9823600000000001}, {'accuracy': 0.9823699999999999}, {'accuracy': 0.98254}, {'accuracy': 0.9825800000000001}, {'accuracy': 0.98253}, {'accuracy': 0.98278}, {'accuracy': 0.98261}, {'accuracy': 0.98248}, {'accuracy': 0.98256}, {'accuracy': 0.98268}, {'accuracy': 0.9825200000000001}, {'accuracy': 0.9826600000000001}, {'accuracy': 0.9828199999999999}, {'accuracy': 0.9832000000000001}, {'accuracy': 0.98254}, {'accuracy': 0.9825200000000001}, {'accuracy': 0.9825900000000001}, {'accuracy': 0.9825000000000002}, {'accuracy': 0.9827800000000002}, {'accuracy': 0.9828600000000002}, {'accuracy': 0.9826}, {'accuracy': 0.98246}, {'accuracy': 0.98264}, {'accuracy': 0.98315}, {'accuracy': 0.9828199999999999}, {'accuracy': 0.98275}, {'accuracy': 0.9827299999999999}, {'accuracy': 0.9827599999999999}, {'accuracy': 0.9825799999999999}, {'accuracy': 0.9823599999999999}, {'accuracy': 0.98293}, {'accuracy': 0.98242}, {'accuracy': 0.9828000000000001}, {'accuracy': 0.98246}, {'accuracy': 0.98264}, {'accuracy': 0.98245}, {'accuracy': 0.98278}, {'accuracy': 0.9826699999999999}, {'accuracy': 0.9823599999999999}, {'accuracy': 0.9827899999999999}, {'accuracy': 0.9827300000000001}, {'accuracy': 0.9822900000000001}, {'accuracy': 0.9822}, {'accuracy': 0.9827800000000002}, {'accuracy': 0.98277}, {'accuracy': 0.98303}, {'accuracy': 0.9827600000000001}, {'accuracy': 0.9827400000000001}, {'accuracy': 0.9827600000000001}, {'accuracy': 0.9828800000000001}, {'accuracy': 0.9831300000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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": "1dd808db-dbf4-46b6-bba6-41b0e0e2397f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9245efd-12fe-4b84-b73b-ccfd07bfb1f1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ef08e55-e5f9-46d6-a59d-ed752969dc0f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b59413c-5f6c-4128-9008-82fb3e0b6cb9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cff42066-b62e-4b16-9023-852183e8ccdb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43fb8aa2-81c2-49d9-b70e-92dfa6a96a2d",
   "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
}
