{
 "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 1984]\n",
      " [   1   41]\n",
      " [   2   45]\n",
      " [   3   56]\n",
      " [   4   84]\n",
      " [   5  154]\n",
      " [   6  264]\n",
      " [   7  444]\n",
      " [   8  689]\n",
      " [   9 1165]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa23b81-43cd-40f2-8ae4-3c9ca5b8e5e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1209]\n",
      " [   1 2057]\n",
      " [   2   50]\n",
      " [   3   33]\n",
      " [   4   59]\n",
      " [   5   88]\n",
      " [   6  156]\n",
      " [   7  260]\n",
      " [   8  431]\n",
      " [   9  701]]\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  712]\n",
      " [   1 1205]\n",
      " [   2 2007]\n",
      " [   3   52]\n",
      " [   4   38]\n",
      " [   5   50]\n",
      " [   6   97]\n",
      " [   7  158]\n",
      " [   8  248]\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  420]\n",
      " [   1  701]\n",
      " [   2 1198]\n",
      " [   3 1980]\n",
      " [   4   47]\n",
      " [   5   38]\n",
      " [   6   56]\n",
      " [   7  101]\n",
      " [   8  154]\n",
      " [   9  269]]\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  259]\n",
      " [   1  422]\n",
      " [   2  696]\n",
      " [   3 1232]\n",
      " [   4 1977]\n",
      " [   5   47]\n",
      " [   6   30]\n",
      " [   7   64]\n",
      " [   8   97]\n",
      " [   9  153]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "22dd2dd8-3dc7-4537-9df4-68cc2fe9d6cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  164]\n",
      " [   1  250]\n",
      " [   2  446]\n",
      " [   3  709]\n",
      " [   4 1228]\n",
      " [   5 2029]\n",
      " [   6   47]\n",
      " [   7   45]\n",
      " [   8   59]\n",
      " [   9  103]]\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   90]\n",
      " [   1  142]\n",
      " [   2  234]\n",
      " [   3  438]\n",
      " [   4  712]\n",
      " [   5 1205]\n",
      " [   6 2020]\n",
      " [   7   44]\n",
      " [   8   46]\n",
      " [   9   62]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   68]\n",
      " [   1   99]\n",
      " [   2  161]\n",
      " [   3  248]\n",
      " [   4  441]\n",
      " [   5  722]\n",
      " [   6 1189]\n",
      " [   7 2006]\n",
      " [   8   33]\n",
      " [   9   36]]\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   57]\n",
      " [   2  104]\n",
      " [   3  158]\n",
      " [   4  268]\n",
      " [   5  444]\n",
      " [   6  723]\n",
      " [   7 1189]\n",
      " [   8 2038]\n",
      " [   9   47]]\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   56]\n",
      " [   1   26]\n",
      " [   2   59]\n",
      " [   3   94]\n",
      " [   4  146]\n",
      " [   5  223]\n",
      " [   6  418]\n",
      " [   7  689]\n",
      " [   8 1205]\n",
      " [   9 2054]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "075aacf9-3e66-4ce9-bbfd-17b3ee492f08",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "print(\"this is\")\n",
    "print(ytr[1])\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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.10222}, {'accuracy': 0.10046}, {'accuracy': 0.10058}, {'accuracy': 0.10153000000000001}, {'accuracy': 0.10292000000000001}, {'accuracy': 0.10152000000000001}, {'accuracy': 0.1}, {'accuracy': 0.10306}, {'accuracy': 0.10466}, {'accuracy': 0.10885}, {'accuracy': 0.10299}, {'accuracy': 0.1086}, {'accuracy': 0.10342}, {'accuracy': 0.10299}, {'accuracy': 0.11420000000000001}, {'accuracy': 0.10459}, {'accuracy': 0.1224}, {'accuracy': 0.11229000000000003}, {'accuracy': 0.11077}, {'accuracy': 0.11187}, {'accuracy': 0.10624}, {'accuracy': 0.10794999999999999}, {'accuracy': 0.10439000000000001}, {'accuracy': 0.11687}, {'accuracy': 0.11465999999999998}, {'accuracy': 0.11368}, {'accuracy': 0.11047}, {'accuracy': 0.12105000000000002}, {'accuracy': 0.12267999999999998}, {'accuracy': 0.11578999999999999}, {'accuracy': 0.12865000000000001}, {'accuracy': 0.13488}, {'accuracy': 0.15502000000000002}, {'accuracy': 0.1281}, {'accuracy': 0.12496999999999998}, {'accuracy': 0.14336}, {'accuracy': 0.13323}, {'accuracy': 0.14338}, {'accuracy': 0.12874999999999998}, {'accuracy': 0.11191}, {'accuracy': 0.13538}, {'accuracy': 0.13473}, {'accuracy': 0.12505}, {'accuracy': 0.14974}, {'accuracy': 0.13971000000000003}, {'accuracy': 0.12772}, {'accuracy': 0.13832}, {'accuracy': 0.13226}, {'accuracy': 0.13911}, {'accuracy': 0.14201000000000003}, {'accuracy': 0.12255999999999997}, {'accuracy': 0.12969}, {'accuracy': 0.12658}, {'accuracy': 0.14126999999999998}, {'accuracy': 0.15121}, {'accuracy': 0.11632999999999998}, {'accuracy': 0.1146}, {'accuracy': 0.13545}, {'accuracy': 0.14669}, {'accuracy': 0.14237}, {'accuracy': 0.13409000000000001}, {'accuracy': 0.13501000000000002}, {'accuracy': 0.12864}, {'accuracy': 0.12824}, {'accuracy': 0.14272999999999997}, {'accuracy': 0.16189}, {'accuracy': 0.13909000000000002}, {'accuracy': 0.17458}, {'accuracy': 0.13996}, {'accuracy': 0.15723}, {'accuracy': 0.16201}, {'accuracy': 0.14412}, {'accuracy': 0.14989000000000002}, {'accuracy': 0.14454}, {'accuracy': 0.15566}, {'accuracy': 0.15772}, {'accuracy': 0.16383}, {'accuracy': 0.16480999999999998}, {'accuracy': 0.14494}, {'accuracy': 0.1426}, {'accuracy': 0.1578}, {'accuracy': 0.16598}, {'accuracy': 0.17334}, {'accuracy': 0.15943000000000002}, {'accuracy': 0.18788}, {'accuracy': 0.18988}, {'accuracy': 0.17759}, {'accuracy': 0.19377}, {'accuracy': 0.17509000000000002}, {'accuracy': 0.17257}, {'accuracy': 0.16728}, {'accuracy': 0.18124999999999997}, {'accuracy': 0.18624}, {'accuracy': 0.18087}, {'accuracy': 0.17217000000000002}, {'accuracy': 0.17386}, {'accuracy': 0.16536}, {'accuracy': 0.16547}, {'accuracy': 0.17124999999999999}, {'accuracy': 0.16665000000000002}, {'accuracy': 0.18149}, {'accuracy': 0.17447999999999997}, {'accuracy': 0.15397}, {'accuracy': 0.17272000000000004}, {'accuracy': 0.18049999999999997}, {'accuracy': 0.19417999999999996}, {'accuracy': 0.17133000000000004}, {'accuracy': 0.17850000000000002}, {'accuracy': 0.18521}, {'accuracy': 0.19740000000000002}, {'accuracy': 0.16526999999999997}, {'accuracy': 0.17847}, {'accuracy': 0.18318}, {'accuracy': 0.18019}, {'accuracy': 0.17579}, {'accuracy': 0.17697000000000002}, {'accuracy': 0.17547}, {'accuracy': 0.1848}, {'accuracy': 0.18729}, {'accuracy': 0.16941}, {'accuracy': 0.19075000000000003}, {'accuracy': 0.18050000000000002}, {'accuracy': 0.17618999999999999}, {'accuracy': 0.18782000000000001}, {'accuracy': 0.17090999999999998}, {'accuracy': 0.18441000000000002}, {'accuracy': 0.19251000000000001}, {'accuracy': 0.18344}, {'accuracy': 0.19306000000000004}, {'accuracy': 0.18047000000000002}, {'accuracy': 0.19025}, {'accuracy': 0.19028}, {'accuracy': 0.18952}, {'accuracy': 0.18056}, {'accuracy': 0.1967}, {'accuracy': 0.15704}, {'accuracy': 0.19621999999999998}, {'accuracy': 0.17165999999999998}, {'accuracy': 0.17251999999999998}, {'accuracy': 0.17104999999999998}, {'accuracy': 0.16515999999999997}, {'accuracy': 0.16494000000000003}, {'accuracy': 0.17044}, {'accuracy': 0.15778}, {'accuracy': 0.19803}, {'accuracy': 0.17616}, {'accuracy': 0.17931999999999998}, {'accuracy': 0.15872999999999998}, {'accuracy': 0.17992000000000002}, {'accuracy': 0.18665999999999996}, {'accuracy': 0.16555}, {'accuracy': 0.16157}, {'accuracy': 0.14306}, {'accuracy': 0.16276000000000002}, {'accuracy': 0.15811999999999998}, {'accuracy': 0.1559}, {'accuracy': 0.14431999999999998}, {'accuracy': 0.15033000000000002}, {'accuracy': 0.14682}, {'accuracy': 0.1499}, {'accuracy': 0.17748000000000003}, {'accuracy': 0.15787999999999996}, {'accuracy': 0.16952}, {'accuracy': 0.16852}, {'accuracy': 0.15766}, {'accuracy': 0.15614}, {'accuracy': 0.15209999999999999}, {'accuracy': 0.17006000000000002}, {'accuracy': 0.1642}, {'accuracy': 0.15833}, {'accuracy': 0.15055999999999997}, {'accuracy': 0.14955000000000002}, {'accuracy': 0.15684}, {'accuracy': 0.16377999999999998}, {'accuracy': 0.17855000000000001}, {'accuracy': 0.15941}, {'accuracy': 0.15824000000000002}, {'accuracy': 0.17609}, {'accuracy': 0.17751}, {'accuracy': 0.16903}, {'accuracy': 0.16054}, {'accuracy': 0.181}, {'accuracy': 0.16851}, {'accuracy': 0.15986}, {'accuracy': 0.17294}, {'accuracy': 0.17287}, {'accuracy': 0.1784}, {'accuracy': 0.1811}, {'accuracy': 0.16538999999999998}, {'accuracy': 0.16074000000000002}, {'accuracy': 0.17695}, {'accuracy': 0.19237}, {'accuracy': 0.19903}, {'accuracy': 0.20328}, {'accuracy': 0.20187}, {'accuracy': 0.19800999999999996}, {'accuracy': 0.20246}, {'accuracy': 0.20615}, {'accuracy': 0.20591999999999996}, {'accuracy': 0.20119000000000004}, {'accuracy': 0.20014999999999997}, {'accuracy': 0.20549}, {'accuracy': 0.2049}, {'accuracy': 0.20590000000000003}, {'accuracy': 0.20376}, {'accuracy': 0.20275000000000004}, {'accuracy': 0.20465}, {'accuracy': 0.19713000000000003}, {'accuracy': 0.20289000000000001}, {'accuracy': 0.20099}, {'accuracy': 0.2056}, {'accuracy': 0.20051000000000002}, {'accuracy': 0.20171}, {'accuracy': 0.20244999999999996}, {'accuracy': 0.20027}, {'accuracy': 0.20339999999999997}, {'accuracy': 0.19861}, {'accuracy': 0.20232}, {'accuracy': 0.20334}, {'accuracy': 0.20254000000000003}, {'accuracy': 0.20493999999999998}, {'accuracy': 0.19865}, {'accuracy': 0.19725}, {'accuracy': 0.20806}, {'accuracy': 0.20056}, {'accuracy': 0.20498000000000002}, {'accuracy': 0.20548000000000002}, {'accuracy': 0.19721}, {'accuracy': 0.20207999999999998}, {'accuracy': 0.20239}, {'accuracy': 0.2016}, {'accuracy': 0.2045}, {'accuracy': 0.20586}, {'accuracy': 0.20495999999999998}, {'accuracy': 0.20221}, {'accuracy': 0.20171999999999998}, {'accuracy': 0.19902000000000003}, {'accuracy': 0.20325}, {'accuracy': 0.20507}, {'accuracy': 0.20777}, {'accuracy': 0.20021999999999998}, {'accuracy': 0.20459}, {'accuracy': 0.20657}, {'accuracy': 0.20389999999999997}, {'accuracy': 0.20345999999999997}, {'accuracy': 0.20574999999999996}, {'accuracy': 0.20543999999999998}, {'accuracy': 0.20355000000000004}, {'accuracy': 0.20400000000000001}, {'accuracy': 0.20305}, {'accuracy': 0.20673}, {'accuracy': 0.20860000000000004}, {'accuracy': 0.20514000000000002}, {'accuracy': 0.20665}, {'accuracy': 0.20699}, {'accuracy': 0.20604}, {'accuracy': 0.20135}, {'accuracy': 0.20398}, {'accuracy': 0.20023}, {'accuracy': 0.20699}, {'accuracy': 0.20383}, {'accuracy': 0.20729000000000003}, {'accuracy': 0.20670000000000002}, {'accuracy': 0.20722000000000002}, {'accuracy': 0.20551}, {'accuracy': 0.20796}, {'accuracy': 0.2061}, {'accuracy': 0.20903}, {'accuracy': 0.20573000000000002}, {'accuracy': 0.20315}, {'accuracy': 0.20748000000000003}, {'accuracy': 0.20668000000000003}, {'accuracy': 0.20459999999999998}, {'accuracy': 0.20661000000000002}, {'accuracy': 0.20728}, {'accuracy': 0.2069}, {'accuracy': 0.20731000000000002}, {'accuracy': 0.21078999999999998}, {'accuracy': 0.20686999999999997}, {'accuracy': 0.2063}, {'accuracy': 0.20210000000000003}, {'accuracy': 0.21042}, {'accuracy': 0.20787}, {'accuracy': 0.20849}, {'accuracy': 0.20621}, {'accuracy': 0.21109}, {'accuracy': 0.20632}, {'accuracy': 0.20773999999999998}, {'accuracy': 0.21017999999999998}, {'accuracy': 0.20953999999999998}, {'accuracy': 0.20720999999999998}, {'accuracy': 0.20747}, {'accuracy': 0.2068}, {'accuracy': 0.20772}, {'accuracy': 0.21057}, {'accuracy': 0.21170999999999998}, {'accuracy': 0.20783000000000001}, {'accuracy': 0.20809000000000002}, {'accuracy': 0.21149}, {'accuracy': 0.21120999999999998}, {'accuracy': 0.20742}, {'accuracy': 0.21258}, {'accuracy': 0.21422000000000002}, {'accuracy': 0.21302000000000004}, {'accuracy': 0.21007000000000003}, {'accuracy': 0.21100000000000002}, {'accuracy': 0.20868000000000003}, {'accuracy': 0.20983000000000002}, {'accuracy': 0.20980000000000004}, {'accuracy': 0.20968}, {'accuracy': 0.20871999999999996}, {'accuracy': 0.20703999999999997}, {'accuracy': 0.20836000000000002}, {'accuracy': 0.20901}, {'accuracy': 0.20953999999999998}, {'accuracy': 0.20929000000000003}, {'accuracy': 0.20976}, {'accuracy': 0.20676}, {'accuracy': 0.2096}, {'accuracy': 0.20843000000000003}, {'accuracy': 0.20924}, {'accuracy': 0.20936}, {'accuracy': 0.20909}, {'accuracy': 0.21027}, {'accuracy': 0.20619}, {'accuracy': 0.2116}, {'accuracy': 0.20916}, {'accuracy': 0.20854}, {'accuracy': 0.209}, {'accuracy': 0.20897000000000002}, {'accuracy': 0.21092999999999998}, {'accuracy': 0.21273}, {'accuracy': 0.21232}, {'accuracy': 0.21098}, {'accuracy': 0.21200000000000002}, {'accuracy': 0.21116000000000001}, {'accuracy': 0.21098}, {'accuracy': 0.21239}, {'accuracy': 0.20989999999999998}, {'accuracy': 0.2105}, {'accuracy': 0.21047000000000002}, {'accuracy': 0.21126}, {'accuracy': 0.20958000000000002}, {'accuracy': 0.21141000000000001}, {'accuracy': 0.21031}, {'accuracy': 0.21073}, {'accuracy': 0.21289000000000002}, {'accuracy': 0.21581}, {'accuracy': 0.21059999999999998}, {'accuracy': 0.21046}, {'accuracy': 0.21129000000000003}, {'accuracy': 0.21214}, {'accuracy': 0.21092}, {'accuracy': 0.20945999999999998}, {'accuracy': 0.20947}, {'accuracy': 0.20947}, {'accuracy': 0.21034000000000003}, {'accuracy': 0.21330999999999997}, {'accuracy': 0.21342}, {'accuracy': 0.20818000000000003}, {'accuracy': 0.21144999999999997}, {'accuracy': 0.209}, {'accuracy': 0.21331000000000003}, {'accuracy': 0.21230000000000002}, {'accuracy': 0.21232}, {'accuracy': 0.21070000000000003}, {'accuracy': 0.21023}, {'accuracy': 0.20999999999999996}, {'accuracy': 0.20939999999999998}, {'accuracy': 0.20953}, {'accuracy': 0.21095999999999998}, {'accuracy': 0.21175000000000002}, {'accuracy': 0.213}, {'accuracy': 0.21216}, {'accuracy': 0.20950000000000002}, {'accuracy': 0.21273}, {'accuracy': 0.21505000000000002}, {'accuracy': 0.21197}, {'accuracy': 0.21206999999999998}, {'accuracy': 0.21516000000000002}, {'accuracy': 0.21484999999999999}, {'accuracy': 0.21291000000000002}, {'accuracy': 0.21524000000000001}, {'accuracy': 0.21117}, {'accuracy': 0.21013}, {'accuracy': 0.21193}, {'accuracy': 0.21151999999999999}, {'accuracy': 0.21253000000000002}, {'accuracy': 0.21252}, {'accuracy': 0.21297000000000002}]\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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NuHs2bMt+roE0dKQACKIVoogbAQh5A25ULryyisRHx+PZcuWiccsW7YMffr0wQUXXAAAOHLkCHiex7PPPovU1FTJ16xZswAAJSUlktfJzc31eO2GhgbMnDlTzMFJSUlBamoqKisrUVVV1cgrD4zDhw9j5cqVHusvKCiQrP/BBx/EBRdcgKuuugodO3bE3XffjZUrVzb59TUajZgLxa6pqqoKaWlpHuuqra0V1zRy5EjccssteP7555GSkoIbbrgBixcvhtlsbvK6/PHKK69gz549yM7OxqBBg/Dcc8/h2LFjzf66BNHSUA4QQbRS4uPj0aFDB+zatcvncbt27UJWVhbi4uIAAHq9HjfeeCNWrFiBt956C8XFxdiwYQNefvll8TlCkvATTzyBsWPHKp43Pz9f8ph1ewQefvhhLF68GI899hiGDBmC+Ph4cByHO+64wyMROdQ4HA5cccUVeOqppxT3C2IvLS0NO3fuxA8//IDvv/8e33//PRYvXoyJEyfigw8+aPTr6/V6qFTSvzEdDgfS0tLw0UcfKT5HSGTnOA7Lly/H77//jv/973/44YcfcPfdd+O1117D77//jpiYGK+NDe12e6PXDAC33347RowYgRUrVuDHH3/Eq6++irlz5+KLL77AVVdd1aRzE0QkQQKIIFox1157LRYtWoT169dj+PDhHvt//fVXnDhxAvfff79k+7hx4/DBBx9gzZo12L9/P3ieF8NfAMSSea1WKzomjWH58uWYNGkSXnvtNXGbyWRCZWVlo88px5sQ6NKlC2prawNav06nw3XXXYfrrrsODocDDz74IN599108++yzyM/PD1kX5S5dumD16tUYNmyYomCUc8kll+CSSy7BSy+9hI8//hgTJkzA0qVLce+99yIxMREAPH6WJ0+eDGgtvq6pQ4cOePDBB/Hggw+ipKQE/fr1w0svvUQCiGhTUAiMIFoxTz75JIxGI+6//36cP39esq+8vBx/+ctfEBUVhSeffFKyr6CgAElJSVi2bBmWLVuGQYMGSUJYaWlpuOyyy/Duu+/i3LlzHq9bWloa0PrUajV4npdse+ONN5rsUrBER0crCqrbb78dGzduxA8//OCxr7KyEjabDQA8fm4qlQq9evUCADHkJPTvaapwu/3222G32/Hiiy967LPZbOL5KyoqPH5uffr0kaypc+fOUKvVYi6T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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5c0ad45-8281-48fe-a7a2-c6e95c789252",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "288063a4-ea40-4e00-bb2c-fc0dcaf6b583",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd229406-2249-4e24-a930-a2a133c717b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e61235b0-2ef6-491c-852a-38bb326ee1f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e81b8da2-6250-4d69-80e7-b668afe9125e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8de8187e-c670-4630-ba2b-9ef18a003837",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "71b1bf59-39d3-497e-99bd-e4b12eb1e207",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "afea64c9-113e-464a-a6c3-3f038a7fa2cd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4641f7b7-4f42-42f7-b30e-a08e18de78e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f206c449-d037-4209-b89a-d3808e0c2380",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "64f0addb-4c16-4660-955d-97e0e387733b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a970f0aa-83dc-4012-8541-37dc9f9f25e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee60cd2c-2146-4d4a-9048-06a191fbe700",
   "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
}
