{
 "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 2403]\n",
      " [   1   77]\n",
      " [   2   40]\n",
      " [   3   82]\n",
      " [   4  117]\n",
      " [   5  166]\n",
      " [   6  288]\n",
      " [   7  531]\n",
      " [   8  853]\n",
      " [   9 1436]]\n",
      "[[   0 1362]\n",
      " [   1 2669]\n",
      " [   2   61]\n",
      " [   3   49]\n",
      " [   4   63]\n",
      " [   5   96]\n",
      " [   6  163]\n",
      " [   7  325]\n",
      " [   8  509]\n",
      " [   9  902]]\n",
      "[[   0  844]\n",
      " [   1 1569]\n",
      " [   2 2393]\n",
      " [   3   53]\n",
      " [   4   32]\n",
      " [   5   63]\n",
      " [   6  118]\n",
      " [   7  186]\n",
      " [   8  314]\n",
      " [   9  503]]\n",
      "[[   0  559]\n",
      " [   1 1013]\n",
      " [   2 1368]\n",
      " [   3 2375]\n",
      " [   4   81]\n",
      " [   5   38]\n",
      " [   6   62]\n",
      " [   7  112]\n",
      " [   8  186]\n",
      " [   9  326]]\n",
      "[[   0  289]\n",
      " [   1  599]\n",
      " [   2  867]\n",
      " [   3 1505]\n",
      " [   4 2332]\n",
      " [   5   43]\n",
      " [   6   39]\n",
      " [   7   65]\n",
      " [   8  103]\n",
      " [   9  195]]\n",
      "[[   0  167]\n",
      " [   1  347]\n",
      " [   2  527]\n",
      " [   3  927]\n",
      " [   4 1402]\n",
      " [   5 2208]\n",
      " [   6   58]\n",
      " [   7   46]\n",
      " [   8   72]\n",
      " [   9  113]]\n",
      "[[   0  121]\n",
      " [   1  214]\n",
      " [   2  312]\n",
      " [   3  548]\n",
      " [   4  864]\n",
      " [   5 1307]\n",
      " [   6 2374]\n",
      " [   7   59]\n",
      " [   8   47]\n",
      " [   9   61]]\n",
      "[[   0   72]\n",
      " [   1  130]\n",
      " [   2  207]\n",
      " [   3  296]\n",
      " [   4  466]\n",
      " [   5  801]\n",
      " [   6 1469]\n",
      " [   7 2607]\n",
      " [   8   52]\n",
      " [   9   39]]\n",
      "[[   0   41]\n",
      " [   1   84]\n",
      " [   2  104]\n",
      " [   3  191]\n",
      " [   4  301]\n",
      " [   5  442]\n",
      " [   6  837]\n",
      " [   7 1474]\n",
      " [   8 2306]\n",
      " [   9   66]]\n",
      "[[   0   65]\n",
      " [   1   40]\n",
      " [   2   79]\n",
      " [   3  105]\n",
      " [   4  184]\n",
      " [   5  257]\n",
      " [   6  510]\n",
      " [   7  860]\n",
      " [   8 1409]\n",
      " [   9 2308]]\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": [
      "18022\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1681]\n",
      " [   1   54]\n",
      " [   2   31]\n",
      " [   3   54]\n",
      " [   4   79]\n",
      " [   5  112]\n",
      " [   6  191]\n",
      " [   7  366]\n",
      " [   8  609]\n",
      " [   9 1021]]\n",
      "[[   0 2389]\n",
      " [   1   70]\n",
      " [   2   42]\n",
      " [   3   67]\n",
      " [   4  114]\n",
      " [   5  169]\n",
      " [   6  298]\n",
      " [   7  499]\n",
      " [   8  870]\n",
      " [   9 1463]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "# noiseyset=[],[]\n",
    "# healthset=[],[],[]\n",
    "# import random\n",
    "# for z in range(0,60000,1):\n",
    "#     t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "#     if t<5:\n",
    "#         noiseyset[0].append(dataset1[z])\n",
    "#         healthset[0].append(dataset1[z])\n",
    "#         healthset[1].append(target1[z])\n",
    "#         healthset[2].append(z)\n",
    "#         noiseyset[1].append(torch.tensor(random.randint(0,9)))\n",
    "        \n",
    "        \n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "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-20:53:48 </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-20:53:48\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": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c28ca85b79ee4907add93637a84eaf97",
       "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\"></pre>\n"
      ],
      "text/plain": []
     },
     "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"
      ]
     },
     "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-23:34:14 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3236</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:34:14\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3236\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\">70674240</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;36m70674240\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.94</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.94\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACInklEQVR4nO3dd5hTVfoH8G96phemMgy9iTQBQRREAcHeFVlXEMXOWlBXXRV0XcWyutgLv1V0VwVlbasrFgSUJkiR3jtMH6bPpN7fH8m9ufemTDIkk5nk+3keHp3kJjm5KefNe95zjkYQBAFEREREMUIb7QYQERERhRODGyIiIoopDG6IiIgopjC4ISIiopjC4IaIiIhiCoMbIiIiiikMboiIiCimMLghIiKimMLghoiIiGIKgxsiiqhly5ZBo9Fg2bJl0mU33ngjunbtGrU2xZInnngCGo0m2s0galMY3BC1cdu2bcMf//hHFBQUwGQyoWPHjrj++uuxbdu2aDct4t544w3Mnz8/oo+xfft2PPHEEzh48GBEH6c1PfPMM/jiiy+i3QyiqGFwQ9SGffbZZxgyZAiWLFmCadOm4Y033sDNN9+MpUuXYsiQIfj888+j3cSIaq3g5sknn2RwQxRD9NFuABH5tm/fPtxwww3o3r07fv75Z2RnZ0vX3XPPPRg9ejRuuOEGbN68Gd27d2+1dtXX1yMpKanVHq894DkhaluYuSFqo1544QU0NDTgnXfeUQQ2AJCVlYW3334b9fX1eP755wEAixYtgkajwfLly73u6+2334ZGo8HWrVuly3bu3Imrr74amZmZMJvNGDZsGL766ivF7ebPny/d55133omcnBx06tQJAHDo0CHceeed6NOnDxISEtChQwdcc801YcuAdO3aFdu2bcPy5cuh0Wig0WhwzjnnSNdXVVXh3nvvRWFhIUwmE3r27InnnnsOTqdTcT8LFizA0KFDkZKSgtTUVAwYMAAvv/yy9PyuueYaAMC5554rPY68PkjtxhtvRHJyMvbt24cLL7wQKSkpuP766wEATqcTc+fOxamnngqz2Yzc3FzcdtttOHHihOI+fvvtN0ycOBFZWVlISEhAt27dcNNNN0nX+6pTAoCDBw9Co9EEzGZpNBrU19fj/fffl57PjTfeCACora3Fvffei65du8JkMiEnJwfnnXceNmzY4Pf+iNoj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NTdERETRwZ43QriIHxERUXSw540QTgUnIiKKDva8EcJhKSIiouhgzxshnApOREQUHex5I0QalmJwQ0RE1KrY80aAwynA4XQtH8SaGyIiotbFnjcCxCEpgJkbIiKi1saeNwIY3BAREUUPe94IsDgcAACNBtBrNVFuDRERUXxhcBMBnq0XtNBoGNwQERG1JgY3EcA1boiIiKKHvW8EiNPAucYNERFR62PvGwHyYSkiIiJqXex9I8DGBfyIiIiihr1vBFjtrgX8DMzcEBERtTr2vhEgZm4Y3BAREbU+9r4RINbcGDgsRURE1OrY+0aAVHOj4xo3RERErY3BTQRYOSxFREQUNex9I8DmcO8IzmEpIiKiVsfeNwJYUExERBQ97H0jwFNzw9NLRETU2tj7RoA0W4oFxURERK2OwU0EsKCYiIgoetj7RoBNXKGYBcVEREStjr1vBLDmhoiIKHrY+0YAN84kIiKKHva+EeCpuWFBMRERUWtjcBMBXOeGiIgoetj7RoBUUMzghoiIqNWx940AKwuKiYiIooa9bwSw5oaIiCh6GNxEgE1coZizpYiIiFode98IYEExERFR9LD3jQCbw1VQbGLmhoiIqNWx940A7i1FREQUPex9I4DDUkRERNHD3jcCbJwtRUREFDUMbiLAauc6N0RERNHC3jcCxIJiTgUnIiJqfex9I0DM3LDmhoiIqPWx940AG7dfICIiihr2vhEgBTd6FhQTERG1NgY3ESDV3DBzQ0RE1OrY+0YAF/EjIiKKHva+YSYIAguKiYiIooi9b5jZnYL0/ywoJiIian3sfcNMLCYGAAMLiomIiFodg5sws9k9mRsOSxEREbU+9r5hJhYTazSAXsvMDRERUWtjcBNm8h3BNRoGN0RERK2NwU2YcXViIiKi6GIPHGaeaeDM2hAREUUDg5sw4wJ+RERE0cUeOMy49QIREVF0sQcOM8+mmTy1RERE0cAeOMxsdhYUExERRRN74DCTam64OjEREVFUMLgJM9bcEBERRRd74DCzcbYUERFRVLEHDjMra26IiIiiij1wmHnWuWHNDRERUTQwuAkzDksRERFFF3vgMBOnghu4zg0REVFUsAcOM3G2lImZGyIioqhgDxxm3FuKiIgoutpED/z666+ja9euMJvNGDFiBNauXev32Hnz5mH06NHIyMhARkYGxo8fH/D41mbj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aDRCqz35ihkGN0REFHN0Ot1J121Q+8WCYiIiIoopDG6IiIgopjC4ISIiopgSdzU34gJBNTU1UW4JERERBUvst4NZ6C/ugpva2loAQGFhYZRbQkRERKGqra1FWlpawGM0QpytU+10OnH8+HGkpKSEbXGnmpoaFBYW4siRI0hNTQ3LfcYynq/g8VyFhucreDxXweO5Ck2kzpcgCKitrUXHjh2bnS4ed5kbrVaLTp06ReS+U1NT+cYPAc9X8HiuQsPzFTyeq+DxXIUmEueruYyNiAXFREREFFMY3BAREVFMYXATBiaTCbNnz4bJZIp2U9oFnq/g8VyFhucreDxXweO5Ck1bOF9xV1BMREREsY2ZGyIiIoopDG6IiIgopjC4ISIiopjC4IaIiIhiCoObMHj99dfRtWtXmM1mjBgxAmvXro12k6LuiSeegEajUfzr27evdH1TUxPuuusudOjQAcnJybjqqqtQUlISxRa3np9//hmXXHIJOnbsCI1Ggy+++EJxvSAImDVrFvLz85GQkIDx48djz549imMqKytx/fXXIzU1Fenp6bj55ptRV1fXis+i9TR3vm688Uav99r555+vOCZeztecOXNw+umnIyUlBTk5Obj88suxa9cuxTHBfPYOHz6Miy66CImJicjJycGDDz4Iu93emk8l4oI5V+ecc47Xe+v2229XHBMP5woA3nzzTQwcOFBamG/kyJH49ttvpevb2vuKwc1JWrhwIWbOnInZs2djw4YNGDRoECZOnIjS0tJoNy3qTj31VBQVFUn/VqxYIV1333334b///S8+/fRTLF++HMePH8eVV14Zxda2nvr6egwaNAivv/66z+uff/55vPLKK3jrrbfw66+/IikpCRMnTkRTU5N0zPXXX49t27bhhx9+wNdff42ff/4Zt956a2s9hVbV3PkCgPPPP1/xXvv4448V18fL+Vq+fDnuuusurFmzBj/88ANsNhsmTJiA+vp66ZjmPnsOhwMXXXQRrFYrVq1ahffffx/z58/HrFmzovGUIiaYcwUAt9xyi+K99fzzz0vXxcu5AoBOnTrh2Wefxfr16/Hbb79h7NixuOyyy7Bt2zYAbfB9JdBJGT58uHDXXXdJfzscDqFjx47CnDlzotiq6Js9e7YwaNAgn9dVVVUJBoNB+PTTT6XLduzYIQAQVq9e3UotbBsACJ9//rn0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",
      "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.09809999999999999}, {'accuracy': 0.18571}, {'accuracy': 0.346}, {'accuracy': 0.4862699999999999}, {'accuracy': 0.49660000000000004}, {'accuracy': 0.50455}, {'accuracy': 0.48274}, {'accuracy': 0.44206}, {'accuracy': 0.57657}, {'accuracy': 0.43118999999999996}, {'accuracy': 0.48734}, {'accuracy': 0.6037299999999999}, {'accuracy': 0.59424}, {'accuracy': 0.55289}, {'accuracy': 0.6256799999999999}, {'accuracy': 0.6018199999999999}, {'accuracy': 0.56748}, {'accuracy': 0.5526099999999999}, {'accuracy': 0.70494}, {'accuracy': 0.5766100000000002}, {'accuracy': 0.69539}, {'accuracy': 0.67296}, {'accuracy': 0.5746300000000001}, {'accuracy': 0.65171}, {'accuracy': 0.68128}, {'accuracy': 0.75782}, {'accuracy': 0.60459}, {'accuracy': 0.5267100000000001}, {'accuracy': 0.64297}, {'accuracy': 0.6909799999999999}, {'accuracy': 0.72686}, {'accuracy': 0.5902}, {'accuracy': 0.65141}, {'accuracy': 0.64388}, {'accuracy': 0.65854}, {'accuracy': 0.6242499999999999}, {'accuracy': 0.5729200000000001}, {'accuracy': 0.6495900000000001}, {'accuracy': 0.7125000000000001}, {'accuracy': 0.73509}, {'accuracy': 0.76249}, {'accuracy': 0.64545}, {'accuracy': 0.71987}, {'accuracy': 0.64377}, {'accuracy': 0.6487200000000001}, {'accuracy': 0.60938}, {'accuracy': 0.7754399999999999}, {'accuracy': 0.5792299999999999}, {'accuracy': 0.64899}, {'accuracy': 0.7541399999999999}, {'accuracy': 0.6806300000000001}, {'accuracy': 0.70962}, {'accuracy': 0.65139}, {'accuracy': 0.74411}, {'accuracy': 0.58893}, {'accuracy': 0.6772699999999999}, {'accuracy': 0.68555}, {'accuracy': 0.73263}, {'accuracy': 0.73411}, {'accuracy': 0.67163}, {'accuracy': 0.68603}, {'accuracy': 0.77239}, {'accuracy': 0.6369499999999999}, {'accuracy': 0.67954}, {'accuracy': 0.7395}, {'accuracy': 0.71932}, {'accuracy': 0.69047}, {'accuracy': 0.70317}, {'accuracy': 0.6895300000000001}, {'accuracy': 0.7830900000000001}, {'accuracy': 0.74265}, {'accuracy': 0.67627}, {'accuracy': 0.6334500000000001}, {'accuracy': 0.53799}, {'accuracy': 0.68058}, {'accuracy': 0.6714999999999999}, {'accuracy': 0.66761}, {'accuracy': 0.80299}, {'accuracy': 0.7186}, {'accuracy': 0.69684}, {'accuracy': 0.626}, {'accuracy': 0.5850799999999999}, {'accuracy': 0.65393}, {'accuracy': 0.68597}, {'accuracy': 0.7475000000000002}, {'accuracy': 0.6925199999999999}, {'accuracy': 0.711}, {'accuracy': 0.6699499999999999}, {'accuracy': 0.61391}, {'accuracy': 0.8058099999999999}, {'accuracy': 0.6415200000000001}, {'accuracy': 0.7790100000000001}, {'accuracy': 0.7353599999999999}, {'accuracy': 0.72319}, {'accuracy': 0.66379}, {'accuracy': 0.69518}, {'accuracy': 0.65955}, {'accuracy': 0.7222600000000001}, {'accuracy': 0.6812}, {'accuracy': 0.68023}, {'accuracy': 0.71535}, {'accuracy': 0.58011}, {'accuracy': 0.7286900000000001}, {'accuracy': 0.7106800000000001}, {'accuracy': 0.53454}, {'accuracy': 0.6173}, {'accuracy': 0.6848}, {'accuracy': 0.79604}, {'accuracy': 0.6799}, {'accuracy': 0.7264600000000001}, {'accuracy': 0.7573199999999999}, {'accuracy': 0.73182}, {'accuracy': 0.75095}, {'accuracy': 0.6278299999999999}, {'accuracy': 0.6662100000000001}, {'accuracy': 0.65788}, {'accuracy': 0.81857}, {'accuracy': 0.60764}, {'accuracy': 0.84358}, {'accuracy': 0.5583600000000001}, {'accuracy': 0.73449}, {'accuracy': 0.6813800000000001}, {'accuracy': 0.63583}, {'accuracy': 0.69231}, {'accuracy': 0.66882}, {'accuracy': 0.7801700000000001}, {'accuracy': 0.63362}, {'accuracy': 0.53879}, {'accuracy': 0.60161}, {'accuracy': 0.58913}, {'accuracy': 0.76691}, {'accuracy': 0.61867}, {'accuracy': 0.69047}, {'accuracy': 0.6058899999999999}, {'accuracy': 0.62893}, {'accuracy': 0.71373}, {'accuracy': 0.7782899999999999}, {'accuracy': 0.43762}, {'accuracy': 0.61615}, {'accuracy': 0.74495}, {'accuracy': 0.5776}, {'accuracy': 0.64057}, {'accuracy': 0.72525}, {'accuracy': 0.67289}, {'accuracy': 0.7596999999999999}, {'accuracy': 0.67007}, {'accuracy': 0.78628}, {'accuracy': 0.68263}, {'accuracy': 0.72324}, {'accuracy': 0.7451899999999999}, {'accuracy': 0.7445799999999999}, {'accuracy': 0.87941}, {'accuracy': 0.94464}, {'accuracy': 0.94998}, {'accuracy': 0.9531300000000001}, {'accuracy': 0.94873}, {'accuracy': 0.9489099999999999}, {'accuracy': 0.94905}, {'accuracy': 0.9452499999999999}, {'accuracy': 0.94757}, {'accuracy': 0.9483399999999997}, {'accuracy': 0.9464600000000001}, {'accuracy': 0.94859}, {'accuracy': 0.9513200000000002}, {'accuracy': 0.94489}, {'accuracy': 0.9511299999999998}, {'accuracy': 0.9506499999999999}, {'accuracy': 0.9495100000000001}, {'accuracy': 0.9422099999999999}, {'accuracy': 0.9444000000000001}, {'accuracy': 0.94682}, {'accuracy': 0.94329}, {'accuracy': 0.94587}, {'accuracy': 0.94413}, {'accuracy': 0.95068}, {'accuracy': 0.94845}, {'accuracy': 0.9494199999999999}, {'accuracy': 0.9459799999999999}, {'accuracy': 0.95238}, {'accuracy': 0.9450700000000001}, {'accuracy': 0.9461600000000001}, {'accuracy': 0.94797}, {'accuracy': 0.94417}, {'accuracy': 0.94705}, {'accuracy': 0.9433699999999998}, {'accuracy': 0.9519399999999999}, {'accuracy': 0.94314}, {'accuracy': 0.94568}, {'accuracy': 0.94747}, {'accuracy': 0.9459800000000002}, {'accuracy': 0.9460599999999999}, {'accuracy': 0.9475199999999999}, {'accuracy': 0.94866}, {'accuracy': 0.9468099999999999}, {'accuracy': 0.9497}, {'accuracy': 0.94784}, {'accuracy': 0.94658}, {'accuracy': 0.9399900000000001}, {'accuracy': 0.94794}, {'accuracy': 0.9451699999999998}, {'accuracy': 0.9474}, {'accuracy': 0.9514399999999998}, {'accuracy': 0.9539900000000001}, {'accuracy': 0.9474999999999998}, {'accuracy': 0.9467000000000001}, {'accuracy': 0.94557}, {'accuracy': 0.9433400000000001}, {'accuracy': 0.9474899999999999}, {'accuracy': 0.9468799999999999}, {'accuracy': 0.94802}, {'accuracy': 0.9475000000000001}, {'accuracy': 0.94671}, {'accuracy': 0.9430400000000001}, {'accuracy': 0.94622}, {'accuracy': 0.9500699999999999}, {'accuracy': 0.94845}, {'accuracy': 0.9513299999999999}, {'accuracy': 0.9489300000000002}, {'accuracy': 0.95028}, {'accuracy': 0.94436}, {'accuracy': 0.9485000000000001}, {'accuracy': 0.94363}, {'accuracy': 0.9452299999999999}, {'accuracy': 0.9480299999999999}, {'accuracy': 0.94377}, {'accuracy': 0.94808}, {'accuracy': 0.9482899999999999}, {'accuracy': 0.9472200000000001}, {'accuracy': 0.94893}, {'accuracy': 0.94712}, {'accuracy': 0.9516}, {'accuracy': 0.94888}, {'accuracy': 0.9522200000000002}, {'accuracy': 0.9458300000000002}, {'accuracy': 0.9511600000000001}, {'accuracy': 0.9492400000000002}, {'accuracy': 0.9473}, {'accuracy': 0.9492100000000001}, {'accuracy': 0.94894}, {'accuracy': 0.9436200000000001}, {'accuracy': 0.94995}, {'accuracy': 0.9488600000000001}, {'accuracy': 0.94528}, {'accuracy': 0.95069}, {'accuracy': 0.9477300000000002}, {'accuracy': 0.9447000000000001}, {'accuracy': 0.9491400000000002}, {'accuracy': 0.9418799999999999}, {'accuracy': 0.94808}, {'accuracy': 0.94669}, {'accuracy': 0.94478}, {'accuracy': 0.95152}, {'accuracy': 0.9458400000000001}, {'accuracy': 0.9443999999999999}, {'accuracy': 0.94815}, {'accuracy': 0.94421}, {'accuracy': 0.9520500000000001}, {'accuracy': 0.94496}, {'accuracy': 0.9498599999999999}, {'accuracy': 0.94292}, {'accuracy': 0.94575}, {'accuracy': 0.94859}, {'accuracy': 0.94855}, {'accuracy': 0.9478000000000002}, {'accuracy': 0.94655}, {'accuracy': 0.9468699999999999}, {'accuracy': 0.95174}, {'accuracy': 0.9464400000000002}, {'accuracy': 0.94676}, {'accuracy': 0.94489}, {'accuracy': 0.9446999999999999}, {'accuracy': 0.9444199999999998}, {'accuracy': 0.95143}, {'accuracy': 0.9507199999999999}, {'accuracy': 0.9475200000000001}, {'accuracy': 0.94553}, {'accuracy': 0.9408499999999999}, {'accuracy': 0.9456300000000001}, {'accuracy': 0.94505}, {'accuracy': 0.9468099999999999}, {'accuracy': 0.9460899999999999}, {'accuracy': 0.95191}, {'accuracy': 0.9424899999999999}, {'accuracy': 0.9498}, {'accuracy': 0.94683}, {'accuracy': 0.94505}, {'accuracy': 0.9435799999999999}, {'accuracy': 0.9496799999999999}, {'accuracy': 0.9476000000000001}, {'accuracy': 0.9427300000000001}, {'accuracy': 0.9495699999999999}, {'accuracy': 0.94449}, {'accuracy': 0.9469899999999999}, {'accuracy': 0.94894}, {'accuracy': 0.94406}, {'accuracy': 0.94859}, {'accuracy': 0.9424700000000001}, {'accuracy': 0.94953}, {'accuracy': 0.9454100000000001}, {'accuracy': 0.9436700000000002}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "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": "6f5032a2-ef28-4307-a52b-9ede0d74e7a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d2406ae-c908-4a63-a5b2-3bd66d28ef43",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0930d694-8122-400f-b879-823dbc43754e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed1c79da-e820-4ca9-9e5e-f4eafea5c5b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7412c586-296e-4805-a3e2-2c02f8697616",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a7ba920-7d1b-4c89-8f56-2558cbb9abf7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22d93fbc-4f90-4680-bd9c-4a249c21c544",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcfbeb32-38ec-485b-9670-2e5d29b4e5bb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1829da59-8115-46fc-8b82-82c7db2fc49f",
   "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
}
