{
 "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 2372]\n",
      " [   1   71]\n",
      " [   2   41]\n",
      " [   3   70]\n",
      " [   4  124]\n",
      " [   5  156]\n",
      " [   6  277]\n",
      " [   7  563]\n",
      " [   8  818]\n",
      " [   9 1424]]\n",
      "[[   0 1447]\n",
      " [   1 2693]\n",
      " [   2   65]\n",
      " [   3   47]\n",
      " [   4   69]\n",
      " [   5   96]\n",
      " [   6  173]\n",
      " [   7  340]\n",
      " [   8  489]\n",
      " [   9  831]]\n",
      "[[   0  831]\n",
      " [   1 1581]\n",
      " [   2 2437]\n",
      " [   3   69]\n",
      " [   4   39]\n",
      " [   5   60]\n",
      " [   6  124]\n",
      " [   7  189]\n",
      " [   8  298]\n",
      " [   9  513]]\n",
      "[[   0  506]\n",
      " [   1 1000]\n",
      " [   2 1402]\n",
      " [   3 2438]\n",
      " [   4   67]\n",
      " [   5   40]\n",
      " [   6   75]\n",
      " [   7  113]\n",
      " [   8  189]\n",
      " [   9  311]]\n",
      "[[   0  330]\n",
      " [   1  565]\n",
      " [   2  842]\n",
      " [   3 1454]\n",
      " [   4 2324]\n",
      " [   5   47]\n",
      " [   6   47]\n",
      " [   7   70]\n",
      " [   8  107]\n",
      " [   9  186]]\n",
      "[[   0  176]\n",
      " [   1  360]\n",
      " [   2  560]\n",
      " [   3  916]\n",
      " [   4 1412]\n",
      " [   5 2183]\n",
      " [   6   54]\n",
      " [   7   49]\n",
      " [   8   76]\n",
      " [   9  111]]\n",
      "[[   0   92]\n",
      " [   1  215]\n",
      " [   2  279]\n",
      " [   3  538]\n",
      " [   4  889]\n",
      " [   5 1286]\n",
      " [   6 2369]\n",
      " [   7   63]\n",
      " [   8   37]\n",
      " [   9   82]]\n",
      "[[   0   62]\n",
      " [   1  118]\n",
      " [   2  170]\n",
      " [   3  313]\n",
      " [   4  463]\n",
      " [   5  785]\n",
      " [   6 1457]\n",
      " [   7 2523]\n",
      " [   8   78]\n",
      " [   9   31]]\n",
      "[[   0   38]\n",
      " [   1   84]\n",
      " [   2  103]\n",
      " [   3  179]\n",
      " [   4  295]\n",
      " [   5  468]\n",
      " [   6  841]\n",
      " [   7 1480]\n",
      " [   8 2396]\n",
      " [   9   60]]\n",
      "[[   0   69]\n",
      " [   1   55]\n",
      " [   2   59]\n",
      " [   3  107]\n",
      " [   4  160]\n",
      " [   5  300]\n",
      " [   6  501]\n",
      " [   7  875]\n",
      " [   8 1363]\n",
      " [   9 2400]]\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": [
      "30064\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1261]\n",
      " [   1   30]\n",
      " [   2   23]\n",
      " [   3   32]\n",
      " [   4   61]\n",
      " [   5   70]\n",
      " [   6  116]\n",
      " [   7  273]\n",
      " [   8  403]\n",
      " [   9  725]]\n",
      "[[   0 2570]\n",
      " [   1   63]\n",
      " [   2   35]\n",
      " [   3   68]\n",
      " [   4  106]\n",
      " [   5  157]\n",
      " [   6  282]\n",
      " [   7  511]\n",
      " [   8  880]\n",
      " [   9 1478]]\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<5:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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-18:05:00 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:05:00\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": "14d249ba694043169f1cc394210c2fe1",
       "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-20:09:45 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3149</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:09:45\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3149\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\">68774160</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;36m68774160\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10110999999999999}, {'accuracy': 0.09951}, {'accuracy': 0.11253000000000002}, {'accuracy': 0.13449}, {'accuracy': 0.10023}, {'accuracy': 0.15624}, {'accuracy': 0.14559}, {'accuracy': 0.14306000000000002}, {'accuracy': 0.17595}, {'accuracy': 0.17154}, {'accuracy': 0.20947}, {'accuracy': 0.16348}, {'accuracy': 0.1782}, {'accuracy': 0.33667}, {'accuracy': 0.22796000000000002}, {'accuracy': 0.19946999999999998}, {'accuracy': 0.26328000000000007}, {'accuracy': 0.2829}, {'accuracy': 0.31472999999999995}, {'accuracy': 0.27618}, {'accuracy': 0.28063999999999995}, {'accuracy': 0.31878}, {'accuracy': 0.25475000000000003}, {'accuracy': 0.29005000000000003}, {'accuracy': 0.26443}, {'accuracy': 0.42102000000000006}, {'accuracy': 0.29927000000000004}, {'accuracy': 0.34457}, {'accuracy': 0.40231000000000006}, {'accuracy': 0.37851}, {'accuracy': 0.40237000000000006}, {'accuracy': 0.26304}, {'accuracy': 0.33242999999999995}, {'accuracy': 0.38274}, {'accuracy': 0.39115}, {'accuracy': 0.38695}, {'accuracy': 0.43366999999999994}, {'accuracy': 0.2674}, {'accuracy': 0.48042000000000007}, {'accuracy': 0.42121000000000003}, {'accuracy': 0.41667}, {'accuracy': 0.34241}, {'accuracy': 0.30175}, {'accuracy': 0.47271}, {'accuracy': 0.46792}, {'accuracy': 0.34555}, {'accuracy': 0.45241999999999993}, {'accuracy': 0.34831}, {'accuracy': 0.37052}, {'accuracy': 0.41290999999999994}, {'accuracy': 0.40858}, {'accuracy': 0.42049000000000003}, {'accuracy': 0.40792}, {'accuracy': 0.39985}, {'accuracy': 0.5014799999999999}, {'accuracy': 0.38393}, {'accuracy': 0.40885999999999995}, {'accuracy': 0.4834100000000001}, {'accuracy': 0.44916}, {'accuracy': 0.48577999999999993}, {'accuracy': 0.50841}, {'accuracy': 0.42735}, {'accuracy': 0.39988000000000007}, {'accuracy': 0.46631}, {'accuracy': 0.37543}, {'accuracy': 0.4133}, {'accuracy': 0.442}, {'accuracy': 0.4579599999999999}, {'accuracy': 0.39645}, {'accuracy': 0.4274}, {'accuracy': 0.36819}, {'accuracy': 0.40799}, {'accuracy': 0.42275}, {'accuracy': 0.4735800000000001}, {'accuracy': 0.43916000000000005}, {'accuracy': 0.4578900000000001}, {'accuracy': 0.5204500000000001}, {'accuracy': 0.44570999999999994}, {'accuracy': 0.41738}, {'accuracy': 0.44506000000000007}, {'accuracy': 0.42615}, {'accuracy': 0.45526}, {'accuracy': 0.5016499999999999}, {'accuracy': 0.47203}, {'accuracy': 0.4108899999999999}, {'accuracy': 0.40024999999999994}, {'accuracy': 0.4875299999999999}, {'accuracy': 0.5283}, {'accuracy': 0.5266500000000001}, {'accuracy': 0.4705399999999999}, {'accuracy': 0.48386000000000007}, {'accuracy': 0.45985}, {'accuracy': 0.49297}, {'accuracy': 0.46823999999999993}, {'accuracy': 0.45932000000000006}, {'accuracy': 0.38919000000000004}, {'accuracy': 0.44353}, {'accuracy': 0.4494999999999999}, {'accuracy': 0.49389000000000005}, {'accuracy': 0.4446300000000001}, {'accuracy': 0.44725000000000004}, {'accuracy': 0.47535999999999995}, {'accuracy': 0.45513999999999993}, {'accuracy': 0.46521}, {'accuracy': 0.49406999999999995}, {'accuracy': 0.5412}, {'accuracy': 0.53303}, {'accuracy': 0.49995}, {'accuracy': 0.49044999999999994}, {'accuracy': 0.5322199999999999}, {'accuracy': 0.42649}, {'accuracy': 0.44903000000000004}, {'accuracy': 0.51931}, {'accuracy': 0.4672300000000001}, {'accuracy': 0.44657}, {'accuracy': 0.48484}, {'accuracy': 0.49941}, {'accuracy': 0.54427}, {'accuracy': 0.5394400000000001}, {'accuracy': 0.46213999999999994}, {'accuracy': 0.51387}, {'accuracy': 0.47762000000000004}, {'accuracy': 0.48411}, {'accuracy': 0.5333699999999999}, {'accuracy': 0.48893000000000003}, {'accuracy': 0.49312000000000006}, {'accuracy': 0.4714499999999999}, {'accuracy': 0.5039}, {'accuracy': 0.524}, {'accuracy': 0.56689}, {'accuracy': 0.53027}, {'accuracy': 0.5203599999999999}, {'accuracy': 0.46685}, {'accuracy': 0.54139}, {'accuracy': 0.48442999999999986}, {'accuracy': 0.5794499999999999}, {'accuracy': 0.50265}, {'accuracy': 0.46159999999999995}, {'accuracy': 0.49541}, {'accuracy': 0.48462999999999995}, {'accuracy': 0.45793}, {'accuracy': 0.48503999999999997}, {'accuracy': 0.4604500000000001}, {'accuracy': 0.50642}, {'accuracy': 0.54868}, {'accuracy': 0.48129999999999995}, {'accuracy': 0.56486}, {'accuracy': 0.45120000000000005}, {'accuracy': 0.49532}, {'accuracy': 0.50539}, {'accuracy': 0.63855}, {'accuracy': 0.54789}, {'accuracy': 0.64078}, {'accuracy': 0.68672}, {'accuracy': 0.75824}, {'accuracy': 0.76537}, {'accuracy': 0.6829799999999999}, {'accuracy': 0.82928}, {'accuracy': 0.66692}, {'accuracy': 0.7402900000000001}, {'accuracy': 0.74283}, {'accuracy': 0.82745}, {'accuracy': 0.7343200000000001}, {'accuracy': 0.82948}, {'accuracy': 0.7197899999999999}, {'accuracy': 0.72276}, {'accuracy': 0.75293}, {'accuracy': 0.77525}, {'accuracy': 0.77456}, {'accuracy': 0.82295}, {'accuracy': 0.7354299999999999}, {'accuracy': 0.8265399999999999}, {'accuracy': 0.82515}, {'accuracy': 0.77973}, {'accuracy': 0.72019}, {'accuracy': 0.8279500000000001}, {'accuracy': 0.69464}, {'accuracy': 0.72351}, {'accuracy': 0.7251200000000001}, {'accuracy': 0.7716200000000001}, {'accuracy': 0.77598}, {'accuracy': 0.7804800000000001}, {'accuracy': 0.7374300000000001}, {'accuracy': 0.71431}, {'accuracy': 0.77707}, {'accuracy': 0.82664}, {'accuracy': 0.81036}, {'accuracy': 0.8153500000000001}, {'accuracy': 0.6647699999999999}, {'accuracy': 0.8109999999999999}, {'accuracy': 0.82236}, {'accuracy': 0.76668}, {'accuracy': 0.71438}, {'accuracy': 0.77263}, {'accuracy': 0.7730600000000001}, {'accuracy': 0.83339}, {'accuracy': 0.72558}, {'accuracy': 0.8253299999999999}, {'accuracy': 0.83041}, {'accuracy': 0.73533}, {'accuracy': 0.73568}, {'accuracy': 0.81652}, {'accuracy': 0.76874}, {'accuracy': 0.7721600000000001}, {'accuracy': 0.7322200000000001}, {'accuracy': 0.71265}, {'accuracy': 0.7673400000000001}, {'accuracy': 0.73587}, {'accuracy': 0.7820400000000001}, {'accuracy': 0.7853600000000001}, {'accuracy': 0.8264900000000001}, {'accuracy': 0.78198}, {'accuracy': 0.77344}, {'accuracy': 0.6236900000000001}, {'accuracy': 0.7623199999999999}, {'accuracy': 0.6666000000000001}, {'accuracy': 0.65878}, {'accuracy': 0.818}, {'accuracy': 0.8200999999999998}, {'accuracy': 0.8232800000000001}, {'accuracy': 0.8309900000000001}, {'accuracy': 0.77863}, {'accuracy': 0.732}, {'accuracy': 0.8295999999999999}, {'accuracy': 0.72215}, {'accuracy': 0.77294}, {'accuracy': 0.7576400000000001}, {'accuracy': 0.7186000000000001}, {'accuracy': 0.7220099999999999}, {'accuracy': 0.71172}, {'accuracy': 0.81573}, {'accuracy': 0.7283100000000001}, {'accuracy': 0.6571}, {'accuracy': 0.7671}, {'accuracy': 0.66123}, {'accuracy': 0.77293}, {'accuracy': 0.7799400000000001}, {'accuracy': 0.8297100000000001}, {'accuracy': 0.7252599999999999}, {'accuracy': 0.7736000000000001}, {'accuracy': 0.7805600000000001}, {'accuracy': 0.6764800000000001}, {'accuracy': 0.7616700000000001}, {'accuracy': 0.8254100000000001}, {'accuracy': 0.8236600000000001}, {'accuracy': 0.8302999999999999}, {'accuracy': 0.77996}, {'accuracy': 0.7283900000000001}, {'accuracy': 0.6808}, {'accuracy': 0.72963}, {'accuracy': 0.77382}, {'accuracy': 0.8280999999999998}, {'accuracy': 0.78136}, {'accuracy': 0.71724}, {'accuracy': 0.7306799999999999}, {'accuracy': 0.76798}, {'accuracy': 0.72942}, {'accuracy': 0.7134699999999999}, {'accuracy': 0.69207}, {'accuracy': 0.76086}, {'accuracy': 0.8106899999999999}, {'accuracy': 0.7229300000000001}, {'accuracy': 0.71417}, {'accuracy': 0.80831}, {'accuracy': 0.7735}, {'accuracy': 0.8238899999999999}, {'accuracy': 0.8243100000000002}, {'accuracy': 0.76608}, {'accuracy': 0.82359}, {'accuracy': 0.8265500000000001}, {'accuracy': 0.75829}, {'accuracy': 0.8312099999999999}, {'accuracy': 0.8251999999999999}, {'accuracy': 0.8258099999999999}, {'accuracy': 0.7954000000000001}, {'accuracy': 0.81777}, {'accuracy': 0.82681}, {'accuracy': 0.78218}, {'accuracy': 0.76014}, {'accuracy': 0.7884599999999999}, {'accuracy': 0.7727099999999999}, {'accuracy': 0.77242}, {'accuracy': 0.716}, {'accuracy': 0.7593099999999999}, {'accuracy': 0.76682}, {'accuracy': 0.7714000000000001}, {'accuracy': 0.72096}, {'accuracy': 0.76055}, {'accuracy': 0.8114699999999999}, {'accuracy': 0.8087500000000001}, {'accuracy': 0.7602400000000001}, {'accuracy': 0.77041}, {'accuracy': 0.7274099999999999}, {'accuracy': 0.76431}, {'accuracy': 0.68789}, {'accuracy': 0.77613}, {'accuracy': 0.7198300000000001}, {'accuracy': 0.72201}, {'accuracy': 0.78122}, {'accuracy': 0.7688300000000001}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e5cb62c3-a75b-48b3-9a80-211b19dd41c3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.77</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py: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.77\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACsGElEQVR4nOydd5wU5f3HP7N993pvHBy9SBWEoKAop9i7IhpBVGJUEg2/GCVGsESxEkwsKFHRxAgRNZqoWBBsoChFivR2lOv99m77/P6YfWafmZ3d2z3ubvfuvu/X617c7c7OPju33PPZz7cJoiiKIAiCIAiC6CboYr0AgiAIgiCI9oTEDUEQBEEQ3QoSNwRBEARBdCtI3BAEQRAE0a0gcUMQBEEQRLeCxA1BEARBEN0KEjcEQRAEQXQrSNwQBEEQBNGtIHFDEARBEES3gsQNQRAdyrp16yAIAtatWyffdtNNN6GoqChma+pOPPjggxAEIdbLIIi4gsQNQcQ5O3fuxC9/+UsUFBTAbDYjPz8fN9xwA3bu3BnrpXU4L7zwApYvX96hz/Hzzz/jwQcfxOHDhzv0eTqTxx57DP/5z39ivQyCiBkkbggijnn33Xdx6qmnYs2aNZg9ezZeeOEF3HLLLVi7di1OPfVUvPfee7FeYofSWeLmoYceInFDEN0IQ6wXQBCENgcOHMCNN96Ifv364auvvkJWVpZ831133YXJkyfjxhtvxLZt29CvX79OW5fdbkdCQkKnPV9XgK4JQcQX5NwQRJzy1FNPobm5GS+//LJC2ABAZmYmXnrpJdjtdjz55JMAgFWrVkEQBHz55ZdB53rppZcgCAJ27Ngh37Z7925cffXVSE9Ph8Viwbhx4/DBBx8oHrd8+XL5nHfccQeys7PRq1cvAMCRI0dwxx13YPDgwbBarcjIyMA111zTbg5IUVERdu7ciS+//BKCIEAQBEyZMkW+v66uDnfffTcKCwthNpsxYMAAPPHEE/D5fIrzrFixAmPHjkVSUhKSk5MxYsQIPPvss/Lru+aaawAAZ599tvw8fH6QmptuugmJiYk4cOAALrzwQiQlJeGGG24AAPh8PixZsgSnnHIKLBYLcnJycNttt6G2tlZxjh9//BHTpk1DZmYmrFYr+vbti5tvvlm+XytPCQAOHz4MQRDCulmCIMBut+P111+XX89NN90EAGhsbMTdd9+NoqIimM1mZGdn49xzz8XmzZtDno8guiLk3BBEnPLf//4XRUVFmDx5sub9Z555JoqKivDhhx8CAC666CIkJibi3//+N8466yzFsStXrsQpp5yC4cOHA5DyeM444wwUFBTgvvvuQ0JCAv7973/j8ssvxzvvvIMrrrhC8fg77rgDWVlZWLBgAex2OwDghx9+wPr163HdddehV69eOHz4MF588UVMmTIFP//8M2w220m9/iVLluA3v/kNEhMTcf/99wMAcnJyAADNzc0466yzcPz4cdx2223o3bs31q9fj/nz56O0tBRLliwBAHz22WeYMWMGpk6diieeeAIAsGvXLnz77be46667cOaZZ+K3v/0t/vrXv+KPf/wjhg4dCgDyv6HweDyYNm0aJk2ahKefflp+rbfddhuWL1+O2bNn47e//S0OHTqE5557Dlu2bMG3334Lo9GIiooKnHfeecjKysJ9992H1NRUHD58GO++++5JXS/GP/7xD9x6660YP348fvWrXwEA+vfvDwD49a9/jVWrVmHu3LkYNmwYqqur8c0332DXrl049dRT2+X5CSIuEAmCiDvq6upEAOJll10W9rhLL71UBCA2NDSIoiiKM2bMELOzs0WPxyMfU1paKup0OvHhhx+Wb5s6dao4YsQI0eFwyLf5fD7x9NNPFwcOHCjf9tprr4kAxEmTJinOKYqi2NzcHLSeDRs2iADEN954Q75t7dq1IgBx7dq18m2zZs0S+/TpE/a1iaIonnLKKeJZZ50VdPsjjzwiJiQkiHv37lXcft9994l6vV4sKSkRRVEU77rrLjE5OTlo7Txvv/120PrCMWvWLBGAeN999ylu//rrr0UA4ptvvqm4ffXq1Yrb33vvPRGA+MMPP4R8Dq1rJoqieOjQIRGA+Nprr8m3LVy4UFT/KU9ISBBnzZoVdN6UlBTxzjvvjOBVEkTXhsJSBBGHNDY2AgCSkpLCHsfub2hoAABMnz4dFRUVinDGqlWr4PP5MH36dABATU0NvvjiC1x77bVobGxEVVUVqqqqUF1djWnTpmHfvn04fvy44nnmzJkDvV6vuM1qtcrfu91uVFdXY8CAAUhNTe3wMMfbb7+NyZMnIy0tTV5/VVUViouL4fV68dVXXwEAUlNTYbfb8dlnn7X7Gm6//fagNaWkpODcc89VrGns2LFITEzE2rVr5TUBwP/+9z+43e52X1c4UlNT8f333+PEiROd+rwE0dmQuCGIOISJFiZyQqEWQeeffz5SUlKwcuVK+ZiVK1di9OjRGDRoEABg//79EEURDzzwALKyshRfCxcuBABUVFQonqdv375Bz93S0oIFCxbIOS+ZmZnIyspCXV0d6uvr2/jKI2Pfvn1YvXp10PqLi4sV67/jjjswaNAgXHDBBejVqxduvvlmrF69+qSf32AwyLlH/Jrq6+uRnZ0dtK6mpiZ5TWeddRauuuoqPPTQQ8jMzMRll12G1157DU6n86TX1RpPPvkkduzYgcLCQowfPx4PPvggDh482OHPSxCdDeXcEEQckpKSgry8PGzbti3scdu2bUNBQQGSk5MBAGazGZdffjnee+89vPDCCygvL8e3336Lxx57TH4MS7j9/e9/j2nTpmmed8CAAYqfeZeG8Zvf/AavvfYa7r77bkycOBEpKSkQBAHXXXddUFJve+Pz+XDuuefiD3/4g+b9TMhlZ2dj69at+OSTT/Dxxx/j448/xmuvvYaZM2fi9ddfb/Pzm81m6HTKz4Y+nw/Z2dl48803NR/DksIFQcCqVavw3Xff4b///S8++eQT3HzzzXjmmWfw3XffITExMWRTPq/X2+Y1A8C1116LyZMn47333sOnn36Kp556Ck888QTeffddXHDBBSd1boKIJ0jcEESccvHFF2PZsmX45ptvMGnSpKD7v/76axw+fBi33Xab4vbp06fj9ddfx5o1a7Br1y6IoiiHpADIZeNGo1F2OtrCqlWrMGvWLDzzzDPybQ6HA3V1dW0+p5pQm3z//v3R1NQU0fpNJhMuueQSXHLJJfD5fLjjjjvw0ksv4YEHHsCAAQParbtv//798fnnn+OMM87QFINqfvGLX+AXv/gFHn30UfzrX//CDTfcgBUrVuDWW29FWloaAARdyyNHjkS0lnCvKS8vD3fccQfuuOMOVFRU4NRTT8Wjjz5K4oboVlBYiiDilHvuuQdWqxW33XYbqqurFffV1NTg17/+NWw2G+655x7FfcXFxUhPT8fKlSuxcuVKjB8/XhFWys7OxpQpU/DSSy+htLQ06HkrKysjWp9er4coiorb/va3v520u8CTkJCgKZauvfZabNiwAZ988knQfXV1dfB4PAAQdN10Oh1GjhwJAHIYiPWnOVlRdu2118Lr9eKRRx4Jus/j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8d568skn5ft6yrUCgF69euHxxx/Hpk2b8OOPP+Kcc87BZZddhp07dwKIw/eVSJwU48ePF++88075Z6/XK+bn54uLFi2K4apiz8KFC8VRo0Zp3ldXVycajUbx7bfflm/btWuXCEDcsGFDJ60wPgAgvvfee/LPPp9PzM3NFZ966in5trq6OtFsNotvvfWWKIqi+PPPP4sAxB9++EE+5uOPPxYFQRCPHz/eaWuPBerrJYqiOGvWLPGyyy4L+ZiefL0qKipEAOKXX34pimJk//c++ugjUafTiWVlZfIxL774opicnCw6nc7OfQGdiPpaiaIonnXWWeJdd90V8jE99Vox0tLSxL///e9x+b4i5+YkcLlc2LRpE4qLi+XbdDodiouLsWHDhhiuLD7Yt28f8vPz0a9fP9xwww0oKSkBAGzatAlut1tx3YYMGYLevXv3+Ot26NAhlJWVKa5NSkoKJkyYIF+bDRs2IDU1FePGjZOPKS4uhk6nw/fff9/pa44H1q1bh+zsbAwePBi33347qqur5ft68vWqr68HAKSnpwOI7P/ehg0bMGLECOTk5MjHTJs2DQ0NDfKn9O6I+lox3nzzTWRmZmL48OGYP38+mpub5ft66rXyer1YsWIF7HY7Jk6cGJfvqx43OLM9qaqqgtfrVfyyACAnJwe7d++O0arigwkTJmD58uUYPHgwSktL8dBDD2Hy5MnYsWMHysrKYDKZkJqaqnhMTk4OysrKYrPgOIG9fq33FLuvrKwM2dnZivsNBgPS09N75PU7//zzceWVV6Jv3744cOAA/vjHP+KCCy7Ahg0boNfre+z18vl8uPvuu3HGGWdg+PDhABDR/72ysjLN9x+7rzuida0A4Prrr0efPn2Qn5+Pbdu24d5778WePXvw7rvvAuh512r79u2YOHEiHA4HEhMT8d5772HYsGHYunVr3L2vSNwQHcIFF1wgfz9y5EhMmDABffr0wb///W9YrdYYrozoblx33XXy9yNGjMDIkSPRv39/rFu3DlOnTo3hymLLnXfeiR07dihy3QhtQl0rPi9rxIgRyMvLw9SpU3HgwAH079+/s5cZcwYPHoytW7eivr4eq1atwqxZs/Dll1/GelmaUFjqJMjMzIRerw/KCC8vL0dubm6MVhWfpKamYtCgQdi/fz9yc3PhcrlQV1enOIauG+TXH+49lZubG5Sw7vF4UFNT0+OvHwD069cPmZmZ2L9/P4Ceeb3mzp2L//3vf1i7di169eol3x7J/73c3FzN9x+7r7sR6lppMWHCBABQvLd60rUymUwYMGAAxo4di0WLFmHUqFF49tln4/J9ReLmJDCZTBg7dizWrFkj3+bz+bBmzRpMnDgxhiuLP5qamnDgwAHk5eVh7NixMBqNiuu2Z88elJSU9Pjr1rdvX+Tm5iquTUNDA77//nv52kycOBF1dXXYtGmTfMwXX3wBn88n//HtyRw7dgzV1dXIy8sD0LOulyiKmDt3Lt577z188cUX6Nu3r+L+SP7vTZw4Edu3b1cIws8++wzJyckYNmxY57yQTqC1a6XF1q1bAUDx3uoJ1yoUPp8PTqczPt9X7Z6i3MNYsWKFaDabxeXLl4s///yz+Ktf/UpMTU1VZIT3RP7v//5PXLdunXjo0CHx22+/FYuLi8XMzEyxoqJCFEVR/PWvfy327t1b/OKLL8Qff/xRnDhxojhx4sQYr7pzaGxsFLds2SJu2bJFBCAuXrxY3LJli3jkyBFRFEXx8ccfF1NTU8X333///9u7u5Cm3jgO4N+hnW0xeqMhKm69bFTQmyO6U2kLs6uworGLssaRSMQbrenFDIJAuqwgJcqIWNRV3kUFbTDLMGINUTLlSARCIRHLl2Hs97/48z9g68U/uDaP3w+cG5/H53l+Dxt8fTyHI8lkUo4cOSKbN2+W2dlZfYy6ujqprKyUV69eSTweF7fbLYFAIF8l5dTv9iuVSklbW5u8fPlSNE2TZ8+eicfjEbfbLXNzc/oYK2W/zp07J2vXrpVoNCqTk5P6NTMzo/f503fv+/fvsnPnTqmtrZVEIiGPHz8Wu90uHR0d+SgpZ/60V2NjY3Lp0iV5/fq1aJomfX19smXLFqmurtbHWCl7JSLS3t4usVhMNE2TZDIp7e3tYjKZ5MmTJyJSeJ8rhpslcO3aNXE4HKIoiuzfv18GBgbyvaS88/v9UlpaKoqiSHl5ufj9fhkbG9PbZ2dnpampSdavXy+rV6+W+vp6mZyczOOK/57nz58LgKyroaFBRP59HDwcDktJSYmYzWbx+Xzy7t27BWNMTU1JIBAQm80ma9askTNnzkgqlcpDNbn3u/2amZmR2tpasdvtsmrVKnE6ndLY2Jj1x8VK2a+f7RMA6e3t1fss5rs3MTEhhw8fFqvVKhs3bpTW1laZn5//y9Xk1p/26sOHD1JdXS0bNmwQs9ksLpdLzp8/L1+/fl0wzkrYKxGRYDAoTqdTFEURu90uPp9PDzYihfe5MomILP15EBEREVF+8J4bIiIiMhSGGyIiIjIUhhsiIiIyFIYbIiIiMhSGGyIiIjIUhhsiIiIyFIYbIiIiMhSGGyJaEaLRKEwmU9b7b4jIeBhuiIiIyFAYboiIiMhQGG6IqKBkMhlcuXIFLpcLZrMZDocDly9fhtfrRXNz84K+nz9/hqIo+tuI0+k0QqEQKioqYDab4XK5cOvWrV/OFY/HUVVVBavVioqKCrS0tGB6ejqn9RFR7jHcEFFB6ejoQFdXF8LhMIaHhxGJRFBSUgJVVRGJRJBOp/W+9+7dQ3l5ObxeLwDg1KlTuH//Pq5evYqRkRH09PTAZrP9dJ7x8XHU1dXh2LFjSCaTePDgAeLxeFaAIqLlhy/OJKKCkUqlYLfbcf36daiquqBtbm4OZWVl6O7uxokTJwAAe/bswdGjR3Hx4kWMjo5i27ZtePr0KQ4ePJg1djQaxYEDB/DlyxesW7cOqqqiqKgIPT09ep94PI6amhpMT0/DYrHktlgiyhme3BBRwRgZGUE6nYbP58tqs1gsOHnyJG7fvg0AePPmDYaGhnD69GkAQCKRQFFREWpqahY119u3b3Hnzh3YbDb9OnToEDKZDDRNW7KaiOjvK873AoiI/mO1Wn/brqoq9u7di48fP6K3txderxdOp3NRv/ujb9++4ezZs2hpaclqczgc/2ssIiosPLkhooLhdrthtVr1G4R/tGvXLuzbtw83b95EJBJBMBhc0JbJZBCLxRY1l8fjwfDwMFwuV9alKMqS1ENE+cFwQ0QFw2KxIBQK4cKFC7h79y7Gx8cxMDCw4IknVVXR1dUFEUF9fb3+802bNqGhoQHBYBCPHj2CpmmIRqN4+PDhT+cKhUJ48eIFmpubkUgk8P79e/T19fGGYiIDYLghooISDofR2tqKzs5O7NixA36/H58+fdLbA4EAiouLEQgEsm76vXHjBo4fP46mpiZs374djY2Nv3y0e/fu3YjFYhgdHUVVVRUqKyvR2dmJsrKynNZHRLnHp6WIaFmZmJjA1q1bMTg4CI/Hk+/lEFEBYrghomVhfn4eU1NTaGtrg6Zp6O/vz/eSiKhA8d9SRLQs9Pf3o7S0FIODg+ju7s73coiogPHkhoiIiAyFJzdERERkKAw3REREZCgMN0RERGQoDDdERERkKAw3REREZCgMN0RERGQoDDdERERkKAw3REREZCgMN0RERGQo/wB0IDtkCcJs/QAAAABJRU5ErkJggg==\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": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10110999999999999}, {'accuracy': 0.09951}, {'accuracy': 0.11253000000000002}, {'accuracy': 0.13449}, {'accuracy': 0.10023}, {'accuracy': 0.15624}, {'accuracy': 0.14559}, {'accuracy': 0.14306000000000002}, {'accuracy': 0.17595}, {'accuracy': 0.17154}, {'accuracy': 0.20947}, {'accuracy': 0.16348}, {'accuracy': 0.1782}, {'accuracy': 0.33667}, {'accuracy': 0.22796000000000002}, {'accuracy': 0.19946999999999998}, {'accuracy': 0.26328000000000007}, {'accuracy': 0.2829}, {'accuracy': 0.31472999999999995}, {'accuracy': 0.27618}, {'accuracy': 0.28063999999999995}, {'accuracy': 0.31878}, {'accuracy': 0.25475000000000003}, {'accuracy': 0.29005000000000003}, {'accuracy': 0.26443}, {'accuracy': 0.42102000000000006}, {'accuracy': 0.29927000000000004}, {'accuracy': 0.34457}, {'accuracy': 0.40231000000000006}, {'accuracy': 0.37851}, {'accuracy': 0.40237000000000006}, {'accuracy': 0.26304}, {'accuracy': 0.33242999999999995}, {'accuracy': 0.38274}, {'accuracy': 0.39115}, {'accuracy': 0.38695}, {'accuracy': 0.43366999999999994}, {'accuracy': 0.2674}, {'accuracy': 0.48042000000000007}, {'accuracy': 0.42121000000000003}, {'accuracy': 0.41667}, {'accuracy': 0.34241}, {'accuracy': 0.30175}, {'accuracy': 0.47271}, {'accuracy': 0.46792}, {'accuracy': 0.34555}, {'accuracy': 0.45241999999999993}, {'accuracy': 0.34831}, {'accuracy': 0.37052}, {'accuracy': 0.41290999999999994}, {'accuracy': 0.40858}, {'accuracy': 0.42049000000000003}, {'accuracy': 0.40792}, {'accuracy': 0.39985}, {'accuracy': 0.5014799999999999}, {'accuracy': 0.38393}, {'accuracy': 0.40885999999999995}, {'accuracy': 0.4834100000000001}, {'accuracy': 0.44916}, {'accuracy': 0.48577999999999993}, {'accuracy': 0.50841}, {'accuracy': 0.42735}, {'accuracy': 0.39988000000000007}, {'accuracy': 0.46631}, {'accuracy': 0.37543}, {'accuracy': 0.4133}, {'accuracy': 0.442}, {'accuracy': 0.4579599999999999}, {'accuracy': 0.39645}, {'accuracy': 0.4274}, {'accuracy': 0.36819}, {'accuracy': 0.40799}, {'accuracy': 0.42275}, {'accuracy': 0.4735800000000001}, {'accuracy': 0.43916000000000005}, {'accuracy': 0.4578900000000001}, {'accuracy': 0.5204500000000001}, {'accuracy': 0.44570999999999994}, {'accuracy': 0.41738}, {'accuracy': 0.44506000000000007}, {'accuracy': 0.42615}, {'accuracy': 0.45526}, {'accuracy': 0.5016499999999999}, {'accuracy': 0.47203}, {'accuracy': 0.4108899999999999}, {'accuracy': 0.40024999999999994}, {'accuracy': 0.4875299999999999}, {'accuracy': 0.5283}, {'accuracy': 0.5266500000000001}, {'accuracy': 0.4705399999999999}, {'accuracy': 0.48386000000000007}, {'accuracy': 0.45985}, {'accuracy': 0.49297}, {'accuracy': 0.46823999999999993}, {'accuracy': 0.45932000000000006}, {'accuracy': 0.38919000000000004}, {'accuracy': 0.44353}, {'accuracy': 0.4494999999999999}, {'accuracy': 0.49389000000000005}, {'accuracy': 0.4446300000000001}, {'accuracy': 0.44725000000000004}, {'accuracy': 0.47535999999999995}, {'accuracy': 0.45513999999999993}, {'accuracy': 0.46521}, {'accuracy': 0.49406999999999995}, {'accuracy': 0.5412}, {'accuracy': 0.53303}, {'accuracy': 0.49995}, {'accuracy': 0.49044999999999994}, {'accuracy': 0.5322199999999999}, {'accuracy': 0.42649}, {'accuracy': 0.44903000000000004}, {'accuracy': 0.51931}, {'accuracy': 0.4672300000000001}, {'accuracy': 0.44657}, {'accuracy': 0.48484}, {'accuracy': 0.49941}, {'accuracy': 0.54427}, {'accuracy': 0.5394400000000001}, {'accuracy': 0.46213999999999994}, {'accuracy': 0.51387}, {'accuracy': 0.47762000000000004}, {'accuracy': 0.48411}, {'accuracy': 0.5333699999999999}, {'accuracy': 0.48893000000000003}, {'accuracy': 0.49312000000000006}, {'accuracy': 0.4714499999999999}, {'accuracy': 0.5039}, {'accuracy': 0.524}, {'accuracy': 0.56689}, {'accuracy': 0.53027}, {'accuracy': 0.5203599999999999}, {'accuracy': 0.46685}, {'accuracy': 0.54139}, {'accuracy': 0.48442999999999986}, {'accuracy': 0.5794499999999999}, {'accuracy': 0.50265}, {'accuracy': 0.46159999999999995}, {'accuracy': 0.49541}, {'accuracy': 0.48462999999999995}, {'accuracy': 0.45793}, {'accuracy': 0.48503999999999997}, {'accuracy': 0.4604500000000001}, {'accuracy': 0.50642}, {'accuracy': 0.54868}, {'accuracy': 0.48129999999999995}, {'accuracy': 0.56486}, {'accuracy': 0.45120000000000005}, {'accuracy': 0.49532}, {'accuracy': 0.50539}, {'accuracy': 0.63855}, {'accuracy': 0.54789}, {'accuracy': 0.64078}, {'accuracy': 0.68672}, {'accuracy': 0.75824}, {'accuracy': 0.76537}, {'accuracy': 0.6829799999999999}, {'accuracy': 0.82928}, {'accuracy': 0.66692}, {'accuracy': 0.7402900000000001}, {'accuracy': 0.74283}, {'accuracy': 0.82745}, {'accuracy': 0.7343200000000001}, {'accuracy': 0.82948}, {'accuracy': 0.7197899999999999}, {'accuracy': 0.72276}, {'accuracy': 0.75293}, {'accuracy': 0.77525}, {'accuracy': 0.77456}, {'accuracy': 0.82295}, {'accuracy': 0.7354299999999999}, {'accuracy': 0.8265399999999999}, {'accuracy': 0.82515}, {'accuracy': 0.77973}, {'accuracy': 0.72019}, {'accuracy': 0.8279500000000001}, {'accuracy': 0.69464}, {'accuracy': 0.72351}, {'accuracy': 0.7251200000000001}, {'accuracy': 0.7716200000000001}, {'accuracy': 0.77598}, {'accuracy': 0.7804800000000001}, {'accuracy': 0.7374300000000001}, {'accuracy': 0.71431}, {'accuracy': 0.77707}, {'accuracy': 0.82664}, {'accuracy': 0.81036}, {'accuracy': 0.8153500000000001}, {'accuracy': 0.6647699999999999}, {'accuracy': 0.8109999999999999}, {'accuracy': 0.82236}, {'accuracy': 0.76668}, {'accuracy': 0.71438}, {'accuracy': 0.77263}, {'accuracy': 0.7730600000000001}, {'accuracy': 0.83339}, {'accuracy': 0.72558}, {'accuracy': 0.8253299999999999}, {'accuracy': 0.83041}, {'accuracy': 0.73533}, {'accuracy': 0.73568}, {'accuracy': 0.81652}, {'accuracy': 0.76874}, {'accuracy': 0.7721600000000001}, {'accuracy': 0.7322200000000001}, {'accuracy': 0.71265}, {'accuracy': 0.7673400000000001}, {'accuracy': 0.73587}, {'accuracy': 0.7820400000000001}, {'accuracy': 0.7853600000000001}, {'accuracy': 0.8264900000000001}, {'accuracy': 0.78198}, {'accuracy': 0.77344}, {'accuracy': 0.6236900000000001}, {'accuracy': 0.7623199999999999}, {'accuracy': 0.6666000000000001}, {'accuracy': 0.65878}, {'accuracy': 0.818}, {'accuracy': 0.8200999999999998}, {'accuracy': 0.8232800000000001}, {'accuracy': 0.8309900000000001}, {'accuracy': 0.77863}, {'accuracy': 0.732}, {'accuracy': 0.8295999999999999}, {'accuracy': 0.72215}, {'accuracy': 0.77294}, {'accuracy': 0.7576400000000001}, {'accuracy': 0.7186000000000001}, {'accuracy': 0.7220099999999999}, {'accuracy': 0.71172}, {'accuracy': 0.81573}, {'accuracy': 0.7283100000000001}, {'accuracy': 0.6571}, {'accuracy': 0.7671}, {'accuracy': 0.66123}, {'accuracy': 0.77293}, {'accuracy': 0.7799400000000001}, {'accuracy': 0.8297100000000001}, {'accuracy': 0.7252599999999999}, {'accuracy': 0.7736000000000001}, {'accuracy': 0.7805600000000001}, {'accuracy': 0.6764800000000001}, {'accuracy': 0.7616700000000001}, {'accuracy': 0.8254100000000001}, {'accuracy': 0.8236600000000001}, {'accuracy': 0.8302999999999999}, {'accuracy': 0.77996}, {'accuracy': 0.7283900000000001}, {'accuracy': 0.6808}, {'accuracy': 0.72963}, {'accuracy': 0.77382}, {'accuracy': 0.8280999999999998}, {'accuracy': 0.78136}, {'accuracy': 0.71724}, {'accuracy': 0.7306799999999999}, {'accuracy': 0.76798}, {'accuracy': 0.72942}, {'accuracy': 0.7134699999999999}, {'accuracy': 0.69207}, {'accuracy': 0.76086}, {'accuracy': 0.8106899999999999}, {'accuracy': 0.7229300000000001}, {'accuracy': 0.71417}, {'accuracy': 0.80831}, {'accuracy': 0.7735}, {'accuracy': 0.8238899999999999}, {'accuracy': 0.8243100000000002}, {'accuracy': 0.76608}, {'accuracy': 0.82359}, {'accuracy': 0.8265500000000001}, {'accuracy': 0.75829}, {'accuracy': 0.8312099999999999}, {'accuracy': 0.8251999999999999}, {'accuracy': 0.8258099999999999}, {'accuracy': 0.7954000000000001}, {'accuracy': 0.81777}, {'accuracy': 0.82681}, {'accuracy': 0.78218}, {'accuracy': 0.76014}, {'accuracy': 0.7884599999999999}, {'accuracy': 0.7727099999999999}, {'accuracy': 0.77242}, {'accuracy': 0.716}, {'accuracy': 0.7593099999999999}, {'accuracy': 0.76682}, {'accuracy': 0.7714000000000001}, {'accuracy': 0.72096}, {'accuracy': 0.76055}, {'accuracy': 0.8114699999999999}, {'accuracy': 0.8087500000000001}, {'accuracy': 0.7602400000000001}, {'accuracy': 0.77041}, {'accuracy': 0.7274099999999999}, {'accuracy': 0.76431}, {'accuracy': 0.68789}, {'accuracy': 0.77613}, {'accuracy': 0.7198300000000001}, {'accuracy': 0.72201}, {'accuracy': 0.78122}, {'accuracy': 0.7688300000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1e2c586-04af-4b7e-a788-fe249ae77fe1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "741f6832-6cce-4bb8-8aca-024c5365f8f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f977aa5a-3f11-4d35-88c5-88a68737e1d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29e0d41b-0bfb-4596-b4e9-da3eb9392bf3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eac99099-a9b0-40fb-9fd7-c4d4eabc646d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be501306-5235-41ea-8d6c-38aad8fab87f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8fb5de7c-fdf8-401a-8073-a4ec34037599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d8b8c64-7e68-4f25-bb2f-37b587e008d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6481a84a-1cf3-497e-a09a-4be3138a0c85",
   "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
}
