{
 "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 2384]\n",
      " [   1   59]\n",
      " [   2   50]\n",
      " [   3   54]\n",
      " [   4  112]\n",
      " [   5  214]\n",
      " [   6  306]\n",
      " [   7  521]\n",
      " [   8  851]\n",
      " [   9 1448]]\n",
      "[[   0 1442]\n",
      " [   1 2370]\n",
      " [   2   60]\n",
      " [   3   43]\n",
      " [   4   57]\n",
      " [   5   97]\n",
      " [   6  166]\n",
      " [   7  329]\n",
      " [   8  488]\n",
      " [   9  871]]\n",
      "[[   0  862]\n",
      " [   1 1448]\n",
      " [   2 2389]\n",
      " [   3   62]\n",
      " [   4   47]\n",
      " [   5   69]\n",
      " [   6  113]\n",
      " [   7  194]\n",
      " [   8  313]\n",
      " [   9  494]]\n",
      "[[   0  541]\n",
      " [   1  886]\n",
      " [   2 1441]\n",
      " [   3 2367]\n",
      " [   4   50]\n",
      " [   5   34]\n",
      " [   6   72]\n",
      " [   7   94]\n",
      " [   8  179]\n",
      " [   9  285]]\n",
      "[[   0  290]\n",
      " [   1  537]\n",
      " [   2  880]\n",
      " [   3 1477]\n",
      " [   4 2320]\n",
      " [   5   60]\n",
      " [   6   40]\n",
      " [   7   78]\n",
      " [   8  117]\n",
      " [   9  204]]\n",
      "[[   0  190]\n",
      " [   1  346]\n",
      " [   2  502]\n",
      " [   3  844]\n",
      " [   4 1450]\n",
      " [   5 2418]\n",
      " [   6   53]\n",
      " [   7   41]\n",
      " [   8   67]\n",
      " [   9  111]]\n",
      "[[   0  114]\n",
      " [   1  169]\n",
      " [   2  316]\n",
      " [   3  514]\n",
      " [   4  858]\n",
      " [   5 1398]\n",
      " [   6 2449]\n",
      " [   7   71]\n",
      " [   8   41]\n",
      " [   9   53]]\n",
      "[[   0   68]\n",
      " [   1   94]\n",
      " [   2  203]\n",
      " [   3  316]\n",
      " [   4  553]\n",
      " [   5  876]\n",
      " [   6 1415]\n",
      " [   7 2359]\n",
      " [   8   53]\n",
      " [   9   33]]\n",
      "[[   0   47]\n",
      " [   1   56]\n",
      " [   2  100]\n",
      " [   3  202]\n",
      " [   4  366]\n",
      " [   5  539]\n",
      " [   6  852]\n",
      " [   7 1429]\n",
      " [   8 2456]\n",
      " [   9   60]]\n",
      "[[   0   62]\n",
      " [   1   35]\n",
      " [   2   59]\n",
      " [   3  121]\n",
      " [   4  187]\n",
      " [   5  295]\n",
      " [   6  534]\n",
      " [   7  884]\n",
      " [   8 1435]\n",
      " [   9 2441]]\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": "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": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "30044\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1178]\n",
      " [   1   30]\n",
      " [   2   21]\n",
      " [   3   25]\n",
      " [   4   65]\n",
      " [   5  107]\n",
      " [   6  148]\n",
      " [   7  247]\n",
      " [   8  464]\n",
      " [   9  711]]\n",
      "[[   0 2408]\n",
      " [   1   66]\n",
      " [   2   43]\n",
      " [   3   58]\n",
      " [   4  110]\n",
      " [   5  194]\n",
      " [   6  287]\n",
      " [   7  511]\n",
      " [   8  906]\n",
      " [   9 1450]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "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<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(((target1[z] - 1) % 10))\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",
    "\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": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:08:24 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:08:24\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9737167253eb41f8b62f0144a92b2887",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:18:18 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3306</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:18:18\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3306\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4876832676</span>                                                        <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m4876832676\u001b[0m                                                        \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10836000000000001}, {'accuracy': 0.12447000000000001}, {'accuracy': 0.09058000000000001}, {'accuracy': 0.1315}, {'accuracy': 0.09422}, {'accuracy': 0.12356}, {'accuracy': 0.10661000000000001}, {'accuracy': 0.11813000000000003}, {'accuracy': 0.11438000000000001}, {'accuracy': 0.11284000000000001}, {'accuracy': 0.13099000000000002}, {'accuracy': 0.10106}, {'accuracy': 0.11907000000000001}, {'accuracy': 0.10872}, {'accuracy': 0.11994000000000002}, {'accuracy': 0.13529000000000002}, {'accuracy': 0.11045}, {'accuracy': 0.11034000000000002}, {'accuracy': 0.09898}, {'accuracy': 0.11623000000000001}, {'accuracy': 0.10655}, {'accuracy': 0.11466000000000001}, {'accuracy': 0.11887000000000003}, {'accuracy': 0.10711}, {'accuracy': 0.11983999999999999}, {'accuracy': 0.11257000000000002}, {'accuracy': 0.12936}, {'accuracy': 0.12266000000000002}, {'accuracy': 0.11061000000000001}, {'accuracy': 0.12535000000000002}, {'accuracy': 0.11027}, {'accuracy': 0.12355000000000001}, {'accuracy': 0.11326}, {'accuracy': 0.15275}, {'accuracy': 0.12580000000000002}, {'accuracy': 0.11545000000000001}, {'accuracy': 0.10024}, {'accuracy': 0.11782999999999999}, {'accuracy': 0.1511}, {'accuracy': 0.11907000000000001}, {'accuracy': 0.10002}, {'accuracy': 0.10782}, {'accuracy': 0.11867000000000001}, {'accuracy': 0.12880999999999998}, {'accuracy': 0.11685000000000001}, {'accuracy': 0.15300000000000002}, {'accuracy': 0.13541000000000003}, {'accuracy': 0.10015}, {'accuracy': 0.14701999999999998}, {'accuracy': 0.11358000000000001}, {'accuracy': 0.11479000000000002}, {'accuracy': 0.10268000000000002}, {'accuracy': 0.12552000000000002}, {'accuracy': 0.13127}, {'accuracy': 0.13823000000000002}, {'accuracy': 0.10789000000000001}, {'accuracy': 0.14627}, {'accuracy': 0.15886000000000003}, {'accuracy': 0.14401000000000003}, {'accuracy': 0.14746}, {'accuracy': 0.13431}, {'accuracy': 0.19196999999999997}, {'accuracy': 0.19249}, {'accuracy': 0.15428000000000003}, {'accuracy': 0.20409000000000002}, {'accuracy': 0.14902}, {'accuracy': 0.13337000000000002}, {'accuracy': 0.15610000000000002}, {'accuracy': 0.19555}, {'accuracy': 0.19842}, {'accuracy': 0.12955}, {'accuracy': 0.20573000000000002}, {'accuracy': 0.13816}, {'accuracy': 0.14207}, {'accuracy': 0.15181000000000003}, {'accuracy': 0.15322}, {'accuracy': 0.14388}, {'accuracy': 0.19768000000000002}, {'accuracy': 0.187}, {'accuracy': 0.15585}, {'accuracy': 0.15533999999999998}, {'accuracy': 0.10982}, {'accuracy': 0.15934}, {'accuracy': 0.15062}, {'accuracy': 0.15745000000000003}, {'accuracy': 0.14348}, {'accuracy': 0.20227999999999996}, {'accuracy': 0.20891}, {'accuracy': 0.17811}, {'accuracy': 0.19282000000000002}, {'accuracy': 0.18258000000000002}, {'accuracy': 0.2593599999999999}, {'accuracy': 0.18014}, {'accuracy': 0.18812}, {'accuracy': 0.21576999999999996}, {'accuracy': 0.17029999999999998}, {'accuracy': 0.21580999999999997}, {'accuracy': 0.23320000000000002}, {'accuracy': 0.21705000000000002}, {'accuracy': 0.13628}, {'accuracy': 0.22237}, {'accuracy': 0.15426}, {'accuracy': 0.18055}, {'accuracy': 0.1633}, {'accuracy': 0.13126}, {'accuracy': 0.12115000000000001}, {'accuracy': 0.23133000000000004}, {'accuracy': 0.16728}, {'accuracy': 0.17935000000000004}, {'accuracy': 0.17542000000000002}, {'accuracy': 0.18206000000000003}, {'accuracy': 0.17479}, {'accuracy': 0.17694}, {'accuracy': 0.15471}, {'accuracy': 0.16943}, {'accuracy': 0.19109000000000004}, {'accuracy': 0.15113}, {'accuracy': 0.19593}, {'accuracy': 0.17228}, {'accuracy': 0.20871}, {'accuracy': 0.17812}, {'accuracy': 0.18731000000000003}, {'accuracy': 0.13059000000000004}, {'accuracy': 0.2004}, {'accuracy': 0.21533000000000002}, {'accuracy': 0.16673}, {'accuracy': 0.25107}, {'accuracy': 0.22109}, {'accuracy': 0.21698}, {'accuracy': 0.20700000000000002}, {'accuracy': 0.22041}, {'accuracy': 0.15205000000000002}, {'accuracy': 0.19971}, {'accuracy': 0.20195}, {'accuracy': 0.20608999999999997}, {'accuracy': 0.19274000000000002}, {'accuracy': 0.18577}, {'accuracy': 0.17359999999999998}, {'accuracy': 0.18031}, {'accuracy': 0.22748999999999997}, {'accuracy': 0.21765000000000004}, {'accuracy': 0.19777999999999998}, {'accuracy': 0.26896}, {'accuracy': 0.20725000000000002}, {'accuracy': 0.20773999999999998}, {'accuracy': 0.23757}, {'accuracy': 0.21042}, {'accuracy': 0.17378}, {'accuracy': 0.21322999999999998}, {'accuracy': 0.15032}, {'accuracy': 0.16260999999999998}, {'accuracy': 0.23239}, {'accuracy': 0.20644}, {'accuracy': 0.20955}, {'accuracy': 0.1576}, {'accuracy': 0.21283000000000002}, {'accuracy': 0.16215000000000002}, {'accuracy': 0.16796000000000003}, {'accuracy': 0.22077}, {'accuracy': 0.27674000000000004}, {'accuracy': 0.22519}, {'accuracy': 0.17554}, {'accuracy': 0.18693000000000004}, {'accuracy': 0.23049}, {'accuracy': 0.19773000000000002}, {'accuracy': 0.20224999999999999}, {'accuracy': 0.21413000000000001}, {'accuracy': 0.14664000000000002}, {'accuracy': 0.23403000000000002}, {'accuracy': 0.26514000000000004}, {'accuracy': 0.15126}, {'accuracy': 0.21869}, {'accuracy': 0.18525}, {'accuracy': 0.22774}, {'accuracy': 0.20833999999999997}, {'accuracy': 0.11525}, {'accuracy': 0.22619000000000003}, {'accuracy': 0.22835}, {'accuracy': 0.15200000000000002}, {'accuracy': 0.20539000000000002}, {'accuracy': 0.19444}, {'accuracy': 0.19065000000000001}, {'accuracy': 0.24799000000000002}, {'accuracy': 0.18683}, {'accuracy': 0.19927}, {'accuracy': 0.15602}, {'accuracy': 0.22445999999999997}, {'accuracy': 0.21715}, {'accuracy': 0.23104999999999998}, {'accuracy': 0.20414}, {'accuracy': 0.21722000000000002}, {'accuracy': 0.25556999999999996}, {'accuracy': 0.19702999999999998}, {'accuracy': 0.18494000000000005}, {'accuracy': 0.17368}, {'accuracy': 0.20112000000000002}, {'accuracy': 0.25288}, {'accuracy': 0.21641}, {'accuracy': 0.19307}, {'accuracy': 0.21159}, {'accuracy': 0.22979999999999995}, {'accuracy': 0.32100999999999996}, {'accuracy': 0.32883}, {'accuracy': 0.34673}, {'accuracy': 0.34936}, {'accuracy': 0.34762999999999994}, {'accuracy': 0.33527}, {'accuracy': 0.3557}, {'accuracy': 0.35715}, {'accuracy': 0.36232}, {'accuracy': 0.35385999999999995}, {'accuracy': 0.36784999999999995}, {'accuracy': 0.35775000000000007}, {'accuracy': 0.34711}, {'accuracy': 0.34744}, {'accuracy': 0.36123999999999995}, {'accuracy': 0.36565000000000003}, {'accuracy': 0.36332}, {'accuracy': 0.35534999999999994}, {'accuracy': 0.34675}, {'accuracy': 0.34353}, {'accuracy': 0.34097}, {'accuracy': 0.35844}, {'accuracy': 0.34324}, {'accuracy': 0.35695999999999994}, {'accuracy': 0.35085999999999995}, {'accuracy': 0.37034}, {'accuracy': 0.35048}, {'accuracy': 0.3471}, {'accuracy': 0.36632}, {'accuracy': 0.34333}, {'accuracy': 0.35984}, {'accuracy': 0.35749}, {'accuracy': 0.35021}, {'accuracy': 0.37892000000000003}, {'accuracy': 0.34696000000000005}, {'accuracy': 0.35191999999999996}, {'accuracy': 0.34046999999999994}, {'accuracy': 0.37660000000000005}, {'accuracy': 0.34859999999999997}, {'accuracy': 0.36050999999999994}, {'accuracy': 0.35167000000000004}, {'accuracy': 0.3761900000000001}, {'accuracy': 0.34991999999999995}, {'accuracy': 0.36005}, {'accuracy': 0.34901}, {'accuracy': 0.36100000000000004}, {'accuracy': 0.34291}, {'accuracy': 0.35627}, {'accuracy': 0.36241}, {'accuracy': 0.35863999999999996}, {'accuracy': 0.36024999999999996}, {'accuracy': 0.36071}, {'accuracy': 0.35946}, {'accuracy': 0.34695}, {'accuracy': 0.34558}, {'accuracy': 0.35016}, {'accuracy': 0.35379999999999995}, {'accuracy': 0.35151999999999994}, {'accuracy': 0.35258}, {'accuracy': 0.36907}, {'accuracy': 0.35189000000000004}, {'accuracy': 0.36909}, {'accuracy': 0.35178000000000004}, {'accuracy': 0.35358999999999996}, {'accuracy': 0.34829}, {'accuracy': 0.35638000000000003}, {'accuracy': 0.34872000000000003}, {'accuracy': 0.34757000000000005}, {'accuracy': 0.35399}, {'accuracy': 0.35409}, {'accuracy': 0.35473999999999994}, {'accuracy': 0.36421000000000003}, {'accuracy': 0.35861}, {'accuracy': 0.3605}, {'accuracy': 0.36050000000000004}, {'accuracy': 0.3618}, {'accuracy': 0.3536099999999999}, {'accuracy': 0.35507}, {'accuracy': 0.34402}, {'accuracy': 0.36541999999999997}, {'accuracy': 0.34558999999999995}, {'accuracy': 0.35311000000000003}, {'accuracy': 0.34275}, {'accuracy': 0.35478}, {'accuracy': 0.36624}, {'accuracy': 0.35036000000000006}, {'accuracy': 0.34789}, {'accuracy': 0.35405}, {'accuracy': 0.36002999999999996}, {'accuracy': 0.36972}, {'accuracy': 0.35312}, {'accuracy': 0.35413000000000006}, {'accuracy': 0.35694}, {'accuracy': 0.33842}, {'accuracy': 0.35314999999999996}, {'accuracy': 0.34343999999999997}, {'accuracy': 0.36066000000000004}, {'accuracy': 0.36473}, {'accuracy': 0.34754000000000007}]\n"
     ]
    }
   ],
   "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": "d6dfd418-18c3-475f-aaaf-11aad26a386e",
   "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.35</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.35\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAAC0LElEQVR4nOydd5wU5f3HP7P9eq9wcHAgiDSpoiiICLZErEiMIFFjiYmGqJGfChpjUCzBjjFRsUSxxxJBJWJBVKRIR9rRrve7vds+vz92n9lnZme23O3eHnvf9+t1L253Z2eemT1uPvf5NkEURREEQRAEQRC9CF28F0AQBEEQBNHdkAAiCIIgCKLXQQKIIAiCIIheBwkggiAIgiB6HSSACIIgCILodZAAIgiCIAii10ECiCAIgiCIXgcJIIIgCIIgeh0kgAiCIAiC6HWQACIIIu6sXbsWgiBg7dq10nNXX301SktL47amROLee++FIAjxXgZB9ChIABFEArBjxw78+te/Rp8+fWA2m1FcXIwrr7wSO3bsiPfSYs4zzzyDl156KabH2LlzJ+69916Ul5fH9Djdyd/+9je8//778V4GQcQNEkAEcZzz7rvvYsyYMVizZg3mz5+PZ555Btdccw2++OILjBkzBu+99168lxhTuksA3XfffSSACCKBMMR7AQRBdJ79+/fjqquuwsCBA/HVV18hLy9Peu2WW27B6aefjquuugpbt27FwIEDu21dVqsVKSkp3Xa84wG6JgTRsyAHiCCOYx5++GG0t7fjH//4h0z8AEBubi6ee+45WK1WLF26FADw9ttvQxAEfPnllwH7eu655yAIArZv3y49t3v3blx66aXIzs6GxWLBuHHj8MEHH8je99JLL0n7vOmmm5Cfn4++ffsCAA4dOoSbbroJQ4YMQVJSEnJycnDZZZdFzUkpLS3Fjh078OWXX0IQBAiCgKlTp0qvNzU14dZbb0VJSQnMZjMGDRqEhx56CB6PR7afN954A2PHjkVaWhrS09MxYsQIPP7449L5XXbZZQCAM888UzoOn6+k5Oqrr0Zqair279+P8847D2lpabjyyisBAB6PB8uWLcNJJ50Ei8WCgoICXH/99WhsbJTt48cff8TMmTORm5uLpKQkDBgwAL/5zW+k19XypgCgvLwcgiAEdcUEQYDVasWKFSuk87n66qsBAK2trbj1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/8bGxoDrNnr0aNma+vfvD71eL+UyMZ555pmw1qJ23dxud0BoMj8/H8XFxd0SfiOI7oQcIII4jhk8eDBWrFiBK6+8EiNGjMA111yDAQMGoLy8HP/6179QV1eH119/XSpxZhiNRlx88cV44403YLVa8cgjjwTs++mnn8bkyZMxYsQIXHfddRg4cCCqq6uxfv16HD16FD/99FPI9V1wwQV45ZVXkJGRgWHDhmH9+vX4/PPPkZOTE7VrMHbsWDz77LP461//ikGDBiE/Px/Tpk3D7bffjg8++AAXXHABrr76aowdOxZWqxXbtm3D22+/jfLycuTm5uLaa69FQ0MDpk2bhr59++LQoUN48sknMXr0aKnUffTo0dDr9XjooYfQ3NwMs9mMadOmIT8/P6K1TpkyBddffz2WLFmCLVu2YMaMGTAajdi7dy/eeustPP7447j00kuxYsUKPPPMM7joootQVlaG1tZWPP/880hPT8d5550HwBsCveyyy/Dkk09CEASUlZXho48+CsjNCnbdPv/8czz22GMoLi7GgAEDMGTIEPTt2xeXXnopRo0ahdTUVHz++efYsGGDzMUjiIQgvkVoBEFEg61bt4pz5swRi4qKRKPRKBYWFopz5swRt23bpvmezz77TAQgCoIgHjlyRHWb/fv3i3PnzhULCwtFo9Eo9unTR7zgggvEt99+W9qGlcGrlWw3NjaK8+fPF3Nzc8XU1FRx5syZ4u7du8X+/fvLSrC7UgZfVVUlnn/++WJaWpoIQFYS39raKi5cuFAcNGiQaDKZxNzcXPHUU08VH3nkEdHhcIiiKIpvv/22OGPGDDE/P180mUxiv379xOuvv16srKyUHef5558XBw4cKOr1+pAl8fPmzRNTUlI0X//HP/4hjh07VkxKShLT0tLEESNGiHfccYdYUVEhiqIobtq0SZwzZ47Yr18/0Ww2i/n5+eIFF1wg/vjjj7L91NbWipdccomYnJwsZmVliddff724ffv2sMrgd+/eLZ5xxhliUlKSCECcN2+eaLfbxdtvv10cNWqUmJaWJqakpIijRo0Sn3nmmWAfAUEclwiiqPBZCYIgCIIgEhzKASIIgiAIotdBAoggCIIgiF4HCSCCIAiCIHodJIAIgiAIguh1kAAiCIIgCKLXQQKIIAiCIIheBzVCVMHj8aCiogJpaWlRa4FPEARBEERs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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10836000000000001}, {'accuracy': 0.12447000000000001}, {'accuracy': 0.09058000000000001}, {'accuracy': 0.1315}, {'accuracy': 0.09422}, {'accuracy': 0.12356}, {'accuracy': 0.10661000000000001}, {'accuracy': 0.11813000000000003}, {'accuracy': 0.11438000000000001}, {'accuracy': 0.11284000000000001}, {'accuracy': 0.13099000000000002}, {'accuracy': 0.10106}, {'accuracy': 0.11907000000000001}, {'accuracy': 0.10872}, {'accuracy': 0.11994000000000002}, {'accuracy': 0.13529000000000002}, {'accuracy': 0.11045}, {'accuracy': 0.11034000000000002}, {'accuracy': 0.09898}, {'accuracy': 0.11623000000000001}, {'accuracy': 0.10655}, {'accuracy': 0.11466000000000001}, {'accuracy': 0.11887000000000003}, {'accuracy': 0.10711}, {'accuracy': 0.11983999999999999}, {'accuracy': 0.11257000000000002}, {'accuracy': 0.12936}, {'accuracy': 0.12266000000000002}, {'accuracy': 0.11061000000000001}, {'accuracy': 0.12535000000000002}, {'accuracy': 0.11027}, {'accuracy': 0.12355000000000001}, {'accuracy': 0.11326}, {'accuracy': 0.15275}, {'accuracy': 0.12580000000000002}, {'accuracy': 0.11545000000000001}, {'accuracy': 0.10024}, {'accuracy': 0.11782999999999999}, {'accuracy': 0.1511}, {'accuracy': 0.11907000000000001}, {'accuracy': 0.10002}, {'accuracy': 0.10782}, {'accuracy': 0.11867000000000001}, {'accuracy': 0.12880999999999998}, {'accuracy': 0.11685000000000001}, {'accuracy': 0.15300000000000002}, {'accuracy': 0.13541000000000003}, {'accuracy': 0.10015}, {'accuracy': 0.14701999999999998}, {'accuracy': 0.11358000000000001}, {'accuracy': 0.11479000000000002}, {'accuracy': 0.10268000000000002}, {'accuracy': 0.12552000000000002}, {'accuracy': 0.13127}, {'accuracy': 0.13823000000000002}, {'accuracy': 0.10789000000000001}, {'accuracy': 0.14627}, {'accuracy': 0.15886000000000003}, {'accuracy': 0.14401000000000003}, {'accuracy': 0.14746}, {'accuracy': 0.13431}, {'accuracy': 0.19196999999999997}, {'accuracy': 0.19249}, {'accuracy': 0.15428000000000003}, {'accuracy': 0.20409000000000002}, {'accuracy': 0.14902}, {'accuracy': 0.13337000000000002}, {'accuracy': 0.15610000000000002}, {'accuracy': 0.19555}, {'accuracy': 0.19842}, {'accuracy': 0.12955}, {'accuracy': 0.20573000000000002}, {'accuracy': 0.13816}, {'accuracy': 0.14207}, {'accuracy': 0.15181000000000003}, {'accuracy': 0.15322}, {'accuracy': 0.14388}, {'accuracy': 0.19768000000000002}, {'accuracy': 0.187}, {'accuracy': 0.15585}, {'accuracy': 0.15533999999999998}, {'accuracy': 0.10982}, {'accuracy': 0.15934}, {'accuracy': 0.15062}, {'accuracy': 0.15745000000000003}, {'accuracy': 0.14348}, {'accuracy': 0.20227999999999996}, {'accuracy': 0.20891}, {'accuracy': 0.17811}, {'accuracy': 0.19282000000000002}, {'accuracy': 0.18258000000000002}, {'accuracy': 0.2593599999999999}, {'accuracy': 0.18014}, {'accuracy': 0.18812}, {'accuracy': 0.21576999999999996}, {'accuracy': 0.17029999999999998}, {'accuracy': 0.21580999999999997}, {'accuracy': 0.23320000000000002}, {'accuracy': 0.21705000000000002}, {'accuracy': 0.13628}, {'accuracy': 0.22237}, {'accuracy': 0.15426}, {'accuracy': 0.18055}, {'accuracy': 0.1633}, {'accuracy': 0.13126}, {'accuracy': 0.12115000000000001}, {'accuracy': 0.23133000000000004}, {'accuracy': 0.16728}, {'accuracy': 0.17935000000000004}, {'accuracy': 0.17542000000000002}, {'accuracy': 0.18206000000000003}, {'accuracy': 0.17479}, {'accuracy': 0.17694}, {'accuracy': 0.15471}, {'accuracy': 0.16943}, {'accuracy': 0.19109000000000004}, {'accuracy': 0.15113}, {'accuracy': 0.19593}, {'accuracy': 0.17228}, {'accuracy': 0.20871}, {'accuracy': 0.17812}, {'accuracy': 0.18731000000000003}, {'accuracy': 0.13059000000000004}, {'accuracy': 0.2004}, {'accuracy': 0.21533000000000002}, {'accuracy': 0.16673}, {'accuracy': 0.25107}, {'accuracy': 0.22109}, {'accuracy': 0.21698}, {'accuracy': 0.20700000000000002}, {'accuracy': 0.22041}, {'accuracy': 0.15205000000000002}, {'accuracy': 0.19971}, {'accuracy': 0.20195}, {'accuracy': 0.20608999999999997}, {'accuracy': 0.19274000000000002}, {'accuracy': 0.18577}, {'accuracy': 0.17359999999999998}, {'accuracy': 0.18031}, {'accuracy': 0.22748999999999997}, {'accuracy': 0.21765000000000004}, {'accuracy': 0.19777999999999998}, {'accuracy': 0.26896}, {'accuracy': 0.20725000000000002}, {'accuracy': 0.20773999999999998}, {'accuracy': 0.23757}, {'accuracy': 0.21042}, {'accuracy': 0.17378}, {'accuracy': 0.21322999999999998}, {'accuracy': 0.15032}, {'accuracy': 0.16260999999999998}, {'accuracy': 0.23239}, {'accuracy': 0.20644}, {'accuracy': 0.20955}, {'accuracy': 0.1576}, {'accuracy': 0.21283000000000002}, {'accuracy': 0.16215000000000002}, {'accuracy': 0.16796000000000003}, {'accuracy': 0.22077}, {'accuracy': 0.27674000000000004}, {'accuracy': 0.22519}, {'accuracy': 0.17554}, {'accuracy': 0.18693000000000004}, {'accuracy': 0.23049}, {'accuracy': 0.19773000000000002}, {'accuracy': 0.20224999999999999}, {'accuracy': 0.21413000000000001}, {'accuracy': 0.14664000000000002}, {'accuracy': 0.23403000000000002}, {'accuracy': 0.26514000000000004}, {'accuracy': 0.15126}, {'accuracy': 0.21869}, {'accuracy': 0.18525}, {'accuracy': 0.22774}, {'accuracy': 0.20833999999999997}, {'accuracy': 0.11525}, {'accuracy': 0.22619000000000003}, {'accuracy': 0.22835}, {'accuracy': 0.15200000000000002}, {'accuracy': 0.20539000000000002}, {'accuracy': 0.19444}, {'accuracy': 0.19065000000000001}, {'accuracy': 0.24799000000000002}, {'accuracy': 0.18683}, {'accuracy': 0.19927}, {'accuracy': 0.15602}, {'accuracy': 0.22445999999999997}, {'accuracy': 0.21715}, {'accuracy': 0.23104999999999998}, {'accuracy': 0.20414}, {'accuracy': 0.21722000000000002}, {'accuracy': 0.25556999999999996}, {'accuracy': 0.19702999999999998}, {'accuracy': 0.18494000000000005}, {'accuracy': 0.17368}, {'accuracy': 0.20112000000000002}, {'accuracy': 0.25288}, {'accuracy': 0.21641}, {'accuracy': 0.19307}, {'accuracy': 0.21159}, {'accuracy': 0.22979999999999995}, {'accuracy': 0.32100999999999996}, {'accuracy': 0.32883}, {'accuracy': 0.34673}, {'accuracy': 0.34936}, {'accuracy': 0.34762999999999994}, {'accuracy': 0.33527}, {'accuracy': 0.3557}, {'accuracy': 0.35715}, {'accuracy': 0.36232}, {'accuracy': 0.35385999999999995}, {'accuracy': 0.36784999999999995}, {'accuracy': 0.35775000000000007}, {'accuracy': 0.34711}, {'accuracy': 0.34744}, {'accuracy': 0.36123999999999995}, {'accuracy': 0.36565000000000003}, {'accuracy': 0.36332}, {'accuracy': 0.35534999999999994}, {'accuracy': 0.34675}, {'accuracy': 0.34353}, {'accuracy': 0.34097}, {'accuracy': 0.35844}, {'accuracy': 0.34324}, {'accuracy': 0.35695999999999994}, {'accuracy': 0.35085999999999995}, {'accuracy': 0.37034}, {'accuracy': 0.35048}, {'accuracy': 0.3471}, {'accuracy': 0.36632}, {'accuracy': 0.34333}, {'accuracy': 0.35984}, {'accuracy': 0.35749}, {'accuracy': 0.35021}, {'accuracy': 0.37892000000000003}, {'accuracy': 0.34696000000000005}, {'accuracy': 0.35191999999999996}, {'accuracy': 0.34046999999999994}, {'accuracy': 0.37660000000000005}, {'accuracy': 0.34859999999999997}, {'accuracy': 0.36050999999999994}, {'accuracy': 0.35167000000000004}, {'accuracy': 0.3761900000000001}, {'accuracy': 0.34991999999999995}, {'accuracy': 0.36005}, {'accuracy': 0.34901}, {'accuracy': 0.36100000000000004}, {'accuracy': 0.34291}, {'accuracy': 0.35627}, {'accuracy': 0.36241}, {'accuracy': 0.35863999999999996}, {'accuracy': 0.36024999999999996}, {'accuracy': 0.36071}, {'accuracy': 0.35946}, {'accuracy': 0.34695}, {'accuracy': 0.34558}, {'accuracy': 0.35016}, {'accuracy': 0.35379999999999995}, {'accuracy': 0.35151999999999994}, {'accuracy': 0.35258}, {'accuracy': 0.36907}, {'accuracy': 0.35189000000000004}, {'accuracy': 0.36909}, {'accuracy': 0.35178000000000004}, {'accuracy': 0.35358999999999996}, {'accuracy': 0.34829}, {'accuracy': 0.35638000000000003}, {'accuracy': 0.34872000000000003}, {'accuracy': 0.34757000000000005}, {'accuracy': 0.35399}, {'accuracy': 0.35409}, {'accuracy': 0.35473999999999994}, {'accuracy': 0.36421000000000003}, {'accuracy': 0.35861}, {'accuracy': 0.3605}, {'accuracy': 0.36050000000000004}, {'accuracy': 0.3618}, {'accuracy': 0.3536099999999999}, {'accuracy': 0.35507}, {'accuracy': 0.34402}, {'accuracy': 0.36541999999999997}, {'accuracy': 0.34558999999999995}, {'accuracy': 0.35311000000000003}, {'accuracy': 0.34275}, {'accuracy': 0.35478}, {'accuracy': 0.36624}, {'accuracy': 0.35036000000000006}, {'accuracy': 0.34789}, {'accuracy': 0.35405}, {'accuracy': 0.36002999999999996}, {'accuracy': 0.36972}, {'accuracy': 0.35312}, {'accuracy': 0.35413000000000006}, {'accuracy': 0.35694}, {'accuracy': 0.33842}, {'accuracy': 0.35314999999999996}, {'accuracy': 0.34343999999999997}, {'accuracy': 0.36066000000000004}, {'accuracy': 0.36473}, {'accuracy': 0.34754000000000007}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "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": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a1e2c586-04af-4b7e-a788-fe249ae77fe1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "741f6832-6cce-4bb8-8aca-024c5365f8f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f977aa5a-3f11-4d35-88c5-88a68737e1d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29e0d41b-0bfb-4596-b4e9-da3eb9392bf3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eac99099-a9b0-40fb-9fd7-c4d4eabc646d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be501306-5235-41ea-8d6c-38aad8fab87f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8fb5de7c-fdf8-401a-8073-a4ec34037599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "964180e7-b88d-431d-a041-9eac49c0979e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d72cd460-ca84-4449-a41e-2528aa10edeb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca6fa11a-af35-48bf-8c34-3310bf9cd6d1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9dd41f82-7fd1-4a97-9d2f-a9af8c69048e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9153ea-c43a-4739-ba50-8d37b08034af",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "839d5e76-f5c0-484f-a0ac-fd6f44fe12a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02a0f958-623c-4db7-b149-8baef20068bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e13e5581-45f2-4f4c-a1ad-f633d687f78d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f412ca2-05f5-4d6f-a969-1cb50c3907a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b65a7aa0-0724-429a-aab3-1ae513b8a04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c62ede7-0aac-467a-b30c-bea25c4a1035",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2464991d-f622-4b94-8ba3-77e1d54fa594",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9767ee5-e1e2-4906-bc6b-797c60884374",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61a7ab54-5e70-4a12-9022-e3803e553032",
   "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
}
