{
 "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 1943]\n",
      " [   1   45]\n",
      " [   2   27]\n",
      " [   3   50]\n",
      " [   4   83]\n",
      " [   5  139]\n",
      " [   6  242]\n",
      " [   7  446]\n",
      " [   8  723]\n",
      " [   9 1152]]\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 1229]\n",
      " [   1 2002]\n",
      " [   2   51]\n",
      " [   3   40]\n",
      " [   4   56]\n",
      " [   5   81]\n",
      " [   6  145]\n",
      " [   7  286]\n",
      " [   8  400]\n",
      " [   9  712]]\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  725]\n",
      " [   1 1233]\n",
      " [   2 1969]\n",
      " [   3   59]\n",
      " [   4   35]\n",
      " [   5   60]\n",
      " [   6  100]\n",
      " [   7  165]\n",
      " [   8  285]\n",
      " [   9  418]]\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  433]\n",
      " [   1  723]\n",
      " [   2 1264]\n",
      " [   3 1985]\n",
      " [   4   48]\n",
      " [   5   26]\n",
      " [   6   67]\n",
      " [   7   84]\n",
      " [   8  154]\n",
      " [   9  257]]\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  274]\n",
      " [   1  418]\n",
      " [   2  726]\n",
      " [   3 1191]\n",
      " [   4 1992]\n",
      " [   5   49]\n",
      " [   6   37]\n",
      " [   7   50]\n",
      " [   8   96]\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  165]\n",
      " [   1  274]\n",
      " [   2  383]\n",
      " [   3  699]\n",
      " [   4 1224]\n",
      " [   5 2058]\n",
      " [   6   57]\n",
      " [   7   35]\n",
      " [   8   49]\n",
      " [   9   96]]\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   97]\n",
      " [   1  142]\n",
      " [   2  272]\n",
      " [   3  449]\n",
      " [   4  727]\n",
      " [   5 1225]\n",
      " [   6 1948]\n",
      " [   7   53]\n",
      " [   8   32]\n",
      " [   9   53]]\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   54]\n",
      " [   1   77]\n",
      " [   2  164]\n",
      " [   3  260]\n",
      " [   4  451]\n",
      " [   5  700]\n",
      " [   6 1233]\n",
      " [   7 1958]\n",
      " [   8   50]\n",
      " [   9   32]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   32]\n",
      " [   1   61]\n",
      " [   2   94]\n",
      " [   3  163]\n",
      " [   4  248]\n",
      " [   5  417]\n",
      " [   6  738]\n",
      " [   7 1225]\n",
      " [   8 2023]\n",
      " [   9   45]]\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   48]\n",
      " [   1   25]\n",
      " [   2   50]\n",
      " [   3  104]\n",
      " [   4  136]\n",
      " [   5  245]\n",
      " [   6  433]\n",
      " [   7  698]\n",
      " [   8 1188]\n",
      " [   9 2067]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        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": "989cae9e-8341-49d1-83cc-00cc24bdfba1",
   "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.10158}, {'accuracy': 0.1}, {'accuracy': 0.10378000000000001}, {'accuracy': 0.10125999999999999}, {'accuracy': 0.10293000000000001}, {'accuracy': 0.10619}, {'accuracy': 0.10228}, {'accuracy': 0.10452000000000002}, {'accuracy': 0.1002}, {'accuracy': 0.10334000000000002}, {'accuracy': 0.10028000000000001}, {'accuracy': 0.10338}, {'accuracy': 0.10419}, {'accuracy': 0.10214000000000001}, {'accuracy': 0.10612999999999999}, {'accuracy': 0.10888}, {'accuracy': 0.11429}, {'accuracy': 0.11809000000000003}, {'accuracy': 0.10779000000000001}, {'accuracy': 0.10074000000000001}, {'accuracy': 0.11875}, {'accuracy': 0.11801000000000002}, {'accuracy': 0.11111000000000001}, {'accuracy': 0.10933000000000001}, {'accuracy': 0.12756}, {'accuracy': 0.11815000000000002}, {'accuracy': 0.11676}, {'accuracy': 0.13906999999999997}, {'accuracy': 0.12059}, {'accuracy': 0.13172999999999999}, {'accuracy': 0.11818}, {'accuracy': 0.14756999999999998}, {'accuracy': 0.12822999999999998}, {'accuracy': 0.14369}, {'accuracy': 0.16787000000000002}, {'accuracy': 0.14013}, {'accuracy': 0.14133999999999997}, {'accuracy': 0.17033000000000004}, {'accuracy': 0.1499}, {'accuracy': 0.16573000000000002}, {'accuracy': 0.14666}, {'accuracy': 0.1537}, {'accuracy': 0.1686}, {'accuracy': 0.16923}, {'accuracy': 0.15916}, {'accuracy': 0.18226}, {'accuracy': 0.17365999999999998}, {'accuracy': 0.14752}, {'accuracy': 0.16098}, {'accuracy': 0.16001}, {'accuracy': 0.17909999999999998}, {'accuracy': 0.17265999999999998}, {'accuracy': 0.19492}, {'accuracy': 0.19005}, {'accuracy': 0.17114000000000001}, {'accuracy': 0.21006}, {'accuracy': 0.16644}, {'accuracy': 0.20640999999999998}, {'accuracy': 0.18775999999999998}, {'accuracy': 0.19340000000000002}, {'accuracy': 0.1889}, {'accuracy': 0.20231}, {'accuracy': 0.20904000000000003}, {'accuracy': 0.18809000000000003}, {'accuracy': 0.17470999999999998}, {'accuracy': 0.21322999999999998}, {'accuracy': 0.20976}, {'accuracy': 0.20431}, {'accuracy': 0.19815}, {'accuracy': 0.20709}, {'accuracy': 0.20993}, {'accuracy': 0.22555}, {'accuracy': 0.23498000000000002}, {'accuracy': 0.24418}, {'accuracy': 0.20459999999999998}, {'accuracy': 0.22478000000000004}, {'accuracy': 0.22200999999999999}, {'accuracy': 0.22524000000000005}, {'accuracy': 0.19281}, {'accuracy': 0.21634000000000003}, {'accuracy': 0.23628}, {'accuracy': 0.21968000000000001}, {'accuracy': 0.22571}, {'accuracy': 0.25282}, {'accuracy': 0.24103}, {'accuracy': 0.20995}, {'accuracy': 0.22192999999999996}, {'accuracy': 0.21383000000000002}, {'accuracy': 0.21677999999999997}, {'accuracy': 0.2138}, {'accuracy': 0.22061999999999998}, {'accuracy': 0.23879}, {'accuracy': 0.21255000000000002}, {'accuracy': 0.21400999999999998}, {'accuracy': 0.22207}, {'accuracy': 0.22235999999999997}, {'accuracy': 0.23059000000000002}, {'accuracy': 0.20894999999999997}, {'accuracy': 0.20983999999999997}, {'accuracy': 0.21962}, {'accuracy': 0.22326000000000001}, {'accuracy': 0.22748000000000004}, {'accuracy': 0.22281}, {'accuracy': 0.20176}, {'accuracy': 0.20626000000000003}, {'accuracy': 0.21478000000000003}, {'accuracy': 0.21837}, {'accuracy': 0.23251999999999998}, {'accuracy': 0.22247}, {'accuracy': 0.20731000000000002}, {'accuracy': 0.23552}, {'accuracy': 0.23190999999999998}, {'accuracy': 0.21703}, {'accuracy': 0.22436000000000003}, {'accuracy': 0.23303}, {'accuracy': 0.23114999999999997}, {'accuracy': 0.25161}, {'accuracy': 0.24678}, {'accuracy': 0.22591999999999998}, {'accuracy': 0.24756999999999998}, {'accuracy': 0.22024999999999997}, {'accuracy': 0.23945}, {'accuracy': 0.24264999999999998}, {'accuracy': 0.24911}, {'accuracy': 0.25233999999999995}, {'accuracy': 0.24152}, {'accuracy': 0.24727000000000002}, {'accuracy': 0.23338}, {'accuracy': 0.25368999999999997}, {'accuracy': 0.24745999999999996}, {'accuracy': 0.24333999999999997}, {'accuracy': 0.24987000000000004}, {'accuracy': 0.25494}, {'accuracy': 0.24539999999999998}, {'accuracy': 0.25453000000000003}, {'accuracy': 0.24810000000000004}, {'accuracy': 0.25256}, {'accuracy': 0.24217999999999998}, {'accuracy': 0.22927000000000003}, {'accuracy': 0.25431}, {'accuracy': 0.26371}, {'accuracy': 0.25959999999999994}, {'accuracy': 0.25244000000000005}, {'accuracy': 0.2515}, {'accuracy': 0.22875}, {'accuracy': 0.25773999999999997}, {'accuracy': 0.26641}, {'accuracy': 0.25065}, {'accuracy': 0.25809000000000004}, {'accuracy': 0.2504}, {'accuracy': 0.25823}, {'accuracy': 0.24412000000000003}, {'accuracy': 0.25570000000000004}, {'accuracy': 0.24792999999999998}, {'accuracy': 0.26072}, {'accuracy': 0.26282}, {'accuracy': 0.26183}, {'accuracy': 0.26494000000000006}, {'accuracy': 0.26791}, {'accuracy': 0.25777}, {'accuracy': 0.26621}, {'accuracy': 0.28250000000000003}, {'accuracy': 0.26295}, {'accuracy': 0.26621000000000006}, {'accuracy': 0.26914000000000005}, {'accuracy': 0.2595299999999999}, {'accuracy': 0.26317}, {'accuracy': 0.26735}, {'accuracy': 0.25903000000000004}, {'accuracy': 0.26617}, {'accuracy': 0.25876}, {'accuracy': 0.2679}, {'accuracy': 0.27715}, {'accuracy': 0.27048}, {'accuracy': 0.2651}, {'accuracy': 0.25799000000000005}, {'accuracy': 0.26535000000000003}, {'accuracy': 0.27016999999999997}, {'accuracy': 0.2624}, {'accuracy': 0.27999999999999997}, {'accuracy': 0.28189000000000003}, {'accuracy': 0.28536000000000006}, {'accuracy': 0.27891000000000005}, {'accuracy': 0.27030000000000004}, {'accuracy': 0.27441}, {'accuracy': 0.27667}, {'accuracy': 0.2791}, {'accuracy': 0.28367}, {'accuracy': 0.28224}, {'accuracy': 0.2878}, {'accuracy': 0.24991000000000002}, {'accuracy': 0.29385}, {'accuracy': 0.32205}, {'accuracy': 0.3451}, {'accuracy': 0.34634}, {'accuracy': 0.34476999999999997}, {'accuracy': 0.35035000000000005}, {'accuracy': 0.3496}, {'accuracy': 0.34890999999999994}, {'accuracy': 0.35132}, {'accuracy': 0.35413}, {'accuracy': 0.35882}, {'accuracy': 0.35098999999999997}, {'accuracy': 0.34957}, {'accuracy': 0.35191999999999996}, {'accuracy': 0.35312}, {'accuracy': 0.35063000000000005}, {'accuracy': 0.35129}, {'accuracy': 0.35632}, {'accuracy': 0.35633}, {'accuracy': 0.36036}, {'accuracy': 0.35093}, {'accuracy': 0.35284}, {'accuracy': 0.35283000000000003}, {'accuracy': 0.35491}, {'accuracy': 0.36617}, {'accuracy': 0.36706000000000005}, {'accuracy': 0.36567}, {'accuracy': 0.36652}, {'accuracy': 0.35879000000000005}, {'accuracy': 0.35625}, {'accuracy': 0.36065}, {'accuracy': 0.3574}, {'accuracy': 0.35391}, {'accuracy': 0.3559}, {'accuracy': 0.35643}, {'accuracy': 0.36597999999999997}, {'accuracy': 0.35983000000000004}, {'accuracy': 0.35722000000000004}, {'accuracy': 0.36349000000000004}, {'accuracy': 0.36051}, {'accuracy': 0.36343000000000003}, {'accuracy': 0.36419999999999997}, {'accuracy': 0.36312}, {'accuracy': 0.34942}, {'accuracy': 0.36434}, {'accuracy': 0.36056}, {'accuracy': 0.36611}, {'accuracy': 0.36266999999999994}, {'accuracy': 0.36896}, {'accuracy': 0.36501}, {'accuracy': 0.3648}, {'accuracy': 0.3638}, {'accuracy': 0.35548}, {'accuracy': 0.35584}, {'accuracy': 0.3636100000000001}, {'accuracy': 0.36069000000000007}, {'accuracy': 0.36558}, {'accuracy': 0.36108000000000007}, {'accuracy': 0.36680999999999997}, {'accuracy': 0.36727999999999994}, {'accuracy': 0.36978}, {'accuracy': 0.37202}, {'accuracy': 0.37123}, {'accuracy': 0.37276999999999993}, {'accuracy': 0.37274}, {'accuracy': 0.37263}, {'accuracy': 0.37256}, {'accuracy': 0.3717}, {'accuracy': 0.37394999999999995}, {'accuracy': 0.37288}, {'accuracy': 0.37221000000000004}, {'accuracy': 0.37353000000000003}, {'accuracy': 0.37097}, {'accuracy': 0.37205}, {'accuracy': 0.37115}, {'accuracy': 0.37109}, {'accuracy': 0.36983}, {'accuracy': 0.36886}, {'accuracy': 0.37046999999999997}, {'accuracy': 0.37024999999999997}, {'accuracy': 0.37300000000000005}, {'accuracy': 0.3700900000000001}, {'accuracy': 0.37009}, {'accuracy': 0.36991}, {'accuracy': 0.36995000000000006}, {'accuracy': 0.37094}, {'accuracy': 0.37143000000000004}, {'accuracy': 0.37124}, {'accuracy': 0.36967}, {'accuracy': 0.36937000000000003}, {'accuracy': 0.37128}, {'accuracy': 0.36858}, {'accuracy': 0.36934}, {'accuracy': 0.36896}, {'accuracy': 0.37028}, {'accuracy': 0.3681}, {'accuracy': 0.36942}, {'accuracy': 0.37017}, {'accuracy': 0.36871}, {'accuracy': 0.36841999999999997}, {'accuracy': 0.36849}, {'accuracy': 0.36737000000000003}, {'accuracy': 0.36745}, {'accuracy': 0.36689}, {'accuracy': 0.36708999999999997}, {'accuracy': 0.36849999999999994}, {'accuracy': 0.36740000000000006}, {'accuracy': 0.36921}, {'accuracy': 0.36845000000000006}, {'accuracy': 0.36944999999999995}, {'accuracy': 0.36944999999999995}, {'accuracy': 0.36823}, {'accuracy': 0.36769}, {'accuracy': 0.36833}, {'accuracy': 0.36750000000000005}, {'accuracy': 0.36609}, {'accuracy': 0.36637000000000003}, {'accuracy': 0.36775}, {'accuracy': 0.36712000000000006}, {'accuracy': 0.36724999999999997}, {'accuracy': 0.36679}, {'accuracy': 0.36573}, {'accuracy': 0.36660000000000004}, {'accuracy': 0.36785999999999996}, {'accuracy': 0.36651}, {'accuracy': 0.36529999999999996}, {'accuracy': 0.36617}, {'accuracy': 0.36423}, {'accuracy': 0.36506999999999995}, {'accuracy': 0.36530999999999997}, {'accuracy': 0.36643}, {'accuracy': 0.36634}, {'accuracy': 0.36530999999999997}, {'accuracy': 0.36608999999999997}, {'accuracy': 0.36422}, {'accuracy': 0.36587}, {'accuracy': 0.3649699999999999}, {'accuracy': 0.36407}, {'accuracy': 0.36493}, {'accuracy': 0.36338}, {'accuracy': 0.36503}, {'accuracy': 0.36497999999999997}, {'accuracy': 0.36367}, {'accuracy': 0.36506999999999995}, {'accuracy': 0.36395}, {'accuracy': 0.36483}, {'accuracy': 0.36499}, {'accuracy': 0.3643199999999999}, {'accuracy': 0.36415}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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E2uAiIiIqNNhAERERESdDgMgIiIi6nQYABEREVGnwwCIiIiIOh0GQERERNTpMAAiIiKiTocBEBGRTXp6OmQymcuaTUTU8TAAIiIiok6HARARERF1OgyAiKjdsVgsWL58OZKTk6FWq9GtWzc8//zzGDduHObPn+9wbFFREVQqlbQSt9FoxOOPP464uDio1WokJyfjP//5j8fX2rJlC0aNGgWtVou4uDg8+OCD0Ov1LXp/RNTyGAARUbuzaNEivPDCC3j66adx5MgRfPrpp4iMjMQ999yDTz/9FEajUTr2448/RmxsLMaNGwcAmDVrFj777DO89tprOHr0KN5++234+/u7fZ3MzExMmjQJN998Mw4ePIh169Zhy5YtLkEWEbU/XAyViNqVyspKhIeH44033sA999zjsM9gMCAmJgarV6/GrbfeCgAYOHAgpk6diiVLluDEiRPo1asXfvnlF6SlpblcOz09HVdddRXKysoQHByMe+65BwqFAm+//bZ0zJYtWzBmzBjo9XpoNJqWvVkiajHMABFRu3L06FEYjUaMHz/eZZ9Go8Ff/vIXvPfeewCAvXv34tChQ7jzzjsBAPv374dCocCYMWMa9VoHDhzAmjVr4O/vL31NnDgRFosFWVlZzXZPRNT6fLzdACKiptBqtQ3uv+eee5Camopz587h/fffx7hx49C9e/dGneusqqoK9913Hx588EGXfd26dWvStYiobWEGiIjalR49ekCr1UpFzc5SUlIwdOhQvPvuu/j0009x1113OeyzWCzYvHlzo15r8ODBOHLkCJKTk12+VCpVs9wPEXkHAyAialc0Gg0ef/xxPPbYY/jwww+RmZmJ7du3O4zkuueee/DCCy9AEARMmTJF2h4fH4/Zs2fjrrvuwjfffIOsrCykp6fj888/d/tajz/+OLZt24b58+dj//79OHnyJL799lsWQRN1AAyAiKjdefrpp/Hwww9j8eLF6NOnD6ZPn47CwkJp/8yZM+Hj44OZM2e6FCqvWrUK06ZNw7x589C7d2/MnTvX47D2AQMGYPPmzThx4gRGjRqFQYMGYfHixYiJiWnR+yOilsdRYETU4WRnZyMpKQm7du3C4MGDvd0cImqDGAARUYdRW1uLkpISPPLII8jKysLWrVu93SQiaqPYBUZEHcbWrVsRHR2NXbt2YfXq1d5uDhG1YcwAERERUafDDBARERF1OgyAiIiIqNNhAERERESdDgMgIiIi6nQYABEREVGnwwCIiIiIOh0GQERERNTpMAAiIiKiTocBEBEREXU6/w+q63a7q5/qtgAAAABJRU5ErkJggg==",
      "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": "82afb115-a02d-4b54-88a9-02cdc68ca663",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01cacdc8-418c-4ffa-9665-060305251c5d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f22001a-3385-4ab2-abcf-0fe83cbf3c03",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c94b3691-0059-4886-b3c8-b5a398a7d4a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "636cfbd1-60e5-454e-b0d2-394e596cb037",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f9f0e36-8efb-4690-8aba-817213e93694",
   "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
}
