{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {
    "tags": []
   },
   "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",
      "5035\n",
      "[[  0 502]\n",
      " [  1 483]\n",
      " [  2 491]\n",
      " [  3 503]\n",
      " [  4 525]\n",
      " [  5 573]\n",
      " [  6 468]\n",
      " [  7 471]\n",
      " [  8 515]\n",
      " [  9 470]]\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": [
       "5022"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([7, 8, 7,  ..., 8, 5, 2])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5109\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 443]\n",
      " [  1 438]\n",
      " [  2 437]\n",
      " [  3 472]\n",
      " [  4 405]\n",
      " [  5 463]\n",
      " [  6 460]\n",
      " [  7 445]\n",
      " [  8 454]\n",
      " [  9 473]]\n",
      "[[  0 672]\n",
      " [  1 446]\n",
      " [  2 442]\n",
      " [  3 479]\n",
      " [  4 417]\n",
      " [  5 484]\n",
      " [  6 481]\n",
      " [  7 490]\n",
      " [  8 522]\n",
      " [  9 577]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([7, 7, 9,  ..., 9, 7, 3])"
      ]
     },
     "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<1:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        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": "b0805637-83d0-49e6-ac21-dc6fb51ac90d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "id": "3249552a-eed5-475c-9fe9-d271b4d7aaca",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10279}, {'accuracy': 0.10564}, {'accuracy': 0.11226000000000003}, {'accuracy': 0.16692}, {'accuracy': 0.17124}, {'accuracy': 0.18775}, {'accuracy': 0.22573}, {'accuracy': 0.27479}, {'accuracy': 0.24855}, {'accuracy': 0.2928}, {'accuracy': 0.30623}, {'accuracy': 0.21032}, {'accuracy': 0.28571}, {'accuracy': 0.24861}, {'accuracy': 0.35163999999999995}, {'accuracy': 0.32542}, {'accuracy': 0.32431}, {'accuracy': 0.28758}, {'accuracy': 0.3236}, {'accuracy': 0.32507}, {'accuracy': 0.37997000000000003}, {'accuracy': 0.31828}, {'accuracy': 0.36499}, {'accuracy': 0.4166199999999999}, {'accuracy': 0.31357}, {'accuracy': 0.33396}, {'accuracy': 0.34421}, {'accuracy': 0.36256}, {'accuracy': 0.36461}, {'accuracy': 0.38261}, {'accuracy': 0.35232}, {'accuracy': 0.3783}, {'accuracy': 0.33132}, {'accuracy': 0.31781}, {'accuracy': 0.28084}, {'accuracy': 0.40444}, {'accuracy': 0.35527999999999993}, {'accuracy': 0.36827}, {'accuracy': 0.38045999999999996}, {'accuracy': 0.41441}, {'accuracy': 0.41179}, {'accuracy': 0.38993}, {'accuracy': 0.47226}, {'accuracy': 0.42153}, {'accuracy': 0.39815}, {'accuracy': 0.39871}, {'accuracy': 0.39485000000000003}, {'accuracy': 0.39791}, {'accuracy': 0.36741999999999997}, {'accuracy': 0.39808}, {'accuracy': 0.43726000000000004}, {'accuracy': 0.51216}, {'accuracy': 0.38865000000000005}, {'accuracy': 0.40885}, {'accuracy': 0.45072999999999996}, {'accuracy': 0.42729999999999996}, {'accuracy': 0.47540000000000004}, {'accuracy': 0.43218999999999996}, {'accuracy': 0.45357000000000003}, {'accuracy': 0.47826}, {'accuracy': 0.49037}, {'accuracy': 0.49444}, {'accuracy': 0.48574}, {'accuracy': 0.4931}, {'accuracy': 0.5165999999999998}, {'accuracy': 0.54511}, {'accuracy': 0.46311}, {'accuracy': 0.55106}, {'accuracy': 0.48830000000000007}, {'accuracy': 0.49713}, {'accuracy': 0.49618}, {'accuracy': 0.5475700000000001}, {'accuracy': 0.4918699999999999}, {'accuracy': 0.4912500000000001}, {'accuracy': 0.53066}, {'accuracy': 0.5508200000000001}, {'accuracy': 0.5344500000000001}, {'accuracy': 0.56985}, {'accuracy': 0.52566}, {'accuracy': 0.52398}, {'accuracy': 0.55381}, {'accuracy': 0.55423}, {'accuracy': 0.56052}, {'accuracy': 0.54164}, {'accuracy': 0.55236}, {'accuracy': 0.57042}, {'accuracy': 0.55948}, {'accuracy': 0.55252}, {'accuracy': 0.5454600000000001}, {'accuracy': 0.51268}, {'accuracy': 0.53804}, {'accuracy': 0.5432599999999999}, {'accuracy': 0.5475399999999999}, {'accuracy': 0.57055}, {'accuracy': 0.58144}, {'accuracy': 0.57854}, {'accuracy': 0.56362}, {'accuracy': 0.5755600000000001}, {'accuracy': 0.5496999999999999}, {'accuracy': 0.5575700000000001}, {'accuracy': 0.58857}, {'accuracy': 0.56265}, {'accuracy': 0.55404}, {'accuracy': 0.5715199999999999}, {'accuracy': 0.55688}, {'accuracy': 0.58802}, {'accuracy': 0.5987699999999999}, {'accuracy': 0.53861}, {'accuracy': 0.5914900000000001}, {'accuracy': 0.58358}, {'accuracy': 0.56646}, {'accuracy': 0.60235}, {'accuracy': 0.5926500000000001}, {'accuracy': 0.58848}, {'accuracy': 0.57786}, {'accuracy': 0.5690199999999999}, {'accuracy': 0.60202}, {'accuracy': 0.59036}, {'accuracy': 0.58829}, {'accuracy': 0.60971}, {'accuracy': 0.59796}, {'accuracy': 0.59763}, {'accuracy': 0.58921}, {'accuracy': 0.6065299999999999}, {'accuracy': 0.61175}, {'accuracy': 0.57973}, {'accuracy': 0.6116400000000001}, {'accuracy': 0.60488}, {'accuracy': 0.59277}, {'accuracy': 0.58424}, {'accuracy': 0.61177}, {'accuracy': 0.6029000000000001}, {'accuracy': 0.6052900000000001}, {'accuracy': 0.60954}, {'accuracy': 0.61171}, {'accuracy': 0.6099600000000001}, {'accuracy': 0.60983}, {'accuracy': 0.6120299999999999}, {'accuracy': 0.6041000000000001}, {'accuracy': 0.6070499999999999}, {'accuracy': 0.61054}, {'accuracy': 0.61212}, {'accuracy': 0.60336}, {'accuracy': 0.60337}, {'accuracy': 0.6065400000000001}, {'accuracy': 0.60883}, {'accuracy': 0.60781}, {'accuracy': 0.60751}, {'accuracy': 0.6067400000000001}, {'accuracy': 0.60572}, {'accuracy': 0.6084499999999999}, {'accuracy': 0.60843}, {'accuracy': 0.60779}, {'accuracy': 0.61331}, {'accuracy': 0.61432}, {'accuracy': 0.6091400000000001}, {'accuracy': 0.6082599999999999}, {'accuracy': 0.6049899999999999}, {'accuracy': 0.60847}, {'accuracy': 0.60942}, {'accuracy': 0.60088}, {'accuracy': 0.61571}, {'accuracy': 0.60948}, {'accuracy': 0.60723}, {'accuracy': 0.60517}, {'accuracy': 0.60367}, {'accuracy': 0.6102699999999999}, {'accuracy': 0.6086400000000001}, {'accuracy': 0.57594}, {'accuracy': 0.6062799999999999}, {'accuracy': 0.61032}, {'accuracy': 0.54854}, {'accuracy': 0.5789799999999999}, {'accuracy': 0.57887}, {'accuracy': 0.5936899999999998}, {'accuracy': 0.56299}, {'accuracy': 0.60498}, {'accuracy': 0.60108}, {'accuracy': 0.5883999999999999}, {'accuracy': 0.61617}, {'accuracy': 0.60886}, {'accuracy': 0.61183}, {'accuracy': 0.60568}, {'accuracy': 0.6113999999999999}, {'accuracy': 0.6022199999999999}, {'accuracy': 0.61051}, {'accuracy': 0.6088}, {'accuracy': 0.6075099999999999}, {'accuracy': 0.6076699999999999}, {'accuracy': 0.61034}, {'accuracy': 0.6107199999999999}, {'accuracy': 0.5476500000000002}, {'accuracy': 0.6072300000000002}, {'accuracy': 0.60942}, {'accuracy': 0.6086000000000001}, {'accuracy': 0.59782}, {'accuracy': 0.5135}, {'accuracy': 0.58212}, {'accuracy': 0.5721200000000001}, {'accuracy': 0.5988100000000001}, {'accuracy': 0.60388}, {'accuracy': 0.59855}, {'accuracy': 0.61087}, {'accuracy': 0.59311}, {'accuracy': 0.61023}, {'accuracy': 0.62144}, {'accuracy': 0.61968}, {'accuracy': 0.6076999999999999}, {'accuracy': 0.57926}, {'accuracy': 0.58797}, {'accuracy': 0.60558}, {'accuracy': 0.5866800000000001}, {'accuracy': 0.59569}, {'accuracy': 0.6164600000000001}, {'accuracy': 0.61669}, {'accuracy': 0.61495}, {'accuracy': 0.61799}, {'accuracy': 0.58628}, {'accuracy': 0.6070599999999999}, {'accuracy': 0.61298}, {'accuracy': 0.61121}, {'accuracy': 0.6202300000000001}, {'accuracy': 0.62268}, {'accuracy': 0.6235299999999999}, {'accuracy': 0.6218999999999999}, {'accuracy': 0.6170500000000001}, {'accuracy': 0.6211099999999999}, {'accuracy': 0.6222799999999999}, {'accuracy': 0.62252}, {'accuracy': 0.62136}, {'accuracy': 0.61998}, {'accuracy': 0.62172}, {'accuracy': 0.61988}, {'accuracy': 0.6210699999999999}, {'accuracy': 0.6225299999999999}, {'accuracy': 0.61789}, {'accuracy': 0.62163}, {'accuracy': 0.61917}, {'accuracy': 0.6221099999999999}, {'accuracy': 0.6219899999999999}, {'accuracy': 0.62256}, {'accuracy': 0.61783}, {'accuracy': 0.6163000000000001}, {'accuracy': 0.61704}, {'accuracy': 0.6173200000000001}, {'accuracy': 0.61829}, {'accuracy': 0.61753}, {'accuracy': 0.61492}, {'accuracy': 0.61758}, {'accuracy': 0.61835}, {'accuracy': 0.6164799999999999}, {'accuracy': 0.6185099999999999}, {'accuracy': 0.6153900000000001}, {'accuracy': 0.6156400000000001}, {'accuracy': 0.61273}, {'accuracy': 0.61668}, {'accuracy': 0.61626}, {'accuracy': 0.6177900000000001}, {'accuracy': 0.61452}, {'accuracy': 0.6187600000000001}, {'accuracy': 0.61505}, {'accuracy': 0.61509}, {'accuracy': 0.61216}, {'accuracy': 0.6136099999999999}, {'accuracy': 0.6145599999999999}, {'accuracy': 0.61445}, {'accuracy': 0.6180399999999999}, {'accuracy': 0.61688}, {'accuracy': 0.6143400000000001}, {'accuracy': 0.61588}, {'accuracy': 0.6140899999999999}, {'accuracy': 0.61408}, {'accuracy': 0.61215}, {'accuracy': 0.61209}, {'accuracy': 0.6127900000000001}, {'accuracy': 0.61637}, {'accuracy': 0.61467}, {'accuracy': 0.6134100000000001}, {'accuracy': 0.6140100000000001}, {'accuracy': 0.61411}, {'accuracy': 0.61043}, {'accuracy': 0.60929}, {'accuracy': 0.6118300000000001}, {'accuracy': 0.60808}, {'accuracy': 0.6102099999999999}, {'accuracy': 0.61242}, {'accuracy': 0.61169}, {'accuracy': 0.6128899999999999}, {'accuracy': 0.61364}, {'accuracy': 0.61281}, {'accuracy': 0.61375}, {'accuracy': 0.6125800000000001}, {'accuracy': 0.6123799999999999}, {'accuracy': 0.6144000000000001}, {'accuracy': 0.6119000000000001}, {'accuracy': 0.6117}, {'accuracy': 0.6112299999999999}, {'accuracy': 0.6114200000000001}, {'accuracy': 0.6093}, {'accuracy': 0.61202}, {'accuracy': 0.61141}, {'accuracy': 0.61318}, {'accuracy': 0.60961}, {'accuracy': 0.60886}, {'accuracy': 0.60728}, {'accuracy': 0.6105}, {'accuracy': 0.60881}, {'accuracy': 0.6008899999999999}, {'accuracy': 0.56179}, {'accuracy': 0.5483499999999999}, {'accuracy': 0.5709299999999999}, {'accuracy': 0.59395}, {'accuracy': 0.5947}, {'accuracy': 0.56508}, {'accuracy': 0.6054}, {'accuracy': 0.60701}, {'accuracy': 0.60365}, {'accuracy': 0.5871699999999999}, {'accuracy': 0.59591}, {'accuracy': 0.58197}, {'accuracy': 0.59272}, {'accuracy': 0.57081}, {'accuracy': 0.6029799999999998}, {'accuracy': 0.6167199999999999}, {'accuracy': 0.61907}, {'accuracy': 0.62192}, {'accuracy': 0.6233700000000001}, {'accuracy': 0.6268499999999999}, {'accuracy': 0.6239699999999999}, {'accuracy': 0.6254799999999999}, {'accuracy': 0.62513}, {'accuracy': 0.62835}, {'accuracy': 0.62593}, {'accuracy': 0.6281}, {'accuracy': 0.6251899999999999}, {'accuracy': 0.6260300000000001}, {'accuracy': 0.6247499999999999}, {'accuracy': 0.6244}, {'accuracy': 0.6244099999999999}, {'accuracy': 0.6240699999999999}, {'accuracy': 0.61441}, {'accuracy': 0.61669}, {'accuracy': 0.6153799999999999}, {'accuracy': 0.6228300000000001}, {'accuracy': 0.62405}, {'accuracy': 0.62266}, {'accuracy': 0.6214199999999999}, {'accuracy': 0.62461}, {'accuracy': 0.62388}, {'accuracy': 0.62301}, {'accuracy': 0.6237100000000001}, {'accuracy': 0.62198}, {'accuracy': 0.6220099999999998}, {'accuracy': 0.61923}, {'accuracy': 0.62155}, {'accuracy': 0.61875}, {'accuracy': 0.62416}, {'accuracy': 0.6203299999999999}, {'accuracy': 0.62144}, {'accuracy': 0.6217499999999999}, {'accuracy': 0.62014}, {'accuracy': 0.6190499999999999}, {'accuracy': 0.62054}, {'accuracy': 0.6196699999999999}, {'accuracy': 0.6167}, {'accuracy': 0.6180899999999999}, {'accuracy': 0.61571}, {'accuracy': 0.6177100000000001}, {'accuracy': 0.6162400000000001}, {'accuracy': 0.6165499999999999}, {'accuracy': 0.6206400000000001}, {'accuracy': 0.6171599999999999}, {'accuracy': 0.6174700000000001}, {'accuracy': 0.61605}, {'accuracy': 0.61847}, {'accuracy': 0.6160800000000001}, {'accuracy': 0.61644}, {'accuracy': 0.61859}, {'accuracy': 0.61842}, {'accuracy': 0.6159300000000002}, {'accuracy': 0.61407}, {'accuracy': 0.61424}, {'accuracy': 0.61372}, {'accuracy': 0.61689}, {'accuracy': 0.6160599999999999}, {'accuracy': 0.6156599999999999}, {'accuracy': 0.6173000000000001}, {'accuracy': 0.61565}, {'accuracy': 0.6165900000000001}, {'accuracy': 0.61656}, {'accuracy': 0.61259}, {'accuracy': 0.61598}, {'accuracy': 0.6161399999999999}, {'accuracy': 0.61589}, {'accuracy': 0.6147199999999999}, {'accuracy': 0.61288}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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": "baf4919e-adec-4e65-b00b-409e09bd182e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c629addb-16d1-409a-b7c5-0d6ac5849809",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c3890af-9ca7-460d-87d7-61a7749722db",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d1a4046-9253-4dcf-acee-ceac85fd9b19",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cbe87020-2f37-440e-90db-c740464dc41f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fa232ac8-7e47-4060-8cf0-3b0dc4f4bd6e",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
