{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6033\n",
      "[[  0 607]\n",
      " [  1 617]\n",
      " [  2 621]\n",
      " [  3 623]\n",
      " [  4 601]\n",
      " [  5 615]\n",
      " [  6 613]\n",
      " [  7 616]\n",
      " [  8 613]\n",
      " [  9 615]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "29967\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 287]\n",
      " [  1 318]\n",
      " [  2 275]\n",
      " [  3 299]\n",
      " [  4 284]\n",
      " [  5 321]\n",
      " [  6 318]\n",
      " [  7 293]\n",
      " [  8 299]\n",
      " [  9 310]]\n",
      "[[   0 1472]\n",
      " [   1  346]\n",
      " [   2  296]\n",
      " [   3  335]\n",
      " [   4  337]\n",
      " [   5  407]\n",
      " [   6  457]\n",
      " [   7  578]\n",
      " [   8  737]\n",
      " [   9 1046]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([3, 0, 1,  ..., 9, 3, 4])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "# noiseyset=[],[]\n",
    "# healthset=[],[],[]\n",
    "# import random\n",
    "# for z in range(0,60000,1):\n",
    "#     t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "#     if t<5:\n",
    "#         noiseyset[0].append(dataset1[z])\n",
    "#         healthset[0].append(dataset1[z])\n",
    "#         healthset[1].append(target1[z])\n",
    "#         healthset[2].append(z)\n",
    "#         noiseyset[1].append(torch.tensor(random.randint(0,9)))\n",
    "        \n",
    "        \n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<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",
    "        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, 1,  ..., 9, 3, 4])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "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-18:07:48 </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-18:07:48\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c38100ffe8f74d758a95b77394abe6c4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:18:41 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3379</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:18:41\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3379\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\">4984518334</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;36m4984518334\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": [
      "[{'accuracy': 0.18389000000000003}, {'accuracy': 0.23702}, {'accuracy': 0.26212}, {'accuracy': 0.35704}, {'accuracy': 0.26816}, {'accuracy': 0.3431}, {'accuracy': 0.35133000000000003}, {'accuracy': 0.30802000000000007}, {'accuracy': 0.40353000000000006}, {'accuracy': 0.42078000000000004}, {'accuracy': 0.49178}, {'accuracy': 0.42428}, {'accuracy': 0.41851000000000005}, {'accuracy': 0.5708499999999999}, {'accuracy': 0.5509000000000001}, {'accuracy': 0.33845000000000003}, {'accuracy': 0.5669500000000001}, {'accuracy': 0.55129}, {'accuracy': 0.5528}, {'accuracy': 0.41131}, {'accuracy': 0.60743}, {'accuracy': 0.4638}, {'accuracy': 0.55715}, {'accuracy': 0.47217000000000003}, {'accuracy': 0.47368000000000005}, {'accuracy': 0.6011599999999999}, {'accuracy': 0.50837}, {'accuracy': 0.60535}, {'accuracy': 0.6647900000000001}, {'accuracy': 0.5788899999999999}, {'accuracy': 0.48844999999999994}, {'accuracy': 0.6136199999999999}, {'accuracy': 0.43346999999999997}, {'accuracy': 0.57345}, {'accuracy': 0.56273}, {'accuracy': 0.5734}, {'accuracy': 0.5047699999999999}, {'accuracy': 0.57094}, {'accuracy': 0.6100300000000001}, {'accuracy': 0.44672}, {'accuracy': 0.60662}, {'accuracy': 0.5411900000000001}, {'accuracy': 0.47618}, {'accuracy': 0.5639299999999999}, {'accuracy': 0.50015}, {'accuracy': 0.6091900000000001}, {'accuracy': 0.5414300000000001}, {'accuracy': 0.50124}, {'accuracy': 0.5775500000000001}, {'accuracy': 0.6937200000000001}, {'accuracy': 0.47877000000000003}, {'accuracy': 0.51861}, {'accuracy': 0.53023}, {'accuracy': 0.61247}, {'accuracy': 0.55025}, {'accuracy': 0.56356}, {'accuracy': 0.47616}, {'accuracy': 0.44722}, {'accuracy': 0.35894}, {'accuracy': 0.6288400000000001}, {'accuracy': 0.33673000000000003}, {'accuracy': 0.5056499999999999}, {'accuracy': 0.5169199999999999}, {'accuracy': 0.4828499999999999}, {'accuracy': 0.52932}, {'accuracy': 0.54704}, {'accuracy': 0.44403999999999993}, {'accuracy': 0.55778}, {'accuracy': 0.58246}, {'accuracy': 0.46293000000000006}, {'accuracy': 0.5542199999999999}, {'accuracy': 0.43746}, {'accuracy': 0.5510200000000001}, {'accuracy': 0.5464}, {'accuracy': 0.47759}, {'accuracy': 0.5695899999999999}, {'accuracy': 0.60944}, {'accuracy': 0.50289}, {'accuracy': 0.6086699999999999}, {'accuracy': 0.58668}, {'accuracy': 0.56423}, {'accuracy': 0.35924}, {'accuracy': 0.51144}, {'accuracy': 0.46009}, {'accuracy': 0.47928}, {'accuracy': 0.45010000000000006}, {'accuracy': 0.46690999999999994}, {'accuracy': 0.56631}, {'accuracy': 0.61773}, {'accuracy': 0.43574999999999997}, {'accuracy': 0.46582999999999986}, {'accuracy': 0.6699700000000001}, {'accuracy': 0.59092}, {'accuracy': 0.4724799999999999}, {'accuracy': 0.47263}, {'accuracy': 0.54809}, {'accuracy': 0.5597099999999999}, {'accuracy': 0.44430000000000003}, {'accuracy': 0.36928}, {'accuracy': 0.40723000000000004}, {'accuracy': 0.61782}, {'accuracy': 0.39506}, {'accuracy': 0.5369900000000001}, {'accuracy': 0.35016}, {'accuracy': 0.48551}, {'accuracy': 0.46661}, {'accuracy': 0.62562}, {'accuracy': 0.49478}, {'accuracy': 0.5643299999999999}, {'accuracy': 0.67173}, {'accuracy': 0.47730999999999996}, {'accuracy': 0.48374999999999996}, {'accuracy': 0.5261600000000001}, {'accuracy': 0.48273}, {'accuracy': 0.38147999999999993}, {'accuracy': 0.4585}, {'accuracy': 0.5821400000000001}, {'accuracy': 0.5430200000000001}, {'accuracy': 0.4738300000000001}, {'accuracy': 0.47506999999999994}, {'accuracy': 0.59663}, {'accuracy': 0.43450000000000005}, {'accuracy': 0.50454}, {'accuracy': 0.5259199999999999}, {'accuracy': 0.49749}, {'accuracy': 0.6569799999999999}, {'accuracy': 0.49704999999999994}, {'accuracy': 0.6464299999999998}, {'accuracy': 0.50667}, {'accuracy': 0.38727}, {'accuracy': 0.7607}, {'accuracy': 0.42983000000000005}, {'accuracy': 0.5098900000000001}, {'accuracy': 0.508}, {'accuracy': 0.5871299999999999}, {'accuracy': 0.5251}, {'accuracy': 0.36757999999999996}, {'accuracy': 0.42593}, {'accuracy': 0.48263000000000006}, {'accuracy': 0.4407}, {'accuracy': 0.61004}, {'accuracy': 0.4525}, {'accuracy': 0.5088299999999999}, {'accuracy': 0.53521}, {'accuracy': 0.51854}, {'accuracy': 0.42477}, {'accuracy': 0.43211000000000005}, {'accuracy': 0.58208}, {'accuracy': 0.50521}, {'accuracy': 0.5811}, {'accuracy': 0.29701}, {'accuracy': 0.36502}, {'accuracy': 0.5984999999999999}, {'accuracy': 0.4300800000000001}, {'accuracy': 0.31734}, {'accuracy': 0.5212500000000001}, {'accuracy': 0.4451299999999999}, {'accuracy': 0.47778}, {'accuracy': 0.53883}, {'accuracy': 0.44596}, {'accuracy': 0.36706000000000005}, {'accuracy': 0.53639}, {'accuracy': 0.47228000000000003}, {'accuracy': 0.5103199999999999}, {'accuracy': 0.5010399999999999}, {'accuracy': 0.5420999999999999}, {'accuracy': 0.5200699999999999}, {'accuracy': 0.45267}, {'accuracy': 0.44647}, {'accuracy': 0.43004999999999993}, {'accuracy': 0.61273}, {'accuracy': 0.4831}, {'accuracy': 0.48819}, {'accuracy': 0.46055999999999997}, {'accuracy': 0.4484699999999999}, {'accuracy': 0.46475999999999995}, {'accuracy': 0.4372599999999999}, {'accuracy': 0.4149}, {'accuracy': 0.44867}, {'accuracy': 0.54538}, {'accuracy': 0.46159}, {'accuracy': 0.48355}, {'accuracy': 0.49472999999999995}, {'accuracy': 0.54476}, {'accuracy': 0.45146}, {'accuracy': 0.4464600000000001}, {'accuracy': 0.54139}, {'accuracy': 0.50549}, {'accuracy': 0.5260100000000001}, {'accuracy': 0.44082999999999994}, {'accuracy': 0.47056000000000003}, {'accuracy': 0.36980999999999997}, {'accuracy': 0.38908}, {'accuracy': 0.31916}, {'accuracy': 0.5342}, {'accuracy': 0.5924099999999999}, {'accuracy': 0.43778000000000006}, {'accuracy': 0.53447}, {'accuracy': 0.51227}, {'accuracy': 0.47763}, {'accuracy': 0.4347}, {'accuracy': 0.7010000000000001}, {'accuracy': 0.77116}, {'accuracy': 0.78771}, {'accuracy': 0.7930299999999999}, {'accuracy': 0.8218500000000001}, {'accuracy': 0.7344700000000001}, {'accuracy': 0.71624}, {'accuracy': 0.817}, {'accuracy': 0.76288}, {'accuracy': 0.7649600000000001}, {'accuracy': 0.77341}, {'accuracy': 0.80318}, {'accuracy': 0.73289}, {'accuracy': 0.80009}, {'accuracy': 0.79328}, {'accuracy': 0.8048}, {'accuracy': 0.741}, {'accuracy': 0.7871100000000001}, {'accuracy': 0.7871}, {'accuracy': 0.77001}, {'accuracy': 0.74824}, {'accuracy': 0.7802199999999999}, {'accuracy': 0.70865}, {'accuracy': 0.78698}, {'accuracy': 0.80435}, {'accuracy': 0.7137399999999999}, {'accuracy': 0.73511}, {'accuracy': 0.75214}, {'accuracy': 0.79881}, {'accuracy': 0.7730199999999999}, {'accuracy': 0.81347}, {'accuracy': 0.76812}, {'accuracy': 0.73305}, {'accuracy': 0.78603}, {'accuracy': 0.78657}, {'accuracy': 0.7387900000000001}, {'accuracy': 0.80594}, {'accuracy': 0.74985}, {'accuracy': 0.75523}, {'accuracy': 0.7256400000000001}, {'accuracy': 0.76775}, {'accuracy': 0.77971}, {'accuracy': 0.73681}, {'accuracy': 0.7430599999999999}, {'accuracy': 0.8208499999999999}, {'accuracy': 0.80069}, {'accuracy': 0.6650400000000001}, {'accuracy': 0.7694099999999999}, {'accuracy': 0.7546599999999999}, {'accuracy': 0.79627}, {'accuracy': 0.7909400000000001}, {'accuracy': 0.76201}, {'accuracy': 0.77494}, {'accuracy': 0.77618}, {'accuracy': 0.77511}, {'accuracy': 0.77077}, {'accuracy': 0.7777899999999999}, {'accuracy': 0.76552}, {'accuracy': 0.81601}, {'accuracy': 0.79466}, {'accuracy': 0.78333}, {'accuracy': 0.76706}, {'accuracy': 0.82319}, {'accuracy': 0.74599}, {'accuracy': 0.76948}, {'accuracy': 0.8199099999999999}, {'accuracy': 0.7824199999999999}, {'accuracy': 0.7987200000000001}, {'accuracy': 0.8152700000000002}, {'accuracy': 0.7755600000000001}, {'accuracy': 0.7820500000000001}, {'accuracy': 0.75539}, {'accuracy': 0.80931}, {'accuracy': 0.75393}, {'accuracy': 0.6998800000000001}, {'accuracy': 0.76538}, {'accuracy': 0.76945}, {'accuracy': 0.78067}, {'accuracy': 0.80921}, {'accuracy': 0.7685099999999999}, {'accuracy': 0.69744}, {'accuracy': 0.7995899999999999}, {'accuracy': 0.77228}, {'accuracy': 0.6951499999999999}, {'accuracy': 0.8033699999999999}, {'accuracy': 0.7429600000000001}, {'accuracy': 0.7358300000000001}, {'accuracy': 0.77147}, {'accuracy': 0.76478}, {'accuracy': 0.8008199999999999}, {'accuracy': 0.8157399999999999}, {'accuracy': 0.7822600000000001}, {'accuracy': 0.79786}, {'accuracy': 0.78515}, {'accuracy': 0.7781499999999999}, {'accuracy': 0.77046}, {'accuracy': 0.7411800000000001}, {'accuracy': 0.7656299999999999}, {'accuracy': 0.79043}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9afcd771-9717-4d2e-96e6-8f9242cd357c",
   "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.79</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.79\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAADKoUlEQVR4nOydd3gc1dX/vzPb1W3LkiuuNIOxwY7pJWDwG0JNAg4hMZgSAnEC8Y/khZeAQwg4QCDwhhpeWgrBCYEEUkzAwYRiqukYY4q7JRdZXdoyM78/du+de+/MbJF2tdLu+TyPHlvb5u7sau/Z7/meczTLsiwQBEEQBEGUCHqxF0AQBEEQBJFPKLghCIIgCKKkoOCGIAiCIIiSgoIbgiAIgiBKCgpuCIIgCIIoKSi4IQiCIAiipKDghiAIgiCIkoKCG4IgCIIgSgoKbgiCIAiCKCkouCEIoqCsXLkSmqZh5cqV/LJzzz0XEydOLNqaSomf/OQn0DSt2MsgiEEFBTcEMcj54IMP8M1vfhNjx45FKBTCmDFjcPbZZ+ODDz4o9tIKzl133YWHHnqooMf48MMP8ZOf/ATr168v6HEGkhtuuAF/+ctfir0MgigaFNwQxCDm8ccfx0EHHYQVK1Zg4cKFuOuuu3D++efjueeew0EHHYQnnnii2EssKAMV3Fx77bUU3BBECeEv9gIIgnDn008/xbe+9S1MnjwZ//nPfzBy5Eh+3aWXXoojjzwS3/rWt/Duu+9i8uTJA7aurq4uVFZWDtjxhgJ0TghicEHKDUEMUm6++WZ0d3fj17/+tRTYAEB9fT3uvfdedHV14aabbgIAPPbYY9A0Dc8//7zjse69915omob333+fX/bRRx/ha1/7GoYPH45wOIzZs2fjySeflO730EMP8ce85JJL0NDQgHHjxgEANmzYgEsuuQR77703IpEIRowYgTPOOCNvCsjEiRPxwQcf4Pnnn4emadA0Dccccwy/vrW1FZdddhnGjx+PUCiEqVOn4sYbb4RpmtLjPProo5g1axaqq6tRU1OD6dOn4/bbb+fP74wzzgAAfPGLX+THEf1BKueeey6qqqrw6aef4sQTT0R1dTXOPvtsAIBpmrjtttuw3377IRwOo7GxERdddBF2794tPcYbb7yBefPmob6+HpFIBJMmTcJ5553Hr3fzKQHA+vXroWlaWjVL0zR0dXXh4Ycf5s/n3HPPBQB0dHTgsssuw8SJExEKhdDQ0IDjjz8eq1ev9nw8ghiKkHJDEIOUp556ChMnTsSRRx7pev1RRx2FiRMn4u9//zsA4Mtf/jKqqqrwxz/+EUcffbR022XLlmG//fbD/vvvDyDp4zn88MMxduxYXHHFFaisrMQf//hHnHbaafjzn/+M008/Xbr/JZdcgpEjR+Kaa65BV1cXAOD111/Hyy+/jK9//esYN24c1q9fj7vvvhvHHHMMPvzwQ1RUVPTr+d9222343ve+h6qqKlx11VUAgMbGRgBAd3c3jj76aGzZsgUXXXQR9thjD7z88su48sorsW3bNtx2220AgGeeeQZnnXUWjjvuONx4440AgDVr1uCll17CpZdeiqOOOgrf//738b//+7/4n//5H+y7774AwP/1IpFIYN68eTjiiCPwi1/8gj/Xiy66CA899BAWLlyI73//+/j8889xxx134K233sJLL72EQCCA7du344QTTsDIkSNxxRVXoK6uDuvXr8fjjz/er/PF+O1vf4sLLrgAc+bMwbe//W0AwJQpUwAA3/nOd/DYY49h0aJFmDZtGnbt2oUXX3wRa9aswUEHHZSX4xPEoMAiCGLQ0draagGwTj311LS3O+WUUywAVnt7u2VZlnXWWWdZDQ0NViKR4LfZtm2bpeu69dOf/pRfdtxxx1nTp0+3ent7+WWmaVqHHXaYteeee/LLHnzwQQuAdcQRR0iPaVmW1d3d7VjPqlWrLADWb37zG37Zc889ZwGwnnvuOX7ZOeecY02YMCHtc7Msy9pvv/2so48+2nH5ddddZ1VWVloff/yxdPkVV1xh+Xw+a+PGjZZlWdall15q1dTUONYu8qc//cmxvnScc845FgDriiuukC5/4YUXLADW73//e+ny5cuXS5c/8cQTFgDr9ddf9zyG2zmzLMv6/PPPLQDWgw8+yC9bsmSJpX6UV1ZWWuecc47jcWtra63vfve7WTxLghjaUFqKIAYhHR0dAIDq6uq0t2PXt7e3AwDmz5+P7du3S+mMxx57DKZpYv78+QCAlpYW/Pvf/8aZZ56Jjo4O7Ny5Ezt37sSuXbswb948rFu3Dlu2bJGOc+GFF8Ln80mXRSIR/v94PI5du3Zh6tSpqKurK3ia409/+hOOPPJIDBs2jK9/586dmDt3LgzDwH/+8x8AQF1dHbq6uvDMM8/kfQ0XX3yxY021tbU4/vjjpTXNmjULVVVVeO655/iaAOBvf/sb4vF43teVjrq6Orz66qvYunXrgB6XIAYaCm4IYhDCghYW5HihBkH/9V//hdraWixbtozfZtmyZZg5cyb22msvAMAnn3wCy7Jw9dVXY+TIkdLPkiVLAADbt2+XjjNp0iTHsXt6enDNNddwz0t9fT1GjhyJ1tZWtLW19fGZZ8e6deuwfPlyx/rnzp0rrf+SSy7BXnvthS996UsYN24czjvvPCxfvrzfx/f7/dx7JK6pra0NDQ0NjnV1dnbyNR199NH46le/imuvvRb19fU49dRT8eCDDyIajfZ7XZm46aab8P7772P8+PGYM2cOfvKTn+Czzz4r+HEJYqAhzw1BDEJqa2sxevRovPvuu2lv9+6772Ls2LGoqakBAIRCIZx22ml44okncNddd6G5uRkvvfQSbrjhBn4fZri9/PLLMW/ePNfHnTp1qvS7qNIwvve97+HBBx/EZZddhkMPPRS1tbXQNA1f//rXHabefGOaJo4//nj86Ec/cr2eBXINDQ14++238fTTT+Of//wn/vnPf+LBBx/EggUL8PDDD/f5+KFQCLoufzc0TRMNDQ34/e9/73ofZgrXNA2PPfYYXnnlFTz11FN4+umncd555+GWW27BK6+8gqqqKs+mfIZh9HnNAHDmmWfiyCOPxBNPPIF//etfuPnmm3HjjTfi8ccfx5e+9KV+PTZBDCYouCGIQcpJJ52E++67Dy+++CKOOOIIx/UvvPAC1q9fj4suuki6fP78+Xj44YexYsUKrFmzBpZl8ZQUAF42HggEuNLRFx577DGcc845uOWWW/hlvb29aG1t7fNjqnht8lOmTEFnZ2dW6w8Ggzj55JNx8sknwzRNXHLJJbj33ntx9dVXY+rUqXnr7jtlyhQ8++yzOPzww12DQZVDDjkEhxxyCK6//no88sgjOPvss/Hoo4/iggsuwLBhwwDAcS43bNiQ1VrSPafRo0fjkksuwSWXXILt27fjoIMOwvXXX0/BDVFSUFqKIAYpP/zhDxGJRHDRRRdh165d0nUtLS34zne+g4qKCvzwhz+Urps7dy6GDx+OZcuWYdmyZZgzZ46UVmpoaMAxxxyDe++9F9u2bXMcd8eOHVmtz+fzwbIs6bJf/epX/VYXRCorK12DpTPPPBOrVq3C008/7biutbUViUQCABznTdd1HHDAAQDA00CsP01/g7IzzzwThmHguuuuc1yXSCT44+/evdtx3mbOnCmtacKECfD5fNw7xLjrrruyWovbeTMMw5EubGhowJgxYwYkJUYQAwkpNwQxSNlzzz3x8MMP4+yzz8b06dNx/vnnY9KkSVi/fj3uv/9+7Ny5E3/4wx94mS8jEAjgK1/5Ch599FF0dXXhF7/4heOx77zzThxxxBGYPn06LrzwQkyePBnNzc1YtWoVNm/ejHfeeSfj+k466ST89re/RW1tLaZNm4ZVq1bh2WefxYgRI/J2DmbNmoW7774bP/vZzzB16lQ0NDTg2GOPxQ9/+EM8+eSTOOmkk3Duuedi1qxZ6OrqwnvvvYfHHnsM69evR319PS644AK0tLTg2GOPxbhx47Bhwwb86le/wsyZM3m598yZM+Hz+XDjjTeira0NoVAIxx57LBoaGnJa69FHH42LLroIS5cuxdtvv40TTjgBgUAA69atw5/+9Cfcfvvt+NrXvoaHH34Yd911F04//XRMmTIFHR0duO+++1BTU4MTTzwRQDItecYZZ+BXv/oVNE3DlClT8Le//c3hhUp33p599lnceuutGDNmDCZNmoS9994b48aNw9e+9jXMmDEDVVVVePbZZ/H6669L6htBlATFLdYiCCIT7777rnXWWWdZo0ePtgKBgDVq1CjrrLPOst577z3P+zzzzDMWAEvTNGvTpk2ut/n000+tBQsWWKNGjbICgYA1duxY66STTrIee+wxfhtWCu5Wtrx7925r4cKFVn19vVVVVWXNmzfP+uijj6wJEyZIZcj9KQVvamqyvvzlL1vV1dUWAKksvKOjw7ryyiutqVOnWsFg0Kqvr7cOO+ww6xe/+IUVi8Usy7Ksxx57zDrhhBOshoYGKxgMWnvssYd10UUXWdu2bZOOc99991mTJ0+2fD5fxrLwc845x6qsrPS8/te//rU1a9YsKxKJWNXV1db06dOtH/3oR9bWrVsty7Ks1atXW2eddZa1xx57WKFQyGpoaLBOOukk64033pAeZ8eOHdZXv/pVq6Kiwho2bJh10UUXWe+//35WpeAfffSRddRRR1mRSMQCYJ1zzjlWNBq1fvjDH1ozZsywqqurrcrKSmvGjBnWXXfdle4lIIghiWZZij5KEARBEAQxhCHPDUEQBEEQ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aITDYfz+97/Hrl27cNZZZ2Hs2LGoqKjA9OnT8Yc//EF6HNM0cdNNN2Hq1KkIhULYY489cP311wMAjj32WCxatEi6/Y4dOxAMBgvqlS1qcBMMBjFr1izpCTJz8KGHHup5v5tuugnXXXcdli9fjtmzZw/EUrOC0lIEQRCDC8uy0B1LFOXHsqyc1trV1YXFixfjjTfewIoVK6DrOk4//XSYponOzk4cffTR2LJlC5588km88847+NGPfgTTNAEAf//733H66afjxBNPxFtvvYUVK1b0qUXKFVdcgUsvvRRr1qzBvHnz0Nvbi1mzZuHvf/873n//fXz729/Gt771Lbz22mv8PldeeSV+/vOf4+qrr8aHH36IRx55hNtNLrjgAjzyyCOIRqP89r/73e8wduxYHHvssTmvL1uKvgsvXrwY55xzDmbPno05c+bgtttuQ1dXFxYuXAgAWLBgAcaOHYulS5cCAG688UZcc801eOSRRzBx4kTuzamqqup3R8P+YFmW0MSP0lIEQRCDgZ64gWnXPF2UY3/403moyKE1yFe/+lXp9wceeAAjR47Ehx9+iJdffhk7duzA66+/zgtopk6dym97/fXX4+tf/zquvfZaftmMGTNyXvNll12Gr3zlK9Jll19+Of//9773PTz99NP44x//iDlz5qCjowO333477rjjDpxzzjkAgClTpuCII44AAHzlK1/BokWL8Ne//hVnnnkmAOChhx7CueeeW9AGi0X33MyfPx+/+MUvcM0112DmzJl4++23sXz5ch71bdy4Edu2beO3v/vuuxGLxfC1r30No0eP5j+/+MUvivUUAAC9cROGmYzSqRScIAiCyJV169bhrLPOwuTJk1FTU4OJEycCSO6Db7/9Ng488EDPyuC3334bxx13XL/XoGZDDMPAddddh+nTp2P48OGoqqrC008/jY0bNwIA1qxZg2g06nnscDiMb33rW7y9y+rVq/H+++/j3HPP7fda0zEoduFFixY5cnKMlStXSr+vX7++8AvqA0y10TSgIkCeG4IgiMFAJODDhz+dV7Rj58LJJ5+MCRMm4L777sOYMWNgmib2339/xGIxRCKR9MfKcL2maY40mZthuLKyUvr95ptvxu23347bbrsN06dPR2VlJS677DLEYrGsjgskU1MzZ87E5s2b8eCDD+LYY4/FhAkTMt6vPxRduSkV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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.18389000000000003}, {'accuracy': 0.23702}, {'accuracy': 0.26212}, {'accuracy': 0.35704}, {'accuracy': 0.26816}, {'accuracy': 0.3431}, {'accuracy': 0.35133000000000003}, {'accuracy': 0.30802000000000007}, {'accuracy': 0.40353000000000006}, {'accuracy': 0.42078000000000004}, {'accuracy': 0.49178}, {'accuracy': 0.42428}, {'accuracy': 0.41851000000000005}, {'accuracy': 0.5708499999999999}, {'accuracy': 0.5509000000000001}, {'accuracy': 0.33845000000000003}, {'accuracy': 0.5669500000000001}, {'accuracy': 0.55129}, {'accuracy': 0.5528}, {'accuracy': 0.41131}, {'accuracy': 0.60743}, {'accuracy': 0.4638}, {'accuracy': 0.55715}, {'accuracy': 0.47217000000000003}, {'accuracy': 0.47368000000000005}, {'accuracy': 0.6011599999999999}, {'accuracy': 0.50837}, {'accuracy': 0.60535}, {'accuracy': 0.6647900000000001}, {'accuracy': 0.5788899999999999}, {'accuracy': 0.48844999999999994}, {'accuracy': 0.6136199999999999}, {'accuracy': 0.43346999999999997}, {'accuracy': 0.57345}, {'accuracy': 0.56273}, {'accuracy': 0.5734}, {'accuracy': 0.5047699999999999}, {'accuracy': 0.57094}, {'accuracy': 0.6100300000000001}, {'accuracy': 0.44672}, {'accuracy': 0.60662}, {'accuracy': 0.5411900000000001}, {'accuracy': 0.47618}, {'accuracy': 0.5639299999999999}, {'accuracy': 0.50015}, {'accuracy': 0.6091900000000001}, {'accuracy': 0.5414300000000001}, {'accuracy': 0.50124}, {'accuracy': 0.5775500000000001}, {'accuracy': 0.6937200000000001}, {'accuracy': 0.47877000000000003}, {'accuracy': 0.51861}, {'accuracy': 0.53023}, {'accuracy': 0.61247}, {'accuracy': 0.55025}, {'accuracy': 0.56356}, {'accuracy': 0.47616}, {'accuracy': 0.44722}, {'accuracy': 0.35894}, {'accuracy': 0.6288400000000001}, {'accuracy': 0.33673000000000003}, {'accuracy': 0.5056499999999999}, {'accuracy': 0.5169199999999999}, {'accuracy': 0.4828499999999999}, {'accuracy': 0.52932}, {'accuracy': 0.54704}, {'accuracy': 0.44403999999999993}, {'accuracy': 0.55778}, {'accuracy': 0.58246}, {'accuracy': 0.46293000000000006}, {'accuracy': 0.5542199999999999}, {'accuracy': 0.43746}, {'accuracy': 0.5510200000000001}, {'accuracy': 0.5464}, {'accuracy': 0.47759}, {'accuracy': 0.5695899999999999}, {'accuracy': 0.60944}, {'accuracy': 0.50289}, {'accuracy': 0.6086699999999999}, {'accuracy': 0.58668}, {'accuracy': 0.56423}, {'accuracy': 0.35924}, {'accuracy': 0.51144}, {'accuracy': 0.46009}, {'accuracy': 0.47928}, {'accuracy': 0.45010000000000006}, {'accuracy': 0.46690999999999994}, {'accuracy': 0.56631}, {'accuracy': 0.61773}, {'accuracy': 0.43574999999999997}, {'accuracy': 0.46582999999999986}, {'accuracy': 0.6699700000000001}, {'accuracy': 0.59092}, {'accuracy': 0.4724799999999999}, {'accuracy': 0.47263}, {'accuracy': 0.54809}, {'accuracy': 0.5597099999999999}, {'accuracy': 0.44430000000000003}, {'accuracy': 0.36928}, {'accuracy': 0.40723000000000004}, {'accuracy': 0.61782}, {'accuracy': 0.39506}, {'accuracy': 0.5369900000000001}, {'accuracy': 0.35016}, {'accuracy': 0.48551}, {'accuracy': 0.46661}, {'accuracy': 0.62562}, {'accuracy': 0.49478}, {'accuracy': 0.5643299999999999}, {'accuracy': 0.67173}, {'accuracy': 0.47730999999999996}, {'accuracy': 0.48374999999999996}, {'accuracy': 0.5261600000000001}, {'accuracy': 0.48273}, {'accuracy': 0.38147999999999993}, {'accuracy': 0.4585}, {'accuracy': 0.5821400000000001}, {'accuracy': 0.5430200000000001}, {'accuracy': 0.4738300000000001}, {'accuracy': 0.47506999999999994}, {'accuracy': 0.59663}, {'accuracy': 0.43450000000000005}, {'accuracy': 0.50454}, {'accuracy': 0.5259199999999999}, {'accuracy': 0.49749}, {'accuracy': 0.6569799999999999}, {'accuracy': 0.49704999999999994}, {'accuracy': 0.6464299999999998}, {'accuracy': 0.50667}, {'accuracy': 0.38727}, {'accuracy': 0.7607}, {'accuracy': 0.42983000000000005}, {'accuracy': 0.5098900000000001}, {'accuracy': 0.508}, {'accuracy': 0.5871299999999999}, {'accuracy': 0.5251}, {'accuracy': 0.36757999999999996}, {'accuracy': 0.42593}, {'accuracy': 0.48263000000000006}, {'accuracy': 0.4407}, {'accuracy': 0.61004}, {'accuracy': 0.4525}, {'accuracy': 0.5088299999999999}, {'accuracy': 0.53521}, {'accuracy': 0.51854}, {'accuracy': 0.42477}, {'accuracy': 0.43211000000000005}, {'accuracy': 0.58208}, {'accuracy': 0.50521}, {'accuracy': 0.5811}, {'accuracy': 0.29701}, {'accuracy': 0.36502}, {'accuracy': 0.5984999999999999}, {'accuracy': 0.4300800000000001}, {'accuracy': 0.31734}, {'accuracy': 0.5212500000000001}, {'accuracy': 0.4451299999999999}, {'accuracy': 0.47778}, {'accuracy': 0.53883}, {'accuracy': 0.44596}, {'accuracy': 0.36706000000000005}, {'accuracy': 0.53639}, {'accuracy': 0.47228000000000003}, {'accuracy': 0.5103199999999999}, {'accuracy': 0.5010399999999999}, {'accuracy': 0.5420999999999999}, {'accuracy': 0.5200699999999999}, {'accuracy': 0.45267}, {'accuracy': 0.44647}, {'accuracy': 0.43004999999999993}, {'accuracy': 0.61273}, {'accuracy': 0.4831}, {'accuracy': 0.48819}, {'accuracy': 0.46055999999999997}, {'accuracy': 0.4484699999999999}, {'accuracy': 0.46475999999999995}, {'accuracy': 0.4372599999999999}, {'accuracy': 0.4149}, {'accuracy': 0.44867}, {'accuracy': 0.54538}, {'accuracy': 0.46159}, {'accuracy': 0.48355}, {'accuracy': 0.49472999999999995}, {'accuracy': 0.54476}, {'accuracy': 0.45146}, {'accuracy': 0.4464600000000001}, {'accuracy': 0.54139}, {'accuracy': 0.50549}, {'accuracy': 0.5260100000000001}, {'accuracy': 0.44082999999999994}, {'accuracy': 0.47056000000000003}, {'accuracy': 0.36980999999999997}, {'accuracy': 0.38908}, {'accuracy': 0.31916}, {'accuracy': 0.5342}, {'accuracy': 0.5924099999999999}, {'accuracy': 0.43778000000000006}, {'accuracy': 0.53447}, {'accuracy': 0.51227}, {'accuracy': 0.47763}, {'accuracy': 0.4347}, {'accuracy': 0.7010000000000001}, {'accuracy': 0.77116}, {'accuracy': 0.78771}, {'accuracy': 0.7930299999999999}, {'accuracy': 0.8218500000000001}, {'accuracy': 0.7344700000000001}, {'accuracy': 0.71624}, {'accuracy': 0.817}, {'accuracy': 0.76288}, {'accuracy': 0.7649600000000001}, {'accuracy': 0.77341}, {'accuracy': 0.80318}, {'accuracy': 0.73289}, {'accuracy': 0.80009}, {'accuracy': 0.79328}, {'accuracy': 0.8048}, {'accuracy': 0.741}, {'accuracy': 0.7871100000000001}, {'accuracy': 0.7871}, {'accuracy': 0.77001}, {'accuracy': 0.74824}, {'accuracy': 0.7802199999999999}, {'accuracy': 0.70865}, {'accuracy': 0.78698}, {'accuracy': 0.80435}, {'accuracy': 0.7137399999999999}, {'accuracy': 0.73511}, {'accuracy': 0.75214}, {'accuracy': 0.79881}, {'accuracy': 0.7730199999999999}, {'accuracy': 0.81347}, {'accuracy': 0.76812}, {'accuracy': 0.73305}, {'accuracy': 0.78603}, {'accuracy': 0.78657}, {'accuracy': 0.7387900000000001}, {'accuracy': 0.80594}, {'accuracy': 0.74985}, {'accuracy': 0.75523}, {'accuracy': 0.7256400000000001}, {'accuracy': 0.76775}, {'accuracy': 0.77971}, {'accuracy': 0.73681}, {'accuracy': 0.7430599999999999}, {'accuracy': 0.8208499999999999}, {'accuracy': 0.80069}, {'accuracy': 0.6650400000000001}, {'accuracy': 0.7694099999999999}, {'accuracy': 0.7546599999999999}, {'accuracy': 0.79627}, {'accuracy': 0.7909400000000001}, {'accuracy': 0.76201}, {'accuracy': 0.77494}, {'accuracy': 0.77618}, {'accuracy': 0.77511}, {'accuracy': 0.77077}, {'accuracy': 0.7777899999999999}, {'accuracy': 0.76552}, {'accuracy': 0.81601}, {'accuracy': 0.79466}, {'accuracy': 0.78333}, {'accuracy': 0.76706}, {'accuracy': 0.82319}, {'accuracy': 0.74599}, {'accuracy': 0.76948}, {'accuracy': 0.8199099999999999}, {'accuracy': 0.7824199999999999}, {'accuracy': 0.7987200000000001}, {'accuracy': 0.8152700000000002}, {'accuracy': 0.7755600000000001}, {'accuracy': 0.7820500000000001}, {'accuracy': 0.75539}, {'accuracy': 0.80931}, {'accuracy': 0.75393}, {'accuracy': 0.6998800000000001}, {'accuracy': 0.76538}, {'accuracy': 0.76945}, {'accuracy': 0.78067}, {'accuracy': 0.80921}, {'accuracy': 0.7685099999999999}, {'accuracy': 0.69744}, {'accuracy': 0.7995899999999999}, {'accuracy': 0.77228}, {'accuracy': 0.6951499999999999}, {'accuracy': 0.8033699999999999}, {'accuracy': 0.7429600000000001}, {'accuracy': 0.7358300000000001}, {'accuracy': 0.77147}, {'accuracy': 0.76478}, {'accuracy': 0.8008199999999999}, {'accuracy': 0.8157399999999999}, {'accuracy': 0.7822600000000001}, {'accuracy': 0.79786}, {'accuracy': 0.78515}, {'accuracy': 0.7781499999999999}, {'accuracy': 0.77046}, {'accuracy': 0.7411800000000001}, {'accuracy': 0.7656299999999999}, {'accuracy': 0.79043}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b038631a-8c56-436e-81a9-bcf7c4bf36c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c14e55f4-784b-4906-b9f0-413e44b11b08",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfb5119e-99b7-4966-8fc7-4365f3ba66b7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2890e933-2503-44d2-9dfe-1f60a144c8f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5eff440-6906-4efb-af71-dcf4760c2902",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef2f4fd0-f4af-471f-8b84-ebe39e75ea92",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f0552ac-2abb-4e6c-8490-28cd65685242",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0b1a48d-4f16-42b9-a3ec-28162ae8cdf1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81da3426-a31e-4ad9-923f-868dd4028a77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95b52300-cb19-4917-af50-edab4a957691",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6967dba-d9c6-4348-b9f9-26a4513675f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39c0c3d8-0544-4232-b3c6-c4ffa62cbe70",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e23f009b-257b-4c7b-8eab-c96859a5c752",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3be51748-90e8-4f84-873c-79438809c51c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3e09581-9c6f-4e66-8595-b9c7d0e6da55",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "217a3ab5-cc3d-44cd-af62-af87836efe79",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53db6aa5-a8b1-4a4c-bc59-2c431f0cfa52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5439c75-a5a0-4bc3-b6f9-15dbb23f7b44",
   "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
}
