{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "36615d92",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:00.349646Z",
     "iopub.status.busy": "2025-09-24T06:29:00.349388Z",
     "iopub.status.idle": "2025-09-24T06:29:00.355799Z",
     "shell.execute_reply": "2025-09-24T06:29:00.355019Z"
    }
   },
   "outputs": [],
   "source": [
    "import platform\n",
    "if 'mac' in platform.platform():\n",
    "    BASE_DIR = \"/Users/USER/vrtopc/\"\n",
    "    DATA_DIR = \"/media/data/vrtopc\"\n",
    "else:\n",
    "    BASE_DIR = \"/home/USER/vr_to_pc/\"\n",
    "    DATA_DIR = \"/media/data/vrtopc\"\n",
    "\n",
    "import sys\n",
    "sys.path.append(BASE_DIR)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "006da939",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:00.357971Z",
     "iopub.status.busy": "2025-09-24T06:29:00.357668Z",
     "iopub.status.idle": "2025-09-24T06:29:00.359941Z",
     "shell.execute_reply": "2025-09-24T06:29:00.359560Z"
    }
   },
   "outputs": [],
   "source": [
    "POS_DECODING_PERC_TRAIN = 0.5\n",
    "\n",
    "LABELS_DEV = ['crawl', 'walk', 'run', 'adult']\n",
    "\n",
    "LABELS_ROC = ['', '2s', '2.5s', '3s']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a095043b",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1837f19e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:00.361589Z",
     "iopub.status.busy": "2025-09-24T06:29:00.361459Z",
     "iopub.status.idle": "2025-09-24T06:29:01.902889Z",
     "shell.execute_reply": "2025-09-24T06:29:01.901764Z"
    }
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "DEVICE = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "from utils.metrics import get_spatial_correlation\n",
    "\n",
    "import numpy as np\n",
    "import scipy\n",
    "import pandas as pd\n",
    "import os\n",
    "import copy\n",
    "import re\n",
    "import yaml\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8012c7a5",
   "metadata": {},
   "source": [
    "# Processed data for the Science and Muessig papers"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba984e24",
   "metadata": {},
   "source": [
    "### Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "97e4bf9d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:01.911901Z",
     "iopub.status.busy": "2025-09-24T06:29:01.911441Z",
     "iopub.status.idle": "2025-09-24T06:29:02.468839Z",
     "shell.execute_reply": "2025-09-24T06:29:02.468251Z"
    }
   },
   "outputs": [],
   "source": [
    "from utils.spatial_units import RateMaps, PolarMaps\n",
    "\n",
    "N_SAMPLES_POS = RateMaps.N_SAMPLES_POS\n",
    "PLACE_SI_TH = RateMaps.PLACE_SI_TH\n",
    "\n",
    "N_SAMPLES_THET = PolarMaps.N_SAMPLES_THET\n",
    "HD_SI_TH = PolarMaps.HD_SI_TH\n",
    "HD_RVL_TH = PolarMaps.HD_RVL_TH\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b001642f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:02.471282Z",
     "iopub.status.busy": "2025-09-24T06:29:02.471109Z",
     "iopub.status.idle": "2025-09-24T06:29:02.474738Z",
     "shell.execute_reply": "2025-09-24T06:29:02.473848Z"
    }
   },
   "outputs": [],
   "source": [
    "edge_n_bins = 4\n",
    "\n",
    "ONLY_2ND_TRIAL = True\n",
    "\n",
    "AGES_TO_REMOVE = list(range(26, 32 +1))\n",
    "\n",
    "SAVE_PLOTS = False\n",
    "SAVE_DIR = None"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e8f8959a",
   "metadata": {},
   "source": [
    "### Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fa366d91",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:02.476982Z",
     "iopub.status.busy": "2025-09-24T06:29:02.476362Z",
     "iopub.status.idle": "2025-09-24T06:29:06.995033Z",
     "shell.execute_reply": "2025-09-24T06:29:06.993720Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['r101_p20', 'r104_p26', 'r112_p40', 'r115_p24', 'r118_p24']"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ratnames_science = []\n",
    "ratnames_muessig = []\n",
    "\n",
    "data_dir = os.path.join(DATA_DIR, 'real_data', 'science2010_data_struct')\n",
    "data = {}\n",
    "for file in os.listdir(data_dir):\n",
    "    if file.endswith('.mat'):\n",
    "        name = file.split('.')[0].lower()\n",
    "        if 'shuffled' in name:\n",
    "            name += '_science2010'\n",
    "        else:\n",
    "            ratnames_science.append(name)\n",
    "        data[name] = scipy.io.loadmat(os.path.join(data_dir, file))\n",
    "\n",
    "data_dir = os.path.join(DATA_DIR, 'real_data', 'muessig_data_struct')\n",
    "for file in os.listdir(data_dir):\n",
    "    if file.endswith('.mat'):\n",
    "        name = file.split('.')[0].lower()\n",
    "        if 'shuffled' in name:\n",
    "            name += '_muessig'\n",
    "        else:\n",
    "            ratnames_muessig.append(name)\n",
    "            \n",
    "        if name in data.keys():\n",
    "            raise ValueError(f\"Duplicate file name: {name}\")\n",
    "        data[name] = scipy.io.loadmat(os.path.join(data_dir, file))\n",
    "\n",
    "sorted(list(data.keys()))[:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "13b5f602",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:06.996717Z",
     "iopub.status.busy": "2025-09-24T06:29:06.996599Z",
     "iopub.status.idle": "2025-09-24T06:29:07.159591Z",
     "shell.execute_reply": "2025-09-24T06:29:07.158566Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "r1308_d4\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1343_d4\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p23\n",
      "\t1 trial(s)\n",
      "\n",
      "r1343_d1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p28\n",
      "\t1 trial(s)\n",
      "\n",
      "r1333_d1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1477_p29\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1637_p23\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p23\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p27\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1515_p23\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p26\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1308_d1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p16_1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p25\n",
      "\t1 trial(s)\n",
      "\n",
      "r1333_d2\n",
      "\t1 trial(s)\n",
      "\n",
      "r1628_p22_ca1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1515_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p24\n",
      "\t1 trial(s)\n",
      "\n",
      "r1474_p25\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p16_2\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "shuffled_metrics_science2010\n",
      "File name shuffled_metrics_science2010 does not start with 'r', skipping\n",
      "shuffled_metrics_adult_science2010\n",
      "File name shuffled_metrics_adult_science2010 does not start with 'r', skipping\n",
      "r1588_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p24\n",
      "\t1 trial(s)\n",
      "\n",
      "r1546_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1490_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1590_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1474_p27\n",
      "\t1 trial(s)\n",
      "\n",
      "r1546_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1526_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r1498_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1262_d1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1637_p24\n",
      "\t0 trial(s)\n",
      "\n",
      "r1546_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1628_p24_ca1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1512_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1515_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p23_2\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1552_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1515_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1262_d3\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p23_1\n",
      "\t1 trial(s)\n",
      "\n",
      "r1588_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1589_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r1546_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r732_p26\n",
      "\t0 trial(s)\n",
      "\n",
      "r572_p20\n",
      "\t0 trial(s)\n",
      "\n",
      "r1783_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1776_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r14_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1776_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r67_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r379_p28\n",
      "\t1 trial(s)\n",
      "\n",
      "r98_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r44_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r711_p22\n",
      "\t0 trial(s)\n",
      "\n",
      "r118_p26\n",
      "\t1 trial(s)\n",
      "\n",
      "r716_p26\n",
      "\t0 trial(s)\n",
      "\n",
      "r1783_p15\n",
      "\t1 trial(s)\n",
      "\n",
      "r732_p31\n",
      "\t0 trial(s)\n",
      "\n",
      "r739_p30\n",
      "\t0 trial(s)\n",
      "\n",
      "r566_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r378_p30\n",
      "\t1 trial(s)\n",
      "\n",
      "r72_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r66_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r663_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r66_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p15\n",
      "\t1 trial(s)\n",
      "\n",
      "r572_p22\n",
      "\t0 trial(s)\n",
      "\n",
      "r1771_p14\n",
      "\t1 trial(s)\n",
      "\n",
      "r1917_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r631_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r573_p20\n",
      "\t0 trial(s)\n",
      "\n",
      "r596_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r86_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r733_p28\n",
      "\t0 trial(s)\n",
      "\n",
      "r1776_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r574_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r85_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r129_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r586_p24\n",
      "\t0 trial(s)\n",
      "\n",
      "r27_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r710_p22\n",
      "\t0 trial(s)\n",
      "\n",
      "r97_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r378_p29\n",
      "\t1 trial(s)\n",
      "\n",
      "r724_p25\n",
      "\t0 trial(s)\n",
      "\n",
      "r739_p29\n",
      "\t0 trial(s)\n",
      "\n",
      "r65_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r72_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r65_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r97_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r731_p30\n",
      "\t0 trial(s)\n",
      "\n",
      "r28_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r66_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r573_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r86_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r678_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r579_p22\n",
      "\t0 trial(s)\n",
      "\n",
      "r86_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r659_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r98_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r661_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r716_p30\n",
      "\t0 trial(s)\n",
      "\n",
      "r28_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r98_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r631_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r76_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r14_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r713_p29\n",
      "\t0 trial(s)\n",
      "\n",
      "r710_p21\n",
      "\t0 trial(s)\n",
      "\n",
      "r1776_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r67_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r45_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r474_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r738_p26\n",
      "\t0 trial(s)\n",
      "\n",
      "r726_p24\n",
      "\t0 trial(s)\n",
      "\n",
      "r14_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r658_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r1919_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r4_p15\n",
      "\t1 trial(s)\n",
      "\n",
      "r115_p24\n",
      "\t1 trial(s)\n",
      "\n",
      "r378_p27\n",
      "\t1 trial(s)\n",
      "\n",
      "r631_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r13_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r73_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "shuffled_metrics_muessig\n",
      "File name shuffled_metrics_muessig does not start with 'r', skipping\n",
      "r97_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1776_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r379_p26\n",
      "\t1 trial(s)\n",
      "\n",
      "r87_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r73_p24\n",
      "\t1 trial(s)\n",
      "\n",
      "r572_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r97_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1783_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r1770_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r71_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r87_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r85_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1771_p17\n",
      "\t1 trial(s)\n",
      "\n",
      "r574_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r75_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r574_p20\n",
      "\t0 trial(s)\n",
      "\n",
      "r15_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r87_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r715_p27\n",
      "\t0 trial(s)\n",
      "\n",
      "r731_p32\n",
      "\t0 trial(s)\n",
      "\n",
      "r1770_p14\n",
      "\t1 trial(s)\n",
      "\n",
      "r65_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r96_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r96_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r1843_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r1783_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r1771_p16\n",
      "\t1 trial(s)\n",
      "\n",
      "r739_p31\n",
      "\t0 trial(s)\n",
      "\n",
      "r710_p20\n",
      "\t0 trial(s)\n",
      "\n",
      "r566_p25\n",
      "\t1 trial(s)\n",
      "\n",
      "r101_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r737_p26\n",
      "\t0 trial(s)\n",
      "\n",
      "r596_p23\n",
      "\t1 trial(s)\n",
      "\n",
      "r1776_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r4_p14\n",
      "\t1 trial(s)\n",
      "\n",
      "r118_p25\n",
      "\t1 trial(s)\n",
      "\n",
      "r716_p25\n",
      "\t0 trial(s)\n",
      "\n",
      "r737_p25\n",
      "\t0 trial(s)\n",
      "\n",
      "r14_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r1919_p15\n",
      "\t1 trial(s)\n",
      "\n",
      "r86_p22\n",
      "\t1 trial(s)\n",
      "\n",
      "r733_p27\n",
      "\t0 trial(s)\n",
      "\n",
      "r659_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1919_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r673_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r738_p27\n",
      "\t0 trial(s)\n",
      "\n",
      "r96_p18\n",
      "\t1 trial(s)\n",
      "\n",
      "r118_p27\n",
      "\t1 trial(s)\n",
      "\n",
      "r711_p23\n",
      "\t0 trial(s)\n",
      "\n",
      "r1783_p19\n",
      "\t1 trial(s)\n",
      "\n",
      "r104_p26\n",
      "\t1 trial(s)\n",
      "\n",
      "r32_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r2_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r86_p21\n",
      "\t1 trial(s)\n",
      "\n",
      "r1776_p15\n",
      "\t1 trial(s)\n",
      "\n",
      "r98_p20\n",
      "\t1 trial(s)\n",
      "\n",
      "r112_p40\n",
      "\t1 trial(s)\n",
      "\n",
      "r118_p24\n",
      "\t1 trial(s)\n",
      "\n",
      "r574_p19\n",
      "\t0 trial(s)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "def get(x):\n",
    "    return x[0][0]\n",
    "\n",
    "data_dict = {}\n",
    "ratnames_old = []\n",
    "\n",
    "for k in data.keys():\n",
    "    print(k)\n",
    "\n",
    "    if not k.startswith('r'):\n",
    "        print(f\"File name {k} does not start with 'r', skipping\")\n",
    "        continue\n",
    "\n",
    "    ratname = k\n",
    "    \n",
    "    if ratname not in data_dict.keys():\n",
    "        data_dict[ratname] = {}\n",
    "    \n",
    "    d = get(data[k]['tmpS'])\n",
    "    d_keys = list(d.dtype.names)\n",
    "\n",
    "    dataset = d[d_keys.index('dataset')][0].split('_')[-1]\n",
    "    ratnames_old.append(f\"{ratname}_{dataset}\")\n",
    "\n",
    "    # sample rate is always 50 Hz\n",
    "    ages = d[d_keys.index('age')][0] # age 40 denotes adult\n",
    "    ages = [a if a<100 else 40 for a in ages]\n",
    "\n",
    "    sample_rates = d[d_keys.index('sampleRate')][0]\n",
    "    env_types = d[d_keys.index('envType')][0]\n",
    "    ppm = d[d_keys.index('ppm')][0]\n",
    "    spike_times = d[d_keys.index('spikeTimes')][0]\n",
    "    is_cs_neuron = d[d_keys.index('isCSNeuron')][0]\n",
    "    has_min_freq = d[d_keys.index('hasMinFreq')][0]\n",
    "    pos = d[d_keys.index('positions')][0]\n",
    "    hd = d[d_keys.index('directions')][0] # degrees\n",
    "    speed = d[d_keys.index('speed')][0] # cm/s\n",
    "\n",
    "    rate_maps = d[d_keys.index('rateMaps')][0]\n",
    "    pos_occ = d[d_keys.index('posOccMaps')][0]\n",
    "    si = d[d_keys.index('SI')][0]\n",
    "    rate_maps_corr = d[d_keys.index('corrRateMaps')][0]\n",
    "    si_corr = d[d_keys.index('SICorr')][0]\n",
    "    rate_maps_hd8 = d[d_keys.index('rateMapsHD8')][0]\n",
    "    rate_maps_hd4 = d[d_keys.index('rateMapsHD4')][0]\n",
    "    \n",
    "    polar_maps = d[d_keys.index('polarMaps')][0]\n",
    "    si_pm = d[d_keys.index('dirSI')][0]\n",
    "    rvl = d[d_keys.index('rvLength')][0]\n",
    "    hd_occ = d[d_keys.index('dirOccMaps')][0]\n",
    "    polar_maps_corr = d[d_keys.index('corrPolarMaps')][0]\n",
    "    si_pm_corr = d[d_keys.index('dirSICorr')][0]\n",
    "    rvl_corr = d[d_keys.index('rvLengthCorr')][0]\n",
    "    polar_maps_pred = d[d_keys.index('predPolarMaps')][0]\n",
    "    dis_ratios = d[d_keys.index('disRatios')][0]\n",
    "\n",
    "    # there are always max 3 trials per day\n",
    "    n_trials = 0\n",
    "    for trial_n in range(len(ages)):\n",
    "        if ONLY_2ND_TRIAL and (trial_n != 1) : continue # keep second trial\n",
    "\n",
    "        rms = rate_maps[trial_n]\n",
    "        sis = si[trial_n]\n",
    "        rms_corr = rate_maps_corr[trial_n]\n",
    "        sis_corr = si_corr[trial_n]\n",
    "        rms_hd8 = rate_maps_hd8[trial_n]\n",
    "        rms_hd4 = rate_maps_hd4[trial_n]\n",
    "\n",
    "        pms = polar_maps[trial_n]\n",
    "        sis_pm = si_pm[trial_n]\n",
    "        rvls = rvl[trial_n]\n",
    "        pms_corr = polar_maps_corr[trial_n]\n",
    "        sis_pm_corr = si_pm_corr[trial_n]\n",
    "        rvls_corr = rvl_corr[trial_n]\n",
    "        drs = dis_ratios[trial_n]\n",
    "        pms_pred = polar_maps_pred[trial_n]\n",
    "        if rms.shape[-1] == 0 or pms.shape[-1] == 0:\n",
    "            print(f\"Skipping trial {trial_n} because rate maps or polar maps are empty\")\n",
    "            continue\n",
    "\n",
    "        t = {}\n",
    "        age = ages[trial_n]\n",
    "        env = env_types[trial_n][0]\n",
    "        p = pos[trial_n]\n",
    "    \n",
    "        if np.isnan(age) and (len(env) == 0) and (p.shape[-1] == 0):\n",
    "            continue\n",
    "        n_trials += 1\n",
    "\n",
    "        age = int(age)\n",
    "        if age not in data_dict[ratname].keys():\n",
    "            data_dict[ratname][age] = {}\n",
    "            data_dict[ratname][age]['trials'] = []\n",
    "\n",
    "        t['name'] = n_trials\n",
    "        t['environment'] = env\n",
    "        t['ppm'] = ppm\n",
    "        t['sample_rate'] = sample_rates[trial_n] # Hz\n",
    "        t['positions'] = p\n",
    "        t['x'] = p[:,0]\n",
    "        t['y'] = p[:,1]\n",
    "        if ratname in ratnames_science:\n",
    "            t['spike_times'] = spike_times[trial_n][0]\n",
    "            t['is_cs_neuron'] = is_cs_neuron[trial_n][0]\n",
    "            t['has_min_freq'] = has_min_freq[trial_n][0]\n",
    "        else:\n",
    "            t['spike_times'] = spike_times[trial_n].squeeze() if len(spike_times[trial_n])>1 else spike_times[trial_n][0]\n",
    "            t['is_cs_neuron'] = is_cs_neuron[trial_n].squeeze() if len(is_cs_neuron[trial_n])>1 else is_cs_neuron[trial_n][0]\n",
    "            t['has_min_freq'] = has_min_freq[trial_n].squeeze() if len(has_min_freq[trial_n])>1 else has_min_freq[trial_n][0]\n",
    "\n",
    "        t['speed'] = speed[trial_n].squeeze()/100 # m/s\n",
    "        t['hd'] = hd[trial_n].squeeze()\n",
    "        t['duration'] = len(t['x'])/t['sample_rate']\n",
    "\n",
    "        # convert to (n_units, n_bins, n_bins)\n",
    "        t['rate_maps'] = np.array([rms[idx][0] for idx in range(len(rms))])\n",
    "        t['si'] = np.array([sis[idx][0] for idx in range(len(sis))])\n",
    "        t['rate_maps_corr'] = np.array([rms_corr[idx][0] for idx in range(len(rms_corr))])\n",
    "        t['si_corr'] = np.array([sis_corr[idx][0] for idx in range(len(sis_corr))])\n",
    "\n",
    "        rms_hd_np8 = np.zeros((t['rate_maps'].shape[0], 8, t['rate_maps'].shape[-1], t['rate_maps'].shape[-1]))\n",
    "        rms_hd_np4 = np.zeros((t['rate_maps'].shape[0], 4, t['rate_maps'].shape[-1], t['rate_maps'].shape[-1]))\n",
    "        for j in range(8):\n",
    "            if j < 4:\n",
    "                rms_hd_np4[:, j, ...] = np.array(\n",
    "                    [get(rms_hd4[idx])[j] for idx in range(len(rms_hd4))]\n",
    "                )\n",
    "            rms_hd_np8[:, j, ...] = np.array(\n",
    "                [get(rms_hd8[idx])[j] for idx in range(len(rms_hd8))]\n",
    "            )\n",
    "        # convert to (n_units, 8, n_bins, n_bins)\n",
    "        t['rate_maps_hd8'] = rms_hd_np8\n",
    "        t['rate_maps_hd4'] = rms_hd_np4\n",
    "\n",
    "        # convert to (n_units, n_bins)\n",
    "        t['polar_maps'] = np.array([pms[idx][0] for idx in range(len(pms))])[..., 0]\n",
    "        t['si_pm'] = np.array([sis_pm[idx][0] for idx in range(len(sis_pm))])\n",
    "        t['rvl'] = np.array([rvls[idx][0] for idx in range(len(rvls))])\n",
    "        t['polar_maps_corr'] = np.array([pms_corr[idx][0] for idx in range(len(pms_corr))])[..., 0]\n",
    "        t['si_pm_corr'] = np.array([sis_pm_corr[idx][0] for idx in range(len(sis_pm_corr))])\n",
    "        t['rvl_corr'] = np.array([rvls_corr[idx][0] for idx in range(len(rvls_corr))])\n",
    "\n",
    "        t['polar_maps_pred'] = np.array([pms_pred[idx][0] for idx in range(len(pms_pred))])[..., 0]\n",
    "        t['dis_ratios'] = np.array(drs[:,0])\n",
    "\n",
    "        if t['rate_maps'].shape[0] != t['polar_maps'].shape[0]:\n",
    "            raise ValueError(f\"Rate maps ({t['rate_maps'].shape}) and polar maps ({t['polar_maps'].shape}) have different number of units\")\n",
    "\n",
    "        t['pos_occ'] = get(pos_occ[trial_n])\n",
    "        t['hd_occ'] = np.array(hd_occ[trial_n][:,0])\n",
    "\n",
    "        data_dict[ratname][age]['trials'].append(t)\n",
    "    print(f\"\\t{n_trials} trial(s)\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5b7778a9",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:07.161613Z",
     "iopub.status.busy": "2025-09-24T06:29:07.161486Z",
     "iopub.status.idle": "2025-09-24T06:29:07.171433Z",
     "shell.execute_reply": "2025-09-24T06:29:07.171040Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------------------\n",
      "r1308_d4\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1343_d4\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p23\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1343_d1\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p28\n",
      "ages [28]\n",
      "\n",
      "--------------------------------\n",
      "r1333_d1\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1477_p29\n",
      "ages [29]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1637_p23\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p23\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p27\n",
      "ages [27]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1515_p23\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p26\n",
      "ages [26]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1308_d1\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p16_1\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p25\n",
      "ages [25]\n",
      "\n",
      "--------------------------------\n",
      "r1333_d2\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1628_p22_ca1\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1515_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p24\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r1474_p25\n",
      "ages [25]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p16_2\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p24\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r1546_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1490_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1590_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1474_p27\n",
      "ages [27]\n",
      "\n",
      "--------------------------------\n",
      "r1546_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1526_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r1498_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1262_d1\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1637_p24\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1546_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1628_p24_ca1\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r1512_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1515_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p23_2\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1552_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1515_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1262_d3\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p23_1\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1588_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1589_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1546_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r732_p26\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r572_p20\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1783_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1776_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r14_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1776_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r67_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r379_p28\n",
      "ages [28]\n",
      "\n",
      "--------------------------------\n",
      "r98_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r44_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r711_p22\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r118_p26\n",
      "ages [26]\n",
      "\n",
      "--------------------------------\n",
      "r716_p26\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1783_p15\n",
      "ages [15]\n",
      "\n",
      "--------------------------------\n",
      "r732_p31\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r739_p30\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r566_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r378_p30\n",
      "ages [30]\n",
      "\n",
      "--------------------------------\n",
      "r72_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r66_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r663_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r66_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p15\n",
      "ages [15]\n",
      "\n",
      "--------------------------------\n",
      "r572_p22\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1771_p14\n",
      "ages [14]\n",
      "\n",
      "--------------------------------\n",
      "r1917_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r631_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r573_p20\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r596_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r86_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r733_p28\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1776_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r574_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r85_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r129_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r586_p24\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r27_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r710_p22\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r97_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r378_p29\n",
      "ages [29]\n",
      "\n",
      "--------------------------------\n",
      "r724_p25\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r739_p29\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r65_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r72_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r65_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r97_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r731_p30\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r28_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r66_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r573_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r86_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r678_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r579_p22\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r86_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r659_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r98_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r661_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r716_p30\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r28_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r98_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r631_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r76_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r14_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r713_p29\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r710_p21\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1776_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r67_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r45_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r474_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r738_p26\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r726_p24\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r14_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r658_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r1919_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r4_p15\n",
      "ages [15]\n",
      "\n",
      "--------------------------------\n",
      "r115_p24\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r378_p27\n",
      "ages [27]\n",
      "\n",
      "--------------------------------\n",
      "r631_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r13_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r73_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r97_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1776_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r379_p26\n",
      "ages [26]\n",
      "\n",
      "--------------------------------\n",
      "r87_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r73_p24\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r572_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r97_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1783_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r1770_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r71_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r87_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r85_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1771_p17\n",
      "ages [17]\n",
      "\n",
      "--------------------------------\n",
      "r574_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r75_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r574_p20\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r15_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r87_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r715_p27\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r731_p32\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1770_p14\n",
      "ages [14]\n",
      "\n",
      "--------------------------------\n",
      "r65_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r96_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r96_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r1843_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r1783_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r1771_p16\n",
      "ages [16]\n",
      "\n",
      "--------------------------------\n",
      "r739_p31\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r710_p20\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r566_p25\n",
      "ages [25]\n",
      "\n",
      "--------------------------------\n",
      "r101_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r737_p26\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r596_p23\n",
      "ages [23]\n",
      "\n",
      "--------------------------------\n",
      "r1776_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r4_p14\n",
      "ages [14]\n",
      "\n",
      "--------------------------------\n",
      "r118_p25\n",
      "ages [25]\n",
      "\n",
      "--------------------------------\n",
      "r716_p25\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r737_p25\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r14_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r1919_p15\n",
      "ages [15]\n",
      "\n",
      "--------------------------------\n",
      "r86_p22\n",
      "ages [22]\n",
      "\n",
      "--------------------------------\n",
      "r733_p27\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r659_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1919_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r673_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r738_p27\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r96_p18\n",
      "ages [18]\n",
      "\n",
      "--------------------------------\n",
      "r118_p27\n",
      "ages [27]\n",
      "\n",
      "--------------------------------\n",
      "r711_p23\n",
      "ages []\n",
      "\n",
      "--------------------------------\n",
      "r1783_p19\n",
      "ages [19]\n",
      "\n",
      "--------------------------------\n",
      "r104_p26\n",
      "ages [26]\n",
      "\n",
      "--------------------------------\n",
      "r32_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r2_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r86_p21\n",
      "ages [21]\n",
      "\n",
      "--------------------------------\n",
      "r1776_p15\n",
      "ages [15]\n",
      "\n",
      "--------------------------------\n",
      "r98_p20\n",
      "ages [20]\n",
      "\n",
      "--------------------------------\n",
      "r112_p40\n",
      "ages [40]\n",
      "\n",
      "--------------------------------\n",
      "r118_p24\n",
      "ages [24]\n",
      "\n",
      "--------------------------------\n",
      "r574_p19\n",
      "ages []\n",
      "\n",
      "--------------------------------\n"
     ]
    }
   ],
   "source": [
    "ages = []\n",
    "print('--------------------------------')\n",
    "for k, v in data_dict.items():\n",
    "    print(k)\n",
    "    ages_tmp = list(v.keys())\n",
    "    print('ages', ages_tmp)\n",
    "    ages += ages_tmp\n",
    "    print()\n",
    "    print('--------------------------------')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7510b433",
   "metadata": {},
   "source": [
    "### Shuffled Threshold Extraction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d1dfc34a",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:07.172548Z",
     "iopub.status.busy": "2025-09-24T06:29:07.172442Z",
     "iopub.status.idle": "2025-09-24T06:29:07.177047Z",
     "shell.execute_reply": "2025-09-24T06:29:07.176688Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "shuffled_metrics_science2010\n",
      "shuffled_metrics_adult_science2010\n",
      "shuffled_metrics_muessig\n"
     ]
    }
   ],
   "source": [
    "metrics_shuffle_th_science = {}\n",
    "metrics_shuffle_th_muessig = {}\n",
    "\n",
    "for filename in data.keys():\n",
    "    if not filename.startswith('shuffled'):\n",
    "        continue\n",
    "    print(filename)\n",
    "\n",
    "    shuffled_si = data[filename]['shuffledSIByAge']\n",
    "    shuffled_si_pm = data[filename]['shuffledDirSIByAge']\n",
    "    shuffled_rvl = data[filename]['shuffledRVLByAge']\n",
    "    for idx in range(len(shuffled_si)):\n",
    "        for m, k in zip([shuffled_si, shuffled_si_pm, shuffled_rvl], ['SI', 'dirSI', 'rvLength']):\n",
    "            m_curr = get(m[idx][0])\n",
    "            keys = list(m_curr.dtype.names)\n",
    "            age_group = get(m_curr[keys.index('ageGroup')])\n",
    "            th = get(m_curr[keys.index(k+'Threshold')])\n",
    "\n",
    "            if 'science' in filename.lower():\n",
    "                if k not in metrics_shuffle_th_science.keys():\n",
    "                    metrics_shuffle_th_science[k] = {}\n",
    "\n",
    "                age = 14+age_group*2\n",
    "                if age != 100:\n",
    "                    metrics_shuffle_th_science[k][age] = th\n",
    "                    metrics_shuffle_th_science[k][age+1] = th\n",
    "                else : metrics_shuffle_th_science[k][40] = th\n",
    "            elif 'muessig' in filename.lower():\n",
    "                if k not in metrics_shuffle_th_muessig.keys():\n",
    "                    metrics_shuffle_th_muessig[k] = {}\n",
    "\n",
    "                age = 14+age_group*2\n",
    "                if age != 100:\n",
    "                    metrics_shuffle_th_muessig[k][age] = th\n",
    "                    metrics_shuffle_th_muessig[k][age+1] = th\n",
    "                else : metrics_shuffle_th_muessig[k][40] = th\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a1585f8e",
   "metadata": {},
   "source": [
    "### Activity Extraction\n",
    "\n",
    "A neuron is considered actually tuned to direction if its corrected polar map still passes the criterion for inclusion (RVL or KLD)\n",
    "\n",
    "and its Pearson correlation with the uncorrected polar map is higher than 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "30fdb6d0",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:07.178076Z",
     "iopub.status.busy": "2025-09-24T06:29:07.177972Z",
     "iopub.status.idle": "2025-09-24T06:29:07.180485Z",
     "shell.execute_reply": "2025-09-24T06:29:07.180182Z"
    }
   },
   "outputs": [],
   "source": [
    "def normalize_rate_maps(rate_maps):\n",
    "    # normalize rate maps\n",
    "    rate_maps_min = np.moveaxis(\n",
    "        np.tile(np.nanmin(rate_maps, axis=(1,2)), (N_SAMPLES_POS, N_SAMPLES_POS, 1)), -1, 0\n",
    "    )\n",
    "    rate_maps_max = np.moveaxis(\n",
    "        np.tile(np.nanmax(rate_maps, axis=(1,2)), (N_SAMPLES_POS, N_SAMPLES_POS, 1)), -1, 0\n",
    "    )\n",
    "    rate_maps = (\n",
    "        (rate_maps - rate_maps_min) / (rate_maps_max - rate_maps_min)\n",
    "    )\n",
    "    return rate_maps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4aa86286",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:07.181538Z",
     "iopub.status.busy": "2025-09-24T06:29:07.181430Z",
     "iopub.status.idle": "2025-09-24T06:29:20.431142Z",
     "shell.execute_reply": "2025-09-24T06:29:20.430269Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r101_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r104_p26\n",
      "\tAge 26 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r112_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r115_p24\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r118_p24\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r118_p25\n",
      "\tAge 25\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r118_p26\n",
      "\tAge 26 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r118_p27\n",
      "\tAge 27 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1262_d1\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1262_d3\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r129_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1308_d1\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1308_d4\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1333_d1\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1333_d2\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (28, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (28, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1343_d1\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1343_d4\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r13_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1474_p25\n",
      "\tAge 25\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (3, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (3, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1474_p27\n",
      "\tAge 27 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1477_p29\n",
      "\tAge 29 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1490_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (6, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (6, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1498_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r14_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r14_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (24, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (24, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r14_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (26, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (26, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r14_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (33, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (33, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1512_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1515_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1515_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1515_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1515_p23\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1526_p23\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1546_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (2, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (2, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1546_p18\n",
      "\tAge 18\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t(n_cells, n_samples_pos, n_samples_pos): (17, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (17, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1546_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (30, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (30, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1546_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p16_1\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (1, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (1, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p16_2\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (36, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (36, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (23, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (23, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (17, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (17, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1552_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (1, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (1, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p23_1\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (6, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (6, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p23_2\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1588_p24\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (2, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (2, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p23\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (15, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (15, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p24\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p25\n",
      "\tAge 25\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (6, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (6, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p26\n",
      "\tAge 26 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p27\n",
      "\tAge 27 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1589_p28\n",
      "\tAge 28 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1590_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (1, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (1, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r15_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (22, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (22, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1628_p22_ca1\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1628_p24_ca1\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (3, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (3, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1637_p23\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (1, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (1, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1637_p24\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p14\n",
      "\tAge 14\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (1, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (1, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p15\n",
      "\tAge 15\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (15, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (15, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1770_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (2, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (2, 60)\n",
      "\tSkipping trial because all rate maps are uniform\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1771_p14\n",
      "\tAge 14\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (4, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (4, 60)\n",
      "\tSkipping trial because all rate maps are uniform\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1771_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1771_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p15\n",
      "\tAge 15\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (17, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (17, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (7, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (7, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1776_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (3, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (3, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1783_p15\n",
      "\tAge 15\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1783_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1783_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1783_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1783_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (3, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (3, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1843_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1917_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1919_p15\n",
      "\tAge 15\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1919_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1919_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r27_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r28_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r28_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (20, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (20, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r2_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (9, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (9, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r32_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (22, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (22, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r378_p27\n",
      "\tAge 27 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r378_p29\n",
      "\tAge 29 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r378_p30\n",
      "\tAge 30 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r379_p26\n",
      "\tAge 26 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r379_p28\n",
      "\tAge 28 in ages to remove, skipping\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r44_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r45_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r474_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r4_p14\n",
      "\tAge 14\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (46, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (46, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r4_p15\n",
      "\tAge 15\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r566_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (52, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (52, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r566_p25\n",
      "\tAge 25\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (15, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (15, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r572_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (65, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (65, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r572_p20\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r572_p22\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r573_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (29, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (29, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r573_p20\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r574_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (26, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (26, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r574_p19\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r574_p20\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r574_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (29, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (29, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r579_p22\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r586_p24\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r596_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r596_p23\n",
      "\tAge 23\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r631_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (35, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (35, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r631_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (47, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (47, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r631_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (40, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (40, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r658_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (44, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (44, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r659_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (28, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (28, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r659_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (39, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (39, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r65_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r65_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r65_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (3, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (3, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r661_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (56, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (56, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r663_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (37, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (37, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r66_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r66_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r66_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r673_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (82, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (82, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r678_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (109, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (109, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r67_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (31, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (31, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r67_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r710_p20\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r710_p21\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r710_p22\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r711_p22\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r711_p23\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r713_p29\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r715_p27\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r716_p25\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r716_p26\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r716_p30\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r71_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (5, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (5, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r724_p25\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r726_p24\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r72_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r72_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (4, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (4, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r731_p30\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r731_p32\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r732_p26\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r732_p31\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r733_p27\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r733_p28\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r737_p25\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r737_p26\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r738_p26\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r738_p27\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r739_p29\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r739_p30\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r739_p31\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r73_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (13, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (13, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r73_p24\n",
      "\tAge 24\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (10, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (10, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r75_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r76_p40\n",
      "\tAge 40\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r85_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (19, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (19, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r85_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r86_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r86_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r86_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (14, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (14, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r86_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r86_p22\n",
      "\tAge 22\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (8, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (8, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r87_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r87_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r87_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (18, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (18, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r96_p16\n",
      "\tAge 16\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (22, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (22, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r96_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r96_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r97_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (15, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (15, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r97_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r97_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (16, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (16, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r97_p21\n",
      "\tAge 21\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (12, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (12, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r98_p17\n",
      "\tAge 17\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (11, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (11, 60)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r98_p18\n",
      "\tAge 18\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (25, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (25, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r98_p19\n",
      "\tAge 19\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (21, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (21, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r98_p20\n",
      "\tAge 20\n",
      "\t(n_cells, n_samples_pos, n_samples_pos): (27, 25, 25)\n",
      "\t(n_cells, N_SAMPLES_THET): (27, 60)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from utils.spatial_units import RateMaps, PolarMaps\n",
    "\n",
    "place_units = RateMaps(positions=None, env_dim=0)\n",
    "hd_units = PolarMaps(thetas=None)\n",
    "\n",
    "data_dict_age = {}\n",
    "perc_kept = []\n",
    "\n",
    "for k, v in sorted(data_dict.items()):\n",
    "    print(f\"Rat {k}\")\n",
    "    if k in ratnames_science:\n",
    "        metrics_shuffle_th = metrics_shuffle_th_science\n",
    "    elif k in ratnames_muessig:\n",
    "        metrics_shuffle_th = metrics_shuffle_th_muessig\n",
    "    else:\n",
    "        raise ValueError(f\"Rat {k} not found in science or muessig data\")\n",
    "    \n",
    "    for age in sorted(v.keys()):\n",
    "        if age in AGES_TO_REMOVE:\n",
    "            print(f\"\\tAge {age} in ages to remove, skipping\")\n",
    "            continue\n",
    "        \n",
    "        exp = v[age] # get the experiment for this rat's age\n",
    "        print(f\"\\tAge {age}\")\n",
    "        if (age in data_dict_age.keys()) and (k in data_dict_age[age].keys()):\n",
    "            print(f\"\\tSkipping because already processed\")\n",
    "            continue\n",
    "\n",
    "        if age not in data_dict_age.keys(): # initialize all dict if first exp for this age\n",
    "            data_dict_age[age] = {}\n",
    "        \n",
    "        data_dict_age[age][k] = {}\n",
    "        for k_tmp in [\n",
    "            'positions', 'hd', 'speed', 'spike_times', 'sample_rate',\n",
    "            'rate_maps', 'pos_occ', 'rate_maps_corr',\n",
    "            'si_matlab', 'si_corr_matlab', 'si_rm', 'si_rm_corr',\n",
    "            'selected_place_units', 'n_fields',\n",
    "            'single_field_dim', 'pu_flipped', 'pu_field_flipped',\n",
    "            'rate_maps_hd8', 'rate_maps_hd4',\n",
    "            'polar_maps', 'hd_occ', 'polar_maps_corr',\n",
    "            'si_pm_matlab', 'rvl_matlab', 'si_pm', 'rvl_pm', 'si_pm_corr_matlab', 'rvl_corr_matlab',\n",
    "            'rvl_pm_corr', 'rvangle_pm', 'rvangle_pm_corr',\n",
    "            'selected_hd_units', 'selected_place_hd_units',\n",
    "            'polar_maps_pred', 'dis_ratios',\n",
    "            'trial_start_idx'\n",
    "        ]:\n",
    "            data_dict_age[age][k][k_tmp] = []\n",
    "\n",
    "        rate_maps_all = []\n",
    "        polar_maps_all = []\n",
    "        indices_to_keep = None\n",
    "        trial_start_idx = 0\n",
    "        for trial in exp['trials']:\n",
    "            if trial['environment'] != 'hp' and trial['environment'] != 'fam':\n",
    "                raise ValueError(f\"\\tEnvironment is {trial['environment']} instead of hp or fam\")\n",
    "\n",
    "            rate_maps = trial['rate_maps']\n",
    "            if rate_maps.shape[1] != N_SAMPLES_POS or rate_maps.shape[2] != N_SAMPLES_POS:\n",
    "                raise ValueError(f\"\\t\\tRate maps shape is {rate_maps.shape} instead of (n_cells, {N_SAMPLES_POS}, {N_SAMPLES_POS})\")\n",
    "            rate_maps_all.append(rate_maps.copy())\n",
    "\n",
    "            si_matlab = trial['si']\n",
    "            rate_maps_corr = trial['rate_maps_corr']\n",
    "            si_corr_matlab = trial['si_corr']\n",
    "            rate_maps_hd8 = trial['rate_maps_hd8']\n",
    "            rate_maps_hd4 = trial['rate_maps_hd4']\n",
    "\n",
    "            pos_occ = trial['pos_occ']\n",
    "\n",
    "            polar_maps = trial['polar_maps']\n",
    "            if polar_maps.shape[1] != N_SAMPLES_THET:\n",
    "                raise ValueError(f\"\\t\\Polar maps shape is {polar_maps.shape} instead of (n_cells, {N_SAMPLES_THET})\")\n",
    "            polar_maps_all.append(polar_maps.copy())\n",
    "\n",
    "            si_pm_matlab = trial['si_pm']\n",
    "            rvl_matlab = trial['rvl']\n",
    "            polar_maps_corr = trial['polar_maps_corr']\n",
    "            si_pm_corr_matlab = trial['si_pm_corr']\n",
    "            rvl_corr_matlab = trial['rvl_corr']\n",
    "            polar_maps_pred = trial['polar_maps_pred']\n",
    "            dis_ratios = trial['dis_ratios']\n",
    "\n",
    "            hd_occ = trial['hd_occ']\n",
    "\n",
    "            print(f\"\\t(n_cells, n_samples_pos, n_samples_pos): {rate_maps.shape}\")\n",
    "            print(f\"\\t(n_cells, N_SAMPLES_THET): {polar_maps.shape}\")\n",
    "\n",
    "            # keep only Complex Spike neurons\n",
    "            idx_to_keep = np.logical_and(\n",
    "                trial['is_cs_neuron'] == 1, trial['has_min_freq'] == 1\n",
    "            )\n",
    "            if isinstance(idx_to_keep, np.bool) : idx_to_keep = np.array([idx_to_keep])\n",
    "            assert len(idx_to_keep) == rate_maps.shape[0]\n",
    "            idx_to_keep = np.where(idx_to_keep)[0] # convert mask to indices\n",
    "            if len(idx_to_keep) == 0:\n",
    "                print(f\"\\tSkipping trial because all rate maps are uniform\")\n",
    "                continue\n",
    "\n",
    "            positions = trial['positions']\n",
    "            hd = trial['hd'].astype(np.float64)\n",
    "            speed = trial['speed']\n",
    "            spike_times = trial['spike_times']\n",
    "            sample_rate = trial['sample_rate']\n",
    "            \n",
    "            perc_kept.append(len(idx_to_keep)/rate_maps.shape[0]*100)\n",
    "            rate_maps = rate_maps[idx_to_keep]\n",
    "            si_matlab = si_matlab[idx_to_keep]\n",
    "            rate_maps_corr = rate_maps_corr[idx_to_keep]\n",
    "            si_corr_matlab = si_corr_matlab[idx_to_keep]\n",
    "            rate_maps_hd8 = rate_maps_hd8[idx_to_keep]\n",
    "            rate_maps_hd4 = rate_maps_hd4[idx_to_keep]\n",
    "\n",
    "            polar_maps = polar_maps[idx_to_keep]\n",
    "            si_pm_matlab = si_pm_matlab[idx_to_keep]\n",
    "            rvl_matlab = rvl_matlab[idx_to_keep]\n",
    "            polar_maps_corr = polar_maps_corr[idx_to_keep]\n",
    "            si_pm_corr_matlab = si_pm_corr_matlab[idx_to_keep]\n",
    "            rvl_corr_matlab = rvl_corr_matlab[idx_to_keep]\n",
    "            polar_maps_pred = polar_maps_pred[idx_to_keep]\n",
    "            dis_ratios = dis_ratios[idx_to_keep]\n",
    "\n",
    "            if indices_to_keep is None: indices_to_keep = idx_to_keep\n",
    "            else: indices_to_keep = np.intersect1d(indices_to_keep, idx_to_keep)\n",
    "            \n",
    "            rate_maps_unnorm = rate_maps.copy()\n",
    "            rate_maps_corr_unnorm = rate_maps_corr.copy()\n",
    "            rate_maps = normalize_rate_maps(rate_maps)\n",
    "            rate_maps_corr = normalize_rate_maps(rate_maps_corr)\n",
    "            \n",
    "            si_rm = place_units.calculate_metrics(rate_maps, pos_occ)\n",
    "            si_rm_corr = place_units.calculate_metrics(rate_maps_corr, pos_occ)\n",
    "            \n",
    "            n_fields, rm_fields = place_units.rate_maps_field_detection(rate_maps, rate_maps, rate_maps)\n",
    "\n",
    "            selected_place_units = place_units.get_place_cells_indices(rate_maps, si_matlab)\n",
    "\n",
    "            if len(selected_place_units) > 0:\n",
    "                single_field_dim = np.array([\n",
    "                    np.sum(np.nansum(np.array(fields), axis=0)>0) for i, fields in enumerate(rm_fields)\n",
    "                    if fields and i in selected_place_units\n",
    "                ])\n",
    "                pu_flipped = place_units.rm_flipped(rate_maps, filter_indices=selected_place_units)\n",
    "\n",
    "                rm_fields_selected = [f for i, f in enumerate(rm_fields) if (i in selected_place_units) and n_fields[i] > 0]\n",
    "                if len(rm_fields_selected) == 0:\n",
    "                    print(f\"\\tSkipping avg rate map field because no selected fields\")\n",
    "                    continue\n",
    "                pu_field_flipped = place_units.rm_field_flipped(rm_fields_selected)\n",
    "\n",
    "                for k_tmp in ['single_field_dim', 'pu_flipped', 'pu_field_flipped']:\n",
    "                    data_dict_age[age][k][k_tmp].append(locals()[k_tmp])\n",
    "            \n",
    "            si_pm, rvl_pm, rvangle_pm = hd_units.calculate_metrics(polar_maps.copy(), hd_occ)\n",
    "            _, rvl_pm_corr, rvangle_pm_corr = hd_units.calculate_metrics(polar_maps_corr.copy(), hd_occ)\n",
    "\n",
    "            selected_hd_units = np.array([\n",
    "                idx for idx in range(polar_maps.shape[0]) if\n",
    "                (not np.isnan(si_pm_matlab[idx])) and (not np.isnan(rvl_matlab[idx])) and\n",
    "                (not np.isnan(si_pm_corr_matlab[idx])) and (not np.isnan(rvl_corr_matlab[idx])) and\n",
    "                ((si_pm_matlab[idx] > metrics_shuffle_th['dirSI'][age]) or (rvl_matlab[idx] > metrics_shuffle_th['rvLength'][age])) and\n",
    "                ((si_pm_corr_matlab[idx] > metrics_shuffle_th['dirSI'][age]) or (rvl_corr_matlab[idx] > metrics_shuffle_th['rvLength'][age])) and\n",
    "                (get_spatial_correlation(polar_maps[idx], polar_maps_corr[idx], return_pvalue=False) > 0.5)# and\n",
    "            ], dtype=np.int32)\n",
    "\n",
    "            selected_place_hd_units = np.intersect1d(selected_place_units, selected_hd_units, assume_unique=True)\n",
    "            selected_place_units = np.setdiff1d(selected_place_units, selected_place_hd_units, assume_unique=True)\n",
    "            selected_hd_units = np.setdiff1d(selected_hd_units, selected_place_hd_units, assume_unique=True)\n",
    "            \n",
    "            selected_place_units += trial_start_idx\n",
    "            selected_hd_units += trial_start_idx\n",
    "            selected_place_hd_units += trial_start_idx\n",
    "\n",
    "            for k_tmp in [\n",
    "                'positions', 'hd', 'speed', 'spike_times', 'sample_rate',\n",
    "                'rate_maps', 'rate_maps_corr', 'pos_occ',\n",
    "                'si_matlab', 'si_corr_matlab', 'si_rm', 'si_rm_corr',\n",
    "                'selected_place_units', 'n_fields',\n",
    "                'rate_maps_hd8', 'rate_maps_hd4',\n",
    "                'polar_maps', 'polar_maps_corr', 'hd_occ',\n",
    "                'si_pm_matlab', 'rvl_matlab', 'si_pm', 'rvl_pm', 'si_pm_corr_matlab', 'rvl_corr_matlab',\n",
    "                'rvl_pm_corr', 'rvangle_pm', 'rvangle_pm_corr',\n",
    "                'selected_hd_units', 'selected_place_hd_units',\n",
    "                'polar_maps_pred', 'dis_ratios',\n",
    "                'trial_start_idx'\n",
    "            ]:\n",
    "                data_dict_age[age][k][k_tmp].append(locals()[k_tmp])\n",
    "\n",
    "            trial_start_idx += len(idx_to_keep)\n",
    "\n",
    "        if trial_start_idx == 0:\n",
    "            data_dict_age[age].pop(k)\n",
    "        else:\n",
    "\n",
    "            for k_tmp in [\n",
    "                'rate_maps', 'rate_maps_corr', 'pos_occ',\n",
    "                'si_matlab', 'si_corr_matlab', 'si_rm', 'si_rm_corr',\n",
    "                'selected_place_units', 'n_fields',\n",
    "                'rate_maps_hd8', 'rate_maps_hd4',\n",
    "                'polar_maps', 'polar_maps_corr', 'hd_occ',\n",
    "                'si_pm_matlab', 'rvl_matlab', 'si_pm', 'rvl_pm', 'si_pm_corr_matlab', 'rvl_corr_matlab',\n",
    "                'rvl_pm_corr', 'rvangle_pm', 'rvangle_pm_corr',\n",
    "                'selected_hd_units', 'selected_place_hd_units',\n",
    "                'polar_maps_pred', 'dis_ratios',\n",
    "            ]:\n",
    "                try:\n",
    "                    data_dict_age[age][k][k_tmp] = np.concatenate(data_dict_age[age][k][k_tmp])\n",
    "                except ValueError as e:\n",
    "                    if \"zero-dimensional\" in str(e):\n",
    "                        data_dict_age[age][k][k_tmp] = np.array(data_dict_age[age][k][k_tmp])\n",
    "                    elif \"need at least one\" in str(e):\n",
    "                        continue\n",
    "                    else:\n",
    "                        raise e\n",
    "            \n",
    "    print(flush=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "83f11fac",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.434687Z",
     "iopub.status.busy": "2025-09-24T06:29:20.433903Z",
     "iopub.status.idle": "2025-09-24T06:29:20.436684Z",
     "shell.execute_reply": "2025-09-24T06:29:20.436372Z"
    }
   },
   "outputs": [],
   "source": [
    "ages = sorted(data_dict_age.keys())\n",
    "n_ages = len(ages)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "72528a24",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.437668Z",
     "iopub.status.busy": "2025-09-24T06:29:20.437561Z",
     "iopub.status.idle": "2025-09-24T06:29:20.448741Z",
     "shell.execute_reply": "2025-09-24T06:29:20.448415Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 14:\n",
      "\tPlace units SI: 0.607 (min 0.393)\n",
      "\tHD units RVL: 0.317 (min 0.292)\n",
      "\tHD units SI: 0.624 (min 0.539)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 15:\n",
      "\tPlace units SI: 0.619 (min 0.369)\n",
      "\tHD units RVL: 0.227 (min 0.174)\n",
      "\tHD units SI: 0.303 (min 0.237)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 16:\n",
      "\tPlace units SI: 0.814 (min 0.372)\n",
      "\tHD units RVL: 0.355 (min 0.245)\n",
      "\tHD units SI: 0.372 (min 0.208)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 17:\n",
      "\tPlace units SI: 0.662 (min 0.365)\n",
      "\tHD units RVL: 0.329 (min 0.066)\n",
      "\tHD units SI: 0.334 (min 0.113)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 18:\n",
      "\tPlace units SI: 0.657 (min 0.353)\n",
      "\tHD units RVL: 0.344 (min 0.047)\n",
      "\tHD units SI: 0.321 (min 0.134)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 19:\n",
      "\tPlace units SI: 0.745 (min 0.346)\n",
      "\tHD units RVL: 0.352 (min 0.060)\n",
      "\tHD units SI: 0.322 (min 0.146)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 20:\n",
      "\tPlace units SI: 0.747 (min 0.364)\n",
      "\tHD units RVL: 0.352 (min 0.113)\n",
      "\tHD units SI: 0.360 (min 0.139)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 21:\n",
      "\tPlace units SI: 0.753 (min 0.370)\n",
      "\tHD units RVL: 0.392 (min 0.271)\n",
      "\tHD units SI: 0.356 (min 0.133)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 22:\n",
      "\tPlace units SI: 0.783 (min 0.363)\n",
      "\tHD units RVL: 0.340 (min 0.158)\n",
      "\tHD units SI: 0.298 (min 0.131)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 23:\n",
      "\tPlace units SI: 0.779 (min 0.382)\n",
      "\tHD units RVL: 0.343 (min 0.255)\n",
      "\tHD units SI: 0.265 (min 0.144)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 24:\n",
      "\tPlace units SI: 0.883 (min 0.379)\n",
      "\tHD units RVL: 0.405 (min 0.074)\n",
      "\tHD units SI: 0.461 (min 0.240)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 25:\n",
      "\tPlace units SI: 0.947 (min 0.338)\n",
      "\tHD units RVL: 0.552 (min 0.408)\n",
      "\tHD units SI: 0.683 (min 0.358)\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Age 40:\n",
      "\tPlace units SI: 1.320 (min 0.362)\n",
      "\tHD units RVL: 0.490 (min 0.026)\n",
      "\tHD units SI: 0.571 (min 0.124)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "si_rm_selected = {}\n",
    "si_pm_selected = {}\n",
    "rvl_pm_selected = {}\n",
    "\n",
    "for age in ages:\n",
    "    for rat in data_dict_age[age].keys():\n",
    "        si_rm = data_dict_age[age][rat]['si_rm']\n",
    "        si_pm = data_dict_age[age][rat]['si_pm']\n",
    "        rvl_pm = data_dict_age[age][rat]['rvl_pm']\n",
    "\n",
    "        selected_place_units = data_dict_age[age][rat]['selected_place_units']\n",
    "        selected_hd_units = data_dict_age[age][rat]['selected_hd_units']\n",
    "        selected_place_hd_units = data_dict_age[age][rat]['selected_place_hd_units']\n",
    "\n",
    "        selected_units_rm = np.concatenate([selected_place_units, selected_place_hd_units])\n",
    "        selected_units_pm = np.concatenate([selected_hd_units, selected_place_hd_units])\n",
    "\n",
    "        if age not in si_rm_selected.keys():\n",
    "            si_rm_selected[age] = []\n",
    "            si_pm_selected[age] = []\n",
    "            rvl_pm_selected[age] = []\n",
    "        si_rm_selected[age].append(si_rm[selected_units_rm])\n",
    "        si_pm_selected[age].append(si_pm[selected_units_pm])\n",
    "        rvl_pm_selected[age].append(rvl_pm[selected_units_pm])\n",
    "\n",
    "for age in si_pm_selected.keys():\n",
    "    si_rm_selected[age] = np.concatenate(si_rm_selected[age])\n",
    "    si_pm_selected[age] = np.concatenate(si_pm_selected[age])\n",
    "    rvl_pm_selected[age] = np.concatenate(rvl_pm_selected[age])\n",
    "\n",
    "    print(f\"Age {age}:\")\n",
    "    if len(si_rm_selected[age]) > 0:\n",
    "        print(f\"\\tPlace units SI: {np.nanmean(si_rm_selected[age]):.3f} (min {np.min(si_rm_selected[age]):.3f})\")\n",
    "    if len(rvl_pm_selected[age]) > 0:\n",
    "        print(f\"\\tHD units RVL: {np.nanmean(rvl_pm_selected[age]):.3f} (min {np.min(rvl_pm_selected[age]):.3f})\")\n",
    "        print(f\"\\tHD units SI: {np.nanmean(si_pm_selected[age]):.3f} (min {np.min(si_pm_selected[age]):.3f})\")\n",
    "    print(flush=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1b8ee756",
   "metadata": {},
   "source": [
    "# Load clustering data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2c5d00e6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.449716Z",
     "iopub.status.busy": "2025-09-24T06:29:20.449609Z",
     "iopub.status.idle": "2025-09-24T06:29:20.451434Z",
     "shell.execute_reply": "2025-09-24T06:29:20.451150Z"
    }
   },
   "outputs": [],
   "source": [
    "BY = 'day'\n",
    "SEED = 7\n",
    "CLUSTERALGO = 'gm'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7bb6da27",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.452338Z",
     "iopub.status.busy": "2025-09-24T06:29:20.452240Z",
     "iopub.status.idle": "2025-09-24T06:29:20.826636Z",
     "shell.execute_reply": "2025-09-24T06:29:20.825800Z"
    }
   },
   "outputs": [],
   "source": [
    "df_dir = os.path.join(DATA_DIR, 'cluster_locomotion', f'by_{BY}')\n",
    "df_data = pd.read_pickle(os.path.join(df_dir, f'data_{SEED}.pkl'))\n",
    "\n",
    "c_idx_col = f'cluster_idx_{CLUSTERALGO}'\n",
    "df_data = df_data[df_data[c_idx_col] != -1].reset_index()\n",
    "df_data.loc[df_data['age'] == 100, 'age'] = 40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "fda2d368",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.830557Z",
     "iopub.status.busy": "2025-09-24T06:29:20.830378Z",
     "iopub.status.idle": "2025-09-24T06:29:20.852530Z",
     "shell.execute_reply": "2025-09-24T06:29:20.851700Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Excluding 0.0% (rat, age) pairs because they have multiple clusters\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>cluster_idx_gm</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>rat</th>\n",
       "      <th>age</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">muessig_data_struct</th>\n",
       "      <th>r101_p20</th>\n",
       "      <th>20</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>r115_p24</th>\n",
       "      <th>24</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>r118_p24</th>\n",
       "      <th>24</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>r118_p25</th>\n",
       "      <th>25</th>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>r129_p40</th>\n",
       "      <th>40</th>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  cluster_idx_gm\n",
       "dataset             rat      age                \n",
       "muessig_data_struct r101_p20 20                2\n",
       "                    r115_p24 24                2\n",
       "                    r118_p24 24                2\n",
       "                    r118_p25 25                2\n",
       "                    r129_p40 40                3"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import re\n",
    "\n",
    "if 'exp' in BY or 'day' in BY:\n",
    "    df_data['dataset'] = df_data['rat'].map(lambda x: re.sub(\"['() ]\", \"\", x.split(',')[0]))\n",
    "    df_data = df_data[\n",
    "        (df_data['dataset'].str.contains('science2010')) | (df_data['dataset'].str.contains('muessig'))\n",
    "    ]\n",
    "    df_data['rat'] = df_data['rat'].map(lambda x: re.sub(\"['() ]\", \"\", x.split(',')[1]))\n",
    "\n",
    "    # this dataset give us a cluster for each (rat, age, trial)\n",
    "    # we want to get a cluster for each (rat, age)\n",
    "    # we exclude the (rat, age) where there are multiple clusters\n",
    "    df_data_exclude = df_data.groupby(['dataset', 'rat', 'age']).agg({c_idx_col: 'nunique'})\n",
    "    df_data_exclude = df_data_exclude[df_data_exclude[c_idx_col] > 1].reset_index()\n",
    "\n",
    "    print(\n",
    "        f\"Excluding {len(df_data_exclude)/len(df_data.reset_index().groupby(['rat', 'age']).count())*100:.1f}% \"+\n",
    "        \"(rat, age) pairs because they have multiple clusters\"\n",
    "    )\n",
    "\n",
    "    df_merge = df_data.merge(df_data_exclude[['dataset', 'rat', 'age']], on=['dataset', 'rat', 'age'], how='left', indicator=True)\n",
    "    df_data = df_merge[df_merge['_merge'] == 'left_only'].drop(columns=['_merge'])\n",
    "\n",
    "    # keep first cluster index because they are all the same after previous operation\n",
    "    df_data = df_data.groupby(['dataset', 'rat', 'age']).agg({c_idx_col: lambda x: list(x)[0]})\n",
    "elif 'age' in BY:\n",
    "    df_data = df_data[['age', c_idx_col]]\n",
    "    \n",
    "df_data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "99d5fe8d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.853911Z",
     "iopub.status.busy": "2025-09-24T06:29:20.853698Z",
     "iopub.status.idle": "2025-09-24T06:29:20.856634Z",
     "shell.execute_reply": "2025-09-24T06:29:20.856305Z"
    }
   },
   "outputs": [],
   "source": [
    "df_data = df_data.reset_index()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0f9fa77",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.870002Z",
     "iopub.status.busy": "2025-09-24T06:29:20.869903Z",
     "iopub.status.idle": "2025-09-24T06:29:20.879191Z",
     "shell.execute_reply": "2025-09-24T06:29:20.878845Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>rat</th>\n",
       "      <th>age</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cluster_idx_gm</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>31</td>\n",
       "      <td>16.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>102</td>\n",
       "      <td>20.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>9</td>\n",
       "      <td>40.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                rat   age\n",
       "cluster_idx_gm           \n",
       "1                31  16.0\n",
       "2               102  20.0\n",
       "3                 9  40.0"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_data_merge = df_data.groupby(c_idx_col).agg({'rat': 'count', 'age': 'median'}).reset_index()\n",
    "df_data_merge = df_data_merge[df_data_merge['rat'] > 2]\n",
    "df_data = pd.merge(\n",
    "    df_data, df_data_merge[c_idx_col], on=c_idx_col, how='inner'\n",
    ")\n",
    "df_data.groupby(c_idx_col).agg({'rat': 'count', 'age': 'median'})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "c97f5fc6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.880260Z",
     "iopub.status.busy": "2025-09-24T06:29:20.880155Z",
     "iopub.status.idle": "2025-09-24T06:29:20.882187Z",
     "shell.execute_reply": "2025-09-24T06:29:20.881901Z"
    }
   },
   "outputs": [],
   "source": [
    "clusters = [c if c < 3 else 'Adult' for c in sorted(df_data[c_idx_col].unique())]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "340c6d55",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "290a1baf",
   "metadata": {},
   "source": [
    "# DEV model data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "567beb1d",
   "metadata": {},
   "source": [
    "### Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d6462bc",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.883179Z",
     "iopub.status.busy": "2025-09-24T06:29:20.883081Z",
     "iopub.status.idle": "2025-09-24T06:29:20.886007Z",
     "shell.execute_reply": "2025-09-24T06:29:20.885726Z"
    }
   },
   "outputs": [],
   "source": [
    "args_dev = { # DEVELOPMENT\n",
    "    'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "    'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "    'env' : 'box_messy',\n",
    "    'env_dim': 0.635,\n",
    "    'name_prefix': None,\n",
    "    'pretrained_model_folder': False,\n",
    "    'moredata': None,\n",
    "    'n_gridcells': [0,0,0,0,25], # with GC\n",
    "    'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "    'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "    'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "    'n_future_pred' : 1,\n",
    "    'frame_subsampling': 4,\n",
    "    'stride' : 10,\n",
    "    'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "    'bptt_steps' : 9,\n",
    "    'latent_dim' : 500,\n",
    "    'bias': False,\n",
    "    'dropouts': '[0,0,0]',\n",
    "    'nonlinearity' : 'sigmoid',\n",
    "    'hidden_reg' : 0.,\n",
    "    'weights_reg' : 0.,\n",
    "    'seed': 1,\n",
    "    'epoch' : None,\n",
    "}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "22f8be4a",
   "metadata": {},
   "source": [
    "### Define Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "e52516ec",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.886951Z",
     "iopub.status.busy": "2025-09-24T06:29:20.886848Z",
     "iopub.status.idle": "2025-09-24T06:29:20.890215Z",
     "shell.execute_reply": "2025-09-24T06:29:20.889907Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Plots' labels:\n",
      "\n",
      "behaviou=crawl\n",
      "pretrained_beha=crawl\n",
      "n_gridcell=0\n",
      "gridcells_softma=False\n",
      "gridcells_module=None\n",
      "gridcells_orientation=None\n",
      "reset_hidden_a=None\n",
      "\n",
      "behaviou=walk\n",
      "pretrained_beha=crawl,walk\n",
      "n_gridcell=0\n",
      "gridcells_softma=False\n",
      "gridcells_module=None\n",
      "gridcells_orientation=None\n",
      "reset_hidden_a=None\n",
      "\n",
      "behaviou=run\n",
      "pretrained_beha=crawl,walk,run\n",
      "n_gridcell=0\n",
      "gridcells_softma=False\n",
      "gridcells_module=None\n",
      "gridcells_orientation=None\n",
      "reset_hidden_a=None\n",
      "\n",
      "behaviou=adult\n",
      "pretrained_beha=crawl,walk,run,adult\n",
      "n_gridcell=0\n",
      "gridcells_softma=False\n",
      "gridcells_module=None\n",
      "gridcells_orientation=None\n",
      "reset_hidden_a=None\n",
      "\n",
      "behaviou=adult\n",
      "pretrained_beha=adult\n",
      "n_gridcell=25\n",
      "gridcells_softma=True\n",
      "gridcells_module=[0.2, 0.4, 0.6]\n",
      "gridcells_orientation=[0.1]\n",
      "reset_hidden_a=10\n",
      "\n"
     ]
    }
   ],
   "source": [
    "n_compare = None\n",
    "print(\"Comparison will be done on the following parameters:\")\n",
    "for k, a in args_dev.items():\n",
    "    if isinstance(a, list):\n",
    "        print(f\"\\t{k}: {a}\")\n",
    "        if n_compare is None:\n",
    "            n_compare = len(a)\n",
    "        elif n_compare != len(a):\n",
    "            raise ValueError(\"All lists must have the same length\")\n",
    "\n",
    "if n_compare is None:\n",
    "    raise ValueError(\"At least one argument must be a list to make a comparison\")\n",
    "\n",
    "labels = [''] * n_compare\n",
    "for k, a in args_dev.items():\n",
    "    if not isinstance(a, list):\n",
    "        args_dev[k] = [a] * n_compare\n",
    "    else:\n",
    "        for i, v in enumerate(a):\n",
    "            labels[i] += f\"\\n{k[:-1]}={v}\" if len(labels[i]) > 0 else f\"{k[:-1]}={v}\"\n",
    "print(\"\\nPlots' labels:\\n\")\n",
    "for l in labels:\n",
    "    print(l)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "57cd039b",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.891333Z",
     "iopub.status.busy": "2025-09-24T06:29:20.891051Z",
     "iopub.status.idle": "2025-09-24T06:29:20.980550Z",
     "shell.execute_reply": "2025-09-24T06:29:20.980090Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n"
     ]
    }
   ],
   "source": [
    "from utils.trainer import RNNTrainer\n",
    "\n",
    "activity_dirs = []\n",
    "models = []\n",
    "\n",
    "print(\"Comparing the activity from the following directories:\")\n",
    "for i in range(n_compare):\n",
    "    model_name = RNNTrainer.define_model_name({k: v[i] for k, v in args_dev.items()})\n",
    "    \n",
    "    env_shape = args_dev['env'][i].split('_')[0]\n",
    "    trained_behav_list = args_dev['pretrained_behav'][i].split(',')\n",
    "    behav = trained_behav_list.pop()\n",
    "    if len(trained_behav_list)>0:\n",
    "        folder_name = '_'.join(trained_behav_list)\n",
    "    else:\n",
    "        folder_name = \"vanilla\"\n",
    "    exp_dir = os.path.join(\n",
    "        DATA_DIR, env_shape, behav, \"predictions\", args_dev['env'][i],\n",
    "        folder_name, model_name\n",
    "    )\n",
    "\n",
    "    activity_dir = f\"act_{args_dev['behaviour'][i]}_epoch\"\n",
    "    if args_dev['epoch'][i] is not None:\n",
    "        epoch = args_dev['epoch'][i]\n",
    "    else:\n",
    "        dirs = [d for d in os.listdir(exp_dir) if re.match(rf\"{activity_dir}\\d+\", d)]\n",
    "        epoch = max([int(re.findall(r'\\d+', d)[-1]) for d in dirs])\n",
    "\n",
    "    models.append(\n",
    "        torch.load(\n",
    "            os.path.join(exp_dir, f\"rnn_epoch{epoch}.pth\"),\n",
    "            weights_only=False,\n",
    "            map_location=torch.device(DEVICE)\n",
    "        ).to(DEVICE)\n",
    "    )\n",
    "    activity_dirs.append(os.path.join(exp_dir, f\"{activity_dir}{epoch}\"))\n",
    "\n",
    "    print(activity_dirs[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0dd02eef",
   "metadata": {},
   "source": [
    "# Comparison models' data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "df2db4d7",
   "metadata": {},
   "source": [
    "### Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "e5fa6baa",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.983963Z",
     "iopub.status.busy": "2025-09-24T06:29:20.983845Z",
     "iopub.status.idle": "2025-09-24T06:29:20.986024Z",
     "shell.execute_reply": "2025-09-24T06:29:20.985651Z"
    }
   },
   "outputs": [],
   "source": [
    "labels_compare = [\n",
    "    'Development',\n",
    "    'Less hidden units', 'More hidden units',\n",
    "    'Train longer',\n",
    "    'Smaller input', 'Bigger input',\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9aee91e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.987246Z",
     "iopub.status.busy": "2025-09-24T06:29:20.987136Z",
     "iopub.status.idle": "2025-09-24T06:29:20.996612Z",
     "shell.execute_reply": "2025-09-24T06:29:20.996189Z"
    }
   },
   "outputs": [],
   "source": [
    "args_compare = [\n",
    "    { # DEVELOPMENT\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': None,\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 4,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 500,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "    { # LESS HIDDEN UNITS\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': None,\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 4,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 375,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "    { # MORE HIDDEN UNITS\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': None,\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 4,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 625,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "    { # TRAIN LONGER\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': 'train_longer',\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 4,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 500,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "    { # SMALLER INPUT\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': 'small_input',\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 6,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 500,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "    { # BIGGER INPUT\n",
    "        'behaviour' : ['crawl', 'walk', 'run', 'adult', 'adult'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': 'big_input',\n",
    "        'pretrained_model_folder': False,\n",
    "        'moredata': None,\n",
    "        'n_gridcells': [0,0,0,0,25], # with GC\n",
    "        'gridcells_softmax': [False,False,False,False,True], # with GC\n",
    "        'gridcells_modules': [None,None,None,None,[0.2,0.4,0.6]], # with GC\n",
    "        'gridcells_orientations': [None,None,None,None,[0.1]], # with GC\n",
    "        'n_future_pred' : 1,\n",
    "        'frame_subsampling': 3,\n",
    "        'stride' : 10,\n",
    "        'reset_hidden_at': [None,None,None,None,10], # with GC\n",
    "        'bptt_steps' : 9,\n",
    "        'latent_dim' : 500,\n",
    "        'bias': False,\n",
    "        'dropouts': '[0,0,0]',\n",
    "        'nonlinearity' : 'sigmoid',\n",
    "        'hidden_reg' : 0.,\n",
    "        'weights_reg' : 0.,\n",
    "        'seed': 1,\n",
    "        'epoch' : None,\n",
    "    },\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "2d42074f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:20.997613Z",
     "iopub.status.busy": "2025-09-24T06:29:20.997512Z",
     "iopub.status.idle": "2025-09-24T06:29:21.000655Z",
     "shell.execute_reply": "2025-09-24T06:29:20.999786Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Development None\n",
      "Less hidden units None\n",
      "More hidden units None\n",
      "Train longer train_longer\n",
      "Smaller input small_input\n",
      "Bigger input big_input\n"
     ]
    }
   ],
   "source": [
    "assert len(labels_compare) == len(args_compare)\n",
    "for l, a in zip(labels_compare, args_compare):\n",
    "    print(l, a['name_prefix'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7af9516d",
   "metadata": {},
   "source": [
    "### Define Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "95793e0c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:21.002694Z",
     "iopub.status.busy": "2025-09-24T06:29:21.002143Z",
     "iopub.status.idle": "2025-09-24T06:29:21.006199Z",
     "shell.execute_reply": "2025-09-24T06:29:21.005894Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'walk', 'run', 'adult', 'adult']\n",
      "\tpretrained_behav: ['crawl', 'crawl,walk', 'crawl,walk,run', 'crawl,walk,run,adult', 'adult']\n",
      "\tn_gridcells: [0, 0, 0, 0, 25]\n",
      "\tgridcells_softmax: [False, False, False, False, True]\n",
      "\tgridcells_modules: [None, None, None, None, [0.2, 0.4, 0.6]]\n",
      "\tgridcells_orientations: [None, None, None, None, [0.1]]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "n_compare = [None]*len(args_compare)\n",
    "for i, args in enumerate(args_compare):\n",
    "    print(\"Comparison will be done on the following parameters:\")\n",
    "    for k, a in args.items():\n",
    "        if isinstance(a, list):\n",
    "            print(f\"\\t{k}: {a}\")\n",
    "            if n_compare[i] is None:\n",
    "                n_compare[i] = len(a)\n",
    "            elif n_compare[i] != len(a):\n",
    "                raise ValueError(\"All lists must have the same length\")\n",
    "    print()\n",
    "\n",
    "if None in n_compare:\n",
    "    raise ValueError(\"At least one argument must be a list to make a comparison\")\n",
    "\n",
    "for i, args in enumerate(args_compare):\n",
    "    for k, a in args.items():\n",
    "        if not isinstance(a, list):\n",
    "            args_compare[i][k] = [a] * n_compare[i]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "f3e3b630",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:21.007369Z",
     "iopub.status.busy": "2025-09-24T06:29:21.007051Z",
     "iopub.status.idle": "2025-09-24T06:29:21.063533Z",
     "shell.execute_reply": "2025-09-24T06:29:21.062941Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Development comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "\n",
      "Less hidden units comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch2000\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch2000\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2000\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2000\n",
      "\n",
      "More hidden units comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "\n",
      "Train longer comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch2500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch2500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch2500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_train_longer_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2500\n",
      "\n",
      "Smaller input comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_small_input_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "\n",
      "Bigger input comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_big_input_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from utils.trainer import RNNTrainer\n",
    "\n",
    "activity_dirs_compare = []\n",
    "models_compare = []\n",
    "\n",
    "for a, args in enumerate(args_compare):\n",
    "    print(labels_compare[a], \"comparing the activity from the following directories:\")\n",
    "    ad = []\n",
    "    m = []\n",
    "    for i in range(n_compare[a]):\n",
    "        model_name = RNNTrainer.define_model_name({k: v[i] for k, v in args.items()})\n",
    "        \n",
    "        env_shape = args['env'][i].split('_')[0]\n",
    "        trained_behav_list = args['pretrained_behav'][i].split(',')\n",
    "        behav = trained_behav_list.pop()\n",
    "        if len(trained_behav_list)>0:\n",
    "            folder_name = '_'.join(trained_behav_list)\n",
    "        else:\n",
    "            folder_name = \"vanilla\"\n",
    "        exp_dir = os.path.join(\n",
    "            DATA_DIR, env_shape, behav, \"predictions\", args['env'][i],\n",
    "            folder_name, model_name\n",
    "        )\n",
    "\n",
    "        activity_dir = f\"act_{args['behaviour'][i]}_epoch\"\n",
    "        if args['epoch'][i] is not None:\n",
    "            epoch = args['epoch'][i]\n",
    "        else:\n",
    "            dirs = [d for d in os.listdir(exp_dir) if re.match(rf\"{activity_dir}\\d+\", d)]\n",
    "            epoch = max([int(re.findall(r'\\d+', d)[-1]) for d in dirs])\n",
    "\n",
    "        m.append(\n",
    "            torch.load(\n",
    "                os.path.join(exp_dir, f\"rnn_epoch{epoch}.pth\"),\n",
    "                weights_only=False,\n",
    "                map_location=torch.device(DEVICE)\n",
    "            ).to(DEVICE)\n",
    "        )\n",
    "        ad.append(os.path.join(exp_dir, f\"{activity_dir}{epoch}\"))\n",
    "\n",
    "        print(ad[-1])\n",
    "    activity_dirs_compare.append(ad)\n",
    "    models_compare.append(m)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26ab3395",
   "metadata": {},
   "source": [
    "# Pos and hd decoding errors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "bdcbe12d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:21.065302Z",
     "iopub.status.busy": "2025-09-24T06:29:21.065181Z",
     "iopub.status.idle": "2025-09-24T06:29:21.069719Z",
     "shell.execute_reply": "2025-09-24T06:29:21.069046Z"
    }
   },
   "outputs": [],
   "source": [
    "pos_dec_err_dev = []\n",
    "hd_dec_err_dev = []\n",
    "\n",
    "for ad in activity_dirs:\n",
    "    pos_dec_err_dev.append(\n",
    "        np.load(os.path.join(ad, \"pos_dec_err.npy\"))\n",
    "    )\n",
    "    hd_dec_err_dev.append(\n",
    "        np.load(os.path.join(ad, \"thet_dec_err.npy\"))\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "f844ca9b",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:21.070860Z",
     "iopub.status.busy": "2025-09-24T06:29:21.070754Z",
     "iopub.status.idle": "2025-09-24T06:29:21.080371Z",
     "shell.execute_reply": "2025-09-24T06:29:21.080007Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Development\n",
      "Less hidden units\n",
      "More hidden units\n",
      "Train longer\n",
      "Smaller input\n",
      "Bigger input\n"
     ]
    }
   ],
   "source": [
    "pos_dec_err_compare_all = []\n",
    "hd_dec_err_compare_all = []\n",
    "\n",
    "for l, ads, args in zip(labels_compare, activity_dirs_compare, args_compare):\n",
    "    print(l)\n",
    "    pos_dec_err, hd_dec_err = [], []\n",
    "    for ad in ads:\n",
    "        pos_dec_err.append(\n",
    "            np.load(os.path.join(ad, \"pos_dec_err.npy\"))\n",
    "        )\n",
    "        hd_dec_err.append(\n",
    "            np.load(os.path.join(ad, \"thet_dec_err.npy\"))\n",
    "        )\n",
    "    pos_dec_err_compare_all.append(pos_dec_err)\n",
    "    hd_dec_err_compare_all.append(hd_dec_err)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "04f3e41c",
   "metadata": {},
   "source": [
    "# sRSA + isomap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "3d670bc9",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:21.081707Z",
     "iopub.status.busy": "2025-09-24T06:29:21.081373Z",
     "iopub.status.idle": "2025-09-24T06:36:10.476945Z",
     "shell.execute_reply": "2025-09-24T06:36:10.476445Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    }
   ],
   "source": [
    "from utils.activiter import RNNActiviter\n",
    "\n",
    "sRSA_dev = []\n",
    "isomap_emb_dev = []\n",
    "isomap_pos_dev = []\n",
    "\n",
    "for ad in activity_dirs:\n",
    "    print(ad)\n",
    "    sRSA_dev.append(\n",
    "        np.load(os.path.join(ad, \"sRSA_values.npy\"))\n",
    "    )\n",
    "\n",
    "    lact = np.load(os.path.join(ad, \"latent_activity.npy\"))\n",
    "    pos = np.load(os.path.join(ad, \"positions.npy\"))\n",
    "    lact = lact.reshape(lact.shape[0]*lact.shape[1], -1)\n",
    "    pos = pos.reshape(pos.shape[0]*pos.shape[1], -1)\n",
    "    print(lact.shape, pos.shape)\n",
    "\n",
    "    isomap_emb, isomap_pos = RNNActiviter.calculate_isomap(\n",
    "        lact, pos, seed=0\n",
    "    )\n",
    "    isomap_emb_dev.append(isomap_emb)\n",
    "    isomap_pos_dev.append(isomap_pos)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "b4cabc4b",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:36:10.480130Z",
     "iopub.status.busy": "2025-09-24T06:36:10.479855Z",
     "iopub.status.idle": "2025-09-24T07:15:16.693687Z",
     "shell.execute_reply": "2025-09-24T07:15:16.693186Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63990, 375) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch2000\n",
      "(63990, 375) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch2000\n",
      "(63990, 375) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2000\n",
      "(63990, 375) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat375_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2000\n",
      "(63990, 375) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63990, 625) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "(63990, 625) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "(63990, 625) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 625) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat625_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 625) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch2500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch2500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch2500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_train_longer_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_train_longer_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_small_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_small_input_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/walk/predictions/box_messy/crawl/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/run/predictions/box_messy/crawl_walk/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/crawl_walk_run/RNN_big_input_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_big_input_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    }
   ],
   "source": [
    "sRSA_compare_all = []\n",
    "isomap_emb_compare_all = []\n",
    "isomap_pos_compare_all = []\n",
    "\n",
    "for ads, args in zip(activity_dirs_compare, args_compare):\n",
    "    sRSA, isomap_emb, isomap_pos = [], [], []\n",
    "    for ad in ads:\n",
    "        print(ad)\n",
    "        sRSA.append(\n",
    "            np.load(os.path.join(ad, \"sRSA_values.npy\"))\n",
    "        )\n",
    "\n",
    "        lact = np.load(os.path.join(ad, \"latent_activity.npy\"))\n",
    "        pos = np.load(os.path.join(ad, \"positions.npy\"))\n",
    "        lact = lact.reshape(lact.shape[0]*lact.shape[1], -1)\n",
    "        pos = pos.reshape(pos.shape[0]*pos.shape[1], -1)\n",
    "        print(lact.shape, pos.shape)\n",
    "\n",
    "        isomap_emb_curr, isomap_pos_curr = RNNActiviter.calculate_isomap(\n",
    "            lact, pos, seed=0\n",
    "        )\n",
    "        isomap_emb.append(isomap_emb_curr)\n",
    "        isomap_pos.append(isomap_pos_curr)\n",
    "\n",
    "    sRSA_compare_all.append(sRSA)\n",
    "    isomap_emb_compare_all.append(isomap_emb)\n",
    "    isomap_pos_compare_all.append(isomap_pos)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8db5c627",
   "metadata": {},
   "source": [
    "# Split with/wo GC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "1dc6c8f6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:15:16.699236Z",
     "iopub.status.busy": "2025-09-24T07:15:16.699033Z",
     "iopub.status.idle": "2025-09-24T07:15:16.702863Z",
     "shell.execute_reply": "2025-09-24T07:15:16.702495Z"
    }
   },
   "outputs": [],
   "source": [
    "poserr_all_dev, poserr_all_dev_gc = pos_dec_err_dev[:-1], pos_dec_err_dev[-1]\n",
    "hderr_all_dev, hderr_all_dev_gc = hd_dec_err_dev[:-1], hd_dec_err_dev[-1]\n",
    "sRSA_dev, sRSA_dev_gc = sRSA_dev[:-1], sRSA_dev[-1]\n",
    "\n",
    "poserr_all_compare = [pos_dec_err[:-1] for pos_dec_err in pos_dec_err_compare_all]\n",
    "poserr_all_compare_gc = [pos_dec_err[-1] for pos_dec_err in pos_dec_err_compare_all]\n",
    "hderr_all_compare = [hd_dec_err[:-1] for hd_dec_err in hd_dec_err_compare_all]\n",
    "hderr_all_compare_gc = [hd_dec_err[-1] for hd_dec_err in hd_dec_err_compare_all]\n",
    "sRSA_compare = [sRSA[:-1] for sRSA in sRSA_compare_all]\n",
    "sRSA_compare_gc = [sRSA[-1] for sRSA in sRSA_compare_all]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2d15d447",
   "metadata": {},
   "source": [
    "# Figure plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "88440f1c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:15:16.707362Z",
     "iopub.status.busy": "2025-09-24T07:15:16.707198Z",
     "iopub.status.idle": "2025-09-24T07:15:16.709543Z",
     "shell.execute_reply": "2025-09-24T07:15:16.709206Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Development', 'Less hidden units', 'More hidden units', 'Train longer', 'Smaller input', 'Bigger input']\n"
     ]
    }
   ],
   "source": [
    "idx = 0\n",
    "print(labels_compare)\n",
    "l = labels_compare[idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "e00f65ee",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:15:16.710732Z",
     "iopub.status.busy": "2025-09-24T07:15:16.710474Z",
     "iopub.status.idle": "2025-09-24T07:15:16.712530Z",
     "shell.execute_reply": "2025-09-24T07:15:16.712206Z"
    }
   },
   "outputs": [],
   "source": [
    "ls_gc = (0, (1,1.5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "63fb1642",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:15:16.716644Z",
     "iopub.status.busy": "2025-09-24T07:15:16.713434Z",
     "iopub.status.idle": "2025-09-24T07:15:16.721562Z",
     "shell.execute_reply": "2025-09-24T07:15:16.721234Z"
    }
   },
   "outputs": [],
   "source": [
    "alpha_low = 0.2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "fddc817f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:15:16.722860Z",
     "iopub.status.busy": "2025-09-24T07:15:16.722605Z",
     "iopub.status.idle": "2025-09-24T07:15:17.520421Z",
     "shell.execute_reply": "2025-09-24T07:15:17.519966Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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IhpU5HK5u7NAREREREREREQOwkAVERERERERERERERERuQUDVUREREREREREREREROQWDFQRERERERERERERERGRWzBQRURERENCXl4eUlNTERYWBolEgqSkJOTm5ro7W0REREQeJy8vDykpKWK9KSwsDCkpKcjLy3N31oiIiOgexEAVERERDXoZGRlITU1FQUEBlEolAKC4uBgZGRlISUkRXyMiIiK6l1VUVCAlJQWpqak4c+YM9uzZg+bmZiQnJ6OgoACpqalISkpydzaJiIjoHsNAFREREQ16CoUCgiCgubkZ5eXlkMlk4nsFBQVYuHCh+zJHRERE5AEqKioQHx+PgoICAMChQ4eQnJwMmUyG5cuXi+mKi4uRmZnprmwSERHRPYiBKiIiIhr0du7cKf4/Li5O73egr8GFU9kQERHRvSw1NVX8f1xcHBITE8XfdTv5AH11JyIiIiJXYaCKiIiIBr3+jStLly41SMOewURERHSvys7O1gs+6QapAIgjq7R0g1pEREREziZ1dwaIiIiInCExMVGvQaaiosKNuSEiIiJyn5ycHL3f4+LiDNJUVlbizJkziIuLM/o+ERERkbNwRBURERENSXK53OA1BquIiIjoXqNUKq2qA8lkMiQnJzNIRURERC7HQBURERENScYaWRioIiIionuNQqEweI11IiIiIvIkDFQRERHRkGSsUYY9hImIiOhew1HmRERE5OkYqCIiIqIhSalUGrzGQBURERHda2QyGWQymd5rxcXFDFYRERGRx2CgioiIiIak/iOq0tPT3ZQTIiIiIvdKTk42eC0rK8sNOSEiIiIyxEAVERERDTlKpRLFxcXi7zKZjI0xREREdM/auXOnwWu5ubnIzc01mj41NdXZWSIiIiISMVBFREREg17/qWv6N7rs3LnTYMobIiIionuFTCZDTk6OwesZGRlITU1Fbm4uCgoKkJ2djfj4eKSkpLghl0RERHSvkgiCILg7E0RERETWysjIQG5uLhITE5GRkYHMzEzExcVh586diIuLw8cff4yMjAwAfY0ye/bsMTrdDREREdG9Ji8vD2vWrDG6lqfWnj17sHTpUtdlioiIiO55DFQRERHRoJKRkYH4+Hhs2rQJQN80f1u3bkVBQQGKi4shk8kQFxeH5ORkbNmyhSOpiIiIiHQolUpkZmaioKAAFRUVkMlkkMvlWLp0KetORERE5BYMVBEREREREREREREREZFbcI0qIiIiIiIiIiIiIiIicgsGqoiIiIiIiIiIiIiIiMgtGKgiIiIiIiIiIiIiIiIit2CgioiIiIiIiIiIiIiIiNyCgSoiIiIiIiIiIiIiIiJyCwaqiIiIiIiIiIiIiIiIyC0YqCIiIiIiIiIiIiIiIiK3YKCKiIiIiIiIiIiIiIiI3IKBKiIiIiIiIiIiIiIiInILBqqIiIiIiIiIiIiIiIjILRioIiIiIiIiIiIiIiIiIrdgoIqIiIiIiIiIiIiIiIjcgoEqIiIiIiIiIiIiIiIicgsGqoiIiIiIiIiIiIiIiMgtGKgiIiIiIiIiIiIiIiIit2CgioiIiIiIiIiIiIiIiNyCgSoiIiIiIiIiIiIiIiJyCwaqiIiIiIiIiIiIiIiIyC0YqCIiIiIiIiIiIiIiIiK3YKCKiIiIiIiIiIiIiIiI3IKBKiIiIiIiIiIiIiIiInILBqqIiIiIiIiIiIiIiIjILRioIiIiIiIiIiIiIiIiIrdgoIqIiIiIiIiIiIiIiIjcQuruDAxlGo0GTU1Neq+Fh4fDy4vxQSIiIhq8WMchIiKioYb1GyIiIvdhoMqJmpqacN999+m91tjYiBEjRrgpR0REREQDxzoOERERDTWs3xAREbkPu4UQERERERERERERERGRW3BEFRERERERERERERERkYcSBAFnz57FrVu3MGrUKCQlJUEikbg7Ww7DQBUREREREREREREREZGHOnfuHK5cuQIAaGlpgVQqxfTp092bKQfi1H9EREREREREREREREQeqLW1FZcuXQIA1NfXAwAuXbqE1tZWd2bLoRioIiIiIiIiIiIiIiIi8kCnT5+GRqOBQqFAeXk5FAoFNBoNzpw54+6sOQwDVURERERERERERERERB6mpqYGt27dgkajQWVlJQCgsrISGo0GN2/exI0bN9ycQ8dgoIqIiIiIiIiIiIiIiMiDqNVqcdRUXV0dOjs7AQCdnZ2oq6sDAJw5cwZqtdpteXQUBqoGod7eXly4cAG9vb3uzgoRERGRw1y6dEmseBMRERERERHdy77++mt0dHSgs7MTtbW1AICwsDC0t7ejtrYWnZ2daG9vx9dff+3mnA4cA1WDjEajwbFjx3Du3DkUFRUNiWgpERER0YULF1BcXIyDBw+ira3N3dkhIiIiIiIicpvW1lZcunQJQN9Ufx0dHWhvb0dLSwuam5vR3d0tTgV46dIl3L17153ZHTAGqgYRQRBw/Phxcd7JW7du4dChQ+jp6XFzzoiIiIjsd/36dZw7dw4AcPfuXRw8eBAKhcLNuSIiIiIiIiJyj9OnT6OnpwdXr15FaWkpampqIJVKodFoMGLECLS2tkKhUEChUECj0eD06dPuzvKASN2dAbLeyZMnUVVVpffa7du3UVBQgAULFmDYsGHuyRgREZGHKi0thUKhQEVFBQBALpdDJpNhxowZCAkJcXPuCABqa2tx8uRJvddUKhXy8/PxyCOPYOTIkW7KGREREREREZHrXbhwAceOHUNjYyPKy8vR09ODsLAwsf1/2LBh6OzshCAIqKyshEwmw82bN3Hjxg2MGTPGzbm3DwNVg0RpaSmuX78OAOju7sb//d//4dFHH0VQUBCampqQn5+PhQsXwt/f3805JSIicq/t27cjPz8fBQUFZtPFxcUhJSUF6enpmD59umsyR3pu376No0ePQhAEg/d6enpw+PBhfOMb30BMTIzrM0dERERERETkImq1GtXV1SgrK8Nnn32Grq4uNDU1oaenB1KpFHK5XC99UFAQenp6IJFIUFdXhzFjxuDs2bODNlDFqf8GiejoaPj5+aGnpwcffPABTp48idzcXHHuSaVSic8//xwdHR1uzikREZF7bN++HeHh4cjMzERBQQEEQTD7U15ejpycHCQlJeGxxx4Tp54j1wkMDERwcLDJ97Vrc16+fNmFuSIiIiIiIiJyjZaWFpw5cwb79u3DV199hbq6OnR1dUEQBCiVSgBAaGgovL299bbz9vaGl1dfeOfmzZsQBAFtbW1QqVSu/ggOIRGMdWElh7h9+zbuu+8+vdcaGxsxYsQIu/bX2NiIJ598EleuXBFfGzFiBNLT08XpiwIDA5GcnGy20YeIiGgoqaqqQkpKCioqKsSROYmJiYiLi0NcXBzCw8Mhk8kAQKzklZeXQ6FQoLi4WJwWUCKRIDMzE7/5zW/c8TEGFUfWcbq7u1FUVITGxkaz6SZOnIgHH3wQEonE5mMQERERWeLoNhwiIiJTent7UVNTg7KyMqPPwmfOnBFHVDU1NUEqlSI6OlovWOXl5YXm5maEhoZi7NixGDNmDIKCgvD973/fhZ/EcTx+6j+uLdGnq6sLL730Eurq6uDl5QWNRgOgryKVk5OD9PR0hIaGor29HZ9//jmSk5MRGhrq5lwTERE51759+7B06VLIZDJs3LgRKSkpWLhwoU37aGlpQX5+PnJycvDGG2+guLgYn332mZNyTP35+vpi4cKF+PLLL1FTU2My3aVLl6BSqfDwww+LvcaIiIiIiIiIBovW1laUlZWhoqICXV1dJtPFxMTg6tWrCAsLQ2trK3p6eqBQKDBixAiEhIRg1KhRaG1thUajgZ+fHyIjIwEASUlJrvooDueRI6qGytoSjuyN89prr+HDDz8E0DcNTnt7uxisAoDw8HBkZGSIwalhw4Zh4cKFBnNXEhERDRU7d+5EZmYmsrKysGbNGofss6CgAGvXroVcLsepU6ccss+hyBk9jgVBwJkzZ3D16lWz6UaNGoW5c+fCx8fH7mMRERER9ccRVURE5AwajQY3btzAtWvX0NDQYPV2Fy9ehFKpRFtbGxoaGhASEoJvfetbCA8PR0dHB0pKSgAAEyZMgFwux+jRo7FgwQJnfQyn86hA1fbt27F161ZxWh5rsqad/iUlJQVZWVmYNm2aM7NoE0dWcm7fvo2nn35aHFlmLFgll8uRkZEhTm/k4+ODBQsWsFJFRERDzs6dO5GTk4NDhw45ZQRxRkYGqqqqcPDgQYfveyhwZkPO119/jdLSUrNp5HI5FixYAD8/vwEfj4iIiAhgoIqIiBzr7t27uH79OsrLy9HZ2Wnz9iqVCuXl5bjvvvtw+/ZtKJVKhIaGYvLkybhw4QJaW1shl8sxYcIEeHl54Tvf+c6gXg7IIwJVQ3VtCUdXcpqamrBy5UqUl5cD6Avktbe3o7e3V0wTFhaG9PR0cSSVVCrF/PnzERERYeenICIi8iwlJSVYs2YNzpw549TjrF27FuPGjcMLL7zg1OMMRs5uyCkvL8eJEyfMdloKCgrCwoULB3VFnIiIiDwHA1VERDRQGo0GtbW1KCsrw61bt+zah6+vL+Li4pCQkIDKykp8/fXX6OzsRElJCTQaDYYPH447d+7Ay8sLiYmJGDZsGCZPnuyRM87Zwu2BKt21JdLT0we8tsShQ4fw6KOPesTaEs6o5CgUCqxatQrXrl0DYDxYpf0uw8PDAQDe3t6YO3euOFclERHRYLZs2TLs3LnTJWsxLlu2DO++++49tS6mNVzRkFNXV4ejR49CrVabTDNs2DAsWLBArPMQERER2YuBKiIisld7ezvKyspQXl4OlUpl1z5GjBiBhIQEjB07FlKpFACgVqvxz3/+Ex0dHbhx44beus5jx47FmDFjEBgYiO985zviNoOVWwNVQ31tCWdVcpqbm7Fq1SpxDQdBENDR0aHXkBMSEoKMjAwMHz4cAODl5YU5c+Zg7NixAzo2ERERkasacpqamnD48GGzi8xKpVLMnTsXo0ePduixiYiI6N7CQBUREdlCEARx9NTNmzft2oePjw9iY2ORkJCAsLAwo2lqampw5MgRaDQalJSUoLOzE35+fnjwwQfh5eWFRx55BGPGjBnIR/EIXu46sHZticrKSocFqQAgOTkZ169fx4MPPohFixY5bL+eJCwsDB988AEmTpwIoG/Kw4CAAL2oaWtrK3JycnD79m0AfcMOjx49Kk6TSEREROTpwsPDsWjRIgQFBZlMo1arUVhYyDoOEREREREROV1HRwfOnz+P//3f/8UXX3xhV5AqPDwcDz30EJ544gnMmjXLZJAK6Bs5NWrUKHh5eSE2NhYAEBsbCy8vL4wePXpIBKkANwWqSkpKkJOTgzNnzjht2p6cnBzExsZi+/btTtm/u4WGhuK9997D5MmTAfw7WOXj4yOm0QarGhsbAfRFeY8fP46ysjK35JmIiMgVKisrsW7dOpu3a21tRWlpqeMzRAMSEhKCRYsWietvGqOt41y8eNGFOSMiIiIiIqJ7gSAIqKurQ1FREf73f/8X58+fR0dHh037kEqlSEhIwJIlS7B48WKMGzfO6un6Zs6cCS8vL8jlcsTHx0Mul8PLywszZ8605+N4JLcEqrZu3YpDhw45/TjvvPMOTp06hdbWVqcfyx1CQkLwl7/8BVOnTgXQF6zy9/eHr6+vmObu3bt455130NDQIL528uRJXL582eX5JSIicoWKigrk5ubatM3mzZsRFhaGNWvWYMaMGVi+fLmTckf28Pf3R0pKCkaOHGk2XUlJCU6fPg03L8FKREREREREQ4BKpcKFCxfwySefoLCwELW1tTY/b4aFhWH27Nl44oknMHv2bLOdME0JCQkRZ1fTPhdPnDgRwcHBNu/LU7l1jaqhzlXzG7e1tSEjIwMlJSUA+iK8nZ2d6O7uFtMEBgZizZo1GDVqlPjatGnTMGXKFIfmhYiIyN0OHTqERx99FL29vdi3bx8UCgVmzJiB6dOnG02/d+9epKamIj4+Xhx1nJubi7179+LgwYMuzPng4a41HDQaDY4fP46qqiqz6aKjo/GNb3wD3t7eTs0PERERDR1co4qIiIC+tvX6+nqUlZXhxo0bdnWE9Pb2RkxMDO6//36Eh4c7LF9nz57FrVu3MGrUKCQlJUEikThk357AurFlg8C+ffvw+OOPuzsbbhEUFITc3FysXbsWZ8+eFUdWSSQScfHx9vZ25ObmYs2aNeJi4+fOnYNarcaDDz7ozuwTERE5VHFxMQRBMAhSxMfHIz8/H9HR0Xqv5+TkQCKRIDk5WXwtPT0deXl5+Mtf/oJnnnnGJfkmy7y8vPDNb34T/v7+ZkeHV1dXo7OzE4888ojeSHMiIiIiIiIiYzo7O1FeXo6ysjK0tbXZtQ+ZTIaEhATExsY6/FlUIpFgxowZDt2nJ3HL1H/OkJOT4+4suFVgYCByc3Mxa9Ys8TU/Pz8MGzZM/L2jowO5ubmoq6sTX7t48SKnyCEioiGjpaUFW7duhUQigSAIej/Xr19HSkqKwTZnzpwB0BfI0rV06VJs2rTJJfkm60kkEiQlJSEpKclsuoaGBnz++ec2zxtORERERERE9476+nocPXoU+/btQ0lJic1BKm9vb8TFxWHRokX4j//4DzzwwAPsMGkHjx5RVVVVhYqKCiiVSigUCpPp8vPzUVBQ4MKceSZ/f3+88847ePbZZ3HixAkAfcEqiUSCzs5OAH3zaubm5mL16tUYM2YMAODq1atQq9V46KGHhtRwQSIiuvfk5uZCqVQC6OvJtGXLFiQmJiIuLg7l5eXYvHkzduzYgQ0bNojbKJVKSCQSyGQyvX0tX74ca9euxf/+7//iBz/4gQs/BVljwoQJ8Pf3x/Hjx6HRaIymUSqVOHjwIBYsWIDQ0FAX55CIiIiIiIg8UVdXFyoqKnDt2jXcvXvXrn2EhITg/vvvR1xcHANTDuCRgap3330XWVlZqKiosCq9IAgMsPz//Pz88Oc//xk//elP8eWXXwIAhg0bBolEApVKBaBvGOPOnTuxevVqjB07FgBQXl4OtVqNb37zm/DyGjID7YiI6B5z+vRpAEBmZia2bt2q915sbCwKCgqQkpKiF6gyRRvYyM/PZ6DKQ8XExGDYsGH44osvoFarjaZpb2/HwYMHMX/+fK4xQUREREREdA9rbGzEtWvXUFNTY7LDozleXl4YO3Ys7r//foN1DWlgPC5QtXfvXqSnp4tT9pDt/Pz88Mc//hE//elPcezYMQAQo7raYFVXVxfeffddrFq1CjExMQD61nNQq9WYO3cuFx8nIqJBqbi4GHv27METTzxh9H2ZTCaOuAL6pgrUksvlRtPn5+c7PJ/kOKNGjcKjjz6Kw4cPiyPI++vu7kZBQQG+9a1vISoqysU5JCIiIiIiInfp7u5GRUUFysrK9NoAbBEcHIyEhATEx8frLbVDjiMRPCwaNGPGDBQXF0Mmk2HZsmXi+gPGGo8AQKFQ4MyZM3j33XfR29vryqxadPv2bYPIamNjo8t683Z3d+P555/HF198Ib7W09Ojt1aDr68vVq1ahdjYWPG1kSNHYt68eZBKPS6OSUREZJa3t7fZ+kBLSwvkcrmYprKyEvHx8ZBIJMjPz8eCBQv00svlckgkEjQ1NTk134ONu+s4xrS1teHQoUNmp22QSCSYPXs2xo0b58KcERER0WDgifUbIiKy3+3bt1FWVobq6mq74gYSiQRjx45FQkICIiIiOKObk3lcJKK4uBgSiQTFxcXiSB9L1qxZg8rKSudmbBDy9fXF73//e6xfvx6HDx8GAPj4+CAgIEAMVnV3d+Mvf/kLnn76aXER+fr6ehw6dAgLFiyAj4+P2/JPRERkqwcffBCFhYWYP3++0ffXrFmjtxaV7ugqY51itOtXkecLCgrCokWLUFhYaDKwKAgCTpw4AZVKhSlTprg4h0RERERERORMPT094ugp3ed9WwQFBYmjp/z8/BybQTLJ4xYjiouLQ2JiotVBKq3MzEznZGiQ8/X1xW9/+1ukpKSIr/n4+CAwMFBseOvp6cH777+P69evi2lu376N/Px8dHV1uTzPRERE9tq8eTOSk5OxY8cOVFVVAQCqqqqwb98+zJw5E3v37oUgCNixYwcA6K2HGRcXp7evkpISo6+T5/Lz80NKSgpGjx5tNt25c+dw8uRJTjNNREREREQ0BDQ1NeGrr77C3r17cfr0aZuDVBKJBGPGjMGCBQvwve99D5MmTfK4IFVvby/ef/99PP/883j//fc9bna5gfK4qf8yMjKQl5c3JKbY8aRh42q1Ghs3bsTBgwf1Xuvo6BAbaaRSKX70ox/h/vvvF9PIZDIsXLgQ/v7+Ls8zERGRPTIyMrBz506DkVCCIEAikUChUCAzMxMSiQRnzpzB2bNnIZFIkJ2djQ0bNojp165di9zcXKSkpOjdP8mz6jjGaDQanDx5EuXl5WbTjRkzBnPmzOHanEREROTx9RsiItLX09ODqqoqlJWVQaFQ2LWPgIAAJCQkYNy4cR7f/v3hhx9i79694u9PPPEEnnrqKTfmyLE8bkRVZmYmmpubza4vYMz27dudlKOhQSqVYvv27ViyZInea7ojq9RqNf7617/i6tWrYhqlUonPP/8c7e3tLs8zERGRPXJycrBx40YIgqD3AwAff/wxQkND8c477+DOnTtikGrjxo0oKyvDokWLsG/fPmzZsgW5ubmQSCRITU118yciW3l5eeHhhx/G5MmTzaa7ceMGCgoK0N3d7aKcERERERER0UAoFAqcPHkSe/fuxcmTJ20OUkkkEkRFRWH+/Pn4wQ9+gClTpnh8kOrmzZv45JNPAPR1ogCAf/zjH7h586Ybc+VYHjeiCgByc3Nx6NAhfPTRR1ZvM3PmTJw+fdqJubKdJ/bG6e3txc9//nN8+umneq+1t7eLjXje3t744Q9/iAkTJohpAgMDkZycjODgYJfnmYiIyB6VlZXIy8vD6dOnIZfLkZGRgQcffFAvTV5eHiorK7Fx40YAQEpKiriuoyAICAsLGxKjvB3NGXWcq1ev4v3338eLL77o0PrG1atXLdYRQ0NDsWDBAgQGBjrsuERERDS4eGIbDhER9VGr1aiursa1a9fsfkb39/fHuHHjkJCQgICAAAfn0HkEQcCvf/1rnDt3DkqlEleuXMH48eMhk8kwffp0vPTSS0NibW2PDFQBfdPtVFZWIjEx0Ww6pVKJM2fOoLi42OPmZfTUSk5vby9efvllMQoL9E2R097eDo1GA6CvJ/IPf/hDTJw4UUzj7++PhQsX6i1CT0RENNRopw6Mi4vDnj17DIJb5Pg6jkqlQmpqKioqKjB69Ghs27bNod97TU0Njh07JtZzjGE9h4iI6N7mqW04RET3MqVSibKyMlRUVKCnp8eufYwePRoJCQmIiooalAGdEydOYNu2bdBoNDh//jw6Ozvh5+eHqVOnwsvLC5s2bcLs2bPdnc0B88hA1ZYtW5CdnW11eu2aEwxUWU+j0eCVV17Rm9fSWLAqLS1Nb9qcYcOGYeHChZDL5S7PMxEREXkGR9dxXnnlFezZs0f83dvbGz/+8Y+xZs0ah60f1dDQgKKiIrMPNz4+Ppg3bx4iIiIcckwiIiIaPDy5DYeI6F7S29uL6upqlJWV4fbt23btw8/PD+PGjcO4ceMQFBTk4By6TldXF5577jncuXMHtbW1qK2tFd+LiopCVFQUhg8fjrfeegvDhg1zY04HzuPWqNq2bRuysrIAwGBtCVM/ZDsvLy/88pe/xLJly/ReCwwMhJdX32mh0Wiwe/dunD9/XkzT1dWF/Px8uwsJIiIiV6qqqsK+ffv0Xjt06BDWrVtn83qY5Byff/65XpAK6Hsweeutt7Bq1So0NDQ45DgRERFYtGiR2bnHe3p6cPjwYdTU1DjkmERERERERGSdlpYWnDlzBnv37sXx48ftan8eNWoU5s6di8cffxzTp08f1EEqANi7dy/u3LmDrq4u1NXVobGxETdv3kRDQwOqq6vR1dWFO3fu6A1GGaw8bkSVXC5HS0sLQkNDsWXLFsTFxVmcguXs2bPYsmULR1TZQaPR4PXXX8ff//538TVBENDe3i5+n15eXli+fDmmT58uppFKpZg3bx5Gjhzp6iwTERFZtG/fPmRmZqKiogISiQRqtVrv/YKCAixfvhx5eXmYP3++m3I5eDmqjnPr1i18//vfNxs0DAkJwWuvvYbk5GS78tpfe3s7Dh8+jJaWFrPpZs6ciQceeMAhxyQiIiLPNxjacIiIhpre3l7cuHED165dQ2Njo1378PPzQ3x8PMaNG+fQ9Y7dSaVS4fLly/j5z38OlUqFqqoq1NbW6k1n7+XlhQkTJuCBBx6AVCrF7373O4waNcqNuR4Yqbsz0J9SqYREIkFVVRVCQkKs2mbhwoU4c+aMk3M2NHl5eeGll16Ct7c3du3aBQCQSCQIDAwUg1UajQb/8z//A0EQxPUi1Go1CgsLMXfuXERGRrrzIxAREenZtm0bNm/eDAAmR14nJyfjo48+QnJyMgoKChiscpP29naEh4ebDVS1trbiueeew/Lly5GZmQk/P78BHTMwMBCLFi1CYWGh2R56p0+fhkql0uuoQ0RERERERAPX2toqrj3V1dVl1z4iIiKQkJCAMWPGOGzKeFcTBAEtLS1QKpVQKBRobm5Gc3MzVCoVPvnkE9y5cwdKpRINDQ0Gay5rNBrU19cjIiICMpkM7777Ll566aVBuQ4X4IEjqsaNG4ewsDCcPn3apu0OHTqEhQsXOilX9hlMvXEEQcC2bdvwwQcf6L3W0dGh1ws9NTUVM2bMEH/38vLCnDlzMHbsWFdml4iIyKiSkhIkJSXpvWZuHcuUlBQUFxejqanJFdkbMhxZx+no6MBvfvMbgykajYmPj8eOHTtw//3323yc/np7e3H06FG9Ob5NHXP27Nni1MhEREQ0NA2mNhwiosFIo9Hgxo0bKCsrQ319vV378PX1RXx8PBISEqwe5OIpenp6xECU9kepVOq1VwiCAKVSiRMnTuCLL76ASqVCW1sburu7Te43NjYW06ZNg5eXFzZt2oTZs2e74uM4nMcFqrKzsz1yGj97DLZKjiAIePPNN/GXv/xF77X+waqlS5di5syZ4u8SiQQPP/ww4uLiXJpfIiKi/pYtW4a8vDwkJycjMzMTSUlJCA8PN1mv2LlzJzIyMrB582b85je/cXFuBy9n1HE+++wzvPLKKxbXDvP19cXGjRvx1FNPDbinmCAIOHXqFMrKysymGz16NObOnQup1OMmIyAiIiIHGWxtOEREg0VbWxvKyspQXl6Ozs5Ou/Zx3333ISEhAWPHjh0Uo6fa29v1AlIKhQJtbW0m0964cQM3btxATU0N2traUF1djZ6eHnR3d0OlUpmcLQbomzVk0qRJiIqKQkREBP70pz8NylFVHheoAvpGVe3duxfTpk2zepvt27fjhRdecGKubDcYKzmCIOD3v/89cnNz9V5TqVTo6ekRX3v88ccNorOzZs1ySA9nIiIie40bNw5JSUn46KOPxNe8vb1NBqoOHTqElJQUJCUl2Tya+17mrDpOXV0dNm3ahJKSEotp58+fj9deew1hYWEDOiYAXLhwAefOnTObJjw8HPPnzx/w1INERETkmQZjGw4RkafSaDSora1FWVkZbt26Zdc+fHx8EBcXh4SEBMhkMsdm0EE0Gg1aWlrEYJQ2MGVuBFR3dzfq6urEwFT/GV7UajWqqqoA9AWxdNvkTYmMjMSsWbMgkUiwc+dOyOXyAX0ud/DIbqF79uzB6tWrbWowys/P97hA1WAkkUjw/PPPQyqV4s9//rP4mr+/PyQSiXiR7du3DxqNBg8//LC47alTp9Db24sJEya4Je9EREQVFRV6nS2sSa/7L7lXZGQk/vu//xtvv/023nnnHYM5uHUVFhbi+9//PrKzswc8tcGUKVPg7++PkydPmuyp1tTUhIMHD2LhwoUICgoa0PGIiIiIiIiGovb2dly/fh3Xr1+HSqWyax/Dhw9HQkICoqOjPWpWi+7uboOAVEtLi9nnVqAvmNXQ0ICamhrU1NSgvr7e7DZSqRQ+Pj7o6enRm+XMHKVSCYlEgoiICId05nQHz/lL//+2b98OAGhubsbMmTP11kMyRqFQoKKiAsXFxa7I3j1BIpHgJz/5Cby8vPDHP/5RfM3f3x8AxGDVJ598Ao1Gg29+85vitmfPnkVPTw+mTp3q+owTEdE9LzEx0ab0+fn5TsoJ2cvb2xs/+clP8NBDD2Hjxo1oaGgwmfb27dtYtWoVVq9ejZ/+9KcDeogZN24c/Pz8cPToUZMj8O7evYvPPvsMCxYsGJQ91IiIiFyloqICmZmZep2B4uLisGXLFpvra+bk5uYiJycHSqUSACCTyZCRkYH09HSHHYOIiMwTBAF1dXUoKytDXV2dXfvw8fFBbGwsEhIS3B5oEQQBbW1tBlP3dXR0WL19c3OzGJiqq6szO8LKmOHDh6OmpsbslH+62tvb0djYiE2bNg3Kaf8ADwxUff755zh06BAAoLKy0qoAlCAIg/YP4MmeffZZSKVS/O53vxNf046s6urqAgD885//hEajwbe+9S0xzfnz56FWqx1a+SQiIrJGcnIyiouLsWDBAotpDx06hLy8PEgkEosdY8j1ZsyYgU8++QS/+MUvzAYUBUHAzp07ceLECWzfvh1jxoyx+5hRUVFITk5GYWGhyQeJzs5O5OfnY+7cuRg1apTdxyIiIhqq8vLykJqaiqysLOzZs0d8PTc3F0lJScjKysKmTZsGdIzi4mKkpqZCJpNh586dYvuDUqlEUlISlErlgI9BRETmdXR0iKOnrA3i9BceHo6EhATExMS4ZfRUb28vlEqlXkBKqVRaNd2erra2NnEqvxs3bqC9vd2m7SUSCaRSKXx9feHr64sRI0bg6tWrNu3jzJkzg7ptw+PWqMrLy8OyZcts3k4ikZjs/eouQ2V+47/85S/YsWOH3mtdXV16i98tWbIEjzzyiF6a+++/HzNnzmQQkYiIXEapVCIuLg6FhYXiWpfG1qjauXMn1q5dK3Z2ycrK4hTCNnBlHUcQBOzZswdvvPGGxYV3AwMD8corr+A//uM/BnTMlpYWHD582OzDhZeXF77xjW8gJiZmQMciIiIaSioqKhAfH4+lS5fqBam0srOzkZmZifz8fCQnJw/oGMnJyQadWXJzc5GRkYHExEScPXvWpv0OlTYcIiJnEgQBt27dQllZGWpra60e8aNLKpUiJiYG999/v0tnqujs7DSYuq+1tdWuz9Dd3Y3a2loxOKVQKKze1svLC76+vvDx8RH/9fHx0WtDP3fuHMrLy23O18aNG5GdnW3zdp7A4wJVLS0tCAsLQ05ODmbMmGHVQmn5+flYt24dA1VO9MEHHxic5P2DVYsWLTLowR4XF4eHH36YwSoiInKZ3NxcrF27FsuWLUNycjIyMjJQXFyM8vJynD59Grm5uVAqlWKQKjEx0aZ1Mck9dZzy8nJs2LAB165ds5j2u9/9Ll5++WUEBgbafbyOjg4cPnxYnErIlKSkJK7PSURE9P9LTU1FXl4ezp49a3SWFaVSibCwMMTFxdnVAAf03XsrKipQWVlp0GZUXFyMhQsXIj09HVlZWTbtdyi14RAROZpKpUJ5eTnKyspsHi2kFRYWhoSEBMTGxsLHx8fBOfw3QRBw9+5dvYBUc3Oz3WtmAX0jr+rr68URU/X19VYFuLSjpHSDUqZGjo0ePRoxMTH45z//iSNHjtiVT29vb3R3d8PLy8uu7d3J4wJVAPDoo4/i888/t2mbtWvX4p133nFSjuzjrErO4cOH8ZOf/ATHjx+3KpDnKLt27cJvfvMbvde6u7v1LvKUlBSDXlFjx47FnDlzBuUFQkREg5M2WGWqo4S2+hMXF4eCgoIBjYrJzc3Fnj17xCkCtPvNyMjA0qVLTW6XmpoKpVIp9vqNi4uDUqnEmTNnkJ+fLzbyDORe76z1IdzVkNPV1YXt27dj9+7dFtOOGTMGO3bswOTJk+0+Xnd3N7744guz62QBwIQJE5CYmMiOOUREdM/T3gvNNTWFhYWJ0yzZWs/RjphKT09HTk7OQLJqgIEqIiJ9giCgvr4eZWVluHHjhl0jj7y9vRETE4OEhAQMHz7c4XlUq9UGa0kplcoBD2gRBAFNTU24ceMGbty4gdraWrPTAUokEr1glPZfc+3hoaGhmDp1KqZNmwZ/f39s3rwZX3zxxYDyDfRNAZiUlDTg/biaRwaqSkpK8OCDDzp9G2dzRiWnrKwMkyZNQk9PD4KDg3H69Gk88MADA82q1T788EO89tpreq/1D1YlJycjOTlZr7EmMjISc+fOhbe3t8vySkRE97aWlhb85je/wd69e/UCNQCQmJiIjIwMrFmzZkDHSElJQWJiIrZs2aLX0JKZmYns7GwkJibi0KFDRhthUlJSUFBQYHLfA12/QXd9CN39aBt4BrJ/dzfkFBUV4cUXX0Rzc7PZdN7e3nj++eexatUquzvM9Pb24ssvv0RNTY3ZdDExMfjGN77BjjlERHTPKi4uRlJSEmQymdl7dFJSEoqLi7Fnzx6znXqM0Qa5BjJ1oCnurt8QEXmKzs5OlJeX4/r167h7965d+5DJZOLoKV9fX4fkq6OjwyAoZW/+jLl7964YmKqpqTG57lb/qft8fX0hlUotdlwcNmwYJk2ahKlTp2Lq1KkYO3YsTpw4gYyMDFy4cMEhn0EikUChULh0cIujeGSgaqhwdCWntbUVY8aMQWtrq/iaj48P/vWvfyElJWVAebXFxx9/jFdffVXvtZ6eHr2Ld8GCBXj00Uf1LtCRI0di3rx5blkYj4iIqLKyEnK5HKGhoQ7Znzbgs2nTJqNTy2gbUky9bypQlZycjKysrAGNeHL2+hCe0JDT2NiIzZs348SJExbTPvTQQ3jjjTcM8mwtQRBw5swZi4vZjho1CnPnznXqNBZERESeSls3sjStn7YOZKqOZIq2fgP0TQmsVCrFkeMKhUIcNW5N8Ov27dsGr925cwcTJ07Ue42BKiK6lzQ0NODatWu4ceMGNBqNzdt7e3sjOjoaCQkJAyo7NRoNWltbDabu6+rqsnufxnR1demtM2Wsk4V2/SjdwJS1AzG8vLyQkJAgjppKSEgQ28Xz8vLws5/9DHV1dQ79TPPmzcPhw4cH5WwfHh0xaG1tRUhIiMHrlZWVKCkpweOPP+6GXLmHRqPB1KlT9YJUQF+AaNGiRfjTn/6EdevWuSQvy5Ytg7e3N37xi1+IQz59fHwQEBAgBqsOHz4MjUaDxx57TLww6uvrcejQIcyfP99hkXQiIiJrxcbGGn3dVH3DEu0C3Xl5eUYbWWbMmIGCggIUFxeb3UdcXJw44isuLs4hPZ8yMzMBAFu2bDH6fnp6OjIzM5GRkWH3+hDudt999+Hdd9/Fe++9h9///vdmp3Y4ceIEfvCDH+D111/HvHnzbD6WRCLBzJkzERAQgJKSEpPpbt26hfz8fMyfPx/+/v42H4eIiGgws7SuY3/9R7xbolunKi4uRk5ODvbs2SPWnbSjyU111NFlb+cVIqKhpqurCxUVFSgrKzNod7ZWSEgIEhISEBcXh2HDhtm0bXd3N5RKpV5QSqlU2hUos0StVqO+vl4MTDU0NIht215eXhg2bJhBUMrWgE9UVJQ4Ymry5Ml6z4UajQavv/46tm/fbvM90xr+/v74wx/+MCiDVICHBqoOHz6M1NRUtLS0iA/7umJjY5GXl4dFixYhLy8PwcHBbsqp6yQnJ6O6utroe4Ig4Nlnn8WVK1fw+9//3iX5eeKJJ+Dl5YWXXnpJL1gVGBiIjo4OCIKAoqIiaDQaLFmyRLxAbt++jYKCAixcuNDmgouIiMjRSkpK8PHHH2Pr1q02b5uVlQWZTIbly5cbff/MmTMAYHFklEwmG9DoKWPy8vLMHlsmk0Emk6GiogJKpXJQTgsA9D1MrF69GrNnz8YLL7yAGzdumEzb3NyMZ599FmlpaXjhhRfsqodMmjQJ/v7++Oqrr0zOz65QKHDw4EEsXLjwnqijEhERaTU1NTl1/wqFQvz/1q1bxU5DWkuXLkVWVhYyMzORmppqMVhFRHQva2xsRFlZGWpqauxaz8nLywtjx45FQkICIiIirNqmra1Nb4RUc3Mz2trabD62tQRBwJ07d8TA1M2bN9HT0wNvb2/4+voiODhYDErZOytGWFiYGJiaOnUq5HK5QZqbN28iMzMTeXl56OzsHOjHMunHP/4xJk2a5LT9O5vHBapaWlr01jf6/PPPDQJVALBx40YIgoCYmBgUFxcjOjra1Vl1qWeeeQZffPGF2WjyW2+9hWvXruFf//qXS9ZH+MEPfgCpVIotW7aI+ZJKpeLIKkEQcOTIEfT29uI73/mO+DdVKBT4/PPPkZyczN7GRETkNq2trfjoo4+wc+dOuwJVMpnM5HQ1eXl5YgDI1KgmZ9H2NrYUfIqLi0NxcTEKCgpsXh/C00yZMgX79u3Dr3/9a/zzn/80m3b37t04c+YMduzYgbi4OJuPFRcXBz8/Pxw5cgRqtdpomra2Nnz22WdYsGABwsPDbT4GERHRYOTKe15GRobR17WjxvPy8lBcXOzwzkBERINZd3e3OHqqpaXFrn0EBweLo6f8/PyMpunt7UVLS4veWlLNzc3o6ekZSPatcvfuXdTU1KCmpga1tbXo6ekRg1FhYWHw8fGxeuo+Y/z8/DB58mRxOr/IyEijI5haW1tx6tQp/PKXv8RXX31lVzBw5MiRaG1tNblWlq6oqChs3rx50I6mAjwwUKVtKBIEQVyc3JRNmzYhJycHKSkpuHbtmquy6BZpaWmIi4vDvHnz0N3dbTLdZ599hkmTJuHs2bMICAhwer6+853vwMvLC5mZmXrBqsDAQLS3t0MQBHz55ZfQaDT43ve+J14sLS0tYrAqMDDQ6fkkIqKh4dChQ3j00Ucdvt/Dhw9jwYIFDtmX7voM+fn5ZgNGCoUC2dnZyM/PF3sJx8XFISMjw+4FwrUjuYz15NKlff/06dNmA1Wm1nDwNIGBgXjjjTfwzW9+E7/85S/NVuavXr2KpUuXYvPmzUhNTbW5Mj969GikpKSgsLDQZI+4rq4u5OfnY+7cuRg9erRN+yciIhqMtHUe3ZFP5liqq5hLP2PGDLN5AICCggIGqoiI0Pf8VlZWhqqqKrsCJhKJBGPGjEFCQgJGjhyp9/zU1dVlEJBqaWkxOQOFo3V2dqK2thZ1dXVoaGhAW1ubOG1feHj4gAM33t7euP/++8URUwkJCSYDXd3d3bh48SKOHTuGd955B5cvX7bre4iLi8OaNWuwcOFCXLt2DT/84Q/N7kcikeC3v/3toO8k6XGBKm2v3qysLJNrSehau3YtMjMzsWPHDmzYsMEFOXSfiIgI7Nu3D0899ZTZOUOvXLmCsWPHorS0FFFRUU7P17e//W14e3tj48aNYmHn7e2tF6z66quvoNFo8P3vf18c7XX37l0cPHgQKSkpnBqHiIissnDhQoSGhjp0PmeJRII9e/YMKFCVkZGBgoICca2F5ORkvTUTTElNTUVWVhby8/PF13Jzc5GSkmLzAuNajl4fYrCt4fCd73wH06dPxwsvvIALFy6YTNfZ2YlXX30VX375JX71q18hNDTUpuOEh4dj0aJFOHTokMnpKtRqNQoLC/HQQw+Ji78TERENVaaCR/1pA1kpKSk27V836GSujiWTyaBUKs1ORdjY2Gjw2p07dzBx4kSb8kRE5Kl6enpQWVmJsrIyNDc327WPoKAgjBs3DvHx8fDz80NbWxtqamr0pu6zZrSPI6nVaiiVSty+fRs3b95EQ0MDfHx8IJVKxVFTAzV27FgxMDVx4kSzM4JpNBpcv34dpaWlOH78OP75z3+isrLS5mNKJBI8+OCDePXVVzFnzhzxc0ybNg25ubk4cuSIyW3nzp2L733vezYf09N4XKCqpKQEhw8ftnpRc23l5H/+53+GdKDq5s2baG5uxsiRI7F//36kpaWZXLMK6JsbOiEhAUeOHMHMmTOdnr/HHnsMXl5e2LBhg16wKigoCO3t7dBoNDh58iQ0Gg0ef/xxMVjV0dGBgwcPIjk5edCuj0FERK61bNky5ObmIi4uzujUbWfOnIFSqTT5vpZCoUBxcTEWLlw44DUVcnJyxP8XFBQgIyMDsbGxyMrKQnp6utFtUlJSkJWVZdDTNz09HXv27EF2djZmzpxp87R8zl4fYjAYM2YMdu/ejT/84Q949913zfY+y8/Px/nz57Ft2zarG9i0goODsWjRIhQWFprsPa7tsKNSqTB58mSb9k9ERDSYaOs0ljrNaDvJ2DraKS4uTgxCVVRUWJzC11zP8hEjRth0bCKiwaKpqUkcPWVqqnJzJBIJRo0ahfvuuw++vr5QKpU4cuQImpub7drfQHh5eSEkJASdnZ1oaGhAdXU1qqur9fLhiGVl5HK5OJXflClTLAa7BEHArVu3UFpainPnzuH69evYv38/6uvrbT62VCrFkiVL8Nvf/haxsbEGI8B8fX3xhz/8AYmJiUZHw3l7e+MPf/iD3WtseRKPC1SFhoZaHaQCIC6eaak38GAXFhaGpqYmdHd3w8/PD3v27MFzzz2HEydOmNyms7MTDz30ED788EOTC7070qOPPorf//73+NnPfiYWGF5eXuLIKo1Gg9OnT0MQBDzxxBNisKqzsxP5+flYuHChzUP/iYjo3pOSkoLKykocPHjQ4L2WlhbExsYiLy8Pjz/+uMV9ZWZmoqqqCh999JHD8pecnIzy8nKEhYWJ6ycYC1Zt2rTJ5D60I7TWrFljc6BqsA/3dxSpVIr/9//+Hx5++GFkZmYancJQq6GhAStXrkRGRgaeffZZm+Ys9/f3R0pKCo4cOYJbt26ZTFdaWgqVSoUZM2YM6nnDiYiIzElOTkZBQYHJ9aGUSqVVHYpMSU9PR3Z2NoqLi01Ok6wNlA32NTiJiKylVqtRVVWFa9euWT39qlZ3dzfa29vR29sLmUyGwMBA3Lp1Czdv3nRSbo3z9fVFWFgY5HI5ent7UVtbi4qKCnz++ee4e/euQ4/l7++PKVOmiKOmRo8ebdUzWktLC0pLS1FaWorGxkYxf7Z+5wAQEBAg3tMsBZnq6+sRGhpq9DihoaGor6/HlClTbM6Dp5EIrpow0krLli3D2rVrrZ5+Z9y4caioqBADOZ7k9u3bBtPlNDY22t1zp6enB+Xl5Whra8P169eRkJCArKws7Nmzx+K2v/zlL/GLX/zCruPaqqioCM8//7zeAnkajUYMVgF9PadSU1PFYBUA+Pj4YMGCBezZREREZrW0tGDr1q144403DN5bvnw5kpOTsWbNGqv3J5fLsW3bNjzzzDOOzCays7ORmZkJAGhubrZp5HBFRYU4VVx5eblNDTnaNbJkMpnZKR5SUlJQUFCA9PR0vRFh/VkbVBlIHcfZmpub8dJLL6GwsNBi2gcffBDZ2dmIjIy06RgajQbHjx9HVVWV2XRjx47FN7/5zQEt4EtEROSpiouLkZSUhKVLlxptq8jMzER2djb27NljNJBUUFCA1NRULFu2zGj9RKlUistEVFZWGtSvtPUve6ZQdnQbDhGRszU3N6OsrAyVlZV67bDGCIIAlUqF9vZ28aejowOBgYEYOXIkwsLCXNahLjg4GGFhYeKPj48PKioqcO7cOZw/fx4NDQ0OPZ63tzfGjx8vBqbi4+Otfh7r6urC119/jZKSElRVVUEQBFy4cAGFhYUmp4A3Z/jw4Xj99ddNzrzSn0qlwre//W3U1taivLxcbFsH+gaIxMfHY8yYMfjXv/4FPz8/m/PjSTwuUJWbm4udO3fi9OnTFtNu2bIFWVlZkEgkSExMtGobV3JGJUej0eAPf/gD/vGPf2D+/PlYvHgxPv74Y2zfvt3i4mxPPvkkPvzwQ7uPbYujR4/ipz/9Kbq7u8XXBEEQI/QAMH36dCxfvlwvWCWVSjFv3jyMHDnSJfkkIqKhJSEhAWfPnrVpdLZ2hIuj6xEFBQXi2gs5OTl6FdHU1FQAMNnZRDdQZaohxxRtA5GlQFVSUhKKi4st7t/YSCRjazh4ekOOIAj48MMPsW3bNr36iTHBwcH45S9/iccee8zmY5SUlODSpUtm00VEROCRRx6Br6+vTfsnIiIaDLSdZvoHi0y9rkvbkQYw3dFHW9fpvyaoNkhlKkhmCQNVRDQYqNVqVFdXo6ysDHfu3DGZpqOjwyAopQ1y+Pr64r777kNERIRTgxve3t6QyWRiQEoul0Mmk0EQBFy5cgXnz5/H+fPnUVFRYbFd21bR0dF660zZ8jl7e3tRVlaG0tJSXL58GWq1GoIg4MSJE/jqq6/Q2dlpc37i4uLwhz/8AUuWLLFpu9/97nfIzc0VR83pBiR9fHwQExMDqVSKjIwMPP/88zbny5N4XKAK6BslNW7cOOzZswfBwcEG77e2tiIzMxO5ubkQBEFcBN2aKX5cyRmVnE8//RQffPABVCoVOjs78Y1vfAPf//73ceLECfzsZz8zOlelrpkzZ+L48eOQSp0/6+OXX36Jn/zkJ+jq6hJf6x+smjJlCp588km9KLa3tzfmzp1rc09mIiIib29vi/fC/uRyOVpaWmzaTqlUisGgQ4cOmW1EAaDXIKMbhMrPzzc6bY3utmfPnrV5DQdtTzhz1bywsDAolUqbR2wBg7sh5+rVq3jhhRdQXl5uMe3jjz+OF1980eZ5zy9fvixOT22KTCbDggULEBAQYNO+iYiIBoOKigpkZmbqLdMgl8uNrs+py9KIKi2lUomtW7eioKBAPMaMGTOQkZFh95R/g7l+Q0RDn1KpRFlZGSoqKvSCFV1dXXoBqba2Nr22WF0ymUwcPaU7cMAR/Pz8xGCUNjAVEhICiUQCjUaDyspKnD9/HufOncOVK1csjgCz1fDhw8V1piZPnmzTjCZA37NzXV0dSktLcf78ebS3twPoC1oVFhaiuLjYrjW6EhMT8c4772DmzJlW56OjowNNTU24cOGCOBCkubkZKpUKEokEgiCIMRHt39THxwf//Oc/ER0dbXMePYVHBqqKi4vF3s1Lly5FXFwc4uPjUV5ejoqKCuTl5QH4d+NLamqqQ9eWcBRHV3Ly8/PxzjvviL9r5xBNSkpCamoqampq8KMf/QgdHR1m9xMZGYnz58+7ZD2oEydO4Nlnn9WLNGsvOO3FPXnyZDz55JN6wTOJRII5c+YM6ouLiIhcb9y4cdi5cyfmz59vVfqSkhIkJSVBIpHYFKjKy8sTR0WZCjbppuk/akkikZidck/bI9jSqChTtL2RTQW5lEolwsLCEBcXZ1XApj9nNeRUVlaK0/k4U2dnJ7KysqyqP8bGxmL79u2YMGGCTceoqqrC8ePH9aZm6C8gIAALFy5EaGioTfsmIiIix2Ogiog8TW9vrzh6qqGhQZy6r62tTRwlZSl44uPjg4iICIeNnpJIJAgODtYLSIWFhel17hMEAQ0NDeKIqQsXLtg1TZ45AQEBeutMjRo1yq6pC5ubm8V1p3RHqHV1deHzzz/HxYsXzT7TmbJgwQLk5uaKnVSBvu/l7t27aGpqMvvT1dUlztbR1NQEtVqNzs5OMTilDVYBfX/fUaNGISAgAHPmzEFOTs6gXRPZIwNVwL970bS0tBh8ubpZ9tQgFeDYSs6xY8fwu9/9zqBntFqtRnt7OyZOnIi0tDS0t7fjySefRGNjo9n9BQUF4dSpUzY3utjj1KlTWLt2rUGwSqVSidFzbf77B6seeughvQuaiIjInMzMTOzbtw/FxcVGR2XramlpQWxsLFpaWmyeQlgb6DE3tUxqairy8vKMBoO0a0iZmvZGO9rJVKDJUm/jga4PYYkzGnIOHTqERx99FCkpKdi/f7/De/gZk5+fj5dffhmtra1m0/n4+GD9+vX44Q9/aFO+6uvr8cUXX5jtLejr64v58+ezEYyIiMjNGKgiIk9x584dFBcX4+LFi1AqlWJQypZm/NDQUIwcORJyudzuZyupVKoXjJLL5QgNDTU6U1draysuXLggBqcstU3bk5f+60zZ+7lUKpW47lR1dbXee62trThw4IBdHTq9vb2RkpIiznrWPwClUCisHknW0NCAc+fOoaenRxwhpw1S9T+mr68vxowZA4lEgrfeestoR9rBwGMDVVqZmZnYu3ev3nBxmUyGGTNmIDMzEwsXLnRj7sxzZCXnyJEj+MMf/mA0gqvRaNDW1ob4+Hj86Ec/gpeXF5555hlcvHjR7D6lUin++c9/YvHixTbnx1Znz55Feno6VCqV+Fr/YNWECROwYsUKg8Ju1qxZuP/++52eRyIiGvxaWloQExMDb29vbNmyBRs2bDBI09raiq1btyI3NxfNzc2QSCTIycnB6tWrbTpWXl4etm7dii1btiA5OVmcWkA7FU12djbi4uKQn59vdGq9lJQUMVilfb+4uBipqalQKBTYuXOnySCSNes3DGR9CEsc3ZBz/vx5JCUlib0BH3zwQZw6dcolUxXX19dj06ZNOHPmjMW0c+bMwdatWxEeHm71/hUKBQ4fPmx2HnNvb2/MmTMHY8aMsXq/RERE5FgMVBGRO/X29uLSpUv4/PPPcf36dbv2IZVKxdFTtk5fHhAQoBeQCgsLQ1BQkMnROV1dXbhy5QrOnTuH8+fPo7Ky0q48mxMbGytO5zd+/HgMGzbM7n319vbi2rVrKCkpwZUrVwxmVLl9+zb279+Puro6m/ft5eWFmJgYTJ482SHPsN3d3SgqKhKDk9rwjbG/hY+PDwCIf7MxY8bgs88+G5Sjqjw+UKWrsrJSjNwOBo6u5Jw6dQo7duwQF3DTPeG0az+NHj0azzzzDPz9/fHSSy/hs88+M7tPbaT1Jz/5iV15skVxcTEyMjLEOT6Bvnx3dnaKi5o/8MAD+OEPfyheZFqJiYkGi7YTEREZozuFMNDXwUUbCKqoqIBSqQTw7xHaKSkpOHjwoF3HqqioQE5ODgoKCqBUKqFQKCCXyxEXF4fU1FSkp6eb3T4vLw85OTmoqKiAQqFAXFwckpOTsWXLFrNzalu7foO960NY4sg6Tk1NDR544AGDQE5MTAwuXrzokjWcent7sXPnTvzpT3+yOAVkeHg4tm7dijlz5li9/7a2Nhw6dAh37941mUYikWDWrFlISEiwer9ERETkOAxUEZG79PT04I9//CPKyspsGjWlFRISgpEjRyI8PNziKCOJRILQ0FCDqfssBYE0Gg3Ky8vFEVNXrlyxa80mc0aMGIFp06Zh6tSpmDJlCkJCQga0P0EQcOPGDXHdKd0BFFpVVVU4ePAgmpqabN6/VCrFuHHjMH78eIfMCNLT04OamhpUVVWJz47aQSumAk8+Pj4QBAFSqRQxMTEAgKKiIoP72WAwqAJVg40zKjnnz5/HK6+8gvLyckRFRRnM/6lSqTB8+HCsXr0aQUFB2Llzp9kGLK1nn30Wf/rTn+zOl7XOnTuHNWvWGMxLqlKpxGBVQkICfvSjHxkEq6ZMmYJp06Y5PY9ERDT4VVRUICMjA4cOHQIAg84dWsnJydizZ8+g6QTjKRxVx1EqlYiJiUFLS4vR94cPH46LFy+6rJJdUlKCjRs34ubNmxbTrly5Ej/72c/g6+tr1b47OztRWFho8QFIO5UFERERuRYDVUTkDtXV1Th79iwuXLiA+vp6q7eTSqUYMWIERo4cabJzn4+Pj0FAKjQ0FN7e3hb3LwgC6uvrxRFTX3/9td7gA0cICgrSW2cqIiLCISOBmpqaUFpaijNnzqCurg4qlcrgp7a2FtXV1VZPxadr2LBhGD9+vMOWq9EGqGpqasTgn+5oKnMjqry8vODl5YXw8HCOqLLH8uXL8e6771pcO8JRx9q5c+eAI7D2cEYl586dO3j99ddRUFCA3t5eREdHGxRGXV1dCAwMRHp6OmQyGQ4ePIiXX37Z4sJvycnJOHjwoNPXhPj666/xzDPPGPQq7uzsFOfcHDduHFauXGkQrJowYQKSkpKcmj8iIho6CgoKkJWVJQasgH9PIZyRkYEnnnjCjbkbvBxVx/nFL36BX//612bTBAYGoqSkxGUjje7evYtXX30VBw4csJh24sSJ2L59u9hzzRK1Wo2jR49anE5i3LhxmD179qB8uCAiIhqsGKgiIldSKpU4ffo0GhoaAADt7e0oLS21uF1wcDBGjhyJ4cOH67XhBgUF6QWktFP32Zqnr7/+WgxO3blzx6btLfHx8cH48ePFUVOxsbF2tUNrB2vorv908+ZNXLhwAVevXsWtW7f0lpvR3U6pVOLOnTsW28mNCQgIwJQpUxAZGWnztsYYC1BpqdVqsZ1cd1SVl5cXJBIJAgICIJFI0NHRwTWqBqKiogLLly/H4cOHnRqsWrduHeLi4rBx40anHcMcR1dympubsXPnTrS0tECpVOLYsWPo6enB2LFjERgYqJe2p6cHvr6+WLNmjdgbec2aNeKoJVMSEhJQWlrq9Gl2Ll68iGeeecZg8fKuri5x6p+4uDg8/fTTBj2VExISMGvWLDbeEBERuYkj6zg//vGP8ec//9lsGl9fXxw5cgSzZ8+2ef/2EAQBn3zyCV577TWj00Po0k63/P3vf9+quolGo8HJkyctLs4bFRWFOXPmuGSdLiIiImKgiohco6enR5w6r3+z/Pnz541OF+7t7Y377rsPERERCA4Ohkwm01tLSiaTWT3Tg66uri5cvHhRnM6vurra7s9ljEQiQVxcnDhiavz48RbzKQgC7t69C4VCoReI6v/T2dkJjUaDtrY2KJVKtLW1mZw2URAE3LlzB83NzXZPrTh9+nQMHz7c5m2N0Qaobt68CY1GA29vb0ilUnh7e+v9NDY2oqOjAxqNRgxkBQcHIyAgAIIgQKFQAABGjRqFoKAgzJkzBzk5OYO2zdxtU//l5uZi27ZtKCgoQHR0tMP3v3btWlRUVODzzz93+L6t5chKTmtrK3bu3CmegEBfj9+jR4+is7MTY8aMMQj69fb2wsvLC8888wxGjhyJhoYGPPXUUyan19GSy+UoKSnB2LFjbc6nLa5cuYJVq1aJa4Vo6QarYmJisGrVKoN5UuPi4vDwww8P2guPiIhoMHN0Q85rr72Gl19+2Wwab29v7Nu3D9/97nftOoY9qqqqsGHDBly+fNli2iVLluCVV16xuhNWaWkpvv76a7NpRowYgfnz59v10ElERES2YaCKiJytsrISxcXFJjvDNTY2oqysTPw9LCwMEyZMwAMPPIARI0YgLCwMISEhds+G1dvba7DOlKU1em0VERGBqVOnYtq0aZg8ebLe85EgCGhpaTEbgGpqajI7HZ8gCOjo6EBLSwtaWlrMjozSaDRobGy02BZuSnh4OB588EGbZ2qTSqUIDw83+Bk2bBiKiorwf//3f+JoKXN6enpw48YN8Xe1Wg1fX1/IZDIolUr09PTA398fw4cPR1BQED799FOnxFlcxa1rVGVnZ2PLli3IzMzEb37zG4fss7S0FGvWrIFcLrd7YXRHcWQl59NPP8WJEycMXu/o6MCRI0fQ3t6OqKgogzU2tPNY/uhHP8KYMWPQ2dmJFStWoKqqyuzxhg0bhsLCQjz88MM259UWV69exapVq9Dc3Kz3end3t1hox8TE4Omnn4afn59emrFjx2LOnDlOn6qQiIg8y70yhbAnc0ZDzl/+8hesWbPGbA83iUSCd955B+np6XYfx1bd3d343e9+hw8++MBi2sjISGzbtg3Tp0+3at/Xrl3DqVOnzKYJCQnBwoULDUbPExERkWMxUEVEztLc3IzTp0+jsbHRbDqNRoPi4mKMHDkSjz32mNXPFaYIgoCbN2+KgakLFy5YnDHCVsHBwZgyZQomTZqE6OhoeHt7mwxAKRQKuwNjXV1dUCqVaGlpsbiulFqtRkNDA9ra2uw61siRI/Hggw/C39/f4L1hw4YZDULp/gQHB+sNrmhpacFf//pX/O1vf7Npna+QkBAMHz4cFy5cgEajQX19PQRBgL+/P1QqFSQSCUaOHAmpVIqnn34av/jFL+z6vJ7CrYEqoC9YtXnzZowbN05cK8Laef61SktLUVBQgI8++gjFxcVIT0/H22+/7ZwM28CRlRy1Wo2PPvoIly5dMnivs7MTR48eRWtrK0aPHo2wsDC99wVBgEajwVNPPYX4+HhoNBr87Gc/w/Hjx80e08vLC//93/+NtLQ0m/Nri7KyMjz99NN6o8WAvqhxR0cHgL6g1KpVqwwKiNGjR+ORRx6xahFAIiIaGu6VKYQ9mbMacvbv34/vfve7Fh9efvnLX7q8En7s2DFs3rzZoL7Sn7e3N3784x9jzZo1VtVPampq8OWXX5r9zP7+/li4cCFkMpmt2SYiIiIrMVBFRI7W3d2N8+fP4+rVq1ZNOSeRSPDAAw9g2rRp8PHxseuYSqUS58+fF9eZsvT8Yg2NRoOenh50d3ejt7cXERERCA8PR1BQEDQaDRQKhd3T6pmjVqvFkVPWBNi6u7tRX19vVzBOIpEgNjYWjz76KEaPHm0yCKVdG8oaAwlQPf3003jiiSdw7do1PP/886ivr8fdu3dx9+5dSCQSCIKA4OBgcc2yt956C4mJiQazkg0mbg9UAX0LnaemporrFWkXOZfJZIiLi0N4eLhe+qamJiiVSlRUVKCgoAAAxAthz549HrMwuqMrORqNBnl5eTh37pzBe93d3Th27Biam5sxatQoyOVygzS9vb1ITU3F+PHjAQA7duzA3//+d4vHffnll/GrX/3Krjxbq6KiAitXrjRYpE83WBUVFYXVq1cbBKsiIiIwb948uwtwIiIafO6FKYQ9mTMbck6fPo1vfetbFqdCWLt2rcs7JjU1NWHLli04duyYxbQzZ85EdnY2IiIiLKZtbGxEYWGh2Z6BPj4+mDdvnlX7IyIiItsxUEVEjiIIAioqKlBSUiIub2JJREQEZs6caXPnNJVKhUuXLomjpmpqamzaXqPRoLu7W/zp6urS+727uxvDhg1DSEgIQkNDERwc7NTZrTQaDe7evSuuO2UNlUqFhoYGq6bT68/f3x8rV65EVlaWwzrCtrS04IMPPsCuXbtsClCFhobi6aefxlNPPYWgoCCUlZWhtbUVRUVF2L59OzQaDZqbm6HRaODl5YXw8HBIJBJs2LAB8+bNQ0hICBISEhzyGdzBIwJVWpmZmdi2bRsAWB2Z1GY/PT0dWVlZBlPfuZMzKjmCIOAf//gHTp8+bfBeT08Pjh8/jjt37iAiIsLoAm8ajQbf+973MGXKFAB9gb3s7GyLEe/U1FR8/PHHdufbGpWVlVi5ciVu376t97pusCoyMhKrV69GQECAXprhw4djwYIFXMOBiOgeMtSnEPZkzm7IKS8vx/Tp0y0+mHz3u9/FP/7xD4cc01oajQZ/+9vfsGPHDnFBW1NCQkLw2muvITk52eJ+lUolDh8+LNZ5jPHy8sKcOXOcvo4oERHRvYiBKiJyBIVCgdOnTxu0b5ri7++PpKQkq2cY6+3tRVlZmRiYunbtmsnZGXp7ey0GoYw90/j5+SE0NBShoaEICQmBVCq1Km/20q47pVQq0draanbdKV13797F7du3LU4FaEx4eDh+/vOf42c/+5nDAm9KpRJ//etfBxyg0u6rvLwc3d3dKC4uxvvvv48bN26gt7cXSqUSMpkMPj4+GD9+PNauXYv4+HhIJBLEx8cP2pk4PCpQBfRFHHNycvDxxx+juLjYbNrExEQkJydjy5YtHhWg0nJWJUcQBBw4cABffvmlwXu9vb04ceIE6uvrMWLECIwYMcIg6KfRaLBkyRIkJiYCAE6dOoXnnnvOYmNLUlISTpw44dTCqbq6GitXrkRDQ4Pe62q1Gh0dHRAEAaNGjcKaNWsM1moICwvDwoULDdayIiKioWsoTyHsyVzRkHPnzh1MnDjR4gPerFmz8NVXX7l8zcpLly7hhRdesLjuJ9C31llmZqbFOkpHRwcOHTpkcbHfmTNn4oEHHrAlu0RERGQBA1VENBDd3d0oLS1FWVmZ1dP8TZgwAVOmTDE7S5QgCKirqxOn8rt48SJUKhXUarVB0Kl/IMra9aCkUqkYmAoNDXXZ9HGdnZ3i1H7Ggk0SiQR+fn7w9/fX+6mtrcW5c+fsmuJvzJgx2Lp1q0OXunFkgEqrpKQEN2/eRGVlJZqbm9Ha2or/+Z//QW9vL1QqFfz9/eHt7Y3169eLMYDhw4dj2LBhmDx5ssM+myt5XKCqv5KSEigUClRUVAAA4uLiIJfLERcX55HBKV3OrOQIgoBDhw6hsLDQ4D2NRoPTp0+jtrYW4eHhiIiIMBqsevTRRzFr1iwAfQGiH/7wh2Z78QJ9a0KdO3fO6GgtR7lx4wZWrlyJW7du6b3eP1i1evVqg4s4NDQUycnJRhe7IyKioWmoTiHsyVzVkNPR0YEpU6aI9UBTEhIScP78eZd3Vuno6MBvfvMb7Nu3z2La+Ph47NixA/fff7/ZdN3d3SgsLLQYoJs8efKAF1cmIiKif2OgiojsIQgCysvLUVJSYvXUc6NGjcLMmTMREhJi9P2amhocPXoUxcXF+Prrr6FQKAyCUtaOOjLGy8sLISEh4nR+tqy7NFA9PT1obW0Vn9/9/f0REBBgEIzy9/eHn5+fmC9BEPDll1/i5MmTdk3xN378eLz11ltISUlx2GdRKpXiFH+W2tR1mQtQ9fT0oKamBidOnIBGo0FNTQ00Gg3CwsJw4sQJHD58WEy7cOFCpKSkwMvLC97e3khISIBEIsHUqVMH5RI5Hh+oGsxcUck5cuSI0amJBEFAcXExqqqqEBYWhlGjRhkUOIIgYMGCBXjooYcgkUjQ2tqKp556CvX19WaPGRgYiBMnTjg1OltXV4eVK1eirq5O7/Xe3l60t7dDEARERERgzZo1BvOHBgUFITk52eBCJyKioW2oTSHsyVzZkKNWq/HQQw/h7NmzZtNFRETg66+/dmpnGlMOHDiAV155xeJUhb6+vti4cSOeeuops+dob28vjh07hhs3bpjdX1xcHB566CGXjyYjIiIaihioIiJbNTU14dSpU2hqarIqfUBAAGbMmGF0Ku/S0lJ89NFHOHTokEF7qCMEBQWJI6aCgoKc+gzh6+uL4cOHQy6XIzw8HKGhoWhvb0dDQwPu3LkDf39/+Pr6WvXcrlarcejQIZSWllo9QkzX7Nmz8c477zi0k99AA1RpaWkGM4X19PSgvr4et2/fhiAIuH79Onp6eqBUKtHc3Axvb2+MGjUKn332Ga5du4b7778fjz32GO7cuYORI0fivvvu44gqMs1VlZwTJ07g008/NXhdEARcuHABZWVlkMlkGD16tNEC4Fvf+hbmzJkDiUQCtVqNNWvW4MKFC2aPKZVK8Y9//ANLlixx2Ofo7+bNm3j66acNGml0g1UjRoxARkaGQbAqICAAycnJJnsmEBHR0DSUphD2ZO5oyPn2t7+N/fv3m00TEhKC0tJSxMbGOi0fptTV1WHjxo0oLS21mHb+/Pl47bXXEBYWZjKNIAg4deoUysrKzO5r9OjRmDt3rtPnjSciIhrqGKgiImt1dXWhpKQE169ftyq9l5cXJk6ciMmTJxvU25VKJfLz8/Hmm2+ipqbGYXl01jpT/v7+CA8PN/sTGBgIQRBQUVGB0tJSXLx4Ed3d3TYdR6VS4eDBg7h8+bJVUynq8vLyQkpKCnJychAdHW3Ttua4IkCldffuXdTW1kIQBNTW1kKtViMkJEScMcbHxwcajQZqtRq+vr5co4rMc2Ulp7i4GPv27TO4cAVBwJUrV3Dp0iWEhIQgKirKaLDqG9/4BubNmyf+/sorr+Bf//qX2WNKJBL89re/xfPPP++Qz2BMfX09Vq5caVBQazQatLe3Q6PRYMSIEUhPTzcISvn5+SE5OXnQXpxERDRwg3kKYU/mroac1atX4y9/+YvZNMOGDcPx48fFtThdqbe3F3/+85+Rk5NjcSqO++67D1lZWZg9e7bZdBcuXMC5c+fMpgkPD8f8+fO5TicREdEAMFBFRJYIgoCysjKUlpZaHXgZPXo0ZsyYYdBuWVZWhv379+PLL79Eb28vbt++jfLycrvz5uPjoxeYsmedqeDgYISHh4sjoYz9WFpupb6+HqWlpTh37pw4vZ8tWlpasH//flRWVtq8rVQqxbJly/CnP/3Joe3Bzc3N4hpUzg5Q6aqpqUF7ezs6OjrQ0NAAiUSC6OhojB49Gn5+fqiqqoIgCBgzZgyCgoIQEhKChISEAX1Wd2KgyolcXcm5cOECPv74Y6MNI2VlZTh//jyCgoIwZswYo8M7Z8yYgUWLFokXx3vvvYc///nPFo+7du1apy4639DQgKefftpgsXLdYNXw4cORnp5u0Ojo6+uLhQsXGqxPQkRERPZzZ0POyy+/jNdee81sGm9vb/zrX//CokWLnJ4fY86cOYONGzeioaHBbDqJRILVq1fjpz/9qdkejtevX8fJkyfN9iQMDg7GwoULOfUxERGRnRioIiJz7ty5g1OnTkGhUFiVPjAwEDNmzMCYMWPE13p6evDll1/iwIEDBqOxuru7Lc4Koku7zpQ2OOXv7292Kj2ZTGZ2FJRcLoevr6/Vx9fV2tqKc+fOoaSkxOIzkCkNDQ04cOAAbt68afO2/v7+WLNmDbKyshzaec/eAJVMJhPXoDIVoLpz547Fzo1dXV2orKyEIAhoamqCj48PIiIiEBMTg+rqanR0dCA4OFgcmDJp0iS7ApSegoEqJ3JHJefKlSv4+9//DrVabfBeVVUVzp49i4CAAIwdOxbe3t4GaaZNm4bvfe974vYFBQX4+c9/bvHCWbBgAfLz8502v+nt27fx9NNPGyymrtFo0NHRgd7eXsjlcmRkZBhEzH18fDB//nyDvwURERHZx90NOW+//TZ+/OMfmw3cSCQSfPDBB/iv//ovl+Spv5aWFvziF79Afn6+xbRTpkzB9u3b9R5i+6utrcXRo0fNzsvu5+eHBQsWQC6X25VnIiKie5m76zdE5Jk6OztRUlJi9Wgnb29vTJw4EZMmTRI7ozU1NeHgwYPIz883O8ro3LlzUKlURt+TSCQIDAw0WGdKIpHojYAyNhpKLpc7fKrwrq4uXLx4EaWlpaioqLB5ej6tyspKFBYWor6+3uZtZTIZXnjhBWzZssWhbdLuDlD1zwvQF/jUfs8hISFobW0Vp/rz8fHBqFGjMHr0aKv364kYqHIid1VyysvL8be//Q09PT0G79XW1uLUqVPw8/NDdHS00WDVxIkT8Z//+Z/o7OwE0Bf8euaZZ9DV1WX2uOPGjUNJSYnTevI2NTVh5cqVBjcGQRDQ3t6O3t5ehIWFIT093aCBRiqV4pFHHsGoUaOckjciIqJ7iSc05Pzv//4vli5darGSn5WVhU2bNrkoV/oEQcCePXvwxhtviPUqUwIDA/HKK6/gP/7jP0ymuX37NgoLC81OM8I6DxERkX08oX5DRJ5DEARcu3YN586ds3qav8jISMyYMQPBwcEQBAGXLl3C/v37cerUKauCE1VVVXoBm4CAAERFRSE2NhYPPPAARo0aZRCECg0NNdq+6wwajQbXr19HaWkpLl26ZLTt2VpVVVX4/PPPcefOHZu3HTVqFH71q19h9erVdh/fGGcFqBoaGnD79m2bAlTa4JNcLselS5fQ3d2NO3fu4Pbt22KaESNGYPjw4fD19cWkSZOcNoDEVRiociJ3VnKqq6vx17/+1Whwqb6+Hl999RV8fX0RHR1tNKI+btw4rFq1Cm1tbQD6PstTTz0lRnFNCQsLQ0lJiUMXqtOlUCiwatUqXLt2Te913WCVTCZDenq6wXR/Xl5emDt3LqKiopySNyIionuFs+o4nZ2dNk3V8OWXX2L+/PkWH5Cee+45/P73vx9Q3gaivLwcGzZsMKi/GPPd734XL7/8ssEDjlZraysOHTqE9vZ2k/uQSCT4xje+gdjYWLvzTEREdK9hoIqItBobG3H69GmL7aBaQUFBmDlzJiIjI9HV1YUjR47gwIEDqK6utum4LS0taG5uxty5c/Ff//VfmD59utnp/FxBEATcunULJSUlOH/+vNhWbI+AgABcv34dn3zyCZRKpc3bJyQk4M033zTbuc8ezc3N+OCDD7Br1y6TI9qMkclkWLVqFZ588kmHB6iGDx8u/u2VSiXKy8shCALKy8vR09MDHx8fxMfHi6OqHLkml7swUOVE7q7k3Lx5E++//77RCPDt27dx/PhxeHt7Izo6Gj4+PgZpxo4di5/85CdoaWmBIAjo7OzEf/3XfxlMv9ffsGHDcOjQIXzzm9902GfR1dzcjFWrVuHq1at6rwuCgI6ODqjVaoSEhCAjIwPDhw/XSyORSDBnzhynBdKIiIjuBc6o45SWlmL//v1ITU21aQHYy5cvY+bMmWYDNwCwdOlS7Nmzx+78DVRXVxe2b9+O3bt3W0w7ZswY7NixA5MnTzb6vkqlwuHDhy0+OCclJWHChAl25ZeIiOhe4+42HCJyP5VKhZKSEottn1re3t6YPHkyJk6ciDt37uDAgQM4fPiwxWcTY+677z489thjHrPurFKpFNed0h3FYyupVIqEhAQUFhbi73//u02BIK3ExET8+c9/xuzZs+3OhzEDDVA99dRTCAgI0HtPrVajvr7ergDVyJEjMXz4cKMjo8rKytDa2orGxkYcOHAAlZWVSEhIwLp162x6fvZkDFQ5kSdUchobG/Hee+/h7t27Bu81Nzfj2LFjEAQBMTExRhfMGzlyJF544QW0trZCrVZDo9Fgw4YNOHr0qNnjenl54f3333fauhAtLS145plncOnSJb3XBUGASqVCT08PQkJCkJ6ebvB9SyQSPPTQQ4iPj3dK3oiIiIY6R9dx7ty5gz/96U/ilBpz585FcnKy1VNY1NfXY9KkSRYXNv7Wt76FoqIit06JUFhYiBdffNFiD0Jvb288//zzWLVqldH89vT0oKioyOJixRMmTEBiYqLbe2ISERF5Ok9owyEi99BoNOI0f9ZOZzdmzBgkJiaivLwc+/fvR3FxsV3rNE2bNg2LFy9GUlKS26du6+zsxNdff43S0lJUVlbavR+JRILY2FiMGzcO7777Lj766CObpwmUSCSYN28ecnJyHB6IGSwBqq+//hqffPIJjhw5gsuXL6OhoUHvewwLC8OtW7cwbNgwq4/nyTwuULVt2zZs3rwZ8fHxVk2P4sk8pZLT1NSE9957z2iDSEtLi7gwd0xMjNETOzw8HFu2bEFHR4e4vsJvf/tbq3oE//znP8frr78+4M9gTGtrK1avXo2vv/5a73XdYFVwcDDS09MN/g4AMHPmTDzwwANOyRsREdFQ5sg6jlqtxjvvvINbt27pvT527FgsX77c6ikM2traMGnSJNTU1JhNN378eJw7d85oBx1XaWxsxObNm3HixAmLaR9++GG88cYbRr/b3t5eHD9+3OKUIjExMXj44YddNnc9ERHRYOQpbThE5FoNDQ04ffq01VPRBQcHY/Lkybhy5Qo+++wz3Lx50+Zj+vn5Yf78+Vi8eDEiIyNt3t6Rent7UVZWhtLSUly+fBlqtdrufd13332YPn06IiIisHHjRuzfv9+moA3Q12Hve9/7Ht5++22j7bkDoVAo8MEHH2D37t0ODVA1NDSgsbHR4mcVBAHd3d1QqVRQq9UIDAyEr68vFAoFjhw5gjNnzuD69etobGxER0eHxcCnt7f3gP5ensbjAlVyuRxKpRISiQTNzc0ICQlxd5bs5kmVHKVSiffeew9NTU0G77W1teHo0aPo6upCTEyM0bUhQkJC8OKLL0IQBLS2tgIAPvnkE7z++usWL5rHH38ce/fudcwH6efu3btYs2YNzp8/r/e6dqrC7u5uBAUFIT09HREREQbbP/jgg5g0aZJT8kZERDRUObKO8+mnn5oM2Pj5+eGJJ57AxIkTrdqXWq1GYmIiLly4YDbd6NGjcfHiRbfO463RaPDee+/h97//PXp7e82mDQsLw+uvv4558+YZvCcIAs6ePYsrV66Y3cfIkSPxyCOPGJ3umYiIyJjDhw9jwYIF7s6Gy3hSGw4ROZ9KpcLZs2dRVVVlVXqpVIrhw4ejvLwcR44cETvz22L06NFYsmQJ5s2bB39/f5u3dxRBEFBXVyeuO2Vs2RhrBQUFYdq0aZg+fToUCgXWrl2L48eP2zy6bNiwYVi5ciXefPNNg2DQQNkboAoLCxPXoDI1gqqurg7t7e1QqVRGfzo7O6FSqcQBIM3NzWhoaEB9fT3u3LmDtra2AQWbFAoFwsLC7N7ek3hcoCo+Ph5VVVVIT0/H22+/7ZY85ObmIicnR4yky2QyZGRkID093ab9eFol5+7du3jvvffQ2Nho8J5KpcLRo0fR0dGBsWPHGi0QAgIC8OKLLyIgIECcm/T06dP46U9/avGCmj59Ok6ePOmU3sttbW3IyMhASUmJwXsqlQrd3d0IDAzEmjVrMGrUKIM0U6ZMwbRp0xyeLyIioqHKUXWc69ev4/3337eY7qGHHsLixYshlUotptVoNHj00Udx6NAhs+lkMhnOnTuHsWPHWp1fZ7hw4QJeeOEF3Lhxw2LatLQ0vPDCC0ZHwF+8eNFoXUhXWFgYFixY4NaHYiIiGjxmzpyJ06dPuzsbLuNpbThE5BwajQZXrlzB+fPnrQoQaDQaqFQqVFdX4+rVqzYfTyKRICkpCUuWLMHUqVPdOiV3c3MzSktLUVpaijt37ti9Hx8fH0ycOBEPPvgg4uPjcezYMfzkJz+x2GHQmODgYDz//PN45ZVXrHres4U9ASpBEBASEoKlS5ciOTkZGo0GbW1taG9vR3t7O1pbW1FfXy+OejLV6bCnpwc3b97EzZs3cefOHdy9exddXV2O/HgAgPfffx8rV650+H7dweMCVXl5eVi2bBmKi4sxffp0q7fbsmULtm7dOqBjFxcXIzU1FTKZDDt37kRiYiKAvtFISUlJyMjIwKZNm6zenydWcjo6OvD+++8bHZba1dWFY8eOobW1FWPHjkVgYKBBmmHDhmHz5s0YOXKk2KBy48YNrFixwuJCgSNHjsS5c+ccPmwTANrb25GRkYHi4mKD9zo7O9HV1YWAgACkp6cbDVZNmDABSUlJDs8XERG51lCaQtiTOaqO09vbi/z8fItrXwJ9vQ//8z//E+Hh4Vbte8WKFRanKfb398eJEycwdepUq/bpLG1tbfj1r3+NTz/91GLaBx54ADt27EBcXJzBexUVFfjqq6/M9l4MCgrCggULBvWsBURE5HybN2/Gtm3bLI76HUo8sQ2HiByrvr4ep0+fRktLi8W0KpUKlZWVuHHjhl0jjoKCgrBw4UIsWrTI6CxPrqJSqXDhwgWUlpZanDLcHIlEgvj4eEyfPh0TJ07EsGHDkJeXh40bN1o9Kk3Xfffdh1deeQXPPvus3XkyRaFQ4P3338eHH36Ijo4OaDQaaDQaCIIg/t/Ya76+vpg6dSomTZpkMBOFRqMRg1X9n7daW1tRXV2NhoYGKJVKswEsR3vyySfx4YcfuuRYzuZxgSoAyM7OxtmzZ/HRRx9Zvc1Ae/pUVFQgPj4eycnJyM/P13svNzcXGRkZSExMxNmzZ63ep6dWcjo7O/HXv/7V6BoO3d3dOH78OBQKBcaOHYugoCCDNFKpFBs2bMD48eNRUVGB3t5etLW14cknnzRYX6K/gIAAfPXVV05pEOro6MC6deuMngddXV3o7OyEv78/1qxZY3T+13HjxmH27NlcbJyIaBAbSlMIezJH13GuXr2KvLw8iw+Avr6++P73v2/1SOhNmzZh27ZtZtNIpVIcPHjQI6Y2+vTTT/HLX/7S4vfg5+eHzZs3IzU11aDecvPmTRw5csRs79Bhw4Zh/vz5GD58uEPyTUREQ8e7776LzMxMcYYZBqrc34ZDRAPX0dGBs2fPWhWouX37Ns6fP4/6+nr4+/vb3E4YHR2NJUuW4Fvf+pbRmRBcobe3F1evXkVpaSmuXLkyoLJ81KhRmDZtGqZNmyY+X//xj3/Er371K3HGLVvExMRg27ZtWLp0qV356e7uFgNG2p+2tjZ0dHTg1q1bOHjwII7/f+ydd1wUd/rHP1vodekgvUgREQG7sQG2xBRjSdfY8HKXS2JDTYxJLhcDmksudyli1MQYG2piNJYAGo1dAREQkV4Elrp02Da/P7ydHyuzlQUW+L5fL16JM9+Z+Q5l55nv53k+z9Wr6OzspIUoVZiYmGDUqFEICgpSKlCJxWJUVFSgvLyctu3TxgJSV3C5XLzwwgv48ccf+20OukTvhKrz588DAI4cOYLU1FRs2rRJaf8AgUCApKQkJCQk9OiPLjw8HIWFhSgqKup2vbS0NERGRmLVqlWIi4tT+5z6HOQIhULs378fBQUF3faJxWJcu3YNNTU1cHV1ZVzkY7PZePPNNzF27Fjk5+fTf/yrVq3CnTt3lF6bw+Hg+PHjePrpp3V1OzTt7e144403cOPGjW77ZGKVsbExVqxYATc3t25jvLy8MHHiRCJWEQgEwgBFHyyEhwK9EeM0NTXh8OHDamXjhYeH46mnnlLLUviLL77AO++8o3QMm83GgQMHsHjxYnWn22uUlZVh3bp1atlmREdH46OPPoKVlZXc9rq6Oly4cEHpSxOXy8UTTzzR782bCQQCgdD/NDU1Ydu2bUhISIBAIKAX9VgsFhGq9GQNh0AgaIdEIsH9+/eRmZmpNJFLKpUiPz8fGRkZEAgEsLa21siGjs1mY/z48Zg7dy4CAgL6ZV2RoiiUlZUhPT0dmZmZGvViehxLS0uMGjUKo0ePpqvBxGIxPvzwQ/z73/9Gc3OzxuccOXIk/vvf/2LKlCly20UiES02PS5AdRWiZP8vEom6nbu9vR13795FVlaWRv2elAlUdXV1uHfvHkpLS1FfX9+nVVKPw2KxYGxsDB6PB3d3dwQHByMiIgJ2dnaYPHlyv1bs6RK9E6rU6SmgCG1/WWQVU6tWrcLOnTu1OgcT+h7kiMViHDx4kLH5tkQiwc2bN1FRUYFhw4YpFAtXrVqFyMhIFBQUoKWlBQDw4YcfqmVds2PHDqxdu7ZH98BER0cH/va3v+Hq1avd9gmFQrS3t8PY2BjLly9n7Evh5uaGyZMng8Ph6HxuBAKBQOhd+tNCeCjRWzGOVCrFhQsXcOHCBZWZbw4ODnjhhRfUCsoPHz6Ml156CVKpVOm4zz//HG+//bYmU+4VxGIx/vOf/+C7775T+X1wdHTE9u3bERERIbe9ubkZKSkpdHzGBIvFwvjx4+Hj46OTeRMIBAJhYFFcXIy4uDgkJCQAeLTIKVtclf0/Ear0Zw2HQCBoRkVFBW7fvo2mpiaFY1pbW5GVlYXMzEwIhULweDwYGxurfQ0rKytER0dj5syZaluU65q6ujq671R9fb3W5zE0NERwcDBCQ0Ph5eUFNpsN4FE12po1a/D9999r1WNp1KhRWLNmDRwdHbuJUS0tLYzCk7roQqBisVgoLi5GYWEhKisrUV9f3yORr6cYGBjAzs4Ovr6+iIiIwFNPPYXRo0fDzMxMrUTNgYzeCVWyBSYWi6VWaZ6MngRQPB6PrsyKiorS6hxMpY61tbUICgqS26ZvQY5EIkFiYiJj1q5UKkVqaipKS0vh4uICHo/HeI5XXnkFzz77LEpKSlBXVwcA+OGHH/Cf//xH5fVXrFiBXbt29ewmGOjs7MSbb76Jy5cvd9snEonQ1tYGIyMjLFu2DJ6ent3GuLi4YMqUKTpv4kcgEAiE3qc/LISHGr29kFNYWIgjR46ozNTjcrl46qmnEBERoTJr8fz585g1a5bKF5j169cjPj5e4zn3BtevX0dsbKxKSw02m42YmBi88cYbcok2HR0dOH/+vMoX1tDQUAQHB+tkzgQCgUDQf86fP4+4uDgkJycD+H9RSrYG4+3tDWtra6SnpxOhSs/WcAgEgmpaW1tx+/ZtlJWVMe6nKApVVVXIyMhAXl4egEcVRBYWFmpXQvn5+WHu3LmYMGFCt0qcvqCtrQ2ZmZlIT09XeJ/qwGaz4evri9DQUAQGBsoJIdXV1fjLX/6CEydOaPwskPWzmjNnDiwsLLSenyLa29uRkZGB7OxsjQQqAwMD2NjYQCQSoa6uDk1NTRodr0tYLBZ4PB68vLwQERGBqKgozJ49m7ENz1BB74Qq4NEfibe3NxYsWKBSja6rq0NqairOnz+vVQAl600FAAUFBRAIBIiNjUVhYSHq6+vh7e2NTZs2qfTNVPeDTB+DHKlUip9//hlpaWnd9lEUhTt37qCwsBBOTk4Kfx7z58/HSy+9BD6fj4cPHwIALly4gNjYWJXZy1OmTMGFCxdopV5XCIVCvPXWW7h48WK3fTKxytDQEMuXL2cUqxwdHTFt2rR+eeAQCAQCQTv6y0J4qNEXCzmtra1ITEykXx6VERISgmeffValB3xWVhbGjh2rMkPu1Vdfxb59+zSab29RX1+P9957D3/88YfKsaNHj8b27dvh4uJCbxOJRLh06ZLKPqL+/v5qCX4EAoFAGLh89913iIuLQ2FhIQB0Sw5esGABNm3ahNGjRwN41Mc5Pz+/z+fZXxChikAY2EgkEty7dw9ZWVmM73ZisRh5eXm4c+cOqqurAQBmZmawtrZWy1WJy+Vi0qRJmDNnDvz8/HQ+f1WIxWLcv38fd+7cQW5ursr1VkVIpVLY2trCz88PHh4eoCgKbW1tdLVTfn4+du/ejQcPHmh8bjabjREjRiA6OlqjyjR10USgEolEEAqFEIvFkEqlWn+/dIGxsTGcnJwQFBSEyZMn48knn0RISEi/zUdf0UuhatGiRVi9erVGTa21DaCOHj2KhQsXAgASExOxc+dOJCYm0otasv0LFixAYmKiwvMMZKEKeBSgnjp1CtevX2fcl52djdzcXDg4OCic/5w5c7B8+XI0NjaiqKgIUqkUubm5WLZsmcrSUG9vb2RkZOhcNRYKhVizZg29cNkVsViM1tZWGBgYYNmyZfD29u42xs7ODjNmzBj0pZUEAoEwWOgPC+GhSG8s5HR2dnYTmiiKwp9//omkpCSVLxY2NjZ44YUXVPZcKi0txahRo+gm8YqIjIzE77//rvNEGm2gKAoHDhzA9u3bIRQKlY61sLDAhx9+iNmzZ9PbpFIprl27hqKiIqXHuru7Y9KkScT+mEAgEAYRj/efAuQFKhaLhfXr12PTpk3deh4uWrQIR44c6cvp9itEqCIQBi4PHz7E7du3GR0ZmpubcffuXWRnZ9MJawYGBmrb/NnY2GD27NmIiorq9jnZ21AUhZKSEqSnpyMrK4uxB61UKqVFGZFI1O3/Zf/mcDiwsbGBjY0NzMzMup2noqICZ86cAZ/P13ieBgYGCAsLw9SpU3vFnUqZQCWVSun7lYlS/QWLxYK1tTW8vb0RFhaGyMhIzJkzB5aWlv02p4GEXgpV58+fh42NjUa9JbZv347169drfC1ZfyoACAsLQ2pqarcx8fHxiI2NVSpWDXShCnj04ff777/j0qVLjPtzc3ORlZUFOzs7ODg4MN7z1KlT8de//hWdnZ3Iz8+HSCRCbW0tXnrpJZW2M9bW1khLS4OXl5dO7keGSCTCunXrkJSU1G2fWCxGW1sbuFwuli5dCl9f325jeDweIiMjeyUTgEAgEAi6pT8shIciul7IEYlEyMzMhKmpKRwdHWFtbS0XZ5SWluLw4cMqxSUOh4PZs2djwoQJSmMzgUCAESNGoKKiQun5Ro4cibS0NL2xAs7NzcXatWvpTHhlPP/889i8eTNMTEwAPIrz0tPTce/ePaXHOTg4YNq0aSRJh0AgEAY4TP2nurJgwQJ4e3tj+/btJAb6H0SoIhAGHi0tLbh9+zbKy8vltlMUhfLycty9excFBQX0ZyCbzYaVlRXMzc1VruUGBQVh7ty5GDt2bJ8ncpWUlODatWtIT09HXV2dQiFKKBQq/QzncDiwt7eHk5MTrKysGO85Ly8PycnJaGho0HiexsbGmDBhAsaNG9crCX6PC1Rdq6QkEolG7/y6xsjIiK6SmjhxIp566imEhIToRaLjQEXvhKrt27dj48aN8PHx0arEUFO6ClU7d+7EqlWruo0RCAR0f6bU1FSEhYV1GzMYhCrg0Qf5xYsXGUUd4JE94p07d2BjYwMnJyfG+x43bhzeeecdAEB+fj7a2togFArx2muvqax6MzQ0RFJSEqZMmdLzm+mCWCzG+vXrce7cuW77JBIJWltbweFwsHTpUsbyXUtLS0RFRcHU1FSn8yIQCASC7ulLC+Ghiq4Xch4+fIiqqir630ZGRnB0dIStrS0d6Le3t+P48eMqhRYACAwMxPPPP0+LNEwIhUKEhoYiJydH6bnc3d2RnZ2tN17hHR0d+PTTT9XKcPfy8sKOHTsQGBhIb7t//z5u376t9Dhra2vMmDGDxD0EAoEwAGHqPyXD2toaq1atoqunjh07hkWLFpEY6H8QoYpAGDhIJBJkZWXh3r17cp9hIpEI9+/fR0ZGBurq6uSOUcfmz9DQEFOnTsWcOXPg4eHRa/N/HJkr1blz53DlyhWVCXXKYLFYsLGxod+nFN3vnTt3cPHiRbS2tmp8DQsLC0ybNg0jR47Uep5MsNlsmJmZobGxEefOnUNubi4txvWnhGFlZQUvLy+Eh4cjMjISTz75JKmS6gX0TqiysbGBQCAAi8VCQ0NDr//Qu1r/KRKhgP8XouLi4rBhw4Zu+5maXNfW1iIoKEhu20AJcq5evYrffvuNcV9paSlu374NKysruLi4MIpVo0aNQmxsLAwMDFBcXIyGhgZIpVJs2LBBZY8FFouF3bt34/XXX9fFrdBIJBLExsbi9OnTjPtkYtVrr70Gf3//bmPMzc0RFRWlNwtVBAKBQGCmLy2Ehyq6XMiRSCTIzMxkXCTjcrmwt7eHg4MDuFwuKIrCjRs3cPr0aZWLalZWVli8eLHSF0ypVIrp06crrCaXYWNjg8zMTLneT/1NUlIStmzZgqamJqXjDAwMsGbNGrz66qu06FdcXIyrV68qtcUwNTVFZGRkn9ubEAgEAkE7lPWfCgsLQ0xMDFauXCl3DBGq5CFCFYEwMCgrK0NqaipaWlrobQKBgLb3e9wq29DQEDweT2k/WwcHB8yZMwczZszos3W/9vZ25OXl4f79+3jw4AEuXryItrY2rc9nYWEBJycn2NvbK3RHkFmCX79+XWWbFiZsbW0RHR3N2D6FCZnwZGpqCnNzc5iZmcl9GRsbIzMzE1evXkVGRgby8vJQW1vbb/Z9BgYGsLW1haenJ0JDQ/HMM88gMjISBgYG/TKfoYbeCVU+Pj4oLi7GqlWr8M033/T69QoLC+Hj4wPgUbWQoj80Ho8HgUCADRs2IC4uTq1zD/Qg59atWzhx4gSjYl1RUYEbN27A3Nwcrq6ujGJVQEAANm/eDDMzM7lM6S+//FKtBuWafK/VRSKRYPPmzTh58iTjvtbWVrDZbLz66qty2ccyTE1NERUVRVRzAoFA0GP60kJ4qKLLGIfP53ez6ngcNpsNW1tbODg4wNjYGBUVFTh06FC3LEmm46KiojBlyhSl1e8LFy7E0aNHlZ7L1NQUt2/fZowP+ouqqips2LBBZYUUAEyePBnbtm2jqwyrqqpw8eJFiEQihccYGhpi+vTpAyZ2JRAIhKHMzJkz6Soq2TNvwYIF2LhxI0aPHs14DBGq5BnoazgEwmCnubkZt27doquNZP2bMjIyUFJS0m39Uh2bv1GjRmHu3LkICwvrdcs2iqJQW1uL+/fvIzc3FyUlJXKCTFFREUpKSjQ6p7GxMRwdHeHo6KjUDUEsFiMlJQUZGRndejypg7OzM+bOnQtnZ2eYmprKiU1MApRsm7GxMf29r6iowMmTJ/HHH38gIyMDZWVlcmJjX2Nubg4XFxf4+/tjzJgxeOKJJ2BhYQEOhwNHR0c4ODiQ3r19jN4JVbLeEmlpaRotMG3atAnbtm3T6poyESopKQlRUVFKxyiqqGJiMAQ5GRkZOHr0KKOSzefzce3aNZiamsLV1ZXxA93Lywvvv/8+LC0tUVdXRz84fv31V/zjH/9QWbb5zDPP4Pjx4zp9WEgkEmzZsgW//PJLt31SqZQueX311Ve7VcQBjx4CkZGRtB0kgUAgEPSHvrYQHqroKsahKApZWVndsh6VYW1tDUdHRxgYGODEiRPIyMhQeYyvry8WLlyoNDvyrbfewpdffqn0PAYGBjh//jwmT56s9nx7G4lEgoSEBHz99dcqFxptbW2xbds2ev4NDQ04f/483VSaCQ6Hg8mTJ8PNzU2n8yYQCASC7ikqKsKnn36KXbt2AQBiYmKwevVqjBo1inE8EarkGQxrOATCYEQsFtM2f1KpFJ2dncjJyUFGRobCHrbm5uawsrJiFBpMTEwwffp0zJkzp9cdE8RiMYqLi2lxqr6+XuHYtrY23Lx5U+U5Za4TTk5OsLS0VJqQ19HRgbNnz+L+/fsaVymxWCxMmDABcXFx8Pf3h5mZGUxMTFS2vxGLxbh8+TLOnDmDGzdu4MGDB6ipqdFKINMFXC4Xtra28PLywsiRIzF58mQEBgZ2W2smAlX/o3dCFQDEx8cjNTUVhw8fVvuYMWPG4NatW1pdLzY2FvHx8UpFKNkfobKqq8cZLEHOvXv3cOjQIcbgta6uDleuXIGhoSHc3d0ZBaVhw4Zh69atsLW1RUtLCwoKCiAWi5GWloa//vWvSjN5gUeNzG/fvq3Tpt5SqRRbt27FsWPHGPfJxKqXX34ZwcHB3cYYGhoiMjJSZe8TAoFAIPQtfW0hPFTRVYwjEolQXFys0r6OCTMzMzg6OqKgoACnTp1SGU+Ym5tj0aJFdCU9E59++ik2bdqk9DxsNhtHjhzB888/r/Gce5P09HSsX79eLT/7pUuX4u2334ahoSFaWlpw/vx5pT8DFouFsWPHMvbxJBAIBIJ+kpCQgPj4eBQVFSEsLAybN2/Gc889JzeGCFXyDJY1HAJhMCFrP9LW1oa6ujpkZGQgJydHoeihzOZv2LBhmDNnDqZNm6a0l21PaWlpQW5uLnJzc5GXl6dRUl5aWhpjXM5isWBra9utjy/TOFNTUwiFQhw9ehT37t3TuLcTl8vFggUL8NVXX8HGxkbp2KqqKvz666/4448/cPfuXZSWlqK5uVmj6+kSmf2hv78/IiIi8MQTT6i0MicClf6gd0LV+fPnAQBHjhxBamoqNm3aBGtra4XjZZVQCQkJWgdXAoEAXl5eAB5lID1+vfj4eMTGxmpsRTeYgpy8vDzs37+f8UEgEAhw+fJlcDgcuLu7M/5R29vb44MPPoCTkxM6OztRUFCA9vZ2PHz4EC+//LLKUk8HBwdkZGTAyclJZ/cklUrx0UcfMTYjl0qlaGtrA0VRePHFFxESEtJtjIGBAaZPn97tZ0wgEAiE/qOvLYSHKrqOcdra2sDn89HQ0KDxi5SRkRHYbDbOnTuH2tpapWNZLBamTp2KyMhIhS93+/btw9KlS5XOg8Vi4auvvsJf/vIXjeba2zQ3N+ODDz7AmTNnVI4NCgrCjh074Onpic7OTly4cEHl9y8kJIQxJiIQCASC/pKcnIy4uDikpKSAx+Nh8+bNWLlyJSwtLYlQ9RiDaQ2HQBjoNDU14datW3j48CEKCwtx9+5dlJWVKRzPZrNhbW0NMzMzuYofFouFMWPGYM6cORg5cqTKaiBtoCgKlZWVdNWUKltzZTx8+BB5eXn0v62srODh4QFvb2/weDyVlnu5ubl44403cOPGDY2vbWxsjBUrVmD79u0wNjaW2yeVSuWqpHJzc1FdXd1vVVKGhoZwcHBAQEAAxo0bh/Hjx2PYsGEaVY0RgUr/0DuhaubMmUhJSdHq2J4EV2lpaQgPD0dUVBQSExNpsUomUi1YsACJiYkanXOwBTlFRUXYt28fYyZAc3Mz/vzzT1AUBQ8PD3C53G5jeDwe3n//fbi7u0MikaCoqAiNjY1oa2vDiy++iIcPHyq9vomJCa5evaqRJaQqpFIp/vnPf+LgwYPd9lEUhdbWVlAUhcWLFzNel8PhYNq0aXB2dtbZnAgEAoGgPf1hITwU6a0YRygUorq6GrW1tRrHdRRF4e7du8jLy1NpGezh4YHFixcrzK47d+4cnnzySZVz2LJlCz766CON5tnbUBSFn3/+GR9//DE6OjqUjjUxMcF7772HZ599FhKJBH/++afKeMzX1xfjxo3rlZd8AoFAIPQehYWFiIuLw65du8BisbBw4UJ4eXkhPj6eCFX/Y7Ct4RAIAxGxWIzMzEykpaUhMzMTd+/eVVmhY25uDmtra7l3AHNzc0RGRmL27Nm9kmAuFApRUFBAV05p4xChiNLSUkyYMAFz5syBh4eHWu1QUlJS8Le//Q3379/X+HpWVlZYt24dNm/eDDabjerqarpKStb/qz+rpIyNjeHj44Pw8HBMmzYN8+bNg52dHaRSKaqrq8Hn8zUSzDgcDhwcHODo6EgEKj1D74Qq2QITi8XSKKOWxWL1OLgSCATYtm0bkpOTUVhYCACIiIhATEwMFixYoPH5BmOQU15ejr179zIufLS2tuLPP/+EWCyGh4cHDAwMuo0xNzfHli1b4OvrC4qiUF5ejurqakilUqxevRppaWlKr8/hcJCYmNjNsqAnUBSFbdu2Yf/+/Yz72traIJFIsHjxYsYmtGw2G0888QTp3UAgEAh6Ql9bCA9FejvGkUgkqK2tBZ/PV2np9zj5+fm4ceMGDAwMGBNnZJiYmGDBggUICAhg3J+WloaJEyeis7NT6fWWL1+O7777TqM59gVFRUVYt24dcnJyVI6dO3cutm7dCnNzc1y/fh0FBQVKx7u6umLy5MlKv78EAoFA0F9ktoCFhYVgsVhISEjA8uXLu41bvHixRvHUQGcwruEQCAOJkpISnD59GtevX0dubq7KdV5DQ0PY2NjItQrx9PTE3LlzMXnyZEb7v57Q0NBAC1OFhYU6qyaytraGv78/AgIC4OXlxbieqoiffvoJmzZtUlptpggnJye89tpr4HK59Pe8urpa4/cvXcLlcumf65IlS7B582aYmprKjRnqAhVFUaipqcH9+/fB4/EwcuTI/p6SztA7oQp4tPDv7e2NBQsWqOwBVFdXh9TUVJw/f17vsoAGa5BTWVmJvXv30n2cutLR0YE///wTHR0d8PDwYOwrZWJigk2bNmHEiBEAHn2fysrKQFEUPv74Y/zyyy8q56Csn5g2UBSF+Ph4/PDDD4z72traIBaLsXDhQkRERHQbw2KxMGnSJHh6eupsTgQCgUDQnP6wEB6K9FWMQ1EU6uvrwefz0d7ervZxAoEAv//+O5qbm2FmZqa0z+WkSZMwa9YsxpeVoqIihIaGqsyQnDt3Ln777Te159dXCIVCfPHFF/j+++9Vjh02bBi2b9+O0NBQZGRkIDMzU+l4e3t7TJs2TecLAAQCgUDoO7raArJYLMTExGDDhg30e62trS3q6ur6d5J9yGBdwyEQ9J3a2lr8+OOPuHDhAiorK1WO53A4sLKyom3+OBwOxo8fjzlz5iAgIEBnlf9SqRRlZWXIzc3F/fv3wefzdXJeFosFd3d3WpxycHDQaM5SqRRffPEFPvnkE60+ow0NDcHhcDR6v9I1bDYbBgYGMDIygpmZGSwsLMDhcGBra4sVK1Zg8eLFjPaDQ02gEovFKCwspG0lc3JykJubi4aGBgDAM888M6icYfRSqFq0aBFWr16NGTNmqH2Mr68v8vPze3FWmjOYg5yamhrs2bOHceFGKBTi8uXLaGlpgYeHB+MChoGBATZs2ICwsDAAj7xnCwsLIZFI8OOPP+Lf//63yjksXboUe/fu7fnN/A+KovDZZ59hz549jPva29shEomwYMECjBkzhvEcEyZMUNqknUAgEAi9S39ZCA81+iPGaWpqAp/PV9tWQywW4/r168jIyICBgQHMzc1hZGTE+BI4bNgwvPDCC4zNguvr6xEUFKTyxTQ8PBzXr1/Xyyqjy5cvY+PGjaivr1c6jsPh4K9//StWrlyJgoIC3Lx5U+l4S0tLREZGwszMTJfTJRAIBEIf87gtoCzJRyAQDKn4aDCv4RAI+kh1dTX27NmDs2fPMibDM9HV5s/a2hrR0dGYOXMmYxyvDe3t7cjLy8P9+/fx4MEDnYk5xsbG8PPzQ0BAAIYPH96tSkgdxGIxNm/ejK+//lrt75c+IKuSMjExgbm5OeO9qxKoampqUFVVpZVA5eDgoJfvaI/T1NSE+/fvy4lSBQUFSivc/P398fPPP/fhLHsXvRSqUlJSYGtrq1Fvie3bt2P9+vW9NyktGOxBTkNDA3bv3k2ruF0RiUS4evUqBAIBPDw8un3IAI8+MN5++21MnDgRwKNqrPz8fHR2duLSpUtYt26dyiZ4kyZNwqVLl9Tya1UHiqLw73//GwkJCYz7ZGLV/PnzMW7cOMZzREREKLQRIhAIBELv0p8WwkOJ/oxx2trawOfz0dDQoNbPuKioCCkpKejs7ASHw4GZmRlMTU27CVZGRkZ47rnnGK0TOjo6EBISItfYmAlvb29kZmZq9eLZ29TV1WHTpk24fPmyyrFjxoxBfHw8Ojs7ceXKFaV/GyYmJpgxYwZ4PJ4up0sgEAiEfqCxsRGffPIJtm/fDmDoxUeDfQ2HQNAHKIrCgwcP8OOPP+L8+fNq28wZGRmBx+PB0NAQw4cPx5w5czBhwgSNbPIUzae2tpYWB0pKSlSuRaqLvb09AgIC4O/vD3d3d62reVpaWvDmm2/iwIEDEAqFOplbb2BoaAg2mw1DQ0OYmZnB3NxcpUBka2uLlStXYtGiRToTqNhsNhwdHfVWoJJKpSgvL+8mSlVVVWl8Li6Xi9TU1B7/HegLeilUDRaGQpDT1NSEPXv2oKampts+iUSC69evo6amBh4eHjAxMek2hsVi4Y033qCr58RiMQoKCtDS0oIHDx5g2bJlKhuBe3h44O7du7C0tNTJPVEUhf/+97/45ptvGPd1dHRAKBTi2WefxYQJExjPERoaiuDgYJ3Mh0AgEAiaMVgshPUZfYhxhEIhqqurUVNTo/Jlsrm5Gb///jsd/LPZbFqwejzZZezYsZg7d263YF8qlWLixIm4ceOG0mvZ29sjKyurV5o29xSpVIp9+/bhX//6l8qXPUtLS3z88ccICQnBH3/8ofSl2MDAANOmTYOjo6Oup0wgEAiEfkAgEGDhwoVDLj7Sh/iGQBisyNyXfv75Z6Snp6vsAyuDw+HA2toaVlZWmDx5MubOndtjJyOxWIzi4mJaJFDlOqAuHA4Hnp6etDil6l1UFRUVFfjLX/6CU6dO6Uw80wVcLhf29vbw9/dHcHAwhEIhbty4oZGIZmdnhxUrVuhcoJJZ/OmLQNXR0YEHDx7IiVK5ubloa2vT2TV+/vln+Pv76+x8/YneC1XFxcVIS0vD/Pnz6W0pKSk4evQo4uPjYWFh0Y+zU85QCXJaW1uxd+9eRh9ZqVSKW7duoaKiAh4eHgozjF9//XU89dRTAB6JQaWlpaitrUV9fT1efPFFlZ6rlpaWuH37Nvz8/Hp+Q//j66+/xn//+1/Gfe3t7RAKhXj66acxadIkxjHBwcEaVQUSCAQCQTcMFgthfaY3Ypy2tjYYGRlpnGkokUhQU1OjsvGvRCLBrVu3kJaWRldisVgsmJiYwMzMTO5lxtHRES+++CLj/Tz77LM4ceKE0jmZm5vjzp07emsHfO/ePaxbtw7FxcUqxy5evBgxMTG4evWq0hcqNpuNSZMmwcPDQ4czJRAIBEJ/MtTio6GyhkMg9CU1NTU4d+4czp07h4cPH6K5uVntYy0sLODt7Y25c+ciKiqqRwnqLS0ttEiQl5ens8okMzMzWpjy9fXVSf/WU6dOYcWKFTrridUTzM3N4ebmhlGjRmHatGl48skn4erqitraWuzevRuHDh1SW3QE1BOo+Hy+2pV2gH4IVBRFobq6mu5nJhOliouLNXJ60YZPPvkEzz77bK9eo6/QW6Hq+PHjiI2NRWFhIVgsVjcFNTk5GYsXL8bRo0cxffr0fpqlcoZSkNPe3o4ffvgBZWVl3fZRFIW0tDSUlpbC3d1dYR+DF154AQsWLKCtePh8PsrLyyEUCvH6668jNzdX6RwMDAxw9uxZjRYmVZGQkIAvvviCcV9HRwc6Ozvx1FNP4YknnmAcExAQgIiICJ3Nh0AgEAiqGSwWwvpMb8Q4n3/+OcrKyhATE6NVRhhFUaivrwefz1fqJV9aWork5ORuY4yNjWFmZgZDQ0MAj+KKp59+GqNHj+5mE/iXv/wF3377rdL5GBkZ4c8//1TY17K/aWtrwz//+U+1PM19fHzw8ccfo7S0FI2NjUrHjhkzZtBk9BEIBMJQ59ixY3j++ef7exp9xlBawyEQehOKopCVlYXTp0/j5s2baGlpQWNjo9oVmkZGRpg4cSLmz5+PMWPGaGWZR1EUKisracGgvLxc43MowsXFBf7+/ggICMCwYcMYe+BqilQqxZo1a/D1119rJNLoCi6XCzs7OwwfPhzjxo3DrFmzMHXq1G7CT01NDXbv3o3Dhw9rLFCtXLkSCxcuZBSoamtrUVVVNSAEKpkb2OOiFFNrnN7GyckJb7zxBhYsWNDn1+4N9FKo2r59OzZu3Ajg0QeLIl/k5ORkzJo1C8nJyXopVg21IKezsxM//vgjioqKuu2jKAqZmZnIz8+Hm5ubwkq4efPmYcmSJfSHvEAgQFFREaRSKTZs2IDz588rnQOLxcK3336LVatW9fyG/sfu3bvx2WefMe7r7OxER0cHnnzySUyZMoVxjK+vL8aNG6eTBxeBQCAQCPqArmOcu3fv4sMPP6T/HRkZiVdffVXryvmmpiZUVVUpzNhsbW1FcnIy4wurzFNd9gIVGhqKp59+ult25EcffYStW7cqnQeHw8Evv/xCV43rI2fOnMHWrVvR0tKidJyhoSHWrFkDR0dHRsvnrowYMQKjR4/W5TQJBAKBQOh1htoaDoGgazo6OnDx4kWcPn2aTjxvaGhQW9AwNjbG7Nmz8corr2hVpS8UCmkBITc3F01NTRqfgwkDAwP4+vrC398f/v7+Oms9AgDl5eVYs2YNfvnllz4TqMzMzOgqqSlTpuCpp56Cu7u70mOGqkDV2NhIC1EyUaqgoKDPxUQulwtfX1+6ek/2X2tr6z6dR2+jd0JVeno6wsPD5bYpa+AZHR2NtLQ0ldZw/cFQDHJEIhEOHDiABw8edNtHURTu37+Pe/fuwdXVFVZWVozniIqKQkxMDN0zoq2tDQUFBRAKhfjqq6+wd+9elfNYs2aNQnFJG77//nvEx8cz7pOJVbNnz1YomHp6emLixInd+mAQCAQCoXcZyBbC+owuYxyRSIQ1a9agoqJCbruFhQVee+01TJ8+Xetkj7a2NvD5fDQ0NHSzXJBKpUhLS8PNmzcZ7Rg4HA7dx8re3h4vvPACnJ2d5cYkJCRg9erVSu0cWCwWdu3aheXLl2t1D33Bw4cPsX79ety5c0fl2KlTp+LJJ5+EQCBQOs7b2xvjx48nsQ+BQCAMAIqLiyEQCODt7a3TBdiBxlBcwyEQdEFlZSXOnDmD8+fPo729HVKpFAKBQGUilAxra2s8+eSTWLJkCXg8nkbXbmhooIWpwsJCjXoaqZqTTBDw8vLq1r+2pxw+fBgffPAB7t+/r9PzdoXD4cDe3h6+vr4YO3YsZs+ejalTp9IOEuowVAQqqVSKsrIyOUHq/v37dI/jvsTa2hoBAQH0l7+/P7y9vXX+O6iP6J1QtWjRIhw9ehRRUVGIjY1FeHg4bG1tFQpVu3btQkxMDDZu3IhPPvmkj2ernKEa5IjFYhw+fBj37t1j3J+Xl4e7d+/CxcVF4QNo0qRJeOutt+jyXpFIhIKCArS2tuLUqVP48MMPVXp8Pvnkk/j11191tkCyf/9+hb9jQqEQ7e3tmDlzJiIjIxnHuLm5YfLkyVqVLBMIBAJBMwaDhbA+o8sY5+jRozh48KDC/QEBAVi1alWPeh8JhUJUV1ejpqamWyPiiooK/P7772htbWU8ls1mw8zMDJaWlnjyySe7VUn/+uuvmD9/vkork3/84x947733tL6H3kYikeDrr7/Gt99+qzLGsre3x5IlS1S+5Lq4uGDKlCl608yYQCAQhgJNTU0oLCxEYWEh6uvrAQArVqxgHPvdd98hNjZWLvkgOjoaR44cGZKC1VBdwyEQtIGiKKSnp+P06dNIT0+nt7W2tkIgEHSLuZnw8PBAZGQkXnrpJYXJ7I/zuKCgqz5OLBYL7u7utDjl4OCgc2ckgUCAjRs34qefflJbxFMXMzMzuLq6YuTIkZg6dSrmzZvXo/enmpoafPfddzhy5IhGApW9vT1WrlyJBQsW6FSgsre3h5OTk07eK9rb2/HgwQM5UerBgwdK+/H2BiwWCx4eHt1Eqd743Rso6J1Q5evri/DwcBw+fJjexuFwFL78p6SkIDo6GuHh4bh161ZfTVMthnKQI5VKcezYMYWZucXFxUhNTYWzszNsbGwYx4SHh2PdunX0IohUKkVxcTEaGhqQkZGB1atXq/xgGzFiBG7fvt3tw1FbDhw4gI8//phxn0gkQltbG6KiohAVFcX4oUIWbAgEAqH3GSwWwvqMrmIcPp+Pt956S+XznM1mY968eYxNdzVBIpGgpqYG1dXVctfs6OhASkoKiouLFR7LYrFgYmKCMWPGYPHixXLzuHHjBqZMmaKyKfMbb7yBr776Suv59wW3bt3Chg0bVL70s1gsPPnkkxgxYoTSJBxbW1tMnz5dZ7EYgUAgELpz7NgxrFy5slsfQZlbSdfKchmyhJ3Hl4RYLBZ4PB5SU1N7tMg5EBnKazgEgrq0trbi/PnzOHv2rFy1SWdnJxoaGlTGw4aGhggKCsK4ceMwc+ZMlZZzwCNhIS8vjxYUlPWj1QRjY2P4+fkhICAAw4cPh6mpqU7O+zjnz59HbGwsUlNTVSaEqYLD4cDW1hZ+fn4YO3YsoqOjERkZqVGVlDIGk0BFURSqq6u7WfeVlJT0+OegKSYmJrQIKhOkhg8fDhMTkz6dh76jd0IVm81GcnIyZsyYQW9TJlTJKqp4PJ7e2f8N9SCHoiicOHFCoYBYVlaGW7duwcHBAXZ2doxjRowYgU2bNsn94VZUVKCyshKVlZV46aWXFPafkGFvb487d+7AxcVF+5vpwpEjR/DBBx8w7pOJVTNmzMDMmTMZxSoHBwdMnz59SJRsEggEQl8zmCyE9RldxTgNDQ3Ys2cPrl69qtZ4Ozs7LFu2DGPHju1RlhlFUaivrwefz6dfdCmKQkZGBq5fv66yOsrR0RFLly6Fv78/vS0vLw+jR49WWJkl47nnnsPx48e1nntf0NjYiC1btiA5OVnlWE9PT8yePVth4hHwyMYxMjIS5ubmupwmgUAgELoQGxuL7du3A3hkG5SSkqKwX+CmTZsQFxcH4FGcxLQsFBERgZs3b/behPWQob6GQyAoo7S0FGfOnMHFixflBAyJRILGxkaVFUI2NjYYNWoUgoKCEBoaiuDgYIXiA0VRqK2tpQWGkpIStSq01MHe3p4WCtzd3XvN9aijowMfffQREhISevSuaWpqiilTpmD27Nl4+umn4eXlpcNZ/j+9JVDV1dWhsrJSK4HK0dFR7bVTkUiEwsLCbqKUKrvy3sDJyUmuSiogIACurq7EEl0N9E6oioiIQHx8vNpClcwqkAhV+glFUThz5gyuXLnCuL+yshLXr1+Hra0t7O3tGRed/Pz88N5778ktbtTX16O4uBitra146aWXGJuhd8XExASXLl1CREREz27ofxw7dgzvv/8+Y0AvFovR2tqKadOmYfbs2Yz3ZGtrq9OMBwKBQCA8YjBZCOszuo5xMjIykJCQoLYHeHh4OFasWNFtDtrQ2NgIPp9PJ77w+Xz8/vvvKpsvs9lsTJ8+HXPnzqWtjKurqzFixAjU1tYqPXbChAm4fPmyXr+sUBSFxMREbNu2TeXLqoGBAWbOnIlRo0YpHGNsbIwZM2YoFbQIBAKBoD3bt29HbGwseDweioqKFFr3yVxpZO+pFEVhw4YNiImJAQCkpqZi5cqVaGpqwtGjR/Hcc8/12T30N2QNh0CQRyKR4NatWzh9+jSys7Pl9lEUhZaWFjQ2NioUkVgsFry9vTFq1Ci4urpi2LBhiIiIYPx8EovFKC4upoUGmXVpT+FwOPD09KTFKVtbW52cVxF37tzB2rVrcfHiRZXJb4rgcrkICgpCSkqKwsR+XVFdXU0LVKqq4bqiTKCSCY29JVA1NjbSQpRMlMrPz9dZfzJ14XK58PX1lauSCggIUNvGktAdvROqNm7cCDs7O6xbt47epkio6hpgRUVF4dy5c305VZWQIOcRFEXh/PnzOH/+POP+mpoaXL16FVZWVnB0dGQUdtzd3fH+++/L9bRqbW1Ffn4+hEIh/vrXv6q0fuRwODh06BAWLFjQsxv6Hz///DPee+89hWJVW1sbnnjiCcydO5fxnng8HiIjI4kVDoFAIOiQ/rAQTkhIQGJiIurr6+mMLW9vb8TExKh85iQnJyMuLo7uJeHt7Y2wsDBs2rQJYWFhWs1HxsKFCyEQCBATE4OwsDB4e3tDIBDg9u3bSEpKwtGjR5Gamgpra2uNz90bMY5IJMLx48dx/PhxtV4yDA0NsWDBAjzzzDM6sdRta2sDn89HQ0MDOjo68McffyA/P1/lcR4eHpg7dy68vLxgY2ODjo4OjBgxQqmNIAAMHz4cGRkZeh8H5OfnY926dXjw4IHScWKxGEFBQZg3bx6MjIwYx3C5XEydOhXOzs69MVUCgUAY0sycORMpKSlISkqSS/x9HF9fXxQWFgJ4tIh85MgRPP/883JjBAIBvL29ER0dLRdTDXbIGg6B8IimpiYkJyfj3LlzjAlYqmz+jI2NERwcjJEjR8LS0hJmZmaIiIiAm5ub3LiWlhbk5uYiNzcXeXl5GgklyjAzM6OFA19fX4Wxqa6QSqX4/PPP8fnnn+Phw4danYPFYmH8+PGIj4/H5MmTdTzD7vREoFq1ahWef/55hQJVVVWVRudUJFB17UeWk5NDi1LqJjfqEh6PB39/fwQGBsLf3x/+/v7w9vYmblk6Ru+EKllAdOHCBTork2mBadeuXVi9ejXdeyIuLk5O3NIHSJAjz6VLlxSKifX19bhy5QrMzMzg7OzMKOw4OTnhgw8+kPv+CYVC5Ofno729Hdu2bcOxY8dUzuPjjz/Gu+++q/2NdOHkyZPYtGkTY/aIRCJBa2srJk6ciHnz5jHek6WlJaKionrNB5dAIBCGGn1tIRwdHU0LS10Fn9jYWMTHxyMsLAwpKSmMYlB0dDQAIC4uDmFhYRAIBEhOTsbKlSshEAiwatUq7Ny5U+M5dT2/Muu2uLg4bNiwQatz92aMU1lZiV27diEjI0Ot8cOGDcOqVasQHBzc42sDj2ILPp+PmpoaZGZm4vLlyyqzIc3MzBAdHQ0PDw84ODiAx+Nh0qRJSEtLU3qck5MTsrOz9b7KqLOzEzt27MBPP/2kdJxEIoGJiQkWL17cbSFCBovFwsSJE3vNtoRAIBCGKr6+vuDxeEoTb2RVV7J30w0bNmDbtm2MY+Pj47Fr1y7k5eX1ynz1EbKGQxjqFBQU4PTp07hy5QpjJYxEIoFAIFBodW1vb49Ro0bB398fXC4XHA4HQUFBGDFiBLhcLiiKQmVlJV0Jo8odSRNcXFzoipZhw4b1yCZcXUpKSvDOO+/gt99+01pks7KywmuvvYZPPvmkT2yyeypQLViwoJvw1xOBys7ODk5OThCLxXjw4IGcKJWbm6uzfmTqwmKx4Onp2a2flIODQ5/8Tg119E6oAh5lJq9evRqLFi2im3+mpaWhoKAAt27dQkJCAgQCAS1ShYWFaZ0F3ZuQIKc7N27cwK+//sq4r7GxEX/++SeMjY0VPlRsbW3xwQcfyPWbkkgkKCoqQmNjIw4ePIjPPvtM5TxeffVV7Nu3T/sb6cJvv/2G2NhYpWLV+PHj8cwzzzDek7m5OaKiokjfBgKBQNABfWkhnJCQgJiYGGzYsIHu89AVHo8HgUDAuD82NhYCgYBRiBIIBHQFsaJzq4MioSoqKooWx7Slt2MciqJw9epV7N27Fw0NDWodM2XKFCxZskSrCjEmJBIJampqkJOTg1OnTqmcB4vFwpgxYxAeHg4ulwsej4eYmBj8/vvvSo+ztLTE3bt3B0TD+gsXLuDdd99V6vUulUrR0dGBqKgoTJkyRaG9YXh4OAIDA3tppgQCgTD0sLGxQUxMjELhqbGxETwej34nVbWOkpKSgpkzZ2ptXTUQIWs4hKGIWCzGtWvXcPr0aYUV9Mps/thsNnx9fREaGgonJyf6M0Zm82dkZISCggJaeFBlr60uBgYG8PX1patbFNmd9gb79u3Dxx9/3CMhf+TIkfjwww/7zF5VXwQqiqLQ0NAAgUCA2tpaWpwqKSlhdKzqTUxMTOQs+wICAuDn5wcTE5M+nQfh/9FLoQr4f7FKkVopm7a3tzeSk5Ph6enZh7NTDxLkMJOWlobjx48zfgC1tLTgzz//BJfLxbBhwxgXNywtLfH+++/LZeJSFIWHDx+Cz+fjypUrWLNmjcqAevz48fS1esrZs2exfv16xmvKxKqxY8fi2WefZbwnU1NTREVF9emDlUAgEAYjfWkhHBMTg4SEBHh7e6OgoKDbfplQFBUVhaSkJLl9LBZLacVUfHw8YmNjAUDrgD06OhpxcXHw9vamLX68vb11IuT0VYzT3t6OgwcP4vTp02p9H0xNTfHyyy9j5syZOuv/RFEUqqqqcPjwYdy9e1fl+GHDhskloKhT8W1sbIxr164hNDRUF1PuVaqrqxEbG4sbN24oHENRFFpbW+Hl5YXFixcrjG8CAwMRFhZGshMJBAJBB7DZbCQkJGDFihWM+2XJOcCjOCQ1NVXpcyc9PR1RUVF61wu8NyFrOIShRH19PX7//XckJSUpTULq7OxEfX19tworU1NTjBw5EsHBwXKJ1+bm5vDz80NzczNyc3NRWFios95B1tbWtKjg5eXVp7ZrtbW1WL9+PY4cOYK2tjatzmFiYoL58+djx44dcHJy0vEMmeHz+fjuu++QmJiokUDl4OBA96BiEqjq6upQWVmp9JxisRjl5eUoLi5GSUkJiouL8fDhQ7S1tfV5/O/k5ETb9slEKVdXV73uGTwU0VuhCniU8fPJJ5/g2LFj9AKLjLCwMMTExGDlypX9NDvVkCBHMVlZWTh8+DBjFVJ7ezsuXboEAHBzc1Mo7Lz33nvw9/eX215bW4vS0lLk5+dj6dKlKktE3dzccPfuXZ0s2v3+++9Yu3Yt42KoVCpFa2srwsPDMX/+fMZ7MjY2RmRkpFwfLgKBQCBoRl9aCAsEAmzbtg2LFy9mrE5SVFFVWFgIHx8fAEBiYiJjH6u0tDSEh4cDeNTUXJvqJ5lQ1dNeV0z0dYxTVFSEnTt3qp216Ovri1WrVtHfZ11x6dIlJCYmKrQ7kWFiYoLIyEi6Suqrr77C3r17lR7D5XJx+vRp2hJSn5FIJNizZw++/PJLhYlBFEWhvb0dhoaGWLhwocLqKU9PT0yYMAEcDqc3p0wgEAiDHhsbG7zwwgv4+uuvu+07duwYFi5cSC8MLliwQGXvqV27diE+Pp5Y/5E1HMIggqIo5Obm4vTp07h+/brSBG9FNn/Ozs4YNWoUfH196fhNKpVCIBDAyMgI7e3tqKmp0cl8WSwW3N3daXGhP+zXzpw5g3fffRd37tzROoHQ29sbmzZtwrJly/pMGOlrgaq5uZkWo2Rf5eXltEjJ5XLB5XJ7/ednYGAAHx8fOVHK398fVlZWvXpdgm7Qa6HqcYqKimBjYzNgfrlIkKOc+/fv4+DBg4yZFZ2dnbh8+TKEQiHc3d0ZFy+MjIywceNGhISEyG1vbm5GQUEB6urq8OKLL6p8QFpYWODWrVvdRC9tOH/+PN5++23Ge5KJVWFhYXj++ecZH06GhoaIjIyEra1tj+dCIBAIQxV9sBA+evQoFi5cCGtraxQVFXVLiAgPD4dAIEBqaipjskRXoUqRmKWKwSRUAY+eo8nJydi/f79KoQh49GI7e/ZsvPTSSzrtBVlbW4t9+/ahoKAAHR0dSl9Yw8LCMHbsWHA4HBw+fBjbt29XOed9+/bhlVde0dl8e5PMzEysW7cOZWVljPspikJHRweEQiEmTpyIuXPnMma+Ojk5YerUqaQZMYFAIPSA6OhopKWlobi4GBYWFvT29PR0hIeHg8Vi0bFPQ0ODSjePmTNnoqGhQS/bLPQWZA2HMFgRCoW4fPkyTp8+jaKiIqVjmWz+OBwO/P39ERISAkdHR/qcVVVVqKysRFtbG2xsbGBoaNjjuRobG8PPzw8BAQEYPnx4v/R0b2trw5YtWzSyIX8cLpeLWbNm4fPPP4efn5+OZ6iY3haoOjo6wOfzaTGqpKQERUVFCqtve1Og4vF48Pf3lxOlvL29deKcpU9IJBJ0dnYyfpmamuo8ObM/GVBC1UCDBDmqKSgowP79+xk/PIVCIa5evYq2tjZ4eHgwilVcLhdr167F2LFj5bZ3dHSgoKAALS0teP3115GTk6N0HgYGBvjtt990ksX8xx9/4K233mJsPCmVStHW1oZRo0Zh4cKFjGIVl8vFjBkzuv3uEAgEAkF9+tNCWNa7ytvbG0lJSfD29tb6HADQ0NCgVeVvdHQ0YmNjkZaWhqSkJNTX1wN4dM8xMTGIiopS6zxMCR+1tbUICgqS29ZXMU5jYyP27duHP/74Q63x1tbWeP311zFp0iSdvSCJxWKcPn0aV69eRWtrK9ra2hQKVo6Ojpg5cyYsLS2RnJyMzZs3M1aUdyU+Ph7r16/XyVx7m5aWFvzjH//AyZMnFY7p7OxER0cHnJ2d8dJLLzHGODweDzNmzCCe8AQCgaAlycnJmDlzJnx9ffHpp5/C2toaSUlJiI+Pp59RLBYLn376qcpnjMweeeHChSorrwYTZA2HMNiorq7GuXPnkJycjJaWFpXjOzo60NDQQK9nWVhYICQkBCNGjICxsTGam5tRWVmJyspK1NbWwsDAAM7OznLiuDbY29vTlS+KktX7glu3bmHt2rW4cuWKynhdEc7OznjzzTexfv36PhVMtBWoHB0dsXLlSjz//PPdBKq2tjbcvHkTt27dQn5+PkpKSlBSUoKOjg6V59WlQMViseDp6dmtn5S9vf2gsRAXiUQKxShl1pnGxsYYMWJEH860dyFCVS9Cghz1KC0txffff4/Ozs5u+2RNHZuamuDh4cH4Ic9ms/Hmm29iypQpctslEgkKCgrQ3NyMjRs3MjaU7wqLxcJXX32Fv/zlLz27ITyyBvr73//O+HCQ9W0YOXIkFi9ezChWcTgcTJ06FS4uLj2eC4FAIAxV+tJCOCYmBsnJyfR1oqKikJiYqLW1rI+PDwoLC7FgwQIkJiZqdY7o6Gjcvn0bcXFxWLVqFb1dJoI9bkmoCHWD/76OcbKzs5GQkIDy8nK1xo8cORKrVq3S6bM1Ozsbx48fR1tbG/3FZKFiZGSEGTNmwNvbG2lpaXjjjTdUevW/8847+Ne//qWzufY2v/76Kz766COFnv1CoRDt7e0wMDDAvHnzMHbs2G6/W+bm5pgxYwbp2UkgEAhaEh0djZSUFLnPV1kVFUVRiI6OVtmT886dO5gxYwYaGxu1skaWUVhYiNjYWLkYTGZ/1RvV3sCjivaVK1cyVrOrA1nDIQwGKIpCVlYWTp8+jVu3bqllVyeRSNDQ0EDHca6urhg1ahQ8PDxQX1+PiooKVFZW0q4GLBYL9vb2sLOz08rKjsPhyAkP/ekqJBaLsX37dnz55ZeoqqrS6hxsNhuTJ0/Gjh07MGbMGB3PUDkygerIkSOMCfOK6CpQGRoaorq6Gvfv38f9+/eRk5ODzMxMFBcXayzY9VSgMjU1lbPsCwgIgJ+f34BPZqMoCkKhUKEYpa0wymazMXr0aB3Ptv8gQlUvQoIc9amoqMDevXsZFzckEglu3ryJuro6eHh4MNrCsFgsrFy5ErNmzZLbTlEUSktLUVtbi2+//Rbfffedyrm8/fbb+Pzzz7W/mf9x+fJlvPnmm4wCHEVRaGtrQ1BQEF544QXGbBE2m40nnngCbm5uPZ4LgUAgEPrOQjg5ORkxMTGor6/vJhKpg0xIUmQbqC7x8fGIiopiXAyKjo5GcnKyWraC+ipUAY9eLE+ePIkjR46olTnI5XLx3HPPYf78+TqxJgEeVbwdPnwYZWVldF+m1tZWRiFq5MiRmDhxIkpKSrBkyRKV2YiLFy/GoUOHdDLPvqC0tBTr1q1DVlYW436RSETHesHBwXj++ee72bkYGRlh+vTpsLOz6/X5EggEwmBk4cKFOHbsGON2VdVR3333HV3RDQCrVq3CN998o/EcZBbIcXFx2LBhA71dFuM8vl0XdO0Bqm01OlnDIQxk2tvbcfHiRZw5c0btRC6KotDc3IzGxkZwOBwEBgYiICAAnZ2dqKysRFVVVbckLEtLSzg5OWkcS5uZmdHig6+vb7fqnb4mLy8P77zzDs6dO6cygUwRPB4Py5cvx4cfftjnFoXaClQODg546qmn4OnpiYKCAlqcamxsBEVRkEgkEIvFGvfj0kagcnZ2pqujZKKUq6trn/Xx0jXKLPo0qXLTlJCQkEFjoU6Eql6EBDmaUV1djT179qC5ubnbPqlUitTUVFRWVsLT01PhA/GVV17Bc8891207n89HeXk5zpw5g61bt6pUqmfPno3ffvutxx+O165dw1//+lfGhSiZWBUYGIgXX3yRUaxisViYNGmSTi2pCAQCgdA38Hg8CAQC7Ny5U22xStabqie2gerQtYeWKt91fRaqul579+7duH37tlrjHR0dsWLFCp1ldEskEiQlJeHPP/+kt3V0dKC1tbXbS4mdnR1mzZoFkUiExYsXo6mpSem5p06divPnzw+YFzaRSIT//Oc/2L17N+MLrlgspq0SLS0t8eKLL3b7PedyuXjiiScwbNiwvpo2gUAgDCrS09ORnJyMgoIC+Pj4ICoqSmnGdUpKCmJiYrpVP4WHh2ts/ScTjBRVhcfHxyM2NhZJSUlq2xCrQ3h4ONLS0gAQoYowtKioqMDZs2dx/vx5tLe3q32czOZP1uPGwsICtbW1Ct8NDA0N4eLiAnNzc7Wv4eLiQgsQw4YN63ebNqlUiu+++w5xcXHdHDfUhcViITQ0FP/85z8xZ84cHc9QNXw+H7t27UJiYqJKgUoqldIiCZfLhb29PTo6Orqtifa2QGVgYABfX185Ucrf37/XE0h7A20t+noTf39/jf4u9RkiVPUiJMjRnLq6OuzZswcCgaDbPoqicOfOHZSWlsLT01Nh9sX8+fPx0ksvdfuQbGxsRGFhIe7cuYPVq1erVLMDAgKQnp4OY2Njre8HAG7evInVq1crFKva29sxfPhwvPTSSwr9a8ePHw9fX98ezYNAIBAIfYtsIQZQb8FEJlL11DZQHbpmHRcUFCgVxAaCUCXj5s2b2L17N2pra9UaP378eCxbtkxndiMPHjxAYmKiXIW4SCRCS0uLXBxgYGCAadOmwcXFBYsXLwafz1d63qCgIKSnp+usCqwvuH79OmJjYxl7nEkkErS1tUEqlYLFYiEyMhKRkZFyYhyLxcL48eMHVXNgAoFA0Fe2b98Oa2treHt7w9vbG15eXlqfa+HChTh69ChSU1MZE0IEAgF4PB68vb1RUFDQk2nTxMbGwtbWVqO4iwmyhkMYKFAUhdTUVJw5cwZ37tzR6FixWIz6+nqYmprC1tYWEolEaZU/i8WCg4MD7OzsVL4XyAQJmRChL3bOVVVVWLduHY4dO6ZWfyUmzMzMsGjRIsTHx/dL5b8qgUokEtHWcrL/isVicLlcWFtbw8LColviW28IVDwejxakZKKUt7d3n/br6gm9ZdHXm3h6evarfaYuIUJVL0KCHO0QCATYs2cP6urquu2jKArZ2dnIz8+Hp6enQhFpzpw5WL58ebcPzPb2duTn56O0tBQvvfSSyixmW1tb3LlzB66urtrfEIDU1FSsWrWKMbtFJlb5+vrilVdeUfjhHRERgYCAgB7Ng0AgEAh9R3JyMqKjowFAZVWVbKy6faNUsXDhQgBQ2N+qq1Clyv6PSWiora1FUFCQ3DZ9iXE6OzuRmJiIX3/9lbFf1OMYGxvjhRdewNy5c3XSuLmpqQlHjhxBUVGR3HZZJZGsmggAAgMDMW7cOCxbtkzlYp2TkxOys7NhY2PT4zn2FfX19Xj33Xdx8eLFbvukUqlcTy9PT0+88MIL4PF4cuNCQ0MRHBzcJ/MlEAgEQs+RvYMrW2qSVZ1rKyh1JTk5GXFxcUhKSqKvTYQqwmClpaUFFy5cwJkzZ1QmOj1OZ2cnBAIBDAwMYGxsrFYClJWVFZycnJTaillbW9NVU15eXnplQXbixAls2bIFmZmZWp9j+PDh2LJlC1555RUdzkx9HheoKIqSE6OEQiGEQmE3AUUmUFlaWnZbG9WFQMVms+Hl5UWLkoGBgfD394e9vX2/V86pQlZppsiiT1+lEhaLBSMjo25fpqamevV31xOIUNWLkCBHe5qbm7Fnzx5UV1cz7s/NzUVOTg7c3d0V+sBOmzYNb7zxRrdFJ5FIhIKCAtTV1eGll15CaWmp0rkYGxvj0qVLPW6ImJaWhpiYGLr5ZFcoikJHRwe8vLzw6quvKvyAIYs1BAKBoB8IBAKEh4fD2toaKSkpjIshsgopAEoFqOTkZCxcuBC7du3qJhgp6zOliK4ilCJbna5zU5TxrIyBEOOUlZUhISEB9+7dU2u8h4cHYmJi4O/v3+NrS6VSXLhwARcuXOj2oiMTaGQiDY/HQ3R0NLZs2aLSutDCwgLJyckYNWpUv/v6qwtFUThw4AC2b9/erZpdZoMss8kwNjbG888/j5CQELlxw4cPx5gxY/T+pZdAIBAGG4sXL9bI+k8WX6iyFpbZ9KnTK1MZsngsNTUV1tbWRKgiDFpKSkpw5swZXLp0ibEPOhOypOjm5mZIJBIYGBjA0tJSrcQsIyMjODs7M9qJsVgsuLu70+KUg4ODXsVoTU1NePfdd7Fv3z6VyemKMDQ0xJNPPonPPvusRxWmPaGqqgpffPEF7dYgE6ZU2f31hkBlYmKC4cOHY9SoURgxYgQCAwPh5+fXYweq3kQfLfrUgcPhMIpRRkZGMDAw0Ku/td6ACFW9CAlyekZbWxu+//57PHz4kHF/QUEB7t69C3d3d5iZmTGOGTduHN55551uwo9UKkVJSQlqa2vx5ptv4saNG0rnwmazceDAASxevFi7m/kfGRkZWLlyJVpaWhj3d3R0wMPDA6+99ppCsSo4OBihoaE9mgeBQCAQeoasxxOgWAzqOkbRQszRo0excuVKpKSkMIpF4eHhSExM1LhXFYvFwqpVq7Bz507G/TJbQnV6VDExUGIciqJw8eJF/PDDD2q/qEZFReGVV16BhYVFj69fWFiII0eOMPbflC0etLa2gqIoPPHEEzhw4ADOnTun9JxGRkb44YcfMGbMGDg6OiqMgfSN3NxcrF27tls/ANn3oetL95gxY/D000/LZfq6u7tj0qRJOql6IxAIBIJ6cDgctaqTZSQkJCAmJkalrV90dDSSk5N7XEkeHh6OuLg4Og7TRKgaaBXjhKGHRCLBzZs3cebMGWRnZ6t9TEtLC5qbm9HS0gI7OztasFBngZvNZsPBwQG2trZy442NjeHn54eAgAAMHz5cYcJ4f3L58mVs2LAB169f17oixtXVFe+88w7efvvtfukPKxQKcerUKXz++edIS0vTSFBRJVBJpVKIxWKV1nV2dnbw9PSkv8LCwhAaGgoTExOt7qm3GIgWfTIMDAwUilEDxSKxt9BroaqpqYnRz7SoqAjp6emYP39+P8xKfQbKIo4+09HRgX379qGkpIRxf2lpKVJTU+Hm5qawcdyoUaMQGxvLmHlcWVmJiooKxMXFKbRH6sqHH36I999/X7ObeIysrCwsX76ccdEKeHTPbm5uWLp0qUKxKiAgAOHh4YNeSScQCAR9RdZfQVGjcOD/ezQoWqxJSEhAbGwsdu3a1U2Iqq+vh0AgwMKFCxlftGRVWIsWLWIUo2JiYmBtba1w8UdmuaNNNRUw8GKclpYW7N+/H0lJSWqNt7S0xKuvvorp06f3+Fnb2tqKo0eP4sGDBwrHdHR0oLW1Fe7u7sjKysLBgweVnpPL5eLrr79GWFgYzM3N4eTkNCCaEXd0dODTTz/FkSNHGPd1zRC2t7fHiy++iGHDhtHbHBwcMG3atAHVq4tAIBAGKosWLcKxY8c0EqpkiTDqClXK4ihVyPpRdY11NBGqBlIPTsLQorGxEcnJyTh37hxjS4yuyBbrm5ub0dzcjLa2NhgaGsLT0xNWVlZobm5WW7R53ObP3t6e7jHk7u6ul8lCQqEQn3zyCb755huFjkyq4HA4mDZtGnbs2NEvSeEikQjXrl3DyZMncfDgQdTW1moktGkrUHG5XLi5udGClIeHBzw9PWFubg4WiwVbW1s4OTn1q4vDYLPoMzQ0hJGRUb+IoAMFvRSqzp8/j4ULF6KxsRFJSUmYPn16tzHbt29HcnIyjh49qpOM195goC3i6CtCoRD79+9XGOg+fPgQt27dgouLi8JGjQEBAdi8eTNj1nFDQwOKi4tx8OBB7NixQ+UH3YsvvogDBw5ofiNdyM7OxvLlyxVmd3d2dmLYsGFYunSpwsUYX19fjBs3johVBAKB0E8cPXoU27Ztw6ZNmxAVFUUviAgEAmzbtg3x8fHw9vZGUlJSNyFKtpCjCkULPbIFHkDxYkx0dDQtVsmun5aWhoULF6K+vp7RalBdBmqM8+DBA+zcuRPFxcVqjQ8MDMSqVavg7u7eo+tSFIXLly/j999/V5rdJxQKYWBggJqaGnz33XdKz8lisfDJJ5/QfdCMjY3h6OgIGxsbvX/5SUpKwpYtW7rFQZ2dnXINrjkcDubMmYNJkybR92RmZobAwED4+voO+YxDAoFAUIWi5F9VzJo1i+75pIlQFRsbS8c/vSlUJScnIzY2FqmpqXLbiVBFGMjk5+fjzJkzuHz5stJKGpmNtKxqSmatbG1tDV9fX1hZWaG6urqb5bIijI2N4ezsDEtLS3h6etLilK2trU7uqzfIzs7GmjVrkJKSotFnVFdsbW2xatUqvP/++31uYScSiXD9+nWcPXsWycnJtKBYXl6u9s9NE4HKysqKFqJkotSwYcO6xdIsFgs2NjZwdnbuM4FKLBYrFKNU2Rz2J0Pdoq+30DuhqrGxETwej/6BbtiwAdu2bWMcGx8fj7i4OKSlpcHDw6Mvp6kWA3URRx8Ri8U4ePAg7t+/z7ifz+fj+vXrcHR0VBiQenl54f3332cM1FtbW1FQUIBLly7h7bffVvmgGzNmDK5evdqjBZL79+9j2bJlEAgEjPuFQiGcnJzw+uuvK3xAeHp6YuLEiXq/IEUgEAiDlcLCQuzcuRPJyckQCASor6+HjY0NvL29sXDhQqxatYrxGFkPKVVERUUxVgGpqqiScfToUezcuROFhYWor6+Ht7c3oqKisGnTph41Lx/IMY5EIsGZM2dw8OBBOVFEEWw2G/PmzcOiRYt6/BJbVlaGQ4cOKXz2y5D1rvziiy9UJtCsW7cOL7zwAv1vAwMDODg4wM7OTq+FnKqqKmzYsKFbXy6RSIS2tja5bcOHD8eiRYvkktMMDQ3h5+cHf39/vbSfIRAIhP6iqakJsbGxOHLkCP28CQsLw+bNm/Hcc88pPba4uBjR0dEoLCwERVEaC1V9UVH1eF+qrhChijDQkFXTnD59Gnl5eQrHicViWphqaWmhE59YLBZcXV3h4+MDc3NzVFVVKXTveRw2mw1PT09MnjwZAQEB8PX11eseqFKpFF9//TW2b9+uste8IlgsFiIiIvDpp59ixowZOp6hcsRisZw4xZS43tLSAj6fr/Q8ygQqFouFYcOGwdnZma6W8vDwkFtnZ6I3BSqKopT2i9JWaOwLiEVf36N3QtXGjRsRHx8P4FEwdf78eaUZQD4+PuBwOErtVPqLgbyIo49IJBIkJiYiMzOTcX9dXR2uXLkCOzs72NjYMI4ZNmwYtm7dypgZIhQKUVBQgOzsbCxZsqTbIsnjuLq6IiMjQ+G11CE3NxfLli1T2B9EKBTC0dERy5YtU/iwcHV1xRNPPKGXZdgEAoHQnwx0C2F9ZjDEOPX19di7dy+uXr2q1ng7OzssW7YMY8eO7VGGXHt7O44fP4579+6pHCsSifCvf/1L5Qvc0qVL8be//U1uG5vNhp2dHRwcHPR20UEikSAhIQFff/213D2KxWK0tbXJiXTm5uZYtGgR/P395c4hW2QJDAwEj8frs7kTCAT9hqIopKamorKyEs7OzkPGNr2xsRHe3t4QCATdEh1YLBZiY2PxySefMB6bkpKCmTNn0v+mKAo+Pj5KF88fR9ajSlUPTJlQpayfprJjY2JiGKvCiVBFGCiIRCKcOnUKJ0+eRGNjY7f9sqQlmTjV3t4ut9/Y2Bje3t7w8vKCoaEhampq1LaMs7a2Rnh4OObOnQsfHx+9/2wsLy/HmjVr8Ouvv8rZRGuCubk5XnnlFWzbtq1HyXqaIpFIcOPGDZw9exZJSUmMP+uuKKuq4nK54PF4sLCwAIvFgpmZGfz9/eHv74+AgAC4uLjAxMREYzs8W1vbHgtUA9miT2bHx/RFigL6Hr0TqiIiIuDt7Y24uDh4eXmpHL99+3bExsZi+/btWLt2bR/MUH0GwyKOviGVSvHLL790K/GXIRAIcPnyZfB4PIVlyg4ODti6dSucnJwYz19UVISSkhK8+OKLKj1uzc3NcfPmTQQGBmp+M/8jLy8Pr7/+Ourr6xn3i0QienFMUfNCZ2dnTJ06lSj6BAKBgMFjIazPDKYY586dO9i1axeqqqrUGh8eHo4VK1Z0u39NoCgKN27cwOnTp1WKUC0tLdi5c6fKF/Mnn3wSH374IeM+Ho8HJycnva08SktLw/r161FZWUlvk0gkaG1t7fZi6+npCTc3N7i6usLNzQ02Njb0AouzszOCgoLg7Ozcp/MnEAj6x507d5CVlUX/Ozg4uF96j/Q1M2fORHJyMlgsltznp+zfLBYLaWlpGDVqlNxx27dvx8aNG+kxFEVh4cKFOHz4sEbXT0tLQ3h4uEqhKjw8HGlpaUhMTNTIhjg+Ph4FBQUKxS1NhKqamppu22praxEUFCS3baDGNwT9RVHsKZVK6Yqp5uZmRvs/W1tb+Pj4YNiwYWCz2WhqakJlZaVSizQOhwNHR0c6Tpo6deqA+J0+fPgwPvjgA4XOSuoQGBiIDz74AIsWLdLhzJQjkUhw8+ZNWpxS5aTwOI9XVXG5XHh7e2PSpEkYMWIEAgICEBAQQP8ONDQ0oKKiQi2niK5oKlANVIs+NputUIgyNDTUe6F2qKF3QhWHw0FDQ4PaPsq7du1CTEwMwsPDcevWrV6enWYMpkUcfYKiKJw6dQrXr19n3N/c3IxLly7B0tISdnZ2jB86PB4PW7duhZubG+M5Hj58iPLycixfvhzZ2dlK58PlcnHq1CnMmjVL85v5H4WFhVi6dClqa2sZ94tEItja2mL58uUKxSoHBwdMnz6dbnxJIBAIQ5HBZCGszwy2GEckEuH48eM4fvy40p4AMgwNDbFgwQI888wzPUoSqaiowKFDh1Q2ym5ubsaePXvQ2tqqdNy4cePwn//8R2H2n4WFBRwdHWFlZaX1nHuL5uZmbN26FWfPnqW3SaVStLa2Ku3rZWJiIidcyb6CgoLg6elJMiEJhCFIU1MTTp06BalUiqqqKjg5OYHNZuOpp57Sql/TQKGoqIiujqAoClFRUQgLC0NhYSHS0tJQWFgI4FFy8M2bN+njFi9ejKNHj8qJVDt37sTKlSu1mocsBlO21MTj8SAQCFBQUNCtj6cyfHx86PtQF02WvAZbfEPQL+rq6rB3715cu3aN3iYUCmlhiilBB3i00O7m5gYfHx+6eryzsxOVlZVoaWlhvJapqSmcnZ3h7OwMe3t7mJqaIjQ0FH5+fnq9MC8QCLBx40b89NNPCu9NFUZGRnj22WexY8cOuLq66niGzEgkEty+fRtnzpxBUlKSUqFeFRRFoaqqClZWVnjttdfw97//HXZ2dt3GNTQ0oLKyslu1nSpsbW3h5OTUzdKcWPQR9AG9E6psbGwUVpYwsXr1aiQkJIDH46l8ye9rSJDTe1AUhaSkJFy8eJFxf2trK/7880+YmJjAwcGB8UFsbm6OLVu2wNfXl/EcdXV1KCkpwbvvviu3aMIEi8XCl19+2c12RxOKioqwdOlSxswu4FH2go2NDZYtW6YwI9rW1haRkZEwNDTUeh4EAoEwkBlMFsL6zGCNcSorK7Fr1y5kZGSoNX7YsGFYtWoVgoODtb5mZ2cnTpw4ofKaHR0d2L17t0rLkOHDh2Pfvn1KX8qMjY3h6OgIW1tbvVqsoCgKP//8Mz7++GM6K1RmfaNuY2kAsLS0hLu7O7y8vDBlyhTMmjVLrxuCEwgE3ZKSkoLKykrU19cjJycHgYGBsLGxgYuLS5/3JOlLZG4z4eHhOHLkSDeHmvj4eGzcuBEsFoteRI2MjERaWhqAR5+31tbWSElJwejRo7Weh8zWLzU1FWFhYd32CwQC8Hg8lX2sNEV2XkC9iiomBmt8Q+hfJBIJTp06hcOHD9MV8p2dnaiqqlIqxpiamsrZ+wGPkngU2fzJKmRcXFzk+hf5+vpi9OjRemsFDTz63N64cSNSU1O1tonz8PDAhg0bsHr16j5JVJJIJEhNTcXZs2fx+++/a7SWzYS5uTlmzJiB2bNn04lXTGt72gpUNjY2cHR0BJvNVihG6ZlEQEMs+oYOeidULVq0CKtXr1Y7gPT19UVhYSERqoYof/zxB2OTeeDRgs6ff/4JLpcLJycnxoUYExMTbN68uVt5v4zm5mYUFhbim2++Ucs7+4033sBXX32l2U10oaSkBEuXLlXYPFEsFsPa2hrLly+HmZkZ4xhra2tERUX1uOE7gUAgDEQGk4WwPjOYYxyKonD16lXs3btX7WzIKVOmYMmSJVp73lMUhbS0NJw8eVKpdYZYLMaePXsUVmDLcHJywpEjR1Ra/RkYGMDBwQH29vZ61euyqKgIa9eulbN6kUqlEAqFWvvce3p6Yty4cQgPD8fIkSPh7++v1ws2BAJBO0pLS3Hp0iVIpVKkp6ejo6MDxsbGGD16NNhsNqZOnarQVWOgM3PmTKSkpCh1qImNjcWOHTuwYcMGJCQk0JZUsgqsxMTEHlfdyuz/FixYgMTERMY5xMfHK7T9S05OxsKFC7Fo0SKN+lcVFhbCx8cHABGqCPrDvXv3kJCQgLKyMgCP4pna2lql/aTs7e3h6+sLZ2dnuXWsxsZGVFVV0bGigYEBHB0d4eLiAicnp25xja2tLcaOHau3yTodHR348MMPsWvXLq3Xc7lcLiIjI/HZZ59hxIgROp5hdyQSCdLT03H27FmcO3eux+vQZmZmtDg1adIkpUnn6gpUYrEYIpEIQqEQIpEIpqam9Oc6segj6Dt6J1QlJCRg165datn4bdq0CXFxcWCxWAgLCyPWf0OUq1ev4rfffmPcJxQKcfnyZVAUBRcXF8YPNgMDA2zYsIEx2wt4lOmSn5+PEydOYMuWLUrtZ4BHGWRnz57VWtEvKyvDkiVLFPbKkEgksLKywrJly2Bubs44xtLSElFRUXrbi4JAIBB6i8FkIazPDIUYp729HQcPHsTp06fVEkZMTU3xyiuvIDo6WusYoLq6GocOHVKYsAI8WuDYv38/ysvLlZ7LysoKhw8fZrQKeRw2mw07Ozs4OjrqTVW2UCjE559/jh9++EFuO0VRtGClKiZjwsDAgM7I9Pf3x8iRIzFy5EgEBwfTFZYEAmFgIhaL8euvv6KtrQ1lZWUoLS2l97m7u8PNzQ1mZmaYN2/eoLQC8vX1RXh4uNK+Ul0tkrs+22JjYxVaJWtDQkICYmJisGHDBsTFxanc3hVZRRagmeCUnJyM6OhoAEBSUhKioqI0nvdQiG8IfYNAIMC+ffvkXIBaWlpQWVnJWCXO4XDg4eEBHx+fbu8xnZ2dqKioQGtrKywsLODi4gJnZ2fY2toyxpxGRkYYPXo0bQWqb9y5cwdr167FxYsXtbaTc3BwwBtvvIFNmzb1euwqS3yQVU4pckFSF1NTUzlxSlXilEAgQEVFhZxA1VWIksXFsv+Xxceydij6lJjF5XIVilGkjQkB0EOhCngUYPn6+iIxMZGxwXlTUxNiY2ORkJBA+ygnJiZi/vz5/TBbxZAgp++4desWTpw4wbiQJBKJcPXqVQiFQri6ujI+qDkcDt5++21MnDiR8fwSiQSFhYW4du0aVq5cqdJ+Zvjw4UhPT9daKCovL8fSpUtRUVGhcD4WFhZYvnw5498I8GghRpYxTBZdCATCUGEwWQjrM0MpxiksLERCQgLy8vLUGu/r64uYmBiNem50RSQS4bffflMpnB4/flxlc2kTExPs379fox5sPB4PTk5OepPscvnyZWzbtg1FRUVy2ymKops6a7PIweFwaN96WWxoYmKCoKAghISEIDg4GMHBwQpjRwKBoH/cuXMHWVlZ6OjoQHp6OqRSKezs7FBTUwMOh4PRo0fD2NgYwcHBCA0N7e/p6hw2m434+HisW7dO6biZM2fSQpC1tTUSExMRGRmp8/kUFhYiNjZWrqeUjY0N4uLiFCaJAppXVMn6XT0uaMm2adIrZijFN4TeQSqV4ty5czhw4ADa2toAPIrt+Hy+QvtmDw8PjBw5spugIKu+YrFYcHZ2hpOTk8L1HxnDhw9HaGio3iQeyZBKpfj888/x+eef4+HDh1qdg8ViYcKECYiPj8ekSZN0PEN5pFIp7ty5Q4tT1dXVPTqfiYkJpk+fjtmzZ2Py5MlqOSDx+XwUFxejqalJTogSiURKk+j6W6BSZtFH1iYJqtBLoSotLQ0RERFgsVhYsGABvL294ePjg4KCAhQWFuLo0aMA/r8p5sKFC5VmDfUXJMjpWzIyMnD06FHG7FqJRILr16+jtbUVrq6ujFknLBYLb7zxhkLbSYqiUFZWhqysLLz00ksqe0TY2NggPT0d7u7uWt1PRUUFli5dqjBjWh2xCnjkcxsWFqb1PAgEAmEgMZgshPWZoRbjSKVSJCUl4aeffkJra6vK8SwWC7Nnz8ZLL72kteBz9+5d/PLLL3QvAybOnTuH1NRUpecxMDDAzp07ERISotH1LSws4Ojo2GMLKF0glUpx79493L17F1lZWcjMzERhYSH9LiATrMRiscbnZrPZMDQ0VGgpYm1tjeDgYFq8GjlypN5a6BAIQ5mmpiacOnUKUqkUOTk5qK2tBZvNhrW1NYqKisDj8WBjY4PAwECw2WzMmzdP5YLvQIPNZuPo0aMqE3hlSTrh4eFITk5W+jm/adMmnVZa6TtDLb4h6Ja8vDwkJCTQ4ixFUWhoaACfz2dcp7KyssLo0aO7xRVmZmawsbFBR0cHrKys1Ko0sbOzw9ixY2FjY6Obm9ERRUVFWLNmDU6fPq1Rv9GuWFlZ4bXXXsMnn3yi0FVIF0ilUty9e5e29VPmcKAOxsbGtDj1xBNPqBSnJBIJmpubUVpaisLCQqX9y5iwsLCAvb19rwtUxKKP0JvopVAF/H8WTWNjY7df8q5T1leRCiBBTn9w7949HDp0iDGzViqV4tatW2hoaIC7u7tCW57XX38dTz31lMJrVFdXIy8vD6+88gqKi4uVzsfIyAgXLlzAhAkTNLoPGVVVVViyZAntZ/w4UqkU5ubmWLZsmUqbKwcHB4SHh5PFFQKBMKgZTBbC+sxQjXGYbFyUYW1tjddffx2TJk3S6qWtrq4Ohw8fVpp5euXKFZXzYbPZ+PrrrxEREaHxHIyNjeHk5AQbGxu9evFsaWnBvXv3kJmZiczMTGRlZaGsrIy2P9EUWZNmQ0NDldaNzs7OcpaBI0aM6NWFEwKBoJqUlBRUVlaitLQUt2/fRnNzM9zc3GBkZITOzk6w2WwYGBggMDAQNjY2cHFxUTupZaDAZrORnJys8r62b9+udqXwmDFjhlR8NFTjG0LPaGlpwf79+5GcnEyvV7a3tyvsJ8TlcjFixAh4e3vTMYejoyOCgoLg4uKChw8fqi2SyHrweXt761Wctm/fPnz88cdqOxIwMXLkSPzjH//AM888o8OZyUNRFO7evYtz587h7NmzCltwqIuxsTGmTp2KOXPmYMqUKSrFqY6ODjQ2NtJfJSUl6Ojo0OiaFhYWsLOz02mfemLRR+gv9FaokhEbG4tjx47JlYtbW1sjIiICsbGxvVKiritIkNM/5OXl4aeffmJsEihrVl5dXQ13d3eFZacvvPACFixYoPBB39TUhPz8fLz55pu4evWq0vmw2Wzs27cPL7/8suY3g0flvkuXLkVJSQnjfqlUCjMzMyxbtkytrGcvLy+MHj1abyx9CAQCQdcMFgthfWaoxzjZ2dlISEhQ2SdKRkhICFauXAkXFxeNryUWi3Hu3Dml8UZGRobCfp0yWCwWvvzySzzzzDOora3VuL+TgYEBHBwcYG9vr7e2HfX19cjMzERaWhquXr2Ku3fvapyNCoAWrNS9TxaLBS8vL1q8klkv65vtDoEwWMnNzcXx48fB5/Nx//59iEQi8Hg8uWcSh8OBRCKhF3XZbDamTp0KNze3fpy5bmGz2di1axeWL1+udNyuXbsQHx+vcgE5PT0dERERWveQGYgM9fiGoBkUReHChQv48ccf0dTUBOBRVUx1dbVCK3I3NzeEhITQooKpqSnmzJmD4OBgZGZm4v79+2r1RmWxWBg+fDhGjRqlN/FGbW0t1q9fjyNHjtC2h5piYmKCBQsWID4+Hk5OTjqe4SMoikJWVhbOnj2Ls2fPorKyskfnMzIywtSpUzF79mxMnToVJiYmCsdKpVI0NzfTwtTjyVWlpaVquTcAPReoiEUfQR/Re6GqK0VFRbCxsdELCxJ1IEFO/1FcXIwffviBMaOWoihkZmairKwMHh4eChvpPv3003jttdcUilXt7e3Iz8/Htm3bcPDgQZVz2rJlCz766CPNbuR/1NTU4PXXX5cTbLsiE6tef/11tZrNcjgcBAUFYcSIEYOykTCBQBjaDBYLYX2GxDiPBKSTJ0/iyJEjalXwcLlcPPfcc5g/f75WCwo5OTk4duwYY2YuAOTn5yMxMVHl4sbWrVvx3nvvoaamBtXV1Rrb5bHZbNjZ2cHR0VFvFkYUIRaLce3aNaSkpCA3NxdlZWUoLy9nTGZiQpZNqk2sxOVyERAQQNsFjhw5El5eXuTFn0DQERKJBGVlZSgoKMDJkyfR2dmJuro61NXVgcvlwsPDQ+7vTZYBLhKJ4O7uDjc3N5ibm+PZZ5/tpzvQPWw2m64SV4ZAIEBhYaHScbIxAIhQNcTiG4J6FBcXIyEhAbm5uQAevVc0NzejsrKSMbaysLBAaGio3O9XREQEZs2aBT6fj7S0NIUx3uM4ODhgzJgx4PF4urmZHnL69Gm8++67yMjIUEtkY8Lb2xubNm3CsmXLVFa2awNFUcjOzqZt/bTtkyXD0NAQU6ZMwezZszFt2jSlieCdnZ20MNXc3Kz0e9Te3q7SuUldgUpmb61IjNKnCjwCQcaAEqoGGiTI6V/Ky8vx/fffMz7sKYrC/fv3UVBQAA8PD4Wlq9HR0Vi1apXCB6VYLEZBQQH27t2L+Ph4lQ/lxYsX49ChQ5rfDB7Z/yxduhQFBQWM+ymKgrW1NV577TW1/dZNTEwQGhqqd2XiBAKB0FMGg4WwPkNinP+nuroau3fvxu3bt9Ua7+joiJUrV2L06NEaX0sgEODIkSMKq6wrKirw448/qlxUXLlyJRISEiCVSlFfXw8+n6+xzQiLxQKPx4Ojo6PeV2lTFIWKigrk5OSgoqIC1dXVKC8vR2lpKcrLy1FZWam0wozD4cDQ0BAGBgY9ipdMTU0xYsQIuZ5XLi4uJAYjEDSgtrYWBQUFKC4uhkgkQmdnJ27fvg2KolBYWAiJRAJbW1tGu3MbGxvU19eDy+Vi7NixYLFYeP7555Vmvw8kZEKVrpBVnROhamjGNwRm2tvbcejQIZw+fZqOHYRCISorKxmruDkcDgIDA+Hn50evKzk4OODZZ5+FlZUVbt68ierqarWubWJigrCwMHh5eenuhrSkra0NW7ZswZ49eyAQCLQ6h4GBAWbNmoV//etf8PPz0+0E8egzLCcnh66cUtcJQRGGhoZ44oknaHHKzMyMcZxUKkVLSwstTinrN8uEoqoqJoGKWPQRBht6L1QVFxcjLS1Nzo4nJSUFR48eRXx8vF43QCVBTv9TVVWFPXv2KCydzcvLw/379+Hh4aEwK3jSpEl46623FGbAUhSFkpISnDlzBn//+99VZiaHh4fj+vXrWmXn1tfXY9myZXjw4IHCMQ4ODlizZo3KTI2u8Hg8REREwNHRUeM5EQgEgj4zkC2E9RkS43Tn5s2b2L17N2pra9UaP2HCBCxbtkzjptdSqRQpKSm4ePEi43O+oaEBu3fvVlnl9eSTT+LUqVP0vwUCAfh8vlZWeRYWFnB0dBwQrgf19fXIyclBcXEx/f0TiUSorKykK67KyspQU1PT7VgWi6XzRtE2NjZyVVfBwcF61widQOhv2traUFRUhIKCAtpeqyu3b99WWVElkUjQ0tICKyurQV9RpcslHiJUkfiG8AiKonDlyhV8//33aGhooLfV1dWhurqa8e/OxcUFo0aNohN6DAwMMGPGDIwbNw7Z2dnIyclR2+YvICAAISEh/S4+3LhxA+vXr8eVK1c0tpGW4ezsjL///e9Yt26dzh1+ZEnp586dw5kzZxT2e1cXAwMDTJ48GXPmzMG0adMU9iQVCoVyVVPafm+A7lVVNjY2cHV1hZWVFbHoIwx69FaoOn78OGJjY1FYWAgWi9Vt8T85ORmLFy/G0aNHMX369H6apXJIkKMf1NbWYvfu3YwvNcAjS8nMzEx4eHjAyMiIcUx4eDjWrVun1OKmqqoKV69exauvvqrSj9fFxQUZGRmws7NT/0b+R0NDA5YtW0aXmDPh6OiIzz//HHV1dRr57bq5uWH06NGwtLTUeF4EAoGg7ww0C2F9hsQ4zHR2duLIkSM4efKkWgt7xsbGeOGFFzB37lyNXzTz8/Nx5MgRxmSctrY2JCQkqIxHxowZg+vXr8tVjre2toLP59OLMJpgYmICR0dH2NjY6H2VUFtbG+7fv4+8vDxGK8D29nY8fPiQFq7KysrQ2NgI4NGCkYGBAYyMjHrFnmbYsGFy4lVQUJDCrF0CYbAikUhQXl6OgoICVFZWKl3Mra2tRW5uLqRSKUpKSuR6VHG5XNjb26OjowMNDQ2DvkcVAERFRcHa2lpr0bu+vh4CgQDJyclEqAKJbwjAw4cPsWvXLmRmZtLb2traUFFRwVgtY2pqitDQUDg7O9Pb/P39MW/ePLS3t+PmzZtqJwY5OjpizJgxarV46C3EYjHi4uLw3//+F1VVVVqdg81mY/LkydixYwfGjBmj0/lRFIUHDx7gzJkzOHv2LEpLS3t0Pi6Xi8mTJ2P27NmYPn06Y4EERVFyVVOaOhMow8DAAPX19bC0tMTw4cMVimMEwmBEL4Wq7du3Y+PGjQCUl5snJydj1qxZSE5O1kuxigQ5+oMsu1jRoktZWRnu3LkDNzc3hT6vI0aMwKZNm5RaQzQ0NODu3bt44YUXVD7AzczMcOPGDYwYMUL9G/kfjY2NWL58Oe7du6dwDIfDwbPPPounn34alZWVCoW6x2GxWPD390dISIje954gEAgEQv9AYhzllJaWIiEhATk5OWqN9/T0xKpVq+Dv76/RdZqbm5GYmMhoCywUCvHdd9+ptGPx8fHB3bt3u9n3dXZ2gs/no66uTuOsUAMDAzg4OMDe3l7vMz1FIhHy8/ORk5OjUthrbm6Wq7qS9bvq7YxWFosFHx8fuuJq5MiR8Pf37/esagKhN6irq6Ot/dTp/ycjOzsb9fX1aGhoQElJCdhsNtzc3MDhcFBfXw82mw1PT08EBgbCxsYGLi4umDFjRi/eSd/DZrNRWFgIT09PnZyvsLAQfn5+RKgi8c2QpbOzE0ePHsWJEyfovwOxWAw+n88YX7HZbPj7+8Pf35+OCywtLfHUU0/By8sLqampCu2bH8fExATh4eE6+3vWhry8PLzzzjs4d+6cxj1NZfB4PCxfvhwffvihTq2iKYpCXl4ebeunNSXg5wAAuMBJREFUqq+TKrhcLiZNmoRZs2YhMjKSUZwSiURyVVO6/Gw0MzODlZUVrKysYGpqSq+FEwhDDb0TqtLT0xEeHi63TVkWT3R0NNLS0lBXV9cX09MIEuToF01NTdizZw+jlQsAVFZW4vbt23B1dVUoRvn5+eG9995TmtEgy9BdunSpXMYNE1wuFydOnMDcuXPVv5H/0dTUhBUrViArK0vpOA6HgyeffBLR0dGor69X2x/X0NAQISEhGD58eK9kCxMIBEJfMJAthPUZEuOohqIoXLx4ET/88IPaySJRUVF45ZVXNPq9lEqluHTpEpKTk7tVHEilUvzwww8qq6sdHByQnZ3NWOktFotRU1OD6upqjRcp2Gw27O3t4eDgoPfJL1KpFKWlpbh37x7q6+vVOoaiKNTX16OsrAwCgQD19fUoKirSuBeBNhgYGCAgIICuuho5ciQ8PT1JzEYYkLS3t6OwsBCFhYV05eLjiMViNDY2oqmpif6vQCCg/11fX4+6ujqw2WxIJBJIpVJwOBwYGRmho6MDXl5emDVrFgIDA8FmszFv3rxBFwNERESo3S+xP8+pz5D4hgA8er7funVLztKZoijaJplpfdLR0RGhoaH0WhGLxcLEiRMxY8YMlJWVIT09XS3xncViITAwECNHjuyXhBSpVIrvvvsOcXFxctbpmsBisTB69Gh8/PHHmDNnjk7nl5+fT4tT2s5PBofDwcSJEzF79mxERkZ2cxaiKAqtra20ONXe3t6j63WFy+XC0tISVlZWsLS01LkFIoEwUNE7oWrRokU4evQooqKiEBsbi/DwcNja2ioUqnbt2oWYmBhs3LgRn3zySR/PVjkkyNE/WltbsXfvXoULNjU1Nbh+/TqGDRumMNvD3d0dW7duVVp6LcvOXbduHU6fPq1yXl988QXeeustte6hK83NzVi5ciXu3r2rciybzcbMmTMxdepUtLa2qp0dbWlpibCwMLi6umo8PwKBQOgvBoOFsD5DYhz1aWlpwf79+5GUlKTWeEtLS7z66quYPn26RpmUJSUlOHz4MOMi75EjR5Cfn6/0eAsLC2RkZChs0C2VSlFfXw8+n6+xvQmLxQKPx4Ojo6NOs2l7Cz6fj3v37uHhw4caH2tubg4zMzM0NDTg3r17yMzMxIMHD/qkIsHMzAzBwcFytoFOTk4kI5egl8is/WQCVVfRSfbVVYxS1HNYZsVpYGAAsViMzs5OSKVS+nOKw+FAIpHA1dUVb7/9NoyMjBAcHIzQ0NA+vNu+ISUlRee9N3vjnPoMiW8IfD4fu3fvRmpqKr2ts7MTFRUVjJXXxsbGGDVqFIYNG0Y/b11dXfHMM8/A1NQUN27cUJgs/TjOzs4YM2ZMv7RiqKqqwtq1a3H8+HGtbezMzMywaNEixMfHa9XmQhEFBQW0OMXkIqAJHA4HEyZMoMWpxy3hRSKRXEKErqumZOKUqakpic8IBAb0Tqjy9fVFeHg4Dh8+TG+TBZdMpKSkIDo6GuHh4bh161ZfTVMtSJCjn7S3t+OHH35Q2FSxvr4eV69ehZOTk8LKKScnJ3zwwQdKf5ZSqRRFRUX417/+ha+//lrlvFavXo1vvvlGvZvoQktLC2JiYpCenq7WeBaLhWnTpmHChAkaXcfJyQnh4eHg8Xgaz5FAIBD6ksFiIazPkBhHcx48eICdO3eqbU0SGBiIVatWwd3dXe1rtLW14dixY7h//363fadPn8adO3eUHm9kZITLly8jIiJC6ThZRrG6/RW6YmFhAScnpwHRD7OxsRE5OTkoKirSeKHC2NgY/v7+GD58OCiKQm5uLjIzM+mvnlrUqIuNjQ1CQkJo8So4OJjEcoQ+QyqVQiAQoKqqCnw+H3w+H4WFhXjw4AFKSkrQ0NCAxsZGjSz+ZHC5XBgaGoLL5dKLfRRFobm5GRRFQSQSyfWfc3FxwaZNm2BmZoZ58+aR7HUCIyS+GbqIRCL88ssvOHbsGP3ZIZVKUVNTg7q6um5V6ywWC35+fggMDKQ/T4yNjTFz5kyEhYUhOzsb2dnZSvvryTAxMUFERAQ8PDx0f2MqOHHiBLZs2aLSDUgZw4cPx5YtW/DKK6/obF6FhYW0OKUq2UoVHA4H48aNw+zZs+kefjIoikJbWxudIKHKBlrT63atmiKWzQSCavROqGKz2UhOTpbzi1YmVMkqqng8nt7Z/5EgR3/p7OzEjz/+iKKiIsb9jY2NuHLlCuzt7RVaQtja2uKDDz6Ai4uL0ms9fPgQ+/fvx+bNm1VWMc2YMQNJSUka27a0trbizTffxPXr1zU6bsKECRg7dqxGDbp9fX0xatQopb26CAQCob8YTBbC+gyJcbRDIpHgzJkzOHjwoFrZqhwOB0899RQWLVqksIfm41AUhWvXruHs2bPdfu8vXbqEy5cvq7zmyZMn1bJqaW1tBZ/PV9gDVBkmJiZwdHSEjY2N3meUdnR0IDc3Fw8ePNDY1o/D4cDHxweBgYFyMWVzczOys7Nx9+5dZGVlITMzE3w+X9dTZ8TV1VWu31VQUNCAqHQj6BcyW9CqqipUV1fL/VcmSvH5fIjFYkilUohEIgiFQo173nWFzWbD0NAQBgYGCt+XRCIR2traIJVK0dLSArFYDC6XCycnJ2zduhVTp06Fm5ub1nMYzNy5cwfJycmwtrbGokWLBkRCga4h8c3QJCMjAwkJCXJ9xpubm1FVVcUopNvZ2WH06NFyfyMhISGYO3cuWlpacPPmTTQ3N6t17eHDhyM0NLRPLZKbmprw7rvvYt++fWrbUz+OoaEhnnrqKfzrX//SmcBWXFxMi1MPHjzo0bnYbDbGjRuHWbNmISoqCjY2NvQ+sVgsVzWlbf8tJkxNTWlxyszMTO9jXAJB39A7oSoiIgLx8fFqC1Uyq0AiVBE0RSQS4cCBAwofgC0tLbh8+TJ4PF63cmAZlpaWeP/99xXa5Mioq6vDmTNnsGLFCpULHL6+vkhPT1faB4sJiUSCn3/+GQkJCSgvL1f7OIqiEBYWhvDw8G6/r4rgcrkYMWIEgoKC9L5JOoFAGFoMJgthfYbEOD2jvr4ee/fuxdWrV9Uab2dnh+XLl2PMmDFqv/A+fPgQhw4d6tZvKS0tDWfPnlV6LIvFwt69e7FkyRK1rtXZ2Qk+n4+6ujqNF6ENDAzg4OAAe3t7vY8pxGIxCgsLkZOTo/YCVFfc3NwQGBioMN6qqalBVlaWnHil7QKSJrDZbPj4+Mj1uxo+fDipOBnCtLe3y4lNTCIUU4VBVyiKglgshlAo7NEiYFdrP3V/J1tbW9HS0oKOjg5IJBJwOBwYGxvjwIEDmDVrltZzGcgcP34cAOhnQkREhJz94aZNmxAfH0//m8ViITExEc8991yfzrO/IfHN0KKurg579+7FtWvX6G0ikQhVVVWMz18jIyOEhITAzc2NjsdsbW3x9NNPw9XVFampqQqToR/H2toa48aN69PfrcuXL2P9+vW4ceOGWpVeTLi6uuKdd97B22+/rZO+mCUlJTh37hzOnDmD3NzcHp2LzWZjzJgxmDNnTjdxqmvVlCIrWW3gcDiwsLCAlZUVrKysSNUUgdBD9E6o2rhxI+zs7LBu3Tp6myKhSmb7x2KxEBUVhXPnzvXlVFVCghz9RywW48iRI8jOzmbc39bWhsuXL8PCwkKhTYqpqSnee+89+Pv7K71WS0sLrl27hsWLF6vMPLa2tsadO3e0ykwRi8U4efIkdu7cidLSUrWPoygKQUFBiIiIUDvL0NTUFKNHj4anpyfJFCEQCHrBYLIQ1mdIjKMb0tPT8d1338ll8CojIiICy5cvVzuxpKOjA7/88ks3O5fc3FwcP35c5SLFJ598gk2bNql1LeD/Kyyqq6s1XpjmcDiws7ODg4NDn2YVawNFUSgvL0dOTg6qq6s1Pt7Ozg6BgYFwd3dXGj9RFIWysjLaLjArKwv37t3TuneEJhgaGiIgIEBOvPLw8NDJohSh/6AoCo2NjXIiFJMQpY0QK0MikUAoFEIkEmm9EAowW/upS2dnJ2pra2FkZASJRAIejwcTExMcOnQII0aM0HpOA5mIiAikp6fDy8sLq1evxqpVq+hqEFnSjgyZLVZjYyMKCwv7xY6svyDxzdBAIpHg1KlTOHz4MJ1ITFEU6uvrUV1dzZh04+Pjg6CgIDpG4XA4mDp1KqZOnYqSkhKkpqaqZWPK4XAQEhKCwMDAPnmmCoVCfPzxx/j222/V7pX1OBwOB9OmTcOOHTt00t+vtLSUrpxisqvWBBaLhTFjxmD27NmIjo6Gra0tgEc/465VU12tYHuKiYkJXTVlbm5O1sIIBB2id0KVQCCAt7c3Lly4gFGjRgFgXmDatWsXVq9eTfeeiIuLkxO39AES5AwMpFIpjh07prBvQ2dnJy5fvgwTExO5jIyuGBkZYePGjQgJCVF6rc7OTmRlZWHhwoUqM20MDQ1x/vx5TJo0Sa37eByZvdC3336LwsJCtY+TSqXw8fHB2LFj4e3trdZD19bWFhEREeR3m0Ag9DuDyUJYnyExju4QCoU4fvw4fv75Z7XEHUNDQyxYsADPPPOMWtUFFEXh9u3bOHXqlNz5y8vLsX//fpUVUH/729/wn//8R/WNdEEqlaKurg58Pl9jqzwWiwUejwdHR8cBYUdXV1eHe/fuobS0VONFeXNzcwQEBMDX11ftShGJRIL8/Hy5fld5eXk6bfatCHNzc4wYMUKu55WjoyNZoNETJBIJamtrGe33uopRmv5NqkNfWvsBj3rdOTg4wMnJif6vo6Mj/ZWSkoK0tDQUFRWhvLwcrq6u8Pb2xuTJk7FkyZIh+Tvr6+uLsLAwHDlyRG57Y2MjnZDJYrHw6aefYv369QCA+Ph4pKamyiX/DHZIfDP4uXfvHhISEuR6lre3t6OiooIxEcTGxgahoaFyicve3t545plnYGhoiOvXr6udtOLs7IyxY8cqbC+hS7Kzs7FmzRqkpKRoHSPY2toiJiYGW7ZsUduCWhFlZWU4d+4czp49i3v37vXoXCwWCxEREZg1axZmzpwJOzs7AI9+jl2rpnS13M1ms+WqpvQ9oYpAGMjonVAFAAkJCVi9ejUWLVqEqKgoxMTEIC0tDQUFBbh16xYSEhIgEAhokSosLEwvs6BJkDNwoCgKv/76K27evMm4XygU4urVq+ByufRD8HG4XC7Wrl2LsWPHKr2WbIFhxYoVKvtEsNls7N27F6+99pp6N6LgeklJSfjmm2+Ql5en0XFubm6YNGkSfH191Xqh8/DwwOjRozW2LSQQCARdMZgshPUZEuPonoqKCuzatQt3795Va/ywYcMQExOjdnUAn8/HwYMH5bJp6+rqsGfPHpVZpvPnz8exY8fUuk5XulZvtLS0aHy8hYUFnJycBkSflJaWFty/fx/5+fkaV5MZGhrCz88PAQEBWvUA7ejoQE5ODm0XmJmZiZKSEo3Pow12dnZ0xZVMvFJkmU3Qns7OTlRXV9OC0+MiFJ/PR21tbZ8IljJ6y9rP1tZWTnR6XIRSJWJnZ2fjwIEDkEgkOH/+PJqbm2FhYYEZM2aAw+Hg5ZdfRlBQkNbzHajY2Nh0s4IFgNWrVyMhIQEsFgsLFizoJkpFRETg9u3bfTXNfofEN4MXgUCAffv24eLFi/Q2iUSC6upqxr8NQ0NDBAcHy7nHmJmZYe7cuQgODsa9e/eQlZWlljhvbGyMiIgIeHp66ux+mJBKpfjqq6+wY8cOjdx1uiITgT799FO59yltePjwIS1OZWVl9ehcsrXf2bNnY+bMmbC3t4dEIkFzczMtTumyasrY2FiuaopUlBMIfYNeClXA/4tVihbHZdP29vZGcnJyr3/gawMJcgYWFEXhzJkzuHLlCuN+sViMa9eugaIo2NvbM/5ustlsvPnmm5gyZYrKa5WXl2PTpk346aefVM5t8+bN+Oc//6nejShAKpUiJSUF33zzjUbl1SKRCE5OTpg6dSr8/f1VClZsNhuBgYEIDg4m/rwEAqHPGUwWwvoMiXF6B4qicPXqVezdu1elTbCMKVOmYMmSJbRVkzKEQiFOnTqF1NRUeltLSwt27dqF9vZ2pcdOmjQJly5d0vpFvaWlBXw+HwKBQONjTUxM4OjoCBsbG72vhBAKhcjLy8P9+/dVfk8fh81mw9PTE0FBQWr9PJXR1NSErKwsuudVZmam1pY/muLm5iZnGRgUFNTjTOzBCkVR9N+Gsn5Q2vzd9BbaWvux2Wx60c/Kygqurq7w9/dHYGAgnJ2d4eTkBHt7+x69PwiFQnzxxRdobGxEcXExiouL6X1eXl7w8PCAtbU13n777SH3nsIkOBUVFcHHxwfAo0XghoaGbokBs2bNGlLxEYlvBh9SqRTnzp3DgQMH0NbWBuDRZ29TUxOqqqoYhXZPT08EBwfDyMiI3jZmzBjMmjULTU1NuHHjhto9JGXVjL1ZhVNaWoq1a9fi5MmTWlfNWlhY4OWXX8a2bdt6FINUVFTQ4tTj1tPaIBOnoqOj4ejoiI6ODlqYamlp0WnVlLm5Of2M6vqzJxAIfYfeClXAozL0Tz75BMeOHetmXRYWFoaYmBisXLmyn2anGhLkDDwoisL58+dx/vx5xv0SiQQ3b95EZ2enQqsTFouFlStXqtWot6amBl9++SX++c9/qnzAapvN/DgUReGPP/7AN998o3ZWC0VREAqFsLe3x4wZMxAYGKhyocjY2BghISHw8/PT+0UlAoEweBhMFsL6DIlxepe2tjYcOnQIp0+fVusF3MzMDC+//DKio6PVEpLu3LmDEydO0L0UhEIhEhISVC66BAQEID09vUeiQ2dnJ/h8Purq6jS2CDMwMICjoyPs7e31PrNVKpWiuLgY9+7d00pkcHZ2RlBQEJydnXU2Jz6fL1d1lZWV1aNeROrC4XDg6+tLV1yNHDkSfn5+atsdDlSkUikaGhqU2vBVVVVpLGj2B6qs/QwMDGBtbS0nRFlZWcn928zMDFZWVvDx8YG3t3evWHsmJSXhjz/+QEdHB27evAmpVAoHBwdUV1eDzWZj7NixMDY2xrRp0xAdHa3z6+szY8aM6eZCM3PmTCQnJ4PFYmHDhg3Ytm1bt+P8/Pw0cuUY6JD4ZnCRl5eHhIQEufVEoVCIyspKxkpvKysrjB49mu5zBACOjo549tln4ejoSDs9qYOlpSXGjx+vdl9RbTh8+DA++OCDHvV5CgoKwtatW7Fo0SKtz1FVVUX3nFLXGUAZoaGhmD17NmbNmgV7e3u5qil1+oCpi6GhIf2MsrCw0PvYkkAYCui1UPU4RUVFsLGxGTB2EiTIGbj8+eefOHv2LOM+qVSK1NRUNDc3w9nZWaEI88orr+C5555Tea2mpiYcOnQIf/3rX1XaZoSGhuLGjRs6ycahKApXrlzB119/rbA/1+NIpVJ0dnbC1tYWkZGRGDFihMqHuZWVFcLDw+Hi4tLjORMIBII6DBYLYX2GxDh9Q2FhIRISEtReJPT19UVMTAy8vb1Vjq2trcWhQ4dQWVkJ4NEzfs+ePSr7LDg7O+PevXs9rvgRi8WoqalBdXW1xrZhXC6Xrr4YCIsKlZWVuHfvHv291gRra2sEBQXB09NT5/cqlUpRWloqJ17l5OT0Sg+jxzEyMqIr8GU9r9zd3QfEzxN45DhQU1Oj0IaPz+dr9butT8is/QwNDenG8V3FqK7/NjY2VvhOZGBgAA8PD/j4+PTqM6K2thZffvklJBIJsrKyUFtbCysrK/j6+tKVRPb29ggODgaHw8Fbb70ltxg92Jk5cyYWL16M5cuXAwA2bdqEuLg4sFgseHt7Mz5nUlJSMHPmzD61lOxvSHwzOGhpacH+/fuRnJxMJ/xQFIXa2lrU1NR0SwLicrkYMWIEvL296eeQgYEBIiMjMXHiRJSUlCA1NVWt5yOHw0FwcDCCgoLA4XB0fm8CgQAbNmzAwYMHtbJVBh49g5999lns2LEDrq6uWp2Dz+fTlVPqricpIyQkhBanbGxsaGGqublZZ1VTLBZLrmqKVHsTCPrHgBKqFNHU1KSX3vUkyBnY3LhxA7/++ivjPoqicOfOHdTV1WHYsGEKX8yef/55vPjiiyorijo6OnDhwgUsXLgQra2tSsc6OTkhIyNDZ5k5FEXhxo0b+Prrr9X2H5dIJOjo6ICtrS1mzJiBkJAQlQsLLi4uCAsL6/HCFoFAIKjDYLAQ1mdIjNN3SKVSJCUl4aefflIZIwCPXsLnzJmDF198UWXFglgsxpkzZ3D9+nX6WocOHZKzy2LCysoKd+/ehbu7u9r3oQipVIq6ujrw+XyNBZKBJlg1NDQgJycHxcXFGleTmZiYICAgAH5+fr1qHyQWi5GXl0dXXGVmZiIvL0/j+WqDhYWFXNVVcHAwHB0de/26j9PW1qbUhk9WETjQYbPZsLe379b/yczMDJ2dnWhvb4eRkZHWFnnOzs7w9vaGm5tbr1fPURSFH374AQ8ePEBFRQXS0tLo5DoWi0XbFBoaGmLkyJGwtbWFn58flixZMmScH9LS0hAREQEfHx/U19fLJeykpqYiNDRUbvz58+excOFCREREEOs/Et8MGCiKwoULF/Djjz/KVYm3traisrKSMc5wc3NDSEiInGgRGBiIp556ChwOBzdu3EBVVZVa13d0dMS4ceN6ZX0yJSUFsbGxSEtL01q48fDwwIYNG7B69Wqt4iY+n4+kpCScPXsWaWlpWs2hKyNHjqRt/SwtLWlxSpcJM4aGhnSChYWFRa+IhwQCQXcMeKEqPT0dR44cYSxT729IkDPwSUtLw/HjxxkDAYqikJ2djYqKCri6uip80M+ZMwfLly9X+RIkFouRkZGBefPmqcy4NTU1xbVr1xASEqL+zajBrVu38M0339ALVqoQi8Vob2+nBavQ0FClAQ+LxYKfn1+3QJBAIBB6g4FuIazPkBin72FqAq4Ma2trvP7665g0aZLKGCQ7OxvHjx9HR0cHAODkyZMq+woYGxvj2rVr3RY3tYWiKDQ2NqKqqkotQa4rXC4Xjo6OcHBwGBCCVXt7O+7fv4+8vDyNLWy4XC58fX0REBAAc3PzXpqhPO3t7cjJyaHFq7t376KsrKxPru3g4NBNvNJ2AZCiKAgEAqU2fNXV1X1ih9jbGBoa0sKTk5NTNzHK0dERdnZ29IJdZ2cnioqKUFBQoHZ/PCYsLCzg4+MDLy8vmJmZ6ep2lNLY2IikpCQcPHgQ9fX1KC4uhkgkgqWlJXg8Hj3O2NgYHR0dMDExwZgxY8Bms/Hyyy8jKCioT+apDxw9elTO3sva2hqJiYmIjIykt+3atQuJiYlITk4GAMTExOCbb77p87n2FyS+GbgUFxcjISEBubm59DaxWKywz5+FhQVCQ0Plft5WVlaYN28e/P39kZ2djaysLLUqCo2MjBAeHq5WRbsmdHR04MMPP8SuXbu0TpDgcrmIiorCjh07MGLECI2Pr66ulhOnerqEHBwcjNmzZ2PatGmwsLCgq6Z0lRAjq5qSiVMmJiY6OS+BQOgbBrRQ1dTUhE8++aRHH9q9CQlyBgdZWVk4fPiwwgdnbm4uiouL4ebmpnBxZNq0aXjjjTdUZm9QFIWioiI8//zzKsunORwOjh8/jqefflqt+9CE9PR0fPPNN7h8+bLKsRRFQSQSoaOjAzweD5GRkRg9erTSezUwMEBwcDACAgJIRguBQOgzBpqFsD5DYpz+Izs7GwkJCSgvL1drfEhICFauXKnSgrehoQGHDx+mBYjz58+rTFzhcrk4d+4cZsyYod7k1aSlpUXhwpKq+ch6WA2E+EIsFqOgoAA5OTka2/ewWCy4u7sjMDAQdnZ2vTRDxQgEAmRlZcnZBtbW1vbJtT08PBAcHAx7e3tMnDgR4eHhMDQ0RG1trVIrPj6fr9PeFv2FhYWFnODk5OQEBwcHOUHKyspKpUAtlUpRUVGBgoICPHz4UOtFQpm1n7e3d6/2YpHR1taGwsJCFBQUoLCwEDU1Nbhx4wY6OjrQ2NgIgUAALpcLZ2dnuXcza2trtLe3o7OzE15eXvDw8ICNjQ3WrFkzZKqqZKSnpwMARo8e3W1fSkqK3L9tbGwYxw1WSHwz8Ghvb6f7eso+x7omJjwuNHE4HAQGBsLPz4/+jGCz2Zg0aRJmzJgBgUCAGzduoLGxUa3re3t7Izw8HEZGRjq7p7S0NKxbtw6XLl3S2nrTwcEBf/3rX7F582aNq1pra2vx+++/4+zZs0hNTe2xOBUUFIRZs2Zh8uTJtDglS47SBQYGBnK2tAMhBiQQCMz0uVAl8znWNUlJSTp/Se4pJMgZPOTm5uLAgQMKfeYLCgrw4MEDuLu7K3wojh8/Hm+//bZa9hl8Ph8rV67EyZMnVY7dsWMH1q5dq3KcNmRmZuLbb7/FhQsXVI6lKAqdnZ3o7OwEj8fD9OnTER4erjQoMjc3x+jRo+Hh4aHLaRMIBIJG6KuFsD5DYpz+RSwW49dff0ViYqJaC+9cLhfPPfcc5s+fr9Q2TiKRIDk5GZcuXQLwqNI6KSlJ6blZLBZ++uknvPjii5rdhBp0dHSguroadXV1Gi2iDzTBiqIolJaWIicnRyuxx8HBAYGBgXB1de23BXeKolBdXY27d+/S4lVWVpbW/TNUIRaLUVJSAuDRAiOXy6W/OByO3L+5XO6AqLRjsViwsbFhFJ5k2xwdHVVaeqpCIBCgoKAARUVFPVoodHJygo+PT69b+8mqvQoLC1FYWNjNeaKzsxPXrl0DAJSVlUEqlcLa2rpbUgqHw8GwYcNQWloKLpdLV5vGxsaSGIBAQ+KbgYOs5/b3338vVwna0dGByspKtLW1dTvGxcUFo0aNkvscdXNzwzPPPANbW1ukpaUhPz9fretbWFhg/PjxOrOolUql+Oyzz/Dvf/8bDx8+1OocLBYLEyZMQHx8PCZNmqTRsXV1dXTl1K1bt3osTgUGBiIqKgoTJ06Eubk5mpubddrvrmvVVE+fiwQCQX/ol4oqGxsbjTMklcFisbBq1Sq9K0knQc7gorCwED/++KPCBaHS0lJkZ2crFatGjRqF2NhYtbJtBAIBtm7dii+//FLl2BUrVmDXrl0qx2lLTk4OvvnmG9oCQhlSqRQdHR205cb06dMxZswYpQKdvb09IiIihlRDYwKBoB/os4WwPkNiHP2guroau3fvVrvHpJOTE1asWKEyO/7BgwdITExEW1sb7t27hxMnTqhcsPjss8+wZs0ateeuCSKRCHw+HzU1NRoLVg4ODnBwcBgQghXw6G/r3r17WlnrWVhYIDAwEN7e3r3eE0gdpFIpSkpK6IqrrKws5OTk6KSqqaOjQ6OFPA6Hwyhgdf3qTZFP9rvYVYR6XIyyt7fXuh+UKjo7O1FcXIyCggLU19drfR5zc3P4+PjA29u716z9RCIRysrKUFBQoFa1l6zfrqqKKqlUChaLBRaLNeQrqgiKIfHNwODhw4fYtWuXnE2xVCpFTU0NY8KHqakpQkND4ezsTG8zNjbG7NmzERERgZKSEty+fVst8Z7NZmPEiBEIDg7WSWxRVFSENWvW4PTp01o/H62srLBkyRL885//1MgWuL6+HsnJyThz5gxu3brVY/u94cOHY8aMGRg3bhwsLCzQ3t7eo/N1hcvlylVN6UOcQyAQdE+/CFWrV69GQkICvL29GT1cb9++DYFAoHC/jPr6eqSlpSEqKgrW1tY4cuRIb05bY0iQM/goLS3FDz/8oDCAefjwIe7evas0szAgIADvvvuuWlkfbW1tSEhIwNq1a1UGDVOmTMGFCxd6NWP0wYMH+Pbbb3Hu3DmVC1ZisRgdHR2QSCSwsLDA1KlTMX78eKUv4F5eXhg9ejTJiCEQCH2CvlsI6zMkxtEfKIrCrVu3sHv3brWrcSZMmIBly5bBxsZG4ZimpiYcOXIERUVFKCkpwcGDB1XGIuvWrcP27ds1mr8miMViVFVVaSxYcTgcuofVQBGsmpubkZOTg4KCAo0zkI2MjDB8+HD4+/vrXU9QkUiEvLw8OfEqPz9f48UxmT2kLlElZHE4HEZBw8TEhLEPVFcxisfj9XlVF0VRtLVfeXm51guQXC4XHh4e8PHx6RVrP4lEgocPH9J2fqWlpQpdLBRRU1OD7OxsUBSFysrKbj2qWCwWOjs7IZVKwePxhmyPKoJqSHyj33R2duLo0aM4ceKE3LOxubmZ/tvvCpvNhr+/P/z9/eWe/6GhoZgzZw4A4ObNm6ioqFDr+g4ODhg3bpxObMT379+Pjz76CHl5eVqfY+TIkfjHP/6BZ555Ru1jGhoakJSUhHPnzuHGjRs9Fqd8fX0xZcoUjBkzBlZWVjqtmjIzM5OrmiJJBQTC4KdfhKpjx44hISEB586d67avsbERXl5e+O677zB//v+x9+dhbZ133vj/PtoBCSSx77ttwAsGbLwljm3s7EsTk6TLtzNtapO2M02nk5j6aZM202ZScKed5nmaxLjZm8WBLM1iuwY7TurExjbYsWNjx0ZmMfsmQIAkJJ3fH/6dUwlJoA0k4PO6Ll3AkXR0BEK6z/2+789975T7Ki0tRVNTE/bu3Tsdh+oVauTMTe3t7XjppZccTiUHrpftq6+vR0JCgtNQJjU1FU888YRLZSbGx8fx0Ucf4Zvf/CYMBsOkt01NTcXZs2enfXFtjUaD559/3qYOtDPc+lUWiwUhISF8YOVsVplQKER2djZycnJolAwhxM58KiEcyKiNE3gMBgPefvttfPjhhy51EshkMjz44IO47bbbnIY3FosFR44cweHDh9HV1YWXX355yg7kb33rW3j99dc9eg6u4hZH7+7unvOBlcFgwNdff41Lly65XaZNKBQiNTUVWVlZAb023+joKBoaGviygV999dWUM8q0Wu2MDDCwDq/EYjGUSiWio6MRHx+P5ORkZGRkICUlBbGxsYiNjYVKpfJ7R5pWq+XL5HlT2i86Ohrp6elISkryaZucZVl0dnbywdTVq1e9nmXHsizOnTuH/v5+jI2NoaenBxKJBDk5OVCpVDCZTNBoNBAIBFiyZAnCw8OxYMECfPe73/X734sEFmrfBCZuUM6LL76Inp4efvv4+Dg6OzsxNDRkd5/o6Gjk5uba9I2Eh4fj7rvvRmpqKv+540qbSSKRIC8vD+np6V69Z2i1WuzYsQNvvPEGRkZGPNpHUFAQtm7divLycsTExLj8uDU1NThw4ABqa2u9CpNYlkVaWhrWrVuH/Px8n1bFEQqFNrOmpmuWMSEkcPklqBocHMTTTz+N3/3ud3bXPfDAAygqKsK2bdtc3p9arcauXbvw0EMP+fIwvUaNnLmru7sbL774IoaHhx1e39fXhxMnTiA+Pt7pWhDx8fH49a9/PeloZo7FYsHJkydx66232tRfdiQsLAynT59Gamrq1E/ES83NzaioqMAHH3wwaWOHZVkYjUYYDAawLIvg4GDccMMNWLNmjdORvkFBQcjNzUVaWhqdQBJCbMyXEsKBjNo4gaulpQUVFRVoaGhw6fYpKSnYvn07Fi5c6PQ2V69exd69e/lSO1MNnLnppptw6NChaZ9B4k1gxa33M1sCK7PZjKtXr6KhocHlBd6txcfHIzs722draUy3gYEBnD9/ng+vzp49a1Oyrre316PfA4dhGD6EcjSTitvmbhtUIpEgOjoasbGxiImJQUxMDB9icd/L5XKft22NRiO/jpM3AZ5cLuermvhq4BvLsujr60NjYyMfoDkb8OcNkUiE06dPQyKR4Nq1a9BqtZDJZEhKSkJLSwuEQiESEhL4cl2PPPIIlR0ndqh9E3i6urrwwgsvoK6ujt/Gsiz6+/sdfv7LZDIsW7YM8fHx/HutSCTC+vXrceONN0Kr1eL48eMun0ukpqYiPz/fqxnKR44cwY4dO3Dq1CmP135KT0/Hzp078b3vfc+l9tXg4CAOHTqEAwcO4NixY16HU4mJiVi7di3y8/NtSih6Kzg4mA+nQkJCqO+HkHnOL0HVZDIzM1FXV+fWgqYFBQVgGAYnT56cxiNzHzVy5ra+vj68+OKLThs4Wq0WtbW1iImJcTp7KCoqCr/61a9cHgnT1NSEzZs3T7nAp1gsxp/+9CeUlJTMSJmR1tZW/OUvf8G77747aQPIYrHAYDDwoyaDgoKwbt06rF27FkFBQQ7vo1KpkJ+f7/LviBAy982XEsKBjNo4gY1lWRw5cgSvvvqqw1HGjmzevBnf+c53nHZOj4yMoKqqCmfPnkVFRQV0Ot2k+8vJyUF9fb3TATu+5G1gFRUVNWtmcXPl3C5cuOBR6Tu1Wo3s7GwkJSXNeCk6b3CzcLiSgS+++CI0Go3DvzfDMA5Dp4k/+0twcDAfWlmHWdbfO2sXW+NeCxqNBq2trV6X9ktLS0NUVJRPOgkHBwf5YKqxsdHl9yFXsCwLg8EAqVQKlUqF0NBQSKVSiEQinDt3DhcvXoTRaIRGowHLsggNDcXQ0BBCQkKwceNGyGQy3HTTTdi8ebPPjonMHdS+CRzj4+N4//338c4779iU9BsdHUVHR4fdjFGGYZCZmYmsrCyb9/j09HTcfffdCA0NxenTp/H111+79PhyuRyFhYUehzJGoxH//d//jWeffdZmFpg7xGIxbr75ZvzhD39AZmbmlLcfGhriw6kvvvjCq3DKYrEgPj4eq1evRkFBARITEz3elzWhUAiFQoGwsDCEhYXRrClCiI2AC6qEQqHbb6ZqtRqDg4M+rYXqC9TImfu0Wi1efPFFpyMXh4eHcezYMURFRTkdgaNSqfCrX/3K5Q/+3t5eFBcX48iRI1PeViQSYc2aNfjlL385Iydj7e3t+Mtf/mLXmJzIbDZDr9fz5YOkUinWrl2LdevWOV2YOSEhAXl5eW6F2ISQuWm+lBAOZNTGmR2Gh4fx+uuvo7q62qXbh4aG4rvf/S5uuukmh53VLMvi6NGj2LdvH/7yl79MuSZWbGwsLl68OGOf3SaTCd3d3eju7nbrvGA2BlbA9bD9woULaG5udnuEdnBwMLKyspCRkTErO4m4cLKurg5fffUVBgcHYTQaodPpMDAwgM7OTpsZWLNNWFiY0zArODgYOp0O165d82qh+ujoaKSlpSE5Odnr1/3IyAgfSnk7q8sad86g1+vBMAyUSiXkcjkiIiIcnjOYTCYcOHCAL/9n/R6VkJCA1atXQ6lU4qc//emsfN2T6Uftm8Dw5ZdfYs+ePejo6OC3mc1mdHd3O3xvj4iIwPLly23aG3K5HLfffjuWLFmC1tZWnDx50qX3TIZhkJOTgyVLlng06/rSpUv4j//4D1RXV7u93h4nNjYWP/nJT/Doo49O+f48PDxsE055+pgsy8JisSA2NhaFhYUoLCxEUlKSTwYvBAUF8bOmpmNWMSFk7gi4oCojIwN79uzBhg0bXLr96dOnkZ+fD4ZhKKgifjE8PIyXXnrJ6ajWkZERHDt2DGq1GsHBwQ5vI5fL8cQTTyA9Pd2lxxwZGcG//du/4eWXX3b5OENCQnDLLbfgN7/5DbKysly+nye46fmVlZWTlgeyXr8KuF4uZc2aNbjhhhscjuhmGAYLFy7E0qVLZ2SENiEkMM2XEsKBjNo4s8ulS5dQUVGBpqYml26flZWF7du3IykpyeH1ra2teOONN/DnP/95yrWEFAoFGhoaEB8f7+5he8zTwEogEPAlAWdTYDUyMoKLFy/iypUrkw4UckQsFiMjIwNZWVlO26mzlcFgQFdXFzo6OtDZ2YnOzk50dHTY/OysjHeg4cpoj4+P869puVwOpVKJsLAwKJVK/sL9rFAo7GbNhYSEID093evSfnq9Hk1NTWhsbERjY6NHs/sm4s4LuIvZbEZoaCi/rpxCoXCpc/PatWs4duwYLBYLNBoNxsfHIZFIkJGRgezsbHznO99Bdna218dL5iZq3/hXX18fXnrpJRw7dozfxrIshoaG0NnZaRfCSKVSLF26FImJifz7A8MwWLlyJbZs2QKz2YwTJ06gra3NpcePjIxEYWEhlEqlW8dtsVjw4osv4umnn4ZGo3HrvhyBQIAbbrgBu3btwooVKya97fDwMD755BMcOHAAR48e9TicslgssFgsiI6ORmFhIVavXo3k5GSvgySBQGAza4r6bgghrgq4oKq0tBTvvvsu6uvroVAoJr0tN2p6cHAQeXl501L6r6qqCtu2bcPVq1fd/rCiRs78MTo6ipdfftlpA0iv1+Pzzz+HUql0OmMoKCgI/+f//B+XT5yMRiPKy8vxxBNPuD2KNjIyEg8++KDLa2R5qre3Fy+99BLefPNNp4s5T1y/CrjeabJ69WrceOONDt8HJBIJli5digULFsyqsjWEkOk3l0oIBzJq48w+ZrMZ+/btw1tvveX0M9maUCjEnXfeifvvv99hCeOxsTG8++67eOqpp6ZcD0sikeDzzz9HQUGBx8fvCbPZzJcEnA+B1fj4OK5cuYKGhga31wBiGAbJycnIzs6e1rZhoBkZGeEDLOswy/p7V/5fpgPLsjCZTBgfH3c7gAT+2VGoUqmQlJSEzMxMZGZm8jOz4uLioFKpXOqQHB8fR0tLCz9j6tq1ax6vs8K1/fV6PcbGxvivwPVzFG52Y1hYmEftfJZl8Y9//AOdnZ04f/48urq6EB0djZycHNx2220oKSmh0fzEKWrf+IfZbMZHH32EvXv32gx0NRgM6OzsdFhuOD09HdnZ2TYhSGxsLO6++24kJCTg4sWL+PLLL10KccRiMfLy8pCRkeHW+0Nvby8effRRvP322x7PcFWpVHjooYfw5JNPTjpgRKfT4ciRI9i/fz+OHj3q0ecCN2vKYrEgMjISq1evxpo1a3wSTslkMptZU9RPQwjxRMAFVYODg0hJSYFQKMTOnTvxn//5n3a3GRoawtNPP42KigoMDAyAYRjs3r0bP/jBD3x6LBqNhp/hMjAwQEEVmZRer8err76K5uZmh9cbjUZ88cUXkMvlTkcwisVi7NixA3l5eS49ptlsxt69e/Gv//qvHjVUACAtLQ0PP/wwHnnkkWkb6dLf349XXnkFr7/+utOOE5Zlodfr+fWrgOulCwsLC7F+/XqEhYXZ3UehUCAvL89n9ZIJIbPfXCohHMiojTN79ff346WXXsIXX3zh0u0jIiLw0EMPYcWKFXadGCzLora2Fj/96U9RW1s76X4EAgHeeOMNPPDAAx4fu6e4ckFdXV3zIrCyWCxoaWnBhQsXPCp/Fx0djezsbMTFxc37Dn2WZTE4ODhpmOVolL83zGYzxsfHYTQaPQ6DgOufhxKJBGKx2OnfUSKRIDo62q7EYGRkJBiGwcjICDo6OtDa2urRZyS3Pq11KMVVUxAIBAgPD0dkZCSio6OhVqt91rE5PDyMZ599Fk1NTTCbzRAKhVi0aBH27t076dqVhFD7ZuZduHABFRUVNjO0LRYL+vr60NPTY/c+qFarkZubC5VKxW+TSCQoKirC6tWrMTAwgOPHj2NgYMClx09OTkZBQYFLawNy/v73v2Pnzp04c+aMx+/TS5cuxVNPPYU77rjD6W1GRkZw5MgRHDhwAP/4xz9s+kpcxQVTZrPZJpxKTU316jNeIBBALpfzs6acrctOCCHuCLigCgDq6+v50c0AoFQq+QalRqOBVqsFAP4DYfPmzQ7XqfBWfn4+6uvrAVBQRVxjNBrx17/+FY2NjQ6vHx8fx7Fjx/jRJo4IhUL89Kc/xZo1a1x6TJZl8cUXX+C2227zaqFigUCA3Nxc/PznP0dxcbHH+5mMVqvFq6++ir/+9a9OF2G3WCzQ6/U2wZtQKMSKFSuwYcMGh/+H0dHRyM/Pn1cjgAkhjs2lEsKBjNo4s9/p06fxl7/8BZ2dnS7dvqCgAA899JDd3x24vkZlSUkJPvroo0n3wTAMnnjiCTzxxBN+GWnrTWAVGRmJmJiYWRVYAdfLMV+4cMHlskfWwsLCkJWVhdTUVI/W6ZgvLBYL+vv77UoLWodZPT09fKlrR1iW5cMpbz6LGIbhwyl3/mbWs7e4EoPcubZIJOIH2snlcoSEhNh9LxaL+fWkrGdJTSwBrlKp+FJ+4eHh0/L/pFAooNfr8bOf/QxjY2MYHx+HVCpFaGgoDh8+jJSUFJ8/Jpk7qH0zc7RaLV577TW7tbdHRkbQ3t5uF8pIJBIsXrwYKSkpNgFLTk4Obr/9dgQHB+PLL7/EpUuXXAqPQkJCsHLlSpdLE+v1ejz55JOoqKjweA1EmUyGe++9F//zP/+DmJgYh7cZHR21CacmW0rBEetZU1w4tWbNGqxatQrp6elehVMSiYQPphyVlyWEEG8FZFAFXA+kSkpKcOjQIQCweTO1PuSioiJUVlY6nG3hjdLSUoSHh6O0tBQABVXEdSaTCW+++SYuXrzo8Hqz2Yza2loIBAKnrymGYfCjH/0IGzdudPlxe3p68Nhjj+GDDz5wefSQM1KpFDfeeCN++9vfYuXKlV7ty5Hh4WG89tprePXVV52GayaTia9PzxEIBMjPz8eGDRsQHh5ud5/09HTk5ua6NRqKEDK3BFoJ4bmK2jhzg9FoxLvvvov33nvPpRkhEokExcXFuOuuu+w6mA0GAx599FH8v//3/6bcz7e+9S08//zzU/6PThcusOru7nZrJgwXWEVHR0MsFk/jEfre4OAgGhoacPXqVbeDEJlMhoULF2LBggU0YtpDJpMJPT09NuFVe3s7GhsbcfXqVXR0dDgdxOUKsVgMiUQCoVDoUicky7I2M7fGx8cnDdIc3Z+7WCwWCIVCSKVS/iKTySCTyRAeHo6EhASkpKQgJibGp9UbuHMplUoFtVoNlUoFlUoFkUiE7du34+jRo+jr60N/fz/UajXCw8Nxww03YPfu3fN+piBxjto3089iseDgwYN21VZMJhO6urr4genWkpOTsWTJEpvPIKVSiTvvvBOLFi1Ca2srTp486VLZW4ZhkJWVhaVLl7oUln/11Vf4j//4D3zyySceDyRITk5GaWkpSkpKHIY7Y2Nj+PTTT3HgwAF8+umnbodTXDDFhVMRERFYs2YN1qxZ41U4xTAMFAoFX9JPJpN5tB9CCHFVwAZVnJqaGpSVlfGBFXD9A6mgoAAlJSW47777pu0xq6ur+Td0CqqIO8xmMyorK3Hu3DmH11ssFpw8eRJms3nSWUDf//73cfvtt7v8uBaLBcPDw6itrUV5eTm++OILj2slc8LCwnDHHXfgqaeeQnJyslf7mkin0+GNN97Ayy+/7LBByo0u1ev1NgG1QCDA8uXLsWHDBrv/J5FIhJycHGRlZc26Uc+EzDSWZVFXV4eOjg7ExsbyM4tms0AqITyXURtnbmlvb8eePXtw9uxZl26fkJCA7du3Iycnx2Y7y7J49tln8e///u9TjmZev349/vKXvyAjI8Pj4/aW2WxGT08Purq65k1gpdfrcenSJXz99ddud4QJhUKkp6cjKyvLbyHjXDA0NASNRgONRmPTqTo+Po7BwUFotVoMDg7y33M/a7Vam/WyXCntZ81sNvOhlNFodDmYsg6kuK/OCAQCCIVCiEQiCIVCmw5ZuVwOpVKJsLAwKJVK/nvu59DQUKej88ViMR9GcV+drWFVXV2NRx55BCzLorW1FePj4xCLxUhMTATDMHjmmWdQVFTk0nMn8w+1b6bX5cuXsWfPHpsKNCzLYmBgwOF6kmFhYVi+fLnNIFWBQIB169Zhw4YNMJlMOHnypE3ZwMmEh4dj1apVNmUDHbFYLHj22Wexa9cutLS0uPEM/0koFGLjxo34wx/+gMWLF9tdr9fr8dlnn2H//v349NNP3VoPceKsKZZlER4ezodT7q61ZU0ikfDBlEKhoBnVhJAZFfBB1UzTarXIz89HXV0dlEolBVXEYxaLBe+//z7q6uocXs+yLOrr66HX6x3ODuI8+OCD2Lp1q9sNDZZlMTQ0hPfffx/PPPMMvvzyS6/LWsXFxeFb3/oWHn/8caelCz0xOjqKvXv34oUXXnA4jZ5lWRgMBrsOFYZhsGzZMmzcuBHR0dE21wUHB2P58uV2pQEIIf905swZfPXVV/zPixcvRm5urv8OyEcCpYTwXEZtnLmHZVl8/vnneOmllxwOHnFk/fr1+Jd/+Re7ygY1NTW49dZbpwx/li1bhvLychQVFfm1fIw3gVVERARiYmJmXWBlMpmg0WjQ0NCA4eFht++fmJiI7Oxs+p930fj4OJqbm9HY2Iienh6P9yMQCKBQKCCVSjE0NORw7Syus9NisdgEU66cB0wMpKbqKmAYhg+lRCKRV//H3HPj/qfi4+ORnJyM9PR0pKamIjY2FiqVatLHGBsbw+23347Ozk4MDAzYnFdwAVdsbCw+/vhjmhlAHKL2zfTQ6XR4/fXXUV1dbfO+otfr0d7ebje4lht8mpaWZvM/n5SUhHvuuQdRUVG4dOkSzpw549LntlgsRm5uLhYsWDBp30B7ezseffRRvPfee24FR9bCw8NRUlKCxx9/3O59xmg04vPPP8f+/ftx+PBhl2aAcbiZsFxAxYVTq1evxurVq5GZmenRezDDMJDL5Xw4RdVpCCH+REHVBPn5+SgrK+NHWbkaVDk64ejt7UV2drbNNmrkzC8sy+Ljjz/GsWPHnF5/9uxZDA0NISIiwmmj6a677sJ3v/tdjwMXbiHoZ599Fi+++CI0Go1XizMzDIMFCxbgRz/6ER5++GGflfHQ6/V4++238cILLzj8n3K0fhVn6dKl2LhxI2JjY222h4eHIz8/3+GaGoTMZ0NDQ/joo49gsVjQ2dmJmJgYCAQC3HHHHT4Nov3F3yWE5zrqyJm7RkdH8eabb2L//v0ur/Hw7W9/G5s3b7bpILly5QqWLl065czutLQ0PProo/jmN7/p9qAwX7NYLPwaVvMlsGJZFteuXUNDQwO6u7vdvn9ERASys7P52Srkn1iWRWdnJxobG9Ha2urxgDGhUIjExESkp6cjJibG6e9Zr9dDo9Hg3LlzOHv2LJqbmzEyMgKdTsdfuJ+tOzq5r678vzMMYzdjypu/O7cPoVDIXybbn1gsRkxMDH+JjY1FbGws//N7772HV155BWazGa2trbBYLJDL5dDpdBAIBEhMTIRIJEJJSQkeeeQRj4+bzF3UvvEtlmXxySef4LXXXrMp+c993vb19dndJzExEUuXLrUJeYKCgnDLLbcgPz8fAwMDqK2tdXhfR5KSklBQUIDg4GCnt/nggw/wy1/+0mlFnKkwDIO8vDw8/fTT2Lx5s811ZrMZx48fx759+1BTU+Py4BDrWVPcBbgeunPh1IIFCzwKp8RiMR9MhYaG0qwpQkjAoKDKCrceVVlZGb/N1aDK1QY6NXLmH5ZlUV1djU8//dTp9Q0NDXyj2NlrafPmzdi+fbvXI465k+annnoKlZWVHnVKWBOJRMjPz8fPf/5z3H777T7poDEYDHjnnXewZ88edHV12V1vNpsxNjbm8IQ/JycHmzZtslsUNSkpCXl5eZDL5V4fHyFzwaFDh9DR0YH+/n40NDQgKysLarUacXFxbq2PF+j8UUJ4PqCOnLlPo9GgoqICly9fdun2mZmZ2L59Oz97EQD6+/uxYMGCKTuToqOj8cMf/hD3338/srKyvDpuX7BYLOjp6UFnZ6dbgRXDMIiMjJyVgRVwfZBdQ0MDWlpa3B7QJJfLkZWVhfT09Hlfenl4eBiNjY12pf3cFRkZifT0dCQnJzt8PVnP0tJoNGhra7P7u3FltMfGxqDX66HX6zE6OorR0VEYDAbo9Xq+agH3PfcV+GcwZT1jypNgimEYu0DK1x2j4+PjaG1tBcMwMJvNMJvNEIvFUCqVGB4ehtFohFwuR2xsLMRiMT744AOflzUnsx+1b3ynqakJFRUVuHTpks324eFhdHR02A0+VSgUyM3Ntfv95+Xl4ZZbboFUKsWXX36JixcvuvQZFRwcjJUrVyIhIcHh9aOjo/jlL3/p1kzyiYKCgvDAAw9g165diIiI4LebzWbU19dj3759OHjwoMtriDuaNQVcP3dZvXo11q5d63E4ZT1rarLQjhBC/ImCqv+/mpoalJaW2pVpo6CK+MqRI0dQXV3t9PrLly/j2rVrk46UXLduHX7yk5/47MSOZVmcP38ev/71r3Hw4EGPSr9YCw4Oxk033YTHH38c+fn5XnfSGI1GvP/++9izZw/a2trsrufWr3JUKz8rKwubNm1CYmIiv00gEGDRokVYsmTJrOxAIsRXWlpa8Nlnn8FiseD06dPQ6/WQyWRYvnw5BAIB1q9fb/O/Q8hE1JEzP1gsFlRXV+P111/HyMjIlLdnGAa33norvvnNb/KdIHq9HosXL7ZZj8KRsLAwbNu2DTfddBNuvvnmgAg7vAmsuBlWvpp1PpN0Oh0uXryIK1euuPW8getrW2RmZmLRokXzqnyQr0r7BQcHIy0tDWlpaXazm81mM65du4bGxkaHs7QsFgsfNFkHU66uRQVcbyuHh4cjMjKS//sNDQ3ZrJ3FfdXpdA73YR1ucZeZKO3Z0dGB0dFRPpzjyhIyDAOWZWEymSASiRAXF4fg4GCsW7cOu3fvppmAxAa1b7w3NjaGt956C/v27bN5/xkfH0dHR4ddn4NQKERWVpZd6bqIiAjcc889SE1NRVtbG06cOOFyW2ThwoVYtmyZw3P+U6dO4dFHH8U//vEPt94fraWlpeGXv/wl/uVf/oU/Zq5azr59+3DgwAGXPgu42azW4RRHqVRi1apVWLNmDRYuXOh2H5BIJLKZNRUI7SpCCJkKBVWwX5fKGgVVxJe++OILfPzxx06vv3r1Kq5evYrY2Finr6n8/Hw8+uijPu/4YFkWhw8fxm9+8xt88cUXDsvruSM8PBx33nkndu7ciZSUFK+O12Qy4cMPP8Tu3bvtFjNlWRZGoxEGg8HhyKoFCxZg06ZNSElJ4bdJpVIsW7YMmZmZdHJK5h2TyYQPPvgAo6OjaG1ttfmfSkpKQmJiIkJCQnDnnXfSCQ1xijpy5hetVotXX33V6ezwiVQqFf71X/8Va9euBcMwsFgsWLNmDWpraye9X1BQELZt24YFCxbgwQcfnHQNz5nEBVZdXV1utY9me2BlNBpx+fJlXLx4ccoSjhMJBAKkpKQgOzvb7yUdpwvLsujq6kJjYyNaWlp8XtrPYrGgo6MDGo0GGo0GTU1NMBqNAK6HVlwQxYVSztrCU1Gr1YiKikJUVBTCw8Nd/uwfHx/nZy4ZDAaMjY1haGgIfX19/HpZ3g6Cc9XIyAg6Ozv542JZ1m7WlsViAcMwkEgkfKnKZ555hi/5TwhA7RtvcGtdvvzyyzYziFiWRX9/P7q7u+2Cobi4OCxbtsxmho9IJMKGDRuwbt06jI+P4+TJk3Z9AM6o1WqsWrUKarXaZrvFYsH//u//4g9/+IPDAbCuEIlE2LJlC/7whz9g4cKF/HNraGjA/v37sX//frS3t0+5H66kHxdOWb9vh4WFYdWqVVi9ejWysrLcDqdCQkJsZk1RXwchZLahoArXS6qVlJRg69atdtdRUEV87dSpU3j//fednki2trbi66+/RlxcnNPXVU5ODnbu3DltI1UtFgteeeUV/PGPf8RXX33l1XpWAJCcnIxvfetb+PGPf4zIyEiPO2vMZjP27duH559/HlevXrW5jmVZ6PV6/gR+ooyMDGzatMmmJFFYWBjy8/MRFxfn0fEQMhudOXMGX331FfR6PU6fPg2LxYKIiAj09vZCIBBg+fLlkMlkWLx4MXJzc/19uCRAUUfO/HT+/HlUVFTg2rVrLt1+6dKl2L59O79+5De+8Q28//77k95HLBbjoYceQmxsLO655x4sXbrU28P2GYvFgt7eXnR2ds6rwMpisaCpqQkXLlzwqDxSbGwssrOz7dYRna2Gh4f58MiV0f3ORERE8KX9JBIJWJZFT08PNBoNGhsbcfXqVYyNjfEVBLhAitvmqbCwMD6YioiIcOk1yTAMlEolVCoV1Go1VCoVVCrVlPcdHR3lQ6vOzk6b7zs6OtDR0QG9Xu/xc+G0tLTYBGcMw9jNpBCLxfzMKu45JCYm4sCBA9SZS3jUvvFMW1sb9uzZY7fG0+joqMP/8+DgYOTm5tp9LmRmZuKuu+6CSqXC5cuXcfr0aZfe70QiEZYtW4ZFixbZ/D+3tLTgZz/7GT788EOn/QRTiYqKwo9+9CP84he/4IP8K1euYP/+/di3bx+am5un3Ac3W4oLp6wpFAqsWrUKa9eudTucEgqFNrOmqGoMIWS2m/dBVXl5ORobG7F7926H17saVDma1tvb24vs7GybbdTIIQDw5ZdfoqqqyulU846ODly4cAGxsbFOS2VkZmbil7/85bSvuWQ0GvG73/0OL7zwgssjmZwRCATIycnBww8/jPvuuw9KpRJSqdTt/ZjNZvz973/H888/jytXrthdp9frnZaqSU1NRVFREdLT0/n/77i4OOTl5c3ZEb+EcIaGhvDRRx/BYrGgoaEB/f39CAsLw6JFi3Dq1Cn09/cjNTUVWVlZEAgEuPPOO6FQKPx92CQAUUfO/MXNyqysrHSp00ckEuEb3/gG7rvvPojFYvzoRz/Cc889N+l9hEIhvvOd7yA+Ph4FBQW44447AqrzxZvAKjw8HLGxsbMysAL+2Ubt6Ohw+74qlQpZWVlISUmZkVJwvjQ+Po6WlhY0NjZ6tb5rUFAQ0tLSkJ6ejtDQUAwMDPBrTDU2NqKvr8+mbJ+zNVndIZfL+WAqMjISMpls0tuLxWI+iOICnbCwMJ+vKQVcH2g2NDTkNMziLpP9n5lMJr6j2NlsKuB6x7hUKsXAwACEQiFfbeHIkSN2n2dk/qL2jXsMBgOqqqrwt7/9zea9ymw2o6ury25tJoFAgIULF9qVslMoFLj99tuxePFiDA4O4vjx4+jt7XXpGBISErBixQqEhITw26qqqvDEE0+goaHBo+fFMAxWrFiBXbt24cYbbwQANDc38zOnplq/k5s1xYVTE7tdg4ODUVhYiLVr12Lx4sVuVbEIDg7mw6mQkBAK2gkhc8q8D6rS09Oh0Wjcuo+rvzJq5JDJXLhwAW+99ZbTk8+enh6cPXt20rAqKSkJv/rVr2YsYOnu7sbjjz+Oqqoq9Pf3e7UvqVSKwsJC/PSnP8Xq1auhUqncDq0sFgtqamrw3HPP2S3SajKZMDY25jQMTEpKQlFRERYsWACGYcAwDDIyMrBs2bIpT+AJma0OHTqEjo4OdHV14cyZMxgbG0NsbCxMJhMMBgNaWlqQkZGB7OxsqNVqxMXFYePGjf4+bBKAqI1Duru78cILL+DUqVMu3T4mJgbbtm1Dbm4ufvvb3+Lxxx+f9PYMw2Dr1q3IzMxEVFQUvvnNbwZcZ7K3gVVMTIxHA3YCwcDAABoaGtDU1OT2Gh9BQUFYtGgRMjMzAzqwY1kW3d3dfGk/d9fr4giFQiQkJCA9PR1yuRxNTU34+uuvcf78eXR2dtoEU744NQ8KCrIJpqw7bx3dlgujuK9yuTygOj4tFgsGBgb4GViOZmadPHlyyhlVCoUCY2NjNKOKTIraN65hWRYnT57Eiy++aDNom2VZDA4OorOz066fIzo6Grm5uTYDbRmGQWFhITZv3gyRSIRz587hwoULLr0XBgUFYcWKFUhKSgJwfUDeL37xC7zyyiselx2Vy+X49re/jd/97ndQKpVob2/HgQMHsG/fPly4cGHS+05ca2ric5DJZCgoKMC6deucrp/liFAohEKhQFhYGMLCwgJq4A4hhPjavA+qJqPVaqFSqQBMPaPKEWrkkKlcvnwZr7/+utPOjf7+fpw5cwbR0dFORzHGxMTg17/+9Yy/rr766iv84he/QHV1tdvrFkwUFhaGTZs24ZFHHkFmZiZUKpVbYRHLsjhy5Aiee+45fPXVVzbbuXIpzt7qEhISsGnTJmRlZfEntYsXL8aiRYumZeQoIf4wMjKC06dPo6amBoODg2hoaMD4+DhUKpXNe0dPTw/kcjlUKhWWL18OgUCA9evXIzEx0Y9HH/gqKipQWVmJ/v5+vixWWlqa07LC1jQaDUpLS20GzaSlpWHnzp3Iy8vz+tima//UxiHAPzuqXnjhBZdHPq9Zswbf+9738N5772Hbtm1TdkbdeuutWL58OcRiMe68804sW7Ys4NbPs1gs/Lo87pQWmguB1djYGC5evIjLly+7XVZJJBIhIyMDixYtmvYKAe7Q6XT8LCdvSvuFh4cjPj4eBoMBDQ0NaGhoQFtbG7+elK9IJBI+mIqKinIaNIWGhtoEUmq1es4Mzjpw4AB+8pOfYHx8HB0dHTCZTJDJZJBIJDCZTDCZTBAKhTAajRCLxbRGFXGK2jdTczZQxWAwoKOjw+59UyaTYdmyZYiPj7d5b4qLi8M999yD+Ph4tLe348SJE9DpdC4dw8KFC5GbmwuxWIxjx47h0UcfxbFjxzwO+xcsWIAnnngC3/72t9HT04O///3v2LdvH86cOTPp/azL+TkatCEWi5Gfn4+1a9ciLy/P5c/6oKAgftZUoA0eIISQ6URB1SQ0Gg3S09MBUFBFpk9TUxNeffVVpyesg4ODqKurQ1RUlNOOmfDwcPz617/221pL+/btw29/+1ucOHHC6/IksbGxuPvuu7Ft2zbExsa6FVqxLIujR4/i2WefxZdffmmz3WAwTNopEBsbi02bNiEnJwcCgQByuRzLly9HcnKyV8+HEH8YGhpCV1cXuru70d3djZGREZw6dQoGgwF9fX3o6+uDSCRCcnKyTSBrNpsxOjoKhUKBpKQkJCYmQi6X45577vHfkwlwmzdvRl5eHnbu3GnTTigtLUV5eTny8vJw6NAhh22IqqoqFBcXo6ysDDt27OC3V1RUoKSkxG67u6Zz/9TGIdYMBgPefvttfPjhhy61A2QyGb75zW/CYrHg3nvvnfI+N954I9atW8f/LJFIEBwcjJCQEAQHBzu8hISEICgoiL/NTIxAZlmWn2HlbmClVqsRGxs7awMrk8mEK1eu4OLFiy53NHIYhkFSUhKys7MRHh4+TUc4Oa58nEajQVdXl1f7MZlMGBoaQktLC65du+bVelKOCIVCm2AqLCzMphNTKBQ6XE8q0AJeX2JZFiUlJTh69Ci/Jg7DMEhISIBEIoHRaERrayuA623+4OBgrFu3Drt376YOYGKD2jfOjY+P4/3338c777xj877GzS7u7e21CYoYhkFmZiaysrJs3n+kUik2b96MwsJCGI1GnDp1Ck1NTS4dg0qlQmFhIZRKJXbt2oVnnnkGnZ2dHj0fsViM22+/HX/4wx+gVCpRXV2Nffv24eTJk04Dr6lK+gH/XC9r7dq1KCgoQHBw8JTHIhAIbGZNBfJsY0IImU4UVE2ipqYGmzdvBgBUV1e7PdqKGjnEVdeuXcPLL7/sdGaSTqfDyZMnERER4bSjJTQ0FE888QRSU1On81AnZTKZUFFRgWeeecauFJ+7uIbtd77zHdxzzz0IDw+HSqVCUFDQlPdlWRbHjx/Hs88+i7q6On67xWKBXq+ftMMgOjoamzZtwpIlSyAQCBAZGYn8/HxERER49XwImS4sy2JgYIAPpbq7u+0WLDYYDDh16hRYloVGo4HZbEZ4eLjDDsHx8XGIxWKIRCKsXLkSDMPgvvvuc+l/b77hAp8dO3agrKzM7nqVSgWtVuvwem4wzNatW1FZWWl33/LycpSWlnrU/piJ/VMbhzjS0tKCiooKl9eESElJQWFhIf6//+//mzLYWb58OW699VaPj00kErkVbAUHB0MikXjUiT2fAyuWZdHS0oILFy6gr6/P7ftHRUUhKysLCQkJ0x4geFPaz2KxYGxsDMPDw+jo6MDo6CiGhoYwMjLik/J91gQCAcLDwxEdHY3IyEio1Wq+LLhEIrEr3TcxuJovmpqacNddd8FkMqGzsxMjIyMICgpCbGwsOjo6MDY2hpCQEMTExEAsFuODDz6gAWnEDrVvHPvyyy+xZ88eu/UJdTodOjo67D7rIiIisHz5coSGhtpsX7x4MW6//XYoFAo0Njaivr7epc9JoVCIZcuWQSqV4j//8z+xb98+jwcBxMbG4ic/+QlKSkpw5MgR7N+/H8eOHXM6aMa6pJ+z2wgEAixZsgRr1qxBYWGhS7OEJRIJwsLCoFQqIZfLZ93ajYQQMh1mZVB15swZ1NTUQKlU4v7777f78PMW17E0cfQzt23igpDOUCOHuKOzsxMvvvii0xIjo6OjOHnyJFQqldMRNsHBwfjlL3+JhQsXTuehumRoaAhPPfUUXnvtNY8W3LYmFouxfPlybNu2DatXr+ZHiboyOunkyZN49tlnUVtby28zmUzQ6/WTjuCOjIzEpk2bsGzZMggEAqSkpGD58uWT1vknZCaYzWb09fXxoVRPT49LJ2quzqhqbW1FcnIykpOTaUbVFEpKSlBRUYG0tDQ0NjbaXb9582bU1NSgqKgI1dXVNtcVFxejqqoKdXV1DkvwceWHne17KtO9f2rjEGe4cryvvvoqhoaGXLrP0qVLsWvXrinLrGVmZqK4uNgXh+kSoVDoVrAVHBwMmUzGhwQsy6Kvr89hJ95UuJKAs7k0W3d3NxoaGviZLO5QKBTIyspCWlqaz2cC6XQ6aDQaaDQal2Z/mUwmjI6OYmRkBMPDw+jq6kJXVxcMBgNfYs6XHYwMw0ClUiEqKgrR0dFQq9V80Go9Q0qtVlO7dIL//d//RUVFBUwmE1pbW2GxWCCXy6HT6SAQCJCYmAiRSISSkhI88sgj/j5cEoCofWOrr68PL7/8Mr744gub7VwgPDg4aLNdKpVi6dKlfHlNjkqlwp133omFCxdicHAQtbW16O7udukY4uLioNFoUF5ejsuXL3v0PBiGwZo1a/DUU09heHgY+/fvx9GjRx2eQ7Esa7felLN9ZmVlYe3atVi1ahXCwsKmPA65XM7PmqJBgIQQYi/ggqp3330XwPW1eQCgoKAAubm5/PU7d+5EeXk5/zPDMKisrMQ3vvGNGT1OV1Ajh7irt7cXL7zwgtOOHYPBgBMnTiA0NNTpSFupVIqf//znWLp06XQeqluuXr2Kxx9/HB9++KHLnVbOhISE4MYbb8TDDz+MtLQ0/mR9qtCqvr4ezz//PI4ePcpv49avmmwR8PDwcGzcuBHLly+HRCJBVlYWcnJyaBFTMmPGx8fR09PDB1N9fX0eldjs7e3FpUuXYLFY0Nzc7HCNqoGBAYyNjSE5ORkFBQW0RtUUtFotnn76aTzwwAMOw6DJZlRZd2Q7w93fk/LD071/auOQqQwPD+P111+3C2mdkUgk2L9/v12n10QymQwRERFISEjAwoULERsbG1CjkAUCAYKCguyCLZPJhJGREYjFYshkMv4SFBQEiUTi9DlwM6xmc2A1NDSEixcvorGx0e3PL6lUigULFmDhwoVe/Q5MJhNaWlrQ2Ng4aWk/o9EInU6HkZERjIyMQKfTYWBgAENDQ/yMKalUipCQEJ+2BZVKJSIjI/lZUxEREXYzpagU1NTGxsZw++23o7OzEwMDA3yfAgD+9xgbG4uPP/54Vv9PkelD7ZvrzGYzPvroI+zdu9emfD5XyaGrq8vuHDo9PR3Z2dk271UCgQA33HADNmzYAIFAgK+++grnz5+f9PybYzKZcPDgQXzwwQcerxcYGhqKb3/729iyZQuOHDmCzz77zK7yBPe8rNebmqz9nJmZibVr12L16tVTlqsVCoUIDQ2FUqlEaGjonC7BSgghvhBwQVVBQQFOnz6N1NRUPPzww9i+fTs/Y2rPnj0oKSnhb8t1qgwODkKj0QTc1H1q5BBPDAwM4MUXX7Q5sbLG1XHmRu06IhKJcPfdd2P16tVISUkJqPIfR48exZNPPolPP/3U65r9ERERuO222/D973/fZoTpZKNLz507h+eeew5HjhwBcL1RajQaYTAYpuzQ3bBhA/Lz8yGXy5Gbm4v09PSA+t2SuUGv19uU8RsYGPBZGaHz589Dq9VCp9Ohvb0dYrEYy5Yt49fAu3jxIgAgKysLarUacXFx2Lhxo08ee77h1odSKpW4evWqTRBUX1+P/Pz8KWdp5+fno76+HpWVldi6davLjz3d+weojUNcd+nSJVRUVLi0/oTJZMKnn346ZVg1UVBQENRqNRISEpCZmYmEhISACq84LMtibGwMOp3OJrBhGAYSicQmvLIOs2QyGaKjo5GcnAy1Ws0HYdYzYmcDg8GAr7/+GpcuXXLYUTgZoVCI1NRUZGdnu1VNgyvt19zcbFPaj2VZ6PV6PozigiluEBMXTA0NDcFkMvG/c+sZc96Qy+WIiopCXFwcFixYgNjYWL4tq1QqZ93fNpBUV1fjkUceAcuyaG1t5UsaczM8nnnmGY9K3pL5gdo3QENDA3bv3m03G3ZsbIwvo2lNrVYjNzcXKpXKZntKSgruvvtuREVFobOzE7W1tRgeHnbp8d977z1cvHjR43OgrKws3H///RgdHcXhw4cxOjpqdxvrtaamCs5SUlKwbt06rF69GtHR0ZPeViaT8bOm5HI59RcQQogbAi6oysjIQF5eHt5++22b7YODg/wHH8Mw+N3vfofHHnsMwPV1Furq6rB3794ZP97JUCOHeGpoaAgvvvgienp6HF5vMplw8uRJvjNjMlFRUSgsLMSqVauwcOHCgGkoWSwWvPHGG/jDH/6AL7/80qVRVZNJSUlBcXEx7rvvPgQHB/Mn+s7qQ58/fx7PP/88Dh06xB+PwWCYsjRPWFgYNmzYgIKCAkRFRSE/Px8xMTFeHTuZ30ZGRtDd3Y2uri50d3d7PetwMmKxGJcuXYJcLkdHRwd0Oh3CwsKwePFinDt3DkNDQ1Cr1cjKyoJAIMCdd94JhUIxbcczHZqamlBVVYXGxkY+8Fer1cjPz5+WcsGOcGtXpaWlobq6GmlpaU6vn6zsHlc60NkaWK48vi/27+izqLe3F9nZ2TbbqI1DnDGbzdi3bx/eeuutKQMKi8WCTz/91OVS287IZDI+vMrIyEBSUlLAhFfOAitXBAUFQS6XQyQSQSqV8mUIXS1RGAijuc1mM65evYoLFy549JkXHx+P7Oxsp52FIyMj0Gg0aGxshE6ng8ViwcjICEZHR21CKa7taTQabYIpbvaARCLhf3/eBkdBQUF8kJqVlYXk5GSoVCooFIqAaZvPFSzLYvv27fj8888xOjqKjo4OxMbGIjg4GOvWrcPu3bvpd06cms99OFqtFq+99ho/oJNjsVj4qg7WJBIJFi9ebDcwNjg4GLfccgvy8vJgMBhQX18PjUYz6WObTCZ88MEHOHTokMfnQhKJBOvWrUNOTo7DUIybNcWFU1N1hSYkJGDt2rVYs2YN4uPjnd6OYRjI5XIolUqEhYXN2jUmCSEkEARcUKVWqx3OJHn44YdRUVEBhmGwdetWu1CqoKAAp06dmqnDdMl8buQQ742MjOCll15yur6T2WxGXV0dRCKRS2s1AddnIa5cuRKFhYVYvHhxQHRWANdnkPz+97/HCy+84NKI68kIhUIsXrwY3//+97F27VqIxWKbmVYTT0wvXbqE559/HgcPHuRrUev1+ikX1A4NDcX69etRWFiI1NRU5OXlzUgHOJn9BgcHbWZMeVrKYioMw0CtViMqKoq/SKVSnDlzBl999RX0ej1Onz4Ni8WCiIgI9Pb2QiAQIC8vD1KpFIsXL7YpvRvo3n33XZSWlk55Ipyfn4+ysjJs2LDBp49fUlKCmpoa/vGLiopQWVnpsKReeXk5SktLXQ6Stm7disrKSpePxdf7d7VDj9o4ZCp9fX146aWXcOzYsUlvx7Isvvjii0lLtHlCJpNBpVIhPj4eGRkZSElJ8Wt45U1gJZPJIJfL3S4/J5FInIZaztbeEovF09Kxz7Is2tvbceHCBY/+1mq1GtnZ2UhKSoLFYkFraytfYpALo7iAyprJZLIJpqxnB3Drknlb2k+hUCAjIwMLFy7EkiVLkJaW5nJ7nUzOukSX2WyGyWSy+76pqQnf//73YTKZoNPpEBISAolEggMHDgRcFRYSWOZjH47FYsHBgwfx+uuv27xfsiyL4eFhdHZ22lVCSU5OxpIlS+xCmfz8fNxyyy0IDg5GY2Mj6urqJh0I2tHRgb/+9a/46quvPB64GhkZiby8PAwPD9sNcpm41tRU3Z8xMTF8OJWUlOT0s08kEvGzpkJDQ2kWLCGE+EjABVWOAqerV68iPT0dwPXOkoGBAbsO4Ztvvhl///vfZ+w4XTEfGznEt8bGxvDKK684XYTaYrHg9OnTYFnW6cwhZ4KDg1FQUIDCwkIsX748YEb+dHZ24sknn0RlZaXdqC13yWQyrF69GiUlJcjIyIBYLIZSqYRKpbKbht/Y2Ijdu3dj3759sFgsLq1fBVwv3bJ+/XqsXr0aixcvxtKlSwPmd0n8z7qOOxdMWdd59yWhUIjw8HBER0cjKioKERERDjvZuBGLo6OjaG1tRUtLC39dUlISEhMTERISgjvvvDNgwuypPPDAA6iqquJPPp2dVFpfX1xcjLfeemtajqempgYlJSXo7+9HWVkZtm/fbnN9aWkpysvLpy2o8vX+Kagivnb69Gns2bNnynCirq4Ozc3N03osQUFBCA8PR3x8PFJSUpCamjrj4RVXhk6n0005UGYiTwMrd3CDohyFWsHBwXbBVnBwMKRSqVvhVn9/Py5cuIDm5ma3Sj0NDg5ieHgYo6OjNrOhrJnNZgwPD9usM2WNYRiPS/sxDAOpVIrQ0FBkZmYiJycHS5cuRUJCwqydteMsCHIUCFlvm+rnyfYz2feOrnPFiRMncPr0af7noqKiafvcJ3PHfOvDuXz5Mvbs2WPXXjQajejs7LSblRQWFobly5fbrc0UFRWFu+++GykpKRgaGkJtba3Tz3iLxYLPPvsMH3zwgdMKMlMRCAR8OdyJgxGsy/m5En5FRERgzZo1WLNmzaSl/YODg/lwarKlBgghhHgu4HqgHH0ocOtSMQyDHTt2OJy1MNUIakJmo6CgIHzve9/Da6+9hqtXr9pdz81+OHv2LIaHh90q0TU6OorPPvsMn332GSQSCXJzc7Fq1Sp+DSZ/iYmJwXPPPYfnnnsOZ86cwa9//WscPHjQrha2K/R6PT755BN88sknUCqV2Lx5M7Zt2wa1Wg2RSMSXB1QoFEhPT0d5eTl+9KMfoaKiAh9++CFEItGU61fpdDp8/PHHOHLkCG644QasX78eK1aswMKFCwOmxBCZOWazGX19fXwpv56eHrc7HV0lFosRGRnJz5YKDw93aTSfSCRCQUEBPvvsM8THx6O7uxt6vR4ymYwva1FQUDBrQqoVK1agvr4eLMuCYRiwLDtlJyfLsqisrIRGo8GJEyd8fkxFRUVobGyESqXi2zDWYdVUCy97a7r3T4i3li9fjv/93//Fu+++i/fee8/p+2R+fj5CQkLQ0NDgs7X6JhobG8O1a9dw7do11NbWArg+GyYxMRFLlizBqlWrsGzZMphMJn52zsSLu7OhJuKCEplM5nZgpdfr+ffw6QqsrGcguUogEDgNtpyFXmvXrsXy5ctx8eJFXLlyxelapiaTCR0dHfzn10QWiwU6nY4/Zp1O5/D1Yz27zJXPT4FAwP+d5HI5H0xlZmYiPj7e5XYfFwT5IrDx9r7Ovp8LCgoKYDKZcO3aNSQkJODGG2/09yEREjB0Oh1ef/11VFdX27w/sizLn8tYbxeJRMjJyUFaWprNe51YLMaGDRuwbt06AMDZs2edzo4aGhrCm2++iRMnTkxZbt8ZmUyGqKgoBAUFQSAQYHR01O2SfsD1SjOrV6/G2rVrsWDBAofv3wKBAAqFgg+nJBKJR8dMCCHEdQE3o2rLli144IEH8NBDDwEAdu7cibKyMjAMg7S0NFy+fNnuPocOHcKWLVsCrlE930bjkOkzPj6ON954A19//bXD61mWxeXLl6HT6bwuK8KVzissLMTKlSvtFkX1l7/97W8oKyvDiRMnvP5fj4+Pxz333INvf/vbkEgkEIlE/Ewrbq2A1tZWVFRU4P3334fJZILBYHBpJkxQUBDWrVuHW265BWvXrkViYqJXx0oC2/j4OHp6evjZUr29vV6vt+YMd2LGXVQqlVejtQ8dOoSOjg709/ejoaEBWVlZUKvViIuLw8aNG3145NPnhz/8Ib/WBMuySEtLw9atW/HAAw8gLS0NYWFh/G2vXr2K+vp6m7XpGIZBSUkJnn322Wk5Pq4EHwAMDAzwZQC5NaSUSuWk6/BwM562b9+O3bt3u/y4vt4/zagi06m9vR0VFRU4d+6c09uYzWZcuXIFPT09/KyZmT6FUSgUSE1NxYoVK3Drrbfi9ttvh0wmA8uyMBqNDgMsZ8HWyMjIpEFUoM+wmi7WM5ukUimGh4f52fUSiQQSiQRSqRQCgQANDQ0QCAR8wMTNqBoaGsLw8LBNZ6X1V+tQUCwW86WgJl6EQiHfRhSLxZBIJPyM5cjISKjVar6klCvBz8TQiMy8uLg4/PjHP/b3YZAAN9f7cFiWxSeffILXXnvNbvDB6Ogo2tvb7c55ExMTsXTpUshkMpvtCxYswF133QWVSoWuri7U1tY6HNBw9uxZvP32217NkObWgOIG5rpb0g+4/jm+atUqrF27FllZWQ4HKEgkEj6YUigUNPCUEEJmWMAFVfX19SgoKEB6ejr6+/uh1Wr5k4q6ujq79TIOHz6M4uJiFBQUUOk/MqeZTCa8/fbbOH/+vNPbGAwGJCcno6+vD+fPn/e6w5xhGCxYsACFhYUoLCxETEyMV/vzBZPJhD//+c947rnncOnSJa/2JRAIsGDBAnznO9/Bli1b+A4PLrQKDQ1FR0cH9uzZg3fffRcGgwF6vd7pCF9rMpkMa9euxb333osbb7wRarXaq2MlgUGv19usLzUwMDBtnaVyudwmmPL1GmhDQ0P46KOPYLFY0NnZiZiYGAgEAtx5551uzc70l9OnTyM/P58PqcrKyvDYY4+5dF+NRoPi4mKcPn0aDMOgpqbG52tWAddLAG7evBkAsHv3bn5WVX19PfLz86cMkvLz81FfX4/Kykps3brV5cf19f4dlWXp7e1Fdna2zTZq4xBPsSyLzz//HC+99BK0Wq1L99HpdGhvb+fDK71eP+PhVUhICFJTU1FQUIBbbrkFd955p8sDhsbHx/nQamxszGGwNTIygr6+Pr78kivtD85sDqyssSyLwcFB9Pb28rOnWJZFZ2cnBgcHYTAYMD4+zrd5nb0GuMBJJBLZhe9CoRAikcjmIhAIIJfL+dn3YWFhs2amMXEsOjoaP/nJT/x9GCTAzeU+nObmZlRUVODixYs2281mM7q6uuzajAqFArm5uXa/j9DQUNx+++3IycnB+Pg46urqHJYOfO+99/DJJ594vB4v9z4cHR0NkUjkdkk/4Hq5vpUrV2LdunVO1+gOCQlBWFgYlEolgoKCPDpWQgghvhFwQRUAVFVV4f777+d/ViqVqKysxKZNm/hte/bsQWVlJWpqagBcLw/43HPPzfixTmYuN3KIf1gsFrzzzjs4c+bMpLe78847kZOTg1OnTqG2thZnzpxxq3PDmeTkZKxatQqFhYWTLi46U7RaLZ566in89a9/RWdnp1f7EovFKCgowLZt27B06VIAsAmtRkdH8eKLL6KqqgojIyPQ6/UujYiVSCRYs2YNvvvd7+LGG2+kxu8so9PpbIIpd8oeuSssLIwfrR0VFTUji66fOXMGX331Ff/z4sWL7QaEBKr7778fVVVVYBgGp06dwvLly93ex+bNm/lZ2QcOHHDrvlqtlg+DDh06xM+WssYFRgCwY8cOlJWV8ddx75+TNcNUKhW0Wi0aGxuRlpbm1vFN9/6pjUOmw+joKN58803s37/fo9BpdHQUbW1t6OnpweDgoN/Cq6SkJBQUFODmm2/G3Xff7ZOSygMDA2htbcXAwAA/cGZsbIwv/efswjDMnAisgOufyb29vRgeHsaFCxeg0+kmvb1QKOTDKW5UPBdYWYdT3PtlcHAw3+5TKpVz4ndG/ik8PBw/+9nP/H0YJMDNxfbN2NgY3nrrLX4tZg43EKCzs9PmvFYoFCIrKwuZmZk2M4oYhsHq1atRVFQEqVSKq1evoq6uzqYEa2trK15//XU0NDR4PGhWJBIhIiICYWFhNjOnXP08l0qlWLFiBdauXYtly5bZlewTCoUIDQ3lZ07RIARCCAkcARlUcbjFTx11PnFlezhqtdqjTqrpNBcbOcT/WJbFBx98MOW6KgkJCUhOTkZSUhKioqLQ2NiI48ePo66uzqP1niaKiYlBYWEhVq1ahczMTL+HVpcvX8avfvUrfPTRR3aLvrpLLpdj/fr1ePjhhxEbGwvgeoM2LCwMZrMZVVVV2Lt3L4aHh13uBBOLxVi7di0efvhhrF69mhrEAWpwcJBfX6q7u9tucV5fYRgGarXaZsaUVCqdlseaDMuyqKurQ0dHB2JjY/kZSoFucHCQL3148OBBm4Es7u4nLy8PTU1NaGxsREpKisv3raqqQnFxMQCguroaRUVFk95m4qwlruxeXV0d8vLy7O6r1WqhUqmQlpZmN0rVFdO9f2rjkOnU2NiIiooKXLlyxet9caWMrMOr6SrR6oxEIkFUVBQWLVqE9evX46677kJSUhIUCoVLayNZGxgYQEdHh8ttOYvFAoPBALFYjNDQULAsO2WZwrGxsRkP+Nyh1+tx4sQJXLlyxe44GYbhS/VJpVK7mVLWpFIpVCoVH0z543OYTC+uWoJQKIRarabSf2RKc6l9w81Wfvnll+1mSxkMBrS3t9ud68TFxWHZsmV2A+bi4+Nx9913Iz4+HsPDwzhx4gQ6OjoAXP+cOXToED7++GO+XKsngoODERkZCYlEws+ecpVYLEZ+fj7WrFmDvLw8uzKFUqmUnzUll8tnxfkOIYTMRwEdVM12c6mRQwILy7LYv38/Pv/8c5fvo1QqkZSUhLi4OIyMjECj0eDkyZM+mSGiUqn48oA5OTlud7r42pEjR/Cb3/wG//jHP7yeSRYVFYXbbrsN3//+9/kGu0AgAMuy+Pjjj/Huu+/ypWdcIRKJsG7dOjzyyCNYsWIFNZL9iGVZ9Pf328yYcvXv6C6hUIiIiAg+lIqMjAyIsNJsNmPXrl04evQo1q1bh8cee8zv/7+ueOedd1BcXOyT2dTcLO6Kigr84Ac/cPl+XNCzdetWVFZWOrxNcXExqqqqHIZB3GwrZ/cvLS1FeXm507J8NTU1KC4uxv333+9wfSlv9z8VauOQ6WaxWFBdXY2//vWvPh80oNfr0d7eju7ubgwODmJsbGzGwyuBQICgoCBERkYiNTUVubm5iImJQWhoqM1Ib+ufQ0ND+fdorVaL9vZ2twcfhYWFITY2FiEhIU5vY7FYoNfrHYZZY2NjTtfemsnfYVtbG+rr6zE4OAiz2QyxWMyvbyUWix2uKyIWi/kZUyqVCjKZjNphXrIOgkQikd33jrZN/H6yn6fa51T7pfVliLvmSvvG2fqPFosFvb296O3ttQn6g4ODkZubyw/S5EilUmzZsgUrV64EAFy4cAHnzp2D2WyGVqvF66+/jrq6Oo/PuQUCAcLCwvh1/9z5HBGJRFi2bBnWrl2LgoICm3CNm03MfZZODK4IIYQEJgqqptFcaeSQwMSyLA4fPozDhw97dH+xWIy4uDgIBAJ0d3ejsbHR5XUhJiOXy1FQUIDCwkLk5ubaTbWfSRaLBa+99hr+8Ic/4Ny5c16NDmYYBqmpqXjggQfwjW98gz/x1el0qKmpwYcffgitVutyI10kEuHGG2/Ejh07sGTJEo+Pi7jObDajt7eXD6V6enrcXqTeVWKx2Ga2lFqtDsgAqLy8HH/6059gNBohEonw7W9/G08++eSkHZiB4OGHH8aePXvcngXljEAgQHFxMfbu3evW/aqqqvD0009j586dKCoq4sv/abVaPP300ygvL0daWhqqq6sdltarqKhASUmJXVlAZ9utcTOmgOszLByVHvRm/1OhNg6ZKVqtFh9++CFOnjyJ3t7eaRtQwI0u7+7uhlar9Wt4FRYWhqioKMTFxdl1roWEhNiEV2KxmA9qQkJCIJfLbb46GxThSmDlDpZlYTAY3Aq2RkdHPf4cHhkZwfHjx2EwGCCTyRwGEkKhkJ8tpVQqERISMuuCKYFA4FHYM9X3vgiNBAKBX4Igs9kMo9EIg8HAf7W+TNzG/RwTE4ONGzfO+PGS2WW2t28MBgOqqqrwt7/9zW5Gkk6nQ0dHB4xGI79NIBBg4cKFWLhwod25ypIlS3DbbbchNDQUPT09qK2thVarRX19PaqqqtDa2urxcUqlUqjVashkMrfO0QUCARYvXoy1a9eisLDQprSuSCSyGeQRiOdehBBCJhfwQdXQ0BBqampw8uRJANdrSxcVFc2KNTRmeyOHzA7/+Mc/3F5bxRGWZSEUCvkGrE6ng0Qi8eqEXiqVYvny5SgsLER+fr5fO79HR0exa9cuvPjii2hpafFqX0KhEEuXLsX3v/99rF69GsD1hv/+/fvx0UcfQavVwmKxuPS7EwgE2LRpE37+859j0aJFXh0XsTU+Po6enh6+jF9fX9+0dTrKZDI+lIqOjoZSqfR7Z5jZbLbpLOQu3M9NTU34zW9+g7GxMZhMJohEIgQFBeGDDz7AqlWr/HrsUykoKEB4eDj+/ve/+2R/xcXFOHPmDC5fvuz2fTUaDXbv3o2amhpotVr09/dDrVYjLS0NxcXF2L59+5T3Ly0thUaj4bep1WqUlZU5LNnHmWpGlbf7nwq1cYi/GAwGDA0NYWhoCIODgzZfrbdz26zXznCX0Wi0Ca9metYQcL2dIJPJ+PAqPj7e4chwo9HocP1MqVQKuVzOX0JCQvggSy6XIyoqCunp6YiJieGDr5nCsizGx8fdCrZGRkYwPj4OlmVx7Ngxuw5XrrSTSqWCQqGY8rPYlYDG2xlC3oRG/m5LuINlWacB0mQ/T3Xbids8DTeXLVuGJ554wsfPmsw1s7l9c/LkSbzwwgvo6emx2T4+Po7Ozk67SirR0dHIzc21W0dRrVbjrrvuQmZmJoxGI06fPo1z587h3XffxaeffurxLGeGYRASEgK1Wu1WyM0wDLKysrBmzRqsWrXKZnAWN7gjLCxsVg5GIIQQYiugg6pdu3bh5z//ucPr0tPTsXv3bmzYsGGGj8p1s7mRQ2aX2tpafPDBBz7d5/DwMHp6ejA0NITh4WEEBwcjKCjI45GTXLhTWFiIFStWOBz9P1OuXbuGJ598Eu+++y76+/u92ldQUBDWrFmDhx9+GKmpqRgdHcWBAwfwzjvvYHBwEMD1xvVUjWaBQIDNmzfj//yf/4OMjAyvjmm+0uv1NmX8BgYGpm2NDa5zj7uEhoZOy+M4w41cnxg+WV8m65xlWRbPP/88zp49i5GREbAsy588btq0Ce+9915An+hlZGSguLgYTz/9tE/2t2fPHvz85z/3qq7+fENtHDJbjI+P2wRXjsIs621TldIbHx9HR0cHurq6+PDKnXU0fIFhGAQFBSE0NBSRkZGIj4/nSx6Nj49jbGzM7WMSi8WQyWRQKBR25QatSxBOLEvoj5nzJpMJo6OjePvtt9HV1YWoqCgkJSUhPj6eX5fK1dlCgfxZ5yssy8JsNrscBLl6G0eBUyAYHx/nz190Oh2/7tqiRYtw9OhRfx8eCXCzsX3T3d2NF154AadOnbLZzrIsBgYG0NXVZTPIQiaTYdmyZYiPj7d5DxQKhbjxxhuxfv16iMViNDc3480338Qrr7yCS5cueXxexc10cndtqMzMTKxduxarV69GeHg4gOuff9afQ/6s3kIIIcT3AjKoGhwcRFFREerr6yf9MGQYBiUlJXj22Wdn8OhcNxsbOWT2unTpEvbv3283gsoXuIXI29vbodPpEBQUZLMOgLsn+QzDYNGiRfy6VhP/T2bSqVOn8Otf/xqHDh3yatQ1cH2tri1btmDbtm2QyWQ4cOAAKisr0d/fD4ZhIBAIpgytBAIBbr75ZuzcuRPp6eleHc9cp9PpbIIpX6y35oxSqbQJpiYuMOxrJpPJaQDFjSr3pmP07Nmz2LNnD4aGhmxOXAUCAdRqNd544w1s3rzZF09lWqjVavzlL3/Bvffe65P9HTp0CFu2bJnxzubZjNo4ZK7iOrmnCrS4bVz5Oi68GhgY8Ft4JZPJEBoayn9WMQzjcWDl6jqK3AL1EwMtZ9ukUqknT88hbpDFbOZpGTt3twXgKb9bWJbF2NgYH0BxbSG9Xg+DwYDx8XGYzeZJZzyq1WoakDLDHM3qTktLw86dO72a1c2pqalBWVkZNBoNNBoN0tLSkJeX59X+Z1P7Znx8HH/7299QVVVlV35+bGwMHR0dNoMvGIZBZmYmsrKy7N7jU1NTcffddyMyMhJDQ0MoLS3F3r17MTAw4PHxBQUFQa1WuzVTNyUlBevWrcPq1asRHR0N4PrnkvUACVp7jhBC5q6ADKoefvhhVFRU8D/n5eWhoKAASqUS4eHh6Ovrg0ajQVVVFRiGQXl5Of7zP//Tj0fs2Gxq5JC5wWKxoKenB83NzWhpaUFLS4vPT8gMBgM6OjrQ1taG7u5uCAQCfrZVcHCw03UCJpOamopVq1ahsLAQCQkJfut0eOedd7Br1y6cOnXK6w6mhIQE3Hvvvbj33ntRU1ODt99+m5+9xQVW3FdHhEIhbrnlFjz22GPIzMz06ljmApZlMTg4aBNMeVp2YioMw0CtVvNl/CIjI33escaVNnI2I2o6RyUbjUY89dRTdievnJCQECxevBhHjhwJ2IWHBQIBampqfLbWBAVV7qM2DiHXmUwmh+UHu7q6cOzYMZw5cwbNzc1urWPpKwzDQCqVIiQkBEqlEhERES4PtODKwboaWLlKIpFMGmxNDLmkUqlf2oXulLGz3jZTZezmCovFAp1Oh8HBQb4NNDY2Br1eD6PRCJPJBLPZ7JOgLSgoaNrajsReVVUViouLUVZWhh07dvDbuXUyJ253FzegiitlrNVqUVNTg23btkGr1WL79u2TlkZ2Zra0b7788kvs2bMHHR0dNtvNZjO6u7vtqoZERERg+fLldlUggoODcdtttyE3NxctLS3Yvn07Dh8+7PF7k0Ag4N+/XX3vTkhIwNq1a7FmzRrEx8cDuH4+woVT0z1AkBBCSOAIuKDq0KFDfKNjx44d2LlzJ8LCwpzevrS0FL///e+h0WiQnJw8U4fpktnSyCFz28jICB9atbS04Nq1az47KebqXbe3t6OzsxMmk4kf0RscHMwHWO6MooqLi+NnWmVkZPilc8JkMuGZZ57B888/79GaNdYEAgEWLVqEb37zmzAYDDaBFXf9ZKGVSCTCrbfeip/+9Kfzag0ri8WCgYEBPpTq6uqatvBGKBQiIiKCH4EeGRnpVcec0Wh0GD5xP4+Ojvp1ZPPHH3+Mjz/+GMPDw05vExUVhdLSUvzsZz+bwSNzna+DqtOnT6OgoICCKjdQG4cQ9xmNRnz00Uf429/+hlOnTqG5uRkjIyMzegwMw0AsFvPh1VSzhEUiEWQy2YyuXWWNG0nvKMSqra1FaGgoFixYgOTkZMhksjlXxm62sp6ZyLV9xsbG+NlPXAA1k0Qi0YyHxfOVRqNBeno6tm7disrKSrvry8vLUVpaiurqahQVFbm9/9LSUmi1WodBlFarhUqlAnC9P6msrMytfQd6+6avrw8vv/wyvvjiC5vtLMtieHgYHR0dNuf6UqkUS5cuRWJiot255ooVK3DzzTfj448/xi9+8Qt8/fXXHh+XRCKBWq12eZBbTEwM1qxZg7Vr1yIpKQlCodCmpJ+/PnMIIYT4V8AFVffffz+qqqrc6oAqLS3F0NAQnnvuuWk+OvcEeiOHzE9msxkdHR1oaWnhZ175omQaN3qrra0NHR0dNif4EomEn3EVFBQEmUzmUgAVHh6OlStXYtWqVcjKyoJQKPT6ON3V39+P3/zmN3jzzTfR1dXl1b4kEgny8/OxcOFCfP7553alFCYLrSQSCbZs2YJ///d/x+LFi706jkBkNpvR29vLB1M9PT3TNspYLBbblPELDw93eRagxWKxCaAchVGB3AnS09ODp59+esqR/UFBQYiJicEnn3wScINAgOv/K3v27MFDDz3kk/3t2bMHDz/8MAVVbqA2DiG+YTQaUVNTg48++gi1tbVobGzk17icSRKJBMHBwXx4FRISYnO9vwOriViWxcmTJ21KvUkkEoSEhNhcaP0S35lYfo9r93Czn1wpv+dPDMME7LHNNcXFxaiqqkJdXZ3DEnxcmJSWlobGxka3988wzKQzprggDIDbg8MCtX1jNpvx8ccf46233oLBYLC5zmg0oqOjAzqdzmZ7eno6srOz7d4Ho6OjsWnTJjz//PN45ZVXJh28NhlufVu1Wu3SuVRERATWrFmDNWvWID09HTKZjA+mFArFrC/lSgghxHsBF1Sp1WqUl5fjBz/4gcv3uXr1KrZs2eL1zAdfC9RGDiHWuJJq1rOuOjo6vDqRs1gs6OvrQ1tbG9rb2+3KiwkEApvgKjg4eMoQSqFQYMWKFSgsLMSyZcv80lFy6dIlPP7449i/f7/diYC7FAoFUlJSoNPpHJ4cOAqtuBI+GzduxI9//GPk5uZ6dQz+ND4+blPGr6+vb9o6D4KCgmyCKaVS6fRESK/XO10XiitHEyjMZjP0ej2/PgP3/cSfrUcvnz592uUQUK1W4/bbb8crr7wScCeO3P9FWlqaT/bHrZ1AQZXrqI1DyPQxmUw4dOgQPv74Yxw7dgxXrlyBVqud8ePgZl6FhYUhMjISCoUiYAKr0dFRnD17dsrbceGVXC7nwyt/H3ugsVgsGB4extDQEHQ6Hd/e4WaW+bL8nr+Nj4/7vJwlsce1Gyd7zahUKmi1WgwMDECpVLq8b262FgBUVlZi69atdrepr69Hfn4+ADgNy5wJxPZNQ0MDKioq0NLSYrOdZVn09vaip6fH5netVquRm5vLzyzjiMViREdH47XXXsPx48c9/p8WiURQKpWQy+VT3lapVGL16tVYu3YtFixYwM+aUiqVAVtinBBCiP8EXFAlFAo96iji1q4KJIHYyCHEFUajEW1tbXxw1dzc7HEHPcuy0Gq1aGtrQ1tbm9OARyqV2gRXEonEaee4TCZDXl4eCgsLkZ+fj6CgII+OzRuHDh3Cb3/7Wxw9etTrmT8KhQJisRgMwzh8zhNDK6684vr16/HDH/4QBQUFXj3+TBgbG7MJprxZmHcqcrmcX18qKioKCoUCwPWOP2fl+LjvZyKosFgsdkGS9fdc55Cz663DJ45AILC5cK8X7gJcLwPa3t7u8utVJBIhMjISr7zyCl+SN1Bwz9EXTRhuPwzDUFDlBmrjEDKzLBYLjhw5gg8//BDHjh3D5cuXMTAwMOPhgVgsRnBwMFQqFRISEhAZGemXwQw9PT0ezcQArodX1sHVXA2vjEYjBgcHodPpoNPp+PJ7RqORD6DmwwwjLlxVKBQ4c+aM3WcX8S0uJFIqlZO29/Pz81FfX+80bJpMfn4+tFot6urqHIZc1kGVu/sPpPaNVqvFa6+9hiNHjthdNzIygo6ODpvZVRKJBIsXL0ZKSorN+7LFYsGVK1fw2Wefobu72+PjCQ4OhlqtnjLslcvlfDi1ePFiqNVqvmwrBcWEEEImE3BBlVqttlv4cSpXr15FQUEBBVWETBOWZdHX18eXCmxpafGokcvVzm5vb0dbW9uko4OFQqFNcBUUFOSwpIBIJMLSpUuxatUqrFixwm6B2OlmsVjw4osv4plnnsFXX33ldYeRRCKBRCJxuni4dQDBnXivXr0aP/rRj7By5cqAmfmi0+n4taW6u7s9LinhCqVSicjISISGhvLrbDgKoiaWyXCXxWLh16+YbPaSo9DJ+nt3172YGDpNDKIc/c1ZloXZbLa5dHV1wWQyufUaDQ0NxeLFi3H06NGAeW0Bvg2qOBRUuYfaOIT4n8ViwRdffIG//e1v+Pzzz/H111+jv79/RsMrhmEgl8sRGxuL1NRUZGZmQqVSQafTYXBwEMPDw9Py3trU1ITOzk6f7U8qlfKhFRdi+btDVSQSQSqVQiqV8m1DsVgMg8GAgYEB9Pf3Q6vV8mtB6XQ6vq0xXeWTAwW31lpwcDDCwsIQERGB2NhYJCYmIj09HQsXLsSSJUuQmJjocnln4hsVFRUoKSmZsqzf5s2bUVNT49E6Uq4eA4BJZ2z19PTYbevt7UV2drbNtplu31gsFhw8eBCvv/46RkdHba4zmUzo6uqyO49OTk7GkiVLIJVK+W1arRZHjhzB119/7fF7gkAg4GdBTXYuEBwcjJUrV2LdunUoKChAREQEwsLCEBISElDnEIQQQgJbwAVVBQUF2LVrFzZs2ODyfbZs2YKBgQGcPHlyGo/MfdSJQ+aysbExtLa28sFVa2ur2x3w3AyPtrY2l4JmmUyG4OBg/jJx9CvDMMjOzkZhYSEKCwsRERHh1vF4S6fToaysDK+88gpaW1u93p9YLEZQUJDT9RW4sEIqlSIoKAj5+fn44Q9/iLVr187oCQFXPtJ6xtTEkypvmUwmPuQJCgpCSEgIZDIZJBIJxsfHMTIy4rRjjmVZjI+POwyN3AmaDAaDzzv/rGfKOQuinGFZFhaLhQ+iuNI83MX6eovFgpGREY+OMSoqCmfPnkV0dLSnT9PnBAIBlEolioqKoFar3SoZY02r1aK/vx81NTUYHBykoMoN1MYhJDBZLBbU1tbigw8+wNGjR3Hp0iX09vbOeHilUqmwYMECrFq1Clu2bMGSJUv48nLcZXBwEIODg3bbXHkvPn/+/LQOggGuh1cTZ16JRCJ+Zrt1gGR9mbjNldswDIOmpiY0NjaiqakJ165dQ1tbG7q6utDf34+hoSHo9fo5H0Bx7Vq5XA6VSoXIyEjExcUhJSUFGRkZWLRoET9DgwQmbn0oV4OqrVu3orKy0qfHkJ6eDo1GM+W+XT1fmsn2zZUrV1BRUWH3u+OqlHR1ddm8R4aFhWH58uUIDw/nt507dw6ff/652wPArYnFYqjV6kkrl0ilUqxYsQJr167FDTfcgMjISISFhdmEZYQQQog7Ai6oKi8vx549e1xab+rMmTPYtm0b6uvrUVZWhkcffXQGjtB11IlD5hOLxYKuri6+VGBLS4tb5d30ej06OjrQ3t6Orq4ulzpUuCCHm3EVFBRkc8KRnp6OwsJCrFq1CvHx8R49L0+1tLTg17/+Nd577z2frCvBlUZ0tpYX12kSFBSE3Nxc/PCHP8T69eunJbCyWCzo7++3CabcDSkn7o8rQ8MFRUajkQ+LgOujirmLu6GTwWDwW2kbZ6X4Jq4/Zo0LnbjL+Pg4v8YUFzpZL1bOsuy0dkCGhYWhubkZYWFh0/YY7hIIBNBqtT6bQanVaqFWq+dFCSRfoTYOIbOHxWJBfX093nvvPXz++edoaGhAb2/vjL7nMQwDpVKJjIwMrF69GnfddRfWr19vN2uJZVmMjo5OGWadPn0a7e3t6O3thV6v5+8vEAggFArBMAyEQqHdjGRXtznbHhcXh8zMTKSnpyMjIwNpaWmTduT29/fj7NmzuHTpEq5cuYKmpia0t7ejp6cHWq0WOp3Or+2UmSISiRAUFASFQoHw8HBER0cjISEBKSkpWLBgAXJycrBo0SKng7PI7FFaWory8nK/BVXcbCqlUomrV69OOpgpkIIqnU6HN954AwcPHrRr13PnydYDAUUiEXJycpCWlgaBQAC9Xo/Dhw/j/PnzNuXB3RUUFAS1Wu20HKpYLEZeXh7Wr1+PjRs3Ijo6GgqFYsr1pgkhhBBXBFxQBVzvXB4cHERZWRk2bdqElJQUAMDQ0BA0Gg1OnTqFsrIyfvHztLQ0l4KtmUadOGS+Gx4e5mdctbS0oK2tzaVRsuPj4+js7ERbWxs6OztdnuXAMIxNcBUcHMx3gMTHx2PVqlUoLCxEWlrajM44qq2txZNPPonDhw97XX6OYRi+PI2z0oDcKN+cnBz827/9GzZu3OhV2ROTyYS+vj6+lF9vb++UI3q5GVB6vR4jIyN8SRpujQRuoe7R0VHo9Xo+jOFmAlkv3B2o5SIcld+zWCw2QZL1LCduOzfTyWKx8CFTAH4U8xiGwfj4eECdgBYUFODUqVM+3eeWLVtw8OBBn+5zLqM2DiGz35kzZ/D+++/js88+Q0NDA3p6emZ8ZqlSqeQHFt1xxx3YvHmzWyX3WJZFT08Pmpqa0NzcDI1Gg8bGxmktCW8dpnGzusxmM4xGI0ZHR23WgprLuPJ7ISEhfPm9mJgYJCUlIT09HYsWLUJOTs6Mld+zHtzDXYxGI/+9SqUKqNnhc5U/Z1Rxa1OlpaWhuroaaWlpk94+EIIqlmXxySef4LXXXsPQ0JDNdRaLBT09Pejr67M5V0hMTMTSpUshk8nQ3NyMw4cPo6Ojw+Nj4Eruy+Vyh7OhhEIhcnNzsWHDBmzZsgVxcXEICQnx+PEIIYQQZwIyqKqvr0dBQcGUDQeuA7Ourg65ubkzc3BuoE4cQmyZTCa0t7fzwVVzczN0Ot2k9+HW1mlvb0dHR4fbJ/0SicQmuJJKpYiMjOTLA2ZlZc1Y7XqLxYKqqirs2rUL9fX1Xo+eFQqFkMlkkMlkdu+XAoGAX+8qIyMDP/rRj3DHHXdMGTaYzWYMDAygqakJra2tfNmZsbExh+Xx9Hq9TaeM9doI1jN+nOHCHm7UMsMwMx5MWa/nxAVI1kGSdaA0MVwKwI/QaVFXV4e8vDx/HwbvnXfewX333Rfw+5zLqI1DyNx0/vx5vPfee/j0009x/vx5dHd3z3h4FRoaivT0dKxcuRK33XYbbrnlFrdn2mi1Wj604i5TlcEym818eUJuYA3X/rEeUDPXceX3FAoFX34vPj4eycnJSE9PR3Z2NhYvXuxx2V13mc1mh8HTxG0T22Qsy6KrqwsjIyMICQlBTk4OPwCWTB/rGU2TVdfggqrt27dj9+7dXj8uF1IVFRWhsrLSpdenv4Oq5uZmVFRU4OLFi3bXDQ8Po6Ojw2Z2lEKhQG5uLtRqNb744gvU19d7VW5dIpEgJCSEL0VqfU4sEAiwZMkSFBUV4bbbbkNiYqLTWVaEEEKIrwRkUAUANTU1KCkpwdWrV53eJi0tDZWVlVi+fPkMHpnrqBOHkMlxtbatywV2dnY67fy3WCzo7e3l17WyLvXiKoFAYBNcRUdHY9WqVVi1ahWWLFkyYw1wo9GIP/3pT9i9e/ekow1dxZVUmTgKzmQygWEYsCyL0NBQxMfH82s2cSNPrcvsjY+POwzQrEMZ67+PuzOeJpa+82aWjvXMJEfhkqNQKUA/8gKaUCiE0WgMqMXIm5qafN7ZNB37nMuojUPI/HHp0iW8++67+PTTT3Hu3Dm7NVJmgkKhQGpqKh9e3XrrrZDJZC7dt7e3F2fPnkV9fT1Onz6NK1euoLOzE1qtll/3aa6X3gP+2VYMDQ2FWq1GTEwMX35v4cKFyMnJwYIFC2as/J7FYpkyfHLWLnVFd3e3zcy6lJQUrFu3zleHT5zgAqOpgqr8/HzU19ejsrISW7du9eoxa2pqsHnzZuzYsQNlZWUu36+np8duW29vL7Kzs222+bp9MzY2hr179+Ljjz+2e31zlUWsZ1cJhUJkZWVBrVbj0KFDuHr1qsfnNAzDIDg4mB/oKJVKbc5/c3JycPPNN+OOO+5AcnJyQLX/CSGEzH0BG1RxysvL8fbbb6O+vp7flpeXhwceeACPPfaYH49satSJQ4j7DAYDrl27ZlMy0FEgxbIsBgYG0NbWhra2NoyMjHj8mNzaTiqVCmvWrMGGDRuQn5/vcgeIt3p7e/Ff//Vf2Lt3L7q7u73eHzeLTCQS8YuSW89Usg6cHI0+9cRkYZX1dVxoNvHxAvyjaF77yU9+gj/96U/+PgwbK1aswMmTJ326z5tvvhl///vffbrPuYzaOITMb1999RVee+01HD16lC+1N1VZYF8TCoUIDQ1FUlISQkND+Rnew8PDGB4exujoqFdrtcwGDMPw7T6lUomIiAjExsby5fe4ACohIWFGKwhMDJ4cBVLTGXYaDAa+M394eBgKhQIymQx33HHHjLXv57OJ5xyOqFQqaLVaNDY2TlmibzI1NTUoLi7Gnj177AKv8vJyFBUVuVUVYDrbNyzL4vPPP8fLL79sF+KxLMuvAWwdXsXExEAsFuPkyZMYHBz0+LFFIhHkcjlfWlUkEkEqlYJhGCxatAi33HIL7r77bhq0RQghxK8CPqiazagThxDvcWsPWJcL7O3ttbvN0NAQP9PKm0Y8cL3jQ6FQYOnSpdiwYQNuueUWqFQqr/bpqvPnz+NXv/oVDhw44FX4BtiGQtZhEb3tE1eFhobiH//4B5YuXervQ7EhFAp93sE1Hfucy6iNQwgBgJGREXR0dGBwcBAdHR04fPgwTp06hcuXL7u0piVxjAugQkJCEBkZiaioKMTHxyMlJQXp6enIysrCkiVLEBoaOmPHxM3In6oMXyB8lra0tGBkZASjo6Po6upCdHQ0FAoFCgoKkJmZ6e/Dm/O4sn7OSkdrtVqoVKop17GaSlVVFbZt24ZDhw45fJz8/HxUVla6FYRNV/umvb0dFRUVOHfunN11Y2NjaG9vtxmcKZFIMDo6iubmZo/fRx2tbcytZ5yVlYVbb70Vd999N1JTUz17UoQQQoiP+T2oOnz4MMrKyvhF0QsKCvDwww/jG9/4hj8PyyeoE4eQ6TE6Omoz4+ratWs2I2ZHRkbQ1taG9vZ2nyymLRAIkJaWhpUrV2Ljxo1YunTpjHQM7N+/H08//TSOHTtGHT3EjvWaXtwaX9xFKBTaXAQCAb/+mMFgcPkxbrvtNjz55JNYtmxZQNWlFwgEKCgowP333+/VKFwA0Gg02Lt3L+rr6wOic222oDYOIcSadWBlraenB4cOHcKpU6fw9ddfo6enZ87PcpoM95ktEokgkUggk8kQHByM4OBgyOVyhIaGQqFQ2AwwEgqF/Awp7pKUlOSzz2WWZW3KQTubCTVb2qLDw8O4du0aDAYDHn/8cXR3dyMqKgq/+c1vsGzZMmRkZMzY+lrzFVf+b+vWraisrLS7vrS0FOXl5U7L/nGzpO6//36n61dVVFSgtLQUe/bssWsL9vf3Q6vVori42O0Ber5u3xgMBrzzzjt4//337dqZZrMZ3d3dNuvnjYyMYHBwEMPDwx49HnD9PYNbm5nDMAySk5NRXFyM++67D+np6R7vnxBCCJkufg2qHnjgAVRVVQGA3aj/zZs348CBA/46NJ+gThxCZobZbEZnZ6dNeKXVagEAer2en2nV09Pjk9lEarUamZmZWLVqFZYvX46kpCTExMRMW0kVi8WCPXv24P/+3/+LCxcu0IyoOYALmKxLMlqv3SUSifiLWCyGSCRy6fXFsizMZjPMZjMsFovNV4PBAKPR6PJaD3K5HCtWrMAPfvADfOtb3/Lq+foa97vyFW6tNQqqXEdtHEKII6Ojo+jo6ODbYY709/fj0KFDOHnyJL7++mt0d3fDaDTO3EHOAG7giFgshlQq5ddGDQoK4r+3XifGXUKhECkpKUhLS0N6ejoyMjKQmJjIl/XiOCrB5yiQmissFgs0Gg1YlsUvfvELaDQa/roFCxbgr3/9K2QyGXJycmjtnWlWUVGBkpISu3WjnG23xs3IAoCBgQG7YLG8vBylpaVTHoMnM7Z82b45efIkXnjhBbu1sLhqIJ2dnXwZzN7eXuh0Oq/aotzsKe61LRAIoFarsWbNGmzbtg2FhYU+bT8TQgghvua3oGrXrl0oLS21q1/MlapiGGbWh1XUiUOI/wwODqK1tRXNzc1oaWnhyyl0dnaira3NZwuBh4aGIj4+HklJSViyZAmSk5ORlJSEpKQkBAUF+eCZ2NLpdPjv//5vvPrqq2hra/P5/snkHAVMXLjEbbMOnJydDHIjqrnZTtZfJ2MdPDkKo5x9pLMsC6PRCJZlXQ6qFi5ciLi4OKSmpuIvf/lLQJ3YuhpUOSp96ex2FFS5h9o4hJDJuBJYWdNqtThy5AhOnjyJK1euoK2tzeEapXOV9UAVoVAIsVgMiUQCiUQCqVTKr6dqHXAB14MZ7rNdIBAgLi4O8fHxiI2NRWxsLKKioqZsW8wm3AAe7iKRSGx+7u7uRl9fH44ePYr/+I//sLv/H//4R9xwww2IjY1FXFycH57B/KLRaFBaWmoTGKrVapSVlU26btRkM6o0Go3Ls4GKiopQXV3t1jH7qn1jMBjw4x//2G4tKqPRiPb2dgwNDWFsbAx9fX1evdcJBAIEBQVBJpPx7eOwsDAsX74cBQUFuP3225GVlRVQ7XhCCCHEGb8FVWq1GoODg3wnUl5eHtRqNTQaDd+QYRgG1dXV2Lhxoz8O0WvUiUNI4BgfH0dbWxs/44p7r2lvb0dHR4dPRpMGBwcjPj4ecXFxCA8PR1RUFB9aJScnIyIiwqcnCc3NzXjiiSfwt7/9zet1ueaDyQIm66DJ+jau7tfZ91yHk/XF0eworpOJC6AmXrjrPMWyLPR6vctBlUwmg1KpxJIlS6BQKLBnzx6o1WqPH9/XXB0Fbb1Omyu3paDKddTGIYS4wt3AisMFM5999hkOHjyI+vp6tLS0YGxsbHoOdJayLgHMXayDG5lMhujoaCQnJ2PRokVYvHgxEhMTAy68sg7nrI/fOpCa2H6yWCw2l9HRUZw/fx4mkwl33nmnw7Ve5XI5Dh8+DKFQiJycHJvSaIQAvm3fHD16FH/84x8BACaTCV1dXejq6sLQ0BAGBwe9aneKxWKEhIRALBZDIBBAoVBg2bJlyM3NRVJSEhITE7Fy5UqEhIR4/BiEEELITPNLUPXOO++guLgYDMPg+eefx7Zt22yur6+vR3FxMZqamlBcXIy33nprpg/RJ6gTh5DAxbIs+vv70dLSgqtXr6K2thbnzp1DW1ubW2v4OCOVSvlRrZGRkfxoNy64SkpKQkJCAiQSiQ+eDfD555/jv/7rv3DkyJE5Vz7HGhcqWZfHk0qlNmV1pFIpJBIJH1J4cgHABzqTfeXCKLFYzHeycGEUtx8ubOJK73Fldrj1IEwmE0wmk81jczN8HD1/T7AsC4PBwHfmTPXRHxERgejoaGRkZCAuLg5//vOfA2okpkAgQGlpKX7+858jLCxs0tuVl5fj0UcfdXqbwcFB/Pd//zd+//vfU1DlBmrjEELcMTY2ho6ODrvZBVORyWSIjY2FSqUCwzAYGhrCBx98gJ07d6KtrY3KIXuIC7ckEgmCg4OhUCgQGhqKsLAwqFQqqNVqREVFITo6GjExMUhISEBwcLDL+7ceGMO1jaxnj3OhE7cdsA+euIE6zi4TtbS0YGRkBK+99hoOHjzo9NgefPBBPProowgNDUVmZqabvzky1/myfTM0NIRf/epXOHHiBNrb29Hd3Y3R0VGPj41hGEilUigUCggEAoSEhGDp0qVYtmwZ0tLS+PPNFStWICkpyePHIYQQQvzFL0HVww8/jD179qCyshL33nuvw9totVqo1epZPcKZOnEImV30ej1aWlrwxRdf4OjRozh79iyGhoa83q9YLOZLjERHR/PrBwgEAsTExNiEV0ql0qtAwGKxYO/evfif//kfnD592uUyb3PVxDWfuLUiuAXMg4KCEBISwl8UCoXDxckVCgWUSiV/CQsLg1KphEKhAHB94e6BgQFotVq7y+DgIHQ6ndvHbh1aWX/lnpf1V0fPe6LBwUG0tLTAbDZjZGSED9AmEovFiIqKwuLFixESEoIdO3agsLDQ7eOfTmq12mbhaWdcCao4GRkZuHLlii8Ob16gNg4hxBO+Cqwm6u3txdWrV9Hc3Ixr166hvb0dXV1d6OnpQX9/PwYHBzE8PIyRkRHo9Xp+XRjiHoZh+FlOUqkUwcHBkMvlCA0NhVKptAm44uPjkZiYOOmAEl8ZHh7GtWvXMDg4iH/7t3+b8jkcPHgQKpUK6enpdusfkfnNl+2bS5cu4fHHH8d7770Hk8nk8TEJhUIoFArIZDLIZDIsWbIEy5YtQ0ZGhs3syAULFmD58uUOz2UIIYSQ2cAvQVVGRgYYhsHly5cnvV1paSl+//vfo7GxESkpKTNzcD5EnTiEzG5msxn19fU4ePAgjh07hpaWFq9nK3HhVFxcHGJjY+1mVCkUCr5UYFJSEmJjY+0WxnaVXq/HwoUL0dLS4tUxz0fWI425k0JujQixWMyX9AOuB0hc+DUTrGd+cbOjJn5v/bP19q6uLoyNjfELqTvqpFMoFMjKykJ8fDzy8vLwi1/8IqBmUwHA/fffj7fffnvK27kTVLm6T3IdtXEIId7wNLCSSqWIjY3lBzR6a2hoCE1NTWhqasK1a9dw7do1dHZ2oqenB319fRgYGKCAywe4GejW621xs7iUSiXCw8MRGRmJqKgovp2sVqtdLvV75coVjI+P4/HHH0dTU9OUt8/Ozsarr74KqVSKxYsXe/nsyFziq/aN0WhEWFiYV+tPyWQyhIWFQSaTITs7G8uWLcOCBQvsgiilUolVq1YhIiLC48cihBBCAoFnvZ9e6u/vR0lJyZS3e/DBB7Fr1y5oNJpZGVQRQmY3oVCIFStWYMWKFQCAzs5OfPrpp6ipqUFDQwNGR0cxNjbmVtkZi8WC9vZ2tLe3g2EYREZG8utayWQyDA8P4/z58zh//jyA64tGx8fH28y6ksvlLj2WTCZDRUUFvvzySyiVSnR2dkKv12NsbAzDw8Po6+tDX18ftFothoaGMDIygrGxMRiNRr4U3XzFsixfks/dEh3cehHWJW24MjfWM7tEIhG/5gLDMA5DJ0fbXMV1BnFfZTIZoqKi0NDQAOD6zGUusOJIJBIEBQUhKioKYrEYDz30UMCFVACmJVCikIoQQmZOUFAQ0tLSMDY2hs7OTpdmyQKAwWBAU1MTOjo6PAqsuM9361K8ERERCAsLQ1ZWlk15Xme49ZC49hw3c4sLtoaGhvh2lV6v5x9rPs9yZ1mW/926M8t84sAhbgYXN9NdrVZDrVaDZVlotVqXQioAuHDhAo4fP45Vq1ZhfHycZqAQn+PKarobVIlEIoSEhCA0NBSLFi1Cbm4uFi1a5HBAnFAoxNKlS5GVleVyqEsIIYQEMr8EVVqtFunp6VPeLi0tzeV97ty5E08//bQ3h0UIIZOKiYnBAw88gAceeAD9/f04ceIEjh07hlOnTmFkZASjo6MYHR11ubQDy7Lo7u5Gd3c3Tp8+jfDwcMTFxSEuLo4Po0wmE5qbm9Hc3MzfT61W2wRX0dHRTk9Obr75Ztx8880ePV+TyYTW1lY0NzejpaUFzc3NuHr1Ktrb29HT04OBgQHodDo+3HJWSm6+sQ6WPCnzwYVc1mGXdejFjUgOCQmBXC53GEhJJBKnrwmj0Yjm5mbI5XIMDg5CKpVCKBTCbDaDYRio1WpIJBLcfffdiI2N9fbXQQghhDgVFBSE1NRUxMbGoqOjw6vAigugDAaD3YXbbjQabdY5mjg4ZOI2s9lsd5216OhoREdHu/x8x8fH0d/fj97eXvT29mJgYACDg4N8mWBu0BA3e2u+z+CaOHDI1deHK37xi1/gs88+o5CKTJv/+q//mrIUJSc4OBhKpRILFy5Ebm4usrOzIZPJnN4+Li4OK1eudHkAIyGEEDIb+CWoAlwLodypZ11TU0NBFSFkxqjVatxyyy245ZZboNPpcOrUKdTW1qK+vp6facUFV66OpONmOJ07dw5hYWGIi4tDfHw8QkNDbUYL9/f3o7+/H2fOnAFwfcReYmIiXy4wMTFx0hObyZjNZgwMDPAdKNYXvV6P2NjYKcMLlmUxNjbGz9QaHh7my+Zwvxuus4jrhHF3ttBcxnWMucN6cXJuphZXjjA4OBhBQUH8KOSIiAh0dHSAZVnIZDLo9Xo+pOLK8UREROC+++6bpmdICCGE2JLJZG4FVlqtFgMDAzCbzfjqq69sZiAHMrFY7HK4Zf25LhAIMDg4yM/c6u/vx8DAAB90DQ0N8YOH9Ho9DAaDV2vizAeDg4N44YUX8Kc//cnfh0LmqB/+8Id45JFHnLbrhUIh1Go1Vq9ejZSUFGRnZyMkJGTSfcpkMhQUFFDFIUIIIXOS34KqwcFBl287VTmH06dPo76+3ttDIoQQj8jlctx000246aaboNfrcebMGRw/fhynTp3C2NgYLBaLTXA1NjY2ZRDBja5taGhASEgIXx7QUYkbo9GIxsZGNDY2Arj+nhkVFWUz6yo8PJy/H8uyGBoaQl9fn10YxXX6mM1mfvQw972zr9z3zrYLBAIoFAqEhITY3MZRZ5LZbIbBYIBer7fpaDGZTHwpHu6xZkOH1Ezhft/j4+Me74NhGJhMJrS0tOC5556DVCr14RESQgghU7MOrDo7O9HX1+fwdiaTyau1X/xJIBDYlAF2VBqYKwtsLSEhwe3Hslgs0Gq1aG9vR2trKxobG9Hc3Iyuri5+Zrx122q+DRx69tln8cc//pHKppFpIRAIcMMNN+DIkSM222UyGW644QZ84xvfgFwud7l8aWZmJpYvXz5j6+ISQgghM41h/dASFQgEUKlUKCgogFKpdHo7rVaL6upq5OfnO5yBpdVq0d/fz4dUgVYWgRYaJ2R+M5lMOHfuHGpra3HixAk+oGdZFkaj0Sa4MhgMLu1TJpPx5QEjIyMnPbFmWRbDw8MYHR2FxWJBUFAQRkdHMTg4aFP6xjo8chYg+ZrZbOaDJ5PJxJ+gccdhMpkgFAr59Z6mwpWGsd4nd5kYoHElfIhjEokEer0+INem4vzwhz/Ec889N+XtBAIBysvL8eijj/psn+Q6auMQQmaCwWDgZ1hZt0/6+/vR1dXlxyOzxwVQzoIn69lRgcJkMqGjowPXrl1Da2sr2tra0NXVxa8pxQ0e4r4ajUabGfFc23Gm2o/Toa6uDnl5ef4+DBIgfN2+qaurQ0FBARiGQUpKCh577DHcfvvtuHbtGjQajUv7CAsLQ2Fhod1xEUIIIXON34IqX3aAsSwLhmEoqCKEBCyLxYJLly6htrYWx48fR09Pj831ZrPZpmQgNxNrMmKxGLGxsYiPj0dUVBREIttJsizL4rPPPpvxjgPrBbOtwyPrNR6A64sFc+sv+TMU4YIxo9E4acA1W8oKeUulUvl0DYjpkJmZicuXL095O3eCKlf3Sa6jNg4hZCZNDKy0Wi06Ojpm5LEZhpkyfOLaNNNNIBDYXbi2lCuXqW7LMAyMRiOampr42foajQYtLS0ut3+49aSs19viwi7rkMtkMjld+2umiEQiGAyGgAoPiX/5un3Dsix+//vf48EHH0RiYiI0Gg3q6upcGqQoFAqxZMkSZGdn02uUEELIvOC30n8AfNIgDeQR34QQwhEIBMjKykJWVhb+5V/+BU1NTTh+/DiOHz+Oa9euQSgUQqFQQKFQALj+/qjX621KBk4s6zY+Po6Wlha0tLRAKBQiJiYGcXFxiImJgUQiAcMw/CwqX7IOnyYGUlxng1AotLk4KmHjb1zoxHVAyWQySKVS/qtYLOa/cp1S3PpRFosFJpMJw8PD/JoQXGeM9WjjiaV0ZkPINdlM50DR2NiIF154AQ899NCUt3Xldbdnzx6XR7USQgiZeVKpFCkpKXxJwOHhYa/3OTGAcjYbytUAimGYaQ+SZoJEIsGCBQuwYMECfpvBYLAJrxobG3Ht2jWH7RqRSITQ0FCEhoa69bjcoC1uwJb1elvcICduRj7XzuIGQnnqZz/7GQUAZFoxDIPHHnsMQ0NDqK6udnkmaExMDAoLC/lzQ0IIIWQ+8NuMKgDIy8uDWq32uFPMuvQfzagihMxW7e3tqK2tRW1t7aQzOsbHx22CK71e7/DknFujKi4ujl/rylXcOkeOQijuewB2QRR3cadUn/Vl4jZHt3F3u/U27pgndgZNHBnNjSa2HlnsyfcTt1n/TliWhcFgwMjICP93tB5tbP279sd6XIsXL8a5c+dm5LE8ZT0Lb7I2xMDAABiGmbLMMCfQ2hGBjNo4hBB/6u7u5ssqT/x8dBZASSQSu4svg6RAG5Az3fR6Pa5evQqNRoMrV65Ao9Ggra1txtorarUa6enpSElJQVBQEL7zne9Ap9O5fP+IiAh0dXVRUEVs+Lp9YzabceHCBZw7d86l0uNSqdTp0heEEELIXOe3oKq+vh65ubk+2Z9Go0FmZmbAdTBRJw4hxF29vb04ceIEamtrcf78+UlP9i0WC/R6vc3oUy5I4oyMjIBlWSgUCn6xXm4UKlfqzrrknfUaAxODlomjeT0Jmtz5yOE6fKyDHmdfuVlP1p1PUqkUUqmU/5kL0pwFSLPBxHI63PpmE8vpeLMoemFhIY4fPz5Nz8A3uL/fVM/NldtY3zbQ2hGBjNo4hBB/MhgM0Gq1MJvN0Ov1EAqFkEgkkMlk/Ge+P2YjzXdjY2O4evWqzcyr9vb2GXns1tZWnDx50uXbv/nmm3jwwQen8YjIbOTL9k13dzeOHz+OoaEhl26fnp6OvLw8SKVStx+LEEIImQv8UvovLy/PZyEVAKSlpWH58uU+2x8hhPhLREQEbrvtNtx2220YGhrCqVOnUFtbiy+//NKu9J9AIEBwcDCCg4MB/HNtKOvgqru7G2NjY+jt7XU4io8LayaGQQzDOB315ygscraN6xiaKmhytA8O1/nEhU4Tv3IjoucDT8vpWCwWuzXQuIBr4iyuhISEaTr6mTcbSi0SQghxn1QqRXR0tL8Pg0wQFBSE7OxsZGdn89tGR0dtwqsrV66gs7PT54+t0+kgFovt2suOhIeH4/Lly3wJaEJ8zWQy4ciRIzAajVPeNjQ0FIWFhfSeRgghZN7zS1C1c+fOWbFPQgjxp9DQUGzcuBEbN27E2NgYTp8+jePHj6Ourg56vd7u9gzD8MENV+qst7eXX6zXUWk7V4IkZwGSL1gfs7MgipsJRTwnEAggl8shl8unvO1NN900/QfkA6mpqdi6dSvCw8O92k9fXx8qKyvR1NTkmwMjhBBCCC84OBg5OTnIycnht42MjECj0fBlAxsbG11eu8eR/v5+DA4OQq1Wu7SfwsJCnDlzBidOnEBhYaHHj0uIMyKRCHl5eZNWKRAIBFi8eDFycnJcXguPEEIImcv8UvpvvqCyOISQ6TA+Po6zZ8+itrYWJ0+enLScxPnz5zE0NOS3oEckEtnMfJpYjk8ikVAINQmGYfiyhlxpQ26djYnbHX3v7OfJ9iGXy92esTXTBAIBtFqtz45Tq9VCrVa7tHYAuY7aOIQQQnxJp9NBo9HYlA3s7u526b6nT5+GwWDA2NgYhoaGJi3lK5fLkZ2djYSEBERHR+PPf/4ztUUJz5ftG5ZlUV1d7fB1HB0djcLCwoBvcxNCCCEzyS8zqgghhHhOLBYjPz8f+fn5MJvNuHjxImpra3H8+HH09fXZ3FYqlU7bybdAIHBpNtRsxc32cjUgmupnT/ZBs8kcy8vL8+mJvVKpRFFRkc/2RwghhBD3yOVyLF26FEuXLuW3DQ8P87OuuK+9vb029zMajXz1AL1eD7FY7HSNTq6EcmdnJ+Lj49HV1YWBgQGo1erpfXJkXmIYBoWFhfj444/5wVASiQT5+flIT0/389ERQgghgYeCKkIImcWEQiFfTuV73/seNBoNjh8/juPHj6O9vd2rxXgnhlATgyiRSDRtIYpQKPRZQOTpTKPZHLLNdWVlZbNin4QQQgjxnEKhwLJly7Bs2TJ+29DQkM2sqytXrkAqlcJgMEAmk2FsbAwSiYQPr6xx5YJjYmLAMAyio6OhUqlm7PmQ+ScsLAw5OTk4d+4c0tLSkJeXB5lM5u/DIoQQQgISlf6bRlQWhxDiT9euXcPu3buxd+9ejIyM2FwnFAqdluQLDg5GSEgI/7O7ZeQ8CZUm7oNbO4sQEpiojUMIISRQVFdX4+mnn4ZOp0NjYyP0ej0MBoNNCUCZTAa1Wg2ZTIalS5dCIBBgx44dtEYVsTEd7Ruz2Yze3l5ER0d7e3iEEELInEYzqgghZI5KSEjAQw89hEWLFkEqlYJlWahUKkRFRSE0NNTpbCUqNUcIIYQQQmaLoqIiHD9+HGfOnIFCocDFixdhsVgwNDSEsbExiMVivmRwSkoKBAIBli9fjpUrV/r5yMl8IBQKKaQihBBCXEBBFSGEzGEpKSlISUnx92EQQgghhBAyLRiGwUMPPYSf/vSnUCqVUKlUGBgYQFJSErKystDQ0IChoSGoVCoolUqIRCI89NBDNDiLEEIIISSAUG0lQgghhBBCCCGEzFpxcXG45557APxz1hS3ntXQ0BAEAgE/eOvuu+9GbGys/w6WEEIIIYTYoaCKEEIIIYQQQgghs9p9992HiIgISKVSxMXFAQB6e3sBXA+ypFIpIiIicN999/nzMAkhhBBCiAMUVBFCCCGEEEIIIWRWk0ql+N73vgfgejAlk8kAADKZjA+uvv/970MqlfrtGAkhhBBCiGO0RtU0slgsdtu4EV2EEELIfBAeHg6BgMbFzDXUxiGEEBKI0tLSkJGRgfPnzyMuLg6XL19GXFwcxsfHsXjxYqSmpqKnp8frx6H2zdxE7RtCCCHzmb/bNwzLsqzfHn2Oa2hoQHZ2tr8PgxBCCPGb7u5uREZG+vswiI9RG4cQQsh8Ru2buYnaN4QQQuYzf7dvaAgQIYQQQgghhBBCCCGEEEII8QsKqgghhBBCCCGEEEIIIYQQQohfUFBFCCGEEEIIIYQQQgghhBBC/ILWqJpGJpMJly9fttmmVqu9WpSst7fXrmbyhQsXEBER4fE+ydxArw3iCL0uiDMz9drw92KcZHr4uo1D71XEGXptEGfotUGcmYnXBrVv5iZq35CZQq8N4gy9Nogz86F9I/LbI88DIpEIWVlZ0/44ERERtJArcYheG8QRel0QZ+i1QVw1E20cej0SZ+i1QZyh1wZxhl4bxBXUviH+RK8N4gy9Nogzc+21QUOACCGEEEIIIYQQQgghhBBCiF9QUEUIIYQQQgghhBBCCCGEEEL8goIqQgghhBBCCCGEEEIIIYQQ4hcUVBFCCCGEEEIIIYQQQgghhBC/YFiWZf19EIQQQgghhBBCCCGEEEIIIWT+oRlVhBBCCCGEEEIIIYQQQgghxC8oqCKEEEIIIYQQQgghhBBCCCF+QUEVIYQQQgghhBBCCCGEEEII8QsKqgghhBBCCCGEEEIIIYQQQohfUFBFbGg0GlRUVGDz5s0oLy/39+EQH5rsb6vValFVVYXi4mJotVr/HCAhZMbU19ejpqbG4/vTZwWZbeg1O7dRG4cQAlD7hsxP9Lqdu6h9QwgB5lf7hoIqwquvr8fu3btRWlqKmpoa9PX1+fuQiI9M9retqKhAfn4+iouLUVVV5cejJIRMJ61Wi5KSEqhUKuTn56O6utqj/dBnBZlt6DU7t1Ebh5D5jdo3ZD6j1+3cRe0bQua3+dq+oaCK8PLy8lBWVob777/f34dCfGyyv+327dvR2Njoh6MihMwkpVKJ3bt3o6CgwKv90GcFmW3oNTu3URuHkPmN2jdkPqPX7dxF7RtC5rf52r6hoIrYUSqV/j4EMk3ob0sIycvL88l+pno/KS4u9snjEOIr9Bk4t9Hfl5D5jdo3ZD6jz8C5i/62hMxv8619Q0EVIYQQQnyquLgY9fX1/j4MQgghhBCfofYNIYQQQuaaQGrfUFBFCCGEEJ8pLy+nWumEEEIImVOofUMIIYSQuSbQ2jcUVE2T+vp6FBcXY/PmzUhPT0d+fr7dH16r1aK8vBzp6ekAri+IyC2SxtFoNCgpKUFxcTGKi4uRn5+P0tJSu8dSqVRgGAYMw/DX19fXIz8/n9++efNmm4S0oqICDMNApVJBq9VO02+CTOTrv5crrxFPlZeX88dTUlKCiooKn+yXeG6y942qqiqkp6eDYRj+egCoqalBSUkJ/7e0fi+qr69HaWkpf/v6+nps3ryZ32egjKog17n7/15TU8N/Fm3evBmlpaV27/eevG6cqaqqwu7du/ljzc/PR35+Pmpqajx7wiTgUPuGTIbaOMRT1L6Z36h9QwIBtXGIM9S+IZ6i9s38Ru0bD7DE58rKyti8vDy2sbGR35aXl8cCYMvKyliWZdndu3ezaWlpLAAWALt7925269atrFKpZAGwdXV1bGNjI6tUKtnt27fz+6mrq2MBsEVFRTaPWVlZyQJglUqlzfaBgQH+Merq6uyONS8vj62srLTZtmPHDhYAu2PHDq9/F8QxX/293HmNsOzkf1vucQcGBmyOc+JrmfiPK+8b3GsrLS3N7v7c+xD3Gqqurma3bt3K76+srIwtKipid+/ezW7fvt3ha4L4j7v/72VlZaxSqbT5/+VeHxPfB9x53XCcvZ9UV1c73ReZ3ah9Q1xBbRziLmrfzG/UviGBgNo4ZCrUviHuovbN/EbtG8/QjCofq6qqQmlpKSorK5GWlsZv37lzJwBg7969AIDt27ejsrLS5r6VlZW4evUqqqurkZeXh927d0Or1doseJaXlwelUmmXbm7duhVKpRJardYmQVcqldi+fTsA2N1Hq9VCq9Vi69at3j9x4hZf/b3ceY24q7y8HHv37kVdXZ3Na5n4jyvvG5P9rdRqtc3PRUVFNvtTKpWorq7G9u3bsXv3bn7RxrffftuHz4J4yp3/95qaGpSWlmLPnj02r4mtW7c6fM9353VD5idq3xBXURuHuIvaN/MbtW+Iv1Ebh7iC2jfEXdS+md+ofeMZCqp8bNu2bSgqKrJ70WzduhXV1dU4dOgQv836NtwHm1KpRFFREQCgpKQEO3bs4BtIHO5Fp9FobLZzt3v66adttnPT0Cdur6ioQElJiXtPkPiML/5e7r5GXNHf34+SkhL09fXZfagS/5vqfcMb999/v83PBQUFAIDGxkav9028587/O/de4W6jhhBnqH1D3EFtHOIuat/MX9S+If5GbRziKmrfEHdR+2b+ovaNZ0T+PoC5pL6+Hlqt1umLyN03orS0NJSVlQG4PhKDexH39/c7vP327dtRWlqKqqoqm9S2rKwMaWlp0Gg0qKmp4Y9j9+7dqKurc+uYiO/44u/l7mvEFcXFxaivr6fXBrEZ+UH8z9X/d+66+dagIdOH2jfEXdTGIYGM2jeBhdo3xJ+ojUPcQe0bEsiofRNYqH3jGZpR5UO++IBxtM+SkhLU1NQgLy8PeXl5TqfxKZVKPn3lFkysqalBWloavzga97Wqqoqfckj8w1d/L3deI67gGlWbNm2iBVoJCTCu/L97MgqPkMlQ+4a4i9o4hBB3UPuG+Au1cYg7qH1DCHEHtW/cR0GVD3EfQNb1ar1RX1+P9PR05Ofnu1yDmJtSyH04lpaWoqysDEVFRVAqlfzIj6efftpu+iGZed7+vTx5jUylpKQEW7duhVarRXFxsU/2SQjxnrv/79TgIb5C7RviCWrjEEJcQe0b4k/UxiHuovYNIcQV1L7xDAVVPsTVA9VoNKiqqnJ4m/LycpdHOHAfMO5MN+cW49NoNCgtLYVareYX1OM+JLdt28bflviXt38vT14jU1Gr1fxCstyCfoQQ/3P1/916yri3C/ISAlD7hniG2jiEEFdQ+4b4E7VxiLuofUMIcQW1bzxDQZUPWU8DLi4utmvolJeX87dzBZemWr9QNRoNv91ZY4n7UCovL+frYQL/XLivqqpq0pE4NFV4Znnz93L3NeLO37a6upo/LmeNdhJ4uPcXjUZj8/fWarU4deoUAN+WtiAzx9X/94kLOk/8v3f0/uDJ68bZ+wk3lZ1eZ3MHtW+Ip6iNQ3yF2jdzF7VviD9RG4d4gto3xFeofTN3UfvGQyzxqYGBATYtLY0FwF+4n7du3Wpz28bGRv42AwMDdvvi7qdUKtkdO3aw27dvZ7du3Wqzv+3btzs8DgBsUVGR3fatW7eySqVy0uewdetWFoDTfRPf8/Tv5e5rZLK/LfdarKur47dVVlby26urq718lsQXpnrfYFmWzcvL4997ysrK2O3bt7NFRUUO//4DAwP8/hobG232Q+8FgcWd//fGxkZWqVTavA4qKyvZ7du3868P7j7c68id1w3LuvZ+smPHDnb37t1sWVnZtP9+yPSi9g3xFLVxiCuofTN/UfuG+Bu1cYgnqH1DXEHtm/mL2jeeoaBqmmzfvp1/8eXl5bGVlZU21+/evdumMZSXl8fu3r3b5jaNjY38C8/6+srKSlapVLJpaWk2H0jWduzY4fC6uro6py+4uro6dseOHTYNtB07dti9+RHf8+TvxbKuv0Ym+9tWVlayRUVFDl+L1o0criFGjR3/ceV9g2WvN164vyn3ocWy119nW7du5d+P6urqbP721n/fia8XOhH3P3c/EwYGBvjPIqVSyRYVFfHvBdavA+vbu/q6meqzYvfu3fwx7dixY7p/NWQGUfuGuIvaOGQq1L6Z36h9QwIFtXGIO6h9Q6ZC7Zv5jdo3nmFYlmVBCCGEEEIIIYQQQgghhBBCyAyjNaoIIYQQQgghhBBCCCGEEEKIX1BQRQghhBBCCCGEEEIIIYQQQvyCgipCCCGEEEIIIYQQQgghhBDiFxRUEUIIIYQQQgghhBBCCCGEEL+goIoQQgghhBBCCCGEEEIIIYT4BQVVhBBCCCGEEEIIIYQQQgghxC8oqCKEEEIIIYQQQgghhBBCCCF+QUEVIYQQQgghhBBCCCGEEEII8QsKqgghhBBCCCGEEEIIIYQQQohfUFBFCCGEEEIIIYQQQgghhBBC/IKCKkIIIYQQQgghhBBCCCGEEOIXFFQRQgghhBBCCCGEEEIIIYQQv6CgihBCCCGEEEIIIYQQQgghhPgFBVWEEEIIIYQQQgghhBBCCCHELyioIoQQQgghhBBCCCGEEEIIIX5BQRUhhBBCCCGEEEIIIYQQQgjxCwqqCCGEEEIIIYQQQgghhBBCiF9QUEUIIYQQQgghhBBCCCGEEEL8goIqQgghhBBCCCGEEEIIIYQQ8v9rz44FAAAAAAb5Ww9jT2m0EFUAAAAAAAAsRBUAAAAAAAALUQUAAAAAAMBCVAEAAAAAALAQVQAAAAAAACxEFQAAAAAAAAtRBQAAAAAAwEJUAQAAAAAAsBBVAAAAAAAALEQVAAAAAAAAC1EFAAAAAADAQlQBAAAAAACwEFUAAAAAAAAsRBUAAAAAAAALUQUAAAAAAMAicSvY0fqid9wAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1650x390 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.lines as mlines\n",
    "\n",
    "plt.style.use(os.path.join(BASE_DIR, 'matplotlib_style.mplstyle'))\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{amsmath}'\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{times}'\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "\n",
    "fig, axs = plt.subplots(\n",
    "    2, 3, figsize=(5.5, 1.3),\n",
    "    height_ratios=(0.001, 1),\n",
    "    dpi=300,\n",
    "    # layout=\"constrained\"\n",
    ")\n",
    "\n",
    "gs = axs.flat[0].get_gridspec()\n",
    "for i in range(3):\n",
    "    axs.flat[i].remove()\n",
    "ax_g = fig.add_subplot(gs[0, :])\n",
    "gs_c = ax_g.get_subplotspec()\n",
    "fig.delaxes(ax_g)\n",
    "\n",
    "nested_gs = gs_c.subgridspec(1,1, wspace=0, hspace=0)\n",
    "ax = fig.add_subplot(nested_gs[0])\n",
    "ax.set_axis_off()\n",
    "\n",
    "alphas = np.linspace(1, alpha_low, len(labels_compare))\n",
    "lines_legend = []\n",
    "for idx, l in enumerate(labels_compare):\n",
    "    lines_legend.append(\n",
    "        mlines.Line2D([], [], color='dimgray', linestyle='-', label=l, alpha=alphas[idx])\n",
    "    )\n",
    "l = ax.legend(\n",
    "    handles=lines_legend,\n",
    "    title_fontsize=8,\n",
    "    loc='upper center', ncol=len(labels_compare), frameon=False, handlelength=0.7,\n",
    "    fontsize=8, borderpad=0, labelspacing=0.5, handletextpad=0.3,\n",
    "    columnspacing=0.8\n",
    ")\n",
    "l.get_title().set_ha(\"left\")\n",
    "plt.setp(l.get_title(), horizontalalignment='left')\n",
    "ax.add_artist(l)\n",
    "\n",
    "###############################################################\n",
    "### PLOT 1 ##################################################\n",
    "ax = axs.flat[3]\n",
    "\n",
    "ax.annotate(\n",
    "    r'\\textbf{a}', xy=(0, 1), xycoords='axes fraction',\n",
    "    xytext=(-10, 10), textcoords='offset points',\n",
    "    ha='right', va='bottom'\n",
    ")\n",
    "\n",
    "m = [np.mean(p) for p in poserr_all_dev]\n",
    "ax.plot(range(len(m)), m, c='black')\n",
    "ax.plot([2,3], [m[-2], np.mean(poserr_all_dev_gc)], c='black')\n",
    "ax.scatter(3, np.mean(poserr_all_dev_gc), c='black', marker='d', s=10)\n",
    "\n",
    "for idx, alpha in enumerate(np.linspace(1, alpha_low, len(labels_compare))):\n",
    "    m = [np.mean(p) for p in poserr_all_compare[idx]]\n",
    "    ax.plot(range(len(m)), m, c='black', alpha=alpha, zorder=-10)\n",
    "    ax.plot([2,3], [m[-2], np.mean(poserr_all_compare_gc[idx])], c='black', alpha=alpha)\n",
    "    ax.scatter(3, np.mean(poserr_all_compare_gc[idx]), c='black', alpha=alpha, marker='d', s=10)\n",
    "\n",
    "ax.set_xticks(range(len(poserr_all_dev)), LABELS_DEV)\n",
    "ax.set_ylabel('Pos dec err (cm)')\n",
    "ax.set_yticks([4, 6])\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "\n",
    "\n",
    "###############################################################\n",
    "### PLOT 2 ####################################################\n",
    "ax = axs.flat[4]\n",
    "ax.annotate(\n",
    "    r'\\textbf{b}', xy=(0, 1), xycoords='axes fraction',\n",
    "    xytext=(-20, 5), textcoords='offset points',\n",
    "    ha='right', va='bottom'\n",
    ")\n",
    "\n",
    "m = [np.mean(y) for y in hderr_all_dev]\n",
    "ax.plot(range(len(m)), m, c='black')\n",
    "ax.plot([2,3], [m[-2], np.mean(hderr_all_dev_gc)], c='black')\n",
    "ax.scatter(3, np.mean(hderr_all_dev_gc), c='black', marker='d', s=10)\n",
    "\n",
    "for idx, alpha in enumerate(np.linspace(1, alpha_low, len(labels_compare))):\n",
    "    m = [np.mean(p) for p in hderr_all_compare[idx]]\n",
    "    ax.plot(range(len(m)), m, c='black', alpha=alpha, zorder=-10)\n",
    "    ax.plot([2,3], [m[-2], np.mean(hderr_all_compare_gc[idx])], c='black', alpha=alpha)\n",
    "    ax.scatter(3, np.mean(hderr_all_compare_gc[idx]), c='black', alpha=alpha, marker='d', s=10)\n",
    "\n",
    "ax.set_ylabel('HD dec err (deg)')\n",
    "ax.set_xticks(range(len(poserr_all_dev)), LABELS_DEV)\n",
    "# ax.set_ylim([30, 35])\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "\n",
    "\n",
    "###############################################################\n",
    "### PLOT 3 ####################################################\n",
    "ax = axs.flat[5]\n",
    "ax.annotate(\n",
    "    r'\\textbf{c}', xy=(0, 1), xycoords='axes fraction',\n",
    "    xytext=(-15, 5), textcoords='offset points',\n",
    "    ha='right', va='bottom'\n",
    ")\n",
    "ax.set_ylabel('sRSA')\n",
    "\n",
    "m = [np.mean(y) for y in sRSA_dev]\n",
    "ax.plot(m, c='black', label='Modeled')\n",
    "ax.scatter(3, np.mean(sRSA_dev_gc), c='black', marker='d', s=10)\n",
    "ax.plot([2,3], [m[-2], np.mean(sRSA_dev_gc)], c='black')\n",
    "\n",
    "for idx, alpha in enumerate(np.linspace(1, alpha_low, len(labels_compare))):\n",
    "    m = [np.mean(p) for p in sRSA_compare[idx]]\n",
    "    ax.plot(range(len(m)), m, c='black', alpha=alpha, zorder=-10)\n",
    "    ax.plot([2,3], [m[-2], np.mean(sRSA_compare_gc[idx])], c='black', alpha=alpha)\n",
    "    ax.scatter(3, np.mean(sRSA_compare_gc[idx]), c='black', alpha=alpha, marker='d', s=10)\n",
    "\n",
    "ax.set_xticks(range(len(sRSA_dev)), LABELS_DEV)\n",
    "ax.set_yticks([0.2,0.4,0.6])\n",
    "ax.set_ylim(bottom=0.11)\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "    \n",
    "plt.tight_layout(w_pad=0.4, pad=0, h_pad=1.2)\n",
    "plt.savefig(\n",
    "    os.path.join(BASE_DIR, 'paper_figures', 'compare_param_sweep.pdf'),\n",
    "    dpi=300, bbox_inches='tight', pad_inches=0.02\n",
    ")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "35070cbe",
   "metadata": {},
   "source": [
    "# End"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92c8ce67",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "vrtopc",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
