{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\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_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e954128-4fd2-47cc-8c67-ab75f6023977",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n",
      "5101\n",
      "[[  0 510]\n",
      " [  1 525]\n",
      " [  2 505]\n",
      " [  3 502]\n",
      " [  4 502]\n",
      " [  5 499]\n",
      " [  6 528]\n",
      " [  7 487]\n",
      " [  8 502]\n",
      " [  9 499]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], 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,50000,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": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4812"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([9, 7, 4,  ..., 6, 1, 2])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5116\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 428]\n",
      " [  1 440]\n",
      " [  2 447]\n",
      " [  3 459]\n",
      " [  4 449]\n",
      " [  5 447]\n",
      " [  6 441]\n",
      " [  7 466]\n",
      " [  8 495]\n",
      " [  9 417]]\n",
      "[[  0 656]\n",
      " [  1 445]\n",
      " [  2 449]\n",
      " [  3 469]\n",
      " [  4 464]\n",
      " [  5 459]\n",
      " [  6 458]\n",
      " [  7 520]\n",
      " [  8 576]\n",
      " [  9 552]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 7, 4,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 9,
     "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,50000,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,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<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(((target1[z] - 1) % 10))\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",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0142f30a-16f1-4de9-858c-e8214f234a01",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "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=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\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=42)\n",
    "simulator.start(n_rounds=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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49NPP8V//vMfDB06FJcuXcLx48cBANOnT8esWbPwzjvvQKUyLony9ddfIyQkBKNGjWpxfc3FcNNKUqtbbYLc1RxMTERkJRU6PXos/N0qr330pXFwVjb/Y/aOO+4w+/nzzz+Hn58fjh49ih07diAnJwe7d++Gt7c3ACAmJka69tVXX8Xdd9+NF198UToWFxfX4ppnz56N22+/3ezY008/LX3/+OOP4/fff8d3332HgQMHoqSkBO+99x6WLl2KKVOmAACio6MxdOhQAMDtt9+OWbNm4aeffsJdd90FAFi5ciWmTp3aqgssWr1b6sMPP0RERATUajUSEhKwa9euRq89cuQI7rjjDkREREAmk2HJkiVtV2gLnc8rAwB08nGxciVERNQenDp1CpMmTUJUVBTc3d0REREBAEhLS0NKSgr69u0rBZu6UlJSMHr06KuuoX///mY/6/V6vPzyy4iNjYW3tzdcXV3x+++/Iy0tDQBw7NgxaDSaRl9brVbj/vvvx+effw4A2LdvHw4fPoypU6deda1NsWrLzerVqzFnzhwsW7YMCQkJWLJkCcaNG4cTJ07A39+/3vXl5eWIiorChAkT8K9//csKFTefabxNBMfbEBFZjZOjAkdfGme1126Jm2++GZ06dcKnn36K4OBgGAwG9OrVC1qtFk5OTk2/1mXOy2QyCCHMjjU0YNjFxfwf5G+99Rbee+89LFmyBLGxsXBxccHs2bOh1Wqb9bqAsWuqT58+uHDhAlasWIFRo0ahU6dOl33c1bBqy827776LGTNmYNq0aejRoweWLVsGZ2dnKeHVNWDAALz11lu4++67pb47W6Gp0uNCQbn0dSKzBAAQ7s2WGyIia5HJZHBWOljlqyXdLnl5eThx4gSee+45jB49Gt27d0dBQYF0vnfv3khJSUF+fn6Dj+/du3eTA3T9/Pxw6dIl6edTp041a3PR7du349Zbb8V9992HuLg4REVF4eTJk9L5zp07w8nJqcnXjo2NRf/+/fHpp5/im2++wQMPPHDZ171aVmu50Wq12Lt3L+bPny8dk8vlSExMRHJyssVeR6PRQKPRSD8XFxdb7LlrO5JRjNs/2lHveIQPW26IiKhpXl5e8PHxwSeffIKgoCCkpaVh3rx50vlJkybhtddew2233YbFixcjKCgI+/fvR3BwMAYNGoRFixZh9OjRiI6Oxt13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j5aCjRDt+/0Toun7s4f3ryF1w42tvYcyIYSwfHsQERERkXVwzA0RERHZFYYbIiIisisMN0RERGRXGG6IiIjIrjDcEBERkV1huCEiIiK7wnBDREREdoXhhog6hC1btkAmk9Xb/4aI7A/DDREREdkVhhsiIiKyKww3RGRTDAYD3nzzTcTExEClUiE8PByvvvoqRo0ahVmzZpldm5OTA6VSKe1GrNFoMHfuXISFhUGlUiEmJgafffZZo6+1bds2DBs2DE5OTggLC8MTTzyBsrKyVr0/Imp9DDdEZFPmz5+P119/Hc8//zyOHj2Kb775BgEBAZg+fTq++eYbaDQa6dqvv/4aISEhGDVqFABg8uTJ+Pbbb/H+++/j2LFjWL58OVxdXRt8nTNnzuC6667DHXfcgYMHD2L16tXYtm1bvQBFRO0PN84kIptRUlICPz8/LF26FNOnTzc7V1lZieDgYCxbtgx33XUXACAuLg633347Fi1ahJMnT6Jr167YuHEjEhMT6z33li1bcO2116KgoACenp6YPn06FAoFli9fLl2zbds2jBgxAmVlZVCr1a17s0TUathyQ0Q249ixY9BoNBg9enS9c2q1Gvfffz8+//xzAMC+fftw+PBhTJ06FQCQkpIChUKBESNGNOu1Dhw4gJUrV8LV1VX6GjduHAwGA86dO2exeyKitudg7QKIiEycnJyaPD99+nT06dMHFy5cwIoVKzBq1Ch06tSpWY+tq7S0FA8//DCeeOKJeufCw8Nb9FxEZFvYckNENqNz585wcnKSBgjXFRsbi/79++PTTz/FN998gwceeMDsnMFgwNatW5v1Wv369cPRo0cRExNT70upVFrkfojIOhhuiMhmqNVqzJ07F88++yy+/PJLnDlzBv/884/ZjKfp06fj9ddfhxAC48ePl45HRERgypQpeOCBB/Djjz/i3Llz2LJlC7777rsGX2vu3LnYsWMHZs2ahZSUFJw6dQo//fQTBxQT2QGGGyKyKc8//zyeeuopLFy4EN27d8fEiRORnZ0tnZ80aRIcHBwwadKkeoN+P/74Y9x5552YOXMmunXrhhkzZjQ6tbt3797YunUrTp48iWHDhqFv375YuHAhgoODW/X+iKj1cbYUEbUrqampiI6Oxu7du9GvXz9rl0NENojhhojaBZ1Oh7y8PDz99NM4d+4ctm/fbu2SiMhGsVuKiNqF7du3IygoCLt378ayZcusXQ4R2TC23BAREZFdYcsNERER2RWGGyIiIrIrDDdERERkVxhuiIiIyK4w3BAREZFdYbghIiIiu8JwQ0RERHaF4YaIiIjsCsMNERER2ZX/ByCqkInxZTKJAAAAAElFTkSuQmCC",
      "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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.11195}, {'accuracy': 0.11853000000000002}, {'accuracy': 0.14397}, {'accuracy': 0.13164000000000003}, {'accuracy': 0.15263000000000002}, {'accuracy': 0.18016}, {'accuracy': 0.15002}, {'accuracy': 0.17169000000000004}, {'accuracy': 0.18097000000000002}, {'accuracy': 0.17625000000000002}, {'accuracy': 0.23388000000000003}, {'accuracy': 0.24292000000000002}, {'accuracy': 0.23457}, {'accuracy': 0.23738}, {'accuracy': 0.23914}, {'accuracy': 0.25523999999999997}, {'accuracy': 0.25105}, {'accuracy': 0.26888999999999996}, {'accuracy': 0.28547}, {'accuracy': 0.29289}, {'accuracy': 0.28706}, {'accuracy': 0.30486}, {'accuracy': 0.29051000000000005}, {'accuracy': 0.30735}, {'accuracy': 0.29978999999999995}, {'accuracy': 0.31571000000000005}, {'accuracy': 0.30161}, {'accuracy': 0.28185000000000004}, {'accuracy': 0.29067000000000004}, {'accuracy': 0.26553}, {'accuracy': 0.30207999999999996}, {'accuracy': 0.25934}, {'accuracy': 0.2596200000000001}, {'accuracy': 0.27904}, {'accuracy': 0.23969000000000001}, {'accuracy': 0.23722}, {'accuracy': 0.21785000000000002}, {'accuracy': 0.22374}, {'accuracy': 0.24215}, {'accuracy': 0.22441}, {'accuracy': 0.20782999999999996}, {'accuracy': 0.21728999999999998}, {'accuracy': 0.22432}, {'accuracy': 0.22504}, {'accuracy': 0.22875}, {'accuracy': 0.23220000000000002}, {'accuracy': 0.24900000000000003}, {'accuracy': 0.21381}, {'accuracy': 0.23838999999999996}, {'accuracy': 0.21475}, {'accuracy': 0.21976}, {'accuracy': 0.24235999999999996}, {'accuracy': 0.25545}, {'accuracy': 0.23756000000000005}, {'accuracy': 0.27736}, {'accuracy': 0.23406000000000002}, {'accuracy': 0.26555999999999996}, {'accuracy': 0.25519000000000003}, {'accuracy': 0.26656}, {'accuracy': 0.28714999999999996}, {'accuracy': 0.28508}, {'accuracy': 0.29501999999999995}, {'accuracy': 0.29102999999999996}, {'accuracy': 0.30280999999999997}, {'accuracy': 0.30726}, {'accuracy': 0.33767}, {'accuracy': 0.34242}, {'accuracy': 0.35534999999999994}, {'accuracy': 0.36301}, {'accuracy': 0.39147}, {'accuracy': 0.38265}, {'accuracy': 0.36952999999999997}, {'accuracy': 0.37111}, {'accuracy': 0.39303000000000005}, {'accuracy': 0.39547000000000004}, {'accuracy': 0.43098000000000003}, {'accuracy': 0.4081099999999999}, {'accuracy': 0.40462}, {'accuracy': 0.42469999999999997}, {'accuracy': 0.40745000000000003}, {'accuracy': 0.42302999999999996}, {'accuracy': 0.42659}, {'accuracy': 0.4476}, {'accuracy': 0.45174000000000003}, {'accuracy': 0.46346999999999994}, {'accuracy': 0.45133999999999996}, {'accuracy': 0.45852000000000004}, {'accuracy': 0.43721}, {'accuracy': 0.47569999999999996}, {'accuracy': 0.46453999999999995}, {'accuracy': 0.45382999999999996}, {'accuracy': 0.47534}, {'accuracy': 0.48316}, {'accuracy': 0.46412}, {'accuracy': 0.46631}, {'accuracy': 0.50522}, {'accuracy': 0.46482}, {'accuracy': 0.49702}, {'accuracy': 0.50621}, {'accuracy': 0.48433000000000004}, {'accuracy': 0.49954}, {'accuracy': 0.51227}, {'accuracy': 0.47918000000000005}, {'accuracy': 0.4995}, {'accuracy': 0.50609}, {'accuracy': 0.5006700000000001}, {'accuracy': 0.5045599999999999}, {'accuracy': 0.50914}, {'accuracy': 0.50983}, {'accuracy': 0.50707}, {'accuracy': 0.50632}, {'accuracy': 0.50942}, {'accuracy': 0.5107900000000001}, {'accuracy': 0.5052900000000001}, {'accuracy': 0.50478}, {'accuracy': 0.5065299999999999}, {'accuracy': 0.52261}, {'accuracy': 0.5231700000000001}, {'accuracy': 0.5139500000000001}, {'accuracy': 0.51818}, {'accuracy': 0.52432}, {'accuracy': 0.52214}, {'accuracy': 0.52894}, {'accuracy': 0.5349}, {'accuracy': 0.5352399999999999}, {'accuracy': 0.53215}, {'accuracy': 0.53566}, {'accuracy': 0.53301}, {'accuracy': 0.5328799999999999}, {'accuracy': 0.5133099999999999}, {'accuracy': 0.5203599999999999}, {'accuracy': 0.5314500000000001}, {'accuracy': 0.5375300000000001}, {'accuracy': 0.53664}, {'accuracy': 0.52563}, {'accuracy': 0.52931}, {'accuracy': 0.52206}, {'accuracy': 0.53252}, {'accuracy': 0.53005}, {'accuracy': 0.53568}, {'accuracy': 0.5376}, {'accuracy': 0.53237}, {'accuracy': 0.5309199999999998}, {'accuracy': 0.5377399999999999}, {'accuracy': 0.54021}, {'accuracy': 0.53773}, {'accuracy': 0.5336000000000001}, {'accuracy': 0.5362500000000001}, {'accuracy': 0.52722}, {'accuracy': 0.5372000000000001}, {'accuracy': 0.53707}, {'accuracy': 0.52382}, {'accuracy': 0.5200199999999999}, {'accuracy': 0.5381199999999999}, {'accuracy': 0.5399299999999999}, {'accuracy': 0.5336000000000001}, {'accuracy': 0.5403}, {'accuracy': 0.5374899999999998}, {'accuracy': 0.53914}, {'accuracy': 0.5370699999999999}, {'accuracy': 0.5260400000000001}, {'accuracy': 0.5407400000000001}, {'accuracy': 0.53309}, {'accuracy': 0.53453}, {'accuracy': 0.52301}, {'accuracy': 0.51474}, {'accuracy': 0.52077}, {'accuracy': 0.52532}, {'accuracy': 0.52636}, {'accuracy': 0.54071}, {'accuracy': 0.5409200000000001}, {'accuracy': 0.5413}, {'accuracy': 0.5396699999999999}, {'accuracy': 0.54376}, {'accuracy': 0.54471}, {'accuracy': 0.54876}, {'accuracy': 0.5414200000000001}, {'accuracy': 0.5474399999999999}, {'accuracy': 0.54535}, {'accuracy': 0.5468300000000001}, {'accuracy': 0.54521}, {'accuracy': 0.5463399999999999}, {'accuracy': 0.5475800000000001}, {'accuracy': 0.54656}, {'accuracy': 0.54349}, {'accuracy': 0.5419099999999999}, {'accuracy': 0.54256}, {'accuracy': 0.5464}, {'accuracy': 0.54556}, {'accuracy': 0.5408799999999999}, {'accuracy': 0.5332899999999999}, {'accuracy': 0.5463800000000001}, {'accuracy': 0.54372}, {'accuracy': 0.5403399999999999}, {'accuracy': 0.5424800000000001}, {'accuracy': 0.54597}, {'accuracy': 0.54412}, {'accuracy': 0.54387}, {'accuracy': 0.55596}, {'accuracy': 0.5627000000000001}, {'accuracy': 0.5652999999999999}, {'accuracy': 0.56011}, {'accuracy': 0.5738700000000001}, {'accuracy': 0.5562199999999999}, {'accuracy': 0.5579699999999999}, {'accuracy': 0.5666599999999999}, {'accuracy': 0.57112}, {'accuracy': 0.58012}, {'accuracy': 0.58328}, {'accuracy': 0.57316}, {'accuracy': 0.57863}, {'accuracy': 0.5796}, {'accuracy': 0.5857600000000001}, {'accuracy': 0.58739}, {'accuracy': 0.58542}, {'accuracy': 0.5871299999999999}, {'accuracy': 0.5745899999999999}, {'accuracy': 0.5856199999999999}, {'accuracy': 0.5859}, {'accuracy': 0.58506}, {'accuracy': 0.5806600000000001}, {'accuracy': 0.5773199999999999}, {'accuracy': 0.58325}, {'accuracy': 0.5884400000000001}, {'accuracy': 0.58395}, {'accuracy': 0.58938}, {'accuracy': 0.57876}, {'accuracy': 0.59159}, {'accuracy': 0.5895400000000001}, {'accuracy': 0.5809099999999999}, {'accuracy': 0.5888}, {'accuracy': 0.59112}, {'accuracy': 0.59046}, {'accuracy': 0.59198}, {'accuracy': 0.59242}, {'accuracy': 0.59295}, {'accuracy': 0.5936299999999999}, {'accuracy': 0.58906}, {'accuracy': 0.5921999999999998}, {'accuracy': 0.59239}, {'accuracy': 0.59067}, {'accuracy': 0.59341}, {'accuracy': 0.58863}, {'accuracy': 0.5767499999999999}, {'accuracy': 0.58696}, {'accuracy': 0.58552}, {'accuracy': 0.5922}, {'accuracy': 0.59222}, {'accuracy': 0.5883499999999999}, {'accuracy': 0.58773}, {'accuracy': 0.58597}, {'accuracy': 0.59361}, {'accuracy': 0.59083}, {'accuracy': 0.59031}, {'accuracy': 0.5907600000000001}, {'accuracy': 0.5896000000000001}, {'accuracy': 0.59009}, {'accuracy': 0.59141}, {'accuracy': 0.58998}, {'accuracy': 0.58981}, {'accuracy': 0.58946}, {'accuracy': 0.59037}, {'accuracy': 0.58939}, {'accuracy': 0.5902800000000001}, {'accuracy': 0.5868800000000001}, {'accuracy': 0.58863}, {'accuracy': 0.5901599999999999}, {'accuracy': 0.5908}, {'accuracy': 0.5884599999999999}, {'accuracy': 0.5890699999999999}, {'accuracy': 0.58958}, {'accuracy': 0.58972}, {'accuracy': 0.5862499999999999}, {'accuracy': 0.59063}, {'accuracy': 0.58906}, {'accuracy': 0.5890199999999999}, {'accuracy': 0.58897}, {'accuracy': 0.59203}, {'accuracy': 0.5903}, {'accuracy': 0.5897300000000001}, {'accuracy': 0.58926}, {'accuracy': 0.58819}, {'accuracy': 0.58919}, {'accuracy': 0.58913}, {'accuracy': 0.58751}, {'accuracy': 0.58896}, {'accuracy': 0.58746}, {'accuracy': 0.58775}, {'accuracy': 0.5895900000000001}, {'accuracy': 0.5888800000000001}, {'accuracy': 0.58642}, {'accuracy': 0.5884099999999999}, {'accuracy': 0.5899300000000001}, {'accuracy': 0.5900299999999998}, {'accuracy': 0.59121}, {'accuracy': 0.5904800000000001}, {'accuracy': 0.59125}, {'accuracy': 0.59016}, {'accuracy': 0.57093}, {'accuracy': 0.5733200000000002}, {'accuracy': 0.58502}, {'accuracy': 0.58434}, {'accuracy': 0.5889300000000001}, {'accuracy': 0.58883}, {'accuracy': 0.58989}, {'accuracy': 0.5897400000000002}, {'accuracy': 0.58843}, {'accuracy': 0.58884}, {'accuracy': 0.58826}, {'accuracy': 0.59144}, {'accuracy': 0.5802500000000002}, {'accuracy': 0.58486}, {'accuracy': 0.5888500000000001}, {'accuracy': 0.5859099999999999}, {'accuracy': 0.59193}, {'accuracy': 0.5896399999999999}, {'accuracy': 0.58899}, {'accuracy': 0.58958}, {'accuracy': 0.58972}, {'accuracy': 0.5881000000000001}, {'accuracy': 0.5905199999999999}, {'accuracy': 0.5894}, {'accuracy': 0.58926}, {'accuracy': 0.5900700000000001}, {'accuracy': 0.59038}, {'accuracy': 0.58404}, {'accuracy': 0.5841100000000001}, {'accuracy': 0.5616300000000001}, {'accuracy': 0.56254}, {'accuracy': 0.58851}, {'accuracy': 0.5931}, {'accuracy': 0.59486}, {'accuracy': 0.59484}, {'accuracy': 0.5939000000000001}, {'accuracy': 0.5945000000000001}, {'accuracy': 0.59615}, {'accuracy': 0.59541}, {'accuracy': 0.5956699999999999}, {'accuracy': 0.5942299999999999}, {'accuracy': 0.5924400000000001}, {'accuracy': 0.5946900000000002}, {'accuracy': 0.59141}, {'accuracy': 0.5938599999999999}, {'accuracy': 0.5915299999999999}, {'accuracy': 0.59161}, {'accuracy': 0.5918400000000001}, {'accuracy': 0.59374}, {'accuracy': 0.59181}, {'accuracy': 0.5924799999999999}, {'accuracy': 0.59127}, {'accuracy': 0.5902200000000001}, {'accuracy': 0.5919900000000001}, {'accuracy': 0.5911700000000001}, {'accuracy': 0.5902700000000001}, {'accuracy': 0.5908499999999999}, {'accuracy': 0.5919800000000001}, {'accuracy': 0.5904099999999999}, {'accuracy': 0.5916699999999999}, {'accuracy': 0.5896800000000001}, {'accuracy': 0.59183}, {'accuracy': 0.5887100000000001}, {'accuracy': 0.5903}, {'accuracy': 0.57951}, {'accuracy': 0.5809500000000001}, {'accuracy': 0.5628599999999999}, {'accuracy': 0.58733}, {'accuracy': 0.5895199999999999}, {'accuracy': 0.5864600000000001}, {'accuracy': 0.57732}, {'accuracy': 0.5882400000000001}, {'accuracy': 0.59176}, {'accuracy': 0.59059}, {'accuracy': 0.5880699999999999}, {'accuracy': 0.59079}, {'accuracy': 0.59138}, {'accuracy': 0.59219}, {'accuracy': 0.59331}, {'accuracy': 0.5946400000000001}, {'accuracy': 0.59337}, {'accuracy': 0.59389}, {'accuracy': 0.59378}, {'accuracy': 0.5888199999999999}, {'accuracy': 0.58948}, {'accuracy': 0.59217}, {'accuracy': 0.59321}, {'accuracy': 0.59368}, {'accuracy': 0.5939}, {'accuracy': 0.59216}, {'accuracy': 0.5929499999999999}, {'accuracy': 0.5925199999999999}, {'accuracy': 0.5944}, {'accuracy': 0.59257}, {'accuracy': 0.59288}, {'accuracy': 0.5926199999999999}, {'accuracy': 0.59056}, {'accuracy': 0.5914900000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3249552a-eed5-475c-9fe9-d271b4d7aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a23ef5a2-330a-48ef-a823-8ccf7eabb143",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0129bbcf-dda3-427c-9e61-460fcf92a88b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b508a77-824f-49b5-bf3d-042628943788",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae9e0585-b4b2-4ca8-80ab-d43acabdecb6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62209643-5453-464a-afb6-7807816723d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75432e5d-2ac0-4052-8714-c170cab4342f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac0a18a-c8b9-4236-857a-f9e76af1b1ab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "37e99bdf-6406-4432-a1e8-f2eea448a987",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d08a9769-8a7d-416d-a2fd-e12050a213d6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0177f756-bed2-4b74-99e9-a86a70c4a93f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "46b24c90-638f-4c76-922f-ec043dcc3c43",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d78b9e75-4008-4763-a263-f111ed3bbeef",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb09bf3a-c37b-4ccc-88de-a26d6c851ba2",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
