{
 "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",
      "4969\n",
      "[[  0 481]\n",
      " [  1 532]\n",
      " [  2 534]\n",
      " [  3 510]\n",
      " [  4 470]\n",
      " [  5 498]\n",
      " [  6 513]\n",
      " [  7 515]\n",
      " [  8 510]\n",
      " [  9 535]]\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": [
       "5034"
      ]
     },
     "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([3, 4, 0,  ..., 3, 5, 1])"
      ]
     },
     "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": [
      "15091\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 347]\n",
      " [  1 328]\n",
      " [  2 349]\n",
      " [  3 364]\n",
      " [  4 338]\n",
      " [  5 329]\n",
      " [  6 356]\n",
      " [  7 360]\n",
      " [  8 361]\n",
      " [  9 359]]\n",
      "[[  0 991]\n",
      " [  1 350]\n",
      " [  2 356]\n",
      " [  3 379]\n",
      " [  4 382]\n",
      " [  5 377]\n",
      " [  6 446]\n",
      " [  7 498]\n",
      " [  8 568]\n",
      " [  9 699]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([3, 4, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        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": "18a97367-0966-4bd9-9e82-dd0999426cde",
   "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.09989}, {'accuracy': 0.1}, {'accuracy': 0.10550999999999999}, {'accuracy': 0.10640000000000001}, {'accuracy': 0.11091000000000002}, {'accuracy': 0.10672}, {'accuracy': 0.11521}, {'accuracy': 0.11095000000000002}, {'accuracy': 0.10971000000000002}, {'accuracy': 0.11854}, {'accuracy': 0.11224999999999999}, {'accuracy': 0.10416}, {'accuracy': 0.11876}, {'accuracy': 0.10859}, {'accuracy': 0.13543}, {'accuracy': 0.11835000000000002}, {'accuracy': 0.12235}, {'accuracy': 0.17175}, {'accuracy': 0.12949}, {'accuracy': 0.12806}, {'accuracy': 0.12312000000000001}, {'accuracy': 0.14433999999999997}, {'accuracy': 0.16576000000000002}, {'accuracy': 0.12477}, {'accuracy': 0.11773}, {'accuracy': 0.14644}, {'accuracy': 0.13709000000000002}, {'accuracy': 0.13605}, {'accuracy': 0.14105}, {'accuracy': 0.15614}, {'accuracy': 0.15272000000000002}, {'accuracy': 0.15177999999999997}, {'accuracy': 0.15558999999999998}, {'accuracy': 0.16484000000000001}, {'accuracy': 0.1668}, {'accuracy': 0.19576}, {'accuracy': 0.18101}, {'accuracy': 0.14004}, {'accuracy': 0.15463999999999997}, {'accuracy': 0.16116}, {'accuracy': 0.16084000000000004}, {'accuracy': 0.17776}, {'accuracy': 0.1719}, {'accuracy': 0.16912}, {'accuracy': 0.18194000000000002}, {'accuracy': 0.19222}, {'accuracy': 0.17726000000000003}, {'accuracy': 0.17962}, {'accuracy': 0.18325000000000002}, {'accuracy': 0.18286}, {'accuracy': 0.1658}, {'accuracy': 0.16314}, {'accuracy': 0.17352000000000004}, {'accuracy': 0.16616}, {'accuracy': 0.16124999999999998}, {'accuracy': 0.18354}, {'accuracy': 0.16247000000000003}, {'accuracy': 0.15646}, {'accuracy': 0.15953}, {'accuracy': 0.16162}, {'accuracy': 0.16158}, {'accuracy': 0.15435}, {'accuracy': 0.1577}, {'accuracy': 0.16967}, {'accuracy': 0.13157000000000002}, {'accuracy': 0.13890999999999998}, {'accuracy': 0.191}, {'accuracy': 0.15267}, {'accuracy': 0.16902}, {'accuracy': 0.14883000000000002}, {'accuracy': 0.15197}, {'accuracy': 0.13256}, {'accuracy': 0.16391000000000003}, {'accuracy': 0.16011999999999998}, {'accuracy': 0.16665999999999997}, {'accuracy': 0.14836999999999997}, {'accuracy': 0.17323}, {'accuracy': 0.15289}, {'accuracy': 0.17739}, {'accuracy': 0.14445999999999998}, {'accuracy': 0.156}, {'accuracy': 0.17811000000000005}, {'accuracy': 0.18031000000000003}, {'accuracy': 0.18686}, {'accuracy': 0.15542}, {'accuracy': 0.17876999999999998}, {'accuracy': 0.1689}, {'accuracy': 0.17523}, {'accuracy': 0.17240000000000003}, {'accuracy': 0.18653}, {'accuracy': 0.20383999999999997}, {'accuracy': 0.18904}, {'accuracy': 0.19473}, {'accuracy': 0.20053}, {'accuracy': 0.19537}, {'accuracy': 0.18783}, {'accuracy': 0.20199999999999996}, {'accuracy': 0.17448000000000002}, {'accuracy': 0.17893}, {'accuracy': 0.19812}, {'accuracy': 0.18984}, {'accuracy': 0.17879}, {'accuracy': 0.18184}, {'accuracy': 0.18365}, {'accuracy': 0.191}, {'accuracy': 0.17568999999999999}, {'accuracy': 0.19690999999999997}, {'accuracy': 0.17389000000000002}, {'accuracy': 0.17218}, {'accuracy': 0.20101}, {'accuracy': 0.21598}, {'accuracy': 0.19650000000000004}, {'accuracy': 0.21949999999999997}, {'accuracy': 0.17587999999999998}, {'accuracy': 0.20068999999999998}, {'accuracy': 0.17297}, {'accuracy': 0.19678999999999996}, {'accuracy': 0.20242999999999997}, {'accuracy': 0.17742}, {'accuracy': 0.18475000000000003}, {'accuracy': 0.16538}, {'accuracy': 0.19272}, {'accuracy': 0.19881000000000001}, {'accuracy': 0.18741999999999998}, {'accuracy': 0.19972999999999996}, {'accuracy': 0.20009000000000002}, {'accuracy': 0.19624}, {'accuracy': 0.18425}, {'accuracy': 0.231}, {'accuracy': 0.21258999999999997}, {'accuracy': 0.22349999999999998}, {'accuracy': 0.20675}, {'accuracy': 0.21437}, {'accuracy': 0.23248000000000002}, {'accuracy': 0.23692999999999995}, {'accuracy': 0.22831}, {'accuracy': 0.23992999999999992}, {'accuracy': 0.26048}, {'accuracy': 0.25714000000000004}, {'accuracy': 0.2571}, {'accuracy': 0.23948}, {'accuracy': 0.26963}, {'accuracy': 0.27680999999999994}, {'accuracy': 0.25812}, {'accuracy': 0.27852}, {'accuracy': 0.27161}, {'accuracy': 0.26289999999999997}, {'accuracy': 0.28012000000000004}, {'accuracy': 0.25243000000000004}, {'accuracy': 0.28037999999999996}, {'accuracy': 0.27903999999999995}, {'accuracy': 0.29344}, {'accuracy': 0.30429999999999996}, {'accuracy': 0.31167}, {'accuracy': 0.32052}, {'accuracy': 0.31156}, {'accuracy': 0.31592000000000003}, {'accuracy': 0.30371}, {'accuracy': 0.31672}, {'accuracy': 0.35699000000000003}, {'accuracy': 0.32566000000000006}, {'accuracy': 0.31817}, {'accuracy': 0.33721999999999996}, {'accuracy': 0.34404}, {'accuracy': 0.33432}, {'accuracy': 0.32941}, {'accuracy': 0.33442}, {'accuracy': 0.37172}, {'accuracy': 0.35344000000000003}, {'accuracy': 0.35797}, {'accuracy': 0.35781999999999997}, {'accuracy': 0.35897}, {'accuracy': 0.36540999999999996}, {'accuracy': 0.33083}, {'accuracy': 0.36144}, {'accuracy': 0.36292}, {'accuracy': 0.37374999999999997}, {'accuracy': 0.34385999999999994}, {'accuracy': 0.36876999999999993}, {'accuracy': 0.37243000000000004}, {'accuracy': 0.3653700000000001}, {'accuracy': 0.34363}, {'accuracy': 0.36912}, {'accuracy': 0.38376}, {'accuracy': 0.39965999999999996}, {'accuracy': 0.38811}, {'accuracy': 0.37628999999999996}, {'accuracy': 0.36312}, {'accuracy': 0.38286999999999993}, {'accuracy': 0.36567000000000005}, {'accuracy': 0.36427}, {'accuracy': 0.36461}, {'accuracy': 0.36838}, {'accuracy': 0.38859}, {'accuracy': 0.38880000000000003}, {'accuracy': 0.45682}, {'accuracy': 0.45662}, {'accuracy': 0.45936000000000005}, {'accuracy': 0.45519999999999994}, {'accuracy': 0.46369}, {'accuracy': 0.45966000000000007}, {'accuracy': 0.46565}, {'accuracy': 0.47998}, {'accuracy': 0.45675}, {'accuracy': 0.48327}, {'accuracy': 0.4481}, {'accuracy': 0.47920999999999997}, {'accuracy': 0.47846}, {'accuracy': 0.48172999999999994}, {'accuracy': 0.4847}, {'accuracy': 0.48663000000000006}, {'accuracy': 0.48602999999999996}, {'accuracy': 0.4859800000000001}, {'accuracy': 0.48595000000000005}, {'accuracy': 0.47614}, {'accuracy': 0.4889}, {'accuracy': 0.4838100000000001}, {'accuracy': 0.4883700000000001}, {'accuracy': 0.48440000000000005}, {'accuracy': 0.49327999999999994}, {'accuracy': 0.48956}, {'accuracy': 0.49867999999999996}, {'accuracy': 0.49755000000000005}, {'accuracy': 0.49887999999999993}, {'accuracy': 0.49171000000000004}, {'accuracy': 0.49623999999999996}, {'accuracy': 0.5000799999999999}, {'accuracy': 0.49156000000000005}, {'accuracy': 0.49854000000000004}, {'accuracy': 0.49881000000000003}, {'accuracy': 0.49462}, {'accuracy': 0.5032400000000001}, {'accuracy': 0.49315}, {'accuracy': 0.49121000000000004}, {'accuracy': 0.48839}, {'accuracy': 0.4974200000000001}, {'accuracy': 0.4963100000000001}, {'accuracy': 0.4921100000000001}, {'accuracy': 0.4973699999999999}, {'accuracy': 0.50027}, {'accuracy': 0.48712999999999995}, {'accuracy': 0.48919999999999997}, {'accuracy': 0.49105}, {'accuracy': 0.49384999999999996}, {'accuracy': 0.49768}, {'accuracy': 0.48977999999999994}, {'accuracy': 0.49205999999999994}, {'accuracy': 0.49782000000000004}, {'accuracy': 0.5027100000000001}, {'accuracy': 0.49013}, {'accuracy': 0.4958}, {'accuracy': 0.49573999999999996}, {'accuracy': 0.49817}, {'accuracy': 0.49553}, {'accuracy': 0.5026299999999999}, {'accuracy': 0.50368}, {'accuracy': 0.50031}, {'accuracy': 0.49642}, {'accuracy': 0.5016}, {'accuracy': 0.4930800000000001}, {'accuracy': 0.49962999999999996}, {'accuracy': 0.49987000000000004}, {'accuracy': 0.50059}, {'accuracy': 0.5045299999999999}, {'accuracy': 0.5048000000000001}, {'accuracy': 0.50345}, {'accuracy': 0.50185}, {'accuracy': 0.5023500000000001}, {'accuracy': 0.5043500000000001}, {'accuracy': 0.4989}, {'accuracy': 0.5027200000000001}, {'accuracy': 0.5024299999999999}, {'accuracy': 0.49998000000000004}, {'accuracy': 0.49971000000000004}, {'accuracy': 0.50634}, {'accuracy': 0.50129}, {'accuracy': 0.49393000000000004}, {'accuracy': 0.49670000000000003}, {'accuracy': 0.5014599999999999}, {'accuracy': 0.5016200000000001}, {'accuracy': 0.4937600000000001}, {'accuracy': 0.5014099999999999}, {'accuracy': 0.50076}, {'accuracy': 0.5015999999999999}, {'accuracy': 0.50083}, {'accuracy': 0.49836}, {'accuracy': 0.49854000000000004}, {'accuracy': 0.50086}, {'accuracy': 0.5044599999999999}, {'accuracy': 0.50471}, {'accuracy': 0.50235}, {'accuracy': 0.5018}, {'accuracy': 0.5030599999999998}, {'accuracy': 0.50412}, {'accuracy': 0.5033800000000002}, {'accuracy': 0.5027199999999998}, {'accuracy': 0.501}, {'accuracy': 0.49828}, {'accuracy': 0.49433999999999995}, {'accuracy': 0.49849}, {'accuracy': 0.49994999999999984}, {'accuracy': 0.50357}, {'accuracy': 0.4979}, {'accuracy': 0.5006999999999999}, {'accuracy': 0.50125}, {'accuracy': 0.5022}, {'accuracy': 0.50382}, {'accuracy': 0.49393000000000004}, {'accuracy': 0.50365}, {'accuracy': 0.49804999999999994}, {'accuracy': 0.49339000000000005}, {'accuracy': 0.50476}, {'accuracy': 0.49867999999999996}, {'accuracy': 0.5031}, {'accuracy': 0.5010699999999999}, {'accuracy': 0.50254}, {'accuracy': 0.49924999999999997}, {'accuracy': 0.49985}, {'accuracy': 0.5017100000000001}, {'accuracy': 0.50245}, {'accuracy': 0.50346}, {'accuracy': 0.5028900000000001}, {'accuracy': 0.49790999999999996}, {'accuracy': 0.49995}, {'accuracy': 0.49989}, {'accuracy': 0.50006}, {'accuracy': 0.50347}, {'accuracy': 0.50241}, {'accuracy': 0.5010600000000001}, {'accuracy': 0.5018400000000001}, {'accuracy': 0.50158}, {'accuracy': 0.50288}, {'accuracy': 0.49940999999999997}, {'accuracy': 0.5005999999999999}, {'accuracy': 0.5009199999999999}, {'accuracy': 0.5011300000000001}, {'accuracy': 0.5021199999999999}, {'accuracy': 0.50223}, {'accuracy': 0.5016700000000001}, {'accuracy': 0.5038699999999999}, {'accuracy': 0.50274}, {'accuracy': 0.5001099999999999}, {'accuracy': 0.5043200000000001}, {'accuracy': 0.5018899999999998}, {'accuracy': 0.50096}, {'accuracy': 0.5047400000000001}, {'accuracy': 0.5007699999999999}, {'accuracy': 0.50256}, {'accuracy': 0.50198}, {'accuracy': 0.50079}, {'accuracy': 0.5019499999999999}, {'accuracy': 0.50128}, {'accuracy': 0.50253}, {'accuracy': 0.50278}, {'accuracy': 0.48075}, {'accuracy': 0.5041800000000001}, {'accuracy': 0.50155}, {'accuracy': 0.50206}, {'accuracy': 0.5021699999999999}, {'accuracy': 0.5023899999999999}, {'accuracy': 0.5040600000000001}, {'accuracy': 0.49978000000000006}, {'accuracy': 0.5027600000000001}, {'accuracy': 0.50198}, {'accuracy': 0.49996999999999997}, {'accuracy': 0.4988999999999999}, {'accuracy': 0.50059}, {'accuracy': 0.50362}, {'accuracy': 0.5018}, {'accuracy': 0.5015499999999999}, {'accuracy': 0.5002899999999999}, {'accuracy': 0.49901999999999996}, {'accuracy': 0.5015799999999999}, {'accuracy': 0.5048199999999999}, {'accuracy': 0.50076}, {'accuracy': 0.49847}, {'accuracy': 0.47838000000000014}, {'accuracy': 0.5014200000000002}, {'accuracy': 0.4898999999999999}, {'accuracy': 0.49389000000000005}, {'accuracy': 0.49854000000000004}, {'accuracy': 0.50132}, {'accuracy': 0.50248}, {'accuracy': 0.50178}, {'accuracy': 0.49692}, {'accuracy': 0.50027}, {'accuracy': 0.4934299999999999}, {'accuracy': 0.5047599999999999}, {'accuracy': 0.49539}, {'accuracy': 0.49245}, {'accuracy': 0.49642}, {'accuracy': 0.4920000000000001}, {'accuracy': 0.49958}, {'accuracy': 0.50234}, {'accuracy': 0.49883}]\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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",
      "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": "5b508a77-824f-49b5-bf3d-042628943788",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6669288b-f8c8-4f2e-8691-d6cf88fb1f81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "59bdc807-1a5e-4737-930c-abd4f0ac1871",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1bd9afa6-c3e8-4d82-8cb6-099c63175721",
   "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
}
