{
 "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",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2324]\n",
      " [   1   66]\n",
      " [   2   31]\n",
      " [   3   60]\n",
      " [   4  118]\n",
      " [   5  159]\n",
      " [   6  302]\n",
      " [   7  570]\n",
      " [   8  836]\n",
      " [   9 1420]]\n",
      "[[   0 1429]\n",
      " [   1 2730]\n",
      " [   2   57]\n",
      " [   3   38]\n",
      " [   4   62]\n",
      " [   5   99]\n",
      " [   6  185]\n",
      " [   7  326]\n",
      " [   8  511]\n",
      " [   9  865]]\n",
      "[[   0  899]\n",
      " [   1 1583]\n",
      " [   2 2366]\n",
      " [   3   60]\n",
      " [   4   32]\n",
      " [   5   72]\n",
      " [   6  119]\n",
      " [   7  187]\n",
      " [   8  283]\n",
      " [   9  528]]\n",
      "[[   0  515]\n",
      " [   1  993]\n",
      " [   2 1396]\n",
      " [   3 2475]\n",
      " [   4   58]\n",
      " [   5   42]\n",
      " [   6   69]\n",
      " [   7  104]\n",
      " [   8  183]\n",
      " [   9  329]]\n",
      "[[   0  281]\n",
      " [   1  609]\n",
      " [   2  871]\n",
      " [   3 1528]\n",
      " [   4 2210]\n",
      " [   5   63]\n",
      " [   6   38]\n",
      " [   7   55]\n",
      " [   8  104]\n",
      " [   9  181]]\n",
      "[[   0  182]\n",
      " [   1  335]\n",
      " [   2  540]\n",
      " [   3  835]\n",
      " [   4 1450]\n",
      " [   5 2202]\n",
      " [   6   59]\n",
      " [   7   37]\n",
      " [   8   66]\n",
      " [   9  117]]\n",
      "[[   0  123]\n",
      " [   1  212]\n",
      " [   2  327]\n",
      " [   3  528]\n",
      " [   4  848]\n",
      " [   5 1299]\n",
      " [   6 2358]\n",
      " [   7   64]\n",
      " [   8   45]\n",
      " [   9   60]]\n",
      "[[   0   60]\n",
      " [   1  124]\n",
      " [   2  192]\n",
      " [   3  299]\n",
      " [   4  552]\n",
      " [   5  774]\n",
      " [   6 1405]\n",
      " [   7 2523]\n",
      " [   8   62]\n",
      " [   9   51]]\n",
      "[[   0   49]\n",
      " [   1   55]\n",
      " [   2  124]\n",
      " [   3  196]\n",
      " [   4  309]\n",
      " [   5  439]\n",
      " [   6  863]\n",
      " [   7 1495]\n",
      " [   8 2407]\n",
      " [   9   50]]\n",
      "[[   0   61]\n",
      " [   1   35]\n",
      " [   2   54]\n",
      " [   3  112]\n",
      " [   4  203]\n",
      " [   5  272]\n",
      " [   6  520]\n",
      " [   7  904]\n",
      " [   8 1354]\n",
      " [   9 2348]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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-20:52:07 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:52:07\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "74896c168b8245bd93c79f10a6054556",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:34:31 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3352</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:34:31\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3352\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\">73207680</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;36m73207680\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.96</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.96\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABu3ElEQVR4nO3dd3iT5foH8G+SZnbvXVpaNqUsQQREAcGFgguRI4jiQZHjwAH8VNDjURSVAx6cHAU9DlAUFwoiS4Gyqezd0lK6Zzoymry/P5K8TZq2tJA0Hd/PdfUyeUfy5G3wvXs/9/M8EkEQBBARERG1E1JPN4CIiIjIlRjcEBERUbvC4IaIiIjaFQY3RERE1K4wuCEiIqJ2hcENERERtSsMboiIiKhdYXBDRERE7QqDGyIiImpXGNwQkVtt3boVEokEW7duFbc98MADiI+P91ib2pOXXnoJEonE080galUY3BC1ckePHsXf/vY3REdHQ6lUIioqCpMnT8bRo0c93TS3e++997By5Uq3vsexY8fw0ksvISMjw63v05Jee+01fP/9955uBpHHMLghasW+++479O/fH5s2bcK0adPw3nvv4aGHHsKWLVvQv39/rF271tNNdKuWCm5efvllBjdE7YiXpxtARPU7e/Ys7r//fnTu3Bl//PEHQkNDxX1PPPEEhg8fjvvvvx+HDh1C586dW6xdlZWV8Pb2brH3awt4TYhaF2ZuiFqpN998E1VVVfjoo48cAhsACAkJwYcffojKykosWrQIALBmzRpIJBJs27bN6bU+/PBDSCQSHDlyRNx24sQJ3HXXXQgKCoJKpcLAgQPx448/Opy3cuVK8TVnzpyJsLAwxMTEAADOnz+PmTNnolu3blCr1QgODsbdd9/tsgxIfHw8jh49im3btkEikUAikeC6664T95eWluLJJ59EbGwslEolkpKS8MYbb8BsNju8zqpVqzBgwAD4+vrCz88PycnJWLp0qfj57r77bgDA9ddfL76PfX1QXQ888AB8fHxw9uxZ3HzzzfD19cXkyZMBAGazGUuWLEGvXr2gUqkQHh6OGTNmoKSkxOE19u3bh7FjxyIkJARqtRoJCQl48MEHxf311SkBQEZGBiQSSaPZLIlEgsrKSnz66afi53nggQcAAFqtFk8++STi4+OhVCoRFhaGG264AQcOHGjw9YjaImZuiFqp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UExERETtGzM3RERE1K4wuCEiIqJ2hcENERERtSsMboiIiKhdYXDjAu+++y7i4+OhUqkwePBg7Nmzx9NN8riXXnoJEonE4ad79+7ifp1Oh8ceewzBwcHw8fHBnXfeiby8PA+2uOX88ccfGDduHKKioiCRSPD999877BcEAfPnz0dkZCTUajVGjx6N06dPOxxTXFyMyZMnw8/PDwEBAXjooYdQUVHRgp+i5Vzqej3wwANO37Ubb7zR4ZiOcr0WLlyIq666Cr6+vggLC8P48eNx8uRJh2Oa8m8vMzMTt9xyCzQaDcLCwvDss8+ipqamJT+K2zXlWl133XVO361HHnnE4ZiOcK0A4P3330efPn3EifmGDBmCX3/9Vdzf2r5XDG6u0OrVqzF79mwsWLAABw4cQEpKCsaOHYv8/HxPN83jevXqhZycHPFn+/bt4r6nnnoKP/30E7755hts27YNFy9exB133OHB1racyspKpKSk4N133613/6JFi/DOO+/ggw8+wO7du+Ht7Y2xY8dCp9OJx0yePBlHjx7Fxo0b8fPPP+OPP/7A3//+95b6CC3qUtcLAG688UaH79pXX33lsL+jXK9t27bhsccew65du7Bx40YYjUaMGTMGlZWV4jGX+rdnMplwyy23wGAwYOfOnfj000+xcuVKzJ8/3xMfyW2acq0A4OGHH3b4bi1atEjc11GuFQDExMTg9ddfx/79+7Fv3z6MHDkSt99+O44ePQqgFX6vBLoigwYNEh577DHxuclkEqKiooSFCxd6sFWet2DBAiElJaXefaWlpYJcLhe++eYbcdvx48cFAEJqamoLtbB1ACCsXbtWfG42m4WIiAjhzTffFLeVlpYKSqVS+OqrrwRBEIRjx44JAIS9e/eKx/z666+CRCIRsrOzW6ztnlD3egmCIEydOlW4/fbbGzynI1+v/Px8AYCwbds2QRCa9m/vl19+EaRSqZCbmyse8/777wt+fn6CXq9v2Q/QgupeK0EQhBEjRghPPPFEg+d01GtlExgYKPz3v/9tld8rZm6ugMFgwP79+zF69Ghxm1QqxejRo5GamurBlrUOp0+fRlRUFDp37ozJkycjMzMTALB//34YjUaH69a9e3fExcV1+OuWnp6O3Nxch2vj7++PwYMHi9cmNTUVAQEBGDhwoHjM6NGjIZVKsXv37hZvc2uwdetWhIWF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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10215}, {'accuracy': 0.16085}, {'accuracy': 0.15391000000000002}, {'accuracy': 0.11789000000000001}, {'accuracy': 0.21549999999999997}, {'accuracy': 0.22010000000000002}, {'accuracy': 0.23586000000000001}, {'accuracy': 0.21781999999999999}, {'accuracy': 0.33316}, {'accuracy': 0.32323}, {'accuracy': 0.35348999999999997}, {'accuracy': 0.38831}, {'accuracy': 0.36888}, {'accuracy': 0.37506}, {'accuracy': 0.38194}, {'accuracy': 0.43871000000000004}, {'accuracy': 0.44132999999999994}, {'accuracy': 0.42832}, {'accuracy': 0.5237399999999999}, {'accuracy': 0.5145899999999999}, {'accuracy': 0.5064}, {'accuracy': 0.5326299999999999}, {'accuracy': 0.6167999999999999}, {'accuracy': 0.5221600000000001}, {'accuracy': 0.58294}, {'accuracy': 0.60987}, {'accuracy': 0.6424300000000001}, {'accuracy': 0.65873}, {'accuracy': 0.62912}, {'accuracy': 0.6354}, {'accuracy': 0.5853299999999999}, {'accuracy': 0.6657499999999998}, {'accuracy': 0.6945499999999999}, {'accuracy': 0.73461}, {'accuracy': 0.60561}, {'accuracy': 0.7114999999999999}, {'accuracy': 0.6496599999999999}, {'accuracy': 0.7566400000000001}, {'accuracy': 0.6955600000000001}, {'accuracy': 0.7375}, {'accuracy': 0.7320099999999999}, {'accuracy': 0.7217899999999999}, {'accuracy': 0.7661}, {'accuracy': 0.74858}, {'accuracy': 0.69827}, {'accuracy': 0.8406}, {'accuracy': 0.6957699999999999}, {'accuracy': 0.8241799999999999}, {'accuracy': 0.7995300000000001}, {'accuracy': 0.80356}, {'accuracy': 0.75623}, {'accuracy': 0.76462}, {'accuracy': 0.7877000000000001}, {'accuracy': 0.7802100000000001}, {'accuracy': 0.8315100000000001}, {'accuracy': 0.8192999999999999}, {'accuracy': 0.8272999999999999}, {'accuracy': 0.7719900000000001}, {'accuracy': 0.7950999999999999}, {'accuracy': 0.81371}, {'accuracy': 0.80449}, {'accuracy': 0.80107}, {'accuracy': 0.8222799999999999}, {'accuracy': 0.82506}, {'accuracy': 0.8033999999999999}, {'accuracy': 0.78546}, {'accuracy': 0.85372}, {'accuracy': 0.81739}, {'accuracy': 0.84629}, {'accuracy': 0.8474299999999999}, {'accuracy': 0.8344099999999999}, {'accuracy': 0.8058099999999999}, {'accuracy': 0.8574499999999998}, {'accuracy': 0.84758}, {'accuracy': 0.86058}, {'accuracy': 0.8531000000000001}, {'accuracy': 0.8920599999999999}, {'accuracy': 0.8802900000000001}, {'accuracy': 0.8556999999999999}, {'accuracy': 0.8541000000000001}, {'accuracy': 0.83256}, {'accuracy': 0.87952}, {'accuracy': 0.8555699999999999}, {'accuracy': 0.8442000000000001}, {'accuracy': 0.8672599999999999}, {'accuracy': 0.87011}, {'accuracy': 0.86309}, {'accuracy': 0.8637900000000001}, {'accuracy': 0.8815}, {'accuracy': 0.8655900000000001}, {'accuracy': 0.8491200000000001}, {'accuracy': 0.88186}, {'accuracy': 0.8472799999999999}, {'accuracy': 0.8740500000000001}, {'accuracy': 0.8775000000000001}, {'accuracy': 0.83581}, {'accuracy': 0.88364}, {'accuracy': 0.8783900000000001}, {'accuracy': 0.89985}, {'accuracy': 0.8686}, {'accuracy': 0.8616400000000001}, {'accuracy': 0.8694799999999999}, {'accuracy': 0.8963599999999999}, {'accuracy': 0.8844200000000001}, {'accuracy': 0.8797699999999999}, {'accuracy': 0.8989100000000001}, {'accuracy': 0.85943}, {'accuracy': 0.87203}, {'accuracy': 0.8869}, {'accuracy': 0.9055199999999999}, {'accuracy': 0.9055499999999999}, {'accuracy': 0.87903}, {'accuracy': 0.8844}, {'accuracy': 0.8924400000000002}, {'accuracy': 0.84925}, {'accuracy': 0.88649}, {'accuracy': 0.90589}, {'accuracy': 0.87571}, {'accuracy': 0.88314}, {'accuracy': 0.8896099999999999}, {'accuracy': 0.8827400000000001}, {'accuracy': 0.86265}, {'accuracy': 0.8959399999999998}, {'accuracy': 0.8848}, {'accuracy': 0.9000999999999999}, {'accuracy': 0.8959999999999999}, {'accuracy': 0.8812200000000001}, {'accuracy': 0.90534}, {'accuracy': 0.9014400000000002}, {'accuracy': 0.8683500000000001}, {'accuracy': 0.89365}, {'accuracy': 0.9075000000000001}, {'accuracy': 0.91931}, {'accuracy': 0.86059}, {'accuracy': 0.8649299999999999}, {'accuracy': 0.9033}, {'accuracy': 0.89965}, {'accuracy': 0.8902100000000001}, {'accuracy': 0.8882899999999999}, {'accuracy': 0.9001399999999998}, {'accuracy': 0.8882099999999999}, {'accuracy': 0.9251699999999999}, {'accuracy': 0.89089}, {'accuracy': 0.89757}, {'accuracy': 0.9053799999999999}, {'accuracy': 0.89025}, {'accuracy': 0.9176500000000001}, {'accuracy': 0.90004}, {'accuracy': 0.89117}, {'accuracy': 0.88885}, {'accuracy': 0.8785000000000001}, {'accuracy': 0.91349}, {'accuracy': 0.91144}, {'accuracy': 0.8995000000000001}, {'accuracy': 0.9314199999999999}, {'accuracy': 0.9340499999999998}, {'accuracy': 0.9561300000000001}, {'accuracy': 0.9564200000000002}, {'accuracy': 0.95595}, {'accuracy': 0.95759}, {'accuracy': 0.9528500000000001}, {'accuracy': 0.95418}, {'accuracy': 0.95443}, {'accuracy': 0.9525600000000001}, {'accuracy': 0.9575500000000001}, {'accuracy': 0.9534900000000001}, {'accuracy': 0.96067}, {'accuracy': 0.9563}, {'accuracy': 0.9549300000000001}, {'accuracy': 0.95426}, {'accuracy': 0.9535900000000002}, {'accuracy': 0.95854}, {'accuracy': 0.95407}, {'accuracy': 0.9569300000000001}, {'accuracy': 0.95222}, {'accuracy': 0.95322}, {'accuracy': 0.9580500000000001}, {'accuracy': 0.9570400000000001}, {'accuracy': 0.95747}, {'accuracy': 0.9575000000000001}, {'accuracy': 0.95899}, {'accuracy': 0.9576}, {'accuracy': 0.9576600000000001}, {'accuracy': 0.9531999999999998}, {'accuracy': 0.95608}, {'accuracy': 0.95701}, {'accuracy': 0.95623}, {'accuracy': 0.9574999999999999}, {'accuracy': 0.9556600000000002}, {'accuracy': 0.9586400000000002}, {'accuracy': 0.9565800000000001}, {'accuracy': 0.9558900000000001}, {'accuracy': 0.9578900000000001}, {'accuracy': 0.9572299999999998}, {'accuracy': 0.9585600000000001}, {'accuracy': 0.9572800000000001}, {'accuracy': 0.9566799999999999}, {'accuracy': 0.9576499999999999}, {'accuracy': 0.9592600000000001}, {'accuracy': 0.9563599999999999}, {'accuracy': 0.9587400000000003}, {'accuracy': 0.95882}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.9565199999999999}, {'accuracy': 0.95755}, {'accuracy': 0.9589099999999998}, {'accuracy': 0.9553699999999999}, {'accuracy': 0.9580299999999999}, {'accuracy': 0.96006}, {'accuracy': 0.9561499999999998}, {'accuracy': 0.9610700000000001}, {'accuracy': 0.9599200000000001}, {'accuracy': 0.95922}, {'accuracy': 0.9598599999999999}, {'accuracy': 0.9611200000000002}, {'accuracy': 0.9599400000000001}, {'accuracy': 0.9604100000000002}, {'accuracy': 0.95738}, {'accuracy': 0.9543299999999999}, {'accuracy': 0.9568199999999999}, {'accuracy': 0.9590799999999999}, {'accuracy': 0.9597000000000001}, {'accuracy': 0.9585199999999998}, {'accuracy': 0.9609400000000001}, {'accuracy': 0.95594}, {'accuracy': 0.9600199999999999}, {'accuracy': 0.9592500000000002}, {'accuracy': 0.95989}, {'accuracy': 0.95748}, {'accuracy': 0.95695}, {'accuracy': 0.95862}, {'accuracy': 0.95787}, {'accuracy': 0.96083}, {'accuracy': 0.95963}, {'accuracy': 0.95916}, {'accuracy': 0.9580400000000001}, {'accuracy': 0.9592699999999998}, {'accuracy': 0.9568099999999999}, {'accuracy': 0.96043}, {'accuracy': 0.95807}, {'accuracy': 0.9547800000000001}, {'accuracy': 0.9580300000000002}, {'accuracy': 0.95387}, {'accuracy': 0.95702}, {'accuracy': 0.95595}, {'accuracy': 0.95679}, {'accuracy': 0.959}, {'accuracy': 0.95695}, {'accuracy': 0.9577}, {'accuracy': 0.96174}, {'accuracy': 0.9587899999999999}, {'accuracy': 0.9609}, {'accuracy': 0.9598699999999999}, {'accuracy': 0.9592899999999999}, {'accuracy': 0.9597000000000001}, {'accuracy': 0.95893}, {'accuracy': 0.9582600000000001}, {'accuracy': 0.96097}, {'accuracy': 0.9579000000000001}, {'accuracy': 0.9583300000000001}, {'accuracy': 0.9604100000000001}, {'accuracy': 0.95799}, {'accuracy': 0.96086}, {'accuracy': 0.9559899999999999}, {'accuracy': 0.96273}, {'accuracy': 0.9602299999999999}, {'accuracy': 0.9574599999999999}, {'accuracy': 0.9541999999999998}, {'accuracy': 0.9602699999999998}, {'accuracy': 0.95956}, {'accuracy': 0.95723}, {'accuracy': 0.9597}, {'accuracy': 0.9606600000000001}, {'accuracy': 0.96151}, {'accuracy': 0.96103}, {'accuracy': 0.95977}, {'accuracy': 0.96065}, {'accuracy': 0.9615600000000001}, {'accuracy': 0.9594000000000001}, {'accuracy': 0.9591800000000001}, {'accuracy': 0.9620299999999998}, {'accuracy': 0.95921}, {'accuracy': 0.96181}, {'accuracy': 0.9597500000000002}, {'accuracy': 0.96279}, {'accuracy': 0.95791}, {'accuracy': 0.9617700000000001}, {'accuracy': 0.96086}, {'accuracy': 0.96283}, {'accuracy': 0.95781}, {'accuracy': 0.95959}, {'accuracy': 0.95893}, {'accuracy': 0.9593900000000002}, {'accuracy': 0.9592700000000001}, {'accuracy': 0.95799}, {'accuracy': 0.96114}, {'accuracy': 0.9595499999999999}, {'accuracy': 0.9634800000000002}, {'accuracy': 0.9595500000000001}, {'accuracy': 0.9585899999999998}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed07a60a-bb9a-4bfa-83ff-95d0ed2db218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee4f476f-5cc0-4d7c-b998-bc8eaee1f2f4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c973e241-0ccd-4c5a-9732-47a9adc08ad8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e97a47db-29dc-42a7-a7bc-db85be35ed57",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "245c14ac-4eb4-4042-a9f6-e2c699692136",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38ce2e88-a06f-4df2-bb35-98ee2b8f9d1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "836a6742-60de-474f-8ce8-fde870de55c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1de0bae8-37f2-46ef-a987-8755e34645b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee8e3a5e-d815-4d36-b1d3-be7be5087e09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81fccf71-dba3-42eb-bb63-1bdc50ed112c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0f8ddf3-1460-4486-b4d5-c5846a1c46e2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d997522-efe5-4a22-bd69-36cd1cfc6eaf",
   "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
}
