{
 "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 2307]\n",
      " [   1   70]\n",
      " [   2   46]\n",
      " [   3   73]\n",
      " [   4  105]\n",
      " [   5  206]\n",
      " [   6  281]\n",
      " [   7  540]\n",
      " [   8  813]\n",
      " [   9 1449]]\n",
      "[[   0 1420]\n",
      " [   1 2658]\n",
      " [   2   63]\n",
      " [   3   38]\n",
      " [   4   58]\n",
      " [   5  105]\n",
      " [   6  189]\n",
      " [   7  294]\n",
      " [   8  555]\n",
      " [   9  824]]\n",
      "[[   0  854]\n",
      " [   1 1627]\n",
      " [   2 2416]\n",
      " [   3   73]\n",
      " [   4   31]\n",
      " [   5   61]\n",
      " [   6  119]\n",
      " [   7  204]\n",
      " [   8  318]\n",
      " [   9  541]]\n",
      "[[   0  544]\n",
      " [   1  980]\n",
      " [   2 1390]\n",
      " [   3 2436]\n",
      " [   4   77]\n",
      " [   5   40]\n",
      " [   6   78]\n",
      " [   7  129]\n",
      " [   8  191]\n",
      " [   9  286]]\n",
      "[[   0  314]\n",
      " [   1  578]\n",
      " [   2  874]\n",
      " [   3 1492]\n",
      " [   4 2371]\n",
      " [   5   38]\n",
      " [   6   42]\n",
      " [   7   70]\n",
      " [   8   87]\n",
      " [   9  193]]\n",
      "[[   0  182]\n",
      " [   1  358]\n",
      " [   2  527]\n",
      " [   3  865]\n",
      " [   4 1425]\n",
      " [   5 2167]\n",
      " [   6   78]\n",
      " [   7   49]\n",
      " [   8   81]\n",
      " [   9   98]]\n",
      "[[   0  118]\n",
      " [   1  217]\n",
      " [   2  296]\n",
      " [   3  514]\n",
      " [   4  818]\n",
      " [   5 1299]\n",
      " [   6 2392]\n",
      " [   7   45]\n",
      " [   8   36]\n",
      " [   9   66]]\n",
      "[[   0   66]\n",
      " [   1  127]\n",
      " [   2  183]\n",
      " [   3  326]\n",
      " [   4  497]\n",
      " [   5  769]\n",
      " [   6 1430]\n",
      " [   7 2473]\n",
      " [   8   59]\n",
      " [   9   26]]\n",
      "[[   0   46]\n",
      " [   1   79]\n",
      " [   2   97]\n",
      " [   3  190]\n",
      " [   4  260]\n",
      " [   5  490]\n",
      " [   6  787]\n",
      " [   7 1580]\n",
      " [   8 2346]\n",
      " [   9   69]]\n",
      "[[   0   72]\n",
      " [   1   48]\n",
      " [   2   66]\n",
      " [   3  124]\n",
      " [   4  200]\n",
      " [   5  246]\n",
      " [   6  522]\n",
      " [   7  881]\n",
      " [   8 1365]\n",
      " [   9 2397]]\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": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2478\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2266]\n",
      " [   1   65]\n",
      " [   2   46]\n",
      " [   3   73]\n",
      " [   4  105]\n",
      " [   5  206]\n",
      " [   6  253]\n",
      " [   7  477]\n",
      " [   8  813]\n",
      " [   9 1449]]\n",
      "[[   0 2490]\n",
      " [   1   69]\n",
      " [   2   46]\n",
      " [   3   73]\n",
      " [   4  105]\n",
      " [   5  206]\n",
      " [   6  297]\n",
      " [   7  532]\n",
      " [   8  813]\n",
      " [   9 1449]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 7, 7, 7])"
      ]
     },
     "execution_count": 4,
     "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<1:\n",
    "        if target1[z]==6:\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(0))\n",
    "        \n",
    "        elif target1[z]==0:\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(6))      \n",
    "        \n",
    "        elif target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(7))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==7:\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(1))     \n",
    "        \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": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:09:04 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:09:04\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "161e8766a23e4b06a8ce066dfe9916f3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-22:59:03 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3424</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:59:03\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3424\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\">74780160</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;36m74780160\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.96</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.96\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABzkklEQVR4nO3dd3gU1foH8O/uZkt67wmEJFQJ/YIoTUCwoWJD5Aqi2BBFsQAW0OtVEC/+8F4LdvReFRTFLogIKEU60jshlPSeTbJ1fn/szmQ22ZRNstmw+/08Tx6zM7MzZyfBefOe95yjEARBABEREZGXUHq6AURERESticENEREReRUGN0RERORVGNwQERGRV2FwQ0RERF6FwQ0RERF5FQY3RERE5FUY3BAREZFXYXBDREREXoXBDRG51YYNG6BQKLBhwwZp21133YWUlBSPtcmbPP/881AoFJ5uBlG7wuCGqJ07ePAg/v73vyMxMRFarRYJCQmYNGkSDh486Ommud1bb72FZcuWufUahw4dwvPPP4/MzEy3Xqctvfzyy/jmm2883Qwij2FwQ9SOff311+jXrx/WrVuHqVOn4q233sI999yD9evXo1+/fli1apWnm+hWbRXcvPDCCwxuiLyIn6cbQETOnTx5EnfeeSdSU1Px+++/Izo6Wto3c+ZMDB06FHfeeSf27duH1NTUNmuXXq9HYGBgm13vYsB7QtS+MHND1E69+uqrqKysxLvvvusQ2ABAVFQU3nnnHej1eixatAgAsHLlSigUCmzcuLHOud555x0oFAocOHBA2nbkyBHccsstiIiIgE6nw4ABA/Ddd985vG/ZsmXSOadPn46YmBgkJSUBAM6cOYPp06eja9eu8Pf3R2RkJG699dZWy4CkpKTg4MGD2LhxIxQKBRQKBUaMGCHtLykpwaOPPork5GRotVqkp6fjlVdegdVqdTjP8uXL0b9/fwQHByMkJAQZGRl4/fXXpc936623AgCuuOIK6Try+qDa7rrrLgQFBeHkyZO45pprEBwcjEmTJgEArFYrlixZgksuuQQ6nQ6xsbG4//77UVxc7HCOnTt3YuzYsYiKioK/vz86deqEu+++W9rvrE4JADIzM6FQKBrMZikUCuj1enz88cfS57nrrrsAAOXl5Xj00UeRkpICrVaLmJgYXHnlldi9e3e95yO6GDFzQ9ROff/9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de7cGR9//DEmTZqEjIwM3HPPPejUqRMyMzPxwQcfoKCgAJ9//rk0zFekVqtx0003Yfny5dDr9fjXv/5V59xvvvkmhgwZgoyMDNx7771ITU1Fbm4utm7dinPnzuGvv/5qtH3XXXcd/vvf/yI0NBQ9evTA1q1b8euvvyIyMrLV7kH//v3x9ttv45///CfS09MRExODkSNH4sknn8R3332H6667DnfddRf69+8PvV6P/fv3Y+XKlcjMzERUVBSmTZuGoqIijBw5EklJSThz5gz+85//oE+fPtJw7z59+kClUuGVV15BaWkptFotRo4ciZiYGJfaOnz4cNx///1YsGAB9u7dizFjxkCtVuP48eP48ssv8frrr+OWW27Bxx9/jLfeegvjx49HWloaysvL8d577yEkJATXXHMNAFu35K233or//Oc/UCgUSEtLww8//FCnFqqh+/brr7/itddeQ0JCAjp16oSuXbsiKSkJt9xyC3r37o2goCD8+uuv2LFjh0P2jcgreHawFhE1Zt++fcLEiROF+Ph4Qa1WC3FxccLEiROF/fv31/uetWvXCgAEhUIhnD171ukxJ0+eFCZPnizExcUJarVaSExMFK677jph5cqV0jHiUHBnw5aLi4uFqVOnClFRUUJQUJAwduxY4ciRI0LHjh0dhiG3ZCh4Tk6OcO211wrBwcECAIdh4eXl5cLcuXOF9PR0QaPRCFFRUcJll10m/Otf/xKMRqMgCIKwcuVKYcyYMUJMTIyg0WiEDh06CPfff7+QnZ3tcJ333ntPSE1NFVQqVaPDwqdMmSIEBgbWu//dd98V+vfvL/j7+wvBwcFCRkaG8NRTTwkXLlwQBEEQdu/eLUycOFHo0KGDoNVqhZiYGOG6664Tdu7c6XCe/Px84eabbxYCAgKE8PBw4f777xcOHDjQpKHgR44cEYYNGyb4+/sLAIQpU6YIBoNBePLJJ4XevXsLwcHBQmBgoNC7d2/hrbfeauhHQHRRUghCrfwoERER0UWMNTdERETkVRjcEBERkVdhcENERERehcENEREReRUGN0RERORVPBrc/P777xg3bhwSEhKgUCjwzTffNPqeDRs2oF+/ftBqtUhPT8eyZcvc3k4iIiK6eHh0Ej+9Xo/evXvj7rvvxk033dTo8adPn8a1116LBx54AJ9++inWrVuHadOmIT4+vt41cmqz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RKAGI7rGeLo5REQ+z1+twqF/jPXYtV0xbtw4dOzYEe+99x4SEhJgtVrRs2dPGI1G+Ps3PEClsf0KhQKCIDhsc1YwHBjoWFLx6quv4vXXX8eSJUuQkZGBwMBAPProozAajU26LmDrmurTpw/OnTuHjz76CCNHjkTHjh0bfV9LMHPTiv63zRbJ3jogCToXf6mJiKj1KRQKBGj8PPLlSrdLYWEhjh49imeffRajRo1C9+7dUVxcLO3v1asX9u7di6KiIqfv79WrV4MFutHR0cjOzpZeHz9+vEmLi27evBk33HAD/v73v6N3795ITU3FsWPHpP2dO3eGv79/g9fOyMjAgAED8N577+Gzzz7D3Xff3eh1W4rBTSvJLNDj92P5UCiASQPdG5ESEZF3CQ8PR2RkJN59912cOHECv/32G2bNmiXtnzhxIuLi4nDjjTdi8+bNOHXqFL766its3boVADB//nx8/vnnmD9/Pg4fPoz9+/fjlVdekd4/cuRIvPHGG9izZw927tyJBx54AGq1utF2de7cGWvXrsWWLVtw+PBh3H///cjNzZX263Q6zJ49G0899RQ++eQTnDx5En/++Sc++OADh/NMmzYNCxcuhCAIDqO43IXBTSvJKqpETLAWw7tEo0MkF2wjIqKmUyqVWL58OXbt2oWePXvisccew6uvvirt12g0+OWXXxATE4NrrrkGGRkZWLhwobS45IgRI/Dll1/iu+++Q58+fTBy5Ehs375dev/ixYuRnJyMoUOH4o477sATTzzRpMVFn332WfTr1w9jx47FiBEjpABL7rnnnsPjjz+OefPmoXv37pgwYQLy8vIcjpk4cSL8/PwwceJE6HS6FtypplEItTvhvFxZWRlCQ0NRWlqKkJCQVj23yWJFcaURMcHu/8EREZGj6upqnD59Gp06dWqTByg1XWZmJtLS0rBjxw7069ev3uMa+hm68vxmQXErUquUDGyIiIjsTCYTCgsL8eyzz+LSSy9tMLBpTeyWIiIiIrfYvHkz4uPjsWPHDixdurTNrsvMDREREbnFiBEj6gxBbwvM3BAREZFXYXBDREREXoXBDREReRUfGwTsVVrrZ8fghoiIvII4KV1TZt6l9klc1kGcv6e5WFBMREReQaVSISwsTJpALiAgwK0rT1PrslqtyM/PR0BAAPz8WhaeMLghIiKvERcXBwB1Zsil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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10102}, {'accuracy': 0.11041000000000001}, {'accuracy': 0.13522}, {'accuracy': 0.22513}, {'accuracy': 0.25376}, {'accuracy': 0.20542}, {'accuracy': 0.33199999999999996}, {'accuracy': 0.34509999999999996}, {'accuracy': 0.47325}, {'accuracy': 0.42453}, {'accuracy': 0.43772}, {'accuracy': 0.40062}, {'accuracy': 0.54242}, {'accuracy': 0.5563800000000001}, {'accuracy': 0.5013}, {'accuracy': 0.5059500000000001}, {'accuracy': 0.59523}, {'accuracy': 0.5482100000000001}, {'accuracy': 0.55743}, {'accuracy': 0.5797000000000001}, {'accuracy': 0.5723499999999999}, {'accuracy': 0.58725}, {'accuracy': 0.61578}, {'accuracy': 0.63378}, {'accuracy': 0.6406799999999999}, {'accuracy': 0.61521}, {'accuracy': 0.61371}, {'accuracy': 0.64207}, {'accuracy': 0.61112}, {'accuracy': 0.6675899999999999}, {'accuracy': 0.7137}, {'accuracy': 0.6626799999999999}, {'accuracy': 0.73905}, {'accuracy': 0.74051}, {'accuracy': 0.7044}, {'accuracy': 0.70834}, {'accuracy': 0.66687}, {'accuracy': 0.69965}, {'accuracy': 0.70077}, {'accuracy': 0.71889}, {'accuracy': 0.7163700000000002}, {'accuracy': 0.7358499999999999}, {'accuracy': 0.71776}, {'accuracy': 0.73354}, {'accuracy': 0.74633}, {'accuracy': 0.6735}, {'accuracy': 0.7107300000000001}, {'accuracy': 0.77484}, {'accuracy': 0.7463900000000001}, {'accuracy': 0.74023}, {'accuracy': 0.7076900000000002}, {'accuracy': 0.7483099999999999}, {'accuracy': 0.8092099999999999}, {'accuracy': 0.7077}, {'accuracy': 0.7401}, {'accuracy': 0.73282}, {'accuracy': 0.7432199999999999}, {'accuracy': 0.7686900000000001}, {'accuracy': 0.8168899999999999}, {'accuracy': 0.7579899999999999}, {'accuracy': 0.73655}, {'accuracy': 0.8063699999999999}, {'accuracy': 0.8050799999999999}, {'accuracy': 0.77857}, {'accuracy': 0.78864}, {'accuracy': 0.75391}, {'accuracy': 0.776}, {'accuracy': 0.78058}, {'accuracy': 0.7709699999999999}, {'accuracy': 0.7925699999999999}, {'accuracy': 0.74958}, {'accuracy': 0.79953}, {'accuracy': 0.75524}, {'accuracy': 0.74388}, {'accuracy': 0.82989}, {'accuracy': 0.73214}, {'accuracy': 0.77754}, {'accuracy': 0.75303}, {'accuracy': 0.7801400000000001}, {'accuracy': 0.79115}, {'accuracy': 0.7697499999999999}, {'accuracy': 0.79531}, {'accuracy': 0.82893}, {'accuracy': 0.8198599999999999}, {'accuracy': 0.73124}, {'accuracy': 0.7676499999999999}, {'accuracy': 0.81415}, {'accuracy': 0.7824500000000001}, {'accuracy': 0.7775000000000001}, {'accuracy': 0.8743399999999999}, {'accuracy': 0.7928900000000001}, {'accuracy': 0.85276}, {'accuracy': 0.7987799999999999}, {'accuracy': 0.82423}, {'accuracy': 0.8219799999999999}, {'accuracy': 0.87076}, {'accuracy': 0.78993}, {'accuracy': 0.8034799999999999}, {'accuracy': 0.77744}, {'accuracy': 0.7763500000000001}, {'accuracy': 0.76413}, {'accuracy': 0.85479}, {'accuracy': 0.78822}, {'accuracy': 0.8338300000000001}, {'accuracy': 0.7732699999999999}, {'accuracy': 0.7858499999999999}, {'accuracy': 0.7864699999999999}, {'accuracy': 0.7699}, {'accuracy': 0.8098899999999999}, {'accuracy': 0.8377700000000001}, {'accuracy': 0.74595}, {'accuracy': 0.8802899999999999}, {'accuracy': 0.77057}, {'accuracy': 0.8016099999999999}, {'accuracy': 0.7838200000000001}, {'accuracy': 0.76166}, {'accuracy': 0.79189}, {'accuracy': 0.7966599999999999}, {'accuracy': 0.8240400000000001}, {'accuracy': 0.73908}, {'accuracy': 0.76389}, {'accuracy': 0.86455}, {'accuracy': 0.79618}, {'accuracy': 0.80135}, {'accuracy': 0.7847899999999999}, {'accuracy': 0.80977}, {'accuracy': 0.8518399999999999}, {'accuracy': 0.7955400000000001}, {'accuracy': 0.79325}, {'accuracy': 0.8231299999999999}, {'accuracy': 0.84375}, {'accuracy': 0.8030999999999999}, {'accuracy': 0.7482800000000001}, {'accuracy': 0.8230700000000001}, {'accuracy': 0.75923}, {'accuracy': 0.78608}, {'accuracy': 0.7471099999999999}, {'accuracy': 0.7610500000000001}, {'accuracy': 0.82036}, {'accuracy': 0.81652}, {'accuracy': 0.8169000000000001}, {'accuracy': 0.8286300000000001}, {'accuracy': 0.85739}, {'accuracy': 0.85169}, {'accuracy': 0.79674}, {'accuracy': 0.78967}, {'accuracy': 0.83934}, {'accuracy': 0.78153}, {'accuracy': 0.81203}, {'accuracy': 0.81853}, {'accuracy': 0.9117200000000001}, {'accuracy': 0.86669}, {'accuracy': 0.9605500000000001}, {'accuracy': 0.95795}, {'accuracy': 0.96142}, {'accuracy': 0.95957}, {'accuracy': 0.9629}, {'accuracy': 0.9563200000000001}, {'accuracy': 0.9568900000000001}, {'accuracy': 0.9602}, {'accuracy': 0.9570700000000001}, {'accuracy': 0.9611699999999999}, {'accuracy': 0.9546299999999999}, {'accuracy': 0.96074}, {'accuracy': 0.9606}, {'accuracy': 0.9580499999999998}, {'accuracy': 0.9570400000000001}, {'accuracy': 0.9569300000000001}, {'accuracy': 0.9574300000000001}, {'accuracy': 0.9583}, {'accuracy': 0.9547799999999999}, {'accuracy': 0.9588899999999999}, {'accuracy': 0.96089}, {'accuracy': 0.9599499999999999}, {'accuracy': 0.9577100000000002}, {'accuracy': 0.9617000000000001}, {'accuracy': 0.95727}, {'accuracy': 0.9596099999999999}, {'accuracy': 0.95922}, {'accuracy': 0.95945}, {'accuracy': 0.9564100000000002}, {'accuracy': 0.9556699999999999}, {'accuracy': 0.96157}, {'accuracy': 0.95874}, {'accuracy': 0.95641}, {'accuracy': 0.95617}, {'accuracy': 0.9591299999999998}, {'accuracy': 0.9568200000000001}, {'accuracy': 0.9597}, {'accuracy': 0.9587600000000001}, {'accuracy': 0.9618300000000002}, {'accuracy': 0.9579899999999999}, {'accuracy': 0.96003}, {'accuracy': 0.95692}, {'accuracy': 0.9583600000000001}, {'accuracy': 0.9559799999999999}, {'accuracy': 0.9591600000000001}, {'accuracy': 0.95687}, {'accuracy': 0.9597900000000001}, {'accuracy': 0.9614499999999999}, {'accuracy': 0.9593599999999999}, {'accuracy': 0.96004}, {'accuracy': 0.95983}, {'accuracy': 0.9599499999999999}, {'accuracy': 0.95914}, {'accuracy': 0.9615}, {'accuracy': 0.9576900000000002}, {'accuracy': 0.9602700000000001}, {'accuracy': 0.95863}, {'accuracy': 0.95952}, {'accuracy': 0.9597300000000001}, {'accuracy': 0.9580500000000001}, {'accuracy': 0.96099}, {'accuracy': 0.95984}, {'accuracy': 0.95734}, {'accuracy': 0.9596}, {'accuracy': 0.9604100000000001}, {'accuracy': 0.9600099999999999}, {'accuracy': 0.9609500000000001}, {'accuracy': 0.9600800000000002}, {'accuracy': 0.9603999999999999}, {'accuracy': 0.9592099999999999}, {'accuracy': 0.9605}, {'accuracy': 0.9598700000000001}, {'accuracy': 0.9600500000000001}, {'accuracy': 0.96228}, {'accuracy': 0.9592500000000002}, {'accuracy': 0.9553799999999999}, {'accuracy': 0.9581500000000001}, {'accuracy': 0.95817}, {'accuracy': 0.9601000000000001}, {'accuracy': 0.96119}, {'accuracy': 0.95928}, {'accuracy': 0.9611000000000001}, {'accuracy': 0.9607699999999999}, {'accuracy': 0.9615599999999999}, {'accuracy': 0.9575799999999999}, {'accuracy': 0.96207}, {'accuracy': 0.9560599999999999}, {'accuracy': 0.9587600000000001}, {'accuracy': 0.96044}, {'accuracy': 0.9602}, {'accuracy': 0.9592}, {'accuracy': 0.95968}, {'accuracy': 0.9625999999999999}, {'accuracy': 0.9600200000000001}, {'accuracy': 0.96092}, {'accuracy': 0.9600800000000002}, {'accuracy': 0.96255}, {'accuracy': 0.9590599999999998}, {'accuracy': 0.959}, {'accuracy': 0.9576800000000001}, {'accuracy': 0.9599300000000002}, {'accuracy': 0.95956}, {'accuracy': 0.9624900000000001}, {'accuracy': 0.9598800000000001}, {'accuracy': 0.96366}, {'accuracy': 0.9616200000000001}, {'accuracy': 0.95959}, {'accuracy': 0.9595}, {'accuracy': 0.9584599999999999}, {'accuracy': 0.9596599999999998}, {'accuracy': 0.9565399999999998}, {'accuracy': 0.9562200000000001}, {'accuracy': 0.95867}, {'accuracy': 0.95907}, {'accuracy': 0.9630899999999999}, {'accuracy': 0.9612700000000001}, {'accuracy': 0.9617999999999999}, {'accuracy': 0.96247}, {'accuracy': 0.96043}, {'accuracy': 0.95801}, {'accuracy': 0.9563400000000002}, {'accuracy': 0.9593}, {'accuracy': 0.9594099999999999}, {'accuracy': 0.96036}, {'accuracy': 0.961}, {'accuracy': 0.95978}, {'accuracy': 0.95794}, {'accuracy': 0.95936}, {'accuracy': 0.96061}, {'accuracy': 0.9617799999999999}, {'accuracy': 0.96119}, {'accuracy': 0.9607100000000001}, {'accuracy': 0.9598199999999999}, {'accuracy': 0.9585699999999999}, {'accuracy': 0.96074}, {'accuracy': 0.96081}, {'accuracy': 0.9598099999999998}, {'accuracy': 0.9572199999999998}, {'accuracy': 0.9621500000000001}, {'accuracy': 0.9582900000000001}, {'accuracy': 0.95968}, {'accuracy': 0.9589000000000001}, {'accuracy': 0.9599400000000001}, {'accuracy': 0.96099}, {'accuracy': 0.9611999999999998}, {'accuracy': 0.9579699999999999}, {'accuracy': 0.9593}, {'accuracy': 0.96092}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b7cf3cd-0f2e-4677-a995-3c01ef0af65a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5a532c4-3a6a-461c-a48e-95ec0b876c41",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbd0cc22-ff4e-4ab1-8d8c-27ccbc5eb50a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e48c5702-ad22-4bbd-9060-cf12befbc1fa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68faabf2-8382-45fc-b1d5-20099597703d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ade6c90-373f-4e83-95b7-3ed82022fc3e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14d04bca-bc50-4899-9cba-506bac2cdeb8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e0b0818-3e91-4f3d-bf62-00b7772f5f95",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f1f8646-a24b-400f-9ed6-1abca32d87bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d4365d2-8b5a-4884-b914-a46f7c72f75a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7753815a-0b52-4167-812b-925e7dda24e5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cb5dfcb-7bd0-42ff-a036-b88ae0770617",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aac8d4b-40f4-47e6-9a51-d0638f4339a0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ddfd272-e6e0-45ed-8d5c-6ba4205ab6f1",
   "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
}
