{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MNIST Digit Addition\n",
    "## Plotting of experiment's results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import sys\n",
    "import re\n",
    "import os\n",
    "sys.path.append('../')\n",
    "sys.path.append('../SLASH/')\n",
    "sys.path.append('../EinsumNetworks/src/')\n",
    "\n",
    "\n",
    "#torch, numpy, ...\n",
    "import torch\n",
    "from torch.utils.tensorboard import SummaryWriter\n",
    "\n",
    "import numpy as np\n",
    "import importlib\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "import seaborn as sns\n",
    "\n",
    "plt.style.use([\"science\", \"grid\"])  # Need SciencePlots pip package\n",
    "\n",
    "\n",
    "matplotlib.rcParams.update(\n",
    "    {\n",
    "        \"font.family\": \"serif\",\n",
    "        \"text.usetex\": False,\n",
    "        \"font.size\": 16\n",
    "    }\n",
    ")\n",
    "\n",
    "\n",
    "import utils\n",
    "\n",
    "\n",
    "from slash import SLASH\n",
    "from tqdm.notebook import tqdm"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Hadling missing data\n",
    "## Training with the drop-out rate of 50/80/90/97 percent.\n",
    "### 1) SLASH\n",
    "### 2) DeepProbLog"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SLASH accuracy overview: [75.05, 88.03999999999999, 79.86999999999999, 86.26, 83.6]\n",
      "SLASH: 82.564+/-4.656997315867812\n",
      "DeepProbLog accuracy overview: [array(9.8), array(11.35), array(59.06), array(59.91), array(22.16)]\n",
      "DeepProbLog: 32.456+/-22.477811815210128\n"
     ]
    },
    {
     "data": {
      "image/png": "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u98B0Nrayjve8Q4+9rGP8dGPfnRcK8CVV17JL37xi6j9XH755axZs4bvfCf9SQED9qQhUfubLvF3xkcVxJPrwKqMTSZl/GloaEi3BEsWL16M0doZ+zRbVfy7DiRZVXrwer2MjIzQ09MTte7RRx/lkksumfG+77nnHm655RZuueUW+vr6+OMf/2h5fIATJ05Erbv77rt597vfPePjBzlw4EDck2cWLVoEQEeHmSHsm9/8JkNDQ3z0ox+1bH/FFVfwgQ98AKczPOP+VVddxW9+85vg03XaSHSugzkVe2NYDYZlUI92aCgB5V8SjBrK4OFj6EBs2tRQ/M+8gh5tTbKy9HDFFVfg8Xi48sor+d3vfhfW66yuriYvL7ZUipF4PB5eeuklrr32Wt7+9rdTXV3NPffcE9Xu8ssvR0S4/vrrueeeexgennjCKC8vT8jkkCeeeAKA5cuXx7xN0De8cuVKAP7yl7+wZMkSamtrLduLCD/72c+ieswrV67kxIkTHD58eCbSM5YMGnNPPpnuOrDqJaUT9RvoiXa6W9uhbtH07V1u/E+/gp6wzqvr+uevJVrirMn75r/E1f6tb30rt912G1/5yle44YYbKCoq4pprruHv//7vuf7666N6aLHyxz/+kRtuuAERwel0ctNNN/HNb36Trq4uamomMpdt3LiRH/7wh3zyk5/kxhtv5JZbbmHLli28613v4p3vfCeFhZYRmVx33XWW2tra2qKepIK90qqq2Apf7t69m7vuuouNGzeOuy9aWlpoamqKaftQqqurATM384oVK+LePlOZWz3aDHcdpDuOVv0G2jeI0dWD0dGNHmtFR8fYtHbttNsax1rx3f/opEb2bOKLX/wira2tfPOb3+T888/nD3/4A+94xzvYtGmT5SN9LPz617/mAx/4wPj7D33oQ/j9fv7f//t/UW1vueUW2tra+PGPf8xVV13Fk08+yQc+8AFWr17Nrl3WyVkefPBBdu7cGfWqq6uLahucoDJV7/y2224bjzq46aabeNe73sXjjz+OwzG7vlvwmJ2dnbPaT6YxpwytZRxtBvVo0xVHq6MujFOdGAeOmQNegam16janKO7Ys2fK7f079uB//CUscxmepdTU1PCJT3yCxx9/nNbWVj7ykY/Q3NzM5z73ubj31dXVxZNPPsm11147HjJ2ww03UFhYaOk+ACgpKeFD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y5R16FXV0tBmgutAB4bQrh6aNBffX59FO3tim+EVq5F15mBbuQRb42KkrHjKprbaSmzXbEZVx2+e1bZsjxbMOmE7d+7kxhtv5J577mHnzp3j61555RX+8R//kR/84Af8+c9/ZtWq9OR5mErjb37zG975zndy7Ngxvv71r6dc249+9CO2bdvGFVdcwR133MGNN96Ycg2xsm3bNkhgroMz3tA2NDTE9MiiFuNBImCzpdd1oKp4//AExqv7KST+DqolDjsyrwryc7HVViJLF8advjC0h9LS1kptAkqknM1s3LiRxx57jM2bN3PdddfR3NxMwRS11tLBO97xDjZv3sz3v/997rzzzhmXRp8LBDptLYna35zx0WZqxIHv6R0Yr+5PzM7sdmyb1uB4z5twvP5iHJedh23lklnniB2bQ9VtZ4PT6eSOO+7g2LFj/OxnPwPMqgF33nknK1asYNWqVaxatYpvfOMbUdvu3r2bN7zhDSxZsoQlS5bw5je/mYMHD46vv/nmm1m0aBEiwgMPPMBVV13FqlWrqK+v5667rOYAWbNo0SJcLhf9/f3cdtttLF++HBHhN7/5DX/3d3/HOeecg4jw7W9/G4De3l5uueUWGhoaaGxspKmpKaoSRBCfz8enPvUpzjvvPCoqKrjhhhvGS5fPhD/84Q+cf/75rFixgsWLF3PTTTdF7a+jo4MbbriBiooKNm3axD/8wz/w2c9+FhGhqamJP/zhDzM+fiLJAFOTGjLRbWB09eL/81PTNwxFBPKc4PaCYZi917pqbAvnIw11SN70A2rxEsxHOxm2hgWQY04HxucHjxf1+uDkgGX7157zsPv5xEzCeM8np05o8/++ER2PvH5zDhsuSk5v7sorr8Rut/PQQw/xsY99jI9+9KPcd999PPPMM6xevZr9+/dz6aWXMjIywm233QbA4cOHueSSS3jve9/Lgw8+CMDHP/5xLr30Uvbs2UNVVRU//elPufvuu7npppv42te+xp/+9CcqKyt55JFHeMMb3kB5eTk333zztPoOHTpEWVkZNTU13HHHHVx55ZVcccUVfOMb3+C3v/0t9fX1fPzjHwfA7XZz9dVXU1xcTHNzM0VFRTz88MO86U1vYmRkhA984ANh+/7pT3/KPffcw9e//nX6+/vZsmULb3/723nmmWfiPo/33Xcf73nPe7j//vt5y1vegsvl4q1vfStbtmxh+/btFBaa3/vb3vY2xsbGOHLkCOXl5Tz00EO8853vBAhzm6SbOdOjtYw4SGOKRPUbeH/xh8l9sXY7lJcgi+dj27ga+7UX4Xj33+C48a3k/P0bcdz4Fhzvvx7H/3c9jmsuwrZqSVKMLMCOPXsmXSf5uUhhPuLMQXKd5v/lJdhqYpoIeNaRn59PVVUVx48f59ChQ/zoRz/iwx/+MKtXrwZg1apVfPCDH+RrX/saIyPmj8DWrVvx+Xx85StfQUQQEf793/+dgYEBvve970Ud4+Mf//h4prdrrrmG17/+9dxxxx3j5cut8Pv9fPe73+WVV14ZN/Ch3HDDDePVb7/4xS/yvve9j1/84he8+uqr3HnnneMDfNdeey1vetOb+MxnPoPHE14I5Zxzzhmv5ltWVsYXvvAFnn322fE6Y7Giqnz605/miiuu4C1veQsAeXl5fO1rX2Pfvn38+Mc/BuDhhx/mhRde4HOf+9x4kcc3vOENXHjhhXEdLxXMGUNr6TpIY4/W99DT1uFYebk43nIFjvdfT87br8Zx9Wbs5642IwUKC5CAT1lEEIcjJYlxaionN5pSnp2OG0kwx/Njjz2GqnLxxReHrV+3bh0jIyNs374dgEcffZR169aFlXApLS2lvr4+OCgTxtqIJ4xNmzZx8uRJTp2KTgfS1NREU1MTa9as4fe//z333nsvn/jEJ6LaBX8IAMrLy6msrBw3kOedd15Y2wsuuIDu7m5efTW8pJGVLjBLpMfDgQMHOHnyJOeff37Y8g0bNpCXl8cjjzwStt+NGzeGtVu3bl1cx0sFWddBGvAfOIb/8RejlvvynOT97TUZNwPLmTOJHpsNsuVrwhgdHR2vuBGsgvtP//RPfO5znxtv43a7qa2tHa8R193dzdjYWFTSd7fbjc8XfeFG1tQK9uba2tqiynTH+vhsFZLW3d1NQUEBubnhT0oVFRXj62PVFQ/B/UaWIg8uC67v6OgAzN5zKFal29PN3DG0Fq4DW18/7q//D3g8kOvE1tiA49JN6MAw/lf3ogPDSGkRtoXz0DE3xskOtHcgptlbIgKlRUhFGbbqcmRxHVJdjtHVi/e/fmuxAeyrK2FjhhlZgNaODpYvWhy1XEqKEPuceSiKiUceeQS/3891112Hw2HeXj/5yU+mLNVSVVXFmjVrePzxx2M6xuBgeFrM3t5eAMvMb7OhqqqK0dFR3G53mLENHq8qIhJltrr8fj+GYYzvN7h9KKGxwcH6Yn19fVRXV4+3SUaR09kyZwytYdWjdY+hpyce3/2nuvBv2x5lSC28DtMSuofx7fOc4LIqBgy2plUsWpJ5qRsB1q1YYblcKmZWrXTDRc6kDUZFMt1gWSJxuVzcdtttLFmyhA9+8IOcOnUKEWHXrl1hhtblcvHe976XH/7wh1RXV3PNNdfwyCOP4PV6ycnJGW/3i1/8gv7+fj72sY+FHWfPnj1s2LBh/P2OHTtYuHAhCxYkNnXl1VdfzX333cf27du55JJLxpdv376dqqoqzj333ChdoezYsQOAzZs3x3S8X/ziF2zbto2f//znLFy4cNy1EmT37t24XC6uueaasP2+8sorYbmcI3VkAnOiO6IeL+5Hoh/VbWphQpOZzmsSIyvzq7A1reZgS0vyjj0Lgrok14mtrgbb/GpkfjWSn5deYRnEyy+/zJVXXsnw8DAPPvgg+fn5LF++nI985CPcdddd46FaXq93fCAp2AvbunUrbreb22+/fdy/29zczOc+97koPyXAz372M3p6egDTv/vwww9z2223YbMl9nZ+3/vex7nnnsvnP//58RSejz76KH/605/46le/GhWH+/zzz/PXv/4VMHuVd955JxdffDFXX311XMcVEe666y6eeOIJfv/73wPmj9NnPvMZVq1axS233AKYA4EXX3wxX/3qV+nrMzPTPfTQQ+zevXs2HzspzI0ebY4DX190bXq7Jra+1ozIy8W+5XzEJviNmfSdk49fDaSmEqkqGx98y5AMESkldHorMO5TdblcVFVV8fa3v51bbrmF4uKJ2Xff+c53WLhwIW9605twOBw4nU6uvPJKfv3rX4+3WbZsGc8++yyf+cxnWLRoETU1NRQXF3PPPfdYjqB/5jOf4T3veQ/Hjx9ncHCQr3zlK+OhXVYaN2zYwH//939H7edb3/oW3//+9wEzTnfZsmXjhhIgNzeXRx99lM9+9rOsXbuW3NxcCgoKuOeee3j3u98NmLGuwSiGD3/4w9x///189rOf5cSJE2zZsoUf/vCH4/t773vfOz7A9qlPfSpqotHw8DBvetObAHjXu95FXl4eX/rSl/j0pz+N2+3myiuv5O677x4P7QK4//77+chHPsKyZctYunQpV1xxBTfffDNf/vKXJ/0e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\n",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Firstly load the data from the trained models for both DPPLs\n",
    "# and trasform the measurements of time and test accuracy to be ready to plot \n",
    "drop_out = '97'  # 50, 80, 90, 97\n",
    "## 1) SLASH, below referred to uncapitalised as 'slash'\n",
    "slash_accuracy_lists = []\n",
    "slash_accuracy_overview = []\n",
    "slash_time_list = []\n",
    "slash_results_path = os.path.join(os.getcwd(), 'data')\n",
    "folders = [x for x in os.listdir(slash_results_path) if re.search(f'pc-poon-domingos-drop-out-{drop_out}-percent-seed-*', x)]\n",
    "# print(len(folders))\n",
    "for f in folders:\n",
    "    model_path = os.path.join(slash_results_path, f, 'slash_digit_addition_models.pt')\n",
    "    models = torch.load(model_path)\n",
    "    if drop_out == '97':\n",
    "        slash_accuracy_lists.append(np.concatenate((np.array([10.67]), np.array(models['test_accuracy_list'])[:,0]*100), axis=0))\n",
    "    else:\n",
    "        slash_accuracy_lists.append(np.array(models['test_accuracy_list'])[:,0]*100)\n",
    "    slash_accuracy_overview.append(np.array(models['test_accuracy_list'])[-1,0]*100)\n",
    "    time = models['time'][0].split(':')\n",
    "    time = int(time[1].split('m')[0]) * 60 + int(time[2].split('s')[0])\n",
    "    slash_time_list.append(time)\n",
    "slash_average_epoch_time = np.average(slash_time_list)\n",
    "minutes = round(slash_average_epoch_time // 60 % 60)\n",
    "seconds = round(slash_average_epoch_time % 60)\n",
    "slash_average_epoch_time = f\"{minutes}m:{seconds}s\"\n",
    "# Determine and print the accuracy's overview\n",
    "print(f'SLASH accuracy overview: {slash_accuracy_overview}')\n",
    "slash_overview_average = np.average(slash_accuracy_overview, axis=0)\n",
    "slash_overview_std = np.std(slash_accuracy_overview, axis=0)\n",
    "print(f'SLASH: {slash_overview_average}+/-{slash_overview_std}')\n",
    "slash_accuracy_average = np.average(slash_accuracy_lists, axis=0)\n",
    "slash_accuracy_std = np.std(slash_accuracy_lists, axis=0)\n",
    "    \n",
    "## 2) DeepProbLog (DPL). below marked as dpl\n",
    "dpl_accuracy_lists = []\n",
    "dpl_accuracy_overview = []\n",
    "dpl_time_list = []\n",
    "dpl_results_path = os.path.join(os.getcwd(), 'data', 'deepproblog')\n",
    "files = [x for x in os.listdir(dpl_results_path) if re.search(f'MNIST_Addition_100_epochs_do_{drop_out}_percent_seed_*', x)]\n",
    "for f in files:\n",
    "    accuracy = []\n",
    "    time = []\n",
    "    c = open(os.path.join(dpl_results_path,f), 'r')\n",
    "    lines = c.readlines()[1:]\n",
    "    spl = lines[0].split(',')\n",
    "    time.append(float(0.0))\n",
    "    accuracy.append(float(spl[1]))\n",
    "    for line in lines[1:]:\n",
    "        spl = line.split(',')\n",
    "        time.append(float(spl[2]))\n",
    "        accuracy.append(float(spl[1]))\n",
    "    dpl_accuracy_lists.append(np.array(accuracy))\n",
    "    dpl_accuracy_overview.append(np.array(accuracy[-1]))\n",
    "    dpl_time_list.append(time[-1]/100)\n",
    "dpl_average_epoch_time = np.average(dpl_time_list)\n",
    "minutes = round(dpl_average_epoch_time // 60 % 60)\n",
    "seconds = round(dpl_average_epoch_time % 60)\n",
    "dpl_average_epoch_time = f\"{minutes}m:{seconds}s\"\n",
    "# Determine and print the accuracy's overview\n",
    "print(f'DeepProbLog accuracy overview: {dpl_accuracy_overview}')\n",
    "dpl_overview_average = np.average(dpl_accuracy_overview, axis=0)\n",
    "dpl_overview_std = np.std(dpl_accuracy_overview, axis=0)\n",
    "print(f'DeepProbLog: {dpl_overview_average}+/-{dpl_overview_std}')\n",
    "dpl_accuracy_average = np.average(dpl_accuracy_lists, axis=0)\n",
    "dpl_accuracy_std = np.std(dpl_accuracy_lists, axis=0)\n",
    "\n",
    "# Accuracy plots\n",
    "clrs = sns.color_palette(\"husl\", 4)\n",
    "x = np.arange(0,101)\n",
    "\n",
    "fig1, axs1 = plt.subplots(figsize=(5,4))\n",
    "axs1.plot(x, slash_accuracy_average, label='SLASH(PC)',\n",
    "          c=clrs[0], linewidth=5)\n",
    "axs1.fill_between(x, \n",
    "                  slash_accuracy_average - slash_accuracy_std, \n",
    "                  slash_accuracy_average + slash_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[0], facecolor=clrs[0],\n",
    "                  linewidth=0)\n",
    "                 \n",
    "axs1.plot(x, dpl_accuracy_average, label='DeepProbLog',\n",
    "          c=clrs[3], linewidth=5, linestyle='--')\n",
    "axs1.fill_between(x, \n",
    "                  dpl_accuracy_average - dpl_accuracy_std, \n",
    "                  dpl_accuracy_average + dpl_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[3], facecolor=clrs[3],\n",
    "                  linewidth=0)\n",
    "\n",
    "\n",
    "#legends and axis titles\n",
    "axs1.legend(loc=\"lower right\")\n",
    "axs1.set(xlabel='epochs', ylabel='test accuracy')\n",
    "axs1.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "utils.mkdir_p('plots')\n",
    "fig1.savefig(f'plots/MNIST_addition_with_drop_out_of_{drop_out}_percent.svg', format=\"svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# DPPLs in MNIST-Addition task\n",
    "### 1) SLASH (PC)\n",
    "### 2) SLASH (DNN)\n",
    "### 3) NeurASP\n",
    "### 4) DeepProbLog"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RTE (m:s) - SLASH (PC) 1m:22s\n",
      "Test accuracy - SLASH (PC) 95.386+/-0.29206848511949807\n",
      "RTE (m:s) - SLASH (DNN) 0m:39s\n",
      "Test accuracy - SLASH (DNN) 98.744+/-0.20626196934965796\n",
      "RTE (m:s) - NeurASP  1m:24s\n",
      "Test accuracy - NeurASP 98.21000000000001+/-0.2978590270581034\n",
      "RTE (m:s) - DeepProbLog 10m:9s\n",
      "Test accuracy - DeepProbLog 98.49000000000001+/-0.17765134392961643\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVUAAAEKCAYAAACi1MYMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAB6wUlEQVR4nO2dd3xUZfaHnzOTQkiAVEIndAIhCUVsqCBWVFZlLWtZxAbYfmsvrIiKiKLurt0VV1xZQFfsBUUEFXVFkBap0iTSA4H0MnN+f9yZYVoyM8kkGeA+n9zP5L73vfd+752ZM+993/OeI6qKiYmJiUl4sDS1ABMTE5OjCdOompiYmISRqKYW0Jhcf/312qFDB9f61q1bycjIqLF+Xl4eWVlZtR4z0DECbY8UHcHoDKQjHNd6LOk4Uj4bR5OOhvpsPPzww6+p6vUAqOoxszz00EPqjve6N/fdd1+t24M5RqDtkaIjGJ2BdITjWo8lHUfKZ+No0tFQnw1gkjrsTKM//otIWxGZJyJNPkI2dOjQWrfv3Lmz3scItD1SdASjM5COcFzrsaTjSPlsHE06GuWzoY3YUgQuBrYCG41T11gvGngUWAfkAd8DQ2qo+xdgDbAK+Bm4sKbjBvMr5c4LL7wQUv2GwtThiakjsjSomjpwa6k2tlH9EegBzAhgVF8GNgBpjvXrgVIg16vefcA+oJtj/UygCjjX33FDNaq7du0KqX5DYerwxNQRWRpUTR004eP/yaq6sbYKItILuBGYqqp7AVR1OrAFeMytXiLwIPCiqm5y1JsPfAE8FQ6xa9euDcdh6o2pwxNTR2RpAFOHO41qVFW1OohqFwECLPQq/wo4S0QSHOvnAM1rqNdHRHrXRysQcJSwsTB1eGLqiCwNYOpwJxL9VLMBO/CbV/kWDBewPm71nOXe9dy315mioqL6HiIsmDo8MXVElgYwdbgTiX6qqUCpqtq8yg85XlPc6gF430Xvei7y8vK45pprSE1NpWvXrvTp04eBAweybNkyWrduTUxMDPn5+WRlZbFhwwaWLl1Kx44dWbFiBW3btgWM0cXc3FxWr16N1WqlZ8+e5OXl0aFDByorK9mzZ4/rmHFxcWRkZLB27VoyMjIoKiqioKDAtT0hIYF27dqxYcMGunXrRkFBAYWFha7tiYmJpKSksGDBAlJSUtixYwfFxcWu7SkpKbRo0YKtW7eSmZnJ1q1bKSsrq/WabDYb/fr1q9M1LViwgNLS0qCuad26PDK6dGb//n0UFh4gO7sfK1ctp1XLRFJS0ti6dTs9e/Ri1649FBeXMmjQoKCvadWqVRQUFNR6TTt2/E52dhar81ZisSiZvXP55Zc1Pte05KfFxMQKnTp25teNm+nUOYOSkjIO7C9k4MDB/Pzzz8THJ9C2bTs2bthIly5dKSjYz8GDBymvKKagoMD1Pm3atImePXvy+++/U1x8iP79c1j281KSkxJJTGzNtm2/+VzTj0u+JjGpGdHRMezevZusPgPZunWXzzWp2tn++way+vZj3bp1WK1WunXrwYKvPsEaVUlFRRn79u2hb1YfVq9eRWxsNG3bpbN58ybatm1NSUkxhQcP0KN7VzZsXE+zZjEkJbXi9x35pLdOo6i4mNKSUvrnnM6mjQd8rml7/hZ27/uRLl26sGXLFlq2TCajw1DX+/Ttt9+6PgeLf3ifFi2iiI6JZd++/XTr2p3t239H7dCjRy82bNhIWlo6Foli79599M3qx/p1G7BYrXTp0pl169aQnp5GZWU5BQV76d27B2vW/kJMbBTprdPY9tsW2rbpQIw1w+ezt3XrVn77/XuSUmIpKSmjrLSc4wf9gbVrfvO5pt+2b+TAwa1kZvZl3br1JCUmk5DQir27K4P6Ps2ZM4dly5aRnp4OkOG0M2L0sTYuIjIDGK2q4mfbF8CJqtrCq/x64FVghKp+JiL/BG4AUlW1wK3eGcB84CZVfcn9GJMmTdJJkyYFrbOoqIgWLVoErhgEqordBnY7rle1q8e6zaZYrFW0TIrCaj38e+fUsWlNAVu27qK8DKxRVURZq7BGVaNqw25T7HYbdpsdu12x2+1GmSpKJc3azEfV7lhs2B2vVQUnYivriN0u2Kqt2KqjSE/rRcsWSaCgjgWgqHgPm7fuxmazYLFUUxW/kRuuvQrvW/T75mq++uJzbLYK59U7FkAUxe5WbgcUEUFEsMcvQOI2Y7FEYZEoLNZorBKFVLfFfvB0RIx7hVqJj2tDekqucQ/txv1Vu7F9+47/YbcLaBTVcV9w1Z/vJDa2pYfOijLl/df2UVlVBlgQtQBWwALqeMWCYPV5P6ujNlKROpHYZqXY7dXGvddq1G6j2d4Xsdg6oNhAbEA1CQmtsVotiIDFAmIRLBYoKdtNSekuFAUpp89p6zgue7zP+VZ8d4CVy5cCdqOu6945EbdXcfxnvJa3nIZa9/scM6psGNFl53sco2VCB1omtHe9O85/bLZKdu1b6Tq2JfkDrr7y8NCF8zN6YI+N+R/kUVZeYOgTu+P9PvxeI+7rh8uqY36kOs67Nw/QGGKLbjbqGX9ERyWQ2f085PDlIkBlVRW/7fiOA4V7EYFqy+8MPesk+vQ8xeew38zbyK+bf3TdLQBLVDWjbxztqyEAIvKwqk6CyGyp7gOai4jVq7Xq/EYUuNUDaOFW5q9enVm2bFlQfm3+OHTAxsIPdlNyIB61G1/OYFizyc6q30v46IPDDW2njuVfQ0VpRshayiurmDPzAKOu+LvPtmaFFxJdbnzgnCr358N+vB8UAFJIijms667JxzHsVOjf37PWwQLFUjK0Tn1Ls989ma79n6BP9g8e5daKVjQ/cLZHWdEBKNrhv5vewnGu8y/8JpPfd1mZ+KBXJYHqiuZYaB6yzo3rezHjmaf465TLfbaJJiDawviaOixT6SG3Fdz/T8NKGgBVtgrmz7MxKMu3oVO4V4iqOClknQBPP5LDdX/5M62S9nmUW2xtiaoc7FFWuh9K99vxJYooBrrWFs2PIrdPFVl9jfWl//uRoUOHUlFip+pQd6LoHrLOr786k/KEVE4787+eGzSamNKLfeqvX+7vvRdgCM6Bl182WvjLRyV8/qnTkB9mz9ZkYssu8iirspegdjtiqXvPaCQa1VXAn4COGD6tTroA1Rg+qc56YDS7veu5b68zCQkJgSvVwPz3N1G+v33oO2oUu3fZsFdUgdrApsSJFdvBIoS6PVWoPZofvhnp16h6f9BCJXrbFqqjq0EsiEVAQPfGA3W7d/v3tqNNqb+nA5+HmqCpqoynYFMBtrW7wWpFoq1Gc7HcDiTV6Zg2GzRrVlLDVt+WbTBUVsbyysu53HPqauNyFcejgh17QTKHe7xC41BhawjzXJvVK45jyw97yIwpBSBufxG29VupLojBT89bUJSXx1Nujfezpe7vPYClshLbr9vAZjfup93R0q9u5be+ffc+rG1b1/l8kWhU3wOmAEMx/FmdDAO+UNVix/o8DN/VocAir3prVHVdfYW0a9euzvvu3p5CK3+fjwBYrbAv30b1/O+Q6CgkOoq2hcXoyvWIrT0QF/IxLRaoKK+pNeavVRIcCjRPbYY0r3Z8+R3lUvcvgb3G737dWw5WC6hFIDYasVhBDOMv0cEbP8WGqlJVFYXdDqXlQlxccQ2V62ZUVaGsPA5JTEBtdqh29AsBRNXjqyrQJiGDVs1bYxELFrEiWKmobk9ZDZcQDNYoQazGtbZv29a40fVAAQsJJESlGBolCgtWxN6CqroeVCAaCxT5/gCKH2NtwQKW+hnxiDOqqrre0V96v4h8rKr7RGQM0A24yq1eoYg8CtwpIv9W1c2O/tSzgZHh0LJhw4Y6G9bYqBg/pYrVolgELBY1+tasUFZ5iPzfk6m2Cbv3Wdhf0oKY84e69tq8aBGdTh1Eetluvl64n317W1FVZaGqykLuwG2071Bk9NUJxpfGAhXlUbz+Rh9sdqNVVV0dw+m9HyU2zopYorBERSNWKwf2teK7bw8x5+1UYmLsxMTA8ScoV1xhNfo5wTBAAnm/rOK7xb05dMhCVSVk9bOT2Kct1mTPq+yQaGftPhv/+LvDfonRRXDbbUafJ66ZJ8YXafprsHy50d+49XcLN/W/l4vPvdnRV1mN3VZFcZGyZd0+nv57W+wK1TYhOlp5emo1FitYrIJYwGIRLFbh3feF6f+yYrNDQaFw9TVtsHb1/LJEq3LhDcopp8KmTeLom4WflkLPnsb7hdhQrUaBxYuVURfHYbGCoAwY2Jk/Xzwfi8WKqAWxCxYVbOXwh0tj+GFJFBaLYrXAm88WcmJuJVptw1ZtR6vtqB2KS4VzbmiPiGFUS0vFaPVHWyE2BnG8sdnZVtZ+ZONfbzV33dMRZ1QweMAq+vbqZdRz46qbEigtE1AoPCSMHPIkrZwdYwKIUFwEH30GT/w91vW8MuSEav56e5mbuVHXD+a9j8bzc140qvD7bgtR8TFInPF+btyxnfadOpLSxkJ2VilX/V+S8fkWSGpl519PHTSOpm4NcIQP5sXy/ufNEIH8XRauvuRSrjhtJIc/0BbsNuHXX+1MeCSW4hLBIorFChMfsNGipeD8kCrC5s2bKS/vyttvG+/n/oPQqUc61gGtHT/66nrNjbHxj38Ia9eJS9ttN1uxpEYH+HbXTqMOVInINIxZT50wnrtWOjYNVtVKt3rRwEPAJRgzpIqAe1T1Wz/H/AvGZIFqwAY8rKrv+zt/qANV27dvp2PHjkHXd2K323j1zYupKGlH4e4cFi+4ji+/j+LfL5dx5ZWOFpNby6O8ooQFC6y0axtFmzZRpKV5NkzqoqO8HObPh5ISYwG4+mqI8WPrbTZcAyi1EYoOVUNDWZmxWK3Qpo3/ulu2QGHh4fWMDEjy81ReXQ2rV8Pu3bto27YNVivUFJDowAHYvx/XF7tVK//HBDh0yKhjtRpLTIyxHoja7se8ecZ1HToEBw/CjTca1+WO2hW7TTnzbKFFC6FlS2jZEp5/3v/59+6FggKjTosWEB8Pv//uX0NhIVRVHV46dvT//u7aZdxTm81Y0tNh0CD/1/vJJ7B9++G6F14InTr53ouyMpg1y7iP0dGQkADnn+//mPv2Ge9TTIzxmW/VCp+BTyc22+H3sybq+p11Dsg6f7BCxX2gqklG/5uKUI3qihUryM3NDfk8ZeX7eWPuGQAUHUokJqYFt475IKDRCreOcGPqiDwdkaChsXSoqk9r0+NVlVWrV5Gdm3u4j7+RiPTR/4ih0L35FAKlZYcdD1q0LCSxZWKdDWp9dIQbU4cngXSo3Q5V1a5Fq53/26CqCq12NPns6mj+Gf0P6ng11g+XY7Mbx3RbT9y+naoNu/xuc39VZz+Q+zbnMb0aVt5dCR5NN/FXJnQuLaXis5+MazkcWMRt4fD/dndfPcc2u9e6z2tw9AIq/rPgcIHF6E7BavHoUnD/X7zWsVggLpbYW64I/sRumEa1FgYOHBi4kh/KKjx9AuOaJddQs2F1hJsjSYeqQmUVVFahjleP/6ttUG1Dnc+y1c7OZ2NdXf/bjX4Hm/2wEXRsG1xeQcWKN416TiPpZkRdg0wNSBvAtnVPWI9Zl2fXOECLy8OqIyzYFXC8ZzXg93qbN6vzKU2jWgt19VMtK/M2qnVzMamvjnDTWDrUZofSMrSkDIpL0RLH/yVlaEkpB7b+RmxKymFDWeHHaFbWebw4aCzU1yHNJGI5yvxUG4ytW7cyadIkhg4dGpRxSExMrNN5fFuqdfOFrK+OcFMfHVpShu4rRIuK3QzkYUPp+r+4DMpqb/G0Buy/7a2zFpMjHJdLivsrIILdbjec72r2zQvyHMH3xy5atAjcpqkeU0Y1IyODUAaqUlLq1sL86ZsO5G98BInZQ3TcLrq1yajTceqrI9wE0qHlFei+A+heY7HvO4Du2Y/uOwClEfho2BhERUG0FaKjIMrwOybKagyLR1mRKMdEBKvF4X5gMXw/LQ53BOc2x6tYHPUc2w8cOkhSSorbNmddq5/9LD7Hw2r1NCDeA9fq3qepbi/qUbRr507atGt3uG/SMe3Y6RPsGlb3Wby3ga/BdPgVB2Ho3Ef/1a6Oecvq6EN2vKrnurqvO/8PYcKBo4G21bl+TBnVUNm0aVOd3DP2be1OZptE1/qPi/Zw5vDG1xFuNm3aRIf0NmhBoctw6r792PfsR/cegOLSppboidUKMVEQHY3EREFMNMTEGP9HOYyb89XqMHDRUYYRcpRhtXpudxqiKCsrf/mF3EEDjX0cizgNZrRjn3pMhAiGXxYtYuhJuQ16jmDYsHY17XJrT/zXGLh/V4zRf2vACW7hfodMo1oLPQ0P8JAR9XQebpnYNDrCgVZXY1+5HtuyNRyXv4uKD5c0zombxUBcMyQ+DomPg4TmSIt4JKE5ByvKSExLM4xkbDQSE+MwmNFIrPFKdDRSzxk+gWiTGIelHrPuwkFTfjbcMXUcxjSqtbBjx446zaiKifI0qilpdZu2WF8d9cG+9wC2b5dh+3mN69G9XldhtUDLBCShOdK8GcQ3RxIcxrJlAtIiHlq1wNIy3jCmtRjELUuXMmhQ3/qoCQtN8b5EogZThyemUa2F4uK6TYxumeDpStMpI7ZJdISC2u1ocRn2vI3YluahW3eEfhARaBlvGMnEFkhKIpKWjKVNCqQmI81jXXPF60Nj3I9giAQdkaABTB3umEa1Furil2mz2Ynxmvc/eHDdo13VVUcg1K5QVu4albetWod97Ra/gSd8cLYuWyVAUkssqYlI6xSkdTIS1wyaxYTFeNbEkeQveyxoAFOHO6ZRrYW6+GWWFJcibhGVVA4RE1vDpPcG1OGNqkJ5heGyVFKGvaQU3bMf+9rN6JZ8w8m9JmKisfToxHItY9DZw7HEN4fYGCPgR1TDGc+aONb8diNdg6nDE9Oo1kJdXJkK9x8EEl3rEnUIkbaNrsMdtSu6Jd9weaquRjflY1u7GQoKa98xuRXWPl2RzG5YO7ah+ZZNWDvW71rCwZHiYnasaABThzumUa2FuqRSKTpYjLtRtUTX382ovilddNde7Lv3YV+7BfvGbbXPNrJYkK4dsGR2RdqkYklPQZJaIiJhSy1TX0wdkaUBTB3uRGI21Yhh69atIe9TXFTmsR4VW3+n97rocGL/bSdVsz+l+p352H/5tWaD2qI5luOyiPrTuUQNPQ5rZlesPTtjSW7l8rWsj45wYuqILA1g6nDnmGqphjpNNTMzM+RzlBZ75s2JblZzIIdgqYsOAPuhYir/9S4cqnnwSTq2MVql7dMRiyAJ8UibFCTWN/BqXXWEG1NHZGmAY1uH9zTVY6ql6pymGmxHdl1+9Vb+7DnP//ff6zfvv6461Gan+oOF/g1qsxgs2T2JuvRsos46CUvHNkhcLJbO7bB0buvXoNZVR0Ng6ogsDXBs6zCnqYZAWVlZ4EpeVJTGgFvUsIIDoWfqDIcO26r12Fd4pumS1EQsfbsjXdofdnmyWg1XKEe/abh1NASmjsjSAKYOd0yjWgt18nmze86mSmhZ/+BwoeqwFRRi+/w7z+AYzZthPfcUJMahTwRJboWkJQXtUxoJPoBg6og0DWDqcOeYevwPlWXLloW8T7TF06gmJtf/FoeiQ8vKsS36Cd3jGX7QemKuy6BKi3gs3TpiaZMakpN+Xe5HQ2DqiCwNYOpwx2yp1kLr1qHn/j770ijytx1iX34ZxeVRnHZKYqPpUJsN27qt2H/K8yiXTm2xZLRDYmOQNqlIQt26JOpyPxoCU0dkaQBThzumUa2FGH+pRwPQN6cVfXNaYdt7AGta/QepQtGh+XuwLV7m6TYVHYX1xBxjHn56Sr1C0dXlfjQEpo7I0gCmDnfMx/9ayM/Pb2oJQHA67HsPYFu7Cd3yu0e5ZUAfJLGlMTe/nrE9j6T70RhEgo5I0ACmDndMo1oLWTUllW9kAunQkjLsv+/G9v0Kj3JJTcTSpxuW1slhSdd7pNyPxiISdESCBjB1uGMa1VrYsGFDU0sAateh1dXY83dhX77WM/K+gPXk/kizGEgMz9S9I+F+NCaRoCMSNICpwx3TqNaCrZa0to1JTTpUFc3fje4uwJ73q8c2S9/uSGqSMXc/TCk9Iv1+NDaRoCMSNICpw51jaqAq1Gmq/fr1C+n4i7/5ldUrC0lOsZPWspJeAzrRvl2nOqoNrEP37MdeVIpt8XJPn9T4OKMvNS4WaVm/WK7B6GhsTB2RpQGObR3mNNUQpqmuWLEipOMv+UZoWZlJ9c6+7FzfnxefDM/t9adDi0rQfQeMeKj7Dnhss56Ui0RHIa3DGwYt1PvRUJg6IksDHNs6vKepHlNGNVTatg0tdmhVuWfDPzq2uoaa9dOhlVXY83ejJaXYl/3isU0y2mPp1BaJb15nf9RgdTQVpo7I0gCmDndMoxpG1OY5m6p5Qi3R9Ot6DrvRj4rdju2HVVDlZrijo7CekA2ApDd9sF4Tk2MR06jWws6dO0Oqn5LYzGM9tXX9Ev7506G796Fl5di37UC3eSbnswzqa6R0bpmAxIXn3DXpaEpMHZGlAUwd7kSkURWRQSLymYisFZHVIrJERC7xqhMtIo+KyDoRyROR70VkSDh15ObmhlQ/Pc3TqF48KjyPIk4derAI3X8QrazC9sNKjzqSloSld1fj/9bJYTlvTTqaGlNHZGkAU4c7EWdURSQDWADsA/qpaj/gX8DbInKBW9XngMuAU1Q1y1HnCxHJDZeW1atXh1S/vNQzIlWz5uFxZVq9ejVaUYl9x14A7D+vgRK3EGciWIcMMIJMJ7WsMR5qOHREAqaOyNIApg53Is6oAiOAlsAzqloNoKovA4eAKwBEpBdwIzBVVfc66kwHtgCPhUuINYQITrZqpari8LoIxMaFR4dFBN2+C+x27HsPYF+zyXN7Vg8kuZURzi+tYVqpENr9aEhMHZGlAUwd7kSiUXWOvLiG0sXwXrcAzjt2ESDAQq99vwLOEpGwOGf27Nkz6LrerdTYOAmb032P1m3RikrUbsf23c/gfqoWzbEM6A1gBE2JbjjX41DuR0Ni6ogsDWDqcCcSjeocYB3wVxFJEBEL8AAQC7zsqJMN2IHfvPbdgmGM+4RDSF5eXuBKDsrLvB7948NjUAHyVq4CwP7LJig46LHNelIuEhVlZEFNTQzbOf3qCOF+NCSmjsjSAKYOdyJuRpWqHhKR4cDrGP2qxcBB4ExV/dpRLRUoVVXvOWmHHK9h8Sfq0KFD0HWLDpbi/hvVLIwuoh1SU9GiUqMv1Q3p2gFLhzbG/6nBR/Cvs44Q7kdDYuqILA1g6nAn4oyqo790AfApkAyUA5cC74rIVar6WV2PnZeXxzXXXENqaipdu3alT58+DBw4kGXLltG6dWtiYmLIz88nKyuLDRs2sGnTJlJTU1mxYoXLqXjnzp3k5uayevVqrFYrPXv2JC8vj/WrWpJAr8PnWreZhB+LycjIYO3atWRkZFBUVERBQYHrnAkJCbRr144NGzbQrVs3CgoKKCwsdG1PTEwkJSWFxd//QHpUErHVh39Dqi3ClrTmNP89n627dtH3zNPY9uOPlJWV1XpNNpuNfv36BXVNHTp0oLKykj179jBw4EAWL15MQUFBWK5p06ZN9OzZkx07dlBcXOzanpKSQosWLdi6dSuZmZls3brV55q2bdsWtmtatmwZcXFxdbqm+Ph4Fi1aFJZrquv7tHjxYoCwXVNd36elS5eSn5/fYJ+9YK+puLiY/Pz8BvvsuV/TnDlzWLZsGenp6eA2TVVU659DKZyIyNsYg1VpqlrmVv4ecDLQDvg3xsh/jHtrVUTuAJ4GjlfVJd7HnjRpkk6aNCloLYsWLQp6Sus/Hv+V1JjDLlRrfivksX+0D/pcNaHV1ax8fga9f/NKj3Jyfyy9uwBgaZtmDFQ1MKHcD1PHsaPB1AEi8rCqToLI7FPtB+S7G1QHG4A0oAuwCkN7R686XTAGutYQBkJJIlZR5tnoj4oJzxRVPVhMrz2eaaYlPQXplWGsxERDUsuwnCsQkZBUDUwdkaYBTB3uRKJR3QO0FRHvronOGOPeB4D3HP8P9aozDPhCVYvDISSUJGK2Ks8pqs2ah2eKavXn3yHlbr5aFjHipDo8Cyytk8PmZRCISEiqBqaOSNMApg53ajWqIvJTYwlx4zkMP9VHHK5UiMgw4GLgLVXdp6rrgX8C94tIqqPOGKAbMCFcQuLignc0bdPjc7YWfcTm/T+wZe96everv123b92BfalnwBRLv56Io2UqzWKRVuEJQB0ModyPhsTUEVkawNThTqCBqlwR+R/wJjBbVfcHqF9vVPUdETkHuA9YIyI2DPepCcCzblVvBR4CvhORKqAIOEtVV4RLS0ZGRtB1W7b9iorYw70OJ572er3PX/3Zt14niceS29u12thBU0K5Hw2JqSOyNICpw51Aj/95wFVAOvCDiLwnIhf5eTQPK6r6uaoOU9VMVc1S1WxVnaaqFW51qlT1r6ray1HnRFX9trbjhsratWuDrltW7vl7E9esfjOb1GbHvsUziZn1pP5IlOE2JfFxYQ/tF4hQ7kdDYuqILA1g6nAnkFG9QFV/VdWJqtoL+BtwPrBBRJ4XkcENL7HpCPZXT1XDb1T3F4KbCxXNYrG0P5zTvClC+0VCKwBMHZGmAUwd7tTa4lTVfK/1b0RkB7Af+AswXkQ2YnQPvK6qO3yPcuRSVFQUVL2q6hJs9krXepS1GdFR9WtF6u4Cj3VJOtx3Ki3ikbhm3rs0OMHej4bG1BFZGsDU4U6ggarXHK9JIjJeRL4H1gO3AO9jzME/EygBPhORsQ0rt3EpKCgIXAkoLfNspTZrllTvEXnd5WVUEw+7TTVVAOpg70dDY+qILA1g6nAnUN/oOSLyLoYzfgzwHTAeYxTefRL630XkBWAZ8EqDKG0CgvV5+z3/IAW/nUNswnbiWmwjLrb+Rs++e59ngSPNtCQ2XGi/QESCDyCYOiJNA5g63AnUp9oWyAKmAN1U9RRV/aeXQXVyAYZzfsTizKbqyH4YkGB93pZ+F0dGzATaVr5MYsFnrPriyXqoNPB5/E9s6Qjtl1TvY9eVSPABBFNHpGmAY1uHdzbVQC3VPFXNDvLY3YCH66SqkXBmUw2WhITgIggWFUKS28+TzV6/qb9qV799qpLcComJrmGvhifY+9HQmDoiSwMc2zq8s6kGMqon+SsUkZaqesi9TFWn1VNbxNGuXbug6pWVWHEbR0Kiqup1Xi085JHQzx4dBc3jkNSma6VC8PejoTF1RJYGMHW4E+jx/0IROSAi3nFLPxeRf4tI4w9BNyIbNmwIql5MlOeU1Ng474iEoaG7PPtTi6MtWNKSXD6qTUWw96OhMXVElgYwdbgTyKheDbwGZHqVj8AY8Z/aEKIihW7dugVVr10bzy7mocPrN/HM+9E/Ki0JSUms1zHDQbD3o6ExdUSWBjB1uBPIqLZR1btU1SNMkqoewJgmOrShhEUCwbpnVFd6poNOSqlfemhvo3qoeQxiafrYN5HgrgKmjkjTAKYOdwJ9U2u0Do6kfE0fvaABKSwsDKqevSreY71lq/p1ltu9Hv/3xzS9QYXg70dDY+qILA1g6nAn0Lf1kFdaaBcich5GmpOjlmB83lQVtXlGimqVWPeA0aq+I//dTz6+zscLJ5HgAwimjkjTAKYOdwIZ1Ucw0ph8LiKPicidIjJZROYB7xLhLlT1JRift/LyCkQPj9cplSS0qEfQ6IPFUHF4yivRUSzbuqnm+o3IseyL6I9I0BEJGsDU4U6guf8fi8ifgKcwpqM6+Q24QlU/aUhxTU1iYmLAOocOHATcHvetB7FY6u76ZPfxT21JUmrTTEv1Jpj70RiYOiJLA5g63AkYwk9V3wHecSTkSwWcQaKPelJSAhuzjRvLcDeqZRX1i/ivXtNTJSUxKB2NganDk0jQEQkawNThTtAjIKq6XlW/czeoInJLw8hqGEKdprppU+DH7u1bPXNR7dhZvwR8PoFUWqcEpaMxMHV4Egk6IkEDHNs6Qp2mCoCIpAFd8fUGuA14PjzSGp5Qp6n27NkzYJ3C/Yp7D2qVvX4J/3we/9um0rND0//6QnD3ozEwdUSWBji2dXhPUw0U+q+ViHwA7AK+BxZ6LU3vaduA7NgRODxsabHnLCex1n2Kqqr6zKaytG8dlI7GwNThSSToiAQNYOpwJ9Dj/1SgHDgP2Ayc7liuBJZgeAcctRQXB07e139wHIXV+9lTVMjuwmI6dqtHS7W4FMrKD69brZCeGpSOxsDU4Ukk6IgEDWDqcCfQ4/+JwGBVrRSRIlX92rlBRD4B3m5QdU1MMD5vp5/dltPPBtueAiQpEUt03efnezv9k9QSS5Q1InzvIDJ8AMHUEWkawNThTqCWqk1VnU6THgZYVYuApg8J04CE5PNWXV0vgwqgezxjBlhSWoWuowExdXgSCToiQQOYOtwJZFRVRJyGc4eI3OrcICLXAfUb6o5wQnLPqF8IVeMQXi1VaZ0Suo4GxNThSSToiAQNYOpwJ5BR/RJYJiJdgH9gpE0pFJH9wD8dy1FLixYtAlcKIz6BqdukNomOmjB1eBIJOiJBA5g63AlkVB8CcoFtqvoZRnrqT4CvgOtVdUrDymtatm7d2qjn83Gn6tC6SXTUhKnDk0jQEQkawNThTqCBKmd21DeBAw7D+lnDSoocMjO9w8h6Ulpayi+/bKBDpzjiy6uJtydjtdQt3YmWlEGRW4RFiwVpkxaUjsbC1OFJJOiIBA1g6nAnUEv17xhO//WbexkhhDqjKtCv3opl+9nwTQ++mtmBt+d0ZspddQ9O7f3oT2ILLNFRQeloLEwdnkSCjkjQAMe2jlBnVK1S1b80nJzGJdQZVWVlZbVu37WjwvV/XDPByOJdN7wf/S2piUHraCxMHZ5Ego5I0ADHto6QZlQBa0SkbU0bReSo7goI5PO2f59nA77KVo/ZVN6BVNKSg9bRWJg6PIkEHZGgAUwd7gQyqu8Cc0XkDhEZISKnui8c5dNUA/m8aXVzz3VL3WdT1TTyH4yOxsLU4Ukk6IgEDWDqcCfQ479zxtQJjld3b0whLN6ZkUvr1q1r3T4wN421Sw+3Ts85N7WW2rXjM/Lf/vC5A+loLEwdnkSCjkjQAKYOdwIZ1U3A9TVsE+DV8MqJLGJiau8jLS/1/E1Jbyt1Oo+WV0Bh0eECEaTd4Q9HIB2NhanDk0jQEQkawNThTqDH/1mq+nUNyyLghYYSJiKjROQbEVkmIptFZKmIXO22PVpEHhWRdSKSJyLfi8iQcGrIz8+vdbu3UW3WvI5G1Xvkv1UClpjDrlmBdDQWpg5PIkFHJGgAU4c7tRpVVX0owP4zw6jFhYjcDkzASNkyEOgFbACGu1V7DrgMOEVVs4B/AV+ISG64dGRlZdW6vbwkPEbV59E/xTMdSyAdjYWpw5NI0BEJGsDU4U59cx9/ERYVbohIBkbIwbGqmg+gqlXAXTgCYjtSu9wITFXVvY4604EtwGPh0rJhw4Zat5eXeRnV+PC0VKV1ssd6IB2NhanDk0jQEQkawNThTq19qiLyVYD9u4dRi5OrgUJV/cm9UFV3AM4ItBdh9Oku9Nr3K2CciCSoar0DK9psthq3qarv439cXY2qV2DqNp5BIWrT0ZiYOjyJBB2RoAFMHe4Eaqkeh2G83JcEIBvoAyxtAE0nAVsdfarfOvpMvxeRa93qZGPM8vrNa98tGD8UfcIhpF+/fjVuKzxQgrq5qdqpIiq6jkbVOy9Vu/SgdTQmpg5PIkFHJGgAU4c7wcyoGuZdKCJWYDxQ2ACaOmJM+boLo0W6BxgFzBaRtqr6GEZW11JV9f5ZOuR49Rv/Ky8vj2uuuYbU1FS6du1Knz59GDhwIMuWLaN169bExMSQn59PVlYWGzZsYOnSpfz5z39mxYoVtG1rzIHYuXMnubm5zPt0OTDYdex9+6NYs2YNe/bscR0zLi6OjIwM1q5dS0ZGBkVFRRQUFLi2JyQk0C61NUn7D+I0xwqUtIrj50WLSEw0MqnOnTuXSy+9lB07dlBcXOzaPyUlhRYtWrB161YyMzPZunUrZWVltV6TzWajX79+fq9p9erVWK1WevbsSV5eHh06dKCystJ1TTNmzODEE08MfE3t2rFhwwa6detGQUEBhYWFru3Oa9q0aRM9e/as0zUtX76c9u3bh+Wagn6f/FxTaWkpzZs3D8s11fV9mjlzJueff37Yrqmu79PcuXMDfp8a433aunUrqampDfbZc7+mOXPmsGzZMtLT08Ftmqqo1t3VVES+VtXT6nwA/8f8FWNSwSmqutitfC5wDpAGvA+cqKotvPa9HsPNa4Qj+IsHkyZN0lCmqa5fv55evXr53fbx+1s4uOmw29O2nVU88FRi0Md2Ys/fReUz/z5c0DKBZpNuClpHY2LqiDwdkaDB1AEi8rCqToJ6DFSJSGsaZkaV02FzhVf5cqA5xqP9PqC5o8XsjjOxqZePUvjZt8ezkVxZXbfZVD6P/imJdZVkYmISAQTKpvovP8vrIvI+kIeRYTXcrKtBm82tfJXjtaNXnS5ANbAmHEJ27txZ47bElN1s27uF3wv2se9gKTHxhXU6h487ldfIfyAdjYmpw5NI0BEJGsDU4U6gPtUrOTzi7sSG0c/5GvBEA2j6CLgcYzBqsVt5FlAG/AIcBKYAQ4EZbnWGAV+EY+QfIDc3t8ZtHXrksav8Fdf6CX2vBW4J+Rze7lSWNr5TXWvT0ZiYOjyJBB2RoAFMHe4EjFKlql28lu6qepKq3q+qhQ2g6S3gJ2CyiCQAiMgpwB+Bx1S1RFXXY6RyuV9EUh11xmB0R0wIl5DVq1fXuK203DN2alwz3xZmMPhEp2qXFpKOxsTU4Ukk6IgEDWDqcCdQS3VUo6hwQ1VtInIORiv4FxEpByqAW1TVPdbArRjpXr4TkSqMvtizVHVFuLRYrTVnRy33MqrNm4WecEyrq9F9hR5l0j7dp15tOhoTU4cnkaAjEjSAqcOdQEb1kIiMxEhV/YmzUEQuBxaq6u6GEKWq+4EbAtSpAv7qWBqEnj171rittNzzsT2uWVINNWtG9xwAd++LhOZYmjcLSUdjYurwJBJ0RIIGMHW4E+jx//+AOcClXuUnYGRZzW4QVRFCXl5ejdvKfB7/69BS9X70r2HkvzYdjYmpw5NI0BEJGsDU4U4go3oeMExVR7sXOlKs/Bl4qoF0RQQdOnSocVtp6UGP9br0qQYz8h9IR2Ni6vAkEnREggYwdbgT6PFfVPVHfxtU9SsROaqNamVlpd/y0tJymv3+MbYyOyVl1ZRUlBN9WauQj+8c+T+Ykc6e43pTGRMFNUQuj4SI5mDq8CYSdESCBjj6dERHRxMXF0f79u1p3rx54B0cBDKqSSJiUVWfbKoOx/u6DXk3Ec5sqkOHDnUm66qVPXv20KePbxiBbVsOAfHEx1mIj4vhwKFooqJCn0ehuws4mJHOrpOy6Na7F82bN8diqW/gMBMTk/qiqlRVVVFYWMjGjRvp2LEjycn+zZ13NtVA3+DvgJki0t69UETaAW/g6Uca8TizqQZjUKHmJGL5+eUe6yVloWfwVpsN3bufPcf1plvvXiQkJJgG1cQkQhARYmJiaN26NV27dq11UkGo2VTvAU4EtonI7yKyWkTygW0Y0aTuqaf2iKamx4i9uzy7BSqqQ8+iqvsKwWanMtoa0qOFiYlJ45KQkEB5eXngig4CRf7/HRgAPI4RZq8ZsN2xPtAR4/SoJS4uzm95pw4HPNY7dP495GO7ZlKJmC1UE5MIRiS0kJ6B+lRR1QPAg47lmCIjI8NveWmJZzCV1m1DnxXr7U5lYmJydBAooEqqiIwUkfO8yi8XEd+pP0cZa9eu9Vte4RXxP7YOT+/2XQ0eSMvExKQJMJ3/a6GmlmpFuedUuObxARv8PvhkUDU5YnnxxRfZuHFjg5/nrbfe4ocffgh5vyVLltCzZ8+gB2hN6ofp/F8LRUVFfsurKzxziye08J1aWhtqt6N79geueITy888/M2rUKHJzc8nNzaVv374MGzaMiRMnsmvXLsBwV8vNzSU5ORkRITc3l9dffz2o40+dOhUR4ccf/bpQA7Bx40ZGjx5NTk4Oubm5ZGVlcdJJJ3HPPfd4GMBBgwbRpk0bRIQ+ffrw2GOH80Z+/vnn5ObmEhMTQ0JCArm5uaxYscLjPDfddBMLFiyga9euAIwbN47u3bsjInTq1Inc3Fz69OlD9+7dGTNmjN9R5C1btjBu3DhycnLIyckhIyODwYMHM3HiRJYvX+6qd8IJJzB69Gjee++9oO6TzWbj4Ycf5qqrrmLPnj1B7RMOqqqqmD17NsOHDyczM5O+ffsyaNAgZsyYgXtQfFXlk08+YeTIkfTq1YusrCxycnL429/+VqOP+BGBqta4AMsDbP+5tu2Rtjz00EMaCgsXLvRbPvPZdTrzqWLX8uuGjSEd17Z3v5bd/oSW3f6ELl26NKR9I50VK1ZobGysPvvss2q321VVtbq6Wp9++mkFdP78+R71R48ercbHMHiysrIU0PHjx/vdvmPHDk1KStK7775bKysrVVXVbrfr7Nmz1Wq16quvvupR/6GHHlJAt2zZ4vd4nTt31tNOO82nfObMmZqWlqYlJSUe5QsXLlRAX3/9dVfZ9u3btWfPntq5c2ctKipylX/++efaqlUrfe6551xaVVUXLFig7dq1U0APHDjgKl+0aJHGx8frb7/95lerO4sWLdI///nPeujQoRqvoSH44YcfVER01qxZrrL//ve/Cuhf//pXV9nOnTsV0CeeeML1WVm8eLHGxsbqVVdd1ShagyXQ9xSYpA47E6ilmiQifuscic7/oVKTn2plmedlJ7Ro6bdeTRzNj/5vvvkmzZs359Zbb3WNmlqtVu644w6ys+vfW7RkyRJ69OjB0KFDmTNnDhUVFT515s6dy4EDB5gwYQLR0dGAMYJ7+eWXc9555/nUrytTp05l3LhxQbnEdejQgTvvvJNt27bx7rvvApCfn88ll1zCrbfeyi233OLSCnD66afz5ptv+hzntNNOo0+fPvzjH/8IeM6TTz6ZN954gxYtWgSsG25OOukk/vSnP7nW//jHPzJkyBD+8Y9/eLRW27dvzz333OP6rJx88slccskl/Oc//2Hv3r2NrjscHFPO/6Hiz0+1qqqaKPH8EkXHJIZ0XO8UKkcTVVVVlJSUUFDge41ffvklQ4YMqdfx33jjDcaOHcvYsWM5cOAAH330kV8NAL/95p1sF2bMmMHll19eLw1g5ELKy8sLqZ+yU6dOAK4ukGeeeYaioiJuucV/cPNhw4Zx7bXXEhPj2d00fPhw/vvf/3oYJ39ERQXu6//www/Jzc1FRHjwwQe555576N+/P+3bt+f5558H4LHHHmPQoEF07tyZF154IeAxjz/+eBYu9M4eD+3ataOkpMT1/rRp04bNmzf7raeqHDx4OL7GDz/8wGmnnUb//v3JycnhnHPOCbobpLEJdNfvwTCc20RkN7AfSALSMfxV6/cNaWRCnaaakJDgU7ZzxyEslljXenEpJCXF+NSrDXst7lTldzwZ0rEammbPhDa/Y9iwYTz77LOcfvrpPPTQQ5x33nnExhr3Ky3NNwB3KFRWVrJkyRKef/55qqqqSEtL44033uCPf/yjR73TTjsNEWHkyJFMmjSJUaNGud7LpKTQQzT6w2k0unfvHvQ+zr5cZ2K6efPm0aVLF2c2Th9EhNdee82nvFevXvz222/8+uuv9OjRI1TpHowcOZKRI0ciIsycOZP333+fJ598kn/+85+MHTuWbdu2cdVVVzFhwgReeuklbr75Zs4880yPEHuFhYXExMS4Wuwi4tHqdrJhwwZOPPFEjx8J7x8MZ71OnTq5+qmLiooYMWIEzz33HFdddRWqyr333ss//vEPLrroonpdfzgIaZqqHmXO/6FOU23Xrp1P2W/bSj3Wi0vthOgbfFQ//l944YVMnDiRtWvXMmrUKFJTU7n44ot555136j348NFHHzFq1CjXFMIxY8Ywb948n0GYAQMG8NJLL7F3715XSvJzzjmH119/nZKSkhqPP2LECNfgmvuyY4fvx9zZ2kxN9U1/44/Vq1czbdo0BgwY4OqC2Lp1a40GtTacP07hzsfkbAUCjBplxKfftGmTq+ySSy5BVfn6669d+xQXF9O1a1f69+9f67GXLFnCqlWrmDJlSq31tm/fzmeffcaUKVNck2LWr19PYWGhy8iKCLfffrvPj2lTEeo0VVT1gKo+qKonqmoPx+tENSYFHNVs2LDBpywuNpo9B0s5UFRJWYUdm/r26dWG2vWoNqoADz/8MPn5+TzzzDMcd9xxfPjhh1xyySUMHDjQ7yN5sMyePZtrr73WtX7jjTdis9n4z3/+41N37Nix7Nixg1deeYXhw4fz9ddfc+2115KZmcnKlSv9Hv/TTz9lxYoVPou/H1enIW/WrGbPj4kTJ7pG/8eMGcNll13GV199FdRjeW04z7l7d3hjxLu3up3BQ9zLUlKMmMHOHxQwIjm1bt2a9u09egg9KC4u5rrrrmPy5MmceuqpNdarrq5mzJgxjB49miuvvNJV3qtXL9LT07nwwgt59NFH2bBhA23btq2x26Spqdf8SBH5IlxCIpFu3XwzcA88Pp3bH0nj5ocSGXPFIe6aEmJw6oNFUBl6rIAjjdatW3P77bfz1VdfkZ+fz80330xeXh73339/nY63Z88evv76a8466yxXC3LUqFHEx8fzxhtv+N2nZcuW3HjjjXzyySfs3LmTRx55hPz8fG666ab6XBpwOG1Hbf2ajzzyCCtWrGDNmjUsXbqUadOm0arV4RCRnTt3rpNhdJ6zvsbZG/cBN+fAkb8ym+3wjMLY2FjWrVvHV1995feYFRUVjBo1irPOOqvW915VueGGG0hOTubFF1/02NaiRQt+/PFHLrroIp566il69erF4MGD+e6770K/yEYg4LviGKS6AugKxHptHtAQoiKFgoICOnb0zoLtwGYDqxWLJbRnf/uu2qenhtqHGWksXbqU5s2be4RMbNOmDc8//zzz58/38LsMRGVlJVFRUVgsFmbNmsULL7zApZd6zkN55ZVXGDduHCtXrnQ9pjofF48//nhXvcTERB588EG+/fZbFi+u//iq87G9rKzMb997MIwYMYK//e1v7N692283QFlZGV9//TX9+/f32F5aWuqhIVKprKxk1KhR9OnTh6effrrGeqrK2LFjKS4uZvbs2X7zTHXu3JlXXnmFv//978ydO5cJEyZw7rnnsnXr1hpD8jUVgaapHg+sA+4AxmCkgB6GMcPqGqC0xp2PAgoLC2vcZi+tgGahDVDB0d2fCvDxxx/z73//2+82EQm6DxLgrLPO4ptvvgFg1qxZnH322T51nP2TM2bMcJX98MMP/O1vf/N7TIvFEpKGmnBGmK/PI/hdd91FYmKiT8vMyfTp07nssst8BnOcj981/uA3MgcPHnQZeidOg9qjRw+P92Ls2LEefcGqyrhx4zhw4ACzZ892tb4ffvhhl/fN6tWrXX2xcXFxXHXVVfztb3+jqKiIrVu3NvDVhU6gx//HgdGq2hZYq4401UAL4F6MNNFHLTX5qQJQWgbN/Uexqo1jIZDKSy+95DGYUV1dzVNPPcX69eu5+eabQz7eypUradmypcejs5MOHTqQk5PDrFmzqK6udpXPnTuXd955x7WuqsyaNYsvv/wyLH1xZ599NiLCunXr6nyMtm3b8t577/H888/z4osvuvSrKm+99RYPPPAAr7zyio/Hwpo1a+jXr19EGFXnQJX7d8VpUDdv3szAgQOZOXOma/nmm29cvsWqyvjx4/n4448577zzmDNnjqveggULXDMaCwoKePrpp13eE6rKd999R5s2bcjMzGz8iw6E1jIDCVjp9v9yP9sX1LZ/pC3hmlGlqlq99Xe1V9tCOp6qavk/3nTNpjoaZ1StW7dOH3jgAT3++OM1Oztbs7KytGPHjjp06FB97733XPV27typnTt31vj4eAW0c+fOPktsbKz+61//0g4dOmhaWppeeumlPucbPny4JiUlKaC9e/fWefPmaX5+vj766KN66qmnar9+/TQ7O1s7deqkJ5xwgk6fPt1j/4EDB2p6eroCmpmZqZMnT3Ztmzdvnubk5Gh0dLTGx8drTk6OLl++3LX9lFNO0VtuucXjeGPHjtVu3bopoB07dtScnJwaZ2o52bRpk1533XXat29fzcnJ0X79+ulFF12k33//vU9dm82mPXv21Mcee6zWYzoZOnSozzVcffXVru3ffPON5uTkKKDp6el600036apVqwKWXXHFFaqqWl5err169dJhw4a5jvnBBx8oUOPivB8rV66stZ7z+7d371694447NCsrS3Ny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j6KiImbPns3999/voXnjxo28/fbbTJgwoVZt//vf/8jIyHAl3jvvvPN44IEH6nKZRxSmUa2FZcuWUVKQRrc26XRtnUH7Fr1Yucy/gdTiUux5ngbX0qsL4u3keozRtWtXpk+fzvLly7nnnnv81lm/fj3bt293pRJ24jSGoaa/cSczM9P1f3x8vEcuqdmzZ7sMEsCNN96IzWbjP//5j89xxo4dy44dO3jllVcYPnw4X3/9Nddeey2ZmZmsXLnS77lHjBhBbm4uvXv35u9//zvPPvusK412uOjSpYsrRCVAcnKyT1lKSopPl0Pbtm1JSUnxedx359Zbb2XAgAEeP0QA9957L/fdd5/f7LbunHrqqTz88MOMHz+e77//HrvdzmOPPRbK5R2RBJz7fyyTkJBAlHjeoqQU/0bVtvQXsLtFs2qZgLRJQVISG1DhkcEll1zC+PHjefbZZznzzDOJj/ecqOd8DJ05cyaff/65q1xVSU9Pp7S0tM7nrunRfM+ePXz99decddZZHuXx8fG88cYb3H777T77tGzZkhtvvJEbb7yRwsJCnnvuOR566CFuuukmvvvuO5/6n376aYP7bXobRRHxW2az2TzK/HVzuDNp0iQ2bdrE559/7mGgv/32W/Ly8njrrbcCanvnnXd46qmneO2113j55Zfp1KkTDz74INdff33AfY9kTKNaC+3ataOZl39pehvfQSdVxfY/z9aKpVcGloTmdR6kCtbf+8Yba+9HdSfYvtKGSO76zDPP8P3333PNNdfw7LPPemxLTTVS1YwdO5aJEyfWehyr1Up1tWc822Aewb2ZNWsWL7zwgqu7wckrr7zCuHHjWLlyJTk5OYDRki4sLOT444931UtMTOTBBx/k22+/Per8NB977DEWLFjAZ5995mOg58+fj81m8xjxd7aCR4wYQUxMDFOmTGHEiBE0b96ciRMn8uCDD7Jw4UImTZrEDTfcQEZGBmeccUajXlNjckw9/oeaTXXDhg2kpXjeoh69En3q6dbf0T37DxeIYOnRyWylutGsWTPefvttysvLfVqBvXr1olOnTn4fo++9916P/sDWrVv7jESvX78+ZD2zZs3i7LPP9il3uki5eyz88MMPNT62WywW14/CkURlZaXHQKyTKVOmMG/ePD777DNXK/+f//wnH3/8MWAMUG3atIkVK1a4lnHjxgFGy3zFihWMGDECgD/96U+A0VI+/fTTef/99wFYtWoVRxPe01SPKaPqnKYazLx/gC4Z3RA9/LgvAh07+fZBebtRSee2WBJbIi0CZ1w9lujZsyevvPIKu3fv9igXEZ5++mk++ugj15cXYM6cOcyZM4cBAwa4yk477TTWrl3LunXrAPjggw/Yu3dvSDpWrlxJy5Yt/fYJdujQgZycHGbNmuXRIp47dy7vvHM4XZuqMmvWLL788ktuueWWkM4fCTgHqrZu3eoqe/zxx5k6dSpXXnkl77//PjNnzmTmzJnMmzfPx1MgGObMmcO7777rWl+8eDFWq5VTTz01HJcQMXhPU23yWU6NuYQ6o2rJD6t05lPFruWdF4t96thLy7Xsnqc9ZlBVfvat2g8cCuocR9OMqnXr1mlOTo4mJSVpx44ddciQIX7rXX/99X5nVH344Yc6aNAg7dKli/bv31//+Mc/6q+//upRp7y8XG+44QZt27atnnDCCfrkk0/q6NGjNTo6WnNycnT58uU6Z84czczMVEA7duyoOTk5Wl1draqq//rXv7RDhw6alpaml156qY+G4cOHa1JSkgLau3dvnTdvnubn5+ujjz6qp556qvbr10+zs7O1U6dOesIJJ+j06dM99h84cKCmp6croJmZmTp8+PCQ7+Ndd93luo+A5uTkaE5OjlZUVKiqamlpqebk5Gh8fLzGx8fr4MGDVdWYiVVbWU5OjpaWlqqq6p///Gdt166d7tq1S1VVCwsLFSPeh9/l9ddf99H5ySefaE5Ojsf15uTkuLY/8cQTetxxx2l2drZmZ2fr4MGD9f333w/5fkQCocyoEg228+4oYNKkSRpKQJUvPl3C3rV9XeutUoXzR3u2VKu/X071O/MPF8THEXXFeVh7dQnKlWrZsmWuEIMmJiaRSaDvqYg8rKqT4Bh7/A+VbhmZHuvNmvsaSZ8ZVD07Y0lLOmZ9U01MjnUizqiKSK6IvCoia0VktYisEZFnRSTNq16CiDwvIusddb5wZHkNG+vXbvVY9zaq9vzdaL5n/6ClVxckqXb/PRMTk6OXiDOqwByMTK2DVLUfcCZwFvCdiMS51fsvkAv0V9U+wI/AIkf+rLDgPQMoKsYz2IbtR68BqvatsXRuhwQIDWhiYnL0Eqnf/ntVtQRAVX8HpgE9gBEAInImcA4wUVWdnuGPAlYgbPPgVixL9lhfuvxwq1Qrq7AtW+Ox3dK7K5JstlJNTI5lItGoZquq9wT7HY5XZ0rSUUAVbtlc1cj6+p1jW1iwV3vOjajWwzNL7Ks2QLlby7VZLJZ+3ZFocz6FicmxTMQZVYdx9KYnhmvHN471bGCHn7pbgHQRCUtCqBir57z9xOTDfarV3jOoenTCkn7kOYGbmJiEl4hvVomIFbgOeE1VnfHjUoEiP9UPOV5TgD3eG/Py8lxRhrp27UqfPn0YOHAgy5Yto3Xr1sTExJCfn09WVhYbNmygWUwvTy2WgyxatIj+HTKI9Ursl5/WgvJNv7Jnzx7XMePi4sjIyGDt2rVkZGRQVFREQUGBa3tCQoIrgo+JiUlks2bNGg8bMWfOHJYtW0Z6ejq4zaiKeD9VEZkEXACc6uxnFZENQIVjIMu97mRgAtBHVdd6HytUP9VX/3M+1RXNqCjuSEVpe666+irat29D1UeLsC08nH9J0lOIueUKJD6u5oPVgOmnamIS+YTipxrRLVURGQNcCgx1GlQH+wB/OUpaOl59JzWHiKodO7uQWDvNYjfTLAXatLkNrbZh+ynPo66lX486GVQTE5Ojj4jrU3UiIlcDdwKnq6r3o/wqoJ2IeIcq7wLs9lM/ZMorDqIcDuUXE52A1RqDfc0mKHYLRRcTjXVwPz9HMDExORaJSKMqIlcB9wJnqOouR9n5IuIMcvcuEA2c5LZPDHAyMDccGsrK93usxzVLAfAN8dejsxmNysTExEXEGVURuRJ4FZgBnCEiVzmM7AU4HvlV9Qvgc+BREXFOxp8A2IAp4dBRVu7ZgxDXLAk9cAj7es/0E5YTc8zBJpNa+fDDD8nNzUVECKVPP5LYuXMn55xzjvlZD4KIM6rAc0AzDIf/N90W71DMf8ToBlghImsxWq1DHZMF6k2pV0u1ebMUbEtWG45dTlITsfbuEo7THRXs2bOH3NxckpOTERFyc3PJycmhd+/enHLKKTz99NMeSfMiSWdubi7du3enX79+vPDCCz6R8uvDyJEjWbFiRVB1x40bR/fu3REROnXqxEUXXRQ2HXXl3Xff5cQTT2TTpk211quqquLBBx+kd+/eZGVlcdJJJzVaAO9vvvmGYcOG0b17dzp37syIESNYs2ZN4B0bAm3E0HtNvYQS+m/Ga//TB+74WifcM1cn/vUlfeu/b2jZwy96hvibtzjo49XE0RT6z8no0aPV+GgdZtmyZTpkyBDt2rWrrl27tomUeeJP59tvv62A3nnnnWE/H6DBfAYXLlxYY7i9pmDw4MG6YcMGv/fLnbFjx2qPHj10z549qqr66quvalxcnC5fvrxB9S1atEijoqL0iSeeUFVVu92u48eP15SUFP3tt9/Cco5QQv9FYks1IvhtYzp92g0ks/XZ9Ey8mo1LToJC9/TTVqwn9W86gUcYAwYMYMGCBSQmJjJixIh65Z1qSC655BJOPPFEXnjhhRqzvx5rfPfdd/To0aPWOuvXr+ef//wn9913H2lpRuyj66+/ni5dugTMulpfHnzwQdLT07nrrrsAI+j51KlTKSkpaZJEg6ZRrQF7lWduqmbVhzzWLb27YGlRcyZKE19iYmJ45JFH2LJlC6+99pqr3G63M2XKFHr06EHv3r3p3bs3Tz/9tM/+q1ev5txzz6VLly506dKFCy64gA0bNri2X3/99XTq1AkR4b333mP48OH07t2bDh06MG3atKB1durUifLycgoLC5k4caLrcfy///0vf/rTn8jJMfrR//73vwOwf/9+xo4dS0ZGBj179iQ3N7fGxHjV1dXcddddDBo0iOTkZEaNGuWTEjsUPvzwQ4477jh69OhB586dGTNmjM/xdu3axahRo0hOTmbgwIHcdNNN3Hfffa6ujw8//LDWc0RFBfa8fO+991BVhg0b5lF++umn88UXX7i6fZzdLhkZGXz66acMGzaMNm3acNFFF3Ho0CG+++47zjnnHNq3b88ll1zCwYMHA5576dKl9O7dG4vlsDlr2bIlGRkZHtd26NAhbrzxRvr160f//v0ZOHAgDz74YNh/4CPaT7UpsainUY0v2wdurqjWUwbQkPzn6dCT2QEkt7Zw7tX+fWY/e7OM/Xvsfrd5c+WdDZMK5vTTT8dqtfLZZ59x6623AnDLLbfw1ltvsXjxYjIzM1m3bh2nnHIKJSUlrkSAv/76K0OGDOGqq67i008/BeC2227jlFNO4ZdffiE1NZXp06czY8YMxowZw5NPPsnHH39MSkoK8+fP59xzzyUpKSmoTJ4bN24kMTGR1q1b88gjj3D66aczbNgwnn76ad555x06dOjAbbfdBkBFRQVnnHEGLVq0IC8vj4SEBL744gvOP/98SkpKPFJgA0yfPp033niDp556isLCQoYOHcrFF19cp77Ht956iyuvvJK5c+fyhz/8gfLyci688EKGDh3KTz/95Mpae9FFF1FWVsamTZtISkris88+cyU8DLavNxCrVq3CYrHQqVMnj/IuXbpQXV3NmjVrGDx4MCtWrOCaa67hvffeY9myZSxcuJA9e/bQq1cvbrrpJnJycpg3bx67du2iV69eTJs2jcmTJ7uOZ7PZ2Ldvn3MWE2BkwLXbfT/XFouFnTt3cujQIVq2bMkdd9zB77//zvLly4mKimLZsmUMGTKE6667LqxZb4+plmooif/SUj1/vdpGuQ1cJbfC0qNzmNUdG8TFxZGamsq2bdsAw4C9/PLLjB8/nsxMIyh47969ue6663jyySddmVInTZpEdXU1jz/+OCKCiDB58mQOHjzI888/73Oe2267jZQUww3uzDPP5Oyzz+aRRx7x++VzYrPZeO655/j555/9ZnUdNWoUHTp0AODhhx/m6quv5s0332T58uVMmTLFlSjvrLPO4vzzz+fee+/16ULIyclxJRxMTExkwoQJfPfdd3z55Zch3UdV5e6772bYsGH84Q9/AIzkik8++SRr167llVdeAeCLL77gf//7H/fffz9JSUY8onPPPZcTTjghpPMFYt++fTRv3twjnTUYLUbAJ8lgcXGx60e1devWDBkyhNmzZ3PDDTcA0KZNG0455RSPpI8A48ePp127dh4pwfv3788vv/xCVVWVq+zgwYNs2WJ46hw6ZDxl/u9//6Njx46ulvfAgQOZPHmyS2NdMRP/BZn4L6G55+hvdqudrv+tx/czXUvqgbpNjV6wYAGqysknn+xRJysri5KSEn766ScAvvzyS7Kysjy+AK1ataJDhw5+fyT79vWMVz5w4EC2b9/O77/7Ooc4R//79OnD+++/z5w5c3wyvgIuow+QlJRESkqKyxgOGjTIo+7gwYPZt28fy5cvD6gLjIytobB+/Xq2b9/ukSoaIDs7m2bNmjF//nyP47onTwTj/jYlKSkpJCYmutaTk5N9ylJSUlzpr520adOGVq1a0aJFC1fZ5MmTKSgo4IEHHqCyspKysjJuv/12l4GPizOe3E499VSmT5/OFVdcwfz586murubOO+8kOdkzxGeoeCf+Mx///aCqYPOMi9qiwmFkLRaiTsxtfFFHCaWlpa6gMoArS+df/vIX7r//fle9iooK0tPTKSwsdNUrKysjNzfX43gVFRUeWU+deLc+nK20HTt20LFjR49twT4CO1ui7jhbaLGxsR7lzi+qdxbS2nSFgvO4zv29j+nc7jRK7sYK8JtJtj6kpqZSWlqKzWbzaK06W4nOpwYnzZt7jkeIiN8yb9e2Rx55hEceecSjbPDgwXz55Zc8/vjj9O3bl8TERP70pz8RGxvLm2++6bpHzz77LL169eLll19m9uzZpKWlcccdd3DPPfd49MfWF9Oo+qGsrBTRw/2SShXNbTZAsGR2QRIafoCqIfo0a+prbUzmz5+PzWZz5YZPTTXCJb766qu1pi5OTU2lT58+fPXVV0Gdx/lldrJ/v9F9066dv5ARdcdpTCoqKjwMq/N8zusLly6bzYbdbncd17m/OwcOHCAnJweAtm3busqco/KA68cqXGRnZzN79my2b9/u0T+5ZcsWoqKi6NOnT1jP583QoUN9nkBHjBjBCSec4DKYUVFR/N///R//93//x5IlS5gyZQr3338/qampQfW1B8sx9fgfLAcPHPAskEIsGI/71iENO0B1NFNeXs7EiRPp0qUL1113HQBnnHEGIsLKlSt96v7xj39k7969gNEvumbNGo9+M4A333yT5557zudcv/zyi8f6smXL6NixI+3bhy3bjks/4OqmcPLTTz+RmppK//6ebnf+dAGceOKJQZ3vzTff5IYbbqBXr1507NjR57yrV6+mvLycM8880+O4P//8c6066stFF12EiPh0xSxcuJCzzjrLbyu/LthsNnbv9swLt23bNp/Pz8GDB/n2229dfbQA1113nWukf/DgwcydO5fExERWrfJMi1RfTKPqh0MHPWf9WMTh1tEqAUuPjMYXdBSwdOlSTj/9dIqLi/n0009d/Vzdu3fn5ptvZtq0aS73qKqqKtcgj7N1NWnSJCoqKnjooYdcfbJ5eXncf//9Pv2KAK+99pprcOTLL7/kiy++YOLEiWF9zAO4+uqr6d+/Pw888IDLbejLL7/k448/ZurUqcTEeMb8+eGHH/j8888Bo7U4ZcoUTj75ZJdxDhYRYdq0aSxcuJD3338fMH6I7r33Xnr37s3YsWMB48fo5JNPZurUqRxwNBY+++wzVq9eXZ/L9qFXr17ceOONPP74466uh9dff51NmzaF1Vf0pptuol27dnz//feusoULF3L55Ze7Wu0lJSXccMMNnHHGGVx22WWuegsWLHAN4IHh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\n",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Firstly load the data from the trained models for all DPPLs\n",
    "# and trasform the measurements of time and test accuracy to be ready to plot \n",
    "## 1) SLASH (PC), below referred to uncapitalised as 'slash_pc'\n",
    "slash_pc_accuracy_list = []\n",
    "slash_pc_accuracy_overview = []\n",
    "slash_pc_time_list = []\n",
    "slash_results_path = os.path.join(os.getcwd(), 'data')\n",
    "folder = [x for x in os.listdir(slash_results_path) if re.search('pc-poon-domingos-normal', x)]\n",
    "for f in folder:\n",
    "    model_path = os.path.join(slash_results_path, f, 'slash_digit_addition_models.pt')\n",
    "    models = torch.load(model_path)\n",
    "    slash_pc_accuracy_list.append(np.array(models['test_accuracy_list'])[:,0]*100)\n",
    "    slash_pc_accuracy_overview.append(np.array(models['test_accuracy_list'])[-1,0]*100)\n",
    "    time = models['time'][-1].split(':')\n",
    "    time = int(time[1].split('m')[0]) * 60 + int(time[2].split('s')[0]) - (15*15)\n",
    "    slash_pc_time_list.append(time / 15)\n",
    "slash_pc_average_epoch_time = np.average(slash_pc_time_list)\n",
    "slash_pc_minutes = round(slash_pc_average_epoch_time // 60 )\n",
    "slash_pc_seconds = round(slash_pc_average_epoch_time % 60)\n",
    "slash_pc_average_epoch_time = f\"{slash_pc_minutes}m:{slash_pc_seconds}s\"\n",
    "print(f'RTE (m:s) - SLASH (PC) {slash_pc_average_epoch_time}')\n",
    "# Determine and print the accuracy's overview\n",
    "slash_pc_overview_average = np.average(slash_pc_accuracy_overview, axis=0)\n",
    "slash_pc_overview_std = np.std(slash_pc_accuracy_overview, axis=0)\n",
    "print(f'Test accuracy - SLASH (PC) {slash_pc_overview_average}+/-{slash_pc_overview_std}')\n",
    "slash_pc_accuracy_average = np.average(slash_pc_accuracy_list, axis=0)\n",
    "slash_pc_accuracy_std = np.std(slash_pc_accuracy_list, axis=0)\n",
    "\n",
    "    \n",
    "\n",
    "## 2) SLASH (DNN), below referred to uncapitalised as 'slash_dnn'\n",
    "slash_dnn_accuracy_list = []\n",
    "slash_dnn_accuracy_overview = []\n",
    "slash_dnn_time_list = []\n",
    "slash_dnn_results_path = os.path.join(os.getcwd(), 'data')\n",
    "folder = [x for x in os.listdir(slash_dnn_results_path) if re.search('dnn-normal', x)]\n",
    "for f in folder:\n",
    "    model_path = os.path.join(slash_dnn_results_path, f, 'slash_digit_addition_models.pt')\n",
    "    models = torch.load(model_path)\n",
    "    slash_dnn_accuracy_list.append(np.array(models['test_accuracy_list'])[:,0]*100)\n",
    "    slash_dnn_accuracy_overview.append(np.array(models['test_accuracy_list'])[-1,0]*100)\n",
    "    time = models['time'][-1].split(':')\n",
    "    time = int(time[1].split('m')[0]) * 60 + int(time[2].split('s')[0]) - (8*15)\n",
    "    slash_dnn_time_list.append(time / 15)\n",
    "slash_dnn_average_epoch_time = np.average(slash_dnn_time_list)\n",
    "slash_dnn_minutes = round(slash_dnn_average_epoch_time // 60 )\n",
    "slash_dnn_seconds = round(slash_dnn_average_epoch_time % 60)\n",
    "slash_dnn_average_epoch_time = f\"{slash_dnn_minutes}m:{slash_dnn_seconds}s\"\n",
    "print(f'RTE (m:s) - SLASH (DNN) {slash_dnn_average_epoch_time}')\n",
    "# Determine and print the accuracy's overview\n",
    "slash_dnn_overview_average = np.average(slash_dnn_accuracy_overview, axis=0)\n",
    "slash_dnn_overview_std = np.std(slash_dnn_accuracy_overview, axis=0)\n",
    "print(f'Test accuracy - SLASH (DNN) {slash_dnn_overview_average}+/-{slash_dnn_overview_std}')\n",
    "slash_dnn_accuracy_average = np.average(slash_dnn_accuracy_list, axis=0)\n",
    "slash_dnn_accuracy_std = np.std(slash_dnn_accuracy_list, axis=0)\n",
    "\n",
    "\n",
    "## 3) NeurASP, below referred to uncapitalised as 'neurasp'\n",
    "neurasp_accuracy_lists = []\n",
    "neurasp_accuracy_overview = []\n",
    "neurasp_time_lists = []\n",
    "neurasp_results_path = os.path.join(os.getcwd(), 'data', 'neurasp')\n",
    "files = [x for x in os.listdir(neurasp_results_path) if re.search('mnist_normal_seed', x)]\n",
    "for f in files:\n",
    "    model_path = os.path.join(neurasp_results_path, f)\n",
    "    models = torch.load(model_path)\n",
    "    neurasp_accuracy_lists.append(np.array(models['test_accuracy_list'])[:,0])\n",
    "    neurasp_accuracy_overview.append(np.array(models['test_accuracy_list'])[-1,0])\n",
    "    time = [x[0] for x in models['time']]\n",
    "    seconds = 0\n",
    "    for s in time:\n",
    "        s = s.split('h:')[1]\n",
    "        seconds += int(s.split('m:')[0]) * 60 + int(s.split('m:')[1].split('s')[0])\n",
    "    time = seconds\n",
    "    neurasp_time_lists.append(time / 15)\n",
    "neurasp_average_epoch_time = np.average(neurasp_time_lists)\n",
    "neurasp_minutes = round(neurasp_average_epoch_time // 60 )\n",
    "neurasp_seconds = round(neurasp_average_epoch_time % 60)\n",
    "neurasp_average_epoch_time = f\"{neurasp_minutes}m:{neurasp_seconds}s\"\n",
    "print(f'RTE (m:s) - NeurASP  {neurasp_average_epoch_time}')\n",
    "# Determine and print the accuracy's overview\n",
    "neurasp_overview_average = np.average(neurasp_accuracy_overview, axis=0)\n",
    "neurasp_overview_std = np.std(neurasp_accuracy_overview, axis=0)\n",
    "print(f'Test accuracy - NeurASP {neurasp_overview_average}+/-{neurasp_overview_std}')\n",
    "neurasp_accuracy_average = np.average(neurasp_accuracy_lists, axis=0)\n",
    "neurasp_accuracy_std = np.std(neurasp_accuracy_lists, axis=0)\n",
    "\n",
    "## 4) DeepProbLog (DPL). below marked as dpl\n",
    "dpl_accuracy_lists = []\n",
    "dpl_accuracy_overview = []\n",
    "dpl_time_lists = []\n",
    "dpl_results_path = os.path.join(os.getcwd(), 'data', 'deepproblog')\n",
    "files = [x for x in os.listdir(dpl_results_path) if re.search('15_epochs_normal', x)]\n",
    "for f in files:\n",
    "    accuracy = []\n",
    "    time = []\n",
    "    c = open(os.path.join(dpl_results_path, f), 'r')\n",
    "    lines = c.readlines()[1:]\n",
    "    spl = lines[0].split(',')\n",
    "    time.append(float(0.0))\n",
    "    accuracy.append(float(spl[1]))\n",
    "    for line in lines[1:]:\n",
    "        spl = line.split(',')\n",
    "        time.append(float(spl[2]))\n",
    "        accuracy.append(float(spl[1]))\n",
    "    dpl_accuracy_lists.append(np.array(accuracy))\n",
    "    dpl_accuracy_overview.append(accuracy[-1])\n",
    "    dpl_time_lists.append(time[-1]/15) \n",
    "dpl_average_epoch_time = np.average(dpl_time_lists)\n",
    "minutes = round((dpl_average_epoch_time // 60) % 60)\n",
    "seconds = round(dpl_average_epoch_time % 60)\n",
    "dpl_average_epoch_time = f\"{minutes}m:{seconds}s\"\n",
    "print(f'RTE (m:s) - DeepProbLog {dpl_average_epoch_time}')\n",
    "# Determine and print the accuracy's overview\n",
    "dpl_overview_average = np.average(dpl_accuracy_overview, axis=0)\n",
    "dpl_overview_std = np.std(dpl_accuracy_overview, axis=0)\n",
    "print(f'Test accuracy - DeepProbLog {dpl_overview_average}+/-{dpl_overview_std}')\n",
    "dpl_accuracy_average = np.average(dpl_accuracy_lists, axis=0)\n",
    "dpl_accuracy_std = np.std(dpl_accuracy_lists, axis=0)\n",
    "\n",
    "\n",
    "# Accuracy plots\n",
    "clrs = sns.color_palette(\"husl\", 4)\n",
    "x = np.arange(0,16)\n",
    "fig1, axs1 = plt.subplots(figsize=(5,4))\n",
    "axs1.plot(x, slash_pc_accuracy_average, label=f'SLASH(PC) {slash_pc_average_epoch_time}',\n",
    "          c=clrs[0], linewidth=4)\n",
    "axs1.fill_between(x, \n",
    "                  slash_pc_accuracy_average - slash_pc_accuracy_std, \n",
    "                  slash_pc_accuracy_average + slash_pc_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[0], facecolor=clrs[0],\n",
    "                  linewidth=0)\n",
    "\n",
    "axs1.plot(x, slash_dnn_accuracy_average, label=f'SLASH(DNN) {slash_dnn_average_epoch_time}',\n",
    "          c=clrs[1], linewidth=4, linestyle='-.')\n",
    "axs1.fill_between(x, \n",
    "                  slash_dnn_accuracy_average - slash_dnn_accuracy_std, \n",
    "                  slash_dnn_accuracy_average + slash_dnn_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[0], facecolor=clrs[0],\n",
    "                  linewidth=0)\n",
    "\n",
    "\n",
    "axs1.plot(x, neurasp_accuracy_average, label=f'NeurASP {neurasp_average_epoch_time}',\n",
    "          c='blue', linewidth=4, linestyle=':')\n",
    "axs1.fill_between(x, \n",
    "                  neurasp_accuracy_average - neurasp_accuracy_std, \n",
    "                  neurasp_accuracy_average + neurasp_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[0], facecolor=clrs[0],\n",
    "                  linewidth=0)\n",
    "\n",
    "axs1.plot(x, dpl_accuracy_average, label=f'DeepProbLog {dpl_average_epoch_time}',\n",
    "          c=clrs[3], linewidth=4, linestyle='--')\n",
    "axs1.fill_between(x, \n",
    "                  dpl_accuracy_average - dpl_accuracy_std, \n",
    "                  dpl_accuracy_average + dpl_accuracy_std,\n",
    "                  alpha=0.3, edgecolor=clrs[0], facecolor=clrs[0],\n",
    "                  linewidth=0)\n",
    "\n",
    "\n",
    "#legends and axis titles\n",
    "axs1.legend(loc=\"lower right\")\n",
    "axs1.set(xlabel='epochs', ylabel='test accuracy')\n",
    "axs1.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "utils.mkdir_p('plots')\n",
    "fig1.savefig('plots/MNIST_addition_complete_data.svg', format=\"svg\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
