{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e954128-4fd2-47cc-8c67-ab75f6023977",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n",
      "4991\n",
      "[[  0 456]\n",
      " [  1 496]\n",
      " [  2 527]\n",
      " [  3 498]\n",
      " [  4 497]\n",
      " [  5 488]\n",
      " [  6 511]\n",
      " [  7 461]\n",
      " [  8 476]\n",
      " [  9 466]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5024"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1, 9, 0,  ..., 6, 4, 2])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e10670e7-831a-431a-a81a-213375bb284a",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "5ca87eb4-75f8-495f-b8b0-052217e63ab5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABsFUlEQVR4nO3dd3hU1dYG8HdmMiVt0nsv9BZISOg1gL0jIlcQBVFEQWxgActVVNSLigL6KViuAnJFsYEQilSpoXcIAdJ7I21mf39M5pAhARKYluH9PU8eM+ecmVk7Ezkre6+9t0wIIUBERETkIOS2DoCIiIjInJjcEBERkUNhckNEREQOhckNERERORQmN0RERORQmNwQERGRQ2FyQ0RERA6FyQ0RERE5FCY3RERE5FCY3BCRRa1fvx4ymQzr16+Xjj388MOIjIy0WUyO5LXXXoNMJrN1GER2hckNkZ07ePAg/vWvfyEkJARqtRrBwcEYNWoUDh48aOvQLO6zzz7DokWLLPoehw4dwmuvvYa0tDSLvo81vf322/j5559tHQaRzTC5IbJjP/30E7p164aUlBSMHTsWn332GR599FGsW7cO3bp1w/Lly20dokVZK7l5/fXXmdwQORAnWwdARI07efIkHnroIURHR+Pvv/+Gn5+fdG7y5Mno27cvHnroIezbtw/R0dFWi6u8vByurq5We7+WgD8TIvvCnhsiOzV79mxUVFTg888/N0lsAMDX1xcLFixAeXk53nvvPQDAsmXLIJPJsGHDhgavtWDBAshkMhw4cEA6duTIEdx3333w9vaGRqNBQkICVqxYYfK8RYsWSa85ceJE+Pv7IzQ0FABw5swZTJw4EW3atIGzszN8fHwwfPhws/WAREZG4uDBg9iwYQNkMhlkMhkGDBggnS8qKsKUKVMQFhYGtVqN2NhYvPvuu9Dr9Savs3jxYsTHx8Pd3R1arRadOnXCRx99JLVv+PDhAICBAwdK71O/PuhSDz/8MNzc3HDy5EnccsstcHd3x6hRowAAer0ec+bMQYcOHaDRaBAQEIAJEyagsLDQ5DV27tyJYcOGwdfXF87OzoiKisIjjzwinW+sTgkA0tLSIJPJrtibJZPJUF5ejq+//lpqz8MPPwwAKC0txZQpUxAZGQm1Wg1/f38MGTIEu3fvvuzrEbVE7LkhslO//vorIiMj0bdv30bP9+vXD5GRkfj9998BALfeeivc3NywdOlS9O/f3+TaJUuWoEOHDujYsSMAQx1P7969ERISgmnTpsHV1RVLly7FXXfdhf/973+4++67TZ4/ceJE+Pn5YcaMGSgvLwcA7NixA1u2bMEDDzyA0NBQpKWlYd68eRgwYAAOHToEFxeX62r/nDlz8NRTT8HNzQ0vv/wyACAgIAAAUFFRgf79++P8+fOYMGECwsPDsWXLFkyfPh2ZmZmYM2cOAGD16tUYOXIkBg8ejHfffRcAcPjwYWzevBmTJ09Gv3798PTTT+Pjjz/GSy+9hHbt2gGA9N/Lqa2txbBhw9CnTx+8//77UlsnTJiARYsWYezYsXj66adx+vRpzJ07F3v27MHmzZuhVCqRk5ODoUOHws/PD9OmTYOnpyfS0tLw008/XdfPy+jbb7/FuHHjkJiYiMceewwAEBMTAwB4/PHHsWzZMkyaNAnt27dHfn4+Nm3ahMOHD6Nbt25meX8iuyCIyO4UFRUJAOLOO++84nV33HGHACBKSkqEEEKMHDlS+Pv7i9raWumazMxMIZfLxRtvvCEdGzx4sOjUqZOorKyUjun1etGrVy/RqlUr6djChQsFANGnTx+T1xRCiIqKigbxbN26VQAQ33zzjXRs3bp1AoBYt26ddGzMmDEiIiLiim0TQogOHTqI/v37Nzj+5ptvCldXV3Hs2DGT49OmTRMKhUKkp6cLIYSYPHmy0Gq1DWKv78cff2wQ35WMGTNGABDTpk0zOb5x40YBQPz3v/81Ob5y5UqT48uXLxcAxI4dOy77Ho39zIQQ4vTp0wKAWLhwoXRs5syZ4tJ/yl1dXcWYMWMavK6Hh4d48sknm9BKopaNw1JEdqi0tBQA4O7ufsXrjOdLSkoAACNGjEBOTo7JcMayZcug1+sxYsQIAEBBQQHWrl2L+++/H6WlpcjLy0NeXh7y8/MxbNgwHD9+HOfPnzd5n/Hjx0OhUJgcc3Z2lr6vqalBfn4+YmNj4enpafFhjh9//BF9+/aFl5eXFH9eXh6Sk5Oh0+nw999/AwA8PT1RXl6O1atXmz2GJ554okFMHh4eGDJkiElM8fHxcHNzw7p166SYAOC3335DTU2N2eO6Ek9PT/zzzz/IyMiw6vsSWRuTGyI7ZExajEnO5VyaBN10003w8PDAkiVLpGuWLFmCuLg4tG7dGgBw4sQJCCHw6quvws/Pz+Rr5syZAICcnByT94mKimrw3hcuXMCMGTOkmhdfX1/4+fmhqKgIxcXF19jypjl+/DhWrlzZIP7k5GST+CdOnIjWrVvj5ptvRmhoKB555BGsXLnyut/fyclJqj2qH1NxcTH8/f0bxFVWVibF1L9/f9x77714/fXX4evrizvvvBMLFy5EVVXVdcd1Ne+99x4OHDiAsLAwJCYm4rXXXsOpU6cs/r5E1saaGyI75OHhgaCgIOzbt++K1+3btw8hISHQarUAALVajbvuugvLly/HZ599huzsbGzevBlvv/229Bxjwe1zzz2HYcOGNfq6sbGxJo/r99IYPfXUU1i4cCGmTJmCnj17wsPDAzKZDA888ECDol5z0+v1GDJkCF544YVGzxsTOX9/f6SmpmLVqlX4888/8eeff2LhwoUYPXo0vv7662t+f7VaDbnc9G9DvV4Pf39//Pe//230OcaicJlMhmXLlmHbtm349ddfsWrVKjzyyCP44IMPsG3bNri5uV12UT6dTnfNMQPA/fffj759+2L58uX466+/MHv2bLz77rv46aefcPPNN1/XaxPZEyY3RHbqtttuwxdffIFNmzahT58+Dc5v3LgRaWlpmDBhgsnxESNG4Ouvv0ZKSgoOHz4MIYQ0JAVAmjauVCqlno5rsWzZMowZMwYffPCBdKyyshJFRUXX/JqXutxNPiYmBmVlZU2KX6VS4fbbb8ftt98OvV6PiRMnYsGCBXj11VcRGxtrttV9Y2JisGbNGvTu3bvRZPBSPXr0QI8ePfDWW2/h+++/x6hRo7B48WKMGzcOXl5eANDgZ3nmzJkmxXKlNgUFBWHixImYOHEicnJy0K1bN7z11ltMbsihcFiKyE49//zzcHZ2xoQJE5Cfn29yrqCgAI8//jhcXFzw/PPPm5xLTk6Gt7c3lixZgiVLliAxMdFkWMnf3x8DBgzAggULkJmZ2eB9c3NzmxSfQqGAEMLk2CeffHLdvQv1ubq6Npos3X///di6dStWrVrV4FxRURFqa2sBoMHPTS6Xo3PnzgAgDQMZ16e53qTs/vvvh06nw5tvvtngXG1trfT6hYWFDX5ucXFxJjFFRERAoVBItUNGn332WZNiaeznptPpGgwX+vv7Izg42CpDYkTWxJ4bIjvVqlUrfP311xg1ahQ6deqERx99FFFRUUhLS8OXX36JvLw8/PDDD9I0XyOlUol77rkHixcvRnl5Od5///0Gr/3pp5+iT58+6NSpE8aPH4/o6GhkZ2dj69atOHfuHPbu3XvV+G677TZ8++238PDwQPv27bF161asWbMGPj4+ZvsZxMfHY968efj3v/+N2NhY+Pv7Y9CgQXj++eexYsUK3HbbbXj44YcRHx+P8vJy7N+/H8uWLUNaWhp8fX0xbtw4FBQUYNCgQQgNDcWZM2fwySefIC4uTpruHRcXB4VCgXfffRfFxcVQq9UYNGgQ/P39mxVr//79MWHCBMyaNQupqakYOnQolEoljh8/jh9//BEfffQR7rvvPnz99df47LPPcPfddyMmJgalpaX44osvoNVqccsttwAwDEsOHz4cn3zyCWQyGWJiYvDbb781qIW60s9tzZo1+PDDDxEcHIyoqCi0adMGoaGhuO+++9ClSxe4ublhzZo12LFjh0nvG5FDsO1kLSK6mn379omRI0eKoKAgoVQqRWBgoBg5cqTYv3//ZZ+zevVqAUDIZDJx9uzZRq85efKkGD16tAgMDBRKpVKEhISI2267TSxbtky6xjgVvLFpy4WFhWLs2LHC19dXuLm5iWHDhokjR46IiIgIk2nI1zMVPCsrS9x6663C3d1dADCZFl5aWiqmT58uYmNjhUqlEr6+vqJXr17i/fffF9XV1UIIIZYtWyaGDh0q/P39hUqlEuHh4WLChAkiMzPT5H2++OILER0dLRQKxVWnhY8ZM0a4urpe9vznn38u4uPjhbOzs3B3dxedOnUSL7zwgsjIyBBCCLF7924xcuRIER4eLtRqtfD39xe33Xab2Llzp8nr5ObminvvvVe4uLgILy8vMWHCBHHgwIEmTQU/cuSI6Nevn3B2dhYAxJgxY0RVVZV4/vnnRZcuXYS7u7twdXUVXbp0EZ999tmVPgKiFkkmxCX9o0REREQtGGtuiIiIyKEwuSEiIiKHwuSGiIiIHAqTGyIiInIoTG6IiIjIoTC5ISIiIodywy3ip9frkZGRAXd3d7Mtu05ERESWJYRAaWkpgoODG+ztdqkbLrnJyMhAWFiYrcMgIiKia3D27FmEhoZe8ZobLrlxd3cHYPjhGHdSJiIiIvtWUlKCsLAw6T5+JTdccmMcitJqtUxuiIiIWpimlJSwoJiIiIgcCpMbIiIicihMboiIiMihMLkhIiIih8LkhoiIiBwKkxsiIiJyKExuiIiIyKEwuSEiIiKHwuSGiIiIHAqTGyIiInIoTG6IiIjIoTC5ISIiIodi8+Tm008/RWRkJDQaDZKSkrB9+/YrXl9UVIQnn3wSQUFBUKvVaN26Nf744w8rRUtE1HJcqNbZOgQim7BpcrNkyRJMnToVM2fOxO7du9GlSxcMGzYMOTk5jV5fXV2NIUOGIC0tDcuWLcPRo0fxxRdfICQkxMqRExHZLyEE3l15BB1mrsTLy/ejVqe3dUg3PJ1eYOqSVNz80UZ8knIcmcUX8OveDCagFiITQghbvXlSUhK6d++OuXPnAgD0ej3CwsLw1FNPYdq0aQ2unz9/PmbPno0jR45AqVRe03uWlJTAw8MDxcXF0Gq11xU/EZE9+jjlOD5cfUx6fE/XEHxwfxfIZDLpWHlVLXakFaBPrC+cFDbvxHcIZVW1KKusRaCHpsG5T9edwOxVRxsc79/aD1893B0KuazBOTLVnPu3zZKb6upquLi4YNmyZbjrrruk42PGjEFRURF++eWXBs+55ZZb4O3tDRcXF/zyyy/w8/PDgw8+iBdffBEKhaLR96mqqkJVVZX0uKSkBGFhYUxuiMhsqmp1+H1fJo5ll+GJ/jHYd74I0X5uCPF0bnBtYXk1Vh7MwuC2/lA5yaFRKqBRNv7v17XYkVaAEQu2Qi+AkYnhWLrzLHR6gXZBWtzcMRAJEV7QqBT4cedZ/LD9LLxclPBzV+OB7uHo19oPaic5wrxdzBaPo9PrBWauOIgArRrbThVgR1oB/nqmHyJ8XKVr8suqkPR2Cmr1Aj2ivXEipxx5ZRfvSy/d0haP9YuRHlfV6pBRVIkIbxfI65Ke6lo9lAqZSYJ6o2lOcuNkpZgayMvLg06nQ0BAgMnxgIAAHDlypNHnnDp1CmvXrsWoUaPwxx9/4MSJE5g4cSJqamowc+bMRp8za9YsvP7662aPn4jI6Knv9+CvQ9kAgGW7zkk3rrgwT2SXVEKjVODebiGo1gn8tPsczhVegItKgQs1OijlcozoHoYHEsPw97E8RPm6YEj7wGv+S/7tPw5DL4B7u4Vi1j2dEOvvhjd/O4TDmSU4nFnS4PrCihoUVtTgjd8OAQCUChlu7xKM1gHueLhXJNRO8iveUDOLL+DrLWcwuJ0/ukd6X1PMLdn+88X4dtsZAIBMBggBbD6Rb5LcbDiWi1q9QNtAd/wwvgcKK2qQerYQ6fkVeO3XQ/huWzrG943Gr/sykVNSiaU7z+JYdhl83VT46IGucJLLMO6bnejbyhefPtgNx7LLUKPTo2OIh62abfds1nOTkZGBkJAQbNmyBT179pSOv/DCC9iwYQP++eefBs9p3bo1Kisrcfr0aamn5sMPP8Ts2bORmZnZ6Puw54aIAKC0sgbumssPZ+9OL8SzS/dCpZDj2aGtMbRDYJNe92BGMW79eFOD48YbXWOc5DLU6sVlr+8T64s74oLh765Gj2ifJvfs5JVVIeHfawAA/7w0GAFaDYQQ2HoyH4ezSvH7vgzsTi8yeY7aSY6q2sZrcnzdVCi5UIvx/aIgl8nQr7UfLlTroFTI0TPGB3q9wPAFW7HrTCEAYOqQ1nh6cKsmxeooFm4+jdd/PWRybERCGN69r7P0+Kkf9uDXvRl4cmAMnh/WVjpeUV2L+DfX4EKNDiGezjhfdKFZ7/3a7e2R3D4AKw9kQSaTwV3thD6tfBHs6Yy9Z4uw/XQB7uoaAj939fU10k60iJ4bX19fKBQKZGdnmxzPzs5GYGDj/6gEBQVBqVSaDEG1a9cOWVlZqK6uhkqlavActVoNtdoxPlgiujbfbTuDV34+gNn3dcbwhLBGr1m++zxO55UDABb8fQr/nC6Al4sSkwZd+Wa9cHMaAOD2LsHwdlHi661n8K8e4XhqUCusO5IDTxcl0gsqsP98CbQaJwR7OuP+hDDsOlOANoFarDuSgzd+OwQhDMlEfnk1Np3Iw6YTeQCACB8XdA71RHWtofC0olqHHtE+GNDGDx2CTf9y//tYLgCgfZAWAVpD3YdMJkOvWF/0ivXFo32iUFpZgy6v/wW9AF65tR3G9IpEdkklRizYhg7BWrhrlEjLL8fJ3DLklVUDAD5ddxIA8Nn6k9DpBeQyYPrN7bD6cLaU2ADARynHkdwuAO2DtcguqcTWk/lwVTthUFt/nMotw8ncciRGecPbteG/1S3VpckiAOw9VwS9XmDTiTx0i/DChqOGSTKD2vqbXOeicsKgdv74fV8mzhddgFIhQ4BWg6paPT5/KB7v/HkE/5wuuOx7v/brIbx2SWLlrnbCf0bE4YX/7UNBeTVmrzqKpGhvTLu5bYPfFwDYcjIPv+zJwNAOARjYxl8aBmvpbJbcqFQqxMfHIyUlRaq50ev1SElJwaRJkxp9Tu/evfH9999Dr9dDLjcUwB07dgxBQUGNJjZERNW1erzy8wEAwPPL9l02uTmWXSp9v+tMoXTTbhXgjmFX6MVZeSALADCmZwS6hnvhzq4hiAv1hFwuwwOJ4Zd93k0dgwAAkb0jUVRRjeILNZh+Szv8uOscPk45jmhfV5zMLceZ/Aqcya8wee7G43mYveoo3ru3M+7vfrE9648akpuBbf0u+77uGiVWTOqD9UdzMLpnJJQKOUK9XLB52iCT6zKKLmDziTycK7yARVvSUHyhBrq63ia9AN7647B07dt3d8KmE7n4Y38WJny3EyMTwzFv3UmUVtUCMCRo9dvQPkiLKF9XvHRrO/i6qaB2MvzBWlRRDQ9nJXJKq3AipwxRvq4IbqRuyZ7srpfcGR3LLsVXm0/j378fRlyYJ0oqa+HhrERcmFeDa+/sEozf92XCVaXAN48mIj7CGzq9gEIuw5cPd8evezMQ7OmMSB8X3PLRRjirFFj8WA+s2JuJBRtOoqpWj8QobwRoNTiWVYqj2aUY981O6fWrdXpsPJ6Hjcc3wU3thO6RXnh6cCv8eSAL/5wuwIHzxdDpBZbsPIvWAW7IL6tG/zZ+uL1zMP4+ngtnpQKx/m74+1gunhwYi1YB7hb9eZqLTWdLLVmyBGPGjMGCBQuQmJiIOXPmYOnSpThy5AgCAgIwevRohISEYNasWQCAs2fPokOHDhgzZgyeeuopHD9+HI888giefvppvPzyy016T86WIrqxLN9zDs8s2Ss9XvfcAET5uja4Lv7N1cgvr25wPECrxobnB5oMDZVV1cJVpUBFtQ4dZq4CABx8fRhc1eb9e7H4Qg2+2ZIGvQC0zk7QC0NNzIrUDOw8U4gBbfywaGyidH3iW2uQU1qFJY/1QFK0j1ljqa7VY8GGk6jRC3ycchwAcHPHQEwaFIsOwR7ILqnEnXM3I6ukUnpOkIcGmcWGx3KZISm6lFIhQ68YX0T4uODbbWfQOdQTB88Xo1YvoFLIcVfXYHi6qDChXzTcNE74ZU8GNp/Mw64zhegZ7YPZw7uYvF6tTo+1R3IQF+YJf23DWUvmlFNSicS3UyCTAQqZYahRo5SjskYPLxclCitqpGtv7hiIef+Kb/AaQgj8vj8THYM9ENnI72V92SWVUDvJ4eli+GO+VqdHWVWt9LiyRoepS1Pxx35Dwv2fEV3QKcQDL/10ANvTLt8D1CPaGwfOl6CsLhm9HF83NT59sCt2nilEWl45gjw02H++GOkFFfjm0aRGC+jNqUUMSwHAiBEjkJubixkzZiArKwtxcXFYuXKlVGScnp4u9dAAQFhYGFatWoVnnnkGnTt3RkhICCZPnowXX3zRVk0gIjtn7Fkx+nVvRoO6kPyyKimxCdRqTG7Q2SVV2JlWiD6tfAEAhzJKcMfcTXioZwTG9IwEALioFGZPbADAw1mJpxqpYeke6Y2bP9qI7acLUKPTQ6mQo0anR25dIXOMv5vZY1E5yaVYgj00OJlbhueGtZF6XQK0Gvz4eE88+f1uVNbocFOHQEwa1Ar/nM7H4h1n8UjvSHi6qDDxu90I93HB+cILOJRZghqdwIa64TQA2Hu2CADg765GTmkVlu48B8DwuTmrFDiVWy5d++OucxjXNxptAt2RlleOJTvPYk96IbadMgwpfjKyGxIivbD9dAHSCypwoVqHtPxyKBVyPNQzAsUXauDvroa3qwoXqnXwcWteCcOhugLtWD83TB3SGqWVtVh/LAd/7M8ySWwAoFdM48mmTCbDbZ2Dm/R+AZcka06Ki4kOAGiUCnwyshu6hJ5CSWUN7ugSAoVchq8fScSv+zLg567GjzvPIuVwDnzd1Jic3AoR3i5IjPJGXlk1/jyQiR1phfh1bwYA4P6EUBzNKsXec8UADDVdIz7f1mhsj3+7C4Pb+eOuuJCrJmnWYNOeG1tgzw21NEezSpFbWiXdXI0qa3RSb8L20wU4mFGMvq38EOXr2uyZNsUXDP8Qezhf2/pR9uzOTzdj79ki9G3li43H8zCwjR8W1uvtqL/+SKiXM9oHaaWZT8Zi2+R2/ugZ44vRPSPw9ZY0/Pv3w+gQrMXrd3TAffO3ItzbBX+/MNBqbdLrBRLeWoOC8mose7wnEiK9kV1SiaS3U6CQy3Ds3zfb/bopQghU1epxrrACzy/bhz3pRegS6gE3jRN6x/ri8X4x+GnPeWw/nY+1R3Kk+h8fVxVGJYVje1oBtp0qgJvaCQ90D8P/bTrd4D3kMsBV7YTSyoY9Et6uKhSUV8NZqYCLSoHiCzW4My4Ed3cNQUKkF1bszUBSlDcifFyxO70QNbX6Br1h//3nDF5efgCD2/rjy4e7AwB+3nMeU5akNni/NVP7IdbfPoZ0anV6KOSXn1a+9kg2tBolEiK9pc+polqHV385gN/3ZSLa1xV3dw3B4awSHM0qxcl6CafKSQ4PZyU6hXjgq7qfibm0mJ4bIjIw/gNiTFbS8soxZ80xBHk647/bzqCkshYP94rEmsPZmDqkNVoHuOPBL7YhyMMZPaK98e22M1KXv4tKgUd6RyG5fQB+2n0OXcM9cXfXUACG2Rn/nCrAmfxy7DtXjAcSw7H9dD4+WXsCHs5KLJnQE7+knkfq2SK8cms76R/j+v/YtTR5pYbejO6R3th4PA8ZRZUm5+svrBbr74bWAe5ScjNxQCz+s+YY1hzOwZrDOVKPBQDkllYht+61rT0bRS6XoWe0D37fn4nNJ/KREOktxeLjqrL7xAYw9FholArE+rtj6YSeOJZdivZBWpMb7n3xobgvPhQllTVYdyQHFdU6DOsQCG9XFdYeyca2UwUoq6o1SWxGJoZjRPcw/HfbGfy46xxKK2sR5KFBh2APqJ3kCPbUYNGWNBTU9dRdqNHhQo2hWPt/u8/hf7vPIdhDg4ziSmiUckwd0hrv/3UMNTo93r+vC+6ND5Xe63yhYXZTiNfF4ZhB7UyLhgHD70eMn/l7067V1RZtHNT24hItxs9Jo1Tg0we74dVbK+HjpoKy3ms8syQVy/ecl2Z85ZZWIbuksrGXthomN0R24D+rj2HehpP47tEkVOv0GP/NTlTWmE7PXbQlDQAwdenF+pGSSkMBIQBolHLohWE2zdx1JzB33QkAwDdbz+D1Xw+hXaAWZwsrcK7w4nTTn/acl77PKa3CwPfXS4/T8srx85O9setMIR792lCg+GifKDyYFI5/ThVgzeFs3NstFLd0CmzwF2BWcSVO5JShV4yPTWdfCCGkm36XME8AhkJZo5xL/gH2dlGhVYDhJuSmdsK/eoTjP2survR7Kq8cJ3MMf6Xml1dL/4D7ull/QkN8hBd+35+JI1mGoRFbJVrmoFTIG53JY6TVKHFnnOk2O/1a+SEx0hsZxRcQ6eOKjKIL+OTBrtLrdAn1wE0dAyGXy9C/lZ/J7+GANv54/Ntd6NvaF20DtXBSyJAQ4Y3/7TqHJTvPIqOuTqiyRo+3/7i47toL/9uH3rG+0grExqnb9WtNtBolfFwNs97aBWlRVFGNUUnhDrP4XmOrL78/vAumDmmNUC9nHMwogUxmqM+xJSY3RHbg47WGRGTE59vgrFQ0SGwuJ8TTGb7uaoxKDMfwhFDoBbD6UDbmbziJw5kl0volRRU12HoqH4ChlqFtkBa7zxSirKoWTnIZhieE4Yft6QAArcYJJZW1SMuvwND//I2c0ovrRH256TS+rPdX8tojOegU4gEPZyUOZhSjskYPN40TCsurUasXGNDGDx890BVFFdVw1yixJ70Q3207g/JqHV69tT06hXqguKIGX246haEdAnEytwx+bmr0ivXFwYxibDqeh3/1iICr2vCani7KJt8kMosv4FzhBVTX7avUJdRw0yutqkVJZQ20GqVUSwAYerweTApHlK8rIn1cMLhdAHzc1Ehu5481hw1TeUsqa6SeG51e4FiO4XtbJBT+WsN7GmuFWnJycy2cFHIsfbznZc/LZDIMbhfQ6Lnesb7Y8Upyg/WDEqO8kRDphfkbTuKZIa3xzdYz2F5vKrZOL3Aip0y6wZ9rpOcGAH58vCf+b9NpPJPc+ob4PBRymbSqtb0sLMjkhsjG6i/DDhi6yfu19sPnD8Xj/VVHoVDIsP5ILo5ml+KD4V0Q5KnBws1peDApHAPbmHaBK2TATR0DcVPHQAghIAQwr266qJeLEkUVNRjXNwruGiUqqmvx9ZYzSIzyQnyEN7qEeuBEThmeGtwKWcWVmPDtTqTVTd8N9tBg2i3t8M2WNOw/XwxPFyUGtvHHir0Z2H++uEH8gOEfvPVHc3HH3E0NpjIDwF2fbcZLt7TDlhN5SDmSg0/r1lABDD1Ea4/k4HReOX7cdQ4dgrX4JTVD+rlolAoIIUwSnYyiC3h35RHc0SUYnUI9MPiDDaio25TQw1kJTxeVNIMlo+gCtIFK7DtXBAAYHh+K9+7rLL3e+ucv1s98/lACPlx9DHPXncDJnDKTGVXGFX/93Cw7K6cxxrVi8ut+f4zFxH42/ou5pbjcwojDE8Kk5QLaBLjjrk83I9TLBd6uKmw9lW9SbG4clgr1Mt2uItrPDW/f3clCkVNTMLkhspDf92WitLIGDySGo6iiGimHc3BblyBpdonRnksWAVMqZJj7YFdolAq8clt7AMCoxAgcyCjGzR0NQ0C9YkyLixsjk8kgkwFPDoxt9LyLyglPDLi4n039NVk8nJX4c3I//L7f0IYBbfwR5euKO7qYzup4dmgb/JJ6Hm5qJ3QI9oCnixKllbVwUSlQUlmDkZ9vM0lsPJyVGNE9DOcKK/DH/iy8+dvFBch09eYJ1+8dOpFThhN1PSR/H8vFiAVbUVpZi9zSKtzcKRBRvm74ZmuaNOX4WHYZQr2cpcQGuNibEezpjMKKGpwruIB//3ZYWiivS5jnZXuE5HIZwuv+Kt2RZrqmiTG58XW3/rCUsdvfWDtiHGIz9ujQ9WsV4I6/XxgItVKBmb8cBABpKLK6Vo/sUsP3lp4CTc3H5IbIAooravDk97sBAJG+rvh5z3ks3nEW207lY/bwLtDrBeauOwFvV5U0bt851AOhXs54enAraC/ZJiDcxwXhPtbdzNBZpcB99YonG+Pnrsa4vtGXPT/3wW6YueIgHkgMw4OJ4XBWKaB2MvS6LNqShk/WnkBBeTUm9ItGeXUtukd640ROGT6pG6Yb1iEA7YK0yCmtQqBWg/kbTpoMJRmnCdfX2B5Kxt6MEE9DTcDWU/lSYgMACZENF1erz5i8GGeVGRmHD23RW2LsuSmsqMG//u8fqT3suTEv4/TwgLqk0ZhEZhVXQgjDjDpb1FzRlTG5IbKA+gtmfbL2ODafMNS7/LjrHKYObY2/Dmbjw9WGQtVOdWPUo5LCMaL75Ve0bYkGtvXHwLYNZ4/IZDKM7R2FMT0jkVdWZbLYWmWNDn/sz8S5wgt44aa2JrNM7k8Iw/9tPAWtsxIJkV5487fDOJJVgrviQhDj54r3/zrW4L0A054bAFhz+OK2L58/FI+2gVeeVurjeuWEwdcGdRVeLippP6r6iZqfu/WHyG4ExjVmsksMw3/nigw9kiGezg5TLOxImNwQWcDWk/nS98bExmjU//2DzHrTkY01K8bZPDcSuVzWYBVZjVKB5U/2RnlVLYI8TLv7Az000lAdAPz2VB8UVlTD100NIQTmbzjV6CqrxuTGOHxgHCp7oHtYkzbIvDR5cVc7SVsLALbpLVHIZfByUUnDUlIsN0ABqy0Ye26MQ1GbjhsSylBv6/aoUtNcebI7EV0T48yk+ovi+biq4O2qwqnccqno1kijlCPWjtbBsDWtRtkgsWmMQi6Tak9kMplJ7UOP6Itr8vjUDRtcuk9R++CmLeTpc8lGj5cOY9kqoWhsA0omN5Yh9dwUV+JoVik+//sUAGBk98b3KiPbYnJDZGbFFTXS2iM/1puq+kifKKx+ph8mD26Fz0Z1w9jekdK5dkHaqy6sRVdXf0puv9YXN4+srpsSnxjlDY3y4s+5QxOTG41SAfd62yv0qLdSbVKU92Vn3lhaY8mNP5MbizAmNzmlVfhi4ynU6gWS2wXgpo5X7/kj6+OwFJGZncwrgxCG6dOtA9yx8OHuWLE3Aw/1jIBWo8QzQ1oDgMlsno5XWMCMmq5+z02078WesPZBhiTGz12Nu7uG4IftZwEAba5Sa1Ofj5sKpVW1cFM7oW3QxedNTm6495O11C9kTW7njzvjQiyyxxVd7BGr1Qss22UoZH+kTyTrbewU/y8gMoManR5rDmWjsKIGFdWGWgzj7KbLFdW2Dby4z0zHEO5zZg6h9XpuIn1dsGpKP+w9W4Qh7S8u5vbs0DbYfCIf7YO0cGtGIuDjpkZafgVi/FzRNdwToV7OiAvzRE8z777dHPV7bp4cGIuu4Vee9UXXTqkwzIoy7nHl66ZCUpTtPnu6MiY3RNdJpxd44rvdJjNwAEhro1xOrL8bFHIZdHpxxaXnqenqD0uFe7vAReWENoGmmxX6uqmx4fkBzf6L29hLEuPvBq1GiY11G2Xa8i93N/XFmq4wFrZaXIBWIyU3N3cMahF7eN2oOMhPBKCqVod3Vx7B7vTCq198if/beKpBYgNcPbnRKBWYeXt7PN4/psm1H3RlkT6uAAzDUy6qy//tdi0JSVTdMJdx6r5hkUTb3twq6xWmX1r0TOY3rm8U2gdp0beVL8b1jbJ1OHQF7LkhAvBJygnMW38S89afRNo7t17x2tWHshGo1aBT3V5FxjVGpiS3wkcpxyHqFtoNr7vRXsnonpHXFTeZ6hCsxWu3t29WLU1TTRoUi/gIL/RrffXVoa1FW282nq0TrRvB3V1DcXfXKy9sSfaByQ0RgI3Hc6Xvq2v1UDk13qm5I60A478x7JB94q2b4aSQ42yBYc2UHtE++HVvBk7mGnaNvlrPDZmfTCbDw70t8xe1m9rJpHbHHjzaOwp70gsb7JhNdKPjsBTd8IQQOF9vUT3jNO76iiqqIYTAT7svLve/91wxdHohbZ8Q5u2C1gEX6zuY3JClebgo8e2jSVfdJoPoRsOeG7rhncwtN9mZ++stZzC2twwd62orvv8nHS8t349eMT7YUm/l4a+3pOFcO3/U6ASUChkCtRp4ulwcJvByMd0fioiIrIM9N3TDM64mbPS/3edw16ebsbmulsY4ZFU/sQGAFXszMHlxKgBDAatCLpOGB8K8ud8MEZGtMLkhh3YsuxQPfL4VO9MK8MKyvfh5z/kG16ytm+kUV29vp1q9wBPf7UJZVS1O1dXQRPq44LbOQXjv3s4NXsM4DbdHtA8WP9YDyx7vZYHWEBFRU3BYihzaoi1p2HaqAPfN3woAWLrzHO6MC5Z6VcqrarG5rkfmtTs64O0/DqNdoDtWHsxCdkkV9p0rwuk8Q3Lz7aNJUhIjl8vw2foTUuJTf42RHjZc1I2IiJjckIPadiofa4/kYPeZhuvWnC24IK0evPF4Lqpr9YjwcUGXUA8snWDYC+ps4QVkl+Rg/dFcVOv0UDvJTTZdvC8+FPERXhj4/noAXGOEiMieMLkhh/TA59sue253eqGU3Kw/aqinGdw2wKRGppW/G9YeycGqg1kAgChf1warkUb5XlzH5tLdpomIyHZYc0MOp0anv+L5+qsQ76rr2ekZYzqUFOtvWI32TL5hDZsYPzc05sfHe+KpQbEYzqm4RER2gz035HCMdTCXsye9CABQfKEGx3PKAABdwz1NrmkVYLofUYxf46sNd4/0RvdI72sLlIiILII9N+RwGluE79Lzer1A6tkiAECEjwt83dQm1xh7boy42zIRUcvB5IZaLCEEqmv1qKzR4f82nsL+c8UAgMOZpQAAZ6UCvm5qjEwMBwD0jvWBXAbU6ATyyqqwp254qlsjiYub+mKnZscQLQa08bN0c4iIyEw4LEV2K6ekEm/8dgiP94+RVgsGgLKqWny9JQ1Ld56VamIAINTLGX8/P1DquXnp1nZ4qEcEqmp1CNRqcHOnQIz+cjuySiqRUVwp1dt0u2RIyujdezth7ZEcvH13Jy7IR0TUgjC5Ibv17I97sfF4Hn7bl2myU/dzS/diZd0spvrOFV7Ayz8fwJYThnVr2gUa6mbUTgpMTm4FAAjy1CCrpBLpBRXYmWZIbhKjGl+XZkT3cIzoHm7WNhERkeUxuSG7dTCjYe1Mda0ea4/mAAD+fVdHtAvSYtmus9iTXoQjWaX4YXs6AGBYh4BGh5uCPZyxB0VYdSALF2p08HFVoXVA4zOhiIioZWJyQ3ZLpbhYElZYXg0vVxWOZpWiulYPD2clRiWFQyaTIT7CC4cySnDbJxshk8nwwrA2GN83GnJ5w6GkIA8NAOD3/ZkAgB4xPhxyIiJyMExuyC7V6PTIL7+4U/ehzBL0jvVF6lnDUFKXME+TpKR9sBbLnugFrcYJsf7uDV7PKOiSxfZ6cqsEIiKHw9lSLdhXm05j9qoj0OuFrUMxu/SCCtToLrbrwHnDTKjUs4b/xoV6NHhOt3CvKyY2wMWeG6O+rXyvN1QiIrIz7LlpofakF+KN3w4BAOIjvDCobYCNI7o+OSWVUDsp4OGixIerj+HjlOMm5/edL8Yvqeex9kjdDt6XmeF0NfWTm44hWkT4NL44HxERtVxMblogIQRm/XlEevx/G0+36OSmtLIGiW+nwNNFiW8eSTRJbHxcVcgvr8ZfB7Pw+z5DnYyHsxLx4de2KnD9PaBu7hh0fYETEZFd4rBUC3Su8AK2ny6Ak1wGhVyGLSfzcaJuG4GW6GiWYdG9oooaPLt0r8m5JwfGIi7MUxqiuq1zENY9NwAeLspreq/6KxHf2onJDRGRI2LPTQt0KNMwRbpNoDvcNU7YdqoAu88UNtgywN7ll1XhlZ8PwNNFJR0z7vX0x9N9kVl8AX1a+SLCxwWPfr0T7honvH5HB3i7qi73klelkMvw5+S+qKzRIdKXQ1JERI6IyU0LdKRue4G2gVp4uiix7VSBlPC0JL+kZuDPAw0X49NqnNAuyB3tg7UAgMHtAvDpg90Q4eMCn0v2gLoW7YK01/0aRERkv5jctEDG7QXaBbnDq67XoyUmN5fb4LJ9sLbB2jO3duYQEhERNQ2TmxbocF0i0zZQKw3RHM4sgRCiRSxIp9cLyOUyHKmrtblUx+CG07yJiIiaislNC1NeVYszBYbNItsGuUOrUUKpkKG0shbnCi8gzNvFxhFe2bsrj+D/Np5CfIQX9tXt4n2pDiEcNiIiomvH2VItzJGsUghhmPXj66aGykmOVnUL1x3MKMH+c8WoqtXZOEqD7JJKJL29Bq//elA69sue86jRCWw7VXDZ53Vgzw0REV0HJjctzO4zhu0H4sIuJgCd61brfXflEdw+dxNmrzxqk9gulXI4B9klVVi4OQ2ncstQVFGNjOLKy17/SO8oTOgfjVYtbNYXERHZFyY3LczOM4Yej/iIi4vYJUQavj+dVw4A+PNAFoSw/ZYMeWUX94b6YuMpHK6b5RXq5YwOwQ2Hnl6+tR2m39yuRdQNERGR/WJy04IIIbCrrucmIdJLOt693vcAcL7ogpTo2NLZutogAFiRmiHN6GoXpMV/xyVh6pDWeHJgjHSNopFdvImIiJqLBcUtyJn8CuSVVUOlkKNTyMVhqXBvF/i5q5FberGnZNOJPET72XZ4J71eclNercPqQ4Y1bdoFaeHposLTg1uhskaH9IIL3MCSiIjMhj03LUjq2SIAhtlEGqVCOi6TyaTeG5WT4SPddDzP6vEZ6fQCJ3PLcK7wgslxYxFx+6CLO3drlAp8MrIr7k8Is2qMRETkuJjctCCncg1bE7QNdG9wbuKAWAxs44dpN7UFgAaJhTV9vz0dgz/YgPNFhhj6xJr2ynQO9bRBVEREdKNgctOCnKqro4lqZE+kjiEeWDg2Ed0iDD04xRdqUHyhBiWVNRaPS68X+HLTaby38giEEPjgr4uztVROcvSK9ZEetw10N9mZm4iIyNxYc9OCnJaSm8vX0ng4G3bLziurwpAPN8BJLsPGFwdZrFhXCIHnlu3FT7vPAwDu6RaKQK0GRRWGpKq6Vm/S0zSgjb9F4iAiIjJictNCCCHqJTeX383asy65qarVI6euwDi/vAr+7hqLxHUsu0xKbAAgt7RKel8ACPbQoHVA/eTGzyJxEBERGTG5aSFySqtQUa2DXGaYHXU52rrkpr680mqLJTdrDmebPE4vKEdBeTUA4LbOQRjXNxohns4Y0j4AlTU6JER4NfYyREREZsPkpoU4lWvotQnzdpFmRDVGIZfBXe2E0qpa6VhuvcX0zC3lkuTGOKPL21WFuQ92k45/MTrBYjEQERHVx4LiFqIpQ1JGHi6mvTf1178xp/yyKuypS2aS2xlqafakGx7b+waeRETkuJjctBCn8wzTwJuU3FwyNJVnoZ6b3elFEAJoE+COdkGG7RSOZBm2WLjS0BkREZEl2UVy8+mnnyIyMhIajQZJSUnYvn37Za9dtGgRZDKZyZdGY5l6Enti7LmJbkJy42mlnpv954sBAJ1CPeDjqjI5F+7N6d5ERGQbNq+5WbJkCaZOnYr58+cjKSkJc+bMwbBhw3D06FH4+zc+bVir1eLo0YtrqdwIGy2easI0cKNLe26+3HQaf+zPRKCHBg/3isSK1Az8q2cEBl7jtOz954rx1A+7kZZv2F6hU4gHvC5JbiK8r56EERERWYLNk5sPP/wQ48ePx9ixYwEA8+fPx++//46vvvoK06ZNa/Q5MpkMgYGB1gzTpmp1eqTXJRJRfk0ZllI1OJZZXInM4krsSU8FABzLKUW0rxui/Vwx8/YOV33Nf07lY//5YjzaJwrzNpyQEhvAsIBgZY3O5PpWAbbd14qIiG5cNh2Wqq6uxq5du5CcnCwdk8vlSE5OxtatWy/7vLKyMkRERCAsLAx33nknDh48aI1wbeZc4QXU6gXUTnIEaa8+BHdpz41RTL3E6GzBBWw4louFm9NQVm9m1eWM+Hwb/v37YXyz9QzWHM4xOdc+SAsfN9OEqlVAwy0iiIiIrMGmyU1eXh50Oh0CAgJMjgcEBCArK6vR57Rp0wZfffUVfvnlF3z33XfQ6/Xo1asXzp071+j1VVVVKCkpMflqaerPlJI3YaXhS2tuACA+wgvLHu+FN+/qCF83tcm5QxkXfyaVNTr8vOe8ScKTU1opfT9zxUFU1+pNnu+sUsC73rBUsIcGbmqbdwoSEdENyi4KipujZ8+eGD16NOLi4tC/f3/89NNP8PPzw4IFCxq9ftasWfDw8JC+wsJa3u7TzZkGDjTec9M51FAX81CPCAxqa7pKsLEwGAC+3pKGKUtSMXz+VgghAAD7zhbjUk8MiMGdccH4/KF4AICXy8Xkxq8JvUtERESWYtM/r319faFQKJCdbboQXHZ2dpNrapRKJbp27YoTJ040en769OmYOnWq9LikpKRFJThCCGw5mQcAiGxicqNRNsxZo/0u1sDcnxCGpTsv9nRtOZGHIe0CEO7jglUHDT1mhzNLsOpgFjYcy8MP29MbvN4TA2Kg1VxMopSKi+/p69qw5oeIiMhabNpzo1KpEB8fj5SUFOmYXq9HSkoKevbs2aTX0Ol02L9/P4KCgho9r1arodVqTb5akqU7z2LN4Rwo5DLc0rHxNl5KV2/UaGAbPwRqNbgzLlg6lhDpjeUTe+GD4V0AAClHcjD4w/XYk16I8qqLhcGv/Hyg0cTmsX7RJonNpZqahBEREVmCzQsjpk6dijFjxiAhIQGJiYmYM2cOysvLpdlTo0ePRkhICGbNmgUAeOONN9CjRw/ExsaiqKgIs2fPxpkzZzBu3DhbNsNijJtSPj2oFTqFejTpOfULh796uDt0egEnhWke2zXcy2ShvRqdwGsrDuJU3WKBAJBXVm3ynE9GdkXxhRqM6N54z9f0m9tixd4MPDkwtklxEhERWYLNk5sRI0YgNzcXM2bMQFZWFuLi4rBy5UqpyDg9PR1y+cUbc2FhIcaPH4+srCx4eXkhPj4eW7ZsQfv27W3VBIsqqTQU9saFezb5OV3DvfCfEV0Q6eMKmUwGJ0XjRcg+bmpMHdIaR7JK8OeBLOw9Z6it0SjlUDspUHyhRrp2aPsA3NwxsEGSVN+E/jGY0D+myXESERFZgkwYq0ZvECUlJfDw8EBxcXGLGKLqP3sdzuRXYNnjPZEQ6W2x95n152Es2HAKgGFRvgCtWpryvXBs92te8I+IiMgcmnP/bnGzpW405XVTsl0tPLX6X0kR0vdOChm6RXhJj+NCPS363kRERObE5MbOGQt8XVWWTW7CvF0Q6mXYD2pQG3/0ifUFYFig79KtFYiIiOyZzWtu6PJ0eoELddsauKoVFn+/n5/sjV/3ZmBkYjg0SgW+H5+EMC/u7k1ERC0Lkxs7VlF9cZVgSw9LAYCvmxpje0dJj3vF+Fr8PYmIiMyNw1J2zDgkpZDLoHbiR0VERNQUvGPaMeP+Tq4qBWSyq+8pRURERExu7JpxWMoaQ1JERESOgsmNHSuz0jRwIiIiR8Lkxo5VSNPALT9TioiIyFEwubFj5RyWIiIiajYmN3bMOFvKxcIL+BERETkSJjd2zLj1gpsVFvAjIiJyFExu7BgLiomIiJqPyY0d41RwIiKi5mNyY8fKrLRpJhERkSNhcmPHLvbcsOaGiIioqZjc2LFy1twQERE1G5MbO2acCs7khoiIqOmY3NgxaRE/rlBMRETUZExu7NS89Sex71wxAPbcEBERNQeTGztUWaPDe6uOSI9DvZxtGA0REVHLwuTGDuWXV0MIw/e/PdUHoV4utg2IiIioBWFyY4fyy6oAAIFaDTqGeNg4GiIiopaFyY0dyi+rBgD4uKlsHAkREVHLw+TGDuXV9dz4uKltHAkREVHLw+TGDhWUG3pufF3Zc0NERNRcTG7sUH45h6WIiIiuFZMbO8RhKSIiomvH5MYOSQXFHJYiIiJqNiY3dii/3NBz48ueGyIiomZjcmOHjD033uy5ISIiajYmN3ZGCMF1boiIiK4Dkxs7U1pVi2qdHgDg48phKSIiouZicmNnsosrAQBuaic4qxQ2joaIiKjlYXJjZw5llgAAWgW42TgSIiKilonJjZ0xJjftg7Q2joSIiKhlYnJjZw5lGJKbDsHcDZyIiOhaMLmxI0IIHJSSG/bcEBERXQsmN3Yku6QKBeXVUMhlaBPobutwiIiIWiQmN3bkcJah1yba1xUaJWdKERERXQsmN3bkTF45ACDK19XGkRAREbVcTG7syJmCCgBAJJMbIiKia8bkxo6cyTckN+HeLjaOhIiIqOVicmNHzuQbhqUifdhzQ0REdK2Y3NgJnV7gbMEFAECED3tuiIiIrhWTGzuRVVKJap0eSoUMwZ7Otg6HiIioxWJyYyeMM6XCvFygkMtsHA0REVHLxeTGTpwtNBQTh7GYmIiI6LowubETRRU1AAAfV5WNIyEiImrZmNzYiZJKQ3KjdVbaOBIiIqKWjcmNnSi+wOSGiIjIHK4puamtrcWaNWuwYMEClJaWAgAyMjJQVlZm1uBuJCUXagEAWo2TjSMhIiJq2Zp9Jz1z5gxuuukmpKeno6qqCkOGDIG7uzveffddVFVVYf78+ZaI0+FxWIqIiMg8mt1zM3nyZCQkJKCwsBDOzhfXY7n77ruRkpJi1uBuJCV1w1IeTG6IiIiuS7N7bjZu3IgtW7ZApTKd1RMZGYnz58+bLbAbjVRzo2FyQ0REdD2a3XOj1+uh0+kaHD937hzc3d3NEtSNqKSyrubGmTU3RERE16PZyc3QoUMxZ84c6bFMJkNZWRlmzpyJW2655ZqC+PTTTxEZGQmNRoOkpCRs3769Sc9bvHgxZDIZ7rrrrmt6X3tSwp4bIiIis2h2cvPBBx9g8+bNaN++PSorK/Hggw9KQ1LvvvtuswNYsmQJpk6dipkzZ2L37t3o0qULhg0bhpycnCs+Ly0tDc899xz69u3b7Pe0N5U1OlTV6gGwoJiIiOh6NTu5CQ0Nxd69e/HSSy/hmWeeQdeuXfHOO+9gz5498Pf3b3YAH374IcaPH4+xY8eiffv2mD9/PlxcXPDVV19d9jk6nQ6jRo3C66+/jujo6Ga/p70xzpSSyQB3NYeliIiIrsc13UmdnJzwr3/967rfvLq6Grt27cL06dOlY3K5HMnJydi6detln/fGG2/A398fjz76KDZu3HjF96iqqkJVVZX0uKSk5LrjNjfjGjfuaifIuWkmERHRdWl2cvPNN99c8fzo0aOb/Fp5eXnQ6XQICAgwOR4QEIAjR440+pxNmzbhyy+/RGpqapPeY9asWXj99debHJMtcI0bIiIi82l2cjN58mSTxzU1NaioqIBKpYKLi0uzkpvmKi0txUMPPYQvvvgCvr6+TXrO9OnTMXXqVOlxSUkJwsLCLBXiNWExMRERkfk0O7kpLCxscOz48eN44okn8PzzzzfrtXx9faFQKJCdnW1yPDs7G4GBgQ2uP3nyJNLS0nD77bdLx/R6QyGuk5MTjh49ipiYGJPnqNVqqNXqZsVlbRf3lWK9DRER0fUyy8aZrVq1wjvvvNOgV+dqVCoV4uPjTVY21uv1SElJQc+ePRtc37ZtW+zfvx+pqanS1x133IGBAwciNTXV7npkmsq4xg1XJyYiIrp+ZusqcHJyQkZGRrOfN3XqVIwZMwYJCQlITEzEnDlzUF5ejrFjxwIw1PCEhIRg1qxZ0Gg06Nixo8nzPT09AaDB8ZaEw1JERETm0+zkZsWKFSaPhRDIzMzE3Llz0bt372YHMGLECOTm5mLGjBnIyspCXFwcVq5cKRUZp6enQy43SweT3covqwYAeLowuSEiIrpeMiGEaM4TLk00ZDIZ/Pz8MGjQIHzwwQcICgoya4DmVlJSAg8PDxQXF0Or1do6HADA2IXbse5oLt66uyNGJUXYOhwiIiK705z7d7N7bowFvGQ+J3PLAQAxfm42joSIiKjlc+zxnhagskaHs4UVAJjcEBERmUOTem7qrxNzNR9++OE1B3MjSssvhxCAVuMEXzeVrcMhIiJq8ZqU3OzZs6dJLyaTceuA5jqRUwYAiPF348+PiIjIDJqU3Kxbt87ScdywTuaw3oaIiMicWHNjY6fzDD030X6uNo6EiIjIMVzTIn47d+7E0qVLkZ6ejurqapNzP/30k1kCu1Hklxt+fv7uGhtHQkRE5Bia3XOzePFi9OrVC4cPH8by5ctRU1ODgwcPYu3atfDw8LBEjA7NuDqxJ7deICIiMotmJzdvv/02/vOf/+DXX3+FSqXCRx99hCNHjuD+++9HeHi4JWJ0aEXG5IarExMREZlFs5ObkydP4tZbbwVg2PiyvLwcMpkMzzzzDD7//HOzB+joiioMyQ03zSQiIjKPZic3Xl5eKC0tBQCEhITgwIEDAICioiJUVFSYNzoHp9cLlFTWJTfsuSEiIjKLZhcU9+vXD6tXr0anTp0wfPhwTJ48GWvXrsXq1asxePBgS8TosEora2Hc2Ys9N0RERObR7ORm7ty5qKysBAC8/PLLUCqV2LJlC+6991688sorZg/QkRVdMMyUclEpoHZS2DgaIiIix9Ds5Mbb21v6Xi6XY9q0aWYN6EbCehsiIiLza3bNTXJyMhYtWoSSkhJLxHNDKb7A5IaIiMjcmp3cdOjQAdOnT0dgYCCGDx+OX375BTU1NZaIzeFxGjgREZH5NTu5+eijj3D+/Hn8/PPPcHV1xejRoxEQEIDHHnsMGzZssESMDqu4wlBz4+nM3cCJiIjM5Zr2lpLL5Rg6dCgWLVqE7OxsLFiwANu3b8egQYPMHZ9DY80NERGR+V3T3lJGWVlZWLx4Mb777jvs27cPiYmJ5orrhlDMYSkiIiKza3bPTUlJCRYuXIghQ4YgLCwM8+bNwx133IHjx49j27ZtlojRYRlrbriAHxERkfk0u+cmICAAXl5eGDFiBGbNmoWEhARLxHVDMA5LseaGiIjIfJqd3KxYsQKDBw+GXH5N5TpUTwmnghMREZlds5ObIUOGWCKOG1J+eRUAwIvDUkRERGbD7hcbKig3TAX3cVPbOBIiIiLHweTGRmp1ehTW1dz4uLHmhoiIyFyY3NhIQd0CfjIZ4OXC5IaIiMhcmNzYiHFIystFBYVcZuNoiIiIHEezk5unn34aH3/8cYPjc+fOxZQpU8wR0w0hv6yu3saVvTZERETm1Ozk5n//+x969+7d4HivXr2wbNkyswR1I8iXiomZ3BAREZlTs5Ob/Px8eHh4NDiu1WqRl5dnlqBuBPllhmngPq6cKUVERGROzU5uYmNjsXLlygbH//zzT0RHR5slqBuBNCzFnhsiIiKzavYiflOnTsWkSZOQm5sr7QKekpKCDz74AHPmzDF3fA5LGpZizw0REZFZNTu5eeSRR1BVVYW33noLb775JgAgMjIS8+bNw+jRo80eoKMyDkt5s+eGiIjIrJqd3ADAE088gSeeeAK5ublwdnaGm5ubueNyeMaeG1/OliIiIjKra0pujPz8/MwVxw3HuM6NN5MbIiIis2pSctOtWzekpKTAy8sLXbt2hUx2+UXndu/ebbbgHFlh3QrFXkxuiIiIzKpJyc2dd94JtdpQ+HrXXXdZMp4bRlWNHgDgrFTYOBIiIiLH0qTkZubMmQAAnU6HgQMHonPnzvD09LRkXA5NCIHKWh0AQO3EHTCIiIjMqVl3VoVCgaFDh6KwsNBS8dwQanQCQhi+V7PnhoiIyKya3W3QsWNHnDp1yhKx3DCq6nptAPbcEBERmVuz76z//ve/8dxzz+G3335DZmYmSkpKTL7o6qpq9dL3TG6IiIjMq9lTwW+55RYAwB133GEya0oIAZlMBp1Od7mnUh1jcqNykl9x5hkRERE1X7OTm3Xr1lkijhtKZQ2LiYmIiCyl2clNVFQUwsLCGvQ4CCFw9uxZswXmyIzTwDUsJiYiIjK7ZncdREVFITc3t8HxgoICREVFmSUoR1fFaeBEREQW0+y7q7G25lJlZWXQaDRmCcrRGWtumNwQERGZX5OHpaZOnQoAkMlkePXVV+Hi4iKd0+l0+OeffxAXF2f2AB3RxeSGw1JERETm1uTkZs+ePQAMPTf79++HSnVxTySVSoUuXbrgueeeM3+EDqjKWFCsZM8NERGRuTU5uTHOkho7diw++ugjaLVaiwXl6Crrem407LkhIiIyu2Z3HSxcuBBarRYnTpzAqlWrcOHCBQCGHh1qGvbcEBERWU6z764FBQUYPHgwWrdujVtuuQWZmZkAgEcffRTPPvus2QN0RCwoJiIispxm312nTJkCpVKJ9PR0k6LiESNGYOXKlWYNzlGxoJiIiMhymr2I319//YVVq1YhNDTU5HirVq1w5swZswXmyLjODRERkeU0++5aXl5u0mNjVFBQALVabZagHF1l3QrFrLkhIiIyv2bfXfv27YtvvvlGeiyTyaDX6/Hee+9h4MCBZg3OURl7bjhbioiIyPyaPSz13nvvYfDgwdi5cyeqq6vxwgsv4ODBgygoKMDmzZstEaPDqWLPDRERkcU0++7asWNHHDt2DH369MGdd96J8vJy3HPPPdizZw9iYmKuKYhPP/0UkZGR0Gg0SEpKwvbt2y977U8//YSEhAR4enrC1dUVcXFx+Pbbb6/pfW2FBcVERESW0+yeGwDw8PDAyy+/bJYAlixZgqlTp2L+/PlISkrCnDlzMGzYMBw9ehT+/v4Nrvf29sbLL7+Mtm3bQqVS4bfffsPYsWPh7++PYcOGmSUmS2NBMRERkeVcU3JTWVmJffv2IScnB3q93uTcHXfc0azX+vDDDzF+/HiMHTsWADB//nz8/vvv+OqrrzBt2rQG1w8YMMDk8eTJk/H1119j06ZNLSi54To3REREltLs5GblypUYPXo08vLyGpyTyWTQ6XRNfq3q6mrs2rUL06dPl47J5XIkJydj69atV32+EAJr167F0aNH8e677zZ6TVVVFaqqqqTHJSUlTY7PUowrFGuUHJYiIiIyt2Z3HTz11FMYPnw4MjMzodfrTb6ak9gAQF5eHnQ6HQICAkyOBwQEICsr67LPKy4uhpubG1QqFW699VZ88sknGDJkSKPXzpo1Cx4eHtJXWFhYs2K0BKnnhgXFREREZtfsu2t2djamTp3aICGxJnd3d6SmpmLHjh146623MHXqVKxfv77Ra6dPn47i4mLp6+zZs9YNthHSbCkWFBMREZlds4el7rvvPqxfv/6aZ0bV5+vrC4VCgezsbJPj2dnZCAwMvOzz5HI5YmNjAQBxcXE4fPgwZs2a1aAeBwDUarXdLS7IgmIiIiLLaXZyM3fuXAwfPhwbN25Ep06doFQqTc4//fTTTX4tlUqF+Ph4pKSk4K677gIA6PV6pKSkYNKkSU1+Hb1eb1JXY+84FZyIiMhymp3c/PDDD/jrr7+g0Wiwfv16yGQy6ZxMJmtWcgMAU6dOxZgxY5CQkIDExETMmTMH5eXl0uyp0aNHIyQkBLNmzQJgqKFJSEhATEwMqqqq8Mcff+Dbb7/FvHnzmtsUm6mUCorZc0NERGRuzU5uXn75Zbz++uuYNm0a5PLrvzmPGDECubm5mDFjBrKyshAXF4eVK1dKNT3p6ekm71NeXo6JEyfi3LlzcHZ2Rtu2bfHdd99hxIgR1x2LtbDnhoiIyHJkQgjRnCd4e3tjx44dZqm5sYWSkhJ4eHiguLgYWq3WJjF0e3M1Csqr8dcz/dA6wN0mMRAREbUkzbl/N7vrZcyYMViyZMk1B0cX17lhQTEREZH5NXtYSqfT4b333sOqVavQuXPnBgXFH374odmCc1QcliIiIrKcZic3+/fvR9euXQEABw4cMDlXv7iYGler06NWbxgJZM8NERGR+TU7uVm3bp0l4rhhGHttAK5QTEREZAm8u1pZeVUtAEAmA5y5txQREZHZMbmxsrK65MZN5cRhPCIiIgtgcmNl5VWGmVJummaPCBIREVETMLmxstKqGgCAq5rJDRERkSUwubEyqeeGyQ0REZFFMLmxsrK6nhsmN0RERJbB5MbKyup6blzVnClFRERkCUxurKyssm62lFp5lSuJiIjoWjC5sTLjOjdu7LkhIiKyCCY3Viatc8Op4ERERBbB5MbKjMkNp4ITERFZBpMbKzMOS7kzuSEiIrIIJjdWxp4bIiIiy2JyY2VSzQ2TGyIiIotgcmNlF6eCM7khIiKyBCY3VlbOYSkiIiKLYnJjZZwKTkREZFlMbqxICMGaGyIiIgtjcmNFlTV66IXheyY3RERElsHkxopK63YEl8kAFxW3XyAiIrIEJjdWVF63I7ibygkymczG0RARETkmJjdWVFFtqLdxZq8NERGRxTC5saIanaHgRuXEHzsREZGl8C5rRdW1egCASsEfOxERkaXwLmtFNTpDcqNkckNERGQxvMtakdRzw2EpIiIii+Fd1oqqpZ4bzpQiIiKyFCY3VsSeGyIiIsvjXdaKWHNDRERkebzLWpGx50bNnhsiIiKL4V3WithzQ0REZHm8y1pRFWtuiIiILI53WSsyrlDMnhsiIiLL4V3WiozDUuy5ISIishzeZa2I2y8QERFZHu+yVlTDRfyIiIgsjsmNFbGgmIiIyPJ4l7UiTgUnIiKyPN5lrYjbLxAREVke77JWJM2WYs8NERGRxfAua0XVnApORERkcbzLWlF1LRfxIyIisjTeZa2omsNSREREFse7rBXV1BUUKzksRUREZDG8y1rRxYJiLuJHRERkKUxurIgFxURERJbHu6wVGde5YUExERGR5fAua0UsKCYiIrI83mWtSNp+gcNSREREFsO7rBVJ2y+w54aIiMhieJe1ohqdYRE/FhQTERFZDu+yVsSeGyIiIsuzi7vsp59+isjISGg0GiQlJWH79u2XvfaLL75A37594eXlBS8vLyQnJ1/xentSzZobIiIii7P5XXbJkiWYOnUqZs6cid27d6NLly4YNmwYcnJyGr1+/fr1GDlyJNatW4etW7ciLCwMQ4cOxfnz560cefMIIdhzQ0REZAUyIYSwZQBJSUno3r075s6dCwDQ6/UICwvDU089hWnTpl31+TqdDl5eXpg7dy5Gjx591etLSkrg4eGB4uJiaLXa646/qWp0erR6+U8AwN4ZQ+HhorTaexMREbV0zbl/27QLobq6Grt27UJycrJ0TC6XIzk5GVu3bm3Sa1RUVKCmpgbe3t6Nnq+qqkJJSYnJly0Yp4EDgNKJ2y8QERFZik2Tm7y8POh0OgQEBJgcDwgIQFZWVpNe48UXX0RwcLBJglTfrFmz4OHhIX2FhYVdd9zXwjgkBXBYioiIyJJa9F32nXfeweLFi7F8+XJoNJpGr5k+fTqKi4ulr7Nnz1o5SgNjMbFMBijk7LkhIiKyFCdbvrmvry8UCgWys7NNjmdnZyMwMPCKz33//ffxzjvvYM2aNejcufNlr1Or1VCr1WaJ93rULyaWyZjcEBERWYpNe25UKhXi4+ORkpIiHdPr9UhJSUHPnj0v+7z33nsPb775JlauXImEhARrhHrdpAX8OCRFRERkUTbtuQGAqVOnYsyYMUhISEBiYiLmzJmD8vJyjB07FgAwevRohISEYNasWQCAd999FzNmzMD333+PyMhIqTbHzc0Nbm5uNmvH1Ug9N1zjhoiIyKJsntyMGDECubm5mDFjBrKyshAXF4eVK1dKRcbp6emQyy8mBPPmzUN1dTXuu+8+k9eZOXMmXnvtNWuG3izSppnsuSEiIrIomyc3ADBp0iRMmjSp0XPr1683eZyWlmb5gCygij03REREVsE7rZVc7LlhMTEREZElMbmxkos1NwobR0JEROTYmNxYibHnRsWeGyIiIoticmMlF2p0AAC1kj03RERElsTkxkrKKmsBAFqNXdRwExEROSwmN1ZSWpfcuKmZ3BAREVkSkxsrKa0yJDfuGqWNIyEiInJsTG6spLSyBgDgxmEpIiIii2JyYyXGmht3JjdEREQWxeTGSow1N+6suSEiIrIoJjdWUsaaGyIiIqtgcmMlUs0Ne26IiIgsismNlVycLcXkhoiIyJKY3FiJtM4NkxsiIiKLYnJjJRdXKGbNDRERkSUxubGCGp1e2luKNTdERESWxeTGCsrr6m0ADksRERFZGpMbKzDW22iUcigV/JETERFZEu+0ViAt4Md6GyIiIotjcmMFxjVuuDoxERGR5TG5sYIyrnFDRERkNUxurIBr3BAREVkPkxsruDgsxZobIiIiS2NyYwUF5YbkxtOFyQ0REZGlMbmxgtyySgCAv7vaxpEQERE5PiY3VpBbWgUA8GNyQ0REZHGscLUgIQQKyquZ3BAREVkRkxsLemflESzYcEp67OeusWE0RERENwYOS1lQ/cQGYM0NERGRNTC5sSIOSxEREVkekxsrcdc4QaNU2DoMIiIih8fkxkp8XFW2DoGIiOiGwOTGgurvJVVZo7dhJERERDcOJjcWVFmjk74vvlBjw0iIiIhuHExuLKS6Vo8anZAec0dwIiIi62ByYyHlVbXS9yGezvh4ZFcbRkNERHTjYHeChZRXG5IbtZMcm6cNsnE0RERENw723FhIeZWh3sZNzfyRiIjImpjcWEhZ3bCUi5pr2xAREVkTkxsLqagblnJVseeGiIjImpjcWIixoNiVw1JERERWxeTGQow1N0xuiIiIrIvJjYWUS8NSrLkhIiKyJiY3FsKeGyIiItvgnddCpJob9twQEVmVEAK1tbXQ6XRXv5jsilKphEJx/fdNJjcWIg1LseeGiMhqqqurkZmZiYqKCluHQtdAJpMhNDQUbm5u1/U6vPNaCGdLERFZl16vx+nTp6FQKBAcHAyVSgWZTGbrsKiJhBDIzc3FuXPn0KpVq+vqweGd10LKq+tqbjgsRURkFdXV1dDr9QgLC4OLi4utw6Fr4Ofnh7S0NNTU1FxXcsOCYgspl1YoZv5IRGRNcjlvbS2VuXra+BtgIRXcW4qIiMgmmNxYgBACeeVVAAAXDksRERFZFZMbC/j871M4lVsOlUKONoHutg6HiIjohsLkxswqqmvxnzXHAAAz72iPIA9nG0dERETUfDU1NbYO4ZoxuTGzTcfzUFmjR5i3Mx5MDLd1OERE1EKsXLkSffr0gaenJ3x8fHDbbbfh5MmT0vlz585h5MiR8Pb2hqurKxISEvDPP/9I53/99Vd0794dGo0Gvr6+uPvuu6VzMpkMP//8s8n7eXp6YtGiRQCAtLQ0yGQyLFmyBP3794dGo8F///tf5OfnY+TIkQgJCYGLiws6deqEH374weR19Ho93nvvPcTGxkKtViM8PBxvvfUWAGDQoEGYNGmSyfW5ublQqVRISUkxx4+tUax2NbM1h7MBAMntAri+AhGRjQkhcKHGNisVOysVzboPlJeXY+rUqejcuTPKysowY8YM3H333UhNTUVFRQX69++PkJAQrFixAoGBgdi9ezf0ej0A4Pfff8fdd9+Nl19+Gd988w2qq6vxxx9/NDvmadOm4YMPPkDXrl2h0WhQWVmJ+Ph4vPjii9Bqtfj999/x0EMPISYmBomJiQCA6dOn44svvsB//vMf9OnTB5mZmThy5AgAYNy4cZg0aRI++OADqNVqAMB3332HkJAQDBo0qNnxNRWTGzPS6QVSDucAAIa0C7BxNEREdKFGh/YzVtnkvQ+9MQwuqqbfZu+9916Tx1999RX8/Pxw6NAhbNmyBbm5udixYwe8vb0BALGxsdK1b731Fh544AG8/vrr0rEuXbo0O+YpU6bgnnvuMTn23HPPSd8/9dRTWLVqFZYuXYrExESUlpbio48+wty5czFmzBgAQExMDPr06QMAuOeeezBp0iT88ssvuP/++wEAixYtwsMPP2zRDgCbD0t9+umniIyMhEajQVJSErZv337Zaw8ePIh7770XkZGRkMlkmDNnjvUCbYLUs4XIL6+Gu8YJ3aO8bR0OERG1IMePH8fIkSMRHR0NrVaLyMhIAEB6ejpSU1PRtWtXKbG5VGpqKgYPHnzdMSQkJJg81ul0ePPNN9GpUyd4e3vDzc0Nq1atQnp6OgDg8OHDqKqquux7azQaPPTQQ/jqq68AALt378aBAwfw8MMPX3esV2LTnpslS5Zg6tSpmD9/PpKSkjBnzhwMGzYMR48ehb+/f4PrKyoqEB0djeHDh+OZZ56xQcRXtvqQoddmYBt/KBU2zxuJiG54zkoFDr0xzGbv3Ry33347IiIi8MUXXyA4OBh6vR4dO3ZEdXU1nJ2vPDnlaudlMhmEECbHGisYdnV1NXk8e/ZsfPTRR5gzZw46deoEV1dXTJkyBdXV1U16X8AwNBUXF4dz585h4cKFGDRoECIiIq76vOth0zvwhx9+iPHjx2Ps2LFo37495s+fDxcXFynDu1T37t0xe/ZsPPDAA9LYnT2R6m3ac0iKiMgeyGQyuKicbPLVnGGX/Px8HD16FK+88goGDx6Mdu3aobCwUDrfuXNnpKamoqCgoNHnd+7c+YoFun5+fsjMzJQeHz9+vEmbi27evBl33nkn/vWvf6FLly6Ijo7GsWPHpPOtWrWCs7PzFd+7U6dOSEhIwBdffIHvv/8ejzzyyFXf93rZLLmprq7Grl27kJycfDEYuRzJycnYunWr2d6nqqoKJSUlJl+WcDqvHCdyyuAkl6F/az+LvAcRETkmLy8v+Pj44PPPP8eJEyewdu1aTJ06VTo/cuRIBAYG4q677sLmzZtx6tQp/O9//5PulzNnzsQPP/yAmTNn4vDhw9i/fz/effdd6fmDBg3C3LlzsWfPHuzcuROPP/44lErlVeNq1aoVVq9ejS1btuDw4cOYMGECsrOzpfMajQYvvvgiXnjhBXzzzTc4efIktm3bhi+//NLkdcaNG4d33nkHQgiTWVyWYrPkJi8vDzqdDgEBpr0cAQEByMrKMtv7zJo1Cx4eHtJXWFiY2V67vrMFFfB1UyMp2hsezlf/hSEiIjKSy+VYvHgxdu3ahY4dO+KZZ57B7NmzpfMqlQp//fUX/P39ccstt6BTp0545513pM0lBwwYgB9//BErVqxAXFwcBg0aZFLD+sEHHyAsLAx9+/bFgw8+iOeee65Jm4u+8sor6NatG4YNG4YBAwZICVZ9r776Kp599lnMmDED7dq1w4gRI5CTk2NyzciRI+Hk5ISRI0dCo9Fcx0+qaWTi0kE4K8nIyEBISAi2bNmCnj17SsdfeOEFbNiwwWTufmMiIyMxZcoUTJky5YrXVVVVoaqqSnpcUlKCsLAwFBcXQ6vVXlcbLqXXCxRWVMPHzf6GzIiIHF1lZSVOnz6NqKgoq9xAqenS0tIQExODHTt2oFu3bpe97kqfYUlJCTw8PJp0/7ZZQbGvry8UCoVJ9xYAZGdnIzAw0Gzvo1arrVafI5fLmNgQERHVqampQX5+Pl555RX06NHjiomNOdlsWEqlUiE+Pt6kCEmv1yMlJcWkJ4eIiIhaps2bNyMoKAg7duzA/Pnzrfa+Np0KPnXqVIwZMwYJCQlITEzEnDlzUF5ejrFjxwIARo8ejZCQEMyaNQuAoQj50KFD0vfnz59Hamoq3NzcTBYzIiIiItsbMGBAgyno1mDT5GbEiBHIzc3FjBkzkJWVhbi4OKxcuVIqMk5PT4dcfrFzKSMjA127dpUev//++3j//ffRv39/rF+/3trhExERkR2yWUGxrTSnIImIiFoOFhS3fOYqKOYyukRE5FBusL/ZHYq5PjsmN0RE5BCMi9I1ZeVdsk/GbR2M6/dcK+4KTkREDkGhUMDT01NaQM7FxcWiO0+Teen1euTm5sLFxQVOTteXnjC5ISIih2FcJ+3SFXKpZZDL5QgPD7/upJTJDREROQyZTIagoCD4+/s3uus12TeVSmUyS/paMbkhIiKHo1Aorrtug1ouFhQTERGRQ2FyQ0RERA6FyQ0RERE5lBuu5sa4QFBJSYmNIyEiIqKmMt63m7LQ3w2X3JSWlgIAwsLCbBwJERERNVdpaSk8PDyueM0Nt7eUXq9HRkYG3N3dzbq4U0lJCcLCwnD27FmH3LPK0dsHOH4bHb19gOO30dHbBzh+Gx29fYDl2iiEQGlpKYKDg686XfyG67mRy+UIDQ212OtrtVqH/YUFHL99gOO30dHbBzh+Gx29fYDjt9HR2wdYpo1X67ExYkExERERORQmN0RERORQmNyYiVqtxsyZM6FWq20dikU4evsAx2+jo7cPcPw2Onr7AMdvo6O3D7CPNt5wBcVERETk2NhzQ0RERA6FyQ0RERE5FCY3RERE5FCY3BAREZFDYXJjBp9++ikiIyOh0WiQlJSE7du32zqka/baa69BJpOZfLVt21Y6X1lZiSeffBI+Pj5wc3PDvffei+zsbBtGfGV///03br/9dgQHB0Mmk+Hnn382OS+EwIwZMxAUFARnZ2ckJyfj+PHjJtcUFBRg1KhR0Gq18PT0xKOPPoqysjIrtuLKrtbGhx9+uMFnetNNN5lcY89tnDVrFrp37w53d3f4+/vjrrvuwtGjR02uacrvZXp6Om699Va4uLjA398fzz//PGpra63ZlEY1pX0DBgxo8Bk+/vjjJtfYa/sAYN68eejcubO0qFvPnj3x559/Sudb8ucHXL19Lf3zu9Q777wDmUyGKVOmSMfs7jMUdF0WL14sVCqV+Oqrr8TBgwfF+PHjhaenp8jOzrZ1aNdk5syZokOHDiIzM1P6ys3Nlc4//vjjIiwsTKSkpIidO3eKHj16iF69etkw4iv7448/xMsvvyx++uknAUAsX77c5Pw777wjPDw8xM8//yz27t0r7rjjDhEVFSUuXLggXXPTTTeJLl26iG3btomNGzeK2NhYMXLkSCu35PKu1sYxY8aIm266yeQzLSgoMLnGnts4bNgwsXDhQnHgwAGRmpoqbrnlFhEeHi7Kysqka672e1lbWys6duwokpOTxZ49e8Qff/whfH19xfTp023RJBNNaV///v3F+PHjTT7D4uJi6bw9t08IIVasWCF+//13cezYMXH06FHx0ksvCaVSKQ4cOCCEaNmfnxBXb19L//zq2759u4iMjBSdO3cWkydPlo7b22fI5OY6JSYmiieffFJ6rNPpRHBwsJg1a5YNo7p2M2fOFF26dGn0XFFRkVAqleLHH3+Ujh0+fFgAEFu3brVShNfu0hu/Xq8XgYGBYvbs2dKxoqIioVarxQ8//CCEEOLQoUMCgNixY4d0zZ9//ilkMpk4f/681WJvqsslN3feeedln9PS2piTkyMAiA0bNgghmvZ7+ccffwi5XC6ysrKka+bNmye0Wq2oqqqybgOu4tL2CWG4Oda/kVyqJbXPyMvLS/zf//2fw31+Rsb2CeE4n19paalo1aqVWL16tUmb7PEz5LDUdaiursauXbuQnJwsHZPL5UhOTsbWrVttGNn1OX78OIKDgxEdHY1Ro0YhPT0dALBr1y7U1NSYtLdt27YIDw9vke09ffo0srKyTNrj4eGBpKQkqT1bt26Fp6cnEhISpGuSk5Mhl8vxzz//WD3ma7V+/Xr4+/ujTZs2eOKJJ5Cfny+da2ltLC4uBgB4e3sDaNrv5datW9GpUycEBARI1wwbNgwlJSU4ePCgFaO/ukvbZ/Tf//4Xvr6+6NixI6ZPn46KigrpXEtqn06nw+LFi1FeXo6ePXs63Od3afuMHOHze/LJJ3HrrbeafFaAff4/eMNtnGlOeXl50Ol0Jh8WAAQEBODIkSM2iur6JCUlYdGiRWjTpg0yMzPx+uuvo2/fvjhw4ACysrKgUqng6elp8pyAgABkZWXZJuDrYIy5sc/PeC4rKwv+/v4m552cnODt7d1i2nzTTTfhnnvuQVRUFE6ePImXXnoJN998M7Zu3QqFQtGi2qjX6zFlyhT07t0bHTt2BIAm/V5mZWU1+jkbz9mLxtoHAA8++CAiIiIQHByMffv24cUXX8TRo0fx008/AWgZ7du/fz969uyJyspKuLm5Yfny5Wjfvj1SU1Md4vO7XPsAx/j8Fi9ejN27d2PHjh0Nztnj/4NMbsjEzTffLH3fuXNnJCUlISIiAkuXLoWzs7MNI6Nr9cADD0jfd+rUCZ07d0ZMTAzWr1+PwYMH2zCy5nvyySdx4MABbNq0ydahWMTl2vfYY49J33fq1AlBQUEYPHgwTp48iZiYGGuHeU3atGmD1NRUFBcXY9myZRgzZgw2bNhg67DM5nLta9++fYv//M6ePYvJkydj9erV0Gg0tg6nSTgsdR18fX2hUCgaVIRnZ2cjMDDQRlGZl6enJ1q3bo0TJ04gMDAQ1dXVKCoqMrmmpbbXGPOVPr/AwEDk5OSYnK+trUVBQUGLbDMAREdHw9fXFydOnADQcto4adIk/Pbbb1i3bh1CQ0Ol4035vQwMDGz0czaesweXa19jkpKSAMDkM7T39qlUKsTGxiI+Ph6zZs1Cly5d8NFHHznM53e59jWmpX1+u3btQk5ODrp16wYnJyc4OTlhw4YN+Pjjj+Hk5ISAgAC7+wyZ3FwHlUqF+Ph4pKSkSMf0ej1SUlJMxlpbsrKyMpw8eRJBQUGIj4+HUqk0ae/Ro0eRnp7eItsbFRWFwMBAk/aUlJTgn3/+kdrTs2dPFBUVYdeuXdI1a9euhV6vl/6BamnOnTuH/Px8BAUFAbD/NgohMGnSJCxfvhxr165FVFSUyfmm/F727NkT+/fvN0niVq9eDa1WKw0d2MrV2teY1NRUADD5DO21fZej1+tRVVXV4j+/yzG2rzEt7fMbPHgw9u/fj9TUVOkrISEBo0aNkr63u8/Q7CXKN5jFixcLtVotFi1aJA4dOiQee+wx4enpaVIR3pI8++yzYv369eL06dNi8+bNIjk5Wfj6+oqcnBwhhGG6X3h4uFi7dq3YuXOn6Nmzp+jZs6eNo7680tJSsWfPHrFnzx4BQHz44Ydiz5494syZM0IIw1RwT09P8csvv4h9+/aJO++8s9Gp4F27dhX//POP2LRpk2jVqpXdTJMW4sptLC0tFc8995zYunWrOH36tFizZo3o1q2baNWqlaisrJRew57b+MQTTwgPDw+xfv16k6m0FRUV0jVX+700TkMdOnSoSE1NFStXrhR+fn52MdX2au07ceKEeOONN8TOnTvF6dOnxS+//CKio6NFv379pNew5/YJIcS0adPEhg0bxOnTp8W+ffvEtGnThEwmE3/99ZcQomV/fkJcuX2O8Pk15tIZYPb2GTK5MYNPPvlEhIeHC5VKJRITE8W2bdtsHdI1GzFihAgKChIqlUqEhISIESNGiBMnTkjnL1y4ICZOnCi8vLyEi4uLuPvuu0VmZqYNI76ydevWCQANvsaMGSOEMEwHf/XVV0VAQIBQq9Vi8ODB4ujRoyavkZ+fL0aOHCnc3NyEVqsVY8eOFaWlpTZoTeOu1MaKigoxdOhQ4efnJ5RKpYiIiBDjx49vkHzbcxsbaxsAsXDhQumapvxepqWliZtvvlk4OzsLX19f8eyzz4qamhort6ahq7UvPT1d9OvXT3h7ewu1Wi1iY2PF888/b7JOihD22z4hhHjkkUdERESEUKlUws/PTwwePFhKbIRo2Z+fEFdunyN8fo25NLmxt89QJoQQ5u8PIiIiIrIN1twQERGRQ2FyQ0RERA6FyQ0RERE5FCY3RERE5FCY3BAREZFDYXJDREREDoXJDRERETkUJjdEdENYv349ZDJZg/1viMjxMLkhIiIih8LkhoiIiBwKkxsisit6vR7vvfceYmNjoVarER4ejrfeeguDBg3CpEmTTK7Nzc2FSqWSdiOuqqrCiy++iLCwMKjVasTGxuLLL7+87Htt2rQJffv2hbOzM8LCwvD000+jvLzcou0jIstjckNEdmX69Ol455138Oqrr+LQoUP4/vvvERAQgHHjxuH7779HVVWVdO13332HkJAQDBo0CAAwevRo/PDDD/j4449x+PBhLFiwAG5ubo2+z8mTJ3HTTTfh3nvvxb59+7BkyRJs2rSpQQJFRC0PN84kIrtRWloKPz8/zJ07F+PGjTM5V1lZieDgYMyfPx/3338/AKBLly645557MHPmTBw7dgxt2rTB6tWrkZyc3OC1169fj4EDB6KwsBCenp4YN24cFAoFFixYIF2zadMm9O/fH+Xl5dBoNJZtLBFZDHtuiMhuHD58GFVVVRg8eHCDcxqNBg899BC++uorAMDu3btx4MABPPzwwwCA1NRUKBQK9O/fv0nvtXfvXixatAhubm7S17Bhw6DX63H69GmztYmIrM/J1gEQERk5Oztf8fy4ceMQFxeHc+fOYeHChRg0aBAiIiKa9NxLlZWVYcKECXj66acbnAsPD2/WaxGRfWHPDRHZjVatWsHZ2VkqEL5Up06dkJCQgC+++ALff/89HnnkEZNzer0eGzZsaNJ7devWDYcOHUJsbGyDL5VKZZb2EJFtMLkhIruh0Wjw4osv4oUXXsA333yDkydPYtu2bSYznsaNG4d33nkHQgjcfffd0vHIyEiMGTMGjzzyCH7++WecPn0a69evx9KlSxt9rxdffBFbtmzBpEmTkJqaiuPHj+OXX35hQTGRA2ByQ0R25dVXX8Wzzz6LGTNmoF27dhgxYgRycnKk8yNHjoSTkxNGjhzZoOh33rx5uO+++zBx4kS0bdsW48ePv+zU7s6dO2PDhg04duwY+vbti65du2LGjBkIDg62aPuIyPI4W4qIWpS0tDTExMRgx44d6Natm63DISI7xOSGiFqEmpoa5Ofn47nnnsPp06exefNmW4dERHaKw1JE1CJs3rwZQUFB2LFjB+bPn2/rcIjIjrHnhoiIiBwKe26IiIjIoTC5ISIiIofC5IaIiIgcCpMbIiIicihMboiIiMihMLkhIiIih8LkhoiIiBwKkxsiIiJyKExuiIiIyKH8Pz/bWbusknIyAAAAAElFTkSuQmCC",
      "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": 12,
   "id": "3249552a-eed5-475c-9fe9-d271b4d7aaca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.10549}, {'accuracy': 0.11109}, {'accuracy': 0.11331000000000002}, {'accuracy': 0.14798}, {'accuracy': 0.13743}, {'accuracy': 0.15525000000000003}, {'accuracy': 0.18500999999999998}, {'accuracy': 0.25228}, {'accuracy': 0.28448}, {'accuracy': 0.33733}, {'accuracy': 0.35734}, {'accuracy': 0.38177000000000005}, {'accuracy': 0.39257}, {'accuracy': 0.41930000000000006}, {'accuracy': 0.4314699999999999}, {'accuracy': 0.44037}, {'accuracy': 0.46015999999999996}, {'accuracy': 0.46016}, {'accuracy': 0.49456999999999995}, {'accuracy': 0.49679}, {'accuracy': 0.5078199999999999}, {'accuracy': 0.51961}, {'accuracy': 0.5269299999999999}, {'accuracy': 0.53632}, {'accuracy': 0.53945}, {'accuracy': 0.53562}, {'accuracy': 0.52653}, {'accuracy': 0.51931}, {'accuracy': 0.5253500000000001}, {'accuracy': 0.51908}, {'accuracy': 0.49429999999999996}, {'accuracy': 0.5147299999999999}, {'accuracy': 0.49646}, {'accuracy': 0.50381}, {'accuracy': 0.50371}, {'accuracy': 0.50179}, {'accuracy': 0.5036400000000001}, {'accuracy': 0.49753}, {'accuracy': 0.50234}, {'accuracy': 0.49394}, {'accuracy': 0.49539}, {'accuracy': 0.49241999999999997}, {'accuracy': 0.4882999999999999}, {'accuracy': 0.49863}, {'accuracy': 0.49582999999999994}, {'accuracy': 0.48845}, {'accuracy': 0.49619}, {'accuracy': 0.49372}, {'accuracy': 0.50187}, {'accuracy': 0.49578999999999995}, {'accuracy': 0.49916}, {'accuracy': 0.5038600000000001}, {'accuracy': 0.49989}, {'accuracy': 0.50841}, {'accuracy': 0.5140300000000001}, {'accuracy': 0.51547}, {'accuracy': 0.4951899999999999}, {'accuracy': 0.5051}, {'accuracy': 0.51779}, {'accuracy': 0.51345}, {'accuracy': 0.5264500000000001}, {'accuracy': 0.52281}, {'accuracy': 0.51305}, {'accuracy': 0.5188299999999999}, {'accuracy': 0.52799}, {'accuracy': 0.52749}, {'accuracy': 0.52413}, {'accuracy': 0.5335300000000001}, {'accuracy': 0.52234}, {'accuracy': 0.5372299999999999}, {'accuracy': 0.5268200000000001}, {'accuracy': 0.53562}, {'accuracy': 0.53837}, {'accuracy': 0.5363999999999999}, {'accuracy': 0.5469999999999999}, {'accuracy': 0.53825}, {'accuracy': 0.5347500000000001}, {'accuracy': 0.53768}, {'accuracy': 0.53827}, {'accuracy': 0.54621}, {'accuracy': 0.5469899999999999}, {'accuracy': 0.54751}, {'accuracy': 0.54644}, {'accuracy': 0.54818}, {'accuracy': 0.5438500000000001}, {'accuracy': 0.54513}, {'accuracy': 0.5464}, {'accuracy': 0.55586}, {'accuracy': 0.55044}, {'accuracy': 0.5591}, {'accuracy': 0.54952}, {'accuracy': 0.5589999999999999}, {'accuracy': 0.5513399999999999}, {'accuracy': 0.5363300000000001}, {'accuracy': 0.54129}, {'accuracy': 0.5478999999999999}, {'accuracy': 0.55552}, {'accuracy': 0.56104}, {'accuracy': 0.5678}, {'accuracy': 0.55958}, {'accuracy': 0.56146}, {'accuracy': 0.5594899999999999}, {'accuracy': 0.54922}, {'accuracy': 0.55166}, {'accuracy': 0.56253}, {'accuracy': 0.56152}, {'accuracy': 0.56141}, {'accuracy': 0.5660499999999999}, {'accuracy': 0.56002}, {'accuracy': 0.56138}, {'accuracy': 0.55545}, {'accuracy': 0.56837}, {'accuracy': 0.5703399999999998}, {'accuracy': 0.5704400000000001}, {'accuracy': 0.56188}, {'accuracy': 0.5745199999999999}, {'accuracy': 0.5812}, {'accuracy': 0.5777300000000001}, {'accuracy': 0.5747800000000002}, {'accuracy': 0.58097}, {'accuracy': 0.5776499999999999}, {'accuracy': 0.57653}, {'accuracy': 0.57726}, {'accuracy': 0.5798300000000001}, {'accuracy': 0.57026}, {'accuracy': 0.5788800000000001}, {'accuracy': 0.5864499999999999}, {'accuracy': 0.58226}, {'accuracy': 0.58455}, {'accuracy': 0.58634}, {'accuracy': 0.58743}, {'accuracy': 0.58522}, {'accuracy': 0.58842}, {'accuracy': 0.58419}, {'accuracy': 0.58774}, {'accuracy': 0.5862700000000001}, {'accuracy': 0.58521}, {'accuracy': 0.58793}, {'accuracy': 0.58647}, {'accuracy': 0.58708}, {'accuracy': 0.5885200000000002}, {'accuracy': 0.58798}, {'accuracy': 0.5877199999999999}, {'accuracy': 0.58672}, {'accuracy': 0.58633}, {'accuracy': 0.5873}, {'accuracy': 0.5854000000000001}, {'accuracy': 0.58604}, {'accuracy': 0.5854799999999999}, {'accuracy': 0.58668}, {'accuracy': 0.5868}, {'accuracy': 0.5872900000000001}, {'accuracy': 0.5854999999999999}, {'accuracy': 0.5870500000000001}, {'accuracy': 0.5880699999999999}, {'accuracy': 0.5852999999999999}, {'accuracy': 0.5866400000000002}, {'accuracy': 0.58746}, {'accuracy': 0.58534}, {'accuracy': 0.58424}, {'accuracy': 0.58423}, {'accuracy': 0.58699}, {'accuracy': 0.5856700000000001}, {'accuracy': 0.58494}, {'accuracy': 0.5849399999999999}, {'accuracy': 0.5859099999999999}, {'accuracy': 0.58508}, {'accuracy': 0.58409}, {'accuracy': 0.5844}, {'accuracy': 0.5847399999999999}, {'accuracy': 0.58462}, {'accuracy': 0.58455}, {'accuracy': 0.5852799999999999}, {'accuracy': 0.58396}, {'accuracy': 0.5819300000000001}, {'accuracy': 0.5836}, {'accuracy': 0.58316}, {'accuracy': 0.5838300000000001}, {'accuracy': 0.5845899999999999}, {'accuracy': 0.58348}, {'accuracy': 0.58212}, {'accuracy': 0.58165}, {'accuracy': 0.58422}, {'accuracy': 0.5822999999999999}, {'accuracy': 0.5840299999999999}, {'accuracy': 0.58277}, {'accuracy': 0.5800299999999999}, {'accuracy': 0.5841000000000001}, {'accuracy': 0.58268}, {'accuracy': 0.5824}, {'accuracy': 0.5835100000000001}, {'accuracy': 0.58176}, {'accuracy': 0.5808600000000002}, {'accuracy': 0.58186}, {'accuracy': 0.5812899999999999}, {'accuracy': 0.58013}, {'accuracy': 0.5816600000000001}, {'accuracy': 0.5811900000000001}, {'accuracy': 0.5828999999999999}, {'accuracy': 0.5690500000000001}, {'accuracy': 0.5812600000000001}, {'accuracy': 0.58377}, {'accuracy': 0.57365}, {'accuracy': 0.59163}, {'accuracy': 0.59545}, {'accuracy': 0.5905199999999999}, {'accuracy': 0.57616}, {'accuracy': 0.5728199999999999}, {'accuracy': 0.5818099999999999}, {'accuracy': 0.58114}, {'accuracy': 0.5892299999999999}, {'accuracy': 0.5863}, {'accuracy': 0.5966099999999999}, {'accuracy': 0.59645}, {'accuracy': 0.58633}, {'accuracy': 0.5949000000000001}, {'accuracy': 0.59227}, {'accuracy': 0.58617}, {'accuracy': 0.58858}, {'accuracy': 0.56932}, {'accuracy': 0.5804200000000002}, {'accuracy': 0.5909500000000001}, {'accuracy': 0.57283}, {'accuracy': 0.57622}, {'accuracy': 0.5946}, {'accuracy': 0.5984700000000001}, {'accuracy': 0.5991700000000001}, {'accuracy': 0.59642}, {'accuracy': 0.5987600000000001}, {'accuracy': 0.5981}, {'accuracy': 0.5976100000000001}, {'accuracy': 0.5982899999999999}, {'accuracy': 0.59734}, {'accuracy': 0.5973999999999999}, {'accuracy': 0.5975699999999999}, {'accuracy': 0.59894}, {'accuracy': 0.59776}, {'accuracy': 0.59846}, {'accuracy': 0.59802}, {'accuracy': 0.59567}, {'accuracy': 0.59749}, {'accuracy': 0.5973400000000001}, {'accuracy': 0.59543}, {'accuracy': 0.5958600000000001}, {'accuracy': 0.5955900000000001}, {'accuracy': 0.5944100000000001}, {'accuracy': 0.5948599999999999}, {'accuracy': 0.59461}, {'accuracy': 0.59493}, {'accuracy': 0.59437}, {'accuracy': 0.59398}, {'accuracy': 0.5874400000000001}, {'accuracy': 0.5671600000000001}, {'accuracy': 0.5801599999999999}, {'accuracy': 0.5749700000000001}, {'accuracy': 0.5929300000000001}, {'accuracy': 0.5988499999999999}, {'accuracy': 0.6012299999999999}, {'accuracy': 0.6029}, {'accuracy': 0.6013999999999999}, {'accuracy': 0.5992500000000001}, {'accuracy': 0.5992299999999999}, {'accuracy': 0.59844}, {'accuracy': 0.59876}, {'accuracy': 0.59597}, {'accuracy': 0.60028}, {'accuracy': 0.5982299999999999}, {'accuracy': 0.59965}, {'accuracy': 0.5968300000000001}, {'accuracy': 0.59875}, {'accuracy': 0.59705}, {'accuracy': 0.59758}, {'accuracy': 0.5962100000000001}, {'accuracy': 0.59679}, {'accuracy': 0.59535}, {'accuracy': 0.59613}, {'accuracy': 0.5944}, {'accuracy': 0.5959999999999999}, {'accuracy': 0.5928100000000001}, {'accuracy': 0.59473}, {'accuracy': 0.59501}, {'accuracy': 0.5976600000000001}, {'accuracy': 0.59676}, {'accuracy': 0.59405}, {'accuracy': 0.59245}, {'accuracy': 0.59286}, {'accuracy': 0.5942200000000001}, {'accuracy': 0.59437}, {'accuracy': 0.59274}, {'accuracy': 0.594}, {'accuracy': 0.59428}, {'accuracy': 0.59242}, {'accuracy': 0.5935700000000002}, {'accuracy': 0.59231}, {'accuracy': 0.59234}, {'accuracy': 0.59185}, {'accuracy': 0.5904299999999999}, {'accuracy': 0.59249}, {'accuracy': 0.5911099999999999}, {'accuracy': 0.59256}, {'accuracy': 0.5926899999999999}, {'accuracy': 0.59141}, {'accuracy': 0.59177}, {'accuracy': 0.59035}, {'accuracy': 0.5902000000000001}, {'accuracy': 0.59134}, {'accuracy': 0.59181}, {'accuracy': 0.5921799999999999}, {'accuracy': 0.58782}, {'accuracy': 0.5886699999999999}, {'accuracy': 0.5879399999999999}, {'accuracy': 0.59009}, {'accuracy': 0.58992}, {'accuracy': 0.5913599999999999}, {'accuracy': 0.59009}, {'accuracy': 0.58869}, {'accuracy': 0.58944}, {'accuracy': 0.5898700000000001}, {'accuracy': 0.5898299999999999}, {'accuracy': 0.5901500000000001}, {'accuracy': 0.59012}, {'accuracy': 0.5877}, {'accuracy': 0.58982}, {'accuracy': 0.5883700000000001}, {'accuracy': 0.58953}, {'accuracy': 0.58868}, {'accuracy': 0.58816}, {'accuracy': 0.58646}, {'accuracy': 0.58847}, {'accuracy': 0.58733}, {'accuracy': 0.58457}, {'accuracy': 0.5884099999999999}, {'accuracy': 0.5866499999999999}, {'accuracy': 0.5701499999999998}, {'accuracy': 0.57026}, {'accuracy': 0.5753}, {'accuracy': 0.57794}, {'accuracy': 0.5918599999999999}, {'accuracy': 0.5994599999999999}, {'accuracy': 0.5929199999999999}, {'accuracy': 0.6001}, {'accuracy': 0.59202}, {'accuracy': 0.5868399999999999}, {'accuracy': 0.59431}, {'accuracy': 0.58784}, {'accuracy': 0.59447}, {'accuracy': 0.6003}, {'accuracy': 0.6025999999999999}, {'accuracy': 0.60203}, {'accuracy': 0.6007900000000002}, {'accuracy': 0.60187}, {'accuracy': 0.5997}, {'accuracy': 0.59469}, {'accuracy': 0.5963}, {'accuracy': 0.5975300000000001}, {'accuracy': 0.5967699999999999}, {'accuracy': 0.59853}, {'accuracy': 0.5981299999999999}, {'accuracy': 0.5961899999999999}, {'accuracy': 0.5965100000000001}, {'accuracy': 0.5983600000000001}, {'accuracy': 0.59501}, {'accuracy': 0.59676}, {'accuracy': 0.5972}, {'accuracy': 0.59547}, {'accuracy': 0.5951700000000001}, {'accuracy': 0.59596}, {'accuracy': 0.59589}, {'accuracy': 0.5957799999999999}, {'accuracy': 0.5943}, {'accuracy': 0.59276}, {'accuracy': 0.5960799999999999}, {'accuracy': 0.59524}, {'accuracy': 0.59479}, {'accuracy': 0.59319}, {'accuracy': 0.59375}, {'accuracy': 0.5927199999999999}, {'accuracy': 0.59222}, {'accuracy': 0.59345}, {'accuracy': 0.59334}, {'accuracy': 0.59475}, {'accuracy': 0.5940399999999999}, {'accuracy': 0.5930700000000002}, {'accuracy': 0.59375}, {'accuracy': 0.5916499999999999}, {'accuracy': 0.5929800000000001}, {'accuracy': 0.5932}, {'accuracy': 0.59222}, {'accuracy': 0.5933400000000001}, {'accuracy': 0.5915700000000002}, {'accuracy': 0.5905999999999999}, {'accuracy': 0.59161}, {'accuracy': 0.5917}, {'accuracy': 0.5911500000000001}, {'accuracy': 0.59224}, {'accuracy': 0.5890299999999999}, {'accuracy': 0.5901000000000001}, {'accuracy': 0.58899}, {'accuracy': 0.58912}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76518d2b-dca0-4c81-9bf4-a96b800d6a66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c00c0f05-739c-4e87-a931-a5f8c8325673",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "738de7ab-316f-4b0e-be8d-a78133a46922",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17c0ed78-92b3-4906-bed0-ad46944b0b5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaee5a06-0bdf-4684-a157-3bd6dd32d34c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "957c02b5-8e5c-4ed1-ad99-c178dc914922",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "34830cbc-b127-477e-a0ef-37e788b0974a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80372ce8-5c19-4d20-a346-8475d5c166fc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b5ebcf1-b5eb-4eb5-ae96-d413b4716f24",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc2c1f1a-b176-4a1c-b489-06166d7f5eee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38326066-3808-422b-bea8-bc526520bd4c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
