{
 "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",
      "5980\n",
      "[[  0 635]\n",
      " [  1 693]\n",
      " [  2 654]\n",
      " [  3 630]\n",
      " [  4 627]\n",
      " [  5 545]\n",
      " [  6 590]\n",
      " [  7 587]\n",
      " [  8 599]\n",
      " [  9 601]]\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": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 4, 2,  ..., 6, 0, 1])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "17876\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 407]\n",
      " [  1 457]\n",
      " [  2 438]\n",
      " [  3 419]\n",
      " [  4 393]\n",
      " [  5 400]\n",
      " [  6 420]\n",
      " [  7 420]\n",
      " [  8 421]\n",
      " [  9 438]]\n",
      "[[   0 1204]\n",
      " [   1  476]\n",
      " [   2  451]\n",
      " [   3  436]\n",
      " [   4  416]\n",
      " [   5  447]\n",
      " [   6  529]\n",
      " [   7  542]\n",
      " [   8  691]\n",
      " [   9  898]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 4, 2,  ..., 9, 9, 9])"
      ]
     },
     "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<3:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "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\">151023-20:50:45 </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;36m151023-20:50:45\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": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c53cef1ab18a47b39e7d62c78b004d35",
       "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\"></pre>\n"
      ],
      "text/plain": []
     },
     "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"
      ]
     },
     "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-23:36:27 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3477</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:36:27\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3477\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\">75937680</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;36m75937680\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.91</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.91\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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axaMRmOkh9ImoOsVOHStgoOuV+DQtQoculbB0RquV8wZigmCIAiCiG4ockMQBEEQRFRB4oYgCIIgiKiCxA1BEARBEFEFiRuCIAiCIKIKEjctwNtvv41OnTrBZDJhxIgRWL9+faSHFHGefvppCIIg++nVq5f0vNlsxr333ot27dohMTERV199NYqLiyM44vDx22+/4dJLL0VeXh4EQcC3334re14URcycORO5ubmIi4vDuHHjsG/fPtk2FRUVuPHGG5GcnIzU1FTcdtttqKurC+NZhI+mrtctt9zi9Vm74IILZNvEyvWaPXs2TjvtNCQlJSErKwtXXHEF9uzZI9smkO/e0aNHcfHFFyM+Ph5ZWVl49NFHYbfbw3kqISeQa3XOOed4fbb+9re/ybaJhWsFAO+++y4GDBggNeYbOXIkfvnlF+n51va5InFzisyfPx/Tpk3DrFmzsGnTJgwcOBDjx49HSUlJpIcWcfr27YvCwkLpZ9WqVdJzDz30EH744Qd89dVXWLlyJU6ePImrrroqgqMNH/X19Rg4cCDefvtt1edfeuklvPnmm3jvvfewbt06JCQkYPz48TCbzdI2N954I3bs2IHFixfjxx9/xG+//YY777wzXKcQVpq6XgBwwQUXyD5rX3zxhez5WLleK1euxL333os//vgDixcvhs1mw/nnn4/6+nppm6a+ew6HAxdffDGsVivWrFmDTz75BHPnzsXMmTMjcUohI5BrBQB33HGH7LP10ksvSc/FyrUCgPbt2+OFF17Axo0b8eeff2LMmDG4/PLLsWPHDgCt8HMlEqfE8OHDxXvvvVf63eFwiHl5eeLs2bMjOKrIM2vWLHHgwIGqz1VVVYl6vV786quvpMd27dolAhDXrl0bphG2DgCI33zzjfS70+kUc3JyxJdffll6rKqqSjQajeIXX3whiqIo7ty5UwQgbtiwQdrml19+EQVBEE+cOBG2sUcC5fUSRVGcPHmyePnll/t8TSxfr5KSEhGAuHLlSlEUA/vu/fzzz6JGoxGLioqkbd59910xOTlZtFgs4T2BMKK8VqIoimeffbb4wAMP+HxNrF4rRlpamvjvf/+7VX6uKHJzClitVmzcuBHjxo2THtNoNBg3bhzWrl0bwZG1Dvbt24e8vDx06dIFN954I44ePQoA2LhxI2w2m+y69erVCx06dIj563bo0CEU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",
      "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.09786}, {'accuracy': 0.10124}, {'accuracy': 0.16911000000000004}, {'accuracy': 0.3321}, {'accuracy': 0.29436}, {'accuracy': 0.27364}, {'accuracy': 0.30202}, {'accuracy': 0.33788999999999997}, {'accuracy': 0.49885999999999997}, {'accuracy': 0.49793000000000004}, {'accuracy': 0.5313699999999999}, {'accuracy': 0.38506000000000007}, {'accuracy': 0.40388999999999997}, {'accuracy': 0.5115999999999999}, {'accuracy': 0.5641}, {'accuracy': 0.48643000000000003}, {'accuracy': 0.5254000000000001}, {'accuracy': 0.46436}, {'accuracy': 0.4591200000000001}, {'accuracy': 0.42962}, {'accuracy': 0.6086199999999999}, {'accuracy': 0.54733}, {'accuracy': 0.46918}, {'accuracy': 0.63732}, {'accuracy': 0.44964000000000015}, {'accuracy': 0.6498200000000001}, {'accuracy': 0.57033}, {'accuracy': 0.6165999999999999}, {'accuracy': 0.56329}, {'accuracy': 0.7071500000000001}, {'accuracy': 0.50747}, {'accuracy': 0.5864}, {'accuracy': 0.63931}, {'accuracy': 0.5101899999999999}, {'accuracy': 0.5526}, {'accuracy': 0.44692999999999994}, {'accuracy': 0.39986}, {'accuracy': 0.5838}, {'accuracy': 0.61096}, {'accuracy': 0.60448}, {'accuracy': 0.5545199999999999}, {'accuracy': 0.63844}, {'accuracy': 0.58768}, {'accuracy': 0.5840500000000001}, {'accuracy': 0.54611}, {'accuracy': 0.64564}, {'accuracy': 0.50851}, {'accuracy': 0.58151}, {'accuracy': 0.7068800000000001}, {'accuracy': 0.57497}, {'accuracy': 0.52603}, {'accuracy': 0.55384}, {'accuracy': 0.49874999999999997}, {'accuracy': 0.62675}, {'accuracy': 0.5850299999999999}, {'accuracy': 0.48956}, {'accuracy': 0.55583}, {'accuracy': 0.54832}, {'accuracy': 0.73156}, {'accuracy': 0.6895}, {'accuracy': 0.5500999999999999}, {'accuracy': 0.55737}, {'accuracy': 0.7129700000000001}, {'accuracy': 0.49736}, {'accuracy': 0.5433299999999999}, {'accuracy': 0.7008400000000001}, {'accuracy': 0.37970000000000004}, {'accuracy': 0.50363}, {'accuracy': 0.64229}, {'accuracy': 0.48518}, {'accuracy': 0.54216}, {'accuracy': 0.57279}, {'accuracy': 0.6326200000000001}, {'accuracy': 0.5092700000000001}, {'accuracy': 0.61601}, {'accuracy': 0.57743}, {'accuracy': 0.5902700000000001}, {'accuracy': 0.5845}, {'accuracy': 0.58299}, {'accuracy': 0.5188599999999999}, {'accuracy': 0.59878}, {'accuracy': 0.5505500000000001}, {'accuracy': 0.51422}, {'accuracy': 0.5134700000000001}, {'accuracy': 0.40717}, {'accuracy': 0.6362099999999999}, {'accuracy': 0.6232}, {'accuracy': 0.57247}, {'accuracy': 0.51755}, {'accuracy': 0.5269799999999999}, {'accuracy': 0.47985}, {'accuracy': 0.62344}, {'accuracy': 0.5576700000000001}, {'accuracy': 0.53258}, {'accuracy': 0.44987999999999995}, {'accuracy': 0.6287799999999999}, {'accuracy': 0.47081}, {'accuracy': 0.5910299999999999}, {'accuracy': 0.70868}, {'accuracy': 0.7284999999999999}, {'accuracy': 0.60584}, {'accuracy': 0.5321}, {'accuracy': 0.55875}, {'accuracy': 0.5119}, {'accuracy': 0.41395}, {'accuracy': 0.5242100000000001}, {'accuracy': 0.6710799999999999}, {'accuracy': 0.6597999999999999}, {'accuracy': 0.46701999999999994}, {'accuracy': 0.6414}, {'accuracy': 0.51218}, {'accuracy': 0.5113300000000001}, {'accuracy': 0.58856}, {'accuracy': 0.67768}, {'accuracy': 0.6621300000000001}, {'accuracy': 0.5426500000000001}, {'accuracy': 0.62012}, {'accuracy': 0.74331}, {'accuracy': 0.51842}, {'accuracy': 0.5116400000000001}, {'accuracy': 0.59901}, {'accuracy': 0.5249599999999999}, {'accuracy': 0.5338}, {'accuracy': 0.6108}, {'accuracy': 0.5046700000000001}, {'accuracy': 0.48558}, {'accuracy': 0.53684}, {'accuracy': 0.5838800000000001}, {'accuracy': 0.59306}, {'accuracy': 0.59853}, {'accuracy': 0.5303899999999999}, {'accuracy': 0.47203999999999996}, {'accuracy': 0.5670700000000001}, {'accuracy': 0.49759000000000003}, {'accuracy': 0.53321}, {'accuracy': 0.48216000000000003}, {'accuracy': 0.5951199999999999}, {'accuracy': 0.5802099999999999}, {'accuracy': 0.5714499999999999}, {'accuracy': 0.44300000000000006}, {'accuracy': 0.5431}, {'accuracy': 0.54757}, {'accuracy': 0.5322800000000001}, {'accuracy': 0.6286099999999999}, {'accuracy': 0.39390000000000003}, {'accuracy': 0.53788}, {'accuracy': 0.62318}, {'accuracy': 0.4741099999999999}, {'accuracy': 0.61651}, {'accuracy': 0.60571}, {'accuracy': 0.32284999999999997}, {'accuracy': 0.64672}, {'accuracy': 0.75977}, {'accuracy': 0.91701}, {'accuracy': 0.9276399999999999}, {'accuracy': 0.9432799999999999}, {'accuracy': 0.9219700000000002}, {'accuracy': 0.91014}, {'accuracy': 0.93269}, {'accuracy': 0.9179599999999999}, {'accuracy': 0.86601}, {'accuracy': 0.9161000000000001}, {'accuracy': 0.91899}, {'accuracy': 0.91576}, {'accuracy': 0.9315299999999999}, {'accuracy': 0.9221299999999999}, {'accuracy': 0.92233}, {'accuracy': 0.90364}, {'accuracy': 0.9172800000000001}, {'accuracy': 0.9282300000000001}, {'accuracy': 0.8909799999999999}, {'accuracy': 0.89748}, {'accuracy': 0.9037499999999999}, {'accuracy': 0.93503}, {'accuracy': 0.8884599999999999}, {'accuracy': 0.85552}, {'accuracy': 0.9057999999999999}, {'accuracy': 0.92515}, {'accuracy': 0.8911199999999999}, {'accuracy': 0.89352}, {'accuracy': 0.9421899999999999}, {'accuracy': 0.8969699999999999}, {'accuracy': 0.92458}, {'accuracy': 0.9104399999999998}, {'accuracy': 0.91607}, {'accuracy': 0.9373900000000001}, {'accuracy': 0.8740499999999999}, {'accuracy': 0.93469}, {'accuracy': 0.9196500000000001}, {'accuracy': 0.9270799999999999}, {'accuracy': 0.92103}, {'accuracy': 0.9366099999999999}, {'accuracy': 0.9084199999999999}, {'accuracy': 0.91959}, {'accuracy': 0.9138900000000001}, {'accuracy': 0.90926}, {'accuracy': 0.90456}, {'accuracy': 0.9165600000000002}, {'accuracy': 0.9007100000000001}, {'accuracy': 0.9252100000000001}, {'accuracy': 0.9362199999999999}, {'accuracy': 0.9406500000000001}, {'accuracy': 0.91349}, {'accuracy': 0.89696}, {'accuracy': 0.93566}, {'accuracy': 0.92591}, {'accuracy': 0.8962800000000002}, {'accuracy': 0.9142800000000001}, {'accuracy': 0.9136700000000001}, {'accuracy': 0.9431100000000001}, {'accuracy': 0.86822}, {'accuracy': 0.9349400000000001}, {'accuracy': 0.9350099999999999}, {'accuracy': 0.92351}, {'accuracy': 0.90312}, {'accuracy': 0.93514}, {'accuracy': 0.9360200000000001}, {'accuracy': 0.9445199999999998}, {'accuracy': 0.8994199999999999}, {'accuracy': 0.9137299999999999}, {'accuracy': 0.93735}, {'accuracy': 0.93732}, {'accuracy': 0.9019999999999999}, {'accuracy': 0.9070599999999999}, {'accuracy': 0.92646}, {'accuracy': 0.9342599999999999}, {'accuracy': 0.9335100000000001}, {'accuracy': 0.9402099999999999}, {'accuracy': 0.85444}, {'accuracy': 0.9160899999999998}, {'accuracy': 0.9355099999999998}, {'accuracy': 0.93047}, {'accuracy': 0.9069500000000001}, {'accuracy': 0.86732}, {'accuracy': 0.9176500000000001}, {'accuracy': 0.9156500000000001}, {'accuracy': 0.90295}, {'accuracy': 0.8808599999999999}, {'accuracy': 0.9312299999999999}, {'accuracy': 0.91171}, {'accuracy': 0.8865299999999999}, {'accuracy': 0.9038999999999999}, {'accuracy': 0.8945700000000001}, {'accuracy': 0.88361}, {'accuracy': 0.9328800000000002}, {'accuracy': 0.9053000000000001}, {'accuracy': 0.92712}, {'accuracy': 0.9222899999999999}, {'accuracy': 0.9054800000000002}, {'accuracy': 0.8929}, {'accuracy': 0.8986799999999999}, {'accuracy': 0.9143000000000001}, {'accuracy': 0.94299}, {'accuracy': 0.9056299999999998}, {'accuracy': 0.92677}, {'accuracy': 0.9261800000000001}, {'accuracy': 0.9270200000000001}, {'accuracy': 0.89131}, {'accuracy': 0.9116899999999999}, {'accuracy': 0.91716}, {'accuracy': 0.9119400000000001}, {'accuracy': 0.91425}, {'accuracy': 0.9097000000000002}, {'accuracy': 0.9292400000000001}, {'accuracy': 0.93788}, {'accuracy': 0.8937299999999999}, {'accuracy': 0.9169700000000001}, {'accuracy': 0.93459}, {'accuracy': 0.8899000000000001}, {'accuracy': 0.93312}, {'accuracy': 0.9189700000000001}, {'accuracy': 0.8895700000000002}, {'accuracy': 0.9355499999999999}, {'accuracy': 0.92398}, {'accuracy': 0.90831}, {'accuracy': 0.91232}, {'accuracy': 0.93354}, {'accuracy': 0.93129}, {'accuracy': 0.89247}, {'accuracy': 0.9345399999999999}, {'accuracy': 0.9120700000000002}, {'accuracy': 0.9224799999999999}, {'accuracy': 0.93696}, {'accuracy': 0.8953700000000001}, {'accuracy': 0.9420300000000001}, {'accuracy': 0.9217299999999999}, {'accuracy': 0.88386}, {'accuracy': 0.89721}, {'accuracy': 0.92981}, {'accuracy': 0.93496}, {'accuracy': 0.9130800000000001}, {'accuracy': 0.8911000000000001}, {'accuracy': 0.9224299999999998}, {'accuracy': 0.9231400000000001}, {'accuracy': 0.9230700000000001}, {'accuracy': 0.90629}, {'accuracy': 0.92621}, {'accuracy': 0.92121}, {'accuracy': 0.9267999999999998}, {'accuracy': 0.9078399999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1a06e9b-29ae-4b49-8cb3-6485f54196c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0466bfc8-01c6-4e95-ac8f-5bb2f3e8800c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3e31187-e7c9-4930-b2a2-21bf27b7b0e6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76d24054-ad14-4c0f-b8b4-01877259ec9c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "256af20e-b1f5-4214-b005-91ef9503bc56",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b3613ed-ded9-4cf2-bd83-03194188c407",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9def9999-c78e-4993-a767-15c05c93f0db",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0fe241d-94e7-4e5c-8d65-466d54f2da35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "faf0f2a7-50bc-4fe3-b125-f4c30ff6a766",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83007093-86ad-45ae-be6b-6b091c798b6e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "996d1358-0df3-4e3b-a852-52576fe3f0da",
   "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
}
