{
 "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 2374]\n",
      " [   1   81]\n",
      " [   2   43]\n",
      " [   3   64]\n",
      " [   4  112]\n",
      " [   5  171]\n",
      " [   6  317]\n",
      " [   7  557]\n",
      " [   8  840]\n",
      " [   9 1416]]\n",
      "[[   0 1442]\n",
      " [   1 2772]\n",
      " [   2   82]\n",
      " [   3   43]\n",
      " [   4   56]\n",
      " [   5  100]\n",
      " [   6  177]\n",
      " [   7  346]\n",
      " [   8  509]\n",
      " [   9  812]]\n",
      "[[   0  859]\n",
      " [   1 1623]\n",
      " [   2 2313]\n",
      " [   3   53]\n",
      " [   4   42]\n",
      " [   5   58]\n",
      " [   6  108]\n",
      " [   7  189]\n",
      " [   8  340]\n",
      " [   9  541]]\n",
      "[[   0  479]\n",
      " [   1  922]\n",
      " [   2 1435]\n",
      " [   3 2431]\n",
      " [   4   65]\n",
      " [   5   24]\n",
      " [   6   56]\n",
      " [   7  116]\n",
      " [   8  188]\n",
      " [   9  327]]\n",
      "[[   0  271]\n",
      " [   1  561]\n",
      " [   2  878]\n",
      " [   3 1499]\n",
      " [   4 2351]\n",
      " [   5   48]\n",
      " [   6   46]\n",
      " [   7   78]\n",
      " [   8  117]\n",
      " [   9  214]]\n",
      "[[   0  206]\n",
      " [   1  324]\n",
      " [   2  506]\n",
      " [   3  864]\n",
      " [   4 1384]\n",
      " [   5 2162]\n",
      " [   6   51]\n",
      " [   7   36]\n",
      " [   8   62]\n",
      " [   9  112]]\n",
      "[[   0  127]\n",
      " [   1  222]\n",
      " [   2  317]\n",
      " [   3  527]\n",
      " [   4  851]\n",
      " [   5 1309]\n",
      " [   6 2393]\n",
      " [   7   57]\n",
      " [   8   38]\n",
      " [   9   66]]\n",
      "[[   0   61]\n",
      " [   1  126]\n",
      " [   2  186]\n",
      " [   3  326]\n",
      " [   4  489]\n",
      " [   5  793]\n",
      " [   6 1394]\n",
      " [   7 2491]\n",
      " [   8   55]\n",
      " [   9   34]]\n",
      "[[   0   39]\n",
      " [   1   70]\n",
      " [   2  112]\n",
      " [   3  190]\n",
      " [   4  294]\n",
      " [   5  461]\n",
      " [   6  853]\n",
      " [   7 1477]\n",
      " [   8 2337]\n",
      " [   9   80]]\n",
      "[[   0   65]\n",
      " [   1   41]\n",
      " [   2   86]\n",
      " [   3  134]\n",
      " [   4  198]\n",
      " [   5  295]\n",
      " [   6  523]\n",
      " [   7  918]\n",
      " [   8 1365]\n",
      " [   9 2347]]\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": [
      "5930\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2159]\n",
      " [   1   71]\n",
      " [   2   39]\n",
      " [   3   59]\n",
      " [   4  102]\n",
      " [   5  155]\n",
      " [   6  298]\n",
      " [   7  497]\n",
      " [   8  744]\n",
      " [   9 1283]]\n",
      "[[   0 2424]\n",
      " [   1   76]\n",
      " [   2   43]\n",
      " [   3   63]\n",
      " [   4  111]\n",
      " [   5  175]\n",
      " [   6  346]\n",
      " [   7  539]\n",
      " [   8  820]\n",
      " [   9 1416]]\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"
   ]
  },
  {
   "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-21:09:21 </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-21:09:21\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "846b767e65c848eb9e94012381f3de0d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-22:59:58 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3458</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:59:58\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3458\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\">75522720</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;36m75522720\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.96</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.96\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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PDxfTcdz1XQ8V83jj/N1uoyNiA3FREREFFQY3BAREVFQYXDTCgwGA+bOnQuDwRDooXQIPF9Nx3PVPDxfTcdz1XQ8V83THs5XyDUUExERUXBj5oaIiIiCCoMbIiIiCioMboiIiCioMLghIiKioMLgphW8+eabyMjIgNFoxLBhw7Bp06ZADyngnn76aahUKsVH7969pfvr6upwzz33oFOnToiIiMC1116LgoKCAI647fz222+4/PLLkZqaCpVKha+//lpxvyAImDNnDlJSUhAWFoZx48bh0KFDimNKS0sxefJkREVFISYmBrfddhuqq6vb8F20ndOdr1tuuaXez9rFF1+sOCZUzte8efPwl7/8BZGRkUhMTMRVV12FAwcOKI5pyu9ebm4uLr30UphMJiQmJuKRRx6B3W5vy7fid005VxdccEG9n6277rpLcUwonCsAePvtt9G/f39pYb7hw4fjp59+ku5vbz9XDG5aaMmSJZg1axbmzp2Lbdu2ISsrCxMmTEBhYWGghxZw55xzDvLy8qSPtWvXSvc9+OCD+O677/DFF19gzZo1OHXqFK655poAjrbtmM1mZGVl4c033/R5/0svvYTXX38d77zzDjZu3Ijw8HBMmDABdXV10jGTJ0/Gnj17sGLFCnz//ff47bffcMcdd7TVW2hTpztfAHDxxRcrftYWLVqkuD9UzteaNWtwzz334I8//sCKFStgs9kwfvx4mM1m6ZjT/e45HA5ceumlsFqtWL9+PT7++GMsXLgQc+bMCcRb8pumnCsAuP322xU/Wy+99JJ0X6icKwDo3LkzXnjhBWzduhVbtmzBmDFjcOWVV2LPnj0A2uHPlUAtMnToUOGee+6RvnY4HEJqaqowb968AI4q8ObOnStkZWX5vK+8vFzQ6XTCF198Id22b98+AYCwYcOGNhph+wBA+Oqrr6SvnU6nkJycLLz88svSbeXl5YLBYBAWLVokCIIg7N27VwAgbN68WTrmp59+ElQqlXDy5Mk2G3sgeJ8vQRCEqVOnCldeeWWDjwnl81VYWCgAENasWSMIQtN+93788UdBrVYL+fn50jFvv/22EBUVJVgslrZ9A23I+1wJgiCMHj1auP/++xt8TKieK1FsbKzw/vvvt8ufK2ZuWsBqtWLr1q0YN26cdJtarca4ceOwYcOGAI6sfTh06BBSU1PRrVs3TJ48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LFmCtWvX1gugiKjj4caZRNRuVFVVISEhAW+88QamT5+uuK+urg6pqal45513cMMNNwAAsrKycM0112Du3Lk4ePAgevXqhRUrVmDcuHH1nnv16tW48MILUVZWhpiYGEyfPh0ajQbvvvuudMzatWsxevRomM1mGI1G/75ZIvIbZm6IqN3Yt28fLBYLxo4dW+8+o9GIm2++GR9++CEAYNu2bdi9ezduueUWAMCOHTug0WgwevToJr3Wn3/+iYULFyIiIkL6mDBhApxOJ7Kzs1vtPRFR29MGegBERKKwsLBG758+fToGDBiAEydO4KOPPsKYMWPQtWvXJj3WW3V1Ne68807cd9999e7r0qVLs56LiNoXZm6IqN3o2bMnwsLCpAZhb/369cOQIUOwYMECfPbZZ7j11lsV9zmdTqxZs6ZJrzVo0CDs3bsXPXr0qPeh1+tb5f0QUWAwuCGidsNoNOKxxx7Do48+ik8++QRHjhzBH3/8oZjxNH36dLzwwgsQBAFXX321dHtGRgamTp2KW2+9FV9//TWys7OxevVqfP755z5f67HHHsP69esxc+ZM7NixA4cOHcI333zDhmKiIMDghojalaeeegoPPfQQ5syZg7PPPhsTJ05EYWGhdP+kSZOg1WoxadKkek2/b7/9Nq677jrMmDEDvXv3xu23397g1O7+/ftjzZo1OHjwIEaNGoWBAwdizpw5SE1N9ev7IyL/42wpIupQcnJy0L17d2zevBmDBg0K9HCIqB1icENEHYLNZkNJSQkefvhhZGdnY926dYEeEhG1UyxLEVGHsG7dOqSkpGDz5s145513Aj0cImrHmLkhIiKioMLMDREREQUVBjdEREQUVBjcEBERUVBhcENERERBhcENERERBRUGN0RERBRUGNwQERFRUGFwQ0REREGFwQ0REREFlf8HjM49kXPyiccAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10730999999999999}, {'accuracy': 0.11746000000000001}, {'accuracy': 0.15567}, {'accuracy': 0.26133000000000006}, {'accuracy': 0.22380999999999998}, {'accuracy': 0.24114}, {'accuracy': 0.34571999999999997}, {'accuracy': 0.34943}, {'accuracy': 0.4258}, {'accuracy': 0.46037}, {'accuracy': 0.41756000000000004}, {'accuracy': 0.5605600000000001}, {'accuracy': 0.5393000000000001}, {'accuracy': 0.50801}, {'accuracy': 0.5859300000000001}, {'accuracy': 0.5957899999999999}, {'accuracy': 0.5865600000000001}, {'accuracy': 0.57332}, {'accuracy': 0.63515}, {'accuracy': 0.6028100000000001}, {'accuracy': 0.56626}, {'accuracy': 0.56242}, {'accuracy': 0.60413}, {'accuracy': 0.60131}, {'accuracy': 0.6232300000000001}, {'accuracy': 0.65764}, {'accuracy': 0.57597}, {'accuracy': 0.62979}, {'accuracy': 0.6726}, {'accuracy': 0.65654}, {'accuracy': 0.63262}, {'accuracy': 0.66306}, {'accuracy': 0.62414}, {'accuracy': 0.7247600000000001}, {'accuracy': 0.67814}, {'accuracy': 0.67913}, {'accuracy': 0.54924}, {'accuracy': 0.7078599999999999}, {'accuracy': 0.64708}, {'accuracy': 0.67124}, {'accuracy': 0.6689499999999999}, {'accuracy': 0.6968599999999999}, {'accuracy': 0.7046299999999999}, {'accuracy': 0.72243}, {'accuracy': 0.66576}, {'accuracy': 0.6543500000000001}, {'accuracy': 0.6559900000000001}, {'accuracy': 0.7445700000000001}, {'accuracy': 0.74306}, {'accuracy': 0.74346}, {'accuracy': 0.67848}, {'accuracy': 0.7016}, {'accuracy': 0.7034199999999999}, {'accuracy': 0.6340600000000001}, {'accuracy': 0.62225}, {'accuracy': 0.7367799999999999}, {'accuracy': 0.7022299999999999}, {'accuracy': 0.6859}, {'accuracy': 0.69274}, {'accuracy': 0.68767}, {'accuracy': 0.7259}, {'accuracy': 0.7524799999999999}, {'accuracy': 0.73411}, {'accuracy': 0.72556}, {'accuracy': 0.77631}, {'accuracy': 0.72096}, {'accuracy': 0.7490100000000001}, {'accuracy': 0.7400399999999999}, {'accuracy': 0.7093900000000001}, {'accuracy': 0.7576600000000001}, {'accuracy': 0.6744600000000001}, {'accuracy': 0.7134}, {'accuracy': 0.73051}, {'accuracy': 0.77043}, {'accuracy': 0.72126}, {'accuracy': 0.67362}, {'accuracy': 0.71275}, {'accuracy': 0.77886}, {'accuracy': 0.7457999999999998}, {'accuracy': 0.6236400000000001}, {'accuracy': 0.7301300000000001}, {'accuracy': 0.71418}, {'accuracy': 0.5916}, {'accuracy': 0.7489}, {'accuracy': 0.78461}, {'accuracy': 0.6986199999999999}, {'accuracy': 0.75509}, {'accuracy': 0.73371}, {'accuracy': 0.76988}, {'accuracy': 0.7322}, {'accuracy': 0.66044}, {'accuracy': 0.6575099999999999}, {'accuracy': 0.7202}, {'accuracy': 0.73753}, {'accuracy': 0.7376699999999999}, {'accuracy': 0.7258799999999999}, {'accuracy': 0.71075}, {'accuracy': 0.7388399999999999}, {'accuracy': 0.72836}, {'accuracy': 0.7532}, {'accuracy': 0.7079799999999998}, {'accuracy': 0.77539}, {'accuracy': 0.76535}, {'accuracy': 0.78403}, {'accuracy': 0.70712}, {'accuracy': 0.76686}, {'accuracy': 0.74529}, {'accuracy': 0.8077799999999999}, {'accuracy': 0.6903699999999999}, {'accuracy': 0.72194}, {'accuracy': 0.71099}, {'accuracy': 0.7668699999999999}, {'accuracy': 0.65878}, {'accuracy': 0.74836}, {'accuracy': 0.74839}, {'accuracy': 0.69467}, {'accuracy': 0.76135}, {'accuracy': 0.71666}, {'accuracy': 0.6912499999999999}, {'accuracy': 0.6900499999999999}, {'accuracy': 0.7787200000000001}, {'accuracy': 0.6291200000000001}, {'accuracy': 0.6948799999999999}, {'accuracy': 0.74143}, {'accuracy': 0.66524}, {'accuracy': 0.76014}, {'accuracy': 0.6015699999999999}, {'accuracy': 0.7740600000000001}, {'accuracy': 0.6767900000000001}, {'accuracy': 0.71419}, {'accuracy': 0.74353}, {'accuracy': 0.73522}, {'accuracy': 0.68523}, {'accuracy': 0.7356499999999999}, {'accuracy': 0.75136}, {'accuracy': 0.70927}, {'accuracy': 0.67149}, {'accuracy': 0.7342500000000001}, {'accuracy': 0.7723599999999999}, {'accuracy': 0.68987}, {'accuracy': 0.74116}, {'accuracy': 0.7658799999999999}, {'accuracy': 0.71479}, {'accuracy': 0.65989}, {'accuracy': 0.79666}, {'accuracy': 0.7496}, {'accuracy': 0.7022199999999998}, {'accuracy': 0.7704799999999999}, {'accuracy': 0.68895}, {'accuracy': 0.71947}, {'accuracy': 0.7607400000000001}, {'accuracy': 0.9617000000000001}, {'accuracy': 0.96355}, {'accuracy': 0.91084}, {'accuracy': 0.9597}, {'accuracy': 0.9604700000000002}, {'accuracy': 0.9602700000000001}, {'accuracy': 0.9609099999999998}, {'accuracy': 0.95977}, {'accuracy': 0.95974}, {'accuracy': 0.9610199999999999}, {'accuracy': 0.95953}, {'accuracy': 0.95842}, {'accuracy': 0.9577500000000001}, {'accuracy': 0.9566399999999999}, {'accuracy': 0.95853}, {'accuracy': 0.9581299999999999}, {'accuracy': 0.95963}, {'accuracy': 0.9569899999999999}, {'accuracy': 0.9583100000000002}, {'accuracy': 0.9569600000000001}, {'accuracy': 0.9584300000000001}, {'accuracy': 0.95719}, {'accuracy': 0.9576600000000001}, {'accuracy': 0.9586599999999998}, {'accuracy': 0.95692}, {'accuracy': 0.95745}, {'accuracy': 0.9553900000000002}, {'accuracy': 0.9572500000000002}, {'accuracy': 0.95939}, {'accuracy': 0.9535599999999999}, {'accuracy': 0.9584400000000001}, {'accuracy': 0.95784}, {'accuracy': 0.9559099999999999}, {'accuracy': 0.95564}, {'accuracy': 0.95663}, {'accuracy': 0.9553899999999999}, {'accuracy': 0.95984}, {'accuracy': 0.9552799999999999}, {'accuracy': 0.9554400000000001}, {'accuracy': 0.9579000000000001}, {'accuracy': 0.95788}, {'accuracy': 0.95767}, {'accuracy': 0.9556600000000002}, {'accuracy': 0.9576600000000001}, {'accuracy': 0.9568199999999999}, {'accuracy': 0.9592600000000001}, {'accuracy': 0.9595199999999998}, {'accuracy': 0.9593999999999999}, {'accuracy': 0.9564199999999999}, {'accuracy': 0.9530399999999999}, {'accuracy': 0.9573499999999999}, {'accuracy': 0.9568499999999999}, {'accuracy': 0.95727}, {'accuracy': 0.95838}, {'accuracy': 0.9565300000000001}, {'accuracy': 0.9580299999999999}, {'accuracy': 0.9576500000000001}, {'accuracy': 0.95992}, {'accuracy': 0.9585799999999999}, {'accuracy': 0.9560099999999998}, {'accuracy': 0.9574}, {'accuracy': 0.9573499999999999}, {'accuracy': 0.95716}, {'accuracy': 0.95842}, {'accuracy': 0.9584000000000001}, {'accuracy': 0.95759}, {'accuracy': 0.95372}, {'accuracy': 0.95727}, {'accuracy': 0.95898}, {'accuracy': 0.9573699999999998}, {'accuracy': 0.9584300000000001}, {'accuracy': 0.9586499999999999}, {'accuracy': 0.95656}, {'accuracy': 0.95647}, {'accuracy': 0.95808}, {'accuracy': 0.95676}, {'accuracy': 0.9582599999999999}, {'accuracy': 0.9585800000000001}, {'accuracy': 0.9584700000000002}, {'accuracy': 0.95637}, {'accuracy': 0.959}, {'accuracy': 0.9568200000000001}, {'accuracy': 0.9577600000000001}, {'accuracy': 0.95749}, {'accuracy': 0.9570399999999999}, {'accuracy': 0.9578}, {'accuracy': 0.95597}, {'accuracy': 0.9555600000000002}, {'accuracy': 0.9578900000000001}, {'accuracy': 0.9578300000000001}, {'accuracy': 0.95759}, {'accuracy': 0.95426}, {'accuracy': 0.9558900000000001}, {'accuracy': 0.95871}, {'accuracy': 0.9594900000000001}, {'accuracy': 0.9581000000000002}, {'accuracy': 0.9592599999999999}, {'accuracy': 0.95777}, {'accuracy': 0.9566099999999998}, {'accuracy': 0.9574300000000001}, {'accuracy': 0.95609}, {'accuracy': 0.9579599999999999}, {'accuracy': 0.9590099999999999}, {'accuracy': 0.9566099999999998}, {'accuracy': 0.9572900000000001}, {'accuracy': 0.9581800000000001}, {'accuracy': 0.95813}, {'accuracy': 0.9564600000000001}, {'accuracy': 0.9598000000000001}, {'accuracy': 0.9598400000000001}, {'accuracy': 0.9576800000000001}, {'accuracy': 0.95998}, {'accuracy': 0.9606199999999999}, {'accuracy': 0.95792}, {'accuracy': 0.95846}, {'accuracy': 0.9602600000000001}, {'accuracy': 0.9562100000000001}, {'accuracy': 0.9581}, {'accuracy': 0.95509}, {'accuracy': 0.9595500000000001}, {'accuracy': 0.9580100000000001}, {'accuracy': 0.9587600000000001}, {'accuracy': 0.95954}, {'accuracy': 0.9590799999999999}, {'accuracy': 0.9596199999999999}, {'accuracy': 0.9619000000000002}, {'accuracy': 0.9576399999999999}, {'accuracy': 0.95975}, {'accuracy': 0.95936}, {'accuracy': 0.95808}, {'accuracy': 0.9577199999999999}, {'accuracy': 0.95699}, {'accuracy': 0.9587899999999999}, {'accuracy': 0.9572500000000002}, {'accuracy': 0.95848}, {'accuracy': 0.95598}, {'accuracy': 0.95749}, {'accuracy': 0.9578700000000001}, {'accuracy': 0.9542599999999999}, {'accuracy': 0.9590799999999999}, {'accuracy': 0.9572700000000001}, {'accuracy': 0.9593400000000001}, {'accuracy': 0.95814}, {'accuracy': 0.95856}, {'accuracy': 0.9576600000000001}, {'accuracy': 0.95673}, {'accuracy': 0.95992}, {'accuracy': 0.95855}, {'accuracy': 0.95862}]\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": "ce4b0d17-26d8-4908-a69d-1506013d487a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1603d5a6-7339-4abc-9a2f-1b4e13b7eec1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1cdf82c-005d-4021-940d-44029600b2b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1bfaa443-0235-40d7-8d45-c3b1d9a4dbf7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57682ef2-fc55-4eec-9bf6-b898080977a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ebbfffa3-d69b-4fff-9c3f-30e83c43ae84",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "85723c5a-c920-4fc1-97c1-eec8290c8a63",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "615d5832-51fd-40d9-b4bc-fe7778d8b962",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fa66dfdb-d417-444d-8985-1d1991efb82d",
   "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
}
