{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "36615d92",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:17.317457Z",
     "iopub.status.busy": "2025-09-24T06:29:17.317355Z",
     "iopub.status.idle": "2025-09-24T06:29:17.322081Z",
     "shell.execute_reply": "2025-09-24T06:29:17.321651Z"
    }
   },
   "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:17.323045Z",
     "iopub.status.busy": "2025-09-24T06:29:17.322948Z",
     "iopub.status.idle": "2025-09-24T06:29:17.324983Z",
     "shell.execute_reply": "2025-09-24T06:29:17.324684Z"
    }
   },
   "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:17.325906Z",
     "iopub.status.busy": "2025-09-24T06:29:17.325809Z",
     "iopub.status.idle": "2025-09-24T06:29:18.752913Z",
     "shell.execute_reply": "2025-09-24T06:29:18.752209Z"
    }
   },
   "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:18.759842Z",
     "iopub.status.busy": "2025-09-24T06:29:18.759561Z",
     "iopub.status.idle": "2025-09-24T06:29:19.333225Z",
     "shell.execute_reply": "2025-09-24T06:29:19.332720Z"
    }
   },
   "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:19.335422Z",
     "iopub.status.busy": "2025-09-24T06:29:19.335304Z",
     "iopub.status.idle": "2025-09-24T06:29:19.337816Z",
     "shell.execute_reply": "2025-09-24T06:29:19.337503Z"
    }
   },
   "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:19.339321Z",
     "iopub.status.busy": "2025-09-24T06:29:19.339196Z",
     "iopub.status.idle": "2025-09-24T06:29:24.207307Z",
     "shell.execute_reply": "2025-09-24T06:29:24.206441Z"
    }
   },
   "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:24.210560Z",
     "iopub.status.busy": "2025-09-24T06:29:24.210255Z",
     "iopub.status.idle": "2025-09-24T06:29:24.375261Z",
     "shell.execute_reply": "2025-09-24T06:29:24.374077Z"
    }
   },
   "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:24.376906Z",
     "iopub.status.busy": "2025-09-24T06:29:24.376704Z",
     "iopub.status.idle": "2025-09-24T06:29:24.386034Z",
     "shell.execute_reply": "2025-09-24T06:29:24.385622Z"
    }
   },
   "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:24.387370Z",
     "iopub.status.busy": "2025-09-24T06:29:24.387057Z",
     "iopub.status.idle": "2025-09-24T06:29:24.391463Z",
     "shell.execute_reply": "2025-09-24T06:29:24.391137Z"
    }
   },
   "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:24.392745Z",
     "iopub.status.busy": "2025-09-24T06:29:24.392365Z",
     "iopub.status.idle": "2025-09-24T06:29:24.395037Z",
     "shell.execute_reply": "2025-09-24T06:29:24.394718Z"
    }
   },
   "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:24.396281Z",
     "iopub.status.busy": "2025-09-24T06:29:24.396173Z",
     "iopub.status.idle": "2025-09-24T06:29:38.570013Z",
     "shell.execute_reply": "2025-09-24T06:29:38.569689Z"
    }
   },
   "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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rat r1546_p18\n",
      "\tAge 18\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 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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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",
      "\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\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:38.571587Z",
     "iopub.status.busy": "2025-09-24T06:29:38.571460Z",
     "iopub.status.idle": "2025-09-24T06:29:38.573880Z",
     "shell.execute_reply": "2025-09-24T06:29:38.573574Z"
    }
   },
   "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:38.574847Z",
     "iopub.status.busy": "2025-09-24T06:29:38.574744Z",
     "iopub.status.idle": "2025-09-24T06:29:38.584464Z",
     "shell.execute_reply": "2025-09-24T06:29:38.584172Z"
    }
   },
   "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:38.585521Z",
     "iopub.status.busy": "2025-09-24T06:29:38.585409Z",
     "iopub.status.idle": "2025-09-24T06:29:38.587408Z",
     "shell.execute_reply": "2025-09-24T06:29:38.587125Z"
    }
   },
   "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:38.588334Z",
     "iopub.status.busy": "2025-09-24T06:29:38.588230Z",
     "iopub.status.idle": "2025-09-24T06:29:38.961742Z",
     "shell.execute_reply": "2025-09-24T06:29:38.961361Z"
    }
   },
   "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:38.963961Z",
     "iopub.status.busy": "2025-09-24T06:29:38.963812Z",
     "iopub.status.idle": "2025-09-24T06:29:38.985198Z",
     "shell.execute_reply": "2025-09-24T06:29:38.984031Z"
    }
   },
   "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:38.986740Z",
     "iopub.status.busy": "2025-09-24T06:29:38.986609Z",
     "iopub.status.idle": "2025-09-24T06:29:38.989433Z",
     "shell.execute_reply": "2025-09-24T06:29:38.989047Z"
    }
   },
   "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:39.004323Z",
     "iopub.status.busy": "2025-09-24T06:29:39.004206Z",
     "iopub.status.idle": "2025-09-24T06:29:39.011946Z",
     "shell.execute_reply": "2025-09-24T06:29:39.011493Z"
    }
   },
   "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:39.013193Z",
     "iopub.status.busy": "2025-09-24T06:29:39.013050Z",
     "iopub.status.idle": "2025-09-24T06:29:39.015223Z",
     "shell.execute_reply": "2025-09-24T06:29:39.014894Z"
    }
   },
   "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:39.016539Z",
     "iopub.status.busy": "2025-09-24T06:29:39.016388Z",
     "iopub.status.idle": "2025-09-24T06:29:39.019505Z",
     "shell.execute_reply": "2025-09-24T06:29:39.019164Z"
    }
   },
   "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:39.020716Z",
     "iopub.status.busy": "2025-09-24T06:29:39.020593Z",
     "iopub.status.idle": "2025-09-24T06:29:39.024517Z",
     "shell.execute_reply": "2025-09-24T06:29:39.024111Z"
    }
   },
   "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:39.025735Z",
     "iopub.status.busy": "2025-09-24T06:29:39.025613Z",
     "iopub.status.idle": "2025-09-24T06:29:39.108923Z",
     "shell.execute_reply": "2025-09-24T06:29:39.108289Z"
    }
   },
   "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:39.110683Z",
     "iopub.status.busy": "2025-09-24T06:29:39.110537Z",
     "iopub.status.idle": "2025-09-24T06:29:39.112823Z",
     "shell.execute_reply": "2025-09-24T06:29:39.112484Z"
    }
   },
   "outputs": [],
   "source": [
    "labels_compare = [\n",
    "    'Development',\n",
    "    'Rate of change',\n",
    "    'Crawl with more data',\n",
    "    'Reverse training',\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9aee91e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:39.114108Z",
     "iopub.status.busy": "2025-09-24T06:29:39.113981Z",
     "iopub.status.idle": "2025-09-24T06:29:39.121739Z",
     "shell.execute_reply": "2025-09-24T06:29:39.121385Z"
    }
   },
   "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",
    "    # # ###################################################################################\n",
    "    # # ########################## DIS-AGREEING MODELS ####################################\n",
    "    # # ###################################################################################\n",
    "    { # RATE OF CHANGE\n",
    "        'behaviour' : ['crawl', 'crawl', 'crawl', 'crawl', 'crawl'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl', 'crawl', 'crawl', 'crawl'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': None,\n",
    "        'pretrained_model_folder': [False,True,True,True,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, 20, 25, 30, 30],\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",
    "    { # CRAWL WITH MORE DATA\n",
    "        'behaviour' : ['crawl', 'crawl', 'crawl', 'crawl', 'crawl'],\n",
    "        'pretrained_behav' : ['crawl', 'crawl', 'crawl', 'crawl', 'crawl'],\n",
    "        'env' : 'box_messy',\n",
    "        'env_dim': 0.635,\n",
    "        'name_prefix': None,\n",
    "        'pretrained_model_folder': [False,True,True,True,False],\n",
    "        'moredata': [None, 1, 2, 3, 3],\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",
    "    { # REVERSE TRAINING\n",
    "        'behaviour' : ['adult', 'run', 'walk', 'crawl', 'crawl'],\n",
    "        'pretrained_behav' : ['adult', 'adult,run', 'adult,run,walk', 'adult,run,walk,crawl', 'crawl'],\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": "code",
   "execution_count": 28,
   "id": "2d42074f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T06:29:39.122923Z",
     "iopub.status.busy": "2025-09-24T06:29:39.122804Z",
     "iopub.status.idle": "2025-09-24T06:29:39.125297Z",
     "shell.execute_reply": "2025-09-24T06:29:39.124923Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Development None\n",
      "Rate of change None\n",
      "Crawl with more data None\n",
      "Reverse training None\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:39.126472Z",
     "iopub.status.busy": "2025-09-24T06:29:39.126353Z",
     "iopub.status.idle": "2025-09-24T06:29:39.129926Z",
     "shell.execute_reply": "2025-09-24T06:29:39.129566Z"
    }
   },
   "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', 'crawl', 'crawl', 'crawl', 'crawl']\n",
      "\tpretrained_behav: ['crawl', 'crawl', 'crawl', 'crawl', 'crawl']\n",
      "\tpretrained_model_folder: [False, True, True, True, False]\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",
      "\tstride: [10, 20, 25, 30, 30]\n",
      "\treset_hidden_at: [None, None, None, None, 10]\n",
      "\n",
      "Comparison will be done on the following parameters:\n",
      "\tbehaviour: ['crawl', 'crawl', 'crawl', 'crawl', 'crawl']\n",
      "\tpretrained_behav: ['crawl', 'crawl', 'crawl', 'crawl', 'crawl']\n",
      "\tpretrained_model_folder: [False, True, True, True, False]\n",
      "\tmoredata: [None, 1, 2, 3, 3]\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: ['adult', 'run', 'walk', 'crawl', 'crawl']\n",
      "\tpretrained_behav: ['adult', 'adult,run', 'adult,run,walk', 'adult,run,walk,crawl', 'crawl']\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:39.131125Z",
     "iopub.status.busy": "2025-09-24T06:29:39.130999Z",
     "iopub.status.idle": "2025-09-24T06:29:39.167252Z",
     "shell.execute_reply": "2025-09-24T06:29:39.166614Z"
    }
   },
   "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",
      "Rate of change 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/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st20_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st25_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st30_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st30_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "\n",
      "Crawl with more data 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/crawl/predictions/box_messy/vanilla/RNN_ft_moredata1_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_moredata2_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_moredata3_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_moredata3_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_crawl_epoch1500\n",
      "\n",
      "Reverse training comparing the activity from the following directories:\n",
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_adult_epoch2500\n",
      "/media/data/vrtopc/box/run/predictions/box_messy/adult/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_run_epoch2500\n",
      "/media/data/vrtopc/box/walk/predictions/box_messy/adult_run/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_walk_epoch2500\n",
      "/media/data/vrtopc/box/crawl/predictions/box_messy/adult_run_walk/RNN_f1_w9_st10_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch2500\n",
      "/media/data/vrtopc/box/crawl/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_crawl_epoch2500\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:39.168738Z",
     "iopub.status.busy": "2025-09-24T06:29:39.168593Z",
     "iopub.status.idle": "2025-09-24T06:29:39.172219Z",
     "shell.execute_reply": "2025-09-24T06:29:39.171839Z"
    }
   },
   "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:39.174375Z",
     "iopub.status.busy": "2025-09-24T06:29:39.174269Z",
     "iopub.status.idle": "2025-09-24T06:29:39.179757Z",
     "shell.execute_reply": "2025-09-24T06:29:39.179386Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Development\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rate of change\n",
      "Crawl with more data\n",
      "Reverse training\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:39.180857Z",
     "iopub.status.busy": "2025-09-24T06:29:39.180747Z",
     "iopub.status.idle": "2025-09-24T06:36:23.743691Z",
     "shell.execute_reply": "2025-09-24T06:36:23.743180Z"
    }
   },
   "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"
     ]
    }
   ],
   "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:23.747340Z",
     "iopub.status.busy": "2025-09-24T06:36:23.747063Z",
     "iopub.status.idle": "2025-09-24T07:03:16.619937Z",
     "shell.execute_reply": "2025-09-24T07:03:16.619444Z"
    }
   },
   "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]_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/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st20_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(63180, 500) (63180, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st25_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(62775, 500) (62775, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_ft_f1_w9_st30_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(60750, 500) (60750, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/crawl/predictions/box_messy/vanilla/RNN_gridcellssm25_mod[0.2,0.4,0.6]_ori[0.1]_reset10_f1_w9_st30_fss4_do[0,0,0]_lat500_nlsigmoid_hreg0.0_wreg0.0_s01/act_crawl_epoch1500\n",
      "(60750, 500) (60750, 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]_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/crawl/predictions/box_messy/vanilla/RNN_ft_moredata1_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/crawl/predictions/box_messy/vanilla/RNN_ft_moredata2_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/crawl/predictions/box_messy/vanilla/RNN_ft_moredata3_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/crawl/predictions/box_messy/vanilla/RNN_moredata3_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_crawl_epoch1500\n",
      "(63990, 500) (63990, 2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/media/data/vrtopc/box/adult/predictions/box_messy/vanilla/RNN_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/run/predictions/box_messy/adult/RNN_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/walk/predictions/box_messy/adult_run/RNN_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/crawl/predictions/box_messy/adult_run_walk/RNN_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/crawl/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_crawl_epoch2500\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:03:16.623063Z",
     "iopub.status.busy": "2025-09-24T07:03:16.622905Z",
     "iopub.status.idle": "2025-09-24T07:03:16.629727Z",
     "shell.execute_reply": "2025-09-24T07:03:16.629380Z"
    }
   },
   "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:03:16.633767Z",
     "iopub.status.busy": "2025-09-24T07:03:16.633630Z",
     "iopub.status.idle": "2025-09-24T07:03:16.635785Z",
     "shell.execute_reply": "2025-09-24T07:03:16.635491Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Development', 'Rate of change', 'Crawl with more data', 'Reverse training']\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:03:16.639007Z",
     "iopub.status.busy": "2025-09-24T07:03:16.638795Z",
     "iopub.status.idle": "2025-09-24T07:03:16.644542Z",
     "shell.execute_reply": "2025-09-24T07:03:16.641173Z"
    }
   },
   "outputs": [],
   "source": [
    "ls_gc = (0, (1,1.5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "63fb1642",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:03:16.645668Z",
     "iopub.status.busy": "2025-09-24T07:03:16.645536Z",
     "iopub.status.idle": "2025-09-24T07:03:16.647308Z",
     "shell.execute_reply": "2025-09-24T07:03:16.647009Z"
    }
   },
   "outputs": [],
   "source": [
    "alpha_low = 0.2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "fddc817f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-09-24T07:03:16.648549Z",
     "iopub.status.busy": "2025-09-24T07:03:16.648331Z",
     "iopub.status.idle": "2025-09-24T07:03:17.288158Z",
     "shell.execute_reply": "2025-09-24T07:03:17.287706Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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pyopKYFKpQIA9qgiIiIiIiIiIiIiIiIKQn4RqFKr1VAqleL/MpnMLBUgERERERERERERERERBRe/SP1XWlpq8n9RURFkMplvCkNERERERERERERERERe4fNAVXNzM7Rarcm0+vp6k/81Go0XS0RERERERERERERERETe4PNAlUKhMJum1WpRXl4OtVqNsrIylJeXm83T3NwsjmdFREREREREREREREREgcfngSoA2LBhg9m0yspKKJVKNDc3o6mpyez1srIys5SBREREFLyqqqogkUgsPoiIiIiIiIiIKDD5RaCqoqICW7duFXtXyWQyLF++HCqVCiqVCgqFQvwLAAUFBaioqEBDQ4Mvi01ERERetHbtWjQ1NXEcSyIiIiIiIiKiICIRBEHwdSGIiIiI7FVaWora2lqTaazOEBEREREREREFJr/oUUVERERERERERERERETjDwNVREREFFDkcrmvi0BERERERERERG7CQBURERERERERERERERH5BANVRERERERERERERERE5BMMVBEREREREREREREREZFPMFBFREREQaG2thalpaVITEyERCJBYWEhqqqqfF0sIiIiIr9TW1sLpVIp1psSExOhVCpRW1vr66IRERHROMRAFREREQW8srIylJaWQq1WQ6vVAgA0Gg3KysqgVCrFaURERETjWXNzM5RKJUpLS1FfX4+amhp0dXWhpKQEarUapaWlKCws9HUxiYiIaJxhoIqIiIgCXmdnJwRBQFdXF5qamiCTycTX1Go1lixZ4rvCEREREfmB5uZmZGZmQq1WAwD27t2LkpISyGQyrFy5UpxPo9GgvLzcV8UkIiKicYiBKiIiIgp41dXV4nOFQmHyP3CnwYWpbIiIiGg8Ky0tFZ8rFAoUFBSI/xvf5APcqTsREREReQsDVURERBTwRjeuLF++3Gwe3hlMRERE41VlZaVJ8Mk4SAVA7FllYBzUIiIiIvI0qa8LQEREROQJBQUFJg0yzc3NPiwNERERke9s3brV5H+FQmE2T0tLC+rr66FQKCy+TkREROQp7FFFREREQUkul5tNY7CKiIiIxhutVmtXHUgmk6GkpIRBKiIiIvI6BqqIiIgoKFlqZGGgioiIiMabzs5Os2msExEREZE/YaCKiIiIgpKlRhneIUxERETjDXuZExERkb9joIqIiIiCklarNZvGQBURERGNNzKZDDKZzGSaRqNhsIqIiIj8BgNVREREFJRG96hau3atj0pCRERE5FslJSVm0yoqKnxQEiIiIiJzDFQRERFR0NFqtdBoNOL/MpmMjTFEREQ0blVXV5tNq6qqQlVVlcX5S0tLPV0kIiIiIhEDVURERBTwRqeuGd3oUl1dbZbyhoiIiGi8kMlk2Lp1q9n0srIylJaWoqqqCmq1GpWVlcjMzIRSqfRBKYmIiGi8kgiCIPi6EERERET2KisrQ1VVFQoKClBWVoby8nIoFApUV1dDoVDgjTfeQFlZGYA7jTI1NTUW090QERERjTe1tbVYs2aNxbE8DWpqarB8+XLvFYqIiIjGPQaqiIiIKKCUlZUhMzMTGzZsAHAnzd+mTZugVquh0Wggk8mgUChQUlKCjRs3sicVERERkRGtVovy8nKo1Wo0NzdDJpNBLpdj+fLlrDsRERGRTzBQRURERERERERERERERD7BMaqIiIiIiIiIiIiIiIjIJxioIiIiIiIiIiIiIiIiIp9goIqIiIiIiIiIiIiIiIh8goEqIiIiIiIiIiIiIiIi8gkGqoiIiIiIiIiIiIiIiMgnGKgiIiIiIiIiIiIiIiIin2CgioiIiIiIiIiIiIiIiHyCgSoiIiIiIiIiIiIiIiLyCQaqiIiIiIiIiIiIiIiIyCcYqCIiIiIiIiIiIiIiIiKfYKCKiIiIiIiIiIiIiIiIfIKBKiIiIiIiIiIiIiIiIvIJBqqIiIiIiIiIiIiIiIjIJxioIiIiIiIiIiIiIiIiIp9goIqIiIiIiIiIiIiIiIh8goEqIiIiIiIiIiIiIiIi8gkGqoiIiIiIiIiIiIiIiMgnGKgiIiIiIiIiIiIiIiIin2CgioiIiIiIiIiIiIiIiHyCgSoiIiIiIiIiIiIiIiLyCQaqiIiIiIiIiIiIiIiIyCcYqCIiIiIiIiIiIiIiIiKfYKCKiIiIiIiIiIiIiIiIfIKBKiIiIiIiIiIiIiIiIvIJqa8LEMz0ej1u3rxpMi0pKQkhIYwPEhERUeBiHYeIiIiCDes3REREvsNAlQfdvHkTkyZNMpl248YNTJw40UclIiIiInId6zhEREQUbFi/ISIi8h3eFkJERETk56qqqqBUKlFYWIjMzExkZmZCqVSitrbWoWUYv7+wsBBVVVUeLDURERERERER0djYo4qIiIjIjymVShQUFKCmpgYymUycXl5ejtLSUhQUFGDv3r0mrxnTaDQoLS2FTCZDdXU1CgoKAABarRaFhYXQarXYsGGDFz4JEREREREREZE59qgiIiIi8lNVVVVQq9UAYBaIqqiogEwmg0ajwaZNmyy+v7m5GYWFhVAoFGhoaBCDVADwxhtvoLm5Ga+//rrHyk9ERERERERENBYGqoiIiIj8VENDAwBYTfFXVFQE4E6vKUsMPalqamosvlcmk6GkpMRNpSUiIiIiIiIichxT/xERERH5KUOvqZUrV1p8vb6+HgBMekoZVFVVQaPRYO3atRbTAhYUFKCrq8ut5SUiIiIiIiIichQDVURERER+SiaToaKiwuJrtbW10Gq1kMlk2Lhxo9nr5eXlAO70qiIiIiIiIiIi8ldM/UdEREQUYKqqqlBaWiqOPTW6x1RzczO0Wi0AQKFQQKPRQKlUIjMzE4mJiSgsLLSaTnC09vZ2s0dHR4ebPxERERERERERjVfsURVgOjs7MTIygqeeegp//vOfMXnyZF8XiYiIiLygrKwMarUazc3NAICSkhLU1NRYTOtnPGaVRqPB1q1bTeatra1FaWkpli9fbnH8KmOTJk1y22cgIiLyJp1Oh+vXryMlJcXXRSEiIiIiGxioCiA3btxAeXk5XnvtNQwNDUGhUECtViM7OxuxsbGIjIz0dRGJiIjIQ7Zu3So+V6vVKCsrQ0ZGBioqKrB27VqTeTs7O8XnmzZtQkNDg8nry5cvR0VFBcrLy1FaWjpmsIqIiChQCIKAxsZGqFQq1NXVISEhAb///e8hkUh8XTQiGsf0ej0GBgbQ399v8lev14vHJ4lE4tDD395DROQKBqoCyKVLl7B9+3bodDoAQH9/Px588EGUlJRg1qxZmDx5MuLi4hAbG2v2iImJEZ9HRUX5+JMQERGRK0pKStDU1ITExESUlZUBgFmwysDw+mhr165FeXk5amtrodFoUFBQ4LHyEhEReVp7ezvUajVUKhUuXrwoTu/p6cHZs2eRk5Pjw9IR0XhhLSA1ODjo66J5nD8Gz9y5Lm/S6/W4fv06Jk+ezCAgjRsMVAWIoaEhLF26VAxSGej1eqhUKpw9exZJSUmYMWMGMjMzERcXZ3VZoaGhJoErWwEtHgyJiIhsO3HiBDo7O8WUfHK5HDKZDEVFRYiPj/foujdu3Ijy8nKUlZVhxYoVYmo/uVwuzlNUVGTxvcYpA9VqNQNVREQUcPr6+nDo0CGoVCp88sknEATB4nwqlYqBKiJyq/EckLLGcAy2diwOdN4KuA0MDODixYsYGhpCR0cHpk2bBqlUKj5CQ0PZXktBiYGqADF//nzcvHnT4muCIKCtrQ0A0N3djfr6ekyZMgVZWVnIyMhAeHi4yfwjIyPo6elBT0+PzXWGhISYBa8sBbSio6N5gCQionHlpZdegkqlglqttjmfQqGAUqnE2rVrMXv2bLeXwzi49MYbb4i9qoynWxrDyvg1rVZrtY4B3Ek9PFpHRwfy8/OdKDEREZFr9Ho9jh8/DpVKhUOHDtnVKLx//348++yzkErZBEJEjmFAigwEQfB4EE6r1eLatWviem7cuIHOzk7ExsaazBcaGorQ0FCzAJal58b/E/kzbqEB4t///d/x+OOPW33dEKxKS0uDVCrF1atXcfXqVXz44YdIT09HVlYWUlJSEBISYvc69Xq9XQEtiURiNZgVFxcnvhYTE8OAFhERBbSXXnoJmzZtglarBTD23YJNTU1obm7G1q1boVQqUVFRgXvuuceudWm1WhQWFkImk2Hv3r0WA07GPaeamprE5wqFQgxCNTc3Q6FQ2FxXUlKS1dcmTpxoV3mJiIg8qa2tDSqVCnv37kVHR4dD7+3p6cHRo0cxf/58D5WOiAIdA1LkS3q9HlevXrXYBnvlyhVkZGQgLCxMnDYyMoKRkREMDQ05tB57A1rGz0NDQ13+fET2YKAqQOTk5CA/Px+nTp2yOo8hWDV9+nTx4DUyMoKmpiY0NTUhKioKmZmZmDFjBuRyuduCRoIgoLe3F729vTbnk0gkiI6Otiug5UhAjYiIyNNaW1uhVCrR3NwsBqcKCgqgUCigUCiQlJQkBpIMQaympiZ0dnZCo9GgubkZe/bsgUqlQnl5OV588cUx16lWq8V0gvX19SgpKTGbx/A6AMyZM8fktbVr16KyshIajcbie43Lunz58jHLQ0RE5G3d3d3Yt28fVCoVzp075/RyoqOjHQ5uEVFwYkCK/JFer8ft27ctvjYyMoLLly8jLS3N5bZcnU4HnU7n0PYukUic6r3Ftl1ylETw88Shvhz3wVXt7e2YNGmSybQbN244fWfysWPH8Kc//Qm/+c1vbN7BLZFITIJVliQmJmLGjBnIyspCdHS0U+XxJEsBrdFpB2NiYhjVJyIij3vrrbewfPlyyGQyrF27FkqlEkuWLHFoGd3d3VCpVNi6dSv27t2LpUuX4r333rP5Hq1Wi8TERCxfvhw1NTUW5yktLUVtbS0UCoVJjyrD+zMyMgAALS0tZj2yKisrUV5ejg0bNqCiosKhz+PuOg4REZHB8PAwPv74Y6hUKhw9ehQjIyNOLUcikaCoqAhKpRLz589HRESEm0tKwYb1m+DirwGpkJAQREZGIjIyElFRUQgPDxdTyhmP8eTIw93vId/o7e3FxYsXrb4ul8uRnJzsxRK5RiKROBzckkqlzMY1jvlloMpfxn1wlacqOXV1dSgpKbFZYZdIJMjOzkZoaCh0Oh30er3VeVNSUjBjxgykpaXZDG75o6ioKJsBLUNPLQa0iIjIGdXV1SgvL0dFRQXWrFnjlmWq1Wo8++yzkMvlOHr0qM15a2trsWnTJmzcuBElJSUmvbY2bdqEyspKKBQKqFQqi+n9NBoNCgsLUVJSgpqaGvH9hiCVrSCYLWzIISIidxIEAadPn4ZKpUJdXd2Y2TpsycjIwNKlS/HQQw+ZpMglGgvrN4EpUAJSxoEpf2+I93QgzJ3vcfR9/u7GjRs2xw+eNm2a2XhVwSYkJMSh1ISG5/6+X9HY/CpQ5ei4DwDEjdDRcR+8wZOVnIMHD+Khhx6yGawKCQnBfffdh+joaAiCIOYvHRkZEYNXOp1OnGboiZWVlYWpU6cG1Q4eGRlpkl7QUg+t2NhYDixIRESi6upqsQdUQkKC25dfVlaG1tZWvP/++zbnM4xxpVarodVq0dnZCblcDoVCgdLSUqxdu9bm+w1BLeNUgkVFRSgrK3M65R8bcoiIyB2uX78OlUoFlUqFK1euOL0cmUyGJUuWQKlUQqFQBNW1LHkP6zf+jQEpchd/C54Zv0ev16O5uRm3b9+GXq8X22wNr4eGhpqNV0V32Api2Qp2kf/wi0CVO8Z9AO4Erewd98EbPF3JcTRYZQ9DQCshIQFz587F7NmzkZCQII5BZXjcvn07IO5EcFRERITVgJZxUIsnBCKi4Hb8+HGsWbMG9fX1Hl3Ps88+i6ysLHzve9/z6HrcjQ05RETkrL6+Phw8eBAqlQonT550ejlhYWFYsGABlEolCgsL2dhELmP9xj8wIEXj3dDQEE6fPg2dTidOMw5aRUVFIT09XeyAYHgYOiYYPw/Gtlt3cya4xTqHZ/g8UOWrcR+8wRuVnEOHDmHx4sUmB6/RHA1WjTZjxgwolUosXrxYDBgKgoC+vj6z4JWlgJattIOBKiIiwqw3lqWAVnh4uK+LSkRETlixYgWqq6s90pPK0rq2bdvm92NvGmNDDhEROWJkZAQajQYqlQqHDx/G0NCQ08uaNWsWlEolFi5cGPTpj8i7WL/xLgakiKzr6enBuXPnrL4+efJkpKSkjLkc48xatgJao/8n2wzjb9mbmtDwf0hIiK+L7td8Gqjy9bgPnuatSs7hw4dRXFxs80ASHh6O1atX4+LFi05H00NCQjBnzhyUlJTg/vvvt2swWkEQ0N/fbxa8unXrlllgKxgDWuHh4XYFtDiwLxERBRI25BARkT1aWlqgUqmwd+9edHZ2Or2cKVOmiDe1Tp061Y0lJPo71m88gwEpIudcvnwZ165ds/p6VlaWx26stDegZfzcVsYvusMw/pYjvbekUum4OSb5LFDlL+M+eJI3KzkfffQRFi5caDNYFRkZiX379qGtrQ0qlQoXLlxwen3R0dFYtGgRlEolZs2a5ZYdxt6AVjAe+MLCwsYMaMXFxTGgRUREfoENOUREZE1XVxf27dsHlUqFpqYmp5cTExOD4uJiKJVK5Ofnj5tGGvId1m9cw4AUkXsJgoCzZ8+it7fX4utSqRR5eXl+k83JMJyMI8EtnU4XlB0X3M2QbtBSMCspKSlo2ot9EqgaL+M+eLuSc+TIETzwwANjBqs0Gg1yc3Nx/vx5qFQq7Nu3D93d3U6vNzk5GSUlJSgpKUFqaqrTy7HXwMCAxRSDo6cFY1dVqVQqBq0sBbUMr0VGRvq6qEREQa2lpQWVlZXYsmWLQ+/r6elBc3MzZs+e7ZmCeQkbcoiIyNjg4CA++ugjqFQq1NfXO93oZMjioVQqcf/99/tN4xuND6zf2IcBKSLvsTRelbHY2FhkZ2cH9DZuGH/LkdSEHH/r73JzcxETE+PrYriFTwJV42XcB19Uco4dO4YFCxZgeHjY6jwRERFoaGjAzJkzAdzpzllfXw+VSoWPPvrI5nvHkpeXh5KSEhQXF/t8rI3BwUG7AlqufF5/FRYWhoSEBKuPqKgoXxeRiCigGcbEdKSX7/PPP4/NmzejoKAAgiAgMzMTr7/+ugdL6TlsyCEiIkEQ8Pnnn0OlUuHAgQO4ffu208vKysoSx0VOTEx0uWwjIyOoqqpCfX09ioqKsHbtWg58TmNi/cYUA1JE/qG7uxvnz5+3+rq941UFG71e73DvrZGRkaALcM2cOTNoOiz4dIyqYOerSk59fT3mz58/ZrCqvr4es2bNMpne29uLgwcPQq1W49NPP3W6DFKpFPPmzYNSqcTcuXMRFhbm9LI8bWhoyK6AlisD/vqb8PBwJCQkID4+HgkJCZDJZCaBrGA5wBEReYpxoOqtt95CZ2cnioqKrPaUevPNN1FaWorMzExxUNyqqiq8+eabPk1T7Cw25BARjV9XrlyBWq2GWq3G1atXnV6OXC4XM3NkZGS4sYTAq6++ir/85S/i/0899RSefvppt66Dgs94rd8wIEXk/3w5XlWwMR5Ty57glr+Pv3XPPfdAKpX6uhhuETSBqrfeegtPPPGEr4thwpeVHI1Gg/vuu89msCo8PBzHjh3D3XffbfH1a9euQa1WQ6VS4cqVK06XJTY2FosXL4ZSqURubm7AViiGhobMAliWxtHydWXOHQyBLEsPmUwWNLlPiYictXnzZpSXl5ud0zIzM6FSqZCWlmYyfenSpdi7dy/Wrl1rki5w6dKlWLlyJb75zW96pdzuMl4bcoiIxivDDY179uzB559/7vRyIiIisGDBAiiVShQUFCAkJMSNpbzj0qVLWLNmDXQ6HTo6OjBhwgRIpVJUV1d7JVU9Ba5gr98wIEUUuAJtvKpgYzz+liPjcHkjwFVQUBA0x8qgCVQ9/PDDfndHsq8rORqNBvfff7/NnkDh4eE4cuSIzbEyBEHA6dOnoVarsX//fqsHRXukpKSId81NnjzZ6eX4s+HhYbsCWgMDA74uqtMiIiJsphZkIIuIgll3dzcyMjLQ3d1tMW1AVlYWzp49azJNLpeju7sbFRUVJmNnVlVVYePGjbh586bHy+1Ovq7jEBGR5+l0OjQ0NEClUuHDDz90KWX6PffcA6VSiQcffBDR0dFuLKUpQRCwceNGNDQ0oKenB+fPn0dWVhbi4+NRVFSEF198MWgac8j9gqV+w4AUUXAaD+NVBRtBEJzqvWXvWJ+hoaEBP/61Mb8OVLW2tqK5uRlarRadnZ1W51OpVKitrfW7bnj+UMk5ceIE5s2b53KwymB4eBhHjhyBWq3GkSNHrB4c7XHXXXdBqVRi4cKFQTPomyN0Op3FFIOjUw/29/f7uqgOMw5kjU4rGB8fz0AWEQU0Q28qAJDJZNi4cSMKCgqgUCjQ1NSE559/Hv/wD/+A9evXi+8JCQmBRCLB1q1b8cwzz4jTu7u7kZiYiDfffBNf+cpXvP5ZnOUPdRwiInI/QRDQ3NyMPXv2YN++fdBqtU4vKyUlBUqlEiUlJUhOTnZfIW04dOgQfvKTn0AQBJw6dQqDg4OIiIhAfn4+JBIJXnjhBSxYsMArZaHAE2j1G0NAyhCMYkCKKPhxvKrxQa/X2xXckkgkUCgUvi6u2/hloGrbtm2oqKhAc3OzXfMLggCJRMJAlRUnT57EnDlzbAarwsLC8PHHH6OgoMDu5fb09KCurg4qlQpnzpxxunxhYWGYP38+SkpKUFRUFDR5Nd1lZGTEroBWX1+fr4tqt8jISJs9sthVmYj82YoVK1BbW4vy8nJs2rTJ7HWtVgulUoljx46J06wFqgyvPfvss/jtb3/r8bK7i7/UcYiIyD1u3ryJffv2QaVSoaWlxenl+DLt+8DAAL7xjW+gvb0dV69eNRk/a8qUKZgyZQomTZqEV199lTfOkUX+Wr9hQIqIjI01XtWMGTMQHx/vxRIRuYffRQTefPNNrF27FhKJxGI6HXLc3XffjYaGBhQVFVmtyAwPD+O+++7Dhx9+iKKiIruWGx8fj8ceewyPPfYYLl26JA6oe/36dYfKNzw8jAMHDuDAgQNISEjAQw89BKVSiaysLFZucKcbZ3x8/JgnGUNA69atW+jp6UF3d7fZw1+CuYZKtrVtJSoqymoQKz4+noEsIvIpjUaDmpoaPPnkkxZfl8lkJnegd3d3i8/lcrnF+VUqldvLSUREZMvg4CAOHz4MlUqFhoYGp6+/Q0NDMXfuXCxduhTz5s1DWFiYm0tqn9deew3t7e0YGhoSrzMSExPR1dWF69evIykpCTdu3MBrr72Gp59+2idlJLLFXwNSEonEJBDFgBSRb02dOlW8ad2SlpYW5Ofn++x8TOQsv+tRVVRUBI1GA5lMhhUrVqCwsBCA5YYdAOjs7ER9fT22bdvmN43wBv52N87nn3+OwsJCm5WcsLAwHD58GHPmzHFqHYIg4LPPPoNKpcKBAwdc6uWTlpaGkpISLFmyxOd3MAUDQRBw+/ZtiwGs7u5u9PT0+N0+ZE1UVJTFlIKG5zwZE5EnhYaG2jxednd3Qy6Xi/O0tLQgMzMTEokEKpUKDz30kMn8crkcEokkoMap8rc6DhER2UcQBHz66afYs2cPPvjgA5eu17Kzs6FUKrF48WIkJCS4sZSOu3TpEtasWQOdToempiZ0d3cjLi4OmZmZaGxsRF9fH2QyGTIzMyGVSrFt2zamRiIz3qrfMCBFRK7ieFXj08DAAObPn4/PP/8cM2fOxIcffojIyEhfF8tt/C5QZUiN09TUhPT0dLvft3TpUuzZs8dzBXOCPzbinD59GgUFBRgYGLA6j1QqxaFDhzBv3jyX1jU4OIiPPvoIKpUK9fX1dg8EN5pEIsHs2bNRUlKCBx54wKOD745ngiCgt7dXDFoZAlharVac5uxv6G3R0dE2UwsyvSQRuaKoqAibN2/G4sWLLb6+YsUK7N27Vww8HT9+HIWFhZBIJGhoaDAbE9JQ9wmUmwUA/6zjEBGRda5kwDA2YcIElJSUoKSkBGlpaW4sofMEQcDGjRtRX1+PmzdvoqmpCXq9HgkJCRgaGsLw8DCAOzeaZGVlIT4+HkVFRXjxxRfZgEcm3F2/YUCKiDyJ41WNPwsWLMCHH35o8v+hQ4d8WCL38rtAVVZWFhITE03GdbDH3r17sWTJEg+Vyjn+2ohjb7Dq4MGDuP/++92yzq6uLuzfvx9qtRrnzp1zejkRERF44IEHoFQqce+99yIkJMQt5aOxGQeyrPXICpRAVkxMjM3UggxkEZEttbW1WLlyJSorK/Hkk08iPT0dra2t0Gg02LRpEzQaDRISEvCDH/wA69evx5tvvonS0lJIJBJ0dXWZpHI1BLEyMzNdOj96m7/WcYiI6O9u3boljil8+vRpp5cTGRmJBx98EEqlEvfcc4/fXIN1dnbi7NmzePvtt/Haa6+J2SP0ej0iIiJMxqGKiIjA4OAgIiIikJ+fD4lEghdeeAELFizw4Scgf+PO+k1HRwfa2trcVTSnMCBFFPwuXbpk8wYUjlcVPN5//3088sgjZtPfe+89PPzwwz4okfv5XaCqrKwMtbW1AZX+xhp/bsRpbGzE7NmzxwxW1dXVub3y3traCrVajb1796Kjo8Pp5SQlJYnjWWVkZLixhOQMQRBw69Ytm4EsPzvcWBUbG2uWUtCQajA+Ph6hoaG+LiIR+VhZWRmqq6vNLvIFQYBEIkFnZyfKy8shkUhQX1+PhoYGSCQSVFZWYv369eL8zz77LKqqqqBUKvH+++97+2M4zZ/rOERE45lOp8OxY8egUqnw0UcfWU0JNBZDVgulUokHHngAUVFRbi6pY3p7e3H27Fk0NjaisbERZ8+eRXt7OwDgs88+w9DQEAYHBzE4OIiQkBDExMSYnKPj4+PR39+P4eFhTJkyRXz8z//8DxvsSeTO+k1PT4/XbkJiQIpo/BIEAY2Njbh9+7bF16VSKcerCgJ6vR6TJk2yGC8xjMHpLzcSucLvAlXNzc3IysoSc0rb66WXXsL3vvc9D5bMcf7eiHPu3Dncc8896O/vtzqPVCrF/v378cADD7h9/Xq9HidOnIBarcYHH3xgM2g2FoVCAaVSiYceesjqeGbkW3q93qRHliGloOFx69atgAxkWeqRxUAW0fhQXl6OzZs3m02vqanBk08+CQAoLS3Fm2++CYlEgu9///vQarVoaWlBWVkZjh07hoqKCkgkEmzduhXPPPOMtz+C0/y9jkNENJ4IgoBz585BpVJh//796O7udnpZ06ZNw9KlS306TvDAwADOnz8vBqUaGxtx5coVi/MODw/j008/BQDxemJ0byrgzljMEyZMwNWrVxEaGoq7774bEokEf/3rX5GUlOTxz0SBwZ31m+HhYZw8edJdRQPAgBQRWTY0NIRTp05ZTSXP8aoC34YNGyy2PRi/XlFR4cUSeYbfBaoAoKqqCnv37sXrr79u93vmzJnjcLpATwuERhx7glWhoaGoq6vzSLDKoL+/H4cPH4ZarYZGo3E6YCGRSFBUVASlUon58+ebXaCQ/9Lr9TZ7ZAVSICsuLs5mICsY7nIgojtaWlpQW1uLY8eOQS6Xo6ysDPfee6/JPLW1tWhpacH3v/99AIBSqcS+ffsA3GlcTExMDLie5IFQxyEiCnbt7e3Yt28fVCqVSynG4uPjxUwVM2bM8GpDlk6nQ0tLi0lQqrW11aF6vz09qgRBgFQqxcjICHtUkVXurt+cOHHCqTFIGZAiIkeNNV7VlClTMHXqVC+WiNzlxo0bmDp1qs3zSWhoKK5du4YJEyZ4sWTu55eBKuBOKpyWlhYUFBTYnE+r1aK+vh4ajcbvBiEPlEacpqYm3HXXXWMGq/bt24eFCxd6vDwdHR3iBVdra6vTy4mOjhZzqRvumKPANTIyMmYgKxBIJBLExcWJKQWN0womJCQgLi6OgSyiccCQOlChUKCmpsYsuOXvAqWOQ0QUbAw3+KlUKhw/ftzpG7mkUinuu+8+KJVKzJ071ytjtOr1ely8eNEkfV9TUxOGh4ddWq5Wq0VzczOAOykCLY1RNTg4iNDQUMTExHCMKrLK3fWbxsZG9Pb2Wn2dASkicieOVxWcFixYgA8//NCu+Q4dOuSFEnmOXwaqNm7ciMrKSrvnN4wHwUCV81paWjBr1iz09fVZnSc0NBRqtRrFxcVeKZMgCGhuboZKpcLevXuh1WqdXtakSZOwZMkSKJVKTJs2zX2FJL9hCGSNTinY09MTkIEsaz2yGMgiIn8QSHUcIqJAp9fr8cknn0ClUrmcMj0vLw9KpRKLFi3yaGOVIAi4du2aSVDq3LlzNm+OdMX58+fR09MDnU6Hvr4+hIaGYvLkyUhISEBoaKjY4ywrKwvx8fGYM2cO/vM//5PBADLh7vpNW1sbOjo6GJAiIq/geFXB5/3338cjjzxi9/x79uyBUqn0YIk8y+8CVZs3bxYHH3ekaAxUua6trQ0zZ860ekAD7gSr9uzZg4ceesiLJbsThGhoaIBarcbhw4cxNDTk9LJycnKgVCpRXFyMhIQEN5aS/NnIyIgYtLL0sHWnmz+RSCQmvbEsBbJ4sUPkXa2trdBoNHjiiSfEaXv37kVtbS0qKysdGnMzUARaHYeIKBBduHABarUaarUa7e3tTi9n0qRJKCkpgVKpRGpqqhtL+HednZ0m6fvOnj2Lnp4ej6xrtEmTJmHKlClQq9WIjIzEtWvXcOvWLcTFxSErKwvnz5/HrVu3kJCQgMzMTEilUmzbtg0pKSleKd941dzcjPLycrG3G3BnbOmNGzeOmTnHEVVVVdi6dat4Y6tMJkNZWRnWrl3r8LLcXb8ZHBwEAAakiMhrxhqvKi4uzutpfsk5er0ekyZNcmiYgKSkJNy4cSNgb3D3fP9+B23atAkSiQQJCQnYuHEjFAoFZDKZzfc0NDRg48aN3ilgEEtLS8Pnn39uM1g1MjKCpUuX4v3338eSJUu8VrbQ0FDMnTsXc+fORV9fHw4ePAi1Wo1PPvnE4WUZLp62bNmCuXPnoqSkBPfddx/Cw8M9UHLyF6GhoUhMTERiYqLF13U6nc1Alq0ArjcJgiCWyZKQkBCxR5ZMJkNkZCQuX76MtLQ0pKWlISUlBaGhoV4uNVFweuutt8QGGIlEAp1OJ762ZMkSCIKA9PR01NbWYvHixT4sKRERBYru7m7U1dVBpVKhsbHR6eVERUVh4cKFHkmD3tvbKwajDNdWHR0dblu+LTKZDDk5OcjOzkZOTg5ycnLE9oJXX30Vf/nLXxAREYFTp07h1q1baG1txa1btxASEiJm1lixYgWDVB5WW1uL0tJSVFRUoKamRpxeVVWFwsJCVFRUYMOGDS6tQ6PRoLS0FDKZDNXV1WLwS6vVorCwEFqt1uV1uIpjZhORt4WHhyM9PR1NTU0WX7916xauXr3K8aoCwPPPP+/wWNY3b97Exo0bUVFR4aFSeZbf9agKCQmBRCJBV1eXQ6kIVqxYgTfeeMODJXNcoN5tfOHCBeTn59tsmA8JCcF7773n8+6E169fx969e6FWq3Hx4kWnlxMbG4vi4mKUlJSIOcuJjOl0OospBQ2pBm2lzfQlrVaLEydOiP8bAnYTJkzApEmTkJycjJSUFMjlcsTExIiP2NhYREZG+q7gRH5u8+bNeP755wHYTkGsVqvx8MMPQ61WB1WwKlDrOERE/mh4eBhHjx7Fnj17cOTIEaczhUgkEhQWFkKpVGLBggVuaSQfGBjAuXPnTIJSV65ccXm59oiOjjYJSOXk5GDixIlWr9UGBgbwjW98A+3t7bh69SquXr0qvjZlyhRMmTIFkyZNwquvvsoAggc1NzcjMzMTy5cvNwlSGVRWVqK8vBwqlQolJSUuraOkpAQqlcrktaqqKpSVlaGgoAANDQ0OLZf1GyIKFhyvKrB1dHRg0qRJTo1FKpVKMTg4GJC9qvwuUJWVlYXExEQcO3bMofft3bvXqz187BHIlZwLFy5g5syZNtOhhYSEYPfu3Xj44Ye9WDLLDHlY1Wo19u/f71KaialTp2LJkiUoKSnhHQZkt+HhYZs9snwVyLp06RLOnz8/5nzh4eEmQaqYmBjExcUhPj7ebProgFZMTIxXBuAm8hfHjx9HYWGhyTRbKYiVSiU0Go3Dd0P5s0Cu4xAR+QPD9YtKpcL+/ftdGk81PT0dSqUSS5YsQVJSktPL0el0aG5uNknh19bW5lQjiaPCw8ORlZUlBqSys7ORmprq8A2Ehw4dwk9+8hMIgoBTp05hcHAQERER4s2IL7zwAhYsWOChT0EAUFpaitraWjQ0NFhM8afVapGYmAiFQmH1jv+xFBYWorm5GS0tLWYZeDQaDZYsWYK1a9c6fEc56zdEFCw4XlVgunbtGp555hns3r3bpfqXtXOwv/O7QFVlZSU2btzod+NNOSPQKzmXLl1CXl7emMGqd955B48++qgXS2abTqfD0aNHoVar8dFHH5mkYnLUzJkzUVJSguLiYsTGxrqxlDTeDA0N2QxkeWpg6cbGRpO7SR1hGPR3dHAqKirKrNEgIiLCahDL+P/o6Gj2WKSAt2LFCtTW1qKkpATl5eUoLCxEUlKS1bpLdXU1ysrK8Pzzz+PFF1/0cmk9I9DrOEREvmLICKFSqXDp0iWnl5OQkIAlS5ZAqVQiMzPT4fqVXq/HhQsXTHpKNTU1uXTtZK+QkBBkZGSY9JRKS0tzy41PgiBg48aNaGhoQE9PD86fP4+srCzEx8ejqKgIL774IuuiHmb4fm01NSUmJkKr1aKrq2vMoR5GM/SYWrt2LbZu3epKUc2wfkNEwYTjVQWOCxcu4Jvf/Cb27t3r8g1C7FHlZllZWXjzzTdxzz332P2el156Cd/73vc8WCrHBUMl58qVK8jNzbV5h19ISAjefvttLFu2zIsls09vby/q6uqgVqvx+eefO70cqVSK+++/H0qlEnPmzGHvEXK7oaEhiykFDY+BgQGnlqvRaNw+kHVoaCiio6PNAlH2jPMmkUgQHR1tM6BlmMaULOSvsrKyUFhYiNdff12cFhoaavUCYO/evVAqlSgsLHS4x7i/CoY6DhGRt/T19eHQoUNQqVQmKZkdFRYWhvvvvx9Lly5FYWGh3dckgiDg2rVrJj2lzp8/77EbpYxJJBKkpqaaBKUUCoVH63mXLl3CmjVroNPp0NHRgQkTJkAqlWLbtm0cm8rDNBoNCgsLIZPJ0NXVZXW+wsJCaDQa1NTUYPny5Q6twxDkciV1IHCnLjNaR0cH8vPzTaaxfkNEgUyr1drsvTplyhRmk/KhpqYmPP300/jggw/ctswNGzYE7BhVftnaXlNTg2eeecahxhyVSuV3gapgMHXqVJw5cwZ5eXlWG7v1ej2+9KUvYefOnfjiF7/o5RLaFhsbiy9+8Yv44he/iCtXrkCtVkOlUuHatWsOLUen0+GDDz7ABx98gPj4eCxevBhKpRLZ2dm884DcIjw8HBMnTrR6ETQ4OGi1R5ZWq8Xg4KDZewRBsDnWnLNGRkZw69YtswC2pfSB0dHRCA0NNSuTPeUKDQ0dM+WgoZcWg8fkTc3NzaiqqnJofuO/REQU/PR6PY4fPw6VSoVDhw5ZrKvZa+bMmVAqlVi0aJFdWR5u3rxpEpQ6e/asS6kFHZGcnCym7jP8jY6O9sq6DVJTU1FaWoq//OUvmDBhAoA7vaEZpPK8+vp6AIBcLrc5n+H1Y8eOORSoam5uhlarBQAoFApoNBqUl5ejubkZnZ2dUCgU2Lhxo13LHH3DDRFRMJLJZEhOTrY6XtXVq1cRGxvL8aq87PPPP8c3vvENHD161K3LnTBhAjZt2uTWZXqT37XsvfTSSwCArq4uzJkzB0VFRTbn7+zsRHNzMzQajTeKNy5NnToVjY2NyMnJsRmseuyxx/C3v/0Njz32mJdLaJ+pU6fia1/7Gr761a/i1KlTUKlUqKurc7ghv6enBzt37sTOnTsxbdo0MR88K7rkSREREWMGskYHsDo6OnDp0iXcuHHDK40TQ0NDGBoaMrt70pA+0DjgZCl94GgjIyPo6emxq0dYRESEzYCW4cHUg+QOjuZ6Hj3INxERBa/W1lao1Wqo1WqXxiacPHkylErlmOPm3rp1yyR9X2Njo9fGRExMTDQLSjmaxs1T/vEf/xGDg4NoaGhAYWEhvva1r/m6SOOCIYhkL0dv4jFu99FoNNi6dStqamrE7a62thalpaVYvnw5ampqHFo2EVGwSklJQW9vr9X2z5aWFo5X5SX19fVYs2aNSz3sbXnttdcCMuWfgd8Fqvbs2YO9e/cCuLOj2BOAEgSBDY8eNnnyZDQ2NiI3Nxfd3d0W5xEEAY8//jj+93//F1/+8pe9XEL7SSQSzJw5EzNnzsS3vvUtfPzxx1CpVDh27JjDY6NdvHgRr776Kl599VXcc889UCqVePDBB71+1yBRREQEJk2aZBYwXblyJYA7aTBbW1tx8eJFXL58GVevXsX169fR29uLwcFBMcjkiXEJ+vv70d/fj46ODnFaSEiIxaCSPekDLRkcHMTg4OCYDTPGqQfHCmwx9SBZU1JSAo1Gg4ceemjMeffu3Yva2lpIJJIxb76hO+mxwsPD2UuSiAKKVqvF/v37oVKpcO7cOaeXEx0djUWLFmHp0qWYOXOm2TXuwMAAzp07J/aSamxsxJUrV1wtvl1iYmLEgJThMWHCBL+9Dg8NDcVzzz3n62KMO54OknZ2dorPN23ahIaGBpPXly9fjoqKCpSXl6O0tJTBKiIi3GkHycjIwOnTpy22e+p0OrS0tHC8Kg86dOgQysrKcOrUKYffGxMTY1cniwULFkCpVDpTPL/hd60Aa9euhVqt9nUxyILJkyfj7NmzyMnJsXqnlCAI+MpXvoI333wTX/nKV7xbQCeEh4dj4cKFWLhwIbq7u7F//36o1Wo0NjY6vKxPPvkEn3zyCX71q19h/vz5UCqVKCgoMEl7RuQrsbGxmDVrFmbNmmUy/fbt22hvbxcf169fx5UrV9DX1ycGr4wfw8PDYmBLr9c7XR69Xm8xfWBYWJjFAJK79iPj1IM3btywOa9UKrUroOXO8lFgeP7556FQKKBUKm2Op1ldXY1nn31W/D/QK42edOnSJfzwhz/Ezp07MX36dBw/fjyg7wQjouA3NDQk3vB29OhRp+tFISEhKCoqglKpxP333y/eKDM8PIzm5maToFRbW5vLA2zbIyIiAllZWSaBqZSUFDZe0ZiSkpK8tq6ysjKL09euXYvy8nLU1tZCo9E43BOeiCgYRUREID093ep4Vbdu3cLVq1c5XpWbqVQq/NM//ZNTNzLdd9992LZtGyZOnIipU6fa7FwRGhqKv/3tby6U1D/4XaDK0IizdetWFBUV2ZU6QKVS8W4pL5k0aRLOnTuHGTNm2AxWPfnkk6ipqcGTTz7p3QK6ICEhAY8//jgef/xxXLhwQUzZYWmQVVsGBwexf/9+7N+/H4mJiViyZAlKSkqgUCh4cUd+xxBoSU9PF6cJgoCuri6TAFZ7e7tZSj+dTmcxmGUpuGVvo8rw8DC6urrclj7QFTqdTkyjOJbIyEirQSxvlpm8QyaT4ec//znuvfderFixQhzI+5NPPkFTUxOOHTuGqqoqaLVasdd3QUEBx9K04Xe/+x3+/Oc/Q6/XQ6vVIj09HQcPHjQ5NhER+ZogCDh16hTUajXq6urQ29vr9LIyMzOhVCqxePFiyGQyXLhwAXV1dWL6vubmZo/0dB8tNDQUGRkZJj2l0tLSeBMOOcXQfmPc88mWscaysjW/tZ7qxm1IarXaaqDK0k1rHR0dyM/Pd6hMRESBQiaTYdKkSVZv2r169Sri4uIQFxfn5ZIFn127duE73/kO2traHHqfRCLBwoUL8fvf/x6ZmZni9HXr1mHz5s1W37d+/XpxXM5AJhG8cUuWg5YuXYo9e/Y49J5nn30Wv/vd7zxUIue0t7ebpeG6ceOG1TFmAklHRweys7PNGpONSSQS/PWvf8WKFSu8WDL3EgQBn3zyCdRqNQ4ePIj+/n6nl5WRkYGSkhIsWbLEq3eaEbnL8PAwOjo6zAJYfX19Nt8nCAKGh4ftCmo50iDj7vSB3iCRSKwGtEZP8+fPQXdUVVXh2WeftRp8NFSxFAoF1Gp1UAVd3FnHaW1tRWZmpllvhOjoaDz22GN44oknUFxcHBT1JyIKTNeuXYNarYZKpXIp1Z5cLsfixYtxzz33YGBgQOwpde7cOQwMDLixxJZJJBJMmzbNJCilUChY5yC30Wg0KCwshEwms9lWUFhYCI1Gg5qaGixfvtzu5Tc3N4sNd01NTVAoFBbnS0xMhFarxYYNG1BRUWH38oO5DYeICLhzjdrY2Gg1lVxYWBjy8vI4XpWTXn/9daxfvx6XL1926H0SiQRKpRLV1dWYPn262et6vR6TJk2ymGI3KSkJN27cCIqMJH4ZqDp+/Djuvfdej7/H04K9ktPR0YGcnBybd0tJJBL85S9/EcfJCWSDg4P48MMPoVKpUF9f73TaDcOd9UqlEgsWLEBkZKSbS0rkXaPTB7a3t6Ojo8Opu4D1er1dAS1bqQfDwsIsBn8C7c7g0Z/D+LMYB7Sio6MD7rMFk+7ubrz44ot48803zQYELygoQFlZGdasWeOj0nmOu+o4jY2NuOeeezA4OGjx9ZiYGEyZMgWTJ0/Gfffdh2XLliE/Px/JyclOl52IyB63b9/GwYMHoVKp8Omnn7q0LIVCgeTkZAwMDOD8+fNmqY89JTk52SQoNWPGDI6lSx5nuIHH1vWyIZBkK9g01ntVKpXYq93aPBUVFdiwYYPdyw72NhwiIuBO+6a18aoAIC4ujuNVOegPf/gDnn/++TGHmBgtJCQEX/ziF1FdXW12/hnt/fffxyOPPGI2fc+ePUEzzIBfBqqCxXio5HR2dmLGjBljBqt27NiBf/iHf/BiyTyrs7MT+/btg0qlMmuYdERkZCQefPBBcZyTYIh+EwF3Lky1Wi3a29tx48YNq+kDXWFv6sGhoSEAf08faPyIiooKiv1u9Gez1lsrMjKSlU0Pa2lpgVwuR0JCgq+L4lHuquO88sorWL9+vc15YmNjMXnyZAB3Ale5ubmYM2cOCgsLkZ2dzTzqROQ2IyMjaGhogFqtxuHDh8U6hL10Oh36+vpw+/ZtxMbGIiIiAqGhoV65oSQxMVEMSBnGlgr2cxH5J6VSCbVajYaGBotp97RaLRITE6FQKKyOlWJLeXk5KisrbQahDPVdRwNh46ENh4gIgHizgDVTp07FlClTvFiiwPTrX/8aP/7xj+1OeWsQGhqKJ554Ar/73e8cSoO7YMECfPjhhyb/Hzp0yKF1+zO/DlT19PQgPj7ebHpLSwuOHz+OJ554wiPrraqqwtatW8UxmGQyGcrKyrB27VqHljNeKjmdnZ3Izs622P3QQCKR4M9//jNWrVrlxZJ5R3NzM9RqNfbu3evwgcnYxIkT8dBDD0GpVCItLc2NJSTyH8PDw7h586ZZDyxr3c7dwVrqwcHBQYyMjCA8PBzh4eGQSqUIDw9HTEyMOJB5sLGULnF0YCs+Pt7iuZdcY61OE6jcVcfRarXIysqyWYcAgPj4eJP1hYSEICMjA/n5+cjKyhIbZ1NSUhiMJSKHNTc3Q6VSYe/evXbfVDMyMoL+/n7cvn1bDE5JJBLI5XIkJSV5NJ1ebGysGIwyBKYmTJjA4x/5BUP6v+XLl6OmpsbsdUOgyVraP7VajdLSUqxYsQJbt241e12r1SIjIwPAnbah0eOaV1ZWory83OG0f8D4acMhIgKAixcv2uwBlJ2dzfGqLNDr9XjppZfw4osv2jWmuTGpVIqnnnoKv/nNbxAbG+vwugcGBjB//nycOnUK+fn5+PDDD4MqU5dfBqr27duH0tJSdHd3Q6VSYfHixWbzbN68GWq1GrW1tW7baTQaDUpLSyGTyVBdXS3e/aPValFYWIiysjJ2G7dCq9VixowZ6OjosDqPRCLBn/70J6xevdqLJfMevV6P48ePQ6VS4dChQ1bTGNljxowZJoMrEwW7vr4+i+kDh4eHvVqOkZERDA8PQyKRIDY2FtHR0YiMjER4eDhCQkIwNDSE27dv4/bt21a7yQe61NTUoLypwJeOHz+ON954A5s2bfJ1UdzGXXWckZER/OUvf8GPfvQjtLS02JxXJpNZHCA2KSkJ+fn5yMzMhEwmExtvp02bxkZbIrLKkQwJer0e/f39YkCqr69PHFMqNDQUiYmJSEpKQkxMjNvLGRERYRKQz8nJwdSpU3l8I79WVVUltp8YB4usTTdm6JEFAF1dXRavhw3BsJKSEtTU1IjzGIJU1oJkYxlPbThERIIg4MyZM1bHHed4Vab0ej1++tOf4qWXXnL4Zuvw8HA8/fTT+K//+q+gCiy5m98Fqrq7u5GYmChWvDds2GC1YcfQ3Vuj0bjcA8UwKGdJSQlUKpXJa4bKVEFBARoaGuxe5nir5Gi1WmRnZ6O9vd3qPBKJBH/84x/xta99zYsl876+vj4cOnQIarUaJ06ccHo8q5CQEMyZMwdKpRL33Xdf0PbyILLEOH2g8aOrq8vpfcpVCQkJmDhxIiZOnIj4+HjExMQgLCxMbLi6ffs2ent7xeeGxqxAkpOTg8cff9zXxQgaPT09ePHFF1FdXT1mr6FA4ok6zle+8hX87W9/szmPoTHYkvDwcOTk5CAvLw/x8fGIjo4Wg1bTp08PijSfROQaw5izarUax44ds1ifEAQBAwMD4jm8r68P/f39JvNKJBLEx8cjKSkJ8fHxbju+SKVSZGRkmKTvS0tL41iUFJCam5tRXl5uEgiWy+WoqKiwmBLQYKweVQZarRabNm2CWq0W11FUVISysjKLPbXsMd7acIiIOF7V2HQ6HTZu3Ijf/OY36O/vd+i9kZGRePbZZ1FRUeHR3vbBwu8CVc8//zwqKysB3BmEfN++fTZT5WRmZiI0NBRnz551ab2FhYVobm622HVco9FgyZIlWLt2rUNdx8djJaenpwczZswYc/C4P/7xj/jHf/xHL5XKt9rb27F3716oVCpcuHDB6eVER0dj0aJFUCqVmDVr1rg+SdD4ptPp0NHR4dX0gbaEhoYiKSlJDGAZHobevnq9XgxkjQ5ijZ7m6FgYnlBQUBA0A3E6a+/evVi6dKnbl6tSqfDQQw+5fbm+4Kk6jj3BqgkTJozZ23jatGnIz89HamoqJBIJIiMjMWPGDOTk5CA9PZ2NvkTjiCAI+Oyzz6BSqXDgwAGTG0gEQRB7SxvO1f39/dDr9RaXFR0dDblcDrlcDqlU6lK5JBIJpk+fbpK+T6FQsBGDyIfGYxsOERHHq7JsaGgI3/3ud/H73//e4axZ0dHR+Jd/+Rf89Kc/dbnOOJ74XaCqqKgICoUCFRUVYt5hWzZv3ozy8nJs3rx5zMG4rTH0mFq7dq3NO3YcNV4rOT09PcjOzsb169dtzrdt2zZ885vf9FKpfE8QBJw/fx4qlQr79u1zOI+pseTkZCiVSpSUlCAlJcWNpSQKXP39/WLQ6saNGz5LH2gQGRlpFryaOHGizQao4eFhq4Gs0UEua41ojtDr9WhubkZnZyfkcjkUCgUWLVqE+fPnu7zsQCeXy8WxKt1BIpFg7dq12LJli9uW6UuerOMYp/yxZuLEiUhISBhzWfHx8cjLy0N2drbYK9k4jVZGRgYvHIiC1JUrV6BSqaBWq3Ht2jUAdxocjNP39fX1jZnKNywsTAxORUVFOV2eyZMnm6Tvy8rKQnR0tNPLIyL3G69tOEREHK/q7/r6+vDP//zP2L59u8PtSXFxcdiwYQP+7d/+jRk9nOB3garQ0FB0dXXZPeB4dXU1ysrKUFhYiGPHjjm1zsTERGi1WqhUKpSUlDi1DEvp7jo6OpCfn28ybbxUcnp6epCTkyNeFFpTXV2NZ555xkul8h86nQ719fVQq9X48MMPXWpIz8vLg1KpRHFx8bg5aRDZSxAEdHd3m/W+6uzs9Iv0gYaHXC53qBJjnJbIWspBwzRbXdObm5tNenpOnz4d3/rWt3DPPfe49BmDwbPPPouqqiooFAooFAqz1+vr66HVaq2+btDZ2QmNRoOSkhLIZDK88cYbniy213i6IWf+/Pn46KOPbM6TnJxs93lPKpUiMzMTM2fOhFwuF6eHh4cjMzMTOTk5UCgUzL9OFOB6e3tRV1cHtVqNTz75xCwoZW+dOyQkBDKZDElJSYiNjXU4k4FcLhdT9xl6S9kTXCci32KgiojGK45Xdact+7nnnsMbb7wBnU7n0HtlMhn+/d//Hf/6r//KAJUL/C5QJZfL0dnZaff8hoakxMREp8Z+MIxNBQBNTU3QarViHuXOzk4oFAps3LhxzBzH9l68jKdKTm9vL2bMmDFmsGrr1q1Yu3atl0rlf3p7e/HBBx9ApVLh008/dXo5UqkU8+bNg1KpxNy5c4P65EHkKp1Oh5s3b5oFsHp7e31SntDQUMjlckyaNMli+kBX6PV6swDW7du3ceXKFezcuRNarRbXr19HbGwsIiIi8LOf/QyFhYVu+FSB7c0330RVVRXef/99s9e6u7uRkZGBbdu24YknnhhzWeXl5WhtbcXrr7/uiaL6hKcbcvR6PQoKCvDJJ5/YnC8nJwfh4eEYGBiwO/icnJyMmTNnIj093eQiwhDMysnJQWZmJtNvEQUInU6HQ4cOoaamBh9++CF6enrQ19fnVDrduLg4yOVyyGQyu1OExsbGmowplZOTg6SkJKbpJgpADFQR0Xg21nhV8fHxyMrKCro6TkdHB8rKyvC3v/3N4cw1EydOxE9+8hM899xzHird+OJ3gaoVK1bg2WeftXsMh6ysLDQ3NzsdqKqtrUVpaSkAoKamBlu3bkVNTY049oHh9eXLl6Ompsbqchiosqy3txfZ2dm4evWqzfl++9vfcqcGcO3aNajVaqhUKly5csXp5UilUqSkpGDatGmYNm0apk+fLj5nihEi64zTBxoeHR0dPhs7KiIiwmL6QEMKM1e88cYbOHHiBC5duoTz588jKysLU6dOxezZs/H//X//nxtKH9i6u7uxadMm/PznPzd7beXKlSgpKcGaNWvsXp5cLsfmzZuDJuWtNxpydDodZs6caXMcUolEgvvvvx+RkZFij4n+/n67glZRUVHIy8tDbm6u2bkxNDQUGRkZyM3NRVZWllv2OSJyn8bGRqhUKuzduxcnTpxAT0+P08uKjIwUU/uNFaCOiIgQx7szPKZMmRJ0DTZE4xUDVUQ03nV1daG5udnq68E0XtWVK1fwzDPP4L333nM4486UKVPw85//HF/72tc8VLrxye8CVVVVVaiurrYrjd/GjRtRUVEBiUSCgoICp1L/GcanAu4MIN/Q0GA2T2VlJcrLy20Gqxiosq6vrw/Z2dm4fPmyzfl+85vf4Fvf+paXSuXfDF1uVSoV9u/f79ZeHnK53CRwZXg+ceJEXmQTWSAIAnp6esRxr/whfWB8fLxZ8CopKcnuLuZnz57FG2+8gWvXruHzzz9Hb28vYmNjMXPmTEyePBkrVqxAdna2hz9F4JoxYwYaGhrsTlMM3BmDUyKROJ2m2N94qyFnaGgI2dnZaGtrszpPaGgoKioqcPbsWTQ3N0Ov16O/v18MXI21n0okEqSnp2PmzJlITk42OxeGhIQgPT0dOTk5mDFjhktj1BCR8wRBQGNjI+rq6vDSSy+hq6vL6WUZejLL5XLExMRYnEcqlSIjI8MkKDV9+nS7e1oRUeBhoIqIKPjHq2pra8M3vvEN7N+/3+E2nWnTpuGVV14ZM/MaOcfvAlXAnV5SWVlZqKmpsbjh9/T0oLy8HFVVVRAEARKJBDU1NXal3xnNOFBlLQWdVqtFYmIiAKChoQEFBQVm8zBQZZu9wapf/epX+Od//mcvlSowDA8P4+jRo1CpVDhy5IjDeVLtFRERYbEHVkpKCu8kJ7JAp9Ohs7PTrAfWrVu3fFKekJAQJCUlmQWwRgdThoeHsW3bNjQ3N6OlpQUXLlzAwMAAIiMjkZaWhvT0dCgUCjzzzDNMIWpFaGio1XQI1sjlcnR3dzv8Pn/lzYacvr4+ZGZm2kwlHBYWhmPHjiEkJAS7du3CBx98gJGREej1enE8t/7+/jFTOSQmJmLmzJnIzMy0uP1LJBKkpaWJQStrDdxE5B6CIOD8+fOoq6vDgQMHcP36dQBAa2urQ+nigTv7b0JCAuRyORISEkyu3wz7tiF9X3Z2ttXjABEFLwaqiIiCd7yqxsZGfPOb38Thw4cdfq9CocCvfvUrLFu2zAMlIwO/DFRpNBrxzuPly5dDoVAgMzMTTU1NaG5uRm1tLQCIUc/S0lKnx30wTv1nLQgF/D0QVVFRgQ0bNpi93t7ebjato6MD+fn5JtPGcyWnr68Pubm5uHjxos35fvnLX+Lb3/62l0oVWHp6esQBok+fPu2VdUokEkyaNMliLyyZTMZeWESjDAwMmAWv2tvb/SZ9YFNTE06cOIH29nZ89tlnuH37NuLi4nDr1i3ExMRg1qxZmDJlCh566CEsXLjQJ2X2d1lZWaiursbixYvtmv/48eMoLCyERCJhoMpJPT09UCgUNtM8R0RE4NNPP8WMGTNw8+ZN7N69G++8847YmC0IgklPK1tBq/DwcGRnZyMvLw8JCQkW55FIJEhNTUVubi6ys7MRGxvr2ockIgB39tWWlhYxOGUpHXZ7e/uY1xQGMTExkMvlSExMhFQqBXAnXYtxT6msrCz2liQiBqqIiP4fe8armjFjhpdL5ZyTJ0/im9/8Jurr6x1+b05ODn7729/aPUQRucYvA1UAoFarUVpaiu7ubrOGcOMiuxKkAoDm5mZkZmYCAJqamqBQKCzOl5iYCK1Wiw0bNqCiosKuZbOSY25gYAA5OTm4cOGCzfn+67/+C//yL//ipVIFpkuXLkGtVkOtVot3l3pbbGysxV5YU6ZMERsCiOiO7u5us+DVzZs3vZo+sK+vD0ePHsWtW7fQ1dUl9qSaNm0aOjo6IAgCkpOTxTE31qxZI/Yopr8rLy/HW2+9BY1GM2bKg+7ubmRkZKC7u9vpNMXAnR7gNTU16OzshFarBXDnrq6ysjKn0g7U1tZizZo1aGlpEcfldIQv6jgdHR3IzMy0ORZNdHQ0Tp8+jenTpwO40/Px0KFD2LVrFz799FNxPkEQMDAwgL6+Pty+fdtm0Co1NRX5+fmYNm2azZszUlNTxd4YjqSFJKI7WltbceDAARw4cGDMINTt27fR2Nho9fWwsDAkJSVBLpdj6tSpJkGp7Oxs7qNEZBHbcIiI/i7Qx6s6duwYnnnmGZw8edLh9951113YunUr7r//fg+UjKzx20CVQXl5Od58802THUMmk6GoqAjl5eVYsmSJy+swBKFUKhVKSkpszmOtR5UlrORYNjAwgNzcXJvjTQDAyy+/jHXr1nmpVIFLEAR89tlnUKlUOHDggNWuud4UGhqKqVOnWgxi8Y5zor8bGRnBzZs3vZY+8OTJk7hy5Qq6u7vR0dGB4eFhJCYmIjIyEoODg+js7ER0dDTmz5+P6dOn45577sGKFSs8UpZA1t3djfT0dISGhmLjxo1Yv3692Tw9PT3YtGkTqqqq0NXVBYlEgq1bt+KZZ55xeH1KpRIFBQXYuHGjSVCpvLwclZWVKCgowN69e+0OOBnfpNPV1RUwgSrgzk0aubm5uH37ttV54uLicP78ebPyNTc3Y9euXVCr1RgcHBSnC4KAwcFB3L59G319fVbvGoyLi0NeXh6ys7MRGRlps5zGvTWc+X6JxouLFy/iwIEDqKurG/PawJher8cnn3xicrNHSEgIkpOTMWfOHDz44INib8cJEyZ4ouhEFITYhkNEZOrChQsWs4gZ+ON4VQcPHkRZWRnOnDnj8HsLCwuxbds2zJ492/0FozH5faDKWEtLi5hT3J0MDT22glCGO2ht9boajZUc6+wNVr300ksWGwDJMp1OhwsXLuDixYsmjwsXLpg0yvlSYmKiWfBq+vTpmDRpEtMIEv0/AwMD6OjowI0bN8TgVUdHh0v7cXt7O06ePIne3l5cv35d7E0VERGBiIgICIKAW7duQafTQaFQYObMmZgyZQpKS0uRnZ3txk8XHIzTFAN3bqIx1A+am5vFXk+GapZSqcT777/v8HoMY2la69HtTI/vwsJCaDQaAIEXqALu1MVmzZqFgYEBq/MkJiaiubnZ4mfr7e3Fnj17sHPnTrOUYoaglaGnlaWgVWhoKDIzM5Gfn29XA7ihl2JOTg7kcvnYH5AoyF25ckUMTtm6S3csZ8+ehUQiwaxZs7B48WJ85StfQUZGBuuTROQ0tuEQEZnS6/VobGy0OV5Vfn6+X2RVev/99/FP//RPaGpqcvi98+fPx7Zt25CXl+eBkpG9AipQ5SlarRYZGRkAYDEFTmVlJcrLyx1qBAJYyRnL0NAQcnNz0dLSYnM+R3qxkWWCIKCjo8MkiGV4bmu8D28KDw9HamqqWS+s1NTUMe9cJxovenp6LKYPtJW2zODjjz/GzZs30dXVBa1WC71ej/j4eEilUrFRb2RkBAMDA0hKSkJaWhrS09ORlZWFsrIyT3+0gNTc3IyysjLs3bsXAEwaR42rVyUlJaipqXHqRpuysjJUVVVBoVBYrHArlUqo1WqUlJRApVKNubzy8nIkJSWhvLwcQGAGqgDg888/R0FBgc2x3yZNmoSmpiarPXkFQUB9fT127dqFI0eOmKXhFAQBQ0NDYk8rnU5ncR35+fnIyMhAaGjomOWeOHGiGLRiLw8aT65duyam9Tt37pxLy5JKpSgsLMTChQuxYMECxMTEuKmURDTe+bp+Q0Tkj/x9vKr//d//xb/+67+OOczMaBKJBMXFxfj9738vxgXIt3wSqFq5ciW2bdvmla6BK1euRHV19Zh5yDUaDQoLC8XGJEOjjSFItXz5ctTU1Di0blZyxjY0NIS8vLwx76bctGkTnn/+eS+Vanzp6+szC15dunQJly5dstgo5wuTJk2y2AsrMTGRd83SuDcyMoLOzk6zAJbxOD6Dg4M4ePAg+vr6cPXqVQwODoq9qcLCwsT5dDodwsPDAdxJczZ79mwkJSXhe9/7HtN22qBWq1FRUSEGrIC/pykuKyvDk08+6fSytVotNm3ahJUrV6KgoMDsdUd6VBnKqVKpxGNnoAaqAKC+vh7333+/zXNVamoqzp07N+YND1evXsU777yD3bt3o7e31+I8xj2tRq8zMjISubm5yM3NtXtfkcvlyMnJQW5urtl3SRQM2tvbxeCUM6lXjIWEhKCgoACLFi3CAw88wHMSEXmEP9RviIj80VjjVaWkpGDy5MleLBGwY8cOfP/738fVq1cdep9EIsHDDz+M6upqpKameqh05AyfBKqam5uxcuVK7Nu3z6PBqueeew4KhQLf//737Zrf0BikVqvFnc/QyOTMQOWs5NhnaGgI+fn5Y3bN/I//+A/84Ac/8FKpaGRkBNevXzfrhXXhwgWPjZ/jqOjoaJPgleGRkpLiF92OiXxpcHDQJHD129/+VhwPy9CjKjk52awXUH9/P8LCwpCZmYmMjAwkJibipz/9qQ8/CVlTW1uL0tJSyGQyiz3CjWm1WhQWFqKhoQEymcyhQJWlnOQdHR3Iz883meaLOs7BgwexePFim70KMzMzcebMGbvOC4ODg9i/fz927tyJ8+fPW51vaGhIDFoNDw+L0yUSCdLS0pCfn48pU6bYfTOFTCYTe1r584DERGO5efMmDh48iAMHDuDzzz93aVkSiQSzZ89GcXExFixY4Pb070REo7ENh4jIurHGq8rJyfHKzUTbtm3Dv/3bv9ksiyUhISF47LHHsHXrVt4o6Kd8lvqvqqoKmzdvhlqtRlpamtuX/+yzz6K5uRl79uxx+7LtxUqO/YaGhjBr1qwxU4H87Gc/ww9/+EMvlYqs6e7uNuuFdfHiRVy9etUsdZIvhISEYMqUKRZ7YfnbII9E3jA8PIy3334b+/fvx+XLl/Hpp59ieHgYcXFxiIyMxNDQEARBQG9vL8LCwhAdHY2cnBxMnDgRixcvxpe+9CWTnlfke4axqxQKBVQq1ZjjZxYWFqKiogIlJSUA4FCgyt5gi6/qOO+++y6+8IUv2Dz/zJw5EydPnkRISIhdyxQEAadPn8auXbtw4MABm722DEGrvr4+k1SEMpkM+fn5yMrKEnsq2iM+Pl4MWk2dOpU9h8nvdXV14YMPPkBdXR0+++wzl+qCEokEd911F4qLi/HAAw8gMTHRjSUlIrKNbThERNb5crwqvV6PX/3qV/jJT36Crq4uh94bGhqK0tJSbNmyxalsIuQ9Ph2jqrKyEhs3bkR5eTlefPFFtyzzxIkTWLNmDeRyuVODlrsTKzmO0el0mDlzJs6ePWtzvp/85Cf40Y9+5KVSkSOGhoZw5coVi0Gs/v5+XxcPAJCQkGCxF9bkyZPtbsAkCkSfffYZ3n77bTQ0NODatWu4fv06oqKikJmZCalUit7eXjQ1NSEsLAzp6elITk5GTk4OvvCFL2DWrFm+Lr7X+WOa4rKyMpNe36PTFVtjGI/KODVgMAWqgDu9y1asWGGzgbyoqAhHjhxx+Fjf1dWF3bt345133kFHR4fNeYeHh8WeVoagVVhYGGbMmIH8/HyHL4xiY2PFoFVqaiqDVuQ3uru7cejQIdTV1eGTTz5x+UalmTNnori4GA8++CCSkpLcVEoiIsewDYeIyDZvj1el1+tRUVGBn//85ybDG9hDKpVi9erV+NWvfsW00QHCp4Eq4E6w6vnnnxcHa3/yySeRnp7u0DJOnDgBtVqN119/HRqNBmvXrsWWLVs8U2AHsJLjOJ1Oh1mzZqGxsdHmfC+88AJ+/OMfe6lU5CpBEHDz5k2LASxHu+p6SlhYGFJSUsx6YKWmpiIqKsrXxSNymVarxfvvv4///d//hVarxZUrVzA8PAyZTIbp06fjwoUL6O3tRXx8PNLS0jBx4kQ8/vjjuPfee8flXUf+mqbYQK1Wo6ysDJ2dnaioqMDatWutzldeXo6GhgaT6cEWqAKA//mf/8HXv/51m/MUFxdj//79Ti1/ZGQEH374IXbu3IlPPvlkzPl1Oh1u376Nvr4+DA4OAriTuz0vLw/Tp093OGBm6OmYnZ3t1PuJXHXr1i0cOnQIBw4cwPHjx22m3LRHbm4uiouLsXDhQl4fEZFfYBsOEdHYvDFelV6vx49//GP84he/wO3btx16b3h4OL75zW/ilVdeGXOsYvIvPg9UAXcaUUpLS8XIqGEAcplMBoVCYXZX3c2bN6HVatHc3Ay1Wg0A4l18NTU1Lg1a7k6s5DhHp9PhrrvuGnPQ5X//93/nuClBoK+vD5cvXzYLYl26dMlk3A9fmjhxolnwatq0aZgwYQLvbqeA0dnZiQMHDqChoQGnTp1CV1cXLl++jIiICMhkMty6dQuCICAzMxMTJ05EUVERiouL3Xo3VKAJhDTFiYmJ0Gq12Lp1q1mwavS4VMaCMVAFAL/+9a/x7W9/2+Y8X/jCF/DOO++4tJ7W1lbs2rULKpUKAwMDY86v0+nE9IADAwOIjY1FXl4ecnJynLp4ioqKwowZM5CTk4O0tDSEhoY68zGIxnT79m0cPnxYPH9Yu3vWXjNmzEBxcTEWLVqE5ORkN5WSiMg92IZDRGQfT41XpdPpsGHDBmzZssWu6yxjkZGR+Na3voWKigqOWx+g/CJQZVBeXo7NmzcDsL9RxFD8tWvXoqKiwq8G2WUlx3k6nQ533303Tp8+bXO+H/7wh/jZz37mpVKRN+n1ely/ft2sB9aFCxfQ3d3t6+IBuNNQmJqaatYLa+rUqQ6NR0LkaX19fWhsbER/fz/OnTuHuro63LhxAzdu3EBPT4/Ya3DChAmYOnUqUlJS8JWvfAX33HMPIiIifFx63/L3NMWVlZViar/RQSelUomysjIsX77c7H2OBKosXYB0dHQgPz/fZJq/1HF+/vOfY+PGjTbnWblyJf7617+6vK7bt29DpVJh165duHjxol3vGRkZEXtaDQ0NITMzE3l5eU4P6BsRESEGrdLT03lRRi7r6+vDRx99hAMHDuDYsWM2x2izh0KhEINTU6dOdVMpiYjcj204RET20ev1OHPmjNVhPhwdr2pgYADr1q3D73//e5Nxf+0RExOD7373u/jJT37CrBMBzq8CVcCdfOdbt27FG2+8AY1GY3PegoIClJSUYOPGjX4VoDJgJcc1Op0Os2fPxueff25zvo0bN7qt8ZACQ09Pjxi4unTpkhjIunLlistpaNxBIpFgypQpZr2wpk+fjvj4ePbCIq8aHh7G6dOnxR6KN27cwGeffYajR49Cq9Xi8uXLCA8Ph1QqRWZmJpKSklBSUoL77ruPDYr/jz+nKVar1VAqlQBg0quqsrISTU1N2Lp1q8X3ORKossTf6zg/+MEPxqwbPPPMM6iurnbL+gRBwPHjx7Fz50589NFHdo/XMzIyIva0io2NRX5+PhQKhdM9pMLDw5GVlYWcnBxkZGQgLCzMqeXQ+DMwMICPP/4YdXV1OHr0qMu92tPT07Fo0SIsWrQI06ZNc1MpiYg8y9/rN0RE/mRwcBCnTp2y2g5nz3hVvb29+Pa3v40dO3Y4XP+Mj4/H888/j/LycgaogoTfBapGO378ODo7O8XclwqFAnK5HAqFwi+DU8ZYyXGdXq/H7Nmz8emnn9qcb8OGDSaDxNP4pNPpcOXKFYu9sPr6+nxdPABAXFycWQ+sadOmYfLkyUzdRG4nCAIaGxtNcjrr9Xo0Nzfj0KFDaGtrw8DAAK5du4Zp06YhOTkZ2dnZ+MIXvoCZM2eysmfEF2mKDan7ZDIZ9u7dazGgpNFoUFhYCMD0XJiZmWkzb7gljlQJA6GO853vfAe/+tWvbM7z3e9+F6+88opb13v9+nW888472L17t0MD/o6MjIh3JE6bNg3Z2dkujY8WFhYGhUKBnJwcZGZmsqcvmRkcHMTRo0dx4MABfPzxx+JYas6aNm2aGJxyNJhPROQPAqF+Q0TkTzo7O9HS0mL1dWvjVWm1Wjz33HOoqalxOLV0YmIifvzjH+Nf/uVfHC4v+Te/D1QFMlZy3EOv1+Pee+/FyZMnbc73/e9/H5WVlV4qFQUSQRDQ1dVlFry6dOkSrl+/7uviAQCkUilSUlIsjoUVExPj6+JRgGptbcXNmzfNpt+6dQtnzpxBfX09+vr6cPPmTSQlJWHixIl4/PHHce+99zrVy2Y88Gaa4traWpSWlgIAVCoVSkpKbM5TU1NjMc3faFqtFomJiQCCt0eVwdNPP40//vGPNufx1JiXQ0NDOHDgAHbu3InGxkaH3qvX69Hf349p06Zh6tSpSE5Odqk3rlQqRUZGBnJycpCVlTXuU3qOZ0NDQ6ivr8eBAwfw0UcfWU3XYq+pU6di0aJFKC4uRkZGBnuNE1FAC5T6DRGRP7E1XpVEIkF2drY4XlVHRwfWrFmDXbt2OZwRadKkSfjZz35mNjYzBQ8GqjyIlRz30ev1KCwsxIkTJ2zOt27dOrz88sveKRQFhYGBAVy+fNliEMvRvLieIpfLLfbCmjhxIhuEyKobN27YHDOnu7sbTU1NqK+vh1arFXsIFRcXj9k9f7zzVppiQ0Bp+fLlqKmpsThPaWkpamtroVAo0NTUZNdym5ubkZmZCSD4A1XA378jWyorK/H973/fY2U4c+YMdu3ahbq6OodTWuj1eiQkJCAnJwcJCQkuH/dDQkLEoNWMGTMQGRnp0vLI/+l0OjQ0NKCurg4ffvihy73Mk5OTxTGnsrKyWBchoqARSPUbIiJ/Yc94VTKZDGvXrsWePXscyuQBAFOmTMHmzZuxatUqdxQ3oOn1ehw7dgy7du3CRx99hDlz5gRVhjEGqjyIlRz30uv1KCoqwvHjx23O54k0PjT+CIKAGzdumAWwLl68iK6uLl8XDwAQERFhFryaNm0aUlJSeLf8ONfT04Nz585ZfT06OhppaWk4deoUjh07hvPnzyMrKwtz5szBXXfdxe3HQZ5MU1xbW4tNmzZh48aNKCkpEYNKWq0WmzZtQmVlJRQKBVQqFRQKhV3LNB7XylpPrbEEWh3n0UcfxXvvvWdznt/+9rd47rnnPFqO7u5uvPvuu3j77bdx48YNh98fHh6Oe++9F+np6ejt7XU5VVtISAjS0tKQnZ2N7OxsREdHu7Q88h86nQ4nTpxAXV0dDh8+jN7eXpeWN3HiRDGtX05ODoNTRBSUAq1+Q0TkLwYGBnD69GmzXlKXL1/Gz372M9TX1zu8zLS0NPziF7/AV77yFXcVM6AMDAzg/fffx/vvv4+jR4+iubkZWq3WJNA3bdo0XLhwwYeldC8GqjyIlRz30+v1mDt3LhoaGmzO96//+q/4xS9+4aVS0XjT29uLS5cumQWxrly54nBuXU+QSCSYNGkSpk+fjsTERMhkMmRlZSEzMxOpqakcdyjIDQ4O4vTp01a3xbCwMOTl5SEsLAyXL1/GtWvXxNemTJmCqVOnequoZKfm5mZs3boVarUaWq0WnZ2dYiCstLTU7tQHiYmJYu85Y4ZpjgThA7GOs3DhQnzwwQc25/nzn/+M1atXe7wser0eH3/8MXbu3Dlmrzxr7rrrLsydOxcxMTFoampyOWglkUgwbdo05ObmYsaMGWJ6DgocIyMjOHnyJOrq6nDo0CGHxkizRC6Xi8Gp/Px8BqeIKOgFYv2GiMhfGI9X1dLSgp/+9Kf49NNPHV5OVlYWfv3rX+Phhx92dxH91o0bN/C3v/0N+/fvx4kTJ3Dx4kWTscatCQsL85tsUO7AQJUHsZLjGXq9HvPmzRszGv/tb38bv/zlL71UKqI7dy9fvXrVrAfWxYsXXb6T2VlXr17F1atXxf8lEgkiIiIQFRWFmJgYxMTEIC4uDjKZDAkJCUhMTIRcLsfEiRMxceJETJ48GTKZDDExMYiNjUVMTAxCQ0N98llobCMjIzhz5gwGBgYsvi6RSJCTkyOOe6bT6VBRUYGGhgYUFhaivLwcUqnUm0WmABWIdRy9Xo85c+bYDAxJJBK8+eabXr1r7+LFi9i1axf27NnjVEq2iRMn4tFHH8Vdd92Fa9eu4ezZsy6POwQAqampyMnJQXZ2NuLj411eHnmGXq/HZ599hrq6OnzwwQfQarUuLU8mk2HhwoUoLi7GrFmzGJwionElEOs3RET+ZPfu3Vi/fj3OnDnj8Htzc3OxdetWLFy40AMl8x+ff/45du3ahYMHD+LUqVO4du2aS8Gmq1evYvLkyW4soe8wUOVBrOR4jl6vx3333Ydjx47ZnO9b3/oWfvOb33ipVESWCYKA7u5us+DVhQsXcP36dYfz8zri0qVLTqWXMhYSEgKpVCo+DEGuuLg4MciVmJiIxMREJCUlYcKECYiPjxcDW8Z/Y2NjGQjxEEEQ0NTUhO7ubqvzpKenIykpSfz/1VdfxV/+8hfx/6eeegpPP/20R8tJwSFQ6zh6vR6zZs3C6dOnrc4TEhKC9957T0yP6C19fX3Yu3cvdu7ciba2NoffL5VKsXDhQnzpS19CbGwszp49i7Nnz9p1J95Ypk6dipycHHGcLPItQRBw6tQp1NXV4eDBg+js7HRpefHx8XjwwQdRXFyMu+++mz2viWjcCtT6DRGRrx05cgRr1qxxqgfVPffcg+rqasyZM8cDJfMdnU6HgwcP4v/+7/9w5MgRnD17Fjdv3jRLj+iqrVu32p1lxd8xUOVBrOR4ll6vx/z583HkyBGb8z333HP47W9/66VSETlmcHAQly9fttgLy9U0TgDQ2trqcgOWM4wDW8aP0NBQREdHIy4uDvHx8WKASyaTiYEsS8Et42nh4eG8w9uC0Wn8RktOTkZqaqr4/6VLl7BmzRrodDp0dHRgwoQJkEqlqK6uNpmPyJJAruPodDpkZ2eLaSksCQ0NxYEDB7BgwQIvluwOQRBw8uRJ7Ny5E4cPH3bqQmbGjBl47LHHUFxcjI6ODjQ2NqKxsRG3bt1yuXzJycnIzc1FdnY25HK5y8sj+wiCgMbGRjE41d7e7tLyYmNj8cADD6C4uBj33HMPbyIhIkJg12+IiHyhrq4Ozz77LBobGx1+b1FREX7/+9/j7rvv9kDJvKu3txdvv/02VCoVGhoa0Nra6nIabnutXLkSf/3rX72yLk9joMqDWMnxPL1ejwceeAAfffSRzfnKysrwu9/9zkulInKdIAhob28Xg1fGY2LdvHnT7uWM1cPGX0gkEqvBrdGPyMhIyGQyxMXFjRnUMp5m+D8yMjLoAl3GuaAtiY+PR1ZWlvi5BUHAxo0b0dDQgJ6eHpw/fx5ZWVmIj49HUVERXnzxxaD7jsi9Ar2OMzAwgMzMTFy5csXqPFKpFEeOHEFBQYEXS2aqvb0d//d//4f/+7//cyqlW1xcHB555BF86UtfwuTJk3H16lUxaOWOc8PEiRPFnlYTJkxweXlkShAEnD9/HnV1dThw4ACuX7/u0vKio6OxYMECFBcXo6CggMEpIqJRAr1+Q0TkLbt378a3v/1tNDc3O/ze2bNn49e//rVPbgp0hwsXLmDnzp3Yv38/Pv30U1y6dMnq8AueJJVKMXHiRDzzzDP46U9/6vX1ewIDVR7ESo536PV6LFy4EIcPH7Y53zPPPIPq6movlYrIc/r6+iz2wLp8+TJ0Op3JvGfPnvXZ+FieFhoaandwy9CbC7iT1stSAMveadHR0X4VxOnr60NjY6PVXhcRERHIy8szGVvs0KFD+MlPfiKmjxocHERERATy8/MhkUjwwgsvBGylkbwjGOo4vb29UCgUNnumhIeH48SJE8jLy/NiycwNDw/jgw8+wM6dO3Hq1CmH3y+RSDB37lx8+ctfRlFRESQSCa5duyYGrbq6ulwuY1JSkhi0Gr1tkP0EQUBLS4sYnLIVTLVHVFQU5s+fj0WLFqGoqAhhYWFuKikRUfAJhvoNEZEnvfnmm/jud7+LixcvOvzeOXPm4Ec/+hGmTJkCiUSC7OxsxMbGeqCU7qHX66HRaLBr1y58+OGHOH36NG7cuGHW7uYNkZGRSElJwV133YXi4mI8/vjjSEtL83o5PM3vAlWbN2/G888/j8zMTJw9e9bXxXEJKzneo9frUVxcjA8++MDmfN/85jexbds2L5WKyLtGRkZw7do1k15Yf/jDH3D9+nWMjIz4ung+Z+i1NTrAFRYWZhLMCgsLE+exNE6HRCIRA1eWAlpj9fCKiYlx2/gfw8PDOH36NIaHhy2+HhoaitzcXERGRorTBgYG8I1vfAPt7e24evUqrl69Kr42ZcoUTJkyBZMmTcKrr76KiIgIt5STgk+w1HE6OzuRmZlps7dSVFQUPv/8c2RkZHivYDacO3cOu3btwr59+5wadHfq1Kl47LHH8PDDD4sXhu3t7Thz5gwaGxsd6rVrTWJiohi0CpaBfT2ttbUVBw4cQF1dHS5duuTSsiIiInD//fdj0aJFmDNnDo/lRER2Cpb6DRGRu/3pT39CeXm5zeEGrFmwYAF++MMfmh1Lw8PDkZeX5xe9/IeGhrBnzx68//77OHLkCJqamtDV1eXRMeWtiY+PR1paGgoLC1FSUoIvfelLiI+P93o5fMHvAlVyuRxarRYSiQRdXV0B/UOwkuN9xcXFOHDggM15vv71r+MPf/iDl0pE5Fs6nQ63b9/G1atX0dbWhhs3bqCjowMdHR3o6uqCVquFVqtFT08Pent7cfv2bfT392NkZAQ6nc7tgzwGmpCQEId6bdlbwYqOjrYYwLIV8DLu2SWVSsXxSm7fvm11PVlZWUhISDCZ9uqrr+Ivf/kLhoaGcOrUKej1eiQmJqKrqwshISHIz89HeHg4nnrqKTz99NMufX8UvIKpjnPlyhXk5OTY7H0aGxuLxsZGTJ061Ysls62npwfvvfce3n77bacuGCMiIrBkyRJ8+ctfhkKhEKd3dHTg7NmzOHPmjMvjIAF3LrQMY1pNnTrVr3qk+trFixfF4FRbW5tLywoPD8fcuXNRXFyMefPmmdygQETkrH379uGhhx7ydTG8JpjqN0RE7rB161b88Ic/REdHh0PvCwkJweOPP47//u//Rnt7u9W2pYSEBGRlZbmjqHbr6OjAzp07sW/fPpw4cQJtbW0221U8JSQkBElJSZgxYwbmzZuHL3zhC1i0aJFfBO58xe8CVZmZmWhtbcXatWuxZcsWXxfHJazk+MbixYtRV1dnc55//Md/xB//+EevlIco0Oj1ety6dQvd3d3o6urCjRs3cP36dTHA1dHRYRLgunXrFgYGBjAyMmLxMd44GthypndVREQEJBIJQkNDERUVJT6io6PF56mpqZg2bZpJkEur1eJ73/se9Hq9OH5ZXFwcsrKycP78edy6dQsJCQnIzMyEVCrFtm3bkJKS4oFviQJdsNVx2trakJeXh/7+fqvzyGQyNDU1QS6Xe7FkY9Pr9Th69Ch27dqFY8eOObWMu+66C4899hgeeOABkwujrq4uMT2gM8Gw0eLi4pCdnY3c3FykpKSMy6DVlStXxOCUMzn9jUmlUsydOxeLFi3Cfffdh+joaDeVkojojjlz5jh9bglEwVa/ISJyhl6vx3/913/hZz/7mcPj5IaGhmLlypXYsmWL2PlkrDG1U1NTkZyc7EqRrWpsbMTOnTtx4MABfP7557h69apTWSlcFRYWhsmTJyM/Px8PPvggvvzlL2PWrFleL4e/87tAVW1tLVasWAGNRoPZs2fb/b6NGzdi06ZNniuYE1jJ8Z0lS5Zg3759Nuf56le/ij/96U9eKhFRcBscHERPTw+6u7vNHu3t7ejo6MDNmzfFXlzd3d0YHh62GtwyfvjZacrtDCkJHXkMDw/bHKwzLCwMUVFRZtPPnTuHW7duYWRkBP39/ZBIJJDL5QgPD4cgCOjo6BB7VcXHx6OoqAgvvvjiuGxMtiWY0hQ7KxjrOKdPn8a9996LwcFBq/NMmDABTU1Nftvj//Lly3j77bfx3nvvOXVXoFwuxxe+8AV84QtfQFJSkslr3d3dYtDK1XGTACAmJgbZ2dnIycnBtGnT3JYS1R9du3YNBw4cwIEDB3Du3DmXliWVSlFYWIhFixZh/vz5iImJcVMpiYhMPf/889i8efO4uvEsGOs3RET20uv1ePHFF1FZWYlbt2459N6wsDB87Wtfwy9/+UuLN0+1tbVZ7ZUlkUiQk5PjUr1Wr9fj0KFDeOedd/Dxxx+LKc19cQ6Ljo7GtGnTMHv2bCxevBhf/vKXmQ7dTn4XqAKAyspKNDQ04PXXX7f7Pf54pw8rOb5VUlKCvXv32pxn1apV2L59u5dKREQGgiDg9u3bYjCrp6dHDGAZnhv+dnV14ebNm2KAxdpDp9ONi0CXIAgQBEEcU8v4YRhzKyYmxmzsLa1WK96939vbC71ej4iICJOxSwYGBiAIAmQyGfLz8yGRSPDCCy9gwYIFvvq4fimY0hQ7K1jrOBqNBvPmzbM5QO7UqVPR1NTk16nVBgYGsG/fPuzcudOpXjuhoaF48MEH8dhjj2HWrFlmweqenh6cO3cOZ86ccXk8JeDOOGCGoFVaWlpQBK3a29vF4NSZM2dcWlZISAgKCgqwaNEiPPDAA3496DQRBb5t27ahvLxcvIuegarAr98QEdmi0+nwox/9CP/93/+Nvr4+h94bERGBNWvW4OWXX0Z4eLjV+fR6Pc6cOWM1g4Uj41X19fXhnXfegUqlQn19PVpaWtDd3e1Qud1BIpFAJpNBoVCgqKgIDz/8MB5++GFmOXCB3wWqDL1g3njjDTQ0NGDjxo2QyWRW59dqtVCpVKiqqvK7ChQrOb63dOlSqFQqm/P8wz/8A1577TUvlYiInKXT6Sz22jIObHV3d5sEuQzjbNkb1LL08KdxugRBGPNcFxoaarEHVF9fHwRBEL8PiUSCyMhISCQSk4dOp0NERASmTJkiPv7nf/6HvaqMBFOaYmcFcx3n8OHDWLRokc19LT09HefOnfP7/OGCIOCzzz7Drl278MEHHzhVV1YoFHjsscewZMkSi8G53t5enDt3Do2Njbhw4YLLNwdERERgxowZyM3NRXp6OkJDQ11anjfdvHkTBw8eFFOLuEIikWD27NlicGr0eINERO7U09ODTZs2oaqqClqtVjyWSyQSv2tn8aRgrt8QEY02NDSE8vJy/O53v7OZscWSqKgo/PM//zNefPFFu6+JBgYGcPr0aYfGq7p06RJ27dqFffv24eTJk7h06ZLNdO2eEhoaiokTJyI3Nxf3338/vvSlL2HevHlBcYOdP/G7QNXSpUvH7AVjjb9VoFjJ8Q+PPPII3n//fZvzrFy5En/961+9VCIi8gZBENDf3281JaGlINetW7fMGln1ej30er3dwa3R87kr0OVKkEqv16O3txfA38+VEonEYqXK0MsqNDQUd9999//P3t3HNV2v/wN/fbbBuGcbiOAdskHibQrYnWbegNrN0UzQ053VScE6pxtNQTp1slOpYKl5zrcS7XSyOqmQlZmVgHrUslLwHlHcAEG5Z4ONwWA3vz/8bQdkG2xsYxvX8/HgkWzvz2cXJvDe+3q/rwsMw2DXrl3dyoANZO5Uptha7j7Hyc3Nxdy5c81+/0ZHR+PixYsu8+akoaEBBw4cwP79+9HY2Gjx9b6+vpg7dy7mzZuHIUOGGB2jVCoNSavy8vI+//zjcrkQiUQYNWoUhEKhUyYGpVIpjh07hiNHjuDChQt9StQxDIPx48dj+vTpmDp1Kvh8vg0jJYSQ7srKypCRkYGsrCwAN+eb+rmk/s/Ots5iT+4+vyGEEOBmwujll1/GJ598YnG/Jl9fX6xatQp/+9vfrHofZKpflVarRUlJCU6fPo2zZ8+iqKgItbW16OjosPg1+orL5WLo0KEYN24c7rvvPsyfPx8ikcjhcQxETpeo0i/+MAxj0Rs9Z5xA0STHeTzwwAP44YcfzI5JTExEdna2gyIihDgjjUYDhUJhMrFlLMllrp8N8L8EkyXlCo2VL9RqtWZ/L7JYLLMTRX25v873MXZSgc1mw9fXl05U9cBdyhRbayDMcb7++mssXLjQ7PfdpEmTcOrUKZdJVgE3T6ceP34c+/btw/nz5626x+TJkzFv3jzccccdJr/2trY2Q9KqrKysz/N0Dw8PDBs2DFwuFx4eHvDw8ICnp6fhz8Y+N/a4LX6WNTU14dixY/jvf/+Ls2fP9vkU2dixY3Hfffdh2rRptCmAEOIQhw4dQkZGBvLy8gD8Lyml/3kmFArB4/Fw+vRpp1tnsaeBML8hhAxcCoUCf/7zn/Gf//zHbKlzYwIDA/Hqq69i1apVfX7vU1JSgh9++AEnTpzAhQsXUFFR0S+l+wDA398f4eHhiImJwaxZszBv3jyzld2IfTldogq4udgmFAqRmJjY45u1hoYGFBQU4NChQ043gaJJjnN56KGH8P3335sd88gjj+Crr75yUESEEHegUqm6nczq6fSWJacM9CfDlEqlIdGkP6ml/6/+dJSpJBgAdHR0GI7ImzpVpdVqweFwEBQURD2qzHCnMsXWGihznM8//xxPPvmk2TFTp07FsWPHHBSRbUkkEnz77bfIz8/vMeluTGhoKObNm4e5c+fC39/f5DiVSgWxWIzi4mKUlpZa/MbYlvS9/CxJbnl4eKCjowNnz55FQUEBioqKAPzvZ2jn8qm9FR0djenTp2PatGlu931DCHFeO3bsQEZGhqF/4a3LQYmJiUhPT8ekSZMAAJGRkbh69arD4+wvA2V+QwgZWGQyGZKTk7F3716L348KBAKsXbsWL7zwgtWvvW/fPuTl5aGwsBDl5eWGai+OxDAMBAIBoqKicMcdd+CBBx7AjBkzzPbVIo7nlImqRYsWYfny5Zg5c2avr3HGCRRNcpzP/PnzsW/fPrNjFixYgL179zooIkLIQKPT6dDS0gKZTGa0/OCtya3a2lqzZbo4HA68vb1NLpDqT2Op1WpIJBLI5XKo1Wq0tbWBYRh4enqCYRhotVq0t7fD09MTEyZMQEBAACZPnox33nmHTlPdwp3KFFtrIM1xtm3bhuXLl5sdM2fOHPz4448Oisj2FAoFfvrpJ+zbtw83btyw+HpPT0/MnDkT8+bNQ1RUlNmx7e3tkEgkuHz5MsRicb+U8+it9vZ2lJWVobS0FJWVlT2enNInqzonrzr/ediwYZg0aRJiY2MxePBgi06G0c9hQoi1bu0/BXRNUDEMg9WrVyM9Pb1bP7xFixZhz549jgy3Xw2k+Q0hxP3V1tZi2bJl2L9/v8UluQcPHox33nkHzz77bK+vEYvF+Oabb3DkyBFcvHgRN27csGozXF95eHhg8ODBGD16NKZOnYp58+ZZVLKf9B+nTFQdOnQIAoHAon9EGzduxOrVq+0XlBVokuOcHn74YXz77bdmx8yfPx/ffPONYwIihBATlEolLl++jPb2drS0tEAul6OlpQUKhQIKhQIqlQq+vr6Qy+XdklzGTizom5fqdDoolUqo1WpDoqu1tRVqtRpBQUEYP348OBwOduzYgaFDh/bDV+7c3KlMsbUG2hxn48aNSE1NNTtm4cKFyMnJcVBE9qHT6XDq1Cl8++23+P33360qaTdmzBjMnz8f06ZN67GnVEdHB0pLS3H58mVcvXrV4hr59tDe3o5r165BIpGgsrKyz322BAIBhEIhhEIhAgICrL5P55Ngpk6B9SbpRUkwQgYOY/2nOktMTIRQKMTGjRvdZn7SVwNtfkMIcU+VlZV49tlnkZuba/F8fujQoXjvvfewePFik2O0Wi1OnDiB/fv348SJE7h8+TLq6ur65XeJt7c3hg0bhttvvx0zZszAww8/bLKfLnF+Tpeo2rhxI9asWQORSIQrV670dzh9QpMc5/XII4/g66+/Njtm3rx5PSa0CCHEXjo6OnDp0iWTpw3YbDaio6Ph5eXV7Tl9uUBjZQe///57/Pzzz1CpVKitrYVWq4WHhwdUKhUYhsHo0aMREhKCxx57DM8884y9v0yX5S5liq01EOc4a9euxZtvvml2zNNPP41PPvnEQRHZV1VVFb777jv88MMPVpXn4PF4ePDBB/Hggw/26t+FWq1GWVkZLl++jJKSEofuvuzo6EBFRQXEYjEqKir6nJzi8/kQCoWIiIhwiRr3vUmCGXuckmCEOCdj/af0eDwekpOTDaenvvrqKyxatMht5id9NRDnN4QQ9yEWi/Hss8/i6NGjFieowsPD8f7772P+/PldHlcqlfjhhx+Qm5uLkydPQiKRoKmpqc89Wq0RGBgIoVCI2NhYzJkzB3PnzoWfn5/D4yD243SJKoFAAJlMBoZhIJVK+7TzsL/RJMe5JSYm9tiP6sEHH8T+/fsdFBEhhNyk0+lw+fJltLS0mBwTGRnZrTxLb7S1teFPf/oT6urqUFVVhaqqKsNzISEhGDJkCEJDQ/Gvf/0LXC7XqvgHAncpU2ytgTrHWblyJTZv3mx2zAsvvICtW7c6KCL7U6lUOHz4ML799lur/v2yWCxMmTIF8+fPx4QJE3qVuNBoNCgvLzckrfT99WxJrVajoqICEokEFRUVfe6bpX/jLBQKwefzbRSl6+spCdbbxNitn3M4HCiVSvj6+lIyjJD/z1z/qZiYGKSkpGDZsmVdrqFEVVcDdX5DCHFtFy9exLPPPovffvvN4mujoqLwf//3f0hISEB1dbWhf+25c+dQUVEBpVJph4jNY7FY4PF4CA8Px8SJE7FkyRJMmzatS39t4p7M1+PoB3w+H01NTUhOTnbpJBVxfvrSTdnZ2SbHfP/993jggQdw4MABB0ZGCBnoysvLzSaphg4dalWSCgC8vLzw/PPP480330RoaCgaGxuhUqnA5XIxdOhQMAyD559/npJUPVi+fDkEAoFF16SkpNgpGuIomzZtgkKhwPbt202O+cc//gE/Pz+sW7fOgZHZD5fLxdy5czFnzhxcunQJ3377LY4ePdrrxI5Wq8WxY8dw7NgxjBw5EvPmzUN8fDy8vb1NXsNmsw1Jnzlz5qCiogLXr19HW1sbOjo60N7ejo6ODsOHsc+N0Wg0qKyshEQiQXl5eZ+TUwEBAYiIiIBIJAKfz6eEiRFqtRpqtdrmyca2tjb8/vvv4HA48PLyQkBAAAQCAYKCghASEoKQkBCEhYVh8ODB8Pf3h6+vLy1uELe3Z88eiMViAP/rmZeYmIg1a9Zg0qRJ/RwdIYQQWyssLMSyZctQWFho8bUikQjTp083lAmsrq7ul96xXC4XgwcPxogRIxATE4Np06Zh5MiRXcbweDyaxw0QTneiSp88KCwstKhHVXp6OtavX2+/wKxAu3Fcwx//+Efs3r3b7BhXb5JOCHEdtbW1qKioMPm8QCBAREREn15Dp9MhPT0dBQUFaG5uxtWrVxEZGYmAgADExcVh3bp1tOBqhjuVKbbWQJ/jPProo9i1a5fZMevWrUN6erqDInIsqVSKAwcOYP/+/aivr7f4eh8fH8yePRvz5s3D8OHD7RDhzQRJR0cHWltbcfLkSRw9ehS///47lEoldDodtFotdDpdlz/35jFfX19DEi0oKIh+VvaTpqYmnD59usdxDMPAy8sL3t7e4PF4EAgECA4OxqBBgzB48GAIBAL4+fnB19cXfn5+8PPzo4UQ4tJKS0uxYcMGw4aKlJQULF++HLfffrvR8XSiqquBPr8hhLiGn3/+GcuXL8eFCxcsvpbNZvfbz3w/Pz+MGDECkyZNwqxZszB//nzD5s+GhgaUlZWZvHb48OHdfj4T9+N0iSoAyMzMREFBQY/Jg84mT56MkydP2jEqy9Ekx3U89thj+PLLL82OSUhIwMGDBx0UESFkIGpubkZJSYnJ5318fDBq1CibLKJVVlZi2bJlUKvVqK+vR3BwMDgcDnbs2IGhQ4f2+f7uzJ3KFFuL5jjAH/7whx7LA2/duhUvvPCCgyJyPLVajRMnTuDbb7/F2bNnrbpHbGws5s2bh7vuustmCQK1Wo0zZ87gyJEj+Pnnn63qsdXZoEGDcN999+G+++7DqFGjoNFozJ7m6vy5qccsOQlGuqurq8PFixf7fB8OhwNvb294e3sbElp8Ph9BQUEYNGgQ/P39DQmszh++vr5gs9k2+EoIsZ+srCxkZmaitLQUMTExePXVV7FgwYIuYyhR1RXNbwghziw/Px/PPfec2TUDZ8AwDPh8PiIjI3HHHXfg/vvvR3x8PDw9Pc1eV1ZWhoaGBpP3HDVqFHx9fe0RMnESTlf679ChQ4iLi4NEIsHkyZORnp5utgmxTCZDbm6uVcccCdH7z3/+AxaLhS+++MLkmNzcXMTHxxua0hJCiC2pVCpDTwFjPDw8IBKJbLaQO2zYMCQlJeHLL79EcHAwgJt9lyhJ1TMqU0wA4LvvvsOMGTNw5MgRk2NefPFF+Pn54ZlnnnFcYA7E4XBw77334t5770VZWRn27duH3NxctLW19foeBQUFKCgowODBg/HQQw/h/vvvt6q0qUajwblz53DkyBEcP34czc3NFt+jM4FAYEhOjRkzpsvJKQ6HY0hw2Jr+JBglwcxTqVQ2uY9arYZcLodcLu/2nP40lj6Bdet/OyexOp/IujWhxeE43VvuAUGn06GyshLNzc0ICAjAsGHDBtwJyOTkZCQnJyMvLw8ZGRlYuHAh+Hw+Xn31VSxbtozmMIQQ4iL279+PF198EaWlpf0dSjccDgeDBw9GdHQ0pk6dioceeggxMTFWrVuMGDECLS0tRt9L6HQ6SCQSjBkzhjYLuTGnO1E1e/Zs5OfnW3Wts+0Cot04ruepp57Czp07zY6ZMWMGDh065KCICCEDgUajQXFxscnFXXvtHtJoNMjKykJBQQFiY2ORnJxMk75ecKcyxdaiOc5NWq0Wd911l9lT/QzDYM+ePUhMTHRgZP2npaUFubm52Ldvn9kypqZ4eHhg+vTpmD9/PkaNGmV2rFarxYULF3DkyBEcO3YMMpnMyqhv4vF4mDZtGqZPn45x48a53aK2JUkwUwkwZ0mCSSQSXLt2zeGv29mtp7H0CSxvb29wuVzDvx8vL68uiSt9z6xbE1oeHh79+vW4m+vXr6O6utrweVhYGIYMGdKPEfU/iUSCjIwMbN++HQzDICkpCREREcjMzHS6tZT+QvMbQogz2bNnD1auXInr16/3dygAAG9vbwwdOhQTJkwwzNdHjBhh09dobW1FcXExtFqt0ed5PB5EIpFNX5M4D6dLVOkXfxiGgSWhMQzjdJMrmuS4pqeffhqffvqp2THTp0/H4cOHHRQRIcSd6XQ6iMViNDU1mRwzcuRIBAUFOTAq0hN3KVNsLZrj/I9Wq8Xtt99utkY8wzDYv38/HnjgAQdG1r90Oh1Onz6Nb7/9FidOnLBoXq83atQozJ8/H/fdd5+hVIhOp0NRURGOHDmCo0ePorGxsU9xBgQE4N5778X06dMxfvx4StZbydFJsOLi4i5JCGdj7DRW5z8bS0pxuVyjJ7JufYwSWj1ra2tDUVERdDodZDIZeDweGIbBmDFj4OXl1d/hOQV9WUCJRAKGYZCVlYVnn32227jFixdbNNdxdTS/IYT0N61Wi2effRaff/451Gp1v8UREBCAiIgIxMTEYM6cOXjwwQfh5+fnkNemflUDl9MlqgCAxWJBKBQiMTGxx4W5hoYGFBQU4NChQ5SoIjbzzDPP4N///rfZMdOmTcPhw4ep4TIhpE9u3fF7q8GDB2PYsGEOjIj0RH+qds+ePSgoKOh1meKsrCynm6tYi+Y4XanVaowePRpXr141OYbFYuHw4cOYNm2aAyNzDjU1Ndi/fz8OHDhgVUm+wMBA3H///ejo6MDRo0dRV1fXp3j8/PwwdepUTJ8+HbfffjuVZnNy+iRY5ySWXC6HTCYzfNTX1xs+pFIpFAoFVCqVVQlSR+BwOF1OYN2a0DJ3ms/T09NkmcHOn/fUB8KdlZSUQCaT4ejRo7h06RJGjx6NadOmgcfjISoqqr/Dcyr6soD5+flgGAYpKSlITU3FyJEjAQBBQUEm+4W4I5rfEEL6S3NzM+6//3788ssvDn1dFouF4OBgREVF4e6778b999+PadOm9fv8mPpVDUxOmahatGgRli9fjpkzZ/b6msjISLOLA/2BJjmubenSpfj444/Njrn33ntx5MgRSlYRQqzS2Nhots50QEAAIiMj3a78lKtzpzLF1qI5Tnft7e2IjIw0W+6Ow+Hgl19+weTJkx0YmfNob2/Hf//7X3z77be4fPmyQ1/bx8cHU6ZMwfTp0xETE9Pvb76JfalUKjQ1NaG6uhpVVVWoqalBXV2dIZmlUqnQ3t5u+K+p8jL9gWEYcLlco32xTJ3GMsbT09Ns7yz9n7lcrp2/IseSyWQQi8UoKCjAkSNHoNFowGazMX36dMTGxkIkEpndXDJQ3VoWUP93JJPJ3Gbu0hs0vyGEONqpU6ewYsUKHD9+3O6v5enpidDQUIwdOxbTpk3DH/7wB4wdO9bur2sNrVaLS5cumWyP4OnpSf2q3JBTJqry8/MRFBRkUd+HjRs3YvXq1fYLygo0yXF9ycnJ2L59u9kxU6ZMwdGjRylZRQixiFKpxOXLl00ujnG5XIwePZomXk7IncoUW4vmOMYpFAqIRCLU1taaHOPp6YmCggKMGzfOgZE5n+LiYuzbtw+HDx+2W1kTb29v3H333Zg+fTri4uKoZBoBcLN85K0nsurq6lBTU4Pa2lo0NTV1SWLpP1QqlVMktIydxtJ/zuVyLX5P4uHhYTKh1bmvlisktLRaLS5evIi6ujr85z//Mfx/5vF4CAgIwKOPPopBgwZh7Nix9N7NhKamJqxbtw4bN24E4F5zl96g+Q0hxBG0Wi0++ugjbNiwwaqerr3h6+uL4cOHY9KkSZg5cybmzZvncuXyqF/VwOOUiSp3QZMc9/Dcc8/ho48+Mjvm7rvvxvHjx+kNDyGkVzo6OlBcXGyy9wabzUZ0dDT1UXBi7lKm2Fo0xzFNJpNBKBRCKpWaHOPl5YULFy7QGyvcXBT94Ycf8N1335lN8PUWl8vFXXfdhenTp2Py5MkusbhOnEt7ezuampq6JLL0Hw0NDVAqlV2SV8b+3F8/602dxtL/uS/JWg6HY0haGUts6Z/rz7mLvpzyjz/+iPPnz0Mul6OqqgphYWHw9/fH+PHjMXfuXISFhWHIkCH9FqcrkMlkSEpKcqu5S2/Q/IYQYk+NjY1YtWoVdu3ahdbWVpvcU38KViQSYfLkyZg7dy5mz57tNmsJ1K9qYHH6RFVZWRkKCwvxyCOPGB7Lz89HTk4OMjMz4e/v34/RmUeTHPfx/PPP48MPPzQ75s4778Qvv/xCySpCiFk6nQ5XrlyBQqEwOSYyMhKBgYEOjIpYyl3KFFuL5jjm1dbWIjIyEnK53OQYX19fFBcXUw+6/0+j0eDXX3/Fvn37UFhYaNG1np6euOOOOzB9+nTceeedbvPGnDgfnU4HhUJhNIklk8mgVCoB3OyrpVKp0NHR0a3MYOfElqMTAPrTWMb6Y1lzGssYNpttsm9W5w9vb28bfEX/09bWhqKiIpSVleGbb75BW1sbSktLDbuwRSIRvLy88PDDD2PkyJEYO3YsJbJ7wZ3mLr1B8xtCiD2cOHECK1euxG+//dan/pksFguDBw9GdHQ0pkyZgoceegiTJ092+3VI6lc1cDhtcfa9e/ciLS0NEokEDMN0KQkya9Ys6HQ6jBw5Ejk5OZgxY0Y/RkoGgg8++ABsNhv//Oc/TY757bffcNddd+HXX391+18ShBDrXbt2zWySaujQoZSkcgEpKSkQCAQWX0MGhpCQEFy4cAGjR482LFzfqqWlBWPHjoVYLEZwcLCDI3Q+bDYbU6ZMwZQpU1BRUYF9+/bh4MGDJv/+OBwO7rjjDtx3332466674OPj4+CIyUDEMAz8/f3h7++P4cOHd3ve2Gmszp/fmphSq9U9ns5qb2+3WXlMtVoNhUJhdB6iP41lrC+WJaexNBoNmpqa0NTUZHYci8Uy2Tfr1oRWb3p1VlRUoKOjA8eOHYNSqURVVRXa2trAMAwYhkFjYyOCgoJw7NgxDB06FNeuXUNUVFSvvqaBLCMjo79DIIQQl6TVarF161Zs3LgRN27csPo+0dHRWLZsGRYuXIjw8HAbRug6RowYgZaWFqP9qnQ6HUpLS6ltgptwyhNVGzduxJo1awDc/Adnqi5yXl4e5syZg7y8PKdMVtFuHPfz0ksvYevWrWbHxMbG4vfff6dkFSGkm9raWrM1qAUCASIiIhwYESHWoTlO75SUlGD8+PFQqVQmxwQFBUEikSAgIMCBkbkGpVKJvLw8fP/995BIJOBwOIiJicH06dNxzz330M5J4lL0p7H0iSupVNolkdXS0mLyWo1GY/aElv7P9ur3BtxMJndOXHUuK+jl5WW39z4sFstkqUH9n9VqNaqqqvDbb7/h4MGDkMvlqK6uBofDQWBgIJqamsDhcDBy5Eh4eXlh+vTpiI2NhUgkAo/Hs0vcxDXR/IYQ0lf19fVYuXIlsrOzjSZWeoPH42HhwoXIysqitcX/j/pVDQxOl6g6ffo0YmNjuzxmroFnQkICCgsLTR4B7E80yXFPK1aswJYtW8yOiYmJwcmTJ+kXCiHEoLm5GVevXjV51N/HxwejRo2inxsuyJXLFFuL5ji9d+7cOcTFxaGjo8PkmNDQUIjFYjoVZIZSqQSXy6WdksRtdXR0dDuB1fmjN2UCNRqNyVNZnRNc9khodU5a3Xoiy9PT0+av11llZSXq6upQVFQErVYLhUIBhmHg6+uLIUOGoK6uDu3t7eDxeBg2bBgCAgLw2GOPYdCgQRg3bpxdY3MVZWVlhh6LA3njBM1vCCHWOn78OFasWIGCggKryvt5eHjgoYcewpYtWzBixAg7ROj66uvrUV5ebvJ56lfl+pyu9N/69esBAPHx8UhLS0NsbKzZJuWLFi1Cfn4+Xn31Vaxbt85RYZIBbPPmzWAYBps3bzY5prCwEHFxcTh16hQtOhNCoFKpIJFITE5YPTw8IBKJ6OeFi6EyxaQ3JkyYgGPHjmHKlCkmF5qrq6sxevRolJSU2H1B11VREo+4Ow8PDwwaNMjogrhOp0NLS4vJ3lj601j6U0899X/SaDRdTmeZOqFlLsF+q7a2NpM7x9lsdrcEVucTWdbOf9rb2yGTyVBbW4tr166hra0N7e3tUCqVYLPZ8PHxQXV1NTQaDRobG+Hh4QGFQgEWi4Vff/0Vs2fPRkdHR6/LGrqK5uZmSCQSSCQSNDY2AgCWLl1qdOyOHTuQlpYGmUxmeCwhIQF79uwZ0AkrQgjpDa1Wi/feew+bNm1CdXW1VfcIDg7GCy+8gFdffRUcjtMt0zuV4OBgyOVyw++2W1VWVsLPz4/eN7gwp/sOKCwsRFJSEnbv3t2r8UKhEACQm5tLiSriMJs2bQKbzca7775rcszp06cRExODwsJCWnwmZADTaDS4evWqyQVqhmEgEolocdrF3Fqm2Jj4+Hjs3r0b8fHxTlummDjGnXfeiYMHDyIhIcFkuYpr165h3LhxKCoqojephJAuGIYxlLkbNmxYt+c7OjqMnsTSP3brCSo2m21IHpmj1WqNnsi6tQRhTwktjUaDlpYWk+UNuVyu0b5Ypk5jqVQqyOVyQ2JMqVSipaUFbDYbSqUSWq0Wfn5+hhOYbDYbvr6+aGtrQ01NDUJCQnDjxg1UVVV1q+biqr766issW7asW2+w+Ph4kz0yFy9ejJycnG7zmNzcXAiFQhQUFAzYfiiEEGJOdXU1VqxYga+//tpsiW9zbr/9dmRkZGDOnDk2js69hYeHQ6lUmuxXJZFIqF+VC3O6d8ESiQRZWVkWje/8X0IcZePGjWAYBhs3bjQ55uzZs5g4cSLOnDlDySpCBqjS0lKztanDw8Opz4qLOX36NNLS0no1Nj4+HjNnzkRiYqJTlikmjjNz5kx8/fXXePjhh00mN0tKShAbG4vTp0/TvIEQ0mseHh4IDg5GcHCw0ecVCoXJsoIKhcLkfVksluHUkzmdE1rmyg62t7cbvV6lUplc6Ot8GovFYkGr1YJhGHC5XHC5XDAMYzgN1N7ebuhx3TnBxTAMeDwetFot1Go15HI5/Pz8UFJSYvbrciULFy7E77//bnhvyuPxkJ+fj0mTJhkdn56ejuzsbAA3/346/17S6XRobGxEUlISfv/9d/sHTwghLuLQoUNYvXo1CgsLrbre09MT8+fPx5YtWzBkyBAbRzcwsFgsCIVCk/2qVCoVysvLDQdbiGtxukRVTEyMReNzc3PtFAkhPcvMzASbzcaGDRtMjjl//jxuv/12nD17lhadCBlgrl+/3m1na2chISFmy9sS50Rliom15s2bhy+//BKPPvqoyWTVuXPnMGXKFPz88880byCE2ERvTmOZ6o3Vm35WliS0Ojo6TJYa1J/O0iecgJunsWQyGWpqaoyeTmez2aiuroZWq0VTUxN0Oh08PT2hVqvh6ekJLpcLFosFFosFHx8fyOVy1NTUYOTIkWhvb4dCoYCfn18v/yadmz5RyefzUVpaarJ0X35+PjIyMsAwDICbianU1FTDyauCggIsW7YMBQUF+Prrr7FgwQLHfAGEEOKE1Go1Nm7ciC1btqC2ttaqe4SEhGDFihVITU2l+b0NeHt7Y/jw4Sb7VUmlUtTV1VF/QRfkdImq+Ph4FBYWYubMmT2O1TcqZxgGcXFxDoiOkO7Wr18PhmEMC5fGXLhwARMmTMCZM2eonA8hA4RUKjVbpzogIMDoghFxflSmmPTF4sWLIZfLsWzZMpNjfv31V8yZM4c2ZBFC7K6n01imemM1NTVBLpdb9FosFstwEsrf39/kOJ1OB5VKhebmZkilUrS2tqKjo8OQxFKr1YbPNRqNoeeWTqczJLw0Gg1aW1vh7e0NjUYDHx8fdHR0wNPTE6GhoeDz+eDxeG6TpAJuzjMYhkF2drbZ/lL6hJT+9Fl2djYWLlxoeD4iIgLx8fEQCoXYtWsXJaoIIQPSjRs38NJLL2Hfvn0mTwT3JDY2FpmZmb1a4yaW6alfVUVFBXx9falflYtxuhXzNWvWQCgUIiEhAbfffrvJcdu3b8fy5csNnyckJDgiPEKMWrduHdhsNt5++22TYy5evIgJEybg3LlzlKwixM0plUqUlZWZfJ7L5SIiIsKwk5W4FipTTPpq6dKlaGlpwcsvv2xyTF5eHhYsWICvv/7acYERQsgtfH194evri6FDh3Z7Tq1Wm+2N1VPvKmN0Oh2USiXkcjnUarXh9U1Rq9UYOnQoxGIxVCoVGhsbodFowDAMWCwWVCoV1Go12traMHz4cHC5XERGRoLD4bhd70iJRIKYmBizC6IbN26ERCIxzEFTU1O7JKn0eDwe1qxZg+3bt9stXkIIcUY//fQTUlNTce7cOauu53K5eOSRR7Bp0yaEhobaODrSGfWrcj9Ot1rO4/GwYcMGTJo0CYsWLUJ8fDyAm71+xGIxTp48iaysLMhkMsMOoJiYGKxataqfIycD3VtvvQWGYfDWW2+ZHHPp0iWMHz8e58+fp2QVIW6qo6MDYrHYaL1k4GaJGv0CCXFNVKaY2MJLL70EuVyO119/3eSYb775Bk888QQ+//xzB0ZGCCG9w+FwEBQUZLL8rf40lrFk1q2nsbRaLZRKJRQKRa/KDXaOYcSIEQAAuVwOb29v1NXVQavVwt/fHxwOBx0dHZDL5eBwOBg5ciQCAgIgFApx2223Wf/FOyF9XylTmpqakJaWZkhSxcTEmK0KEhsbi/T0dJvHSQghzkatVuOdd97BP//5T9TX11t1j7CwMLzyyitYsWIFlfdzEOpX5X6ccpUsOTkZALB8+XJDg89bF4X0NasjIiIMYwjpb3//+9/BZrOxdu1ak2OKi4sxbtw4XLhwgRaqCXEz+l075koDRERE9NjDgTg3KlNMbOW1116DXC5HZmamyTFffPEF/P398eGHHzowMkII6bueTmM1NzejsbERpaWlKCsrg0wmA8MwhtNUPeFyuQgICACXy4Wfnx9OnjwJHo8HuVyO1tZWtLS0IDAwEEqlElwuFzweD+Hh4fDw8DBsiHUnMpkMIpHI5PP6krP6Db89nZYSCATg8XhWxyORSJCWltblRLlQKER6errFm356KycnB8uWLUNpaWmfYieEDAzXrl3DSy+9hO+//96qU8D693ibNm3C1KlT7RAh6Qn1q3IvTrtKnpycjMWLF2PdunX46quvupXLiYmJQUpKitn6/oT0hzfeeAMMw+CNN94wOeby5csYM2YMioqKKFlFiBu5du0aFAqFyeeHDh2KwMBAB0ZE7IHKFBNbysjIgFwuN5uI+uijj+Dv7282oUUIIa6EYRioVCq0tLRAIBBAIBB0eb6trQ1yubzLh0KhMJy4CggIgKenp2G8j48Phg8fjmvXriE4OBjXr1+HRqOBXC6HVquFp6cnIiMj4e3tjTvuuAN8Pt/RX7Ld8Xg8FBYWGn3uq6++MmycAYDExERMnDjR7P1OnTrV7f9Lb+Xk5CApKQkZGRldNhZnZWUhNjYWGRkZSE1NterepkgkErMnygghRG///v1IT0/HhQsXrLrey8sLixYtwnvvvWeyxyNxHOpX5T4Ynf5okgsoLS2FQCBwmUW+uro6hISEdHmstraWsrgDxNtvv222nA8AREZG4uLFi13eZBFCXFNtbS0qKipMPi8QCBAREeHAiIg9ZWVlYfny5YYyxSkpKSgsLDRbpvjkyZP9HbbN0BzH9pYsWYLPPvvM7Jg333wTf/vb3xwUESGE2J5arUZNTQ3q6uqg0WgsupbP5yM0NBRcLtdQTlD/X6lUivr6ehw8eBDNzc2oqqpCc3MztFotWCwWIiIikJCQAIFAgKVLl8LDw8NOX2H/SUhIQGFhIcrKyuDv7294/PTp04iNjQXDMIZ5iVQqRUBAgNn7zZ49G1Kp1OL5i0QigUgkQmJiotHqN5mZmUhLS0Nubq5NT7bFxsYaEnVSqdSqE1U0vyHEfbW3t+PNN9/ERx99ZDKh0ZOhQ4di9erVeOGFF6i8n5PRaDQoLi422q8KuHkKm/pVOT+XSlS5GprkkPXr1+PVV181O0YkEqGoqIiSVYS4MLlcjpKSEpj6lerj44NRo0bRZNbN6JNV+t3Jt9L/exAKhcjLy8PIkSMdGJ190RzHPhYsWIBvvvnG7JjNmzfj5Zdfdkg8hBBiK+3t7aipqUF9fb3JPp7GMAwDgUCA0NDQXpVOvnLlCnbv3o2amhr8/vvvaG1tBYvFwt13342IiAgsWLDA7XpT6eXl5WH27NmIjIzEhg0bwOPxkJubi8zMTMOchGEYbNiwAatXrzZ7r/z8fCQkJCApKQm7d++2KI6kpCTk5OSgoKDAaIk/mUwGPp8PoVAIsVhs0b1NSUtLQ1BQENLS0gBQoooQ8j+lpaV48cUX8eOPP1rUA1GPYRjcdddd2Lx5M+688047REhspbW1FZcuXTK5LqP/3UOcFyWq7IgmOQQANmzY0GMTWqFQiEuXLlGyihAXpFKpcOnSJZO7gj08PBAdHU3f326qqalpQJYppjmO/SQkJCAvL8/smO3bt2Pp0qUOiogQQqynUqlQXV2NhoYGkwtHxjAMg+DgYAwePBhcLtei19yzZw8kEgnKyspw4cIFjBs3DiNHjoRQKMSiRYss/RJcSkJCAvLz87tsotGfotLpdEhISMBPP/1k9h5nzpzBzJkz0dTUhIyMDKxatcqiGPSvbe7/N5/PN5yE62svqby8PGRkZCA3N9fw2pSoIoR8/fXXePXVV1FcXGzV9d7e3vjjH/+Id9991+oyqMTx6uvrTfarAoARI0bQz3QnRlu7CbGzNWvW9NhTQiKRYNSoUWhvb3dQVIQQW9BoNLh69arJJBXDMBAKhZSkcmOBgYHIyMjA1atXodVqIRaLIZVKodVqcerUKZslqbKyspCQkIDY2FiIRCKIRCIkJCQgJyenx2vz8vKQkJAAkUgEhmEgEomQlJRkso8F6V+5ubm4++67zY5ZtmwZvvzySwdFRAghlmtra0NZWRkuXryI+vr6XiepWCwWBg8ejPHjx2PEiBEWJ6kAID4+Hmw2GxEREYiNjUVERAQ4HM6A6BWZm5uLhQsXQqfTGT6Am0mjpKSkHpNUO3bsQGxsLJqamgDA4hNP+rlFT0ki/Y72njZm9EQmkyElJcVoicGe1NXVdfuor6/vUzyEkP7V1taGtLQ08Pl8PPLII1YlqYYPH44PPvgACoUC//rXvyhJ5WKCg4PN/j+rqKiAUql0YETEEpz+DoCQgWD16tVgsVhmd6OVlZXhtttuQ3Fxca/KWhBC+l9paanJGsjAzd06fn5+DoyI9Dd79CFLSEhATEwMsrOzuyz8pKWlISkpCTExMcjPzze6KKRflMvIyEBMTAxkMhny8vKwbNky5OTkIDk5Gdu2bbN5zKRvjh8/jpiYGJw9e9bkmMcffxy+vr6YN2+eAyMjhBDzlEolqqurIZVKLbqOzWZj0KBBGDx4MDicvi1TCAQC3HnnnThx4gSGDBkCALjjjjvA5/P7dF9XkZ2djdOnTyMvLw9isRgikQjx8fGYNGmSyWvy8/ORkpLS5XS4UCi0uI/LqVOnAKDHhV398ydPnkRiYqJFr9HZrFmzsG3bNqtOT916cooQ4rpKSkrw4osvIjc31+L+h8DNDaZTp07Fpk2bEBcXZ4cIiSONGDECLS0tUKlU3Z7T6XSQSCTUr8pJUaKKEAd55ZVXwGazsWLFCpNjysvLMWrUKFy+fJmSVYQ4uRs3bhh2mxoTEhKC4OBgB0ZE3FFWVhby8vIQExPTbREmIyMDWVlZKCwsxPr165GRkdHl+bS0NAiFwi6JKB6Ph8TERMTHx4PP5yMrKws8Hq/btaR/sVgsnDp1CmPHjsWVK1eMjtHpdFiwYAFyc3Mxc+ZMB0dICCFdtbS0oKqqyuzcyBgOh4OQkBCEhITYdMFo6tSp6OjoQFlZGUaOHImpU6fa7N6uYNKkSWYTU7cqLCw0zBuEQqHVG29kMplF428tm2yJtLQ0xMfHIz4+3up7EEJc2549e/D666+bnC/3xNfXF0888QQyMzMREBBg4+hIf2Gz2RCJRCb7ValUKpSXl1O/KidEpf8IcaCXX34ZW7ZsMTvm2rVruO2228ye0iCE9C+pVIqqqiqTzwcEBGDYsGEOjIi4q4KCAgAwWeJPv+PPWBk/c2VnOyeneipPS/oHh8PB+fPnER4ebnKMVqvF7NmzceLECQdGRggh/yOXy3HlyhUUFxdblKTy8PDAsGHDMH78eISFhdl8VzOLxcKsWbPw7LPPYtasWWCxaOnDnNWrV2PZsmWYNWtWn06HNzQ02DAq0/Ly8gy9qQghA4tSqcTKlSsRGBiIxYsXW5WkCg8Px44dO6BQKPDRRx9RksoNeXt7Y/jw4Safl0qlqKurc2BEpDdotkaIg7300kvYunWr2TEVFRWIioqiuqmEOCGlUomysjKTz3O5XERERHRpYk2ItTIyMpCammqy94K+xE5MTEyXx/U7lLOyskwmuTrvQKZ+Vc7J09MTRUVFCA0NNTlGo9Hgvvvuw7lz5xwYGSFkoGtqakJxcTGuXLkCuVze6+s8PT0xYsQIjBs3DoMHD6YEkpNbvHixReODgoLsFMn/6PtS5efn2/21CCHO49KlS5g9ezb8/f2xefNmNDc3W3Q9i8XC9OnTcfbsWZSVleHZZ5+1U6TEWQwaNIj6VbkYKv1HSD944YUXwDAMXnjhBZNjKisrcdttt+HKlSvw8fFxYHSEEFM6OjogFouh1WqNPs9msxEZGdnn3gqE6Jkry5eTkwOZTAYej4f09PQuzwmFQkNPqt6UxJFIJN2SXcQ5+Pj44PLlyxAKhSZ3qnd0dOCOO+7A+fPnERUV5eAICSEDhU6ng0wmQ3V1tcULO1wuF2FhYRAIBLSZx4WY2uxiir5McW97W/XUy8qYpKQkZGRkWNWXqrPa2tpuj9XX12PMmDF9ui8hxLY+//xzrF27FmKx2Krr/fz88PTTT2P9+vXUP3oAon5VrsWpV9Kam5uNHr8sLS3F6dOn8cgjj/RDVITYxl/+8hewWCz8+c9/Njnm+vXriIqKQklJCSWrCOln+klMe3u7yTERERHUX444RFZWFlJSUiAUCpGbm2t0sUZfNtAU/WksAGaTWcZKItTX1/c+WNJnAQEBKC4uRmRkpMnSWiqVChMnTsSlS5cwYsQIB0dICHFnOp0OjY2NqK6utrg8ube3N0JDQ8Hn8ylB5WIWLVpk8TX6ksQ90SeyEhISLLp/ZmYmhEIhEhMTLY7tVoMGDerzPQgh9qFUKrFmzRp88sknUCgUVt1DKBTijTfewJIlS2wcHXElbDYbQqEQxcXF1K/KBTjlOftDhw4hKCgIAoEAhw8f7vZ8REQExGIx5syZY1GZAUKczfPPP4+PPvrI7JgbN24gMjLS6l/OhBDbuHbtmtnvw6FDhyIwMNCBEZGBJiUlBSKRCAzDICUlBfHx8SgoKLB6Uq0/qZWYmGh2V7K+yX3nD9pt7HjBwcEoKiqCr6+vyTFKpRLjxo0zukucEEIspdPpUFdXh4sXL6KsrMyiJJWvry9EIhHGjBlDp6j6kaWlsfTmzJlj8Wkq4H+liGUymdlx+hLFlp7m3rZtG7KyssAwjNEPPX1ilP7dEeJaLly4gJkzZ8Lf3x//+Mc/LF4H0/cnvHDhAsRiMSWpCICbFSqoX5VrcLpEVVNTE+Lj4yGTyaDT6XDw4EGj41avXo1Zs2Zh5MiRKC8vd3CUhNhOSkoKtm3bZnZMVVUVoqKiKFlFSD+pra01e4JEIBCY7SFDiC1s27YNYrEYOp0Oubm5kEgkiIiIQFZWlsX3ysrKgkQiAY/Hw/bt2+0QLbGHIUOG4OzZs2ZPbsrlckRHR/e4SEgIIaZotVrU1tbi/PnzuHbtmtFyOab4+fkhKioK0dHRfS7NRqzT3NyM5557DkFBQeDz+WCz2Zg8eTK+/vrrHq8tKytDVFQU8vLyrH59/SltU/0vZTIZZDIZhEKhxZtt9PMgYx9SqdQwTiqVGh4nhDi/Tz75BEKhEOPHj8fhw4dNlto3JSAgAC+//DLkcjny8vIwduxYO0VKXNWgQYPA5/NNPl9RUYHW1lYHRkSMcbpE1fr16wHc3L01adKkbj0XOktNTQWPx7P4uDghziY5ObnHhcLq6mpERkZavSuOEGIduVyOyspKk8/7+PggPDzcgRERZ2LqZ3JpaSn27t1rt9eNj4831GlPSUmxKFlVWFhoKBtYUFBAC4kuRiQS4dSpU/D09DQ5RiqVYtSoUbTBhRBiEY1Gg+rqapw/fx4VFRXo6Ojo9bUBAQEYNWoURo0aZbR8P3GMpqYmwyaWzsmagoICJCYm4tVXXzV5bX5+PkQikeG0EwCrTm3rT2zr13ZupX/cVA/OvLw88Pl8pKSkWPS6ve2LRQhxDvqkup+fH/70pz+htLTU4ntERUXhP//5D5qamrB582ZqmUHMCg8PB5fLNfqcTqeDWCyGRqNxcFSkM6dLVOXl5SExMRFisRinTp3qcZK7fPlyXL16Fe+9956DIiTEPpYuXYp//etfZsfU1NQgKiqKklWEOIhKpYJEIjG5G9PDwwMikQgsltP9OiV25ixlivUbelJSUnp1gqawsBCxsbF9LhtI+tfYsWPx888/g8Mx3W62trYWo0ePtrifDCFk4FGr1bhx4wbOnz+P69evQ61W9/paHo+H0aNHIyoqiprUO4GkpKQuJ4v0GIaBTqdDRkYGzp492+35jRs3Yvbs2YY5r06nQ1JSEkpKSiyOISYmBtu2bUNOTg7S0tK6PJeVlYXMzEykpqaa7DOVkZEBmUyGrKwsi04Hd06wde7DSQhxLoWFhZg2bRr4fD4++ugjtLS0WHQ9m83GnDlzUFxcjCtXruDRRx+1U6TE3ej7VZkqC6tSqXDt2jUHR0U6c7qVtdOnT2PHjh2IiIjo1Xj9LuBdu3bZMSpCHOOZZ57Bv//9b7NjamtrKVlFiANoNBqIxWKTizUMw0AoFJo91UDckzOVKe7c22HPnj1mx+bl5SE2NhapqanIzc3t9Umq2trabh9FRUV9CZvYQFxcHPLz880myisrKzFu3DiLFp0JIQNHR0cHKisrcf78eVRVVVm0i1ggEGDMmDEQiUS0g91JlJaWIi8vz5CUio+PNySE9OsrOp0Oy5Yt63Ld4sWLsWbNGuh0OsO127Ztw+7du62OJTk5GWKxGBKJBLGxsYaP7OxsFBQUmDxNBQBpaWng8XhITk7u1VxF348qKSkJPB4PPB4PSUlJYBjGbJknQojjaLVabNu2DeHh4YiNjcWxY8csLu/H4/GwevVqKBQK/Pjjjxg1apSdoiXurKd+VY2NjWbbPhD7Mr0Ns58EBgZaVCqgoKAAQNfdM4S4sqeeegoMw+Dpp582eYqjtrYWkZGRuHLlCpVsIsROysrKzNYoHjFiBO0cHqA6lymOiYnpsUzxtm3bkJCQgCtXrlj0OjKZDLGxseDxeMjPzzf6814gEBj+rC8FaExeXh6SkpKQnZ3dbQdzZmYm4uPjTTY0HzRokEVxE8eZNm0a9u/fjwcffNDknEEsFmPixIk4d+4cnf4khAAA2tvbUV1djfr6eot6+DAMg6CgIISGhposnUP6T05ODoCbm1j27NnTbfNvZmYm1qxZg4KCAsOmx1mzZnXpJRUYGIj8/HxMmjSpz/EIhUJkZ2dbfF18fLzRU2GmWDKWEOJYMpkMq1atwn/+8x+r+/9ER0fjrbfeMnkKkxBLDRo0CHK53OTvj2vXrsHX1xfe3t4Ojow43bvV+Ph4HDp0qNfj+9LkkxBntWTJEuzcudPkcVQAqKurQ1RUFDVLJ8QObty4YfZ7KyQkBMHBwY4LiDgVR5UpzsvLg0QiQWFhockSNp036kyePNnomJycHCQlJSE/P9/oG7zdu3fTpgcXdv/992PPnj1m5wwXL17EnXfeafHOVUKIe2lra0NZWRkuXLiAurq6XiepWCwWQkJCMG7cOLP9HUj/ys3NBcMwyM/PN1qhJjU1FatXrwZwc9NNRESEIUmlP4FVWlpqkyQVIWRgO3nyJKZMmQKBQICPP/7Y4iQVh8PBgw8+iKtXr+LSpUuUpCI211O/KolEQv2q+oFTJqpurWNsSnp6OiQSiaH8EiHu5IknnsBnn31mduGpvr4ekZGR1DiWEBuSSqWoqqoy+XxAQACGDRvmwIiIs3FUmeL4+HgAQGJiouHPt9KX5REKhUbfwGVlZWHZsmXYvn07gJs14fUfeXl5yMnJQWFhIc2jXFxiYiI++eQTs2NOnTqFWbNmOSgiQogzaW1tRWlpKS5evIiGhgaLElSDBw/GuHHjMHz4cJctd6xSqfo7BIeQSCRITEw0u4Hm1VdfhU6nQ2ZmJqRSKXQ6HXQ6HdLS0nDw4EEEBgY6MGJCiDvRarX45z//iWHDhuGOO+7AL7/8YtGpXeBmKc/09HS0tLRg//79EIlEdoqWDHQ99atqa2ujflX9wOkSVcnJyZBKpZg7d67J5uPNzc147rnnkJmZaXjMXNkdQlzV448/ji+++MJssqqhoQFRUVGUrCLEBpRKJcrKykw+z+VyERERYfZ7krg/R5Up5vF4yM7OhkQiQU5OTpdTfjKZDGlpacjJyYFQKERubm636zMzM5GSkgKZTIakpKQuPSJiY2ORkJCApKQkSlK5iaeeegr/+Mc/zI45cuQIHnroIQdFRAjpby0tLRCLxSgqKrLovQKbzUZYWBjGjx+PYcOGwcPDw45R2l57ezsaGhpQVlaGc+fO4cKFCwMiWSWRSEyertYLDAxEfHy8YfGYx+MhNzfXUNaYEEIs1djYiKeffhq+vr544YUXcP36dYvvMWbMGHzzzTdobGzEunXrXHZjBHEt1K/K+ThdjyrgZjPwuLg48Hg8JCYmQigUQiQSGZpx6msv6ydXiYmJeOSRR/ozZELs5tFHHwWbzcYf//hHk7tRGhsbERUVhcuXL1M5MkKs1NHRAbFYbLI0FovFgkgkAofjlL86iQPpyxTPnDmzV+P7UqY4MTERMTEx2LZtG9avXw+ZTIbGxkYIBAIIhUJs27YNycnJ3a6TSCS9PqFOiSr38Ze//AUKhcLsBq7vv/8ejz76KL788ksHRkYIcSSFQoGqqipDH6Le4nA4GDx4MAYNGgQ2m22n6Gyvo6MDcrnc8GEsKSWXywdEycLe/E7Xj4mNjUVeXp7ZU1Tp6emUxCKEGPXzzz9j5cqVOHnypMUnp4D/lfd7//33ER4ebocICelZT/2qKioqnKpflUajQVZWFk6dOoW4uDgkJye71JytJ0652hYTE4ODBw8amn7funO98w/ApKQkQ9kbQtzVokWLwGKxsGjRIrPJqttuuw1XrlyhZBUhFtLXIG5vbzc5RigUOs3khPQvfZnikydP9jjWFmWKhUIhMjIyLL7GmjeMxPWtWbMGcrkc69atMzlm165d8PPzM5SEJIS4h+bmZlRVVUGhUFh0nYeHB0JDQxEcHAwWy+mKrnSj0Wi6JKZ60/tELpcPiPdIvek5KRKJIBKJejWPycvLo0QVIcRAq9Viy5YtePfdd82WyzcnKCgIf/nLX/Daa6/RJlDiFMLDw6FUKo1udNFqtZBIJBg9erRTzJE+/fRT7N27FwBw7do1eHl54ZlnnunnqGyn//+GTYiPj4dUKsXq1asRERFhqJ2s0+nA4/EQHx+P3NxcSlKRASMxMdFo4rYzqVSKqKgo1NbWOjAyQlzftWvXzC7qDB06lGr2EwMqU0yc3TvvvIMXXnjB7JgdO3Zg5cqVDoqIEGJPMpkMly5dQklJiUVJKi6Xi/DwcIwfPx4hISFOsQBjjFarRXNzM65fv45Lly7hzJkzEIvFqK2t7VWSCoDJ39fuprS0tMcxvUlmATd7chYWFvYxIkKIO6itrcXjjz8OHx8fvPLKK1YlqcaPH48DBw6gvr4ea9eupSQVcRq96VdVXl7u4Ki6q6ysRHZ2NgAYShLu2bMHlZWV/RmWTTE6F9puW1paCoFA4DKLhXV1dQgJCenyWG1tLQYNGtRPERF38PXXX2PhwoVmd8oHBgbiypUr3f79EUK6q62tRUVFhcnn+Xw+lUYj3RQWFiIuLg4Mw/SqTLG7nQCnOY5r+NOf/oRPPvnE7JjXX38df//73x0UESHEVnQ6HaRSKaqrq3udrNHz8vJCWFgY+Hy+U/bd1Ol0UCgUhhNTLS0tNjklPHbsWHh5edkgQufEYrHAMAxiYmLMjpPJZJBIJGbH6ccAN0+wDRQ0vyGkqyNHjmDVqlUoLCy06uewh4cH5s2bhy1btmDYsGF2iJAQ2+lpbSg8PLzfTmfrdDqkp6ejoKAAzc3NuHr1KiIjIxEQEIC4uDisW7fOKed0lnKpRJWroUkOsZdvv/0WCxYsMDtRYLFYmDp1Kt59990em+oSMlDJ5XKUlJSY/F7y8fHBqFGjnHaHMelfeXl5SEpKQlNT04ArU0xzHNeRlJRkSJyakpmZidWrVzsoIkJIX+h0OjQ0NKC6utpoiRpzfHx8EBoaCj6fb6forKPT6aBUKg2JKYVCYbJnaF8IhUKn+9ptSZ+oshWdTgeGYShRRfMbMsBotVpkZmZiy5YtqKmpseoegwYNwosvvog1a9bQySniUiQSicl+VSwWC9HR0f3SEuL48eN48803odPpUFRUBJVKBS6XizFjxoBhGKxduxZTpkxxeFy25vQrb2VlZYbai3r5+fl47rnnBszxfUJuNX/+fHzzzTdmF8+1Wi2OHj2KO+64A0OHDkVmZqZd3vAR4qpUKhUkEonJJBWHw4FIJKIkFTGJyhQTV5CdnY25c+eaHZOamooPP/zQQRERQqyh1WpRW1uLCxcuoLy83KIklZ+fHyIjIzF69GinSdS0traitrYWV69exdmzZ1FcXIzr16+jubnZZu9ZvL29ERISApFIhIkTJzrN125vnecjffkghAws1dXV+OMf/whvb2+kp6dblaSaNGkS8vLyUFtbSz2oiEsKDw8Hl8s1+py+X5Wj11bb2trwwQcfAECXjUoqlQrV1dUAgA8++MDiDUzOyGlPVO3duxdpaWmGBuRqtbrL83l5eVi8eDFycnIwY8aMforSPNqNQ+xt//79mD9/fq9/SHp4eODBBx/Epk2bEBERYefoCHFeGo0Gly9fNlkqh2EY3HbbbfDz83NwZMTVuVqZYmvRHMf1TJs2DceOHTM75rPPPsMTTzzhoIgIIb2h0WhQX1+PmpoadHR0WHStv78/wsLC4O/vb6foeq+trc1wYkoul3d7f28LXC4XAQEB8Pf3h7+//4BbINVvroqPjwePx4NAILDqPo2NjZDJZMjLy6MTVaD5DXF/+fn5WLVqFc6cOWPV9Z6enliwYAG2bNmC0NBQ2wZHSD9QKpUoLi42uWlDIBA4dE31X//6F7788ku0t7ejqKgIWq0WPB4PjY2N4HA4GDNmDDw9PfHYY4/hmWeecVhc9uCUiaqNGzdizZo1AMwfN8/Ly8OcOXOQl5fnlMkqmuQQRzhw4AD+8Ic/WJzRv+222/D666/TghQZkMRiMWQymcnn+7P2MCGugOY4rker1WLy5MkoLCw0OYZhGHz11VdYsGCBAyMjhBij0WhQW1uLmpoaixMFgYGBCAsLg6+vr52i61l7e7shKdXc3Gxxkq03PDw8uiSmPD09bf4aroTFYkEikWDkyJE2uZ9EIkFUVBQlqmh+Q9yQWq3Ghg0bsHXrVtTV1Vl1j9DQUKxYsQKrVq2iKiTE7ThLv6rKykosW7YMarXasI7l4eEBFosFpVIJDoeDwMBAiEQicDgc7NixA0OHDrV7XPbidD9JTp8+jbS0tF4dN4+Pj8fMmTORmJhot3hycnLA5/PNLmgS0p8eeOAB7N+/3+KJwZUrV/Dkk0/Cz88Py5YtQ2Njo50iJMS53Lhxw+zP9JCQEEpSEYtQmWLiClgsFk6ePInRo0ebHKPT6ZCYmIjc3FwHRkYI6UytVuP69es4f/48bty4YVGSgM/nY8yYMYiMjHR4kqqjowNSqRTl5eW4cOECzp8/j7KyMjQ0NNgsScXhcMDn8zFixAiMGzcOEyZMwMiRIxEUFDTgk1QAEBMTY7MkFXCzp9ekSZNsdj9CSP+rrKzEwoUL4ePjg9dff93iJBXDMIiNjcXhw4dRVVWF1NRUSlIRtxQSEgIej2fy+YqKCpMVemxFp9Phn//8J9RqNZqamlBfXw+lUon29na0t7cbDvY0NTWhubkZarUa//znP126fK/T/TRZv349ABj6OvS0eL5o0SJIpVK8+uqrNo9FIpEgKSmJklTE6d1///0oKioyu/hkSktLC3bs2IHg4GBMnjwZhw4dskOEhDgHqVSKqqoqk8/7+/tj2LBhDoyIuLK9e/ciKioKIpEIixYt6vLcrFmzsHDhQowcORKHDx/upwgJ6YrFYuHcuXNmS1VotVrcf//9+Pnnnx0YGSGkvb0dFRUVOH/+PKqrq3udoGIYBkFBQRg7diyEQqHDGnxrNBrIZDJUVFSgqKgI586dg0QiQX19vc16JLDZbPB4PAwfPhxjxozB7bffDqFQiEGDBpnsHzGQZWRkuMQ9CSGO98MPP2DChAkYPnw49u7da/EGAi6Xi8cffxzV1dU4deoUpk+fbp9ACXEiI0eO7Nd+VT///DNOnTqFhoYGXLhwAa2treBwOIbkMJvNBpvNBnAzcabT6XDq1Cn88ssvdovJ3pyu9F9kZCRiY2O7NB5ns9kmJ+r5+flISEhAbGwsTp48adNYYmNjDeVRpFKp2UyqMXRsnPSH8vJyrFixAt9//z3a29utukdQUBBSUlLwxhtv0O5E4jaUSiUuX75sciLB5XIRHR094PoZEOu4S5lia9Ecx7W1tbVBJBLhxo0bJsdwOBz89ttviImJcWBkhAw8+kbYDQ0NFu2AZRgGwcHBGDx4sEOSNlqtFgqFwlDKT6lU2vw1WCwW/Pz8DKX8fHx8wDCMzV+HEFNofkPciVqtxt///nd88MEHaGhosOoeYWFhWLVqFV5++WU6OUUGpJaWFly+fNnkHC0oKMimp5n1NBoN5syZg6KiIjQ3N0OlUoHFYsHX17fL3Ei/FgHc/H7Vf3z66acuOYdyukQVi8VCXl4eZs6caXjMXKJq+/btSElJAZ/Pt/oHrzFpaWkICgpCWloaAEpUEdej1WqxefNmbN68GdevX7fqHmw2GzNnzsSmTZswbtw4G0dIiOOo1WpcunTJZPKWxWIhOjraYbuQiWs7ffo0YmNjuzxmrtl4QkICCgsLbTpP6W80x3F9CoUCQqHQbMkXT09PnDlzxqoT24QQ89ra2lBVVQWpVGpRgorFYmHQoEEYPHgwPDw87BafTqdDS0sLmpubIZfL0dLSYvNSMgzDwNfXF/7+/ggICOi2+EIc68yZM8jLywOPx8OiRYsQEBDQ3yE5HM1viDsoLy/Hiy++iAMHDkCtVlt8PcMwuOOOO/Dee+9hypQpdoiQENfSU78qfRliW9Bqtfjvf/+L7du346effgIAyOVy6HQ6cLlco5uTGIaBTqcDm83GhAkTwDAMdu3aZbOYHMnp0uGW7tq0Rw39vLw8FBYWIjU11eb3JsRRWCwWXnnlFVRWVuLkyZO47777LN4Bo9FokJubi/HjxyM8PBz//Oc/7XqslRB70Ol0EIvFZk8YRkREUJKK9JozlSkmxFp+fn4oLi42uxGrvb0dsbGxKC8vd1xghLg5pVIJiUSCixcvorGxsdfJHzabjdDQUIwfPx7Dhg2zeZJKn5iqrq5GSUkJzpw5g8uXL6OqqgoKhcJmSSpfX1+EhoYiKioKEydOxKhRozBkyBD4+flRksqO9u7di71792LHjh3YsWMHzpw50+X59PR0xMbGIi0tDSkpKRAIBPj666/7J1hCiFX27duHsWPHYuTIkdi3b5/FSSovLy88/fTTqK+vx6+//kpJKkL+v576VV27dq3P/ap0Oh2OHDmC5ORkrFu3DnV1dYYKV/r/dnR0dJuP6XQ6qFQq6HQ6hISEgGEYhIWFQSAQ9Cme/uJ0J6rWrFmD4OBgrFq1yvCYqRNV+rJ/DMMgPj7ekGnsC5lMhtjYWBQUFIDH4xkmy3SiirgDpVKJN954Ax9//DGkUqlV9+ByuXj44Yfx7rvvUi8f4hLKy8tRX19v8vkhQ4YgLCzMgRERV+dMZYr7C81x3MeNGzcwatQoKBQKk2P8/Pxw+fJlDBkyxIGREeJeFAoFqqur0dTUZNF1HA4HISEhCAkJMfQhsJXW1lZDKT+FQtHrvliW8Pb2NpTy8/f3t/nXQHonLi4Op0+fRkREBJYvX47k5GTDiSl9lRo9/bpHU1MTJBIJwsPD+yPkfkHzG+Jq2tvbsXbtWnz00UdWr/EMGzYMaWlpeP7556m8HyEmaDQaFBUVmdwA7eXlhdGjR1v8PaTT6XDs2DF89tlnKCsr6/KcTCaDRCIBcHMeqdVqu5yqCgoKgk6nQ2NjI7hcLsaMGQOGYbB27VqXTTQ7XaJKJpNBKBTi8OHDuP322wEYX/zZvn07li9fbqjFmJGR0SW5Za3Y2FhkZGQgPj4eAHqdqDJWNqW+vh5jxozp8hhNcoiz2L9/P1577TWcPXvW6nuMHTsWb775JhYuXGjDyAixnbq6Oly7ds3k83w+H0Kh0IEREXfgLGWK+xMt5LiX8vJyjB492uxOQB6PB7FY7LK78wjpL3K5HFVVVZDL5RZd5+HhgcGDB2PQoEE2Wzhsa2uDXC43fFhTEqonXC7XUMrP39+fen86icjISMTExGDPnj1dHm9qagKfzwdwc+1jw4YNWL16NQAgMzMTBQUFXTbmuDua3xBXIRaL8eKLL+LgwYNWl/e7++67sWXLFkyePNkOERLifmzZr0qn0+H48eP47LPPUFpaanLc1atX0dzcDLVaDaVSCYZhMHToUAwfPhxarRbFxcXQ6XSIjIxEQEAAJk+ejHfeecdlT6k73ayRx+Nhw4YNmDRpEhYtWmRIGJ09exZisRgnT55EVlYWZDKZIUkVExNjkyRVWloa4uPjDa9piVsnM4Q4u4ceeggPPfQQamtrsXr1amRnZ1t8VPXixYtITExEQEAAlixZgvXr18PPz89OERNiGblcbraOsI+Pj12aXhL35wxligmxpfDwcBQUFGDSpElQqVRGx8hkMkRHR+Pq1asDsm8JIZZqampCVVUVWlpaLLrO09MToaGhCAoK6nOCqr293ZCUam5uRkdHR5/uZ4yHh4chKeXv728oT0OcS2NjY7ckFQBDT26GYZCYmGhIUgFAamoq4uLiHBYjIaRnX331FV577TUUFxdbdb2Pjw8ee+wxbNy40eKqUYQMdL6+vhg2bJjJdaaGhgb4+/ub7Q2l0+nwyy+/YOfOnYbTUuYMHz4cRUVF4HA48Pf3h06ng06ng6enJ65evQqdTofAwEAEBASAw+Hgz3/+s8smqQAnPFGll5WVheXLl5v8y9WHLRQKkZeX1+fFxry8PKSlpaGgoKDL4709UdXbfwS0G4c4K61Wi3/9619Yv359r35YGqPflZOZmemyx0yJe1CpVCguLja5u4zD4WD06NG0mEKs0t9lip0B7Th2T2fOnMHkyZPN7swdMmQIxGIxvLy8HBgZIa5Bp9NBJpOhqqrK4g1gXl5eCA0NhUAgsHqBQa1WG5JScrncZOK5L/QLJfpTU8aaehPnExcXh1OnTnV5rLS0FCKRCMDN93FSqbTbRoQ5c+a4zdylN2h+Q5xRW1sbXn/9dWzfvt3i8rF6I0aMwF//+lcsXbqUyvsR0kdisRgymczocywWC9HR0d16oOt0Opw4cQI7d+6EWCzu9WsxDIOAgADU1NSAxWKhqKgIWq0WfD4fUqkULBYLY8aMgaenJx577DE888wzffnS+p3T/nRKTk6GVCrFqlWrEBERYcgY6j9iYmKwbds2XL16tc9JKplMhpSUFOTn59smeEJcEIvFwtKlSyEWi1FcXIwHHnjA4lId+p0BU6dORWhoKN5++227lBQhxByNRgOxWGzy3x7DMBCJRJSkIlZbs2YN1q1b12Pp1O3bt2P27NmGzxMSEuwdGiF9MnHiRBw5csRsD5kbN25gzJgx9PudkE50Oh0aGhpQVFQEiURiUZLK29sbQqEQY8aMQVBQkEVJKo1GA5lMhoqKChQVFeHs2bOQSCSor6+3WZKKzWYjMDAQw4cPx5gxY3D77bdDKBRi0KBBlKRyIcb+Xen7UjEMg9TUVKOnZa3dwEgI6bvLly9j7ty58PPzw7vvvmtxkorFYmHatGkoKChAeXk5kpOTKUlFiA2MHDnS5HqSVquFRCKBVqsFcHOO+Ouvv+LPf/4z3njjjV4nqRiGwYwZM/Dxxx/j888/x/Dhw+Hp6YnBgwcDgKEn3eDBg+Hp6YmQkBA89thjNvjq+pfTnqgyprS0FAKBAIGBgTa9b0JCAlJSUpCYmNjtOTpRRQYytVqNdevW4YMPPkBNTY1V9+BwOJgzZw42b96MqKgoG0dISHfmdrcAN0tcBQcHOy4g4pb0J7/1ZYpTUlJQWFhotkzxyZMn+ztsm6Edx+4tNzcXc+fONbzBMiY6OhoXL16kBQ8yoGm1WjQ0NKC6utpkc21TfH19ERYWZtF7W61WC4VCYTg1pVQqLQ25RywWC35+foZTUz4+Pi5dQobcNHv2bCxevBjPPvssACA9PR0ZGRlgGAZCoRAlJSXdrsnPz8fs2bNN9uB0RzS/Ic7gyy+/xBtvvGH0+7I3fH198eSTTyIjI4PKNRNiJz31qxIIBKitrcXOnTtx5cqVXt+XYRjcd999eOKJJxAeHm54/Pjx43jzzTeh0+lQVFQElUoFLpeLMWPGgGEYrF271i0qW7lUosqU5uZmq3/4ZmZmQiwWY9u2bUaf722iqq6urttj9fX1GDNmTJfHaJJDXNXx48eRmpqKX3/91eQP4p4IhUK8+uqreOaZZ2hhi9jFjRs3UFVVZfL5kJAQDB8+3IEREXfm6DLFzoQWctzf119/jYULF5r9nT9p0iScOnWKfqeTAUer1aKurg41NTUW933y9/dHaGhor96/6nQ6tLS0GEr5tbS0WD0PN4VhGPj6+hpK+fn6+lJiyg0VFhYiLi4OIpEIjY2NXTbTFBQUYOLEiV3GHzp0CElJSYiLi6PSfzS/IQ6gVCqRnp6OTz75BHK53Kp7RERE4PXXX3f50l+EuIqamhpUVlZ2eUyn0+HixYs4cOAAqqurLarkM23aNDz55JNG1w10Oh3S09NRUFCA5uZmXL16FZGRkQgICEBcXBzWrVvnFvM3l09UnT59Gnv27MH69eutul4kEll8nL23f2U0ySHuqLm5Genp6fj888/R3Nxs1T28vb2xaNEivPvuu3SyhdiMVCo1+/Pc398fUVFRbvHLmziPpqYmrFu3Dl999VW3f38xMTFISUnBsmXL+ik6+6E5zsDw+eef48knnzQ7ZurUqTh27JiDIiKkf2k0GkOCytLylwEBAQgLC4Ofn5/JMTqdDkqlEnK5HHK5HAqFwuzJRmv5+PggICAA/v7+8PPzo2TzAJGTk4NFixYZPufxeMjOzsasWbMMj23fvh3Z2dnIy8sDcLM84IcffujwWPsLzW+Io128eBEvvfQSDh8+bNXPexaLhfvuuw9btmzBhAkT7BAhIcQcfUUfnU6HS5cu4fvvv0dpaanheV9fX7Nl1QHg3nvvxZNPPomIiAiz4yorK7Fs2TKo1WrU19cjODgYHA4HO3bswNChQ23y9fQ3l05UNTc3Y926ddi+fTsaGhpsfn+ZTAY+nw+g5xNVxtAkh7i7nJwcvPHGGygqKrL6HhMnTsS6detw//332zAyMtAolUpcvnzZ5OSey+UiOjra4r5rhFjKXmWKnQ3NcQaObdu2Yfny5WbHzJkzBz/++KODIiLE8dRqNWpra1FbW2txGTQej4ewsDD4+PgYfb61tdVQyk+hUNilzJq3t7ehlJ+/v3+PCybEvZ0+fRrAzVOxt7q1b7dAIDA6zl3R/IY4yueff4433njD6j5w/v7+ePrpp7Fu3TqzGyAIIfbV0dGBvXv34ptvvjH6/cxisUyeVp8yZQqWLFkCoVDY69f717/+hS+//NLw+WOPPeZWpygdnqjS1zm2tdzcXMycOdOm95RIJBCJRAAoUUWIOZWVlVi5ciX27dtndeNmPp+PpUuX4u9//zu8vLxsHCFxZ2q1GpcuXTLZG4LFYiE6Ohre3t4OjoyQ/+lLmWJnRHOcgWXjxo1ITU01O2bhwoXIyclxUESEOEZHRwdqampQV1dn8U53gUCA0NDQbvMPlUplKOUnl8stPpnVG1wu11DKz8/PDx4eHjZ/DULcEc1viD0plUr89a9/xccff2x1eb/IyEisXbsWjz/+uI2jI4RYQqfT4cyZM9i5cyfOnj2LlpYWk2M9PDy6zAfvueceLFmyxJBzsIRGo0FWVhYKCgoQGxuL5ORkt9qA1C8nqgQCgdlG95ZiGAbJyck2P5Kel5eHhIQEADcTYfHx8RZdT5McMtBotVr83//9HzZu3IiKigqr7sFisTBt2jS89957iImJsXGExN3odDpcuXIFCoXC5BiRSGTxRgNCbKmvZYqdEc1xBp61a9fizTffNDvm6aefxieffOKgiAixn/b2dlRXV6O+vt6inlAMwyAoKAihoaHgcrmGe+mTUnK53OTGmr7w8PAwlPLz9/e3qB8CIeR/aH5D7OHy5ct48cUXkZ+fb9WpWTabjZkzZ+L999/H6NGj7RAhIcQSZ8+exaefforz588bHlOpVGY37nt5eWHatGlYsmQJoqKiHBGmS+qXRNXy5cuRlZUFoVBo9HjbqVOnIJPJTD6v19jYiMLCQsTHx4PH42HPnj02iY/P50Mmk3Vb2NQ/JpVKe3UfmuSQgezcuXNYuXIljhw5YnUJk6FDh2LlypV4+eWXqXY+Maq8vBz19fUmnx8yZAjCwsIcGBEhXdm7THF/oTnOwLRy5Ups3rzZ7JgXXngBW7dudVBEhNhWW1sbqqur0djYaFGCisViITg4GIMHDwaLxTKU8pPL5VZXGzCHw+EYklIBAQGGpBghpG9ofkNsKScnB3/9619x5coVq64PCAjA0qVL8c4771DVGUKcwPnz5/Hpp5/i7NmzRp9XKpVGT8qPGzcOf/jDHzB37lz6Xu5BvySqvvrqK2RlZeGnn37q9lxTUxMiIiKwY8cOPPLIIz3eKy0tDWVlZdi9e7c9Qu0TmuQQcvMN/9///ndkZWVZvUjr6emJhx56CJs2bUJ4eLiNIySuqq6uDteuXTP5PJ/Pt6jWLyF6rlSmuL/QHGfgSk5Oxvbt282OSU9Px7p16xwUESF919raiqqqql5vSNRjsVgICgqCt7c32traIJfL0draavP42Gw2/Pz8DKemqJwxIfZB8xvSV+3t7Xj99dexbds2NDU1WXWP2267DW+99RYWLVpk4+gIIda4cOECPv30U5w5c8bsOK1WC6VSaSgXPXbsWDz44IMYOXIkgJs9Q6Ojo2kjvhn9kqhqamrC+vXrsWHDhm7PLV68GPHx8Vi2bFmv7ycQCLBx40Y8++yztgyzz2iSQ0hXubm5SE9PR2FhoUW7VDuLjo7G3/72Nzz66KM2jo64ErlcjpKSEpP/jnx8fDBq1CiaABCruUqZ4v5Cc5yB7dFHH8WuXbvMjlm3bh3S09MdFBEh1mlpaUF1dbVFP++1Wi1UKhW8vb3B5XLtcmKKxWLBz8/PcGrKx8fHaBNuQoht0fyGWKu0tBR/+ctf8NNPP1ld3i8hIQFbt26lsmCEOImLFy9i586dKCws7PU1Go0G4eHhePDBBxEREdHt+eDgYNqAb0a/JKrMiYqKQkFBgUUNx+Pi4sAwDE6ePGnHyCxHkxxCjGtsbERqaip27dpltuGgOX5+fnj88cexYcMG6j80wKhUKhQXF5tsPs7hcDB69Gjqz0D6xNnLFPc3muOQP/zhD9i/f7/ZMf/4xz/wl7/8xUEREdJ7crkc1dXVaG5u7nGsTqdDa2srWlpaDAkqHo9n08bVDMPA19fXUMrP19eXElOE9AOa3xBL7du3D2vWrMGlS5esuj4wMBDJycn4+9//TiXBCHESly5dwqeffoqCggKLrouNjcWSJUsQFBSEyspKk+MiIiIgEAj6GqZbcrpEFZvNtnj3gUAgQFNTk9V9cOyFJjmE9Gznzp14++23UVJSYtX1DMMgLi4OmZmZmD59um2DI05Ho9Hg8uXLJsvqMAyD2267DX5+fg6OjLibgVKm2Fo0xyEAMGPGDBw5csTsmH/961945plnHBMQIT1obm5GVVUVFAqFyTE6nQ5tbW1oaWmBUqmEUqkEh8OBQCAAj8ez2WltHx8fQyk/Pz8/OgVOiBOg+Q3pDbVajTfffBMffPABGhsbrbpHVFQU3n77bSrvR4gTKS4uxs6dOy0+CDNp0iQ89dRTGDt2rOGxq1evmiz/yWKxMHr0aEpOG+F0iarIyEhs374dM2bM6NX406dPIzY2FgzDUKKKEBcmFovxyiuv4MCBA+jo6LDqHoMGDcLy5cvx2muv0WkaNyUWi82W5wkPD0dwcLDjAiJua6CUKbYWzXEIcLME2l133WX2zRzDMNizZw8SExMdGBkhXclkMlRVVUGpVBp9vq2tzZCUamlpMfQW8PDwQHBwMAIDA/t8wsnb29tQys/f39+mJ7IIIbZB8xtizrVr1/DSSy9h//79Jqt7mMNisRAfH4+tW7di1KhRdoiQEGKNy5cvY+fOnfj9998tum7ixIlYsmQJxo8f3+05tVqNS5cuob293ei11K/KOKdLVKWlpWHv3r0oLCyEv7+/2bH6Hc1NTU2IiYmh0n+EuAG1Wo1NmzZhy5YtqKqqsuoebDYbs2bNwqZNm7rsaCCu7caNG2b/TYSEhGD48OEOjIgMVO5UpthaNMchelqtFrfffjsuXLhgcgzDMNi/fz8eeOABB0ZGBjqdTgepVIrq6upuJ7Hb29vR0tJiODV164ZHT09PBAcHIyAgwOoEFZfLNZTy8/Pzg4eHh9VfCyHEMWh+Q4z54YcfkJaWhvPnz1t1vb+/P5599lm888478PHxsXF0hBBrlZSUYOfOnfj1118tum7ChAl46qmnMGHCBLPjWlpacPnyZZO91alfVXdOl6hqamrCyJEjwWazkZ6ejldeeaXbmObmZqxfvx5ZWVmQSqVgGAbbtm3D0qVL+yFi02iSQ0jf/Pbbb1i9ejV+/vlnw85WS4WHhyMtLQ0pKSm0U8GFSaVSSCQSk8/7+/sjKiqK+jkQh3CnMsXWojkO6UytVmP06NG4evWqyTEsFguHDx/GtGnTHBgZGYh0Oh0aGhpQXV0NlUoFAOjo6OhSys/U6X0vLy8EBwf3uGHSGA8PD0MpP39/fzrdT4gLovkN0VOr1diwYQPef/991NfXW3UPoVCIN954A0uWLLFxdISQvrh69Sp27tyJEydOWHTd+PHjsWTJEkycOLHX19TU1FC/Kgs4XaIKAAoLCw07jwGAx+MZGpVLJBJD2Sd96AkJCUZ7SPQ3muQQYhtKpRKvvfYaPvnkE7Nl38zx8vLCggUL8O6772LIkCG2DZDYlVKpxOXLl00mK7lcLqKjo8HhcBwcGRmo3KlMsbVojkNu1d7ejsjISFRUVJgcw+Fw8Msvv2Dy5MkOjIwMFFqtFvX19aipqelSxq+lpaXHstLe3t4IDg62qMclh8PpUsqP+gwQ4vpofkNu3LiBl19+Gd9++63Jkl3msFgs3Hfffdi6dSvGjRtnhwgJIdaSSCTYuXMnfv75Z4uuGzt2LJ566ilMnDjRqs3R1K+q95wyUQXc/MeTkpKC/Px8AOjyD6FzyPHx8cjOzkZgYKDDY+wJTXIIsb19+/bhtddes/rYPXBzF8Rbb72F+fPn2zAyYg891fVlsViIjo6Gt7e3gyMjA5k7lSm2Fs1xiDEKhQIikQi1tbUmx3h6eqKgoIAWb4jNaDQaVFdXo7S0FE1NTVAqlYaTVD3x9fVFUFAQfH19exzLZrPh5+dnODVFcw9C3A/NbwauQ4cOYfXq1SgsLLTqel9fXyxZsgSZmZkWbXoghNifRCLBZ599huPHj1t03ZgxY7BkyRLExMT0qXoP9avqPadNVOnl5eUhIyPDkLACbp6wiouLQ0pKChYuXNiP0ZlHkxxC7Ke6uhqrVq3CV199hba2NqvuERgYiKeeegrvvPMOTSadkE6nw5UrV6BQKEyOEYlE4PF4jguKELhXmWJr0RyHmCKTySAUCiGVSk2O8fLywoULFyASiRwYGXE3crkcV69eRVlZGVpaWiy61s/PD8HBwWaTTSwWC35+foYTUz4+PlRimBA3R/ObgUWr1eK9997De++9h5qaGqvuER4ejtdee81t5viEuJOysjJ89tlnOHr0qEXXRUdH46mnnjJURbEFhUKBK1euUL+qHjh9osqV0SSHEPvTarXYvn07NmzYgLKyMqvuwWKxcM899+Ddd9/FnXfeadsAidXKy8vN1gMfMmQIwsLCHBgRIf/jLmWKrUVzHGJObW0tIiMjIZfLTY7x9fVFcXExhg0b5sDIiKtTKpWoq6uDWCxGVVWVyTf7pvj7+yM4ONhoeRWGYeDr62tITPn5+VFiipABhuY3A0N9fT1efvll5OTk9PoEbmcMw2DKlCl4//33ERMTY4cICSF9UV5ebkhQWTJXHDVqFJYsWYLJkyfbZQ5I/ap6RokqO6JJDiGOdenSJaxcuRJ5eXlQq9VW3SM0NBQvvvgiVq9eTT2P+lFdXR2uXbtm8nk+n29IChDSX9yhTLG1aI5DenLt2jWMHj0aSqXS5JiAgACIxWIEBwc7MDLialpaWiCTySCVSqFSqaBSqSCRSHp9PcMwCAgIQFBQELhcbpfnfHx8DKX8/Pz8qOQKIQMczW/c288//4wVK1bg1KlTFm90AG6W53r88cexceNGqupBiBO6du0aPv/8cxw5csSi7/GoqCg89dRTuOOOO+y+SYn6VZlHiSo7okkOIf2jvb0d69atwwcffIC6ujqr7uHh4YE5c+Zgy5YtVJrIweRyOUpKSkxOLHx8fDBq1ChaTCJOw5XLFFuL5jikN0pKSjB+/Hizu5WDgoIgkUgQEBDgwMiIs2tpaYFUKoVUKjVaz7+ystLsiT3gZoKKx+MhKCgIHh4eAG4uMupPTPn7+4PNZtslfkKIa6L5jfvRarX4xz/+gczMTNy4ccOqewwdOhSvvvoqli9fTu9BCXFCFRUV+Pzzz3H48GGLElSRkZF46qmncOeddzrsFD31qzKPElV2RJMcQvrf0aNHkZqait9//92qXVPAzV9er732Gp566ikbR0dupVKpUFxcbPJEHIfDwejRo+Hp6engyAghndEch/TWuXPnEBcXh46ODpNjQkNDIRaL4ePj48DIiDPR6XRdklPm/r0AQFtbG0pLS40+xzAM+Hw+goKCupTy8/f3NySsCCHEGJrfuA+ZTIYVK1Zg165dVvW0ZhgGd955JzZt2oS7777bDhESQvqqsrISn3/+OQ4dOmTRep9IJMKSJUtw991390uZ5576VQ0aNAgjRoxwcFTOgRJVdkSTHEKch0wmQ3p6Or744osed+Ca4uPjg0WLFmHjxo1UpsgOtFotiouL0draavR5hmFw2223wc/Pz8GREUJuRXMcYonffvsNU6ZMgUajMTlmxIgRKCkpoY0IA4hOp4NCoYBUKoVMJusxOXWriooKKBQKw+csFgshISEYOXIk+Hw+/P396d8TIcQiNL9xfSdPnsTLL7+MEydOWLVRlcvlYvHixXjvvffoPT8hTurGjRv4/PPPkZeXZ9H3uVAoxJIlS3DPPff0ex/S6upqXL9+3eTzA7VfFSWq7IgmOYQ4p927d2Pt2rUoLi626nqGYTBp0iSsW7cOc+bMsXF0A5dYLIZMJjP5fHh4OL1ZIMRJ0ByHWOrQoUNISEiAVqs1OSYqKgpFRUXUI9KN6XQ6yOVyQ3LK2p6iAKBUKlFeXo6AgABERERAKBTC19fXhtESQgYamt+4Jq1Wi+3bt+Odd95BRUWFVfcICwvDqlWr8PLLLw/YkluEOLsbN27giy++QF5entn3FLcaOXIklixZgqlTp/Z7gqoz6lfVHSWq7IgmOYQ4t2vXrmHlypX47rvvTNaH7YlAIMDSpUvx5ptvDrhfILZ048YNVFVVmXx+IB99JsQZ0RyHWGPfvn14+OGHze58nDBhAk6fPk2LRG5Ep9OhubkZMpmsz8kp4OaGIX9/f/D5fGi1WgQHB9O/F0KITdD8xrU0NzcjNTUVn332GZRKpVX3iI2NxaZNmzBt2jQbR0cIsZXq6mp88cUXOHjwoMUJqieffBL33nuvUyWo9NRqNYqKikxWFRiI/aooUWVHNMkhxDVotVps3boV7733HiorK626B4vFwvTp0/Hee+9h4sSJtg3QzUmlUkgkEpPP+/v7IyoqyiknFoQMVDTHIdbavXs3Hn30UbPJqrvvvhu//PKLA6MitqbVarucnDJX9rE3GIZBQEAAeDweeDwenbojhNgFzW9cw7lz5/Diiy/i2LFjFi1a63l6euKRRx7B5s2bERoaaocICSG2UFNTY0hQWTKXHDFiBJ588kncd999Tr+ORP2quqJElR3RJIcQ13PmzBm88sorOHLkiFWTXgAYNmwYXnnlFbz44osDaueDNVpbW1FcXGzy75rL5SI6OpoWpOykra0N99xzDy5evIixY8fil19+oZOBpFdojkP6YseOHVi2bJnZMfHx8cjNzXVQRMQWtFotmpubIZVK0dTUZLPkFJ/PB4/HA5vNtlGkhBBiHM1vnNunn36KtWvXoqyszKrrQ0JCsGLFCqSmptL7dEKcWG1tLf7zn//gxx9/tGg+OXz4cEOCypW+x3vqVyUUCsHn8x0YUf+hRJUd0SSHENfV1taGN954Azt27EBjY6NV9/D09MS8efPw3nvvDagdEL2lVqtx6dIlk2UXWSwWoqOj4e3t7eDIBo4pU6Z0ObUwZcoUHD9+vB8jIq6C5jikr95//328/PLLZsc8/PDD+Prrrx0TELGKVqtFU1OTITll7SYfPRaLZUhOBQYGUnKKEOJQNL9xPkqlEmlpafj3v/8NhUJh1T0mTpyIzMxMJCQk2Dg6Qogt1dXVGRJUlpSKHjZsGJ544gnMmDHDpRJUnZWUlKC5udnoc2w2G6NHjwaXy4VOp0NlZSWam5sREBCAYcOGOf2pMUtQosqOaJJDiHv46aef8Oqrr+L06dNmSxWZEx0djTfffBOLFi2ycXSuSafT4cqVK2bfbIhEIvB4PMcFNcD89NNPmDt3brfHf/zxR8yZM6cfIiKuhOY4xBbefvttvP7662bHPPnkk9i5c6eDIiK9odFoDMmp5uZmmySnAgMDDckpV11gIIS4PprfOI9Lly7hhRdewOHDh636PePh4YF58+Zhy5YtGDZsmB0iJITYSl1dHXbtb2lQOwAAVdxJREFU2oUDBw5YlKAaMmQInnzyScyYMcPlNzf11K/Kx8cHo0aNQlVVFaqrqw2Ph4WFYciQIY4K0+5cMlF15swZ5OXlgcfjYdGiRQgICOjvkIyiSQ4h7qW+vh6rV6/Gnj17rG7W6u/vjyeeeAIbNmxw2p9djnDt2jXU1dWZfH7IkCEICwtzYEQDi1arRUhICBoaGro9FxQUhNraWloodDJZWVnIzs5GY2MjZDIZgJslAFJSUpCYmGj2WolEgrS0tC694IRCIdLT0xETE2NVPDTHIbaSlpaGzMxMs2Oee+45fPDBBw6KiBij0Wggk8kgk8nQ1NRk9cYdPRaLZeg3RckpQoizoPlN//vyyy/xt7/9DVevXrXq+qCgILzwwgv461//SuXjCXFyDQ0N+PLLL/H9999bnKB6/PHHMWvWLJdPUHXWU78qf39/KBQK6HQ6yGQy8Hg8MAyDMWPGuE0LB6d7R7B3717s3bsXO3bswI4dO3DmzJkuz6enpyM2NhZpaWlISUmBQCCgkiCEEIcIDg7GJ598gpaWFvz73/9GZGSkxfeQy+X48MMPwePxcNddd+Ho0aN2iNS51dXVmU1S8fl8SlLZ2Zo1a4wmqYCbk8X09HQHR0TMSUhIgFgsRnZ2NgoKCiAWiyEWixETE4OkpCTExsYakle3ysnJgUgkwuTJk1FQUGD4SEhIQGxsbI8JAkLsLSMjA88995zZMR9++CHS0tIcFBHRU6vVaGhowNWrV3H27FmUlZVBJpNZnaRis9kQCAQQiUS4/fbbERERAT6fT0kqQggZ4Nra2vDKK68gMDAQjz32mFVJqnHjxuG7775DfX093njjDUpSEeLEGhsb8cEHH+DJJ5/Et99+2+skVWhoKFatWoWPP/4Ys2fPdqskFQD4+fmZPR118eJFNDU1QaFQoKqqypC0qqiocGCU9uV0J6ri4uJw+vRpREREYPny5UhOTjacOti+fTtSUlIMY/UloZqamiCRSBAeHt4fIZtEu3EIcX8lJSVYuXKlxTV0OwsJCcFzzz2HV199FZ6enjaO0LnI5XKUlJSYXOTSH2emRSv7qa2txZAhQ8w2JWWz2aiurkZwcLADIyPGZGVlISUlBampqcjIyOj2PJ/Ph0wmM/q8RCKBSCRCYmIisrOzu12bmZmJtLQ05ObmIj4+3qK4aI5DbG3JkiX47LPPzI5588038be//c1BEQ1MarUaMpkMUqkUcrm8zyen2Gw2eDwe+Hw+AgIC3KqGPiHE/dD8xrFKSkrw4osvIjc31+x7E1M4HA4eeOABbN261enWAwkh3TU2NmL37t3Yv3+/yV7lxgwePBiPP/44EhISBkQS2li/KrlcjsrKSjAMY5ife3h4QCQSgWEYt2md4XSJqsjISMTExGDPnj1dHm9qagKfzwcAMAyDDRs2YPXq1QBuLrQUFBRg9+7dDo/XHJrkEDJwqNVqbNy4EVu3bu1SL9YSHA4H8fHx2LRpE0aPHm3jCPufSqVCcXGxyYQeh8PB6NGj3T5Z19+mTJmCX375pVfjjh8/7oCIXE9ZWRlycnIgFovR2NgIABAIBIiNjbV5SeKUlBRkZWVBKBRCLBZ3ez4hIQF5eXmIj49Hbm5ul+eSkpKQk5ODgoICoyX+ZDIZ+Hy+yXubQ3McYg8LFizAN998Y3bMX/7yF6xatYoWpGyoo6OjS3KqrzgcjiE55e/vT8kpQojLoPmNY3z11Vd47bXXUFxcbNX1fD4fy5cvx9q1a+m9IyEuQCqVYs+ePfjuu++gUql6fV1ISAgef/xxzJ49e0AkqPRu7Vel1WohkUgMc/aWlhaEhYWBxWJh0KBBCA4OhqenJ8aOHevym76dLlElEAgMiz6dLV++HFlZWWAYBomJid2SUnFxcTh16pSjwuwVmuQQMjCdOHECq1evxokTJ6xuMB4REYG0tDQsW7bM5X/RADd/sRYXF6O1tdXo8wzD4LbbboOfn5+DIxtYfvjhBzzwwAO9Hn/w4EEkJCTYMSLXsnfv3m69noyJjY1FRkYGZsyY0efXlMlkWL9+PRYvXmw02WTuRJV+cdjcVE9/vVQqtWgHFs1xiL3ok6894XK5iIiIwNSpU7Fo0SLMmjXLLX5fOkpHRwekUimkUikUCkWf78fhcMDn88Hn8+Hn50fJKUKIS6L5jf20t7dj7dq1+OijjyCVSq26R3R0NNatW4cFCxbYODpCiD3IZDLs2bMH+/btsyhBNWjQIDz22GOYO3fugEpQdaZQKHD58mUAN38PNTQ0QK1Wo7KyEjqdDkOGDAGXyzWcpvLw8EBYWJjZ0oGuwOkSVcYSTqWlpRCJRABuLrpIpdJuu5XnzJmDn376yWFx9gZNcggZ2BQKBf7617/i008/RVNTk1X38PLywsKFC/Huu+8iNDTUxhE6jlgsNtlDBwDCw8OpzFwvyWQyXLt2DZWVlaisrER1dTVqamrQ0NCAhoYGyGQyyOVyKBQKKJVKtLW1oaOjAxqNxuISTkFBQaitraXFXwCLFy9GTk6O4e/Q1CJs5+eTkpKwa9cuu8WUk5ODpKQk8Hg8lJaWdkk0FRYWIjY2Fjwez+xiQGxsLAoLC5GdnY3ExMRevzbNcYg93XPPPThx4oRF1zAMg8GDB2PSpEl46KGH8Mc//hECgcBOEbqm9vZ2Q2LaFskpDw8P8Pl88Hg8Sk4RQtwCzW9sr7y8HC+++CIOHDhgVal8NpuNhIQEbN26FVFRUXaIkBBia01NTcjOzsY333xjcYLq0Ucfxdy5c+Hh4WHHCF1DdXU1JBIJSktLodPpUFNTA6VSCS8vL4SFhUGr1YLFYsHf3x/Dhg0DwzAYO3YsuFxuf4duNadLSxp7g6PvS8UwDFJTU42W1Olpd7O7kEgkhn+EAQEB9I1LiBPz8/PD+++/j/fffx9ff/01/va3v+HChQsW3aOtrQ1ffPEFvvjiC0yYMAHvvPMOHnroITtFbB83btwwm6TSH1UeKNrb21FRUYGKigpcv34dN27cQG1trWGXjEwmQ1NTE+RyOZRKJVpbW9He3g61Wm31CT1rNTQ0ID093WhvpIFk8uTJKCwshE6nM9SE7inpp9PpkJ2dDYlEgt9//93mMel7VwmFQuTm5nY7DaXf9NPTQr3++ZMnT5pMVNXV1XV7rL6+3oqoCemd48ePIyYmBmfPnu31NTqdDtXV1fjhhx/www8/4M9//jN8fX0RHR2NGTNm4PHHH8fEiRPtF7STUqlUhuRUS0tLn+/n6elpKOtHp6AJIYSYcuDAAaSmpuLixYtWXR8QEIDk5GS89dZb8PLysnF0hBB7aG5uNiSo2traen1dUFAQHnvsMdx///1Ou86t1WoN6wCd/9zT56ae06/tdP7c2LhLly6hvr4era2tqK+vB8MwCA4ORnl5OdRqNXQ6HYRCoWHj2LVr11w6qe90iSo+n4+PP/4Yzz77LAAgPT0deXl5YBgGQqEQ69ev73ZNfn7+gEhUabVayGQy6HQ6NDQ0ALh52sLf39/wMVCPRBLi7BYsWIAFCxbgxo0bWLVqFb7++muLfnEDwLlz5/CHP/wBPB4PzzzzDN5++234+PjYKWLbkEqlqKqqMvm8v78/hg8f7sCI+k6r1aK+vh7l5eWorKxEVVUVqqqqUFdXh7q6OkilUjQ1NaG5uRktLS1QKpVQqVSGU02uZtOmTVi/fv2APVX13HPPoaCgwLCRJiIiAomJiVi8eDGEQiECAwMNY0tLS1FYWIiPPvoI+fn50Ol0KCgowPPPP48PPvigz7GkpKQgLy/PMOeJj49Hdna20ZJ95pLDxpibR926s5gQe2OxWDh16hTGjh2LK1euWH2flpYWFBQUoKCgAO+++y44HA6GDh2Ku+66CwsWLMD8+fPdcvFLpVIZyvoplco+38/T09NQ1s/X19cGERJCCHFHarUa77zzDv7xj38Y1qwsFRUVhTfffBOPPvqojaMjxDXIZDJwuVx4eXmZreJhTeLEFgkWY5/L5XIcPHgQR44c6bLOpd/c2XmTZ+c/+/v7Y8aMGZg8eTLYbDYOHTrkkK+ht0mizmP7Q2trK+rq6tDY2AipVAqNRgMvLy/U1tYaxrS3tyM8PBzV1dUQiURobm6GTCazqKy/M3G60n+FhYWIi4uDSCRCY2OjITHDMAwKCgq67YQ8dOgQkpKSEBcX5/al/5qamnD16lWzY3x8fAynrfz8/AbswiIhzk6r1eKjjz5CZmYmysvLrboHi8XClClT8N5772Hy5Mk2jrDvWltbUVxcbPIXu6enJ0aPHt0vCXalUmlINOnL51VXV6O+vt5wqqm5ublL+Tz9qSYn+7XpEAUFBUb7I7m706dPIzY21nCKKiMjA6tXr+7VtRKJBElJSTh9+jQYhkFeXp5Nelbp5eXlISUlBY2NjcjIyEBycnKX59PS0pCZmQmhUAixWGzyPvp+QImJicjOzjY6prflvKg0DrG19vZ2jB492q4b0vh8PsaNG4c5c+bgiSeeQHh4uN1ey57a2toMySlT/SAtweVyDckpZ98UQwghtkKl/6xTWVmJl156Cd999x06Ojosvp7FYmHmzJnYunUrRo8ebYcICXFenU+/S6VSfPrpp5DJZGhrawOLxYKHhwc4HE6X/+o/PD09u3zu6DLMKpUK58+fx8WLFy363vfx8cGECRMQHR1NBy7MqK6uhlqthkwmQ3V1NVgsFgICArqs9Wu1WkyZMgXBwcGGakVcLhfjxo3rx8it53T/GmJiYrBnzx4sWrTI8BiPx0N2dnaXJNX27duRnZ1taLYsFAodHarDyeXyHscolUoolUrU1NSAYRj4+voaEle+vr5UO54QJ8FisfD888/j+eefx4ULF/DKK68gPz/fohM3Wq0Wx44dwx133IGwsDC8/PLLWLlypVP8oler1bh69arJJBWLxUJkZKTVsarVaty4caNL+byamhrU1NQYdpvIZDIoFAooFAq0tbUZTjX1544YV8ThcAZkuSwAXU5xFxQUYNKkSb2+VigUoqCgAAkJCcjPz0dGRoZNE1Xx8fEQi8Xg8/mGEsmdk1VBQUE2ey1C+ounpydKSkqwYsUK5OTkoLq62uY/w6VSKY4dO4Zjx47htddeA5fLRUREBO69914sXrwYM2bMcNqNX62trYZFDUtPaRvj5eVlSE55e3vbIEJCCCHuLD8/H6+88opFpXo78/PzwzPPPIMNGzbQpgji1jpvKNJ/6JNTnU+/63S6bhuZe7sBiWEYcDicbsmrzp/bKrGlUqlw4cIFXLhwwaIElbe3NyZMmNBvG5ZdiUajMfT1U6vVhrn5re9L9J+r1Wo0NjYiKCjIsPblrGUUzXG6E1WdnT59GgCMLgzl5+d3+VwgEFi0gOQItt6NU1RU1KcdkiwWC35+fggICIC/vz+8vb0pcUWIE2lvb8dbb72Fjz76yOr+Lx4eHnjggQewefNmRERE2DjC3tHpdLhy5YrZRu0ikQgAUFZWhsrKSty4cQNVVVWora01lM/Tn2rSl89ra2szlM9z4l9dbic1NXVA9qhqamoCn88HwzA4ePAgZs2aZfV9YmJiUFZWBrFYjJEjR9o0zszMTKSlpQG4ueCuP+Kv72HF4/EglUpNXq8/UZWcnIxt27YZHUMnqoiz0Gq1OH78OHbt2oWjR49CLBbbJEFjDsMwGDx4MCZNmoQ//OEPePTRR/u1lIZSqTQsbNjia/f29gafzwePx6PkFCFkwKMTVT3TarXIyMjAli1bupSfskRERATeeOMNPPXUUzaOjpD+o1QquySgOn/0ds7W3t6OX375xc6R/k9vkln6xzgcDtRqtSFB1d7e3uvX8fLywu23304JKgvpT1S1tLQYPry9vbskq/QnUr29vd3iRJVTJ6pcnS0nOWq12updKqaw2WzDaSt/f3+3rNFPiKs6dOgQ1qxZg1OnTlmdlImKisLf/vY3PPHEEzaO7qb29nZUVFSgoqLC0KupuroaZWVlqK2tNSSZWlpaupxookST7XXePeXl5QUfHx/DxgQ+nw+BQICgoCDs2LHDog0PwcHBqKmpcdrTBPb01VdfISkpCSkpKfjwww/7dK+cnBwsWrQIWVlZWLp0qY0ivCkvLw8JCQkAgG3bthlOVRUWFiI2NrbHRFVsbCwKCwuRnZ2NxMREo2Pq6uq6PVZfX48xY8Z0eYwWckh/qKysxH/+8x/8+OOPOHfunNU9MSzh5+eHUaNGYcaMGXj88cftfupUv/AhlUqhUqn6fD8fHx/weDzw+Xya/xNCSCeUqDKturoaK1aswN69ey1aoNZjsVi49957sXXrVkyYMMEOERJify0tLd2SUPrklC3maC0tLTh58qQNIrUtjUZjqGCj1WrBYrHAMAwYhjH8+db/MgzT5QSVK57u6W+tra2G9zYNDQ3o6OiASqWCXC6HQqGAQCBAaGgopk2bBj8/P4hEIjAMA5FIRD2qSHe2nORotVo0NzdDLpejubnZLrtHPTw8DEkrf39/eHp62vw1CCGWaWxsxJo1a/Dll1+aPaFkjq+vL/74xz8iMzMTAoHA8LhWq0Vtba0h0XT9+nXD5KOhocEw4dL/Emxtbe2SbCK2xWaz4eHhAS6XCx8fH/j6+iIgIACBgYHg8/kYNGgQBg0ahLCwMISFhWH48OEYMWIEgoODe51I+umnnzB37txex3Tw4EFDEmSgWb58ObZv326zU1AsFgtJSUnYvXt3r6+RyWSGZFN+fr7RyaY+IQV0P/2mPwllbqrH5/Mhk8kgFostKqNMCznEWbW3t+O7777D3r178euvv+LatWuGshn2wuFwMGzYMNx5551YsGABFixY0Od5dOeFEGsWBG/l4+NjKOvH5XL7fD9CCHFHNL/p7ujRo1i5ciUKCgqsut7HxwdPPvkkMjMzERAQYOPoCLEtnU4HhULRrTyf/sOaHmyWkMlkOHPmjF1fwxIajQa1tbWoqqqyaA2IzWYjLCwMQ4cOhZeXV4+ntfR/HogbZPWMJf8YhkFdXR3a29vR3t6OpqYmVFZWoqGhAT4+PoYDKAsWLEBkZKRhs3JUVFR/fzlWc/pEVXNzM/Ly8gwZ5aCgIMTHx7tEvwx7TnI6Ojogl8sNiStbvIG9FZfL7ZK4ouOZhPSvL774Am+99RYuX75s9T16s3BNrMNisQynmry9veHj4wN/f38EBgaCx+MhKCgIISEhCAkJwZAhQzB06FAMHz4cw4cPd+jGgClTpvSqnMCUKVNw/PhxB0TknOLi4hAUFISffvrJJvdLSkrCmTNnUFJS0utrcnJykJSUBADIzc1FfHy82TG3norSl/UrKChATExMt2tlMhn4fD6EQiHEYrFFXw8t5BBXcuHCBXzxxRfIz89HcXFxr/q+9pVAIMC4ceMwe/ZsPPnkkxgxYkSP1+gXRmQymU3m9r6+voayfpScIoSQntH85iatVostW7Zg48aNqK6utuoew4cPx2uvvYalS5cO6MVn4nx0Oh3kcjmkUikaGxu7JKNkMpndNziZU1dXh4sXL/bb6+vpNzWbS1AZKw/v4eGBYcOGYciQIeBwOIbvff1YffKl8+edH/fw8IC3tze8vLzA5XLB5XINn+s/vL29DY9xOByjyZ1bPzf3XG/H6r8WYyfHrH09/X/NaWtrQ1FREXQ6HS5duoTvv/8eDMNAp9OBzWZDo9HgwQcfxOjRo8EwDMaOHevS836nTlRt3LgRa9asMfqcSCTCtm3bbNqY3NYcOcnRH/3Tn7qyxw9W/aKr/oMmG4T0j/LycqxcuRL79++3S5J6oGIYxnCqqXP5PH9//y7l8wYPHozQ0FAMGzYMw4YNw4gRI1zqWHVtbS2GDBlidkcUm81GdXU1goODHRiZc4mMjERSUhLWr19vk/tt374da9assagsmT6RlJiYiOzsbKNjkpKSkJOTYzTZpD9tZer6tLQ0ZGZmmi37Zwot5BBX1tzcjF27duG7775DYWEhqqurodVq7fqaXl5eiIiIwNSpU7F48WLMmDEDDMN0SU7ZYpeun5+fITlF1REIIf1JIpEgLS0NEonE8JhQKER6errRDTSWysvLQ0ZGBiQSCSQSCYRCIWJiYvp0/4E+v6mvr8crr7yCPXv2WFXFh2EY3HPPPdi8eTMmT55shwgJ6R19VSpjJfpkMplTVohhs9kIDAw0JGO4XC7YbDZUKhXa2toM7RTa2trQ2tqKtrY2w9rvrckfc8kgc5+r1WoUFRXh3LlzFpUy9PT0xIQJEzBmzBiHzj/11WhMfXh7e8PX19ewkZjNZjssNlu6fv06qqur8eOPP+L8+fOQy+WoqqpCWFgY/P39MX78eMydOxdhYWEYMmRIf4fbJ055RKapqQnx8fEoLCw0uev/6tWriI+PR0pKCj744AMHR+h89Jlm/aJia2urIXGlUChs8kNYqVRCqVSipqYGDMPA19fX0OPK19e3183WCSF9Ex4ejq+++gparRabN2/G5s2bcf369f4Oyymw2WxwOBzDzhv9zyl9+bzg4GAMGjQIoaGhhqPo4eHhCA0NHTCnRkNCQrBy5Ups3LjR5JhXXnllQCepgJtlN235BlsoFEImk1l0DY/HQ3Z2NtavX4+cnBzEx8cbkqIymczwuFAoRG5ubrfrY2JisG3bNqSkpCAtLa1LWcCsrCxkZmYiNTXV4iQVIa4uICAAycnJhp5uWq0WR48exe7du3Hs2DGIxWKbl9lua2vDpUuXcOnSJWzfvh0MwyAoKAijRo3C1KlTMWfOHKtLIuk3VPB4PKr/TwhxCvoT3xkZGV02y2RlZSE2NhYZGRlITU21+v760tQZGRmIiYmBTCZDXl4eli1bhpycHCQnJ2Pbtm19/joGit9++w0vvfQSfv/9d6sqb3h5eeHRRx/Fu+++26XUPCH2pNFo0NTU1C0RJZVK0dTUZPdNSNbgcDiGUsz6uZtAIACPx4O/v7/F66pqtRqtra2G9VpjH62trWhpaTG0cjCmo6MDly5dwrlz5yyaA3t6emL8+PEYO3Zsv2yQUqlUUKlUZnsyd9Y5saVPXpn7cJbEVlhYmGFznbe3N65evQq1Wo2amhqEhISguroaN27cwKRJk/o71D5zyhNVy5cvR1ZWluHzmJgYxMXFGUonNTQ0QCKRICcnBwzDIDMzE6+88ko/Rmycs+zG0el0UCqVhtNWCoXC5mW/WCyW4eRBQEAAvL29KXFFiAOdOnUKq1evxtGjR51yQmYJFosFNpsNT09P+Pr6IjAwEEFBQYZJXOfyeUOGDMGwYcMQHh4OHx+f/g7dZWi1WoSEhBg93RMUFITa2toBf2qWxWIhLy8PM2fOtMn98vPzMXv2bKs2jkgkEmzbtg15eXmQyWRobGyEQCCAUChEUlKSYbHd3PW37mgWCASGxR1rOMschxB7qaysxOeff46ffvoJ58+ft+g0pLW8vb0xcuRIxMXF4f7778dtt91mdBzDMF1OTlFyihDiTCQSCUQikckT3ZmZmUhLSzNZ1rgnaWlpkMlkRhNR+tPoQPfenb0xkOY3Wq0WH330EdatW2f1psehQ4ciLS0Nf/7znwf8ewdiH2q12nAK6tbTUc3NzU7Z0sDT07NLIqpzYsrPz69fY9NoNF2SWE1NTfjpp5/www8/GJJ7Go0GGo0GWq3W5NqSh4eHIUHlymXmeuLp6WnRiS17bX7u6OjA1q1bUVZWhhs3bkAsFkOr1YLFYiEyMhJhYWEYOXIkXnzxRZd/X+B0iar8/HzD7pjU1FSkp6cjMDDQ5Pi0tDS8++67kEgkCA8Pd1SYveKskxytVguFQmHocdXS0mLz19A3dNP3uPLy8rL5axBCulMqlXjjjTfw8ccf93pXiatgsViG/k9+fn6GzQuDBg3C0KFDMWzYMIwcORIikcjQSJKY9tNPP2Hu3LndHj948KDh9/BAZutE1enTpxEXF+eUZSas4axzHELspb29Hfv27cPevXvx22+/4dq1a3bvYcBmsxESEoLx48dj5syZeOihhzB48GDweLwBcwqYEOJ69GWJ7dEjE7iZrDd3YkqfCAMs78s7EOY3MpkMq1evxhdffIHW1laLr2cYBpMnT8amTZswZcoUO0RIBpqOjg6jiSiZTIbm5ub+Ds8oLpfbJQHV+cMVNtCqVCrs378fu3fvNrtupNPpDEkrjUYDT09PTJs2DXfddRcAdDmxpVQqLSoX6I46J7b0yavOiaxbP3o7nz969ChOnDiB69evo7CwEO3t7eByuVCpVPD09ERMTAyGDh2Ku+++G9OmTbPzV2lfTpeoWrRoEXJycixaHEpLS0NzczM+/PBDO0dnGVeZ5Gg0GkPSSi6XWzVZ6YmHh0eXxBXVzCfE/g4cOICkpCQolcr+DqXfcDgcQ7+pwMBA8Hg8BAcHIzQ01FD2LyIiApGRkRg+fPiA2wk4ZcoU/PLLL10+P378eD9G5DxYLBa2b9+OZ5991ib32759O5YvX06JKkLcyIULF/DZZ5/h0KFDuHz5MuRyud1fUyAQYNy4cZg7dy4ef/xxjBgxwu6vSYgra29vx9mzZ+Ht7Y1x48b1dzgDgr6yirmlJj6fb1iYtqTXq/60FgCTPTb1PToBmEyWmeLO85vCwkK89NJL+Pnnn606hcLlcpGYmIgtW7YM+BLhxHIqlcrwPX9rUkqhUPR3eEZ5e3t3S0LpT0h5e3v3d3hWUalUOHDgAHbt2oXGxsZeX+ft7Y0FCxYgMTER/v7+JsdptVqzpQdvfc7WpbZdjYeHR48nttrb25GTkwM2m43z58+jvLwcAQEBGD58OCoqKtDc3IyRI0fi9ttvB5vNxrPPPms4WeyKnC5RJRAIkJmZiaVLl/b6mtLSUsyePRslJSV2jMxyrjrJ6ejoMCStmpub0d7ebvPX4HK5hqSVv78/7QolxE5WrFiB3bt3o7W1Fe3t7dBqtYZdMRqNximPyvcn/aktLy8vQ28rfbnBsLAwDB8+HOHh4RAKhbjtttus7ifiLNra2nDPPfegqKgIY8aMwS+//EInYP8/FosFhmEgFAptcj992T1KVBHiXrRaraE/wvXr1/Hjjz/i6NGjKC4uRkNDg91/z3p5eSEiIgJTp07FH//4R0yfPn3AbbogA1dbWxvOnz+P06dPo7i4GBKJBBUVFaitrYVMJkNra6vh9+7dd9/dZXMOsQ99kojH45ndpR8bG4vCwkKTySZzYmNjIZPJUFBQYDTJ1TlRZen93XF+s2PHDrz99tsoLy+36vrQ0FCsWrUKK1asoN8vxKy2trZuvaL0H866edbX19doiT4+n+9WJe3a29tx4MABfPnllxYnqB5++GEkJibaZe1Dq9X22GNroCe2zp07h8bGRiiVStTU1ECn0yEsLAze3t7QarWora2FQCBAbGwsgoKCEBERgUWLFvV32FZzukQVm822ahFH37vKmbjLJEelUnVJXNmjzIm3t7chceXn5+c0DesIGQhkMhmuXr0KsViM8vJyVFRUoKqqCnV1dWhoaEBTUxMUCgVaW1vR0dHh8j2wbI3D4YDL5cLX1xf+/v7g8XgYNGgQBg8ejKFDh2LEiBEQCoWGU1uUmHcN+kSVLaZJ+vswDEOJKkLcgL55t0wmM9usW6vVorCwELm5uSgsLMT169ftsgGsM4ZhEBoaikmTJuGhhx7Co48+atFpBUKcxa1JKLFYjMrKSqNJqN6IiIjo0quR2EdWVhZSUlJ6LOuXkJCAvLw8q/pI9TYGAGZPbNXV1XV7rL6+HmPGjOnymCvObxQKBVJTU7Fz506rWz3ExMTgvffew/Tp020bHHFpra2tRkv0SaVSu1RnsgX9e3Rjp6PcvdpTR0cHfvjhB3z55Zeor6/v9XVeXl6YP38+kpKSzLbjcTRjiS1zJ7ac9d9kb9XV1eHixYvQ6XSorKxER0cHAgMD4evrC7VaDQ6Hg5aWFkPCdfLkyWCxWFiwYIHJXrfOzulWy6z5BigtLbVDJESPy+WCy+Uajne3trYaklYKhcImi26tra1obW1FTU0NGIYxLPjqE1f68gGEENvj8XiIi4tDXFxcj2N1Oh0uX76Mq1evory8HDdu3DAktRobGyGVStHW1oaWlha0tLRApVLZvYdHf1Or1VCr1WhpaUFtbW2P41ksFjw8PAyNNwMDAw29toYMGYKhQ4ciIiICQqEQUVFRtMDoBpxsTxAhxAr65JRUKkVTU1Ovvq9ZLFa33681NTU4cOAAfv31V4jFYshkMpvGqdPpUFVVhaqqKhw4cADPP/88/Pz8MGrUKMycORNPPPEEJkyYYNPXJMRSbW1tOHv2LM6ePYtLly5BIpGgsrISNTU1aGpqglKptPnGKHfr3eqsLP2ZZo/koT7xlZiYaHYefeuGG3dw4cIFvPjii/jvf/9r1feQp6cn5s+fj61btyI0NNQOERJX0NLSYjQRJZVKnbYHUUBAgNFEFI/Hg4eHR3+H53AdHR348ccf8eWXXxpNypvC5XIxf/58LFq0yKkSVHosFgu+vr7w9fXt1XitVmtYn+rNyS1nS2zpN3zIZDK0t7eDYRh4e3tDrVZDo9EYqiZ5e3ujtbUVFRUVCA8Px+HDhylRZStCoRCHDx/GjBkzen2NfscOcQxvb294/7/27jUorvO+4/hvl+UmbgtCMpIlJIEukS+ZaJFHjVN7UgvGbmt76gRku2mmL2yDPc00M6ktrDqTTqdtXHB6yXSmLdL4VSMnEortxp5JFLCT1E5aTwxS7da2LFgkhG4IwQIr7runL9RzwgILu8uBsyzfz8wOy9mzZx/YZ8/57/N/LtnZWr9+vQzD0MjIiIaGhjQ8PKxgMLjoBjnDMBQMBhUMBnX58mW53W7l5uZaa1xlZ2eTuAIccuHCBd24cUMbNmzQhg0bZj2+cePGObcHg0F9+umn8vv96urqUk9Pjy5fvqze3l719/crEAhYo7bMi22qCofDGh8ft+bpvnjx4oLPMUdtrVmzRnl5eSosLNTatWtVUlKijRs3qrS0VFu3btX27du1bds2Rm3ZpKCgQJWVlSoqKko4YRgIBNTf36/W1lYNDg7aW0AAS2pqaspKTg0NDS06xk1LS9Pu3bt19913Kz8/X263WxMTE/rRj36kV199Ve+99566u7tt7+ARDAbV1tamtrY2vfTSS/J4PNq8ebP27dunRx55RH/wB3+Q8j2KsXzmSkKZ0/EtVRIqFsm6BkqqcXqWm8OHD8vv98vr9erIkSOOlmU5fe9739Nf/MVfJJz4W7dunb7+9a+rvr6e7xGrgNnmNnN6PjMptdSjvxPhcrlUUFAw5zR9BQUF1Nv/NzU1pZ/85Cd65ZVX4k5QPfTQQ3r00UdTqqOs2+221nuKhWEYUUdsmfdnPhbL9wMzqRTPbXR0VJcuXbI6RRuGIY/HM+s6m5aWpj179qinp0cXLlxQaWmp1b6Wm5ub0P/NSUn3ST5w4IBqa2tjWm/q9OnTeuqpp9Te3m77cHHExhz9lJOTow0bNigcDuvGjRtW4irRYebThcNhDQ0NaWhoSBcvXlRaWpo12io/P5/1VIBlcu3atXmDncLCwjmTVJKUm5srn88X82LG4XBYPT096ujokN/vV3d3tzV6q6+vz2o0nD5qK5VHrUwftRVLwOlyuay1tnJzc5Wfn2+ttVVSUqLNmzdbUxLu2rVLRUVFy/BXrDznzp2zbS7uQCDA/xlYAaampqyGm+HhYVuSU2aDSn5+/qzOVhkZGaquro5YQ+WDDz7Q0aNH9fbbb+vMmTMaHh5eVBlmmpqaUldXl7q6uvSDH/xA0s11gu+8807df//9+spXvqLS0lJbXxOpwUxCnT59OuqaUMna2WhqakrhcJg1dpbY2rVrHXvt9vZ2qxNzS0tLSjW2zmVkZEQvvPCCXn755YSvE5/97GfV2Nio+++/3+bSwWmGYWh4eDjqNH3JOOuJ2+22klEzb/n5+SwRMo+pqSn99Kc/1SuvvKKrV6/G/LyMjAw99NBDOnDgAN9VdbMdZWZiy2yHmesWDAatz9bg4KAGBwet9utgMGjtNzExoVAoFHeMZC69kZaWZrUJeTyeiO8TU1NT1nu+efNmuVwueb3eFZmkkpIwUXXw4EE1NTWpuLhYDQ0N2r9/v7Zu3SpJGhoakt/v1/vvv6+Ghgart0hZWZmeffZZB0sNk9vttpJI0s2ssbm+1fDwsC3DKEOhkAKBgDWtQHp6upW0ysvLo0cosASGh4d14cKFqI9nZ2db52o7uN1ulZaWqrS0VPfdd19MzxkZGVFHR4fOnj2r8+fPq6enR5cuXVJvb6/6+vo0ODhonYdSfdSWYRjWqK3BwcGYRm2lpaUpMzNTu3fv1vvvv78MpUxuPp/P1gVjvV6vKisrbTseAPtMTk5aDTd2zA7g8Xis5FReXl7cMwF89rOfjZieLxAI6NixY3rjjTfU3t6uK1eu2N45o7+/X7/4xS/0i1/8Qn/+53+urKwslZWV6Z577tGBAwf0xS9+kQb+FDczCdXR0aGLFy+uiCRUrM6cOaPdu3c7XYyUZiaH+vv7Y9rfrobR9vZ2VVRUqLKyUs3NzSmdpDpz5oz+9E//VG+99VZCyzB4PB499NBD+sd//Ec6JaxwZqfumdPzmb8n49q40zvwTJ+iz0xGEWvEZ2pqSi0tLTp69GhcCar09HQ9+OCDeuyxx1I6QWUOppgrwRTLNrNjdKJmJr0Mw1A4HLaSVqFQKOL+zG3Z2dm6ceOGPB6PQqGQDMPQ5ORkRLv31NSUxsbGlJubq82bN0tSXLPUJZukS1RJUnNzs/bu3ava2tp59zMXJm9ubl6mkiFe5kXIDBQnJycjEld2zG87OTmp/v5+KxjOzMyMSFwxBBhYnImJCfn9/qiNYh6PR9u3b3c8qFyzZs2sxr35hMNhXblyRZ9++qm6urrU3d2tnp4eXblyRdeuXYsYtTU2Npbyo7ZCoZBGRkZiSmqtBocOHbL9mObC3gCcNzk5aTXk2DFiyePxWI0tiSSn5uP1elVXV2edQ8LhsH7+85/r+PHjeuedd+T3+zU2Nmbb60k3kxYfffSRPvroIzU1NcnlcqmkpEQ+ny8lp4ZJdWNjYzp16pQ++OADffTRR/L7/SmXhJJuNrzl5uaqqKhIGzZsUGlpqXbs2KE77rhDe/bs0bZt25wuYsqLZc1b6TeJrKqqqkW/Zmtrq6qqqnTw4MG4ZtqZa23Zvr4+3XbbbYsu01I4fvy4vvnNb8Y0+9BcioqK9Cd/8if61re+RRvJCjJ9jcyZyajBwcGkPHdPj4nMKdTNpJTdMdJqFQqF1NraqqNHj+ry5csxPy89PV2///u/r8cee8zREbCxMJeaWSiRNF+yKdnWnHK5XEpLS4t5dKBhGLpy5YpGRkY0Pj6ukZERGYahjIwMuVwuTU1NWaO1zDa5srKyFbs+lSS5jCRtdWttbVVdXZ26urqi7lNWVqbm5mbt2bNnGUsWu2vXrs1aoLO3t1fr1q1zqETJZ3x83EpaDQ0NLcnw4+zsbCtplZuby3BhIA7hcFiffPJJ1Au8y+XSzp07V+yw4niNjY2po6NDnZ2dOnfunLq7u3X58mVdvXpV169ftxo8zVFbydiLbSE7d+7UmTNnnC6G486dO2frKMGlOqZTiHGwEk1MTESMnFqs9PR0q/ElNzfX0YaX7u5uHT16VCdPntSHH34Y82iGxcjNzdWuXbu0f/9+feUrX4m5owjsNVcSqqenR9euXUupJFRGRoZycnIiklA7d+7U7bffroqKCm3ZssXxTlO4yTwXztfUVFhYqEAgoM7OzkWtN97a2qqamhodOXIkYgpVSWpsbFRlZWXMU49LyRffjI2N6Vvf+pYOHz6c8Fqnt912m1588UU9/PDDNpcOdpm+JubMKfoGBweTsrNkRkbGrJFRZnLK6ZgolYVCIb311ls6evSoLl26FPPzPB6Pfu/3fk+PP/64iouLl7CEN5lrPS2UWJpvdFOs6z+lusnJSaszcTAY1OTkpDwej/Ly8jQ8PKypqSndc889+q3f+i2lpaXpiSeeUGFhocOlTlzSJqpMjY2NOn78uNrb261tPp9Pjz76qJ577jkHS7awZAtyVoLR0dGIEVd2N/Ka842aiaucnBy+0ADz8Pv9GhgYiPp4aWkp57R5hMNh9fb2Wsmt8+fPW2ttXbt2Tf39/RGjtiYnJx0Pxvbt26f/+q//crQMyeCuu+7Sr3/9a1uPef/99+vkyZO2HtMpxDhYKSYmJqxGHzvWTk1PT7caY5K5k8bExIR+9KMf6Yc//KHee+89XbhwYcnXo/B4PNq8ebP27dunL3/5y3r44YeZknuRRkZGZq0JlcpJqLVr16qkpIQk1ApXVVWl1tZWtbW1zZkkCgQCKiwsVFlZmTo7OxN+nRMnTuipp57SW2+9NefrVFRUqLm5Oa5EWLLEN11dXfra176mkydPJtQmkpaWpgceeED/9E//xEhCm5lTb5m3iYmJiJ8LbTPvT//djvhkKWRmZs6ZiCosLFROTo7TxVtVQqGQfvazn+l73/teXDOgeDwe/e7v/q4ef/zxmM9jhmFoYmIirmnyZv4+MjKSEvFJspg+gtLstJCRkaFQKCSPx6Pq6mpt3LhRn//853Xvvfc6XNrFSfpE1UqWLEHOSmUO8zRHW9mxZsBMbrdbubm51rpaa9asoecH8P8uX748by+ddevWMa/5EhgbG1NXV5c6OzvV1dWlCxcuWNPz9PX1WaO2RkZGlmTU1oMPPqg33njD1mOuRGlpabb/b5fimE6xM8YZHx9Xd3e33G63XC6X3G53xP2ZPxPZhtVlfHzcSk6NjIws+ngZGRlWA81Kbpj54IMPdPToUb311ls6c+aMLaPKFlJUVKQ777xTDzzwgP7oj/5ImzZtWvLXXClmJqE6Ozut6/3g4GBKJaHM6fhKSkq0ZcsWazo+n89HEioFmetFVVdXz7lMQ319vRobG9Xc3DxrFJT0m1FSBw4cUFNT05yvcfjwYdXX1+vIkSOzElH9/f0KBAKqqamJu/3A6Tacf//3f9ehQ4f08ccfJ/R8r9erp59+Wn/5l3+56jsKmI3tM5NKc22LJ+E0OTnp9J9mq+zs7IgE1PRbdna208Vb9cLhsJWg6unpifk5LpdL99xzj6qqqpSVlRXTtHnTE06p8p01WZmDKHJycpSTk6Pc3Fzr/ly3zMxM/fjHP9bk5KSuXr2qixcvWrOFbdu2TVu2bFF+fr6efPJJpaenO/zXLY7jiaq3335bDQ0N1sLte/fu1dNPP61HHnnEyWLZwukgJ9WYi+ANDQ1ZjbR2V9+0tDQraZWXl8eFGauWORVHNHl5edqxYweJ3STR19enM2fOqKurS+fPn7fW2urt7bVGbQWDwZhGbT355JM6cuTIMpY+Obndbu3du1cHDhxY1JQ00s2RiceOHVN7e3vKBP12xjg3btzQJ598YlfR5mRn0iuR/TlXLr2xsTFrqhw7klPTexFPXwQ5lQQCAR07dkxvvPGG2tvbdeXKlSUf1ZuVlaWysjLdc889euyxx3TvvfemZJJiZGTEmo7v448/jlgTKlWTUDPXhCIJtbodPnxYdXV1s9aNirZ9OnNElnSzF/nM9fAaGxtVX1+/YBkSGbHlRBvOxMSE/uqv/kr//M//nPC0rTt37tTf/M3fzJn4S3bhcDiuEUmxjlJa6lHEK8maNWtmJaHM5FRWVpbTxYNufg7Gx8et28jIiN555x29+uqrunjxokKhUEy3cDiswsJClZSUKDMz0+k/K2VlZ2cvmFyKloDKzc1VdnZ23N8PP/30U7322msKh8P69a9/rdHRUWVnZ+uuu+6S2+3WI488sqLXpjI5mqh69NFHdeLECUm/mb/YfKOqqqr0k5/8xKmi2YJE1dIKhUIKBoNW4mopFslLT0+3klb5+fmrvlcSVofR0VF98sknURtQMjIytHv3bhbhXcEmJiasUVvnzp3T+fPndfnyZV25ckVf+9rXmMNeshIMdjEMQy6Xi0TVHIaHh/Xpp5/aVbSkZCarnEiS2V2Xk8no6Ki1hoMdcWBWVpbVcJOqyan5hMNh/fznP9fx48f1zjvvyO/3a2xsbElf0+1265ZbbpHP59NDDz2kxx9/XPn5+Uv6mos1VxLKnI4v1ZNQ5nR8e/fu1ebNm0lCYV5+v1/19fXy+/3WtqKiIjU0NMy7btR8I6r8fr/Ky8tjev3Kykq1tLTEVeblbMPp7u7W17/+db355psJJVXS0tJUWVmp7373u9q1a5ft5ZspFArFPOIonlFKqRIbOy03N3fOKfq8Xi8Ji0UwDEOhUEhjY2NWEmmu+zN/xnp/dHRU4+Pj1kg9wzA0MDCgK1euxB2DmdPn8n7PLzMzc8FE0nzb1qxZ41j8c/z4cXV1den69ev68MMPdeedd2rt2rXatm2bDhw44EiZ7OZYouqll15SfX39rIU2XS6X1Ziz0pNVJKqW1+TkZMT6VuPj47a/RmZmppW0ysvLo6EeKWdqakoff/yxJiYm5nzc7XbrM5/5DKMNkfJibdyf2dFmvv1IVM1taGhIZ8+etatoiGIpplSMZ3+7jI6OWtP62ZFEyc7OthpzuLbN1t3draNHj+rkyZP68MMPE+7tH4+8vDzt2rVL9913n7761a/qjjvuWPLXNJlJqP/+7/+etSZUKiah5loTiiQUVrPlaMP58Y9/rPr6en344YcJPT8/P19PPPGE/vqv/3rOThWhUCjuEUmxjFJKhXPfSpefnz8rEWXeX+nTfSXCnN7RzsTR2NjYrN+Xq+6HQiGdOXOGBNU80tPTY04uzbXPmjVrVnQ7bn9/v15++WWFw2FdunRJGzduVFpamp544gkVFhY6XTxbOJaoKioq0uDgoNXA4/P5VFRUJL/fb/W4cblcamlp0X333edEEReNRJWzJiYmrNFWw8PDSzKXcHZ2tpW4ys3NteYIBVYiwzB09uxZDQ8PR92nvLx81vQbQCqKtYHO7GAT674kqmZbaKpRpIbFJsnC4bACgYAtHZHM9RgKCwuZ8iZOExMTev311/Xaa6/pvffe04ULF5Z8eiWPx6PS0lLt27dPX/rSl/Twww8nNMvBzCTU9DWhhoaGUjYJtXXrVm3fvl133nmnfD4fSShgHkvVhjM1NaW//du/1Xe/+1319fUldIwNGzboD//wD/Xbv/3b8yacWIZ+5XK5XBHJqOmJKK/Xu6Ia2EOh0JIljqZPkZdqOjo6NDQ0FNO+5ojnlZKg8ng8CU2TN/331ZiQnek//uM/9J//+Z/W75///Od17733OlgiezmSqPrhD3+ompoauVwu/eu//queeuqpiMfb29tVU1Ojc+fOqaamRj/4wQ+Wu4i2IFGVXEZHRyNGXNndWGguhmeOtsrJyeFLIFaU7u5uXbt2LerjGzdu1IYNG5axRIBz3G636uvr9fzzz6ugoGDe/RobG/Xss89G3WdwcFDf/va39Z3vfIdE1Rz6+/vV1dVlV9GAOU1fn2GlfKFfKU6fPq1XXnlFb7/9ts6cOaNgMLjkr1lYWKiysjI9+OCDevLJJ+X1enX69Ok514RK1STUhg0btGXLFpJQgI3sjG+CwaAqKyvV0dGh/v7+hBNIRUVFuuOOO5SXlxfRkWOuzh/R7i/0c75tsb7e9G2pOuXwfFwulzIyMpSRkaH09HTrZv4+8+f0+1lZWfJ6vSooKFjyzs+GYWhycnJJEkfT77NGWGJu3LihM2fOzLtPUVGRSkpKlrWzlcvlSmiavOm3jIyMVXlusFs4HNbPfvYznTt3Tlu3btXv/M7vpFTs50ii6umnn9aRI0fU3NysL33pS3PuEwgEVFRUtKJ7H5OoSl6GYWhkZMRKWgWDQdu/vLrdbuXk5FiJqzVr1nBSRtK6du2auru7oz5uNggBq0VRUVFMU1zFkqgybd++XR0dHXYUz3F2xjgjIyMaGBhQOByWYRgKh8MR92PZBswlJyeH9RkcEAgE9P3vf19vvvmmTp06pStXrvA5jcFcSShzOr6Kigpt2rQppRoigGRkZ3xz11136f3330+oHC6XS3l5eSouLl6xn/uFklyJJskWe4y0tDRlZGTI4/FEJJbM+zNvmZmZ1k/zNvP37OxspaenKy0tTWlpadbrzLy/UHtQOBxessTR9Ptck5NbZ2enBgcHZ21PNEFldqqPd5q86b9nZWXRnoll4ci40dbWVpWVlUVNUkmS1+vVc889p+985ztWlhCwi8vlsk64JSUlCofDunHjhoaHhzU0NKSRkZFFX7zD4bCVCJNuLnaal5dn3VgHAckiGAzqwoULUR/Pzs7mHIxVp7Ky0vZjzrdw+Gq2Zs2aOddYiMdcSax4k16JJslSYZRGKjEXE/d6vQlND4fF83q9euaZZ/TMM89I+k3Pz2PHjundd99VV1eXLeuLrSQzk1Bbt27Vjh07SEIBKWy+mSqi8Xg8KiwsnHc0/0phxkqJSmSEWKzbnOJyuWYlsNxut5WgYhQSpJvTfE5PVK1fv147d+7U+vXrE5o6Lzs7myQTVgxHElX9/f2qq6tbcL/HHntML730kvx+P42kWFJut9tKIG3cuFGhUEjBYNBKXI2Oji76NUKhkAKBgAKBgKSbiwBOT1zR0xdOmJiYUGdnZ9TErMfj0fbt22k8wapz/PjxFXFM3GSeo5xaK9LOpFe8+5Mok/Ly8qxFxZm7Pvm43W7t379f+/fvt7Z1d3fr3/7t3/TTn/5U//M//xPTCNZk5XK5lJWVpYKCAm3YsEG7du3S7bffrjvvvFN79uxRaWmp00UE4IBvfvObs5a5iCYrK0vFxcUrct3EeBJE8eyTig3rhmFoamqKhFQKyczMVFZWljW6zrw/82cs96f//Id/+AdlZ2frj//4j7Vt2zan/0xg2TiSqAoEAiovL19wv3immTp06JBefPHFxRQLsKSlpamgoMDqyTQ1NWUlrYaHh21ZtHFyclL9/f3WF/PMzMyIxBUNLVhq4XBYHR0dUQNll8ulsrIyeqQDwALMHrJOMQzDkSTZ9J/LLS8vzxo5Rcy08pSWluqFF17QCy+8IOlmx5nXX39dr776qt577z319PSsmIY8wzA0Ojqq0dFRXblyRadOnZJ0s7NPZmamcnJyVFBQIK/Xq3Xr1mnDhg3atGmTNm/erPLycu3cuVMlJSV0CrLZ2NiY7r77bv3v//6vbr/9dv3qV79akUkArFxf/epXVVtbG/Uaaa75sm7dumX5/NuxblW0qfiAZON2u5WVlTUrIRRP4mih5yzlmkvf/va3Hf1uATjFkUSVFFsSKp7hzq2trSSqsGTMIfiFhYWSbn6ZNpNWw8PDmpycXPRrmPMF9/X1Sbo53dr0xBUXKdjt3Llz844W3Lx5s/Ly8paxRACARExvNHLKciTJMjIylJ+fL6/XK4/Hsa8xWAIZGRk6cOCADhw4YG07ffq0XnnlFb399ts6c+aMgsGggyWMn9lr/saNG+rt7V1wf7fbba11Yo4SLC4u1i233KKNGzeqtLRU27Zt044dO7Rt2zY6Ei1g//79VtLw1KlTqqys1LvvvutwqbCahMNhFRQUWDOqmDwej7xerwoKCuZs5LZjaru59iGhhGRhrvG1mNFHCyWRVnqcSPsfVivHPrlzLQwXzUIX1FOnTqm9vX2xRQJilpGRoeLiYhUXF0u62WNveuIqFAot+jXMnpm9vb3W4od5eXnKz89XTk4OvS6xKJcvX9bAwEDUx9etW5fQosEAgNXJ6ekXkXo+97nP6XOf+5z1eyAQ0Pe//329+eabOnnypC3xdjIJh8NW/N/f36/z58/Pu7/L5VJ6erqys7OtUVtr1661Rm1t3rxZ27ZtU1lZmXbt2qX8/Pxl+kucd/LkSf3qV7+K2PbLX/5SJ0+e1P333+9QqbDapKen6/nnn9ehQ4dkGIa2bNmiRx55RNu2bYvoXDI9ieR2uxUKhRQKhRQOh6378f5u3p9r23z3sbqZU9nOlQhabOJo+n2SpgCicRkOzNXhdrtVWFiovXv3yuv1Rt0vEAiopaVFFRUVc47ACgQC6u/vt5JUyXZhvXbtmtavXx+xrbe3l8bfFGcYhkZGRqykVTAYtH39CHOagPz8fOXl5WnNmjVc7BGzQCCgzs7OqI/n5eVpx44d1KkUE+taN9nZ2UyNI+mZZ57Rv/zLvyy4n9vtVmNjo5599lnbjrkSEOMAcFJnZ6dOnz6t1tZWnTp1SiMjIzIMQ5OTkxoZGVEwGNTo6KgmJiZYx22a6dMR5ufnq7CwUMXFxSopKdGmTZtUWlqqsrIy7dy5Uxs3blyRHePC4bDWr1+v69evz3ps7dq16u3tXZF/F5bHUsQ3x48fV2VlpYqKihZbvCVnGEbcybB47y/mGHaWKdZ9k2UaWo/Hs+hp7LKzs+fdx+Px0AYAwFGOjagKBAJqbW1dcD+Xy6X29vZ5R0wZhsHJFEnD5XIpJydHOTk5KikpkWEYCgaDVuLqxo0bi17LwTAM63jSzd7L0xNXZi8VPheYaXR0VF1dXVEfz8jIUFlZGXVnCSyUIFrKx+M559x6660qKSlZwv/EyhBLjJIMxwSA1ai8vFzl5eX68pe/vOC+4XBYFy5c0Keffiq/36/z58/r0qVLunLlivr6+jQwMGDF6OPj40nX+dFOiUxHmJGRYc3sUFBQYE1HeOutt2rTpk3WdITl5eVJMR3h888/P2eSSpKuX7+uQ4cOqaGhYZlLhdVs+pSmyc7lcsnj8az4adPsNl8Cz44EnDmSKVqCKTMzkxHrAFYFR68+dgzmojEVyc7lclnrTEk3R/6ZiauhoaF51wiKVSgU0uDg4JxTas612On021Juj/cYfJ6X1tTUlDo6OqL2LHa73dq+fXvKfjExDCPuNVPsfHylWEllXUqdnZ16+eWX9cQTTyy4byznriNHjsjv99tRNABAHNxut7Zs2aItW7bE/Jy+vj6dPXtWnZ2dOn/+vHp6enT58mX19vZqYGBAg4ODCgaDGhsb09TUlC3fa5NROBzW2NiYxsbG1N/fv+D+5nSEWVlZEdMRrl+/XiUlJdq8ebO2bt2q7du3a8eOHfPOrpKI3t5e/f3f//28+/zd3/2dnnvuOWsKdwBYCAk8AFgejk39J0k+n09FRUUJB6jTp/5zuVxJ1/uNaXEQi6mpKWt01NDQkMbHx50ukqOcSKglmoBbSQzD0NmzZ61ReHMpLy+3vcFgrnIsd4IokVFFq1lJSYluvfVWp4vhuOmf8/k+FwMDA3K5XAtOZWxKtlglUcQ4APAbY2Nj6ujoUGdnp7q6utTd3a1Lly6pt7dXfX19CgQCTEcYhTkd4Zo1a+acjnDLli3WqK1NmzbNO23fF77whVlrU0Xb791337Xzz0CKIL4BAMA5jnUHaG9vj1gcdzH8fr927Nhhy7GA5ebxeFRYWKjCwkJJ0sTEhJW0Gh4e1uTkpMMlXF4r6Yt7tFFhdowus3v7hQsXNDw8HDGqSPrNukUlJSXyeDwaGhpa0gQSkh/vUyTDMDQwMBD1cZfLteA+0/cFAKSerKws3XHHHbrjjjti2j8cDqunpydi1JY5HeG1a9es6QhHRkY0Pj6eNGukLIXp0xFeu3Ztwf3N6Qizs7MjpiMMh8MxJakk6Ze//KVaWlpUVVW12OIDAADAJo4kqnw+n21JKkkqKyvTnj17bDse4KSMjAytXbtWa9eulXSzh6aZtBoeHk6Z3vipwEz6JLtAIKDLly9HfTwvL09ZWVkRoz6wepGois9KOAcAAJKL2+1WaWmpSktLtX///pie09/fr7Nnz6qjo0Pd3d26cOGCNR1hf3+/BgcHdePGDY2NjWlycjJlr0/TpyOMpZNINI8//rh6e3vnHaEFAACA5eNIourQoUMr4phAMjAX1Vy/fr0Mw9Do6KiVuAoGgzQqY14jIyO6cuVK1MczMzO1cePGZSwRkpU5+o4Gm9/Ytm2bqqurrY4Dibp+/bqam5t17tw5ewoGAFh1ioqKtG/fPu3bty+m/cfGxtTZ2amOjg6dO3duzukIh4eHV+10hNevX9ehQ4fU0NDgdFEAAAAgh9aoWi2Y3xhLzTAMBYNBa7TVjRs3Urb3JOI3OTmprq6uqKPw0tLStHXrVmVkZCxzyTCX6VM1Tv8Z7X6s22J9HJHcbrcCgYDy8/NtOV4gEFBRUVHKNAQS4wBAajGnI+zo6JDf79f58+fV09Ojq1evRkxHeOPGjZSZjtDj8Wh8fJxOOrAQ3wAA4BzH1qgCsHgul0t5eXnKy8uTdPML5vj4uLUm0PTbXNuWenuqNMiuVFevXo2apHK5XLr11ltJUs2w2GTPYhJMJIuSi8/nsy1JJUler1eVlZW2HQ8AADtNn47wvvvui+k5gUDAmo7w3Llz6unpsaYjvH79uoaGhhQMBpN2OsKpqSmdPn1aPp/P6aIAAACseiSqgBTidruVnZ3tdDEizJXUcipxFsv2VFJSUqJQKKSRkZFZj91yyy3KyclxoFTzW+pk0ELPAUxLMRUQ0wsBAFKJ1+vVXXfdpbvuuium/ScmJtTZ2amzZ8/q/Pnz6u7u1sWLF3X16lVdv37dmo5wZGRkWaYj9Hg8tq6dDQAAgMSRqAKwpFbaSJGlHF22FMeej8fjUWlpqa5evRqx2HRhYaEKCwujPm+5RxOxNhKSUayL28djz549th8TAICVIiMjQ7t379bu3btj2j8cDuvSpUvq6OhQZ2fnnNMRDg0NaWBgQJOTk3GX5xvf+AbxJwAAQJIgUQUA06zkxFq05NZnPvMZ9fX1qbu7W7m5udq5c6fS0tLmTCCtpL8dAAAAqcvtdmvTpk3atGmTvvjFL0bdLxwOa/369bp+/XrMxy4uLtaLL75oQykBAABgBxJVALCCTU+spaWlRd0vNzdXxcXFysrKksfDqR8AAACpwe126+jRo3rggQdifs4rr7zCaCoAAIAkQmQGAKtEbm4uSSoAAACknPvvv1933313TPt+4QtfUFVV1RKXCAAAAPEgUQUAAAAAAFa01157bd4ZBqSbMxC8/vrry1MgAAAAxIxEFQAAAAAAWNHWr1+vb3zjG/Pu82d/9mcqLi5ephIBAAAgVi7DMAynC5Gqrl69qpKSkohtH330EYExAGDVWLt2LWtApCBiHABAMgqHw9q9e7cGBgZmPVZYWKiPP/7YlriE+CY1Ed8AAFYzp+MbFitZQv39/bO23XbbbQ6UBAAAZ/T29mrdunVOFwM2I8YBAKw0AwMDs5IQiSK+SU3ENwCA1czp+IYuQAAAAAAAAAAAAHAEiSoAAAAAAAAAAAA4gkQVAAAAAAAAAAAAHOEyDMNwuhCpampqSmfPno3YVlRUtKhFyfr6+mbNkczinpCoG5gb9QLRLFfdcHoxTiwNu2MczlWIhrqBaKgbiGY56gbxTWoivsFyoW4gGuoGolkN8Y3HsVdeBTwej3bv3r3kr1NcXMxCrpgTdQNzoV4gGuoGYrUcMQ71EdFQNxANdQPRUDcQC+IbOIm6gWioG4gm1eoGXYAAAAAAAAAAAADgCBJVAAAAAAAAAAAAcASJKgAAAAAAAAAAADiCRBUAAAAAAAAAAAAc4TIMw3C6EAAAAAAAAAAAAFh9GFEFAAAAAAAAAAAAR5CoAgAAAAAAAAAAgCNIVAEAAAAAAAAAAMARJKoAAAAAAAAAAADgCBJViOD3+3X48GFVVVWpsbHR6eLARvO9t4FAQCdOnFBNTY0CgYAzBQSwbNrb29Xa2prw87lWYKWhzqY2YhwAEvENVifqbeoivgEgra74hkQVLO3t7WpqalJ9fb1aW1t1/fp1p4sEm8z33h4+fFgVFRWqqanRiRMnHCwlgKUUCARUV1enwsJCVVRUqKWlJaHjcK3ASkOdTW3EOMDqRnyD1Yx6m7qIb4DVbbXGNySqYPH5fGpoaNCBAwecLgpsNt97W1tbq87OTgdKBWA5eb1eNTU1ae/evYs6DtcKrDTU2dRGjAOsbsQ3WM2ot6mL+AZY3VZrfEOiCrN4vV6ni4AlwnsLwOfz2XKchc4nNTU1trwOYBeugamN9xdY3YhvsJpxDUxdvLfA6rba4hsSVQAAwFY1NTVqb293uhgAAAC2Ib4BAACpJpniGxJVAADANo2NjcyVDgAAUgrxDQAASDXJFt+QqFoi7e3tqqmpUVVVlcrLy1VRUTHrjQ8EAmpsbFR5ebmkmwsimoukmfx+v+rq6lRTU6OamhpVVFSovr5+1msVFhbK5XLJ5XJZj7e3t6uiosLaXlVVFZEhPXz4sFwulwoLCxUIBJboP4GZ7H6/YqkjiWpsbLTKU1dXp8OHD9tyXCRuvvPGiRMnVF5eLpfLZT0uSa2traqrq7Pey+nnovb2dtXX11v7t7e3q6qqyjpmsvSqwE3xft5bW1uta1FVVZXq6+tnne8TqTfRnDhxQk1NTVZZKyoqVFFRodbW1sT+YCQd4hvMhxgHiSK+Wd2Ib5AMiHEQDfENEkV8s7oR3yTAgO0aGhoMn89ndHZ2Wtt8Pp8hyWhoaDAMwzCampqMsrIyQ5IhyWhqajKqq6sNr9drSDLa2tqMzs5Ow+v1GrW1tdZx2traDElGZWVlxGs2Nzcbkgyv1xuxfWBgwHqNtra2WWX1+XxGc3NzxLaDBw8akoyDBw8u+n+Budn1fsVTRwxj/vfWfN2BgYGIcs6sy3BOLOcNs26VlZXNer55HjLrUEtLi1FdXW0dr6GhwaisrDSampqM2traOesEnBPv572hocHwer0Rn1+zfsw8D8RTb0zRzictLS1Rj4WVjfgGsSDGQbyIb1Y34hskA2IcLIT4BvEivlndiG8Sw4gqm504cUL19fVqbm5WWVmZtf3QoUOSpGPHjkmSamtr1dzcHPHc5uZmdXV1qaWlRT6fT01NTQoEAhELnvl8Pnm93lnZzerqanm9XgUCgYgMutfrVW1trSTNek4gEFAgEFB1dfXi/3DExa73K546Eq/GxkYdO3ZMbW1tEXUZzonlvDHfe1VUVBTxe2VlZcTxvF6vWlpaVFtbq6amJmvRxuPHj9v4VyBR8XzeW1tbVV9fryNHjkTUierq6jnP+fHUG6xOxDeIFTEO4kV8s7oR38BpxDiIBfEN4kV8s7oR3ySGRJXNnnrqKVVWVs6qNNXV1WppadFbb71lbZu+j3lh83q9qqyslCTV1dXp4MGDVoBkMiud3++P2G7u9+KLL0ZsN4ehz9x++PBh1dXVxfcHwjZ2vF/x1pFY9Pf3q66uTtevX591UYXzFjpvLMaBAwcift+7d68kqbOzc9HHxuLF83k3zxXxBjVANMQ3iAcxDuJFfLN6Ed/AacQ4iBXxDeJFfLN6Ed8kxuN0AVJJe3u7AoFA1EoU74morKxMDQ0Nkm72xDArcX9//5z719bWqr6+XidOnIjI2jY0NKisrEx+v1+tra1WOZqamtTW1hZXmWAfO96veOtILGpqatTe3k7dQETPDzgv1s+7+dhqC2iwdIhvEC9iHCQz4pvkQnwDJxHjIB7EN0hmxDfJhfgmMYyospEdF5i5jllXV6fW1lb5fD75fL6ow/i8Xq+VfTUXTGxtbVVZWZm1OJr588SJE9aQQzjDrvcrnjoSCzOo2r9/Pwu0Akkmls97Ir3wgPkQ3yBexDgA4kF8A6cQ4yAexDcA4kF8Ez8SVTYyL0DT56tdjPb2dpWXl6uioiLmOYjNIYXmxbG+vl4NDQ2qrKyU1+u1en68+OKLs4YfYvkt9v1KpI4spK6uTtXV1QoEAqqpqbHlmAAWL97POwEP7EJ8g0QQ4wCIBfENnESMg3gR3wCIBfFNYkhU2cicD9Tv9+vEiRNz7tPY2BhzDwfzAhPPcHNzMT6/36/6+noVFRVZC+qZF8mnnnrK2hfOWuz7lUgdWUhRUZG1kKy5oB8A58X6eZ8+ZHyxC/ICEvENEkOMAyAWxDdwEjEO4kV8AyAWxDeJIVFlo+nDgGtqamYFOo2NjdZ+sTCzqdMrqt/vt7ZHC5bMi1JjY6M1H6b0m4X7Tpw4MW9PHIYKL6/FvF/x1pF43tuWlharXNGCdiQf8/zi9/sj3u9AIKD3339fkr1TW2D5xPp5n7mg88zP/Vznh0TqTbTziTmUnXqWOohvkChiHNiF+CZ1Ed/AScQ4SATxDexCfJO6iG8SZMBWAwMDRllZmSHJupm/V1dXR+zb2dlp7TMwMDDrWObzvF6vcfDgQaO2ttaorq6OOF5tbe2c5ZBkVFZWztpeXV1teL3eef+G6upqQ1LUY8N+ib5f8daR+d5bsy62tbVZ25qbm63tLS0ti/wrYYeFzhuGYRg+n8869zQ0NBi1tbVGZWXlnO//wMCAdbzOzs6I43AuSC7xfN47OzsNr9cbUQ+am5uN2tpaq36YzzHrUTz1xjBiO58cPHjQaGpqMhoaGpb8/4OlRXyDRBHjIBbEN6sX8Q2cRoyDRBDfIBbEN6sX8U1iSFQtkdraWqvy+Xw+o7m5OeLxpqamiGDI5/MZTU1NEft0dnZaFW/6483NzYbX6zXKysoiLkjTHTx4cM7H2traola4trY24+DBgxEB2sGDB2ed/GC/RN4vw4i9jsz33jY3NxuVlZVz1sXpQY4ZiBHsOCeW84Zh3AxezPfUvGgZxs16Vl1dbZ2P2traIt776e/vzPrCF3HnxXtNGBgYsK5FXq/XqKystM4F0+vB9P1jrTcLXSuampqsMh08eHCp/zVYRsQ3iBcxDhZCfLO6Ed8gWRDjIB7EN1gI8c3qRnyTGJdhGIYAAAAAAAAAAACAZcYaVQAAAAAAAAAAAHAEiSoAAAAAAAAAAAA4gkQVAAAAAAAAAAAAHEGiCgAAAAAAAAAAAI4gUQUAAAAAAAAAAABHkKgCAAAAAAAAAACAI0hUAQAAAAAAAAAAwBEkqgAAAAAAAAAAAOAIElUAAAAAAAAAAABwBIkqAAAAAAAAAAAAOIJEFQAAAAAAAAAAABxBogoAAAAAAAAAAACOIFEFAAAAAAAAAAAAR5CoAgAAAAAAAAAAgCNIVAEAAAAAAAAAAMARJKoAAAAAAAAAAADgCBJVAAAAAAAAAAAAcASJKgAAAAAAAAAAADiCRBUAAAAAAAAAAAAcQaIKAAAAAAAAAAAAjiBRBQAAAAAAAAAAAEeQqAIAAAAAAAAAAIAjSFQBAAAAAAAAAADAESSqAAAAAAAAAAAA4AgSVQAAAAAAAAAAAHAEiSoAAAAAAAAAAAA4gkQVAAAAAAAAAAAAHEGiCgAAAAAAAAAAAI4gUQUAAAAAAAAAAABHkKgCAAAAAAAAAACAI0hUAQAAAAAAAAAAwBEkqgAAAAAAAAAAAOAIElUAAAAAAAAAAABwBIkqAAAAAAAAAAAAOOL/AJyQJWaea752AAAAAElFTkSuQmCC",
      "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_alternative_hyp.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
}
