{
 "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",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2357]\n",
      " [   1   72]\n",
      " [   2   40]\n",
      " [   3   78]\n",
      " [   4  117]\n",
      " [   5  170]\n",
      " [   6  302]\n",
      " [   7  541]\n",
      " [   8  846]\n",
      " [   9 1423]]\n",
      "[[   0 1470]\n",
      " [   1 2681]\n",
      " [   2   53]\n",
      " [   3   37]\n",
      " [   4   64]\n",
      " [   5  104]\n",
      " [   6  183]\n",
      " [   7  328]\n",
      " [   8  505]\n",
      " [   9  883]]\n",
      "[[   0  842]\n",
      " [   1 1556]\n",
      " [   2 2359]\n",
      " [   3   65]\n",
      " [   4   41]\n",
      " [   5   69]\n",
      " [   6  104]\n",
      " [   7  186]\n",
      " [   8  336]\n",
      " [   9  514]]\n",
      "[[   0  476]\n",
      " [   1 1000]\n",
      " [   2 1450]\n",
      " [   3 2443]\n",
      " [   4   60]\n",
      " [   5   33]\n",
      " [   6   69]\n",
      " [   7  122]\n",
      " [   8  181]\n",
      " [   9  309]]\n",
      "[[   0  346]\n",
      " [   1  621]\n",
      " [   2  894]\n",
      " [   3 1493]\n",
      " [   4 2409]\n",
      " [   5   47]\n",
      " [   6   46]\n",
      " [   7   68]\n",
      " [   8  109]\n",
      " [   9  187]]\n",
      "[[   0  169]\n",
      " [   1  353]\n",
      " [   2  490]\n",
      " [   3  895]\n",
      " [   4 1368]\n",
      " [   5 2205]\n",
      " [   6   53]\n",
      " [   7   27]\n",
      " [   8   55]\n",
      " [   9  107]]\n",
      "[[   0  113]\n",
      " [   1  205]\n",
      " [   2  327]\n",
      " [   3  519]\n",
      " [   4  830]\n",
      " [   5 1320]\n",
      " [   6 2377]\n",
      " [   7   81]\n",
      " [   8   39]\n",
      " [   9   92]]\n",
      "[[   0   62]\n",
      " [   1  138]\n",
      " [   2  167]\n",
      " [   3  309]\n",
      " [   4  501]\n",
      " [   5  760]\n",
      " [   6 1394]\n",
      " [   7 2540]\n",
      " [   8   51]\n",
      " [   9   41]]\n",
      "[[   0   33]\n",
      " [   1   73]\n",
      " [   2  105]\n",
      " [   3  186]\n",
      " [   4  270]\n",
      " [   5  426]\n",
      " [   6  876]\n",
      " [   7 1497]\n",
      " [   8 2294]\n",
      " [   9   71]]\n",
      "[[   0   55]\n",
      " [   1   43]\n",
      " [   2   73]\n",
      " [   3  106]\n",
      " [   4  182]\n",
      " [   5  287]\n",
      " [   6  514]\n",
      " [   7  875]\n",
      " [   8 1435]\n",
      " [   9 2322]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "29877\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1227]\n",
      " [   1   41]\n",
      " [   2   18]\n",
      " [   3   43]\n",
      " [   4   57]\n",
      " [   5   76]\n",
      " [   6  158]\n",
      " [   7  276]\n",
      " [   8  414]\n",
      " [   9  703]]\n",
      "[[   0 2437]\n",
      " [   1   72]\n",
      " [   2   43]\n",
      " [   3   73]\n",
      " [   4  123]\n",
      " [   5  164]\n",
      " [   6  294]\n",
      " [   7  529]\n",
      " [   8  858]\n",
      " [   9 1439]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 4, 3, 6])"
      ]
     },
     "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, 3, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:05:05 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:05:05\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": "50fc8971b1ef4d13a3f0aeee198fba4b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:09:59 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3154</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:09:59\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3154\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\">68883360</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;36m68883360\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.10371}, {'accuracy': 0.13035999999999998}, {'accuracy': 0.22509}, {'accuracy': 0.40145}, {'accuracy': 0.43794000000000005}, {'accuracy': 0.52083}, {'accuracy': 0.35517000000000004}, {'accuracy': 0.40774}, {'accuracy': 0.6538099999999999}, {'accuracy': 0.56517}, {'accuracy': 0.6745599999999999}, {'accuracy': 0.59864}, {'accuracy': 0.57575}, {'accuracy': 0.65711}, {'accuracy': 0.53028}, {'accuracy': 0.50668}, {'accuracy': 0.7130599999999999}, {'accuracy': 0.49974999999999997}, {'accuracy': 0.5603}, {'accuracy': 0.5301699999999999}, {'accuracy': 0.63943}, {'accuracy': 0.60187}, {'accuracy': 0.47169}, {'accuracy': 0.7506299999999999}, {'accuracy': 0.72165}, {'accuracy': 0.69264}, {'accuracy': 0.67947}, {'accuracy': 0.71806}, {'accuracy': 0.59061}, {'accuracy': 0.5016399999999999}, {'accuracy': 0.56246}, {'accuracy': 0.6503399999999999}, {'accuracy': 0.50944}, {'accuracy': 0.64131}, {'accuracy': 0.58095}, {'accuracy': 0.6681900000000001}, {'accuracy': 0.48446999999999996}, {'accuracy': 0.5406000000000001}, {'accuracy': 0.6132799999999999}, {'accuracy': 0.54242}, {'accuracy': 0.64178}, {'accuracy': 0.71483}, {'accuracy': 0.59374}, {'accuracy': 0.634}, {'accuracy': 0.6129800000000001}, {'accuracy': 0.7072499999999999}, {'accuracy': 0.6769000000000001}, {'accuracy': 0.5506399999999999}, {'accuracy': 0.62897}, {'accuracy': 0.5420499999999999}, {'accuracy': 0.61929}, {'accuracy': 0.65425}, {'accuracy': 0.70183}, {'accuracy': 0.45454}, {'accuracy': 0.6457200000000001}, {'accuracy': 0.70185}, {'accuracy': 0.76742}, {'accuracy': 0.67209}, {'accuracy': 0.7269500000000001}, {'accuracy': 0.7785900000000001}, {'accuracy': 0.7785299999999999}, {'accuracy': 0.64848}, {'accuracy': 0.67709}, {'accuracy': 0.63509}, {'accuracy': 0.55494}, {'accuracy': 0.60182}, {'accuracy': 0.6316200000000001}, {'accuracy': 0.65786}, {'accuracy': 0.7348399999999999}, {'accuracy': 0.5961000000000001}, {'accuracy': 0.60728}, {'accuracy': 0.6127500000000001}, {'accuracy': 0.6254600000000001}, {'accuracy': 0.76467}, {'accuracy': 0.7564900000000001}, {'accuracy': 0.56159}, {'accuracy': 0.62103}, {'accuracy': 0.6133500000000001}, {'accuracy': 0.66238}, {'accuracy': 0.7026399999999999}, {'accuracy': 0.57347}, {'accuracy': 0.69708}, {'accuracy': 0.46387}, {'accuracy': 0.6295900000000001}, {'accuracy': 0.59429}, {'accuracy': 0.54183}, {'accuracy': 0.51705}, {'accuracy': 0.62897}, {'accuracy': 0.68953}, {'accuracy': 0.61991}, {'accuracy': 0.7758}, {'accuracy': 0.6058999999999999}, {'accuracy': 0.66883}, {'accuracy': 0.6209999999999999}, {'accuracy': 0.53813}, {'accuracy': 0.5926499999999999}, {'accuracy': 0.6606400000000001}, {'accuracy': 0.75646}, {'accuracy': 0.5827699999999999}, {'accuracy': 0.43740000000000007}, {'accuracy': 0.67738}, {'accuracy': 0.6684699999999999}, {'accuracy': 0.69219}, {'accuracy': 0.62452}, {'accuracy': 0.68059}, {'accuracy': 0.6003100000000001}, {'accuracy': 0.6759999999999999}, {'accuracy': 0.6124499999999999}, {'accuracy': 0.66677}, {'accuracy': 0.66381}, {'accuracy': 0.77352}, {'accuracy': 0.77513}, {'accuracy': 0.63773}, {'accuracy': 0.6470499999999999}, {'accuracy': 0.5609400000000001}, {'accuracy': 0.61357}, {'accuracy': 0.6512800000000001}, {'accuracy': 0.81303}, {'accuracy': 0.7397}, {'accuracy': 0.75344}, {'accuracy': 0.69154}, {'accuracy': 0.63864}, {'accuracy': 0.46334}, {'accuracy': 0.67388}, {'accuracy': 0.6379699999999999}, {'accuracy': 0.75445}, {'accuracy': 0.5855600000000001}, {'accuracy': 0.63339}, {'accuracy': 0.6910499999999999}, {'accuracy': 0.56775}, {'accuracy': 0.6548100000000001}, {'accuracy': 0.6894699999999999}, {'accuracy': 0.6321200000000001}, {'accuracy': 0.62883}, {'accuracy': 0.76714}, {'accuracy': 0.69589}, {'accuracy': 0.77294}, {'accuracy': 0.59984}, {'accuracy': 0.64326}, {'accuracy': 0.7410599999999999}, {'accuracy': 0.66954}, {'accuracy': 0.68726}, {'accuracy': 0.6810200000000001}, {'accuracy': 0.6531499999999999}, {'accuracy': 0.6028}, {'accuracy': 0.64547}, {'accuracy': 0.48913}, {'accuracy': 0.58367}, {'accuracy': 0.76968}, {'accuracy': 0.76048}, {'accuracy': 0.61102}, {'accuracy': 0.87196}, {'accuracy': 0.89254}, {'accuracy': 0.7634200000000001}, {'accuracy': 0.95875}, {'accuracy': 0.9615199999999999}, {'accuracy': 0.9617699999999999}, {'accuracy': 0.95777}, {'accuracy': 0.9603999999999999}, {'accuracy': 0.9600299999999999}, {'accuracy': 0.9638300000000001}, {'accuracy': 0.95976}, {'accuracy': 0.95421}, {'accuracy': 0.9632599999999998}, {'accuracy': 0.9590199999999998}, {'accuracy': 0.9492900000000001}, {'accuracy': 0.9651099999999999}, {'accuracy': 0.96481}, {'accuracy': 0.95841}, {'accuracy': 0.95442}, {'accuracy': 0.9542999999999999}, {'accuracy': 0.9650599999999999}, {'accuracy': 0.96549}, {'accuracy': 0.96641}, {'accuracy': 0.9579599999999999}, {'accuracy': 0.95462}, {'accuracy': 0.9574800000000001}, {'accuracy': 0.9585600000000001}, {'accuracy': 0.96329}, {'accuracy': 0.96485}, {'accuracy': 0.96601}, {'accuracy': 0.9429299999999999}, {'accuracy': 0.95959}, {'accuracy': 0.95217}, {'accuracy': 0.95669}, {'accuracy': 0.9419599999999999}, {'accuracy': 0.9524900000000001}, {'accuracy': 0.95785}, {'accuracy': 0.9583999999999999}, {'accuracy': 0.9496100000000002}, {'accuracy': 0.9578199999999999}, {'accuracy': 0.9657500000000001}, {'accuracy': 0.9577200000000001}, {'accuracy': 0.9598599999999999}, {'accuracy': 0.9652200000000001}, {'accuracy': 0.95068}, {'accuracy': 0.95856}, {'accuracy': 0.9515899999999998}, {'accuracy': 0.9489099999999999}, {'accuracy': 0.96488}, {'accuracy': 0.96616}, {'accuracy': 0.95874}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.96555}, {'accuracy': 0.9477400000000001}, {'accuracy': 0.9492200000000001}, {'accuracy': 0.95809}, {'accuracy': 0.9559}, {'accuracy': 0.96577}, {'accuracy': 0.9578099999999999}, {'accuracy': 0.9666899999999998}, {'accuracy': 0.9661099999999999}, {'accuracy': 0.9663299999999999}, {'accuracy': 0.96646}, {'accuracy': 0.9582500000000002}, {'accuracy': 0.9491099999999999}, {'accuracy': 0.95759}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.9487900000000001}, {'accuracy': 0.9572499999999999}, {'accuracy': 0.95049}, {'accuracy': 0.9578599999999999}, {'accuracy': 0.95637}, {'accuracy': 0.95588}, {'accuracy': 0.95486}, {'accuracy': 0.95533}, {'accuracy': 0.96613}, {'accuracy': 0.95688}, {'accuracy': 0.9552099999999999}, {'accuracy': 0.9557399999999999}, {'accuracy': 0.94854}, {'accuracy': 0.9661099999999999}, {'accuracy': 0.9557899999999998}, {'accuracy': 0.9677199999999999}, {'accuracy': 0.9553600000000001}, {'accuracy': 0.9563200000000001}, {'accuracy': 0.94184}, {'accuracy': 0.9553100000000001}, {'accuracy': 0.9673}, {'accuracy': 0.9445}, {'accuracy': 0.95618}, {'accuracy': 0.95665}, {'accuracy': 0.96652}, {'accuracy': 0.95633}, {'accuracy': 0.9671899999999999}, {'accuracy': 0.9564599999999999}, {'accuracy': 0.9664300000000001}, {'accuracy': 0.92315}, {'accuracy': 0.9666599999999999}, {'accuracy': 0.9536999999999999}, {'accuracy': 0.9575799999999999}, {'accuracy': 0.9135300000000001}, {'accuracy': 0.94101}, {'accuracy': 0.9668999999999999}, {'accuracy': 0.94306}, {'accuracy': 0.9670399999999999}, {'accuracy': 0.96745}, {'accuracy': 0.9662200000000001}, {'accuracy': 0.95557}, {'accuracy': 0.96716}, {'accuracy': 0.9666599999999999}, {'accuracy': 0.9550099999999999}, {'accuracy': 0.94098}, {'accuracy': 0.9542299999999999}, {'accuracy': 0.9444100000000001}, {'accuracy': 0.9677000000000001}, {'accuracy': 0.9424899999999999}, {'accuracy': 0.95562}, {'accuracy': 0.9558099999999999}, {'accuracy': 0.95565}, {'accuracy': 0.9668199999999999}, {'accuracy': 0.9399899999999999}, {'accuracy': 0.9516199999999999}, {'accuracy': 0.96695}, {'accuracy': 0.9673000000000002}, {'accuracy': 0.9677700000000001}, {'accuracy': 0.94253}, {'accuracy': 0.9406699999999999}, {'accuracy': 0.9415099999999998}, {'accuracy': 0.9424999999999999}, {'accuracy': 0.93991}, {'accuracy': 0.9395100000000001}, {'accuracy': 0.9566400000000002}, {'accuracy': 0.9538800000000002}, {'accuracy': 0.9674999999999999}, {'accuracy': 0.9164499999999999}, {'accuracy': 0.9555399999999998}, {'accuracy': 0.9670700000000002}, {'accuracy': 0.9544499999999999}, {'accuracy': 0.9545899999999999}, {'accuracy': 0.94167}, {'accuracy': 0.9547700000000001}, {'accuracy': 0.95536}, {'accuracy': 0.9514999999999999}, {'accuracy': 0.9529700000000002}, {'accuracy': 0.9545000000000001}, {'accuracy': 0.9437599999999999}, {'accuracy': 0.9671200000000001}, {'accuracy': 0.9387000000000001}, {'accuracy': 0.9677900000000002}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0c930e5d-4523-4b85-ba76-dc41d90b1f52",
   "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.97</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.97\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACaGElEQVR4nO2dd5wTZf7HP+nZXtgKLCxNEOlwIAqCgGA97IieYIGzcRZOTzkVzvMUy+kPPQueZ72zYO+iiIAKqFQR6b1tYftutqTN749kJjOTSTZZks1u9vN+vfYFm0xmnjxJ9vnk8y2PThAEAYQQQgghcYI+1gMghBBCCIkkFDeEEEIIiSsobgghhBASV1DcEEIIISSuoLghhBBCSFxBcUMIIYSQuILihhBCCCFxBcUNIYQQQuIKihtCCCGExBUUN4SQqLJy5UrodDqsXLlSuu2aa65BYWFhzMYUT/ztb3+DTqeL9TAIaVNQ3BDSxvntt9/whz/8AV26dIHFYkHnzp1x1VVX4bfffov10KLOc889h1dffTWq19i2bRv+9re/4cCBA1G9Tmvy8MMP46OPPor1MAiJGRQ3hLRhPvjgAwwbNgzLly/Htddei+eeew7XX389VqxYgWHDhuHDDz+M9RCjSmuJmwceeIDihpA4whjrARBCtNm7dy+uvvpq9OzZE9999x2ys7Ol+2677TaMHTsWV199NbZs2YKePXu22rhsNhuSkpJa7XrtAc4JIW0LOjeEtFEef/xx1NfX49///rdC2ABAVlYWXnjhBdhsNjz22GMAgPfeew86nQ6rVq3yO9cLL7wAnU6HrVu3Srft2LEDl156KTIzM2G1WjFixAh88sknise9+uqr0jlvvvlm5OTkoGvXrgCAgwcP4uabb0bfvn2RkJCATp064bLLLouYA1JYWIjffvsNq1atgk6ng06nw/jx46X7q6qqcPvtt6OgoAAWiwW9e/fGo48+CrfbrTjP22+/jeHDhyMlJQWpqakYOHAgnnrqKen5XXbZZQCAM888U7qOPD9IzTXXXIPk5GTs3bsX5557LlJSUnDVVVcBANxuNxYtWoRTTjkFVqsVubm5uOGGG1BZWak4x/r16zFlyhRkZWUhISEBPXr0wHXXXSfdr5WnBAAHDhyATqcL6mbpdDrYbDa89tpr0vO55pprAAC1tbW4/fbbUVhYCIvFgpycHJx11lnYuHFjwPMR0h6hc0NIG+XTTz9FYWEhxo4dq3n/GWecgcLCQnz++ecAgPPOOw/Jycl45513MG7cOMWxS5YswSmnnIIBAwYA8OTxnH766ejSpQvuueceJCUl4Z133sGFF16I999/HxdddJHi8TfffDOys7Mxf/582Gw2AMC6deuwZs0aXHHFFejatSsOHDiA559/HuPHj8e2bduQmJh4Qs9/0aJF+NOf/oTk5GTce++9AIDc3FwAQH19PcaNG4ejR4/ihhtuQLdu3bBmzRrMmzcPRUVFWLRoEQBg2bJlmD59OiZOnIhHH30UALB9+3asXr0at912G8444wzceuutePrpp/HXv/4VJ598MgBI/wbC6XRiypQpGDNmDP75z39Kz/WGG27Aq6++imuvvRa33nor9u/fj2eeeQabNm3C6tWrYTKZUFpaismTJyM7Oxv33HMP0tPTceDAAXzwwQcnNF8i//3vfzFr1iyMHDkSf/zjHwEAvXr1AgDceOONeO+99zBnzhz0798f5eXl+OGHH7B9+3YMGzYsItcnpE0gEELaHFVVVQIAYerUqUGP+/3vfy8AEGpqagRBEITp06cLOTk5gtPplI4pKioS9Hq98Pe//126beLEicLAgQOFxsZG6Ta32y2cdtppQp8+faTbXnnlFQGAMGbMGMU5BUEQ6uvr/cazdu1aAYDw+uuvS7etWLFCACCsWLFCum3mzJlC9+7dgz43QRCEU045RRg3bpzf7Q8++KCQlJQk7Nq1S3H7PffcIxgMBuHQoUOCIAjCbbfdJqSmpvqNXc67777rN75gzJw5UwAg3HPPPYrbv//+ewGA8MYbbyhuX7p0qeL2Dz/8UAAgrFu3LuA1tOZMEARh//79AgDhlVdekW5bsGCBoP5TnpSUJMycOdPvvGlpacItt9wSwrMkpH3DsBQhbZDa2loAQEpKStDjxPtramoAANOmTUNpaakinPHee+/B7XZj2rRpAICKigp8++23uPzyy1FbW4uysjKUlZWhvLwcU6ZMwe7du3H06FHFdWbPng2DwaC4LSEhQfq/w+FAeXk5evfujfT09KiHOd59912MHTsWGRkZ0vjLysowadIkuFwufPfddwCA9PR02Gw2LFu2LOJjuOmmm/zGlJaWhrPOOksxpuHDhyM5ORkrVqyQxgQAn332GRwOR8THFYz09HT89NNPOHbsWKtel5DWhuKGkDaIKFpEkRMItQg6++yzkZaWhiVLlkjHLFmyBEOGDMFJJ50EANizZw8EQcD999+P7Oxsxc+CBQsAAKWlpYrr9OjRw+/aDQ0NmD9/vpTzkpWVhezsbFRVVaG6urqFzzw0du/ejaVLl/qNf9KkSYrx33zzzTjppJNwzjnnoGvXrrjuuuuwdOnSE76+0WiUco/kY6qurkZOTo7fuOrq6qQxjRs3DpdccgkeeOABZGVlYerUqXjllVfQ1NR0wuNqjsceewxbt25FQUEBRo4cib/97W/Yt29f1K9LSGvDnBtC2iBpaWnIz8/Hli1bgh63ZcsWdOnSBampqQAAi8WCCy+8EB9++CGee+45lJSUYPXq1Xj44Yelx4gJt3feeSemTJmied7evXsrfpe7NCJ/+tOf8Morr+D222/H6NGjkZaWBp1OhyuuuMIvqTfSuN1unHXWWfjLX/6ieb8o5HJycrB582Z89dVX+PLLL/Hll1/ilVdewYwZM/Daa6+1+PoWiwV6vfK7odvtRk5ODt544w3Nx4hJ4TqdDu+99x5+/PFHfPrpp/jqq69w3XXX4YknnsCPP/6I5OTkgE35XC5Xi8cMAJdffjnGjh2LDz/8EF9//TUef/xxPProo/jggw9wzjnnnNC5CWlLUNwQ0kY5//zz8eKLL+KHH37AmDFj/O7//vvvceDAAdxwww2K26dNm4bXXnsNy5cvx/bt2yEIghSSAiCVjZtMJsnpaAnvvfceZs6ciSeeeEK6rbGxEVVVVS0+p5pAi3yvXr1QV1cX0vjNZjMuuOACXHDBBXC73bj55pvxwgsv4P7770fv3r0j1t23V69e+Oabb3D66adrikE1p556Kk499VQ89NBDePPNN3HVVVfh7bffxqxZs5CRkQEAfnN58ODBkMYS7Dnl5+fj5ptvxs0334zS0lIMGzYMDz30EMUNiSsYliKkjXLXXXchISEBN9xwA8rLyxX3VVRU4MYbb0RiYiLuuusuxX2TJk1CZmYmlixZgiVLlmDkyJGKsFJOTg7Gjx+PF154AUVFRX7XPX78eEjjMxgMEARBcdu//vWvE3YX5CQlJWmKpcsvvxxr167FV1995XdfVVUVnE4nAPjNm16vx6BBgwBACgOJ/WlOVJRdfvnlcLlcePDBB/3uczqd0vkrKyv95m3IkCGKMXXv3h0Gg0HKHRJ57rnnQhqL1ry5XC6/cGFOTg46d+7cKiExQloTOjeEtFH69OmD1157DVdddRUGDhyI66+/Hj169MCBAwfw0ksvoaysDG+99ZZU5itiMplw8cUX4+2334bNZsM///lPv3M/++yzGDNmDAYOHIjZs2ejZ8+eKCkpwdq1a3HkyBH88ssvzY7v/PPPx3//+1+kpaWhf//+WLt2Lb755ht06tQpYnMwfPhwPP/88/jHP/6B3r17IycnBxMmTMBdd92FTz75BOeffz6uueYaDB8+HDabDb/++ivee+89HDhwAFlZWZg1axYqKiowYcIEdO3aFQcPHsS//vUvDBkyRCr3HjJkCAwGAx599FFUV1fDYrFgwoQJyMnJCWus48aNww033ICFCxdi8+bNmDx5MkwmE3bv3o13330XTz31FC699FK89tpreO6553DRRRehV69eqK2txYsvvojU1FSce+65ADxhycsuuwz/+te/oNPp0KtXL3z22Wd+uVDB5u2bb77Bk08+ic6dO6NHjx7o27cvunbtiksvvRSDBw9GcnIyvvnmG6xbt07hvhESF8S2WIsQ0hxbtmwRpk+fLuTn5wsmk0nIy8sTpk+fLvz6668BH7Ns2TIBgKDT6YTDhw9rHrN3715hxowZQl5enmAymYQuXboI559/vvDee+9Jx4il4Fply5WVlcK1114rZGVlCcnJycKUKVOEHTt2CN27d1eUIZ9IKXhxcbFw3nnnCSkpKQIARVl4bW2tMG/ePKF3796C2WwWsrKyhNNOO0345z//KdjtdkEQBOG9994TJk+eLOTk5Ahms1no1q2bcMMNNwhFRUWK67z44otCz549BYPB0GxZ+MyZM4WkpKSA9//73/8Whg8fLiQkJAgpKSnCwIEDhb/85S/CsWPHBEEQhI0bNwrTp08XunXrJlgsFiEnJ0c4//zzhfXr1yvOc/z4ceGSSy4REhMThYyMDOGGG24Qtm7dGlIp+I4dO4QzzjhDSEhIEAAIM2fOFJqamoS77rpLGDx4sJCSkiIkJSUJgwcPFp577rlgLwEh7RKdIKj8UUIIIYSQdgxzbgghhBASV1DcEEIIISSuoLghhBBCSFxBcUMIIYSQuILihhBCCCFxBcUNIYQQQuKKDtfEz+1249ixY0hJSYlY23VCCCGERBdBEFBbW4vOnTv77e2mdXDM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B0SYuiaxFJymGCGEEBILKG4izMFyTxJb14yEGI+EEEII6ZhQ3EQQu9ONI5UecdMjKynGoyGEEEI6JhQ3EeRwZT3cgiffJifFEuvhEEIIIS3G4XDEeggthuImghwoswEACjslsfyQEEJIWCxduhRjxoxBeno6OnXqhPPPPx979+6V7j9y5AimT5+OzMxMJCUlYcSIEfjpp5+k+z/99FP87ne/g9VqRVZWFi666CLpPp1Oh48++khxvfT0dLz66qsAgAMHDkCn02HJkiUYN24crFYr3njjDZSXl2P69Ono0qULEhMTMXDgQLz11luK87jdbjz22GPo3bs3LBYLunXrhoceeggAMGHCBMyZM0dx/PHjx2E2m7F8+fJITJsmzHqNIPu94oYhKUIIaRsIgiC16GhtEkyGsL7o2mw2zJ07F4MGDUJdXR3mz5+Piy66CJs3b0Z9fT3GjRuHLl264JNPPkFeXh42btwIt9uz5c/nn3+Oiy66CPfeey9ef/112O12fPHFF2GP+Z577sETTzyBoUOHwmq1orGxEcOHD8fdd9+N1NRUfP7557j66qvRq1cvjBw5EgAwb948vPjii/i///s/jBkzBkVFRdixYwcAYNasWZgzZw6eeOIJWCyeiMb//vc/dOnSBRMmTAh7fKFCcRNBRHFTmMX+CoQQ0hZocLjQf/5XMbn2tr9PQWIYlbOXXHKJ4veXX34Z2dnZ2LZtG9asWYPjx49j3bp1yMzMBAD07t1bOvahhx7CFVdcgQceeEC6bfDgwWGP+fbbb8fFF1+suO3OO++U/v+nP/0JX331Fd555x2MHDkStbW1eOqpp/DMM89g5syZAIBevXphzJgxAICLL74Yc+bMwccff4zLL78cAPDqq6/immuuiWqEg2GpCHKg3BeWIoQQQsJh9+7dmD59Onr27InU1FQUFhYCAA4dOoTNmzdj6NChkrBRs3nzZkycOPGExzBixAjF7y6XCw8++CAGDhyIzMxMJCcn46uvvsKhQ4cAANu3b0dTU1PAa1utVlx99dV4+eWXAQAbN27E1q1bcc0115zwWINB5yaC7D/uETc9syluCCGkLZBgMmDb36fE7NrhcMEFF6B79+548cUX0blzZ7jdbgwYMAB2ux0JCcHbizR3v06ngyAIitu0EoaTkpTr1+OPP46nnnoKixYtwsCBA5GUlITbb78d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\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.10371}, {'accuracy': 0.13035999999999998}, {'accuracy': 0.22509}, {'accuracy': 0.40145}, {'accuracy': 0.43794000000000005}, {'accuracy': 0.52083}, {'accuracy': 0.35517000000000004}, {'accuracy': 0.40774}, {'accuracy': 0.6538099999999999}, {'accuracy': 0.56517}, {'accuracy': 0.6745599999999999}, {'accuracy': 0.59864}, {'accuracy': 0.57575}, {'accuracy': 0.65711}, {'accuracy': 0.53028}, {'accuracy': 0.50668}, {'accuracy': 0.7130599999999999}, {'accuracy': 0.49974999999999997}, {'accuracy': 0.5603}, {'accuracy': 0.5301699999999999}, {'accuracy': 0.63943}, {'accuracy': 0.60187}, {'accuracy': 0.47169}, {'accuracy': 0.7506299999999999}, {'accuracy': 0.72165}, {'accuracy': 0.69264}, {'accuracy': 0.67947}, {'accuracy': 0.71806}, {'accuracy': 0.59061}, {'accuracy': 0.5016399999999999}, {'accuracy': 0.56246}, {'accuracy': 0.6503399999999999}, {'accuracy': 0.50944}, {'accuracy': 0.64131}, {'accuracy': 0.58095}, {'accuracy': 0.6681900000000001}, {'accuracy': 0.48446999999999996}, {'accuracy': 0.5406000000000001}, {'accuracy': 0.6132799999999999}, {'accuracy': 0.54242}, {'accuracy': 0.64178}, {'accuracy': 0.71483}, {'accuracy': 0.59374}, {'accuracy': 0.634}, {'accuracy': 0.6129800000000001}, {'accuracy': 0.7072499999999999}, {'accuracy': 0.6769000000000001}, {'accuracy': 0.5506399999999999}, {'accuracy': 0.62897}, {'accuracy': 0.5420499999999999}, {'accuracy': 0.61929}, {'accuracy': 0.65425}, {'accuracy': 0.70183}, {'accuracy': 0.45454}, {'accuracy': 0.6457200000000001}, {'accuracy': 0.70185}, {'accuracy': 0.76742}, {'accuracy': 0.67209}, {'accuracy': 0.7269500000000001}, {'accuracy': 0.7785900000000001}, {'accuracy': 0.7785299999999999}, {'accuracy': 0.64848}, {'accuracy': 0.67709}, {'accuracy': 0.63509}, {'accuracy': 0.55494}, {'accuracy': 0.60182}, {'accuracy': 0.6316200000000001}, {'accuracy': 0.65786}, {'accuracy': 0.7348399999999999}, {'accuracy': 0.5961000000000001}, {'accuracy': 0.60728}, {'accuracy': 0.6127500000000001}, {'accuracy': 0.6254600000000001}, {'accuracy': 0.76467}, {'accuracy': 0.7564900000000001}, {'accuracy': 0.56159}, {'accuracy': 0.62103}, {'accuracy': 0.6133500000000001}, {'accuracy': 0.66238}, {'accuracy': 0.7026399999999999}, {'accuracy': 0.57347}, {'accuracy': 0.69708}, {'accuracy': 0.46387}, {'accuracy': 0.6295900000000001}, {'accuracy': 0.59429}, {'accuracy': 0.54183}, {'accuracy': 0.51705}, {'accuracy': 0.62897}, {'accuracy': 0.68953}, {'accuracy': 0.61991}, {'accuracy': 0.7758}, {'accuracy': 0.6058999999999999}, {'accuracy': 0.66883}, {'accuracy': 0.6209999999999999}, {'accuracy': 0.53813}, {'accuracy': 0.5926499999999999}, {'accuracy': 0.6606400000000001}, {'accuracy': 0.75646}, {'accuracy': 0.5827699999999999}, {'accuracy': 0.43740000000000007}, {'accuracy': 0.67738}, {'accuracy': 0.6684699999999999}, {'accuracy': 0.69219}, {'accuracy': 0.62452}, {'accuracy': 0.68059}, {'accuracy': 0.6003100000000001}, {'accuracy': 0.6759999999999999}, {'accuracy': 0.6124499999999999}, {'accuracy': 0.66677}, {'accuracy': 0.66381}, {'accuracy': 0.77352}, {'accuracy': 0.77513}, {'accuracy': 0.63773}, {'accuracy': 0.6470499999999999}, {'accuracy': 0.5609400000000001}, {'accuracy': 0.61357}, {'accuracy': 0.6512800000000001}, {'accuracy': 0.81303}, {'accuracy': 0.7397}, {'accuracy': 0.75344}, {'accuracy': 0.69154}, {'accuracy': 0.63864}, {'accuracy': 0.46334}, {'accuracy': 0.67388}, {'accuracy': 0.6379699999999999}, {'accuracy': 0.75445}, {'accuracy': 0.5855600000000001}, {'accuracy': 0.63339}, {'accuracy': 0.6910499999999999}, {'accuracy': 0.56775}, {'accuracy': 0.6548100000000001}, {'accuracy': 0.6894699999999999}, {'accuracy': 0.6321200000000001}, {'accuracy': 0.62883}, {'accuracy': 0.76714}, {'accuracy': 0.69589}, {'accuracy': 0.77294}, {'accuracy': 0.59984}, {'accuracy': 0.64326}, {'accuracy': 0.7410599999999999}, {'accuracy': 0.66954}, {'accuracy': 0.68726}, {'accuracy': 0.6810200000000001}, {'accuracy': 0.6531499999999999}, {'accuracy': 0.6028}, {'accuracy': 0.64547}, {'accuracy': 0.48913}, {'accuracy': 0.58367}, {'accuracy': 0.76968}, {'accuracy': 0.76048}, {'accuracy': 0.61102}, {'accuracy': 0.87196}, {'accuracy': 0.89254}, {'accuracy': 0.7634200000000001}, {'accuracy': 0.95875}, {'accuracy': 0.9615199999999999}, {'accuracy': 0.9617699999999999}, {'accuracy': 0.95777}, {'accuracy': 0.9603999999999999}, {'accuracy': 0.9600299999999999}, {'accuracy': 0.9638300000000001}, {'accuracy': 0.95976}, {'accuracy': 0.95421}, {'accuracy': 0.9632599999999998}, {'accuracy': 0.9590199999999998}, {'accuracy': 0.9492900000000001}, {'accuracy': 0.9651099999999999}, {'accuracy': 0.96481}, {'accuracy': 0.95841}, {'accuracy': 0.95442}, {'accuracy': 0.9542999999999999}, {'accuracy': 0.9650599999999999}, {'accuracy': 0.96549}, {'accuracy': 0.96641}, {'accuracy': 0.9579599999999999}, {'accuracy': 0.95462}, {'accuracy': 0.9574800000000001}, {'accuracy': 0.9585600000000001}, {'accuracy': 0.96329}, {'accuracy': 0.96485}, {'accuracy': 0.96601}, {'accuracy': 0.9429299999999999}, {'accuracy': 0.95959}, {'accuracy': 0.95217}, {'accuracy': 0.95669}, {'accuracy': 0.9419599999999999}, {'accuracy': 0.9524900000000001}, {'accuracy': 0.95785}, {'accuracy': 0.9583999999999999}, {'accuracy': 0.9496100000000002}, {'accuracy': 0.9578199999999999}, {'accuracy': 0.9657500000000001}, {'accuracy': 0.9577200000000001}, {'accuracy': 0.9598599999999999}, {'accuracy': 0.9652200000000001}, {'accuracy': 0.95068}, {'accuracy': 0.95856}, {'accuracy': 0.9515899999999998}, {'accuracy': 0.9489099999999999}, {'accuracy': 0.96488}, {'accuracy': 0.96616}, {'accuracy': 0.95874}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.96555}, {'accuracy': 0.9477400000000001}, {'accuracy': 0.9492200000000001}, {'accuracy': 0.95809}, {'accuracy': 0.9559}, {'accuracy': 0.96577}, {'accuracy': 0.9578099999999999}, {'accuracy': 0.9666899999999998}, {'accuracy': 0.9661099999999999}, {'accuracy': 0.9663299999999999}, {'accuracy': 0.96646}, {'accuracy': 0.9582500000000002}, {'accuracy': 0.9491099999999999}, {'accuracy': 0.95759}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.9487900000000001}, {'accuracy': 0.9572499999999999}, {'accuracy': 0.95049}, {'accuracy': 0.9578599999999999}, {'accuracy': 0.95637}, {'accuracy': 0.95588}, {'accuracy': 0.95486}, {'accuracy': 0.95533}, {'accuracy': 0.96613}, {'accuracy': 0.95688}, {'accuracy': 0.9552099999999999}, {'accuracy': 0.9557399999999999}, {'accuracy': 0.94854}, {'accuracy': 0.9661099999999999}, {'accuracy': 0.9557899999999998}, {'accuracy': 0.9677199999999999}, {'accuracy': 0.9553600000000001}, {'accuracy': 0.9563200000000001}, {'accuracy': 0.94184}, {'accuracy': 0.9553100000000001}, {'accuracy': 0.9673}, {'accuracy': 0.9445}, {'accuracy': 0.95618}, {'accuracy': 0.95665}, {'accuracy': 0.96652}, {'accuracy': 0.95633}, {'accuracy': 0.9671899999999999}, {'accuracy': 0.9564599999999999}, {'accuracy': 0.9664300000000001}, {'accuracy': 0.92315}, {'accuracy': 0.9666599999999999}, {'accuracy': 0.9536999999999999}, {'accuracy': 0.9575799999999999}, {'accuracy': 0.9135300000000001}, {'accuracy': 0.94101}, {'accuracy': 0.9668999999999999}, {'accuracy': 0.94306}, {'accuracy': 0.9670399999999999}, {'accuracy': 0.96745}, {'accuracy': 0.9662200000000001}, {'accuracy': 0.95557}, {'accuracy': 0.96716}, {'accuracy': 0.9666599999999999}, {'accuracy': 0.9550099999999999}, {'accuracy': 0.94098}, {'accuracy': 0.9542299999999999}, {'accuracy': 0.9444100000000001}, {'accuracy': 0.9677000000000001}, {'accuracy': 0.9424899999999999}, {'accuracy': 0.95562}, {'accuracy': 0.9558099999999999}, {'accuracy': 0.95565}, {'accuracy': 0.9668199999999999}, {'accuracy': 0.9399899999999999}, {'accuracy': 0.9516199999999999}, {'accuracy': 0.96695}, {'accuracy': 0.9673000000000002}, {'accuracy': 0.9677700000000001}, {'accuracy': 0.94253}, {'accuracy': 0.9406699999999999}, {'accuracy': 0.9415099999999998}, {'accuracy': 0.9424999999999999}, {'accuracy': 0.93991}, {'accuracy': 0.9395100000000001}, {'accuracy': 0.9566400000000002}, {'accuracy': 0.9538800000000002}, {'accuracy': 0.9674999999999999}, {'accuracy': 0.9164499999999999}, {'accuracy': 0.9555399999999998}, {'accuracy': 0.9670700000000002}, {'accuracy': 0.9544499999999999}, {'accuracy': 0.9545899999999999}, {'accuracy': 0.94167}, {'accuracy': 0.9547700000000001}, {'accuracy': 0.95536}, {'accuracy': 0.9514999999999999}, {'accuracy': 0.9529700000000002}, {'accuracy': 0.9545000000000001}, {'accuracy': 0.9437599999999999}, {'accuracy': 0.9671200000000001}, {'accuracy': 0.9387000000000001}, {'accuracy': 0.9677900000000002}]\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": "98d2bbdb-24e7-445d-9608-12716c3ed32a",
   "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
}
