{
 "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": [
      "torch.Size([60000])\n",
      "6090\n",
      "[[  0 611]\n",
      " [  1 611]\n",
      " [  2 587]\n",
      " [  3 575]\n",
      " [  4 610]\n",
      " [  5 620]\n",
      " [  6 601]\n",
      " [  7 608]\n",
      " [  8 625]\n",
      " [  9 626]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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",
    "print(tag1.shape)\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",
    "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 ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\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([2, 9, 3,  ..., 8, 6, 7])"
      ]
     },
     "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": [
      "18044\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 390]\n",
      " [  1 420]\n",
      " [  2 459]\n",
      " [  3 453]\n",
      " [  4 401]\n",
      " [  5 446]\n",
      " [  6 427]\n",
      " [  7 397]\n",
      " [  8 388]\n",
      " [  9 415]]\n",
      "[[   0 1048]\n",
      " [   1  446]\n",
      " [   2  469]\n",
      " [   3  475]\n",
      " [   4  442]\n",
      " [   5  507]\n",
      " [   6  510]\n",
      " [   7  536]\n",
      " [   8  649]\n",
      " [   9  827]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 3, 9,  ..., 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<3:\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": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.70</span>                                                                <a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/utils.py#181\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">181</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.70\u001b[0m                                                                \u001b]8;id=67776;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/utils.py\u001b\\\u001b[2mutils.py\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=356439;file:///home/gzh0040/fsdownload/gossip_GPU/FAMNIST30c%/../gossipy_original/utils.py#181\u001b\\\u001b[2m181\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAC3LElEQVR4nOydd5wU5f3HP9uvN467oxwdC9IUAqKiBBBssSsSI4glRiVRiSYSo0STiCXW2I01iYL6s2uwIFix0ASV3tsdd8f1sm3m98fuM/M8z8xsudu9svd9v168uN2dnXmm7Dyf+VabqqoqCIIgCIIgUgR7Rw+AIAiCIAgikZC4IQiCIAgipSBxQxAEQRBESkHihiAIgiCIlILEDUEQBEEQKQWJG4IgCIIgUgoSNwRBEARBpBQkbgiCIAiCSClI3BAEQRAEkVKQuCEIIqksX74cNpsNy5cv19679NJLMWDAgA4bUyrxl7/8BTabraOHQRCdChI3BNHJ+fHHH/GrX/0Kffr0gcfjQe/evXHxxRfjxx9/7OihJZ3HHnsMzz//fFK38dNPP+Evf/kLdu7cmdTttCd33nkn3nzzzY4eBkF0GCRuCKIT8/rrr+OYY47B0qVLMWfOHDz22GO4/PLLsWzZMhxzzDF44403OnqISaW9xM3tt99O4oYgUghnRw+AIAhztm3bhksuuQSDBg3CZ599hp49e2qfXXfddZg4cSIuueQSrFu3DoMGDWq3cTU2NiIzM7PdttcVoGNCEJ0LstwQRCfl3nvvRVNTE5566ilB2ABAYWEhnnzySTQ2NuKee+4BALz22muw2Wz49NNPDet68sknYbPZ8MMPP2jvbdy4Eeeffz4KCgqQlpaGsWPH4u233xa+9/zzz2vrvOaaa1BUVIS+ffsCAHbt2oVrrrkGhx9+ONLT09GjRw9ccMEFCbOADBgwAD/++CM+/fRT2Gw22Gw2TJo0Sfu8pqYG119/PUpLS+HxeDBkyBDcfffdUBRFWM+iRYswZswYZGdnIycnByNGjMBDDz2k7d8FF1wAAPj5z3+ubYePD5K59NJLkZWVhW3btuG0005DdnY2Lr74YgCAoih48MEHcdRRRyEtLQ3FxcW46qqrUF1dLaxj5cqVmD59OgoLC5Geno6BAwfisssu0z43i1MCgJ07d8Jms0W0ZtlsNjQ2NuKFF17Q9ufSSy8FANTX1+P666/HgAED4PF4UFRUhJNPPhmrV6+2XB9BdEXIckMQnZR33nkHAwYMwMSJE00/P/HEEzFgwAC89957AIDTTz8dWVlZeOWVV3DSSScJyy5evBhHHXUUhg8fDiAUx3P88cejT58+uPnmm5GZmYlXXnkFZ599Nv7v//4P55xzjvD9a665Bj179sRtt92GxsZGAMB3332Hr776ChdddBH69u2LnTt34vHHH8ekSZPw008/ISMjo037/+CDD+K3v/0tsrKycMsttwAAiouLAQBNTU046aSTsG/fPlx11VXo168fvvrqK8yfPx8HDhzAgw8+CAD46KOPMHPmTEyZMgV33303AGDDhg348ssvcd111+HEE0/E7373Ozz88MP405/+hCOPPBIAtP+tCAQCmD59Ok444QT84x//0Pb1qquuwvPPP485c+bgd7/7HXbs2IFHHnkEa9aswZdffgmXy4WDBw9i2rRp6NmzJ26++Wbk5eVh586deP3119t0vBj//ve/ccUVV2DcuHH49a9/DQAYPHgwAOA3v/kNXnvtNcydOxfDhg1DVVUVvvjiC2zYsAHHHHNMQrZPEJ0ClSCITkdNTY0KQD3rrLMiLnfmmWeqANS6ujpVVVV15syZalFRkRoIBLRlDhw4oNrtdvWOO+7Q3psyZYo6YsQItaWlRXtPURT1uOOOU4cOHaq999xzz6kA1BNOOEFYp6qqalNTk2E8K1asUAGoL774ovbesmXLVADqsmXLtPdmz56t9u/fP+K+qaqqHnXUUepJJ51keP+vf/2rmpmZqW7evFl4/+abb1YdDoe6e/duVVVV9brrrlNzcnIMY+d59dVXDeOLxOzZs1UA6s033yy8//nnn6sA1P/+97/C+0uWLBHef+ONN1QA6nfffWe5DbNjpqqqumPHDhWA+txzz2nvLViwQJVv5ZmZmers2bMN683NzVWvvfbaGPaSILo25JYiiE5IfX09ACA7Ozvicuzzuro6AMCMGTNw8OBBwZ3x2muvQVEUzJgxAwBw6NAhfPLJJ7jwwgtRX1+PyspKVFZWoqqqCtOnT8eWLVuwb98+YTtXXnklHA6H8F56err2t9/vR1VVFYYMGYK8vLykuzleffVVTJw4Efn5+dr4KysrMXXqVASDQXz22WcAgLy8PDQ2NuKjjz5K+Biuvvpqw5hyc3Nx8sknC2MaM2YMsrKysGzZMm1MAPDuu+/C7/cnfFyRyMvLwzfffIP9+/e363YJor0hcUMQnRAmWpjIsUIWQaeccgpyc3OxePFibZnFixdj9OjROOywwwAAW7duhaqquPXWW9GzZ0/h34IFCwAABw8eFLYzcOBAw7abm5tx2223aTEvhYWF6NmzJ2pqalBbW9vKPY+NLVu2YMmSJYbxT506VRj/Nddcg8MOOwynnnoq+vbti8suuwxLlixp8/adTqcWe8SPqba2FkVFRYZxNTQ0aGM66aSTcN555+H2229HYWEhzjrrLDz33HPwer1tHlc07rnnHvzwww8oLS3FuHHj8Je//AXbt29P+nYJor2hmBuC6ITk5uaiV69eWLduXcTl1q1bhz59+iAnJwcA4PF4cPbZZ+ONN97AY489hvLycnz55Ze48847te+wgNsbb7wR06dPN13vkCFDhNe8lYbx29/+Fs899xyuv/56TJgwAbm5ubDZbLjooosMQb2JRlEUnHzyyfjDH/5g+jkTckVFRVi7di0++OAD/O9//8P//vc/PPfcc5g1axZeeOGFVm/f4/HAbhefDRVFQVFREf773/+afocFhdtsNrz22mv4+uuv8c477+CDDz7AZZddhvvuuw9ff/01srKyLIvyBYPBVo8ZAC688EJMnDgRb7zxBj788EPce++9uPvuu/H666/j1FNPbdO6CaIzQeKGIDopZ5xxBp5++ml88cUXOOGEEwyff/7559i5cyeuuuoq4f0ZM2bghRdewNKlS7Fhwwaoqqq5pABoaeMul0uzdLSG1157DbNnz8Z9992nvdfS0oKamppWr1PGapIfPHgwGhoaYhq/2+3GL37xC/ziF7+Aoii45ppr8OSTT+LWW2/FkCFDElbdd/Dgwfj4449x/PHHm4pBmWOPPRbHHnss/v73v+Oll17CxRdfjEWLFuGKK65Afn4+ABiO5a5du2IaS6R96tWrF6655hpcc801OHjwII455hj8/e9/J3FDpBTkliKITspNN92E9PR0XHXVVaiqqhI+O3ToEH7zm98gIyMDN910k/DZ1KlTUVBQgMWLF2Px4sUYN26c4FYqKirCpEmT8OSTT+LAgQOG7VZUVMQ0PofDAVVVhff++c9/ttm6wJOZmWkqli688EKsWLECH3zwgeGzmpoaBAIBADAcN7vdjpEjRwKA5gZi9Wna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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.20509}, {'accuracy': 0.20137}, {'accuracy': 0.25368}, {'accuracy': 0.42593000000000003}, {'accuracy': 0.16443000000000002}, {'accuracy': 0.27046}, {'accuracy': 0.27975999999999995}, {'accuracy': 0.39046000000000003}, {'accuracy': 0.34441}, {'accuracy': 0.26996000000000003}, {'accuracy': 0.25071}, {'accuracy': 0.19490000000000002}, {'accuracy': 0.29281}, {'accuracy': 0.36531}, {'accuracy': 0.41312999999999994}, {'accuracy': 0.42192999999999997}, {'accuracy': 0.31217}, {'accuracy': 0.44017000000000006}, {'accuracy': 0.44493}, {'accuracy': 0.33525}, {'accuracy': 0.25422}, {'accuracy': 0.28593999999999997}, {'accuracy': 0.31938}, {'accuracy': 0.39465999999999996}, {'accuracy': 0.33366999999999997}, {'accuracy': 0.28925000000000006}, {'accuracy': 0.36021000000000003}, {'accuracy': 0.4463800000000001}, {'accuracy': 0.39363000000000004}, {'accuracy': 0.36296}, {'accuracy': 0.37117999999999995}, {'accuracy': 0.39597}, {'accuracy': 0.30853}, {'accuracy': 0.26511000000000007}, {'accuracy': 0.38817}, {'accuracy': 0.23402000000000003}, {'accuracy': 0.24472000000000005}, {'accuracy': 0.33916999999999997}, {'accuracy': 0.39994}, {'accuracy': 0.27776999999999996}, {'accuracy': 0.34204}, {'accuracy': 0.21498}, {'accuracy': 0.35686999999999997}, {'accuracy': 0.4431}, {'accuracy': 0.33235000000000003}, {'accuracy': 0.28642}, {'accuracy': 0.26561}, {'accuracy': 0.38956}, {'accuracy': 0.42004}, {'accuracy': 0.43642000000000003}, {'accuracy': 0.43100999999999995}, {'accuracy': 0.34128000000000003}, {'accuracy': 0.34055}, {'accuracy': 0.34622}, {'accuracy': 0.35675}, {'accuracy': 0.37867}, {'accuracy': 0.34716}, {'accuracy': 0.49277000000000004}, {'accuracy': 0.45191}, {'accuracy': 0.3173}, {'accuracy': 0.36977000000000004}, {'accuracy': 0.36947}, {'accuracy': 0.4069999999999999}, {'accuracy': 0.39207}, {'accuracy': 0.35478}, {'accuracy': 0.33875}, {'accuracy': 0.35443}, {'accuracy': 0.37737999999999994}, {'accuracy': 0.46857999999999994}, {'accuracy': 0.42928999999999995}, {'accuracy': 0.40192999999999995}, {'accuracy': 0.32649999999999996}, {'accuracy': 0.42461000000000004}, {'accuracy': 0.37387}, {'accuracy': 0.33019}, {'accuracy': 0.3505}, {'accuracy': 0.40099}, {'accuracy': 0.21427000000000002}, {'accuracy': 0.32579}, {'accuracy': 0.32143}, {'accuracy': 0.2764}, {'accuracy': 0.48097}, {'accuracy': 0.36206}, {'accuracy': 0.40001999999999993}, {'accuracy': 0.46537000000000006}, {'accuracy': 0.27596999999999994}, {'accuracy': 0.27526}, {'accuracy': 0.37149999999999994}, {'accuracy': 0.35879}, {'accuracy': 0.39390000000000003}, {'accuracy': 0.41685}, {'accuracy': 0.25020000000000003}, {'accuracy': 0.40287000000000006}, {'accuracy': 0.32053}, {'accuracy': 0.4662699999999999}, {'accuracy': 0.31011}, {'accuracy': 0.3273}, {'accuracy': 0.3563}, {'accuracy': 0.35639000000000004}, {'accuracy': 0.26403000000000004}, {'accuracy': 0.342}, {'accuracy': 0.31761999999999996}, {'accuracy': 0.40259999999999996}, {'accuracy': 0.38064}, {'accuracy': 0.23381}, {'accuracy': 0.29046999999999995}, {'accuracy': 0.43568999999999997}, {'accuracy': 0.40898}, {'accuracy': 0.44575}, {'accuracy': 0.39823000000000003}, {'accuracy': 0.23022}, {'accuracy': 0.21313999999999997}, {'accuracy': 0.43583}, {'accuracy': 0.39704999999999996}, {'accuracy': 0.42489}, {'accuracy': 0.31764000000000003}, {'accuracy': 0.34238}, {'accuracy': 0.27117}, {'accuracy': 0.38798999999999995}, {'accuracy': 0.39854}, {'accuracy': 0.4127199999999999}, {'accuracy': 0.42502000000000006}, {'accuracy': 0.35971}, {'accuracy': 0.36528999999999995}, {'accuracy': 0.32015000000000005}, {'accuracy': 0.3324}, {'accuracy': 0.39574999999999994}, {'accuracy': 0.26685}, {'accuracy': 0.31349}, {'accuracy': 0.38981999999999994}, {'accuracy': 0.41719999999999996}, {'accuracy': 0.34964000000000006}, {'accuracy': 0.40225}, {'accuracy': 0.3446}, {'accuracy': 0.41821}, {'accuracy': 0.40237}, {'accuracy': 0.43970000000000004}, {'accuracy': 0.34297}, {'accuracy': 0.31316}, {'accuracy': 0.44554}, {'accuracy': 0.33126}, {'accuracy': 0.30528}, {'accuracy': 0.42957999999999996}, {'accuracy': 0.29904000000000003}, {'accuracy': 0.37565}, {'accuracy': 0.38256}, {'accuracy': 0.29881}, {'accuracy': 0.20712999999999998}, {'accuracy': 0.36396}, {'accuracy': 0.39088}, {'accuracy': 0.24835}, {'accuracy': 0.4324}, {'accuracy': 0.45453}, {'accuracy': 0.37018999999999996}, {'accuracy': 0.2364}, {'accuracy': 0.33773}, {'accuracy': 0.32859}, {'accuracy': 0.43387000000000003}, {'accuracy': 0.33868}, {'accuracy': 0.31085}, {'accuracy': 0.31209}, {'accuracy': 0.26267999999999997}, {'accuracy': 0.33807}, {'accuracy': 0.18536}, {'accuracy': 0.40621}, {'accuracy': 0.21799}, {'accuracy': 0.26108000000000003}, {'accuracy': 0.38376}, {'accuracy': 0.30816}, {'accuracy': 0.34446}, {'accuracy': 0.39331}, {'accuracy': 0.31052}, {'accuracy': 0.36181}, {'accuracy': 0.4208}, {'accuracy': 0.33015}, {'accuracy': 0.36585}, {'accuracy': 0.39059}, {'accuracy': 0.28581}, {'accuracy': 0.33287000000000005}, {'accuracy': 0.36917}, {'accuracy': 0.3014800000000001}, {'accuracy': 0.37849000000000005}, {'accuracy': 0.27823000000000003}, {'accuracy': 0.4629}, {'accuracy': 0.38908}, {'accuracy': 0.32864}, {'accuracy': 0.36204000000000003}, {'accuracy': 0.35316}, {'accuracy': 0.33096000000000003}, {'accuracy': 0.29866}, {'accuracy': 0.23900000000000002}, {'accuracy': 0.40305}, {'accuracy': 0.37054}, {'accuracy': 0.35175}, {'accuracy': 0.33505}, {'accuracy': 0.33768000000000004}, {'accuracy': 0.39623}, {'accuracy': 0.45719999999999994}, {'accuracy': 0.33701}, {'accuracy': 0.41828000000000004}, {'accuracy': 0.7098}, {'accuracy': 0.70869}, {'accuracy': 0.71468}, {'accuracy': 0.71391}, {'accuracy': 0.70577}, {'accuracy': 0.70955}, {'accuracy': 0.70907}, {'accuracy': 0.7099}, {'accuracy': 0.70686}, {'accuracy': 0.71379}, {'accuracy': 0.71285}, {'accuracy': 0.70646}, {'accuracy': 0.70475}, {'accuracy': 0.70834}, {'accuracy': 0.7069099999999999}, {'accuracy': 0.7069799999999999}, {'accuracy': 0.70932}, {'accuracy': 0.70117}, {'accuracy': 0.69851}, {'accuracy': 0.7053499999999999}, {'accuracy': 0.69858}, {'accuracy': 0.70491}, {'accuracy': 0.69717}, {'accuracy': 0.70563}, {'accuracy': 0.70309}, {'accuracy': 0.70702}, {'accuracy': 0.7035599999999999}, {'accuracy': 0.70425}, {'accuracy': 0.7088699999999999}, {'accuracy': 0.70376}, {'accuracy': 0.70629}, {'accuracy': 0.7078199999999999}, {'accuracy': 0.71063}, {'accuracy': 0.69917}, {'accuracy': 0.7060700000000001}, {'accuracy': 0.70487}, {'accuracy': 0.7039500000000001}, {'accuracy': 0.7036100000000001}, {'accuracy': 0.70486}, {'accuracy': 0.70503}, {'accuracy': 0.7037699999999999}, {'accuracy': 0.70607}, {'accuracy': 0.70823}, {'accuracy': 0.7070399999999999}, {'accuracy': 0.70772}, {'accuracy': 0.70301}, {'accuracy': 0.70493}, {'accuracy': 0.70201}, {'accuracy': 0.7123099999999999}, {'accuracy': 0.7038200000000001}, {'accuracy': 0.6970600000000001}, {'accuracy': 0.6999799999999999}, {'accuracy': 0.7028899999999999}, {'accuracy': 0.69929}, {'accuracy': 0.7050299999999999}, {'accuracy': 0.70506}, {'accuracy': 0.70728}, {'accuracy': 0.69966}, {'accuracy': 0.7043}, {'accuracy': 0.7016300000000001}, {'accuracy': 0.70192}, {'accuracy': 0.70591}, {'accuracy': 0.69973}, {'accuracy': 0.70775}, {'accuracy': 0.69967}, {'accuracy': 0.7047899999999999}, {'accuracy': 0.7045699999999999}, {'accuracy': 0.70518}, {'accuracy': 0.7062599999999999}, {'accuracy': 0.70412}, {'accuracy': 0.7079700000000001}, {'accuracy': 0.7086600000000001}, {'accuracy': 0.69953}, {'accuracy': 0.7067300000000001}, {'accuracy': 0.6999899999999999}, {'accuracy': 0.7051200000000001}, {'accuracy': 0.70488}, {'accuracy': 0.71209}, {'accuracy': 0.70123}, {'accuracy': 0.70892}, {'accuracy': 0.6972099999999999}, {'accuracy': 0.70677}, {'accuracy': 0.70618}, {'accuracy': 0.70665}, {'accuracy': 0.70469}, {'accuracy': 0.70497}, {'accuracy': 0.7043600000000001}, {'accuracy': 0.69914}, {'accuracy': 0.70556}, {'accuracy': 0.70119}, {'accuracy': 0.70525}, {'accuracy': 0.7084900000000001}, {'accuracy': 0.7058}, {'accuracy': 0.69966}, {'accuracy': 0.70579}, {'accuracy': 0.7059200000000001}, {'accuracy': 0.70525}, {'accuracy': 0.7015100000000001}, {'accuracy': 0.70541}, {'accuracy': 0.7012700000000001}]\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": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25158f47-204c-497d-bf9a-b15aa83cf750",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa999e-5218-459b-aa18-c368d2b89a07",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d38c6bc-0648-4efd-bd10-c21686f81fb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65522bb9-83a9-4924-9ac4-ba3aeca46882",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd33447b-b31e-4cba-8293-c1aa029a6dfa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2f26062-db15-4120-ba56-68df79685aca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3fe85b8-ea75-4769-ac7f-2082bd43c7b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4a172bb-0afb-4ee7-b710-3384a8d99aee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c56f527a-9987-4d05-b7ad-38bcd05623c0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29587a5e-d15d-4934-8d31-9da72b123f7f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "942c183e-b9ac-4b75-9d7e-42183adbccc0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e09bc5a3-2095-4134-90a6-2e897757bcce",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e04c871-eca9-4307-ba99-cf18ad9f9371",
   "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
}
