{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2381]\n",
      " [   1   61]\n",
      " [   2   37]\n",
      " [   3   63]\n",
      " [   4  130]\n",
      " [   5  202]\n",
      " [   6  296]\n",
      " [   7  531]\n",
      " [   8  887]\n",
      " [   9 1417]]\n",
      "[[   0 1468]\n",
      " [   1 2466]\n",
      " [   2   61]\n",
      " [   3   29]\n",
      " [   4   71]\n",
      " [   5  103]\n",
      " [   6  189]\n",
      " [   7  296]\n",
      " [   8  503]\n",
      " [   9  912]]\n",
      "[[   0  838]\n",
      " [   1 1420]\n",
      " [   2 2441]\n",
      " [   3   54]\n",
      " [   4   41]\n",
      " [   5   63]\n",
      " [   6   99]\n",
      " [   7  177]\n",
      " [   8  330]\n",
      " [   9  540]]\n",
      "[[   0  525]\n",
      " [   1  860]\n",
      " [   2 1447]\n",
      " [   3 2414]\n",
      " [   4   64]\n",
      " [   5   41]\n",
      " [   6   71]\n",
      " [   7  104]\n",
      " [   8  189]\n",
      " [   9  273]]\n",
      "[[   0  323]\n",
      " [   1  489]\n",
      " [   2  859]\n",
      " [   3 1444]\n",
      " [   4 2346]\n",
      " [   5   59]\n",
      " [   6   35]\n",
      " [   7   83]\n",
      " [   8  106]\n",
      " [   9  182]]\n",
      "[[   0  190]\n",
      " [   1  316]\n",
      " [   2  528]\n",
      " [   3  883]\n",
      " [   4 1472]\n",
      " [   5 2394]\n",
      " [   6   60]\n",
      " [   7   48]\n",
      " [   8   56]\n",
      " [   9  120]]\n",
      "[[   0  112]\n",
      " [   1  191]\n",
      " [   2  295]\n",
      " [   3  491]\n",
      " [   4  877]\n",
      " [   5 1454]\n",
      " [   6 2401]\n",
      " [   7   43]\n",
      " [   8   46]\n",
      " [   9   59]]\n",
      "[[   0   58]\n",
      " [   1  101]\n",
      " [   2  174]\n",
      " [   3  312]\n",
      " [   4  482]\n",
      " [   5  864]\n",
      " [   6 1433]\n",
      " [   7 2325]\n",
      " [   8   60]\n",
      " [   9   47]]\n",
      "[[   0   42]\n",
      " [   1   61]\n",
      " [   2  100]\n",
      " [   3  186]\n",
      " [   4  305]\n",
      " [   5  518]\n",
      " [   6  905]\n",
      " [   7 1505]\n",
      " [   8 2370]\n",
      " [   9   58]]\n",
      "[[   0   63]\n",
      " [   1   35]\n",
      " [   2   58]\n",
      " [   3  124]\n",
      " [   4  212]\n",
      " [   5  302]\n",
      " [   6  511]\n",
      " [   7  888]\n",
      " [   8 1453]\n",
      " [   9 2392]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 1, 0,  ..., 7, 0, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:08:13 </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-18:08:13\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": "8603c488ee674eb3ba7a2d63556a1eb8",
       "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-21:39:08 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3328</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:39:08\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3328\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\">4909285888</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;36m4909285888\u001b[0m                                                        \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "008f9041-da88-4944-a2cf-5c9ba298ad58",
   "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.68</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.68\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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mRuiNqp79+74+OOPcdtttyEtLQ133303unbtipycHHz44YcoLi7Gl19+KU3zFSmVStxwww1YtmwZdDodXnvtNafnfueddzBixAikpaVhxowZ6NatGwoKCrBlyxacOXMGf//9d5Pju+aaa/Dpp58iODgYffr0wZYtW7B69WqEh4e32D3IyMjAe++9hxdeeAGpqamIiorCmDFj8Pjjj+PHH3/ENddcgzvvvBMZGRnQ6XTYv38/VqxYgZycHERERGD69OkoLS3FmDFjkJCQgFOnTuGtt97CgAEDpOneAwYMgEKhwMsvv4yKigqo1WqMGTMGUVFRbo111KhRuOeeezB//nzs3bsX48aNg1KpxPHjx/H111/jzTffxE033YSPP/4Y7777LiZOnIiUlBRUVlZi8eLFCAoKwlVXXQXAWpa8+eab8dZbb0EmkyElJQU///yzUy9UY/dt9erVeOONNxAXF4euXbuiZ8+eSEhIwE033YT09HQEBARg9erV2LFjh0P2jahD8O5kLSJqyr59+4TJkycLsbGxglKpFGJiYoTJkycL+/fvb/CaVatWCQAEmUwmnD592uU5WVlZwpQpU4SYmBhBqVQK8fHxwjXXXCOsWLFCOkecCu5q2nJZWZkwbdo0ISIiQggICBDGjx8vHDlyROjSpYvDNOQLmQqen58vXH311UJgYKAAwGFaeGVlpTBnzhwhNTVVUKlUQkREhHDxxRcLr732mmAwGARBEIQVK1YI48aNE6KiogSVSiUkJSUJ99xzj5CXl+fwOosXLxa6desmKBSKJqeFT506VfD392/w+AcffCBkZGQIvr6+QmBgoJCWliY88cQTwrlz5wRBEITdu3cLkydPFpKSkgS1Wi1ERUUJ11xzjbBz506H5ykqKhJuvPFGwc/PTwgNDRXuuece4cCBA82aCn7kyBHh0ksvFXx9fQUAwtSpUwW9Xi88/vjjQnp6uhAYGCj4+/sL6enpwrvvvtvYHwFRuyQThHr5USIiIqJ2jD03RERE1KEwuCEiIqIOhcENERERdSgMboiIiKhDYXBDREREHQqDGyIiIupQOt0ifhaLBefOnUNgYGCLLbtORERErUsQBFRWViIuLs5pb7f6Ol1wc+7cOSQmJnp7GERERHQeTp8+jYSEhEbP6XTBTWBgIADrzRF3UiYiIqK2TavVIjExUfocb0ynC27E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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": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10556000000000001}, {'accuracy': 0.15105000000000002}, {'accuracy': 0.16660999999999998}, {'accuracy': 0.20562}, {'accuracy': 0.19590999999999997}, {'accuracy': 0.20819000000000001}, {'accuracy': 0.24711000000000002}, {'accuracy': 0.3039299999999999}, {'accuracy': 0.3050800000000001}, {'accuracy': 0.26908}, {'accuracy': 0.27877}, {'accuracy': 0.28836999999999996}, {'accuracy': 0.28492000000000006}, {'accuracy': 0.29742999999999997}, {'accuracy': 0.33666}, {'accuracy': 0.30752999999999997}, {'accuracy': 0.38188999999999995}, {'accuracy': 0.37350000000000005}, {'accuracy': 0.39512}, {'accuracy': 0.4013700000000001}, {'accuracy': 0.39266999999999996}, {'accuracy': 0.41692}, {'accuracy': 0.40786}, {'accuracy': 0.37976}, {'accuracy': 0.37254}, {'accuracy': 0.34967}, {'accuracy': 0.41742999999999997}, {'accuracy': 0.38785000000000003}, {'accuracy': 0.37210999999999994}, {'accuracy': 0.41597000000000006}, {'accuracy': 0.37823}, {'accuracy': 0.4356}, {'accuracy': 0.38513}, {'accuracy': 0.37849000000000005}, {'accuracy': 0.44686999999999993}, {'accuracy': 0.38505999999999996}, {'accuracy': 0.36965000000000003}, {'accuracy': 0.4446199999999999}, {'accuracy': 0.45809999999999995}, {'accuracy': 0.43259}, {'accuracy': 0.43825000000000003}, {'accuracy': 0.43486}, {'accuracy': 0.44943}, {'accuracy': 0.44521}, {'accuracy': 0.43345}, {'accuracy': 0.43735999999999997}, {'accuracy': 0.4783100000000001}, {'accuracy': 0.43788}, {'accuracy': 0.49704000000000015}, {'accuracy': 0.4535}, {'accuracy': 0.48451999999999995}, {'accuracy': 0.46991000000000005}, {'accuracy': 0.4508}, {'accuracy': 0.43766}, {'accuracy': 0.44128}, {'accuracy': 0.41047}, {'accuracy': 0.47363999999999995}, {'accuracy': 0.48020000000000007}, {'accuracy': 0.50019}, {'accuracy': 0.49176999999999993}, {'accuracy': 0.52556}, {'accuracy': 0.5128600000000001}, {'accuracy': 0.5111300000000001}, {'accuracy': 0.52085}, {'accuracy': 0.5111399999999999}, {'accuracy': 0.53276}, {'accuracy': 0.5029999999999999}, {'accuracy': 0.54314}, {'accuracy': 0.5357999999999999}, {'accuracy': 0.55196}, {'accuracy': 0.51059}, {'accuracy': 0.50229}, {'accuracy': 0.54333}, {'accuracy': 0.53464}, {'accuracy': 0.5112599999999999}, {'accuracy': 0.54226}, {'accuracy': 0.53893}, {'accuracy': 0.56357}, {'accuracy': 0.53772}, {'accuracy': 0.53893}, {'accuracy': 0.55553}, {'accuracy': 0.5645200000000001}, {'accuracy': 0.5565800000000001}, {'accuracy': 0.51925}, {'accuracy': 0.52595}, {'accuracy': 0.5497}, {'accuracy': 0.5626599999999999}, {'accuracy': 0.57136}, {'accuracy': 0.55488}, {'accuracy': 0.5620200000000001}, {'accuracy': 0.5666899999999999}, {'accuracy': 0.55166}, {'accuracy': 0.5651999999999999}, {'accuracy': 0.55209}, {'accuracy': 0.56405}, {'accuracy': 0.59554}, {'accuracy': 0.57576}, {'accuracy': 0.5513800000000001}, {'accuracy': 0.57536}, {'accuracy': 0.5755999999999999}, {'accuracy': 0.5509999999999999}, {'accuracy': 0.5525}, {'accuracy': 0.55452}, {'accuracy': 0.5549600000000001}, {'accuracy': 0.5626}, {'accuracy': 0.54497}, {'accuracy': 0.57881}, {'accuracy': 0.5775300000000001}, {'accuracy': 0.58078}, {'accuracy': 0.60272}, {'accuracy': 0.5762500000000002}, {'accuracy': 0.5827899999999999}, {'accuracy': 0.5824}, {'accuracy': 0.5833}, {'accuracy': 0.56774}, {'accuracy': 0.56707}, {'accuracy': 0.57297}, {'accuracy': 0.58299}, {'accuracy': 0.57758}, {'accuracy': 0.61246}, {'accuracy': 0.59438}, {'accuracy': 0.59261}, {'accuracy': 0.5803999999999999}, {'accuracy': 0.5912499999999999}, {'accuracy': 0.6079800000000001}, {'accuracy': 0.5691200000000001}, {'accuracy': 0.60033}, {'accuracy': 0.5724799999999999}, {'accuracy': 0.59317}, {'accuracy': 0.6124400000000001}, {'accuracy': 0.60442}, {'accuracy': 0.56623}, {'accuracy': 0.58311}, {'accuracy': 0.6032799999999999}, {'accuracy': 0.6136199999999999}, {'accuracy': 0.59765}, {'accuracy': 0.5708}, {'accuracy': 0.5747099999999999}, {'accuracy': 0.6098899999999998}, {'accuracy': 0.6156400000000001}, {'accuracy': 0.6235799999999999}, {'accuracy': 0.6031100000000001}, {'accuracy': 0.59995}, {'accuracy': 0.59315}, {'accuracy': 0.6117900000000001}, {'accuracy': 0.5953299999999999}, {'accuracy': 0.6098800000000001}, {'accuracy': 0.61635}, {'accuracy': 0.6098399999999999}, {'accuracy': 0.60555}, {'accuracy': 0.61161}, {'accuracy': 0.6105799999999999}, {'accuracy': 0.59498}, {'accuracy': 0.6173200000000001}, {'accuracy': 0.6287400000000001}, {'accuracy': 0.62756}, {'accuracy': 0.63209}, {'accuracy': 0.6030900000000001}, {'accuracy': 0.6139}, {'accuracy': 0.6180800000000002}, {'accuracy': 0.61663}, {'accuracy': 0.6072500000000001}, {'accuracy': 0.62765}, {'accuracy': 0.62293}, {'accuracy': 0.63778}, {'accuracy': 0.6352800000000001}, {'accuracy': 0.6280299999999999}, {'accuracy': 0.65611}, {'accuracy': 0.65467}, {'accuracy': 0.6396}, {'accuracy': 0.6142900000000001}, {'accuracy': 0.60527}, {'accuracy': 0.6295}, {'accuracy': 0.62603}, {'accuracy': 0.6221999999999999}, {'accuracy': 0.6146500000000001}, {'accuracy': 0.60567}, {'accuracy': 0.65472}, {'accuracy': 0.6279000000000001}, {'accuracy': 0.65419}, {'accuracy': 0.6480000000000001}, {'accuracy': 0.6116800000000001}, {'accuracy': 0.66455}, {'accuracy': 0.6389}, {'accuracy': 0.6369800000000001}, {'accuracy': 0.62901}, {'accuracy': 0.63983}, {'accuracy': 0.6287200000000001}, {'accuracy': 0.62256}, {'accuracy': 0.62768}, {'accuracy': 0.63704}, {'accuracy': 0.6678900000000001}, {'accuracy': 0.6405}, {'accuracy': 0.6418299999999999}, {'accuracy': 0.6611999999999999}, {'accuracy': 0.6189500000000001}, {'accuracy': 0.6424899999999999}, {'accuracy': 0.62607}, {'accuracy': 0.63702}, {'accuracy': 0.65374}, {'accuracy': 0.6247499999999999}, {'accuracy': 0.6475299999999999}, {'accuracy': 0.6453399999999999}, {'accuracy': 0.64436}, {'accuracy': 0.6535899999999999}, {'accuracy': 0.6686500000000001}, {'accuracy': 0.6568400000000001}, {'accuracy': 0.66801}, {'accuracy': 0.66532}, {'accuracy': 0.6689899999999999}, {'accuracy': 0.66875}, {'accuracy': 0.67265}, {'accuracy': 0.67432}, {'accuracy': 0.67352}, {'accuracy': 0.6750700000000001}, {'accuracy': 0.6778000000000001}, {'accuracy': 0.67599}, {'accuracy': 0.67455}, {'accuracy': 0.67804}, {'accuracy': 0.6794999999999999}, {'accuracy': 0.6751900000000001}, {'accuracy': 0.6810700000000001}, {'accuracy': 0.6762}, {'accuracy': 0.67685}, {'accuracy': 0.67895}, {'accuracy': 0.6769999999999999}, {'accuracy': 0.67642}, {'accuracy': 0.67912}, {'accuracy': 0.67906}, {'accuracy': 0.67954}, {'accuracy': 0.67988}, {'accuracy': 0.68079}, {'accuracy': 0.6815599999999999}, {'accuracy': 0.6799200000000001}, {'accuracy': 0.6799}, {'accuracy': 0.6829600000000001}, {'accuracy': 0.67989}, {'accuracy': 0.67845}, {'accuracy': 0.68166}, {'accuracy': 0.6794100000000001}, {'accuracy': 0.68087}, {'accuracy': 0.68157}, {'accuracy': 0.6780600000000001}, {'accuracy': 0.6776}, {'accuracy': 0.67882}, {'accuracy': 0.6797199999999999}, {'accuracy': 0.68027}, {'accuracy': 0.68304}, {'accuracy': 0.68272}, {'accuracy': 0.6786200000000001}, {'accuracy': 0.68142}, {'accuracy': 0.6771399999999999}, {'accuracy': 0.68027}, {'accuracy': 0.6828500000000001}, {'accuracy': 0.68423}, {'accuracy': 0.6813999999999999}, {'accuracy': 0.68142}, {'accuracy': 0.68296}, {'accuracy': 0.6774800000000001}, {'accuracy': 0.68157}, {'accuracy': 0.6811}, {'accuracy': 0.6803}, {'accuracy': 0.6851}, {'accuracy': 0.6806500000000001}, {'accuracy': 0.6836300000000001}, {'accuracy': 0.67974}, {'accuracy': 0.6821300000000001}, {'accuracy': 0.6785399999999999}, {'accuracy': 0.67932}, {'accuracy': 0.6818600000000001}, {'accuracy': 0.6786000000000001}, {'accuracy': 0.68245}, {'accuracy': 0.68066}, {'accuracy': 0.67937}, {'accuracy': 0.6851700000000001}, {'accuracy': 0.6770799999999999}, {'accuracy': 0.6860200000000001}, {'accuracy': 0.6787500000000001}, {'accuracy': 0.68173}, {'accuracy': 0.6797}, {'accuracy': 0.68567}, {'accuracy': 0.682}, {'accuracy': 0.68387}, {'accuracy': 0.67506}, {'accuracy': 0.68256}, {'accuracy': 0.6824899999999999}, {'accuracy': 0.67555}, {'accuracy': 0.68091}, {'accuracy': 0.6805800000000002}, {'accuracy': 0.6809999999999999}, {'accuracy': 0.68397}, {'accuracy': 0.68197}, {'accuracy': 0.6824600000000001}, {'accuracy': 0.68512}, {'accuracy': 0.6826399999999999}, {'accuracy': 0.6841299999999999}, {'accuracy': 0.6793199999999999}, {'accuracy': 0.6804000000000001}, {'accuracy': 0.68406}, {'accuracy': 0.68186}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b6fe361-f901-46d7-9d2c-4115348e2c32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7841fd69-ca01-4606-a24f-d738656aec1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "151842d7-05ec-44b1-82bb-92dbed36c21e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd4be85c-5795-46fb-8434-b59ad99bbc2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3febeee-f8ca-40d2-b2fa-9257dca9b1a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9435d333-9fd0-43fe-8203-4a062429ab27",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aac1a87e-107e-4842-a7a3-f99e82fa9ca0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be44aec2-6d98-4d43-a452-057523dad8ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93a8809a-c501-4fcc-a7a1-769fe98a8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f83642b-f51a-42fa-b37b-73a7b6bd3f37",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c62a3ea-e703-4b1d-a1ba-d21b9fe55c14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b172bf4-fce6-44aa-87f5-37ba90fb00e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "084269bd-7f55-4358-a040-2be8111a6ab5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e14e8c3e-d66b-4572-94a9-e4acde017711",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b3f37cb-3c2b-433e-aa3a-29594d54dcaa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5b62486-78e1-4518-be55-4e07960c812e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "463f75ad-b3ee-45a5-bccd-9203a56a466a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "989bea67-2b79-49d0-b116-f4c445d7887a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5b3c45f-cd47-4d6b-b4f0-7bb2bc937e82",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f578cfb4-d20e-4a66-9f72-6675b84120d9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "692f1301-0ea3-4b8b-af63-3464ad25ed85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f53f47e6-a3dc-4d39-a671-fb20194dacc6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "538ba8ff-487c-4309-bcfc-9f6ede463ce1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea918a62-e7ed-4603-89fe-555252e4dc51",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "675f0dc8-de77-453c-9445-95ec92ad05c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bb21935-6fe2-4393-a11f-6e6a85c3a61d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e6b67a7-9c37-48f1-839d-be3c34a9a67f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acfc3384-ce01-4d70-a70b-3f59855dc971",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6eb46e26-0ea1-495a-9e27-a87b3e84bac9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2f37a1b1-4b0c-40a2-8af6-f0872df4ba4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b245641d-9ab1-40a6-892d-4b76d66991c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6a578b2-e50d-46ea-8869-a210b762c353",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45e1bedc-fbd8-47ac-b402-9fba20a89122",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c432599-b440-4597-b358-3a48d39be4d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93e29a01-2ea5-45d6-838c-13332260a7a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd1d42b2-7c8a-4bbb-acc8-dcda5aad8930",
   "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
}
