{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\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_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=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",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\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_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2335]\n",
      " [   1   61]\n",
      " [   2   48]\n",
      " [   3   73]\n",
      " [   4  106]\n",
      " [   5  190]\n",
      " [   6  297]\n",
      " [   7  522]\n",
      " [   8  879]\n",
      " [   9 1428]]\n",
      "[[   0 1486]\n",
      " [   1 2450]\n",
      " [   2   57]\n",
      " [   3   36]\n",
      " [   4   47]\n",
      " [   5  113]\n",
      " [   6  172]\n",
      " [   7  349]\n",
      " [   8  549]\n",
      " [   9  869]]\n",
      "[[   0  883]\n",
      " [   1 1435]\n",
      " [   2 2363]\n",
      " [   3   66]\n",
      " [   4   50]\n",
      " [   5   70]\n",
      " [   6  113]\n",
      " [   7  170]\n",
      " [   8  317]\n",
      " [   9  511]]\n",
      "[[   0  557]\n",
      " [   1  842]\n",
      " [   2 1475]\n",
      " [   3 2317]\n",
      " [   4   43]\n",
      " [   5   44]\n",
      " [   6   60]\n",
      " [   7  116]\n",
      " [   8  190]\n",
      " [   9  305]]\n",
      "[[   0  301]\n",
      " [   1  501]\n",
      " [   2  869]\n",
      " [   3 1534]\n",
      " [   4 2441]\n",
      " [   5   59]\n",
      " [   6   38]\n",
      " [   7   71]\n",
      " [   8  110]\n",
      " [   9  198]]\n",
      "[[   0  175]\n",
      " [   1  293]\n",
      " [   2  500]\n",
      " [   3  826]\n",
      " [   4 1534]\n",
      " [   5 2278]\n",
      " [   6   72]\n",
      " [   7   37]\n",
      " [   8   68]\n",
      " [   9  102]]\n",
      "[[   0  116]\n",
      " [   1  196]\n",
      " [   2  328]\n",
      " [   3  524]\n",
      " [   4  773]\n",
      " [   5 1437]\n",
      " [   6 2477]\n",
      " [   7   74]\n",
      " [   8   40]\n",
      " [   9   52]]\n",
      "[[   0   59]\n",
      " [   1  112]\n",
      " [   2  188]\n",
      " [   3  318]\n",
      " [   4  531]\n",
      " [   5  946]\n",
      " [   6 1406]\n",
      " [   7 2362]\n",
      " [   8   55]\n",
      " [   9   46]]\n",
      "[[   0   35]\n",
      " [   1   69]\n",
      " [   2  112]\n",
      " [   3  182]\n",
      " [   4  299]\n",
      " [   5  533]\n",
      " [   6  843]\n",
      " [   7 1433]\n",
      " [   8 2352]\n",
      " [   9   56]]\n",
      "[[   0   53]\n",
      " [   1   41]\n",
      " [   2   60]\n",
      " [   3  124]\n",
      " [   4  176]\n",
      " [   5  330]\n",
      " [   6  522]\n",
      " [   7  866]\n",
      " [   8 1440]\n",
      " [   9 2433]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\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",
    "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(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \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(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \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(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \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(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[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(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[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(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\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(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[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(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[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(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\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(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[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",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\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": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7316\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1805]\n",
      " [   1   61]\n",
      " [   2   26]\n",
      " [   3   73]\n",
      " [   4   78]\n",
      " [   5  190]\n",
      " [   6  207]\n",
      " [   7  522]\n",
      " [   8  879]\n",
      " [   9 1428]]\n",
      "[[   0 2482]\n",
      " [   1   61]\n",
      " [   2   42]\n",
      " [   3   73]\n",
      " [   4  106]\n",
      " [   5  190]\n",
      " [   6  321]\n",
      " [   7  522]\n",
      " [   8  879]\n",
      " [   9 1428]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "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,60000,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,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(2))     \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",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\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\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.77</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.77\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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yM/Px7Zt2xAZGQkASElJkfZ99dVXcccdd+Cll16StqWmpnrc5scffxw333yzbNtTTz0lff3II49g5cqV+OabbzBgwACUl5fjnXfewfvvv4+JEycCADp06IChQ4cCAG6++WZMmzYNP/74I26//XYAwJIlS3DPPfd4dYJFdks1EnGkFMDRUkRE5LmjR49i3LhxaN++PfR6PZKTkwEAmZmZ2LVrF/r06SMFNq527dqFUaNGXXAb+vfvL/vearXilVdeQc+ePREZGYmQkBCsXLkSmZmZAICDBw/CZDLVeW6dToe7774bixYtAgDs2LED+/btwz333HPBba0Pn8KNRKy3UasU0AQwZiQiag4C1SoceHmMz87tieuuuw5t27bFwoULkZCQAJvNhh49esBsNiMwMLD+c53jfYVCAUEQZNvcFQwHBwfLvn/rrbfwzjvvYN68eejZsyeCg4Px+OOPw2w2N+i8gL1rqnfv3jhz5gwWL16MkSNHom3btuf83IXgU7iRiCOlPP1lJiIi71EoFAjSBPjk5Um3S2FhIQ4fPowXXngBo0aNQteuXVFcXCy936tXL+zatQtFRUVuP9+rV696C3Sjo6ORnZ0tfX/06NEGLS66YcMG3HDDDbjrrruQmpqK9u3b48iRI9L7HTt2RGBgYL3n7tmzJ/r374+FCxfiq6++wr333nvO814oBjeNpGZ2YibDiIjIMxEREWjVqhU+/vhjHDt2DH/++SemT58uvT9u3DjExcXhxhtvxIYNG3DixAn873//w6ZNmwAAs2fPxtdff43Zs2fj4MGD2Lt3L9544w3p8yNHjsT777+PnTt34p9//sGDDz4ItVp9znZ17NgRq1evxsaNG3Hw4EE88MADyM3Nld7X6XR49tln8cwzz+Czzz7D8ePHsXnzZnzyySey40yePBmvv/46BEGQjeLyFgY3jcRitSFYo2JwQ0REHlMqlVi6dCm2b9+OHj164IknnsBbb70lva/RaLBq1SrExMTg6quvRs+ePfH6669Li0uOGDEC3377LX766Sf07t0bI0eOxNatW6XPv/3220hKSsKwYcNw55134qmnnmrQ4qIvvPAC+vbtizFjxmDEiBFSgOVs5syZePLJJzFr1ix07doVY8eORV5enmyfcePGISAgAOPGjYNOp7uAO9UwCsG1E87PlZWVISwsDKWlpdDr9Y1+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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.13794}, {'accuracy': 0.20002}, {'accuracy': 0.17514}, {'accuracy': 0.25654}, {'accuracy': 0.29074}, {'accuracy': 0.24034}, {'accuracy': 0.28662}, {'accuracy': 0.29148999999999997}, {'accuracy': 0.36872}, {'accuracy': 0.32687999999999995}, {'accuracy': 0.35225}, {'accuracy': 0.37648999999999994}, {'accuracy': 0.37719}, {'accuracy': 0.40076999999999996}, {'accuracy': 0.42796}, {'accuracy': 0.42401}, {'accuracy': 0.43596}, {'accuracy': 0.48768}, {'accuracy': 0.48979}, {'accuracy': 0.48368}, {'accuracy': 0.49756999999999996}, {'accuracy': 0.53664}, {'accuracy': 0.516}, {'accuracy': 0.5363899999999999}, {'accuracy': 0.58362}, {'accuracy': 0.6359299999999999}, {'accuracy': 0.62995}, {'accuracy': 0.6117900000000001}, {'accuracy': 0.5962400000000001}, {'accuracy': 0.56673}, {'accuracy': 0.5739799999999999}, {'accuracy': 0.5896999999999999}, {'accuracy': 0.5760599999999999}, {'accuracy': 0.59059}, {'accuracy': 0.60568}, {'accuracy': 0.57218}, {'accuracy': 0.58189}, {'accuracy': 0.5681099999999999}, {'accuracy': 0.5752499999999999}, {'accuracy': 0.60627}, {'accuracy': 0.59121}, {'accuracy': 0.59445}, {'accuracy': 0.5460699999999999}, {'accuracy': 0.60503}, {'accuracy': 0.58184}, {'accuracy': 0.62196}, {'accuracy': 0.63598}, {'accuracy': 0.59701}, {'accuracy': 0.6218100000000001}, {'accuracy': 0.61541}, {'accuracy': 0.62256}, {'accuracy': 0.63286}, {'accuracy': 0.6228999999999999}, {'accuracy': 0.6466099999999999}, {'accuracy': 0.61337}, {'accuracy': 0.63681}, {'accuracy': 0.6254799999999999}, {'accuracy': 0.60866}, {'accuracy': 0.6382}, {'accuracy': 0.6173500000000001}, {'accuracy': 0.6227400000000001}, {'accuracy': 0.6288199999999999}, {'accuracy': 0.64006}, {'accuracy': 0.6109199999999999}, {'accuracy': 0.6369199999999999}, {'accuracy': 0.6475000000000001}, {'accuracy': 0.6175999999999999}, {'accuracy': 0.5921599999999999}, {'accuracy': 0.5811499999999999}, {'accuracy': 0.6626200000000001}, {'accuracy': 0.65879}, {'accuracy': 0.6579900000000001}, {'accuracy': 0.6404500000000001}, {'accuracy': 0.6416600000000001}, {'accuracy': 0.63766}, {'accuracy': 0.59477}, {'accuracy': 0.6403700000000001}, {'accuracy': 0.66021}, {'accuracy': 0.59853}, {'accuracy': 0.66257}, {'accuracy': 0.62718}, {'accuracy': 0.6838900000000001}, {'accuracy': 0.67099}, {'accuracy': 0.65823}, {'accuracy': 0.64147}, {'accuracy': 0.62489}, {'accuracy': 0.64735}, {'accuracy': 0.67635}, {'accuracy': 0.6245099999999999}, {'accuracy': 0.64869}, {'accuracy': 0.66418}, {'accuracy': 0.5762599999999999}, {'accuracy': 0.65258}, {'accuracy': 0.6617599999999999}, {'accuracy': 0.61699}, {'accuracy': 0.67372}, {'accuracy': 0.6459800000000001}, {'accuracy': 0.6720400000000002}, {'accuracy': 0.64417}, {'accuracy': 0.6300600000000001}, {'accuracy': 0.63594}, {'accuracy': 0.67781}, {'accuracy': 0.63988}, {'accuracy': 0.63208}, {'accuracy': 0.6486099999999999}, {'accuracy': 0.6724599999999998}, {'accuracy': 0.66088}, {'accuracy': 0.67364}, {'accuracy': 0.6523}, {'accuracy': 0.6590699999999999}, {'accuracy': 0.6546799999999999}, {'accuracy': 0.66165}, {'accuracy': 0.64022}, {'accuracy': 0.63181}, {'accuracy': 0.63267}, {'accuracy': 0.65567}, {'accuracy': 0.65009}, {'accuracy': 0.6211499999999999}, {'accuracy': 0.6386999999999999}, {'accuracy': 0.6867300000000001}, {'accuracy': 0.66446}, {'accuracy': 0.6316999999999999}, {'accuracy': 0.6384999999999998}, {'accuracy': 0.66804}, {'accuracy': 0.65727}, {'accuracy': 0.6437700000000001}, {'accuracy': 0.6643000000000001}, {'accuracy': 0.68356}, {'accuracy': 0.67093}, {'accuracy': 0.6781}, {'accuracy': 0.6839999999999999}, {'accuracy': 0.6406799999999999}, {'accuracy': 0.6556}, {'accuracy': 0.68547}, {'accuracy': 0.65333}, {'accuracy': 0.6622100000000001}, {'accuracy': 0.64718}, {'accuracy': 0.67075}, {'accuracy': 0.62635}, {'accuracy': 0.6959599999999999}, {'accuracy': 0.6672500000000001}, {'accuracy': 0.6740900000000001}, {'accuracy': 0.6554599999999999}, {'accuracy': 0.63042}, {'accuracy': 0.65701}, {'accuracy': 0.69519}, {'accuracy': 0.6522499999999999}, {'accuracy': 0.70008}, {'accuracy': 0.68789}, {'accuracy': 0.63437}, {'accuracy': 0.69527}, {'accuracy': 0.68772}, {'accuracy': 0.6632600000000001}, {'accuracy': 0.71139}, {'accuracy': 0.68158}, {'accuracy': 0.6603}, {'accuracy': 0.6980799999999999}, {'accuracy': 0.70548}, {'accuracy': 0.7113999999999999}, {'accuracy': 0.6825100000000001}, {'accuracy': 0.70823}, {'accuracy': 0.65894}, {'accuracy': 0.66462}, {'accuracy': 0.6956299999999999}, {'accuracy': 0.67088}, {'accuracy': 0.66273}, {'accuracy': 0.68087}, {'accuracy': 0.6781400000000001}, {'accuracy': 0.6299999999999999}, {'accuracy': 0.68754}, {'accuracy': 0.6905699999999999}, {'accuracy': 0.6975100000000001}, {'accuracy': 0.7102800000000001}, {'accuracy': 0.66959}, {'accuracy': 0.6732899999999999}, {'accuracy': 0.6620900000000001}, {'accuracy': 0.61554}, {'accuracy': 0.6975399999999999}, {'accuracy': 0.65656}, {'accuracy': 0.68801}, {'accuracy': 0.6702899999999998}, {'accuracy': 0.6633399999999999}, {'accuracy': 0.6368400000000001}, {'accuracy': 0.6976000000000001}, {'accuracy': 0.6945}, {'accuracy': 0.6504}, {'accuracy': 0.69981}, {'accuracy': 0.68867}, {'accuracy': 0.66731}, {'accuracy': 0.63659}, {'accuracy': 0.6991399999999999}, {'accuracy': 0.65886}, {'accuracy': 0.67703}, {'accuracy': 0.7065100000000001}, {'accuracy': 0.6959500000000001}, {'accuracy': 0.7062200000000001}, {'accuracy': 0.6645500000000001}, {'accuracy': 0.6963199999999999}, {'accuracy': 0.6660899999999998}, {'accuracy': 0.68918}, {'accuracy': 0.7039000000000002}, {'accuracy': 0.7697999999999999}, {'accuracy': 0.76977}, {'accuracy': 0.7746799999999999}, {'accuracy': 0.77634}, {'accuracy': 0.7738499999999999}, {'accuracy': 0.77379}, {'accuracy': 0.7746999999999999}, {'accuracy': 0.7731899999999999}, {'accuracy': 0.7728900000000001}, {'accuracy': 0.7758800000000001}, {'accuracy': 0.7752399999999999}, {'accuracy': 0.77213}, {'accuracy': 0.76968}, {'accuracy': 0.77597}, {'accuracy': 0.7718700000000001}, {'accuracy': 0.7778400000000001}, {'accuracy': 0.77622}, {'accuracy': 0.77573}, {'accuracy': 0.77686}, {'accuracy': 0.76976}, {'accuracy': 0.7749900000000001}, {'accuracy': 0.7779499999999999}, {'accuracy': 0.77057}, {'accuracy': 0.77674}, {'accuracy': 0.77702}, {'accuracy': 0.77607}, {'accuracy': 0.7706000000000001}, {'accuracy': 0.78006}, {'accuracy': 0.7761}, {'accuracy': 0.7721600000000001}, {'accuracy': 0.7758}, {'accuracy': 0.7718700000000001}, {'accuracy': 0.77167}, {'accuracy': 0.77566}, {'accuracy': 0.77564}, {'accuracy': 0.77632}, {'accuracy': 0.7732300000000001}, {'accuracy': 0.7736500000000001}, {'accuracy': 0.7713500000000001}, {'accuracy': 0.77462}, {'accuracy': 0.77124}, {'accuracy': 0.7778400000000001}, {'accuracy': 0.77348}, {'accuracy': 0.7735000000000001}, {'accuracy': 0.77776}, {'accuracy': 0.77406}, {'accuracy': 0.7733700000000001}, {'accuracy': 0.7758300000000001}, {'accuracy': 0.7737100000000001}, {'accuracy': 0.7731600000000001}, {'accuracy': 0.7727}, {'accuracy': 0.77433}, {'accuracy': 0.7768200000000001}, {'accuracy': 0.7757799999999999}, {'accuracy': 0.77418}, {'accuracy': 0.7756100000000001}, {'accuracy': 0.77297}, {'accuracy': 0.7749999999999999}, {'accuracy': 0.7734099999999999}, {'accuracy': 0.7672700000000001}, {'accuracy': 0.77252}, {'accuracy': 0.7761799999999999}, {'accuracy': 0.77677}, {'accuracy': 0.77315}, {'accuracy': 0.77504}, {'accuracy': 0.7716900000000001}, {'accuracy': 0.7763000000000001}, {'accuracy': 0.77659}, {'accuracy': 0.77129}, {'accuracy': 0.7762699999999999}, {'accuracy': 0.77505}, {'accuracy': 0.77677}, {'accuracy': 0.77218}, {'accuracy': 0.77627}, {'accuracy': 0.7802300000000001}, {'accuracy': 0.7743300000000001}, {'accuracy': 0.77522}, {'accuracy': 0.77355}, {'accuracy': 0.7689600000000001}, {'accuracy': 0.77134}, {'accuracy': 0.7759699999999999}, {'accuracy': 0.7708}, {'accuracy': 0.7733700000000001}, {'accuracy': 0.7735599999999999}, {'accuracy': 0.77426}, {'accuracy': 0.77328}, {'accuracy': 0.7744099999999999}, {'accuracy': 0.7759699999999999}, {'accuracy': 0.77526}, {'accuracy': 0.7738}, {'accuracy': 0.77359}, {'accuracy': 0.7798700000000001}, {'accuracy': 0.77695}, {'accuracy': 0.7722100000000001}, {'accuracy': 0.78257}, {'accuracy': 0.77423}, {'accuracy': 0.76927}, {'accuracy': 0.77455}, {'accuracy': 0.7727700000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b7cf3cd-0f2e-4677-a995-3c01ef0af65a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77c0f3cf-2999-40aa-93e7-73924d2c4f26",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e0edaa-0ae8-4e79-8c56-98d960f604bf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc31766d-d70e-4c8b-8918-3533fb21d9bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccc00971-e277-4bc2-a8d5-11829397e40c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "881255e2-5d20-40f8-9ca4-d7951edfc419",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "852e18c7-bf8c-43ec-8a00-3baf3abad300",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67b920fe-6085-4e7b-aa1e-ffee1c7da95d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5077bfe-47be-4497-9357-aae20abd8020",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b8c5d9e-0713-47d6-b65c-ad0cbbdb8381",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ac7c8f3-1533-4f2f-b87f-06f31d57846b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f2737a9-e89a-4404-b8f4-9de5f129bbf0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a0434dc-d371-4075-8aa8-690883a96449",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f2376a5-dac3-48ad-a034-3d1bbe80a05e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58eb6494-5b98-4f8e-a813-d41eeba50c28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "259420a5-318d-41d7-8197-8a06f105d753",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fe5502f-779c-446b-9f83-f1a4a26ee3d6",
   "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
}
