{
 "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 1988]\n",
      " [   1   51]\n",
      " [   2   30]\n",
      " [   3   66]\n",
      " [   4  111]\n",
      " [   5  151]\n",
      " [   6  225]\n",
      " [   7  408]\n",
      " [   8  713]\n",
      " [   9 1133]]\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 1163]\n",
      " [   1 2037]\n",
      " [   2   50]\n",
      " [   3   38]\n",
      " [   4   61]\n",
      " [   5  104]\n",
      " [   6  156]\n",
      " [   7  283]\n",
      " [   8  429]\n",
      " [   9  697]]\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  716]\n",
      " [   1 1190]\n",
      " [   2 1964]\n",
      " [   3   42]\n",
      " [   4   38]\n",
      " [   5   54]\n",
      " [   6  101]\n",
      " [   7  166]\n",
      " [   8  268]\n",
      " [   9  459]]\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  463]\n",
      " [   1  737]\n",
      " [   2 1188]\n",
      " [   3 1920]\n",
      " [   4   51]\n",
      " [   5   29]\n",
      " [   6   52]\n",
      " [   7   94]\n",
      " [   8  153]\n",
      " [   9  261]]\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  273]\n",
      " [   1  421]\n",
      " [   2  718]\n",
      " [   3 1233]\n",
      " [   4 2013]\n",
      " [   5   44]\n",
      " [   6   35]\n",
      " [   7   63]\n",
      " [   8  104]\n",
      " [   9  171]]\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  163]\n",
      " [   1  232]\n",
      " [   2  440]\n",
      " [   3  760]\n",
      " [   4 1163]\n",
      " [   5 2012]\n",
      " [   6   58]\n",
      " [   7   38]\n",
      " [   8   55]\n",
      " [   9   84]]\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  104]\n",
      " [   1  154]\n",
      " [   2  297]\n",
      " [   3  453]\n",
      " [   4  695]\n",
      " [   5 1231]\n",
      " [   6 1974]\n",
      " [   7   57]\n",
      " [   8   34]\n",
      " [   9   41]]\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   48]\n",
      " [   1   87]\n",
      " [   2  170]\n",
      " [   3  236]\n",
      " [   4  415]\n",
      " [   5  673]\n",
      " [   6 1229]\n",
      " [   7 1984]\n",
      " [   8   44]\n",
      " [   9   29]]\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   29]\n",
      " [   1   47]\n",
      " [   2   85]\n",
      " [   3  167]\n",
      " [   4  279]\n",
      " [   5  421]\n",
      " [   6  739]\n",
      " [   7 1193]\n",
      " [   8 2038]\n",
      " [   9   55]]\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   53]\n",
      " [   1   44]\n",
      " [   2   58]\n",
      " [   3   85]\n",
      " [   4  174]\n",
      " [   5  281]\n",
      " [   6  431]\n",
      " [   7  714]\n",
      " [   8 1162]\n",
      " [   9 2070]]\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<1:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49efb2bc-081d-4a81-8b94-ae49c5d8c52e",
   "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=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "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.10137}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10081}, {'accuracy': 0.1}, {'accuracy': 0.10208000000000002}, {'accuracy': 0.10624}, {'accuracy': 0.10445}, {'accuracy': 0.10843}, {'accuracy': 0.11039000000000002}, {'accuracy': 0.11001000000000001}, {'accuracy': 0.11986000000000001}, {'accuracy': 0.12442}, {'accuracy': 0.10371000000000001}, {'accuracy': 0.11485000000000001}, {'accuracy': 0.12110000000000003}, {'accuracy': 0.13749}, {'accuracy': 0.11013999999999999}, {'accuracy': 0.12907}, {'accuracy': 0.13704}, {'accuracy': 0.12966999999999998}, {'accuracy': 0.14598}, {'accuracy': 0.12072999999999998}, {'accuracy': 0.11692}, {'accuracy': 0.11872}, {'accuracy': 0.15616000000000002}, {'accuracy': 0.13599}, {'accuracy': 0.14125000000000001}, {'accuracy': 0.13516}, {'accuracy': 0.14067}, {'accuracy': 0.19688}, {'accuracy': 0.16589}, {'accuracy': 0.1784}, {'accuracy': 0.16308}, {'accuracy': 0.18589}, {'accuracy': 0.1689}, {'accuracy': 0.16483}, {'accuracy': 0.18694}, {'accuracy': 0.16942999999999997}, {'accuracy': 0.16473999999999997}, {'accuracy': 0.17239000000000002}, {'accuracy': 0.18291}, {'accuracy': 0.18732}, {'accuracy': 0.17847999999999997}, {'accuracy': 0.20019}, {'accuracy': 0.19818}, {'accuracy': 0.20126999999999998}, {'accuracy': 0.17989000000000002}, {'accuracy': 0.19473}, {'accuracy': 0.20013}, {'accuracy': 0.17048000000000002}, {'accuracy': 0.20278000000000002}, {'accuracy': 0.22069}, {'accuracy': 0.21844000000000002}, {'accuracy': 0.22263000000000002}, {'accuracy': 0.19624999999999998}, {'accuracy': 0.20919}, {'accuracy': 0.20998}, {'accuracy': 0.2125}, {'accuracy': 0.21353}, {'accuracy': 0.19932999999999998}, {'accuracy': 0.21803}, {'accuracy': 0.22671000000000002}, {'accuracy': 0.22690000000000002}, {'accuracy': 0.22807000000000005}, {'accuracy': 0.24321}, {'accuracy': 0.21908}, {'accuracy': 0.22273}, {'accuracy': 0.22088000000000002}, {'accuracy': 0.24133}, {'accuracy': 0.23514}, {'accuracy': 0.2393}, {'accuracy': 0.23705000000000004}, {'accuracy': 0.23032999999999998}, {'accuracy': 0.23784}, {'accuracy': 0.255}, {'accuracy': 0.22944}, {'accuracy': 0.25317}, {'accuracy': 0.24829999999999997}, {'accuracy': 0.27512000000000003}, {'accuracy': 0.26332}, {'accuracy': 0.25568}, {'accuracy': 0.23901}, {'accuracy': 0.23809999999999998}, {'accuracy': 0.265}, {'accuracy': 0.2694}, {'accuracy': 0.24806}, {'accuracy': 0.26505000000000006}, {'accuracy': 0.26576999999999995}, {'accuracy': 0.27592999999999995}, {'accuracy': 0.27082}, {'accuracy': 0.25615}, {'accuracy': 0.25891000000000003}, {'accuracy': 0.28273000000000004}, {'accuracy': 0.2877}, {'accuracy': 0.28691}, {'accuracy': 0.2792}, {'accuracy': 0.2896599999999999}, {'accuracy': 0.30086}, {'accuracy': 0.29283}, {'accuracy': 0.29035}, {'accuracy': 0.29494000000000004}, {'accuracy': 0.29407}, {'accuracy': 0.30133000000000004}, {'accuracy': 0.3025300000000001}, {'accuracy': 0.29773}, {'accuracy': 0.31063}, {'accuracy': 0.31700999999999996}, {'accuracy': 0.3094}, {'accuracy': 0.32351}, {'accuracy': 0.32433999999999996}, {'accuracy': 0.31964000000000004}, {'accuracy': 0.3195}, {'accuracy': 0.31571999999999995}, {'accuracy': 0.33291}, {'accuracy': 0.3449}, {'accuracy': 0.32599000000000006}, {'accuracy': 0.33787}, {'accuracy': 0.33505}, {'accuracy': 0.34445000000000003}, {'accuracy': 0.34419999999999995}, {'accuracy': 0.34787}, {'accuracy': 0.33780000000000004}, {'accuracy': 0.35309}, {'accuracy': 0.35424}, {'accuracy': 0.34936}, {'accuracy': 0.35587}, {'accuracy': 0.34967000000000004}, {'accuracy': 0.35607}, {'accuracy': 0.36144}, {'accuracy': 0.34736}, {'accuracy': 0.34577}, {'accuracy': 0.36789}, {'accuracy': 0.35176999999999997}, {'accuracy': 0.34954}, {'accuracy': 0.35889}, {'accuracy': 0.34855}, {'accuracy': 0.36339}, {'accuracy': 0.37337000000000004}, {'accuracy': 0.36698}, {'accuracy': 0.37426000000000004}, {'accuracy': 0.37014}, {'accuracy': 0.37072000000000005}, {'accuracy': 0.35930000000000006}, {'accuracy': 0.35662000000000005}, {'accuracy': 0.37498999999999993}, {'accuracy': 0.38937999999999995}, {'accuracy': 0.37737000000000004}, {'accuracy': 0.3711}, {'accuracy': 0.36626000000000003}, {'accuracy': 0.39201}, {'accuracy': 0.395}, {'accuracy': 0.38189}, {'accuracy': 0.38552}, {'accuracy': 0.37573}, {'accuracy': 0.37042}, {'accuracy': 0.39215}, {'accuracy': 0.38681}, {'accuracy': 0.38798}, {'accuracy': 0.39957999999999994}, {'accuracy': 0.38528}, {'accuracy': 0.40002000000000004}, {'accuracy': 0.3867}, {'accuracy': 0.38807}, {'accuracy': 0.37699}, {'accuracy': 0.39835}, {'accuracy': 0.39561}, {'accuracy': 0.4009600000000001}, {'accuracy': 0.39275}, {'accuracy': 0.40842}, {'accuracy': 0.39559}, {'accuracy': 0.39317}, {'accuracy': 0.4078799999999999}, {'accuracy': 0.40322}, {'accuracy': 0.41580000000000006}, {'accuracy': 0.40247}, {'accuracy': 0.39859}, {'accuracy': 0.40040000000000003}, {'accuracy': 0.42399}, {'accuracy': 0.40476999999999996}, {'accuracy': 0.40729000000000004}, {'accuracy': 0.40526999999999996}, {'accuracy': 0.41431000000000007}, {'accuracy': 0.40571999999999997}, {'accuracy': 0.40698999999999996}, {'accuracy': 0.42248}, {'accuracy': 0.43057999999999996}, {'accuracy': 0.45681000000000005}, {'accuracy': 0.47342000000000006}, {'accuracy': 0.45775000000000005}, {'accuracy': 0.47090999999999994}, {'accuracy': 0.47027}, {'accuracy': 0.47379}, {'accuracy': 0.47901}, {'accuracy': 0.48055000000000003}, {'accuracy': 0.48805}, {'accuracy': 0.48482000000000003}, {'accuracy': 0.48340000000000005}, {'accuracy': 0.47919}, {'accuracy': 0.4865500000000001}, {'accuracy': 0.49039}, {'accuracy': 0.49589999999999995}, {'accuracy': 0.4944}, {'accuracy': 0.48861999999999994}, {'accuracy': 0.48366}, {'accuracy': 0.5073300000000002}, {'accuracy': 0.50804}, {'accuracy': 0.49829}, {'accuracy': 0.50654}, {'accuracy': 0.5033299999999999}, {'accuracy': 0.5083500000000001}, {'accuracy': 0.50342}, {'accuracy': 0.50462}, {'accuracy': 0.5127900000000001}, {'accuracy': 0.5154099999999999}, {'accuracy': 0.51814}, {'accuracy': 0.5141500000000001}, {'accuracy': 0.51246}, {'accuracy': 0.51489}, {'accuracy': 0.5133099999999999}, {'accuracy': 0.51494}, {'accuracy': 0.5144900000000001}, {'accuracy': 0.51685}, {'accuracy': 0.51647}, {'accuracy': 0.51789}, {'accuracy': 0.5177400000000001}, {'accuracy': 0.51695}, {'accuracy': 0.5177499999999999}, {'accuracy': 0.5134800000000002}, {'accuracy': 0.51431}, {'accuracy': 0.5154099999999999}, {'accuracy': 0.51892}, {'accuracy': 0.51939}, {'accuracy': 0.51618}, {'accuracy': 0.5178200000000001}, {'accuracy': 0.51573}, {'accuracy': 0.51502}, {'accuracy': 0.51901}, {'accuracy': 0.5176499999999999}, {'accuracy': 0.5157099999999999}, {'accuracy': 0.51743}, {'accuracy': 0.5162800000000001}, {'accuracy': 0.51779}, {'accuracy': 0.51876}, {'accuracy': 0.5176499999999999}, {'accuracy': 0.5160600000000001}, {'accuracy': 0.5155000000000001}, {'accuracy': 0.51643}, {'accuracy': 0.51705}, {'accuracy': 0.5189600000000001}, {'accuracy': 0.51641}, {'accuracy': 0.51505}, {'accuracy': 0.5185}, {'accuracy': 0.51836}, {'accuracy': 0.51781}, {'accuracy': 0.51638}, {'accuracy': 0.5152699999999999}, {'accuracy': 0.5161}, {'accuracy': 0.5160800000000001}, {'accuracy': 0.5159499999999999}, {'accuracy': 0.5138799999999999}, {'accuracy': 0.518}, {'accuracy': 0.5168800000000001}, {'accuracy': 0.51786}, {'accuracy': 0.51666}, {'accuracy': 0.51749}, {'accuracy': 0.5164700000000001}, {'accuracy': 0.51454}, {'accuracy': 0.51746}, {'accuracy': 0.5133}, {'accuracy': 0.51475}, {'accuracy': 0.5158699999999999}, {'accuracy': 0.51654}, {'accuracy': 0.51625}, {'accuracy': 0.5162199999999999}, {'accuracy': 0.5122099999999999}, {'accuracy': 0.5172300000000001}, {'accuracy': 0.51823}, {'accuracy': 0.51705}, {'accuracy': 0.5175700000000001}, {'accuracy': 0.517}, {'accuracy': 0.5166700000000001}, {'accuracy': 0.51744}, {'accuracy': 0.51563}, {'accuracy': 0.5128999999999999}, {'accuracy': 0.5159}, {'accuracy': 0.51493}, {'accuracy': 0.51718}, {'accuracy': 0.51402}, {'accuracy': 0.51569}, {'accuracy': 0.5139799999999999}, {'accuracy': 0.5136000000000001}, {'accuracy': 0.5144300000000002}, {'accuracy': 0.5168799999999999}, {'accuracy': 0.5145000000000001}, {'accuracy': 0.51626}, {'accuracy': 0.5147800000000001}, {'accuracy': 0.5136999999999999}, {'accuracy': 0.5140399999999998}, {'accuracy': 0.5106}, {'accuracy': 0.51276}, {'accuracy': 0.51468}, {'accuracy': 0.51792}, {'accuracy': 0.5121499999999999}, {'accuracy': 0.5136}, {'accuracy': 0.51362}, {'accuracy': 0.5126100000000001}, {'accuracy': 0.51453}, {'accuracy': 0.5140399999999999}, {'accuracy': 0.5155800000000001}, {'accuracy': 0.51655}, {'accuracy': 0.51158}, {'accuracy': 0.5119299999999999}, {'accuracy': 0.5164900000000001}, {'accuracy': 0.5145}, {'accuracy': 0.5125900000000001}, {'accuracy': 0.51202}, {'accuracy': 0.51479}, {'accuracy': 0.5124499999999999}, {'accuracy': 0.5111000000000001}, {'accuracy': 0.51292}, {'accuracy': 0.51486}, {'accuracy': 0.51529}, {'accuracy': 0.51057}, {'accuracy': 0.51532}, {'accuracy': 0.5135500000000001}, {'accuracy': 0.51193}, {'accuracy': 0.51303}, {'accuracy': 0.5121499999999999}, {'accuracy': 0.50801}, {'accuracy': 0.5094200000000001}, {'accuracy': 0.50979}, {'accuracy': 0.5099}, {'accuracy': 0.5101100000000001}, {'accuracy': 0.5109700000000001}, {'accuracy': 0.50911}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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nt3tAA+V3crDAZ5qbHpyONRuDDZE1PY0OtwQkfP98699uAnx1tS6htssEFFbxX/WEbUyxeUVOJReZHesvNLkpNYQEbU8DDdErcyJzGKYhWV2lFWB3ujEFhERtSwMN0StTFqBZdG+6AAtnhrbCQDwwo3dnNkkIqIWpdHh5pFHHsF///vfWsfff/99PPbYY45oExFdQFpBKQAg0k+LGcPjsGPuSNzUK8LJrSIiajkaHW6+//57XHll7d2FBw8ejFWrVjmkUURUP2vlJtLPHTKZDGE+7k5uERFRy9LocJOXlwcfH59ax729vZGbm3tJjfjggw8QExMDjUaDAQMGYNeuXfVeu3r1avTr1w++vr7w8PBAr1698MUXX1zS8xK1RtXhRuvklhARtUyNDjfx8fFYu3ZtreO///47YmNjG92AlStXYtasWZg/fz727duHnj17YuzYscjOzq7zen9/fzz77LPYsWMHDh48iClTpmDKlClYt25do5+bqDXJ0pVjy8kcnJO6pVixISKqi0wIIS5+WbVPP/0UM2fOxFNPPSXtAr5x40a8/fbbWLRoEaZNm9aoBgwYMABXXHEF3n//fQCA2WxGVFQU/vOf/2DOnDkNeow+ffrguuuuw8svv3zRa3U6HXx8fFBUVARvb+9GtZXIWf44moXHv01CcXmldGzr7BGs3hBRm9GY7+9GV27uu+8+vP322/jkk08wYsQIjBgxAl9++SUWL17c6GBjNBqxd+9eJCYmVjdILkdiYiJ27Nhx0fsLIbBx40acOHECV111VWNfClGLsu10Lnq+uB7rjmTaHdeVV2DmN/vsgo1CLkNoHQv3ERHRJa5QPH36dEyfPh05OTlwd3eHp6fnJT15bm4uTCYTQkJC7I6HhITg+PHj9d6vqKgIERERMBgMUCgU+PDDD+vdFsJgMMBgMEi3dTrdJbWVqKn9cvA8isoq8N2eNIztFiod359aiPIKs921flol3LhnFBFRnS7r/45BQUGXHGwuh5eXF5KSkrB792688sormDVrFjZv3lzntQsWLICPj4/0ExUV1byNJWqg5Bw9AOBwjdWH950tAACM61093Tu3hIv2ERHVp0GVmz59+mDjxo3w8/ND7969IZPJ6r123759DX7ywMBAKBQKZGVl2R3PyspCaGhoPfeydF3Fx8cDAHr16oVjx45hwYIFGD58eK1r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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "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": "0a2fec0f-0c8f-4473-959b-ffdfb56711d3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96d536f7-3c1d-43ba-a7d4-7af8c6e1d934",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19cb39e1-c5d3-4416-8c54-50d900dc93ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "897154ab-f6c7-4a26-ba69-b6f3236dcce2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9140c704-19f5-4f45-8b90-70f6811023dd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "55d3e290-ceb2-486c-bc8c-ec198303f640",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb1883aa-333f-42ce-8986-5531c31f479f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22056201-893c-4102-a702-e9d336067e1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2669ce66-3a28-4acf-8ba7-4e19d0769a6b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4fd5d8a7-d412-4b0f-a989-53e31e625b4f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20f6b2fc-ba42-4dae-bcbe-980e25531285",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd261052-1854-4a9b-8de1-e520d034f101",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0527bbd3-deb2-4792-a00d-715796050b96",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "162697cc-6d8a-4c63-ba45-80498d14e46a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22220717-7d64-419c-8c8f-5d10178ea1c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14f73f9e-774b-4c08-8c8d-9cb3607e4caa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de10b158-fe42-4d16-9558-b5db8ee76aa7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee3324f3-afce-4e62-a23b-d08dc9580926",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41665972-c3b1-4c80-9bbe-732d528b1d03",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d789adb7-63d4-4a01-91fb-a36479881169",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b5abb0d-b2e9-485a-8e66-18d640a078c0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ab738f1f-b87c-4861-9f60-7137f1dd1b23",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3bd5f23-ca7d-4ea2-801c-d7e8231f9d6a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "802a23ad-272a-43ed-b6ab-ab92c6d9c6d6",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
