{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "\n",
    "import torch.multiprocessing as mp\n",
    "mp.set_sharing_strategy('file_system')\n",
    "\n",
    "# setting path\n",
    "sys.path.append('../')\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_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "from torchvision import models\n",
    "\n",
    "from models import *\n",
    "import os\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "from data.datasets import input_dataset\n",
    "import argparse\n",
    "import torchvision.transforms as transforms\n",
    "from torch.utils.data import DataLoader, random_split\n",
    "from torchvision.models import resnet34\n",
    "import os\n",
    "import torch\n",
    "import datetime\n",
    "# import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import scipy as sp\n",
    "import cv2\n",
    "import numpy as np\n",
    "from torchvision import datasets, transforms\n",
    "from torch.utils.data import DataLoader\n",
    "from torch import nn, optim\n",
    "from PIL import ImageFile\n",
    "    \n",
    "    \n",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5dbef333-022e-40f5-a11a-dff6a51035fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.autograd import Variable\n",
    "\n",
    "def conv3x3(in_planes, out_planes, stride=1):\n",
    "    return nn.Conv2d(in_planes, out_planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "\n",
    "\n",
    "class BasicBlock(nn.Module):\n",
    "    expansion = 1\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(BasicBlock, self).__init__()\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=1, padding=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False),\n",
    "                nn.BatchNorm2d(self.expansion*planes)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = self.bn2(self.conv2(out))\n",
    "        out += self.shortcut(x)\n",
    "        out = F.relu(out)\n",
    "        return out\n",
    "\n",
    "\n",
    "class PreActBlock(nn.Module):\n",
    "    '''Pre-activation version of the BasicBlock.'''\n",
    "    expansion = 1\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(PreActBlock, self).__init__()\n",
    "        self.bn1 = nn.BatchNorm2d(in_planes)\n",
    "        self.conv1 = conv3x3(in_planes, planes, stride)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = conv3x3(planes, planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(x))\n",
    "        shortcut = self.shortcut(out)\n",
    "        out = self.conv1(out)\n",
    "        out = self.conv2(F.relu(self.bn2(out)))\n",
    "        out += shortcut\n",
    "        return out\n",
    "\n",
    "\n",
    "class Bottleneck(nn.Module):\n",
    "    expansion = 4\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(Bottleneck, self).__init__()\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv3 = nn.Conv2d(planes, self.expansion*planes, kernel_size=1, bias=False)\n",
    "        self.bn3 = nn.BatchNorm2d(self.expansion*planes)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False),\n",
    "                nn.BatchNorm2d(self.expansion*planes)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = F.relu(self.bn2(self.conv2(out)))\n",
    "        out = self.bn3(self.conv3(out))\n",
    "        out += self.shortcut(x)\n",
    "        out = F.relu(out)\n",
    "        return out\n",
    "\n",
    "\n",
    "class PreActBottleneck(nn.Module):\n",
    "    '''Pre-activation version of the original Bottleneck module.'''\n",
    "    expansion = 4\n",
    "\n",
    "    def __init__(self, in_planes, planes, stride=1):\n",
    "        super(PreActBottleneck, self).__init__()\n",
    "        self.bn1 = nn.BatchNorm2d(in_planes)\n",
    "        self.conv1 = nn.Conv2d(in_planes, planes, kernel_size=1, bias=False)\n",
    "        self.bn2 = nn.BatchNorm2d(planes)\n",
    "        self.conv2 = nn.Conv2d(planes, planes, kernel_size=3, stride=stride, padding=1, bias=False)\n",
    "        self.bn3 = nn.BatchNorm2d(planes)\n",
    "        self.conv3 = nn.Conv2d(planes, self.expansion*planes, kernel_size=1, bias=False)\n",
    "\n",
    "        self.shortcut = nn.Sequential()\n",
    "        if stride != 1 or in_planes != self.expansion*planes:\n",
    "            self.shortcut = nn.Sequential(\n",
    "                nn.Conv2d(in_planes, self.expansion*planes, kernel_size=1, stride=stride, bias=False)\n",
    "            )\n",
    "\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(x))\n",
    "        shortcut = self.shortcut(out)\n",
    "        out = self.conv1(out)\n",
    "        out = self.conv2(F.relu(self.bn2(out)))\n",
    "        out = self.conv3(F.relu(self.bn3(out)))\n",
    "        out += shortcut\n",
    "        return out\n",
    "\n",
    "class ResNet(TorchModel):\n",
    "    def __init__(self, block, num_blocks, num_classes=10):\n",
    "        super(ResNet, self).__init__()\n",
    "        self.in_planes = 64\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, 64, kernel_size=3, stride=1, padding=1, bias=False)\n",
    "        self.bn1 = nn.BatchNorm2d(64)\n",
    "        self.layer1 = self._make_layer(block, 64, num_blocks[0], stride=1)\n",
    "        self.layer2 = self._make_layer(block, 128, num_blocks[1], stride=2)\n",
    "        self.layer3 = self._make_layer(block, 256, num_blocks[2], stride=2)\n",
    "        self.layer4 = self._make_layer(block, 512, num_blocks[3], stride=2)\n",
    "        self.linear = nn.Linear(512*block.expansion, num_classes)\n",
    "\n",
    "    def _make_layer(self, block, planes, num_blocks, stride):\n",
    "        strides = [stride] + [1]*(num_blocks-1)\n",
    "        layers = []\n",
    "        for stride in strides:\n",
    "            layers.append(block(self.in_planes, planes, stride))\n",
    "            self.in_planes = planes * block.expansion\n",
    "        return nn.Sequential(*layers)\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",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "    def forward(self, x):\n",
    "        out = F.relu(self.bn1(self.conv1(x)))\n",
    "        out = self.layer1(out)\n",
    "        out = self.layer2(out)\n",
    "        out = self.layer3(out)\n",
    "        out = self.layer4(out)\n",
    "        out = F.avg_pool2d(out, 4)\n",
    "        out = out.view(out.size(0), -1)\n",
    "        out = self.linear(out)\n",
    "        return out\n",
    "\n",
    "def PreResNet18(num_classes):\n",
    "    return ResNet(PreActBlock, [2,2,2,2],num_classes=num_classes)\n",
    "\n",
    "def ResNet18(num_classes):\n",
    "    return ResNet(BasicBlock, [2,2,2,2],num_classes=num_classes)\n",
    "\n",
    "def ResNet34(num_classes):\n",
    "    return ResNet(BasicBlock, [3,4,6,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet50(num_classes):\n",
    "    return ResNet(Bottleneck, [3,4,6,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet101(num_classes):\n",
    "    return ResNet(Bottleneck, [3,4,23,3],num_classes=num_classes)\n",
    "\n",
    "def ResNet152(num_classes):\n",
    "    return ResNet(Bottleneck, [3,8,36,3],num_classes=num_classes)\n",
    "\n",
    "\n",
    "def test():\n",
    "    net = ResNet18()\n",
    "    y = net(torch.randn(1,3,32,32))\n",
    "    print(y.size())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "eba576af-0560-4349-bef2-b8ee5a825dec",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dirichlet_distribution(alpha, num_clients):\n",
    "    return np.random.dirichlet([alpha] * num_clients)\n",
    "\n",
    "def partition_dataset(data, targets, num_clients, alpha):\n",
    "    num_classes = 100\n",
    "    data_indices = [[] for _ in range(num_clients)]\n",
    "    labels = np.array(targets)\n",
    "    \n",
    "    for k in range(num_classes):\n",
    "        class_indices = np.where(labels == k)[0]\n",
    "        np.random.shuffle(class_indices)\n",
    "        proportions = dirichlet_distribution(alpha, num_clients)\n",
    "        proportions = (proportions / proportions.sum()) * len(class_indices)\n",
    "        proportions = np.cumsum(proportions).astype(int)\n",
    "        \n",
    "        previous_idx = 0\n",
    "        for i in range(num_clients):\n",
    "            client_indices = class_indices[previous_idx:proportions[i]]\n",
    "            data_indices[i].extend(client_indices)\n",
    "            previous_idx = proportions[i]\n",
    "    \n",
    "    return data_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args:\n",
    "    def __init__(self):\n",
    "        self.dataset = 'cifar10'\n",
    "        self.noise_type = 'worst'\n",
    "        self.noise_path = None\n",
    "        self.is_human = True\n",
    "\n",
    "args = Args()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fb6d1fb3-90e4-4fe4-8ee1-daa73c3ffe32",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = ResNet18(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "311792f2-7e67-40d3-b9dd-ec25f2eb7b19",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 10])\n"
     ]
    }
   ],
   "source": [
    "dummy_input = torch.randn(32,3, 32, 32)  # Batch size of 32\n",
    "output = model(dummy_input)\n",
    "print(output.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3009e343-a6c5-4a92-9f2c-0bc221b820ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Loaded worse_label from ./data/CIFAR-10_human.pt.\n",
      "The overall noise rate is 0.40208\n",
      "noisy labels loaded from ./data/CIFAR-10_human.pt\n",
      "The noisy data ratio in each class is [0.10618 0.12106 0.10684 0.09346 0.0808  0.11336 0.08406 0.10546 0.09258\n",
      " 0.0962 ]\n",
      "over all noise rate is  0.40208\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Seed\n",
    "torch.manual_seed(42)\n",
    "torch.cuda.manual_seed(42)\n",
    "\n",
    "# Hyper Parameters\n",
    "batch_size = 16\n",
    "learning_rate = 0.001\n",
    "noise_type_map = {'clean':'clean_label', 'worst': 'worse_label', 'aggre': 'aggre_label', 'rand1': 'random_label1', 'rand2': 'random_label2', 'rand3': 'random_label3', 'clean100': 'clean_label', 'noisy100': 'noisy_label'}\n",
    "args.noise_type = noise_type_map[args.noise_type]\n",
    "# load dataset\n",
    "if args.noise_path is None:\n",
    "    if args.dataset == 'cifar10':\n",
    "        args.noise_path = '.\"your path\"/CIFAR-10_human.pt'\n",
    "    elif args.dataset == 'cifar100':\n",
    "        args.noise_path = '.\"your path\"/CIFAR-100_human.pt'\n",
    "    else: \n",
    "        raise NameError(f'Undefined dataset {args.dataset}')\n",
    "\n",
    "# args.noise_path = './data/CIFAR-100_human.pt'\n",
    "train_dataset,test_dataset,num_classes,num_training_samples = input_dataset(args.dataset,args.noise_type, args.noise_path, args.is_human)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cdf886dd-07c1-4e81-a6c0-4418880d9388",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "ffb2f34b-ce86-4e29-80a6-c86dde7bd3d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True, num_workers=2)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False, num_workers=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3405e784-caa3-410a-b153-d26462f100f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# train_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c15b5396-ce45-4019-9ef1-29ddb7587ede",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data1, train_targets1 = [], []\n",
    "for batch in train_loader:\n",
    "    images, labels = batch\n",
    "    train_data1.append(images)\n",
    "    train_targets1.append(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4bcac027-a5c3-4ad5-a936-fb7585562c2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = torch.cat(train_data1, dim=0)\n",
    "train_targets = torch.cat(train_targets1, dim=0)\n",
    "\n",
    "test_data1, test_targets1 = [], []\n",
    "for batch in test_loader:\n",
    "    images, labels = batch\n",
    "    test_data1.append(images)\n",
    "    test_targets1.append(labels)\n",
    "\n",
    "test_data = torch.cat(test_data1, dim=0)\n",
    "test_targets = torch.cat(test_targets1, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "969d1150-90e6-43bf-bbdc-407d82d04598",
   "metadata": {},
   "outputs": [],
   "source": [
    "# test_data[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1a93af80-b82c-40f9-aebe-98baa2ac219f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# train_data = torch.load('CIFAR100train_data.pt')\n",
    "# train_targets = torch.load('CIFAR100train_targets.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "125f8400-f838-4ccf-bc59-c1cb7ad890e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# test_data = torch.load('CIFAR100test_data.pt')\n",
    "# test_targets = torch.load('CIFAR100test_targets.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e9f48b4f-cc77-4e1c-a603-8f613be2cd7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dirichlet_distribution(alpha, num_clients):\n",
    "    return np.random.dirichlet([alpha] * num_clients)\n",
    "\n",
    "def partition_dataset(data, targets, num_clients, alpha):\n",
    "    num_classes = 10\n",
    "    data_indices = [[] for _ in range(num_clients)]\n",
    "    labels = np.array(targets)\n",
    "    \n",
    "    for k in range(num_classes):\n",
    "        class_indices = np.where(labels == k)[0]\n",
    "        np.random.shuffle(class_indices)\n",
    "        proportions = dirichlet_distribution(alpha, num_clients)\n",
    "        proportions = (proportions / proportions.sum()) * len(class_indices)\n",
    "        proportions = np.cumsum(proportions).astype(int)\n",
    "        \n",
    "        previous_idx = 0\n",
    "        for i in range(num_clients):\n",
    "            client_indices = class_indices[previous_idx:proportions[i]]\n",
    "            data_indices[i].extend(client_indices)\n",
    "            previous_idx = proportions[i]\n",
    "    \n",
    "    return data_indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1e06bd0f-6a97-4df3-a257-94cee500c543",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "dataset = TensorDataset(test_data, test_targets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f21f66a4-2b7d-4370-afe0-44a2a18c22dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_clients = 10\n",
    "alpha = 1.5  # Example alpha value\n",
    "data_indices = partition_dataset(train_data, train_targets, num_clients, alpha)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "e40b9925-426e-4428-9449-42081e43bce4",
   "metadata": {},
   "outputs": [],
   "source": [
    "concatenated_data = []\n",
    "concatenated_targets = []\n",
    "for indices in data_indices:\n",
    "    concatenated_data.append(train_data[indices])\n",
    "    concatenated_targets.append(train_targets[indices])\n",
    "\n",
    "concatenated_data = torch.cat(concatenated_data, dim=0)\n",
    "concatenated_targets = torch.cat(concatenated_targets, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "422b0f02-8fe2-4f82-8176-fb9f7a5b8e6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (concatenated_data, concatenated_targets)\n",
    "Xte, yte = (test_data, test_targets)\n",
    "\n",
    "# print(\"this is\")\n",
    "# print(ytr[1])\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "065af6ec-e741-4275-824a-2676a550dd23",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c261d7b-9a25-4013-99ed-337dc0d77f01",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77a46e14-4f5e-41a2-bbff-74b3658104f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e8c2e5f7-c284-4800-b1f1-5f581b78691f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=model,\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 16,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05673ff6-5592-4596-a355-807aead25003",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "0a302a07-7c29-4177-9066-11d5fd3a7709",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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b96Mt99+W7GA4liNGDECixcvxsyZM3HqqaciMTERF110Ea699lq8//77uPXWW/H999/jjDPOgNfrxY4dO/D+++9j6dKlGDlyJObOnYsff/wRF1xwAXr06IHS0lL8+9//Rrdu3aTeawUFBUhNTcWCBQuQlJSEhIQEjB49WnNeX3MKCgrwyCOPYNasWThw4AAuvfRSJCUlYf/+/fjvf/+LW265BXfffTe+++47zJgxA5dffjn69esHj8eDN998UwrUoptuugmPP/44brrpJowcORI//vgjdu3aFfH79uKLL+KRRx5Bnz59kJWVhQkTJmDQoEEYP348RowYgfT0dKxduxYffvghZsyYEdVrJTrhxXFFKxF1EuvXrxcmT54sJCYmCna7XTj77LOFX3/9VfPY3bt3CwAEAMLPP/+seUxJSYlw++23C/n5+YLJZBJycnKEiRMnCi+//LJ0jNgORKt1hcPhEP76178Kubm5gs1mE8444wxhxYoVwllnnaVoRXEs7UDq6+uFq6++WkhNTRUAKFqDuFwu4YknnhBOOukkwWKxCGlpacKIESOEhx56SKipqREEQRCWLVsmXHLJJUJeXp5gNpuFvLw84aqrrhJ27dqleJ5PP/1UGDRokGA0GltsDSJee7gWIx999JEwduxYISEhQUhISBAGDBgg3H777cLOnTsFQRCEffv2CTfccINQUFAgWK1WIT09XTj77LOFb7/9VnGexsZG4cYbbxRSUlKEpKQk4YorrhBKS0sjagdSXFwsXHDBBUJSUpIAQPp5PPLII8KoUaOE1NRUwWazCQMGDBAeffRRweVytfCTICI5nSCo6upERERE1CFxjhsRERFRJ8HgRkRERNRJMLgRERERdRIMbkRERESdBIMbERERUSfB4EZERETUSbABrwafz4cjR44gKSkpZlvSEBEREYUjCALq6uqQl5cX0rhcjsFNw5EjRxT7LxIRERG1h0OHDqFbt25h72dw05CUlATA/+bJ92EkIiIiagu1tbXIz8+XMkg4DG4axOHR5ORkBjciIiJqNy1N0eLiBCIiIqJOgsGNiIiIqJNgcCMiIiLqJBjciIiIiDoJBjciIiKiToLBjYiIiKiTYHAjIiIi6iQY3IiIiIg6CQY3IiIiok6CwY2IiIiok4h7cHvhhRfQs2dPWK1WjB49GqtXr272+Orqatx+++3I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3OR7klpNBrxxw6h4XRIREXUCrLR1Xq2tsinOEYProFbQqrgRERERNYfBLU7ELa+4epSIiIgixeAWJzUaq0qJiIiImsPgFifiHDcOlRIREVGkGNziwOcTNNuBEBERUdvrzA2MGdzioMHlgS/QO5GNdomIqDUEQUCjyxOXr2gbAC9ZsgRjx45FamoqunTpggsvvBB79+6V7i8qKsJVV12F9PR0JCQkYOTIkVi1apV0///+9z+ceuqpsFqtyMjIwO9+9zvpPp1Oh08++UTxfKmpqXjttdcAAAcOHIBOp8PixYtx1llnwWq14u2330ZFRQWuuuoqdO3aFXa7HUOGDMG7776rOI/P58OTTz6JPn36wGKxoHv37nj00UcBABMmTMCMGTMUx5eVlcFsNmPZsmVRvT/R4ASrOBC3uzIb9bCaDHG+GiIi6oya3F4Mmr00Ls+9be5k2M2RR4iGhgbMnDkTQ4cORX19PWbPno3f/e532LhxIxobG3HWWWeha9eu+Oyzz5CTk4P169fD5/MBAL744gv87ne/w3333Yc33ngDLpcLX375ZdTXfO+99+Lpp5/GySefDKvVCofDgREjRuDvf/87kpOT8cUXX+Daa69FQUEBRo3yt+aaNWsWFi5ciGeffRZjx47F0aNHsWPHDgDATTfdhBkzZuDpp5+GxWIBALz11lvo2rUrJkyYEPX1RYrBLQ5qGjm/jYiIThyXXXaZ4vtFixYhMzMT27Ztw6+//oqysjKsWbMG6enpAIA+ffpIxz766KO48sor8dBDD0m3DRs2LOpruOuuu/D73/9ecdvdd98t/fmOO+7A0qVL8f7772PUqFGoq6vDc889h+effx7XXXcdAKCgoABjx44FAPz+97/HjBkz8Omnn+KKK64AALz22mu4/vrr27TXHoNbHEjNd7milIiIWslmMmDb3Mlxe+5o7N69G7Nnz8aqVatQXl4uVdMKCwuxceNGnHzyyVJoU9u4cSNuvvnmY77mkSNHKr73er147LHH8P777+Pw4cNwuVxwOp2w2+0AgO3bt8PpdGLixIma57Narbj22muxaNEiXHHFFVi/fj22bNmCzz777JivtTlMDnEQbAXCihsREbWOTqeLargyni666CL06NEDCxcuRF5eHnw+HwYPHgyXy9Xi9l0t3a/T6ULm3GktPkhISFB8/9RTT+G5557D/Pnz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",
      "text/plain": [
       "<Figure size 700x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5070527f-6b4b-4c69-8525-15e56ca68a59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.31203000000000003}, {'accuracy': 0.32796}, {'accuracy': 0.34365000000000007}, {'accuracy': 0.32587}, {'accuracy': 0.32606}, {'accuracy': 0.32220999999999994}, {'accuracy': 0.33686}, {'accuracy': 0.34058}, {'accuracy': 0.35153}, {'accuracy': 0.35769}, {'accuracy': 0.36589}, {'accuracy': 0.36993}, {'accuracy': 0.36143}, {'accuracy': 0.384}, {'accuracy': 0.38405}, {'accuracy': 0.38961999999999997}, {'accuracy': 0.39289999999999997}, {'accuracy': 0.4152600000000001}, {'accuracy': 0.40644}, {'accuracy': 0.40976}, {'accuracy': 0.40388999999999997}, {'accuracy': 0.40237999999999996}, {'accuracy': 0.41448}, {'accuracy': 0.42042999999999997}, {'accuracy': 0.41623}, {'accuracy': 0.41642999999999997}, {'accuracy': 0.41746}, {'accuracy': 0.43025}, {'accuracy': 0.42713}, {'accuracy': 0.43741}, {'accuracy': 0.43901}, {'accuracy': 0.42134}, {'accuracy': 0.43319}, {'accuracy': 0.41853000000000007}, {'accuracy': 0.42888000000000004}, {'accuracy': 0.43384999999999996}, {'accuracy': 0.43141999999999997}, {'accuracy': 0.4269}, {'accuracy': 0.42272}, {'accuracy': 0.42636}, {'accuracy': 0.44471999999999995}, {'accuracy': 0.42613}, {'accuracy': 0.43900000000000006}, {'accuracy': 0.43865999999999994}, {'accuracy': 0.45409}, {'accuracy': 0.46708}, {'accuracy': 0.44867999999999997}, {'accuracy': 0.43403}, {'accuracy': 0.43421000000000004}, {'accuracy': 0.44317}, {'accuracy': 0.43261000000000005}, {'accuracy': 0.41000000000000003}, {'accuracy': 0.44665999999999995}, {'accuracy': 0.41472999999999993}, {'accuracy': 0.43865}, {'accuracy': 0.42867}, {'accuracy': 0.42432}, {'accuracy': 0.43812999999999996}, {'accuracy': 0.45766999999999997}, {'accuracy': 0.4490900000000001}, {'accuracy': 0.42652}, {'accuracy': 0.45061999999999997}, {'accuracy': 0.4612}, {'accuracy': 0.46396}, {'accuracy': 0.46161}, {'accuracy': 0.45914}, {'accuracy': 0.4544600000000001}, {'accuracy': 0.45361}, {'accuracy': 0.46210000000000007}, {'accuracy': 0.49205}, {'accuracy': 0.47942}, {'accuracy': 0.4521}, {'accuracy': 0.43764000000000003}, {'accuracy': 0.41981999999999997}, {'accuracy': 0.43857999999999997}, {'accuracy': 0.4425199999999999}, {'accuracy': 0.46355}, {'accuracy': 0.43571}, {'accuracy': 0.46082}, {'accuracy': 0.43883}, {'accuracy': 0.44496}, {'accuracy': 0.4582}, {'accuracy': 0.46841}, {'accuracy': 0.45942}, {'accuracy': 0.46959999999999996}, {'accuracy': 0.46708}, {'accuracy': 0.4754899999999999}, {'accuracy': 0.46692}, {'accuracy': 0.47297}, {'accuracy': 0.46347000000000005}, {'accuracy': 0.46408000000000005}, {'accuracy': 0.45853}, {'accuracy': 0.44012}, {'accuracy': 0.45382}, {'accuracy': 0.47517}, {'accuracy': 0.46172}, {'accuracy': 0.44739000000000007}, {'accuracy': 0.46024999999999994}, {'accuracy': 0.49000000000000005}, {'accuracy': 0.44639999999999996}, {'accuracy': 0.46439}, {'accuracy': 0.4647200000000001}, {'accuracy': 0.47122}, {'accuracy': 0.48613999999999996}, {'accuracy': 0.46502}, {'accuracy': 0.49508}, {'accuracy': 0.48308999999999996}, {'accuracy': 0.47124}, {'accuracy': 0.46941}, {'accuracy': 0.45175}, {'accuracy': 0.48944}, {'accuracy': 0.48993000000000003}, {'accuracy': 0.45153999999999994}, {'accuracy': 0.43521}, {'accuracy': 0.46437999999999996}, {'accuracy': 0.4631800000000001}, {'accuracy': 0.43776000000000004}, {'accuracy': 0.44193}, {'accuracy': 0.45285000000000003}, {'accuracy': 0.45777999999999996}, {'accuracy': 0.46353}, {'accuracy': 0.45264}, {'accuracy': 0.47663}, {'accuracy': 0.46188}, {'accuracy': 0.45998}, {'accuracy': 0.45825999999999995}, {'accuracy': 0.47583000000000003}, {'accuracy': 0.46423000000000003}, {'accuracy': 0.48845}, {'accuracy': 0.47163000000000005}, {'accuracy': 0.4708}, {'accuracy': 0.44425}, {'accuracy': 0.46110000000000007}, {'accuracy': 0.44855999999999996}, {'accuracy': 0.48642}, {'accuracy': 0.43901}, {'accuracy': 0.49848}, {'accuracy': 0.47281000000000006}, {'accuracy': 0.4752599999999999}, {'accuracy': 0.48297}, {'accuracy': 0.4754300000000001}, {'accuracy': 0.48790000000000006}, {'accuracy': 0.46697000000000005}, {'accuracy': 0.45050999999999997}, {'accuracy': 0.44960000000000006}, {'accuracy': 0.47151999999999994}, {'accuracy': 0.4587800000000001}, {'accuracy': 0.4575}, {'accuracy': 0.44627}, {'accuracy': 0.45972999999999997}, {'accuracy': 0.44998000000000005}, {'accuracy': 0.4760900000000001}, {'accuracy': 0.48085000000000006}, {'accuracy': 0.46969000000000005}, {'accuracy': 0.46380999999999994}, {'accuracy': 0.47884000000000004}, {'accuracy': 0.46882}, {'accuracy': 0.47459999999999997}, {'accuracy': 0.48258}, {'accuracy': 0.48335999999999996}, {'accuracy': 0.47074}, {'accuracy': 0.47545000000000004}, {'accuracy': 0.46966}, {'accuracy': 0.48094000000000003}, {'accuracy': 0.47446}, {'accuracy': 0.4864300000000001}, {'accuracy': 0.45522999999999997}, {'accuracy': 0.45146}, {'accuracy': 0.4514699999999999}, {'accuracy': 0.48089000000000004}, {'accuracy': 0.47115999999999997}, {'accuracy': 0.48488}, {'accuracy': 0.47101999999999994}, {'accuracy': 0.45520000000000005}, {'accuracy': 0.45297}, {'accuracy': 0.47451}, {'accuracy': 0.48547}, {'accuracy': 0.49850000000000005}, {'accuracy': 0.48448}, {'accuracy': 0.46026000000000006}, {'accuracy': 0.47722999999999993}, {'accuracy': 0.47786999999999996}, {'accuracy': 0.48909000000000014}, {'accuracy': 0.48444000000000004}, {'accuracy': 0.46324}, {'accuracy': 0.45757000000000003}, {'accuracy': 0.44347999999999993}, {'accuracy': 0.46268999999999993}, {'accuracy': 0.45277}, {'accuracy': 0.458}, {'accuracy': 0.4532}, {'accuracy': 0.44688000000000005}, {'accuracy': 0.49420000000000003}, {'accuracy': 0.4871}, {'accuracy': 0.49056999999999995}, {'accuracy': 0.45701}, {'accuracy': 0.47049}, {'accuracy': 0.44420000000000004}, {'accuracy': 0.47857000000000005}, {'accuracy': 0.48360000000000003}, {'accuracy': 0.53368}, {'accuracy': 0.52763}, {'accuracy': 0.51582}, {'accuracy': 0.5250199999999999}, {'accuracy': 0.55043}, {'accuracy': 0.55802}, {'accuracy': 0.53965}, {'accuracy': 0.5382100000000001}, {'accuracy': 0.55486}, {'accuracy': 0.5444599999999999}, {'accuracy': 0.56465}, {'accuracy': 0.54363}, {'accuracy': 0.5683999999999999}, {'accuracy': 0.5744100000000001}, {'accuracy': 0.5739400000000001}, {'accuracy': 0.55229}, {'accuracy': 0.56936}, {'accuracy': 0.53494}, {'accuracy': 0.5438099999999999}, {'accuracy': 0.579}, {'accuracy': 0.56254}, {'accuracy': 0.56791}, {'accuracy': 0.57591}, {'accuracy': 0.57746}, {'accuracy': 0.54668}, {'accuracy': 0.5788800000000001}, {'accuracy': 0.5775999999999999}, {'accuracy': 0.5742}, {'accuracy': 0.57553}, {'accuracy': 0.55178}, {'accuracy': 0.56801}, {'accuracy': 0.57108}, {'accuracy': 0.57927}, {'accuracy': 0.57664}, {'accuracy': 0.5907}, {'accuracy': 0.5381900000000001}, {'accuracy': 0.5742}, {'accuracy': 0.57892}, {'accuracy': 0.5741}, {'accuracy': 0.5767199999999999}, {'accuracy': 0.59882}, {'accuracy': 0.579836}, {'accuracy': 0.579843}, {'accuracy': 0.52471}, {'accuracy': 0.579033}, {'accuracy': 0.5798800000000001}, {'accuracy': 0.59157}, {'accuracy': 0.5922999999999999}, {'accuracy': 0.5700100000000001}, {'accuracy': 0.57159}, {'accuracy': 0.59393}, {'accuracy': 0.5775700000000002}, {'accuracy': 0.59525}, {'accuracy': 0.57217}, {'accuracy': 0.5745100000000001}, {'accuracy': 0.5772700000000001}, {'accuracy': 0.57821}, {'accuracy': 0.57467}, {'accuracy': 0.579327}, {'accuracy': 0.57499}, {'accuracy': 0.5719100000000001}, {'accuracy': 0.579383}, {'accuracy': 0.579076}, {'accuracy': 0.5959900000000001}, {'accuracy': 0.579317}, {'accuracy': 0.579735}, {'accuracy': 0.59897}, {'accuracy': 0.5707699999999999}, {'accuracy': 0.57157}, {'accuracy': 0.59353}, {'accuracy': 0.579743}, {'accuracy': 0.57853}, {'accuracy': 0.57617}, {'accuracy': 0.57574}, {'accuracy': 0.59095}, {'accuracy': 0.59706}, {'accuracy': 0.59511}, {'accuracy': 0.5790900000000001}, {'accuracy': 0.5743799999999999}, {'accuracy': 0.57403}, {'accuracy': 0.59004}, {'accuracy': 0.59304}, {'accuracy': 0.59638}, {'accuracy': 0.5959}, {'accuracy': 0.59198}, {'accuracy': 0.5782700000000001}, {'accuracy': 0.5963199999999999}, {'accuracy': 0.5977599999999998}, {'accuracy': 0.5798579}, {'accuracy': 0.5933299999999999}, {'accuracy': 0.579884}, {'accuracy': 0.59421}, {'accuracy': 0.57492}, {'accuracy': 0.5911}, {'accuracy': 0.57835}, {'accuracy': 0.5748900000000001}, {'accuracy': 0.59253}, {'accuracy': 0.57804}, {'accuracy': 0.5763100000000001}, {'accuracy': 0.57922}, {'accuracy': 0.57408}, {'accuracy': 0.5772100000000001}, {'accuracy': 0.5787700000000001}, {'accuracy': 0.57943}, {'accuracy': 0.5908299999999999}, {'accuracy': 0.579751}, {'accuracy': 0.579108}, {'accuracy': 0.5782899999999999}, {'accuracy': 0.579337}, {'accuracy': 0.5734699999999999}, {'accuracy': 0.579327}, {'accuracy': 0.579253}, {'accuracy': 0.59166}, {'accuracy': 0.59992}, {'accuracy': 0.5926199999999999}, {'accuracy': 0.5975}, {'accuracy': 0.5959700000000001}, {'accuracy': 0.5962799999999999}, {'accuracy': 0.57851}, {'accuracy': 0.5916300000000001}, {'accuracy': 0.59286}, {'accuracy': 0.59746}, {'accuracy': 0.5763}, {'accuracy': 0.59441}, {'accuracy': 0.595799}, {'accuracy': 0.59652}, {'accuracy': 0.59477}, {'accuracy': 0.57786}, {'accuracy': 0.5769200000000001}, {'accuracy': 0.59226}, {'accuracy': 0.59283}, {'accuracy': 0.5917899999999999}, {'accuracy': 0.579778}, {'accuracy': 0.5736699999999999}, {'accuracy': 0.5936}, {'accuracy': 0.57219}, {'accuracy': 0.59163}, {'accuracy': 0.5924899999999999}, {'accuracy': 0.57941}, {'accuracy': 0.57005}, {'accuracy': 0.57411}, {'accuracy': 0.5706500000000001}, {'accuracy': 0.57925}, {'accuracy': 0.5991900000000001}, {'accuracy': 0.57151}, {'accuracy': 0.57046}, {'accuracy': 0.579343}, {'accuracy': 0.5768599999999999}, {'accuracy': 0.57685}, {'accuracy': 0.59228}, {'accuracy': 0.59773}, {'accuracy': 0.5776100000000001}, {'accuracy': 0.59381}, {'accuracy': 0.57113}, {'accuracy': 0.59762}, {'accuracy': 0.5953900000000001}, {'accuracy': 0.5996100000000001}, {'accuracy': 0.57516}, {'accuracy': 0.59807}, {'accuracy': 0.5990500000000001}, {'accuracy': 0.59334}, {'accuracy': 0.59443}, {'accuracy': 0.5986899999999999}, {'accuracy': 0.59981}, {'accuracy': 0.59327}, {'accuracy': 0.5751299999999999}, {'accuracy': 0.579913}, {'accuracy': 0.5964900000000001}, {'accuracy': 0.57205}, {'accuracy': 0.5909599999999999}, {'accuracy': 0.59191}, {'accuracy': 0.5793600000000001}, {'accuracy': 0.57989}, {'accuracy': 0.579701}, {'accuracy': 0.57687}, {'accuracy': 0.579089}, {'accuracy': 0.57953}, {'accuracy': 0.579767}, {'accuracy': 0.59257}, {'accuracy': 0.57846}, {'accuracy': 0.59133}, {'accuracy': 0.5753199999999999}, {'accuracy': 0.5926800000000001}, {'accuracy': 0.579888}, {'accuracy': 0.5967}, {'accuracy': 0.5976800000000001}, {'accuracy': 0.59604}, {'accuracy': 0.5746800000000001}, {'accuracy': 0.5922499999999999}, {'accuracy': 0.5979}, {'accuracy': 0.59349}, {'accuracy': 0.5748900000000001}, {'accuracy': 0.59338}, {'accuracy': 0.58594}, {'accuracy': 0.58534}, {'accuracy': 0.579638}, {'accuracy': 0.5737099999999999}, {'accuracy': 0.58004}, {'accuracy': 0.58775}, {'accuracy': 0.59688}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4812cafe-820d-4a3b-ba74-f3f93540c8b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e21bc33-430f-4bfa-afbc-5eb3470579a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36912f17-4767-42a6-968f-a32bd0727613",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "447c2b68-631d-454b-8a21-eb92bac3b8b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9312507a-3c9c-497c-9ad9-3cbd8c0bb170",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae572b25-cd48-4e51-9750-42aad45ad7ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aceb8a67-0126-4439-9ccc-ee6689c6b779",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "275f81cb-2a57-4007-944f-6c7630e2691b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c7e314d-0c8d-4486-8594-c25293cd2277",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
