{
 "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",
      "5040\n",
      "[[  0 492]\n",
      " [  1 529]\n",
      " [  2 469]\n",
      " [  3 478]\n",
      " [  4 490]\n",
      " [  5 460]\n",
      " [  6 480]\n",
      " [  7 527]\n",
      " [  8 508]\n",
      " [  9 504]]\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": [
       "5074"
      ]
     },
     "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([4, 3, 4,  ..., 4, 8, 5])"
      ]
     },
     "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": [
      "5977\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 522]\n",
      " [  1 322]\n",
      " [  2 515]\n",
      " [  3 335]\n",
      " [  4 501]\n",
      " [  5 359]\n",
      " [  6 513]\n",
      " [  7 486]\n",
      " [  8 491]\n",
      " [  9 359]]\n",
      "[[  0 522]\n",
      " [  1 343]\n",
      " [  2 515]\n",
      " [  3 350]\n",
      " [  4 501]\n",
      " [  5 406]\n",
      " [  6 513]\n",
      " [  7 486]\n",
      " [  8 491]\n",
      " [  9 698]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([4, 3, 4,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\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": "93379500-b378-47bc-a32a-2e3c6a525702",
   "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.10009000000000001}, {'accuracy': 0.10772999999999999}, {'accuracy': 0.11108000000000003}, {'accuracy': 0.11491}, {'accuracy': 0.11321000000000003}, {'accuracy': 0.12800000000000003}, {'accuracy': 0.12098}, {'accuracy': 0.12732}, {'accuracy': 0.13446}, {'accuracy': 0.13506}, {'accuracy': 0.13677}, {'accuracy': 0.14654}, {'accuracy': 0.16474000000000003}, {'accuracy': 0.13468000000000002}, {'accuracy': 0.18164}, {'accuracy': 0.20648}, {'accuracy': 0.19438}, {'accuracy': 0.17772000000000002}, {'accuracy': 0.20292}, {'accuracy': 0.20572}, {'accuracy': 0.21498000000000003}, {'accuracy': 0.17836000000000002}, {'accuracy': 0.21116000000000001}, {'accuracy': 0.22645999999999997}, {'accuracy': 0.27547}, {'accuracy': 0.20272}, {'accuracy': 0.21333000000000002}, {'accuracy': 0.24731000000000006}, {'accuracy': 0.20406}, {'accuracy': 0.22546}, {'accuracy': 0.21703}, {'accuracy': 0.20448}, {'accuracy': 0.21017999999999998}, {'accuracy': 0.20476}, {'accuracy': 0.23522000000000004}, {'accuracy': 0.20632}, {'accuracy': 0.24449}, {'accuracy': 0.28056}, {'accuracy': 0.24827}, {'accuracy': 0.24380000000000002}, {'accuracy': 0.26332999999999995}, {'accuracy': 0.27612999999999993}, {'accuracy': 0.21387}, {'accuracy': 0.23670999999999998}, {'accuracy': 0.21128}, {'accuracy': 0.23635}, {'accuracy': 0.30711}, {'accuracy': 0.30243000000000003}, {'accuracy': 0.24026000000000006}, {'accuracy': 0.29654}, {'accuracy': 0.24074}, {'accuracy': 0.28427}, {'accuracy': 0.27682}, {'accuracy': 0.25159}, {'accuracy': 0.31582000000000005}, {'accuracy': 0.32283}, {'accuracy': 0.27608}, {'accuracy': 0.33447000000000005}, {'accuracy': 0.30243000000000003}, {'accuracy': 0.33793}, {'accuracy': 0.22290000000000001}, {'accuracy': 0.28588}, {'accuracy': 0.34293}, {'accuracy': 0.30588000000000004}, {'accuracy': 0.25084000000000006}, {'accuracy': 0.36157}, {'accuracy': 0.3674}, {'accuracy': 0.29317000000000004}, {'accuracy': 0.35732}, {'accuracy': 0.37557}, {'accuracy': 0.30082}, {'accuracy': 0.29807}, {'accuracy': 0.31036}, {'accuracy': 0.34615}, {'accuracy': 0.34412}, {'accuracy': 0.37002}, {'accuracy': 0.38183}, {'accuracy': 0.38139}, {'accuracy': 0.39964999999999995}, {'accuracy': 0.37793}, {'accuracy': 0.3309000000000001}, {'accuracy': 0.42108}, {'accuracy': 0.34021}, {'accuracy': 0.31079}, {'accuracy': 0.38811999999999997}, {'accuracy': 0.37459000000000003}, {'accuracy': 0.37096}, {'accuracy': 0.30098}, {'accuracy': 0.42115}, {'accuracy': 0.31584}, {'accuracy': 0.4359100000000001}, {'accuracy': 0.40705}, {'accuracy': 0.36696999999999996}, {'accuracy': 0.42533000000000004}, {'accuracy': 0.42481}, {'accuracy': 0.39608}, {'accuracy': 0.37733999999999995}, {'accuracy': 0.34767000000000003}, {'accuracy': 0.35757}, {'accuracy': 0.4401}, {'accuracy': 0.39699}, {'accuracy': 0.38069000000000003}, {'accuracy': 0.41880999999999996}, {'accuracy': 0.45332000000000006}, {'accuracy': 0.4046}, {'accuracy': 0.3669}, {'accuracy': 0.42339000000000004}, {'accuracy': 0.46114000000000005}, {'accuracy': 0.39109999999999995}, {'accuracy': 0.44813000000000003}, {'accuracy': 0.37650999999999996}, {'accuracy': 0.4112100000000001}, {'accuracy': 0.42118}, {'accuracy': 0.41151}, {'accuracy': 0.41825}, {'accuracy': 0.46437}, {'accuracy': 0.45976}, {'accuracy': 0.43156000000000005}, {'accuracy': 0.38674}, {'accuracy': 0.38627}, {'accuracy': 0.38705}, {'accuracy': 0.42245999999999995}, {'accuracy': 0.40354999999999996}, {'accuracy': 0.41638000000000003}, {'accuracy': 0.4721400000000001}, {'accuracy': 0.43576}, {'accuracy': 0.43572999999999995}, {'accuracy': 0.45492999999999995}, {'accuracy': 0.3812}, {'accuracy': 0.44738999999999995}, {'accuracy': 0.39818999999999993}, {'accuracy': 0.42973999999999996}, {'accuracy': 0.44602}, {'accuracy': 0.42821}, {'accuracy': 0.47605}, {'accuracy': 0.47843}, {'accuracy': 0.45603999999999995}, {'accuracy': 0.34394}, {'accuracy': 0.47230999999999995}, {'accuracy': 0.42831}, {'accuracy': 0.4625000000000001}, {'accuracy': 0.48308}, {'accuracy': 0.4434600000000001}, {'accuracy': 0.49460999999999994}, {'accuracy': 0.4013000000000001}, {'accuracy': 0.36190999999999995}, {'accuracy': 0.47809999999999997}, {'accuracy': 0.47766000000000003}, {'accuracy': 0.41234000000000004}, {'accuracy': 0.46179999999999993}, {'accuracy': 0.49467000000000005}, {'accuracy': 0.42493}, {'accuracy': 0.4258}, {'accuracy': 0.47852999999999996}, {'accuracy': 0.41501}, {'accuracy': 0.48058000000000006}, {'accuracy': 0.42957}, {'accuracy': 0.43415}, {'accuracy': 0.47161}, {'accuracy': 0.43709999999999993}, {'accuracy': 0.38905}, {'accuracy': 0.4896399999999999}, {'accuracy': 0.4717300000000001}, {'accuracy': 0.44426}, {'accuracy': 0.43543999999999994}, {'accuracy': 0.43168999999999996}, {'accuracy': 0.49359000000000003}, {'accuracy': 0.45137}, {'accuracy': 0.40607999999999994}, {'accuracy': 0.48429}, {'accuracy': 0.44681999999999994}, {'accuracy': 0.48342}, {'accuracy': 0.45287000000000005}, {'accuracy': 0.37277000000000005}, {'accuracy': 0.46879}, {'accuracy': 0.4707699999999999}, {'accuracy': 0.45038999999999996}, {'accuracy': 0.41567999999999994}, {'accuracy': 0.45009}, {'accuracy': 0.45131000000000004}, {'accuracy': 0.45185000000000003}, {'accuracy': 0.42652999999999996}, {'accuracy': 0.44138}, {'accuracy': 0.50614}, {'accuracy': 0.45332}, {'accuracy': 0.43651}, {'accuracy': 0.40218999999999994}, {'accuracy': 0.45044000000000006}, {'accuracy': 0.43777}, {'accuracy': 0.43735999999999997}, {'accuracy': 0.42145}, {'accuracy': 0.42532}, {'accuracy': 0.50844}, {'accuracy': 0.48647999999999997}, {'accuracy': 0.46125999999999995}, {'accuracy': 0.24376000000000003}, {'accuracy': 0.47408}, {'accuracy': 0.50031}, {'accuracy': 0.4965}, {'accuracy': 0.51555}, {'accuracy': 0.5190499999999999}, {'accuracy': 0.51829}, {'accuracy': 0.51758}, {'accuracy': 0.5210299999999999}, {'accuracy': 0.52621}, {'accuracy': 0.5256700000000001}, {'accuracy': 0.5202600000000001}, {'accuracy': 0.53006}, {'accuracy': 0.5214899999999999}, {'accuracy': 0.52459}, {'accuracy': 0.5284499999999999}, {'accuracy': 0.52963}, {'accuracy': 0.52461}, {'accuracy': 0.52349}, {'accuracy': 0.52334}, {'accuracy': 0.52256}, {'accuracy': 0.5348900000000001}, {'accuracy': 0.52035}, {'accuracy': 0.53551}, {'accuracy': 0.53481}, {'accuracy': 0.53636}, {'accuracy': 0.53547}, {'accuracy': 0.53429}, {'accuracy': 0.5399200000000001}, {'accuracy': 0.53974}, {'accuracy': 0.54295}, {'accuracy': 0.5428399999999999}, {'accuracy': 0.53146}, {'accuracy': 0.53392}, {'accuracy': 0.5105500000000001}, {'accuracy': 0.51925}, {'accuracy': 0.5271100000000001}, {'accuracy': 0.5282100000000001}, {'accuracy': 0.5317899999999999}, {'accuracy': 0.5357399999999999}, {'accuracy': 0.5419599999999999}, {'accuracy': 0.54274}, {'accuracy': 0.54308}, {'accuracy': 0.53779}, {'accuracy': 0.53943}, {'accuracy': 0.5284099999999999}, {'accuracy': 0.5397299999999999}, {'accuracy': 0.5302}, {'accuracy': 0.5235700000000001}, {'accuracy': 0.5363899999999999}, {'accuracy': 0.5442899999999999}, {'accuracy': 0.54101}, {'accuracy': 0.5450000000000002}, {'accuracy': 0.54583}, {'accuracy': 0.5456300000000001}, {'accuracy': 0.54364}, {'accuracy': 0.54463}, {'accuracy': 0.54212}, {'accuracy': 0.5436799999999999}, {'accuracy': 0.54507}, {'accuracy': 0.5387600000000001}, {'accuracy': 0.5442899999999999}, {'accuracy': 0.54167}, {'accuracy': 0.54524}, {'accuracy': 0.53994}, {'accuracy': 0.5427000000000001}, {'accuracy': 0.5417599999999999}, {'accuracy': 0.54247}, {'accuracy': 0.5399100000000001}, {'accuracy': 0.54198}, {'accuracy': 0.5442600000000001}, {'accuracy': 0.54301}, {'accuracy': 0.5415599999999999}, {'accuracy': 0.5419299999999999}, {'accuracy': 0.5439399999999999}, {'accuracy': 0.54085}, {'accuracy': 0.5384300000000001}, {'accuracy': 0.5357899999999999}, {'accuracy': 0.53563}, {'accuracy': 0.5433899999999999}, {'accuracy': 0.54131}, {'accuracy': 0.54098}, {'accuracy': 0.54111}, {'accuracy': 0.5422499999999999}, {'accuracy': 0.53554}, {'accuracy': 0.5354599999999999}, {'accuracy': 0.53724}, {'accuracy': 0.54369}, {'accuracy': 0.5375500000000001}, {'accuracy': 0.54311}, {'accuracy': 0.5462}, {'accuracy': 0.54661}, {'accuracy': 0.5448099999999999}, {'accuracy': 0.5471300000000001}, {'accuracy': 0.54393}, {'accuracy': 0.54443}, {'accuracy': 0.5464}, {'accuracy': 0.5455100000000002}, {'accuracy': 0.54052}, {'accuracy': 0.54457}, {'accuracy': 0.5435800000000001}, {'accuracy': 0.5443800000000001}, {'accuracy': 0.54062}, {'accuracy': 0.54581}, {'accuracy': 0.5480599999999999}, {'accuracy': 0.5457099999999999}, {'accuracy': 0.54299}, {'accuracy': 0.5386200000000001}, {'accuracy': 0.54433}, {'accuracy': 0.54522}, {'accuracy': 0.5447}, {'accuracy': 0.5426500000000001}, {'accuracy': 0.54541}, {'accuracy': 0.54417}, {'accuracy': 0.5433899999999999}, {'accuracy': 0.5441900000000001}, {'accuracy': 0.5323299999999999}, {'accuracy': 0.5413300000000001}, {'accuracy': 0.53417}, {'accuracy': 0.53725}, {'accuracy': 0.53706}, {'accuracy': 0.54136}, {'accuracy': 0.52717}, {'accuracy': 0.53562}, {'accuracy': 0.54518}, {'accuracy': 0.54718}, {'accuracy': 0.54583}, {'accuracy': 0.54889}, {'accuracy': 0.54708}, {'accuracy': 0.5464600000000001}, {'accuracy': 0.5414}, {'accuracy': 0.5498000000000001}, {'accuracy': 0.54361}, {'accuracy': 0.53944}, {'accuracy': 0.53756}, {'accuracy': 0.5399200000000001}, {'accuracy': 0.54295}, {'accuracy': 0.54789}, {'accuracy': 0.5477799999999999}, {'accuracy': 0.54616}, {'accuracy': 0.5485}, {'accuracy': 0.55001}, {'accuracy': 0.5462100000000001}, {'accuracy': 0.54708}, {'accuracy': 0.5491400000000001}, {'accuracy': 0.54832}, {'accuracy': 0.54348}, {'accuracy': 0.54376}, {'accuracy': 0.5439400000000001}, {'accuracy': 0.54969}, {'accuracy': 0.5400600000000001}, {'accuracy': 0.54093}, {'accuracy': 0.54268}, {'accuracy': 0.54337}, {'accuracy': 0.5459999999999999}, {'accuracy': 0.53993}, {'accuracy': 0.54447}, {'accuracy': 0.54448}, {'accuracy': 0.53433}, {'accuracy': 0.5414800000000001}, {'accuracy': 0.54789}, {'accuracy': 0.5444700000000001}, {'accuracy': 0.54754}, {'accuracy': 0.5407399999999999}, {'accuracy': 0.54847}, {'accuracy': 0.5476099999999999}, {'accuracy': 0.5455300000000001}, {'accuracy': 0.5460800000000001}, {'accuracy': 0.54525}, {'accuracy': 0.5474300000000001}, {'accuracy': 0.54438}, {'accuracy': 0.5445200000000001}, {'accuracy': 0.54261}, {'accuracy': 0.54912}, {'accuracy': 0.5382199999999999}, {'accuracy': 0.53877}, {'accuracy': 0.5307299999999999}, {'accuracy': 0.53166}, {'accuracy': 0.5393800000000001}, {'accuracy': 0.51741}, {'accuracy': 0.5345}, {'accuracy': 0.53586}, {'accuracy': 0.5282600000000002}, {'accuracy': 0.5450899999999999}, {'accuracy': 0.5475200000000001}, {'accuracy': 0.5482600000000001}, {'accuracy': 0.5457099999999999}, {'accuracy': 0.54403}, {'accuracy': 0.54939}, {'accuracy': 0.5426399999999999}, {'accuracy': 0.53815}, {'accuracy': 0.54342}, {'accuracy': 0.54015}, {'accuracy': 0.53864}, {'accuracy': 0.54779}, {'accuracy': 0.54677}, {'accuracy': 0.54631}, {'accuracy': 0.5497099999999999}, {'accuracy': 0.5482199999999999}, {'accuracy': 0.55033}]\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/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACRIElEQVR4nO3dd5gUVdYG8Lc6Tw5MHgYGGATJSRAEUUAxZ0VWBVFYE4ZlDbCuoLvrYlhdzOlbxXVVUNa0BgwIKEHJkhGQDJNz6ljfH91VXdVdPdMTe6b7/T0PjzPV1d23pkfqcM659wqiKIogIiIiChO6UA+AiIiIqDUxuCEiIqKwwuCGiIiIwgqDGyIiIgorDG6IiIgorDC4ISIiorDC4IaIiIjCCoMbIiIiCisMboiIiCisMLghoja1atUqCIKAVatWycduvvlm5ObmhmxM4eTRRx+FIAihHgZRh8LghqiD27VrF2688UZkZ2fDbDYjKysLN9xwA3bt2hXqobW5l19+GYsXL27T99i9ezceffRRHD58uE3fpz39/e9/xyeffBLqYRCFDIMbog7so48+wrBhw7BixQrMmDEDL7/8Mm699VasXLkSw4YNw8cffxzqIbap9gpuHnvsMQY3RGHEEOoBEJG2gwcP4qabbkLPnj3xww8/IDU1VX7s3nvvxbhx43DTTTdh+/bt6NmzZ7uNq6amBjExMe32fp0BfyZEHQszN0Qd1NNPP43a2lq8/vrrqsAGAFJSUvDaa6+hpqYGTz31FABg2bJlEAQBq1ev9nut1157DYIgYOfOnfKxvXv34pprrkFycjIsFgtGjBiBzz77TPW8xYsXy6955513Ii0tDV27dgUAHDlyBHfeeSf69OmDqKgodOnSBddee22rZUByc3Oxa9curF69GoIgQBAEnHPOOfLj5eXluO+++5CTkwOz2Yy8vDw8+eSTcLlcqtdZsmQJhg8fjri4OMTHx2PgwIF47rnn5Ou79tprAQDnnnuu/D7K/iBfN998M2JjY3Hw4EFcdNFFiIuLww033AAAcLlcWLRoEfr37w+LxYL09HTcdtttKCsrU73Gpk2bMHnyZKSkpCAqKgo9evTALbfcIj+u1acEAIcPH4YgCA1mswRBQE1NDd5++235em6++WYAQFVVFe677z7k5ubCbDYjLS0N5513HrZs2RLw9Yg6I2ZuiDqo//3vf8jNzcW4ceM0Hz/77LORm5uLL774AgBw8cUXIzY2Fh988AHGjx+vOnfp0qXo378/BgwYAMDdx3PWWWchOzsbc+fORUxMDD744ANcccUV+O9//4srr7xS9fw777wTqampmD9/PmpqagAAGzduxLp163D99deja9euOHz4MF555RWcc8452L17N6Kjo1t0/YsWLcLdd9+N2NhYPPzwwwCA9PR0AEBtbS3Gjx+PEydO4LbbbkO3bt2wbt06zJs3D6dOncKiRYsAAN9++y2mTp2KiRMn4sknnwQA7NmzB2vXrsW9996Ls88+G/fccw+ef/55/OlPf8Lpp58OAPJ/A3E4HJg8eTLGjh2Lf/zjH/K13nbbbVi8eDFmzJiBe+65B4cOHcKLL76IrVu3Yu3atTAajSgsLMT555+P1NRUzJ07F4mJiTh8+DA++uijFv28JO+88w5mzpyJkSNH4ve//z0AoFevXgCA22+/HcuWLcPs2bPRr18/lJSUYM2aNdizZw+GDRvWKu9P1CGIRNThlJeXiwDEyy+/vMHzLrvsMhGAWFlZKYqiKE6dOlVMS0sTHQ6HfM6pU6dEnU4n/uUvf5GPTZw4URw4cKBYX18vH3O5XOKYMWPE3r17y8feeustEYA4duxY1WuKoijW1tb6jWf9+vUiAPHf//63fGzlypUiAHHlypXysenTp4vdu3dv8NpEURT79+8vjh8/3u/4X//6VzEmJkb89ddfVcfnzp0r6vV68ejRo6IoiuK9994rxsfH+41d6cMPP/QbX0OmT58uAhDnzp2rOv7jjz+KAMR3331XdXz58uWq4x9//LEIQNy4cWPA99D6mYmiKB46dEgEIL711lvysQULFoi+f5XHxMSI06dP93vdhIQE8a677griKok6N5aliDqgqqoqAEBcXFyD50mPV1ZWAgCmTJmCwsJCVTlj2bJlcLlcmDJlCgCgtLQU33//Pa677jpUVVWhuLgYxcXFKCkpweTJk7F//36cOHFC9T6zZs2CXq9XHYuKipK/ttvtKCkpQV5eHhITE9u8zPHhhx9i3LhxSEpKksdfXFyMSZMmwel04ocffgAAJCYmoqamBt9++22rj+GOO+7wG1NCQgLOO+881ZiGDx+O2NhYrFy5Uh4TAHz++eew2+2tPq6GJCYm4ueff8bJkyfb9X2J2huDG6IOSApapCAnEN8g6IILLkBCQgKWLl0qn7N06VIMGTIEp512GgDgwIEDEEURjzzyCFJTU1V/FixYAAAoLCxUvU+PHj383ruurg7z58+Xe15SUlKQmpqK8vJyVFRUNPPKg7N//34sX77cb/yTJk1Sjf/OO+/EaaedhgsvvBBdu3bFLbfcguXLl7f4/Q0Gg9x7pBxTRUUF0tLS/MZVXV0tj2n8+PG4+uqr8dhjjyElJQWXX3453nrrLVit1haPqzFPPfUUdu7ciZycHIwcORKPPvoofvvttzZ/X6L2xp4bog4oISEBmZmZ2L59e4Pnbd++HdnZ2YiPjwcAmM1mXHHFFfj444/x8ssvo6CgAGvXrsXf//53+TlSw+3999+PyZMna75uXl6e6ntllkZy991346233sJ9992H0aNHIyEhAYIg4Prrr/dr6m1tLpcL5513Hh588EHNx6VALi0tDdu2bcPXX3+Nr776Cl999RXeeustTJs2DW+//Xaz399sNkOnU//b0OVyIS0tDe+++67mc6SmcEEQsGzZMvz000/43//+h6+//hq33HILnnnmGfz000+IjY0NuCif0+ls9pgB4LrrrsO4cePw8ccf45tvvsHTTz+NJ598Eh999BEuvPDCFr02UUfC4Iaog7rkkkvwxhtvYM2aNRg7dqzf4z/++CMOHz6M2267TXV8ypQpePvtt7FixQrs2bMHoijKJSkA8rRxo9EoZzqaY9myZZg+fTqeeeYZ+Vh9fT3Ky8ub/Zq+At3ke/Xqherq6qDGbzKZcOmll+LSSy+Fy+XCnXfeiddeew2PPPII8vLyWm113169euG7777DWWedpRkM+jrzzDNx5pln4vHHH8d7772HG264AUuWLMHMmTORlJQEAH4/yyNHjgQ1loauKTMzE3feeSfuvPNOFBYWYtiwYXj88ccZ3FBYYVmKqIN64IEHEBUVhdtuuw0lJSWqx0pLS3H77bcjOjoaDzzwgOqxSZMmITk5GUuXLsXSpUsxcuRIVVkpLS0N55xzDl577TWcOnXK732LioqCGp9er4coiqpjL7zwQouzC0oxMTGawdJ1112H9evX4+uvv/Z7rLy8HA6HAwD8fm46nQ6DBg0CALkMJK1P09Kg7LrrroPT6cRf//pXv8ccDof8+mVlZX4/tyFDhqjG1L17d+j1erl3SPLyyy8HNRatn5vT6fQrF6alpSErK6tdSmJE7YmZG6IOqnfv3nj77bdxww03YODAgbj11lvRo0cPHD58GP/6179QXFyM999/X57mKzEajbjqqquwZMkS1NTU4B//+Iffa7/00ksYO3YsBg4ciFmzZqFnz54oKCjA+vXrcfz4cfzyyy+Nju+SSy7BO++8g4SEBPTr1w/r16/Hd999hy5durTaz2D48OF45ZVX8Le//Q15eXlIS0vDhAkT8MADD+Czzz7DJZdcgptvvhnDhw9HTU0NduzYgWXLluHw4cNISUnBzJkzUVpaigkTJqBr1644cuQIXnjhBQwZMkSe7j1kyBDo9Xo8+eSTqKiogNlsxoQJE5CWltaksY4fPx633XYbFi5ciG3btuH888+H0WjE/v378eGHH+K5557DNddcg7fffhsvv/wyrrzySvTq1QtVVVV44403EB8fj4suugiAuyx57bXX4oUXXoAgCOjVqxc+//xzv16ohn5u3333HZ599llkZWWhR48e6NOnD7p27YprrrkGgwcPRmxsLL777jts3LhRlX0jCguhnaxFRI3Zvn27OHXqVDEzM1M0Go1iRkaGOHXqVHHHjh0Bn/Ptt9+KAERBEMRjx45pnnPw4EFx2rRpYkZGhmg0GsXs7GzxkksuEZctWyafI00F15q2XFZWJs6YMUNMSUkRY2NjxcmTJ4t79+4Vu3fvrpqG3JKp4Pn5+eLFF18sxsXFiQBU08KrqqrEefPmiXl5eaLJZBJTUlLEMWPGiP/4xz9Em80miqIoLlu2TDz//PPFtLQ00WQyid26dRNvu+028dSpU6r3eeONN8SePXuKer2+0Wnh06dPF2NiYgI+/vrrr4vDhw8Xo6KixLi4OHHgwIHigw8+KJ48eVIURVHcsmWLOHXqVLFbt26i2WwW09LSxEsuuUTctGmT6nWKiorEq6++WoyOjhaTkpLE2267Tdy5c2dQU8H37t0rnn322WJUVJQIQJw+fbpotVrFBx54QBw8eLAYFxcnxsTEiIMHDxZffvnlhj4Cok5JEEWf/CgRERFRJ8aeGyIiIgorDG6IiIgorDC4ISIiorDC4IaIiIjCCoMbIiIiCisMboiIiCisRNwifi6XCydPnkRcXFyrLbtOREREbUsURVRVVSErK8tvbzdfERfcnDx5Ejk5OaEeBhERETXDsWPH0LVr1wbPibjgJi4uDoD7hyPt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hRfEbt26iSaTSRw5cqT4008/hXpIzTZlyhQxMzNTNJlMYnZ2tjhlyhTxwIED8uN1dXXinXfeKSYlJYnR0dHilVdeKZ46dSqEI27YypUrRQB+f6ZPny6Kons6+COPPCKmp6eLZrNZnDhxorhv3z7Va5SUlIhTp04VY2Njxfj4eHHGjBliVVVVCK5GW0PXWFtbK55//vliamqqaDQaxe7du4uzZs3yC7478jVqXRsA8a233pLPCeb38vDhw+KFF14oRkVFiSkpKeIf//hH0W63t/PV+Gvs+o4ePSqeffbZYnJysmg2m8W8vDzxgQceUK2TIood9/pEURRvueUWsXv37qLJZBJTU1PFiRMnyoGNKHbuz08UG76+cPj8tPgGNx3tMxREURRbPx9EREREFBrsuSEiIqKwwuCGiIiIwgqDGyIiIgorDG6IiIgorDC4ISIiorDC4IaIiIjCCoMbIiIiCisMbogoIqxatQqCIPjtf0NE4YfBDREREYUVBjdEREQUVhjcEFGH4nK58NRTTyEvLw9msxndunXD448/jgkTJmD27Nmqc4uKimAymeTdiK1WKx566CHk5OTAbDYjLy8P//rXvwK+15o1azBu3DhERUUhJycH99xzD2pqatr0+oio7TG4IaIOZd68eXjiiSfwyCOPYPfu3XjvvfeQnp6OmTNn4r333oPVapXP/c9//oPs7GxMmDABADBt2jS8//77eP7557Fnzx689tpriI2N1XyfgwcP4oILLsDVV1+N7du3Y+nSpVizZo1fAEVEnQ83ziSiDqOqqgqpqal48cUXMXPmTNVj9fX1yMrKwquvvorrrrsOADB48GBcddVVWLBgAX799Vf06dMH3377LSZNmuT32qtWrcK5556LsrIyJCYmYubMmdDr9Xjttdfkc9asWYPx48ejpqYGFoulbS+WiNoMMzdE1GHs2bMHVqsVEydO9HvMYrHgpptuwptvvgkA2LJlC3bu3Imbb74ZALBt2zbo9XqMHz8+qPf65ZdfsHjxYsTGxsp/Jk+eDJfLhUOHDrXaNRFR+zOEegBERJKoqKgGH585cyaGDBmC48eP46233sKECRPQvXv3oJ7rq7q6Grfddhvuuecev8e6devWpNcioo6FmRsi6jB69+6NqKgouUHY18CBAzFixAi88cYbeO+993DLLbeoHnO5XFi9enVQ7zVs2DDs3r0beXl5fn9MJlOrXA8RhQaDGyLqMCwWCx566CE8+OCD+Pe//42DBw/ip59+Us14mjlzJp544gmIoogrr7xSPp6bm4vp06fjlltuwSeffIJDhw5h1apV+OCDDzTf66GHHsK6deswe/ZsbNu2Dfv378enn37KhmKiMMDghog6lEceeQR//OMfMX/+fJx++umYMmUKCgsL5cenTp0Kg8GAqVOn+jX9vvLKK7jmmmtw5513om/fvpg1a1bAqd2DBg3C6tWr8euvv2LcuHEYOnQo5s+fj6ysrDa9PiJqe5wtRUSdyuHDh9GrVy9s3LgRw4YNC/VwiKgDYnBDRJ2C3W5HSUkJ7r//fhw6dAhr164N9ZCIqINiWYqIOoW1a9ciMzMTGzduxKuvvhrq4RBRB8bMDREREYUVZm6IiIgorDC4ISIiorDC4IaIiIjCCoMbIiIiCisMboiIiCisMLghIiKisMLghoiIiMIKgxsiIiIKKwxuiIiIKKz8Px/L5uK+KFS3AAAAAElFTkSuQmCC",
      "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": "2d6788ca-edf3-4f07-9fc7-9f66d535d304",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1f0e77c-9e66-4be7-ac44-bcf7948d348a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0c7c843-4d33-4623-b0b1-e1d8f951e214",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb2f2f9e-0f0b-47cc-ac95-88a90b35cb64",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0bdc8ac1-0aee-4ce9-97ca-d78cdd1ec988",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d4d6f13-f5cf-4256-9628-0881a27996ed",
   "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
}
