{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c2681a89",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib created a temporary config/cache directory at /tmp/matplotlib-9tehxpqc because the default path (/afs/csail.mit.edu/u/c/czw/.config/matplotlib) is not a writable directory; it is highly recommended to set the MPLCONFIGDIR environment variable to a writable directory, in particular to speed up the import of Matplotlib and to better support multiprocessing.\n",
      "/storage/czw/anaconda3/envs/sss/lib/python3.7/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "from hydra import initialize, initialize_config_module, initialize_config_dir, compose\n",
    "from omegaconf import OmegaConf\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.axes as ax\n",
    "import matplotlib.cm as cm\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "module_path = os.path.abspath(os.path.join('..'))\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(module_path)\n",
    "from data.subject_data import SubjectData\n",
    "samp_rate = 2048"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "306162d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "FLOAT_FEATURES = [\"delta_magnitude\", \"delta_pitch\", \"magnitude\", \"word_length\", \"rms\", \"pitch\", \"max_vector_magnitude\", \"mean_pixel_brightness\", \"max_global_angle\", \"gpt2_surprisal\", \"morpheme_count\", \"delta_rms\", \"face_num\", \"is_onset\", \"max_global_magnitude\", \"max_vector_angle\", \"max_mean_magnitude\", \"charecter_num\", \"word_diff\", \"bin_head\"] #NOTE that is_onset and bin_head are categorical variables, but for our purposes, can be treated as a float"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9fe7197a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'data': {'name': '???', 'high_gamma': False, 'samp_frequency': 2048, 'raw_brain_data_dir': '/storage-old/datasets/neuroscience/ecog', 'movie_transcripts_dir': '/storage/czw/seeg_decoding/updated_word_features', 'subject': '???', 'electrodes': '???', 'brain_runs': '???', 'rereference': 'None', 'normalization': False, 'despike': False, 'delta': -0.1, 'duration': 0.7, 'interval_duration': 1.0, 'words': [], 'cached_transcript_aligns': '/storage/czw/seeg_decoding/saved_aligns', 'val_split': 0.1, 'test_split': 0.1, 'preprocessor': 'stft'}}\n"
     ]
    }
   ],
   "source": [
    "# duration=1.5\n",
    "# delta=-0.5\n",
    "data_delta = -0.1\n",
    "data_duration = 0.7\n",
    "\n",
    "with initialize(version_base=None, config_path=\"../conf\"):\n",
    "    cfg = compose(overrides=[\"+data=finetuning_template\", \n",
    "                             f'++data.duration={data_duration}', \n",
    "                             \"++data.interval_duration=1.0\",\n",
    "                             f'++data.delta={data_delta}',\n",
    "                             \"++data.movie_transcripts_dir=/storage/czw/seeg_decoding/updated_word_features\"])\n",
    "    print(cfg)\n",
    "#    ++data.name=\"sentence_position_finetuning\"\n",
    "data_cfg = cfg.data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "00cb1b3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "elec = \"T1b2\"\n",
    "# elec = \"T1cIe11\"\n",
    "subj = \"sub3\"\n",
    "# elec, subj = \"O1aIb7_sub3\".split(\"_\")\n",
    "# elec, subj = \"LT3d3_sub2\".split(\"_\")\n",
    "# elec, subj = \"RT1aIa6_sub2\".split(\"_\")\n",
    "# elec, subj = \"RT1aIa6_sub2\".split(\"_\")\n",
    "\n",
    "\n",
    "data_cfg.subject = subj \n",
    "data_cfg.electrodes = [elec]\n",
    "data_cfg.brain_runs = [\"trial002\"]\n",
    "# data_cfg.brain_runs = [\"trial000\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "db5c089b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "10242it [00:01, 5615.53it/s]\n"
     ]
    }
   ],
   "source": [
    "subj_data = SubjectData(data_cfg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d9651247",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_control_idxs(features, control):\n",
    "    '''\n",
    "        features -- dataframe of word features per word\n",
    "        control -- the name of a feature, e.g. rms\n",
    "        returns\n",
    "            a list of indexs, each of which correspond with a subsample of the control conditions\n",
    "    '''\n",
    "    #restrict attention to high (low) rms and compare between targets\n",
    "    if control in FLOAT_FEATURES:\n",
    "        high = np.percentile(features[control], 75)\n",
    "        low = np.percentile(features[control], 25)\n",
    "        if control in [\"bin_head\", \"is_onset\"]:\n",
    "            low, high = 0.4, 0.6\n",
    "        assert high > low\n",
    "        control_high_idxs = features[features[control] >= high].index\n",
    "        control_low_idxs = features[features[control] <= low].index\n",
    "        assert len(control_high_idxs) > 2 and len(control_low_idxs) > 2\n",
    "        return [control_high_idxs, control_low_idxs]\n",
    "    elif control == \"idx_in_sentence\":\n",
    "        onset_idxs = features[features[\"is_onset\"]==1].index\n",
    "        offset_idxs = features[features[\"is_offset\"]==1].index\n",
    "        midset_idxs = features[(features[\"is_onset\"]==0) & (features[\"is_offset\"]==0)].index\n",
    "        return [onset_idxs, midset_idxs, offset_idxs]\n",
    "    else:\n",
    "        print(\"control not found\")\n",
    "        import pdb; pdb.set_trace()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "37d3fed6",
   "metadata": {},
   "outputs": [],
   "source": [
    "words_df, neural_data = subj_data.words, subj_data.neural_data\n",
    "# neural_data = neural_data[0].mean(axis=1)\n",
    "# neural_data = neural_data[0,:,:512].mean(axis=-1)\n",
    "# neural_data = neural_data[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8f458f90",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 10242, 1433)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "neural_data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f4b0607e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0fef9155",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pval2star(p):\n",
    "    if p > 0.05:\n",
    "        return 'ns'\n",
    "    elif p > 0.01:\n",
    "        return '*'\n",
    "    elif p > 0.001: \n",
    "        return '**'\n",
    "    else:\n",
    "        return '***'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "47516edc",
   "metadata": {},
   "outputs": [],
   "source": [
    "search_start = 0.0\n",
    "search_end = 0.5\n",
    "interval = 0.1\n",
    "onset_idxs, midset_idxs, offset_idxs = get_control_idxs(words_df, 'idx_in_sentence')\n",
    "\n",
    "min_pval = 1\n",
    "min_interval = (0,0)\n",
    "for interval_start in np.arange(search_start, search_end, interval):\n",
    "    #print(interval_start)\n",
    "    assert interval_start > data_delta\n",
    "    assert interval_start + interval < data_delta + data_duration\n",
    "\n",
    "    interval_start_idx = int((interval_start-data_delta)*samp_rate)\n",
    "    interval_end_idx = interval_start_idx + int(samp_rate*interval)\n",
    "\n",
    "    truncated_data_arr = neural_data[:,:,interval_start_idx:interval_end_idx]\n",
    "    #print(interval_start_idx, interval_end_idx, data_arr.shape)\n",
    "    assert truncated_data_arr.shape[0] == 1\n",
    "    \n",
    "    onset_data = truncated_data_arr[0,onset_idxs,:].mean(axis=-1).tolist()\n",
    "    midset_data = truncated_data_arr[0,midset_idxs,:].mean(axis=-1).tolist()\n",
    "    offset_data = truncated_data_arr[0,offset_idxs,:].mean(axis=-1).tolist()\n",
    "    \n",
    "    tstat, pval = stats.f_oneway(onset_data, midset_data, offset_data)\n",
    "    if pval < min_pval:\n",
    "        min_pval = pval\n",
    "        min_time = (interval_start_idx, interval_end_idx)\n",
    "(best_interval_start_idx, best_interval_end_idx) = min_time\n",
    "truncated_data_arr = neural_data[:,:,best_interval_start_idx:best_interval_end_idx]        \n",
    "onset_data = truncated_data_arr[0,onset_idxs,:].mean(axis=-1).tolist()\n",
    "midset_data = truncated_data_arr[0,midset_idxs,:].mean(axis=-1).tolist()\n",
    "offset_data = truncated_data_arr[0,offset_idxs,:].mean(axis=-1).tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "cf9a6f65",
   "metadata": {},
   "outputs": [],
   "source": [
    "# truncated_data_arr.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f5bf4a4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# len(onset_data), len(midset_data), len(offset_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7decbccf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_peak_boxplot(df,onset_data, midset_data, offset_data):\n",
    "    plt.figure(dpi=900)\n",
    "    fig, ax = plt.subplots(figsize=(5, 4))\n",
    "    g = sns.boxplot(df, x=\"label\", y=\"activity\", color=\"grey\", ax=ax, showfliers=False)\n",
    "    plt.ylabel(\"Response ($\\mu V$)\",size=25)\n",
    "    plt.xlabel(\"\")\n",
    "    plt.ylim(-250,650)\n",
    "\n",
    "    onset_peak = df.activity.max()\n",
    "    h = 50\n",
    "    onset_peak -= 3*h\n",
    "\n",
    "    _, f_pval = stats.f_oneway(onset_data, midset_data, offset_data)\n",
    "    f_stars = pval2star(f_pval)\n",
    "    g.plot([0,2],[onset_peak+2.5*h,onset_peak+2.5*h],lw=1.5, c='k')\n",
    "    g.text(1, onset_peak+2*h, f_stars, ha='center', va='bottom', color=\"k\", fontsize=25)\n",
    "\n",
    "    sns.despine()\n",
    "    ax.tick_params(labelsize=25, rotation=0)\n",
    "\n",
    "# g.fig.set_size_inches(15,15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0cf778ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = [\"Onset\"]*len(onset_idxs) + [\"Midset\"]*len(midset_idxs) + [\"Offset\"]*len(offset_idxs)\n",
    "all_data = np.concatenate([onset_data, midset_data, offset_data])\n",
    "df = pd.DataFrame({\"label\": labels, \"activity\": all_data})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "565f6f1c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 5760x4320 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAFzCAYAAAAdR1JWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAABbnklEQVR4nO3dd1gUV/s38O/QOyqKXVGxodgrUSzYI7YYo9EoakzRPCnGmMcklthLElsSNRo1+qAJWDBqLCkaewXELioooKIo0jvn/YMf8+7KLuzC7LLg93Ndezmze+bMDbvO3pw5RRJCCBARERGZMLPSDoCIiIioKExYiIiIyOQxYSEiIiKTx4SFiIiITB4TFiIiIjJ5TFiIiIjI5DFhISIiIpPHhIVKhRACiYmJ4DRARESkCyYsVCqSkpLg7OyMpKSk0g6FiIjKACYsREREZPKYsBAREZHJY8JCREREJo8JCxEREZk8JixERERk8piwEBERkcljwkJEREQmjwkLERERmTwmLERERGTymLAQERGRyWPCQkRERCaPCQsRERGZPCYsREREZPKYsBAREZHJY8JCREREJo8JCxEREZk8JixERERk8piwEBERkcljwkJEREQmjwkLERERmTwmLERERGTymLAQERGRyWPCQkRERCaPCQsRERGZPCYsREREZPKYsBAREZHJY8JCREREJo8JCxEREZk8JixERERk8piwEBERkcljwkJEpIejR49CkiT4+fkVuw43NzdIklSiOObMmQNJkrB58+YS1UNUVlgYquKYmBhcu3YN9+7dw5MnT5CSkgIAsLe3R5UqVVC3bl14eHigZs2ahgqBiIiIygnFEpb4+Hjs2bMHhw4dwtGjR/H48WOdjqtSpQq6deuGvn37YvDgwXBxcVEqJCIiIionSnxL6MCBAxgyZAiqV6+OiRMnIiAgALGxsRBC6PR4/PgxduzYgUmTJqFGjRoYNGgQ9u/fr8TPRkRUbEeOHEGvXr1w8+ZNncqnpaVh5syZeO+99wAAmZmZ8Pb2hr+/v87nPHjwIDp27Ihnz57Jz82dOxeTJ0/G8+fPdaojJiYGI0aMwC+//KLzeYnKBFEMOTk5YuPGjaJRo0bCzMxMmJmZCUmSCjxsbGxE/fr1Rdu2bUWXLl3EK6+8Itq0aSPq1asnrK2tNR6TX5+7u7vYsGGDyM7OLk6IZOISEhIEAJGQkFDaoRBpNGDAAAFAWFlZiS+++EKkpqYKIYQ4cuSIACDGjRsnl923b5+oV6+eXD4qKkoEBAQIAAKA6N69u7h27Zpcvm7dukL18nv//n0xbNgwufzSpUuFEEKkpKSIypUrCwDC1dVV/PLLL/Ixs2fPFgDEpk2bhBBCZGVliW+//VY4ODgIAKJZs2YiNzfXgL8hIuPSO2EJCAgQ7u7uBRIVGxsb4ePjI+bOnSsOHDggoqOji6wrOjpaHDhwQMybN0/06tVL2NraFkhc6tevL3777bdi/XBkupiwkKlLS0sTS5YsERUqVBAAhJubm9izZ49awhIZGSkGDx4sJxqvvfaauHXrllzHP//8I9q1aycACEtLS/H555+LlJQUOWHJzMwUS5cuFfb29gKAcHd3FwEBAWpxPHz4ULzzzjvC3NxcABBdu3YVly9fVktYjh8/Ljw9PQUAYWNjI6ZPny7i4+ON/BsjMiy9EpauXbuqJSqWlpZiyJAhIiAgQCQnJ5c4mJSUFLFjxw4xbNgwYWVlpZa8eHt7l7h+Mh1MWKisePr0qZg6daqwtraWWy7yExg7Ozs5iThz5ozG43Nzc8W2bdvkFpg6deoIR0dHtbpcXV3F999/LzIzM7XGcf36dTk5srCwEI0aNRIAhIeHh3yd9PPzE/fv3zfUr4KoVOmVsOQnEFWqVBFz5swRsbGxhopLPH78WMydO1dUrVpV/s9I5QcTFiprIiIixJtvvikkSZJbVDw8PMSePXt0Oj4jI0MsX75cuLi4yMfb29uLmTNniqSkJJ3jOH78uOjcubNcBwDRv39/ERYWVtwfjahM0KvTbeXKlfHtt9/i/v37mD17NlxdXfXtMqOzKlWqYObMmbh37x6+/fZbjh4iolIlSRLMzApeMs3NzfWq40Wa6iyMpvJmZmZ610NU5uiT3SQlJYlZs2bJnc+MSZ+/QExB/n1ufR/Xr1/X+RwnT54UkyZNEk2bNhWOjo7C0dFRNG3aVEyaNEmcPHmy2LEbql5VbGGhsiI+Pl5Mmzat0FtC3bt3F+fPn9dax2+//SYaNGggAIjatWsXuCVUrVo1sXbt2kIHGdy8eVMMHTq0wC2hpk2bCkmShLm5uZg4caKIiYkxxK+BqNTp3elWkiRRq1YtuWc6aWbIhCU5OVlMmDChyLomTJigV98iQ9WrCRMWMnUZGRniu+++E5UqVRIARN26dUVQUFCBTreDBg0SAIQkSWLUqFEiIiJCruPYsWOiY8eOcqfb6dOni+TkZLVOt0uWLJE73TZt2rTALabY2FgxefJkYWFhUWin2+bNmwsAws7OTsycOVMkJiYa+TdGZFjFSljyO962adNGHDlyxABhlX2qCYuNjY3o27evTo+oqKhC683OzhZ9+vRRSyBsbW1Fu3btRKdOnYSTk5Paa3379tVpaLih6tWGCQuZuldffVUepjxjxgyRkpIihNA8rHnv3r1yp1obGxsRHR0tAgMD1YY1X716VS6vaVhzfusJAPHNN98IIfIGIlSpUkXumLt582b5GE3Dmr/55ht5WLOnpyeHNVO5UqKEJX978ODBakP5SD1hqVu3rmL1zpgxQy1xmDRpknj69Kn8enJysvjqq6/UynzxxRelVq82TFjI1P3999/Cx8enQKunpoRFCCFSU1PFl19+KSZNmiSEECI9PV106dJFbN26tUDdLyYs+f744w/Rvn17ERcXJz83e/Zs8d577xUYpvxiwpIvOjpaDB8+XGzcuFGPn5bI9OmdsJw5c0Z06dJFTlby/7WyshIff/yxePbsmSHiLHMMkbBER0cLGxsbud633npLa1nV5MLW1rbQ+9qGqrcwTFiorNKWsOhDW8KiD20JC1F5pXe38o4dO+L48ePYtWsXGjVqJD+flZWFVatWwd3dHStXrkR2dra+VVMRVq1ahfT0dACAnZ0dVqxYobXszJkzUbt2bQB5U4avXLnS6PUSEREppdjj4IYMGYIrV67g+++/R5UqVeTn4+PjMXXqVDRr1gx79uxRJEjKs2vXLnl7xIgRqFSpktayVlZWGD9+vLy/e/duo9dLRESklBIN3Dc3N8fkyZNx+/ZtfPHFF7C1tZVfCw8Px7Bhw9CzZ0+EhoaWNM6X3s2bN3H79m15v1+/fkUe079/f3k7PDwct27dMlq9ROVV9+7dIYTA5s2bi11HZGQkhBAlimPOnDkQQsDPz69E9RCVFYrMNOTg4ID58+fj1q1b8PPzkydHEkLg33//Rbt27TBhwgQ8fPhQidO9lC5duqS237lz5yKPadOmDaysrLTWYch6iYiIlKTo1Ig1atTAxo0bERISgj59+sjP5+bm4pdffkGjRo0wd+5cpKWlKXlak/f8+XOMGDECbm5usLW1haOjI+rVq4chQ4bg+++/R2JiYpF1XL9+Xd62srKS+5EU5sVyqnUYul4iIiIlGWQuZ09PTxw8eBCHDh2Cp6en/HxKSgq+/vprNGrUCFu2bDHEqU1SQkICAgMDce/ePaSnpyM5ORmRkZHYs2cP/vOf/6BOnTpYvXp1oXXcu3dP3q5Vq5bGKb41qVOnjrwdGRlptHqJiIiUZNDFJ3r37o2QkBBs2rQJNWvWlJ+PiYnB+PHj0b59exw/ftyQIZgMNzc3vPLKK+jZsydatGgBCwsL+bWEhAR8+OGHmDhxotbjVVthnJ2ddT6vk5OTvJ2UlGS0el+UkZGBxMREtQcREZGuDL5aliRJGDduHG7duoUFCxbA0dFRfu3ixYvo3r07XnvtNdy5c8fQoRiVmZkZevXqBX9/fzx9+hQRERE4ceIE/v77b1y6dAnx8fFYs2YNKleuLB+zceNGLFmyRGN9KSkp8raNjY3Ocah2hFatw9D1vmjRokVwdnaWH7rceiIiIspnUXQRZdjY2GDGjBl45513MGfOHPz000/IysqCEAJBQUHYv38/pkyZgpkzZ6JChQrGCstgvL298eeff2p93cHBAe+99x5effVVeHt7y7dV5s6dCz8/P1StWlWtfFZWlryt2jpTFNWymZmZBV43VL0vmjFjBqZOnSrvJyYmvrRJixACqamppR0GEZkIOzs7nW/Hv8yMlrDkc3FxwerVq/Hhhx/iv//9L3bv3g0hBDIzM7FixQr88ssvmD17Nv7zn/8YO7RSUbt2bfz666/o1KkTACA1NRU///wzvvjiC7VydnZ28nb+JG+6UC1rb29f4HVD1fsia2trWFtb61x/eZaamgoHB4fSDoOITERycrJO19GXncFvCWnTsGFD7Ny5EydPnlQbSvvs2TN8/PHHpRVWqejYsSO6d+8u72tqmVH9gtNnlJXqX/KaviQNVS8REZGSjN7Cki8mJgbXrl3DtWvX0KxZM4SFhb3UzeTdu3fH0aNHAUDjRGyqfV30mc/m0aNH8raLi4vR6iXt7OzskJycXNphEJGJUG3pJu0MnrDcu3dPTkzyH9evX9dpZMnLpHr16vJ2XFxcgdcbN24sbz99+hSpqak6fcijoqLk7SZNmhitXtJOkiQ2/xIR6UmRhEUIgbt37xZITG7cuKGx1aSoKakLW8umvFL9PWlKGJo2baq2HxoaCi8vr0LrjImJwZMnT7TWYch6iYiIlKR3wnLz5s0CicmtW7c0dtgsKjFxcHCAh4cHmjdvjubNm6NZs2Zo3ry5WmvDy+LatWvytqura4HXO3ToAGtra2RkZAAATpw4UWRioTrHjY2NDTp06GC0eomIiJSkd8LStGnTAsOvikpMbGxs0KRJkwKJSd26dfU9fbmUlpaG33//Xd7XlDA4ODjAx8cHf/zxBwDA398f06dPL7Ref39/edvHx0fjbQhD1UtERKSkYt8S0pSkWFpaomHDhmpJSfPmzdGgQQOYmZXagCSTN3PmTMTGxsr7Q4YM0VjOz89PTizCwsKwd+9e+Pr6aiwbHByMAwcOqB2rjaHqJSIiUook9Fzj3MzMDGZmZqhfv36BxKRRo0awtLQ0VKxlxuHDh3Ho0CF88sknqFWrltZyWVlZmDlzptrstm3atMGFCxc0TiIkhEDr1q3l1ZGrV6+Of/75p0Cn14cPH8LHx0delLBVq1YIDg7WOjGRoeotTGJiIpydnZGQkKA2zT8REZEmeicsISEhaNq0qV7TuL9sgoKCMHToUJiZmeGVV15Bt27d0Lx5c1SuXBlWVlaIi4vDuXPn4O/vrzbaplKlSjh16pTayJ0XXbhwAd7e3vKcKU5OTnj//ffh7e0NCwsLnDt3Dt9//73cYmNra4tjx46hXbt2hcZsqHq1YcJCRET60DthoaLlJyz6aNiwIX777Te0bt26yLK7d+/G6NGji5zozdbWFv7+/jrHYqh6NWHCQkRE+mDHEgNo0qQJhgwZgooVKxZZ1s3NDUuXLkVISIhOyQoADB06FBcvXoSPj4/G2zGSJKFXr14IDg7WK6kwVL1EREQlxRYWA7tz5w6uX7+O6OhoPH/+HDk5OXBycoKrqyvat2+P+vXrl6j+qKgonDp1CjExMQCAmjVrwsvLq8QLCxqq3nxsYSEiIn0olrAsXboULVq0QMuWLV/KeVRIP0xYiIhIH4olLGZmZvJtBBcXF7Ro0UJOYFq0aIFmzZrBysqq0DqWL1+Ohw8folu3bnj11VeVCItMFBMWIiLSh+IJS351L/aBMDc3R6NGjeQEJv/fGjVqyGUCAwPxxhtvwMbGBvfv31dbmI/KFyYsRESkD8USlpEjRyIsLAzh4eHIycnRfDINHTkrVaqEFi1aoE6dOjh9+jRu3boFSZLwyy+/YMyYMUqERiaICQsREelDsdWaf/31VwBAeno6rly5gtDQUFy6dAmXLl1CWFgYEhMTNc6O+/TpUxw9erTA86ozvxIREdHLTbGEJZ+NjQ3atWtXYEKxiIgIOYG5dOkSTp8+rZaUqCYzkiShS5cuSodGREREZVSpDmsOCQnBjz/+iM2bNyM3NxfW1tbw8fHBhAkTOM9HOcdbQkREpI9SnTiudevWWL9+Pf7991+4uLggIyMDHh4eTFaIiIhIjUnMdOvl5YWAgAAIIfDNN99g7dq1pR0SERERmRCTmul2wIABOHjwIJydnREbG1vkvC1UdvGWEBER6cMkWljyDRgwAEDel9lff/1VytEQERGRqTCphKVOnTry9p07d0oxEiIiIjIlJpWwJCYmyttZWVmlGAkRERGZEsXmYRk0aBBatWqFli1bolWrVmjQoIHedYSEhMjb7u7uSoVGREREZZxBFj8EAHt7e3h6espJTP7aQba2thqPv3PnDlq1aoXU1FS4urri/v37sLS0VCI0MkHsdEtERPpQNGEpUPkLaweZmZmhQYMGcgJTv359CCFw+fJl/Pjjj0hMTIS1tTX27dsHHx8fJcIiE8WEhYiI9KFYwrJy5UqEhIQgNDQU169f19oHRdMCiEDe1PyWlpb48ssvMXz4cDRt2lRrWSr7mLAQEZE+DDIPS2ZmJq5evSonMCEhIQgLC0NSUlLBALQkJba2tmjVqhXatGmDtm3bom3btvDw8NDYkkNlDxMWIiLSh1Enjrtz545aEhMaGoqHDx9qD+6FZMbGxgYtW7bEqVOnDB0qGRgTFiIi0kepz3T75MkThISEyAlMaGgowsPDkZubq7G8JEnIyckxcpSkNCYsRESkj1JPWDRJTU1FWFiYWmvMlStXkJ6ezoSlnGDCQkRE+lBsHhYl2dnZoVOnTujUqZP8XE5ODm7cuIHQ0NDSC4yIiIhKhUm2sFD5xxYWIiLSB4fcEBERkcnTK2GZO3cuUlJSDBWLVikpKZg7d67Rz0tERESmQa9bQmZmZnB1dcXHH3+M9957DxUqVDBgaMDz58+xZs0arFixAnFxcexsW47wlhAREelD74Qlf24Ue3t7jB49GhMmTED79u0VDercuXP4+eefsX37dqSkpEAIwdFB5QwTFiIi0odeCcvJkyfx4Ycfyqsq5ycvDRo0wJAhQ9CvXz907txZ6wKH2qSmpuLkyZM4dOgQgoKCEBERASBvun4AaN26NVavXg0vLy+96iXTxYSFiIj0ofcoISEEtm3bhnnz5uHWrVt5lajMSGthYQEPDw80a9YMDRo0QI0aNVCxYkXY2tpCCIH09HTEx8cjJiYGt2/fxpUrV3Djxg211pP8kBo2bIhZs2bhzTff5LpC5QwTFiIi0kexhzXn5uYiMDAQq1atwunTp9Ur1TO5eDGEjh074uOPP8brr7/OtYPKKSYsRESkD0XmYbl69Sr8/f2xc+dOhIeHaz7R/yUx2k7XoEEDDBs2DGPGjIGnp2dJQyITx4SFiIj0ofjEcZGRkfj3339x8eJFXLt2Dffu3UNcXJw8HNre3h6VK1dG3bp10bRpU7Rt2xbe3t6oX7++kmGQiWPCQkRE+uBMt1QqmLAQEZE+2EGEiIiITB4TFiIiIjJ5TFiIiIjI5DFhISIiIpPHhIWIiIhMHhMWIiIiMnlMWIiIiMjkMWEhIiIik8eEhYiIiEweExYiIiIyeUxYiIiIyOQxYSEiIiKTZ1HaARCZCiEEMjIyjHoea2trSJJk8HMa6zxERIbChIXo/2RkZGDEiBGlHYZBBAQEwMbGprTDICIqNoMnLDdv3kRwcDDi4uKQkJCA3NxczJo1y9CnJSIionJEEkIIpStNSkrCqlWrsHbtWjx48KDA6zk5OQWeGzlyJO7fvw9JkhAQEICaNWsqHRaZkMTERDg7OyMhIQFOTk6lHQ4A490SSk9Px9ixYwEAW7ZsMUrLB28JEVFZp3gLy9mzZzFq1Cjcu3cPQN6XgCptF00vLy8EBARAkiRs2bIFM2bMUDo0okJJkmT02yY2Nja8VUNEpANFRwkFBwejT58+uHfvHoQQEELA3d0dQ4YMQY0aNQo9dty4cbC0tAQA7Ny5U8mwiIiIqIxTLGHJzs7GqFGjkJSUBABo1aoVzpw5g1u3bmHXrl3w9PQs9HhnZ2f06NEDQgiEhobi2bNnSoVGREREZZxiCcvWrVsRHh4OSZLQunVrnDhxAh06dNCrjs6dOwPIu40UFhamVGhERERUximWsAQFBcnba9euhZ2dnd51NG/eXN6+ffu2EmERERFROaBYwhIaGgoAqFu3Ltq1a1esOipVqiRvP3/+XIGoiIiIqDxQLGF58uQJJElCvXr1il2HhcX/H7SUnZ2tRFhERERUDiiWsOQPzSzJPBZxcXHytmprCxEREb3cFEtYqlatCiEEwsPDi13H2bNn5e3atWsrERYRERGVA4olLPkjfOLi4nDixAm9j8/Ozsb27dsBAObm5ujSpYtSoREREVEZp1jCMnjwYHl7+vTpGqffL8zChQsRFRUFSZLg4+MDR0dHpUIrNc+fP8fu3bvx4YcfwtvbG9WqVYO1tTUcHBxQp04d+Pr6YsWKFYiPj9epvsjISEiSpPfj4MGDesV9+fJlTJ06FS1atEClSpXg4OCAxo0bY/To0XrXRUREpAihoNatWwszMzNhZmYmhgwZIhISEuTX+vXrJyRJEmZmZmrH5ObmigULFghzc3P59ZMnTyoZltFdv35dDBw4UFhZWQkART7s7OzE8uXLRW5ubqH1RkRE6FTfi48DBw7oFHdWVpaYMWOGMDMzK7S+gQMHisePH5fod5SQkCAAqH1GXhZpaWnC19dX+Pr6irS0tNIOh4ioTFB0LaH169eje/fuSE1Nxe+//w53d3f4+fmhR48e8gy4ABASEoLY2FicOXMG/v7+uHv3LoQQkCQJU6ZMgZeXl5JhGd2VK1ewb98+tefMzc3h7u6OqlWrIicnB9evX5dn801NTcUnn3yCK1euYP369TovUte3b1+dylWpUkWncu+++y42btwo71taWsLDwwMODg64ceMGnj59CgDYt28fevfujZMnT8Le3l6nuomIiEpE6QzowIEDwtHRUW4tUX1IklTo88OHDxc5OTlKh2R0gYGBAoCwsLAQQ4YMEUFBQQVaEnJzc0VQUJCoWbOmWuvFjz/+qLXeF1tYlLRu3Tq1ugcNGiSio6Pl1zMzM8Xq1auFhYWFXObNN98s9vnYwsIWFiIifSi6+CEA9OvXD8HBwejatau8AKL4vxWb8/tUqD4vhICDgwMWL16MwMBAmJkpHpLRWVpa4u2338adO3ewe/duDB48GE5OTmplJEnC4MGDcfr0aVSrVk1+ftasWcjKyjJqvKmpqZg9e7a83717d+zatQs1a9aUn7O0tMQHH3yAtWvXys9t374dwcHBRo2ViIheTgbJDtzd3fHvv//izJkzmDJlClq0aAEzMzO15MXOzg49e/bEkiVLcO/ePUyfPt0QoZSKwYMHY/369ahTp06RZWvXro2vv/5a3o+Li8OxY8cMGV4Bv/zyCx49egQgL5Fas2YNzM3NNZadOHEiOnbsCCBvzaclS5YYLU4iInp5KdqH5UUdOnRQWwAxISEBKSkpcHZ2Zt8HFb6+vnj33Xfl/Rs3bsDHx8do59+5c6e83a1bNzRp0qTQ8u+++648Z84ff/yBjIwMWFtbGzRGIiJ6uRn1/ouzszNq1KjBZOUFL87qm5iYaLRzJycnq7Xo9OvXr8hj+vfvr3b8v//+a5DYiIiI8pX9DiPlwL1799T2XV1djXbua9euqfWZyZ8AsDDVqlWDm5ubvH/p0iVDhEZERCRjwmICdu3apbbfqVMnnY4bO3YsGjZsCHt7e9jb26NOnTro168fli5disePH+tUx/Xr19X2GzRooNNxquVerIOIiEhpBu3DUpi0tDScOXMGsbGxqFSpEjp16lRgJM3LICEhAStXrpT3W7RogWbNmul07NatW9X2U1NTERUVhUOHDmH27NmYNm0a5syZo7UDLaDeumNhYYHq1avrdG7VDsWRkZFFls/IyFBbGNOYt72IiKjsUzRh2bFjB3JzcyFJEoYPH651ArSVK1di9uzZapPJWVlZ4YMPPsDChQthaWmpZFgm7dNPP5VH6ADA/PnzdT62evXqcHNzg62tLeLj43H9+nWkp6cDANLT0zF//nycP38ee/fu1fo7VU0cHB0ddR5Wrppcqr6P2ixatEhtNBQREZE+FLsldPbsWYwYMQKjRo3Czz//rDVZ+e677zB16lQkJiaqzcWSkZGB7777DiNGjFAqJJO3ceNG/Pzzz/L+G2+8AV9fX63lJUlChw4dsH79ejx48AAPHjzAqVOn8PfffyM4OBjPnz/Htm3b1PqXHDp0CB9++KHWOlNSUuRtGxsbnWO3tbXVWIc2M2bMQEJCgvyIiorS+VxERESKJSyqi+JNmDBBY5lHjx5h1qxZACAnNM7OzrCzswOQN6/H77//jk2bNikVlsk6fvw4Jk+eLO/Xq1cP69atK/SYunXr4uzZs3j77bc13rqxtrbGqFGjEBwcjLZt28rPr1u3DmFhYRrrVO1wa2Ghe4ObatnMzMwiy1tbW8PJyUntQUREpCvFEpZz584ByEtEtA2N3bBhA1JTUwEAlStXxpEjRxAfH49nz57JE8cJIbBs2TKlwjJJly5dgq+vr9ynw9XVFQcPHoSzs7Mi9VesWBG7du2SW0yEEPj+++81ls1PFgHIt5N0oVqWw9SJiMjQFEtYwsPDAQBubm5a/3oODAyUtxcsWIBu3boByOu/snjxYnlI7c2bN3Hz5k2lQjMpN2/eRJ8+fZCQkAAgL7k4fPgwGjVqpOh56tSpg5EjR8r7f/75p8ZyDg4O8nZaWprO9ecnni/WQUREZAiKJSyxsbGQJEnrKJPHjx/j8uXLAPL6SowePbpAmVGjRsnbISEhSoVmMiIiItCrVy95yLGDgwMOHDiAli1bGuR83bt3l7cjIyM13rqpXLmyvJ2cnIzk5GSd6lbtKOzi4lL8IImIiHSgWMKS/xe36i0GVcePHweQd8vI29tbrdNmvqZNm8rbql+I5UF0dDR8fHwQHR0NIK/T6r59++R1eQzhxeTx6dOnBco0btxYbf/+/fs61a3aabaoqfyJiIhKSrGEJb+/hLYhrqrTv+ffCnqRviNPyorY2Fj06tULERERAPI6oAYFBWn9PShF9bYNoDmZVE0SASA0NLTIerOysnDlyhWtdRARESlNsYTF1dUVQgitfU9URxGp3qpQld+vA4DGFpiy6NmzZ+jdu7f8e7G0tERAQAD69Olj8HNfu3ZN3ra2ttbYqbd+/fqoVauWvH/ixIki67148aJafxdvb+8SRkpERFQ4xRKWVq1aAQCeP3+ulpwAwKlTp+ROuQ4ODmjfvr3GOvJbIIC89WrKusTERPTt21fuu2Nubg5/f38MGjTI4OcWQuC3336T9wtbI0g1nsDAwCKHKfv7+8vbzZo103k6fyIiouJSLGEZOnSovD1p0iQcPXoUmZmZuHDhAsaPHw8gr//KkCFDtE4Vf/78eXm7YcOGSoVWKlJTU/Hqq6/iwoULAAAzMzNs2rQJr7/+ulHO/8MPP6jNvTJkyBCtZf38/OTtuLi4QueDiY6Oxi+//KLxWCIiIoMRCsnIyBCNGjUSZmZmGh+SJAkLCwsRFham8fjs7GxRpUoVIUmSsLGxERkZGUqFZnTp6emiV69eAoAAICRJEhs2bChRnVeuXBETJkwQN27cKLRcbm6uWLFihTA3N5fPX6NGDZGamlrocYMGDZLLOzg4iBMnThQok5CQILp27SqXq169epH1apOQkCAAiISEhGIdX5alpaUJX19f4evrK9LS0ko7HCKiMkGxtYSsrKwQEBAAHx8fPHv2TGOZ+fPnw9PTU+NrBw4cQFxcHCRJQseOHWFlZaVUaEa3cuVK/PXXX/J+hQoVEBgYqDYPTWF69+6NTz/9VO25rKwsbNy4ERs3bkTbtm3Rs2dPtGzZEq6urvJaQiEhIdi+fTtu3LghH2dtbY3ffvutyD5BK1euxOnTp/HkyRMkJyfDx8cHEydORJ8+feDg4ICwsDCsXr1avm1nZmaGdevWlZu+RkREZNoUXfywZcuWuHLlChYsWIADBw4gOjoaNjY2aNu2LT766KNC+24sXboUQF7fi8LW0ykLXhydEx8fj0OHDul8fFH9dy5evIiLFy/qVM/WrVvRpUuXIsu6ubkhKCgIvr6+ePbsGTIyMvDjjz/ixx9/LFDW3NwcK1euLPPvE9GLxP+ta2bM81hbW2tde01JxjoPkaEomrAAeV+Sq1ev1vu4rVu3yttVq1ZVMqRyoXr16hg1ahSOHDlS5Bw1VatWxaRJk/DRRx+pTQxXFC8vL4SFheGjjz7Cnj17kJ2dXaBMhw4dsGLFikI78RKVVRkZGeV2AdaAgAC9FjglMjWSEEKUdhCkn6ioKFy9ehX3799HfHw8srKy4OjoiMqVK6N169Zo2rRpif+SevLkCY4dO4bo6GhkZmaiRo0aaN++vWJLCCQmJsLZ2RkJCQkv3UKI6enp8pciv0RMi+p7U97ws0ZlneItLGR4tWvXRu3atQ16jipVquC1114z6DmITI21tTUCAgIMfp709HSMHTsWALBlyxajJBLW1tYGPweRITFhISL6P5IkGb0VwsbGhi0fRDpgwkJERKTCGJ2v2fFafwZJWO7cuYOtW7fi5MmTuHHjBp4/f15g5ExhJEnS2OGTiIjI0Mpr5+uy3o9J0YQlOzsbU6dOxZo1a5Cbmys/z369REREVBKKJixvvPEGgoKCmKCQoow1N4axpKena9wuD8p6kzMRYJzO1+x4rT/FEpbdu3dj9+7d8sWqRo0aePvtt9GlSxfUrFkTdnZ2Sp2KXjLltXkWgHzBKi/KepMzEWD8ztfseK0bxRIW1QXxevbsiT179sDe3l6p6omIiOglpljCkr/Ssrm5ObZs2cJkhQyiRYsWMDNTbJHxUiGEkPt4mZmZlflbKLm5uWorgxMRGYJiCcvTp08hSRJatGiBGjVqKFUtkRozMzOYm5uXdhhERGRkiv2pmr9mTYUKFZSqkoiIiAiAgglL48aNIYRATEyMUlUSERERAVAwYRkzZgwA4NatW7h7965S1RIREREpl7CMHj0aLVu2BABMmzZNqWqJiIiIlEtYrKyssGPHDlSvXh179uzB2LFjkZycrFT1RERE9BJTbJTQsWPHAADffvstPvjgA/j7+2P//v0YOXIkOnfujGrVqsHKykrn+ry9vZUKjYiIiMo4xRKW7t27q80nIYRAfHw81q5di7Vr1+pVFxc/JCIiIlWKr9YshIAkSXLywnWFiIiIqKQUS1jq1KlT5mfsJCIiItOkWMISGRmpVFVEREREasr2oixERET0UlC8DwuR0lT7QeXk5JRiJKSJ6nvCPmtEZChMWMjkZWRkyNuXL18uxUioKBkZGbC1tS3tMIioHDJKwpKSkoKIiAjEx8cjIyMDFSpUQJUqVVC3bl1jnJ6IiIjKOIMlLA8ePMC6desQFBSEa9euITc3t0CZihUrokuXLnj77bfx6quvcpQRaWRtbS1ve3p6wtzcvBSjoRfl5OTILV+q7xURkZIUT1hyc3OxaNEizJs3D1lZWQDU72tLkiTvP3v2DHv37sXevXvRqlUrbNmyBc2aNVM6JCrjVBNZc3NzJiwmjH90EJGhKDpKKCcnB8OHD8esWbOQmZkJoGAnPE37QgiEhISgQ4cOOH78uJIhERERUTmgaMIyffp0BAUFyfsODg549913sXfvXkRGRiI5ORmZmZl4+vQpzp07h9WrV6Njx44A8v4yS0tLg6+vL6Kjo5UMi4iIiMo4xRKWGzduYPXq1XKT8KBBgxAeHo41a9bg1VdfRZ06dWBnZwcLCwtUrFgR7dq1w5QpU3D69GkEBgbC0dERkiQhKSkJM2bMUCosIiIiKgcUS1i2bNkiL1g4cOBA7N69G66urjod+9prr+HgwYMwNzeHEAKBgYFITk5WKjQiIiIq4xRLWA4fPgwg79bO999/r3fnu06dOmHcuHEAgKysLBw9elSp0IiIiKiMUyxhiYqKgiRJaNasGWrXrl2sOgYMGCBv379/X6nQiIiIqIxTLGFJSEgAAFSuXLnYdagem5iYWOKYiIiIqHxQLGGpVKkShBAlGuETExOjVh8RERERoGDCUr9+fQDA7du3ceXKlWLVsXPnzgL1ERERESmWsKj2P5k0aRLS0tL0On7Pnj1ywmJvbw9vb2+lQiMiIqIyTrGExc/PD/b29gCAc+fOoVu3bjqtrJuTk4PvvvsOb7zxBoC8UUYTJ06ElZWVUqERERFRGafYWkI1atTA119/jWnTpkGSJFy4cAGtW7dGt27d0L9/f3h6esLFxQVWVlZISkpCREQEzp07h507d+LRo0fylP01a9bE7NmzlQqLiIiIygFFFz+cOnUqYmJisHz5ckiShNzcXBw9erTQOVWEEPKcLVWrVsXhw4dRoUIFJcOickTTqt9ljRBC/jnMzMzK/IKB5eE9ISLTp/hqzd9++y06deqEjz76SK3lRHWV5hf3hRAYPnw4fvjhB1SpUkXpkKgcCQsLK+0QiIioFCi6+GG+119/Hffu3cO2bdswYsQI1K1bt8AqzTY2NvDy8sLnn3+OGzduICAggMkKERERaaR4C0s+S0tLjBw5EiNHjgSQ17n2+fPnyMjIgLOzs9xBl6go1tbWCAgIKO0wFJOeno6xY8cCyFuDy8bGppQjUo61tbXB6hZCICMjw2D1G1N6errG7fLA2tq6zN/mJNNksITlRebm5nBxcTHW6agckSSpXH2pq7KxsSm3P5vSMjIyMGLEiNIOQ3H5yWt5ERAQwM80GYRBbgkRERERKcloLSxJSUnyLSEnJydUqlQJFhZGOz0RlSMtWrSAmVnZ/XurPI4UY4d4MjSDZQwpKSn49ddfERQUhPPnz+PJkyfqJ7awQLNmzdClSxf4+fmhTZs2hgqFiMoZMzMzmJubl3YYRGREBvkTZe3atahduzbeeecd/PHHH3j8+DGEEGqPrKwsXLp0CT/88APat2+Pvn374s6dO4YIh4iIiMo4RVtYsrKyMHr0aOzcuVOeEO7F4cyqVF/7888/0bp1a+zduxfdunVTMiwiIioHOFKsbDDUSDFFE5b33nsPO3bs+P+VW1igX79+6N+/P5o1awYXFxdYW1urTc0fGBiIu3fvQpIkJCcnY8CAAQgODkbjxo2VDI2IiMo4jhQrGww1UkyxhOXo0aPYtGmT3KrSo0cPrF+/HvXr19dYvlWrVhg6dCgWLlyIDRs24OOPP0Z6ejrS0tLw3nvv4ciRI0qFRkRERGWcYgnLhg0b5O3evXtj//79Oo0CkiQJkyZNgru7O3r37g0hBI4dO4bbt2/D3d1dqfCIiKgc4Ugx02KMkWKKJSynTp0CkJeArFu3Tu8hyz169MCYMWOwZcsWAMDJkyeZsBARkUYcKfbyUSw9ffjwISRJgoeHB9zc3IpVx6BBg+Tt2NhYhSIjIiKisk6xhKVChQoAUKIFDFWPdXZ2LmlIREREVE4olrDUr18fQghER0cXu46YmBi1+oiIiIgABROW/KFmt2/fLnbHm/wVeV1cXNCjRw+lQiMiIqIyTrGExc/PD3Xq1AEAvP3220hOTtbr+N9++w1BQUGQJAmff/451xkiIiIimWJZgbOzM3bt2oU+ffrg4sWLeOWVV7BmzRp4eXkVelxqaioWL16MRYsWAQDGjBmDTz/9VKmwiKicUJ0ZOycnpxQjoRepvh+FzW5OVBKKJSzHjh0DAKxYsQJTp07F5cuX0bVrV7Rs2RL9+vVD8+bN4eLiAisrK7WZbvfv34+kpCQAwBtvvIGJEyfKdWnj7e2tVNikxalTp7B582acOHFC7pdUq1YtebHKohJRIqWpTsl++fLlUoyECpORkQFbW9vSDoPKIcUSlu7du6tNfJM/421oaCguXbqk9bj8bFySJAQEBMj9WLSRJAnZ2dnKBE0FpKSk4MMPP8TGjRsLvHb9+nVcv34d69evx4QJE7Bq1SrY29uXQpRERPSyUbyjSP6ihwDkfwtrIlRNctiUWLpycnIwbNgwHD58WH7O1tYWzZo1g4WFBa5du4bExEQAwMaNGxETE4P9+/dz8iYyCmtra3nb09OTnzsTkpOTI7d6qb5PREpSLGGpU6dOmZ9a+GU3c+ZMtWRl0qRJWLx4MSpVqgQgr/Vl8eLFmD9/PgDg0KFDmDVrFhYsWFAq8dLLRfX6Ym5uzoTFRPF7gAxFsYQlMjJSqaqoFMTExGD58uXy/ltvvYWffvpJrYy9vT3mzZsHAHLSsnz5ckyZMgU1atQwXrBERPTSKbsrR5GiVq1ahfT0dACAnZ0dVqxYobXszJkzUbt2bQBAWloaVq5caYwQiYjoJcbJTggAsGvXLnl7xIgR8m0gTaysrDB+/HjMnTsXALB7924sWbLE4DES0cuNQ9tNlzGGtjNhIdy8eRO3b9+W9/v161fkMf3795cTlvDwcNy6dQuNGjUyWIxERBzaXjYYamh7qSUsaWlpOHPmDGJjY1GpUiV06tQJTk5OpRXOS+3FYeedO3cu8pg2bdrAysoKmZmZch1MWIiIyFAUTVh27NiB3NxcSJKE4cOHa+0tvnLlSsyePVueMA7Iu83wwQcfYOHChbC0tFQyLCrC9evX5W0rKyu5f0ph8svduXOnQB1ERIbAoe2myxhD2xVLWM6ePYsRI0ZAkiT07t0br7/+usZy3333HT777LMC97gyMjLw3Xff4fbt29i9e7dSYZEO7t27J2/XqlVL52GJderUkRMWjhIjIkPj0PaywVBD2xUbJXTw4EF5e8KECRrLPHr0CLNmzQLw/38gZ2dn2NnZAcjrqPP7779j06ZNSoVFOsifDA7Iez90pXoLT7W1TJOMjAwkJiaqPYiIiHSlWMJy7tw5AHmJiLZOmxs2bEBqaioAoHLlyjhy5Aji4+Px7NkzTJ8+HUBe0rJs2TKlwiIdpKSkyNs2NjY6H6faqUq1Dk0WLVoEZ2dn+aHLbScibXJzc5GTk1NmH9nZ2cjMzERmZiays7NLPZ6SPnJzc0v7I0EvAcVuCYWHhwMA3NzctHaeDQwMlLcXLFiAbt26AcjrD7F48WIcP34cp0+fxs2bN3Hz5k00btxYqfCoEFlZWfK2hYXuHwnVsvmdb7WZMWMGpk6dKu8nJiYyaaFiCwsLK+0QiMjIFGthiY2NhSRJqF69usbXHz9+LHfIsbGxwejRowuUGTVqlLwdEhKiVGhUhPxbcgDkyeN0oVq2qEUQra2t4eTkpPYgIiLSlWItLPm3elS//FQdP34cQN4tI29vb41jtJs2bSpvP3r0SKnQqAgODg7ydlpams7H5b/nL9ZBZAjW1tZFruZeVqSnp2Ps2LEAgC1btuh1K9bUcfFDMhTFEhYbGxukpqZq7Xx57NgxeTv/VtCL9OkTQcqpXLmyvP3w4UOdj1NNKl1cXBSNiehFkiSVqy/2fDY2NuXy5yJSmmK3hFxdXSGEwM2bNzW+rjqKqHv37hrLJCQkyNuGmCWPNFPtK/T06VO1lpPCREVFydtNmjRRPC4iIqJ8iiUsrVq1AgA8f/5cLTkBgFOnTsmdch0cHNC+fXuNdURERMjb1apVUyo0KoLqrTgACA0NLfKYmJgYPHnyRGsdRERESlIsYRk6dKi8PWnSJBw9ehSZmZm4cOECxo8fDyCvSXfIkCFaJ/s5f/68vN2wYUOlQqMidOjQQe2+84kTJ4o8Jr9PEpDXpN2hQweDxEZERAQo2IdlxIgRmDdvHm7fvo0HDx7Ax8enQBkzMzNMmzZN4/E5OTnYv38/gLxhzi1btlQqNCqCg4MDfHx88McffwAA/P395XlxtPH395e3fXx8ihwlRESkpLI+94sQQv4ZzMzMDDY7rLEY4/1QLGGxsrJCQEAAfHx88OzZM41l5s+fD09PT42vHThwAHFxcZAkCR07doSVlZVSoZEO/Pz85IQlLCwMe/fuha+vr8aywcHBOHDggNqxRETGxLl4Xj6K3RICgJYtW+LKlSuYMmUK6tevDysrKzg5OaFHjx4ICgrC559/rvXYpUuXAsjLOrV9UZLhDB8+XK1V691338WNGzcKlHv48CHGjBmDnJwcAHl9l1577TWjxUlERC8nRVdrBvI6y65evVrv47Zu3SpvV61aVcmQSAeSJGHDhg3w9vZGWloaHj58iI4dO+L999+Ht7c3LCwscO7cOXz//feIjY0FkDeSa/369WW+KZOIygbOxVM2mPxqzSVVt27d0g7hpdeuXTv4+/tj9OjRSEtLQ2JiIpYsWYIlS5YUKGtrawt/f3+0a9euFCIlopcR5+J5uSl6S4jKvqFDh+LixYvw8fHR2HIiSRJ69eqF4OBgtZFhREREhmTwFpabN28iODgYcXFxSEhIQG5uLmbNmmXo01IJNG3aFH/99ReioqJw6tQpxMTEAABq1qwJLy8vLlpIRERGZ5CEJSkpCatWrcLatWvx4MGDAq9rSlhGjhyJ+/fvQ5IkBAQEoGbNmoYIjfRQu3ZtvPHGG6UdBhERkfIJy9mzZzFq1Cjcu3cPQN6oH1XaOmh6eXkhICAAkiRhy5YtmDFjhtKhERVKCIGMjAyDn0d1lWt9VscuCWtra3aOJqIyTdGEJTg4GH369EFycrKcqLi7u6N58+Y4d+6cxtaWfOPGjcNnn32G7Oxs7Ny5kwkLGV1GRgZGjBhh1HPmjxIwtICAAHbqI6IyTbFOt9nZ2Rg1apS8WnOrVq1w5swZ3Lp1C7t27dI6YVw+Z2dn9OjRA0IIhIaGap18joiIiF4+irWwbN26FeHh4ZAkCa1bt8axY8dgZ2enVx2dO3fG4cOHIYRAWFiY1lWdiQzBWHM8qN56MtatGkPNi0BEZCyKJSxBQUHy9tq1a/VOVgCgefPm8vbt27eZsJBRGXOOB1tbW6Och4iovFDsllBoaCiAvAngijuZWKVKleTt58+fKxAVERERlQeKJSxPnjyBJEmoV69eseuwsPj/DT7Z2dlKhEVERETlgGIJS35TekmGhcbFxcnbqq0tRERE9HJTLGGpWrUqhBAIDw8vdh1nz56VtzmbKhEREeVTLGHp3LkzgLxWkhMnTuh9fHZ2NrZv3w4AMDc3R5cuXZQKjYiIiMo4xRKWwYMHy9vTp09HTk6OXscvXLgQUVFRkCQJPj4+cHR0VCo0IiIiKuMUTVhatWoFIO/WzvDhw5GYmFjkcUIILFy4EHPnzpWfmzlzplJhERERUTmg6NT869evR/fu3ZGamorff/8d7u7u8PPzQ48ePeQZcAEgJCQEsbGxOHPmDPz9/XH37l0IISBJEqZMmQIvLy8lwyIiIqIyTtGEpW3btggMDMSIESOQnJyMp0+f4ttvv8W3334rlxFCFJinJX/doWHDhmHFihVKhkRERETlgGK3hPL169cPwcHB6Nq1K4QQ8gPIm0lUkiS154UQcHBwwOLFixEYGAgzM8VDIiIiojJO0RaWfO7u7vj3339x7tw5bN26FcePH8fVq1fVOuLa2dmhU6dO6Nu3L95++21UrFjREKEQERFROWCQhCVfhw4d0KFDB3k/ISEBKSkpcHZ2hr29vSFPTUREROWIQROWFzk7O8PZ2dmYpyQiIqJywCQ7jOTm5pZ2CERERGRCTCphycnJwcaNG9GkSZPSDoWIiIhMiFFvCWmTlZWFjRs3YsmSJbh3715ph0NEREQmplQTloyMDPz0009YunQpHjx4AADyBHJERERE+UqcsBw6dAj//PMPIiIikJCQAEdHRzRv3hzDhg1DixYtNB6TnZ2NNWvWYNGiRYiNjZWTlPz5Wtq0aVPSsIiIiKgcKXbCcvHiRYwfPx5Xr14t8Nru3bsxb948vPnmm/jpp59ga2srv3bo0CFMnjwZkZGRaq0pQgh07NgRM2fOxIABA4obFhEREZVDxUpYLly4gJ49eyIlJUXrLRwhBLZt24YnT57g4MGDAPJWcVadpj+/nLe3N7766iv06tWrOOEQERFROad3wpKbm4uxY8ciOTlZrXXE3t4eFSpUQHx8PFJTU+Xn//zzT/j7++P69ev45ptv1G799OrVCzNnzkTXrl0V/JGIiIiovNF7WPOBAwdw48YNOfHw9fVFcHAwkpKSEBUVheTkZJw9exb9+vWTj5k3bx6WLVsGIC+JadGiBY4cOYLDhw8zWSEiIqIi6d3CEhQUJG8PHz4cAQEBBcq0b98ef/zxB4YNG4agoCCEh4fLt47efvtt/PDDD7CwMIkR1UREMiEEMjIyDH6e9PR0jduGZG1tzRGYVKZJIv/+jI7atGmD0NBQSJKEO3fuwM3NTWvZu3fvwt3dXf5P0qVLF/z7778lCpjKh8TERDg7OyMhIQFOTk6lHQ4RgLzkYcSIEaUdhkEEBATAxsamtMOg/6P6WeN7oxu9bwlFR0dDkiS4u7sXmqwAQP369dGwYUO5z8q0adOKFSQRERG93PS+L5OQkAAAqFWrlk7la9WqhfDwcABAq1at9D0dEZHRWFtba7zNrTTVW0/GulVjbW1t8HMQGZLeCUtWVhYkSdL5w29lZSVv16xZU9/TEREZjSRJRmuaV52fioiKZtTFD83MTGqtRSIiIiojmEEQERGRyePYYiIiIhXGGN7Ooe3603tYs5mZGSRJQsWKFbUubqgqLCwMz549gyRJ6Natm25BSRL+/vtvfcKiMobDmonIVJXX4e1lffh0sVtY4uPjdZ5TJT+j06W8trWJiIiI6OVVrBYWQ5MkCTk5OQY/D5UetrAQkakyxi2h0hraXpYbBPRuYRk3bpwh4iAiIjIJxhrezqHt+tG7hYVICWxhISIifXBYMxEREZk8JixERERk8piwEBERkcljwkJEREQmjwkLERERmTwmLERERGTymLAQERGRyWPCQkRERCaPCQsRERGZPCYsREREZPKYsBAREZHJY8JCREREJo8JCxEREZk8JixERERk8piwEBERkcljwkJEREQmjwkLERERmTwmLERERGTymLAYSGpqKg4cOIDPPvsMvXr1Qq1atWBraws7OzvUrFkTffr0wYIFC/DgwQO96pUkSe/H2rVr9TrH3bt3MWvWLLRt2xZVqlSBra0tGjRogKFDh2LHjh3IycnRqz4iIqKSkoQQorSDKE9iY2Px4YcfYt++fUhNTS2yvKWlJaZNm4Y5c+bAysqqyPKSJOkd05o1a/Dee+/pVHbFihX473//i4yMDK1lOnfuDH9/f9SrV0/vWPIlJibC2dkZCQkJcHJyKnY9RET0crAo7QDKm6ioKAQEBKg9J0kS6tevj2rVqsHc3Bzh4eF4+PAhACArKwuLFi1CaGgogoKCdEpa8nl7e8PW1rbIcnXq1NGpvnnz5mHWrFnyvpmZGTw8PFCpUiW1mE+fPg1vb2+cP38e1apV0zleIiKiYhOkqPPnzwsAQpIk4ePjI/z9/cWTJ08KlDt69Kjw8PAQAOTH9OnTi6xftXxERIRicR88eFBIkiTX3blzZ3Hz5k359ZycHLF9+3bh4OAgl3nllVeKfb6EhAQBQCQkJCgRPhERlXO8JaSw4OBgLFy4EHPnzoWHh0ehZRMSEuDl5YVr164BAKysrHD//n1UrVpV6zGqt4QiIiLg5uZW4piFEGjdujUuXboEAGjcuDGCg4NhZ2dXoOxff/2F3r17y/u7du3C0KFD9T4nbwkREZE+2OlWYW3atMGOHTuKTFYAwNnZGcuXL5f3MzMzsW/fPkOGp9HBgwflZAUAVq5cqTFZAYBevXrhjTfekPcXL15s8PiIiIiYsJQyHx8ftX4oN27cMHoMO3fulLfr1auHPn36FFr+3XfflbfPnz+P6Ohog8VGREQEMGEpdebm5nB2dpb3ExMTjR7D/v375e2+ffsWORKpa9eusLe3B5B3O+mPP/4waHxERERMWEpZWloaHj9+LO+7uroa9fyPHz/Go0eP5P3OnTsXeYyFhQXat28v76veTiIiIjIEJiylbM+ePcjNzZX3O3XqpPOxn332GZo1awYnJyfY2tqiVq1a6NGjB+bMmYOIiAid6rh+/brafoMGDXQ6TrXci3UQEREpjfOwlKLs7GwsXLhQ3nd1dYWPj4/Ox+/YsUNtPyYmBjExMTh69CgWLFiAiRMnYvny5YXO1XLv3j21fV3nbFEtFxkZWWT5jIwMtcnoEhISAJTOLTAiIjItjo6ORXZHYMJSihYvXozLly/L+1999RVsbGx0Pr5KlSqoX78+HBwckJCQgBs3biA5ORlAXjK0bt06nDt3DkeOHFHrJ6PqxYRBW7kXqQ5FTkpKKrL8okWL8PXXXxd4vnbt2jqdj4iIyi9dprhgwlJK/vzzT8yZM0fe9/LywuTJk4s8zsPDA++88w58fX1Rv359tdeys7Nx6NAhfPHFFwgLCwMAhISEYOTIkThw4IDG+lJSUtT2dU2YVFttXqxDkxkzZmDq1Knyfm5uLp49ewYXF5diLTdQ1iUmJqJ27dqIioriPDQvKX4GiJ+B/8/R0bHIMkxYSsGNGzcwcuRIeRHBihUrYtu2bTA3Ny/y2KtXr2p9zcLCAq+++ip8fHwwfPhwefTPwYMHsXfvXvj6+hY4Jisrq0AdulAtl5mZWWR5a2trWFtbqz1XoUIFnc5Vnjk5Ob30F6qXHT8DxM+Abl6KTrebN28u1irHRT02b96sdyxRUVHo06cPnj17BgCws7PDvn37ULduXcV+XhsbG2zfvl1txtzVq1drLPviBHHp6ek6nUO1XP4QZyIiIkN5KRIWUxEbG4tevXohKioKQF6rQ1BQELy8vBQ/l6OjI95//315//jx4xqTEQcHB7X9tLQ0nepXXYn6xTqIiIiU9lLcErK1tS10fZ6S1KurZ8+eoXfv3rh16xaAvFsqv/32m9q6PErr3r27vJ2eno6oqCg0bNhQrUzlypXV9h8+fAgXF5ci61adu0WX8qTO2toas2fPLnCbjF4e/AwQPwP64eKHRpCYmAgfHx9cuHABAGBmZgZ/f3+MHDnSoOe9desWGjduLO+fOnWqwMRwV69eRfPmzeX9/fv3Y8CAAUXWPWLECAQGBgIAXn/9dQQEBCgUNRERUUG8JWRgKSkpGDBggJysSJKEDRs2GDxZAdRv2wAF+6sAQMOGDdU60IaGhupUd0hIiLzdtGnT4gVIRESkIyYsBpSeno5Bgwbh5MmT8nM//PADxo8fb5TzX7t2TW1f07T/VlZW6Nixo7x/4sSJIut99OgRbt++Le97e3uXIEoiIqKiMWExkKysLAwfPhz//POP/Nx3332n1hHW0H799Vd5283NDdWrV9dYbvDgwfL2X3/9pba2kSb+/v7ydoUKFdCtW7cSRkpERFQ4JiwGkJOTgzfffFNtFeQFCxbgk08+MVoMe/fuxd69e+X9IUOGaC07atQoudNXVlYWlixZorVscnIyVq1aJe+PHj1a57lbiIiIiosJi8KEEJg4caLaOj+zZs3CF198UaJ6ExIS8Nprr+HixYtFlt2+fTtGjRol79vZ2eHzzz/XWr5WrVp499135f2VK1di586dBcplZWVh/PjxuH//PoC8UVJffvmlPj8GUZnh5uYmz7l09OhRxert3r17ieZyotJ39epVTJ48Gc2bN4eTkxPMzMwKfU+fPHmCr7/+Gp07d0alSpVgYWEhl/fz8zN6/GUV/zRWWGBgIH755Rd538bGBmfPnkW/fv10Or5FixZYunRpgeeFENi1axd27dqFJk2aoG/fvmjVqhWqV68Oe3t7JCUl4fLly9ixYwfOnz8vHydJEjZt2oRq1aoVet45c+bgwIEDCA8PR05ODkaMGIE333wTQ4YMQaVKlXDz5k2sWbNGnvIfAJYtW6b1NlNpycnJwdGjR7Fv3z6cPHkSjx49wuPHj2FnZ4eqVauiQYMGGDBgAAYNGoRatWqVdrikIz8/P7X/VwAwZswYbN26Va96fH19sW/fPrXnPv30U3zzzTcljpFMg6GvAVu3bsXEiRMLzBKuTVhYGHr37l3krXbSgSBFbdq0SQAo9qNbt24a642Pj9e7LkdHR7Ft2zadY79586aoXbu2TnV//vnnCv3GlPPHH38IDw8PneK3sLAQH374oXj69Glph23S6tatK//Ojhw5UmpxjBs3rsB7aG9vL5KSknSuIzY2VlhYWBSo59NPP9VY3lA/e7du3eR6N23apFi9xmQqn4sXGfoaEBMTI6ytreU6rK2tRYcOHUTfvn3lx+HDh+Xyubm5wtPTUy4vSZLw9PQUvXv3lst/8803hvhVKE71u03b95ShsYWljLC1tcX48ePxzz//4N69e4WWdXZ2xrhx4/Dpp5+iTp06Op+jUaNGCAsLw7Rp07Bt2zaNs956eHhgyZIlGDhwoN4/g6EIIfDxxx+r9a0B8ibnq1+/PqpXr47k5GTcv38fT548AZC3UOSqVasQGBiIQ4cOwdPTszRCpxJISUnBzp07MW7cOJ3K+/v7Izs728BRUWkw1jXgf//7HzIyMgDk3Uq/cOFCoZOSnj9/HpcvXwaQN//W0aNH0bVr1+L+mC89JiwK8/PzM8g9SWtra2zcuBEA8PjxY4SFheH+/fuIi4tDRkYGHBwcUKlSJbRo0QItWrTQaSFFTSpUqIANGzZg+fLl+OeffxAVFYWUlBRUr14dnp6eaN26tZI/VokJIfDWW2+pjVxycXHBnDlzMHLkSLWZfIUQOHPmDL755hvs2rULQN7Mvt7e3jh8+DDat29v9PhJf25uboiMjAQAbNmyReeEZcuWLQDybpPWqVOnyMQ//xxk2ox5DVDtQzhx4sQiZ1BXLd+1a1cmKyXEhKUMcnV1Ra9evQx6DkdHR7XhzqZq5cqVaheqDh06YN++fahSpUqBspIkoXPnzti5cye2bt2K8ePHIycnB8+fP8eIESNw6dIlrphaBrRt2xa2tra4fv06jh49iqioKNSuXbvQYy5fvixPitilSxeYmZkVmbBQ2WDMa0D+orUAivzMFac8FY6jhKjMunHjBv773//K+02aNMGhQ4c0Xqhe9NZbb2HNmjXyfmRkJD766CODxEnKe+uttwAAubm5+N///ldkedUOu2PHjjVYXGRcxr4GqHa01aUVW9/yVIRS6TlDpIAJEyaodWY7fvy43nX06dNHrsPc3FxERkZqLKetw9mVK1fElClTRJMmTYS9vb1wdHQUnp6e4rPPPhMPHz7UOY6rV6+KadOmiY4dOwoXFxdhaWkpbGxshKurq2jfvr2YOHGi2LRpk84dBJ88eSK+++470bt3b1GnTh1hY2MjnJ2dRdOmTcXkyZPF6dOntR4bERGhSEdxJal2un3ttdfE/fv3hZmZmQAgmjZtWuix2dnZolq1agKAsLGxEc+fP1fr+KpUp9uEhASxdOlS0aFDB1GpUiVhZ2cnGjZsKMaOHStOnDghl9On0y0/F4UzxjVA9f0q6jF79mwxe/bsEv2O0tPTxZYtW8TQoUNFvXr1hL29vTA3NxeOjo7C3d1d9O/fX8yePVucPn1a5Obm6vQz/vnnn+L9998XzZs3Fy4uLsLKykrUqFFD9OrVS6xcuVIkJydrPVZTh/fCHobshM2Ehcqkx48fq/XWHzBgQLHquXDhgtp/tqlTp2ospylhWbx4scZRJ/kPR0dH8ffffxd6/tzcXPHZZ5/JX75FPYr6chZCiOXLlwtnZ+ci6xo9erRITU0tcLwpfjG9mLAIIUTPnj3l586dO6f12D/++EMu98YbbwghhOIJy4kTJ4ocYffxxx+LrKwsnRIWfi6KZqxrgDETltDQUNGoUSOdj//tt98K/dlu374tevToUWQ91atXFwcPHtRYhyklLOzDQmXSoUOH5N76ADBhwoRi1dO2bVt4enrKPfl///13fPvtt0UeN2/ePMyaNQtAXn8fDw8P2NjY4MaNG4iNjQUAJCUlYdCgQbh69Srq1q2rsZ4vv/wSy5Ytk/clSULDhg1Ro0YNmJmZIT4+HuHh4UhOTgaQdwtEm9zcXLz33ntYv369xvrS09Nx5coVuS5/f39ERkbi77//Vlve3tbWFn379gUA/Pvvv0hPTwcAtG/fHpUqVSpw3hYtWhT5+zKEcePGyUtfbNmyRWuHSdXbQbp20NXHhQsX0L9/fyQlJcnPVaxYER4eHsjOzsa1a9eQlJSEFStWwNLSUqc6+bkomrGuAR06dICNjQ0A4Ny5c4iPjwcANG/eHDVr1lSry93dHQDk39Pt27dx584dAECNGjUKjERS/R09fPgQPj4+ePr0qfxchQoV0LhxYzg6OiI1NRUPHz5EZGQkhBAACn/fg4OD0b9/f7X5X5ycnNC0aVPY2dkhOjoa4eHh8rl9fX3x22+/YejQoWr1eHp6om/fvoiJicGVK1cA5H2+O3TooPG8mj4LijFYKkRkQO+++66c0UuSJBISEopd19SpU9X+QoiNjS1QRrWFpVKlSkKSJFGhQgWxadMmkZmZKZfLzc0VmzdvFlZWVnL5MWPGaDzvw4cPhaWlpVxu0qRJGm8j5ebmipCQEPHll1+KLl26aP05Fi1apPY7+eijj0R0dLRamYyMDLFmzRphZ2en9pe/NqYy34amFpbk5GRhb28vAIjKlSurvQ/5nj9/LmxsbAQAUa1aNZGdnS2EUK6FJT09Xbi7u8vl7OzsxJo1a0RGRoZcJjU1VSxatEhYWFgISZKEi4tLoS0s/FzoxtjXACH0n0NHtbVl3LhxhZb94IMP5LI1atQQ+/btEzk5OQXKxcfHi+3bt4vevXuLX3/9VWNdcXFxombNmnJ9jRs3Fr///rv8+c93/fp10atXL7mcs7Oz3rfFjYkJC5VJ7dq1k//zNGrUqER1+fv7q12s9u/fX6DMixMC2traipCQEK11fvvtt2plNd0j3rJli1ymsC8cVS9ecPLdvHlT/pKTJKnICQOPHj0q384yNzcXERERGsuZwheTEJoTFiGEeOutt+Tng4KCChz3008/ya+rNvUrlbAsW7ZM7Utz7969Wn+GDRs2FGg+1/Slx8+Fbox9DRDCsAlL/fr15bJ//fWXTnFre9/Hjh0r19W+fXuRmJiotY6srCzRv39/ufyECRM0ljOFhIWjhKhMUm3m1Ha7RVcvHq/LFNozZsxAq1attL7+7rvvwtbWFgCQlpaG4ODgAmWio6Pl7VdeeUWnWLWNNFi+fLk8ImH8+PFqa0lp0q1bN0yaNAlA3lTm69at0+n8pkZ1xE/+PCuqVJ8zxOign376Sd4eOXJkoRMqTpw4ET169CiyTn4udFPa1wClKfW+R0dHY9u2bQAAKysrbN++HY6OjlrrsLCwwE8//STfrty2bRsSEhL0Cd1omLBQmaQ6v4Gzs3OJ6nrxeNW6tcm/qGtjb2+vNsnejRs3CpTJvy8OQG2NJn3l5ubKFygA+Pjjj3U6bvTo0fJ2fl+QsqZnz57yejD79u1Te+/u3r2LEydOAABatmyJli1bKnruq1evyn0AAGDKlClFHvPBBx8UWYafC92U9jVAaUq977/++qs8o/PAgQPRoEGDIo+pVasWunXrBgBIT0/HqVOnin1+Q2LCQmWSamc71Y6BxfHi8fmdCbWpV69ekYtJAlDrkPf8+fMCr7dt21bePnDgAL744oti/WVz6dIlJCYmAgAqV66s8zIDzZs3l7dDQ0PljnxliZmZGcaMGQMAyMzMxK+//iq/ZujWFdVFRh0dHeHl5VXkMX379oUkSYWW4edCN6V5DTAE1fd9zJgxOHnyZLHqOX78uLzds2dPnY9Tfd81tQibAo4SojKpQoUK8pog+Rfl4nrx+IoVKxZaXpdkBQDs7Ozk7dTU1AKvd+3aFW3atJEvDosWLcLy5cvh4+ODnj17okuXLmjbtm2RE07l99wH8i7iuq4MriozMxOJiYkl/ku1NIwdOxaLFy8GkJekTJ48GUIIeSVnc3NztVYDpdy+fVve9vDwKDIRAfJa3tzc3BAREaG1DD8XuinNa4AhfPTRRzhy5AgAIDw8HF26dEHDhg3Rr18/eHt7o2vXrkUuBQCov+8///wz9u7dq9P5VT/PcXFxekZvHExYqEyqWLGifLEqafPti8cXNSzPyspK73No+itVkiTs3LkTAwYMwPXr1wHk/WW3f/9+7N+/H0DeMMQ+ffrAz88Pr776qsa6VYdBJiUl4dChQ3rHBwAJCQkm+cVUlKZNm6Jdu3a4cOECzp49i1u3biE2NhZ3794FAPTp00enC72+8oe3Anlr1+jKxcWl0ISFnwvdlOY1wBAGDx6MhQsX4quvvpKHK4eHhyM8PByrV68GkDfE+PXXX8fbb7+N6tWra6xH9X0PCQkpVizsw0KkoPr168vbV65cKVGzdf78C5rqNjQ3NzeEhIRg1apVGuetSExMxI4dOzBw4EB07txZ4xddSkqKIrEUNqeDqVOdX2XLli0Gn3sFyGt9yKdPEqvL7Qt+LopWXq4BqmbMmIHg4GCMGTMGDg4OBV6/fPkyZs2aBXd3d63zRSnxvpvqe86Ehcok1V70CQkJGju16urcuXPytp2dndFXpLa2tsZ//vMfXLp0CTExMfjf//6HSZMmFegsd+bMGfTo0UPtL3tAvcNgs2bNIPKmK9D74ebmZowf1yBGjRolj3LYsmULAgMDAeT9bgy1iKfqInmqk8YVRdey/FwUrjxdA1S1bNkSW7duxbNnz3Dy5EksWLAAffr0UeuUm5qaimnTpmH58uUFjld93wMDA4v1nm/evNkYP6remLBQmZTfoz3f9u3bi1VPcnIy9u3bJ+937twZFhald6e0Ro0aGD16NH766Sfcvn0bISEhGDZsmPz6vXv38P3336sdo3q7ozSGY5oCFxcXDBgwAAAQFRUl90l4/fXX1S70SnJ1dZW3IyMjdTpGCKFzWVX8XBRUXq8B+SwtLeHl5YUvvvgChw4dQlxcHNatW4fKlSvLZWbPnl2gRaU8v+9MWKhM6tKlCxo1aiTvb9y4EWlpaXrXs3nzZrX/8EUNVza2Vq1aYceOHWrzdxw+fFitTKdOneTtJ0+eyH03lGBm9v8vEaY6WiSfppFAhlyZWfWv8Lt376r1HdDm5s2bJe4gCvBzAbw814B89vb2eOedd+TWQyCvte7MmTNq5VTf9xdfKwlTeM+ZsFCZJEkSPvnkE3k/JiYGX3/9tV51PH78WF4PCADq1KmD1157TbEYlSJJEgYNGiTv569VlK927dpo2rSpvK/af6Ok7O3t5e3ifBkY08CBA9U6S9arVw9dunQx2Pk6dOgg910RQqh9kWijOuy6pF72z8XLdA1Q1b17d7XbPi++7/nrGAHAnj17FOtAawrvORMWKrMmTpyoNnfBsmXLdG4WTk5OxpAhQ9Tu+69evdqoTcH6/JWi2u9B0wgG1Qv3d999J48uKSnVIdyqwx5NkZWVFZ4+fSrfh797965OQ42Lq0KFCvD19ZX3Fy5cWGiHxydPnmDlypVF1svPhe7K+jUgnz7veUZGhjx7MVDwfR82bJg8c29iYiI+/fRTRWJUfc/v3r1bKq0sTFiozLK0tMT27dvl3vS5ubl466238PXXX6uN4HjRpUuX0K1bN5w+fVp+bvLkyWp/rRrDJ598gi+++AJRUVGFlouIiMCPP/4o73t7excoM27cOHkm1+TkZPTq1UttAiltrly5gkmTJmHTpk0aX2/Tpo28vWnTJpMd7lhapk+fLjeVR0VFYeTIkRrn3Hn+/DmGDBmicQLBF/Fzobuyfg3Id+/ePXTt2hV79+6VZ6nVZvbs2fJnzMrKSu0WEJA31f6SJUvk/Z9//hnvvfeexs+lqpSUFGzevBk+Pj4aX/f09JSTuadPn2pcCsPQSr9nEVEJNGzYEIcOHcLAgQMRHx+PnJwczJkzB+vXr8eIESPQsWNHVKtWDSkpKYiMjMTevXvx119/qV0Uxo0bp9Nfvkp7/vw5Vq5cicWLF8PLywvdunVDy5YtUaVKFVhaWuLRo0c4duwYNm/eLP8l7eTkhA8//LBAXVZWVti1axc6dOiAp0+f4sGDB/D29kbPnj0xcOBANGnSBI6OjkhOTsbDhw8REhKCv/76S/6LW/WvVFWjRo3CsmXLIIRAaGgoatasiTZt2qBixYpy60Xz5s0xf/58A/2WTFuHDh0wZcoUeZ6Mffv2oUWLFnj//ffRsmVL5Obm4vz58/jxxx/x4MEDuLu7w8nJqdCZRPm50E9ZvgaoOnHiBE6cOIHKlSvj1VdfRfv27VGvXj04OzsjLS0N169fx/bt29WSrClTpqBChQoF6nrjjTdw9uxZeRTRunXrsHPnTrz55pvw8vKSO+bGx8fjxo0bOHv2LP7880+kpqZqnbPIyckJAwcORFBQEADAz88PCxcuRIMGDdSG9c+fP19t1lxFKbOGIlHpunr1qtrqrbo8bG1txbx580Rubm6R9RdnpVLVFYZnz55d6Ou6POzt7cXhw4cLPeft27eFh4eHXvUCEGvWrNFa55dfflnoscZYuVXbas3FpdRqzULkrXY7ZMiQIn/HFSpUEBcuXChyxV9+LorH0NcAIQy3WnNERITe742vr69IT08v9Pzz588XkiTpVW/VqlULjbNWrVqFHm/I1bt5S4jKBQ8PD5w7dw7/+9//4OXlpdaj/UWurq545513cPPmTXz11VcG7edQmHfeeQcTJkyQF+/TxsbGBm+++SauXLmC3r17F1q2QYMGCA4OxqpVq4qc/MrBwQG+vr7Yvn07/Pz8tJabP38+/vnnH4wZMwaNGzeGg4NDqf3OTJGFhQV27tyJZcuWafxrF8jrKHnhwgWtLRaq+LkonrJ4DchXtWpVLF26FF27di1yEsLGjRtj/fr12LNnT5GTEH755ZcIDQ3F8OHDiyzbpEkTfP755zh69KjWMm5ubrh06RIWLVoEb29vuLq6Fmvm7+KShDDxsYpExfD06VOcPn0ajx49QlxcHGxsbFC1alW4u7ujbdu2hV7MSsP9+/dx+fJl3Lt3D8+fP4ckSXB2dkbjxo3Rvn17tUnK9BEeHo4LFy7g8ePHSEpKgr29PapWrYomTZrA09NTnmyNlJGRkYG///4bt2/fRkZGBmrUqIGOHTvC3d29WPXxc1F8Ze0akC89PR2XLl1CeHg4Hj16hLS0NNjb26NatWpo3bq12sgvfaSlpeHkyZOIiIiQh+A7Ozujfv368PT0RI0aNZT8MQyCCQsRERGZPNNMMYmIiIhUMGEhIiIik8eEhYiIiEweExYiIiIyeUxYiIiIyOQxYSEiIiKTx4SFiIiITB4TFiIiIjJ5TFiIiIjI5DFhISIiIpPHhIWIiIhMHhMWIiIiMnlMWIiIiMjkMWEhIiIik/f/APTyWCgYlyUsAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_peak_boxplot(df, onset_data, midset_data, offset_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d2c0f10f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_best_interval(search_start, search_end, interval, target_idxs):\n",
    "    #global variables: \n",
    "#         data_delta\n",
    "#         data_duration\n",
    "#         neural_data\n",
    "\n",
    "    target_onset_idxs = np.intersect1d(onset_idxs, target_1_idxs)\n",
    "    target_midset_idxs = np.intersect1d(midset_idxs, target_1_idxs)\n",
    "    target_offset_idxs = np.intersect1d(offset_idxs, target_1_idxs)\n",
    "\n",
    "    for interval_start in np.arange(search_start, search_end, interval):\n",
    "        min_pval = 1\n",
    "        min_interval = (0,0)\n",
    "        for interval_start in np.arange(search_start, search_end, interval):\n",
    "            #print(interval_start)\n",
    "            assert interval_start > data_delta\n",
    "            assert interval_start + interval < data_delta + data_duration\n",
    "\n",
    "            interval_start_idx = int((interval_start-data_delta)*samp_rate)\n",
    "            interval_end_idx = interval_start_idx + int(samp_rate*interval)\n",
    "\n",
    "            truncated_data_arr = neural_data[:,:,interval_start_idx:interval_end_idx]\n",
    "            #print(interval_start_idx, interval_end_idx, data_arr.shape)\n",
    "            assert truncated_data_arr.shape[0] == 1\n",
    "\n",
    "            onset_data = truncated_data_arr[0,target_onset_idxs,:].mean(axis=-1).tolist()\n",
    "            midset_data = truncated_data_arr[0,target_midset_idxs,:].mean(axis=-1).tolist()\n",
    "            offset_data = truncated_data_arr[0,target_offset_idxs,:].mean(axis=-1).tolist()\n",
    "\n",
    "            tstat, pval = stats.f_oneway(onset_data, midset_data, offset_data)\n",
    "            if pval < min_pval:\n",
    "                min_pval = pval\n",
    "                min_time = (interval_start_idx, interval_end_idx)\n",
    "        return min_time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "03a2d17f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_sentence_position_data_target(neural_data, target_idxs, onset_idxs, offset_idxs, midset_idxs):\n",
    "    onset_data = neural_data[0,np.intersect1d(onset_idxs, target_idxs),:].mean(axis=-1).tolist()\n",
    "    midset_data = neural_data[0,np.intersect1d(midset_idxs, target_idxs),:].mean(axis=-1).tolist()\n",
    "    offset_data = neural_data[0,np.intersect1d(offset_idxs, target_idxs),:].mean(axis=-1).tolist()\n",
    "    return onset_data, midset_data, offset_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "d541ca7a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 5760x4320 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "target = \"rms\"\n",
    "features = words_df\n",
    "\n",
    "if target==\"pos\":\n",
    "    target_1_idxs = features[(features[target]==\"NOUN\")].index\n",
    "    target_2_idxs = features[(features[target]==\"VERB\")].index\n",
    "else:\n",
    "    target_1_idxs, target_2_idxs = get_control_idxs(features, target)\n",
    "    \n",
    "onset_idxs, midset_idxs, offset_idxs = get_control_idxs(features, \"idx_in_sentence\")\n",
    "\n",
    "min_time = get_best_interval(search_start, search_end, interval, target_1_idxs)\n",
    "\n",
    "(best_interval_start_idx, best_interval_end_idx) = min_time\n",
    "target_1_truncated_data_arr = neural_data[:,:,best_interval_start_idx:best_interval_end_idx]        \n",
    "\n",
    "target_1_onset_data, target_1_midset_data, target_1_offset_data = get_sentence_position_data_target(target_1_truncated_data_arr, target_1_idxs, onset_idxs, offset_idxs, midset_idxs)\n",
    "\n",
    "min_time = get_best_interval(search_start, search_end, interval, target_2_idxs)\n",
    "(best_interval_start_idx, best_interval_end_idx) = min_time\n",
    "target_2_truncated_data_arr = neural_data[:,:,best_interval_start_idx:best_interval_end_idx]        \n",
    "\n",
    "target_2_onset_data, target_2_midset_data, target_2_offset_data = get_sentence_position_data_target(target_2_truncated_data_arr, target_2_idxs, onset_idxs, offset_idxs, midset_idxs)\n",
    "\n",
    "labels = [\"Onset\"]*(len(target_1_onset_data)+len(target_2_onset_data)) +\\\n",
    "        [\"Midset\"]*(len(target_1_midset_data)+len(target_2_midset_data)) +\\\n",
    "        [\"Offset\"]*(len(target_1_offset_data)+len(target_2_offset_data))\n",
    "all_data = np.concatenate([target_1_onset_data, target_2_onset_data, target_1_midset_data, target_2_midset_data, target_1_offset_data, target_2_offset_data])\n",
    "target_1_color = \"darkgrey\"\n",
    "target_2_color = \"grey\"\n",
    "colors = [target_1_color]*(len(target_1_onset_data)) + \\\n",
    "         [target_2_color]*(len(target_2_onset_data)) + \\\n",
    "         [target_1_color]*(len(target_1_midset_data)) + \\\n",
    "         [target_2_color]*(len(target_2_midset_data)) + \\\n",
    "         [target_1_color]*(len(target_1_offset_data)) + \\\n",
    "         [target_2_color]*(len(target_2_offset_data)) \n",
    "df = pd.DataFrame({\"label\": labels, \"activity\": all_data, \"colors\":colors})\n",
    "\n",
    "plt.figure(dpi=900)\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "g = sns.boxplot(df, x=\"label\", y=\"activity\", hue=\"colors\", ax=ax, palette=[\"dimgrey\", \"lightgrey\"], showfliers=False)\n",
    "plt.ylabel(\"Response ($\\mu V$)\",size=25)\n",
    "plt.xlabel(\"\")\n",
    "plt.ylim(-250,650)\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "onset_peak = df.activity.max()\n",
    "h = 50\n",
    "onset_peak -= 3*h\n",
    "_, t1_pval = stats.f_oneway(target_1_onset_data, target_1_midset_data, target_1_offset_data)\n",
    "t1_stars = pval2star(t1_pval)\n",
    "g.plot([0,2.0],[onset_peak+2.5*h,onset_peak+2.5*h],lw=1.5, c='k')\n",
    "g.text(1.0, onset_peak+2*h, t1_stars, ha='center', va='bottom', color=\"k\", fontsize=25)\n",
    "\n",
    "onset_peak += 2*h\n",
    "_, t2_pval = stats.f_oneway(target_2_onset_data, target_2_midset_data, target_2_offset_data)\n",
    "t2_stars = pval2star(t2_pval)\n",
    "g.plot([0.0,2.0],[onset_peak+2.5*h,onset_peak+2.5*h],lw=1.5, c='grey')\n",
    "g.text(1.0, onset_peak+2*h, t2_stars, ha='center', va='bottom', color=\"grey\", fontsize=25)\n",
    "\n",
    "sns.despine()\n",
    "ax.tick_params(labelsize=25, rotation=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ff75467f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 10242, 204)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "target_1_truncated_data_arr.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "46718b12",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
