{
 "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": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2362]\n",
      " [   1   70]\n",
      " [   2   44]\n",
      " [   3   74]\n",
      " [   4  117]\n",
      " [   5  191]\n",
      " [   6  334]\n",
      " [   7  549]\n",
      " [   8  819]\n",
      " [   9 1363]]\n",
      "[[   0 1407]\n",
      " [   1 2634]\n",
      " [   2   55]\n",
      " [   3   38]\n",
      " [   4   72]\n",
      " [   5  102]\n",
      " [   6  163]\n",
      " [   7  318]\n",
      " [   8  511]\n",
      " [   9  928]]\n",
      "[[   0  863]\n",
      " [   1 1648]\n",
      " [   2 2401]\n",
      " [   3   58]\n",
      " [   4   34]\n",
      " [   5   53]\n",
      " [   6  107]\n",
      " [   7  187]\n",
      " [   8  321]\n",
      " [   9  549]]\n",
      "[[   0  500]\n",
      " [   1 1000]\n",
      " [   2 1403]\n",
      " [   3 2337]\n",
      " [   4   51]\n",
      " [   5   27]\n",
      " [   6   58]\n",
      " [   7  130]\n",
      " [   8  193]\n",
      " [   9  334]]\n",
      "[[   0  305]\n",
      " [   1  571]\n",
      " [   2  867]\n",
      " [   3 1556]\n",
      " [   4 2371]\n",
      " [   5   44]\n",
      " [   6   36]\n",
      " [   7   68]\n",
      " [   8  103]\n",
      " [   9  177]]\n",
      "[[   0  209]\n",
      " [   1  357]\n",
      " [   2  504]\n",
      " [   3  918]\n",
      " [   4 1372]\n",
      " [   5 2160]\n",
      " [   6   58]\n",
      " [   7   42]\n",
      " [   8   66]\n",
      " [   9   99]]\n",
      "[[   0  109]\n",
      " [   1  204]\n",
      " [   2  316]\n",
      " [   3  523]\n",
      " [   4  872]\n",
      " [   5 1286]\n",
      " [   6 2388]\n",
      " [   7   75]\n",
      " [   8   39]\n",
      " [   9   69]]\n",
      "[[   0   61]\n",
      " [   1  132]\n",
      " [   2  181]\n",
      " [   3  328]\n",
      " [   4  480]\n",
      " [   5  770]\n",
      " [   6 1457]\n",
      " [   7 2494]\n",
      " [   8   64]\n",
      " [   9   39]]\n",
      "[[   0   39]\n",
      " [   1   81]\n",
      " [   2  120]\n",
      " [   3  180]\n",
      " [   4  288]\n",
      " [   5  496]\n",
      " [   6  835]\n",
      " [   7 1501]\n",
      " [   8 2357]\n",
      " [   9   63]]\n",
      "[[   0   68]\n",
      " [   1   45]\n",
      " [   2   67]\n",
      " [   3  119]\n",
      " [   4  185]\n",
      " [   5  292]\n",
      " [   6  482]\n",
      " [   7  901]\n",
      " [   8 1378]\n",
      " [   9 2328]]\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",
    "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": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "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",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==1:\n",
    "            tag1[z]=7     \n",
    "        elif tag1[z]==7:\n",
    "            tag1[z]=1   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 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"
   ]
  },
  {
   "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:00 </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:00\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": "41916cd195eb4187a4539de9ced7fe13",
       "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:38 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3421</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:58:38\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3421\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\">74714640</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;36m74714640\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.0\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.10427000000000002}, {'accuracy': 0.18261}, {'accuracy': 0.15357000000000004}, {'accuracy': 0.18128000000000002}, {'accuracy': 0.27121}, {'accuracy': 0.22996000000000003}, {'accuracy': 0.38596}, {'accuracy': 0.34210999999999997}, {'accuracy': 0.32172}, {'accuracy': 0.37447}, {'accuracy': 0.48823999999999995}, {'accuracy': 0.47598}, {'accuracy': 0.50178}, {'accuracy': 0.44973}, {'accuracy': 0.59423}, {'accuracy': 0.58417}, {'accuracy': 0.65382}, {'accuracy': 0.64751}, {'accuracy': 0.67218}, {'accuracy': 0.6077299999999999}, {'accuracy': 0.61325}, {'accuracy': 0.64375}, {'accuracy': 0.70861}, {'accuracy': 0.64634}, {'accuracy': 0.74275}, {'accuracy': 0.68222}, {'accuracy': 0.73964}, {'accuracy': 0.7194200000000001}, {'accuracy': 0.76479}, {'accuracy': 0.7527899999999998}, {'accuracy': 0.7448300000000001}, {'accuracy': 0.82896}, {'accuracy': 0.7010799999999999}, {'accuracy': 0.75392}, {'accuracy': 0.85322}, {'accuracy': 0.8622799999999999}, {'accuracy': 0.7967}, {'accuracy': 0.80917}, {'accuracy': 0.79993}, {'accuracy': 0.83439}, {'accuracy': 0.81044}, {'accuracy': 0.8606400000000001}, {'accuracy': 0.81823}, {'accuracy': 0.8183399999999998}, {'accuracy': 0.8192499999999999}, {'accuracy': 0.8332499999999999}, {'accuracy': 0.8530999999999999}, {'accuracy': 0.8390000000000001}, {'accuracy': 0.85077}, {'accuracy': 0.8856300000000001}, {'accuracy': 0.87729}, {'accuracy': 0.88368}, {'accuracy': 0.85928}, {'accuracy': 0.87255}, {'accuracy': 0.8395299999999999}, {'accuracy': 0.8509499999999999}, {'accuracy': 0.87303}, {'accuracy': 0.91088}, {'accuracy': 0.8728199999999999}, {'accuracy': 0.8741300000000001}, {'accuracy': 0.8596}, {'accuracy': 0.8533900000000001}, {'accuracy': 0.8572200000000001}, {'accuracy': 0.87759}, {'accuracy': 0.87791}, {'accuracy': 0.87259}, {'accuracy': 0.8627100000000001}, {'accuracy': 0.8661100000000002}, {'accuracy': 0.8777700000000002}, {'accuracy': 0.8785000000000001}, {'accuracy': 0.8496500000000001}, {'accuracy': 0.89551}, {'accuracy': 0.88401}, {'accuracy': 0.8950899999999999}, {'accuracy': 0.9093800000000002}, {'accuracy': 0.8932100000000001}, {'accuracy': 0.89617}, {'accuracy': 0.88089}, {'accuracy': 0.8766}, {'accuracy': 0.9107099999999999}, {'accuracy': 0.9134999999999998}, {'accuracy': 0.9134599999999999}, {'accuracy': 0.9234100000000002}, {'accuracy': 0.8768100000000001}, {'accuracy': 0.88832}, {'accuracy': 0.9048299999999999}, {'accuracy': 0.8966}, {'accuracy': 0.88479}, {'accuracy': 0.8982600000000002}, {'accuracy': 0.89444}, {'accuracy': 0.90094}, {'accuracy': 0.90403}, {'accuracy': 0.9075200000000001}, {'accuracy': 0.89365}, {'accuracy': 0.90001}, {'accuracy': 0.90977}, {'accuracy': 0.89584}, {'accuracy': 0.8945099999999998}, {'accuracy': 0.9112399999999999}, {'accuracy': 0.91694}, {'accuracy': 0.8969400000000001}, {'accuracy': 0.92049}, {'accuracy': 0.90547}, {'accuracy': 0.9162799999999999}, {'accuracy': 0.9128999999999999}, {'accuracy': 0.9094200000000001}, {'accuracy': 0.9126099999999999}, {'accuracy': 0.9185200000000002}, {'accuracy': 0.9036200000000001}, {'accuracy': 0.9179700000000001}, {'accuracy': 0.9066300000000002}, {'accuracy': 0.91141}, {'accuracy': 0.9013899999999999}, {'accuracy': 0.9117499999999998}, {'accuracy': 0.8951200000000001}, {'accuracy': 0.9115399999999999}, {'accuracy': 0.9230799999999999}, {'accuracy': 0.91921}, {'accuracy': 0.90138}, {'accuracy': 0.90779}, {'accuracy': 0.91134}, {'accuracy': 0.9238200000000001}, {'accuracy': 0.9175199999999999}, {'accuracy': 0.9279}, {'accuracy': 0.9127600000000001}, {'accuracy': 0.92508}, {'accuracy': 0.9135100000000002}, {'accuracy': 0.90154}, {'accuracy': 0.90983}, {'accuracy': 0.90944}, {'accuracy': 0.93481}, {'accuracy': 0.91788}, {'accuracy': 0.9071899999999999}, {'accuracy': 0.91842}, {'accuracy': 0.9240699999999998}, {'accuracy': 0.9314499999999999}, {'accuracy': 0.93728}, {'accuracy': 0.9328}, {'accuracy': 0.9143100000000001}, {'accuracy': 0.9314500000000001}, {'accuracy': 0.92282}, {'accuracy': 0.9325999999999999}, {'accuracy': 0.9196199999999999}, {'accuracy': 0.9356200000000001}, {'accuracy': 0.9123300000000001}, {'accuracy': 0.90807}, {'accuracy': 0.9162500000000001}, {'accuracy': 0.9138999999999999}, {'accuracy': 0.94457}, {'accuracy': 0.9148100000000001}, {'accuracy': 0.75803}, {'accuracy': 0.8708300000000001}, {'accuracy': 0.95824}, {'accuracy': 0.95898}, {'accuracy': 0.96024}, {'accuracy': 0.9604799999999999}, {'accuracy': 0.9572499999999999}, {'accuracy': 0.96111}, {'accuracy': 0.9591100000000001}, {'accuracy': 0.9641699999999999}, {'accuracy': 0.9606699999999998}, {'accuracy': 0.9597899999999999}, {'accuracy': 0.9602700000000001}, {'accuracy': 0.9600100000000001}, {'accuracy': 0.9558600000000002}, {'accuracy': 0.9550700000000001}, {'accuracy': 0.95837}, {'accuracy': 0.96301}, {'accuracy': 0.9630599999999999}, {'accuracy': 0.95333}, {'accuracy': 0.95978}, {'accuracy': 0.9556799999999999}, {'accuracy': 0.9583800000000002}, {'accuracy': 0.95694}, {'accuracy': 0.96028}, {'accuracy': 0.96111}, {'accuracy': 0.95939}, {'accuracy': 0.9592599999999999}, {'accuracy': 0.95846}, {'accuracy': 0.9564199999999999}, {'accuracy': 0.95529}, {'accuracy': 0.9566399999999999}, {'accuracy': 0.95631}, {'accuracy': 0.96112}, {'accuracy': 0.95939}, {'accuracy': 0.96044}, {'accuracy': 0.95875}, {'accuracy': 0.9582599999999999}, {'accuracy': 0.9574299999999999}, {'accuracy': 0.96039}, {'accuracy': 0.9617499999999998}, {'accuracy': 0.9573300000000001}, {'accuracy': 0.9578300000000001}, {'accuracy': 0.9589899999999998}, {'accuracy': 0.9585600000000001}, {'accuracy': 0.95841}, {'accuracy': 0.9619399999999999}, {'accuracy': 0.95839}, {'accuracy': 0.96164}, {'accuracy': 0.9630599999999999}, {'accuracy': 0.9635400000000001}, {'accuracy': 0.95503}, {'accuracy': 0.9582499999999999}, {'accuracy': 0.9622499999999998}, {'accuracy': 0.96035}, {'accuracy': 0.9608500000000001}, {'accuracy': 0.9572299999999998}, {'accuracy': 0.95522}, {'accuracy': 0.9621000000000001}, {'accuracy': 0.95996}, {'accuracy': 0.95903}, {'accuracy': 0.95716}, {'accuracy': 0.9587600000000001}, {'accuracy': 0.9542300000000001}, {'accuracy': 0.95619}, {'accuracy': 0.95991}, {'accuracy': 0.96247}, {'accuracy': 0.9542299999999999}, {'accuracy': 0.96029}, {'accuracy': 0.9624099999999999}, {'accuracy': 0.96133}, {'accuracy': 0.9598599999999999}, {'accuracy': 0.95991}, {'accuracy': 0.96007}, {'accuracy': 0.9556699999999999}, {'accuracy': 0.9613100000000001}, {'accuracy': 0.9590099999999998}, {'accuracy': 0.9578400000000002}, {'accuracy': 0.9620600000000001}, {'accuracy': 0.9587600000000001}, {'accuracy': 0.9580800000000002}, {'accuracy': 0.9626199999999999}, {'accuracy': 0.95885}, {'accuracy': 0.9629899999999999}, {'accuracy': 0.9615199999999998}, {'accuracy': 0.9595}, {'accuracy': 0.9603400000000001}, {'accuracy': 0.9651299999999999}, {'accuracy': 0.958}, {'accuracy': 0.9585100000000001}, {'accuracy': 0.9629099999999999}, {'accuracy': 0.96183}, {'accuracy': 0.9590200000000001}, {'accuracy': 0.96236}, {'accuracy': 0.95923}, {'accuracy': 0.96302}, {'accuracy': 0.96298}, {'accuracy': 0.9617700000000001}, {'accuracy': 0.9632299999999999}, {'accuracy': 0.96176}, {'accuracy': 0.96146}, {'accuracy': 0.9605400000000002}, {'accuracy': 0.9608399999999999}, {'accuracy': 0.95993}, {'accuracy': 0.95975}, {'accuracy': 0.96065}, {'accuracy': 0.9596399999999999}, {'accuracy': 0.9614800000000001}, {'accuracy': 0.9596700000000002}, {'accuracy': 0.9621099999999998}, {'accuracy': 0.95998}, {'accuracy': 0.96225}, {'accuracy': 0.959}, {'accuracy': 0.95745}, {'accuracy': 0.96259}, {'accuracy': 0.96144}, {'accuracy': 0.9634300000000001}, {'accuracy': 0.9596199999999999}, {'accuracy': 0.9566700000000001}, {'accuracy': 0.9578999999999999}, {'accuracy': 0.96164}, {'accuracy': 0.9587399999999999}, {'accuracy': 0.9595}, {'accuracy': 0.9595500000000001}, {'accuracy': 0.96212}, {'accuracy': 0.9568300000000001}, {'accuracy': 0.9625}, {'accuracy': 0.9639499999999999}, {'accuracy': 0.9577300000000001}, {'accuracy': 0.9554200000000002}, {'accuracy': 0.9619499999999999}, {'accuracy': 0.9616899999999999}, {'accuracy': 0.9616599999999998}, {'accuracy': 0.96031}, {'accuracy': 0.9627799999999999}, {'accuracy': 0.9620799999999999}, {'accuracy': 0.9620799999999999}, {'accuracy': 0.9614900000000001}, {'accuracy': 0.96173}, {'accuracy': 0.9606600000000001}, {'accuracy': 0.9614799999999999}, {'accuracy': 0.9614399999999999}, {'accuracy': 0.96227}, {'accuracy': 0.96204}, {'accuracy': 0.9617200000000002}, {'accuracy': 0.9612599999999999}, {'accuracy': 0.9648}, {'accuracy': 0.9631300000000002}, {'accuracy': 0.9602899999999999}, {'accuracy': 0.9606999999999999}]\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81819e42-77ef-4c29-bd00-95dbf29e49be",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cad4d63-d616-422f-bb16-fbef5a434293",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1e59d97-7af2-42d6-add3-d2e8b53665f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0b520e7-2604-464a-8479-7bcdefebf075",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e898352-2f30-42bd-8a08-9c20e90ed037",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d6b3747-9131-493c-ba6f-11b2a4dae7be",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e120fd8d-1b61-406e-ab03-e55a2b9a8d3d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af703fef-f83d-4bbe-b944-4094a95545ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6be83745-7fe9-4dac-9390-535095d597c0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90e36a1f-259a-4dbe-aaf2-22349bf69ec3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e51497e-3121-49e1-9a9a-934c0b62b731",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "808e02c3-aaa0-43a9-9ca2-b359b25065e9",
   "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
}
