{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2354]\n",
      " [   1   61]\n",
      " [   2   34]\n",
      " [   3   77]\n",
      " [   4  112]\n",
      " [   5  187]\n",
      " [   6  308]\n",
      " [   7  501]\n",
      " [   8  855]\n",
      " [   9 1465]]\n",
      "[[   0 1462]\n",
      " [   1 2368]\n",
      " [   2   65]\n",
      " [   3   31]\n",
      " [   4   57]\n",
      " [   5  110]\n",
      " [   6  187]\n",
      " [   7  317]\n",
      " [   8  526]\n",
      " [   9  888]]\n",
      "[[   0  885]\n",
      " [   1 1434]\n",
      " [   2 2452]\n",
      " [   3   60]\n",
      " [   4   35]\n",
      " [   5   62]\n",
      " [   6  110]\n",
      " [   7  178]\n",
      " [   8  311]\n",
      " [   9  547]]\n",
      "[[   0  512]\n",
      " [   1  869]\n",
      " [   2 1393]\n",
      " [   3 2362]\n",
      " [   4   65]\n",
      " [   5   60]\n",
      " [   6   66]\n",
      " [   7  101]\n",
      " [   8  219]\n",
      " [   9  318]]\n",
      "[[   0  322]\n",
      " [   1  525]\n",
      " [   2  869]\n",
      " [   3 1466]\n",
      " [   4 2452]\n",
      " [   5   64]\n",
      " [   6   36]\n",
      " [   7   72]\n",
      " [   8  108]\n",
      " [   9  182]]\n",
      "[[   0  193]\n",
      " [   1  344]\n",
      " [   2  504]\n",
      " [   3  849]\n",
      " [   4 1419]\n",
      " [   5 2335]\n",
      " [   6   52]\n",
      " [   7   33]\n",
      " [   8   65]\n",
      " [   9   89]]\n",
      "[[   0   99]\n",
      " [   1  173]\n",
      " [   2  303]\n",
      " [   3  517]\n",
      " [   4  837]\n",
      " [   5 1465]\n",
      " [   6 2435]\n",
      " [   7   64]\n",
      " [   8   37]\n",
      " [   9   75]]\n",
      "[[   0   80]\n",
      " [   1  111]\n",
      " [   2  195]\n",
      " [   3  322]\n",
      " [   4  520]\n",
      " [   5  887]\n",
      " [   6 1402]\n",
      " [   7 2387]\n",
      " [   8   72]\n",
      " [   9   30]]\n",
      "[[   0   31]\n",
      " [   1   70]\n",
      " [   2  116]\n",
      " [   3  201]\n",
      " [   4  300]\n",
      " [   5  513]\n",
      " [   6  904]\n",
      " [   7 1494]\n",
      " [   8 2378]\n",
      " [   9   57]]\n",
      "[[   0   62]\n",
      " [   1   45]\n",
      " [   2   69]\n",
      " [   3  115]\n",
      " [   4  203]\n",
      " [   5  317]\n",
      " [   6  500]\n",
      " [   7  853]\n",
      " [   8 1429]\n",
      " [   9 2349]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\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": [
      "5978\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2186]\n",
      " [   1   53]\n",
      " [   2   28]\n",
      " [   3   69]\n",
      " [   4  101]\n",
      " [   5  171]\n",
      " [   6  272]\n",
      " [   7  457]\n",
      " [   8  762]\n",
      " [   9 1304]]\n",
      "[[   0 2413]\n",
      " [   1   60]\n",
      " [   2   31]\n",
      " [   3   77]\n",
      " [   4  113]\n",
      " [   5  185]\n",
      " [   6  303]\n",
      " [   7  497]\n",
      " [   8  863]\n",
      " [   9 1450]]\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<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(((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",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.81</span>                                                                <a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py#181\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">181</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.81\u001b[0m                                                                \u001b]8;id=333904;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py\u001b\\\u001b[2mutils.py\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=30220;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py#181\u001b\\\u001b[2m181\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB+oUlEQVR4nO3dd3hTZfsH8G9Gk3Tv3ULLXqWFIliRIVRwb0UcIAoOxIULXhVe9VXc4qsIyk9AfVVQ3IthoSh7lj1LS1u6Z9q0SZrk/P5IzmnSAS20TZt+P9fVi+aM5Mlp2nNzP/fzPDJBEAQQERERuQi5sxtARERE1JoY3BAREZFLYXBDRERELoXBDREREbkUBjdERETkUhjcEBERkUthcENEREQuhcENERERuRQGN0RERORSGNwQUZtKTU2FTCZDamqqtO2+++5DTEyM09rkSv79739DJpM5uxlEHQqDG6IO7vDhw7jnnnsQGRkJtVqNiIgI3H333Th8+LCzm9bmPv74Y6xYsaJNX+PIkSP497//jczMzDZ9nfb0+uuv46effnJ2M4ichsENUQf2ww8/YOjQoUhJScG0adPw8ccf44EHHsDGjRsxdOhQ/Pjjj85uYptqr+Dm5ZdfZnBD5EKUzm4AETUuPT0d9957L3r06IG///4bwcHB0r4nnngCo0aNwr333osDBw6gR48e7dYunU4HT0/Pdnu9zoDXhKhjYeaGqIN6++23UV1djU8//dQhsAGAoKAgfPLJJ9DpdHjrrbcAAKtXr4ZMJsOmTZsaPNcnn3wCmUyGQ4cOSduOHTuG2267DQEBAdBoNBg2bBh++eUXh/NWrFghPefMmTMREhKCqKgoAMCZM2cwc+ZM9O3bF+7u7ggMDMTtt9/eahmQmJgYHD58GJs2bYJMJoNMJsPYsWOl/eXl5XjyyScRHR0NtVqNXr164c0334TFYnF4npUrVyIxMRHe3t7w8fFBXFwcPvjgA+n93X777QCAK664Qnod+/qg+u677z54eXkhPT0d11xzDby9vXH33XcDACwWCxYuXIiBAwdCo9EgNDQUDz30EMrKyhyeY/fu3Zg4cSKCgoLg7u6O2NhY3H///dL+xuqUACAzMxMymeyc2SyZTAadTofPP/9cej/33XcfAKCyshJPPvkkYmJioFarERISgiuvvBJ79+5t8vmIOiNmbog6qF9//RUxMTEYNWpUo/tHjx6NmJgY/P777wCAa6+9Fl5eXvj2228xZswYh2NXrVqFgQMHYtCgQQCsdTwjR45EZGQk5syZA09PT3z77be46aab8P333+Pmm292OH/mzJkIDg7GvHnzoNPpAAC7du3C1q1bceeddyIqKgqZmZlYvHgxxo4diyNHjsDDw+Oi3v/ChQvx2GOPwcvLCy+88AIAIDQ0FABQXV2NMWPG4OzZs3jooYfQrVs3bN26FXPnzkVeXh4WLlwIAFi/fj0mT56M8ePH48033wQAHD16FFu2bMETTzyB0aNH4/HHH8d///tf/Otf/0L//v0BQPq3KSaTCRMnTsTll1+Od955R3qvDz30EFasWIFp06bh8ccfR0ZGBj766CPs27cPW7ZsgZubGwoLCzFhwgQEBwdjzpw58PPzQ2ZmJn744YeLul6iL7/8EtOnT8fw4cPx4IMPAgB69uwJAHj44YexevVqzJo1CwMGDEBJSQk2b96Mo0ePYujQoa3y+kQdgkBEHU55ebkAQLjxxhvPedwNN9wgABC0Wq0gCIIwefJkISQkRDCZTNIxeXl5glwuF1555RVp2/jx44W4uDhBr9dL2ywWi3DZZZcJvXv3lrYtX75cACBcfvnlDs8pCIJQXV3doD3btm0TAAhffPGFtG3jxo0CAGHjxo3StqlTpwrdu3c/53sTBEEYOHCgMGbMmAbbX331VcHT01M4ceKEw/Y5c+YICoVCyMrKEgRBEJ544gnBx8enQdvtfffddw3ady5Tp04VAAhz5sxx2P7PP/8IAISvvvrKYfuaNWsctv/4448CAGHXrl1NvkZj10wQBCEjI0MAICxfvlzaNn/+fKH+n3JPT09h6tSpDZ7X19dXePTRR5vxLok6N3ZLEXVAlZWVAABvb+9zHifu12q1AIBJkyahsLDQoTtj9erVsFgsmDRpEgCgtLQUGzZswB133IHKykoUFxejuLgYJSUlmDhxIk6ePImzZ886vM6MGTOgUCgctrm7u0vf19bWoqSkBL169YKfn1+bd3N89913GDVqFPz9/aX2FxcXIzk5GWazGX///TcAwM/PDzqdDuvXr2/1NjzyyCMN2uTr64srr7zSoU2JiYnw8vLCxo0bpTYBwG+//Yba2tpWb9e5+Pn5YceOHcjNzW3X1yVqbwxuiDogMWgRg5ym1A+CrrrqKvj6+mLVqlXSMatWrUJCQgL69OkDADh16hQEQcBLL72E4OBgh6/58+cDAAoLCx1eJzY2tsFr19TUYN68eVLNS1BQEIKDg1FeXo6KiooLfOfNc/LkSaxZs6ZB+5OTkx3aP3PmTPTp0wdXX301oqKicP/992PNmjUX/fpKpVKqPbJvU0VFBUJCQhq0q6qqSmrTmDFjcOutt+Lll19GUFAQbrzxRixfvhwGg+Gi23U+b731Fg4dOoTo6GgMHz4c//73v3H69Ok2f12i9saaG6IOyNfXF+Hh4Thw4MA5jztw4AAiIyPh4+MDAFCr1bjpppvw448/4uOPP0ZBQQG2bNmC119/XTpHLLh95plnMHHixEaft1evXg6P7bM0osceewzLly/Hk08+iaSkJPj6+kImk+HOO+9sUNTb2iwWC6688ko899xzje4XA7mQkBCkpaVh7dq1+PPPP/Hnn39i+fLlmDJlCj7//PMLfn21Wg253PH/hhaLBSEhIfjqq68aPUcsCpfJZFi9ejW2b9+OX3/9FWvXrsX999+Pd999F9u3b4eXl1eTk/KZzeYLbjMA3HHHHRg1ahR+/PFHrFu3Dm+//TbefPNN/PDDD7j66qsv6rmJOhIGN0Qd1HXXXYelS5di8+bNuPzyyxvs/+eff5CZmYmHHnrIYfukSZPw+eefIyUlBUePHoUgCFKXFABp2Libm5uU6bgQq1evxtSpU/Huu+9K2/R6PcrLyy/4Oetr6ibfs2dPVFVVNav9KpUK119/Pa6//npYLBbMnDkTn3zyCV566SX06tWr1Wb37dmzJ/766y+MHDmy0WCwvksvvRSXXnopXnvtNXz99de4++67sXLlSkyfPh3+/v4A0OBanjlzplltOdd7Cg8Px8yZMzFz5kwUFhZi6NCheO211xjckEthtxRRB/Xss8/C3d0dDz30EEpKShz2lZaW4uGHH4aHhweeffZZh33JyckICAjAqlWrsGrVKgwfPtyhWykkJARjx47FJ598gry8vAavW1RU1Kz2KRQKCILgsO3DDz+86OyCPU9Pz0aDpTvuuAPbtm3D2rVrG+wrLy+HyWQCgAbXTS6XY/DgwQAgdQOJ89NcbFB2xx13wGw249VXX22wz2QySc9fVlbW4LolJCQ4tKl79+5QKBRS7ZDo448/blZbGrtuZrO5QXdhSEgIIiIi2qVLjKg9MXND1EH17t0bn3/+Oe6++27ExcXhgQceQGxsLDIzM/HZZ5+huLgY33zzjTTMV+Tm5oZbbrkFK1euhE6nwzvvvNPguRctWoTLL78ccXFxmDFjBnr06IGCggJs27YNOTk52L9//3nbd9111+HLL7+Er68vBgwYgG3btuGvv/5CYGBgq12DxMRELF68GP/5z3/Qq1cvhISEYNy4cXj22Wfxyy+/4LrrrsN9992HxMRE6HQ6HDx4EKtXr0ZmZiaCgoIwffp0lJaWYty4cYiKisKZM2fw4YcfIiEhQRrunZCQAIVCgTfffBMVFRVQq9UYN24cQkJCWtTWMWPG4KGHHsKCBQuQlpaGCRMmwM3NDSdPnsR3332HDz74ALfddhs+//xzfPzxx7j55pvRs2dPVFZWYunSpfDx8cE111wDwNotefvtt+PDDz+ETCZDz5498dtvvzWohTrXdfvrr7/w3nvvISIiArGxsejbty+ioqJw2223IT4+Hl5eXvjrr7+wa9cuh+wbkUtw7mAtIjqfAwcOCJMnTxbCw8MFNzc3ISwsTJg8ebJw8ODBJs9Zv369AECQyWRCdnZ2o8ekp6cLU6ZMEcLCwgQ3NzchMjJSuO6664TVq1dLx4hDwRsbtlxWViZMmzZNCAoKEry8vISJEycKx44dE7p37+4wDPlihoLn5+cL1157reDt7S0AcBgWXllZKcydO1fo1auXoFKphKCgIOGyyy4T3nnnHcFoNAqCIAirV68WJkyYIISEhAgqlUro1q2b8NBDDwl5eXkOr7N06VKhR48egkKhOO+w8KlTpwqenp5N7v/000+FxMREwd3dXfD29hbi4uKE5557TsjNzRUEQRD27t0rTJ48WejWrZugVquFkJAQ4brrrhN2797t8DxFRUXCrbfeKnh4eAj+/v7CQw89JBw6dKhZQ8GPHTsmjB49WnB3dxcACFOnThUMBoPw7LPPCvHx8YK3t7fg6ekpxMfHCx9//PG5fgREnZJMEOrlR4mIiIg6MdbcEBERkUthcENEREQuhcENERERuRQGN0RERORSGNwQERGRS2FwQ0RERC6ly03iZ7FYkJubC29v71abdp2IiIjaliAIqKysRERERIO13errcsFNbm4uoqOjnd0MIiIiugDZ2dmIioo65zFdLrjx9vYGYL044krKRERE1LFptVpER0dL9/Fz6XLBjdgV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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": 9,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.16219}, {'accuracy': 0.21089000000000002}, {'accuracy': 0.23490000000000003}, {'accuracy': 0.26586}, {'accuracy': 0.20162999999999998}, {'accuracy': 0.29158999999999996}, {'accuracy': 0.28731}, {'accuracy': 0.28814999999999996}, {'accuracy': 0.33279999999999993}, {'accuracy': 0.32014999999999993}, {'accuracy': 0.22759000000000001}, {'accuracy': 0.30974}, {'accuracy': 0.31279}, {'accuracy': 0.29918000000000006}, {'accuracy': 0.28509}, {'accuracy': 0.35891}, {'accuracy': 0.29132}, {'accuracy': 0.30358}, {'accuracy': 0.34303999999999996}, {'accuracy': 0.34458}, {'accuracy': 0.37107}, {'accuracy': 0.34199}, {'accuracy': 0.31498}, {'accuracy': 0.30437}, {'accuracy': 0.36177000000000004}, {'accuracy': 0.39312}, {'accuracy': 0.37457}, {'accuracy': 0.34379}, {'accuracy': 0.37211000000000005}, {'accuracy': 0.36517}, {'accuracy': 0.41462000000000004}, {'accuracy': 0.40284999999999993}, {'accuracy': 0.4123}, {'accuracy': 0.4253800000000001}, {'accuracy': 0.43518}, {'accuracy': 0.39746000000000004}, {'accuracy': 0.45610999999999996}, {'accuracy': 0.45352}, {'accuracy': 0.42164}, {'accuracy': 0.4025}, {'accuracy': 0.45549000000000006}, {'accuracy': 0.46342}, {'accuracy': 0.43326000000000003}, {'accuracy': 0.45335000000000003}, {'accuracy': 0.45022}, {'accuracy': 0.46663999999999994}, {'accuracy': 0.46516}, {'accuracy': 0.46928000000000003}, {'accuracy': 0.46653}, {'accuracy': 0.48351999999999995}, {'accuracy': 0.47707999999999995}, {'accuracy': 0.46810999999999997}, {'accuracy': 0.47330999999999995}, {'accuracy': 0.48073999999999995}, {'accuracy': 0.46510000000000007}, {'accuracy': 0.46795}, {'accuracy': 0.47844999999999993}, {'accuracy': 0.4771500000000001}, {'accuracy': 0.4767799999999999}, {'accuracy': 0.47054}, {'accuracy': 0.4805}, {'accuracy': 0.4812099999999999}, {'accuracy': 0.43864000000000003}, {'accuracy': 0.46209999999999996}, {'accuracy': 0.48914}, {'accuracy': 0.4873799999999999}, {'accuracy': 0.48416999999999993}, {'accuracy': 0.50114}, {'accuracy': 0.49742}, {'accuracy': 0.50735}, {'accuracy': 0.5034500000000002}, {'accuracy': 0.50625}, {'accuracy': 0.50342}, {'accuracy': 0.50173}, {'accuracy': 0.50644}, {'accuracy': 0.48525999999999997}, {'accuracy': 0.53073}, {'accuracy': 0.48461}, {'accuracy': 0.48169000000000006}, {'accuracy': 0.48427}, {'accuracy': 0.5317200000000001}, {'accuracy': 0.51668}, {'accuracy': 0.5319399999999999}, {'accuracy': 0.5365300000000001}, {'accuracy': 0.50442}, {'accuracy': 0.52488}, {'accuracy': 0.52095}, {'accuracy': 0.5249600000000001}, {'accuracy': 0.53996}, {'accuracy': 0.52612}, {'accuracy': 0.5197}, {'accuracy': 0.54699}, {'accuracy': 0.52603}, {'accuracy': 0.53736}, {'accuracy': 0.55115}, {'accuracy': 0.5299699999999999}, {'accuracy': 0.53176}, {'accuracy': 0.52571}, {'accuracy': 0.5338}, {'accuracy': 0.55331}, {'accuracy': 0.5396}, {'accuracy': 0.5515700000000001}, {'accuracy': 0.5250100000000001}, {'accuracy': 0.5734299999999999}, {'accuracy': 0.55384}, {'accuracy': 0.56599}, {'accuracy': 0.5271199999999999}, {'accuracy': 0.57662}, {'accuracy': 0.55053}, {'accuracy': 0.56996}, {'accuracy': 0.58992}, {'accuracy': 0.5716100000000001}, {'accuracy': 0.59109}, {'accuracy': 0.57655}, {'accuracy': 0.55167}, {'accuracy': 0.55321}, {'accuracy': 0.5568599999999999}, {'accuracy': 0.52256}, {'accuracy': 0.5770199999999999}, {'accuracy': 0.58556}, {'accuracy': 0.58736}, {'accuracy': 0.59598}, {'accuracy': 0.59265}, {'accuracy': 0.5951099999999999}, {'accuracy': 0.59177}, {'accuracy': 0.59988}, {'accuracy': 0.58646}, {'accuracy': 0.5699400000000001}, {'accuracy': 0.58095}, {'accuracy': 0.58378}, {'accuracy': 0.58516}, {'accuracy': 0.56823}, {'accuracy': 0.5785199999999999}, {'accuracy': 0.52769}, {'accuracy': 0.5847100000000001}, {'accuracy': 0.60376}, {'accuracy': 0.59222}, {'accuracy': 0.57654}, {'accuracy': 0.5803499999999999}, {'accuracy': 0.61412}, {'accuracy': 0.57661}, {'accuracy': 0.58406}, {'accuracy': 0.6214199999999999}, {'accuracy': 0.58357}, {'accuracy': 0.57606}, {'accuracy': 0.60029}, {'accuracy': 0.58122}, {'accuracy': 0.56368}, {'accuracy': 0.58413}, {'accuracy': 0.6149600000000001}, {'accuracy': 0.6306399999999999}, {'accuracy': 0.6200999999999999}, {'accuracy': 0.5921799999999999}, {'accuracy': 0.58526}, {'accuracy': 0.61302}, {'accuracy': 0.5692600000000001}, {'accuracy': 0.60958}, {'accuracy': 0.5640599999999999}, {'accuracy': 0.6022}, {'accuracy': 0.57744}, {'accuracy': 0.62243}, {'accuracy': 0.5838300000000001}, {'accuracy': 0.58864}, {'accuracy': 0.61922}, {'accuracy': 0.58091}, {'accuracy': 0.5946899999999999}, {'accuracy': 0.60273}, {'accuracy': 0.5506699999999999}, {'accuracy': 0.6012199999999999}, {'accuracy': 0.5910500000000001}, {'accuracy': 0.60671}, {'accuracy': 0.55286}, {'accuracy': 0.6076900000000001}, {'accuracy': 0.6192}, {'accuracy': 0.5834599999999999}, {'accuracy': 0.5908100000000001}, {'accuracy': 0.58271}, {'accuracy': 0.63775}, {'accuracy': 0.64247}, {'accuracy': 0.6080800000000001}, {'accuracy': 0.6223400000000001}, {'accuracy': 0.6396299999999999}, {'accuracy': 0.6222300000000001}, {'accuracy': 0.59492}, {'accuracy': 0.6393500000000001}, {'accuracy': 0.5886}, {'accuracy': 0.59516}, {'accuracy': 0.61091}, {'accuracy': 0.59106}, {'accuracy': 0.5928}, {'accuracy': 0.59542}, {'accuracy': 0.6098899999999999}, {'accuracy': 0.6173200000000001}, {'accuracy': 0.60791}, {'accuracy': 0.5957100000000001}, {'accuracy': 0.5663199999999999}, {'accuracy': 0.5962799999999999}, {'accuracy': 0.5827199999999999}, {'accuracy': 0.58463}, {'accuracy': 0.61299}, {'accuracy': 0.81082}, {'accuracy': 0.81464}, {'accuracy': 0.8127799999999998}, {'accuracy': 0.8108600000000001}, {'accuracy': 0.8116}, {'accuracy': 0.81167}, {'accuracy': 0.8131599999999999}, {'accuracy': 0.8133699999999999}, {'accuracy': 0.81089}, {'accuracy': 0.8079600000000001}, {'accuracy': 0.8100999999999999}, {'accuracy': 0.8133900000000001}, {'accuracy': 0.81151}, {'accuracy': 0.81131}, {'accuracy': 0.8100400000000001}, {'accuracy': 0.8134}, {'accuracy': 0.81236}, {'accuracy': 0.8105800000000001}, {'accuracy': 0.81387}, {'accuracy': 0.8138799999999999}, {'accuracy': 0.8075699999999999}, {'accuracy': 0.81199}, {'accuracy': 0.8116999999999999}, {'accuracy': 0.8117800000000001}, {'accuracy': 0.8156700000000001}, {'accuracy': 0.8122799999999998}, {'accuracy': 0.81448}, {'accuracy': 0.80968}, {'accuracy': 0.8098099999999999}, {'accuracy': 0.8134399999999999}, {'accuracy': 0.8103400000000001}, {'accuracy': 0.81131}, {'accuracy': 0.81325}, {'accuracy': 0.8063499999999999}, {'accuracy': 0.81017}, {'accuracy': 0.80856}, {'accuracy': 0.8128399999999999}, {'accuracy': 0.80883}, {'accuracy': 0.8075800000000001}, {'accuracy': 0.8135}, {'accuracy': 0.8129100000000001}, {'accuracy': 0.8110399999999999}, {'accuracy': 0.8129500000000001}, {'accuracy': 0.8114700000000001}, {'accuracy': 0.8094999999999999}, {'accuracy': 0.80731}, {'accuracy': 0.80992}, {'accuracy': 0.81114}, {'accuracy': 0.8119299999999999}, {'accuracy': 0.80877}, {'accuracy': 0.8108200000000002}, {'accuracy': 0.81319}, {'accuracy': 0.8099700000000001}, {'accuracy': 0.81105}, {'accuracy': 0.81104}, {'accuracy': 0.81275}, {'accuracy': 0.80998}, {'accuracy': 0.81125}, {'accuracy': 0.8110999999999999}, {'accuracy': 0.80937}, {'accuracy': 0.8127799999999998}, {'accuracy': 0.8123600000000002}, {'accuracy': 0.8148199999999999}, {'accuracy': 0.8112400000000001}, {'accuracy': 0.81526}, {'accuracy': 0.80671}, {'accuracy': 0.81457}, {'accuracy': 0.8097899999999999}, {'accuracy': 0.8172200000000001}, {'accuracy': 0.81401}, {'accuracy': 0.8111599999999999}, {'accuracy': 0.8147400000000001}, {'accuracy': 0.8114399999999999}, {'accuracy': 0.81253}, {'accuracy': 0.8108000000000001}, {'accuracy': 0.81098}, {'accuracy': 0.81332}, {'accuracy': 0.8108000000000001}, {'accuracy': 0.8152799999999999}, {'accuracy': 0.8083199999999999}, {'accuracy': 0.8077099999999999}, {'accuracy': 0.8109399999999999}, {'accuracy': 0.8145300000000001}, {'accuracy': 0.8115500000000001}, {'accuracy': 0.81329}, {'accuracy': 0.8130000000000001}, {'accuracy': 0.8104100000000001}, {'accuracy': 0.8138500000000001}, {'accuracy': 0.8135600000000001}, {'accuracy': 0.8179000000000001}, {'accuracy': 0.81267}, {'accuracy': 0.8106100000000002}, {'accuracy': 0.8117800000000001}, {'accuracy': 0.8098699999999999}, {'accuracy': 0.8157500000000001}, {'accuracy': 0.8087899999999999}, {'accuracy': 0.81497}, {'accuracy': 0.8101800000000001}, {'accuracy': 0.8083}, {'accuracy': 0.81294}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "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": "741f6832-6cce-4bb8-8aca-024c5365f8f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f977aa5a-3f11-4d35-88c5-88a68737e1d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29e0d41b-0bfb-4596-b4e9-da3eb9392bf3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eac99099-a9b0-40fb-9fd7-c4d4eabc646d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be501306-5235-41ea-8d6c-38aad8fab87f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8fb5de7c-fdf8-401a-8073-a4ec34037599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "964180e7-b88d-431d-a041-9eac49c0979e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d72cd460-ca84-4449-a41e-2528aa10edeb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3647affb-7e23-4826-8058-973df745fe4d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2064158-713b-4ec8-acfa-44352afe03ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "308b67f1-8217-4290-a641-8c739d3bafc9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bb06c003-6ff6-46aa-86e0-5d71e39c55f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e4c07ef-f1e2-4832-b645-bfc71696ebe2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc9bf717-0456-4438-a81b-33271327dfa4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3eab7baf-543c-4e87-82cf-4166e2aa5ee3",
   "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
}
