{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe5a643b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import warnings\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import nibabel.freesurfer.io as fsio\n",
    "import pandas as pd\n",
    "from scipy.optimize import curve_fit\n",
    "\n",
    "from src.utils import load_pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0c1391bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.style.use('../style/plots.mplstyle')\n",
    "palette = ['#a4c8ffff', '#ffa5acff', '#afffa6ff', '#d8a6ffff', '#ffd0a5ff', '#d7d7d7ff']\n",
    "\n",
    "seaborn_props = {\n",
    "    'boxprops': {'edgecolor':'black', 'linewidth': 1.5},\n",
    "    'medianprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'whiskerprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'capprops': {'color':'black', 'linewidth': 1.5}\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "51757aa8",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_datasets = os.path.join(..., 'datasets')\n",
    "assert os.path.exists(path_datasets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'THINGS-fMRI'\n",
    "subject_id = 'S3'\n",
    "num_neighbors = 50\n",
    "split = 'test'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "541847a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_dataset = os.path.join(path_datasets, dataset)\n",
    "assert os.path.exists(path_dataset)\n",
    "\n",
    "path_results = os.path.join(path_dataset, 'results', subject_id)\n",
    "assert os.path.exists(path_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b743728f",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_annot_left = os.path.join(path_dataset, 'freesurfer', subject_id, 'label', 'lh.visual.annot')\n",
    "path_annot_right = os.path.join(path_dataset, 'freesurfer', subject_id, 'label', 'rh.visual.annot')\n",
    "assert os.path.exists(path_annot_left)\n",
    "assert os.path.exists(path_annot_right)\n",
    "\n",
    "labels_vertices_left, _, names_vertices_left = fsio.read_annot(path_annot_left)\n",
    "labels_vertices_right, _, names_vertices_right = fsio.read_annot(path_annot_right)\n",
    "\n",
    "names_vertices_left = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_left])\n",
    "names_vertices_right = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_right])\n",
    "\n",
    "assert np.all(names_vertices_left == names_vertices_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1a01d967",
   "metadata": {},
   "outputs": [],
   "source": [
    "unique_labels_left = np.unique(labels_vertices_left)[1:]\n",
    "unique_labels_right = np.unique(labels_vertices_left)[1:]\n",
    "\n",
    "assert np.all(unique_labels_left == unique_labels_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1d663f58",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_geodesic_lh = os.path.join(path_results, f'{subject_id}_geodesic_matrix_lh.pickle')\n",
    "assert os.path.exists(path_geodesic_lh), path_geodesic_lh\n",
    "\n",
    "path_geodesic_rh = os.path.join(path_results, f'{subject_id}_geodesic_matrix_rh.pickle')\n",
    "assert os.path.exists(path_geodesic_rh), path_geodesic_rh\n",
    "\n",
    "dict_geodesic_rh = load_pickle(path_geodesic_rh)\n",
    "dict_geodesic_lh = load_pickle(path_geodesic_lh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0b4e39fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "assert np.all(np.array(dict_geodesic_lh['areas']) == np.array(dict_geodesic_rh['areas']))\n",
    "\n",
    "names_areas = np.array(dict_geodesic_lh['areas'])\n",
    "matrix_geodesic_lh = dict_geodesic_lh['matrix']\n",
    "matrix_geodesic_rh = dict_geodesic_rh['matrix']\n",
    "\n",
    "index_V1 = np.where(names_areas == 'V1')[0]\n",
    "\n",
    "dict_distances = {}\n",
    "for area in names_areas:\n",
    "    index_area = np.where(names_areas == area)[0]\n",
    "    dict_distances[area] = (matrix_geodesic_lh[index_V1, index_area].item() + matrix_geodesic_rh[index_V1, index_area].item()) / 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "52aacf48",
   "metadata": {},
   "outputs": [],
   "source": [
    "assert np.all(names_vertices_left == names_vertices_right)\n",
    "assert np.all(unique_labels_left == unique_labels_right)\n",
    "\n",
    "primary_rois = ['V1']\n",
    "indices_primary = np.array([i for i, area in enumerate(names_vertices_left) if area in primary_rois])\n",
    "\n",
    "early_rois = ['V2', 'V3', 'V4']\n",
    "indices_early = np.array([i for i, area in enumerate(names_vertices_left) if area in early_rois])\n",
    "\n",
    "ventral_rois = ['V8', 'FFC', 'PIT', 'VMV1', 'VMV3', 'VMV2', 'VVC']\n",
    "indices_ventral = np.array([i for i, area in enumerate(names_vertices_left) if area in ventral_rois])\n",
    "\n",
    "dorsal_rois = ['V6', 'V3A', 'V7', 'IPS1', 'V3B', 'V6A']\n",
    "indices_dorsal = np.array([i for i, area in enumerate(names_vertices_left) if area in dorsal_rois])\n",
    "\n",
    "mt_rois = ['MST', 'LO1', 'LO2', 'MT', 'PH', 'V4t', 'FST', 'V3CD', 'LO3']\n",
    "indices_mt = np.array([i for i, area in enumerate(names_vertices_left) if area in mt_rois])\n",
    "\n",
    "assert len(primary_rois) + len(early_rois) + len(ventral_rois) + len(dorsal_rois) + len(mt_rois) == len(unique_labels_left)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "421f9b5f",
   "metadata": {},
   "source": [
    "## Stimuli"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a62f144b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_results = os.path.join(path_dataset, 'results', subject_id)\n",
    "\n",
    "assert os.path.exists(path_results)\n",
    "\n",
    "path_dict_dims_lh = os.path.join(path_results, 'decode', f'{subject_id}_decode_stimuli_lh_{split}_{num_neighbors}.npy')\n",
    "assert os.path.exists(path_dict_dims_lh)\n",
    "accuracy_lh = np.load(path_dict_dims_lh)\n",
    "\n",
    "path_dict_dims_rh = os.path.join(path_results, 'decode', f'{subject_id}_decode_stimuli_rh_{split}_{num_neighbors}.npy')\n",
    "assert os.path.exists(path_dict_dims_rh)\n",
    "accuracy_rh = np.load(path_dict_dims_rh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "bec12ae7",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(9876)\n",
    "\n",
    "dims_areas_linear = []\n",
    "\n",
    "for i_area, (label, name) in enumerate(zip(unique_labels_left, names_vertices_left)):\n",
    "    indices_area_left = np.where(labels_vertices_left == label)[0]\n",
    "    vertices_area_left = accuracy_lh[indices_area_left]\n",
    "\n",
    "    indices_area_right = np.where(labels_vertices_right == label)[0]\n",
    "    vertices_area_right = accuracy_rh[indices_area_right]\n",
    "\n",
    "    vertices_area = np.concatenate((vertices_area_left, vertices_area_right), axis=0)\n",
    "    num_vertices_area = vertices_area.shape[0]\n",
    "\n",
    "    for i_sample in range(num_subsample):\n",
    "        sampled_indices = np.random.choice(num_vertices_area, size=num_subsample, replace=False)\n",
    "        p90 = np.percentile(vertices_area[sampled_indices], 90)\n",
    "        mean_above_p90 = vertices_area[sampled_indices][vertices_area[sampled_indices] > p90].mean()  \n",
    "        \n",
    "        dims_areas_linear.append({'Area': name,\n",
    "                                  'Linear Dimensionality': mean_above_p90,\n",
    "                                  'Distance (mm)': dict_distances[name]})\n",
    "\n",
    "df_dims_areas_linear = pd.DataFrame(dims_areas_linear)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b2fb3bb1",
   "metadata": {},
   "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>Area</th>\n",
       "      <th>Linear Dimensionality</th>\n",
       "      <th>Distance (mm)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.023083</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.024352</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.022500</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.022917</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.024167</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2595</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019537</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2596</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019907</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2597</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.020333</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2598</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019167</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2599</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019417</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2600 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Area  Linear Dimensionality  Distance (mm)\n",
       "0      V1               0.023083       0.000000\n",
       "1      V1               0.024352       0.000000\n",
       "2      V1               0.022500       0.000000\n",
       "3      V1               0.022917       0.000000\n",
       "4      V1               0.024167       0.000000\n",
       "...   ...                    ...            ...\n",
       "2595  VVC               0.019537      75.406933\n",
       "2596  VVC               0.019907      75.406933\n",
       "2597  VVC               0.020333      75.406933\n",
       "2598  VVC               0.019167      75.406933\n",
       "2599  VVC               0.019417      75.406933\n",
       "\n",
       "[2600 rows x 3 columns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_dims_areas_linear"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "6e33f29f",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_dim = []\n",
    "std_dim = []\n",
    "distance = []\n",
    "\n",
    "for area in names_vertices_left:\n",
    "    mean_dim.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Linear Dimensionality'].mean())\n",
    "    std_dim.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Linear Dimensionality'].std())\n",
    "    distance.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Distance (mm)'].mean())\n",
    "\n",
    "mean_dim = np.array(mean_dim)\n",
    "std_dim = np.array(std_dim)\n",
    "distance = np.array(distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "262e0bc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = np.concatenate((distance[indices_primary], distance[indices_early], distance[indices_ventral]))\n",
    "y = np.concatenate((mean_dim[indices_primary], mean_dim[indices_early], mean_dim[indices_ventral]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "c3d4e082",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/g8/xtksjdh97hb95w5r0pwn7b6m0000gn/T/ipykernel_53182/754428833.py:14: OptimizeWarning: Covariance of the parameters could not be estimated\n",
      "  popt, pcov = curve_fit(linear_model, x, y, p0=p0)\n"
     ]
    }
   ],
   "source": [
    "def nonlinear_model(x, a, b, c):\n",
    "        return a * x**b + c\n",
    "\n",
    "def linear_model(x, a, b, c):\n",
    "        return a * x + b \n",
    "\n",
    "with warnings.catch_warnings(record=True) as caught:\n",
    "    p0 = [1.0, 2.0, 1.0]\n",
    "    popt, pcov = curve_fit(nonlinear_model, x, y, p0=p0)\n",
    "    model = nonlinear_model\n",
    "\n",
    "if caught:\n",
    "    p0 = [1.0, 2.0, 1.0]\n",
    "    popt, pcov = curve_fit(linear_model, x, y, p0=p0)\n",
    "    model = linear_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "64cb7544",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.00x^0.02 + 1.00\n"
     ]
    }
   ],
   "source": [
    "x_plot = np.linspace(0, x.max(), 100)\n",
    "y_plot = model(x_plot, *popt)\n",
    "\n",
    "a, b, c = popt\n",
    "print(f'{a:.2f}x^{b:.2f} + {c:.2f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "14e647b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_dim = []\n",
    "std_dim = []\n",
    "distance = []\n",
    "\n",
    "for area in names_vertices_left:\n",
    "    mean_dim.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Linear Dimensionality'].mean())\n",
    "    std_dim.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Linear Dimensionality'].std())\n",
    "    distance.append(df_dims_areas_linear[df_dims_areas_linear['Area'] == area]['Distance (mm)'].mean())\n",
    "\n",
    "mean_dim = np.array(mean_dim)\n",
    "std_dim = np.array(std_dim)\n",
    "distance = np.array(distance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "887e4168",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWsAAAFKCAYAAADbtn7rAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABMYUlEQVR4nO3dd1hUx/oH8O9SFpbeOwIWBIOCqAgaFbvGbnK5mpio0Z9RsaQXYm6Mxp7kWmJMtSWiUVNNEfUaY6yoUdEoNlCKKIIUWYrAvr8/jruwbKGXw76f5zmPMGfm7Oy6+zI7Z4qEiAiMMcZaNKPmrgBjjLHqcbBmjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAhysGWNMBDhYM8aYCHCwZgYvISEB8+bNw2OPPQY7OzuYm5vD29sbw4cPx8cff4yioiKdZdPS0pCfn6+WNmXKFEgkEkyaNKmxq14nhw4dgkQigUQiQVlZmSq9pdfb0HGwZgbt3XffRdeuXbFu3TqkpaWhbdu2CAkJgZGREfbu3Yu5c+eiY8eO+Pvvv9XKPXz4EP/5z3/g7++PzMzMZqo9MyQSXhuEGapNmzbh+eefh6WlJTZv3oxx48bB2NhYdf7y5ct4/vnnceLECTg5OeHSpUtwdnYGANy8eRN+fn4AgGvXrqF9+/aqchkZGcjLy4OtrS3c3d2b9knVwKFDh9C/f38AQGlpKUxMTAC0/HobOm5ZM4O1ZMkSAMAHH3yAp556Si1QA0BgYCB+/vlnuLi4ICsrC2vXrq3Rdd3d3REQECC6gCfWehsKDtbMIOXm5uLGjRsAgJ49e+rM5+zsjLFjxwIATp482RRVY0wrDtbMIJmamqp+/uWXX/Tmfe+99/DPP/9g+/btAIDIyEhVFwgAdOjQARKJBIcOHQKg+0Zd5Zt6O3bsQK9evWBtbQ17e3sMGTIEx48fBwDI5XK8/fbbaN++PczMzODq6ornnnsOt2/fVrvezZs3Vde8fv261rr7+vpCIpFg8+bN1b4mfIOxZeNgzQySpaUlevfuDUC4yTh58mQcPnwY5eXlGnnd3NzQqVMnODo6AgA6d+6M7t27q85369YNvXv3hq2tbY0e+6WXXsLEiRNx/fp1tG/fHiUlJdi/fz/69++PP/74Az179sSyZcugUCjQoUMHZGZm4uuvv0bfvn1RWFjYAM+eiREHa2aw1q1bBysrKxARtm7din79+sHBwQEjRozA8uXLcfLkSSgUCq3ldu3apfp9x44dOHLkCLp27Vqjx/3444+xfPly3L59G2fPnsXVq1fh4eGBkpISDBo0CIWFhTh58iSSkpJw8eJF7Nu3D8bGxrhx44ba4zLDwsGaGayuXbvi5MmTePzxx1Vp+fn5+O233/DWW28hPDwc7u7uWLBgQYO2aIcNG4Y33nhDNQrDy8sLkydPBgAoFAp89dVX6NGjhyr/4MGD0adPHwDQGELIDAcHa2bQOnXqhL/++gtnz57Fu+++i169eqn1Z2dmZmLJkiXo0qUL0tLSGuQxR4wYoZHm6+sLALCwsEC/fv00znt4eACAxgQcZjg4WDMGICQkBAsXLsTRo0eRm5uLffv24ZVXXoGLiwsA4MaNG/jXv/7VII/l7e2tkSaVSgEAjo6OMDLS/Fgq/4DwtAjDxcGasSosLCwwePBgfPDBB7h58yYmTJgAADhx4kSDdENYWlrqPKctUDMGcLBmBmrmzJno0KGDamKMLjKZDJ9//rmq5XvlypWmqF6t6Wpxy+XyJq4JaywcrJlBKioqwvXr1/Hjjz9Wm9fa2hpWVlYAoJpu3hIob1ACQElJicb5oqIi5ObmNmGNWGPiYM0MknLix+nTp6udMLJv3z7cv38fDg4OCA8PB6DeXdFc/ciOjo6QSCQAgMTERI3ze/bsUVtVj4kbB2tmkAYPHownn3wSADB9+nS8+OKLuHnzplqe4uJibNq0CVFRUQCA999/X9XCVv4LALdu3WqaSlchk8kQGhoKQJjYU3mG4759+xAdHd0s9WKNg4M1M1ixsbGYPHkyFAoF1qxZAz8/P/j4+CAsLAydO3eGnZ0dnn/+eRQVFWHZsmWYNWuWqqyDgwN8fHwAAOPGjUOPHj2wd+/eJn8O77//PkxMTHDp0iW0bdsWoaGh8PX1xdChQ+Hn54cxY8Y0eZ1Y4+BgzQyWVCrF5s2bER8fj1deeQWhoaEoKSnBuXPnkJaWho4dO+K1115DQkIC3nzzTY3yu3fvRkREBMrLy3H16lWd63M0pmHDhuHIkSMYO3YsrKyscOnSJchkMixatAh//fWX2jcAJm68njVjjIkAt6wZY0wEOFgzxpgIcLBmjDER4GDNGGMiwMGaMcZEwKT6LKwlISLV2soWFhaqGWyMsdaNW9YiU1hYCCsrK1hZWfEWT4wZEA7WjDEmAhysGWNMBDhYM8aYCHCwZowxEeBgzRhjIsDBmjHGRICDNWOMiQAHa8YYEwEO1owxJgI83bw1uHwVSKzDLiUB7YFA/4avD2OswXGwbg1Ky4CiorqVY4yJgui6QbKzszF37lz4+PhAJpMhODgYGzdurHH5LVu2oGvXrrC0tIS7uzuio6ORk5Oj83F8fX0hlUrh7OyMqKgoJCYmauR9//33IZFItB4LFy5s0PprZWoCyGRVDvOK8zJzLedlQjnGmCiI6tMql8sxZMgQXLhwAdHR0QgICMCuXbswbdo03LlzBzExMXrLL1u2DDExMRg4cCBWrlyJ5ORkrFu3DkePHsXx48chk8kAAMXFxYiMjMSlS5cwdepU9OjRA8nJyfjkk08QFxeHY8eO4bHHHlNdNyEhAZaWlvj00081HrNLly4NVn+dAv01uzPKyoCdPwk/jxoKmIjqv5oxVhWJyPLlywkAbd++XZWmUCho2LBhJJVKKSUlRWfZ1NRUkkqlNHz4cCovL1elx8bGEgBasWKFKm3p0qUEgD777DO1a5w5c4ZMTEzoiSeeUEv39/ensLCwRq2/UkFBAQEgAFRQUKA7Y2kp0bbdwlFaWu11GWMtm6iCdWBgIHl6emqkHzx4kADQ8uXLdZZdsWIFAaB9+/ZpnPPx8aGAgADV7/379yepVEplZWUaeYODg8nS0lL1u1wuJyMjI3r++ecbtf5KHKwZM0yi6bPOy8tDYmIievbsqXFOmXby5Emd5U+cOAEACA8P1zgXFhaGxMRE5OXlAQBiY2MRHx8PY2NjtXxEhMzMTLX0ixcvQqFQICgoCIDQhVJaWtqg9ZfL5WoHY8zwiCZYp6eng4jQpk0bjXMWFhawt7dHcnKyzvJpaWmws7ODtbW1xjkvLy8AwM2bNwEAbm5uCA4O1sgXGxuLjIwM9O/fX5V2/vx5AMDff/+NwMBAWFhYQCaTYcCAATh79myD1F+52YCVlRVcXV11PkfGWOslmmCtbPVaWVlpPW9hYaG31ZmXl6e3LAC95S9evIg5c+bAxMQE77zzjio9ISEBAHDkyBHMnj0bP/74I/7zn//g9OnTePzxx3H69OkGqT9jzLCJZogAEan9q+181W6Lquf1lQWgs/zZs2cxdOhQ5ObmYv369ejWrZvq3NChQ2FjY4OXXnoJTk5OAIDRo0dj+PDhiIiIwPz583H06NF61b+goED1s1wu59Y1YwZINMFa2X2ha9/BwsJCeHt76y2flZWlsywA2Nraapz77bffMGHCBBQUFGDNmjWYPXu22vmRI0di5MiRGuV69OiBXr164ciRI3jw4EG96m9paanzeTHGDINoukH8/PwgkUiQlpamcU4ulyM3N1dvsPbz80NOTo7Wroa0tDQYGRnB09NTLf3TTz/F6NGjUVJSgm3btmHevHm1qrOrqyuICAUFBfWuP2PMsIkmWFtZWSEwMBDx8fEa55SjKHr16qWzvHLEhbby8fHxCAoKUrv5uHr1asyaNQs2NjbYv38/Jk6cqFGOiBAWFoawsDCtj3np0iVYW1vDxcWl3vVnjBk20QRrAJg0aRJu3bqFHTt2qNKICKtWrYKZmRkmTJigs2xUVBRMTU2xcuVKtX7j7du3IyUlBVOmTFGlxcXF4eWXX4ajoyMOHz6Mvn37ar2mRCKBo6MjTp06hZ9++knt3NatW3Hp0iU8++yzqr7o+tSfMWbYJKTrjlcLVFRUhO7du+P69euYN28e/P39sXPnThw4cACrVq3Cq6++CgBISkrCsWPH0K5dO0RERKjKv/fee1i4cCEGDRqEqKgoXL16FWvXrkVwcDD+/PNP1XTzgIAAXLlyBVOmTMHAgQO11mXSpEkAhNZz7969UVxcjBdeeEHVet68eTMCAwNx5MgR2NnZ1ar++sjlctWIkoKCAt392ZWnm0eN4enmjIldE0/CqbfMzEyaPn06ubi4kEwmo5CQENq6datank2bNhEAmjx5skb5DRs2UKdOnUgqlZK3tzfNmTOH7t+/rzp/69Yt1QxBfUdl169fp6effpqcnZ3J1NSUfH196dVXX6WcnJw61V8fnsHImGESVcuaccuaMUMlqj5rxhgzVBysGWNMBDhYM8aYCHCwZowxEeBgzRhjIsDBmjHGRICDNWOMiQAHa8YYEwEO1owxJgIcrBljTAQ4WDPGmAhwsGaMMRHgYM0YYyLAwZoxxkSAgzVjjIkAB2vGGBMBDtaMMSYCHKwZY0wEOFgzxpgIcLBmjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAfr1kpBFT9nZqn/zhgTHZPmrgBrBKnpwOlzFb8fOgpYyIBuwYC3Z7NVizFWd9yybm1S04G/TgBFxerphUVCemp689SLMVYvHKxbEwUBZ87rz3PmPHeJMCZCHKxbk3tZQgtan8IiIR9jTFQ4WLcmVbs+6puPMdZicLBuTWTmDZuPMdZicLBuTZydhFEf+ljIhHyMMVHhYN2aGEmE4Xn6dAsW8jHGRIWDdWvj7Qn0Cdfs6rCQCek8zpoxUeJJMa2Rtyfg6gLs/ln4PbI34ObKLWrGRIxb1q1V5cDs4sSBmjGR42DNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAjx0jzGm3+WrQOL12pcLaA8E+jd8fQyU6FrW2dnZmDt3Lnx8fCCTyRAcHIyNGzfWuPyWLVvQtWtXWFpawt3dHdHR0cjJydH5OL6+vpBKpXB2dkZUVBQSExM18t66dQtTpkyBh4cHTE1N4eHhgWnTpuH27dsaeadPnw6JRKL12Lx5c61eC8aaRGkZUFRU+6O0rLlr3qqIqmUtl8sxZMgQXLhwAdHR0QgICMCuXbswbdo03LlzBzExMXrLL1u2DDExMRg4cCBWrlyJ5ORkrFu3DkePHsXx48chkwnrahQXFyMyMhKXLl3C1KlT0aNHDyQnJ+OTTz5BXFwcjh07hsceewwAcO/ePURERCAnJwcvvPACAgMDcfHiRXz++eeIi4vDqVOn4O7urqpDQkICfH19sXjxYo369erVqwFfLcYaiKkJIKu65gxVrN4oMwegZRy/qajCS8tHIrJ8+XICQNu3b1elKRQKGjZsGEmlUkpJSdFZNjU1laRSKQ0fPpzKy8tV6bGxsQSAVqxYoUpbunQpAaDPPvtM7RpnzpwhExMTeuKJJ1RpM2bMIAC0d+9etbw//fQTAaDZs2er0srLy0kmk1FUVFTtn/wjBQUFBIAAUEFBge6MpaVE23YLR2lpnR+PMa34/dXkRNUNsmXLFnh6emLChAmqNIlEgtdffx0PHz5EbGyszrKxsbF4+PAhXnrpJRgZVTztiRMnwsfHB5s2bVKl7d+/H1KpFNOmTVO7RmhoKB577DH8+eefannbtm2LoUOHquUdPXo0bG1t1fJeu3YNRUVFCAoKqv2TZ4wZNNF8T8nLy0NiYiLGjRunca5nz54AgJMnT+osf+LECQBAeHi4xrmwsDDs2rULeXl5sLW1RWxsLO7evQtjY2O1fESEzMxMtfQ///wTBQUFGteUy+WQy+Vqec+fF7bcUgbrwsJCmJmZaTyOtmtp+5kxZjhE07JOT08HEaFNmzYa5ywsLGBvb4/k5GSd5dPS0mBnZwdra2uNc15eXgCAmzdvAgDc3NwQHKy51GhsbCwyMjLQv39/VZq3tzcCAwM18q5evRplZWVqeZXBeu/evfD19YWlpSUsLCwwduxYJCUl6ay7lZWV6nB1ddWZjzHWeomqZQ0IgUsbCwsLva3OvLw8vWUB/a3WixcvYs6cOTAxMcE777yjt64HDx7EokWLYGNjg1deeUWVnpCQAEBo5S9YsABOTk44duwY1qxZg2PHjiE+Ph6+vr56r80YM0yiCdZEpPavtvP6uhOISG9ZADrLnz17FkOHDkVubi7Wr1+Pbt266Xycffv2Ydy4cSgvL8fXX38Nb29v1bkJEyYgNDQUb775pmrkydixYxEeHo4nn3wSb7/9NrZt26ZxzcrdLHK5nFvXjBkg0QRrZfdFYWGh1vOFhYVqgVFb+aws7bt6K69pa2urce63337DhAkTUFBQgDVr1mD27Nk6H2Pjxo2YOXMmJBIJduzYgdGjR6udf+aZZ7SWGz9+PLy9vREXF6f1vKWlpc7HZIwZBtH0Wfv5+UEikSAtLU3jnFwuR25urt5g7efnh5ycHK1dHWlpaTAyMoKnp/ouKp9++ilGjx6NkpISbNu2DfPmzdN5/QULFmDatGmwsLDA77//jqeeeqoWzw5wdXXFgwcPalWGMWY4RBOsraysEBgYiPj4eI1zylEg+iaVKEeMaCsfHx+PoKAgtZuPq1evxqxZs2BjY4P9+/dj4sSJOq/94osvYsmSJWjTpg2OHj2KAQMGaOTJyspCly5dMH78eI1zpaWluHbtGtq3b6/zMRhjhk00wRoAJk2ahFu3bmHHjh2qNCLCqlWrYGZmpjb+uqqoqCiYmppi5cqVan3X27dvR0pKCqZMmaJKi4uLw8svvwxHR0ccPnwYffv21Xndzz//HGvWrEG7du3UZjZW5eTkhLKyMuzZswdnzpxRO7ds2TLk5eWp1YExxiqTkK67bi1QUVERunfvjuvXr2PevHnw9/fHzp07ceDAAaxatQqvvvoqACApKQnHjh1Du3btEBERoSr/3nvvYeHChRg0aBCioqJw9epVrF27FsHBwfjzzz9VN/0CAgJw5coVTJkyBQMHDtRal0mTJkEul6NNmza4f/8+Xn31Va3D/aysrDB27FgAwKFDhzBs2DCYm5sjOjoanp6eOHjwIL777jtERkZi3759MDU11fsayOVy1aiWgoIC3f3ZZWXAzp+En6PGACaiuT3BxIDfX02veSZO1l1mZiZNnz6dXFxcSCaTUUhICG3dulUtz6ZNmwgATZ48WaP8hg0bqFOnTiSVSsnb25vmzJlD9+/fV52/deuWajq3voOI6M8//6w2n4+Pj9rjnzlzhkaPHk329vYklUqpY8eOtHjxYioqKqrR8+fp5qxF4PdXkxNVy5pxy5q1EPz+anKi6rNmjDFDxcGaMcZEgIN1a1WuqPj5j6PCbh/5PI6bNRBFpd7TzCz131mj4D5rkalxn3V6BvDnMc10G2vA0104nBwAI/57zWopNR04fa5i8wEAsJAB3YIBb0+dxVj98F2B1kpmrj09/4FwXL4KSKWAhxvg5Q64uwLVDBtkDKnpwF8nNNMLi4T0PuEcsBsJB+vWyqbSUrBDBwB3M4XWdla2MPAPAB4+BG6mCIeRBHBxrmh1W/F6JKwKBQFnzuvPc+Y84OkhvJ9Yg+JgbQhsrQFHe6BTR6C4BMi4IwTu23eFIViA8EG8kykcZ84Dtjbq3SUS/vAZvHtZQgtan8IiIZ+rc9PUyYBwsDY05maAn49wlCuAzHtC4E7PAOSVVjTMyxeOS1cAMzPA000I3G6uvBGqoarcR90Q+Vit8KfOkBkbCX3V7q7CzaG8fCFop2UA2fcr8pWUAEm3hMPISGg1eT1qdT/auIEZAF33Qeqaj9UKB2smkEgAO1vheCxAaB3dftRdknEXKC8X8ikUwu8Zd4FT5wB7u0etbg/Awc6wuksuXwUSr9e+XEB7INC/4evT2JydhFEf+rpCLGRCPtbgOFgz7WTmQDtf4SgvF/qy0zOA9DtAUaUPa06ucFxMFMp4uAFeHoCrC2CifyNg0SstU38talNOjIwkwjcwbaNBlLoF883FRsLBmlXP2LjiZiOREJyV/dz3cyvyFRUDN24Kh7Ex4ObyqJwb8GhFw1bF1ETL86KKPluZOQAtgUvMff7ensLwPB5n3eR4UozItLiFnAqLgNuP+rnvZqrPnKzMwV4I3F7uQldLa+0uMZQFjh6WArt/Fn6O7C3ceOYWdaNqpe8k1mQsZED7tsJRVqbeXVJcqeV1P0c4LlwSyihb6q7OQiuciUvlwOzixIG6CXCwZg3HxETor/byELpL7ucILe70DCA3ryJfYRFwLUk4TEwA90fdJR7uwtBCxpgGDtatgdZRCZV6t/bEQWvfaWOOSpBIAEcH4Qh+TBjDreznvntPGFUCCK3x1NvCAQgTcDw9hOBta916u0sYqyUO1q1BdaMSdE1SaMpRCZYWgH874SgtFbpL0jKE/u6ShxX5su4Lx/mLQhlPd6Gl7uwkjAtnzEBxsG4NtI5KqGG55mBqKowa8PYUprln369odeflV+STFwJXbwiHqQng/mgWpYerMKuSMQPCwbo1CPQX5yQLQLgx5ewoHCFBQEFBRT93ZpbQ9w0I3wJS0oRDAsDJSRgS6OWhvmgVa90MbSJSJRysWctiZQUEdBCOh6XCTMn028JsyoelQh6CsFjQvSzg3EXA2qpidImzY+tZo9uAA5NOhjYRqRIO1qzlkpoCPl7CoVAIy7squ0vyCyryPSgAEq8Jh9RUmEXp6S50m0hFvEa3AQcmnQxxItIj4n8GzDAYGQnrbbs4A127CBsoKAP3veyK7pKHpcDNVOGQSIQxwMpWt7VV8z6H2jLgwKSTti6/yhORRg1ttRORavys7t27h9u3b6Ndu3aqGXSVZWVl4bfffsNzzz3XoBVkTCsba+EI9BdGk2TcEfq6M+4Ko00AIYDfvSccfycIQwGVgdvRseVP5DDgwMQ0Vdu5V1ZWhqlTp8LNzQ2hoaFwdnbGiy++iKIqX89u3LiBqVOnNlpFGdPJTAr4tgEe7wk8ORIY0Afo2F5zt5u8B8Clq8D+P4EffgGOnwZS0iuCO2MtWLV/lteuXYtvv/0WixYtQrdu3XD48GGsXbsWf/75J/bu3QtXV9emqCdjNWNkJCwg5eYChFbqLkl7tKWZUslDIPmWcBgZVXSXeLkDutZbYawZVRusN27ciHfeeQdvvfUWAGDYsGF49tlnMW7cOPTq1QtxcXFo3759o1eUsVqTSITtyWxtKrY0q7xGt2pLM4X6lmZ2tpW6S+x5FiVrEaoN1snJyejVq5daWmBgII4dO4bhw4ejd+/e+P333xutgow1GHMzoK2PcJSXC33ZykWnCittaZabJxz/JALm5pW2NHPhPmLWbKp95zk5OSEjI0Mj3cHBAQcPHsTYsWPRv39/vPHGG41SQcYahbGxMMTPww3oTkDuoy3N0m8D2TkV+Yorr9FtJGyqoGx1W7TCNbq1aYlrzxigaoN1t27d8MMPP2DChAka5ywtLfHrr79iwoQJWLBgAST8dZGJkUQC2NsKR5ByS7NHwwIzMiu2NCtXCN0ot+8Ap84+2tLsUT+3vV3r7S4Rw9ozBqDaYP3000/jww8/RHZ2NhwdHTXOS6VS7N69G7Nnz0ZcXFyjVJKxJiUzB9r5CUdZubCpgnJMd+XApNrS7LIwHtrTTegqaanqOiPSwVZca8+0UrxTjMjUeKcY1vCUW5op1y7JydWf37+dcGOzIbtL6rMTTcIl4Q9LbQUFAl061b5cUzGQ3Xla57NirDFIJML2ZA72QvAqLBRuTqZnCCNJFFW2NFOuGGhlJdzU9HQH7Gyar7ukJc+IrM86KB3aNnx9WiAO1ozVlYWFECg6tAVupgDHTmnPV1AAJPwjHBYWFasFujg17ZZmLXlGJK+DUi0O1ozVl4KE1f9qorCwypZmro/W6HZrnVua1bTFXHUWqamJ8PrUpNWvqNSTm5nVajfvrXOwzs7OxunTp1FSUoJOnTrVeGLMvXv34OzsXNeHZazluZcl7CtZHXs7IC+vIriUlQGp6cIhAeDkWDEs0KaVbGlW1xZzxw5AJ//qW/2p6cCv+yp+P3RUuEfQLVjY3KIVqVOwfu+997Bs2TKUVvprGBkZiU2bNqFNmzYa+S9cuIBffvkFe/bswalTp9TKMSZ6uoauVRXoL3SBZNx9tOjUnYotzQjC6oH3soVWupVlxbBAZyfxrtHdmP3kqenAXyc00wuLhPQ+4a0qYNc6WG/fvh3vvfee6ncjIyMoFAr88ccfGDx4MI4fPw4HBwecO3cOW7ZswY8//oiUlBQAABHxWGzW+sjMa57P1BRo4yUcCqqyRveDirwFcuDKdeEwVa7R7Sb0c4tJffrJy/T0RytIWBpAnzPnhc2XW0mXSK2D9aeffgoAGD16NFavXg1fX1/cvHkTS5cuxZdffok1a9YgLy8P69atAyAEaAAICQnBiBEjMGLEiAasPmMtgLOT8NVbX1eIhUzIV5nRo/W2XZyArp2FTRSUi07dq7ylWSlwK1U4Kst/IIxMMUQ16XoqLBLyubaObtdaB+vz58/DxsYG27ZtU43x9fX1xeeff46cnBysW7cOeXl5ICL06dMHkyZNwsiRI+Hu7t7glWesRTCSCH2k2r6SK3ULrr6FZ115S7OHwO27QvC+fUf7Mq57DwI2lbY0c2pFW5pVp6ZdTzXNJwK1Dtb5+fno3r271skYb731Fr777jtIJBKsX78es2bNapBKMtbieXsKfaSnz6kHiLre7JJKAV9v4VAohL7s9Ayhn1ZeadGp/AIg/xpw+ZpQRrWlmau4tzSrTm26nvQR0T6XdbrBaG6u/QXo1EmY5eTu7s6Bmhkeb09hoafdPwu/R/ZumGFkRkbCV3lXZ2Htkt17hHQbGyA/vyLfw4fCeO+bKY+6WJwrWt1VN2IQu7p2PVUlovHdDfqdSRnEfXx8GvKyarKzszF37lz4+PhAJpMhODgYGzdurHH5LVu2oGvXrrC0tIS7uzuio6ORk5OjkU/5OL6+vpBKpXB2dkZUVBQSExM18hYWFuI///kP2rdvD5lMho4dO+KDDz5AuXIBoAasP2vhKgdmF6eGvbmVmg78ur/i9/x8oeXo3w5o46l+o05BFetz/7xXKHfuotBCV7SCFSaUXU/61KTrSTlaRe2o1BiVmWs5L2uWdU/q9IhJSUn44IMP0LlzZ3Tu3BkeHh5q540baVaWXC7HkCFDcOHCBURHRyMgIAC7du3CtGnTcOfOHcTExOgtv2zZMsTExGDgwIFYuXIlkpOTsW7dOhw9ehTHjx+H7NEQo+LiYkRGRuLSpUuYOnUqevTogeTkZHzyySeIi4vDsWPH8NhjjwEAFAoFnnrqKezduxfPP/88wsLCsH//frz22mu4evUqPv/88warPzNguoapFRULU9r7hAMRYcC9exVrl1TuLsnLF45LVwAzs4o1up00F2cTjYboemrJszqrolqSSCQkkUjIyMhIdTg4OFC/fv0oOjqaJBIJhYWFUVlZWW0vXa3ly5cTANq+fbsqTaFQ0LBhw0gqlVJKSorOsqmpqSSVSmn48OFUXl6uSo+NjSUAtGLFClXa0qVLCQB99tlnatc4c+YMmZiY0BNPPKFK27FjBwGgZcuWqeWdMWMGAaATJ040SP2VCgoKCMKoXCooKKg2P2tipaVE23YLR2lpw1yzXEH0w68V19V2/PCrkE9JoSDKySW6eJlo70H9ZZXHjWT1azSWmr5GJQ8r8qVn6K5bTfM1dP2aWK1X3fv2229x7tw5nD9/HufOncOdO3dU5yqPoTY1NUVgYCBCQkIQHBys+tfevu5DjTp16oT8/HykpaWppf/xxx8YMGAAli9frnMThJUrV+KNN97Avn37MHjwYLVzvr6+kMlkuHxZWJFswIABOHr0KAoLCzW+JYSEhOD69esoKCgAADzxxBP43//+h/v376vddE1OTkbbtm0xc+ZMbNiwod71V+JV91q4xlgB7u494H+Hq883sK/uYWrFxRWLTmXcrVijuyqJRFi3pJO/MCywMeZF1OQ1Sk2veYu5oV/zFrqKX61r8e9//xv//ve/Vb/fu3dPLXifP38eV65cwcOHD3H+/HmcP39eLYh7e3vj5s2bta5oXl4eEhMTMW7cOI1zPXv2BACcPHlSZ/kTJ4SvkOHh4RrnwsLCsGvXLuTl5cHW1haxsbG4e/euRqAmImRmZqqlnzx5EkFBQRpB08/PD87Ozqo61bf+zIA1xDA1c3Ogna9wlJcDFxOFbcuqIqqYAi8zrxhd0pRbmhnYzMSaqver7+zsjMGDB6u1VktKSvDPP/+oBfGEhATk5eUhNTVVz9V0S09PBxFpnc5uYWEBe3t7JCcn6yyflpYGOzs7WFtba5zz8vICANy8eRPBwcFwc3ODm5ubRr7Y2FhkZGRgzJgxAIQbi/fv30ffvn21PqaXl5eqTvWpv1wu1/ozMxANNUxNSWIk7OpenSItW5p5uQMe9dzSTN/CSwY4M7GmGuVPpZmZGUJDQxEaGqqWfvPmTZw/X81/hA55eXkAoOoCqMrCwkJvIMvLy9NbFtAfCC9evIg5c+bAxMQE77zzTq3rVJ/66yrDDERDDVNTqunCU0aSisBaeUsznAUc7ISA6ekubIdW0+4SZfeGUtWFlwxwZmJNNWlnjK+vL3x9fetUVtm1rquLnYj0jkIhIr1lAd2jWM6ePYuhQ4ciNzcX69evR7du3Wpdp/rWnxmwhpohqVTTbpWwUGGijXIH+OJK5e7nCseFS0KwVY7ndnXWvUZ3Tbo3yhWa5+vzHFqRltFzXgPK7ovCwkKt5wsLC+Ht7a23fFZWls6yAGBra6tx7rfffsOECRNQUFCANWvWYPbs2bWqk/Ka9am/8mYmILT+XV1dteZjrVhDzpCsaXeJpaUQfL08hL7s+zkVi07l5FXkKyyqtEa3sdCt4ekuDA9UTqCrafdGz+4N+xxaEdEEaz8/P0gkEo2RFIAQwHJzc/UGaz8/P/z999+Qy+UaNwPT0tJgZGQET0/1N/ynn36KOXPmwNjYGNu2bcPEiRPVzltbW8PJyUlrnZTXVX6TqE/9ecQHA9BwMyTr0q0ikQCODsLR5TFhDLcycN+9V7GlWVk5kHZbOAAhv5e7sLFCTbo3JGjYLp9WRDSrvlhZWSEwMBDx8fEa55SjKHr16qWzvHLEhbby8fHxCAoKUrv5uHr1asyaNQs2NjbYv3+/RqBWCgsLw4ULF1BUZcpqUlISsrKyVHWqb/0ZA9AwMyQbYvafpYUwc7L/48CTo4RWf1sfYcJNZdn3gfP/ACf/rlndiksaZmZiKySaYA0AkyZNwq1bt7Bjxw5VGhFh1apVMDMzw4QJE3SWjYqKgqmpKVauXKnWb7x9+3akpKRgypQpqrS4uDi8/PLLcHR0xOHDh3WO9lDWqbi4GGvWrFFLX7FiBQCoXbc+9WesQSm7Vap2J1jINIfGXb4K/PCb7uOXfcDp80BGphBEzaTCML+6bFMmM69d3QyIaLpBAODFF1/EN998g8mTJ+PMmTPw9/fHzp07ceDAAaxatUq1DGtSUhKOHTuGdu3aISIiAoCwXsnbb7+NhQsXYsiQIYiKisLVq1exdu1a9OjRAzNnzlQ9zvz580FEGDVqFM6dO4dz585p1GXSpEkAgAkTJuDLL79ETEwMkpOTERYWhri4OOzatQvR0dHo2rVrrevPWJOoabdKXRc7CuggtLbTM4Rukbv39Oc3NRUCPVHjLYolYqIK1jKZDIcOHUJMTAy2bt2KBw8eoGPHjti6dSueffZZVb7Dhw9j6tSpmDx5sipYA8C7774LV1dXrFu3DnPmzIGrqytmzJiBRYsWqdYFSUlJwZUrVwAAmzdvxubNm7XWRRmsJRIJfv75ZyxcuBA7duzAli1b4Ofnh//+97+YN29enerPWJOpSbdKfbbmsrIEOrYXjuRbwPHTuutSWgr8dkAo4+UhTMSprm4GpNbTzVnz4unmLVxjT1VuKVOr61pO2zRyiaRiVxxdenYDvD2EoYQNVRddHpa2yBa9qFrWjDGR09W9UVBQMbrkXrZm8D55Boj/W2hhK8d0WzfCZLHqJu00Iw7WjLGmpa3rxcZaOAL9hR3fb98B0tKB1NsVeYmEfu+794C/E4QWubGxMBVeaU8ctHbJ1GRnlxa+JomoRoMwxgyAmRTwawNE9KhI69BWc7cbIqELpORhRVpRsXAztOpR3c4uNZ2004wbN3DLmrG60rp/X6UPc31aeUxd185A9xBht5vrScK0dIWeqelGRhWtbolR9Tu7iGBNEg7WjNVVdUPadK1f0Qz79zU4fSvnNRaJRAjaXTsLvxeXCN0lyjW6yyq9ropHwbwUgJ2NsD9lVrYwo1LbolMi2C2dgzVjdaV1SFsNy4lZS7kJZ24mjONu6yOs0Z2Z9WhMdwZQeQ2e3Hzh+OeKUMbDXZgCX3mN7oZehrYRiPxdw1gz0rZ/X2vXUm/CGRsD7q7C0S1YCM7pGUD6bSC70obYxSVA0k3hMDISAranu7DJQgtfk4SDNWOsZsSyMYBEIqyxbW8LBAUIXRe3Hw0LzMis2NJMUXmNbgjrnejTzGuScLBmjNVMY96Ea8ybtTJzoJ2fcJSVA3czK9bornzPQa59+WIeZ80Ya1r1DYiNeROuqW7WmhhXTKohAnJyK/q5c3I184d3B3zb8AxGxlgTqm9AbMybcM1xs1YiEXZwd7AHOncSvhWkZwj98ncyhTxtPFtEoAY4WDNmOOobEOuyaYGYxqJbyITJN35tKtYaaUE4WDPWUjV0oKvv6JW67AVpyGPRGxgHa8ZaqpYY6Gq7F6ShjkVvBPyKMNZStdRAV5uNAQxxLHoj4WDNWEvVkgNdQ+wFyWqFV91jjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAR4NwhjTT0yzEFsxDtaMMf1a4uQcA8TBmjGmX0udnNMQRPStQQSvJmOsWbXkyTn1JaJvDRysGWOGS0TfGiRERNVnYy2FXC6HlZUVAKCgoACWlpbNXCPGWFPgoXuMMSYCHKwZY0wEOFgzxpgIcLBmjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAhysGWNMBDhYM8aYCHCwZowxEeBgzRhjIsDBmjHGRICDNWOMiYDognV2djbmzp0LHx8fyGQyBAcHY+PGjTUuv2XLFnTt2hWWlpZwd3dHdHQ0cnJy9JbJzc2Fl5cXFi5cqHFOIpFUe1Q2ffp0nfk2b95c4+fBGDMsotopRi6XY8iQIbhw4QKio6MREBCAXbt2Ydq0abhz5w5iYmL0ll+2bBliYmIwcOBArFy5EsnJyVi3bh2OHj2K48ePQ6Zlx4jCwkKMGTMG6enpWq/59ddfa02Pi4vDN998g/Hjx6ulJyQkwNfXF4sXL9Yo06tXL731Z4wZMBKR5cuXEwDavn27Kk2hUNCwYcNIKpVSSkqKzrKpqakklUpp+PDhVF5erkqPjY0lALRixQqNMhcuXKCgoCCCsIMmvfvuuzWqZ2pqKjk6OpK/vz/l5+er0svLy0kmk1FUVFSNrqNNQUGBqj4FBQV1vg5jTFxE1Q2yZcsWeHp6YsKECao0iUSC119/HQ8fPkRsbKzOsrGxsXj48CFeeuklGBlVPO2JEyfCx8cHmzZtUsu/bNkyhISEID09HS+//HKt6jl79mxkZ2fjiy++gLW1tSr92rVrKCoqQlBQUK2uxxhjognWeXl5SExMRM+ePTXOKdNOnjyps/yJEycAAOHh4RrnwsLCkJiYiLy8PFXa2bNnMXXqVFy6dAmjRo2qcT0PHDiAPXv2YNKkSejbt6/aufPnzwOAKlgXFhaivLy82mvK5XK1gzFmeETTZ52eng4iQps2bTTOWVhYwN7eHsnJyTrLp6Wlwc7OTq2lq+Tl5QUAuHnzJoKDgwEIfdFmZmYAgMTExBrXMyYmBqampliyZInGOWWw3rt3L1566SXcunULUqkUw4cPx0cffYS2bdtqvaZyg1xmAC5fBRKv175cQHsg0L/h68NaDNEEa2WrV1fgsrCw0NvqzMvL01sWgFp5ZaCujaNHj+LUqVOYOnWq1j8qCQkJAIRW/oIFC+Dk5IRjx45hzZo1OHbsGOLj4+Hr61vrx2WtSGkZUFRUt3KsVRNNsCYitX+1nTc2NtZbXl9ZAHrL18T69esBAK+99prW8xMmTEBoaCjefPNN1ciTsWPHIjw8HE8++STefvttbNu2TaNcQUGB6me5XA5XV9d61ZO1YKYmgMaoJAKKioUfZeYAJFVLCeVYqyaa/2Fl90VhYaHW84WFhfD29tZbPisrS2dZALC1ta1z/R4+fIhffvkF3bt3R2BgoNY8zzzzjNb08ePHw9vbG3FxcVrPW1pa1rleTGQC/TW7M8rKgJ0/CT+PGgqYiOZjyxqQaG4w+vn5QSKRIC0tTeOcXC5Hbm6u3mDt5+eHnJwcrV0laWlpMDIygqenZ53rd/DgQTx48AATJ06sU3lXV1c8ePCgzo/PGGvdRBOsraysEBgYiPj4eI1zylEg+iaVKEeMaCsfHx+PoKAgrTcfa+rw4cMAgKFDh2o9n5WVhS5dumhMkgGA0tJSXLt2De3bt6/z4zPGWjfRBGsAmDRpEm7duoUdO3ao0ogIq1atgpmZmdr466qioqJgamqKlStXqvVdb9++HSkpKZgyZUq96nb69GlYWlrq7AJxcnJCWVkZ9uzZgzNnzqidW7ZsGfLy8updB8ZY6yWqzq8XX3wR33zzDSZPnowzZ87A398fO3fuxIEDB7Bq1Sq4u7sDAJKSknDs2DG0a9cOERERAAAfHx+8/fbbWLhwIYYMGYKoqChcvXoVa9euRY8ePTBz5sx61e3KlSvw9vZWm3BT1SeffIJhw4Zh4MCBiI6OhqenJw4ePIjvvvsOkZGRePHFF+tVB8ZYK9ZscyfrKDMzk6ZPn04uLi4kk8koJCSEtm7dqpZn06ZNBIAmT56sUX7Dhg3UqVMnkkql5O3tTXPmzKH79+/rfcw//vij2unmMpmMwsPDq63/mTNnaPTo0WRvb09SqZQ6duxIixcvpqKiomrLEvF0c4NUWkq0bbdwlJY2d21YM5EQ6RjPxlokuVyuGi9eUFDAI0UMQeXRIFFjeDSIgRJVnzVjjBkqDtaMMSYCHKwZY0wEOFgz1tIpKt1WysxS/50ZDL5TwVhLlpoOnD5X8fuho4CFDOgWDHjXfcYtEx9uWTPWUqWmA3+dqFjESamwSEhP1b7VHGudOFgz1hIpCDhzXn+eM+e5S8SAcLBmrCW6lyW0oPUpLBLyMYPAwZqxlqhq10d98zHR42DNWEskM2/YfEz0OFgz1hI5OwmjPvSxkAn5mEHgYM1YS2QkEYbn6dMtWMjHDAIHa8ZaKm9PoE+4ZleHhUxI53HWBoUnxTDWknl7Aq4uwO6fhd8jewNurtyiNkDcsmaspascmF2cOFAbKA7WjDEmAhysGWNMBDhYM8aYCHCwZowxEeBgzRhjIsDBmjHGRICDNWOMiQAHa8YYEwEO1owxJgI83ZyxluTyVSDxepXESrvB7IkDoGUGY0B7INC/MWvGmhkHa8ZaktIyoEjPDjG6NhsoLWuc+rAWg4M1Yy2JqQkgq2Yda13lWKsmISLecVNE5HI5rKysAAAFBQWwtLRs5hoxxpoC32BkjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAjw4U2Qqj7SUy+XNWBPGWHUsLCwgkTTMnpkcrEWmsLBQ9bOrq2sz1oQxVp2GnAvB3SCMMdZIGvLbL89gFBmFQoGsrCwA+r9iyeVyVcv77t27PNNRZPj/T7wq/989ePBANeO4vrgbRGSMjIzg4uJSqzKWlpb8YRcx/v8Tr4bqrwa4G4QxxkSBgzVjjIkA91kzxpgIcMuaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAhysW6ns7GzMnTsXPj4+kMlkCA4OxsaNG5u7WkyH8vJy9OnTR+u43EGDBkEikWg9Dh061PSVZQCAf/75B2PHjoWdnR1sbW0RGRmJ3377TSNfSkoKnnvuOXh4eMDS0hLh4eH4+eefa/14PCmmFZLL5RgyZAguXLiA6OhoBAQEYNeuXZg2bRru3LmDmJiY5q4iq2Lp0qU4cuSI1nMJCQno3r075s+fr3EuMDCwsavGtDh9+jT69++PkpISzJw5E/7+/tizZw9GjBiB1atXq/6v7ty5g759++L+/fuYN28ePD098dVXX2HMmDHYtm0bnn766Zo/KLFWZ/ny5QSAtm/frkpTKBQ0bNgwkkqllJKS0oy1Y1WdPHmSTExMyMzMjKp+JG/fvk0A6PXXX2+m2jFtunfvTgDo999/V6UpFAqKiooiqVRKV69eJSKimTNnkkQioaNHj6ryFRUVUXBwMDk5OVFBQUGNH5ODdSsUGBhInp6eGukHDx4kALR8+fJmqBXT5sGDB9S+fXsaOXIk9evXTyNY7927lwDQ1q1bm6mGrKqUlBQCQAMHDtQ4d+7cOQJAMTExVFZWRlZWVtSrVy+NfBs3biQAtGPHjho/LvdZtzJ5eXlITExEz549Nc4p006ePNnU1WI6zJ8/H3l5efjyyy+1nj9//jwAICgoCIDQxaVQKJqsfkxTamoqACA4OFjjXIcOHQAAp06dwj///IOCggKEh4dr5KvLZ5GDdSuTnp4OIkKbNm00zllYWMDe3h7JycnNUDNW1ffff4+NGzfiiy++0Lk2uTJYb9myBW5ubrCysoK1tTWee+453Lt3rymryx5RrqKXn5+vcU65Iubt27eRlpYGAFo/i15eXgBQq88i32BsZfLy8gBA57KMFhYWvMNMC5Ceno7/+7//w7Rp0zBmzBid+RISEgAAf//9Nz744AOYm5tj//79+OKLL3Dy5EmcPHkSdnZ2TVRrBgg3de3t7fHLL78gPz8fNjY2qnM7d+4EABQVFen9LFpYWACo3XrXHKxbGXq01AvpWPKFiGBsbNyUVWJVEBEmT54MOzs7rF69Wm/emTNn4sGDB3j99ddhZCR8EX7qqafQsWNHvPLKK1i1ahWWLFnSBLVmSqampliwYAFeeeUVDB06FCtWrICXlxd+/fVXLFq0CDY2NjA1NdX7WVSm1eazyMG6lbG2tgagvv1XZYWFhfD29m7KKrEqPvroIxw8eBA//vgjiouLUVxcDAAoLS0FIHyVNjY2hr29PaKjo7VeY86cOXj99dcRFxfHwboZvPzyyygpKcHixYvRr18/AIC3tze2b9+Ol156CQ4ODno/i8o0W1vbGj8mB+tWxs/PDxKJRNVfVplcLkdubi4H62a2Z88eEJHO7g9nZ2f4+Pjg5s2bOq8hlUphb2+PBw8eNFItWXXeeustzJ07FwkJCbCwsEDnzp1RVlaGW7duITw8HH5+fgCg9bOoTKvNZ5GDdStjZWWFwMBAxMfHa5xT3nnu1atXU1eLVfLhhx8iJydHI/2VV15BQkIC9u/fD5lMhgsXLmDChAkYOHAg1q5dq5Y3MzMTWVlZCAsLa6pqs0p27twJMzMzjBkzRu3zFBcXh4cPHyIyMhIBAQGwtbXVOuKjTp/FuowzZC3b0qVLdU6KMTMzo9u3bzdj7ZguVcdZFxYWkr29Pdna2tKtW7fU8j7//PMEgHbu3NnU1WRE1LdvX7Kzs6Ps7GxVWl5eHoWGhpKHhwcVFhYSEdGMGTO0Torp0qULubq6UlFRUY0fk4N1K1RYWEidOnUiqVRKr776Kn3++ec0aNAgAkCrVq1q7uoxHbRNitm2bRtJJBJyd3enxYsX09q1a2ngwIEEgJ555plmqik7cOAAGRsbU1BQEK1du5ZWr15NnTp1IjMzM7VZjRkZGeTm5kY2Nja0cOFC2rBhA3Xv3p0kEgl9++23tXpMDtatVGZmJk2fPp1cXFxIJpNRSEgIz4Jr4bQFayIhMAwcOJCsrKzI3NycgoOD6eOPP6by8vJmqCVT2r9/P/Xp04dsbW3JycmJRo0aRfHx8Rr5kpKSKCoqiuzt7cnKyooiIiLo119/rfXj8bZejDEmAjyDkTHGRICDNWOMiQAHa8YYEwEO1owxJgIcrBljTAQ4WDPGmAhwsGaMMRHgYM0YYyLAwZo1Kp5zVTf8urGqOFi3QiUlJfj2228xcuRItG3bFubm5rC3t0efPn2wbt06lJSUNHodysvLsX79esyfP18tffPmzZBIJJg0aVKj10FJIpFAIpGgrKys2rwLFy5U5a98KJckDQ0NxTvvvIM7d+5oLR8ZGQmJRIIDBw7Uqa66XjdD8dxzz6Fr164oLy9v7qrodOrUKZiYmGDfvn1N+ri8RGorc+nSJURFReGff/6BhYUFunTpgtDQUGRkZODUqVM4cuQIPvvsM/zvf//Tue9fQ9i2bRvmzJmDZ555ptEeozG1bdsWERERqt/Lyspw//59nD17Fu+//z7Wr1+P7777Dv3792/QxxX761YfO3fuxNdff43Dhw+36N2MevTogSlTpmDy5Mm4dOkS7O3tm+aB67uYCWs5rl27RtbW1gSA5s2bR1lZWWrnU1NTafDgwQSAOnXqpFrGsTFs2rRJ68pwubm5dPny5SZdphUAAaDS0tJq87777rsEgCZPnqz1fElJCcXExBAAsrGxocTERLXzt27dosuXL5NcLq9TXXW9bq1dXl4eubq60pgxY5q7KjVy+/Ztkslk9H//939N9pjcDdJKEBGefvppPHjwADExMVizZg0cHR3V8nh5eeGHH35Ahw4dcOnSJXz55ZdNXk9bW1sEBATA3d29yR+7IUilUixZsgQzZsxAfn4+3nzzTbXzbdq0QUBAgGpDVFYzH374Ie7evYs33nijuatSI+7u7nj22WexceNGJCYmNs2DNtmfBdaoDh8+TADI3d292hbzpk2bqE+fPrR27VqNc19//TU9/vjjZG1tTebm5hQUFETvv/++RksxOTmZANCYMWNo586d1KZNGzI3N6fOnTtTt27dVK1Z5aFsqeprOR48eJDGjBlDrq6uZGlpSUFBQbR06VKNxy4tLaUvv/ySBgwYQI6OjmRiYkL29vYUGRlJsbGxGtdFA7aslbKzs8nc3JwAUHp6uipduczp/v37VWkKhYL++9//Us+ePcnBwYFkMhl16tSJ3nrrLbp//75GWW2vG5GwTvmHH35IvXr1Int7ezIxMSEnJycaPnw4xcXFaX3ewcHBlJubS/Pnzydvb2+SSqXUrl07WrBggdbWv0KhoK+++op69+5NdnZ2ZG9vT7169aIdO3aQQqHQyL9v3z4aNmwYOTg4kJmZGQUEBNC7775LBQUFel+/yuRyOdnb29Njjz2mcW7y5MkEgC5cuEBffvkldenShczNzcnNzY1mzZpFDx48oPLyclq5ciV16NBB9dquX79eo74AqFu3bpSdnU2zZs0id3d31XtcuXxwamoqPf300+To6Eh2dnY0cOBAOnv2rNZ6nz59mgDQtGnTavxc64ODdSsRHR1NAGjWrFl1Kl9eXk4TJ04kAGRmZkZDhgyhcePGkaOjIwGgkJAQtW4VZbBu27YtmZiYUI8ePWj48OE0bNgwev/99ykiIoIAkJ+fHz3zzDP02WefEZHuYL1ixQqSSCRkZGREffr0oXHjxpGbmxsBoL59+1JJSQkRCcFk9OjRBIAcHBxo+PDhNG7cOOrYsaMqwK1Zs0bt2o0RrIlItQnA119/rUrTFqxffPFFAkCOjo40YsQI1R8kPOqOKi4uJiLS+7oVFRVRWFgYASAPDw8aNWoUjR49mnx8fAgASSQS+vHHHzWed/v27alz584kk8lo4MCBNHz4cJJKpQSARo4cqZa/rKxM9dpaWlrSE088QU888QTJZDICQG+++aZa/vfff58AkImJCUVERND48ePJw8ND9X6p/IdIn9jYWAJACxYs0DinDNYjRowgABQREUEjR45UdfeNGTOGnn76aZJKpdS/f38aNGgQGRkZEQD68MMPtb4e/v7+ZG1tTaNHj6bw8HC1942bmxu5u7vTmDFjyN/fX/VapKSkaK27p6cnWVhYqP4PGxMH61ZCGTg2b95cp/Jr1qxRBd/r16+r0vPz81UflPHjx6vSlcEaAM2ePVuVrlwQX1dQ1pZ+6tQpMjIyIhsbGzpy5IgqvaCgQBX8/vvf/xIR0XfffUcAqGfPnhotw2XLlqk+kJU1VrBW/oGsHGSqButbt24RAPL396f8/HxVvsLCQlWgqBzsdb1uH374IQGgcePGqT2PsrIymj17NgGgQYMGaX3egYGBlJSUpEo/ffo0mZqaqlqsSh999BEBoM6dO6t9W7hx4wa5uLgQAFUr88CBAwSAPD091VqeJSUlNGXKlFr1uz/33HMEgPbt26dxThmsJRIJ/fTTT6r0M2fOkEQiIQBkZWWlVofPP/+cAFDHjh21vh6dOnWiu3fvqtLnzZunOjd06FDVt4LS0lLq27cvAaBly5ZprbuygVP5j3Nj4T7rViIjIwMA6jzCY/Xq1QCAL7/8Eu3atVOlW1tbY9u2bbC1tcX333+P69eva5R96aWXVD8bGdX+LfXZZ59BoVDg7bffRu/evVXplpaWWLVqFdq1a4fbt28DAB4+fIjRo0dj+fLlGv3CM2fOBAAkJyfXug51YWdnBwDIysrSmUc5xM/BwQGWlpaqdJlMhnXr1uGLL75Ajx49qn0sqVSKJ554AsuWLYOJScUgLmNjY8yYMQOA7ue9bNky1U7bANCtWzc8/vjjAICLFy+q0jds2ABAeA94eHio0tu2bYuYmBh07twZly9fBgB88MEHAIT3TUhIiFo9169fDxcXF+zYsQPp6enVPrdDhw4BADp37qwzz4gRIzB69GjV76GhoQgICAAAREdHq9XhqaeeAgCt71UAWLRoEVxcXFS/Vx55s3r1atX/k4mJCcaOHav3Wl26dAEA/PHHHzrr3lA4WLcSyg9wTcYSV5Wamork5GQ4OTlpHYpma2uLYcOGAQD+/PNPtXMymQzt27evQ40rKD+slT+MSj169MD169excuVKAMCECRPw008/ITIyUpWnpKQE586dQ2xsLABhrHJTjNN9+PAhAGEcty5BQUFwcHDAiRMnEBERgXXr1uHatWsAgO7du2P69Ono2LFjtY81Z84c/Prrr2p5CwsLER8fjx9++AEAdI6frzwEUUkZjAsLCwEA6enpuHbtGlxdXbXumD5//nwkJCRg4sSJKC8vx+HDhwEAAwcO1MhrYWGBfv36oby8HH/99Zfe56VQKJCeng6pVAo3Nzed+cLDwzXSnJ2dAUAtUAMVf0TLy8u1fh6qXkt5HXNzc43/C+W1iouLtdZL+UcwNTVVZ90bCo+zbiXc3d2RkJCAzMzMWpdVtlp9fX115lG+KZUteCXlm7k+lNds06ZNjfLn5+fjiy++wN69e3HlyhWkp6dDoVCoBU1qghmA9+/fByC0mnWxsLDAd999h2eeeQbx8fGIj48HILRWx44di5kzZ6JDhw41ery7d+9iw4YN+OOPP3Dt2jXcuXMHRKR63rqes7ZxwMo/7gqFAkDt/g+ys7NVQV7fcweqD2LZ2dkoLy+vdqyytsdRPm8nJyet6TW9ljK/o6OjRtnqrmVrawtA+L9pbBysW4lu3bohLi4OJ0+exPPPP683b15eHhYvXowBAwZgyJAhqg+5vjemMo+ZmZlael26PaqqzbeBf/75BwMGDEBmZiZcXFzQvXt3/Pvf/0ZISAj69esHb2/vetenps6dOweg4quwLpGRkUhKSsLvv/+OPXv24MCBA0hKSsJHH32EdevWYffu3Vq/VVR26NAhjBw5EnK5HN7e3ujZsycCAwMRGhoKX19fvV0p1QUcoHb/B8pvLWZmZqouB12q+9ZVWloKoOKPhi6mpqY1rl91GvJayteiKb7JcbBuJcaMGYOlS5fil19+QXFxMczNzXXm3b17Nz788ENs3boVGRkZqq/E+vp6k5KSANS9T1wfd3d33Lx5E2lpafD399c4/9lnn8HT0xMjR47EnDlzkJmZiTfeeANLly5V+2ORk5PT4HXTJS0tDefOnYOJiYlal4wuZmZmGDt2rKoPNDExEUuWLME333yD119/XW+wJiJMmzYNcrkcn3zyCWbNmqV2/uzZs/V5KgCgGveelpam9fzdu3fx008/ISQkBCEhITA1NUVpaSm++uorjT/gtWFvbw+JRIKcnByUl5e36JmL2ijvV1T3DaMhcJ91KxEWFoY+ffrg9u3bWLp0qc589+/fV51/4YUXYGxsjDZt2sDHxwdZWVkafdKA0BKPi4sDAPTr169G9alJa05JebPr999/1zh3+fJlzJw5EwsXLgQAHD9+HADw1ltvabTqK6/VUF1Lrb6WLFmC8vJyjB8/Xu1mVVU7duxA+/btsWTJErX0gIAAfPzxxwDUuwq0vW53795FUlIS7OzsNAI1UPG86/OcfXx84OXlhYyMDJw/f17j/Pfff48XXngBO3fuhFQqRUREBBQKhep9URkRYdCgQejdu7eq20cXmUwGLy8vEJFGF5sYKLsQtTUyGhoH61Zkw4YNkMlkWLx4MV577TXk5uaqnU9OTsbIkSORlJQEf39/tdliyhEd06dPV2thFxQUYNKkScjPz8eoUaPg4+NTo7ooW/Z5eXnV5o2OjoZEIsHixYvVAkVBQQHmzJkDAKqFn5Q3g3766Se1axw+fBhz585V/a7rhlB9FRUV4b333sOnn34KOzs7rFixQm/+wMBA3LhxA6tXr8aVK1fUzn3zzTcAoHZDT9vrZmtrC6lUitzcXNWNPaXvv/8eixYtAlD/56x8/WbMmKHqjweEb1WLFi2CkZERJk6cCKDi/TJnzhy1lr1CocA777yD//3vf7hx4waCg4OrfdxevXoBqPhDLCbHjh0DALVRTI2m0QcHsiZ1/PhxcnJyIgBkYWFBffv2paioKOrVqxcZGxsTAAoKCqJbt26plSsvL6eoqCgCQObm5jR06FAaN26c6lrBwcGUmZmpyq8cZ+3p6am1HmfOnFGNjx0xYgQtWbKEiHSPI1aOkTYxMaGBAwfS6NGjVWN7hw8frhq/rRwLDIB69+5NTz31FIWEhKgmnSgn0ly5ckV1bWX+2oyzbtu2LT3zzDOq41//+hdFRkaqJmM4OjrSX3/9pVFe26SY+fPnq55bZGQkPfXUUxQcHKwaI/z3339X+7opxwIbGxvTgAEDaPz48aqJQD4+PmRlZUVGRkZqs1f1PW/l+OUvvvhClVZWVkYjR44kAGRra0ujR4+mIUOGqGZqLl26VO0ar776qup59ezZk8aNG0dt27ZVvfcqj5nXZ9u2bQSA5syZU6N66nut9T13Xa+Hvveyvhm35eXlZG9vTzY2No26zo4SB+tWKDMzkxYuXEhhYWFka2tLxsbGZG9vT/369aNPPvlENRuwKoVCQZs2baLevXuTlZUVWVpaUkhICK1cuZKKiorU8lYXrImIli9fTh4eHqrZZUT63/x79+6lwYMHk52dHZmamlJAQAAtWbJEo77bt29XPTdbW1vq3LkzzZ07l9LS0mju3LkEgD744ANV/roE66qHsbExOTg4UHh4OC1atEhjkSwlbQGkvLycNmzYQD179iQrKysyNTWlNm3a0LRp0+jGjRs1et3Kysro448/pi5dupClpSU5OjpSaGgoxcTEUE5ODo0aNYoA0O7du2v0vHUFQeXjdOvWjSwsLEgmk1FERAR9++23Wp/vzz//TEOHDiV7e3syMzOj9u3b07Rp0+jatWvVvtZKcrmcHB0dydvbm8rKympUT6LmD9b79u0joO6zhmtLQsSrnDPGmtfy5cvx1ltv4eeff8aoUaOauzo18uSTT+KXX37BtWvXajzstD44WDPGmp1cLkfbtm0RHBzc5Iv610VKSgratWuHGTNmYP369U3ymBysGWMtwu7du/Gvf/0L+/btw+DBg5u7Ono9/fTT+Ouvv5CQkNBkmw9wsGaMtRhTp07F6dOnce7cuRY75vrEiRPo3bs39u3bp3W6fWPhYM0YYyLA46wZY0wEOFgzxpgIcLBmjDER4GDNGGMiwMGaMcZEgIM1Y4yJAAdrxhgTAQ7WjDEmAv8P/oLv1sCIslIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_svg = os.path.join('svg', subject_id, 'depth')\n",
    "os.makedirs(path_svg, exist_ok=True)\n",
    "path_figure = os.path.join(path_svg, f'{subject_id}_stimuli_{split}_{num_neighbors}.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(3, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "ax.plot(x_plot, y_plot, color=palette[1], linewidth=2)\n",
    "ax.errorbar(distance[indices_primary], mean_dim[indices_primary], yerr=std_dim[indices_primary], fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "ax.errorbar(distance[indices_early], mean_dim[indices_early], yerr=std_dim[indices_early], fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "ax.errorbar(distance[indices_ventral], mean_dim[indices_ventral], yerr=std_dim[indices_ventral], fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "\n",
    "ax.set_xlabel('Cortical Distance (mm)')\n",
    "ax.set_ylabel(r'$R^2$')\n",
    "ax.set_xlim(-4, 90)  \n",
    "# ax.set_ylim(-0.005, 0.0025)  \n",
    "# ax.set_ylim(-0.006, -0.002)\n",
    "\n",
    "ax.set_xticks([0, 45, 90], [0, 45, 90])\n",
    "ax.set_title('Stimuli')\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "src",
   "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.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
