{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ea407e0a-b8eb-45d5-b55b-ba578a3ab71d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.300865Z",
     "start_time": "2024-09-25T20:06:42.890256Z"
    }
   },
   "outputs": [],
   "source": [
    "import os\n",
    "from pathlib import Path\n",
    "from time import time\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.nn import functional as F  # noqa\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data import Dataset\n",
    "from tqdm import trange\n",
    "\n",
    "from experiment_utils import compute_jemmig\n",
    "from kgi import apply_kgi_to_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b356a358-d45a-4d1a-a15e-bf7dac1e2f7e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.304861Z",
     "start_time": "2024-09-25T20:06:44.301746Z"
    }
   },
   "outputs": [],
   "source": [
    "# attempt to enable LaTeX rendering\n",
    "# change to `False` if you get an error during plotting (latex not installed)\n",
    "plt.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81ef3524-c84d-452b-a553-eeab55289fbd",
   "metadata": {},
   "source": [
    "# Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "590fcc14-88e4-4823-a080-575b4e2c8e51",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.506415Z",
     "start_time": "2024-09-25T20:06:44.306558Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 600x600 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "class XYC(Dataset):\n",
    "    \"\"\" dataset \"\"\"\n",
    "\n",
    "    def __init__(self, path_dir):\n",
    "        self.data_path = os.path.join(path_dir, \"xy.npz\")\n",
    "        self.data_zip = np.load(self.data_path)\n",
    "        self.data = self.data_zip['imgs']\n",
    "        self.labels = self.data_zip['labs']\n",
    "\n",
    "    def __len__(self):\n",
    "        return self.data.shape[0]\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        if torch.is_tensor(idx):\n",
    "            idx = idx.tolist()\n",
    "\n",
    "        sample = self.data[idx]\n",
    "        label = self.labels[idx]\n",
    "        sample = torch.from_numpy(np.expand_dims(sample, axis=0))\n",
    "        label = torch.from_numpy(np.expand_dims(label, axis=0))\n",
    "        sample = {'x': sample,\n",
    "                  'y': label}\n",
    "        return sample\n",
    "\n",
    "\n",
    "train_x = XYC('datasets')\n",
    "test_x = XYC('datasets')\n",
    "true_labels = train_x.labels\n",
    "\n",
    "plt.figure(dpi=200, figsize=(3, 3))\n",
    "plt.scatter(true_labels[:, 0], true_labels[:, 1], c='b', s=.5)\n",
    "plt.xticks(np.arange(15, 47, 5), np.arange(15, 47, 5))\n",
    "plt.yticks(np.arange(15, 47, 5), np.arange(15, 47, 5))\n",
    "plt.xlabel(\"x position\")\n",
    "plt.ylabel(\"y position\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Visualize the problem"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "5f8de31343ab7bd2"
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1440x480 with 2 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/sAAAHtCAYAAABGaG6VAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAB7CAAAewgFu0HU+AABzNElEQVR4nO39e3xU5b33/79nMmBA0QnRblAOYQCRegAHkNoWtXXSe9felbbMGDyxa63Jbvl6aNVEe3K3W0tDa2uxbpuguy39acEErd2ltTvRqmy3t2hGsFUEmuEQChQhGVA5yGTW748wOcAkzCTrkFnzej4e8yBk1rquaz6zcs36zLXWdXkMwzAEAAAAAABcw+t0AwAAAAAAgLlI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAABgEYrGYIpGI080wTTwed9XryTUk+wAAAADgsFgsptLSUlVXVzvdFNP4/X6VlZVpxowZTjclL5HsAwAAIKfF43F5PJ4+H0VFRZoxY4aqqqoUi8UyKre0tLRzfwxOVVVV8ng8Ki0tta3O7sdbpsdSJkpLS1VVVaVAIGBamYNBOBzWzJkzGeF3AMk+HBeLxTo7zKqqKqebAwAAclggEFAoFDruMXLkSEWjUS1evFgTJ07knAODSiQSUTAYVHl5udNNsURNTY1isZhqa2udbkpe8TndAAAAAMAs4XC418ugY7GYqqurVVtbq8WLF6uxsVFNTU29lhUMBiV1XIoMWCUajaq+vl5tbW1ON8VSd999tyKRiK666ir+pmzCyD4AAADyQiAQUE1NjRoaGiR1JFl9Xf5dXV2thoYG1dXV2dVES8yYMUMej0eNjY1ONwVp3HTTTQqHw65PgMPhsAKBAFfV2IhkHwAAAHklFAp1JvCNjY1avHixwy1CvmpsbFQ0GtXdd9/tdFNsUVVVpdraWsXjcaebkhdI9gEAAJB3wuFw52X6jDTCKTU1NQoEAp3HottdddVVksS9+zYh2QcAAEBe6n5vP6P7cEJ9fb1CoZDTzbCN3+9XIBDQihUrnG5KXiDZBwAAQF4KhUKdy5yl7uPvrq9l3eLxuKqqqjRx4sTOVYUmTpyoSCSi+vr6XutMzRNQVFQkj8ejGTNm9DnKeezqAY2Njcftn+5e/Nra2s52RaNRST2XEvR4PKqoqEjbvoqKCs2YMUNFRUUqKipSaWlpn6+pv208Vn19fWcbJ06cqIqKCsViMdXX1ysSiXS2KdsvZrKN+bGvq/t7m4qlGVIxybc16EOhkKLRKJfy28EAHNbc3GxIMiQZlZWVxz1fXV1tBAKBzucaGhqMUChk+P1+Q5IRDAaNurq6zu3b2tqM8vJyIxAIGJIMv99vlJeX99mGpqYmo7y83AgGg4bf7zf8fr8RCoV6lNuXuro6IxQKGZKMQCBglJeXG83NzUZdXZ0RDoc7y62urk5b97Gvp6ampte62trajMrKys7Xl6ozHA5n3F4AANykra2tz3OJvoTD4c59j1VZWWlIMkKhUI/fNzc3d35upz6Hu38uS0r7mVxdXd1jm+5lHFvHsW0Ih8NGeXl5j/37qq+urs4IBoNGMBjs0c7U74LB4HHnJam6urevext7O5/qbxt7ex9S503HtiUV5+7t6O09GkjMj23Psft1f665ubnXMk4k1fZsymhoaDDC4bARDoeNQCDQ4z2sqakxQqFQ5/NNTU39btuxysvLO89p+zpPra6u7vP5VDslGQ0NDaa1D+mR7MNxJ0r2u3+AHNthd3/U1NQYTU1NnZ3xsR8SwWAwbf39/WBL6e+Hk2Fk/wHU35MLAADcbCDJfvfP4ra2th7P9ZZIpr7gD4fDx5XX1NRkhMPh4xK4VD1+v7/HZ3Vzc3NneX2dB6X7nG9oaOg8LwgEAr2+xtS5womSq8rKSiMYDB63XV1dXZ/nGQNtYyr5CwQCPd6DVLl9vba+kv3+xrz7FxbHvpfdYzHQZD/VhkzV1NT0aG9bW5vh9/uNyspKo7q6ujPxb2pq6jxHNEP3Lw5SMU33upuamk74fhlGxzEhKe0gGMxFsg/HZZrspz4ounfWxyb3qRH51AdFW1tbj2Q83Ydcfz/YDGNgH079+QDqz8kFAABuN5BkP/VZLum4kdDeEsnets+kfb3tk0rIj9U9kU732rq3/9gvK44t+0TJfm/7G0ZXApxu8GSgbeyrfSdqe2/vUX9j3n2/3gZ8up8jDuS8KxAIGH6/P6NtU1ehHit1btj99afOfTMtuy91dXU9kvLUcdDXlSsnGihLnfufaDsMHMk+HJdpsp/JB0hvnVrqC4F0+/f3g80w+v/h1N8PoGxPLgAAyAdmjewfm7j1lkj2dV6RTverFHuTOp85Nonqfh6U7pwlNZqayTnFQC6b7p7gHmugbexr31Ti2tsocG/vUX9j3n2QqTfdz10Hkuynrv7MRDAYTBuf1G0ax15NUV5ebsr54rHnwKljP93rTrUlky+VersaA+byCcgh6dYg7T6DaXl5edr9Zs6cqcbGRsViseOe8/v9vdZXWlqq2traXidjSZU3c+bM454LBoOKxWKKRqPHzbK6aNEiST2X/TlWVVWVKioqVF9fr3A43NnWeDyuFStW5M0SLQAAWKm5ubnz59RkfSdSXl6uxYsXa/HixWpsbFQoFFJZWVmvn82p84hYLKZIJJJ2m9RkZenOVaSOc4B05yx9nceYqXs98Xi817Y42cbu+hvzvs7tzBaPxzVy5MiMtisrK0sbx9Tr7H6uGQqFTJvhv6ysrPPn+vp6xeNxBYPBtH8r6dqSjhPHQ74i2UfO6O0DpLtZs2aZXmdKbx9s/dHfD6BsTy4AAEDfXnvtNUmZJ/pSx5J9qVnio9GootFo5wzx4XBYS5cu7XHOkKojtW1fun/50F0mSaHZotGoYrGYWltb065WcKz+tjEQCCgWi+m11147LlFMxSvbc53+xry/9fVXJueWfr9flZWVx/0+NZt/MBi0LIHuXm9NTY2k9INv3duSqdbW1gG2DidCso+c0dsHSPffm9HRZfPB1t8Pp/5+AGV7cgEAAHqXugJPUudVdJmqq6tTY2OjampqOs8dpI7Rz8bGRm3evPm4z+SGhoZBv6Z6fX29ampqMloqzyypqxkrKirU1NTUGbfFixcrFospEAj0O26DPeYDWX4udZ7affTdKvF4vPOYSPe3kmpLNrF24gusfON1ugGAmfrbaXRf13XGjBmKRCKdl9D3JbWebEVFRY/OOtMPp4aGBhkdc2f0+kh9i5pSV1enhoYGhcPhHqMQ9fX1mjBhAmuWAgCQoe7rzKcbrTyRUCikuro6NTc3q7m5WdXV1ZI6EqPUOYLUdUm4mWu0W6G0tFSRSESNjY0Kh8Oqq6tTU1OT2traMhrZ76/U+VssFlNRUZFmzJihiRMnqqqqSn6/X3V1dVmX2d+YpwZperudwkx+v39Ao9up81Q7vszoK9Hv3pZMvnhInasyQGU9kn3kvYF8sPX3w2mgH/qZnlwAAID0GhsbOxOY8vLyAScegUBAlZWVnV/Sdx8ZLy0tlaTjvsC3W18DAqlbBAOBgNra2lRXV9c5t5DVSdmiRYsUCARUU1OjYDDYeX5UXl6uzZs39+uS+v7GPDWQ0teVDWYNrAQCgX6XFYvFFIvF5Pf708bH7PPBV199VVL6W2bj8XjnlyOZvFepLziyuXUG/UOyj7w20A+2/n44mfmh39fJBQAAOF40Gu2cMyf1OZ6NvhK01EBA9/OIysrKzlv/Urff9VaulSPKfY0ip5K5UCiU9hzIyisHo9GoAoGAysvL1dTUJMMw1NzcrJqamn5/0dDfmKeu9ojH473ut2LFin616VipZPdEsW1sbFQkEukxSJQaSU83kWD321PS6c972Vcynzr3zPQKg1RZEydOzLodyA7JPvLaQD/Y+vvh1N8PoGxPLgAAQJfUFXAzZsxQPB5XIBBQU1NT1uVMmDCh86rA7qLRaOeI6rGJT+oLhdT96d0/01OJ5YQJEyy51D+VVHb/UqO+vr7HbQypEdva2trjbmOsr6/XTTfdZHq7urevsbGxcwWk1Kh1LBYb0JcM/Yl56rwutd+xI+RVVVV9nrtlIzX4k5rLqTeRSET19fU9vmRI/ZzuvK+qqirtF1jxeFxFRUUqKirK+jX09cVEapWp1Os5kVS87VjxIO85teYfkNJ9rdJ069Wm1jvtbR3STNasD4VCadda7b627rHr2tbV1XWuJape1n5NrVtbU1NjNDU1Gc3NzZ2PdNt319DQ0Fl2eXl5j+3b2tqM6upqw+/392iX3+83wuHwceuXNjU1dbYl2/WFAQDIdd3PBQKBgBEOh3s8QqFQ5+dkb5+96aRbw72tra3H+UG6R2/nLA0NDT329fv9x/3/2HOZE50HdT+P6u08qPv5zrGP7o59Xd1j1v3nY+M20Db21b5UXMLhcNp9071H3fUn5obRde7Yfbvu56upn9OtN5+ppqYmQ5JRXV3d53ap2KbqqqysNGpqaoxwOGz4/f4e25aXl/e6zn33c89s08DUe9j9XLqtrc0Ih8NZxyIVW1iPKMNxTib7htH/DzbDGNiHk2Fk9wE0kJMLAADcrPu5QF+fyYFAwKisrOz1c/lYfSWS3ZOt7p/DlZWVfX6J0NbWZpSXl3eeY6S+nKipqemzDQNJ9g2jIwlMxSAUChmVlZXHJWfNzc09XlMgEOhMHlOJXTgcNjXZb2trM4LB4Anfv9Tj2DidKNlP1ZFNzLuXnYpFMBjsfG9TcQqHwwNK9g2jayCnLw0NDUZ5eblRXl5uhMPhHgNBlZWVRjAY7GzPiY7tUCjUeRyc6MuuYzU1NRmhUMgIhUJGOBzuPDZSf1+ZyuQ1wxwk+3Cc08l+fz/YBvrh1L2cbD6A+ntyAQAAMNikztFCoVDaxLmtrc2oq6vrcc7lJqnzXCfqNeO8MTXwlemVpamrGXq7+gDm8hiGYQhA1kpLS9XY2KhQKKSamprjZhRNrUe6aNGiznuT+HMDAADo4vF4JEltbW0nnHeoqKhI8XhcTU1N/ZqhfzCKxWKaOHGiampqOucKsENFRUXGE1PW1taqqakp7fYTJ05ULBbL6P1L1fvEE0+ora0t2yajH5igD+in1KQ8dXV1aZcO8fv9CofDampq6uz8Bvv6ugAAAHbpPtlbJuvNW7kigFMCgYDC4bDtyzJmEm+p43y3oqJCtbW1x01IWV9fr1gspsrKyowS/Xg8rtra2s4lo2E9kn2gH/hwAgAAGBi/3985mj1jxozjVgFIaWxs7FymLRQKuWZUP2Xp0qWKRqO2DQrV1tb2WImhL6lVoUKhUI8VJmKxmG666SaFQqGMk/fa2loFg0Fbr2DIdyT7QD/w4QQAADBwNTU1qqysVDweVyQSkcfj0cSJE1VaWqoZM2aoqKhIpaWlisViCofDamhocLrJpvP7/aqpqVEkErG8rng8rrq6uuOWhuxNKsnvHvdoNKoZM2boqquuyvj9iMViWrRokZYuXdqvdqN/uGcfGIBj11oNBAIKBAJqbW3tsTZsOBxWXV2dQ60EAAAY3OLxuBYtWqTGxkbF43HFYjH5/X4FAgGFQiFVVFSkvW3STSoqKuT3+y29zL2iokLV1dUZXXaf0tjY2GOfkSNHqqKiIqtBrIkTJ6qqqopRfZuR7AMDxIcTAAAAzBCJRFRaWuqqpDgSiWjWrFmqrKx0uil5h2QfAAAAAAaJ2tpa1yT7qdWpwuGw003JSyT7AAAAAAC4DBP0AQAAAADgMiT7AAAAAAC4DMk+AAAAAAAuQ7IPAAAAAIDLkOwDAAAAAOAyJPsAAAAAALiMz+kGAAAAoP8OHTqkv/zlL5KkM844Qz4fp3cAkCsSiYTeeecdSdL555+vwsJC08rm0wAAACCH/eUvf9FFF13kdDMAAAO0Zs0azZo1y7TyuIwfAAAAAACXsWRkf9q0adq9e/cJt7tB0vezLPsKSa/3p1GDiNfr1bZt2xQMBjOKUybGSXoly30eknSvKbVbw4o4ZWqzpGwuoNkk6RKL2nIiTsYpEyslfTSL7ZOSxktKmNyOwR6nTNjVZ+7cuTPLPQA46Ywzzuj8ec2aNRo9erSDrQEAZGPnzp2dV2d178/NYEmyv3v3bu3atavX5x+VFJB0Vj/KvlfSfknPSKruV+ucV1BQIOnEccrEDZIWKLvENOWzks6VtFdSeECtsIaZccrEJElLj/48JMt9z5T0m6M/XyHpoFmNyoDdccqEV1LD0X8/nOW+Hkn/P0mGpCpJa0xq02CMU6byvc8E0Lfu9+iPHj1aY8aMcbA1AID+MnvOFdvv2b9XHUlmf7+zCB7993RJH0j6iRmNylE3Hn1c3M/9xx19vCdpsToSK8OcpuWcmZJukXRZP/c/udu+P5C0SFJupZPmOVXSPeqIR3/uE/JIuvToz5WSatTxxUG+os8EAABAf9iS7I+Q9OmjP39d0jATyjxP0s2S/q6OBHWlOi7/zQdhdSRRCyVdaEJ5p6jjfWlSRyz/LOkdE8rNBZdLKlZHcnm9SWXeIqlF0jZ1XN6f67edZGqKpGmSitRxPJlhnqT2o2W+J+kPJpU72NFnAgAAYKAsT/ZHSJojaYUFZU84Wq6hjqR3vTpGrtyqQNLZkh5X9peZZ1L28qM/L5C0SlKryXUMNpMl/VjSBRaU/cOj/z4m6ZuStlpQx2BylqQvS7rDgrKvOvrYLikkaYMFdQwm9JkAAAAwg+Wz8V+hjsTRSh5JayWVWFyP0/yS3pL5if6xlqljLgC3e1nWJPrdXauOL2fc7gFZk+h3N0bSGxbXMRjQZwIAAMAMLL0HAAAAAIDLWJrs3yvpF1ZWcIyopCttrM9OsyVtsbE+u987Ow2RtE/SSJvqm62OpfzcqknSXJvqGqKOmeWLbKrPbvSZgP2i0agmTpyoeDxuSnm1tbUqLS1VRUWFIpGIIpGIotGoKWUDAJANy+7Zf0QdM0ibMbFUpk6W9FN13Jf6UxvrtVqZpH9Xx0R6dimU9Dl13DrweRvrtdqZkv6ojvuiPTbVWaCOS9BflzRL5q8f76RX1LG0ntW3lqR41PHevSjpakl/taleO9BnAvaKRqOqqalRbW2taWVGIhHFYjE9++yz8vv9kqRYLKYZM2aourpa5eXlptUFAMCJWDayP1HSh6wqvA8lkkY7UK+VTlfHZHJ286tjhnU3OUkd9+nblein+Byq12rnq+OLIbudJ2m4A/VaiT4TsMfixYs1Y8YM1dTUKBKJdCblA1VbW6v6+voeib4kBQIBLV26VBUVFYzwAwBsZcnI/g3qmJ3bKUF1XJr6OwfbYJbLJV3iYP1FkirUsdZ5riuRecvr9YdH0lfUcZn2uw62wwxDJd0km9bu7EVY0vuS3nSwDWahzwTsU1lZqcrKStPLraqqUigUSvvlQTgc7tymoaHB9LrNkEwmtXbtWu3du1fFxcWaPn26vN78nNqJWCAdjosuxKKnZCKhDStW6EBLi4aPHaspZWXy+pw8S+7GsMKoUYYhOfpo6FhdalA+CgoKjEQiYYwaNeqE2/7K4TgakvF+DsQpk8dnB0EsDckYN8jjlMnj1EEQR0My/nWQxynTx45BEMvufSaQT/x+vyHJaGtr63cZTU1NhiSjsrKy122CweCA6+lNS0tL599vS0tLVvu2t7cbS5YsMQKBQI9+KRAIGEuWLDHa29tNb+9gRSyQDsdFF2LRU/uRI8bz8+YZW3y+HudUW3w+4/l584z2I0cyKmcgffiJ5O9XMAAAACZYsWKFJKm4uLjXbUaO7JgWtrGx0ZY2ZSKZTOr666/XLbfcolgs1uO5WCymW265RQsWLFAymXSohfYhFkiH46ILsegpmUjo5UmTdOnKlRqf6Dkj1/hEQpeuXKmXJ09WMuHsbF0k+wAAAAOQSuD7uv8/9dyrr75qQ4sy89BDD+nxxx/vc5vHHntMDz30kE0tcg6xQDocF12IRU+r58/Xx7Zu7XObj23ZotXz59vUovRI9gEAAAYgtWxfavQ+ndRz/Vnib/v27X0+du7cmXWZyWRSP/nJTzLa9oEHHnD1aB2xQDocF12IRU/JREITnn46o21Lnn7a0dF9kn0AAIABaG1ttWTblLFjx/b5uOiii7Iuc+3atdq8eXNG28ZiMa1bty7rOnIFsUA6HBddiEVPG1as0LgME/jxiYQ21tVZ3KLekewDAADkmb1791q6fS4hFkiH46ILsejpQEuLpdubaZCsCQAAAIB0Wk5worhz586sR/f7mkzQjO1zCbFAOhwXXYhFT8PHjrV0ezMxsg8AADAAqfvxM7lEv6/7+nszZsyYPh+jR4/Ouszp06drwoQJGW0bCAQ0bdq0rOvIFcQC6XBcdCEWPU0pK9M2X2Zj5lt9Pp0diVjcot6R7AMAAAxAX7Pwp6S+CMhkWzt4vV597Wtfy2jb2267TV6ve08ZiQXS4bjoQix68vp82jx3bkbbbpk7V94MvxiwgrvfCQAAAIvNnDlTktTc3NzrNql1qWfNmmVLmzKxcOFCXXvttX1uc+2112rhwoU2tcg5xALpcFx0IRY9zVm+XC+VlPS5zUslJZqzfLk9DeoFyT4AAMAAlJaWSup7Wb3Uc+Fw2IYWZcbr9WrZsmVasmSJAoFAj+cCgYCWLFmiZcuWuX6UTiIWSI/jogux6Mnr8+niTZv0wrx52nrMyP1Wn08vzJunizdtcnRUX5I8hmEYppc6erS0a5fpxWajUVKpoy3oXUFBgQ4fPqwxY8Zo1wni9CtJC+xpVq8OSDrZgXqziVMmPivpdwNv1oCNl7TNxPLMjlMmTpW0z5aa+vYVST/PcFsn4pSpHZKyv+PWXN37TCs+FoDBqqioSPF4XG1tbQO6xN7j8SgQCKQd3Y/H4yoqKlIwGFRTU9MAWpve9u3bNfboBFAtLS0aM2ZM1mUkk0mtW7dOe/fuVXFxsaZNm5Y3J+3HIhZIh+OiC7HoKXl0eb0DLS0aPnaszo5EskryzejDe2PJVw2fkfTvkoJWFJ6BX0v6vkN1m+17knZLusOh+rdIusqhus22WtIXJD3pUP1JSZdIGlxpZv+8L+kjkl6QdJJDbfiSpFUO1W22/ytpqegzgcEsFospEolo5syZqqmpOe756upqVVVVKRaLHTfq9cQTT0iSli5daktb+8Pr9erCCy90uhmDArFAOhwXXYhFT16fT+dcfbXTzUjLkq9gopL2W1FwhnZIetvB+s3UrI6E2ykHJb3qYP1mikta63Ab1kj6wOE2mKFd0ivq+ALDKW+q44swN6DPBJwRi8U6L69/7bXX+ty2pqZG0WhUtbW1ikajxz1fWVmpcDis0tLSHpfzR6NRVVVVqbq6WsGgU1/pAQDykWU3ETwj6XRJ51lVQS+ek2T+BXLOWq+OEczP2FxvTNJTNtdptXfVdWuEx8Z6D0l6XM4mx1b4taQySafZXO/jkt6xuU6r0WcC9qivr9eiRYsUj8fV2traeel+JBLRyJEj5ff7VVZWpsrKyh77lZWVqb6+XoFAoNekva6uTrW1tYpEIgoEAmptbVU8HlddXZ1CoZDVLw0AgB4suWd/9OjR2rVrl74m6WZJma3KOHBvSbpF0rM21ddf/bl3+AJ1JFYXWNqyLn8/Wt/dNtWXjlX3WPvUMSp9gSz8tqub99Qxon+5ReU7fS/6k5I+IclvQ11JSeskXabsR8KdjlMmBkufyT37QG6x8n5PAIC1rOzDLZ1J4SeyN1n8vAZ/ot9fb0j6pI312f3e2SkhaYbsm2DuDVmX6A8GX1DH5G52SKjjvnYnL3m3En0mAAAAzGLLtIl2jBHlyziUXbEknuaVTyzNK59Y5lYdAAAAcI7lyX6dJKvnajQkjZS0yeJ6nLZXHUvgHbG4nv8j6acW1zEYnCWp7+mYBq5G9l6R4ZRrJH3L4jq2yp5bBZxGnwkAAAAzWJ7sJ9UxwdyUo4/3TSz7raNlnqOOS7LzYaTqoKRz1fG6XzSx3HZJU4+W+z9H/+92hyWF1fGazb50+sqj5d4jd8y+fyJHJD2sjtc8x+Sylxwt95PqmOjQ7egzAQAAYAZbLuP/QNLGo49r1DFCN1DPqWNiqVS5+XTSukkdr/kb6hgFHKhWSVepY+mtjer4QiFfbFPHa/6NpDtNKvM6daw/v1HuWRouE23qeM2vqeN4MmPlgfsk/fxouZtNKC9X0GcCAABgoOyYjLyH30kKSBqljom2SrPcf5mknepYKirfJ5Z6SdJwdSyR55dUkeX+r0h6Xh2TnT1pZsNy0FZ1LOd2+tH/367s/jj2Snrk6M91yo/R/N4cklQvabE6lje8WtK4LPY3JN2vjqtLfi1pg9kNzDH0mQAAAOgP25N9SXrg6L9zlf2lBYvUMQKNDg1HH6MkTcpy3xWSlpreoty1Q9JdR3++QNLQLPbd1m1fdCTsqVsjhiq7JSMNdcQyH24lydQDR/+lzwQAAECmHEn2U54++sDA7ZIUcroRLnKF0w1wka873QAXoc8EAABApmy5Zx8AAAAAANiHZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFzGZ0WhXq9XBQUFVhTtCqnYEKe+EafMEKfMECcAAADkE0uS/W3btllRrKt4vV7ilAHilBnilBniBAAAgHxhSbIfDAa1e/duK4p2hVTCQZz6RpwyQ5wyQ5wyt3PnTqebAAAAgAGyJNnfvXu3du3aZUXRrpC6hJg49Y04ZYY4ZYY4AQAAIJ8wQR8AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMj5nq79c0oIs9/mupJgFbcltp59+uu6///6s9lm1apWeeOIJi1qU2x555BENGTIk4+137Nihu+++28IW5a67775b55xzTsbbG4ahG2+8Ue3t7Ra2KjddfvnlWrAguz7zu9/9rmIx+kwAAIB841CyP19SsaRLJF2V5b7/kLRV0npJz5ncrtxz0UUXadasWSouLs46CRg9erTOOOMMvf/++/rlL39pTQNzyOmnn66ysjJJ0oIFC7JK9nft2qXt27dLkmpra3XkyBFL2pgrPB6PvvKVr8jj8eiGG27Q5MmTM97XMAxFo1G1t7frv/7rv7Rt2zYLW5ob5s+fr+LiYl1yySW66qrs+sx//OMf2rp1q9avX6/nnqPPBAAAyBcOJPuzJf27pEn93P/Oo/+ukrRH0htmNConTZ06VRUVFfrSl77Ur/1LS0tVWlqqd955Rxs2bNDLL79scgtzxxlnnKErrrhCP/vZz/q1/6hRozr3ffvtt/Xyyy/rwIEDZjYxZwwZMkSzZ8/Wgw8+KK83+zuFPB6PfvrTn0qSTjrpJD3xxBOdX6Tko9mzZ+vf//3fNWlS//rMO+/s6DNXrVqlPXv26I038rfPBAAAyCc2JfsFkvxHf26UdIoJZX5G0lhJnzz6/70mlJkbiouLJUlLlixRKBQacHlnnHGGVq9erTPPPFPt7e3at2+fEonEgMvNBaeddpp8Pp/Kysr04IMPmlJmY2OjLrnkEr311ls6dOiQ3n//fVPKHeyGDRum4cOHa9SoUVq9erUpZd5///0644wz9KMf/UjJZFJtbW2mlDvYFRQUyO/3S+o4nk45ZeB95mc+8xmNHTtWn/xkR5+5d2/+9JkAAAD5yKYJ+s5Wxyj8HpmT6KdccLTMdyQNM7Hcwcvr9WrHjh3as2ePKYl+SkFBgf7xj39oz549+vjHP25auYOZx+PRf//3f2vPnj2mJfopL774ovbs2aPq6mpTyx3Mbr75Zu3Zs0d//etfTS33rrvu0p49e9TU1CSPx2Nq2YPV2WefrT179mjPnj2mJPopF1xwgfbs2aN33nlHw4blR58JAACQr2xI9iOS1llch0fSPkmZ3xeci4qLi3Xw4MGs7iXvj4aGBt12222W1jEY7Ny5UzNnzrS0jn/913/VCy+8YGkdg8Hy5cv1/e9/39I6SkpK9O6771pax2AQiUS0bp21fabH49G+ffuymksBAAAAucWGy/i9kqxNTjsMUUfS725Dhw61vA6fz6eCggLL63Gaz+fr1z3l2SgoKJDP5/CiFzYoKCiw/JjxeDyWf9E1GHi9Xlte55AhQ/LmSgkAAIB8ZPHI/o2S7rK2ih6WSvqYjfXZZ+rUqVq+fLlt9d14442qqqqyrT47+Xw+rVq1SiNGjLClvqlTp+o3v/mNLXU5oba21rZbP3w+n/7whz+Yemn7YHLjjTfqrrvs6zOXLl2qj33MnX0mAABAvrMw2b9BHcn+dOuqOM4lkm6VVGpjnda76KKLdMcdd5h6j/6JTJ06Vdddd53+v//v/7OtTjv4/X7927/9mz796U/bcpWEJBUVFenKK6/Uv/3bv1l+JYHdvvWtb+kLX/iCRo0aZUt9Xq9Xn/70p/Wd73xHZ511li112uWGG27QjTfeqOnTp9tW5yWXXKJbb71VpaXu6jMBAABgabK/QNLF1hXfq4ikyx2o1zqzZs3q9/J6A3Heeefpq1/9qu31WqmoqEjf/OY3bb98efjw4fr2t7/tutsjvvGNb3SuDmGnO++803XJ/oIFC3Txxfb3mZFIRJdf7q4+EwAAAJYl++MkFVpTdEb8kuwZabTa6aef7kgylTJkyBCNHz/esfrNNHz4cI0ZM8bRNpSUlLjiHn6Px6MJEyY4es/3mWeeadutGFYbO3asCgud6zP9fr9tV2cAAADAHhYl+69I+og1RWekQtKvHazfPPfff7+++93vOlb/pEmT9NZbbzlWv5kuv/xyvfjii47V7/V6tXHjRp155pmOtcEsI0aMUCwWczRBfeqpp3Tttdc6Vr+ZXnnlFX3kI871mRUVFfr1r93RZwIAAKCDu24gBgAAAAAAJPsAAAAAALgNyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMiT7AAAAAAC4DMk+AAAAAAAuY1Gy/5CkbdYUnZFXJK1wsH7zrFq1Sg0NDY7Vv3fvXv34xz92rH4z/e1vf1NNTY1j9RuGoR/96Efav3+/Y20wy+HDh1VdXa1EIuFYG5YtW6bXX3/dsfrN9NBDD2nbNuf6zFdeeUUrVrijzwQAAEAHi5L9eyXFrCk6I89LesTB+s3zxBNP6Omnn3as/t27d+vb3/62Y/Wbaf369aqurnasfsMw9I1vfEPxeNyxNpjl8OHDuuuuu3TkyBHH2vDQQw/plVdecax+M913332KxZzrM59//nk98og7+kwAAAB0sPAy/r2S3rOu+F61Ssr9kdPu3n//fb3zzju213vw4EHt3r3b9nqtlEgktGPHDhmGYWu97e3tjtRrtZ07dzoyur9z50598MEHttdrpb179+q99+zvM1tbW11xtQkAAAB6sjDZD0t6WFK7dVUcp13STZK+b2Od1vvlL3+puXPnqr3dvlgmk0k99dRTuuyyy2yr0w4tLS0qKSlRe3u7bYm3YRjas2ePxo4d6+hl71aYOHGiNm7cqGQyaUt9hmEokUjo3HPP1dq1a22p0y7hcFgPP/ywrX/n7e3tuummm/T977urzwQAAIDlE/RVSbre2ip6OE/SkzbWZ5+XX35ZZ555pm31VVVV6brrrrOtPjsdOXJEJ510ktra2mypz+73zm7nn3++nnrqKVvqOnLkiAoLC2177+xWVVWl66+3r88877zz9OST7uwzAQAA8p3Fyb4hyZ4Rvw521mU/O0f8DMNw3SXn3SWTSVtfn10j306wO5Z2/h3YzTAMW48VNx+XAAAA+c6Gpfeek7TA4joMSZ+S1GJxPc7at2+fPvGJT1h+Kfitt96aFzNzX3nllVq/fr2ldTz11FNauHChpXUMBvfcc4/lKx3s3LlToVDI0joGg+eee04LFljbZxqGoU996lNqaXF3nwkAAJDPfNZX8Y6kVZLuOPr/eyUVmlT23yX9RB3J/nOyd34A+yUSCT3//PO68847VVBQoBtvvFFTp041pexkMqmqqioZhqEnn3xS27dvN6Xcwex///d/de+992r06NGaOXOm5s+fb1rZP/rRj7Rr1y69/vrrrru3PJ233npLjz76qDZt2qRTTz1V3/nOd0wr+09/+pMaGhq0b98+rV692rRyB6t33nlHq1at0h13dPSZ9957rwoLzekz//73v+snP/mJDMPQc8895+qrJAAAAPKdDcm+1DFD/v1Hfz5f0lxJ/gGWuVnSE93KzR8PPPCAJGnIkCG67rrrdO655w6ovIMHD+q3v/2t7r//fldfup/O448/Lkm69NJLNXLkSH3qU58acJlPPvmkHnzwQUfXTXfCq6++qldffVVFRUWaOnWqwuGwPB7PgMp88cUXtXTpUq1cudKkVuaG1tZW3X9/R992/vnna+7cufL7/QMqc/PmzXriiSc6ywUAAIC72ZTsd/dFSb+VdLakIkmjstx/s6RDkp6S9E0zG5ZzfvCDH+i9997TV7/6VQ0ZMkSTJk3Kav+9e/dq9+7d2r17t6655hqLWpkbXnjhBe3evbszqZwyZYq83szvcjl8+HDnOunXX3+9Dhw4YEk7c0FbW5vmz5+vN954Q16vV+PGjdPJJ5+c8f6GYWjDhg0yDEPf+ta38mI0vy9f/OIX9dvf/lZnn322ioqKNGpUdn3m5s2bdejQIT311FP65jfzu88EAADIJw4k+5L0uaP/Vkj6cZb7XiXpNVNbk8t+9rOf6Wc/+5nGjx+vt956K6t9H374YX3729+2qGW5Z/369frwhz8sqeOLkGwund6wYYOCwaBVTcs5yWRS5513niTpmWee0Zw5c7La9/zzz3fdMoUD8bnPfU6SVFFRoR//OLs+86qrrtJrr9FnAgAA5BuHkv2UmqMPDNTWrVuzGj1F34qLi51ugmv88z//s9NNcI2amhrLJ0IEAACAO9gwGz8AAAAAALATyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMiT7AAAAAAC4DMk+AAAAAAAuQ7IPAAAAAIDLkOwDAAAAAOAyJPsAAAAAALgMyT4AAAAAAC7jc7oBAADYob6+XjfddFPG248cOVLNzc0Wtshe8XhcRUVFkiTDMBxuDQAAsBrJPgAgL7S2tioej0uSAoHAcc8BAAC4Cck+ACDvuGnEHgAAIB3u2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAgQ5FIRBMnTlQ0GlUsFuv8v8fj0cSJE1VfX9/n/rW1tZoxY4Y8Hk/nPhUVFYrFYifcfuLEiYpEImpsbOyzjlS7ioqKVFRUpNLS0hO2K6WqqqqzvhkzZqiqqiqj/QAAwODDbPwAgLwTiUROuM3SpUvl9/t7/C4WiykWi6mxsVFVVVXy+/2dy/ilkuy6ujqFw+Ee+8Xj8R6Jut/v18iRI9Xa2qra2lrV1taqqalJwWCwc/vLL79c0WhUkjp/X19fr/r6eoXDYdXV1R3X5sbGRpWWlnb+PxgMqrW1VZFIpLOMdKLRqCKRiGKxmPx+v0KhkGKxmBYvXqz6+no1NTUdFwsAADDIGRYYNWqUIYlHL4+CggIjkUgQJ+JEnIjToHy4VU1NTVZxaG5uPq6MYDDY+Xx1dXWP50KhkCHJCAaDx+3X/bljy21qajLC4bDR1tbW+btAIGBIMiorK3ts29bW1llWeXn5cfX4/X5DkhEKhXqU19bW1qPtx0rVV1NT0+P3dXV1hiQjHA4ftw8Gj5aWls73tqWlxenmAACyYGUfTrLvwIOkgzgRJ+I0mB9u1T3Z769UwpwuoW9qakpbfiphDgQCGdVRXV1tSH0n2KnkvKGhofN3lZWVfdbT3Nyctn2p/Y798uLY57t/eYDBhWQfAHKXlX04l/EDAJClUCh03O96u8y9pqZGkjK+/z21/d13393rNhUVFaqqqlJdXV1nW1K3CGR7n31qv+bm5rT7puYTaGxsPO72BAAAMHiR7AMAkKWJEydmvO1rr70mSZo5c2ZG26eS677usU89132yvtR+mdaTkpoXoLa2ts/tWltbsyoXAAA4i2QfAIBBIh6P9/jZjknx/H6/4vG4DMOwvC4MXslkUmvXrtXevXtVXFys6dOny+vNz0WbiAXS4bjoQix6SiYS2rBihQ60tGj42LGaUlYmr29wpNmWtMLr9aqgoMCKol0hFRvi1DfilBnilBniBKfMnDlTjY2Neu211/ocrZc6Eu9U8v3aa6+lvV1A0nGz9EtSIBBQNBrNqJ507YtGo1ntB3dIJpN66KGH9MADD/RYAjIQCOi2227TwoUL8+YknlggHY6LLsSip2QiodXz56vk6ac1NZHo/P3WL35RW+bO1Zzlyx1P+i2pfdu2bVYU6yper5c4ZYA4ZYY4ZYY4wQmpJfeqq6tVXl5+wu2vuuoq1dbWqqqqSk1NTcc9H4/HtWjRIklSWVlZ5+9DoZCi0ahqamrS1tP9xCxd+6qqqtTQ0JDpy4ILJJNJXX/99Xr88cePey4Wi+mWW27RK6+8omXLlrn+BJ5YIB2Oiy7EoqdkIqGXJ03SpVu3Hvfc+ERC41eu1EuTJ+viTZscTfgtqTkYDGr37t1WFO0KqYSDOPWNOGWGOGWGOGVu586dTjfBVcrLy1VTU6NoNKrS0lLV1dX1uDw/Go2qqqpKFRUVCofDqqmp6Rxpj0QiWrp0aef2sVhMkUhE8XhcoVCox4R5d999txYvXqxoNKqKiorOif5S+1VUVPTavrq6OjU2NioSiaiurq7H86n2VVdXM/LvMg899FDaE/fuHnvsMc2ePVs333yzTa1yBrFAOhwXXYhFT6vnz0+b6Hf3sS1b9ML8+bq0vt6mVqVh6tz+R7G0Vd8PlgAjTsSJOA3mh1t1X3rP7/enfRwbi+5L2xlG19J7x65Hbxi9L21nGMevcx8IBDqXz0tXV3Nzc4/nA4FAj/aFQqG0S+GllvlLvcZQKNRZbzgc7rN9oVCo8/lgMGiEQqEedTY1NfUj6rBDf5Ztam9vNyZMmJBRnxAIBIz29naLX4VziAXS4bjoQix6aj9yxNjq8xmGdMLHFp/PaD9ypM/yrFx6z/3XWAAAcIx4PJ72YRW/36+mpibV1NQoFAqptbVVra2tCgaDqqysVFtbW4/78wOBgJqbm1VdXd25vSSFw2HV1dWpoaEh7eR94XBYTU1NnSP+sVhMgUBATU1NWrp0qUKhUK/LBjY0NHS2LxaL6bXXXtPMmTNVXV2ttrY2RvVdZu3atdq8eXNG28ZiMa1bt87iFjmHWCAdjosuxKKnDStWaFy3e/T7Mj6R0MZjrpiz0+CYJhAAAIuVl5dndM98X9LdQ58SCAROOKN9tm2orKxUZWVlxttLHbfSHXspfsqJ7sk3I0bIDXv37rV0+1xCLJAOx0UXYtHTgZYWS7c3EyP7AAAAeaa4uNjS7XMJsUA6HBddiEVPw8eOtXR7M5HsAwAA5Jnp06drwoQJGW0bCAQ0bdo0i1vkHGKBdDguuhCLnqaUlWlbhjPsb/X5dHYkYnGLekeyDwAAkGe8Xq++9rWvZbTtbbfd5uqltIgF0uG46EIsevL6fNo8d25G226ZO9fRpffc/U4AAAAgrYULF+raa6/tc5trr71WCxcutKlFziEWSIfjogux6GnO8uV6qaSkz21eKinRnOXL7WlQL0j2AQAA8pDX69WyZcu0ZMkSBQKBHs8FAgEtWbJEy5Ytc/0onUQskB7HRRdi0ZPX59PFmzbphXnztPWYkfutPp9emDdPF2/a5OioviR5jBNNHdwPo0eP1q5du8wu1jUKCgp0+PBhjRkzhjj1gThlhjhlhjhlzoKPBQAW2r59u8YenQCqpaVFY8aMybqMZDKpdevWae/evSouLta0adPy5qT9WMQC6XBcdCEWPSWPLq93oKVFw8eO1dmRSFZJvhl9eG9Yeg8AACDPeb1eXXjhhU43Y1AgFkiH46ILsejJ6/PpnKuvdroZaeXvVzAAAAAAALgUyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy/icrX68pPOy3OclSXHzm5Ljhg0bpk9+8pNZ7dPc3Ky3337bohbltk9/+tPyejP/Luy9997TCy+8YGGLctfFF1+skSNHZrXPH/7wBxmGYVGLctf48eN13nnZ9ZkvvfSS4vG4NQ0CAADAoOVQsn+WpKGSrpf03Sz3/bykdZLelbTH5HblHr/fr6KiIo0ZM0a///3vs9q3pqZG1dXVSiQSamlpsaiFuWPo0KE666yzJElPPvmkCgsLM973b3/7mz71qU9JkrZs2UKiKqmkpEQej0c//vGP9ZGPfCTj/ZLJpM455xwlEgnt2rVLBw8etLCVueGss87S0KFDdf311+u7382uz/z85z+vdevW6d1339WePfSZAAAA+cKBZH+IpD9KOr+f+z919N9fSfqypIQZjcpJPp9Pd9xxh775zW/2a/+KigpVVFRox44dKikp0ZEjR0xuYe7wer2aNm2a1qxZ06/9J02apFgsJkkqLi5WW1tbXif8hYWF+tvf/qaCgoKs9/V6vdq4caMk6corr9SqVauUTCbNbmLOGDJkiP74xz/q/PP712c+9VRHn/mrX/1KX/7yl5VI5G+fCQAAkE8cuGd/j7K/dD+dBZJeMaGc3PX000/rG9/4xoDLGT16tA4cOJDVZetus2DBAr3yijnH0549e7K+1NpNUsdTfxL9Yz399NP9/jLLLcw6nsw8xgEAADD42ZTdTVZHkr9H0ghJHhPK9Ei6oFu5J5lQ5uDn8Xi0a9cu7dmzR6FQSB7PwGPp8XhUUFCgd955R3v27NFHP/pRE1qaG/77v/9be/bs0YMPPmhKLKWOeK5evVp79uxRdXW1KWXmgptvvll79uzRm2++aWos77rrLu3Zs0fRaNSUMnPB5MmTtWfPHu3Zs0cjRoww7e/8ggsu6Cz3pJPyo88EAADIVzYk+yFJdZKKjz7MSQI6+I6WOVLSi5LGmVj24HPaaafpf//3f3XGGWeouLhYQ4cONa1sj8ejkSNHqri4WEuXLtU111xjWtmD1Z/+9CddfPHFKi4u1imnnGJq2aeddpqKi4u1YMEC1dbWmlr2YPT9739fd9xxh4qLi1VUVGRq2cOHD1dxcbGmTp2qF1980dSyB6NQKKS6ujoVFxeruLjYtC9OpI5bf4qLizVy5Ei9+OKLGjfO3X0mAABAPrPhnv1iSdMsrsMj6SJJmU+olot8Pl9WE53114c//GGNHj3a8nqcNmPGDNOT/GONGjVK5557rqV1DAaTJ0+2PHEsLCzU7NmzLa1jMCguLta0adb2mR6PRxdddFFWk1ACAAAgt1g8sj9T0qXWVtHDF9SxnJ/7nHHGGbr66qttq2/mzJm69FI73zv7eL1effGLX7TtMma73zu7ff7zn1dJSYktdXm9Xt1www2mXtUymNj9d/eFL3xB48e7s88EAADIdxaO7E+SdIs6ltezyyJ1zM7/uKQdNtZrrdNPP11XXHGFHnzwQdvqnD9/voqKirR7926tX7/etnqtNnToUE2bNk3/+Z//aerl0X2ZPHmy/uM//kPr16/X2rVrbanTLtOmTdOPf/xj25J9n8+n//zP/1QsFtOrr76qAwcO2FKvHSZNmqRbbrlF119vX5+5aNEiJRIJPf7449qxwz19JgAAACwd2V8qexP9lB+q40sG9ygrK9Mvf/lL2+v9P//n/2jlypW212uls846S2vWrLEt0U/x+/1qamrSkCFDbK3Xai+//LJtiX53zz//vOtWPFi6dKmtiX7KD3/4Q91yi7v6TCBTtbW1Ki0tVUVFhSKRiCKRyIAmA43FYiotLVVtbW3ncqyp39fX1ysSifT4PQAAVrLhnn0AAIDBJZV4P/vss/L7/ZI6kvIZM2aourpa5eXlWZcZj8fV2NioxsbGtM9XV1crEAgMpNkAAGTMopH9zZLmWFN0Rm6XtMrB+s3zyCOP6Cc/+Ylj9U+ZMkV79+51rH4zXXHFFXrrrbccq9/j8Wjfvn0aO3asY20wy4gRI3TgwAFHJ3h78cUX9eUvf9mx+s20efNmzZnjXJ95++23a9Uqd/SZQCZqa2tVX1/fI9GXpEAgoKVLl6qiosLU5T6DwaCamppUWVlpWpkAAJyIRSP7Ts/w7JPkjgm8hgwZ4uil316v1zUzdhcUFDj6Wjwej4YNG2b7LQRWSL0WJ5100kny+dxxcdJJJ52kgoICx+r3+XyunfQQSKeqqkqhUKhHop8SDoc7t2loaMi67HA4rOrqasViMY0cOVLBYHCgzbVFMpnU2rVrtXfvXhUXF2v69Onyem1YoXkQIhZIh+OiC7HoKZlIaMOKFTrQ0qLhY8dqSlmZvIPkHDV/3xUAAJB3otGo4vF4n0l4MBhUY2Oj4vF4v+oIBAIKhUI5kegnk0k9+OCDmjx5smbMmKFPfepTmjFjhiZPnqwHH3xQyWTS6SbahlggHY6LLsSip2QioRfCYbUMG6ap112nGXffranXXaeWYcP0QjisZCLhdBNJ9gEAQP5YsWKFJKm4uLjXbUaOHClJvd577xbJZFLXX3+9brnlluMmDozFYrrlllu0YMGCvDiBJxZIh+OiC7HoKZlI6OVJk3TpypUaf0xSPz6R0KUrV+rlyZMdT/hJ9gEAQN5IJfDpLuFPST336quv2tAi5zz00EN6/PHH+9zmscce00MPPWRTi5xDLJAOx0UXYtHT6vnz9bGtW/vc5mNbtmj1/Pk2tSg9kn0AAJA3Upfmp0bv00k919/L+KPRqCoqKjofkUhE9fX1/SpLkrZv397nY+fOnVmXmUwmM54A+IEHHnD1aB2xQDocF12IRU/JREITnn46o21Lnn7a0dH9wTFzAAAAgA1aW1st2TalsbFRs2bNUk1NTefvYrGYJk6cqPLy8h6/z5QVq7isXbtWmzdvzmjbWCymdevW6cILLzS9HYMBsUA6HBddiEVPG1as0NQME/jxiYTerqvTOVdfbXGr0mNkHwAAwASppfuOXWIvEAiosrJStbW1qq2tdah1PWW7rK5bluFNh1ggHY6LLsSipwMtLZZubyaSfQAA8oRhGPrjH/+o22+/XcuXL1diEMwU7CZ+v79z6b5jlZWVSepY0i9bLS0tfT7WrFmTdZl9TVBoxva5hFggHY6LLsSip+FZXm2V7fZmItkHACBPNDY26oorrtCPf/xjXX311TrnnHP0q1/9Kq+S/tT9+Jlcot/Xff3ZCgQCkjrmAYhGo1ntO2bMmD4fo0ePzro906dP14QJEzJu+7Rp07KuI1cQC6TDcdGFWPQ0paxM23yZ3Q2/1efT2ZGIxS3qHck+AAB54s9//nOP/zc3N+uLX/xiXiX9fc3Cn5L6IiCTbVNisZgqKioymojv2GWrnOD1evW1r30to21vu+02eb3uPWUkFkiH46ILsejJ6/Np89y5GW27Ze5ceTP8YsAK7n4nAABAp09/+tMaMmTIcb/Pp6R/5syZkjpec29SyfisWbMyLrempka1tbWKZDCCkxrld9rChQt17bXX9rnNtddeq4ULF9rUIucQC6TDcdGFWPQ0Z/lyvVRS0uc2L5WUaM7y5fY0qBcWJfubJL1vTdEZ2Stpm4P1m2fHjh3atWuXY/UfPnxYGzZscKx+M7377rv629/+5lj9hmHo7bffdsVJdDKZ1Pr16x1dWmXz5s1qa2tzrH4zbdq0Se+/71yfuXfvXm3b5o4+E32bM2eOGhoaek1i8yHpLy0tldT3snqp53q7/z6d1D2q5eXlaZ/vPpofDAYzLtdKXq9Xy5Yt05IlS477AiIQCGjJkiVatmyZ60fpJGKB9DguuhCLnrw+ny7etEkvzJunrceM3G/1+fTCvHm6eNMmR0f1JcljGIZhdqGjR4/Wrl2/kXSZ2UVnqFrSXQ7VfWIFBQU6fPiwxowZk1Eiv3DhQv3sZz+zoWXHW79+vT784Q87Une2ccrEhAkTHLt8MplMqrCwUEeOHDG1XCvilKkDBw5o2LBhttaZMnv27KwmpXIyTpn485//rMsuu8yRuqurq3XXXV19pgUfC1kxDEN79uxxtA1uZxiGnn32Wf3whz/U66+/3ut2JSUlqqys1E033SSfwycsZvJ4PAoEAmlH9+PxuIqKihQMBtXU1JRxmY2NjWpoaFB1dXXa5xcvXqyqqiqFw2HV1dX1u+3pbN++vXN5vpaWFo0ZMybrMpLJpNatW6e9e/equLhY06ZNy5uT9mMRC6TDcdGFWPSUTCS0sa5OB1paNHzsWJ0diWSV5JvRh/fGPZ/cAICc9//+3//T1VdfrS1btjjdFEjasmWLvvrVr+rOO+/Ua6+9pnPOOcfpJpmiurpaVVVVisVix41QPfHEE5KkpUuXHrdfLBZTJBLRzJkzVVNT0+O5UCikmpqatGVKHZf5+/3+tOUOBl6v19XrYmeDWCAdjosuxKInr8+nc66+2ulmpGXhVzBXSFpiXfG9uk7Sdxyo1zq1tbUKhUK211tfX995b6NbbNmyRcXFxbaPXO7du1ennXaa6aP6TvvQhz6kTZs22V7v+PHj9dprr9ler5WuuOIKLVlif5953XXX6TvfGTx95m233UaiPwi9//77+tKXvuR0M0xTWVmpcDis0tLSHpfzR6NRVVVVqbq6Ou2l9jU1NYpGo6qtrU07o351dbUqKirU2NjY+bt4PK4ZM2aotbVVzz77bFaT/gEAMBAWJvsHJf1AUvbryfbfXEm/l/SBjXVa78iRI3r55Zd16aWX2lbn/fffr9tvv10HDhywrU47GIahtrY2TZ8+Xfv27bOlzrVr1+rSSy/Ve++9Z0t9dnrvvff02c9+tseJrZWOHDmi6dOn6+9//7uj8wVY4eDBg/rBD37QrzW4+2vu3Ln6/e9/rw8+cFefCWSirq5OVVVVikQiqqioUCQSUVVVlerq6lRZWZl2n7KyMgUCAYVCobRfBgQCATU0NKihoUGlpaWaMWOGIpGIQqGQ2traBs29+gCA/GDxZfw7JW21tooe3pZkTwJntwMHDujNN9+0rb6dO3e6dsIuwzD0xhtv2DbxlN3vnd02bNjQ50RXZjIMQ+vWrbOlLifs3LlTW7fa12e+/fbbtn3plakHHnhA11xzjTZv3ux0U9DNySefrP/8z/90uhmmKy8v73VCvXSCwWCfs/in9HbfPgAAdrLhnv1Nkh6T1PdSDQNjSKqRFLewDucdOnRIDz30kP71X/9VBQUFltXz1FNP9Tlhk1s8+uij+pd/+Rf90z/9k2V1vPHGG1q5cqVl5Q8WzzzzjM4880x99KMftayO/fv36xe/+IVl5Q8WmzZt0mOPPXbC5W0GwjAM1dTU2PYlTTY+8pGPqLm5WXv37nV8okA3y/cJ+gAAyAc2fHJHJX1T0oSj/58tyaxE9T1Jb6gj2b9Vbrt8/1jvv/++br75Zp1//vny+XyaOnWqioqKTCnbMAy9/PLLkqTvfe97Wrt2rSnlDmZVVVUaOXKkPvzhD+uMM87Q5MmTTSt77dq1OnDggFauXKkf//jHppU7WD366KM6dOiQJGnIkCFZrU19Itu2bdP27du1Y8cO3XbbbaaVO1hFo1F985vf1IQJHX3m7NmzTfty77333tMbb7whwzB06623DtrL9z0ej04//XSnm+FaL7zwgu688069+uqrvW4zceJEffvb39a1115Lkg8AQI6y6RN8q6SPHf15s6QxJlR9SNIaSZcPsJzcYhhG5737v/nNb3TllVdq+PDhAyqzvb1de/bs0Zw5c1x3H/SJ3HTTTZKkq6++Wv/xH/9hysRJe/fu1TXXXKP169cPuKxc8thjj+mxxx7TqFGj9Je//EXFxcXyeDwDKnPfvn168MEH9aMf/cikVuaGrVu36mMf6+gzN2/erDFjxgw44Tp06JDWrFmjyy/Prz4TPa1evVqlpaW9ThZKkg8AgHs4sCDiBElvSkqqY0Q+W8bRfR9XviX6x7r66qv1wx/+UMlksl9JumEYSiaT2rlzp0aNGpV3iX53v/nNb/SJT3yiM5bZXj6cimUymVRJSUneJfrd7dq1S6NGjVJ7e3u/YimpM5bz58/Pu0T/WBMmTNCbb77Z71imjs3HH3+cRB/64x//mDbRnzhxon75y1/q7bff1r/8y7+Q6AMA4AIOJPuSNFNSoaTb+rHvx4/um/mEOm72ve99T4WFhf1a+/j+++9XYWFh5+XC+W7t2rUqLCxUYWFh5yXpmdqwYUPnvm6cdT9b7e3tGjZsmAoLC/Xiiy9mtW8ymdQpp5yiwsJC/elPf7Kohbll5syZKiws7NdtDB//+MdVWFiY1SRkcK9PfOITPf5Pkg8AgHs59KmemgX9F5J+m+W+uyS5a63ygUiNgG7evFnjx4/Pat/9+/e7bt33gUrFY8qUKVldgp5IJIjlMVKrHZSVlemkk07Kat+DBw9a0aSclYrlL37xC/32t7/Nat9du3ZxbKJTKBTSH//4RzU0NGjWrFkKh8Mk+AAAuJTDn/DvHn1goBKJhGuXynNCS0uL001wjX/84x9ON8E13n33Xb37Ln0m+s/j8eif//mf9c///M9ONwUAAFjMocv4AQAAAACAVUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZnxWFer1eFRQUWFG0K6RiQ5z6RpwyQ5wyQ5wAAACQTyxJ9rdt22ZFsa7i9XqJUwaIU2aIU2aIEwAAAPKFJcl+MBjU7t27rSjaFVIJB3HqG3HKDHHKDHHK3M6dO51uAgAAAAbIkmR/9+7d2rVrlxVFu0LqEmLi1DfilBnilBniBAAAgHzCBH0AAAAAALgMyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMiT7AAAAAAC4DMk+AAAAAAAuQ7IPAAAAAIDLkOwDAAAAAOAyJPsAAAAAALgMyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMiT7AAAAAAC4DMk+AAAAAAAuQ7IPAAAAAIDLkOwDAAAAAOAyJPsAAAAAALiMz9nqh0oqzHKf9yW1W9CW3ObxeDRixIis9jl8+LAOHz5sUYty24gRI+TxeDLePplM6r333rOwRblr+PDh8vmy62r2799vUWty29ChQ1VYmF2f+f7776u9nT4TAAAg3zic7N8k6WdZ7jNb0hoL2pLbSkpKFIvFstqnurpad911l0Utym3/+Mc/NGzYsIy3X79+vT784Q9b2KLctWrVKl122WUZb59MJlVYWKgjR45Y16gcddNNN+lnP8uuz5w9e7bWrKHPBAAAyDcOXca/RtIBST/px74vHt23xtQW5apvfetbOnDggN56662s97399tt14MABNTc3W9Cy3DNt2jQdOHBABw4cyHr0dMqUKZ37nnLKKRa1MHd4vV699957OnDggObMmZPVvh6PR/v27dOBAwf0qU99yqIW5pY1a9bowIED+slPsu8zX3zxRR04cEA1NfSZAAAA+cSBZL9J0gWShkka0o/9Tzq6b5mkJ01sV+6pra3VbbfdpmHDhmWdnEqSz+fTsGHDNG7cOL355pvyevN3CofPf/7z+u1vf6thw4Zp2LBhWV3CL3Ukt6l9o9Gozj77bItaOvh96EMf0vr16zV8+HANGzZMBQUFWe3v8Xg6Y/noo4/qq1/9qkUtzQ1NTU264IILNGzYMA0Zkn2fedJJJ2nYsGEqKyvTk0/md58JAACQT2y6jP8sSQ8c/fl89S/JP9Zpkj4hqe7o/6+RlB+X/S5fvlwFBQX6+Mc/ruLi4gGX5/P5dM455+iJJ56QYRi65557+nWlQC5atGiRJk2apJKSEpWUlJhS5uTJk/Wzn/1M+/bt0zPPPKNHH33UlHIHu7lz5+q6667TsGHDTPuyY8yYMfrqV7+qT3ziE9q9e7cWLlxoSrmD3VlnnaUHHnhAknT++ef3K8k/1mmnnaZPfOITqqvr6DOvueYabpUAAABwMRuS/XMk3SgpbEHZ/qPlGpLulPSwpDYL6hkchg0bpptvvlnhcDjr0dIT8Xq9mjdvniRp7969evTRR/Xqq6+aWsdgc/PNN+uaa67RuHHjTC+7tLRUknTmmWfq0KFDeuyxx0yvYzCZO3euysvLdcUVV5he9rnnnqtzzz1Xra2tisViuv/++02vYzA555xzdOONNyocNr/P9Pv9CofDMgxDd955px5++GG1tbm3zwQAAMhnNly3PU3SHRbX4ZF0n6QzLK7HWcOHD1d1dbXpif6xKioqdMkll1hax2Bwzz33WJLod/fRj340Ly5Dv+666yxJ9LsbOXKkvv/971tax2Awbdo03XGHtX2mx+PRfffdpzPOcHefCQAAkM8sTvZPlVRkbRU9fEjZL+WXG4YMGaJRo0bZVt+pp56qoiI73zt7jR492rY5Cux+7+z2oQ99KKuVCwbqzDPPzHpOhVxh99/dhz70oX7N9wEAAIDBz8JsxyvpHnVcWm+X1ZI+q46RfvfweDyaPXu2/vrXv9pW53e+8x09/PDDrpy0r7CwUH//+99tS6pmzZqlv/zlL5ZfkeEEr9er1atX6zOf+Ywt9Q0dOlR///vfdfrpp9tSn528Xq/uuecePfywfX3m6tWr9dnPfta1X54AAADkMwszuQZJt1lXfK+WS3LXpb5f+cpX9MILL9he71VXXaU33njD9nqtVFJSovfee8/25Ka4uFiHDh2Sz2fTnJg22b9/vyZPnmx7vTt37tSsWbNsr9dKDQ0Nuu2222yvd/ny5XlxewQAAEC+sXhk34lRYa/cOLLvxAi7U/VayePxODLCnoql20ZQnXpNBQUFroylE39vbjwuAQAAYFk2vlLSdGuKzsjVktwxY/fdd9+tW2+91bH6x40bp2eeecax+s300Y9+VI8//rhj9Xs8HjU0NOif/umfHGuDWYYPH64///nPGjp0qGNtePjhh3XllVc6Vr+ZVq5cqenTpztW/9VXX+36VQ4AAADyjUXXFH/UmmIzNk7SBQ63wRznnHOOI5dJp5x88smaM2eOY/Wbqbi4WB/5yEccq9/j8ejSSy/VSSed5FgbzOLz+XTZZZc52oZgMKgzzzzT0TaY5eKLL5bf73es/nHjxumCC9zRZwIAAKCDu67RBgAAAAAAJPsAAAAAALgNyT4AAAAAAC5Dsg8AAAAAgMuQ7AMAAAAA4DIk+wAAAAAAuAzJPgAAAAAALkOyDwAAAACAy5DsAwAAAADgMiT7AAAAAAC4jEXJflKSYU3RGTEcrt88hmHIMJx7LU7XbybDMJRMJh1tg9P1mymZTHJsmsTp1+J0/QAAADCfRcn+eEkvWlN0Ru6X9GkH6zfPjTfeqNtuu82x+jds2CC/3+9Y/WZatWqVzjnnHMfqTyaTOuWUU7Rt2zbH2mCW/fv3q7CwUIcOHXKsDR//+Me1dOlSx+o30/jx4/Xii871mffff78+/Wl39JkAAADoYFGyn5CzI+vtRx+5r729Xe3tzr0WwzCUSCQcq99Mg+G1OF2/mY4cOeJo/YlEwjVXSiQSCUdH1p3uZwAAAGA+C+/Zr5K00rrie3WfpF84UK91/uu//ku333677fW+8MILqqiosL1eK+3atUtXXnml7YnVvn379JnPfMZVyb4kfe5zn9P27dttr/eqq67Shg0bbK/XSlVVVVq50v4+87777tMvfuGuPhMAAACWJvtrJNVIqrOuiuMskfSYJHclAdu2bdMTTzyhH/zgB7bV+ac//UlLlizR6tWrbavTDgcPHtSqVat0zz336MCBA7bUuW3bNt1777165plnXHdf9H//939r0aJFevPNN22pL5FI6J577tF//dd/ad++fbbUaZc1a9aopqZGdXX29ZlLlizRY4895rovTgAAAGD5bPwNsnd0/yFJ622szz7bt2/Xj370I9vqa2ho0JNPPmlbfXZKJpP693//dx08eNCW+ux+7+z2H//xH1q/3p6/u2Qyqe9973uOzhVgpYaGBltH9x966CHb3jsAAADYy4al996XZPVlvoakLZKcvYfYaslkUps3b7Z8dHjnzp2uGzVNZ9u2bZYnjfv379eOHTssrWMw2L17t1pbWy2t48iRI9q8ebOldQwG77//vuW3RhiGoS1btjg+7wIAAACs47O+it9L2iTpjaP/HyLJY1LZSXVNBjhVkjtH+1La2to0ceJEvfvuuxoyZIh8Pp+8XnO+rzEMo/PEv6yszHWX76cTDAb1P//zP5o1a5a8Xq98PvP+HI4cOSLDMPSLX/zC0dUU7LJw4ULFYjF9//vflyQNHTrUtLJTE/Ft3rzZ0dUU7PL73/9emzZt0htvdPSZQ4YMkcdjTp+ZTCY7JwOcOnWqa6+QAJC9ZDKptWvXau/evSouLtb06dNNO8fINcQC6XBcdCEWPSUTCW1YsUIHWlo0fOxYTSkrk9fEvGJADAuMGjUqtdB9msd+QzJMekT7qGfwPgoKCoxEInGCOJ348Yc//MG09+zIkSNGQUGB47GxIk6ZPG644QbTYmkYhnHBBRe4Mk6ZPM4880xTY/md73zHlXHK9LF//37TYhmNZtZnAsgtLS0tnX+/LS0tWe3b3t5uLFmyxAgEAj36gUAgYCxZssRob2+3qNWDD7FAOhwXXYhFT+1HjhjPz5tnbPH5eiSpW3w+4/l584z2I0cyKmcgffiJOJDsFxnSX7vHo5+PxwzpVMdPxJ1MOk455RRj8eLFA36/duzYYRQVFTkeF6vilMlj6NChxqWXXjrwg98wjHHjxtn6xclgS2I9Ho9xxhlnGIlEYsCxjEQiRmFhoSvjlOmjqKjI+Otf/zrgWD722GPGqadm1mcCyC39PVFsb283rrnmmj77g2uvvTYvTuCJBdLhuOhCLHpqP3LE+J/x4/tMWP+npCSjhN9lyb4M6XxDmm1IP+wrPr08bji6b+AEdQzeh5lJx5gxY4zZs2cbn//857N+n5YtW2bMnj3buPDCCx2PidVxyuQxfPhwY/bs2cbs2bONQ4cOZRXLzZs3d+7r9XpdHadMHxdddJExe/Zso6mpKatYtre3Gx/72MeM2bNnG6eddprr45TJ4/zzzzdmz55t/PCHP8wqloZhGDfccIMxe/bs476F7+sBILf090RxyZIlGfUJS5YssbD1gwOxQDocF12IRU/Pz5uXUfL6/Lx5JyzLymTfYxjmz/Y2evRo7dq1K4Mtz5U0J8vSn5S0O/tGDSIFBQU6fPiwxowZk2GcTmzEiBG69tprs9rn9ddf1yuvvGJK/VawIk6Z+vKXv5zVPfxtbW1asWKFhS3qnZNxysSVV16pM888M+PtDcPQ0qVLlUwmTW3HYI9TJs4991zNmZNdn/nkk09q9+7s+kwLPhYAWGj79u0aO3asJKmlpUVjxow54T7JZFKTJk3KaOLTQCCgTZs2ufaeXGKBdDguuhCLnpKJhLYPG6ZxicQJt93q82nswYN93sPfnz48Uw7PHPDm0QcG6t1339XPf/5zp5vhGo888ojTTXCN3/3ud043wTXefPNNvfkmfSaAgVu7dm3GK5zEYjGtW7dOF154ocWtcgaxQDocF12IRU8bVqzQ1AwSfUkan0jo7bo6nXP11Ra3Kj33fuUCAACAtPbu3Wvp9rmEWCAdjosuxKKnAy0tlm5vJpJ9AACAPFNcXGzp9rmEWCAdjosuxKKn4UcvubdqezOR7AMAAOSZ6dOna8KECRltGwgENG3aNItb5BxigXQ4LroQi56mlJVpW4Zze231+XR2JGJxi3pHsg8AAJBnvF6vvva1r2W07W233ebqybaIBdLhuOhCLHry+nzaPHduRttumTu3z8n5rObudwIAAABpLVy48IQr+Vx77bVauHChTS1yDrFAOhwXXYhFT3OWL9dLJSV9bvNSSYnmLF9uT4N6QbIPAACQh7xer5YtW6YlS5YoEAj0eC4QCGjJkiVatmyZ60fpJGKB9DguuhCLnrw+ny7etEkvzJunrceM3G/1+fTCvHm6eNMmR0f1JcljWLCg8ujRo3N2HWs7uGG9bzsQp8wQp8wQp8xZ8LEAwEJmrNGcTCa1bt067d27V8XFxZo2bVrenLQfi1ggHY6LLsSip2QioY11dTrQ0qLhY8fq7EgkqyTfjD68N85+1QAAAADHeb1eV6+LnQ1igXQ4LroQi568Pp/Oufpqp5uRVv5+BQMAAAAAgEtZMrLv9XpVUFBgRdGukIoNceobccoMccoMcQIAAEA+sSTZ37ZtmxXFuorX6yVOGSBOmSFOmSFOAAAAyBeWJPvBYFC7d++2omhXSCUcxKlvxCkzxCkzxClzO3fudLoJAAAAGCBLkv3du3cz23UfUpcQE6e+EafMEKfMECcAAADkEyboAwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXMbnbPU3SLovy32ukLTW/KbkuLFjx+qVV17Jap+HHnpI992Xbfzzw+bNm3XSSSdlvP2mTZt06aWXWtii3LVy5UpdfPHFGW9vGIbGjx+vRCJhYaty0w033JD13+wVV1yhtWvXWtMgAAAADFoOJfuPSgpIOkvS6H7su1/SM5KqTW5X7rnhhhu0YMECFRYWavTo7GJZXl6uUCikvXv3KhwOW9TC3DFp0iQtXbpUUseXJwUFBRnve+qpp+rPf/6zpI7k6uDBg5a0MVd4vV41NDTI6/Vq+vTp8vv9Ge9rGIYaGxtlGIaqqqq0Zs0a6xqaIx599FEFAgGdddZZWf+dP/roo9q/f7+eeeYZVVfTZwIAAOQLB5L9eyV9VtIZ/dw/ePTf0yV9IOknZjQqJ91444268cYbsxo17W7cuHEaN26c3nvvPS1evFhVVVUyDMPkVuaGmTNn6pZbbtFll13Wr/1PPvnkzn1/8IMfaNGiRdq1a5d5Dcwhp556qu655x5ddtll8nqzv1PI4/F0XiVRWVmpmpoaNTQ0mN3MnHHvvffqs5/9rM44o399ZjDY0Weefvrp+uCDD/STn+RvnwkAAJBPbEr2R0j69NGfvy5pmAllnifpZkl/l2RIWikpaUK5g184HJbX69XChQt14YUXDri8U045RV//+tfV1NQkwzD05z//We+8844JLR38Lr/8chUXF+vSSy/V9ddfb0qZt9xyi1paWrRt2zZt2rRJr7/+uinlDnZTpkzRtGnTVFRUpK9//eumlDlv3jy1t7erqKhI7733nv7whz+YUu5gN2LECH360x195te//nUNGzbwPvO8887TzTffrL///e8yDEMrV65UMpkffSYAAEA+8hgWDOWOHj2626jmCElzJK0yu5puDEkXSlqvjtH+wa2goECHDx/WmDFjshr9LSgo0Nlnn61169ZpyJAhlrVvwYIFWrVqlVpbWy2rIxP9jVOmJk+erPr6el1wwQWml53y2GOP6Zvf/Ka2bt1qWR1WxykTZ511lm677TbdcccdltWxfft2hUIhbdiwoV/7D4Y4ZWLEiBGaM2eOVq2yrs80DEMXXnih1q9frw8+OL7PzNcrfIBctX37do0dO1aS1NLSojFjxjjcIgBApqzsw22Yjf8KWZvoS5JHHZP2lVhcj7P8fr/eeustSxN9SVq2bJluuOEGS+sYDF5++WVLE31Juvbaa/X4449bWsdg8MADD1ia6EvSmDFj9MYbb1hax2BwxRVXWJroSx23Sqxdu1YlJSWW1gMAAADnsPQeAAAAAAAuY3Gyf6+kX1hbRQ9RSVfaWJ99Zs+erS1btthW37333qtf/MLO984+Q4YM0b59+zRy5Ehb6ps9e7Y2b95sS11OaGpq0ty5c22pa8iQIdq/f7+Kiopsqc9udv/dRaNRXXmlO/tMAACAfGdhsv+IpJtkzmR8mTpZ0k8l3WpjndYrKyvTr3/9a51yyim21VlYWKjPfe5zeuqpp2yr0w5nnnmmXnvtNY0YMUIej8eWOgsKCjRmzBi9/vrr8vkcWu3SIq+88oo+/OEPW35rSYrH49GIESP04osv6rzzzrOlTrs88sgjuummm0yZjC9TJ598sn7605/q1lvd1WcCAADA0tn4J0r6kHXF96pEUnbrUA92p59+uiZPnmx7vX6/X1OmTLG9XiuddNJJlt+nn47P59MFF1xg2xcMdjn//PNVWFhoe73nnXeehg8fbnu9Vpo4caI+9CH7+8ySkhKNHu2uPhMAAACWjezfIOksa4rOSFBuuZz/8ssv1yWXXOJY/UVFRaqoqHCsfjOVlJSYtrxef3g8Hn3lK1/RiBEjHGuDWYYOHaqFCxc6eqVCOBzWueee61j9Zrrhhht01lnO9ZnBYJDL+ZGXamtrVVpaqoqKCkUiEUUiEUWj0UFbLgAA2bBo6T3J+ZWtGiWVOt2ItLJZAuxXv/qVFixYYFPL0jtw4IBOPvlk2+s1e6m0z372s/rd735nQssGZvz48dq2bZtp5TmxpNypp56qffv22VJXX77yla/o5z//eUbbDual93bs2OH46HpjY6NKSzv6TJbeQz6IRCKKxWJ69tln5ff7JUmxWEwzZsxQdXW1ysvLB1W5fWHpPQDIXVb24e66gRgAAOAEamtrVV9fr7a2ts6EXJICgYCWLl2qSCSimTNnKhgMDopyAQDoD5J9AACQV6qqqhQKhXok5CnhcLhzm4aGhkFRrh0SiaRWrNiglpYDGjt2uMrKpsjny88VmokF0uG46EIsekomEtqwYoUOtLRo+NixmlJWJu8gmZR7cLQCAADABtFoVPF4vM/R9WAwqMbGRsXj8bSJu53lWi2RSGr+/NV6+ukSJRJTO3//xS9u1dy5W7R8+Zy8OYknFkiH46ILsegpmUho9fz5Knn6aU1NJDp/v/WLX9SWuXM1Z/lyx5P+/Hk3AABA3luxYoUkqbi4uNdtRo4cKaljLguny7VSIpHUpEkva+XKS5VIjD/mufFaufJSTZ78shKJpEMttA+xQDocF12IRU/JREIvT5qkS1eu1Phuib4kjU8kdOnKlXp58mQlj3nObiT7AAAgb6QS7b5G1lPPvfrqq46Xa6X581dr69aP9bnNli0f0/z5q21qkXOIBdLhuOhCLHpaPX++PrZ1a5/bfGzLFq2eP9+mFqXHZfwAACBvxONxSV2j7Omknktt62S5UsdMzX3ZuXNnVuVJHaN0Tz89IaNtOy7ZTbr28lxigXQ4LroQi56SiYQmPP10RtuWPP20komEY5fzu/ddAAAAOEZra2tObStJY8eO7fNx0UUXZVWeJK1YsUGJxLiMtk0kxquubmPWdeQKYoF0OC66EIueNqxYoXEZXp4/PpHQxro6i1vUO5J9AACAPNPScsDS7XMJsUA6HBddiEVPB1paLN3eTFzGDwAAMIi1nOBEcefOnVmP7o8dO9zS7XMJsUA6HBddiEVPw8eOtXR7MzGyDwAA8kbqvvlMLqXv6/57u8qVpDFjxvT5GD16dFblSTq6Lva2jLb1+bYqEjk76zpyBbFAOhwXXYhFT1PKyrQtw3vwt/p8OjsSsbhFvSPZBwAAeSOT9e1TCXsm21pdrlV8Pq/mzt2c0bZz525x9WRbxALpcFx0IRY9eX0+bZ47N6Ntt8yd69jkfJJlyf5nJEWtKTojv5Z0s4P1m+d73/uefvSjHzlW/5YtW3TZZZc5Vr+ZVq9erS984QuO1Z9MJvXxj39cu3btcqwNZnn//ff1kY98RIcPH3asDV/60pf05JNPOla/mf7v//2/ikad6zN//etf6+ab3dFnAicyc+ZMSVJzc3Ov28RiMUnSrFmzHC/XSsuXz1FJyUt9blNS8pKWL59jU4ucQyyQDsdFF2LR05zly/VSSUmf27xUUqI5y5fb06BeWJTsRyXtt6bojOyQ9LaD9ZunublZW7Zscaz+gwcPDpr1gAcqHo9r7dq1jrZhzZo1+uCDDxxtgxna29v1yiuvKJlMOtaGN998U7t373asfjNFo1Ht3+9cn7ljxw69/bY7+kzgREpLSyX1vfxd6rlwOOx4uVby+bzatOlizZv3gny+rcc8t1Xz5r2gTZsudv0onUQskB7HRRdi0ZPX59PFmzbphXnztPWYkfutPp9emDdPF2/a5OiovmTpBH3PSDpd0nnWVZHWc5KabK7TWuvXr9eqVav0mc98xtZ6Y7GYnnrqKVvrtNq7776rX/3qV1qwYIE8Ho9t9R46dEiPP/64o8mxFX7961+rrKxMp512mq31Pv7443rnnXdsrdNqzzzzjE4//XSdd569feZzzz2npiZ39ZlAX1KJdmNjY9rn4/G4YrGYgsHgoCjXaj6fV/X1lyqRSKqu7m21tBzQ2LHDFYmcLZ9vvNPNsxWxQDocF12IRU9en0+X1tcrmUjo7bo6HWhp0fCxY3V2JKLxDif5nQwLjBo1ypBkSF8zpJghGTY93jSky4/WPXgfBQUFRiKR6BanEz8uuOACY926dVa8XWlt377dWLRoUc7FKZOHz+czmpqajCNHjtgSy3fffdd49tlncy5OmT6efPJJo62tzZZYtre3G9Fo1Dj11FNzLk6ZPL72ta8ZsVjMllgahmG8+eabxuWXH99nAm5XXV1tSDKam5uPe66mpsaQZDQ1NR33XHNzsxEMBo3y8nJTyx2olpaWzr/flpYW08sHAFjHyj7c4mRfhlRmyLZk/2zHT9atTDqKi4uteLvSuv3223M2Tpk+9uzZY0ssX3rppZyOUyaPuro6W2J5+PDhnI5TJo+ysjJbYmkYhnH22en7TCAfhMNhIxAI9PiysqmpyfD7/UZ1dXXafSorKzv/TnpL2vtT7kCR7ANA7rKyD7fp+gJDktWXTBsWlz84GIZh+eXnRseXQJbWMVhYHU9iaW75xNLcOoB8VldXp9raWkUiEQUCAbW2tioej6uurk6hUCjtPmVlZaqvr1cgEOj1cvz+lAsAgBU8hgVnfKNHj+4247hX0vmS1ppdTTeGpJGS9ikXkv6CggIdPnxYY8aMyXpm9mHDhmnfvn0aMmSIRa2TPvWpT+m5555Te3u7ZXVkYiBxysRJJ52k1atXWzor8s9//nPdeuutlk7KZ3WcMjFkyBDdeeeduu+++yyrY8uWLZo6daoOHTrUr/0HQ5wy4fV6df7551s6maRhGBo5cqT27duXNunniwAgt2zfvl1jx46VJLW0tGjMmDEOtwgAkCkr+3AbpktMSlovacrRx/smlv3W0TLPUa4k+gN18OBBnXvuuZoyZYpefPFF08ptb2/X1KlTNWXKFP3P//yP44m+HQ4fPqxwOKwpU6bo7rvvNrXsK6+8UlOmTNE999zjitn3T+TIkSN6+OGHNWXKFM2ZY+6SK0uWLNGUKVP0yU9+st+Jfi5JJpNav369pkyZoilTpuj9983rM9966y1NmTJF55xzTq+JPgAAANzBprURPpC08ejjGklb+948I89JuqVbuflz0rpp0yZt3LhR3/jGN1RXVzfg8lpbW3XVVVfp7bff1saNG3Xw4EETWpkbtm3bpo0bN+o3v/mN7rzzTlPKvO666/TCCy9o48aNrlkaLhNtbW3auHGjXnvtNV111VWmrDxw33336ec//7k2btyozZs3m9DK3PDBBx9o48aN2rhxo6655hpt3TrwPvO5557TLbfc0lkuiT4AAIC7ObAmwO8kBSSNkhSUVJrl/ssk7VTH8nrPmtu0HPPSSy9p+PDhisVi8vv9qqioyGr/V155Rc8//7z279+vJ5980qJW5oatW7fq8ccf1+mnny5Juv322+XLYsmMvXv36pFHHpHUcb9mPozm9+bQoUOqr6/X4sWL5fF4dPXVV2vcuHEZ728Yhu6//361t7fr17/+tTZs2GBhawe/3/3udwoEAho1apSCwWDnWt6ZWrZsmXbu3KmmpiY9+2x+95kAAAD5xKEFAB84+u9cZX9xwSJJb5vamlzW0NCghoYGjRo1SpMmTcpq3xUrVmjp0qUWtSz37NixQ3fddZck6YILLtDQoUMz3nfbtm2d+6IjYU/dGjF06FBdcMEFWe1711135cWtJJl64IEHJElz586V15tdn7lo0SK9/TZ9JgAAQL5xKNlPefroAwO1a9cuZvk10RVXXOF0E1zj61//utNNcI2nn35aTz9Nnwmgp0Qi0fnzzp07HWwJACBb3fvt7v25GRxO9gEAADAQ77zzTufPF110kYMtAQAMxDvvvKOSkhLTyrMk2edb5cwQp8wQp8wQp8wQJwAAAOQDj8GUzAAAADnr0KFD+stf/iJJOuOMM7KaYDZl586dnVcFrFmzRqNHjza1jcBAcHxiMBvo8ZlIJDqv0Dr//PNVWFhoWtu4jB8AACCHFRYWatasWaaVN3r0aI0ZM8a08gAzcXxiMOvv8WnmpfvdZTsVPgAAAAAAGORI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABcxmMYhuF0IwAAAAAAgHkY2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlfE43AAAAAOapra1VXV2dAoGAWltbJUl33323gsHgoCwX+cXs4ygWi6miokKRSEShUEiBQKDz99FoVCtWrFB1dXXn74ETiUajikQiampqkt/vH3B5TvadJPsAAAAuEYlEFIvF9Oyzz3aepMZiMc2YMUPV1dUqLy8fVOUiv1hxHMXjcTU2NqqxsTHt8yT6yFQ0GlVNTY1qa2tNK9PpvpNkHwAAwAVqa2tVX1+vtra2HqNRgUBAS5cuVSQS0cyZM7MeTbKqXOQXu4+jYDCopUuXclzihBYvXqwVK1Zo5syZikQieuKJJxSPxwdc7mDoOz2GYRiWlQ4AAABbFBUVaebMmWpoaEj7vMfjUSgU6vV5u8tFfrHqOIpGo1q0aJGqq6sVi8U0cuRIEnwMSFFRkeLx+HFJen/KcbrvZGQfAAAgx0WjUcXj8T6TnGAwqMbGRsXj8YxPYK0qF/nFjuMoEAhwuT4GjcHSdzIbPwAAQI5bsWKFJKm4uLjXbUaOHClJvd7bbGe5yC8cR8g3g+WYJ9kHAADIcamTxb5Gh1LPvfrqq46Xi/zCcYR8M1iOeS7jBwAAyHGpyaRSI0XppJ7LZuIpq8pFfrHjOErNpJ7S2tqqsrIyhcPhfpUHDMRg6TtJ9gEAAHJcau3mXNkW+cXq46ixsVGzZs3qkezHYjFNnDhR5eXlPX4P2GGw9J1cxg8AAAAgJ6WWMausrDzu95WVlaqtrTV13XQgl5DsAwAAAMhJfr+/10v1y8rKJElVVVV2NgkYNEj2AQAAclzq3s9MLgft6x5Su8pFfnHqOEotxRePxxWNRk0rFziRwdJ3kuwDAADkuEzWaE6ddGaznrNV5SK/WHUcxWIxVVRUqL6+PqNtAbsMlr6TZB8AACDHzZw5U5LU3Nzc6zapZGfWrFmOl4v8YtVxVFNTo9raWkUikRNumxrlB+wwWPpOkn0AAIAcV1paKqnvJZxSz2WzFJlV5SK/WHUcFRcXS5LKy8vTPt99ND8YDGZcLjBQg6XvJNkHAADIcamTxcbGxrTPx+NxxWKxrBMeq8pFfrHqOAoGg6qsrOx1ab1UfXwRBbsNlr6TZB8AAMAFqqurFYvF0t6b/MQTT0iSli5detxzsVhMM2bMUEVFhanlAt1ZcXyGQqFey5Q6LvP3+/0cn7BETvSdBgAAAFwhHA4bgUDAaGtr6/xdU1OT4ff7jerq6rT7VFZWGpIMSUZTU5Np5QLHsuL4bG5uNkKhkNHQ0ND5u7a2NiMYDBp+v7/XYxpIp7m5ufN4635MpZMLfafHMAzD2q8TAAAAYJfa2lrV1dUpEAiotbVV8XhcVVVVCoVCabePRqOKRCIKBAJqaGgwrVwgHauOz6qqKkWjUbW2tmrkyJEKBoOqrq626mXARerr67Vo0SLF4/HjlsobOXKk/H6/ysrKVFlZ2eO5XOg7SfYBAAAAAHAZ7tkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACXIdkHAAAAAMBlSPYBAAAAAHAZkn0AAAAAAFyGZB8AAAAAAJch2QcAAAAAwGVI9gEAAAAAcBmSfQAAAAAAXIZkHwAAAAAAlyHZBwAAAADAZUj2AQAAAABwGZJ9AAAAAABchmQfAAAAAACX+f8DKSgVd/Lr3GIAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n = 5\n",
    "img = torch.zeros(64 * n, 64 * n, 3)\n",
    "for i in range(n):\n",
    "    for j in range(n):\n",
    "        delta = 32 // (n - 1)\n",
    "        target = train_x[j * delta * 33 + i * delta][\"x\"][0].clone()\n",
    "        if i == 0:\n",
    "            img[i * 64:i * 64 + 64, j * 64:j * 64 + 64, 0] = target\n",
    "        elif j == 0:\n",
    "            img[i * 64:i * 64 + 64, j * 64:j * 64 + 64, 2] = target\n",
    "        else:\n",
    "            img[i * 64:i * 64 + 64, j * 64:j * 64 + 64, :] = target[:, :, None]\n",
    "        img[i * 64:i * 64 + 64, j * 64:j * 64 + 1, :] = 1\n",
    "        img[i * 64:i * 64 + 1, j * 64:j * 64 + 64, :] = 1\n",
    "fig, axes = plt.subplots(1, 2, dpi=200, figsize=(6 * 1.2, 2 * 1.2))\n",
    "axes[0].imshow(img, cmap='gray')\n",
    "axes[0].axis(\"off\")\n",
    "axes[1].scatter(*np.meshgrid([0, 0.2, 0.6, 0.8, 1],\n",
    "                             [0, 0.2, 0.5, 0.6, 1]), c='k', s=10)\n",
    "axes[1].scatter(*np.meshgrid([1], [0, 0.2, 0.5, 0.6, 1]), c='r', s=10)\n",
    "axes[1].scatter(*np.meshgrid([0, 0.2, 0.6, 0.8], [0]), c='b', s=10)\n",
    "axes[1].set_yticks(torch.linspace(0, 1, 3))\n",
    "axes[1].set_aspect(1.)\n",
    "axes[0].set_title(\"Images\", fontsize=11)\n",
    "axes[1].set_title(\"Disentangled $(x,y)$\", fontsize=11)\n",
    "plt.annotate(\"\", xy=(0.37, 0.5), xytext=(0.29, 0.5),\n",
    "             xycoords='figure fraction', textcoords='figure fraction',\n",
    "             arrowprops=dict(arrowstyle=\"->\", lw=1.5))\n",
    "plt.text(-.6, .6, \"Encode\")\n",
    "plt.savefig(\"figs/disent_problem.pdf\", bbox_inches='tight', pad_inches=0.01)\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.879651Z",
     "start_time": "2024-09-25T20:06:44.575368Z"
    }
   },
   "id": "a209531ebf77d3dc"
  },
  {
   "cell_type": "markdown",
   "id": "f41c1b63-06ef-4250-90f9-aef08e904e6e",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e42bd55c-bbf9-4b73-be81-3b80feaa7544",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.884698Z",
     "start_time": "2024-09-25T20:06:44.882684Z"
    }
   },
   "outputs": [],
   "source": [
    "class VAE(nn.Module):\n",
    "    \"\"\" VAE model \"\"\"\n",
    "\n",
    "    def __init__(self, latent_dim):\n",
    "        super(VAE, self).__init__()\n",
    "        self.latent_dim = latent_dim\n",
    "\n",
    "        self.encoder_seq = nn.Sequential(\n",
    "            nn.Linear(64 * 64, 1024),\n",
    "            nn.ReLU(True),\n",
    "            nn.Linear(1024, 512),\n",
    "            nn.ReLU(True),\n",
    "            nn.Linear(512, 128),\n",
    "        )\n",
    "\n",
    "        self.fc_mu = nn.Linear(128, self.latent_dim)\n",
    "        self.fc_logvar = nn.Linear(128, self.latent_dim)\n",
    "\n",
    "        self.decoder_seq = nn.Sequential(\n",
    "            nn.Linear(self.latent_dim, 128),\n",
    "            nn.ReLU(True),\n",
    "            nn.Linear(128, 512),\n",
    "            nn.ReLU(True),\n",
    "            nn.Linear(512, 1024),\n",
    "            nn.ReLU(True),\n",
    "            nn.Linear(1024, 64 * 64),\n",
    "            nn.Sigmoid()\n",
    "        )\n",
    "\n",
    "    def sample(self, z=None):\n",
    "        samples = self.decode(z)\n",
    "        return samples\n",
    "\n",
    "    def reconstr(self, x):\n",
    "        mu, _ = self.encode(x)\n",
    "        reconstr = self.decode(mu)\n",
    "        return reconstr\n",
    "\n",
    "    def encode(self, x):\n",
    "        x = self.encoder_seq(x)\n",
    "        mu = self.fc_mu(x)\n",
    "        logvar = self.fc_logvar(x)\n",
    "        return mu, logvar\n",
    "\n",
    "    def latent(self, x):\n",
    "        z, _ = self.encode(x)\n",
    "        return z\n",
    "\n",
    "    def decode(self, x):\n",
    "        x = self.decoder_seq(x)\n",
    "        return x\n",
    "\n",
    "    @staticmethod\n",
    "    def reparameterize(mu, logvar):\n",
    "        std = torch.exp(0.5 * logvar)\n",
    "        eps = torch.randn_like(std)\n",
    "        return mu + eps * std\n",
    "\n",
    "    def forward(self, x):\n",
    "        mu, logvar = self.encode(x)\n",
    "        c = self.reparameterize(mu, logvar)\n",
    "        reconstr = self.decode(c)\n",
    "        return [reconstr, mu, logvar]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "965449a4-6ebc-4d2d-999b-6f81cbdc6d09",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.888685Z",
     "start_time": "2024-09-25T20:06:44.885955Z"
    }
   },
   "outputs": [],
   "source": [
    "device_ = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "random_state = np.random.RandomState(1234)\n",
    "seeds_list = [34, 7777, 1234, 978124, 920952, 3986, 4604, 9522, 111, 71292]\n",
    "epochs = 1000\n",
    "train_dataloader = DataLoader(train_x, batch_size=64, shuffle=True, drop_last=True)\n",
    "test_dataloader = DataLoader(test_x, batch_size=64, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "8351edbf-f821-480d-816d-a2599010d343",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.896494Z",
     "start_time": "2024-09-25T20:06:44.894586Z"
    }
   },
   "outputs": [],
   "source": [
    "def transform(x):\n",
    "    return x\n",
    "\n",
    "\n",
    "def loss_function(recon_x, x, mu, logvar):\n",
    "    recon_loss = F.binary_cross_entropy(recon_x, x, reduction='sum') / x.size(0)\n",
    "    kld_loss = -0.5 * torch.sum(1 + logvar - mu.pow(2) - logvar.exp())\n",
    "    return recon_loss + kld_loss\n",
    "\n",
    "\n",
    "def train(kgi, seed=0, progress_bar=True):\n",
    "    np.random.seed(seeds_list[seed])\n",
    "    torch.manual_seed(seeds_list[seed])\n",
    "\n",
    "    # model\n",
    "    model = VAE(2)\n",
    "    if kgi:\n",
    "        batch = next(iter(train_dataloader))\n",
    "        inputs = batch['x']\n",
    "        enc_output = model.encoder_seq(inputs.view(inputs.size(0), -1))\n",
    "        mu = model.fc_mu(enc_output)\n",
    "        logvar = model.fc_logvar(enc_output)\n",
    "        lat = model.reparameterize(mu, logvar)\n",
    "        en_hidden_layers = 1\n",
    "        apply_kgi_to_model(model.encoder_seq, knot_low=[-0.1] + [0.2] * (en_hidden_layers + 1),\n",
    "                           knot_high=[1.1] + [0.8] * (en_hidden_layers + 1),\n",
    "                           perturb_factor=0.1, kgi_by_bias=False)\n",
    "\n",
    "        apply_kgi_to_model(model.fc_mu, knot_low=enc_output.min().item(),\n",
    "                           knot_high=enc_output.max().item(),\n",
    "                           perturb_factor=0.1, kgi_by_bias=False)\n",
    "\n",
    "        apply_kgi_to_model(model.fc_logvar, knot_low=enc_output.min().item(),\n",
    "                           knot_high=enc_output.max().item(),\n",
    "                           perturb_factor=0.1, kgi_by_bias=False)\n",
    "        lat_mean = 0.5 * (lat.min().item() + lat.max().item())\n",
    "        interval = 0.01\n",
    "        de_hidden_layers = 2\n",
    "        apply_kgi_to_model(model.decoder_seq,\n",
    "                           knot_low=[lat_mean - interval] + [0.5 - interval] * (de_hidden_layers + 1),\n",
    "                           knot_high=[lat_mean + interval] + [0.5 + interval] * (de_hidden_layers + 1),\n",
    "                           perturb_factor=0.1, kgi_by_bias=False)\n",
    "    model.to(device_)\n",
    "\n",
    "    optimizer = optim.Adam(model.parameters(), lr=0.00005, betas=(0.9, 0.99))\n",
    "    jemmig_history = []\n",
    "    loop = trange(epochs, desc=\"Training Epochs\", disable=not progress_bar)\n",
    "    for _ in loop:\n",
    "        model.train()\n",
    "        for iteration, batch in enumerate(train_dataloader, 1):\n",
    "            inputs, target = batch['x'].to(device_), batch['x'].to(device_)\n",
    "            optimizer.zero_grad()\n",
    "            output = model(inputs.view(inputs.size(0), -1))\n",
    "            loss = loss_function(output[0], target.view(target.size(0), -1), output[1], output[2])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "        # compute JEMMIG and log\n",
    "        model.eval()\n",
    "        jemmig_history.append(compute_jemmig(test_x.labels[:, :2],\n",
    "                                             test_x.data,\n",
    "                                             transform,\n",
    "                                             model,\n",
    "                                             random_state,\n",
    "                                             num_train=1000,\n",
    "                                             valid_idx=np.array([0, 1]),\n",
    "                                             categorical_continuous_factors=True,\n",
    "                                             continuous_factors=False,\n",
    "                                             batch_size=100,\n",
    "                                             num_bins=20,\n",
    "                                             artifact_dir=None)['discrete_jemmig'])\n",
    "    return jemmig_history"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cbf1435d-4758-4d80-becf-b16c5a9c2b5a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.910634Z",
     "start_time": "2024-09-25T20:06:44.897633Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0_False exists\n",
      "0_True exists\n",
      "1_False exists\n",
      "1_True exists\n",
      "2_False exists\n",
      "2_True exists\n",
      "3_False exists\n",
      "3_True exists\n",
      "4_False exists\n",
      "4_True exists\n",
      "5_False exists\n",
      "5_True exists\n",
      "6_False exists\n",
      "6_True exists\n",
      "7_False exists\n",
      "7_True exists\n",
      "8_False exists\n",
      "8_True exists\n",
      "9_False exists\n",
      "9_True exists\n"
     ]
    }
   ],
   "source": [
    "# train all models\n",
    "seeds = list(range(10))  # use `seeds = [0]` for fast test\n",
    "out_dir = Path(\"results/disent_paper\")\n",
    "\n",
    "out_dir.mkdir(exist_ok=True, parents=True)\n",
    "for seed_ in seeds:\n",
    "    for kgi_ in [False, True]:\n",
    "        name_ = f\"{seed_}_{kgi_}\"\n",
    "        if not (out_dir / name_).exists():\n",
    "            t0 = time()\n",
    "            hist_ = train(kgi_, seed_, progress_bar=True)\n",
    "            np.savetxt(out_dir / name_, hist_)\n",
    "            print(f\"{name_} trained in {(time() - t0) / 60:.1f} min, \"\n",
    "                  f\"loss={hist_[-1]:.2e}\")\n",
    "        else:\n",
    "            print(f\"{name_} exists\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a3065351-a450-42d0-8f40-dc71f07a2889",
   "metadata": {},
   "source": [
    "# Analysis\n",
    "\n",
    "### Metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7eedeb24-6b53-40ca-89cf-87c78ecff39a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:44.919060Z",
     "start_time": "2024-09-25T20:06:44.904863Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "No KGI\n",
      "JEMMIG score: 0.61 ± 0.13\n",
      "slowness: 0.73 ± 0.17\n",
      "\n",
      "KGI\n",
      "JEMMIG score: 0.71 ± 0.11\n",
      "slowness: 0.57 ± 0.19\n",
      "\n",
      "Copy to table\n",
      "DisEnt & $0.61\\!\\pm\\!0.13$ & $0.71\\!\\pm\\!0.11$ & $0.73\\!\\pm\\!0.17$ & $0.57\\!\\pm\\!0.19$ \n"
     ]
    }
   ],
   "source": [
    "def print_metrics(kgi):\n",
    "    losses = []\n",
    "    slowness = []\n",
    "    for seed in seeds:\n",
    "        # read history\n",
    "        name = f\"{seed}_{kgi}\"\n",
    "        hist = np.loadtxt(out_dir / name)\n",
    "        # use average of last 50 epochs (5 * 10) as final loss\n",
    "        final_loss = hist[-5:].mean()\n",
    "        losses.append(final_loss)\n",
    "        # AUC for convergence slowness\n",
    "        init_loss = hist[:10].mean()\n",
    "        slowness.append((1 - hist.mean()) / (1 - init_loss))\n",
    "        # read relative error\n",
    "    losses = np.array(losses)\n",
    "    slowness = np.array(slowness)\n",
    "    print(\"\\nKGI\" if kgi else \"\\nNo KGI\")\n",
    "    print(f\"JEMMIG score: {losses.mean():.2f} ± {losses.std():.2f}\")\n",
    "    print(f\"slowness: {slowness.mean():.2f} ± {slowness.std():.2f}\")\n",
    "    return losses.mean(), losses.std(), slowness.mean(), slowness.std()\n",
    "\n",
    "\n",
    "lmf, lsf, smf, ssf = print_metrics(False)\n",
    "lmt, lst, smt, sst = print_metrics(True)\n",
    "print(\"\\nCopy to table\")\n",
    "print(f\"DisEnt & \"\n",
    "      f\"${lmf:.2f}\\!\\pm\\!{lsf:.2f}$ & ${lmt:.2f}\\!\\pm\\!{lst:.2f}$ & \"\n",
    "      f\"${smf:.2f}\\!\\pm\\!{ssf:.2f}$ & ${smt:.2f}\\!\\pm\\!{sst:.2f}$ \")"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### History"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "945fd4cd6df0db39"
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0a04837f-62ed-4c71-b2ee-f5f65ef76c65",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:45.002740Z",
     "start_time": "2024-09-25T20:06:44.920673Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "Text(0.5, 1.0, 'Disentanglement')"
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 800x320 with 1 Axes>",
      "image/png": "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r73k45YW4PPP4wsf7bKLXHKlVSWGiKgQihq4jxo1KmXvOlG398QTsrTEbbfJz/K/+y77c+y0E9DUJHPWATm4VQnchw3LX1uJdti6Vc4CCsiCQUJo76f1AemUKbK846BBMgUlm9lHO7P77jJ47yxw/9OfYkE7EPteiIgqUVEDd4/HU8zLEZXeBx/IyOHcc4G77pLrOhu1l87q1fEj3x5/XM6L3q8f8Ne/dqWl1MO98IK8n7z66vhKK5ncX6aqDjNpklxeegl4883s27TPPsBFFwH335+8beBAWVv9tdeAc86RHzhplWFkvXEi6k44go2oUDZvjpWsCAS6fj6dLrmY9KGHAqtWyailK5/1U7cgRHwxoc5s3gysWAH8+CPw29/Kdf36AVdcEdsnk+ouOzIgU7LZ5P1ltj74APD7tbe1tcmvZ58te/NrauQkRk88Eb/f4MHZX5eIqFyVrEjz3Llzce2112LkyJEYOXIkxo8fj1mzZpWqOUT599FHXTu+d29ZGvK77+SsKh9/rB2VVVczaCd88YWcdfO004BMhgdt3y4Hax54YHwllEmT4vdLDNwnT5ZBszplZvHi9Ndqa5Nv32zts48MzA87TN6j3nijXN+3b/w8X0cfDey/v5zk989/jqXk9OrFAaNE1L2UpMf92muvhdvthlD95W9ubobX64XFYsHMmTMxsLPp7IjKnTKHey7efVdGI/36ya7Eu+/OX7uoWxo3DvjhB7nMmRMrt/jdd7I++Z57xu+/eLF2Gkz//sAjj8gBqffemxy433qrXPr1k5laV1zReeCe6KuvgIULgeuvl4NFtVxxhbxP3WMPYNEiuW7bNlk7ff/9k78fQOayP/SQfBwKycozw4dn1zYionJW9B738ePHw+VyYcSIEXA6nfD5fPD5fJgyZQoGDRoEn8+HCy+8sNjNIsq/desy269v3/hZYL79VpbeUKZsJOqEEPFB+MqV8usHHwAHHACMGCEzqtRSvT3795e91itXyuA5VarML78AV14p367qAZ+dzR1WVSV7+X/72+QbhwsvlJ8WfP01MH168rF9+wKXXprZIFeDgUE7EXU/Re1xb2pqgsfjgcViwezZs+O2jR07Fna7HWPHjoXP58NLL72E89WfhRJVim3bgOXLMw/cIxFZkPqhh4CRI+VClIXVq+OfKx/2/O538usvv8hSjn//e2yf9eu1z/Xjj/HPO+tNP/DA+OcNDTJz69FHtfevrpbBOyA/TFq1CjjySKC1VY7jrqqKTYhERETxihq4u1wu6HS6lNVl9Ho9PB4P9t9/f8yYMYOBO1Wejg7gmGNkHkAmnntOdnECMo+dKAeJvenffy+/qrO1NmyI3yfVfWXirKPKINBM7b67LKDUu7fMS99vP8Bsjm1PHF89dKgc3Lp5s6wSQ0REqRU1cA8GgzAajWnz1w0GA/R6PXw+XxFbRpQnoVDmQTuQHMUQ5SCxl3zaNFlDXT2ANHFcc6oe964aOFBe68EHY+vOPDNWDrJXr+RjujoBEhFRT1HUHPeQMlFMJ2pqagrcEqICWbEi/fbEmYJ32qlwbaFuqaMjuW661jjoa6+Nf67TAW+/Ddx5J7B2beaZXNnSKnx0zDGxx0cdVZjrEhH1BEWfOTWYGLgkaG1tRSgUgsViKVKriPJo+fL020eNkqkxW7bI54MGFb5N1G20tACjR8t88A8/jOWXawXur74a//ynn4DzzgM2bgTuuUdOWlQst90me9Q/+0yWbCQiotwUtcfd4XBACIFbb7015T4TJkyATqdj4E6V5+mngcsuS7196lT5takJGDZMTglpNBanbVRWhABmzgReeaXzfZ97Tg4s3bIF+Mc/ZDbW+vXATTfF9lGnygwYIL9u2RK7PwTk227jxtjz117LvL2pJnX6/HPgmWc6P753b2DiROD//i95MCsREWWuqD3udrsdLpcLTqcToVAIkyZNwpFHHokNGzZgwYIFaGhoQDAYhMFgwMSJE4vZNKKuEQK4/HLtbZGILK592GHy+XHHyefZTHFJ3cqbbwLjx8vHH38cn0ry888ywB09WqbEXHKJXK/XAwsWxJ9DoZR/BOQMpe+8k3zNzZtTt2fwYO2c97vvBhwOmVZz6KHx2+66Czj8cPm2fuopec2nnkp9DSIi6rqiT8DU1NQEk8mEmTNnJlWXEULAYDBgzpw5xW4WUfY6OmTwrdPJrkctV14p02EOPzx+PYP2HmvhQjkbqOLuu4HXX489v+MOWbZx4MD48v433ywnHlJ0dMia51VVwH//K9cNGAAcf7x24J6KXi/TaKo0Pn9ta5NVYjo64tf/5S9Afb18rNMBPp9M3+FYayKiwir6BEx6vR7Nzc2YMmUKhg8fDiEEhBAYNGgQ7HY7lixZghEjRhS7WUTZ2bgROOIIWctu0SJg3rzkfZqagCeeKH7bqKxNmBD/PDFgVmqtb9gAvPFGbP2++yZPhnTWWbJWu1LH/YQTsp90aPBg7fvI3r2Bq6+WjxOHYvzxj7EqpoA8nkE7EVHhFT1wV9TX16O5uRkdHR0Ih8NoaWnBVCUHmKjcrF0bPwLwtdeAL7+U6ywWoLk5+ZgxY+RUj0Q7fPppfLoLIN9Kp5+u/RZSl3Ps6AC2bo3fPmeOTKtRHH00cPDB2bVpt92S1z3zDPDFF8A++8jniZP4snQjEVFpFD1wX7hwITYkzAQySNWdM2vWLMydO7fYzSJKLRSSEcywYcA338h1X38d275mjRw9SJTgq69kYN7eLp9feqn2fnPmAOPGAZs2pT6X+i2XyogRstc9HSW3XjF4cPI+Z54ZP4g0sUee96NERKVR1MB96dKlMJlMmJD4WbHK1KlTYbFYkoJ7opKprwe2bZMJv7/7nexp1+oeVbv33uK0jcrW6tXAsccC554rCwq99lpyqova55/Le8Su2HdfGWQ//njqfS6/PD4QVyrN/OlP8ushhwDV1V1rBxERFUZRA3fnjl7JSZMmpdxnypQpEEJgypQpxWoWUXqtrbHH8+bJMhrPPpt6/8ZG4M9/Lny7qKz985+yQgwg7/1uuKHzY5Ys6do1991XflVSXLQMHQqcf37suTKZ05Qpsvb7229r57xPnQrU1Mj9iIioNHRCqLMoC2v//fdHOBzG+k7m2q6qqoLJZML8+fOL1LLKsmLFCuyz4z/z8uXLMWzYsBK3qJs780zgrbcy23fWrPioiHqsM84AZs8u7jW3bJH56Nu3AyaT7OH3eGQajmLVKrnf4YfLEpEvvhi/PR0hWBCJiChThYjXiloOMhQKoba2ttP9DAYDQl39zJgoX3pn+GuybRvQp09h20JlbeVKOdHQkCGyqFAx1dTEBpH26SMHwra2yvVqu+0mty9cKGu3H3ts5tdg0E5EVFpFH5za0tJS7EsSdU2mgTuD9h7vsceAF16QX9vatPc59FDZ633OOfm7bk1Ncu9+r16xoP3llwGDQQ69UN6mI0dmF7QTEVHpFTVwHzVqFCKRCL7//vuU+7S2tiIUCqGurq6ILSNKI5PA3eUqfDuoqNatA669Fnj0Ue3tb70lA/QtW2LrMnkbnHmmzDNPrI2ejbvvll8HDAC+/x5YulTOmJrKr38tx1Pfdlvu1yQiotIraqqMw+HANddcA5vNhnlaE9YAsNls0Ol0sNlsxWwaUWrpetI//ljmD4weXbz2UMFt2AD84Q/A88/L5yZTfJnFZctkAA7IfPIbb5SPjzgCeO+99OdWUhxzDdynTJETIO23nxwnrQxIJSKi7q+oPe52ux1jx47FggULcMABB+DJJ5/EwoULsXDhQkyfPh0jR45EU1MTjEYjrlam7CMqpfb2WPSWaNo04Jhj5Kw3TP7tNtatA2pr41/2GTPi91E/v+mmWJ12dQEiLXvsAVxwgXycKnA/5pj45wceCOy1l3x8551AQ4PMZb/sMsBoTH89IiLqXora4w4AXq8XVqsVTU1NsNvtcduEEDAajfD7/cVuFlG8xYuBhx6Sxbe1vPBC8kw2VNZWrpSlDs85B9DrU+83aZIM3tWWLweuvx748EPgnnviZzQFgJ13llVAE49T++1vgaefjn2Ak9iGSy6RH9w4HMCVV8obB5MJ8HqBXXeVbTjyyEy/WyIi6o6KWg5Szev1wuVyIRAIAADq6upgs9nSTs5EEstBFlBrK2C1Ap3dPH72mcyLoIphNMpKK3vvDTz8sHyZdTqZo96/v9xn8WLgoIPye9033wR8PjnBkbq+ussFXHNN7Pny5bE0GkD24vfqld+2EBFR8VR8OUg1q9UKq9VaqssTaXM6Ow/aAWDgwMK3hfJmyxYZtAOy5/3CC2UPeWsr8Le/yXx1rxeYOze/1z3nHFnP/YwzkrclpsokvqUYtBMRUaKSBe5EZeW992QJkXRz0iuuuAIYPrzgTaL8Wb06eV19PVBdLdNe3ngD+PvfU5dwzNaZZ8rBrb/6Vep9Dj449vjcc3kvSEREnSvq4NTW1lbMmjULGzZsiFu/cOFCnH766Rg8eDAuuugiLFu2rJjNIgLOOiuzoH3tWuBf/yp8eyivVq3SXh8Oxx4//7yckCgfLr1U9rLvskvqfY48EnjuOeCRR+SQCSIios4UNcf9/vvvxy233AKPx4NxO+bYbm1tRXV1NXQ6HZSmVFVVYcmSJRjOXk1NzHEvgEyrwpRmSAjlYMMGWX2lb1/A45HpMcVQVRWrMkNERD1XIeK1ova4z9hRQ00J2gFEB6NarVaEw2FMmTIFHR0duOWWW4rZNCLqRj79FNhzT1nrPBxO3eOezu9/D5x6KjBrVnbH3XVX9tciIiLKRFF73GtqalBbW4v58+fHrWttbUU4HMbAHUmeNTU10Ol0WJ+vz613cLvd8Hg8MBgMaGlpAQBMmjQJxjwUQw6FQnA6nViwYAFqdswzbrPZkkpe5gN73Asgscd95EiZFpNYmJs97mWpowN4/HFZlvHyy+VkSR9/LLfddpvMXXc6sztnW5scINrWln4OLsUll8jqNPffn77cJBER9QwVX1UmEonAYDBEny9duhSRSAS1tbXRoB2QpSGbmpryem2bzYZQKISmpibod/xXDYVCMJlMcDqdXQqw3W43GhoaMG3aNLhUc543NDTA7XYXJHinArNageuuk1NkPv00MH26nP2GytKsWcANN8jHa9cC33wT27ZkiUyXyZZS1aV3mr+SkyfLe77hw1nWn4iICq+ogbter0ckEok+VyZaSuzxbmlpiQbX+eB2u+H1ehEOh+POazAYMG3aNNhsNtTV1eXU8+52u+FwOODz+WA2m6Pr/X4/3G43DAYDA/dKVFsri2oPGwaceKKM0HbbrdStohQ++ij2eNIkOdOo8qfm55+B2bPzf83qanlvx2owRERULEXNcTeZTPD7/fj+++8BAC6XCzqdDuMTuqqCwWBcz3xXNTQ0wGw2a94MKLXkGxoasj5vKBSCw+GA1WqNC9oB+T1EIpG4GxUqASGA228H7HY5WjFROAycdFLyevVMOQCD9jK3cmX8c3Xm0xtvZD9Y9JFH4p9Pnx7//He/A1paGLQTEVFxFbXHvaGhAU1NTdGgXAiB2trauMGqSopMYiCcKyWATtebbjQa4ff7EYlEsurpdzgcAGSefKL6+nro9fq8fR+Uo5deAu67Tz7u318W61YIISOy99+PP+aww4BTTilaE3u69nbgxhuBX36RAbMyi2k2li6Nf54YyGdj+/bk9JirrpIfvlx6KTB6NPDUU7mfn4iIKFdF7XE3m82YOnUqhBAQQsBsNmPOnDlx+zidTuh0Os1gOBdKJZvBgwen3EcZTOrPZMbMHUKhUMpUH4Xdbs/rJweUA/X7SzX+AEIAp58uZ+FRO+ssYOHC3JKiKSdPPAE8+ijgdsslU8uWAbfcAgSDyYF7Ns47L/55qpz2008H1qyRPfiZVg8lIiLKp6LPnGq329PmfM+ZMwdLly6NG6zaFUpwna4nXdk2f/78aOpMZ7xeL4BY0B4KhaIDUy0WS5d62lesWJF2+2qtaSBJm3reePW0mKEQ4PMl79+3L+eaL7Jp02KPn30W+OMfU++7eDGwfDkwdizwm98An30GPPhg5jOennkmMGaMXF57DTjkELnOYJCDWmfOTH98VVG7OoiIiOIVPXDPxIgRI/J2LiXHXOlV16JsyyYfXSlpWVNTA7/fD5/PB4fDgZqaGrjdbthsNjQ1NeU04HWfxPxqyp06CG9vBz74AHjySVnuUcvXXxenXT1Ee7sMdtP1UK9dG3u8++6xx6GQLK145pmyV3ztWuCYY2SFzmOPlUE7kHnQDsibhL33lo/Vv5rffgv8+CNw4IGZn4uIiKjYyjJwzyelXnu+9w2FQtHHPp8PTlWR6Pr6eqxfvx4mkwmBQCAvdeIpR4m95xMmxNcKTHTEEYVtTw/yxReA2Sxzwz/8ENhpJ+391IH7zjvLr3Pnyl51AJg6VQbr770XK6uv1GjPxqpVwNCh2tsGDZILERFROeMHvzlSeuf9fn90kKqask6ZGTYby5cvT7vMmzevS23vURID93RB+x57AH/9a2Hb04NceaXMCQ8E4tNhPvss9jKsXy8nT1Io985K0K74979lPntnHnss9mHKjBnyBmD2bDmkIVXQTkREVCm6fY97oSh58QaDQXMAqrIuGAwiGAxm1evOmVDzKJuk5FWrmMScR6oJkvHtt/Lre+8BJ58sZyL98EMZ2Kv99FN8IK9Ilffe1CQrvSjDPmprgUWLZA33Pfbo8rdARERUVrp9lKLkr2eSBpMuDz7VvumqxijB/YIFCzI+L+XZtm2Z78ugPa/UqTFbtsivzzwjv27fDlxwAZD4q/HDDzK3vTOffy4D/DFjgFdeAQYPlvNkWSzyugzaiYioO+r2Pe6Z1GVXgvpsarhnUuaxpqYGkUgEgUAg4/NSnm3enNl+Fkth29FDbN8OfPcdcNBBQL9+wNatcv3338t0FSVHHZDVYRYvjj8+Ekk9blhxzDHA4YfHntfVyTx5nY5lGomIqHvr9oF7XV0dgsEgmpubU+6jDDQdPXp0xuc1mUyd7qPcENTW1mZ8XsqTNWuAP/8ZeP759Pvdfbcs3H3ppcVpVzd30UXArFnAFVfIwF0J1H0+4NBDk4v2vPFG9td48MHkdfywhIiIeoJu/+/OsqMnNV2pR2VbpjXcgdjMrpmkwbCqTAncckvnQTsgaw1OmgSwBGeXvfOODNoBObNoYv66VqXNDRvkV4MB+Ne/Up/7nHOAM86QvfknnJCX5hIREVWcbh+4K8F4qllRI5EIQqFQ1sG1wWCA0WhEJBLRvCkIhUKIRCLQ6/VdmoyJcvTvf2e23777FrQZPYkStOfCaJS99O3t8fXVFa++Crz5JrD//rlfg4iIqNJ1+8AdAJxOJ0KhUFztdcXMHVMlTlPXq9shFArBZDJplntUzqs+h5oys6rWealM6HTAkCGlbkXF+v57eX+k3Le+915u56mpkRlLgEx5eecdYPz42PZjj+1CI4mIiLqRguS4L1y4EHq9HsOHD0+737XXXqu5vra2FhMnTsxbe+rr6zF//nxYLBYEAoHoINRgMIiGhgY4nU7NHneXyxUt5+hwOJL2MZvNcDqdcDgcMBgM0Z51v9+PhoYG1NfXZ5V+Q3kSDme230cfcTRjBl5/XVZx6d9fprPcfjtgs8nUlW++AebMAaZPl/tkYs895SylCr8fOPjg2PNdd5U3BIsXy3Sbp57K67dDRERUsXRCCJHvk9bU1KC1tRUejwfjxo1LuV9VVRV0Oh2UJiiPdTod2tvb890suN1ueDweGAwGtLS0IBKJoKGhIWUqSzAYhM1mg8FggM/nS3lev98Pp9MZHYxqMBjgcDgKliKzYsUK7LMjJ3v58uWs+57os8+Ao45Kv8/HH8vyJIQlS4Bx44D99gM8HjmodPVq4KyzZA66VnlGoxEIBmPPv/xSDj7NxBtvAPX1crKl996Ttde1CCFLPibOoUVERFQJChGv5b3H/cUXX0QkEoHJZEobtCv0ej1sNlv0eSgUQlNTE1566SWcf/75eW2b3W6H3W7PeH+j0Zi2Go3CbDYzj72crFyZfvuDDzJoV/nnP+WkRYsWAU4n8Je/AE88ASxcmPoYddAOAG+9lXrf886TtdYVp54qe+eFSF8NRqdj0E5ERKSW98B9xowZ0Ol00fzvztTV1WHq1KnR55FIBDU1NXjhhRfyHrhTNyeEnMFn1ar49bvuCjz0EHDKKTJPY8CAkjSvXKlz0x9+WAbu2ear33RT8rqddpIpL2efDRxwgMxgevZZ2aMPMEuJiIgoW3kP3JUBoHV1dTkdr9frodfrNQeSEqV12WWxqTkVr7wiawl20yhx82bg5pvlvcnf/pZ9PfOVK+OHBLS2ynKLH32Ue5sefFBOwHT88YAyp9myZXIQK2c0JSIiyl1BAne9Xo+BAwfmfI6amhoG7pS9xKAdAPbaq9sG7QBw//3A44/Lx4ccIu9dAGDjRpkfnu7XMByWeenq2UyBrgXtgJzLavfd49fttBODdiIioq7KezlIJdUlEz6fD1OmTElar9fr006YRJQk1RjroUOL244ie/LJ2OOXXpJfly+X9ytDhwKBgMxVDwaBCROADz4Atm0DHnhAprAkBu2dOeQQYO+90++TGLQTERFRfuS9x91gMGTcWz527FjN9aFQCAaDIZ/Nou5uyxbt9RneRFaq3qrf4O+/l8H5U0/JiYwAIDFjze8H/vpXmV6TiYYG4J57gBtvBF5+GWhslMMIrrsuts9uuwHr1snHnQX1RERElLu897iPGjUKAPCS0v2XpU8//RSRSCTrmUyph9u8OXld376xkZDdUEcHsHRp7Pmnn8p66ukqqS5bBtxwQ2bn33NPYOJEoE8f4LHHZE/+2WcDgwbF77dkSWwC2r/+NatvgYiIiLKQ98Dd4XBACIEJEybg559/zvp4m80GnU6H8eqpE4k6s2lT8jplZGQ39fTTuR23YUP67XvuKWcv/fZb2ZueKPHHOmiQLJ3/9dfAVVfl1iYiIiLqXN4Dd7PZjFGjRqGlpSVlKkwq48ePj6bJZFIDnihKK3BP7BruRjZsAK68Mv/nbWuTky+dfLKsVKNFa8CrXi8ryRAREVHh5D1wBwCPxwO9Xo9AIIDBgwfjSfUIOg1z587FyJEj4fV6odPp4PF4CtEs6i4WLwa2bpWjLC+8EDjjDO1Jl7pxj/udd+b/nHV1mU141DvvI2OIiIgoEwX5F2wwGOD3+zF27FiEw2HY7XbU19fDbDZj9OjRMBgMaGlpQSAQwIIFCxAMBiF2VAXxeDw4qrPp6qnneughOduP0SgTsJWbPK1pPrtR4P7dd8Cf/wwcdxxw663A3/+e3fGhEJBuvLdOB/z+95mdSz0AlYNRiYiIikcnRKo6el3X2toKq9WKpqYmeTGNetrK5Q0GAzweT3RwK6W2YsUK7LPPPgCA5cuXY9iwYSVuURGp30Nnnw28/nrqfc1mwOcrfJsKYNEi4MsvgfPPlzXQjz4amD8/t3PtsYf8QGLAAOCXX5K3G42y2kx1debndDqB2bOBRx4Bjjgit3YRERF1Z4WI1wqSKqMYNGgQfD4ffD4frFYrBg0aBCFE3GI2m+HxeLBkyRIG7ZSddEE7AHzzTXHakWfK7KW//a1crrgi+6B9/PhYjvqjj8oUmAMO0N73sceyC9oBWSZy7lwG7URERMVUlGzVsWPHRgeqtra2oqWlBTU1NRjUjQcPUp799BPw4YfZHVNbW5i2FJjPBygFmXKpqmo2Ay+8IMs3rlkDmExy/ZFHAp9/Lh/r9TK7aMsWDiolIiKqFEUfZjZo0CAG7JS9s8/OvtvZ6SxMWwqsqoufg516qvy6zz5yUdx1l7wR2LhR5snvt1/XrkNERETFxfoQVP42b84+aK+uBo45pjDtKbB0Eyglam6WA08DAeCWW2Qu/PXXa+9rMADz5skMonPPzU9biYiIqHgYuFP5W7Ei+2PGjMl/O4qktTX1tv79ZXoLALzxhgzGDQaZHnPZZXIgaroe+4MPlgsRERFVnoIOTiXKi+XLO9/nkUdij/v2Bf7xj4I1p9Bmzkxed+65MmDftAlwu4Fp02T5erWhQ7ueZkNERETlK+897r0ymcElAzqdDm1tbXk5F1W4TAL3iy+Wvey77grsu2/ZRbCbN8uyjql+Pf7wB2DOHFmiXquC5emnA/36yccTJhSunURERFS+8h7dJJZ77MpCBCCzwH3AAODww4Hhw8suaJ87F9htN1nVJRJJ3v7tt7Ik4+LFgN2ufY6hQwvaRCIiIqoAee9xd7lc+T4l9XRr13a+j9IdXYaeflqmuXz5JXDggbIU44UXAvfcI7d/9lnn59hzz4I2kYiIiCpA3gP3Cfwcn/KtpaXzfTRm5S0XCxfGHq9dK5d77wVOPhkYMkQG8Z1hjzsRERGxqgyVv/XrS92CLunTR3u9xZL5OdjjTkREROWVDEykRavH/ZRT5ARLu+wCNDYWvUnZ+PHHrp+jf/+un4OIiIgqGwN3Kn9K4N6vnxyAuvvustxjfb0sen7zzaVtXwpCyGoxK1d2vu+ECcDq1cCLL8pJlb78svDtIyIiosqS91SZWbNm5e1c48aNy9u5qIIpgfvee8uRnG1tsfyTPJUfLYTZs2W1GC2nngq8/Xbs+QUXyHQY5S2/cWNsW3V14dpIRERElSPvgbvVaoUuTwMF27OZ+526p/b2WA3FwYPlINRUSeNlYN06YMoU+UFAKKS9z6hRwH/+AwwcGFt34onx+wwYAPzzn3IypsmTC9deIiIiqhwFG5xqMBgwaNCgQp2eeooPPpA5JwBQU1Patqhs2QJcdJHMX3/xRWDYMNnM884D/vtf7WOmT5eBvdUq54k6+WTg3Xfl8112Sd7/uuvkQkRERAQUIHAfNGgQWltbEQqFYDab4XA4mPJCuXv00djjX/2qdO1IMGUK8Mor8rHLJWuyf/pp6qD9hBOAyy+Pz+z5z3+ADz8ETjqp4M0lIiKibiDvg1PD4TBmzpyJMWPGwOfzwWazoVevXrjooovwWSYzzRAphADef18+3mUX4KabStselYcfjj2+917gsMOAW2/V3tfhkN9GYjr+oEHAWWfJtBgiIiKizhSkqozVaoXP50NzczMmTpyIgQMHYubMmTAajRg5ciQefPBBbNiwoRCXpu5kyRLgp5/k45NPBnbaqSTNeP99wG6Pn0jp55/j9/nySzkYVct995X1/FBERERUIQpaDnLEiBFwOp0Ih8OYM2cOxo0bh+bmZtx8882orq7GGWecgbfVpTWI1NSR8jHHlKwZ55wDTJsmB5X+7ncyNSZTAwbIMbVEREREXVW0Ou5msxkejwfhcBhTp07F8OHDMWfOHJjNZgwePBi33norli1bVqzmUCX44ovY48MOK0kTtm4F1B8O/e//Atdck/nxb76Z/zYRERFRz1T0CZgGDRoEu92O5uZmBAIBXH311RBCYMqUKaitrcXo0aPx5JNPFrtZVI7UsxCVKHBfuzb3Y6+/PrnMIxEREVGuSjpz6qhRo+ByudDS0gKfz4cLLrgAgUAAdrsd06dPL2XTqNTC4VjS+M47A7W1JWnGjz9mt//FFwPz5snBq3ffXZg2ERERUc9UsDru2diwYQOWLl2KpUuXAgCEUrebei6/PzZ96MUXF3SG1G++AaqqgAMOSN7WWeA+d648Xqm37nAAo0fLhYiIiCifShq4z507Fy6XC16vF4AM2JXa7xdccEEpm0alpsyWChR0YGowCJhMsurLwoXAEUfIvPaqKuDcc+MrxeyxB7BmTez5wQfLYjcnnCCbu9turMlOREREhVP0wH3ZsmVwuVxwu92IRCIQQsBgMMDhcMBut3O2VZI2b4493nnnglxCCOAPf4g9vuMOYOBA4PnngbFjgTlz4vf/n/8BHngg9vzii2WA37cvMGlSQZpIREREFFW0wH369OlwuVwIBoPRVBir1QqHw4GxY8cWqxlUKQocuAsBnH66nLlUocyECiQH7YCcLEkduHNCYCIiIiqmggbuCxcujPauAzIVxmg0wuFwYMKECYW8NFW6LVtij/McuM+ZA1xyCbBuXebHHHkkcMopgMUiJ2SaPBk45JC8NouIiIgorbwH7hs2bIDb7YbL5UIoFIIQAnq9Hna7HQ6HAyNGjMj3Jak7KmCP++mnZ7f/4MHAPffIPPg5c+Q9Rf/+eW0SERERUafyHrjr9XrodDro9fpoKsyYMWPyfRnq7vIYuG/YIIPtPfYA1q/P7tihQ4FVq+LXMWgnIiKiUihoqozf74ff78/pWJ1Oh3XZ5DJQ95KnwH3dOmD//WVlyQ8/zKwu+zXXAFOnyscjR+Z8aSIiIqK8KkjgLoRAOBzu0jl0Ol2eWkMVKU+B+z/+AbS2yscXXQRkUmX01luB//s/2Ut///05X5qIiIgor/IeuAcCgXyfknqiPAXumzbFHi9bBrz7bvI+Bx8MfP117Pk++wA//CAD9733zvnSRERERHmV98B91KhR+T4l9UR5Ctx33TX++YIFyfuYTLHA/fDD5deampwvSURERFQQVaVuAJEmdeDer1/Op2lvT799p52AKVMAg0EG+U8/nfOliIiIiAqq6DOnEmVECdz795fTk+ZIyW9P1NwMTJsGHH+8TIf59ltg69aCTdJKRERE1GUM3Kk8KYF7FyLp9nbg739PXv/ss7KHffLk2LpevRi0ExERUXnLe+A+a9asvJ1rHOeU77m6ELgLIXPW587V3m6xdKFdRERERCWS98DdarXmrZRje2cJytQ9CQFEIvLxwIFZH/7II8CNN2pvmzgRGDIk55YRERERlUzBUmUMBgMGDRpUqNNTd/bzz7IWIwDsuWfWh6cK2mfMAKzWLrSLiIiIqITyHrgPGjQIra2tCIVCMJvNcDgcTHmh7KinN80ycG9rS73twgtzbA8RERFRGch7OchwOIyZM2dizJgx8Pl8sNls6NWrFy666CJ89tln+b4cdUfqwH2PPbI69Ntvtdc//HAX2kNERERUBgpSx91qtcLn86G5uRkTJ07EwIEDMXPmTBiNRowcORIPPvggNmzYUIhLU3fQhR735ub4588+K1Pm//SnrjeLiIiIqJQKOgHTiBEj4HQ6EQ6HMWfOHIwbNw7Nzc24+eabUV1djTPOOANvv/12IZtAlSiLwD0QAM47D3juOfl81arYtmnTgIsvLkD7iIiIiEqgaDOnms1meDwehMNhTJ06FcOHD8ecOXNgNpsxePBg3HrrrVi2bFmxmkPlrKUl9ni33dLuajYDr74KXHKJHM96zTWxbUOHFqh9RERERCVQtMBdMWjQINjtdjQ3NyMQCODqq6+GEAJTpkxBbW0tRo8ejSeffLLYzaJyotRwB4Bddkm7q1I1EgAefDB+GwN3IiIi6k6KHrirjRo1Ci6XCy0tLfD5fLjgggsQCARgt9sxffr0UjaNSkkduKeZgClxmMQdd8Q/32uvPLaJiIiIqMRKGrgrNmzYgKVLl2Lp0qUAACFEiVtEJaXUcAfSBu4nnpj+NJxoiYiIiLqTgk3AlIm5c+fC5XLB6/UCkAG7Uvv9ggsuKGXTqJQ66XH/5hvgt78FFi1KfYobbgB69SpA24iIiIhKpOiB+7Jly+ByueB2uxGJRCCEgMFggMPhgN1u52yrFB+49++ftNnhABYuTH34f/4jK80QERERdSdFC9ynT58Ol8uFYDAYTYWxWq1wOBwYO3ZssZpBlSBNj/u2bcB776U+1OEAzj23QO0iIiIiKqGCBu4LFy6M9q4DMhXGaDTC4XBgwoQJhbw0VTKNHvd584B77wW++EL7kJ12Av76V6ChoQjtIyIiIiqBvAfuGzZsgNvthsvlQigUghACer0edrsdDocDI0aMyPclqbtRAve+fYHevbFtG3D22cC6dcm77rcfMH++jO8HDChuM4mIiIiKKe+Bu16vh06ng16vj6bCjBkzJt+Xoe5MCdx3pMn4/dpBe0MDcPfdMr4nIiIi6u4Kmirj9/vh9/tzOlan02GdVrRG3V9C4D5zpvZuJ5/MoJ2IiIh6joIE7kIIhMPhLp1Dp9PlqTUxbrcbHo8HBoMBLS0tAIBJkybBaDTm/VomkwnTpk0ryLm7PVXgvnUr8PLL2rsNG1a0FhERERGVXN4D90AgkO9T5oXNZkMoFEJTUxP0ej0AIBQKwWQywel0wm635+1aDQ0NCAaDeTtfj6MK3H0+oLU1eZc+fWR+OxEREVFPkffAfdSoUfk+ZZe53W54vV6Ew+Fo0A4ABoMB06ZNg81mQ11dXV56x4PBIBobG7t8nh6rowP45Rf5eOed8corybsYDMCkScDAgcVtGhEREVEpVZW6AcXQ0NAAs9kcF7QrrFZrdJ98XYvpMV2wcWPs8c47IxSKPf3oI2DxYqC5Gbj66uI3jYiIiKiUun3gHgwGEYlE0gbTRqMRfr8fkUikS9dqaGhAQ0MDampqunSeHq25OfZ4332xerV82L8/cOyxwAEHlKZZRERERKVWloH73LlzMXfu3Lyca8aMGQCAwYMHp9xHCbRzrYADyHz5SCQCs9mc8zkIwDffRB++uewgfPWVfLznnkABxisTERERVYy8B+77778/DkjTLbphwwYsW7Ys7TnMZjNOO+20vLRHCca10mQUyrb58+fnfB2HwwGXy5Xz8bSDKnCf+s5B0ce77VaKxhARERGVj7wPTm1paUlbyvHqq6/GrFmz0NbWlvY8Qoi8tEdJf0mXvqJsyzVVprGxMW858gCwYsWKtNtXK/kj3dHnn0cffo2Do4+XLClFY4iIiIjKR0EnYEolX0F5JpR67fneVxEKhdDc3Iz6+vqsj01ln332ydu5KooQEJ98Ah2ACAZhCfaPbvrVr0rXLCIiIqJyUJLAvTtxOBzweDylbkb3sHIldDs+TZiP0aiuqcKWLcCuuwJ33lnithERERGVWFkG7nq9Hq1as+6UGSVFJl3+fC6WL1+edvvq1atx9NFH5/WaZUEZiQrgU4zCuecC//63LO1eVZbDqImIiIiKpywD93yqqalBJBLJKA0mmzKOhUiRUQwbNizv56wI334bfbgYB0IpBMSgnYiIiKhA5SDLqY55Jr3hSlCfTc+5w+GA0+nMsVWUSAjg05nfRZ9/iwNYSYaIiIhIpdv3uNfV1SEYDKJZPbFPgtCO6TlHjx6d0TmDwSAWLFgAk8mU9nxjx46N3sSku35Pt20b8OSTwH7vf4dRO9Z9h5FIU3qfiIiIqMfp9oG7xWKB2+1OW+pR2Wa1WjM6p9FoRDgcTrm9uroakUgETU1NaWdsJemMM4C33wbmYy0AoA29sAZ7sMediIiISKXbZw8rwXiqWVEjkQhCoRAD7BLZvFkG7QAwGOsBAGFUA9Cxx52IiIhIpSCBeygUQq9evTSXF198EQBSbu/Vq1fOEyGl4nQ6EQqFoiksajNnzgQATJs2TfP7MJlMcDgcOV03l7rwPc0TT8Qe10D+vNZDRuxDhpSiRURERETlqSCBuxCiS0u+1dfXw2q1wmKxxN0UBINBNDQ0wOl0ava4u1wuBINBuN1uBIPBjK4ViUSi19C6UaCY1auBiRPl497YjkHYAABogRwXcMABpWoZERERUfnJe477tGnTyrKn2ePxwO12w2azwWAwoKWlBZFIBB6PB2azWfOY8ePHw+v1wmAwdJpK09jYCJfLhZaWlmh1GqXyjF6vRyAQyPe3VJGEAF5/HdhjD+CHH2LrqxEbM6D0uPfu9iMwiIiIiDKnE4Xo4qaCWrFiBfbZZx8AcrKmSqr7/uyzwKWXAr16AaedBrz5plx/EL7G1zgEAPA0LkO/F57G+PElbCgRERFRFxQiXmOfJhXV7Nnya3t7LGgHYvntADDu6sHYlUE7ERERUZxuX1WG8sPplGUbv/mmMOffH0uij3cdznIyRERERInY406dam4GbrlFPv71r4HFi3M/V6qCQTfv5wG+3/HkpJNyvwARERFRN5X3wP3000/P+Vij0QiLxYIxY8bksUXUVeriON9+28nO7e3A5MmATgfsvDPw8cfAAw8AO3K8tMYt//fDDhx2+rvyyZ57AieckJ+GExEREXUjeQ/cfT4fdDpdTmUd/X4/Ghsb4XA48Pjjj+e7aZSjtrYsdn7oIeCOO+JWiR9/xKPj3sXPPwNr1iQfcmifb4GNG+WT444DqpjBRURERJQo74H7BRdcAJ1Ol9Oxfr8fkUgELpcLFosF559/fp5bR7lob89i5/r6pFW6997DHe9twM8YGF1Xh/m4CQ8icMDF2PWe6bGdTaYutJSIiIio+8p74O7xeLp0vMPhwLRp0zB58mQG7mUi48B9y5aUm2bjdHSgCkPwE3ywYIJuOvqKbbjo2xmAOv2GgTsRERGRprIbnOpyueDxeNDc3FzqptAOaeLxeEuWpNx0HD6OPj4A3wGpMqkYuBMRERFpKstk4rq6OkRSlR+hotu0KcMdOx25moEhQ7p+DiIiIqJuqCwD95aWFuj1+lI3g3bIOHDvapH3W2/t2vFERERE3VhZBu7BYBB1dXWlbgbtoBR8UXvqKeCGG4D161UrX3klab/n8NvMLnLMMcC99+bWQCIiIqIeoOxy3G/ZMdOPzWYrcUtIkdjjvnIlcOWV8vH33++I19evB+bNi+100kn47XvXwA8zLsbznV/kvvtk7XciIiIi0lR2Pe6RSARmsxlXX311qZtCOyQG7uqZU199dccD9cxKl1wCvPsuvL1/i3XYTfukhx4ae3z22QAn3SIiIiJKq+wC96lTp2LOnDmlbgapJAbuiR3j69cn7DRgAABgl10AQIfr8E+swN5wYCrOMv4I+HzA558DXq+cVXXmTPa2ExEREXWi7FJlqPwkBu4bNsQ//+47YHCbKhFeFbi3tgJP4Do8gesAAL98BGCnPeR+F1xQoBYTERERdT9l1+NO5ScxcFdnxQDA8uWIH8G6I3Dv3z/5XDvtlN+2EREREfUUDNypU9u3xz/vNHCXOTLYurWw7SIiIiLqSRi4U6feeAP49a9jzxMD9xUroNnjnjjj6lFHFaR5RERERD0CA3fKyM47xx7H1W6H7HFf8F7y4FR14H7llcDUqQVsIBEREVE3x8GplJF+/WKPE3vcX3kFMGzbiOiUWQMGQAjgl1/k07o64Mkni9FKIiIiou6LgTt17qWX8Jsvv8IR+Al/xiNJgfu2bcAAxOe4b98OdHTIp1qDVImIiIgoOwzcqXOPPYbz5r0NALgD96CpadekXeIC9wED8NFHsacM3ImIiIi6jjnu1Lm99oo+3BsrNXdJDNyvuCL2dN26QjWMiIiIqOdg4E6d23vv6MO9sEpjB4Fj8En02aLQLli2LLY1GCxc04iIiIh6Cgbu1DlV4J7Y4z5oEHA4FuEILAIA/Ig9MOr8/eL2cTgK30QiIiKi7o6BO3UuRapMr17AsGGAAaHouqdwBdpVQycGDwZuvrk4zSQiIiLqzhi4U+dSpMrcfjuw557A7lgbXdeM2ujjqipg2TKgNraKiIiIiHLEwJ06p+pxP374avz+98D27cBddwF6PbAH1kS3r8Ee0cfnnhudi4mIiIiIuojlIKlzgwdHH9YZWlD3j9gmvT6+x30tdgcABALAkUcWq4FERERE3R8Dd+rcLrsAffrIbnb17EvPPYfr3nkZffFVdJXS4240FruRRERERN0bA3fqnE4ne91//BFYv16u27wZuOQSJMbnSo87EREREeUXc9wpMzU18qvS4752bdIuLajGFuyMBx8sYruIiIiIegj2uFNmlMB90yagqQk444ykXTbsdRCCrwFHHVXcphERERH1BAzcKTOqAaoYPx5oa0vaZZj5IAwfVcQ2EREREfUgTJWhzCg97kAszz1B70MOLFJjiIiIiHoeBu6UmQMO6Hwf1n8kIiIiKhgG7pSZP/0J6N8//T4mU1GaQkRERNQTMXCnzPTrB9x0U/p9hgwpTluIiIiIeiAG7pS5q66SU6UmOvhg4OWXi90aIiIioh6FVWUoc8OHA598Ajz/vCwHuXIlcMghwEEHlbplRERERN0eA3fKzgEHAH/5S6lbQURERNTjMFWGiIiIiKgCMHAnIiIiIqoADNyJiIiIiCoAA3ciIiIiogrAwJ2IiIiIqAIwcCciIiIiqgAsB1mB2traoo9Xr15dwpYQERERkRZ1jKaO3bqCgXsF+umnn6KPjz766BK2hIiIiIg689NPP2H48OFdPg9TZYiIiIiIKoBOCCFK3QjKzi+//IJFixYBAIYMGYLevQv3wcnq1aujvfrz5s3D0KFDC3YtKgy+hpWPr2Hl42tY2fj6Vb5SvIZtbW3RLInDDz8c/fr16/I5mSpTgfr164fRo0cX/bpDhw7FsGHDin5dyh++hpWPr2Hl42tY2fj6Vb5ivob5SI9RY6oMEREREVEFYOBORERERFQBGLgTEREREVUABu5ERERERBWAgTsRERERUQVg4E5EREREVAEYuBMRERERVQBOwEREREREVAHY405EREREVAEYuBMRERERVQAG7kREREREFYCBOxERERFRBWDgTkRERERUARi4ExERERFVAAbuREREREQVgIE7EREREVEFYOBORERERFQBGLgTEREREVUABu5ERERERBWAgTtp8nq9MJlM0Ol0qK6uhs1mQzAYLHWzKEORSAQOhwO1tbXQ6XQwmUxwOBwIhUKlbhp1QUNDA3Q6HXQ6Hfx+f6mbQxkKhUJxv4/V1dWwWCz8m1ohGhsbYbFYUF1dHX3tvF5vqZtFCSKRCEwmU8a/VxUb5wiiBFarVQAQAITRaBQGgyH63OVylbp51IlAICD0er0AIPR6fdzrB0A4nc5SN5FyEAgEoq8pAOHz+UrdJMqAy+WK/u4ZDAZhtVqF2WwWer2ev4tlLhwOR/9+Jr52AITZbC51E3u8cDgsAoGAqK+vj74ugUCg0+MqOc5h4E5xlH8yRqNRhMPh6Hp1MJjJLwWVRjgcFnq9Xuj1+rjXKRwOC7vdHv3DxKCv8ij/XIxGI1/DCqH8PU38faTKoPyuaQVyyt9Tu91egpaREELU19fHdUopS2e/a5Ue5zBwpzjKm7a5uTlpm8fjYS9DmXM6nWn/6Cj/bPR6fZFbRl2h/KNxuVzCbDYzcK8A4XA4Gkho/T2l8qZ8wpXu/53y/5JKw+PxiPr6euFyuaKdVpkE3ZUe5zDHnaKCwSAikQjMZjMMBkPSdqvVCgDw+/2IRCJFbh1lYv78+TCbzTAajZrbnU4nAJkLyHz3yhCJRNDQ0ACDwQC73V7q5lCGGhoaAAD19fWaf0+pvC1YsAAAUv4tBRB9Xfm3tDSsViucTifsdjv0en1Gx3SHOIeBO0XNmDEDQPo/VMo2DowrT9OmTYsGDFr0en30D1xFDMIhTJgwAZFIJHrTReUvFArB7XYDAF+3ClVXVwcg/d9JJWDnjVnl6A5xDgN3ilL+QNXW1qbcR/ljxh6G8qTX62E2m9Puo/QiZNpDQaXj9/vh9XphNBqjPUFU/pSKI0pA5/V6YbFYohWBLBZL2fbmkWQ0GmG32+H3+9HY2Bi3LRKJwGazIRKJwOVylaiFlIvuEOcwcKeolpYWAEBNTU2n+65fv77QzaECUPceKX+cqHw5HA4A8pMUqhzz588HIIM/i8UCm82GlpaWuJ68ESNGlG1gQJLL5YLT6cTkyZOjZSBNJhOqq6sRDAbh8/mYvlZhukOcw8CdsqL00rK3qDJNmDABgPz4nj3u5a2xsRGhUAhWqzXtx7pUfpSA3Ov1oqWlBeFwGIFAAIFAAOFwGAaDITrXApU3q9UKs9mMSCQCv98f7fywWq3s/Oimyj3OYeBOUeX6JqX8cDgcCAaDsNvtqK+vL3VzKI1QKBQdq8De9sqj/lva1NQUd5Os1+vh8/kAyJ539rqXL6/Xi9raWgSDQXg8HoTDYYTDYTidTjQ2NsJkMvH1qzDdIc5h4E5RmfTAdoc3fU/U0NAAt9sNq9XKnMwKoPTEulwufjJSgZTXzGq1ar5+BoOh7AfA9XShUAg2mw0A4PP5oq+lXq9HfX09fD4fQqEQLBZLiVtK2egOcU7vUjeAyoeS86XkgGlRtqUb2EHlpaGhAY2Njaivr2eFiwoQDAajwZzP54v2ziqUMnVKiUgA8Hg8xW0kpaX8LU1XbcRgMCAYDKK5ublYzaIsKH8r7Xa75uuolBMMhULwer0cPF4hukOcw8CdooxGI/x+PwKBQMp9lPw+lr+qDDabDV6vFx6Ph/9YKpBSnURLMBhkSc8ypfwtLfeeO0pNuUFOF7wZjUaEQqFojzyVv+4Q5zBVhqKUj/yUP1halHy+zkoOUulZLBZ4vV7+U6kwRqMRQs5qrbkoH/X6fL7oOiovo0ePBpA+DUb5W6rsS+VFCdrSVRZRXsNy7ZmlZN0hzmHgTlHKmzRVT55Sy9ZsNjPvtsyZTCYsWLAAgUCgbP/4EHVXSj50KBTS/FuqXs/fz/KkBHipPvWKRCJ8DStQd4hzGLhTHGXgojK5hCIYDEarXDBPunxFIhGYTCZEIhEEAgGWESQqEeXv5NixY+P+lkYikWhQyMHH5ctut0dTYRLLdkYiEYwdOzZuP6oclR7n6AQ/Z6UESl40IO86W1paonemTqeTpQTLmMPhiE61rg4ItHJtXS4XJw+pQNXV1YhEIvD5fOzpK3Pq30fltVLSZ/j7V/6UqjGhUAh6vR51dXVx/w+tVisHhpdQMBiMq5Km/l1TUp1MJpPm71lFxzmCSIPL5RJGo1EAEHq9XpjNZhEIBErdLOqE3W4XADJaXC5XqZtLOdDr9QKA8Pl8pW4KZcDj8Qiz2Sz0er3Q6/XCarXyb2mFcTqdSa+hx+MpdbN6PI/H0+n/ObPZnPL4So1z2ONORERERFQBmONORERERFQBGLgTEREREVUABu5ERERERBWAgTsRERERUQVg4E5EREREVAEYuBMRERERVQAG7kREREREFYCBOxERERFRBWDgTkRERERUARi4ExERERFVAAbuREREREQVgIE7EREREVEFYOBORERERFQBGLgTEREREVUABu5ERERERBWgd6kbQERE1N00NDQgFAohFAoBABwOB+x2e4lbRUSVjoE7ERFRHlksFjidThiNRgCA3++HxWKBz+eDx+MpceuIqJIxVYaIiLoFt9uNxsbGkrahsbERDocjGrQDgNlsRn19PbxeL7xeb3R9JBJBQ0MD/H5/KZpKRBWIgTsREVW8hoYGOBwOmM3mkrbD5/PBZrMhEonErR8/fnx0u0Kv1wOQPfQM3okoEwzciYiKyOv1orq6OuOltra21E3Oiclkgk6nK0pAqvS0q9NT0gkGg6itrU0KrtOd32KxwOFwwGazwWazIRgMau5rNBqjAbmask7JeVc4nU6YzWZYLJakbUREiZjjTkRURC0tLdGA0WAwJG2j7IRCoWhqSn19fdp9g8EgXC4X3G53xue32WwIhUJoamqKC75NJhOcTmfSgFOn0wmn05l0HuUGxmKxJG1zuVyora2FzWZDIBDIuG1E1PMwcCciKpHm5uZSN6HiNTQ0AIBmsKxobGzEjBkzUFdXB5vNhpkzZ2bU2+52u+H1ehEOh+N60Q0GA6ZNmwabzYa6urqMevmdTicMBoPmzYXBYIDdbo9ez2q1dno+IuqZdEIIUepGEBH1FG63Gw6HAwDQnf/8mkwmBINB+Hy+guWdh0Ih1NbWwmAwZHUTVF1djUgkkhSQa+1XV1cXl5euptPpYDabU25XaPXaJ8r1eyGinoU57kREVJGUXnblRiifgsEgIpFI2t50o9EIv9+ftvfeZrMBAAKBQNqbBIPBAKPRiFAoxIGqRJQSA3ciIqpIM2fOBICCpJbMmDEDADB48OCU+9TU1ABAykDbZrPBYrHE1W5PF5QrlWdY652IUmHgTkREFScUCiESiUCv1ycN8s0HJcBO10uubJs/f37SNpvNhkmTJsUNXo1EImmDciWliD3uRJQKA3ciogrT0NAQLUmoTOJjMpmiJSSVAZupuN3uaLlGpZpJpsGi+ljleIfDkbaUYSgUgs1mQ3V1dfQY9UREuVDKMdbV1XXpPKko6S9Kr7oWZVtiqozJZEIoFMLkyZOj5SNtNhvGjh2btrynkpaj3JQQESViVRkiohJR8p/TmTZtWlKvbzAYjAbaSo61wWCIBnuNjY0IhUJJvbuRSARjx46NBr1KoKjM6Gm1WlP2CEcikbgAX6/Xo6amBi0tLXC73XC73QgEAkk54T6fL1p+0WAwIBgMRgN5j8eTc5qL0stdiN52ILvSnOp91TXetWq9p6t+A8ifayQSQSgUyqhaDRH1MIKIiIrG5XIJABkvzc3NSecwm83R7R6PJ7o+HA4Lq9WquU0IIQwGgwAg6uvr49aHw+HoOe12u2a7le1GozGpTYFAQFitVhEOh6PrjEZjtB1OpzPluXKlfJ+J586EXq8XAOLam2qfxJ+hmt1uFwCE1WrNug2pKD+3dNclop6LqTJERCUihOh0Sdej7HQ643qs9Xo9PB5PNFd68uTJ0W1KL7zVak3q9dXr9fD5fDAYDHC73UlpM16vF36/HwaDAYFAIKlNRqMRHo9HMx9ca2Ik5fqpZh/NhJKaky4HvRIp6TecjIuItDBwJyKqUKmCVq3A2OVyAQAmTZqU8nxKWcXEdBnl2M5y57Vo1XDPZ7CdLgc9H+fNJIDOZxuUnw1z3IlICwN3IqJuRp0brfRMK187q0sOJFc1WbBgAYDcBoKmG4zZFYUObDO5uVCC+kL0+q9fvz7v5ySiysfAnYiom1MHud2lJ1cJlguVUqLcpKSbxVS5GRo9enTer5+ufjwR9VwM3ImIuhl1iozBYIBer48GukrvebrjEnvllSA23bHFVqgUGYXFYgGQ/kZH2ZbPCaCUc3a33H0iyg8G7kREFSpVUKnkoqvzyy+88MK4bVrnUgazKjN4KpSylZ2VMiwmZYBsuh7xrlCC8VT17QtVslH5BKHQNyZEVJkYuBMRVajJkycnVWZR11pXBpUqj5U66jabLS7oD4VCGDt2LCKRCMxmc1IPst1uh9FoRCgUgsViSbphCAaDsFgsXZ5UKRtK7ny6iZ+6yul0IhQKaV5j5syZAGSd/XxK9akHERHAwJ2IqGSUmU4TF2VWUmVJ1etrMBhgMpmii06niwbPSqCuppR89Hq9qK6uRm1tbfRrMBiE2WxOOQFTU1MTjEYj/H5/9Jja2lrodDqYTCb4/f6ipncogW22JSXVs5J2lvpTX18Pq9WadLMSDAbR0NAAp9OZ1wBbfY1CTSxFRJWNM6cSEZVIVweKOhwO1NXVRXve9Xo9zGYzJk2apBlQGgwGNDc3o7GxET6fLxq4Wq1WjB8/Pm2utl6vRyAQgNvthsfjiR5rNBqj1yxm4K6kAWXS4+71ejF58mREIhG0tLRE22mz2VBTUwO9Xo/x48cn1ZsHZGlMt9sNm80Gg8GAlpYWRCKRuHr5+aLcoOX7vETUfeiEEKLUjSAiosxZLBb4/X64XC7Y7fZSN6dklJ+Dx+PJ6wDRUrHZbPB6vT3+dSWi1JgqQ0REFUmZMGrGjBklbkl+KD3uykBiIqJEDNyJiKgiWa1W6PV6eL3eiq9P73a7EYlEYLfbWQqSiFJi4E5ERBVLqeqilLKsVEqpzXIquUlE5YeBOxERVSyr1Qqz2YzGxsaCloYsJKXtLpeLve1ElBYDdyIiqmgejwd6vT46UVQlCYVCaGhogNVq5YBUIuoUq8oQEVHFC4VCMJlMaWvRl5tIJAKTyQSDwQCfz1fq5hBRBWDgTkRERERUAZgqQ0RERERUARi4ExERERFVAAbuREREREQVgIE7EREREVEFYOBORERERFQBGLgTEREREVUABu5ERERERBWAgTsRERERUQVg4E5EREREVAEYuBMRERERVQAG7kREREREFYCBOxERERFRBWDgTkRERERUARi4ExERERFVAAbuREREREQVgIE7EREREVEFYOBORERERFQBGLgTEREREVWA/wfDBiyhw6mLbgAAAABJRU5ErkJggg=="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def moving_ave(series, window_size):\n",
    "    \"\"\" Moving average to smooth the loss history a little bit \"\"\"\n",
    "    return np.convolve(series, np.ones(window_size) / window_size, mode='valid')\n",
    "\n",
    "\n",
    "_, ax = plt.subplots(figsize=(10 / 2.5, 4 / 2.5), dpi=200)\n",
    "out_dir = Path(\"results/disent_paper\")\n",
    "hist_def = np.loadtxt(out_dir / f\"{9}_{False}\")\n",
    "hist_kgi = np.loadtxt(out_dir / f\"{0}_{True}\")\n",
    "ax.plot(np.arange(1, 1000 + 1, 1), moving_ave(hist_def, 1), label=\"No KGI\", lw=1, c='b')\n",
    "ax.plot(np.arange(1, 1000 + 1, 1), moving_ave(hist_kgi, 1), label=\"KGI\", lw=1, c='r')\n",
    "ax.set_xticks([0, 200, 400, 600, 800, 1000],\n",
    "              [0, 2, 4, 6, 8, 10])\n",
    "ax.set_ylabel(\"JEMMIG score\")\n",
    "ax.set_xlabel(\"Epoch ($10^2$)\")\n",
    "ax.set_title(\"Disentanglement\", fontsize=10)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Visualize latent\n",
    "\n",
    "You need the pretrained model weights to visualize the latent. Please download them from [here](https://drive.google.com/file/d/1VA9MR9kVto3H80vlSMoxWxn6jKwWAiRR/view?usp=sharing)."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "fff68bda547e5712"
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [],
   "source": [
    "# read all data\n",
    "data_path = os.path.join(\"datasets/xy.npz\")\n",
    "data_zip = np.load(data_path)\n",
    "data = torch.from_numpy(data_zip['imgs']).reshape(1089, -1)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:45.002854Z",
     "start_time": "2024-09-25T20:06:44.994460Z"
    }
   },
   "id": "219afae6fff91cc6"
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "outputs": [],
   "source": [
    "def get_latent(path):\n",
    "    \"\"\" load model and compute latent \"\"\"\n",
    "    model = VAE(2)\n",
    "    model.load_state_dict(torch.load(path))\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        return model.encode(data)[0]\n",
    "\n",
    "\n",
    "xy_def = get_latent(\"results/disent_models/models_9_False.pt\")\n",
    "xy_kgi = get_latent(\"results/disent_models/models_0_True.pt\")"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:45.135948Z",
     "start_time": "2024-09-25T20:06:45.003665Z"
    }
   },
   "id": "83f439c55c5cc81a"
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 1400x600 with 2 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, dpi=200, figsize=(7, 3))\n",
    "axes[0].scatter(xy_def[:, 0], xy_def[:, 1], s=4, c='k', lw=0)\n",
    "axes[0].scatter(xy_def[:, 0].reshape(33, 33)[16, :], xy_def[:, 1].reshape(33, 33)[16, :], s=10, c='b', lw=0)\n",
    "axes[0].scatter(xy_def[:, 0].reshape(33, 33)[:, 16], xy_def[:, 1].reshape(33, 33)[:, 16], s=10, c='b', lw=0)\n",
    "axes[0].set_aspect(1)\n",
    "axes[0].set_xticks([])\n",
    "axes[0].set_yticks([])\n",
    "axes[1].scatter(xy_kgi[:, 0], xy_kgi[:, 1], s=4, c='k', lw=0)\n",
    "axes[1].scatter(xy_kgi[:, 0].reshape(33, 33)[16, :], xy_kgi[:, 1].reshape(33, 33)[16, :], s=10, c='r', lw=0)\n",
    "axes[1].scatter(xy_kgi[:, 0].reshape(33, 33)[:, 16], xy_kgi[:, 1].reshape(33, 33)[:, 16], s=10, c='r', lw=0)\n",
    "axes[1].set_aspect(1)\n",
    "axes[1].set_xticks([])\n",
    "axes[1].set_yticks([])\n",
    "axes[0].set_xlim(-2.5, 2.5)\n",
    "axes[0].set_ylim(-2.5, 2.5)\n",
    "axes[1].set_xlim(-2.5, 2.5)\n",
    "axes[1].set_ylim(-2.5, 2.5)\n",
    "axes[0].set_title(\"No KGI\", fontsize=12)\n",
    "axes[1].set_title(\"KGI\", fontsize=12)\n",
    "plt.savefig(\"figs/disent_latent.pdf\", bbox_inches='tight', pad_inches=0.01)\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:45.301813Z",
     "start_time": "2024-09-25T20:06:45.140046Z"
    }
   },
   "id": "4cdac1979f5f21c7"
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-09-25T20:06:45.302218Z",
     "start_time": "2024-09-25T20:06:45.299357Z"
    }
   },
   "id": "3db5f22a6a81011d"
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
