{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "847db128-119d-4381-bd95-15991ae0a96d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "dtype = torch.float64\n",
    "torch.set_default_dtype(dtype)\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.nn import BCELoss, MSELoss, NLLLoss\n",
    "import numpy as np\n",
    "import sympy as sp\n",
    "from madgrad import MADGRAD\n",
    "from dataset.mnist_logic import *\n",
    "from library.mnist_multi_add_networks import *\n",
    "from library.utils import *\n",
    "from itertools import chain\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import confusion_matrix\n",
    "from PIL import Image\n",
    "import os\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "097bedf5-3a92-4a46-ae33-f915215f7257",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed(42)\n",
    "\n",
    "batch_size = 128\n",
    "loss_fn_supervision = BCELoss()\n",
    "loss_fn_reconstruction = MSELoss()\n",
    "epochs = 2 ** 8\n",
    "even_label_distribution = torch.full(size=(10,), fill_value=1./10.).to(device)\n",
    "noise_scales = [0.3115310029581702, 0.8485090728796351, 0.9770926024145439]\n",
    "lfl_lr = 11.331405298874264\n",
    "cnn_lr = 0.000571482276406197\n",
    "mlp_lr = 0.012437761948519307\n",
    "reconstruction_lr = 0.001\n",
    "reg_coef = 0.13687607266487536\n",
    "mlp_loss_weight = 8.473281653324152\n",
    "label_distribution_wight = 1.266068955037883\n",
    "\n",
    "def train():\n",
    "    model.train()\n",
    "    losses = {\n",
    "        'reconstruction': [],\n",
    "        'supervision': [],\n",
    "        'accuracy': [],\n",
    "        'regularization': [],\n",
    "        'mlp_supervision': [],\n",
    "        'label_distribution': [],\n",
    "    }\n",
    "    for left_images, right_images, labels, carry in dataloader:\n",
    "        left_images, right_images, labels, carry = left_images.to(device), right_images.to(device), labels.to(device), carry.to(device)\n",
    "        preds_lfl, preds_mlp, carry_lfl, carry_mlp, left_reconstructions, right_reconstructions, left_label_mean, right_label_mean = model(left_images, right_images)\n",
    "        reconstruction_loss = loss_fn_reconstruction(left_reconstructions, left_images) + loss_fn_reconstruction(right_reconstructions, right_images)\n",
    "        accuracy = np.mean([get_accuracy(preds_lfl[:, i, :], labels[:, i, :].type(dtype)) for i in range(preds_lfl.shape[1])] + [get_accuracy(carry_lfl, carry.type(dtype))])\n",
    "        preds_lfl, preds_mlp, labels = torch.flatten(preds_lfl, 1), torch.flatten(preds_mlp, 1), torch.flatten(labels, 1)\n",
    "        preds_lfl_full, preds_mlp_full, actual_full = torch.cat([preds_lfl, carry_lfl], dim=1), torch.cat([preds_mlp, carry_mlp], dim=1), torch.cat([labels, carry], dim=1)\n",
    "        supervision_loss = loss_fn_supervision(preds_lfl_full, actual_full.type(dtype))\n",
    "        # accuracy = (get_accuracy(preds_lfl, labels.type(dtype)) + get_accuracy(carry_lfl, carry.type(dtype))) / 2.\n",
    "        regularization_loss = model.lfl.reg_loss()\n",
    "        mlp_loss = loss_fn_supervision(preds_mlp_full, actual_full.type(dtype))\n",
    "        label_distribution_loss = loss_fn_supervision(left_label_mean, even_label_distribution) + loss_fn_supervision(right_label_mean, even_label_distribution)\n",
    "        \n",
    "        losses['reconstruction'].append(reconstruction_loss.item())\n",
    "        losses['supervision'].append(supervision_loss.item())\n",
    "        losses['accuracy'].append(accuracy)\n",
    "        losses['regularization'].append(regularization_loss.item())\n",
    "        losses['mlp_supervision'].append(mlp_loss.item())\n",
    "        losses['label_distribution'].append(label_distribution_loss.item())\n",
    "        loss = reconstruction_loss + supervision_loss + reg_coef * regularization_loss + mlp_loss_weight * mlp_loss + label_distribution_wight * label_distribution_loss\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "            \n",
    "    mean_loss = {k: np.mean(v) for k, v in losses.items()}\n",
    "    return mean_loss\n",
    "\n",
    "def test():\n",
    "    model.eval()\n",
    "    bceloss, accuracy = [], []\n",
    "    for left_images, right_images, labels, carry in dataloader:\n",
    "        left_images, right_images, labels, carry = left_images.to(device), right_images.to(device), labels.to(device), carry.to(device)\n",
    "        preds_lfl, preds_mlp, carry_lfl, carry_mlp, left_reconstructions, right_reconstructions, left_label_mean, right_label_mean = model(left_images, right_images)\n",
    "        accuracy_ = np.mean([get_accuracy(preds_lfl[:, i, :], labels[:, i, :].type(dtype)) for i in range(preds_lfl.shape[1])] + [get_accuracy(carry_lfl, carry.type(dtype))])\n",
    "        preds, labels = torch.flatten(preds_lfl, 1), torch.flatten(labels, 1)\n",
    "        preds_full, actual_full = torch.cat([preds, carry_lfl], dim=1), torch.cat([labels, carry], dim=1)\n",
    "        bceloss_ = loss_fn_supervision(preds_full, actual_full.type(dtype))\n",
    "        # accuracy_ = (get_accuracy(preds, labels.type(dtype)) + get_accuracy(carry_lfl, carry.type(dtype))) / 2.\n",
    "        bceloss.append(bceloss_.detach().cpu().numpy()), accuracy.append(accuracy_)\n",
    "    bceloss, accuracy = np.mean(bceloss), np.mean(accuracy)\n",
    "    return bceloss, accuracy\n",
    "\n",
    "def test_cnn():\n",
    "    pred, label = [], []\n",
    "    for image, label_ in dataloader:\n",
    "        image, label_ = image.to(device), label_.to(device)\n",
    "        pred_ = model.cnn(image)\n",
    "        pred.append(pred_)\n",
    "        label.append(label_)\n",
    "    pred = torch.argmax(torch.cat(pred, dim=0), dim=1, keepdim=False).detach().cpu().numpy()\n",
    "    label = torch.cat(label, dim=0).detach().cpu().numpy()\n",
    "    return pred, label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "78ae8357-2703-44e7-af0e-2d6e2d22c9a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch: 0 mean_loss: {'reconstruction': 0.27428482812735494, 'supervision': 0.5957342799166854, 'accuracy': 0.236572265625, 'regularization': 0.770854212726912, 'mlp_supervision': 0.3783710700021438, 'label_distribution': 0.6502660809487013}\n",
      "epoch: 1 mean_loss: {'reconstruction': 0.21869176535057405, 'supervision': 0.5209583002393982, 'accuracy': 0.234375, 'regularization': 0.48769152012535427, 'mlp_supervision': 0.3601171930642606, 'label_distribution': 0.6503555789153292}\n",
      "epoch: 2 mean_loss: {'reconstruction': 0.18450689209827503, 'supervision': 0.4414627682149023, 'accuracy': 0.2349853515625, 'regularization': 0.4339396657914034, 'mlp_supervision': 0.34402290180077305, 'label_distribution': 0.6510622467718741}\n",
      "epoch: 3 mean_loss: {'reconstruction': 0.16375506505341908, 'supervision': 0.4232317593709721, 'accuracy': 0.229736328125, 'regularization': 0.4150435229189617, 'mlp_supervision': 0.329892420728334, 'label_distribution': 0.6511048132940548}\n",
      "epoch: 4 mean_loss: {'reconstruction': 0.1536285577437652, 'supervision': 0.4165538955148541, 'accuracy': 0.24104817708333331, 'regularization': 0.4026876807585769, 'mlp_supervision': 0.3023734584482486, 'label_distribution': 0.6537697727762717}\n",
      "epoch: 5 mean_loss: {'reconstruction': 0.15356795580130428, 'supervision': 0.4162264753091186, 'accuracy': 0.2657877604166667, 'regularization': 0.39497365216350244, 'mlp_supervision': 0.24614889008074653, 'label_distribution': 0.6569711716996194}\n",
      "epoch: 6 mean_loss: {'reconstruction': 0.15703985662423797, 'supervision': 0.38427812083119184, 'accuracy': 0.35078938802083337, 'regularization': 0.39067477718170174, 'mlp_supervision': 0.17518863860789163, 'label_distribution': 0.6581535472011453}\n",
      "epoch: 7 mean_loss: {'reconstruction': 0.1541148771879281, 'supervision': 0.3284161723321901, 'accuracy': 0.49873860677083337, 'regularization': 0.386921293512048, 'mlp_supervision': 0.09630349393147959, 'label_distribution': 0.6550241858859156}\n",
      "epoch: 8 mean_loss: {'reconstruction': 0.14490968661293985, 'supervision': 0.2521776354937081, 'accuracy': 0.6995849609375, 'regularization': 0.3812937957066842, 'mlp_supervision': 0.06320100574594505, 'label_distribution': 0.654251213520026}\n",
      "epoch: 9 mean_loss: {'reconstruction': 0.13631174039638283, 'supervision': 0.18956624130623828, 'accuracy': 0.8156331380208334, 'regularization': 0.3742186664159043, 'mlp_supervision': 0.049429485975410206, 'label_distribution': 0.6540873484586658}\n",
      "epoch: 10 mean_loss: {'reconstruction': 0.1298288594026742, 'supervision': 0.1497968846856735, 'accuracy': 0.8650309244791666, 'regularization': 0.3660521080277256, 'mlp_supervision': 0.04598153980623476, 'label_distribution': 0.6544582107903253}\n",
      "epoch: 11 mean_loss: {'reconstruction': 0.12413082646806874, 'supervision': 0.11459730067340648, 'accuracy': 0.9112141927083333, 'regularization': 0.35731349678780316, 'mlp_supervision': 0.03620853672322848, 'label_distribution': 0.6542512611578644}\n",
      "epoch: 12 mean_loss: {'reconstruction': 0.12039297003090002, 'supervision': 0.09534742811008129, 'accuracy': 0.9315185546875, 'regularization': 0.34847667428969753, 'mlp_supervision': 0.03683647288738074, 'label_distribution': 0.6539108314768443}\n",
      "epoch: 13 mean_loss: {'reconstruction': 0.11719670149814565, 'supervision': 0.0780122055723226, 'accuracy': 0.94775390625, 'regularization': 0.3398144730693575, 'mlp_supervision': 0.03268479308998373, 'label_distribution': 0.6539091999343969}\n",
      "epoch: 14 mean_loss: {'reconstruction': 0.11430213734046984, 'supervision': 0.06718223471736154, 'accuracy': 0.9569091796875, 'regularization': 0.33143429871104446, 'mlp_supervision': 0.0314325880339482, 'label_distribution': 0.6542064167037531}\n",
      "epoch: 15 mean_loss: {'reconstruction': 0.11279509952572436, 'supervision': 0.060772627634577414, 'accuracy': 0.9618733723958334, 'regularization': 0.32341212206863473, 'mlp_supervision': 0.028814797791008054, 'label_distribution': 0.6542968739214315}\n",
      "epoch: 16 mean_loss: {'reconstruction': 0.1115485791896802, 'supervision': 0.05294075471034172, 'accuracy': 0.9674886067708334, 'regularization': 0.31601011569889603, 'mlp_supervision': 0.027746879074330096, 'label_distribution': 0.6540319086983012}\n",
      "epoch: 17 mean_loss: {'reconstruction': 0.110473014887394, 'supervision': 0.045632716913005675, 'accuracy': 0.9737548828125, 'regularization': 0.30901659183451446, 'mlp_supervision': 0.024772660052751208, 'label_distribution': 0.6541109356226406}\n",
      "epoch: 18 mean_loss: {'reconstruction': 0.10936001988764314, 'supervision': 0.04318722942176364, 'accuracy': 0.9747314453125, 'regularization': 0.30259845354036374, 'mlp_supervision': 0.024507884007530737, 'label_distribution': 0.6541203122676947}\n",
      "epoch: 19 mean_loss: {'reconstruction': 0.1088223631344378, 'supervision': 0.04199361569112672, 'accuracy': 0.9750569661458333, 'regularization': 0.29665894986321406, 'mlp_supervision': 0.0238545237810716, 'label_distribution': 0.6540879217586435}\n",
      "epoch: 20 mean_loss: {'reconstruction': 0.1085043610503037, 'supervision': 0.04004246693692598, 'accuracy': 0.9761149088541666, 'regularization': 0.29109256138445105, 'mlp_supervision': 0.023473623497131606, 'label_distribution': 0.6543108211866496}\n",
      "epoch: 21 mean_loss: {'reconstruction': 0.10788074392885244, 'supervision': 0.03546905303884067, 'accuracy': 0.9794514973958333, 'regularization': 0.2860133400616221, 'mlp_supervision': 0.02015500268470681, 'label_distribution': 0.6544093127535182}\n",
      "epoch: 22 mean_loss: {'reconstruction': 0.1076833931164117, 'supervision': 0.03356047111478398, 'accuracy': 0.9806315104166667, 'regularization': 0.2813380013721437, 'mlp_supervision': 0.019747946872530633, 'label_distribution': 0.6543289837312526}\n",
      "epoch: 23 mean_loss: {'reconstruction': 0.1074920754796919, 'supervision': 0.031157213041863967, 'accuracy': 0.9815266927083334, 'regularization': 0.2770455826604701, 'mlp_supervision': 0.018467840876228145, 'label_distribution': 0.6540588306482863}\n",
      "epoch: 24 mean_loss: {'reconstruction': 0.10716062086369083, 'supervision': 0.02861402452910456, 'accuracy': 0.9834391276041667, 'regularization': 0.27313168859231096, 'mlp_supervision': 0.016500599930596646, 'label_distribution': 0.6540672864315633}\n",
      "epoch: 25 mean_loss: {'reconstruction': 0.10721306874896772, 'supervision': 0.029437058722706598, 'accuracy': 0.98291015625, 'regularization': 0.26948633335880545, 'mlp_supervision': 0.01821374857577867, 'label_distribution': 0.653895637966101}\n",
      "epoch: 26 mean_loss: {'reconstruction': 0.10711447067245149, 'supervision': 0.027273665582742176, 'accuracy': 0.9831949869791667, 'regularization': 0.266145221797535, 'mlp_supervision': 0.017610102910537488, 'label_distribution': 0.6540035656668587}\n",
      "epoch: 27 mean_loss: {'reconstruction': 0.10698492385310515, 'supervision': 0.02659561769920108, 'accuracy': 0.98486328125, 'regularization': 0.2630449327050157, 'mlp_supervision': 0.016081830016869303, 'label_distribution': 0.6539865430799217}\n",
      "epoch: 28 mean_loss: {'reconstruction': 0.10686892641754688, 'supervision': 0.028110418928953298, 'accuracy': 0.9825032552083334, 'regularization': 0.2601988412485657, 'mlp_supervision': 0.018780577678159802, 'label_distribution': 0.654092618153707}\n",
      "epoch: 29 mean_loss: {'reconstruction': 0.10691945168297917, 'supervision': 0.024401598725709087, 'accuracy': 0.9860432942708333, 'regularization': 0.25761893812135195, 'mlp_supervision': 0.0164727519368207, 'label_distribution': 0.6541769911719606}\n",
      "epoch: 30 mean_loss: {'reconstruction': 0.10698711127184388, 'supervision': 0.024130306578602493, 'accuracy': 0.9860026041666667, 'regularization': 0.2552284875015687, 'mlp_supervision': 0.01610963493342657, 'label_distribution': 0.6541624005633171}\n",
      "epoch: 31 mean_loss: {'reconstruction': 0.10706228962852246, 'supervision': 0.02356311313828192, 'accuracy': 0.986328125, 'regularization': 0.25301016505364476, 'mlp_supervision': 0.015107369598421929, 'label_distribution': 0.6540988479046028}\n",
      "epoch: 32 mean_loss: {'reconstruction': 0.10701743400039582, 'supervision': 0.022689541945152075, 'accuracy': 0.9886881510416666, 'regularization': 0.25097419984318076, 'mlp_supervision': 0.013445265484919935, 'label_distribution': 0.6540640547062349}\n",
      "epoch: 33 mean_loss: {'reconstruction': 0.107172421320091, 'supervision': 0.021826407279844966, 'accuracy': 0.9861246744791666, 'regularization': 0.2490770998419422, 'mlp_supervision': 0.01562512221852798, 'label_distribution': 0.6543761884528176}\n",
      "epoch: 34 mean_loss: {'reconstruction': 0.10678283896408576, 'supervision': 0.022663204829177795, 'accuracy': 0.9857177734375, 'regularization': 0.24730444575236563, 'mlp_supervision': 0.015120747809768709, 'label_distribution': 0.6540754171097578}\n",
      "epoch: 35 mean_loss: {'reconstruction': 0.10760870522892799, 'supervision': 0.022064876261091555, 'accuracy': 0.9860432942708334, 'regularization': 0.2456329877643244, 'mlp_supervision': 0.016980159661349564, 'label_distribution': 0.6542285279037834}\n",
      "epoch: 36 mean_loss: {'reconstruction': 0.10716163692619607, 'supervision': 0.01967035684057217, 'accuracy': 0.9888916015625, 'regularization': 0.2441060327938407, 'mlp_supervision': 0.013098937546549966, 'label_distribution': 0.6540031417459564}\n",
      "epoch: 37 mean_loss: {'reconstruction': 0.1073123413559795, 'supervision': 0.017738953981318525, 'accuracy': 0.9903564453125, 'regularization': 0.24265675523063726, 'mlp_supervision': 0.011179776477929042, 'label_distribution': 0.6541422335814793}\n",
      "epoch: 38 mean_loss: {'reconstruction': 0.10687193211144758, 'supervision': 0.019325661722847054, 'accuracy': 0.9878336588541666, 'regularization': 0.241349347422766, 'mlp_supervision': 0.013016427988957583, 'label_distribution': 0.6540650406213748}\n",
      "epoch: 39 mean_loss: {'reconstruction': 0.1068883273441491, 'supervision': 0.017345939552160475, 'accuracy': 0.9903157552083334, 'regularization': 0.24007343706037432, 'mlp_supervision': 0.01042783779357059, 'label_distribution': 0.6540275278816721}\n",
      "epoch: 40 mean_loss: {'reconstruction': 0.10726018174946247, 'supervision': 0.017796108301432925, 'accuracy': 0.9886881510416667, 'regularization': 0.23886281315119048, 'mlp_supervision': 0.012767079970231545, 'label_distribution': 0.6540080421779754}\n",
      "epoch: 41 mean_loss: {'reconstruction': 0.10701429165929034, 'supervision': 0.01666548259877037, 'accuracy': 0.9890543619791666, 'regularization': 0.23771945832925045, 'mlp_supervision': 0.012280945551161302, 'label_distribution': 0.6540087181062395}\n",
      "epoch: 42 mean_loss: {'reconstruction': 0.10701021573526254, 'supervision': 0.016524438987760622, 'accuracy': 0.9897054036458333, 'regularization': 0.2366144173265811, 'mlp_supervision': 0.010867344549921307, 'label_distribution': 0.6540808038525529}\n",
      "epoch: 43 mean_loss: {'reconstruction': 0.107445857379866, 'supervision': 0.016740038242614705, 'accuracy': 0.9901529947916666, 'regularization': 0.23558838382416042, 'mlp_supervision': 0.011362118031926351, 'label_distribution': 0.6541787433689025}\n",
      "epoch: 44 mean_loss: {'reconstruction': 0.10684461106672463, 'supervision': 0.015153836349720022, 'accuracy': 0.99072265625, 'regularization': 0.234654641373196, 'mlp_supervision': 0.010038171471176673, 'label_distribution': 0.6538756553186862}\n",
      "epoch: 45 mean_loss: {'reconstruction': 0.10736301386517375, 'supervision': 0.015221329285549394, 'accuracy': 0.9911702473958334, 'regularization': 0.2337513693419484, 'mlp_supervision': 0.010872768632030495, 'label_distribution': 0.6539620348554263}\n",
      "epoch: 46 mean_loss: {'reconstruction': 0.10701363498976887, 'supervision': 0.013385434265205826, 'accuracy': 0.9925537109375, 'regularization': 0.23290524160133197, 'mlp_supervision': 0.008752838367239946, 'label_distribution': 0.6538905137667674}\n",
      "epoch: 47 mean_loss: {'reconstruction': 0.10740336931347047, 'supervision': 0.01397876319303731, 'accuracy': 0.9906819661458334, 'regularization': 0.23208509138309524, 'mlp_supervision': 0.01030801534159578, 'label_distribution': 0.6538714585515153}\n",
      "epoch: 48 mean_loss: {'reconstruction': 0.10705792958828164, 'supervision': 0.012872405224011077, 'accuracy': 0.9927978515625, 'regularization': 0.2313035903454692, 'mlp_supervision': 0.00875722174859043, 'label_distribution': 0.6538706952906097}\n",
      "epoch: 49 mean_loss: {'reconstruction': 0.1070868031877627, 'supervision': 0.014326731725103747, 'accuracy': 0.990478515625, 'regularization': 0.230571276894336, 'mlp_supervision': 0.012404042541731644, 'label_distribution': 0.6540137724000641}\n",
      "epoch: 50 mean_loss: {'reconstruction': 0.10751311493362505, 'supervision': 0.01182856163297354, 'accuracy': 0.9913736979166667, 'regularization': 0.2298559128063644, 'mlp_supervision': 0.009501397536149748, 'label_distribution': 0.6539727325165379}\n",
      "epoch: 51 mean_loss: {'reconstruction': 0.10726520629019677, 'supervision': 0.011440511470814027, 'accuracy': 0.9921061197916666, 'regularization': 0.22919320744007415, 'mlp_supervision': 0.009119477879178595, 'label_distribution': 0.6540982975294336}\n",
      "epoch: 52 mean_loss: {'reconstruction': 0.107371783151714, 'supervision': 0.014435885353751059, 'accuracy': 0.9886881510416666, 'regularization': 0.22858093673291432, 'mlp_supervision': 0.013762579381727032, 'label_distribution': 0.6539377668465678}\n",
      "epoch: 53 mean_loss: {'reconstruction': 0.10689335506019665, 'supervision': 0.011757220646269852, 'accuracy': 0.9915364583333334, 'regularization': 0.22796908016227643, 'mlp_supervision': 0.009913205475471643, 'label_distribution': 0.6541477103152821}\n",
      "epoch: 54 mean_loss: {'reconstruction': 0.10731584019882989, 'supervision': 0.010639009797470272, 'accuracy': 0.9927571614583333, 'regularization': 0.2273504734701502, 'mlp_supervision': 0.009062309251346039, 'label_distribution': 0.6540177523917512}\n",
      "epoch: 55 mean_loss: {'reconstruction': 0.1072580440820854, 'supervision': 0.010526240832479059, 'accuracy': 0.9930826822916666, 'regularization': 0.22679558551657455, 'mlp_supervision': 0.008318212309937966, 'label_distribution': 0.6542572278654855}\n",
      "epoch: 56 mean_loss: {'reconstruction': 0.10708922508757548, 'supervision': 0.011070381780018141, 'accuracy': 0.9919026692708333, 'regularization': 0.22624959985754478, 'mlp_supervision': 0.009902822078116064, 'label_distribution': 0.6541948408130118}\n",
      "epoch: 57 mean_loss: {'reconstruction': 0.1071262936612961, 'supervision': 0.011240551150413065, 'accuracy': 0.9916178385416666, 'regularization': 0.22575404601811266, 'mlp_supervision': 0.010287975020154331, 'label_distribution': 0.6541974972248439}\n",
      "epoch: 58 mean_loss: {'reconstruction': 0.10691464790138694, 'supervision': 0.01086035529270335, 'accuracy': 0.9925944010416667, 'regularization': 0.22525323292214533, 'mlp_supervision': 0.008971179934979824, 'label_distribution': 0.6541564382192474}\n",
      "epoch: 59 mean_loss: {'reconstruction': 0.10708029678263278, 'supervision': 0.009849140628209808, 'accuracy': 0.994140625, 'regularization': 0.22475693891711232, 'mlp_supervision': 0.0077150429466028006, 'label_distribution': 0.6539872493980374}\n",
      "epoch: 60 mean_loss: {'reconstruction': 0.10747383050334654, 'supervision': 0.009920571765541768, 'accuracy': 0.9924723307291666, 'regularization': 0.22428094330741344, 'mlp_supervision': 0.00871216927557303, 'label_distribution': 0.6537265580559921}\n",
      "epoch: 61 mean_loss: {'reconstruction': 0.10709990338931136, 'supervision': 0.009620715838827605, 'accuracy': 0.9928792317708333, 'regularization': 0.22384559823078853, 'mlp_supervision': 0.008125428830951308, 'label_distribution': 0.6542939388234053}\n",
      "epoch: 62 mean_loss: {'reconstruction': 0.1070529261599642, 'supervision': 0.010900174132641608, 'accuracy': 0.990966796875, 'regularization': 0.22342621315759068, 'mlp_supervision': 0.010348277667706251, 'label_distribution': 0.6540088086174465}\n",
      "epoch: 63 mean_loss: {'reconstruction': 0.10737112796239827, 'supervision': 0.010126326434788918, 'accuracy': 0.9921061197916666, 'regularization': 0.22301765927204042, 'mlp_supervision': 0.008969512164661474, 'label_distribution': 0.6542758414211881}\n",
      "epoch: 64 mean_loss: {'reconstruction': 0.10702930271358091, 'supervision': 0.008907390399470999, 'accuracy': 0.9940999348958333, 'regularization': 0.22263233261904453, 'mlp_supervision': 0.006717798428270649, 'label_distribution': 0.6542385235011914}\n",
      "epoch: 65 mean_loss: {'reconstruction': 0.10696709335553951, 'supervision': 0.009553854340988852, 'accuracy': 0.9938151041666666, 'regularization': 0.22224848535052855, 'mlp_supervision': 0.008169550225044073, 'label_distribution': 0.6542531054097668}\n",
      "epoch: 66 mean_loss: {'reconstruction': 0.10719002321255608, 'supervision': 0.007898612820085232, 'accuracy': 0.9954833984375, 'regularization': 0.2218548444657133, 'mlp_supervision': 0.006092375559164899, 'label_distribution': 0.6544597894698675}\n",
      "epoch: 67 mean_loss: {'reconstruction': 0.10740109767972217, 'supervision': 0.01028371725498039, 'accuracy': 0.9917399088541667, 'regularization': 0.22150502710891032, 'mlp_supervision': 0.009602281119980124, 'label_distribution': 0.6541062087735272}\n",
      "epoch: 68 mean_loss: {'reconstruction': 0.10729489054718659, 'supervision': 0.009129779325789391, 'accuracy': 0.9934488932291666, 'regularization': 0.22115784472812164, 'mlp_supervision': 0.00745562263980356, 'label_distribution': 0.654123498513291}\n",
      "epoch: 69 mean_loss: {'reconstruction': 0.10709910735901632, 'supervision': 0.007366728092485765, 'accuracy': 0.9959309895833333, 'regularization': 0.22082755408483526, 'mlp_supervision': 0.005351884612605551, 'label_distribution': 0.6542919677776369}\n",
      "epoch: 70 mean_loss: {'reconstruction': 0.10747447017814783, 'supervision': 0.009587215989982944, 'accuracy': 0.9927164713541666, 'regularization': 0.22048955266975998, 'mlp_supervision': 0.008766887017900175, 'label_distribution': 0.6541544811343472}\n",
      "epoch: 71 mean_loss: {'reconstruction': 0.10723533127165069, 'supervision': 0.006344204712744689, 'accuracy': 0.9967447916666666, 'regularization': 0.22016247694504876, 'mlp_supervision': 0.004423048362901746, 'label_distribution': 0.6539961826911931}\n",
      "epoch: 72 mean_loss: {'reconstruction': 0.10739334585643365, 'supervision': 0.006813062336405939, 'accuracy': 0.9959309895833334, 'regularization': 0.21986735371005223, 'mlp_supervision': 0.005503753902989922, 'label_distribution': 0.6541496980340984}\n",
      "epoch: 73 mean_loss: {'reconstruction': 0.10714834139061202, 'supervision': 0.00790463580355674, 'accuracy': 0.9944661458333334, 'regularization': 0.21958037399273647, 'mlp_supervision': 0.006607980564811704, 'label_distribution': 0.6541218876445964}\n",
      "epoch: 74 mean_loss: {'reconstruction': 0.10750028623061275, 'supervision': 0.008721490696985634, 'accuracy': 0.9927978515625, 'regularization': 0.2192864605569425, 'mlp_supervision': 0.008228017065960743, 'label_distribution': 0.6541483345204916}\n",
      "epoch: 75 mean_loss: {'reconstruction': 0.1073222861818112, 'supervision': 0.010773265443756229, 'accuracy': 0.9898681640625, 'regularization': 0.21901074065910203, 'mlp_supervision': 0.011284847215462437, 'label_distribution': 0.6541079219339091}\n",
      "epoch: 76 mean_loss: {'reconstruction': 0.10734678404566891, 'supervision': 0.008680129005892458, 'accuracy': 0.9942626953125, 'regularization': 0.21874434304442367, 'mlp_supervision': 0.007676607263185456, 'label_distribution': 0.6541541822108798}\n",
      "epoch: 77 mean_loss: {'reconstruction': 0.10762193314180016, 'supervision': 0.007789847869408979, 'accuracy': 0.9943440755208333, 'regularization': 0.2184807862129715, 'mlp_supervision': 0.006861802682059192, 'label_distribution': 0.6542536271763829}\n",
      "epoch: 78 mean_loss: {'reconstruction': 0.10712419996388806, 'supervision': 0.007614304698521262, 'accuracy': 0.9949544270833333, 'regularization': 0.21822175935369145, 'mlp_supervision': 0.006929086108715791, 'label_distribution': 0.6544154481594991}\n",
      "epoch: 79 mean_loss: {'reconstruction': 0.10719093115600209, 'supervision': 0.007106048015719353, 'accuracy': 0.994873046875, 'regularization': 0.2180009306891977, 'mlp_supervision': 0.006362747634536077, 'label_distribution': 0.6540141886635951}\n",
      "epoch: 80 mean_loss: {'reconstruction': 0.10731956294875918, 'supervision': 0.006844526487434009, 'accuracy': 0.9954833984375, 'regularization': 0.21780226692117888, 'mlp_supervision': 0.005550492051312425, 'label_distribution': 0.6541427707752849}\n",
      "epoch: 81 mean_loss: {'reconstruction': 0.10768945688043904, 'supervision': 0.006949131632049747, 'accuracy': 0.9956868489583334, 'regularization': 0.21757142597254892, 'mlp_supervision': 0.006080666202555114, 'label_distribution': 0.6536465013886957}\n",
      "epoch: 82 mean_loss: {'reconstruction': 0.10739047022538789, 'supervision': 0.007089840515702412, 'accuracy': 0.9955240885416666, 'regularization': 0.2173454753433563, 'mlp_supervision': 0.006597130464861949, 'label_distribution': 0.6546594447873855}\n",
      "epoch: 83 mean_loss: {'reconstruction': 0.10746629924643536, 'supervision': 0.005856874365569488, 'accuracy': 0.99658203125, 'regularization': 0.21711597230399304, 'mlp_supervision': 0.00470831094572574, 'label_distribution': 0.6540163545552327}\n",
      "epoch: 84 mean_loss: {'reconstruction': 0.10755615653614278, 'supervision': 0.004624720842803831, 'accuracy': 0.9981282552083333, 'regularization': 0.21690125918329975, 'mlp_supervision': 0.0026859988186021333, 'label_distribution': 0.654514721308364}\n",
      "epoch: 85 mean_loss: {'reconstruction': 0.10740178788094941, 'supervision': 0.007858073585999006, 'accuracy': 0.9936930338541667, 'regularization': 0.216703408382467, 'mlp_supervision': 0.00864600918928779, 'label_distribution': 0.653725422951981}\n",
      "epoch: 86 mean_loss: {'reconstruction': 0.10721776033867392, 'supervision': 0.009302016167559128, 'accuracy': 0.991943359375, 'regularization': 0.2165217539599329, 'mlp_supervision': 0.00898154222025542, 'label_distribution': 0.6543465528443837}\n",
      "epoch: 87 mean_loss: {'reconstruction': 0.10743298615663094, 'supervision': 0.006260062175351966, 'accuracy': 0.9958902994791666, 'regularization': 0.21632443472214885, 'mlp_supervision': 0.005130981568184494, 'label_distribution': 0.6540445409227844}\n",
      "epoch: 88 mean_loss: {'reconstruction': 0.10739317209362134, 'supervision': 0.007190822122642543, 'accuracy': 0.9943033854166667, 'regularization': 0.21612319375107203, 'mlp_supervision': 0.007001835305987452, 'label_distribution': 0.6538946415976992}\n",
      "epoch: 89 mean_loss: {'reconstruction': 0.1073763717161499, 'supervision': 0.0063082292338638955, 'accuracy': 0.9958902994791666, 'regularization': 0.21591553988162324, 'mlp_supervision': 0.0051225980703137625, 'label_distribution': 0.6545081616544586}\n",
      "epoch: 90 mean_loss: {'reconstruction': 0.10729118056758385, 'supervision': 0.00658802705001074, 'accuracy': 0.9962565104166667, 'regularization': 0.2157214709796954, 'mlp_supervision': 0.005709698428562919, 'label_distribution': 0.6540294283270532}\n",
      "epoch: 91 mean_loss: {'reconstruction': 0.10725328392447488, 'supervision': 0.007800891285047504, 'accuracy': 0.9941813151041667, 'regularization': 0.2155227504303559, 'mlp_supervision': 0.007415989997026381, 'label_distribution': 0.6541662735809953}\n",
      "epoch: 92 mean_loss: {'reconstruction': 0.10735503496762634, 'supervision': 0.0057427360629574205, 'accuracy': 0.9964599609375, 'regularization': 0.21532699580782472, 'mlp_supervision': 0.004887997260475752, 'label_distribution': 0.6540615820928325}\n",
      "epoch: 93 mean_loss: {'reconstruction': 0.10731175212344704, 'supervision': 0.005726961276234787, 'accuracy': 0.9961751302083333, 'regularization': 0.21513621379098236, 'mlp_supervision': 0.004992430592512396, 'label_distribution': 0.6540670170560424}\n",
      "epoch: 94 mean_loss: {'reconstruction': 0.10714104510860807, 'supervision': 0.007788243380875281, 'accuracy': 0.9945068359375, 'regularization': 0.21494517003059604, 'mlp_supervision': 0.007638170928907788, 'label_distribution': 0.6542783515100083}\n",
      "epoch: 95 mean_loss: {'reconstruction': 0.10731803878735205, 'supervision': 0.007115199367693453, 'accuracy': 0.994140625, 'regularization': 0.21476030853872546, 'mlp_supervision': 0.006910714412190816, 'label_distribution': 0.6543023752598711}\n",
      "epoch: 96 mean_loss: {'reconstruction': 0.10733161336943067, 'supervision': 0.005761785038562137, 'accuracy': 0.9960123697916667, 'regularization': 0.21458057829831206, 'mlp_supervision': 0.005306250054874966, 'label_distribution': 0.6542801987355777}\n",
      "epoch: 97 mean_loss: {'reconstruction': 0.10705959627904424, 'supervision': 0.005507964522983503, 'accuracy': 0.9966634114583334, 'regularization': 0.21442489712844098, 'mlp_supervision': 0.0050870728026075306, 'label_distribution': 0.6539510526130312}\n",
      "epoch: 98 mean_loss: {'reconstruction': 0.10750105786489644, 'supervision': 0.0055803940076162815, 'accuracy': 0.9958089192708333, 'regularization': 0.21425796829357535, 'mlp_supervision': 0.0052626736941646735, 'label_distribution': 0.6542950017620935}\n",
      "epoch: 99 mean_loss: {'reconstruction': 0.10728599401352046, 'supervision': 0.006452611800469812, 'accuracy': 0.995361328125, 'regularization': 0.21409865371085698, 'mlp_supervision': 0.00706729081760228, 'label_distribution': 0.6544178722503351}\n",
      "epoch: 100 mean_loss: {'reconstruction': 0.10697310203045307, 'supervision': 0.004806420241557153, 'accuracy': 0.996337890625, 'regularization': 0.21393705069563412, 'mlp_supervision': 0.004335605611297866, 'label_distribution': 0.6541418837552571}\n",
      "epoch: 101 mean_loss: {'reconstruction': 0.10716810065920301, 'supervision': 0.003961932951482666, 'accuracy': 0.9977213541666667, 'regularization': 0.21376985871858134, 'mlp_supervision': 0.0029671267382195927, 'label_distribution': 0.6542290716509204}\n",
      "epoch: 102 mean_loss: {'reconstruction': 0.10763855043217616, 'supervision': 0.00720667781036625, 'accuracy': 0.9945068359375, 'regularization': 0.21359806206992865, 'mlp_supervision': 0.007315991130786561, 'label_distribution': 0.6540111183480305}\n",
      "epoch: 103 mean_loss: {'reconstruction': 0.1070467398159203, 'supervision': 0.007085470582096479, 'accuracy': 0.9944661458333333, 'regularization': 0.21345155102531882, 'mlp_supervision': 0.006793547241193488, 'label_distribution': 0.654112888022949}\n",
      "epoch: 104 mean_loss: {'reconstruction': 0.1074128598981475, 'supervision': 0.0051269655900927375, 'accuracy': 0.9967854817708334, 'regularization': 0.21328433256208218, 'mlp_supervision': 0.004299121964221278, 'label_distribution': 0.6543209568915307}\n",
      "epoch: 105 mean_loss: {'reconstruction': 0.1067857741776662, 'supervision': 0.007837311955291477, 'accuracy': 0.9935709635416667, 'regularization': 0.21312274545281631, 'mlp_supervision': 0.009090536404319564, 'label_distribution': 0.6543407013191556}\n",
      "epoch: 106 mean_loss: {'reconstruction': 0.10743160176996272, 'supervision': 0.006397445458221656, 'accuracy': 0.9950764973958333, 'regularization': 0.21298948601419765, 'mlp_supervision': 0.006174889086525283, 'label_distribution': 0.6543438815069846}\n",
      "epoch: 107 mean_loss: {'reconstruction': 0.10713723897980032, 'supervision': 0.008301983710784071, 'accuracy': 0.9925537109375, 'regularization': 0.21285530689664128, 'mlp_supervision': 0.008906358672321582, 'label_distribution': 0.6541715554048533}\n",
      "epoch: 108 mean_loss: {'reconstruction': 0.10747078284115909, 'supervision': 0.006017631182283515, 'accuracy': 0.99560546875, 'regularization': 0.2127157802062188, 'mlp_supervision': 0.005206275192469382, 'label_distribution': 0.6541769245509652}\n",
      "epoch: 109 mean_loss: {'reconstruction': 0.10738811683164502, 'supervision': 0.004721866396570576, 'accuracy': 0.9974365234375, 'regularization': 0.21261785058972404, 'mlp_supervision': 0.003982540515804002, 'label_distribution': 0.654637682410969}\n",
      "epoch: 110 mean_loss: {'reconstruction': 0.10729317997023649, 'supervision': 0.004075402153310826, 'accuracy': 0.9977620442708333, 'regularization': 0.21247096095157106, 'mlp_supervision': 0.0028624265469903267, 'label_distribution': 0.6542387153450571}\n",
      "epoch: 111 mean_loss: {'reconstruction': 0.10765123607824209, 'supervision': 0.003950686626960193, 'accuracy': 0.9979654947916667, 'regularization': 0.21233090086508133, 'mlp_supervision': 0.0032751515664061637, 'label_distribution': 0.6540668665856078}\n",
      "epoch: 112 mean_loss: {'reconstruction': 0.10770608668716998, 'supervision': 0.004303202883029872, 'accuracy': 0.9973958333333333, 'regularization': 0.2122209570430495, 'mlp_supervision': 0.004078955734870966, 'label_distribution': 0.6539359991631557}\n",
      "epoch: 113 mean_loss: {'reconstruction': 0.10749231564822942, 'supervision': 0.0037514252480128968, 'accuracy': 0.9981689453125, 'regularization': 0.21211064079223105, 'mlp_supervision': 0.0026892197754482, 'label_distribution': 0.6542194820887912}\n",
      "epoch: 114 mean_loss: {'reconstruction': 0.1074283543176108, 'supervision': 0.005433560253510906, 'accuracy': 0.9959309895833333, 'regularization': 0.21198208090616472, 'mlp_supervision': 0.005795737574903795, 'label_distribution': 0.6541698803972664}\n",
      "epoch: 115 mean_loss: {'reconstruction': 0.10725844701757195, 'supervision': 0.006970048395454681, 'accuracy': 0.994384765625, 'regularization': 0.21184191664038846, 'mlp_supervision': 0.008232621463312537, 'label_distribution': 0.6541853152534949}\n",
      "epoch: 116 mean_loss: {'reconstruction': 0.10702421673763839, 'supervision': 0.005396585026610995, 'accuracy': 0.9962972005208334, 'regularization': 0.21171403797079186, 'mlp_supervision': 0.005262291643527491, 'label_distribution': 0.6544003519309216}\n",
      "epoch: 117 mean_loss: {'reconstruction': 0.10744180370578878, 'supervision': 0.004700221959902745, 'accuracy': 0.9971110026041666, 'regularization': 0.21157970904553502, 'mlp_supervision': 0.003951498606841638, 'label_distribution': 0.6539960884981924}\n",
      "epoch: 118 mean_loss: {'reconstruction': 0.10730155092397167, 'supervision': 0.0035535562308259424, 'accuracy': 0.998046875, 'regularization': 0.21145474552993732, 'mlp_supervision': 0.002745399112366052, 'label_distribution': 0.6543363058769598}\n",
      "epoch: 119 mean_loss: {'reconstruction': 0.10748210939733223, 'supervision': 0.005996454856234319, 'accuracy': 0.9950358072916667, 'regularization': 0.21134405453115412, 'mlp_supervision': 0.006501701991191608, 'label_distribution': 0.6542440826580991}\n",
      "epoch: 120 mean_loss: {'reconstruction': 0.10742227883507847, 'supervision': 0.007105037157734561, 'accuracy': 0.9933268229166667, 'regularization': 0.21123934127807914, 'mlp_supervision': 0.008774068492082012, 'label_distribution': 0.6542967498677074}\n",
      "epoch: 121 mean_loss: {'reconstruction': 0.10746187400823842, 'supervision': 0.005798319123458641, 'accuracy': 0.9951171875, 'regularization': 0.21112163739811418, 'mlp_supervision': 0.006110022721915359, 'label_distribution': 0.6544207311054975}\n",
      "epoch: 122 mean_loss: {'reconstruction': 0.10751125154136118, 'supervision': 0.004855273355932827, 'accuracy': 0.9971923828125, 'regularization': 0.21100188413377538, 'mlp_supervision': 0.0038999452587514054, 'label_distribution': 0.6542906492733973}\n",
      "epoch: 123 mean_loss: {'reconstruction': 0.10733764960408869, 'supervision': 0.005436438778857118, 'accuracy': 0.9965006510416667, 'regularization': 0.2109126389820034, 'mlp_supervision': 0.005349294063166098, 'label_distribution': 0.6544346776469265}\n",
      "epoch: 124 mean_loss: {'reconstruction': 0.1075619565409119, 'supervision': 0.006425168260841467, 'accuracy': 0.9953206380208334, 'regularization': 0.2107847455073202, 'mlp_supervision': 0.006756363772489914, 'label_distribution': 0.6542304066440632}\n",
      "epoch: 125 mean_loss: {'reconstruction': 0.10747123100653588, 'supervision': 0.0047784733747348795, 'accuracy': 0.9967041015625, 'regularization': 0.21068397268659206, 'mlp_supervision': 0.004735804034903038, 'label_distribution': 0.6541414051788299}\n",
      "epoch: 126 mean_loss: {'reconstruction': 0.10761949836664259, 'supervision': 0.003602261029172433, 'accuracy': 0.9976806640625, 'regularization': 0.21058397827117054, 'mlp_supervision': 0.0029405390192105765, 'label_distribution': 0.654392871911174}\n",
      "epoch: 127 mean_loss: {'reconstruction': 0.10751491121204437, 'supervision': 0.0033469348880342986, 'accuracy': 0.998046875, 'regularization': 0.21046647657810577, 'mlp_supervision': 0.0030001503056491102, 'label_distribution': 0.6542603819484105}\n",
      "epoch: 128 mean_loss: {'reconstruction': 0.10765097331068983, 'supervision': 0.00409580769584263, 'accuracy': 0.9970703125, 'regularization': 0.21035574895167677, 'mlp_supervision': 0.003999285028310807, 'label_distribution': 0.654172769046766}\n",
      "epoch: 129 mean_loss: {'reconstruction': 0.10737099328988886, 'supervision': 0.004859581288156332, 'accuracy': 0.9966227213541666, 'regularization': 0.21024093885308115, 'mlp_supervision': 0.00501566022417916, 'label_distribution': 0.654364186197154}\n",
      "epoch: 130 mean_loss: {'reconstruction': 0.10768096072977004, 'supervision': 0.006123845778608932, 'accuracy': 0.9945068359375, 'regularization': 0.21012364479798232, 'mlp_supervision': 0.006900282182016208, 'label_distribution': 0.6541023497426223}\n",
      "epoch: 131 mean_loss: {'reconstruction': 0.10738117764108672, 'supervision': 0.00389197281202819, 'accuracy': 0.9976806640625, 'regularization': 0.2100078107939813, 'mlp_supervision': 0.0030435150061286515, 'label_distribution': 0.6544651595829867}\n",
      "epoch: 132 mean_loss: {'reconstruction': 0.10755358409263185, 'supervision': 0.003101813208117846, 'accuracy': 0.9984537760416667, 'regularization': 0.20990660736840408, 'mlp_supervision': 0.0022236979568960678, 'label_distribution': 0.6543531210161964}\n",
      "epoch: 133 mean_loss: {'reconstruction': 0.10711470061918305, 'supervision': 0.0033538725018721974, 'accuracy': 0.998046875, 'regularization': 0.20979623752908305, 'mlp_supervision': 0.0028628051171059573, 'label_distribution': 0.6539254657297303}\n",
      "epoch: 134 mean_loss: {'reconstruction': 0.10750374452696124, 'supervision': 0.0038273490889626136, 'accuracy': 0.9971516927083333, 'regularization': 0.2097263722472561, 'mlp_supervision': 0.0038200045997844614, 'label_distribution': 0.6537505339599448}\n",
      "epoch: 135 mean_loss: {'reconstruction': 0.10780237225602576, 'supervision': 0.00359033405170084, 'accuracy': 0.9974772135416667, 'regularization': 0.20963945397726125, 'mlp_supervision': 0.0030904938404128527, 'label_distribution': 0.6539553826104486}\n",
      "epoch: 136 mean_loss: {'reconstruction': 0.10754511492021127, 'supervision': 0.004915730619663521, 'accuracy': 0.9965006510416667, 'regularization': 0.20955548320693712, 'mlp_supervision': 0.005030175941798429, 'label_distribution': 0.654388637407348}\n",
      "epoch: 137 mean_loss: {'reconstruction': 0.10767546863295686, 'supervision': 0.0033095170873840432, 'accuracy': 0.9982096354166666, 'regularization': 0.20946305919662062, 'mlp_supervision': 0.0024207400264169574, 'label_distribution': 0.654152458632772}\n",
      "epoch: 138 mean_loss: {'reconstruction': 0.10760550599567476, 'supervision': 0.004098907214339325, 'accuracy': 0.9976399739583333, 'regularization': 0.20935849167440657, 'mlp_supervision': 0.0039013643823027815, 'label_distribution': 0.6541207009109302}\n",
      "epoch: 139 mean_loss: {'reconstruction': 0.1075710100837949, 'supervision': 0.005425001769437807, 'accuracy': 0.9956868489583333, 'regularization': 0.20928151555521923, 'mlp_supervision': 0.005761524017014526, 'label_distribution': 0.6540533022130923}\n",
      "epoch: 140 mean_loss: {'reconstruction': 0.10722662497131909, 'supervision': 0.00527654571992957, 'accuracy': 0.9954427083333334, 'regularization': 0.2091714815932982, 'mlp_supervision': 0.005601708899442602, 'label_distribution': 0.6540924791018666}\n",
      "epoch: 141 mean_loss: {'reconstruction': 0.1076622045903396, 'supervision': 0.006510095927910483, 'accuracy': 0.9944661458333334, 'regularization': 0.2090742409033329, 'mlp_supervision': 0.006575943008401395, 'label_distribution': 0.6541743699884539}\n",
      "epoch: 142 mean_loss: {'reconstruction': 0.1071532290748041, 'supervision': 0.004822540228562683, 'accuracy': 0.9967041015625, 'regularization': 0.20898903493500942, 'mlp_supervision': 0.004532750670132165, 'label_distribution': 0.6540635795723135}\n",
      "epoch: 143 mean_loss: {'reconstruction': 0.10750302923270086, 'supervision': 0.003601668199648217, 'accuracy': 0.9976806640625, 'regularization': 0.20889147389826068, 'mlp_supervision': 0.003241685755268918, 'label_distribution': 0.6542008449109542}\n",
      "epoch: 144 mean_loss: {'reconstruction': 0.10738770291184527, 'supervision': 0.004036674354562833, 'accuracy': 0.9972330729166666, 'regularization': 0.2087901172686159, 'mlp_supervision': 0.0038660622946290694, 'label_distribution': 0.6541461757676984}\n",
      "epoch: 145 mean_loss: {'reconstruction': 0.10730259792462152, 'supervision': 0.003981403440608518, 'accuracy': 0.9965006510416666, 'regularization': 0.20868234658907248, 'mlp_supervision': 0.003886731851919817, 'label_distribution': 0.6541017638326041}\n",
      "epoch: 146 mean_loss: {'reconstruction': 0.10735948437494557, 'supervision': 0.004406942312486794, 'accuracy': 0.9969075520833334, 'regularization': 0.20858942261803753, 'mlp_supervision': 0.004746701914601623, 'label_distribution': 0.6542286672626295}\n",
      "epoch: 147 mean_loss: {'reconstruction': 0.10700053777087193, 'supervision': 0.006047063530962101, 'accuracy': 0.9956868489583334, 'regularization': 0.20848244439290872, 'mlp_supervision': 0.005939714974007463, 'label_distribution': 0.6542871049220994}\n",
      "epoch: 148 mean_loss: {'reconstruction': 0.10736625212969438, 'supervision': 0.004457460306860869, 'accuracy': 0.9970296223958333, 'regularization': 0.20837973296702317, 'mlp_supervision': 0.004377175742443372, 'label_distribution': 0.6542220499110143}\n",
      "epoch: 149 mean_loss: {'reconstruction': 0.1073697440666829, 'supervision': 0.0034655378411215976, 'accuracy': 0.9979248046875, 'regularization': 0.208271570015182, 'mlp_supervision': 0.0029600343689679858, 'label_distribution': 0.6543139024050331}\n",
      "epoch: 150 mean_loss: {'reconstruction': 0.10734459161506496, 'supervision': 0.00324335684643677, 'accuracy': 0.9982096354166666, 'regularization': 0.208189326172038, 'mlp_supervision': 0.0024302435664643315, 'label_distribution': 0.6538581531279035}\n",
      "epoch: 151 mean_loss: {'reconstruction': 0.1075914235128109, 'supervision': 0.0033533157399199295, 'accuracy': 0.9980875651041667, 'regularization': 0.20810568025715576, 'mlp_supervision': 0.0029872087722007754, 'label_distribution': 0.6543508937565501}\n",
      "epoch: 152 mean_loss: {'reconstruction': 0.10724128033596575, 'supervision': 0.0029351074322085165, 'accuracy': 0.9979654947916666, 'regularization': 0.20801787523158666, 'mlp_supervision': 0.0028831794324533106, 'label_distribution': 0.6539646928813775}\n",
      "epoch: 153 mean_loss: {'reconstruction': 0.10739365545225968, 'supervision': 0.0031125977021619696, 'accuracy': 0.9978434244791666, 'regularization': 0.20793947739476779, 'mlp_supervision': 0.0030988247715177664, 'label_distribution': 0.6539214302912135}\n",
      "epoch: 154 mean_loss: {'reconstruction': 0.107555196707681, 'supervision': 0.0026694013616784555, 'accuracy': 0.9989420572916667, 'regularization': 0.20788946656546625, 'mlp_supervision': 0.002334551315837232, 'label_distribution': 0.6543766229735734}\n",
      "epoch: 155 mean_loss: {'reconstruction': 0.10757769483255983, 'supervision': 0.0023280503555869374, 'accuracy': 0.9989420572916667, 'regularization': 0.20783226119399112, 'mlp_supervision': 0.0017473982929928555, 'label_distribution': 0.6542829629595013}\n",
      "epoch: 156 mean_loss: {'reconstruction': 0.10755226641721777, 'supervision': 0.002702714553193292, 'accuracy': 0.9989420572916667, 'regularization': 0.20776036999302347, 'mlp_supervision': 0.0022339123610766896, 'label_distribution': 0.6543364266749667}\n",
      "epoch: 157 mean_loss: {'reconstruction': 0.10752239960256112, 'supervision': 0.0026965179386938126, 'accuracy': 0.9983723958333334, 'regularization': 0.2077003102440434, 'mlp_supervision': 0.002499119745650974, 'label_distribution': 0.6537842149545064}\n",
      "epoch: 158 mean_loss: {'reconstruction': 0.10731496124633799, 'supervision': 0.002967308180732952, 'accuracy': 0.9978434244791667, 'regularization': 0.20765254726522672, 'mlp_supervision': 0.0034516194330708526, 'label_distribution': 0.654311206216907}\n",
      "epoch: 159 mean_loss: {'reconstruction': 0.10738955112159951, 'supervision': 0.0032851660946969325, 'accuracy': 0.9983723958333334, 'regularization': 0.20757604926949558, 'mlp_supervision': 0.00266803514390005, 'label_distribution': 0.6544526426096567}\n",
      "epoch: 160 mean_loss: {'reconstruction': 0.10754423757531596, 'supervision': 0.005722970983376294, 'accuracy': 0.9951171875, 'regularization': 0.20750025873570685, 'mlp_supervision': 0.007247947254286741, 'label_distribution': 0.654183909045587}\n",
      "epoch: 161 mean_loss: {'reconstruction': 0.10733594859332807, 'supervision': 0.004093804834225257, 'accuracy': 0.9972737630208334, 'regularization': 0.20744303968106037, 'mlp_supervision': 0.0042309120264987145, 'label_distribution': 0.6544039495030155}\n",
      "epoch: 162 mean_loss: {'reconstruction': 0.10716701273130755, 'supervision': 0.0032693869740486837, 'accuracy': 0.9980875651041666, 'regularization': 0.20735139827211002, 'mlp_supervision': 0.0033353812187763444, 'label_distribution': 0.6541657422073048}\n",
      "epoch: 163 mean_loss: {'reconstruction': 0.10720415682273166, 'supervision': 0.0032811446573759303, 'accuracy': 0.9976399739583334, 'regularization': 0.20730027780924498, 'mlp_supervision': 0.0031897838847390085, 'label_distribution': 0.654161687188168}\n",
      "epoch: 164 mean_loss: {'reconstruction': 0.10757982902314803, 'supervision': 0.004033872679297113, 'accuracy': 0.9971923828125, 'regularization': 0.20722330660787658, 'mlp_supervision': 0.004188108197346821, 'label_distribution': 0.6541957842755111}\n",
      "epoch: 165 mean_loss: {'reconstruction': 0.10751746854526276, 'supervision': 0.0029548802029995226, 'accuracy': 0.9984944661458335, 'regularization': 0.20712039850539604, 'mlp_supervision': 0.0026769392187426144, 'label_distribution': 0.6546205459005401}\n",
      "epoch: 166 mean_loss: {'reconstruction': 0.10731004117088874, 'supervision': 0.0030705801204246, 'accuracy': 0.9974772135416666, 'regularization': 0.20703743816343573, 'mlp_supervision': 0.0034028126860054346, 'label_distribution': 0.6544465160331054}\n",
      "epoch: 167 mean_loss: {'reconstruction': 0.1073328439950269, 'supervision': 0.0035575437189236583, 'accuracy': 0.9976806640625, 'regularization': 0.20697140094673233, 'mlp_supervision': 0.0036040110840799082, 'label_distribution': 0.6544412187748769}\n",
      "epoch: 168 mean_loss: {'reconstruction': 0.10772355365025618, 'supervision': 0.0036851405493007173, 'accuracy': 0.9977620442708333, 'regularization': 0.20689479892757193, 'mlp_supervision': 0.003550937545683742, 'label_distribution': 0.654231532438559}\n",
      "epoch: 169 mean_loss: {'reconstruction': 0.107058128555586, 'supervision': 0.003444362294006421, 'accuracy': 0.9974365234375, 'regularization': 0.20681713514151734, 'mlp_supervision': 0.003454972352710771, 'label_distribution': 0.654260082235111}\n",
      "epoch: 170 mean_loss: {'reconstruction': 0.10763882762164667, 'supervision': 0.004845955086321896, 'accuracy': 0.9962158203125, 'regularization': 0.2067334606814019, 'mlp_supervision': 0.005467227724271361, 'label_distribution': 0.6542790556838725}\n",
      "epoch: 171 mean_loss: {'reconstruction': 0.10750734785142516, 'supervision': 0.003396722242976124, 'accuracy': 0.9980061848958333, 'regularization': 0.20665181694114315, 'mlp_supervision': 0.003086593852056244, 'label_distribution': 0.6540710026678459}\n",
      "epoch: 172 mean_loss: {'reconstruction': 0.10762730832159337, 'supervision': 0.002570518730912705, 'accuracy': 0.9983317057291666, 'regularization': 0.20656333191243503, 'mlp_supervision': 0.0023226914194611112, 'label_distribution': 0.6543908493534276}\n",
      "epoch: 173 mean_loss: {'reconstruction': 0.10737862951502254, 'supervision': 0.005475982555567008, 'accuracy': 0.9951578776041667, 'regularization': 0.20648720349428257, 'mlp_supervision': 0.006723812911341968, 'label_distribution': 0.6541023829347199}\n",
      "epoch: 174 mean_loss: {'reconstruction': 0.10738964824448269, 'supervision': 0.0045629137680132745, 'accuracy': 0.9962158203125, 'regularization': 0.20640206447503637, 'mlp_supervision': 0.005308666452463174, 'label_distribution': 0.6543145257703274}\n",
      "epoch: 175 mean_loss: {'reconstruction': 0.10772982803175588, 'supervision': 0.003323882158702626, 'accuracy': 0.997802734375, 'regularization': 0.20632033995324844, 'mlp_supervision': 0.0033779437100038513, 'label_distribution': 0.6545676524501816}\n",
      "epoch: 176 mean_loss: {'reconstruction': 0.10713678153271412, 'supervision': 0.0037990174174282556, 'accuracy': 0.9971516927083333, 'regularization': 0.20626125457402428, 'mlp_supervision': 0.0037701191574865747, 'label_distribution': 0.6540598830136084}\n",
      "epoch: 177 mean_loss: {'reconstruction': 0.10725907436159993, 'supervision': 0.0034727258647572357, 'accuracy': 0.9979248046875, 'regularization': 0.20621826528442516, 'mlp_supervision': 0.003270510205758735, 'label_distribution': 0.6540585292014534}\n",
      "epoch: 178 mean_loss: {'reconstruction': 0.10764335904562856, 'supervision': 0.0036419728186320444, 'accuracy': 0.9979654947916666, 'regularization': 0.20615659207730275, 'mlp_supervision': 0.0035943483006770837, 'label_distribution': 0.6541959705432855}\n",
      "epoch: 179 mean_loss: {'reconstruction': 0.10729557850759248, 'supervision': 0.0025288503409371145, 'accuracy': 0.998291015625, 'regularization': 0.20608388294613814, 'mlp_supervision': 0.0023257743507230783, 'label_distribution': 0.6542740958557635}\n",
      "epoch: 180 mean_loss: {'reconstruction': 0.1073312034140356, 'supervision': 0.0015807937949992791, 'accuracy': 0.99951171875, 'regularization': 0.2059987092041417, 'mlp_supervision': 0.000915285446591874, 'label_distribution': 0.6541674430067062}\n",
      "epoch: 181 mean_loss: {'reconstruction': 0.10746053222282774, 'supervision': 0.003420278899267125, 'accuracy': 0.9970703125, 'regularization': 0.2059293070812661, 'mlp_supervision': 0.004064886459550536, 'label_distribution': 0.6538493958269629}\n",
      "epoch: 182 mean_loss: {'reconstruction': 0.10769701833617121, 'supervision': 0.0038077892814663396, 'accuracy': 0.9976399739583334, 'regularization': 0.20587000950581252, 'mlp_supervision': 0.003928960372564784, 'label_distribution': 0.6539281431541688}\n",
      "epoch: 183 mean_loss: {'reconstruction': 0.10747756915463139, 'supervision': 0.002484107363254855, 'accuracy': 0.9986979166666667, 'regularization': 0.2057903142161342, 'mlp_supervision': 0.0022774510008430958, 'label_distribution': 0.6541952105125439}\n",
      "epoch: 184 mean_loss: {'reconstruction': 0.10754976458520957, 'supervision': 0.0032909153868136364, 'accuracy': 0.9977620442708334, 'regularization': 0.2056950499418111, 'mlp_supervision': 0.0033994159227205556, 'label_distribution': 0.6538906646689806}\n",
      "epoch: 185 mean_loss: {'reconstruction': 0.10737721761035726, 'supervision': 0.003369602984480359, 'accuracy': 0.99755859375, 'regularization': 0.20563254143453152, 'mlp_supervision': 0.0036270533325719377, 'label_distribution': 0.6541151214733296}\n",
      "epoch: 186 mean_loss: {'reconstruction': 0.10747910687036367, 'supervision': 0.002707217233823744, 'accuracy': 0.998046875, 'regularization': 0.2055532975642872, 'mlp_supervision': 0.0028321334252962, 'label_distribution': 0.6542169221697742}\n",
      "epoch: 187 mean_loss: {'reconstruction': 0.1075178460169638, 'supervision': 0.0029089577629993263, 'accuracy': 0.9981689453125, 'regularization': 0.20548088115186836, 'mlp_supervision': 0.002843498364094613, 'label_distribution': 0.6542462287634938}\n",
      "epoch: 188 mean_loss: {'reconstruction': 0.10707345125401004, 'supervision': 0.0038922669986428795, 'accuracy': 0.9967854817708333, 'regularization': 0.20540452608838256, 'mlp_supervision': 0.004553755024989041, 'label_distribution': 0.6540617266990214}\n",
      "epoch: 189 mean_loss: {'reconstruction': 0.10743983632040705, 'supervision': 0.0026645318892816487, 'accuracy': 0.997802734375, 'regularization': 0.20532567803146184, 'mlp_supervision': 0.0024661703521315524, 'label_distribution': 0.6541568576273286}\n",
      "epoch: 190 mean_loss: {'reconstruction': 0.1073885981469633, 'supervision': 0.0027855377718005027, 'accuracy': 0.9984130859375, 'regularization': 0.205254961133387, 'mlp_supervision': 0.002624083187300269, 'label_distribution': 0.6541191247895187}\n",
      "epoch: 191 mean_loss: {'reconstruction': 0.10729369678266179, 'supervision': 0.004006118994375032, 'accuracy': 0.9973958333333334, 'regularization': 0.20518303448139824, 'mlp_supervision': 0.003985116720463238, 'label_distribution': 0.6542649249998822}\n",
      "epoch: 192 mean_loss: {'reconstruction': 0.10774833487513812, 'supervision': 0.0036181495071161062, 'accuracy': 0.9975992838541666, 'regularization': 0.20512161265949702, 'mlp_supervision': 0.0038226972858337134, 'label_distribution': 0.6541850633612921}\n",
      "epoch: 193 mean_loss: {'reconstruction': 0.1073919810789442, 'supervision': 0.003353433538703742, 'accuracy': 0.9971110026041667, 'regularization': 0.20506821513221188, 'mlp_supervision': 0.0037427110716395763, 'label_distribution': 0.654269571847424}\n",
      "epoch: 194 mean_loss: {'reconstruction': 0.10761932839185209, 'supervision': 0.0021057359136842793, 'accuracy': 0.9990641276041667, 'regularization': 0.20502115189219455, 'mlp_supervision': 0.0016964130920868316, 'label_distribution': 0.6542890766364532}\n",
      "epoch: 195 mean_loss: {'reconstruction': 0.10721567342613739, 'supervision': 0.0018104109025801837, 'accuracy': 0.9991861979166667, 'regularization': 0.2049643866640247, 'mlp_supervision': 0.001368692430882169, 'label_distribution': 0.6542837792390428}\n",
      "epoch: 196 mean_loss: {'reconstruction': 0.10722162415791964, 'supervision': 0.002841299021102474, 'accuracy': 0.9980061848958333, 'regularization': 0.20488869938971968, 'mlp_supervision': 0.0030896219547223163, 'label_distribution': 0.6541183049202752}\n",
      "epoch: 197 mean_loss: {'reconstruction': 0.1076187407024849, 'supervision': 0.00326269415650783, 'accuracy': 0.9975179036458333, 'regularization': 0.2048223005790644, 'mlp_supervision': 0.003936069987490269, 'label_distribution': 0.654160182960796}\n",
      "epoch: 198 mean_loss: {'reconstruction': 0.10732839756848418, 'supervision': 0.0026270459833819654, 'accuracy': 0.9984537760416666, 'regularization': 0.2047546677372502, 'mlp_supervision': 0.0024749664166653063, 'label_distribution': 0.6546449776389209}\n",
      "epoch: 199 mean_loss: {'reconstruction': 0.10712609205468501, 'supervision': 0.0027400148176466117, 'accuracy': 0.998046875, 'regularization': 0.2046661824880378, 'mlp_supervision': 0.002801747782936675, 'label_distribution': 0.6542998045067411}\n",
      "epoch: 200 mean_loss: {'reconstruction': 0.10748131161795052, 'supervision': 0.0016973332465158681, 'accuracy': 0.9993082682291666, 'regularization': 0.20459275209003291, 'mlp_supervision': 0.0014283409322853702, 'label_distribution': 0.6540963020975028}\n",
      "epoch: 201 mean_loss: {'reconstruction': 0.10713615063189413, 'supervision': 0.0017795134432260612, 'accuracy': 0.9992268880208334, 'regularization': 0.20453036218391163, 'mlp_supervision': 0.0013009982727282283, 'label_distribution': 0.6543790239094485}\n",
      "epoch: 202 mean_loss: {'reconstruction': 0.10747217812025785, 'supervision': 0.0022838982563416505, 'accuracy': 0.9981689453125, 'regularization': 0.20447400786890552, 'mlp_supervision': 0.0024894234772634893, 'label_distribution': 0.6546865604832983}\n",
      "epoch: 203 mean_loss: {'reconstruction': 0.10747905091467318, 'supervision': 0.003100929132611071, 'accuracy': 0.997802734375, 'regularization': 0.20440681748457823, 'mlp_supervision': 0.0032024349533778286, 'label_distribution': 0.6542984022134477}\n",
      "epoch: 204 mean_loss: {'reconstruction': 0.10708405184255529, 'supervision': 0.0026952190522401666, 'accuracy': 0.9984537760416666, 'regularization': 0.20435405807175913, 'mlp_supervision': 0.0025626124458042517, 'label_distribution': 0.6543209837645296}\n",
      "epoch: 205 mean_loss: {'reconstruction': 0.10732799205659341, 'supervision': 0.0018990598336462404, 'accuracy': 0.9990641276041667, 'regularization': 0.20429644096462704, 'mlp_supervision': 0.0017249910279907024, 'label_distribution': 0.6542368483220931}\n",
      "epoch: 206 mean_loss: {'reconstruction': 0.10765148725789661, 'supervision': 0.0021971570640553443, 'accuracy': 0.9985758463541667, 'regularization': 0.20425122766112458, 'mlp_supervision': 0.0020773120031361077, 'label_distribution': 0.654253758713192}\n",
      "epoch: 207 mean_loss: {'reconstruction': 0.10775730212659354, 'supervision': 0.002480736238879748, 'accuracy': 0.99853515625, 'regularization': 0.20419961614117388, 'mlp_supervision': 0.002402844329875563, 'label_distribution': 0.6543022255634945}\n",
      "epoch: 208 mean_loss: {'reconstruction': 0.10763624709607932, 'supervision': 0.0024042900849083034, 'accuracy': 0.9982503255208333, 'regularization': 0.20414077221389798, 'mlp_supervision': 0.002486340016493828, 'label_distribution': 0.6541139598104692}\n",
      "epoch: 209 mean_loss: {'reconstruction': 0.10728910685909494, 'supervision': 0.0022657305536196715, 'accuracy': 0.998779296875, 'regularization': 0.20409186499115856, 'mlp_supervision': 0.002431483487833863, 'label_distribution': 0.6539960124927531}\n",
      "epoch: 210 mean_loss: {'reconstruction': 0.1073108618858733, 'supervision': 0.0022818537179667333, 'accuracy': 0.9987386067708334, 'regularization': 0.20404152372816517, 'mlp_supervision': 0.0018369623489914455, 'label_distribution': 0.6542385855201346}\n",
      "epoch: 211 mean_loss: {'reconstruction': 0.10743698507852625, 'supervision': 0.002116140657686634, 'accuracy': 0.9991455078125, 'regularization': 0.2040027077936092, 'mlp_supervision': 0.0018779282022519225, 'label_distribution': 0.6541722996493295}\n",
      "epoch: 212 mean_loss: {'reconstruction': 0.10731942817736666, 'supervision': 0.0017090304427125516, 'accuracy': 0.9990641276041667, 'regularization': 0.20396185743104706, 'mlp_supervision': 0.001518006563854573, 'label_distribution': 0.6541003210009796}\n",
      "epoch: 213 mean_loss: {'reconstruction': 0.1074674642803, 'supervision': 0.0021784241233785617, 'accuracy': 0.9980875651041666, 'regularization': 0.20391935130019187, 'mlp_supervision': 0.0024337265596463507, 'label_distribution': 0.6541046202021071}\n",
      "epoch: 214 mean_loss: {'reconstruction': 0.10723387758232394, 'supervision': 0.0033860890671192218, 'accuracy': 0.9976806640625, 'regularization': 0.2038782266713855, 'mlp_supervision': 0.0036533504162067115, 'label_distribution': 0.654105609070976}\n",
      "epoch: 215 mean_loss: {'reconstruction': 0.1075007889884678, 'supervision': 0.002629838573603025, 'accuracy': 0.9974772135416667, 'regularization': 0.20385200978305826, 'mlp_supervision': 0.003147160965138824, 'label_distribution': 0.6543049092432518}\n",
      "epoch: 216 mean_loss: {'reconstruction': 0.10753553567652091, 'supervision': 0.004198054311598873, 'accuracy': 0.99658203125, 'regularization': 0.20381568151024834, 'mlp_supervision': 0.005419646512397229, 'label_distribution': 0.6540528831520415}\n",
      "epoch: 217 mean_loss: {'reconstruction': 0.10739327951876752, 'supervision': 0.0020395454468319246, 'accuracy': 0.9983317057291667, 'regularization': 0.20377615536841465, 'mlp_supervision': 0.001948443429579148, 'label_distribution': 0.6541866369760932}\n",
      "epoch: 218 mean_loss: {'reconstruction': 0.10773785339407374, 'supervision': 0.002310112306668391, 'accuracy': 0.99853515625, 'regularization': 0.20372623183751926, 'mlp_supervision': 0.001905575047724202, 'label_distribution': 0.6543661857038028}\n",
      "epoch: 219 mean_loss: {'reconstruction': 0.10763174416385826, 'supervision': 0.0020562660150678057, 'accuracy': 0.9986979166666666, 'regularization': 0.20368383905281023, 'mlp_supervision': 0.0018508135042180802, 'label_distribution': 0.6538806558802186}\n",
      "epoch: 220 mean_loss: {'reconstruction': 0.10718486372280575, 'supervision': 0.0045640297873048696, 'accuracy': 0.9958902994791666, 'regularization': 0.20363527910837056, 'mlp_supervision': 0.006122209133601333, 'label_distribution': 0.6541237848648345}\n",
      "epoch: 221 mean_loss: {'reconstruction': 0.10733827361047599, 'supervision': 0.0034230858048131738, 'accuracy': 0.9971516927083334, 'regularization': 0.20358134327409644, 'mlp_supervision': 0.003698726257377986, 'label_distribution': 0.6541949893231855}\n",
      "epoch: 222 mean_loss: {'reconstruction': 0.10719005504062419, 'supervision': 0.0021532305573724255, 'accuracy': 0.9990234375, 'regularization': 0.2035218952659833, 'mlp_supervision': 0.0018631456630281893, 'label_distribution': 0.6544450414566626}\n",
      "epoch: 223 mean_loss: {'reconstruction': 0.1074377390488499, 'supervision': 0.002091756739628081, 'accuracy': 0.9989420572916666, 'regularization': 0.2034558415946749, 'mlp_supervision': 0.0019006935365166587, 'label_distribution': 0.6540653794572789}\n",
      "epoch: 224 mean_loss: {'reconstruction': 0.10748175364906974, 'supervision': 0.0022069463827558665, 'accuracy': 0.9989420572916667, 'regularization': 0.20339342113526412, 'mlp_supervision': 0.0021371361889069855, 'label_distribution': 0.6542636397390947}\n",
      "epoch: 225 mean_loss: {'reconstruction': 0.107524570669618, 'supervision': 0.0013501646752451225, 'accuracy': 0.9996337890625, 'regularization': 0.2033565920660369, 'mlp_supervision': 0.0010241352424109514, 'label_distribution': 0.6539848921472258}\n",
      "epoch: 226 mean_loss: {'reconstruction': 0.10714903823743044, 'supervision': 0.0011335801546693068, 'accuracy': 0.9996744791666667, 'regularization': 0.20330839006876045, 'mlp_supervision': 0.0008384515282700958, 'label_distribution': 0.6539426659008994}\n",
      "epoch: 227 mean_loss: {'reconstruction': 0.10715737749113383, 'supervision': 0.0026618571497664723, 'accuracy': 0.9980875651041666, 'regularization': 0.20324787943303382, 'mlp_supervision': 0.0032749992477939483, 'label_distribution': 0.6545429271048391}\n",
      "epoch: 228 mean_loss: {'reconstruction': 0.10717480337472216, 'supervision': 0.0025916511069490845, 'accuracy': 0.9980875651041667, 'regularization': 0.20319415548521233, 'mlp_supervision': 0.003146490685920121, 'label_distribution': 0.6538017017251759}\n",
      "epoch: 229 mean_loss: {'reconstruction': 0.10717568624371265, 'supervision': 0.0013547875567579283, 'accuracy': 0.999267578125, 'regularization': 0.20313287131708319, 'mlp_supervision': 0.0011606872405584882, 'label_distribution': 0.6544133966175696}\n",
      "epoch: 230 mean_loss: {'reconstruction': 0.10754004381426893, 'supervision': 0.00400171579891888, 'accuracy': 0.9967041015625, 'regularization': 0.20307457955332237, 'mlp_supervision': 0.0054645834024727585, 'label_distribution': 0.6541282002558122}\n",
      "epoch: 231 mean_loss: {'reconstruction': 0.10746858984212307, 'supervision': 0.005554185314660963, 'accuracy': 0.995849609375, 'regularization': 0.20300014308509615, 'mlp_supervision': 0.006629194575659415, 'label_distribution': 0.6542472013874849}\n",
      "epoch: 232 mean_loss: {'reconstruction': 0.10732811570859942, 'supervision': 0.0016971889464948715, 'accuracy': 0.9993489583333333, 'regularization': 0.20294384329348875, 'mlp_supervision': 0.0011346934786725812, 'label_distribution': 0.654252383603145}\n",
      "epoch: 233 mean_loss: {'reconstruction': 0.10767789796314574, 'supervision': 0.0016286644722783615, 'accuracy': 0.9991861979166667, 'regularization': 0.20289549084292596, 'mlp_supervision': 0.0011866272290799065, 'label_distribution': 0.6538727026398319}\n",
      "epoch: 234 mean_loss: {'reconstruction': 0.10768144627649767, 'supervision': 0.0025288885274936364, 'accuracy': 0.998291015625, 'regularization': 0.20286246645512715, 'mlp_supervision': 0.0026751574375774665, 'label_distribution': 0.6544368735750049}\n",
      "epoch: 235 mean_loss: {'reconstruction': 0.10750734171032521, 'supervision': 0.0028018948922266494, 'accuracy': 0.9985758463541667, 'regularization': 0.2028266426257343, 'mlp_supervision': 0.0026317916892996014, 'label_distribution': 0.6541260465246029}\n",
      "epoch: 236 mean_loss: {'reconstruction': 0.10772358698916053, 'supervision': 0.004307610617600172, 'accuracy': 0.9965413411458333, 'regularization': 0.2027943069904533, 'mlp_supervision': 0.005977854422891841, 'label_distribution': 0.6543890936854526}\n",
      "epoch: 237 mean_loss: {'reconstruction': 0.10767896416145809, 'supervision': 0.003521180573673609, 'accuracy': 0.9969482421875, 'regularization': 0.20273961933919754, 'mlp_supervision': 0.004220387939782246, 'label_distribution': 0.6543943241839794}\n",
      "epoch: 238 mean_loss: {'reconstruction': 0.10726446323418694, 'supervision': 0.004560812493487082, 'accuracy': 0.99560546875, 'regularization': 0.2026815104669641, 'mlp_supervision': 0.006132373495998633, 'label_distribution': 0.6540660994636848}\n",
      "epoch: 239 mean_loss: {'reconstruction': 0.10722439395433425, 'supervision': 0.002994521052471276, 'accuracy': 0.997314453125, 'regularization': 0.20263298115417, 'mlp_supervision': 0.003962434663397692, 'label_distribution': 0.6543483949447845}\n",
      "epoch: 240 mean_loss: {'reconstruction': 0.1070983233866273, 'supervision': 0.0025693984954537528, 'accuracy': 0.9983317057291667, 'regularization': 0.2026040952726827, 'mlp_supervision': 0.0027607315013310303, 'label_distribution': 0.6542536504972167}\n",
      "epoch: 241 mean_loss: {'reconstruction': 0.10737912640985078, 'supervision': 0.003395879385031186, 'accuracy': 0.9976806640625, 'regularization': 0.20257309472283008, 'mlp_supervision': 0.003910786960670423, 'label_distribution': 0.654548110522711}\n",
      "epoch: 242 mean_loss: {'reconstruction': 0.10742204916169833, 'supervision': 0.002823891114831772, 'accuracy': 0.9981282552083333, 'regularization': 0.2025001556235922, 'mlp_supervision': 0.003196056969415331, 'label_distribution': 0.654255362275609}\n",
      "epoch: 243 mean_loss: {'reconstruction': 0.10740912483838783, 'supervision': 0.002888465626712633, 'accuracy': 0.9979654947916666, 'regularization': 0.2024475794178308, 'mlp_supervision': 0.0033466236587864377, 'label_distribution': 0.654257707566247}\n",
      "epoch: 244 mean_loss: {'reconstruction': 0.10755246539531507, 'supervision': 0.002560010744335962, 'accuracy': 0.997802734375, 'regularization': 0.2023936618962054, 'mlp_supervision': 0.0030375507832236543, 'label_distribution': 0.6539054740510051}\n",
      "epoch: 245 mean_loss: {'reconstruction': 0.10725080453033008, 'supervision': 0.0033524863117247025, 'accuracy': 0.9971923828125, 'regularization': 0.20234939480263797, 'mlp_supervision': 0.004297682990978973, 'label_distribution': 0.6540923103596168}\n",
      "epoch: 246 mean_loss: {'reconstruction': 0.10770908401435525, 'supervision': 0.002383431407149279, 'accuracy': 0.9984944661458334, 'regularization': 0.20229428607442862, 'mlp_supervision': 0.002572937846068035, 'label_distribution': 0.6541918000642504}\n",
      "epoch: 247 mean_loss: {'reconstruction': 0.10715637214476739, 'supervision': 0.0032460566213074167, 'accuracy': 0.9977213541666667, 'regularization': 0.20225113462676597, 'mlp_supervision': 0.0036536593894966043, 'label_distribution': 0.6542134698330075}\n",
      "epoch: 248 mean_loss: {'reconstruction': 0.10706431210271941, 'supervision': 0.002376376208676683, 'accuracy': 0.9987386067708334, 'regularization': 0.20220579944025885, 'mlp_supervision': 0.002297636935714806, 'label_distribution': 0.6539447928732093}\n",
      "epoch: 249 mean_loss: {'reconstruction': 0.10776587495007295, 'supervision': 0.002329491374999313, 'accuracy': 0.9987386067708333, 'regularization': 0.2021723481658561, 'mlp_supervision': 0.002225556573793349, 'label_distribution': 0.653956017895854}\n",
      "epoch: 250 mean_loss: {'reconstruction': 0.1072203212027488, 'supervision': 0.0019173432500879707, 'accuracy': 0.9988199869791667, 'regularization': 0.20211798987492596, 'mlp_supervision': 0.0023620107864523177, 'label_distribution': 0.654241499659}\n",
      "epoch: 251 mean_loss: {'reconstruction': 0.10684086219073756, 'supervision': 0.0011752537148645662, 'accuracy': 0.99951171875, 'regularization': 0.20206293610502518, 'mlp_supervision': 0.0009576264714289469, 'label_distribution': 0.6540599881121909}\n",
      "epoch: 252 mean_loss: {'reconstruction': 0.106986394090501, 'supervision': 0.004298919631059877, 'accuracy': 0.9965413411458334, 'regularization': 0.20203094153954912, 'mlp_supervision': 0.005301230168551666, 'label_distribution': 0.6543081329079117}\n",
      "epoch: 253 mean_loss: {'reconstruction': 0.10741775003231294, 'supervision': 0.005297524012159813, 'accuracy': 0.9946695963541666, 'regularization': 0.20199004124633754, 'mlp_supervision': 0.007076542120443912, 'label_distribution': 0.6542354450269533}\n",
      "epoch: 254 mean_loss: {'reconstruction': 0.10767972542469126, 'supervision': 0.0019595144905570987, 'accuracy': 0.9988199869791666, 'regularization': 0.20196225718362215, 'mlp_supervision': 0.0020614739386380972, 'label_distribution': 0.6540899905645225}\n",
      "epoch: 255 mean_loss: {'reconstruction': 0.10710632197194521, 'supervision': 0.0023962387522544603, 'accuracy': 0.9982096354166667, 'regularization': 0.20192695604934097, 'mlp_supervision': 0.0023958445948836604, 'label_distribution': 0.654076048008043}\n",
      "epoch: 0 mean_loss: {'reconstruction': 0.1073072716001935, 'supervision': 0.0036028007339423975, 'accuracy': 0.9974365234375, 'regularization': 0.20188681126089272, 'mlp_supervision': 0.003993803169719857, 'label_distribution': 0.652814421252625}\n",
      "epoch: 1 mean_loss: {'reconstruction': 0.10749336086688008, 'supervision': 0.0017421727395992093, 'accuracy': 0.998931884765625, 'regularization': 0.20188431390140987, 'mlp_supervision': 0.001454699458163647, 'label_distribution': 0.6528659808754709}\n",
      "epoch: 2 mean_loss: {'reconstruction': 0.1072554730384321, 'supervision': 0.0023416227027510195, 'accuracy': 0.99859619140625, 'regularization': 0.20186406371907945, 'mlp_supervision': 0.0023939010004028235, 'label_distribution': 0.652836975704641}\n",
      "epoch: 3 mean_loss: {'reconstruction': 0.107407340876396, 'supervision': 0.0024250982962578573, 'accuracy': 0.998687744140625, 'regularization': 0.20185261958433165, 'mlp_supervision': 0.0021292031713089606, 'label_distribution': 0.6527939821205789}\n",
      "epoch: 4 mean_loss: {'reconstruction': 0.10730978203250785, 'supervision': 0.001567898437593444, 'accuracy': 0.999481201171875, 'regularization': 0.20180688814833378, 'mlp_supervision': 0.0011827946807284441, 'label_distribution': 0.6526680351819274}\n",
      "epoch: 5 mean_loss: {'reconstruction': 0.10759914074524603, 'supervision': 0.0019598940954860195, 'accuracy': 0.9991455078125, 'regularization': 0.2017531813049581, 'mlp_supervision': 0.001783707719184072, 'label_distribution': 0.6531111452246428}\n",
      "epoch: 6 mean_loss: {'reconstruction': 0.10738175804227953, 'supervision': 0.0017397530096366022, 'accuracy': 0.9993896484375, 'regularization': 0.20170016858479306, 'mlp_supervision': 0.001436169240687167, 'label_distribution': 0.6527524460068737}\n",
      "epoch: 7 mean_loss: {'reconstruction': 0.10749984420533934, 'supervision': 0.0013140966559612036, 'accuracy': 0.99957275390625, 'regularization': 0.20166575384647012, 'mlp_supervision': 0.0010319229112860475, 'label_distribution': 0.6529457084193719}\n",
      "epoch: 8 mean_loss: {'reconstruction': 0.10749866592640017, 'supervision': 0.0012747973427197105, 'accuracy': 0.99951171875, 'regularization': 0.20160664120808422, 'mlp_supervision': 0.0010050703833005528, 'label_distribution': 0.6528901955123418}\n",
      "epoch: 9 mean_loss: {'reconstruction': 0.10743433072826938, 'supervision': 0.0015017076558190355, 'accuracy': 0.999481201171875, 'regularization': 0.20157467814766328, 'mlp_supervision': 0.001197346919617405, 'label_distribution': 0.6528455135759688}\n",
      "epoch: 10 mean_loss: {'reconstruction': 0.10759451769564507, 'supervision': 0.0014311452941167795, 'accuracy': 0.9993896484375, 'regularization': 0.20155158387614486, 'mlp_supervision': 0.0012089977276130354, 'label_distribution': 0.6528776158111815}\n",
      "epoch: 11 mean_loss: {'reconstruction': 0.10737981959493875, 'supervision': 0.0017752259918385666, 'accuracy': 0.9991455078125, 'regularization': 0.20152078628609865, 'mlp_supervision': 0.001572016561262563, 'label_distribution': 0.6527505654980508}\n",
      "epoch: 12 mean_loss: {'reconstruction': 0.10740661542425717, 'supervision': 0.0018172725856704431, 'accuracy': 0.999267578125, 'regularization': 0.20148128178106683, 'mlp_supervision': 0.001555048553854087, 'label_distribution': 0.6529051590567659}\n",
      "epoch: 13 mean_loss: {'reconstruction': 0.10743119550527896, 'supervision': 0.0013790002559677873, 'accuracy': 0.999481201171875, 'regularization': 0.20145934958303677, 'mlp_supervision': 0.0012272935127108403, 'label_distribution': 0.6528092917058299}\n",
      "epoch: 14 mean_loss: {'reconstruction': 0.10748942763251504, 'supervision': 0.0018576373365556688, 'accuracy': 0.99908447265625, 'regularization': 0.20140166499596335, 'mlp_supervision': 0.0017383749445628507, 'label_distribution': 0.6528177707824472}\n",
      "epoch: 15 mean_loss: {'reconstruction': 0.10750149709082532, 'supervision': 0.0011108996207887935, 'accuracy': 0.999664306640625, 'regularization': 0.20134104412789233, 'mlp_supervision': 0.0008043478446911555, 'label_distribution': 0.6530040380872928}\n",
      "epoch: 16 mean_loss: {'reconstruction': 0.1074379753914713, 'supervision': 0.0014393211932436749, 'accuracy': 0.999481201171875, 'regularization': 0.20130765948404994, 'mlp_supervision': 0.0012079469258628847, 'label_distribution': 0.6527034195546078}\n",
      "epoch: 17 mean_loss: {'reconstruction': 0.10737812292013468, 'supervision': 0.001255810095351662, 'accuracy': 0.999481201171875, 'regularization': 0.20126976596883356, 'mlp_supervision': 0.0010732862092176214, 'label_distribution': 0.6529113015430383}\n",
      "epoch: 18 mean_loss: {'reconstruction': 0.10722992060147697, 'supervision': 0.0010504121697438664, 'accuracy': 0.9996337890625, 'regularization': 0.20123346378340573, 'mlp_supervision': 0.0008877443336206845, 'label_distribution': 0.6528552674403753}\n",
      "epoch: 19 mean_loss: {'reconstruction': 0.1074904659919537, 'supervision': 0.0013066175578932135, 'accuracy': 0.99957275390625, 'regularization': 0.2012013013011904, 'mlp_supervision': 0.0010365163711866668, 'label_distribution': 0.6529138495731179}\n",
      "epoch: 20 mean_loss: {'reconstruction': 0.10713740769989263, 'supervision': 0.0012069148500376005, 'accuracy': 0.999542236328125, 'regularization': 0.2011477604163011, 'mlp_supervision': 0.0011244425971347755, 'label_distribution': 0.6528563637536493}\n",
      "epoch: 21 mean_loss: {'reconstruction': 0.10744109979124153, 'supervision': 0.0009454466871274038, 'accuracy': 0.99969482421875, 'regularization': 0.20111690675967941, 'mlp_supervision': 0.0007589922436522152, 'label_distribution': 0.6530055992114342}\n"
     ]
    }
   ],
   "source": [
    "model = MNISTMultiAddLFL_MLP(n_hidden=8192, fuzzifier_layer_kwargs={'noise_scale': noise_scales[0]}, lfl_layer_kwargs=[{'noise_scale': noise_scales[1]}, {'noise_scale': noise_scales[2]}]).to(device)\n",
    "optimizer = MADGRAD([\n",
    "    {'params': model.lfl.parameters(), 'lr': lfl_lr},\n",
    "    {'params': model.cnn.parameters(), 'lr': cnn_lr},\n",
    "    {'params': model.mlp.parameters(), 'lr': mlp_lr},\n",
    "    {'params': model.reconstruction_layer.parameters(), 'lr': reconstruction_lr},\n",
    "])\n",
    "loss_records = []\n",
    "\n",
    "use_n_digits = [2, 3]\n",
    "loss_records_ = {n_digits: [] for n_digits in use_n_digits}\n",
    "for n_digits in loss_records_:\n",
    "    train_dataset = MNISTMultiDigitADDDataset(mnist_train, n_digits=n_digits)\n",
    "    dataloader = DataLoader(train_dataset, batch_size=batch_size)\n",
    "    for epoch in range(epochs):\n",
    "        mean_loss = train()\n",
    "        print(f'epoch: {epoch} mean_loss: {mean_loss}')\n",
    "        loss_records_[n_digits].append(mean_loss)\n",
    "        if mean_loss['supervision'] < 0.001:\n",
    "            break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "188ae5aa-9e1c-4046-9198-df5facd62325",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(l8 & l9) | (c0 & l0 & r4) | (c0 & l1 & r1) | (c0 & l2 & r5) | (c0 & l3 & r7) | (c0 & l4 & r0) | (c0 & l5 & r2) | (c0 & l6 & r9) | (c0 & l7 & r3) | (c0 & l8 & r8) | (c0 & l9 & r6) | (c1 & l0 & r2) | (c1 & l1 & r9) | (c1 & l2 & r0) | (c1 & l3 & r5) | (c1 & l4 & r8) | (c1 & l5 & r3) | (c1 & l6 & r7) | (c1 & l7 & r6) | (c1 & l8 & r4) | (c1 & l9 & r1) | (l4 & l5 & r5) | (r2 & r4 & r6) | (r3 & r5 & r9) | (r3 & r7 & r8) | (c1 & l3 & r3 & r9) | (l0 & l4 & l9 & r1) | (l0 & l5 & l6 & l9) | (l0 & l5 & l8 & r0) | (l0 & l5 & r4 & r9) | (l3 & l9 & r0 & r8) | (r0 & r3 & r6 & r8) | (r1 & r2 & r3 & r9) | (c1 & l2 & l3 & l9 & r8) | (l0 & l7 & r0 & r1 & r7) | (l1 & l4 & l7 & r0 & r7) | (l1 & l5 & l7 & r0 & r1 & r7),\n",
       " (c0 & l0 & r8) | (c0 & l1 & r6) | (c0 & l2 & r7) | (c0 & l3 & r9) | (c0 & l4 & r5) | (c0 & l5 & r4) | (c0 & l6 & r1) | (c0 & l7 & r2) | (c0 & l8 & r0) | (c0 & l9 & r3) | (c1 & l0 & r4) | (c1 & l1 & r1) | (c1 & l2 & r5) | (c1 & l3 & r7) | (c1 & l4 & r0) | (c1 & l5 & r2) | (c1 & l6 & r9) | (c1 & l7 & r3) | (c1 & l8 & r8) | (c1 & l9 & r6) | (l0 & r0 & r8) | (l1 & l6 & r7) | (l3 & l7 & r3) | (l7 & r5 & r8) | (l7 & r6 & r9) | (l9 & r4 & r7) | (c1 & l5 & r3 & r9) | (c1 & r0 & r3 & r9) | (l1 & r0 & r7 & r9) | (l3 & l4 & r0 & r1) | (l3 & l6 & r3 & r5) | (l3 & l8 & l9 & r7) | (l5 & r3 & r5 & r9) | (l2 & l3 & r5 & r6 & r9) | (l2 & l6 & r4 & r5 & r8) | (l7 & l9 & r2 & r3 & r9),\n",
       " (c0 & l0 & r0) | (c0 & l1 & r3) | (c0 & l2 & r9) | (c0 & l3 & r1) | (c0 & l4 & r7) | (c0 & l5 & r8) | (c0 & l6 & r6) | (c0 & l7 & r4) | (c0 & l8 & r5) | (c0 & l9 & r2) | (c1 & l0 & r8) | (c1 & l1 & r6) | (c1 & l2 & r7) | (c1 & l3 & r9) | (c1 & l4 & r5) | (c1 & l5 & r4) | (c1 & l6 & r1) | (c1 & l7 & r2) | (c1 & l8 & r0) | (c1 & l9 & r3) | (l0 & l4 & r7) | (l0 & l6 & l7) | (l1 & l8 & r7) | (l2 & r3 & r7) | (l3 & l5 & l7) | (l0 & l1 & l5 & r6) | (l0 & r6 & r7 & r8) | (l1 & r4 & r6 & r7) | (l3 & l5 & l6 & l7) | (l3 & l7 & l8 & r9) | (l3 & l7 & r0 & r5) | (l3 & l8 & r0 & r7) | (l7 & r1 & r3 & r9) | (r0 & r1 & r7 & r8) | (r0 & r3 & r5 & r8) | (r0 & r5 & r7 & r8) | (l0 & l2 & l5 & r0 & r7) | (l7 & r3 & r5 & r7 & r8),\n",
       " (c0 & l0 & r5) | (c0 & l1 & r2) | (c0 & l2 & r1) | (c0 & l3 & r6) | (c0 & l4 & r9) | (c0 & l5 & r0) | (c0 & l6 & r3) | (c0 & l7 & r8) | (c0 & l8 & r7) | (c0 & l9 & r4) | (c1 & l0 & r0) | (c1 & l1 & r3) | (c1 & l2 & r9) | (c1 & l3 & r1) | (c1 & l4 & r7) | (c1 & l5 & r8) | (c1 & l6 & r6) | (c1 & l7 & r4) | (c1 & l8 & r5) | (c1 & l9 & r2) | (l1 & l7 & r2) | (l3 & l9 & r9) | (l4 & l8 & r1) | (l7 & l9 & r9) | (r1 & r5 & r8) | (r3 & r8 & r9) | (l0 & r1 & r2 & r5) | (l2 & r1 & r5 & r7) | (l7 & r5 & r6 & r9) | (l9 & r0 & r3 & r5) | (c1 & l2 & l5 & r0 & r8) | (c1 & l7 & r0 & r3 & r7) | (l0 & l9 & r2 & r3 & r9) | (l4 & l6 & r4 & r8 & r9) | (l8 & r2 & r3 & r4 & r5),\n",
       " (c0 & l0 & r7) | (c0 & l1 & r4) | (c0 & l2 & r6) | (c0 & l3 & r3) | (c0 & l4 & r1) | (c0 & l5 & r5) | (c0 & l6 & r2) | (c0 & l7 & r0) | (c0 & l8 & r9) | (c0 & l9 & r8) | (c1 & l0 & r5) | (c1 & l1 & r2) | (c1 & l2 & r1) | (c1 & l3 & r6) | (c1 & l4 & r9) | (c1 & l5 & r0) | (c1 & l6 & r3) | (c1 & l7 & r8) | (c1 & l8 & l9) | (c1 & l8 & r7) | (c1 & l9 & r4) | (l0 & l2 & l3) | (l1 & l4 & r7) | (l3 & l5 & l8) | (l7 & l8 & r9) | (l7 & r2 & r8) | (l9 & r1 & r8) | (r3 & r7 & r8) | (l0 & l1 & r0 & r6) | (l0 & l1 & r0 & r8) | (l0 & l4 & l8 & r8) | (l0 & l6 & l9 & r4) | (l1 & l7 & l8 & r2) | (l3 & l6 & l9 & r8) | (l4 & r0 & r3 & r4) | (l8 & l9 & r1 & r9) | (l8 & r1 & r4 & r8) | (l9 & r0 & r3 & r5) | (l1 & l9 & r0 & r2 & r4) | (l4 & l5 & l7 & l9 & r4) | (l5 & l7 & r0 & r6 & r8) | (r1 & r2 & r4 & r6 & r9),\n",
       " (c0 & l0 & r9) | (c0 & l1 & r8) | (c0 & l2 & r3) | (c0 & l3 & r2) | (c0 & l4 & r6) | (c0 & l5 & r7) | (c0 & l6 & r4) | (c0 & l7 & r5) | (c0 & l8 & r1) | (c0 & l9 & r0) | (c1 & l0 & r7) | (c1 & l1 & r4) | (c1 & l2 & r6) | (c1 & l3 & r3) | (c1 & l4 & r1) | (c1 & l5 & r5) | (c1 & l6 & r2) | (c1 & l7 & r0) | (c1 & l8 & r9) | (c1 & l9 & r8) | (l3 & l5 & l9) | (l3 & r7 & r8) | (c1 & l3 & l9 & r1) | (c1 & l7 & r2 & r8) | (l5 & r1 & r3 & r5) | (l6 & r0 & r2 & r3) | (c1 & l4 & r1 & r7 & r8) | (c1 & l8 & r2 & r5 & r7) | (l4 & l5 & r0 & r2 & r8) | (r0 & r2 & r3 & r5 & r7) | (c1 & l1 & l4 & l5 & l9 & r6) | (l4 & l9 & r3 & r4 & r5 & r7),\n",
       " (c0 & l0 & r1) | (c0 & l1 & r0) | (c0 & l2 & r2) | (c0 & l3 & r4) | (c0 & l4 & r3) | (c0 & l5 & r9) | (c0 & l6 & r8) | (c0 & l7 & r7) | (c0 & l8 & r6) | (c0 & l9 & r5) | (c1 & l0 & r9) | (c1 & l1 & r8) | (c1 & l2 & r3) | (c1 & l3 & r2) | (c1 & l4 & r6) | (c1 & l5 & r7) | (c1 & l6 & r4) | (c1 & l7 & r5) | (c1 & l8 & r1) | (c1 & l9 & r0) | (l1 & l3 & l7) | (l6 & r8 & r9) | (c1 & r0 & r6 & r7) | (l0 & l1 & r0 & r2) | (l1 & l2 & l4 & r8) | (l3 & l8 & l9 & r2) | (l3 & r1 & r5 & r8) | (l3 & r2 & r3 & r5) | (l4 & l9 & r5 & r6) | (l5 & l9 & r2 & r3) | (l9 & r1 & r4 & r7) | (r0 & r1 & r3 & r6) | (c1 & l2 & l7 & l8 & r3) | (l0 & l1 & l8 & l9 & r7) | (l1 & l3 & l5 & l7 & r3) | (l3 & l6 & l9 & r4 & r9) | (l2 & l3 & r0 & r2 & r3 & r9),\n",
       " (c0 & l0 & r6) | (c0 & l1 & r5) | (c0 & l2 & r4) | (c0 & l3 & r8) | (c0 & l4 & r2) | (c0 & l5 & r1) | (c0 & l6 & r0) | (c0 & l7 & r9) | (c0 & l8 & r3) | (c0 & l9 & r7) | (c1 & l0 & r1) | (c1 & l1 & r0) | (c1 & l2 & r2) | (c1 & l3 & r4) | (c1 & l4 & r3) | (c1 & l5 & r9) | (c1 & l6 & r8) | (c1 & l7 & r7) | (c1 & l8 & r6) | (c1 & l9 & r5) | (l0 & l2 & l3) | (l0 & l6 & r4) | (l1 & r3 & r9) | (l2 & r8 & r9) | (l5 & l8 & r6) | (l5 & r3 & r7) | (l7 & r5 & r8) | (r1 & r3 & r7) | (c1 & l7 & r4 & r7) | (c1 & r3 & r7 & r8) | (l0 & l2 & l6 & l8) | (l1 & l2 & l7 & r4) | (l2 & l5 & r0 & r4) | (l3 & l4 & l9 & r2) | (l3 & l6 & l7 & r4) | (l3 & l6 & l7 & r8) | (l0 & l5 & l9 & r1 & r9) | (l0 & l5 & r5 & r6 & r7) | (l4 & l6 & l9 & r1 & r8),\n",
       " (c0 & l0 & r3) | (c0 & l1 & r7) | (c0 & l2 & r8) | (c0 & l3 & r0) | (c0 & l4 & r4) | (c0 & l5 & r6) | (c0 & l6 & r5) | (c0 & l7 & r1) | (c0 & l8 & r2) | (c0 & l9 & r9) | (c1 & l0 & r6) | (c1 & l1 & r5) | (c1 & l2 & r4) | (c1 & l3 & r8) | (c1 & l4 & r2) | (c1 & l5 & r1) | (c1 & l6 & r0) | (c1 & l7 & r9) | (c1 & l8 & r3) | (c1 & l9 & r7) | (l4 & l6 & r9) | (l4 & r5 & r9) | (r0 & r6 & r7) | (l1 & l4 & l6 & r4) | (l3 & l9 & r4 & r9) | (l4 & l5 & l6 & l9) | (l4 & l8 & r4 & r9) | (l4 & r0 & r2 & r9) | (l7 & r0 & r3 & r7) | (l9 & r0 & r7 & r8) | (r0 & r3 & r5 & r7) | (r0 & r4 & r7 & r8) | (c1 & l3 & l5 & l9 & r8) | (l6 & l7 & r2 & r5 & r7),\n",
       " (c0 & l0 & r2) | (c0 & l1 & r9) | (c0 & l2 & r0) | (c0 & l3 & r5) | (c0 & l4 & r8) | (c0 & l5 & r3) | (c0 & l6 & r7) | (c0 & l7 & r6) | (c0 & l8 & r4) | (c0 & l9 & r1) | (c1 & l0 & r3) | (c1 & l1 & r7) | (c1 & l2 & r8) | (c1 & l3 & r0) | (c1 & l4 & r4) | (c1 & l5 & r6) | (c1 & l6 & r5) | (c1 & l7 & r1) | (c1 & l8 & r2) | (c1 & l9 & r9) | (l1 & l8 & r0) | (l8 & r5 & r8) | (r3 & r7 & r8) | (c1 & l0 & l2 & l5) | (c1 & l0 & l7 & r8) | (c1 & l2 & l4 & r0) | (l0 & l1 & l3 & r8) | (l1 & r2 & r5 & r9) | (l2 & l6 & l8 & r4) | (l5 & l7 & r4 & r8) | (l7 & r0 & r2 & r6) | (l8 & r0 & r3 & r8) | (r0 & r1 & r6 & r9) | (r1 & r5 & r7 & r8) | (c1 & l0 & l6 & l7 & l8) | (c1 & l3 & l5 & l9 & r8) | (l0 & l4 & l5 & l7 & r9),\n",
       " (c0 & l8) | (c0 & r8) | (r0 & r7) | (c0 & l0 & r0) | (c0 & l0 & r1) | (c0 & l0 & r2) | (c0 & l0 & r3) | (c0 & l0 & r5) | (c0 & l0 & r6) | (c0 & l0 & r7) | (c0 & l0 & r9) | (c0 & l1 & r0) | (c0 & l1 & r5) | (c0 & l1 & r7) | (c0 & l1 & r9) | (c0 & l2 & r0) | (c0 & l3 & r0) | (c0 & l3 & r5) | (c0 & l5 & r0) | (c0 & l5 & r1) | (c0 & l5 & r3) | (c0 & l5 & r5) | (c0 & l5 & r6) | (c0 & l5 & r7) | (c0 & l5 & r8) | (c0 & l5 & r9) | (c0 & l6 & r0) | (c0 & l6 & r5) | (c0 & l6 & r7) | (c0 & l7 & r0) | (c0 & l7 & r1) | (c0 & l7 & r5) | (c0 & l7 & r6) | (c0 & l7 & r7) | (c0 & l7 & r9) | (c0 & l8 & r1) | (c0 & l8 & r3) | (c0 & l8 & r5) | (c0 & l8 & r6) | (c0 & l8 & r9) | (c0 & l9 & r0) | (c0 & l9 & r1) | (c0 & l9 & r5) | (c0 & l9 & r7) | (c0 & l9 & r8) | (c0 & l9 & r9) | (c1 & l0 & r0) | (c1 & l0 & r1) | (c1 & l0 & r3) | (c1 & l0 & r5) | (c1 & l0 & r6) | (c1 & l0 & r7) | (c1 & l0 & r8) | (c1 & l0 & r9) | (c1 & l1 & r0) | (c1 & l1 & r5) | (c1 & l1 & r7) | (c1 & l1 & r8) | (c1 & l2 & r8) | (c1 & l3 & r0) | (c1 & l3 & r8) | (c1 & l5 & r0) | (c1 & l5 & r1) | (c1 & l5 & r5) | (c1 & l5 & r6) | (c1 & l5 & r7) | (c1 & l5 & r8) | (c1 & l5 & r9) | (c1 & l6 & r0) | (c1 & l6 & r5) | (c1 & l6 & r8) | (c1 & l7 & r0) | (c1 & l7 & r1) | (c1 & l7 & r5) | (c1 & l7 & r7) | (c1 & l7 & r8) | (c1 & l7 & r9) | (c1 & l8 & r0) | (c1 & l8 & r1) | (c1 & l8 & r2) | (c1 & l8 & r3) | (c1 & l8 & r5) | (c1 & l8 & r6) | (c1 & l8 & r7) | (c1 & l8 & r8) | (c1 & l8 & r9) | (c1 & l9 & r0) | (c1 & l9 & r5) | (c1 & l9 & r7) | (c1 & l9 & r8) | (c1 & l9 & r9) | (l0 & l3 & l6) | (l0 & l4 & r9) | (l1 & l7 & r2) | (l1 & r1 & r2) | (l3 & l6 & r4) | (l3 & l8 & r8) | (l3 & r2 & r9) | (l4 & r5 & r9) | (l8 & r3 & r6) | (l0 & l1 & l2 & l8) | (l0 & l3 & l6 & l9) | (l0 & l5 & l7 & r9) | (l1 & l3 & r3 & r4) | (l1 & l7 & r7 & r9) | (l3 & r1 & r3 & r7) | (l7 & r0 & r4 & r9) | (l0 & l2 & l4 & l8 & r7),\n",
       " (l2 & r6) | (l3 & r3) | (l4 & r3) | (l7 & r4) | (r7 & r9) | (c0 & l0 & r4) | (c0 & l1 & r1) | (c0 & l1 & r2) | (c0 & l1 & r3) | (c0 & l1 & r4) | (c0 & l1 & r6) | (c0 & l2 & r1) | (c0 & l2 & r2) | (c0 & l2 & r3) | (c0 & l2 & r4) | (c0 & l2 & r5) | (c0 & l2 & r6) | (c0 & l2 & r7) | (c0 & l2 & r9) | (c0 & l3 & r1) | (c0 & l3 & r2) | (c0 & l3 & r4) | (c0 & l3 & r6) | (c0 & l3 & r7) | (c0 & l3 & r9) | (c0 & l4 & r0) | (c0 & l4 & r1) | (c0 & l4 & r2) | (c0 & l4 & r4) | (c0 & l4 & r5) | (c0 & l4 & r6) | (c0 & l4 & r7) | (c0 & l4 & r9) | (c0 & l5 & r2) | (c0 & l5 & r4) | (c0 & l6 & r1) | (c0 & l6 & r2) | (c0 & l6 & r3) | (c0 & l6 & r4) | (c0 & l6 & r6) | (c0 & l6 & r9) | (c0 & l7 & r2) | (c0 & l7 & r3) | (c0 & l9 & r2) | (c0 & l9 & r3) | (c0 & l9 & r4) | (c0 & l9 & r6) | (c1 & l0 & r2) | (c1 & l0 & r4) | (c1 & l1 & r1) | (c1 & l1 & r2) | (c1 & l1 & r3) | (c1 & l1 & r4) | (c1 & l1 & r6) | (c1 & l1 & r9) | (c1 & l2 & r0) | (c1 & l2 & r1) | (c1 & l2 & r2) | (c1 & l2 & r3) | (c1 & l2 & r4) | (c1 & l2 & r5) | (c1 & l2 & r7) | (c1 & l2 & r9) | (c1 & l3 & r1) | (c1 & l3 & r2) | (c1 & l3 & r4) | (c1 & l3 & r5) | (c1 & l3 & r6) | (c1 & l3 & r7) | (c1 & l3 & r9) | (c1 & l4 & r0) | (c1 & l4 & r1) | (c1 & l4 & r2) | (c1 & l4 & r4) | (c1 & l4 & r5) | (c1 & l4 & r6) | (c1 & l4 & r7) | (c1 & l4 & r8) | (c1 & l4 & r9) | (c1 & l5 & r2) | (c1 & l5 & r3) | (c1 & l5 & r4) | (c1 & l6 & r1) | (c1 & l6 & r2) | (c1 & l6 & r3) | (c1 & l6 & r4) | (c1 & l6 & r6) | (c1 & l6 & r7) | (c1 & l6 & r9) | (c1 & l7 & r2) | (c1 & l7 & r3) | (c1 & l7 & r6) | (c1 & l8 & r4) | (c1 & l9 & r1) | (c1 & l9 & r2) | (c1 & l9 & r3) | (c1 & l9 & r4) | (c1 & l9 & r6) | (l0 & l2 & l3) | (l1 & l8 & r7) | (l1 & l9 & r1) | (l1 & r1 & r2) | (l1 & r1 & r4) | (l2 & l9 & r1) | (l3 & l9 & r5) | (l5 & r3 & r8) | (l6 & l7 & r8) | (l6 & r0 & r7) | (l7 & r2 & r7) | (l8 & r5 & r8) | (r0 & r5 & r8) | (r2 & r3 & r8) | (r6 & r7 & r9) | (c1 & l2 & l5 & r9) | (c1 & l6 & l9 & r5) | (c1 & l6 & r0 & r2) | (c1 & l8 & l9 & r7) | (c1 & r0 & r3 & r9) | (c1 & r1 & r2 & r5) | (c1 & r3 & r5 & r9) | (l0 & l1 & l5 & r5) | (l0 & l3 & l5 & r7) | (l0 & l4 & l8 & r8) | (l0 & l5 & r4 & r9) | (l1 & l2 & l5 & r2) | (l1 & l2 & r1 & r8) | (l1 & l8 & r0 & r4) | (l2 & r1 & r5 & r7) | (l3 & l9 & r0 & r8) | (l4 & l5 & r0 & r5) | (l5 & l9 & r3 & r7) | (l5 & r2 & r4 & r9) | (l5 & r2 & r7 & r9) | (l8 & l9 & r1 & r3) | (l8 & r1 & r3 & r7) | (r0 & r1 & r7 & r9) | (r3 & r4 & r8 & r9) | (l0 & l3 & l7 & r0 & r6) | (l1 & l5 & l7 & r3 & r6) | (l3 & l4 & l6 & l9 & r3) | (l3 & l6 & r0 & r3 & r7) | (l4 & l5 & l9 & r3 & r8) | (l9 & r2 & r4 & r7 & r9)]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "learned_expression = model.lfl.expression([sp.Symbol(f'l{i}') for i in range(0, 10)] + [sp.Symbol(f'r{i}') for i in range(0, 10)] + [sp.Symbol(f'c{i}') for i in range(0, 2)])\n",
    "learned_expression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0e27d8f2-b672-458a-abdc-c9a84928a30f",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_name = 'MNIST Multi-digit Sum LFL-Type1'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "877bf22b-d781-427b-bb62-d94d4b39866f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x100 with 20 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reconstructions_folder = f'figures/{save_name}_digit_reconstructions'\n",
    "if not os.path.exists(reconstructions_folder):\n",
    "    os.makedirs(reconstructions_folder)\n",
    "encoding = torch.nn.functional.one_hot(torch.tensor(np.arange(10))).type(dtype).to(device)\n",
    "reconstruction = torch.clip(model.reconstruction_layer(encoding).reshape(-1, 28, 28) * 1.5, 0., 1.)\n",
    "plt.figure(figsize=(5, 1), dpi=100)\n",
    "for i in range(10):\n",
    "    reconstructed_image = reconstruction[i].detach().cpu().numpy()\n",
    "    reconstructed_image = np.round(reconstructed_image * 255.).astype(np.uint8)\n",
    "    empty_image = np.zeros((28, 28), dtype=np.uint8)\n",
    "    yellow_image = np.stack([reconstructed_image, reconstructed_image, empty_image], axis=2)\n",
    "    cyan_image = np.stack([empty_image, reconstructed_image, reconstructed_image], axis=2)\n",
    "    Image.fromarray(yellow_image).save(os.path.join(reconstructions_folder, f'{i}_yellow.jpg'))\n",
    "    Image.fromarray(cyan_image).save(os.path.join(reconstructions_folder, f'{i}_cyan.jpg'))\n",
    "    plt.subplot(2, 10, i + 1)\n",
    "    plt.imshow(yellow_image, vmin=0, vmax=1);plt.xticks([]);plt.yticks([])\n",
    "    plt.subplot(2, 10, 10 + i + 1)\n",
    "    plt.imshow(cyan_image, vmin=0, vmax=1);plt.xticks([]);plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3857d038-f74f-452c-ad95-eb5096725923",
   "metadata": {},
   "outputs": [],
   "source": [
    "# print latex formula for the paper\n",
    "\n",
    "# for i, expression in enumerate(learned_expression):\n",
    "#     exp_str = str(expression).replace('&', '\\\\wedge').replace('|', '\\\\vee').replace('c0', 'C_0').replace('c1', 'C_1')\n",
    "#     for j, j_ in [('l', 'yellow'), ('r', 'cyan')]:\n",
    "#         for k in range(10):\n",
    "#             exp_str = exp_str.replace(f'{j}{k}', '\\\\raisebox{-0.2\\\\height}{\\\\includegraphics[height=1em]{' + reconstructions_folder + f'/{k}_{j_}.jpg' + '}}')\n",
    "#     if i < 10:\n",
    "#         exp_str = '$y_{' + str(i) + '} = ' + exp_str + '$\\n'\n",
    "#     else:\n",
    "#         exp_str = '$C\\'_{' + str(i-10) + '} = ' + exp_str + '$\\n'\n",
    "#     print(exp_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a8c120c6-d9cc-4368-8afe-058f71e77141",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train dataset\tBCE loss: 0.0022486282532729962\taccuracy: 0.99951171875\n"
     ]
    }
   ],
   "source": [
    "dataloader = DataLoader(train_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'train dataset\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2cb2a766-20f2-4c04-a4ef-fd50fb5becf3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAJXCAYAAAB7SesVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAABOvAAATrwFj5o7DAACgrklEQVR4nOzdd3gU1dvG8e+mF0p6IRBC7x1CU0qA0BERUUQEpKgI+LOgIgiivAioiA1UehUivStVQHrvEBJCCakkBEgv+/6BWVmzgWSzSSazz+e69tKcaefO2YQns2dmNFqtVosQQgghhBmxKO4OCCGEEEIUNSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKIJXx8/NDo9Gg0Wj47rvvcl0vMzMTb29v3bqLFi3SW75o0SLdsm7duuW6n8GDB6PRaPj5558Nbt+uXTuD223evJlevXrh7e2NjY0Nzs7O1KhRgz59+jBr1ixiYmIA+Oyzz3T9yOtr8ODBT/0+Pb7fRo0aPXHdsWPH6tbNLU9+ZR//v9/3p9m7d2+eM+ZVWFiYwWymPlb2e9PUzp07x9ChQ6lSpQp2dnaUKlWKSpUq0bFjRz777DPOnz9v8mMWhXbt2uXrPfL4z35ur3v37unWz/7Z/eyzz/Ldt+xt8/My5jhFITY2lgULFvDWW2/RtGlTbGxsFN3fJymsnzG1siruDojCs2TJEt555x2Dy/744w8iIyPztJ9t27Zx8OBBWrVqZZJ+jRw5kjlz5gBQr149WrVqhaWlJVevXmXDhg2sW7eOqlWr0qNHDxo2bMigQYNy7GPx4sUAvPDCC5QqVUpv2TPPPJOv/pw+fZrz589Tt27dHMsyMzNZvnx5vvZXEIMHD2bx4sXs2bPHZMWW0mk0GipWrEhYWFi+t122bBlDhgwhIyODChUq0KFDB8qWLcutW7c4ePAgu3bt4uHDh3z99dem77hCde7cGS8vL4PLbGxsTHIMQz9jDx8+ZM2aNQAGf2YbNmxokmOb2oEDBxg6dKjJ9rd3717at2/PoEGD8v0HjihaUgCpVOPGjTl58iQXLlygTp06OZYvWbIEgCZNmnDixIlc92Nvb09ycjITJkxg9+7dBe7Xhg0bmDNnDqVLl2bTpk20bdtWb3l0dDQrV67E09MTgN69e9O7d+8c+8kugL7++mv8/PyM7k/292nx4sV89dVXOZbv2LGDiIiIp36fioq/vz+XLl2ibNmyJe5Yu3btIj093ST7AoiIiGDEiBFkZGQwa9YsRo8ejYXFvye1k5OT2bx5M2lpaSY7Zknw8ccfF3rxPGzYMIYNG6bXFhYWpiuAStI//J6enrqzP02aNGHp0qV88803xd0to5j6Z0zt5CMwlXrttdeAfwudxyUkJLBhwwZatmxJ1apVn7ifrl27UrlyZfbs2WOSAuj3338HYNSoUTmKHwAPDw/GjBlDs2bNCnysvOjQoQM+Pj6sWLGCzMzMHMuzC63s72dxc3BwoGbNmnh7e5e4Y1WpUoWaNWuaZF8AW7ZsITk5mZYtW/LOO+/oFT/wqHh/8cUXGTBggMmOKdSnZcuWzJ49m9dff50GDRpgZVVyzwuY+mdM7aQAUqmOHTvi7e3N8uXLycrK0lsWFBRESkpKnv5Rt7a2ZtKkSQBMmDChwP2Kjo4G0J3hKW4WFhYMGDCAO3fusHPnTr1l9+/fZ8OGDTRv3pzq1asb3P5p82Sy50LlZT6BRqPRFVzt27fXmz+xd+/ePB3vSa5evcqLL76Ii4sLjo6O+Pv7s3LlylzXf9KxkpOTmThxIlWqVMHW1paKFSsyduxYEhMTdXNX/vuR1n/nJ2R/bwBu3LihlzcvZ/WMfS89bUxym5+VPe9l7969/PXXX3Ts2JGyZcvi7OxM7969CQ4OBiArK4tvvvmGOnXqYG9vj4+PDx999JHZnYmCR+8TV1dXbG1tdfP6/uvu3bvY2dlRunRpHjx4AOi/92JiYnjjjTfw8fHBzs6OGjVqMHXq1Fy/n5mZmcydO5dnnnkGJycn7O3tqVOnDlOmTCE5ObnQssKj90j79u2BR3885TY3MftnQavVMmfOHJo0aUKpUqVwcnLSrbN582aGDRtGnTp1dDlq1KjB+++/T2xsrMHj5zYHKPtnKisri1mzZlGnTh3s7Ozw9PRk8ODBREVFmfT7UFJIAaRSlpaWDBgwgPDwcHbt2qW3bMmSJdja2vLSSy/laV8DBgygZs2aHDp0iC1bthSoXxUqVAAe/XLI/mVX3HI7W/b777+TnJxcZGd/Bg0aRJUqVYBH8zgGDRqke+U2pyOvzpw5g7+/P6tXr8bd3Z1evXphY2ND//79+fbbb/O1r/T0dLp06cIXX3xBbGwsXbt2pUmTJsydO5cOHTrk+R/6qlWr6uaKODo66uXt27fvU7fPfi/t2rWLS5cu5StDQWzYsIEOHTrw4MEDunbtipeXFxs2bKBNmzbExMTQr18/Jk6ciJ+fH4GBgSQlJTFjxgzefPPNIuujUtjb2zN48GDS0tJYuHChwXUWL15MamoqAwYMoHTp0nrL4uLiaN68OWvWrKFly5Z06tSJ8PBwxo8fz3PPPZfjrG1KSgpdu3ZlxIgRnD9/nqZNm9KlSxfu37/Pp59+SocOHQq1CHrmmWfo3Lkz8OhszOPvaUPzpt5++23GjBlD2bJl6dmzp950hcGDB7Ny5UpKly5Np06d6NSpE8nJycycOZNmzZrlWlA+ycCBAxk3bhwVKlSge/fuWFpasnjxYgICAkhNTTU+eEmlFapSsWJFLaC9dOmS9uzZs1pA++qrr+qWh4SEaAHtCy+8oNVqtdqXXnpJC2gXLlyot5+FCxdqAe1LL72k1Wq12qCgIC2gbdSokTYrK0u33qBBg7SAds6cOQa3b9u2rV77wYMHtRYWFlpA6+rqqh02bJh2wYIF2pMnT2ozMjLynBPQAtrr16/neZvHTZo0SQtoP/roI61Wq9U2btxY6+DgoL1//75unWeffVZrY2OjvXv3rnbbtm0G8+zZs0cLaAcNGmTwONnfh0mTJhk8/n+/79nfzz179hjc39OOZ0hWVpa2fv36WkD7v//9T5uZmalbtnbtWt145DXbtGnTtIC2Tp062qioKF17dHS0tl69ermOTfZ7878AbcWKFfOcJ1tCQoLW09NTC2htbGy0zz//vPa7777T7tu3T5uYmJjrdrmNSbanjY1Go9H+/vvvuvbMzExt//79dd+TGjVqaG/fvq1bfuPGDa2Li4tWo9Hk6/3atm1bg/3ITfb3N7f3zn9l58nt+5Bf169f143944KDg7UajUZbpUoVvd8d2WrUqKEFtKdOndK1Zb/3AG2bNm20CQkJumW3bt3SVq1aVQtov/vuO719jR49Wgtoe/TooY2NjdW1p6SkaAcPHqwFtB9//PETc3z00UcF+r7k5Wc0e6ycnZ21J0+eNLjOmjVrtA8fPtRrS09P106YMEELaN94441c9/tf2d/LKlWqaMPCwnTtCQkJ2mbNmmkB7aJFi/KYUD3kDJCK1atXj4YNG7Ju3ToePnwI/HuWI79nNfr27UvDhg05deqUbqKjMVq2bMlvv/2Gu7s7d+/eZd68ebz++us0btwYFxcXhg0bZtTVQAX12muvkZSUxOrVqwG4fv06Bw4coHv37ri4uBR5f0xp3759nD17Fi8vL6ZNm6Y3V+b555+nT58++drf7NmzAZg+fToeHh66dnd39yK92qpMmTLs2LGDevXqkZaWxrp163jnnXdo06YNTk5OdOvWjf3795v8uC+//LLeGSoLCws+/PBDAC5cuMD333+Pj4+Pbrmvry+vvvoqWq2Wv/76y+T9+a//fnya/Zo1a1ahH9uQqlWr0qlTJ0JCQnJ8zLx3716uXLlC8+bNDV4lptFomD17NmXKlNG1lS9fnmnTpgHo3eojJiaGX375BXd3d5YtW4arq6tuma2tLT/99BOenp78+uuvOaYFFJcPP/ww19tw9OnTB0dHR702KysrvvjiC8qVK2fU7+Hvv/+eihUr6r4uU6YMY8eOBdB9zG5OpABSuUGDBpGYmMiaNWvQarUsXboUd3d3unbtmq/9aDQaPv/8cwAmTZpUoF8g/fr1IywsjJUrVzJs2DAaNmyIpaUl9+/fZ/78+TRo0IDDhw8bvX9jvPLKK1hbW+sKxCVLlqDVag1ezlvS7Nu3D3hU7Nja2uZY/uqrr+Z5Xzdv3uTmzZuUKlXK4P2hAgMDi7RgrFevHmfOnGHXrl188MEHtG7dGgcHB9LT09m2bRtt27blp59+Mukxu3TpkqMt+2ICa2trOnTokGN5tWrVALhz545J+2LIfz8+zX7Vrl270I+dm5EjRwLwyy+/6LVnf53bx4MNGjQweBVrnz59cHBwIDQ0lPDwcODRP+BpaWm6WyH8l4ODA02bNiUuLk43X6u4GbrC9XE3btxg9uzZ/O9//2Po0KEMHjyYwYMHk5GRQWxsLPHx8Xk+lpWVFYGBgTnasydNF8V7U2lK7nR3kSevvPIKY8eOZcmSJVSuXJnQ0FDGjBmDtbV1vvfVs2dPmjdvzpEjR1ixYkW+/uH8LwcHB1566SXdPKS4uDhWrlzJhAkTiI+PZ/DgwVy+fNno/eeXu7s7Xbp0YfPmzdy4cYOlS5fi5ub2xJtAKsWBAweYN29ejvaPP/6YmjVr6v6BePwvv8fl5zYC2b8kK1SokOsN13x9fYmLi8vzPgtKo9EQEBBAQEAAAKmpqfz555989NFHXLp0iXfffZeePXvi6+trkuOVL18+R1v2vai8vLywtLTMdXlRzLMw9WXwly9f1p1xedywYcPyfM+tHj164Ovry4YNG4iMjMTLy4uYmBjWrl2Ls7NzrvMRc3tvajQafH19uXz5Mrdv38bHx4fr168DsHLlyidO7odHNz+sUaNGnvpemHL7mYRHF51MmzbN4NWp2e7fv4+zs3OejuXt7W3wCrfseVfmOAdICiCV8/DwoHPnzmzbto2pU6cCBbuke8qUKXTq1InPPvuMl19+2VTdxMXFhZEjR1K+fHmee+45rly5wtWrV3O9+qowvPbaa2zatImRI0cSEhLCqFGjjCoUH1cUp9qvXbumu3rscYMHD9a7JNZc7hBra2tLz549adasGVWqVCEpKYnt27czYsSIPG3/tDH77+X2eV1WUkVGRhp8f7Vr1y7PBZClpSUjRoxgwoQJLFiwgE8++YRFixaRlpbGW2+9hb29fYH7mT1uderUoWnTpk9c9/GPx4pTbrlXr17N//3f/1GuXDlmzpxJq1at8PDw0J3BbdWqFYcOHUKr1eb5WGp8bxaUFEBm4LXXXmPLli1s376dOnXq0KRJE6P31bFjR9q2bctff/2V61UdBZH9Vzw8+iutKAugnj174uzszNatW4G8FYrZd9bN7Yq2mzdvmq6Ducg+LZ6b7PkoN27cMLg8P3OuypUrB8CtW7dyXacoMueFl5cXtWrV4sSJE3qXDSthzEqSdu3a5esf2twMGzaMzz//nLlz5/LRRx8xd+5cAN54441ct8ntPavVanXjlP3+zr4qsFmzZoXyu6koZc9F/OWXX+jRo0eO5deuXSvqLqmSlIRmoFevXvj5+eHq6mqSW77/3//9HwBffPFFvk+bPu0X6eOfzRv6qKEw2draMmjQIFxdXfH398/TzRizC4IrV64YXP7nn3/mqw/Z/zhnZGTka7snefbZZwFYt26dwfFasWJFnvfl6+uLr68vDx8+ZNu2bTmW79y5M98ff1lbWxuV92nvpczMTN3HIo+/l540ZqmpqWY5GbQoeHp60qdPH8LCwvjoo48IDg6mTZs21KpVK9dtTp8+bfAWB+vXrycpKYlKlSrpxjYgIAArKyu2b99e6Pf7eRJT/Axn/wxlF3WP27Fjh1GXwIucpAAyA3Z2dly/fp3Y2FjefffdAu+vdevWdOnShVu3brFx48Z8bZv9V+Dt27dzLLt165buY4rmzZubbM5Gfnz77bfExsZy5MiRPK3v5+eHn58fFy5c0Jt3kJWVxeTJkzl06FC+jp/9j7Mp72vTtm1b6tatS0REBOPHj9crHDZu3Jjvq0myJ7R+9NFHer+I7969ywcffJDv/pUrV46oqKh8TegEmDNnDsOGDePUqVM5lj18+JA33niDuLg4SpUqpTfpv1mzZjg6OrJ9+3b+/vtvXXtqaiqjR4/O9ayDKLjs9072oyaedm8krVbLyJEj9c7WhYeH8/HHHwMwevRoXbu3tzcjRowgMjKSF1980eDvmNu3bxu8O74pmeJnOPuj659++knvI9mQkBCzvJ9UYZGPwIRRpkyZwvbt20lKSsrXdnfv3mXBggV89tln1K5dmxo1amBtbc3t27c5cuQIGRkZlCtXrkQ9S2jKlCm8+uqrvPLKK8yePRs3NzdOnz5NdHQ0o0eP5ocffsjzvnr16sXnn3/O2LFj2bFjh+4y87Fjxxo9aVOj0bBkyRLatWvHN998w+bNm2ncuDG3bt3i77//ZvTo0Xz//fd53t97773H1q1b2bdvH9WqVdNddr1nzx6qVatGixYtOHz4cJ4fvNm7d2++++47GjVqROvWrbG3t8fNzc3gxNvHpaWlMX/+fObPn0/58uVp0KABZcuWJSoqiuPHj5OQkICNjQ0LFy7E3d1dt52joyPjxo1jwoQJtG/fnjZt2uDo6Mjx48fJzMxkyJAhivoI5YsvvuDnn382uKx06dLs2LGjQPufN28e27dvz3X5zp07czxw2FjPPvss9erV49y5c7i7u/PCCy88cf2ePXty7tw5KleuTLt27UhLS2PXrl0kJibSqVMnxowZo7f+zJkzuXHjBlu2bKFatWo0atSIihUrkpqayuXLl7l06RINGjTI8fF2ixYtdP+f/fHuf78veb0y1c/PjwYNGnDy5EmaNm1KnTp1sLa2pnXr1gwZMiRP+xgzZgyLFy9m7ty57N27l8aNGxMXF8dff/1FixYt8PLy4uDBg3nal8idFEDCKE2aNOH5559n3bp1+drup59+omfPnuzYsYMLFy6wd+9e7t+/T+nSpfH396dbt268/fbbereEV7oBAwZgbW3N9OnTOXr0KPb29rRt25apU6dy9OjRfO2rcePG/Pbbb3zzzTfs2rVLV2C++uqrBbpqpVGjRhw5coTx48eze/du1q9fT+3atVm6dCmtW7fOVwFkbW3N9u3bmTp1KsuXL2fr1q26W+p/8cUXNGzYEI1Gk+erU7In569fv56goCAyMjKoWLHiUwugoUOHUrFiRf7880+OHTvGyZMniYmJwc7OjkqVKtG+fXtGjRqluwT9cePHj8fJyYmffvqJ/fv3U7ZsWTp37syXX35p8Iq64hQaGkpoaKjBZaZ4UG14eLjuSkFDTPlxLDx6/t65c+cYMmTIU4tkFxcXDh8+zCeffMLWrVuJi4ujYsWKvPbaa4wdOzbHFXe2trZs2rSJlStXsmjRIk6ePMnx48dxdXWlfPnyfPzxx/Tr1y/HcQyd8X3a9+VJ1q5dy4cffsi+ffs4deoUWVlZZGRk5LkAqlq1KidOnGDcuHEcPHiQDRs2ULFiRcaNG8e4ceN0d5sWBaPRmmJ2mxBC8GgCceXKlalevToXL14s7u4IhcnMzMTPz4/w8HCCg4N1j375r71799K+fXsGDRpUos4Gi5JF5gAJIfLt1KlTOe5PEhERwaBBg8jMzGTgwIHF1DOhZAsXLuT27dv06NEj1+JHiKIiH4EJIfJtyJAh3Llzh/r16+Pu7s6dO3c4ceIEiYmJtGjRgvfee6+4uygU4u7du7oJ81u3btU9zkGI4iYFkBAi395++21+++03Lly4QFxcHNbW1tSoUYN+/foxZswYg4/cEObpwYMHzJ8/H2tra2rXrs2UKVNo0KBBcXdLCJkDJIQQQgjzI3OAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF25DL4xyXFFncPhBBClBAr2nsVdxdM4pU9kcXdhYJzcMv3JnIGSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2bEq7g6Yg6ysLJasCGLlmg3cDo/A1cWZbp07MObNYdjb2xV39/JEDRlAciiJGjKAOnKoIQMUfw5H74o8tz7E4LLoM3+zc0Rb3dcW1jbUGTwOv84v4+DpS9qDeML3b+bMz5+SGh+jW8/S1g6/rq9S/pkeOFWth62zB8kxt4k+tZ9z874gKeqW3nE8m7Sn+kujcK5WHztnD7Iy0nkYHsr1bcsIXvsLWWmphRP+P4p7LPJCo9VqtcXdCcVIii2U3U6ZMYulv/1Op4A2tGndkpDQMJatWo1/k0YsmDMLjUZTKMc1JTVkAMmhJGrIAOrIoYYMUPQ5VrT30vs6uwC6tWcdt/au01uWEh9D5JEdj77QaGj/3Ta8m3fk5u41RB7bjYNHeaq/OJLk2Aj+eL0lGYkPAChTsQbdV54j+tR+Io7sICUuirKValOtzwiyMjPYMbwNCaEXdMep1vctvJsHEnf5BMmxEVha2+Le6FkqdnyRiMN/suedbjlyvLIn0qTfFyiG95SDW743kTNAhSw4JJRlK1cTGNCWH76Zqmsv7+PNlBmz2LZjN90COxRjD59ODRlAciiJGjKAOnKoIQMoK8e9a+cI274i1+Xl2z6Hd/OOXF09h+Nfjda1hx/YTODc/dR+dSxnf5kIPCqctr3WlHvBZ/X2cefvrXSYvYN6wydyYNxLuvbg1XMIXj1Hb92rq2eTei+G6n1H4lyzMfGXT5oiZq6UNBZPInOACtnm7TvRarUMGtBPr71fn17Y29mxccsfxdSzvFNDBpAcSqKGDKCOHGrIAMrLYWFji6WtvcFlno0ffRR2fdsyvfa754/w4FYwlboO0LWl3Y/LUfwARJ3YQ2rCXcpWrpOn/iRG3ATAppRTntYvCKWNRW7kDFAhO3/hEhYWFtSvW1uv3dbWlpo1qnH+4uVi6lneqSEDSA4lUUMGUEcONWQAZeWo+cq71Bv+6AxOYsQNQjYu4MLi6WgzM4BH838AMlOScmybkZxImYo1sHV215sL9F/WjmWwcihN6vVLBpdb2TtiaWOHlUNp3Ou3pNbAD0iJi+bupWMFjfdUShqLJylxZ4C0Wi1JSUmUlKlL0TGxODuVxcbGJscyTw93YmLvkpmZWQw9yzs1ZADJoSRqyADqyKGGDKCMHNqsLCKP7ebMnAn89X5vjvzfCB6Eh1L/jck8Oy1It17CP0WLR+O2etvbuXhQxq8mAA4e5Z94rDqDx2FpbUPY9uUGlzf94Hte+DOK59Zfo9XnS3l4O4Q973TTzS0qTEoYi7woEWeAVq9ezbJlyzh27BiRkf9O1vLy8qJZs2YMGDCAF198MV/7DA8PJzw8XK/Nx8Uen3LeJulztuSUFINvAgDbf9pTUlNxdHAw6XFNSQ0ZQHIoiRoygDpyqCEDKCNHUtQtdo8K1GsL2biAVp8vxa9zf3ye6UH4gc2EbV9O3SGfUP+NyWQkPyTq+B7s3X1oNHo6GstH/yxb2eXeT59nelDr1feJPL6Ha+vnGVzn4rKvub59BXbO7ni3CKRMxZpYlyprurBPoISxyAtFnwFKTk6mc+fO9OvXj507d1KpUiX69u3Lq6++St++falUqRI7d+7k5ZdfJjAwkOTk5Dzve+7cuTRv3lzvNXfhUpNnsLezIy0tzeCy1H/a7WxtTX5cU1JDBpAcSqKGDKCOHGrIAMrOcWHhlwB4t+wMQNr9eHaP6UpS5E1aTJjHc+tDCJy7j5S4KEI2zAcgPfG+wX15NGpD6/9bwb2Qc+z/+EXI5dOQ+9cvEXVsFzf+XMnhz1/nzsFttP9+m+4MU2FS8lg8TtFngCZNmsSePXv4/vvvGT58OLYGvmGpqan8+uuvvP/++3z22WdMnz49T/sePnw43brpXw7o42J4wlpBeLi7cS00jLS0tBwVcVR0DO5urlhaWpr8uKakhgwgOZREDRlAHTnUkAGUneNhRBgAtk7/Xqp9L/gMWwc0onSFati5epEYeYOkyJu0nrKcrIwMHtzOeT8ht3otafvNBhIjwtg9ugvpD+7luQ9h25dTf8Qk/LoM4OzPnxY00hMpeSwep+gzQCtXrmTMmDGMGjXKYPEDjyZVjR49mtGjR/Pbb7/led8+Pj74+/vrvUz98RdA3Tq1yMrK4uz5i3rtqampXL4STN3ahV+NF5QaMoDkUBI1ZAB15FBDBlB2jtIVqgGQEheVY9mDW8HEnN5PUuRNNJZWeDZpT8yZAzkmSLvW8afdrM0k341g19uBT5wgbUj2FWk2pZ2MC5EPSh6Lxym6AIqOjqZWrVp5Wrd27drExOTvDVEUugV2QKPRsHh5kF570NqNJKek0LNrYC5bKocaMoDkUBI1ZAB15FBDBlBGDpsyLjnaNBYWNHhjMgDhB7Y8cft6wydh5+LBhcX6n2Q412xM+++2knovll0jO5JyN/cbF9q5eBhsr/7iSADuXjj6xD6YghLGIi8U/RFYpUqV2L59O0OHDn3qulu3bsXPz6/wO5VPNapVYUC/PixbtYZR74+jbeuWhFy/wdKVv9PCvwndOhf/zaCeRg0ZQHIoiRoygDpyqCEDKCNH809+wcqhNLHnD5MUdQs7Zw98O/bFuVoDQrcs+fdO0EDbmRt5GB5KwvVLaCws8HmmB+Vadub8gql66zl4+RLw/TasHEpzadk3eDZpl+O4j990sdPc/dwPu8zdi8dIig7Hztkdn2d64N6gFVEn9xH2R+43aDQVJYxFXij6URjffvst77//Pn379uV///sfzZo1w9raWrc8PT2do0ePMmvWLNauXcvXX3/Nu+++a/wBC+lRGJmZmSxeHsSqtRsIvxOJi7MT3Tt3ZPRbQ3GwN/28o8KghgwgOZREDRlAHTnUkAGKPsd/H4VRuecQKnV9lTJ+NbAp40JWWgr3rp0nZNMCQjct0lu37tAJVOzUD0evimizMom7cporq77n9t71eut5NG5Lxzm7ntyP5v+ey6j5yrv4PNuTMn41sC3jQmZqMgnXL3FjxyqCV88hKyM9x/aF8SiMIn9PGfEoDEUXQFqtlv/973/8+OOPAFhYWODm5oatrS2pqanExsaSlZUFwNtvv813331XsOeLFFIBJIQQQn3+WwCVVIVRABU5tRVA2S5evMiKFSs4fvw4d+7cISkpCQcHB8qVK0ezZs146aWXqFu3bsEPJAWQEEKIPJICSEHUWgAVGSmAhBBC5JEUQApiRAGk6KvAhBBCCCEKgxRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIs6PRarXa4u6EUnxW07q4u2ASn52MKO4uCCGEEEXHwS3fm8gZICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZsequDtQEjg4u9F25Hiqt+9OaY9ypCTEE3HpNNu/fJ+716/i59+GwUt2PXEf37SpyIPoOwaXBbwzmTZvfULK/XtM83fXW1ajfQ9qde5D+Qb+lPWqQHJCHJGXz7L/l2ncOnXIZBmfJisriyUrgli5ZgO3wyNwdXGmW+cOjHlzGPb2dkXWj4KSHMqhhgygjhxqyACSQ0lKQgaNVqvVFncnlOKzmtY52pwrVGbI0l1kZWZwet0SEu7cwt7JmXJ1mnB0+RxunvwbR1cPqrTqmGNbB2c3unzyDREXT/NLn2YGj+lWuSZvrj9OVno6WZkZOQqgD/bfIuXBPS7t3EDcjRBKuXnS9KXhlC3ny7qPhnBmw7KcOU5GGPkdyN2UGbNY+tvvdApoQ5vWLQkJDWPZqtX4N2nEgjmz0Gg0Jj9mYZAcyqGGDKCOHGrIAJJDSYo8g4NbvjeRM0BP8cJXS0iMi2XRwABSEx8YXCfxbjRnN63I0d7itTEAnFq7KNf995j8E6EHd2Hj4IhXzQY5lq/+4FXCjvyl13by9/mM3HyGTmOncXbjcgq7hg0OCWXZytUEBrTlh2+m6trL+3gzZcYstu3YTbfADoXaB1OQHMqhhgygjhxqyACSQ0lKSgaZA/QEfs3bUr5hc/b88BmpiQ+wtLbB0tomz9s37DOIjNQUzhkojgAa9RmMT71mbJvyv1z38d/iByAxLoYbx/dTys0TR1ePPPfHWJu370Sr1TJoQD+99n59emFvZ8fGLX8Ueh9MQXIohxoygDpyqCEDSA4lKSkZ5AzQE1R9pjMAqQ8SGLJ0N75NWqOxsCDi4ml2zvyEkAM7ct3Wu05jvGrW5/yWVSQnxOdY7uDkSqexX3Jg7gzib1/Pd9/KeJYnMy2NlAcJ+d42v85fuISFhQX169bWa7e1taVmjWqcv3i50PtgCpJDOdSQAdSRQw0ZQHIoSUnJIGeAnsDVrxoA/b5bRcrDBFa/N4DNk97GwdmVAb9sonLLgFy3bdRnEJD7x1+BH39Fyv17/D33q3z3q+qznSnfwJ+LO9aSkZqS7+3zKzomFmenstjY5Dz75enhTkzsXTIzMwu9HwUlOZRDDRlAHTnUkAEkh5KUlAxSAD2BrWNpAGJDr/DbW89zYftqjq/6lcWDA9FmZRHwvy8MbmdpbUO97i9zL/wGoQdzXh3m59+Ghr0HsnXK/8hIS81Xn5x8KvL89IU8jInkjy8/yH8oIySnpBh8IwPY/tOekpq/HMVBciiHGjKAOnKoIQNIDiUpKRlUVQAtW7aMgIDcz8o8Ljw8nKNHj+q97qfrTyZOT00GyHGlVdyNa9w6fQifek2xtnfIse9anXpj7+TC6fVLckxQtrS2psdnP3Hpz3Vc25+/z0FLe3jz2oLtWFpZs/yNXjyMjcrX9sayt7MjLS3N4LLUf9rtbG2LpC8FITmUQw0ZQB051JABJIeSlJQMqiqAbty4wV9/5Zw0bMjcuXNp3ry53utkQpbeOg+iHt2352FsZI7tH0ZHoLGwwK502RzLGvYZhDYri9NrF+dY5j/gbZwrVOHo8tm4+FbRvaxs7dFYWODiW4Uynj45tnN0cee1hX/g6ObJshE9ibh4Kk85TcHD3Y34ewkG39BR0TG4u7liaWlZZP0xluRQDjVkAHXkUEMGkBxKUlIyqKoAyo/hw4dz5MgRvVfjsvrfjvCzx4BHE47/q4xXeTLT00m+F5ejvXLLDlw/vId74TdybFfWuwKW1tYMWryDMX9e1r3KN/DHtlQZxvx5mX7frdLbxsHZjUGL/qSsty8r3ujF7dOHCxo/X+rWqUVWVhZnz1/Ua09NTeXylWDq1q5ZpP0xluRQDjVkAHXkUEMGkBxKUlIyKL4Aaty4cZ5fs2fPzvN+fXx88Pf313uVsda/MdPl3RtJTXxA4xdfx+KxatWzRn3KN2xB2NG/cszhadh7IBaWlpxcs9DgcU+tXUzQOy/leEUHXyAtKZGgd15i57fjdevbl3XmtYV/4FyhMr+91Zsbxw/kOaOpdAvsgEajYfHyIL32oLUbSU5JoWfXwCLvkzEkh3KoIQOoI4caMoDkUJKSkkHxd4K2sLCgVKlSuLq6PnXdhIQEEhISjJ5dbuhO0M36v0n3ST9w8+RBzm8Nwr6sM80HjsLK2pYFA9oRefmM3vpj/riEfVkXvmnjm68JzoOX7MSrZoMcd4IeseYI5eo05vT6pYT+vTPHdiEHd5J4N1o/RyHcCfqLaTNZtmoNnQLa0LZ1S0Ku32Dpyt9p2rghi37+rkTcmRQkh5KoIQOoI4caMoDkUJIiz2DEnaAVXwBVqlSJmjVrsm3btqeuO2XKFCZNmmTSAgigTtcXafX6e3hUq0Nmeho3ju1j16yJRF89r7dexWbPMmTpbo4un8PWL8bk69i5FUCfXU5/4naLXutA2NF9+tsUQgGUmZnJ4uVBrFq7gfA7kbg4O9G9c0dGvzUUB3t7kx+vsEgO5VBDBlBHDjVkAMmhJEWeQY0F0Isvvshff/1FdHT0U9f9v//7PyZOnGjyAqikKYwCSAghhFAsIwqgEjEHKDY2lrCwsKeuW7FiRdq0aVP4nRJCCCFEiab4M0BFSc4ACSGEECWQGs8ACSGEEEKYmhRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIsyMFkBBCCCHMjhRAQgghhDA7UgAJIYQQwuxIASSEEEIIs6PRarXa4u6EYiTFFncPhBCFZGk7r+LugkkM3BtZ3F0QQnkc3PK9iZwBEkIIIYTZkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZsSruDpiDrKwslqwIYuWaDdwOj8DVxZlunTsw5s1h2NvbFXf38kQNGUByKElxZ3D0rkifDSEGl0Wf/ps/RrTVfW1hbUPdweOo1PllHL18SXsQz+39mzk951NS4mP0tm01cT5VegwyuN8db3cm8tguvbaylWtT//XxuNVrgZ2zBylxUUSd3s/5RdO5H3a5gCnzprjHwlQkh3KUhAxSABWBqV9/z9LffqdTQBteH9ifkNAwlqwI4vKVYBbMmYVGoynuLj6VGjKA5FASpWS4uWcdN/es02vTK2o0GgJmbsS7eUdu7FrDpd9m4eBRnhovjsSj4TNsG9KS9MQHOfZ7YOJrOdruhZ7X+9qpSl26LjxI2v14rq6bS3JMOKUrVKN6nxH4tu3Nltea8eDWNdMEfQKljEVBSQ7lKAkZpAAqZMEhoSxbuZrAgLb88M1UXXt5H2+mzJjFth276RbYoRh7+HRqyACSQ0mUlCH+2jmub1+R6/IKbZ/Du3lHrqyew9EZo3Xtt/dvpsu8/dQZOJbTP0/Msd2T9pmtep8RWNk5sH3oM8QHn9W1x54/TLuv1lKpyyucnft5PhPlj5LGoiAkh3KUlAwyB6iQbd6+E61Wy6AB/fTa+/Xphb2dHRu3/FFMPcs7NWQAyaEkSstgYWOLpa29wWVeTR59FBa6dZlee+z5I9y/FUylrgNy3a+1Y2l4wl+61qXKApAUc0evPSkmAoCM5MSnd76AlDYWxpIcylFSMkgBVMjOX7iEhYUF9evW1mu3tbWlZo1qnL9YNJ/xF4QaMoDkUBIlZaj9yrsMOJDIK/sf8PyGEOq9Ph6N5b8nxy2sbQDISEnKsW1GciKlvCti5+yeY9lLu+N4eU88r+x7QMCszbjUaJRjnYijOwFoPXkxrrWbYe9eDs/GbWn+0Y88vHOdkE2LTJQyd0oai4KQHMpRUjKUiALo4sWLBAUFsWfPHjIyMgyuc+7cOT7/vHBPFRsjOiYWZ6ey2NjY5Fjm6eFOTOxdMjMzi6FneaeGDCA5lEQJGbRZWUQc282pORPY815vDv3fCB6Gh9Lwzcm0nRakWy8h9BIAXo3b6m1v5+JBWb+aADh4lNe1J9+N4uKKWRyd/jZ7P3yBC8u+waNBazrP3Yd7vZZ6+wjdspSz86bgUb8V3RYdou+WmwT+vIuMlCS2Dm5JasLdwoqvo4SxMAXJoRwlJYPi5wANHz6cBQsW6L728/Nj/vz5tGvXTm+9s2fPMnnyZCZOzPlZvCHh4eGEh4frtfm42ONTzrvAfX5cckqKwTcBgO0/7SmpqTg6OJj0uKakhgwgOZRECRmSom6x8+1AvbZrGxbwzBdLqdS5P+Wf6cHtA5sJ3b6ceq9/QoM3J5Oe/JDI43twcPeh8ZjpujNFlnb/9vPUT5/o7fPW3g3c2Pk73RYfodkHs9g6qLne8sSoW8QFn+HWnnU8uB2Cc7X61H71fdp/s56do7uQkfSwkL4DjyhhLExBcihHScmg6DNAy5cvZ/78+bRp04bvvvuODz74gPj4eDp16sTChQsLtO+5c+fSvHlzvdfchUtN1PN/2dvZkZaWZnBZ6j/tdra2Jj+uKakhA0gOJVFyhnMLvwSgXKvOAKTdj2fn6K4kRt6k1afz6LMhhC7z9pESF8W1DfMBSE+8/8R93gs5z+39m3Ct1UTv47Ja/d+h+Uc/cuTLt7j023fc3r+Zcwumsm/cy7jXa0HtAe8VUsp/KXks8kNyKEdJyaDoM0A//fQTrVu3Zs+ePbq2//3vf7z44osMHz6c5ORkRo4cadS+hw8fTrdu3fTafFwMT4IsCA93N66FhpGWlpajIo6KjsHdzRVLS0uTH9eU1JABJIeSKDlD4p0wAGyd3HRt8cFn2PxKI0r7VsPe1YvEiBskRt7k2SnLycrI4OFtw/cTetzDOzd0+82+zL7my2NIuH6JhOuX9NaNOLKDtIf38WzUxkSpcqfkscgPyaEcJSWDos8AXb16lX799GeRe3t7s3v3brp3787o0aOZNWuWUfv28fHB399f72Xqj78A6tapRVZWFmfPX9RrT01N5fKVYOrWrmnyY5qaGjKA5FASJWcoXaEaAClxUTmWPbgZTPSp/SRG3kRjaYVX0/ZEnz5gcIL0f5XxrfrPfqN1bfauXmhy+YfAwtISjVXh/42q5LHID8mhHCUlg6ILoMzMTOzsct4x0sbGhrVr1/LCCy/w/vvvM2PGjGLoXd50C+yARqNh8fIgvfagtRtJTkmhZ9fAXLZUDjVkAMmhJErIYFPWJUebxsKChm9OBuD2/i1P3L7BiEnYuXhwfvF0XZuVnQMWNjlP7bvXa4lP6+5Enz2kN7E54fpFylSsiWvtZnrr+wb0wcrekbhLJ/KVyRhKGAtTkBzKUVIyKPojsEqVKnHq1CmDyywtLVm5ciWvvvoq48aNo1mzZgbXK241qlVhQL8+LFu1hlHvj6Nt65aEXL/B0pW/08K/Cd06F//NoJ5GDRlAciiJEjK0/OQXrB1KE3PuMIlRt7Bz8aBix764VGtAyJYlRBzZoVu3/cyNPLwT+uijKo0F5Z/tgU/LzpxbMFVvvdIVqhHw3WZu/bWBB7eukZGShEv1hlTpMYiMlESOTh+l14ez876g7fTVdPzxD66u+ZmH4aE4Va1Ltd7DSYmP4eLybwv9+6CEsTAFyaEcJSWDRqvVaou7E7l5//33WbZsGbdv38ba2trgOlqtlsGDB7N06VI0Gk3BLq1LijV+2yfIzMxk8fIgVq3dQPidSFycnejeuSOj3xqKg73p5x0VBjVkAMmhJEWdYWk7L72vq/YaQqWur1LWrwY2ZVzITE3hXsh5rm1ckOP+O/WGTsCvUz9KeVckKzOT+KunubTye27tXa+3np2rJ01GT8e1dlPs3cphaWtHcmwEEUd3cn7hNB7euZ6jX251m1NvyDicq9XHztWL1IS7RB7dxZlfJxtcf+DeyAJ/L/5LDe8nkBxKUuQZHNyevs5/KLoAOnXqFDNmzOCdd96hRYsWua6n1Wr54IMPOHnypN6E6XwrpAJICFH8/lsAlVSFUQAJUeKprQAqclIACaFaUgAJoWJGFECKngQthBBCCFEYpAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2NFqtVlvcnVCMpNji7oEQQpiFec96FXcXCmzY/sji7oLI5uCW703kDJAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLNjld8NLCws0Gg0+dpGo9GQkZGR30MJIYQQQhSKfBdAr732Wr4LICGEEEIIJcl3AbRo0aJC6IYQQgghRNGROUBCCCGEMDv5PgNkSGZmJsuWLWPHjh1ERUUxY8YMGjVqRHx8PJs2baJDhw74+PiY4lAlUlZWFktWBLFyzQZuh0fg6uJMt84dGPPmMOzt7Yq7e3nyy/wlXLh0hfMXLxMeEUnN6lXZsGpxcXcr39QwFqCOHPKeUg6lZLBzcqPR8PH4PtsDB/dypN6P5+6V0xz+5j0SblwFoFKnvlRo3RW3Wo1x8quFhZUVS9q6kvYwIcf+qnYbgG+bHrjVaoyDWzmS46KIuXCMk79+wb3QiznWL+tXgyZvTaZc03ZY2Zfi/q1gLv3+M5dW/1Lo2R+nlPEoiJKQocAF0MOHDwkMDOTw4cM4OjqSlJREfHw8AGXKlGHcuHEMHjyY//u//ytwZ0uqqV9/z9LffqdTQBteH9ifkNAwlqwI4vKVYBbMmVUi5lTN/PEXnJzKUrdWDeITcv6iKSnUMBagjhzynlIOJWQoXb4yPX7dTVZmBsGblvAw8ia2ZV1wq9UEO2d3XQFUu+9buNdtxt0rZ3gQEUbZClUN7s/SxpZ2Xywm5uJxrm1dwcPIm5Qu50etvm9Qsd1z/DG6B3eO7dat71ylDj0X7Ae0XFw1m8To25RrFkDrcT/h6OXL8R/HF/r3IJsSxqOgSkKGAhdAEydO5NSpU2zcuJEWLVrg4eGhW2Zpacnzzz/PH3/8YbYFUHBIKMtWriYwoC0/fDNV117ex5spM2axbcduugV2KMYe5s3OTUFUKP/oLF5AtxeKuTfGUctYqCWHvKeUQSkZ2k9ZSnJ8DFtGBJCe+CDX9fZOGkxSzB20mZm0+Wx+rgVQVmYGm4e1J/LUfr32a9tW0Oe3kzQbM5UNA1vo2pu+PQVrh1JsHPIsMeePAHBp9S+0+vgH6g98n+BNi3VFWGFSyngUREnJUOA5QGvWrOHNN9+kR48eBiu6atWqcePGjYIepsTavH0nWq2WQQP66bX369MLezs7Nm75o5h6lj/Z/1CVZGoZC7XkkPeUMighg3fTdnjUa87JnyeTnvgAC2sbLKxtDK6bGHkLbWbmU/epzczMUfwAJIRdIT7kPM5V6ur3oUlbEm5e1RU/2a5tWY6FlRVVuvTPRyLjKWE8CqqkZCjwGaDIyEjq1KmT63JbW1sePnxY0MOUWOcvXMLCwoL6dWvrtdva2lKzRjXOX7xcTD0zP2oZC7XkUAM1jIUSMpRv2RmAtIcJdJ+7B6+GrdFYWBB7+RTHfhxP+KE/TXcwjQZ7N29S4mP0mi2sbchIScqxekZyIgDutZuarg9PoITxKKiSkqHAZ4A8PDy4efNmrsvPnDlD+fLlC3qYEis6JhZnp7LY2OT8a8bTw52Y2Ltk5uGvGVFwahkLteRQAzWMhRIylK1YDYAOM1aR/jCB3Z+8woGpI7FzcqPzd5so52+6j0tqvTACR/dyXNu2Qq/93vWLOPnVxN7FQ6/du1k7ABw9i+aMpRLGo6BKSoYCF0Bdu3Zl3rx5xMTE5Fh26tQpFi1aRK9evYze/927d/n222+ZNGkSR478e2pywYIFPPvss9StW5dhw4Zx69atfO03PDyco0eP6r3C70QY3c/cJKekGHwTANj+056Smmry44qc1DIWasmhBmoYCyVksHYoDcC9sCv8+W5vru9YzeU1v7L1zU6gzaLp21+Y5DhutZrQ/N2viQ+5wKl5U/SWnV82Cys7Bzp+sxbPhq0p5V2Raj0H0fiNSWRlpGNp52CSPjyNEsajoEpKhgJ/BPbZZ5+xadMmGjZsSO/evdFoNCxbtoxFixYRFBSEp6cnn3zyiVH7joyMpFmzZoSHhwMwZcoUli9fzr179xg5ciTly5cnOTmZBQsW8Mcff3Dq1Cnc3NzytO+5c+cyefJkvbZJn4zls/EfGtXX3Njb2XE3Lt7gstS0NADsbG1NekxhmFrGQi051EANY6GEDJmpyQBc27JUr/3+rWtEnTmEV6NnsLJzMPgRVV45VapF5x82k3Ivlj/e6UVmSrLe8mvbVmDn7E7jNybRc/5fAKQnPeTwzA9oOvJz0hPvG33s/FDCeBRUSclQ4DNA5cqV4/DhwzRu3JhffvkFrVbLokWLWL58OR06dGD//v24uroate8ZM2Zw7949goKCOHz4MI0aNWL8+PHMnj2bvXv3cvPmTWJiYlixYgURERF89dVXed738OHDOXLkiN5r+JCBRvXzSTzc3Yi/l0DaP4P+uKjoGNzdXLG0tDT5cUVOahkLteRQAzWMhRIyJEY/+iM36W5UjmVJsRFoLCywKVXW6P2X8a1Gt5//RJuZwda3AnkYYfjCnPMrvmN5J282vNaSjUOeZXmgD9e2LcfOyY2EsMK/AgyUMR4FVVIymORO0BUrVmTTpk3cvXuXI0eOcOjQIaKjo9myZQu+vr5G73fbtm0MHTqUvn374u/vz5dffsn169fp1asXbdq00a338ssv07dvX7Zs2ZLnffv4+ODv76/38innbXRfc1O3Ti2ysrI4e17/plupqalcvhJM3do1TX5MYZhaxkItOdRADWOhhAwxF44B4OiRc56No2d5sjLSSb0fZ9S+y5SvQvdfdqLRWLD1jU7cvxn8xPUz01KJuXCM6LOHyEhOpHyLTmgsLLh9qGiuXFLCeBRUSclg0kdhlC1blmbNmtG8eXOjz/o87ubNm9St+++litlXmzVr1izHui1atCAsLKzAxzS1boEd0Gg0LF4epNcetHYjySkp9OwaWEw9Mz9qGQu15FADNYyFEjLc+GsjaYkPqNH7dTSPnRlwqVYfj3otiDj+F5lp+Z8zUqqcH91+2YGljS1bR3bmXlj+rj6yLlWGpiO/4P7tEEL/DHr6BiaghPEoqJKSwSSPwoBH9wNav349oaGhAFSuXJnevXvzwgvG3+DMxsaG9PR03de2/3xmWLp06RzrOjo6kpWVZfSxCkuNalUY0K8Py1atYdT742jbuiUh12+wdOXvtPBvQrfOxX8zqLxYv3k7dyIiAXjwMJG09HRmz10EQDlvL3r36FKMvcsbtYyFWnLIe0oZlJAhNSGOYz+Mo/XHP9Lj1z2E/LkK2zIu1Hl5FJmpyRz57iPdul6NnsWr8bMAuFSrB0C9ge+TmZYCwOn5j268Z+1Qiu4/76CUly9nl87EtVp9XKvV1ztu2J71unlFTpVr02bSPG7u30JSdDiOnuWp/twQbEqVZdtbnY0qwIyhhPEoqJKSQaPVarUF2UFiYiK9e/dm9+7daLVanJycALh37x4ajYZ27dqxceNGHB0d873vOnXq8NxzzzF16qM3dFpaGr/99htdunTB09NTb93x48ezbNmygt10MSnW+G2fIDMzk8XLg1i1dgPhdyJxcXaie+eOjH5rKA729oVyTFMbOGwUR0+cMrjMv0kjls77sYh7ZBw1jAWoI4e8p5SjODLMe9YrR1vlTi9Sb+B7OFepS1ZGGhEn9nF89qfEXzuvW6fxiIk0fmNi7vtt8ujv+lLeFXl5c8gT+7CyRxXdfCB7Fw+eGf8zbrUfPXoj5V4s4Yf+5OTcKTy8E2Zw+2H7I58W0yjynjKCQ94ugHpcgQugUaNGMXv2bN577z3Gjh2rK0yyH4r67bffMnLkSH78Mf+/zAYOHMjt27fZs2fPU9dt1qwZ5cuXZ926dfk+jk4hFUBCCCH0GSqASprCKoCEEYqjAPL09KRjx44sX77c4PL+/fuze/duoqJyzu5/mlu3bhEVFUXTpk++A2d0dDQfffQRffv2pXv37vk+jo4UQEIIUSSkABImZUQBVOA5QImJiTz77LO5Lm/bti2bN282at8VKlSgQoUKT13Pw8ODhQsXGnUMIYQQQpifAl8F1rRpU86ePZvr8jNnztCkSZOCHkYIIYQQwmQKfAbo66+/JjAwkHr16jF8+HCsrB7tMiMjg19++YWgoCD+/NOED7ITQgghhCigfM8BCggIyNF269YtQkNDKVOmDJUrVwYgNDSU+/fvU6VKFSpUqMCuXbtM0+PCJHOAhBCiSMgcIGFSRTEHKDQ0FI1Gk6M9+47PcXGP7tbp5OSEk5MT6enpunsDCSGEEEIoQb4LICXebVkIIYQQIj9M+igMIYQQQoiSQAogIYQQQpgdkzwLLDg4mG+//ZajR49y7969HM/k0mg0hIQ8+ZbkQgghhBBFpcBngE6fPk3jxo1ZsGCBbsKzo6MjqamphIWFYWlpqZsgLYQQQgihBAUugCZOnIiDgwPnzp3TXer+3XffER4ezsKFC7l37x4//PBDgTsqhBBCCGEqBS6A/v77b0aMGEG1atV0l8dnfwQ2aNAgevXqxccff1zQwwghhBBCmEyBC6CkpCQqVaoEgK2tLQAPHz7ULW/evDl///13QQ8jhBBCCGEyBS6AvL29uXPnDgClSpWiTJkyXLx4Ubc8e5kQQgghhFIU+Cowf39/vTM8nTp1YubMmVSoUIHMzEx++OEH/P39C3oYIYQQQgiTKfAZoKFDh+Li4kJycjIA06ZNw8bGhkGDBvH6669jbW3NV199VeCOCiGEEEKYSr4fhpoXDx8+ZPfu3VhaWtK6dWucnJxMfYjCIQ9DFUKIIiEPQxUmZcTDUAulACqxpAASQghhZoICSn4x2u9wRr63kUdhCCGEEMLs5HsSdOXKlfN9EHkUhhBCCCGUJN8FkK+vr+6Gh0IIIYQQJVG+C6C9e/cWQjeEEEIIIYqOzAESQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZseoAsjS0pIVK1aYui9CCCGEEEXCqAJIHh8mhBBCiJJMPgITQgghhNmRAkgIIYQQZiffj8LItn//fjIy8v74+ddee83YQwkhhBBCmJRGa8SEHgsLizw/EFWr1aLRaMjMzMx354pcUmxx90AIIYQoUkEBXsXdhQLrdzjvJ2SyGX0GaMSIEbRo0cLYzc1KVlYWS1YEsXLNBm6HR+Dq4ky3zh0Y8+Yw7O3tirt7eaKGDKCOHL/MX8KFS1c4f/Ey4RGR1KxelQ2rFhd3t/JNDWMB6sihhgwgOUzBwbsiPdaFGFwWc+Zv9rzRVve1xtKKKs+PoFLPwTj6VIGsLB6Gh3B900JC189Fm5WV63Gaf7aYil0GEH/1NDtea6q3rLRvdSo/NwznWk1wrtEIa8cynPr2PYJXfW+akP8wugB69tlneeWVV0zZF9Wa+vX3LP3tdzoFtOH1gf0JCQ1jyYogLl8JZsGcWXk+m1ac1JAB1JFj5o+/4ORUlrq1ahCfkFDc3TGaGsYC1JFDDRlAcpjS7b3ruL13nV5balyM3tfNJszDr+ur3Nq9htAN89FYWOLT7nmafPgTTtUacGL6SIP79mgaQIWOL5GRkmRwuWu9FlTv/z8e3r5G/JXTeDRuY5pQ/2F0ASTyJjgklGUrVxMY0JYfvpmqay/v482UGbPYtmM33QI7FGMPn04NGUA9OXZuCqJCeR8AArq9UMy9MY5axkINOdSQASSHqSVcO8fN7bnf78/W2Z2KnV/h9t71HPrkJV37tTVz6LToCH49BnPy6zFoM/U/mrKwsaXJhz8Suv5XvFt3M7jvO/s3sb6TG+mJ93Fv3BaP2btME+o/5CqwQrZ5+060Wi2DBvTTa+/Xpxf2dnZs3PJHMfUs79SQAdSTI7v4KcnUMhZqyKGGDCA5CoOFjS2WtvYGl1k7lkFjYUFK7B39BVotKXejyEpPy1H8ANQaNA7rUmU59/OnuR437X486Yn3C9T3vCjRZ4AyMjIIDQ3Fx8cHR0fH4u6OQecvXMLCwoL6dWvrtdva2lKzRjXOX7xcTD3LOzVkAPXkUAO1jIUacqghA0gOU6ve/13qDJsIQGLEDa5vXMClJdN1RU3ines8uBWMX48hxF89TdSxXVhYWlE+oC+ezQM599O4HPss7VudmgPHcnzam6Q/LP6P740qgLKeMLGpKN24cYNatWrx+++/06dPn+LujkHRMbE4O5XFxsYmxzJPD3dOnTlHZmYmlpaWxdC7vFFDBlBPDjVQy1ioIYcaMoDkMJmsLKKO7SZ83wYSI25g5+KBb2B/6r4xGedaTfj7w0f/1mqzsvh7bB/8Jy2k2Se/6jbPSEnm+NThhG1ZkmPXTT6eQ9zFY9zYurRw+p5PRhVAcXFxhIWFUbNmTRwcHHTtWVlZTJ8+nQULFnDnzh1q167N1KlT6dSpk1Gd27hx4xOXR0ZGotVqOXbsGFZWj6L06tUrT/sODw8nPDxcr83HxR6fct5G9TU3ySkpBt/IALb/tKekpuL42PdRadSQAdSTQw3UMhZqyKGGDCA5TCUp6hZ/jQ7Ua7u+cQHNJy+lYuf+eD/Tg4gDmwFIT3rAw1vXuB92mTsHNmNhZY1ft9doOu4XstLTuPnnSt0+/Lq/hlv9VuwY1KxQ+m0MowqgadOmMXfu3BwFxIcffsi3334LgLOzMydOnKBHjx4cOnSIxo0b5/s4vXv31s12z76f0H9pNBpmzJiR7/sNzZ07l8mTJ+u1TfpkLJ+N/zDf/XwSezs77sbFG1yWmpYGgJ2trUmPaWpqyADqyaEGahkLNeRQQwaQHIXt0qIvHxVALTsTcWAzVg6l6DB3PzGnD3B08mDdejf/+I2AX/fR+MOfiPh7K+mJ97Ep40L9UdMJ/v0nEkLOF3nfc2NUAXTgwAG6du2qd/YnLi6OH374AQ8PD/bv30/VqlX5+++/6dq1KzNnzmTZsmX5Po61tTW2traMHTsWX1/fHMujoqL4+OOPefvtt2natKmBPeRu+PDhdOumPwPdx8XwZK+C8HB341poGGlpaTmq+qjoGNzdXBV/SlYNGUA9OdRALWOhhhxqyACSo7AlRoQBYFvWDYDy7V/AwbMCt/esybHu7b3raFi/FU7VGxJzah91hn2KhbUNN7Yto1T5Krr1NJZWWFjbUKp8FdKTHpAaF10kWbIZdRXY9evXqVevnl7bzp07SU9P591336Vq1aoAtG7dmldffZUDBw4Y1bnTp0/TsGFDZsyYQWRkJAMGDGDQoEG61wsvPLoEuH379rq2vPLx8cHf31/vZeqPvwDq1qlFVlYWZ89f1GtPTU3l8pVg6tauafJjmpoaMoB6cqiBWsZCDTnUkAEkR2ErXaEaACnxUQDYuT66e7TGImcxZmH56NyK5p//Onj6YlOqLIFLjtNt9RXdy8GjPGUr1abb6is0evfbooih309jNoqPj8fLS//W2YcPH0aj0eSY79OgQQMiIyON6lytWrXYt28fs2bN4quvvqJevXrs3r3bqH0Vl26BHdBoNCxeHqTXHrR2I8kpKfTsGpjLlsqhhgygnhxqoJaxUEMONWQAyWEqNmVccrRpLCyo+8ajKSN39m8B4P71RwWaX7eB+utaWlKh00tkZaRzL/gMAJeXfsXBcf1yvFLionl45zoHx/Xj6srvCjOWQUZ9BObp6cnt27f12g4ePIi9vT3169fXa7e0tMS2gJ9XDh06lOeee47333+fjh078vLLLzNz5swC7bOo1KhWhQH9+rBs1RpGvT+Otq1bEnL9BktX/k4L/yZ066z8G3OpIQOoJ8f6zdu5E/Hoj4oHDxNJS09n9txFAJTz9qJ3jy7F2Lu8UctYqCGHGjKA5DCVpp/8gpVDae6eO0xy9C1snT2o0KEvTtUaELZlCVFHdwAQcXArcRePUe6ZHrT9cQfhf63Hwsqail1ewbl6Qy4v/Yq0hLsA3D1/2OCxGoyZQfrDBG7vWavXbu1Yhqr9RgHg6O0HgKd/R6wcSgGPbpSYcO1cgbMa9TDU7t27c+3aNU6dOoWDgwNXr16lTp06dOjQge3bt+ut+/HHH7N+/XouXzbNvQv27NnDW2+9RUREBEOHDuW7774z3WXwhfQw1MzMTBYvD2LV2g2E34nExdmJ7p07MvqtoTjYm37eUWFQQwZQR46Bw0Zx9MQpg8v8mzRi6bwfi7hHxlHDWIA6cqghA0gOYz3+MNRKPYdQseurlK5YA5syLmSlpZAQcp7rGxdwffMive0s7Ryo3v9/VOjQF0dvPzSWVty/fpHQ9fMI3TDvqcftvu4aaQ/u5XgW2JOeRwZw9IvXc1xmb8zDUI0qgPbu3UtAQACVKlWiSZMm7Nu3j5iYGNauXctzzz2nt26DBg2oW7cuy5cvz3fncpOWlsaXX37JtGnTSE1NZfXq1YougIQQQgilMtenwRs1B6hdu3b88MMPxMfHs3r1ahITE5k2bVqO4mf//v2cO3eOwEDTfmZpY2PDpEmTuH79OqdOnaJjx44m3b8QQggh1M2oM0DZMjMziY2NxcPDw+A9epKTk0lKSsLJyalEXH4oZ4CEEEKYG3M9A1SgZ4FZWlri6emZ63J7e3vsS9DnrkIIIYQwD0YVQPfv5/8prWXKlDHmUEIIIYQQJmdUAeTk5GTwI6/caDQaMjLyf3pKCCGEEKIwGFUAvfbaa/kqgIQQQgghlMSoAmjRokUm7oYQQgghRNEx6jJ4IYQQQoiSTAogIYQQQpgdoz4Cc3HJ+bC0J9FoNNy9e9eYQwkhhBBCmJxRBVD9+vXzNAk6OjqaS5cuyYRpIYQQQiiKUQXQ3r17n7j8/v37fPXVV8yaNQuAF154wZjDCCGEEEIUCpPOAUpLS2PmzJlUrVqVqVOn0rx5c44ePUpQUJApDyOEEEIIUSAFehRGNq1Wy8KFC5k8eTK3bt2iadOmrFixQh5SKoQQQghFKvAZoLVr11KnTh2GDRuGvb09QUFBHD16VIofIYQQQiiW0QXQ7t27ad68OX379uXBgwf8+uuvXLhwgb59+5qyf0IIIYQQJmfUR2CBgYHs2rULFxcXvvrqK0aPHo2NjY2p+yaEEEIIUSg0Wq1Wm9+NLCws0Gg0VKpUKU9PeddoNJw4ccKoDhappNji7oEQQghRpIICvIq7CwXW73D+H7huVAHk5+eX73v7XL9+Pb+HKXoqKYAOdPcs7i6YxDNbooq7C0IIIUoCB7d8b2LUR2BhYWHGbCaEEEIIoQjyLDAhhBBCmB0pgIQQQghhdoz6CKxPnz75Wl+j0bBmzRpjDiWEEEIIYXJGFUDr169Ho9GQ1/nT8jBUIYQQQiiJUR+BaTQabG1t6d+/P3/88QdZWVlPfGVmZpq630IIIYQQRjOqALp16xYTJ07k1KlTdOnSBV9fXyZMmMC1a9dM3T8hhBBCCJMz6j5Ajzt8+DCLFi0iKCiIhIQEWrRowZAhQ3jppZcoXbq0qfpZNOQ+QIoi9wESQgiRJ0bcB6jAV4G1aNGCn3/+mYiICJYvX06ZMmV466238Pb2ZunSpQXdvRBCCCGEyRk1CdoQW1tbXn75ZVxcXEhNTWXv3r0l4+7PQgghhDA7JimAgoODWbRoEUuXLiU8PJwaNWrw5ZdfMnjwYFPsXgghhBDCpIwugB48eMDKlStZtGgRhw4dwsnJiZdeeonBgwfTvHlzU/ZRCCGEEMKkjCqABgwYwPr160lLS6NTp0789ttv9O7dG1tbW1P3TwghhBDC5Iy6CszCwgJ7e3t69OiBj4/P0w+i0fDNN98Y1cEiJVeBKYpcBSaEECJPjLgKzOgCKF8H0WhKxs0QpQBSFCmAhBBC5IkRBZBRH4HJ1V1CCCGEKMmMKoAqVqxo6n4IIYQQQhQZk90HSOQuKyuLJSuCWLlmA7fDI3B1caZb5w6MeXMY9vZ2hX58W8+KNFsZanBZwrkDnBvT1uAyjbUtjRecwb58NcJXf8f1n97TW+7UtBOubfpQukYTHPzqYmFjy6lhjUkMOWNwf6VrNafCoImUqdMCjZUNSWEXCF/1DbF7fy9YwHwo7rEwFTXkUEMGUEcONWS4cOkKm7b+yeFjJ7gdHoGlpQV+vhV45aUX6NUtsEQ9lFsN41ESMkgBVASmfv09S3/7nU4BbXh9YH9CQsNYsiKIy1eCWTBnVpH9YMbuW8fd/ev02tLvRee6foVXP8HG1TvX5e4d+uMe8DJJYedJvnUFxyr1c123bOMA6kzbQsb9u4Sv+oaMh/G4tO5NzUkruVbamchNv+Y/kBGUMhYFpYYcasgA6sihhgzzFi3n0NETBHZoy8t9e5Oalsa2P3fz4YTPOXLsJFM/G1fcXcwzNYxHScggBVAhCw4JZdnK1QQGtOWHb6bq2sv7eDNlxiy27dhNt8AORdKXpNCzxOxcnqd17X1rUv7lsdxY8CmV3pxhcJ0b8ydwbeabaNPT8B008YkFUOWR36DNzODM261JjboBQMT6OdT+chN+b0wnZk8QmQ/v5TtTfihpLApCDTnUkAHUkUMNGQAG9n+R6V9MwMbG5t+2l/syaMQY1mzYzOBXX6J61crF2MO8UcN4lJQMBX4WmHiyzdt3otVqGTSgn157vz69sLezY+OWP4q0PxprWyxs7Z+6XtX3ZpNwZh+xe1fnuk5a7B206WlP3ZdVaWccq9Tn/tn9uuInW/SO5Vg5lsH1md5P3U9BKW0sjKWGHGrIAOrIoYYMAI0b1tMrfuDRFcuBHR59xB98zfA0AKVRw3iUlAxSABWy8xcuYWFhQf26tfXabW1tqVmjGucvXi6yvpTr9x6t/0yi1faHNP0tlAoDx6OxzHkS0KPLYErXakHI96NNclyN1aNfSpkpSTmWZaUkAlC6ZlOTHOtJlDQWBaGGHGrIAOrIoYYMTxIZHQOAi7NT8XYkj9QwHiUlQ4ksgLZs2cKoUaN4+eWXeeedd9i5c2dxdylX0TGxODuVzfGXCYCnhzsxsXcL/x5J2izundzFjXnjufjJcwR/NYKUOyFUfP1zak7Wn4BsVcaVSm9O5/aqr0m5HWySw6fHR5GeEEvpWv5Y2OhPfivbsB0ANm7lTXKsJ1HEWJiAGnKoIQOoI4caMuQmOiaWoDUb8fH2oknjBsXdnTxRw3iUlAyKngPUpk0bJk6cSMeOHQHIyMjgxRdfZOPGjTx+/8Yff/yRQYMGsWDBgjzvOzw8nPDwcL02Hxd7fMrlPunXGMkpKQbfBAC2/7SnpKbi6OBg0uM+LjX6FuffD9Rri9o6n+oTluHRoT8uLXsQd2gzAJXe+orMpAfcXjbV0K6Mdmf1d1Qc+gU1J63ixuLJZDyIx/WZ5/DqMQwAS7unfyxXUEoYC1NQQw41ZAB15FBDBkPS0tJ458NPeZiYyPdfTcHG2rq4u5QnahiPkpIh3wVQ5cr5n0Sm0WgICQnJ93YHDhwgOvrfq5SmTZvGhg0b6N+/P+PHj8fPz4+rV6/y6aefsnjxYtq2bcugQYPytO+5c+cyefJkvbZJn4zls/Ef5rufT2JvZ8fduHiDy1LTHs2fsSumZ6jdXjYVjw79cW7ehbhDmynboC2eXQZxcXxvstJSTHqsW8u/xMK+FD5938GlVQ8A0hNiCf76DWp+upyMxAcmPZ4hSh6L/FBDDjVkAHXkUEOG/8rIyOCdDz/l1JlzfDHhQ1o2L/yP2E1FDeNRUjLkuwDy9fUttsvX5s2bR0BAAMuX/3slU8OGDdmwYQONGzdm3rx5eS6Ahg8fTrdu3fTafFxMfxbCw92Na6FhpKWl5aiIo6JjcHdzxdLS0uTHzYuUyDAArMo+uoV45dGzuH/hEElhF7ErVwUAG/dHz3qzciyLXbkqpN+LJjPJiGJFq+XG3E+4vWwqDpXqos3KJDHkDHZelQBIvnWl4IGeQsljkR9qyKGGDKCOHGrI8LjMzEze/2Qyu/86wIQP/8eLfXoVd5fyRQ3jUVIy5LsA2rt3byF04+mSk5O5efMmEydOzLHMwsKCfv36MWOG4cu1DfHx8cn5INdCeBZY3Tq1OHDoKGfPX6Rp44a69tTUVC5fCaaFfxOTHzOv7H2qAZAe9+iZW7aevliVcqLp8qs51vXsOhjProO5NnMkkZt+MfqYmckPeXDxsO5rZ//OAMQfK/yrApQ8FvmhhhxqyADqyKGGDNmysrL4cMIXbN+xm4/eHcXA/i8Wd5fyTQ3jUVIylJhJ0NkPYPX0NPygTw8PD1JSTPuxjSl0C+yARqNh8fIgvfagtRtJTkmhZ9fAXLY0HasyLjkbLSyo+PrnALr5P1e/HMylSf30Xte+ffufdbZwaVI/4o//abJ+2biXp3z/D7l//m/un9lnsv3mRgljYQpqyKGGDKCOHGrIAI+Kn3GT/o/N23fw3qg3eP21/sXdJaOoYTxKSgZFT4IGWLt2LdeuXQOgdOnS3Lhxw+B6t27dwsXFwD/0xaxGtSoM6NeHZavWMOr9cbRt3ZKQ6zdYuvJ3Wvg3oVvnwr8ZVNX3f8XSoTQPLh4iNfo21k7uuLd/EccqDYj6Ywn3ju8AIO7gphzb2no+eu5bcvg17u5bo7fMoXI9XFv1BKBM/WcB8Ow+lPS4SADurPuRzMT7ADg374pPv3e5d3wn6fdisPOpgleP4WSlJnPl/14rnOD/oYSxMAU15FBDBlBHDjVkAJjx7U+s37ydenVq4eXlyYb/3GumRrUq1KxetZh6l3dqGI+SkkGjffxyKiPt37+fL7/8kqNHj3Lv3j3+u0uNRkNGRka+95t91udxHTp0YMeOHTnaAwMDycjIYPfu3fk+jk4hfAQGjz6TXrw8iFVrNxB+JxIXZye6d+7I6LeG4mBv+nlHB7rrnyXz7PY6Hp0GYO9bE6vSLmSlpZB0/RxRWxcStW3hE/eV/RwxQ88C8+g8iOof537l3bGXK+tufGhfsRaV356JY5UGWJVyIi0ugriDm7i5ZAoZCYa/789sicpL3Hwp6rEoLGrIoYYMoI4casgwcNgojp44levyUW+8zug3hxZhj4ynhvEo8gwObvnepMAF0J49ewgMDMTZ2Rl/f3+2bt1KQEAAiYmJHD16lLp169K4cWMWLnzyP7SGGDrbY2FhQYUKFfTa4uLiGD58OD169GDIkCFGZymsAqio/bcAKqkKowASQgihQsVRAHXo0IHQ0FCOHz+OVqvFw8ODnTt3EhAQwN69e3nuuefYvHkzzz77bEEOUzSkAFIUKYCEEELkiREFUIEnQZ84cYJhw4bh6uqq+8gqKysLgHbt2jF48GA+/fTTgh5GCCGEEMJkClwApaen4+XlBYCd3aPHHCQkJOiW16tXj5MnTxb0MEIIIYQQJlPgAsjHx4dbt24B4ODggJubG6dO/TsR7erVq9gq4I6PQgghhBDZCnwZfOvWrdm5cyefffYZAD179mTmzJnY2tqSmZnJjz/+mOOOy0IIIYQQxanABdDIkSNZt24dycnJ2Nvb8+WXX3L8+HEmTZoEQK1atfjmm28K3FEhhBBCCFMxyX2A/kur1XLu3DksLS2pWbOmIp75kSdyFZiiyFVgQggh8sSIq8AK5U7QGo2G+vXrF8auhRBCCCEKzKQFUFJSEnfv3s1xJ2h49BR5IYQQQgglKHABlJmZybRp0/jpp5+Iisr9I4vMzMyCHkoIIYQQwiQKXACNHTuWWbNmUa9ePV588UVFPpBUCCGEEOJxBS6AVqxYQffu3dm0KeeTxIUQQgghlKjAN0J88OABPXv2NEVfhBBCCCGKRIELoMaNGxMWFmaCrgghhBBCFI0CF0DTp09n/vz58rwvIYQQQpQYBZ4DNG/ePMqVK0fz5s1p2bIllSpVynHjQ41Gw/z58wt6KCGEEEIIkyjwnaAtLJ5+Ekmj0ZSMy+DlTtCKIneCFkIIkSdG3Am6UB6FUWKppAASQqjXivZexd0Fk3hlT2Rxd0GoiREFUIHnAAkhhBBClDRSAAkhhBDC7OR7EnRAQAAajYY//vgDKysrAgICnrqNRqNh165dRnVQCCGEEMLU8l0AhYaGYmFhoXvgaWhoKBqNxuQdE0IIIYQoLPkugP5700O5CaIQQgghShqZAySEEEIIsyMFkBBCCCHMToHvBF25cuUnLtdoNNjb2+Pr60tgYCDDhw/H0dGxoIcVQgghhDBagc8A+fr6YmVlRVhYGPHx8Tg5OeHk5ER8fDxhYWFYWVlhb2/P4cOHee+992jSpAkxMTGm6LsQQgghhFEKXADNmjWLu3fvMnv2bKKjozl58iQnT54kJiaGH3/8kbi4OObPn09sbCw//PADwcHBTJo0yRR9F0IIIYQwSoEfhdGxY0eqV6/O7NmzDS5/6623uHbtGjt27ABgwIABHDhwgBs3bhTksIVDHoUhhFA4eRSGEAYUx6Mwjhw5QoMGDXJd3qBBAw4fPqz7ulWrVkRGyhtfCCGEEMWnwAWQra0tx48fz3X58ePHsbW11X2dlpZGqVKlCnpYIYQQQgijFbgA6tWrFwsXLuTrr78mOTlZ156cnMxXX33FokWL6NWrl6790KFDVK1ataCHFUIIIYQwWoHnAMXFxdGhQwfOnDmDjY0N5cuXB+D27dukpaVRr149du/ejaurKykpKQwZMoQuXbowaNAgkwQwKZkDJIRQOJkDJIQBRswBKnABBI8+1po3bx6bN2/m+vXrAPj5+dGzZ0+GDRuGjY1NQQ9RNKQAEkIonBRAQhhQXAWQakgBJIRQOCmAhDDAiAKowHeCFk+XlZXFkhVBrFyzgdvhEbi6ONOtcwfGvDkMe3u74u5enqghA0gOJVFDBij+HI7eFXlufYjBZdFn/mbniLa6ry2sbagzeBx+nV/GwdOXtAfxhO/fzJmfPyU1Xv8Gta61m+HXdQAuNZvgXL0BVnYO7Bvbh9v7Nj6hL37UHTYBb/9O2Dq5kXovlrsXj3H0yzdJvVf4f2AW91iYwi/zl3Dh0hXOX7xMeEQkNatXZcOqxcXdrXwrCTnyXQB9/vnnaDQaxo8fj4WFBZ9//vlTt9FoNHz66adGdVANpn79PUt/+51OAW14fWB/QkLDWLIiiMtXglkwZxYajaa4u/hUasgAkkNJ1JABlJPj1p513Nq7Tq8t5fGiRqOh7Tcb8W7ekZu713BpxSwcPMpT/cWRuDd8hj9eb0lG4gPd6uVadaVanze5H3aJe9fO41bX/4nHd63jT/vvt5EUdYurq2eTEheFnbMHbvVaYOVQukgKIKWMRUHM/PEXnJzKUrdWDeITEoq7O0YrCTnyXQB99tlnaDQaPvroI2xsbPjss8+euo05F0DBIaEsW7mawIC2/PDNVF17eR9vpsyYxbYdu+kW2KEYe/h0asgAkkNJ1JABlJXj3rVzhG1fkevy8m2fw7t5R66unsPxr0br2sMPbCZw7n5qvzqWs79M1LUHr/2Zi0u/IjM1mUrdX3tiAWRpa0frKcuJPXuIvz7ojTYzwzSh8kFJY1EQOzcFUaG8DwAB3V4o5t4YryTkyPdl8NevXyc0NFQ3sfn69etPfYWGhpq84yXF5u070Wq1DBrQT6+9X59e2NvZsXHLH8XUs7xTQwaQHEqihgygvBwWNrZY2tobXObZ+NFHYde3LdNrv3v+CA9uBVOp6wC99pS4aDJTk8mLip1eolS5Spz68WO0mRlY2tqjsSzaGRZKGwtjZRcNJV1JyJHvd2jFihV1/5+enk5CQgIuLi66y9+LSnJysu7YSr7K7PyFS1hYWFC/bm29dltbW2rWqMb5i5eLqWd5p4YMIDmURA0ZQFk5ar7yLvWGPzqDkxhxg5CNC7iweLrubIyF9aPfk5kpSTm2zUhOpEzFGtg6u+eYC5QX3i06k/YwAZvSznRdehzn6g3Jyswk9twhTs76gLhLud8s11SUNBaiZCjQjRC1Wi2NGzdm9erVpuqPnuDgYA4ePKjXtnv3blq2bEnp0qXx8fGhdOnSdOnShXPnzhVKHwoqOiYWZ6eyBos0Tw93YmLvkpmZWQw9yzs1ZADJoSRqyADKyKHNyiLy2G7OzJnAX+/35sj/jeBBeCj135jMs9OCdOslXL8EgEfjtnrb27l4UMavJgAOHsb9IVvatxoWlla0n7WZ+Ktn2P/xi5z+8WOcKteh45xdlK1U++k7KSAljIUoWQp0jtLGxgZPT08sLAp8Q2mD3nnnHZycnGjVqhUAf/75J926dcPCwoJnnnkGb29vbt++zc6dO3nmmWc4ePAgderUydO+w8PDCQ8P12vzcbHHp5y3STMkp6TkeobK9p/2lNRUHB0cTHpcU1JDBpAcSqKGDKCMHElRt9g9KlCvLWTjAlp9vhS/zv3xeaYH4Qc2E7Z9OXWHfEL9NyaTkfyQqON7sHf3odHo6bqPq6zsjOuntUNprOwdub5tOYe/GKprj7t8ko5zdlF36AT+nvCK8SHzQAljIUqWAlcuL7zwAmvWrKEwbid06tQpmjZtqvv6448/xsfHh4sXL7J3715+++039u/fz4kTJ7C2tmbChAl53vfcuXNp3ry53mvuwqUmz2BvZ0daWprBZan/tNs99qw0JVJDBpAcSqKGDKDsHBcWfgmAd8vOAKTdj2f3mK4kRd6kxYR5PLc+hMC5+0iJiyJkw3wA0hPvG3Ws7LlCoVuW6LVHn/yLxIgbeDRpa2gzk1LyWAhlKvAstREjRvDqq6/SuXNn3nnnHapUqYKDgQrb19c33/uOj4/HxcUFeHS36dOnT/Pzzz/neJZYgwYNGD16NLNmzcrzvocPH063bt302nxcDE8eLAgPdzeuhYaRlpaW46+TqOgY3N1csbS0NPlxTUkNGUByKIkaMoCyczyMCAPA1unfG8TdCz7D1gGNKF2hGnauXiRG3iAp8iatpywnKyODB7cN30/oaZJi7uBUtR4pd3Pe3DD5biTONRoZtd/8UPJYCGUq8Bmg+vXrc+7cOXbu3EmvXr2oU6cOlSpVyvEyRrly5bh586bua41GoyuI/svV1TXX6t8QHx8f/P399V6m/vgLoG6dWmRlZXH2/EW99tTUVC5fCaZu7ZomP6apqSEDSA4lUUMGUHaO0hWqAZASF5Vj2YNbwcSc3k9S5E00llZ4NmlPzJkDBidI58Xdi8cAw3OIHDx8SI2PNmq/+aHksRDKVOACaOLEiUycOJFJkybp/t/Qyxg9evRg0aJFJCYmYmNjQ+vWrVm6NOfHVJmZmaxcuZK6desWNI7JdQvsgEajYfHyIL32oLUbSU5JoWfXwFy2VA41ZADJoSRqyADKyGFTJucfhRoLCxq8MRmA8ANbnrh9veGTsHPx4MLi6Ub34cafK8nKzKRqnxF67T7P9MDBozx3Dm43et95pYSxECWLop8FFhsbS8OGDfH09OSLL76gdOnS9O3bl9q1azNw4EC8vLy4ffs28+bN48SJE6xcuZIXX3zR+AMW0rPAvpg2k2Wr1tApoA1tW7ck5PoNlq78naaNG7Lo5+9KxN1J1ZABJIeSqCEDFH2O/z4L7Nlpv2PlUJrY84dJirqFnbMHvh374lytAaFblnD489d167aduZGH4aEkXL+ExsICn2d6UK5lZ84vmKp3E0QABy9fKnV9FQDnGg3xbd+HsO0rSAh7dDn59W3LSIr89wx9w1HTqD3wA+4c3Eb4gS04elWker+3SU+8z/bBzUmO1r/opDCeBaaG99T6zdu5E/Hoe7Nw6UpsbW14pV8fAMp5e9G7R5fi7F6eFXkONT4MNSQkhAEDBnD06FE0Go1usnX2G1mr1VKqVCmmT5/OW2+9VbCDFVIBlJmZyeLlQaxau4HwO5G4ODvRvXNHRr81FAd70887KgxqyACSQ0nUkAGKPsd/C6DKPYdQqeurlPGrgU0ZF7LSUrh37TwhmxYQummR3rp1h06gYqd+OHpVRJuVSdyV01xZ9T23967PcRyPxm3pOGdXrv3Y+VYHok/+pddW7YU3qfbCm5SuUI30pAdEHv6T03Mm6BVK2QqjAFLDe2rgsFEcPXHK4DL/Jo1YOu/HIu6RcYo8R3EVQGlpafz000+sW7dOd9fnypUr06dPH0aOHGmSGxXu2bOHP/74g6tXr/LgwQPs7e1183iee+65XOcG5Ys8DV4IoXDyNHghDCiOAujBgwcEBARw4sQJSpUqRZUqVQAIDQ3lwYMHNG3alN27d1OqVKmCHKZoSAEkhFA4KYCEMMCIAqjAk6A/++wzTpw4wbRp04iJieHUqVOcOnWK6Ohopk+fzokTJ/L0wFQhhBBCiKJS4DNAfn5+BAQEsGDBAoPLhwwZwp49ewgLCyvIYYqGnAESQiicnAESwoDiOAMUERGBv79/rsubN29OZKS80YUQQgihHAUugDw8PDh79myuy8+ePYubW/4rMyGEEEKIwlLgAqhHjx7MnTuX+fPn53ge2OLFi5k3bx69evUq6GGEEEIIIUymwHOAYmNjadWqFSEhIXh5eVGz5qPbjV+5coWIiAiqVq3KwYMHcXV1NUmHC5XMARJCKJzMARLCgOKYA+Tm5sbx48f5+OOPcXJy4tChQxw6dAgnJyfGjRvHsWPHSkbxI4QQQgizofg7QRcpOQMkhFA4OQMkhAHFcQZICCGEEKKkkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZkQJICCGEEGZHCiAhhBBCmB0pgIQQQghhdqQAEkIIIYTZkTtBP07uBC1MbHYrddy1d+RBuWuvEELB5E7QQgghhBBPJwWQEEIIIcyOFEBCCCGEMDtSAAkhhBDC7EgBJIQQQgizIwWQEEIIIcyOFEBCCCGEMDtSAAkhhBDC7EgBJIQQQgizIwWQEEIIIcyOFEBCCCGEMDtSAAkhhBDC7EgBJIQQQgizIwWQEEIIIcyOFEBCCCGEMDtSAAkhhBDC7FgVdwfMQVZWFktWBLFyzQZuh0fg6uJMt84dGPPmMOzt7Yq7e3mihgygnBx2zm40HT4ev7Y9cHQvR+r9eGIun+bvr97j3o2rOHqUo0bP1/Bt3QUn36pYO5Ti/u1QQnat4/SSmWQkJxrcb+WA3tR7ZTRuNRpiYWXFgzthBG9byYl5X+bal1rPv077Sb8CMO9ZV9IeJBRK5v9SylgU1C/zl3Dh0hXOX7xMeEQkNatXZcOqxcXdrXxRy1hIDuUoCRmkACoCU7/+nqW//U6ngDa8PrA/IaFhLFkRxOUrwSyYMwuNRlPcXXwqNWQAZeQoU74yvefvJiszgysbl/Ag4iZ2ZV1wr90EO2d3uHEVvzY9aDpiAmH7NhO6ay0ZKcmUa9qGZm98SpWOfVgzsBUZKcl6+20xZioNB71P6K61HP7+E7RZWZQpX5lSXhVy7Yudsxst3/mS9KSHWDuUKuzoepQwFqYw88dfcHIqS91aNYhPKJri0dTUMhaSQzlKQgYpgApZcEgoy1auJjCgLT98M1XXXt7HmykzZrFtx266BXYoxh4+nRoygHJydJy6lOT4GNYPDSA98YHBde6c3M/SrpVJjovWtV1cM5eEmyE0e2MCNZ8bwvlVs3XLfFt3ofHrH7Jz/CCublme5760fv9rHkbd5m7wOWr0eNX4UPmklLEwhZ2bgqhQ3geAgG4vFHNv8k8tYyE5lKOkZJA5QIVs8/adaLVaBg3op9fer08v7O3s2Ljlj2LqWd6pIQMoI0e5pu3wqt+co7Mnk574AAtrGyysbXKsFx96Sa/4yRayYzUArlXr6LU3GvIh0RdP6IqfvJzN8fEPoHq3V9j35Wi0WZnGxDGaEsbCVLKLn5JKLWMhOZSjpGSQAqiQnb9wCQsLC+rXra3XbmtrS80a1Th/8XIx9Szv1JABlJHDt3VnANIeJtB7/h7eOPKQN48l8eLKY1RoGfjU7Ut5lgcgOT5W12Zl54B3w1ZEnT1M0xETeH1vFMMP3mPo/ru0Hf8TVvaOOfZjYW1Dm09+4PKmJUSePmiidHmnhLEQj6hlLCSHcpSUDFIAFbLomFicncpiY5Pzr3xPD3diYu+SmVm0f33nlxoygDJyOFWsBkDnr1eR9jCBPz9+hb+mjMTeyY3uP26ifPPcTwtrLCxoOmI8WRkZBG9fqWsv61sVCysrqgS+SIOB/+Pkgulsf/9FQnevo86Lb9D9+w059tVk2Djsnd05NOtj04fMAyWMhXhELWMhOZSjpGRQ9BygGjVq0LNnT4YMGUKdOnWevkE+hIeHEx4ertfm42KPTzlvkx4nOSXF4JsAwPaf9pTUVBwdHEx6XFNSQwZQRg5rh9IA3Lt+ha3v9Na13z66m5fXnKP5qC+4fWSXwW1bvjMNrwYtOfbz58SHXsqxTwcXDza+0Vm3feiudWg0Gmr2GoRv6y7c/Hs7AE4Vq9N4yIcc+Oo9Uh47k1SUlDAW4hG1jIXkUI6SkkHRZ4CCg4P59ttvqV+/Pi1btmTu3Lk8eGB40mh+zZ07l+bNm+u95i5capJ9P87ezo60tDSDy1L/abeztTX5cU1JDRlAGTkyUx9duXVls/57LeHmNSLPHMKjTlOs7HL+Umg4+AMaDnqPK5uWcuznzw3u82HU7RzF0+WNj45TrmlbXVub8T9xN/gcF1b/WvBARlLCWIhH1DIWkkM5SkoGRRdAAMOHD6dnz56cOHGCN998E29vbwYPHsy+ffsKvN8jR47ovYYPGWiiXv/Lw92N+HsJBt8MUdExuLu5YmlpafLjmpIaMoAyciRGPzrrmBQblWNZUmwEGgsLbEqX1Wuv138Urf43jWt/BLF70tAc2z3U7TPS4D4BbMs4AY/uE1Tevz2nl35LmfKVKVOhCmUqVNGdRSpTrhKly1U0PmAeKWEsxCNqGQvJoRwlJYPiC6A2bdqwfv16wsPDmTFjBn5+fixZsoT27dtTrVo1vvzyS+7cuZPv/fr4+ODv76/3MvXHXwB169QiKyuLs+cv6rWnpqZy+UowdWvXNPkxTU0NGUAZOaLOHwOglGfOK4dKeZYnMz2d1IQ4XVudfm/y7EezCN21jh2fDESblZVju+S7UTyIuImjh+F9AiTHxTz62tsXgMBpy3l10xXdq0rHPgD0W3WcF5b8XcCUT6eEsRCPqGUsJIdylJQMii+Asrm7u/P+++9z/vz5R2drhg8nNjaW8ePHU7FiRXr06MHatWuLu5s5dAvsgEajYfHyIL32oLUbSU5JoWfXp1/5U9zUkAGUkeP63o2kJT6g1vOvo3nsLyDX6vXxrN+COyf+IjMtFXh0h+Y2H39P2F+b+fOj/mifMGnw6tYVOLp7U6n9c3rtdV58A0A3/yds3xa2f9Avxyv82F4Adk0YzJ7Jb5gyskFKGAvxiFrGQnIoR0nJoNFqtdri7kRuLCwsWLZsGa+88orB5SkpKaxZs4aFCxeyZ88egILNLE8qnAmhX0ybybJVa+gU0Ia2rVsScv0GS1f+TtPGDVn083eKuCPm06ghAxR9jtmtvHK01en3Jm0/+ZGI0we5tn0VtmVdqN9/FJY2tqwd0pa7V87g164nXWeuISUhjsPfjdMVRdmS4qK5fXin7mub0mXpu+wQpTwrcG7lT9y/E0bFZ7ri16Y7V7csZ+f4QU/sZ8Dn86nZa1Cuj8IYeTDnx2sFpZb31PrN27kT8ej7s3DpSmxtbXil36MzauW8vejdo0txdi9P1DIWkkM5ijyDg1u+NynRBdDjbty4weLFi5k4caLxByykAigzM5PFy4NYtXYD4XcicXF2onvnjox+aygO9vaFckxTU0MGKPochgoggKqBL9Jw0Hu4VKlLZnoad07s48iPnxJ37TwAzd6cSLM3c38vhx//iw3D9C+Zt3fxoPmoz/Fr0wPbsi48uBPGpfWLOL34a4MfnT2uOAogtbynBg4bxdETpwwu82/SiKXzfiziHuWfWsZCcihHkWcw5wLIJAqpABLmK7cCqKQpjAJICCFMxogCSNFzgCZNmkT9+vWLuxtCCCGEUBlF3whx0qRJxd0FIYQQQqiQos8ACSGEEEIUBimAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZkcKICGEEEKYHSmAhBBCCGF2pAASQgghhNmRAkgIIYQQZsequDsgRG5WBXgVdxcKbOTByOLughBCCAPkDJAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLNjVdwdMAe/zF/ChUtXOH/xMuERkdSsXpUNqxYXd7fyJSsriyUrgli5ZgO3wyNwdXGmW+cOjHlzGPb2doV+fAfvivRcF2JwWcyZv9n9Rlvd1xpLK6o8P4LKPQfj6FMFsrJ4GB5C6KaFhK6fizYrS7eu/6fzqdR9kMH97h3dmahju/TarB3LUO/Nzynfrg82ZVx4ePsawb//RMj6uSZImXfFPR6moIYMoI4casgAkkNJSkIGKYCKwMwff8HJqSx1a9UgPiGhuLtjlKlff8/S336nU0AbXh/Yn5DQMJasCOLylWAWzJmFRqMpkn7c3ruO23vX6bWlxMXofe0/YR5+XV/l1u41hGyYj8bCkvLtnqfphz/hXK0Bx6ePzLHfw5+9lqMtIeS83tcWVta0/f4PnGs0JPj3n7gfdgnvll1o+vEcbJ3dubhwqgkS5o1SxqMg1JAB1JFDDRlAcihJScggBVAR2LkpiArlfQAI6PZCMfcm/4JDQlm2cjWBAW354Zt//5Ev7+PNlBmz2LZjN90COxRJX+5dO8eN7StyXW7r7E7Fzq9we+96Dn7ykq792po5BC46gl+PwZz4egzazAy97Z60z2yVnxuKa51mnPzmHYJ//wmA0A3zafVlELWHjOf6liUkR982MlneKWk8jKWGDKCOHGrIAJJDSUpKBpkDVASyi5+SavP2nWi1WgYN6KfX3q9PL+zt7Ni45Y8i7Y+FjS2WtvYGl1k7lkFjYUFy7B39BVotyXejyEpPy1H8ZLNyKA1P+KvEN7A/GcmJhGyYp9d+deX3WNrYUqFD3/wFMZLSxsMYasgA6sihhgwgOZSkpGSQM0Diqc5fuISFhQX169bWa7e1taVmjWqcv3i5yPpSo/+71B02EYDEiBuEblzApSXTdUVN4p3rPLgVTKUeQ7h39TSRx3ZhYWlFhYC+eDUP5OxP4wzut8+uOKwdy5CZmkL0yb2c+/lT4q+c+ncFjQbnGo2Iv3KKrLRUvW3jLh5Fm5WFS62mhRP6P5Q0HsZSQwZQRw41ZADJoSQlJUOJLoCysrLQarVYWloWd1dULTomFmenstjY2ORY5unhzqkz58jMzCzcccjKIurYbsL3bSAx4gZ2Lh74Bvan3huTcanVhAMf9gFAm5XFgbF9aD5pIc0++VW3eUZKMsemDidsyxK93abcjeLKb7OIv3yCjJQknGs0pvpLYwj4ZR97Rwdy99whAGxKO2Nl50ByTHjOrqWnkXovFnv3ojnTp4jxKCA1ZAB15FBDBpAcSlJSMij+I7CVK1cSEBBAr169OHjwIAAXL14kICAAe3t7bG1tadq0Kdu3by/mnqpXckqKwTcygO0/7SmpqQaXm0pS1C32jg4k+PefuHNgM6EbF7B3VCdu/PEbPm16Ue6ZHrp105Me8ODWNcK2LePg+Jc5PGkgsWcO0GzcL/gGvqy337OzP+H0dx9w44/fCP9rA+d/ncSuEc+isbCg8fuzdOtZ2jkA5Dj7ky0zLQUrO8Mfy5maEsajoNSQAdSRQw0ZQHIoSUnJoOgzQH/++SevvPIK1tbW2NrasmfPHv766y+6detGWloanTt3JiMjg/3799OzZ0927dpFmzZt8rTv8PBwwsP1/5r3cbHHp5x3YUQp0ezt7LgbF29wWWpaGgB2trZF2SWdi4u+pGLn/ni37MydA5uxcihFx7n7iTl9gCOTB+vWu/HHb3T4dR9NPvyJiL+3kp54P9d9JoSc587+TVTo0BdbZ3dS42PITEkCHs0/MsTSxo6MlGSTZsuNkscjr9SQAdSRQw0ZQHIoSUnJoOgzQDNnzqRatWqEh4cTHx9Pr169eP7553FycuLKlSts3LiRrVu3cu7cOdzc3Jg2bVqe9z137lyaN2+u95q7cGkhpim5PNzdiL+XQNo/b9zHRUXH4O7mWmynMhMjwgCwKesGQIX2L+DgWYFbe9bkWPf23nXYlCqLU/WGedjvDQBs/9lv2oN4MlKSDH7MZWFtg62Tm8GPxwqDkscjr9SQAdSRQw0ZQHIoSUnJoOgC6OzZswwdOhQ3NzcsLS358MMPuXXrFu+//z7u7u669fz8/HjzzTc5fPhwnvc9fPhwjhw5ovcaPmRgYcQo8erWqUVWVhZnz1/Ua09NTeXylWDq1q5ZTD2D0hWqPepLfBQAdq5eAGgscv5waSyt9P77JKUqVAUgJT76UYNWS/yVUzhXb4iFtf6pXZfa/mgsLIi/fMK4EPmk5PHIKzVkAHXkUEMGkBxKUlIyKLoASkhIwM3NTfd19v97enrmWNfb25uUlJQ879vHxwd/f3+9l3z8ZVi3wA5oNBoWLw/Saw9au5HklBR6dg0s9D7YlHHJ0aaxsKDuG5MBCN+/BYCE649+4Py66RezGktLfDu9RFZGOveCzwCP5vUY+kjLtV5LyrXuTuzZQ6Ql3NW13/xzJVb2jlTpPVxv/eovjyEzLZVbu1YXIGHeKWE8CkoNGUAdOdSQASSHkpSUDIqeA1ShQgXOnTun+zr7/48cOUKvXr301j106BC+vr5F2r+8Wr95O3ciIgF48DCRtPR0Zs9dBEA5by969+hSjL17uhrVqjCgXx+WrVrDqPfH0bZ1S0Ku32Dpyt9p4d+Ebp0L/4ZWzT75BSuH0tw9d5ik6FvYOnvg26EvTtUacH3LEqKO7gAg4uBW4i4ew+eZHrT7cQfhf61HY2WNX5dXcK7ekEtLv9IVNaUrVKPNt5sJ37eBB7eukZmShHP1hvh1H0RGSiInvhql14fQDfOo1GMQDd/5Gkdvv0d3gm7VlfLtnuf83MkkRd0q9O8DKGM8CkoNGUAdOdSQASSHkpSUDBqtVqst7k7kZuzYscyePZvp06fj7e3NuHHjSE5Opnbt2vTr148XXniBzMxMFi9ezEcffcTQoUP5+eefjT9gUqzpOv+YgcNGcfTEKYPL/Js0Yum8HwvluKaUmZnJ4uVBrFq7gfA7kbg4O9G9c0dGvzUUB/vCufppVYCX7v8r9RyCX9dXKV2xBjZlXMhKSyEh5DyhGxdwffMive0s7Ryo0f9/VOjQF0dvPzSWVty/fpGQ9fMIfewmhnYunjQYPR2XWk2xdy+HhY0dKbERRB3bycVF00i8cz1Hn6xLlaXem19Qvt3z/z4LbPVsQtb+YjDDS7sjTfPN+I/iGA9TU0MGUEcONWQAyaEkRZ7Bwe3p6/yHogugu3fv0qpVK4KDgwGwsrIiKCgIV1dXOnToQGZmJgBarRZnZ2fOnj2Lj08B7sVSSAWQMM7jBVBJVVgFkBBCiMcYUQAp+iMwV1dXzpw5w+bNm0lISKBdu3ZUqVIFgAMHDvDTTz8RFRVF7dq1eeeddwpW/AghhBDCbCj6DFCRkzNAiiJngIQQQuSJEWeAFH0VmBBCCCFEYZACSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXakABJCCCGE2ZECSAghhBBmRwogIYQQQpgdKYCEEEIIYXY0Wq1WW9ydUIyk2OLugRCKtLydV3F3ocAG7I0s7i4IIQqLg1u+N5EzQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1IACSGEEMLsSAEkhBBCCLMjBZAQQgghzI4UQEIIIYQwO1bF3QFz8Mv8JVy4dIXzFy8THhFJzepV2bBqcXF3K1+ysrJYsiKIlWs2cDs8AlcXZ7p17sCYN4dhb29X3N3LMzXkUML7ydG7Ir03hBhcFn36b3aMaKv72sLahjqDx+HX+WUcvXxJexBP+P7NnJ7zKanxMU88TqvJi6nUdQBxV0+z7dWmBtfxaNyW2gM/wK2uP5a2DiRF3+bOoe2c+OZd4wPmgxLGo6DU8HMBkkNJSkIGKYCKwMwff8HJqSx1a9UgPiGhuLtjlKlff8/S336nU0AbXh/Yn5DQMJasCOLylWAWzJmFRqMp7i7miRpyKOn9dHPPOm7tWafXlvJ4UaPR0G7mRrybd+TmrjVc/m0WDh7lqf7iSNwbPsP2IS3JSHxgcN+ezQKo2OklMlKScj1+tRfeoNnYH4g4soNzc78gIzUJR09fylapY5J8eaGk8TCWGn4uQHIoSUnIIAVQEdi5KYgK5X0ACOj2QjH3Jv+CQ0JZtnI1gQFt+eGbqbr28j7eTJkxi207dtMtsEMx9jBv1JJDSe+ne9fOEbZ9Ra7LK7R9Du/mHbm6eg7HZozWtd/ev5nO8/ZTZ+BYzvw8Mcd2Fja2+H/0I9fW/Uq51t0M7tupSl2avj+Ls79O5vyC/yt4GCMpaTyMoZafC8mhHCUlg8wBKgLZvxxLqs3bd6LVahk0oJ9ee78+vbC3s2Pjlj+KqWf5o5YcSns/WdjYYmlrb3CZR5NHH4WFbl2m1373/BEe3AqmUtcBBrerO3gc1o5lOT3n01yPW+vV90hNiOPC4mkAWNk7QjH8Vam08cgvtfxcSA7lKCkZpAAST3X+wiUsLCyoX7e2XrutrS01a1Tj/MXLxdSz/FFLDiWp9cq79D+QyMv7H9B7Qwh1Xx+PxvLfE8uW1jYAZBr4GCsjORFH74rYOrvrtZf2rU7t18Zy6sePSX+Y+0dK3i0CuXvhKFWfG8rzm2/w0l8JvPRXAq2nLMfOxcNECdVPLT8XkkM5SkqGElEA7d69myFDhlC3bl2cnJywsbHBzc2N1q1bM2XKFGJinjyRUhRMdEwszk5lsbGxybHM08OdmNi7ZGZmFkPP8kctOZRAm5VF5LHdnJ4zgb3v9ebw/43gQXgoDd6czLPTgnTrJYReAsCzcVu97e1cPCjjVxMAB4/yesuaj5vD3YvHuL5laa7Ht3Ysg72rF251m9Pk3Zlc2zCfvz58geC1v+LboS8dZ+/M9ayU0KeWnwvJoRwlJYOi5wBlZGQwaNAgVq5ciVar1bVbW1tTpUoVQkNDmThxIrNmzWLZsmV06dIlz/sODw8nPDxcr83HxR6fct4m679aJKekGHwjA9j+056Smoqjg0NRdivf1JJDCZKibrHr7UC9tpANC2j9xVL8OvfH55kehB/YzPXty6n7+ifUf3My6ckPiTq+Bwd3HxqNma47U2Rl9+/3u3L313Bv0IptA5s98fhWjqWBR4XU4f8bQciGBQDc3ruB9MT71B8+kco9XiN4zS+mjK1Kavm5kBzKUVIyKPoM0IwZM1i1ahXTpk3jzp07JCQksG7dOtzd3enWrRsRERGcPHmS+vXr8/zzz3P+/Pk873vu3Lk0b95c7zV3Ye5/cZozezs70tLSDC5L/afdzta2KLtkFLXkULLzC78EoFyrzgCk3Y9n9+iuJEXepOWn8+i9IYTAeftIiYsiZMN8ANIT7wNgU9aFRmOmcyXoJ+6FPPlnOTM1GYCszEyu/2d+UeiWJUDOs07CMLX8XEgO5SgpGRR9BmjRokW8/vrrjB07Vtf23HPPkZmZyYABA3jnnXdo2LAhf/zxB40aNeKLL75g1apVedr38OHD6dZN/+oSHxc5ZW6Ih7sb10LDSEtLy1HVR0XH4O7miqWlZTH1Lu/UkkPJHt4JA8DWyU3XFh98hi2vNKK0bzXsXb1IjLhBYuRNWk9ZTlZGBg9uP7qfUL1hn2JhbcP1rcsoVb6KbnsLSyssrWwoVb4KGUkPSImLJu1+PBnJiWSkJpOVrv+LNjk2AgCb0s6FnFYd1PJzITmUo6RkUPQZoJs3b9KsWc5T4c2aNSM1NZWLFy8Cjz4Se+2119i7d2+e9+3j44O/v7/eSz7+MqxunVpkZWVx9vxFvfbU1FQuXwmmbu2axdSz/FFLDiUrU6EaAClxUTmWPbgZTPSp/SRG3kRjaYVX0/ZEnz6gmyDt6OWLTamydFt2nOfWXtG9HDzLU7ZybZ5be4Um7337aGdaLXGXT2JbxiXHXJ/sOUUp8dGFmFQ91PJzITmUo6RkUHQB5OLiwuXLOWeLX758GY1Gg6Ojo67Nzc2N+/fvF2X3zEa3wA5oNBoWLw/Saw9au5HklBR6dg3MZUtlUUsOJbAp65KjTWNhQf03JwNwe/+WJ25ff8Qk7Fw8uLB4uq7t4pKv2PdxvxyvlLhoHt65zr6P+3H5t+9061/fthyNhQXV+ozQ23f1F94E4M7B7UbnMydq+bmQHMpRUjIo+iOwLl26MHv2bFq1asULLzy6wdj58+d55513cHd3p169erp1w8LC8PLyKq6uPtH6zdu5ExEJwIOHiaSlpzN77iIAynl70btH3idvF4ca1aowoF8flq1aw6j3x9G2dUtCrt9g6crfaeHfhG6di/+GVnmhlhxKeD81/+QXrB1KE3vuMIlRt7Bz8aBix744V2tA6JYlRB7ZoVu33cyNPLwTSsL1S2g0Fvg824NyLTtzfsFUvfVizx02eKzGY2aQ9jCBW7vX6rWHbFpI5R6DaDRmBqV9q3Ev+CzuDVpTqesAok78xY2dQQb3Z2pKGI+CUMvPheRQjpKSQaN9/PIqhblz5w7+/v5ERERgb2+PnZ0d8fHxaDQali9fzksvvaRbt27dutSrV4/ffvvN+AMmxZqg1zkNHDaKoydOGVzm36QRS+f9WCjHNaXMzEwWLw9i1doNhN+JxMXZie6dOzL6raE42JecuVNqyFEc76fl7fT/uKjSawiVur5KGb8a2JRxISs1hXv/3969R0V13XsA/w4CMzwUEBAUFVBRYBmDqUgxBqyJL3wQEEk1Ynw2WpdJDGrSSBRNYlZarUrS+gADjQ8IuiLl2qWIBqw1acRaYmiJEXwQR0BHRCHA8Jh9//AyNyMgMygehvP9rDVryZ4953w3R5gf++xzprgARZmf4vL/pBj0Hb4oDl4TomHX1xOiqQkVP+TjYloCfszNMGrf4RlFqK+ubPWzwCxt7fHU4nXwfCEKKmd31GlKcTU7Hd8lbtQvlG72cm6ZSWM2Fn++uw6Oo+t44mOwdWm/zwO6dAEEAGVlZdi0aRNOnTqF+vp6+Pv74/XXX0dISIhBv59++gnW1tawsrLq+M46qQAiMncPFkDmqLMKICLqArpjAfREsQAiahULICLq0jpQAHXpRdBEREREnYEFEBEREckOCyAiIiKSHRZAREREJDssgIiIiEh2WAARERGR7LAAIiIiItlhAURERESywwKIiIiIZIcFEBEREckOCyAiIiKSHRZAREREJDssgIiIiEh2WAARERGR7LAAIiIiItlhAURERESywwKIiIiIZEchhBBSh5ALtVqNxMRELFmyBB4eHlLH6bDuMI7uMAaA4+hKusMYgO4xju4wBoDj6GycAXqC1Go1NmzYALVaLXWUR9IdxtEdxgBwHF1JdxgD0D3G0R3GAHAcnY0FEBEREckOCyAiIiKSHRZAREREJDssgJ4gDw8PrF+/vkstAuuI7jCO7jAGgOPoSrrDGIDuMY7uMAaA4+hsvAqMiIiIZIczQERERCQ7LICIiIhIdlgAERERkeywACIiIiLZYQFEREREssMCiIiIiGSHBdAToNPpsHXrVvj6+kKpVGLAgAFYvXo1ampqpI5mtA8//BBRUVHw8vKCQqFAQECA1JFMdv78ecTGxmLkyJFwdHSEs7MzgoODsW/fPpjT3SBKSkoQExMDf39/ODo6wtbWFr6+vli5ciVKS0uljtdhhYWFUCqVUCgUyMjIkDqOUa5evQqFQtHqY+zYsVLHM8mtW7fw2muvwdvbG0qlEu7u7pgyZQouXrwodTSjxMfHt3ksFAoFfHx8pI5oNI1Gg9WrV2PYsGGwtbVF3759MWnSJGRlZUkdzWhqtRoLFy5E3759oVQq4ePjgw8++AANDQ1SR9OzlDqAHKxcuRIJCQmIiIhAbGwsCgsLsW3bNuTn5+P48eNQKBRSR2zXO++8A2dnZ/ziF7/A7du3pY7TIb///e9x8uRJzJw5E0uXLkVdXR3S09MRExODnJwc7NmzR+qIRikvL0dJSQlmzJiBAQMGwMrKCgUFBUhMTER6ejry8/Ph6uoqdUyTCCHw6quvwsrKCvX19VLHMVlERAQiIyMN2vr06SNRGtMVFxcjNDQUlpaWmD9/PgYOHIiKigqcO3cOt27dwrBhw6SO2K7IyEgMGTKkRfvp06exe/duTJs2TYJUpqutrcWzzz6LkpISLFmyBCNGjIBGo8GePXswefJk7N+/H3PmzJE65kOVlpYiKCgIt27dwrJly+Dn54e8vDysW7cOBQUFSE1NlTrifYI6VUFBgVAoFCIyMtKgPSEhQQAQn3/+uUTJTFNcXKz/t6enp3j66aelC9NBZ86cEXV1dQZtTU1NIjQ0VAAQ3333nUTJHo/09HQBQGzevFnqKCZLSkoStra2Ij4+XgAQhw8fljqSUa5cuSIAiPXr10sd5ZEEBQWJgIAAcffuXamjPHbh4eECgLhw4YLUUYzS/HO8bds2g/abN28KKysrERoaKk0wE6xYsaLV97ePPvpIABDZ2dkSJTPEU2CdLDU1FUIIvPHGGwbtS5Ysga2tLfbt2ydNMBMNGjRI6giPbMyYMVAqlQZtFhYWmDlzJgCgoKBAiliPjaenJwCgsrJS2iAmunXrFtasWYO1a9fqx2CO6urqzOq0drOcnBx888032LhxI3r16gWtVgutVit1rMfi5s2b+Nvf/obAwEA89dRTUscxyt27dwEA/fr1M2jv3bs3lEol7OzspIhlktzcXNjY2GDWrFkG7TExMQCAvXv3ShGrBRZAnSwvLw8WFhYYPXq0QbtKpUJAQADy8vIkSkbNrl+/DgBmd9pIq9VCo9FArVYjOzsby5YtAwCEhYVJnMw0q1atgouLC1atWiV1lA7bsmULbGxsYGdnB09PT7z33ntdaq3Dwxw7dgwA4ODggJCQENjY2EClUmHkyJFmteakNXv37kVjYyMWLlwodRSjjRs3DpaWlvjd736Ho0eP4vr16/j2228xb9486HQ6vP3221JHbFd9fT1UKlWL5R3NxVtXed9jAdTJbty4ARcXlxYzD8D9D4grKytDU1OTBMkIuH+uevfu3fD09MRzzz0ndRyTpKamwtXVFf3798fEiRNRUVGB/fv3Izg4WOpoRsvJycFnn32GTz75BNbW1lLHMZmFhQXGjx+PTZs2ITMzE4mJiRg8eDDWrVuHqKgos1hc/8MPPwAAoqKi4ODggLS0NOzYsQMajQZhYWE4ceKExAk7Ljk5GTY2Npg9e7bUUYw2ZMgQfP7556irq0NYWBgGDBiAgIAA/P3vf8epU6fM4veUv78/7ty5gwsXLhi05+TkAPj/PzqlxkXQnaympqbV4ge4PwsE3F/0Zm9v/yRjEe7PoMyaNQv37t3DoUOHzO4NeNKkScjOzkZVVRXy8vKQmZlpVqe/tFotli5diujoaEyYMEHqOB0ycOBAnDx50qBt8eLFmDNnDlJTU3HkyBFMnz5donTGqaqqAgD4+voiMzNT/1f7888/D39/f6xduxYvvPCClBE75OzZs/jPf/6DuXPnwsHBQeo4JnFxcYGfnx/mzp2LX/7ylygvL8eWLVswdepUnDx5EsOHD5c64kO9/vrr+Otf/4qXXnoJ27dvh6+vL86dO4cVK1bAysqq65wqlnoRUnc3fPhw0adPn1afmzVrlgAgGhsbn3CqR2Oui6B/rqGhQcyYMUMoFAqRmJgodZzHIjc3VwAwm/HEx8cLe3t7cf36dX1bcnKyWS2CbktBQYEAIJYtWyZ1lHZNmzatzf83ISEhQqFQiOrqagmSPZpXX31VABBffvml1FFM8s033whLS0uxa9cug/by8nLh6OhoFoughRDiwIEDwtXVVQAQAIS1tbVYt26dCAwMFE5OTlLHE0JwEXSn69evHzQaTauLCtVqNdzd3dGjRw8JkslXU1MT5syZg8zMTGzfvh2LFy+WOtJjERoaiv79+yM5OVnqKO0qLS3Fhx9+iEWLFqG2thZFRUUoKirCzZs3AQBlZWUoKioym3U0D/Ly8gJw/34uXZ2HhwcAwN3dvcVzffv2hRBCvzDXXNTW1iItLQ2DBg3CuHHjpI5jkj/96U9obGxEVFSUQXufPn0wduxYnDlzBo2NjRKlM97s2bNx48YNnD9/HqdPn0ZpaSk2bNiAkpKSLnNbBRZAnSwwMBA6nQ5nz541aK+rq0N+fj5GjRolUTJ50ul0iImJwcGDB7F582asWLFC6kiPVW1tLe7cuSN1jHaVl5dDq9Vi+/bt8PHx0T/eeustAMCyZcvg4+OD4uJiiZN2zKVLlwAAbm5uEidpX/MFGq2ty7h+/TosLS3Ru3fvJx3rkXzxxRe4e/cuFixYYBb3Wfu5srIyAGh1bWhjYyOamprMYm0ZAFhaWmLkyJEYO3Ysevfujfz8fJSXl2Py5MlSRwPAAqjTvfTSS1AoFNi2bZtBe2JiImpqavDyyy9LE0yGdDodFixYgNTUVGzatAmxsbFSR+qQ8vLyVtvT0tJw+/ZtBAUFPeFEpvP29sbBgwdbPJYvXw4AWLNmDQ4ePKifneiqWrspaFNTE959910A6PLrfwAgPDwc9vb2SEpKMphZ+Pbbb/H1119j3Lhx+vWK5iI5ORkWFhaYP3++1FFM5u/vDwD4y1/+YtB+9epVnD59Gk8//TSsrKykiPZI6uvr8eabb8LJyQlLly6VOg4AQCHMpZQ0YytWrMAnn3yCiIgIhIWFobCwEAkJCQgJCcGJEyfM4i+UvXv34tq1awDuX/KrUqn0b1aenp76+zt0ZbGxsfjjH/+IwMBAvPbaay2eHzFiBEaMGCFBMtPMnz8fBQUFmDhxIry8vPDTTz/hn//8Jw4dOgQ3Nzd8/fXXZns/nZSUFCxYsACHDx/Giy++KHWcdkVGRqKqqgrBwcEYMGAAbt68ifT0dFy4cAHz5s1r8SbWVf35z3/G8uXLMWbMGPz6179GRUUFEhISoNVq8Y9//MOsPvrm2rVr8Pb2xqRJk3D06FGp45js6tWreOaZZ3D37l3ExMQgODgYZWVl2LFjB27duoXMzExMnTpV6pgPVV1djaCgIERGRsLLywsajQafffYZioqK8MUXX3Sd/NIuQZKHxsZGsXnzZjF06FBhbW0tPDw8RGxsrFktLGy+W3JrD3NZlPewMcCM7uabmZkpZsyYIfr37y+USqWwsbERfn5+IjY2VpSXl0sd75GY2yLopKQkERoaKtzc3ISVlZXo2bOnGDNmjNizZ4/Q6XRSxzNJWlqaGDVqlFCpVKJXr15i+vTpZnP35J9rvpt4enq61FE6rKSkRCxZskT4+PgIpVIpHBwcxMSJE81mQbdWqxXR0dFi4MCBwtraWri4uIiZM2eK/Px8qaMZ4AwQERERyQ7XABEREZHssAAiIiIi2WEBRERERLLDAoiIiIhkhwUQERERyQ4LICIiIpIdFkBEREQkOyyAiIiISHZYABEREZHssAAiIiIi2WEBRERP3Pz581t8CPC4cePg5eUlTaB2GJstNzcXCoUCKSkpHdpPSkoKFAoFcnNzO/T6tly9ehUKhQLx8fGPdbtE5owFEBGZtcrKSsTHxz/2ooGIujdLqQMQEQHA8ePH0ZHPZq6srMSGDRsA3J+pISIyBmeAiMgo1dXVnbp9a2trKJXKTt0HEVEzFkBEMtC8tiQ7OxtxcXHo378/VCoVRo0ahePHjxv0/fl6kf379yMgIAAqlQpxcXH6Pvv370dwcDDs7e1hZ2eHkJAQZGdnt9hvXV0dVq9ejX79+sHGxgajR49usb9mba2zOXv2LCIiIuDq6gqlUgkvLy8sXLgQGo0Gubm58Pb2BgBs2LABCoUCCoXCYCZIp9Ph448/RkBAAGxsbODg4IApU6bg3LlzLfZ1584dLFmyBC4uLrCzs8O4cePwr3/9y5hvcZuqqqoQFxeH0aNHw9nZGSqVCr6+vvjggw/Q2NjY6msaGhraPU7NjD0WRGSIp8CIZGTNmjVoaGjAG2+8Aa1Wi127dmHq1Kk4duwYnn/+eYO+hw8fhlqtxm9/+1ssX74crq6uAIC3334bH330EaZPn45NmzahqakJBw4cwOTJk3Ho0CFERETotzF79mxkZGQgPDwcEyZMQHFxMSIjI/VFS3sOHz6M6OhoODk5YfHixfD29oZarUZmZiauX78OPz8/bN26FStXrkRERAQiIyMBAG5ubvptvPzyy0hPT8fs2bPxm9/8BtXV1UhKSsJzzz2HU6dOYfTo0QDuFx2TJk1CXl4eXnnlFQQFBeHf//43XnjhBTg7O3f4e65Wq7Fnzx5ERUVh3rx50Ol0yMrKQlxcHK5cuYKkpKQWrzH2OJlyLIjoAYKIur3k5GQBQHh5eYl79+7p29VqtejZs6fw9/fXt125ckUAEFZWVuLixYsG28nLyxMARHx8vEF7Q0ODCAwMFJ6enkKn0wkhhMjKyhIAxKJFiwz6Hj58WAAQD/76CQ0NFZ6envqvq6qqRO/evYW7u7soKytrMaampiaDvOvXr2/R59ChQwKASElJMWi/d++eGDhwoAgJCdG37dq1SwAQGzduNOi7detWAcAgW1tycnIEAJGcnKxv02q1oqGhoUXfefPmCQsLC6FWq/VtphwnU47Fw75HRHLFU2BEMrJ06VL07NlT/3W/fv0wZ84c/Pe//8WlS5cM+k6bNg1Dhw41aEtNTYVCocDcuXOh0Wj0j8rKSkydOhXXrl3TbycjIwMAsHr1aoNtvPjiixg2bFi7WY8fP46KigqsXr3aYEanmYVF+7++Dhw4ACcnJ4SFhRnk1Wq1mDBhAs6cOYPa2lp9XisrK6xcudJgG8uWLUOvXr3a3VdbrK2tYWl5f7K9oaEBFRUV0Gg0mDBhAnQ6Xaun4ow5TqYcCyJqiafAiGTE19e3RZufnx8A4PLly/Dx8dG3DxkypEXfwsJCCCFafa5ZeXk5hg4disuXL8PS0rLVvn5+frh48eJDsza/eQcEBDy038MUFhbizp076NOnT5t9NBoNBgwYgMuXL8PDwwP29vYGzyuVSgwaNAh37tzpcI6PP/4YO3fuxPfffw+dTmfwXGVlZYv+xhwnU44FEbXEAoiIWmVra9uiTafToUePHjh69GiLGxk2Gz58+GPN0dZ+jKHT6eDu7o69e/e22ad5bVNn2bJlC1atWoUpU6YgNjYW7u7usLa2xvnz5/HWW2+1KIiMJcWxIOpOWAARycj333+P8PBwg7bCwkIAwKBBg9p9vY+PD7KysuDt7f3QmYfm7WVlZaGoqKjFKa/mfT5M88xFfn4+fvWrX7XZ72EFko+PD44dO4Znn30WNjY27eY9ceIEqqurDWaBtFotLl++DCcnp3Yzt2bfvn3w9vbGkSNHDE7bFRcXt/kaY46TKceCiFriGiAiGdm5cyeqqqr0X9+4cQMHDhyAn5+fwemvtsydOxcAsHbt2lZnLm7evKn/d/Mb+B/+8AeDPhkZGe2e/gKAiRMnwtnZGZs3bzbYbjPxfzdNbC5WWjtFFRMTg8bGRrz77rut7uPBvA0NDdi6datBnx07duDevXvt5m1Ljx49DPICQG1tLRISEtp8jTHHyZRjQUQtcQaISEYcHR0RHByM+fPno76+Hjt37kRNTQ22bdtm1OuDgoIQFxeH999/H5cuXcLMmTPh5uYGtVqNr776CkVFRfqZjUmTJmH69OnYs2cPbt++rb8MfteuXRg+fDgKCgoeui87OzskJiYiOjoaTz31FBYtWgRvb2+UlpYiMzMTSUlJCAgIgLOzMwYPHoy0tDQMGTIErq6u6NOnD8aPH4/o6GgcOXIEW7Zswblz5xAWFgZHR0f8+OOP+PLLL2FtbY2cnBwAwIIFC7B7926sW7cOxcXF+svgDx48iMGDB7d5z572REZGYu3atQgLC0NkZCQqKiqQkpJisMj5QcYcJ1OOBRG1QtqL0IjoSWi+vPr48ePinXfeER4eHkKpVIpnnnlGHD161KCvMZdMZ2RkiPHjxwsHBwehVCqFp6enCA8PF2lpaQb9ampqxJtvvinc3NyESqUSgYGBIisrS7zyyivtXgbf7KuvvhLTpk0Tjo6OQqlUCi8vL7Fo0SKh0WgM+gQFBQmVSiUAiNDQUP1zOp1OfPrppyI4OFjY29sLGxsbMXjwYDF79mxx7Ngxg33dvn1bLFy4UPTu3VvY2tqK0NBQkZeX12a2B7V2GXxjY6PYuHGj8Pb2FtbW1mLw4MHi/fffF9nZ2S36mnKcmhlzLHgZPFFLCiE68OE7RGRWUlJSsGDBAuTk5PDzsoiIwDVAREREJEMsgIiIiEh2WAARERGR7HANEBEREckOZ4CIiIhIdlgAERERkeywACIiIiLZYQFEREREssMCiIiIiGSHBRARERHJDgsgIiIikh0WQERERCQ7LICIiIhIdlgAERERkeywACIiIiLZ+V8RV+khmJO/vQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x640 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataloader = DataLoader(mnist_train, batch_size=batch_size)\n",
    "pred, label = test_cnn()\n",
    "visualize_confusion(confusion_matrix(label, pred), name=f'{save_name} train')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "039d9dbc-ebf8-4d3e-84e1-ab3fc56b1155",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test\tBCE loss: 0.0687058380356601\taccuracy: 0.9850807189941406\n"
     ]
    }
   ],
   "source": [
    "test_dataset = MNISTMultiDigitADDDataset(mnist_test, n_digits=3, lenth=65536)\n",
    "dataloader = DataLoader(test_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'test\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4cf3cfe9-cbe0-42c6-a4bd-9e1fff7e3cb0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x640 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataloader = DataLoader(mnist_test, batch_size=batch_size)\n",
    "pred, label = test_cnn()\n",
    "visualize_confusion(confusion_matrix(label, pred), name=f'{save_name} test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e778bbd4-44e8-493a-9ed4-956a933a9feb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test\tBCE loss: 0.07159797965484244\taccuracy: 0.9806863947432172\n",
      "CPU times: user 1min 48s, sys: 13 s, total: 2min 1s\n",
      "Wall time: 1min 20s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "test_dataset = MNISTMultiDigitADDDataset(mnist_test, n_digits=128, lenth=8192)\n",
    "dataloader = DataLoader(test_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'test\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  }
 ],
 "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
}
