{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6034\n",
      "[[  0 544]\n",
      " [  1 653]\n",
      " [  2 611]\n",
      " [  3 625]\n",
      " [  4 574]\n",
      " [  5 576]\n",
      " [  6 567]\n",
      " [  7 556]\n",
      " [  8 588]\n",
      " [  9 601]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 4,  ..., 6, 5, 8])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12358\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 299]\n",
      " [  1 358]\n",
      " [  2 574]\n",
      " [  3 643]\n",
      " [  4 568]\n",
      " [  5 529]\n",
      " [  6 290]\n",
      " [  7 317]\n",
      " [  8 583]\n",
      " [  9 604]]\n",
      "[[   0 1488]\n",
      " [   1  388]\n",
      " [   2  574]\n",
      " [   3  643]\n",
      " [   4  568]\n",
      " [   5  529]\n",
      " [   6  456]\n",
      " [   7  602]\n",
      " [   8  583]\n",
      " [   9  604]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 4,  ..., 7, 7, 7])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        if target1[z]==6:\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(0))\n",
    "        \n",
    "        elif target1[z]==0:\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(6))      \n",
    "        \n",
    "        elif target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(7))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==7:\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(1))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "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:02:18 </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:02:18\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": "bb4db8cec1ec4662a634abacbaef1f5f",
       "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-20:10:51 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3446</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:10:51\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3446\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\">75260640</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;36m75260640\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.10627}, {'accuracy': 0.24328000000000002}, {'accuracy': 0.11071}, {'accuracy': 0.24763000000000002}, {'accuracy': 0.46913}, {'accuracy': 0.28199}, {'accuracy': 0.30417}, {'accuracy': 0.4806}, {'accuracy': 0.44688999999999995}, {'accuracy': 0.37165}, {'accuracy': 0.48077}, {'accuracy': 0.42054}, {'accuracy': 0.37983999999999996}, {'accuracy': 0.48735}, {'accuracy': 0.30562}, {'accuracy': 0.52508}, {'accuracy': 0.54568}, {'accuracy': 0.5485899999999999}, {'accuracy': 0.32273999999999997}, {'accuracy': 0.55855}, {'accuracy': 0.4521}, {'accuracy': 0.30471}, {'accuracy': 0.52159}, {'accuracy': 0.56481}, {'accuracy': 0.36822}, {'accuracy': 0.53281}, {'accuracy': 0.3488}, {'accuracy': 0.2807}, {'accuracy': 0.43734}, {'accuracy': 0.34887000000000007}, {'accuracy': 0.38511}, {'accuracy': 0.49612}, {'accuracy': 0.61747}, {'accuracy': 0.4908}, {'accuracy': 0.4021699999999999}, {'accuracy': 0.46776000000000006}, {'accuracy': 0.7317499999999999}, {'accuracy': 0.47878}, {'accuracy': 0.67527}, {'accuracy': 0.52764}, {'accuracy': 0.58464}, {'accuracy': 0.5521900000000001}, {'accuracy': 0.6307399999999999}, {'accuracy': 0.3766299999999999}, {'accuracy': 0.5749500000000001}, {'accuracy': 0.45753000000000005}, {'accuracy': 0.60058}, {'accuracy': 0.49427000000000004}, {'accuracy': 0.59912}, {'accuracy': 0.35673}, {'accuracy': 0.58247}, {'accuracy': 0.50998}, {'accuracy': 0.47619}, {'accuracy': 0.50085}, {'accuracy': 0.72255}, {'accuracy': 0.5682}, {'accuracy': 0.59444}, {'accuracy': 0.53365}, {'accuracy': 0.5539999999999999}, {'accuracy': 0.6387500000000002}, {'accuracy': 0.5229799999999999}, {'accuracy': 0.72317}, {'accuracy': 0.39857000000000004}, {'accuracy': 0.6762400000000001}, {'accuracy': 0.6465099999999999}, {'accuracy': 0.47498000000000007}, {'accuracy': 0.59455}, {'accuracy': 0.5062}, {'accuracy': 0.5372800000000001}, {'accuracy': 0.5375599999999999}, {'accuracy': 0.5321999999999999}, {'accuracy': 0.4303699999999999}, {'accuracy': 0.53393}, {'accuracy': 0.73177}, {'accuracy': 0.4961399999999999}, {'accuracy': 0.5027999999999999}, {'accuracy': 0.51542}, {'accuracy': 0.65076}, {'accuracy': 0.40088}, {'accuracy': 0.5340499999999999}, {'accuracy': 0.69611}, {'accuracy': 0.45834}, {'accuracy': 0.45444000000000007}, {'accuracy': 0.6554800000000001}, {'accuracy': 0.5031300000000001}, {'accuracy': 0.53629}, {'accuracy': 0.61639}, {'accuracy': 0.5166}, {'accuracy': 0.48206}, {'accuracy': 0.5071899999999999}, {'accuracy': 0.7016899999999999}, {'accuracy': 0.58266}, {'accuracy': 0.3463399999999999}, {'accuracy': 0.64849}, {'accuracy': 0.56555}, {'accuracy': 0.6326700000000001}, {'accuracy': 0.5637}, {'accuracy': 0.52312}, {'accuracy': 0.5405800000000001}, {'accuracy': 0.6681}, {'accuracy': 0.74866}, {'accuracy': 0.61331}, {'accuracy': 0.63184}, {'accuracy': 0.44475}, {'accuracy': 0.47170000000000006}, {'accuracy': 0.5636099999999999}, {'accuracy': 0.63208}, {'accuracy': 0.51958}, {'accuracy': 0.5499200000000001}, {'accuracy': 0.52601}, {'accuracy': 0.3164}, {'accuracy': 0.4728199999999999}, {'accuracy': 0.6299899999999999}, {'accuracy': 0.43998}, {'accuracy': 0.6866599999999999}, {'accuracy': 0.49856}, {'accuracy': 0.63948}, {'accuracy': 0.37162}, {'accuracy': 0.5057699999999999}, {'accuracy': 0.58418}, {'accuracy': 0.55126}, {'accuracy': 0.7383200000000001}, {'accuracy': 0.63163}, {'accuracy': 0.46407}, {'accuracy': 0.42735}, {'accuracy': 0.63129}, {'accuracy': 0.3998}, {'accuracy': 0.5731599999999999}, {'accuracy': 0.4848}, {'accuracy': 0.45628000000000013}, {'accuracy': 0.6072299999999999}, {'accuracy': 0.31233}, {'accuracy': 0.5987}, {'accuracy': 0.56824}, {'accuracy': 0.64563}, {'accuracy': 0.73537}, {'accuracy': 0.6076299999999999}, {'accuracy': 0.6638299999999999}, {'accuracy': 0.7152499999999999}, {'accuracy': 0.48773999999999995}, {'accuracy': 0.64559}, {'accuracy': 0.63605}, {'accuracy': 0.6513500000000001}, {'accuracy': 0.5735100000000001}, {'accuracy': 0.67547}, {'accuracy': 0.6439199999999999}, {'accuracy': 0.69527}, {'accuracy': 0.63918}, {'accuracy': 0.46617999999999993}, {'accuracy': 0.5963900000000001}, {'accuracy': 0.75461}, {'accuracy': 0.75327}, {'accuracy': 0.7533299999999999}, {'accuracy': 0.74194}, {'accuracy': 0.74047}, {'accuracy': 0.74908}, {'accuracy': 0.7373000000000001}, {'accuracy': 0.7470199999999999}, {'accuracy': 0.7499}, {'accuracy': 0.7437199999999999}, {'accuracy': 0.7396400000000001}, {'accuracy': 0.7441899999999999}, {'accuracy': 0.7393599999999999}, {'accuracy': 0.72907}, {'accuracy': 0.7321300000000001}, {'accuracy': 0.7435500000000002}, {'accuracy': 0.7411400000000001}, {'accuracy': 0.73251}, {'accuracy': 0.73803}, {'accuracy': 0.74511}, {'accuracy': 0.7392100000000001}, {'accuracy': 0.74326}, {'accuracy': 0.73992}, {'accuracy': 0.73836}, {'accuracy': 0.7419}, {'accuracy': 0.7373299999999999}, {'accuracy': 0.7300099999999999}, {'accuracy': 0.7423900000000001}, {'accuracy': 0.7363299999999999}, {'accuracy': 0.7425}, {'accuracy': 0.7386199999999999}, {'accuracy': 0.73389}, {'accuracy': 0.7388199999999999}, {'accuracy': 0.7461500000000001}, {'accuracy': 0.7448699999999999}, {'accuracy': 0.7354399999999999}, {'accuracy': 0.7414000000000001}, {'accuracy': 0.73692}, {'accuracy': 0.7446200000000001}, {'accuracy': 0.7444700000000001}, {'accuracy': 0.73756}, {'accuracy': 0.72617}, {'accuracy': 0.7395599999999999}, {'accuracy': 0.7431899999999999}, {'accuracy': 0.74402}, {'accuracy': 0.73651}, {'accuracy': 0.74244}, {'accuracy': 0.7367900000000001}, {'accuracy': 0.73112}, {'accuracy': 0.7391300000000001}, {'accuracy': 0.73714}, {'accuracy': 0.7399999999999999}, {'accuracy': 0.73841}, {'accuracy': 0.73959}, {'accuracy': 0.73601}, {'accuracy': 0.73856}, {'accuracy': 0.7343}, {'accuracy': 0.73593}, {'accuracy': 0.7413699999999999}, {'accuracy': 0.73906}, {'accuracy': 0.7350899999999999}, {'accuracy': 0.7357899999999999}, {'accuracy': 0.7384799999999999}, {'accuracy': 0.7373000000000001}, {'accuracy': 0.73343}, {'accuracy': 0.73173}, {'accuracy': 0.73592}, {'accuracy': 0.7428600000000001}, {'accuracy': 0.7343200000000001}, {'accuracy': 0.7376}, {'accuracy': 0.73408}, {'accuracy': 0.73846}, {'accuracy': 0.73885}, {'accuracy': 0.7359800000000001}, {'accuracy': 0.7356100000000001}, {'accuracy': 0.7446699999999999}, {'accuracy': 0.7355400000000001}, {'accuracy': 0.73132}, {'accuracy': 0.7380099999999999}, {'accuracy': 0.73522}, {'accuracy': 0.73364}, {'accuracy': 0.73564}, {'accuracy': 0.7401199999999999}, {'accuracy': 0.73644}, {'accuracy': 0.74077}, {'accuracy': 0.7423}, {'accuracy': 0.73952}, {'accuracy': 0.7389600000000002}, {'accuracy': 0.7391300000000001}, {'accuracy': 0.7382900000000001}, {'accuracy': 0.7323799999999999}, {'accuracy': 0.73379}, {'accuracy': 0.7389699999999999}, {'accuracy': 0.73736}, {'accuracy': 0.73921}, {'accuracy': 0.72683}, {'accuracy': 0.7398499999999999}, {'accuracy': 0.73572}, {'accuracy': 0.74129}, {'accuracy': 0.7435799999999999}, {'accuracy': 0.73713}, {'accuracy': 0.72615}, {'accuracy': 0.7314799999999999}, {'accuracy': 0.7442500000000001}, {'accuracy': 0.74442}, {'accuracy': 0.73652}, {'accuracy': 0.74091}, {'accuracy': 0.73488}, {'accuracy': 0.74225}, {'accuracy': 0.73097}, {'accuracy': 0.7374299999999999}, {'accuracy': 0.74319}, {'accuracy': 0.73321}, {'accuracy': 0.7375}, {'accuracy': 0.7301599999999999}, {'accuracy': 0.74135}, {'accuracy': 0.7365900000000001}, {'accuracy': 0.73992}, {'accuracy': 0.74121}, {'accuracy': 0.73686}, {'accuracy': 0.7332699999999999}, {'accuracy': 0.73262}, {'accuracy': 0.7330000000000001}, {'accuracy': 0.7383599999999999}, {'accuracy': 0.73625}, {'accuracy': 0.7315799999999999}, {'accuracy': 0.73617}, {'accuracy': 0.73608}, {'accuracy': 0.74231}, {'accuracy': 0.73493}, {'accuracy': 0.7429}, {'accuracy': 0.7399000000000001}, {'accuracy': 0.7264100000000001}, {'accuracy': 0.7364499999999999}, {'accuracy': 0.72674}, {'accuracy': 0.7345599999999999}, {'accuracy': 0.7381399999999999}, {'accuracy': 0.74291}, {'accuracy': 0.7379300000000001}, {'accuracy': 0.73844}, {'accuracy': 0.73897}, {'accuracy': 0.73939}, {'accuracy': 0.7343499999999998}, {'accuracy': 0.7343500000000001}, {'accuracy': 0.72849}, {'accuracy': 0.74677}, {'accuracy': 0.73785}, {'accuracy': 0.7328399999999999}, {'accuracy': 0.73573}, {'accuracy': 0.7378199999999999}]\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.0\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": "b4c996a8-d2c0-4eec-aa34-c819bf0bba92",
   "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.74</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.74\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACz+ElEQVR4nOydd5gUVdbG36pOkwMMM8AQhqxIEhBERRAQzFmRVUFU1oRhUXfhcwVd18Us7ppZc4KVNa0BxBFMJCVIkJzTDAPDMLlT1fdH962+lbqrZzrAzPk9D4893RVuVbd9T7/nPecKsizLIAiCIAiCaCKIyR4AQRAEQRBELKHghiAIgiCIJgUFNwRBEARBNCkouCEIgiAIoklBwQ1BEARBEE0KCm4IgiAIgmhSUHBDEARBEESTgoIbgiAIgiCaFBTcEARBEATRpKDghiCIuLJ48WIIgoDFixcrz914440oKipK2piaEg8//DAEQUj2MAjiuIKCG4I4ztmwYQOuv/56FBYWwuVyoW3btrjuuuuwYcOGZA8t7rz00kt466234nqO33//HQ8//DB27doV1/Mkkn/84x/49NNPkz0MgkgaFNwQxHHMxx9/jP79+6O4uBgTJ07ESy+9hJtvvhmLFi1C//798cknnyR7iHElUcHNI488QsENQTQh7MkeAEEQxmzfvh033HADOnfujB9++AGtWrVSXrvnnnswdOhQ3HDDDVi7di06d+6csHHV1NQgPT09Yec7EaB7QhDHF6TcEMRxylNPPYXa2lq89tprqsAGAPLy8vDqq6+ipqYGTz75JABg3rx5EAQB33//ve5Yr776KgRBwPr165XnNm3ahKuuugotWrRASkoKBg4ciM8//1y131tvvaUc84477kB+fj7atWsHANi9ezfuuOMO9OjRA6mpqWjZsiWuvvrqmCkgRUVF2LBhA77//nsIggBBEDB8+HDl9YqKCtx7771o3749XC4XunbtiieeeAKSJKmOM2fOHAwYMACZmZnIyspC79698fzzzyvXd/XVVwMAzjnnHOU8vD9Iy4033oiMjAxs374dF1xwATIzM3HdddcBACRJwqxZs3DKKacgJSUFBQUFuPXWW3H06FHVMX799VeMGTMGeXl5SE1NRadOnXDTTTcprxv5lABg165dEAQhrJolCAJqamrw9ttvK9dz4403AgCqqqpw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8Y8ePaq7b/369VONqWPHjrDZbIp3iPHSSy9ZGovRffP7/bp0YX5+Ptq2bZuQlBhBJBJSbgjiOKVbt254++23cd1116F37964+eab0alTJ+zatQuvv/46Dh8+jA8//FAp82U4HA5cccUVmDNnDmpqavD000/rjv3iiy/irLPOQu/evTFp0iR07twZpaWlWLp0Kfbt24fffvst4vguuugivPvuu8jOzkbPnj2xdOlSfPvtt2jZsmXM7sGAAQPw8ssv4+9//zu6du2K/Px8jBgxAg888AA+//xzXHTRRbjxxhsxYMAA1NTUYN26dZg3bx527dqFvLw83HLLLSgvL8eIESPQrl077N69G//617/Qr18/pdy7X79+sNlseOKJJ3Ds2DG4XC6MGDEC+fn5UY112LBhuPXWWzFz5kysWbMGo0ePhsPhwNatW/HRRx/h+eefx1VXXYW3334bL730Ei6//HJ06dIFVVVVmD17NrKysnDBBRcACKQlr776avzrX/+CIAjo0qULvvjiC50XKtx9+/bbb/Hss8+ibdu26NSpE3r06IF27drhqquuQt++fZGRkYFvv/0Wv/zyi0p9I4gmQXKLtQiCiMTatWvlcePGyW3atJEdDofcunVredy4cfK6detM91m4cKEMQBYEQd67d6/hNtu3b5fHjx8vt27dWnY4HHJhYaF80UUXyfPmzVO2YaXgRmXLR48elSdOnCjn5eXJGRkZ8pgxY+RNmzbJHTt2VJUhN6YUvKSkRL7wwgvlzMxMGYCqLLyqqkqeNm2a3LVrV9npdMp5eXnyGWecIT/99NOyx+ORZVmW582bJ48ePVrOz8+XnU6n3KFDB/nWW2+VDx48qDrP7Nmz5c6dO8s2my1iWfiECRPk9PR009dfe+01ecCAAXJqaqqcmZkp9+7dW/7zn/8sHzhwQJZlWV61apU8btw4uUOHDrLL5ZLz8/Pliy66SP71119VxykrK5OvvPJKOS0tTc7NzZVvvfVWef369ZZKwTdt2iSfffbZcmpqqgxAnjBhgux2u+UHHnhA7tu3r5yZmSmnp6fLffv2lV966aVwbwFBnJAIsqzRRwmCIAiCIE5gyHNDEARBEESTgoIbgiAIgiCaFBTcEARBEATRpKDghiAIgiCIJgUFNwRBEARBNCkouCEIgiAIoknR7Jr4SZKEAwcOIDMzM2Zt1wmC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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.10627}, {'accuracy': 0.24328000000000002}, {'accuracy': 0.11071}, {'accuracy': 0.24763000000000002}, {'accuracy': 0.46913}, {'accuracy': 0.28199}, {'accuracy': 0.30417}, {'accuracy': 0.4806}, {'accuracy': 0.44688999999999995}, {'accuracy': 0.37165}, {'accuracy': 0.48077}, {'accuracy': 0.42054}, {'accuracy': 0.37983999999999996}, {'accuracy': 0.48735}, {'accuracy': 0.30562}, {'accuracy': 0.52508}, {'accuracy': 0.54568}, {'accuracy': 0.5485899999999999}, {'accuracy': 0.32273999999999997}, {'accuracy': 0.55855}, {'accuracy': 0.4521}, {'accuracy': 0.30471}, {'accuracy': 0.52159}, {'accuracy': 0.56481}, {'accuracy': 0.36822}, {'accuracy': 0.53281}, {'accuracy': 0.3488}, {'accuracy': 0.2807}, {'accuracy': 0.43734}, {'accuracy': 0.34887000000000007}, {'accuracy': 0.38511}, {'accuracy': 0.49612}, {'accuracy': 0.61747}, {'accuracy': 0.4908}, {'accuracy': 0.4021699999999999}, {'accuracy': 0.46776000000000006}, {'accuracy': 0.7317499999999999}, {'accuracy': 0.47878}, {'accuracy': 0.67527}, {'accuracy': 0.52764}, {'accuracy': 0.58464}, {'accuracy': 0.5521900000000001}, {'accuracy': 0.6307399999999999}, {'accuracy': 0.3766299999999999}, {'accuracy': 0.5749500000000001}, {'accuracy': 0.45753000000000005}, {'accuracy': 0.60058}, {'accuracy': 0.49427000000000004}, {'accuracy': 0.59912}, {'accuracy': 0.35673}, {'accuracy': 0.58247}, {'accuracy': 0.50998}, {'accuracy': 0.47619}, {'accuracy': 0.50085}, {'accuracy': 0.72255}, {'accuracy': 0.5682}, {'accuracy': 0.59444}, {'accuracy': 0.53365}, {'accuracy': 0.5539999999999999}, {'accuracy': 0.6387500000000002}, {'accuracy': 0.5229799999999999}, {'accuracy': 0.72317}, {'accuracy': 0.39857000000000004}, {'accuracy': 0.6762400000000001}, {'accuracy': 0.6465099999999999}, {'accuracy': 0.47498000000000007}, {'accuracy': 0.59455}, {'accuracy': 0.5062}, {'accuracy': 0.5372800000000001}, {'accuracy': 0.5375599999999999}, {'accuracy': 0.5321999999999999}, {'accuracy': 0.4303699999999999}, {'accuracy': 0.53393}, {'accuracy': 0.73177}, {'accuracy': 0.4961399999999999}, {'accuracy': 0.5027999999999999}, {'accuracy': 0.51542}, {'accuracy': 0.65076}, {'accuracy': 0.40088}, {'accuracy': 0.5340499999999999}, {'accuracy': 0.69611}, {'accuracy': 0.45834}, {'accuracy': 0.45444000000000007}, {'accuracy': 0.6554800000000001}, {'accuracy': 0.5031300000000001}, {'accuracy': 0.53629}, {'accuracy': 0.61639}, {'accuracy': 0.5166}, {'accuracy': 0.48206}, {'accuracy': 0.5071899999999999}, {'accuracy': 0.7016899999999999}, {'accuracy': 0.58266}, {'accuracy': 0.3463399999999999}, {'accuracy': 0.64849}, {'accuracy': 0.56555}, {'accuracy': 0.6326700000000001}, {'accuracy': 0.5637}, {'accuracy': 0.52312}, {'accuracy': 0.5405800000000001}, {'accuracy': 0.6681}, {'accuracy': 0.74866}, {'accuracy': 0.61331}, {'accuracy': 0.63184}, {'accuracy': 0.44475}, {'accuracy': 0.47170000000000006}, {'accuracy': 0.5636099999999999}, {'accuracy': 0.63208}, {'accuracy': 0.51958}, {'accuracy': 0.5499200000000001}, {'accuracy': 0.52601}, {'accuracy': 0.3164}, {'accuracy': 0.4728199999999999}, {'accuracy': 0.6299899999999999}, {'accuracy': 0.43998}, {'accuracy': 0.6866599999999999}, {'accuracy': 0.49856}, {'accuracy': 0.63948}, {'accuracy': 0.37162}, {'accuracy': 0.5057699999999999}, {'accuracy': 0.58418}, {'accuracy': 0.55126}, {'accuracy': 0.7383200000000001}, {'accuracy': 0.63163}, {'accuracy': 0.46407}, {'accuracy': 0.42735}, {'accuracy': 0.63129}, {'accuracy': 0.3998}, {'accuracy': 0.5731599999999999}, {'accuracy': 0.4848}, {'accuracy': 0.45628000000000013}, {'accuracy': 0.6072299999999999}, {'accuracy': 0.31233}, {'accuracy': 0.5987}, {'accuracy': 0.56824}, {'accuracy': 0.64563}, {'accuracy': 0.73537}, {'accuracy': 0.6076299999999999}, {'accuracy': 0.6638299999999999}, {'accuracy': 0.7152499999999999}, {'accuracy': 0.48773999999999995}, {'accuracy': 0.64559}, {'accuracy': 0.63605}, {'accuracy': 0.6513500000000001}, {'accuracy': 0.5735100000000001}, {'accuracy': 0.67547}, {'accuracy': 0.6439199999999999}, {'accuracy': 0.69527}, {'accuracy': 0.63918}, {'accuracy': 0.46617999999999993}, {'accuracy': 0.5963900000000001}, {'accuracy': 0.75461}, {'accuracy': 0.75327}, {'accuracy': 0.7533299999999999}, {'accuracy': 0.74194}, {'accuracy': 0.74047}, {'accuracy': 0.74908}, {'accuracy': 0.7373000000000001}, {'accuracy': 0.7470199999999999}, {'accuracy': 0.7499}, {'accuracy': 0.7437199999999999}, {'accuracy': 0.7396400000000001}, {'accuracy': 0.7441899999999999}, {'accuracy': 0.7393599999999999}, {'accuracy': 0.72907}, {'accuracy': 0.7321300000000001}, {'accuracy': 0.7435500000000002}, {'accuracy': 0.7411400000000001}, {'accuracy': 0.73251}, {'accuracy': 0.73803}, {'accuracy': 0.74511}, {'accuracy': 0.7392100000000001}, {'accuracy': 0.74326}, {'accuracy': 0.73992}, {'accuracy': 0.73836}, {'accuracy': 0.7419}, {'accuracy': 0.7373299999999999}, {'accuracy': 0.7300099999999999}, {'accuracy': 0.7423900000000001}, {'accuracy': 0.7363299999999999}, {'accuracy': 0.7425}, {'accuracy': 0.7386199999999999}, {'accuracy': 0.73389}, {'accuracy': 0.7388199999999999}, {'accuracy': 0.7461500000000001}, {'accuracy': 0.7448699999999999}, {'accuracy': 0.7354399999999999}, {'accuracy': 0.7414000000000001}, {'accuracy': 0.73692}, {'accuracy': 0.7446200000000001}, {'accuracy': 0.7444700000000001}, {'accuracy': 0.73756}, {'accuracy': 0.72617}, {'accuracy': 0.7395599999999999}, {'accuracy': 0.7431899999999999}, {'accuracy': 0.74402}, {'accuracy': 0.73651}, {'accuracy': 0.74244}, {'accuracy': 0.7367900000000001}, {'accuracy': 0.73112}, {'accuracy': 0.7391300000000001}, {'accuracy': 0.73714}, {'accuracy': 0.7399999999999999}, {'accuracy': 0.73841}, {'accuracy': 0.73959}, {'accuracy': 0.73601}, {'accuracy': 0.73856}, {'accuracy': 0.7343}, {'accuracy': 0.73593}, {'accuracy': 0.7413699999999999}, {'accuracy': 0.73906}, {'accuracy': 0.7350899999999999}, {'accuracy': 0.7357899999999999}, {'accuracy': 0.7384799999999999}, {'accuracy': 0.7373000000000001}, {'accuracy': 0.73343}, {'accuracy': 0.73173}, {'accuracy': 0.73592}, {'accuracy': 0.7428600000000001}, {'accuracy': 0.7343200000000001}, {'accuracy': 0.7376}, {'accuracy': 0.73408}, {'accuracy': 0.73846}, {'accuracy': 0.73885}, {'accuracy': 0.7359800000000001}, {'accuracy': 0.7356100000000001}, {'accuracy': 0.7446699999999999}, {'accuracy': 0.7355400000000001}, {'accuracy': 0.73132}, {'accuracy': 0.7380099999999999}, {'accuracy': 0.73522}, {'accuracy': 0.73364}, {'accuracy': 0.73564}, {'accuracy': 0.7401199999999999}, {'accuracy': 0.73644}, {'accuracy': 0.74077}, {'accuracy': 0.7423}, {'accuracy': 0.73952}, {'accuracy': 0.7389600000000002}, {'accuracy': 0.7391300000000001}, {'accuracy': 0.7382900000000001}, {'accuracy': 0.7323799999999999}, {'accuracy': 0.73379}, {'accuracy': 0.7389699999999999}, {'accuracy': 0.73736}, {'accuracy': 0.73921}, {'accuracy': 0.72683}, {'accuracy': 0.7398499999999999}, {'accuracy': 0.73572}, {'accuracy': 0.74129}, {'accuracy': 0.7435799999999999}, {'accuracy': 0.73713}, {'accuracy': 0.72615}, {'accuracy': 0.7314799999999999}, {'accuracy': 0.7442500000000001}, {'accuracy': 0.74442}, {'accuracy': 0.73652}, {'accuracy': 0.74091}, {'accuracy': 0.73488}, {'accuracy': 0.74225}, {'accuracy': 0.73097}, {'accuracy': 0.7374299999999999}, {'accuracy': 0.74319}, {'accuracy': 0.73321}, {'accuracy': 0.7375}, {'accuracy': 0.7301599999999999}, {'accuracy': 0.74135}, {'accuracy': 0.7365900000000001}, {'accuracy': 0.73992}, {'accuracy': 0.74121}, {'accuracy': 0.73686}, {'accuracy': 0.7332699999999999}, {'accuracy': 0.73262}, {'accuracy': 0.7330000000000001}, {'accuracy': 0.7383599999999999}, {'accuracy': 0.73625}, {'accuracy': 0.7315799999999999}, {'accuracy': 0.73617}, {'accuracy': 0.73608}, {'accuracy': 0.74231}, {'accuracy': 0.73493}, {'accuracy': 0.7429}, {'accuracy': 0.7399000000000001}, {'accuracy': 0.7264100000000001}, {'accuracy': 0.7364499999999999}, {'accuracy': 0.72674}, {'accuracy': 0.7345599999999999}, {'accuracy': 0.7381399999999999}, {'accuracy': 0.74291}, {'accuracy': 0.7379300000000001}, {'accuracy': 0.73844}, {'accuracy': 0.73897}, {'accuracy': 0.73939}, {'accuracy': 0.7343499999999998}, {'accuracy': 0.7343500000000001}, {'accuracy': 0.72849}, {'accuracy': 0.74677}, {'accuracy': 0.73785}, {'accuracy': 0.7328399999999999}, {'accuracy': 0.73573}, {'accuracy': 0.7378199999999999}]\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecbbe105-9bf7-445c-98fa-8978922c9d1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ef2d273-250d-450a-a662-a7b72def491b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90e437aa-9da1-4ab9-9e45-ba89e95f207a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb4baa5-ba6c-4102-91e4-111c3b0b5fa2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b1dc97-431b-4a8f-ba04-61d4c3cc6abd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8986be3-03f4-4ebc-bfd3-794fbef7f9ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcd47ac2-d80f-4e13-9b76-d03483431081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc113a2c-dfd9-4dae-a973-ba5925b4f9bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6ac9abe-848f-49c2-9fc8-c94e75015695",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22f6eba1-7059-491f-bacd-0739425d9305",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d98f7ea7-9936-4a3b-8585-ecfc1913085e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "746d526e-8881-4cb2-b68d-452746c6d54d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e9bfaa0-a5ba-4db8-851e-1f2542180865",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "56388e1c-c114-4a01-aaac-3adf8b5dce5f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e37d62c-409e-4447-80cd-d6ac411b0a95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2356e789-01f7-40ba-9093-73f255ddc460",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10f98fcf-6f37-469b-8eb0-0a6b6ae018c0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c41187c7-275e-48b1-9030-ac8f9808763d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3567da34-9ccc-4a1a-8abe-cfdf77df1b78",
   "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
}
