{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2343]\n",
      " [   1   64]\n",
      " [   2   35]\n",
      " [   3   60]\n",
      " [   4  120]\n",
      " [   5  170]\n",
      " [   6  303]\n",
      " [   7  525]\n",
      " [   8  875]\n",
      " [   9 1422]]\n",
      "[[   0 1455]\n",
      " [   1 2410]\n",
      " [   2   63]\n",
      " [   3   42]\n",
      " [   4   77]\n",
      " [   5  104]\n",
      " [   6  188]\n",
      " [   7  301]\n",
      " [   8  534]\n",
      " [   9  838]]\n",
      "[[   0  894]\n",
      " [   1 1447]\n",
      " [   2 2454]\n",
      " [   3   53]\n",
      " [   4   35]\n",
      " [   5   57]\n",
      " [   6  109]\n",
      " [   7  189]\n",
      " [   8  297]\n",
      " [   9  520]]\n",
      "[[   0  525]\n",
      " [   1  906]\n",
      " [   2 1431]\n",
      " [   3 2422]\n",
      " [   4   60]\n",
      " [   5   47]\n",
      " [   6   77]\n",
      " [   7  115]\n",
      " [   8  171]\n",
      " [   9  270]]\n",
      "[[   0  307]\n",
      " [   1  499]\n",
      " [   2  838]\n",
      " [   3 1405]\n",
      " [   4 2419]\n",
      " [   5   62]\n",
      " [   6   32]\n",
      " [   7   65]\n",
      " [   8  136]\n",
      " [   9  182]]\n",
      "[[   0  184]\n",
      " [   1  274]\n",
      " [   2  544]\n",
      " [   3  892]\n",
      " [   4 1449]\n",
      " [   5 2378]\n",
      " [   6   61]\n",
      " [   7   36]\n",
      " [   8   77]\n",
      " [   9  131]]\n",
      "[[   0  116]\n",
      " [   1  191]\n",
      " [   2  296]\n",
      " [   3  511]\n",
      " [   4  873]\n",
      " [   5 1488]\n",
      " [   6 2424]\n",
      " [   7   57]\n",
      " [   8   44]\n",
      " [   9   60]]\n",
      "[[   0   69]\n",
      " [   1  109]\n",
      " [   2  190]\n",
      " [   3  277]\n",
      " [   4  477]\n",
      " [   5  859]\n",
      " [   6 1449]\n",
      " [   7 2361]\n",
      " [   8   61]\n",
      " [   9   35]]\n",
      "[[   0   42]\n",
      " [   1   63]\n",
      " [   2   94]\n",
      " [   3  213]\n",
      " [   4  294]\n",
      " [   5  529]\n",
      " [   6  870]\n",
      " [   7 1505]\n",
      " [   8 2373]\n",
      " [   9   68]]\n",
      "[[   0   65]\n",
      " [   1   37]\n",
      " [   2   55]\n",
      " [   3  125]\n",
      " [   4  196]\n",
      " [   5  306]\n",
      " [   6  487]\n",
      " [   7  846]\n",
      " [   8 1432]\n",
      " [   9 2474]]\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",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [],
   "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<1:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 0,  ..., 9, 0, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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\">161023-03:02:09 </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;36m161023-03:02:09\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": "cc100088c6764536a587709a439d52d0",
       "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\">161023-05:16:56 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3532</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-05:16:56\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3532\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\">5210215672</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;36m5210215672\u001b[0m                                                        \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "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= 32,\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"
   ]
  },
  {
   "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>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.70\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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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": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b6fe361-f901-46d7-9d2c-4115348e2c32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7841fd69-ca01-4606-a24f-d738656aec1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "151842d7-05ec-44b1-82bb-92dbed36c21e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd4be85c-5795-46fb-8434-b59ad99bbc2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3febeee-f8ca-40d2-b2fa-9257dca9b1a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9435d333-9fd0-43fe-8203-4a062429ab27",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aac1a87e-107e-4842-a7a3-f99e82fa9ca0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be44aec2-6d98-4d43-a452-057523dad8ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93a8809a-c501-4fcc-a7a1-769fe98a8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f83642b-f51a-42fa-b37b-73a7b6bd3f37",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c62a3ea-e703-4b1d-a1ba-d21b9fe55c14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b172bf4-fce6-44aa-87f5-37ba90fb00e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "084269bd-7f55-4358-a040-2be8111a6ab5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e14e8c3e-d66b-4572-94a9-e4acde017711",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b3f37cb-3c2b-433e-aa3a-29594d54dcaa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5b62486-78e1-4518-be55-4e07960c812e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "463f75ad-b3ee-45a5-bccd-9203a56a466a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "989bea67-2b79-49d0-b116-f4c445d7887a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5b3c45f-cd47-4d6b-b4f0-7bb2bc937e82",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f578cfb4-d20e-4a66-9f72-6675b84120d9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "692f1301-0ea3-4b8b-af63-3464ad25ed85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f53f47e6-a3dc-4d39-a671-fb20194dacc6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "538ba8ff-487c-4309-bcfc-9f6ede463ce1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea918a62-e7ed-4603-89fe-555252e4dc51",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "675f0dc8-de77-453c-9445-95ec92ad05c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bb21935-6fe2-4393-a11f-6e6a85c3a61d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e6b67a7-9c37-48f1-839d-be3c34a9a67f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acfc3384-ce01-4d70-a70b-3f59855dc971",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6eb46e26-0ea1-495a-9e27-a87b3e84bac9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2f37a1b1-4b0c-40a2-8af6-f0872df4ba4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b245641d-9ab1-40a6-892d-4b76d66991c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6a578b2-e50d-46ea-8869-a210b762c353",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45e1bedc-fbd8-47ac-b402-9fba20a89122",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c432599-b440-4597-b358-3a48d39be4d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f22d92a-0ce6-423e-8dbb-f488594bb27c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5ccada1-48af-4a8e-9484-6348de4e43de",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "273dfe8e-d6e3-4da0-839a-045609fee997",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "860a434b-d4dc-473a-a392-5acb1a93f198",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5dcb4e2f-4bdc-46d5-a9f4-1ecf33306e2a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ade98d91-0d9c-4ee6-882a-4363423e3d60",
   "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
}
