{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "5922\n",
      "[[  0 567]\n",
      " [  1 682]\n",
      " [  2 571]\n",
      " [  3 620]\n",
      " [  4 603]\n",
      " [  5 544]\n",
      " [  6 576]\n",
      " [  7 605]\n",
      " [  8 600]\n",
      " [  9 607]]\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": [
      "30090\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 290]\n",
      " [  1 346]\n",
      " [  2 298]\n",
      " [  3 307]\n",
      " [  4 296]\n",
      " [  5 262]\n",
      " [  6 291]\n",
      " [  7 336]\n",
      " [  8 297]\n",
      " [  9 268]]\n",
      "[[   0 1490]\n",
      " [   1  371]\n",
      " [   2  314]\n",
      " [   3  348]\n",
      " [   4  361]\n",
      " [   5  355]\n",
      " [   6  452]\n",
      " [   7  614]\n",
      " [   8  744]\n",
      " [   9 1000]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([3, 1, 1,  ..., 8, 3, 1])"
      ]
     },
     "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, 1, 1,  ..., 8, 3, 1])"
      ]
     },
     "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-17:07:57 </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-17:07:57\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": "2f0cf4c0a1e3478fb5ded01884311cf9",
       "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-17:36:21 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3475</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-17:36:21\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3475\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\">75894000</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;36m75894000\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.16579000000000002}, {'accuracy': 0.21647}, {'accuracy': 0.39749}, {'accuracy': 0.36543000000000003}, {'accuracy': 0.5374400000000001}, {'accuracy': 0.55577}, {'accuracy': 0.55823}, {'accuracy': 0.5573699999999999}, {'accuracy': 0.64962}, {'accuracy': 0.70363}, {'accuracy': 0.7857999999999999}, {'accuracy': 0.61086}, {'accuracy': 0.77938}, {'accuracy': 0.7207}, {'accuracy': 0.65152}, {'accuracy': 0.44758999999999993}, {'accuracy': 0.65343}, {'accuracy': 0.7528500000000001}, {'accuracy': 0.78624}, {'accuracy': 0.5388400000000001}, {'accuracy': 0.72531}, {'accuracy': 0.7484999999999999}, {'accuracy': 0.7812399999999999}, {'accuracy': 0.64829}, {'accuracy': 0.78339}, {'accuracy': 0.7637799999999999}, {'accuracy': 0.74559}, {'accuracy': 0.7849300000000001}, {'accuracy': 0.7412600000000001}, {'accuracy': 0.78142}, {'accuracy': 0.7317599999999999}, {'accuracy': 0.79257}, {'accuracy': 0.7448699999999999}, {'accuracy': 0.78616}, {'accuracy': 0.66314}, {'accuracy': 0.8535999999999999}, {'accuracy': 0.8218200000000001}, {'accuracy': 0.79087}, {'accuracy': 0.7901499999999999}, {'accuracy': 0.79585}, {'accuracy': 0.85002}, {'accuracy': 0.77829}, {'accuracy': 0.72704}, {'accuracy': 0.80411}, {'accuracy': 0.6358699999999999}, {'accuracy': 0.75561}, {'accuracy': 0.68614}, {'accuracy': 0.7493200000000001}, {'accuracy': 0.71478}, {'accuracy': 0.75614}, {'accuracy': 0.8225800000000001}, {'accuracy': 0.80307}, {'accuracy': 0.6777599999999999}, {'accuracy': 0.7799000000000001}, {'accuracy': 0.88577}, {'accuracy': 0.6567800000000001}, {'accuracy': 0.6318300000000001}, {'accuracy': 0.7780499999999999}, {'accuracy': 0.8799000000000001}, {'accuracy': 0.68746}, {'accuracy': 0.8245799999999999}, {'accuracy': 0.78466}, {'accuracy': 0.7249899999999999}, {'accuracy': 0.7217699999999999}, {'accuracy': 0.7106199999999999}, {'accuracy': 0.7843899999999999}, {'accuracy': 0.70507}, {'accuracy': 0.74576}, {'accuracy': 0.79622}, {'accuracy': 0.89634}, {'accuracy': 0.8052300000000001}, {'accuracy': 0.77273}, {'accuracy': 0.79276}, {'accuracy': 0.8032}, {'accuracy': 0.71975}, {'accuracy': 0.7934999999999999}, {'accuracy': 0.7867200000000001}, {'accuracy': 0.77119}, {'accuracy': 0.65331}, {'accuracy': 0.78655}, {'accuracy': 0.6225600000000001}, {'accuracy': 0.60521}, {'accuracy': 0.8023100000000001}, {'accuracy': 0.86265}, {'accuracy': 0.64888}, {'accuracy': 0.7751299999999999}, {'accuracy': 0.7835000000000001}, {'accuracy': 0.8507199999999999}, {'accuracy': 0.76397}, {'accuracy': 0.78493}, {'accuracy': 0.80116}, {'accuracy': 0.8034100000000001}, {'accuracy': 0.79582}, {'accuracy': 0.86567}, {'accuracy': 0.78828}, {'accuracy': 0.81229}, {'accuracy': 0.7567999999999999}, {'accuracy': 0.77708}, {'accuracy': 0.68296}, {'accuracy': 0.8276600000000001}, {'accuracy': 0.72051}, {'accuracy': 0.68485}, {'accuracy': 0.77767}, {'accuracy': 0.69197}, {'accuracy': 0.8499800000000001}, {'accuracy': 0.8328300000000001}, {'accuracy': 0.81673}, {'accuracy': 0.8522000000000001}, {'accuracy': 0.7927599999999999}, {'accuracy': 0.8105499999999999}, {'accuracy': 0.6949799999999999}, {'accuracy': 0.7565899999999999}, {'accuracy': 0.72001}, {'accuracy': 0.77387}, {'accuracy': 0.81601}, {'accuracy': 0.7825799999999999}, {'accuracy': 0.7450600000000001}, {'accuracy': 0.75961}, {'accuracy': 0.83009}, {'accuracy': 0.83101}, {'accuracy': 0.74719}, {'accuracy': 0.91543}, {'accuracy': 0.76524}, {'accuracy': 0.79457}, {'accuracy': 0.8073}, {'accuracy': 0.7934699999999999}, {'accuracy': 0.8672400000000001}, {'accuracy': 0.7654799999999999}, {'accuracy': 0.8369099999999999}, {'accuracy': 0.79391}, {'accuracy': 0.67851}, {'accuracy': 0.73331}, {'accuracy': 0.74798}, {'accuracy': 0.7930999999999999}, {'accuracy': 0.77202}, {'accuracy': 0.7962}, {'accuracy': 0.7905900000000001}, {'accuracy': 0.7884}, {'accuracy': 0.7942}, {'accuracy': 0.8081100000000001}, {'accuracy': 0.79786}, {'accuracy': 0.59028}, {'accuracy': 0.78623}, {'accuracy': 0.76381}, {'accuracy': 0.71566}, {'accuracy': 0.8168799999999999}, {'accuracy': 0.72081}, {'accuracy': 0.70111}, {'accuracy': 0.72932}, {'accuracy': 0.7154}, {'accuracy': 0.7304000000000002}, {'accuracy': 0.6500100000000001}, {'accuracy': 0.8067399999999999}, {'accuracy': 0.96478}, {'accuracy': 0.96465}, {'accuracy': 0.9639599999999999}, {'accuracy': 0.96478}, {'accuracy': 0.9646699999999999}, {'accuracy': 0.96257}, {'accuracy': 0.9639399999999998}, {'accuracy': 0.96426}, {'accuracy': 0.96194}, {'accuracy': 0.9631500000000001}, {'accuracy': 0.9619899999999999}, {'accuracy': 0.9617899999999999}, {'accuracy': 0.9630799999999999}, {'accuracy': 0.96159}, {'accuracy': 0.96404}, {'accuracy': 0.96341}, {'accuracy': 0.9621699999999999}, {'accuracy': 0.9611199999999999}, {'accuracy': 0.9647500000000001}, {'accuracy': 0.9626899999999999}, {'accuracy': 0.9620900000000001}, {'accuracy': 0.9640700000000001}, {'accuracy': 0.96272}, {'accuracy': 0.96301}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96418}, {'accuracy': 0.9634600000000001}, {'accuracy': 0.96146}, {'accuracy': 0.96227}, {'accuracy': 0.9638}, {'accuracy': 0.9636000000000001}, {'accuracy': 0.96227}, {'accuracy': 0.96319}, {'accuracy': 0.962}, {'accuracy': 0.96381}, {'accuracy': 0.9627000000000001}, {'accuracy': 0.9614400000000002}, {'accuracy': 0.96366}, {'accuracy': 0.9628300000000001}, {'accuracy': 0.96311}, {'accuracy': 0.9629099999999999}, {'accuracy': 0.96542}, {'accuracy': 0.96532}, {'accuracy': 0.96089}, {'accuracy': 0.96236}, {'accuracy': 0.96207}, {'accuracy': 0.96486}, {'accuracy': 0.9640600000000001}, {'accuracy': 0.96365}, {'accuracy': 0.96438}, {'accuracy': 0.9645400000000001}, {'accuracy': 0.96411}, {'accuracy': 0.96434}, {'accuracy': 0.9627399999999999}, {'accuracy': 0.96248}, {'accuracy': 0.9619799999999998}, {'accuracy': 0.9638000000000002}, {'accuracy': 0.96343}, {'accuracy': 0.9628099999999999}, {'accuracy': 0.96207}, {'accuracy': 0.9645100000000001}, {'accuracy': 0.96275}, {'accuracy': 0.96394}, {'accuracy': 0.9638300000000001}, {'accuracy': 0.9642000000000002}, {'accuracy': 0.9653600000000001}, {'accuracy': 0.96397}, {'accuracy': 0.9635199999999999}, {'accuracy': 0.96204}, {'accuracy': 0.9639600000000002}, {'accuracy': 0.9637999999999998}, {'accuracy': 0.96547}, {'accuracy': 0.96601}, {'accuracy': 0.9650400000000001}, {'accuracy': 0.9658599999999999}, {'accuracy': 0.9642899999999999}, {'accuracy': 0.9648900000000001}, {'accuracy': 0.9642}, {'accuracy': 0.9659600000000002}, {'accuracy': 0.96343}, {'accuracy': 0.9644199999999999}, {'accuracy': 0.9632000000000002}, {'accuracy': 0.96433}, {'accuracy': 0.9635599999999999}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96341}, {'accuracy': 0.9636099999999999}, {'accuracy': 0.9631000000000001}, {'accuracy': 0.9655999999999999}, {'accuracy': 0.9658100000000001}, {'accuracy': 0.9637600000000001}, {'accuracy': 0.96376}, {'accuracy': 0.9645300000000001}, {'accuracy': 0.96498}, {'accuracy': 0.9639599999999999}, {'accuracy': 0.9635200000000002}, {'accuracy': 0.96052}, {'accuracy': 0.9626899999999999}, {'accuracy': 0.9635999999999999}, {'accuracy': 0.9644}, {'accuracy': 0.96226}, {'accuracy': 0.9647}, {'accuracy': 0.9655799999999999}, {'accuracy': 0.9639}, {'accuracy': 0.9639899999999999}, {'accuracy': 0.96426}, {'accuracy': 0.96272}, {'accuracy': 0.9622799999999998}, {'accuracy': 0.96294}, {'accuracy': 0.96381}, {'accuracy': 0.96556}, {'accuracy': 0.96448}, {'accuracy': 0.9655400000000001}, {'accuracy': 0.9632699999999998}, {'accuracy': 0.9640700000000001}, {'accuracy': 0.9638499999999999}, {'accuracy': 0.96241}, {'accuracy': 0.9642799999999999}, {'accuracy': 0.96445}, {'accuracy': 0.9642200000000001}, {'accuracy': 0.96356}, {'accuracy': 0.96391}, {'accuracy': 0.9644999999999999}, {'accuracy': 0.9650399999999999}, {'accuracy': 0.96433}, {'accuracy': 0.9638}, {'accuracy': 0.96594}, {'accuracy': 0.9633199999999998}, {'accuracy': 0.9628}, {'accuracy': 0.9648100000000002}, {'accuracy': 0.9662500000000002}, {'accuracy': 0.96323}, {'accuracy': 0.96357}, {'accuracy': 0.9639199999999999}, {'accuracy': 0.9628500000000001}, {'accuracy': 0.96333}, {'accuracy': 0.9644999999999999}, {'accuracy': 0.96351}, {'accuracy': 0.96423}, {'accuracy': 0.96401}, {'accuracy': 0.96379}, {'accuracy': 0.9635300000000001}, {'accuracy': 0.9661}, {'accuracy': 0.96486}, {'accuracy': 0.9649000000000001}, {'accuracy': 0.96351}, {'accuracy': 0.96348}]\n"
     ]
    }
   ],
   "source": [
    "\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(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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iGWpGE4DJyKKFC03Lj5lhSrTFvGyVEFBAWbMmIExY8Zg7NixWLRoESwWC2bOnAkAmD59OrKzs7FgwQIAwFNPPYV58+bhnXfeQW5uLkpLSwEA8fHx7a7RtZdYlmLmhoiIKHIiHtxMnToVFRUVmDdvHkpLSzFixAgsX75cajIuLi5WROEvvfQSbDYbrrnmGsXjzJ8/H4888khHDt2LWJZKYnBDREQUMREPbgBgzpw5mDNnjs/rVq5cqfj+0KFD4R9QG4mZmxSuTkxERBQxLEyGkLQ6MWdLERHRKc5ut0d6CG3G4CaEOFuKiIjaavny5Tj77LORnJyM7t2749JLL8X+/ful648ePYpp06ahW7duiIuLw5gxY/DLL79I1//vf//DGWecAbPZjNTUVFx55ZXSdRqNBp988oni+ZKTk7FkyRIA7qqIRqPB0qVLMXHiRJjNZrz99tuoqqrCtGnTkJ2djdjYWAwbNgzvvvuu4nFcLheefvpp9O/fHyaTCb169cLjjz8OAJg0aZJXZaaiogJGo1ExmSjUOkVZqqsQMzdJnC1FRNQpCIKARntkViqOMeiCmv1jsVhQUFCA4cOHo76+HvPmzcOVV16JzZs3o6GhARMnTkR2djY+++wzZGZmYuPGjXC5XACAL774AldeeSUefPBBvPnmm7DZbPjyyy+DHvMDDzyAZ599FiNHjoTZbEZTUxNGjx6N+++/H4mJifjiiy9www03oF+/fhg7diwA95Irr7zyCv7xj3/g7LPPRklJibQQ76xZszBnzhw8++yzMJlMAID//ve/yM7OxqRJk4IeX6AY3IRQDTM3RESdSqPdiSHzvo7Ic+/42xTEGgM/zV599dWK71977TWkpaVhx44dWLNmDSoqKrBu3Tppu6H+/ftLt3388cfxu9/9TrFobV5eXtBjvvvuu3HVVVcpLrvnnnuk///pT3/C119/jffffx9jx45FXV0dnnvuOTz//POYMWMGAKBfv344++yzAQBXXXUV5syZg08//RTXXXcdAGDJkiW48cYbw7rAIstSISIIAqeCExFRm+3duxfTpk1D3759kZiYiNzcXADuWcObN2/GyJEj/e6juHnzZkyePLndY1CvHed0OvHYY49h2LBh6NatG+Lj4/H111+juLgYALBz505YrVa/z202m3HDDTfgtddeAwBs3LgR27Ztw4033tju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UdfD4IaIiIi6FAY3RERE1KUwuCGiTsXlcuHpp59G//79YTKZ0KtXLzz++OOYNGkS5syZo7htRUUFjEajtBux1WrF/fffj5ycHJhMJvTv3x+vvvqq3+davXo1JkyYgJiYGOTk5ODOO++ExWIJ6+sjovBjcENEncrcuXPx5JNP4uGHH8aOHTvwzjvvICMjA7NmzcI777wDq9Uq3fa///0vsrOzMWnSJADA9OnT8e677+Kf//wndu7ciZdffhnx8fE+n2f//v248MILcfXVV2PLli1YunQpVq9e7RVAEdGphxtnElGnUVdXh7S0NDz//POYNWuW4rqmpib06NEDixcvxnXXXQcAyMvLw1VXXYX58+djz549GDhwIFasWIH8/Hyvx165ciXOO+88nDx5EsnJyZg1axZ0Oh1efvll6TarV6/GxIkTYbFYYDabw/tiiShsmLkhok5j586dsFqtmDx5std1ZrMZN9xwA1577TUAwMaNG7Ft2zbceOONAIDNmzdDp9Nh4sSJAT3Xr7/+iiVLliA+Pl76mjJlClwuFw4ePBiy10REHU8f6QEQEYliYmJavH7WrFkYMWIEjh49itdffx2TJk1C7969A7qvWn19PW655RbceeedXtf16tUrqMcios6FmRsi6jQGDBiAmJgYqUFYbdiwYRgzZgxeeeUVvPPOO7jpppsU17lcLqxatSqg5xo1ahR27NiB/v37e30ZjcaQvB4iigwGN0TUaZjNZtx///2477778Oabb2L//v34+eefFTOeZs2ahSeffBKCIODKK6+ULs/NzcWMGTNw00034ZNPPsHBgwexcuVKvP/++z6f6/7778eaNWswZ84cbN68GXv37sWnn37KhmKiLoDBDRF1Kg8//DD+8pe/YN68eRg8eDCmTp2K8vJy6fpp06ZBr9dj2rRpXk2/L730Eq655hrcfvvtGDRoEGbPnu13avfw4cOxatUq7NmzBxMmTMDIkSMxb9489OjRI6yvj4jCj7OliOiUcujQIfTr1w/r1q3DqFGjIj0cIuqEGNwQ0SnBbrejqqoK99xzDw4ePIiffvop0kMiok6KZSkiOiX89NNPyMrKwrp167B48eJID4eIOjFmboiIiKhLYeaGiIiIuhQGN0RERNSlMLghIiKiLoXBDREREXUpDG6IiIioS2FwQ0RERF0KgxsiIiLqUhjcEBERUZfC4IaIiIi6lP8HpIE+uW5uXgAAAAAASUVORK5CYII=\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.16579000000000002}, {'accuracy': 0.21647}, {'accuracy': 0.39749}, {'accuracy': 0.36543000000000003}, {'accuracy': 0.5374400000000001}, {'accuracy': 0.55577}, {'accuracy': 0.55823}, {'accuracy': 0.5573699999999999}, {'accuracy': 0.64962}, {'accuracy': 0.70363}, {'accuracy': 0.7857999999999999}, {'accuracy': 0.61086}, {'accuracy': 0.77938}, {'accuracy': 0.7207}, {'accuracy': 0.65152}, {'accuracy': 0.44758999999999993}, {'accuracy': 0.65343}, {'accuracy': 0.7528500000000001}, {'accuracy': 0.78624}, {'accuracy': 0.5388400000000001}, {'accuracy': 0.72531}, {'accuracy': 0.7484999999999999}, {'accuracy': 0.7812399999999999}, {'accuracy': 0.64829}, {'accuracy': 0.78339}, {'accuracy': 0.7637799999999999}, {'accuracy': 0.74559}, {'accuracy': 0.7849300000000001}, {'accuracy': 0.7412600000000001}, {'accuracy': 0.78142}, {'accuracy': 0.7317599999999999}, {'accuracy': 0.79257}, {'accuracy': 0.7448699999999999}, {'accuracy': 0.78616}, {'accuracy': 0.66314}, {'accuracy': 0.8535999999999999}, {'accuracy': 0.8218200000000001}, {'accuracy': 0.79087}, {'accuracy': 0.7901499999999999}, {'accuracy': 0.79585}, {'accuracy': 0.85002}, {'accuracy': 0.77829}, {'accuracy': 0.72704}, {'accuracy': 0.80411}, {'accuracy': 0.6358699999999999}, {'accuracy': 0.75561}, {'accuracy': 0.68614}, {'accuracy': 0.7493200000000001}, {'accuracy': 0.71478}, {'accuracy': 0.75614}, {'accuracy': 0.8225800000000001}, {'accuracy': 0.80307}, {'accuracy': 0.6777599999999999}, {'accuracy': 0.7799000000000001}, {'accuracy': 0.88577}, {'accuracy': 0.6567800000000001}, {'accuracy': 0.6318300000000001}, {'accuracy': 0.7780499999999999}, {'accuracy': 0.8799000000000001}, {'accuracy': 0.68746}, {'accuracy': 0.8245799999999999}, {'accuracy': 0.78466}, {'accuracy': 0.7249899999999999}, {'accuracy': 0.7217699999999999}, {'accuracy': 0.7106199999999999}, {'accuracy': 0.7843899999999999}, {'accuracy': 0.70507}, {'accuracy': 0.74576}, {'accuracy': 0.79622}, {'accuracy': 0.89634}, {'accuracy': 0.8052300000000001}, {'accuracy': 0.77273}, {'accuracy': 0.79276}, {'accuracy': 0.8032}, {'accuracy': 0.71975}, {'accuracy': 0.7934999999999999}, {'accuracy': 0.7867200000000001}, {'accuracy': 0.77119}, {'accuracy': 0.65331}, {'accuracy': 0.78655}, {'accuracy': 0.6225600000000001}, {'accuracy': 0.60521}, {'accuracy': 0.8023100000000001}, {'accuracy': 0.86265}, {'accuracy': 0.64888}, {'accuracy': 0.7751299999999999}, {'accuracy': 0.7835000000000001}, {'accuracy': 0.8507199999999999}, {'accuracy': 0.76397}, {'accuracy': 0.78493}, {'accuracy': 0.80116}, {'accuracy': 0.8034100000000001}, {'accuracy': 0.79582}, {'accuracy': 0.86567}, {'accuracy': 0.78828}, {'accuracy': 0.81229}, {'accuracy': 0.7567999999999999}, {'accuracy': 0.77708}, {'accuracy': 0.68296}, {'accuracy': 0.8276600000000001}, {'accuracy': 0.72051}, {'accuracy': 0.68485}, {'accuracy': 0.77767}, {'accuracy': 0.69197}, {'accuracy': 0.8499800000000001}, {'accuracy': 0.8328300000000001}, {'accuracy': 0.81673}, {'accuracy': 0.8522000000000001}, {'accuracy': 0.7927599999999999}, {'accuracy': 0.8105499999999999}, {'accuracy': 0.6949799999999999}, {'accuracy': 0.7565899999999999}, {'accuracy': 0.72001}, {'accuracy': 0.77387}, {'accuracy': 0.81601}, {'accuracy': 0.7825799999999999}, {'accuracy': 0.7450600000000001}, {'accuracy': 0.75961}, {'accuracy': 0.83009}, {'accuracy': 0.83101}, {'accuracy': 0.74719}, {'accuracy': 0.91543}, {'accuracy': 0.76524}, {'accuracy': 0.79457}, {'accuracy': 0.8073}, {'accuracy': 0.7934699999999999}, {'accuracy': 0.8672400000000001}, {'accuracy': 0.7654799999999999}, {'accuracy': 0.8369099999999999}, {'accuracy': 0.79391}, {'accuracy': 0.67851}, {'accuracy': 0.73331}, {'accuracy': 0.74798}, {'accuracy': 0.7930999999999999}, {'accuracy': 0.77202}, {'accuracy': 0.7962}, {'accuracy': 0.7905900000000001}, {'accuracy': 0.7884}, {'accuracy': 0.7942}, {'accuracy': 0.8081100000000001}, {'accuracy': 0.79786}, {'accuracy': 0.59028}, {'accuracy': 0.78623}, {'accuracy': 0.76381}, {'accuracy': 0.71566}, {'accuracy': 0.8168799999999999}, {'accuracy': 0.72081}, {'accuracy': 0.70111}, {'accuracy': 0.72932}, {'accuracy': 0.7154}, {'accuracy': 0.7304000000000002}, {'accuracy': 0.6500100000000001}, {'accuracy': 0.8067399999999999}, {'accuracy': 0.96478}, {'accuracy': 0.96465}, {'accuracy': 0.9639599999999999}, {'accuracy': 0.96478}, {'accuracy': 0.9646699999999999}, {'accuracy': 0.96257}, {'accuracy': 0.9639399999999998}, {'accuracy': 0.96426}, {'accuracy': 0.96194}, {'accuracy': 0.9631500000000001}, {'accuracy': 0.9619899999999999}, {'accuracy': 0.9617899999999999}, {'accuracy': 0.9630799999999999}, {'accuracy': 0.96159}, {'accuracy': 0.96404}, {'accuracy': 0.96341}, {'accuracy': 0.9621699999999999}, {'accuracy': 0.9611199999999999}, {'accuracy': 0.9647500000000001}, {'accuracy': 0.9626899999999999}, {'accuracy': 0.9620900000000001}, {'accuracy': 0.9640700000000001}, {'accuracy': 0.96272}, {'accuracy': 0.96301}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96418}, {'accuracy': 0.9634600000000001}, {'accuracy': 0.96146}, {'accuracy': 0.96227}, {'accuracy': 0.9638}, {'accuracy': 0.9636000000000001}, {'accuracy': 0.96227}, {'accuracy': 0.96319}, {'accuracy': 0.962}, {'accuracy': 0.96381}, {'accuracy': 0.9627000000000001}, {'accuracy': 0.9614400000000002}, {'accuracy': 0.96366}, {'accuracy': 0.9628300000000001}, {'accuracy': 0.96311}, {'accuracy': 0.9629099999999999}, {'accuracy': 0.96542}, {'accuracy': 0.96532}, {'accuracy': 0.96089}, {'accuracy': 0.96236}, {'accuracy': 0.96207}, {'accuracy': 0.96486}, {'accuracy': 0.9640600000000001}, {'accuracy': 0.96365}, {'accuracy': 0.96438}, {'accuracy': 0.9645400000000001}, {'accuracy': 0.96411}, {'accuracy': 0.96434}, {'accuracy': 0.9627399999999999}, {'accuracy': 0.96248}, {'accuracy': 0.9619799999999998}, {'accuracy': 0.9638000000000002}, {'accuracy': 0.96343}, {'accuracy': 0.9628099999999999}, {'accuracy': 0.96207}, {'accuracy': 0.9645100000000001}, {'accuracy': 0.96275}, {'accuracy': 0.96394}, {'accuracy': 0.9638300000000001}, {'accuracy': 0.9642000000000002}, {'accuracy': 0.9653600000000001}, {'accuracy': 0.96397}, {'accuracy': 0.9635199999999999}, {'accuracy': 0.96204}, {'accuracy': 0.9639600000000002}, {'accuracy': 0.9637999999999998}, {'accuracy': 0.96547}, {'accuracy': 0.96601}, {'accuracy': 0.9650400000000001}, {'accuracy': 0.9658599999999999}, {'accuracy': 0.9642899999999999}, {'accuracy': 0.9648900000000001}, {'accuracy': 0.9642}, {'accuracy': 0.9659600000000002}, {'accuracy': 0.96343}, {'accuracy': 0.9644199999999999}, {'accuracy': 0.9632000000000002}, {'accuracy': 0.96433}, {'accuracy': 0.9635599999999999}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96341}, {'accuracy': 0.9636099999999999}, {'accuracy': 0.9631000000000001}, {'accuracy': 0.9655999999999999}, {'accuracy': 0.9658100000000001}, {'accuracy': 0.9637600000000001}, {'accuracy': 0.96376}, {'accuracy': 0.9645300000000001}, {'accuracy': 0.96498}, {'accuracy': 0.9639599999999999}, {'accuracy': 0.9635200000000002}, {'accuracy': 0.96052}, {'accuracy': 0.9626899999999999}, {'accuracy': 0.9635999999999999}, {'accuracy': 0.9644}, {'accuracy': 0.96226}, {'accuracy': 0.9647}, {'accuracy': 0.9655799999999999}, {'accuracy': 0.9639}, {'accuracy': 0.9639899999999999}, {'accuracy': 0.96426}, {'accuracy': 0.96272}, {'accuracy': 0.9622799999999998}, {'accuracy': 0.96294}, {'accuracy': 0.96381}, {'accuracy': 0.96556}, {'accuracy': 0.96448}, {'accuracy': 0.9655400000000001}, {'accuracy': 0.9632699999999998}, {'accuracy': 0.9640700000000001}, {'accuracy': 0.9638499999999999}, {'accuracy': 0.96241}, {'accuracy': 0.9642799999999999}, {'accuracy': 0.96445}, {'accuracy': 0.9642200000000001}, {'accuracy': 0.96356}, {'accuracy': 0.96391}, {'accuracy': 0.9644999999999999}, {'accuracy': 0.9650399999999999}, {'accuracy': 0.96433}, {'accuracy': 0.9638}, {'accuracy': 0.96594}, {'accuracy': 0.9633199999999998}, {'accuracy': 0.9628}, {'accuracy': 0.9648100000000002}, {'accuracy': 0.9662500000000002}, {'accuracy': 0.96323}, {'accuracy': 0.96357}, {'accuracy': 0.9639199999999999}, {'accuracy': 0.9628500000000001}, {'accuracy': 0.96333}, {'accuracy': 0.9644999999999999}, {'accuracy': 0.96351}, {'accuracy': 0.96423}, {'accuracy': 0.96401}, {'accuracy': 0.96379}, {'accuracy': 0.9635300000000001}, {'accuracy': 0.9661}, {'accuracy': 0.96486}, {'accuracy': 0.9649000000000001}, {'accuracy': 0.96351}, {'accuracy': 0.96348}]\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": "df1f6f77-da98-476a-8d47-a7b1067da8e7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5a4a223-b95a-49d7-82ff-661e6ecc77c4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "782710ff-abf8-46ee-9764-afeabc46ea51",
   "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
}
