{
 "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 2412]\n",
      " [   1   47]\n",
      " [   2   45]\n",
      " [   3   46]\n",
      " [   4  101]\n",
      " [   5  201]\n",
      " [   6  341]\n",
      " [   7  530]\n",
      " [   8  891]\n",
      " [   9 1456]]\n",
      "[[   0 1368]\n",
      " [   1 2401]\n",
      " [   2   71]\n",
      " [   3   43]\n",
      " [   4   62]\n",
      " [   5  117]\n",
      " [   6  198]\n",
      " [   7  293]\n",
      " [   8  513]\n",
      " [   9  851]]\n",
      "[[   0  885]\n",
      " [   1 1486]\n",
      " [   2 2391]\n",
      " [   3   55]\n",
      " [   4   49]\n",
      " [   5   70]\n",
      " [   6  122]\n",
      " [   7  195]\n",
      " [   8  335]\n",
      " [   9  470]]\n",
      "[[   0  514]\n",
      " [   1  858]\n",
      " [   2 1432]\n",
      " [   3 2357]\n",
      " [   4   89]\n",
      " [   5   32]\n",
      " [   6   57]\n",
      " [   7  126]\n",
      " [   8  191]\n",
      " [   9  319]]\n",
      "[[   0  300]\n",
      " [   1  532]\n",
      " [   2  873]\n",
      " [   3 1476]\n",
      " [   4 2360]\n",
      " [   5   56]\n",
      " [   6   39]\n",
      " [   7   63]\n",
      " [   8  102]\n",
      " [   9  153]]\n",
      "[[   0  202]\n",
      " [   1  302]\n",
      " [   2  520]\n",
      " [   3  886]\n",
      " [   4 1454]\n",
      " [   5 2398]\n",
      " [   6   58]\n",
      " [   7   40]\n",
      " [   8   83]\n",
      " [   9  130]]\n",
      "[[   0  142]\n",
      " [   1  187]\n",
      " [   2  324]\n",
      " [   3  518]\n",
      " [   4  892]\n",
      " [   5 1454]\n",
      " [   6 2363]\n",
      " [   7   64]\n",
      " [   8   36]\n",
      " [   9   86]]\n",
      "[[   0   76]\n",
      " [   1   89]\n",
      " [   2  169]\n",
      " [   3  313]\n",
      " [   4  517]\n",
      " [   5  835]\n",
      " [   6 1425]\n",
      " [   7 2394]\n",
      " [   8   51]\n",
      " [   9   46]]\n",
      "[[   0   46]\n",
      " [   1   62]\n",
      " [   2  127]\n",
      " [   3  189]\n",
      " [   4  316]\n",
      " [   5  533]\n",
      " [   6  875]\n",
      " [   7 1420]\n",
      " [   8 2379]\n",
      " [   9   70]]\n",
      "[[   0   55]\n",
      " [   1   36]\n",
      " [   2   48]\n",
      " [   3  117]\n",
      " [   4  160]\n",
      " [   5  304]\n",
      " [   6  522]\n",
      " [   7  875]\n",
      " [   8 1419]\n",
      " [   9 2419]]\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": [
      "30041\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1229]\n",
      " [   1   19]\n",
      " [   2   24]\n",
      " [   3   23]\n",
      " [   4   47]\n",
      " [   5   93]\n",
      " [   6  174]\n",
      " [   7  237]\n",
      " [   8  440]\n",
      " [   9  710]]\n",
      "[[   0 2458]\n",
      " [   1   51]\n",
      " [   2   45]\n",
      " [   3   51]\n",
      " [   4   89]\n",
      " [   5  179]\n",
      " [   6  314]\n",
      " [   7  520]\n",
      " [   8  895]\n",
      " [   9 1443]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 4, 2, 3])"
      ]
     },
     "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<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",
    "        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,  ..., 4, 2, 3])"
      ]
     },
     "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": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">161023-02:26:36 </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:26:36\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": "ee588fa7a2f24da0899f21492ce4d3c8",
       "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:31 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3334</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-03:52:31\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3334\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\">4918136764</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;36m4918136764\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.16491000000000003}, {'accuracy': 0.21276}, {'accuracy': 0.23723}, {'accuracy': 0.22917}, {'accuracy': 0.27781}, {'accuracy': 0.27066}, {'accuracy': 0.31869000000000003}, {'accuracy': 0.31421}, {'accuracy': 0.36363}, {'accuracy': 0.38897000000000004}, {'accuracy': 0.34749}, {'accuracy': 0.28508}, {'accuracy': 0.39377}, {'accuracy': 0.3637}, {'accuracy': 0.42325999999999997}, {'accuracy': 0.37764}, {'accuracy': 0.5192599999999999}, {'accuracy': 0.4245}, {'accuracy': 0.39637}, {'accuracy': 0.46158}, {'accuracy': 0.42341999999999996}, {'accuracy': 0.3448}, {'accuracy': 0.49625}, {'accuracy': 0.5159100000000001}, {'accuracy': 0.43787000000000004}, {'accuracy': 0.5120699999999999}, {'accuracy': 0.536}, {'accuracy': 0.5367599999999999}, {'accuracy': 0.50242}, {'accuracy': 0.5135400000000001}, {'accuracy': 0.48044000000000003}, {'accuracy': 0.40713}, {'accuracy': 0.42686}, {'accuracy': 0.44828999999999997}, {'accuracy': 0.5338900000000001}, {'accuracy': 0.41816000000000003}, {'accuracy': 0.53148}, {'accuracy': 0.41342}, {'accuracy': 0.47474999999999995}, {'accuracy': 0.5201399999999999}, {'accuracy': 0.48337}, {'accuracy': 0.41130000000000005}, {'accuracy': 0.49753}, {'accuracy': 0.47599}, {'accuracy': 0.50105}, {'accuracy': 0.49568}, {'accuracy': 0.5638799999999999}, {'accuracy': 0.41122}, {'accuracy': 0.56168}, {'accuracy': 0.38952000000000003}, {'accuracy': 0.46003}, {'accuracy': 0.63947}, {'accuracy': 0.47556000000000004}, {'accuracy': 0.5050600000000001}, {'accuracy': 0.52305}, {'accuracy': 0.49107}, {'accuracy': 0.6035800000000001}, {'accuracy': 0.42102000000000006}, {'accuracy': 0.5080499999999999}, {'accuracy': 0.54093}, {'accuracy': 0.54478}, {'accuracy': 0.34541}, {'accuracy': 0.5659099999999999}, {'accuracy': 0.5494500000000001}, {'accuracy': 0.50715}, {'accuracy': 0.50056}, {'accuracy': 0.35695}, {'accuracy': 0.47979000000000005}, {'accuracy': 0.50796}, {'accuracy': 0.4614}, {'accuracy': 0.47107}, {'accuracy': 0.56678}, {'accuracy': 0.53603}, {'accuracy': 0.4943999999999999}, {'accuracy': 0.46018}, {'accuracy': 0.4465100000000001}, {'accuracy': 0.5271199999999999}, {'accuracy': 0.43363000000000007}, {'accuracy': 0.4385}, {'accuracy': 0.56551}, {'accuracy': 0.42028999999999994}, {'accuracy': 0.52756}, {'accuracy': 0.50763}, {'accuracy': 0.48841999999999997}, {'accuracy': 0.44714}, {'accuracy': 0.5607499999999999}, {'accuracy': 0.5840599999999999}, {'accuracy': 0.41942}, {'accuracy': 0.53745}, {'accuracy': 0.5054200000000001}, {'accuracy': 0.48805999999999994}, {'accuracy': 0.52935}, {'accuracy': 0.45461}, {'accuracy': 0.54173}, {'accuracy': 0.43755}, {'accuracy': 0.38519000000000003}, {'accuracy': 0.41032}, {'accuracy': 0.53332}, {'accuracy': 0.54267}, {'accuracy': 0.483}, {'accuracy': 0.49994999999999995}, {'accuracy': 0.37641}, {'accuracy': 0.53372}, {'accuracy': 0.49639}, {'accuracy': 0.52233}, {'accuracy': 0.5448500000000001}, {'accuracy': 0.5954999999999999}, {'accuracy': 0.50552}, {'accuracy': 0.54708}, {'accuracy': 0.39714}, {'accuracy': 0.38098}, {'accuracy': 0.45264}, {'accuracy': 0.6148100000000001}, {'accuracy': 0.5121300000000001}, {'accuracy': 0.5550800000000001}, {'accuracy': 0.42336}, {'accuracy': 0.5394699999999999}, {'accuracy': 0.6267499999999999}, {'accuracy': 0.634}, {'accuracy': 0.66347}, {'accuracy': 0.58038}, {'accuracy': 0.5934299999999999}, {'accuracy': 0.4316}, {'accuracy': 0.5811499999999999}, {'accuracy': 0.53132}, {'accuracy': 0.46912000000000004}, {'accuracy': 0.39173}, {'accuracy': 0.56943}, {'accuracy': 0.4441}, {'accuracy': 0.46855000000000013}, {'accuracy': 0.5367999999999999}, {'accuracy': 0.53228}, {'accuracy': 0.52689}, {'accuracy': 0.54945}, {'accuracy': 0.4492299999999999}, {'accuracy': 0.48162000000000005}, {'accuracy': 0.48175}, {'accuracy': 0.536}, {'accuracy': 0.54009}, {'accuracy': 0.4938599999999999}, {'accuracy': 0.51814}, {'accuracy': 0.5223}, {'accuracy': 0.67974}, {'accuracy': 0.56427}, {'accuracy': 0.5459200000000001}, {'accuracy': 0.46839}, {'accuracy': 0.46471}, {'accuracy': 0.57711}, {'accuracy': 0.6204999999999999}, {'accuracy': 0.55632}, {'accuracy': 0.6682300000000001}, {'accuracy': 0.64266}, {'accuracy': 0.4860300000000001}, {'accuracy': 0.51006}, {'accuracy': 0.51693}, {'accuracy': 0.5156600000000001}, {'accuracy': 0.49877000000000005}, {'accuracy': 0.39216}, {'accuracy': 0.54468}, {'accuracy': 0.5151000000000001}, {'accuracy': 0.55653}, {'accuracy': 0.50192}, {'accuracy': 0.56956}, {'accuracy': 0.55366}, {'accuracy': 0.47851999999999995}, {'accuracy': 0.5686600000000002}, {'accuracy': 0.6468100000000001}, {'accuracy': 0.55852}, {'accuracy': 0.54306}, {'accuracy': 0.5589700000000001}, {'accuracy': 0.57165}, {'accuracy': 0.54626}, {'accuracy': 0.5370900000000001}, {'accuracy': 0.44313}, {'accuracy': 0.59162}, {'accuracy': 0.46839}, {'accuracy': 0.44005}, {'accuracy': 0.4539099999999999}, {'accuracy': 0.54827}, {'accuracy': 0.66197}, {'accuracy': 0.62141}, {'accuracy': 0.57381}, {'accuracy': 0.63951}, {'accuracy': 0.52873}, {'accuracy': 0.41104}, {'accuracy': 0.52202}, {'accuracy': 0.5356099999999999}, {'accuracy': 0.53483}, {'accuracy': 0.62043}, {'accuracy': 0.635}, {'accuracy': 0.48266}, {'accuracy': 0.52338}, {'accuracy': 0.4868}, {'accuracy': 0.54318}, {'accuracy': 0.50124}, {'accuracy': 0.38988999999999996}, {'accuracy': 0.41593}, {'accuracy': 0.6342999999999999}, {'accuracy': 0.64409}, {'accuracy': 0.4303199999999999}, {'accuracy': 0.4341100000000001}, {'accuracy': 0.69444}, {'accuracy': 0.8269}, {'accuracy': 0.7630500000000001}, {'accuracy': 0.8268700000000001}, {'accuracy': 0.7621399999999999}, {'accuracy': 0.83079}, {'accuracy': 0.8290599999999999}, {'accuracy': 0.8257}, {'accuracy': 0.8294900000000001}, {'accuracy': 0.8277599999999999}, {'accuracy': 0.82623}, {'accuracy': 0.83543}, {'accuracy': 0.8283999999999999}, {'accuracy': 0.83178}, {'accuracy': 0.83169}, {'accuracy': 0.82982}, {'accuracy': 0.8302399999999999}, {'accuracy': 0.8304600000000001}, {'accuracy': 0.83102}, {'accuracy': 0.83108}, {'accuracy': 0.82513}, {'accuracy': 0.8313500000000001}, {'accuracy': 0.83125}, {'accuracy': 0.8298599999999998}, {'accuracy': 0.8327600000000001}, {'accuracy': 0.82761}, {'accuracy': 0.8331099999999999}, {'accuracy': 0.8298099999999998}, {'accuracy': 0.8343399999999999}, {'accuracy': 0.83091}, {'accuracy': 0.83249}, {'accuracy': 0.83309}, {'accuracy': 0.83112}, {'accuracy': 0.83095}, {'accuracy': 0.8328200000000001}, {'accuracy': 0.8308}, {'accuracy': 0.83056}, {'accuracy': 0.83148}, {'accuracy': 0.8333999999999999}, {'accuracy': 0.83109}, {'accuracy': 0.8250400000000001}, {'accuracy': 0.82943}, {'accuracy': 0.8311100000000001}, {'accuracy': 0.8326399999999999}, {'accuracy': 0.83542}, {'accuracy': 0.8285199999999999}, {'accuracy': 0.8350899999999999}, {'accuracy': 0.83374}, {'accuracy': 0.8328900000000001}, {'accuracy': 0.8317500000000001}, {'accuracy': 0.83498}, {'accuracy': 0.83332}, {'accuracy': 0.83316}, {'accuracy': 0.83148}, {'accuracy': 0.83574}, {'accuracy': 0.8331900000000001}, {'accuracy': 0.82972}, {'accuracy': 0.8316099999999998}, {'accuracy': 0.82982}, {'accuracy': 0.8316699999999999}, {'accuracy': 0.8227}, {'accuracy': 0.82549}, {'accuracy': 0.83162}, {'accuracy': 0.83374}, {'accuracy': 0.82987}, {'accuracy': 0.8343100000000001}, {'accuracy': 0.8338199999999999}, {'accuracy': 0.83144}, {'accuracy': 0.8347900000000001}, {'accuracy': 0.83248}, {'accuracy': 0.8322100000000001}, {'accuracy': 0.8297700000000001}, {'accuracy': 0.8306600000000002}, {'accuracy': 0.8362800000000001}, {'accuracy': 0.83689}, {'accuracy': 0.8338299999999998}, {'accuracy': 0.83363}, {'accuracy': 0.83134}, {'accuracy': 0.82944}, {'accuracy': 0.83332}, {'accuracy': 0.8319599999999999}, {'accuracy': 0.8358000000000001}, {'accuracy': 0.8321400000000001}, {'accuracy': 0.8317400000000001}, {'accuracy': 0.83036}, {'accuracy': 0.83152}, {'accuracy': 0.8305899999999999}, {'accuracy': 0.8312900000000001}, {'accuracy': 0.8325600000000002}, {'accuracy': 0.8332}, {'accuracy': 0.8301299999999999}, {'accuracy': 0.83155}, {'accuracy': 0.8301999999999999}, {'accuracy': 0.8321399999999999}, {'accuracy': 0.8324100000000001}, {'accuracy': 0.8301700000000001}, {'accuracy': 0.83091}, {'accuracy': 0.8359399999999999}, {'accuracy': 0.8269599999999999}]\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.83</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.83\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/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACqDklEQVR4nO2dd3wUZf7HP9s3PYFUktARRToIoiIIUaxnF7GAKFixoZ5yKpx6inqnh3fYjp+KehYU61mwIKAiShPpvUMapG+SbTO/P3af2WfalmSTTTbf9+vFi2R2yjOzk3k+860GURRFEARBEARBxAnGWA+AIAiCIAgimpC4IQiCIAgiriBxQxAEQRBEXEHihiAIgiCIuILEDUEQBEEQcQWJG4IgCIIg4goSNwRBEARBxBUkbgiCIAiCiCtI3BAEQRAEEVeQuCEIokVZvnw5DAYDli9fLi274YYb0L1795iNKZ7461//CoPBEOthEESbgsQNQbRxtmzZguuuuw75+fmw2Wzo0qULrr32WmzZsiXWQ2txXnrpJSxcuLBFj7F161b89a9/xf79+1v0OK3JU089hU8//TTWwyCImEHihiDaMB9//DGGDh2KpUuXYurUqXjppZdw0003YdmyZRg6dCg++eSTWA+xRWktcfPYY4+RuCGIOMIc6wEQBKHNnj17cP3116Nnz5748ccfkZWVJX129913Y/To0bj++uuxceNG9OzZs9XG5XA4kJSU1GrHaw/QNSGItgVZbgiijfL3v/8d9fX1+M9//iMTNgCQmZmJV199FQ6HA88++ywAYPHixTAYDFixYoVqX6+++ioMBgM2b94sLdu+fTuuuOIKdOrUCXa7HcOHD8fnn38u227hwoXSPm+//XZkZ2ejoKAAAHDgwAHcfvvt6Nu3LxISEtC5c2dceeWVUbOAdO/eHVu2bMGKFStgMBhgMBgwduxY6fOqqircc889KCwshM1mQ+/evfHMM89AEATZft5//30MGzYMKSkpSE1NxYABA/DCCy9I53fllVcCAM466yzpOHx8kJIbbrgBycnJ2LNnD84//3ykpKTg2muvBQAIgoB58+bh5JNPht1uR05ODm655RZUVlbK9rF27VpMmDABmZmZSEhIQI8ePXDjjTdKn2vFKQHA/v37YTAYglqzDAYDHA4H3nzzTel8brjhBgBAbW0t7rnnHnTv3h02mw3Z2dk4++yzsX79et39EUR7hCw3BNFG+d///ofu3btj9OjRmp+feeaZ6N69O7788ksAwAUXXIDk5GR88MEHGDNmjGzdRYsW4eSTT0b//v0B+OJ4Tj/9dOTn5+Ohhx5CUlISPvjgA1xyySX46KOPcOmll8q2v/3225GVlYXZs2fD4XAAANasWYNffvkFV199NQoKCrB//368/PLLGDt2LLZu3YrExMRmnf+8efNw5513Ijk5GQ8//DAAICcnBwBQX1+PMWPG4MiRI7jlllvQtWtX/PLLL5g1axaKi4sxb948AMB3332HSZMmYfz48XjmmWcAANu2bcPKlStx991348wzz8Rdd92Ff/3rX/jLX/6Ck046CQCk//XweDyYMGECzjjjDPzjH/+QzvWWW27BwoULMXXqVNx1113Yt28f5s+fj99//x0rV66ExWJBWVkZzjnnHGRlZeGhhx5Ceno69u/fj48//rhZ14vx9ttvY9q0aRgxYgRuvvlmAECvXr0AALfeeisWL16MGTNmoF+/fjh+/Dh+/vlnbNu2DUOHDo3K8QmiTSASBNHmqKqqEgGIF198cdD1/vSnP4kAxJqaGlEURXHSpElidna26PF4pHWKi4tFo9EoPv7449Ky8ePHiwMGDBAbGxulZYIgiKeddprYp08fadkbb7whAhDPOOMM2T5FURTr6+tV41m1apUIQHzrrbekZcuWLRMBiMuWLZOWTZkyRezWrVvQcxNFUTz55JPFMWPGqJY/8cQTYlJSkrhz507Z8oceekg0mUziwYMHRVEUxbvvvltMTU1VjZ3nww8/VI0vGFOmTBEBiA899JBs+U8//SQCEN955x3Z8iVLlsiWf/LJJyIAcc2aNbrH0LpmoiiK+/btEwGIb7zxhrRszpw5ovJRnpSUJE6ZMkW137S0NPGOO+4I4ywJon1DbimCaIPU1tYCAFJSUoKuxz6vqakBAEycOBFlZWUyd8bixYshCAImTpwIAKioqMAPP/yAq666CrW1tTh27BiOHTuG48ePY8KECdi1axeOHDkiO8706dNhMplkyxISEqSf3W43jh8/jt69eyM9Pb3F3RwffvghRo8ejYyMDGn8x44dQ1FREbxeL3788UcAQHp6OhwOB7777ruoj+G2225TjSktLQ1nn322bEzDhg1DcnIyli1bJo0JAL744gu43e6ojysY6enp+O2333D06NFWPS5BtDYkbgiiDcJECxM5eihF0Lnnnou0tDQsWrRIWmfRokUYPHgwTjjhBADA7t27IYoiHn30UWRlZcn+zZkzBwBQVlYmO06PHj1Ux25oaMDs2bOlmJfMzExkZWWhqqoK1dXVTTzz8Ni1axeWLFmiGn9RUZFs/LfffjtOOOEEnHfeeSgoKMCNN96IJUuWNPv4ZrNZij3ix1RdXY3s7GzVuOrq6qQxjRkzBpdffjkee+wxZGZm4uKLL8Ybb7wBp9PZ7HGF4tlnn8XmzZtRWFiIESNG4K9//Sv27t3b4scliNaGYm4Iog2SlpaGvLw8bNy4Meh6GzduRH5+PlJTUwEANpsNl1xyCT755BO89NJLKC0txcqVK/HUU09J27CA2/vvvx8TJkzQ3G/v3r1lv/NWGsadd96JN954A/fccw9GjRqFtLQ0GAwGXH311aqg3mgjCALOPvts/PnPf9b8nAm57OxsbNiwAd988w2+/vprfP3113jjjTcwefJkvPnmm00+vs1mg9EofzcUBAHZ2dl45513NLdhQeEGgwGLFy/Gr7/+iv/973/45ptvcOONN+K5557Dr7/+iuTkZN2ifF6vt8ljBoCrrroKo0ePxieffIJvv/0Wf//73/HMM8/g448/xnnnndesfRNEW4LEDUG0US688EIsWLAAP//8M8444wzV5z/99BP279+PW265RbZ84sSJePPNN7F06VJs27YNoihKLikAUtq4xWKRLB1NYfHixZgyZQqee+45aVljYyOqqqqavE8lepN8r169UFdXF9b4rVYrLrroIlx00UUQBAG33347Xn31VTz66KPo3bt31Kr79urVC99//z1OP/10TTGo5NRTT8Wpp56KJ598Eu+++y6uvfZavP/++5g2bRoyMjIAQHUtDxw4ENZYgp1TXl4ebr/9dtx+++0oKyvD0KFD8eSTT5K4IeIKcksRRBvlgQceQEJCAm655RYcP35c9llFRQVuvfVWJCYm4oEHHpB9VlRUhE6dOmHRokVYtGgRRowYIXMrZWdnY+zYsXj11VdRXFysOm55eXlY4zOZTBBFUbbs3//+d7OtCzxJSUmaYumqq67CqlWr8M0336g+q6qqgsfjAQDVdTMajRg4cCAASG4gVp+muaLsqquugtfrxRNPPKH6zOPxSPuvrKxUXbfBgwfLxtStWzeYTCYpdojx0ksvhTUWrevm9XpV7sLs7Gx06dKlVVxiBNGakOWGINooffr0wZtvvolrr70WAwYMwE033YQePXpg//79eO2113Ds2DG89957Upovw2Kx4LLLLsP7778Ph8OBf/zjH6p9v/jiizjjjDMwYMAATJ8+HT179kRpaSlWrVqFw4cP448//gg5vgsvvBBvv/020tLS0K9fP6xatQrff/89OnfuHLVrMGzYMLz88sv429/+ht69eyM7Oxvjxo3DAw88gM8//xwXXnghbrjhBgwbNgwOhwObNm3C4sWLsX//fmRmZmLatGmoqKjAuHHjUFBQgAMHDuDf//43Bg8eLKV7Dx48GCaTCc888wyqq6ths9kwbtw4ZGdnRzTWMWPG4JZbbsHcuXOxYcMGnHPOObBYLNi1axc+/PBDvPDCC7jiiivw5ptv4qWXXsKll16KXr16oba2FgsWLEBqairOP/98AD635JVXXol///vfMBgM6NWrF7744gtVLFSw6/b999/j+eefR5cuXdCjRw/07dsXBQUFuOKKKzBo0CAkJyfj+++/x5o1a2TWN4KIC2KbrEUQRCg2btwoTpo0SczLyxMtFouYm5srTpo0Sdy0aZPuNt99950IQDQYDOKhQ4c019mzZ484efJkMTc3V7RYLGJ+fr544YUXiosXL5bWYangWmnLlZWV4tSpU8XMzEwxOTlZnDBhgrh9+3axW7dusjTk5qSCl5SUiBdccIGYkpIiApClhdfW1oqzZs0Se/fuLVqtVjEzM1M87bTTxH/84x+iy+USRVEUFy9eLJ5zzjlidna2aLVaxa5du4q33HKLWFxcLDvOggULxJ49e4omkylkWviUKVPEpKQk3c//85//iMOGDRMTEhLElJQUccCAAeKf//xn8ejRo6IoiuL69evFSZMmiV27dhVtNpuYnZ0tXnjhheLatWtl+ykvLxcvv/xyMTExUczIyBBvueUWcfPmzWGlgm/fvl0888wzxYSEBBGAOGXKFNHpdIoPPPCAOGjQIDElJUVMSkoSBw0aJL700kvBvgKCaJcYRFFhHyUIgiAIgmjHUMwNQRAEQRBxBYkbgiAIgiDiChI3BEEQBEHEFSRuCIIgCIKIK0jcEARBEAQRV5C4IQiCIAgiruhwRfwEQcDRo0eRkpIStbLrBEEQBEG0LKIoora2Fl26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FUwmU4e9XoIg4J577sHpp5+O/v37A0BYf3slJSWa9x/7LB7RulYAcM0116Bbt27o0qULNm7ciAcffBA7duzAxx9/DKDjXatNmzZh1KhRaGxsRHJyMj755BP069cPGzZsaHP3FYkbokU477zzpJ8HDhyIkSNHolu3bvjggw+QkJAQw5ER8cbVV18t/TxgwAAMHDgQvXr1wvLlyzF+/PgYjiy23HHHHdi8ebMs1o3QRu9a8XFZAwYMQF5eHsaPH489e/agV69erT3MmNO3b19s2LAB1dXVWLx4MaZMmYIVK1bEeliakFuqGWRmZsJkMqkiwktLS5GbmxujUbVN0tPTccIJJ2D37t3Izc2Fy+VCVVWVbB26bpDOP9g9lZubqwpY93g8qKio6PDXDwB69uyJzMxM7N69G0DHvF4zZszAF198gWXLlqGgoEBaHs7fXm5urub9xz6LN/SulRYjR44EANm91ZGuldVqRe/evTFs2DDMnTsXgwYNwgsvvNAm7ysSN83AarVi2LBhWLp0qbRMEAQsXboUo0aNiuHI2h51dXXYs2cP8vLyMGzYMFgsFtl127FjBw4ePNjhr1uPHj2Qm5sruzY1NTX47bffpGszatQoVFVVYd26ddI6P/zwAwRBkB6+HZnDhw/j+PHjyMvLA9CxrpcoipgxYwY++eQT/PDDD+jRo4fs83D+9kaNGoVNmzbJBOF3332H1NRU9OvXr3VOpBUIda202LBhAwDI7q2OcK30EAQBTqezbd5XUQ9R7mC8//77os1mExcuXChu3bpVvPnmm8X09HRZRHhH5L777hOXL18u7tu3T1y5cqVYVFQkZmZmimVlZaIoiuKtt94qdu3aVfzhhx/EtWvXiqNGjRJHjRoV41G3DrW1teLvv/8u/v777yIA8fnnnxd///138cCBA6IoiuLTTz8tpqeni5999pm4ceNG8eKLLxZ79OghNjQ0SPs499xzxSFDhoi//fab+PPPP4t9+vQRJ02aFKtTalGCXa/a2lrx/vvvF1etWiXu27dP/P7778WhQ4eKffr0ERsbG6V9dJTrddttt4lpaWni8uXLxeLiYulffX29tE6ovz2PxyP2799fPOecc8QNGzaIS5YsEbOyssRZs2bF4pRajFDXavfu3eLjjz8url27Vty3b5/42WefiT179hTPPPNMaR8d5VqJoig+9NBD4ooVK8R9+/aJGzduFB966CHRYDCI3377rSiKbe++InETBf7973+LXbt2Fa1WqzhixAjx119/jfWQYs7EiRPFvLw80Wq1ivn5+eLEiRPF3bt3S583NDSIt99+u5iRkSEmJiaKl156qVhcXBzDEbcey5YtEwGo/k2ZMkUURV86+KOPPirm5OSINptNHD9+vLhjxw7ZPo4fPy5OmjRJTE5OFlNTU8WpU6eKtbW1MTiblifY9aqvrxfPOeccMSsrS7RYLGK3bt3E6dOnq14uOsr10rpOAMQ33nhDWiecv739+/eL5513npiQkCBmZmaK9913n+h2u1v5bFqWUNfq4MGD4plnnil26tRJtNlsYu/evcUHHnhArK6ulu2nI1wrURTFG2+8UezWrZtotVrFrKwscfz48ZKwEcW2d18ZRFEUo28PIgiCIAiCiA0Uc0MQBEEQRFxB4oYgCIIgiLiCxA1BEARBEHEFiRuCIAiCIOIKEjcEQRAEQcQVJG4IgiAIgogrSNwQBEEQBBFXkLghCKJDsHz5chgMBlX/G4Ig4g8SNwRBEARBxBUkbgiCIAiCiCtI3BAE0aYQBAHPPvssevfuDZvNhq5du+LJJ5/EuHHjMGPGDNm65eXlsFqtUjdip9OJBx98EIWFhbDZbOjduzdee+013WP9/PPPGD16NBISElBYWIi77roLDoejRc+PIIiWh8QNQRBtilmzZuHpp5/Go48+iq1bt+Ldd99FTk4Opk2bhnfffRdOp1Na97///S/y8/Mxbtw4AMDkyZPx3nvv4V//+he2bduGV199FcnJyZrH2bNnD84991xcfvnl2LhxIxYtWoSff/5ZJaAIgmh/UONMgiDaDLW1tcjKysL8+fMxbdo02WeNjY3o0qULXnnlFVx11VUAgEGDBuGyyy7DnDlzsHPnTvTt2xffffcdioqKVPtevnw5zjrrLFRWViI9PR3Tpk2DyWTCq6++Kq3z888/Y8yYMXA4HLDb7S17sgRBtBhkuSEIos2wbds2OJ1OjB8/XvWZ3W7H9ddfj9dffx0AsH79emzevBk33HADAGDDhg0wmUwYM2ZMWMf6448/sHDhQiQnJ0v/JkyYAEEQsG/fvqidE0EQrY851gMgCIJgJCQkBP182rRpGDx4MA4fPow33ngD48aNQ7du3cLaVkldXR1uueUW3HXXXarPunbtGtG+CIJoW5DlhiCINkOfPn2QkJAgBQgrGTBgAIYPH44FCxbg3XffxY033ij7TBAErFixIqxjDR06FFu3bkXv3r1V/6xWa1TOhyCI2EDihiCINoPdbseDDz6IP//5z3jrrbewZ88e/Prrr7KMp2nTpuHpp5+GKIq49NJLpeXdu3fHlClTcOONN+LTTz/Fvn37sHz5cnzwwQeax3rwwQfxyy+/YMaMGdiwYQN27dqFzz77jAKKCSIOIHFDEESb4tFHH8V9992H2bNn46STTsLEiRNRVlYmfT5p0iSYzWZMmjRJFfT78ssv44orrsDtt9+OE088EdOnT9dN7R44cCBWrFiBnTt3YvTo0RgyZAhmz56NLl26tOj5EQTR8lC2FEEQ7Yr9+/ejV69eWLNmDYYOHRrr4RAE0QYhcUMQRLvA7Xbj+PHjuP/++7Fv3z6sXLky1kMiCKKNQm4pgiDaBStXrkReXh7WrFmDV155JdbDIQiiDUOWG4IgCIIg4gqy3BAEQRAEEVeQuCEIgiAIIq4gcUMQBEEQRFxB4oYgCIIgiLiCxA1BEARBEHEFiRuCIAiCIOIKEjcEQRAEQcQVJG4IgiAIgogrSNwQBEEQBBFX/D+mmSfmWBNh3gAAAABJRU5ErkJggg==\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.16491000000000003}, {'accuracy': 0.21276}, {'accuracy': 0.23723}, {'accuracy': 0.22917}, {'accuracy': 0.27781}, {'accuracy': 0.27066}, {'accuracy': 0.31869000000000003}, {'accuracy': 0.31421}, {'accuracy': 0.36363}, {'accuracy': 0.38897000000000004}, {'accuracy': 0.34749}, {'accuracy': 0.28508}, {'accuracy': 0.39377}, {'accuracy': 0.3637}, {'accuracy': 0.42325999999999997}, {'accuracy': 0.37764}, {'accuracy': 0.5192599999999999}, {'accuracy': 0.4245}, {'accuracy': 0.39637}, {'accuracy': 0.46158}, {'accuracy': 0.42341999999999996}, {'accuracy': 0.3448}, {'accuracy': 0.49625}, {'accuracy': 0.5159100000000001}, {'accuracy': 0.43787000000000004}, {'accuracy': 0.5120699999999999}, {'accuracy': 0.536}, {'accuracy': 0.5367599999999999}, {'accuracy': 0.50242}, {'accuracy': 0.5135400000000001}, {'accuracy': 0.48044000000000003}, {'accuracy': 0.40713}, {'accuracy': 0.42686}, {'accuracy': 0.44828999999999997}, {'accuracy': 0.5338900000000001}, {'accuracy': 0.41816000000000003}, {'accuracy': 0.53148}, {'accuracy': 0.41342}, {'accuracy': 0.47474999999999995}, {'accuracy': 0.5201399999999999}, {'accuracy': 0.48337}, {'accuracy': 0.41130000000000005}, {'accuracy': 0.49753}, {'accuracy': 0.47599}, {'accuracy': 0.50105}, {'accuracy': 0.49568}, {'accuracy': 0.5638799999999999}, {'accuracy': 0.41122}, {'accuracy': 0.56168}, {'accuracy': 0.38952000000000003}, {'accuracy': 0.46003}, {'accuracy': 0.63947}, {'accuracy': 0.47556000000000004}, {'accuracy': 0.5050600000000001}, {'accuracy': 0.52305}, {'accuracy': 0.49107}, {'accuracy': 0.6035800000000001}, {'accuracy': 0.42102000000000006}, {'accuracy': 0.5080499999999999}, {'accuracy': 0.54093}, {'accuracy': 0.54478}, {'accuracy': 0.34541}, {'accuracy': 0.5659099999999999}, {'accuracy': 0.5494500000000001}, {'accuracy': 0.50715}, {'accuracy': 0.50056}, {'accuracy': 0.35695}, {'accuracy': 0.47979000000000005}, {'accuracy': 0.50796}, {'accuracy': 0.4614}, {'accuracy': 0.47107}, {'accuracy': 0.56678}, {'accuracy': 0.53603}, {'accuracy': 0.4943999999999999}, {'accuracy': 0.46018}, {'accuracy': 0.4465100000000001}, {'accuracy': 0.5271199999999999}, {'accuracy': 0.43363000000000007}, {'accuracy': 0.4385}, {'accuracy': 0.56551}, {'accuracy': 0.42028999999999994}, {'accuracy': 0.52756}, {'accuracy': 0.50763}, {'accuracy': 0.48841999999999997}, {'accuracy': 0.44714}, {'accuracy': 0.5607499999999999}, {'accuracy': 0.5840599999999999}, {'accuracy': 0.41942}, {'accuracy': 0.53745}, {'accuracy': 0.5054200000000001}, {'accuracy': 0.48805999999999994}, {'accuracy': 0.52935}, {'accuracy': 0.45461}, {'accuracy': 0.54173}, {'accuracy': 0.43755}, {'accuracy': 0.38519000000000003}, {'accuracy': 0.41032}, {'accuracy': 0.53332}, {'accuracy': 0.54267}, {'accuracy': 0.483}, {'accuracy': 0.49994999999999995}, {'accuracy': 0.37641}, {'accuracy': 0.53372}, {'accuracy': 0.49639}, {'accuracy': 0.52233}, {'accuracy': 0.5448500000000001}, {'accuracy': 0.5954999999999999}, {'accuracy': 0.50552}, {'accuracy': 0.54708}, {'accuracy': 0.39714}, {'accuracy': 0.38098}, {'accuracy': 0.45264}, {'accuracy': 0.6148100000000001}, {'accuracy': 0.5121300000000001}, {'accuracy': 0.5550800000000001}, {'accuracy': 0.42336}, {'accuracy': 0.5394699999999999}, {'accuracy': 0.6267499999999999}, {'accuracy': 0.634}, {'accuracy': 0.66347}, {'accuracy': 0.58038}, {'accuracy': 0.5934299999999999}, {'accuracy': 0.4316}, {'accuracy': 0.5811499999999999}, {'accuracy': 0.53132}, {'accuracy': 0.46912000000000004}, {'accuracy': 0.39173}, {'accuracy': 0.56943}, {'accuracy': 0.4441}, {'accuracy': 0.46855000000000013}, {'accuracy': 0.5367999999999999}, {'accuracy': 0.53228}, {'accuracy': 0.52689}, {'accuracy': 0.54945}, {'accuracy': 0.4492299999999999}, {'accuracy': 0.48162000000000005}, {'accuracy': 0.48175}, {'accuracy': 0.536}, {'accuracy': 0.54009}, {'accuracy': 0.4938599999999999}, {'accuracy': 0.51814}, {'accuracy': 0.5223}, {'accuracy': 0.67974}, {'accuracy': 0.56427}, {'accuracy': 0.5459200000000001}, {'accuracy': 0.46839}, {'accuracy': 0.46471}, {'accuracy': 0.57711}, {'accuracy': 0.6204999999999999}, {'accuracy': 0.55632}, {'accuracy': 0.6682300000000001}, {'accuracy': 0.64266}, {'accuracy': 0.4860300000000001}, {'accuracy': 0.51006}, {'accuracy': 0.51693}, {'accuracy': 0.5156600000000001}, {'accuracy': 0.49877000000000005}, {'accuracy': 0.39216}, {'accuracy': 0.54468}, {'accuracy': 0.5151000000000001}, {'accuracy': 0.55653}, {'accuracy': 0.50192}, {'accuracy': 0.56956}, {'accuracy': 0.55366}, {'accuracy': 0.47851999999999995}, {'accuracy': 0.5686600000000002}, {'accuracy': 0.6468100000000001}, {'accuracy': 0.55852}, {'accuracy': 0.54306}, {'accuracy': 0.5589700000000001}, {'accuracy': 0.57165}, {'accuracy': 0.54626}, {'accuracy': 0.5370900000000001}, {'accuracy': 0.44313}, {'accuracy': 0.59162}, {'accuracy': 0.46839}, {'accuracy': 0.44005}, {'accuracy': 0.4539099999999999}, {'accuracy': 0.54827}, {'accuracy': 0.66197}, {'accuracy': 0.62141}, {'accuracy': 0.57381}, {'accuracy': 0.63951}, {'accuracy': 0.52873}, {'accuracy': 0.41104}, {'accuracy': 0.52202}, {'accuracy': 0.5356099999999999}, {'accuracy': 0.53483}, {'accuracy': 0.62043}, {'accuracy': 0.635}, {'accuracy': 0.48266}, {'accuracy': 0.52338}, {'accuracy': 0.4868}, {'accuracy': 0.54318}, {'accuracy': 0.50124}, {'accuracy': 0.38988999999999996}, {'accuracy': 0.41593}, {'accuracy': 0.6342999999999999}, {'accuracy': 0.64409}, {'accuracy': 0.4303199999999999}, {'accuracy': 0.4341100000000001}, {'accuracy': 0.69444}, {'accuracy': 0.8269}, {'accuracy': 0.7630500000000001}, {'accuracy': 0.8268700000000001}, {'accuracy': 0.7621399999999999}, {'accuracy': 0.83079}, {'accuracy': 0.8290599999999999}, {'accuracy': 0.8257}, {'accuracy': 0.8294900000000001}, {'accuracy': 0.8277599999999999}, {'accuracy': 0.82623}, {'accuracy': 0.83543}, {'accuracy': 0.8283999999999999}, {'accuracy': 0.83178}, {'accuracy': 0.83169}, {'accuracy': 0.82982}, {'accuracy': 0.8302399999999999}, {'accuracy': 0.8304600000000001}, {'accuracy': 0.83102}, {'accuracy': 0.83108}, {'accuracy': 0.82513}, {'accuracy': 0.8313500000000001}, {'accuracy': 0.83125}, {'accuracy': 0.8298599999999998}, {'accuracy': 0.8327600000000001}, {'accuracy': 0.82761}, {'accuracy': 0.8331099999999999}, {'accuracy': 0.8298099999999998}, {'accuracy': 0.8343399999999999}, {'accuracy': 0.83091}, {'accuracy': 0.83249}, {'accuracy': 0.83309}, {'accuracy': 0.83112}, {'accuracy': 0.83095}, {'accuracy': 0.8328200000000001}, {'accuracy': 0.8308}, {'accuracy': 0.83056}, {'accuracy': 0.83148}, {'accuracy': 0.8333999999999999}, {'accuracy': 0.83109}, {'accuracy': 0.8250400000000001}, {'accuracy': 0.82943}, {'accuracy': 0.8311100000000001}, {'accuracy': 0.8326399999999999}, {'accuracy': 0.83542}, {'accuracy': 0.8285199999999999}, {'accuracy': 0.8350899999999999}, {'accuracy': 0.83374}, {'accuracy': 0.8328900000000001}, {'accuracy': 0.8317500000000001}, {'accuracy': 0.83498}, {'accuracy': 0.83332}, {'accuracy': 0.83316}, {'accuracy': 0.83148}, {'accuracy': 0.83574}, {'accuracy': 0.8331900000000001}, {'accuracy': 0.82972}, {'accuracy': 0.8316099999999998}, {'accuracy': 0.82982}, {'accuracy': 0.8316699999999999}, {'accuracy': 0.8227}, {'accuracy': 0.82549}, {'accuracy': 0.83162}, {'accuracy': 0.83374}, {'accuracy': 0.82987}, {'accuracy': 0.8343100000000001}, {'accuracy': 0.8338199999999999}, {'accuracy': 0.83144}, {'accuracy': 0.8347900000000001}, {'accuracy': 0.83248}, {'accuracy': 0.8322100000000001}, {'accuracy': 0.8297700000000001}, {'accuracy': 0.8306600000000002}, {'accuracy': 0.8362800000000001}, {'accuracy': 0.83689}, {'accuracy': 0.8338299999999998}, {'accuracy': 0.83363}, {'accuracy': 0.83134}, {'accuracy': 0.82944}, {'accuracy': 0.83332}, {'accuracy': 0.8319599999999999}, {'accuracy': 0.8358000000000001}, {'accuracy': 0.8321400000000001}, {'accuracy': 0.8317400000000001}, {'accuracy': 0.83036}, {'accuracy': 0.83152}, {'accuracy': 0.8305899999999999}, {'accuracy': 0.8312900000000001}, {'accuracy': 0.8325600000000002}, {'accuracy': 0.8332}, {'accuracy': 0.8301299999999999}, {'accuracy': 0.83155}, {'accuracy': 0.8301999999999999}, {'accuracy': 0.8321399999999999}, {'accuracy': 0.8324100000000001}, {'accuracy': 0.8301700000000001}, {'accuracy': 0.83091}, {'accuracy': 0.8359399999999999}, {'accuracy': 0.8269599999999999}]\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": "08d2a845-6a63-4c1e-916e-1d7f60b92ecd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "85a7ec0b-c9b6-447a-a950-fe783e14d2d0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "752a8472-a5ba-443c-889c-ec53a2663066",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3102d03e-5c87-469f-b7ce-d7ddbbcac73d",
   "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
}
