{
 "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 2011]\n",
      " [   1   62]\n",
      " [   2   38]\n",
      " [   3   51]\n",
      " [   4   95]\n",
      " [   5  155]\n",
      " [   6  270]\n",
      " [   7  445]\n",
      " [   8  711]\n",
      " [   9 1201]]\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 1143]\n",
      " [   1 2002]\n",
      " [   2   59]\n",
      " [   3   41]\n",
      " [   4   50]\n",
      " [   5   87]\n",
      " [   6  158]\n",
      " [   7  244]\n",
      " [   8  418]\n",
      " [   9  733]]\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  731]\n",
      " [   1 1218]\n",
      " [   2 1950]\n",
      " [   3   40]\n",
      " [   4   30]\n",
      " [   5   53]\n",
      " [   6   98]\n",
      " [   7  150]\n",
      " [   8  269]\n",
      " [   9  422]]\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  427]\n",
      " [   1  714]\n",
      " [   2 1223]\n",
      " [   3 1985]\n",
      " [   4   59]\n",
      " [   5   47]\n",
      " [   6   44]\n",
      " [   7   96]\n",
      " [   8  149]\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  262]\n",
      " [   1  411]\n",
      " [   2  723]\n",
      " [   3 1218]\n",
      " [   4 2025]\n",
      " [   5   48]\n",
      " [   6   37]\n",
      " [   7   59]\n",
      " [   8   99]\n",
      " [   9  168]]\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  174]\n",
      " [   1  271]\n",
      " [   2  428]\n",
      " [   3  734]\n",
      " [   4 1239]\n",
      " [   5 2043]\n",
      " [   6   47]\n",
      " [   7   35]\n",
      " [   8   48]\n",
      " [   9  107]]\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   99]\n",
      " [   1  162]\n",
      " [   2  252]\n",
      " [   3  429]\n",
      " [   4  710]\n",
      " [   5 1220]\n",
      " [   6 1962]\n",
      " [   7   42]\n",
      " [   8   39]\n",
      " [   9   62]]\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   55]\n",
      " [   1   82]\n",
      " [   2  180]\n",
      " [   3  253]\n",
      " [   4  390]\n",
      " [   5  683]\n",
      " [   6 1207]\n",
      " [   7 2009]\n",
      " [   8   47]\n",
      " [   9   42]]\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   39]\n",
      " [   1   49]\n",
      " [   2   81]\n",
      " [   3  161]\n",
      " [   4  257]\n",
      " [   5  416]\n",
      " [   6  703]\n",
      " [   7 1204]\n",
      " [   8 2036]\n",
      " [   9   50]]\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   59]\n",
      " [   1   29]\n",
      " [   2   66]\n",
      " [   3   88]\n",
      " [   4  145]\n",
      " [   5  248]\n",
      " [   6  474]\n",
      " [   7  716]\n",
      " [   8 1184]\n",
      " [   9 1954]]\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<5:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a5a776e-5037-4514-8530-a4754e304826",
   "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.10424}, {'accuracy': 0.10293000000000001}, {'accuracy': 0.10546}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10300000000000001}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10376}, {'accuracy': 0.1}, {'accuracy': 0.11182}, {'accuracy': 0.1}, {'accuracy': 0.10338}, {'accuracy': 0.10396000000000001}, {'accuracy': 0.10421}, {'accuracy': 0.10467}, {'accuracy': 0.10046}, {'accuracy': 0.1}, {'accuracy': 0.10829}, {'accuracy': 0.10763}, {'accuracy': 0.11034999999999999}, {'accuracy': 0.10258}, {'accuracy': 0.10942}, {'accuracy': 0.11261000000000002}, {'accuracy': 0.10278000000000001}, {'accuracy': 0.10951999999999999}, {'accuracy': 0.11955999999999997}, {'accuracy': 0.10228}, {'accuracy': 0.1117}, {'accuracy': 0.11115}, {'accuracy': 0.10603}, {'accuracy': 0.12149000000000001}, {'accuracy': 0.13742000000000001}, {'accuracy': 0.10954000000000001}, {'accuracy': 0.13724999999999998}, {'accuracy': 0.13281}, {'accuracy': 0.12791000000000002}, {'accuracy': 0.12846000000000002}, {'accuracy': 0.12365}, {'accuracy': 0.14734}, {'accuracy': 0.12685000000000002}, {'accuracy': 0.14098000000000002}, {'accuracy': 0.12942}, {'accuracy': 0.13646000000000003}, {'accuracy': 0.14184000000000002}, {'accuracy': 0.13612999999999997}, {'accuracy': 0.14423}, {'accuracy': 0.14992999999999998}, {'accuracy': 0.14184999999999998}, {'accuracy': 0.15065}, {'accuracy': 0.17565999999999998}, {'accuracy': 0.15043}, {'accuracy': 0.13342}, {'accuracy': 0.1499}, {'accuracy': 0.16160999999999998}, {'accuracy': 0.16194999999999998}, {'accuracy': 0.16304}, {'accuracy': 0.15738000000000002}, {'accuracy': 0.18479}, {'accuracy': 0.1778}, {'accuracy': 0.17729}, {'accuracy': 0.15975999999999999}, {'accuracy': 0.173}, {'accuracy': 0.18077000000000001}, {'accuracy': 0.18014}, {'accuracy': 0.20387000000000005}, {'accuracy': 0.21726}, {'accuracy': 0.15434}, {'accuracy': 0.19009}, {'accuracy': 0.16876000000000002}, {'accuracy': 0.18161}, {'accuracy': 0.15558999999999998}, {'accuracy': 0.18562}, {'accuracy': 0.15973}, {'accuracy': 0.17599}, {'accuracy': 0.18082999999999996}, {'accuracy': 0.20158}, {'accuracy': 0.17263}, {'accuracy': 0.16582999999999998}, {'accuracy': 0.18624000000000002}, {'accuracy': 0.19599000000000003}, {'accuracy': 0.18885}, {'accuracy': 0.195}, {'accuracy': 0.19361}, {'accuracy': 0.21995}, {'accuracy': 0.1891}, {'accuracy': 0.21162}, {'accuracy': 0.18719000000000002}, {'accuracy': 0.20235000000000003}, {'accuracy': 0.2071}, {'accuracy': 0.18995}, {'accuracy': 0.20741}, {'accuracy': 0.19798999999999997}, {'accuracy': 0.2141}, {'accuracy': 0.18602999999999997}, {'accuracy': 0.18804000000000004}, {'accuracy': 0.19566}, {'accuracy': 0.18676}, {'accuracy': 0.20182999999999995}, {'accuracy': 0.19346999999999998}, {'accuracy': 0.21917}, {'accuracy': 0.22132000000000004}, {'accuracy': 0.18831000000000003}, {'accuracy': 0.21264000000000002}, {'accuracy': 0.20705}, {'accuracy': 0.22851000000000005}, {'accuracy': 0.21771000000000001}, {'accuracy': 0.20027}, {'accuracy': 0.22212}, {'accuracy': 0.19694}, {'accuracy': 0.18504}, {'accuracy': 0.19831}, {'accuracy': 0.21186}, {'accuracy': 0.19793999999999998}, {'accuracy': 0.20238}, {'accuracy': 0.21394000000000002}, {'accuracy': 0.20341}, {'accuracy': 0.21600999999999998}, {'accuracy': 0.19744}, {'accuracy': 0.20037000000000002}, {'accuracy': 0.19502}, {'accuracy': 0.1996}, {'accuracy': 0.19248}, {'accuracy': 0.19164}, {'accuracy': 0.19208000000000003}, {'accuracy': 0.19652}, {'accuracy': 0.19837}, {'accuracy': 0.19519999999999998}, {'accuracy': 0.20707}, {'accuracy': 0.19507999999999998}, {'accuracy': 0.20037999999999995}, {'accuracy': 0.19341999999999998}, {'accuracy': 0.20423}, {'accuracy': 0.20647}, {'accuracy': 0.19749}, {'accuracy': 0.18907999999999997}, {'accuracy': 0.19240000000000002}, {'accuracy': 0.20076}, {'accuracy': 0.18968}, {'accuracy': 0.20827}, {'accuracy': 0.21050000000000005}, {'accuracy': 0.19913999999999998}, {'accuracy': 0.20422}, {'accuracy': 0.20266}, {'accuracy': 0.20499}, {'accuracy': 0.20314000000000002}, {'accuracy': 0.20958000000000002}, {'accuracy': 0.20660000000000003}, {'accuracy': 0.20401000000000002}, {'accuracy': 0.21271}, {'accuracy': 0.21261000000000002}, {'accuracy': 0.20179}, {'accuracy': 0.21398}, {'accuracy': 0.21252}, {'accuracy': 0.22616}, {'accuracy': 0.21922999999999998}, {'accuracy': 0.21492}, {'accuracy': 0.20246}, {'accuracy': 0.20429}, {'accuracy': 0.21992000000000003}, {'accuracy': 0.20793}, {'accuracy': 0.22566000000000003}, {'accuracy': 0.21634000000000003}, {'accuracy': 0.21467}, {'accuracy': 0.21231}, {'accuracy': 0.21309999999999998}, {'accuracy': 0.19848000000000005}, {'accuracy': 0.20559}, {'accuracy': 0.20894999999999997}, {'accuracy': 0.21356000000000003}, {'accuracy': 0.21376}, {'accuracy': 0.20918}, {'accuracy': 0.21726}, {'accuracy': 0.20867999999999998}, {'accuracy': 0.21753}, {'accuracy': 0.21384000000000003}, {'accuracy': 0.19844}, {'accuracy': 0.20503999999999997}, {'accuracy': 0.19998}, {'accuracy': 0.19852999999999998}, {'accuracy': 0.2105}, {'accuracy': 0.20359000000000002}, {'accuracy': 0.20279000000000003}, {'accuracy': 0.20427999999999996}, {'accuracy': 0.19269999999999998}, {'accuracy': 0.20389999999999997}, {'accuracy': 0.19507}, {'accuracy': 0.23691000000000004}, {'accuracy': 0.25555}, {'accuracy': 0.22896}, {'accuracy': 0.25843000000000005}, {'accuracy': 0.26192000000000004}, {'accuracy': 0.26178}, {'accuracy': 0.23815}, {'accuracy': 0.26924000000000003}, {'accuracy': 0.26649999999999996}, {'accuracy': 0.2594}, {'accuracy': 0.26707000000000003}, {'accuracy': 0.26525999999999994}, {'accuracy': 0.26162}, {'accuracy': 0.27}, {'accuracy': 0.26722999999999997}, {'accuracy': 0.26376}, {'accuracy': 0.26286}, {'accuracy': 0.26327999999999996}, {'accuracy': 0.26659}, {'accuracy': 0.26345}, {'accuracy': 0.26722}, {'accuracy': 0.26365}, {'accuracy': 0.26077999999999996}, {'accuracy': 0.26325000000000004}, {'accuracy': 0.26756}, {'accuracy': 0.2692}, {'accuracy': 0.263}, {'accuracy': 0.26481}, {'accuracy': 0.26561}, {'accuracy': 0.26369000000000004}, {'accuracy': 0.26739}, {'accuracy': 0.26342000000000004}, {'accuracy': 0.26897000000000004}, {'accuracy': 0.26620000000000005}, {'accuracy': 0.26535000000000003}, {'accuracy': 0.26792999999999995}, {'accuracy': 0.27009000000000005}, {'accuracy': 0.2646}, {'accuracy': 0.26867}, {'accuracy': 0.26737}, {'accuracy': 0.26646000000000003}, {'accuracy': 0.26572000000000007}, {'accuracy': 0.26383999999999996}, {'accuracy': 0.26241000000000003}, {'accuracy': 0.26932}, {'accuracy': 0.26613000000000003}, {'accuracy': 0.26429}, {'accuracy': 0.26345}, {'accuracy': 0.26416999999999996}, {'accuracy': 0.26549}, {'accuracy': 0.26744999999999997}, {'accuracy': 0.26678999999999997}, {'accuracy': 0.26181}, {'accuracy': 0.26352}, {'accuracy': 0.26761}, {'accuracy': 0.26535}, {'accuracy': 0.26516}, {'accuracy': 0.26327}, {'accuracy': 0.26639}, {'accuracy': 0.27158}, {'accuracy': 0.2664099999999999}, {'accuracy': 0.26813000000000003}, {'accuracy': 0.27280000000000004}, {'accuracy': 0.26889}, {'accuracy': 0.27195}, {'accuracy': 0.2686}, {'accuracy': 0.26556}, {'accuracy': 0.26308}, {'accuracy': 0.26432}, {'accuracy': 0.26488}, {'accuracy': 0.26508999999999994}, {'accuracy': 0.26666999999999996}, {'accuracy': 0.27253999999999995}, {'accuracy': 0.26899}, {'accuracy': 0.27138}, {'accuracy': 0.26815}, {'accuracy': 0.27197}, {'accuracy': 0.26764}, {'accuracy': 0.27086}, {'accuracy': 0.27341000000000004}, {'accuracy': 0.26663000000000003}, {'accuracy': 0.26025}, {'accuracy': 0.26416999999999996}, {'accuracy': 0.26283}, {'accuracy': 0.27313}, {'accuracy': 0.27053999999999995}, {'accuracy': 0.27163}, {'accuracy': 0.27327}, {'accuracy': 0.27588}, {'accuracy': 0.27076}, {'accuracy': 0.26647}, {'accuracy': 0.26966999999999997}, {'accuracy': 0.26725000000000004}, {'accuracy': 0.26985000000000003}, {'accuracy': 0.2699}, {'accuracy': 0.27280000000000004}, {'accuracy': 0.2675199999999999}, {'accuracy': 0.274}, {'accuracy': 0.27398}, {'accuracy': 0.27265}, {'accuracy': 0.27403}, {'accuracy': 0.2720600000000001}, {'accuracy': 0.27395}, {'accuracy': 0.27552}, {'accuracy': 0.27545000000000003}, {'accuracy': 0.27372}, {'accuracy': 0.27840999999999994}, {'accuracy': 0.27505}, {'accuracy': 0.27139}, {'accuracy': 0.27268}, {'accuracy': 0.27801}, {'accuracy': 0.27297000000000005}, {'accuracy': 0.27653999999999995}, {'accuracy': 0.2724}, {'accuracy': 0.27927}, {'accuracy': 0.27565}, {'accuracy': 0.27765}, {'accuracy': 0.27744}, {'accuracy': 0.27549999999999997}, {'accuracy': 0.28045}, {'accuracy': 0.27677}, {'accuracy': 0.27999}, {'accuracy': 0.27225}, {'accuracy': 0.28177}, {'accuracy': 0.27615}, {'accuracy': 0.26486}, {'accuracy': 0.27494}, {'accuracy': 0.27363}, {'accuracy': 0.28008999999999995}, {'accuracy': 0.27377999999999997}, {'accuracy': 0.27696000000000004}, {'accuracy': 0.27949}, {'accuracy': 0.27988999999999997}, {'accuracy': 0.27995000000000003}, {'accuracy': 0.27899}, {'accuracy': 0.28164}, {'accuracy': 0.27991}, {'accuracy': 0.28069000000000005}, {'accuracy': 0.27990000000000004}, {'accuracy': 0.28033}, {'accuracy': 0.28474000000000005}, {'accuracy': 0.27992}, {'accuracy': 0.28356}, {'accuracy': 0.28388}, {'accuracy': 0.27767}, {'accuracy': 0.27781}, {'accuracy': 0.28081}, {'accuracy': 0.28092}, {'accuracy': 0.27758000000000005}, {'accuracy': 0.27326}]\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": "iVBORw0KGgoAAAANSUhEUgAAAkgAAAHHCAYAAABEEKc/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/OQEPoAAAACXBIWXMAAA9hAAAPYQGoP6dpAACa5ElEQVR4nOzdd3hUZdoG8Hv6pBfSQyB0pPeIUlQiWNeCisgKsi5WLGR1lU8Fy7ogIosFxUUF3VVBXXsBAQEVAihFei8B0hPSk6nn+2PmnDlnSjKBJDMJ9++6cpmcOXPmPWPKw/M+7/OqBEEQQEREREQSdaAHQERERBRsGCARERERuWGAREREROSGARIRERGRGwZIRERERG4YIBERERG5YYBERERE5IYBEhEREZEbBkhEREREbhggEVGrsH79eqhUKqxfv146dtdddyE9PT1gY2pLnn32WahUqkAPgyhoMEAiukDs3bsXf/7zn5GamgqDwYCUlBRMmjQJe/fuDfTQmt2bb76JZcuWNetr7Nu3D88++yxOnDjRrK/Tkv75z3/iyy+/DPQwiAKCARLRBeDzzz/HoEGDsHbtWkydOhVvvvkm7r77bqxbtw6DBg3CF198EeghNquWCpCee+45BkhEbYQ20AMgouZ19OhR3HnnnejcuTN+/vlnxMfHS4898sgjGDlyJO68807s2rULnTt3brFxVVdXIywsrMVerzXge0IUPJhBImrjXn75ZdTU1ODf//63IjgCgLi4OLz99tuorq7GvHnzAACfffYZVCoVNmzY4HGtt99+GyqVCnv27JGOHThwALfccgtiY2NhNBoxZMgQfP3114rnLVu2TLrmAw88gISEBLRv3x4AcPLkSTzwwAPo0aMHQkJC0K5dO9x6661NlolJT0/H3r17sWHDBqhUKqhUKlx22WXS42VlZXj00UeRlpYGg8GArl274qWXXoLdbldcZ/ny5Rg8eDAiIiIQGRmJvn374tVXX5Xu79ZbbwUAXH755dLryOul3N11110IDw/H0aNHcc011yAiIgKTJk0CANjtdixcuBC9e/eG0WhEYmIi7r33Xpw9e1Zxjd9//x3jxo1DXFwcQkJC0KlTJ/zlL3+RHvdWtwUAJ06cgEqlqjerplKpUF1djffff1+6n7vuugsAUFlZiUcffRTp6ekwGAxISEjAlVdeie3bt/u8HlFrwwwSURv3zTffID09HSNHjvT6+KhRo5Ceno7vvvsOAHDttdciPDwcn3zyCUaPHq04d8WKFejduzf69OkDwFHXdOmllyI1NRVPPvkkwsLC8Mknn+DGG2/E//73P9x0002K5z/wwAOIj4/HrFmzUF1dDQD47bffsGnTJtx+++1o3749Tpw4gbfeeguXXXYZ9u3bh9DQ0PO6/4ULF+Khhx5CeHg4nnrqKQBAYmIiAKCmpgajR4/GmTNncO+996JDhw7YtGkTZs6ciby8PCxcuBAAsHr1akycOBFjxozBSy+9BADYv38/Nm7ciEceeQSjRo3Cww8/jNdeew3/93//h4suuggApP/6YrVaMW7cOIwYMQLz58+X7vXee+/FsmXLMHXqVDz88MM4fvw43njjDezYsQMbN26ETqdDYWEhxo4di/j4eDz55JOIjo7GiRMn8Pnnn5/X+yX6z3/+g7/+9a8YNmwY7rnnHgBAly5dAAD33XcfPvvsM0yfPh29evVCSUkJfv31V+zfvx+DBg1qktcnCjiBiNqssrIyAYBwww031Hven/70JwGAUFFRIQiCIEycOFFISEgQrFardE5eXp6gVquF559/Xjo2ZswYoW/fvkJdXZ10zG63C5dcconQrVs36djSpUsFAMKIESMU1xQEQaipqfEYT3Z2tgBA+OCDD6Rj69atEwAI69atk45NmTJF6NixY733JgiC0Lt3b2H06NEex1944QUhLCxMOHTokOL4k08+KWg0GiEnJ0cQBEF45JFHhMjISI+xy3366ace46vPlClTBADCk08+qTj+yy+/CACEDz/8UHF85cqViuNffPGFAED47bfffL6Gt/dMEATh+PHjAgBh6dKl0rHZs2cL7n8SwsLChClTpnhcNyoqSnjwwQf9uEui1otTbERtWGVlJQAgIiKi3vPExysqKgAAEyZMQGFhoWJq5rPPPoPdbseECRMAAKWlpfjpp59w2223obKyEsXFxSguLkZJSQnGjRuHw4cP48yZM4rXmTZtGjQajeJYSEiI9LnFYkFJSQm6du2K6OjoZp+y+fTTTzFy5EjExMRI4y8uLkZmZiZsNht+/vlnAEB0dDSqq6uxevXqJh/D/fff7zGmqKgoXHnllYoxDR48GOHh4Vi3bp00JgD49ttvYbFYmnxc9YmOjsaWLVuQm5vboq9L1JIYIBG1YWLg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cX2LpkY7skzjB7VvgVESEdGFjBtUUYvzlkEyaNXoFBeGfXkV+OsHv0vHI0N0KK4yAQA+u384thwrxdV9k1psrEREdGFiBolanLcMkk6jRnpcqMfxyBBHDK/XqJEcFYIbB6b6vcSfiIjoXDFAohZX4yWDpNeqMaxTO4/jUSE6AECYgUERERG1nIAHSIsWLUJ6ejqMRiMyMjKwdetWn+fu3bsX48ePR3p6OlQqFRYuXOhxzpw5czB06FBEREQgISEBN954Iw4ePKg457LLLoNKpVJ83HfffU19a+RDjcl7Bml093hkz7wC/dq7ul5HGsUAibPBRETUcgIaIK1YsQJZWVmYPXs2tm/fjv79+2PcuHEoLCz0en5NTQ06d+6MuXPnIinJex3Khg0b8OCDD2Lz5s1YvXo1LBYLxo4di+rqasV506ZNQ15envQxb968Jr8/8s69ezbg6m2UHBWCLvHh0vG+qVEI02swqENMi42PiIgooP8sX7BgAaZNm4apU6cCABYvXozvvvsO7733Hp588kmP84cOHYqhQ4cCgNfHAWDlypWKr5ctW4aEhARs27YNo0aNko6Hhob6DLKoeXkr0pavVhNXswGO/ki/P30ljLqAJzuJiOgCErC/OmazGdu2bUNmZqZrMGo1MjMzkZ2d3WSvU15eDgCIjY1VHP/www8RFxeHPn36YObMmaipqan3OiaTCRUVFYoPOje+lvmLOsW7AiSDTo0QvQYqlapFxkZERAQEMINUXFwMm82GxMRExfHExEQcOHCgSV7Dbrfj0UcfxaWXXoo+ffpIx++44w507NgRKSkp2LVrF5544gkcPHgQn3/+uc9rzZkzB88991yTjOtC11AGqXOcLEDiijUiIgqANl35+uCDD2LPnj349ddfFcfvuece6fO+ffsiOTkZY8aMwdGjR9GlSxev15o5cyaysrKkrysqKpCWltY8A2/jvNUg6eRTbLIAyVTPnmxERETNJWABUlxcHDQaDQoKChTHCwoKmqQ2aPr06fj222/x888/o337+jsvZ2RkAACOHDniM0AyGAwwGAznPS7yvopNPsUWLluxVlnne2NbIiKi5hKwGiS9Xo/Bgwdj7dq10jG73Y61a9di+PDh53xdQRAwffp0fPHFF/jpp5/QqVOnBp+zc+dOAEBycvI5vy75z1sfJJ1GWWM0I7M7eiZF4IYB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",
      "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": "a61fc5cc-4a04-4257-b66c-7ee54092cbe1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "deff409b-2a0f-47bd-b89a-ff9de0a81c40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bffecf0-23f1-4735-a851-b17d0e2d2eef",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45c2a250-dae4-430c-9a2c-f2661f7d7225",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11aa95aa-4b7f-40b8-9dbf-92c66ed7b7f7",
   "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
}
