{"cells":[{"cell_type":"markdown","source":["\n","The code is composed on Google Colab. This Python notebook is devoted to training the classifier on MNIST dataset.\n","\n","Code modified from https://github.com/machinestein/GNOT/blob/main/notebooks/train_classifier.ipynb\n","\n","\n"],"metadata":{"id":"QRJzk24Hg4aR"}},{"cell_type":"code","execution_count":1,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"WEhnrpuVndzX","outputId":"060ff6c6-ff25-41b6-dd19-a2333e09d6ce","executionInfo":{"status":"ok","timestamp":1758772534624,"user_tz":240,"elapsed":13215,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/drive\n"]}],"source":["from google.colab import drive\n","drive.mount('/content/drive')"]},{"cell_type":"code","execution_count":2,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"YeNFvijmnl5E","outputId":"29fcef98-a592-4c96-f452-00e46672d632","executionInfo":{"status":"ok","timestamp":1758772535210,"user_tz":240,"elapsed":580,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[{"output_type":"stream","name":"stdout","text":["/content/drive/MyDrive/OTHJ_FashionMNIST_MNIST\n"]}],"source":["cd/content/drive/MyDrive/OTHJ_FashionMNIST_MNIST"]},{"cell_type":"code","execution_count":3,"metadata":{"id":"8PUDV1YmtFuS","cellView":"form","executionInfo":{"status":"ok","timestamp":1758772553855,"user_tz":240,"elapsed":18637,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["# @title imports\n","\n","# Data Handling and Numerical Libraries\n","import os, sys\n","sys.path.append(\"..\")\n","\n","import matplotlib.pyplot as plt\n","import numpy as np\n","import torch\n","import torchvision\n","import torchvision.datasets as datasets\n","import torchvision.models as models\n","import torchvision.transforms as transforms\n","\n","from PIL import Image\n","from torch import nn\n","from torchvision.transforms import Compose, Resize, Normalize, ToTensor\n","\n","import pandas as pd\n","from matplotlib.colors import ListedColormap\n","import seaborn as sns                       # Advanced data visualization\n","import random\n","\n","import tensorflow as tf\n","import keras                                # High-level neural networks API\n","from keras.datasets import mnist            # MNIST dataset of hand-written digits\n","from keras.datasets import fashion_mnist            # fashion_MNIST dataset of hand-written digits\n","from keras.layers import (                  # Neural network layers\n","    Conv2D, Conv2DTranspose,\n","    Input, Flatten, Dense,\n","    Lambda, Reshape\n",")\n","from keras.models import Model              # Model definition and training\n","from keras.callbacks import (               # Training callbacks\n","    EarlyStopping, ModelCheckpoint\n",")\n","from keras import backend as K\n","from sklearn.manifold import TSNE\n","\n","import sys\n","sys.path.append('/Volumes/D/GitHub-Portfolio/DeepLearning-MNIST-VAE/src/')\n","\n","# Metrics\n","from keras.metrics import MeanSquaredError\n","from skimage.metrics import peak_signal_noise_ratio as psnr\n","\n"]},{"cell_type":"markdown","metadata":{"id":"_29W2X4Q-K1I"},"source":["\n","\n","---\n","## Preparation\n","\n","\n","---\n","\n"]},{"cell_type":"code","execution_count":4,"metadata":{"id":"YSGswIZHoSIk","executionInfo":{"status":"ok","timestamp":1758772559401,"user_tz":240,"elapsed":6,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["def test_accuracy(model, testloader):\n","    correct = 0\n","    total = 0\n","    with torch.no_grad():\n","        for data in testloader:\n","            x, y = data\n","            outputs = model(x.cuda())\n","            _, predicted = torch.max(outputs.data, 1)\n","            total += y.size(0)\n","            correct += (predicted == y.cuda()).sum().item()\n","    accuracy = 100 * correct / total\n","    print('Accuracy of the network:', accuracy)\n","    return accuracy"]},{"cell_type":"code","execution_count":5,"metadata":{"id":"wcNgt1LGjt44","tags":[],"executionInfo":{"status":"ok","timestamp":1758772565042,"user_tz":240,"elapsed":3581,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["IMG_SIZE = 28\n","transform = Compose([\n","    Resize((IMG_SIZE, IMG_SIZE)),\n","    ToTensor(),\n","    Normalize((0.5), (0.5)),\n","])\n","DATASET_PATH = '../datasets/'\n","DATASET = 'MNIST'\n","# DATASET = 'FashionMNIST'\n","\n","model = models.resnet18()\n","\n","if DATASET == 'MNIST':\n","    dataset = datasets.MNIST(DATASET_PATH,  train=True, download=True, transform=transform)\n","    testset = datasets.MNIST(DATASET_PATH, train=False, download=True, transform=transform)\n","    model.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n","    model.fc =  nn.Linear(in_features=512, out_features=10, bias=True)\n","    NC = 1\n","elif DATASET == 'FashionMNIST':\n","    dataset = datasets.FashionMNIST(DATASET_PATH, train=True, download=True, transform=transform)\n","    testset = datasets.FashionMNIST(DATASET_PATH, train=True, download=True, transform=transform)\n","    model.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)\n","    model.fc =  nn.Linear(in_features=512, out_features=10, bias=True)\n","    NC = 1\n","trainloader = torch.utils.data.DataLoader(dataset, batch_size=64, shuffle=True)\n","testloader = torch.utils.data.DataLoader(testset, batch_size=64, shuffle=True)\n","\n"]},{"cell_type":"code","execution_count":6,"metadata":{"id":"UbeoCvyAygXA","executionInfo":{"status":"ok","timestamp":1758772565072,"user_tz":240,"elapsed":27,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["dataiter = iter(trainloader)\n","images, labels = next(dataiter)\n","classes = list(range(10))"]},{"cell_type":"code","execution_count":7,"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":192},"id":"O8QmecGajt45","outputId":"8bd9509e-3acd-4391-d3da-037d25d280d3","executionInfo":{"status":"ok","timestamp":1758772565368,"user_tz":240,"elapsed":294,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"iVBORw0KGgoAAAANSUhEUgAAAh8AAACvCAYAAABdCLyNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAihlJREFUeJztvXd0nNd55/+d3nsfzKB3giDYSZESJZEmZVm2bCtZy1YS23HsjSM7ieXN/qKcjR3vyYmc7Dlrb9ayE+d4bSeOuyw3iWqkKPYGFoDobTAF03uv7+8PnnuNIUCKBWUAvp9zcCQMBuB9577vvc99yvfhMAzDgIWFhYWFhYVlheCu9gBYWFhYWFhY7i9Y44OFhYWFhYVlRWGNDxYWFhYWFpYVhTU+WFhYWFhYWFYU1vhgYWFhYWFhWVFY44OFhYWFhYVlRWGNDxYWFhYWFpYVhTU+WFhYWFhYWFYU1vhgYWFhYWFhWVFY44OFhYWFhYVlRVk24+PFF19EY2MjxGIxdu7cifPnzy/XP8XCwsLCwsKyhlgW4+MnP/kJnnvuOXz5y1/GpUuXsGnTJhw6dAiBQGA5/jkWFhYWFhaWNQRnORrL7dy5E9u3b8c3vvENAEClUoHdbsfnP/95/PVf//Utf7dSqWBubg4KhQIcDmeph8bCwsLCwsKyDDAMg2QyCavVCi731r4N/lL/44VCAf39/Xj++efpa1wuFwcOHMCZM2cWvD+fzyOfz9PvPR4Puru7l3pYLCwsLCwsLCuAy+WCzWa75XuW3PgIhUIol8swmUxVr5tMJoyOji54/wsvvICvfOUrC17/whe+AJFItNTDY2FhYWFhYVkG8vk8vva1r0GhULzre5fc+LhTnn/+eTz33HP0+0QiAbvdDpFIBJFIBIZhkM1mUalUVnGUy49QKIRQKKTfF4vFKo/QeoTL5UIsFlP33P0614VCAYVCYRVHtPxwuVxIJBIaSq1UKsjlcut+rkUiEQQCAf2enev1y/041zweD2KxeEGKxO2kTCy58aHX68Hj8eD3+6te9/v9MJvNC95PjIybkc1m8dZbbyEYDC71UGsGDoeDLVu2oK+vj742Pj6Oc+fOYRlScmoGrVaL/fv3Q6lUAgDS6TTeeusthMPhVR7Z8sHhcLBt2zb09vbS18bGxnDhwoV1Pdc6nQ4HDhyAXC4H8Lu5jkQiqzyy5YPD4WDHjh3o6emhr42MjKC/v39dz7Ver8eBAwcgk8kAAKlUCm+99Rai0egqj2z54HA42LVrV1XKwNDQEC5fvryu59poNGL//v2QSqV3/LtLbnwIhUJs3boVR44cwQc/+EEA1y3fI0eO4HOf+9wd/71yuQy/34+5ubklHmlt0draWvV9MpmEy+VapdGsDIVCAaVSiX5P5trn863iqJafjo6Oqu/vh7kuFosol8v0+1KpBJ/Pt+4r4Lq6uqq+TyQS636uy+Xygrn2er0IhUKrOKrlhcPhIJVKVb12P8w1wzBVc30nLEvY5bnnnsPHP/5xbNu2DTt27MDXv/51pNNpfPKTn1yOf46FhYWFhYVlDbEsxsdHPvIRBINBfOlLX4LP50NfXx9ee+21BUmoLCwsLCwsLPcfy5Zw+rnPfe6uwiwsLCwsLCws65tVr3ZZbTgcTtXX/NcWo1wug2GYdZ25zePxwOFw6LWysLCwsLAsJfe18aFSqWAymaDT6dDY2AihUAipVAqNRoO2tjbweLyq98diMZw9exbBYBAXL15EOp1GsVhcVxs0l8vFwYMH0dXVhbfeegsDAwOrPSQWFhYWlnXGfWt8cDgcyGQymM1m1NfXY/PmzZBKpVCpVLBarXjggQfA51//eIhx4fP5UC6XMT09jdHRUeTzeZRKpXVnfHR3d+Phhx/GyMgIa3ywsAALvKOESqWyrp7/tQ6Hw6nSDSJfLLXHfWl8WK1WtLS0YOPGjXjkkUegVCphMBjA5/MhEokgk8mqbmCCUqnEww8/jLa2NoTDYbjdbly6dGlBidVah31oWVh+h0Qiwd69e2EymbBhwwaqS5PP5/Ef//EfGBoaQqlUWteh2FpHrVbDZDKhu7sb+/fvRyqVgtfrhcPhwJEjR5DP51EsFld7mCzzuC+ND51Ohw0bNmD37t14//vfT3Mc5sPhcBZswBKJBBs3boTJZMLAwAAkEgmGh4fXlfFBPof72fC48V5Yj5/FzXKa1uO13isikQibN29GR0cHDh06RMUSU6kUTp8+jbGxsbvWOmBZGmQyGerq6rBr1y585jOfQTgcxvDwMM6dO4dTp06hXC6zxkeNcV8ZH1wuF1wuFzabDQ888ABaW1vB5XKRy+WQSCSQSCTg8XhQKBSQzWaRy+UQCoUgEonQ2NgItVqNjRs3Qi6XY9++fWhpacHc3BxcLhemp6eRyWRW+xLvCC6XCz6fj/b2duj1erS0tECv16O9vb3qfcSVyefzwefzUSgU1t2DrFQq0draCpPJhN27d0MkEoHD4SAej+PUqVMIh8OYmJhALpdb7aHeFgKBADweD2q1GiKRCEqlEhKJBN3d3dBqtZBIJBAIBAuMjenpaXi9Xng8Hvj9fmSzWWSz2VW6ijuD3KcCgQACgQCVSoUKXt3N/crj8WheWFdXFzo6Ou5KybFWIM9vS0sLDAYDgOvG5vT0NObm5tZNCIlhGMhkMjQ3NyMSiaCrqwt+vx9TU1OskVhD3HfGB5/Ph9lsxpYtW6DRaMDlcpHP5xEKhTA3N4fLly8jnU4jGo0iHo9jYmICSqUSu3fvRkNDA9rb26FUKrF9+3Y0NDTg0qVLEIvFmJubW5PGh0AgQHt7O1pbW/HII4+gqakJfr8fsVis6n08Hg9CoRBisRgMw6w740Mul6O7uxsbNmzAZz/7WSgUCnA4HHg8HhSLRUxNTcHpdK4J44PD4dAQosFggEKhgNVqhUajwfvf/340NTVBrVZDLBZX/V6lUsHx48cxMDCAy5cvo1Ao0H47awHyfJPE8XK5TPtr3M39yuVyoVarYTAY0NzcjJaWFkgkEgBYk2FJck+0trZSlV2GYZDL5eD3+9fkNd0MqVQKmUyGUCiE5uZm8Hg8zMzMsMZHDXFfGR+kkkWv10OtViMej2N8fBxOpxP9/f2Ix+NVno98Po9wOIxwOIxKpYK5uTn09PTAZDLBZDKBz+dDrVZDo9HQ5NS1Ap/PR2dnJ4xGI/bt24eOjg40NjZCpVJhZGQEU1NTiMfjAID6+npYrVaYTCYYDAYMDw9jYGAA+Xx+TWzGt0IikUCv16OjowMHDhyA3W6v8ghwuVxoNBpoNJoF1U+1CJ/Ph1wux0MPPQSj0YjOzk4olUooFApIJBK0tbVBrVZDIpEsSKgGgM7OTmg0GrS0tMDn88HlcsHtdsPhcGBychLFYrFmm2XpdDpYLBZ0dHRgy5YtiEQi8Hg8mJmZwfnz5++odJzH40Emk6Gvrw+NjY3Q6XSQSCTgcrmoVCrIZDKIx+M1+1lwuVxYrVYolUq0tbVBp9NBrVZDKpWivb0dRqORvre+vh779u3D+fPncfnyZeRyuTXf1PJ2GpuxrC5ra8e8R2QyGYxGI/R6PTQaDVwuF44fP47BwUG8+uqrC3qNEDgcDlwuF+bm5vDggw8il8tBp9OteeOjq6sLbW1teOSRR9DZ2Qnguo5JJBLB2NgY9X40NDRg69ataG9vR0tLC37729/C6XQikUiseeNDKpWivr4eGzZswMGDB6FUKmnHWYZhwOPxqPFR63PM4XAgEAigVqtx8OBBugmrVKoF75vP/A25q6sLXV1dyOfzKBQKGB0dxejoKI4dOwav14tMJlOzG65er0d3dzcOHjyIZ555Bg6HA1euXMGJEydw6dKl2w4rEM+RXC5HX18fWltbodfrqdejUqkgmUwiFovVbKk9j8dDfX096urq8MQTT6CtrQ1msxlKpRJSqbSqq/IDDzyAXC6HF198EdPT0+BwOGve+GCpfWp7NV1iSGltpVLB5OQkrl27hrNnz1LX+s2y1UnznEKhgFgshng8vmbdd3w+n57ktm/fjra2Nmg0mqpEU5fLhcHBQUQiEXA4HFitVmzcuBF2ux11dXXYunUrCoUCrly5gtOnT6/yFd0bKpUKfX19aG9vh0gkQi6Xw9TUFNLpNPx+P8LhME6ePAm/31/zYTWBQACr1QqbzYampibY7Xaau7IYlUoFFy9ehMvlotUaer0eSqUSFosFer0eJpMJXC4X8XgcsVgM09PTuHbtWk1tuCQsaLVasXXrVtjtdmpAiMViCIVCcLnc2z4NCwQCeq93dXWhqakJEokElUoFoVAIyWQSb7/9NhwOBxwOR01UuvD5fNjtdigUCrS2tkKtVqOzsxNarRadnZ0wGAxQKpUQiURVCfYMw9A28I2Njdi+fTtGR0erwq5rGZFIBIvFgmQySSsY1xtcLhcGgwFisZh651wuF5LJ5B3/LblcDrVaTfOnSD5kqVRa8lD7fWV8KJVK1NfXo1KpYGhoCOfOncMbb7xxW4ZEuVxGPp9HMBiEUqlcs8aHQCBAT08PmpqasH//frS0tEAkEtGfMwyDyclJnD17FsD1U2BDQwN27doFrVZLXfYtLS3g8/k4c+ZMTW1Ed4pOp8OePXtgt9shkUgQDodx8eJF+Hw+XLx4EeFwGNeuXaMJyLWMQCBAY2MjmpubaRjtVpTLZRw9ehRvv/02crkcisUivTceeughmM1m2Gw2NDQ0gM/nQyAQ4J133sHIyEhNqd+SsZFxk5ACn8+HRCKBSCSiyea389yKRCK0tLSgubmZGjPA9c68Ho8HHo8H3//+93HlyhUUCoVVNzyA693Eu7q6YLfb8aEPfQj19fUwGo00sfhWGy9J0G1vb8cjjzyCfD6PoaGhFRz98iGVSmG32xGPx9et8cHj8WC326HT6ahHPpVK3ZXxoVKp0NLSQvOnIpEIZmdn6fqwlNxXxkc4HMbo6Ch8Ph+cTifGx8fvaOGolcX2biGJeGRTkclk9FQIXG/tnkwmF2yyN0rQy2QymEwmyOXy1biMJUUgEECj0UChUIDL5aJUKiEejyMUCsHlciEWiyGXy9W0mByfz4dWq4XBYMCOHTvQ2NgIuVx+y3JaktcUDofh9/vpNY6OjiIUCkEqlYLL5cJut8Nms0Gn06G7uxtutxtWqxXJZBLRaHSFr3RxVCoVDAYDrFYr9Ho9ZDIZgOvGQiqVQjabRblcvq1nnYRbOjo60NLSArFYTD/HUqmEyclJTE1NIRaLreo9weVyIZPJIJPJ0N3dDY1Gg97eXhgMBlgsFqhUKvB4PJRKJUQikSpBRJPJRENx8z0gWq0Wzc3N6OvrQzKZxNzcHJxOJ0qlUs0ftvL5PKLRKMLhMILBIGQyGRQKBYRCIQwGAz3Nrwc4HA7EYjGkUik2bdpEc9ZUKhXEYjHK5TJGR0cRDAZRKBRuOXc8Hg88Hg9NTU3o6OiAxWJBc3Mz9SYS48PpdOLkyZNLeh/cV8aH2+2Gz+ejp6Ba3lCWGi6XSxVcW1pa0NHRAbVaXZXfEAqFEAwGkU6nF/z+fONDrVbTXJe1jlgshtFopKGnQqGAQCAAj8eD0dFRpNPpmr9HRCIRmpub0dTUhCeffBI2m21Bnsd8GIZBJpNBIpHA3NwcZmZmqAiTw+EAh8NBIpGA3+/H/v37YbPZYLPZUFdXh3A4jAsXLsDtdiMWi9XEZ2MymdDT04O2tjbYbDa6yeRyOYTDYSQSCRSLxXddOLlcLoRCITQaDfbs2YPm5uYqA7tQKODChQsYGBhAMBhcND9speDz+dTg+uQnP0lPvhKJBGazGSKRCJlMBvl8HlNTUwiFQshkMiiXy9izZ8+i94fVaoVarYZCoUBjYyOOHz+OUCiEXC5X8xVP6XQac3Nz8Hg8cDqdMBgMkMvl1PPh8XjWjeeDy+XSEvBPfepT6OzsRF1dHSQSCXK5HJLJJM6ePYvZ2dl3TREQCAQQi8XYu3cvPv7xj8NkMqG+vp6u9dFoFLOzszh27BjOnTvHGh93S6VSQalUoh9sLbhLVwqhUIienh5YrVY0NzfDYrFUhVvK5TJmZ2cxOTm5aLx3sTK8tXySUCgUVFpfpVJBKpVWXc9aUXnlcDiQSCRoamqiJbQymWzRyhzi8SgUCjh9+jSmp6fhcDiq8p3INft8PgwNDaG3t7eq4aJMJoPBYKCVUKsJOUSYTCZauTVfAj2ZTGJ2dhbBYPC25lEsFqOzsxONjY0wm83QarXUe+Dz+RAIBDA3N4dAILBqCZnE46FWq7Fr1y4aFiMJsVwuF6FQCKVSCQ6HA7FYDMPDwwiHw/SwxeFw4PV66d+02Ww0VCUWi2EwGKjHhFzz1NQUSqVSzSailstl6smbnJxEuVxGQ0MDgFs3Cl1L8Hg8aLVamghtsVhQX18PrVZLDxQejwfhcBjxePyWeYzA9c/FZrOhpaUFnZ2dMJlMUCqV4HK5SKVS1HAPhUJIJBJLvhbeV8YHSRy9H5HJZHj/+9+Prq4ubN++nWqckBuqVCrh/PnzOHnyJJxOZ9XvkvfcuBnX+sZ8K0wmEx555BFs2rQJJpNpgebFWoAkVapUKuzevRtNTU20ogFYfH7S6TRisRi+/e1v44033rhpsuTo6CjGx8exfft2+m8xDAO1Wo22tjYkk0n62mohEAggFArR0dGB97znPbBarVU/DwQCNKH8dg4apEqoubmZlhxzOBxkMhlcvnwZDocDQ0NDmJ6eXrX8H6FQCJPJhObmZnzqU59CfX09LBYLBAIBFYS7du0a/H4/Xn/9dczOzmJsbAyRSITmdgwMDKCurg7A9Xl9//vfjwcffJCWZMvlcjQ3N8NoNKK+vh5nz55FIpFAMpmsWeODGNUzMzM4ceIEcrkctm3bttrDWlJEIhH17n384x+H3W5HQ0MDRCIRvF4vEokEzp07B6fTCZfLRcONi0ESSjdv3ozf+73fQ3t7O5qbm2nHdq/Xi/PnzyOXyyGdTsPtdi/5Yf2+Mj7uFR6PB6lUWlXvX+sIhUI0NTXBYrGgsbERVqsVYrGYZv9XKhVq4Xq9XgQCgVsurOTktNZRKpXo6OiA3W5fVF5/LSAUCmE2m2G322G32+kmBPzOUMxmsygWiwgEAkin03A6nQiFQvB6vbcsmSWGeiaTQSwWg0gkogbanVSOLCdGo5Ge/nQ6HVUfjcfjiEQicLvdtDrlVhADzmQyoaGhATabDUKhkIbh0uk0ZmZmMDk5iWQyuSrltVwuFxKJBFqtFlu3bkVjYyOMRiOUSiVVc/V6vYhGo7h8+TLta0LmnYy5XC4jEAhUbUqDg4MQCASoq6uDxWKBUqmEWq2GSqWC3W5HIpFAJBLB1NQUdb3X6sGDbJ61Or67geR0kbm32Ww0ryedTiMej+PKlSvw+/0YHByEz+ej4ZabfQ4WiwUmkwnt7e2w2WxQq9XgcrmIxWIIBAIYHR2lQoO5XA5Op5P1fKwmfD4fer0eer0ePB5vTRgfSqUSv/d7v4fW1lbs3bsXer2+yg1ZLpcxPDwMh8OBgYEBjI2N1XxVx1JQV1eHD3zgA1CpVODz+WvSqFIoFNi9ezfa2tqwY8cO6PV6ei3A9bkNBoOIRqN44403MDs7i9OnT9NT0u0QjUYxPT0Nk8kEi8WynJdzx2zatAn79u3Drl270NTUROfP6XTi9OnTOHv2LMbHx9/VWJBKpejq6kJ7ezsefPBBmEwmqpCaSqUQCARw9OhRDA8PIxAIrIq6LzE029ra8Kd/+qe0pJoYSdlsFhcuXMD09DR++MMf0kTRSqVC16lSqUSTZqenp+nf9ng8ePPNN7Fz505s2bIFvb292LJlC0wmE/R6Pbq6unDw4EH84he/wJUrV2jyai3C4XDA4/FqxkBeCqRSKfr6+tDc3EznXiKRoFQqYWhoCF6vF//yL/+CsbExhMNh5HK5d02w3rFjB97znvdgy5Yt2Lx5Mw3TOp1OHD9+HOfPn8fLL79MDRiSsrCUsMbHbcDn86FUKqnhQazEcrmMRCKBeDxesw8jiRGTzG8ej0dPxaTnRSQSgc/nQyqVetc44XqBz+dDJpPRagaSD5HJZBAOhxGLxWr+c2AYhqrMptNp6pmoVCrUBT80NIRQKISxsTF4vV6Ew2F6er8disUi9Z7UCjKZDBKJBFarFQ0NDVXPY6lUQjgcxtTUFPx+/y0TTeeHrTZs2ICWlhb6nJRKJeRyOYyOjsLtdiMYDCKZTK74c87lciESiaDT6dDb20v7sqhUKnC5XOrVCofDGB8fx8zMDK3QuhnzDRIANITm8XhoIrnFYoFMJqM9gTgcDurq6tDb24tAIIDp6ema9C7w+XxIpVKaz8bj8SCRSOgXCc+sBci9aTQasXHjRjQ0NECpVILD4WBychLxeBwDAwPw+XzU2/FuJbHEc19XV4empiZotVoIBAKkUikkEgk4HA6MjY3B4/Egm80u6xyzxsdtIJfLsWnTJnR0dGDTpk0wGo0QCoWIxWKYmprC+Ph4zXoLuFwulEollEplVRIi2bhSqRTGxsZw9epVBIPBmo3pLjUCgQAKhYJu2MViEbFYDF6vF5cvX4bf76/5RSqfz8PlcoHL5WJ0dJRWH5HYdzAYxK9+9SvMzc0hGo3SHid3YlRls1lEIpGaqmxqaGhAfX09HnjgAezbt4+GW7LZLJLJJK5du4ZXXnnlXRVIeTwe5HI5Wltb8V//63+FxWKBRqMBwzA0DPn//t//w+TkJEZHR5FMJlfcICUiWd3d3fjCF74As9mMuro68Pl8VCoVxGIxHD58GA6HAy+99BK8Xu8dV6bEYjEqJOV0OhEOh5FKpdDV1YUtW7ZAIBCAz+dj+/bt+Ku/+iucPHkS3/jGN2ry+SDVPqS0lpTakpYYXC4XwWCw5g8WwPV9hyhL/9mf/RkMBgOtSvz2t7+NiYkJDAwMUKPjdsJhNpsNdrsdu3fvxsMPP0xVmx0OB/r7+3Hy5En86le/Qi6XW3bjkjU+bgM+nw+dTke7gfJ4PKRSKVpXTmr+axWSXHQjxWIR+XwekUiEaj3cT8wPPzEMg1KpRGP8mUymJk928yGet2AwiOHhYSgUCgDX59XtdiMajSIQCCASidwy+exWiMViqh8AXHfdE0/ISn8+5D7W6XRobGyEXq+HVCqlC2gmk6GqtPF4/JYnN1K509zcjIaGBlpFQErwiTcpEAjQ6pbV2LCEQiGMRiMNgRAvTz6fh9PpRCAQwMTEBNWkyWazdzxO4gUlDTW9Xi9mZmag0+mQz+fB4/Gop7Curg5arbZmQxrkmSb5SsQAkUgk0Gg0tF9XrRofZLwajQYGgwEtLS1oaGiAVCoFwzCYnZ2l+itzc3OIxWKLSiPcCPEWNjY2oq2tDUajESKRCOl0Gul0Gi6XC+Pj4/B4PEilUitSmMEaH7eBTCajblmpVIpSqYSRkRFMT09jYGAAs7OzNeWWvh1IaVYsFsPQ0BAuXLhQkyeZlaJSqSCfzyOdTiMUCiEajdbsAkXI5XKYmZmB0+nE4OAgNTDJZlIul2/7RHQz6urqsH37drrBEz2F1ZDfJtUaW7duxeOPP07VecmGMzs7i5MnT2JgYAChUOhdwy319fX4kz/5EzQ2NkKr1dK/VSqVEAwG4fF4MDU1tardUDUaDfbu3Ut7s0gkEuTzebjdbvzzP/8zHA4Hrl69SsXU7uWeTSQSSKVSyOfzmJ2dRaVSwYYNG6BQKGg4RqFQYHx8vGaNj/ltMBwOB1QqFaxWK8xmMzZu3Ai5XE7bCdQapMu4xWLBwYMHYbfbsX//figUCuTzeczNzeG73/0uHA4Hzp07R8tp3w0Oh4P29nY0NjbiySefxAMPPACdTgcAmJqawsDAAI4dO4ZXX32V9m5aiYMFa3zcBqSBHAldkLhyKBRCNput6U27VCrB4/FAKpWip6eH5jeQBVgoFNLF5Wax4kgkAofDQTu8EpRKJRobG5FIJBAOh1fysu4aiURCF1LyWRSLRSSTSTidTloFUuuGBwA69mKxuOReK6FQCIFAAIlEUlWGXCgUkEwmV1x0isPhwGAwQKPRoK6uDgaDgWqzkM8gGAzC4XBQnYubIRQKodPpaKWQ0WgEn8+nJ+ZcLkdl1DOZzKpsVCKRiG6cdrsdZrMZQqEQlUoFfr8fHo8HLpcLHo+Hut3vFZILkk6nEYlEEI/HkU6nqRAhUcMkn1UtQmTBSaiIyAkQr2atNgLkcDgQiUTQ6/VUi6murg46nQ5cLhcejwderxezs7PweDxIp9O3te8Qb6HRaERLSwtVAS4Wi/B6vXA6nZiamqIHipWsZGKNj9uAtCIn7daTySQuXbqEqampmm82Fo1G8a//+q9oaGjAli1bYDQaaSa4Xq+HXC7H+9//frS2tuLXv/41RkZGqn6fYRi8+eabGB4exp/8yZ+gqamJ/mz37t3427/9W7z99tv4wQ9+UJMP9Y20t7fjiSeeQG9vLwQCAYrFIsLhMAYHB/GNb3wDc3NzNT+nK4HFYoHVaoXJZKp6PR6PY3JyEpFIZMXmm8fjQSAQ4AMf+AAeeughbNy4EY2NjdQbQ0qHT5w4gZ/+9KfvahiZzWY8/vjj6OjowLZt2yCXyyEQCGgYy+l04oc//CFmZmYQiURW4hIXML8b7Qc+8AEoFAqIRCLMzc3hJz/5Caanp3Hp0iXEYrElP/ykUikqWOVyuQBgwX1Qq5DkXLPZjMbGRjAMg3g8Dq/Xi6tXr8Lv99ec14McBOvq6vDYY4+htbUVH/rQhyCTycDn8+F0OvHtb38bs7OzGBwcRDqdvu3cPHLAfOSRR/ChD30IOp0Ocrkc77zzDi5evEi/EonEink86NhW7F9agwgEAiiVSuh0OqqCSSoiQqHQu56waoFyuYxwOAyJRLLARUcWdZVKBa1WW9Vmez6kD8iN10q6BJMM7LVgfIhEImi1WigUCupiz2QyiMfjVBdiPQjRkRPPzZqKES2EmyWgKhQKWCwW+jkVCgWaoJxKpVY0P0gul0Mul9NuvVqttsobU6lUaJiJnNxuVKudj0wmQ2NjI2w2G+RyeVXScTAYhNfrxdzc3KpuVBKJhGqOaDQaKiJG7tO5ubk72oTuBOIBIR4l8jzUcjk66UUikUigUqkgl8upxHw4HKZ5QLWYy0WS3/V6PZqamqhqKYfDQSAQgN/vh9PphMfjQTKZvCOPB8kTslgs9OCZy+UQDAYxMzMDj8eDUCi04oYHwBoft8RiseDDH/4wWltb0dbWBj6fj9nZWUxPT+P8+fNwOp1r6pRMSmznbza3IyHe2dmJHTt2oKmpqeq9ZJGqtYf5diCfQzabhdvthtPphNvtXpWKhqWGSK6LxWI0NjbSahACyffJ5/PUbX8jPT09ePzxx9HZ2QkA8Hq9mJiYwPDwMLxe74ptyjweDw888AC6urqwZ88edHd3LzCSZTIZ9Ho9uru78eijj8LhcGB0dJQaJfPbKvB4PNhsNjz11FM0z4MQCoXwn//5n5iZmcHo6Ohtx9SXA71ej4cffhgGgwEikQjJZBIDAwOYnJzEuXPnViVBvFYND+D6PaDVatHa2ootW7bQxnperxcvvfQSxsfHMTc3d895McuBwWDArl270NPTgw9/+MO0KaTT6cS//du/YXZ2FgMDA1QK4XYQi8WQSCT4oz/6I+zevRsbN26ETCbD7OwsfD4fTp48iddeew2JRGLZS2pvBmt8LAJRMtXr9WhubkZ9fT0VdQkEAvD5fIhGo2tyo7rZTXarm4/EnuVyeU2ffm6H+Q3ygOueoXw+T7/WWuIw8LuGaEQTgugDkNMz6fJKYBiGnpoZhoFYLK5KNGMYhuZWEKl2UvlB3PwrtVhxOBwolUqqbXGjIQVcdy1LJBLodDpqIKdSKZRKJXp6z2az4PF4EIlEMBqNMBgMUCgU1EDJZrM0SdHpdN52TH2p4fF4EAqFkMvltAKHVKK43W5axbQaaw85aNTigYPcAzdqkxDPZiaTua3mgquBVCpFQ0MD7HY7DAYDuFwurUCcmpqC2+2micC3A6nkUqlUqK+vR3t7OzQaDXg8HjKZDM3nIX9ztfYw1vhYBIvFgkcffRTt7e14/PHHIZfLUalU4PF48LOf/YzKFudyuTVnfNwpHA4Hdrsd27dvrzmFyzuBnHpFIhFkMlnViXctw+VyoVAosHHjRipEpdFo0NnZCYVCAZVKRSXX50MWYr/fj3g8jjfeeAMDAwM0gbqjowMbN26km73H48Hp06fhcDhWfON5tyZ/RFRq79696O3tRS6XQyaTQTKZpOHRmZkZyOVyWK1W1NfX0+RN0l7gxIkTmJycxJkzZ2gn19VAp9Nhw4YN6OnpoYbH1NQUxsbG8J3vfIc2uFuNpGiSbJxKpVb0370dxGIx9Ho9NBoNzeFhGAY6nQ4PPvggpFIpXn/99ZrUMWpoaMAf//EfQ6fTQSQSweFw4N///d8xMzOD8+fP33aohcDj8bBnzx50dnZiy5Yt9H5nGAZerxfXrl1DpVJBc3Mz9QatBqzxcQNcLpc2VmpqaoLJZAKPx0MkEkEkEsHs7CzcbveqWowrBclul8vl0Gg0a7L5GoFkwQuFQmp8rEUPDjGiiFqtUCikJxyDwYCOjg4agpDL5dQjcmMWOxGcMxgMSKVSmJ6eRjQapR4RnU5Hc3lINZDf779tWfaVhNynpP8FIR6Pw+/3IxAI0Kqu+vp6egqcH3pzOp1wOp2IRCLv2gtmOSEVD2q1Gnw+H8ViEalUiq49oVCIeqyWC9ItmM/nU6lyhmGQy+Vor5xa83wQ7x+pciH3N5/Ph1wup56QWkQqlaK+vh4ymQyVSgWZTAbT09NwOp1IJBLI5XLUW0uKBW7s4US++Hw+RCJRlYKpRCKh7yWePoVCAavVimKxiHQ6TauByM9XAtb4mIdYLIZWq0VXVxeeeOIJ6PV6CIVC+Hw+vPTSS5iensbg4CBVTlzvWCwW6PV6qi9AqgvWIqTEtrW1FQ8++CAVlFpLEOlos9mMhx9+GGq1Gna7HWq1Gl1dXZBIJLT8tFQqIRQKIRgMIpvNVjUM5PF46O7uhtFohFQqhVwux+///u/j0KFDyOVyKBQKaGxsBI/HQzQaRSQSwdDQED2F1SKLhQOlUikty21qagKfz4dYLKZJuKVSCel0Gl6vF2+//TbcbveqnQIJ840PgUBAvQ3E47AS8XmtVguj0YjW1lY0NTVBLpcjm83i4sWL+P73v4+ZmZmaT7QnhMNhnD59GiMjIzU/5nw+j2g0Cr/fj1AohHQ6DbVaTcdNGszJZDK0t7dDLBYjGo3SRPBKpYKmpibodDpaNUP0PIDrB5dt27ahra0NuVyO6sW43W4MDg7i4sWLCAQCtMJpuVm7u8kSQixKEjcmraRJjkMqlcLExARmZmYQjUbXVJLpvSCXy6HX6yGTySAQCKrk2YHf5UvU+kMN/O4EpFarYTQaIRAIaFdfsuHWKqQUTyQSQaPRwGQyobOzE3q9Hq2trVRvhSjvFgoFhEIhWi6ZSqXgcrnofcvn86HRaMDlcmG1WiGVSml3X5L3QjxD2WyWVguEQqFVMbrnn9hKpRKtaiHMbyQ23wAhuVtSqZTKbd/4d8mJj2iXiESiqv5HpVKJbva3k5x9r/B4PIjFYtowDgDNXSHXvlyQz0+hUMBkMkGn00GhUNAy5GAwiKtXryISiawZr28+n4ff769p0UAicDh/PZ3/vJNxCwQCmEwmKJVKtLe3QyqV0kNFPB5HpVJBR0cHjEYjGhoaYLVaafd18kUqx8gzRA4s4XAYCoVi0eTz5eKOjI8XXngBv/jFLzA6OgqJRIIHHngA//iP/4iOjg76nlwuhy9+8Yv48Y9/jHw+j0OHDuGb3/xmTdeJk9bR7e3teN/73kcNj2w2i/HxcYyOjuLs2bM01no/wOFwqDZIQ0MDFArFgtbz4+Pj+PnPf46JiYmac8PeCMmDsFgsVRuV2+3Gj370I7hcrpqMBwPXKx96enrQ0NCARx99FDqdDq2trRAKhRCLxahUKlQk6OjRo/D7/RgdHaUnZSIXTjYuDoeDt956CzKZDE8++SQ2btyI9vZ2mM3mKnEmAJiYmMCxY8cwNDS07O7+xZivxOt0OiEQCHDt2jXMzs7S99TX19NnllQKANcrIIiRdaPhDFw3whQKBbq6uvA//sf/QCQSwcjICDKZDFX7HBwcpKXFpVJpRbyeq9WRVaPRQKvV4j3veQ8ef/xx2O12aLVaKmKXSCRWpOHYUkK8W6vt0boVXq8Xv/71r2G327Flyxb09fXhb/7mb5DP56tCXDweDyqVioZayWGBVHMxDENLjIk4GTlMjIyMwOPxALj+TLlcLvh8PszNzcHr9SIQCMDr9a5ortMdGR/vvPMOnn32WWzfvh2lUgl/8zd/g4MHD2J4eJhm1H/hC1/AK6+8gp/97GdQqVT43Oc+hw9/+MM4derUslzAvUA2IJlMBovFgpaWFmzbto3GW0kposvlqlKAW2/c2PuFxNB1Oh3q6uroDU8gJ8BIJIKxsTEEg8GaX4wkEgn0ej2t3iCkUimMjo4iFArV7MlIIpHAbrejo6MDe/fupY0CGYah3WsjkQi8Xi+uXLkCl8tFJbdvBokbk/CL3W6n+SQEItDkdDpX9eRIZO/D4TCkUilGR0dx7do1eh2ktwVRriWQvBUAixofpI+GVqvFrl27kEgkoFAokEwmac+mcDhclQtDSjWXq+KDaLOspIooyfEgVUWtra3YunUrDbXm83lkMhmk02laRbRWIN2q53uwao1kMomxsTEAwJYtW6BUKrF582ban4aMm3QoJzk48yEG63zDleTpZDIZuFwuTE5O0rV7bGwMMzMz8Pv98Pl8q9Lt946Mj9dee63q++9973swGo3o7+/HQw89hHg8ju985zv44Q9/iEcffRQA8N3vfhddXV04e/Ysdu3atXQjvweI0aHX62Gz2dDX14cPfvCDMBqNqKurQ7lchsvlwtjYGP7zP/8Tc3NzSCQSNSvNe7uQm3P+JsLlcqFSqWicWaVSobu7m6rt7dixA3q9vmohjMViVHLd4XCsiYZ0BoMBW7duRUNDQ5Ug2lqYT4VCgc7OTjQ3N0OtVkMkEqFQKCAYDOLNN9+Ez+fDhQsXEIvFMDs7i0wmc8s54XA4tINrc3MzGhsbaVO6G7HZbNi1axfS6TQGBwepbsZKUalUMDg4SLtuSqVSBIPBKvfw+Pg43n77bQgEgiojed++ffjDP/xDyGQyqNXqm/4bpERZrVajt7cXpVKJnhh37dqFfD5PSxNPnjwJr9eLS5cuLUtLAZvNhg996EPQ6/UrlmPV1dWFlpYWbNmyBRs3bkRLSwtUKhX8fj8GBwcxNTWFy5cvY3h4uGYN9LWM1+vFb37zG1y8eBGTk5M0mVwikcBqtQK4njzNMAx4PB4qlQri8Tg1ArlcLg3HPPDAAzCbzcjn88jlcvjBD36ACxcuwOPxVKn1Es9eLpdbtarNe7q7yQJAMsz7+/tRLBZx4MAB+p7Ozk7U19fjzJkzixofRF+BsBLZ9CSTW6lUor6+ngoYiUQiiEQixONxhMNhuFwuXL58GZFI5KYthheLI9c68zdfIkilUCggk8mo+mNnZyc6OzvR2tpa9bvEDR4KheipcC1cM1HInH8yXokY/lIgEolgMBioKBaXy6WegMuXL2N2dhbvvPPOLbtbkvuUhCC0Wi1MJhP9u6QUj3wRA12tVqOxsRE6nY5uhiu5UDEMA7/fD7/ff9P3uN3uqu/nqztmMpkFpcaLaVUQA8RsNle9t7OzE+VyGbFYDPF4HNFoFBKJBKOjo8tifCiVSnR3d9MKhfnXtNSQObZYLOju7sa2bduwc+dOiEQiCAQCpFIpOBwOXLt2DSdOnEA4HF7252X+qf1+IZlMYmRkBF6vF9lsFkKhkO5PpB9XIBCgxkapVILf70ehUKAezNbWVhgMBvT29oJhGOot7O/vx+HDh5dNDfdeuGvjo1Kp4C//8i+xZ88e9PT0AAB8Ph+EQuGCU4bJZILP51v077zwwgv4yle+crfDuCNIU6QNGzZg165daGxsRG9vL63mIKfJsbEx/PjHP4bb7UY4HF5geBB3rVAohMlkglgshlqtBsMwGBkZQSKRWNEGPbfLjWVZwPVFl7QUf+KJJ7BhwwaqZmqz2aqugRgcZ8+exYkTJzA8PFxz17ieicfjuHjxIoLBIN5++20Eg0Fcu3YNyWTypgsL6QRrs9mgUqmwadMmGI1GtLe3w2AwoK2tDQaDAXw+H4VCgXoZOjo60NjYCLVajZ6eHrhcLirANTo6WvX3ZTIZLdmrBYgi786dO6HRaBZs5DMzM/j1r3+NYrFI2wv09vbetL0AWeyj0SiuXr0Kl8u1bFoX6XQaDoeDVpwIBAJaQqxSqWgOw708d8ToaG1thdVqxcGDB/HAAw9ApVIhk8lgYmICLpcLAwMDVPfE4/Hc9AC2FBCDR6/XQyKRYG5ubkWTH2uBTCaDqakpGgYTCARwOBwAUOWdIOXhPB6PJpz39fWhrq4O+Xwek5OTeOedd2jX9XQ6XZPVmXdtfDz77LO4du0aTp48eU8DeP755/Hcc8/R7xOJBOx2+z39zZtBMogbGxvx8MMPo6mpCX19fdTaJupv09PTOHLkCO3qeGMZH6kpl0qltP+FxWJBpVKhC1Mt5obcKK0O/K5bqFarxebNm2G1WtHX10cNj/mLTSKRgNfrxeDgII4ePVqzZZfrEQ6Hg0wmg5mZGUxOTuIXv/gF7WZaqVQWVHqQ3xEIBBCLxbSt+MMPP4zm5ma0t7dDq9XSOSYeyJmZGVy8eJGW9MpkMhgMBjQ3N6OzsxP5fB5jY2P0viDGB4kt14IxWldXhwcffBAtLS20ORfwO+Pb7/fjjTfeQC6Xg0gkos/wYuqpwHXjw+12IxKJwOl0Ym5ubtlCjfl8HoFAgHpueDweZDIZTabNZDLIZrP3tL4Q75fVakV3dzd6e3uxefNmJBIJ2t354sWLuHTpEo4fP05zXJYLcp+SREmVSoVoNHrfGR+FQgGBQKDqtfmJ1TciFovR2tpKlYwbGhoQj8cRiURw9uxZXL16FU6ns+Y8HoS7Mj4+97nP4be//S2OHz8Om81GXzebzSgUCojFYlXeD7/fv8CdSSChjuWAtFa2Wq2wWq1oampCW1sb2tra0NvbC5VKBQ6Hg2QyiUAggHA4jPHxcUQiEfT09KBUKtHYm9lsrhKuIScqm81Gy5UymQy8Xi8EAsGqKsctRiaTwRtvvAGn04k9e/ZAr9dX/Zwomep0ugWeK2K0hEIhTE5OwuPxLEs3TZbFUalU2LhxI8rlMpxOJ6RSKYxGI1QqFRVMm58jwOPxYDAYIBaLodPpaOxYoVCgqakJSqUSPB4P6XQa165dg9frxczMDILBIEZHR+FyuSCTyaBQKKg8e319Pfbt2weFQkHFiCqVCrRaLRobG+FwOHDkyJFVTUYk1T8mkwktLS20eockU09NTeH111/H+Pg4xsfHUSwWwePx4Ha7EQwGb5pjUalUqBS10+m8ox4bd0ogEMCxY8douJrP58NkMqFcLuNjH/sYHA4HXn31Vdok7WZGASmjnl8mT7xgGzZsQF1dHVpbW2GxWGA2mxGPx6mcwIULF3DmzBkEAoEVOUSRpNByuQyv14tIJHLHniUiIDdf12I9Q6QhtmzZgvb2dphMJggEAhw5cgRjY2O4fPlyzXfoviPjg2EYfP7zn8fLL7+MY8eOVbVXB4CtW7fSD+Cpp54CAIyNjcHpdGL37t1LN+rbhFjTNpsNvb292L59O/bs2QOlUgmNRlPl8fB4PAgEApienkY+n0dzczN1yarVamzYsIG6ZQUCAYxGI5X0JTHlWCyGN954g2bJ15Lxkc/ncf78eQSDQfT09Cx4SEnSErB4HkulUkEsFoPL5UIwGGS9HiuITCZDc3Mzstks/H4/JBIJNBoNGIZBXV0dFAoFWlpaqBEvFAqpO9Zms1Gti/kVH+QEPTw8jGvXruHixYuYnp5GLBZDOp2mAlNEPdVoNGLLli0ol8s0/lwul2E2m9HT0wOJRIJjx46tqvFBvDBarRY2mw1KpbLKoPB4PPjFL34Bn88Hl8tVtbGOjIysxpAXEI1GcenSJXC5XBQKBXo9QqEQBw8exNjYGM6dO0fLX29mfPB4PBiNRmp8CgQCSKVSiMVivO9976Ny/HK5nHZ8dblcGBwcxNWrV3Hp0qUVvW6iYxIKhaiq7p0gkUhgNBqpKu96h+QodXR00PW8XC7j4sWLOHnyJKLRaM0XAtyR8fHss8/ihz/8IX71q19BoVDQPA7SxEqlUuFTn/oUnnvuOWi1WiiVSnz+85/H7t27V7TShcQPH3nkEWzfvh11dXXU+0GqBeYjl8vR2NgIo9EIs9lMRX3IBBMjgyzeRLyIlMMVi0WEw2HadC4YDNacV4DErblcLvr7+xEOh9HU1ERFhBYrRQyHw0gkEgiFQojFYjh27BhOnz69Ygp4y8GNjeXWwkLFMAwVBOrs7ITZbIZOpwPDMFAoFBAKhdBoNFWeD9KGnSQIkxJRl8uFRCJBS6QHBwdprX8ikaD3rcPhwKlTp6BUKtHZ2Umb1W3YsAESiQTFYhGFQgGpVIq25V7tSgiTyYSOjg60tLRUPeckVHjp0iW4XC4qyFSLkLlRq9Xwer3QarVUadlisYDH4+FjH/sYda8nk0lcvXoV+XweBoOBemMVCgXa2tqgUqkgFovB5/PpV2trK1QqFe19c+HCBQwPD2NychLT09NUD2IlIeE60n34TsN3crmc6pKsd0QiETo7O2Gz2dDc3AyDwYArV67A5/PB6XQimUyuiXLoOzI+vvWtbwEAHn744arXv/vd7+ITn/gEAOBrX/sauFwunnrqqSqRsZVEJBJBKpVi3759+OQnPwmxWLzA4Ji/6ZAqj8V+Btw685oYKn6/H3Nzc1Qat9aMj/kn1oGBAUSjUSiVSlrWtZjxEYlE4PF4MDk5CZfLhVOnTuH06dOrMPqlYbGciLVifBB1wra2NgDA9u3bF7zvxmshXZhJOV0ul8OlS5fg8Xjw9ttvw+FwIBaLLeqhm52dRTabRXd3N/L5PIRCISQSCZRKJTo6OlAoFJDNZnH16lUMDAysSCXEu2EwGLBx40aaKAtc/0yIfPrY2BjcbndNl8ynUilMTk7CaDTC7/eDw+HQhmNmsxkajQYqlQrZbBbRaJQedOLxOLq6uqDT6bBt2zYYDAbY7XYqOjVfx4fkvgSDQXi9Xhw/fhxHjhxBKBSqKsdcae6l+mx+NRsxXtbCs303CIVCdHV10TJ5rVaLwcFBDA0N0Q64a4E7Dru8G2KxGC+++CJefPHFux7UvUJ6OJCNlSgWZrPZ287I53A4KJfLdNEOhUIL4p+VSoX+XYfDgUgkUrNN50jYpFAo4OzZsxgfH0ehUIDNZsPOnTtpPTkRlspmszh//jyuXr0Kj8eDYDC4KieipWSx+7dWN6H5BINBHD16FGq1mioXEogks8fjQbFYrCpVLJVKNPeI6FYQzweRXb+ZezudTiMQCODUqVPgcDjUA0gg/SScTif6+/sRDAZX/Z7XaDRoaWmh+UyxWAw+nw+Dg4Po7++H3++vySq0xfD5fPjtb38Ls9mM3t5e6HQ6dHZ2gsfjQalUVsnGP/nkk8jlcrRXj81mg0wmo95Zkp9D1qrJyUn4/X6MjY3B4/Hg2rVriEQiNRUmvlfWq+EBXDc+2tvb0drainK5TMUeSeXbWmFd9nYRCASQSCTU+CAuylAotCCb+GZwOBzk83nEYjHEYjEMDQ0t8GYUi0V4vV6k02m4XK6ajrFVKhVEo1FEo1F4PB4IhUJEo1E0NjaisbGxyvggJ6oTJ07gzTffRDQaXVM39a24sdx4rWxEr776KrRaLZqamqiXisgqx2IxnD59ekFyWbFYpKJjd9qCnTQzO3LkCC5fvkyTqgnZbJY2O6sFrwdwXW+I9LYArnvuBgYGcOnSJZw+fRrFYnHVDaTbZW5uDj/96U9hsVjg8XjQ0tICu90OhUKxoE9NV1fXLf8WyacIBoMIh8N4/fXXMTAwgKGhoTUdQr0V693z0d3djY6ODmp8kLDiWmJdGh+ZTAYcDgfHjh1DOp2u+rrdTZR0BiXxcq/Xu8DzUS6XEY/HqXzvWqJcLtM+DT/72c9w5swZAL8zPlKpFIaHh5FMJmsuhHQ3lEolZLPZBSd9pVKJrq4uuFyumshbWAwivyyTyeDxeKjng+SCZLNZeDyeBfNEPHf3Ii1N1D0zmUzVs0MSHlej38vNSKfT8Pl8kMvlAK57jPr7+zE9Pb1mPB6EUqmEVCoFv9+Pq1evIhQKQa1WU20WIgx4Y7i0WCxiamqKyqDPb5w4Pj6OQCCAa9euUc/XeiGbzSIYDFIRQfJskKZrqVRqTc3/rSDh4kqlQvOt1qLXal0aH+TU9pOf/AQ//elPq352tzfgerlxCeVyGRMTE+BwOLhw4cKi71krnoHboVgsUjnh+Wg0GuzatQsKhQKXL1+uSTGeWCyG/v7+W57klmueMplMTZfrzScWi2FmZoZuQG63G2+++SYikciaND7i8Tji8TjcbjfUajUCgQDsdjs+8IEPwGAwoL6+foEwWjqdxtGjR+F2u6mxnU6nab6P1+tdV881IZ1Ow+PxwGAw0OsrFovIZDIIBoOIxWLr7pqLxSLGx8cxNzdXMwJ/d8K6ND4I6/EhW2rul88oEAjgwoULiEaj4HK5VDhLIBBArVZXdUOtVe6HeboXfD4freRyu924ePEiIpHIPSuCrjZEBI6ojB49ehQKhaJK8p6Qz+fpdRPtDJLvk06na9KztxSEQiFcuXIFkUgEkUiEej4mJiYQCASQSCTW9D0wn/nGlc/ng9vtrumQ/81Y18YHCwthcnISXq8XLS0tcDgc2LJlCxoaGqgo1Y2JnCxrj/HxcUxOTla5pZer++xKk8lkMDo6Cg6Hg7NnzwK4eVLljde8lpoo3i0OhwOzs7NVXV2B34Vf1tu1E6NybGwMU1NTrOeDhaVWITkfoVAI4+PjKJfLEIvFtHnW1NTUmsvbYamGbDTrFXLiXa/ei3vhfvpsiNcjl8shGo0iHA7XZLj43WCND5b7glKphFKpRJujvf322/je975HF6xKpbImH2AWFpb7CyIcmEgkMDs7C4fDsSaNLtb4YLmvmN8kaz1U8bCwsNxfELXqTCZTk5pStwtrfLCwsLCwsKwRcrkczp8/D5FIhEQisdrDuWtY44OFhYWFhWWNUC6XEQwGIRAI1rT3ljU+WFhYWFhY1gi5XA4DAwMAsKbz1Gre+OByudDr9euuVOpGiCojQSaTwWKxrNJoVob5nViB691Y9Xp9zett3Cv341zrdLoqNU4+nw+DwbBoQ8P1xPyGlcD1uV/vcz2/Azhw/bk2GAwQCASrOKrlhcPhVLUfAO7Pub4TOEyN7eqJRAIqlQp//dd/DZFIhEqlgkwms65L6AAs6Lybz+fXpHDMncDj8SCVSqm+BjvX6xd2rq9zv871ehY4I5B+YoT7Za5lMhk9MObzeXz1q19FPB6HUqm85e+uCc/HjSfF+wGRSFS1aN0PsHN9/8DO9f0Dl8uFQqFY7WGsOPfjXN8JrKQjCwsLCwsLy4pS854P4rK7H9yzYrGYfp/P59dkp8I7gbjsbnTPrve5lkgkC1zx7FyvT26c61wud9+44tm5vv/m+k6oeeMjm83izTffRCAQWO2hLBscDgfbtm3D1q1b6Wvj4+M4ffr0uk601Wq1eOyxx2hsMJPJ4PXXX0coFFrlkS0fHA4HO3fuRF9fH31tdHQUZ8+eXddzrdfrcejQIep+T6fTeO211xAOh1d5ZMsHh8PB7t270dvbS18bGRnB+fPn1/VcGwwGPPbYYzTZNplM4rXXXkM0Gl3lkS0fHA4He/bsQU9PD31taGjoph3D1wsmkwmHDh1akGx7O9S88VGpVBAOh+H3+1d7KMvKjY2B0uk0fD7fKo1mZWAYpqqfSrlcZud6HTM/4bBUKiEUCq3rQwWwcK5TqdS6n2sul1vl5SiXywiFQuv+UJHJZKpeS6VS634t4/P5d+3RYnM+WFhYWFhYWFYU1vhgYWFhYWFhWVFY44OFhYWFhYVlRWGNDxYWFhYWFpYVhTU+WFhYWFhYWFaUmq92YWFhuXt4PB44HE6V5gLDMOtec4GFheV65RGHw6Hy5/P/fz6VSoWuDStVBs4aHyws6xSJRIL9+/fDarVi48aNkEqlOHXqFNxuN65evbruywBZWO5XFAoFxGIxNmzYAIvFArlcDrFYjIaGBphMJmpgZLNZ5HI5TExMYHh4GD6fD7OzsygWiygUCss6Rtb4WCaIhUmsTGJVruZ4yH9vNY71LH40n/nW/92o890Oqz3nQqEQGzZsQGdnJw4ePAiNRoNKpYKhoSHMzs4iGAyu6ElntZn/DNz42nzmfyb3y2fDsj4ge45UKoVCoUBHRwfa29uh1WqhUCjQ19eH5uZmANfv7WQyiWQyiTNnzqBcLoPL5VLtHdb4WGMIhUJIJBIcOHAAdrsdVqsVIpEIP/nJT3DlyhUUCoUqYa3lgsPh0I6aFosFMpkMzc3NEIvFSCaTyOfzCAQCyGaz1DVfLpdRLpfh8/mQSCSoy65UKq35jpQCgQAikQhyuRxarRZCoRBSqRQ2mw179uwBn/+7R4FsSO+28dzqfeVyGUePHsXY2Bi8Xi9isdjSXcxtUiqV4HQ6IRAIkMlkYDAYsHv3brS3t6O1tRVerxdvvfUWxsfHkU6nl32xWWlIuEmpVMJsNkMul8NsNkOhUKCurg5SqbSqJXipVEI6nUY8HseFCxcQiUQwOjq67qXvWdY+XC4XfD4fbW1t0Ov1ePDBB9HQ0ICmpiZotVqIxWIIBALodLqq9UokEoHL5aKvrw8GgwFOpxPbtm3D1atX8dprry2r8c0aH0sIh8OBQCCATCbDAw88gL6+PvT09EChUODq1asYHR1FuVxeEeODy+VCJBJBJpPBbrdDr9dj165dUCgUCAQCSKfTmJiYQCKRAI/HA5fLRbFYRLFYRDqdRiqVAp/PB5fLBcMwa9744PP5kEgk0Gg0qK+vh1QqhVqtRl9fHz71qU/RngzzvVW38gq82/tKpRIymQwymQySyeSqGB/lchmBQABSqRT5fB5cLhednZ2oVCpoampCJBKBy+XC3NwcCoXCujQ+eDweFAoF7HY7DAYDurq6YDQasXHjRmg0GjQ3N1Pjo1gsIhQKwefzoVgswuFwwOFwsMbHfcKNXrC15PXicrkQCARoaGhAY2MjDh06hJ6eHkgkkqqDFVB9XQKBAAKBAM3NzWhpaYHH40F9fT1KpRLeeOONZc0NY42Pe4TD4YDP50Ov10OpVOLRRx+F3W7Hrl27YLVaaX8DhUIBvV6PUqmEfD6/bOPhcrmQSqWQSqVobW2FyWTC448/Dp1OR42JhoYGcDgcdHV1IZvN0sZAk5OTCIfD0Ov1iMfjMJlMUKvVuHLlCiYmJhCLxZBMJpdt7MuBxWJBQ0MD9Ho9bDYbLBYLOjo6IBAIIBaLYTAYwOPxFl1objcksdj7atl1z+FwoFQqwePxoNPpoNPpkE6nF0iBrzW4XC64XC5UKhV0Oh3q6urQ2dkJs9mMjo4OyGQyaLVayGQy6PV6iMXiBeE3hUIBhmGwd+9eNDc3I51OY25uDpOTkwvks1lWD5PJBIvFgnw+j1wuh0KhsKiRKBKJoFKpIJPJYDabqaE5Hy6XC7FYjM7OTkgkEgC/6zPl9Xrh9/trskGcQCBAU1MT1Go1Nm3aBIPBgA0bNkCv16OhoYEeqBY7OLrdbvj9flitVlgsFvocKBQK6jFpaWlBPB5fttww1vi4R4i7y2g0wmKx4IMf/CA6Ozvp4gZc71oql8uh0WiWvbkSMT7UajVaW1vR2NiI9773vdBqtRgZGUE+n0draytkMhlSqRTK5TJUKhX4fD6OHz+OmZkZ+lB3dnairq4OfD4fyWQSpVJpzRkfRqMRfX19qK+vR1dXF+x2OzZu3EjzPG5lICyF8bHahsf8MczPeVAoFBCJRNBoNFCpVBAKhas5zCWBnP7UajUaGxuxefNmHDp0CGazGW1tbQtyexiGqTI+eDwe5HI5hEIhtm7divr6eszOzkKpVMLj8bDGRw2h1+vR2dmJVCqFRCKBVCq1qHeRhNgMBgN6enogEAgWvIfH40GtVuPxxx+HWq0GAEQiEfh8PnA4HMRisZozPoiXvbGxEXa7HU899RSamppgsViqmryRUPqNeL1eDA8Pg8vlwmQy0RC7XC6n4eiGhgZ4PB4EAoFlWcfuyfj46le/iueffx5/8Rd/ga9//esArrcR/uIXv4gf//jHyOfzOHToEL75zW/CZDItxXhXBDKxYrEYRqNxUWsZuJ7f0draCrVajZ6eHuj1ejQ3N0OpVFa5ukhiTyQSWVavBwDIZDL09vbCarXi4MGDMJlMEAgESKVScDgcCIfDuHDhAg2vlMtlGAwGiEQiTE9PIxKJ0ByPSCQChUKBa9euwe/3Qy6Xo6enB/l8Hvl8HolEYlXCCXeCRqNBW1sb6uvr0d7eDpVKVbXhVCoVFItFlMtlOjfzwynlcpm2xp6bm0M+n0c2m0WxWEQ0GkWxWLxpzseZM2fgcrmQSqVW5mIX4WaldeRnGo0GdXV1cLvdKzyye0ckEkEoFMJiscBisUCtVkOr1cJms6GlpYV6veRy+aKfwc0+FxKqAYDt27fDbDZjYGAAmUwG+XwelUoFQqEQXC4XhUJhTYQkibdLLBbTz8pisUCj0UAmk9GD0nzS6TSSySTd2AOBAKanp5HP51fNEJNIJJBIJOju7sb+/fsBXL+2QqGwqIEgFAqhVCohk8lgNBoXGKDk+SD5cQSRSIR9+/ahrq4OgUAA8Xh8eS/sFvD5fGg0GhoaJ0aCRqPBoUOH0NzcjObmZqjVanpPjo+PIxQKYXx8HIFAYEHy+9zcHILBIK5evYrjx4+jsbERbW1t0Gq1MJvNUKlUaGlpQalUwujoaG0ZHxcuXMC//uu/VrWLBoAvfOELeOWVV/Czn/0MKpUKn/vc5/DhD38Yp06duufBrhRcLhdCoRAqlQrt7e0LYmYEpVKJgwcPwmKxYOvWrVAqlTdd0JLJJMLh8LIbH1KpFJs2bUJLSwsOHToElUqFdDqNWCyGmZkZzM7O4uzZswiFQshkMqhUKjCbzZDJZNTo4PP54PF4GBsbA8MwcLvdCAQC6OnpQUdHB5LJJOLxODwez5owPtrb29HQ0ICOjg4A1V6OSqVC3bbJZHLBQ1YsFhGJRBCPx3Hx4kXEYjFEIhFkMhlMTU3dNFTBMAxisRiy2WzN5lJwOBxotVpYrda7aom92ohEIigUCnR2dmLLli2w2+1oaGiAzWZDa2tr1Xtv9lwuBgm/SCQS7Ny5EzabDb/85S8RCoVQKpXAMAxEIhHt6FnrxgdJvFWr1VCr1di6dSv1DLW0tMBoNEKj0QCofjYCgQDm5ubg8/kwMzODoaEhxGIxJBIJZLPZVfHqSaVSaDQabNiwAQcOHIBCoaDeCqB6nu9lfGKxGA8//DA6OzvxyiuvYGpq6l6GfU/w+XwYDAbw+Xxks1lwuVzqaX/sscfougaAGmEDAwMYGRnB4cOHMTIygmKxuOh9qlAooFQqsW/fPvq3rFYr9ZzH4/E7enbu6Lru5pdSqRSeeeYZ/Nu//Rv+/u//nr4ej8fxne98Bz/84Q/x6KOPAgC++93voqurC2fPnsWuXbuWZtRLBJ/Ph1AoBI/HqzIwyGk4m83C6/Xe1PORTCYxOzuLcrmMnp6eqrJan8+HVCoFr9eLaDQKl8uFfD6/5Ak8IpEIWq0WSqUSra2tMJvN2LJlC0wmEzgcDqLRKE6cOIG5uTmcOXMGfr8fPp+PVjcwDINQKIREIkGFZkj1C6FYLEImk6GzsxP79++nNeBzc3OYmZmhi1MqlUIkElnS61su4vE45ubmkEgk4Ha7kUgk4HA4FsxPuVxGJpNBLpeDy+VCNptFJpNBoVBAOBy+pWGRy+XoZrUaMAyDdDpNN4tcLgeBQEDvZw6HA6PRiKamJnrSr2XIJkpO6hs2bEBrayu6u7vR1dUFlUoFrVYLlUpF338rSCI1SQ7mcrmQy+X08yHfE80EgUBAc7y6urpoPhQpTawV5hsbUqkUvb29MBqNqKurg0qlQl1dHTQaDYxGI4RCIYLBIF0TyL1OvjKZDMRiMex2O/X2zc7OIhKJrIpQnVQqhU6ng1qtpvNCrvlG7mXTLBQKGBwchMPhQCKRuOu/cy8IhUIYDAbodDrs27cPMpmMrs9KpRJqtRoqlQoMwyCRSCCTyeDy5cvw+Xw4c+YMnE4nAoHALdcgcugKh8OYm5uD2WwGAGrghcNhKJVKun4sJXdlfDz77LN43/vehwMHDlQZH/39/SgWizhw4AB9rbOzE/X19Thz5syixgdx4RNWcqIFAgGUSiUtjyVks1n4/X6k02nMzs7e9CaWy+Ww2Ww06YlQLpfhcDjg9Xpx9uxZuFwuTExMIJvNLvkpiQjHNDQ04EMf+hAMBgM6OjpoDD8YDOKll17CxMQERkdHFw0BvFuioUajgVKpxJYtW/DUU09BIBBAKBTC6/VidnYWFy5cwOHDh+HxeBCNRlc9z+F2iEQiuHTpEubm5nDlyhXMzc3h/PnzKBaLN/2dtXBd86lUKojH45DL5UilUsjlcuDxeFXGR11dHY151zpk7BqNBlqtFvv27cMjjzyC+vp62O32O/57DMOgVCohl8shHA6Dz+dDKpVWGR9k4ZVIJLQskcPh0JwQEhOvJUgemtlshtFoxMc+9jH09fXBarVCoVBQb006nUYul4PT6YTL5YLP50MgEEA0GkU4HIZEIoFcLkdvby82bdoEpVIJqVSKCxcu4OLFi6tifMjlcphMJmqAAPdmZAALc3+A6/vS2bNnMTIysmoHKrFYjKamJjQ1NeHDH/4wdDodJBIJPSyTcEylUkEoFEIwGMTPf/5zXLt2DdPT07fllSb7r9/vh8PhQENDAxiGgcFgwLZt2xAIBGg4J5/PL+kaeMfGx49//GNcunQJFy5cWPAzn88HoVC4YCEzmUzw+XyL/r0XXngBX/nKV+50GPeETqejceLW1lZqfITDYYyOjiISidA42WJhEqFQiLq6Ouj1emzYsAF2ux1SqZSWNsbjcZw5cwYzMzO0gmQxl/5SIBQKYTQaodVq6d8XCoWoVCoYHByEy+WC0+lEMBi8a/d/Pp9HMpnEyMgI3nrrLdhsNtjtdjAMQ5P5gsEg5HI5fD4fPTHVMrFYjKp8kge1XC6vOQPjVlQqFcRiMQiFQiSTSXqKXSzprpYhJ3mDwQCVSoVt27ahvb0dfX19VL2RvO92KZfLiMfjGB0dRTQaxfj4OGQyGfbu3QuVSgWj0XjTz4nH48Fut6O9vZ3+26sNyQMg+RBarRbt7e208kEsFsPr9cLpdMLtdiMajSIWiyGdTiMQCCASiSCRSCCZTNJSe6FQCJFIRPOayDqwmgeMWCwGp9OJ48ePI5/PQyKRQCaTIZfLIZVKQSqVQqVS0VytUqm0aIiIJCerVCrs3r0bMpkMAoGAehFCoRDcbjfcbveyh8pvhIzLarXikUcegc1mo/o0AoGAVnURQzifz+PChQuYnp7G1NQUgsHgHY85m80iFAohnU7TXLdSqUQN1eUILd6R8eFyufAXf/EXePPNNxdNULobnn/+eTz33HP0+0QicVenmDvBbrdj37596O3txYEDByASiSCRSHD58mV85zvfAZfLxfT0NIrF4qKTKBAI0NHRgYaGBjz66KOwWCxQKpUoFouYmJiA0+nEz3/+cwwNDdFQy3I9rFKpFE1NTdDr9ahUKiiXy5BKpYhGo3jjjTcwNTWF4eHhe6qyIXoVx48fh8vlwoMPPoiHH34YVqsVzc3NkMvl0Ov10Gq1GB8fRzQaXbWY8O3i9Xrx5ptvIhKJwO/3r8teJ+VyGV6vF7lcDqFQCPF4HEqlcrWHdceQkzwpAfzYxz6G/fv3V/WsuRPDgyyufr8fr7zyCmZnZ/HOO+/QuHpjYyNUKtVNjQ8+n4/u7m5s27aN5kqsNjweD3q9HgaDAX/wB3+A9vZ2dHZ2QqVS0VDKwMAAHA4Hjh07hrGxsapEyltVfY2OjuLy5ctQKpUwmUzweDyr9mz7fD74/X6Mjo7iJz/5CQwGA6xWK8LhMNxuN0wmE9ra2pDL5RCJRKhxdeN4SWVTe3s79ZyRHB6/3w+3242RkRGMjIyseAm6WCxGfX09enp68IlPfAIGgwFisXhRJeZKpYJMJoNf//rXOHfuHBWOvFMSiQRcLhc1LInxls/naS7gUs/5HRkf/f39CAQC2LJlC32tXC7j+PHj+MY3voHXX38dhUIBsVisyvvh9/tpLOlGRCJRVZbxciKVSqnS55YtW9DY2AiFQoFsNks9BCROtpjBQOrBNRoNOjs70djYCI1GA6lUSt1SREyMeBqW+zTN5XKpe3R+vDufz8Pr9VIBqaUgkUhgbm4OV69eRbFYRFtbG5LJJPh8PrRaLRoaGrB582bMzMys2oZOTgNmsxkWiwWdnZ2wWCy0yiUUCmF2dhbj4+P05FfrCYP3yvyNpZYNwhuRSqUQiURobW2lpZJENXgx4aSbGSDZbBbxeJzmeJBcrdnZWQwPDyMQCFBRvUuXLiESiaCxsRGVSoXq9NzIjQ27VguhUAir1QqlUokNGzbAaDSisbGRavXEYjHqfR0YGKDej2g0ilwuh0qlgrq6OhiNRvj9furxnf/sZrNZhMNhZLNZ5PN5RCKRVXtmyD1MEijj8Th4PB6SySRyuRzi8TjcbjeKxSINNeZyuapyc1LNtGPHDrS0tEChUNBkznQ6jYGBAZrXQqqbVhKBQEAPc8RTSe63+RSLRZoQTLzrdytgSTwfqVQKDMOAx+NBKpVCIpHQPLF3a81xp9yR8bF//34MDg5WvfbJT34SnZ2d+P/+v/8PdrsdAoEAR44cwVNPPQUAGBsbg9PpxO7du5ds0HcL2SD37t2Lj3zkIzSGHAqFcPbsWfT39+PcuXM3LZ/j8/nQ6XRoaGjAe97zHjQ2NsJkMtH8ilwuh5dffhmnT59esURDPp8PlUoFvV6PpqYmulimUikMDw9jampqyRKFAoEAgsEgRkdH8etf/xrbt2/Ho48+iq1bt+LgwYPg8/kQiUQ4efIk+vv7V6W3CY/Hg0AgwObNm/Ge97wHmzZtQm9vL314HQ4HfvrTn2JkZAQ+n29F1GZZ7hwul0sX4Keffhrbt2+nHr7FEsBv1qOF6DSMjIygVCqhUChgenoav/nNbxAMBjE+Pk43skwmgx//+Mdobm5GT08PSqUS6uvrV+Jy7wrSw2PPnj2w2+04cOAATCYT7HY7eDweTp8+DZfLhV//+teYmJiAz+dDMpmkzyXZiLdu3Yq9e/fi7bffxunTp5HL5aqMD5KISv7NWjBiiX5FOBxGOBwGcH2+g8EgQqFQ1fjm/z/Jl7BYLPj0pz8Nu91ORbaCwSC8Xi9++ctfYnJyEk6nc1XK5CUSCZqammC32+nmvxiFQgH9/f2Ynp6mxtLdEovFEI/HEQqFUKlUaDRApVJRheSl5o6MD4VCgZ6enqrXZDIZdDodff1Tn/oUnnvuOVqB8fnPfx67d+9e1UoXkiBZX1+P7du3o6GhAXw+n56Cp6amcPXqVczMzCzax4RIlZMytaamJuh0OkilUqpYOjU1BY/Hg0gkcsukxaWmXC7TOnyfzweZTEYrMYguwVItFGTRIZ9PIBDAyMgIlEolurq6UCwWYbFYYLfb0dzcjGg0Cp/Pt6ILlcFgoHkoLS0t0Ov1VaeGcrmMYrG4qlUoLO8OqcSpq6uDRCJBqVSiIQISiybaDBKJZIFaKQCqzjg7O4uLFy/Sefd6vbR/0fwSRFJ2Tcqjb6bhwjAMPSWvlvFKDkJGo5Hmnel0OohEIkxMTCCTyaC/vx9ut5smgmez2arxkhya1tZWtLe3Y3Z2lipf3nhgqVW13lspC89n/kneaDSioaEBBoMBMpmMSiCQPkxzc3MIh8Mruo7PRygU0mThGysPgeseD6/Xi0gkguHhYTgcjnsODZH8HpFIRPt8FQoFGnZZDi/2kiucfu1rXwOXy8VTTz1VJTK2mpCQxL59+/DHf/zHNDQxMDCA73znO3C73bh27dpNm74JBAIYDAa0trbi2WefRV1dHRoaGsDj8RCLxRAMBvGv//qvGB8fh8vlWtFry+VycLvdSKVSyGQykEqlsFqtmJubQywWW9bEz6mpKczOziIcDkMmk6G9vR179uwBADidToyPj+Pw4cMr+hD39PRg37592LlzJ3bv3k2l0xmGoX1qam0BXQ1q/TPg8XjYuHEj7U8RDAYRDofB4XCQTCaRzWZhtVphMBhgs9lQV1e34G/MzMzg9ddfx+DgIA4fPkwXUVLlcmPPokqlQkupSWnhYh7QSqWCcDhM82lWA4lEgk2bNqG5uRm/93u/h7q6OuRyOcRiMbz00ksYGxvDhQsXEAwGF43ZczgcdHd3o6enB4cOHcJDDz1EN5iLFy8um6T2aiGRSGCz2WAwGOgBkrSZuHjxIrxeL5VTHxgYoB6i1UChUGDLli2w2WyLej0ymQyOHTuGmZkZvPzyy1Qy4F7/TZPJRMXMstksYrEY3UOWutIFWALj49ixY1Xfi8VivPjii3jxxRfv9U8vGWq1GvX19TCZTDSRjDyoRECLCG4thkgkQn19Pe0RolarwefzUSwWMTs7C4/HQ08MKy0oJZFI0NjYCLVaDZ1OR2/WlRA/qlQqKBQKCIVCGBkZQaVSgV6vp0nD8XgcfD5/Wb0MJO5OhNFITw+1Wk11GQDQ5OFYLLas1UdrBeI+J25o0mCqVkSzGIaB3++HTCaD3++vkn8niyGPx6OVDfOJx+MIh8OYmprC+Pg43G43VfO91ZyT+0goFNLPY7FwTrlcxsTERJU3ZiXh8/mQyWTUu0cq7SYnJ6nmDtGuWcxdPr9M02w2Q6lUQiAQ0N5Pq53HshyQfD0it06Un0lunNvtpqqfq61aS7w0N3rziLFcKBTg9/up0ZHJZO7ZM0EUnslaTbz9RAeL3BerWmq7FmltbcWBAwewadMmqNVqpNNphEIhzMzMUG2SW02eVqvFe9/7Xmoty+VycLlcRKNR/OY3v8HExAT6+/sRDodXPMnSbDbj6aefhlarhUgkQiqVwtWrV1d0DOPj45ibm0NDQwOuXr2K9vZ2HDhwAEKhEC+99BJ14S0HZNFUKBSQyWTo6urCjh07oNVqq95HRMVGRkbQ39+PWCx2XxsfBJFIRIW0lEol1X5YbYrFIo4cOYJjx44tSOwk8/ZHf/RHtAPnfCYmJnDkyBFcvnyZJsHfTniEiDepVCoqYrVYfkkul8N//ud/QiQSIRQK3eOV3hlkY6qrq8NHP/pR2kDM5/PhO9/5DsbGxjA0NIR4PH7Ta5bL5ZDL5WhtbaWt1AHQ53Q9Vn6R3Li6ujrs2rWLtpQIh8M4e/YspqenqcdjtfPAyFiVSmVVhQspd04kEhgYGMDo6ChNBL5XUqkUPZwRBV+xWEyF6lY952OtQWLCJpMJ9fX1UCgUKBQKCAQCmJychNvtvqmVS/T+DQYDbd5jNpshEAhQKpUwNzdHRbbm5uaQyWRW7aYl/65YLKba/ytJsVhEMpmksuvFYpEq8Ol0OnC5XITD4WXZ7MViMS03tlqtsNvtUCgUCxql8Xg8iEQiKJVKmM1meqpYTE59rQil3SscDgcikQhSqZRuSDfrkbEa3GzB43K51CiYr9hKSCaTcLlcCAaDt/Ro3gjJCyNrxa3KG4luykrnBZDKMr1eD5VKBYlEgkAgAJ/PRysf0ul01bjIZ0Q2EuIBrq+vpzlR6XQa0WiUVv6sF/h8Pt1EDQYD9VxLJBJks1mkUimkUimq+LyahgfxNkilUgiFQvD5fLpGEc8E8WqRMumlGq9KpYLJZIJerweHw6HKv+QzWRM5H7VEXV0dbDYb9uzZg/e85z3I5XLwer1444038B//8R+0rOxGiPu1vr4eH/nIR9DY2IhHHnkEcrkcAoEAfr8f//Zv/4bp6WmcPHkSsVhsxYVoCKlUCqOjo0in07SqY6UhrkCi9Mrj8WA0GtHc3IwHHngAs7OzOHXq1JIv1BwOB1arFXV1dXjmmWdw6NAh6q688XNQqVRUQpzL5SIYDGJycnLB/Pv9fhw9erRmNuDlRqfTQalUorGxEc3NzWuiczFJMCWb8I19aebm5nDq1CnqibxdQ1Kv1+Ppp59Gc3MzWlpaoFQqb9pagdwfK22kyuVy7NixA21tbdDpdKhUKnjrrbdo0vyNFVykeaBSqcT+/fvR2tqKrq6uqmZ85DDW39+/7u594uGpr6/HQw89BLvdDrvdjkqlAqfTSZttJpPJVff4SKVS2O122Gw2qNVqyGQyaghkMhnMzc3hm9/8Jqanp3Hp0iUkEoklG/O2bdvw1FNPobu7GzwejyZrz88drLmcj1qGlJIR13KpVKL138Fg8KaLLHHja7Va6vUgp2ni9nK5XHC5XLS+fLVOyuVymaoSzi+fWyxLerkhPTJIB99SqQSbzUabIS0HpLyXqFLeDHJaViqVsNlsdMO6cd6kUinMZjPt2FsL+Q/3CumqHIvFYLFY6OvkXmEYhuZ9rIbxeqeo1WpahkuUKYHrhngymaSCancqdEdySFQqFT153ozVet6JRgUJCXE4HHoylclkVfpKRCPCarXSkIPRaKRfCoUCIpEI2WyWyqqT3Ji1DhGgk0gkMBgMtBEb8cTm83nMzc1V5U2s9rNOxisWi2kOG5nfdDpNm3nOzc0tqFy6V/h8Pi3rJdUuRNeFVIktNeva+CC5HblcDnw+n8bMyAn9ZidxpVKJnp4e9PX14cCBA9RNl8vlMDMzg/HxcVy8eJE2i1tNFz1peCYSiWjTIeJCJ+7WlVpMkskkHA4HBAIBNBoN9Ho9Hn/8cVy6dAmHDx9eMe/QrQSnjEYjlEolLbm9EZfLBZVKhZmZGfz6179ecXXD5aBYLKK/vx/JZLKqg+lahMPhYPfu3XjwwQexa9cu2Gw2ukgPDg7inXfewblz5+5Kw4WEoYRCYc0mXZIOp3q9niaIGo1GMAyDQ4cO0fg/n8+nLdLb2tqohyOTyUAul0MoFFJDc2JiAidPnqSqzusBgUAAmUwGm82GXbt2obm5GQ899BCEQiGKxSLcbjdeeuklOJ1ODA8PI5VKrXquB1k3yX4zXz9qbGyMqlV7PJ4lz6EjjTX1ej3dJ6PRKOLx+LKFF9e18UGyg+d7BAQCAdRqNRoaGqiG/42QTp82mw0qlQoikQjJZBKJRAKzs7NwuVy0U+hqUygUEIlEEIvFUCqVwOVyIZVK6ZdYLF6WhnaLQboBE2NHKBTS2PRynaiJGmOhULiloXBj0qJQKIRcLl/weqFQQHNzM7hcLlpbW2m5GelyvBZzQYgSZCQSoTlOtaDOebcQOX+yiZI8lWAwiKmpKQQCgZtqdNwK8pnU8ufCMAwNcZbLZdpoj1QokE2Jx+OhoaGBhhtJvydyWOLxeDRcGo1G4fV6102uB+l8XFdXh7q6OlitVurpIV28yTX7/f5Vyd252bjnV1kRDwRJF/B6vUin08t2iCMyBAzDUHn6VCq1bGKR69r4EAqFkMlk1IIkcbSnn34ahw4dwvT0NPr7+xd8sBaLBQ888ADt4hgKhXDkyBHMzs7ilVdeQTAYrJnW8ZFIBEePHkU4HMahQ4eg0+nQ0tICPp+Pzs5OCIVC2lF3uSE9OOx2O5544gkoFAqoVCpMTk4uy4JOHpJEIoHp6Wlcvnz5pu+dv6kwDAONRoOmpiZaWkkwGo148sknUSgU8PTTT8Pj8eD73/8+XC4XLl26tCY9IeVyGXNzczSWWygUFk3UXCuQ+4wYtD6fD06nE8eOHcOvfvWrm+pz3A43M0BqxSBJpVK4cOEC4vE4Dh48CLPZjN27d9MEQbKWkaaCmUwGR48exdzcXFW32/r6eqRSKWSzWQwODuLEiRP31P+pViAJpn19ffjEJz4Bq9WKnp4eGsoIhUI4d+4cxsbGcOXKFWqQ1wIk4ZQYH8ViEZFIBDMzM9RLs9Rd30mDOoVCAYvFQpv0TU9P49VXX8XU1NSyHVzXtfExvy46m82Cx+PR0ziRaV5MTIZUx/D5fOTzecTjcczMzMDhcGBmZoYqI9YCxWKRSgxnMhkoFApoNBrIZDJotVpEIpEV22SI5S6VSqkCLNFMWK7Fm8xtIBDA7OzsTd9HNhRi2WezWar5IhKJaO4Il8uFTqcDcP0+UCgUtJxzrXWDJTAMQ2PGuVwOhUKB5gURSJZ9LV/jfO8l0R8AQPOwiIbL3UBygogGBrlfSZ4Y0T9Zbc9XqVSiXbd9Ph8Ns97oWWQYhiofk/w0o9FIexzxeDwalg6Hw7TXy1plfo4H0S9paWmBwWCgZfekx4/L5YLH46FidbUCj8eDTCaDRCKhiabZbBbJZJJ6aZY6NCQQCKj+CdFGIj1y5ubmlrXyb10bH5FIBNlsFgMDAzhx4gSV/iYLr8FgwCOPPAKgOoFMKBRCLBYjGo3i6tWrGBsbw49+9CP6kNaSNDcR+fJ6vRgfH0c2m4VcLodUKkVfXx8UCgVGRkZWxKVKYqxGo3HFWreTRDm/349XX331tn+vvr4eO3bsoPXsJpMJO3bsoJ07SSKmSqXCE088gcnJSZw9exaxWGz5LmaZKJfLmJmZQTQahcPhgNlsRl1dHZ0fDoeDtrY2FAoFBINBTE9Pr/KIF4ck41ksFjQ1NdEOvcVi8ZY5XO8Gn8+npZhEgIrH46FYLMLj8cDlctVMRQQptwwGg/i7v/s7aDQadHR0gM/nw+l0UgOCdDTOZDJIpVLgcDj49Kc/jR07dtCD1fnz53Hq1ClcuXKFutfXKmKxGEqlEp2dnXj44YfR1dWF7u5u8Pl82m5iYGAAY2Nj+N73vodwOFxzXkydTod9+/ahsbGRCqCRihyPx4NAILDkxofdbkdbWxv27t2Lhx56CLFYDOPj47h27Rr6+/uXtZhiXRsfhUIBDMMgEAjA4XCgXC7TLHZyQif5CPOV/UgeQSaTgcvloj0PltrltRSQGDCx6tVqNSqVCk1MSyaTkMlkSCQS9PNYLoiK4M26MC4HhULhXfM9FiOXy9F8HrFYjFQqBbvdjmKxSD0fwPWTgcViQTabhVKphEQiWZVOl/cC8fTweDzaXp1soiQfSqlUwmAwLChbrSWI55LokgiFQtrh9EZtizuBVLcplUrIZDKqAVMulxGLxahXYH4eiVgsBo/HW9CEbbkhZZfFYhEjIyOQy+WoVCoQCASYmpqi7RTK5TICgQDy+TxkMhnkcjnVuJFIJKhUKggGg9QoXW2j6l4hCaZGoxFtbW2w2WxQKBQol8vUK+ZwOOhXrRkewPVr0Ol0dE8iOTqktf1yhIfkcjntI6PT6ZDNZqn+STweX9b7Yl0bH6QE7dSpUxgZGYFYLIZEIoFMJoNSqURfXx/NkyA6/8D1KhmXy4Xh4WH84Ac/gM/nqyn33GLkcjk4HA7apVIqlWLr1q2wWq2YmpqCw+HAxYsXl9WAIgYbce2TGHMtEggEcPLkSWp4yuVynD17Fl1dXfjzP/9zaLVayOVy8Hg8aLValMtlfOhDH8LMzAzNsVluY24lIKEotVqNurq6m7aQrwVEIhENJxLBP+B6tcbhw4cxNjZ2R3+PhB90Oh0effRRtLa2wmq1QqPR0JDsiRMnMDk5Cb/fj2w2i3K5DJFIhPe9730wm804fPjwqniKSqUSwuEwTYjmcDh0fMDvDiVcLhednZ2or69Ha2srLBYLkskkotEopqamMDIyUjP5a/eCVqtFT08Ptm7diocffhhSqRQcDgfhcBiXLl3CyMgIfvCDHyASiayZ8JJAIIDJZEI4HF620LnNZsPOnTtp92aZTEb1X5ab2twZlggS3w8EAggEAvR1Et+SSqXYsWMHJBIJfT+Js/n9fng8HkxOTtJKklqmVCohGo1SwTOhUEhP8I2NjWAYBmNjY8jlcot27r0X5vdXIbF4ospHKmBqbZPO5/NV94RQKKSLeCQSoSdsohOjUCjQ0tICHo+H8+fPI5FILJvy33JCSoxvbDJGrrdWjUXgd4mmpJMtcP2ZTSQS8Hg8d9xnhdyzMpkM9fX1sNlsNEGdnDpJ2GX+xk4qSZqbm3Hy5Mklv87bgZRDArhl80ihUAiNRgOLxQKVSgWxWIxIJIJ4PI54PL6qAolLwfwKRrPZDLPZDJPJBOC6VzSRSMDtdmN2dnbFEu/vFpK3QvJ3uFzusuXMkaoacm8QAcb56/ZyU7srzTJDFlyVSkVdzdlsFqFQCIODg/j2t78Nn8+HUChUk5vnjcTjcZw+fRput5uqF/b09MBsNuP3f//3EQqFoNfr4XQ6cfr0aYRCoSULHyiVShiNRuzcuRMf/ehHYbVaaSfS/v5+XLp0qWYSdG9GsVhELBbD5OQk/uM//gNtbW145plnqMqlQqHAvn370N7ejmvXrkEqlWJiYqIm3bc3o1QqYXR0lLZjv7H/zf2GRCKB3W7Hhg0b8N73vhcmk4m2KPD5fHC5XLhy5Qqmpqaq5pnP56Onpwe9vb146aWXVvEKbg0JUzU2NqK7uxsqlQoMw2B8fBxjY2OYnZ1FKpVacwb0fHp7e7F37140Nzejt7cXBoMBuVwOHo8H/f39cDgcePvtt2n5dS3C4/FozgpRHCZCaB6PB16vd8kPv/v378eDDz6ITZs2YdOmTRCLxcjn8zh+/Di++93vYnZ2dtkNkPvS+CAWJTlBEfctqXl3u924dOkSrQ6odcMDAL1RAWB6ehqlUgnt7e2QSCRobW2F2WzG9PQ0ZDIZxsfHqeuxWCyiUqnc8Y02vyRRJpPBYDCgqakJW7ZsoafSVCqFiYkJuN3ums+RIG7qWCyG4eFhqixIrlEkEsFms9FqqVAoVNNegsVgGAaRSAQ+n2+B67lWSklXCnL4MBgMMJvNaGpqqqqKIJUzgUCAtqUncLlc6PV6WCwWiMXi1bqEd4V4IjUaDW2kRu4Bl8tF+zCtRchzaTab0dfXh/r6enR2dtJu45FIBGNjY1QUspaVW4lHj1TekdJ/kt+Tz+dpNdZSXAOHw0FDQwN2795Nu70TrZzZ2VmcOHFiRcQz19bquURs3LgRH/jAB9DZ2Qm73U6bxTkcDrz00kuYmJhAPB5fdfXSO6FcLlMNhx//+MfQarUYGBhAXV0dnnzySahUKuzZswebN2/Gli1bEIvFcObMGXi9XgwNDSEUCiGVSt1yMSJVQiR3RqvVwmQyobe3Fw8//DAVZQuHw+jv78e1a9fws5/9DKFQqGZq6e9nKpUKAoEAbao1XwmWLG7EHbtSrtfVgDSMbGtrwx/+4R/CbrdXJdqmUimcOnUK09PTCIVCKybSt5TweDw0NTXBZDKhr6+PVr7l83lMTU2hv78fwWBwtYd511gsFthsNvT29qK7u5smakajUczMzGBwcBBnzpxBMBhEOByuae/1jW0pxGIxrFYrpFIpNmzYAKVSiUOHDsHlcuH8+fP3VLkokUggkUhQV1eH1tZWKBQKcDgczMzM4OrVqxgYGKgKMS4n95XxQaxlq9WKXbt20cSaUqmEXC6HcDiMq1evwuPxrHgW+71SqVSQy+WQy+UQjUapWExTUxMefPBBKBQKNDQ0gMvlor29nZ4EpqamaAiGeEHmK90R5ud0kBbspOSxt7cX+/bto1Z7NpvF9PQ0xsbGcPXq1TUdU15PzNf7uLH78fyeQKQVwVrZcO9EmZR4sTQaDWw2G3bs2AGdTgeBQEDveVLOOj09jXQ6XfP5XotB9GpI40Wr1UorJ0KhENxu95pVNOVwOFCr1aivr6f9akifGhIy83g8mJ2dpfLgtWp4AKAVW/l8nibsMwwDoVBI81c6OjogFAoxMDCwIMfnxrV6McjzIZFIIJfLodFoaJ8bUvk0PDyMubm5FZOSuK+Mj+bmZnR2dmL37t1obW2lGdGTk5N44403MDY2hmvXrq35mncA9IQTi8Xwgx/8AA0NDXjiiSeohoFUKsXu3bvR3d2Nnp4eGm6KxWIYHByEx+OhEvJEpn3Dhg1ob2+H2WymangKhYLmeOTzeUQiEQwNDeGVV16B2+1ekws3cGuly/UYotBoNDRE19XVBY/HA7/fv9rDui3q6uqwc+dOAIDD4bjp+5RKJex2OywWC7Zv347m5mbo9XrIZDJwuVxks1lMTU1hdnYWV65coYmmaxHS26WrqwsqlQqVSgVDQ0Nwu90YGxujGiBrDavVCpPJhN27d9NcD51Oh2QyieHhYQwODuKNN96Ay+WC3+9f0xVpxFCWSqUwGo0ol8vYtWsX0ul0VWg7l8thdHT0ppWMHA4Hzc3NMJlM2L59Ozo6OrBlyxZUKhWakzc8PIxLly4hEAis2Od1XxkfxAXZ1tYGk8lENxGfz4djx47B7XbD7XavKY/HzSiVSggEAkgmkzh16hRcLhd27doFlUpFO4G2traCYRi0tbUhl8thamoKwWCQKjoSrQ61Wg2FQoENGzZgz549qK+vR1NTE/23hEIhhEIh0uk0IpEInE4nLl++jEQisSpG3Hzj4G77e9z4d9YzHA6HCtOZTCbYbDbaUrtWmT+vOp0Ora2tmJqaApfLvemcy2Qy2O12NDY2YvPmzbBarVAqlTTGXigU4Ha74XA4MDs7C5/Pd9MwZK1vaDweDxaLBQ0NDZBKpahUKvB4PBgZGaFt0tciGo2GJtBu374dKpUKcrmc5rGMj4/jwoULiMViSCQSNT9PNzLf60y8zaRrd7FYpGKARGAvFArRnmO3Mj5MJhPa29uxd+9e7Nq1C2KxGJVKBVNTU3jrrbfgcDgwOTm5oofF+8L4IE3Wuru7sX//fthsNjAMg2AwCIfDgcuXL2NsbGzdtFCfT7FYhMPhQCQSwTe/+U1YLBbs2bMHer2elsUaDAZIJBI0NDRQSfFHH32UtlQm4RSbzQar1QqFQgGxWIxSqURVMcPhMMbHx2l3zGg0uio5M21tbWhqaqIlanNzc3A4HDSmejPUajU6OjpgMBiwefNmNDQ0UFc8cP1z9Hq9tA03MdLWGxaLBd3d3QgEApiZmbktl+5KQU7qTqcT4+PjMBgMtFRw8+bN1HNzs/HqdDq0t7dDpVLBbrdDJpNV6Sek02lcvnwZ09PTSCQSN71/iWKsRCKpOeFBEm7R6XTYsGEDent7oVQqqeQAqXBZa5BuzHv27MHOnTvR0dFBpQTi8ThGR0fxyiuvYGpqCn6/f03l6xHcbje+//3vo6urCxqNhn5JpVL09vYim82iq6sLhUIBmUwG8Xgcv/zlL+FyuRZ4sUibgPr6euh0OjzxxBPYsmULVQYuFovIZDJUHZq0DFnJ/e++MD7EYjFtJLZt2zZa3RKNRjEyMoKJiQnMzs7WdFLS3VIqleDz+WgvCLVaDaFQiKamJkilUmpVk6Z7XC4XLS0t9Pdv9XmQKploNIqJiQlcuHABv/rVr5BKpVZtUbbb7di5cyckEgmkUimuXr2KRCIBDodzS+NDLpdjw4YNMJvN2LhxIwwGA819AFAVSyZdMddqSIlArm2+p0en06GxsRFqtZpm19fKM0E0agKBAFwuF32udTodFAoFTCYTNm7ceNPfV6lUVWKCBHJ9uVwO4+PjmJmZuWXyNWnUJxaLa67UmsvlQq1W087cRJuGlJJ7vd41GUrSarWor6/Hxo0bsWfPHmi1WiiVSqrE6XA4cOrUKYTD4TUrmhYMBnH48GH4/X68733vA5fLpdosra2t9H3EQ0e0bdxu94K8OpKfR7zUDzzwAPbu3Ut/Tio5SZLrapRcr2vjg4i2tLW1YcuWLejo6Kjq5plKpTA7O4tgMIhyubwuwi03gySkxmIxHD16lDYR4vP5OH78OJRKJerq6qjkOBG24XK5sFqt0Ov11IhJpVJIpVKIRCLw+/2IRqPw+XyYm5ujMu6rhVarRVNTE/R6Pe3V0dnZiUwmg0QiQSWlSa4Kaayk1WrR3d1NPweZTAY+n49KpYJ0Oo1AIIBXXnkFDocDLperJvp83CkMwyAej0MkElGhKdL8j2A0GlEqlVBXVweNRoN0Ol0zGyzp3Do+Pg65XA6JRIL6+nqqZ6FSqaqu5UZEItGiobRMJoPZ2VlMTk5ienoac3Nzt/RqFYtFnDhxAoODg/B6vUtybUuFQCDAxo0b0dLSAo1GA+C6pygSiWBkZATj4+M1561ZDJL8vHHjRtTX16O3txctLS3U41EqleD1enHp0iWcPHkSo6Oja0KJ+laQJO9kMomBgQEkk0lYLJYFPbJKpRJmZ2fh8XgglUphsVig1WrB4XDQ0tIClUpFvdNdXV0wm81obGwEcP3AnUqlcPHiRQwNDeHs2bMIh8OrUhSwro0PUj/d1NSEffv2obW1taqZViqVgtvtRigUqqlmccsF6YNy4sSJqtflcjnEYjGNgysUCkgkEvD5fPB4PGzevBkAMDw8jOHhYQQCAfj9frhcLkxNTdEs+lpArVajoaEB9fX1aGhoQGdnJ5LJJEqlEhXZeuedd6irXiqVQq1WQywWQ61W05bcRHa8UCjQrpKvv/46dcmvNcMD+J0aKJ/PRywWQzwepx1iCaS/i9VqhVqtRrlcrinjg8Sp8/k8Nm7cWFWlIxQKqVLjYizm8SCy5OPj4xgfH8fs7CxdD25GsVjEmTNnluy6lhKBQIANGzZgw4YNVCLb7XbTUNXExMSaCC2Tk/umTZvwwAMPYNu2bejs7ASPxwOHw4Hf74ff78epU6fw7W9/u6bWoHuBYRiaPFsul7Fnz54F7ykWizQ/USKRwGg00kPU/v37YbfbabjGbrdXSaXHYjH4fD6cPHkSr732GpXoXw3WtfGhUCigUqnQ2NiIzs5OGAwGAKCnYK/XC6/Xi1gstu4Nj1tBMsJnZmYQDoep54NI/TocDur58Pv9SKfTSCaTVAullsIPw8PD+NWvfoWenh5s3LiRVuQIBALI5XI0NzcDuF75QDwfxNAiXrH5m1Q+n8f09DQ1OnK53JpYvBeDlNpyOBxMTU1Bq9Wit7cXUqmUNq4aHR2lUtSkK3StEY1GAQBDQ0O03LKuru6OE4SJYeV2u/HWW29hdnaWGqprbT3g8XgwGo0wGAxobGxEfX09TSp0u90YHR1FPB6vqRye+fD5fHC5XBoKfvDBB9He3o5NmzahsbERGo0GxWIRyWQS+Xwep06dot6nWluD7pV0Oo3h4WFkMhm0tLTAbDZjw4YNVNBOJBJhw4YNNHk6l8vREvmWlhao1WoqnikQCFAsFmkuzNWrVzE5OYmBgQFEIpFVrXha18aHSqWiYio9PT0Aqj0e5GutxgiXCuIRmZycXO2h3DNXr17FxMQE9uzZg1QqhZaWFnR3d0MqlUKr1UKr1aK9vf2mv3/jBpbL5TA2Nobp6WnEYrGa3IxvF4ZhkEqlkM/nqcy63W6H1WqlnSwHBwdx8eJFDA8PIxQKrfaQFyUSiSAWi+HKlSuQyWTYs2cP6urqbvr+G3NbCCQPwuFw4De/+Q2V4K7Fzfnd4PP5sNlssNlsaG1tRXNzMyQSCcrlMhwOB65du4ZoNFqzhjMx/rVaLVQqFZ5++mk89thj9EBAOrtGIhFEo1EcOXIE3/72t1d72MtCKpXC1atX4ff7oVar0dLSgubm5irjg3ij341isYhCoYDBwUFcuXIFx44dw5UrV2qiL9W6Nj4ymQxCoRBisRhSqRR1zzqdTpw6dYoqe6bT6TW54LAspFgsUpEzLpcLp9MJl8sFuVwOtVoNtVoNi8UCuVwOvV5PmzgRIpEILl26RLPlo9Eozp49u6gk+VqlUqnQvjSZTAYWiwWZTAaFQgHDw8NwOp01a3gAoBso6eKcTCbhdDphtVphs9loj4wbS6aj0SitfCKKvqTpGEm4W4vrAJfLhVgsRkdHB5WJF4lE8Pv9iMfjmJqawszMTM2Ez26Ex+Ohq6sLRqMRnZ2dMJvNaG5uBp/PR7lcRqlUwrVr1zA1NYW5uTn4fD4MDQ2t9rCXjUqlQlt9XL16FXNzc1Rv6U4huYxDQ0NwuVzw+Xw1o168ro2PeDyObDaLYDCIaDQKoVAIsViM0dFRvPzyyzRJci0uOCyLQ7w4AwMDGBwcpLoVRNmvo6MDe/fuhc1mo6V6wO/i/16vF9///vdph9RUKkVdoOvF+CiXy7h06RIuX76MV199tepn5Fmo5WeCdN4cGhrCyMgIzp8/D6PRiD179uDRRx9FS0tL1dwSAoEAjh49Cq/Xi8HBQdpWnuQL1PI13woejweZTEbzIkjPmatXr2J2dhYDAwO4du1aTWw4iyEQCLBz50709vbi0UcfRXNzMz0UkOfu1KlTOHz4MBWBW6tzdTuQzupk7wKAX/ziF/f0N2vxuV7Xxgdp5z44OIif//zntLrjypUr9FRQS5PBsrQwDINMJoNgMEgNz1KphGKxCK1Wi8HBwQWeD4/Hg+npadr7hGxM6ymmTKjV+P/tQoyQdDqNUCiEkZERcDgcDA0N4dKlSwve7/P5cPnyZcTjcXg8HrqxrcUcD4JAIEB9fT2sVivq6+thsVhok7CBgQGMj48jEonQtgm1BI/HQ2NjI3Q6HTo7O9Ha2ko7unq9XsTjcfh8PqqaTFSXa9WIWg5q0WhYKta18UEqHF577TW8+eab9HWSNb8eJ5SlmkQiUaXvMTQ0hLfffhvA4gqmpNxt/r3B3ie1CZmXeDyORCKBubk5HD9+HMDN1Wnn9y6a/zfWKmKxGH19fWhubkZfXx+sViuVFj98+DAuX76MaDRak9cpFAqxa9cutLe3Y9++fWhpaYFIJEKlUqFlwVeuXMHMzAwmJibgcrlq8jpY7o51bXwQ7qZlPMv64UZDgr0X1h/EoLjf5nZ+qTFpUDY5OUlLhjOZzKonFt6McrkMt9uNSqUCuVyOoaEh8PnXt6Rr165hbm4OMzMz8Pv9SKVSrOGxzrgvjA8WFhaW9Qrx8pRKJSQSCbz++uu4du0aLQ+vVQqFAk6ePAkul4uXX365qq8SSYq80VPFsn7gvvtbqvF4PPiDP/gD6HQ6SCQSbNy4ERcvXqQ/ZxgGX/rSl2CxWCCRSHDgwAFMTEws6aBZWFhYWECVPqenp3HixAm8/fbbVf1Nap1yuYxisYhcLodsNotMJoNMJoN8Pk8bXLIh8vXJHXk+otEo9uzZg0ceeQSHDx+GwWDAxMQElfEFgH/6p3/CP//zP+P73/8+mpqa8Ld/+7c4dOgQhoeHaZ0yCwsLC8u9k8lkcObMGXC5XBw+fBgcDge5XK5myilZWG7GHRkf//iP/wi73Y7vfve79LX5rdUZhsHXv/51/I//8T/w5JNPAgD+/d//HSaTCb/85S/x9NNP3/EAeTwezGYzjQWuV1QqVdX3CoUC9fX1qzSalUGj0VT1LeDz+bBYLLfsz7EeIO2w53+/3udaq9VWdZAlc73eDyQ3zrVKpVr3c63T6RbMtdVqvSudirUCh8NZIO1/P8y1wWComus7gcPcgT+ru7sbhw4dgtvtxjvvvIO6ujr82Z/9GT796U8DAKanp9HS0oLLly+jr6+P/t6+ffvQ19eH//N//s+Cv5nP56vcg4lEAna7HX/9138NkUgEhmHWtKT17UJawBOIMt16hsvlQiQS0XJXdq7XL0QIi8T02blev9w415VKBfl8/r6b60KhcMsGheuBG+c6n8/jq1/9KuLx+ALD+0buyJ0wPT2Nb33rW3juuefwN3/zN7hw4QL+/M//HEKhEB//+Mfh8/kAACaTqer3TCYT/dmNvPDCC/jKV75y03+Tw+FAIpHcyTDXBUSX/36Cnev7B3au7x+4XO59OddCoXDde3HvhTtKOK1UKtiyZQv+4R/+AZs3b8ZnPvMZfPrTn8a//Mu/3PUAnn/+ecTjcfrlcrnu+m+xsLCwsLCw1D535PmwWCzo7u6ueq2rqwsvvfQSAMBsNgMA/H4/LBYLfY/f768Kw8xHJBJBJBLR70kUaC1karOwsLCwsLBch+zbt5PNcUfGx549ezA2Nlb12vj4OBoaGgBcTz41m804cuQINTYSiQTOnTuHz372s7f1bxA1yq997Wt3MjQWFhYWFhaWGiCZTC4ooriROzI+vvCFL+CBBx7AP/zDP+C//Jf/gvPnz+Pb3/42bW3M4XDwl3/5l/j7v/97tLW10VJbq9WKD37wg7f1b1itVgwPD6O7uxsul+tdk1ZYVhaSEMzOTW3Bzkvtws5NbcLOy9LDMAySySSsVuu7vveOjI/t27fj5ZdfxvPPP4//+T//J5qamvD1r38dzzzzDH3Pf//v/x3pdBqf+cxnEIvFsHfvXrz22mu3XVLH5XJRV1cH4HqZGntT1Cbs3NQm7LzULuzc1CbsvCwt7+bxINxRqe1KkUgkoFKpbqtch2VlYeemNmHnpXZh56Y2YedldbljeXUWFhYWFhYWlnuhJo0PkUiEL3/5y1VVMCy1ATs3tQk7L7ULOze1CTsvq0tNhl1YWFhYWFhY1i816flgYWFhYWFhWb+wxgcLCwsLCwvLisIaHywsLCwsLCwrCmt8sLCwsLCwsKwoNWl8vPjii2hsbIRYLMbOnTtx/vz51R7SfcXf/d3fgcPhVH11dnbSn+dyOTz77LPQ6XSQy+V46qmn4Pf7V3HE65fjx4/j/e9/P6xWKzgcDn75y19W/ZxhGHzpS1+CxWKBRCLBgQMHMDExUfWeSCSCZ555BkqlEmq1Gp/61KeQSqVW8CrWH+82L5/4xCcWPEOPPfZY1XvYeVl6XnjhBWzfvh0KhQJGoxEf/OAHF7QEuZ31y+l04n3vex+kUimMRiP+6q/+CqVSaSUvZd1Tc8bHT37yEzz33HP48pe/jEuXLmHTpk04dOgQAoHAag/tvmLDhg3wer306+TJk/RnX/jCF/Cb3/wGP/vZz/DOO+9gbm4OH/7wh1dxtOuXdDqNTZs24cUXX1z05//0T/+Ef/7nf8a//Mu/4Ny5c5DJZDh06BByuRx9zzPPPIOhoSG8+eab+O1vf4vjx4/jM5/5zEpdwrrk3eYFAB577LGqZ+hHP/pR1c/ZeVl63nnnHTz77LM4e/Ys3nzzTRSLRRw8eBDpdJq+593Wr3K5jPe9730oFAo4ffo0vv/97+N73/sevvSlL63GJa1fmBpjx44dzLPPPku/L5fLjNVqZV544YVVHNX9xZe//GVm06ZNi/4sFosxAoGA+dnPfkZfGxkZYQAwZ86cWaER3p8AYF5++WX6faVSYcxmM/O//tf/oq/FYjFGJBIxP/rRjxiGYZjh4WEGAHPhwgX6nsOHDzMcDofxeDwrNvb1zI3zwjAM8/GPf5x58sknb/o77LysDIFAgAHAvPPOOwzD3N769eqrrzJcLpfx+Xz0Pd/61rcYpVLJ5PP5lb2AdUxNeT4KhQL6+/tx4MAB+hqXy8WBAwdw5syZVRzZ/cfExASsViuam5vxzDPPwOl0AgD6+/tRLBar5qizsxP19fXsHK0wMzMz8Pl8VXOhUqmwc+dOOhdnzpyBWq3Gtm3b6HsOHDgALpeLc+fOrfiY7yeOHTsGo9GIjo4OfPazn0U4HKY/Y+dlZYjH4wAArVYL4PbWrzNnzmDjxo0wmUz0PYcOHUIikcDQ0NAKjn59U1PGRygUQrlcrpp0ADCZTPD5fKs0qvuPnTt34nvf+x5ee+01fOtb38LMzAwefPBBJJNJ+Hw+CIVCqNXqqt9h52jlIZ/3rZ4Xn88Ho9FY9XM+nw+tVsvO1zLy2GOP4d///d9x5MgR/OM//iPeeecdvPe970W5XAbAzstKUKlU8Jd/+ZfYs2cPenp6AOC21i+fz7foM0V+xrI03FFXW5b7g/e+9730/3t7e7Fz5040NDTgpz/9KSQSySqOjIVlbfD000/T/9+4cSN6e3vR0tKCY8eOYf/+/as4svuHZ599FteuXavKV2OpHWrK86HX68Hj8RZkHvv9fpjN5lUaFYtarUZ7ezsmJydhNptRKBQQi8Wq3sPO0cpDPu9bPS9ms3lBsnapVEIkEmHnawVpbm6GXq/H5OQkAHZelpvPfe5z+O1vf4u3334bNpuNvn4765fZbF70mSI/Y1kaasr4EAqF2Lp1K44cOUJfq1QqOHLkCHbv3r2KI7u/SaVSmJqagsViwdatWyEQCKrmaGxsDE6nk52jFaapqQlms7lqLhKJBM6dO0fnYvfu3YjFYujv76fvOXr0KCqVCnbu3LniY75fcbvdCIfDsFgsANh5WS4YhsHnPvc5vPzyyzh69Ciampqqfn4769fu3bsxODhYZRy++eabUCqV6O7uXpkLuR9Y7YzXG/nxj3/MiEQi5nvf+x4zPDzMfOYzn2HUanVV5jHL8vLFL36ROXbsGDMzM8OcOnWKOXDgAKPX65lAIMAwDMP86Z/+KVNfX88cPXqUuXjxIrN7925m9+7dqzzq9UkymWQuX77MXL58mQHA/O///b+Zy5cvM7OzswzDMMxXv/pVRq1WM7/61a+YgYEB5sknn2SampqYbDZL/8Zjjz3GbN68mTl37hxz8uRJpq2tjfnoRz+6Wpe0LrjVvCSTSea//bf/xpw5c4aZmZlh3nrrLWbLli1MW1sbk8vl6N9g52Xp+exnP8uoVCrm2LFjjNfrpV+ZTIa+593Wr1KpxPT09DAHDx5krly5wrz22muMwWBgnn/++dW4pHVLzRkfDMMw//f//l+mvr6eEQqFzI4dO5izZ8+u9pDuKz7ykY8wFouFEQqFTF1dHfORj3yEmZycpD/PZrPMn/3ZnzEajYaRSqXMhz70Icbr9a7iiNcvb7/9NgNgwdfHP/5xhmGul9v+7d/+LWMymRiRSMTs37+fGRsbq/ob4XCY+ehHP8rI5XJGqVQyn/zkJ5lkMrkKV7N+uNW8ZDIZ5uDBg4zBYGAEAgHT0NDAfPrTn15wgGLnZelZbE4AMN/97nfpe25n/XI4HMx73/teRiKRMHq9nvniF7/IFIvFFb6a9Q2HYRhmpb0tLCwsLCwsLPcvNZXzwcLCwsLCwrL+YY0PFhYWFhYWlhWFNT5YWFhYWFhYVhTW+GBhYWFhYWFZUVjjg4WFhYWFhWVFYY0PFhYWFhYWlhWFNT5YWFhYWFhYVhTW+GBhYWFhYWFZUVjjg4WFhYWFhWVFYY0PFhYWFhYWlhWFNT5YWFhYWFhYVhTW+GBhYWFhYWFZUf5/y8hTymrRE3EAAAAASUVORK5CYII=\n"},"metadata":{}}],"source":["def imshow(img):\n","    img = img / 2 + 0.5\n","    npimg = img.numpy()\n","    plt.imshow(np.transpose(npimg, (1, 2, 0)))\n","    plt.show()\n","\n","dataiter = iter(trainloader)\n","images, labels = next(dataiter)\n","classes = list(range(10))\n","\n","imshow(torchvision.utils.make_grid(images[:16]))"]},{"cell_type":"markdown","metadata":{"id":"pu_v8osGjt45"},"source":["\n","\n","---\n","\n","\n","##  Train the Classifier\n","\n","\n","---\n","\n"]},{"cell_type":"code","execution_count":8,"metadata":{"id":"RctbOIV0jt45","executionInfo":{"status":"ok","timestamp":1758772568615,"user_tz":240,"elapsed":294,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["model.cuda()\n","optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n","loss_fn = nn.CrossEntropyLoss()"]},{"cell_type":"code","execution_count":9,"metadata":{"id":"24lRKwDpjt45","executionInfo":{"status":"ok","timestamp":1758772569977,"user_tz":240,"elapsed":2,"user":{"displayName":"Shu Liu","userId":"06233144459630989636"}}},"outputs":[],"source":["def fit(model, trainloader, testloader, optimizer, loss_fn, epochs=10):\n","    model.train()\n","    for epoch in range(epochs):\n","        correct = 0\n","        for batch_idx, (X_batch, y_batch) in enumerate(trainloader):\n","            X_batch, Y_batch = X_batch.cuda(), y_batch.cuda()\n","            optimizer.zero_grad()\n","            output = model.forward(X_batch)\n","            loss = loss_fn(output, Y_batch)\n","            loss.backward()\n","            optimizer.step()\n","            predicted = torch.max(output.data, 1)[1]\n","            correct += (predicted == Y_batch).sum()\n","        test_accuracy(model, testloader)\n","    return model"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"O-gigslOjt45"},"outputs":[],"source":["model = fit(model, trainloader, testloader, optimizer, loss_fn)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"iC1wIPQKjt45"},"outputs":[],"source":["# @title save the trained classifier\n","\n","model.eval()\n","save_path = os.getcwd()\n","file_name = os.path.join(save_path, 'model_classifier_28_by_28_{}.pt'.format(DATASET))\n","torch.save(model.cpu().state_dict(), file_name)\n"]}],"metadata":{"accelerator":"GPU","colab":{"collapsed_sections":["_29W2X4Q-K1I"],"gpuType":"T4","provenance":[]},"kernelspec":{"display_name":"Python 3","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.7.12"}},"nbformat":4,"nbformat_minor":0}