{
 "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 CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2398]\n",
      " [   1   80]\n",
      " [   2   36]\n",
      " [   3   67]\n",
      " [   4  105]\n",
      " [   5  194]\n",
      " [   6  287]\n",
      " [   7  566]\n",
      " [   8  812]\n",
      " [   9 1401]]\n",
      "[[   0 1452]\n",
      " [   1 2724]\n",
      " [   2   74]\n",
      " [   3   22]\n",
      " [   4   65]\n",
      " [   5  112]\n",
      " [   6  207]\n",
      " [   7  304]\n",
      " [   8  477]\n",
      " [   9  867]]\n",
      "[[   0  827]\n",
      " [   1 1561]\n",
      " [   2 2378]\n",
      " [   3   55]\n",
      " [   4   41]\n",
      " [   5   53]\n",
      " [   6  122]\n",
      " [   7  172]\n",
      " [   8  275]\n",
      " [   9  569]]\n",
      "[[   0  529]\n",
      " [   1  962]\n",
      " [   2 1483]\n",
      " [   3 2394]\n",
      " [   4   71]\n",
      " [   5   34]\n",
      " [   6   80]\n",
      " [   7  121]\n",
      " [   8  182]\n",
      " [   9  305]]\n",
      "[[   0  289]\n",
      " [   1  603]\n",
      " [   2  834]\n",
      " [   3 1516]\n",
      " [   4 2302]\n",
      " [   5   44]\n",
      " [   6   40]\n",
      " [   7   70]\n",
      " [   8  120]\n",
      " [   9  177]]\n",
      "[[   0  172]\n",
      " [   1  341]\n",
      " [   2  496]\n",
      " [   3  918]\n",
      " [   4 1423]\n",
      " [   5 2182]\n",
      " [   6   57]\n",
      " [   7   32]\n",
      " [   8   69]\n",
      " [   9  103]]\n",
      "[[   0  102]\n",
      " [   1  210]\n",
      " [   2  323]\n",
      " [   3  540]\n",
      " [   4  837]\n",
      " [   5 1273]\n",
      " [   6 2359]\n",
      " [   7   70]\n",
      " [   8   54]\n",
      " [   9   56]]\n",
      "[[   0   56]\n",
      " [   1  137]\n",
      " [   2  173]\n",
      " [   3  300]\n",
      " [   4  510]\n",
      " [   5  820]\n",
      " [   6 1404]\n",
      " [   7 2514]\n",
      " [   8   64]\n",
      " [   9   41]]\n",
      "[[   0   36]\n",
      " [   1   84]\n",
      " [   2  104]\n",
      " [   3  189]\n",
      " [   4  304]\n",
      " [   5  440]\n",
      " [   6  834]\n",
      " [   7 1471]\n",
      " [   8 2382]\n",
      " [   9   47]]\n",
      "[[   0   62]\n",
      " [   1   40]\n",
      " [   2   57]\n",
      " [   3  130]\n",
      " [   4  184]\n",
      " [   5  269]\n",
      " [   6  528]\n",
      " [   7  945]\n",
      " [   8 1416]\n",
      " [   9 2383]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:08:25 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:08:25\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "69a52bb911254e999c858a5beeefc175",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-22:58:22 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3370</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:58:22\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3370\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\">73600800</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;36m73600800\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.96</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.96\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.12084999999999999}, {'accuracy': 0.10489}, {'accuracy': 0.10875000000000001}, {'accuracy': 0.15235}, {'accuracy': 0.19195999999999996}, {'accuracy': 0.16478}, {'accuracy': 0.22895}, {'accuracy': 0.24573}, {'accuracy': 0.35149}, {'accuracy': 0.22818999999999998}, {'accuracy': 0.32143}, {'accuracy': 0.47312000000000004}, {'accuracy': 0.42325}, {'accuracy': 0.5877399999999999}, {'accuracy': 0.52376}, {'accuracy': 0.43418}, {'accuracy': 0.47973999999999994}, {'accuracy': 0.45869}, {'accuracy': 0.48789}, {'accuracy': 0.65229}, {'accuracy': 0.6444799999999999}, {'accuracy': 0.54667}, {'accuracy': 0.5629700000000002}, {'accuracy': 0.68415}, {'accuracy': 0.73014}, {'accuracy': 0.65787}, {'accuracy': 0.64678}, {'accuracy': 0.6682499999999999}, {'accuracy': 0.68904}, {'accuracy': 0.72453}, {'accuracy': 0.71142}, {'accuracy': 0.70797}, {'accuracy': 0.77977}, {'accuracy': 0.73236}, {'accuracy': 0.78505}, {'accuracy': 0.8051300000000001}, {'accuracy': 0.7264000000000002}, {'accuracy': 0.76461}, {'accuracy': 0.7933100000000001}, {'accuracy': 0.82107}, {'accuracy': 0.7700800000000001}, {'accuracy': 0.7795300000000001}, {'accuracy': 0.8157500000000001}, {'accuracy': 0.8197699999999999}, {'accuracy': 0.8251599999999998}, {'accuracy': 0.7901900000000001}, {'accuracy': 0.77633}, {'accuracy': 0.83461}, {'accuracy': 0.8352499999999999}, {'accuracy': 0.83679}, {'accuracy': 0.83801}, {'accuracy': 0.79244}, {'accuracy': 0.81785}, {'accuracy': 0.8119500000000001}, {'accuracy': 0.8621700000000001}, {'accuracy': 0.83402}, {'accuracy': 0.85267}, {'accuracy': 0.85035}, {'accuracy': 0.8184899999999999}, {'accuracy': 0.8423299999999999}, {'accuracy': 0.85655}, {'accuracy': 0.87421}, {'accuracy': 0.86201}, {'accuracy': 0.8714000000000001}, {'accuracy': 0.8424400000000001}, {'accuracy': 0.8292400000000001}, {'accuracy': 0.85632}, {'accuracy': 0.8644000000000002}, {'accuracy': 0.86394}, {'accuracy': 0.88818}, {'accuracy': 0.8601599999999999}, {'accuracy': 0.8832200000000002}, {'accuracy': 0.8830199999999999}, {'accuracy': 0.8861899999999998}, {'accuracy': 0.8875399999999999}, {'accuracy': 0.91302}, {'accuracy': 0.88012}, {'accuracy': 0.9127199999999999}, {'accuracy': 0.89307}, {'accuracy': 0.8808199999999999}, {'accuracy': 0.8739100000000001}, {'accuracy': 0.87239}, {'accuracy': 0.88024}, {'accuracy': 0.8916999999999999}, {'accuracy': 0.8971499999999999}, {'accuracy': 0.88347}, {'accuracy': 0.88734}, {'accuracy': 0.88791}, {'accuracy': 0.8828699999999999}, {'accuracy': 0.90624}, {'accuracy': 0.8802900000000001}, {'accuracy': 0.8783399999999999}, {'accuracy': 0.89686}, {'accuracy': 0.8971699999999998}, {'accuracy': 0.90754}, {'accuracy': 0.9139500000000002}, {'accuracy': 0.87863}, {'accuracy': 0.90466}, {'accuracy': 0.91385}, {'accuracy': 0.91632}, {'accuracy': 0.9125900000000001}, {'accuracy': 0.9170600000000002}, {'accuracy': 0.8993200000000001}, {'accuracy': 0.92387}, {'accuracy': 0.88521}, {'accuracy': 0.88242}, {'accuracy': 0.8897100000000002}, {'accuracy': 0.8965799999999999}, {'accuracy': 0.9171400000000001}, {'accuracy': 0.92179}, {'accuracy': 0.91433}, {'accuracy': 0.9077999999999999}, {'accuracy': 0.9038200000000002}, {'accuracy': 0.91151}, {'accuracy': 0.9030699999999999}, {'accuracy': 0.9172799999999999}, {'accuracy': 0.88584}, {'accuracy': 0.9249400000000001}, {'accuracy': 0.91206}, {'accuracy': 0.9028600000000001}, {'accuracy': 0.9090999999999999}, {'accuracy': 0.90106}, {'accuracy': 0.9190499999999998}, {'accuracy': 0.9103899999999999}, {'accuracy': 0.9168100000000001}, {'accuracy': 0.91074}, {'accuracy': 0.9344699999999999}, {'accuracy': 0.9196099999999999}, {'accuracy': 0.92534}, {'accuracy': 0.9022900000000001}, {'accuracy': 0.9197000000000001}, {'accuracy': 0.90587}, {'accuracy': 0.8992100000000001}, {'accuracy': 0.9160300000000001}, {'accuracy': 0.93255}, {'accuracy': 0.9146699999999999}, {'accuracy': 0.8949}, {'accuracy': 0.90751}, {'accuracy': 0.92057}, {'accuracy': 0.9235300000000001}, {'accuracy': 0.8852399999999999}, {'accuracy': 0.9178500000000002}, {'accuracy': 0.9270299999999999}, {'accuracy': 0.9189900000000002}, {'accuracy': 0.906}, {'accuracy': 0.90398}, {'accuracy': 0.9244899999999999}, {'accuracy': 0.9259300000000001}, {'accuracy': 0.93442}, {'accuracy': 0.92387}, {'accuracy': 0.8296800000000001}, {'accuracy': 0.78861}, {'accuracy': 0.9162100000000001}, {'accuracy': 0.94077}, {'accuracy': 0.96082}, {'accuracy': 0.9614499999999999}, {'accuracy': 0.9557500000000001}, {'accuracy': 0.9584299999999999}, {'accuracy': 0.9585599999999997}, {'accuracy': 0.9568}, {'accuracy': 0.95321}, {'accuracy': 0.9591799999999999}, {'accuracy': 0.95769}, {'accuracy': 0.95859}, {'accuracy': 0.95572}, {'accuracy': 0.9594399999999998}, {'accuracy': 0.9585800000000001}, {'accuracy': 0.9601599999999998}, {'accuracy': 0.9606299999999999}, {'accuracy': 0.9580100000000001}, {'accuracy': 0.9588700000000001}, {'accuracy': 0.9584600000000002}, {'accuracy': 0.9576100000000001}, {'accuracy': 0.9566600000000001}, {'accuracy': 0.9581799999999999}, {'accuracy': 0.9593700000000001}, {'accuracy': 0.9600299999999999}, {'accuracy': 0.9594299999999999}, {'accuracy': 0.95985}, {'accuracy': 0.9607300000000001}, {'accuracy': 0.96004}, {'accuracy': 0.9577899999999999}, {'accuracy': 0.9624899999999998}, {'accuracy': 0.9578599999999999}, {'accuracy': 0.9623100000000001}, {'accuracy': 0.9583600000000001}, {'accuracy': 0.96164}, {'accuracy': 0.95774}, {'accuracy': 0.95837}, {'accuracy': 0.9597}, {'accuracy': 0.9595099999999999}, {'accuracy': 0.96132}, {'accuracy': 0.9619099999999999}, {'accuracy': 0.95996}, {'accuracy': 0.9607100000000001}, {'accuracy': 0.9596599999999998}, {'accuracy': 0.9608400000000001}, {'accuracy': 0.9611599999999999}, {'accuracy': 0.9581800000000001}, {'accuracy': 0.9589899999999998}, {'accuracy': 0.96115}, {'accuracy': 0.96058}, {'accuracy': 0.9618}, {'accuracy': 0.9611199999999999}, {'accuracy': 0.9606699999999998}, {'accuracy': 0.96419}, {'accuracy': 0.9604199999999998}, {'accuracy': 0.96139}, {'accuracy': 0.95861}, {'accuracy': 0.9611000000000001}, {'accuracy': 0.9550600000000001}, {'accuracy': 0.9569999999999999}, {'accuracy': 0.95943}, {'accuracy': 0.9555100000000001}, {'accuracy': 0.95971}, {'accuracy': 0.9613699999999998}, {'accuracy': 0.9623900000000001}, {'accuracy': 0.96099}, {'accuracy': 0.9618400000000001}, {'accuracy': 0.9576999999999998}, {'accuracy': 0.9608300000000002}, {'accuracy': 0.96196}, {'accuracy': 0.95967}, {'accuracy': 0.95672}, {'accuracy': 0.9606200000000001}, {'accuracy': 0.9577600000000001}, {'accuracy': 0.9634600000000001}, {'accuracy': 0.9583600000000001}, {'accuracy': 0.96074}, {'accuracy': 0.9606999999999999}, {'accuracy': 0.9619300000000001}, {'accuracy': 0.961}, {'accuracy': 0.96059}, {'accuracy': 0.96187}, {'accuracy': 0.9645100000000001}, {'accuracy': 0.9605600000000001}, {'accuracy': 0.9611300000000002}, {'accuracy': 0.9628}, {'accuracy': 0.96098}, {'accuracy': 0.96357}, {'accuracy': 0.96448}, {'accuracy': 0.9612999999999999}, {'accuracy': 0.9620000000000001}, {'accuracy': 0.95996}, {'accuracy': 0.96221}, {'accuracy': 0.9641399999999999}, {'accuracy': 0.9621700000000001}, {'accuracy': 0.95932}, {'accuracy': 0.9597899999999999}, {'accuracy': 0.95747}, {'accuracy': 0.9632400000000001}, {'accuracy': 0.95936}, {'accuracy': 0.95859}, {'accuracy': 0.9612699999999998}, {'accuracy': 0.96045}, {'accuracy': 0.95921}, {'accuracy': 0.9578200000000001}, {'accuracy': 0.96157}, {'accuracy': 0.9608000000000001}, {'accuracy': 0.9604199999999998}, {'accuracy': 0.96207}, {'accuracy': 0.95835}, {'accuracy': 0.96176}, {'accuracy': 0.9593900000000002}, {'accuracy': 0.9588699999999999}, {'accuracy': 0.9641299999999999}, {'accuracy': 0.95906}, {'accuracy': 0.9617100000000001}, {'accuracy': 0.9635900000000002}, {'accuracy': 0.9601599999999999}, {'accuracy': 0.9626300000000001}, {'accuracy': 0.9561}, {'accuracy': 0.9614100000000001}, {'accuracy': 0.9621400000000001}, {'accuracy': 0.96098}, {'accuracy': 0.9619}, {'accuracy': 0.96}, {'accuracy': 0.9615500000000001}, {'accuracy': 0.9632}, {'accuracy': 0.9632900000000001}, {'accuracy': 0.9621699999999999}, {'accuracy': 0.96287}, {'accuracy': 0.9609900000000001}, {'accuracy': 0.9603499999999998}, {'accuracy': 0.9600100000000001}, {'accuracy': 0.96357}, {'accuracy': 0.96449}, {'accuracy': 0.9619500000000002}, {'accuracy': 0.9606600000000001}, {'accuracy': 0.9643400000000002}, {'accuracy': 0.9645400000000002}, {'accuracy': 0.96204}, {'accuracy': 0.9623900000000001}, {'accuracy': 0.96107}, {'accuracy': 0.9624600000000001}, {'accuracy': 0.9626100000000001}, {'accuracy': 0.9624}, {'accuracy': 0.96241}, {'accuracy': 0.9597499999999999}, {'accuracy': 0.9641399999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed07a60a-bb9a-4bfa-83ff-95d0ed2db218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d3f947a-e6c8-45b7-b229-b01a515f7b7d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abe157d0-e1d8-4193-b245-3150367c0cc8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3b9ae0a-267a-4812-8448-b8125fc1eed9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6823789-57a0-42d9-ad76-b56ac884abcd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11e1e75f-e402-47d6-8048-989a9ed68207",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8489606-69ae-4ad9-b578-666297ce4491",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc71a4ee-d877-4304-a959-b7d1f77f4b2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c17e1b1-f441-446f-9110-280227b8b49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad1dab37-ff10-46e7-b640-040f8da61a82",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5cdaf4ee-0466-4043-8c0d-d35c7ce62909",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92ac83e5-6e80-4361-86c7-82669e8cfee5",
   "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
}
