{
 "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",
      "5113\n",
      "[[  0 490]\n",
      " [  1 482]\n",
      " [  2 476]\n",
      " [  3 529]\n",
      " [  4 526]\n",
      " [  5 482]\n",
      " [  6 480]\n",
      " [  7 514]\n",
      " [  8 466]\n",
      " [  9 499]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4977"
      ]
     },
     "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([2, 7, 2,  ..., 5, 8, 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": [
      "24937\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 262]\n",
      " [  1 274]\n",
      " [  2 268]\n",
      " [  3 240]\n",
      " [  4 239]\n",
      " [  5 263]\n",
      " [  6 252]\n",
      " [  7 214]\n",
      " [  8 258]\n",
      " [  9 237]]\n",
      "[[   0 1254]\n",
      " [   1  302]\n",
      " [   2  294]\n",
      " [   3  267]\n",
      " [   4  285]\n",
      " [   5  355]\n",
      " [   6  394]\n",
      " [   7  442]\n",
      " [   8  613]\n",
      " [   9  832]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([2, 7, 6,  ..., 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",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffb17946-59dc-42f0-8a18-11e2c5ff3686",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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.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.1}, {'accuracy': 0.11444000000000001}, {'accuracy': 0.1}, {'accuracy': 0.10722000000000001}, {'accuracy': 0.10773999999999999}, {'accuracy': 0.1}, {'accuracy': 0.10002}, {'accuracy': 0.10888}, {'accuracy': 0.11732000000000001}, {'accuracy': 0.10930999999999999}, {'accuracy': 0.11906000000000001}, {'accuracy': 0.10001}, {'accuracy': 0.10016000000000003}, {'accuracy': 0.11742000000000001}, {'accuracy': 0.10883000000000001}, {'accuracy': 0.1095}, {'accuracy': 0.10918000000000001}, {'accuracy': 0.10871}, {'accuracy': 0.10067}, {'accuracy': 0.10977}, {'accuracy': 0.1}, {'accuracy': 0.10846}, {'accuracy': 0.11097000000000001}, {'accuracy': 0.11421}, {'accuracy': 0.10195000000000001}, {'accuracy': 0.11090000000000003}, {'accuracy': 0.10158}, {'accuracy': 0.10938}, {'accuracy': 0.10741}, {'accuracy': 0.10674999999999998}, {'accuracy': 0.10795999999999999}, {'accuracy': 0.10386000000000002}, {'accuracy': 0.10575000000000001}, {'accuracy': 0.12788}, {'accuracy': 0.12042}, {'accuracy': 0.11835}, {'accuracy': 0.12031}, {'accuracy': 0.11459}, {'accuracy': 0.11683000000000002}, {'accuracy': 0.12686}, {'accuracy': 0.11965999999999999}, {'accuracy': 0.12904}, {'accuracy': 0.11125}, {'accuracy': 0.11624000000000001}, {'accuracy': 0.10903}, {'accuracy': 0.12272000000000001}, {'accuracy': 0.11429}, {'accuracy': 0.11107}, {'accuracy': 0.10781}, {'accuracy': 0.13723999999999997}, {'accuracy': 0.12006999999999998}, {'accuracy': 0.11865999999999999}, {'accuracy': 0.11936}, {'accuracy': 0.13284}, {'accuracy': 0.12322999999999999}, {'accuracy': 0.1155}, {'accuracy': 0.12273}, {'accuracy': 0.12986999999999999}, {'accuracy': 0.11810000000000001}, {'accuracy': 0.14725000000000002}, {'accuracy': 0.12733999999999998}, {'accuracy': 0.12492999999999999}, {'accuracy': 0.12018}, {'accuracy': 0.11259999999999999}, {'accuracy': 0.11003}, {'accuracy': 0.13225000000000003}, {'accuracy': 0.12940000000000002}, {'accuracy': 0.12366999999999997}, {'accuracy': 0.11773}, {'accuracy': 0.11652}, {'accuracy': 0.12397}, {'accuracy': 0.11101000000000001}, {'accuracy': 0.10789}, {'accuracy': 0.11116999999999999}, {'accuracy': 0.11774}, {'accuracy': 0.12326999999999999}, {'accuracy': 0.11416}, {'accuracy': 0.11013999999999999}, {'accuracy': 0.11359}, {'accuracy': 0.11835999999999999}, {'accuracy': 0.11925000000000001}, {'accuracy': 0.11644000000000002}, {'accuracy': 0.11656}, {'accuracy': 0.11998}, {'accuracy': 0.12481}, {'accuracy': 0.11293}, {'accuracy': 0.12362}, {'accuracy': 0.12728}, {'accuracy': 0.12383}, {'accuracy': 0.11199999999999999}, {'accuracy': 0.11626}, {'accuracy': 0.12340999999999999}, {'accuracy': 0.13119}, {'accuracy': 0.12649}, {'accuracy': 0.13}, {'accuracy': 0.11308}, {'accuracy': 0.11615}, {'accuracy': 0.1156}, {'accuracy': 0.11471}, {'accuracy': 0.13721}, {'accuracy': 0.13777}, {'accuracy': 0.11356999999999999}, {'accuracy': 0.12492999999999999}, {'accuracy': 0.12474999999999999}, {'accuracy': 0.15411999999999998}, {'accuracy': 0.13962}, {'accuracy': 0.11837}, {'accuracy': 0.12322999999999999}, {'accuracy': 0.13285}, {'accuracy': 0.12405}, {'accuracy': 0.13533}, {'accuracy': 0.12630000000000002}, {'accuracy': 0.13732}, {'accuracy': 0.15456}, {'accuracy': 0.14531}, {'accuracy': 0.13216}, {'accuracy': 0.13953000000000002}, {'accuracy': 0.11945000000000001}, {'accuracy': 0.14057000000000003}, {'accuracy': 0.12691999999999998}, {'accuracy': 0.14018000000000003}, {'accuracy': 0.14162}, {'accuracy': 0.13915}, {'accuracy': 0.15484}, {'accuracy': 0.15175}, {'accuracy': 0.13974999999999999}, {'accuracy': 0.14055}, {'accuracy': 0.14154}, {'accuracy': 0.13426}, {'accuracy': 0.15889}, {'accuracy': 0.14651}, {'accuracy': 0.15533000000000002}, {'accuracy': 0.15731}, {'accuracy': 0.1503}, {'accuracy': 0.15655}, {'accuracy': 0.15247000000000002}, {'accuracy': 0.15753999999999999}, {'accuracy': 0.1484}, {'accuracy': 0.1577}, {'accuracy': 0.15194000000000002}, {'accuracy': 0.15905}, {'accuracy': 0.15879}, {'accuracy': 0.14009}, {'accuracy': 0.16466999999999998}, {'accuracy': 0.15704}, {'accuracy': 0.15072000000000002}, {'accuracy': 0.17685999999999996}, {'accuracy': 0.14819}, {'accuracy': 0.18397999999999998}, {'accuracy': 0.15797999999999998}, {'accuracy': 0.16611}, {'accuracy': 0.17587}, {'accuracy': 0.1653}, {'accuracy': 0.14474}, {'accuracy': 0.16185000000000002}, {'accuracy': 0.15717}, {'accuracy': 0.15184999999999998}, {'accuracy': 0.16515}, {'accuracy': 0.16832}, {'accuracy': 0.16416}, {'accuracy': 0.17572}, {'accuracy': 0.15077000000000002}, {'accuracy': 0.15931}, {'accuracy': 0.16268}, {'accuracy': 0.17603}, {'accuracy': 0.16526999999999997}, {'accuracy': 0.18001}, {'accuracy': 0.17035}, {'accuracy': 0.18317}, {'accuracy': 0.17684}, {'accuracy': 0.17543999999999998}, {'accuracy': 0.16057000000000002}, {'accuracy': 0.19100999999999999}, {'accuracy': 0.17339}, {'accuracy': 0.16645}, {'accuracy': 0.17941000000000001}, {'accuracy': 0.20107}, {'accuracy': 0.18983000000000003}, {'accuracy': 0.18613000000000002}, {'accuracy': 0.18860000000000002}, {'accuracy': 0.25834}, {'accuracy': 0.26861999999999997}, {'accuracy': 0.29324}, {'accuracy': 0.30158}, {'accuracy': 0.30077000000000004}, {'accuracy': 0.30771000000000004}, {'accuracy': 0.29979999999999996}, {'accuracy': 0.30376000000000003}, {'accuracy': 0.2977899999999999}, {'accuracy': 0.30610000000000004}, {'accuracy': 0.30321}, {'accuracy': 0.30099}, {'accuracy': 0.30623999999999996}, {'accuracy': 0.30232}, {'accuracy': 0.30157000000000006}, {'accuracy': 0.29889}, {'accuracy': 0.29922}, {'accuracy': 0.30412}, {'accuracy': 0.3074}, {'accuracy': 0.30243}, {'accuracy': 0.3035}, {'accuracy': 0.30443000000000003}, {'accuracy': 0.30745000000000006}, {'accuracy': 0.3078600000000001}, {'accuracy': 0.31117}, {'accuracy': 0.31056000000000006}, {'accuracy': 0.31554000000000004}, {'accuracy': 0.31307}, {'accuracy': 0.30699999999999994}, {'accuracy': 0.30578}, {'accuracy': 0.30445}, {'accuracy': 0.31002}, {'accuracy': 0.31229000000000007}, {'accuracy': 0.30466}, {'accuracy': 0.30926}, {'accuracy': 0.31906999999999996}, {'accuracy': 0.30978}, {'accuracy': 0.31681}, {'accuracy': 0.3176}, {'accuracy': 0.31078000000000006}, {'accuracy': 0.30852}, {'accuracy': 0.31381999999999993}, {'accuracy': 0.30666000000000004}, {'accuracy': 0.30937000000000003}, {'accuracy': 0.31724}, {'accuracy': 0.30802}, {'accuracy': 0.31486000000000003}, {'accuracy': 0.31536000000000003}, {'accuracy': 0.31704999999999994}, {'accuracy': 0.3169}, {'accuracy': 0.31496999999999997}, {'accuracy': 0.31118}, {'accuracy': 0.3108700000000001}, {'accuracy': 0.31883}, {'accuracy': 0.31649}, {'accuracy': 0.3144600000000001}, {'accuracy': 0.3149}, {'accuracy': 0.31137}, {'accuracy': 0.31500000000000006}, {'accuracy': 0.31482}, {'accuracy': 0.30522}, {'accuracy': 0.31654}, {'accuracy': 0.31269}, {'accuracy': 0.31687}, {'accuracy': 0.31731}, {'accuracy': 0.31624}, {'accuracy': 0.3179}, {'accuracy': 0.3174}, {'accuracy': 0.31967}, {'accuracy': 0.31409000000000004}, {'accuracy': 0.31555000000000005}, {'accuracy': 0.31961000000000006}, {'accuracy': 0.31421}, {'accuracy': 0.3106399999999999}, {'accuracy': 0.31333}, {'accuracy': 0.32012}, {'accuracy': 0.3235}, {'accuracy': 0.32109999999999994}, {'accuracy': 0.31467}, {'accuracy': 0.31472}, {'accuracy': 0.3148000000000001}, {'accuracy': 0.31703000000000003}, {'accuracy': 0.32155}, {'accuracy': 0.3167}, {'accuracy': 0.31448}, {'accuracy': 0.31177}, {'accuracy': 0.32155}, {'accuracy': 0.31703000000000003}, {'accuracy': 0.31555999999999995}, {'accuracy': 0.31971}, {'accuracy': 0.31394}, {'accuracy': 0.31886000000000003}, {'accuracy': 0.31015}, {'accuracy': 0.31231}, {'accuracy': 0.31649}, {'accuracy': 0.32152000000000003}, {'accuracy': 0.31439000000000006}, {'accuracy': 0.31605}, {'accuracy': 0.31620000000000004}, {'accuracy': 0.31638}, {'accuracy': 0.31404}, {'accuracy': 0.31931}, {'accuracy': 0.31564000000000003}, {'accuracy': 0.31637000000000004}, {'accuracy': 0.31263}, {'accuracy': 0.32189999999999996}, {'accuracy': 0.31784999999999997}, {'accuracy': 0.31913}, {'accuracy': 0.32338}, {'accuracy': 0.32147}, {'accuracy': 0.32068}, {'accuracy': 0.31781000000000004}, {'accuracy': 0.31406999999999996}, {'accuracy': 0.31768}, {'accuracy': 0.31899999999999995}, {'accuracy': 0.31511999999999996}, {'accuracy': 0.32103000000000004}, {'accuracy': 0.32066999999999996}, {'accuracy': 0.32178999999999996}, {'accuracy': 0.31929}, {'accuracy': 0.32128000000000007}, {'accuracy': 0.31836000000000003}, {'accuracy': 0.31526}, {'accuracy': 0.31777}, {'accuracy': 0.32371}, {'accuracy': 0.31690999999999997}, {'accuracy': 0.31925000000000003}, {'accuracy': 0.31881000000000004}, {'accuracy': 0.31981}, {'accuracy': 0.31723}, {'accuracy': 0.32188}, {'accuracy': 0.31973}, {'accuracy': 0.32186000000000003}, {'accuracy': 0.3125}, {'accuracy': 0.31484}, {'accuracy': 0.3229099999999999}, {'accuracy': 0.31423999999999996}, {'accuracy': 0.315}, {'accuracy': 0.32058}, {'accuracy': 0.32111999999999996}, {'accuracy': 0.31964000000000004}, {'accuracy': 0.31182999999999994}, {'accuracy': 0.31424}, {'accuracy': 0.31862}, {'accuracy': 0.31456999999999996}, {'accuracy': 0.31778000000000006}, {'accuracy': 0.32014}, {'accuracy': 0.32295999999999997}, {'accuracy': 0.31686}, {'accuracy': 0.31923999999999997}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACFIUlEQVR4nO3dd3hUZdoG8HtmMiW9kF4gCb2EXkRpAoIdO7IoiHVFdkVssK6gqy6I5UMXBdddwQ7K2guIEVAg9N5bIATSeybJ1PP9MXNOzpmZNEgyKffvunKRzJw5854JyTx5nud9X5UgCAKIiIiI2hG1twdARERE1NwYABEREVG7wwCIiIiI2h0GQERERNTuMAAiIiKidocBEBEREbU7DICIiIio3WEARERERO0OAyAiIiJqdxgAEZHXbdy4ESqVChs3bpRuu++++5CYmOi1MbUlL7zwAlQqlbeHQdSiMAAiagMOHz6Me+65B3FxcdDr9YiNjcXUqVNx+PBhbw+tyb377rtYuXJlkz7HkSNH8MILL+Ds2bNN+jzN6Z///Ce++eYbbw+DyGsYABG1cl999RUGDhyI1NRUzJgxA++++y4eeOABbNiwAQMHDsTXX3/t7SE2qeYKgF588UUGQERtiI+3B0BEl+706dO49957kZycjN9//x0RERHSfY8//jhGjhyJe++9FwcOHEBycnKzjctoNMLf37/Znq814GtC1LIwA0TUir322muoqKjAv//9b0XwAwDh4eF47733YDQasXjxYgDAmjVroFKpsGnTJrdzvffee1CpVDh06JB027Fjx3DHHXcgLCwMBoMBgwcPxnfffad43MqVK6Vzzpw5E5GRkYiPjwcAnDt3DjNnzkT37t3h6+uLDh064M4772y0TEpiYiIOHz6MTZs2QaVSQaVSYcyYMdL9xcXFmD17NhISEqDX69GlSxe8+uqrsNvtivOsWrUKgwYNQmBgIIKCgpCSkoK33npLur4777wTAHD11VdLzyPvV3J13333ISAgAKdPn8b111+PwMBATJ06FQBgt9uxZMkS9O7dGwaDAVFRUXjkkUdQVFSkOMeuXbswceJEhIeHw9fXF0lJSbj//vul+z31TQHA2bNnoVKpas2KqVQqGI1GfPjhh9L13HfffQCAsrIyzJ49G4mJidDr9YiMjMQ111yDPXv21Hg+otaIGSCiVuz7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IvISqQTmw1/FRM2NP3VERF7CDBCR9zAAIiLyEpPYA8QmaKJmx586IiIvEUtgzAARNT8GQEREXmKyiiUw/iomam78qSMi8hIpA8Rp8ETNjgEQEZGXiE3QepbAiJodAyAiIi+p7gHir2Ki5safOiIiL2ETNJH3MAAiIvKSKivXASLyFgZAREReYLcLMIsBEFeCJmp2/KkjIvICcQo8wAwQkTcwACIi8gKx/wdgAETkDQyAiIi8oMq5DYZWo4JGrfLyaIjaHwZAREReIG2EykUQibyCARARkReIJTAugkjkHQyAiIi8gIsgEnkXf/KIiLxAKoExA0TkFQyAiIi8QGyCZgaIyDv4k0dE5AUm7gRP5FUMgIiIvIAlMCLvYgBEROQFbIIm8i7+5BEReYE0DZ4lMCKvYABEROQF4k7wemaAiLyCP3lERF5gYg8QkVcxACIi8gJpGjxLYERewQCIiMgL2ARN5F38ySMi8gJOgyfyLgZAREReYGIGiMir+JNHROQF1VthMANE5A0MgIiIvEAqgbEJmsgrGAAREXmBtBAiS2BEXsGfPCIiL6i0sARG5E0MgIiIvKC4wgIACPXTeXkkRO0TAyAiIi8oKDcBAML8GQAReQMDICKiZma22lFaZQUAhAcwACLyBgZARETNrKjCDADQqFUIMmi9PBqi9okBEBFRM8t3lr9C/XRQq1VeHg1R+8QAiIiomRUaHRkglr+IvIcBEBFRMysodwRAbIAm8h4GQEREzazAyACIyNsYABERNbNCo6MHKDxA7+WRELVfDICIiJoZS2BE3scAiIiomYklsA5sgibyGgZARETNTFwFugMzQERewwCIiKiZFUpN0OwBIvIWBkBERM2MJTAi72MARETUjExWG8qc+4CxBEbkPQyAiIiaUYXJJn0eyH3AiLyGARARUTOyCYL0ObcBI/IeBkBERM3IZncEQBq1CioVIyAib2EARETUjKQAiMEPkVcxACIiakZiAKTmb18ir+KPIBFRM7ILzAARtQQMgIiImlF1BogBEJE3MQAiImpGUgaIARCRV7WIAOidd95BYmIiDAYDhg0bhh07dtR47Pvvv4+RI0ciNDQUoaGhGD9+vNvx9913H1QqleLj2muvberLICKqk5VN0EQtgtcDoNWrV2POnDlYsGAB9uzZg379+mHixInIzc31ePzGjRsxZcoUbNiw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AfJAXGSptLTUyyMhIiKi+hLft+uzWCIDIA/KysoAAAkJCV4eCRERETVUWVkZgoODaz2Ge4F5YLfbcfHiRQQGBjbaAlmlpaVISEjA+fPn2+3+Yu39NWjv1w/wNQD4GrT36wf4GjTl9QuCgLKyMsTGxio2U/eEGSAP1Go14uPjm+TcQUFB7fI/vFx7fw3a+/UDfA0Avgbt/foBvgZNdf11ZX5EbIImIiKidocBEBEREbU7DICaiV6vx4IFC6DX6709FK9p769Be79+gK8BwNegvV8/wNegpVw/m6CJiIio3WEGiIiIiNodBkBERETU7jAAIiIionaHARARERG1OwyAmsk777yDxMREGAwGDBs2DDt27PD2kJrECy+8AJVKpfjo0aOHdH9VVRUee+wxdOjQAQEBAbj99tuRk5PjxRFfvt9//x033XQTYmNjoVKp8M033yjuFwQB8+fPR0xMDHx9fTF+/HicPHlScUxhYSGmTp2KoKAghISE4IEHHkB5eXkzXsWlq+v677vvPrf/E9dee63imNZ8/QCwcOFCDBkyBIGBgYiMjMQtt9yC48ePK46pz//9jIwM3HDDDfDz80NkZCSefvppWK3W5ryUS1Kf6x8zZozb/4M///nPimNa6/UDwLJly9C3b19pcb/hw4fj559/lu5vy99/oO7rb4nffwZAzWD16tWYM2cOFixYgD179qBfv36YOHEicnNzvT20JtG7d29kZWVJH5s3b5bue+KJJ/D999/jyy+/xKZNm3Dx4kXcdtttXhzt5TMajejXrx/eeecdj/cvXrwYb7/9NpYvX47t27fD398fEydORFVVlXTM1KlTcfjwYaxfvx4//PADfv/9dzz88MPNdQmXpa7rB4Brr71W8X/i888/V9zfmq8fADZt2oTHHnsM27Ztw/r162GxWDBhwgQYjUbpmLr+79tsNtxwww0wm83YunUrPvzwQ6xcuRLz58/3xiU1SH2uHwAeeughxf+DxYsXS/e15usHgPj4eCxatAi7d+/Grl27MHbsWEyaNAmHDx8G0La//0Dd1w+0wO+/QE1u6NChwmOPPSZ9bbPZhNjYWGHhwoVeHFXTWLBggdCvXz+P9xUXFwtarVb48ssvpduOHj0qABDS0tKaaYRNC4Dw9ddfS1/b7XYhOjpaeO2116TbiouLBb1eL3z++eeCIAjCkSNHBADC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2h4GQERERNTuMAAiIiKidocBEBG1Ona7HYsXL0aXLl2g1+vRsWNHvPLKKxg7dixmzZqlODYvLw86nU7aidtkMuHZZ59FQkIC9Ho9unTpgv/+9781PtfmzZsxcuRI+Pr6IiEhAX/9619hNBqb9PqIqOkxACKiVmfevHlYtGgRnn/+eRw5cgSfffYZoqKi8OCDD+Kzzz6DyWSSjv3kk08QFxeHsWPHAgCmTZuGzz//HG+//TaOHj2K9957DwEBAR6f5/Tp07j22mtx++2348CBA1i9ejU2b97sFmQRUevDzVCJqFUpKytDREQEli5digcffFBxX1VVFWJjY7F8+XLcddddAIB+/frhtttuw4IFC3DixAl0794d69evx/jx493OvXHjRlx99dUoKipCSEgIHnzwQWg0Grz33nvSMZs3b8bo0aNhNBphMBia9mKJqMkwA0RErcrRo0dhMpkwbtw4t/sMBgPuvfdefPDBBwCAPXv24NChQ7jvvvsAAPv27YNGo8Ho0aPr9Vz79+/HypUrERAQIH1MnDgRdrsd6enpjXZNRNT8fLw9ACKihvD19a31/gcffBD9+/dHZmYmVqxYgbFjx6JTp071eqyr8vJyPPLII/jrX//qdl/Hjh0bdC4ialmYASKiVqVr167w9fWVmppdpaSkYPDgwXj//ffx2Wef4f7771fcZ7fbsWnTpno918CBA3HkyBF06dLF7UOn0zXK9RCRdzAAIqJWxWAw4Nlnn8UzzzyDjz76CKdPn8a2bdsUM7kefPBBLFq0CIIg4NZbb5VuT0xMxPTp03H//ffjm2++QXp6OjZu3IgvvvjC43M9++yz2Lp1K2bNmoV9+/bh5MmT+Pbbb9kETdQGMAAiolbn+eefx5NPPon58+ejZ8+emDx5MnJzc6X7p0yZAh8fH0yZMsWtUXnZsmW44447MHPmTPTo0QMPPfRQjdPa+/bti02bNuHEiRMYOXIkBgwYgPnz5yM2NrZJr4+Imh5ngRFRm3P27Fl07twZO3fuxMCBA709HCJqgRgAEVGbYbFYUFBQgKeeegrp6enYsmWLt4dERC0US2BE1GZs2bIFMTEx2LlzJ5YvX+7t4RBRC8YMEBEREbU7zAARERFRu8MAiIiIiNodBkBERETU7jAAIiIionaHARARERG1OwyAiIiIqN1hAERERETtDgMgIiIiancYABEREVG78/88dnEI/sk3twAAAABJRU5ErkJggg==\n",
      "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": "a23ef5a2-330a-48ef-a823-8ccf7eabb143",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0129bbcf-dda3-427c-9e61-460fcf92a88b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "537c903a-fbc2-410b-8b91-0a498b34e204",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "447ee384-cf7c-4c89-b882-c7ba7ce896b1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cbbbdcbf-9ba6-4454-bb19-cdb25f2fc773",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "270a55b7-a5af-4c17-b34c-41e5f6dbe74e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "298cba74-5301-482f-b0cc-da3984f7c4fa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d54e0652-cf7f-4c56-8b79-f998d89fa427",
   "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
}
