{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "989255aa",
   "metadata": {},
   "source": [
    "## This notebook provides the reproduction of Fig. 5 in the paper: information in weights (IIW) with varying batch size."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "fe2e76ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import pdb\n",
    "import os\n",
    "from collections import defaultdict\n",
    "from tqdm import tqdm\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "from torch import nn\n",
    "\n",
    "from src.models import MLP\n",
    "from src.dataset import load_data\n",
    "from src.pib_utils import train\n",
    "from src.utils import plot_info_acc, plot_info, train_track_info\n",
    "from src.utils import img_preprocess, setup_seed, predict, eval_metric, feature_map_size\n",
    "\n",
    "use_gpu = True if torch.cuda.is_available() else False\n",
    "__fig_dir__ = './figure'\n",
    "if not os.path.exists(__fig_dir__):\n",
    "    os.makedirs(__fig_dir__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e2a12c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "load from MNIST\n",
      "Extracting ./data\\train-images-idx3-ubyte.gz\n",
      "Extracting ./data\\train-labels-idx1-ubyte.gz\n",
      "Extracting ./data\\t10k-images-idx3-ubyte.gz\n",
      "Extracting ./data\\t10k-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "D:\\PAC-Bayes IB\\PAC-Bayes-IB\\src\\utils.py:23: UserWarning: The given NumPy array is not writeable, and PyTorch does not support non-writeable tensors. This means you can write to the underlying (supposedly non-writeable) NumPy array using the tensor. You may want to copy the array to protect its data or make it writeable before converting it to a tensor. This type of warning will be suppressed for the rest of this program. (Triggered internally at  ..\\torch\\csrc\\utils\\tensor_numpy.cpp:180.)\n",
      "  y = torch.LongTensor(y)\n"
     ]
    }
   ],
   "source": [
    "__data_set__ = 'mnist'\n",
    "x_tr, y_tr, x_va, y_va, x_te, y_te = load_data(__data_set__)\n",
    "all_tr_idx = np.arange(len(x_tr))\n",
    "num_class = np.unique(y_va).shape[0]\n",
    "x_tr, y_tr = img_preprocess(x_tr, y_tr, use_gpu)\n",
    "x_va, y_va = img_preprocess(x_va, y_va, use_gpu)\n",
    "x_te, y_te = img_preprocess(x_te, y_te, use_gpu)\n",
    "setup_seed(2020)\n",
    "__layers__ = [512,]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e93062b1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([55000, 784])\n"
     ]
    }
   ],
   "source": [
    "print(x_tr.shape)\n",
    "info_bs_list = []\n",
    "train_acc_bs_list = []\n",
    "test_acc_bs_list = []\n",
    "info_df_list = []\n",
    "loss_acc_list_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b67df34a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "##############################\n",
      "batch size: 4\n",
      "##############################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:01<00:00,  8.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initialize model weights.\n",
      "done get prior weights\n",
      "finish training and tracking\n"
     ]
    }
   ],
   "source": [
    "print('###'*10)\n",
    "print('batch size: 4')\n",
    "print('###'*10)\n",
    "model = MLP(num_class, 'relu', layers=__layers__)\n",
    "if use_gpu:\n",
    "    model.cuda()\n",
    "model.use_gpu = use_gpu\n",
    "\n",
    "# get prior on the validation set\n",
    "train(model, np.arange(len(y_va)), x_va, y_va, x_va, y_va, num_epoch=10, batch_size=128, lr=1e-3, weight_decay=1e-5, early_stop_ckpt_path=\"./checkpoints/mlp_prior.pth\",verbose=False)\n",
    "w0_dict = dict()\n",
    "for param in model.named_parameters():\n",
    "    w0_dict[param[0]] = param[1].clone().detach() # detach but still on gpu\n",
    "model.w0_dict = w0_dict\n",
    "model._initialize_weights()\n",
    "print(\"done get prior weights\")\n",
    "\n",
    "info_dict, loss_acc_list = train_track_info(model, all_tr_idx, x_tr, y_tr, x_va, y_va, \n",
    "                                            num_epoch=10,\n",
    "                                            batch_size=4, \n",
    "                                            lr=1e-3,\n",
    "                                            weight_decay=0,\n",
    "                                            track_info_per_iter=100,\n",
    "                                            verbose=False,)\n",
    "print(\"finish training and tracking\")\n",
    "# plot_info_acc(info_dict, loss_acc_list, 'bs32', __fig_dir__)\n",
    "\n",
    "# save info\n",
    "df_info = pd.DataFrame(info_dict)\n",
    "info_bs_list.append(df_info.mean(1).mean())\n",
    "train_acc_bs_list.append(max(loss_acc_list['tr_acc']))\n",
    "test_acc_bs_list.append(max(loss_acc_list['va_acc']))\n",
    "info_df_list.append(df_info)\n",
    "loss_acc_list_list.append(loss_acc_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cc91c0a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "##############################\n",
      "batch size: 16\n",
      "##############################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:00<00:00, 15.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initialize model weights.\n",
      "done get prior weights\n",
      "finish training and tracking\n"
     ]
    }
   ],
   "source": [
    "print('###'*10)\n",
    "print('batch size: 16')\n",
    "print('###'*10)\n",
    "model = MLP(num_class, 'relu', layers=__layers__)\n",
    "if use_gpu:\n",
    "    model.cuda()\n",
    "model.use_gpu = use_gpu\n",
    "\n",
    "# get prior on the validation set\n",
    "train(model, np.arange(len(y_va)), x_va, y_va, x_va, y_va, num_epoch=10, batch_size=128, lr=1e-3, weight_decay=1e-5, early_stop_ckpt_path=\"./checkpoints/mlp_prior.pth\",verbose=False)\n",
    "w0_dict = dict()\n",
    "for param in model.named_parameters():\n",
    "    w0_dict[param[0]] = param[1].clone().detach() # detach but still on gpu\n",
    "model.w0_dict = w0_dict\n",
    "model._initialize_weights()\n",
    "print(\"done get prior weights\")\n",
    "\n",
    "info_dict, loss_acc_list = train_track_info(model, all_tr_idx, x_tr, y_tr, x_va, y_va, \n",
    "                                            num_epoch=int((55000/4 * 10) / (55000/16)),\n",
    "                                            batch_size=16, \n",
    "                                            lr=1e-3,\n",
    "                                            weight_decay=0,\n",
    "                                            track_info_per_iter=100,\n",
    "                                            verbose=False,)\n",
    "print(\"finish training and tracking\")\n",
    "# plot_info_acc(info_dict, loss_acc_list, 'bs128', __fig_dir__)\n",
    "\n",
    "# save info\n",
    "df_info = pd.DataFrame(info_dict)\n",
    "info_bs_list.append(df_info.mean(1).mean())\n",
    "train_acc_bs_list.append(max(loss_acc_list['tr_acc']))\n",
    "test_acc_bs_list.append(max(loss_acc_list['va_acc']))\n",
    "info_df_list.append(df_info)\n",
    "loss_acc_list_list.append(loss_acc_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "11edbd48",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "##############################\n",
      "batch size: 64\n",
      "##############################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:00<00:00, 15.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initialize model weights.\n",
      "done get prior weights\n",
      "finish training and tracking\n"
     ]
    }
   ],
   "source": [
    "print('###'*10)\n",
    "print('batch size: 64')\n",
    "print('###'*10)\n",
    "model = MLP(num_class, 'relu', layers=__layers__)\n",
    "if use_gpu:\n",
    "    model.cuda()\n",
    "model.use_gpu = use_gpu\n",
    "\n",
    "# get prior on the validation set\n",
    "train(model, np.arange(len(y_va)), x_va, y_va, x_va, y_va, num_epoch=10, batch_size=128, lr=1e-3, weight_decay=1e-5, early_stop_ckpt_path=\"./checkpoints/mlp_prior.pth\",verbose=False)\n",
    "w0_dict = dict()\n",
    "for param in model.named_parameters():\n",
    "    w0_dict[param[0]] = param[1].clone().detach() # detach but still on gpu\n",
    "model.w0_dict = w0_dict\n",
    "model._initialize_weights()\n",
    "print(\"done get prior weights\")\n",
    "\n",
    "info_dict, loss_acc_list = train_track_info(model, all_tr_idx, x_tr, y_tr, x_va, y_va, \n",
    "                                            num_epoch=int((55000/4 * 10) / (55000/64)),\n",
    "                                            batch_size=64, \n",
    "                                            lr=1e-3,\n",
    "                                            weight_decay=0,\n",
    "                                            track_info_per_iter=100,\n",
    "                                            verbose=False,)\n",
    "print(\"finish training and tracking\")\n",
    "# plot_info_acc(info_dict, loss_acc_list, 'bs512', __fig_dir__)\n",
    "\n",
    "# save info\n",
    "df_info = pd.DataFrame(info_dict)\n",
    "info_bs_list.append(df_info.mean(1).mean())\n",
    "train_acc_bs_list.append(max(loss_acc_list['tr_acc']))\n",
    "test_acc_bs_list.append(max(loss_acc_list['va_acc']))\n",
    "info_df_list.append(df_info)\n",
    "loss_acc_list_list.append(loss_acc_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "41bd3b43",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "##############################\n",
      "batch size: 256\n",
      "##############################\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:00<00:00, 15.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initialize model weights.\n",
      "done get prior weights\n",
      "finish training and tracking\n"
     ]
    }
   ],
   "source": [
    "print('###'*10)\n",
    "print('batch size: 256')\n",
    "print('###'*10)\n",
    "model = MLP(num_class, 'relu', layers=__layers__)\n",
    "if use_gpu:\n",
    "    model.cuda()\n",
    "model.use_gpu = use_gpu\n",
    "\n",
    "# get prior on the validation set\n",
    "train(model, np.arange(len(y_va)), x_va, y_va, x_va, y_va, num_epoch=10, batch_size=128, lr=1e-3, weight_decay=1e-5, early_stop_ckpt_path=\"./checkpoints/mlp_prior.pth\",verbose=False)\n",
    "w0_dict = dict()\n",
    "for param in model.named_parameters():\n",
    "    w0_dict[param[0]] = param[1].clone().detach() # detach but still on gpu\n",
    "model.w0_dict = w0_dict\n",
    "model._initialize_weights()\n",
    "print(\"done get prior weights\")\n",
    "\n",
    "info_dict, loss_acc_list = train_track_info(model, all_tr_idx, x_tr, y_tr, x_va, y_va, \n",
    "                                            num_epoch=int((55000/4 * 10) / (55000/256)), # = (55000/32 * 10) / (55000/1024)\n",
    "                                            batch_size=256,\n",
    "                                            lr=1e-3,\n",
    "                                            weight_decay=0,\n",
    "                                            track_info_per_iter=100,\n",
    "                                            verbose=False,)\n",
    "print(\"finish training and tracking\")\n",
    "# plot_info_acc(info_dict, loss_acc_list, 'bs1024', __fig_dir__)\n",
    "\n",
    "# save info\n",
    "df_info = pd.DataFrame(info_dict)\n",
    "info_bs_list.append(df_info.mean(1).mean())\n",
    "train_acc_bs_list.append(max(loss_acc_list['tr_acc']))\n",
    "test_acc_bs_list.append(max(loss_acc_list['va_acc']))\n",
    "info_df_list.append(df_info)\n",
    "loss_acc_list_list.append(loss_acc_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3afe0bdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "infomation in weights!\n",
      "[7.810381202943972e-05, 6.223292584763839e-05, 8.20052286144346e-05, 8.663371609145543e-05]\n"
     ]
    }
   ],
   "source": [
    "batch_size_list = [4, 16, 64, 256]\n",
    "info_list = []\n",
    "for i in range(4):\n",
    "    best_va_idx = np.argmax(loss_acc_list_list[i]['va_acc'])\n",
    "    best_iter = int(best_va_idx * 55000 / (batch_size_list[i]*100))\n",
    "    info = info_df_list[i].iloc[best_iter-10:best_iter+10].mean(1).mean(0)\n",
    "    info_list.append(info)\n",
    "\n",
    "print('infomation in weights!')\n",
    "print(info_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8904de7f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "last acc gap!\n",
      "[0.035345494747161865, 0.02954542636871338, 0.06040000915527344, 0.06300002336502075]\n"
     ]
    }
   ],
   "source": [
    "acc_gap = [x-y for x,y in zip(train_acc_bs_list, test_acc_bs_list)]\n",
    "print('last acc gap!')\n",
    "print(acc_gap)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec656c71",
   "metadata": {},
   "source": [
    "## plot the IIW against batch size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ba0ddd20",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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75ztMV0X2IiILK19+2jWn9u0v7Zinezl6t0b/vznwvNzL12YPBkeeKDuSxdERGQpS5bAUUdFQj54cDQAFWlJlJS3dAsXRvPQsWOjB+dp06Kzpp/+NOYPGxY9pv/4xxo3XESkkjTFpQsiIm3QRRdFo9BVVoGLL1azdWl5lJS3VLfeCrffHteJz5qVfX611aJH54z+/XWgJyJSiXr0gJEj045CRKRFe/vt6CYJ4LLLYOWV041HpD6UlLcUn34aCXfm1N8FF8R4xwAbbphtlr7VVhqMUURERERavUWLYkCM776L2333TTsikfpRUl6p3GOIsrFjY3r+eZg0KXoohhi6Z//949/n+99PN1YRERERkWZ23nkxquRaa8UIoCItlZLySrJ4MVx+Obz7blwf/t572XmdO8fwOZmkXD1YiIiINJtzzonRRQ84INvBvoik5+WXs1cAXXllaaN/ilQqJeWVZOxYOP747OMePWCvvWIM2113Ld4bsIiIiDSJs86CM8+M+//5DzzyiBJzkTQtWACHHx79HR9/POy2W9oRiTSMkvJK4Q4jRsT9qqpI0LfbLobnERERkdQsXpy9P2+eknKRtJ11FrzyCvTpE03YRVo69QhWKR54IDte7ezZMHeuEnIREZEKsMcecRVZxsSJcS5dRJrfc8/BX/4SfR9fcw0st1zaEYk0nGrKK4XGqxUREalIAwbAo4/CddfFtat33AEXXginnJJ2ZCJty7x50cv6kiVw6qmw/fZpRyTSOJSUVwqNVysiIlKxBgyIaccd4dBD4de/hvXWi65fRKR5/P73MS75hhvC2WenHY1I41HzdREREZESHXJInEN3j4FQXn457YhE2oZx42LYs/bto9VK7iUlIi2dknIRERGRMpxxRtSWf/tt1JR/+mnaEYm0bt98A0cdFff/7/90lae0PkrKRURERMpgFteWb7stfPQR7LNP9M8qIk3jN7+BqVNhiy3gD39IOxqRxqekXERERKRMnTvD7bdDz54wYUKMmbxkSdpRibQ+990Hl18OnTpFs/WOHdOOSKTxKSkXERERqYdVVoF77oEVVoBbb41mtSLSeL76Co45Ju6ffTZsvHG68Yg0FSXlIiIiIvX0gx/A6NHR+dRf/hLjJotI4zjppOizYdttowm7SGulpFxERESkAXbbDS66KO4PHQqPP55uPCKtwa23wv/+B127wrXXxokvkdZKSbmIiIhIAx1/PJx8MixcCAccAO++m3ZEIi3X55/Dz38e9887D9ZbL914RJqaknIRERGRRnDBBbDnnnEd7F57xa2IlMc9EvIZM+CHP4wTXiKtnZJyERERkUbQvj3ceCNsuim88w4MHgwLFqQdlUjLcv31cMcdsPzycNVV0E7ZirQB+pqLiIiINJLll4e77oJVV4XHHoMTToiaPxGp20cfwYknxv0LL4R11kk3HpHmUnJSbmYDzGyxmc0zszVLWH4tM5tvZovMrG/DwhQRERFpGdZZB+68M8Yyv/JKOP/8tCMSqXzuMfzZ11/D3nvDkUemHZFI8ymnpvxgwIB73P3juhZ294+AO5N9HFq/8ERERERanq22gv/+N+6PGBHNcUWksFGj4MEHoXt3uOwyMEs7IpHmU05Svj3gwH1lrHNvcrtjGeuIiIhISsysd9oxtBaDB8M550QN4GGHwaRJaUckUpkmT4ZTT437l1wCq62Wbjwiza2cpDwzGMEbZazzVq11RUREpLK9Z2Yfmtn/zGyYmW2QdkAt2e9+B0ccAXPnRpPcj+tsayjStixeDEcdBd9+CwcdBAcemHZEIs2vnKS8S3I7r4x1MssuV8Y6IiIikq41iMvWLgZeN7PPzWy0mZ1oZpumHFuLYhZNcXfcET75JBLzOXPSjkqkclx4ITz5ZNSO/+c/aUcjko5ykvLMaJtrlLFOZtmvy1hHRERE0nMz8AnRj0xmWhk4APgn8KKZfWlmY83sN2bW38w0mksRnTrBbbfBeuvBiy/CT38atYMibd2bb8Lvfx/3L78cVlop3XhE0lJOIfp2cvvjMtbZM7l9r4x1REREJCXufoi7r01cenYUcDUwmZpJejdgL+A84DlgppndZ2anmdm2ZtYhnegr10orwd13Q1UVjB0bzdpF2rKFC+Hww2H+fDj6aNhrr7QjEklPOUn5/URBfIyZbVbXwma2OXA00Tnc/fWKTkRERFLh7lPc/Vp3P8bdvwesSbZJ+2vJYpkkfXlgN+BPwJPA12b2iJmdaWY7pxB+RVp//agx79Ahhkm74oq0IxJJz1//ChMmxBCC//hH2tFIU5k0aRJmhpkxZsyYkuc//PDD1c8PGzas6D7GjBlTveyuu+5acjxDhgyp34tqAuUk5ZcCs4FOwENmNrjQgmZ2IPAgsAzwLaArRERERFowd//U3W9x91+6+6ZAD2Bf4ALgBWAx2SS9CzAQOAN4KJ2IK9POO8Oll8b944+HRx5JNx6RNLz4Ipx1Vty/+mpYYYV045HKM2jQoOr7Dz/8cNFlH3ooW8zUteyECROq79eVwDenkpNyd58JHJs8XAm42cw+MLMbzezvyXSjmX0I3EgU1g4MdfcZjR65iIiIpMbdZ7r7Xe7+W3ffmmjSnqktn0LN5u6S45hj4Le/hUWLYti0t96qex2R1mL+/Gi2vmgRnHgi7LJL2hFJpcok5lOmTGHWrFkFl7vllltqPC6WmOcm8LmJf9rK6pjF3ccAhxK13wasBRwInJxMBxLN2wyYA/zU3W9qzIBFRESkspjZ94FDgMOBnwG9iBPzUsBf/wr77QezZsW1tDNUfSFtxMiR8Npr8L3vxe9ApJDcmuxCiXa+hH306NEFt5nZTlVVFb179254kI2k7N5S3f1moA9wDvAyUehmzoR78tyfgPXc/cbGC1VEREQqgZltama/NLNbzOxT4E1gFPBTYF3imOBL4A7g1NQCrWDt2sH110PfvjB5MhxwQNQgirRmzzwD550X3/9rroGuXdOOSCpZbk32Cy+8kHeZzHXoVVVVDB06FCicwM+aNas6ga+kWnKAevWO6u7Tgf8D/s/M2hPN2QG+cvdFjRWciIiIpCsp5/sBOybTdkBVZnbOou8Tnbw9BTzp7m8jRS27LNx5J2y1VYzTPHRoJCqmBv/SCn37LRxxBCxZAiNGwLbbph2RVLq+fftW3y+UaGeaox944IEMGTKEyy67jClTpjBlypSlasJzt1FJ15NDPWrKa3P3xe7+RTIpIRcREWnBzKyTme1oZv9nZg8CM4HxwLnEMGjdiJZxrwD/JnpkX9Pd+7j7ke5+hRLy0q25Jtx1V9QYXncd/OUvaUck0jROOw3eew823hj++Me0o5GWIlOjPWnSpLzzM4n2rrvuWmfncJV6PTk0QlLe1MxsNTO70Mwmm9l3Zva5md1lZj9s4HZ/ZGZ3Jtubb2YfJx3VbdlYsYuIiLRAXwOPAX8EBgHLAQuIGvC/AD8Gurv7Fu5+UtIj+6epRdsK9O0LN9wQNeR/+APU6rNIpMV79FG46KIYDvC662CZZdKOSFqK3Brt2ol5buKdSbIzt/muK8/0vF5p15NDGUm5ma1qZlcl05olLL9msuyVZta9PsGZ2abEWKgnAb2B+USv7nsRw7L9rp7b/Q9wL7B3sr1vgdWIs/3jzezn9dmuiIhIK5A5XF4M3ADsAKzo7ju5+x/c/X53n51eeK3TvvvGtbYQTXyfey7deEQay+zZcNRRcf+MM2CLLdKNp9KNHx8tZsaPTzuSyjB4cHYU7tq135ma7759+1JVVQVkk/h8NeWZpP7AAw9silAbpJya8p8BRwJbuPvHdS2cLLN5ss5h5QZmZl2AO4nr1V8ENnb3FYlmcxcQ17GdY2a7lbndk4ATkod/Js72dwdWAS4G2gP/MbPty41ZRESklTCiPDyEKItHm9mpZraNmdWrPxqp229+A8ceC999F0n6tGlpRyTScL/6FXzwAfTvD7+rV3Vausyad9p2W/j97+O2OfdbqXr37l2dcOc2P4dsJ2+5TdELJfGVfD05lJeU70pcQzamjHVuIQr2H5UTVGIY0YPrHGBvd38dwN1nu/upRI+uRjSlK0lyIHF68vBGd/8/d/862e6X7v4LosleO+LaORERkbZmMPAvsiOsdCNalp0LPA18bWaPmtkfzWyQmS2bXqitixlcfHGM2/z557D33lHLKNJS3X03XHVVNFe/9lro2DHtiKQlyiTduYn1rFmzmDJlCgAHHXRQ9fOFkvjcpu+Vdj05lJeUb5LcPl/GOhOS203LWCcjU7t+Q4Ga+b8lt33NbP0St9mfaK4O8M8Cy/w9ud3WzPqUuF0REZFWwd1vc/dT3L0v0B3Yk0jInwUWAl2AgcQoLA8AM83seTO7wMz2M7MeBTYtJejYEcaMgfXXh1dfhUMOgUXqRldaoC+/hOOOi/t//jP84AfpxlNf7s03PfMMdOkC7dvH7TPPNN++K1luzXYmEb8lp/ON3F7aIds8PVOTDtkEPTdpryTlJOWZYc++KGOd6cltWQW0mS1PDL8CUeDn8yzRGQ1AqZ2+rZtzv1DPsG/l3K+8tg0iIiLNJGmddp+7n+bumaHQdgFGEi3L5hHDq/YHTgFuBT43szfMbJSZ/dTMeqYRe0vWrVvUMHbvDvfeG83aRVqaX/4SPvsMdtgBTjkl7WhahgED4JFH4Oyz43bAgLQjqgz5elXPJNn5ar2HDBkCRAKfGZc8s14l1pJDeUn5vOR2+TLWySy7sIx1ADYkO/bp6/kWcPclZBPrUs+95Z4Hal9gmdxr5TYqcbsiIiKtnrt/5+7j3P0sdx9EJOkDgBHAfcTJcgM2AI4FrgXeSyncFm299eD226Pm/F//imbtIi3FLbfATTfBssvC1VdHza+UZsCAGD5OCXlWvibpmSQ7k4Dnyk28b7nlluradajM68mhvKQ804S8nCHDtkpuyx0qZfWc+58UWS4zb/Uiy+TK7TKlUCKf+3yp2xUREWlz3H2Ruz/n7n9z972AVYGhwBQiOc9MUg877ghXXBH3TzoJHijUdlCkgnz2GRx/fNw//3zoo4tBpRHkXlc+adKk6hrwQjXfuUOj5Rs6rdKUk5Q/QRSsvzSzOkcXNLPOwC+I2uknyowrt9OYeQWXgrnJ7XIlbncSMCO5/9vaM83MgOE5T5XTKkBERKRNMbOOZra9mf3ezO4nythRQC9qtk6Tejr88OiJefFiOPBAeD1v+0GRyuAe15F/9RXsthsMG5Z2RNJaZDpzmzVrFqNGjQKKjzeeOzRapV9PDuUl5Vcmtz2JoVEKJqzJvFuIQhngqnpF18jcfSHw1+ThPsn1br2Tg4oNgJuArck2t19SaFtmNtTMJpjZhOnTpxdaTEREpNUws65Jj+tnmdk4orn648DZRD8sy1OzdvxV4D9pxNqanH02DB4cPbHvtRd8UU7vPiLN6Nproz+EFVeEK6+s7KG2pGXJreG+7LLLgOLjjecOjZZv6LRKU/JYo+4+wcyuBY4gemJ928yuAp4k2zx9dWBH4CiiCZsTQ489U2Zc3+bc7wJ8U2C5rsntnDK2/XfimvVjiCZ2Q2vNvwLYjGimP6vQRtz9MuAygP79+6s2QEREWh0zWxHYgSjbdwS2oOaxQ+4h92LgRaJ13OPAk+4+q3kibd3atYtkZ9o0eOEF2G8/ePRR6Nw57chEsj74AE4+Oe5fdBGstVa68UjrkqkVL/X68EyteKaZO+S//rxSlFNTDjF2+L1EIbwacFry+MVkuhf4XTLPiJ7Tj6lHXLnXka9RZLnMvJKvWfdwLPBjYsz1t4GpwEPAwe5+HLBKsvi7pW5XRESkNTCzwWb2LzN7CfgSGAv8hjhZ3ZFsTfhCYtzyvwB7AFXuvpW7n+rudykhb1xdu8Kdd8Laa8P48XD00ZU/jJG0HUuWxHdy9uw4afTTn6YdkbRGtWu666r5rl2T3r9//0aPqbGUlZS7+4KkI5dfAh9QsxOX3OmDZJk93X1+PeJ6i+y1aHl7QDezdkBmfPI3yt1BMsTLEHffwN17uftu7n6zma1Edui08eVuV0REpIW7hegTZhPiOCFTts8DHiWGQ9uFSMJ3cPc/uPuD7v5tge1JI1lttWgavNxycOON8Mc/ph2RSLjkkhjCq0cPuPRSNVuXppFbM963b986rw8vd/k0mdfzNGvSKdqmQF9g5eTpGcBE4BWv74az23+eOCt/qbsfn2f+ACDTLH4Ddy807ni5+/0F8G9iPPa1kuvQi+rfv79PmDChMXYvIiJSb2Y20d0bVBVgZpn+VGYTNeFPJNML7r6ogSE2u9ZYRt9zD+yzT9RO/u9/cOihaUckbdm778Lmm8PcuTBmDPzkJ2lHJFKZipXRJV9TXluSdL+cTE3hBiIpP8zMznL32k3UT01uJzZiQr4WcEby8IJSEnIREZFW5tdEEv6Suxfs8FTSs+ee8Pe/wymnwFFHQc+esO22aUclbdHixXDkkZGQH3aYEnKR+ir3mvLmNIoYV3x54G4z+wFEz+5mdh5wQLLc72uvaGaeTCPzzNvEzM4ws43MrGPyXFczO5ioeV8luf17U7woERGRSubu/3T3SUrIK9tJJ8EJJ8CCBXEN7/vvpx2RtEV//zs88wyssUZ07iYi9VOvmvKk6frmRC/lPYge0otePeLuZ5WzD3efZ2b7Ao8QTeRfN7PZxJjk7Yhrzn/v7g+WGf5KwB+TaYmZfQ2sSPYExaPA/i2xiZ6IiIi0DWZw4YUweTI88EAMlfbMMzEUlUhzeO01+L//i/tXXAHduqUbj0hLVnZSbmZHAGeS7QytVGUl5QDu/rKZbUz08r4XsCbRE+zzwD/c/ZFytwm8SfQUuzPQG6girh+fCPzX3W+uxzZFREREmlWHDnDzzdF0/Y034MAD43rzDvW+OFGkNAsXwuGHR0uN446DH/0o7YhEWray/rbN7M/EkGel9KnoJS5XfCPunwEnJ1Op6xTcr7t/Tp4m7yIiIgJm9mgjb9Ld/YeNvE1JrLhi9Mi+9dbw4IPRrP0//1Hv19K0/vxnePHF6M/gggvSjkak5Ss5KTezrYkaayfG9P4t0eR7UvJcB6A70B84HtgHeAoYkiTCIiIiUvkGkh2WtKGsEbclBfTqBWPHws47x9BU668PJ5dclSFSnokT4U9/ivvXXAPLL59qOCKtQjkdvWWGJZtGjD/+ClDdO7mHL939AXffjxjjdHvgfjPr1FgBi4iISJOzRpqkmQwYAFdfHfd//etoxi7S2L77LpqtL14cvf/vtFPaEYm0DuUk5dsSZ7v/VUonaO5+CXArMZb5CfULT0RERJqTu7dr5Kl92q+prTjkEBg5MsYvP/hgeOWVtCOS1ub006P/gvXXh3POSTsakdajnKR89eT29ZznqodLyQwvVst/iTPlB5UfmoiIiIiU44wz4NBDYc6c6JH900/Tjkhai6eeiuvH27WDa6+FLl3Sjkik9SgnKc8k3V/kPDcn5/7Kedb5KLldr5ygRERERKR8ZnDlldEj+4cfwr77wty5aUclLd2cOXDEEeAOv/tddCwoIo2nnKR8enK7Qs5znwOLk/sb5lknU7uuLiBEREREmkHnznD77dEz9gsvRDK1ZEmdq4kUNGIETJkCm24KZ56ZdjQirU85Q6K9DqwBbAA8CeDuC8zsdWATool67XHDf5bcftLAOEVERKQZmNkZjb1Ndz+rsbcpxa2ySnT2NmAAjBkT1wL/+c9pRyUt0UMPwcUXQ8eOcN110EndN4s0unKS8ieB3YCdgctznr+Z6MztaDP7FLgFWBY4EjiQ6BzuvsYIVkRERJrcSBp/GDMl5Sn4wQ9g9Gj48Y+jU67vfz9qzUVKNWsWHH103B85EjbbLM1oRFqvcpqv35Hc7mVmuU3YLwSmJtv6P+AVYDwwLJk/E/hLg6IUERGR5tRYQ6JpWLSU7bYbXHRR3D/uOHjiiXTjkZbllFPgo49gq61g+PC0oxFpvUquKXf3181s52SdDjnPz02evx7YrtZqrwE/c/ePEBERkZZg57QDkMZ1/PHw9ttw4YWw//7w7LPwve+lHZVUurFjo5f1zp3jtkM57WtFpCxl/bzc/fECz08DdjCz9YGNku2+6+4vNjxEERERaS6Fynpp2S64AN57L64z32svGD8eundPOyqpVDNmwNChcf+vf4UNNkg3HpHWrpzm63Vy97fd/TZ3v0UJuYiIiEhlaN8ebrwxes9+5x0YPBgWLEg7KqlE7tG64osvYKed4MQT045IpPVr1KRcRERERCrT8svDXXfBqqvCY4/BCSdEAiaS66abosf+5ZaDq6+GdsoWRJqcfmYiIiIibcQ668Cdd8Z1wldeCeefn3ZEUkk++QR+8Yu4//e/Q69e6cYj0lYoKRcRERFpQ7baCv7737g/YgTccUeq4UiFcI8e+mfOhB/9CI49Nu2IRNoOJeUiIiIibczgwfDnP0cidthhMGlS2hFJ2q66Cu69F7p1gyuuANOAhiLNRkm5iIiISBt02mlwxBEwdy7svTd8/HHaEUlapk6NMckB/v1vWGONNKMRaXuUlIuIiIi0QWYwahTssENcS7z33jBnTtpRSXNbsgSOOio++5/8BA45JO2IRNoeJeUiIiIibdQyy8Btt0GfPvDii/DTn8LixWlHJc3p3/+GceNglVXgkkvUbF0kDUrKRURERNqwHj3gnnugqgrGjoXf/S7tiKS5vP12dPYH0Wpi5ZXTjUekrVJSLiIiIhXBzLyMaae0421N1l8fbr0VOnSIYdKuuCLtiKSpLVoERx4J330Hhx8O++2XdkQibZeSchEREakUn9cxzUuWWwC8lkaArdkuu0TzZYDjj4dHHkk3Hmlaf/sbPPssrLkmXHhh2tGItG1KykVERKQiuPtqxSbgnWTRu939yzRjba2OPRZOPTVqUQcPhrfeSjsiaQqvvAJnnhn3r7oqLl0QkfQoKRdpJlOmTMHMMDOmTJmSdjgiIi2KmW0ObJY8vDbFUFq9v/4V9t0XZs2CvfaCGTPSjkga04IF0Vx94UL4+c9ht93SjkhElJRLmzFkyBDMjCFDhqQdioiIlO+I5PYL4N40A2nt2reH//0PttgCJk+GAw6A+fPTjkoay9lnw8svQ+/e0YRdRNKnpFykGVVVVVGlNmIiImUxsw7AocnDG9x9UZrxtAXLLgt33QVrrAFPPglDh4J72lFJQz3/PPzlLzHs2TXXwHLLpR2RiICScpFm07t3b2bOnMnMmTPp3bt32uGIiLQkPwJWSe6r6XozWXPNSMy7doXrrotkTlquefPgiCNiHPpf/xp22CHtiEQkQ0m5SB1mzZqVdggiIm3dkcnty+7+UopxtDl9+8INN0TN6h/+AKNHpx2R1Ncf/hAd9224IfzpT2lHIyK5lJRLqzds2DDMjDFjxgAwZsyY6g7XMmbNmrXUc8OGDaNbt2706tVrqW1edtllDBkyhD59+mBmdOvWjX79+jFixIiiSfyYMWOq48iV2Xdm3fPOO2+pbedbrxz1jTnj4YcfZtddd6Vbt26YGX369GHYsGFMmjSpSdYTEQEws+7AXsnDkmrJzWyomU0wswnTp09vuuDaiH33hfPOi/uHHx5NoKVlefxx+Oc/o7+A666Dzp3TjkhEanB3TQ2c+vXr51K5hg8f7lVVVQ5UT1VVVV5VVVW9zMyZM6vnzZw50/v27Vtj2dzlevfuXWNb+abJkycvFcfkyZMLzi+079rT0KFDy379DYk59z0stu65557bqOuJSP0AE7wCysXGnIBfJP8ZC4FVyl1fZXTjWLLE/dhj3cF91VXdp01LOyIp1ezZ7r16xWd3xhlpRyPSdhUro1VTLq3eueeey8yZMxk8eDAAgwcPrr62O58RI0YwadIkhg8fzsSJE3n//fer5x133HHVw5kNHTqUhx56iMmTJzNx4kSGDx9evVx9e3gfMmRIjX3PnDmThx56qPoa9Msuu6zsGuaGxjxs2DDOS6pIBg8ezOjRo5k4cSKjR4+ujmvEiBE8/PDDjbKeiEgtmV7X73P3L1KNpA0zg4svhl12gc8/j6HSvvkm7aikFL/9Lbz/fvSm/4c/pB2NiORVKFvX1HbPwi9ZssTHfzjelyxZknYojWrw4MEO+ODBg5eal1tTDvioUaPybiMzf/jw4Xnnjxo1qnqZ2kqpKQf8oYceKrpuodgKaayYC62fqYUfNGhQg9cTkYahldWUAxvm/D/+pD7baG1ldNq++sp9/fXdwX3PPd0XLUo7Iinmvvvis+rUyf2VV9KORqRtK1ZGd2j6tF8ayv5odS/UCviZlTHWyqBBgxg6dOhSz8+aNav6+dNOOy3vuv3796+xfLnDnw0aNIhBgwYt9Xzv3r3p3bs3U6ZMYfLkySVvr6ExjxgxAoih3M4999y86w8bNmypGu/6riciUsuRye1XwF0pxiGJbt3g7rth663hnnvgN7+Ja5Wl8sycCcccE/fPOgs22STdeESkMCXlIrUUasZdVVXFqFGjiq578803N2jfu+66a8F59RnfvKExZ5rK5ztJkTF8+PDqSwMaup6ISIaZtQd+mjy80d0XpBmPZK23Htx+OwwaBBdeCOuvD8cfn3ZUUttJJ8Enn8CAAXDqqWlHIyLFKClvAZqzBvn+9+5nzxv2ZIkvoZ21455D72GP9fZotv1XglLGEJ81axYTJkxg0qRJTJ48mSlTpjBhwoQGD5/Wt2/fBq1fTH1izlyL3qdPn6Lbrv2e1Xc9EZEcg4A1kvsam7zC7LgjXHFFjHt94onQuzfsvnvaUUnGbbfB9ddDly5w7bXR67qIVC4l5VJD/zX6c/qOp9d4LFlTpkxh2LBheZtcV1VVMWjQoIprjl3fmHOT9XKS5/quJyJSS6aDtzfc/YVUI5G8Dj8c3n4bzjkHDjwQnnkGNtoo7ajkiy/g5z+P++edB9/7XrrxiEjdlJRLDT269mDkwJFph5Gq7t27531+ypQpNWp+hw4dyq677krv3r2ra7gnTZpEv379miXOUjQk5tzm8uW0AKjveiIiGWa2ArBf8lC15BXs7LPhnXdgzJjokf2552CVVdKOqu1yj4R8+vToKf+EE9KOSERKoaRcpESZDsuqqqqYOHFii6gFbmjMmc7lXnjhhYLXf8+aNYtbbrkFgAMPPJCqqqp6rycikjgQ6AIsAa5PORYpol27aB49bRq88ALstx88+ih07px2ZG3T//4X1/svvzxcdVV8PiJS+fRTFSnRhAkTgOghvVBym7mWulI0NObMOmPGjCm4zC233MKwYcMYNmxYdWJd3/VERADc/Qp3N3dv7+6fpB2PFNe1K9x5J6y9NowfD0cfHTW20rw++gh++cu4f+GFsO666cYjIqVTUi5Sokyz9kJJ7KxZs6qHAqsUDY05U9M+ZcoUzjvvvKLL5HZSV9/1RESkZVpttRgqbbnl4MYb4Y9/TDuitsUdjj0Wvv46LiM48si0IxKRcigplzZn0qRJTJkypezrnTPDlU2aNIkRI0ZUJ7qTJk3ivPPOo1evXjWS30zT7DQ1NOa+fftWNz8fMWIEQ4YM4eGHH2bKlCmMGTOGfv36Va9/+eWXN3g9ERFpuTbdFG66KZpM//GPcMMNaUfUdlx2GTzwAHTvHvfN0o5IRMri7poaOPXr18+l8p177rkO1JgyZs6cWf3cxIkTC26jb9++S20jM1VVVfnEiRNrPNe7d+/qdSdPnlz9/OTJk2tsN/P8Qw89VOe+hw8fXtbrbkjMGYMHDy64DcBHjRqVd9/1XU9E6geY4BVQLlbSpDK6+f3zn+7g3qmT+9NPpx1N6zd5svuyy8Z7ftNNaUcjIoUUK6NVUy5txvDhwxk6dOhS1z2XY+LEiZx77rn07du3ejt9+/bl3HPPZebMmfTt25fRo0c3aB+NrTFiHj16NKNHj2bQoEE1tjF06FAmT57M0KFD8+67vuuJiEjLddJJcPzxsGBBdPz2/vtpR9R6LVkSTdW//TaGpTvooLQjEpH6sEjapSH69+/vmQ61RERE0mJmE929f9pxVBKV0elYtAj23BMefBB+8IMYw3zFFdOOqvX5xz/g17+GVVeF11+HlVZKOyIRKaRYGa2achERERFpVB06wC23REL+xhtRi7toUdpRtS5vvgmnnRb3L79cCblIS6akXEREREQa3YorRo/sK68cNeYnnaSh0hrLokVwxBEwfz4cdRTsvXfaEYlIQygpFxEREZEm0asX3HEHLLMMXHIJ/OtfaUfUOvz1r/DCCzE2/D/+kXY0ItJQSspFREREpMlsuy1cdVXc//Wv4Z570o2npXvppew48FdfrWv1RVoDJeUiIiIi0qQOPRTOPDN6Cz/4YHjllbQjapnmz4fDD4/m67/8Jfzwh2lHJCKNQUm5iIiIiDS5M8+EQw6BOXNgr73g00/Tjqjl+eMf4dVXYb31ogm7iLQOSspFREREpMmZRTP2AQPgww9h331h7ty0o2o5xo+Hc8+Fdu3g2mth2WXTjkhEGouSchERERFpFp07R8dvPXtGR2VHHBFN2qW4uXOz79Wpp8Z1+iLSeigpFxEREZFms8oqMVTaCivAmDFw+ulpR1T5TjsN3n0XNtoIzjor7WhEpLEpKRcRERGRZrXRRjB6NLRvD+ecE82xJb/HHouh5Dp0gOuui+HlRKR1UVIuIiIiIs1ut93goovi/nHHwRNPpBtPJZo9G446Ku6ffjr07ZtuPCLSNJSUi4iIiEgqjj8eTj4ZFi6E/feH995LO6LK8utfw7Rp0K9fNGEXkdZJSbmIiIiIpOaCC2DPPeGrr+J25sy0I6oM99wDV14ZzdWvuw46dkw7IhFpKkrKRURERCQ17dvDjTfCppvCO+/A4MFRc96WffklHHts3P/zn+EHP0g3HhFpWkrKRURERCRVyy8Pd90Fq64Kjz4KJ5wA7mlHlZ4TT4TPPoPtt4dTTkk7GhFpakrKRURERCR166wDd94ZY5lfcUU0a2+LRo+OlgNdu8I110RLAhFp3ZSUi4iIiEhF2Gor+O9/4/7w4XDHHamG0+w++yw6vwM4/3zo0yfdeESkeSgpFxEREZGKMXhwXEftDocdBpMmpR1R83CHYcPievJdd4Wf/zztiESkuSgpFxEREZGKctppcMQRMHcu7L03fPxx2hE1veuui+b7K64Yva6bpR2RiDQXJeUiIiIiUlHMYNQo2GEH+OSTSMy//TbtqJrOhx/CSSfF/X/9C9ZeO914RKR5KSmXNmPIkCGYGUOGDEk7lBoqNS4REZE0LbMM3HZbXFf94ovw05/CkiVpR9X43OHoo2H2bNh3X/jZz9KOSESam5JyEREREalIPXrAPfdAVVV0+va736UdUeO75BJ4+GFYaaVoHaBm6yJtj5JyEREREalY668Pt94KHTrA3/4Ww6W1Fu+9B7/9bdy/9NIYp11E2h4l5SIiIiJS0XbZJWqUIYYMe+SRdONpDIsXw5FHRmd2hx4avc6LSNukpFxavWHDhmFmjBkzBoAxY8ZgZliB9mFTpkxh2LBh9OnTBzOjW7du9OvXj8suu6zOfWXW7devX411R4wY0eC4irnssssYMmTIUjGPGDGCWbNm1bn+ww8/zK677kq3bt0wM/r06cOwYcOYVMc4NPVdT0REpFzHHgunngqLFkUC+9ZbaUfUMP/4Bzz9NKy+Olx0UdrRiEiq3F1TA6d+/fq5VK7hw4d7VVWVA9VTVVWVV1VVLbXs6NGjayxXe+rdu7dPnjw5735GjRpVdN2qqiqfOXNmveIqZObMmd67d++i+wUKxpyJo9i65557bqOuJyJNB5jgFVAuVtKkMrp1WbTIfd993cG9Tx/36dPTjqh+XnvNvVOneB333JN2NCLSHIqV0akXlq1hanUF/pIl7uPHx20rMnjwYAd88ODBeefnJuR9+/b10aNH+8SJE/2hhx7yoUOH1kica5s4ceJS606ePNknTpxYI3kdNGhQ2XGV8poAHzp0qD/00EN599u3b9+86+e+rsGDB1e/5tGjR9dI9h966KFGWU9EmpaS8jZQRovPmeO+xRbu4L7DDu7ffZd2ROVZsMC9b9+I/9hj045GRJqLkvLWUODHiBn5p1GjssuNGlV82VyZEqHQNHZsLDdhQvHlJkzIbvO44wovVzsxLBRXE6kr+c0kk4XmP/TQQ9XJ5vDhw2vMyyTAhWq5cxPkcuMqplA8Gbm197VNnjy5zvUz70nuyYT6riciTU9JeUpltDS7jz5yX2ONOIQ4/PCWVY8wcmTE3bOn++zZaUcjIs2lWBmta8qlsFNPjZS5DbjsssuYMmUKAJdffnneZQYNGsTQoUOrl8+VWbd379551z3ttNMYPXo0o0ePbqyQmTVrFkOHDmXo0KGcdtppeZfp379/jeVzZa5zr6qq4txzz827/rBhw4C4dryh64mIiDSWNdeEu+6Crl3huuvgL39JO6LSTJwIf/pT3L/6alh++XTjEZHKoKS8pShWV50kikDcL7ZsrokTl55/333QLvlaTJ4MDzwA/foV32a/ftltXnZZ4eUmTiz8mlI2MYlt0KBBVFVVFVxu1113BSLBzU1yt9xySwAmTZqUt3O1qqoqBg8ezOBG7Fq1qqqKUaNGMWrUqIIx33zzzQXXz3TGNjT3+1PL8OHDmTx5MpMnT27weiIiIo2pb1/43/9iXO8//AEa8bx3k/juOzjiiOio7uSTYeDAtCMSkUrRIe0ApML07w+nn17zcRuQqel++OGH6dOnT8Hlvvrqqxrr9O3bF4gkdNSoUUyZMoXzzjuP8847j759+9K/f3923XXXRk3G85k1axYTJkxg0qRJTJ48mSlTpjBhwoSiPa9nXnOx1wtL1/7Xdz0REZHGtt9+cO65MHw4HH44rLsubLVV2lHld8YZ8Prr8P3vwznnpB2NiFQSJeVSU48eMHJk2lE0u0yiWft+OSZPnsyIESO47LLLmDVrFpMmTWLSpEnVTd0HDx7Mueee26jJamYItnzNxKuqqhg0aFDeebnJejnx1Hc9ERGRpnLqqfD223DllbDPPvD887DOOmlHVdPTT8P550djxGuvjWb3IiIZar4uQjbBHDp0aMmdB2VqyXOde+65zJw5k8mTJzNq1CgGDx5c3bR8zJgx9OvXr6Rxw0sxZcoU+vTpU510Dx06lNGjRzNx4kTcnZkzZxa85ju3uXs58dR3PRERkaZiBhdfDDvvDJ9/DnvtBd98k3ZUWd9+G83W3eF3v4Nttkk7IhGpNErKRcgm5fWtJc+3vUySPHPmzOoO3mbNmlXdUVpDZRLuqqqqGicB8p0sKBQjwAsvvFBwmVmzZnHZZZdV1/43ZD0REZGm0qkT3HprNA1/9VU45BBYvDjtqMKIEdFNz6abRhN2EZHalJSLAP2SzuoefvjhoknksGHDMLPqDt9y1+/Xr99SvbJnDB48mEGDBgGNl/hPmDABiM7pCjUlL7avzDpjxowpuMwtt9zCsGHDGDZsWHUteX3XExERaUrdusE990D37nH7m9+kHRE8/DD85z/QsWP0Er/MMmlHJCKVSEm5CNH0O5M8/vCHP8y7zMMPP1yddA8ZMmSp+ZMmTWLUqFEF95FJokutya5L9+7dgcKJd1218pma9kzndMWWyY25vuuJiIg0tfXWg9tvjyT4wgvhkkvSi+Xrr+Hoo+P+mWfCZpulF4uIVDYl5dLmTJo0iSlTpixVI54Zn3zSpEn06dOHyy67rLqzthEjRlTXjvft23ep4cAOOuig6nX79evHmDFjmDJlClOmTGHMmDH06dOnen+ZZUuNq5BMPJn4Msn5pEmTOO+88+jVq1eNhP2WW26psX7fvn2re4UfMWIEQ4YM4eGHH66OuV+/fnnHbq/veiIiIs1hxx0hU/yceGKM7pqGU06BDz+M3uAb6co1EWmtSu3USlPhqV+/fi6V79xzz3WgxlTbqFGjllomd+rdu7fPnDkz7/YHDRpUdF3AR48eXa+4Cunbt2/BfVVVVfnEiROXir+2wYMHF4151KhRefdd3/VEpOkAE7wCysVKmlRGt12//707uK+wgvtrrzXvvseOjX137uz+5pvNu28RqUzFymjVlEubMXz48BrN1PNdhz106FAmT55co9f0zNBio0aNYvLkyQWvkX7ooYcYPXp0jWu8q6qq6Nu3L8OHD2fmzJl5xysvJa5CJk6cyLnnnkvfvn2r1+/bt291L/B9+/Zl9OjRRbc9evTo6rhzt5F5L2q3CmjoeiIiIs3h7LNh8GCYPTt6ZP/ii+bZ74wZkCkC//IX2GCD5tmviLRcFkm7NET//v09c72wiIhIWsxsorv3TzuOSqIyum2bOxcGDoQXXoABA+DRR6Fz56bd50EHwS23wE47xf7aqQpMRCheRutvQkRERERapa5d4c47Ye21Yfz46HitKeujbropEvJll4Wrr1ZCLiKl0V+FiIiIiLRaq60Gd98Nyy0HN94IZ53VNPv59FM44YS4//e/Q69eTbMfEWl9lJSLiIiISKu26aZRi92uHYwcGcl5Y3KH446DmTNhjz3ivohIqZSUi4iIiEirt+eeUYMNcNRR8Mwzjbftq6+Ge+6Bqiq44gowa7xti0jrp6RcRERERNqEk06C44+H+fNhv/3g/fcbvs1p02JMcoB//xvWXLPh2xSRtkVJuYiIiIi0CWbwr3/BbrvB9OkxVNrXX9d/e0uWRK37N9/AAQfAoYc2Xqwi0nYoKRcRERGRNqNDh+gh/Qc/gDfegAMPhEWL6ret//wHHnsMVl4ZLr1UzdZFpH6UlIuIiIhIm7LiitEj+8orw4MPwsknlz9U2jvvwIgRcf+yy2JbIiL1oaRcRERERNqcXr3gjjtgmWXg4ovhootKX3fxYjjiCJg3D372s7g+XUSkvpSUi4iIiEibtO22cNVVcf9Xv4oe1Evxt7/Bs89Gp24XXth08YlI26CkXERERETarEMPhTPPjE7bDj4YXnml+PKvvgpnnBH3r7wSunVr+hhFpHVTUi4iIiIibdqZZ8Ihh8CcOdEj+6ef5l9uwQI4/HBYuBB+/nPYfffmjVNEWicl5SIiIiLSpplFM/YBA+DDD2HffWHu3KWX+9Of4KWX4nr0v/2t2cMUkVZKSbmIiIiItHmdO0fHbz17wgsvREduS5Zk57/wApxzTiTw11wDyy2XUqAi0uooKRcRERERAVZZJYZKW2EFGDMGTj89np83L5qtL14cHcLtuGO6cYpI69Ih7QBERERERCrFRhvBLbfAnntGzfj3vx+dv731Fmy4YTRhFxFpTErKRURERERy7L47/Otf8ItfwDHHRA15u3Zw7bXQpUva0YlIa6Pm6yIiIiIitZxwAgwZEgk5RFK+aFG6MYlI66SkXEREREQkj802i47dANxh3LhUwxGRVkpJuYiIiIhIHrvsEr2yt28PnTrBwIFpRyQirZGuKRcRERERyWPAAHjkkaghHzgwHouINLaKT8rNbDXgNGAvYE3ga+B54J/u/kgDtrs/cAzQD+gBfAdMBu4H/uHunzcwdBERERFp4QYMUDIuIk2ropuvm9mmwGvASUBvYD6RQO8FPGRmv6vHNtuZ2fXAbcCewGrAPKALsBkwAnjDzLZslBchIiIiIiIiUkDFJuVm1gW4E1gJeBHY2N1XBLoBFwAGnGNmu5W56eOAw5L7/wRWdfcVgM7AHsAHQHfgRjOr2PdHREREREREWr5KTjqHAesCc4C93f11AHef7e6nAncQiflfytzuocnto+7+K3f/ItnuInd/ADgimd8H2LRhL0FERERERESksEpOyjO12Te4+8d55v8tue1rZuuXsd1Vk9sXC8yfmHN/2TK2KyIiIiIiIlKWikzKzWx5ogM2gAcKLPYs0ekbwA/L2PzU5HaLAvMz+50PvFHGdkVERERERETKUpFJObAh0TQd4PV8C7j7EuDt5OEPytj25cntLmb2DzNbBcDMOpjZ7sC1yfyz3H1meWGLiIiIiIiIlK5Sk/LVc+5/UmS5zLzViyxTg7vfCvwBWAycAnxuZrOJIdHuB74BjnL3c8oJWERERERERKRclTpOee613POKLDc3uV2uzO3/hehl/dJkX8vX2ncPM2uX1MbnZWZDgaHJwzlm9nahZcvUA5jRSNuSlkWffdumz7/taszPft1G2k6rMXHixBlmNq2RNqffadulz77t0mfftjVLGV2pSXmTSa5Xv5EYo/xu4GzgTWIYtD2Ac4hO5PoBhxTajrtfBlzWBPFNcPf+jb1dqXz67Ns2ff5tlz77puXuKzfWtvRZtV367NsuffZtW3N9/pXafP3bnPtdiizXNbmdU8a2/04k5A+7+97u/ry7f+Pu09x9FHAA4MDBZvajsqIWERERERERKUOlJuW515GvUWS5zLxPS9moma0AHJU8/Ge+Zdz9cWBS8nDfUrYrIiIiIiIiUh+VmpS/RdRWA2yUbwEzawdkxicvdeiy7wHtk/vvF1luSnLbs8TtNqZGbxIvLYY++7ZNn3/bpc++5dBn1Xbps2+79Nm3bc3y+Zu7171UCszseWBL4FJ3Pz7P/AHAM8nDDdy9zo7WzGwLsrXgP3L3+wss9xywFTDG3YfUJ34RERERERGRulRqTTnADcntYWaWb8izU5PbiaUk5Im3gfnJ/ePyLWBmfYG+ycPnStyuiIiIiIiISNkqOSkfBUwjhiu728x+ANF7upmdR3TIBvD72iuamSfTyNzn3X0ucG3y8AAzu9zM1k7W6Wxm+wJ3EL3SzwauaewXJSIiIiIiIpJRsUm5u88jOlr7kqi5ft3MvgZmAb8lrjk/zd0fLHPTvwGeSu4fC3xgZnOIHt/vANYGvgGGuHuzj0loZsuZ2Yc5JxaObO4YpHEkJ5D2MbOzzew+M5uR87luUOI2upjZKWb2lJlNN7PvzGxasr3fNPVrkIYzs/XN7CIze9vMvjWzr83sTTO7ysx2KnEbd+R8d65p4pClDma2TvK7vMvMPjCz+Wb2jZm9bGZ/LdC6CzPrmfM5FpvqHHrFzAab2Z1m9nGy/8/M7Gkz+5OZNdoQYJKl8rn1UPksGSqjW5eWXD5X9Djl7v6ymW0MnAbsBaxJJOnPA/9w90fqsc05ZjYQOBw4GNgC6AbMIzp/ewi40N2nNcZrqIc/AWultG9pXD8Ebq/vyhatQ+4CeidPLQTmAusk067ABQ2MUZqQmZ0E/A3olDw1J7m/QTItAR6vYxv7oZEgKoZF66qpgOU8PRtYFtg0mYaa2U/c/bEim/q8yLyFRfa/PHAr8fuH+A59DawMrApsC9wPTC/6QqQ+VD63HiqfRWV0K9PSy+eKTsoB3P0z4ORkKnUdq2P+YuDqZKoYFtez/5K4ln3rlMORxvEFMAF4AfiYEntwTP5YHgNWAZ4mTkw97e5LzGxZovXIAUU2ISkzs2HAhcSf8rnAxe7+QTJvNeJPu2Md21gO+BdRqHxCHCRIujIjeNxDXOL0iLvPNLNOxIH+f4BewB1mtn5Shi3F3Vcrd8dm1j7Z7w7AB8AI4E53n5vs/3vE/8KX5W5bilP53CqpfG7DVEa3Si26fK74pLytsBjibVTy8HiyvcRLy3WXu9+ReWBmPctY91KiwB8H7O7uCzIz3P1b4MlkkgqUfNZ/Tx7+3N0vz52fFAT/LWFTZxOX1JxM/JmrwE/fTGALd38598nkN3qfmf0YeBFYARgG/LER9/1rosD/AtjO3T+qtf/Xk0kakcrnVknlcxumMrrVatHlc8VeU94GnQj0By5x9xfTDkYaLmmRUTYz2wz4cfLwhNwCX1qMk4GuwHO1C/tSJTVzJwIvEWd3pQK4+9e1C/xa898Cnk0e9mus/ZpZR7KjjozMLfClyal8bmVUPrd5KqNboZZePisprwBmtiZxtu1z4P9SDkfSd1hy+5K7v5lqJFJfhya3N9Zn5ZyauXbEgV+9DiAlNZnmae2LLlWeXYnaOQduasTtShEqn6UWlc+tg8rotqtiy2cl5ZXhImLot1Pd/eu0g5HUDUhuXzSzKjM738zez+nB8TYz2z7VCKUgM+tD/DlDfIbbJL2Afmlm88zsLTP7m5mtUmQzvyRq5q5y9/FNHrQ0GjPrAGyXPHytyHLjzWx28p1438yur+N3nflfmAp8bWYnJr3JzjOzmWY2zsyOSA4WpfGofJZcKp9bOJXRbVell88qvFNmZnsD+wPj3P36tOORivC9nPsTiGH81iR6dl2V+L48YRpypVLlfn4DiSEY9yI6jHFgfaKZ00tmtlHtlZOauT8RZ3NHNHWw0uh+AaxGdB50bZHltkmWAehJ1MA9aWb/NLN8nZVmvlczgNuIzoU2IUYOWR7YiejYZkzS4Yw0kMpnyUPlc8unMrrtqujyWUl5ipJeOv9NdK//i5TDkcpRldweQQyt8gtgBXfvRvQaeQ8x3MPfrMQxNKVZVeXcPxN4B9jG3VcAliOuR/wCWB24NTlzm+tfxJ/479xdvWi3IGa2KfCX5OG/3f2NWot8B1wM7Ags7+5VxHWN/YjhlSCudTwtz+arktt+xPA7lwGruHt3YKWc/e4P/L6hr6WtU/ksBVQltyqfW66qnPsqo9uIllA+KylP11nEn/o/8nw5pO1ql3N7rrtf7O7fAbj7VGAw8CFR8OssbeXJ/V91YH93fw7A3Ze4+33A0cn89ckZOsfM9koePwtc2TzhSmMws9WBO4AuwETy/Dbd/TN3/4W7P+nuc5Ln3N0nufs+wOhk0d+bWVWt1XP/F55y92HuPiPZxtfu/ntgTLLMr5MhWKT+VD5LPiqfWz6V0W1MSymflZSnxMw2J864fEgU/iIZc3LuX1h7ZnIAcEnycKCaqlac3M/vfnd/u/YC7n4PcXYeYuzMTM3cf4DFRMcx3tSBSuMws+7Ag0RN2bvAnpkD9TJlDhSWJfle5Cj6v5DIDPFTRSP2LNvWqHyWIlQ+t3wqo9uQllQ+KylPz4VEz39/AMzMlsudcpZbJnmuazphSgo+SW6/ypxpyyNTiHQhmsZI5fgk5/5ShX2eeWsnt8OJmrmrgHfz/CdkDu465Dyf79omaUZmtiLwALAx8AEwyN0/r8+23P19YHrysHet2aV8r3KfX7vAMlI3lc9SiMrnlk9ldBvR0spnJeXpWTe5vQ74Js+UcWnyWM3n2o6CPUIWoLO1leUNsh2ElCLz+WX+E44j/39CpufPw3KeWxdJTVJzci/RC+9nRIH/QRPtTv8LzUflsxSi32HLpzK6DWiJ5bOScpHK83By293MehRYZoPk9huyYy5KBXD3uUBmiJT1iyyamTe1SQOSJmFmXYjOX7YlfoOD3P3dBm6zF7By8vD9WrMfzrlf6Hu1Qc79qQ2JRUTyUvncwqmMbv1aavmspDwl7t7T3a3QlLPoUclzPdOKVZrd7WSvTzml9kwz6wz8PHn4gLuXc8ZXmsd1ye0eZrbUH7SZ7Ql8P3l4L4C7H1nHf8LjyfLX5jw/talfiCwt6aTlNmBnYBawm7u/XsJ6dTVlPCe5nQc8mjvD3d8jeyB5coH1f5XcfgZMqiseyU/lsxSh8rl1UBndSrXk8llJuUgTMrMemQnoljOrKneemVX/FpMhNjLDJww3sxOSgh4zW5foAXJtYAExVqZUnquIJnLtgdvMbCsAM2tnZnuQ7bX1WZICX1qGpOOmG4A9iJqwH7l7qQnwODM7zcw2znQAZWELM7sdODhZ7lx3/yrP+iOIZpfbm9mlmZo6M1vBzP5M9PwM8Ed3X1y/VyjSNqh8btNURrdCLb18NnUeWJnMLPPBHOXu16QZi9RfzudYl165Z1STM3bXAT9NnlpInJ3PHDgsAI5w95saKVRpZGbWGxhHtkOPb4gDgEynUG8QZ3A/LnF744CdiLPwRzZmrFI6M9uRbI3Id8DXRRb/0N23zFl3KtlrDBcCs4nvQ5ecdS4CTi7Us6+Z/ZwYP7s9cQAwC1iRbCdD/3L3QmfqpRGofG4dVD63bSqjW5+WXj53KBKsiKQk+cH/zMzuBoYCmwPLEb1HPgKcr7FzK5u7TzGzTYDfAvsTw3EsIZotjQYucvdvUwxR6ie3hVnnZCqk9rArvwV2BbYCVgO6EwfwbwNPA5dlxsstxN0vNbOJwG+AHYhr3L4CngP+4+73l/5SRKRcKp9bB5XRrVKLLp9VUy4iIiIiIiKSEl1TLiIiIiIiIpISJeUiIiIiIiIiKVFSLiIiIiIiIpISJeUiIiIiIiIiKVFSLiIiIiIiIpISJeUiIiIiIiIiKVFSLiIiIiIiIpISJeUiIiIiIiIiKVFSLtIAZjbVzNzMrkk7lkpmZhuZ2X/N7AMzm5+8Z25mA8vYRpt7r1vCazazkZnPM+1YRERytYT/0EqgMrp+WsJrVhndcnRIOwARad3MrB/wJNAl7VhEREQkS2W0SGVQTbmINLW/EIX9HOCXwNbAJsn0Qopx1VtOLcLItGMRERFpAJXRIhVANeUi0mTMrCOwU/JwlLv/J814pPG5+0hgZMphiIhImVRGt34qo1sO1ZSLSFPqAXRK7r+dZiAiIiJSg8pokQqhpFxEmtIyOfcXphaFiIiI1KYyWqRCKCmXBqvds6OZLWNmvzazCWb2tZnNMbMXzWy4mXUusp2SerGsqyfJ2tcSmdnOZnaHmX1iZvPM7E0zO93Mlq213o/N7N6c5d4ws9PMrFO+/RTYdz8zuz7pwfS7ZFs3mFnfEtdfOXl9z5nZl2a2INnGHWa2Xx3r1n7dA83sJjOblvSmOqvU11Fru13N7FQze8rMZiTb+tTM7jazQ83M8qwzMvl83s95+uqcGBvcW2l932sz62ZmRyXrvpF8PxeY2Wdm9oCZDS30mWe+ozlPnVnrNRV8XWa2lpn9OflsZ5jZQjP7yszGm9lfzWyTEl7z983sUjN7P3nN083sHjP7YV3rlrDtZczsl2b2qJl9kcQ3y8zeMbOHk9/ChnnWK/h7NLNxed6fYtPAArEtb2a/NbMnktgWmNnnZna/mR1hZu0b+vpFWqvav1FTGa0yWmV0vnVVRquMTpe7a9LUoIm4VsWTaVVgUs7j2tOTQOcC25maLHNNqfsrMD+zr5HA74AlBWJ5GlgWMODCIjHfB7SvK2bgKGBBgW0sBH5ex+s6EJhdJA4HxgLLlvC6z8rzumfV47PdBPigjpieALoV+U4Umop+zk31Xudsp9g0CVitnusu9bqAE4Hv6lhvah2veT+iI55C6/+yAb/h1YBXS3htN5XzewTGlbDN3Glgnm3sCHxex3rPACs31X+cJk0teUJldIPLjWRbKqOLx9Io7zUqo/O9Jyqj28CUegCaWv5U68/96eSP+D/AbsAWwE+A53KWObvAdqr/3ErdX4H5mf08l/NncAjQD9gduDdnmT8Bv07u3wscAPQF9gHG5yyXtwDJifml5HV/BpxM9F66fRJr5k96CfCjAtv5CdkC+gPgt8CPk1j2Bm7MieWWOl73y8nta8AxwFbADsBvyvxc1wBm5Gz3f8CPkvfxIOCpWn+47XPWXQXYOPkOZJb5Q/JcZlqzzHga673+EHgW+D9gT6A/sC1wGHFwl4l3XJ51v5/Enlnm4lqvaanXBQzPWX42cF7yPdyCKMxOBB4AphR5zROBecC05DUPSD7X3wKzkmUWABvU8zc8OifGG5Lv4zbJZ/3j5L16FrixnN8j0CvP+5M7bQN8khP/+rXW3waYn8yfkexrH+J3sTtwCbCI7H9Px7T+BzVpqtQJldEqo1VGq4xWGV3xU+oBaGr5EzUL/IXAoDzLdAFeT5aZDnTIs0zmz+2aUvdXYL7nTGOodQYdaE+2MJ+d/JH+I892uubE9HKBfU3N2deHtf/sk2W2IFsQTa392oGVcv60bwA6FdjX8Tn7+mEdr/sxCtR2lPG53pyzvZPyzG8H3FTHMj1z5h/ZwHga/F4ny3yvjv0cVex9rvVej6xjW5vmFEiTgV5Fll27jtf8IrVqO5JldspZZqnvcQnva2eyNRoX1LHsSnmeK/p7LLKtdsCdObEfU2t+R2BKzvd5+QLb2RNYnG8bmjRpUhnd0HIDldGlxtPg9zpZRmV0zfVVRreRSdeUS2P7t7s/XPtJd58HXJQ87AH8oBlimQsMdffFtWJZDFyWPFyeOAAZXntld58LXJs83NTMVqxjf79294/zbOdF4swrwLrEWfVcxwMrJnEc6+4L8m3c3S8hO2bo0UXiWAIc7e7f1RFvQWa2OlEjAfCEu/8rTzxLgGHAV8lTJ9Z3f/VQ3/cad3+32Ibd/WriTD9Ec7SGGE4cYAIc5u7vF9nvh3Vs6yh3n5lnvceJGifIDm1Tju5E4QrweLEF3f3Lemy/kPPIfj5/d/cra80/iDiLvxD4qbt/UyCme4Bbk4fFfhciojJaZXTzUBmdXU9ltMrokigpl8Z2fZF5E3Lu927qQICH3P2rAvNezrl/m7sX6nU0d7leRfY1E7i9yPyrcu7vWmvevsntvclBRjFPJLcDiizzTLGCpUQ7Ax2S+1cUWsjdvwZuSR6uZ2Y9G7jfUjTkva7BwmpJ5ywbZyYgczCxWX2DNLN2RLMygPHu/mx9twW85u4vFZmf+W3V53f1JXEWHuBnZtah2MKNwcyOAX6TPLybaOJXW+Z38Uy+g7taMr+LLZsjfpEWTGV0fiqjG4/K6KWpjA4qo4vQGyON7c0i83IL3+WbOhDgnSLzZtVjuWIxv+juiwrNdPePzOxTYHWiuRQASY+UmycPjzCzI4rsI9dqRea9XGReqTbOuV9XQfUs8PPk/iZEc66mVK/3OpeZ7UnUfuxI8c+1RwPi7Al0S+4/2YDtQPHfFWR/W2X/rtx9vpndCBwBDAa2MrPRRAcwT+c7898QZrYTcZ0ZRMc1hyY1OrX1T253ytdrbAEdiVqFLxoWpUirpTI6D5XRjUpl9NJURgeV0UWoplwaVR1nkXN/1M0xPEKpsTRGzKX8wXye3K6U81x36ndyrEuReY3xB909535dr+2zAus1lfq+15mz7lcQZ373pO4Cstj7XJeVc+5/2oDtQPHvKGS/p/X9Tz+RbM3GOsQZ8ruAL83sJYvhiVYuuHaJzKwPcBtRME8H9i7U5I3oiKg+utZzPZFWT2V0USqjG4fK6KWpjM5SGV2AaspFGkepZwlryz2I+C/Za60aYnHdi5Slvq+tqTQknqOJ3m4hrkn7J3Gt18fA3My1jWZ2HfAzYiieVi8pdA8ws37EsD8Did5TOxDNAzcDTjWzw9z97vrsI7ne827ioHABsL+7TyuySua38QhwShm7qqsZnYi0PSqjm4/K6EamMrptUFIulaTUM4nLNnUg9bBqGcvkdsTxJVGAGdDO3V9r7MDqKbcZ46pED7iF5DbTK3R9YGOq73sNcFxy+x6wbdK5UT6NUZswI+f+6o2wvSbn7hOJoV0ws2WJYXoOAw4FVgBuNrM+7v5Z4a0sLbmGbDSwQfLUce7+dB2rzQDWJHoorpTfhUhbpjK6cv6LVEY3nMrohMroyqDm61JJMk1kuhVdKvunUUm2KNZ5hZmtSfZP/9XM80nnNa8nD7czs0o565v7B7t1Hcvmzn+14FKNp17vdWKj5PbOQoV98hn0bXCU8D7ZZoo7NsL2mpW7f+vu97v7z4gxUCGane1Vj81dSLZDn3Pd/boS1nkxue1rZmruJpI+ldEqo0uhMroZqIxufZSUSyWZktz2K1TwmdkqwKDmC6lk3cj2RJlP7jAQD9WaNza57UnDh/doLI8RY3dCkSEszGwFoikVwHvuPrWJ44KGvdeZA4ViNTn7UvdZ88xQNssUWiDpGOWe5OE2ZrZNHdusZI/k3C+rYx0z+yVwQvJwLHBaiatmfhddiGF9RCRdKqNVRpdCZXTzUxndCigpl0qSGX9xdeJaoRrMbBngGqBzM8ZUjr8nY4fWYGabkR1j9UOic45cF5JtenaZmRU9A2xmOyS9YzYZd/+U6OwDYGcz+3ntZZKDskvIdtRyUe1lmlB93+vM+Kd7m9lSzd+STk7+U8L+M53C9Kljub+RvX7wf8WGozGztUvYb6Mzs94lfJ92y7lf8lA+ZrYbcU0gRI/Dh7l7qdcbXgdkrmc7x8x2r2Nfm5nZUmPeikijURmtMrpUKqMbicrotkPXlEsluR44E6giCr4+wH3EH+ZmwElE06ZngUo7o/ky8ANgkpn9hYixA1Fj8FtgOeK6tBNqj7fq7tPN7HCigO0BjDez64kONz4gOtNYHdiSOEu/EdET5+M0rV8BPyQK9IvNbABwA9EjZx/i89g+WXY8pRWUjaHe7zVRiPwNWIN4n88lmgF2BnYhOitZBphE8eZxzxBj4u5jZsOAp8memZ/t7l8AuPsrZnY6cA4xPukrZnYpUTswnehZdmNgH+D71H0A0RTWAR4zs7eAO4AXgI+I60fXIL5zRybLfkh8L+tkZt2I8XHbA/OA3wO96mj9+b67fwvg7gvMbAgxvmln4F4zuxW4laixc6L3177A3sBWwAUsfZAnIo1DZbTK6FKojG5cKqPbCnfXpKlBEzCS+PF5Hcv1zCwHHFlgmf2BhTnL5U4LgV/Utb+c5Uc2JJZkuYE5yw3MM39qMu8aosfQQrEvAn5Rx/uzB1EI5Fu/9nR4fV53PT7bTYk/+WKxPAF0a8j7XGIsDX6viWE+HijyWuYCQ5J9ODC1wHY2Jwr4fNu4Js/ypxK9mRZ7H5faV+5rbozfYAnf8WLTB8Bmpe671mdf6pTvN9afOPNfyvpnNNZ3X5Om1jKV+v9Qyv81KqNVRheOpcHvNSqj6/qOq4xuxZOar0tFcffbiTPso4lxLBcCnwA3A9u5e3Od6S2bu18JbAfcSJzFXECMD3ozsHVdsbv7/cSZ3VOIs7SfJtv4jvizfYA4k7mBl9YJR4O5+ytEpz2/Jc40f0V8Jp8B9xK9fu7k7jObI56cuOr1Xnucld+TqEGYQBTw84ieXi8F+rr76BL2/xIwINn/B8D8OpY/H1gfOJ+oRfiaODD5iqjBOIc44EvDk8BOSQyPEs0HZyfxTU+e+xWwobu/3NzBufsE4r07BriT+LznJ9MnxLWVZwP93P2s5o5PpC1RGa0yusS4VEY3HpXRbYQlZzlEREREREREpJmpplxEREREREQkJUrKRURERERERFKipFxEREREREQkJUrKRURERERERFKipFxEREREREQkJUrKRURERERERFKipFxEREREREQkJUrKRURERERERFKipFxEREREREQkJf8PFNvPmHkgJPAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1008x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "batch_size_list = [\"4\",\"16\",\"64\",\"256\"]\n",
    "figs, axs = plt.subplots(1,2,figsize=(14,5))\n",
    "plt.style.use(['science','nature'])\n",
    "ax = axs[0]\n",
    "ax.plot(batch_size_list, train_acc_bs_list, label=\"train acc\",color=\"green\",marker=\"^\", lw=2)\n",
    "ax.plot(batch_size_list, test_acc_bs_list,label=\"test acc\",color=\"red\",marker=\"^\",linestyle=\"--\", lw=2)\n",
    "ax.set_ylabel(\"acc\",size=28)\n",
    "ax.set_xlabel(\"number of batch size\",size=28)\n",
    "ax.legend(fontsize=28)\n",
    "ax.set_title(\"train/test acc to batch size\", size=28)\n",
    "ax.tick_params(labelsize=24)\n",
    "ax.set_ylim(0.8,1.005)\n",
    "ax.set_yticks([0.8,0.9,1.0])\n",
    "\n",
    "ax1 = axs[1]\n",
    "lns1 = ax1.plot(batch_size_list, info_list, label=\"IIW\",color=\"blue\",marker=\"o\", lw=2)\n",
    "ax1.set_xlabel(\"number of batch size\",size=28)\n",
    "ax1.set_ylabel(\"IIW\",size=28)\n",
    "ax1.tick_params(labelsize=24)\n",
    "\n",
    "ax1.yaxis.offsetText.set_fontsize(20)\n",
    "ax1.yaxis.get_major_formatter().set_powerlimits((0,1))\n",
    "lns = lns1\n",
    "labs = [l.get_label() for l in lns]\n",
    "ax1.legend(lns, labs, loc=\"center right\", fontsize=28)\n",
    "ax1.set_title(\"IIW to batch size\", size=28)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(os.path.join(__fig_dir__,\"info_batch_size.pdf\"),bbox_inches = 'tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e444eddf",
   "metadata": {},
   "source": [
    "## We can see that when bs=16 the acc gap is the smallest. Simultaneously, the IIW gets to the bottom!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04c9c75a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
