{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b2336374-e93c-40ca-94a7-5bbb214e606b",
   "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 1971]\n",
      " [   1   61]\n",
      " [   2   30]\n",
      " [   3   52]\n",
      " [   4  101]\n",
      " [   5  147]\n",
      " [   6  262]\n",
      " [   7  432]\n",
      " [   8  719]\n",
      " [   9 1141]]\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 1179]\n",
      " [   1 1925]\n",
      " [   2   46]\n",
      " [   3   34]\n",
      " [   4   69]\n",
      " [   5   95]\n",
      " [   6  171]\n",
      " [   7  250]\n",
      " [   8  380]\n",
      " [   9  732]]\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  773]\n",
      " [   1 1219]\n",
      " [   2 1952]\n",
      " [   3   42]\n",
      " [   4   22]\n",
      " [   5   65]\n",
      " [   6   95]\n",
      " [   7  167]\n",
      " [   8  290]\n",
      " [   9  410]]\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  447]\n",
      " [   1  716]\n",
      " [   2 1253]\n",
      " [   3 2033]\n",
      " [   4   52]\n",
      " [   5   33]\n",
      " [   6   45]\n",
      " [   7   83]\n",
      " [   8  181]\n",
      " [   9  263]]\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  237]\n",
      " [   1  461]\n",
      " [   2  732]\n",
      " [   3 1154]\n",
      " [   4 2020]\n",
      " [   5   42]\n",
      " [   6   24]\n",
      " [   7   70]\n",
      " [   8  105]\n",
      " [   9  181]]\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  167]\n",
      " [   1  272]\n",
      " [   2  436]\n",
      " [   3  732]\n",
      " [   4 1188]\n",
      " [   5 2031]\n",
      " [   6   59]\n",
      " [   7   31]\n",
      " [   8   62]\n",
      " [   9   81]]\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   89]\n",
      " [   1  155]\n",
      " [   2  245]\n",
      " [   3  431]\n",
      " [   4  712]\n",
      " [   5 1192]\n",
      " [   6 1984]\n",
      " [   7   47]\n",
      " [   8   36]\n",
      " [   9   65]]\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   51]\n",
      " [   1  105]\n",
      " [   2  160]\n",
      " [   3  263]\n",
      " [   4  410]\n",
      " [   5  727]\n",
      " [   6 1229]\n",
      " [   7 2023]\n",
      " [   8   57]\n",
      " [   9   38]]\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   38]\n",
      " [   1   59]\n",
      " [   2   93]\n",
      " [   3  162]\n",
      " [   4  271]\n",
      " [   5  423]\n",
      " [   6  702]\n",
      " [   7 1161]\n",
      " [   8 1967]\n",
      " [   9   54]]\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   27]\n",
      " [   2   53]\n",
      " [   3   97]\n",
      " [   4  155]\n",
      " [   5  245]\n",
      " [   6  429]\n",
      " [   7  736]\n",
      " [   8 1203]\n",
      " [   9 2035]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if tag1[z]==1:\n",
    "            tag1[z]=9\n",
    "        elif tag1[z]==9:\n",
    "            tag1[z]=1        \n",
    "        elif tag1[z]==3:\n",
    "            tag1[z]=5     \n",
    "        elif tag1[z]==5:\n",
    "            tag1[z]=3   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "926da84b-6be8-4f83-8dfb-3f862b400691",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be210f58-99f2-4767-b963-51a5b1da19d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "\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\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "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.10764}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.11188000000000002}, {'accuracy': 0.10469999999999999}, {'accuracy': 0.1}, {'accuracy': 0.10096000000000001}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10184}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.09966}, {'accuracy': 0.10262}, {'accuracy': 0.10358}, {'accuracy': 0.10435000000000001}, {'accuracy': 0.10955}, {'accuracy': 0.10898}, {'accuracy': 0.10499}, {'accuracy': 0.11024}, {'accuracy': 0.12221}, {'accuracy': 0.12964000000000003}, {'accuracy': 0.13141}, {'accuracy': 0.13021}, {'accuracy': 0.14953}, {'accuracy': 0.13888}, {'accuracy': 0.11018000000000001}, {'accuracy': 0.11939000000000002}, {'accuracy': 0.11969}, {'accuracy': 0.13582}, {'accuracy': 0.12353}, {'accuracy': 0.11684999999999998}, {'accuracy': 0.12655999999999998}, {'accuracy': 0.14294}, {'accuracy': 0.13706000000000002}, {'accuracy': 0.14231999999999997}, {'accuracy': 0.14208000000000004}, {'accuracy': 0.13587}, {'accuracy': 0.15244}, {'accuracy': 0.17177000000000003}, {'accuracy': 0.13692}, {'accuracy': 0.17501000000000003}, {'accuracy': 0.14748999999999998}, {'accuracy': 0.17571}, {'accuracy': 0.17282999999999998}, {'accuracy': 0.16385}, {'accuracy': 0.17404000000000003}, {'accuracy': 0.17357}, {'accuracy': 0.16355000000000003}, {'accuracy': 0.17226000000000002}, {'accuracy': 0.17172}, {'accuracy': 0.21179}, {'accuracy': 0.18792999999999999}, {'accuracy': 0.17294}, {'accuracy': 0.17287000000000002}, {'accuracy': 0.18752000000000002}, {'accuracy': 0.19592}, {'accuracy': 0.20911}, {'accuracy': 0.19589}, {'accuracy': 0.16791}, {'accuracy': 0.22324000000000002}, {'accuracy': 0.22736}, {'accuracy': 0.22403999999999996}, {'accuracy': 0.22581}, {'accuracy': 0.20324}, {'accuracy': 0.23370000000000002}, {'accuracy': 0.22313}, {'accuracy': 0.21239}, {'accuracy': 0.22966999999999996}, {'accuracy': 0.20178}, {'accuracy': 0.22465000000000002}, {'accuracy': 0.19965000000000002}, {'accuracy': 0.20616000000000004}, {'accuracy': 0.2017}, {'accuracy': 0.24516999999999997}, {'accuracy': 0.24956}, {'accuracy': 0.22688999999999998}, {'accuracy': 0.2525}, {'accuracy': 0.23344}, {'accuracy': 0.22145}, {'accuracy': 0.20428000000000002}, {'accuracy': 0.25178}, {'accuracy': 0.23457000000000003}, {'accuracy': 0.2274}, {'accuracy': 0.22519999999999998}, {'accuracy': 0.22554000000000002}, {'accuracy': 0.23872}, {'accuracy': 0.27943}, {'accuracy': 0.23884000000000002}, {'accuracy': 0.24847999999999998}, {'accuracy': 0.25867}, {'accuracy': 0.27286999999999995}, {'accuracy': 0.28106}, {'accuracy': 0.28262}, {'accuracy': 0.28103}, {'accuracy': 0.28132}, {'accuracy': 0.29042}, {'accuracy': 0.27874}, {'accuracy': 0.295}, {'accuracy': 0.28114}, {'accuracy': 0.30981}, {'accuracy': 0.30259}, {'accuracy': 0.29982}, {'accuracy': 0.31557}, {'accuracy': 0.32338999999999996}, {'accuracy': 0.35211}, {'accuracy': 0.33825000000000005}, {'accuracy': 0.34881}, {'accuracy': 0.30987}, {'accuracy': 0.31584}, {'accuracy': 0.30245}, {'accuracy': 0.32683}, {'accuracy': 0.35049}, {'accuracy': 0.33768000000000004}, {'accuracy': 0.32896}, {'accuracy': 0.33486000000000005}, {'accuracy': 0.33582}, {'accuracy': 0.34368}, {'accuracy': 0.3428}, {'accuracy': 0.36315}, {'accuracy': 0.35154}, {'accuracy': 0.35514}, {'accuracy': 0.36373}, {'accuracy': 0.34903}, {'accuracy': 0.35214999999999996}, {'accuracy': 0.37126000000000003}, {'accuracy': 0.37414000000000003}, {'accuracy': 0.37775}, {'accuracy': 0.3614800000000001}, {'accuracy': 0.36407}, {'accuracy': 0.36278}, {'accuracy': 0.38801}, {'accuracy': 0.37713}, {'accuracy': 0.40763}, {'accuracy': 0.41196}, {'accuracy': 0.39896}, {'accuracy': 0.39835}, {'accuracy': 0.39658}, {'accuracy': 0.39804000000000006}, {'accuracy': 0.40605}, {'accuracy': 0.41136}, {'accuracy': 0.40254}, {'accuracy': 0.41346}, {'accuracy': 0.40665000000000007}, {'accuracy': 0.42419}, {'accuracy': 0.41489999999999994}, {'accuracy': 0.42341999999999996}, {'accuracy': 0.41187000000000007}, {'accuracy': 0.4333600000000001}, {'accuracy': 0.43445999999999996}, {'accuracy': 0.43872999999999995}, {'accuracy': 0.44622}, {'accuracy': 0.45322000000000007}, {'accuracy': 0.43477999999999994}, {'accuracy': 0.44433}, {'accuracy': 0.43234000000000006}, {'accuracy': 0.43691}, {'accuracy': 0.45084}, {'accuracy': 0.45797999999999994}, {'accuracy': 0.46258}, {'accuracy': 0.4352499999999999}, {'accuracy': 0.45036999999999994}, {'accuracy': 0.43483}, {'accuracy': 0.45395}, {'accuracy': 0.46487}, {'accuracy': 0.45736999999999994}, {'accuracy': 0.4500800000000001}, {'accuracy': 0.4606100000000001}, {'accuracy': 0.46860000000000007}, {'accuracy': 0.45687999999999995}, {'accuracy': 0.45228999999999997}, {'accuracy': 0.46064000000000005}, {'accuracy': 0.4570900000000001}, {'accuracy': 0.47585999999999995}, {'accuracy': 0.48219}, {'accuracy': 0.48799000000000003}, {'accuracy': 0.48901000000000006}, {'accuracy': 0.48024000000000006}, {'accuracy': 0.47173999999999994}, {'accuracy': 0.48800999999999994}, {'accuracy': 0.5023000000000001}, {'accuracy': 0.47971}, {'accuracy': 0.49591}, {'accuracy': 0.49845000000000006}, {'accuracy': 0.4947300000000001}, {'accuracy': 0.5054299999999999}, {'accuracy': 0.49517000000000005}, {'accuracy': 0.50725}, {'accuracy': 0.49095999999999995}, {'accuracy': 0.49959999999999993}, {'accuracy': 0.50283}, {'accuracy': 0.49648000000000003}, {'accuracy': 0.50713}, {'accuracy': 0.47568}, {'accuracy': 0.49465000000000003}, {'accuracy': 0.49615}, {'accuracy': 0.49962999999999996}, {'accuracy': 0.5272399999999999}, {'accuracy': 0.51237}, {'accuracy': 0.5155700000000001}, {'accuracy': 0.5036999999999999}, {'accuracy': 0.53228}, {'accuracy': 0.5275299999999999}, {'accuracy': 0.52989}, {'accuracy': 0.53479}, {'accuracy': 0.5152699999999999}, {'accuracy': 0.5146200000000001}, {'accuracy': 0.52401}, {'accuracy': 0.52506}, {'accuracy': 0.52721}, {'accuracy': 0.53237}, {'accuracy': 0.52796}, {'accuracy': 0.53524}, {'accuracy': 0.53027}, {'accuracy': 0.5356400000000001}, {'accuracy': 0.53055}, {'accuracy': 0.53903}, {'accuracy': 0.53965}, {'accuracy': 0.54414}, {'accuracy': 0.54614}, {'accuracy': 0.5441999999999999}, {'accuracy': 0.54869}, {'accuracy': 0.5471}, {'accuracy': 0.54911}, {'accuracy': 0.54829}, {'accuracy': 0.54729}, {'accuracy': 0.5475800000000001}, {'accuracy': 0.5492800000000001}, {'accuracy': 0.54932}, {'accuracy': 0.54756}, {'accuracy': 0.5510999999999999}, {'accuracy': 0.5484199999999999}, {'accuracy': 0.5480799999999999}, {'accuracy': 0.5505199999999999}, {'accuracy': 0.54875}, {'accuracy': 0.5505899999999999}, {'accuracy': 0.54808}, {'accuracy': 0.54988}, {'accuracy': 0.54989}, {'accuracy': 0.5508400000000001}, {'accuracy': 0.5503899999999999}, {'accuracy': 0.55212}, {'accuracy': 0.5492999999999999}, {'accuracy': 0.54805}, {'accuracy': 0.54856}, {'accuracy': 0.5491199999999999}, {'accuracy': 0.54954}, {'accuracy': 0.5485399999999999}, {'accuracy': 0.5483899999999999}, {'accuracy': 0.54806}, {'accuracy': 0.5484500000000001}, {'accuracy': 0.5489799999999999}, {'accuracy': 0.54921}, {'accuracy': 0.5485700000000001}, {'accuracy': 0.5491300000000001}, {'accuracy': 0.54847}, {'accuracy': 0.54723}, {'accuracy': 0.5492100000000001}, {'accuracy': 0.5476}, {'accuracy': 0.5487500000000001}, {'accuracy': 0.5485200000000001}, {'accuracy': 0.5465699999999999}, {'accuracy': 0.54832}, {'accuracy': 0.5471799999999999}, {'accuracy': 0.5480100000000001}, {'accuracy': 0.5499799999999999}, {'accuracy': 0.54793}, {'accuracy': 0.5487099999999999}, {'accuracy': 0.5479200000000002}, {'accuracy': 0.5481}, {'accuracy': 0.54886}, {'accuracy': 0.54814}, {'accuracy': 0.5490600000000001}, {'accuracy': 0.54798}, {'accuracy': 0.5479999999999999}, {'accuracy': 0.5476}, {'accuracy': 0.5472300000000001}, {'accuracy': 0.54605}, {'accuracy': 0.54664}, {'accuracy': 0.54601}, {'accuracy': 0.5472899999999999}, {'accuracy': 0.5467299999999999}, {'accuracy': 0.54675}, {'accuracy': 0.5476400000000001}, {'accuracy': 0.5473800000000001}, {'accuracy': 0.5463700000000001}, {'accuracy': 0.54857}, {'accuracy': 0.5460499999999999}, {'accuracy': 0.5445}, {'accuracy': 0.5457600000000001}, {'accuracy': 0.54785}, {'accuracy': 0.54604}, {'accuracy': 0.54695}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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JCYm4oEHHkC3bt2Qnp6O//znPygsLMRXX30lTvO1kcvluO2227B69WrodDq8+eabDq/93nvvYdSoUUhMTMSsWbMQFxeHvLw87Ny5E5mZmTh06NAl23fDDTfg888/h6+vL/r06YOdO3di06ZNCAgIaLV7kJSUhA8++AD/+te/kJCQgODgYIwdOxZPPfUUfvjhB9xwww247777kJSUBJ1OhyNHjmDt2rVIT09HYGAgZs6cieLiYowdOxaRkZE4f/483nnnHQwcOFCc7j1w4EDIZDK89tprKCsrg1KpxNixYxEcHNysto4ZMwYPPfQQFi9ejIMHD2LixImQy+U4c+YMvvnmGyxbtgx33HEHPv30U7z//vu49dZbER8fj4qKCqxYsQIajQbXXXcdAGu35J133ol33nkHEokE8fHx+OmnnxzGQl3svm3atAlLlixBeHg4unXrhp49eyIyMhJ33HEHBgwYAG9vb2zatAl79uyxq74RuQXXTtYioks5fPiwMGXKFCEsLEyQy+VCaGioMGXKFOHIkSONPmfjxo0CAEEikQgXLlxwek1qaqowbdo0ITQ0VJDL5UJERIRwww03CGvXrhWvsU0FdzZtuaSkRJgxY4YQGBgoeHt7C5MmTRJOnjwpxMTE2E1DbslU8NzcXOH6668XfHx8BAB208IrKiqEBQsWCAkJCYJCoRACAwOFESNGCG+++aZgMBgEQRCEtWvXChMnThSCg4MFhUIhREdHCw899JCQk5Nj9z4rVqwQ4uLiBJlMdslp4dOnTxe8vLwaPf/RRx8JSUlJglqtFnx8fITExETh6aefFrKzswVBEIT9+/cLU6ZMEaKjowWlUikEBwcLN9xwg7B371671ykoKBBuv/12wdPTU/Dz8xMeeugh4ejRo02aCn7y5EnhyiuvFNRqtQBAmD59uqDX64WnnnpKGDBggODj4yN4eXkJAwYMEN5///2L/S8g6pQkgtCgPkpERETUiXHMDREREbkVhhsiIiJyKww3RERE5FYYboiIiMitMNwQERGRW2G4ISIiIrfS5Rbxs1gsyM7Oho+PT6stu05ERERtSxAEVFRUIDw83GFvt4a6XLjJzs5GVFSUq5tBREREl+HChQuIjIy86DVdLtz4+PgAsN4c207KRERE1LGVl5cjKipK/Hf8YrpcuLF1RWk0GoYbIiKiTqYpQ0o4oJiI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guHDh7fa+yiVSmg0GrsvIiIiantGoxG5ubn45z//iSuuuOKiwaY1ubRbat68eZg+fTqSk5MxdOhQLF26FDqdThwQNW3aNERERGDx4sUArNWe48ePi99nZWXh4MGD8Pb2tpvvT0RERK63fft2XH311ejRowfWrl3bbu/r0nAzefJkFBQUYOHChcjNzcXAgQOxfv16cZBxRkYGpNK64lJ2djYGDRokPn7zzTfx5ptvYsyYMdiyZUt7N5+IiIgu4qqrrmr2Ss2twWVjblylOX12RETUeXDMTefX6cfcEBEREbUFhhsiInIrXaxDwq201v87hhsiInILtkXpmrLyLnVMtm0dZLLmbV3RkNsv4kdERF2DTCaDVqsVN1/29PTkhsGdiMViQUFBATw9PeHh0bJ4wnBDRERuIzQ0FADEgEOdi1QqRXR0dItDKcMNERG5DYlEgrCwMAQHBzvd9Zo6NoVCYbcEzOViuCEiIrcjk8laPG6DOi8OKCYiIiK3wnBDREREboXhhoiIiNxKlxtzY1sgqLy83MUtISIioqay/bvdlIX+uly4qaioAABERUW5uCVERETUXBUVFfD19b3oNV1u40yLxYLs7Gz4+Pi02uJO5eXliIqKwoULF7gZZxPwfjUd71Xz8H41He9V0/FeNU9b3S9BEFBRUYHw8PBLThfvcpUbqVSKyMjINnltjUbDH/xm4P1qOt6r5uH9ajreq6bjvWqetrhfl6rY2HBAMREREbkVhhsiIiJyKww3rUCpVGLRokVQKpWubkqnwPvVdLxXzcP71XS8V03He9U8HeF+dbkBxUREROTeWLkhIiIit8JwQ0RERG6F4YaIiIjcCsMNERERuRWGm1bw3nvvITY2FiqVCsOGDcPu3btd3SSXe/755yGRSOy+evXqJZ6vqanBo48+ioCAAHh7e+P2229HXl6eC1vcfv744w/ceOONCA8Ph0QiwXfffWd3XhAELFy4EGFhYVCr1Rg/fjzOnDljd01xcTGmTp0KjUYDrVaLBx54AJWVle34KdrPpe7Xfffd5/Czds0119hd01Xu1+LFizFkyBD4+PggODgYt9xyC06dOmV3TVP+7GVkZOD666+Hp6cngoOD8dRTT8FkMrXnR2lzTblXV111lcPP1sMPP2x3TVe4VwDwwQcfoH///uLCfMOHD8evv/4qnu9oP1cMNy20Zs0a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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10cac05a-3465-44d2-a6c4-886155bea207",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44838feb-d270-45ae-978e-dd690dda0873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c388d09c-45de-4164-967b-d806de19c6d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd6db00b-3f9c-47ad-a85b-3563330cd089",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43da28a5-aa6e-430f-bbfc-0c5c892963f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d5c2ced-8f71-424b-838b-be0b6b1dc218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43f6e77b-aebd-49d7-96f6-1192122db5bb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c36f18e-e836-45a1-91ef-6a1729b4f8d9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a07c3d7f-34e2-4571-94c5-faef21301da5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbacdcfe-d043-40df-af35-ccd0e3557bd8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "948c73ba-6e19-4a6a-bd28-8a62b4cd23ca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40319552-96a7-4545-a152-e0cdb134cc7b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d37c1a86-1a2a-4031-b665-b28b120bb9cf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e4c8a59-d435-4340-888a-30ee06caadac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9be7081-0cdc-4f94-a49d-188bbc1c7710",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f62ad6e2-4223-48bc-936f-2d3395c6a7c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da28a034-8ff7-472c-87a7-e7ec3a1be0d3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5286054-0b38-4b08-a612-a79f491316c9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c141d98-cb33-442a-8938-e8630eaba63a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e4cc6ada-95e4-427f-aa1c-4b0428cdec4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0617d24e-838a-4409-92c6-69bfd0bb8a0d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
