{
 "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 Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\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(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(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",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz\n",
      "Using downloaded and verified file: ./data/MNIST/raw/train-images-idx3-ubyte.gz\n",
      "Extracting ./data/MNIST/raw/train-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz\n",
      "Using downloaded and verified file: ./data/MNIST/raw/train-labels-idx1-ubyte.gz\n",
      "Extracting ./data/MNIST/raw/train-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz\n",
      "Using downloaded and verified file: ./data/MNIST/raw/t10k-images-idx3-ubyte.gz\n",
      "Extracting ./data/MNIST/raw/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz\n",
      "Using downloaded and verified file: ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz\n",
      "Extracting ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "\n",
      "[[   0 2373]\n",
      " [   1   79]\n",
      " [   2   50]\n",
      " [   3   85]\n",
      " [   4   95]\n",
      " [   5  154]\n",
      " [   6  300]\n",
      " [   7  582]\n",
      " [   8  855]\n",
      " [   9 1407]]\n",
      "[[   0 1417]\n",
      " [   1 2663]\n",
      " [   2   46]\n",
      " [   3   42]\n",
      " [   4   81]\n",
      " [   5  111]\n",
      " [   6  203]\n",
      " [   7  367]\n",
      " [   8  511]\n",
      " [   9  871]]\n",
      "[[   0  868]\n",
      " [   1 1619]\n",
      " [   2 2350]\n",
      " [   3   68]\n",
      " [   4   40]\n",
      " [   5   58]\n",
      " [   6  106]\n",
      " [   7  205]\n",
      " [   8  292]\n",
      " [   9  520]]\n",
      "[[   0  513]\n",
      " [   1  968]\n",
      " [   2 1457]\n",
      " [   3 2449]\n",
      " [   4   59]\n",
      " [   5   42]\n",
      " [   6   52]\n",
      " [   7  108]\n",
      " [   8  202]\n",
      " [   9  296]]\n",
      "[[   0  312]\n",
      " [   1  597]\n",
      " [   2  897]\n",
      " [   3 1441]\n",
      " [   4 2372]\n",
      " [   5   56]\n",
      " [   6   40]\n",
      " [   7   71]\n",
      " [   8  112]\n",
      " [   9  185]]\n",
      "[[   0  166]\n",
      " [   1  363]\n",
      " [   2  506]\n",
      " [   3  854]\n",
      " [   4 1391]\n",
      " [   5 2138]\n",
      " [   6   60]\n",
      " [   7   40]\n",
      " [   8   51]\n",
      " [   9  110]]\n",
      "[[   0  120]\n",
      " [   1  219]\n",
      " [   2  310]\n",
      " [   3  554]\n",
      " [   4  852]\n",
      " [   5 1344]\n",
      " [   6 2398]\n",
      " [   7   55]\n",
      " [   8   39]\n",
      " [   9   61]]\n",
      "[[   0   66]\n",
      " [   1  111]\n",
      " [   2  171]\n",
      " [   3  319]\n",
      " [   4  497]\n",
      " [   5  768]\n",
      " [   6 1392]\n",
      " [   7 2521]\n",
      " [   8   76]\n",
      " [   9   39]]\n",
      "[[   0   29]\n",
      " [   1   76]\n",
      " [   2  108]\n",
      " [   3  195]\n",
      " [   4  302]\n",
      " [   5  471]\n",
      " [   6  851]\n",
      " [   7 1436]\n",
      " [   8 2368]\n",
      " [   9   66]]\n",
      "[[   0   59]\n",
      " [   1   47]\n",
      " [   2   63]\n",
      " [   3  124]\n",
      " [   4  153]\n",
      " [   5  279]\n",
      " [   6  516]\n",
      " [   7  880]\n",
      " [   8 1345]\n",
      " [   9 2394]]\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": [
      "2357\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2204]\n",
      " [   1   79]\n",
      " [   2   43]\n",
      " [   3   85]\n",
      " [   4   88]\n",
      " [   5  154]\n",
      " [   6  268]\n",
      " [   7  582]\n",
      " [   8  855]\n",
      " [   9 1407]]\n",
      "[[   0 2446]\n",
      " [   1   79]\n",
      " [   2   45]\n",
      " [   3   85]\n",
      " [   4  100]\n",
      " [   5  154]\n",
      " [   6  310]\n",
      " [   7  582]\n",
      " [   8  855]\n",
      " [   9 1407]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 6, 6, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==2:\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(4))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==4:\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(2))     \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",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "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\">180923-04:05:14 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.93</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m180923-04:05:14\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.93\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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HXD99dcjPT1duj8rKwuTJk1CcHAwfHx8MHDgQOzatUu6/48//sBll10GT09PhISEYMKECdJ9MpkMv/76q9X7BQYGYunSpQCAzMxMyGQyrFixAiNHjoSnpye+++47FBUVYdKkSYiOjoa3tzeSk5OxbNkyq9cxGo148803kZSUBLVajY4dO+LVV18FAIwePRqzZ8+2enxBQQFUKhXWr1/vjMNmF5eCO4k4JQVwWoqIqK0QBAHVetfsVOylVDi0+kej0WDOnDno3bs3KisrMX/+fEyYMAEpKSmoqqrCyJEjER0djd9//x0RERHYv38/jEbTjMFff/2FCRMm4Nlnn8U333wDnU6Hv//+2+Exz507F++88w769esHT09P1NTUYMCAAXjmmWfg7++Pv/76C3fffTcSExMxaNAgAMC8efPwxRdf4L333sOwYcOQk5OD48ePAwCmT5+O2bNn45133oFarQYA/O9//0N0dDRGjx7t8Piai+HGScQpKYDhhoiorajWG9Bj/mqXvPexl8bDW9X80+ytt95q9fVXX32F0NBQHDt2DNu3b0dBQQH27NmD4OBgAEBSUpL02FdffRV33nknXnzxRem2Pn36ODzmxx57DLfccovVbU8++aT094cffhirV6/GDz/8gEGDBqGiogLvv/8+Fi9ejKlTpwIAEhMTMWzYMADALbfcgtmzZ+O3337DHXfcAQBYunQp7rnnnhbdYJFnYScRw43KQ84dMYmIyGFpaWmYNGkSEhIS4O/vj7i4OADA2bNnkZKSgn79+knBpr6UlBSMGTPmoscwcOBAq68NBgNefvllJCcnIzg4GL6+vli9ejXOnj0LAEhNTYVWq23wvT09PXH33Xfjq6++AgDs378fR44cwT333HPRY20MKzdOouPuxEREbY6XUoFjL4132Xs74oYbbkCnTp3wxRdfICoqCkajEb169YJOp4OXl1fj79XE/TKZDILYGGpmr2HYx8fH6uu33noL77//PhYtWoTk5GT4+Pjgscceg06na9b7Aqapqb59+yIrKwtLlizB6NGj0alTpyafdzF4JnaSumXgbCYmImorZDIZvFUeLvnjSBW/qKgIJ06cwHPPPYcxY8age/fuKCkpke7v3bs3UlJSUFxcbPf5vXv3brRBNzQ0FDk5OdLXaWlpzbq46LZt23DTTTfhP//5D/r06YOEhASc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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.11749000000000001}, {'accuracy': 0.23874}, {'accuracy': 0.25736000000000003}, {'accuracy': 0.28412}, {'accuracy': 0.29614}, {'accuracy': 0.28424}, {'accuracy': 0.31527000000000005}, {'accuracy': 0.35358999999999996}, {'accuracy': 0.29964}, {'accuracy': 0.3781}, {'accuracy': 0.37514}, {'accuracy': 0.43892}, {'accuracy': 0.45782999999999996}, {'accuracy': 0.4483}, {'accuracy': 0.46202}, {'accuracy': 0.46534999999999993}, {'accuracy': 0.49009}, {'accuracy': 0.54627}, {'accuracy': 0.50877}, {'accuracy': 0.60531}, {'accuracy': 0.61268}, {'accuracy': 0.67327}, {'accuracy': 0.6432}, {'accuracy': 0.67926}, {'accuracy': 0.6864399999999999}, {'accuracy': 0.70886}, {'accuracy': 0.6895899999999999}, {'accuracy': 0.68384}, {'accuracy': 0.67919}, {'accuracy': 0.68362}, {'accuracy': 0.70586}, {'accuracy': 0.68755}, {'accuracy': 0.69117}, {'accuracy': 0.68773}, {'accuracy': 0.74143}, {'accuracy': 0.73711}, {'accuracy': 0.7255499999999999}, {'accuracy': 0.73155}, {'accuracy': 0.7262500000000001}, {'accuracy': 0.74346}, {'accuracy': 0.7839}, {'accuracy': 0.7292400000000001}, {'accuracy': 0.7493700000000001}, {'accuracy': 0.69307}, {'accuracy': 0.7499800000000001}, {'accuracy': 0.7612500000000001}, {'accuracy': 0.73239}, {'accuracy': 0.75145}, {'accuracy': 0.7707499999999999}, {'accuracy': 0.77587}, {'accuracy': 0.79924}, {'accuracy': 0.78514}, {'accuracy': 0.72557}, {'accuracy': 0.7832699999999999}, {'accuracy': 0.7821499999999999}, {'accuracy': 0.78257}, {'accuracy': 0.7776299999999999}, {'accuracy': 0.76752}, {'accuracy': 0.7392299999999999}, {'accuracy': 0.8036099999999999}, {'accuracy': 0.8015700000000001}, {'accuracy': 0.7779100000000001}, {'accuracy': 0.7801199999999999}, {'accuracy': 0.7812499999999999}, {'accuracy': 0.77357}, {'accuracy': 0.7947500000000001}, {'accuracy': 0.78}, {'accuracy': 0.8197800000000001}, {'accuracy': 0.81138}, {'accuracy': 0.75564}, {'accuracy': 0.79023}, {'accuracy': 0.78962}, {'accuracy': 0.78104}, {'accuracy': 0.8205899999999999}, {'accuracy': 0.79704}, {'accuracy': 0.8447799999999999}, {'accuracy': 0.8021499999999999}, {'accuracy': 0.82162}, {'accuracy': 0.8236100000000001}, {'accuracy': 0.7489600000000001}, {'accuracy': 0.8375999999999999}, {'accuracy': 0.80141}, {'accuracy': 0.8033199999999999}, {'accuracy': 0.81448}, {'accuracy': 0.79845}, {'accuracy': 0.78448}, {'accuracy': 0.8076000000000001}, {'accuracy': 0.7920999999999999}, {'accuracy': 0.78377}, {'accuracy': 0.7908899999999999}, {'accuracy': 0.8064}, {'accuracy': 0.80288}, {'accuracy': 0.82506}, {'accuracy': 0.79816}, {'accuracy': 0.7831}, {'accuracy': 0.80121}, {'accuracy': 0.81483}, {'accuracy': 0.8152100000000001}, {'accuracy': 0.80112}, {'accuracy': 0.8012900000000001}, {'accuracy': 0.7980600000000001}, {'accuracy': 0.7862}, {'accuracy': 0.82882}, {'accuracy': 0.8190099999999999}, {'accuracy': 0.7560800000000001}, {'accuracy': 0.8014699999999999}, {'accuracy': 0.86921}, {'accuracy': 0.83361}, {'accuracy': 0.80404}, {'accuracy': 0.80783}, {'accuracy': 0.81898}, {'accuracy': 0.81713}, {'accuracy': 0.7732700000000001}, {'accuracy': 0.8526399999999998}, {'accuracy': 0.81106}, {'accuracy': 0.82051}, {'accuracy': 0.85616}, {'accuracy': 0.82379}, {'accuracy': 0.79176}, {'accuracy': 0.79853}, {'accuracy': 0.8140000000000001}, {'accuracy': 0.84396}, {'accuracy': 0.8226000000000001}, {'accuracy': 0.80786}, {'accuracy': 0.8233599999999999}, {'accuracy': 0.7859700000000001}, {'accuracy': 0.86213}, {'accuracy': 0.8087500000000001}, {'accuracy': 0.8259299999999999}, {'accuracy': 0.82072}, {'accuracy': 0.82027}, {'accuracy': 0.8352699999999998}, {'accuracy': 0.8036}, {'accuracy': 0.8126900000000001}, {'accuracy': 0.80223}, {'accuracy': 0.8211600000000001}, {'accuracy': 0.8301399999999999}, {'accuracy': 0.8254399999999998}, {'accuracy': 0.8379700000000001}, {'accuracy': 0.82925}, {'accuracy': 0.8446199999999999}, {'accuracy': 0.82012}, {'accuracy': 0.8100999999999999}, {'accuracy': 0.8414900000000001}, {'accuracy': 0.80358}, {'accuracy': 0.8539899999999999}, {'accuracy': 0.8130499999999999}, {'accuracy': 0.7986699999999999}, {'accuracy': 0.8125}, {'accuracy': 0.8403700000000001}, {'accuracy': 0.8247399999999999}, {'accuracy': 0.82814}, {'accuracy': 0.8440799999999999}, {'accuracy': 0.80474}, {'accuracy': 0.79111}, {'accuracy': 0.81533}, {'accuracy': 0.79074}, {'accuracy': 0.84207}, {'accuracy': 0.82226}, {'accuracy': 0.84565}, {'accuracy': 0.8309300000000001}, {'accuracy': 0.78476}, {'accuracy': 0.8051}, {'accuracy': 0.8096099999999999}, {'accuracy': 0.8292999999999999}, {'accuracy': 0.8307399999999999}, {'accuracy': 0.8140099999999999}, {'accuracy': 0.80052}, {'accuracy': 0.8012599999999999}, {'accuracy': 0.8202}, {'accuracy': 0.83916}, {'accuracy': 0.8134}, {'accuracy': 0.8399300000000001}, {'accuracy': 0.8224500000000001}, {'accuracy': 0.8318299999999998}, {'accuracy': 0.82757}, {'accuracy': 0.8155899999999999}, {'accuracy': 0.81174}, {'accuracy': 0.79628}, {'accuracy': 0.77584}, {'accuracy': 0.79785}, {'accuracy': 0.85724}, {'accuracy': 0.8641099999999999}, {'accuracy': 0.8166800000000001}, {'accuracy': 0.82254}, {'accuracy': 0.8224}, {'accuracy': 0.7985}, {'accuracy': 0.79362}, {'accuracy': 0.82724}, {'accuracy': 0.83703}, {'accuracy': 0.84254}, {'accuracy': 0.8552899999999999}, {'accuracy': 0.84398}, {'accuracy': 0.81143}, {'accuracy': 0.7978500000000001}, {'accuracy': 0.84267}, {'accuracy': 0.83063}, {'accuracy': 0.84784}, {'accuracy': 0.8342500000000002}, {'accuracy': 0.8103399999999998}, {'accuracy': 0.8514900000000001}, {'accuracy': 0.90288}, {'accuracy': 0.94267}, {'accuracy': 0.9527300000000001}, {'accuracy': 0.9308900000000001}, {'accuracy': 0.9404199999999999}, {'accuracy': 0.9280700000000002}, {'accuracy': 0.94769}, {'accuracy': 0.93808}, {'accuracy': 0.92696}, {'accuracy': 0.9302499999999998}, {'accuracy': 0.9397500000000001}, {'accuracy': 0.93477}, {'accuracy': 0.92548}, {'accuracy': 0.9367700000000001}, {'accuracy': 0.9335099999999998}, {'accuracy': 0.9354800000000001}, {'accuracy': 0.9381999999999998}, {'accuracy': 0.9378299999999999}, {'accuracy': 0.93076}, {'accuracy': 0.9303400000000002}, {'accuracy': 0.9409699999999999}, {'accuracy': 0.9461400000000001}, {'accuracy': 0.9299899999999999}, {'accuracy': 0.9454}, {'accuracy': 0.9332099999999999}, {'accuracy': 0.94941}, {'accuracy': 0.9313299999999998}, {'accuracy': 0.9323599999999999}, {'accuracy': 0.9202999999999999}, {'accuracy': 0.9286599999999998}, {'accuracy': 0.93668}, {'accuracy': 0.92304}, {'accuracy': 0.91973}, {'accuracy': 0.9320299999999999}, {'accuracy': 0.95145}, {'accuracy': 0.9379399999999999}, {'accuracy': 0.93789}, {'accuracy': 0.94468}, {'accuracy': 0.93753}, {'accuracy': 0.9251100000000001}, {'accuracy': 0.9289700000000002}, {'accuracy': 0.9357899999999999}, {'accuracy': 0.9345700000000001}, {'accuracy': 0.9359400000000001}, {'accuracy': 0.9373000000000001}, {'accuracy': 0.93765}, {'accuracy': 0.9407300000000001}, {'accuracy': 0.9325699999999999}, {'accuracy': 0.9334800000000001}, {'accuracy': 0.9302699999999999}, {'accuracy': 0.9349599999999999}, {'accuracy': 0.9337899999999999}, {'accuracy': 0.9259800000000002}, {'accuracy': 0.92773}, {'accuracy': 0.9250499999999999}, {'accuracy': 0.93215}, {'accuracy': 0.9442400000000001}, {'accuracy': 0.93144}, {'accuracy': 0.9285599999999998}, {'accuracy': 0.93794}, {'accuracy': 0.92301}, {'accuracy': 0.93392}, {'accuracy': 0.93101}, {'accuracy': 0.93865}, {'accuracy': 0.9300600000000001}, {'accuracy': 0.93757}, {'accuracy': 0.9409799999999999}, {'accuracy': 0.9270900000000001}, {'accuracy': 0.9313199999999998}, {'accuracy': 0.94368}, {'accuracy': 0.9276099999999999}, {'accuracy': 0.9413199999999999}, {'accuracy': 0.9399599999999999}, {'accuracy': 0.94031}, {'accuracy': 0.93086}, {'accuracy': 0.9368500000000001}, {'accuracy': 0.93758}, {'accuracy': 0.93123}, {'accuracy': 0.93015}, {'accuracy': 0.9257099999999999}, {'accuracy': 0.9397300000000002}, {'accuracy': 0.93826}, {'accuracy': 0.9260400000000001}, {'accuracy': 0.9414}, {'accuracy': 0.9475899999999999}, {'accuracy': 0.93333}, {'accuracy': 0.94512}, {'accuracy': 0.92322}, {'accuracy': 0.94146}, {'accuracy': 0.9310699999999998}, {'accuracy': 0.9397900000000001}, {'accuracy': 0.9324600000000001}, {'accuracy': 0.9315200000000001}, {'accuracy': 0.9215899999999999}, {'accuracy': 0.93035}, {'accuracy': 0.9462999999999999}, {'accuracy': 0.9290200000000001}, {'accuracy': 0.93764}, {'accuracy': 0.9344100000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "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": "77c0f3cf-2999-40aa-93e7-73924d2c4f26",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e0edaa-0ae8-4e79-8c56-98d960f604bf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc31766d-d70e-4c8b-8918-3533fb21d9bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccc00971-e277-4bc2-a8d5-11829397e40c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "881255e2-5d20-40f8-9ca4-d7951edfc419",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "852e18c7-bf8c-43ec-8a00-3baf3abad300",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67b920fe-6085-4e7b-aa1e-ffee1c7da95d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5077bfe-47be-4497-9357-aae20abd8020",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b8c5d9e-0713-47d6-b65c-ad0cbbdb8381",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ac7c8f3-1533-4f2f-b87f-06f31d57846b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f2737a9-e89a-4404-b8f4-9de5f129bbf0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a0434dc-d371-4075-8aa8-690883a96449",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1d9f8b6-b0ee-4727-a582-f928f21c0e15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8634fbd-f547-4a8d-83e4-06c539e3c5e3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7e11e43-5cb3-4dff-b595-76a2002ed866",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b333099-aa35-4c32-b541-9ca1e36fdc91",
   "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
}
