{
 "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 1994]\n",
      " [   1   45]\n",
      " [   2   36]\n",
      " [   3   70]\n",
      " [   4  100]\n",
      " [   5  180]\n",
      " [   6  263]\n",
      " [   7  473]\n",
      " [   8  729]\n",
      " [   9 1236]]\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 1161]\n",
      " [   1 2025]\n",
      " [   2   57]\n",
      " [   3   46]\n",
      " [   4   57]\n",
      " [   5   83]\n",
      " [   6  147]\n",
      " [   7  240]\n",
      " [   8  404]\n",
      " [   9  732]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "66be2793-b403-43b1-9269-30f94e832cf4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  714]\n",
      " [   1 1181]\n",
      " [   2 1946]\n",
      " [   3   55]\n",
      " [   4   24]\n",
      " [   5   54]\n",
      " [   6   90]\n",
      " [   7  150]\n",
      " [   8  269]\n",
      " [   9  392]]\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  486]\n",
      " [   1  738]\n",
      " [   2 1239]\n",
      " [   3 2085]\n",
      " [   4   56]\n",
      " [   5   30]\n",
      " [   6   47]\n",
      " [   7   80]\n",
      " [   8  149]\n",
      " [   9  283]]\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  251]\n",
      " [   1  434]\n",
      " [   2  717]\n",
      " [   3 1166]\n",
      " [   4 2048]\n",
      " [   5   63]\n",
      " [   6   35]\n",
      " [   7   59]\n",
      " [   8  107]\n",
      " [   9  155]]\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  168]\n",
      " [   1  248]\n",
      " [   2  416]\n",
      " [   3  728]\n",
      " [   4 1146]\n",
      " [   5 2013]\n",
      " [   6   53]\n",
      " [   7   33]\n",
      " [   8   40]\n",
      " [   9   75]]\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   98]\n",
      " [   1  149]\n",
      " [   2  277]\n",
      " [   3  410]\n",
      " [   4  730]\n",
      " [   5 1188]\n",
      " [   6 2027]\n",
      " [   7   56]\n",
      " [   8   28]\n",
      " [   9   59]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   54]\n",
      " [   1   84]\n",
      " [   2  153]\n",
      " [   3  206]\n",
      " [   4  415]\n",
      " [   5  692]\n",
      " [   6 1193]\n",
      " [   7 2028]\n",
      " [   8   56]\n",
      " [   9   33]]\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   34]\n",
      " [   1   50]\n",
      " [   2  102]\n",
      " [   3  147]\n",
      " [   4  249]\n",
      " [   5  405]\n",
      " [   6  698]\n",
      " [   7 1178]\n",
      " [   8 1989]\n",
      " [   9   61]]\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   46]\n",
      " [   2   57]\n",
      " [   3   87]\n",
      " [   4  175]\n",
      " [   5  292]\n",
      " [   6  447]\n",
      " [   7  703]\n",
      " [   8 1229]\n",
      " [   9 1974]]\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",
    "        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": "41ae4ab7-9252-46b1-bc56-d47b49ec2a30",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=350)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1004}, {'accuracy': 0.1}, {'accuracy': 0.10191000000000001}, {'accuracy': 0.1}, {'accuracy': 0.10750000000000001}, {'accuracy': 0.10500000000000001}, {'accuracy': 0.10102}, {'accuracy': 0.10485}, {'accuracy': 0.10371999999999999}, {'accuracy': 0.10213000000000001}, {'accuracy': 0.10949}, {'accuracy': 0.10266}, {'accuracy': 0.11721}, {'accuracy': 0.11099}, {'accuracy': 0.10888}, {'accuracy': 0.12625}, {'accuracy': 0.10210000000000001}, {'accuracy': 0.11688000000000001}, {'accuracy': 0.10607}, {'accuracy': 0.1324}, {'accuracy': 0.11445000000000001}, {'accuracy': 0.14652}, {'accuracy': 0.10794999999999999}, {'accuracy': 0.10923000000000001}, {'accuracy': 0.10590000000000002}, {'accuracy': 0.15855000000000002}, {'accuracy': 0.14711}, {'accuracy': 0.13355999999999998}, {'accuracy': 0.1481}, {'accuracy': 0.14077}, {'accuracy': 0.15375}, {'accuracy': 0.14726999999999998}, {'accuracy': 0.15527000000000002}, {'accuracy': 0.13667}, {'accuracy': 0.14748999999999998}, {'accuracy': 0.1257}, {'accuracy': 0.15858999999999998}, {'accuracy': 0.18302000000000002}, {'accuracy': 0.19383}, {'accuracy': 0.16994}, {'accuracy': 0.17817}, {'accuracy': 0.17915}, {'accuracy': 0.187}, {'accuracy': 0.18309999999999998}, {'accuracy': 0.18234}, {'accuracy': 0.18658999999999998}, {'accuracy': 0.17207}, {'accuracy': 0.16479000000000002}, {'accuracy': 0.17141}, {'accuracy': 0.20234999999999997}, {'accuracy': 0.16714}, {'accuracy': 0.19849999999999998}, {'accuracy': 0.17156999999999997}, {'accuracy': 0.21098}, {'accuracy': 0.20729999999999998}, {'accuracy': 0.21234000000000003}, {'accuracy': 0.21737}, {'accuracy': 0.2166}, {'accuracy': 0.19347}, {'accuracy': 0.20063}, {'accuracy': 0.22319000000000006}, {'accuracy': 0.22356999999999996}, {'accuracy': 0.23308}, {'accuracy': 0.24329}, {'accuracy': 0.24496999999999997}, {'accuracy': 0.2052}, {'accuracy': 0.22437}, {'accuracy': 0.21728}, {'accuracy': 0.19773}, {'accuracy': 0.24158000000000004}, {'accuracy': 0.25092000000000003}, {'accuracy': 0.26063}, {'accuracy': 0.20479000000000003}, {'accuracy': 0.24689}, {'accuracy': 0.26125999999999994}, {'accuracy': 0.213}, {'accuracy': 0.22548000000000004}, {'accuracy': 0.25577}, {'accuracy': 0.2841000000000001}, {'accuracy': 0.20937999999999998}, {'accuracy': 0.24711}, {'accuracy': 0.25848}, {'accuracy': 0.25417}, {'accuracy': 0.2694599999999999}, {'accuracy': 0.23914999999999997}, {'accuracy': 0.26297}, {'accuracy': 0.27601}, {'accuracy': 0.25032}, {'accuracy': 0.26967}, {'accuracy': 0.28221999999999997}, {'accuracy': 0.30364}, {'accuracy': 0.26003000000000004}, {'accuracy': 0.25825}, {'accuracy': 0.28409999999999996}, {'accuracy': 0.28603}, {'accuracy': 0.27407000000000004}, {'accuracy': 0.28758}, {'accuracy': 0.30151000000000006}, {'accuracy': 0.3149700000000001}, {'accuracy': 0.30554}, {'accuracy': 0.3149}, {'accuracy': 0.29869999999999997}, {'accuracy': 0.31068999999999997}, {'accuracy': 0.30394999999999994}, {'accuracy': 0.30583000000000005}, {'accuracy': 0.3323999999999999}, {'accuracy': 0.33934}, {'accuracy': 0.30939999999999995}, {'accuracy': 0.33638999999999997}, {'accuracy': 0.35082}, {'accuracy': 0.35111}, {'accuracy': 0.34192}, {'accuracy': 0.33056}, {'accuracy': 0.35313999999999995}, {'accuracy': 0.33553}, {'accuracy': 0.34019000000000005}, {'accuracy': 0.33941}, {'accuracy': 0.34936}, {'accuracy': 0.33407}, {'accuracy': 0.33267}, {'accuracy': 0.36904000000000003}, {'accuracy': 0.35129}, {'accuracy': 0.35983}, {'accuracy': 0.36872}, {'accuracy': 0.35479000000000005}, {'accuracy': 0.35441}, {'accuracy': 0.38798}, {'accuracy': 0.36952}, {'accuracy': 0.36490999999999996}, {'accuracy': 0.33730000000000004}, {'accuracy': 0.37026}, {'accuracy': 0.37763}, {'accuracy': 0.38505}, {'accuracy': 0.37663}, {'accuracy': 0.37739}, {'accuracy': 0.34861000000000003}, {'accuracy': 0.37746}, {'accuracy': 0.37122}, {'accuracy': 0.37745}, {'accuracy': 0.38175000000000003}, {'accuracy': 0.39108}, {'accuracy': 0.38803}, {'accuracy': 0.39544}, {'accuracy': 0.39619000000000004}, {'accuracy': 0.41337}, {'accuracy': 0.40911}, {'accuracy': 0.41136}, {'accuracy': 0.4136699999999999}, {'accuracy': 0.39378}, {'accuracy': 0.41083}, {'accuracy': 0.3955000000000001}, {'accuracy': 0.40674}, {'accuracy': 0.41829}, {'accuracy': 0.40356000000000003}, {'accuracy': 0.40001}, {'accuracy': 0.42377000000000004}, {'accuracy': 0.40137999999999996}, {'accuracy': 0.40555}, {'accuracy': 0.41995000000000005}, {'accuracy': 0.43080999999999997}, {'accuracy': 0.45043999999999995}, {'accuracy': 0.42638}, {'accuracy': 0.41533}, {'accuracy': 0.42161}, {'accuracy': 0.43637}, {'accuracy': 0.4363}, {'accuracy': 0.45895}, {'accuracy': 0.43658}, {'accuracy': 0.43549}, {'accuracy': 0.42469}, {'accuracy': 0.422}, {'accuracy': 0.44075999999999993}, {'accuracy': 0.42664}, {'accuracy': 0.42058}, {'accuracy': 0.45531}, {'accuracy': 0.43415}, {'accuracy': 0.44787999999999994}, {'accuracy': 0.44289999999999996}, {'accuracy': 0.45249000000000006}, {'accuracy': 0.4508599999999999}, {'accuracy': 0.43806}, {'accuracy': 0.4311400000000001}, {'accuracy': 0.42435}, {'accuracy': 0.45724}, {'accuracy': 0.44793000000000005}, {'accuracy': 0.4524100000000001}, {'accuracy': 0.45309}, {'accuracy': 0.47287999999999997}, {'accuracy': 0.46649}, {'accuracy': 0.45442}, {'accuracy': 0.44875}, {'accuracy': 0.45016000000000006}, {'accuracy': 0.46804000000000007}, {'accuracy': 0.46084}, {'accuracy': 0.46242}, {'accuracy': 0.46360999999999997}, {'accuracy': 0.47235999999999995}, {'accuracy': 0.46502999999999994}, {'accuracy': 0.47606000000000004}, {'accuracy': 0.47795}, {'accuracy': 0.47388}, {'accuracy': 0.48563999999999996}, {'accuracy': 0.47884000000000004}, {'accuracy': 0.48369}, {'accuracy': 0.48825}, {'accuracy': 0.48427}, {'accuracy': 0.48907}, {'accuracy': 0.4923}, {'accuracy': 0.49253}, {'accuracy': 0.49178000000000005}, {'accuracy': 0.49054000000000003}, {'accuracy': 0.48993000000000003}, {'accuracy': 0.48064999999999997}, {'accuracy': 0.48878000000000005}, {'accuracy': 0.4981400000000001}, {'accuracy': 0.49576000000000003}, {'accuracy': 0.4975200000000001}, {'accuracy': 0.49666000000000005}, {'accuracy': 0.49573}, {'accuracy': 0.49616000000000005}, {'accuracy': 0.49837}, {'accuracy': 0.4960000000000001}, {'accuracy': 0.4969099999999999}, {'accuracy': 0.49942999999999993}, {'accuracy': 0.4986}, {'accuracy': 0.4970899999999999}, {'accuracy': 0.49899000000000004}, {'accuracy': 0.49967999999999996}, {'accuracy': 0.50022}, {'accuracy': 0.50005}, {'accuracy': 0.49725}, {'accuracy': 0.50056}, {'accuracy': 0.49978000000000006}, {'accuracy': 0.49397}, {'accuracy': 0.50273}, {'accuracy': 0.49948000000000004}, {'accuracy': 0.49910000000000004}, {'accuracy': 0.49657000000000007}, {'accuracy': 0.50167}, {'accuracy': 0.4971000000000001}, {'accuracy': 0.5000000000000001}, {'accuracy': 0.50065}, {'accuracy': 0.5010899999999999}, {'accuracy': 0.49557}, {'accuracy': 0.5013500000000001}, {'accuracy': 0.50149}, {'accuracy': 0.50278}, {'accuracy': 0.49610000000000004}, {'accuracy': 0.49762000000000006}, {'accuracy': 0.5007299999999999}, {'accuracy': 0.49985}, {'accuracy': 0.5016}, {'accuracy': 0.49928999999999996}, {'accuracy': 0.5012}, {'accuracy': 0.50363}, {'accuracy': 0.5008900000000001}, {'accuracy': 0.49731}, {'accuracy': 0.49707999999999997}, {'accuracy': 0.49649}, {'accuracy': 0.49817}, {'accuracy': 0.50094}, {'accuracy': 0.49896}, {'accuracy': 0.5010199999999999}, {'accuracy': 0.4991}, {'accuracy': 0.4980399999999999}, {'accuracy': 0.49800000000000005}, {'accuracy': 0.49822}, {'accuracy': 0.49734}, {'accuracy': 0.50204}, {'accuracy': 0.4994300000000001}, {'accuracy': 0.49812}, {'accuracy': 0.49978000000000006}, {'accuracy': 0.49642}, {'accuracy': 0.50241}, {'accuracy': 0.50051}, {'accuracy': 0.49924999999999997}, {'accuracy': 0.49543}, {'accuracy': 0.50194}, {'accuracy': 0.49938000000000005}, {'accuracy': 0.4996800000000001}, {'accuracy': 0.5010100000000001}, {'accuracy': 0.49711999999999995}, {'accuracy': 0.49763}, {'accuracy': 0.49828}, {'accuracy': 0.49801}, {'accuracy': 0.49707999999999986}, {'accuracy': 0.50087}, {'accuracy': 0.4995}, {'accuracy': 0.4962000000000001}, {'accuracy': 0.49666999999999994}, {'accuracy': 0.49806}, {'accuracy': 0.49496}, {'accuracy': 0.49765}, {'accuracy': 0.4971}, {'accuracy': 0.49946999999999997}, {'accuracy': 0.50021}, {'accuracy': 0.49695}, {'accuracy': 0.49575}, {'accuracy': 0.49732000000000004}, {'accuracy': 0.4959700000000001}, {'accuracy': 0.48866}, {'accuracy': 0.47824999999999995}, {'accuracy': 0.44164000000000003}, {'accuracy': 0.4587299999999999}, {'accuracy': 0.47612}, {'accuracy': 0.48305999999999993}, {'accuracy': 0.49238}, {'accuracy': 0.49517999999999995}, {'accuracy': 0.49449}, {'accuracy': 0.49268999999999996}, {'accuracy': 0.49444}, {'accuracy': 0.49808}, {'accuracy': 0.49782000000000004}, {'accuracy': 0.49917000000000006}, {'accuracy': 0.49887}, {'accuracy': 0.49990999999999997}, {'accuracy': 0.49758000000000013}, {'accuracy': 0.49842}, {'accuracy': 0.49729999999999996}, {'accuracy': 0.49872999999999995}, {'accuracy': 0.49524}, {'accuracy': 0.49573999999999996}, {'accuracy': 0.49535999999999997}, {'accuracy': 0.49643000000000004}, {'accuracy': 0.49716000000000005}, {'accuracy': 0.49573}, {'accuracy': 0.49443000000000004}, {'accuracy': 0.49985}, {'accuracy': 0.49812}, {'accuracy': 0.49912999999999996}, {'accuracy': 0.49767}, {'accuracy': 0.49829999999999997}, {'accuracy': 0.49895000000000006}, {'accuracy': 0.5011599999999999}, {'accuracy': 0.50303}, {'accuracy': 0.49685000000000007}, {'accuracy': 0.49404000000000003}, {'accuracy': 0.49507}, {'accuracy': 0.49437}, {'accuracy': 0.4949}, {'accuracy': 0.49859}, {'accuracy': 0.49493}, {'accuracy': 0.49548000000000003}, {'accuracy': 0.49481}, {'accuracy': 0.49806999999999996}]\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": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACKtUlEQVR4nO3deViU5foH8O/MwCzsIPuibC65ICpplltKYquVlVknl8o6mac6VJan0sw6lpXHFlOPJ7Ndy1/7ghWJpeKuuW8I4sK+DQzMDMy8vz9m5mVeZkBQEAa+n+uay5l3m+cFZG7u536eRyYIggAiIiKiLkTe3g0gIiIiutwYABEREVGXwwCIiIiIuhwGQERERNTlMAAiIiKiLocBEBEREXU5DICIiIioy2EARERERF0OAyAiIiLqchgAEVG7y8jIgEwmQ0ZGhrht+vTpiI6Obrc2dSYvvvgiZDJZezeDqENhAETUCRw6dAh/+9vfEBERAZVKhfDwcNx77704dOhQezetzb333ntYs2ZNm77H4cOH8eKLLyInJ6dN3+dy+ve//41vvvmmvZtB1G4YABG5uK+++gqDBw9Geno6ZsyYgffeew8PPPAANm7ciMGDB+Prr79u7ya2qcsVAC1YsIABEFEn4tbeDSCii5eVlYX77rsPsbGx+OOPPxAUFCTue/zxxzFy5Ejcd9992L9/P2JjYy9bu3Q6HTw9PS/b+7kCfk2IOhZmgIhc2Ouvv47q6mr897//lQQ/ABAYGIiVK1dCp9Nh8eLFAID169dDJpNh06ZNDtdauXIlZDIZDh48KG47evQo7rjjDgQEBECtViMpKQnfffed5Lw1a9aI15w1axaCg4MRGRkJADh9+jRmzZqF3r17Q6PRoFu3brjzzjtbLZMSHR2NQ4cOYdOmTZDJZJDJZBgzZoy4v7y8HE888QSioqKgUqkQHx+P1157DWazWXKdtWvXYsiQIfD29oaPjw8GDBiAt956S7y/O++8EwBw7bXXiu9jX6/U0PTp0+Hl5YWsrCzccMMN8Pb2xr333gsAMJvNWLp0Kfr16we1Wo2QkBA8/PDDKCsrk1xj165dSElJQWBgIDQaDWJiYnD//feL+53VTQFATk4OZDJZk1kxmUwGnU6HDz/8ULyf6dOnAwAqKyvxxBNPIDo6GiqVCsHBwbjuuuuwZ8+eRq9H5IqYASJyYd9//z2io6MxcuRIp/tHjRqF6Oho/PjjjwCAG2+8EV5eXvjiiy8wevRoybHr1q1Dv3790L9/fwCWuqJrrrkGERERePbZZ+Hp6YkvvvgCt956K/7v//4Pt912m+T8WbNmISgoCPPmzYNOpwMA7Ny5E1u3bsXdd9+NyMhI5OTkYPny5RgzZgwOHz4MDw+PS7r/pUuX4h//+Ae8vLzw3HPPAQBCQkIAANXV1Rg9ejTOnTuHhx9+GN27d8fWrVsxd+5c5OXlYenSpQCAX3/9FVOmTMG4cePw2muvAQCOHDmCLVu24PHHH8eoUaPw2GOP4e2338a//vUvXHHFFQAg/tuYuro6pKSkYMSIEXjjjTfEe3344YexZs0azJgxA4899hiys7Px7rvvYu/evdiyZQvc3d1RWFiI8ePHIygoCM8++yz8/PyQk5ODr7766pK+XjYff/wxHnzwQQwdOhQPPfQQACAuLg4A8Pe//x3r16/H7Nmz0bdvX5SUlGDz5s04cuQIBg8e3CrvT9QhCETkksrLywUAwsSJE5s87pZbbhEACFqtVhAEQZgyZYoQHBws1NXVicfk5eUJcrlceOmll8Rt48aNEwYMGCDo9Xpxm9lsFq6++mqhZ8+e4rYPPvhAACCMGDFCck1BEITq6mqH9mRmZgoAhI8++kjctnHjRgGAsHHjRnHbtGnThB49ejR5b4IgCP369RNGjx7tsH3hwoWCp6encPz4ccn2Z599VlAoFEJubq4gCILw+OOPCz4+Pg5tt/fll186tK8p06ZNEwAIzz77rGT7n3/+KQAQPv30U8n2tLQ0yfavv/5aACDs3Lmz0fdw9jUTBEHIzs4WAAgffPCBuG3+/PlCw1/3np6ewrRp0xyu6+vrKzz66KPNuEsi18YuMCIXVVlZCQDw9vZu8jjbfq1WCwCYPHkyCgsLJV0n69evh9lsxuTJkwEApaWl+P3333HXXXehsrISxcXFKC4uRklJCVJSUnDixAmcO3dO8j4zZ86EQqGQbNNoNOLz2tpalJSUID4+Hn5+fm3epfLll19i5MiR8Pf3F9tfXFyM5ORkmEwm/PHHHwAAPz8/6HQ6/Prrr63ehkceecShTb6+vrjuuuskbRoyZAi8vLywceNGsU0A8MMPP6C2trbV29UUPz8/bN++HefPn7+s70t0uTEAInJRtsDGFgg1pmGgNGHCBPj6+mLdunXiMevWrUNiYiJ69eoFADh58iQEQcALL7yAoKAgyWP+/PkAgMLCQsn7xMTEOLx3TU0N5s2bJ9bgBAYGIigoCOXl5aioqLjIO2+eEydOIC0tzaH9ycnJkvbPmjULvXr1wvXXX4/IyEjcf//9SEtLu+T3d3NzE2uh7NtUUVGB4OBgh3ZVVVWJbRo9ejQmTZqEBQsWIDAwEBMnTsQHH3wAg8Fwye26kMWLF+PgwYOIiorC0KFD8eKLL+LUqVNt/r5ElxtrgIhclK+vL8LCwrB///4mj9u/fz8iIiLg4+MDAFCpVLj11lvx9ddf47333kNBQQG2bNmCf//73+I5tiLhp556CikpKU6vGx8fL3ltn+2x+cc//oEPPvgATzzxBIYPHw5fX1/IZDLcfffdDoXIrc1sNuO6667DnDlznO63BXvBwcHYt28fNmzYgJ9//hk///wzPvjgA0ydOhUffvjhRb+/SqWCXC79G9NsNiM4OBiffvqp03NshewymQzr16/Htm3b8P3332PDhg24//778eabb2Lbtm3w8vJqdGJDk8l00W0GgLvuugsjR47E119/jV9++QWvv/46XnvtNXz11Ve4/vrrL+naRB0JAyAiF3bTTTdh1apV2Lx5M0aMGOGw/88//0ROTg4efvhhyfbJkyfjww8/RHp6Oo4cOQJBEMTuLwDikHl3d3cxY3Ix1q9fj2nTpuHNN98Ut+n1epSXl1/0NRtqLBCIi4tDVVVVs9qvVCpx88034+abb4bZbMasWbOwcuVKvPDCC4iPj2+1WZTj4uLw22+/4ZprrnEaMDZ01VVX4aqrrsIrr7yCzz77DPfeey/Wrl2LBx98EP7+/gDg8LU8ffp0s9rS1D2FhYVh1qxZmDVrFgoLCzF48GC88sorDICoU2EXGJELe/rpp6HRaPDwww+jpKREsq+0tBR///vf4eHhgaefflqyLzk5GQEBAVi3bh3WrVuHoUOHSrqwgoODMWbMGKxcuRJ5eXkO71tUVNSs9ikUCgiCINn2zjvvXHKWwp6np6fTgOquu+5CZmYmNmzY4LCvvLwcdXV1AODwdZPL5UhISAAAscvJNn/PpQZud911F0wmExYuXOiwr66uTrx+WVmZw9ctMTFR0qYePXpAoVCItUw27733XrPa4uzrZjKZHLomg4ODER4eflm634guJ2aAiFxYz5498eGHH+Lee+/FgAED8MADDyAmJgY5OTl4//33UVxcjM8//1wc4mzj7u6O22+/HWvXroVOp8Mbb7zhcO1ly5ZhxIgRGDBgAGbOnInY2FgUFBQgMzMTZ8+exV9//XXB9t100034+OOP4evri759+yIzMxO//fYbunXr1mpfgyFDhmD58uV4+eWXER8fj+DgYIwdOxZPP/00vvvuO9x0002YPn06hgwZAp1OhwMHDmD9+vXIyclBYGAgHnzwQZSWlmLs2LGIjIzE6dOn8c477yAxMVEc6p6YmAiFQoHXXnsNFRUVUKlUGDt2LIKDg1vU1tGjR+Phhx/GokWLsG/fPowfPx7u7u44ceIEvvzyS7z11lu444478OGHH+K9997Dbbfdhri4OFRWVmLVqlXw8fHBDTfcAMDSBXrnnXfinXfegUwmQ1xcHH744QeH2qymvm6//fYblixZgvDwcMTExKB3796IjIzEHXfcgYEDB8LLywu//fYbdu7cKcniEXUK7TsIjYhaw/79+4UpU6YIYWFhgru7uxAaGipMmTJFOHDgQKPn/PrrrwIAQSaTCWfOnHF6TFZWljB16lQhNDRUcHd3FyIiIoSbbrpJWL9+vXiMbRi8syHbZWVlwowZM4TAwEDBy8tLSElJEY4ePSr06NFDMgT7UobB5+fnCzfeeKPg7e0tAJAMia+srBTmzp0rxMfHC0qlUggMDBSuvvpq4Y033hCMRqMgCIKwfv16Yfz48UJwcLCgVCqF7t27Cw8//LCQl5cneZ9Vq1YJsbGxgkKhuOCQ+GnTpgmenp6N7v/vf/8rDBkyRNBoNIK3t7cwYMAAYc6cOcL58+cFQRCEPXv2CFOmTBG6d+8uqFQqITg4WLjpppuEXbt2Sa5TVFQkTJo0SfDw8BD8/f2Fhx9+WDh48GCzhsEfPXpUGDVqlKDRaAQAwrRp0wSDwSA8/fTTwsCBAwVvb2/B09NTGDhwoPDee+819S0gckkyQWiQZyUiIiLq5FgDRERERF0OAyAiIiLqchgAERERUZfDAIiIiIi6HAZARERE1OUwACIiIqIuhxMhOmE2m3H+/Hl4e3u32hT4RERE1LYEQUBlZSXCw8Md1uJriAGQE+fPn0dUVFR7N4OIiIguwpkzZxAZGdnkMQyAnPD29gZg+QLaVtAmIiKijk2r1SIqKkr8HG8KAyAnbN1ePj4+DICIiIhcTHPKV1gETURERF0OAyAiIiLqchgAERERUZfDAIiIiIi6HAZARERE1OUwACIiIqIuhwEQERERdTkMgIiIiKjLYQBEREREXQ4DICIiIupyGAARERFRl8MAiIiIiLocBkBERNShmcwCaoym9m4GdTIdIgBatmwZoqOjoVarMWzYMOzYsaPRY9esWQOZTCZ5qNVqyTGCIGDevHkICwuDRqNBcnIyTpw40da3QUTUpVTU1CIzqwSCILT4XEEQsPlEMU4WVjV5nNksYMaanbjyld9wvKDyYpt6QYY600XdR1dXoNXjtbSjOF2ia++mtFi7B0Dr1q1Damoq5s+fjz179mDgwIFISUlBYWFho+f4+PggLy9PfJw+fVqyf/HixXj77bexYsUKbN++HZ6enkhJSYFer2/r2yEi6jL+/eMRTFm1DSs2nRK31RhNWLsjF5X6WqfnGOvM2H6qBHPW78ff3t+Oaat3OAQeJVUG/H60AGazgM925OKP40WoMtRh4Q+HLylI+elAHh75ZDeKKg2S7dnFOiQu+BUzP9qNOpMZgCVAW/rbcXycmXPR79fZ6Qx1SFn6B5ZnZOGNX463d3NazK29G7BkyRLMnDkTM2bMAACsWLECP/74I1avXo1nn33W6TkymQyhoaFO9wmCgKVLl+L555/HxIkTAQAfffQRQkJC8M033+Duu+9umxshIupkDHUm7D9bAY27Aj1DvFClr8PanWcwpncQ+oX7Yt2uMwCA19KO4oERMVC6yfH27yewPCMLf52twIJb+uHng3n4Zu857DtTjpmjYnH4vBY/7M8T3+NceQ1yS6sR6KXC6xuOIcJPgzVbc3CuvAZ3JUXi5wP54rF/nihGxrEiXNsnWNxmrDPj8bV7oVEqcEP/MLy+4RhmXRuHiYkRknsxmwW89P1h5Gv1cFPI8c6UQeK+nw7koabWhN+OFODlH49g/s19cei8Fkt/s/Qc9AzxhodSgTnr92Nsn2DMmdDH4Wt1+LwWC384jKnDe+D6AWEX/NqWVBlQbTQhKsCjmd+NiycIAmQyWatfc876/SivtgS63/91Hm/fndjq79OW2jUAMhqN2L17N+bOnStuk8vlSE5ORmZmZqPnVVVVoUePHjCbzRg8eDD+/e9/o1+/fgCA7Oxs5OfnIzk5WTze19cXw4YNQ2ZmptMAyGAwwGCo/4tAq9W2xu0REbmE9CMFOHhOi3uGdUeQtwpnSqvx/uZsfLXnLLT6OgBAn1BvRPpr8NuRQry+4RgeGxsvucb87w7i4VFx2HDQErD8dCAPxwsqsft0mXjM6s3Z0BkstTxDYwKwI7sUALArpwynS3RYszVHcs0vdp0FACT18MfAKD+8vzkbyzOyJAHQp9tP42fre3699xwEAXjqy78Q7qfBldEB4nF7z5QhX2vpBfj+r/O4fXAEfj1cgOP5lTDUmcXj1mzNQXm1EX3DfcRtj32+F0VVBggCcDS/EtOviUawt7T04o1fjiHzVAkyT5Vg4cR+uG94tNOvtcksYNFPR/BR5mkIEPD1rGvQP8LX6bEXq6KmFltPFkMA8Hb6Cajc5Ph05lXwUlk+8gVBgCAAcnnTwcofx4vwzP/txz+Te2FwD39o9bUY3N0fAPB/e87hxwN5kuOzinSID/Zq1XtpS+0aABUXF8NkMiEkJESyPSQkBEePHnV6Tu/evbF69WokJCSgoqICb7zxBq6++mocOnQIkZGRyM/PF6/R8Jq2fQ0tWrQICxYsaIU7IiJqf+XVRnyx6wxuHxyJbp5KAJD8Zf7TgTz8dqQAL9zYFyU6I/7+yW7UmgSs/CML/0zuhXd+PyEGPoFeSlTq63A0vxJH8+trcN7+/aTkPT/fcQaf7zgjvq6oqcXu02XwVCow/ZpoLNuYheIqo/WaKqx76Cq8+vNRrPzjFNKPFuDP48XiuWG+asQHe+HPE8UI9VHjvXsHwywAH27NwY6cUhw8V4H+Eb4orzbirfT6+k5BAJRuchjrzLjv/e2YcU0MvNVuKNQa8NuRAgD1+2d8sNPh6zb96mh8vO00vtl3HhsOFYjbCxt0mX2+/Qz6hvsg/UgBfDTuiA/ywu9H68s2Xv7xCCb0D4Ovxh0/H8zDsJhuCPJWocpQh/W7z+J/m7PFY5dtPInlfxvS6PeyJb776zzKdEa8vzkbuaXVkn2zP9sDABjfNxQ/H8zDsfxKfDd7BEJ91c4uBQBYsSkLeRV6zPm//ZDLALMAzBwZg6wiHTYes9zv0ym9sflEsRj8NQyAPtl2Gp9tz8Xyvw1Gj26eAIAjeVp8vO00/j4qDt27tX0GrDHt3gXWUsOHD8fw4cPF11dffTWuuOIKrFy5EgsXLryoa86dOxepqania61Wi6ioqEtuKxFRe3h/czbe+f0kVm46hZ4hXsgprsYTyT1xZ1IUThRW4ol1+2CsM8NQZ0ZJlQG1JgEeSgWqjSa88tMRAEC/cB/MmdAHI+ID8fmOXDz/zUEAwLg+wdh1ugwVNZauj+Gx3XBnUiSWZ2ThhJOC5tlje+KRMXE4ll8lBiEj4rtBJpMhKToAK/84hZ+s3Vx9Qr3x/T9GwCwIqDUJWLsjF9f1DUGwj+VD+oYBYfjur/OY/dkejOkdjEPnK1BeXYteIV64+8ru2HKyGP+68Qq8+N0h/HmiGMszshzas3hSAr7767wkYAEAH7Ub5t/cF90DPPDSD4dRU2vJVC24pR9qTWZcEeaDc2U1mPN/+/Gf35zXu1wd1w01tSbszS3Hop+PoECrx5aTlqCgf7gPvtl3Hraky73DuuPT7blIO5SPv86U45Ntp1Gpr8PLt/VHoJeqRd9vAPjzRBEe+3yv+DrQSwVPlQJ9Qr2x4VABMo4VAYD4LwCs3pKNf91wBQBLF+FvRwrw7V/nccvAcIzpHYS9ueXisWZr6dWqP+uDt1sGhuPvo+NQZxKQeaoE206V4L6reoj7q411eC3tKCr1dXhvYxZeuyMBALA8Iwvf/XUe2ppavHvP4Bbfa2tp1wAoMDAQCoUCBQUFku0FBQWN1vg05O7ujkGDBuHkSctfI7bzCgoKEBZW3w9bUFCAxMREp9dQqVRQqVr+A0dE1BH9dsTy4V6iM6LklKWb6dmvDmDN1hxoa2phtHb5/GitxVG5yfHTYyOxbONJfLn7LMJ91fjw/qHiB/HdV0bhk22ncbKwCv8Y1xMrN2WJ3U59wrxx++BI9A71xo1vbwYA3JoYjm/2nUeYrxrTr44GAIzuHVQfAPUMAgAM6eEvafez1/eBu0JubRPw4MhYyf6ZI2Pxw/7zyCmpFrvLvFVuWDp5EPqG++D+ETEAgA9nDMX/7TmLbadKIUCAyk2Br/eeRZC3ChP6h+LmgeH4YtcZRPhpMHW1ZdRxTKAnZDIZ7kyKxBu/HEO10QSlmxx3D42Cyk0BwFLg/WraUZTqjAj0UuGmhDBUG+vw1Z5zqDMLmHZ1NGQAHvp4N77ac05s98nCKnG0m1mwBEov39ofxVUGbDhUgFvf2wJbbffhPC2+mnX1BYOgOpMZCrlMzOyt2ZIj7ps0OBLPXt8HQd6Wayz55Rg+23EG18R3ww/782CyRjP//eMUFHIZwn3V+P6vPOzIKRV/Lm4eGI6aWhO6eSrxRHJPdO/mieP5lfhk+2kkXxGCe4d1R2yQJdszPK4b/vMb8MexIpTpjPC3Zh2/2XseldZM4td7z2FC/1AIEPDD/vMAgEfGxDV5j21NJrTzuL9hw4Zh6NCheOeddwAAZrMZ3bt3x+zZsxstgrZnMpnQr18/3HDDDViyZAkEQUB4eDieeuopPPnkkwAsGZ3g4GCsWbOmWUXQWq0Wvr6+qKiogI+PzwWPJyLqSEYu/h1nSmsAWIKbGdfE4NPtp8UPo1AfNcZeEYzPtuci1EeNf9/eH2P7hMBsFvDHiSL0C/cVPzxtKmpqUaYzIjrQE59uP43nvrZkhBZPSsBdV1oy5h9l5mDj0UIsvXsQjuZpEe6nEYt8z5RWY+TijQCAbXPHiV0vk5Zvxb4z5Vhy10CHwmVnsot12H+2HOlHCnEsvxILb+2PoTEBFzxPZ6iDAIh1MDYbDuXjpe8P4627E5FkrRma+9V+fL7jDIZGB+CLvw+XHJ9drENeeQ2ujAkQg7WcYh3OltVgRM9AmM0CJq3Yir255Rjc3Q/RgZ5iMHTHkEhc2zsYo3oFwlvtjvwKPR78aCcOntNC7S6Hv4cSeRV6PH/jFQ7Bn70d2aWYuno7ort54onkXugb5oPRb2yEIAC/PzlaDEycKdDqoVEqcOuyLThVJB267qFUICk6AH8cr88S3TkkEq/fObDJr63JLODGt//E0fxK9ArxQn6FHuOuCMGO7FKcK6+BQi4Tgy6bsX2CsXr6lU1e92K05PO73QOgdevWYdq0aVi5ciWGDh2KpUuX4osvvsDRo0cREhKCqVOnIiIiAosWLQIAvPTSS7jqqqsQHx+P8vJyvP766/jmm2+we/du9O3bFwDw2muv4dVXX8WHH36ImJgYvPDCC9i/fz8OHz7sMGeQMwyAiMhVVRvr0HfeBgDAwon9MKRHAPqG+6CkyoCv955DoJcK1/YJho/aDXvPlKNPqDc8lC3rDDhdosPo1zMAAN8+eg0GRvk167xPt5+GQibD3UO7i9t0hjpU6uuarEW53PIqarDgu8OYdnU0hsd1a/H5xjoz9HUm+KjdUamvRcp//oBJEJD2+CgxO2KjrzVh/e6zGNTdDxnHivD6hmO4MSEMyxrpGjKZBdz0zmYcyasfrBMf7IWThVUY1SsIH90/tFltTD9SgHnfHkL/CB9UGerg56HEsxP6INJfg//9mS12hb5372Dc0IxRbX8cLxKzafYCvVRIva4X/vX1AXir3aAz1EEmk+HLvw8XC6pbU0s+v9u9Bmjy5MkoKirCvHnzkJ+fj8TERKSlpYlFzLm5uZDL66crKisrw8yZM5Gfnw9/f38MGTIEW7duFYMfAJgzZw50Oh0eeughlJeXY8SIEUhLS2tW8ENE1JEdL6jE4rRjOF2iQ/8IX8waE4eeId7ifltXSzdPpWQkUjcvlUNW4WI/gLoHeODGAWEoqjTgirDm/5F477AeDts8VW7wVLX7R5FEmK8GK+67+MJkpZscSjfL55a32h2/pI4G4Jh9AgC1uwJ/s9bNVFiHlP91przRa3+z9xyO5GnhrXbDdX1D8NWeczhZWAVvlRues9bzNMe4K0Iw7ooQp/tmjopFfIgX9uWWY3xf58c0NKpXEO67qgf+OluOv13VA4fOVSDEV41JgyMR4qPG6N5BCPJSoURngM5Qh/hg7wtftI21ewaoI2IGiIg6qrtWZorDxwHAXSHDi7f0wz1Du0Mmk+H/dp/Fk1/+hatiA7D2oeFNXIk6mkp9LRIW/AJBAHY9n+y0DmjGBzuw8VgRnryuF2ZdG49/rtuHP08U4d17BuOa+MB2aHXH0pLP73afCZqIiJpnZ04pdmSXwl0hw7v3DMK1vYNQaxLw3NcHMfbNTdiaVYzjhZah6j07wF/Y1DLeasuQeqDxLNDxAkuGb1hsNyjkMrw9ZRB2PX8dg5+LwACIiKgDEwQBe3PLYKgzicO67xgSiZsSwrF6+pV49vo+8FQqkF2sw/KMLJy0fkD2CnGdCemonq2eap+TAEhnqMO5cktxe0+7+XYUF5jQkJxjAERE1IF9ufssbntvK55Yuw+brKNzZlpreWQyGf4+Og4fPWApfD1eUD9ZoX1dELmOgZGWWaEPnXdckcBW3xXopXIopqaW61iVZ0REBEOdCW5yORRyGdbvtiwHYZt3p2+Yj8Mw517WYKdAWz9jcUuKk6njiLNmdrKLHVdXP15gCW6Z3WsdzAAREXUgWUVVGDD/F7z0/SEUVuqxM6dUsn9Cf8dJYr3V7gi3G0YeFaCBr8a9zdtKrS820BLc5JZWo9ZkluyzzbTd04XW2+rIGAAREXUgH27NgdFkxoeZp5F2MN+yaKVdicf1TgIgQNrl1S+sdRfXpMsnxEcFjbsCJrPgsJ7XiQJ2b7YmBkBERB2Im928Zys3nQIA/H10HCL9NRjZM7DRDz/7rEC/cHZ/uSqZTIaYQMuiodkNZmq2jQBjBqh1sAaIiKgDyauoEZ/bRvxMGdodT6f0lqzo3lAv+wxQBAMgVxYT5InDeVpJHVBJlUH8eegTyu9va2AARETUgTTs9kiI9BXX02pKzxD7DBC7wFxZrDUDdMouALKtzB4f7AVfD9Z3tQYGQEREHciZBgHQ9f0vvA4TYBn11TPYC928lAj2bnolcerYYoOsXWDFVeK23bllAIDB3f3ao0mdEgMgIqIOYM2WbOw7Uw6tdcV2mxsGOC96bkjtrsCv1jWnyLXFWEeC2a/Wvue0JQAa0qP1FxDtqhgAERG1sy92ncGL3x8WXwd5q7BwYj/UmgT06ObZji2j9hBmndKguMoAQRBQZxaw/2wFgItfwJYcMQAiImpHhZV6PP/1Qcm27gEemNDMri/qfDRKBQDALACGOjOyiqpQU2uCt9oNcUEcAdZaOAyeiKgdHTqnhdFkhpvdZD/uCq7t1JVp3BXi8xqjCefKLKO/YoO8IOe6X62GARARUSvQ15rw4dYchyLmC7ENdb6ub4i4LdL/wqO+qPNyV8jFILi61oTiKiMAIMiL63+1JgZAREStYM3WHMz/7hBufPvPZh3/75+OIOHFDfjjhGWB0x7dPLHhiVGYNDgSc1J6t2VTyQXYskA1xjoUV1nWeAv04ui+1sQaICKiVrDbOkpHq6+DySxAcYGuim/3nYNWX4eMY5YAKLqbB3qHeuPNuwa2eVup4/NQukGrr0O10cQAqI0wA0RE1ApCfeoXIz2ar23y2DKdUbJyOwCO9iIJD6UtA2QfALELrDUxACIiagVafa34fEe2dAX33afLsOFQvvj6aH6lw/nRgaz7oXq2kWDVtSYUV1pqgAI5wWWrYgBERNQKSnVG8fn2U9IAaNLyrXj44904fN6SGTrWIEOkcpMjxFsNIhvnGSAGQK2JARARUSsoq64PgHbm1AdANUaT+Hx7dgkA4FiBNAPUo5sHhzeThEZpKdGtNppQxACoTTAAIiJqBWW6+i6wEp0RFdW11uf1tT5ZRZa1nWxdYD5qy4cc63+oIY275eO5vNqISuvyKEEMgFoVAyAiolZg3wUGAGfKLPMBlVTVb993phxlOiOOWQOg1Ot6wU0uQ0q/5q33RV2HhzUDdNY6CaJSIYePhgO3WxO/mkREl6jGaEJNraWrKy7IE1lFOpwprUb/CF9JBujgOS2u+88mVBtNCPZW4W9X9cD0a2Laq9nUgdmKoHOtE2t281JCJmM3aWtiBoiI6BLZ6n/cFTJcEeYDoD4DVFwlzQwVVxkR3c0Da2YMhZuCv4LJOQ/rRIi2mcVZ/9P6mAEiIrpEtu4vfw8logIsw9nPlFq6LmwjeGy6eSrx9axr4O/JOV2ocR4NMkBBHALf6vjnBxF1WttPlWD8fzYhM6ukTd/HlgEK8FQiyrqO19kGNUDj+4bgyet64dfU0Qx+6IJso8AMdWYAnASxLTAAIqJO6+eD+TheUIWfD+a16nVLdUZ8vO20OPmhLQMU4KlEVIAGAHDGWrxaYs0AJUX74x/jeiKAwQ81g20UmA27wFofAyAi6rQqamol/7aWOev344VvDiJ13V8A7LrAGmSABEFAiXVfN09+gFHz2UaB2TAAan0MgIio0yq3dk2VVzcdABnqTLhn1Ta89duJZl33tyMFkn/LbBkgDyXC/TSQyQB9rRlFVQaxCJrLGFBL2EaB2fDnp/V1iABo2bJliI6OhlqtxrBhw7Bjx45mnbd27VrIZDLceuutku3Tp0+HTCaTPCZMmNAGLSeijsyW+Sm/QAYo7WA+tmaV4D+/HW/WdX017pLXpdX1GSClmxxh1oVRc0uqxS6wbuz6ohbwaBgAsQao1bV7ALRu3TqkpqZi/vz52LNnDwYOHIiUlBQUFhY2eV5OTg6eeuopjBw50un+CRMmIC8vT3x8/vnnbdF8IurAbIFPRbWxyePqTIL4XBDqn/96uAA/7D/vcHy4n0Z8vul4ETYdLwIABHhYAqO+4b4AgO3ZpWIXGLswqCUaZoA4C3Tra/cAaMmSJZg5cyZmzJiBvn37YsWKFfDw8MDq1asbPcdkMuHee+/FggULEBsb6/QYlUqF0NBQ8eHv799Wt0BEHZS2mTVASrf6X4WVBsuyA1WGOsz6dDdmf7YXKzZlSY73tPtwmrZ6B86U1kDlJkdSdAAAYFSvQADA93+dh8lsCahY/EwtwRqgtteuAZDRaMTu3buRnJwsbpPL5UhOTkZmZmaj57300ksIDg7GAw880OgxGRkZCA4ORu/evfHII4+gpKRth8ES0eVXqa/F1NU78MWuMw77BEEQa38qamphNgsOx9iY7PaVW9f0OllYhVprZujVn49ib26ZeEy13QKnABAb6Ik/n7kW/SMsmZ+RPYMA1K/55atxlwRZRBdi3wXmJpc5dLvSpWvXiRCLi4thMpkQEhIi2R4SEoKjR486PWfz5s14//33sW/fvkavO2HCBNx+++2IiYlBVlYW/vWvf+H6669HZmYmFAqFw/EGgwEGQ/1kZVqt9uJuiIguqy0nS/DH8SIUavW4KylKsq/aaEKdNbAxC5bMTmMfIvYBTVm1Ed27eeBEgxXb950px6Du/tbj6yT7bhsUgWBvtfg6upsHQnxUKNBafq/YhsYTNZfGvf6zqpuXEnI5l8FobS41E3RlZSXuu+8+rFq1CoGBgY0ed/fdd4vPBwwYgISEBMTFxSEjIwPjxo1zOH7RokVYsGBBm7SZiNqObfi5bbVsew0Ln7U1tU0EQPXn78wpxbpdZ2C0TkBnc846rw8A6BpkgG4eGC55LZPJMLZPCD7fkQsAePHmfhe6FSIJ+xogdn+1jXYNgAIDA6FQKFBQUCDZXlBQgNBQx9WRs7KykJOTg5tvvlncZjZbfkm5ubnh2LFjiIuLczgvNjYWgYGBOHnypNMAaO7cuUhNTRVfa7VaREVFORxHRB2LbQZmZzU+FQ2GvpdX1yIqwPl17DNAL/94RLIvNsgTp4p0OFdeHwBVG+oDpivCfBAd6Olwzdlj46F2l+PuK7ujd6j3hW+GyI4HA6A2164BkFKpxJAhQ5Ceni4OZTebzUhPT8fs2bMdju/Tpw8OHDgg2fb888+jsrISb731VqNBy9mzZ1FSUoKwsDCn+1UqFVQq/oARuRpbBqjKUIc6k1myuGh5jXTkV8PX9nRGxwySzeheQZIAyGwWUG1d+f2j+4ciIdLX6XkRfhrMZ+aHLpLajQFQW2v3LrDU1FRMmzYNSUlJGDp0KJYuXQqdTocZM2YAAKZOnYqIiAgsWrQIarUa/fv3l5zv5+cHAOL2qqoqLFiwAJMmTUJoaCiysrIwZ84cxMfHIyUl5bLeGxG1LdsEhIClG8x+jS1tjWMGqDE1Dbq07I3pHYwPtuSIXWD6OhNsI+WTov0dRusQtQa5XAaNuwI1tSYEenMEYVto9/+5kydPRlFREebNm4f8/HwkJiYiLS1NLIzOzc2FXN780RMKhQL79+/Hhx9+iPLycoSHh2P8+PFYuHAhszxEnUyJXQCk1ddKAqCGAU9TQ+EbjuqylxjpJ75XjdEEncFyrEwm/SudqLV5KC0BEOcAahvtHgABwOzZs512eQGW4exNWbNmjeS1RqPBhg0bWqllRNSRldlNcNgwwLnQa3sNR3XZRAVo4KNxg5fKDVWGOpwrr4GbdTSOh7uCI3OoTamtI8HYBdY2ODEFEbmsUvsMUI00iGk4Cqy8wWzQL/9wGEutS180zACF+Kjwxp0D8dH9wyCTyRBhnfn5XHmNWC/kqeoQfz9SJ9bNuvxFhD+nUWgL/B9MRC7LvgaosYyPyk0OQ51Zsr9Qq8f/NmcDAB4aFYtqgzQACvfT4I4hkeLrCH8NjhVU4lxZjTg6hwEQtbWXJvbHntNlSOrBlQzaAv8HE5FL0teaJPPxaPUNAiBrDVD3AA+cKKyS1AQVVdVPfJpfoUd1rTR7FO4r/Yu7PgNUjXA/y4SHDRerJGptiVF+SIzya+9mdFrsAiMil1TWoEvLPsOjrzXhaL5lRvce3TwASLvE7LvO8iv0DhmgMF+15LVtJufsYp3YXebJ0V9ELo0BEBG5JPsgBqgf9l5jNGH06xuRVaQDAMRYJyk8eK4CPx/Iczg3r0LvUAMU5ifNAA2I8AMA7M0th846CaKHihkgIlfGAIiIXFKZznnNT1ZRlbgGV4SfBjNHxSKphz+qjSY8vnYfCiv1KKmyywBp9Q4TIYY3yAANjPKFQi5DXoUeJ4uqADADROTqGAARkUsqbdAFprWuB1ag1QMA+kf4YPMz1yLYW43PH7oK3QM8YDSZcTy/CiW6+hqgvIoah4kQwxtkgDyUbugb5gMA+PN4sXUbM0BErowBEBG5pFK7QmagPgOUbw2AQn3UkMks8/S4K+ToGewFAMgp0Um6wE6XVIurxj+R3BO3D4pA/wjH5S2GWEfiHM6z1BZxFBiRa+P/YCJySaXWUV2hPmrka/ViDZCt+yvER9qN1aObpRYop1gn6QI7Za0VAoBHr42Hu8L534WDuvthzdb618wAEbk2ZoCIyCUVWzNA0YGWUV5iAFRRnwGyF2M9rmEGyLbIqVIhbzT4AeozQDbMABG5NgZAROSSckuqAQD9wy3dVbZ5gGxdYCENCpmjraPBsot1DiPIAEBzgYxOhJ8GIT71SxIwA0Tk2hgAEZFLyi62dF0lWCeKq6iphSAIYhF0wwxQtLUL7ExpjWQiRBvPCwQ0MplMkgViBojItTEAIiKXY6gz4XyFpetqYKQlA1RrElBTa6ovgm6QAQr300CpkMNoMqPSOmLMV+Mu7r9QBggABne3C4A4DJ7IpTEAIiKXc6a0GoIAeKnc0D3AAyo3y6+ys2U14pIXId7SAEghl6G7dVZoAJDJIFljqTkZHfsMECdCJHJtDICIqMPbk1uG19KOQl9rma8np9hS/9OjmwdkMhm6B1gCm+3ZpQAAtbscPhrHgMY2KzQABHgocXV8oPha437hgKZfuC+U1mDLoxnHE1HHxQCIiDq8NzYcw/KMLGQcKwRgGckF1Bc224a4bz9VAkA6B5C9SYMjxOf6WhOGx3YTX9sCm6Yo3eSYNrwH+oR6o5+TuYKIyHWwE5uIOjzbvD1F1n/FAMjapWX715YBajgHkE1Kv1DIZIAgAAKAPqHe4r6ThVXNastzN/Zt+Q0QUYfDDBARdXi2WZ4rrMtf2LrAbCO7elgzQUWVltFdti6xhmQyGX7952gMjPLDK7f1h1xenyXKs84fRERdAwMgIuqQak1m8bktALIVOJ8ulXaBRXeTBjxXxgQ0et34YC98++g1uG1QJABg5X1DoJDL8NqkAa3XeCLq8BgAEVGH8/G20+g3fwO2nCyGsc6MGmvxc3lNLcxmAfnWbI1t0VJbJsjmqphuaK6UfqE4/FIKJl/ZvZVaT0SugAEQEXU46UcKYKwzY2tWsTjDM2DJBJVWG1FrEiCTAcHelpmZwxrM+RMVIF3N/UJUbhzRRdTVMAAiog7HtsxFfoVB7P4CgIrqWjH7E+ilEtfucrNbwyvER+V0BBgRkT0GQETUbkqqDKi0y/AAgMks4GyZZZbnAq1eEgCV1xjFAKhh1ifRuiTGAyNi2rDFRNRZcBg8EV02c9b/hdMl1fjw/qHIr9Djlnc3w99TiYynxohZm3ytHkZrAXR+wwCouhZ5tsVOGwx1/+99Q7Azpww3DAi9THdDRK6MARARXRZ1JjO+2HUWALB2Ry5+2J8Hrb4OWn0dqgx18FZb1uU6bZ3jBwAKKvTQ1khrgPKta4A1zAAF+6hxY0JYW98GEXUSDICI6LIo1RnF569vOAad0SS+3nyiGKv+PIWnU/qI9T8AUGmow/ny+vl5DHVm5Fj3NzbZIRFRczAAIqLLotA6SSEAMfixzcr8YWYO9uSW4//2nEWQdWSXzYmCSsnro3laAI4ZICKilmARNBFdFsVVBsnrsX2C0TfMBwBwvMCyDEWBVi/JAAHAsQYBUFaRpYsslAEQEV0CBkBEdFkUW9fxCvRS4aFRsXjjzoEI8FQCqO8eK6o0iLM821apOFHgfI2uUHaBEdElYBcYEV0WtgzQyJ6B+NcNVwCAGADZ5Gv1MJkFAEC/cF8cOFchjghriBkgIroUzAAR0WVRbK0Bsq/x8feQBkDl1bWo1NcBAJKi/Ru9lp+HOzyU/PuNiC5ehwiAli1bhujoaKjVagwbNgw7duxo1nlr166FTCbDrbfeKtkuCALmzZuHsLAwaDQaJCcn48SJE23QciJqLlsGKNCrPuhpmAGyCfZWISZQur6Xv4e7+Hx0r6A2aCERdSXtHgCtW7cOqampmD9/Pvbs2YOBAwciJSUFhYWFTZ6Xk5ODp556CiNHjnTYt3jxYrz99ttYsWIFtm/fDk9PT6SkpECv1zu5EhFdDvY1QDb+jQRAPbp5IDbQS7It1Ld+fa87hkS2QQuJqCtp9wBoyZIlmDlzJmbMmIG+fftixYoV8PDwwOrVqxs9x2Qy4d5778WCBQsQGxsr2ScIApYuXYrnn38eEydOREJCAj766COcP38e33zzTRvfDRE1pj4DVB8ABXg4D4C6B3hieFw3dA/wELcZ6urnDbo6LrCNWklEXUW7BkBGoxG7d+9GcnKyuE0ulyM5ORmZmZmNnvfSSy8hODgYDzzwgMO+7Oxs5OfnS67p6+uLYcOGNXpNg8EArVYreRBR63IWAPl7ujs9tkc3DyjkMkwd3kPc9vT43lC5yfHyrf2hkHOxUyK6NO0aABUXF8NkMiEkJESyPSQkBPn5+U7P2bx5M95//32sWrXK6X7beS255qJFi+Dr6ys+oqKiWnorRNSEOpMZJdah7oHeF64B6tHNkvm568ooBHgqEeGnwXV9Q3B04QT87aoeTs8hImqJdu8Ca4nKykrcd999WLVqFQIDWy8FPnfuXFRUVIiPM2fOtNq1iQgorTZCECwzP9t3ezXWBRZl7fryUbtj45NjsOGfo+CmkIsLphIRXap2HUcaGBgIhUKBgoICyfaCggKEhjqu6JyVlYWcnBzcfPPN4jaz2TJHiJubG44dOyaeV1BQgLCw+oURCwoKkJiY6LQdKpUKKpXK6T4iunSHzlu6lQM8lHBT1P/d5WcXAHXzVIpZoh52tT++Hs67yYiILkW7ZoCUSiWGDBmC9PR0cZvZbEZ6ejqGDx/ucHyfPn1w4MAB7Nu3T3zccsstuPbaa7Fv3z5ERUUhJiYGoaGhkmtqtVps377d6TWJqG39ergAMz7YCaA+s2OjdJPDW2X5O6xvuGVZDC+VW6NdY0REraXdZxJLTU3FtGnTkJSUhKFDh2Lp0qXQ6XSYMWMGAGDq1KmIiIjAokWLoFar0b9/f8n5fn5+ACDZ/sQTT+Dll19Gz549ERMTgxdeeAHh4eEO8wURUdtbv9vSpTwiPhAv39rfYb+/pxKVhjokXxGCAq0e18QHsquLiNpcuwdAkydPRlFREebNm4f8/HwkJiYiLS1NLGLOzc2FXN6yRNWcOXOg0+nw0EMPoby8HCNGjEBaWhrUak6dT3S57T9bAQCYPTYe0Q0mNwQsBc+5pdXoH+GLX/45+nI3j4i6KJkgCEJ7N6Kj0Wq18PX1RUVFBXx8fNq7OUQuaffpUuhrzbj3f9shlwEHXkyBp8rxb678Cj2O5GsxplcQMz9EdEla8vnd7hkgIup8CrR6TFpeP+9Wz2Bvp8EPYFnUlAubEtHl5lLD4InINRw6XyF5nRDp204tISJyjgEQEYkMdSY8sGYn3t+cfUnXOVFQJXndL5xdyUTUsTAAIiLRj/vzkH60EAt/OHxJ1zluFwCp3OQY2yekiaOJiC4/1gARkchYZxafC4LgUJRsMgvYdLwQw2K6NVrTAwAnCisBAG/dnYjRvYIkEx4SEXUEzAARkUjtrhCfa/V1Dvs/25GL+9fswpu/HG/0GmazgJOFlgxQv3BfBj9E1CExACIiUZ25flaMEuvq7fa2niwGAOzMKW30GufKa1BtNMFdIUN0N49GjyMiak8MgIhIVG2sz/qUWtflsvfXmXIAwLGCStSZzA77gfrur9hAL8m6X0REHQl/OxGRSGcwic+Lq6QBUGGlHucr9AAstULZxTqn19iRXQYA6BPm3UatJCK6dAyAiEjUVAZo/xnp3D6H87QO55vNAr7ddw4AMKFfaBu0kIiodTAAIiKRfQaoYQ3QX2fLJa8P52lhW0nHNnpsW3YJ8ir08Fa74do+wW3bWCKiS8Bh8EQkss8AlTTIAO2z1v9cEeaDI3larNx0Ct/vO4//Tk3C5JWZuG1wBOpMloDopoQwyYgyIqKOhhkgIhJVG+0yQHYBkCAI4qru9wzrLm4/X6HHf349Dp3RhE+25WLT8SIAwPX9wy5Ti4mILg4DICISSWuA6rvATpdUo6KmFko3OSYnRWHOhN7iPjdF/WSJeRV6uMllSIr2vzwNJiK6SAyAiEgkrQGqzwDZ6n/6hvlA6SbHrDHxGBYTAAAoqpTWCg2M8oOHkr3rRNSxMQAiIlFjNUC2+p/EKD9xm7faEuQUaKUB0FWxAW3XQCKiVsIAiIhEOrsaoFKdEWbrzNC2+p+BUb7ifi+VLQDSS65xVWy3tm4mEdElYwBE1MWYzUKjszhXG+ozQCazAK2+FnUmMw6eswRACZF+4n7bYqj2y2dE+GkwpAfrf4io42MARNTF/O397Ri3ZBP0tSYIgoB/fX0Ab2w4BgCorjVJjs0pqYZWXweDdZ6fHgH1a3t5qaV1Pk+n9MYv/xzF+h8icgkMgIi6EEEQsDWrBKdLqrHndBmyinT4bHsu3t14EvpaE6qtRdC2Wp+0g/nQWbNCane5ZG0vb5U00AnyVolZISKijo4BEFEXoq+t7/rSGU04ml+/nMXZsmoYrV1jdyVFAQB+PHAeOmthtGeDzI6XqunXREQdGQMgoi7EfpRXtbEOR/MqxdcnC+sXN70xIQwadwXOlNZgW1YJAMBDJZ3Z2UvtLn3NAIiIXAgDIKIupLrBKK+j+fUBUFZRFQBAqZDDV+OOUb0CAQC/H7PM7nzBDJCaARARuQ4GQERdSE2tdKJD+y6wrEJLAKRRWjI9oT5qAEBBhWWYu4eyQQaoQQDUsCaIiKgjYwBE1IXYZ4BySnQ4W1YjvrZlgDytgY63tYsr3zrPT8MC54YZH2aAiMiVMAAi6kLsa4AyrbU9NllFlhogD2ugYwtoKmpqLdsvkAHiCDAiciUMgIi6kBonq72r3Cy/BqoMttFelkDHIcBpUAPkrW56PxFRR8YAiKgLqWkw0SEADI+TLl1hm8iwYYDjMArMLkDyVCqgkMtAROQqGAARdSH2NUA21/YOlrz2VNlqgJrO8HgoFZBZYx7W/xCRq2EARNSF1DgJgIbGBEDjXp/d0VgDHS+VdJ6fhktcyGQyeFm3sf6HiFwNAyCiLqRhBshNLkNckBfC/NTitvpRYA2LnKVdYEB95odD4InI1XSIAGjZsmWIjo6GWq3GsGHDsGPHjkaP/eqrr5CUlAQ/Pz94enoiMTERH3/8seSY6dOnQyaTSR4TJkxo69sgancLfziMuV/thyAITvfX2I0CA4D4YC8o3eSYelUPcZSXbcX3hkXQzhY59WowYoyIyFW0+2+tdevWITU1FStWrMCwYcOwdOlSpKSk4NixYwgODnY4PiAgAM899xz69OkDpVKJH374ATNmzEBwcDBSUlLE4yZMmIAPPvhAfK1SqS7L/RBdTlp9LdzlcmiUCuhrTXh/czYA4InkXgjxUTsc3zAD1CfUGwAw/ZoY/O2qHiirrkWglxIA4NNgqYumMkBcBoOIXM1FZYDq6urw22+/YeXKlaistEylf/78eVRVVbX4WkuWLMHMmTMxY8YM9O3bFytWrICHhwdWr17t9PgxY8bgtttuwxVXXIG4uDg8/vjjSEhIwObNmyXHqVQqhIaGig9/f/+W3yhRB6WvNeH297Yg4cVfMPSV31BcZUB5da24v7jK4PS86gajwHqH+ojP3RRyBHmrILNWNjcMeJwNcxczQA3qhYiIOroWB0CnT5/GgAEDMHHiRDz66KMoKrKsE/Taa6/hqaeeatG1jEYjdu/ejeTk5PoGyeVITk5GZmbmBc8XBAHp6ek4duwYRo0aJdmXkZGB4OBg9O7dG4888ghKSkoauQpgMBig1WolD6KO7OC5CuzJLQcAVBrqsPt0GcprjOL+4qr65xsO5WPB94dQZzKLRdBjegchpV8Ibh8c0eh7uCnkkuLohsPgAfsAyHEfEVFH1uIA6PHHH0dSUhLKysqg0WjE7bfddhvS09NbdK3i4mKYTCaEhIRItoeEhCA/P7/R8yoqKuDl5QWlUokbb7wR77zzDq677jpx/4QJE/DRRx8hPT0dr732GjZt2oTrr78eJpPjCBgAWLRoEXx9fcVHVFRUi+6D6HLLs67PZXOioBIVdhmgErsM0EvfH8YHW3KwM6dMnAl63BUhWHlfktNuMnv2hdBNZoBYA0RELqbFv7X+/PNPbN26FUqlUrI9Ojoa586da7WGNcXb2xv79u1DVVUV0tPTkZqaitjYWIwZMwYAcPfdd4vHDhgwAAkJCYiLi0NGRgbGjRvncL25c+ciNTVVfK3VahkEUYdWoJUGQMcLqtAzxFt8besC0xnqcK7cst5XvrZGrAHycG9exsZL7YbCSsu1nNUAje0TjI3HCjEiPqjlN0FE1I5aHACZzWanmZSzZ8/C29vbyRmNCwwMhEKhQEFBgWR7QUEBQkNDGz1PLpcjPj4eAJCYmIgjR45g0aJFYgDUUGxsLAIDA3Hy5EmnAZBKpWKRNLkUWwYoLsgTWUU6HC+oxIiaQHG/rQssu1gnbivQGsQusIbrejXGfni7s1Fg1w8Iw4T+oWLdEBGRq2hxF9j48eOxdOlS8bVMJkNVVRXmz5+PG264oUXXUiqVGDJkiKTrzGw2Iz09HcOHD2/2dcxmMwwG50WfgCU4KykpQVhYWIvaR9RR2VZoH9XLknk5VaRDSZV9DZDl/4NthXfAkjWyLYWhaW4AZDcSrLG1vhj8EJEranEG6M0330RKSgr69u0LvV6Pe+65BydOnEBgYCA+//zzFjcgNTUV06ZNQ1JSEoYOHYqlS5dCp9NhxowZAICpU6ciIiICixYtAmCp10lKSkJcXBwMBgN++uknfPzxx1i+fDkAoKqqCgsWLMCkSZMQGhqKrKwszJkzB/Hx8ZJh8kSuLN+aARrSwx9rd5xBTa0Jf50pF/fbMkBZhfUBUKFdBkjT3C4wuwxQc4MmIiJX0OIAKDIyEn/99RfWrl2L/fv3o6qqCg888ADuvfdeSVF0c02ePBlFRUWYN28e8vPzkZiYiLS0NLEwOjc3F3J5faJKp9Nh1qxZOHv2LDQaDfr06YNPPvkEkydPBgAoFArs378fH374IcrLyxEeHo7x48dj4cKF7OaiTsMWAIX5atAzxAv7z1ZgZ06puL9EzADZd4Hp62uAmrlyu624WamQQ+nWIeZNJSJqFRc1dMPNzQ1/+9vfWq0Rs2fPxuzZs53uy8jIkLx++eWX8fLLLzd6LY1Ggw0bNrRa24g6GrNZEIugQ33V6Bnsjf1nK1Ciu0AXWKVeHAXW/C4wy68IZ0PgiYhcWYsDoI8++qjJ/VOnTr3oxhBR404UVEImk8FX4446swCZDAj2ViEm0MPh2AKtAb2f/xmGOrNkm22JjJYWQTdW/0NE5Kpa/Fvt8ccfl7yura1FdXU1lEolPDw8GAARtYGK6lpc958/AABfz7oaABDopYK7Qo7u3TydnmMLflRuchjqzDDaBUPNDYBsXWDNPZ6IyFW0uFO/rKxM8qiqqsKxY8cwYsSIiyqCJqIL25NbJj4/aS1sDvO1TGLYI8AxA2RzdVw3vHLbAPh7SJeqaOkoMA+u9UVEnUyrVDX27NkTr776qkN2iIhax/6zFeLzk9a6Htsszj26NR4AffrgMNwxJFIy47NCLoNS0bz/+hF+loENYReYMZqIyNW02p91bm5uOH/+fGtdjojs2GeAckuqAVi6wADAz0MJb7UbKvV1knMGdfcT5+gJ9lHjaL5l4WIPd0Wz5+4ZER+IlfcNwaAov0u9BSKiDqXFAdB3330neS0IAvLy8vDuu+/immuuabWGEZGF2Sxgr10AZJsE0UdT/983wFMpBkBv3jkQ63aewdK7E8X9Id71U0C0ZD4fuVyGlH6Nz8pOROSqWhwA3XrrrZLXMpkMQUFBGDt2LN58883WahcRWWUVVUFrl93JK7cGQHazNPtq6p9PGhKJSUMiJdcYFtsNX+4+CwDi2l5ERF3ZRa0FRkSXz+E8reR1YaUlALKfpdk+AHJm0uAIZBdXYdnGLIzpzYVLiYg4tIOog9PW1Epemy1T+YiTFAJAkHfTs5zLZDI8ndIHtw+ORCgLmomImhcApaamNvuCS5YsuejGEJEjbYPiZhv7hUpTr+uFTceKMGVo9yavFRfk1aptIyJyVc0KgPbu3dusi3FVaKLW13B0l419BijS3wO7nk/m/0EiomZqVgC0cePGtm4HETWiUl/rdLtXg8kJGfwQETUfl3cm6uBsGSDvBgGP/SgwIiJqmYsqgt61axe++OIL5Obmwmg0SvZ99dVXrdIwIrKwZYBCfdWoLKxf3d2+C4yIiFqmxRmgtWvX4uqrr8aRI0fw9ddfo7a2FocOHcLvv/8OX1/ftmgjUZdmywCF+kpHb3kxACIiumgtDoD+/e9/4z//+Q++//57KJVKvPXWWzh69CjuuusudO/e9AgUImo5WwAU7qsRt6nd5XBv5npeRETkqMW/QbOysnDjjTcCAJRKJXQ6HWQyGf75z3/iv//9b6s3kKirs+8Cs/Fm/Q8R0SVpcQDk7++PykrLoooRERE4ePAgAKC8vBzV1dWt2zoiEjNAYZIAiN1fRESXosW/RUeNGoVff/0VAwYMwJ133onHH38cv//+O3799VeMGzeuLdpI1GWZzQKqjI41QMwAERFdmhYHQO+++y70estaRM899xzc3d2xdetWTJo0Cc8//3yrN5CoK6sy1kGwLn0R7ldfA9RwSDwREbVMi3+LBgQEiM/lcjmeffbZVm0QUVdTZzLDzVrQLAiCZELDKmv3l7tChgBPpbidXWBERJemxTVAycnJWLNmDbRa7YUPJqIm7T9bjgEv/oL3Mk5i0c9HcPWrv6NQqxf3i5Mgqt0lMz8zACIiujQtDoD69euHuXPnIjQ0FHfeeSe+/fZb1NY6n6qfiJq25WQJampN2HAwHys3nUJehR5f7Doj7reNAPNWu0HlJoebXGZ9zRogIqJL0eIA6K233sK5c+fwzTffwNPTE1OnTkVISAgeeughbNq0qS3aSNRp5VXUAACO5FWK2+Ty+i6w+gyQG2QyGTytWaCG64AREVHLXNRManK5HOPHj8eaNWtQUFCAlStXYseOHRg7dmxrt4+oUztfbunuMprM4rZqgwk/H8jDsfxKaG0ZIJUl42MLfNgFRkR0aS7pt2h+fj7Wrl2LTz75BPv378fQoUNbq11EXYItA2Tv54N5eHfjSQDAy7f2B1Af8NgCIC6ESkR0aVqcAdJqtfjggw9w3XXXISoqCsuXL8ctt9yCEydOYNu2bW3RRqJOK69C77Atq0gnPj9RYOkas9X8+HlY/vW3GxFGREQt1+IMUEhICPz9/TF58mQsWrQISUlJbdEuok5PX2tCqc7Y5DEZx4sA1GeAnk7pjd+OFGJkz8A2bx8RUWfW4gDou+++w7hx4yCXcyFGokvhLPvT0OkSy/IyPtYAKCk6AEnRAU2dQkREzdDiKOa6665j8EPUCs6XW+p/lG4X/v/ELi8iotbVISKZZcuWITo6Gmq1GsOGDcOOHTsaPfarr75CUlIS/Pz84OnpicTERHz88ceSYwRBwLx58xAWFgaNRoPk5GScOHGirW+DSPTXmXK8lnYU1dZ1vJyxBUBXRvvj5oHhmH51NOwmgRb5ebjj5oHhbdVUIqIuqd0DoHXr1iE1NRXz58/Hnj17MHDgQKSkpKCwsNDp8QEBAXjuueeQmZmJ/fv3Y8aMGZgxYwY2bNggHrN48WK8/fbbWLFiBbZv3w5PT0+kpKSIa5gRtbWJy7ZgeUYWVmRkNXqMrQss0s8D70wZhBdv6YdudpmeMF81PJUKfDhjKAK9VG3eZiKirqTdA6AlS5Zg5syZmDFjBvr27YsVK1bAw8MDq1evdnr8mDFjcNttt+GKK65AXFwcHn/8cSQkJGDz5s0ALNmfpUuX4vnnn8fEiRORkJCAjz76COfPn8c333xzGe+MCDhZVNXoPtsQ+DC/+lXeg7wtz9Xucmx8agy2PjsOA6P82rSNRERdUbsGQEajEbt370ZycrK4TS6XIzk5GZmZmRc8XxAEpKen49ixYxg1ahQAIDs7G/n5+ZJr+vr6YtiwYY1e02AwQKvVSh5ErUHtpmh0n20SxHDf+lXeg7wtmZ5Ifw+o3RXw9eB8P0REbaHFAdBjjz2Gt99+22H7u+++iyeeeKJF1youLobJZEJISIhke0hICPLz8xs9r6KiAl5eXlAqlbjxxhvxzjvv4LrrrgMA8byWXHPRokXw9fUVH1FRUS26D6LGqNwbD4CcZYCCrQFQlL/G6TlERNQ6WhwA/d///R+uueYah+1XX3011q9f3yqNuhBvb2/s27cPO3fuxCuvvILU1FRkZGRc9PXmzp2LiooK8XHmzJkLn0TUCH2tSXyudm/8v1ieNQMUZpcBirQGPrFBXm3UOiIiAi5iHqCSkhL4+vo6bPfx8UFxcXGLrhUYGAiFQoGCggLJ9oKCAoSGhjZ6nlwuR3x8PAAgMTERR44cwaJFizBmzBjxvIKCAoSFhUmumZiY6PR6KpUKKhWLTKl1lFfXis/dFc4DIK2+FpUGywixcLsM0NTh0VC5KTBpcETbNpKIqItrcQYoPj4eaWlpDtt//vlnxMbGtuhaSqUSQ4YMQXp6urjNbDYjPT0dw4cPb/Z1zGYzDAYDACAmJgahoaGSa2q1Wmzfvr1F1yS6WOU19bM7G+yyQfZs2R9fjTs8lPV/hwR4KvHImDgE+6idnkdERK2jxRmg1NRUzJ49G0VFReLq7+np6XjzzTexdOnSFjcgNTUV06ZNQ1JSEoYOHYqlS5dCp9NhxowZAICpU6ciIiICixYtAgBx+Y24uDgYDAb89NNP+Pjjj7F8+XIAgEwmwxNPPIGXX34ZPXv2RExMDF544QWEh4fj1ltvbXH7iFqqTFefAdLXmp0ec95W/+PLQIeIqD20OAC6//77YTAY8Morr2DhwoUAgOjoaCxfvhxTp05tcQMmT56MoqIizJs3D/n5+UhMTERaWppYxJybmyuZeVqn02HWrFk4e/YsNBoN+vTpg08++QSTJ08Wj5kzZw50Oh0eeughlJeXY8SIEUhLS4NazQ8bansVdhkgfV3TGaAIPxY7ExG1B5kgCMLFnlxUVASNRgMvr85VsKnVauHr64uKigr4+Pi0d3PIxXy+IxdzvzoAAEjpF4KV9zkuGPzmL8fwzu8n8beruuPlWwdc7iYSEXVKLfn8bnEGyF5QUNClnE7UKdkXQTfaBeZkBBgREV0+zQqABg8ejPT0dPj7+2PQoEGQOVuwyGrPnj2t1jgiV1RebdcF1lgRtLUGyH4EGBERXT7NCoAmTpwoDhNnITFR0yQZoDrnGSDbOmDMABERtY9mBUDz588HAJhMJlx77bVISEiAn59fW7aLyGWVVTc9DF4QBHEl+HAGQERE7aJF8wApFAqMHz8eZWVlbdUeIpdXXlOfAaqxC4D+b/dZXL0oHT/sz4PBmhkK8eUEnERE7aHFEyH2798fp06daou2EHUou3JKkW/tqmoJZzVAO3NK8eSXf+F8hR7/+fU4ACDQSwVVE4ulEhFR22lxAPTyyy/jqaeewg8//IC8vDyuok6dUlZRFe5YkYl/fN7yov4yJ6PAXv7hsLjtdGk1ACCCBdBERO2mxcPgb7jhBgDALbfcIhkNJggCZDIZTCbno16IXMkZa5CSr21ZBkgQBFRIAiDL/4dz1pofADCZLVNvsQCaiKj9tDgA2rhxY1u0g6hD0RksgUttXcvmCdXW1MFoqh/5ZagzQxAEaPV1DseGMQNERNRuWhwAxcTEICoqymEuIEEQcObMmVZrGFF7qjJYsjh1ZufD2BtzttySOVK7y8XuL62+DkYnw+E5AoyIqP20uAYoJiYGRUVFDttLS0sRExPTKo0iam9VtgyQqWUZoLNllq6uuKD65WGKKg3ic/u1v5gBIiJqPy0OgGy1Pg1VVVVxsVHqNKqsXVa1ppZlgM5ZA6Dobp5wk1v+n9gCIC+VG6IDPcRjWQNERNR+mt0FlpqaCgCQyWR44YUX4OFR/4vcZDJh+/btSExMbPUGErUHsQusGRmg3w4X4FhBJWaNiRMzQBH+GqjdFagy1KGw0lJI7aN2Q5S/B4ASAFwGg4ioPTU7ANq7dy8ASwbowIEDUCqV4j6lUomBAwfiqaeeav0WErUDsQvMbG4062nz4Ee7AABJPfxxtsxSAxTpr4HaXY4qQ30GyFvtjqgAyx8OCrkMwd4MgIiI2kuzAyDb6K8ZM2bgrbfeuuAy80SurMpg6QITBMuwdTeF8wCo2lg/uqusulYc7h7prxEnObQFQD4aN0T6W7q9Qn3UUMgbD6qIiKhttbgG6IMPPoCPjw9OnjyJDRs2oKbG8gtfEFpWLErUkekM9YFNnbnxn+3z5dJ5gsQuMD8PaJSWAKjQLgM0LKYb/DzckXxFcGs3mYiIWqDFw+BLS0tx5513YuPGjZDJZDhx4gRiY2PxwAMPwN/fH2+++WZbtJPosqqym7en1mSG2t35khX2ExzmVdSgwroOWIS1Cwyw7wJzQ6ivGrufv47ZHyKidtbiDNATTzwBd3d35ObmSgqhJ0+ejLS0tFZtHFF7qTLYB0DSDJDJLKCkyhLUnLcLgI7kWZaC8fdwh5fKDeqGXWBqdwBg8ENE1AG0OAP0yy+/YMOGDYiMjJRs79mzJ06fPt1qDSNqT/YBUF2DofCPfLIbvxwuwE+PjZQEQEfzKwFYsj8AxKyRbRSYt7rF/92IiKiNtPg3sk6nk2R+bEpLS6FSqVqlUUTtzb4GqLZBDdAvhwsAAJ9uP40aY/3ad9lFOgBAkJfl/4GtC8y2OKqPxr3tGkxERC3S4i6wkSNH4qOPPhJfy2QymM1mLF68GNdee22rNo6ovVTaB0BOlrEAAE+Vm6QGyHaOv6dlighVg7ohZoCIiDqOFv9GXrx4McaNG4ddu3bBaDRizpw5OHToEEpLS7Fly5a2aCPRZWWsM0vW7rJfD8y+a8xDqZAEQDbdrAGQrQbIxlvNDBARUUfR4gxQ//79cfz4cYwYMQITJ06ETqfD7bffjr179yIuLq4t2kh0Wdl3fwHSIuhCbf2wd7NZQH6FdBg8UJ8BsnWB2fgwA0RE1GFc1G9kX19fPPfcc63dFqIOocohAKrPABVo6xc2PVWsczpHkJgBcugCYwaIiKijuKgASK/XY//+/SgsLITZLK2PuOWWW1qlYUSXi9ksYNupEgyI9IW32t1JAGSXAaqsz/icshY9N+TvYQmANA0CIGaAiIg6jhb/Rk5LS8PUqVNRXFzssE8mk8FkMjk5i6jjqDLUYfZne3B9/1BMvrI71mzNwUs/HMbw2G74/KGrHAKgOkkGqD4Ayquw1P8o5DKY7DJB3bwa6QLjKDAiog6jxTVA//jHP3DnnXciLy8PZrNZ8mDwQ65g49FCZBwrwpqtlnmrVm/JBgBknrKs0u4QANkFN/ZdYLbh7VHWeX9sAjwtw+A9lNK/LzgKjIio42hxAFRQUIDU1FSEhIS0RXuI2tyJwioAgKHOErCX6YyS/fbLYACA0WTGqaIqDHrpF7y/OdvhehENAyBrF9j4ftL/Iw27xIiIqP20OAC64447kJGR0QZNIbo8sqwBkG2ou84ozVw2HAVWZxLwybZcMePTUKiPBrbVLRRyGXw0lkxPpL8HPps5DEqFHP0jfCCTcQkMIqKOosU5+XfffRd33nkn/vzzTwwYMADu7tK6hscee6zVGkfUFk4UWpasMDYywaGzGqA6s/NjAcDPwx3eandU1NTC30MpCXSujgvE1rlj4aFk9oeIqCNpcQD0+eef45dffoFarUZGRobkl71MJmMARB1arcmM7GLL6C1DIwFQpZMusNzS6kav6atxh4/GDRU1teIQeHuBXlwihoioo2lxF9hzzz2HBQsWoKKiAjk5OcjOzhYfp06duqhGLFu2DNHR0VCr1Rg2bBh27NjR6LGrVq3CyJEj4e/vD39/fyQnJzscP336dMhkMsljwoQJF9U26lxOl1SLw9qNdWbJWl6+1lFazrrAcksaD4B81G7wVlnO9ffkSC8iIlfQ4gDIaDRi8uTJkMtbfKpT69atQ2pqKubPn489e/Zg4MCBSElJQWFhodPjMzIyMGXKFGzcuBGZmZmIiorC+PHjce7cOclxEyZMQF5envj4/PPPW6W95NpOWut/AEtmJ99uWLu7wvIz3bALzFBnxpkySwCUel0vLLy1v2S/r4e7WPfTzZPZHiIiV9DiKGbatGlYt25dqzVgyZIlmDlzJmbMmIG+fftixYoV8PDwwOrVq50e/+mnn2LWrFlITExEnz598L///Q9msxnp6emS41QqFUJDQ8WHv79/q7WZXNdJa/0PAJjMAs6V1a/lZbSOCmsYAJ0ps2SN3BUyPHptPO5KipTs99W4i7M8MwNEROQaWlwDZDKZsHjxYmzYsAEJCQkORdBLlixp9rWMRiN2796NuXPnitvkcjmSk5ORmZnZrGtUV1ejtrYWAQEBku0ZGRkIDg6Gv78/xo4di5dffhndunVzeg2DwQCDoX5+F61W2+x7INdywi4DBEBS26O31gQ1DIBso8Yi/T2gkMugkCvgrpCJXWk+anex+yyAGSAiIpfQ4gDowIEDGDRoEADg4MGDkn0tHeZbXFwMk8nkMKdQSEgIjh492qxrPPPMMwgPD0dycrK4bcKECbj99tsRExODrKws/Otf/8L111+PzMxMKBSOo3EWLVqEBQsWtKjt5JpOFEgDoNOl9ctZGOvMEARBrAFSu8uhrzUjq8hyTvcAD/FYT5Ubyq3D4n017rgrKQp5FTW4ZWBYW98CERG1ghYHQBs3bmyLdlyUV199FWvXrkVGRgbUarW4/e677xafDxgwAAkJCYiLi0NGRgbGjRvncJ25c+ciNTVVfK3VahEVFdW2jafLzmQWxGDGpmFxs6HOLI4C8/dQIq9Cjyzrml89utkFQEppANQzxBufPnhVWzafiIhaUetUMl+kwMBAKBQKFBQUSLYXFBQgNDS0yXPfeOMNvPrqq/jll1+QkJDQ5LGxsbEIDAzEyZMnne5XqVTw8fGRPKjzOVdWA0OdGUo3OdwVlmylrbjZxlBnhs5oCYD8PKRD2iPtZnz2UtX/7cA1voiIXE+7BkBKpRJDhgyRFDDbCpqHDx/e6HmLFy/GwoULkZaWhqSkpAu+z9mzZ1FSUoKwMHZPdHZnSqvx94934+cDeQ77bBMgxgZ6Qu1m6Qot00lndzbUmsSlMPw9pIGNrdAZADxVlvOVbnKoucQFEZHLaffVGVNTUzFt2jQkJSVh6NChWLp0KXQ6HWbMmAEAmDp1KiIiIrBo0SIAwGuvvYZ58+bhs88+Q3R0NPLz8wEAXl5e8PLyQlVVFRYsWIBJkyYhNDQUWVlZmDNnDuLj45GSktJu90ltr7jKgJGLLV20WUVVuH6ANOC1FUD3DPFGUaUBMABafYMAqM4sFkH7NQiA7Gdz9rRmgHyZ/SEickntHgBNnjwZRUVFmDdvHvLz85GYmIi0tDSxMDo3N1cy59Dy5cthNBpxxx13SK4zf/58vPjii1AoFNi/fz8+/PBDlJeXIzw8HOPHj8fChQuhUnGETmf27u/1XZylDRY4BernAOoZ7IXdOaUAHGd91uprxdFdDbvA7DM9ti4wH67wTkTkkjrEb+/Zs2dj9uzZTvc1XHg1JyenyWtpNBps2LChlVpGruTQ+QrxubPMjC0DFB/sBaWb897fkqr6wMlP03gGyIsZICIil9auNUBErck2WgsAampNDvuLKy1zPYX7aRoNgGyZI427Aio3aW2Pxp1dYEREnQUDIOoUSnVGSbeXswBIb92mcVc0GgAVV1mCJC+1G9wU0nmtNE4yQBwBRkTkmhgAUadgm9/HNhen/SKnNrYASO0uh1Ih/dH3ttbylFiDKG+Vm8MxHsr6HuPEKD/IZUBSDy6xQkTkijpEDRDRpbItV9E/3BcHzlXAUGeG2SxALrdERIIgiEtdqJ1kgPw83FGpr0OJNQPkqXKSAbLrAkvuG4KDC1IkQREREbkOZoCoU7BlgPpH1E9iqa+rzwLVmgSYzJbRXWo3BZQN6ntstTy2bjQvlRvcGmSA7LvAADD4ISJyYQyAqFOwDXHvG+4rbrPvBrMPhlROusD8NJYh70XWUWCeKjcom8gAERGRa2MARJ2CbQRYz2AvqN0tP9b2hdC2+h+ZDFC5yaFyr//Rl8nsaoCsXWDeaje42c0/5SaXNVo4TUREroe/0cnl6WtN4ppecUFeYqZGbxcAGWot9T8qNzlkMhlUdhkgjbtCnOTQ1gXmqVJIaoCY/SEi6lwYAJHLyynRQRAsdTyBXkoxWKkxmsVj6keA1a/hZaN2V0BlfV1t7TbzUrlLuska1v8QEZFrYwBELs9W/xMX5AmZTAa1NViRdoFZgiGNkwBIYxcA2XipFJIiaAZARESdCwMgcnlZhZb6n7ggLwD1QY4kAKprkAGyC25U7nKoGnRxeTUYBs8uMCKizoUBELk82xD4uOAGAZDRsQjalumRdIG5KaBukAHybDARogczQEREnQoDIHJ5ti6weFsGSOlYBG3rAnNWA6RRKhwyQJZRYDLJMURE1HkwACKXZjYLOFUszQDZgpwtJ4vxyo+HUWM0SZbBABoWQcsdaoC81e7SGiB3TnpIRNSZ8Lc6uay8ihq8+N0h6GvNUCrkiPLXAKjvAvty91kAgMkMXBHmDaA+OLJf6d1ZEXSYrxpVhrr6Y5gBIiLqVJgBIpe1ftdZbDhUAAAY2TNQzNg0LFjecCi/fh0wN8cuMJW7QhIQAUC4nwbu9jVALIImIupUGACRy7Kt3P63q7rjv1OTxO0NszXnymtgaNAF1nAiRPuZoYO9VVC7K+CuYA0QEVFnxQCIXFZFTS0AoEeAJxR2BctqJ9maokqDZJ9jDVD9OZHWrjT7pTAYABERdS4MgMhllVdbMkC+Hu6S7c7m7NmWXQqgkVFgDTJAkf4eAAD3BscQEVHnwQCIXMLmE8W47/3t+HxHLmpNlnqecmsGyFfTIABSOv5Y/3WmHADEQMd+jh91gyJoWwbI3S6rxHmAiIg6F44CI5fwWtpRHDhXgT9PFOPweS0W3tpf7ALzaxgANZGtcVYErbZbDBUAImxdYPazRXMleCKiToW/1anDy6uowYFzFeLro/laAEBFtTUD1KALzFkNUMN9jS2GCth1gdkVQdsHQ0RE5Pr4W506vN+OFEpeV9TUQhAEsQvMT6OU7LcvWG6YuRFHgTUxEaLYBWYX9NjPCk1ERK6PARB1eL8etsz1c/PAcABAeXUtdEYTTGYBAODXRBF0vHV2aJvGiqAFof6YCD/bKLD6oEfJLjAiok6Fv9WpQ9Lqa7F2Ry4KtXpkZhUDAO4YEgnAkgGyjQBTuskduryaDoCcZYAUiAvywvi+IZg2vId4Pfuh9fZD4omIyPWxCJo6pJWbsrBsY5b4OjbQE4O6+wEADHVmFGgt8/o0LIAGALVdF5htgVRxn60IWiFdCkMul0kmUwQAmcy+BohdYEREnQn/rKUOafOJYsnr6/qGwEvpBltS5kxpNQDHIfCANAMU7qeRvLYFR9KlMC7834DD4ImIOhcGQNQh9Qrxlry+rm8I5HKZGPCcLrEEQA3rfwBpABTgqUSAZ32RtLNh8E0Nm39wRAxG9QrC1XGBF3EXRETUUbELjDok2+KlABDopcSg7v4ALBmfsupanC7VWV8rHc61HwVmC4DOldcAqK8BajgMvjHP39T3Eu6CiIg6KmaAqEOqMVoWL43w02Dp5EFiQbItA5Rb0ngXmNpuXS8fjTv87TNAtlFgiuZlgIiIqHPqEAHQsmXLEB0dDbVajWHDhmHHjh2NHrtq1SqMHDkS/v7+8Pf3R3JyssPxgiBg3rx5CAsLg0ajQXJyMk6cONHWt0GtSG9dvf3plN4Y0bO++8nHFgCVNt4F5qGqD2iCvVXo5iQAclfIxIkO7Y8nIqKuod0DoHXr1iE1NRXz58/Hnj17MHDgQKSkpKCwsNDp8RkZGZgyZQo2btyIzMxMREVFYfz48Th37px4zOLFi/H2229jxYoV2L59Ozw9PZGSkgK9Xn+5botaoNpYh725ZRDsJuOpsQZADbunbBmfQuvq7s4yQO4KOX5+fCR+fGwEPFVu8PewD4AsP/IymQzP3XAFHhsbj2BvdeveEBERdXjtHgAtWbIEM2fOxIwZM9C3b1+sWLECHh4eWL16tdPjP/30U8yaNQuJiYno06cP/ve//8FsNiM9PR2AJfuzdOlSPP/885g4cSISEhLw0Ucf4fz58/jmm28u451Rcy384TBue28rNh0vErfZusA0SucBkI2zDBAAXBHmg37hvg7n2HePTb8mBqnje19a44mIyCW1awBkNBqxe/duJCcni9vkcjmSk5ORmZnZrGtUV1ejtrYWAQEBAIDs7Gzk5+dLrunr64thw4Y1+5p0eWUXWwqabd1aQH0XWMP6nIYBkLMMUEP2Q9ibKngmIqKuo11HgRUXF8NkMiEkJESyPSQkBEePHm3WNZ555hmEh4eLAU9+fr54jYbXtO1ryGAwwGAwiK+1Wm2z74EuXbU121NtNMFQZ4KbXC52gTUMgBpmfEJ8Ltx91dTaYERE1DW59DD4V199FWvXrkVGRgbU6ouv41i0aBEWLFjQii2jlqgy1AEAyqqNuPb1DIT7aeoDoCa6wOQyoH+E7wWvb58BknNRUyIiQjt3gQUGBkKhUKCgoECyvaCgAKGhoU2e+8Ybb+DVV1/FL7/8goSEBHG77byWXHPu3LmoqKgQH2fOnLmY26GLpLMGQFmFVThfoceu02WoNlw4AOoV4g0v1YVj+JhAz1ZsLRERdQbtGgAplUoMGTJELGAGIBY0Dx8+vNHzFi9ejIULFyItLQ1JSdL1m2JiYhAaGiq5plarxfbt2xu9pkqlgo+Pj+RBl4/OGuwUVdZ3QxpNlokQG3aB+dgFQLa1wS5kUHd/vHhzX7w/LenCBxMRUZfQ7l1gqampmDZtGpKSkjB06FAsXboUOp0OM2bMAABMnToVERERWLRoEQDgtddew7x58/DZZ58hOjparOvx8vKCl5cXZDIZnnjiCbz88svo2bMnYmJi8MILLyA8PBy33npre91ml6Az1EFnrGvRsHJBEKAzWjJA9gGQTVNF0IlRfs1+n+nXxDT7WCIi6vzaPQCaPHkyioqKMG/ePOTn5yMxMRFpaWliEXNubi7k8vpE1fLly2E0GnHHHXdIrjN//ny8+OKLAIA5c+ZAp9PhoYceQnl5OUaMGIG0tLRLqhOiC7tuySZLF9bzyQj0UjXrnJpaE2zT/xRVOQZADYuWfdT2AZD/xTeWiIi6NJlgP/scAbB0mfn6+qKiooLdYc2krzWhzwtpAID3pyVh3BUhFzjDorBSj6GvpDvdp3aX4+jC6yXbjHVmjHl9I9zd5Pj9yTHiEhlEREQt+fxu9wwQdQ72c/i0JCix1f8442yNLqWbHL89ORoKuYzBDxERXTQGQNQqbJMZAkBFTW2zz7ONAHOmsUVKPZT8sSUiokvDWeGoVeTYBUBafeNBTUNVTQRAaiVnbSYiorbBAIhaRU5JfReY1i4DlFVUhU+2nYbJbCk109eaJBmii8kAERERXSr2JVCryGmkC+yhj3Yhq0iH4ioDnkjuhekf7MD+sxXIeGoMgn3U0BlbVgNERETUGpgBolaRU2LXBWYNgExmAVlFlu3v/n4SR/K02HaqFNVGE3afLgNwgQwQu8CIiKiNMACiS1ZjNCGvQi++tmWAsourxG11ZgHzvj0ovi6rthzDLjAiImoPDIDokp0pq5a8tgVAB85VSLbvzCkTn+dX1ABougiaGSAiImorDIDokhU3mMFZq7cGQGe1AIBxfYIR22BB0nytJWPEDBAREbUHFkHTJdPWSIMYWwbooDUDdP2AMNw2KAKbTxZj26kSLM/IQr7WEjRVNTERopoBEBERtRFmgOiS2TI+UQEay+uaOmzNKha7wAZE+EIhl2F0ryAMj+0GoL4LrNrILjAiIrr8GADRJbON+ory9wBgyQDds2o7ampN6BPqjbig+u6vUF/LgrT5FewCIyKi9sMAiC6ZLQCK9NdItl8Z7Y8v/j4cbor6HzNbAKTV16HaWNd0ETQDICIiaiMMgOiS2Za+CPJWQeVW/yM17ooQ+KjdJcd6q9zgYe3ayq/QN7kYKpfCICKitsIAiC6ZLQPko3aHr6Y+4Okb5uNwrEwmq+8G0+rFLjBvlZvdMZZ/mQEiIqK2wgCILplt1Jevxh3udt1dfcMdAyAACPWxBEAFWj101iLoIB8VAMBTqYCXNRhiAERERG2FARBdMtsoMB+NO85bR3cBQKCXyunxtgDofHl9F1iQ9VhPlZvYbebBLjAiImojDIDoktnmAfJRu0MQLnx8rHVU2N7cMjEDZOsW81K5icPpw/zUbdBaIiIiToRIraA+A+SGAE8lSnVGDIz0bfT4gVF+AID0o4UQBCDCT4MIP0vQ46FSYOnkQcgu1qFPqPMuNCIiokvFAIgumX0N0JoZV+J/f2bjmev7NHp8QqQfAIjZoqRof7G7y1PphlBftZgRIiIiagsMgOiS1JrMqDZa6nh81O7o0c0Tb08Z1OQ5vhp3xAZ54lSRDgCQFB2A2jozAIgF0ERERG2JnzZ0SSr19RMZequb/+OUGOUnBkBXRvtDX2uGh1KB4XHdWr2NREREDTEAokti6/7yUrlJZny+kEFRfvhqzzl4q93QK9gbcrkM++ePb9E1iIiILhY/beiS1E+C2LJY+rq+oYj01+C+q3pALrfMfMjgh4iILhdmgOiS2M8B1BKhvmpsfmZsWzSJiIjogvgnN10S+zmAiIiIXAUDILokthqglmaAiIiI2hMDIAIA/HQgD3etyER+hb5F59lPgkhEROQqGAARAGDWp3uwI6cUz361v0XnVekdV3MnIiLq6BgAkcTh89om9+sMddLX1rW8PBkAERGRC2EARBKFlYZG972dfgIJC37BtlMl4rZq62ruDICIiMiVtHsAtGzZMkRHR0OtVmPYsGHYsWNHo8ceOnQIkyZNQnR0NGQyGZYuXepwzIsvvgiZTCZ59OnT+LpU1DR9rQkPfbQLH2fmYMmvx2EyC1jy63Fxf5U1A2Rby4uIiMgVtGsAtG7dOqSmpmL+/PnYs2cPBg4ciJSUFBQWFjo9vrq6GrGxsXj11VcRGhra6HX79euHvLw88bF58+a2uoVOQ2k3CaHZLIjPv913Dr8cLsAL3x4St/nZjfiqtnaJeSqZASIiItfRrgHQkiVLMHPmTMyYMQN9+/bFihUr4OHhgdWrVzs9/sorr8Trr7+Ou+++GyqVqtHrurm5ITQ0VHwEBga21S10Gt28lOJz+24wnbWLy559tkdnXQjVQ8UMEBERuY52C4CMRiN2796N5OTk+sbI5UhOTkZmZuYlXfvEiRMIDw9HbGws7r33XuTm5jZ5vMFggFarlTy6GpNd1ud0iU58XlDpOCy+tLpWfF7NImgiInJB7RYAFRcXw2QyISQkRLI9JCQE+fn5F33dYcOGYc2aNUhLS8Py5cuRnZ2NkSNHorKystFzFi1aBF9fX/ERFRV10e/vqowms/j8dGk1TGYBFTW1OFdW43BsSVV9hkgsgmYXGBERuZBO96l1/fXXi88TEhIwbNgw9OjRA1988QUeeOABp+fMnTsXqamp4mutVtvlgiBDbX0AdKa0GrM/24P0o4VOl7go1RmxZks2PFRu4jB4FkETEZErabcAKDAwEAqFAgUFBZLtBQUFTRY4t5Sfnx969eqFkydPNnqMSqVqsqaos/nfn6ewPbsUy+4ZDKWbJQkoyQCVVOPng5YsXHGV47D4vAo9Xvz+MABA424JfNgFRkRErqTdusCUSiWGDBmC9PR0cZvZbEZ6ejqGDx/eau9TVVWFrKwshIWFtdo1Xd3//szGr4cLcOh8BQCgzmRutAbI5vU7ErBwYj+H7TW1ti4wZoCIiMh1tOsosNTUVKxatQoffvghjhw5gkceeQQ6nQ4zZswAAEydOhVz584Vjzcajdi3bx/27dsHo9GIc+fOYd++fZLszlNPPYVNmzYhJycHW7duxW233QaFQoEpU6Zc9vvrqGyzOVdbR3DZZ38A4EietF5K5SbHHUMicd/w6Ea7ujyYASIiIhfSrp9akydPRlFREebNm4f8/HwkJiYiLS1NLIzOzc2FXF4fo50/fx6DBg0SX7/xxht44403MHr0aGRkZAAAzp49iylTpqCkpARBQUEYMWIEtm3bhqCgoMt6bx2VIAhi3U6NNQCyr/8BHAMiX407ZDIZACDAU4lqo2NhtK0rjIiIyBW0+5/ts2fPxuzZs53uswU1NtHR0RAEwemxNmvXrm2tpnVK+lozbL1dtu4rQ50l4JHJALlMJukOA4CyaqP4vJuXCmcbjAzTuCugkMvasNVEREStq92XwqDLq8puMVNbAGS0BkAadwVCfdQO59jPEt3NU+mw35OTIBIRkYthANTF2CYuBOy6wOos/6rc5Aj3qw+Augd4wEfthv9MThS3+Xk4Dov34BxARETkYvjJ1cXYL23RsAtM6SZHmK8GQBkAYOrwHnhgRIxY/wMAtSbHLkjOAURERK6GGaAuRuc0A2QJgFRuCoTZZYBCfdWS4AcAKvW1aMiLI8CIiMjFMADqYnRN1AAp3eSI8NOI+53VA13XN8RhG4fAExGRq+EnVxcj6QJzUgNk6QKzCHESAE1OioKfRokzZdV49eejADgJIhERuR5mgLoQY51Z2gXmJAMU5lsf9DgLgNwUctyYEIZeIV7iNhZBExGRq+EnVxex5WQxZqzZie4BHuI2xxogOXqGeKFXiBeiu3mK64Q546upHw7PYfBERORqGAB1ETtzSmGsM+NkYZW4rWEGSOWmgMpNgQ1PjHIofm7Ifjg8M0BERORq2AXWRVTq6xy2NcwA2TI+Fwp+AMDfwy4DxBogIiJyMQyAughnw9erax2LoJvLR12f9eEoMCIicjUMgLoIZxkgvdGxCLq53BRyeFuDIGaAiIjI1TAA6oS+/+s8rnn1d+w/Wy5u0zrJADWcCVrl1rJAxlYHxAwQERG5GgZAndCP+/NwrrwGm44Viduc1gA5FEG37MfBNlGiswVSiYiIOjL+6d4JFVcZAEizPk0XQbe8BggA5t/cD9tOleCq2G4X21QiIqJ2wQCoE7IFQBU19gGQ8y4wQRAuqgYIAPpH+KJ/hO8ltJSIiKh9sAusEyquMgIAtDX1WR+tkwyQySyg1iRIJkIkIiLqCviJ18noa02osi54assAGepMYpanoRqjSTIRIhERUVfAAKiTsXV/AfU1QM7qf2xqak0OEyESERF1dqwB6gQMdSb8drgQY/sEi91fgCUDVG2sQ6HW0Oi5lgDo4oqgiYhclSAIqKurg8lkau+mUAsoFAq4ubk1a8WCC2EA1Am8nX4CyzZmYWyfYNwztLu4vUxnxHVL/sC58hqHc3zUbtDq61BtrGMGiIi6FKPRiLy8PFRXV7d3U+gieHh4ICwsDErlpU3BwgCoE/h0ey4A4PejhRjfN0TcrjOaoDM6Bj8A4OehhFZfB71dFxhrgIioszObzcjOzoZCoUB4eDiUSmWrZBOo7QmCAKPRiKKiImRnZ6Nnz56Qyy/+D3cGQJ1AjwAPlFdXAACO5lc26xwP6/IVNUbzRQ+DJyJyNUajEWazGVFRUfDw8Gjv5lALaTQauLu74/Tp0zAajVCr1Rd9LQZAnYC+tn6E148H8ho9bkR8IAx1JgyM9MOu02UAIOkCYw0QEXUVl5I5oPbVWt87BkCdQL5WLz4vqmy84DnAU4m3pwwCANyzahsASxG00VoEzQwQERF1FfzEc3E1RpNkxuem2FZvBwCNu6ULTFoDxB8HIiLqGpgBclHGOjP+9r/tKK2uH/Ye4acRR3zJZIAgSM/xVruLz9XWGqBn/u+AuI1F0ERE1FXwT/4OrFCrx74z5U73HTpfgR05pThZWAUAiA30xDv3DBL3x3TzdDjHVvgMAG5yx1EP7AIjIqKWqK1tXg9ER8RPvA7s4U9249ZlW/DjfsfC5r8aBEYhPmoM7u6Pjx8YisWTEjAg0nGRUvuusthAL4f97AIjIurY0tLSMGLECPj5+aFbt2646aabkJWVJe4/e/YspkyZgoCAAHh6eiIpKQnbt28X93///fe48soroVarERgYiNtuu03cJ5PJ8M0330jez8/PD2vWrAEA5OTkQCaTYd26dRg9ejTUajU+/fRTlJSUYMqUKYiIiICHhwcGDBiAzz//XHIds9mMxYsXIz4+HiqVCt27d8crr7wCABg7dixmz54tOb6oqAhKpRLp6emt8WVzil1gHZTOUIe9ueUAgMfW7sXo3kFwk8ugkMvgrpDjr7MVkuNDfS1DAUf2DAIAHDwv3Q8A9jmfh0fHYmhMAM6V1+CpL/8CwACIiLomQRBQU9s+M0Jr3BUtmodIp9MhNTUVCQkJqKqqwrx583Dbbbdh3759qK6uxujRoxEREYHvvvsOoaGh2LNnD8xmS53njz/+iNtuuw3PPfccPvroIxiNRvz0008tbvOzzz6LN998E4MGDYJarYZer8eQIUPwzDPPwMfHBz/++CPuu+8+xMXFYejQoQCAuXPnYtWqVfjPf/6DESNGIC8vD0ePHgUAPPjgg5g9ezbefPNNqFQqAMAnn3yCiIgIjB07tsXtay4GQB3UwXP1AYzJLGDlpixkHCvCqaIqLJjY3yEDZAuAbHzs6n3m3dQXX+89h4dGxYrb1O4KDI/rhjqTGV/sOgNjnRndvFRtczNERB1YTa0JfedtaJf3PvxSCjyUzf8onjRpkuT16tWrERQUhMOHD2Pr1q0oKirCzp07ERAQAACIj48Xj33llVdw9913Y8GCBeK2gQMHtrjNTzzxBG6//XbJtqeeekp8/o9//AMbNmzAF198gaFDh6KyshJvvfUW3n33XUybNg0AEBcXhxEjRgAAbr/9dsyePRvffvst7rrrLgDAmjVrMH369DadpLLd/+RftmwZoqOjoVarMWzYMOzYsaPRYw8dOoRJkyYhOjoaMpkMS5cuveRrdlT7G2R4VmzKwoFzFdAZTXjqy79wqlgn2e+lkv4H8tVYAiA/D3fcPyIG3/9jBIJ9HCeMclPIse6hq/DNo9dA4aQuiIiIOo4TJ05gypQpiI2NhY+PD6KjowEAubm52LdvHwYNGiQGPw3t27cP48aNu+Q2JCUlSV6bTCYsXLgQAwYMQEBAALy8vLBhwwbk5lpWKThy5AgMBkOj761Wq3Hfffdh9erVAIA9e/bg4MGDmD59+iW3tSntmgFat24dUlNTsWLFCgwbNgxLly5FSkoKjh07huDgYIfjq6urERsbizvvvBP//Oc/W+WaHc258hq8t/EkMo4VAQAeG9cTH2fmoKzasdBMqZDDaLKkNn007pJ9PhrLtzbE+8KzZHIaeCLqyjTuChx+KaXd3rslbr75ZvTo0QOrVq1CeHg4zGYz+vfvD6PRCI1G0/R7XWC/TCaD0GD4sLMiZ09P6SCb119/HW+99RaWLl2KAQMGwNPTE0888QSMRmOz3hewdIMlJibi7Nmz+OCDDzB27Fj06NHjguddinbNAC1ZsgQzZ87EjBkz0LdvX6xYsQIeHh5iFNjQlVdeiddffx1333232E94qde8nLT6Wpwtq3Z4ZBfr8N1f5/H13rN4YM1OfLo9VxzOfmW0P24bFCle4/cnR+NfN/QBANwzrDuW3zsYtw+OwB2DIyXv1SfUBwAwMMqxGJqIiOrJZDJ4KN3a5dGSP0BLSkpw7NgxPP/88xg3bhyuuOIKlJWVifsTEhKwb98+lJaWOj0/ISGhyaLioKAg5OXVD7o5ceJEsxaM3bJlCyZOnIi//e1vGDhwIGJjY3H8+HFxf8+ePaHRaJp87wEDBiApKQmrVq3CZ599hvvvv/+C73up2i0DZDQasXv3bsydO1fcJpfLkZycjMzMzMt6TYPBAIOhfgZlrVZ7Ue9/IZ9sO43FacdadE5ChB8i/T3w5a4zGNMnGLFBXngoyAu3DopAoKcKcrkM1w8IczhvYJQfMueORRDreoiIOgV/f39069YN//3vfxEWFobc3Fw8++yz4v4pU6bg3//+N2699VYsWrQIYWFh2Lt3L8LDwzF8+HDMnz8f48aNQ1xcHO6++27U1dXhp59+wjPPPAPAMhrr3XffxfDhw2EymfDMM8/A3d29seaIevbsifXr12Pr1q3w9/fHkiVLUFBQgL59+wKwdHE988wzmDNnDpRKJa655hoUFRXh0KFDeOCBB8Tr2IqhPT09JaPT2kq7ZYCKi4thMpkQEhIi2R4SEoL8/PzLes1FixbB19dXfERFRV3U+1+Im1wGlZvc4aF2l6N/hA8GRvkhwk+DVVOTMKi7H+4YEglfD3fEBHpi9wvX4a3JieK1gr3VkF+gZifMVwM3RbuXeRERUSuQy+VYu3Ytdu/ejf79++Of//wnXn/9dXG/UqnEL7/8guDgYNxwww0YMGAAXn31VSgUlm62MWPG4Msvv8R3332HxMREjB07VlIj++abbyIqKgojR47EPffcg6eeeqpZC8Y+//zzGDx4MFJSUjBmzBiEhobi1ltvlRzzwgsv4Mknn8S8efNwxRVXYPLkySgsLJQcM2XKFLi5uWHKlCmXtMhpc3EUGCzD81JTU8XXWq22TYKgh0bF4aFRcc069rq+0iCOkxQSEVFycjIOHz4s2WZft9OjRw+sX7++0fNvv/12hxFcNuHh4diwQToarry8XHweHR3tUCMEAAEBAQ7zBzUkl8vx3HPP4bnnnmv0mOLiYuj1eklWqC21WwAUGBgIhUKBgoICyfaCggKEhoZe1muqVKpGa4qIiIio7dTW1qKkpATPP/88rrrqKgwePPiyvG+7pRWUSiWGDBkiKYoym81IT0/H8OHDO8w1iYiIqO1s2bIFYWFh2LlzJ1asWHHZ3rddu8BSU1Mxbdo0JCUlYejQoVi6dCl0Oh1mzJgBAJg6dSoiIiKwaNEiAJYiZ1vqz2g04ty5c9i3bx+8vLzEyZ4udE0iIiLqOMaMGeO0a62ttWsANHnyZBQVFWHevHnIz89HYmIi0tLSxCLm3NxcyOX1Sarz589j0KD6BT/feOMNvPHGGxg9ejQyMjKadU0iIiIimdAeYVcHp9Vq4evri4qKCvj4+LR3c4iIqJXo9XpkZ2cjJibmsow0otbX1PewJZ/fHFpERERdDv/2d12t9b1jAERERF2GbWK/5sxwTB2T7XvXnEkam8J5gIiIqMtQKBTw8/MTJ+Hz8PDgeoguQhAEVFdXo7CwEH5+fuIEjxeLARAREXUptnnhGs5ETK7Bz8/voucLtMcAiIiIuhSZTIawsDAEBwc7Xe2cOi53d/dLzvzYMAAiIqIuSaFQtNqHKbkeFkETERFRl8MAiIiIiLocBkBERETU5bAGyAnbJEtarbadW0JERETNZfvcbs5kiQyAnKisrAQAREVFtXNLiIiIqKUqKyvh6+vb5DFcC8wJs9mM8+fPw9vbu9UmyNJqtYiKisKZM2e67PpiXf1r0NXvH+DXAODXoKvfP8CvQVvevyAIqKysRHh4uGQxdWeYAXJCLpcjMjKyTa7t4+PTJX/g7XX1r0FXv3+AXwOAX4Oufv8AvwZtdf8XyvzYsAiaiIiIuhwGQERERNTlMAC6TFQqFebPnw+VStXeTWk3Xf1r0NXvH+DXAODXoKvfP8CvQUe5fxZBExERUZfDDBARERF1OQyAiIiIqMthAERERERdDgMgIiIi6nIYAF0my5YtQ3R0NNRqNYYNG4YdO3a0d5PaxIsvvgiZTCZ59OnTR9yv1+vx6KOPolu3bvDy8sKkSZNQUFDQji2+dH/88QduvvlmhIeHQyaT4ZtvvpHsFwQB8+bNQ1hYGDQaDZKTk3HixAnJMaWlpbj33nvh4+MDPz8/PPDAA6iqqrqMd3HxLnT/06dPd/iZmDBhguQYV75/AFi0aBGuvPJKeHt7Izg4GLfeeiuOHTsmOaY5P/u5ubm48cYb4eHhgeDgYDz99NOoq6u7nLdyUZpz/2PGjHH4Ofj73/8uOcZV7x8Ali9fjoSEBHFyv+HDh+Pnn38W93fm7z9w4fvviN9/BkCXwbp165Camor58+djz549GDhwIFJSUlBYWNjeTWsT/fr1Q15envjYvHmzuO+f//wnvv/+e3z55ZfYtGkTzp8/j9tvv70dW3vpdDodBg4ciGXLljndv3jxYrz99ttYsWIFtm/fDk9PT6SkpECv14vH3HvvvTh06BB+/fVX/PDDD/jjjz/w0EMPXa5buCQXun8AmDBhguRn4vPPP5fsd+X7B4BNmzbh0UcfxbZt2/Drr7+itrYW48ePh06nE4+50M++yWTCjTfeCKPRiK1bt+LDDz/EmjVrMG/evPa4pRZpzv0DwMyZMyU/B4sXLxb3ufL9A0BkZCReffVV7N69G7t27cLYsWMxceJEHDp0CEDn/v4DF75/oAN+/wVqc0OHDhUeffRR8bXJZBLCw8OFRYsWtWOr2sb8+fOFgQMHOt1XXl4uuLu7C19++aW47ciRIwIAITMz8zK1sG0BEL7++mvxtdlsFkJDQ4XXX39d3FZeXi6oVCrh888/FwRBEA4fPiwAEHbu3Cke8/PPPwsymUw4d+7cZWt7a2h4/4IgCNOmTRMmTpzY6Dmd6f5tCgsLBQDCpk2bBEFo3s/+Tz/9JMjlciE/P188Zvny5YKPj49gMBgu7w1coob3LwiCMHr0aOHxxx9v9JzOdP82/v7+wv/+978u9/23sd2/IHTM7z8zQG3MaDRi9+7dSE5OFrfJ5XIkJycjMzOzHVvWdk6cOIHw8HDExsbi3nvvRW5uLgBg9+7dqK2tlXwt+vTpg+7du3far0V2djby8/Ml9+zr64thw4aJ95yZmQk/Pz8kJSWJxyQnJ0Mul2P79u2Xvc1tISMjA8HBwejduzceeeQRlJSUiPs64/1XVFQAAAICAgA072c/MzMTAwYMQEhIiHhMSkoKtFqt5K9oV9Dw/m0+/fRTBAYGon///pg7dy6qq6vFfZ3p/k0mE9auXQudTofhw4d3ue9/w/u36Wjffy6G2saKi4thMpkk31QACAkJwdGjR9upVW1n2LBhWLNmDXr37o28vDwsWLAAI0eOxMGDB5Gfnw+lUgk/Pz/JOSEhIcjPz2+fBrcx2305+/7b9uXn5yM4OFiy383NDQEBAZ3i6zJhwgTcfvvtiImJQVZWFv71r3/h+uuvR2ZmJhQKRae7f7PZjCeeeALXXHMN+vfvDwDN+tnPz893+nNi2+cqnN0/ANxzzz3o0aMHwsPDsX//fjzzzDM4duwYvvrqKwCd4/4PHDiA4cOHQ6/Xw8vLC19//TX69u2Lffv2dYnvf2P3D3TM7z8DIGpV119/vfg8ISEBw4YNQ48ePfDFF19Ao9G0Y8uovdx9993i8wEDBiAhIQFxcXHIyMjAuHHj2rFlbePRRx/FwYMHJbVvXUlj929f0zVgwACEhYVh3LhxyMrKQlxc3OVuZpvo3bs39u3bh4qKCqxfvx7Tpk3Dpk2b2rtZl01j99+3b98O+f1nF1gbCwwMhEKhcKj2LygoQGhoaDu16vLx8/NDr169cPLkSYSGhsJoNKK8vFxyTGf+Wtjuq6nvf2hoqENBfF1dHUpLSzvl1yU2NhaBgYE4efIkgM51/7Nnz8YPP/yAjRs3IjIyUtzenJ/90NBQpz8ntn2uoLH7d2bYsGEAIPk5cPX7VyqViI+Px5AhQ7Bo0SIMHDgQb731Vpf5/jd2/850hO8/A6A2plQqMWTIEKSnp4vbzGYz0tPTJX2jnVVVVRWysrIQFhaGIUOGwN3dXfK1OHbsGHJzczvt1yImJgahoaGSe9Zqtdi+fbt4z8OHD0d5eTl2794tHvP777/DbDaLvyQ6k7Nnz6KkpARhYWEAOsf9C4KA2bNn4+uvv8bvv/+OmJgYyf7m/OwPHz4cBw4ckASDv/76K3x8fMRuhI7qQvfvzL59+wBA8nPgqvffGLPZDIPB0Om//42x3b8zHeL73yal1SSxdu1aQaVSCWvWrBEOHz4sPPTQQ4Kfn5+k2r2zePLJJ4WMjAwhOztb2LJli5CcnCwEBgYKhYWFgiAIwt///nehe/fuwu+//y7s2rVLGD58uDB8+PB2bvWlqaysFPbu3Svs3btXACAsWbJE2Lt3r3D69GlBEATh1VdfFfz8/IRvv/1W2L9/vzBx4kQhJiZGqKmpEa8xYcIEYdCgQcL27duFzZs3Cz179hSmTJnSXrfUIk3df2VlpfDUU08JmZmZQnZ2tvDbb78JgwcPFnr27Cno9XrxGq58/4IgCI888ojg6+srZGRkCHl5eeKjurpaPOZCP/t1dXVC//79hfHjxwv79u0T0tLShKCgIGHu3LntcUstcqH7P3nypPDSSy8Ju3btErKzs4Vvv/1WiI2NFUaNGiVew5XvXxAE4dlnnxU2bdokZGdnC/v37xeeffZZQSaTCb/88osgCJ37+y8ITd9/R/3+MwC6TN555x2he/fuglKpFIYOHSps27atvZvUJiZPniyEhYUJSqVSiIiIECZPniycPHlS3F9TUyPMmjVL8Pf3Fzw8PITbbrtNyMvLa8cWX7qNGzcKABwe06ZNEwTBMhT+hRdeEEJCQgSVSiWMGzdOOHbsmOQaJSUlwpQpUwQvLy/Bx8dHmDFjhlBZWdkOd9NyTd1/dXW1MH78eCEoKEhwd3cXevToIcycOdMh+Hfl+xcEwen9AxA++OAD8Zjm/Ozn5OQI119/vaDRaITAwEDhySefFGpray/z3bTche4/NzdXGDVqlBAQECCoVCohPj5eePrpp4WKigrJdVz1/gVBEO6//36hR48eglKpFIKCgoRx48aJwY8gdO7vvyA0ff8d9fsvEwRBaJvcEhEREVHHxBogIiIi6nIYABEREVGXwwCIiIiIuhwGQERERNTlMAAiIiKiLocBEBEREXU5DICIiIioy2EARERklZGRAZlM5rBmExF1PgyAiIiIqMthAERERERdDgMgInI5ZrMZixcvRnx8PFQqFbp3745XXnkFY8eOxezZsyXHFhUVQalUiitxGwwGPPPMM4iKioJKpUJ8fDzef//9Rt9r8+bNGDlyJDQaDaKiovDYY49Bp9O16f0RUdtjAERELmfu3Ll49dVX8cILL+Dw4cP47LPPEBISggcffBCfffYZDAaDeOwnn3yCiIgIjB07FgAwdepUfP7553j77bdx5MgRrFy5El5eXk7fJysrCxMmTMCkSZOwf/9+rFu3Dps3b3YIsojI9XAxVCJyKZWVlQgKCsK7776LBx98ULJPr9cjPDwcK1aswF133QUAGDhwIG6//XbMnz8fx48fR+/evfHrr78iOTnZ4doZGRm49tprUVZWBj8/Pzz44INQKBRYuXKleMzmzZsxevRo6HQ6qNXqtr1ZImozzAARkUs5cuQIDAYDxo0b57BPrVbjvvvuw+rVqwEAe/bswcGDBzF9+nQAwL59+6BQKDB69Ohmvddff/2FNWvWwMvLS3ykpKTAbDYjOzu71e6JiC4/t/ZuABFRS2g0mib3P/jgg0hMTMTZs2fxwQcfYOzYsejRo0ezzm2oqqoKDz/8MB577DGHfd27d2/RtYioY2EGiIhcSs+ePaHRaMSi5oYGDBiApKQkrFq1Cp999hnuv/9+yT6z2YxNmzY1670GDx6Mw4cPIz4+3uGhVCpb5X6IqH0wACIil6JWq/HMM89gzpw5+Oijj5CVlYVt27ZJRnI9+OCDePXVVyEIAm677TZxe3R0NKZNm4b7778f33zzDbKzs5GRkYEvvvjC6Xs988wz2Lp1K2bPno19+/bhxIkT+Pbbb1kETdQJMAAiIpfzwgsv4Mknn8S8efNwxRVXYPLkySgsLBT3T5kyBW5ubpgyZYpDofLy5ctxxx13YNasWejTpw9mzpzZ6LD2hIQEbNq0CcePH8fIkSMxaNAgzJs3D+Hh4W16f0TU9jgKjIg6nZycHMTFxWHnzp0YPHhwezeHiDogBkBE1GnU1taipKQETz31FLKzs7Fly5b2bhIRdVDsAiOiTmPLli0ICwvDzp07sWLFivZuDhF1YMwAERERUZfDDBARERF1OQyAiIiIqMthAERERERdDgMgIiIi6nIYABEREVGXwwCIiIiIuhwGQERERNTlMAAiIiKiLocBEBEREXU5/w+y4sH8Uoi4sAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10cac05a-3465-44d2-a6c4-886155bea207",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44838feb-d270-45ae-978e-dd690dda0873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c388d09c-45de-4164-967b-d806de19c6d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd6db00b-3f9c-47ad-a85b-3563330cd089",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43da28a5-aa6e-430f-bbfc-0c5c892963f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d5c2ced-8f71-424b-838b-be0b6b1dc218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "468a557f-50d8-4a23-8601-2caae9d7331f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb4a33f1-94f8-43a1-9328-db531554561e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15fdde62-149d-43b7-a205-fd0edbb60aba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66c0a656-acfc-4061-b2d3-73a933703ff2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b5dce62-6d44-4282-b5ba-0352fc3fbcbe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d10f4d8d-ce05-4465-9d7b-23aed749707d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "62121d33-ca98-491d-bb17-576c2741fb8f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0124f2c-c079-433f-a5ec-51bd6c9da501",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b64372ca-1911-4519-a050-ec506a4b27a2",
   "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
}
