{
 "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 2330]\n",
      " [   1   74]\n",
      " [   2   37]\n",
      " [   3   60]\n",
      " [   4  112]\n",
      " [   5  179]\n",
      " [   6  325]\n",
      " [   7  552]\n",
      " [   8  845]\n",
      " [   9 1379]]\n",
      "[[   0 1430]\n",
      " [   1 2709]\n",
      " [   2   71]\n",
      " [   3   36]\n",
      " [   4   53]\n",
      " [   5  105]\n",
      " [   6  175]\n",
      " [   7  304]\n",
      " [   8  503]\n",
      " [   9  892]]\n",
      "[[   0  893]\n",
      " [   1 1620]\n",
      " [   2 2398]\n",
      " [   3   58]\n",
      " [   4   31]\n",
      " [   5   53]\n",
      " [   6  114]\n",
      " [   7  207]\n",
      " [   8  327]\n",
      " [   9  524]]\n",
      "[[   0  549]\n",
      " [   1  943]\n",
      " [   2 1378]\n",
      " [   3 2536]\n",
      " [   4   60]\n",
      " [   5   41]\n",
      " [   6   79]\n",
      " [   7  142]\n",
      " [   8  179]\n",
      " [   9  343]]\n",
      "[[   0  271]\n",
      " [   1  566]\n",
      " [   2  859]\n",
      " [   3 1422]\n",
      " [   4 2321]\n",
      " [   5   67]\n",
      " [   6   42]\n",
      " [   7   75]\n",
      " [   8   97]\n",
      " [   9  183]]\n",
      "[[   0  176]\n",
      " [   1  375]\n",
      " [   2  547]\n",
      " [   3  883]\n",
      " [   4 1537]\n",
      " [   5 2150]\n",
      " [   6   56]\n",
      " [   7   50]\n",
      " [   8   65]\n",
      " [   9  109]]\n",
      "[[   0  121]\n",
      " [   1  205]\n",
      " [   2  293]\n",
      " [   3  517]\n",
      " [   4  782]\n",
      " [   5 1325]\n",
      " [   6 2338]\n",
      " [   7   61]\n",
      " [   8   31]\n",
      " [   9   55]]\n",
      "[[   0   58]\n",
      " [   1  126]\n",
      " [   2  184]\n",
      " [   3  325]\n",
      " [   4  461]\n",
      " [   5  807]\n",
      " [   6 1449]\n",
      " [   7 2505]\n",
      " [   8   57]\n",
      " [   9   43]]\n",
      "[[   0   38]\n",
      " [   1   80]\n",
      " [   2  121]\n",
      " [   3  182]\n",
      " [   4  307]\n",
      " [   5  437]\n",
      " [   6  819]\n",
      " [   7 1489]\n",
      " [   8 2346]\n",
      " [   9   50]]\n",
      "[[   0   57]\n",
      " [   1   44]\n",
      " [   2   70]\n",
      " [   3  112]\n",
      " [   4  178]\n",
      " [   5  257]\n",
      " [   6  521]\n",
      " [   7  880]\n",
      " [   8 1401]\n",
      " [   9 2371]]\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": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7446\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1969]\n",
      " [   1   59]\n",
      " [   2   37]\n",
      " [   3   60]\n",
      " [   4  112]\n",
      " [   5  179]\n",
      " [   6  227]\n",
      " [   7  389]\n",
      " [   8  845]\n",
      " [   9 1379]]\n",
      "[[   0 2699]\n",
      " [   1   76]\n",
      " [   2   37]\n",
      " [   3   60]\n",
      " [   4  112]\n",
      " [   5  179]\n",
      " [   6  316]\n",
      " [   7  559]\n",
      " [   8  845]\n",
      " [   9 1379]]\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<3:\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",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:53:02 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:53:02\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bd81daa7edeb412aa66f6826ee55d56d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:35:31 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3393</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:35:31\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3393\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\">74103120</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;36m74103120\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.91</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.91\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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u3bF559/jltvvRXp6em4++670bFjR2RlZeHTTz9FYWEhvv76a2mar0ir1eK6667DokWLUFVVhddff73Wc7///vsYOXIk0tPTcc8996BTp07Iy8vDxo0bcfr0aezevbvB8V155ZX473//i7CwMPTq1QsbN27En3/+iaioqBY7B4MGDcKHH36If//73+jSpQtiY2MxduxYPPHEE/jpp59w5ZVX4s4778SgQYNQVVWFvXv3YsmSJcjKykJ0dDSmTZuG4uJijB07FsnJyTh58iTeffdd9O/fX5ru3b9/f2g0GrzyyisoKyuDXq/H2LFjERsb26SxjhkzBvfddx/mzZuHXbt2Yfz48dBqtTh69Ci+/fZbvP3227jhhhvw+eef44MPPsC1116Lzp07o6KiAvPnz0doaCguv/xyAPay5I033oh3330XKpUKnTt3xi+//FKrF6q+8/bnn3/izTffRGJiIjp27Iju3bsjOTkZN9xwA/r164fg4GD8+eef2Lp1qyL7RuQVPDtZi4gasmfPHmHy5MlCQkKCoNVqhfj4eGHy5MnC3r1763zMihUrBACCSqUSTp065faYzMxM4Y477hDi4+MFrVYrJCUlCVdeeaWwZMkS6RhxKri7acslJSXC1KlThejoaCE4OFiYMGGCcOjQISE1NVUxDflcpoLn5uYKV1xxhRASEiIAUEwLr6ioEGbPni106dJF0Ol0QnR0tHDhhRcKr7/+umAymQRBEIQlS5YI48ePF2JjYwWdTid06NBBuO+++4ScnBzF68yfP1/o1KmToNFoGpwWPmXKFCEoKKjO+z/55BNh0KBBQkBAgBASEiKkp6cLTz75pHD27FlBEARhx44dwuTJk4UOHToIer1eiI2NFa688kph27ZtiucpKCgQrr/+eiEwMFCIiIgQ7rvvPmHfvn2Nmgp+6NAhYfTo0UJAQIAAQJgyZYpgNBqFJ554QujXr58QEhIiBAUFCf369RM++OCD+n4EROcllSC45EeJiIiIzmPsuSEiIiKvwuCGiIiIvAqDGyIiIvIqDG6IiIjIqzC4ISIiIq/C4IaIiIi8is8t4mez2XD27FmEhIS02LLrRERE1LoEQUBFRQUSExNr7e3myueCm7NnzyIlJcXTwyAiIqJmOHXqFJKTk+s9xueCm5CQEAD2kyPupExERETtW3l5OVJSUqTreH18LrgR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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10096000000000001}, {'accuracy': 0.10424}, {'accuracy': 0.15416}, {'accuracy': 0.17002}, {'accuracy': 0.21612}, {'accuracy': 0.29012000000000004}, {'accuracy': 0.25787}, {'accuracy': 0.36555}, {'accuracy': 0.37156}, {'accuracy': 0.39015999999999995}, {'accuracy': 0.43289999999999995}, {'accuracy': 0.39508000000000004}, {'accuracy': 0.47248}, {'accuracy': 0.49700999999999995}, {'accuracy': 0.52167}, {'accuracy': 0.46031000000000005}, {'accuracy': 0.5496500000000001}, {'accuracy': 0.5573400000000002}, {'accuracy': 0.5426300000000002}, {'accuracy': 0.53812}, {'accuracy': 0.5826600000000001}, {'accuracy': 0.56705}, {'accuracy': 0.56441}, {'accuracy': 0.57522}, {'accuracy': 0.62778}, {'accuracy': 0.6128899999999999}, {'accuracy': 0.5689900000000001}, {'accuracy': 0.69081}, {'accuracy': 0.63449}, {'accuracy': 0.68044}, {'accuracy': 0.6652199999999999}, {'accuracy': 0.62495}, {'accuracy': 0.6570199999999999}, {'accuracy': 0.64306}, {'accuracy': 0.6763199999999999}, {'accuracy': 0.68014}, {'accuracy': 0.72349}, {'accuracy': 0.70384}, {'accuracy': 0.71617}, {'accuracy': 0.7054699999999999}, {'accuracy': 0.7067300000000001}, {'accuracy': 0.6535500000000001}, {'accuracy': 0.68508}, {'accuracy': 0.67623}, {'accuracy': 0.70283}, {'accuracy': 0.6754200000000001}, {'accuracy': 0.71064}, {'accuracy': 0.7106100000000001}, {'accuracy': 0.6689100000000001}, {'accuracy': 0.70903}, {'accuracy': 0.7431300000000001}, {'accuracy': 0.71029}, {'accuracy': 0.7216}, {'accuracy': 0.7444599999999999}, {'accuracy': 0.6770400000000001}, {'accuracy': 0.6918200000000001}, {'accuracy': 0.70006}, {'accuracy': 0.7333099999999999}, {'accuracy': 0.68436}, {'accuracy': 0.70351}, {'accuracy': 0.7384999999999999}, {'accuracy': 0.69038}, {'accuracy': 0.6892199999999999}, {'accuracy': 0.71551}, {'accuracy': 0.7018200000000001}, {'accuracy': 0.69374}, {'accuracy': 0.72041}, {'accuracy': 0.71877}, {'accuracy': 0.6571400000000001}, {'accuracy': 0.7377900000000001}, {'accuracy': 0.7271500000000001}, {'accuracy': 0.7197199999999999}, {'accuracy': 0.75049}, {'accuracy': 0.7325900000000001}, {'accuracy': 0.65866}, {'accuracy': 0.68198}, {'accuracy': 0.73083}, {'accuracy': 0.75495}, {'accuracy': 0.72573}, {'accuracy': 0.68658}, {'accuracy': 0.77898}, {'accuracy': 0.67611}, {'accuracy': 0.75439}, {'accuracy': 0.6852599999999999}, {'accuracy': 0.7495499999999999}, {'accuracy': 0.76097}, {'accuracy': 0.6904100000000001}, {'accuracy': 0.7831}, {'accuracy': 0.7873600000000001}, {'accuracy': 0.72261}, {'accuracy': 0.7119800000000001}, {'accuracy': 0.73605}, {'accuracy': 0.72683}, {'accuracy': 0.7269599999999998}, {'accuracy': 0.74303}, {'accuracy': 0.73308}, {'accuracy': 0.74373}, {'accuracy': 0.7560800000000001}, {'accuracy': 0.70759}, {'accuracy': 0.75292}, {'accuracy': 0.6848700000000001}, {'accuracy': 0.6711400000000001}, {'accuracy': 0.72835}, {'accuracy': 0.77116}, {'accuracy': 0.69971}, {'accuracy': 0.7131700000000001}, {'accuracy': 0.68692}, {'accuracy': 0.7220500000000001}, {'accuracy': 0.73681}, {'accuracy': 0.78901}, {'accuracy': 0.7377800000000001}, {'accuracy': 0.6888099999999999}, {'accuracy': 0.7124400000000001}, {'accuracy': 0.7527199999999998}, {'accuracy': 0.72123}, {'accuracy': 0.7377100000000001}, {'accuracy': 0.7536599999999999}, {'accuracy': 0.7806}, {'accuracy': 0.7079899999999999}, {'accuracy': 0.7366900000000001}, {'accuracy': 0.78207}, {'accuracy': 0.79674}, {'accuracy': 0.77891}, {'accuracy': 0.74196}, {'accuracy': 0.77174}, {'accuracy': 0.69246}, {'accuracy': 0.78415}, {'accuracy': 0.7516299999999999}, {'accuracy': 0.74617}, {'accuracy': 0.80777}, {'accuracy': 0.7523299999999999}, {'accuracy': 0.7480200000000001}, {'accuracy': 0.7718499999999999}, {'accuracy': 0.7690300000000001}, {'accuracy': 0.7333299999999999}, {'accuracy': 0.72744}, {'accuracy': 0.73963}, {'accuracy': 0.75404}, {'accuracy': 0.6785100000000001}, {'accuracy': 0.6983699999999999}, {'accuracy': 0.69709}, {'accuracy': 0.72484}, {'accuracy': 0.8177}, {'accuracy': 0.67132}, {'accuracy': 0.71529}, {'accuracy': 0.70286}, {'accuracy': 0.75286}, {'accuracy': 0.7565899999999999}, {'accuracy': 0.7706600000000001}, {'accuracy': 0.7710899999999999}, {'accuracy': 0.6837799999999999}, {'accuracy': 0.8876600000000001}, {'accuracy': 0.8552100000000001}, {'accuracy': 0.8604900000000001}, {'accuracy': 0.85232}, {'accuracy': 0.85107}, {'accuracy': 0.83598}, {'accuracy': 0.90833}, {'accuracy': 0.9104099999999999}, {'accuracy': 0.8888400000000001}, {'accuracy': 0.9075900000000001}, {'accuracy': 0.91307}, {'accuracy': 0.9135300000000001}, {'accuracy': 0.8986599999999999}, {'accuracy': 0.8961200000000001}, {'accuracy': 0.8990499999999999}, {'accuracy': 0.8857700000000002}, {'accuracy': 0.88979}, {'accuracy': 0.9000200000000002}, {'accuracy': 0.91378}, {'accuracy': 0.9055399999999999}, {'accuracy': 0.8941399999999998}, {'accuracy': 0.9131500000000001}, {'accuracy': 0.9133899999999999}, {'accuracy': 0.91403}, {'accuracy': 0.90038}, {'accuracy': 0.9013899999999999}, {'accuracy': 0.8981199999999999}, {'accuracy': 0.9094300000000001}, {'accuracy': 0.89653}, {'accuracy': 0.8985899999999999}, {'accuracy': 0.9082000000000001}, {'accuracy': 0.8863800000000002}, {'accuracy': 0.8821199999999999}, {'accuracy': 0.91646}, {'accuracy': 0.8952100000000002}, {'accuracy': 0.88994}, {'accuracy': 0.9119700000000002}, {'accuracy': 0.8897299999999999}, {'accuracy': 0.9033}, {'accuracy': 0.9031499999999999}, {'accuracy': 0.8890500000000001}, {'accuracy': 0.89517}, {'accuracy': 0.9167599999999998}, {'accuracy': 0.9129000000000002}, {'accuracy': 0.8882399999999999}, {'accuracy': 0.92337}, {'accuracy': 0.8981800000000002}, {'accuracy': 0.91303}, {'accuracy': 0.9212199999999999}, {'accuracy': 0.9147400000000001}, {'accuracy': 0.8882}, {'accuracy': 0.88924}, {'accuracy': 0.92911}, {'accuracy': 0.8887700000000001}, {'accuracy': 0.8949199999999999}, {'accuracy': 0.9039200000000001}, {'accuracy': 0.8990900000000002}, {'accuracy': 0.9150400000000001}, {'accuracy': 0.8784700000000001}, {'accuracy': 0.8823400000000001}, {'accuracy': 0.9004899999999999}, {'accuracy': 0.8960699999999999}, {'accuracy': 0.8881500000000001}, {'accuracy': 0.91037}, {'accuracy': 0.9046299999999998}, {'accuracy': 0.8956100000000001}, {'accuracy': 0.9006099999999998}, {'accuracy': 0.8854899999999999}, {'accuracy': 0.9206800000000002}, {'accuracy': 0.8897700000000001}, {'accuracy': 0.8894500000000001}, {'accuracy': 0.88017}, {'accuracy': 0.90303}, {'accuracy': 0.8846999999999999}, {'accuracy': 0.88874}, {'accuracy': 0.9053599999999999}, {'accuracy': 0.8783200000000001}, {'accuracy': 0.89545}, {'accuracy': 0.88902}, {'accuracy': 0.91364}, {'accuracy': 0.88444}, {'accuracy': 0.8823200000000002}, {'accuracy': 0.89244}, {'accuracy': 0.9038000000000002}, {'accuracy': 0.8844199999999999}, {'accuracy': 0.88717}, {'accuracy': 0.9057999999999999}, {'accuracy': 0.8967099999999999}, {'accuracy': 0.8888599999999999}, {'accuracy': 0.88459}, {'accuracy': 0.87395}, {'accuracy': 0.8969100000000001}, {'accuracy': 0.8808200000000002}, {'accuracy': 0.89147}, {'accuracy': 0.8883899999999999}, {'accuracy': 0.90276}, {'accuracy': 0.89008}, {'accuracy': 0.90323}, {'accuracy': 0.9008600000000001}, {'accuracy': 0.8898999999999999}, {'accuracy': 0.9082500000000001}, {'accuracy': 0.8860299999999999}, {'accuracy': 0.9075399999999998}, {'accuracy': 0.9131699999999998}, {'accuracy': 0.89815}, {'accuracy': 0.8804000000000001}, {'accuracy': 0.90655}, {'accuracy': 0.8844899999999999}, {'accuracy': 0.88737}, {'accuracy': 0.9034600000000002}, {'accuracy': 0.88233}, {'accuracy': 0.8955599999999999}, {'accuracy': 0.9108400000000001}, {'accuracy': 0.8906499999999999}, {'accuracy': 0.88344}, {'accuracy': 0.91063}, {'accuracy': 0.9026500000000001}, {'accuracy': 0.88681}, {'accuracy': 0.89605}, {'accuracy': 0.8811199999999999}, {'accuracy': 0.9002799999999999}, {'accuracy': 0.89613}, {'accuracy': 0.89032}, {'accuracy': 0.9047999999999998}, {'accuracy': 0.91014}, {'accuracy': 0.8735899999999999}, {'accuracy': 0.90549}, {'accuracy': 0.87015}, {'accuracy': 0.91249}, {'accuracy': 0.90227}, {'accuracy': 0.9040800000000001}, {'accuracy': 0.91463}, {'accuracy': 0.88716}, {'accuracy': 0.8945299999999999}, {'accuracy': 0.8880800000000001}, {'accuracy': 0.9005600000000001}, {'accuracy': 0.8978599999999999}, {'accuracy': 0.8901600000000001}, {'accuracy': 0.89947}, {'accuracy': 0.8950700000000001}, {'accuracy': 0.8842800000000001}, {'accuracy': 0.8937800000000001}, {'accuracy': 0.9113100000000001}, {'accuracy': 0.89733}, {'accuracy': 0.8805999999999999}, {'accuracy': 0.89802}, {'accuracy': 0.8931099999999998}, {'accuracy': 0.9160400000000001}, {'accuracy': 0.90649}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "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": "5fd08630-3851-458b-b952-5e341f25b51b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65795dd9-c833-4986-b09b-41bc3b776dca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "55cbeddb-5d80-4880-8143-8737966dd06c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ed1c1d1-55eb-4a47-b086-ae79901b82c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0c94a94-5e0e-45c0-aa5e-3ec7b38f5ace",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f1d40d0-a08c-4b43-a592-627e3597e153",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b7f1a88-338e-4b34-8d15-90eb08fe4e74",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3843d8a0-f5ff-4f76-9b91-1aadc2cf2c9e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82a806cb-be9c-41b8-95e3-e85da6785c3f",
   "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
}
