{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "c9c0fa1e-6269-42db-b306-fefd6f577891",
   "metadata": {},
   "source": [
    "# Entorhinal Modularisaion - Analysis of Learnt Reps - 21st August 2024\n",
    "\n",
    "Here we try to use Kyle's metrics to see if things are moduarised or not."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 418,
   "id": "f22b88a3-0b55-4f27-9ec3-fa2e3e039d36",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "from jax import vmap, value_and_grad, grad, jit, random\n",
    "import jax.nn as jnn\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import math\n",
    "import scipy\n",
    "import seaborn as sns\n",
    "\n",
    "from sklearn.preprocessing import LabelEncoder\n",
    "from sklearn.feature_selection import mutual_info_classif\n",
    "\n",
    "def entropy(x):\n",
    "    _, counts = np.unique(x, return_counts=True, axis=0)\n",
    "    p_x = counts / x.shape[0]\n",
    "    return -np.sum(p_x * np.log2(p_x))\n",
    "\n",
    "def conditional_entropy(x, y):\n",
    "    \"\"\"H(X|Y) = H(X, Y) - H(Y)\"\"\"\n",
    "    H_xy = entropy(np.concatenate([x, y], axis=1))\n",
    "    H_y = entropy(y)\n",
    "    return H_xy - H_y\n",
    "\n",
    "def compute_ncmi(s, z, n_neighbors=3):\n",
    "    \"\"\"\n",
    "    Normalized conditional mutual information between sources s and latents z.\n",
    "    The [i, j] element is the conditional mutual information between the i-th source and the j-th latent \n",
    "    given the rest of the sources, normalized by the conditional entropy of the i-th source given the rest\n",
    "    of the sources.\n",
    "    I(z_j; s_i | s_{-i}) = I(z_j; s_i, s_{-i}) - I(z_j; s_{-i}) = I(z_j; s) - I(z_j; s_{-i})\n",
    "    NCMI[i, j] = I(z_j; s_i | s_{-i}) / H(s_i | s_{-i})\n",
    "    \"\"\"\n",
    "    \n",
    "    ds = s.shape[1]\n",
    "    dz = z.shape[1]\n",
    "    \n",
    "    I_z_j_and_s_joint = np.empty(shape=(dz,))\n",
    "    s_joint = LabelEncoder().fit_transform([str(s_sample) for s_sample in s])\n",
    "    for j in range(dz):\n",
    "        I_z_j_and_s_joint[j] = mutual_info_classif(z[:, j].reshape(-1, 1), s_joint, n_neighbors=n_neighbors).squeeze()\n",
    "    \n",
    "    ncmi = np.empty(shape=(ds, dz))\n",
    "    for i in range(ds):\n",
    "        s_rest = s[:, np.arange(ds) != i]\n",
    "        s_rest_str = LabelEncoder().fit_transform([str(s_sample) for s_sample in s_rest])\n",
    "        for j in range(dz):\n",
    "            I_z_j_and_s_rest = mutual_info_classif(z[:, j].reshape(-1, 1), s_rest_str, n_neighbors=n_neighbors).squeeze()\n",
    "            ncmi[i, j] = I_z_j_and_s_joint[j] - I_z_j_and_s_rest\n",
    "        H_s_i_given_s_rest = conditional_entropy(s[:, i].reshape(-1, 1), s_rest)\n",
    "        ncmi[i, :] /= H_s_i_given_s_rest\n",
    "    return ncmi\n",
    "\n",
    "def compute_cinfomec(s, z):\n",
    "    \"\"\"\n",
    "    Compute CInfoM, CInfoC, and InfoE between discrete sources s and continuous latents z.\n",
    "    s: np.ndarray, shape=(n_samples, n_sources)\n",
    "    z: np.ndarray, shape=(n_samples, n_latents)\n",
    "    \n",
    "    Inactive latents are heuristically identified by their range being less than a proportion of the range of the most active latent. Inactive latents are ignored in the computation of CInfoM and CInfoC.\n",
    "    \"\"\"\n",
    "    ncmi = compute_ncmi(s, z)\n",
    "    ncmi[ncmi < 0] = 0\n",
    "    \n",
    "    z_ranges = np.max(z, axis=0) - np.min(z, axis=0)\n",
    "    max_z_range = np.max(z_ranges)\n",
    "    z_active = z_ranges > 0.1 * max_z_range\n",
    "    \n",
    "    ds = s.shape[1]\n",
    "    ncmi_active = ncmi[:, z_active]\n",
    "    dz_active = np.sum(z_active)\n",
    "    if dz_active == 0:\n",
    "        return {\n",
    "            'CInfoM': 0,\n",
    "            'CInfoC': 0,\n",
    "            # 'InfoE': 0,\n",
    "            'NCMI': ncmi,\n",
    "            'z_active': z_active\n",
    "        }\n",
    "    cinfom = (np.mean(np.max(ncmi_active, axis=0) / np.sum(ncmi_active, axis=0)) - 1 / ds) / (\n",
    "                1 - 1 / ds)\n",
    "    cinfoc = (np.mean(np.max(ncmi_active, axis=1) / np.sum(ncmi_active, axis=1)) - 1 / dz_active) / (\n",
    "                1 - 1 / dz_active)\n",
    "    # infoe = infomec.compute_infoe(s, z, 'discrete', 'continuous')\n",
    "    return {\n",
    "        'CInfoM': cinfom,\n",
    "        'CInfoC': cinfoc,\n",
    "        # 'InfoE': infoe,\n",
    "        'NCMI': ncmi,\n",
    "        'z_active': z_active\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 419,
   "id": "86f40c32-ff71-404c-86d8-f7323f97a9c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from metrics import compute_linear_metrics\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb081d1b-7eb9-4b76-9aa0-660e27df6344",
   "metadata": {},
   "source": [
    "Three cases:\n",
    "1) Totally random reward position\n",
    "2) Half random, half in one position\n",
    "3) Totally in one position\n",
    "4) Flexible prob of random vs. fixed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 657,
   "id": "6a2f804f-e271-4a0c-aa0f-393d90f1e1fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampling_choice = 2 # Correspond to 1, 2, and 3 above.\n",
    "prob = 9\n",
    "if sampling_choice == 1:\n",
    "    params_best = np.load('./data/PI_Learnt_Reps/random_2.npy', allow_pickle = True)[()]\n",
    "elif sampling_choice == 2:\n",
    "    params_best = np.load('./data/PI_Learnt_Reps/half_half_2.npy', allow_pickle = True)[()]\n",
    "elif sampling_choice == 3:\n",
    "    params_best = np.load('./data/PI_Learnt_Reps/fixed_2.npy', allow_pickle = True)[()]\n",
    "else:\n",
    "    params_best = np.load(f'./data/PI_Learnt_Reps/prop_{prob}_1.npy', allow_pickle = True)[()]\n",
    "\n",
    "N = params_best['W'].shape[1] # Number of neurons"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 658,
   "id": "703e6c64-f1e0-4ef3-b22a-5aa5178b66fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAS8AAAIOCAYAAADpxovWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABQz0lEQVR4nO3de1RUV543/O+B4hYEjcp15FLaGcKASQwkARO8DBEXGtfYY/Ikrh7FqN1NxNjKw6Ninl4a02uwexhfYkelNYAaOolPGmM78YqtgHYgjyjGdIf4mjdEK0jF4LSgJkBd9vsHodqqOhR1iqrAob6ftfZaXbv2OWdTHX9r73P2/h1JCCFARKQyPkPdASIiVzB4EZEqMXgRkSoxeBGRKjF4EZEqMXgRkSoxeBGRKjF4EZEqMXgRkSoxeLnRtm3bIEkSkpOTXTr++vXr2LRpEy5evGj33aZNmyBJ0iB7SDRyMHi5UXl5OQDgr3/9Kz766CPFx1+/fh2vvvqqbPBavnw56uvrB9tFohGDwctNGhsb8fHHH2Pu3LkAgLKyMreef8KECUhLS3PrOYnUjMHLTfqC1ZYtWzB16lS8++67+Pbbb63atLa24mc/+xliYmLg7++P6OhoPPvss/j6669RU1ODxx57DADw4osvQpIkSJKETZs2AZCfNprNZvzmN7/Bgw8+iICAAISHh2Px4sX46quvrNrNmDEDycnJOHfuHDIyMnDfffdh4sSJ2LJlC8xms9X5fvWrXyEhIQFBQUEYM2YMHnroIbz++uvu/rmIBo3Byw2+++47vPPOO3jssceQnJyMpUuX4vbt23jvvfcsbVpbW/HYY4/h/fffR35+Po4ePYqSkhKMHj0af/vb3/Doo4+ioqICAPC///f/Rn19Perr67F8+fJ+r/vSSy9h3bp1mDVrFg4dOoTXXnsNx44dw9SpU9He3m7VVq/X4yc/+Qn+7d/+DYcOHUJ2djYKCwtRWVlpafOb3/wGmzZtwsKFC3H48GHs378fy5Ytw61bt9z7gxG5g6BB27dvnwAgSktLhRBC3L59W4waNUpkZGRY2ixdulT4+fmJTz/9tN/znDt3TgAQFRUVdt9t3LhR3Pt/V3NzswAgVqxYYdXuo48+EgDEhg0bLHXTp08XAMRHH31k1faf/umfxOzZsy2fn3nmGfHII48490cTDTGOvNygrKwMQUFBeOGFFwAAo0aNwnPPPYczZ87gypUrAICjR49i5syZSExMdMs1T58+DQBYsmSJVf3jjz+OxMRE/OlPf7Kqj4yMxOOPP25V99BDD+Hq1atWx3788cdYsWIFjh8/js7OTrf0lcgTGLwG6fPPP0ddXR3mzp0LIQRu3bqFW7du4dlnnwXw9yeQ33zzDSZMmOC26968eRMAEBUVZfdddHS05fs+48aNs2sXEBCA7777zvK5sLAQxcXFaGhoQHZ2NsaNG4fMzEw0Nja6rd9E7sLgNUjl5eUQQuAPf/gD7r//fkvpe+q4d+9emEwmhIWF2d1IH4y+YNTW1mb33fXr1zF+/HjF59RoNMjPz8eFCxfw3//933jnnXeg0+kwe/Zsu4cPREONwWsQTCYT9u7di0mTJuH06dN25X/+z/+JtrY2HD16FNnZ2Th9+jQuX77c7/kCAgIAwGo01J9//ud/BgCrG+4AcO7cOTQ3NyMzM3MQfxkwZswYPPvss8jLy8N///d/48svvxzU+YjcTTPUHVCzo0eP4vr16/j1r3+NGTNm2H2fnJyMN954A2VlZXjjjTdw9OhRTJs2DRs2bMDkyZNx69YtHDt2DPn5+XjwwQcxadIkBAUF4fe//z0SExMxatQoREdHIzo62u7cCQkJ+NnPfobf/va38PHxQXZ2Nr788kv88pe/RExMDNasWaP475k3bx6Sk5ORmpqKsLAwXL16FSUlJYiLi8MDDzzgyk9E5DlD/cRAzebPny/8/f3FjRs3+m3zwgsvCI1GI/R6vdDpdGLp0qUiMjJS+Pn5iejoaPE//sf/EF9//bWl/TvvvCMefPBB4efnJwCIjRs3CiHsnzYKIYTJZBK//vWvxT/+4z8KPz8/MX78ePFv//ZvQqfTWbWbPn26SEpKsutbTk6OiIuLs3z+z//8TzF16lQxfvx44e/vL2JjY8WyZcvEl19+6cKvQ+RZkhB8exARqQ/veRGRKjF4EZEqMXgRkSoxeBHRoOzcuRMPPfQQQkNDERoaivT0dBw9etThMbW1tUhJSUFgYCAmTpyI0tJSxddl8CKiQZkwYQK2bNmCxsZGNDY24p//+Z/xL//yL/jrX/8q276lpQVz5sxBRkYGmpqasGHDBqxatQpVVVWKrsunjUTkdmPHjsV//Md/YNmyZXbfrVu3DocOHUJzc7OlLjc3Fx9//LGihJuqWKRqNptx/fp1hISEMBUy2RFC4Pbt24iOjoaPDycTzurq6kJPT4/sd0IIu39rAQEBll0g/TGZTHjvvfdw9+5dpKeny7apr69HVlaWVd3s2bNRVlYGg8EAPz8/p/qviuB1/fp1xMTEDHU3aJjT6XRu3fw+knV1dUEbNwr6GybZ70eNGoU7d+5Y1W3cuNGSHNPWJ598gvT0dHR1dWHUqFF4//338U//9E+ybfV6PSIiIqzqIiIiYDQa0d7eLptsQI4qgldISAgA4CnMgQbORWV3ef///cTlY3/8j5Pd2BNl1NpvVxhhwFkcsfx3QgPr6emB/oYJnzfGIDTEerTaeduMH6XqoNPpEBoaaql3NOpKSEjAxYsXcevWLVRVVSEnJwe1tbX9BjDbUV3f3SslMytVBK++P0gDP2ikHzZ42f4fq8QP3dd7qbXfLvn+ri1vKSh3X4jAfSHWt72N3/+gfU8PneHv748f/ehHAIDU1FScO3cOr7/+On73u9/ZtY2MjIRer7equ3HjBjQajWzqpv649F/4jh07oNVqERgYiJSUFJw5c8Zhe3c8FiUi9zMIs2wZLCEEuru7Zb9LT09HdXW1Vd2JEyeQmprq9P0uwIXgtX//fqxevRqvvPIKmpqakJGRgezsbFy7dk22vbseixKR+5khYLIpZihbgLBhwwacOXMGX375JT755BO88sorqKmpwU9+8hMAvUkuFy9ebGmfm5uLq1evIj8/H83NzSgvL0dZWRkKCgoUXVfxtHHr1q1YtmyZ5cUQJSUlOH78OHbu3ImioiK79qWlpYiNjUVJSQkAIDExEY2NjSguLsaCBQuUXp6I3Kh3pGVfp8TXX3+NRYsWoa2tDaNHj8ZDDz2EY8eOYdasWQB6E2beO7jRarU4cuQI1qxZg+3btyM6Ohrbtm1THA8UBa+enh6cP38e69evt6rPysrChx9+KHuMux6LEpH7GSBgsBlp2X4eyEDvKN2zZ49d3fTp03HhwgVF17GlKHi1t7fDZDLJPua0vQHXx5XHot3d3VbzZb4IgsgzDAIyI6+h6YtSLt2wl3vM6ehJj9LHokVFRRg9erSlcI0XkWcYhQSDTTEKdTy1VRS8xo8fD19fX9nHnLajqz6uPBYtLCxER0eHpeh0OiXdJCIn9cBHtqiBol76+/sjJSXF7jFndXU1pk6dKnuMK49FAwICLGtMlKw1ISJlDMJHtqiB4l7m5+fjzTffRHl5OZqbm7FmzRpcu3YNubm5ADz3WJSI3M8ofGGwKUbhO9TdcoripRLPP/88bt68ic2bN6OtrQ3Jyck4cuQI4uLiAHjusSgRuV+P8IWfzUirRyX3vFzaHrRixQqsWLFC9jtPPRYlIvczQ4LZZgKmdJHqUFHF3kYi8ozekZevTd0QdUYhBi8iL2aELwzwtalTBwYvIi9mEBoYbEZehpF8z4uIRoYe4QsNp41EpDYceRGRKhnhYxe8jHzaSETDnUFm2mhQyQvFGLyIvJhJ+MBks0jV9vNwxeBF5MU48iIiVTIKDQxCY1M3RJ1RiMGLyIsZhC98OfIiIrUxCB+Z4DX4twf9EBi8iLxYX0oc6zoGLyIa5gxmX/iYbUZeZgYvIhrmDMIXPpw2EpHaqDl4qWM1GhF5hFlIskWJoqIiPPbYYwgJCUF4eDjmz5+Py5cvOzympqYGkiTZlc8++8zp6zJ4EXkxd+Swr62tRV5eHhoaGlBdXQ2j0YisrCzcvXt3wGMvX76MtrY2S3nggQecvi6njURezGj2sbthbzSbFJ3j2LFjVp8rKioQHh6O8+fPY9q0aQ6PDQ8Px5gxYxRdrw9HXkRezNGrzzo7O63KvW+xd6SjowMAMHbs2AHbTpkyBVFRUcjMzMTp06cV9Z3Bi8iLGYUvjGab8v20MSYmxurN9UVFRQOeTwiB/Px8PPXUU0hOTu63XVRUFHbt2oWqqiocOHAACQkJyMzMRF1dndN957SRyIuZhA+M/WSV0Ol0Vi98DggIGPB8K1euxKVLl3D27FmH7RISEpCQkGD5nJ6eDp1Oh+Li4gGnmn048iLyYnajru8LALu31g8UvF5++WUcOnQIp0+fxoQJExT3JS0tDVeuXHG6PUdeRF7MKHwg2Yy8bEdiAxFC4OWXX8b777+PmpoaaLVal/rS1NSEqKgop9szeBF5MaPZB5LZx65Oiby8PLz99tv44x//iJCQEOj1egDA6NGjERQUBAAoLCxEa2sr9u3bBwAoKSlBfHw8kpKS0NPTg8rKSlRVVaGqqsrp6zJ4EXkxuUWpShep7ty5EwAwY8YMq/qKigosWbIEANDW1oZr165Zvuvp6UFBQQFaW1sRFBSEpKQkHD58GHPmzHH6ugxeRF7MJCS7aaNJYfASTuT/2rNnj9XntWvXYu3atYquY0vR+HCotgEQkWcYzT6yRQ0U9XKotgEQkWeYzD6yRQ0UTRuHahsAEXmGUfgAg3zaOFQG1csfahsAEXmG14y87qV0G0BKSgq6u7vx1ltvITMzEzU1Nf2O1rq7u632UXV2drraTSJywCwTrMwjPXh5chtAUVERXn31VVe7RkROMkECbJ4umqDsaeNQcSnEenobQGFhITo6OixFp9O50k0iGoAQkmxRA0Ujrx9qG0BAQIBTm0CJaHBMZgkwS/Z1KqAoeA3VNgAi8gyzzPagEXnPa6i2ARCRZ3jNyGuotgEQkWeYzZLMyGsEBi8iGlnMQoI0yI3ZQ4XBi8ibmSUI25EWR15ENNyZZe55cdpIRMOekBl52Y3EhikGLyJvJr4vtnUqwOBF5MWEkBl58YY9EQ13nDYSkToJ+43Zdp+HKQYvIm8m87SRSyWIaNgT5t5iW6cGDF5EXkwyS5BsRlq2n4crBi8ib6biaaM6cl8QkWeIfooCrrwSEeh9G1lKSgoCAwMxceJElJaWKrougxeRNzP3UxRw5ZWILS0tmDNnDjIyMtDU1IQNGzZg1apVivL8cdpI5MXccc/LlVcilpaWIjY2FiUlJQCAxMRENDY2ori4GAsWLHDquhx5EXkzB9PGzs5Oq3LvG70cceaViPX19cjKyrKqmz17NhobG2EwGJy6DoMXkReThGQZfVnK94tUY2JiMHr0aEspKioa8HzOvhJRr9cjIiLCqi4iIgJGoxHt7e1O9Z3TRiJvJneP6/vPOp0OoaGhlmpnXorj7CsRAUCSbPdUCtn6/jB4EXkxydxbbOsAIDQ01Cp4DaTvlYh1dXUDvhIxMjLS8gKfPjdu3IBGo8G4ceOcuh6njURerC942RYlhBBYuXIlDhw4gFOnTjn1SsT09HRUV1db1Z04cQKpqanw8/Nz6roMXkTerG+Rqm1RIC8vD5WVlXj77bctr0TU6/X47rvvLG0KCwuxePFiy+fc3FxcvXoV+fn5aG5uRnl5OcrKylBQUOD0dRm8iLyYJOSLEjt37kRHRwdmzJiBqKgoS9m/f7+lje0rEbVaLY4cOYKamho88sgjeO2117Bt2zanl0kAvOdF5N3kpokuTBsHYvtKRACYPn06Lly4oOxi92DwIvJmDp42DncMXkReTG6aqHTaOFQYvIi8mKOlEsMdgxeRNxOwnyaqZOSl6Gnjpk2bIEmSVYmMjHR4zGDTXhCR57hjnddQUTzySkpKwsmTJy2ffX19+23bl/bipz/9KSorK/HnP/8ZK1asQFhYmKJHokTkGV41bdRoNAOOtvq4I+0FEXmOmoOX4kWqV65cQXR0NLRaLV544QV88cUX/bZ1Ne1Fd3e3XToOIvIAN2RSHSqKgtcTTzyBffv24fjx49i9ezf0ej2mTp2KmzdvyrZ3Ne1FUVGRVSqOmJgYJd0kIiep+Z6XouCVnZ2NBQsWYPLkyXj66adx+PBhAMDevXv7PcaVtBeFhYXo6OiwFJ1Op6SbROQkNQevQS2VCA4OxuTJk3HlyhXZ711NexEQEOBU7iAiGiQVr7Af1Mbs7u5uNDc3IyoqSvZ7d6S9ICLPccfG7KGiKHgVFBSgtrYWLS0t+Oijj/Dss8+is7MTOTk5ADyT9oKIPMdrpo1fffUVFi5ciPb2doSFhSEtLQ0NDQ2Ii4sD0H/aizVr1mD79u2Ijo5WnPaCiDxHEjJLJVQy8lIUvN59912H33si7QUReY6a13lxbyORN5Nb1zUSR15ENLJw5EVEqsTgRUSqJJkFJLOwq1MDBi8iL8aRFxGpEoMXEakSgxcRqZPMIlW1LJXgS2eJvFjfDXvbokRdXR3mzZuH6OhoSJKEgwcPOmxfU1Njl05ekiR89tlniq7LkReRN3PDItW7d+/i4Ycfxosvvqho69/ly5cRGhpq+RwWFqbougxeRF5MMgGSj32dEtnZ2cjOzlZ87fDwcIwZM0bxcX04bSTyYo6mjbap2Lu7u9167SlTpiAqKgqZmZk4ffq04uMZvIi8mKOUODExMVbp2IuKitxyzaioKOzatQtVVVU4cOAAEhISkJmZibq6OkXn4bSRyIs5WmGv0+ms7km5K7txQkICEhISLJ/T09Oh0+lQXFyMadOmOX0ejryIvJijkVdoaKhV8WRq9rS0tH7TyfeHIy8iLyaZBCQfYVf3Q2tqauo3nXx/GLyIvJg7MqneuXMHn3/+ueVzS0sLLl68iLFjxyI2NhaFhYVobW3Fvn37AAAlJSWIj49HUlISenp6UFlZiaqqKlRVVSm6LoMXkRdzR1aJxsZGzJw50/I5Pz8fAJCTk4M9e/bYpYfv6elBQUEBWltbERQUhKSkJBw+fBhz5sxRdF0GLyJv5oZFqjNmzLC8j1WObXr4tWvXYu3atcouIoPBi8iLSSYBSRr6e16uYPAi8mJMRkhEqsTgRUSqxGkjEamTWfQW2zoVYPAi8mKS2QzJbLarUwMGLyIvJpmF3TSR97yIaPgTAGzXaKkjdinbmB0fHy+bvjUvL0+2vbvSvRKRh5iEfFEBRSOvc+fOwWT6e5rFv/zlL5g1axaee+45h8cNNt0rEXmGZDZDkrzgnpdt0NmyZQsmTZqE6dOnOzxusOleichDzDLvPlNJ8HI5n1ffbvClS5dCkiSHbZWme+3u7rZLQUtE7ieZhGxRA5eD18GDB3Hr1i0sWbKk3zaupnstKiqySj8bExPjajeJyBGTWb6ogMtPG8vKypCdnY3o6Oh+27ia7rWwsNCSVgPofREAAxiRBwiz/TRRjODgdfXqVZw8eRIHDhxQfGxaWhoqKysdtgkICPBoylki+p7JbB+sVHLPy6XgVVFRgfDwcMydO1fxsa6keyUiDzGbAJhk6oY/xcHLbDajoqICOTk50GisD/dUulci8hCzTDbCkbrC/uTJk7h27RqWLl1q952n0r0SkYeYBQDbaeMIDV5ZWVn9pnz1VLpXIvIQkwkQXjJtJKIRxGyG/chrBN+wJ6KRQZhMEDYjL8GRFxENe2aZpRIjeZ0XEY0QJhMg2Yy0bO+BDVMubw8iIvUTJpNsUaKurg7z5s1DdHQ0JEnCwYMHBzymtrYWKSkpCAwMxMSJE1FaWqq47wxeRN6sL4e9bVHg7t27ePjhh/HGG2841b6lpQVz5sxBRkYGmpqasGHDBqxatUrx+k9OG4m8mDCZIWymjULhPa/s7GxkZ2c73b60tBSxsbEoKSkBACQmJqKxsRHFxcVYsGCB0+dRRfDqW1dmhOEHT1Hbedv1m5dGYXBjT5RRa79dYURvfx29cp7kGUxdEDbbg/p+T9tUVO7ac1xfX4+srCyrutmzZ6OsrAwGgwF+fn5OnUcVwev27dsAgLM48oNf+/5/HMzRX7irG4qptd+Dcfv2bYwePXqou6EK/v7+iIyMxFn9B7Lfjxo1yi6Ty8aNG7Fp06ZBX1uv1yMiIsKqLiIiAkajEe3t7U7vfVZF8IqOjoZOp0NISIhd4sO+dDk6nc4q1TTJG4m/lxACt2/fdpieiawFBgaipaUFPT09st8LIez+rbkz04vtuftGzQMlNr2XKoKXj48PJkyY4LBNaGjoiPnH+EMYab8XR1zKBQYGIjAw8Ae/bmRkJPR6vVXdjRs3oNFoMG7cOKfPw6eNRPSDSk9PR3V1tVXdiRMnkJqa6vT9LoDBi4gG6c6dO7h48SIuXrwIoHcpxMWLFy0ZZgoLC7F48WJL+9zcXFy9ehX5+flobm5GeXk5ysrKUFBQoOzCQuW6urrExo0bRVdX11B3RRX4e5G7nT59ui8pmFXJyckRQgiRk5Mjpk+fbnVMTU2NmDJlivD39xfx8fFi586diq8rCcHny0SkPpw2fm/Pnj1Wb/XWaDSYMGECXnzxRbS2tnrkmpIkWT16/vTTT7Fp0yZ8+eWXdm2XLFmC+Ph4j/RjsDZv3gxJknD8+HG77/bv3w9JkpxefU3ktEGPGUeIiooKAUBUVFSI+vp6cerUKbFp0yYREBAgtFqtuHPnjtuvWV9fL3Q6neXze++9JwCI06dP27X9/PPPxYULF9zeB3cwGAwiJSVFTJgwQdy6dctSf/36dTF27Fgxc+ZMYTabh7CHNBKpYqnEDyk5ORmpqakAgJkzZ8JkMuG1117DwYMH8ZOf/MSt10pLS3O67aRJk9x6bXfSaDTYu3cvUlJSsGrVKuzduxcAsHz5chgMBlRUVChav0PkDE4bB9AXYK5evQoA6OrqQmFhIbRaLfz9/fEP//APyMvLw61bt6yOO3XqFGbMmIFx48YhKCgIsbGxWLBgAb799ltLm3unjXv27MFzzz0HoDdo9k1f+1Jry00bne1LfHw8nnnmGRw7dgyPPvoogoKC8OCDD6K8vNyq3bfffouCggJotVoEBgZi7NixSE1NxTvvvDPg75SUlITNmzdj3759OHToEHbv3o0jR45g69atiIuLG/B4IsWGeug3WNu3bxfx8fEiICBAPProo6Kurs6l8/RNG8+dO2dV//rrrwsAYteuXcJsNovZs2cLjUYjfvnLX4oTJ06I4uJiERwcLKZMmWJ5gtfS0iICAwPFrFmzxMGDB0VNTY34/e9/LxYtWiT+9re/Wc4NQGzcuFEIIcSNGzfEv//7vwsAYvv27aK+vl7U19eLGzduCCF6n9jExcVZjnW2L0IIERcXJ0JDQ2WfCNXW1lra/fznPxf33Xef2Lp1qzh9+rT44IMPxJYtW8Rvf/tbp35Do9Eo0tPTRXh4uBg1apTIzs5W8n8BkSKqDl7vvvuu8PPzE7t37xaffvqp+MUvfiGCg4PF1atXFZ+rL3g1NDQIg8Egbt++LT744AMRFhYmQkJChF6vF8eOHRMAxG9+8xurY/fv328JcEII8Yc//EEAEBcvXnR4zXuDlxCO73nZBi9n+yJEb/DSaDTigQceEG1tbaKtrU20tLSI+++/X/z85z+3tEtOThbz588f6Kdy6MMPPxQAREBAgGhtbR3UuYgcUfW0cevWrVi2bBmWL1+OxMRElJSUICYmBjt37nT5nGlpafDz80NISAieeeYZREZG4ujRo4iIiMCpU6cA9E7h7vXcc88hODgYf/rTnwAAjzzyCPz9/fGzn/0Me/fuxRdfuH+js7N96RMZGYn77rsPkZGRiIyMRHx8PBISEizTYQB4/PHHcfToUaxfvx41NTX47rvvFPerpKQEPj4+6O7uRl1dnfI/jMhJqg1ePT09OH/+vF1qjaysLHz44Ycun3ffvn04d+4cmpqacP36dVy6dAlPPvkkAODmzZvQaDQICwuzOkaSJERGRuLmzZsAem+unzx5EuHh4cjLy8OkSZMwadIkvP766y73y5azfekTFBSEK1euIDo6GlqtFi+88AKEEFYBatu2bVi3bh0OHjyImTNnYuzYsZg/fz6uXLniVJ/ee+89/J//83+wdetWzJgxAytXrsTXX389+D+WSIZqg1d7eztMJpNsag3bTZ9KJCYmIjU1FY888ohdao5x48bBaDTim2++saoXQkCv12P8+PGWuoyMDPzXf/0XOjo60NDQgPT0dKxevRrvvvuuy31ztS8AMGbMGOzbtw/Hjx/H7t27odfrceHCBRgMf8/dFRwcjFdffRWfffYZ9Ho9du7ciYaGBsybN2/A/nz99ddYsWIFZsyYgVWrVqG8vBxdXV146aWX3PL3EtlSbfDqI5daw1OP5TMzMwEAlZWVVvVVVVW4e/eu5ft7+fr64oknnsD27dsBABcuXOj3/H0pR5yZrintS3h4OBYsWIDJkyfj6aefxuHDhwGg35FRREQElixZgoULF+Ly5ctWT0nl5ObmoqurC+Xl5ZAkCVqtFr/+9a/x/vvvuy1gE91Lteu8xo8fD19fX9nUGrajMXeZNWsWZs+ejXXr1qGzsxNPPvkkLl26hI0bN2LKlClYtGgRgN40t6dOncLcuXMRGxtr+UcNAE8//XS/509OTgYA7Nq1CyEhIQgMDIRWq5VNE+JsX/oTHByM4OBgq6D0xBNP4JlnnsFDDz2E+++/H83NzXjrrbeQnp6O++67r99zvfXWWzh48CBKS0uh1Wot9StWrMAf/vAHrFy5EjNnzvTY/y/kpYb2ecHgPP744+Kll16yqktMTBTr169XfK7+lkrY+u6778S6detEXFyc8PPzE1FRUeKll16yWgJRX18vfvzjH4u4uDgREBAgxo0bJ6ZPny4OHTpkdS7YPG0UQoiSkhKh1WqFr6+vZcW/EPZPG53tixC9Txvnzp1rVdfV1WXZFNtn/fr1IjU1Vdx///0iICBATJw4UaxZs0a0t7f3+3u0traKMWPGiKysLNnvv/jiCxEcHCx+/OMf93sOIleoemP2/v37sWjRIpSWliI9PR27du3C7t278de//pULI20UFBRg3rx5iI2NxY0bN/CrX/0KtbW1+OSTT/hbkSqpdtoIAM8//zxu3ryJzZs3o62tDcnJyThy5Aj/Mcr46quvsHDhQrS3tyMsLAxpaWloaGjgb0WqpeqRFxF5L9U/bSQi78TgRUSDUlRUhMceewwhISEIDw/H/Pnzcfny5QGPq62tRUpKCgIDAzFx4kSUlpYqui6DFxENSm1tLfLy8tDQ0IDq6moYjUZkZWXh7t27/R7T0tKCOXPmICMjA01NTdiwYQNWrVqFqqoqp6/Le15E5FbffPMNwsPDUVtbi2nTpsm2WbduHQ4dOoTm5mZLXW5uLj7++GPU19c7dR1VPG00m824fv267EtnicQ9L5318eFkwlldXV2KXzrrzItnOzo6AABjx47tt019fb3dvuTZs2ejrKwMBoPBqVegqSJ4Xb9+3e7V40S2dDrdgC8npl5dXV3Qxo2C/oZJ9vtRo0bhzp07VnUbN260eueCHCEE8vPz8dRTT1l2jMjR6/Wy+5KNRiPa29vt9hXLUUXwCgkJAQA8hTnQwPmXUvb5YstjLl/7438tH7iRB/z4HycP6vjB/M2DMZjfy9W/2QgDzuKI5b8TGlhPTw/0N0z4vDEGoSHWo9XO22b8KFUHnU5n9VZ1Z0ZdK1euxKVLl3D27NkB28rtS5ar748qglffH6OBHzSS8uDlM4hXmtv+H/tDceXvvNdg/ubBGMzv5fLf/P1dW95SUO6+EIH7Qqxvexu//0FDQ0OtgtdAXn75ZRw6dAh1dXUDjoAjIyNl9yVrNBrZvbxyXPovbceOHZY85ykpKThz5ozD9oN9JEpEnmESQrYoIYTAypUrceDAAZw6dcpqc35/0tPTUV1dbVV34sQJpKamOnW/C3AheO3fvx+rV6/GK6+8gqamJmRkZCA7O9vyam9b7ngkSkSeYYQZBptihFnROfLy8lBZWYm3334bISEh0Ov10Ov1VqmdCgsLsXjxYsvn3NxcXL16Ffn5+WhubkZ5eTnKyspQUFDg9HUVBy+lqZdLS0sRGxuLkpISJCYmYvny5Vi6dCmKi4uVXpqI3MwgzLJFiZ07d6KjowMzZsxAVFSUpezfv9/Spq2tzWqAo9VqceTIEdTU1OCRRx7Ba6+9hm3btmHBggVOX1fRPa++1Mvr16+3qneUetkdj0SJyDMMEDBA2NUp4cxS0b5X+N1r+vTpDpNzDkRR8HIl9bIrj0S7u7vR3d1t+dzZ2amkm0TkJIPoLbZ1auDSDXulqZeVPhItKirC6NGjLYVrvIg8wygkGGyKUajjqa2i4OVK6mVXHokWFhaio6PDUnQ6nZJuEpGTeuAjW9RAUS/9/f2RkpJi94izuroaU6dOlT3GlUeiAQEBljUmSteaEJHzDMJHtqiB4l7m5+fjzTffRHl5OZqbm7FmzRpcu3YNubm5ADzzSJSIPMMofGGwKUbhO9TdcoriFfYDpV7u75HomjVrsH37dkRHRyt+JEpEnmGCBBMkuzo1cGl70IoVK7BixQrZ7zzxSJSIPKNvtGVdJ79Ze7hRxd5GIvKMHuELP5vg1aOSpRIMXkRezAhfGOBrU6cODF5EXswgNDLTxhF8z4uIRoYe4QsNp41EpDYceRGRKhnhYxe8jAo3Zg8VBi8iL2YSPjDZrKi3/TxcMXgReTGDzD0vg0rehsjgReTFGLyISJWMQgOD0NjUDVFnFGLwIvJiBuELX468iEhtDMJHJngpy2E/VBi8iLyYUWZjtpHBi4iGO4PZFz5mm5GXmcGLiIY5g/CFD6eNRKQ2ZvjAbJNQ2fbzcKWOXhKRRxjMPrJFibq6OsybNw/R0dGQJAkHDx502L6mpgaSJNmVzz77TNF1OfIi8mJGmWmj0hv2d+/excMPP4wXX3xRUXr3y5cvW71cJywsTNF1GbyIvJjR7GN3w95oVpYGOjs7G9nZ2YqvHR4ejjFjxig+rg+njURezNGrzzo7O63KvW+xd4cpU6YgKioKmZmZOH36tOLjGbyIvJhR+MJotinfTyNjYmKs3lxfVFTklmtGRUVh165dqKqqwoEDB5CQkIDMzEzU1dUpOg+njURezCR8YOwnJY5Op7O6JxUQEOCWayYkJCAhIcHyOT09HTqdDsXFxZg2bZrT5+HIi8iL2Y26vi8A7N5a767gJSctLQ1XrlxRdAxHXkRezCh8INmMvGxHYj+EpqYmREVFKTqGwYvIi5mFBLNNznrbzwO5c+cOPv/8c8vnlpYWXLx4EWPHjkVsbCwKCwvR2tqKffv2AQBKSkoQHx+PpKQk9PT0oLKyElVVVaiqqlJ0XQYvIi9mNPtAslmUalS4SLWxsREzZ860fM7PzwcA5OTkYM+ePWhra8O1a9cs3/f09KCgoACtra0ICgpCUlISDh8+jDlz5ii6LoMXkRczCclu2mhSOPKaMWMGhIMcYHv27LH6vHbtWqxdu1bRNeQoCrFFRUV47LHHEBISgvDwcMyfPx+XL192eIy7tgIQkfsZzT6yRQ0U9bK2thZ5eXloaGhAdXU1jEYjsrKycPfu3QGPvXz5Mtra2izlgQcecLnTROQeJrOPbFEDRdPGY8eOWX2uqKhAeHg4zp8/P+D6jMFuBSAi9zMKH2AYPG10xaB62dHRAQAYO3bsgG0HuxWAiNzPa0Ze9xJCID8/H0899RSSk5P7bde3FSAlJQXd3d146623kJmZiZqamn5Ha93d3Vb7qDo7O13tJhE5YJYJVuaRHrxWrlyJS5cu4ezZsw7bubIVoKioCK+++qqrXSMiJwkAtg8K1fHuIBenjS+//DIOHTqE06dPY8KECYqPH2grQGFhITo6OixFp9O50k0iGoBJ+MgWNVA08hJC4OWXX8b777+PmpoaaLValy460FaAgIAAj+6jIqJeJrMEmCX7OhVQFLzy8vLw9ttv449//CNCQkKg1+sBAKNHj0ZQUBAAeGwrABG5n1lmhf2IvOe1c+dOAL0rau9VUVGBJUuWAIDHtgIQkft5zcjL0RaAPp7aCkBE7mc2SzIjrxEYvIhoZDELCdIgs0oMFQYvIm9mliBsR1oceRHRcGeWuefFaSMRDX9C6i22dSrA4EXkxYS5t9jWqQGDF5EXE8L+npfgyIuIhjshc8Pe7gb+MMXgReTNeM+LiFRJ5mkjl0oQ0bDHG/ZEpEqSWYJkM9Ky/TxcMXgReTMB++yDKslGqI7cF0TkGX33vGyLAnV1dZg3bx6io6MhSRIOHjw44DG1tbVISUlBYGAgJk6ciNLSUsVdZ/Ai8mbmfooCd+/excMPP4w33njDqfYtLS2YM2cOMjIy0NTUhA0bNmDVqlWKc/xx2kjkxdxxzys7OxvZ2dlOty8tLUVsbCxKSkoAAImJiWhsbERxcTEWLFjg9Hk48iLyZqKfgt63dt1b7n2j12DU19cjKyvLqm727NlobGyEwWBw+jwMXkReTBKSZfRlKd8vUo2JicHo0aMtpaioyC3X1Ov1iIiIsKqLiIiA0WhEe3u70+fhtJHIm8nd4/r+s06nQ2hoqKXanS/FkSTb/ZRCtt4RBi8iLyaZe4ttHQCEhoZaBS93iYyMtLy8p8+NGzeg0Wgwbtw4p8/DaSORF+sLXrbFk9LT01FdXW1Vd+LECaSmpsLPz8/p8zB4EXmzvo3ZtkWBO3fu4OLFi7h48SKA3qUQFy9etLxFrLCwEIsXL7a0z83NxdWrV5Gfn4/m5maUl5ejrKwMBQUFiq7LaSORF3M0bXRWY2MjZs6cafmcn58PAMjJycGePXvsXoeo1Wpx5MgRrFmzBtu3b0d0dDS2bdumaJkEwOBF5N3kpokKg9eMGTMcvhbR9nWIADB9+nRcuHBB2YVsMHgReTMHTxuHOwYvIi8mid5iW6cGDF5EXswd97yGCoMXkTcTsJ8mqmTkpWipxKZNmyBJklWJjIx0eIw7Ul8QkWcMxTovd1E88kpKSsLJkyctn319fftt25f64qc//SkqKyvx5z//GStWrEBYWJjix6JE5H5eNW3UaDQDjrb6uCv1BRF5iDdlUr1y5Qqio6Oh1Wrxwgsv4Isvvui3raupL7q7u+3ScRCR+6l52qgoeD3xxBPYt28fjh8/jt27d0Ov12Pq1Km4efOmbHtXU18UFRVZpeKIiYlR0k0icpLXBK/s7GwsWLAAkydPxtNPP43Dhw8DAPbu3dvvMa6kvigsLERHR4el6HQ6Jd0kIiepOXgNaqlEcHAwJk+ejCtXrsh+72rqi4CAALfmDiKifqh4hf2gskp0d3ejubkZUVFRst+7K/UFEXlG3wp726IGioJXQUEBamtr0dLSgo8++gjPPvssOjs7kZOTA8BzqS+IyDO8Ztr41VdfYeHChWhvb0dYWBjS0tLQ0NCAuLg4APBY6gsi8gxJyKzzUsnIS1Hwevfddx1+76nUF0TkISpe58W9jURezKtW2BPRyMHgRUSqxOBFRKokmQUks7CrUwMGLyIvxpEXEakSgxcRqRKDFxGpk8wiVbWs8+Ibs4m8mRDyxQU7duyAVqtFYGAgUlJScObMmX7b1tTU2KWUlyQJn332mdPX48iLyIu5a9q4f/9+rF69Gjt27MCTTz6J3/3ud8jOzsann36K2NjYfo+7fPkyQkNDLZ/DwsKcviZHXkReTDLJF6W2bt2KZcuWYfny5UhMTERJSQliYmKwc+dOh8eFh4cjMjLSUhy9E8MWgxeRF+tb52VbANilYu/u7pY9R09PD86fP2+X8j0rKwsffvihw+tPmTIFUVFRyMzMxOnTpxX1ncGLyIs5SokTExNjlY69qKhI9hzt7e0wmUyyKd9tk5H2iYqKwq5du1BVVYUDBw4gISEBmZmZqKurc7rvvOdF5MUcrbDX6XRW96MGym4sl/K9v3TvCQkJSEhIsHxOT0+HTqdDcXExpk2b5lTfOfIi8mKORl6hoaFWpb/gNX78ePj6+sqmfLcdjTmSlpbWb0p5OQxeRF5MMgnZooS/vz9SUlLsUr5XV1dj6tSpTp+nqamp35TycjhtJPJi7sqkmp+fj0WLFiE1NRXp6enYtWsXrl27htzcXAC9KeJbW1uxb98+AEBJSQni4+ORlJSEnp4eVFZWoqqqClVVVU5fk8GLyJvJLUp1YZHq888/j5s3b2Lz5s1oa2tDcnIyjhw50m+K+J6eHhQUFKC1tRVBQUFISkrC4cOHMWfOHKevyeBF5MXcubdxxYoVWLFihex3tini165di7Vr17p2oe8xeBF5MckkINnME5Xe8xoqDF5EXozJCIlIlRi8iEiVOG0kInUyi95iW6cCDF5EXkwymyGZzXZ1asDgReTNBACVZlJl8CLyYpJZQJJsR17qiF6K9jbGx8fLpm7Ny8uTbe+OVK9E5EEmIV9UQNHI69y5czCZ/p5m8S9/+QtmzZqF5557zuFxg0n1SkSeI5nNMiOvEXjPyzbobNmyBZMmTcL06dMdHhceHo4xY8Yo7hwReZhZZn+QSoKXyylx+naCL126tN+EY32Upnrt7u62S0FLRO7njpQ4Q8Xl4HXw4EHcunULS5Ys6beNq6lei4qKrNLPxsTEuNpNInLEZJYvKuDy08aysjJkZ2cjOjq63zaupnotLCxEfn6+5XNnZycDGJEnCLP9NFGM4OB19epVnDx5EgcOHFB8bFpaGiorKx22CQgIGDBfNhG5gclsH6xUcs/LpeBVUVGB8PBwzJ07V/GxSlO9EpEHCZngNVJHXmazGRUVFcjJyYFGY324J1K9EpEHedPI6+TJk7h27RqWLl1q950nUr0SkQeZZfYHqWSFveLglZWVBdFPjmtPpHolIg8ymQBhsq4zm+TbDjPc20jkzcxm2I+8Rui0kYhGDmEyQdiMvARHXkQ07Jm96GkjEY0gJhMg2Yy0bO+BDVMubw8iIvUTZrNsccWOHTug1WoRGBiIlJQUnDlzxmH72tpapKSkIDAwEBMnTkRpaami6zF4EXkzN+1t3L9/P1avXo1XXnkFTU1NyMjIQHZ2ttXSqXu1tLRgzpw5yMjIQFNTEzZs2IBVq1YpWgPK4EXkxYTJ3HvT3qooD15bt27FsmXLsHz5ciQmJqKkpAQxMTHYuXOnbPvS0lLExsaipKQEiYmJWL58OZYuXYri4mKnr6mKe15968qMMLiUX9vc1eXytTtvD83NS6MwDOr4wfzNgzGY38vVv9mI3uP6W39I/TOYuiBgfY+r7/e0TUXV357jnp4enD9/HuvXr7eqz8rKwocffih73fr6emRlZVnVzZ49G2VlZTAYDPDz8xuw76oIXrdv3wYAnMUR106w/o8uX/v+9QO38YwvBnf4IP7mwRjc7zW4v/n27dsYPXr0oM7hLfz9/REZGYmz+g9kvx81apRdJpeNGzdi06ZNdm3b29thMpkQERFhVR8REQG9Xi97fr1eL9veaDSivb3dqf3Pqghe0dHR0Ol0CAkJsUt82JcuR6fTWaWaJnkj8fcSQuD27dsO0zORtcDAQLS0tKCnp0f2eyGE3b+1gTK92LaXO8dA7eXq+6OK4OXj44MJEyY4bBMaGjpi/jH+EEba78URl3KBgYEIDAwc9HnGjx8PX19fu1HWjRs37EZXfSIjI2XbazQajBs3zqnr8oY9EQ2Kv78/UlJSUF1dbVVfXV2NqVOnyh6Tnp5u1/7EiRNITU116n4XwOBFRG6Qn5+PN998E+Xl5WhubsaaNWtw7do15ObmAuhNl7V48WJL+9zcXFy9ehX5+flobm5GeXk5ysrKUFBQ4PQ1VTFtdCQgIAAbN25k5lUn8fciT3j++edx8+ZNbN68GW1tbUhOTsaRI0cQFxcHwD5dllarxZEjR7BmzRps374d0dHR2LZtGxYsWOD0NSXB58tEpEKcNn5vz549Vm/11mg0mDBhAl588UW0trZ65JqSJFk9ev7000+xadMmfPnll3ZtlyxZgvj4eI/0YzDy8vLg5+eHCxcu2H3X09ODyZMn40c/+hHu3r07BL2jEU2QEEKIiooKAUBUVFSI+vp6cerUKbFp0yYREBAgtFqtuHPnjtuvWV9fL3Q6neXze++9JwCI06dP27X9/PPPxYULF9zeh8G6e/eueOCBB0RycrLo7u62+q6wsFD4+PiIs2fPDlHvaCRj8PpeX/A6d+6cVf0vf/lLAUBUVlZ6vA+Ogtdw9uGHHwpfX1+xfv16S93//b//V/j6+oq1a9cOYc9oJOO0cQBpaWkAel/3BgBdXV0oLCyEVquFv78//uEf/gF5eXm4deuW1XGnTp3CjBkzMG7cOAQFBSE2NhYLFizAt99+a2lz77Rxz549eO655wAAM2fOtExf+1Jry00bne1LfHw8nnnmGRw7dgyPPvoogoKC8OCDD6K8vNyq3bfffouCggJLZoCxY8ciNTUV77zzjsPfKD09Hf/rf/0v/Md//Ac++ugjdHd3Y8mSJUhMTMTmzZsH+omJXDPU0XOwtm/fLuLj40VAQIB49NFHRV1dnUvn6W/k9frrrwsAYteuXcJsNovZs2cLjUYjfvnLX4oTJ06I4uJiERwcLKZMmSK6urqEEEK0tLSIwMBAMWvWLHHw4EFRU1Mjfv/734tFixaJv/3tb5ZzAxAbN24UQghx48YN8e///u8CgNi+fbuor68X9fX14saNG0IIIXJyckRcXJzlWGf7IoQQcXFxIjQ0VKB3Z6hVqa2ttbT7+c9/Lu677z6xdetWcfr0afHBBx+ILVu2iN/+9rcD/n7d3d3ioYceEg8++KD4xS9+Ifz8/IblNJdGDlUHr3fffVf4+fmJ3bt3i08//VT84he/EMHBweLq1auKz9UXvBoaGoTBYBC3b98WH3zwgQgLCxMhISFCr9eLY8eOCQDiN7/5jdWx+/fvtwQ4IYT4wx/+IACIixcvOrzmvcFLCMfTRtvg5WxfhOgNXhqNRjzwwAOira1NtLW1iZaWFnH//feLn//855Z2ycnJYv78+QP9VP26ePGi8Pf3FwDEa6+95vJ5iJyh6mmj0jQczkhLS4Ofnx9CQkLwzDPPIDIyEkePHkVERAROnToFoHcKd6/nnnsOwcHB+NOf/gQAeOSRR+Dv74+f/exn2Lt3L774YpCbrGU425c+kZGRuO+++xAZGYnIyEjEx8cjISHBMh0GgMcffxxHjx7F+vXrUVNTg++++05Rnx5++GH867/+K4KCglBYWOjaH0bkJNUGr740HLZpNRyl4XDGvn37cO7cOTQ1NeH69eu4dOkSnnzySQDAzZs3odFoEBYWZnWMJEmIjIzEzZs3AQCTJk3CyZMnER4ejry8PEyaNAmTJk3C66+/7nK/bDnblz5BQUG4cuUKoqOjodVq8cILL0AIYRWgtm3bhnXr1uHgwYOYOXMmxo4di/nz5+PKlStO9ysgIAA+Pj7w9fUd3B9INADVBi9X0nA4IzExEampqXjkkUfs0nKMGzcORqMR33zzjVW9EAJ6vR7jx4+31GVkZOC//uu/0NHRgYaGBqSnp2P16tV49913Xe6bq30BgDFjxmDfvn04fvw4du/eDb1ejwsXLsBg+HsOreDgYLz66qv47LPPoNfrsXPnTjQ0NGDevHlu6TORO6k2ePVRmoZjMDIzMwEAlZWVVvVVVVW4e/eu5ft7+fr64oknnsD27dsBQHYxZ5++LTvOTNeU9iU8PBwLFizA5MmT8fTTT+Pw4cMAgK+//lr2/BEREViyZAkWLlyIy5cvWz0lJRoOVLu30ZU0HIM1a9YszJ49G+vWrUNnZyeefPJJXLp0CRs3bsSUKVOwaNEiAL0pbk+dOoW5c+ciNjYWXV1dlmUJTz/9dL/nT05OBgDs2rULISEhCAwMhFarlU0R4mxf+hMcHIzg4GCroPTEE0/gmWeewUMPPYT7778fzc3NeOutt5Ceno777rtP8e9F5FFD+7xgcB5//HHx0ksvWdUlJiZaLZZ0Vn9LJWx99913Yt26dSIuLk74+fmJqKgo8dJLL1ktgaivrxc//vGPRVxcnAgICBDjxo0T06dPF4cOHbI6F2yeNgohRElJidBqtcLX19ey4l8I+6eNzvZFiN6njXPnzrWq6+rqEv7+/iI+Pt5St379epGamiruv/9+ERAQICZOnCjWrFkj2tvbHf4m98rJyRHBwcFOtydylao3Zu/fvx+LFi1CaWkp0tPTsWvXLuzevRt//etfLbvZqVdBQQHmzZuH2NhY3LhxA7/61a9QW1uLTz75hL8VqZJqp43AwGk46O+++uorLFy4EO3t7QgLC0NaWhoaGhr4W5FqqXrkRUTeS/VPG4nIOzF4EdGgFBUV4bHHHkNISAjCw8Mxf/58XL58ecDjamtrkZKSgsDAQEycOBGlpaWKrsvgRUSDUltbi7y8PDQ0NKC6uhpGoxFZWVkOE1C2tLRgzpw5yMjIQFNTEzZs2IBVq1ahqqrK6evynhcRudU333yD8PBw1NbWYtq0abJt1q1bh0OHDqG5udlSl5ubi48//hj19fVOXUcVTxvNZjOuX78u+9JZInHPS2d9fDiZcFZXV5fil8468+KWjo4OAMDYsWP7bVNfX2+3L3n27NkoKyuDwWBw6vVnqghe169ft3v1OJEtnU434MuJqVdXVxe0caOgv2GS/X7UqFG4c+eOVd3GjRut3rkgRwiB/Px8PPXUU5YdI3L0er3svmSj0Yj29na7fcVyVBG8QkJCAABPYQ40cO6FlMPBF1seG+ouuOTjfy0fuNEw0nnHjLhHv7T8d0ID6+npgf6GCZ83xiA0xHq02nnbjB+l6qDT6azequ7MqGvlypW4dOkSzp49O2BbuX3JcvX9UUXw6vtjNPCDRlJP8PJxw6vUh4Ltf8xqwVsKyo0KkTAqxPp3M6P3c2hoqFXwGsjLL7+MQ4cOoa6ubsARcGRkpOy+ZI1GI7uXV45L/5Xu2LHDkuc8JSUFZ86ccdh+sI9EicgzDMIkW5QQQmDlypU4cOAATp06Ba1WO+Ax6enpqK6utqo7ceIEUlNTnbrfBbgQvPbv34/Vq1fjlVdeQVNTEzIyMpCdnW31Ntx7ueORKBF5hhFmGGyKEWZF58jLy0NlZSXefvtthISEQK/XQ6/XW6V2KiwsxOLFiy2fc3NzcfXqVeTn56O5uRnl5eUoKytDQUGB09dVHLyUpl4uLS1FbGwsSkpKkJiYiOXLl2Pp0qUoLi5WemkicjODMMsWJXbu3ImOjg7MmDEDUVFRlrJ//35Lm7a2NqsBjlarxZEjR1BTU4NHHnkEr732GrZt24YFCxY4fV1F97z6Ui+vX7/eqt5R6mV3PBIlIs8wQMAAYVenhDNLRfte4Xev6dOnO0zOORBFwcuV1MuuPBLt7u5Gd3e35XNnZ6eSbhKRkwyit9jWqYFLN+yVpl5W+ki0qKgIo0ePthSu8SLyDKOQYLApRqGOp7aKgpcrqZddeSRaWFiIjo4OS9HpdEq6SURO6oGPbFEDRb309/dHSkqK3SPO6upqTJ06VfYYVx6JBgQEWNaYKF1rQkTOMwgf2aIGinuZn5+PN998E+Xl5WhubsaaNWtw7do15ObmAvDMI1Ei8gwTfGSLGiheYT9Q6uX+HomuWbMG27dvR3R0tOJHokTkGUaZkZZRJTfsXdoetGLFCqxYsUL2O088EiUizzAIXxiEr02dshX2Q0UVexuJyDN6hC/8bIJXz0geeRHRyGCELwzwtalTBwYvIi9mEBqZaaM61nkxeBF5sR7hCw2njUSkNhx5EZEqmQGYhG0yQnVg8CLyYgahgUZobOqGqDMKMXgReTGDzD0vg0rehsjgReTFGLyISJWMQgODzbRxRG8PIqKRwSB84cuRFxGpjUH4yAQvdTxvZPAi8mJGmY3ZRgYvIhruDGZf+JhtRl5mBi8iGubkkg+O2GSERDRyGGVu2Ktl2qiOEEtEHmEw+8gWJerq6jBv3jxER0dDkiQcPHjQYfuamhpIkmRXPvvsM0XX5ciLyIsZhS98Bjnyunv3Lh5++GG8+OKLitK7X7582erlOmFhYYquy+BF5MWMZh+7G/ZGs7I00NnZ2cjOzlZ87fDwcIwZM0bxcX04bSTyYo5efdbZ2WlV7n2LvTtMmTIFUVFRyMzMxOnTpxUfz+BF5MWMwhdGs035fhoZExNj9eb6oqIit1wzKioKu3btQlVVFQ4cOICEhARkZmairq5O0Xk4bSTyYibhA6PNq89M33/W6XRW96QCAgLccs2EhAQkJCRYPqenp0On06G4uBjTpk1z+jwceRF5MbtR1/cFgN1b690VvOSkpaXhypUrio7hyIvIi5khwQzbTKo/fBropqYmREVFKTqGwYvIixnNPpBs1nUZFa7zunPnDj7//HPL55aWFly8eBFjx45FbGwsCgsL0drain379gEASkpKEB8fj6SkJPT09KCyshJVVVWoqqpSdF0GLyIv5o7g1djYiJkzZ1o+5+fnAwBycnKwZ88etLW14dq1a5bve3p6UFBQgNbWVgQFBSEpKQmHDx/GnDlzFF2XwYvIi5mEBMnuhr2yaeOMGTMgHOQA27Nnj9XntWvXYu3atYquIUdRiC0qKsJjjz2GkJAQhIeHY/78+bh8+bLDY9y1FYCI3M9o9pEtaqCol7W1tcjLy0NDQwOqq6thNBqRlZWFu3fvDnjs5cuX0dbWZikPPPCAy50mIvcwmX1kixoomjYeO3bM6nNFRQXCw8Nx/vz5AddnDHYrABG5n1H4ADbTRtt1X8PVoHrZ0dEBABg7duyAbQe7FYCI3M9rRl73EkIgPz8fTz31FJKTk/tt17cVICUlBd3d3XjrrbeQmZmJmpqafkdr3d3dVvuoOjs7Xe0mETkghARhc4Pe9vNw5XLwWrlyJS5duoSzZ886bOfKVoCioiK8+uqrrnaNiJxkFhJMZsmuTg1cGh++/PLLOHToEE6fPo0JEyYoPn6grQCFhYXo6OiwFJ1O50o3iWgAJuEjW9RA0chLCIGXX34Z77//PmpqaqDVal266EBbAQICAjy6j4qIepnMEmAz8rIdiQ1XioJXXl4e3n77bfzxj39ESEgI9Ho9AGD06NEICgoCAI9tBSAi9zPLrLA3j8Qb9jt37gTQu6L2XhUVFViyZAkAeGwrABG5n9eMvBxtAejjqa0AROR+ZrMkM/IagcGLiEYWs5AgCXU+bWTwIvJmZgnCdqTFkRcRDXdC9BbbOjVg8CLyYsLsA2Fzz8v283DF4EXkxYS5t9jWqQGDF5EXE8L+nteI39tIROonZG7Y293AH6YYvIi8mZB6i22dCjB4EXkzmRX2XCpBRMMeb9gTkSpJZgmSzUjL9vNwxeBF5M3E98W2TgXUsRqNiDyj756XbVGgrq4O8+bNQ3R0NCRJwsGDBwc8pra2FikpKQgMDMTEiRNRWlqquOsMXkTezNxPUeDu3bt4+OGH8cYbbzjVvqWlBXPmzEFGRgaampqwYcMGrFq1SnGOP04bibyYO+55ZWdnIzs72+n2paWliI2NRUlJCQAgMTERjY2NKC4uxoIFC5w+D0deRN5M9FPQ+9aue8u9b/QajPr6emRlZVnVzZ49G42NjTAYDE6fh8GLyItJQrKMvizl+0WqMTExGD16tKUUFRW55Zp6vR4RERFWdRERETAajWhvb3f6PJw2EnkzuXtc33/W6XQIDQ21VLvzpTiSZLufUsjWO8LgReTFJHNvsa0DgNDQUKvg5S6RkZGWl/f0uXHjBjQaDcaNG+f0eThtJPJmDu55eUp6ejqqq6ut6k6cOIHU1FT4+fk5fR4GLyIvZne/S+bp40Du3LmDixcv4uLFiwB6l0JcvHjR8haxwsJCLF682NI+NzcXV69eRX5+Ppqbm1FeXo6ysjIUFBQoui6njURezNG00VmNjY2YOXOm5XN+fj4AICcnB3v27LF7HaJWq8WRI0ewZs0abN++HdHR0di2bZuiZRIAgxeRd5MJXkoXqc6YMcPhaxFtX4cIANOnT8eFCxeUXcgGgxeRN3PwtHG4Y/Ai8mKS6C22dWrA4EXkxdxxz2uoMHgReTMB+2miSkZeipZKbNq0CZIkWZXIyEiHx7gj9QUReUbfyMu2qIHikVdSUhJOnjxp+ezr69tv277UFz/96U9RWVmJP//5z1ixYgXCwsIUPxYlIvfzqnteGo1mwNFWH3elviAiD1Hx00bFK+yvXLmC6OhoaLVavPDCC/jiiy/6betq6ovu7m67dBxE5H5qnjYqCl5PPPEE9u3bh+PHj2P37t3Q6/WYOnUqbt68Kdve1dQXRUVFVqk4YmJilHSTiJzkNcErOzsbCxYswOTJk/H000/j8OHDAIC9e/f2e4wrqS8KCwvR0dFhKTqdTkk3ichJag5eg1oqERwcjMmTJ+PKlSuy37ua+iIgIMCtuYOIqB/edM/rXt3d3WhubkZUVJTs9+5KfUFEntH3tNG2qIGi4FVQUIDa2lq0tLTgo48+wrPPPovOzk7k5OQA8FzqCyLyDK+ZNn711VdYuHAh2tvbERYWhrS0NDQ0NCAuLg4APJb6gog8SCUjLVuKgte7777r8HtPpb4gIs/g3kYiUiUGLyJSJQYvIlIlBi8iUiXJLCCZhV2dGjB4EXkxjryISJUYvIhIlRi8iEid5N6QrY5bXnxjNpFXE8Jy095y897BOxgd2bFjB7RaLQIDA5GSkoIzZ87027ampsYupbwkSfjss8+cvh5HXkRezF3Txv3792P16tXYsWMHnnzySfzud79DdnY2Pv30U8TGxvZ73OXLlxEaGmr5HBYW5vQ1OfIi8mKSSb4otXXrVixbtgzLly9HYmIiSkpKEBMTg507dzo8Ljw8HJGRkZbi6J0Ythi8iLyY7ZTx3nVftqnYu7u7Zc/R09OD8+fP26V8z8rKwocffujw+lOmTEFUVBQyMzNx+vRpRX1n8CLyYo5S4sTExFilYy8qKpI9R3t7O0wmk2zKd9tkpH2ioqKwa9cuVFVV4cCBA0hISEBmZibq6uqc7jvveRF5MUcr7HU6ndX9qIGyG8ulfO8v3XtCQgISEhIsn9PT06HT6VBcXIxp06Y51XeOvIi8mKORV2hoqFXpL3iNHz8evr6+sinfbUdjjqSlpfWbUl4OgxeRF5NMQrYo4e/vj5SUFLuU79XV1Zg6darT52lqauo3pbwcThuJvJmbFqnm5+dj0aJFSE1NRXp6Onbt2oVr164hNzcXQG+K+NbWVuzbtw8AUFJSgvj4eCQlJaGnpweVlZWoqqpCVVWV09dk8CLyYpKQueflwiLV559/Hjdv3sTmzZvR1taG5ORkHDlypN8U8T09PSgoKEBrayuCgoKQlJSEw4cPY86cOUr67uJy2h9QZ2cnRo8ejRn4F2gk9bx16PP/J22ou+CS/+/50qHugiKdt824/x+/QEdHh9UNZupf37+pp2ZugkYTaPWd0diFs6c3DfvfkyMvIi8mmQQkm3edKb3nNVQYvIi8GJMREpEqMXgRkSpx2khE6mQWvcW2TgUYvIi8mCSE3dIIV5ZKDAUGLyJvZhaA7TSRIy8iGu4ks4Bkk31QLTfsFe1tjI+Pl03dmpeXJ9veHaleiciDTEK+qICikde5c+dgMv09zeJf/vIXzJo1C88995zD4waT6pWIPEcym2VGXup4fZCi4GUbdLZs2YJJkyZh+vTpDo8LDw/HmDFjFHeOiDzMLJPEXiXBy+WUOH07wZcuXdpvwrE+SlO9dnd326WgJSL3c0dKnKHicvA6ePAgbt26hSVLlvTbxtVUr0VFRVbpZ2NiYlztJhE5YjLLFxVw+WljWVkZsrOzER0d3W8bV1O9FhYWIj8/3/K5s7OTAYzIE4TZfpooRnDwunr1Kk6ePIkDBw4oPjYtLQ2VlZUO2wQEBAyYL5uI3EDIvGR2JC9SraioQHh4OObOnav4WKWpXonIg0wmQNi8qNHswosbh4Di4GU2m1FRUYGcnBxoNNaHeyLVKxF5kMlsP01UydNGxcHr5MmTuHbtGpYuXWr3nSdSvRKRB5kFANvgNUKnjVlZWegvc/SePXusPq9duxZr1651qWNE9APwpmkjEY0gZjPsR14jdNpIRCOHMJkgbEZegiMvIhr2zDI37EfyOi8iGiHk9jaqJHi5vD2IiNRPmEyyxRU7duyAVqtFYGAgUlJScObMGYfta2trkZKSgsDAQEycOBGlpcreF8rgReTN3LS3cf/+/Vi9ejVeeeUVNDU1ISMjA9nZ2VZLp+7V0tKCOXPmICMjA01NTdiwYQNWrVqlaA0ogxeRFxMms8zIS3nw2rp1K5YtW4bly5cjMTERJSUliImJwc6dO2Xbl5aWIjY2FiUlJUhMTMTy5cuxdOlSFBcXO31NVdzz6ltXZoQBUMf6OQCAuatrqLvgks7b6rjn0afzTm9/+1t/SP0zmLogYD1NNMIAAHapqPrbc9zT04Pz589j/fr1VvVZWVn48MMPZa9bX1+PrKwsq7rZs2ejrKwMBoMBfn5+A/ZdFcHr9u3bAICzODLEPVFo/R+HugcuuX/9wG2Go9u3b2P06NFD3Q1V8Pf3R2RkJM7qP5D9ftSoUXaZXDZu3IhNmzbZtW1vb4fJZEJERIRVfUREBPR6vez59Xq9bHuj0Yj29nan9j+rInhFR0dDp9MhJCTELvFhX7ocnU5nlWqa5I3E30sIgdu3bztMz0TWAgMD0dLSgp6eHtnvhRB2/9YGyvRi217uHAO1l6vvjyqCl4+PDyZMmOCwTWho6Ij5x/hDGGm/F0dcygUGBiIwMHDQ5xk/fjx8fX3tRlk3btywG131iYyMlG2v0Wgwbtw4p67LG/ZENCj+/v5ISUlBdXW1VX11dTWmTp0qe0x6erpd+xMnTiA1NdWp+10AgxcRuUF+fj7efPNNlJeXo7m5GWvWrMG1a9eQm5sLoDdd1uLFiy3tc3NzcfXqVeTn56O5uRnl5eUoKytDQUGB09dUxbTRkYCAAGzcuJGZV53E34s84fnnn8fNmzexefNmtLW1ITk5GUeOHEFcXBwA+3RZWq0WR44cwZo1a7B9+3ZER0dj27ZtWLBggdPXlASfLxORCnHaSESqxOBFRKrE4EVEqsTgRUSqpPrgpTQNh7fatGkTJEmyKpGRkUPdLSKXqTp4KU3D4e2SkpLQ1tZmKZ988slQd4nIZaoOXkrTcHg7jUaDyMhISwkLCxvqLhG5TLXBqy8Nh21aDUdpOLzdlStXEB0dDa1WixdeeAFffPHFUHeJyGWqDV6upOHwZk888QT27duH48ePY/fu3dDr9Zg6dSpu3rw51F0jconqtwcpTcPhrbKzsy3/e/LkyUhPT8ekSZOwd+9e5OfnD2HPiFyj2pGXK2k46O+Cg4MxefJkXLlyZai7QuQS1QYvV9Jw0N91d3ejubnZqYyVRMORqqeN+fn5WLRoEVJTU5Geno5du3ZZpeGgvysoKMC8efMQGxuLGzdu4Fe/+hU6OzuRk5Mz1F0jcomqg9dAaTjo77766issXLgQ7e3tCAsLQ1paGhoaGvhbkWoxJQ4RqZJq73kRkXdj8CIiVWLwIiJVYvAiIlVi8CIiVWLwIiJVYvAiIlVi8CIiVWLwIiJVYvAiIlVi8CIiVWLwIiJV+v8BS00/KAq7ubEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 2000x600 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x1500 with 18 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "L = 3 # Size of room\n",
    "\n",
    "all_positions = np.array([[i,j] for i in range(L) for j in range(L)])\n",
    "if sampling_choice == 3:\n",
    "    object_positions = np.array([[0,1], [0,1]])\n",
    "    num_samples = 2\n",
    "else:\n",
    "    num_samples = 9\n",
    "    object_positions = all_positions.T\n",
    "\n",
    "labels = np.zeros([2*L**2, L, L, num_samples]) # This is the output matrix, x and y current position, and displacement to reward, in each position, for each room\n",
    "\n",
    "for room in range(num_samples):\n",
    "    object_position = object_positions[:,room]\n",
    "    for l_x in range(L):\n",
    "        for l_y in range(L):\n",
    "            # First ensure one set of labels encodes position\n",
    "            one_hot_ind = np.where(np.logical_and(all_positions[:,0] == l_x, all_positions[:,1] == l_y))[0]\n",
    "            labels[one_hot_ind, l_x, l_y, room] = 1\n",
    "\n",
    "            # Now go through and calculate shortest action to object\n",
    "            distance = object_position - np.array([l_x, l_y])\n",
    "            distance[distance > L] = distance[distance > L] - L\n",
    "            distance[distance < 0] = distance[distance < 0] + L\n",
    "            one_hot_ind = np.where(np.logical_and(all_positions[:,0] == distance[0], all_positions[:,1] == distance[1]))[0]\n",
    "            labels[L**2+one_hot_ind, l_x, l_y, room] = 1\n",
    "\n",
    "\n",
    "# Finally we create the network's one-hot inputs for these rooms.\n",
    "inputs = np.zeros([L**2, num_samples])\n",
    "for d in range(num_samples):\n",
    "    pos = object_positions[:,d]\n",
    "    one_hot_code_ind = np.where(np.logical_and(all_positions[:,0] == pos[0,None], all_positions[:,1] == pos[1,None]))[0]\n",
    "    inputs[one_hot_code_ind, d] = 1\n",
    "\n",
    "# Create random data to feed the network\n",
    "T = L**2 # Length of each trajectory\n",
    "\n",
    "# Set up step matrix\n",
    "steps = np.zeros([4, 2])\n",
    "steps[0,0] = -1\n",
    "steps[1,0] = 1\n",
    "steps[2,1] = -1\n",
    "steps[3,1] = 1\n",
    "\n",
    "steoreotyped_actions = np.tile([1,1,L,1,1,L,1,1,1], [num_samples,1]).astype(int).T\n",
    "\n",
    "# Given actions, compute the positions\n",
    "positions = np.zeros([2, T, num_samples])\n",
    "for t in range(1, T):\n",
    "    positions[:,t,:] = np.mod(positions[:,t-1,:] + steps[steoreotyped_actions[t-1,:]].T, L) # This is for periodic\n",
    "positions = positions.astype(int)\n",
    "\n",
    "network_signals = np.zeros([2*L**2,T,num_samples])\n",
    "for d in range(num_samples):\n",
    "    for t in range(T):\n",
    "        for input_dim in range(2*L**2):\n",
    "            network_signals[input_dim,t,d] = labels[input_dim, positions[0,t,d], positions[1,t,d],d]\n",
    "        \n",
    "plt.figure(figsize = (20, 6))\n",
    "plt.subplot(3,1,1)\n",
    "plt.imshow(steoreotyped_actions.T)\n",
    "plt.title('Actions')\n",
    "plt.xticks()\n",
    "plt.yticks()\n",
    "plt.colorbar()\n",
    "\n",
    "plt.subplot(3,1,2)\n",
    "plt.imshow(positions[0,:,:].T)\n",
    "plt.title('Positions X')\n",
    "plt.xticks()\n",
    "plt.yticks()\n",
    "plt.colorbar()\n",
    "\n",
    "plt.subplot(3,1,3)\n",
    "plt.imshow(positions[1,:,:].T)\n",
    "plt.title('Positions Y')\n",
    "plt.xticks()\n",
    "plt.yticks()\n",
    "plt.colorbar()\n",
    "\n",
    "plt.figure(figsize = (15,15))\n",
    "plot_rows = 10\n",
    "plot_cols = int(num_samples/plot_rows)+1\n",
    "for room in range(num_samples):\n",
    "    plt.subplot(plot_rows, plot_cols, room+1)\n",
    "    plt.imshow(network_signals[:,:,room])\n",
    "    plt.xticks([])\n",
    "    plt.yticks([])\n",
    "    plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 659,
   "id": "2047532d-317a-43a0-9226-21ace3717dcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_rep(params, inputs, actions):\n",
    "    # Inputs dim x traj length x rooms, actions traj length x rooms\n",
    "    g = jnp.zeros([N, T, num_samples])\n",
    "    g = g.at[:,0,:].set(params['I'][:,:-1]@inputs[:,:] + params['I'][:,-1][:,None])\n",
    "\n",
    "    # For rest we just recurrently go around.\n",
    "    for t in range(1,T):\n",
    "        g = g.at[:,t,:].set(jnp.einsum('ijk,ki->ji', params['W'][actions[t-1],:,:-1],g[:,t-1,:]) + params['W'][actions[t-1],:,-1].T)\n",
    "    return g"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 660,
   "id": "89624f89-19ec-4265-bae5-0790152fd1f0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x2af178ec0>"
      ]
     },
     "execution_count": 660,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = generate_rep(params_best, inputs, steoreotyped_actions)\n",
    "plt.imshow(g[55,:,:])\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 661,
   "id": "7ee608e8-bae4-479c-ab54-0303897f6cd8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(18, 9, 9)"
      ]
     },
     "execution_count": 661,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "network_signals.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 662,
   "id": "fa6a721e-7aee-40a0-9357-1a416329b3a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "81"
      ]
     },
     "execution_count": 662,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "s_full = np.reshape(network_signals, [network_signals.shape[0], (L**2)*num_samples]).astype(int).T\n",
    "z = np.reshape(g, [N, (L**2)*num_samples]).T\n",
    "s_full.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 663,
   "id": "9a9875fa-9c70-45cf-bc8e-cc8ce48f0df4",
   "metadata": {},
   "outputs": [],
   "source": [
    "one_hot_to_num_array = np.array([i for i in range(L**2)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 664,
   "id": "b5415529-4e85-4dff-a3cd-8e9d671ce0a5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0, 0],\n",
       "       [0, 1],\n",
       "       [0, 2],\n",
       "       [0, 3],\n",
       "       [0, 4],\n",
       "       [0, 5],\n",
       "       [0, 6],\n",
       "       [0, 7],\n",
       "       [0, 8],\n",
       "       [3, 6],\n",
       "       [3, 7],\n",
       "       [3, 8],\n",
       "       [3, 0],\n",
       "       [3, 1],\n",
       "       [3, 2],\n",
       "       [3, 3],\n",
       "       [3, 4],\n",
       "       [3, 5],\n",
       "       [6, 3],\n",
       "       [6, 4],\n",
       "       [6, 5],\n",
       "       [6, 6],\n",
       "       [6, 7],\n",
       "       [6, 8],\n",
       "       [6, 0],\n",
       "       [6, 1],\n",
       "       [6, 2],\n",
       "       [7, 5],\n",
       "       [7, 3],\n",
       "       [7, 4],\n",
       "       [7, 8],\n",
       "       [7, 6],\n",
       "       [7, 7],\n",
       "       [7, 2],\n",
       "       [7, 0],\n",
       "       [7, 1],\n",
       "       [1, 2],\n",
       "       [1, 0],\n",
       "       [1, 1],\n",
       "       [1, 5],\n",
       "       [1, 3],\n",
       "       [1, 4],\n",
       "       [1, 8],\n",
       "       [1, 6],\n",
       "       [1, 7],\n",
       "       [4, 8],\n",
       "       [4, 6],\n",
       "       [4, 7],\n",
       "       [4, 2],\n",
       "       [4, 0],\n",
       "       [4, 1],\n",
       "       [4, 5],\n",
       "       [4, 3],\n",
       "       [4, 4],\n",
       "       [5, 7],\n",
       "       [5, 8],\n",
       "       [5, 6],\n",
       "       [5, 1],\n",
       "       [5, 2],\n",
       "       [5, 0],\n",
       "       [5, 4],\n",
       "       [5, 5],\n",
       "       [5, 3],\n",
       "       [8, 4],\n",
       "       [8, 5],\n",
       "       [8, 3],\n",
       "       [8, 7],\n",
       "       [8, 8],\n",
       "       [8, 6],\n",
       "       [8, 1],\n",
       "       [8, 2],\n",
       "       [8, 0],\n",
       "       [2, 1],\n",
       "       [2, 2],\n",
       "       [2, 0],\n",
       "       [2, 4],\n",
       "       [2, 5],\n",
       "       [2, 3],\n",
       "       [2, 7],\n",
       "       [2, 8],\n",
       "       [2, 6]])"
      ]
     },
     "execution_count": 664,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Let's try turning into 1D code?\n",
    "s = np.zeros([s_full.shape[0], 2])\n",
    "for data in range(s.shape[0]):\n",
    "    s[data,0] = np.dot(s_full[data,0:L**2], one_hot_to_num_array)\n",
    "    s[data,1] = np.dot(s_full[data,L**2:], one_hot_to_num_array)\n",
    "\n",
    "s = s.astype(int)\n",
    "s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 665,
   "id": "cd2aa052-ea15-49a2-950b-52ae69af67f0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "linear_metrics = compute_linear_metrics(s, z, 'continuous', 'continuous')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 666,
   "id": "cdcd737c-bbe2-41f0-947e-122462650c81",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_mi_heatmap(results, k):\n",
    "    mi = results[k]\n",
    "    mi = mi[:, results['z_active']]\n",
    "    fig, ax = plt.subplots(figsize=(0.5 * (mi.shape[1] + 1), 0.5 * (mi.shape[0] + 1)))\n",
    "    sns.heatmap(\n",
    "        mi, ax=ax, annot=False, fmt='.2f', square=True, vmin=0, vmax=1, cbar=True,\n",
    "        annot_kws={'fontsize': 8},\n",
    "        xticklabels=[rf'$\\mathbf{{z}}_{{{i}}}$' for i in results['z_active'].nonzero()[0]],\n",
    "        yticklabels=[rf'$\\mathbf{{s}}_{{{i}}}$' for i in range(mi.shape[0])],\n",
    "        rasterized=True\n",
    "    )\n",
    "    ax.set_title(k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 667,
   "id": "1ae695f2-3c70-4e0d-8604-614856aed4e9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x2aecc0e00>"
      ]
     },
     "execution_count": 667,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(linear_metrics['linear_ncmi'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 668,
   "id": "dde37e1f-4f4e-4a3b-b498-d8b326a55728",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 950x150 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_mi_heatmap(linear_metrics, 'linear_nmi')\n",
    "plt.savefig(f'./Figs/Entorhinal_NMI_{sampling_choice}.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 669,
   "id": "d6c1fcea-cde4-497d-8ce8-69d93df68740",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OXMGb775plnHUKvVBr8jLkQ7ZDJuC01ERETU1bj6DLPFBfO0adMwdepUfP3117h8+TKEEAgJCcGYMWPg5uZm1jGys7OxYsUKvT4vz77w7hFgaTpERERE5GTChWaTpZg9pXvt2jUolUo0NzfDzc0Nly9fRmlpKa5du4bExESzi2Xg1sbT165d02tenv539QKIiIiIyLlEq5BsrsLsGea5c+ciPz8fJ06cQHV1NWbNmqX7W319PZ599lmzg0r9rjiXYxARERF1TULj7Azsy+wqtby8HL1790ZMTAzy8/MBABMmTIAQAtu2bbNbgkRERETUuQmNdHMVZhfMKpUKoaGhAIDTp08jOjoaxcXFGD58uMHPFBIRERHRb0e7Rrq5CrMLZrlcjoaGBrS0tODChQsIDw8HAHh4eKBbNy6nICIiIvqtam+TSTZXYXalq1AooFQq0bdvX9y8eRPx8fEAbm0pN2DAALslSERERESdW7tGJtlchdkF89KlS+Hu7o4bN25g8ODByMjIwFdffYWrV6/qimciIiIi+u1p18okm6swe5eMtLQ0VFVVQalUIiIiAnK5HOHh4aisrESfPn3smSMRERERdWKuVBxLseiHS/z9/eHv/3/7JXt5ecHLy8vmSRERERFR19Guce372Sz+pT8iIiIiol/TsmAmIiIiIjJOyyUZRERERETGtWtde4bZtV8dEREREdmdrXbJ2LhxI8LCwuDp6YnY2FgcOXLE6NiSkhLIZDKDdu7cOb1x+fn5CA8P121YsW/fPovzYsFMRERERFbRaLtJNkvk5eVh0aJFePHFF1FRUYHk5GRMnTr1jr8off78edTU1OjasGHDdH8rKytDeno6MjIycOrUKWRkZGDWrFn46quvLMqNBTMRERERWUXb3k2yWWLNmjWYPXs25syZA4VCgZycHAwYMACbNm0y+byAgAAEBQXpmpubm+5vOTk5mDx5MrKysjBixAhkZWVh4sSJyMnJsSg3FsxEREREZBVtu0yyqdVqNDY26jW1Wm3w/NbWVpw8eRKpqal6/ampqTh27JjJ2NHR0ejXrx8mTpyIL774Qu9vZWVlBsecMmXKHY95u05z05+q6aqzU0Bm8Dhnp4A1l0udGj+ol69T4wPApet1zk4B/+96ibNTcLrgXn7OTgGrLx92dgro3s3tzoPs6HDtGafGB4DFneDa+KaT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",
      "text/plain": [
       "<Figure size 950x150 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_mi_heatmap(linear_metrics, 'linear_ncmi')\n",
    "plt.savefig(f'./Figs/Entorhinal_NCMI_{sampling_choice}.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 670,
   "id": "6b6da3bd-a7ab-4f43-b3c5-862392eecf31",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('./data/PI_Learnt_Reps/source_example_kyle.npy', s)\n",
    "np.save('./data/PI_Learnt_Reps/sink_example_kyle.npy', z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 671,
   "id": "3e1cf28f-4598-4234-b7cc-7e160eea6f99",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x2b1247fe0>"
      ]
     },
     "execution_count": 671,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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B+9j8vBeJkcy38dUVcR/KSsryxVJNFmcuzABAIBHkIwBALCZ65NxIBDQgw8+qEAgYHcorsb7mBy8j8nDe5kcvI/ukPYLuAAAQCzXV8YAALgdyRgAAJuRjAEAsBnJGAAAm7k+GdfU1KioqEhZWVkqKSnRzp077Q7JVYLBoC677DJlZ2crLy9PN9xwgz788EO7w3K9YDAon8+nyspKu0NxnU8//VQ/+tGPNGrUKA0bNkyXXHKJGhsb7Q7LVTo7O/XTn/5URUVFGjp0qC644AKtXr1ahsHzzZ3K1cm4vr5elZWVWrVqlZqamjRr1ixVVFSoubnZ7tBcY/v27Vq2bJn27NmjhoYGdXZ2qry8XCdPnrQ7NNfau3ev6urqNHXqVLtDcZ0//elPmjFjhs455xy98cYbOnjwoB5//HGde+65dofmKo899ph+9atfaf369frggw/085//XP/4j/+oJ554wu7Q0AdX39p0+eWX69JLL1VtbW33scmTJ+uGG25QMBi0MTL3+u///m/l5eVp+/bt+u53v2t3OK5z4sQJXXrppaqpqdEjjzyiSy65ROvWrbM7LNe477779M4779Dhsui6665Tfn6+nn766e5jP/jBDzRs2DD98z//s42RoS+urYw7OjrU2Nio8vLymOPl5eXavXu3TVG5XygUkiSNHDnS5kjcadmyZZo9e7auueYau0Nxpc2bN6u0tFQ33nij8vLyNG3aND311FN2h+U6M2fO1O9+9zsdOnRIkvT73/9eu3bt0ve//32bI0Nf0r5RRLIcO3ZM0WhU+fn5Mcfz8/N19OhRm6JyN9M0VVVVpZkzZ6q4uNjucFznpZde0nvvvae9e/faHYprHT58WLW1taqqqtL999+vd999V8uXL1cgENCCBQvsDs817r33XoVCIU2aNEl+v1/RaFRr1qzRzTffbHdo6INrk3GXs7dhNE0zKVszetFdd92lP/zhD9q1a5fdobhOS0uLVqxYod/+9ree2mkm2QzDUGlpqR599FFJ0rRp03TgwAHV1taSjONQX1+vF154QRs3btSUKVO0f/9+VVZWaty4cVq4cKHd4aEXrk3Go0ePlt/v71EFt7W19aiW0b+7775bmzdv1o4dO1KyxeVg19jYqLa2NpWUlHQfi0aj2rFjh9avX69IJCK/329jhO4wduxYXXTRRTHHJk+erH/5l3+xKSJ3uueee3TffffppptukiRdfPHF+vjjjxUMBknGDuXaNePMzEyVlJSooaEh5nhDQ4PKyspsisp9TNPUXXfdpVdeeUVvv/22ioqK7A7Jla6++mq9//772r9/f/coLS3Vrbfeqv3795OIB2jGjBk9bq07dOiQCgsLbYrInU6dOqWMjNg/736/n1ubHMy1lbEkVVVVaf78+SotLdX06dNVV1en5uZmLVmyxO7QXGPZsmXauHGjXn/9dWVnZ3d3GnJzczV06FCbo3OP7OzsHuvsw4cP16hRo1h/j8PKlStVVlamRx99VHPnztW7776ruro61dXV2R2aq8yZM0dr1qzRhAkTNGXKFDU1NWnt2rW644477A4NfTFd7pe//KVZWFhoZmZmmpdeeqm5fft2u0NyFUm9jg0bNtgdmut973vfM1esWGF3GK7zr//6r2ZxcbEZCATMSZMmmXV1dXaH5DrhcNhcsWKFOWHCBDMrK8u84IILzFWrVpmRSMTu0NAHV99nDADAYODaNWMAAAYLkjEAADYjGQMAYDOSMQAANiMZAwBgM5IxAAA2IxkDAGAzkjEAADYjGQMAYDOSMQAANiMZAwBgM5IxAAA2+39qCFhClLqY8wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = generate_rep(params_best, inputs, steoreotyped_actions)\n",
    "plt.imshow(g[21,:,:])\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 672,
   "id": "2508bea9-10e0-462e-81e4-9fef252c59a2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0, 0, 0, 1, 1, 1, 2, 2, 2],\n",
       "       [0, 1, 2, 0, 1, 2, 0, 1, 2]])"
      ]
     },
     "execution_count": 672,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "object_positions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 673,
   "id": "34a41cca-1923-4570-a8d8-d547a397a8cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 0, 0]],\n",
       "\n",
       "       [[0, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [1, 1, 1, 1, 1, 1, 1, 1, 1],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2],\n",
       "        [2, 2, 2, 2, 2, 2, 2, 2, 2]]])"
      ]
     },
     "execution_count": 673,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "positions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 678,
   "id": "9a30fde9-0bdd-43c7-9928-1d00012824b5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x2b0872600>"
      ]
     },
     "execution_count": 678,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "room1 = 4\n",
    "room2 = 0\n",
    "neuron1 = 31\n",
    "neuron2 = 35\n",
    "\n",
    "position_ordering = [0, 1, 2, 4, 5, 3, 8, 6, 7] \n",
    "\n",
    "plt.figure()\n",
    "plt.subplot(2,2,1)\n",
    "plt.imshow(np.reshape(g[neuron1,position_ordering,room1], [L,L]), origin='lower')\n",
    "plt.subplot(2,2,2)\n",
    "plt.imshow(np.reshape(g[neuron1,position_ordering,room2], [L,L]), origin='lower')\n",
    "\n",
    "plt.subplot(2,2,3)\n",
    "plt.imshow(np.reshape(g[neuron2,position_ordering,room1], [L,L]), origin='lower')\n",
    "plt.subplot(2,2,4)\n",
    "plt.imshow(np.reshape(g[neuron2,position_ordering,room2], [L,L]), origin='lower')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 521,
   "id": "4f4b8b2f-f898-44f7-8ad4-07d101a803a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6170402631461114"
      ]
     },
     "execution_count": 521,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "linear_metrics['linear_cinfom']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 656,
   "id": "0182f70c-0985-4be7-a3af-f18d995282f1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.6, 1.0)"
      ]
     },
     "execution_count": 656,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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52P06NFtnh89enSsWbOm05lzzjknvvvd78aTTz4ZxWIxnnjiibjpppuiqakp1q9fHxERa9as6dI9IyKuueaaqKmpafkaP358Vz4KAAAAAAD0G5edOTlGDi1PPH/9r56LtXX1KSYCgNLS5TPOIyIymUybx8ViscNzu3z2s5+N8847L0466aQoLy+Piy66KN7//vdHREQut3vbmK7cMyLiyiuvjNra2pavlStXJvkoAAAAAADQ52qGlsflZ09JPL+1MR9fvntZiokAoLR0qTgfNWpU5HK5DivB165d22HF+C5DhgyJm266KbZt2xYvv/xyrFixIiZOnBgjRoyIUaNGRUTEmDFjunTPiIjKysqorq5u8wUAAAAAAAPV+04YH1NGj0g8/5Pfvxp/eHVTeoEAoIR0qTivqKiI4447Lu699942z997770xa9asN50tLy+Pgw46KHK5XNx6661x4YUXRja74+1PPvnkDve855573vKeAAAAAAAwWJTlsjFv9vTE88VixPzbF0exWEwxFQCUhrKuDlx++eVx8cUXx/HHHx8nn3xyfOc734kVK1bEpZdeGhE7tlBftWpV3HzzzRERsXz58njsscdi5syZsXHjxvjqV78af/zjH+P73/9+yz0//vGPx2mnnRbXXnttXHTRRfHzn/887rvvvnj44YdT+pgAAAAAAND/nXLYqDh7+ui4Z/HrieafeGVj3P6H1fEnR49LORkADG5dLs7nzJkTGzZsiPnz58fq1avjiCOOiAULFsTBBx8cERGrV6+OFStWtFyfz+fjuuuui2XLlkV5eXmcfvrp8cgjj8TEiRNbrpk1a1bceuut8ZnPfCY++9nPxqGHHhq33XZbzJw5s/ufEAAAAAAABpC5F0yL3yxbF435QqL5axYsibOmjY4hFbmUkwHA4JUpDpI9W+rq6qKmpiZqa2uddw4AAAAAwID2xbuWxrceeCHx/GXvOjwue9fkFBMBwMDTlQ65S2ecAwAAAAAAPe+jZxwWo4ZXJp7/1gMvxGubtqeYCAAGN8U5AAAAAAD0M8Mry+Jfzp2SeL6+qRBfvGtpiokAYHBTnAMAAAAAQD/058ceFEceWJN4/hfPvBZPvvJGiokAYPBSnAMAAAAAQD+UzWZi3uzp3brHVbcvjkKhmFIiABi8FOcAAAAAANBPnTBx35h99LjE8394tTZ++vtXU0wEAIOT4hwAAAAAAPqxT583NarKk/84/0t3L4stDc0pJgKAwUdxDgAAAAAA/diB+wyJj5x2aOL5dZsb4oZfP59iIgAYfBTnAAAAAADQz136jkNibE1V4vnvPvRSrNiwLcVEADC4KM4BAAAAAKCfG1pRFp8+b2ri+cZ8Ib6wYEmKiQBgcFGcAwAAAADAAPAnR4+LYyfsk3j+l4vWxCMvrE8vEAAMIopzAAAAAAAYADKZTHxu9oxu3WP+7YsjXyimlAgABg/FOQAAAAAADBBHj98n3nPsQYnnl67ZHLc+viLFRAAwOCjOAQAAAABgAPnUuVNiWEUu8fx19yyP2u1NKSYCgIFPcQ4AAAAAAAPIAdVV8Y+nH5Z4/o2tjfH1+59LMREADHyKcwAAAAAAGGA+9PZJMX7fIYnnv//Iy/HCui0pJgKAgU1xDgAAAAAAA0xVeS7mnj8t8XxzoRj/dsfiFBMBwMCmOAcAAAAAgAHonBlj4qRD9k08/+tl6+I3y9ammAgABi7FOQAAAAAADECZTCbmXTgjspnk97j6jsXRlC+kFwoABijFOQAAAAAADFDTx1XHX544IfH8C+u2xn8vfCXFRAAwMCnOAQAAAABgALvirMkxoqos8fzX7lseb2xtTDERAAw8inMAAAAAABjA9hteGR8/8/DE83X1zfHVe5elmAgABh7FOQAAAAAADHCXnDwxDhk1LPH8Dx9dEUvX1KWYCAAGFsU5AAAAAAAMcBVl2fjMhdMSzxeKEfNvXxzFYjHFVAAwcCjOAQAAAABgEDh9ygFx2uT9E88/8sKGuGfx6ykmAoCBQ3EOAAAAAACDQCaTiXkXTotcNpP4Hl9YsCQamvMppgKAgUFxDgAAAAAAg8RhB4yIi086OPH8Kxu2xX/99uX0AgHAAKE4BwAAAACAQeQT75ocI4eWJ57/xv3PxdrN9SkmAoD+T3EOAAAAAACDSM3Q8rj8rMmJ57c25uMrdy9LMREA9H+KcwAAAAAAGGTed+KEmDJ6ROL5Hz/5ajz7am2KiQCgf1OcAwAAAADAIFOWy8a82dMTzxeLEVfdviiKxWKKqQCg/1KcAwAAAADAIHTKYaPirOmjE88/8crGuOMPq1NMBAD9l+IcAAAAAAAGqbnnT4vyXCbx/BfvWhrbG/MpJgKA/klxDgAAAAAAg9TEUcPig2+flHh+1abt8Z0HX0wxEQD0T4pzAAAAAAAYxD56+mExanhl4vkbH3g+Xtu0PcVEAND/KM4BAAAAAGAQG1FVHp88Z3Li+fqmQlz7y6UpJgKA/kdxDgAAAAAAg9yfHzc+jjiwOvH8z59+LZ58ZWOKiQCgf1GcAwAAAADAIJfLZmLehTO6dY/5ty+KQqGYUiIA6F8U5wAAAAAAUAJOnLRvXHjU2MTzz7xaG//71KoUEwFA/6E4BwAAAACAEnHl+dOisix5NfClXy6NrQ3NKSYCgP5BcQ4AAAAAACXiwH2GxN+fdkji+bWbG+KG3zyfYiIA6B8U5wAAAAAAUEIufeehMaa6KvH8fzz0Uqx8Y1uKiQCg7ynOAQAAAACghAytKItPnzc18XxjcyG+sGBJiokAoO8pzgEAAAAAoMRc9LZxccyEfRLP3/XHNbHwhQ3pBQKAPqY4BwAAAACAEpPJZOJzs2d06x7z71gc+UIxpUQA0LcU5wAAAAAAUILeNn6f+LNjD0w8v2R1Xdz2+MoUEwFA31GcAwAAAABAifrUuVNjaEUu8fxX7lkWtdubUkwEAH1DcQ4AAAAAACVqdHVV/NPphyWef2NrY3zj/udSTAQAfUNxDgAAAAAAJexDb58UB40cknj+e4+8HC+s25JiIgDofYpzAAAAAAAoYVXluZh7/rTE882FYnz+ziUpJgKA3qc4BwAAAACAEnfuEWNi5qR9E8//aunaeGD5uhQTAUDvUpwDAAAAAECJy2QyMW/29Mhkkt/j6jsWR1O+kF4oAOhFinMAAAAAACBmjKuJvzxhQuL559duif/53SspJgKA3qM4BwAAAAAAIiLiirMnx4jKssTzX7vvudi4tTHFRADQOxTnAAAAAABARESMGl4ZHzvz8MTztdub4v/etzzFRADQOxTnAAAAAABAi7+dNTEmjRqWeP5/fvdKLFuzOcVEANDzFOcAAAAAAECLirJsfOaCaYnnC8WIq+9YHMViMcVUANCzFOcAAAAAAEAbZ0w9IE49fFTi+YefXx/3LVmbYiIA6FmKcwAAAAAAoI1MJhPzLpweuWwm8T3+7c7F0dCcTzEVAPQcxTkAAAAAANDB4aNHxMUnHZx4/pUN2+J7v305vUAA0IMU5wAAAAAAQKcue9fhsc/Q8sTz3/jV87Fuc0OKiQCgZyjOAQAAAACATu0ztCIuP2ty4vktDc3xlbuXpZgIAHqG4hwAAAAAANijvzpxQkwePTzx/I+eXBl/XFWbYiIASJ/iHAAAAAAA2KOyXDbmXTgj8XyxGHHV7YuiWCymmAoA0qU4BwAAAAAA3tTbDx8V75o2OvH84y9vjDufXZ1iIgBIl+IcAAAAAAB4S3MvmBbluUzi+WsWLI36pnyKiQAgPYpzAAAAAADgLU0aNSw+eMqkxPOrNm2P7zz4YoqJACA9inMAAAAAAGCvfPSMw2LU8IrE8zf+5oVYU1ufYiIASIfiHAAAAAAA2Csjqsrjn8+eknh+e1M+rv3l0hQTAUA6FOcAAAAAAMBe+4vjx8eMcdWJ53/21Kr4/YqNKSYCgO5TnAMAAAAAAHstl83E52bP6NY9rrp9cRQKxZQSAUD3Kc4BAAAAAIAuOXHSvnHBkWMTzz+zclP87KlVKSYCgO5RnAMAAAAAAF326fOmRmVZ8prh2l8uja0NzSkmAoDkFOcAAAAAAECXjd93aHzktEMSz6/d3BA3/uaFFBMBQHKKcwAAAAAAIJF/eOehMaa6KvH8dx56MVa+sS3FRACQjOIcAAAAAABIZGhFWXzqvCmJ5xubC3HNXUtSTAQAySjOAQAAAACAxC46+sB42/h9Es8veHZN/O7FDekFAoAEFOcAAAAAAEBi2WwmPjd7erfucdXtiyNfKKaUCAC6TnEOAAAAAAB0yzETRsafHXNg4vklq+viR0+sTDERAHSN4hwAAAAAAOi2fzl3agwpzyWe/8rdy6KuvinFRACw9xTnAAAAAABAt42pqYp/Ov3QxPMbtjbGN+5/LsVEALD3FOcAAAAAAEAqPnzqIXHgPkMSz3/vkZfjxXVbUkwEAHtHcQ4AAAAAAKSiqjwX/3r+tMTzTflifP7OJSkmAoC9ozgHAAAAAABSc/6RY+LESfsmnr9/6dp4cPm6FBMBwFtTnAMAAAAAAKnJZDIx78Lpkckkv8fVdyyOpnwhvVAA8BYU5wAAAAAAQKqOOLAm/vKE8Ynnn1u7JX7wu1dSTAQAb05xDgAAAAAApO6Ks6fEiMqyxPP/977nYuPWxhQTAcCeKc4BAAAAAIDUjRpeGf/nzMMSz9dub4qv3bc8xUQAsGeKcwAAAAAAoEe8f9akmDRqWOL5/3l0RSx/fXOKiQCgc4pzAAAAAACgR1SUZWPu+dMSz+cLxbj6jsVRLBZTTAUAHSnOAQAAAACAHnPmtAPi1MNHJZ5/6Ln1cf+StSkmAoCOFOcAAAAAAECPyWQy8dkLp0cum0l8j3+7c3E0NOdTTAUAbSnOAQAAAACAHjV59Ij4m5kTEs+/vGFbfP+Rl9MLBADtKM4BAAAAAIAed9m7JkfNkPLE89+4//lYt7khxUQAsJviHAAAAAAA6HEjh1XE5WdNTjy/uaE5rrtnWYqJAGA3xTkAAAAAANAr/nrmhDj8gOGJ5297YmX8cVVtiokAYAfFOQAAAAAA0CvKctmYN3t64vliMWL+7YujWCymmAoAFOcAAAAAAEAvOvXw/eNd0w5IPP/Yy2/EgmfXpJgIABTnAAAAAABAL5t7wfQoz2USz39hwZKob8qnmAiAUqc4BwAAAAAAetWkUcPiA6dMSjy/atP2+I8HX0wxEQClTnEOAAAAAAD0uo+ecVjsN6wi8fwNv3kh1tTWp5gIgFKmOAcAAAAAAHpddVV5/PM5UxLPb2/Kx5d+uTTFRACUMsU5AAAAAADQJ957/PiYPrY68fz/PrUqfr9iY4qJAChVinMAAAAAAKBP5LKZ+Nzs6d26x/zbF0ehUEwpEQClSnEOAAAAAAD0mZmH7BfnHzkm8fzTKzfFz59ZlWIiAEpRouL8hhtuiEmTJkVVVVUcd9xx8dBDD73p9T/4wQ/i6KOPjqFDh8bYsWPjAx/4QGzYsKHl9e9973uRyWQ6fNXX1yeJBwAAAAAADCBXnjctKsqSr/X74l1LY2tDc4qJACg1Xf5b6LbbbovLLrss5s6dG0899VSceuqpcd5558WKFSs6vf7hhx+OSy65JD70oQ/FokWL4sc//nE8/vjj8eEPf7jNddXV1bF69eo2X1VVVck+FQAAAAAAMGCM33dofOTUQxLPv17XEN964IUUEwFQarpcnH/1q1+ND33oQ/HhD384pk2bFl/72tdi/PjxceONN3Z6/e9+97uYOHFifOxjH4tJkybF29/+9vj7v//7eOKJJ9pcl8lkYsyYMW2+AAAAAACA0vAP7zw0DhhRmXj+2w++GCvf2JZiIgBKSZeK88bGxnjyySfj7LPPbvP82WefHY888kinM7NmzYpXX301FixYEMViMV5//fX4yU9+EhdccEGb67Zs2RIHH3xwHHTQQXHhhRfGU0891cWPAgAAAAAADFTDKsvi0+dNTTzf2FyIL961NMVEAJSSLhXn69evj3w+H6NHj27z/OjRo2PNmjWdzsyaNSt+8IMfxJw5c6KioiLGjBkT++yzT3zjG99ouWbq1Knxve99L37xi1/ELbfcElVVVXHKKafEc889t8csDQ0NUVdX1+YLAAAAAAAYuN79tgPj6PH7JJ6/89nV8eiLG9ILBEDJ6PJW7RE7tlVvrVgsdnhul8WLF8fHPvaxmDdvXjz55JPxy1/+Ml566aW49NJLW6456aST4m/+5m/i6KOPjlNPPTV+9KMfxeTJk9uU6+1dc801UVNT0/I1fvz4JB8FAAAAAADoJ7LZTHxu9vRu3eOq2xdHvlBMKREApaJLxfmoUaMil8t1WF2+du3aDqvQd7nmmmvilFNOiU9+8pNx1FFHxTnnnBM33HBD3HTTTbF69erOQ2WzccIJJ7zpivMrr7wyamtrW75WrlzZlY8CAAAAAAD0Q8dOGBl/esyBiecXr66LHz+hMwCga7pUnFdUVMRxxx0X9957b5vn77333pg1a1anM9u2bYtstu3b5HK5iNixUr0zxWIxnn766Rg7duwes1RWVkZ1dXWbLwAAAAAAYOD71LlTY0h5LvH8V+5ZFnX1TSkmAmCw6/JW7Zdffnl897vfjZtuuimWLFkSn/jEJ2LFihUtW69feeWVcckll7RcP3v27Pjf//3fuPHGG+PFF1+M3/72t/Gxj30sTjzxxBg3blxERFx11VVx9913x4svvhhPP/10fOhDH4qnn366zXbuAAAAAABAaRhTUxX/+M5DE8+v39IY1//q+RQTATDYlXV1YM6cObFhw4aYP39+rF69Oo444ohYsGBBHHzwwRERsXr16lixYkXL9e9///tj8+bNcf3118cVV1wR++yzT5xxxhlx7bXXtlyzadOm+MhHPhJr1qyJmpqaOOaYY+LBBx+ME088MYWPCAAAAAAADDR/d9ohcevjK2PVpu2J5v/rty/F+06cEJNGDUs5GQCDUaa4p/3SB5i6urqoqamJ2tpa27YDAAAAAMAgcMcfXouP/vCpxPPvmjY6vvu3x6eYCICBpCsdcpe3agcAAAAAAOgNFxw5Nk6cuG/i+fuWvB4PPbcuxUQADFaKcwAAAAAAoF/KZDIxb/b0yGSS3+PqOxZHc76QXigABiXFOQAAAAAA0G8dcWBNvPe48Ynnl7++JX742IoUEwEwGCnOAQAAAACAfu2fz5kSwyvLEs9/9d7lsWlbY4qJABhsFOcAAAAAAEC/tv+Iyvg/ZxyWeH7Ttqb42n3PpZgIgMFGcQ4AAAAAAPR77z9lYkzcb2ji+f/+3Sux/PXNKSYCYDBRnAMAAAAAAP1eZVku5l4wPfF8vlCMq+9YHMViMcVUAAwWinMAAAAAAGBAeNe0A+Lth41KPP/Qc+vjV0vXppgIgMFCcQ4AAAAAAAwImUwmPnvh9MhlM4nv8W93LonG5kKKqQAYDBTnAAAAAADAgDFlzIj465kTEs+/tH5rfP+Rl9MLBMCgoDgHAAAAAAAGlE+8a3LUDClPPP/1+5+L9VsaUkwEwECnOAcAAAAAAAaUkcMq4hPvOjzx/OaG5rjunmUpJgJgoFOcAwAAAAAAA85fn3RwHHbA8MTztz6+Mha9VptiIgAGMsU5AAAAAAAw4JTnsvHZC6cnni8WI+bfvjiKxWKKqQAYqBTnAAAAAADAgPSOyfvHmVMPSDz/6EtvxF1/XJNiIgAGKsU5AAAAAAAwYM29YFqU5zKJ57+wYEnUN+VTTATAQKQ4BwAAAAAABqxD9h8e7581MfH8qxu3x3cfejG9QAAMSIpzAAAAAABgQPs/Zx4e+w2rSDx/w29eiNfr6lNMBMBAozgHAAAAAAAGtOqq8rji7CmJ57c15uPaXy5NMREAA43iHAAAAAAAGPDmnDA+po2tTjz/v79fFU+t2JhiIgAGEsU5AAAAAAAw4OWymfjc7Ondusf8OxZHsVhMKREAA4niHAAAAAAAGBROOmS/OO+IMYnnn1qxKX7+9GspJgJgoFCcAwAAAAAAg8a/nj8tKsqS1x9fvGtpbGtsTjERAAOB4hwAAAAAABg0xu87NP7u1EmJ59fU1ce3fvNCiokAGAgU5wAAAAAAwKDyj+88LA4YUZl4/tsPvhivbtyWYiIA+jvFOQAAAAAAMKgMqyyLT507NfF8Q3MhrrlraYqJAOjvFOcAAAAAAMCg86fHHBhHj98n8fydf1gdj730RnqBAOjXFOcAAAAAAMCgk81mYt6F07t1j6tuXxT5QjGlRAD0Z4pzAAAAAABgUDru4JHx7reNSzy/6LW6+MmTK1NMBEB/pTgHAAAAAAAGrU+dNzWGlOcSz3/57mWxub4pxUQA9EeKcwAAAAAAYNAaWzMk/uGdhyaeX7+lMa7/1fMpJgKgP1KcAwAAAAAAg9pHTjskDtxnSOL5m377Ury8fmuKiQDobxTnAAAAAADAoFZVnotPnzc18XxTvhifX7AkxUQA9DeKcwAAAAAAYNC78KixccLEkYnn7138ejz83PoUEwHQnyjOAQAAAACAQS+TycTnZs+ITCb5PebfsSia84X0QgHQbyjOAQAAAACAknDEgTXxF8cdlHh++etb4pbHVqSYCID+QnEOAAAAAACUjH8+Z0oMryxLPH/dvctj07bGFBMB0B8ozgEAAAAAgJJxwIiq+OgZhyWe37StKb5233MpJgKgP1CcAwAAAAAAJeUDp0yMg/cbmnj+v3/3Sjz3+uYUEwHQ1xTnAAAAAABASaksy8Xc86clns8XinH1nUuiWCymmAqAvqQ4BwAAAAAASs5Z00fHKYftl3j+weXr4tfL1qaYCIC+pDgHAAAAAABKTiaTiXkXzohsJvk9rr5jSTQ2F9ILBUCfUZwDAAAAAAAlacqYEfHXMw9OPP/S+q1x88KX0wsEQJ9RnAMAAAAAACXrE2dNjuqqssTz/37/c7F+S0OKiQDoC4pzAAAAAACgZO07rCI+cdbkxPOb65vjunuWp5gIgL6gOAcAAAAAAEra35x0cBx2wPDE87c9viIWv1aXYiIAepviHAAAAAAAKGnluWx85oJpiecLxYj5dyyKYrGYYioAepPiHAAAAAAAKHnvnHJAnDH1gMTzv3vxjfjlH9ekmAiA3qQ4BwAAAAAAiIi5F0yLsmwm8fznFyyJ+qZ8iokA6C2KcwAAAAAAgIg4dP/h8bezJiaef3Xj9vjPh19KLxAAvUZxDgAAAAAAsNPHzjw89h1WkXj+m79+Pl6vq08xEQC9QXEOAAAAAACwU82Q8rji7MmJ57c15uNLv1yWYiIAeoPiHAAAAAAAoJW/PGFCTB0zIvH8T3//ajy9clN6gQDocYpzAAAAAACAVnLZTHxu9oxu3WP+7YuiWCymlAiAnqY4BwAAAAAAaOfkQ/eLc2eMSTz/+xWb4hfPvJZiIgB6kuIcAAAAAACgE/96/rSoKEtepVyzYGlsa2xOMREAPUVxDgAAAAAA0IkJ+w2ND799UuL5NXX18a0HXkwxEQA9RXEOAAAAAACwB/94+mGx/4jKxPPffuCFWLVpe4qJAOgJinMAAAAAAIA9GF5ZFp86d2ri+YbmQlyzYEmKiQDoCYpzAAAAAACAN/FnxxwYRx9Uk3j+jj+sjsdffiPFRACkTXEOAAAAAADwJrLZTMybPb1b97jq9kVRKBRTSgRA2hTnAAAAAAAAb+G4g/eNi942LvH8H1fVxU+efDXFRACkSXEOAAAAAACwFz517tSoKk9erXzp7mWxub4pxUQApEVxDgAAAAAAsBfG7TMkLn3HoYnn129piOt//XyKiQBIi+IcAAAAAABgL/39aYfGuJqqxPP/9fDL8cqGrSkmAiANinMAAAAAAIC9NKQiF58+f1ri+cZ8IT5/55IUEwGQBsU5AAAAAABAF8w+amwcf/DIxPP3LH49fvv8+hQTAdBdinMAAAAAAIAuyGQy8bnZMyKTSX6P+bcvjuZ8Ib1QAHSL4hwAAAAAAKCLjjyoJv782IMSzy97fXPc8vjKFBMB0B2KcwAAAAAAgAQ+ee6UGFaRSzz/1XuWRe22phQTAZCU4hwAAAAAACCBA0ZUxUfPODzx/MZtTfG1+5enmAiApBTnAAAAAAAACX3w7RNjwr5DE8//98JX4vm1m1NMBEASinMAAAAAAICEKstyMfeCaYnnmwvFuPqOJSkmAiAJxTkAAAAAAEA3nD19dMw6dL/E8w8sXxe/Xro2xUQAdJXiHAAAAAAAoBsymUzMmz09spnk97j6zsXR2FxILxQAXaI4BwAAAAAA6KapY6rjr2ZOSDz/4rqtcfPCl9MLBECXKM4BAAAAAABScPlZU6K6qizx/L/f/1xs2NKQYiIA9pbiHAAAAAAAIAX7DquIy941OfH85vrmuO7e5SkmAmBvKc4BAAAAAABScvHJB8eh+w9LPH/rYytiyeq6FBMBsDcU5wAAAAAAACkpz2XjMxdOTzxfKEbMv31xFIvFFFMB8FYU5wAAAAAAACk6fcoBcfqU/RPPL3xxQ9y9aE2KiQB4K4pzAAAAAACAlH3mwulRls0knv/8giVR35RPMREAb0ZxDgAAAAAAkLJD9x8el5w8MfH8yje2x02/fSm9QAC8KcU5AAAAAABAD/j4mYfHvsMqEs9f/6vnY21dfYqJANgTxTkAAAAAAEAPqBlaHpefNTnx/LbGfHzp7mUpJgJgTxTnAAAAAAAAPeQvTxgfU8eMSDz/kydfjWdWbkovEACdUpwDAAAAAAD0kLJcNuZdOL1b95h/x+IoFospJQKgM4pzAAAAAACAHjTrsFFxzozRieeffGVj/OKZ11JMBEB7inMAAAAAAIAeNvf86VGRS17LfPGupbGtsTnFRAC0pjgHAAAAAADoYRP2GxofOnVS4vnVtfXx7QdeTDERAK0pzgEAAAAAAHrBP51+WOw/ojLx/LcffCFWbdqeYiIAdlGcAwAAAAAA9ILhlWXxL+dMSTxf31SIL961NMVEAOyiOAcAAAAAAOgl7zn2oDjqoJrE87c/81o88fIbKSYCIEJxDgAAAAAA0Guy2UzMu3B6t+5x1e2Lo1AoppQIgAjFOQAAAAAAQK86fuK+8SdHj0s8/+yq2vjJ719NMREAinMAAAAAAIBe9unzpkZVefKa5st3L4stDc0pJgIobYpzAAAAAACAXjZunyHx96cdmnh+3eaG+Oavn08xEUBpU5wDAAAAAAD0gUvfcWiMralKPP+fD70Ur2zYmmIigNKlOAcAAAAAAOgDQypy8enzpiaeb8wX4gsLlqSYCKB0Kc4BAAAAAAD6yJ8cPS6OO3hk4vm7F70ejzy/PsVEAKVJcQ4AAAAAANBHMplMfG729G7dY/4di6M5X0gpEUBpUpwDAAAAAAD0oaMO2if+/LiDEs8vXbM5bn18ZYqJAEqP4hwAAAAAAKCP/cs5U2JYRS7x/HX3LIvabU0pJgIoLYpzAAAAAACAPnZAdVX80xmHJZ7fuK0p/v3+51JMBFBaFOcAAAAAAAD9wAdPmRTj9x2SeP7mhS/H82u3pJgIoHQkKs5vuOGGmDRpUlRVVcVxxx0XDz300Jte/4Mf/CCOPvroGDp0aIwdOzY+8IEPxIYNG9pc89Of/jSmT58elZWVMX369PjZz36WJBoAAAAAAMCAVFWei7nnT08831woxr/duTjFRAClo8vF+W233RaXXXZZzJ07N5566qk49dRT47zzzosVK1Z0ev3DDz8cl1xySXzoQx+KRYsWxY9//ON4/PHH48Mf/nDLNQsXLow5c+bExRdfHM8880xcfPHF8d73vjceffTR5J8MAAAAAABggDlnxug4+ZD9Es//Ztm6+PWytSkmAigNmWKxWOzKwMyZM+PYY4+NG2+8seW5adOmxbvf/e645pprOlz/la98JW688cZ44YUXWp77xje+EV/60pdi5cqVERExZ86cqKuri7vuuqvlmnPPPTdGjhwZt9xyy17lqquri5qamqitrY3q6uqufCQAAAAAAIB+Y8nqurjg6w9FoUsNzm6H7D8s7r7stCjPObEXKG1d6ZC79P+YjY2N8eSTT8bZZ5/d5vmzzz47HnnkkU5nZs2aFa+++mosWLAgisVivP766/GTn/wkLrjggpZrFi5c2OGe55xzzh7vGRHR0NAQdXV1bb4AAAAAAAAGumljq+N9J05IPP/iuq1x88JXUkwEMPh1qThfv3595PP5GD16dJvnR48eHWvWrOl0ZtasWfGDH/wg5syZExUVFTFmzJjYZ5994hvf+EbLNWvWrOnSPSMirrnmmqipqWn5Gj9+fFc+CgAAAAAAQL91+VmTY0RVWeL5f79vebyxtTHFRACDW6I9OjKZTJvHxWKxw3O7LF68OD72sY/FvHnz4sknn4xf/vKX8dJLL8Wll16a+J4REVdeeWXU1ta2fO3a9h0AAAAAAGCg2294ZXz8zMMTz9fVN8dX712WYiKAwa1Lv6o0atSoyOVyHVaCr127tsOK8V2uueaaOOWUU+KTn/xkREQcddRRMWzYsDj11FPj3/7t32Ls2LExZsyYLt0zIqKysjIqKyu7Eh8AAAAAAGDAuOTkifHDx1bEi+u2Jpr/4aMr4q9nHhzTxr75ub4AdHHFeUVFRRx33HFx7733tnn+3nvvjVmzZnU6s23btshm275NLpeLiB2ryiMiTj755A73vOeee/Z4TwAAAAAAgMGuoiwbn71geuL5QjFi/u2LW/oYAPasy1u1X3755fHd7343brrppliyZEl84hOfiBUrVrRsvX7llVfGJZdc0nL97Nmz43//93/jxhtvjBdffDF++9vfxsc+9rE48cQTY9y4cRER8fGPfzzuueeeuPbaa2Pp0qVx7bXXxn333ReXXXZZOp8SAAAAAABgADp96gHxzin7J55f+OKGuHvR6ykmAhicurRVe0TEnDlzYsOGDTF//vxYvXp1HHHEEbFgwYI4+OCDIyJi9erVsWLFipbr3//+98fmzZvj+uuvjyuuuCL22WefOOOMM+Laa69tuWbWrFlx6623xmc+85n47Gc/G4ceemjcdtttMXPmzBQ+IgAAAAAAwMD1mQumx8PPPRjNhWQrx7+wYEmcPnX/qCzLpZwMYPDIFAfJ/hx1dXVRU1MTtbW1UV3trA4AAAAAAGDwuOr2RfFfv3058fynzp0a//DOQ9MLBDAAdKVD7vJW7QAAAAAAAPSuy86cHCOHlieev/5Xz8XauvoUEwEMLopzAAAAAACAfq5maHlcfvaUxPNbG/Px5buXpZgIYHBRnAMAAAAAAAwA7zthfEwZPSLx/E9+/2r84dVN6QUCGEQU5wAAAAAAAANAWS4b82ZPTzxfLEbMv31xFIvFFFMBDA6KcwAAAAAAgAHilMNGxdnTRyeef+KVjXH7H1anmAhgcFCcAwAAAAAADCBzL5gWFbnkFc8XFyyJ7Y35FBMBDHyKcwAAAAAAgAHk4P2GxQffPinx/Gu19fHtB19IMRHAwKc4BwAAAAAAGGA+esZhMWp4ZeL5bz3wQry2aXuKiQAGNsU5AAAAAADAADO8siz+5dwpiefrmwrxxbuWppgIYGBTnAMAAAAAAAxAf37sQXHkgTWJ53/xzGvx5CtvpJgIYOBSnAMAAAAAAAxA2Wwm5s2e3q17XHX74igUiiklAhi4FOcAAAAAAAAD1AkT943ZR49LPP+HV2vjp79/NcVEAAOT4hwAAAAAAGAA+/R5U6OqPHnl86W7l8WWhuYUEwEMPIpzAAAAAACAAezAfYbER047NPH8us0NccOvn08xEcDAozgHAAAAAAAY4C59xyExtqYq8fx3H3opVmzYlmIigIFFcQ4AAAAAADDADa0oi0+fNzXxfGO+EF9YsCTFRAADi+IcAAAAAABgEPiTo8fFsRP2STz/y0Vr4pEX1qcXCGAAUZwDAAAAAAAMAplMJj43e0a37jH/9sWRLxRTSgQwcCjOAQAAAAAABomjx+8T7zn2oMTzS9dsjlsfX5FiIoCBQXEOAAAAAAAwiPzLuVNiaEUu8fx19yyP2u1NKSYC6P8U5wAAAAAAAIPI6Oqq+KfTD0s8/8bWxvj6/c+lmAig/1OcAwAAAAAADDIfevukGL/vkMTz33/k5Xhh3ZYUEwH0b4pzAAAAAACAQaaqPBdzz5+WeL65UIx/u2NxiokA+jfFOQAAAAAAwCB0zowxcdIh+yae//WydfGbZWtTTATQfynOAQAAAAAABqFMJhPzLpwR2Uzye1x9x+JoyhfSCwXQTynOAQAAAAAABqnp46rjL0+ckHj+hXVb478XvpJiIoD+SXEOAAAAAAAwiF1x1uQYUVWWeP5r9y2PN7Y2ppgIoP9RnAMAAAAAAAxi+w2vjI+feXji+br65vi/9y5PMRFA/6M4BwAAAAAAGOQuOXliHDJqWOL5Hzz6SixdU5diIoD+RXEOAAAAAAAwyFWUZeMzF05LPF8oRlx9x+IoFosppgLoPxTnAAAAAAAAJeD0KQfEaZP3Tzz/2+c3xL2LX08xEUD/oTgHAAAAAAAoAZlMJuZdOC1y2Uzie3x+wZJoaM6nmAqgf1CcAwAAAAAAlIjDDhgRF590cOL5VzZsi//67cvpBQLoJxTnAAAAAAAAJeQT75ocI4eWJ57/xv3PxdrN9SkmAuh7inMAAAAAAIASUjO0PC4/a3Li+a2N+fjK3ctSTATQ9xTnAAAAAAAAJeZ9J06IKaNHJJ7/8ZOvxrOv1qaYCKBvKc4BAAAAAABKTFkuG/NmT088XyxGXHX7oigWiymmAug7inMAAAAAAIASdMpho+Ks6aMTzz/xysa44w+rU0wE0HcU5wAAAAAAACVq7vnTojyXSTz/xbuWxvbGfIqJAPqG4hwAAAAAAKBETRw1LD749kmJ51dt2h7fefDFFBMB9A3FOQAAAAAAQAn76OmHxajhlYnnv/XAC7G6dnuKiQB6n+IcAAAAAACghI2oKo9PnjM58fz2pnxce9fSFBMB9D7FOQAAAAAAQIn78+PGxxEHViee/39PvxZPvrIxxUQAvUtxDgAAAAAAUOJy2UzMu3BGt+4x//ZFUSgUU0oE0LsU5wAAAAAAAMSJk/aNC48am3j+mVdr42dPrUoxEUDvUZwDAAAAAAAQERFXnj8tKsuS10fX/nJpbG1oTjERQO9QnAMAAAAAABAREQfuMyT+/rRDEs+v3dwQN/zm+RQTAfQOxTkAAAAAAAAtLn3noTGmuirx/H889FKsfGNbiokAep7iHAAAAAAAgBZDK8ri0+dNTTzf2FyILyxYkmIigJ6nOAcAAAAAAKCNi942Lo6ZsE/i+bv+uCYWvrAhvUAAPUxxDgAAAAAAQBuZTCY+N3tGt+4x/47FkS8UU0oE0LMU5wAAAAAAAHTwtvH7xJ8de2Di+SWr6+K2x1emmAig5yjOAQAAAAAA6NSnzp0aQytyieevu2dZ1G5vSjERQM9QnAMAAAAAANCp0dVV8U+nH5Z4fsPWxvjG/c+lmAigZyjOAQAAAAAA2KMPvX1SHDRySOL57z3ycry4bkuKiQDSpzgHAAAAAABgj6rKc/Gv509LPN9cKMbn71ySYiKA9CnOAQAAAAAAeFPnHTEmZk7aN/H8/UvXxgPL16WYCCBdinMAAAAAAADeVCaTiXmzp0cmk/weV9+xOJryhfRCAaRIcQ4AAAAAAMBbmjGuJv7yhAmJ559fuyX+53evpJgIID2KcwAAAAAAAPbKFWdPjhGVZYnnv3bfc7Fxa2OKiQDSoTgHAAAAAABgr4waXhkfO/PwxPO125vi/963PMVEAOlQnAMAAAAAALDX/nbWxJg0alji+f/53SuxbM3mFBMBdJ/iHAAAAAAAgL1WUZaNz1wwLfF8oRhx9R2Lo1gsppgKoHsU5wAAAAAAAHTJGVMPiFMPH5V4/uHn18d9S9ammAigexTnAAAAAAAAdEkmk4l5F06PXDaT+B7/dufiaGjOp5gKIDnFOQAAAAAAAF12+OgRcfFJByeef2XDtvjeb19OLxBANyjOAQAAAAAASOSydx0e+wwtTzz/jV89H+s2N6SYCCAZxTkAAAAAAACJ7DO0Ii4/a3Li+S0NzfGVu5elmAggGcU5AAAAAAAAif3ViRNi8ujhied/9OTK+OOq2hQTAXSd4hwAAAAAAIDEynLZmHfhjMTzxWLEVbcvimKxmGIqgK5RnAMAAAAAANAtbz98VLxr2ujE84+/vDHufHZ1iokAukZxDgAAAAAAQLfNvWBalOcyieevWbA06pvyKSYC2HuKcwAAAAAAALpt0qhh8cFTJiWeX7Vpe3znwRdTTASw9xTnAAAAAAAApOKjZxwWo4ZXJJ6/8TcvxJra+hQTAewdxTkAAAAAAACpGFFVHv989pTE89ub8nHtL5emmAhg7yjOAQAAAAAASM1fHD8+ZoyrTjz/s6dWxe9XbEwxEcBbU5wDAAAAAACQmlw2E5+bPaNb97jq9sVRKBRTSgTw1hTnAAAAAAAApOrESfvGBUeOTTz/zMpN8f+eXpViIoA3pzgHAAAAAAAgdZ8+b2pUliWvor5419LY2tCcYiKAPVOcAwAAAAAAkLrx+w6Nj5x2SOL5tZsb4sbfvJBiIoA9U5wDAAAAAADQI/7hnYfGmOqqxPPfeejFWPnGthQTAXROcQ4AAAAAAECPGFpRFp86b0ri+cbmQlxz15IUEwF0TnEOAAAAAABAj7no6APjbeP3STy/4Nk18bsXN6QXCKATinMAAAAAAAB6TDabic/Nnt6te1x1++LIF4opJQLoSHEOAAAAAAD8/+3deZyVBb0/8O+ZhRnWQUAW2UQQmJFyAUEhLDcUhPIuSdfS63b7+csWJbtpFP5Ey/SmP8vSur8kbl2vUZnlAipaCS5ZElg5bAo6qCwCMsM6MDPn94dJEbjMwzPbOe/363X+4PH5POdz7uv2vKwPzznQpI4dcEj847F9E+eXrq2Jnzy7JsVGAPsynAMAAAAAANDk/v3M4dG+uDBx/hsPL4+aXXtSbATwV4ZzAAAAAAAAmlzvstK47OTBifObtu+O2x5bmWIjgL8ynAMAAAAAANAsLhl/RPTt2j5xfvZTL8XqjdtTbATwJsM5AAAAAAAAzaK0uDC+NKk8cX5PfTa++mBlio0A3mQ4BwAAAAAAoNlMel/vGD2oW+L8o0s3xIIVr6fYCMBwDgAAAAAAQDPKZDIxY3JFZDLJr3HdA5VRV9+QXikg7xnOAQAAAAAAaFYj+pbF1FH9E+dXbtgWdz1TlWIjIN8ZzgEAAAAAAGh2n58wLDqXFCXO3zJ/RbyxfXeKjYB8ZjgHAAAAAACg2R3auSQ+c+qQxPnqnXvi1kdXpNgIyGeGcwAAAAAAAFrEBWMHxaAeHRPn//uZqlixfmuKjYB8ZTgHAAAAAACgRbQrKojpk8oT5+sbsnHdA5WRzWZTbAXkI8M5AAAAAAAALebU8p4x/sgeifMLV26Mx5ZuSLERkI8M5wAAAAAAALSYTCYTX5lcEYUFmcTXuP7Byqitq0+xFZBvDOcAAAAAAAC0qKG9OscnxgxInH9p0474r6deSq8QkHcM5wAAAAAAALS4y08bGmXtixPnb3vshXh9a22KjYB8YjgHAAAAAACgxR3SsV1MO31o4vzW2rq4+ZHlKTYC8onhHAAAAAAAgFbh42MGxJE9OyXOz3l2Tfz51eoUGwH5wnAOAAAAAABAq1BUWBBfmVyROJ/NRsx8oDKy2WyKrYB8YDgHAAAAAACg1Thp6KFxWnnPxPnfrd4cc/+0LsVGQD4wnAMAAAAAANCqTD+rIooLM4nzX5u7NHbtqU+xEZDrEg3nt99+ewwaNChKS0tj5MiRsXDhwrc994ILLohMJrPf66ijjtp7zuzZsw94zq5du5LUAwAAAAAAoA0b1KNjXDhuUOL8q1t2xv9bsCrFRkCua/RwPmfOnLj88stj+vTpsXjx4hg/fnxMnDgxqqqqDnj+N7/5zVi7du3e15o1a6Jbt27x0Y9+dJ/zunTpss95a9eujdLS0mSfCgAAAAAAgDbt06cMie4d2yXO3/6bF2NdtYc0gfem0cP5LbfcEhdffHFccsklUV5eHrfeemv0798/7rjjjgOeX1ZWFr179977evbZZ+ONN96ICy+8cJ/zMpnMPuf17t072ScCAAAAAACgzetSWhxXnjEscX7nnvq46aFlKTYCclmjhvPdu3fHokWLYsKECfscnzBhQjz11FPv6Rp33nlnnHbaaTFw4MB9jm/bti0GDhwY/fr1i8mTJ8fixYvf8Tq1tbVRU1OzzwsAAAAAAIDccc6o/lHRp0vi/M8Xvxp/qHojxUZArmrUcL5x48aor6+PXr167XO8V69esW7dunfNr127NubNmxeXXHLJPseHDx8es2fPjvvuuy/uvvvuKC0tjXHjxsXKlSvf9lo33HBDlJWV7X3179+/MR8FAAAAAACAVq6wIBPXTKk4qGvMvL8yGhqyKTUCclWjv6o94s2vVf9b2Wx2v2MHMnv27OjatWucffbZ+xw/4YQT4hOf+EQcffTRMX78+PjJT34SQ4cOjdtuu+1tr3X11VdHdXX13teaNWuSfBQAAAAAAABasTFHdI9J70v+E79L1myJXz73aoqNgFzUqOG8R48eUVhYuN/T5Rs2bNjvKfS/l81mY9asWXHeeedFu3bt3rlUQUEcf/zx7/jEeUlJSXTp0mWfFwAAAAAAALnn6onl0a4o0fOgERHx9XnLYnttXYqNgFzTqDtMu3btYuTIkTF//vx9js+fPz/Gjh37jtnHH388Xnjhhbj44ovf9X2y2WwsWbIk+vTp05h6AAAAAAAA5KD+3TrEJ8cfkTi/vqY2vvv4iyk2AnJNo/9qzrRp0+L73/9+zJo1K5YuXRpXXHFFVFVVxaWXXhoRb36F+vnnn79f7s4774wxY8bEiBEj9vtn1157bTz88MOxatWqWLJkSVx88cWxZMmSvdcEAAAAAAAgv/3vDw2Onp1LEuf/c8GqWLN5R4qNgFxS1NjA1KlTY9OmTTFz5sxYu3ZtjBgxIubOnRsDBw6MiIi1a9dGVVXVPpnq6uq455574pvf/OYBr7lly5b45Cc/GevWrYuysrI49thjY8GCBTF69OgEHwkAAAAAAIBc07GkKK6aODym/eS5RPnauob4+rxl8Z2PH5dyMyAXZLLZbLalS6ShpqYmysrKorq62u+dAwAAAAAA5KCGhmz8wx1PxXNrtiS+xpxPnhBjjuieXimg1WrMhtzor2oHAAAAAACAllBQkIlrplQc1DVmPlAZ9Q058VwpkCLDOQAAAAAAAG3GcQMOiX84tm/i/POv1cRPn12TYiMgFxjOAQAAAAAAaFO+eObwaF9cmDj/jUeWR82uPSk2Ato6wzkAAAAAAABtSu+y0vjUhwYnzm/ctju+/asXUmwEtHWGcwAAAAAAANqcfzvpiOjbtX3i/A+eXB2rN25PsRHQlhnOAQAAAAAAaHNKiwvj6knDE+f31Gfjqw8uTbER0JYZzgEAAAAAAGiTznpfnxh9eLfE+UeXro+FK19PsRHQVhnOAQAAAAAAaJMymUzMmFIRmUzya1z3QGXU1TekVwpokwznAAAAAAAAtFkj+pbFOSP7J86vWL8t/ud3VSk2AtoiwzkAAAAAAABt2pVnDItOJUWJ87fMXxFbduxOsRHQ1hjOAQAAAAAAaNMO7VwSnzllSOL8lh174tZHV6bYCGhrDOcAAAAAAAC0eReMOzwO794hcf5Hv305Vq7fmmIjoC0xnAMAAAAAANDmlRQVxvSzKhLn6xuyMfOByshmsym2AtoKwzkAAAAAAAA54bTynvGBIT0S5xeu3Bi/WrYhxUZAW2E4BwAAAAAAICdkMpn4yuSKKCzIJL7G9Q8ujd11DSm2AtoCwzkAAAAAAAA5Y1jvzvHxMQMS51dv3B7/9dRL6RUC2gTDOQAAAAAAADnlitOGRln74sT5bz22MjZuq02xEdDaGc4BAAAAAADIKYd0bBdXnHZk4vzW2rq4+ZHlKTYCWjvDOQAAAAAAADnn4ycMjCE9OyXO//j3a+L516pTbAS0ZoZzAAAAAAAAck5xYUF8ZXJF4nw2GzHz/srIZrMptgJaK8M5AAAAAAAAOemDQw+NU4f3TJx/ZvXmmPfndSk2AlorwzkAAAAAAAA5a/pZ5VFcmEmc/9rcpbFrT32KjYDWyHAOAAAAAABAzjri0E7xrycenjj/yhs7484nVqdXCGiVDOcAAAAAAADktM+cemR079gucf47v34h1tfsSrER0NoYzgEAAAAAAMhpZe2L4/MThiXO79hdHzc+tCzFRkBrYzgHAAAAAAAg5009vn+U9+mSOP/zP7waS9ZsSa8Q0KoYzgEAAAAAAMh5hQWZuGZKxUFd49r7n49sNptSI6A1MZwDAAAAAACQF044ontMHNE7cX5x1Zb45ZLXUmwEtBaGcwAAAAAAAPLGlyaVR7ui5BPZ1+ctix2761JsBLQGhnMAAAAAAADyRv9uHeLfxg9KnF9Xsyu++5sXU2wEtAaGcwAAAAAAAPLKpz40JHp2Lkmc/96CVfHKGztSbAS0NMM5AAAAAAAAeaVjSVF88czhifO1dQ1xw7xlKTYCWprhHAAAAAAAgLzzD8f2jaP7d02cf/CPa+N3qzenVwhoUYZzAAAAAAAA8k5BQSZmTK44qGtce//zUd+QTakR0JIM5wAAAAAAAOSlkQMPibOPOSxx/vnXauJni9ak2AhoKYZzAAAAAAAA8tYXJw6P9sWFifP/8fDy2LprT4qNgJZgOAcAAAAAACBv9SlrH//7Q4MT5zdu2x3f/vULKTYCWoLhHAAAAAAAgLz2yZOOiL5d2yfOz3pidby0cXuKjYDmZjgHAAAAAAAgr5UWF8ZVE4cnzu+pz8ZX5y5NsRHQ3AznAAAAAAAA5L3J7+8Txx9+SOL8/Mr18cTKjSk2ApqT4RwAAAAAAIC8l8lk4popR0Umk/waMx94PurqG9IrBTQbwzkAAAAAAABExIi+ZfHRkf0S51es3xZ3/64qxUZAczGcAwAAAAAAwF9cecaw6FRSlDh/8/wVsWXH7hQbAc3BcA4AAAAAAAB/0bNzaXz6lCGJ81t27IlbH12ZYiOgORjOAQAAAAAA4G9cOO7wGNi9Q+L8j377cqxcvzXFRkBTM5wDAAAAAADA3ygpKozpk8oT5+sbsnHdg0sjm82m2ApoSoZzAAAAAAAA+DunV/SKcUO6J84vWPF6/Hr5hhQbAU3JcA4AAAAAAAB/J5PJxIzJR0VBJvk1rn9gaeyua0ivFNBkDOcAAAAAAABwAMN6d46PjxmYOL9q4/b44dMvpVcIaDKGcwAAAAAAAHgbV5w+NLqUFiXOf/OxlbFxW22KjYCmYDgHAAAAAACAt9GtY7u44vShifNbd9XFzY+sSLER0BQM5wAAAAAAAPAOPnHCwBjSs1Pi/JzfV0XlazUpNgLSZjgHAAAAAACAd1BcWBBfPqs8cb4hGzHzgecjm82m2ApIk+EcAAAAAAAA3sWHhvWMU4b3TJz/7arN8dCf16XYCEiT4RwAAAAAAADeg+lnlUdRQSZx/qtzl8auPfUpNgLSYjgHAAAAAACA92DwoZ3iX8cenjj/yhs7484nVqdXCEiN4RwAAAAAAADeo8+eemR069gucf47v34h1tfsSrERkAbDOQAAAAAAALxHZe2L4/MThibO79hdHzc9tDzFRkAaDOcAAAAAAADQCB87fkAM7905cf6eP7wSz63Zkl4h4KAZzgEAAAAAAKARCgsyMWNKxUFd49r7n49sNptSI+BgGc4BAAAAAACgkcYO7hFnHtU7cf4PVVvivudeS7ERcDAM5wAAAAAAAJDAlyaVR7ui5HPb1+ctix2761JsBCRlOAcAAAAAAIAEBnTvEJd8YFDi/NrqXfHdx1el2AhIynAOAAAAAAAACX3q5CFxaOeSxPnvPf5ivLplZ4qNgCQM5wAAAAAAAJBQp5Ki+OKZwxPna+sa4oa5S1NsBCRhOAcAAAAAAICD8I/H9o2j+5Ulzj/wx7Xx+5c2p9gIaCzDOQAAAAAAAByEgoJMzJhScVDXuPb+56OhIZtSI6CxDOcAAAAAAABwkEYO7BYfOeawxPk/v1oTP1v0SoqNgMYwnAMAAAAAAEAKvnjm8CgtTj6/3fTw8ti6a0+KjYD3ynAOAAAAAAAAKTisa/u49IODE+c3bquN7/z6xRQbAe+V4RwAAAAAAABS8r9OGhyHlZUmzs96YnW8vGl7io2A98JwDgAAAAAAAClp364wrppUnji/u74hvvrg0hQbAe+F4RwAAAAAAABSNOX9fWLUwEMS5x+pXB9PvrAxxUbAuzGcAwAAAAAAQIoymUxcM+WoyGSSX2Pm/ZVRV9+QXingHRnOAQAAAAAAIGXv61cW/3xcv8T55eu3xt2/X5NiI+CdGM4BAAAAAACgCXzhzGHRsV1h4vwtjyyP6h17UmwEvB3DOQAAAAAAADSBnp1L49OnHJk4/8aOPXHrYytSbAS8HcM5AAAAAAAANJGLPnB4DOjWIXH+R0+/HC9s2JpiI+BADOcAAAAAAADQREqKCmP6WeWJ83UN2bjugaUpNgIOxHAOAAAAAAAATWhCRa8YO7h74vzjK16PXy/bkGIj4O8ZzgEAAAAAAKAJZTKZmDGlIgoyya9x3YOVsbuuIb1SwD4M5wAAAAAAANDEhvfuEueOGZA4v+r17fHDp19KrxCwD8M5AAAAAAAANINppw+LLqVFifPffGxlbNpWm2Ij4C2GcwAAAAAAAGgG3Tq2i8tPG5o4v3VXXdwyf0WKjYC3GM4BAAAAAACgmZx34sAYfGjHxPm7f1cVS9fWpNgIiDCcAwAAAAAAQLMpLiyIL0+uSJxvyEbMvL8ystlsiq0AwzkAAAAAAAA0o5OH9YyThx2aOP/0qk3x8PPrU2wEGM4BAAAAAACgmX15ckUUFWQS5786tzJ27alPsRHkN8M5AAAAAAAANLPBh3aK8088PHF+zeadMevJ1ekVgjxnOAcAAAAAAIAW8LlTj4xuHdslzn/7Vy/EhppdKTaC/GU4BwAAAAAAgBZQ1qE4pp0+NHF+x+76uOnh5Sk2gvxlOAcAAAAAAIAW8rHj+8fw3p0T53+26JV4bs2W9ApBnjKcAwAAAAAAQAspKiyIGZMrDuoaMx+ojGw2m1IjyE+GcwAAAAAAAGhBY4f0iDOO6pU4v+jlN+K+515LsRHkH8M5AAAAAAAAtLDpkyqiXWHy6e7r85bFzt31KTaC/GI4BwAAAAAAgBY2oHuHuHj8oMT5tdW74ruPv5hiI8gvhnMAAAAAAABoBS47eUgc2rkkcf57C16M17bsTLER5A/DOQAAAAAAALQCnUqK4t/PGJY4v2tPQ3x93rIUG0H+MJwDAAAAAABAK/FPx/WL9/crS5y/77nX4tmXNqfYCPKD4RwAAAAAAABaiYKCTMyYXHFQ17j2/spoaMim1Ajyg+EcAAAAAAAAWpFRh3eLDx99WOL8n16tjp/94ZUUG0HuM5wDAAAAAABAK3PVxOFRWpx8yvuPh5fHttq6FBtBbjOcAwAAAAAAQCtzWNf28b9OGpw4//rW2vjOr19IsRHkNsM5AAAAAAAAtEKXfnBw9CkrTZy/c+HqeHnT9hQbQe5KNJzffvvtMWjQoCgtLY2RI0fGwoUL3/bcCy64IDKZzH6vo446ap/z7rnnnqioqIiSkpKoqKiIe++9N0k1AAAAAAAAyAnt2xXGVROHJ87vrm+Ir81dmmIjyF2NHs7nzJkTl19+eUyfPj0WL14c48ePj4kTJ0ZVVdUBz//mN78Za9eu3ftas2ZNdOvWLT760Y/uPefpp5+OqVOnxnnnnRfPPfdcnHfeeXHOOefEM888k/yTAQAAAAAAQBv34aMPi5EDD0mcf/j59fHUCxtTbAS5KZPNZrONCYwZMyaOO+64uOOOO/YeKy8vj7PPPjtuuOGGd83/4he/iH/8x3+M1atXx8CBAyMiYurUqVFTUxPz5s3be96ZZ54ZhxxySNx9993vqVdNTU2UlZVFdXV1dOnSpTEfCQAAAAAAAFqtP76yJT787ScT54f37hwPfOYDUVToV5zJL43ZkBv1n47du3fHokWLYsKECfscnzBhQjz11FPv6Rp33nlnnHbaaXtH84g3nzj/+2ueccYZ73jN2traqKmp2ecFAAAAAAAAueb9/brGP4/slzi/bN3W+PHv16TYCHJPo4bzjRs3Rn19ffTq1Wuf47169Yp169a9a37t2rUxb968uOSSS/Y5vm7dukZf84YbboiysrK9r/79+zfikwAAAAAAAEDb8e9nDIuO7QoT529+ZHlU79iTYiPILYm+jyGTyezz52w2u9+xA5k9e3Z07do1zj777IO+5tVXXx3V1dV7X2vW+FsyAAAAAAAA5KaeXUrjslOGJM6/sWNPfPOxlSk2gtzSqOG8R48eUVhYuN+T4Bs2bNjvifG/l81mY9asWXHeeedFu3bt9vlnvXv3bvQ1S0pKokuXLvu8AAAAAAAAIFddNG5Q9O/WPnH+h0+/FC9s2JZiI8gdjRrO27VrFyNHjoz58+fvc3z+/PkxduzYd8w+/vjj8cILL8TFF1+83z878cQT97vmI4888q7XBAAAAAAAgHxRWlwY0ydVJM7XNWTj+gcrU2wEuaOosYFp06bFeeedF6NGjYoTTzwx/vM//zOqqqri0ksvjYg3v0L91VdfjR/+8If75O68884YM2ZMjBgxYr9rfu5zn4uTTjopbrzxxvjIRz4Sv/zlL+PRRx+NJ554IuHHAgAAAAAAgNxzxlG94sQjusfTqzYlyv9m+evx6+Ub4uRhPVNuBm1bo3/jfOrUqXHrrbfGzJkz45hjjokFCxbE3LlzY+DAgRERsXbt2qiqqtonU11dHffcc88BnzaPiBg7dmz8+Mc/jh/84Afx/ve/P2bPnh1z5syJMWPGJPhIAAAAAAAAkJsymUzMmFIRBZnk17jugcrYU9+QXinIAZlsNptt6RJpqKmpibKysqiurvZ75wAAAAAAAOS06ff+Ke56purdT3wbX5lcERd/YFCKjaD1acyG3OgnzgEAAAAAAICWNe30odG5tNG/yrzXNx9dEZu3706xEbRthnMAAAAAAABoY7p3KonPnXpk4nzNrrq4Zf7yFBtB22Y4BwAAAAAAgDbo/BMPjyMO7Zg4/z/PVMXStTUpNoK2y3AOAAAAAAAAbVC7ooL4ylkVifMN2YjrHqiMbDabYitomwznAAAAAAAA0EadPLxnfGjYoYnzT724KR6pXJ9iI2ibDOcAAAAAAADQhn35rIooKsgkzn/1waVRW1efYiNoewznAAAAAAAA0IYN6dkpzjtxYOJ81eYdMeuJl9IrBG2Q4RwAAAAAAADauMtPHRqHdChOnP/2r1bGhq27UmwEbYvhHAAAAAAAANq4sg7FMW3CsMT57bvr4z8eWp5iI2hbDOcAAAAAAACQA/7l+P4xrFfnxPmf/eGV+OMrW9IrBG2I4RwAAAAAAAByQFFhQcyYUpE4n81GzLy/MrLZbIqtoG0wnAMAAAAAAECOGDekR0yo6JU4/+zLb8T9f1ybYiNoGwznAAAAAAAAkEOmn1Ue7QqTz4Bfn7s0du6uT7ERtH6GcwAAAAAAAMghA7t3jIs+MChx/rXqXfG9BS+m2AhaP8M5AAAAAAAA5JhPnzIkenQqSZz/7uMvxmtbdqbYCFo3wzkAAAAAAADkmE4lRfHvZwxLnN+1pyFufGhZio2gdTOcAwAAAAAAQA7655H94n19yxLnf7nktVj08uYUG0HrZTgHAAAAAACAHFRQkIkZUyoO6hrX3l8ZDQ3ZlBpB62U4BwAAAAAAgBx1/OHdYsrRhyXO//GV6vj54ldTbAStk+EcAAAAAAAActhVE4dHaXHyWfDGh5bFttq6FBtB62M4BwAAAAAAgBzWt2v7+ORJgxPnX99aG7f/+oUUG0HrYzgHAAAAAACAHHfpB4+IPmWlifPfX7g6qjbtSLERtC6GcwAAAAAAAMhxHdoVxVUThyfO765viK/NXZpiI2hdDOcAAAAAAACQBz589GFx3ICuifMPPb8unnpxY3qFoBUxnAMAAAAAAEAeyGQycc2Uow7qGjPvr4z6hmxKjaD1MJwDAAAAAABAnji6f9f4p+P6Jc4vW7c1fvz7qhQbQetgOAcAAAAAAIA88u9nDosO7QoT529+ZEVU79yTYiNoeYZzAAAAAAAAyCO9upTGZScPSZzfvH13fOuxlSk2gpZnOAcAAAAAAIA8c/EHBkX/bu0T5//rqZfixde3pdgIWpbhHAAAAAAAAPJMaXFhTJ9Unjhf15CNrz64NMVG0LIM5wAAAAAAAJCHzjiqd5xwRLfE+V8t2xC/Wb4hxUbQcgznAAAAAAAAkIcymUzMmHxUFGSSX+O6BypjT31DeqWghRjOAQAAAAAAIE9VHNYlPjZ6QOL8i69vjx89/XKKjaBlGM4BAAAAAAAgj33+9KHRubQocf7WR1fE5u27U2wEzc9wDgAAAAAAAHmse6eS+NypRybO1+yqi/87f0WKjaD5Gc4BAAAAAAAgz51/4uFxRI+OifN3PfNyLFtXk2IjaF6GcwAAAAAAAMhz7YoK4suTyxPnG7IR1z1QGdlsNsVW0HwM5wAAAAAAAECcPKxnnDT00MT5J1/YFPMr16fYCJqP4RwAAAAAAACITCYTMyaXR2FBJvE1vjp3adTW1afYCpqH4RwAAAAAAACIiIghPTvHeScMTJx/edOO+MGTL6VXCJqJ4RwAAAAAAADY64rThsYhHYoT57/9qxdiw9ZdKTaCpmc4BwAAAAAAAPYq61Ac004fmji/rbYuvvHw8hQbQdMznAMAAAAAAAD7+JfRA2JYr86J8z9d9Er8+dXqFBtB0zKcAwAAAAAAAPsoKiyIGVMqEuez2Yhr738+stlsiq2g6RjOAQAAAAAAgP2MG9IjTq/olTj/+5feiAf+uDbFRtB0DOcAAAAAAADAAU2fVB7FhZnE+a/PWxY7d9en2AiahuEcAAAAAAAAOKDDe3SMiz4wKHH+1S074z8XrEqxETQNwzkAAAAAAADwtj598pDo0akkcf67j78Ya6t3ptgI0mc4BwAAAAAAAN5W59Li+MIZQxPnd+6pjxvnLUuxEaTPcA4AAAAAAAC8o38e2T9G9O2SOP+LJa/FopffSLERpMtwDgAAAAAAALyjwoJMzJh81EFdY+b9z0dDQzalRpAuwzkAAAAAAADwrkYP6hZnvb9P4vxzr1THvYtfTbERpMdwDgAAAAAAALwnV08cHiVFySfGGx9aFttr61JsBOkwnAMAAAAAAADvSb9DOsT/OumIxPkNW2vj9t+8kGIjSIfhHAAAAAAAAHjPLv3Q4OjdpTRx/v8tXB1rNu9IsREcPMM5AAAAAAAA8J51aFcUV00cnji/u64hvjZ3aYqN4OAZzgEAAAAAAIBG+cgxh8WxA7omzs/787p4+sVN6RWCg2Q4BwAAAAAAABolk8nENVOOOqhrzHygMuobsik1goNjOAcAAAAAAAAa7Zj+XeMfj+ubOL90bU3M+f2aFBtBcoZzAAAAAAAAIJEvnjk8OrQrTJy/+ZHlUb1zT4qNIBnDOQAAAAAAAJBIry6lcdnJQxLnN23fHbc9tjLFRpCM4RwAAAAAAABI7OIPDIp+h7RPnJ/91Eux6vVtKTaCxjOcAwAAAAAAAImVFhfGlyaVJ87XNWTjqw8uTbERNJ7hHAAAAAAAADgoE0f0jjGDuiXOP7ZsQzy+4vUUG0HjGM4BAAAAAACAg5LJZGLGlIrIZJJf47oHKmNPfUN6paARDOcAAAAAAADAQTvqsLL42PEDEudf2LAt7vrtyyk2gvfOcA4AAAAAAACk4vMThkbnkqLE+f/76Mp4Y/vuFBvBe2M4BwAAAAAAAFLRo1NJfPbUIxPnq3fuif/76IoUG8F7YzgHAAAAAAAAUvOvYw+PQT06Js7f9UxVLF+3NcVG8O4M5wAAAAAAAEBq2hUVxJfPKk+cr2/IxnUPVEY2m02xFbwzwzkAAAAAAACQqlOG94zxR/ZInH/ihY3x6NINKTaCd2Y4BwAAAAAAAFKVyWRixuSKKCzIJL7G9Q9WRm1dfYqt4O0ZzgEAAAAAAIDUHdmrc5x3wsDE+Zc37YjZT76UXiF4B4ZzAAAAAAAAoElcftqR0bVDceL8bb96IV7fWptiIzgwwzkAAAAAAADQJLp2aBfTTh+aOL+tti6+8fDyFBvBgRnOAQAAAAAAgCZz7ugBMbRXp8T5nyxaE39+tTrFRrA/wzkAAAAAAADQZIoKC2LG5KMS57PZiJn3V0Y2m02xFezLcA4AAAAAAAA0qQ8c2SNOK++VOP+7lzbHg39am2Ij2JfhHAAAAAAAAGhy088qj+LCTOL8DXOXxa499Sk2gr8ynAMAAAAAAABNblCPjnHRuEGJ869u2Rn/b8GqFBvBXxnOAQAAAAAAgGbx6VOGRI9O7RLnb//Ni7GueleKjeBNhnMAAAAAAACgWXQuLY4rJwxLnN+5pz5ufGhZio3gTYZzAAAAAAAAoNl8dFT/OOqwLonz9y5+Nf5Q9UaKjcBwDgAAAAAAADSjwoJMXDPlqIO6xrX3V0ZDQzalRmA4BwAAAAAAAJrZ6EHd4qz39Umcf27NlvjFkldTbES+M5wDAAAAAAAAze6qicOjpCj5XPn1ectie21dio3IZ4ZzAAAAAAAAoNn179YhPnnSEYnzG7bWxh2/eTHFRuQzwzkAAAAAAADQIi794ODo1aUkcf4/F66KNZt3pNiIfGU4BwAAAAAAAFpEx5KiuGri8MT53XUNccO8pSk2Il8ZzgEAAAAAAIAW85Gj+8Yx/bsmzs/907r47apN6RUiLxnOAQAAAAAAgBZTUJCJa6ZUHNQ1Zt5fGfUN2ZQakY8M5wAAAAAAAECLOnbAIfGPx/ZNnK9cWxM/eXZNio3IN4ZzAAAAAAAAoMX9+5nDo31xYeL8Nx5eHjW79qTYiHxiOAcAAAAAAABaXO+y0rjs5MGJ85u2747bHluZYiPyieEcAAAAAAAAaBUuGX9E9O3aPnF+9lMvxeqN21NsRL4wnAMAAAAAAACtQmlxYXxpUnni/J76bHz1wcoUG5EvDOcAAAAAAABAqzHpfb1j9KBuifOPLt0QC1a8nmIj8oHhHAAAAAAAAGg1MplMzJhcEZlM8mtc90Bl1NU3pFeKnGc4BwAAAAAAAFqVEX3LYuqo/onzKzdsi7ueqUqxEbnOcA4AAAAAAAC0Op+fMCw6lxQlzt8yf0W8sX13io3IZYZzAAAAAAAAoNU5tHNJfObUIYnz1Tv3xK2PrkixEbnMcA4AAAAAAAC0SheMHRSDenRMnP/vZ6pixfqtKTYiVxnOAQAAAAAAgFapXVFBTJ9Unjhf35CN6x6ojGw2m2IrcpHhHAAAAAAAAGi1Ti3vGeOP7JE4v3Dlxnhs6YYUG5GLDOcAAAAAAABAq5XJZOIrkyuisCCT+BrXP1gZu+saUmxFrkk0nN9+++0xaNCgKC0tjZEjR8bChQvf8fza2tqYPn16DBw4MEpKSmLw4MExa9asvf989uzZkclk9nvt2rUrST0AAAAAAAAghwzt1Tk+MWZA4vxLm3bE7KdWp9iIXFPU2MCcOXPi8ssvj9tvvz3GjRsX3/ve92LixIlRWVkZAwYc+P9ZzznnnFi/fn3ceeedMWTIkNiwYUPU1dXtc06XLl1i+fLl+xwrLS1tbD0AAAAAAAAgB11+2tD4xZLXonrnnkT52x57If7h2H5xaOeSlJuRCxr9xPktt9wSF198cVxyySVRXl4et956a/Tv3z/uuOOOA57/0EMPxeOPPx5z586N0047LQ4//PAYPXp0jB07dp/zMplM9O7de58XAAAAAAAAQETEIR3bxbTThybOb62ti5sfWf7uJ5KXGjWc7969OxYtWhQTJkzY5/iECRPiqaeeOmDmvvvui1GjRsVNN90Uffv2jaFDh8aVV14ZO3fu3Oe8bdu2xcCBA6Nfv34xefLkWLx48Tt2qa2tjZqamn1eAAAAAAAAQO76+JgBcWTPTonzc55dE39+tTrFRuSKRg3nGzdujPr6+ujVq9c+x3v16hXr1q07YGbVqlXxxBNPxJ///Oe4995749Zbb42f/exncdlll+09Z/jw4TF79uy477774u67747S0tIYN25crFy58m273HDDDVFWVrb31b9//8Z8FAAAAAAAAKCNKSosiK9Mrkicz2YjZj5QGdlsNsVW5IJGf1V7xJtfq/63stnsfsfe0tDQEJlMJu66664YPXp0TJo0KW655ZaYPXv23qfOTzjhhPjEJz4RRx99dIwfPz5+8pOfxNChQ+O222572w5XX311VFdX732tWbMmyUcBAAAAAAAA2pCThh4ap5X3TJz/3erNMfdPB34omPzVqOG8R48eUVhYuN/T5Rs2bNjvKfS39OnTJ/r27RtlZWV7j5WXl0c2m41XXnnlwKUKCuL4449/xyfOS0pKokuXLvu8AAAAAAAAgNw3/ayKKC488IO978XX5i6NXXvqU2xEW9eo4bxdu3YxcuTImD9//j7H58+fH2PHjj1gZty4cfHaa6/Ftm3b9h5bsWJFFBQURL9+/Q6YyWazsWTJkujTp09j6gEAAAAAAAB5YFCPjnHhuEGJ869u2RnfX7gqxUa0dY3+qvZp06bF97///Zg1a1YsXbo0rrjiiqiqqopLL700It78CvXzzz9/7/nnnntudO/ePS688MKorKyMBQsWxBe+8IW46KKLon379hERce2118bDDz8cq1atiiVLlsTFF18cS5Ys2XtNAAAAAAAAgL/16VOGRPeO7RLnv/PrF2Nd9a4UG9GWNXo4nzp1atx6660xc+bMOOaYY2LBggUxd+7cGDhwYERErF27Nqqqqvae36lTp5g/f35s2bIlRo0aFR//+MdjypQp8a1vfWvvOVu2bIlPfvKTUV5eHhMmTIhXX301FixYEKNHj07hIwIAAAAAAAC5pktpcVx5xrDE+Z176uOmh5al2Ii2LJPNZrMtXSINNTU1UVZWFtXV1X7vHAAAAAAAAPJAfUM2ptz2RFSurUl8jXs/NTaOHXBIiq1oLRqzITf6iXMAAAAAAACA1qCwIBPXTKk4qGtce39lNDTkxLPGHATDOQAAAAAAANBmjTmie0x6X+/E+SVrtsQvn3s1xUa0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1dVx/vnnx6mnntpMTQFyS5L77znnnBOPPfZY3HnnnbF8+fK4++67Y/jw4c3YGiA3NPYe/MQTT8T5558fF198cTz//PPx05/+NH7/+9/HJZdc0szNAdq27du3x9FHHx3f/va339P5NriWk8lms9mWLkHLGzNmTBx33HFxxx137D1WXl4eZ599dtxwww37nf/FL34x7rvvvli6dOneY5deemk899xz8fTTTzdLZ4Bc0Nj774EcddRRMXXq1JgxY0ZT1QTIOUnvvx/72MfiyCOPjMLCwvjFL34RS5YsaYa2ALmjsfffhx56KD72sY/FqlWrolu3bs1ZFSDnNPYe/I1vfCPuuOOOePHFF/ceu+222+Kmm26KNWvWNEtngFyTyWTi3nvvjbPPPvttz7HBtRxPnBO7d++ORYsWxYQJE/Y5PmHChHjqqacOmHn66af3O/+MM86IZ599Nvbs2dNkXQFySZL7799raGiIrVu3+h8RARoh6f33Bz/4Qbz44otxzTXXNHVFgJyU5P573333xahRo+Kmm26Kvn37xtChQ+PKK6+MnTt3NkdlgJyR5B48duzYeOWVV2Lu3LmRzWZj/fr18bOf/SzOOuus5qgMkLdscC2nqKUL0PI2btwY9fX10atXr32O9+rVK9atW3fAzLp16w54fl1dXWzcuDH69OnTZH0BckWS++/fu/nmm2P79u1xzjnnNEVFgJyU5P67cuXKuOqqq2LhwoVRVOS/RgEkkeT+u2rVqnjiiSeitLQ07r333ti4cWN86lOfis2bN/udc4BGSHIPHjt2bNx1110xderU2LVrV9TV1cWHP/zhuO2225qjMkDessG1HE+cs1cmk9nnz9lsdr9j73b+gY4D8M4ae/99y9133x3/5//8n5gzZ0707NmzqeoB5Kz3ev+tr6+Pc889N6699toYOnRoc9UDyFmN+fffhoaGyGQycdddd8Xo0aNj0qRJccstt8Ts2bM9dQ6QQGPuwZWVlfHZz342ZsyYEYsWLYqHHnooVq9eHZdeemlzVAXIaza4luFRCaJHjx5RWFi4398s3LBhw35/o+UtvXv3PuD5RUVF0b179ybrCpBLktx/3zJnzpy4+OKL46c//WmcdtppTVkTIOc09v67devWePbZZ2Px4sXx6U9/OiLeHHKy2WwUFRXFI488EqecckqzdAdoy5L8+2+fPn2ib9++UVZWtvdYeXl5ZLPZeOWVV+LII49s0s4AuSLJPfiGG26IcePGxRe+8IWIiHj/+98fHTt2jPHjx8f111/viUeAJmKDazmeOCfatWsXI0eOjPnz5+9zfP78+TF27NgDZk488cT9zn/kkUdi1KhRUVxc3GRdAXJJkvtvxJtPml9wwQXxP//zP35XDCCBxt5/u3TpEn/6059iyZIle1+XXnppDBs2LJYsWRJjxoxpruoAbVqSf/8dN25cvPbaa7Ft27a9x1asWBEFBQXRr1+/Ju0LkEuS3IN37NgRBQX7TgiFhYUR8dcnHwFInw2u5RjOiYiIadOmxfe///2YNWtWLF26NK644oqoqqra+7U7V199dZx//vl7z7/00kvj5ZdfjmnTpsXSpUtj1qxZceedd8aVV17ZUh8BoE1q7P337rvvjvPPPz9uvvnmOOGEE2LdunWxbt26qK6ubqmPANAmNeb+W1BQECNGjNjn1bNnzygtLY0RI0ZEx44dW/KjALQpjf3333PPPTe6d+8eF154YVRWVsaCBQviC1/4Qlx00UXRvn37lvoYAG1SY+/BU6ZMiZ///Odxxx13xKpVq+LJJ5+Mz372szF69Og47LDDWupjALQ527Zt2/sX8SMiVq9eHUuWLImqqqqIsMG1Jr6qnYiImDp1amzatClmzpwZa9eujREjRsTcuXNj4MCBERGxdu3avf8BjogYNGhQzJ07N6644or4zne+E4cddlh861vfin/6p39qqY8A0CY19v77ve99L+rq6uKyyy6Lyy67bO/xf/3Xf43Zs2c3d32ANqux918A0tHY+2+nTp1i/vz58ZnPfCZGjRoV3bt3j3POOSeuv/76lvoIAG1WY+/BF1xwQWzdujW+/e1vx+c///no2rVrnHLKKXHjjTe21EcAaJOeffbZOPnkk/f+edq0aRHx1/9N1wbXemSyvlMFAAAAAAAAgDzmq9oBAAAAAAAAyGuGcwAAAAAAAADymuEcAAAAAAAAgLxmOAcAAAAAAAAgrxnOAQAAAAAAAMhrhnMAAAAAAAAA8prhHAAAAAAAAIC8ZjgHAAAAAAAAIK8ZzgEAAAAAAADIa4ZzAAAAAAAAAPKa4RwAAAAAAACAvGY4BwAAAAAAACCv/X8Pc1wdTDWLDgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 2500x1200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "probs = 1-np.array([0, 0.25,0.5, 0.75, 1])\n",
    "cinfoms = np.array([0.6170402631461114, 0.9481972968958017,0.9594811308033679,  0.9549277881791858, 0.9653385243211565])\n",
    "\n",
    "plt.figure(figsize = (25,12))\n",
    "plt.scatter(probs, cinfoms, s= 500)\n",
    "\n",
    "plt.plot(probs, cinfoms, lw = 10)\n",
    "plt.ylim([0.6, 1])"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "modularise",
   "language": "python",
   "name": "modularise"
  },
  "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
