{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2318]\n",
      " [   1   65]\n",
      " [   2   46]\n",
      " [   3   70]\n",
      " [   4   97]\n",
      " [   5  166]\n",
      " [   6  290]\n",
      " [   7  533]\n",
      " [   8  879]\n",
      " [   9 1471]]\n",
      "[[   0 1424]\n",
      " [   1 2718]\n",
      " [   2   53]\n",
      " [   3   38]\n",
      " [   4   51]\n",
      " [   5  100]\n",
      " [   6  190]\n",
      " [   7  304]\n",
      " [   8  522]\n",
      " [   9  832]]\n",
      "[[   0  863]\n",
      " [   1 1527]\n",
      " [   2 2381]\n",
      " [   3   64]\n",
      " [   4   28]\n",
      " [   5   62]\n",
      " [   6  114]\n",
      " [   7  183]\n",
      " [   8  288]\n",
      " [   9  514]]\n",
      "[[   0  498]\n",
      " [   1 1008]\n",
      " [   2 1404]\n",
      " [   3 2485]\n",
      " [   4   69]\n",
      " [   5   34]\n",
      " [   6   57]\n",
      " [   7  118]\n",
      " [   8  171]\n",
      " [   9  293]]\n",
      "[[   0  324]\n",
      " [   1  591]\n",
      " [   2  875]\n",
      " [   3 1432]\n",
      " [   4 2339]\n",
      " [   5   58]\n",
      " [   6   43]\n",
      " [   7   65]\n",
      " [   8  110]\n",
      " [   9  200]]\n",
      "[[   0  186]\n",
      " [   1  368]\n",
      " [   2  509]\n",
      " [   3  909]\n",
      " [   4 1424]\n",
      " [   5 2081]\n",
      " [   6   70]\n",
      " [   7   40]\n",
      " [   8   71]\n",
      " [   9  101]]\n",
      "[[   0  128]\n",
      " [   1  225]\n",
      " [   2  304]\n",
      " [   3  500]\n",
      " [   4  827]\n",
      " [   5 1367]\n",
      " [   6 2331]\n",
      " [   7   68]\n",
      " [   8   32]\n",
      " [   9   65]]\n",
      "[[   0   73]\n",
      " [   1  127]\n",
      " [   2  192]\n",
      " [   3  339]\n",
      " [   4  520]\n",
      " [   5  777]\n",
      " [   6 1426]\n",
      " [   7 2571]\n",
      " [   8   61]\n",
      " [   9   36]]\n",
      "[[   0   42]\n",
      " [   1   68]\n",
      " [   2  118]\n",
      " [   3  171]\n",
      " [   4  294]\n",
      " [   5  478]\n",
      " [   6  893]\n",
      " [   7 1475]\n",
      " [   8 2303]\n",
      " [   9   55]]\n",
      "[[   0   67]\n",
      " [   1   45]\n",
      " [   2   76]\n",
      " [   3  123]\n",
      " [   4  193]\n",
      " [   5  298]\n",
      " [   6  504]\n",
      " [   7  908]\n",
      " [   8 1414]\n",
      " [   9 2382]]\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": [
      "6035\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2161]\n",
      " [   1   58]\n",
      " [   2   41]\n",
      " [   3   65]\n",
      " [   4   85]\n",
      " [   5  151]\n",
      " [   6  258]\n",
      " [   7  469]\n",
      " [   8  801]\n",
      " [   9 1308]]\n",
      "[[   0 2408]\n",
      " [   1   64]\n",
      " [   2   42]\n",
      " [   3   71]\n",
      " [   4   99]\n",
      " [   5  170]\n",
      " [   6  293]\n",
      " [   7  515]\n",
      " [   8  886]\n",
      " [   9 1437]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 8, 8, 8])"
      ]
     },
     "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<1:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        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,  ..., 8, 8, 8])"
      ]
     },
     "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:09:39 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:09:39\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": "b60d260b3b08428b8c4d45ac517d9cec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-22:57:38 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3280</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:57:38\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3280\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\">71635200</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;36m71635200\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.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": "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/ICcnByUl5e7fZEnrnNDREQUOF5PBb/66qsBANdff73brClBEKBQKOBwOHzXuhBRF268zpJERETkJa/DzerVq/3RjpBWt4hfkBtCRETUCngdbjIyMpCWluax1o0gCDh58qTPGhZK6hbxY+WGiIjI37y+22ZkZKCgoMDjeHFxMTIyMnzSqFBTN6A4yA0hIiJqBby+3Ypja+qrrKyEXq/3SaNCjTgVXM3KDRERkd81u1tq2rRpAACFQoGZM2fCaDRK5xwOB/744w/06dPH5w0MBWLlRsnZUkRERH7X7HCzY8cOAK7Kza5du6DVaqVzWq0WmZmZeOKJJ3zfwhBQV7lhuCEiIvK3ZocbcZbUxIkT8eabb8JkMvmtUaFGqtxwbykiIiK/83oQyMcffwyTyYTDhw9j+fLlqK6uBuCq6FDDnAIrN0RERIHidbgpLi7GiBEj0LlzZ1x99dXIyckBANx77714/PHHfd7AUGB3cMwNERFRoHgdbh599FFoNBpkZ2e7DSoeM2YMli1b5tPGhQoHKzdEREQB4/Uifr/88guWL1+O1NRUt+OdOnXCiRMnfNawUOJwOgFwbykiIqJA8LpyU1VV5VaxERUXF0On0/mkUaHG4co2DDdEREQB4HW4GTp0KD799FPpe4VCAafTiVdffRWXX365TxsXKsTKDbuliIiI/M/rbqlXX30VI0aMwNatW2G1WvHUU09hz549KC4uxvr16/3RxgueWLnhgGIiIiL/87py07NnTxw8eBBDhgzBDTfcgKqqKtx8883YsWMHOnTo4I82XvBYuSEiIgocrys3ABAZGYlnnnnG120JWVzEj4iIKHDOKdzU1NRg586dyM/Ph7O2KiG6/vrrfdKwUMJF/IiIiALH63CzbNkyjB8/HoWFhR7nFAoFHA6HTxoWSriIHxERUeB4PebmoYcewm233YacnBw4nU63LwabhnERPyIiosDxOtzk5eVh2rRpSEhI8Ed7QpKjdswN17khIiLyP6/Dza233oo1a9b4oSmhi+GGiIgocLwec/P222/jtttuw++//45evXpBo9G4nX/44Yd91rhQwXBDREQUOF6Hmy+//BK//PIL9Ho91qxZA4VserNCoWC4aQDDDRERUeB4HW6eeeYZPP/885g+fTqUSq97tVolKdxwnRsiIiK/8zqdWK1WjBkzhsHGC+JsKVZuiIiI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O3bEhx9+2Oh7rVu3DkOHDoXBYEBaWhoefvhhVFVV+fXzEZH/MdwQUYsyY8YMvPzyy5g5cyb27t2LL774AgkJCZg0aRK++OILWCwW6bGfffYZUlJSMHz4cADA+PHj8eWXX+Jf//oX9u3bh/fffx/h4eENvs+RI0dw5ZVX4pZbbsHOnTuxePFirFu3ziNAEdGFhxtnElGLUVFRgbi4OLz99tuYNGmS27mamhokJydj/vz5uP322wEAmZmZuPnmmzF79mwcPHgQXbp0wYoVKzBy5EiP116zZg0uv/xylJSUICoqCpMmTYJKpcL7778vPWbdunUYNmwYqqqqoNfr/fthichvWLkhohZj3759sFgsGDFihMc5vV6Pu+66Cx999BEAYPv27di9ezfuvvtuAEBWVhZUKhWGDRvWrPf6888/sXDhQoSHh0tfo0ePhtPpxLFjx3z2mYgo8NTBbgARkchgMDR5ftKkSejTpw9OnTqFjz/+GMOHD0e7du2a9dz6KisrMWXKFDz88MMe59q2bevVaxFRy8LKDRG1GJ06dYLBYJAGCNfXq1cvDBgwAAsWLMAXX3yBe+65x+2c0+nE2rVrm/Ve/fr1w969e9GxY0ePL61W65PPQ0TBwXBDRC2GXq/H008/jaeeegqffvopjhw5gk2bNrnNeJo0aRJefvllCIKAm266STqenp6OCRMm4J577sG3336LY8eOYc2aNfjqq68afK+nn34aGzZswNSpU5GVlYVDhw7hu+++44BiohDAcENELcrMmTPx+OOPY9asWejWrRvGjBmD/Px86fzYsWOhVqsxduxYj0G/7733Hm699VY88MAD6Nq1KyZPntzo1O7evXtj7dq1OHjwIIYOHYq+ffti1qxZSE5O9uvnIyL/42wpIrqgHD9+HB06dMCWLVvQr1+/YDeHiFoghhsiuiDYbDYUFRXhiSeewLFjx7B+/fpgN4mIWih2SxHRBWH9+vVISkrCli1bMH/+/GA3h4haMFZuiIiIKKSwckNEREQhheGGiIiIQgrDDREREYUUhhsiIiIKKQw3REREFFIYboiIiCikMNwQERFRSGG4ISIiopDCcENEREQh5f8BHjNebXz386AAAAAASUVORK5CYII=\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.15213000000000002}, {'accuracy': 0.19876}, {'accuracy': 0.28065}, {'accuracy': 0.3757}, {'accuracy': 0.37888}, {'accuracy': 0.64586}, {'accuracy': 0.61418}, {'accuracy': 0.5835100000000001}, {'accuracy': 0.66}, {'accuracy': 0.6090099999999999}, {'accuracy': 0.69059}, {'accuracy': 0.69265}, {'accuracy': 0.71639}, {'accuracy': 0.74458}, {'accuracy': 0.73024}, {'accuracy': 0.71285}, {'accuracy': 0.76173}, {'accuracy': 0.75688}, {'accuracy': 0.7955699999999999}, {'accuracy': 0.7524900000000001}, {'accuracy': 0.81038}, {'accuracy': 0.7992699999999999}, {'accuracy': 0.7722800000000001}, {'accuracy': 0.7645200000000001}, {'accuracy': 0.82501}, {'accuracy': 0.83863}, {'accuracy': 0.8433400000000001}, {'accuracy': 0.78302}, {'accuracy': 0.8455199999999999}, {'accuracy': 0.8151999999999999}, {'accuracy': 0.8130599999999999}, {'accuracy': 0.8045500000000001}, {'accuracy': 0.81852}, {'accuracy': 0.83238}, {'accuracy': 0.81476}, {'accuracy': 0.8496600000000001}, {'accuracy': 0.8535300000000001}, {'accuracy': 0.86535}, {'accuracy': 0.82308}, {'accuracy': 0.8419399999999999}, {'accuracy': 0.7929}, {'accuracy': 0.8540599999999999}, {'accuracy': 0.8048400000000001}, {'accuracy': 0.81966}, {'accuracy': 0.8402}, {'accuracy': 0.8859999999999999}, {'accuracy': 0.7981800000000001}, {'accuracy': 0.86592}, {'accuracy': 0.8544499999999999}, {'accuracy': 0.75616}, {'accuracy': 0.8205500000000001}, {'accuracy': 0.8836300000000001}, {'accuracy': 0.83323}, {'accuracy': 0.8024899999999999}, {'accuracy': 0.85832}, {'accuracy': 0.8342499999999999}, {'accuracy': 0.7819499999999999}, {'accuracy': 0.82111}, {'accuracy': 0.84587}, {'accuracy': 0.8118299999999999}, {'accuracy': 0.83255}, {'accuracy': 0.83596}, {'accuracy': 0.85574}, {'accuracy': 0.8009600000000001}, {'accuracy': 0.8201}, {'accuracy': 0.82478}, {'accuracy': 0.8421899999999999}, {'accuracy': 0.85161}, {'accuracy': 0.88148}, {'accuracy': 0.8922100000000001}, {'accuracy': 0.8696499999999998}, {'accuracy': 0.9260400000000001}, {'accuracy': 0.85376}, {'accuracy': 0.87271}, {'accuracy': 0.8547699999999999}, {'accuracy': 0.8559300000000001}, {'accuracy': 0.92332}, {'accuracy': 0.91098}, {'accuracy': 0.8865299999999999}, {'accuracy': 0.90829}, {'accuracy': 0.8813000000000001}, {'accuracy': 0.86947}, {'accuracy': 0.7961400000000001}, {'accuracy': 0.83672}, {'accuracy': 0.84046}, {'accuracy': 0.89161}, {'accuracy': 0.8030899999999999}, {'accuracy': 0.8689600000000001}, {'accuracy': 0.8574999999999999}, {'accuracy': 0.84748}, {'accuracy': 0.85838}, {'accuracy': 0.88529}, {'accuracy': 0.87381}, {'accuracy': 0.91618}, {'accuracy': 0.8036100000000002}, {'accuracy': 0.8144399999999999}, {'accuracy': 0.8815500000000001}, {'accuracy': 0.87834}, {'accuracy': 0.8651399999999999}, {'accuracy': 0.84579}, {'accuracy': 0.85122}, {'accuracy': 0.89664}, {'accuracy': 0.86854}, {'accuracy': 0.8547800000000001}, {'accuracy': 0.9226700000000001}, {'accuracy': 0.86455}, {'accuracy': 0.84299}, {'accuracy': 0.85592}, {'accuracy': 0.87389}, {'accuracy': 0.85946}, {'accuracy': 0.8922399999999999}, {'accuracy': 0.85997}, {'accuracy': 0.87916}, {'accuracy': 0.8340400000000001}, {'accuracy': 0.9163200000000001}, {'accuracy': 0.8577199999999999}, {'accuracy': 0.85548}, {'accuracy': 0.8627699999999999}, {'accuracy': 0.90961}, {'accuracy': 0.8766700000000001}, {'accuracy': 0.84856}, {'accuracy': 0.8395400000000001}, {'accuracy': 0.88695}, {'accuracy': 0.87904}, {'accuracy': 0.8843}, {'accuracy': 0.85213}, {'accuracy': 0.8436199999999999}, {'accuracy': 0.8748299999999999}, {'accuracy': 0.89293}, {'accuracy': 0.8904}, {'accuracy': 0.8283400000000001}, {'accuracy': 0.8982899999999999}, {'accuracy': 0.86961}, {'accuracy': 0.89861}, {'accuracy': 0.8882199999999999}, {'accuracy': 0.8722100000000002}, {'accuracy': 0.9062899999999999}, {'accuracy': 0.868}, {'accuracy': 0.89255}, {'accuracy': 0.87529}, {'accuracy': 0.853}, {'accuracy': 0.9018799999999999}, {'accuracy': 0.9038}, {'accuracy': 0.8873999999999999}, {'accuracy': 0.8858}, {'accuracy': 0.8704500000000002}, {'accuracy': 0.8936}, {'accuracy': 0.8982700000000001}, {'accuracy': 0.8664400000000001}, {'accuracy': 0.87906}, {'accuracy': 0.8821199999999999}, {'accuracy': 0.9430200000000001}, {'accuracy': 0.9717100000000001}, {'accuracy': 0.9565100000000001}, {'accuracy': 0.9730099999999998}, {'accuracy': 0.97066}, {'accuracy': 0.9719599999999999}, {'accuracy': 0.9718600000000001}, {'accuracy': 0.9714500000000001}, {'accuracy': 0.9716799999999999}, {'accuracy': 0.97028}, {'accuracy': 0.9711500000000001}, {'accuracy': 0.9704200000000001}, {'accuracy': 0.96998}, {'accuracy': 0.9713}, {'accuracy': 0.9710400000000001}, {'accuracy': 0.9711500000000001}, {'accuracy': 0.9717500000000001}, {'accuracy': 0.97112}, {'accuracy': 0.97158}, {'accuracy': 0.9709199999999999}, {'accuracy': 0.9710999999999999}, {'accuracy': 0.9706100000000001}, {'accuracy': 0.9712999999999999}, {'accuracy': 0.9712299999999999}, {'accuracy': 0.9714299999999998}, {'accuracy': 0.97061}, {'accuracy': 0.9718}, {'accuracy': 0.9705799999999998}, {'accuracy': 0.97123}, {'accuracy': 0.97104}, {'accuracy': 0.9713199999999999}, {'accuracy': 0.9709900000000001}, {'accuracy': 0.9722099999999999}, {'accuracy': 0.9717799999999999}, {'accuracy': 0.97156}, {'accuracy': 0.9713499999999999}, {'accuracy': 0.9700599999999999}, {'accuracy': 0.9715599999999999}, {'accuracy': 0.97187}, {'accuracy': 0.97134}, {'accuracy': 0.97231}, {'accuracy': 0.9712799999999999}, {'accuracy': 0.9719099999999999}, {'accuracy': 0.9702200000000001}, {'accuracy': 0.9712799999999999}, {'accuracy': 0.9711799999999998}, {'accuracy': 0.9702900000000001}, {'accuracy': 0.97075}, {'accuracy': 0.9707799999999999}, {'accuracy': 0.97072}, {'accuracy': 0.9718600000000001}, {'accuracy': 0.9709200000000001}, {'accuracy': 0.9706999999999999}, {'accuracy': 0.9715299999999999}, {'accuracy': 0.97151}, {'accuracy': 0.9714}, {'accuracy': 0.97183}, {'accuracy': 0.9718600000000001}, {'accuracy': 0.9703399999999999}, {'accuracy': 0.96943}, {'accuracy': 0.9710700000000001}, {'accuracy': 0.97101}, {'accuracy': 0.9712999999999999}, {'accuracy': 0.9708399999999999}, {'accuracy': 0.9715}, {'accuracy': 0.97133}, {'accuracy': 0.9711000000000001}, {'accuracy': 0.9716800000000001}, {'accuracy': 0.97163}, {'accuracy': 0.9711000000000001}, {'accuracy': 0.9723200000000002}, {'accuracy': 0.97191}, {'accuracy': 0.9725499999999998}, {'accuracy': 0.9715900000000002}, {'accuracy': 0.9709299999999998}, {'accuracy': 0.9719599999999999}, {'accuracy': 0.9710300000000001}, {'accuracy': 0.9718899999999999}, {'accuracy': 0.9710599999999999}, {'accuracy': 0.97188}, {'accuracy': 0.9720300000000002}, {'accuracy': 0.97187}, {'accuracy': 0.9717400000000002}, {'accuracy': 0.9711400000000001}, {'accuracy': 0.97112}, {'accuracy': 0.9707800000000001}, {'accuracy': 0.9714599999999999}, {'accuracy': 0.97094}, {'accuracy': 0.9722199999999999}, {'accuracy': 0.9721499999999998}, {'accuracy': 0.9715}, {'accuracy': 0.9722900000000001}, {'accuracy': 0.9720000000000001}, {'accuracy': 0.9713900000000001}, {'accuracy': 0.97212}, {'accuracy': 0.9712}, {'accuracy': 0.97148}, {'accuracy': 0.9719399999999998}, {'accuracy': 0.97104}, {'accuracy': 0.97198}, {'accuracy': 0.97054}, {'accuracy': 0.9715199999999999}, {'accuracy': 0.9707500000000001}, {'accuracy': 0.9723}, {'accuracy': 0.9708799999999999}, {'accuracy': 0.97244}, {'accuracy': 0.9714499999999999}, {'accuracy': 0.9708399999999999}, {'accuracy': 0.9711500000000001}, {'accuracy': 0.9704}, {'accuracy': 0.9709300000000001}, {'accuracy': 0.9708500000000001}, {'accuracy': 0.9709200000000001}, {'accuracy': 0.97108}, {'accuracy': 0.9723}, {'accuracy': 0.9713200000000001}, {'accuracy': 0.9715699999999998}, {'accuracy': 0.9715599999999999}, {'accuracy': 0.9717899999999998}, {'accuracy': 0.9723900000000001}, {'accuracy': 0.97159}, {'accuracy': 0.9719}, {'accuracy': 0.97205}, {'accuracy': 0.97188}, {'accuracy': 0.9704600000000001}, {'accuracy': 0.9721300000000002}, {'accuracy': 0.97115}, {'accuracy': 0.9708300000000001}, {'accuracy': 0.97287}, {'accuracy': 0.9712200000000001}, {'accuracy': 0.97157}, {'accuracy': 0.97181}, {'accuracy': 0.97208}, {'accuracy': 0.9721400000000001}, {'accuracy': 0.9718900000000001}, {'accuracy': 0.9703199999999998}, {'accuracy': 0.97291}, {'accuracy': 0.9716099999999999}, {'accuracy': 0.97231}, {'accuracy': 0.97195}, {'accuracy': 0.9723}, {'accuracy': 0.9723}, {'accuracy': 0.9704200000000001}, {'accuracy': 0.97104}, {'accuracy': 0.9723599999999999}, {'accuracy': 0.9724299999999999}, {'accuracy': 0.9712500000000001}, {'accuracy': 0.9722000000000002}, {'accuracy': 0.97165}]\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": "5bce0ec2-4f19-4328-81f8-e044940d3005",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91eec614-2442-4ca0-9b17-444ded3f0e6c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b655daa-725a-4fa4-b455-35f11ad77c28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f4aa798b-e33c-4912-bf5a-9f0db9cf8079",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c292b35-8bcc-45f8-94f4-ac36bad83777",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae7ae1a5-d387-42d5-a8bf-95db6a0d2020",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5476139-63d1-49f5-a3ef-d04605ea4581",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3276d5f5-663c-4ee8-98ff-00206a5ff678",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e77448e-4251-4e49-9652-9beb89b097df",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f42ced50-18b0-498a-824f-9682083bc62d",
   "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
}
