{
 "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",
      "5100\n",
      "[[  0 522]\n",
      " [  1 497]\n",
      " [  2 534]\n",
      " [  3 531]\n",
      " [  4 478]\n",
      " [  5 526]\n",
      " [  6 494]\n",
      " [  7 493]\n",
      " [  8 496]\n",
      " [  9 443]]\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": [
       "4867"
      ]
     },
     "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([1, 2, 7,  ..., 7, 1, 0])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "25292\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 229]\n",
      " [  1 246]\n",
      " [  2 248]\n",
      " [  3 246]\n",
      " [  4 237]\n",
      " [  5 237]\n",
      " [  6 262]\n",
      " [  7 248]\n",
      " [  8 252]\n",
      " [  9 266]]\n",
      "[[   0 1217]\n",
      " [   1  273]\n",
      " [   2  264]\n",
      " [   3  275]\n",
      " [   4  271]\n",
      " [   5  308]\n",
      " [   6  403]\n",
      " [   7  460]\n",
      " [   8  623]\n",
      " [   9  903]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 7, 2,  ..., 4, 5, 0])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "        \n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<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",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0689e324-e1fd-49dd-9e96-7dfa95ed212d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "print(\"this is\")\n",
    "print(ytr[1])\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10369999999999999}, {'accuracy': 0.10002}, {'accuracy': 0.10521}, {'accuracy': 0.12095000000000003}, {'accuracy': 0.12538000000000002}, {'accuracy': 0.11885000000000001}, {'accuracy': 0.11766000000000001}, {'accuracy': 0.13482000000000002}, {'accuracy': 0.11998}, {'accuracy': 0.13338}, {'accuracy': 0.14124000000000003}, {'accuracy': 0.15205000000000002}, {'accuracy': 0.11442000000000001}, {'accuracy': 0.14411999999999997}, {'accuracy': 0.15206000000000003}, {'accuracy': 0.14819}, {'accuracy': 0.15918000000000002}, {'accuracy': 0.15981}, {'accuracy': 0.19797}, {'accuracy': 0.16541999999999998}, {'accuracy': 0.14022}, {'accuracy': 0.15776}, {'accuracy': 0.17808}, {'accuracy': 0.1341}, {'accuracy': 0.1617}, {'accuracy': 0.21568}, {'accuracy': 0.22296999999999997}, {'accuracy': 0.19542}, {'accuracy': 0.22076}, {'accuracy': 0.25843000000000005}, {'accuracy': 0.23507000000000003}, {'accuracy': 0.18938}, {'accuracy': 0.18203}, {'accuracy': 0.26850999999999997}, {'accuracy': 0.22740999999999997}, {'accuracy': 0.22037}, {'accuracy': 0.22974999999999998}, {'accuracy': 0.23607999999999998}, {'accuracy': 0.25134}, {'accuracy': 0.29739}, {'accuracy': 0.21847}, {'accuracy': 0.26935000000000003}, {'accuracy': 0.23928000000000002}, {'accuracy': 0.28942}, {'accuracy': 0.25817}, {'accuracy': 0.20865}, {'accuracy': 0.20875}, {'accuracy': 0.24235999999999996}, {'accuracy': 0.17913}, {'accuracy': 0.23554999999999998}, {'accuracy': 0.18708}, {'accuracy': 0.22066999999999998}, {'accuracy': 0.22466999999999998}, {'accuracy': 0.20687000000000003}, {'accuracy': 0.23399999999999999}, {'accuracy': 0.18694}, {'accuracy': 0.14970999999999998}, {'accuracy': 0.18822}, {'accuracy': 0.22372}, {'accuracy': 0.20140999999999995}, {'accuracy': 0.19476}, {'accuracy': 0.25792000000000004}, {'accuracy': 0.19827999999999998}, {'accuracy': 0.24121}, {'accuracy': 0.24147000000000002}, {'accuracy': 0.19793}, {'accuracy': 0.18834}, {'accuracy': 0.23123}, {'accuracy': 0.21614999999999998}, {'accuracy': 0.22946000000000005}, {'accuracy': 0.19787}, {'accuracy': 0.17315}, {'accuracy': 0.21063}, {'accuracy': 0.20582000000000003}, {'accuracy': 0.19907999999999998}, {'accuracy': 0.24705}, {'accuracy': 0.20267}, {'accuracy': 0.25688}, {'accuracy': 0.16759999999999997}, {'accuracy': 0.21520999999999998}, {'accuracy': 0.19721}, {'accuracy': 0.2061}, {'accuracy': 0.24831000000000003}, {'accuracy': 0.23829000000000003}, {'accuracy': 0.23403999999999997}, {'accuracy': 0.24445}, {'accuracy': 0.21319}, {'accuracy': 0.22244999999999995}, {'accuracy': 0.22535}, {'accuracy': 0.22696999999999998}, {'accuracy': 0.20330999999999996}, {'accuracy': 0.18588000000000002}, {'accuracy': 0.26199999999999996}, {'accuracy': 0.24947}, {'accuracy': 0.22853000000000004}, {'accuracy': 0.24391}, {'accuracy': 0.23121}, {'accuracy': 0.26422}, {'accuracy': 0.20074999999999998}, {'accuracy': 0.21191}, {'accuracy': 0.25756000000000007}, {'accuracy': 0.23278999999999997}, {'accuracy': 0.24585999999999997}, {'accuracy': 0.23043999999999998}, {'accuracy': 0.2682300000000001}, {'accuracy': 0.22437000000000004}, {'accuracy': 0.21193}, {'accuracy': 0.20534}, {'accuracy': 0.24140999999999999}, {'accuracy': 0.25109000000000004}, {'accuracy': 0.22979999999999995}, {'accuracy': 0.24902999999999995}, {'accuracy': 0.30450999999999995}, {'accuracy': 0.28069}, {'accuracy': 0.24753999999999995}, {'accuracy': 0.28393}, {'accuracy': 0.25397}, {'accuracy': 0.24606}, {'accuracy': 0.23494}, {'accuracy': 0.24049}, {'accuracy': 0.23965999999999998}, {'accuracy': 0.27713}, {'accuracy': 0.21313}, {'accuracy': 0.26574000000000003}, {'accuracy': 0.2774}, {'accuracy': 0.26899999999999996}, {'accuracy': 0.26392}, {'accuracy': 0.28161}, {'accuracy': 0.29018000000000005}, {'accuracy': 0.21830000000000002}, {'accuracy': 0.21873}, {'accuracy': 0.25748}, {'accuracy': 0.25742999999999994}, {'accuracy': 0.28335}, {'accuracy': 0.27894}, {'accuracy': 0.26785000000000003}, {'accuracy': 0.28865}, {'accuracy': 0.25972}, {'accuracy': 0.27516}, {'accuracy': 0.25568}, {'accuracy': 0.25234999999999996}, {'accuracy': 0.26357}, {'accuracy': 0.25832}, {'accuracy': 0.27276999999999996}, {'accuracy': 0.29484000000000005}, {'accuracy': 0.28063000000000005}, {'accuracy': 0.2354}, {'accuracy': 0.23088000000000003}, {'accuracy': 0.28582}, {'accuracy': 0.27155999999999997}, {'accuracy': 0.24186999999999997}, {'accuracy': 0.30127}, {'accuracy': 0.28355}, {'accuracy': 0.31027}, {'accuracy': 0.28449}, {'accuracy': 0.25676}, {'accuracy': 0.31189999999999996}, {'accuracy': 0.29280000000000006}, {'accuracy': 0.25294000000000005}, {'accuracy': 0.29879999999999995}, {'accuracy': 0.26231}, {'accuracy': 0.2707}, {'accuracy': 0.28229}, {'accuracy': 0.27888}, {'accuracy': 0.27774}, {'accuracy': 0.25930000000000003}, {'accuracy': 0.27890000000000004}, {'accuracy': 0.28353}, {'accuracy': 0.28659}, {'accuracy': 0.27912}, {'accuracy': 0.28325}, {'accuracy': 0.29428}, {'accuracy': 0.28728}, {'accuracy': 0.33153999999999995}, {'accuracy': 0.28653999999999996}, {'accuracy': 0.28407}, {'accuracy': 0.28418}, {'accuracy': 0.28453999999999996}, {'accuracy': 0.28408}, {'accuracy': 0.2761}, {'accuracy': 0.30910000000000004}, {'accuracy': 0.29718999999999995}, {'accuracy': 0.30872}, {'accuracy': 0.3054}, {'accuracy': 0.30149000000000004}, {'accuracy': 0.29830999999999996}, {'accuracy': 0.30511}, {'accuracy': 0.29312000000000005}, {'accuracy': 0.32677}, {'accuracy': 0.31980000000000003}, {'accuracy': 0.29731}, {'accuracy': 0.32157}, {'accuracy': 0.29113999999999995}, {'accuracy': 0.33433}, {'accuracy': 0.33942}, {'accuracy': 0.33513000000000004}, {'accuracy': 0.34389000000000003}, {'accuracy': 0.34904999999999997}, {'accuracy': 0.33311}, {'accuracy': 0.34343}, {'accuracy': 0.35462999999999995}, {'accuracy': 0.32902}, {'accuracy': 0.35604}, {'accuracy': 0.34324000000000005}, {'accuracy': 0.33174000000000003}, {'accuracy': 0.35117}, {'accuracy': 0.35218}, {'accuracy': 0.34223000000000003}, {'accuracy': 0.35027}, {'accuracy': 0.34171}, {'accuracy': 0.34152}, {'accuracy': 0.34535}, {'accuracy': 0.35719999999999996}, {'accuracy': 0.35665}, {'accuracy': 0.35536999999999996}, {'accuracy': 0.35617}, {'accuracy': 0.35706000000000004}, {'accuracy': 0.35819}, {'accuracy': 0.35397}, {'accuracy': 0.35616}, {'accuracy': 0.35001000000000004}, {'accuracy': 0.34971}, {'accuracy': 0.35164000000000006}, {'accuracy': 0.34635000000000005}, {'accuracy': 0.35611000000000004}, {'accuracy': 0.35669}, {'accuracy': 0.35614}, {'accuracy': 0.34996}, {'accuracy': 0.35206}, {'accuracy': 0.35424999999999995}, {'accuracy': 0.36286}, {'accuracy': 0.35995}, {'accuracy': 0.35776}, {'accuracy': 0.35821000000000003}, {'accuracy': 0.35895}, {'accuracy': 0.34978999999999993}, {'accuracy': 0.35306}, {'accuracy': 0.3573}, {'accuracy': 0.35273999999999994}, {'accuracy': 0.35624}, {'accuracy': 0.35505}, {'accuracy': 0.35724999999999996}, {'accuracy': 0.35241}, {'accuracy': 0.35533}, {'accuracy': 0.35631999999999997}, {'accuracy': 0.35515}, {'accuracy': 0.36258}, {'accuracy': 0.35388000000000003}, {'accuracy': 0.35597}, {'accuracy': 0.3572}, {'accuracy': 0.35422}, {'accuracy': 0.35465}, {'accuracy': 0.35699000000000003}, {'accuracy': 0.36174}, {'accuracy': 0.35068}, {'accuracy': 0.36054}, {'accuracy': 0.35940000000000005}, {'accuracy': 0.35434}, {'accuracy': 0.36302}, {'accuracy': 0.35866}, {'accuracy': 0.34811000000000003}, {'accuracy': 0.33657}, {'accuracy': 0.34743}, {'accuracy': 0.34602999999999995}, {'accuracy': 0.35499}, {'accuracy': 0.35910000000000003}, {'accuracy': 0.35824999999999996}, {'accuracy': 0.35175999999999996}, {'accuracy': 0.35706}, {'accuracy': 0.35454}, {'accuracy': 0.36150000000000004}, {'accuracy': 0.36096000000000006}, {'accuracy': 0.35768999999999995}, {'accuracy': 0.35835}, {'accuracy': 0.35729}, {'accuracy': 0.36262}, {'accuracy': 0.36110000000000003}, {'accuracy': 0.35977000000000003}, {'accuracy': 0.36131}, {'accuracy': 0.35624}, {'accuracy': 0.35345000000000004}, {'accuracy': 0.36319}, {'accuracy': 0.35607}, {'accuracy': 0.35913}, {'accuracy': 0.35938000000000003}, {'accuracy': 0.35963999999999996}, {'accuracy': 0.35301}, {'accuracy': 0.35263999999999995}, {'accuracy': 0.35618}, {'accuracy': 0.35348000000000007}, {'accuracy': 0.34677}, {'accuracy': 0.35945}, {'accuracy': 0.35179}, {'accuracy': 0.35064}, {'accuracy': 0.34470999999999996}, {'accuracy': 0.35050000000000003}, {'accuracy': 0.35760000000000003}, {'accuracy': 0.35504}, {'accuracy': 0.35945}, {'accuracy': 0.35963}, {'accuracy': 0.3561}, {'accuracy': 0.35875}, {'accuracy': 0.35250000000000004}, {'accuracy': 0.35872000000000004}, {'accuracy': 0.35262000000000004}, {'accuracy': 0.35513000000000006}, {'accuracy': 0.3646}, {'accuracy': 0.35346}, {'accuracy': 0.36193000000000003}, {'accuracy': 0.35403}, {'accuracy': 0.35662}, {'accuracy': 0.35328}, {'accuracy': 0.34656999999999993}, {'accuracy': 0.33889}, {'accuracy': 0.34497999999999995}, {'accuracy': 0.34405}, {'accuracy': 0.35541999999999996}, {'accuracy': 0.35205999999999993}, {'accuracy': 0.34263}, {'accuracy': 0.36252999999999996}, {'accuracy': 0.36366}, {'accuracy': 0.36701}, {'accuracy': 0.36174}, {'accuracy': 0.35852000000000006}, {'accuracy': 0.35062}, {'accuracy': 0.34154}, {'accuracy': 0.34514}, {'accuracy': 0.34666}, {'accuracy': 0.35402}, {'accuracy': 0.36518}, {'accuracy': 0.36307999999999996}, {'accuracy': 0.35821}, {'accuracy': 0.35366}, {'accuracy': 0.35638}, {'accuracy': 0.34935}, {'accuracy': 0.35697999999999996}, {'accuracy': 0.36157}, {'accuracy': 0.35259000000000007}, {'accuracy': 0.35473}, {'accuracy': 0.36151999999999995}, {'accuracy': 0.35789000000000004}, {'accuracy': 0.35382}, {'accuracy': 0.3547600000000001}, {'accuracy': 0.35646}, {'accuracy': 0.36113}, {'accuracy': 0.36391}, {'accuracy': 0.35428}, {'accuracy': 0.3597}, {'accuracy': 0.35733000000000004}, {'accuracy': 0.35647}, {'accuracy': 0.35629}, {'accuracy': 0.33815999999999996}, {'accuracy': 0.32589999999999997}, {'accuracy': 0.33169}, {'accuracy': 0.3239}, {'accuracy': 0.32065}, {'accuracy': 0.34446999999999994}, {'accuracy': 0.35583}, {'accuracy': 0.34024}, {'accuracy': 0.35378}, {'accuracy': 0.34854999999999997}, {'accuracy': 0.36043000000000003}, {'accuracy': 0.35418}, {'accuracy': 0.36218000000000006}, {'accuracy': 0.35001}, {'accuracy': 0.34859999999999997}, {'accuracy': 0.36613999999999997}, {'accuracy': 0.35764}, {'accuracy': 0.35654}, {'accuracy': 0.35663999999999996}, {'accuracy': 0.35704}, {'accuracy': 0.35666000000000003}, {'accuracy': 0.35697999999999996}, {'accuracy': 0.33142}, {'accuracy': 0.34281}, {'accuracy': 0.36151999999999995}, {'accuracy': 0.35466000000000003}, {'accuracy': 0.36216}, {'accuracy': 0.36092}, {'accuracy': 0.35762}, {'accuracy': 0.36828}, {'accuracy': 0.36024}, {'accuracy': 0.36204000000000003}, {'accuracy': 0.36094}, {'accuracy': 0.35639000000000004}, {'accuracy': 0.36305000000000004}, {'accuracy': 0.35964999999999997}, {'accuracy': 0.36073000000000005}, {'accuracy': 0.33512}, {'accuracy': 0.33272}, {'accuracy': 0.33235}, {'accuracy': 0.35446000000000005}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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NmzYgNTUVPTo0QP33nsvysvLueda2vVVV1cDAJKSkgD49nO5ZcsW9OvXD2lpadwxEydORE1NDQ4ePNiMo/eN+BpZn3zyCZKTk9G3b1/MmzcP9fX13HMt5RptNhtWrVoFo9GIESNGtMrvn/gaWa3h+3fffffhiiuuEHy/gMj8/5A2Q21iZWVlsNlsgm8oAKSlpeHIkSNhGlXghg8fjg8++AA9evRAYWEhnnnmGYwaNQoHDhxAUVERtFotEhISBK9JS0tDUVFReAYcJHbcUt8/9rmioiKkpqYKnler1UhKSmoR1z1p0iRce+216Ny5M06cOIF//etfuOyyy7BlyxaoVKoWdX12ux0PPvggLr74YvTt2xcAfPq5LCoqkvwes89FEqlrBICbb74ZnTp1QmZmJvbt24fHHnsMR48exVdffQUg8q9x//79GDFiBBobGxETE4Ovv/4avXv3xp49e1rN90/uGoGW//0DgFWrVmHXrl3Yvn2723OR+P8hBUDEL5dddhn3cf/+/TF8+HB06tQJn3/+OQwGQxhHRgJ10003cR/369cP/fv3R9euXbFhwwaMHz8+jCPz33333YcDBw5g06ZN4R5Kk5G7xrvuuov7uF+/fsjIyMD48eNx4sQJdO3atbmH6bcePXpgz549qK6uxpo1azBjxgxs3Lgx3MMKKblr7N27d4v//p05cwYPPPAAfvnlF+j1+nAPxyc0BdbEkpOToVKp3Crdi4uLkZ6eHqZRhU5CQgK6d++O48ePIz09HWazGVVVVYJjWvK1suP29P1LT09HSUmJ4Hmr1YqKiooWed1dunRBcnIyjh8/DqDlXN+cOXPw/fffY/369ejQoQP3uC8/l+np6ZLfY/a5SCF3jVKGDx8OAILvYyRfo1arRU5ODoYMGYKFCxdiwIABeP3111vV90/uGqW0tO/fzp07UVJSgsGDB0OtVkOtVmPjxo144403oFarkZaWFnHfRwqAmphWq8WQIUOQl5fHPWa325GXlyeY+22p6urqcOLECWRkZGDIkCHQaDSCaz169CgKCgpa7LV27twZ6enpgmuqqanB1q1buWsaMWIEqqqqsHPnTu6Y3377DXa7nfsl1pKcPXsW5eXlyMjIABD518cwDObMmYOvv/4av/32Gzp37ix43pefyxEjRmD//v2CQO+XX35BXFwcN0URTt6uUcqePXsA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3249552a-eed5-475c-9fe9-d271b4d7aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c00c0f05-739c-4e87-a931-a5f8c8325673",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "738de7ab-316f-4b0e-be8d-a78133a46922",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4638d9e-616a-4ad8-9613-9267608efbe7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60010eda-f81d-44f7-81cd-245b5eafaae6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5890a65-5c65-470e-af9e-9e49ade94a59",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6aa543d-dd7e-4ad5-87c7-13b542959c34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe79c3f3-5ebb-4b8b-905b-64827bcedbc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "022fd203-7baa-4c05-a7d2-3ff54320fef1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ef6fbf8-814b-4fa2-869e-a3b89f3d1b2e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d8018a8-1536-4e5b-91fd-19f8144ca6d4",
   "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
}
