{
 "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",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\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(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2339]\n",
      " [   1   64]\n",
      " [   2   34]\n",
      " [   3   64]\n",
      " [   4   98]\n",
      " [   5  156]\n",
      " [   6  305]\n",
      " [   7  506]\n",
      " [   8  859]\n",
      " [   9 1453]]\n",
      "[[   0 1468]\n",
      " [   1 2758]\n",
      " [   2   62]\n",
      " [   3   38]\n",
      " [   4   56]\n",
      " [   5  129]\n",
      " [   6  181]\n",
      " [   7  298]\n",
      " [   8  542]\n",
      " [   9  839]]\n",
      "[[   0  828]\n",
      " [   1 1604]\n",
      " [   2 2357]\n",
      " [   3   62]\n",
      " [   4   38]\n",
      " [   5   53]\n",
      " [   6   88]\n",
      " [   7  194]\n",
      " [   8  317]\n",
      " [   9  518]]\n",
      "[[   0  538]\n",
      " [   1  978]\n",
      " [   2 1439]\n",
      " [   3 2502]\n",
      " [   4   52]\n",
      " [   5   35]\n",
      " [   6   71]\n",
      " [   7  118]\n",
      " [   8  209]\n",
      " [   9  321]]\n",
      "[[   0  295]\n",
      " [   1  586]\n",
      " [   2  842]\n",
      " [   3 1437]\n",
      " [   4 2332]\n",
      " [   5   51]\n",
      " [   6   40]\n",
      " [   7   81]\n",
      " [   8  106]\n",
      " [   9  174]]\n",
      "[[   0  201]\n",
      " [   1  325]\n",
      " [   2  540]\n",
      " [   3  884]\n",
      " [   4 1429]\n",
      " [   5 2174]\n",
      " [   6   59]\n",
      " [   7   47]\n",
      " [   8   73]\n",
      " [   9  118]]\n",
      "[[   0   84]\n",
      " [   1  192]\n",
      " [   2  297]\n",
      " [   3  543]\n",
      " [   4  846]\n",
      " [   5 1324]\n",
      " [   6 2427]\n",
      " [   7   58]\n",
      " [   8   34]\n",
      " [   9   74]]\n",
      "[[   0   74]\n",
      " [   1  110]\n",
      " [   2  184]\n",
      " [   3  315]\n",
      " [   4  504]\n",
      " [   5  774]\n",
      " [   6 1353]\n",
      " [   7 2516]\n",
      " [   8   63]\n",
      " [   9   33]]\n",
      "[[   0   37]\n",
      " [   1   71]\n",
      " [   2  127]\n",
      " [   3  186]\n",
      " [   4  330]\n",
      " [   5  451]\n",
      " [   6  896]\n",
      " [   7 1524]\n",
      " [   8 2293]\n",
      " [   9   62]]\n",
      "[[   0   59]\n",
      " [   1   54]\n",
      " [   2   76]\n",
      " [   3  100]\n",
      " [   4  157]\n",
      " [   5  274]\n",
      " [   6  498]\n",
      " [   7  923]\n",
      " [   8 1355]\n",
      " [   9 2357]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "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",
    "train_set, test_set = get_MNIST()\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": [
      "12403\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1628]\n",
      " [   1   31]\n",
      " [   2   34]\n",
      " [   3   64]\n",
      " [   4   98]\n",
      " [   5  156]\n",
      " [   6  165]\n",
      " [   7  272]\n",
      " [   8  859]\n",
      " [   9 1453]]\n",
      "[[   0 2800]\n",
      " [   1   65]\n",
      " [   2   34]\n",
      " [   3   64]\n",
      " [   4   98]\n",
      " [   5  156]\n",
      " [   6  294]\n",
      " [   7  599]\n",
      " [   8  859]\n",
      " [   9 1453]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 7, 7, 7])"
      ]
     },
     "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<5:\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]==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",
    "            noiseyset[1].append(torch.tensor(7))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==7:\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(1))     \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": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "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\">151023-18:04:43 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:04:43\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e9d853ab6a11470baf29da3a9e509253",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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\">151023-19:33:20 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2257</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-19:33:20\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m2257\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">49292880</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m49292880\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.11912}, {'accuracy': 0.1449}, {'accuracy': 0.14678000000000002}, {'accuracy': 0.18405}, {'accuracy': 0.2665}, {'accuracy': 0.3095}, {'accuracy': 0.33599000000000007}, {'accuracy': 0.28537}, {'accuracy': 0.38281}, {'accuracy': 0.43185}, {'accuracy': 0.39632999999999996}, {'accuracy': 0.41403999999999996}, {'accuracy': 0.46510000000000007}, {'accuracy': 0.52627}, {'accuracy': 0.58287}, {'accuracy': 0.46130000000000004}, {'accuracy': 0.51563}, {'accuracy': 0.5439899999999999}, {'accuracy': 0.43515999999999994}, {'accuracy': 0.5411699999999999}, {'accuracy': 0.56121}, {'accuracy': 0.5546900000000001}, {'accuracy': 0.5933}, {'accuracy': 0.5025700000000001}, {'accuracy': 0.59353}, {'accuracy': 0.59811}, {'accuracy': 0.5285200000000001}, {'accuracy': 0.5758099999999999}, {'accuracy': 0.5981799999999999}, {'accuracy': 0.58967}, {'accuracy': 0.6469600000000001}, {'accuracy': 0.6246}, {'accuracy': 0.67138}, {'accuracy': 0.55654}, {'accuracy': 0.55349}, {'accuracy': 0.68404}, {'accuracy': 0.65269}, {'accuracy': 0.64965}, {'accuracy': 0.6055299999999999}, {'accuracy': 0.66414}, {'accuracy': 0.6159699999999999}, {'accuracy': 0.62913}, {'accuracy': 0.68704}, {'accuracy': 0.6829999999999999}, {'accuracy': 0.62549}, {'accuracy': 0.67154}, {'accuracy': 0.65118}, {'accuracy': 0.6353899999999999}, {'accuracy': 0.66343}, {'accuracy': 0.6533100000000001}, {'accuracy': 0.6777399999999999}, {'accuracy': 0.63307}, {'accuracy': 0.5991400000000001}, {'accuracy': 0.6723900000000002}, {'accuracy': 0.6887599999999999}, {'accuracy': 0.71705}, {'accuracy': 0.5883700000000001}, {'accuracy': 0.64469}, {'accuracy': 0.7024600000000001}, {'accuracy': 0.5909700000000001}, {'accuracy': 0.64165}, {'accuracy': 0.64648}, {'accuracy': 0.6112599999999999}, {'accuracy': 0.6942600000000001}, {'accuracy': 0.6431}, {'accuracy': 0.6397600000000001}, {'accuracy': 0.6961299999999999}, {'accuracy': 0.66906}, {'accuracy': 0.60086}, {'accuracy': 0.62103}, {'accuracy': 0.58653}, {'accuracy': 0.6113}, {'accuracy': 0.65405}, {'accuracy': 0.66667}, {'accuracy': 0.6803300000000001}, {'accuracy': 0.7000200000000001}, {'accuracy': 0.63364}, {'accuracy': 0.60478}, {'accuracy': 0.67391}, {'accuracy': 0.70088}, {'accuracy': 0.69339}, {'accuracy': 0.64648}, {'accuracy': 0.6358699999999999}, {'accuracy': 0.71842}, {'accuracy': 0.68334}, {'accuracy': 0.63321}, {'accuracy': 0.58223}, {'accuracy': 0.6446500000000001}, {'accuracy': 0.6030599999999999}, {'accuracy': 0.5905400000000001}, {'accuracy': 0.70606}, {'accuracy': 0.6996}, {'accuracy': 0.67547}, {'accuracy': 0.6676300000000001}, {'accuracy': 0.70579}, {'accuracy': 0.61087}, {'accuracy': 0.64761}, {'accuracy': 0.67816}, {'accuracy': 0.69332}, {'accuracy': 0.7421599999999999}, {'accuracy': 0.62633}, {'accuracy': 0.6077999999999999}, {'accuracy': 0.63249}, {'accuracy': 0.67515}, {'accuracy': 0.62673}, {'accuracy': 0.67303}, {'accuracy': 0.6394}, {'accuracy': 0.70078}, {'accuracy': 0.68327}, {'accuracy': 0.71386}, {'accuracy': 0.6235099999999999}, {'accuracy': 0.6277999999999999}, {'accuracy': 0.6102000000000001}, {'accuracy': 0.682}, {'accuracy': 0.74895}, {'accuracy': 0.6471600000000001}, {'accuracy': 0.66044}, {'accuracy': 0.7201200000000001}, {'accuracy': 0.6943699999999999}, {'accuracy': 0.6297}, {'accuracy': 0.69363}, {'accuracy': 0.6455599999999999}, {'accuracy': 0.75878}, {'accuracy': 0.6878099999999999}, {'accuracy': 0.6666000000000001}, {'accuracy': 0.6506900000000001}, {'accuracy': 0.64795}, {'accuracy': 0.71591}, {'accuracy': 0.66482}, {'accuracy': 0.67252}, {'accuracy': 0.66212}, {'accuracy': 0.66557}, {'accuracy': 0.6127499999999999}, {'accuracy': 0.66662}, {'accuracy': 0.73431}, {'accuracy': 0.65976}, {'accuracy': 0.6566400000000001}, {'accuracy': 0.7047100000000001}, {'accuracy': 0.64793}, {'accuracy': 0.73459}, {'accuracy': 0.66327}, {'accuracy': 0.67586}, {'accuracy': 0.68035}, {'accuracy': 0.67309}, {'accuracy': 0.68598}, {'accuracy': 0.5986500000000001}, {'accuracy': 0.71574}, {'accuracy': 0.7021499999999999}, {'accuracy': 0.67806}, {'accuracy': 0.68252}, {'accuracy': 0.6479000000000001}, {'accuracy': 0.7427900000000001}, {'accuracy': 0.69116}, {'accuracy': 0.84263}, {'accuracy': 0.84026}, {'accuracy': 0.8328899999999999}, {'accuracy': 0.85745}, {'accuracy': 0.83735}, {'accuracy': 0.8440700000000001}, {'accuracy': 0.8354000000000001}, {'accuracy': 0.81766}, {'accuracy': 0.82936}, {'accuracy': 0.8383900000000001}, {'accuracy': 0.8325400000000001}, {'accuracy': 0.82812}, {'accuracy': 0.83994}, {'accuracy': 0.8342700000000001}, {'accuracy': 0.83018}, {'accuracy': 0.84695}, {'accuracy': 0.82807}, {'accuracy': 0.84016}, {'accuracy': 0.8404299999999999}, {'accuracy': 0.8515099999999999}, {'accuracy': 0.8232799999999999}, {'accuracy': 0.8428800000000001}, {'accuracy': 0.8461399999999999}, {'accuracy': 0.8440700000000001}, {'accuracy': 0.85441}, {'accuracy': 0.8374499999999999}, {'accuracy': 0.8425499999999999}, {'accuracy': 0.82783}, {'accuracy': 0.8362700000000001}, {'accuracy': 0.8078099999999999}, {'accuracy': 0.8391499999999998}, {'accuracy': 0.8326400000000002}, {'accuracy': 0.8177}, {'accuracy': 0.8437300000000001}, {'accuracy': 0.84955}, {'accuracy': 0.8398200000000001}, {'accuracy': 0.86258}, {'accuracy': 0.83335}, {'accuracy': 0.83947}, {'accuracy': 0.82494}, {'accuracy': 0.82698}, {'accuracy': 0.8198699999999999}, {'accuracy': 0.82089}, {'accuracy': 0.84629}, {'accuracy': 0.8451000000000001}, {'accuracy': 0.8340400000000001}, {'accuracy': 0.8328300000000001}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\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=200)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "8b18419b-1195-4787-88c0-0c4f4c6390ca",
   "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.83</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.83\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACWwElEQVR4nO3dd5hTVfoH8O9NZpJM752BodehC4IgCCPYuyK6gihYseysu8qqsOoqdnFtqD+xroq66lpBRHClSZfey1Cm95pkkvv7Izk3N20mmZaZ4ft5nnlkkpvkpDj3zfu+5xxJlmUZRERERJ2EJtADICIiImpJDG6IiIioU2FwQ0RERJ0KgxsiIiLqVBjcEBERUafC4IaIiIg6FQY3RERE1KkwuCEiIqJOhcENERERdSoMboioVa1evRqSJGH16tXKZTfffDMyMjICNqbO5B//+AckSQr0MIjaFQY3RO3c7t278ac//QlpaWnQ6/VITU3FjTfeiN27dwd6aK3u9ddfx3vvvdeqj7Fnzx784x//wLFjx1r1cdrSU089ha+//jrQwyAKGAY3RO3Yl19+ieHDh2PlypWYNWsWXn/9ddx6661YtWoVhg8fjq+++irQQ2xVbRXcPPbYYwxuiDqRoEAPgIg8O3z4MG666Sb06NED//vf/5CQkKBcd99992H8+PG46aabsGPHDvTo0aPNxlVdXY2wsLA2e7yOgK8JUfvCzA1RO/Xcc8+hpqYGb731llNgAwDx8fF48803UV1djWeffRYA8MUXX0CSJPz6669u9/Xmm29CkiTs2rVLuWzfvn245pprEBsbC4PBgJEjR+Kbb75xut17772n3Oddd92FxMREdOnSBQBw/Phx3HXXXejbty9CQkIQFxeHa6+9tsUyIBkZGdi9ezd+/fVXSJIESZIwceJE5fqysjLcf//9SE9Ph16vR69evfDMM8/AarU63c+nn36KESNGICIiApGRkcjMzMTLL7+sPL9rr70WAHDeeecpj6PuD3J18803Izw8HIcPH8ZFF12EiIgI3HjjjQAAq9WKRYsWYeDAgTAYDEhKSsLtt9+O0tJSp/vYvHkzpk6divj4eISEhKB79+645ZZblOs99SkBwLFjxyBJUoPZLEmSUF1djffff195PjfffDMAoLKyEvfffz8yMjKg1+uRmJiI888/H1u3bvV6f0QdETM3RO3Ut99+i4yMDIwfP97j9eeeey4yMjLw/fffAwAuvvhihIeH47PPPsOECROcjl26dCkGDhyIQYMGAbD18ZxzzjlIS0vDQw89hLCwMHz22We44oor8J///AdXXnml0+3vuusuJCQkYP78+aiurgYAbNq0CevWrcP111+PLl264NixY3jjjTcwceJE7NmzB6Ghoc16/osWLcI999yD8PBwPPzwwwCApKQkAEBNTQ0mTJiAU6dO4fbbb0fXrl2xbt06zJs3D7m5uVi0aBEAYMWKFZg+fTomT56MZ555BgCwd+9erF27Fvfddx/OPfdc3HvvvfjXv/6Fv//97+jfvz8AKP/1pr6+HlOnTsW4cePw/PPPK8/19ttvx3vvvYdZs2bh3nvvxdGjR/Hqq69i27ZtWLt2LYKDg1FQUIApU6YgISEBDz30EKKjo3Hs2DF8+eWXzXq9hA8//BCzZ8/GqFGjcNtttwEAevbsCQC444478MUXX2Du3LkYMGAAiouLsWbNGuzduxfDhw9vkccnahdkImp3ysrKZADy5Zdf3uBxl112mQxArqiokGVZlqdPny4nJibK9fX1yjG5ubmyRqORH3/8ceWyyZMny5mZmXJdXZ1ymdVqlceOHSv37t1buezdd9+VAcjjxo1zuk9ZluWamhq38axfv14GIH/wwQfKZatWrZIByKtWrVIumzlzptytW7cGn5ssy/LAgQPlCRMmuF3+xBNPyGFhYfKBAwecLn/ooYdkrVYr5+TkyLIsy/fdd58cGRnpNna1zz//3G18DZk5c6YMQH7ooYecLv/tt99kAPK///1vp8uXLVvmdPlXX30lA5A3bdrk9TE8vWayLMtHjx6VAcjvvvuuctmCBQtk1z/lYWFh8syZM93uNyoqSr777rt9eJZEHRvLUkTtUGVlJQAgIiKiwePE9RUVFQCAadOmoaCgwKmc8cUXX8BqtWLatGkAgJKSEvzyyy+47rrrUFlZiaKiIhQVFaG4uBhTp07FwYMHcerUKafHmTNnDrRardNlISEhyr/NZjOKi4vRq1cvREdHt3qZ4/PPP8f48eMRExOjjL+oqAhZWVmwWCz43//+BwCIjo5GdXU1VqxY0eJjuPPOO93GFBUVhfPPP99pTCNGjEB4eDhWrVqljAkAvvvuO5jN5hYfV0Oio6Px+++/4/Tp0236uERtjcENUTskghYR5HjjGgRdcMEFiIqKwtKlS5Vjli5diqFDh6JPnz4AgEOHDkGWZTz66KNISEhw+lmwYAEAoKCgwOlxunfv7vbYtbW1mD9/vtLzEh8fj4SEBJSVlaG8vLyJz9w3Bw8exLJly9zGn5WV5TT+u+66C3369MGFF16ILl264JZbbsGyZcua/fhBQUFK75F6TOXl5UhMTHQbV1VVlTKmCRMm4Oqrr8Zjjz2G+Ph4XH755Xj33XdhNBqbPa7GPPvss9i1axfS09MxatQo/OMf/8CRI0da/XGJ2hp7bojaoaioKKSkpGDHjh0NHrdjxw6kpaUhMjISAKDX63HFFVfgq6++wuuvv478/HysXbsWTz31lHIb0XD7wAMPYOrUqR7vt1evXk6/q7M0wj333IN3330X999/P8aMGYOoqChIkoTrr7/eram3pVmtVpx//vn429/+5vF6EcglJiZi+/btWL58OX788Uf8+OOPePfddzFjxgy8//77TX58vV4Pjcb5u6HVakViYiL+/e9/e7yNaAqXJAlffPEFNmzYgG+//RbLly/HLbfcghdeeAEbNmxAeHi410X5LBZLk8cMANdddx3Gjx+Pr776Cj/99BOee+45PPPMM/jyyy9x4YUXNuu+idoTBjdE7dQll1yCt99+G2vWrMG4cePcrv/tt99w7Ngx3H777U6XT5s2De+//z5WrlyJvXv3QpZlpSQFQJk2HhwcrGQ6muKLL77AzJkz8cILLyiX1dXVoaysrMn36crbSb5nz56oqqryafw6nQ6XXnopLr30UlitVtx1111488038eijj6JXr14ttrpvz5498fPPP+Occ87xGAy6Ovvss3H22WfjySefxMcff4wbb7wRn376KWbPno2YmBgAcHstjx8/7tNYGnpOKSkpuOuuu3DXXXehoKAAw4cPx5NPPsnghjoVlqWI2qm//vWvCAkJwe23347i4mKn60pKSnDHHXcgNDQUf/3rX52uy8rKQmxsLJYuXYqlS5di1KhRTmWlxMRETJw4EW+++SZyc3PdHrewsNCn8Wm1Wsiy7HTZK6+80uzsglpYWJjHYOm6667D+vXrsXz5crfrysrKUF9fDwBur5tGo8HgwYMBQCkDifVpmhuUXXfddbBYLHjiiSfcrquvr1fuv7S01O11Gzp0qNOYunXrBq1Wq/QOCa+//rpPY/H0ulks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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.11912}, {'accuracy': 0.1449}, {'accuracy': 0.14678000000000002}, {'accuracy': 0.18405}, {'accuracy': 0.2665}, {'accuracy': 0.3095}, {'accuracy': 0.33599000000000007}, {'accuracy': 0.28537}, {'accuracy': 0.38281}, {'accuracy': 0.43185}, {'accuracy': 0.39632999999999996}, {'accuracy': 0.41403999999999996}, {'accuracy': 0.46510000000000007}, {'accuracy': 0.52627}, {'accuracy': 0.58287}, {'accuracy': 0.46130000000000004}, {'accuracy': 0.51563}, {'accuracy': 0.5439899999999999}, {'accuracy': 0.43515999999999994}, {'accuracy': 0.5411699999999999}, {'accuracy': 0.56121}, {'accuracy': 0.5546900000000001}, {'accuracy': 0.5933}, {'accuracy': 0.5025700000000001}, {'accuracy': 0.59353}, {'accuracy': 0.59811}, {'accuracy': 0.5285200000000001}, {'accuracy': 0.5758099999999999}, {'accuracy': 0.5981799999999999}, {'accuracy': 0.58967}, {'accuracy': 0.6469600000000001}, {'accuracy': 0.6246}, {'accuracy': 0.67138}, {'accuracy': 0.55654}, {'accuracy': 0.55349}, {'accuracy': 0.68404}, {'accuracy': 0.65269}, {'accuracy': 0.64965}, {'accuracy': 0.6055299999999999}, {'accuracy': 0.66414}, {'accuracy': 0.6159699999999999}, {'accuracy': 0.62913}, {'accuracy': 0.68704}, {'accuracy': 0.6829999999999999}, {'accuracy': 0.62549}, {'accuracy': 0.67154}, {'accuracy': 0.65118}, {'accuracy': 0.6353899999999999}, {'accuracy': 0.66343}, {'accuracy': 0.6533100000000001}, {'accuracy': 0.6777399999999999}, {'accuracy': 0.63307}, {'accuracy': 0.5991400000000001}, {'accuracy': 0.6723900000000002}, {'accuracy': 0.6887599999999999}, {'accuracy': 0.71705}, {'accuracy': 0.5883700000000001}, {'accuracy': 0.64469}, {'accuracy': 0.7024600000000001}, {'accuracy': 0.5909700000000001}, {'accuracy': 0.64165}, {'accuracy': 0.64648}, {'accuracy': 0.6112599999999999}, {'accuracy': 0.6942600000000001}, {'accuracy': 0.6431}, {'accuracy': 0.6397600000000001}, {'accuracy': 0.6961299999999999}, {'accuracy': 0.66906}, {'accuracy': 0.60086}, {'accuracy': 0.62103}, {'accuracy': 0.58653}, {'accuracy': 0.6113}, {'accuracy': 0.65405}, {'accuracy': 0.66667}, {'accuracy': 0.6803300000000001}, {'accuracy': 0.7000200000000001}, {'accuracy': 0.63364}, {'accuracy': 0.60478}, {'accuracy': 0.67391}, {'accuracy': 0.70088}, {'accuracy': 0.69339}, {'accuracy': 0.64648}, {'accuracy': 0.6358699999999999}, {'accuracy': 0.71842}, {'accuracy': 0.68334}, {'accuracy': 0.63321}, {'accuracy': 0.58223}, {'accuracy': 0.6446500000000001}, {'accuracy': 0.6030599999999999}, {'accuracy': 0.5905400000000001}, {'accuracy': 0.70606}, {'accuracy': 0.6996}, {'accuracy': 0.67547}, {'accuracy': 0.6676300000000001}, {'accuracy': 0.70579}, {'accuracy': 0.61087}, {'accuracy': 0.64761}, {'accuracy': 0.67816}, {'accuracy': 0.69332}, {'accuracy': 0.7421599999999999}, {'accuracy': 0.62633}, {'accuracy': 0.6077999999999999}, {'accuracy': 0.63249}, {'accuracy': 0.67515}, {'accuracy': 0.62673}, {'accuracy': 0.67303}, {'accuracy': 0.6394}, {'accuracy': 0.70078}, {'accuracy': 0.68327}, {'accuracy': 0.71386}, {'accuracy': 0.6235099999999999}, {'accuracy': 0.6277999999999999}, {'accuracy': 0.6102000000000001}, {'accuracy': 0.682}, {'accuracy': 0.74895}, {'accuracy': 0.6471600000000001}, {'accuracy': 0.66044}, {'accuracy': 0.7201200000000001}, {'accuracy': 0.6943699999999999}, {'accuracy': 0.6297}, {'accuracy': 0.69363}, {'accuracy': 0.6455599999999999}, {'accuracy': 0.75878}, {'accuracy': 0.6878099999999999}, {'accuracy': 0.6666000000000001}, {'accuracy': 0.6506900000000001}, {'accuracy': 0.64795}, {'accuracy': 0.71591}, {'accuracy': 0.66482}, {'accuracy': 0.67252}, {'accuracy': 0.66212}, {'accuracy': 0.66557}, {'accuracy': 0.6127499999999999}, {'accuracy': 0.66662}, {'accuracy': 0.73431}, {'accuracy': 0.65976}, {'accuracy': 0.6566400000000001}, {'accuracy': 0.7047100000000001}, {'accuracy': 0.64793}, {'accuracy': 0.73459}, {'accuracy': 0.66327}, {'accuracy': 0.67586}, {'accuracy': 0.68035}, {'accuracy': 0.67309}, {'accuracy': 0.68598}, {'accuracy': 0.5986500000000001}, {'accuracy': 0.71574}, {'accuracy': 0.7021499999999999}, {'accuracy': 0.67806}, {'accuracy': 0.68252}, {'accuracy': 0.6479000000000001}, {'accuracy': 0.7427900000000001}, {'accuracy': 0.69116}, {'accuracy': 0.84263}, {'accuracy': 0.84026}, {'accuracy': 0.8328899999999999}, {'accuracy': 0.85745}, {'accuracy': 0.83735}, {'accuracy': 0.8440700000000001}, {'accuracy': 0.8354000000000001}, {'accuracy': 0.81766}, {'accuracy': 0.82936}, {'accuracy': 0.8383900000000001}, {'accuracy': 0.8325400000000001}, {'accuracy': 0.82812}, {'accuracy': 0.83994}, {'accuracy': 0.8342700000000001}, {'accuracy': 0.83018}, {'accuracy': 0.84695}, {'accuracy': 0.82807}, {'accuracy': 0.84016}, {'accuracy': 0.8404299999999999}, {'accuracy': 0.8515099999999999}, {'accuracy': 0.8232799999999999}, {'accuracy': 0.8428800000000001}, {'accuracy': 0.8461399999999999}, {'accuracy': 0.8440700000000001}, {'accuracy': 0.85441}, {'accuracy': 0.8374499999999999}, {'accuracy': 0.8425499999999999}, {'accuracy': 0.82783}, {'accuracy': 0.8362700000000001}, {'accuracy': 0.8078099999999999}, {'accuracy': 0.8391499999999998}, {'accuracy': 0.8326400000000002}, {'accuracy': 0.8177}, {'accuracy': 0.8437300000000001}, {'accuracy': 0.84955}, {'accuracy': 0.8398200000000001}, {'accuracy': 0.86258}, {'accuracy': 0.83335}, {'accuracy': 0.83947}, {'accuracy': 0.82494}, {'accuracy': 0.82698}, {'accuracy': 0.8198699999999999}, {'accuracy': 0.82089}, {'accuracy': 0.84629}, {'accuracy': 0.8451000000000001}, {'accuracy': 0.8340400000000001}, {'accuracy': 0.8328300000000001}]\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": "214646e5-ff75-4944-b645-b599f630800b",
   "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
}
