{
 "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": [
      "[[   0 2422]\n",
      " [   1   67]\n",
      " [   2   48]\n",
      " [   3   68]\n",
      " [   4  101]\n",
      " [   5  190]\n",
      " [   6  307]\n",
      " [   7  514]\n",
      " [   8  869]\n",
      " [   9 1494]]\n",
      "[[   0 1459]\n",
      " [   1 2466]\n",
      " [   2   55]\n",
      " [   3   42]\n",
      " [   4   58]\n",
      " [   5  131]\n",
      " [   6  187]\n",
      " [   7  323]\n",
      " [   8  517]\n",
      " [   9  832]]\n",
      "[[   0  836]\n",
      " [   1 1399]\n",
      " [   2 2402]\n",
      " [   3   52]\n",
      " [   4   40]\n",
      " [   5   55]\n",
      " [   6   92]\n",
      " [   7  204]\n",
      " [   8  300]\n",
      " [   9  508]]\n",
      "[[   0  500]\n",
      " [   1  858]\n",
      " [   2 1404]\n",
      " [   3 2405]\n",
      " [   4   72]\n",
      " [   5   43]\n",
      " [   6   87]\n",
      " [   7  114]\n",
      " [   8  188]\n",
      " [   9  310]]\n",
      "[[   0  342]\n",
      " [   1  546]\n",
      " [   2  883]\n",
      " [   3 1443]\n",
      " [   4 2398]\n",
      " [   5   68]\n",
      " [   6   32]\n",
      " [   7   75]\n",
      " [   8  101]\n",
      " [   9  172]]\n",
      "[[   0  165]\n",
      " [   1  287]\n",
      " [   2  560]\n",
      " [   3  860]\n",
      " [   4 1430]\n",
      " [   5 2357]\n",
      " [   6   64]\n",
      " [   7   37]\n",
      " [   8   70]\n",
      " [   9  111]]\n",
      "[[   0  107]\n",
      " [   1  155]\n",
      " [   2  318]\n",
      " [   3  497]\n",
      " [   4  880]\n",
      " [   5 1426]\n",
      " [   6 2390]\n",
      " [   7   65]\n",
      " [   8   32]\n",
      " [   9   65]]\n",
      "[[   0   84]\n",
      " [   1  118]\n",
      " [   2  165]\n",
      " [   3  308]\n",
      " [   4  563]\n",
      " [   5  898]\n",
      " [   6 1476]\n",
      " [   7 2391]\n",
      " [   8   61]\n",
      " [   9   31]]\n",
      "[[   0   34]\n",
      " [   1   74]\n",
      " [   2  112]\n",
      " [   3  182]\n",
      " [   4  273]\n",
      " [   5  536]\n",
      " [   6  814]\n",
      " [   7 1422]\n",
      " [   8 2408]\n",
      " [   9   61]]\n",
      "[[   0   51]\n",
      " [   1   30]\n",
      " [   2   53]\n",
      " [   3  143]\n",
      " [   4  185]\n",
      " [   5  296]\n",
      " [   6  551]\n",
      " [   7  855]\n",
      " [   8 1454]\n",
      " [   9 2416]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6066\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2137]\n",
      " [   1   64]\n",
      " [   2   45]\n",
      " [   3   62]\n",
      " [   4   86]\n",
      " [   5  173]\n",
      " [   6  275]\n",
      " [   7  469]\n",
      " [   8  793]\n",
      " [   9 1290]]\n",
      "[[   0 2395]\n",
      " [   1   74]\n",
      " [   2   49]\n",
      " [   3   68]\n",
      " [   4  101]\n",
      " [   5  192]\n",
      " [   6  307]\n",
      " [   7  521]\n",
      " [   8  901]\n",
      " [   9 1442]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 8, 8, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "# noiseyset=[],[]\n",
    "# healthset=[],[],[]\n",
    "# import random\n",
    "# for z in range(0,60000,1):\n",
    "#     t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "#     if t<5:\n",
    "#         noiseyset[0].append(dataset1[z])\n",
    "#         healthset[0].append(dataset1[z])\n",
    "#         healthset[1].append(target1[z])\n",
    "#         healthset[2].append(z)\n",
    "#         noiseyset[1].append(torch.tensor(random.randint(0,9)))\n",
    "        \n",
    "        \n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 8, 8, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\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\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.83</span>                                                                <a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py#181\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">181</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.83\u001b[0m                                                                \u001b]8;id=635509;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py\u001b\\\u001b[2mutils.py\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=37443;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST10c%/../gossipy_original/utils.py#181\u001b\\\u001b[2m181\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACFbklEQVR4nO3dd3xT9foH8E92ugfdA8pWoICAIAqCUMCFWxG9gihuHBcXXBX0ehXHlYteB+pPQL1XQbnugSICypIte1PK6N5N28zz+yM5J+ckaZtA2pT28369+qJNTpJvTgPn4Xme7/erEgRBABEREVEboQ71AIiIiIiCicENERERtSkMboiIiKhNYXBDREREbQqDGyIiImpTGNwQERFRm8LghoiIiNoUBjdERETUpjC4ISIiojaFwQ0RNatVq1ZBpVJh1apV0m233347srKyQjamtuTZZ5+FSqUK9TCIWhUGN0St3O7du/GXv/wF6enpMBgMSEtLw6233ordu3eHemjN7u2338aiRYua9TX27NmDZ599Frm5uc36Oi3pxRdfxFdffRXqYRCFDIMbolbsiy++wIABA7BixQpMmTIFb7/9Nu68806sXLkSAwYMwJdffhnqITarlgpunnvuOQY3RG2INtQDICLfDh8+jNtuuw1dunTBb7/9hsTEROm+hx9+GMOHD8dtt92GHTt2oEuXLi02LpPJhIiIiBZ7vbMBzwlR68LMDVEr9eqrr6K2thbvvfeeIrABgISEBLz77rswmUx45ZVXAABLly6FSqXC6tWrvZ7r3XffhUqlwq5du6Tb9u3bhxtuuAHx8fEwGo0YNGgQvvnmG8XjFi1aJD3n/fffj6SkJGRkZAAAjh07hvvvvx89e/ZEWFgYOnTogBtvvDFoGZCsrCzs3r0bq1evhkqlgkqlwsiRI6X7Kyoq8MgjjyAzMxMGgwHdunXDyy+/DIfDoXiexYsXY+DAgYiKikJ0dDSys7Px+uuvS+/vxhtvBABccskl0uvI+4M83X777YiMjMThw4dx+eWXIyoqCrfeeisAwOFwYN68eejduzeMRiOSk5Nxzz33oLy8XPEcmzdvxrhx45CQkICwsDB07twZd9xxh3S/rz4lAMjNzYVKpWo0m6VSqWAymfDhhx9K7+f2228HAFRXV+ORRx5BVlYWDAYDkpKSMGbMGGzdurXB5yM6GzFzQ9RKffvtt8jKysLw4cN93n/xxRcjKysL33//PQDgiiuuQGRkJD777DOMGDFCceySJUvQu3dv9OnTB4Czj+eiiy5Ceno6ZsyYgYiICHz22We45ppr8L///Q/XXnut4vH3338/EhMTMWvWLJhMJgDApk2bsG7dOtx8883IyMhAbm4u3nnnHYwcORJ79uxBeHj4Gb3/efPm4cEHH0RkZCSeeuopAEBycjIAoLa2FiNGjMDJkydxzz33oGPHjli3bh1mzpyJ/Px8zJs3DwCwfPlyTJw4EaNHj8bLL78MANi7dy/Wrl2Lhx9+GBdffDEeeughvPHGG/jb3/6Gc889FwCkPxtis9kwbtw4DBs2DP/85z+l93rPPfdg0aJFmDJlCh566CEcPXoUb775JrZt24a1a9dCp9OhqKgIY8eORWJiImbMmIHY2Fjk5ubiiy++OKPzJfr4448xdepUDB48GHfffTcAoGvXrgCAe++9F0uXLsW0adPQq1cvlJaWYs2aNdi7dy8GDBgQlNcnahUEImp1KioqBADC1Vdf3ehxV111lQBAqKqqEgRBECZOnCgkJSUJNptNOiY/P19Qq9XC3//+d+m20aNHC9nZ2UJ9fb10m8PhEC688EKhe/fu0m0LFy4UAAjDhg1TPKcgCEJtba3XeNavXy8AED766CPptpUrVwoAhJUrV0q3TZ48WejUqVOj700QBKF3797CiBEjvG5//vnnhYiICOHAgQOK22fMmCFoNBohLy9PEARBePjhh4Xo6Givsct9/vnnXuNrzOTJkwUAwowZMxS3//777wIA4b///a/i9mXLlilu//LLLwUAwqZNmxp8DV/nTBAE4ejRowIAYeHChdJts2fPFjz/KY+IiBAmT57s9bwxMTHCAw884Me7JDq7sSxF1ApVV1cDAKKioho9Try/qqoKADBhwgQUFRUpyhlLly6Fw+HAhAkTAABlZWX49ddfcdNNN6G6uholJSUoKSlBaWkpxo0bh4MHD+LkyZOK17nrrrug0WgUt4WFhUnfW61WlJaWolu3boiNjW32Msfnn3+O4cOHIy4uThp/SUkJcnJyYLfb8dtvvwEAYmNjYTKZsHz58qCP4b777vMaU0xMDMaMGaMY08CBAxEZGYmVK1dKYwKA7777DlarNejjakxsbCz++OMPnDp1qkVfl6ilMbghaoXEoEUMchriGQRdeumliImJwZIlS6RjlixZgv79+6NHjx4AgEOHDkEQBDzzzDNITExUfM2ePRsAUFRUpHidzp07e712XV0dZs2aJfW8JCQkIDExERUVFaisrDzNd+6fgwcPYtmyZV7jz8nJUYz//vvvR48ePXDZZZchIyMDd9xxB5YtW3bGr6/VaqXeI/mYKisrkZSU5DWumpoaaUwjRozA9ddfj+eeew4JCQm4+uqrsXDhQpjN5jMeV1NeeeUV7Nq1C5mZmRg8eDCeffZZHDlypNlfl6ilseeGqBWKiYlBamoqduzY0ehxO3bsQHp6OqKjowEABoMB11xzDb788ku8/fbbKCwsxNq1a/Hiiy9KjxEbbh977DGMGzfO5/N269ZN8bM8SyN68MEHsXDhQjzyyCMYOnQoYmJioFKpcPPNN3s19Qabw+HAmDFj8MQTT/i8XwzkkpKSsH37dvz000/48ccf8eOPP2LhwoWYNGkSPvzww9N+fYPBALVa+X9Dh8OBpKQk/Pe///X5GLEpXKVSYenSpdiwYQO+/fZb/PTTT7jjjjvw2muvYcOGDYiMjGxwUT673X7aYwaAm266CcOHD8eXX36Jn3/+Ga+++ipefvllfPHFF7jsssvO6LmJWhMGN0St1JVXXon3338fa9aswbBhw7zu//3335Gbm4t77rlHcfuECRPw4YcfYsWKFdi7dy8EQZBKUgCkaeM6nU7KdJyOpUuXYvLkyXjttdek2+rr61FRUXHaz+mpoYt8165dUVNT49f49Xo9xo8fj/Hjx8PhcOD+++/Hu+++i2eeeQbdunUL2uq+Xbt2xS+//IKLLrrIZzDo6YILLsAFF1yAF154AZ988gluvfVWLF68GFOnTkVcXBwAeJ3LY8eO+TWWxt5Tamoq7r//ftx///0oKirCgAED8MILLzC4oTaFZSmiVurxxx9HWFgY7rnnHpSWliruKysrw7333ovw8HA8/vjjivtycnIQHx+PJUuWYMmSJRg8eLCirJSUlISRI0fi3XffRX5+vtfrFhcX+zU+jUYDQRAUt/373/8+4+yCXEREhM9g6aabbsL69evx008/ed1XUVEBm80GAF7nTa1Wo2/fvgAglYHE9WnONCi76aabYLfb8fzzz3vdZ7PZpOcvLy/3Om/9+/dXjKlTp07QaDRS75Do7bff9mssvs6b3W73KhcmJSUhLS2tRUpiRC2JmRuiVqp79+748MMPceuttyI7Oxt33nknOnfujNzcXHzwwQcoKSnBp59+Kk3zFel0Olx33XVYvHgxTCYT/vnPf3o991tvvYVhw4YhOzsbd911F7p06YLCwkKsX78eJ06cwJ9//tnk+K688kp8/PHHiImJQa9evbB+/Xr88ssv6NChQ9DOwcCBA/HOO+/gH//4B7p164akpCSMGjUKjz/+OL755htceeWVuP322zFw4ECYTCbs3LkTS5cuRW5uLhISEjB16lSUlZVh1KhRyMjIwLFjx/Dvf/8b/fv3l6Z79+/fHxqNBi+//DIqKythMBgwatQoJCUlBTTWESNG4J577sGcOXOwfft2jB07FjqdDgcPHsTnn3+O119/HTfccAM+/PBDvP3227j22mvRtWtXVFdX4/3330d0dDQuv/xyAM6y5I033oh///vfUKlU6Nq1K7777juvXqjGztsvv/yCuXPnIi0tDZ07d0bPnj2RkZGBG264Af369UNkZCR++eUXbNq0SZF9I2oTQjtZi4iasmPHDmHixIlCamqqoNPphJSUFGHixInCzp07G3zM8uXLBQCCSqUSjh8/7vOYw4cPC5MmTRJSUlIEnU4npKenC1deeaWwdOlS6RhxKrivacvl5eXClClThISEBCEyMlIYN26csG/fPqFTp06KachnMhW8oKBAuOKKK4SoqCgBgGJaeHV1tTBz5kyhW7dugl6vFxISEoQLL7xQ+Oc//ylYLBZBEARh6dKlwtixY4WkpCRBr9cLHTt2FO655x4hPz9f8Trvv/++0KVLF0Gj0TQ5LXzy5MlCREREg/e/9957wsCBA4WwsDAhKipKyM7OFp544gnh1KlTgiAIwtatW4WJEycKHTt2FAwGg5CUlCRceeWVwubNmxXPU1xcLFx//fVCeHi4EBcXJ9xzzz3Crl27/JoKvm/fPuHiiy8WwsLCBADC5MmTBbPZLDz++ONCv379hKioKCEiIkLo16+f8Pbbbzf2KyA6K6kEwSM/SkRERHQWY88NERERtSkMboiIiKhNYXBDREREbQqDGyIiImpTGNwQERFRm8LghoiIiNqUdreIn8PhwKlTpxAVFRW0ZdeJiIioeQmCgOrqaqSlpXnt7eap3QU3p06dQmZmZqiHQURERKfh+PHjyMjIaPSYdhfcREVFAXCeHHEnZSIiImrd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L7wAABg1ahSmTZumOL64uBh6vR4rVqwIxmnziVPBg8TmcG+9wHUViIhaB0EQUGcNzUrFYTpNQNcDk8mE6dOno2/fvqipqcGsWbNw7bXXYvv27aitrcWIESOQnp6Ob775BikpKdi6dSscrmvP999/j2uvvRZPPfUUPvroI1gsFvzwww8Bj3nGjBl47bXXcN5558FoNKK+vh4DBw7Ek08+iejoaHz//fe47bbb0LVrVwwePBgAMHPmTLz//vv417/+hWHDhiE/Px/79u0DAEydOhXTpk3Da6+9BoPBAAD4z3/+g/T0dIwaNSrg8fmLwU2QcAE/IqLWp85qR69ZP4Xktff8fRzC9f5fZq+//nrFzwsWLEBiYiL27NmDdevWobi4GJs2bUJ8fDwAoFu3btKxL7zwAm6++WY899xz0m39+vULeMyPPPIIrrvuOsVtjz32mPT9gw8+iJ9++gmfffYZBg8ejOrqarz++ut48803MXnyZABA165dMWzYMADAddddh2nTpuHrr7/GTTfdBABYtGgRbr/99mZNBPBKHCQWbppJRERn4ODBg5g4cSK6dOmC6OhoZGVlAQDy8vKwfft2nHfeeVJg42n79u0YPXr0GY9h0KBBip/tdjuef/55ZGdnIz4+HpGRkfjpp5+Ql5cHANi7dy/MZnODr200GnHbbbdhwYIFAICtW7di165duP322894rI1h5iZIxMwN17ghImo9wnQa7Pn7uJC9diDGjx+PTp064f3330daWhocDgf69OkDi8WCsLCwxl+riftVKhUEQVDc5qthOCIiQvHzq6++itdffx3z5s1DdnY2IiIi8Mgjj8Bisfj1uoCzNNW/f3+cOHECCxcuxKhRo9CpU6cmH3cmeCUOEm69QETU+qhUKoTrtSH5CqTsUlpaiv379+Ppp5/G6NGjce6556K8vFy6v2/fvti+fTvKysp8Pr5v376NNugmJiYiPz9f+vngwYN+bS66du1aXH311fjLX/6Cfv36oUuXLjhw4IB0f/fu3REWFtboa2dnZ2PQoEF4//338cknn+COO+5o8nXPVKsIbt566y1kZWXBaDRiyJAh2LhxY4PHvv/++xg+fDji4uIQFxeHnJycRo9vKeLWC+y5ISKiQMXFxaFDhw547733cOjQIfz666+YPn26dP/EiRORkpKCa665BmvXrsWRI0fwv//9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fBARERFRaLDnhoiIiNoUBjdERETUpjC4ISIiojaFwQ0RERG1KQxuiIiIqE1hcENERERtCoMbIiIialMY3BBRu7Bq1SqoVCqv/W+IqO1hcENERERtCoMbIiIialMY3BBRq+JwOPDKK6+gW7duMBgM6NixI1544QWMGjUK06ZNUxxbXFwMvV4v7UZsNpvx5JNPIjMzEwaDAd26dcMHH3zQ4GutWbMGw4cPR1hYGDIzM/HQQw/BZDI16/sjoubH4IaIWpWZM2fipZdewjPPPIM9e/bgk08+QXJyMqZOnYpPPvkEZrNZOvY///kP0tPTMWrUKADApEmT8Omnn+KNN97A3r178e677yIyMtLn6xw+fBiXXnoprr/+euzYsQNLlizBmjVrvAIoIjr7cONMImo1qqurkZiYiDfffBNTp05V3FdfX4+0tDTMnz8fN910EwCgX79+uO666zB79mwcOHAAPXv2xPLly5GTk+P13KtWrcIll1yC8vJyxMbGYurUqdBoNHj33XelY9asWYMRI0bAZDLBaDQ275slombDzA0RtRp79+6F2WzG6NGjve4zGo247bbbsGDBAgDA1q1bsWvXLtx+++0AgO3bt0Oj0WDEiBF+vdaff/6JRYsWITIyUvoaN24cHA4Hjh49GrT3REQtTxvqARARicLCwhq9f+rUqejfvz9OnDiBhQsXYtSoUejUqZNfj/VUU1ODe+65Bw899JDXfR07dgzouYiodWHmhohaje7duyMsLExqEPaUnZ2NQYMG4f3338cnn3yCO+64Q3Gfw+HA6tWr/XqtAQMGYM+ePejWrZvXl16vD8r7IaLQYHBDRK2G0WjEk08+iSeeeAIfffQRDh8+jA0bNihmPE2dOhUvvfQSBEHAtddeK92elZWFyZMn44477sBXX32Fo0ePYtWqVfjss898vtaTTz6JdevWYdq0adi+fTsOHjyIr7/+mg3FRG0AgxsialWeeeYZPProo5g1axbOPfdcTJgwAUVFRdL9EydOhFarxcSJE72aft955x3ccMMNuP/++3HOOefgrrvuanBqd9++fbF69WocOHAAw4cPx3nnnYdZs2YhLS2tWd8fETU/zpYiorNKbm4uunbtik2bNmHAgAGhHg4RtUIMbojorGC1WlFaWorHHnsMR48exdq1a0M9JCJqpViWIqKzwtq1a5GamopNmzZh/vz5oR4OEbVizNwQERFRm8LMDREREbUpDG6IiIioTWFwQ0RERG0KgxsiIiJqUxjcEBERUZvC4IaIiIjaFAY3RERE1KYwuCEiIqI2hcENERERtSn/D9ijkDwNzWjtAAAAAElFTkSuQmCC",
      "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.20694999999999997}, {'accuracy': 0.3443}, {'accuracy': 0.33368000000000003}, {'accuracy': 0.37431000000000003}, {'accuracy': 0.39720000000000005}, {'accuracy': 0.43404}, {'accuracy': 0.43859000000000004}, {'accuracy': 0.41323999999999994}, {'accuracy': 0.48824000000000006}, {'accuracy': 0.49363}, {'accuracy': 0.51861}, {'accuracy': 0.53805}, {'accuracy': 0.53038}, {'accuracy': 0.54912}, {'accuracy': 0.52607}, {'accuracy': 0.52698}, {'accuracy': 0.51832}, {'accuracy': 0.61112}, {'accuracy': 0.5283800000000001}, {'accuracy': 0.53576}, {'accuracy': 0.52745}, {'accuracy': 0.5720799999999999}, {'accuracy': 0.5677399999999999}, {'accuracy': 0.55099}, {'accuracy': 0.57723}, {'accuracy': 0.5871700000000001}, {'accuracy': 0.6023900000000001}, {'accuracy': 0.6023700000000001}, {'accuracy': 0.6048200000000001}, {'accuracy': 0.6290000000000001}, {'accuracy': 0.58408}, {'accuracy': 0.6157999999999999}, {'accuracy': 0.6431399999999999}, {'accuracy': 0.6667000000000001}, {'accuracy': 0.61456}, {'accuracy': 0.6190100000000001}, {'accuracy': 0.6172599999999999}, {'accuracy': 0.6100399999999999}, {'accuracy': 0.5963200000000001}, {'accuracy': 0.6296200000000001}, {'accuracy': 0.6254500000000001}, {'accuracy': 0.6753300000000001}, {'accuracy': 0.61707}, {'accuracy': 0.68598}, {'accuracy': 0.65493}, {'accuracy': 0.6235099999999999}, {'accuracy': 0.60952}, {'accuracy': 0.6328400000000001}, {'accuracy': 0.61765}, {'accuracy': 0.56369}, {'accuracy': 0.64033}, {'accuracy': 0.65713}, {'accuracy': 0.66147}, {'accuracy': 0.64915}, {'accuracy': 0.69648}, {'accuracy': 0.6405400000000001}, {'accuracy': 0.64266}, {'accuracy': 0.67823}, {'accuracy': 0.64229}, {'accuracy': 0.6862199999999999}, {'accuracy': 0.65671}, {'accuracy': 0.65714}, {'accuracy': 0.68239}, {'accuracy': 0.6515099999999999}, {'accuracy': 0.6580699999999999}, {'accuracy': 0.6973}, {'accuracy': 0.6503599999999998}, {'accuracy': 0.66347}, {'accuracy': 0.6533100000000001}, {'accuracy': 0.6949799999999999}, {'accuracy': 0.74935}, {'accuracy': 0.6665199999999999}, {'accuracy': 0.66432}, {'accuracy': 0.64442}, {'accuracy': 0.69313}, {'accuracy': 0.7357600000000001}, {'accuracy': 0.70854}, {'accuracy': 0.6881700000000001}, {'accuracy': 0.6529}, {'accuracy': 0.6815800000000001}, {'accuracy': 0.7059}, {'accuracy': 0.7116899999999999}, {'accuracy': 0.6689}, {'accuracy': 0.66271}, {'accuracy': 0.6737499999999998}, {'accuracy': 0.6609299999999999}, {'accuracy': 0.6860299999999999}, {'accuracy': 0.70928}, {'accuracy': 0.6892099999999999}, {'accuracy': 0.68333}, {'accuracy': 0.67706}, {'accuracy': 0.66482}, {'accuracy': 0.6732899999999999}, {'accuracy': 0.6668099999999999}, {'accuracy': 0.70781}, {'accuracy': 0.68415}, {'accuracy': 0.6719899999999999}, {'accuracy': 0.68866}, {'accuracy': 0.64827}, {'accuracy': 0.68563}, {'accuracy': 0.68086}, {'accuracy': 0.7033699999999999}, {'accuracy': 0.6640400000000002}, {'accuracy': 0.70261}, {'accuracy': 0.7173700000000001}, {'accuracy': 0.7041899999999999}, {'accuracy': 0.6960999999999998}, {'accuracy': 0.6728799999999999}, {'accuracy': 0.67996}, {'accuracy': 0.69702}, {'accuracy': 0.7305200000000001}, {'accuracy': 0.7255299999999999}, {'accuracy': 0.69192}, {'accuracy': 0.70779}, {'accuracy': 0.69781}, {'accuracy': 0.6985500000000001}, {'accuracy': 0.7216199999999999}, {'accuracy': 0.7757800000000001}, {'accuracy': 0.73557}, {'accuracy': 0.69566}, {'accuracy': 0.6644400000000001}, {'accuracy': 0.7121799999999999}, {'accuracy': 0.70723}, {'accuracy': 0.68155}, {'accuracy': 0.7011999999999999}, {'accuracy': 0.7026899999999999}, {'accuracy': 0.71972}, {'accuracy': 0.75834}, {'accuracy': 0.70039}, {'accuracy': 0.7507900000000001}, {'accuracy': 0.7415499999999999}, {'accuracy': 0.69126}, {'accuracy': 0.71753}, {'accuracy': 0.7334999999999999}, {'accuracy': 0.6933100000000001}, {'accuracy': 0.7135}, {'accuracy': 0.7089399999999999}, {'accuracy': 0.70365}, {'accuracy': 0.68296}, {'accuracy': 0.71577}, {'accuracy': 0.6629999999999999}, {'accuracy': 0.7720499999999999}, {'accuracy': 0.77928}, {'accuracy': 0.69507}, {'accuracy': 0.70147}, {'accuracy': 0.72374}, {'accuracy': 0.7393500000000001}, {'accuracy': 0.72699}, {'accuracy': 0.6640699999999999}, {'accuracy': 0.68833}, {'accuracy': 0.70071}, {'accuracy': 0.75037}, {'accuracy': 0.7392100000000001}, {'accuracy': 0.72766}, {'accuracy': 0.70374}, {'accuracy': 0.70404}, {'accuracy': 0.66178}, {'accuracy': 0.7491}, {'accuracy': 0.71432}, {'accuracy': 0.74113}, {'accuracy': 0.7036}, {'accuracy': 0.76514}, {'accuracy': 0.74234}, {'accuracy': 0.73379}, {'accuracy': 0.69876}, {'accuracy': 0.6850400000000001}, {'accuracy': 0.71204}, {'accuracy': 0.7000399999999999}, {'accuracy': 0.68201}, {'accuracy': 0.7016}, {'accuracy': 0.6968099999999999}, {'accuracy': 0.71428}, {'accuracy': 0.7125}, {'accuracy': 0.7339499999999999}, {'accuracy': 0.6834800000000001}, {'accuracy': 0.75653}, {'accuracy': 0.72667}, {'accuracy': 0.6977}, {'accuracy': 0.74501}, {'accuracy': 0.7017299999999999}, {'accuracy': 0.7505200000000001}, {'accuracy': 0.7607999999999999}, {'accuracy': 0.70252}, {'accuracy': 0.6938}, {'accuracy': 0.7412600000000001}, {'accuracy': 0.7605600000000001}, {'accuracy': 0.7120400000000001}, {'accuracy': 0.70221}, {'accuracy': 0.7263}, {'accuracy': 0.73817}, {'accuracy': 0.77148}, {'accuracy': 0.77798}, {'accuracy': 0.6975300000000001}, {'accuracy': 0.69626}, {'accuracy': 0.6748799999999999}, {'accuracy': 0.7475299999999999}, {'accuracy': 0.73083}, {'accuracy': 0.7806}, {'accuracy': 0.72795}, {'accuracy': 0.75024}, {'accuracy': 0.82813}, {'accuracy': 0.83079}, {'accuracy': 0.83316}, {'accuracy': 0.8309599999999999}, {'accuracy': 0.8307500000000001}, {'accuracy': 0.83234}, {'accuracy': 0.8308099999999999}, {'accuracy': 0.83332}, {'accuracy': 0.82873}, {'accuracy': 0.83076}, {'accuracy': 0.83063}, {'accuracy': 0.8327100000000002}, {'accuracy': 0.83109}, {'accuracy': 0.8332499999999999}, {'accuracy': 0.8290900000000001}, {'accuracy': 0.8331199999999999}, {'accuracy': 0.828}, {'accuracy': 0.83271}, {'accuracy': 0.8337899999999999}, {'accuracy': 0.82833}, {'accuracy': 0.8309300000000001}, {'accuracy': 0.8324999999999999}, {'accuracy': 0.8307800000000002}, {'accuracy': 0.83108}, {'accuracy': 0.83178}, {'accuracy': 0.8311299999999999}, {'accuracy': 0.8299399999999999}, {'accuracy': 0.83642}, {'accuracy': 0.83016}, {'accuracy': 0.8333}, {'accuracy': 0.83104}, {'accuracy': 0.83173}, {'accuracy': 0.8309599999999999}, {'accuracy': 0.83429}, {'accuracy': 0.8334400000000001}, {'accuracy': 0.8340000000000002}, {'accuracy': 0.83097}, {'accuracy': 0.8296899999999999}, {'accuracy': 0.83201}, {'accuracy': 0.8331799999999999}, {'accuracy': 0.83141}, {'accuracy': 0.8332099999999999}, {'accuracy': 0.83195}, {'accuracy': 0.83266}, {'accuracy': 0.83124}, {'accuracy': 0.8323499999999999}, {'accuracy': 0.83073}, {'accuracy': 0.8333299999999999}, {'accuracy': 0.8317}, {'accuracy': 0.83187}, {'accuracy': 0.8312899999999999}, {'accuracy': 0.83079}, {'accuracy': 0.83101}, {'accuracy': 0.8339399999999999}, {'accuracy': 0.8329700000000001}, {'accuracy': 0.8307100000000001}, {'accuracy': 0.83138}, {'accuracy': 0.83429}, {'accuracy': 0.8315899999999999}, {'accuracy': 0.8336400000000002}, {'accuracy': 0.8298300000000001}, {'accuracy': 0.8321799999999999}, {'accuracy': 0.8322900000000001}, {'accuracy': 0.8319899999999999}, {'accuracy': 0.8324999999999999}, {'accuracy': 0.83274}, {'accuracy': 0.83355}, {'accuracy': 0.83237}, {'accuracy': 0.83049}, {'accuracy': 0.8334100000000001}, {'accuracy': 0.83415}, {'accuracy': 0.83291}, {'accuracy': 0.83009}, {'accuracy': 0.83179}, {'accuracy': 0.8318099999999999}, {'accuracy': 0.8324200000000002}, {'accuracy': 0.8323}, {'accuracy': 0.8305400000000001}, {'accuracy': 0.8350900000000001}, {'accuracy': 0.83513}, {'accuracy': 0.83576}, {'accuracy': 0.83302}, {'accuracy': 0.8324900000000002}, {'accuracy': 0.8296300000000001}, {'accuracy': 0.8330400000000001}, {'accuracy': 0.8321}, {'accuracy': 0.83095}, {'accuracy': 0.8331099999999999}, {'accuracy': 0.83294}, {'accuracy': 0.83003}, {'accuracy': 0.8289200000000001}, {'accuracy': 0.83238}, {'accuracy': 0.83337}, {'accuracy': 0.83409}, {'accuracy': 0.8328099999999999}, {'accuracy': 0.82962}, {'accuracy': 0.8346500000000001}, {'accuracy': 0.8346199999999999}, {'accuracy': 0.8337600000000001}, {'accuracy': 0.83245}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aacc875-f5ef-40fe-b554-f4a24df054f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90eafb39-6280-49cf-8bc3-488f7848cfec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1990245d-61be-446e-aa86-81f09d52454f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7de073ae-f238-42b4-b966-70f821f18891",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5f4f110-4d3c-453d-94cb-14ba9315f58a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "100da884-0287-4750-ba40-24d3e5c18670",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d9fd195-69a4-4613-8f56-7a7ace4d1d52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7e9071e-47a9-46bf-a6ba-a36446b3dc9b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57cc8ef4-1fae-4a80-8590-793f6b87f77f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "088a411f-42b8-4a17-a2e5-8ec36d28d15f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d18eeee8-ff56-435a-9587-1ead6c43f434",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0cca6ffa-2e32-41a6-a949-b2ec9f6f1b1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440c827c-c5df-4170-8ae1-c2542168d8a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac6c83fc-df18-4c5e-ac05-5eb3856b7da9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f90ff1eb-ab44-44b4-bda7-b317c6dbf485",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a626435b-8326-407e-b8f2-2250aafe7f2b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a2f8591-006a-45c1-b635-acc8e8eff1bd",
   "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
}
