{
 "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",
      "5003\n",
      "[[  0 491]\n",
      " [  1 511]\n",
      " [  2 510]\n",
      " [  3 514]\n",
      " [  4 521]\n",
      " [  5 483]\n",
      " [  6 498]\n",
      " [  7 553]\n",
      " [  8 555]\n",
      " [  9 515]]\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": [
       "5005"
      ]
     },
     "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([7, 7, 7,  ..., 2, 3, 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": [
      "9971\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 504]\n",
      " [  1 247]\n",
      " [  2 475]\n",
      " [  3 253]\n",
      " [  4 508]\n",
      " [  5 246]\n",
      " [  6 528]\n",
      " [  7 461]\n",
      " [  8 494]\n",
      " [  9 287]]\n",
      "[[  0 504]\n",
      " [  1 275]\n",
      " [  2 475]\n",
      " [  3 289]\n",
      " [  4 508]\n",
      " [  5 324]\n",
      " [  6 528]\n",
      " [  7 461]\n",
      " [  8 494]\n",
      " [  9 835]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([7, 7, 7,  ..., 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<5:\n",
    "        if target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(9))\n",
    "        \n",
    "        elif target1[z]==9:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(1))      \n",
    "        \n",
    "        elif target1[z]==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",
    "            noiseyset[1].append(torch.tensor(5))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==5:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(3))     \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[1][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[1][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": "97f19ee9-e676-4bce-badb-08e901fa5fea",
   "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.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10595000000000002}, {'accuracy': 0.10009000000000001}, {'accuracy': 0.10747999999999999}, {'accuracy': 0.10330999999999999}, {'accuracy': 0.11186}, {'accuracy': 0.12349000000000002}, {'accuracy': 0.12182}, {'accuracy': 0.13530000000000003}, {'accuracy': 0.13054000000000002}, {'accuracy': 0.11614}, {'accuracy': 0.1628}, {'accuracy': 0.14794000000000002}, {'accuracy': 0.11882000000000001}, {'accuracy': 0.13030000000000003}, {'accuracy': 0.13526000000000002}, {'accuracy': 0.13476}, {'accuracy': 0.17185}, {'accuracy': 0.16433000000000003}, {'accuracy': 0.20656}, {'accuracy': 0.19312}, {'accuracy': 0.19192000000000004}, {'accuracy': 0.17739999999999997}, {'accuracy': 0.14215999999999998}, {'accuracy': 0.18221000000000004}, {'accuracy': 0.19363}, {'accuracy': 0.22442}, {'accuracy': 0.1919}, {'accuracy': 0.21427999999999997}, {'accuracy': 0.22358000000000003}, {'accuracy': 0.23498999999999998}, {'accuracy': 0.20012}, {'accuracy': 0.23764000000000002}, {'accuracy': 0.19913}, {'accuracy': 0.21619000000000002}, {'accuracy': 0.16996}, {'accuracy': 0.17332}, {'accuracy': 0.17404000000000003}, {'accuracy': 0.20592000000000002}, {'accuracy': 0.22444000000000003}, {'accuracy': 0.18985999999999997}, {'accuracy': 0.25455}, {'accuracy': 0.21987}, {'accuracy': 0.22769}, {'accuracy': 0.1654}, {'accuracy': 0.25089}, {'accuracy': 0.25565000000000004}, {'accuracy': 0.24322000000000005}, {'accuracy': 0.29029}, {'accuracy': 0.25062}, {'accuracy': 0.26217}, {'accuracy': 0.28317000000000003}, {'accuracy': 0.29779}, {'accuracy': 0.30998000000000003}, {'accuracy': 0.23056000000000001}, {'accuracy': 0.22507000000000002}, {'accuracy': 0.33991999999999994}, {'accuracy': 0.28259}, {'accuracy': 0.2932}, {'accuracy': 0.24292000000000002}, {'accuracy': 0.30287000000000003}, {'accuracy': 0.29449999999999993}, {'accuracy': 0.27743}, {'accuracy': 0.2892}, {'accuracy': 0.28241}, {'accuracy': 0.28453000000000006}, {'accuracy': 0.29094}, {'accuracy': 0.32696}, {'accuracy': 0.31106}, {'accuracy': 0.31896}, {'accuracy': 0.27935}, {'accuracy': 0.34968000000000005}, {'accuracy': 0.30282}, {'accuracy': 0.27393999999999996}, {'accuracy': 0.3428}, {'accuracy': 0.25166}, {'accuracy': 0.29942}, {'accuracy': 0.34144}, {'accuracy': 0.27247}, {'accuracy': 0.23098000000000002}, {'accuracy': 0.28963}, {'accuracy': 0.27791}, {'accuracy': 0.35066}, {'accuracy': 0.32376999999999995}, {'accuracy': 0.27186999999999995}, {'accuracy': 0.33777}, {'accuracy': 0.27697}, {'accuracy': 0.37832}, {'accuracy': 0.30157999999999996}, {'accuracy': 0.3503}, {'accuracy': 0.30911}, {'accuracy': 0.31043000000000004}, {'accuracy': 0.33404}, {'accuracy': 0.32448}, {'accuracy': 0.37496}, {'accuracy': 0.34364}, {'accuracy': 0.32184}, {'accuracy': 0.36188}, {'accuracy': 0.34863}, {'accuracy': 0.35494}, {'accuracy': 0.29306}, {'accuracy': 0.37265}, {'accuracy': 0.33743999999999996}, {'accuracy': 0.382}, {'accuracy': 0.35368}, {'accuracy': 0.36815000000000003}, {'accuracy': 0.34495000000000003}, {'accuracy': 0.36436}, {'accuracy': 0.38586}, {'accuracy': 0.35708}, {'accuracy': 0.40569000000000005}, {'accuracy': 0.37976}, {'accuracy': 0.41871}, {'accuracy': 0.3637}, {'accuracy': 0.37749}, {'accuracy': 0.4385899999999999}, {'accuracy': 0.35766}, {'accuracy': 0.41044}, {'accuracy': 0.40801999999999994}, {'accuracy': 0.36041}, {'accuracy': 0.42810999999999994}, {'accuracy': 0.3777400000000001}, {'accuracy': 0.3719}, {'accuracy': 0.39421999999999996}, {'accuracy': 0.39116}, {'accuracy': 0.42206}, {'accuracy': 0.37439}, {'accuracy': 0.41348}, {'accuracy': 0.41685}, {'accuracy': 0.41958}, {'accuracy': 0.37551999999999996}, {'accuracy': 0.38003}, {'accuracy': 0.37899000000000005}, {'accuracy': 0.41699}, {'accuracy': 0.39073}, {'accuracy': 0.38205}, {'accuracy': 0.42013}, {'accuracy': 0.4276000000000001}, {'accuracy': 0.39831000000000005}, {'accuracy': 0.41685999999999995}, {'accuracy': 0.41796999999999995}, {'accuracy': 0.4037}, {'accuracy': 0.43426}, {'accuracy': 0.42614}, {'accuracy': 0.43582}, {'accuracy': 0.41784}, {'accuracy': 0.4413600000000001}, {'accuracy': 0.44553000000000004}, {'accuracy': 0.43319}, {'accuracy': 0.39862000000000003}, {'accuracy': 0.45694}, {'accuracy': 0.44353}, {'accuracy': 0.43081}, {'accuracy': 0.42121}, {'accuracy': 0.40998999999999997}, {'accuracy': 0.4364199999999999}, {'accuracy': 0.42384000000000005}, {'accuracy': 0.44286999999999993}, {'accuracy': 0.43672000000000005}, {'accuracy': 0.43552}, {'accuracy': 0.45848999999999995}, {'accuracy': 0.44378}, {'accuracy': 0.399}, {'accuracy': 0.43959000000000004}, {'accuracy': 0.43934999999999996}, {'accuracy': 0.43167}, {'accuracy': 0.44575999999999993}, {'accuracy': 0.4466}, {'accuracy': 0.44451999999999997}, {'accuracy': 0.40973999999999994}, {'accuracy': 0.43971}, {'accuracy': 0.46089}, {'accuracy': 0.44894}, {'accuracy': 0.4618199999999999}, {'accuracy': 0.44315}, {'accuracy': 0.4522399999999999}, {'accuracy': 0.43571}, {'accuracy': 0.45535000000000003}, {'accuracy': 0.45481}, {'accuracy': 0.44902999999999993}, {'accuracy': 0.45004999999999995}, {'accuracy': 0.4396999999999999}, {'accuracy': 0.43037000000000003}, {'accuracy': 0.45289999999999997}, {'accuracy': 0.43426}, {'accuracy': 0.47104}, {'accuracy': 0.45095999999999997}, {'accuracy': 0.41731999999999997}, {'accuracy': 0.43714000000000003}, {'accuracy': 0.43724999999999997}, {'accuracy': 0.42973}, {'accuracy': 0.42024999999999996}, {'accuracy': 0.50552}, {'accuracy': 0.50081}, {'accuracy': 0.50505}, {'accuracy': 0.50937}, {'accuracy': 0.51359}, {'accuracy': 0.5088299999999999}, {'accuracy': 0.51593}, {'accuracy': 0.5092699999999999}, {'accuracy': 0.50602}, {'accuracy': 0.5064799999999999}, {'accuracy': 0.5106200000000001}, {'accuracy': 0.5054100000000001}, {'accuracy': 0.5098100000000001}, {'accuracy': 0.51237}, {'accuracy': 0.50679}, {'accuracy': 0.50751}, {'accuracy': 0.5209900000000001}, {'accuracy': 0.51689}, {'accuracy': 0.5173100000000002}, {'accuracy': 0.5145199999999999}, {'accuracy': 0.51807}, {'accuracy': 0.5229600000000001}, {'accuracy': 0.52234}, {'accuracy': 0.5135}, {'accuracy': 0.51261}, {'accuracy': 0.5176200000000001}, {'accuracy': 0.5199}, {'accuracy': 0.51277}, {'accuracy': 0.52337}, {'accuracy': 0.52413}, {'accuracy': 0.5218400000000001}, {'accuracy': 0.52565}, {'accuracy': 0.52503}, {'accuracy': 0.5250000000000001}, {'accuracy': 0.5231999999999999}, {'accuracy': 0.51472}, {'accuracy': 0.5236799999999999}, {'accuracy': 0.51347}, {'accuracy': 0.51958}, {'accuracy': 0.5194000000000001}, {'accuracy': 0.5246600000000001}, {'accuracy': 0.52383}, {'accuracy': 0.5279800000000001}, {'accuracy': 0.52408}, {'accuracy': 0.52525}, {'accuracy': 0.5286599999999999}, {'accuracy': 0.52745}, {'accuracy': 0.52551}, {'accuracy': 0.51736}, {'accuracy': 0.52654}, {'accuracy': 0.52589}, {'accuracy': 0.52761}, {'accuracy': 0.5294899999999999}, {'accuracy': 0.5250900000000001}, {'accuracy': 0.52608}, {'accuracy': 0.52425}, {'accuracy': 0.52906}, {'accuracy': 0.5278799999999999}, {'accuracy': 0.52654}, {'accuracy': 0.52586}, {'accuracy': 0.5288600000000001}, {'accuracy': 0.5261800000000001}, {'accuracy': 0.52647}, {'accuracy': 0.5283100000000001}, {'accuracy': 0.5279}, {'accuracy': 0.53008}, {'accuracy': 0.5288999999999999}, {'accuracy': 0.52782}, {'accuracy': 0.52701}, {'accuracy': 0.52888}, {'accuracy': 0.52907}, {'accuracy': 0.5267200000000001}, {'accuracy': 0.52114}, {'accuracy': 0.5286299999999999}, {'accuracy': 0.5287}, {'accuracy': 0.53045}, {'accuracy': 0.5276500000000001}, {'accuracy': 0.5282899999999999}, {'accuracy': 0.5270299999999999}, {'accuracy': 0.52795}, {'accuracy': 0.5279999999999999}, {'accuracy': 0.52918}, {'accuracy': 0.5265200000000001}, {'accuracy': 0.52669}, {'accuracy': 0.52778}, {'accuracy': 0.52775}, {'accuracy': 0.52665}, {'accuracy': 0.52893}, {'accuracy': 0.5261}, {'accuracy': 0.5266900000000001}, {'accuracy': 0.5261699999999999}, {'accuracy': 0.5261399999999999}, {'accuracy': 0.51671}, {'accuracy': 0.52681}, {'accuracy': 0.5252800000000001}, {'accuracy': 0.5289699999999999}, {'accuracy': 0.5254300000000001}, {'accuracy': 0.52285}, {'accuracy': 0.52993}, {'accuracy': 0.5254300000000001}, {'accuracy': 0.49724}, {'accuracy': 0.52281}, {'accuracy': 0.5214000000000001}, {'accuracy': 0.52864}, {'accuracy': 0.5296899999999999}, {'accuracy': 0.52857}, {'accuracy': 0.5297600000000001}, {'accuracy': 0.53042}, {'accuracy': 0.5316500000000001}, {'accuracy': 0.5304}, {'accuracy': 0.52993}, {'accuracy': 0.52801}, {'accuracy': 0.5282399999999999}, {'accuracy': 0.52766}, {'accuracy': 0.52945}, {'accuracy': 0.52749}, {'accuracy': 0.52713}, {'accuracy': 0.52729}, {'accuracy': 0.52734}, {'accuracy': 0.52513}, {'accuracy': 0.52852}, {'accuracy': 0.5283399999999999}, {'accuracy': 0.5287399999999998}, {'accuracy': 0.52887}, {'accuracy': 0.52807}, {'accuracy': 0.52611}, {'accuracy': 0.52756}, {'accuracy': 0.5197800000000001}, {'accuracy': 0.5227299999999999}, {'accuracy': 0.5292300000000001}, {'accuracy': 0.5312999999999999}, {'accuracy': 0.52644}, {'accuracy': 0.5251300000000001}, {'accuracy': 0.5295300000000001}, {'accuracy': 0.52728}, {'accuracy': 0.52705}, {'accuracy': 0.5263899999999999}, {'accuracy': 0.5244}, {'accuracy': 0.52678}, {'accuracy': 0.5273899999999999}, {'accuracy': 0.52582}, {'accuracy': 0.52736}, {'accuracy': 0.5276}, {'accuracy': 0.5257400000000001}, {'accuracy': 0.5279700000000002}, {'accuracy': 0.5281800000000001}, {'accuracy': 0.52596}, {'accuracy': 0.52517}, {'accuracy': 0.52352}, {'accuracy': 0.52652}, {'accuracy': 0.5267299999999999}, {'accuracy': 0.52635}, {'accuracy': 0.52564}, {'accuracy': 0.51954}, {'accuracy': 0.517}, {'accuracy': 0.52668}, {'accuracy': 0.52554}, {'accuracy': 0.5256}, {'accuracy': 0.52643}, {'accuracy': 0.5292999999999999}, {'accuracy': 0.5292399999999999}, {'accuracy': 0.52757}, {'accuracy': 0.52672}, {'accuracy': 0.5282899999999999}, {'accuracy': 0.52952}, {'accuracy': 0.53025}, {'accuracy': 0.52759}, {'accuracy': 0.5303500000000001}, {'accuracy': 0.52792}, {'accuracy': 0.52619}, {'accuracy': 0.5295}, {'accuracy': 0.5269}, {'accuracy': 0.5302}, {'accuracy': 0.52664}, {'accuracy': 0.5279200000000001}, {'accuracy': 0.52814}, {'accuracy': 0.52723}, {'accuracy': 0.5286700000000001}, {'accuracy': 0.53074}, {'accuracy': 0.52996}, {'accuracy': 0.529}, {'accuracy': 0.5303800000000001}, {'accuracy': 0.52539}, {'accuracy': 0.5293699999999999}, {'accuracy': 0.5243599999999999}, {'accuracy': 0.52622}, {'accuracy': 0.52757}, {'accuracy': 0.5221899999999999}, {'accuracy': 0.5170300000000001}, {'accuracy': 0.5130399999999999}, {'accuracy': 0.52093}, {'accuracy': 0.52652}, {'accuracy': 0.5284599999999999}, {'accuracy': 0.52758}, {'accuracy': 0.5262399999999999}, {'accuracy': 0.52376}, {'accuracy': 0.52614}, {'accuracy': 0.52689}, {'accuracy': 0.5269800000000001}]\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": "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WyZes2zZMvTs2RPt27cHABw/fhyCIOCZZ55BTEyM7GPOnDkAgJycHNnrtGnTxuW1KyoqMHv2bLHnJTo6GjExMSgsLERRUdEl3rl3jh07hhUrVriMPyMjQzb+qVOnon379rj66quRnJyMu+++GytWrKj166vVarH3SDqmoqIixMbGuoyrtLRUHNOwYcNwyy234LnnnkN0dDRuvPFGLF68GAaDodbjqsmrr76K/fv3IyUlBf369cOzzz6Lv//+u95fl6ihseeGyA9FREQgISEBe/furfa6vXv3IikpCeHh4QAAnU6Hm266Cd9++y3eeecdZGdnY+PGjXjppZfEx9gbbh977DGMHj3a7fOmp6fLvpZmaeweeughLF68GNOnT8eAAQMQEREBhUKBO+64w6Wpt65ZrVZceeWVeOKJJ9yetwdysbGx2L17N1auXIlff/0Vv/76KxYvXowJEybgo48+uuTX1+l0UCrlfxtarVbExsbis88+c/sYe1O4QqHA8uXLsWXLFvz4449YuXIl7r77brzxxhvYsmULQkNDPS7KZ7FYLnnMAHD77bdjyJAh+Pbbb/Hbb7/htddewyuvvIJvvvkGV199da2em8ifMLgh8lPXXXcdFi5ciA0bNmDw4MEu5//880+cOnUKU6ZMkR0fO3YsPvroI6xevRqHDh2CIAhiSQqAOG1co9GImY5LsXz5ckycOBFvvPGGeKyyshKFhYWX/JzOPP2ST0tLQ2lpqVfj12q1uP7663H99dfDarVi6tSpeO+99/DMM88gPT29zlb3TUtLw++//45Bgwa5DQadXX755bj88svx4osv4vPPP8f48eOxdOlS3HvvvYiKigIAl/+Xp0+f9mos1d1TQkICpk6diqlTpyInJwe9e/fGiy++yOCGAgrLUkR+6vHHH0dQUBCmTJmC/Px82bmCggLcf//9CA4OxuOPPy47l5GRgRYtWmDZsmVYtmwZ+vXrJysrxcbGYvjw4Xjvvfdw4cIFl9fNzc31anwqlQqCIMiO/e9//6t1dkEqJCTEbbB0++23Y/PmzVi5cqXLucLCQpjNZgBw+f+mVCrRvXt3ABDLQPb1aWoblN1+++2wWCx44YUXXM6ZzWbx+S9evOjy/61nz56yMbVu3RoqlUrsHbJ75513vBqLu/9vFovFpVwYGxuLxMTEBimJETUkZm6I/FS7du3w0UcfYfz48ejWrRvuuecetGnTBqdOncKHH36IvLw8fPHFF+I0XzuNRoObb74ZS5cuRVlZGV5//XWX53777bcxePBgdOvWDZMnT0bbtm2RnZ2NzZs34+zZs9izZ0+N47vuuuvwySefICIiAp07d8bmzZvx+++/o2XLlnX2/6BPnz5499138Z///Afp6emIjY3FiBEj8Pjjj+OHH37Addddh7vuugt9+vRBWVkZ9u3bh+XLl+PUqVOIjo7Gvffei4KCAowYMQLJyck4ffo0/ve//6Fnz57idO+ePXtCpVLhlVdeQVFREXQ6HUaMGIHY2Fifxjps2DBMmTIFc+fOxe7duzFq1ChoNBocO3YMX331Fd58803ceuut+Oijj/DOO+9gzJgxSEtLQ0lJCRYuXIjw8HBcc801AGxlydtuuw3/+9//oFAokJaWhp9++smlF6q6/2+///475s2bh8TERLRp0wYdOnRAcnIybr31VvTo0QOhoaH4/fffsW3bNln2jSggNO5kLSKqyd69e4Vx48YJCQkJgkajEeLj44Vx48YJ+/bt8/iYVatWCQAEhUIhnDlzxu01J06cECZMmCDEx8cLGo1GSEpKEq677jph+fLl4jX2qeDupi1fvHhRmDRpkhAdHS2EhoYKo0ePFg4fPiy0bt1aNg25NlPBs7KyhGuvvVYICwsTAMimhZeUlAizZs0S0tPTBa1WK0RHRwsDBw4UXn/9dcFoNAqCIAjLly8XRo0aJcTGxgparVZo1aqVMGXKFOHChQuy11m4cKHQtm1bQaVS1TgtfOLEiUJISIjH8++//77Qp08fISgoSAgLCxO6desmPPHEE8L58+cFQRCEnTt3CuPGjRNatWol6HQ6ITY2VrjuuuuE7du3y54nNzdXuOWWW4Tg4GAhKipKmDJlirB//36vpoIfPnxYGDp0qBAUFCQAECZOnCgYDAbh8ccfF3r06CGEhYUJISEhQo8ePYR33nmnureAqElSCIJTfpSIiIioCWPPDREREQUUBjdEREQUUBjcEBERUUBhcENEREQBhcENERERBRQGN0RERBRQmt0iflarFefPn0dYWFidLbtORERE9UsQBJSUlCAxMdFlbzdnzS64OX/+PFJSUhp7GERERHQJzpw5g+Tk5GqvaXbBTVhYGADb/xz7TspERETk34qLi5GSkiL+Hq9Oswtu7KWo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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": "5183c190-b08b-44d2-802d-c9d613a7ea2b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b51fd015-97b9-4e1d-8cc1-e35f4dd33a54",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96c40280-5bb9-4c00-814b-483f7c808608",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d694fc0-2335-4668-895f-84073d43662c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca42476c-5f0a-4499-8846-a67fe4450ca1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3c0c1bc-ceaa-4502-8f9d-94f38efae249",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c497876a-2a39-4e29-8900-4aad092f57f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75570d1b-d2af-42b1-a4f1-cf39049ebcd1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88df68fc-58af-43f6-b527-17de081a9425",
   "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
}
