{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\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",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 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",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\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",
    "\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_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,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]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1981]\n",
      " [   1   45]\n",
      " [   2   36]\n",
      " [   3   54]\n",
      " [   4   99]\n",
      " [   5  143]\n",
      " [   6  253]\n",
      " [   7  444]\n",
      " [   8  704]\n",
      " [   9 1165]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa23b81-43cd-40f2-8ae4-3c9ca5b8e5e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1216]\n",
      " [   1 1920]\n",
      " [   2   56]\n",
      " [   3   23]\n",
      " [   4   49]\n",
      " [   5   88]\n",
      " [   6  159]\n",
      " [   7  249]\n",
      " [   8  433]\n",
      " [   9  731]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "66be2793-b403-43b1-9269-30f94e832cf4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  756]\n",
      " [   1 1238]\n",
      " [   2 1965]\n",
      " [   3   43]\n",
      " [   4   34]\n",
      " [   5   67]\n",
      " [   6  101]\n",
      " [   7  168]\n",
      " [   8  232]\n",
      " [   9  447]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  410]\n",
      " [   1  738]\n",
      " [   2 1254]\n",
      " [   3 2025]\n",
      " [   4   54]\n",
      " [   5   41]\n",
      " [   6   63]\n",
      " [   7  102]\n",
      " [   8  141]\n",
      " [   9  242]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d70cf5da-acd4-44cd-9674-4122225f00ca",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  276]\n",
      " [   1  442]\n",
      " [   2  690]\n",
      " [   3 1194]\n",
      " [   4 1952]\n",
      " [   5   55]\n",
      " [   6   34]\n",
      " [   7   49]\n",
      " [   8   91]\n",
      " [   9  153]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "22dd2dd8-3dc7-4537-9df4-68cc2fe9d6cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  145]\n",
      " [   1  285]\n",
      " [   2  458]\n",
      " [   3  744]\n",
      " [   4 1186]\n",
      " [   5 2017]\n",
      " [   6   51]\n",
      " [   7   33]\n",
      " [   8   47]\n",
      " [   9   93]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5c6c8374-d56f-49c2-ac81-a94873d19c1c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   77]\n",
      " [   1  172]\n",
      " [   2  250]\n",
      " [   3  438]\n",
      " [   4  757]\n",
      " [   5 1145]\n",
      " [   6 1958]\n",
      " [   7   56]\n",
      " [   8   30]\n",
      " [   9   55]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   57]\n",
      " [   1   86]\n",
      " [   2  145]\n",
      " [   3  233]\n",
      " [   4  466]\n",
      " [   5  753]\n",
      " [   6 1211]\n",
      " [   7 2015]\n",
      " [   8   43]\n",
      " [   9   30]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   32]\n",
      " [   1   48]\n",
      " [   2   97]\n",
      " [   3  163]\n",
      " [   4  238]\n",
      " [   5  425]\n",
      " [   6  728]\n",
      " [   7 1192]\n",
      " [   8 2057]\n",
      " [   9   63]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   50]\n",
      " [   1   26]\n",
      " [   2   49]\n",
      " [   3   83]\n",
      " [   4  165]\n",
      " [   5  266]\n",
      " [   6  442]\n",
      " [   7  692]\n",
      " [   8 1222]\n",
      " [   9 2021]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aba313c-d985-49aa-8858-05382c6f2f7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\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=CIFAR10Net(),\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= 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.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=350)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10338}, {'accuracy': 0.10169000000000002}, {'accuracy': 0.1}, {'accuracy': 0.10176}, {'accuracy': 0.10277}, {'accuracy': 0.10010000000000001}, {'accuracy': 0.10554}, {'accuracy': 0.11200000000000002}, {'accuracy': 0.11140000000000001}, {'accuracy': 0.10346}, {'accuracy': 0.10306}, {'accuracy': 0.10395000000000001}, {'accuracy': 0.10674999999999998}, {'accuracy': 0.1038}, {'accuracy': 0.11739000000000002}, {'accuracy': 0.10434000000000002}, {'accuracy': 0.11543}, {'accuracy': 0.11450000000000002}, {'accuracy': 0.10478000000000001}, {'accuracy': 0.10937999999999999}, {'accuracy': 0.10389}, {'accuracy': 0.12549000000000002}, {'accuracy': 0.11757}, {'accuracy': 0.13069999999999998}, {'accuracy': 0.12847999999999998}, {'accuracy': 0.13396000000000002}, {'accuracy': 0.1119}, {'accuracy': 0.11768}, {'accuracy': 0.11228}, {'accuracy': 0.11731}, {'accuracy': 0.1116}, {'accuracy': 0.12446000000000002}, {'accuracy': 0.13574000000000003}, {'accuracy': 0.13442}, {'accuracy': 0.10969}, {'accuracy': 0.13392}, {'accuracy': 0.123}, {'accuracy': 0.13181}, {'accuracy': 0.14528999999999997}, {'accuracy': 0.12710000000000002}, {'accuracy': 0.13699999999999998}, {'accuracy': 0.16104000000000002}, {'accuracy': 0.12661}, {'accuracy': 0.14899}, {'accuracy': 0.14898999999999998}, {'accuracy': 0.15156}, {'accuracy': 0.14201}, {'accuracy': 0.15700999999999998}, {'accuracy': 0.14139}, {'accuracy': 0.13852000000000003}, {'accuracy': 0.15626}, {'accuracy': 0.15914}, {'accuracy': 0.13630000000000003}, {'accuracy': 0.15242}, {'accuracy': 0.16743999999999998}, {'accuracy': 0.19674999999999998}, {'accuracy': 0.14991}, {'accuracy': 0.16844}, {'accuracy': 0.16999}, {'accuracy': 0.20664}, {'accuracy': 0.15275}, {'accuracy': 0.19436000000000003}, {'accuracy': 0.18766}, {'accuracy': 0.16418000000000002}, {'accuracy': 0.18948}, {'accuracy': 0.16079}, {'accuracy': 0.18805}, {'accuracy': 0.16031}, {'accuracy': 0.16259}, {'accuracy': 0.15352}, {'accuracy': 0.15497}, {'accuracy': 0.16304}, {'accuracy': 0.16191999999999998}, {'accuracy': 0.16155999999999998}, {'accuracy': 0.15793}, {'accuracy': 0.17738}, {'accuracy': 0.19263}, {'accuracy': 0.17191}, {'accuracy': 0.16762000000000002}, {'accuracy': 0.17701}, {'accuracy': 0.17482999999999999}, {'accuracy': 0.16016999999999998}, {'accuracy': 0.16846999999999998}, {'accuracy': 0.14013}, {'accuracy': 0.1796}, {'accuracy': 0.17864}, {'accuracy': 0.15258}, {'accuracy': 0.15877000000000002}, {'accuracy': 0.16953}, {'accuracy': 0.17805}, {'accuracy': 0.16470999999999997}, {'accuracy': 0.16274}, {'accuracy': 0.20224999999999999}, {'accuracy': 0.13818999999999998}, {'accuracy': 0.16697}, {'accuracy': 0.13724000000000003}, {'accuracy': 0.15941}, {'accuracy': 0.16443999999999998}, {'accuracy': 0.16494999999999999}, {'accuracy': 0.14941}, {'accuracy': 0.14496}, {'accuracy': 0.17601000000000003}, {'accuracy': 0.17077}, {'accuracy': 0.16694}, {'accuracy': 0.18369}, {'accuracy': 0.16877000000000003}, {'accuracy': 0.17538000000000004}, {'accuracy': 0.19011999999999998}, {'accuracy': 0.18861}, {'accuracy': 0.19433999999999998}, {'accuracy': 0.16646}, {'accuracy': 0.17728000000000002}, {'accuracy': 0.16603}, {'accuracy': 0.1585}, {'accuracy': 0.18123999999999998}, {'accuracy': 0.20148000000000002}, {'accuracy': 0.17712}, {'accuracy': 0.20110999999999998}, {'accuracy': 0.18912}, {'accuracy': 0.17938}, {'accuracy': 0.19745000000000001}, {'accuracy': 0.18164}, {'accuracy': 0.19365}, {'accuracy': 0.18339}, {'accuracy': 0.17364}, {'accuracy': 0.18788999999999997}, {'accuracy': 0.16934}, {'accuracy': 0.16332999999999998}, {'accuracy': 0.17704}, {'accuracy': 0.17364}, {'accuracy': 0.20603}, {'accuracy': 0.18529999999999996}, {'accuracy': 0.18025999999999998}, {'accuracy': 0.16933}, {'accuracy': 0.16552}, {'accuracy': 0.14471}, {'accuracy': 0.17597000000000002}, {'accuracy': 0.18239}, {'accuracy': 0.18206}, {'accuracy': 0.18605}, {'accuracy': 0.17366}, {'accuracy': 0.18057}, {'accuracy': 0.18245000000000003}, {'accuracy': 0.17858000000000002}, {'accuracy': 0.19081}, {'accuracy': 0.19192}, {'accuracy': 0.1977}, {'accuracy': 0.20475000000000004}, {'accuracy': 0.20631}, {'accuracy': 0.18958999999999998}, {'accuracy': 0.20171}, {'accuracy': 0.1955}, {'accuracy': 0.19244999999999998}, {'accuracy': 0.20073}, {'accuracy': 0.21518}, {'accuracy': 0.18467}, {'accuracy': 0.19466999999999998}, {'accuracy': 0.20612000000000003}, {'accuracy': 0.20548000000000002}, {'accuracy': 0.19878}, {'accuracy': 0.20682999999999999}, {'accuracy': 0.20417000000000002}, {'accuracy': 0.19467}, {'accuracy': 0.19372}, {'accuracy': 0.22349000000000002}, {'accuracy': 0.20156999999999997}, {'accuracy': 0.21851000000000004}, {'accuracy': 0.20966}, {'accuracy': 0.21215}, {'accuracy': 0.22847}, {'accuracy': 0.22494}, {'accuracy': 0.21964}, {'accuracy': 0.22588}, {'accuracy': 0.21635}, {'accuracy': 0.22159}, {'accuracy': 0.2285}, {'accuracy': 0.2205}, {'accuracy': 0.22290000000000001}, {'accuracy': 0.22948}, {'accuracy': 0.22948}, {'accuracy': 0.23634}, {'accuracy': 0.22644999999999998}, {'accuracy': 0.22134}, {'accuracy': 0.24175999999999997}, {'accuracy': 0.23967}, {'accuracy': 0.24420000000000003}, {'accuracy': 0.26352999999999993}, {'accuracy': 0.28526}, {'accuracy': 0.27754999999999996}, {'accuracy': 0.28481000000000006}, {'accuracy': 0.28562}, {'accuracy': 0.2908700000000001}, {'accuracy': 0.29530999999999996}, {'accuracy': 0.2924}, {'accuracy': 0.28446000000000005}, {'accuracy': 0.28915}, {'accuracy': 0.29457}, {'accuracy': 0.29423}, {'accuracy': 0.29836}, {'accuracy': 0.29378000000000004}, {'accuracy': 0.30317}, {'accuracy': 0.29877000000000004}, {'accuracy': 0.30177}, {'accuracy': 0.30251}, {'accuracy': 0.30569999999999997}, {'accuracy': 0.30375}, {'accuracy': 0.30537000000000003}, {'accuracy': 0.29791}, {'accuracy': 0.30358}, {'accuracy': 0.30720000000000003}, {'accuracy': 0.30794999999999995}, {'accuracy': 0.30579}, {'accuracy': 0.31024}, {'accuracy': 0.31046}, {'accuracy': 0.30821}, {'accuracy': 0.30891}, {'accuracy': 0.31083000000000005}, {'accuracy': 0.30522000000000005}, {'accuracy': 0.30365999999999993}, {'accuracy': 0.30835}, {'accuracy': 0.31287000000000004}, {'accuracy': 0.31666}, {'accuracy': 0.3132400000000001}, {'accuracy': 0.30367}, {'accuracy': 0.3069}, {'accuracy': 0.31493000000000004}, {'accuracy': 0.3114}, {'accuracy': 0.30727}, {'accuracy': 0.31670999999999994}, {'accuracy': 0.32428}, {'accuracy': 0.31572}, {'accuracy': 0.31812000000000007}, {'accuracy': 0.31549000000000005}, {'accuracy': 0.30805000000000005}, {'accuracy': 0.32261999999999996}, {'accuracy': 0.31371000000000004}, {'accuracy': 0.31121}, {'accuracy': 0.31121000000000004}, {'accuracy': 0.31598000000000004}, {'accuracy': 0.31828999999999996}, {'accuracy': 0.31545}, {'accuracy': 0.31738}, {'accuracy': 0.31194}, {'accuracy': 0.31948000000000004}, {'accuracy': 0.31804}, {'accuracy': 0.32476000000000005}, {'accuracy': 0.31815}, {'accuracy': 0.32045}, {'accuracy': 0.32106999999999997}, {'accuracy': 0.32671}, {'accuracy': 0.32111}, {'accuracy': 0.32460999999999995}, {'accuracy': 0.31878}, {'accuracy': 0.32293000000000005}, {'accuracy': 0.32345999999999997}, {'accuracy': 0.31742}, {'accuracy': 0.31796}, {'accuracy': 0.33072}, {'accuracy': 0.3277}, {'accuracy': 0.32448}, {'accuracy': 0.31950999999999996}, {'accuracy': 0.3295}, {'accuracy': 0.32565}, {'accuracy': 0.32049}, {'accuracy': 0.31897000000000003}, {'accuracy': 0.32249000000000005}, {'accuracy': 0.32650999999999997}, {'accuracy': 0.32426}, {'accuracy': 0.32625}, {'accuracy': 0.32899}, {'accuracy': 0.32199}, {'accuracy': 0.32700999999999997}, {'accuracy': 0.31822}, {'accuracy': 0.32737}, {'accuracy': 0.32304999999999995}, {'accuracy': 0.32813000000000003}, {'accuracy': 0.33133}, {'accuracy': 0.33204}, {'accuracy': 0.33021}, {'accuracy': 0.33243999999999996}, {'accuracy': 0.33692}, {'accuracy': 0.33311}, {'accuracy': 0.33301}, {'accuracy': 0.33259}, {'accuracy': 0.33173}, {'accuracy': 0.33389}, {'accuracy': 0.33591999999999994}, {'accuracy': 0.33144999999999997}, {'accuracy': 0.33432000000000006}, {'accuracy': 0.33008000000000004}, {'accuracy': 0.33315}, {'accuracy': 0.33107}, {'accuracy': 0.33024000000000003}, {'accuracy': 0.3343}, {'accuracy': 0.33210999999999996}, {'accuracy': 0.33232999999999996}, {'accuracy': 0.33493999999999996}, {'accuracy': 0.33309}, {'accuracy': 0.33453}, {'accuracy': 0.33188999999999996}, {'accuracy': 0.3317}, {'accuracy': 0.33246}, {'accuracy': 0.33242000000000005}, {'accuracy': 0.33329000000000003}, {'accuracy': 0.33492}, {'accuracy': 0.33152}, {'accuracy': 0.33521999999999996}, {'accuracy': 0.33013}, {'accuracy': 0.33717}, {'accuracy': 0.33399999999999996}, {'accuracy': 0.33449999999999996}, {'accuracy': 0.33198000000000005}, {'accuracy': 0.3327}, {'accuracy': 0.33554000000000006}, {'accuracy': 0.33222999999999997}, {'accuracy': 0.33333}, {'accuracy': 0.33631}, {'accuracy': 0.33381}, {'accuracy': 0.33336000000000005}, {'accuracy': 0.32994}, {'accuracy': 0.33628}, {'accuracy': 0.33636}, {'accuracy': 0.33152000000000004}, {'accuracy': 0.33808999999999995}, {'accuracy': 0.33308000000000004}, {'accuracy': 0.33597}, {'accuracy': 0.33265}, {'accuracy': 0.33408000000000004}, {'accuracy': 0.3353}, {'accuracy': 0.33318}, {'accuracy': 0.33335}, {'accuracy': 0.33464}, {'accuracy': 0.33584}, {'accuracy': 0.33246999999999993}, {'accuracy': 0.33599000000000007}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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VeWFu2m+hu6/pqZGmDJlihAVFSX4+voKSUlJwty5c92C/858/4IgeLx/AMLq1aulc5ryvZ+dnS1cddVVgl6vFyIjI4W//vWvgsViaee7ab7G7j8nJ0e47LLLhPDwcEGn0wmpqanCI488IlRUVCiu01nvXxAE4c477xSSkpIErVYrREVFCZMnT5aCH0Ho2l9/QWj4/jvq118lCILQNrklIiIioo6JPUBERETU7TAAIiIiom6HARARERF1OwyAiIiIqNthAERERETdDgMgIiIi6nYYABEREVG3wwCIiMghIyMDKpXKbc8mIup6GAARERFRt8MAiIiIiLodBkBE1OnYbDYsW7YMqamp0Ol06NmzJ5577jlMmjQJ8+fPV5xbVFQErVYr7cRtMpnw2GOPITExETqdDqmpqfj3v/9d73tt3boV48ePh16vR2JiIh544AEYDIY2vT8iansMgIio01m0aBFeeOEFPPXUUzh8+DA++ugjxMTE4O6778ZHH30Ek8kknfuf//wHCQkJmDRpEgBg1qxZ+Pjjj/Haa6/hyJEjePvttxEYGOjxfU6dOoUrr7wSN954I/bv349169Zh69atbkEWEXU+3AyViDqVqqoqREVF4Y033sDdd9+tOGY0GhEfH49Vq1bhlltuAQAMHToUN9xwA5YsWYLjx4+jX79+2LhxI9LT092unZGRgcsvvxxlZWUIDQ3F3XffDY1Gg7fffls6Z+vWrZgwYQIMBgP8/Pza9maJqM0wA0REncqRI0dgMpkwefJkt2N+fn64/fbb8e677wIA9u3bh4MHD+KOO+4AAGRmZkKj0WDChAlNeq/ff/8da9asQWBgoPRn6tSpsNlsyMrKarV7IqL25+PtARARNYder2/w+N13341hw4bh3LlzWL16NSZNmoSkpKQmvdZVdXU17r33XjzwwANux3r27NmsaxFRx8IMEBF1Kn369IFer5eaml2lpaVh1KhReOedd/DRRx/hzjvvVByz2WzYsmVLk95rxIgROHz4MFJTU93+aLXaVrkfIvIOBkBE1Kn4+fnhsccew6OPPor3338fp06dws6dOxUzue6++2688MILEAQB06dPl55PTk7G7Nmzceedd+LLL79EVlYWMjIy8Mknn3h8r8ceewzbt2/H/PnzkZmZiRMnTuCrr75iEzRRF8AAiIg6naeeegp//etfsXjxYgwYMAAzZsxAYWGhdHzmzJnw8fHBzJkz3RqVV65ciZtuugnz5s1D//79MXfu3HqntQ8ZMgRbtmzB8ePHMX78eAwfPhyLFy9GfHx8m94fEbU9zgIjoi4nOzsbvXv3xp49ezBixAhvD4eIOiAGQETUZVgsFpSUlODhhx9GVlYWtm3b5u0hEVEHxRIYEXUZ27ZtQ1xcHPbs2YNVq1Z5ezhE1IExA0RERETdDjNARERE1O0wACIiIqJuhwEQERERdTsMgIiIiKjbYQBERERE3Q4DICIiIup2GAARERFRt8MAiIiIiLodBkBERETU7fw/MtPVtTv1Hb8AAAAASUVORK5CYII=",
      "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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5c0ad45-8281-48fe-a7a2-c6e95c789252",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "288063a4-ea40-4e00-bb2c-fc0dcaf6b583",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd229406-2249-4e24-a930-a2a133c717b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e61235b0-2ef6-491c-852a-38bb326ee1f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e81b8da2-6250-4d69-80e7-b668afe9125e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba5f2b37-c3bc-4b21-aa98-574965de1a65",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "095804a9-861d-4dd4-bc33-79420846a6e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2026df9-6c42-47e9-b340-cfb90058b023",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c722886-9a5f-4203-b28e-58b8d8d28268",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dfcd6f8f-03f8-4081-b8dc-be1af2fb5371",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "080b801b-6704-4cdd-81f1-e61a965ab07c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6926fbd1-bef9-45e5-ae01-2d9fb1784066",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2da49de-3c48-4d42-8b58-7c3baa43f40e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b36cba65-e2e3-4c15-b423-6ef0812b60c4",
   "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
}
