{
 "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 1997]\n",
      " [   1   59]\n",
      " [   2   30]\n",
      " [   3   54]\n",
      " [   4  103]\n",
      " [   5  172]\n",
      " [   6  265]\n",
      " [   7  430]\n",
      " [   8  680]\n",
      " [   9 1161]]\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 1207]\n",
      " [   1 2003]\n",
      " [   2   49]\n",
      " [   3   47]\n",
      " [   4   53]\n",
      " [   5   90]\n",
      " [   6  158]\n",
      " [   7  276]\n",
      " [   8  466]\n",
      " [   9  736]]\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  739]\n",
      " [   1 1181]\n",
      " [   2 2088]\n",
      " [   3   45]\n",
      " [   4   28]\n",
      " [   5   54]\n",
      " [   6   84]\n",
      " [   7  171]\n",
      " [   8  298]\n",
      " [   9  436]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  427]\n",
      " [   1  714]\n",
      " [   2 1188]\n",
      " [   3 1962]\n",
      " [   4   68]\n",
      " [   5   23]\n",
      " [   6   44]\n",
      " [   7   94]\n",
      " [   8  147]\n",
      " [   9  252]]\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  278]\n",
      " [   1  428]\n",
      " [   2  683]\n",
      " [   3 1239]\n",
      " [   4 2018]\n",
      " [   5   52]\n",
      " [   6   40]\n",
      " [   7   60]\n",
      " [   8  106]\n",
      " [   9  141]]\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  135]\n",
      " [   1  265]\n",
      " [   2  440]\n",
      " [   3  671]\n",
      " [   4 1180]\n",
      " [   5 2014]\n",
      " [   6   65]\n",
      " [   7   39]\n",
      " [   8   57]\n",
      " [   9  115]]\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   94]\n",
      " [   1  158]\n",
      " [   2  235]\n",
      " [   3  489]\n",
      " [   4  704]\n",
      " [   5 1219]\n",
      " [   6 2039]\n",
      " [   7   61]\n",
      " [   8   39]\n",
      " [   9   48]]\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   63]\n",
      " [   1   98]\n",
      " [   2  144]\n",
      " [   3  252]\n",
      " [   4  439]\n",
      " [   5  710]\n",
      " [   6 1182]\n",
      " [   7 1962]\n",
      " [   8   54]\n",
      " [   9   40]]\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   20]\n",
      " [   1   56]\n",
      " [   2   82]\n",
      " [   3  156]\n",
      " [   4  225]\n",
      " [   5  426]\n",
      " [   6  674]\n",
      " [   7 1183]\n",
      " [   8 1916]\n",
      " [   9   45]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   40]\n",
      " [   1   38]\n",
      " [   2   61]\n",
      " [   3   85]\n",
      " [   4  182]\n",
      " [   5  240]\n",
      " [   6  449]\n",
      " [   7  724]\n",
      " [   8 1237]\n",
      " [   9 2026]]\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",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c17faaee-4ada-49de-9343-8275dd417c0d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\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.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.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.10022}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.09966}, {'accuracy': 0.10186999999999999}, {'accuracy': 0.09974000000000001}, {'accuracy': 0.10364999999999999}, {'accuracy': 0.10882}, {'accuracy': 0.10286000000000002}, {'accuracy': 0.10288000000000001}, {'accuracy': 0.10403}, {'accuracy': 0.10911}, {'accuracy': 0.10200000000000002}, {'accuracy': 0.10926}, {'accuracy': 0.10731000000000002}, {'accuracy': 0.10446000000000003}, {'accuracy': 0.10199}, {'accuracy': 0.11338}, {'accuracy': 0.11847}, {'accuracy': 0.10556000000000001}, {'accuracy': 0.12042}, {'accuracy': 0.11295000000000002}, {'accuracy': 0.11073000000000002}, {'accuracy': 0.10798}, {'accuracy': 0.12062000000000002}, {'accuracy': 0.11443}, {'accuracy': 0.12203000000000001}, {'accuracy': 0.12677}, {'accuracy': 0.11805999999999998}, {'accuracy': 0.13245}, {'accuracy': 0.12539999999999998}, {'accuracy': 0.14112000000000002}, {'accuracy': 0.13115}, {'accuracy': 0.14034000000000002}, {'accuracy': 0.13853}, {'accuracy': 0.12291}, {'accuracy': 0.12828999999999996}, {'accuracy': 0.12538}, {'accuracy': 0.12794}, {'accuracy': 0.15984}, {'accuracy': 0.17058}, {'accuracy': 0.13853000000000001}, {'accuracy': 0.15348}, {'accuracy': 0.15591000000000005}, {'accuracy': 0.13415000000000002}, {'accuracy': 0.16168}, {'accuracy': 0.15350999999999998}, {'accuracy': 0.17143999999999998}, {'accuracy': 0.17178}, {'accuracy': 0.17855000000000004}, {'accuracy': 0.17020000000000002}, {'accuracy': 0.17893}, {'accuracy': 0.18621000000000001}, {'accuracy': 0.18334999999999999}, {'accuracy': 0.18903}, {'accuracy': 0.19543}, {'accuracy': 0.16424}, {'accuracy': 0.18867}, {'accuracy': 0.19419}, {'accuracy': 0.19569}, {'accuracy': 0.18297999999999998}, {'accuracy': 0.19666999999999998}, {'accuracy': 0.21381}, {'accuracy': 0.19412999999999997}, {'accuracy': 0.20247}, {'accuracy': 0.19544}, {'accuracy': 0.23640000000000003}, {'accuracy': 0.19570999999999997}, {'accuracy': 0.19460999999999998}, {'accuracy': 0.20188}, {'accuracy': 0.21907000000000001}, {'accuracy': 0.20681}, {'accuracy': 0.19318}, {'accuracy': 0.25590999999999997}, {'accuracy': 0.2012}, {'accuracy': 0.21940000000000004}, {'accuracy': 0.20200999999999997}, {'accuracy': 0.2157}, {'accuracy': 0.22252}, {'accuracy': 0.21141000000000001}, {'accuracy': 0.20689000000000002}, {'accuracy': 0.18807999999999997}, {'accuracy': 0.20952}, {'accuracy': 0.22948999999999997}, {'accuracy': 0.24489}, {'accuracy': 0.20145}, {'accuracy': 0.21403}, {'accuracy': 0.26161}, {'accuracy': 0.21627000000000002}, {'accuracy': 0.22917}, {'accuracy': 0.22406}, {'accuracy': 0.26672}, {'accuracy': 0.24279}, {'accuracy': 0.24702000000000002}, {'accuracy': 0.25671999999999995}, {'accuracy': 0.23285999999999998}, {'accuracy': 0.22181}, {'accuracy': 0.24364999999999998}, {'accuracy': 0.23678}, {'accuracy': 0.24198}, {'accuracy': 0.26105999999999996}, {'accuracy': 0.263}, {'accuracy': 0.25839}, {'accuracy': 0.24348999999999998}, {'accuracy': 0.25193000000000004}, {'accuracy': 0.23838000000000004}, {'accuracy': 0.25452}, {'accuracy': 0.28859999999999997}, {'accuracy': 0.27367}, {'accuracy': 0.25728999999999996}, {'accuracy': 0.2636}, {'accuracy': 0.26935000000000003}, {'accuracy': 0.25628000000000006}, {'accuracy': 0.25684}, {'accuracy': 0.25644999999999996}, {'accuracy': 0.27384000000000003}, {'accuracy': 0.2993}, {'accuracy': 0.28741000000000005}, {'accuracy': 0.29317000000000004}, {'accuracy': 0.26348}, {'accuracy': 0.29702}, {'accuracy': 0.26321000000000006}, {'accuracy': 0.25982}, {'accuracy': 0.31478999999999996}, {'accuracy': 0.29761}, {'accuracy': 0.29427}, {'accuracy': 0.30361000000000005}, {'accuracy': 0.29492}, {'accuracy': 0.29191}, {'accuracy': 0.32272}, {'accuracy': 0.29628000000000004}, {'accuracy': 0.3048}, {'accuracy': 0.31046}, {'accuracy': 0.31147}, {'accuracy': 0.30693000000000004}, {'accuracy': 0.33944}, {'accuracy': 0.33768}, {'accuracy': 0.32998999999999995}, {'accuracy': 0.34784000000000004}, {'accuracy': 0.33723000000000003}, {'accuracy': 0.34441}, {'accuracy': 0.34396000000000004}, {'accuracy': 0.33591999999999994}, {'accuracy': 0.33022}, {'accuracy': 0.34177}, {'accuracy': 0.35806000000000004}, {'accuracy': 0.33428}, {'accuracy': 0.33401999999999993}, {'accuracy': 0.33598}, {'accuracy': 0.34884000000000004}, {'accuracy': 0.35824}, {'accuracy': 0.37690999999999997}, {'accuracy': 0.35036000000000006}, {'accuracy': 0.36092}, {'accuracy': 0.37282000000000004}, {'accuracy': 0.37517999999999996}, {'accuracy': 0.37433999999999995}, {'accuracy': 0.37162999999999996}, {'accuracy': 0.36828000000000005}, {'accuracy': 0.38495999999999997}, {'accuracy': 0.37865}, {'accuracy': 0.38166}, {'accuracy': 0.37149000000000004}, {'accuracy': 0.36776}, {'accuracy': 0.36624}, {'accuracy': 0.39199}, {'accuracy': 0.3803}, {'accuracy': 0.3802}, {'accuracy': 0.43918}, {'accuracy': 0.44398}, {'accuracy': 0.46098}, {'accuracy': 0.4751600000000001}, {'accuracy': 0.48278999999999994}, {'accuracy': 0.47957}, {'accuracy': 0.4795000000000001}, {'accuracy': 0.47697}, {'accuracy': 0.47035}, {'accuracy': 0.48167}, {'accuracy': 0.4764400000000001}, {'accuracy': 0.48615}, {'accuracy': 0.49022999999999994}, {'accuracy': 0.49157}, {'accuracy': 0.47989}, {'accuracy': 0.47538}, {'accuracy': 0.47989}, {'accuracy': 0.48486}, {'accuracy': 0.488}, {'accuracy': 0.49444999999999995}, {'accuracy': 0.48616000000000004}, {'accuracy': 0.49431}, {'accuracy': 0.48151}, {'accuracy': 0.49315999999999993}, {'accuracy': 0.49770000000000003}, {'accuracy': 0.4928699999999999}, {'accuracy': 0.4938999999999999}, {'accuracy': 0.4750500000000001}, {'accuracy': 0.48931}, {'accuracy': 0.49812}, {'accuracy': 0.49233000000000005}, {'accuracy': 0.48944}, {'accuracy': 0.48743}, {'accuracy': 0.48342999999999997}, {'accuracy': 0.4817600000000001}, {'accuracy': 0.48663999999999996}, {'accuracy': 0.4907500000000001}, {'accuracy': 0.49807999999999997}, {'accuracy': 0.49996999999999997}, {'accuracy': 0.50003}, {'accuracy': 0.49786}, {'accuracy': 0.49101}, {'accuracy': 0.49928999999999996}, {'accuracy': 0.49836}, {'accuracy': 0.4940300000000001}, {'accuracy': 0.49412}, {'accuracy': 0.5049400000000002}, {'accuracy': 0.5077}, {'accuracy': 0.5083599999999999}, {'accuracy': 0.5073300000000001}, {'accuracy': 0.5099}, {'accuracy': 0.50875}, {'accuracy': 0.50951}, {'accuracy': 0.51009}, {'accuracy': 0.50997}, {'accuracy': 0.50952}, {'accuracy': 0.50935}, {'accuracy': 0.50922}, {'accuracy': 0.50786}, {'accuracy': 0.51019}, {'accuracy': 0.50987}, {'accuracy': 0.5108900000000001}, {'accuracy': 0.50981}, {'accuracy': 0.5090700000000001}, {'accuracy': 0.5111100000000002}, {'accuracy': 0.51001}, {'accuracy': 0.50962}, {'accuracy': 0.5105599999999999}, {'accuracy': 0.50892}, {'accuracy': 0.50807}, {'accuracy': 0.5092}, {'accuracy': 0.50956}, {'accuracy': 0.50964}, {'accuracy': 0.5118699999999999}, {'accuracy': 0.50952}, {'accuracy': 0.50989}, {'accuracy': 0.50932}, {'accuracy': 0.5101800000000001}, {'accuracy': 0.50973}, {'accuracy': 0.50725}, {'accuracy': 0.50722}, {'accuracy': 0.5113200000000001}, {'accuracy': 0.5113299999999998}, {'accuracy': 0.5098799999999999}, {'accuracy': 0.5088800000000001}, {'accuracy': 0.50948}, {'accuracy': 0.50702}, {'accuracy': 0.5084599999999999}, {'accuracy': 0.50911}, {'accuracy': 0.5090299999999999}, {'accuracy': 0.5090999999999999}, {'accuracy': 0.50816}, {'accuracy': 0.50969}, {'accuracy': 0.50793}, {'accuracy': 0.50554}, {'accuracy': 0.5098199999999999}, {'accuracy': 0.5093}, {'accuracy': 0.50719}, {'accuracy': 0.50866}, {'accuracy': 0.50703}, {'accuracy': 0.5062199999999999}, {'accuracy': 0.50699}, {'accuracy': 0.5075}, {'accuracy': 0.5072500000000001}, {'accuracy': 0.50662}, {'accuracy': 0.5067800000000001}, {'accuracy': 0.5061199999999999}, {'accuracy': 0.5083300000000001}]\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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v2TJErzxxht47733sG3bNvj5+WHChAmor6+X2kydOhX79+/HunXr8OOPP+L333/HXXfd1VFvod2d7R4BwOWXX273ufr888/tzrv7Pdq0aRP++c9/4s8//8S6detgMBgwfvx41NTUSG3O9vNlMplw1VVXQa/XY+vWrfjoo4+wfPlyLFy40BVvqc215B4BwKxZs+w+S0uWLJHOufs9io2NxfPPP4+dO3dix44dGDt2LK677jrs378fgBt9hgSdl2HDhol//vOf0mOTySSio6PF4sWLXdgr11m0aJEYMGCA03Pl5eXC29tbfPnll9KxgwcPCgAiPT29g3roWgDEN998Iz02m80iMjJSvPjii9Kx8vJyoVKpxOeffy6EEOLAgQMCgNi+fbvU5pdffhEymUycPn26w/reUZreIyGEmD59urjuuuuafY6n3SMhhCgsLBQAxKZNm4QQLfv5+vnnn4VcLhf5+flSm3fffVdotVqh0+k69g10gKb3SAghRo8eLe6///5mn+Np90gIIYKCgsR//vMft/oMMXNzHvR6PXbu3Im0tDTpmFwuR1paGtLT013YM9c6evQooqOjkZSUhKlTpyI7OxsAsHPnThgMBrv71atXL8THx3vs/crMzER+fr7dPQkICMDw4cOle5Keno7AwEAMHTpUapOWlga5XI5t27Z1eJ9dZePGjQgPD0fPnj1xzz33oKSkRDrnifeooqICABAcHAygZT9f6enpSE1NRUREhNRmwoQJqKyslP5ydydN75HVp59+itDQUPTr1w8LFixAbW2tdM6T7pHJZMKKFStQU1ODESNGuNVnyOM2zmxLxcXFMJlMdv+TASAiIgKHDh1yUa9ca/jw4Vi+fDl69uyJvLw8PPnkkxg1ahT27duH/Px8KJVKBAYG2j0nIiIC+fn5rumwi1nft7PPkPVcfn4+wsPD7c57eXkhODjYY+7b5Zdfjuuvvx7dunXD8ePH8a9//QtXXHEF0tPToVAoPO4emc1mzJs3DxdffDH69esHAC36+crPz3f6WbOecyfO7hEA/OMf/0BCQgKio6OxZ88ePPLIIzh8+DC+/vprAJ5xj/bu3YsRI0agvr4eGo0G33zzDfr06YOMjAy3+QwxuKE2dcUVV0jf9+/fH8OHD0dCQgK++OIL+Pj4uLBn1JXdcsst0vepqano378/kpOTsXHjRowb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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": "ba5f2b37-c3bc-4b21-aa98-574965de1a65",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e20cde54-7fb4-40b7-8b33-f737dbde2266",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1141c7bb-f583-4860-a404-d9c4adbde581",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19d254a9-c325-4c3b-b935-2cd6d1ba12f7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b316d11-454b-4211-913b-a844003a74f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98391920-dcd6-437c-9017-0567fab54772",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b06d47ce-08b9-45d1-94a2-c2bf7dd8ec14",
   "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
}
