{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class 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 2398]\n",
      " [   1   77]\n",
      " [   2   43]\n",
      " [   3   69]\n",
      " [   4  102]\n",
      " [   5  168]\n",
      " [   6  289]\n",
      " [   7  530]\n",
      " [   8  797]\n",
      " [   9 1464]]\n",
      "[[   0 1363]\n",
      " [   1 2722]\n",
      " [   2   68]\n",
      " [   3   43]\n",
      " [   4   67]\n",
      " [   5  111]\n",
      " [   6  167]\n",
      " [   7  327]\n",
      " [   8  517]\n",
      " [   9  828]]\n",
      "[[   0  856]\n",
      " [   1 1614]\n",
      " [   2 2299]\n",
      " [   3   67]\n",
      " [   4   39]\n",
      " [   5   54]\n",
      " [   6  109]\n",
      " [   7  201]\n",
      " [   8  289]\n",
      " [   9  496]]\n",
      "[[   0  537]\n",
      " [   1  952]\n",
      " [   2 1469]\n",
      " [   3 2468]\n",
      " [   4   62]\n",
      " [   5   53]\n",
      " [   6   73]\n",
      " [   7  107]\n",
      " [   8  176]\n",
      " [   9  325]]\n",
      "[[   0  304]\n",
      " [   1  566]\n",
      " [   2  861]\n",
      " [   3 1455]\n",
      " [   4 2341]\n",
      " [   5   62]\n",
      " [   6   43]\n",
      " [   7   65]\n",
      " [   8  109]\n",
      " [   9  180]]\n",
      "[[   0  201]\n",
      " [   1  333]\n",
      " [   2  493]\n",
      " [   3  861]\n",
      " [   4 1392]\n",
      " [   5 2174]\n",
      " [   6   56]\n",
      " [   7   49]\n",
      " [   8   64]\n",
      " [   9   97]]\n",
      "[[   0  106]\n",
      " [   1  222]\n",
      " [   2  316]\n",
      " [   3  511]\n",
      " [   4  845]\n",
      " [   5 1272]\n",
      " [   6 2389]\n",
      " [   7   45]\n",
      " [   8   44]\n",
      " [   9   57]]\n",
      "[[   0   74]\n",
      " [   1  130]\n",
      " [   2  206]\n",
      " [   3  326]\n",
      " [   4  516]\n",
      " [   5  792]\n",
      " [   6 1446]\n",
      " [   7 2535]\n",
      " [   8   47]\n",
      " [   9   36]]\n",
      "[[   0   30]\n",
      " [   1   70]\n",
      " [   2  133]\n",
      " [   3  215]\n",
      " [   4  306]\n",
      " [   5  469]\n",
      " [   6  855]\n",
      " [   7 1542]\n",
      " [   8 2347]\n",
      " [   9   65]]\n",
      "[[   0   54]\n",
      " [   1   56]\n",
      " [   2   70]\n",
      " [   3  116]\n",
      " [   4  172]\n",
      " [   5  266]\n",
      " [   6  491]\n",
      " [   7  864]\n",
      " [   8 1461]\n",
      " [   9 2401]]\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": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "18180\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1721]\n",
      " [   1   51]\n",
      " [   2   36]\n",
      " [   3   48]\n",
      " [   4   75]\n",
      " [   5  121]\n",
      " [   6  204]\n",
      " [   7  377]\n",
      " [   8  541]\n",
      " [   9 1008]]\n",
      "[[   0 2548]\n",
      " [   1   69]\n",
      " [   2   53]\n",
      " [   3   77]\n",
      " [   4  105]\n",
      " [   5  159]\n",
      " [   6  300]\n",
      " [   7  527]\n",
      " [   8  817]\n",
      " [   9 1444]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "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-20:54:03 </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-20:54:03\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": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4d74078fb31947a4a8bd94098616bc73",
       "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\"></pre>\n"
      ],
      "text/plain": []
     },
     "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"
      ]
     },
     "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-23:36:16 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3454</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:36:16\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3454\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\">75435360</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;36m75435360\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": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=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=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.86</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.86\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10622000000000001}, {'accuracy': 0.12226}, {'accuracy': 0.17265999999999998}, {'accuracy': 0.17746}, {'accuracy': 0.17818}, {'accuracy': 0.16172000000000003}, {'accuracy': 0.28137}, {'accuracy': 0.28076}, {'accuracy': 0.24946000000000002}, {'accuracy': 0.32500999999999997}, {'accuracy': 0.31677}, {'accuracy': 0.33641}, {'accuracy': 0.39353000000000005}, {'accuracy': 0.35279}, {'accuracy': 0.44345}, {'accuracy': 0.41339999999999993}, {'accuracy': 0.44762}, {'accuracy': 0.49928}, {'accuracy': 0.41943}, {'accuracy': 0.42797}, {'accuracy': 0.47707999999999995}, {'accuracy': 0.56774}, {'accuracy': 0.44787}, {'accuracy': 0.57362}, {'accuracy': 0.51292}, {'accuracy': 0.53736}, {'accuracy': 0.50098}, {'accuracy': 0.5168}, {'accuracy': 0.5782900000000001}, {'accuracy': 0.56882}, {'accuracy': 0.5297099999999999}, {'accuracy': 0.5629500000000001}, {'accuracy': 0.59848}, {'accuracy': 0.629}, {'accuracy': 0.5565100000000001}, {'accuracy': 0.53103}, {'accuracy': 0.50446}, {'accuracy': 0.56337}, {'accuracy': 0.5729900000000001}, {'accuracy': 0.5471}, {'accuracy': 0.5724}, {'accuracy': 0.5859699999999999}, {'accuracy': 0.55577}, {'accuracy': 0.6370600000000001}, {'accuracy': 0.56273}, {'accuracy': 0.57318}, {'accuracy': 0.60824}, {'accuracy': 0.5685600000000001}, {'accuracy': 0.57101}, {'accuracy': 0.5941000000000001}, {'accuracy': 0.63414}, {'accuracy': 0.57923}, {'accuracy': 0.5631999999999999}, {'accuracy': 0.5415300000000001}, {'accuracy': 0.5726100000000001}, {'accuracy': 0.62736}, {'accuracy': 0.5484600000000001}, {'accuracy': 0.6284700000000001}, {'accuracy': 0.5406600000000001}, {'accuracy': 0.6522300000000001}, {'accuracy': 0.5892700000000001}, {'accuracy': 0.6131499999999999}, {'accuracy': 0.5563400000000001}, {'accuracy': 0.6187400000000001}, {'accuracy': 0.58166}, {'accuracy': 0.49207}, {'accuracy': 0.6569400000000001}, {'accuracy': 0.6531100000000001}, {'accuracy': 0.6162099999999999}, {'accuracy': 0.61113}, {'accuracy': 0.61986}, {'accuracy': 0.5371900000000001}, {'accuracy': 0.61981}, {'accuracy': 0.61216}, {'accuracy': 0.53672}, {'accuracy': 0.60887}, {'accuracy': 0.5451399999999998}, {'accuracy': 0.58628}, {'accuracy': 0.62578}, {'accuracy': 0.6033000000000001}, {'accuracy': 0.5635700000000001}, {'accuracy': 0.6319700000000001}, {'accuracy': 0.64056}, {'accuracy': 0.61186}, {'accuracy': 0.6241999999999999}, {'accuracy': 0.6569}, {'accuracy': 0.6519400000000001}, {'accuracy': 0.67506}, {'accuracy': 0.5957600000000001}, {'accuracy': 0.55613}, {'accuracy': 0.5576099999999999}, {'accuracy': 0.59645}, {'accuracy': 0.5896699999999999}, {'accuracy': 0.57307}, {'accuracy': 0.5914299999999999}, {'accuracy': 0.5415199999999999}, {'accuracy': 0.61011}, {'accuracy': 0.6450100000000001}, {'accuracy': 0.6764899999999999}, {'accuracy': 0.6597700000000001}, {'accuracy': 0.67998}, {'accuracy': 0.67542}, {'accuracy': 0.66602}, {'accuracy': 0.61185}, {'accuracy': 0.57042}, {'accuracy': 0.5723999999999999}, {'accuracy': 0.61724}, {'accuracy': 0.69775}, {'accuracy': 0.5763}, {'accuracy': 0.6733999999999999}, {'accuracy': 0.6404}, {'accuracy': 0.64678}, {'accuracy': 0.65757}, {'accuracy': 0.6651199999999999}, {'accuracy': 0.65951}, {'accuracy': 0.56235}, {'accuracy': 0.65393}, {'accuracy': 0.5725199999999999}, {'accuracy': 0.58979}, {'accuracy': 0.6557700000000001}, {'accuracy': 0.5945400000000001}, {'accuracy': 0.7003199999999999}, {'accuracy': 0.6174999999999999}, {'accuracy': 0.6187900000000001}, {'accuracy': 0.57578}, {'accuracy': 0.6245399999999999}, {'accuracy': 0.59167}, {'accuracy': 0.6419400000000002}, {'accuracy': 0.5964700000000001}, {'accuracy': 0.57957}, {'accuracy': 0.5693599999999999}, {'accuracy': 0.62918}, {'accuracy': 0.5919000000000001}, {'accuracy': 0.6633600000000001}, {'accuracy': 0.64995}, {'accuracy': 0.64171}, {'accuracy': 0.6729599999999999}, {'accuracy': 0.6049399999999999}, {'accuracy': 0.57153}, {'accuracy': 0.61303}, {'accuracy': 0.6913099999999999}, {'accuracy': 0.61211}, {'accuracy': 0.6332899999999999}, {'accuracy': 0.608}, {'accuracy': 0.59764}, {'accuracy': 0.6752500000000001}, {'accuracy': 0.57595}, {'accuracy': 0.59471}, {'accuracy': 0.57339}, {'accuracy': 0.6365399999999999}, {'accuracy': 0.69758}, {'accuracy': 0.83271}, {'accuracy': 0.7858700000000001}, {'accuracy': 0.74612}, {'accuracy': 0.8202100000000001}, {'accuracy': 0.77268}, {'accuracy': 0.79558}, {'accuracy': 0.81631}, {'accuracy': 0.79829}, {'accuracy': 0.7932500000000001}, {'accuracy': 0.83606}, {'accuracy': 0.85816}, {'accuracy': 0.79921}, {'accuracy': 0.83735}, {'accuracy': 0.8579000000000001}, {'accuracy': 0.8555900000000001}, {'accuracy': 0.8341100000000001}, {'accuracy': 0.82423}, {'accuracy': 0.8110099999999999}, {'accuracy': 0.8503200000000002}, {'accuracy': 0.8288800000000002}, {'accuracy': 0.8293700000000002}, {'accuracy': 0.8397600000000001}, {'accuracy': 0.8003899999999999}, {'accuracy': 0.8263}, {'accuracy': 0.8203699999999999}, {'accuracy': 0.8091899999999999}, {'accuracy': 0.8326500000000001}, {'accuracy': 0.8236000000000001}, {'accuracy': 0.81814}, {'accuracy': 0.83116}, {'accuracy': 0.83956}, {'accuracy': 0.8125399999999999}, {'accuracy': 0.7998200000000001}, {'accuracy': 0.82889}, {'accuracy': 0.8122399999999999}, {'accuracy': 0.78091}, {'accuracy': 0.7661}, {'accuracy': 0.7881699999999999}, {'accuracy': 0.8433800000000001}, {'accuracy': 0.81165}, {'accuracy': 0.83124}, {'accuracy': 0.8105300000000002}, {'accuracy': 0.8169700000000001}, {'accuracy': 0.8033999999999999}, {'accuracy': 0.8491800000000002}, {'accuracy': 0.8054399999999999}, {'accuracy': 0.80388}, {'accuracy': 0.8325000000000001}, {'accuracy': 0.84296}, {'accuracy': 0.84518}, {'accuracy': 0.8115}, {'accuracy': 0.8126200000000001}, {'accuracy': 0.84383}, {'accuracy': 0.76946}, {'accuracy': 0.7815399999999999}, {'accuracy': 0.7376499999999999}, {'accuracy': 0.8088099999999999}, {'accuracy': 0.78117}, {'accuracy': 0.84826}, {'accuracy': 0.7726500000000001}, {'accuracy': 0.80955}, {'accuracy': 0.8363999999999999}, {'accuracy': 0.8131999999999999}, {'accuracy': 0.84429}, {'accuracy': 0.8379099999999999}, {'accuracy': 0.77159}, {'accuracy': 0.8354900000000001}, {'accuracy': 0.7760400000000001}, {'accuracy': 0.8003499999999999}, {'accuracy': 0.77599}, {'accuracy': 0.8388899999999999}, {'accuracy': 0.8204499999999999}, {'accuracy': 0.8407199999999999}, {'accuracy': 0.8130000000000001}, {'accuracy': 0.84047}, {'accuracy': 0.7881100000000001}, {'accuracy': 0.8218799999999999}, {'accuracy': 0.8417100000000002}, {'accuracy': 0.83661}, {'accuracy': 0.78888}, {'accuracy': 0.82317}, {'accuracy': 0.84146}, {'accuracy': 0.8496599999999999}, {'accuracy': 0.7376700000000002}, {'accuracy': 0.8494300000000001}, {'accuracy': 0.85498}, {'accuracy': 0.79066}, {'accuracy': 0.8077400000000001}, {'accuracy': 0.8142800000000001}, {'accuracy': 0.7856500000000001}, {'accuracy': 0.83184}, {'accuracy': 0.78138}, {'accuracy': 0.7865599999999999}, {'accuracy': 0.8047699999999999}, {'accuracy': 0.85358}, {'accuracy': 0.8470000000000001}, {'accuracy': 0.81645}, {'accuracy': 0.8508800000000001}, {'accuracy': 0.8516}, {'accuracy': 0.80282}, {'accuracy': 0.8189}, {'accuracy': 0.7536799999999999}, {'accuracy': 0.7670100000000001}, {'accuracy': 0.7305200000000001}, {'accuracy': 0.8505499999999999}, {'accuracy': 0.81889}, {'accuracy': 0.85183}, {'accuracy': 0.8606199999999999}, {'accuracy': 0.75372}, {'accuracy': 0.81516}, {'accuracy': 0.7520499999999999}, {'accuracy': 0.8158099999999999}, {'accuracy': 0.8236500000000001}, {'accuracy': 0.83965}, {'accuracy': 0.8134600000000001}, {'accuracy': 0.7821300000000001}, {'accuracy': 0.74452}, {'accuracy': 0.76586}, {'accuracy': 0.80456}, {'accuracy': 0.7873500000000001}, {'accuracy': 0.79882}, {'accuracy': 0.83605}, {'accuracy': 0.76905}, {'accuracy': 0.8613999999999999}, {'accuracy': 0.76482}, {'accuracy': 0.81674}, {'accuracy': 0.8286300000000001}, {'accuracy': 0.8177899999999999}, {'accuracy': 0.77406}, {'accuracy': 0.80515}, {'accuracy': 0.77102}, {'accuracy': 0.73071}, {'accuracy': 0.8285899999999999}, {'accuracy': 0.8433399999999999}, {'accuracy': 0.8357800000000001}, {'accuracy': 0.7808}, {'accuracy': 0.85483}, {'accuracy': 0.85875}, {'accuracy': 0.78073}, {'accuracy': 0.8336100000000002}, {'accuracy': 0.83948}, {'accuracy': 0.86635}, {'accuracy': 0.76915}, {'accuracy': 0.76766}, {'accuracy': 0.77675}, {'accuracy': 0.81744}, {'accuracy': 0.8374099999999999}, {'accuracy': 0.8129}, {'accuracy': 0.8573000000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "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": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1e2c586-04af-4b7e-a788-fe249ae77fe1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "829f3ef5-e8f8-4d2a-a54b-0b1f38a62c1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0d604b0-97aa-4a7b-b31c-cb79600f8982",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1732389-df64-4fc5-aa5f-6b3cada25002",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6923b354-6551-42f2-bcf8-f4183bffe935",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f3f5dfa-6ca1-41c8-8c8c-5748f3ec1d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "038c7ffd-dd96-4110-aaf9-77cca80d8b5a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "386b3c4a-2c64-44ca-ae85-9e055e405fa6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a683c72-2b32-48b6-8ec0-ea8c31eda893",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e28737f-18ab-4d28-8777-b88c6236038c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7add2597-1c2f-4be6-a4c0-d7a3911b950d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6351726d-f7d9-486d-947e-63c5ddcadd85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1821952-894a-4f0b-b2d5-fcedee22a88e",
   "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
}
