{
 "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",
      "6006\n",
      "[[  0 600]\n",
      " [  1 672]\n",
      " [  2 575]\n",
      " [  3 620]\n",
      " [  4 560]\n",
      " [  5 573]\n",
      " [  6 585]\n",
      " [  7 602]\n",
      " [  8 597]\n",
      " [  9 614]]\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([8, 9, 2,  ..., 1, 6, 6])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2e298a2b-4e21-45da-ac3e-abe3a04ae797",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        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",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7409\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 403]\n",
      " [  1 436]\n",
      " [  2 645]\n",
      " [  3 612]\n",
      " [  4 573]\n",
      " [  5 550]\n",
      " [  6 434]\n",
      " [  7 449]\n",
      " [  8 569]\n",
      " [  9 589]]\n",
      "[[   0 1130]\n",
      " [   1  456]\n",
      " [   2  645]\n",
      " [   3  612]\n",
      " [   4  573]\n",
      " [   5  550]\n",
      " [   6  528]\n",
      " [   7  622]\n",
      " [   8  569]\n",
      " [   9  589]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([8, 9, 2,  ..., 7, 7, 7])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:50:26 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:50:26\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "16e2a4e99d4b439abb1e7b3ae697b4f8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:30:39 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3282</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:30:39\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3282\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\">71678880</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;36m71678880\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:30:40 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.90</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:30:40\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.90\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACtIUlEQVR4nO2dd5gUVdbG36qOk4dhIsOQMZAFhEXBAAjmrIiuoK6uiVUXI6vCuq5iXnXN7po+E+qaA4gIqIAJRIIgOc8AMzA5dKj6/ui+VbdSh5nu6aH7/J6Hx5nqCreq27lvn/OecwVZlmUQBEEQBEEkCWKiB0AQBEEQBBFLSNwQBEEQBJFUkLghCIIgCCKpIHFDEARBEERSQeKGIAiCIIikgsQNQRAEQRBJBYkbgiAIgiCSChI3BEEQBEEkFSRuCIIgCIJIKkjcEAQRVxYtWgRBELBo0SJl22WXXYYePXokbEzJxN///ncIgpDoYRBEh4LEDUF0cNauXYs//vGPKC0thcvlQpcuXXDJJZdg7dq1iR5a3HnmmWfwyiuvxPUav/32G/7+979j27Ztcb1Oe3L//ffjww8/TPQwCCJhkLghiA7M+++/j6FDh2LBggW4/PLL8cwzz+BPf/oTFi5ciKFDh+KDDz5I9BDjSnuJm3vuuYfEDUEkEfZED4AgCHM2b96MSy+9FL169cI333yDgoIC5bUbb7wRY8aMwaWXXopVq1ahV69e7TauhoYGZGRktNv1DgXomRBEx4IiNwTRQXn44YfR2NiIF154QSNsACA/Px/PP/88Ghoa8NBDDwEA3nvvPQiCgMWLFxvO9fzzz0MQBKxZs0bZtn79epx//vnIy8uD2+3G8OHD8fHHH2uOe+WVV5RzXnfddSgsLETXrl0BANu3b8d1112Hww8/HGlpaejcuTMuuOCCmEVAevTogbVr12Lx4sUQBAGCIOCEE05QXq+ursZNN92EsrIyuFwu9OnTBw8++CAkSdKc5+2338awYcOQlZWF7OxsDBw4EE888YRyfxdccAEA4MQTT1Suw/uD9Fx22WXIzMzE5s2bceqppyIrKwuXXHIJAECSJDz++OPo378/3G43ioqKcPXVV+PgwYOac/z888+YOHEi8vPzkZaWhp49e+KKK65QXjfzKQHAtm3bIAhCyGiWIAhoaGjAq6++qtzPZZddBgCoq6vDTTfdhB49esDlcqGwsBAnnXQSVqxYYXk+gjgUocgNQXRQPvnkE/To0QNjxowxff24445Djx498NlnnwEATjvtNGRmZuKdd97B8ccfr9l3zpw56N+/PwYMGAAg4OM59thjUVpaijvuuAMZGRl45513cPbZZ+N///sfzjnnHM3x1113HQoKCjBz5kw0NDQAAH766ScsXboUF110Ebp27Ypt27bh2WefxQknnIDffvsN6enpbbr/xx9/HH/5y1+QmZmJO++8EwBQVFQEAGhsbMTxxx+P3bt34+qrr0a3bt2wdOlSzJgxA+Xl5Xj88ccBAPPnz8fkyZMxbtw4PPjggwCAdevWYcmSJbjxxhtx3HHH4YYbbsCTTz6Jv/3tbzjyyCMBQPmvFT6fDxMnTsTo0aPxyCOPKPd69dVX45VXXsHll1+OG264AVu3bsVTTz2FX375BUuWLIHD4cC+ffswYcIEFBQU4I477kBubi62bduG999/v03Pi/F///d/uPLKKzFixAj8+c9/BgD07t0bAHDNNdfgvffew7Rp09CvXz9UVVXhu+++w7p16zB06NCYXJ8gOgQyQRAdjurqahmAfNZZZ4Xc78wzz5QByLW1tbIsy/LkyZPlwsJC2efzKfuUl5fLoijK//jHP5Rt48aNkwcOHCg3Nzcr2yRJko855hi5b9++yraXX35ZBiCPHj1ac05ZluXGxkbDeJYtWyYDkF977TVl28KFC2UA8sKFC5VtU6dOlbt37x7y3mRZlvv37y8ff/zxhu333nuvnJGRIW/YsEGz/Y477pBtNpu8Y8cOWZZl+cYbb5Szs7MNY+d59913DeMLxdSpU2UA8h133KHZ/u2338oA5DfeeEOzfe7cuZrtH3zwgQxA/umnnyyvYfbMZFmWt27dKgOQX375ZWXbrFmzZP2f8oyMDHnq1KmG8+bk5MjXX399BHdJEIc2lJYiiA5IXV0dACArKyvkfuz12tpaAMCkSZOwb98+TTrjvffegyRJmDRpEgDgwIED+Prrr3HhhReirq4OlZWVqKysRFVVFSZOnIiNGzdi9+7dmutcddVVsNlsmm1paWnKz16vF1VVVejTpw9yc3PjnuZ49913MWbMGHTq1EkZf2VlJcaPHw+/349vvvkGAJCbm4uGhgbMnz8/5mO49tprDWPKycnBSSedpBnTsGHDkJmZiYULFypjAoBPP/0UXq835uMKRW5uLn744Qfs2bOnXa9LEO0NiRuC6IAw0cJEjhV6EXTyyScjJycHc+bMUfaZM2cOhgwZgsMOOwwAsGnTJsiyjLvvvhsFBQWaf7NmzQIA7Nu3T3Odnj17Gq7d1NSEmTNnKp6X/Px8FBQUoLq6GjU1Na2888jYuHEj5s6daxj/+PHjNeO/7rrrcNhhh+GUU05B165dccUVV2Du3Lltvr7dble8R/yYampqUFhYaBhXfX29Mqbjjz8e5513Hu655x7k5+fjrLPOwssvv4yWlpY2jyscDz30ENasWYOysjKMGDECf//737Fly5a4X5cg2hvy3BBEByQnJwclJSVYtWpVyP1WrVqF0tJSZGdnAwBcLhfOPvtsfPDBB3jmmWewd+9eLFmyBPfff79yDDPc3nLLLZg4caLpefv06aP5nY/SMP7yl7/g5Zdfxk033YRRo0YhJycHgiDgoosuMph6Y40kSTjppJNw2223mb7OhFxhYSFWrlyJefPm4YsvvsAXX3yBl19+GVOmTMGrr77a6uu7XC6Iova7oSRJKCwsxBtvvGF6DDOFC4KA9957D99//z0++eQTzJs3D1dccQUeffRRfP/998jMzLRsyuf3+1s9ZgC48MILMWbMGHzwwQf48ssv8fDDD+PBBx/E+++/j1NOOaVN5yaIjgSJG4LooJx++ul48cUX8d1332H06NGG17/99lts27YNV199tWb7pEmT8Oqrr2LBggVYt24dZFlWUlIAlLJxh8OhRDpaw3vvvYepU6fi0UcfVbY1Nzejurq61efUYzXJ9+7dG/X19RGN3+l04owzzsAZZ5wBSZJw3XXX4fnnn8fdd9+NPn36xKy7b+/evfHVV1/h2GOPNRWDev7whz/gD3/4A+677z68+eabuOSSS/D222/jyiuvRKdOnQDA8Cy3b98e0VhC3VNJSQmuu+46XHfdddi3bx+GDh2K++67j8QNkVRQWoogOii33nor0tLScPXVV6Oqqkrz2oEDB3DNNdcgPT0dt956q+a18ePHIy8vD3PmzMGcOXMwYsQITVqpsLAQJ5xwAp5//nmUl5cbrrt///6Ixmez2SDLsmbbv//97zZHF3gyMjJMxdKFF16IZcuWYd68eYbXqqur4fP5AMDw3ERRxKBBgwBASQOx/jRtFWUXXngh/H4/7r33XsNrPp9POf/BgwcNz23IkCGaMXXv3h02m03xDjGeeeaZiMZi9tz8fr8hXVhYWIguXbq0S0qMINoTitwQRAelb9++ePXVV3HJJZdg4MCB+NOf/oSePXti27Zt+O9//4vKykq89dZbSpkvw+Fw4Nxzz8Xbb7+NhoYGPPLII4ZzP/300xg9ejQGDhyIq666Cr169cLevXuxbNky7Nq1C7/++mvY8Z1++un4v//7P+Tk5KBfv35YtmwZvvrqK3Tu3Dlmz2DYsGF49tln8c9//hN9+vRBYWEhxo4di1tvvRUff/wxTj/9dFx22WUYNmwYGhoasHr1arz33nvYtm0b8vPzceWVV+LAgQMYO3Ysunbtiu3bt+Pf//43hgwZopR7DxkyBDabDQ8++CBqamrgcrkwduxYFBYWRjXW448/HldffTVmz56NlStXYsKECXA4HNi4cSPeffddPPHEEzj//PPx6quv4plnnsE555yD3r17o66uDi+++CKys7Nx6qmnAgikJS+44AL8+9//hiAI6N27Nz799FODFyrUc/vqq6/w2GOPoUuXLujZsycOP/xwdO3aFeeffz4GDx6MzMxMfPXVV/jpp5800TeCSAoSW6xFEEQ4Vq1aJU+ePFkuKSmRHQ6HXFxcLE+ePFlevXq15THz58+XAciCIMg7d+403Wfz5s3ylClT5OLiYtnhcMilpaXy6aefLr/33nvKPqwU3Kxs+eDBg/Lll18u5+fny5mZmfLEiRPl9evXy927d9eUIbelFLyiokI+7bTT5KysLBmApiy8rq5OnjFjhtynTx/Z6XTK+fn58jHHHCM/8sgjssfjkWVZlt977z15woQJcmFhoex0OuVu3brJV199tVxeXq65zosvvij36tVLttlsYcvCp06dKmdkZFi+/sILL8jDhg2T09LS5KysLHngwIHybbfdJu/Zs0eWZVlesWKFPHnyZLlbt26yy+WSCwsL5dNPP13++eefNefZv3+/fN5558np6elyp06d5Kuvvlpes2ZNRKXg69evl4877jg5LS1NBiBPnTpVbmlpkW+99VZ58ODBclZWlpyRkSEPHjxYfuaZZ0K9BQRxSCLIsi4+ShAEQRAEcQhDnhuCIAiCIJIKEjcEQRAEQSQVJG4IgiAIgkgqSNwQBEEQBJFUkLghCIIgCCKpIHFDEARBEERSkXJN/CRJwp49e5CVlRWztusE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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10807}, {'accuracy': 0.15896}, {'accuracy': 0.19057}, {'accuracy': 0.24752000000000002}, {'accuracy': 0.46735000000000004}, {'accuracy': 0.30308999999999997}, {'accuracy': 0.39554000000000006}, {'accuracy': 0.38062}, {'accuracy': 0.43872999999999995}, {'accuracy': 0.58359}, {'accuracy': 0.5176299999999999}, {'accuracy': 0.5510300000000001}, {'accuracy': 0.44348}, {'accuracy': 0.60728}, {'accuracy': 0.43061999999999995}, {'accuracy': 0.44014}, {'accuracy': 0.50029}, {'accuracy': 0.67193}, {'accuracy': 0.69075}, {'accuracy': 0.58114}, {'accuracy': 0.51368}, {'accuracy': 0.7310199999999999}, {'accuracy': 0.6326200000000001}, {'accuracy': 0.48412}, {'accuracy': 0.6698299999999999}, {'accuracy': 0.40232999999999997}, {'accuracy': 0.58413}, {'accuracy': 0.66827}, {'accuracy': 0.76927}, {'accuracy': 0.70577}, {'accuracy': 0.6402500000000001}, {'accuracy': 0.6381399999999999}, {'accuracy': 0.40861000000000003}, {'accuracy': 0.52766}, {'accuracy': 0.6361500000000001}, {'accuracy': 0.6566}, {'accuracy': 0.58649}, {'accuracy': 0.64524}, {'accuracy': 0.7004100000000001}, {'accuracy': 0.73111}, {'accuracy': 0.65874}, {'accuracy': 0.7224999999999999}, {'accuracy': 0.70851}, {'accuracy': 0.7470000000000001}, {'accuracy': 0.59306}, {'accuracy': 0.5726500000000001}, {'accuracy': 0.7547}, {'accuracy': 0.7500600000000001}, {'accuracy': 0.6613499999999999}, {'accuracy': 0.65717}, {'accuracy': 0.71563}, {'accuracy': 0.40780000000000005}, {'accuracy': 0.6382699999999999}, {'accuracy': 0.6677899999999999}, {'accuracy': 0.7415700000000001}, {'accuracy': 0.45145}, {'accuracy': 0.59533}, {'accuracy': 0.62729}, {'accuracy': 0.7876399999999999}, {'accuracy': 0.49361}, {'accuracy': 0.70259}, {'accuracy': 0.63539}, {'accuracy': 0.66743}, {'accuracy': 0.7333999999999999}, {'accuracy': 0.6851799999999999}, {'accuracy': 0.43152}, {'accuracy': 0.53368}, {'accuracy': 0.58378}, {'accuracy': 0.52403}, {'accuracy': 0.4960800000000001}, {'accuracy': 0.45957}, {'accuracy': 0.77648}, {'accuracy': 0.78572}, {'accuracy': 0.70982}, {'accuracy': 0.7805099999999999}, {'accuracy': 0.69689}, {'accuracy': 0.65948}, {'accuracy': 0.8275}, {'accuracy': 0.48692}, {'accuracy': 0.58703}, {'accuracy': 0.65064}, {'accuracy': 0.5520200000000001}, {'accuracy': 0.8190199999999999}, {'accuracy': 0.68433}, {'accuracy': 0.6290899999999999}, {'accuracy': 0.7885500000000001}, {'accuracy': 0.77227}, {'accuracy': 0.62963}, {'accuracy': 0.6912499999999999}, {'accuracy': 0.89272}, {'accuracy': 0.69151}, {'accuracy': 0.7320499999999999}, {'accuracy': 0.48796}, {'accuracy': 0.77526}, {'accuracy': 0.6810600000000001}, {'accuracy': 0.8479099999999999}, {'accuracy': 0.56126}, {'accuracy': 0.69146}, {'accuracy': 0.75998}, {'accuracy': 0.5959300000000001}, {'accuracy': 0.78163}, {'accuracy': 0.6501699999999999}, {'accuracy': 0.71874}, {'accuracy': 0.60329}, {'accuracy': 0.7886899999999999}, {'accuracy': 0.69443}, {'accuracy': 0.64725}, {'accuracy': 0.7016100000000001}, {'accuracy': 0.69844}, {'accuracy': 0.7969100000000001}, {'accuracy': 0.55305}, {'accuracy': 0.7158899999999999}, {'accuracy': 0.52217}, {'accuracy': 0.61837}, {'accuracy': 0.70111}, {'accuracy': 0.41273}, {'accuracy': 0.6457499999999999}, {'accuracy': 0.6690000000000002}, {'accuracy': 0.47928}, {'accuracy': 0.61333}, {'accuracy': 0.68956}, {'accuracy': 0.74648}, {'accuracy': 0.49477000000000004}, {'accuracy': 0.46283}, {'accuracy': 0.7029500000000001}, {'accuracy': 0.6842499999999999}, {'accuracy': 0.68636}, {'accuracy': 0.7489899999999999}, {'accuracy': 0.43492999999999993}, {'accuracy': 0.5521900000000001}, {'accuracy': 0.8374}, {'accuracy': 0.64774}, {'accuracy': 0.48861}, {'accuracy': 0.70976}, {'accuracy': 0.80146}, {'accuracy': 0.5374099999999999}, {'accuracy': 0.7448699999999999}, {'accuracy': 0.64228}, {'accuracy': 0.80633}, {'accuracy': 0.48416}, {'accuracy': 0.84672}, {'accuracy': 0.87783}, {'accuracy': 0.71648}, {'accuracy': 0.77186}, {'accuracy': 0.7874399999999999}, {'accuracy': 0.77125}, {'accuracy': 0.76507}, {'accuracy': 0.7362299999999999}, {'accuracy': 0.73551}, {'accuracy': 0.58517}, {'accuracy': 0.35536}, {'accuracy': 0.8893800000000001}, {'accuracy': 0.72884}, {'accuracy': 0.8157500000000001}, {'accuracy': 0.9102500000000001}, {'accuracy': 0.8853300000000001}, {'accuracy': 0.90829}, {'accuracy': 0.89308}, {'accuracy': 0.9001899999999999}, {'accuracy': 0.8916600000000001}, {'accuracy': 0.9033899999999999}, {'accuracy': 0.9122600000000001}, {'accuracy': 0.8920600000000001}, {'accuracy': 0.9007499999999998}, {'accuracy': 0.9112100000000002}, {'accuracy': 0.9118700000000001}, {'accuracy': 0.8854}, {'accuracy': 0.91973}, {'accuracy': 0.8743000000000001}, {'accuracy': 0.9103899999999999}, {'accuracy': 0.90158}, {'accuracy': 0.9108900000000002}, {'accuracy': 0.8834500000000001}, {'accuracy': 0.9195}, {'accuracy': 0.9000699999999998}, {'accuracy': 0.8828800000000001}, {'accuracy': 0.90991}, {'accuracy': 0.90626}, {'accuracy': 0.87956}, {'accuracy': 0.9106500000000001}, {'accuracy': 0.9105999999999999}, {'accuracy': 0.90726}, {'accuracy': 0.90147}, {'accuracy': 0.9370999999999998}, {'accuracy': 0.88399}, {'accuracy': 0.90061}, {'accuracy': 0.90154}, {'accuracy': 0.9004800000000002}, {'accuracy': 0.9187900000000001}, {'accuracy': 0.8901399999999999}, {'accuracy': 0.9172999999999998}, {'accuracy': 0.8896099999999999}, {'accuracy': 0.8992700000000001}, {'accuracy': 0.90134}, {'accuracy': 0.8993500000000001}, {'accuracy': 0.8723299999999998}, {'accuracy': 0.91726}, {'accuracy': 0.9020599999999999}, {'accuracy': 0.9001700000000001}, {'accuracy': 0.90005}, {'accuracy': 0.9144400000000001}, {'accuracy': 0.8950899999999999}, {'accuracy': 0.8875500000000001}, {'accuracy': 0.89275}, {'accuracy': 0.9023}, {'accuracy': 0.92085}, {'accuracy': 0.9188799999999999}, {'accuracy': 0.8896200000000001}, {'accuracy': 0.8904400000000001}, {'accuracy': 0.8793300000000001}, {'accuracy': 0.91661}, {'accuracy': 0.91676}, {'accuracy': 0.8992899999999999}, {'accuracy': 0.9088200000000001}, {'accuracy': 0.90342}, {'accuracy': 0.9163499999999999}, {'accuracy': 0.88994}, {'accuracy': 0.89885}, {'accuracy': 0.9180299999999999}, {'accuracy': 0.91138}, {'accuracy': 0.9259499999999999}, {'accuracy': 0.91684}, {'accuracy': 0.8989}, {'accuracy': 0.89915}, {'accuracy': 0.9092100000000001}, {'accuracy': 0.88224}, {'accuracy': 0.9242100000000001}, {'accuracy': 0.9179700000000001}, {'accuracy': 0.89441}, {'accuracy': 0.89861}, {'accuracy': 0.87442}, {'accuracy': 0.9371600000000001}, {'accuracy': 0.90852}, {'accuracy': 0.8829499999999999}, {'accuracy': 0.9014}, {'accuracy': 0.9007999999999999}, {'accuracy': 0.9365499999999999}, {'accuracy': 0.91977}, {'accuracy': 0.9}, {'accuracy': 0.9091699999999999}, {'accuracy': 0.90273}, {'accuracy': 0.8913}, {'accuracy': 0.8969100000000001}, {'accuracy': 0.9012500000000001}, {'accuracy': 0.9199299999999999}, {'accuracy': 0.9193999999999999}, {'accuracy': 0.9179899999999999}, {'accuracy': 0.8917999999999999}, {'accuracy': 0.9028699999999998}, {'accuracy': 0.8896000000000001}, {'accuracy': 0.8825099999999999}, {'accuracy': 0.9192400000000001}, {'accuracy': 0.8866400000000001}, {'accuracy': 0.9100299999999999}, {'accuracy': 0.8984000000000002}, {'accuracy': 0.89033}, {'accuracy': 0.89979}, {'accuracy': 0.9090400000000001}, {'accuracy': 0.9009800000000002}, {'accuracy': 0.8988499999999998}, {'accuracy': 0.9082799999999999}, {'accuracy': 0.9169300000000001}, {'accuracy': 0.8976299999999998}, {'accuracy': 0.8815199999999999}, {'accuracy': 0.90901}, {'accuracy': 0.91694}, {'accuracy': 0.9136399999999998}, {'accuracy': 0.9019600000000001}, {'accuracy': 0.88186}, {'accuracy': 0.9088500000000002}, {'accuracy': 0.91103}, {'accuracy': 0.9083699999999999}, {'accuracy': 0.91741}, {'accuracy': 0.8924799999999999}, {'accuracy': 0.8813699999999999}, {'accuracy': 0.8812599999999999}, {'accuracy': 0.88286}, {'accuracy': 0.88917}, {'accuracy': 0.9005099999999999}, {'accuracy': 0.87788}, {'accuracy': 0.88185}, {'accuracy': 0.915}, {'accuracy': 0.9032399999999999}, {'accuracy': 0.9080200000000002}, {'accuracy': 0.92014}, {'accuracy': 0.88195}, {'accuracy': 0.9069299999999998}, {'accuracy': 0.89807}, {'accuracy': 0.89976}, {'accuracy': 0.90076}, {'accuracy': 0.90687}, {'accuracy': 0.8916699999999999}, {'accuracy': 0.9006500000000001}, {'accuracy': 0.8903399999999999}, {'accuracy': 0.8893600000000002}, {'accuracy': 0.89767}, {'accuracy': 0.88365}, {'accuracy': 0.88928}, {'accuracy': 0.90801}, {'accuracy': 0.90045}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1a06e9b-29ae-4b49-8cb3-6485f54196c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0466bfc8-01c6-4e95-ac8f-5bb2f3e8800c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3e31187-e7c9-4930-b2a2-21bf27b7b0e6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76d24054-ad14-4c0f-b8b4-01877259ec9c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad0d645c-7ca5-4d33-835e-93d9db80a802",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "530a978f-ca8f-4c23-bd89-233f78dfee09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee79b818-f6fa-4d0f-8f08-21d7b58b3dc7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1f73453-af36-4542-a428-ce3e06c60faa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61b48937-4bef-4d2d-a491-7e4b67db8571",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32593ed3-40d2-4377-905f-2a3e9065d29b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "874ba690-30a6-406c-88bf-722515922bf8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a68c63cf-195a-4804-b750-c2964a694bda",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "815df2dd-d27d-4b55-ac06-50a1a1a3f8e7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc1a3091-511b-4912-8f0a-6b5a4f6cc919",
   "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
}
