{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "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": null,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e954128-4fd2-47cc-8c67-ab75f6023977",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n",
      "4944\n",
      "[[  0 481]\n",
      " [  1 495]\n",
      " [  2 499]\n",
      " [  3 485]\n",
      " [  4 506]\n",
      " [  5 512]\n",
      " [  6 507]\n",
      " [  7 498]\n",
      " [  8 486]\n",
      " [  9 485]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "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",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\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 ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "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]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4982"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([9, 9, 3,  ..., 0, 2, 9])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if tag1[z]==1:\n",
    "            tag1[z]=9\n",
    "        elif tag1[z]==9:\n",
    "            tag1[z]=1        \n",
    "        elif tag1[z]==3:\n",
    "            tag1[z]=5     \n",
    "        elif tag1[z]==5:\n",
    "            tag1[z]=3   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3a01dd9-6139-499e-b926-6e539ee21cf7",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": 14,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10131000000000001}, {'accuracy': 0.13223000000000001}, {'accuracy': 0.14657000000000003}, {'accuracy': 0.20110999999999998}, {'accuracy': 0.23531}, {'accuracy': 0.32860999999999996}, {'accuracy': 0.33185000000000003}, {'accuracy': 0.3601500000000001}, {'accuracy': 0.3769600000000001}, {'accuracy': 0.38456999999999997}, {'accuracy': 0.40281}, {'accuracy': 0.42774999999999996}, {'accuracy': 0.44272}, {'accuracy': 0.45113000000000003}, {'accuracy': 0.48484}, {'accuracy': 0.48301}, {'accuracy': 0.48835999999999996}, {'accuracy': 0.49747}, {'accuracy': 0.50827}, {'accuracy': 0.5267799999999999}, {'accuracy': 0.51758}, {'accuracy': 0.51716}, {'accuracy': 0.5144599999999999}, {'accuracy': 0.52557}, {'accuracy': 0.53083}, {'accuracy': 0.52674}, {'accuracy': 0.52828}, {'accuracy': 0.5292600000000001}, {'accuracy': 0.5316599999999999}, {'accuracy': 0.5338299999999999}, {'accuracy': 0.52826}, {'accuracy': 0.52983}, {'accuracy': 0.5210299999999999}, {'accuracy': 0.5396000000000001}, {'accuracy': 0.52901}, {'accuracy': 0.5323}, {'accuracy': 0.53411}, {'accuracy': 0.54213}, {'accuracy': 0.53806}, {'accuracy': 0.5327900000000001}, {'accuracy': 0.53623}, {'accuracy': 0.5588799999999999}, {'accuracy': 0.55312}, {'accuracy': 0.5528500000000001}, {'accuracy': 0.5561100000000001}, {'accuracy': 0.5673999999999999}, {'accuracy': 0.5670200000000001}, {'accuracy': 0.57388}, {'accuracy': 0.569}, {'accuracy': 0.5779400000000001}, {'accuracy': 0.57765}, {'accuracy': 0.57039}, {'accuracy': 0.5774600000000001}, {'accuracy': 0.5736400000000001}, {'accuracy': 0.576}, {'accuracy': 0.58651}, {'accuracy': 0.58814}, {'accuracy': 0.5856600000000001}, {'accuracy': 0.5926400000000001}, {'accuracy': 0.5858099999999999}, {'accuracy': 0.59348}, {'accuracy': 0.59794}, {'accuracy': 0.58949}, {'accuracy': 0.5997699999999999}, {'accuracy': 0.5897399999999999}, {'accuracy': 0.59623}, {'accuracy': 0.6039599999999999}, {'accuracy': 0.60368}, {'accuracy': 0.6086}, {'accuracy': 0.6090500000000001}, {'accuracy': 0.6052200000000001}, {'accuracy': 0.59648}, {'accuracy': 0.6060900000000001}, {'accuracy': 0.60441}, {'accuracy': 0.6108000000000001}, {'accuracy': 0.60725}, {'accuracy': 0.6113099999999999}, {'accuracy': 0.60798}, {'accuracy': 0.62267}, {'accuracy': 0.6127100000000001}, {'accuracy': 0.6207699999999999}, {'accuracy': 0.61593}, {'accuracy': 0.61555}, {'accuracy': 0.6170899999999999}, {'accuracy': 0.61581}, {'accuracy': 0.6184999999999999}, {'accuracy': 0.61304}, {'accuracy': 0.61914}, {'accuracy': 0.6224399999999999}, {'accuracy': 0.62058}, {'accuracy': 0.62637}, {'accuracy': 0.62904}, {'accuracy': 0.6224500000000001}, {'accuracy': 0.62507}, {'accuracy': 0.6376499999999999}, {'accuracy': 0.6425599999999999}, {'accuracy': 0.6373599999999999}, {'accuracy': 0.63852}, {'accuracy': 0.61875}, {'accuracy': 0.62702}, {'accuracy': 0.6191700000000001}, {'accuracy': 0.62164}, {'accuracy': 0.6356499999999998}, {'accuracy': 0.6286400000000001}, {'accuracy': 0.6385500000000001}, {'accuracy': 0.64646}, {'accuracy': 0.62005}, {'accuracy': 0.63688}, {'accuracy': 0.6372800000000001}, {'accuracy': 0.64251}, {'accuracy': 0.63836}, {'accuracy': 0.64587}, {'accuracy': 0.65068}, {'accuracy': 0.64209}, {'accuracy': 0.6397300000000001}, {'accuracy': 0.64537}, {'accuracy': 0.63239}, {'accuracy': 0.63792}, {'accuracy': 0.6416100000000001}, {'accuracy': 0.63436}, {'accuracy': 0.64234}, {'accuracy': 0.65011}, {'accuracy': 0.65307}, {'accuracy': 0.65208}, {'accuracy': 0.6522699999999999}, {'accuracy': 0.6526099999999999}, {'accuracy': 0.65208}, {'accuracy': 0.6526}, {'accuracy': 0.6547400000000001}, {'accuracy': 0.65302}, {'accuracy': 0.6541399999999999}, {'accuracy': 0.65289}, {'accuracy': 0.6524300000000001}, {'accuracy': 0.65181}, {'accuracy': 0.65329}, {'accuracy': 0.6515600000000001}, {'accuracy': 0.65127}, {'accuracy': 0.6522200000000001}, {'accuracy': 0.65262}, {'accuracy': 0.6518999999999999}, {'accuracy': 0.65152}, {'accuracy': 0.65094}, {'accuracy': 0.65073}, {'accuracy': 0.65114}, {'accuracy': 0.65018}, {'accuracy': 0.651}, {'accuracy': 0.6507000000000001}, {'accuracy': 0.65027}, {'accuracy': 0.6505599999999999}, {'accuracy': 0.64971}, {'accuracy': 0.6502700000000001}, {'accuracy': 0.65025}, {'accuracy': 0.65015}, {'accuracy': 0.64968}, {'accuracy': 0.65033}, {'accuracy': 0.6493499999999999}, {'accuracy': 0.64994}, {'accuracy': 0.65034}, {'accuracy': 0.64936}, {'accuracy': 0.6494899999999999}, {'accuracy': 0.64845}, {'accuracy': 0.64896}, {'accuracy': 0.64956}, {'accuracy': 0.64843}, {'accuracy': 0.64765}, {'accuracy': 0.64854}, {'accuracy': 0.64791}, {'accuracy': 0.64787}, {'accuracy': 0.6484300000000001}, {'accuracy': 0.6487800000000001}, {'accuracy': 0.64813}, {'accuracy': 0.64789}, {'accuracy': 0.64744}, {'accuracy': 0.64714}, {'accuracy': 0.64767}, {'accuracy': 0.6464300000000001}, {'accuracy': 0.64717}, {'accuracy': 0.64699}, {'accuracy': 0.64607}, {'accuracy': 0.6461500000000001}, {'accuracy': 0.64671}, {'accuracy': 0.64719}, {'accuracy': 0.64802}, {'accuracy': 0.64666}, {'accuracy': 0.64703}, {'accuracy': 0.64655}, {'accuracy': 0.64764}, {'accuracy': 0.64713}, {'accuracy': 0.64607}, {'accuracy': 0.6465399999999999}, {'accuracy': 0.6458600000000001}, {'accuracy': 0.64586}, {'accuracy': 0.6450400000000001}, {'accuracy': 0.6460199999999999}, {'accuracy': 0.64666}, {'accuracy': 0.6457900000000001}, {'accuracy': 0.6451200000000001}, {'accuracy': 0.64429}, {'accuracy': 0.6302099999999999}, {'accuracy': 0.6314599999999999}, {'accuracy': 0.64349}, {'accuracy': 0.6427900000000001}, {'accuracy': 0.6396499999999999}, {'accuracy': 0.6445099999999999}, {'accuracy': 0.6516099999999999}, {'accuracy': 0.6538200000000001}, {'accuracy': 0.6495}, {'accuracy': 0.64769}, {'accuracy': 0.6539699999999999}, {'accuracy': 0.65363}, {'accuracy': 0.64898}, {'accuracy': 0.65383}, {'accuracy': 0.6383699999999999}, {'accuracy': 0.65165}, {'accuracy': 0.6435599999999999}, {'accuracy': 0.6534999999999999}, {'accuracy': 0.65201}, {'accuracy': 0.64727}, {'accuracy': 0.6545500000000001}, {'accuracy': 0.64562}, {'accuracy': 0.64026}, {'accuracy': 0.65037}, {'accuracy': 0.65083}, {'accuracy': 0.656}, {'accuracy': 0.6332399999999999}, {'accuracy': 0.64342}, {'accuracy': 0.64706}, {'accuracy': 0.64907}, {'accuracy': 0.64679}, {'accuracy': 0.6524699999999999}, {'accuracy': 0.64769}, {'accuracy': 0.64647}, {'accuracy': 0.64917}, {'accuracy': 0.6518900000000001}, {'accuracy': 0.64673}, {'accuracy': 0.64574}, {'accuracy': 0.6548100000000001}, {'accuracy': 0.63434}, {'accuracy': 0.64657}, {'accuracy': 0.6532100000000001}, {'accuracy': 0.65091}, {'accuracy': 0.6553199999999999}, {'accuracy': 0.65429}, {'accuracy': 0.65224}, {'accuracy': 0.64245}, {'accuracy': 0.65535}, {'accuracy': 0.6467999999999999}, {'accuracy': 0.64544}, {'accuracy': 0.65391}, {'accuracy': 0.65534}, {'accuracy': 0.65188}, {'accuracy': 0.6550100000000001}, {'accuracy': 0.64314}, {'accuracy': 0.65333}, {'accuracy': 0.63875}, {'accuracy': 0.65428}, {'accuracy': 0.65233}, {'accuracy': 0.64952}, {'accuracy': 0.6553099999999998}, {'accuracy': 0.6435599999999999}, {'accuracy': 0.6528799999999999}, {'accuracy': 0.6545799999999999}, {'accuracy': 0.6543199999999999}, {'accuracy': 0.6404}, {'accuracy': 0.65219}, {'accuracy': 0.65375}, {'accuracy': 0.65432}, {'accuracy': 0.6492000000000001}, {'accuracy': 0.64733}, {'accuracy': 0.6413300000000001}, {'accuracy': 0.65377}, {'accuracy': 0.6358599999999999}, {'accuracy': 0.6462999999999999}, {'accuracy': 0.6495}, {'accuracy': 0.64943}, {'accuracy': 0.6529400000000001}, {'accuracy': 0.6525}, {'accuracy': 0.64602}, {'accuracy': 0.6422599999999998}, {'accuracy': 0.6447799999999999}, {'accuracy': 0.6513500000000001}, {'accuracy': 0.6466400000000001}, {'accuracy': 0.65244}, {'accuracy': 0.64537}, {'accuracy': 0.65175}, {'accuracy': 0.6539499999999998}, {'accuracy': 0.6509199999999999}, {'accuracy': 0.6449299999999999}, {'accuracy': 0.6515}, {'accuracy': 0.65079}, {'accuracy': 0.65235}, {'accuracy': 0.6489500000000001}, {'accuracy': 0.64245}, {'accuracy': 0.65215}, {'accuracy': 0.6374099999999999}, {'accuracy': 0.64961}, {'accuracy': 0.64}, {'accuracy': 0.64985}, {'accuracy': 0.65016}, {'accuracy': 0.6401600000000001}, {'accuracy': 0.6376200000000001}, {'accuracy': 0.64435}, {'accuracy': 0.64959}, {'accuracy': 0.6428800000000001}, {'accuracy': 0.6295}, {'accuracy': 0.63886}, {'accuracy': 0.63802}, {'accuracy': 0.64983}, {'accuracy': 0.6486799999999999}, {'accuracy': 0.6507400000000001}, {'accuracy': 0.65069}, {'accuracy': 0.65427}, {'accuracy': 0.64703}, {'accuracy': 0.64116}, {'accuracy': 0.64245}, {'accuracy': 0.6486400000000001}, {'accuracy': 0.64306}, {'accuracy': 0.64595}, {'accuracy': 0.65046}, {'accuracy': 0.6293900000000001}, {'accuracy': 0.6349799999999999}, {'accuracy': 0.6418100000000001}, {'accuracy': 0.6411499999999999}, {'accuracy': 0.6493499999999999}, {'accuracy': 0.6508800000000001}, {'accuracy': 0.64537}, {'accuracy': 0.64831}, {'accuracy': 0.64404}, {'accuracy': 0.6446099999999999}, {'accuracy': 0.6487799999999999}, {'accuracy': 0.64986}, {'accuracy': 0.6454899999999999}, {'accuracy': 0.64583}, {'accuracy': 0.6337400000000001}, {'accuracy': 0.63985}, {'accuracy': 0.6290600000000001}, {'accuracy': 0.6457999999999999}, {'accuracy': 0.65025}, {'accuracy': 0.6437600000000001}, {'accuracy': 0.64467}, {'accuracy': 0.63602}, {'accuracy': 0.6381}, {'accuracy': 0.63659}, {'accuracy': 0.6432700000000001}, {'accuracy': 0.6390900000000002}, {'accuracy': 0.64466}, {'accuracy': 0.64158}, {'accuracy': 0.64235}, {'accuracy': 0.6366099999999999}, {'accuracy': 0.6384500000000001}, {'accuracy': 0.63395}, {'accuracy': 0.62354}, {'accuracy': 0.64164}, {'accuracy': 0.63788}, {'accuracy': 0.6360399999999999}, {'accuracy': 0.63521}, {'accuracy': 0.6390100000000001}, {'accuracy': 0.6379}, {'accuracy': 0.6390300000000001}, {'accuracy': 0.64349}, {'accuracy': 0.63754}, {'accuracy': 0.64009}, {'accuracy': 0.6430800000000001}, {'accuracy': 0.64341}, {'accuracy': 0.6369900000000001}, {'accuracy': 0.6387499999999999}, {'accuracy': 0.61431}, {'accuracy': 0.6301100000000001}, {'accuracy': 0.6445000000000001}, {'accuracy': 0.6384099999999999}, {'accuracy': 0.6313600000000001}, {'accuracy': 0.6366400000000001}, {'accuracy': 0.63679}, {'accuracy': 0.63342}, {'accuracy': 0.6432}, {'accuracy': 0.63835}, {'accuracy': 0.6392599999999999}, {'accuracy': 0.63857}, {'accuracy': 0.63705}, {'accuracy': 0.63495}, {'accuracy': 0.6395299999999999}, {'accuracy': 0.6399199999999999}, {'accuracy': 0.63817}, {'accuracy': 0.63821}, {'accuracy': 0.6446799999999999}, {'accuracy': 0.6336600000000001}, {'accuracy': 0.64347}, {'accuracy': 0.63771}, {'accuracy': 0.62587}, {'accuracy': 0.63132}, {'accuracy': 0.63581}, {'accuracy': 0.63797}, {'accuracy': 0.6346999999999999}, {'accuracy': 0.63867}, {'accuracy': 0.6422300000000001}, {'accuracy': 0.63158}, {'accuracy': 0.63768}, {'accuracy': 0.63852}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4812cafe-820d-4a3b-ba74-f3f93540c8b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e21bc33-430f-4bfa-afbc-5eb3470579a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36912f17-4767-42a6-968f-a32bd0727613",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "447c2b68-631d-454b-8a21-eb92bac3b8b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9312507a-3c9c-497c-9ad9-3cbd8c0bb170",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae572b25-cd48-4e51-9750-42aad45ad7ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aceb8a67-0126-4439-9ccc-ee6689c6b779",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "275f81cb-2a57-4007-944f-6c7630e2691b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c7e314d-0c8d-4486-8594-c25293cd2277",
   "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
}
