{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchvision import transforms\n",
    "from torch.utils.data import Dataset, DataLoader, random_split\n",
    "import torch\n",
    "from torch.utils.data import Dataset\n",
    "import os\n",
    "import json\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import cv2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['E:\\\\Datasets\\\\record\\\\Town01_1', 'E:\\\\Datasets\\\\record\\\\Town01_10', 'E:\\\\Datasets\\\\record\\\\Town01_11', 'E:\\\\Datasets\\\\record\\\\Town01_2', 'E:\\\\Datasets\\\\record\\\\Town01_3', 'E:\\\\Datasets\\\\record\\\\Town01_4', 'E:\\\\Datasets\\\\record\\\\Town01_5', 'E:\\\\Datasets\\\\record\\\\Town01_6', 'E:\\\\Datasets\\\\record\\\\Town01_7', 'E:\\\\Datasets\\\\record\\\\Town01_8', 'E:\\\\Datasets\\\\record\\\\Town01_9', 'E:\\\\Datasets\\\\record\\\\Town02_1', 'E:\\\\Datasets\\\\record\\\\Town02_10', 'E:\\\\Datasets\\\\record\\\\Town02_11', 'E:\\\\Datasets\\\\record\\\\Town02_2', 'E:\\\\Datasets\\\\record\\\\Town02_3', 'E:\\\\Datasets\\\\record\\\\Town02_4', 'E:\\\\Datasets\\\\record\\\\Town02_5', 'E:\\\\Datasets\\\\record\\\\Town02_6', 'E:\\\\Datasets\\\\record\\\\Town02_7', 'E:\\\\Datasets\\\\record\\\\Town02_8', 'E:\\\\Datasets\\\\record\\\\Town02_9', 'E:\\\\Datasets\\\\record\\\\Town03_1', 'E:\\\\Datasets\\\\record\\\\Town03_10', 'E:\\\\Datasets\\\\record\\\\Town03_11', 'E:\\\\Datasets\\\\record\\\\Town03_2', 'E:\\\\Datasets\\\\record\\\\Town03_3', 'E:\\\\Datasets\\\\record\\\\Town03_4', 'E:\\\\Datasets\\\\record\\\\Town03_5', 'E:\\\\Datasets\\\\record\\\\Town03_6', 'E:\\\\Datasets\\\\record\\\\Town03_7', 'E:\\\\Datasets\\\\record\\\\Town03_8', 'E:\\\\Datasets\\\\record\\\\Town03_9', 'E:\\\\Datasets\\\\record\\\\Town04_1', 'E:\\\\Datasets\\\\record\\\\Town04_10', 'E:\\\\Datasets\\\\record\\\\Town04_11', 'E:\\\\Datasets\\\\record\\\\Town04_2', 'E:\\\\Datasets\\\\record\\\\Town04_3', 'E:\\\\Datasets\\\\record\\\\Town04_4', 'E:\\\\Datasets\\\\record\\\\Town04_5', 'E:\\\\Datasets\\\\record\\\\Town04_6', 'E:\\\\Datasets\\\\record\\\\Town04_7', 'E:\\\\Datasets\\\\record\\\\Town04_8', 'E:\\\\Datasets\\\\record\\\\Town04_9', 'E:\\\\Datasets\\\\record\\\\Town05_1', 'E:\\\\Datasets\\\\record\\\\Town05_10', 'E:\\\\Datasets\\\\record\\\\Town05_11', 'E:\\\\Datasets\\\\record\\\\Town05_2', 'E:\\\\Datasets\\\\record\\\\Town05_3', 'E:\\\\Datasets\\\\record\\\\Town05_4', 'E:\\\\Datasets\\\\record\\\\Town05_5', 'E:\\\\Datasets\\\\record\\\\Town05_6', 'E:\\\\Datasets\\\\record\\\\Town05_7', 'E:\\\\Datasets\\\\record\\\\Town05_8', 'E:\\\\Datasets\\\\record\\\\Town05_9', 'E:\\\\Datasets\\\\record\\\\Town06_1', 'E:\\\\Datasets\\\\record\\\\Town06_10', 'E:\\\\Datasets\\\\record\\\\Town06_11', 'E:\\\\Datasets\\\\record\\\\Town06_2', 'E:\\\\Datasets\\\\record\\\\Town06_3', 'E:\\\\Datasets\\\\record\\\\Town06_4', 'E:\\\\Datasets\\\\record\\\\Town06_5', 'E:\\\\Datasets\\\\record\\\\Town06_6', 'E:\\\\Datasets\\\\record\\\\Town06_7', 'E:\\\\Datasets\\\\record\\\\Town06_8', 'E:\\\\Datasets\\\\record\\\\Town06_9', 'E:\\\\Datasets\\\\record\\\\Town07_1', 'E:\\\\Datasets\\\\record\\\\Town07_10', 'E:\\\\Datasets\\\\record\\\\Town07_11', 'E:\\\\Datasets\\\\record\\\\Town07_2', 'E:\\\\Datasets\\\\record\\\\Town07_3', 'E:\\\\Datasets\\\\record\\\\Town07_4', 'E:\\\\Datasets\\\\record\\\\Town07_5', 'E:\\\\Datasets\\\\record\\\\Town07_6', 'E:\\\\Datasets\\\\record\\\\Town07_7', 'E:\\\\Datasets\\\\record\\\\Town07_8', 'E:\\\\Datasets\\\\record\\\\Town07_9', 'E:\\\\Datasets\\\\record\\\\Town10_1']\n"
     ]
    }
   ],
   "source": [
    "dataset_paths = []\n",
    "# records_folder = \"../data/record\"\n",
    "records_folder = \"E:\\\\Datasets\\\\record\"\n",
    "for name in os.listdir(records_folder):\n",
    "   dir = os.path.join(records_folder, name)\n",
    "   if os.path.isdir(dir):\n",
    "      dataset_paths.append(dir)\n",
    "\n",
    "print(dataset_paths)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7837\n",
      "0\n",
      "6269 1568\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQEAAAD8CAYAAAB3lxGOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/av/WaAAAACXBIWXMAAAsTAAALEwEAmpwYAACzT0lEQVR4nOz9d4xtW57fh31W2OmkynVzfLlfd0/nmZ7p6UkmhxqRnCFA06QAiaIJjwiIsGULsClZhgjLAmyLFAHDAA0SGpACJAaDpDighx6OZ0hO7Onp8EK/HO67OdStfMIOK/iPtXedU3Wrbr63bvWr78W5dc6O6+yzfr/1yz/hvecQhzjEpxdyvwdwiEMcYn9xyAQOcYhPOQ6ZwCEO8SnHIRM4xCE+5ThkAoc4xKcch0zgEIf4lOOJMQEhxJ8QQrwnhPhQCPHXntR9DnGIQzwaxJOIExBCKOB94I8BV4A/Av6C9/7tx36zQxziEI+EJyUJfA340Hv/sfe+BP4h8ItP6F6HOMQhHgH6CV33BHB54vMV4Ef3OlgI8UMUtqiBBEQJVOAJrFbE4BNA1ccJECL8Zfxn4s3u2yY3eXY5tt7eSHhC7HKOH58rdrn2XeG3/dm+2U/sEPUY/J3neAPkgHnAez8uRPXLEx7K/T6D5jgPOLavoZbwnXZDyvh33wt+l/ee8Iwe23O67b1f2LnxSTGBe0II8cvAL+/X/Z8cesBp0EvAVagIc6XXhuqzYOdARoAGFY2JUOvtc1FDmKj1ezP+2BwvDKDAWxATv6T3HioTiFDFYaMEpAPnwphcOBepuIMIFGFOY8KxWwPYAVOBjupdVSDubYf5sM2a8WdXQPkRmLf2foRPHDHwHOF7p0BC/YVrKMYEbgkPC8JzEARir4A2UNbH94E3uJM7ArwIdHfZbtnOHPzE/SwwBK4BGw/y5e6Gi7ttfFLqwFXg1MTnk/W2LXjv/473/ive+688oTHsEzaAm2DsmCAM4NagtQxRTblKEKjYb2cAmkBY2yj+TojmWLGdAYR9IuwUCqElQqv6l5YgNWgZPiuF0CKcL8Kwtua53hpM+BNx55Khd4xR6Ilj6lVMAErXF/dg18Hc2OsbPQHsdt0B8BHbCV8yJshJwt8NzUNqYBgzk90Q1cfv/E0bBtw8tOZHkPX7NR4jA9gTT0oS+CPgBSHEOQLx/3ng33tC93rGYIDru4jLHuavwuY0rLUY/9CT2Dm5JjbV80eg8XcVD5uJ1IggCnDbBNmdvN/D1vzfOSIfNd+Ju0il1cTtNeidEkENV4FdApZ3jPcocAS4BKzsdZMHxHGgQ3iAfYJ2OvmjFMBtAvE2z2M3wlfsLsrv9gU77K0S6Im/DfPZTWpo1JObwG7M8vHjiTAB770RQvxV4NcJT/BXvPf7Kf/tP3JglAdbgajYvuwatn6KibdbKz261l7N7pK5IEgWXof5JXxgGrvNaceE/i62tOI7IUB7MPfSR3eZyEKDrraP01kob4D5cMfBx0G8QNBrrt3jXveLhrHE4bp0CMR+lSBiN7r2GjBd74fADBp9fzfY+piGkCdFvYRtzPCuY9MTY2hUgC0djCCprN/HtR4PnphNwHv/a8CvPanrHzgUwKUUshhwIBtqFzXh16LzLmqA3yL8nT9Xs+rbmgF4BA6JDIcLQLtgNLDjMwLZuvqz2nE92CYWTzKdqP7gJ7btxpi8ZzyA2jDoRmBWCTp0gwzEPMgM3BIwuvO57QEBTBHIeKeNNGCDoIXCllpDi7D6Xyd8/5wglSzQSEzhtZdqona81/Xxo3oEdxPdJ7n7TjSMoMEI2LzLtR4vDiMGnybsCEoztvv4xibAhE1gx3Ru5p3ebnsfq5ICvKrnkGD7RK1vtKvvZVL3nDy3magWj0eY3SZus62+8B3Cgt0xFkcg11uMp5wEcQzk0Xr/NR5k4h+TcLwX3i/esdcTHFITnorGa8NJgqHuWL1tN1H/XhLBpARwP46tB1lrHXfRu54IDpnA04QvoXcR2usgGk5QW/GbieInJpYBzAT1b81XHcT/LbHSIkSwv3kBdicf2JrLAqSo6dPX9N8wgsZIFa7nmzFsGQgn7r0Fw52r5i4T2FZQlkBGIL40MAB9Jhgq3Rr44V5PbVe8egKOHA3j2V1rL9m+ukJ4EAkwQ2Ad59mNhQRMegh2Yi9J4X6Nm40otdOvawjSxPJuJz0xHDKBpw25DtkKqAKs3+4VgrFrDj+eI3b8ErYCV9YMoj5Z6DEVqEm/vAi8Zgu10Uk4dl/BmsH4vb3nngk7waRlu9m5y/FOgOiBfB6iV0F/meCia9UM8CZBUoDdp2Ryx2hSDSMngTMYJTix21h3RTPmmODiy7i3D38nFGOLP4x/vL28Aw0mn8+kN6JBBazyNFWBZiSHeJpYnoelhbDCA1vLfMMQGnhTzxE/nv7e4Vfeg8HNcTAQBJsaYf0ObjkLUiCE3L6eSYeXbnfHBD6ct4OQJz0HW+PcQv0d9AS32qazEIyUWkLahWQBohbIGdDdMDJrwE8a1HoEAt26AMHHvn3AUQzdbgRMU/iI6V051k5JoPlGkkD86W4n3Sca1ckSDD5wd7G/ObYxxU4EjW2hT2CITxeHTOBpw98K0kBjpreGsaW5WcENlEOoPPhaNFce/Ag2fw/Wfhdf7HRFjalP+PBCgpMCpxoJQIQYgoZIJwUCYUH6O5iDgAlasqB3ISy/Y0WzzXhqo6SrgxlUzZKEBtlMvRW2W8I7bDeOTrPbSi0EtOIU0Kw7ibyD/jxhVd25bef4d+Me9xvAOnmcIxDxbpg0uE4y2oYZOAIjWd9lfE8eh0zgaaNbwvRNiPphBZy0ATQTxArIl6HcCCuvs1DZEKFHBX4N1m4wFkNrY5K3CCZ/VIFvXFpKB+ITsiZaud0UINnOFLbhHkRhdzOQ1TrONkvmDrgK/BJj4tEEYphUN84TVuzt579/HW6v1YFX9Li5q3fuXt4GyZ0ksFOUYZfPzdgmCXZwl/tMBiHtZESiHucqwXD69HHIBJ42PJBeA70BbiKctonn97UvupVA+T5U6zUjAMwE0ecX8K6ozwtiuHDUq65ECImU4SWCEBD0fCERWoCSCCUQjQqwB52HzXZsYLzDYD4xJi/G0i5ybA/YsjD47ae5dba71eYJBNGI110CA8jYyQTeXIfvfDCoL7TI0q6jz9mboCfZ5Tb95Y577c4Y1I6/G7scsxN64p6OYAOoCAxk+T7OfzI4ZAJPGxvAmoKiNuVDzQzsdrE7yyAdwPqbUKzXv1TElvvKX4JhIJYgyQuUEggpECiUUoEBMI55a16TJoGt9/eSAhrj5B1MoBl0fWVPyFHY2j72ONx58gZjJqAIVvtJ49oJgn3gTsMgQOGa66e7+CQ8gbB2igi7uf2aL74bU2i276Y2NK7Eu7kTd6J5Hjlh9V8nxC48veCgnThkAk8bHlifgjypV8PG2LaDCr2FmSNQXYO116Eq6t2NK3EE/TBxJIJQwmFn8M99QoCQe/gD3A4ddduM2TnxbTBG2Mlz/Pa3zUdfhe+wxSx6hGCeyTFkjCP09oJn7zyLyRvujKGY3PawZNCoBJbt3oK7ofmtC4I95Bpjz8j+4JAJ7AeqKrjZrKsJRobsPjx4F8KK7QoUfRAz4N6B4fWQfDMZd56vb62x1jqctTjv9hYqJ+l8671ASImSCrnbHG7o/I5Fsl7t7+ADO4h+kvC8CExvayVsdHZFUAWSiRs2gTyT6sRuuJc//yGY4n2hkQIau8L93KfRp4YEFWCzfu2PGtBg31KJP91YA3kbfOOmcuAUSBuYQrwJ5gqUOaQZjCT0P4B0ge1GJRfsAMLhywJrC0R7Cqdkk7O3nXTqD6KOGQpeRomsieiu65jY8XfSTgATEnFNGN5NfN7m+wz7/JCxQXAKmGW8qsJ21eBO1+V2NIS4kyNNJgfthWZ89xvoM4mGycSMQ4f3giV830H9t884j2F/ccgE9gtqGewC+JQta7iToFeBa9C/GRhCawpGMfirMJr8ucIE9JUDX0Ler7N1/XhOe2pfYT3RaiNdU8JgZ2U5LxvindghZb3o1wRm99J9G6LfLVzRs40ZeB9yCWiiBKcJRsAbjHML5hmL+btkV26DIjCSSZdgTMgkvB9h92GYwKT6FnHvUN8NQgLTqD5+wLPAAOCQCewPJMFFKPtgOjVxmkCA+ioUF2BUi8qpC2Z/X3KH7ih0iCcYXoesDa1pQOKdrddEj1eCcbJQ+Oe9x4k7p6AUEiFckOi3dk5asycNfjuxkzlIxrEPu0gDW587BCagCYTSeAaaSD7H/U3TecZMYIYgWczvOKbR4ZuqQNsdqg+GSZ+q4+5RfhUhCGiZ8L1a7LcdYBKHNoH9gAJaOWSroEdh5XUOKIMBcLMRLX3NDJrVcUdMuRDBbjC6HAJxVIT3Dl+MsJur2P4y1uT1VBXgJXgRhAUrx96JyUsGM+MeBsBJT8DE5l0t4w2xTboG/cS2jECsxwhMwNff0xFW9WTinL1WzMnIwt7E+6Y+wU4VofncbGu+/87r7+kq2XEtGNduuFtMwgbBCOgZZx4+OziUBPYDTZJdexWqBagyQvWOPpjhdq/WNg/XDpHTCxgOgsgvddidb8LmNTDLwAiqc/jpM0gdI0St+3uP8mKPqRgIRcrAYyzg3U5mIcep9W431982N8D4T+PSEwJkD+xZAjOId1xjjjGB7+Weg/GKTn38DEEa2KVk2vZBTOBucQH3oyI0uQgd9pYGlhkz8pKxtPNs4KElASHEKSHEvxZCvC2EeEsI8b+pt/91IcRVIcRr9esXHt9wf0jQZNYOUqjUhEXdg3kAXdFbMCNAgy1hOITVj2H0Pajeg+oj6H8YGMM2yHE24R6QMK5BuuU2aCINbG17aHwTdx3k+I+fJLgU5DwhiWfnQCaTehqRfbfBGralJjPDdgYCd07xnc/2bp6Hu2HSiBlz93Jw/R33ebaYwKNIAgb4T7333xNCdIHvCiF+o973t7z3f+PRh/dDjCIFswiuE6jNWxApmC73F30GYRJuBJ97uQGDT6D6gO1ReEOgwIcMhCCcS49H4N3OawVIuf3eW5HGdtI+0NQpeBDjVr0S116JQBfN54Ig9iTcadW/m0pgGU/jDsHg1hBkw6T2ct9NqieTzOR+v0sTttyEO++For5HxP1VH3q6eGgm4L2/TijRgvd+UwjxDjxARuenHjHYFqEgaO2vMzYQ9H0RVuNrvw4uh80c7E3u0E1VidADhC/xhHBi/Fa1AFyt/6oJQhNiu6C9dbstSO4pAUwymG3uw72+2yaBWI4RpINJ3M3y3lyvqR40Wbnofgx/O/ffr1TQOGEb1nq359EwmphnTQqAx2QYFEKcBb4I/GG96a8KId4QQvyKEGLmcdzjhw/NxLZ11GAJ5mMerNDmEFgC1sFeYTsDUMACyOdAzOCdxDk/bgVQE3/45+o05LE3cDJQ0Fu7nTa2zXc1XnAnMWkS2NXN38QLNJ+bmuozbBfn7xUjMJlslBDUgd1Kpu0WHXivQKS7obleoxY0K/zdSog9WOGUp4VHZgJCiA7wT4D/xHu/AfxtQsWILxAkhb+5x3m/LIT4jhDiO486hoOJEcFgVDC2FLa4/1TSJFTkCfXM2b5aJsDzkHwBOs+D7OG9ChKA391t56mJH7YYxdZIvN8hnU/eqyaGbenEE1GN2PrcnUa52lsBjCv+nGRc9HMSd2MCk/eNCZ6GSav/zoy9sct0jF0zo+4DtWt3yx4xxd1/v6efJnw/eCQmIISICAzgf/De/1MA7/1N77313jvg7xJakt2BH96+A/cLD1wC+V1CEInj7salyX0ZYbLvMalEB1qvwPRJSNp4MY75dfVry4M34Q3zO2aDn7z8ZGHRXY1rk6GDO/bfoQpMMoRmEFME195k/sC9pIDm3pPvaxVr6+V37Jfcec1JZjSJDeATArPe7Vk3koUGeZxnKQDoQfAo3gEB/HfAO977/3Zi+7GJw/4M8IOHH94POypQQ4Kr4DLwHnuvSBHwGUIATE5QA/bQL6WCtA06pq4ssj3kf6frvKHhRrLd5t2zE+/vVlhz5/amWAq7zLKGCTQcqHGzNUS781r3qxI0q/KkmO/ZLiXdzd1YMq5NOCQE+FxnLLHt5Vlw4C6yt+1iN+nm2cGjeAd+Avj3gTeFEK/V2/5z4C8IIb5AeGKfAP/RI9zjhx8VBDvALe5uABsRmnMcJ6SeVnBHFr0CjoB+CfRE8s2Elw52IYMtxqBCAVNXuwC3nbXz/cQmOzlue+exbqcq0HCFhqk0hLtbzMFkf4a90KgEDcHvNq0b1WC3pCJLeJZXCM+1iVvI67+3CEzhOEECiyauYwguwLtFDN6t4Mj+41G8A7/L7r/MYa+BB8YuXWuafJr1+rP04PqE9lkNdknlZQOKa7C8BtlzMDUTeh46ubvcZ5vQ3DoJZ7KmwW6utd34lN/zQ73pbl6BZvteDAD2nqZd7mQQO+/T1Pbb696W8KWazD7Y7mGg3r9e73+RYHxspADFvTMBn20V4TBs+FnEImFBKtha3Mf0MTGhJYijO0/uAx+AfQP6vwcrN0MosjOhMpHbIXArgtSg5VgiF7C1qjZNT/S9VuMJPPay+Yqg68/sGMNe5cJ3k0x2QyOhNJl9d4Mn/CjN/RspZoVg03m2Cf1uOGQCzxokwR61yVhA2EWaFAJOzkUkU+zS8LZR8G/A6FuwdgWKqs4AdCFPYSJTUCG2mdJCfZLmU3PDSXvAJJHtpPim6AmBZnbuviNyt/Fs7GULaYKBztSvyQrBPbYzhcZ42ojpzfvd0AykIuj8q3sctxNDxmnDBUEya9ybs/d5jWcLh0xg39Fh20RtVNEGTRr6BATwck9wa7miuMkO+2ACnCaIrPVKNfoIBk0UoQv++a2ipuyodr7d+Od3a344GfS2a/chxra+XdEYIZo6APezik4z7hPQQHNnBN7OCj/NQCZtAQ2HasSt+29/Fo6/SjAavslYdTjP/TOSZwuHCUT7jnuJobujMJ6yyUEAQmLOPKRfhmQGqk0YvEEwJl4LtQtML9gHmnoChOrEWFFXIx5zBG8MQu/CAO6JCYJu6O+OS+x0yTVGzElpYKdHoNHBm8rDjVcBAjFPulAnxfadY2s8CAOC5b8p7nG/aAy4OxnXew9wjWcLh0zgAMIDH9+hInjwg0D8nWlQM+C/AsPjhBWqXkEbe98OGrG7EXuzqZr4sHPG7CRy04ywzi1ouiRNbL4TTUriJHbW6G8uvnOcu8VWTBb5mPQWNNJATljJH6bE97MX+/+oOGQCP0zQQ+j8EayvQfvzodBIfD5UB4oSkDsJpuYGDVPYQXO+qjsObxHSzhWXHTTZGAF2ruCTBO3YvfrQbprpTkagCQaQ3QuMb8fOqd2oACGh6mk3/XyWccgE9h2TRTcew6XaJajL4I6CPAUyDmmAcoLwpETUHYCUCoWN/G6L7hbuMk3uEPcn9fRm6Zfb3fS7Re7uiUkj3z3Gsg2NStAU/YAgAVwiuPseJl/ghxOHhsF9x2N0LVWEOKL2KJQpwwYGoFRd0gyIxgygwZaXUE/UENDsUjpvl1RYoSfoUkwcN+lvmNw/UZXIw+5dgHbiQQh/cqyT0YKNK7AJvHj8Lr3ogJLTwRz1IfZGAdyowF2F/NJ2yXuHBNAQ/Z5BufdDJ9uSidSE+rADDf03GsHdCgYB20fVGBI0wTDYfKnd9POdIcJ6YvuTa/Mlpr/AsVN7xS082zhkAgcQe+dma2A6eK2WNyH/MBQboQqhwJXDuyCHWxtaHxgT6Ng27/dUCfbYts1Wt5eePZHVJ+x9zrpJ6+UkJ4sIQUK7cZBGApm0TUxaN3eJzHwsEEy3R1y6/PQ7Cj8OHDKBA4i1PfekwCuElFyg2oD+VaiaAKEKKoOvDN65O+0AgDc2GATvy242eVA1sWmn+C5CqrGt/7raGHhPaWA3JCCnCYxgr6zL3fID4Mml8npWr77HQY0aPGQCBxBze+4xwKiu3QfQB38NXDk2wjsbmIE14AzeGzz1qxEF9tIPzF2jhCbOaVbh5kJ+LJlPzrj7Kep7B4q6jsIuVZS2DWS3UMVD7IZDJnAAsbznngLEdVAJIda+zsDzBVsdgZqXcfWLcfDcnqv/XgSkt+8fVyEJ7gbTEGOdVnxHyPD9oEnwmbxnEwG44/57ovlyT84tKMgOrL/hkAkcQOw92Tz4NaiahBYDZhOKPEgDTYxw5YNfsMkabOhjr2Q/s5vewIRRsKZ+BfcmtCZ/YY97beFuNQQaTmJ2/N0Nk/uepDRQsHBAqemADvvTjcW7eswKQl58LSq7Zcg/CMxBrUO5AsVqKE7qd1mW7ygq0rzfoU9vW1hVYBT2Xjp3c0F5n7aA3RiBRog+d3Ks3Qi8kQBKdg10eozodXocm3pil3+iOAwWOmAQQCdmggB3CzZqIu0ASnCXAoEWXdjchKgN+gUgBeUnggMm0NgGtAixABb2Dpk1IdBgW4jwbmLFRKTQZOGfu37bncFCkqzVZThYZ3u1n53FRBwhOnC1vsaIJ7fmxRw/cYyL76/zZKWNJ4NHZgJCiE8Iia8WMN77rwghZoF/BJwlVBf6c977g5li9YyhE4Ws4DEithfBiAiZiZOPewTVDTAr4DcgOwnxACoJtOoyZDuq7rq6wrDXO+hwj2Ijk41IvK3f7mEA2EYnTSrxTqvhZMbfJLco6SSK4SgBl7CdQZiJc0aEbL+nMe3muHzhI/o7O7weEDwu1vgz3vsvTBQN/WvAb3rvXwB+s/58iMeAV+dBbFXkDqu0lpME3BBVvP3E0RCGa2GfszC4AWsfwPAm2KLW7ycUdVVnFm5taib4Hvn521SBxse/27F+bKS8a8TgZCHSSV9ixNnj88ho4c7vuIU+ITLwKa07ckDlyz1H86zjSclHvwj8/fr93wd+6Qnd51MHJ+HaVgahQEuYa0eMCcISgmKynWeyRVj9Deh/An41FAtxtejvmloDnlBG3Nd9RiZdbnvp4pMqhWVbS/Rt2HnuXqvnZMPPSelDsb55G1FdZfc0bANcIAigTwlug25bcvSAugceBxPwwL8SQnxXCPHL9bYjdYciCE3nj+w86bDvwMNBRpMCsAM/JE0BmUwcVbG9FdkO+Lpenm6BmqjU42QI6Gn6lttGrJ9Y5Z3d/nlbTYDJge44D2qVYWdronuhOaY5TzAsS3rpbpFGnpBheK+af48fM52M7pOzOz5RPA7D4De891eFEIvAbwgh3p3c6b33Qog7fhHv/d8B/g7AbvsPsTuqXdRs5R3oaSgF958gU4K7BkYHo95ko6g7yn9N4I7Liom+AhPYrSPRHWNvVIG7eRXcjr+Cz33uK3z85r9mdbhbDPN19gPGR0x3eLAGUs8IHlkS8N5frf/eAv4ZodnIzab/QP33yWVufMqw2RTBmagN4J0m9PA7z7iZ585laeeqqYMa4NcIK+fO4pyNe26Hm07BHc1CXXMOPHg0UNMQZBJ+x2sShkFeUNkdhsytY3dWCn468Gii9N7HPYt41A5E7bojMUKINvDHCc1GfhX4i/VhfxH4549yn0OMceF2/UYFInce1iqPbEUgWgTNK6lfk/AEwa8R2+chegH0efBTtaHuPgjYwZ39/O444E7cVTDZuXOyE8qdAyhGG8zNH0FsY3SWcUu3p4+RqbhyFw3sWcajqgNHgH8WmhGhgf/Re///FUL8EfCPhRB/GbgI/LlHvM8hamx5B+vWYs7DwEviMyn5hQo2YgKh79adKGbsPkvAt8HNgMsAAdKFKkR3M3BZdjCLnXo/d/KByW1+cqNnXO0nYnsl4b3g0NIzM9cGkdfXa4ye+9fkY2W1T7U/Qsgj45GYgPf+Y+BHdtm+DPzco1z7EHeiTTPNBVm7xagM1vHKQjQlYaqEjVvAKKTs3hFDVAXjnANYClF+UobqQ1LV2+/CCGxNye4eEsO9BAo/qWbcJiQDHSEwqUbKkHteqBgWzC0kiFjhCwiqTMF+ap1VuT8SyOPAYdjwAcLshCPaVWMK99ZSLt+E8jrBMLjHhPQVxE3dwBz8daiugc3ZIkpXpx3vJr7v5frfItam9+D9iAPN53UC8Q7q80vu3vNQMrd4nOfOnEEk7foaTaj03VqBPXkc7UZPMDD5yeGQCRwgrG/RlacoJsR9Y+DaRVi9Md62Gw01cUQdIJsFjoMbhcIjpmIbI9gNe1YCmywaslu7s4bgJ2MKJIF4m+9REuIbGiPl3uLE+xcucPniu/h8pT7uCvttlj85t8DLJ87Tfsabj+6GQyZwgLAxYcCPk4k1xzlY34DyPirnGMJqnihQR4A5qPIgDUzq+s7uYijcizlM6g6N/34Xi7+HcXPSJgCpkVo2CZ2Zl+v9exkmLJ9cWuHC5dv4akRgHvvtlxOcWjzG8fkzLPZO7/NYHhyHCUQHEhK3Uy6/l54+iQ0gWgE9B/IYIaFnMihH1e5DXycYNU1L2V3T2FLf1diruDUu6gSlJh5gWA+gyVdovkefoBIcZY/OqTRFCp0tee2TAu+H3J8x8cljaekysr9Emhw8SeCQCRxQmNGDtM7agQqwFcTLoObBdwKhOxtyBhr4ujKonWhVvk3N2JkvYMdCwERRobCoT5YxdsDVkJ24syYBCXdvLW7Ab7K03rQQf1J1Ax8EntXNNRZbGcMDaCA8VAcOJBzYR3SHOSBeh3hzTKRN+vCWy60OGxZ+bA9QTBgHd9YKq7EthseOVYtGWmAqnOuvMY5w3O2ak2hKFU+KGk0jg/3HzPQRer0ORXnw/ISHksCBxQPX6WIcQFQb42QOcgOqhfE+b8GqemF3dXeSiUs0M8bCFgFa2DtZyI+lAeHqvIXLBD1+t/oEa/V3m2FcXryJDtzpmrAEx+n+49rqiIXYc7PYv1iFh8WhJHAg8bB6cBNRWBPOCBA3IVplHKE34R5sZsdeEbwA6B2zaK9SXx70AOIrhLiA3YKZIDCHS/UxOduLlu4UtcVd7vc0McuZM1+m2zuOd4fqwCGeAnS8M034fiEIongrfCwAXUG7D5SwsyjGXpL2Nrqzex+3sxu4yaA6RWidvkddAixBQrgOvMs4CnCSCzXGtzYhSXU/kQIpn1y9QJFXzwRLelAcMoEDCGsfRhWA8HPHwDRb0sTKAgymwMuJXKF6Ndu5qO1a3HeCmAWoKTjxuThoF3XhonBI3XPAdwh9EY7eY6yG4DF4nztTgxs1YsjdujA8HRTATUbDS/zhxYsHsLjYoU3gQEJTPWKD7C5hNY2gisGloJpQ4ZryjdpdBYfQv8w0a96kNyH0LYg66+jeELOWQndYNx3RdYVjy7id2P2giWacrCzcGN8elhk+TowNlflBFAM4ZAIHEpV9WLdYY/VvAcchSUL+gN9DnheT1ne9exEhtncrshuOS//2Fs5eBH2q9g6sQ6sNGxZ8SmBCU8A8IXdgN5ytx6nrv024491Civcfj7HH9FPDIRM4gJjuTbG28SD183ZU4dEt1KmjRHNtyo/XceuNkc7URUZsCPAxgN4xpfXOXuRN/ICpQ489zrZCn4PyAtxog10C2Q4qBycIhH+ZIM7vhYwgrQjG3VFq28UzR2ZdIjY5SvhWBw2HTOAAIo4etKRlt37FQEw61eb4sdMcPT7Pe8OLLA+ujcOJt3jFzhLeNYSZ8OzVzEDDFmEKE0KSN7rAzboMeRmCk+gQCHmNe6f9XiZIA6o+xzHOLXjGmIAc8HIGKofLB885cMgEDiJuLT9g99s4A9mDvABy8uXLfPwH73BBbOD9LIijdQnjprZ40+ZrF2wzRngwIHqGo2fh9u0NUCuY/iZ+Y1hfa3N8LJvcf6ZfE0acEYi/YNwz7RmDc/RmBMO+gLVnwU7xYHho74AQ4iUhxGsTrw0hxH8ihPjrQoirE9t/4XEO+BAPAgl0oUqgKAmraQWxgtPz+FPH4PkFaD9MseyxSuBHFTdvrqDVOmZpmqQrQK4TCoVEwHEebr25QGAETbLRiL3jC/YXa6ueY6fP01LPRvDSg+ChJQHv/XvAFwCEEIrQ6eGfAX8J+Fve+7/xOAZ4iEdBbY33q4QVtTXe3IthJg6Gur6A3I9zdCaFATMp8k9my/vxvhLcFcWoWAEM+WpeZwua+p537XZ6DzRhxcHeMP4CdSejZwUGsugaI3s3O8eziccVJ/BzwEfe+4uP6XqHeCxosvYmRekKIgeZgqkUUhVibhSgmn4BJujyfq9Ovo1I3lyz8RBI4DrYplcggANVQrpTvYi5Pzfh2sT4J3sfPEMMALhewMpG/qxZK+4Lj4sJ/HngH0x8/qtCiDeEEL8ixGQt60PsD+pw4OaloN2VxLEIGYKRD4LCjIJkZwTgpLA4oY8bE7obRwZmh5Auhf0yh0XCNTIBSiKyIkgaUjN2DU7f59hT7qOF8b5jBXj9g2eLMd0vHpkJCCFi4E8D/+96098GniOoCteBv7nHeYfNR54aNFvEnEVwNiOdU/ScRfsK0aqg62kftcg56vJge/njJw1zBlIDVQQ6Da7FbgK3DXhIreSVs23mZuqoI29CMVOmCZLA/ZjSc4JbsLFpPIto8VMv/xjf+IlfQjwjWY0PgsfhHfh3gO95728CNH8BhBB/F/gXu5102HzkaaKJslOwEMGiYPnqCqqokFMdWB0idJtWJ6K4aXFVHIqPGkCbWjLQ2y8HQRpYAQoDZJBOQXUplCwjhDdvbIwY2tqY5wE/JHgImtTg+wmvedanx5B/++63WOTZH+lueBxM4C8woQoIIY5NtCD7M4Q+BIfYV0i2uv52ZFiRRyX2wip27Tb4mNb5iJUli11LQnivIPj8GwuhMXWgEGzp500KsfDQ3YDOKtyY8BoAo5Fj2N/Z2GRE0D8ixsFADwatJOahcyieDD6VDUnrhiN/DPinE5v/70KIN4UQbwA/A/xvH+Ueh3gcqN1rqQsztTAht78bQTQCcoYf59j3+1A0yUP1mmbMndmFUG+rwBqYGREd68PtCtwEQXsQW6m1k2JyXr9SHnYd+g9/7hXmOlMPde6TwsLcfo/g4fCofQcGwNyObf/+I43oEE8ADiih7YN4nwPLBdy2YGLCqmxBKMScBWvwA7gjaMhs/Td2DyqgZ6guqzsKnWoFMz3N8hDuFJQbf+TDTcHLS9dZGeysSrS/+P7yfo/g4XAYMfipgQE7hP4ASglrBrSEqQyVR4g4wWpD5wwooVi/Av62BTWpAtTv/aT4XsGKgeEmgWG0CW5Jj5SSNN5pKJMECaBTX+/henfl1bMVn9smML31Z2tY94VDJvBpwqiCtSIU+OwI6EooHSenZ5g5knBhLWdj2eJvjIJhsJkejT1AVOPPTQsxC2w06bQnGIf7CkZFxLtXdoYJR4RiA41k0HguHiyYaHb+DPAmz4IpThCcnudOwL+5tN+jeXAcMoFPE8oSBgPQcU07EcQx3URybD5DL2g+jPqsr5T421FdOdjXJcNhm0uvanL8VZAo4lkYTnYwFnhiPDnbCbVhGLI+v1FHRtzRAfku+NZrb+J3s1XsAzx1wrM6mKnEh5WFPk3wDoYlrI9gMISigJWKcsPQXzKY0jE/p1AzKvQbcHW58W3XYEfAXgFSIjqGINrnEweWWLeTJEpCKPCI7bUDO9zZSXlvXF97dkgtkpJ2krC+pg4cA4BDJvDpgy1Drr+0MCrAe4y1rK2U3LpRoRHIcqI7kK+rBZu6GYnxtedgYrqXOf7WJoEJNAk+AkTE7sJm4yZsWok36+dBJCGYjTOOnzrB+bOnDmCo0CET+BSiziQsCugPURpKY8kHJSsXS9Zv5jg/CoyiIUpbr9imid9vVIHJssSNDaHephXEMdC7+zi2Couu86xmCN4LN/MBF/sbMLVwIJnAoU3gUw2PLUYM85yFboy6UHD9toeqqLuRpYCsbQI7poqkbn3mCa6+GEQGyoGNIEugMihtsbva/JpMwCavYTtaCnJXJyMeALxz4zbv3NirVNqzjUNJ4NOO/oi8KuibEocNdQBHBhCQ5ZANg32gQaMeJITVnoqtBJ9YkczNQtICCdIMiOM+AK1EcGxaT0y4RuVoegtsRycCfRCX1QOIQybwqYcnNzmfLK+S04e4Cit/FAE2EPpUFEKDvQuGQufGRv2JDEWZZrR6MaQZ5A6nHUW9lM/2NK+cyhiHDVjGNoE7cSuH8tmKCv6hxSET+LRDOJz1VP0SHzvoWUg06bwGrZFHe0x/bS5IA1utym1gAFvlABxCRMzOzDFccTD0UAqoNC5vIwRsDh0fLBlcvLN/4Q8HpU9rmInufdyziEMm8GmGCtZ76SWMPOQC2l1opXSmFHpWMftyj1NfnUe0Iog19FJIdND9Y2imkJQRZ0/3KEtJliVABDYGpvBesD6wXN7wlN1JQ+HB9QhMoivgxTnNKwsHkwscGgY/zVAKojqJxxuIu/ReOEN5YxNbBl1/+oiitRAz+/wsZsPSXWyzeQvWV96uE5Ey8BYvRgwSgT7eoYthtL7OzrJiIouQM1PY24+nVmC7kzDo769HoZVMcX5K8cLZHlI5/uDapQPH1g6ZwA81BGGl3q53JzIEDeauwjqJKyS4DizOMX1mnkJq+h/dxpRQpRIrHWe+sgjrjqmZNhcvC9a/824wIOouVB6PY7mniI92cRtNqHDd3hwPQgY7g1AEq+KjE+9sRzHoP/JlHgkeT6ujaXU7OG8PZMjgoTrwKUM7hjSCUye6zMxEYEKyD91pONoBLYnSiDRT6E6CyCKMNNiWIDvSwnQEOddDZyFNCDqSMX6+x2haonqKUgMIhPDESW0JVAofpVizu0vwYeCHD9uJ6fFhVGxw8eYK/eESpRkcOAYAh0zghxzjPnkNjAsL+PJqhSVCah2Mfq0BolXgqpzKOZwQRHMtpEoY9h1rA8NIwmZesLZ8O5QwdxZUAcqhTmgG1YjR1VsM+3m94jucr1d8J0L2YhpD59EF0KMdmJvt3PvApwBjDFmWUO0eEPHM476YQF0w9JYQ4gcT22aFEL8hhPig/jtTbxdCiP+HEOLDutjol57U4A/x4CgMlBaWVnI2VkZ440AqsAU+LymGBd4r+muO0ijKS5rVN4csXV+lKHJGG4Z8ycIwh80c/AjmS2S3wrmc6v0rmMu3QRi895iyzjx0DsraJfgYSvAcX4yZmrr/XIMnib6BS1dW+fa7KwdRELhvSeDvAX9ix7a/Bvym9/4F4DfrzxBqDr5Qv36ZUHj0EM8gbGXwzoUqQ1LBqmHtgxU2bpdUVmAvrrL0bz5k9bcvM7y8xqhf0B/kuJtrIRGpspAJjv7kHGpew9oG9Puh09GZKUSvQ9SuCVU48Dmsr8LmoyvyKwNLb6r1yNd5FGT136GF1y9s8snt/VdPHgb3xQS8979NKCk5iV8E/n79/u8DvzSx/b/3Ad8CpoUQxx7DWA/xhBBFEtHOwED1yTr5jSEzp6YQg4ri+jLmZh9ul9y6tMrSlVsQF9CKoJPAlKD9fBenJKzWzUZ8GvSOTheZ1KQigUiGoKPq0cXmtQ1LzGBfY/U1MCfhbApnZ+FMds9Tnkk8ik3gyERB0RvAkfr9CbY3Z71Sbzvg+GGNYU2Zm5umdW4x1AWwBXFXceTzU3TPTyNmWqGM+CBn8MEy5cWl8Chms2BhNAVDV2GmCZGFx2YgS2GjQOFpd+rOwkIG4l8ZPZZRz8+m9KL9bfk1BDotOHMEXn1+hm/+yLEDOUsei4vQe+8ftGy4EOKXCerCAcEB1PZkAiIBe7cSXhKlIpx1sDaEjqJ3IiU72+LF+bNc/61brC8VSCHRqWBoFKbTxowKoIC1Ebevr+GPWrgtYCpCJhmtVsZoOMCZOq/AWNjIgzHxMWBm7jgfXNvY11/FEhIrpYS0kzFYO5hFBh+FCdxsyovX4v6tevtV4NTEcSfrbdtw2HfgKcA57l22S2G8xtmQGDT18gxTR9t47YlPt4gX2sRrJQtHZ+ivD+gz4Mgrs1x74ybeWsgd1Xof1vvw3hIse3wmsZnCb1gq17gD/WNjAAA/eP8K2u2/Nf5mAWtX4L2lWxyLzUFcKh5JHfhV4C/W7/8i8M8ntv8HtZfgx4D1CbXhEE8VFaF4x06IEC0kFSQxqxsjqk9WwJZ0z0yRpgkW6HtQsxlRN2X6+VkK6/B40iMJOlVQjcDk8NFtWB7A6giWV/DXbpH/4Cb+5irl+pOJ5vniiwv83JdOc7K1v6G6xoOuYD41fLK2r0N5aNyXJCCE+AfATwPzQogrwH8J/F+BfyyE+MvAReDP1Yf/GvALwIcEtekvPeYxH+KBMLE2JTp8lBrmUlgfgo8p14ZQ3ICZWVIiXCEp+xZ0AZlGz0SUXYlPPNVSQbEp0N2IynhoK5gR4Eu4tREKADgTepniqcyDNxa5H/zo177ObLTO62/tbw/cxRheOA5femme7752m9+/ee9znjXcFxPw3v+FPXb93C7HeuA/fpRBHeIJoajF52kJUwqGEvoV+E0wA/BzlIWAyrLx0QadlzJKIvRiio8EeWSgqrh+8Qa+qIOAjk2H7uOX8okKIBMtxH3Ek6gY9Nqbb/HNz8+FRqf7gpRUFsx2PAszgqOLi7zw/JA/uDk8cCrBYe7ApxHrJWyshAIhol13E/KgDEZ7quUBy9evY6aPELXatOMUa3NG5DCqsDcHofdAnsNHOVzIwe2lWT6ZVOHf/c57dPxRzpyAC588kVvcAzlH5iK0qSgHHiEcVXUwy6MdMoFPIzzj1mJ+wLjWHygKcl/iVzbw+SxTRxXRegRVjru+GXoXDDVb9ga3UtP5bsTeVA96/JifnieKYm7tYxOiTpbSqUKtxdu3c3yZEnouHCwc5g586pETugRbGBZYV7G+3sdtbGCuD9FKIzRcX+3DRhlW/2ursLJJYASau6/2T0Y4FlHEqdOnH6KV6ePDYDAgN57+CFZWPFofzJi4QyZwCEKhUAVFwcaojylLqDy5zzEYKmFYXd2A0QgYBVVgtL/uuaUbSxTW8Jnn9q8p6cVlh3VwZGGRhYUzzMweOZAxZYfqwCEIqoCGUtC/0YciBmOobhuqWxWqkiReM+xk9aJfQTEKfyn3ZcTdpMPqretEev+m8ImWIMk8P/jgFt/6/i1u+QMZUnbIBA4B4+7AI/id2xBPQ9mGDwSfXL3OsW7EL710nKmvz7CUG67dXOH3X/8jgr5/lEgtUNkVxjFhdQnyXWMUHg/SmS5pt8t6f2evw6cDAZjcs3odrtiD2jEh4FAdOESNhFA5tKzL/Kb8X/5P/ztePHWO9duW1ZUR3SyDCjY3gyogxRT//L/5L/n5H/0CoY0YBPLI0PLJxvVfu3GRf/mv3iBJF57offaCBwoH09NwXMNZQmjsQcShJHAIwjSYbDCiQXX4N7/7Gpv9AtIu7/czbry3FDqLtVoIMQfk/Mvffo3VzckVXyJkTNpp0994cs04fuSFL+IGH/D+e+88sXvcHRFnjh/jxZMxq+sFbZ1SjHKufnz5wKkEh0zgENyhycqE6ORJXr+0Sm/2BL2jMbdvbXLmpZN89eUzjIzhuc9+llsrI3738k0uXV9j7ArMkCKl3U7p3y1v6RGhNXztx77CG3/4XYJ342mjYunGJeaiDO2PkM3MIKKC7Qm0BwOHTOAQBI22kQQKcBeZTo6T2BGRnmFu8QReLdOePkY2d5pB33DkhZO0NjZYnr3KbZOxsfwWeEUovVlhTFNg48lU3rRCI5OEz778dX7v6r967Ne/H1x1kK2OePlMzMxsl/X+YcnxQxxolGyZiGSHqd4cx+OKwq3zuc9/liTNOL/YZXqmy3ETUVUVq6urXFs8zvSxs/xr22fpvd/Cu5vgLD5veg0mjNuVPz6kWca777zNO+/sb7D+hxuwsPwBLx7r0EnVvo7lYXFoGDwEIEBOIbVCRedY+MK/y+zZL3Huhec5fuIkU70p5ue69FoRG7nAiAgrBFm3y+zsLIuLR/l3//Sf58wrPwfM43zOyuYtavPZExnxt777B0hvWTb7F68gCP0SV255Ll55lzy/dhDDBA4lgUNIQNM++TMcOf4Cc8eO8uLLr3J04SiZy0m6U3RnZjgzKxA6JTIpeEWVacwoR0rB2tIqIko5/txLfPLOH4FrVmfFXr0GH3nU0vKdt6/zEy8t8ltv74c0IDguWiz0IJYD0iyi3bEHzigIh0zgU4yM0Dr4CChH0pnh9Euf40s/8gXmZqeIkwgBzE13me6lPDcDVwuBMgJjwKAh7TDl2wzW13ntjcvcunoRpRzINs5rPMfAfsy43djjW7VnphY52R4SyyfDZO6NFgu9WbJoQBaN0CrFys6BbD5yyAQ+NWjqfJcI3UNFZ5DxWZg6Qjo3y0uf+SKnzz2PVzGDwuOlRzhHf2iZT/tcXxJs0MZLF0jaeKz3KATdbhtbWo4eP0Ws/jij0YD1tdsMR0PcqIPH4X2JGb7N48oqXF69wZfPnyW1+1Xhd4jTx5EoEq3xtIl7x5F8xEGTBw6ZwA8tBEEcr1dfkQAxQua0T36ZhTM/Rac9RxwrTpw8wfHjp+h1OsRphPQVkZAorZluR8ymIz5ek/SrIaYosHiMsfiqwitFWZZMzy9gsTz30o9w4f03SK4aZHKUfDCiKEaYfJObn3xMqDPzeL5fJCS3bt14TNd7UHguLF/jlVMnyaZ6RO0ZVNIiRjD6YWMCQohfAf4kcMt7/9l6238D/CmCSfkj4C9579eEEGeBd4D36tO/5b3/K09i4Ie4B0QP5AzYq4BFtY7T6jxP0omZPXGGxcVZjhw9xclTJ+hNT6FFhBAepSCJErRSjKqS1K9zYQlubDoqaxAeNAIrwOQ5lfeMRiO01mxu9nGl5eMP3+LK27/KbgQvVYLSbawZ4eyjhBX70BtBSParvfkmA759+T2WVlOO5UfQ1x0jvz9jeRQI7+/OtYQQ3wT6hF4CDRP448Bvee+NEOL/BuC9/z/UTOBfNMfd9yAOC40+BgQffSAIiUhOEU99Hpl/jGfE7NHPc/alr9HtzZG2u7zy6mc4d+4MaRYjgSK3jEY5xhR4KXHGMcoHvDIvWerDrVyC9wQnWITWYJ3DVhV5njOsSi689z6DQZ+iv86b3/otrHsPAVgXmpxEUUq7d5zu9Mus3X6f5Rvfw5QPH+gznwrOTGd898bjki4eHprdmr49c/iu9/4rOzfeUxLw3v92TdyT2yajM74F/NlHHt4hHhCCEOtfJ/7QAtkCdwNwKNGn13FER78IMmJ6+jiGhKw3w5e+8mWee+40rZZC4nCVQ6BxziKEw1iBFQUnp0pW7AyjKCLDIrxDK4lQmlgDWoGxWGuorKGdaN58403SRPPjv/A/pzQ5Ekde9TFlxXRnERVrIilZX3+JC+/McO3Sd8kHS/AQun1uJSKb5vGpGA+GpuezBE60wHnNpX1OsX4YPA6bwP8S+EcTn88JIb4PbAD/hff+d3Y76eD1HXiW0AE9TZydQsmM0fq3QFSgZ6EMOrIp+ixdeQcRnUa1F7B+yPMvfZavffUrzC/MkQ8LyiEI4fHWkpeWsigRUqAjRStN+enTJe9sJqy5Nt6F7VkaEWeCWIEX4ExoUFwZKM8cJxKaN17/Hr3eFHErRQuBFw5jLM44jLUYU4IQPP/qzxBPn+PyR3/A8Pab+OrBqvI8P5fx2oVrT+IB3xdOTvfIfIEpSl45nYHrcvn9mwfMIvCITEAI8X8kWJ7+h3rTdeC0935ZCPFl4H8SQrzqvb8jivyw78DDog3xc2TTL9Ge7uHskNG6A19A+QEgQfVQvefx4iSMKqa7M3zuc6/y0ovPIbH0N9aItCaJY7J2QtKK6SoJvhVEfq1INRTxaWRrjikB1lqEtThfhJoipcNUjsp4XAmmgmFZ4ZXn+q3bCBHR0xKiCOHBexHUh7IMDMFBFKWcOnGOJM24/nHG6q0PqIZL4O4vwKjdiellkpXR/ujhr55aYEbnjPpDprqzDEwMHLxyww/NBIQQ/yHBYPhzdYVhvPd1Wxrw3n9XCPER8CLwnUcf6qcVwaofHmsPsKAHaHGdfKOkv/YxkINIEe1XUdog1DwiOUosJcfOLfDKF7/I88+dpxUnaCloZRntdotOK6XdVURx6BKGCXqtkOArwxs32lS+oCgMRRlWvMbqYCuDcRVlacA5vHXktmRzfYOiNHz4yQVOFEeJ04Q0TpBSUJQj8v4GUgqE1KhIEYuIhZkZ8tnTDAeeVnuR4dr7VMW9+xVYD68eSfmdT/ZHHVhdX6LTm2VmapE4yRipg7mWPRQTEEL8CeB/D/yU9344sX0BWPHeWyHEeUJn4o8fy0g/VZgCmgqaGujVQSgZ8CEMV9kcfoLo/BS9ToeNvIfQU8SLX0NSYjdX0Nbyymde4XNf/BLHTxwjy1KyNCHNMuIkQccaL6CsgpXdGUdVWipjONNeY2PguHmjAp2AczgfSmkJ5yicCy3HvcNUFmcMzlUMjcEYx8KRI7zx5pt4KZjqtEmzlEgq1teXuH71HVyxQtReQPgOSdohSRKWr39AsXyBEy/+BALJ+tKb+HtIBKNRybGphP2yCRSjiiqR+CiishGtTvrDGSy0R+OR/4ywRP2GEALGrsBvAv9nIURFWDD+ivd+ZzfjQ9wVPeAYwaTiCdVrPdAGVseHCYFuT9OeO89gBA4F6zcwvk/WmuWFV7/AZz73Kr1eD+c9zjmKoiSvDHI4IIljkiQhihKiSCGcp6wqYgrO9N7l+8M5RkWMFhLlBc45vHdY4zDOMipKhHN46XE4qspR5iUOydHFRW4eWWB1eZleKwNnKcyIWzfe5fpHv0NlCuKZFyg3BqTpNHML57GFxZh1bt94A2cl91OsL1IRWbzjuTwlxIAWkuneFDNT00S9hFv9gznV78c7sFvjkf9uj2P/CfBPHnVQnz6kBBtzs6KtsH05GYIfAjNAD2RC3Juj3ZujNAIvp/DVdeym49jzL3D6pS9x7txZtI5Y7/fp5wVJHKGURkaSWGuyNCZLg1SQJBFKKITwZJlg3c6wXE2FPgT16m6cw+Ggqr3y1lKYkspajDHYCoyzeO9ptVNOnzrB0o1bGOvCNWyFcQAJVAZXDnCJYzj4BDu8gi/6IKbpr1zhflf2q+s5dh/d8sO8orLrSB0TaRiNNg6cFACHEYPPBtRZUBmU7zKWAI4AKWQdqIZgLtDtvUTv2IsonRH3pjDWcfODN3GDD4g7J3j+s1/jxNmXmZubI4oirLUUlUUai3WOKPZEXiHwRFZhrcV5h3MOHUfEscJHEe9tprhI0O3kOBtUBE0wDqLAWYcU4HJDZWomYIJE4H2ottlutUjaGcsbG3SrDOEdnd5pjpxPuf3J9+mvXYb2LBjPaHSFIPGcRHVfxuUf4qt7VyS5vjHi5saTq2N4N5TAzc2SW8vXaccWoebQWfbDqQ4c4nFCE3p2WYJvv0cyc47W1It4LymGPUabS0TZNE5E2MEa8dQ5jszOcO3tJbAlx869hBKC6zdvsXb1Dyk2ljj63Od58dWf5cwLYfWPlEZohXceGRkEkiiKiOIIJSVSSKx1GGsQZYE3hsoYilIxQOCcxxFch1JKkJIIhUKAAKcd1od9kZZ4NENXYYqSKM1QcUSr45jqdXjvrXfpTc0yNd2mytfJi1XiqRlSLTHWY0yfcWLRMlKcwMvzqB7YwSd4u87dqGo/4/MUEOmMrJWgFLzz1lXuEXv3TOKQCTw1LEJyDMwNsKvADNniF+nNn6bYXKHcXKZz9CXyYYQrbuKpiOcWOHL8BEfmjqPVn0QQgRB89NY7rC1/D3yPr/7sn+H8Kz/GyeMnSVoxOFBa4IXEVCVFaXDWIoVECIlUAu8FVWmoSoPUEi2DKuBcrfPXxO8QxFoQRRqtIpQSKBQoqKoSHEgpUDpCCYtAIJ3EOA9CcXTxKBff+5D169dodZ7DoBkUBcXGJXy+ibOufhZNoNAQ03+H1tSXmDr6HLc/SShHr/Gs1vI1wNCMcHLIRn+TG5dv7feQHgqHTOCpIAamwfTBDYAFiI/jfUTev0J/vU+cziGjjCPnnkfZI4Aj7s3T7c7hgOljr7CytsaH3/tN1pcvcvbVb/CFL36Tcy88z/T0NEppvASMQ6oQyzYyDiEt3kBZVVTWYq3FO4evjX1KB8mgk1Q46xmWCus8WSvBCwVVOE5EAkGI0y8rizUG56C0hrws8c7RarVJW22kgjKKWVw4wnPPv8D3/+APyIuKo8dPk6QRV1Y+YdS/suMZZYDBu3XK4TusX7+JKVfYnn58BIgIpc33f8mtPPRHIyq7SRxJDmZdoUMm8JRggKtgS4Iq4MFIik2Jihfozp+j1Z4j67VJIo2zCyE4RwuGecFouMHGxY8oyu9TDbr86B/7s7z8I99gcWEOrTVFVWHzHGMt1jiE9CgdYYyhsg5XWZyzVFVgAg7wzgECIQVZ6vipkxf5eHWOC/05pI7odNtEOg7Vc5SuDYcWCzhTgRVYLDiPyQ0OgRTgrUFIhY4i0k6bI6dOkL09zeDGdfSpk5w8+wLa5Vx+a5P+6qT3uHEoJVSFpyousL1vgSDYS54nuE/3p9/AJCwQSbDWINNon9qwPDoOmcBTgWPcqPIoMAuyx9SRc7Sm5li5+AGusswuvIJWGq/BVBXDcsi1i1ewa9/BDG9A/Bm+9sd+nnMvfxYZaW6trOBNMNh57/FC4kxokJkkIUDHe0/txsV7gVAC6QEkUkGSKF49ss7njm3w8eAYSZYipQxFyJ0BFEqHe1gMHoilQkYSrT1pFhFpTV6UwU1YFFQ22A5whqyVcvzEUT568/usLC9z5uxZprvfJJKSD777TxkNLtXPpVnxK2Ct/jsJT2AKT65k2YOiAAY5rC6NMOZJtlp5sjhkAo8EQRBP72cNyKD9EiI9id94A8wV+jcr7FqXYvN1RPvn2NgskGqAUgpjPDfeeoNi9Idg+xz73F/k/MufJ9KasrAoXVEaSytpkXVaQQqwFq8j8tGQq1evMSqHlGUFXqC1oNVuMzM3x+zsPHhBMRyCrfjqwg1u9me4nWeMqtBkdDQaYL1BoWuDosLj0RpMLWUorcFCFEWARwqDcxalJN6Dl4JEJczPL3IhabPyycesPfccJ06e4vTLX2FlZZUrb/96nfTUwHF3Iv9ol+c9BcwSXKtPr02xBo4dOYfyQ4rccWZ6xJurBy+V+JAJPBQEYTU/C2kMw2vANcb+oZ2rmAKOwCjFFzeDMcxv4vN3GbpzxEe+ju4uMhjlCCo21lZxy9/DjC4CHaae+7O0pha5evUGrii50b1BlmW89MrnEDqmqCymKrC1Qa8yhs1Bn+s3rjIaDlFaESlJkqYsL9/k5JnzzMzMgjCcnhXMdFv82kcZK4VByYR2t4PzgnwwoMgLin6JEAKlFCICLXJM5RGi7mGowBuDMT4wCkHoZVgZYqU4duwoL738Au+89hofvvMucZyQZj0+85WfgfIaV95/kMIgO9fb0zDzMqy+Rch4f3o+OgccPX2czxzrolqe5eJ3+cHq4BmwVjwYDpnAA0EAc8AJUC3k9CJaKUrZhX6PMAlHwDLbGYEFroYVz7mtfU4uMH3qi0zPH0HFCeWw5NrbP8CUYfWHl0hPvcpgAMMLH5NELdrthFE5ZGp6mijSKA1VXlKWJdYK4lgxMzdHZ2oKpRXr6ysUVUkxGlKVJZsblo8/epdWmpGmMa90u/z+pS7fvzpkNe/Tbs8SZYpONo9wHmssxvuQMis9SEVpbKAAJcA6TGHI8xHGBGkkTRMAlJR46Wh3Uo6cOsEHH3zA0oUPubVwlPMvvUh3epak+zLINyaKkzY4SpieN7h7bUIDZkCQHmz9Gz0f4itGrz38T30PHE9hvYDbyxfJFxZZub7KmxcOWk2hgEMm8CAQM8jeV8haXXJj6U3PIKVmGLUYOQ/Di8AtApFLQqhv05gzBWZAL0KkEa5g8fxnmT9ymjTN2BwOufHO72FG3wZypl/49xgMSspCoLylKnKibgJaYY1hZXmZP/r279NOO3gZUnXjKKbb6SKUCOK6Urz8yueZmZlhY2OVjfUVnIAkyki1BuV4f83xcZ5gozbTccxUex43MqxtLlFVFVJKEq3RWlBYg7Z1OK8GjAUUVVVRlSOqUIGUUjQhvxZvHKUt0HHKsePHWLpxA7TCW0cSZ7z05W/Smz/Kx9//h6zfenPrUc9On2T2hZ/g1soSmxc/wJsPCbYC2L7S34D+bQKjkMDxsM1/GWZ+ClZ/nzsls0fHzQKch3c/uEY0usn6muOod1x/7Hd68jhkAveFU0AF/jZu40OGmyVeJmzal+jNzNPptbFmipJzIM+B8mAc5BXYjwi66giYRnXmac/M0+lktLtdRqMRH739LtX6b2CLDSAlWvxTOJuitQJfT+Aq6OMYA3U1nyvDIUJIlJIUZUkUpcRpRKw13Zkpjhw7ysz8LDO9aQQCJWKQkEQRWoaWEyqW6DglkyGAqBwU5KMR3vta/BfBo+DqFENNWHyNAVNhfEV/s09lKowHUxh0nY4oLEilsCh00mHx1HMs547BYJO1tRWiKEFHipljJ0k+/Aos3QC/BMDa+uusv/YeUyd+ntOf+wZO/ih5MWLQ7zO8cQXyVUL6SgFiGoQGt0qobmeg+DYi/Xl895uw+Q5BXXt8sDUfWhs4UuFozUBsQRTPgvPywXDIBO5AiyCKdgn6roakB8PbhBXm4xAa6wRmfZU1901U2qIalsFxnKboLCMK9beo1q9jhvW00F2sixiVBrMx5NbVm7jN7+LM9VAPgJegdxaSNlAhNGhf67hpClqjtabyoYS3cxbvC/ICHMEeIERMu93i6OJRTp06Ryttsba+zmA4wHtIpCbWGqUU4BDW4YsKKwSFLZDeB7EfAFPXy4rwPhQtNXWzD+8rjA/vlZKhxLip8MqgnMbYutxWVVE6R5qmHD11ivWVFW5++BGttIVSgrIs6ff7DFUG6SKMVgGD8xVUFauXfpW1yxJEhPca7w24PPxG8VEQdacjYxAM8JjwmZdBRwjVxcfPQ6l4En0C+8CggJMLgpHTcPvxSx1PGodM4A4MgQuEiXQU7AIMc8ZRbY31NwF7DtfPccMBlFcIfuyTGHUUnwiUlLjWq+COgJUQ9VCtFCUl+Y0PcMXrBNfhIkc++4vMLhxBOMX62hqbo01SgpBrKkAYtBBorUkBOl3AoEUwzCU6ZfH4cY4cPcqpU2c5eeoMcZyQ50PWV9eRXmJMhXMhGQjvkbHCeYk3BaDw1mO8RycKnIUKLAYd1QOpid7U00brUFmvk0WYSjPKoQjrPmgP3lJWDlsM2RgMMNZQ5kNWbt9kZuMU83Oz3Lxxg6Ic4csCIV/EkwC3CWqUxbsreCaffwMJ1oIdEFb5pZoBAByBeG7re5F1geegnCZktj9YBaO7oQRGFRgRcWNQHjgpAA6ZwB5ommVcgz21vBJ4F8x3J86ZARUhY42UEuscTihozRNM6B67uoot3wTfGLy+wAs//u9w7vzzPPfSS7Sn2lz+4AL/9nf/DRvr62ggzVIYVQitIRIIC1kWIUSLOFEYA+fOnePrP/ENZmYXQElSHeG8B1LEnCTrthlsbDAajXDOIYXAG4urKpASBLRaCVVlcdZgjUGhUDo02TTeBFVE6y1iiyINHjwRIjLoTCP6Aq1U7S0QSCmoKklVGSyChdNnMdUAu3aJ1rnTzMxP0d8QZFlCq5UwymexpqLM8xDRyJcweQGDJUJIJMAPgEtblZS3C+AJsAi121IgIIrxRKE2gpkFcxPcu49lpgD87lVYWS55Y79aIDwiDpnAFs5A+2WybpfcGPxoBIMNAiO4uMvxjnHUWgIcB32EpHeM9uw0W66quiL2YDiguPU+FG8ThEhIj/xpzr/0RRaOH2f+6FE60x1ilTAcDtFa082yoAIAUdSj2+2ysLiIzjK0VuSjnFgq5haOcvr8ebLuFNZWVKOCSsV478nznH6/TzEagbco6cE5lFaoREESgl2tDZK1UhrvQWmPRoeIwXoMJoJtU6YKzEBEmkyneA9CSLRXVNZQuRI3HBJHEXiPKC1xmjE3f5Lvf//7DNQPmJ7qolBIJSG1ZGk0dkcKwdL1K/TtiN7pc8i4Rb/fp1ydg/x1dhfvC+AGkT6CMdQMSyOkQHQ6ZNkCcXyOYvASw6W3ofrgoWfM1h09vDY6eLaABvdTcny3vgN/HfhfAUv1Yf+59/7X6n3/GfCXCSz6f+29//V7DmJfagxmwCIwC6oHOoOsbi1tTG1QrqBYJwSo7CwYIQj5/SfCcfQDE5h9gfbsNE6AqxzOVOTDPmbtB1B+TJikJzjx6i8wd+I8vXaHVisjiiKybpc0islNhfcerTVRFNp+ee/DMVlQA6rRCFurBwBCCCKtUYGS65ReT1QbAJ0zhIRAiRCQtVooCVVlkD6wtAobcgWNhfr+iC1dIDya5vkQTCDGmEBmEWjvKawllglFYXC2ZLixQX/QZ1RWjPICqRO8c7z7/d9ECsfcmS+xvrKKKQvAoZQijSJkJEBoPrlwmfz6PwfbJ5v7GWYWz2CFZGl1E3f9B8Db9/FbN41YpomyL3DkuXNoneCpWF16m42rv8uDknCHYD1aqs98Efjgga/y1PFwJceBvwf8P4H/fsf2v+W9/xuTG4QQnwH+PPAqwVfz/xNCvOi9fwbLsXcI0X4WrKkrdxu23EnFCvAaeyeregJjaJhDD8RZXJRC1EY5w2i0QnH7AhRvsVX9Jv0a5179CRaPnqDVThAyCq1tgSrPGfWDlKBTTRZ1yaIME8Hm5ibCWnJr0WlKbgyiFs8RAqU1o6pC18xAaI3HYZxHqYhOOyVJEpAQRzGxjjBlhVUm2BSiBKljkihEJI6qHOU9OkoRGDY3NwFNhKFCYICIKljlKwOVZ1RVDPp9EqWpjMHicdYG6UBHaOXJRzleeFqtY1z46BLxzIgoyRgWIyKhUHGKTmOUEBSFpbtwnHLwp3Brv8po+bcYLc8SzT9HkrUZbbP4f57ghr1FkN4mowqbPogDhKiIs5QsjsmyaRaP/DTX5p7j6ge/C6MP73v2aOClHjzvYDSCTgofPD5Tw1PFQ/UduAt+EfiHdcHRC0KID4GvAX/w8EN8UmiMSLXPq9gEIkgyiDSweJ8h6jFEz8HsF0m6PWanp8iShJVbNymWX4OidlmhmT3zxzl59kvMzM+jotq4pkICyrhdWFjdhQFjRmxuGkxlMKZC64iKIBU0qzFCBEagFJQlKklCsVDnwFuEligFzjlcZVBKYoWlsC4ELimNkgKtIpwQob1YvfIbY8jzTXQablVhtlQAgFFTY99UVB6qqgo2B6WDSmU8lasoigLvg189TmN0EnHixVfob17Gjz5h4fmvk6QJxXAT6yxFnpMkCa12ghYgTs5zO/4zuKXvgnuX6vYfbff8T//P6M0uMtowVPkc6M8hUo1fLaG4DLwBgFKK+YUF5mdn0UohVUSkY86eipnpzXL1o++wev073E9lozVgdQPOnYCp43B7lcdpb3yqeBSbwF8VQvwHhErC/6n3fpUgG39r4pgr9bY7sP99B1YJP+XnIVmAbo+s2yXr9ciioBasLB9jdOHvs10akIQagLOAQvfO0zt3inJznf7lC1y/CtghlO8RViWAc5x85ac5dvo8adYiSmJMZYLhSyk0tVgvDN1Ot/Z4NQQ2IssyQIMx9XEibNNjXuCNQYhgD/PeY41BK0gjjYg0UZzgBJSVQVYGSSAKKQ0ya4W6gZubCBHiApRSRJHGmAKM39KOQvIAVNUITMWoZlBUhrLyjEY5Ku3gK09uLNZ7cmOIZEzazuhNTdHt9bh29TLODbh88TpTxz9Pt9tl9fZtBpt90izCOxeae8SKuW5KlUesVS/gV6fqUmspdGZpLc6w2O3h0TC6SnX7e8A6XnyB7Mg5RqvHofgE2MDZgvz2e9jBKVR3BqxDaIeWEa1Wl+PnvwzxHKvXvg3V1XvOoD4w6kMvhtH+JzU+NB6WCfxt4L8iyFn/FfA3CU1I7hvPRt8BD7wOxetQwOh2i5H6GrOf/SJmVJHnDtRPg/2tiXMcIZ/9KpBgNgpWXv+A4NbKCGJok++uiee+wrHzP87iwkKwpkuBNSXSQ6wVaZoSxTECi0Zv1dfUWhMhIMvQOgqSQBN/AFAb8Uyeg1Yo5Wm1enRbrZDi6x04j4o0sVLBNWhtkAgQJEmC1gpTluSDAUMhMNYgvQ+hARXo2tpdVYEpVR6oTGhNPhpRGTDVKMg5WkNZBgZBhRUWrRXOeLRKgmFQSrTWtFotTpw4wdHzP87Kt/4ZK1e+w9yZH8UrTVGVWEKtgjy3pJnGWUuSJMzOzFB1UgwKEKRpSq/Xo5tljCqg6+F6HX7sv41dNnSPPM/m0quI4lt4KjaLCyx98hbJ4vOhGnJvikhqrHWsr6+zvrQE6jQID+XuAUad+tcVBALKsvC6w4t5QPBQTMB7vxXoLYT4u8C/qD9eJYTXNThZb3sGIIB5wvDeYffEzyEQxOg0lXgXs2k32DsppaivJQn66CZbSSxinpmjP8qxc5+lM9UlSWOEA6zDIoIerwLxCGtBaXSkEY1T3kCWZegsJcsyqlEeXIQEE4Lx4PGIbqhrJ6OITpoSa4nU0dYk9UCsNUfSNY7ry3yw2uaD1Q7COYxWVEWJ1AKpdCgoaiqqymxZ56FWmIzBhPUWAyFCsDJb76uqwhnPyFeQ61piAak1CaEfobUlRe36m5md56tf+3GK5fd5/+23UelpZmZ7mMEQ7w1SCCyB4TgbTErh62u6aQoIRKRJtUZnmkxroqwCvgx8F3AY+ybH4vNMnX8Js6K4cfP3qEyfy1d+H3XtI4y7Qqv7EsfPfZmk3aNY+wg3/DZQEfU+h9dtzPAik/aFWlGkAmYTWFyAXhYTifIglhcEHr7vwDHvfeNA/zMExy3ArwL/oxDivyUYBl8Avv3Io7z/ke3xNwHOhC69rgIWCJrKLkY/+x4rbzR8yyDYxG/7aSfLYTf5AYqQNAQIhcyeY+7UNzh1+hTttIuONJFWCCm3rmKxSClq31zI39e1QQ+hIYK0GxiAJoIMUh1hMKQ6xZgKYyxktXfACZSSlFWJqyyRjJFKkFclMhW8eOR1zrUucXH1K+TDiKHdRMcx3oLEo7VCRDpUB85zKhWMeVGmaRqQBrOFJ6U2n0YaXwWpYFQZPB5TWGwsSNIUZx0pEqMropqQTZ5z+8YNpmZn6fV6zJ35Cuqj7zHaeI/O9E+QtdvkeWAEKpRKQumQKGV1SmRSdBrUtSzSZFkECKLIMtMSbB5/ifL6+yFL01UUN9/l5Bd/FrfwdXxuuLn+bTx9jAsG2OHmGyxdGXHiuZ9FRXMQfz70VbMtWrPnKLsvUq59F1fcAhyGwOqPAdNJRIogTReZ6faRK2v7WvPwYfGwfQd+WgjxBQLj+wT4jwC8928JIf4xwW9jgP/4yXkGJolRE4S0aaBup+M7IEPN+6D/X6wDRO7Fq28y2UpqfLQEkSDUCxCfwksHpoT8MvB+GIvoMXXky5z+zI8zPztLlmRIqUBJlJAhtFeFuP2tkccJSIcmwXiLNhDpKHy1CnyqqPChaIj2JCRU3mM8CK1ItQpdgYQglorCOcrCULgRzlkiKZlPlznq3uP9qx3eu51gTeg5iJCgPN75cT2C4I8MLzSMDDkGhacJHRzVeQKVqcBrvA4eAqE1aZqSaI0QgiRNEBbKUYEpCqIoGB/7GxtUxtDudjl6/DjHjp/kynt/wM3rQ0S2wHSvTTEY4YWn3WkTxyFvQnmNbmuyKEMIQZppsiwj0lFIYUZjF+e4Zb5BvvQbWG+4NXqH9MpRFs9/lekXf4xbr43w1evjn1skCD2F1TFRb4b49puUmx9QVQpTnePEcz9K++QvceXD32Ow/gGQswQsEnF9o0JrQW+2w0a5ScLd8x2fVdyPd+C++w7Ux//XwH/9KIPaG1taGEH8VgRmkBHq8Xcha4fIMFvC6BLwIY9c80VkCP0icu4zzC7MYEclG0sXMf2PCSHGEqmPMrXw47zwxR9hYWGRRCdoHSIHUbLux+fGYrYHg0chsEbhlcHmpg63BbRGVRXVyio60pjKUFVhVW40UgFUQqNV2NL3waLvrAUbcgBaLcXzR6/Qmba8f/ks60Mw3qFs6CgcpzFVZTBViZKKoTFBMkgS0FAZjzGWoR8h6ukSogEr+pWpW5d5jKnq5iQG4z1UFaYqMSZHOE+71aKVJBhn6A/7DNdXGK6toeKY6RM/ydKNyxTrl/FG4VoxURrVDVMsZdkPd9aa1AdVI9UZSimUVCitMLkhjTQLi7Ok2csMM8Oli/8a5youXf5tRlXEqBriq7e2zafOzDkWTn+VYjBi5doVyn5j4rdMz8+zuHiMLE2J45/k47emGWy8BmzyVu2feHvF8+vffnzRh/uBAxQx2OjdCWHVjwEFIgHRBtGBOIVIwGhpu2/+gVEzGxmhohQ5/fNMLSxQ5ENWr13GLH8CvAkIhEhoTZ9l8dzPMzc3x3RvmizN0HLi0VqHVApXl/uyxlK5ClNWKBlWzcblVXkH+QiUxtReioYJMII0SrHGIiJNoiMqFN6HMF/rQEeSKElRiUYryanZNZ4/eYmLGwkX1mZRUoIQOFfhpMJ5cMbgnaewFZWpiOOEIg+uSQTBg2oCkVljCBEAAmEFHo/FIoRAuOBeFLZASkGSaIhaSClC9WJT4ZwlloIo0QgBoyJndqrL9PQ8N9ffgWKK/kqE1xFeBANmHMdYBEpYTCHIoxHVqKKqIkajnG63gxQCFKQqRSqJ9i/RuXmbzfz7OJtz8+r/584ZFc3i1TGufvg9hmvvMU5VDnDFgHK4ThzFpEmbE2df4PJFSdF/HWf7HMx1/04840ygEfkjgu49AyIDkYZINtkKfn2tQyfb4RKMLhAs9Q+jnalwLzGN1M+hj5/n5KmzRGnCaH2NzevvYZbfItgTJDJaYGbh6zz3ha/RyVIcjjRJ0VIHK7xzIENZbm88pbVYUwVCqgxVVRLXzTqblX0cJ2AxtdoghKCoc/WFLUJZr8pglAJrQn0PKYhkkDBcVYKVZKng5NxHHG0v8+a7X2DDtACHryq8cxhXkg9zXG1ktIXFeoOUCmcNlYGoLkYaxzGRlsRxDEBeGSIh6uBKEaIXhcC6oBJEOgqE7yxRnGDxeCHQWqJbCb62j7QKQztLWDn1DVZvX6McrOHKDkL3UFKFeoe1nUTX5XyryrK+uUqyIUg6KaP+Gt3uNJgKnaVsbgxZvnEFkUZ7WOxD4pOrVhgs/TZ1qiSIiCjqgJSYcpP15TdRznDkxGeZPXKa2YV5dCtl5dYiy1ffrouh7k8fxMeJZ5AJyPrV6PkJ0AU1BWoa0WrjtQpBMs5A1YfBjdqve4tH484nIXoO1Z2ld/Qoi4vzRGnK2q1r3Pj4dczaHxI6AEfE7RMsnP8FPvvKZ4iTEHlYVBVOuC0GYJ0DBwaHd47S2GAlNyFwpyhyrHXISKBlhESgmyAirUCpoPAoiax8qN3pHM6FKEfrLVGcokRYaWUUUeU5RVGghOBIssbznQ9476bmDz6aob8x2Oot4HyoNux9HWbsDM7YUEvQhXoIUit0HJGlKVpHWKFJ0jrAsrDYKg/5CUZDZIiTUFFIRhGJ1jjvKaoC4SCNInyqUVKTxEloWebAZZZWJ+NzX/w8m7df59J7bxAlkLYyknYHISTee6qqpKgcQkqESNi4ehVXvk/TxCXNFkEUqCShGOSY8gcTv6smMHgFIgYW6liDm1vzRciI9tTLnDz/k6i0y/ULv836rddZWX2X4eolNm68wOzJF+lMnUIePY5WKbeuzVAO3wA/YIuRHEA8Q0wg1MoPRSNTgp7fAmoDX7uHiFuoLA0C6NoKbF4mZPmtE9x1j+igkc8RnTzH1PQ0qYrYWL5J3r/B6pVLUH0XEAg1S3f6LMdf+FlOnz5JkoVwOmscVVlhbWjT7SbmhKh9R9Y5rHdUeUFZlhRVTmktkVVEsSBWGulrI6A3+KrCCEFVVRhjQqQgFYiQ4gsC4TaRWhNHGiEVtipxzpFqx/HFDznrrvJrr3+GD294Stffkq2cAITGWRCmRAkRGo94g5eOSMVkSYxK4lB7QCnSWOOx6EigtMJXCmsN2kShmxFQ+QqND12MPUipEXiEUCgpg01EKdJIgRfIuvFJp53x3Gf+GCs3P2ZztEFr+hg4T2VLqqpiuLmJK0qiTpssy+ieOsvwaoXzH2DNBvnodng2w535/AmIEyCnkboHOkaoFF9s4m0G3EYpSdI9wcnnvs7RxWOUxpO8+JNc0R3Wlt6iKNa5evsH3Lj9JqfOfJP29HmyVsbU/BGWb38RN/y4LoZyMAMFnhEmIAgrfkIg/oi67yvggqi/uY5Pgq8aLWvbWBK8ANj69SgFHaZRM7N0Om2oClZufMzw5gfgmhVFErVP0lv4KV585RWUUngURVGEO5cFw80hUivMBBNQAlRtuaucR9SZfaOypCoKkkyihcBrT+EN1ptakYnwvtwKFAqNQZuL1snOXlLkw+Bt0CpY5bVCeM9stM6L3Yu8txTzby8dI68sznrqTmKoSAXGEYdAImtLnLAgPJHOaLUSWt1usGGUJdpZIhFTeYUUEuPKUNFPRyEvAI9SkOc5pjJBwvGCOE0QqBDdrBRIiZKKVpoiCK5S7zzep7zy6itcfv8z9N96g6K/itUlhYeqLPEbGyBjvDGUZUG32yY58yqlfZ7BxgCzdh3vVsBcYiyiC2AK0jNErZQkShFCEycJxrWpiimUErQ6LdqdLlHcZWOQU5QlVVnRnnuOuLPAxq3rlPlNYEh/fYM8v4ghYn3zFlKCk91aEHj8RUueBp4hJhDXfx3hiZawVSVGgo+hqGv3tTLQKWTzMNK1ADCqz7uXLaANulXH264R0n1nUZ0fJ5mZpVi9zvDmh1B9wtiwGNOaPs3C+V/gxPHjREqTFwUMhzUxegpTMRz0kUqFyDzvEEKgtUJbjUTivKcylmGebzUBwQVC0NbgBAgrsKKich5jBFrbYHnH4iyBYKzAevDGUxiL0YQqRsaglSJSnjNHlnhlepnf+uAFLqwkjKocfOg1oIUkSmJ0pGoLu6bIPZJQUFRFGqRGSk8UxwytQygd0n2NpSwrhBShLZmStTUj1BtMEonyBV5JBG6rBoBQoLQmUhoV6xBNaA3Ce4SQxDpmqjfDmZe/yfUrbzAa3sKlx7EyMA7qfAlTVvQ3+tgqjCmKMzpTEQMtsOUR7O2UkPhF+G1ZQ4qSLJ0lyTKEB52kZAJMEiHjiCRJUEpTlCVFYeqCqQ7nAdli6tgLaP0iQmqErSiGOaONZay9hhuucGeSyVZQxYHAM8IEPGESxQSVoEmo8WwZ67BhQpVxqOGX1kZBAKvBpmBXwO/2owC0QbWRyUvI7nEYDcC9g8eC+izx9FGGtz6GjbfZXo9ujvbMaY6//NP0OlNYV1GWFaOiIJYyGNRcIPq8KJC+bvihRG1g81R16S+Ew1kXuvSIUHxD6mCtt94HohGaylZYa1AytASztsIhUQiMDcTWhAEDGO8RXuCReC+YTws+f3yFmzbm31yZpz8q8UKiVSAmg6WsDFAQRQrpPc4atAAZR0Fkd8E1KIQL2rQQdYCTJI0VKgK8wmGI0AgRmLiXikppbBgN1oeipyGvQRIJhTcOYyuE8MHwF2m8C8z0hRde4MM3X+Ti+29hVA+dTocYBpWEEkuVpRgVCCeJsuAhMsajZYTOYobRIlRtxtk8BpdfoSpnafemAiOKkuCmFRJqo6yxDmvDc3TGAR6hJM6Fhi7OS3SscV5idUQ6vUjuv0px63vgd7ZFa9NkLR4EPENMoEEjCTSBrxAYA0AOrg95nTmXtpBZhmAW7DFcPsDnl8AuhyAh16gJGpGeRfdOk80voqNgkbfVOYabG/jRBqNr34HqEpN1A2RyinbnSyyePU0cJeRFjiygspAXBYUQIEOtfVyoniMAZSIkEu8ETo5z8aWASGt0HOG9Q7ggIkt8qO2nFAKJQlH5ijI3SGVAODQRJSo8GVthrMU7QRTJ4BqsV9M49pyfXefzx1f5zscn+Xi9i1ARSkdhvbahOYj1nv7mAKUI0YzeEkUh+EY4h6XElMGCIFxwcSqpyNIYhcIpoPJ4qRBOoaO6cpIVWCkQQuC8I5WaEo/1jiiKQsNSU+GlQiqNd2HlFR4EnqnpKV78kT/B7Rtv0x8uE2dd4jgiTxxe+SAVUHdFNiHJyLoq5CYIBVkLqvOE+I1+mE9ujWJzg2FriqwtEDJkU4qtRqyhXqP1Fl27bI0z+CIwQrwL9gwPlbWUpkKgcG4v8ikJtq1DJvCAqAgrfkJY/RvRXjKWFOpXnZcqcMgoBOUo3cFVU5h8FmwVVg1X4UyJRRFNz5B2u6RZGykV1pTYwTrF7bdhcJPt+lxG0j1Be/7HmF1YQElNVVbBml2vwHlZhgxABQiJc4aqLMPq7wKBW0K1DiGCA1DrqI4fsFgrkDLYDKTUwR0mVAi4sQZbTzhRWVAKJx0WV5fW8zgkkZLoKAmMRyniJGaxk/P180tUkeF3Lh6nICFNM5IkwxHahAkpMVVBZSq0D+MQ3iOcxzuLw4csY6FQdRdjAWipg+sPiRcgkuA+NKUD7/DehX6H3iKQeAdChy/pitATQOrA9PC+JmAXOh0JHQIYlebVVz/DW997nv6Hb1GM5kjas6g0wlQgvcJLiYqDOuHQdeSjRHiBThNMfgwqBU1ku1zEyZjhYIA1BXEUI7XCIUJHZukxVYkQkqjdCWOuJNZVdRAUeCmQQoHzwbtSekxRAU2/ibWJ+TPiIDUle4aYQJOkEcTdwBAmmUHzaocy3HkfX+WY0QiXtYlbrVC8IksRoo1WAqllaMFtKoQQ5KMCUzgo+hSDG9i1j8BfZrtB8Rjp1GmmT7xKp9MBCZUzgKMyoUiGbyQU74MYW1f+dcYiFFhnwQbCl0qEfAKh8EJgnKUyJjAUIHI+EIl3IYGnTjGWkcYaV2vpHiHCKuhwoBRago5CII1OUpIsJdWSl4+s8OXTBW9dP8Un/Tl0HKOjKDCPytYRhSG4qCn4Ya1Fi+DTr4oKEWmkDhmPAoVUtdnVOyLvUVLgvUVqHeooulDAVMog8hsn0VKG6krWBR4uwVQWFQm0klhrcN7hRC0nSYGSiqqyCCk5dv4b3L76JsVoA6vbQUqKNAqFMSWSjNIVoT16pJFCgrQhY7I3hRtqsHPBjawTRJyAEBgH3lTYUYE1JtRdcCXWFERZC5DoKKptNkE6M1VFOSqwpgIvMWWJNR5fFOBnGEuvu+UTh2sGz4Hk/lrWPV08Q0wAwgNqHlLjHWjsAqb+K8DnUCVQxVC0cJUNlXZ0EoxOCei4VYftVsgSRqMcu9mnLFdheKl26ayxLTsge440e5Wpo8dodzKQIhBGWU/YeghShJLdcay2whXAIXUo3eWtx9ciMWHECCnwTmBwgUkYh0dQVhXCO6xUOAiMwFZo5zEW4igEy0RJEuQi55B1bH6WZUxPTzMzM0eWZSQM+dLxZUQ8zWtLL2Fki1iEGIV8OGSU58EYBzjv8M6E2P+QGYCkyWmQITZBqWDXE3WpRAsKRRRFFIVnVIyQTlJZg7eOVjsjipIthiCEwpRVsMhrRaedIkTw7DSh0wiBihRahhbp1nnyQvLqq5/l49efp7hxEfwCQmiE9Ujl8VVBvlqE7spJG4Ul1klgpkCURDjVwdsM5wxCKaIoJo4jpNZIPIXPyUcjqEowBVQFtqgwRbB7eAQiiUO+g7PYOmLTe4GnfnZmk7Enokcg9J0eqpgQ7+JCoBsj8Bs0dSafBTxjTGASJeGBivrVtJhy9b4WQSrQIZGn0nihEcQkcUpc665AKLXd38BvXAJ7kTsjCqdJOifI5j9H1u6RZAkShXGOqnKYyuEwSCdDNWFVu7x0qOXnlEcJhY9CCq8XQcxFCIQMpCVcMBYKIXBO4IytVyaHrzwVjX4LThIad8gIHSdkSYysA3ESFZF120BElkW02y2iSDPa3GRzcJ3rrJKXL3LFnCNK1hj2N3E2BDJVJjBYKWXw3UuJrCMHnHNBp67rEEY61BtQIqhA4TxwzjIqRuAcVWGQKkgQ1gUXZG5yqMVs64PbUAqNlAoVaZTSCC9CQVPngitRBrVCSkWSxBibMTs3z7mXf5r+2v8LM1olS0/ivaslggg36NceDKiqAlc5hJIgJZGUoUqyToAgbWgp6+8boCONjtOQ5yCCtIbzmNEoZHYiIYmpklrdwOOdCF2X6r4PwebUBLfthU22JFhmQUbg1gjVpnfWrdwfPMNMAMaGwYZgff3e1H/9+CXCBJBSImWw8FpryPubFBvXcOsfg71GCCyaNEQeJ+qepTP3HHE7w3ofDHyyvqtQSOkAHYxjunZvGYut3PjeQiFE0IsRnpA8qWoXoKsPCWP1zgbilxLhHF4IcA4pwz0iHZFECXHWptfrEOsEhyfSirTVDmXGS8P66m2uXrlIMRwy6K/jTc7yyVnOvXgCn/VI0hGb62uYqsKaMhQaIbgZtdZooYKBzPtaN7cYZ4ixqDr12dVaWGkqpIZhIfAYpAOUwtgqJBFJGBUFzvlg5/COwhm0VMRJqCBclQaZKKI4Ik4SvPWhh6IzOOfxxiCRpHGCM5bPffELfPTmWdaWL1DmPeLWFEJJItHGS731e2MqjCkQWqKThKqokFGEiiRKamxpyAdrYK4hKUEewcfd8DhEXQ7arQQJk15wIasIcPiyCqXbpAzTrhyGUuey/tJEjCXW3YLVLKEfxSCkKLs5wgJ2rD7+YfNbHh+ecSbQQBIe5uRDh0Cmog7Jc2ArqhwGrkIYi89vU+UX8fmtWgTb4ToUZ4la59CdOZwQFFUZKgQ78FHQb6WMkFEU3HECvLehsk6eh5VehSy2rfZ79WSQyCDySrmlFlhrEV7UVo4gIdTRuyAVrSyj1e2GpJkkIWt1abVTvPUMh0O8t2wON9i8tszt6zdYunGVYX8QdFUdsXB0kRXTpr1RMhNVJEmLOE6pjA0WcOsIFYmCu1ALQaBmMTY4Go9LQv1B5yxShXgCYw3GKrT0xElM3s/xntAQJYqobIWp9SXpPSNThHgJFaNssGk4a0MtQ02dXARCeKzTWGuxVYWtJZIkSZiZm+Xcy9/kB3/0K1SbN+pggwQvCHEeEirj8ErVi3EoCGNMGb6WtxgvMXmO27xcp5JXIG6APgJiIYRO+iK4l7lJ6DzVAtEDlwVJU9TzzZt6IbkWYqdpsjrjcN27xqhY4Bb4frg+XUKRG0XwIuyfIfEZZAKCcYpw877xDEjGtgJV/xVBhi5KqCxOiGAwqm6CuULgtDsDN9qgj6OyM+ikh0BSliXKSawJP6QiBLdQelChMk4I/Q1uscoYlBAoAcI5RBOHX8eoe0RYF0T4W7mgmwuhsAa8EMHCjkRHMUnWYmZ6mpm5eeI4whMMaEVZcuPaZZZu3QorfjFgtLTCaLBBVeY0bbhknNDfzFi6eY18OGB2foXe1Dytbg8RaQabknw4xGJDM2Fr6/oGQTTXEoR3aClQMsJUoYaA8BIrFFGkUEjaWasmdijLCiIZXJ62rk0oCIxPhUIplbWoMkcpXUtIwVDona/rEQQXZRRJKikpKo+0Dq1C6bVXf+SrfPiDX6dav0SVz4fVtG5RhooCY8gykPU88aJuseZxxlAVeSiO6ia6GPklqDYJuSYJgZCHBDVzOTAE20Sw1nYoqOfgZPZgE8/yIAQ8rF/9+vpuYk7vT6HC+ykq8ivc2XfgHwEv1YdMA2ve+y/UVYnfAd6r933Le/9X7n8oE4TdhAyjCD9eRMgpaLwGEVt5rnYYQouFBoYheMPfrs/bKaItgDgG0SJeZ6HXIArvLNZIvHM477GVI3dFmFxC1Q06wxW8c1uKCZ5Q6wsfmICUKC+CYOIc0oeJ7vFIIRFSYJ2trRsapCJrt5mdW2R2dppWq00xGtAf9FldWeP6lU9YunqF0foK1nisMDAYhYrIzYBqj8L68m3ywSAwlSTh6IlTPP/Sqxw7dox+t8NG3ZPQFAVFYepgHUEch1yAuklSSCF2oF2wunvpiGSCl5BXI0ajEluWOOexKKyuv48LPnsvJUrGwa/hK0wVJB4vwEShdsHIO6qqwjtPKwtuXiEFWsWIWCKJiZMYf9rxma/8Sb73O3+bqhhANgulCRcL8Y2AQqswL+I0xZYF1oGKgtESY0HMgj/BuNpdwxSaOTeZAOQn9j9OTBEYTc7260fc3a7wZHE/ksDfY0ffAe/9/6J5L4T4mwRFu8FH3vsvPNgwBGMCn7QDND90U8WxMRI2cQMNFx4GfdcXhJV/nd2zuo6DOA7JNCJK8F5hPXWfHYWvbDA/+lApF2NAaJSq+YsFTzB4mRKEsCgn8HWzj6ZKrxAWT1ArpFIoIeukHQeqwuPQMiaKYtJ2i263S29mijRLKZ0hz3OuX77Mu2//gNHN65hiGMRPFQWR1FVgM5AeRF2FSCtsVTEsDVJH9BUUVUmr22Fufo65uQV0FMOyYL0yWFeFYDlciIirIxyNrRClpBQFWdpClAJRCYzMUTpl1CdY9KWkLEqcjULWoQqGNbyn9BaRF2gJ2JBMVFVVUKE9mLIKgUNKg3ehTZmxuLrBihQeJcO+qRnDV3/8p3nrj/4l1cb7CPVVSFO8S0CnaOGwMgqVklQcosCjBIwNsRkqwcgqNJepTtXz58rEnGikzKeBnPHqXzJeoPa3ien9VBbas++ACMrunwN+9tGG0Yj5dQegurXFWCKoGCcI2XqfITzIxn3YJ4hZFXeu/jGhFsFJSKYgjoOVVsmw8lmLVgojJcaW+LwKKoCtUBhkZFFWI+PgPzbG1626JA5BVdnGDxgMSFIhhEIQ3IDW1wqOFAgZOEoUt+j1OvSmZmh3MmxVsrS8ySjP6a+t8c6br9O/drHuRlp/H1vV31UGkdin4buICpVmwTZQGZwNkkh/Y50LH33AzNQMz73wGZSSGBNiBITwCBEM4SUGHUdB8BUKoSOqYkSR55RF7bLVnlSbEFOgNToSVGWFNglFLlF18pKi8fw5RBxi9Y2tKKsSoWQo/uEcQkA7SZAyJopD/kdRVjhn8MKDN1tBUHPz83z+67/It3/rb2EG6ySzJ1BJhK0kURzjEThb4F0YkxV1zoIjOD3jOIg4PgOzwJ3BPQ+KJtNV13Nwjfsj5NBlKdgDuoT5WrDfaciPahP4SeCm936yods5IcT3CSbR/8J7/zv3vsxk4lAzrEZEa8SnauKYxjPQSAsjgnFlt4c5S2gX1oWkO2YAuLCKovAeChuCfbz3GO1R0iGcwqtAFHGaoiKNrwxKhoVPSDEuIebrbjtK1vUF5B28KFaKpJURxTFSKnSiKIohG+urbG6usrG5wWi0iVnZYLhybYIBNM9CMY6sjGr+F0R3V9VRkqYOuRaBBW0sr7CyvMKZ8yE4qCxLnLFBNRHhGSoVMgFdZakwxD54M8oqx5pgAEvaMZv5Jt750PIs0qEMelKhhSJppyihQ91UBEpLRnmOEh4vQzck7UMsgFASpSKU1khdr+J4hBRUeYmIJa4uqOIJbcl+9Bs/zWu/948x/XeQ8ihJ2kbFmtJLbFFSGhdsQtLhNzeCnUgluFYW1DUnatdem9B6/n7EfUUg9jqFG0nw+S8yrnkh6/lVEgh6rwa2DSoCaTTG7ocpfvN48ahM4C8A/2Di83XgtPd+WQjxZeB/EkK86r3f2Hni9uYjTWiwIfxICeEBDQg/1GStgEZdaBiDZ8xht90BWAyrv8jCPaQGF3zSHqAsMSpwcE+gbK2SEMyDRibQm56mXeewQ10ezEKSBIORq1MBvXfYKqgDcTpWa0LvvxB8o2SIzttY32BtZZnhaIjPh7jhEFP0cdbiXBnqI/qcLTuJrEVtqaiD9kPS1KgMz8g7fFEzzjip7Rjh0RhTMRj2KYscQQit/f+396axtm3ZXd9vdqvZzelu97oqu6psYlsRjQWOBcgyEBPbkTCYKPGXBCKkKBJIQUqkOOELyqckUlCIFCERmcgQBCEyyIiAAnZCQiSa2Khsl102rrLLdr2qes29p9nNamaXD2PNs9e5dd97t169qnOe6g7p6Jyzm7XnXnPOMcf4j/8YI+uSlyELUTtLiIHoA/04IhXQDQaF9wnyiLGZoZPKv+V7DSExpj2NtWSgaST7MMepqHOS2gOubqmco2ka1ssVxmqpRwCEYWSIorhSzhAjOggt2KLIJhKU4uzsjG//PX+cT/6T/57+7TfRxrI8PsEG2L7+Nin7iU4OxCtZS6Ei5xNwWu5fBHQF6WxaI6/z7mBcsT6XiDLQyAlecCsQhXw8rV2PuK5f5N3BwnfLMFQcMILwHq/9YOR9KwGllAV+GCn0DsDUfmyY/v5ZpdRnkV6NP/P0+282H9H5kGyRkJtZNn9hEBYsoIA2N6721P8L4BGohxLzzUAcxK9OmnxtSViJN2OwtQMn3HgVAo1rObt3xvrBEb7bc/XkCbthh0JRVTUPHj6grhdY66gbAbaCF565tWaqAJQZ/cju6orLy3MunzzGnz8hDpfEsCFNPrRoksnMB7g2qicTM+3l+VQ27nRvkjl85WhBTYi2nrLjYiLGyPmTt3ny1puc3HvEar1G6cQ49vjeE4LE6gMGPbkIm+1WUqAnpWeNVBtKOdH1HfZax2TCEMBJwxKjlwxpi80AFmM0PmvIIzorVD21OctZLI+YSN7jQ5CKQVYLtSJFjBLMwBIJypLGnt/93b+XT/3TH2PoP8n+vGEYInXdkIKHWGCpngOgHMB3oGuuD5oUJkWwQEJ08O6KYEQUQIVs8FbuMUoOFetKl1ZIk4VGhRDS3n6X676TlHkvgOV07a+hfDWWwL8J/HLO+RplUUo9AJ7knKNS6uNI34Ffe+9LXWPtiDLYc5N88XSW4bvJGjHX7nOoRZhFAWRBwEGDsSjbYJwTAMmJdrdVw/FpzenJA7RO/Pq/+gzj679IjG+Rs2AQyjzk/AuvYRYr6rZmtVpT1Q0xjISYMNqRSez3G3ZvvE7avkFKAzHuID79nRbcdIXKCVNCox2yCHokEFMWWVEaE26iG1nc2k0xdLFUlFZcXV7wmV/7ZX6bszx8dA/vj7i8vJICGcOA1fq6dZkULZXyaB6orSUQGMJk2aSMrixd11E3zdTKTDoNGWNR3uPjiHMG6zS2bjDGEVNgGEa01lTWUR05cBItyUYJyQhN1bYYDdZqUk5YW2NrMClwcnLMq9/2x/j1n/+fyfsnBC29DQ51JyQ9Wn6v5L7kCMMAudyzNG1WjWzuE2RTb/jyFPQFYuqXbVLqBEyKIWlZX05BUFA5CI3wC67n7/2QgYpVXFiyX1t5nhDhl/UdyDn/GNJ9+G889fLvAf4rpVRx4P/jnPNzcCMLAFhuXJEC+h3Scd/9q9xHXIAV16Qio2RT5CCKQGlwFutaqYoztf5WVvz7k5M1p2entO2C3/jcr7L79V+A9DkOikmTQyCNO/yTPb2CjWonfIEpdCXjzjmQ0yCffR3RKByIwnuYf1eFgFZTB9Ab37ss9rLgJxxFtdAegxJSkzKamEbhD3jJDRjHntc/9+sYVcO3JFbrI9brE9pqiR86nKu42FyyudwQfCAbaOuKFBO2qaUfAQZbix5tXcMmTNx3K52CbJbQZ9M0jKNmuVxirCJlhTYapS1aT5yEyuFjwGo3kayERm1by3LVoJXCOEcMgcF7bLSoQSjXv/d7vpff/MW/Ski/CP6ExELSymNZQ2VDN1xv6hxn9w8O7qPhANKV1N+iCByiSCZXEjO7RnlNhCFCvRKE9ZpAVOa5eo81+16iuFlspyiGD1aeJzrwrL4D5Jz/5DMe+wngJ97/cOZfsGjd50Fd10jf02NQlZhoOX853ih9v0ApIlId1zYNjbU412IdtMdHVIslQ7/lzTfegPQWMunFN5wII3kPWRZbumYxzklOZZMX/7tYOxlZoJGbC65BFuHcFPSIJVCiJuVelHvTglsIcaZ2pDgAFqWsIOxTopFSUuz0S29+nr67ZH18ymsf/TgvvfQKWp+SyRgnTVG2e8t+u2UcEnUtPfoEfxwgWGl7jmLlGgmbKlDWUtuGvutpprZpR8cnNE3NZrvFNQ5naxonFYghC/kqAhiS0mirqCd6cYyRnIWybLLB2SB1GKzl7OyMxaMf4OrzPwnDudyb0E/374JDZWqm+12wlRJZKRTfomAzojiq6adYXnPgr2AARSFP5e6L21a6wpK5abmVhrTvV+bjnzNlP1hFcEcYg2VSSlSgmGvPU875CPgIqGOE7TJlpzE5rqX+ABUYDQpsXdO0K9ana1zlcE6APGstR+s1/XbLr/7SJ4lf/BngLQ6br3AT4JDaPN/cc/5CCWWWsGZRBgsOSPKInFrle5dMyW76v0cUwxTivF5gQa5Tn0wfmcTlGXvINVlFMO46eYmUSP3Ifjxn2G7pB8/RyZkUVJ2qM61P1tSLGvf2OWGQeoOS6JelNVoA8DSN1Ombd0S2OJx1RCXlzSAwxoGamsVqQeNq6cQ03bN+P0iZr2Ul5dhTJGUlGYYYYkz4FCFK6nPIfkJwLK5xfO8f+oP8vf/l75Hip4A/IIrdWhgKRtLO5qGsK7i5kcspmzhYZCX0XJ4v0adikhcW4SzdXVuI/TQ3BcvKCDj4Xtbr80oZ09wi+aCufWeUABzMnRaeK7FiZv7TTiZfBtw0d1H876lSrqxYg1quOH7wgOOje7SLSk7JoLCNhRi4ePttPvOpT5LPPzmxDufYRMeByqy4BoiukVw4nAYlAzJzAPoUsulLqO9ZjMZnycBBWcyUQFmouYdeI22DQdUWXRkBzHIkjsIF0NrQaktTNXS7HZ/9zK+QYmK5POLRyx9hfbJmfRq5vHhM323po/Q9hEBjLSHAtu9pXYO1sFqv6fsN1lr6ocdZKy3VVWS/uSLlTFUthMqgpDkKMTPEgI4DNkh9wylJkW7Xo7OR6437KeUaUeIebGNpaHjtpddQq++Dy38AwxZOTlE48rCe1o2a3avVdA89B8urzEeZs6l83TXPpFgAxVobOFgExdWc3puG2XyfT/NU6l1+kPK1AwfvkBIo/OmO9y68MPflymRNyKyagvhTBR+MFUTYLFg+epUHL73M8ckKXTkIUsQz0HPxxQ1v/OZvkM8/C/kzHDb/nCc+v10FxW2YyoMgi2+eSJI5uATzpKdiBXwl2rxYBMVq8DDMUO2xk+sl4Q+oDDlmgpEyZMRE1gmzMvic+a3Pf5791RUKeOWjH+Xk9JRVXl0nOw0hoLOG3E+quRE6sYdsG6FzOUffO5q2YbvZYqwlELHZ4FPG9B6lRrpO0ntTytNdlVBe33k0/jrNGG3ouk7owj5LWA8IIUqV6QDOOFzr+P7v/z7+/t/6P8j5kxD+ALaxhJMz8kVArLe56VyUdLHUCkhYrLTAwSWYzxUc3Ag9e7xUxA6z63RIavCz6lvebbkjSqCYW89j/hsE0T0GVqCWoBeHsJjRkkfuFKaucVUzAVI19+6dEuLAZz/7Jfb7PWlzDvs9xA3kNxESR9Hq81tTfPZiBhZzvyyukudQmI+Gg8lfFMLITRfh/ZhzpQJz6UdYLJPptFNGgNBspGimAlsJv0FqLoIfPG994Qv0U6Xk+w8e8PIrH2G9PsJpzZPdQDe1GU8TV8FiyRNWabPUIdxsnrBhQ991WGuJKlC5irqpSXFksTySaEDOjN4TVCb6gHaapmqoqhpXC9aRZqXUx3EABYvFgt4HmsrR7/eEEOhDlOxD5Ti7dw/V/EFy949g+xben9GenRKah/gveQRgLa5VIfxM0YFrf764A3PMpoBIZR7nrkIB6eYAXeEDzAHDD5fcESWQeb6yS4WxdQScQXUGq2OMrbHOSZ89A66uaNsWU1eQEkO/4+L1L/G53/oMDF9CqsMWwGUO+hRQrmh/pufb6XfDgSZaNrqeja34a+X/KVf9mp+upvd8NSyxzfT9C9ilubY+zBqyIvs9aINdLqWctrU0zjEMI2M3MHSemDNHp6d8y7d/O9/0sY9J4tIw4P2GnOdMRbBti1NSqBQVrvkU4KVRMVwHLVxjicNUbr02kjvgpYQ6WVKpnXLQatp6gXVuqnwMOUWyTjS1pW0blBpwVhGsvS7iMvRBKi21LT/87/0IP/HjP0XOPwvD76PvGmxrUccPyZfllG6m+15Q/jLPxT0rG71YWcUyKC5AkZED+Nvz7IjVvMrxh0fuiBJ4LykJRqeIL3wE1Qnm7AFNu0AZxdDtGDZXkmHn91xeb7weeIyYiGVjz825QsMtMve9yu3ppvfMny+nxZqDT1ke3/Jscz8/47HnlbIgj4AHHAgujgOhZT19hJFOPU2DHyPW1qIunEX5SPIdTVPz2suv8ejhK2hn2O16us0F426YgFRoLDjb8OD0lGHoCcHTdR775Bxnp2xDZadinAE/dmwuMtZYuu4C4yTPXyWpOYCR+oCbsME4h1vUtEasFGOsNFG1Bte2uMowDNAPgc4Hkg+C/2EJtKzOznjw4CGsvg82/xB4k3wBftNO09ZyU5EXC6qc4vNTfm5hlXLh87kqh0THwXooYPEc1ykRng+XfAiUgOJAADqT0255hGqXkEd2X/gFGH4VyRws5vnznrTFF5yHI8v75wVMislXrIby+gIKzmsjer5yf/95pHz26fQz/w7FXSmuSpbKSiGzOj3m5PiUpq4ZxpGLi3OMcxwd3+fhSy9zcnoKEZ48fpOL83PiOFJVFZXRssmnjWStA9sTkLbkIg7n5DnplATWZnzoiAFiMiyOlsQwMfU4MBxTiHS7HSkEiJmqrWlsSdAKko5sLZGEVZCbGu8D2IydQpUA//Yf/SH+3l/7R8CvTvfo0dSkZhaz13a2JMp8FtesYAFFiZcDoVhwJeTruQkEz9l8BewNvLs1sETWxd1qYnrHlUBRAI/APEKdvIRpGsLmkvzGLxH5Tb5yamahdkp+wM3MRThkhsHBdCy3aZ7MNMcHyqKYUX0/UCkZlg65H+V7lOeKyRuBGiLEsae5f59v+di3slyvcU3Dbrfj5Ow+zjhOz+5ztD4BNFeXl1w9eSL9/lKiaSwqCmjqM3Rdx2KxoG0bfNdhrcNNjVODD9CIi4ASHHbbSRXfqlqjonRhin4k+hGDIpIZkqfNUwt3BTlkvEqEHAmbnag8BWEIE81YPs93PdZCmx2bvuP09BSlfocAhHxaUqyv3Te4pgqD3CNtJsbgtOm1ATeRemKAUNyAOT5Q3Ia5lGuup78navc7Kv+yRoq7ebvpw3O5w0qgAj4CnIE9Bgf58W8QeAMpA/V+QBiFAIpwk404JyXNlcAcNyj/zwtBlAzGEnIqgN0HaQVUSCZkCZ8W/kAZQyPkKOumeLmBDG274LWPfpSzRy/hXIUmY7Xl5ZdfpWkWaO0Yx4GLy3MuLi642m4Zxg5DwvoGpZN8awcoKdvuu3DgBljAtcCG0HtUhNXpGkyNUwHlMk3bYGvJ0ozJzULypcOyJ/hR+i5MjUpbY+j3A7vdDtc2whPwnjzxvGgbLA3YgCezblu+54/8cf7vn/y56b5/FvjEdH+KGwnXuEkqvv+kRFOQ6lGVlXoEcXIRNJIFlcvJPXBwBQpeMlcEIMDyO2UmFuJPzV1SAHDnlEAxtV5D0j0nwlD4NIQvcJN9934kI27Ds/jYxXyck4Gq2XPN7DXl+cABMS5g0wetAErW2pxQNHMBlIJmKq81SNktU9ec3H+F4+UZvh/w40CKmbZdYqyg3uMY6LYd2/2WbrNBxYiKgFaS4qsTtjE4JfTdGHr6vsO1FuccIWRO1y2bqWOyA0LfCzuwrXDaUTcWhcUYab+mQsngjFK3MyRGE7FWKMFOg1MG6prRB0I/ELK0XjPGiALKCI/Ad1Ln0VpefvgKxvweYvwXyPzOcZ4eAZPL3H8BOd2PudH8Nk6nf/ZyTwtXQGvIq9m0Ph01KlIwiHKgPO2SlrTk4l580O7i+5c7pAQ0svFfQrTlBZLqWXz0ZyUTvR+Za+FnTUaxBIr5VpTClpu3q6R8Fn+yAEcfJElkwcENmDa+aafiIpMiywht2I8THwIW9x/wkY9+hEzmyfkTyQGoKlzVELxHaioGvB+lVFqGSACTsRhiGNDaYg1TYpV8p7ZdkHNmvV4TYnGL1NR4FZRyrNZrhBacqOsa33uGIUpptOil3ZrWVFpjtYGUpNAImRDyRPUwoKSAyaJeMCopiR4J+NBDMGIhACFGXOv4Az/8x/mp/+1np7H+GmINlPyBnYSRk+K68i974J68Ji8hTinbKiGtkybGaYrgHIQV5InCXbXgJ5YmTDkDAK9wk+7dcTB/Gt5/aPhrK3dECTjgmxFtuUdIF28jN3HOxns/8k5atzxerI/C1y8g4Jy3DV9+AhRXoFgBRRF8tVLGs+IAADquw4K5+JRWMgYTk8kawChUtcAs1nTjyL4b2HYbYogcH51wvD5BKSX1+6dMvXE70ncdIfSSPjy5y1lBHwLWBZQS3v56vebi4hxrLfXqHn23oW1XZIIwBTPknAhETNZYZch1Fk9ZJXKasg2tlVJpSCciRSUZidYQY8R7z9D313RuYwwhCXVYKQs5k7ORZKSmoQU+/tEFrvou/PhPORQNLWm/HQdiWaGk1xzYqYVo1UAe5TUxTbwTNTGHDUKWmOa4mujDwcvfY2Eneg7sTjgwR4sbd/e4BLdX3fCGFNDlMTKBBrEIFnzl2rNwwlcIGltQdTjE7uHg1x0j5KPA9WK4IWWDl2vM48iJA5//g1AAxRp6NBt74SnICSs01TKGyYQdBznltMWeHmGtpPp67xmGgZwzVdNQNZJXr5RluVyChv1+z+hHOYUnhnNUTKduAAVRJaKSBiPOVWQym6tzNudb8lQGTCtFjIFh2DPsBilRHqLkamiwSYqIVk1DXdVYZaTcmtJobVmtVtS1JaSRYRwYfS9NWxWkGDERFFEY4MAQBkIAZx22aVifnfIH/8gPc8BnfosDom8hlYY1JbpyNPtxkLdIR+vJSsiDWAFZIYVKs1gKpSdbDmIxxADjlgPJLE/zNbcUi0JYcmhL9iyX9HbkjlgCcAh/OeRGXfLlG+vdfKnpBFX3QH0Usp3Mtx7hdG8R829EOAMJAdxaxESck3zmtN8yqTWy8Qs78GtRJ/5l5B4UBTWFuvRKdtLI5A5M7MNUujQJwm6bBacn96iamqatSSmyZEHbLnnw8AHro2OUMlLMJEV832GRVmejmhqORIVVYJWlD4NkWdYNJhuO1kc0dYP3nnE/klKi9x1N27JsGmJS1M1S8jRUpvdByrgnJcDl1JK9bltWqzVKK4b9HlJEaYO1hrXSQMfQj6SpMlFKljF5LDV935NzwGlppKqTJeOpqorf/tt/B//4f/92hu5TyGFyMd3XcpgUrsmaA2twXrymRIymx3Ij64ipTkOacjV0FkshzklHWw4U9pJjUMDnLTdDysUCCdyF3oR3RAkU86ww9q6QCXw63lqScQrRo1A9JzafugfLj0G1kj4EYRRNHl+WTC9Xg/8NDlo6Tp8xqzxzLUXhTIvg2pSsZuP6agGekqGWOYT6Bg7JQdPnpzDlBgSmzhvyfF3DMCmqHEghMI4DrraMo2yMk+M1q+WKum7IGcZxxPc9OxLb/VbacXl73aMQpLinsaCidEteL9b0fU9VV3TdHu89q9WSGBP90BF6j8eAUoxxxBpHZSydl3Cb1tKcJWdFjCMhWLLOWGtQVuP9wObinHrVYp3FWWmOMo6R7aYXdyCCntqIhxAEb0iZsfOEDBcXF2il+K7v/Xf4J//g09Pc/qbMrV4ydZOBsQC5cDi55+sPDtbijB6erPANpNnkFGpUYhHoWqyGayt2Prclz6XQl0t4sEQbvlZh5eeX91QCSqmPIOXGHyEj/ss557+olDoD/lfEmf8c8O/mnM+nCsR/EfhB5K78yZzzv3zvoRQW1hPEp5qXFSvFRmoOWWEFbZ26xZiVbPJCDHEVNBVKW3IY4SqA33MoXQ43e8GVxTD/Hw455pmDP1fcioavnvhRFFLZ+JqDT1msELhZamxaYKUnHhGURTtH3bS07RrnGlbrNavFCuccOSuGfqDvB3bbK2H/7bakMJJylL6NMaGsIalEwlI5Rxwifd/T+57Pf/Hz9NstVdXg3DGr9ZJqUdFtNgzDSEAqGTdNS2pqmKoOGaNIMRFHTyTSDwPbzZ7lskGMkszlZkMTR6pmIVGBqWDqbrelaeXkHIaeru8ggzEZgyGpgIoKHyP9/opHrz6iar+Zsfus3BcuJl6AmfCUATlkyn0vJ3l1uK/XFOPiehXsZ3KZUpJ50FaUcvJgFlPVqEsOblzBs56lYErZ8duX58EEAvCf5py/A/hu4E8rpb4D+FHgp3PO3wr89PQ/wA8gZcW+FSkk+peebxgNssFLNGBegjxOz51Nv8tEPQBzX0xN42Vi4uTLpSAAkp6y0TLIZJxxKA6SZz/lmiVNuIyrTNY4e21RQIVt+JVKWXQ1141VWcn/avXUdScTtOASukQLrPiqANqhmyVHL73Ew5df4fT0Pmdn9zg+PqVZLGiXS+q6JaVEGDv80DF2HX4cpZFIiKQJWKynRiC1tayaVgoUxZHQe/a7nj5kQhgYhgGt8lQy/Vg6GWUppDqMA+OwF7dCKzRaWIWVFBXRShHGgTCK0gg5knIihkjwAqTVdY0xlmH0jOOIQjoWDSESU6DrPSF7amswzqCMNDutjeMT//r3T/cuI5ySt4C3wT+ezWWxNq8Qc73UJizYULESCmmoh7SFdD4930N6E9n0o1gE12unANmFaFYOslK4pGy7u4ELvOcKzjl/kamOcs55o5T6NFLG54eA751e9uPAPwb+8+nxv5pzzsA/U0qdKKVenq7zLlLM8XLylptfTscKOXXPp9fXwA5pGbXnGuTL9ybfDa4n5DqkVjZvy6Hr8ZwpCIcYfAn1pen1JVpQxsXsNeXaefbYO0lRAIWyuuag9Cqw66kuQLFYit+qwZ0KJ6DbcygtDmp5xuLePR48eon10RFV1bJYthhTEYKn73tSyvjRE2LAp0TnRwH+yFR1g86JHJMk/IREUoqmdqAS/W5Pzpqz4xN635ODZ7/fC7PQOdB5Iv2Acw11U5NzQFuDNRX9OOC0xipNVhbrLDFFRj+SVUJjqF2NRREHj6scq9WKYejpJ3AzRccYRBFrq/AhYnKSaIEBi0G3K/ptx6OXXuKX3T2yfzzNyRZRssUCKCZ5CX8WxT6/356bPQbLewoprDTLmeYpFayohHMVh/qRxZItrykNSCK37QrAV3iMTU1Ifhfwz4FHs439JcRdAFEQvzV72+enx95FCQREo14hJlgxy0qSTkImch5eeRMx54s5vgaWAtgYpL8AWWLoMYkvV9WQlpBfhniK8BCuZmMoEzJXPiu+vFJNMRWLQiiLInDYvM9SBkUBLKffx9xcnBn8xewzis8Y5T22gpxQ9YKs9lLXrlqyuHePl199jZN7D1gsl2jtiFHhx55x7BmGYSr2oSZrYBRXQqWp9ZchRFEo3TCQciDljLaGZlETY6KuHUdHRzRjg1KKx48fs9sNpHRJCFHKlBuNqxynJ6d0XUdTtSyP1gyPHzMGT4xBKgwHaSOukT4EGSEAVZWl3+8ZuoC3XiyUnKSJa/SYCXhz2pJNIgeo6ooxjiTrGfcyf7qynL32h3j8639run97JAqQEeW/40D0crN5KQfRHByup9/Fdy84gedA5Cq8gEIlL/UKWg7l8gv/pIQL57jWHGD8+vMInlsJKKVWSP3AP5tzvirFJwByzllJJ4vnlpt9BwwSHpxKNl3ngZfNVuL485s0P8XhGm1NUTb9hFCjHVQGtEM1K8hrcjiBzdtwrcOevvnluvPiE9ewGQe3oIQOywlSrjMvbDiXoiwsogiOQLkJgS5ocfneheU2LSC7hGEHpkKvjojJg2toTs94+MprPHjpVY5WK3xK7HZ7QkiEMJBiwo8jMUXpgYCCFEnek0KCnBmGcaq/asmT3xtiZN/vyTlhdCYETdd1aK1YH5/iwyjNTEIPyWCmIqIoiDHiqorFasVysWDoB7r9hhQjaMgqE6J0G0pZwmUxBrSpMVVN7PfsdwM+RHz0mEoiHTF6FAkfoTKW/ThgnKGtFmit6PseZSx1VfMtv+0TPP7NBxBLJKjjEJ6bZw+W+RunOXl6QxbcAA6lxeYhvjWC4fQccKuag9tRrIDF7L1l88+tzUJQ+2o4Me9PnksJKKUcogD+es75b08Pv1HMfKXUyxyqKr6OkP6LvMahC+S13Ow7UOdDZ9gS428Q62DPwRR/WgrxwyATOGEIfhRFUFfopkFpQ9TSv16FTIybSQGUaz6t/ecSObgOz9rcxY8sVss8OaRo/cJ4LKfNpDRUnsgpcDAhyylRMIhG2G6VgzGh61q6Ao0BtbCc3rvP/QePWC6XJKXw48h+vxMT2ktJsRjTRNbJ8i1jnEp1Q0oRP4xYZ4jGEMKAVQbnIIfEPnXUzkLu2XU7mqoRNmDbSJShiyyaBpUSIWZSvyeFxPp4jVHgfcAZy2gMWYGrHYtmQbfbM/gBpY1UPlIK6wwKRYrS8djnSCYyhoBOiWEcMdowZk9bL0g5EwaPqyti7Knqmr6qqWzD0fqE05d/P+ef/zvTfbzkkEdQEPyisMthM68uVJ6fM1YLdlXCiSXEV9ZOWSMFdCxW6rzWRFEOloOVUXCf8vfX1xp4nuiAAn4M+HTO+S/Mnvq7wJ8A/uvp90/OHv8zSqm/CfwbwOV74wGGA1W4NHooN7z44XNxoM7A3gPToHSNoiJTkaOClNFti25alHFyAvk9qT+H/q1JAVxxU+uW0GMp1FF+5hMHB7N/jvYWAHMOKJVrFldiFspkIX/n4pcWPxIOiqBUGc6CQo87aI5RVQX9Hogo7WiXa1bLJTkl+rEnxSRGs/fSaFQn4b9PXZLUFK7TVgsVN2R88uSQ0Fphq+q64q/RBmcraaaSJftPKUW3vSJnRVYao7T0Hqgc4zBKF6Pcs2TFOPSM4yh9CJWmcTVoqJzD15VcLyVizJhkGEIgpyjlyCuHiooxiPuiAR88IQdyyjhjp16KgWZ1RNdtIEZpsmoMTb3g4x//BD/7+QcIMFiYgSsONRhK+G4+x/Xs+ciN8uLXLmIhi82JaIU+XqyOo2nu5zhCUTqlenVhIBYXoqyboni+PvI8lsDvA/594BeUUp+cHvsvkc3/t5RSfwr4DaQxKcDfR8KDn0FU4X/43h9RNpVDvvwVB5dgDpxMqbT6Hmr5TZjmDNO0uKom58joB/xuDz6gFguUVqT9FXE8h+5tYYVd4whP14QvBI6CzE9g3LV/XoCdBQc/ryiAYvLNKaIFcJq7DJUor1xwDgOqlRj2DerxHJvwECaOQFgSU4KhB+Oo12uapfD5u/2e/diTQyYGT5xOeqUyRuXr6j1VIwh9JknCUM4YpablrSUsmBJhGFAoVqsVrjJo7Tg7kYSkYdhjbYsyCmMUIYycrM+E/NMN2KrCauEejDHix0jTVJi2pu87dvsdow9CeUgTluBkk4jCgEXd4mMgbD3jOBBjBKWJKTH2PRHpYjR0iaQ1QwigNc5VVNax9yNNs2R973ewefxTHHClEnItG7hsxDInpc5AWZdw2Jw9B6uwWAk1YoW2HGjD5Tpl7RQsqZQss9MaLPNdrMPiJsx/vvbyPNGB/5d3jmX8oWe8PgN/+isbRjHJNIcbPEdOa+AE9Ck0j1D2FLs+oalqXFNjrKYfO3LfgQ/ge+JmS4xXMDxG+gOUa5aY/zwpCW6a7MW0KyZcec5zmLyyiMprC3V4Tksuz5XTpRCCyoZ/+nSBm/Xwig+5k/fGKN10qgbdNpzdf8iiXTAMgqB32x37vpey30nSdWNKhJwZvJ8y9QzWWWlGmjJuOjW1UdLafL8XlZUSQSl8CBgr9yGHyGZzgbUa75kyAaUIyH6zwatEygmjDNurDckHfArShJRIIrPf7UgxMXqPqSyVrdFUBC8pw96PUiYuK3yKhBgFowgB19akIeC9J8ZIVU/vy57KSZy/rhcsl4lxGDG15eFHP8rm8Rmi/ANywBRrs0RhVhxcuSLFOitzUUz6Kw6RhRJJKt2hipVRqj7tOVgDPXKAwIGAVkhDcFP5wNfTLbgjjMGnQZL5hroP5iVU+wqmPkIvltKyyhmMk866wY8Mmz3h8kpKUMe3kHLhJf4LgsTPN/7cby9hoYIez58rYyp/l6Si8tqnzbanMQOLmIZTxOC6IdMEFOUe1HqyBipozoR8Mm45nCpTCDRFcSFMS3V0xPHpKXXlGLxsjHEcyTmilMZoRUyJNIFrISaMtSSStBzzkRADzhicM7iqokuRfvCixpRCpcQ4DhhjyGnki298kbHvqKqapk5oIwovxcjF5hJjLUYJOeuyH9hsrjBWC3koS1fkoeslazEHMgnnKow19J2kKpOi9ClcZOk9kDJ12xCuiVEHLGMcBoZhpPN7jlcnJAI62+uD1TjH0fqM44e/k8s3/08Om35yx64jBQtQS6CGPFloWsnfuWA1JdS35KYr6RE3dkRwh9Np3ZUwYHEdClGtKJNCRJoXoy2HwjwM/bWXO6IE4KAISojtCLgP7mVYPYSqJRtNRpFTQGeHNoaYk4So+kHQ8/AWkjN+yeFGFvPrWclIc0IIHDZxhSyWAkzONXOa/cxBpvJckcIhX3BILe0RP3TyIVUF1RJ0i6sXNKf3SDGS+5795hy6Qk5RkjOgLbZtOTm5R7NckrPCjx37/Z5hHLFa8EalFJWzBK0IyaMEESTGSEqJsfeyyKsa70ch+0ypwzkd7pH3AWs9MQfS0KGVgGhGa1bNMdZqttsrQftjAqcY/TBxEyLLdgGN9BpMUUKSOQk3IEepQKxqCGGk2+3khK8qXFNPNpVi0S7Eox96tK1BDdPtVpJSPHgsO1ztiGHHsN8TUqAyjkW75OGrn+DyzX+JbNZC711yjQHpHqpHQgUmgx8kpByne34dPYjT3G358k2651B8pJDeSqSgbPRhmv9DGbib13kvjsnXRu6IEigA2o5DD7iXoHkIzSkYRY6BmC0pjuTg8YWTXk2nskJWP5vp5+mbOyeFPMsVgJsbfR4GhJvkymLCl5yDZ4GXBrE+jji4BbM4sqqF2ty21KsT2sUR7XJJs2jRKhND5snjN7l6q4GNk3ZjVUNVrzh6+JCj41MqJ3UD9/uObr8neY+pKqw2xDiCEvCPrLEaYogM/SCm/5TMk0n44FHDFFFVmqq2JKUkAj4KIKqNYvSe4/WKnCPb7Z7FcoX3mZQipERIgTS5NjFJp+GqanBVTQqeYZQMQY3CGHH/cpBux3FSUN4HUkrU+47KVZPronCuIubMOIp1FGPAWocxWgynscM5R0pBOAvakbVHW4erG9rjb6O7/GfTnO6mOVnKXOYt5A7ciUxd8MI4tTXkY0iPOXBA8rRWt3z5gQKHnpUrDhhE2WYlOrF7h/fejtwRJVD87Yk+q8+gugft5EPFhHG1NK9II4SAj5GUIxVLcs6k601bzKynrw+H0M341GNMn11QW7iJ6BdL4OmQX3EJIjcntSiA+xx8+pISrMT8X5+xOj6hOVqzWB2zWKzIOVPXtZTWHjxZKZKybLVQYherI5bHR6yOTqicxftA13UMfUeOEaU1zmmyzvjBC3M6QU5pCkdmyIq2bkhWave5qkJrc+1755yxrtQQTJyf79A6U9drYoy07QKtNW+/9Zjz8wuqymCtxmAIKaJSJITMol3gQyCEgd1O8IZxFO6/s1ZKnmmDrexE8NQkMsrKfd7v9sTaU6UGa60AmymS/EiMnmHwpKRIIaCNwfuB3e4S7yVkp7SaVH/GuJqj+6/QXZZoU4kUTCHYnMA/AbtCGtcY4ZlooFmLhRkvOJzkJVX4nTbyvJBpAblLHcgVB2zqbsgdUQIFpT0Sn9guAS1AWM5gDSmMkgiUkccmxy+mQNjvybuLyRXYz645D9UVFt88979s6AYBdr44e98sQYmem4BiURzhqevNCSaF7HPFocCFhKTc8aucvfpNHN87wVVScqqpKgbvadoVWku23HLZEoe11Nk3hpOTM9bHa0KQOH/X7em6jr7vsUqRkmcYpBNwzhqlBL1PlNx+hTZgtMZoiRIY69DKEKOXYiPGYKYehhlFygLaGmNoFy1V29A0DeeXF8QYiSgqXaONITtDbeupYhH0wxSy7Pqp3ZsAgkz6KOaMMpqm7gk+4MdBohm2oe97YhoJIaKtJvrIOIxkMk1dEzwS5TAwerlfm42Qm7TSaKPRxqCVwmnLYnmKO/o2/NUnp7kqB8YUtk07GK8kVTtNlmWY0M8bXaLnhK5389uLG1EiUcW1LOXN747cESXgwL0GtpXT3w+iidFSvlZLO3BihLqFnFHaYGwN3pP2WxiuJhCnFHGYx90L0ytycwJOOYRsCmgz39CFv1CQ+hL6KUDflkN4sFgJJWxYOhAVHnoA1rB4xINv+jgvv/IqWWtCiGIBVBU+RipnSSlIpR2jySeKxq+wzrJcrqjqCt91jL1snDiOpOjBGuEBoHDGkjUorbHGsu8SxghqT8qE4CW2b7Sk8yo99TQ11NaKQpqoxq6aCpgCL736Ms41GGNYLpaMITF2iZw9zmUq61it1jx58oTziyvZ1EtN5YR7EIJ0NgoksorEGNhvN6ishNQ0BkIcGdRAiImmqdBLi1GGkAPDMNC2FYv1CYtFZtt36FQTLi9xriWlgRgD4zAK9qAzyjqygqquuXf/o3zp6he4CUIXmnoG/xaEKYSYJ3xg2E2HTgkFlwjW8yT/zJvTFCvgCTddy9uXO6IEFOgWgoLdDgol2Roxz6KXIpopSragNpimxjjFsJP/qY7BO0iF8HM1u34BZjIHBbHmuloPAwIkzk/1gtyWsOAcRyhYQeEVFCJRoQUX1wEOisGAOmN171VO7j8kpMx+t0WlhNGGTc5stls5nY2Rvn4hUjsnakZpQvAMQTZOv+/IOU2JOhq0RkUxzZVWkgQU4uSvBypnUNowjlHajVtDzhliJGTJ5tNaE3xmP+zxvScpxbJZkVMmomiaFeMoOQCDj2x3PbtOyoBZrVisWkLSbPd79vuBGEdihqYRyvI4DJAT1lnCKO5IQOL+rqrRRqOyIoREUghWECODD+z3YvEYo0GJy5Z8T8aSVMLpCq29lEyvHPthII4j0SdR4Vlh7Brqfw2GX5qtjXnjEaaDpPj9zUToKtZiyT8oCW7vFcYr0YjMAex+CVEE5UC6nXyBudwRJZClRFYG6SXoJus9C1Fm8AcTzXtwajr1oKpbVFMTx5HxykEXIJdNW3yzOUYwD8OU2HEB7njqdcVvK7H+8t4SZShMrzKR83ToMvEFQDyhvv9Rjh88kLj6fs+47wg5YY2FqyQ4x5hwrZOKun3PsqrpgycQGYYGbSTW7r2Xq5tMGiOqViiV6fs9xmi895IENLH/YkpoLS6B9CmsUCj6cSQEKSVmsmYwSoBCLYpo8IFhCFiveP3zX8InzTAMbLcd+2Fk0w9YIikOVFcdl6tISqN8vk4sdMV2kFJhxihao2iVBp0kEzBlqRVYW/KYMVnCakortLLkDN1ux+bq6rpUmtrtBc8bRwIK7wPD/oqkE2EIWCMK2PtRSgBaS3AVO+Vol/fpvqzMX7EIyqY85WayWFlPFTeTgp5n85ZDprgRaw7gNBwiBUXuIG346yN5Clc1qOUROY7Ciut6pJKrkgxAa6VwiFGQM9oY6kZO3lAHqTqTE/gGwiPEXD9HQkNFIxdfX3PoGVCiE3Mff8UhznvEgeRTsgYLy69wBQrRaM0hHFj8yRrWL3HvI5/g9P4Ddtst+82e6CPtupFQZwg4bSQjrk+MKpJy4GIcSVNbMF1LfcCcspyiMdJkgzWORbti7PZc7cQCyhmpGFzLZo4hXGfkGWdRKNlQk6LQ2k6WRaIfBUi0QEyKvgvUywVmlwjRc7HZUlWOoBXWiWnbxZHYBxZLhc+Wfd9TNQ0NDYmET55KW5q6IbuG6HtGPxJ9z2q9lp6EXU8MCV05dJQ1YYymWdaMo/Qg6Lo9xliWyxq7WtMPO6xd0Pc9IUrKdOe7iXwUCDFSVxVqZen2HU1zRsfHkYrET0tELMIC/O2mv8vJX/j+S56ve/ZsfV+vrUJXLhv9aXygHB5fP0VwR5SAEn68a8hEMftDnOoADEKtdVYsBGtASXiwco6JTUpdV6iTE8aqEZ/XasLQE7dPpnyB1zn0FCzEjak4x3VnnxL2mYf+4DCJhSW44BAZeMqcvGaLFSBQgznh+P5HODo+hSwn+eZqgzWKtWohSf6+tVZacOHJeQpKjSOWwHJ5LGfK0ANBrIccUCpS146UPD54iBmlM2ShOmtdSZ8ApRjGQQzdqqauKobByylcaVSM7PYDMWashWEI1LqmbhpUDGTrGLPijbfeRmmNMlJOTFcVp0dHhLdBJ029OkGNI9vdyJgyl7tO3BtTgbX4aNgNmX43sttLaNXUe8akGIeBHD3H9TGmymijpAhJ1rSrlhACl+cXdBPQeHKyQGmHynByesJue0HwPeSKMScpnorBugatR9pFy3h0Sr9/me7iWUqAaT4fc+gsNM4eL+5eQfifxTt5L3keItA3pCWgZG8Ne9hPGjOXk3o6ZaeedcUiDzlwcS5UVuMsShtSEracchZbOZrVirQ+otucEZ40EF9HLINiFZQJKZGDiIT1Shx4h5hyBTwq/n6he84VQHnugkOIcAFqjTt6RLM6FkLPMHBxccnYd1hTcXV5hdZq0v+KQKa2glsELNl7jLU4pdn1W6m3NwTqGpSzghfETAgd/dAToxBxFBmfk9QRQNJ7tZZTO6tMP/T0/YDWjpCh6z0RTVXXXO09MWVGHalXLcpFLi93XF7teXJ5yWq1JoYtIULTWDH9vWexOsFVhpQcOcPuqiMEqXXonGH0S87jpbgofiSO4oIpvWUIQg32Y8d+8Ny7d8rRVNT0/MkT+mFgHEaSyXg/8tZbb9P3YpZbaxmjI0WFUgHrKknzyqBixDlF1JaqqlgsF+xX9+kuPoF0K3qWlJDuLMfjmkla1sL7UQB3U+6IEkhTHLaAdiWdlsNvqyRS4EcYOvI2krUkAQWY8nPqyVJQ5MVCSCZ1g/WJWD8kd50QQ270Fij+GogFcImAinNzr2ju/ez3PFRYQKOCL0zuhbuHO33A8uw+aMP5k0v22w1x6LHOslhIKqn3Uiyz2+1o6grdtMTp6zbGsj5ZoSJTLX9oaqnMG/uANAiVzZCz5AsIUKdRQczhlKGpG5raMXYD+11PyoneJ3wY2Q+REDXtYkmyis22R1mNzZ7Hjy8JYaDbdIzBg85sLjZYi4T19i19L5tXYVEq0o2evu8Yfcc4eAnzacW+GyZabpYyfTFgncb2I24FSldcdXsuLi/FELx/gskSTwwh0PcdOWdMNmSVGWNk1VpCyFydXwnAT6CxFuc0KxxD1LimpY2wdVtcVbM8vkcYX2b75jspAaY1sOKQ1p6QA6REfz6IMN/TUazbUSp3RAkEpBxBCdmVnPwC1DgBBLsBYqHeAqm0kZqkZLVYR/CB3RCwVYM1Bn18TOQVwRnyli8HC0u3n/K5JXTI7P/ynqdDRfNkn3ugTqF9QHP2gKOTB9i6IkwnXxqjJDlZaegRyYQgJJ00juTKEYInINbB+uQUpxXbocO2ThgIqxXBe0LYkrMhB0/WmXHfy2mvhChzDfhpzaKp0SqTTSb2kZAT+zHR9YqYM3Vb4b1nf9FJsZF+ZLSiYELIEzVD/GKjpfGH3ye8TeRhlOalPhBRdNsO21i0aVE4MlkIS1nCloqEcwYf5PHttqNyexZtS1aOLve8cblD6cy99Yp2IXjNclkTgiifPkQIQsG2QDdVIYYsNpQBpSxOKSlt5ioq52CxQKlMGl9l++Y3IzVynyUlClCsvOIiFpC4FJn9ajZuqR5VwtGldsU3pDtQzPKy+Z8aVh5gKLkA5WZNG1M3UxLedLonOz2lyWEgWwu1YdEuGbRiHB5DnLP+QCah5eAmlLhwAfngQA0ufPB5ZaNiUazBvoQ9eZn29JR2saCupeqNH3tS9mDSZK3AOA50ozTlbBdL3GpF0zTEqAh9R9M09MOWi7c7mnUjgckA1gna36xW+L6fcv8T2RhCSgzjIJ1+lJaMQmAMIzGOjMNAQhGzZRwCsQvY5YqjkxMuLzakzqOMJQchauWcSD7iVg0Ei7VwenYKWM6zVPHOSAsxHzxh6FEEGrckKE1dtxgzBVUzhH7ExxGMRQWxdoxRUg0pToVHA3RacdFl2iag+4GmqXGuoe93dCgaAqH3bLfdhKV09D6watc0qwaDxe839H2P6x3WBPpB6hVkAFNRre8zbj73LuuyUIVrbhagLbkHX60Uq7cA0LdjDdwRJVCkaN4VN0G5DYc67Xr6fwLw0h6SAjWVJstJrAF1KElmsFgcqXF4rcixXJenPqMgwYXvfYZYKPMNXzCAJYeQ4fTZ+h5m/ZDlvfu4Shp57sMGUmTsBzSwXCxJacrki5HYdyjnWLYN3X7PEAOh7/HeQ2jZbAXpthaw0wbpOpxT1PWKofeolGiWa/yY6Xc9Qx+E6rtcorWe2owJuy9GSCrjtSH7DGNPsJbN5RUxJpS1HJ0dsXn7bcFnA7immTj8Adu0KOU4PV1zcX4hp69tMCaw3+3p9h1V5agqofbWTcuyXRF94nK3JeTE0Hu0kwzBZd1QN0upJOQlGmCtI0Xo+shmGyQU6A3OBVBSj/C0OSW0nWDuQSyr3AWUgnW7pus6IaN3ng0bnHb45Am9FDoJIZPSVOPhXVH+4vqtuZlV+kFIYb6WpCLNTRfh6yN3RAmUTVhO33Nkg7XcLNpYTuCC4M9MtlzQ+jKxUwZYqiddEOkvL8nx6eSiIoEDsl8UwRd4djLSvJhoKR1eg1tjFkuMscSg6LoRUsJqTZ5q6a1Pjqkax/5qx363R5maqqkZh8i+67FGCy7qA33X4UPATa6DtZIvEEI39SD15JDJyeNsQxh6MYXjyDAEYeIBIQWs1iyWS2LT0I+BhV7Tt+B7D8PI0I2CKRjDuB/InYeUwDasTk+5fPsCYyxNC8H3nJ+LMhJKR8ZMBTeTD4xkzp9EQjdSH3liGPA+sdn1kGXMNS1KaXa7ET9FZZfLJcYYurQlxMiuDyxrQ+USYdthbcd6fcq6belDxLUtr5y9wvnmLeyTKyxuasHWC5UayCYz7veMSvIvAhbnoG1btu0pYfeIm3VxnyUl/bjUCSzhvq/25C4cguLSFnZqIaN9feQOKYGpeg4gG3BibGGmfX0P0gj+DQ7AYaHxFnNcg1qJNTB0YAxB7+g7LZzBzR7pT/8A0fCXHOL7BdSDm+XEisy7xSQOhSUL3fgYlMbUFcZoun1HHAbq2tG2lmEYyUmjcmbcDdc1/iyROAQ2YUfebAjNEtsuUCjZHEEQ9G7T4VrHen1K12cp/U0mZE8YI+HyMREBDBWgU6LbbklK0bY1VVXRrlopO64qqvU9vDKM40hSmXrhGLdSkqzbbgWA1YbVakXsI8kHcobNpiOwobWWHLz4AyiatqH3HXSe5DMp72EY6MeO3tqpAokHH9BVxeLePZq24eLigt1uh7OOzWaDthofPTprfEhcVp7T9QKVICDNTJvTNWo7sNk8IQSxGK11tK1Qk/uuk16MwUMMk7sg05ZNxncj4zBCrsCeQnib907ouZqtAWav/yAUQcGTCo/leSjJH5zcISUwlzUHck4PLKXIw7BHtGbpG1CwhKk2nDpCKvBMKH60EAJBS8RA3IQGcmFtlZp/hSjUIdXTi5QkkSUS8ntWqcQpZ0BZtHUYbaQZp/cYrakXLSkn6faToR8GrDHElPC+k400TmGn4Mn2mqqPs9CFQOgCNkC7fsjDh6d84Teu6HsZuvDNMlppXG2lwKrWmKoi9D2kjDEL6rYVQK0fGZIjDQMxAtZSuYqkIRsPYxSA1Qc4XrI6WvP48Q68J/uM78Q16toWfE+wAtpu/ZbcB4nL0UPSU8HXAE0j1O4YQQu3oFkuaduKq+0VJgiFeb/bS9vyqkJVCqJ0O+6DZ2XsNRm7tS2DG+hC4AtvfOH67AjB0/lOKrKFAFncJ2sttoHQC2Fp5zNdGBmzh+oBMED4ledcp0+TeT4oH3468L6sivbXXlTOtx/rVEq9hQRn377tsXwVcp8P9/jhw/8dPuzjh6/td/imnPODpx+8E0oAQCn1Mznn333b43i/8mEfP3z4v8OHffxwO9/hbuU0vpAX8kK+7vJCCbyQF/INLndJCfzl2x7AVykf9vHDh/87fNjHD7fwHe4MJvBCXsgLuR25S5bAC3khL+QW5NaVgFLq+5VSv6KU+oxS6kdvezzPK0qpzymlfkEp9Uml1M9Mj50ppf6RUupXp9+ntz3OuSil/opS6k2l1Kdmjz1zzErkf5jm5eeVUt95eyO/Huuzxv/nlVKvT/PwSaXUD86e+y+m8f+KUurfup1RH0Qp9RGl1P+llPolpdQvKqX+k+nx252DnPOt/SDsiM8CH0foWD8HfMdtjukrGPvngPtPPfbfAj86/f2jwH9z2+N8anzfA3wn8Kn3GjPST/IfIMyY7wb++R0d/58H/rNnvPY7pvVUAx+b1pm55fG/DHzn9Pca+FfTOG91Dm7bEvgu4DM551/LOY/A3wR+6JbH9NXIDwE/Pv3948Afvb2hfLnknP8fpLDiXN5pzD8E/NUs8s+Ak6kF/a3JO4z/neSHgL+Zcx5yzr+ONMj9rq/Z4J5Dcs5fzDn/y+nvDfBp4FVueQ5uWwm8ys3sjc9Pj30YJAP/UCn1s0qp/2h67FE+tGH/EvDodob2Fck7jfnDNDd/ZjKX/8rMBbvT41dKfTPwu4B/zi3PwW0rgQ+z/P6c83cCPwD8aaXU98yfzGLPfahCLx/GMQN/CfgE8DuR5I7/7lZH8xyilFoBPwH82ZzzvDb+rczBbSuB14GPzP5/bXrszkvO+fXp95vA30FMzTeKuTb9fvP2Rvjc8k5j/lDMTc75jZxzzDkn4H/iYPLfyfErpRyiAP56zvlvTw/f6hzcthL4/4BvVUp9TClVAT8C/N1bHtN7ilJqqZRal7+BPwx8Chn7n5he9ieAn7ydEX5F8k5j/rvAfzAh1N8NXM5M1jsjT/nIfwyZB5Dx/4hSqlZKfQz4VuBffL3HNxellAJ+DPh0zvkvzJ663Tm4TbR0hoD+KwS9/XO3PZ7nHPPHEeT554BfLOMG7gE/Dfwq8FPA2W2P9alx/w3EZPaIf/mn3mnMCCL9P07z8gvA776j4/9r0/h+fto0L89e/+em8f8K8AN3YPy/HzH1fx745PTzg7c9By8Ygy/khXyDy227Ay/khbyQW5YXSuCFvJBvcHmhBF7IC/kGlxdK4IW8kG9weaEEXsgL+QaXF0rghbyQb3B5oQReyAv5BpcXSuCFvJBvcPn/AeBZdu5P0XadAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class RedLightPredictionDataset(Dataset):\n",
    "    def __init__(self, dataset_paths, return_metadata=False, transform=None, sensor_range=50.0, bev_range=50.0):\n",
    "        super().__init__()\n",
    "        self.records = []\n",
    "        self.return_metadata = return_metadata\n",
    "        self.transform = transform\n",
    "        self.sensor_range = sensor_range\n",
    "        self.bev_range = bev_range\n",
    "\n",
    "        for path in dataset_paths:\n",
    "            self.read_data_folder(path)\n",
    "    \n",
    "    def read_data_folder(self, path):\n",
    "        for agent in os.listdir(os.path.join(path, 'agents')):\n",
    "            agent_folder = os.path.join(path, 'agents', agent)\n",
    "\n",
    "            rec = {}\n",
    "            for line in open(os.path.join(agent_folder, 'gt_location', 'data.jsonl'), 'r'):\n",
    "                record = json.loads(line)\n",
    "                rec[record['frame']] = {\n",
    "                    'location': record['location'],\n",
    "                    'rotation': record['rotation'],\n",
    "                }\n",
    "            \n",
    "            for line in open(os.path.join(agent_folder, 'gt_traffic_light', 'data.jsonl'), 'r'):\n",
    "                record = json.loads(line)\n",
    "                rec[record['frame']]['is_red_light'] = 0\n",
    "                if record['current_traffic_light'] is not None:\n",
    "                    if record['current_traffic_light']['state'] == 'Red':\n",
    "                        rec[record['frame']]['is_red_light'] = 1\n",
    "\n",
    "            for filename in os.listdir(os.path.join(agent_folder, 'front_camera')):\n",
    "                frame = int(filename.split('.')[0])\n",
    "                rec[frame]['image_path'] = os.path.join(agent_folder, 'front_camera', filename)\n",
    "                rec[frame]['output_path'] = os.path.join(agent_folder, 'pred_traffic_light', 'data.jsonl'),\n",
    "\n",
    "            for frame, r in rec.items():\n",
    "                r['frame'] = frame\n",
    "                self.records.append(r)\n",
    "    \n",
    "    def __len__(self):\n",
    "        return len(self.records)\n",
    "    \n",
    "    def __getitem__(self, index):\n",
    "        record = self.records[index]\n",
    "        agent_image = cv2.imread(record['image_path'])\n",
    "        agent_image = cv2.cvtColor(agent_image, cv2.COLOR_BGR2RGB)\n",
    "        y = record['is_red_light']\n",
    "\n",
    "        image = agent_image\n",
    "\n",
    "        if self.transform is not None:\n",
    "            image = self.transform(image)\n",
    "\n",
    "        if self.return_metadata:\n",
    "            return image, y, self.records[index]\n",
    "        return image, y\n",
    "\n",
    "preprocess = transforms.Compose([\n",
    "    transforms.ToPILImage(),\n",
    "    transforms.Resize(size=(224, 224)),\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]),\n",
    "])\n",
    "\n",
    "dataset = RedLightPredictionDataset(dataset_paths, transform=preprocess)\n",
    "\n",
    "print(len(dataset))\n",
    "img, label = dataset[0]\n",
    "plt.imshow(np.array(img).transpose(1, 2, 0))\n",
    "print(label)\n",
    "\n",
    "train_size = int(len(dataset) * 0.8)\n",
    "test_size = len(dataset) - train_size\n",
    "print(train_size, test_size)\n",
    "train_dataset, test_dataset = random_split(dataset, [train_size, test_size], generator=torch.Generator().manual_seed(233))\n",
    "\n",
    "train_loader = DataLoader(\n",
    "    train_dataset,\n",
    "    batch_size=64,\n",
    "    shuffle=True,\n",
    "    num_workers=0,\n",
    ")\n",
    "\n",
    "test_loader = DataLoader(\n",
    "    test_dataset,\n",
    "    batch_size=64,\n",
    "    shuffle=False,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0: 2358, 1: 1542}\n"
     ]
    }
   ],
   "source": [
    "label_counts = {}\n",
    "for i in range(len(dataset)):\n",
    "    _, label = dataset[i]\n",
    "    if label not in label_counts:\n",
    "        label_counts[label] = 0\n",
    "    label_counts[label] += 1\n",
    "\n",
    "print(label_counts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using cache found in C:\\Users\\IX/.cache\\torch\\hub\\pytorch_vision_v0.10.0\n"
     ]
    }
   ],
   "source": [
    "from torch import nn\n",
    "import torch.optim as optim\n",
    "\n",
    "device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)\n",
    "\n",
    "def vacuity(alpha):\n",
    "    class_num = alpha.shape[1]\n",
    "    S = torch.sum(alpha, dim=1, keepdim=True)\n",
    "    v = class_num / S\n",
    "    return v\n",
    "\n",
    "def epistemic(alpha):\n",
    "    return vacuity(alpha)\n",
    "\n",
    "def activate(alpha):\n",
    "    return alpha / torch.sum(alpha, dim=1, keepdim=True)\n",
    "\n",
    "def aleatoric(alpha):\n",
    "        soft = activate(alpha)\n",
    "        max_soft, hard = soft.max(dim=1)\n",
    "        return (1 - max_soft).unsqueeze(1)\n",
    "\n",
    "def uce_loss(alpha, y, weights=None):\n",
    "    y = nn.functional.one_hot(y)\n",
    "    S = torch.sum(alpha, dim=1, keepdim=True)\n",
    "    B = y * (torch.digamma(S) - torch.digamma(alpha) + 1e-10)\n",
    "\n",
    "    if weights is not None:\n",
    "        B *= weights.view(1, -1)\n",
    "\n",
    "    A = torch.sum(B, dim=1, keepdim=True)\n",
    "\n",
    "    return A.mean()\n",
    "\n",
    "class RedLightModelENN(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.backbone = torch.hub.load('pytorch/vision:v0.10.0', 'resnext50_32x4d', pretrained=True)\n",
    "        self.linear = nn.Linear(1000, 2)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.backbone(x)\n",
    "        x = self.linear(x)\n",
    "        alpha = x.relu() + 1.0\n",
    "        return alpha\n",
    "\n",
    "model = RedLightModelENN()\n",
    "model.to(device)\n",
    "\n",
    "# criterion = nn.CrossEntropyLoss()\n",
    "criterion = uce_loss\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.001, weight_decay=0)\n",
    "\n",
    "save_dir = '../tmp/RedLightPredictionENN/'\n",
    "os.makedirs(save_dir, exist_ok=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "try:\n",
    "    model.load_state_dict(torch.load(os.path.join(save_dir, 'model.pth')))\n",
    "    optimizer.load_state_dict(torch.load(os.path.join(save_dir, 'optimizer.pth')))\n",
    "except Exception as e:\n",
    "    print(e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 training loss: 0.3860946774330674 accuracy: 0.8599457144737244\n",
      "Epoch 0 testing loss: 0.2616972440481186 accuracy: 0.9139030575752258\n",
      "Epoch 1 training loss: 0.2105836386279184 accuracy: 0.9293347597122192\n",
      "Epoch 1 testing loss: 0.21470363289117814 accuracy: 0.9381377100944519\n",
      "Epoch 2 training loss: 0.261464387862658 accuracy: 0.9109905362129211\n",
      "Epoch 2 testing loss: 0.26183573007583616 accuracy: 0.8992346525192261\n",
      "Epoch 3 training loss: 0.20797532869084756 accuracy: 0.934120237827301\n",
      "Epoch 3 testing loss: 0.21834707349538804 accuracy: 0.9304846525192261\n",
      "Epoch 4 training loss: 0.29005998882408046 accuracy: 0.8915297389030457\n",
      "Epoch 4 testing loss: 0.2252072897553444 accuracy: 0.9336734414100647\n",
      "Epoch 5 training loss: 0.21491453211222375 accuracy: 0.9347583055496216\n",
      "Epoch 5 testing loss: 0.2285012573003769 accuracy: 0.9304846525192261\n",
      "Epoch 6 training loss: 0.1706227243934967 accuracy: 0.9551762342453003\n",
      "Epoch 6 testing loss: 0.21171254217624663 accuracy: 0.9336734414100647\n",
      "Epoch 7 training loss: 0.16263002617170616 accuracy: 0.9554952383041382\n",
      "Epoch 7 testing loss: 0.20707113057374954 accuracy: 0.9451530575752258\n",
      "Epoch 8 training loss: 0.17258642134921892 accuracy: 0.9491146802902222\n",
      "Epoch 8 testing loss: 0.18154655575752257 accuracy: 0.9464285373687744\n",
      "Epoch 9 training loss: 0.14276777122321785 accuracy: 0.9590045809745789\n",
      "Epoch 9 testing loss: 0.19723470211029054 accuracy: 0.9477040767669678\n",
      "Epoch 10 training loss: 0.12732706926002793 accuracy: 0.9642685651779175\n",
      "Epoch 10 testing loss: 0.18830984145402907 accuracy: 0.9406887292861938\n",
      "Epoch 11 training loss: 0.11730109995269046 accuracy: 0.9626734256744385\n",
      "Epoch 11 testing loss: 0.16113923504948616 accuracy: 0.9528061151504517\n",
      "Epoch 12 training loss: 0.10637572639602788 accuracy: 0.9676184058189392\n",
      "Epoch 12 testing loss: 0.1629169736802578 accuracy: 0.9553571343421936\n",
      "Epoch 13 training loss: 0.08994991153630676 accuracy: 0.9743180274963379\n",
      "Epoch 13 testing loss: 0.15866481348872186 accuracy: 0.9559949040412903\n",
      "Epoch 14 training loss: 0.10386964272023463 accuracy: 0.9714467525482178\n",
      "Epoch 14 testing loss: 0.16793048202991487 accuracy: 0.9508928656578064\n",
      "Epoch 15 training loss: 0.08481467522832813 accuracy: 0.9778273701667786\n",
      "Epoch 15 testing loss: 0.1402771918475628 accuracy: 0.9623724222183228\n",
      "Epoch 16 training loss: 0.06176289627138449 accuracy: 0.9851650595664978\n",
      "Epoch 16 testing loss: 0.15607452586293222 accuracy: 0.9598214030265808\n",
      "Epoch 17 training loss: 0.06441482308567786 accuracy: 0.9840484261512756\n",
      "Epoch 17 testing loss: 0.15659318819642068 accuracy: 0.9604591727256775\n",
      "Epoch 18 training loss: 0.08301237263545698 accuracy: 0.9795820116996765\n",
      "Epoch 18 testing loss: 0.2411782695353031 accuracy: 0.9375\n",
      "Epoch 19 training loss: 0.1624083111100659 accuracy: 0.9457648396492004\n",
      "Epoch 19 testing loss: 0.2166104693710804 accuracy: 0.9502550959587097\n"
     ]
    }
   ],
   "source": [
    "num_epochs = 20\n",
    "for epoch in range(num_epochs):\n",
    "    train_loss = 0.0\n",
    "    train_correct = 0.0\n",
    "    for i, data in enumerate(train_loader):\n",
    "        x, y = data\n",
    "        x = x.to(device)\n",
    "        y = y.to(device)\n",
    "        optimizer.zero_grad()\n",
    "        y_pred = model(x)\n",
    "        loss = criterion(y_pred, y)\n",
    "\n",
    "        with torch.no_grad():\n",
    "            _, predictions = torch.max(y_pred, 1)\n",
    "            train_correct = train_correct + (predictions == y).float().sum()\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        train_loss += loss.item()\n",
    "    train_loss = train_loss / len(train_loader)\n",
    "    train_acc = train_correct / len(train_dataset)\n",
    "    print(f'Epoch {epoch} training loss: {train_loss} accuracy: {train_acc}')\n",
    "\n",
    "    with torch.no_grad():\n",
    "        test_loss = 0.0\n",
    "        test_correct = 0.0\n",
    "        for i, data in enumerate(test_loader):\n",
    "            x, y = data\n",
    "            x = x.to(device)\n",
    "            y = y.to(device)\n",
    "            y_pred = model(x)\n",
    "            loss = criterion(y_pred, y)\n",
    "            _, predictions = torch.max(y_pred, 1)\n",
    "            test_correct = test_correct + (predictions == y).float().sum()\n",
    "            test_loss += loss.item()\n",
    "        test_loss = test_loss / len(test_loader)\n",
    "        test_acc = test_correct / len(test_dataset)\n",
    "        print(f'Epoch {epoch} testing loss: {test_loss} accuracy: {test_acc}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the current cell or a previous cell. \n",
      "\u001b[1;31mPlease review the code in the cell(s) to identify a possible cause of the failure. \n",
      "\u001b[1;31mClick <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. \n",
      "\u001b[1;31mView Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "torch.save(model.state_dict(), os.path.join(save_dir, 'model.pth'))\n",
    "torch.save(optimizer.state_dict(), os.path.join(save_dir, 'optimizer.pth'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['E:\\\\Datasets\\\\record\\\\Town01_1', 'E:\\\\Datasets\\\\record\\\\Town01_10', 'E:\\\\Datasets\\\\record\\\\Town01_11', 'E:\\\\Datasets\\\\record\\\\Town01_2', 'E:\\\\Datasets\\\\record\\\\Town01_3', 'E:\\\\Datasets\\\\record\\\\Town01_4', 'E:\\\\Datasets\\\\record\\\\Town01_5', 'E:\\\\Datasets\\\\record\\\\Town01_6', 'E:\\\\Datasets\\\\record\\\\Town01_7', 'E:\\\\Datasets\\\\record\\\\Town01_8', 'E:\\\\Datasets\\\\record\\\\Town01_9', 'E:\\\\Datasets\\\\record\\\\Town02_1', 'E:\\\\Datasets\\\\record\\\\Town02_10', 'E:\\\\Datasets\\\\record\\\\Town02_11', 'E:\\\\Datasets\\\\record\\\\Town02_2', 'E:\\\\Datasets\\\\record\\\\Town02_3', 'E:\\\\Datasets\\\\record\\\\Town02_4', 'E:\\\\Datasets\\\\record\\\\Town02_5', 'E:\\\\Datasets\\\\record\\\\Town02_6', 'E:\\\\Datasets\\\\record\\\\Town02_7', 'E:\\\\Datasets\\\\record\\\\Town02_8', 'E:\\\\Datasets\\\\record\\\\Town02_9', 'E:\\\\Datasets\\\\record\\\\Town03_1', 'E:\\\\Datasets\\\\record\\\\Town03_10', 'E:\\\\Datasets\\\\record\\\\Town03_11', 'E:\\\\Datasets\\\\record\\\\Town03_2', 'E:\\\\Datasets\\\\record\\\\Town03_3', 'E:\\\\Datasets\\\\record\\\\Town03_4', 'E:\\\\Datasets\\\\record\\\\Town03_5', 'E:\\\\Datasets\\\\record\\\\Town03_6', 'E:\\\\Datasets\\\\record\\\\Town03_7', 'E:\\\\Datasets\\\\record\\\\Town03_8', 'E:\\\\Datasets\\\\record\\\\Town03_9', 'E:\\\\Datasets\\\\record\\\\Town04_1', 'E:\\\\Datasets\\\\record\\\\Town04_10', 'E:\\\\Datasets\\\\record\\\\Town04_11', 'E:\\\\Datasets\\\\record\\\\Town04_2', 'E:\\\\Datasets\\\\record\\\\Town04_3', 'E:\\\\Datasets\\\\record\\\\Town04_4', 'E:\\\\Datasets\\\\record\\\\Town04_5', 'E:\\\\Datasets\\\\record\\\\Town04_6', 'E:\\\\Datasets\\\\record\\\\Town04_7', 'E:\\\\Datasets\\\\record\\\\Town04_8', 'E:\\\\Datasets\\\\record\\\\Town04_9', 'E:\\\\Datasets\\\\record\\\\Town05_1', 'E:\\\\Datasets\\\\record\\\\Town05_10', 'E:\\\\Datasets\\\\record\\\\Town05_11', 'E:\\\\Datasets\\\\record\\\\Town05_2', 'E:\\\\Datasets\\\\record\\\\Town05_3', 'E:\\\\Datasets\\\\record\\\\Town05_4', 'E:\\\\Datasets\\\\record\\\\Town05_5', 'E:\\\\Datasets\\\\record\\\\Town05_6', 'E:\\\\Datasets\\\\record\\\\Town05_7', 'E:\\\\Datasets\\\\record\\\\Town05_8', 'E:\\\\Datasets\\\\record\\\\Town05_9', 'E:\\\\Datasets\\\\record\\\\Town06_1', 'E:\\\\Datasets\\\\record\\\\Town06_10', 'E:\\\\Datasets\\\\record\\\\Town06_11', 'E:\\\\Datasets\\\\record\\\\Town06_2', 'E:\\\\Datasets\\\\record\\\\Town06_3', 'E:\\\\Datasets\\\\record\\\\Town06_4', 'E:\\\\Datasets\\\\record\\\\Town06_5', 'E:\\\\Datasets\\\\record\\\\Town06_6', 'E:\\\\Datasets\\\\record\\\\Town06_7', 'E:\\\\Datasets\\\\record\\\\Town06_8', 'E:\\\\Datasets\\\\record\\\\Town06_9', 'E:\\\\Datasets\\\\record\\\\Town07_1', 'E:\\\\Datasets\\\\record\\\\Town07_10', 'E:\\\\Datasets\\\\record\\\\Town07_11', 'E:\\\\Datasets\\\\record\\\\Town07_2', 'E:\\\\Datasets\\\\record\\\\Town07_3', 'E:\\\\Datasets\\\\record\\\\Town07_4', 'E:\\\\Datasets\\\\record\\\\Town07_5', 'E:\\\\Datasets\\\\record\\\\Town07_6', 'E:\\\\Datasets\\\\record\\\\Town07_7', 'E:\\\\Datasets\\\\record\\\\Town07_8', 'E:\\\\Datasets\\\\record\\\\Town07_9', 'E:\\\\Datasets\\\\record\\\\Town10_1']\n",
      "Average loss: 1.4013853785165442 accuracy: 0.8240398168563843\n"
     ]
    }
   ],
   "source": [
    "\n",
    "dataset_paths = []\n",
    "records_folder = \"E:\\\\Datasets\\\\record\"\n",
    "for name in os.listdir(records_folder):\n",
    "   dir = os.path.join(records_folder, name)\n",
    "   if os.path.isdir(dir):\n",
    "      dataset_paths.append(dir)\n",
    "\n",
    "print(dataset_paths)\n",
    "\n",
    "def write_pred():\n",
    "    dataset = RedLightPredictionDataset(dataset_paths, return_metadata=True, transform=preprocess)\n",
    "    dataloader = DataLoader(\n",
    "        dataset,\n",
    "        batch_size=64,\n",
    "        shuffle=False,\n",
    "    )\n",
    "\n",
    "    save_objs = {}\n",
    "\n",
    "    total_loss = 0.0\n",
    "    total_samples = 0.0\n",
    "    total_correct = 0.0\n",
    "    for i, data in enumerate(dataloader):\n",
    "        x, y, meta = data\n",
    "        x = x.to(device)\n",
    "        y = y.to(device)\n",
    "\n",
    "        alpha = model(x)\n",
    "        loss = criterion(alpha, y)\n",
    "        epis = epistemic(alpha)\n",
    "        alea = aleatoric(alpha)\n",
    "\n",
    "        with torch.no_grad():\n",
    "            _, predictions = torch.max(alpha, 1)\n",
    "            total_samples += y.shape[0]\n",
    "            total_correct += (predictions == y).float().sum()\n",
    "\n",
    "        for i in range(y.shape[0]):\n",
    "            output_path = meta['output_path'][0][i]\n",
    "            if output_path not in save_objs:\n",
    "                save_objs[output_path] = {}\n",
    "            frame = int(meta['frame'][i])\n",
    "            if frame not in save_objs[output_path]:\n",
    "                save_objs[output_path][frame] = {}\n",
    "            save_objs[output_path][frame] = {\n",
    "                'frame': int(meta['frame'][i]),\n",
    "                'is_under_red_traffic_light': int(predictions[i]),\n",
    "                'is_under_red_traffic_light_gt': int(y[i]),\n",
    "                'epistemic': float(epis[i]),\n",
    "                'aleatoric': float(alea[i]),\n",
    "            }\n",
    "\n",
    "        total_loss += loss.item()\n",
    "    total_loss = total_loss / len(dataloader)\n",
    "    total_acc = total_correct / total_samples\n",
    "    print(f'Average loss: {total_loss} accuracy: {total_acc}')\n",
    "\n",
    "    for filepath, frames in save_objs.items():\n",
    "        os.makedirs(os.path.dirname(filepath), exist_ok=True)\n",
    "        with open(filepath, 'w') as file:\n",
    "            for frame in sorted(list(frames.keys())):\n",
    "                line = json.dumps(save_objs[filepath][frame])\n",
    "                file.write(line+\"\\n\")\n",
    "\n",
    "write_pred()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.13 ('venv': venv)",
   "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.9"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "da7e20478b5a775c0656e92accb7702d4567ea1fb2ed254df86c89875ad00a36"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
