{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2332]\n",
      " [   1   69]\n",
      " [   2   38]\n",
      " [   3   59]\n",
      " [   4  114]\n",
      " [   5  222]\n",
      " [   6  309]\n",
      " [   7  511]\n",
      " [   8  875]\n",
      " [   9 1481]]\n",
      "[[   0 1447]\n",
      " [   1 2288]\n",
      " [   2   64]\n",
      " [   3   33]\n",
      " [   4   76]\n",
      " [   5  112]\n",
      " [   6  182]\n",
      " [   7  294]\n",
      " [   8  522]\n",
      " [   9  881]]\n",
      "[[   0  855]\n",
      " [   1 1505]\n",
      " [   2 2437]\n",
      " [   3   64]\n",
      " [   4   34]\n",
      " [   5   65]\n",
      " [   6  104]\n",
      " [   7  195]\n",
      " [   8  296]\n",
      " [   9  504]]\n",
      "[[   0  561]\n",
      " [   1  854]\n",
      " [   2 1427]\n",
      " [   3 2437]\n",
      " [   4   72]\n",
      " [   5   38]\n",
      " [   6   53]\n",
      " [   7  116]\n",
      " [   8  177]\n",
      " [   9  301]]\n",
      "[[   0  317]\n",
      " [   1  525]\n",
      " [   2  840]\n",
      " [   3 1432]\n",
      " [   4 2376]\n",
      " [   5   59]\n",
      " [   6   45]\n",
      " [   7   70]\n",
      " [   8  106]\n",
      " [   9  180]]\n",
      "[[   0  182]\n",
      " [   1  350]\n",
      " [   2  509]\n",
      " [   3  846]\n",
      " [   4 1408]\n",
      " [   5 2370]\n",
      " [   6   71]\n",
      " [   7   45]\n",
      " [   8   61]\n",
      " [   9   98]]\n",
      "[[   0  127]\n",
      " [   1  179]\n",
      " [   2  321]\n",
      " [   3  536]\n",
      " [   4  859]\n",
      " [   5 1409]\n",
      " [   6 2407]\n",
      " [   7   58]\n",
      " [   8   34]\n",
      " [   9   69]]\n",
      "[[   0   77]\n",
      " [   1  119]\n",
      " [   2  190]\n",
      " [   3  293]\n",
      " [   4  534]\n",
      " [   5  850]\n",
      " [   6 1465]\n",
      " [   7 2382]\n",
      " [   8   61]\n",
      " [   9   34]]\n",
      "[[   0   40]\n",
      " [   1   67]\n",
      " [   2  110]\n",
      " [   3  198]\n",
      " [   4  320]\n",
      " [   5  549]\n",
      " [   6  851]\n",
      " [   7 1482]\n",
      " [   8 2433]\n",
      " [   9   75]]\n",
      "[[   0   62]\n",
      " [   1   44]\n",
      " [   2   64]\n",
      " [   3  102]\n",
      " [   4  207]\n",
      " [   5  326]\n",
      " [   6  513]\n",
      " [   7  847]\n",
      " [   8 1435]\n",
      " [   9 2377]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "17992\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1637]\n",
      " [   1   52]\n",
      " [   2   31]\n",
      " [   3   39]\n",
      " [   4   78]\n",
      " [   5  150]\n",
      " [   6  211]\n",
      " [   7  350]\n",
      " [   8  626]\n",
      " [   9 1027]]\n",
      "[[   0 2378]\n",
      " [   1   63]\n",
      " [   2   45]\n",
      " [   3   66]\n",
      " [   4  120]\n",
      " [   5  214]\n",
      " [   6  299]\n",
      " [   7  516]\n",
      " [   8  886]\n",
      " [   9 1482]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "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(torch.tensor(random.randint(0,9)))\n",
    "        \n",
    "        \n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">161023-02:25:44 </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;36m161023-02:25:44\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": "00a7632ffe3b4b7183e97a93dd06ad13",
       "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\">161023-03:52:43 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3399</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-03:52:43\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3399\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\">5014021254</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;36m5014021254\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.13014}, {'accuracy': 0.18632}, {'accuracy': 0.25823999999999997}, {'accuracy': 0.31531000000000003}, {'accuracy': 0.28064999999999996}, {'accuracy': 0.365}, {'accuracy': 0.42212999999999995}, {'accuracy': 0.39542}, {'accuracy': 0.40042999999999995}, {'accuracy': 0.45851}, {'accuracy': 0.39965}, {'accuracy': 0.47094}, {'accuracy': 0.39227}, {'accuracy': 0.5098800000000001}, {'accuracy': 0.5444599999999999}, {'accuracy': 0.5134500000000001}, {'accuracy': 0.5495}, {'accuracy': 0.55574}, {'accuracy': 0.56372}, {'accuracy': 0.54966}, {'accuracy': 0.5205}, {'accuracy': 0.5091700000000001}, {'accuracy': 0.55167}, {'accuracy': 0.53327}, {'accuracy': 0.5872599999999999}, {'accuracy': 0.49307}, {'accuracy': 0.5931599999999999}, {'accuracy': 0.60358}, {'accuracy': 0.47375000000000006}, {'accuracy': 0.59261}, {'accuracy': 0.50606}, {'accuracy': 0.50655}, {'accuracy': 0.5935900000000001}, {'accuracy': 0.5096700000000001}, {'accuracy': 0.56314}, {'accuracy': 0.53148}, {'accuracy': 0.62816}, {'accuracy': 0.4298399999999999}, {'accuracy': 0.58674}, {'accuracy': 0.55537}, {'accuracy': 0.60132}, {'accuracy': 0.6157000000000001}, {'accuracy': 0.6083999999999999}, {'accuracy': 0.63071}, {'accuracy': 0.53025}, {'accuracy': 0.55383}, {'accuracy': 0.65859}, {'accuracy': 0.54403}, {'accuracy': 0.58241}, {'accuracy': 0.60045}, {'accuracy': 0.50842}, {'accuracy': 0.60224}, {'accuracy': 0.6526599999999998}, {'accuracy': 0.5217799999999999}, {'accuracy': 0.5848800000000001}, {'accuracy': 0.55724}, {'accuracy': 0.66268}, {'accuracy': 0.6489}, {'accuracy': 0.6371999999999999}, {'accuracy': 0.584}, {'accuracy': 0.6658999999999999}, {'accuracy': 0.60558}, {'accuracy': 0.6277700000000002}, {'accuracy': 0.59591}, {'accuracy': 0.61439}, {'accuracy': 0.6557999999999999}, {'accuracy': 0.59825}, {'accuracy': 0.5759999999999998}, {'accuracy': 0.5237499999999999}, {'accuracy': 0.63636}, {'accuracy': 0.6198300000000001}, {'accuracy': 0.51507}, {'accuracy': 0.62321}, {'accuracy': 0.5387500000000001}, {'accuracy': 0.59912}, {'accuracy': 0.49437}, {'accuracy': 0.56224}, {'accuracy': 0.70187}, {'accuracy': 0.5425800000000001}, {'accuracy': 0.60211}, {'accuracy': 0.54447}, {'accuracy': 0.61582}, {'accuracy': 0.575}, {'accuracy': 0.65725}, {'accuracy': 0.6073999999999999}, {'accuracy': 0.66771}, {'accuracy': 0.5831899999999999}, {'accuracy': 0.6422899999999999}, {'accuracy': 0.5184300000000001}, {'accuracy': 0.60121}, {'accuracy': 0.5458500000000001}, {'accuracy': 0.62185}, {'accuracy': 0.5186399999999999}, {'accuracy': 0.5655299999999999}, {'accuracy': 0.6046800000000001}, {'accuracy': 0.6323700000000001}, {'accuracy': 0.56328}, {'accuracy': 0.5969800000000001}, {'accuracy': 0.61474}, {'accuracy': 0.58939}, {'accuracy': 0.6162400000000001}, {'accuracy': 0.64191}, {'accuracy': 0.63809}, {'accuracy': 0.6257699999999999}, {'accuracy': 0.63717}, {'accuracy': 0.6371200000000001}, {'accuracy': 0.57369}, {'accuracy': 0.6211200000000001}, {'accuracy': 0.60111}, {'accuracy': 0.6128300000000001}, {'accuracy': 0.51717}, {'accuracy': 0.60351}, {'accuracy': 0.58436}, {'accuracy': 0.67025}, {'accuracy': 0.56167}, {'accuracy': 0.56545}, {'accuracy': 0.5980099999999999}, {'accuracy': 0.5647300000000001}, {'accuracy': 0.59075}, {'accuracy': 0.5771299999999999}, {'accuracy': 0.61101}, {'accuracy': 0.56009}, {'accuracy': 0.6175300000000001}, {'accuracy': 0.6913900000000001}, {'accuracy': 0.52391}, {'accuracy': 0.5559000000000001}, {'accuracy': 0.6898899999999999}, {'accuracy': 0.5590999999999999}, {'accuracy': 0.6239299999999999}, {'accuracy': 0.56529}, {'accuracy': 0.64737}, {'accuracy': 0.64675}, {'accuracy': 0.6009800000000001}, {'accuracy': 0.6086699999999999}, {'accuracy': 0.6060299999999998}, {'accuracy': 0.59098}, {'accuracy': 0.71688}, {'accuracy': 0.5875499999999999}, {'accuracy': 0.53869}, {'accuracy': 0.67884}, {'accuracy': 0.6519000000000001}, {'accuracy': 0.5804400000000001}, {'accuracy': 0.67221}, {'accuracy': 0.60683}, {'accuracy': 0.6694599999999999}, {'accuracy': 0.6779000000000001}, {'accuracy': 0.6845899999999999}, {'accuracy': 0.67035}, {'accuracy': 0.58029}, {'accuracy': 0.5816699999999999}, {'accuracy': 0.68114}, {'accuracy': 0.65833}, {'accuracy': 0.55229}, {'accuracy': 0.68832}, {'accuracy': 0.59207}, {'accuracy': 0.60202}, {'accuracy': 0.57041}, {'accuracy': 0.60923}, {'accuracy': 0.51662}, {'accuracy': 0.6586000000000001}, {'accuracy': 0.625}, {'accuracy': 0.5624100000000001}, {'accuracy': 0.71162}, {'accuracy': 0.6041200000000001}, {'accuracy': 0.50515}, {'accuracy': 0.68774}, {'accuracy': 0.5461599999999999}, {'accuracy': 0.55289}, {'accuracy': 0.5387099999999999}, {'accuracy': 0.5872299999999999}, {'accuracy': 0.62866}, {'accuracy': 0.59764}, {'accuracy': 0.59311}, {'accuracy': 0.59111}, {'accuracy': 0.57552}, {'accuracy': 0.7060500000000001}, {'accuracy': 0.68591}, {'accuracy': 0.65181}, {'accuracy': 0.67445}, {'accuracy': 0.57054}, {'accuracy': 0.68399}, {'accuracy': 0.67713}, {'accuracy': 0.68203}, {'accuracy': 0.55097}, {'accuracy': 0.7297399999999999}, {'accuracy': 0.67252}, {'accuracy': 0.61448}, {'accuracy': 0.64727}, {'accuracy': 0.6251}, {'accuracy': 0.67101}, {'accuracy': 0.5333500000000001}, {'accuracy': 0.71004}, {'accuracy': 0.6096800000000001}, {'accuracy': 0.5703}, {'accuracy': 0.5657}, {'accuracy': 0.53989}, {'accuracy': 0.5954699999999999}, {'accuracy': 0.5567000000000001}, {'accuracy': 0.63561}, {'accuracy': 0.71492}, {'accuracy': 0.66373}, {'accuracy': 0.75499}, {'accuracy': 0.77013}, {'accuracy': 0.8466099999999999}, {'accuracy': 0.7674899999999999}, {'accuracy': 0.84559}, {'accuracy': 0.8454200000000001}, {'accuracy': 0.84784}, {'accuracy': 0.84777}, {'accuracy': 0.84884}, {'accuracy': 0.8477499999999999}, {'accuracy': 0.85038}, {'accuracy': 0.8475400000000001}, {'accuracy': 0.8502700000000001}, {'accuracy': 0.8494200000000001}, {'accuracy': 0.84615}, {'accuracy': 0.84846}, {'accuracy': 0.8491099999999999}, {'accuracy': 0.84841}, {'accuracy': 0.8489300000000002}, {'accuracy': 0.85031}, {'accuracy': 0.84895}, {'accuracy': 0.8474299999999999}, {'accuracy': 0.84684}, {'accuracy': 0.8483499999999999}, {'accuracy': 0.8494999999999999}, {'accuracy': 0.8447700000000001}, {'accuracy': 0.84799}, {'accuracy': 0.8478999999999999}, {'accuracy': 0.85006}, {'accuracy': 0.8489699999999999}, {'accuracy': 0.8475299999999999}, {'accuracy': 0.8484200000000002}, {'accuracy': 0.84792}, {'accuracy': 0.84823}, {'accuracy': 0.8487500000000001}, {'accuracy': 0.84955}, {'accuracy': 0.84909}, {'accuracy': 0.84742}, {'accuracy': 0.8488900000000001}, {'accuracy': 0.85016}, {'accuracy': 0.84996}, {'accuracy': 0.84691}, {'accuracy': 0.8487399999999999}, {'accuracy': 0.84894}, {'accuracy': 0.8463799999999999}, {'accuracy': 0.8478}, {'accuracy': 0.8491500000000001}, {'accuracy': 0.8488100000000001}, {'accuracy': 0.84633}, {'accuracy': 0.84791}, {'accuracy': 0.8491299999999999}, {'accuracy': 0.8491199999999999}, {'accuracy': 0.84794}, {'accuracy': 0.8468499999999999}, {'accuracy': 0.8489299999999999}, {'accuracy': 0.84901}, {'accuracy': 0.8488000000000001}, {'accuracy': 0.8455999999999999}, {'accuracy': 0.85147}, {'accuracy': 0.85077}, {'accuracy': 0.8457700000000001}, {'accuracy': 0.84999}, {'accuracy': 0.8476199999999998}, {'accuracy': 0.85023}, {'accuracy': 0.8469999999999999}, {'accuracy': 0.8475100000000001}, {'accuracy': 0.8510899999999999}, {'accuracy': 0.84809}, {'accuracy': 0.8501000000000001}, {'accuracy': 0.84931}, {'accuracy': 0.8501799999999999}, {'accuracy': 0.8489000000000001}, {'accuracy': 0.8481}, {'accuracy': 0.84947}, {'accuracy': 0.84975}, {'accuracy': 0.84871}, {'accuracy': 0.8473899999999999}, {'accuracy': 0.8463200000000001}, {'accuracy': 0.8477500000000001}, {'accuracy': 0.84765}, {'accuracy': 0.85082}, {'accuracy': 0.8495800000000001}, {'accuracy': 0.84823}, {'accuracy': 0.84805}, {'accuracy': 0.8495700000000002}, {'accuracy': 0.8505100000000001}, {'accuracy': 0.84426}, {'accuracy': 0.8490800000000001}, {'accuracy': 0.8479999999999999}, {'accuracy': 0.8491799999999999}, {'accuracy': 0.8494400000000001}, {'accuracy': 0.84799}, {'accuracy': 0.84795}, {'accuracy': 0.8479299999999999}, {'accuracy': 0.8487499999999999}, {'accuracy': 0.84846}, {'accuracy': 0.8485099999999999}, {'accuracy': 0.8475300000000001}, {'accuracy': 0.84993}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.85</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.85\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACWQ0lEQVR4nO3deXwTdfoH8E/u9C69OQoFCihyCSyIirhQwftWlnUFUfDEC3WVnwoeq3gvrhfqqqirgrrqeuKBgMohlwjIfV+9oPRuc87vj2QmM5NJmtCkadPP+/Xqy5JMkm+msfP0eZ7v96sTBEEAERERUZzQx3oARERERJHE4IaIiIjiCoMbIiIiiisMboiIiCiuMLghIiKiuMLghoiIiOIKgxsiIiKKKwxuiIiIKK4wuCEiIqK4wuCGiKJqyZIl0Ol0WLJkiXTbNddcg4KCgpiNKZ489NBD0Ol0sR4GUavC4Iaolfvjjz/wt7/9DZ07d4bFYkGnTp1w1VVX4Y8//oj10KLu5Zdfxrx586L6Gps3b8ZDDz2EvXv3RvV1WtLjjz+Ozz77LNbDIIoZBjdErdgnn3yCwYMHY9GiRZg8eTJefvllXHfddVi8eDEGDx6MTz/9NNZDjKqWCm4efvhhBjdEccQY6wEQkbZdu3bh6quvRo8ePfDTTz8hOztbuu/222/HyJEjcfXVV2PDhg3o0aNHi42rrq4OSUlJLfZ6bQHPCVHrwswNUSv19NNPo76+Hq+99poisAGArKwsvPrqq6irq8NTTz0FAPj444+h0+mwdOlSv+d69dVXodPpsGnTJum2rVu34vLLL0dGRgasViuGDh2Kzz//XPG4efPmSc958803IycnB126dAEA7Nu3DzfffDP69OmDhIQEZGZm4oorrohYBqSgoAB//PEHli5dCp1OB51OhzPPPFO6v7KyEnfccQfy8/NhsVhQWFiIJ598Em63W/E88+fPx5AhQ5CSkoLU1FT0798fzz//vPT+rrjiCgDAn//8Z+l15P1Batdccw2Sk5Oxa9cunHvuuUhJScFVV10FAHC73ZgzZw5OOukkWK1W5Obm4oYbbsCxY8cUz7FmzRqMGzcOWVlZSEhIQPfu3XHttddK92v1KQHA3r17odPpgmazdDod6urq8Pbbb0vv55prrgEA1NTU4I477kBBQQEsFgtycnJw1llnYd26dQGfj6gtYuaGqJX64osvUFBQgJEjR2ref8YZZ6CgoABfffUVAOC8885DcnIyPvzwQ4waNUpx7IIFC3DSSSehX79+ADx9PKeddho6d+6M++67D0lJSfjwww9x8cUX47///S8uueQSxeNvvvlmZGdnY+bMmairqwMArF69GsuXL8df/vIXdOnSBXv37sUrr7yCM888E5s3b0ZiYmKz3v+cOXNw6623Ijk5Gffffz8AIDc3FwBQX1+PUaNG4dChQ7jhhhvQtWtXLF++HDNmzEBxcTHmzJkDAPj+++8xYcIEjBkzBk8++SQAYMuWLVi2bBluv/12nHHGGbjtttvwr3/9C//3f/+HE088EQCk/wbidDoxbtw4nH766XjmmWek93rDDTdg3rx5mDx5Mm677Tbs2bMHL774In777TcsW7YMJpMJZWVlGDt2LLKzs3HfffchPT0de/fuxSeffNKs8yV69913MWXKFAwbNgzXX389AKBnz54AgBtvvBEff/wxpk2bhr59++Lo0aP45ZdfsGXLFgwePDgir0/UKghE1OpUVlYKAISLLroo6HEXXnihAECorq4WBEEQJkyYIOTk5AhOp1M6pri4WNDr9cIjjzwi3TZmzBihf//+QmNjo3Sb2+0WTj31VKFXr17SbW+99ZYAQDj99NMVzykIglBfX+83nhUrVggAhHfeeUe6bfHixQIAYfHixdJtkyZNErp16xb0vQmCIJx00knCqFGj/G5/9NFHhaSkJGH79u2K2++77z7BYDAI+/fvFwRBEG6//XYhNTXVb+xyH330kd/4gpk0aZIAQLjvvvsUt//8888CAOG9995T3L5w4ULF7Z9++qkAQFi9enXA19A6Z4IgCHv27BEACG+99ZZ026xZswT1r/KkpCRh0qRJfs+blpYm3HLLLSG8S6K2jWUpolaopqYGAJCSkhL0OPH+6upqAMD48eNRVlamKGd8/PHHcLvdGD9+PACgoqICP/74I6688krU1NTgyJEjOHLkCI4ePYpx48Zhx44dOHTokOJ1pk6dCoPBoLgtISFB+t7hcODo0aMoLCxEenp61MscH330EUaOHIkOHTpI4z9y5AiKiorgcrnw008/AQDS09NRV1eH77//PuJjuOmmm/zGlJaWhrPOOksxpiFDhiA5ORmLFy+WxgQAX375JRwOR8THFUx6ejp+/fVXHD58uEVf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CAsXLpSajPfv36+Y73748GGcfPLJ0r+feeYZPPPMMxg1ahSWLFkS0mvq9Xp06dIlou9DlJqayg9+GHi+QsdzFR6er9DxXIWO5yo80ThfTWVsRDFfoXjatGkBy1DqgKWgoIAbohEREVFQcT9bioiIiNoXBjcRYLFYMGvWLMWsLAqM5yt0PFfh4fkKHc9V6HiuwtMazldMt18gIiIiijRmboiIiCiuMLghIiKiuMLghoiIiOIKgxsiIiKKKwxuIuCll15CQUEBrFYrhg8fjlWrVsV6SDH30EMPQafTKb5OOOEE6f7GxkbccsstyMzMRHJyMi677DK/fcbi1U8//YQLLrgAnTp1gk6nw2effaa4XxAEzJw5Ex07dkRCQgKKioqwY8cOxTEVFRW46qqrkJqaivT0dFx33XWora1twXfRcpo6X9dcc43fZ+3ss89WHNNeztfs2bPxpz/9CSkpKcjJycHFF1+Mbdu2KY4J5f+9/fv347zzzkNiYiJycnJwzz33wOl0tuRbibpQztWZZ57p99m68cYbFce0h3MFAK+88goGDBggLcw3YsQIfPPNN9L9re1zxeCmmRYsWIDp06dj1qxZWLduHQYOHIhx48ahrKws1kOLuZNOOgnFxcXS1y+//CLdd+edd+KLL77ARx99hKVLl+Lw4cO49NJLYzjallNXV4eBAwfipZde0rz/qaeewr/+9S/MnTsXv/76K5KSkjBu3Dg0NjZKx1x11VX4448/8P333+PLL7/ETz/9hOuvv76l3kKLaup8AcDZZ5+t+Kx98MEHivvby/launQpbrnlFqxcuRLff/89HA4Hxo4di7q6OumYpv7fc7lcOO+882C327F8+XK8/fbbmDdvHmbOnBmLtxQ1oZwrAJg6daris/XUU09J97WXcwUAXbp0wRNPPIG1a9dizZo1GD16NC666CL88ccfAFrh50qgZhk2bJhwyy23SP92uVxCp06dhNmzZ8dwVLE3a9YsYeDAgZr3VVZWCiaTSfjoo4+k27Zs2SIAEFasWNFCI2wdAAiffvqp9G+32y3k5eUJTz/9tHRbZWWlYLFYhA8++EAQBEHYvHmzAEBYvXq1dMw333wj6HQ64dChQy029lhQny9BEIRJkyYJF110UcDHtOfzVVZWJgAQli5dKghCaP/vff3114JerxdKSkqkY1555RUhNTVVsNlsLfsGWpD6XAmCIIwaNUq4/fbbAz6mvZ4rUYcOHYR///vfrfJzxcxNM9jtdqxduxZFRUXSbXq9HkVFRVixYkUMR9Y67NixA506dUKPHj1w1VVXYf/+/QCAtWvXwuFwKM7bCSecgK5du7b787Znzx6UlJQozk1aWhqGDx8unZsVK1YgPT0dQ4cOlY4pKiqCXq/Hr7/+2uJjbg2WLFmCnJwc9OnTBzfddBOOHj0q3deez1dVVRUAICMjA0Bo/++tWLEC/fv3l/b4A4Bx48ahurpa+is9HqnPlei9995DVlYW+vXrhxkzZqC+vl66r72eK5fLhfnz56Ourg4jRoxolZ+rmO8t1ZYdOXIELpdL8cMCgNzcXGzdujVGo2odhg8fjnnz5qFPnz4oLi7Gww8/jJEjR2LTpk0oKSmB2WxGenq64jG5ubkoKSmJzYBbCfH9a32mxPtKSkqQk5OjuN9oNCIjI6Ndnr+zzz4bl156Kbp3745du3bh//7v/3DOOedgxYoVMBgM7fZ8ud1u3HHHHTjttNPQr18/AAjp/72SkhLNz594XzzSOlcA8Ne//hXdunVDp06dsGHDBtx7773Ytm0bPvnkEwDt71xt3LgRI0aMQGNjI5KTk/Hpp5+ib9++WL9+fav7XDG4oag455xzpO8HDBiA4cOHo1u3bvjwww+RkJAQw5FRvPnLX/4ifd+/f38MGDAAPXv2xJIlSzBmzJgYjiy2brnlFmzatEnR60baAp0reV9W//790bFjR4wZMwa7du1Cz549W3qYMdenTx+sX78eVVVV+PjjjzFp0iQsXbo01sPSxLJUM2RlZcFgMPh1hJeWliIvLy9Go2qd0tPT0bt3b+zcuRN5eXmw2+2orKxUHMPzBun9B/tM5eXl+TWsO51OVFRUtPvzBwA9evRAVlYWdu7cCaB9nq9p06bhyy+/xOLFi9GlSxfp9lD+38vLy9P8/In3xZtA50rL8OHDAUDx2WpP58psNqOwsBBDhgzB7NmzMXDgQDz//POt8nPF4KYZzGYzhgwZgkWLFkm3ud1uLFq0CCNGjIjhyFqf2tpa7Nq1Cx07dsSQIUNgMpkU523btm3Yv39/uz9v3bt3R15enuLcVFdX49dff5XOzYgRI1BZWYm1a9dKx/z4449wu93SL9/27ODBgzh69Cg6duwIoH2dL0EQMG3aNHz66af48ccf0b17d8X9ofy/N2LECGzcuFEREH7//fdITU1F3759W+aNtICmzpWW9evXA4Dis9UezlUgbrcbNputdX6uIt6i3M7Mnz9fsFgswrx584TNmzcL119/vZCenq7oCG+P7rrrLmHJkiXCnj17hGXLlglFRUVCVlaWUFZWJgiCINx4441C165dhR9//FFYs2aNMGLECGHEiBExHnXLqKmpEX777Tfht99+EwAIzz33nPDbb78J+/btEwRBEJ544gkhPT1d+N///ids2LBBuOiii4Tu3bsLDQ0N0nOcffbZwsknnyz8+uuvwi+//CL06tVLmDBhQqzeUlQFO181NTXC3XffLaxYsULYs2eP8MMPPwiDBw8WevXqJTQ2NkrP0V7O10033SSkpaUJS5YsEYqLi6Wv+vp66Zim/t9zOp1Cv379hLFjxwrr168XFi5cKGRnZwszZsyIxVuKmqbO1c6dO4VHHnlEWLNmjbBnzx7hf//7n9CjRw/hjDPOkJ6jvZwrQRCE++67T1i6dKmwZ88eYcOGDcJ9990n6HQ64bvvvhMEofV9rhjcRMALL7wgdO3aVTCbzcKwYcOElStXxnpIMTd+/HihY8eOgtlsFjp37iyMHz9e2Llzp3R/Q0ODcPPNNwsdOnQQEhMThUsuuUQoLi6O4YhbzuLFiwUAfl+TJk0SBMEzHfzBBx8UcnNzBYvFIowZM0bYtm2b4jmOHj0qTJgwQUhOThZSU1OFyZMnCzU1NTF4N9EX7HzV19cLY8eOFbKzswWTySR069ZNmDp1qt8fF+3lfGmdJwDCW2+9JR0Tyv97e/fuFc455xwhISFByMrKEu666y7B4XC08LuJrqbO1f79+4UzzjhDyMjIECwWi1BYWCjcc889QlVVleJ52sO5EgRBuPbaa4Vu3boJZrNZyM7OFsaMGSMFNoLQ+j5XOkEQhMjng4iIiIhigz03REREFFcY3BAREVFcYXBDREREcYXBDREREcUVBjdEREQUVxjcEBERUVxhcENERERxhcENEbULS5YsgU6n89v/hojiD4MbIiIiiisMboiIiCiuMLgholbF7XbjqaeeQmFhISwWC7p27YrHHnsMo0ePxrRp0xTHlpeXw2w2S7sR22w23HvvvcjPz4fFYkFhYSHeeOONgK/1yy+/YOTIkUhISEB+fj5uu+021NXVRfX9EVH0MbgholZlxowZeOKJJ/Dggw9i8+bNeP/995Gbm4spU6bg/fffh81mk479z3/+g86dO2P06NEAgIkTJ+KDDz7Av/71L2zZsgWvvvoqkpOTNV9n165dOPvss3HZZZdhw4YNWLBgAX755Re/AIqI2h5unElErUZNTQ2ys7Px4osvYsqUKYr7Ghsb0alTJ8ydOxdXXnklAGDgwIG49NJLMWvWLGzfvh19+vTB999/j6KiIr/nXrJkCf785z/j2LFjSE9Px5QpU2AwGPDqq69Kx/zyyy8YNWoU6urqYLVao/tmiShqmLkholZjy5YtsNlsGDNmjN99VqsVV199Nd58800AwLp167Bp0yZcc801AID169fDYDBg1KhRIb3W77//jnnz5iE5OVn6GjduHNxuN/bs2ROx90RELc8Y6wEQEYkSEhKC3j9lyhQMGjQIBw8exFtvvYXRo0ejW7duIT1Wrba2FjfccANuu+02v/u6du0a1nMRUevCzA0RtRq9evVCQkKC1CCs1r9/fwwdOhSvv/463n//fVx77bWK+9xuN5YuXRrSaw0ePBibN29GYWGh35fZbI7I+yGi2GBwQ0SthtVqxb333ou///3veOedd7Br1y6sXLlSMeNpypQpeOKJJyAIAi655BLp9oKCAkyaNAnXXnstPvvsM+zZswdLlizBhx9+qPla9957L5YvX45p06Zh/fr12LFjB/73v/+xoZgoDjC4IaJW5cEHH8Rdd92FmTNn4sQTT8T48eNRVlYm3T9hwgQYjUZMmDDBr+n3lVdeweWXX46bb74ZJ5xwAqZOnRpwaveAAQOwdOlSbN++HSNHjsTJJ5+MmTNnolOnTlF9f0QUfZwtRURtyt69e9GzZ0+sXr0agwcPjvVwiKgVYnBDRG2Cw+HA0aNHcffdd2PPnj1YtmxZrIdERK0Uy1JE1CYsW7YMHTt2xOrVqzF37txYD4eIWjFmboiIiCiuMHNDREREcYXBDREREcUVBjdEREQUVxjcEBERUVxhcENERERxhcENERERxRUGN0RERBRXGNwQERFRXGFwQ0RERHHl/wE88FKlfiAP+gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.13014}, {'accuracy': 0.18632}, {'accuracy': 0.25823999999999997}, {'accuracy': 0.31531000000000003}, {'accuracy': 0.28064999999999996}, {'accuracy': 0.365}, {'accuracy': 0.42212999999999995}, {'accuracy': 0.39542}, {'accuracy': 0.40042999999999995}, {'accuracy': 0.45851}, {'accuracy': 0.39965}, {'accuracy': 0.47094}, {'accuracy': 0.39227}, {'accuracy': 0.5098800000000001}, {'accuracy': 0.5444599999999999}, {'accuracy': 0.5134500000000001}, {'accuracy': 0.5495}, {'accuracy': 0.55574}, {'accuracy': 0.56372}, {'accuracy': 0.54966}, {'accuracy': 0.5205}, {'accuracy': 0.5091700000000001}, {'accuracy': 0.55167}, {'accuracy': 0.53327}, {'accuracy': 0.5872599999999999}, {'accuracy': 0.49307}, {'accuracy': 0.5931599999999999}, {'accuracy': 0.60358}, {'accuracy': 0.47375000000000006}, {'accuracy': 0.59261}, {'accuracy': 0.50606}, {'accuracy': 0.50655}, {'accuracy': 0.5935900000000001}, {'accuracy': 0.5096700000000001}, {'accuracy': 0.56314}, {'accuracy': 0.53148}, {'accuracy': 0.62816}, {'accuracy': 0.4298399999999999}, {'accuracy': 0.58674}, {'accuracy': 0.55537}, {'accuracy': 0.60132}, {'accuracy': 0.6157000000000001}, {'accuracy': 0.6083999999999999}, {'accuracy': 0.63071}, {'accuracy': 0.53025}, {'accuracy': 0.55383}, {'accuracy': 0.65859}, {'accuracy': 0.54403}, {'accuracy': 0.58241}, {'accuracy': 0.60045}, {'accuracy': 0.50842}, {'accuracy': 0.60224}, {'accuracy': 0.6526599999999998}, {'accuracy': 0.5217799999999999}, {'accuracy': 0.5848800000000001}, {'accuracy': 0.55724}, {'accuracy': 0.66268}, {'accuracy': 0.6489}, {'accuracy': 0.6371999999999999}, {'accuracy': 0.584}, {'accuracy': 0.6658999999999999}, {'accuracy': 0.60558}, {'accuracy': 0.6277700000000002}, {'accuracy': 0.59591}, {'accuracy': 0.61439}, {'accuracy': 0.6557999999999999}, {'accuracy': 0.59825}, {'accuracy': 0.5759999999999998}, {'accuracy': 0.5237499999999999}, {'accuracy': 0.63636}, {'accuracy': 0.6198300000000001}, {'accuracy': 0.51507}, {'accuracy': 0.62321}, {'accuracy': 0.5387500000000001}, {'accuracy': 0.59912}, {'accuracy': 0.49437}, {'accuracy': 0.56224}, {'accuracy': 0.70187}, {'accuracy': 0.5425800000000001}, {'accuracy': 0.60211}, {'accuracy': 0.54447}, {'accuracy': 0.61582}, {'accuracy': 0.575}, {'accuracy': 0.65725}, {'accuracy': 0.6073999999999999}, {'accuracy': 0.66771}, {'accuracy': 0.5831899999999999}, {'accuracy': 0.6422899999999999}, {'accuracy': 0.5184300000000001}, {'accuracy': 0.60121}, {'accuracy': 0.5458500000000001}, {'accuracy': 0.62185}, {'accuracy': 0.5186399999999999}, {'accuracy': 0.5655299999999999}, {'accuracy': 0.6046800000000001}, {'accuracy': 0.6323700000000001}, {'accuracy': 0.56328}, {'accuracy': 0.5969800000000001}, {'accuracy': 0.61474}, {'accuracy': 0.58939}, {'accuracy': 0.6162400000000001}, {'accuracy': 0.64191}, {'accuracy': 0.63809}, {'accuracy': 0.6257699999999999}, {'accuracy': 0.63717}, {'accuracy': 0.6371200000000001}, {'accuracy': 0.57369}, {'accuracy': 0.6211200000000001}, {'accuracy': 0.60111}, {'accuracy': 0.6128300000000001}, {'accuracy': 0.51717}, {'accuracy': 0.60351}, {'accuracy': 0.58436}, {'accuracy': 0.67025}, {'accuracy': 0.56167}, {'accuracy': 0.56545}, {'accuracy': 0.5980099999999999}, {'accuracy': 0.5647300000000001}, {'accuracy': 0.59075}, {'accuracy': 0.5771299999999999}, {'accuracy': 0.61101}, {'accuracy': 0.56009}, {'accuracy': 0.6175300000000001}, {'accuracy': 0.6913900000000001}, {'accuracy': 0.52391}, {'accuracy': 0.5559000000000001}, {'accuracy': 0.6898899999999999}, {'accuracy': 0.5590999999999999}, {'accuracy': 0.6239299999999999}, {'accuracy': 0.56529}, {'accuracy': 0.64737}, {'accuracy': 0.64675}, {'accuracy': 0.6009800000000001}, {'accuracy': 0.6086699999999999}, {'accuracy': 0.6060299999999998}, {'accuracy': 0.59098}, {'accuracy': 0.71688}, {'accuracy': 0.5875499999999999}, {'accuracy': 0.53869}, {'accuracy': 0.67884}, {'accuracy': 0.6519000000000001}, {'accuracy': 0.5804400000000001}, {'accuracy': 0.67221}, {'accuracy': 0.60683}, {'accuracy': 0.6694599999999999}, {'accuracy': 0.6779000000000001}, {'accuracy': 0.6845899999999999}, {'accuracy': 0.67035}, {'accuracy': 0.58029}, {'accuracy': 0.5816699999999999}, {'accuracy': 0.68114}, {'accuracy': 0.65833}, {'accuracy': 0.55229}, {'accuracy': 0.68832}, {'accuracy': 0.59207}, {'accuracy': 0.60202}, {'accuracy': 0.57041}, {'accuracy': 0.60923}, {'accuracy': 0.51662}, {'accuracy': 0.6586000000000001}, {'accuracy': 0.625}, {'accuracy': 0.5624100000000001}, {'accuracy': 0.71162}, {'accuracy': 0.6041200000000001}, {'accuracy': 0.50515}, {'accuracy': 0.68774}, {'accuracy': 0.5461599999999999}, {'accuracy': 0.55289}, {'accuracy': 0.5387099999999999}, {'accuracy': 0.5872299999999999}, {'accuracy': 0.62866}, {'accuracy': 0.59764}, {'accuracy': 0.59311}, {'accuracy': 0.59111}, {'accuracy': 0.57552}, {'accuracy': 0.7060500000000001}, {'accuracy': 0.68591}, {'accuracy': 0.65181}, {'accuracy': 0.67445}, {'accuracy': 0.57054}, {'accuracy': 0.68399}, {'accuracy': 0.67713}, {'accuracy': 0.68203}, {'accuracy': 0.55097}, {'accuracy': 0.7297399999999999}, {'accuracy': 0.67252}, {'accuracy': 0.61448}, {'accuracy': 0.64727}, {'accuracy': 0.6251}, {'accuracy': 0.67101}, {'accuracy': 0.5333500000000001}, {'accuracy': 0.71004}, {'accuracy': 0.6096800000000001}, {'accuracy': 0.5703}, {'accuracy': 0.5657}, {'accuracy': 0.53989}, {'accuracy': 0.5954699999999999}, {'accuracy': 0.5567000000000001}, {'accuracy': 0.63561}, {'accuracy': 0.71492}, {'accuracy': 0.66373}, {'accuracy': 0.75499}, {'accuracy': 0.77013}, {'accuracy': 0.8466099999999999}, {'accuracy': 0.7674899999999999}, {'accuracy': 0.84559}, {'accuracy': 0.8454200000000001}, {'accuracy': 0.84784}, {'accuracy': 0.84777}, {'accuracy': 0.84884}, {'accuracy': 0.8477499999999999}, {'accuracy': 0.85038}, {'accuracy': 0.8475400000000001}, {'accuracy': 0.8502700000000001}, {'accuracy': 0.8494200000000001}, {'accuracy': 0.84615}, {'accuracy': 0.84846}, {'accuracy': 0.8491099999999999}, {'accuracy': 0.84841}, {'accuracy': 0.8489300000000002}, {'accuracy': 0.85031}, {'accuracy': 0.84895}, {'accuracy': 0.8474299999999999}, {'accuracy': 0.84684}, {'accuracy': 0.8483499999999999}, {'accuracy': 0.8494999999999999}, {'accuracy': 0.8447700000000001}, {'accuracy': 0.84799}, {'accuracy': 0.8478999999999999}, {'accuracy': 0.85006}, {'accuracy': 0.8489699999999999}, {'accuracy': 0.8475299999999999}, {'accuracy': 0.8484200000000002}, {'accuracy': 0.84792}, {'accuracy': 0.84823}, {'accuracy': 0.8487500000000001}, {'accuracy': 0.84955}, {'accuracy': 0.84909}, {'accuracy': 0.84742}, {'accuracy': 0.8488900000000001}, {'accuracy': 0.85016}, {'accuracy': 0.84996}, {'accuracy': 0.84691}, {'accuracy': 0.8487399999999999}, {'accuracy': 0.84894}, {'accuracy': 0.8463799999999999}, {'accuracy': 0.8478}, {'accuracy': 0.8491500000000001}, {'accuracy': 0.8488100000000001}, {'accuracy': 0.84633}, {'accuracy': 0.84791}, {'accuracy': 0.8491299999999999}, {'accuracy': 0.8491199999999999}, {'accuracy': 0.84794}, {'accuracy': 0.8468499999999999}, {'accuracy': 0.8489299999999999}, {'accuracy': 0.84901}, {'accuracy': 0.8488000000000001}, {'accuracy': 0.8455999999999999}, {'accuracy': 0.85147}, {'accuracy': 0.85077}, {'accuracy': 0.8457700000000001}, {'accuracy': 0.84999}, {'accuracy': 0.8476199999999998}, {'accuracy': 0.85023}, {'accuracy': 0.8469999999999999}, {'accuracy': 0.8475100000000001}, {'accuracy': 0.8510899999999999}, {'accuracy': 0.84809}, {'accuracy': 0.8501000000000001}, {'accuracy': 0.84931}, {'accuracy': 0.8501799999999999}, {'accuracy': 0.8489000000000001}, {'accuracy': 0.8481}, {'accuracy': 0.84947}, {'accuracy': 0.84975}, {'accuracy': 0.84871}, {'accuracy': 0.8473899999999999}, {'accuracy': 0.8463200000000001}, {'accuracy': 0.8477500000000001}, {'accuracy': 0.84765}, {'accuracy': 0.85082}, {'accuracy': 0.8495800000000001}, {'accuracy': 0.84823}, {'accuracy': 0.84805}, {'accuracy': 0.8495700000000002}, {'accuracy': 0.8505100000000001}, {'accuracy': 0.84426}, {'accuracy': 0.8490800000000001}, {'accuracy': 0.8479999999999999}, {'accuracy': 0.8491799999999999}, {'accuracy': 0.8494400000000001}, {'accuracy': 0.84799}, {'accuracy': 0.84795}, {'accuracy': 0.8479299999999999}, {'accuracy': 0.8487499999999999}, {'accuracy': 0.84846}, {'accuracy': 0.8485099999999999}, {'accuracy': 0.8475300000000001}, {'accuracy': 0.84993}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aacc875-f5ef-40fe-b554-f4a24df054f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90eafb39-6280-49cf-8bc3-488f7848cfec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1990245d-61be-446e-aa86-81f09d52454f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7de073ae-f238-42b4-b966-70f821f18891",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5f4f110-4d3c-453d-94cb-14ba9315f58a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "100da884-0287-4750-ba40-24d3e5c18670",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d9fd195-69a4-4613-8f56-7a7ace4d1d52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7e9071e-47a9-46bf-a6ba-a36446b3dc9b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57cc8ef4-1fae-4a80-8590-793f6b87f77f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "088a411f-42b8-4a17-a2e5-8ec36d28d15f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d18eeee8-ff56-435a-9587-1ead6c43f434",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0cca6ffa-2e32-41a6-a949-b2ec9f6f1b1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440c827c-c5df-4170-8ae1-c2542168d8a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac6c83fc-df18-4c5e-ac05-5eb3856b7da9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c019db7-d79b-4a2d-880a-c74837d5b356",
   "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
}
