{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6030\n",
      "[[  0 620]\n",
      " [  1 689]\n",
      " [  2 570]\n",
      " [  3 614]\n",
      " [  4 582]\n",
      " [  5 530]\n",
      " [  6 637]\n",
      " [  7 646]\n",
      " [  8 564]\n",
      " [  9 603]]\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",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "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<5:\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([7, 3, 3,  ..., 5, 8, 2])"
      ]
     },
     "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": 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:50:11 </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:50:11\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": "f2599e4711f34d7ebfc04298b7120ba6",
       "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-23:25:48 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3187</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:25:48\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3187\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\">69604080</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;36m69604080\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": [
      "[{'accuracy': 0.1748}, {'accuracy': 0.52333}, {'accuracy': 0.66639}, {'accuracy': 0.74436}, {'accuracy': 0.73302}, {'accuracy': 0.74396}, {'accuracy': 0.7642599999999999}, {'accuracy': 0.7752300000000001}, {'accuracy': 0.75183}, {'accuracy': 0.74021}, {'accuracy': 0.78126}, {'accuracy': 0.78632}, {'accuracy': 0.78902}, {'accuracy': 0.7492000000000001}, {'accuracy': 0.77656}, {'accuracy': 0.76589}, {'accuracy': 0.7721600000000001}, {'accuracy': 0.8007799999999999}, {'accuracy': 0.76432}, {'accuracy': 0.79312}, {'accuracy': 0.78402}, {'accuracy': 0.7794700000000001}, {'accuracy': 0.75008}, {'accuracy': 0.7863499999999999}, {'accuracy': 0.76014}, {'accuracy': 0.77917}, {'accuracy': 0.7673400000000001}, {'accuracy': 0.77423}, {'accuracy': 0.76825}, {'accuracy': 0.7755699999999999}, {'accuracy': 0.75952}, {'accuracy': 0.7773500000000001}, {'accuracy': 0.77762}, {'accuracy': 0.8}, {'accuracy': 0.79733}, {'accuracy': 0.7701899999999999}, {'accuracy': 0.7708699999999998}, {'accuracy': 0.7830199999999999}, {'accuracy': 0.76388}, {'accuracy': 0.77112}, {'accuracy': 0.7718100000000001}, {'accuracy': 0.78111}, {'accuracy': 0.7804800000000001}, {'accuracy': 0.7739999999999999}, {'accuracy': 0.7759400000000001}, {'accuracy': 0.7953}, {'accuracy': 0.7847600000000001}, {'accuracy': 0.78818}, {'accuracy': 0.80593}, {'accuracy': 0.81416}, {'accuracy': 0.76515}, {'accuracy': 0.7889100000000001}, {'accuracy': 0.78756}, {'accuracy': 0.8111200000000001}, {'accuracy': 0.7872100000000001}, {'accuracy': 0.7951699999999999}, {'accuracy': 0.80295}, {'accuracy': 0.75859}, {'accuracy': 0.80067}, {'accuracy': 0.797}, {'accuracy': 0.7897899999999999}, {'accuracy': 0.7893100000000001}, {'accuracy': 0.76338}, {'accuracy': 0.77478}, {'accuracy': 0.7785}, {'accuracy': 0.7778400000000001}, {'accuracy': 0.78159}, {'accuracy': 0.78849}, {'accuracy': 0.77491}, {'accuracy': 0.79815}, {'accuracy': 0.80873}, {'accuracy': 0.79646}, {'accuracy': 0.79362}, {'accuracy': 0.7961600000000001}, {'accuracy': 0.78595}, {'accuracy': 0.77096}, {'accuracy': 0.78734}, {'accuracy': 0.7857100000000001}, {'accuracy': 0.7700199999999999}, {'accuracy': 0.77448}, {'accuracy': 0.80002}, {'accuracy': 0.7816799999999999}, {'accuracy': 0.76589}, {'accuracy': 0.7795599999999999}, {'accuracy': 0.7647899999999999}, {'accuracy': 0.75343}, {'accuracy': 0.78854}, {'accuracy': 0.77599}, {'accuracy': 0.7834199999999999}, {'accuracy': 0.77462}, {'accuracy': 0.7959600000000002}, {'accuracy': 0.79685}, {'accuracy': 0.76726}, {'accuracy': 0.7739900000000001}, {'accuracy': 0.7606999999999999}, {'accuracy': 0.7630899999999999}, {'accuracy': 0.77272}, {'accuracy': 0.79857}, {'accuracy': 0.79008}, {'accuracy': 0.7796200000000001}, {'accuracy': 0.79184}, {'accuracy': 0.7903800000000001}, {'accuracy': 0.7880499999999999}, {'accuracy': 0.7960999999999999}, {'accuracy': 0.82454}, {'accuracy': 0.7782199999999999}, {'accuracy': 0.7917000000000001}, {'accuracy': 0.78274}, {'accuracy': 0.77843}, {'accuracy': 0.77889}, {'accuracy': 0.7903800000000001}, {'accuracy': 0.7705899999999999}, {'accuracy': 0.7704899999999999}, {'accuracy': 0.7790199999999998}, {'accuracy': 0.77879}, {'accuracy': 0.79743}, {'accuracy': 0.79858}, {'accuracy': 0.78075}, {'accuracy': 0.78848}, {'accuracy': 0.78393}, {'accuracy': 0.77547}, {'accuracy': 0.79592}, {'accuracy': 0.7680100000000001}, {'accuracy': 0.77407}, {'accuracy': 0.78684}, {'accuracy': 0.79496}, {'accuracy': 0.76194}, {'accuracy': 0.78222}, {'accuracy': 0.78764}, {'accuracy': 0.79893}, {'accuracy': 0.7910400000000001}, {'accuracy': 0.78194}, {'accuracy': 0.7786500000000001}, {'accuracy': 0.7889299999999999}, {'accuracy': 0.7919699999999998}, {'accuracy': 0.8025100000000001}, {'accuracy': 0.8167500000000001}, {'accuracy': 0.78583}, {'accuracy': 0.78285}, {'accuracy': 0.7953399999999999}, {'accuracy': 0.7928599999999999}, {'accuracy': 0.7778700000000001}, {'accuracy': 0.7797799999999999}, {'accuracy': 0.79538}, {'accuracy': 0.76383}, {'accuracy': 0.77217}, {'accuracy': 0.78712}, {'accuracy': 0.8102}, {'accuracy': 0.7835600000000001}, {'accuracy': 0.77661}, {'accuracy': 0.82724}, {'accuracy': 0.8503000000000001}, {'accuracy': 0.85239}, {'accuracy': 0.8545}, {'accuracy': 0.85235}, {'accuracy': 0.85578}, {'accuracy': 0.86341}, {'accuracy': 0.8556900000000001}, {'accuracy': 0.8469200000000001}, {'accuracy': 0.8471}, {'accuracy': 0.8522000000000001}, {'accuracy': 0.8528800000000001}, {'accuracy': 0.8543899999999999}, {'accuracy': 0.85351}, {'accuracy': 0.8378399999999999}, {'accuracy': 0.84231}, {'accuracy': 0.85229}, {'accuracy': 0.84451}, {'accuracy': 0.8583399999999999}, {'accuracy': 0.8515599999999999}, {'accuracy': 0.84772}, {'accuracy': 0.85707}, {'accuracy': 0.8408200000000001}, {'accuracy': 0.8488200000000001}, {'accuracy': 0.84419}, {'accuracy': 0.8490399999999999}, {'accuracy': 0.8484300000000001}, {'accuracy': 0.84952}, {'accuracy': 0.8467399999999999}, {'accuracy': 0.84519}, {'accuracy': 0.85778}, {'accuracy': 0.8534599999999999}, {'accuracy': 0.84235}, {'accuracy': 0.86069}, {'accuracy': 0.83888}, {'accuracy': 0.85687}, {'accuracy': 0.85318}, {'accuracy': 0.84952}, {'accuracy': 0.8553599999999999}, {'accuracy': 0.8527300000000002}, {'accuracy': 0.8498700000000001}, {'accuracy': 0.84819}, {'accuracy': 0.8471300000000002}, {'accuracy': 0.8440800000000002}, {'accuracy': 0.8399300000000001}, {'accuracy': 0.8403}, {'accuracy': 0.8394499999999999}, {'accuracy': 0.85329}, {'accuracy': 0.84963}, {'accuracy': 0.8384499999999999}, {'accuracy': 0.8559700000000001}, {'accuracy': 0.83683}, {'accuracy': 0.8513}, {'accuracy': 0.84476}, {'accuracy': 0.8401900000000001}, {'accuracy': 0.84496}, {'accuracy': 0.84169}, {'accuracy': 0.85527}, {'accuracy': 0.8510500000000001}, {'accuracy': 0.84842}, {'accuracy': 0.8343299999999999}, {'accuracy': 0.8501199999999999}, {'accuracy': 0.8515499999999999}, {'accuracy': 0.85362}, {'accuracy': 0.85867}, {'accuracy': 0.8350100000000001}, {'accuracy': 0.85352}, {'accuracy': 0.8430300000000001}, {'accuracy': 0.8478899999999999}, {'accuracy': 0.8529399999999999}, {'accuracy': 0.8465}, {'accuracy': 0.85137}, {'accuracy': 0.8606199999999999}, {'accuracy': 0.8502700000000001}, {'accuracy': 0.8553599999999999}, {'accuracy': 0.85573}, {'accuracy': 0.84694}, {'accuracy': 0.85056}, {'accuracy': 0.84913}, {'accuracy': 0.8445}, {'accuracy': 0.85}, {'accuracy': 0.8399600000000002}, {'accuracy': 0.84383}, {'accuracy': 0.84497}, {'accuracy': 0.84947}, {'accuracy': 0.8491900000000001}, {'accuracy': 0.8523}, {'accuracy': 0.85373}, {'accuracy': 0.84289}, {'accuracy': 0.8526100000000001}, {'accuracy': 0.8604800000000001}, {'accuracy': 0.8465299999999999}, {'accuracy': 0.86066}, {'accuracy': 0.8534099999999999}, {'accuracy': 0.83233}, {'accuracy': 0.8452300000000001}, {'accuracy': 0.84587}, {'accuracy': 0.86043}, {'accuracy': 0.8428100000000001}, {'accuracy': 0.84429}, {'accuracy': 0.8609500000000001}, {'accuracy': 0.84991}, {'accuracy': 0.85006}, {'accuracy': 0.84884}, {'accuracy': 0.85953}, {'accuracy': 0.8458}, {'accuracy': 0.8509}, {'accuracy': 0.85158}, {'accuracy': 0.84317}, {'accuracy': 0.8561399999999999}, {'accuracy': 0.84749}, {'accuracy': 0.84806}, {'accuracy': 0.84932}, {'accuracy': 0.85147}, {'accuracy': 0.85334}, {'accuracy': 0.83972}, {'accuracy': 0.84597}, {'accuracy': 0.84602}, {'accuracy': 0.8466999999999999}, {'accuracy': 0.8457399999999999}, {'accuracy': 0.84961}, {'accuracy': 0.85297}, {'accuracy': 0.8379899999999999}, {'accuracy': 0.83612}, {'accuracy': 0.85207}, {'accuracy': 0.8483500000000002}, {'accuracy': 0.84246}, {'accuracy': 0.84411}, {'accuracy': 0.8595}, {'accuracy': 0.8436}, {'accuracy': 0.8581000000000001}, {'accuracy': 0.8558600000000001}, {'accuracy': 0.84042}, {'accuracy': 0.84762}, {'accuracy': 0.8485199999999999}, {'accuracy': 0.8542500000000001}, {'accuracy': 0.84459}, {'accuracy': 0.85351}, {'accuracy': 0.8526299999999999}, {'accuracy': 0.8518000000000001}, {'accuracy': 0.8446100000000001}, {'accuracy': 0.86032}, {'accuracy': 0.84845}, {'accuracy': 0.83789}, {'accuracy': 0.8432299999999999}, {'accuracy': 0.84931}, {'accuracy': 0.8448}, {'accuracy': 0.84773}, {'accuracy': 0.85504}, {'accuracy': 0.8417199999999999}]\n"
     ]
    }
   ],
   "source": [
    "\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= 5),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.84</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.84\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": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1748}, {'accuracy': 0.52333}, {'accuracy': 0.66639}, {'accuracy': 0.74436}, {'accuracy': 0.73302}, {'accuracy': 0.74396}, {'accuracy': 0.7642599999999999}, {'accuracy': 0.7752300000000001}, {'accuracy': 0.75183}, {'accuracy': 0.74021}, {'accuracy': 0.78126}, {'accuracy': 0.78632}, {'accuracy': 0.78902}, {'accuracy': 0.7492000000000001}, {'accuracy': 0.77656}, {'accuracy': 0.76589}, {'accuracy': 0.7721600000000001}, {'accuracy': 0.8007799999999999}, {'accuracy': 0.76432}, {'accuracy': 0.79312}, {'accuracy': 0.78402}, {'accuracy': 0.7794700000000001}, {'accuracy': 0.75008}, {'accuracy': 0.7863499999999999}, {'accuracy': 0.76014}, {'accuracy': 0.77917}, {'accuracy': 0.7673400000000001}, {'accuracy': 0.77423}, {'accuracy': 0.76825}, {'accuracy': 0.7755699999999999}, {'accuracy': 0.75952}, {'accuracy': 0.7773500000000001}, {'accuracy': 0.77762}, {'accuracy': 0.8}, {'accuracy': 0.79733}, {'accuracy': 0.7701899999999999}, {'accuracy': 0.7708699999999998}, {'accuracy': 0.7830199999999999}, {'accuracy': 0.76388}, {'accuracy': 0.77112}, {'accuracy': 0.7718100000000001}, {'accuracy': 0.78111}, {'accuracy': 0.7804800000000001}, {'accuracy': 0.7739999999999999}, {'accuracy': 0.7759400000000001}, {'accuracy': 0.7953}, {'accuracy': 0.7847600000000001}, {'accuracy': 0.78818}, {'accuracy': 0.80593}, {'accuracy': 0.81416}, {'accuracy': 0.76515}, {'accuracy': 0.7889100000000001}, {'accuracy': 0.78756}, {'accuracy': 0.8111200000000001}, {'accuracy': 0.7872100000000001}, {'accuracy': 0.7951699999999999}, {'accuracy': 0.80295}, {'accuracy': 0.75859}, {'accuracy': 0.80067}, {'accuracy': 0.797}, {'accuracy': 0.7897899999999999}, {'accuracy': 0.7893100000000001}, {'accuracy': 0.76338}, {'accuracy': 0.77478}, {'accuracy': 0.7785}, {'accuracy': 0.7778400000000001}, {'accuracy': 0.78159}, {'accuracy': 0.78849}, {'accuracy': 0.77491}, {'accuracy': 0.79815}, {'accuracy': 0.80873}, {'accuracy': 0.79646}, {'accuracy': 0.79362}, {'accuracy': 0.7961600000000001}, {'accuracy': 0.78595}, {'accuracy': 0.77096}, {'accuracy': 0.78734}, {'accuracy': 0.7857100000000001}, {'accuracy': 0.7700199999999999}, {'accuracy': 0.77448}, {'accuracy': 0.80002}, {'accuracy': 0.7816799999999999}, {'accuracy': 0.76589}, {'accuracy': 0.7795599999999999}, {'accuracy': 0.7647899999999999}, {'accuracy': 0.75343}, {'accuracy': 0.78854}, {'accuracy': 0.77599}, {'accuracy': 0.7834199999999999}, {'accuracy': 0.77462}, {'accuracy': 0.7959600000000002}, {'accuracy': 0.79685}, {'accuracy': 0.76726}, {'accuracy': 0.7739900000000001}, {'accuracy': 0.7606999999999999}, {'accuracy': 0.7630899999999999}, {'accuracy': 0.77272}, {'accuracy': 0.79857}, {'accuracy': 0.79008}, {'accuracy': 0.7796200000000001}, {'accuracy': 0.79184}, {'accuracy': 0.7903800000000001}, {'accuracy': 0.7880499999999999}, {'accuracy': 0.7960999999999999}, {'accuracy': 0.82454}, {'accuracy': 0.7782199999999999}, {'accuracy': 0.7917000000000001}, {'accuracy': 0.78274}, {'accuracy': 0.77843}, {'accuracy': 0.77889}, {'accuracy': 0.7903800000000001}, {'accuracy': 0.7705899999999999}, {'accuracy': 0.7704899999999999}, {'accuracy': 0.7790199999999998}, {'accuracy': 0.77879}, {'accuracy': 0.79743}, {'accuracy': 0.79858}, {'accuracy': 0.78075}, {'accuracy': 0.78848}, {'accuracy': 0.78393}, {'accuracy': 0.77547}, {'accuracy': 0.79592}, {'accuracy': 0.7680100000000001}, {'accuracy': 0.77407}, {'accuracy': 0.78684}, {'accuracy': 0.79496}, {'accuracy': 0.76194}, {'accuracy': 0.78222}, {'accuracy': 0.78764}, {'accuracy': 0.79893}, {'accuracy': 0.7910400000000001}, {'accuracy': 0.78194}, {'accuracy': 0.7786500000000001}, {'accuracy': 0.7889299999999999}, {'accuracy': 0.7919699999999998}, {'accuracy': 0.8025100000000001}, {'accuracy': 0.8167500000000001}, {'accuracy': 0.78583}, {'accuracy': 0.78285}, {'accuracy': 0.7953399999999999}, {'accuracy': 0.7928599999999999}, {'accuracy': 0.7778700000000001}, {'accuracy': 0.7797799999999999}, {'accuracy': 0.79538}, {'accuracy': 0.76383}, {'accuracy': 0.77217}, {'accuracy': 0.78712}, {'accuracy': 0.8102}, {'accuracy': 0.7835600000000001}, {'accuracy': 0.77661}, {'accuracy': 0.82724}, {'accuracy': 0.8503000000000001}, {'accuracy': 0.85239}, {'accuracy': 0.8545}, {'accuracy': 0.85235}, {'accuracy': 0.85578}, {'accuracy': 0.86341}, {'accuracy': 0.8556900000000001}, {'accuracy': 0.8469200000000001}, {'accuracy': 0.8471}, {'accuracy': 0.8522000000000001}, {'accuracy': 0.8528800000000001}, {'accuracy': 0.8543899999999999}, {'accuracy': 0.85351}, {'accuracy': 0.8378399999999999}, {'accuracy': 0.84231}, {'accuracy': 0.85229}, {'accuracy': 0.84451}, {'accuracy': 0.8583399999999999}, {'accuracy': 0.8515599999999999}, {'accuracy': 0.84772}, {'accuracy': 0.85707}, {'accuracy': 0.8408200000000001}, {'accuracy': 0.8488200000000001}, {'accuracy': 0.84419}, {'accuracy': 0.8490399999999999}, {'accuracy': 0.8484300000000001}, {'accuracy': 0.84952}, {'accuracy': 0.8467399999999999}, {'accuracy': 0.84519}, {'accuracy': 0.85778}, {'accuracy': 0.8534599999999999}, {'accuracy': 0.84235}, {'accuracy': 0.86069}, {'accuracy': 0.83888}, {'accuracy': 0.85687}, {'accuracy': 0.85318}, {'accuracy': 0.84952}, {'accuracy': 0.8553599999999999}, {'accuracy': 0.8527300000000002}, {'accuracy': 0.8498700000000001}, {'accuracy': 0.84819}, {'accuracy': 0.8471300000000002}, {'accuracy': 0.8440800000000002}, {'accuracy': 0.8399300000000001}, {'accuracy': 0.8403}, {'accuracy': 0.8394499999999999}, {'accuracy': 0.85329}, {'accuracy': 0.84963}, {'accuracy': 0.8384499999999999}, {'accuracy': 0.8559700000000001}, {'accuracy': 0.83683}, {'accuracy': 0.8513}, {'accuracy': 0.84476}, {'accuracy': 0.8401900000000001}, {'accuracy': 0.84496}, {'accuracy': 0.84169}, {'accuracy': 0.85527}, {'accuracy': 0.8510500000000001}, {'accuracy': 0.84842}, {'accuracy': 0.8343299999999999}, {'accuracy': 0.8501199999999999}, {'accuracy': 0.8515499999999999}, {'accuracy': 0.85362}, {'accuracy': 0.85867}, {'accuracy': 0.8350100000000001}, {'accuracy': 0.85352}, {'accuracy': 0.8430300000000001}, {'accuracy': 0.8478899999999999}, {'accuracy': 0.8529399999999999}, {'accuracy': 0.8465}, {'accuracy': 0.85137}, {'accuracy': 0.8606199999999999}, {'accuracy': 0.8502700000000001}, {'accuracy': 0.8553599999999999}, {'accuracy': 0.85573}, {'accuracy': 0.84694}, {'accuracy': 0.85056}, {'accuracy': 0.84913}, {'accuracy': 0.8445}, {'accuracy': 0.85}, {'accuracy': 0.8399600000000002}, {'accuracy': 0.84383}, {'accuracy': 0.84497}, {'accuracy': 0.84947}, {'accuracy': 0.8491900000000001}, {'accuracy': 0.8523}, {'accuracy': 0.85373}, {'accuracy': 0.84289}, {'accuracy': 0.8526100000000001}, {'accuracy': 0.8604800000000001}, {'accuracy': 0.8465299999999999}, {'accuracy': 0.86066}, {'accuracy': 0.8534099999999999}, {'accuracy': 0.83233}, {'accuracy': 0.8452300000000001}, {'accuracy': 0.84587}, {'accuracy': 0.86043}, {'accuracy': 0.8428100000000001}, {'accuracy': 0.84429}, {'accuracy': 0.8609500000000001}, {'accuracy': 0.84991}, {'accuracy': 0.85006}, {'accuracy': 0.84884}, {'accuracy': 0.85953}, {'accuracy': 0.8458}, {'accuracy': 0.8509}, {'accuracy': 0.85158}, {'accuracy': 0.84317}, {'accuracy': 0.8561399999999999}, {'accuracy': 0.84749}, {'accuracy': 0.84806}, {'accuracy': 0.84932}, {'accuracy': 0.85147}, {'accuracy': 0.85334}, {'accuracy': 0.83972}, {'accuracy': 0.84597}, {'accuracy': 0.84602}, {'accuracy': 0.8466999999999999}, {'accuracy': 0.8457399999999999}, {'accuracy': 0.84961}, {'accuracy': 0.85297}, {'accuracy': 0.8379899999999999}, {'accuracy': 0.83612}, {'accuracy': 0.85207}, {'accuracy': 0.8483500000000002}, {'accuracy': 0.84246}, {'accuracy': 0.84411}, {'accuracy': 0.8595}, {'accuracy': 0.8436}, {'accuracy': 0.8581000000000001}, {'accuracy': 0.8558600000000001}, {'accuracy': 0.84042}, {'accuracy': 0.84762}, {'accuracy': 0.8485199999999999}, {'accuracy': 0.8542500000000001}, {'accuracy': 0.84459}, {'accuracy': 0.85351}, {'accuracy': 0.8526299999999999}, {'accuracy': 0.8518000000000001}, {'accuracy': 0.8446100000000001}, {'accuracy': 0.86032}, {'accuracy': 0.84845}, {'accuracy': 0.83789}, {'accuracy': 0.8432299999999999}, {'accuracy': 0.84931}, {'accuracy': 0.8448}, {'accuracy': 0.84773}, {'accuracy': 0.85504}, {'accuracy': 0.8417199999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cde28483-bf7d-4aac-855d-eaca858d218b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ae90b1b-b84d-4a72-946b-a9c6b604847c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e2e25dd-816e-42f4-a02c-edf143a1f27e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ae522e4-15b1-477e-b6d6-ca24bad89624",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12883e05-18ac-4eb3-803e-a9139fc87b39",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "24342e85-3d7b-4b1b-815e-815396b8037f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11c5f1b8-dfec-4ae0-8c19-0a995c7caa02",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7095753-5ebf-447f-97fd-67ad7409ac3e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e5bb751-0118-47d2-ae2d-2c2ffda2ea63",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4290b90-c67f-4dd9-9257-1bce1d83938e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e11d656d-e460-4e0f-a196-9cffa6b9981e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8eaece65-bde1-4719-9a12-4fb972af0e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8b445b70-9de4-47f0-8471-b85632372e95",
   "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
}
