{
 "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",
    "    \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",
      "5961\n",
      "[[  0 613]\n",
      " [  1 664]\n",
      " [  2 614]\n",
      " [  3 629]\n",
      " [  4 557]\n",
      " [  5 536]\n",
      " [  6 613]\n",
      " [  7 667]\n",
      " [  8 598]\n",
      " [  9 596]]\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": [
      "17899\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 460]\n",
      " [  1 478]\n",
      " [  2 400]\n",
      " [  3 425]\n",
      " [  4 436]\n",
      " [  5 387]\n",
      " [  6 412]\n",
      " [  7 399]\n",
      " [  8 400]\n",
      " [  9 414]]\n",
      "[[   0 1203]\n",
      " [   1  494]\n",
      " [   2  410]\n",
      " [   3  451]\n",
      " [   4  469]\n",
      " [   5  448]\n",
      " [   6  509]\n",
      " [   7  566]\n",
      " [   8  661]\n",
      " [   9  860]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([3, 0, 0,  ..., 0, 4, 5])"
      ]
     },
     "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<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",
    "        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([3, 0, 0,  ..., 0, 4, 5])"
      ]
     },
     "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])"
   ]
  },
  {
   "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:51:06 </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:51:06\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": "f9bed2fc70904e62b9c0c6a1040c449c",
       "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:35:12 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3470</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:35:12\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3470\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\">75784800</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;36m75784800\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.95</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.95\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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YzzjlblLUjqtBjERTT7lRERE1ARNztz07t0be/fuxciRI3H55ZejuroaV111FTZv3oxOnToF4hjPeCXu4CY+0gCtllPBiYiIAumU0ghxcXF47LHHmvtYWi2534bNxERERAF3SsFNXV0dtm7dioKCAjidTtV1l112WbMcWGsiz5QyG0J8JERERK1fk4ObxYsX4+abb0ZRUZHPdRqNBg6Ho1kOrDXxBDfM3BAREQVak3tu/vrXv+Laa69Fbm4unE6n6h8DG/9KqxncEBERBUuTg5v8/HzMmDEDqampgTieVqmEPTdERERB0+Tg5pprrsGKFSsCcCitV5m89QJ7boiIiAKtyT03r7/+Oq699lr89ttv6NOnDwwG9YB97733NtvBtRbyVHCWpYiIiAKuycHNxx9/jJ9++gkRERFYsWIFNBrPui0ajYbBjR+lNa6yFFcnJiIiCrwmBzePPfYYnnrqKTz66KPQaptc1QpLckMxy1JEREQB1+ToxGq1YuLEiQxsmoCzpYiIiIKnyRHK5MmTsWjRokAcS6tkczhR6d40k8ENERFR4DW5LOVwOPDiiy9iyZIl6Nu3r09D8SuvvNJsB9caiAX8tBogNpJlKSIiokBrcnCzbds2DBgwAACwfft21XXK5mJyKXM3E8dFGqDjpplEREQB1+TgZvny5YE4jlarss5VkoqJYNaGiIgoGNgVHGC1VteWFGajLsRHQkREFB4Y3ARYjdWVuYlkcENERBQUDG4CrMaduYkyNrkCSERERKeAwU2AieCGmRsiIqLgYHATYKIsxZ4bIiKi4GBwE2A1bCgmIiIKKgY3AeYJbthzQ0REFAwtIrh54403kJWVhYiICAwdOhR//PFHo+73ySefQKPR4IorrgjsAZ6GWpaliIiIgirkwc2iRYswY8YMzJ49G5s2bUK/fv0wYcIEFBQUNHi/w4cP48EHH8SoUaOCdKSnppoNxUREREEV8uDmlVdewe23344pU6agZ8+emDdvHsxmM95///167+NwOHDjjTfiqaeeQseOHYN4tE1Xy6ngREREQRXS4MZqtWLjxo0YN26cfJlWq8W4ceOwdu3aeu/3j3/8AykpKbjttttO+hwWiwUVFRWqf8HERfyIiIiCK6TBTVFRERwOB1JTU1WXp6amIi8vz+99Vq1ahffeew/z589v1HPMmTMHcXFx8r/MzMzTPu6mqOZsKSIioqAKeVmqKSorK3HTTTdh/vz5SEpKatR9Zs6cifLycvnf0aNHA3yUaixLERERBVdIR9ykpCTodDrk5+erLs/Pz0daWprP7Q8cOIDDhw/j0ksvlS9zOp0AAL1ejz179qBTp06q+5hMJphMpgAcfeOwLEVERBRcIc3cGI1GDBo0CMuWLZMvczqdWLZsGYYNG+Zz++7du2Pbtm3YsmWL/O+yyy7Deeedhy1btgS95NQYXMSPiIgouEJeK5kxYwYmT56MwYMHY8iQIZg7dy6qq6sxZcoUAMDNN9+MjIwMzJkzBxEREejdu7fq/vHx8QDgc3lLwUX8iIiIgivkI+7EiRNRWFiIWbNmIS8vD/3798fixYvlJuOcnBxotWdUa5BKLTM3REREQaWRJEkK9UEEU0VFBeLi4lBeXo7Y2NiAPpfN4USXx34EAGyZdT7izcaAPh8REVFr1ZTx+8xNiZwBREkKYFmKiIgoWBjcBJAoSem1Ghj1PNVERETBwBE3gKo5DZyIiCjoGNwEEBfwIyIiCj4GNwHENW6IiIiCj8FNALEsRUREFHwMbgKIZSkiIqLgY3ATQKIsxcwNERFR8DC4CSCxaSZ7boiIiIKHwU0AcV8pIiKi4GNwE0CcLUVERBR8DG4CqMbCshQREVGwMbgJoBoby1JERETBxuAmgGpZliIiIgo6BjcBVG3hIn5ERETBxuAmgKwOJwDAxB3BiYiIgoajbgDZ3MGNkcENERFR0HDUDSCbQwIA6LU8zURERMHCUTeA7O7MjV6nCfGREBERhQ8GNwEkMjdGHU8zERFRsHDUDSAbMzdERERBx+AmgOxO9twQEREFG0fdAPLMlmLmhoiIKFgY3ASQnbOliIiIgo6jbgCx54aIiCj4GNwEkFyW4mwpIiKioOGoG0ByWYrBDRERUdBw1A0gm9NdltKyLEVERBQsDG4CSF7Ej3tLERERBQ1H3QCRJAkOeZ0bZm6IiIiChcFNgIisDcCeGyIiomDiqBsgYqYUwNlSREREwcRRN0DsqswNy1JERETBwuAmQMRMKYA9N0RERMHE4CZARFnKoNNAo2FwQ0REFCwMbgKE+0oRERGFBkfeAOG+UkRERKHB4CZA5AX8OFOKiIgoqDjyBggzN0RERKHB4CZA7E723BAREYUCR94AEZkb7itFREQUXBx5A0QuS3GNGyIioqBicBMg8lRwNhQTEREFFUfeAJHLUmwoJiIiCioGNwFiY+aGiIgoJDjyBojdyZ4bIiKiUGBwEyCcLUVERBQaHHkDRC5LMXNDREQUVAxuAoSzpYiIiEKDI2+AeGZL8RQTEREFE0feAOHeUkRERKHB4CZAuLcUERFRaHDkDRCbXcyWYuaGiIgomBjcBIiNmRsiIqKQ4MgbIHb23BAREYUEg5sA4WwpIiKi0ODIGyCevaWYuSEiIgomBjcBIk8FZ88NERFRUHHkDRCxQjH3liIiIgoujrwBYuOu4ERERCHB4CZAbNxbioiIKCQ48gaIXZ4txcwNERFRMDG4CRBmboiIiEKDI2+AeGZLMXNDREQUTAxuAsTuFHtL8RQTEREFE0feAJHLUlznhoiIKKhaxMj7xhtvICsrCxERERg6dCj++OOPem87f/58jBo1CgkJCUhISMC4ceMavH2o2Li3FBERUUiEPLhZtGgRZsyYgdmzZ2PTpk3o168fJkyYgIKCAr+3X7FiBSZNmoTly5dj7dq1yMzMxPjx43H8+PEgH3nD5EX82FBMREQUVCEfeV955RXcfvvtmDJlCnr27Il58+bBbDbj/fff93v7//73v5g2bRr69++P7t27491334XT6cSyZcuCfOQNY+aGiIgoNEIa3FitVmzcuBHjxo2TL9NqtRg3bhzWrl3bqMeoqamBzWZDYmJioA7zlHBvKSIiotDQh/LJi4qK4HA4kJqaqro8NTUVu3fvbtRjPPLII0hPT1cFSEoWiwUWi0X+uaKi4tQPuAnsTrG3FDM3REREwXRGpxWef/55fPLJJ/jyyy8RERHh9zZz5sxBXFyc/C8zMzMox2bnbCkiIqKQCOnIm5SUBJ1Oh/z8fNXl+fn5SEtLa/C+//znP/H888/jp59+Qt++feu93cyZM1FeXi7/O3r0aLMc+8lY2XNDREQUEiENboxGIwYNGqRqBhbNwcOGDav3fi+++CKefvppLF68GIMHD27wOUwmE2JjY1X/gsGztxQzN0RERMEU0p4bAJgxYwYmT56MwYMHY8iQIZg7dy6qq6sxZcoUAMDNN9+MjIwMzJkzBwDwwgsvYNasWfjoo4+QlZWFvLw8AEB0dDSio6ND9jq82bm3FBERUUiEPLiZOHEiCgsLMWvWLOTl5aF///5YvHix3GSck5MDraJv5a233oLVasU111yjepzZs2fjySefDOahN8jKvaWIiIhCQiNJkhTqgwimiooKxMXFoby8PKAlqk5//wEOp4Tf/z4WqbH+m52JiIiocZoyfrNmEgBOpwSHU8yWYuaGiIgomBjcBIDNvSM4wJ4bIiKiYOPIGwCimRjgbCkiIqJg48gbAMrghuvcEBERBReDmwAQM6UA9twQEREFG4ObALC7e24MOg00GgY3REREwcTgJgC4rxQREVHocPQNAO4rRUREFDoMbgJAZG44U4qIiCj4OPoGgI2ZGyIiopBhcBMANVYHACDSoAvxkRAREYUfBjcBUFJtAQAkRhlDfCREREThJ+S7grdGRVVWAECbaFOIj4SIKPxIkgS73Q6HwxHqQ6EmMhgM0OlOv+rB4CYAit3BTVI0MzdERMFktVqRm5uLmpqaUB8KnQKNRoN27dohOjr6tB6HwU0AiLJUmyhmboiIgsXpdOLQoUPQ6XRIT0+H0WjkQqpnEEmSUFhYiGPHjqFLly6nlcFhcBMARdWuzA17boiIgsdqtcLpdCIzMxNmsznUh0OnIDk5GYcPH4bNZjut4IYNxQFQXOXO3LAsRUQUdFquDn/Gaq5MG98BAeDpuWFZioiIKNgY3ARASbWYLcXMDRERUbAxuGlmDqeEkhr23BAREYUKg5tmVlpjheTaWgqJZgY3RER0ZrLZbKE+hFPG4KaZiX6bBLMBem6cSUREjbR48WKMHDkS8fHxaNOmDS655BIcOHBAvv7YsWOYNGkSEhMTERUVhcGDB+P333+Xr//2229x1llnISIiAklJSbjyyivl6zQaDb766ivV88XHx2PhwoUAgMOHD0Oj0WDRokUYPXo0IiIi8N///hfFxcWYNGkSMjIyYDab0adPH3z88ceqx3E6nXjxxRfRuXNnmEwmtG/fHs8++ywAYMyYMZg+fbrq9oWFhTAajVi2bFlznDa/OBW8mXlmSrGZmIgo1CRJQq0tNCsVRxp0TZr9U11djRkzZqBv376oqqrCrFmzcOWVV2LLli2oqanB6NGjkZGRgW+++QZpaWnYtGkTnE7XRs3ff/89rrzySjz22GP48MMPYbVa8cMPPzT5mB999FG8/PLLGDBgACIiIlBXV4dBgwbhkUceQWxsLL7//nvcdNNN6NSpE4YMGQIAmDlzJubPn49XX30VI0eORG5uLnbv3g0AmDp1KqZPn46XX34ZJpNrXPzPf/6DjIwMjBkzpsnH11gMbppZMde4ISJqMWptDvSctSQkz73zHxNgNjZ+mL366qtVP7///vtITk7Gzp07sWbNGhQWFmL9+vVITEwEAHTu3Fm+7bPPPovrr78eTz31lHxZv379mnzM999/P6666irVZQ8++KD8/3/961+xZMkSfPrppxgyZAgqKyvx2muv4fXXX8fkyZMBAJ06dcLIkSMBAFdddRWmT5+Or7/+Gtdddx0AYOHChbjlllsCusAi6ybNpKLOhie/2YEXFruiVW69QERETbFv3z5MmjQJHTt2RGxsLLKysgAAOTk52LJlCwYMGCAHNt62bNmCsWPHnvYxDB48WPWzw+HA008/jT59+iAxMRHR0dFYsmQJcnJyAAC7du2CxWKp97kjIiJw00034f333wcAbNq0Cdu3b8ctt9xy2sfaEGZumsnPO/OxcM1h+WduvUBEFHqRBh12/mNCyJ67KS699FJ06NAB8+fPR3p6OpxOJ3r37g2r1YrIyMiGn+sk12s0Gkhitoubv4bhqKgo1c8vvfQSXnvtNcydOxd9+vRBVFQU7r//flit1kY9L+AqTfXv3x/Hjh3DggULMGbMGHTo0OGk9zsdzNw0kyv6Z+CsrAT5Z65xQ0QUehqNBmajPiT/mlJ2KS4uxp49e/D4449j7Nix6NGjB0pLS+Xr+/btiy1btqCkpMTv/fv27dtgg25ycjJyc3Pln/ft29eozUVXr16Nyy+/HH/5y1/Qr18/dOzYEXv37pWv79KlCyIjIxt87j59+mDw4MGYP38+PvroI9x6660nfd7TxeCmmWi1GjxzRR/556ZG7EREFL4SEhLQpk0bvPPOO9i/fz9++eUXzJgxQ75+0qRJSEtLwxVXXIHVq1fj4MGD+N///oe1a9cCAGbPno2PP/4Ys2fPxq5du7Bt2za88MIL8v3HjBmD119/HZs3b8aGDRtw1113wWAwnPS4unTpgqVLl2LNmjXYtWsX7rzzTuTn58vXR0RE4JFHHsHDDz+MDz/8EAcOHMC6devw3nvvqR5n6tSpeP755yFJkmoWV6AwuGlG3dJiMOuSnshOisJFfdqG+nCIiOgModVq8cknn2Djxo3o3bs3HnjgAbz00kvy9UajET/99BNSUlJw0UUXoU+fPnj++eflzSXPPfdcfPbZZ/jmm2/Qv39/jBkzBn/88Yd8/5dffhmZmZkYNWoUbrjhBjz44ION2lz08ccfx8CBAzFhwgSce+65coCl9MQTT+Bvf/sbZs2ahR49emDixIkoKChQ3WbSpEnQ6/WYNGkSIiIiTuNMNY5G8i7CtXIVFRWIi4tDeXk5YmNjQ304RETUTOrq6nDo0CFkZ2cHZQClxjt8+DA6deqE9evXY+DAgfXerqHfYVPGbzYUExERUUDYbDYUFxfj8ccfx9lnn91gYNOcWJYiIiKigFi9ejXatm2L9evXY968eUF7XmZuiIiIKCDOPfdcnynowcDMDREREbUqDG6IiIioVWFwQ0RErUqYTQJuVZrrd8fghoiIWgWxKF1jVt6llkls6yDW7zlVbCgmIqJWQafTIT4+Xl5Azmw2B3TnaWpeTqcThYWFMJvN0OtPLzxhcENERK1GWloaAPiskEtnBq1Wi/bt2592UMrghoiIWg2NRoO2bdsiJSXF767X1LIZjUZotaffMcPghoiIWh2dTnfafRt05mJDMREREbUqDG6IiIioVWFwQ0RERK1K2PXciAWCKioqQnwkRERE1Fhi3G7MQn9hF9xUVlYCADIzM0N8JERERNRUlZWViIuLa/A2GinM1ql2Op04ceIEYmJimm1xp4qKCmRmZuLo0aOIjY1tlsdszXi+Go/nqml4vhqP56rxeK6aJlDnS5IkVFZWIj09/aTTxcMuc6PVatGuXbuAPHZsbCzf+E3A89V4PFdNw/PVeDxXjcdz1TSBOF8ny9gIbCgmIiKiVoXBDREREbUqDG6agclkwuzZs2EymUJ9KGcEnq/G47lqGp6vxuO5ajyeq6ZpCecr7BqKiYiIqHVj5oaIiIhaFQY3RERE1KowuCEiIqJWhcENERERtSoMbprBG2+8gaysLERERGDo0KH4448/Qn1IIffkk09Co9Go/nXv3l2+vq6uDvfccw/atGmD6OhoXH311cjPzw/hEQfPr7/+iksvvRTp6enQaDT46quvVNdLkoRZs2ahbdu2iIyMxLhx47Bv3z7VbUpKSnDjjTciNjYW8fHxuO2221BVVRXEVxE8Jztft9xyi8977YILLlDdJlzO15w5c3DWWWchJiYGKSkpuOKKK7Bnzx7VbRrz2cvJycHFF18Ms9mMlJQUPPTQQ7Db7cF8KQHXmHN17rnn+ry37rrrLtVtwuFcAcBbb72Fvn37ygvzDRs2DD/++KN8fUt7XzG4OU2LFi3CjBkzMHv2bGzatAn9+vXDhAkTUFBQEOpDC7levXohNzdX/rdq1Sr5ugceeADffvstPvvsM6xcuRInTpzAVVddFcKjDZ7q6mr069cPb7zxht/rX3zxRfzrX//CvHnz8PvvvyMqKgoTJkxAXV2dfJsbb7wRO3bswNKlS/Hdd9/h119/xR133BGslxBUJztfAHDBBReo3msff/yx6vpwOV8rV67EPffcg3Xr1mHp0qWw2WwYP348qqur5duc7LPncDhw8cUXw2q1Ys2aNfjggw+wcOFCzJo1KxQvKWAac64A4Pbbb1e9t1588UX5unA5VwDQrl07PP/889i4cSM2bNiAMWPG4PLLL8eOHTsAtMD3lUSnZciQIdI999wj/+xwOKT09HRpzpw5ITyq0Js9e7bUr18/v9eVlZVJBoNB+uyzz+TLdu3aJQGQ1q5dG6QjbBkASF9++aX8s9PplNLS0qSXXnpJvqysrEwymUzSxx9/LEmSJO3cuVMCIK1fv16+zY8//ihpNBrp+PHjQTv2UPA+X5IkSZMnT5Yuv/zyeu8TzueroKBAAiCtXLlSkqTGffZ++OEHSavVSnl5efJt3nrrLSk2NlayWCzBfQFB5H2uJEmSRo8eLd1333313idcz5WQkJAgvfvuuy3yfcXMzWmwWq3YuHEjxo0bJ1+m1Woxbtw4rF27NoRH1jLs27cP6enp6NixI2688Ubk5OQAADZu3AibzaY6b927d0f79u3D/rwdOnQIeXl5qnMTFxeHoUOHyudm7dq1iI+Px+DBg+XbjBs3DlqtFr///nvQj7klWLFiBVJSUtCtWzfcfffdKC4ulq8L5/NVXl4OAEhMTATQuM/e2rVr0adPH6Smpsq3mTBhAioqKuRv6a2R97kS/vvf/yIpKQm9e/fGzJkzUVNTI18XrufK4XDgk08+QXV1NYYNG9Yi31dht3FmcyoqKoLD4VD9sgAgNTUVu3fvDtFRtQxDhw7FwoUL0a1bN+Tm5uKpp57CqFGjsH37duTl5cFoNCI+Pl51n9TUVOTl5YXmgFsI8fr9vafEdXl5eUhJSVFdr9frkZiYGJbn74ILLsBVV12F7OxsHDhwAH//+99x4YUXYu3atdDpdGF7vpxOJ+6//36MGDECvXv3BoBGffby8vL8vv/Eda2Rv3MFADfccAM6dOiA9PR0bN26FY888gj27NmDL774AkD4natt27Zh2LBhqKurQ3R0NL788kv07NkTW7ZsaXHvKwY3FBAXXnih/P99+/bF0KFD0aFDB3z66aeIjIwM4ZFRa3P99dfL/9+nTx/07dsXnTp1wooVKzB27NgQHllo3XPPPdi+fbuq1438q+9cKfuy+vTpg7Zt22Ls2LE4cOAAOnXqFOzDDLlu3bphy5YtKC8vx+eff47Jkydj5cqVoT4sv1iWOg1JSUnQ6XQ+HeH5+flIS0sL0VG1TPHx8ejatSv279+PtLQ0WK1WlJWVqW7D8wb59Tf0nkpLS/NpWLfb7SgpKQn78wcAHTt2RFJSEvbv3w8gPM/X9OnT8d1332H58uVo166dfHljPntpaWl+33/iutamvnPlz9ChQwFA9d4Kp3NlNBrRuXNnDBo0CHPmzEG/fv3w2muvtcj3FYOb02A0GjFo0CAsW7ZMvszpdGLZsmUYNmxYCI+s5amqqsKBAwfQtm1bDBo0CAaDQXXe9uzZg5ycnLA/b9nZ2UhLS1Odm4qKCvz+++/yuRk2bBjKysqwceNG+Ta//PILnE6n/Mc3nB07dgzFxcVo27YtgPA6X5IkYfr06fjyyy/xyy+/IDs7W3V9Yz57w4YNw7Zt21QB4dKlSxEbG4uePXsG54UEwcnOlT9btmwBANV7KxzOVX2cTicsFkvLfF81e4tymPnkk08kk8kkLVy4UNq5c6d0xx13SPHx8aqO8HD0t7/9TVqxYoV06NAhafXq1dK4ceOkpKQkqaCgQJIkSbrrrruk9u3bS7/88ou0YcMGadiwYdKwYcNCfNTBUVlZKW3evFnavHmzBEB65ZVXpM2bN0tHjhyRJEmSnn/+eSk+Pl76+uuvpa1bt0qXX365lJ2dLdXW1sqPccEFF0gDBgyQfv/9d2nVqlVSly5dpEmTJoXqJQVUQ+ersrJSevDBB6W1a9dKhw4dkn7++Wdp4MCBUpcuXaS6ujr5McLlfN19991SXFyctGLFCik3N1f+V1NTI9/mZJ89u90u9e7dWxo/fry0ZcsWafHixVJycrI0c+bMULykgDnZudq/f7/0j3/8Q9qwYYN06NAh6euvv5Y6duwonXPOOfJjhMu5kiRJevTRR6WVK1dKhw4dkrZu3So9+uijkkajkX766SdJklre+4rBTTP497//LbVv314yGo3SkCFDpHXr1oX6kEJu4sSJUtu2bSWj0ShlZGRIEydOlPbv3y9fX1tbK02bNk1KSEiQzGazdOWVV0q5ubkhPOLgWb58uQTA59/kyZMlSXJNB3/iiSek1NRUyWQySWPHjpX27Nmjeozi4mJp0qRJUnR0tBQbGytNmTJFqqysDMGrCbyGzldNTY00fvx4KTk5WTIYDFKHDh2k22+/3efLRbicL3/nCYC0YMEC+TaN+ewdPnxYuvDCC6XIyEgpKSlJ+tvf/ibZbLYgv5rAOtm5ysnJkc455xwpMTFRMplMUufOnaWHHnpIKi8vVz1OOJwrSZKkW2+9VerQoYNkNBql5ORkaezYsXJgI0kt732lkSRJav58EBEREVFosOeGiIiIWhUGN0RERNSqMLghIiKiVoXBDREREbUqDG6IiIioVWFwQ0RERK0KgxsiIiJqVRjcEFFYWLFiBTQajc/+N0TU+jC4ISIiolaFwQ0RERG1KgxuiKhFcTqdePHFF9G5c2eYTCa0b98ezz77LMaMGYPp06erbltYWAij0SjvRmyxWPDII48gMzMTJpMJnTt3xnvvvVfvc61atQqjRo1CZGQkMjMzce+996K6ujqgr4+IAo/BDRG1KDNnzsTzzz+PJ554Ajt37sRHH32E1NRUTJ06FR999BEsFot82//85z/IyMjAmDFjAAA333wzPv74Y/zrX//Crl278PbbbyM6Otrv8xw4cAAXXHABrr76amzduhWLFi3CqlWrfAIoIjrzcONMImoxKisrkZycjNdffx1Tp05VXVdXV4f09HTMmzcP1113HQCgX79+uOqqqzB79mzs3bsX3bp1w9KlSzFu3Difx16xYgXOO+88lJaWIj4+HlOnToVOp8Pbb78t32bVqlUYPXo0qqurEREREdgXS0QBw8wNEbUYu3btgsViwdixY32ui4iIwE033YT3338fALBp0yZs374dt9xyCwBgy5Yt0Ol0GD16dKOe688//8TChQsRHR0t/5swYQKcTicOHTrUbK+JiIJPH+oDICISIiMjG7x+6tSp6N+/P44dO4YFCxZgzJgx6NChQ6Pu662qqgp33nkn7r33Xp/r2rdv36THIqKWhZkbImoxunTpgsjISLlB2FufPn0wePBgzJ8/Hx999BFuvfVW1XVOpxMrV65s1HMNHDgQO3fuROfOnX3+GY3GZnk9RBQaDG6IqMWIiIjAI488gocffhgffvghDhw4gHXr1qlmPE2dOhXPP/88JEnClVdeKV+elZWFyZMn49Zbb8VXX32FQ4cOYcWKFfj000/9PtcjjzyCNWvWYPr06diyZQv27duHr7/+mg3FRK0AgxsialGeeOIJ/O1vf8OsWbPQo0cPTJw4EQUFBfL1kyZNgl6vx6RJk3yaft966y1cc801mDZtGrp3747bb7+93qndffv2xcqVK7F3716MGjUKAwYMwKxZs5Cenh7Q10dEgcfZUkR0Rjl8+DA6deqE9evXY+DAgaE+HCJqgRjcENEZwWazobi4GA8++CAOHTqE1atXh/qQiKiFYlmKiM4Iq1evRtu2bbF+/XrMmzcv1IdDRC0YMzdERETUqjBzQ0RERK0KgxsiIiJqVRjcEBERUavC4IaIiIhaFQY3RERE1KowuCEiIqJWhcENERERtSoMboiIiKhVYXBDRERErcr/A1ev244KzabVAAAAAElFTkSuQmCC",
      "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.11775}, {'accuracy': 0.11141000000000001}, {'accuracy': 0.15704}, {'accuracy': 0.34318000000000004}, {'accuracy': 0.43102}, {'accuracy': 0.48177999999999993}, {'accuracy': 0.64957}, {'accuracy': 0.6690100000000001}, {'accuracy': 0.71598}, {'accuracy': 0.81063}, {'accuracy': 0.84177}, {'accuracy': 0.66951}, {'accuracy': 0.83991}, {'accuracy': 0.81124}, {'accuracy': 0.82273}, {'accuracy': 0.8166100000000001}, {'accuracy': 0.8375299999999999}, {'accuracy': 0.8703900000000001}, {'accuracy': 0.8406}, {'accuracy': 0.8907299999999999}, {'accuracy': 0.8886900000000001}, {'accuracy': 0.84672}, {'accuracy': 0.8159099999999999}, {'accuracy': 0.8576900000000001}, {'accuracy': 0.8564}, {'accuracy': 0.82325}, {'accuracy': 0.87463}, {'accuracy': 0.87095}, {'accuracy': 0.83816}, {'accuracy': 0.89056}, {'accuracy': 0.8693899999999999}, {'accuracy': 0.8439100000000002}, {'accuracy': 0.7864899999999999}, {'accuracy': 0.88702}, {'accuracy': 0.78522}, {'accuracy': 0.9259700000000001}, {'accuracy': 0.88683}, {'accuracy': 0.8346600000000001}, {'accuracy': 0.8998800000000001}, {'accuracy': 0.8523}, {'accuracy': 0.8954899999999999}, {'accuracy': 0.8953099999999999}, {'accuracy': 0.8771100000000001}, {'accuracy': 0.87263}, {'accuracy': 0.8692399999999999}, {'accuracy': 0.9200899999999999}, {'accuracy': 0.88978}, {'accuracy': 0.88379}, {'accuracy': 0.94098}, {'accuracy': 0.85631}, {'accuracy': 0.89817}, {'accuracy': 0.8879000000000001}, {'accuracy': 0.69358}, {'accuracy': 0.8684600000000001}, {'accuracy': 0.9152000000000001}, {'accuracy': 0.8953700000000001}, {'accuracy': 0.79165}, {'accuracy': 0.84321}, {'accuracy': 0.8992100000000001}, {'accuracy': 0.8252900000000001}, {'accuracy': 0.8354199999999998}, {'accuracy': 0.86115}, {'accuracy': 0.90382}, {'accuracy': 0.9047499999999999}, {'accuracy': 0.8972300000000001}, {'accuracy': 0.87568}, {'accuracy': 0.88734}, {'accuracy': 0.83208}, {'accuracy': 0.88605}, {'accuracy': 0.8919600000000001}, {'accuracy': 0.85394}, {'accuracy': 0.79078}, {'accuracy': 0.8492099999999999}, {'accuracy': 0.89944}, {'accuracy': 0.8646499999999999}, {'accuracy': 0.88452}, {'accuracy': 0.9078900000000001}, {'accuracy': 0.89171}, {'accuracy': 0.8951499999999999}, {'accuracy': 0.8252}, {'accuracy': 0.8493299999999999}, {'accuracy': 0.88293}, {'accuracy': 0.85863}, {'accuracy': 0.89505}, {'accuracy': 0.8072100000000001}, {'accuracy': 0.82943}, {'accuracy': 0.8981299999999999}, {'accuracy': 0.92807}, {'accuracy': 0.81081}, {'accuracy': 0.8753400000000001}, {'accuracy': 0.77728}, {'accuracy': 0.9520899999999999}, {'accuracy': 0.9011699999999999}, {'accuracy': 0.8058799999999999}, {'accuracy': 0.8835999999999998}, {'accuracy': 0.8602700000000001}, {'accuracy': 0.9381499999999999}, {'accuracy': 0.9316099999999998}, {'accuracy': 0.90622}, {'accuracy': 0.92599}, {'accuracy': 0.92796}, {'accuracy': 0.8732200000000001}, {'accuracy': 0.86233}, {'accuracy': 0.91138}, {'accuracy': 0.81267}, {'accuracy': 0.9380900000000001}, {'accuracy': 0.90798}, {'accuracy': 0.86578}, {'accuracy': 0.9180699999999998}, {'accuracy': 0.79609}, {'accuracy': 0.8675200000000001}, {'accuracy': 0.81778}, {'accuracy': 0.9032100000000002}, {'accuracy': 0.8910399999999999}, {'accuracy': 0.84888}, {'accuracy': 0.91661}, {'accuracy': 0.80429}, {'accuracy': 0.7270099999999999}, {'accuracy': 0.87996}, {'accuracy': 0.9313}, {'accuracy': 0.9148699999999999}, {'accuracy': 0.81005}, {'accuracy': 0.8575799999999999}, {'accuracy': 0.7939}, {'accuracy': 0.82982}, {'accuracy': 0.90114}, {'accuracy': 0.8498300000000001}, {'accuracy': 0.84142}, {'accuracy': 0.897}, {'accuracy': 0.8482799999999999}, {'accuracy': 0.83843}, {'accuracy': 0.8966799999999999}, {'accuracy': 0.8636600000000001}, {'accuracy': 0.85074}, {'accuracy': 0.8718299999999999}, {'accuracy': 0.7895}, {'accuracy': 0.87454}, {'accuracy': 0.66775}, {'accuracy': 0.75154}, {'accuracy': 0.8985499999999998}, {'accuracy': 0.82046}, {'accuracy': 0.83704}, {'accuracy': 0.77374}, {'accuracy': 0.7561}, {'accuracy': 0.79009}, {'accuracy': 0.78813}, {'accuracy': 0.67134}, {'accuracy': 0.58187}, {'accuracy': 0.71303}, {'accuracy': 0.8592599999999999}, {'accuracy': 0.5722}, {'accuracy': 0.7818599999999999}, {'accuracy': 0.81409}, {'accuracy': 0.96616}, {'accuracy': 0.9691400000000001}, {'accuracy': 0.9566800000000001}, {'accuracy': 0.9362299999999999}, {'accuracy': 0.9038299999999999}, {'accuracy': 0.9446000000000001}, {'accuracy': 0.94375}, {'accuracy': 0.9574400000000001}, {'accuracy': 0.9744999999999999}, {'accuracy': 0.95199}, {'accuracy': 0.96722}, {'accuracy': 0.9746}, {'accuracy': 0.96081}, {'accuracy': 0.96745}, {'accuracy': 0.9678899999999999}, {'accuracy': 0.9746899999999998}, {'accuracy': 0.9697499999999998}, {'accuracy': 0.9661099999999999}, {'accuracy': 0.97492}, {'accuracy': 0.9656999999999998}, {'accuracy': 0.9747199999999999}, {'accuracy': 0.9691500000000002}, {'accuracy': 0.9667399999999999}, {'accuracy': 0.96563}, {'accuracy': 0.9678699999999999}, {'accuracy': 0.95945}, {'accuracy': 0.9751600000000001}, {'accuracy': 0.9616000000000001}, {'accuracy': 0.9601}, {'accuracy': 0.9594999999999999}, {'accuracy': 0.9613900000000001}, {'accuracy': 0.97471}, {'accuracy': 0.94913}, {'accuracy': 0.94329}, {'accuracy': 0.96243}, {'accuracy': 0.97427}, {'accuracy': 0.9661199999999999}, {'accuracy': 0.96897}, {'accuracy': 0.9667399999999999}, {'accuracy': 0.95824}, {'accuracy': 0.9754999999999999}, {'accuracy': 0.97514}, {'accuracy': 0.9556899999999999}, {'accuracy': 0.96655}, {'accuracy': 0.97488}, {'accuracy': 0.96829}, {'accuracy': 0.9643900000000001}, {'accuracy': 0.95809}, {'accuracy': 0.96973}, {'accuracy': 0.97102}, {'accuracy': 0.95878}, {'accuracy': 0.9750300000000001}, {'accuracy': 0.97517}, {'accuracy': 0.9755800000000001}, {'accuracy': 0.9585100000000001}, {'accuracy': 0.9684899999999999}, {'accuracy': 0.9753299999999999}, {'accuracy': 0.94392}, {'accuracy': 0.96844}, {'accuracy': 0.97529}, {'accuracy': 0.9693999999999999}, {'accuracy': 0.9674499999999998}, {'accuracy': 0.96775}, {'accuracy': 0.9435600000000001}, {'accuracy': 0.9581199999999999}, {'accuracy': 0.96614}, {'accuracy': 0.9689}, {'accuracy': 0.9760100000000002}, {'accuracy': 0.9747200000000001}, {'accuracy': 0.96867}, {'accuracy': 0.9758600000000002}, {'accuracy': 0.9509400000000001}, {'accuracy': 0.95669}, {'accuracy': 0.9756500000000001}, {'accuracy': 0.9639500000000002}, {'accuracy': 0.96262}, {'accuracy': 0.93832}, {'accuracy': 0.97546}, {'accuracy': 0.97461}, {'accuracy': 0.9462300000000001}, {'accuracy': 0.93915}, {'accuracy': 0.9581200000000001}, {'accuracy': 0.9424800000000001}, {'accuracy': 0.9628200000000001}, {'accuracy': 0.9504100000000001}, {'accuracy': 0.9751100000000001}, {'accuracy': 0.96867}, {'accuracy': 0.97455}, {'accuracy': 0.96621}, {'accuracy': 0.97517}, {'accuracy': 0.96706}, {'accuracy': 0.9754200000000001}, {'accuracy': 0.97503}, {'accuracy': 0.9523699999999999}, {'accuracy': 0.95777}, {'accuracy': 0.97532}, {'accuracy': 0.97568}, {'accuracy': 0.9542200000000001}, {'accuracy': 0.9635800000000001}, {'accuracy': 0.95932}, {'accuracy': 0.9753499999999999}, {'accuracy': 0.97646}, {'accuracy': 0.9608500000000001}, {'accuracy': 0.97586}, {'accuracy': 0.97552}, {'accuracy': 0.95985}, {'accuracy': 0.96874}, {'accuracy': 0.97606}, {'accuracy': 0.96058}, {'accuracy': 0.97532}, {'accuracy': 0.9586499999999999}, {'accuracy': 0.9685}, {'accuracy': 0.97503}, {'accuracy': 0.9761299999999998}, {'accuracy': 0.9242799999999999}, {'accuracy': 0.95899}, {'accuracy': 0.9754399999999999}, {'accuracy': 0.9653500000000002}, {'accuracy': 0.9754099999999999}, {'accuracy': 0.97495}, {'accuracy': 0.9620900000000001}, {'accuracy': 0.9686299999999999}, {'accuracy': 0.9665500000000001}, {'accuracy': 0.9681999999999998}, {'accuracy': 0.97563}, {'accuracy': 0.9751399999999999}, {'accuracy': 0.96068}, {'accuracy': 0.9696999999999999}, {'accuracy': 0.9490999999999999}, {'accuracy': 0.9614}, {'accuracy': 0.9757200000000001}, {'accuracy': 0.97577}, {'accuracy': 0.9759699999999999}, {'accuracy': 0.9616900000000002}, {'accuracy': 0.9405699999999999}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96487}, {'accuracy': 0.9559200000000001}, {'accuracy': 0.94459}, {'accuracy': 0.97543}, {'accuracy': 0.9584800000000001}, {'accuracy': 0.9544300000000001}, {'accuracy': 0.9747900000000002}, {'accuracy': 0.93087}, {'accuracy': 0.9764899999999999}, {'accuracy': 0.9478300000000001}, {'accuracy': 0.95475}]\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": "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": "8e3229ca-8cf4-41ba-ac76-36bd891d950f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efcb4892-6ecd-4dfb-84b3-493ddb710e49",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0060f25c-dba5-4864-9800-8ac3ee2b5629",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7f2f684-8f69-44fe-8c1c-4243a88ddb52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "148ff41a-5ed7-4fb5-bb6e-a8e4d4318e6b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05c27837-9ccb-4d5b-97d9-03771becb45a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d88b0d2-a477-4f8f-95ac-d6544c4900ad",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea6d537e-001e-467d-a78f-ef0924824272",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fad6c0f6-9581-4a11-b41e-63a41f5018f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c32270d-237e-4090-ad5c-f684cc1c6c64",
   "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
}
