{
 "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",
      "4941\n",
      "[[  0 474]\n",
      " [  1 481]\n",
      " [  2 498]\n",
      " [  3 495]\n",
      " [  4 518]\n",
      " [  5 499]\n",
      " [  6 497]\n",
      " [  7 526]\n",
      " [  8 495]\n",
      " [  9 502]]\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": [
       "4956"
      ]
     },
     "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, 3, 0,  ..., 4, 0, 0])"
      ]
     },
     "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": [
      "14998\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 340]\n",
      " [  1 354]\n",
      " [  2 335]\n",
      " [  3 371]\n",
      " [  4 367]\n",
      " [  5 353]\n",
      " [  6 344]\n",
      " [  7 344]\n",
      " [  8 365]\n",
      " [  9 328]]\n",
      "[[  0 914]\n",
      " [  1 377]\n",
      " [  2 344]\n",
      " [  3 385]\n",
      " [  4 399]\n",
      " [  5 404]\n",
      " [  6 425]\n",
      " [  7 455]\n",
      " [  8 621]\n",
      " [  9 758]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 3, 0,  ..., 5, 3, 7])"
      ]
     },
     "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",
    "        \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<3:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1b51de3-0c26-4346-9056-1dfcc38e621f",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "print(\"this is\")\n",
    "print(ytr[1])\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",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10722000000000001}, {'accuracy': 0.10732000000000001}, {'accuracy': 0.1}, {'accuracy': 0.11808}, {'accuracy': 0.11691000000000003}, {'accuracy': 0.13613000000000003}, {'accuracy': 0.15359000000000003}, {'accuracy': 0.16111999999999999}, {'accuracy': 0.13827000000000003}, {'accuracy': 0.16278}, {'accuracy': 0.15381000000000003}, {'accuracy': 0.19532000000000002}, {'accuracy': 0.20606}, {'accuracy': 0.17373}, {'accuracy': 0.2021}, {'accuracy': 0.25216}, {'accuracy': 0.23844000000000004}, {'accuracy': 0.17553000000000002}, {'accuracy': 0.19669999999999999}, {'accuracy': 0.25532}, {'accuracy': 0.23162}, {'accuracy': 0.24287999999999998}, {'accuracy': 0.27503}, {'accuracy': 0.27761}, {'accuracy': 0.20321000000000003}, {'accuracy': 0.24158999999999997}, {'accuracy': 0.20385}, {'accuracy': 0.28098}, {'accuracy': 0.22197999999999993}, {'accuracy': 0.29402}, {'accuracy': 0.30891}, {'accuracy': 0.22187}, {'accuracy': 0.23103}, {'accuracy': 0.32322}, {'accuracy': 0.25936}, {'accuracy': 0.27183999999999997}, {'accuracy': 0.27901}, {'accuracy': 0.29166}, {'accuracy': 0.25199}, {'accuracy': 0.23922999999999997}, {'accuracy': 0.21097000000000002}, {'accuracy': 0.32672}, {'accuracy': 0.30075999999999997}, {'accuracy': 0.27418}, {'accuracy': 0.31260999999999994}, {'accuracy': 0.24484000000000003}, {'accuracy': 0.21651000000000004}, {'accuracy': 0.18798}, {'accuracy': 0.24843999999999994}, {'accuracy': 0.21729000000000004}, {'accuracy': 0.22043}, {'accuracy': 0.17703999999999998}, {'accuracy': 0.24377}, {'accuracy': 0.2751}, {'accuracy': 0.22118999999999994}, {'accuracy': 0.27921}, {'accuracy': 0.27322}, {'accuracy': 0.30247000000000007}, {'accuracy': 0.25300999999999996}, {'accuracy': 0.28929}, {'accuracy': 0.26879}, {'accuracy': 0.25908999999999993}, {'accuracy': 0.30515}, {'accuracy': 0.26852}, {'accuracy': 0.33290000000000003}, {'accuracy': 0.28453}, {'accuracy': 0.30844000000000005}, {'accuracy': 0.33412}, {'accuracy': 0.30191}, {'accuracy': 0.30505000000000004}, {'accuracy': 0.30774}, {'accuracy': 0.28415999999999997}, {'accuracy': 0.31019}, {'accuracy': 0.30878}, {'accuracy': 0.30602}, {'accuracy': 0.35228000000000004}, {'accuracy': 0.35977999999999993}, {'accuracy': 0.31852}, {'accuracy': 0.3158}, {'accuracy': 0.39057000000000003}, {'accuracy': 0.31647}, {'accuracy': 0.40903999999999996}, {'accuracy': 0.40404}, {'accuracy': 0.3881}, {'accuracy': 0.38947000000000004}, {'accuracy': 0.35324999999999995}, {'accuracy': 0.39685}, {'accuracy': 0.32866999999999996}, {'accuracy': 0.36871}, {'accuracy': 0.32007}, {'accuracy': 0.35734000000000005}, {'accuracy': 0.35114000000000006}, {'accuracy': 0.36960000000000004}, {'accuracy': 0.35458}, {'accuracy': 0.45194}, {'accuracy': 0.41585}, {'accuracy': 0.41913}, {'accuracy': 0.36449}, {'accuracy': 0.37750000000000006}, {'accuracy': 0.38125}, {'accuracy': 0.36619}, {'accuracy': 0.3681}, {'accuracy': 0.40042}, {'accuracy': 0.38526000000000005}, {'accuracy': 0.40218}, {'accuracy': 0.43995000000000006}, {'accuracy': 0.37777000000000005}, {'accuracy': 0.39330999999999994}, {'accuracy': 0.43603}, {'accuracy': 0.39049999999999996}, {'accuracy': 0.41579}, {'accuracy': 0.38509999999999994}, {'accuracy': 0.40986}, {'accuracy': 0.41537999999999997}, {'accuracy': 0.45362}, {'accuracy': 0.37026000000000003}, {'accuracy': 0.43217999999999995}, {'accuracy': 0.41642999999999997}, {'accuracy': 0.38212}, {'accuracy': 0.37908000000000003}, {'accuracy': 0.46552}, {'accuracy': 0.37071}, {'accuracy': 0.36621}, {'accuracy': 0.44653}, {'accuracy': 0.41025}, {'accuracy': 0.4755599999999999}, {'accuracy': 0.42766000000000004}, {'accuracy': 0.45487}, {'accuracy': 0.4693100000000001}, {'accuracy': 0.42596000000000006}, {'accuracy': 0.42618}, {'accuracy': 0.445}, {'accuracy': 0.44878}, {'accuracy': 0.45047999999999994}, {'accuracy': 0.43525}, {'accuracy': 0.46853}, {'accuracy': 0.45149}, {'accuracy': 0.42914}, {'accuracy': 0.43905000000000005}, {'accuracy': 0.46772}, {'accuracy': 0.49316000000000004}, {'accuracy': 0.47741}, {'accuracy': 0.4628}, {'accuracy': 0.49653}, {'accuracy': 0.49213000000000007}, {'accuracy': 0.43414}, {'accuracy': 0.45099999999999996}, {'accuracy': 0.46887}, {'accuracy': 0.46572}, {'accuracy': 0.45858}, {'accuracy': 0.4438099999999999}, {'accuracy': 0.44783}, {'accuracy': 0.50374}, {'accuracy': 0.49822}, {'accuracy': 0.48273}, {'accuracy': 0.4781700000000001}, {'accuracy': 0.4750500000000001}, {'accuracy': 0.50476}, {'accuracy': 0.5064200000000001}, {'accuracy': 0.50539}, {'accuracy': 0.48382}, {'accuracy': 0.51165}, {'accuracy': 0.51147}, {'accuracy': 0.5098799999999999}, {'accuracy': 0.47276999999999997}, {'accuracy': 0.50765}, {'accuracy': 0.48549}, {'accuracy': 0.50162}, {'accuracy': 0.50139}, {'accuracy': 0.49777999999999994}, {'accuracy': 0.50454}, {'accuracy': 0.5001300000000001}, {'accuracy': 0.4979}, {'accuracy': 0.51393}, {'accuracy': 0.50697}, {'accuracy': 0.5230199999999999}, {'accuracy': 0.5124}, {'accuracy': 0.52063}, {'accuracy': 0.50559}, {'accuracy': 0.51971}, {'accuracy': 0.50232}, {'accuracy': 0.51215}, {'accuracy': 0.5151299999999999}, {'accuracy': 0.50513}, {'accuracy': 0.5236500000000002}, {'accuracy': 0.5038199999999999}, {'accuracy': 0.5103100000000002}, {'accuracy': 0.51327}, {'accuracy': 0.5115299999999999}, {'accuracy': 0.5202099999999998}, {'accuracy': 0.5144}, {'accuracy': 0.51912}, {'accuracy': 0.50434}, {'accuracy': 0.51242}, {'accuracy': 0.50556}, {'accuracy': 0.50042}, {'accuracy': 0.50438}, {'accuracy': 0.47947000000000006}, {'accuracy': 0.47535}, {'accuracy': 0.5145199999999999}, {'accuracy': 0.49628999999999995}, {'accuracy': 0.4616999999999999}, {'accuracy': 0.50442}, {'accuracy': 0.5085200000000001}, {'accuracy': 0.5116599999999999}, {'accuracy': 0.5106599999999999}, {'accuracy': 0.5024200000000001}, {'accuracy': 0.48543000000000003}, {'accuracy': 0.5118699999999999}, {'accuracy': 0.51991}, {'accuracy': 0.51991}, {'accuracy': 0.5286299999999999}, {'accuracy': 0.5263199999999999}, {'accuracy': 0.5173599999999999}, {'accuracy': 0.52669}, {'accuracy': 0.5241100000000001}, {'accuracy': 0.52381}, {'accuracy': 0.52261}, {'accuracy': 0.51942}, {'accuracy': 0.52371}, {'accuracy': 0.52835}, {'accuracy': 0.5306400000000001}, {'accuracy': 0.53485}, {'accuracy': 0.5313}, {'accuracy': 0.52379}, {'accuracy': 0.52681}, {'accuracy': 0.5259}, {'accuracy': 0.5239900000000001}, {'accuracy': 0.52389}, {'accuracy': 0.52882}, {'accuracy': 0.5354399999999999}, {'accuracy': 0.5250199999999999}, {'accuracy': 0.5206}, {'accuracy': 0.52634}, {'accuracy': 0.5112500000000001}, {'accuracy': 0.50255}, {'accuracy': 0.5190600000000001}, {'accuracy': 0.53071}, {'accuracy': 0.51984}, {'accuracy': 0.5320400000000001}, {'accuracy': 0.51664}, {'accuracy': 0.52374}, {'accuracy': 0.52592}, {'accuracy': 0.5238700000000001}, {'accuracy': 0.52493}, {'accuracy': 0.52508}, {'accuracy': 0.52248}, {'accuracy': 0.52552}, {'accuracy': 0.5294000000000001}, {'accuracy': 0.5224500000000001}, {'accuracy': 0.53097}, {'accuracy': 0.52363}, {'accuracy': 0.52369}, {'accuracy': 0.53026}, {'accuracy': 0.52801}, {'accuracy': 0.53208}, {'accuracy': 0.5286000000000001}, {'accuracy': 0.53058}, {'accuracy': 0.5253}, {'accuracy': 0.52097}, {'accuracy': 0.51823}, {'accuracy': 0.50706}, {'accuracy': 0.5144500000000001}, {'accuracy': 0.51416}, {'accuracy': 0.5074799999999999}, {'accuracy': 0.5271199999999999}, {'accuracy': 0.53613}, {'accuracy': 0.47176}, {'accuracy': 0.4751}, {'accuracy': 0.5289300000000001}, {'accuracy': 0.5161}, {'accuracy': 0.50808}, {'accuracy': 0.52641}, {'accuracy': 0.48186}, {'accuracy': 0.50649}, {'accuracy': 0.53108}, {'accuracy': 0.53407}, {'accuracy': 0.52465}, {'accuracy': 0.5356299999999999}, {'accuracy': 0.53296}, {'accuracy': 0.5339800000000001}, {'accuracy': 0.53053}, {'accuracy': 0.53758}, {'accuracy': 0.5275000000000001}, {'accuracy': 0.52608}, {'accuracy': 0.52067}, {'accuracy': 0.5316500000000001}, {'accuracy': 0.52942}, {'accuracy': 0.5290199999999999}, {'accuracy': 0.52579}, {'accuracy': 0.52495}, {'accuracy': 0.5300499999999999}, {'accuracy': 0.5320199999999999}, {'accuracy': 0.52827}, {'accuracy': 0.5289299999999999}, {'accuracy': 0.5314699999999999}, {'accuracy': 0.5309600000000001}, {'accuracy': 0.5280199999999999}, {'accuracy': 0.5160699999999998}, {'accuracy': 0.5290199999999999}, {'accuracy': 0.52309}, {'accuracy': 0.52541}, {'accuracy': 0.5218200000000001}, {'accuracy': 0.52237}, {'accuracy': 0.52593}, {'accuracy': 0.5183199999999999}, {'accuracy': 0.5230400000000001}, {'accuracy': 0.52003}, {'accuracy': 0.52724}, {'accuracy': 0.5231499999999999}, {'accuracy': 0.52561}, {'accuracy': 0.5256700000000001}, {'accuracy': 0.5241200000000001}, {'accuracy': 0.5180499999999999}, {'accuracy': 0.52686}, {'accuracy': 0.52181}, {'accuracy': 0.5244500000000001}, {'accuracy': 0.5287300000000001}, {'accuracy': 0.52501}, {'accuracy': 0.5165199999999999}, {'accuracy': 0.52643}, {'accuracy': 0.5274500000000002}, {'accuracy': 0.53276}, {'accuracy': 0.5259999999999999}, {'accuracy': 0.52073}, {'accuracy': 0.52469}, {'accuracy': 0.5268200000000001}, {'accuracy': 0.5202300000000001}, {'accuracy': 0.53373}, {'accuracy': 0.52539}, {'accuracy': 0.53238}, {'accuracy': 0.52274}, {'accuracy': 0.51676}, {'accuracy': 0.52051}, {'accuracy': 0.5158699999999999}, {'accuracy': 0.52527}, {'accuracy': 0.52762}, {'accuracy': 0.5245900000000001}, {'accuracy': 0.51708}, {'accuracy': 0.5208}, {'accuracy': 0.52159}, {'accuracy': 0.5234300000000001}, {'accuracy': 0.5181899999999999}, {'accuracy': 0.5233399999999999}, {'accuracy': 0.51738}, {'accuracy': 0.51705}, {'accuracy': 0.5264900000000001}, {'accuracy': 0.52215}, {'accuracy': 0.5247300000000001}, {'accuracy': 0.51759}, {'accuracy': 0.52335}, {'accuracy': 0.5208699999999999}, {'accuracy': 0.52263}, {'accuracy': 0.52206}, {'accuracy': 0.5216099999999999}, {'accuracy': 0.5197299999999999}, {'accuracy': 0.5267899999999999}, {'accuracy': 0.5159100000000001}, {'accuracy': 0.52032}, {'accuracy': 0.5231}, {'accuracy': 0.51248}, {'accuracy': 0.49363}, {'accuracy': 0.50822}, {'accuracy': 0.5152699999999999}, {'accuracy': 0.4998}, {'accuracy': 0.52376}, {'accuracy': 0.5231700000000001}, {'accuracy': 0.5262500000000001}, {'accuracy': 0.5255200000000001}, {'accuracy': 0.5327200000000001}, {'accuracy': 0.5006200000000001}, {'accuracy': 0.52551}, {'accuracy': 0.52546}, {'accuracy': 0.48351000000000005}, {'accuracy': 0.49144999999999994}, {'accuracy': 0.48956999999999995}, {'accuracy': 0.5197700000000001}, {'accuracy': 0.52643}, {'accuracy': 0.50281}, {'accuracy': 0.5227299999999999}, {'accuracy': 0.52723}, {'accuracy': 0.52294}, {'accuracy': 0.52705}, {'accuracy': 0.52583}, {'accuracy': 0.522}, {'accuracy': 0.5235299999999999}, {'accuracy': 0.52692}, {'accuracy': 0.5257700000000002}, {'accuracy': 0.5220800000000001}, {'accuracy': 0.53035}, {'accuracy': 0.53209}, {'accuracy': 0.51838}, {'accuracy': 0.53188}, {'accuracy': 0.47470999999999997}, {'accuracy': 0.5173399999999999}, {'accuracy': 0.50153}, {'accuracy': 0.50519}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACK8klEQVR4nO3dd3wUZf4H8M/2TS+kkRA6Su+CKE1AsHdF9ARBORun/NBTOBX0PMXKYUe9E+zgodgFNQJKkR56l9DTe9vd7M7vj81MZmZLsskmu1k+79eLF5uZ2dlnsknmu9/n+zyPRhAEAUREREQhQhvoBhARERH5E4MbIiIiCikMboiIiCikMLghIiKikMLghoiIiEIKgxsiIiIKKQxuiIiIKKQwuCEiIqKQwuCGiIiIQgqDGyJqVmvWrIFGo8GaNWukbXfeeSc6duwYsDaFkqeeegoajSbQzSAKKgxuiILc3r178Ze//AVpaWkwmUxITU3F7bffjr179wa6ac3urbfewpIlS5r1Nfbt24ennnoKWVlZzfo6Lem5557DV199FehmEAUMgxuiIPbll19i4MCByMjIwNSpU/HWW2/hrrvuwurVqzFw4ECsWLEi0E1sVi0V3Dz99NMMbohCiD7QDSAi944ePYo77rgDnTt3xm+//YbExERp30MPPYQRI0bgjjvuwK5du9C5c+cWa1dFRQUiIiJa7PVaA35PiIILMzdEQeqll15CZWUl3n33XUVgAwAJCQl45513UFFRgRdffBEAsHz5cmg0Gqxdu9blXO+88w40Gg327NkjbTtw4ABuuukmxMfHw2w2Y/Dgwfjmm28Uz1uyZIl0zvvvvx9JSUlo164dAOD48eO4//77cf755yMsLAxt2rTBzTff7LcMSMeOHbF3716sXbsWGo0GGo0Go0ePlvYXFxdj5syZSE9Ph8lkQteuXfHCCy/A4XAozrN06VIMGjQIUVFRiI6ORp8+ffDqq69K13fzzTcDAC655BLpdeT1QWp33nknIiMjcfToUVxxxRWIiorC7bffDgBwOBxYuHAhevXqBbPZjOTkZNxzzz0oKipSnGPr1q2YMGECEhISEBYWhk6dOmHatGnSfnd1SgCQlZUFjUbjNZul0WhQUVGBDz74QLqeO++8EwBQVlaGmTNnomPHjjCZTEhKSsKll16K7du3ezwfUWvEzA1RkPr222/RsWNHjBgxwu3+kSNHomPHjvj+++8BAFdeeSUiIyPx+eefY9SoUYpjly1bhl69eqF3794AnHU8F198MdLS0jB79mxERETg888/x3XXXYcvvvgC119/veL5999/PxITEzF37lxUVFQAALZs2YINGzbg1ltvRbt27ZCVlYW3334bo0ePxr59+xAeHt6k61+4cCH+9re/ITIyEo8//jgAIDk5GQBQWVmJUaNG4fTp07jnnnvQvn17bNiwAXPmzMHZs2excOFCAMDPP/+MSZMmYezYsXjhhRcAAPv378f69evx0EMPYeTIkXjwwQfx2muv4R//+Ad69OgBANL/ntTU1GDChAkYPnw4Xn75Zela77nnHixZsgRTp07Fgw8+iGPHjuGNN97Ajh07sH79ehgMBuTm5mL8+PFITEzE7NmzERsbi6ysLHz55ZdN+n6JPvroI9x9990YMmQI/vrXvwIAunTpAgC49957sXz5csyYMQM9e/ZEQUEB1q1bh/3792PgwIF+eX2ioCAQUdApLi4WAAjXXnut1+OuueYaAYBQWloqCIIgTJo0SUhKShJqamqkY86ePStotVrhn//8p7Rt7NixQp8+fYTq6mppm8PhEC666CKhW7du0rbFixcLAIThw4crzikIglBZWenSno0bNwoAhA8//FDatnr1agGAsHr1amnblClThA4dOni9NkEQhF69egmjRo1y2f7MM88IERERwqFDhxTbZ8+eLeh0OuHEiROCIAjCQw89JERHR7u0Xe5///ufS/u8mTJligBAmD17tmL777//LgAQPvnkE8X2lStXKravWLFCACBs2bLF42u4+54JgiAcO3ZMACAsXrxY2jZv3jxB/ac8IiJCmDJlist5Y2JihAceeKABV0nUurFbiigIlZWVAQCioqK8HifuLy0tBQBMnDgRubm5iu6M5cuXw+FwYOLEiQCAwsJC/Prrr7jllltQVlaG/Px85Ofno6CgABMmTMDhw4dx+vRpxetMnz4dOp1OsS0sLEx6bLPZUFBQgK5duyI2NrbZuzn+97//YcSIEYiLi5Pan5+fj3HjxsFut+O3334DAMTGxqKiogI///yz39tw3333ubQpJiYGl156qaJNgwYNQmRkJFavXi21CQC+++472Gw2v7fLm9jYWGzatAlnzpxp0dclamkMboiCkBi0iEGOJ+og6LLLLkNMTAyWLVsmHbNs2TL0798f5513HgDgyJEjEAQBTz75JBITExX/5s2bBwDIzc1VvE6nTp1cXruqqgpz586Val4SEhKQmJiI4uJilJSUNPLKG+bw4cNYuXKlS/vHjRunaP/999+P8847D5dffjnatWuHadOmYeXKlU1+fb1eL9UeydtUUlKCpKQkl3aVl5dLbRo1ahRuvPFGPP3000hISMC1116LxYsXw2KxNLld9XnxxRexZ88epKenY8iQIXjqqafw559/NvvrErU01twQBaGYmBi0bdsWu3bt8nrcrl27kJaWhujoaACAyWTCddddhxUrVuCtt95CTk4O1q9fj+eee056jlhw+8gjj2DChAluz9u1a1fF1/Isjehvf/sbFi9ejJkzZ2LYsGGIiYmBRqPBrbfe6lLU628OhwOXXnopHn30Ubf7xUAuKSkJmZmZWLVqFX788Uf8+OOPWLx4MSZPnowPPvig0a9vMpmg1So/GzocDiQlJeGTTz5x+xyxKFyj0WD58uX4448/8O2332LVqlWYNm0aXnnlFfzxxx+IjIz0OCmf3W5vdJsB4JZbbsGIESOwYsUK/PTTT3jppZfwwgsv4Msvv8Tll1/epHMTBRMGN0RB6qqrrsJ7772HdevWYfjw4S77f//9d2RlZeGee+5RbJ84cSI++OADZGRkYP/+/RAEQeqSAiANGzcYDFKmozGWL1+OKVOm4JVXXpG2VVdXo7i4uNHnVPN0k+/SpQvKy8sb1H6j0Yirr74aV199NRwOB+6//3688847ePLJJ9G1a1e/ze7bpUsX/PLLL7j44ovdBoNqF154IS688EI8++yz+PTTT3H77bdj6dKluPvuuxEXFwcALt/L48ePN6gt3q6pbdu2uP/++3H//fcjNzcXAwcOxLPPPsvghkIKu6WIgtTf//53hIWF4Z577kFBQYFiX2FhIe69916Eh4fj73//u2LfuHHjEB8fj2XLlmHZsmUYMmSIolspKSkJo0ePxjvvvIOzZ8+6vG5eXl6D2qfT6SAIgmLb66+/3uTsglxERITbYOmWW27Bxo0bsWrVKpd9xcXFqKmpAQCX75tWq0Xfvn0BQOoGEuenaWpQdsstt8But+OZZ55x2VdTUyOdv6ioyOX71r9/f0WbOnToAJ1OJ9UOid56660GtcXd981ut7t0FyYlJSE1NbVFusSI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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\")"
   ]
  },
  {
   "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": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c00c0f05-739c-4e87-a931-a5f8c8325673",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "738de7ab-316f-4b0e-be8d-a78133a46922",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4638d9e-616a-4ad8-9613-9267608efbe7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60010eda-f81d-44f7-81cd-245b5eafaae6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5890a65-5c65-470e-af9e-9e49ade94a59",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6aa543d-dd7e-4ad5-87c7-13b542959c34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe79c3f3-5ebb-4b8b-905b-64827bcedbc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "022fd203-7baa-4c05-a7d2-3ff54320fef1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75c4f0cc-e742-4c59-adc0-bd9a67676ede",
   "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
}
