{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe5a643b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\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",
    "\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 = 'S1'\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 = os.path.join(path_results, f'{subject_id}_geodesic_matrix.pickle')\n",
    "assert os.path.exists(path_geodesic), path_geodesic\n",
    "\n",
    "dict_geodesic = load_pickle(path_geodesic)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0b4e39fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "names_areas = np.array(dict_geodesic['areas'])\n",
    "matric_geodesic = dict_geodesic['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] = matric_geodesic[index_V1, index_area].item()\n"
   ]
  },
  {
   "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.045463</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.052417</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.050333</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.039833</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.051250</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.020000</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2596</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.020521</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2597</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019667</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2598</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019896</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2599</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.019583</td>\n",
       "      <td>80.366436</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.045463       0.000000\n",
       "1      V1               0.052417       0.000000\n",
       "2      V1               0.050333       0.000000\n",
       "3      V1               0.039833       0.000000\n",
       "4      V1               0.051250       0.000000\n",
       "...   ...                    ...            ...\n",
       "2595  VVC               0.020000      80.366436\n",
       "2596  VVC               0.020521      80.366436\n",
       "2597  VVC               0.019667      80.366436\n",
       "2598  VVC               0.019896      80.366436\n",
       "2599  VVC               0.019583      80.366436\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": "b212e7a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.optimize import curve_fit\n",
    "\n",
    "def model(x, a, b, c):\n",
    "    return a * x**b + c\n",
    "\n",
    "# Fit model\n",
    "p0 = [1.0, 2.0, 1.0]  # initial guesses\n",
    "popt, pcov = curve_fit(model, x, y, p0=p0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "64cb7544",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.01x^0.23 + 0.05\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": "iVBORw0KGgoAAAANSUhEUgAAAVUAAAFKCAYAAACtjMxgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABHnElEQVR4nO3deVxU9f4/8NewDAyL7CC7uCAYCm5s5oqSpol2i5+mpV2tq6ntWVr3m5m7dW9pXSvLrQJT22xxL3eFygVTUREQARVBQBmQZeb9++M4A8MsDDjDzMD7+XjMg5lzzmfO5wzMm8/ncz6LiIgIjDHGDMLK1BlgjLG2hIMqY4wZEAdVxhgzIA6qjDFmQBxUGWPMgDioMsaYAXFQZYwxA+KgyhhjBsRBlTHGDIiDKrMYGRkZeP755/HAAw/A1dUV9vb2CAwMxKhRo/DRRx+hqqpKa9r8/Hzcvn1bZdvUqVMhEokwefJkY2e9Rfbv3w+RSASRSIS6ujrldnPPd3vHQZVZhLfffhu9e/fG6tWrkZ+fj86dOyMqKgpWVlbYuXMn5syZg+7du+PEiRMq6WpqavB///d/CA0NRVFRkYlyz9oVYszMrVu3jgCQo6Mjbd26lerq6lT2nzt3jmJjYwkAeXp6UlFRkXJfTk4OASAAdOnSJZV0hYWFdP78eSosLGyV62iu33//XZn32tpa5XZzz3d7xyVVZvYWL14MAHjvvffw2GOPwdraWmV/eHg4tm/fDm9vbxQXF2PVqlV6va+vry/CwsLg6+tr8Dwbk6Xmu73goMrMWllZGS5fvgwAiImJ0Xqcl5cXxo0bBwBIS0trjawxphEHVWbWbG1tlc9//vlnnce+8847OHv2LFJTUwEAQ4YMQUhIiHJ/t27dIBKJsH//fgDab/g0vDm0efNmxMfHw9nZGW5ubkhMTMSxY8cAAFKpFG+++Sa6du0KOzs7+Pj44KmnnkJhYaHK++Xm5irfMysrS2PeO3XqBJFIhA0bNjT5mfCNKvPGQZWZNUdHRwwYMACAcLNqypQpOHjwIGQymdqxHTt2RI8ePeDh4QEA6NmzJ/r166fc37dvXwwYMAAuLi56nfull17CxIkTkZWVha5du6K6uhp79uzB0KFD8fvvvyMmJgZLly6FXC5Ht27dUFRUhC+//BKDBg1CZWWlAa6eWSIOqszsrV69Gk5OTiAibNq0CYMHD4a7uztGjx6NZcuWIS0tDXK5XGO6rVu3Kl9v3rwZhw8fRu/evfU670cffYRly5ahsLAQJ0+exMWLF+Hn54fq6moMHz4clZWVSEtLQ3Z2Nv7++2/s3r0b1tbWuHz5ssp5WfvCQZWZvd69eyMtLQ0PPvigctvt27fx66+/Yt68eYiNjYWvry/eeustg5YQR44ciddffx02NjYAgICAAEyZMgUAIJfL8cUXX6B///7K40eMGIGBAwcCgFrXLtZ+cFBlFqFHjx44dOgQTp48ibfffhvx8fEq7a1FRUVYvHgxevXqhfz8fIOcc/To0WrbOnXqBABwcHDA4MGD1fb7+fkBgNpAA9Z+cFBlFiUqKgoLFizAkSNHUFZWht27d+OVV16Bt7c3AODy5ct4/PHHDXKuwMBAtW1isRgA4OHhASsr9a+PItATL/3WbnFQZRbLwcEBI0aMwHvvvYfc3FxMmDABAHD8+HGDVL8dHR217tMUUBkDOKgyMzdjxgx069ZNOQBAG4lEgs8++0xZkrxw4UJrZK/ZtJVgpVJpK+eEGQsHVWbWqqqqkJWVhR9++KHJY52dneHk5ARAGAxgLhQ3ugCgurpabX9VVRXKyspaMUfMmDioMrOm6OD+559/Ntkxfvfu3bh16xbc3d0RGxsLQLWabqp2Tg8PD4hEIgBAZmam2v6ffvpJZRYqZtk4qDKzNmLECPzjH/8AAEyfPh0vvvgicnNzVY65e/cu1q9fj+TkZADAokWLlCVWxU8AuHLlSutkuhGJRII+ffoAEAYwNBxxtXv3bsyaNcsk+WLGwUGVmb2UlBRMmTIFcrkcH374IUJCQhAcHIzo6Gj07NkTrq6u+Oc//4mqqiosXboUM2fOVKZ1d3dHcHAwAGD8+PHo378/du7c2erXsGjRItjY2ODcuXPo3Lkz+vTpg06dOuGhhx5CSEgIkpKSWj1PzDg4qDKzJxaLsWHDBqSnp+OVV15Bnz59UF1djVOnTiE/Px/du3fHa6+9hoyMDLzxxhtq6bdt24a4uDjIZDJcvHhR6/h7Yxo5ciQOHz6McePGwcnJCefOnYNEIsHChQtx6NAhlRI1s2wi4g51jDFmMFxSZYwxA+KgyhhjBsRBlTHGDIiDKmOMGRAHVcYYMyCbpg9hLUVEyvk9HRwclKNqGGNtF5dUjaiyshJOTk5wcnLi5TUYayc4qDLGmAFxUGWMMQPioMoYYwbEQZUxxgyIgypjjBkQB1XGGDMgDqqMMWZAHFQZY8yAOKgyxpgB8TDV1nT+IpDZglnnw7oC4aGGzw9jzOA4qLam2jqgqqpl6RhjFoGDamuytQEkkkYbCai6KzyV2APQMOmKLf+aGLMU/G1tTeGh6tX4ujpgy4/C80ceAmz4V8KYJeMbVYwxZkAcVBljzIA4qDLGmAFxUGWMMQPioMoYYwbEQZUxxgyIgypjjBkQB1XGGDMgDqqMMWZAHFQZY8yAOKgyxpgBcVBljDED4qDKGGMGxEGVMcYMiIMqY4wZEAdVxhgzIA6qpian+udFxaqvGWMWh6eZN6WrBcCfp+pf7z8COEiAvpFAoL/JssUYazkuqZrK1QLg0PH69akUKquE7VcLTJMvxth94aBqCnIC/jqt+5i/TnNTAGMWiIOqKdwsFkqkulRWCccxxiwKB1VTaFzlv9/jGGNmg4OqKUjsDXscY8xscFA1BS9P4S6/Lg4S4TjGmEXhoGoKViKh25QufSOF4xhjFoWDqqkE+gMDY9Wr+BJ7YTv3U2XMInFQNaVAf2B0ouq2h4ZyQGXMgnFQNbXGVXyZ3DT5YIwZhMUF1ZKSEsyZMwfBwcGQSCSIjIzEunXr9E6/ceNG9O7dG46OjvD19cWsWbNQWlqqdtxXX30FkUik8TF16lQDXlEjMpnx3psxZnQWNfZfKpUiMTERZ86cwaxZsxAWFoatW7di2rRpuH79OubPn68z/dKlSzF//nwkJCRgxYoVyMnJwerVq3HkyBEcO3YMEkn9HfmMjAwAwNq1a2Fvr9ru2aVLF8NfnEIdB1XGLBpZkGXLlhEASk1NVW6Ty+U0cuRIEovFlJeXpzXt1atXSSwW06hRo0gmkym3p6SkEABavny5yvGJiYnk7e19X/mtqKggAASAKioqNB9UW0v09bb6x/Wi+zonY8y0LKr6v3HjRvj7+2PChAnKbSKRCHPnzkVNTQ1SUlK0pk1JSUFNTQ1eeuklWFnVX/bEiRMRHByM9evXqxyfkZGBiIgIw19EU7j6z5hFs5igWl5ejszMTMTExKjtU2xLS0vTmv748eMAgNjYWLV90dHRyMzMRHl5OQCgqKgI169fVwbVmpoaVFdX65VPqVSq8mg2rv4zZtEsJqgWFBSAiBAUFKS2z8HBAW5ubsjJydGaPj8/H66urnB2dlbbFxAQAADIzc0FAJw+LcwglZeXh379+sHBwQESiQTR0dH47bffdObTyclJ+fDx8dH38urJ6pqfhjFmNiwmqCpKkU5OThr3Ozg46CwZlpeX60wLQJlecZPq8OHDePzxx/H9999j5cqVyMvLQ2JiIn766acWX0eTuPrPmEWzmLv/RKTyU9N+a2trnel1pQWgTB8dHY0333wTU6dORdeuXZXHPfbYY4iIiMBzzz2H0aNHq7TNKlRUVCifS6XS5pdWufrPmEWzmJKqotpeWVmpcX9lZSVcXFx0pteVFoAy/cCBA7Fo0SKVgAoAwcHBGD9+PPLz83Hu3DmN7+Xo6KjyaDYuqTJm0SwmqIaEhEAkEiE/P19tn1QqRVlZGQIDA3WmLy0t1dhEkJ+fDysrK/j7Nz08VFHyvHPnTjNy3wxcUmXMollMUHVyckJ4eDjS09PV9inu+sfHx2tNr+ghoCl9eno6IiIilKXhcePGoWvXrqiqUp+dX1FCNdoAAC6pMmbRLCaoAsDkyZNx5coVbN68WbmNiLBy5UrY2dmp9F9tLDk5Gba2tlixYoVK22pqairy8vJUhp76+vri8uXL+Oyzz1TeY//+/dixYwcefvhheHt7G+7CGqrju/+MWTIRabt7Y4aqqqrQr18/ZGVl4fnnn0doaCi2bNmCvXv3YuXKlXj11VcBANnZ2Th69Ci6dOmCuLg4Zfp33nkHCxYswPDhw5GcnIyLFy9i1apViIyMxIEDB5TDVG/cuIHo6GgUFBRgypQpiI6Oxrlz5/DJJ5/Ay8sLhw8fRqdOnZrMr1QqVfY4qKio0NzGWlcHbPmx/nVIMBDXr+UfEmPMtEw0kqvFioqKaPr06eTt7U0SiYSioqJo06ZNKsesX7+eANCUKVPU0q9Zs4Z69OhBYrGYAgMDafbs2XTr1i21465fv07/+te/yN/fn2xsbMjPz4+eeeYZKigo0DuvLRqmeuiY3u/PGDM/FlVStTQtKqn6dQSGDGilHDLGDM2i2lTbBb5RxZhF45KqEamVVPMKgMysRkeR6lLUViLArtESK2FdgfBQ42aWMWYQFjOiqk2orQM0dNNSISf1Y2q5RwBjloKDamuytQEkWpamVgRSkQhoNCk2bPnXxJil4Oq/Eel1o0rh+1+FwCqRAOMfbqUcMsYMjW9UmQvre78KnvqPMYvGQdVc2Nyr4vPdf8YsGgdVc6GYtlAmB7hFhjGLxUHVXNg0mAuWS6uMWSwOquai4QTbPP0fYxaLg6q54JIqY20CB1VzoVJS5R4AjFkqDqrmomFQlclNlw/G2H3hoGoubBqMmuK+qoxZLA6q5oJvVDHWJnBQNRd8o4qxNoGDqrngkipjbQIHVXNhzSVVxtoCDqrmgqv/jLUJHFTNhXWDu//cT5Uxi8VB1VxYN/hVcEmVMYvFQdVcqPRT5aDKmKXioGou+O4/Y20CB1VzwTeqGGsTOKiaCy6pMtYmcFA1F1xSZaxN4KBqLnjqP8baBA6q5sKa7/4z1hZwUDUXViJAJBKec1BlzGJxUDUXIlF9EwDfqGLMYnFQNSeKm1VcUmXMYnFQNSfWHFQZs3QcVM0JV/8Zs3gcVM2JsvpfBxCZNi+MsRbhoGpOFN2qCICcgypjloiDqjmxbdBXtarKdPlgjLUYB1Vz4u5a/7zklsmywRhrOYsLqiUlJZgzZw6Cg4MhkUgQGRmJdevW6Z1+48aN6N27NxwdHeHr64tZs2ahtLS0yXTz5s2DSCTC/v377yP3TfBwr39ezEGVMUtkUUFVKpUiMTERn376KR599FF88MEH8PLywrRp07BkyZIm0y9duhRTp06Fh4cHVqxYgUmTJuHzzz/H0KFDUaWjun3gwAGsWLHCkJeiWcOgyiVVxiwTWZBly5YRAEpNTVVuk8vlNHLkSBKLxZSXl6c17dWrV0ksFtOoUaNIJpMpt6ekpBAAWr58ucZ0paWlFBQURHZ2dgSAfv/9d73zW1FRQRBuO1FFRYV+iX7cQfT1NqLU74jqZE0fzxgzKxZVUt24cSP8/f0xYcIE5TaRSIS5c+eipqYGKSkpWtOmpKSgpqYGL730Eqys6i974sSJCA4Oxvr16zWmmzlzJuRyOWbMmGG4C9HF815pVS4Hyspb55yMMYOxmKBaXl6OzMxMxMTEqO1TbEtLS9Oa/vjx4wCA2NhYtX3R0dHIzMxEeblqEPvyyy/xzTffYMOGDXB1db2P3DeDSrtqSeuckzFmMBYTVAsKCkBECAoKUtvn4OAANzc35OTkaE2fn58PV1dXODs7q+0LCAgAAOTm5iq35eTkYPbs2XjxxReRkJCgdz6lUqnKo9k8G7arNn0DjTFmXmyaPsQ8KEqRTk5OGvc7ODjoDGLl5eU60wJQppfJZHjyyScRGBio1w2whrSdQ2+uroCVlVD955IqYxbHYoIq3Ru2SVqGbxIRrBvOnq9hv660AJTpFy9ejD/++ANpaWmwt7e/n2w3n7WV0F+1+BZQIQXuVgP2dq2bB8ZYi1lM9V9Rba+srNS4v7KyEi4uLjrT60oLAC4uLkhLS8O7776Ll156CQEBASguLkZxcbHymPLychQXF0Mul2t8r4qKCuXjxo0bel+fCk+P+ufXi1r2Howxk7CYoBoSEgKRSIT8/Hy1fVKpFGVlZQgMDNSZvrS0VGMTQX5+PqysrODv748dO3agrq4Oy5cvh5eXl/KxcuVKAMC4cePg5eWFvLw8jedxdHRUebSIv2/986sFLXsPxphJWEz138nJCeHh4UhPT1fbp7jrHx8frzV9TEwMvv32W6Snp2Po0KEq+9LT0xEREQFnZ2c89dRTePDBB9XSb9q0CV9++SXee+89REZGomPHjvd5RTp4eQJ2dkB1NVB4XVgI0MZiflWMtWt6l1Rv3ryJ06dPo6KiQuP+4uJibNq0yWAZ02Ty5Mm4cuUKNm/erNxGRFi5ciXs7OxU+q82lpycDFtbW6xYsUKlbTU1NRV5eXmYOnUqAKBz584YPny42qNz584AgL59+2L48OHGbWu1EgGBfsJzmUwIrIwxi9BkUK2rq8PTTz+Njh07ok+fPvDy8sKLL76oNqzz8uXLePrpp42WUQB48cUX0aNHD0yZMgWvvfYa1q5di8TEROzcuROLFi2Cr69Qbc7OzsZXX32FY8eOKdMGBwfjzTffxM6dO5GYmIi1a9fitddew9SpU9G/f//W69yvr0D/+ufcBMCY5WhqyNX7779PEomEFi1aRDt27KB58+aRo6MjRUVF0fXr15XHHT9+nKysrIwx6ktFUVERTZ8+nby9vUkikVBUVBRt2rRJ5Zj169cTAJoyZYpa+jVr1lCPHj1ILBZTYGAgzZ49m27dutXked9+++3WGaaqIJMRbd0uDFn95gei2rrmpWeMmYSISPcU8xEREZg0aRLmzZun3Hb+/HmMHz8etbW12LVrF7p27Yq0tDTEx8dDxusrKUmlUmW/1YqKiubfuDr+F5CdKzx/MBYI8td5OGPM9Jqs/ufk5KjdAAoPD8fRo0fh6emJAQMG4MSJE0bLYLsWHFD//NJl0+WDMaa3JoOqp6cnrl27prbd3d0dv/32G3r16oWhQ4di3759Rslgu9bRG3C6V7q9cRMov23a/DDGmtRkUO3bty++//57jfscHR3xyy+/ICEhAW+99ZbBM9fuiURAaJf61xe5tMqYuWsyqD7xxBPIy8tDSYnmcehisRjbtm3Ds88+q3GyE3afOneqX2U15wpQU2vS7DDGdGvyRhVrufu+UaXwx0ngUrbwvHdPIDzUQDlkjBmaxQxTbdcaNgGcvyiMsGKMmSUOqpbApQMQdK8nwN1q4AK3rTJmrjioWoqe4YDo3vPzF7htlTEz1eKgWlJSgl27dmH79u3IysrSO93Nmzdbesr2zaUD0ClYeF5TKzQDMMbMTouC6jvvvAN/f388/PDDGD9+PLp3746EhASt0+GdOXMGS5cuRXx8PPz8/O4rw+1azzChmxUgBFUtk9swxkyn2Xf/U1NTMWnSJOVrKysr5YTN3bp1w7Fjx+Du7o5Tp05h48aN+OGHH5TBloggEonazVBWg939b+hkBnD+kvDcryMwOL4+0DLGTK7ZJdVPPvkEADB27FhkZ2ejrq4O2dnZmD59Oi5duoQPP/wQL774Ivr27YtVq1bhypUrICJERkbizTffxJEjRwx+Ee1KRDgguTftYOF1oEB9tBtjzHSaXVJVLNVcUFCgVvJ6/PHHsW/fPpSXl4OIMHDgQEyePBljxoxRTsvXnhilpAoAV/KBI/eW43aQAA8PB8Riw7w3Y+y+NLukevv2bYSGhmoMEPPmzUNZWRkA4OOPP8aBAwfwzDPPtMuAalRB/sK8AABQWQX8ddq0+WGMKbXoRpW2We979OgBAPD19cXMmTNbniumm0gExPQFbO8tsZKTxxNZM2YmDNpPVRFsg4ODDfm2TBNHB6BvVP3r9BOAltViGWOtp0VBNTs7G++99x527dqFwsJCtf3W1tb3nTGmh5AgIOBeF7XqGuBwGqBl6WzGWOto0RKdhYWFeP3115WvXV1d0bNnT0RERAAAqqurIZPJOLgam6IZoLQMkFYCxbeAk2eAvpGmzhlj7Vaz7/5/8803OHXqFE6fPo1Tp07h+vX6lT5FDfpL2traIjw8HFFRUYiMjFT+dHNzM1zuzZzR7v43VlIK7NlfX0qN7Qd05iYYxkzhvqf+u3nzpkqQPX36NC5cuIC6BjMpNQy2gYGByM3NvZ9TWoxWC6qAMDXgHyeF51YiYNggwNvTeOdjjGlklPlUq6urcfbsWZVgm5GRgfLych5RZSxEwJ+n6uddtRMDI4YAHZyNd07GmJpWnaQ6NzcXp0+fRlJSUmud0qRaNagCQvV//xHgepHw2tFBCKwOEuOelzGmxDP/G1GrB1UAqKkB9h4Ayu4tEujSARg+WCi5MsaMjudTbWvEYmDIg0IpFRBWYP39kBBsGWNGx0G1LXKQAMMGAvZ2wutbZcBvhzmwMtYKOKi2Vc5OQMKgBoG1FNh3ELh717T5YqyN46Dalrl0UA2speVCe6uUh7MyZiwcVNs6RWBV9AC4XSEMFCgrN2m2GGurOKi2By4dgBGDAad7vQ8qq4A9B4AbRabNF2NtEAfV9sLRUeiz6n5vmHBtrXDzKivHpNlirK3hfqpGZJJ+qk2pqxNmsyqsn7MBoV2APr0Aq3b2P/b8RSBT/5WAlcK6AuGhhs8PaxNaNEsVs2A2NsCgOGE2qwv3AsrFy0Ib64CY+vWv2oPaOqCqqmXpGNOCg2p7ZGUlTA/o0gH48yQgJ6CoGNi5Twis7WUiFlsbQNJ4CC8BVfe6nUnsAWhYqdaWvzZMO67+G5FZVv8bu1kCHD5eH0hEIqBXD6BH9/a59HVdHbDlR+F5cpJQsmesGdpZIxpT4+UBjEwAvL2E10TA6bPAb4d4eRbGWoCDKhOqucMGAhHh9dtu3AR+3QtcuWq6fDFmgTioMoHVvWp/w4ECNbXAkXSht0B1tWnzx5iF4KDKVPl4AQ8PB4IC6rfl5QO/7BF+tvUmeHmD6ysqVn3NmB4sLqiWlJRgzpw5CA4OhkQiQWRkJNatW6d3+o0bN6J3795wdHSEr68vZs2ahdLSUrXj7ty5g3nz5iE0NBQSiQTdu3fH0qVLUVtba8jLMU9iMTAgGoiPBsS2wra71UKJ9dCxtjt3wNUC4Jfd9a/3HwG27xC2M6Yni7r7L5VKMWjQIJw5cwazZs1CWFgYtm7din379mHx4sWYP3++zvRLly7F/PnzkZCQgPHjxyMnJwerV69GeHg4jh07Bsm97jW1tbVISEjA0aNHMW3aNPTp0wdHjx7Fpk2bMHr0aPz8889659fs7/43paoK+OMUkN9gKXIbG6GpILRL2xkwcLUAOHRc+/6BsUCgf+vlh1kusiDLli0jAJSamqrcJpfLaeTIkSQWiykvL09r2qtXr5JYLKZRo0aRTCZTbk9JSSEAtHz5cuW2devWqW0jIpozZw4BoD179uiV34qKCgJAAKiiokLfyzQ/cjlR7lWib38i+npb/eOXPUQ3bpo6d/dPJif6/hfVa2v8+P4X4TjGmmBRxYyNGzfC398fEyZMUG4TiUSYO3cuampqkJKSojVtSkoKampq8NJLL8GqQelq4sSJCA4Oxvr165XbysvL0bNnT0yfPl3lPRITEwEAJ06cMNQlWQaRCAgOAMYkAl1D6reX3ZtK8Gi6MEmLpbpZ3HT+K6uE4xhrgsUE1fLycmRmZiImJkZtn2JbWlqa1vTHjwtVu9jYWLV90dHRyMzMRHm5MB3eiy++iIyMDLi7u6scpwimnTp10noeqVSq8mhTxGIgug+QOARwc63fnnsV+HkXcOa80Hne0lTpOXG3vsexds1ihosUFBSAiBAUFKS2z8HBAW5ubsjJ0T7jUn5+PlxdXeHsrL5kc0CAcKc7NzcXkZGRKvvu3r2L3NxcfP/991i0aBGio6Mxbtw4redRtKG2aZ4ewEPDgKxsIOOcsExLnQw4c07Y1usBICRY6KZlCfSd76A9zYvAWsxigqqiFKktaDk4OOgsGZaXl+tMC0Bj+s8++wwvvPACAMDLywtr1qyBWMwrk8JKJNyoCg4UgumlbKG7VdVdIO0vIPMSEPkA4O9r/sNdvTyFvrm6mgAcJMJxjDXBYqr/dK+TAmnprEBEsLa21pleV1oAGtPHxsbihx9+wOrVq2Fvb4+4uDidd/8rKiqUjxs3bmg9rs2wEwP9ooS+rf6+9dvLbwMHjwG79wPXzXwybCuRMMGMLn0jLafkzUzKYkqqimp7pZbx6JWVlQgMDNSZvrhY840GxXu6uLio7YuOjlY+HzduHB544AHMmTMHY8aM0fheFtltyhBcOgCD44Gim8DJv4GSW8L2klvCPALeXkCv8Po5BsxNoL/QberPU6ptpw4SIaBydyqmJ4spqYaEhEAkEiE/P19tn1QqRVlZmc6gGhISgtLSUo1V/Pz8fFhZWcHfX/cXJyAgAIMHD0Zubi5KSkqafxHtgbeXcCNrYCzg0qD9uugmsPeg8Lhx0zxHZgX6A6MT618PGQCMHcUBlTWLxQRVJycnhIeHIz09XW2f4q5/fHy81vSKHgKa0qenpyMiIkJZGh4zZgxCQkJQp+FO9p07d2BlZQU7O7sWXUe7IBIJgWjUCCCuv7BctkLRTWGp7L0HgIJr5hdcG1bxvT25ys+azWKCKgBMnjwZV65cwebNm5XbiAgrV66EnZ2dSv/VxpKTk2Fra4sVK1aotK2mpqYiLy8PU6dOVW4LDg5Gbm6u2vDXQ4cO4eDBgxg+fHj7uMt/v6xEQEgQMHoEENuvfuFBQJjH9cBRYMc+oUuWXG66fDJmQBY1TLWqqgr9+vVDVlYWnn/+eYSGhmLLli3Yu3cvVq5ciVdffRUAkJ2djaNHj6JLly6Ii4tTpn/nnXewYMECDB8+HMnJybh48SJWrVqFyMhIHDhwQDlMtaioCLGxscjPz8e0adPQu3dvnD17Fp9++ilcXV1x+PBhdO3atcn8tolhqoYklwNX8oFzmUD5HdV9jg5AWDegcyfTzqzPk1Sz+2RRQRUAbt68ifnz52P79u24c+cOunfvjpdffhlPPvmk8pgNGzbg6aefxpQpU7BhwwaV9J988glWr16NrKws+Pj4ICkpCQsXLoSbm5vaef7v//4P27dvR1FREXx8fDB69Gi8/fbb8PPz0yuvHFS1IBLmEjh3AShpNJmNra0waiu0ixBojUnjwn96LKfCC/8xHSwuqFoSDqpNIBLaWM9dBK416n4mEgGBfkBoV2F1AmP0dc04B/x9vvnpIsKFCWUY04DrNsx0RCLAx1t4lJULAwYU7atEQF6B8HBzAbp1AToFGrY6rnHhPz3TMaYFl1SNiEuqLVB1VxidlZUtzOHakK0t0DlYaB5w6WCa/DHWBA6qRsRB9T7IZEIp9WKWersrIHR36hICBPkDOkbSMdbaOKgaEQdVAym5JZRer1wFZI26XoltgU5BQJdOqjNnMWYiHFSNiIOqgVXXADlXgKwc4PYd9f1urkLzQKdAwFiDMzT2GNAD9xhoN7jFnVkOO7HQl7V7V2HwQFYOcDW/vvRaWgb8VQaczBAmdwkJBnw7AtYGHONSWycsMdOSdKxd4KDKLI9IJLSpensCNZFCs8DlK8Cte22vcgKuFgoPO7GwMmxIEODhfv9dszT2GNCjbyv3GGg3uPpvRFz9b2Vl5UD2FSA3T73nACAMk+0UKMwBa8jeAzwKizXAv33Wdri6AH16AVERwmCCnDygoLC+eaBCCvydKTxcXYTgGhygOieBMXA7bLvCQZW1PVZWQpuqvy9QUyssP52bJ0w5qFBWLjxO/w24uwnBNdC/ZQFW3qCyV1QMdPRRnd2K22HbFQ6qrG0T2wrdrbp0EpZLycsX2mAb9n29VSo8Tp4RAmyQvxBgnfWYiexqgTCxtcL+I+oTW3M7bLvCbapGxG2qZqyiQpgxKy8fKC3XfIyrixAYA/2ENtjGN7muFgCHjms/x8BY7RNc19QC27YLz4cMUC/dsuYxoyYW/lfI2icnJ+CBMOFx+44QIBsHWEUTwZlzQrNAgJ/w8PQQ9v91Wvc5/joN+PupB0t9SresecyoiYWDKmMdnOsD7J0KIehdLaxfZwsQbnJlXhIedmLAzU336quAsP9mMeDTYF0ubaXbyiphu67SLdNOUxMLyet7gYhtAStr9dqGEZpYuPpvRFz9t3CVlUJwzS8UbkC15KsSHy104wKEG1rbdzS9FPbYUdwUcL8UtQETLOLIJVXGtHFwEEZvde8qDJEtvAbkXwOuXQfqZPq9h8S+/vnN4paVbvVhRm2KJmfi2gAHVcb0YScWhr2GBAszaF0vAo6kNR1cMy8JTQp+PqqlJl30Pa6hlrYpnjmvPRhbYsCVU8vbug2EgypjzWVtLfSBjeuv++4/IKwYW3BNeK7v8jANS7f6atymKJMBNTVNp6urEx6aWGI/WWPWBvTEQZWxlgr0F6qSjdvuxGLAxVnoVVDdILBJK5t+TwcJ4OXZ/LyEh9aXKpvq6mVjozmQisWqc9NaYj9ZY9YG9GSBnxpjZiTQX1gORlOfUzkJgwquXQcKbwC3bgFN3evy7whUVQItvampT/VXW8m0psbyex/oW8pvSW1ATxxUGbtfDdvmvD3rX1uJAE934dGzh1BqvVEkTLjdcMhsQ5dyhIeTI9DRW6ii+ngB9noGAX2qv7oYub3R6Lw8hdJ+Uz0sWlIb0BMHVcZai2IawqAAoVS47Sdhu7sbUH5baAdVqJAK88Vm5QivXTrUB1hvT+2TcN9vtdbI7Y1GZyUSuk3pav7oG2nUfxocVBlrDo1dlxrU6X/aBY3j+BvfSbdqMHH28EHC65JSoVfBjSKguER1opby28Lj4mXhtauLEFx9vIRSl/29IGuIaq0R2xtbhba27lbqp8qd/42IO/+3QRnngL/PNz+djY2wGqxSUxOqEODnK4wEunETKC3V3R7r0kEIsp4ewsQwd+8jMCYMsrySqqZ/dvqMqOKx/4yZmMYZp5pQW6u765K2kqHEHujVQ3heUytUy2/cBIpuCkvHNAyyipLspezm5a0xI7c3Gk1T/XRragHUak5nYBxUGWuOhl2X9NXS0U4NuzSJbevniAWENtmbJUKAvVFcv5TM/TJye6PRtOSfnSKdgXH134i4+s9azdlM4PwlQC6vfzRX436qljiiygxwSZWxtkAxy5aCTCbc+LpZAlzOEXoTNKXxCKwaDdVl1iQOqoy1RdbW9SvOWomEOQiIhPW6FCXZpiqp5y8IQVnR19bD3aid5tsKrv4bEVf/mVmrqgJu3hK6bxWXALfKmm42cHAAPN2EAOvhDri78uqxjfCnwVh7JZEAUqmwrAwgDE6o1dFLARDmmM2rBPIKhNciAC4ugIfbvYe70L2rYT/cdoaDKmPtWUunDFQg1C87czlX2GZtBbi6CkHW/V6wdXa2zF4FLcBBlbH2TNEViUi/AQP2dkIg9fYUunmVlAr9Yxu2IsrkwlI0DZejsbEWlqBxdxUCrbtrmw203KZqRNymyizGjZvAvoNNH6dptFVdndAee6v0XjAt1a+3gY014OYqPBSBtoOzxTcdcEmVMXZ/85Da2NT3NFCorhGG1paUCgG3pFRoj22oTib0LrhZUr/N2kqY10ARbN1chdc21rAUHFQZY4afh9ROLMwr29GnftvdaqE0W1om/LxVpj5xt0wuBOCSRiPERCKhBGt176fISthmhgMUuPpvRFz9Z2ZPMYRW7zZVe8MGs+pqIbieu6B9jlldnByB4ADhxpibC+DkZPJ2WotrvCgpKcGcOXMQHBwMiUSCyMhIrFu3Tu/0GzduRO/eveHo6AhfX1/MmjULpaXq46YV5+nUqRPEYjG8vLyQnJyMzMxMQ14OY6aluPuv76xWd+8KxxtqIhI7O8DXB/DrKNwwk0iE0rCdWL8qf4UUOHtBWITx593A1h+BXb8BaX8BF7KEQK3PWl0GZFElValUikGDBuHMmTOYNWsWwsLCsHXrVuzbtw+LFy/G/PnzdaZfunQp5s+fj4SEBIwfPx45OTlYvXo1wsPDcezYMUjuTchw9+5d9O/fH+fOncPTTz+N/v37IycnB//73/8gEolw9OhRPPDAA3rll0uqzKw1nuxF24KBrT0vwNUC9flQ7eyAYH+h6l9aBpSWCzOA6cPXBxj6oDFyqsaigury5cvxxhtvIDU1FRMmTAAAEBEefvhh/Pbbb8jKykJgYKDGtPn5+ejSpQsSEhLw888/w+reHcbU1FQ88cQTWL58OebOnQugPvh++umnePbZZ5XvceLECcTExCAxMRG//PJLk/nloMoskpyEaQar7gqlRi/P1q1SN7VwoWIdLSKhTbasXAiwZeVCsNXU8yAkSFj9thVYVFDt0aMHbt++jfz8fJXtv//+O4YNG4Zly5bh9ddf15h2xYoVeP3117F7926MGDFCZV+nTp0gkUhw/rww+fCwYcNw5MgRVFZWwtpatQoSFRWFrKwsVFRUNJlfDqqMNZOcgO07ml5jauwo7YG+tk4IsOWKYHsb6BQAdOtinDw3YjF3/8vLy5GZmYnx48er7YuJiQEApKWlaU1//Ljwny82NlZtX3R0NLZu3Yry8nK4uLggJSUFN27cUAuoRISioiK17Q1JpVKNzxkzO6YukWqiz8KFTa2jZWsDeHkIDxOwmKBaUFAAIkJQUJDaPgcHB7i5uSEnJ0dr+vz8fLi6usLZ2VltX0BAAAAgNzcXkZGR6NixIzp27Kh2XEpKCq5du4akpCSt51GUTBkzK+badtrY/fSXNRMWE1TLy8sBaA9aDg4OOkuG5eXlOtMCukuWf//9N2bPng0bGxv8+9//1jfbjJkHfcf4Nw60RlhuRCdD95c1AYsJqoqmX21NwESks1pORDrTAtCa/uTJk3jooYdQVlaGjz/+GH379tV6noZtrVKpFD4+PlqPZazVNHuM/73+qEZYbkQnL0+hzbSpNlUzXkfLYoKqotpe2Xio2z2VlZVa7/wr0hcXF2tNCwAuLi5q+3799VdMmDABFRUV+PDDD/Hcc8/pzCffjGJmSbG2lr5j/AdEm2ZFVSuRsE6Wrrv/Zr6OlsUE1ZCQEIhEIrU7/4BQIiwrK9MZVENCQnDixAlIpVK1wJefnw8rKyv4+6uuB/7JJ59g9uzZsLa2xtdff42JEyca5mIYMxVzbbNs3OYrFmtv8/3ztPAAzHKYqsWMqHJyckJ4eDjS09PV9inu+sfHx2tNr+ghoCl9eno6IiIiVG5iffDBB5g5cyY6dOiAPXv2cEBlbYO5tlkq2nwVD22joGpqVI9r7TZfPVhMUAWAyZMn48qVK9i8ebNyGxFh5cqVsLOzUw4I0CQ5ORm2trZYsWKFSttqamoq8vLyMHXqVOW2Xbt24eWXX4aHhwcOHjyIQYMGGeV6GGs15y8C3/8KHFEvVGh0JF04/vxF4+ZLQdHm29xHa7f56sGiOv9XVVWhX79+yMrKwvPPP4/Q0FBs2bIFe/fuxcqVK/Hqq68CALKzs3H06FF06dIFcXFxyvTvvPMOFixYgOHDhyM5ORkXL17EqlWrEBkZiQMHDiiHqYaFheHChQuYOnUqEhISNOZl8uTJTeaXO/8zs5FxDvj7fPPTRYQDvXoYPj9tmEUFVQC4efMm5s+fj+3bt+POnTvo3r07Xn75ZTz55JPKYzZs2ICnn34aU6ZMwYYNG1TSf/LJJ1i9ejWysrLg4+ODpKQkLFy4EG5ubgCAvLw8BAcHN5kPfT42DqrMbFhKP9U2wOKCqiXhoMp0ahzoAKHLk2L5aMUcoqJGd7oNFejMcURVG2B+DRKMtRctXXTPUDdnrESm6TbVxnFQZcxUFDdnAO3VcYWG1XIzvDnD6vFvhzFTUXTIV8zMpGsuZRtr3TMzMbNhUV2qGGuTmjMzEzN7HFQZMzVzHeXEWoSDKmOmZq6jnFiLcJsqY6bScCVTfRxJN9tlmVk9DqqMmUpzu1Qppuwzw/HurB4HVcZMpWGXKkD/UU7cpcqs8YgqI+IRVazZeJSTxeN/eYyZEx7lZPH47j9jjBkQB1XGGDMgDqqMMWZAHFQZY8yAOKgyxpgB8d1/I2rYW00qlZowJ4wxXRwcHCBqPBl4C3FQNaLKykrlcx8fHxPmhDGmiyH7kXP1nzHW7hmyJskjqoxILpejuFiYA1Nb9UIqlSpLsTdu3OBRVxaGf3+Wq+Hv7s6dO8rRj/eLq/9GZGVlBW9vb72Pd3R05C+lBePfn+UyVHsqwNV/xhgzKA6qjDFmQNymyhhjBsQlVcYYMyAOqowxZkAcVBljzIA4qDLGmAFxUDWxkpISzJkzB8HBwZBIJIiMjMS6detMnS2mhUwmw8CBAzX2axw+fDhEIpHGx/79+1s/swwAcPbsWYwbNw6urq5wcXHBkCFD8Ouvv6odl5eXh6eeegp+fn5wdHREbGwstm/f3uzzced/E5JKpUhMTMSZM2cwa9YshIWFYevWrZg2bRquX7+O+fPnmzqLrJElS5bg8OHDGvdlZGSgX79+eOGFF9T2hYeHGztrTIM///wTQ4cORXV1NWbMmIHQ0FD89NNPGD16ND744APl7+r69esYNGgQbt26heeffx7+/v744osvkJSUhK+//hpPPPGE/iclZjLLli0jAJSamqrcJpfLaeTIkSQWiykvL8+EuWONpaWlkY2NDdnZ2VHjr05hYSEBoLlz55ood0yTfv36EQDasWOHcptcLqfk5GQSi8V08eJFIiKaMWMGiUQiOnLkiPK4qqoqioyMJE9PT6qoqND7nBxUTSg8PJz8/f3Vtv/2228EgJYtW2aCXDFN7ty5Q127dqUxY8bQ4MGD1YLqzp07CQBt2rTJRDlkjeXl5REASkhIUNt36tQpAkDz58+nuro6cnJyovj4eLXj1q1bRwBo8+bNep+X21RNpLy8HJmZmYiJiVHbp9iWlpbW2tliWrzwwgsoLy/H559/rnH/6dOnAQAREREAhKYduVzeavlj6q5evQoAiIyMVNvXrVs3AMAff/yBs2fPoqKiArGxsWrHteS7yEHVRAoKCkBECAoKUtvn4OAANzc35OTkmCBnrLHvvvsO69atw9q1a7XOi6sIqhs3bkTHjh3h5OQEZ2dnPPXUU7h582ZrZpfdo5h16vbt22r7FLPHFRYWIj8/HwA0fhcDAgIAoFnfRb5RZSLl5eUAoHW6MQcHB14twAwUFBTgmWeewbRp05CUlKT1uIyMDADAiRMn8N5778He3h579uzB2rVrkZaWhrS0NLi6urZSrhkg3Bx0c3PDzz//jNu3b6NDhw7KfVu2bAEAVFVV6fwuOjg4AGjefKscVE2E7k25QFqmXiAiWFtbt2aWWCNEhClTpsDV1RUffPCBzmNnzJiBO3fuYO7cubCyEiqAjz32GLp3745XXnkFK1euxOLFi1sh10zB1tYWb731Fl555RU89NBDWL58OQICAvDLL79g4cKF6NChA2xtbXV+FxXbmvNd5KBqIs7OzgBUl1xpqLKyEoGBga2ZJdbIf/7zH/z222/44YcfcPfuXdy9excAUFtbC0CoQlpbW8PNzQ2zZs3S+B6zZ8/G3LlzsWvXLg6qJvDyyy+juroa7777LgYPHgwACAwMRGpqKl566SW4u7vr/C4qtrm4uOh9Tg6qJhISEgKRSKRsz2lIKpWirKyMg6qJ/fTTTyAirdV+Ly8vBAcHIzc3V+t7iMViuLm54c6dO0bKJWvKvHnzMGfOHGRkZMDBwQE9e/ZEXV0drly5gtjYWISEhACAxu+iYltzvoscVE3EyckJ4eHhSE9PV9unuNMYHx/f2tliDbz//vsoLS1V2/7KK68gIyMDe/bsgUQiwZkzZzBhwgQkJCRg1apVKscWFRWhuLgY0dHRrZVt1sCWLVtgZ2eHpKQkle/Trl27UFNTgyFDhiAsLAwuLi4a7/C36LvYkv5fzDCWLFmitfO/nZ0dFRYWmjB3TJvG/VQrKyvJzc2NXFxc6MqVKyrH/vOf/yQAtGXLltbOJiOiQYMGkaurK5WUlCi3lZeXU58+fcjPz48qKyuJiOjZZ5/V2Pm/V69e5OPjQ1VVVXqfk4OqCVVWVlKPHj1ILBbTq6++Sp999hkNHz6cANDKlStNnT2mhabO/19//TWJRCLy9fWld999l1atWkUJCQkEgCZNmmSinLK9e/eStbU1RURE0KpVq+iDDz6gHj16kJ2dncooq2vXrlHHjh2pQ4cOtGDBAlqzZg3169ePRCIRffPNN806JwdVEysqKqLp06eTt7c3SSQSioqK4lE5Zk5TUCUSvsAJCQnk5ORE9vb2FBkZSR999BHJZDIT5JIp7NmzhwYOHEguLi7k6elJjzzyCKWnp6sdl52dTcnJyeTm5kZOTk4UFxdHv/zyS7PPx8upMMaYAfGIKsYYMyAOqowxZkAcVBljzIA4qDLGmAFxUGWMMQPioMoYYwbEQZUxxgyIgypjjBkQB1WmxONAWoY/N9YQB1UTq66uxjfffIMxY8agc+fOsLe3h5ubGwYOHIjVq1ejurra6HmQyWT4+OOP1ZZW3rBhA0QiESZPnmz0PCiIRCKIRCLU1dU1eeyCBQuUxzd8KKbb69OnD/7973/j+vXrGtMPGTIEIpEIe/fubVFetX1u7cVTTz2F3r17QyaTmTorWv3xxx+wsbHB7t27W+2cPPWfCZ07dw7Jyck4e/YsHBwc0KtXL/Tp0wfXrl3DH3/8gcOHD+PTTz/Fvn37tK6NZAhff/01Zs+ejUmTJhntHMbUuXNnxMXFKV/X1dXh1q1bOHnyJBYtWoSPP/4Y3377LYYOHWrQ81r653Y/tmzZgi+//BIHDx406xUq+vfvj6lTp2LKlCk4d+4c3NzcjH/S+52sgLXMpUuXyNnZmQDQ888/T8XFxSr7r169SiNGjCAA1KNHD+UUZcawfv16jbMplZWV0fnz51t1CkIABIBqa2ubPPbtt98mADRlyhSN+6urq2n+/PkEgDp06ECZmZkq+69cuULnz58nqVTaorxq+9zauvLycvLx8aGkpCRTZ0UvhYWFJJFI6JlnnmmV83H13wSICE888QTu3LmD+fPn48MPP4SHh4fKMQEBAfj+++/RrVs3nDt3TuvSyMbk4uKCsLAw+Pr6tvq5DUEsFmPx4sV49tlncfv2bbzxxhsq+4OCghAWFqZc3I3p5/3338eNGzfw+uuvmzorevH19cWTTz6JdevWITMz0/gnbJXQzVQcPHiQAJCvr2+TJdD169fTwIEDadWqVWr7vvzyS3rwwQfJ2dmZ7O3tKSIighYtWqRW8srJySEAlJSURFu2bKGgoCCyt7ennj17Ut++fZWlQ8VDUfLTVRL77bffKCkpiXx8fMjR0ZEiIiJoyZIlaueura2lzz//nIYNG0YeHh5kY2NDbm5uNGTIEEpJSVF7XxiwpKpQUlJC9vb2BIAKCgqU2xVT+O3Zs0e5TS6X03//+1+KiYkhd3d3kkgk1KNHD5o3bx7dunVLLa2mz41ImCv3/fffp/j4eHJzcyMbGxvy9PSkUaNG0a5duzRed2RkJJWVldELL7xAgYGBJBaLqUuXLvTWW29pLE3L5XL64osvaMCAAeTq6kpubm4UHx9PmzdvJrlcrnb87t27aeTIkeTu7k52dnYUFhZGb7/9NlVUVOj8/BqSSqXk5uZGDzzwgNq+KVOmEAA6c+YMff7559SrVy+yt7enjh070syZM+nOnTskk8loxYoV1K1bN+Vn+/HHH6vlFwD17duXSkpKaObMmeTr66v8G1dMjXn16lV64oknyMPDg1xdXSkhIYFOnjypMd9//vknAaBp06bpfa0txUHVBGbNmkUAaObMmS1KL5PJaOLEiQSA7OzsKDExkcaPH08eHh4EgKKiolSaExRBtXPnzmRjY0P9+/enUaNG0ciRI2nRokUUFxdHACgkJIQmTZpEn376KRFpD6rLly8nkUhEVlZWNHDgQBo/fjx17NiRANCgQYOourqaiIQv/dixYwkAubu706hRo2j8+PHUvXt3ZSD68MMPVd7bGEGViJQTRn/55ZfKbZqC6osvvkgAyMPDg0aPHq38x4F7zTB3794lItL5uVVVVVF0dDQBID8/P3rkkUdo7NixFBwcTABIJBLRDz/8oHbdXbt2pZ49e5JEIqGEhAQaNWoUicViAkBjxoxROb6urk752To6OtLDDz9MDz/8MEkkEgJAb7zxhsrxixYtIgBkY2NDcXFx9Oijj5Kfn5/y76XhPwxdUlJSCAC99dZbavsUQXX06NEEgOLi4mjMmDHKZq6kpCR64oknSCwW09ChQ2n48OFkZWVFAOj999/X+HmEhoaSs7MzjR07lmJjY1X+bjp27Ei+vr6UlJREoaGhys8iLy9PY979/f3JwcFB+Ts0Fg6qJqD4gm/YsKFF6T/88ENlkMzKylJuv337tvIP+tFHH1VuVwRVAPTcc88ptysmT9YWPDVt/+OPP8jKyoo6dOhAhw8fVm6vqKhQBqn//ve/RET07bffEgCKiYlRK2ktXbpU+cVpyFhBVfGPrGEwaBxUr1y5QgAoNDSUbt++rTyusrJS+YVuGJS1fW7vv/8+AaDx48erXEddXR0999xzBICGDx+u8brDw8MpOztbuf3PP/8kW1tbZQlQ4T//+Q8BoJ49e6qUvi9fvkze3t4EQFlq27t3LwEgf39/lZJcdXU1TZ06tVntwk899RQBoN27d6vtUwRVkUhEP/74o3L7X3/9RSKRiACQk5OTSh4+++wzAkDdu3fX+Hn06NGDbty4odz+/PPPK/c99NBDylJ2bW0tDRo0iADQ0qVLNeZdURBp+E/UGLhN1QSuXbsGAC2+o69Yg/7zzz9Hly5dlNudnZ3x9ddfw8XFBd999x2ysrLU0r700kvK54r16Zvj008/hVwux5tvvokBAwYotzs6OmLlypXo0qULCgsLAQA1NTUYO3Ysli1bptZuOWPGDABATk5Os/PQEq6urgCEZaW1UXS9cnd3h6Ojo3K7RCLB6tWrsXbtWvTv37/Jc4nFYjz88MNYunQpbGzqO9hYW1vj2WefBaD9upcuXapc3RMA+vbtiwcffBAA8Pfffyu3r1mzBoDwN+Dn56fc3rlzZ8yfPx89e/bE+fPnAQDvvfceAOHvJioqSiWfH3/8Mby9vbF582YUFBQ0eW379+8HAPTs2VPrMaNHj8bYsWOVr/v06YOwsDAAwKxZs1Ty8NhjjwGAxr9VAFi4cCG8vb2Vrxv2tPjggw+UvycbGxuMGzdO53v16tULAPD7779rzbshcFA1AcUXTZ++mI1dvXoVOTk58PT01NhFyMXFBSNHjgQAHDhwQGWfRCJB165dW5DjeoovVcMvjUL//v2RlZWFFStWAAAmTJiAH3/8EUOGDFEeU11djVOnTiElJQWA0NezNfo51tTUABD6wWoTEREBd3d3HD9+HHFxcVi9ejUuXboEAOjXrx+mT5+O7t27N3mu2bNn45dfflE5trKyEunp6fj+++8BQGv/44ZdwxQUQVOxBn1BQQEuXboEHx8fjau0vvDCC8jIyMDEiRMhk8lw8OBBAEBCQoLasQ4ODhg8eDBkMhkOHTqk87rkcjkKCgogFovRsWNHrcfFxsaqbfPy8gIAlYAK1P+zk8lkGr8Pjd9L8T729vZqvwvFe929e1djvhT/rK5evao174bA/VRNwNfXFxkZGSgqKmp2WkUpsFOnTlqPUfzxKErECoo/uvuheM+goCC9jr99+zbWrl2LnTt34sKFCygoKIBcLlcJbtQKI5Ju3boFQCiFauPg4IBvv/0WkyZNQnp6unL58M6dO2PcuHGYMWMGunXrptf5bty4gTVr1uD333/HpUuXcP36dRCR8rq1XbOmfpSKf8JyuRxA834HJSUlymCs69qBpoNNSUkJZDJZk309NZ1Hcd2enp4at+v7XorjPTw81NI29V4uLi4AhN+NMXFQNYG+ffti165dSEtLwz//+U+dx5aXl+Pdd9/FsGHDkJiYqPwy6voDUhxjZ2ensr0l1f3GmlO6Pnv2LIYNG4aioiJ4e3ujX79++H//7/8hKioKgwcPRmBg4H3nR1+nTp0CUF8F1GbIkCHIzs7Gjh078NNPP2Hv3r3Izs7Gf/7zH6xevRrbtm3TWEpvaP/+/RgzZgykUikCAwMRExOD8PBw9OnTB506ddLZhNBUYACa9ztQ1ALs7OyUVW1tmqrF1NbWAqgP7trY2trqnb+mGPK9FJ+FsWtGHFRNICkpCUuWLMHPP/+Mu3fvwt7eXuux27Ztw/vvv49Nmzbh2rVryqqgrrbI7OxsAC1vs9XF19cXubm5yM/PR2hoqNr+Tz/9FP7+/hgzZgxmz56NoqIivP7661iyZIlKUC8tLTV43rTJz8/HqVOnYGNjo9IUoY2dnR3GjRunbKPLzMzE4sWL8dVXX2Hu3Lk6gyoRYdq0aZBKpfjf//6HmTNnquw/efLk/VwKACj7Defn52vcf+PGDfz444+IiopCVFQUbG1tUVtbiy+++ELtH21zuLm5QSQSobS0FDKZzKxHUmmiaE9vqsR+v7hN1QSio6MxcOBAFBYWYsmSJVqPu3XrlnL/v/71L1hbWyMoKAjBwcEoLi5WazMFhJLtrl27AACDBw/WKz/6lI4UFDdNduzYobbv/PnzmDFjBhYsWAAAOHbsGABg3rx5aqXkhmOxmyr53K/FixdDJpPh0UcfVbnp0djmzZvRtWtXLF68WGV7WFgYPvroIwCqVWRNn9uNGzeQnZ0NV1dXtYAK1F/3/VxzcHAwAgICcO3aNZw+fVpt/3fffYd//etf2LJlC8RiMeLi4iCXy5V/Fw0REYYPH44BAwYomzu0kUgkCAgIABGpNS1ZAkXTmabCgCFxUDWRNWvWQCKR4N1338Vrr72GsrIylf05OTkYM2YMsrOzERoaqjJ6RXEHf/r06Sol1oqKCkyePBm3b9/GI488guDgYL3yoigpl5eXN3nsrFmzIBKJ8O6776p8oSsqKjB79mwAUE7Aorip8OOPP6q8x8GDBzFnzhzla203Fu5XVVUV3nnnHXzyySdwdXXF8uXLdR4fHh6Oy5cv44MPPsCFCxdU9n311VcAoHJjSNPn5uLiArFYjLKyMuUNIoXvvvsOCxcuBHD/16z4/J599lllezEg1FIWLlwIKysrTJw4EUD938vs2bNVSspyuRz//ve/sW/fPly+fBmRkZFNnjc+Ph5A/T9MS3L06FEAUOm1YhRG7bDFdDp27Bh5enoSAHJwcKBBgwZRcnIyxcfHk7W1NQGgiIgIunLliko6mUxGycnJBIDs7e3poYceovHjxyvfKzIykoqKipTHK/qp+vv7a8zHX3/9pexfOHr0aFq8eDERae+HqehjamNjQwkJCTR27Fhl38hRo0Yp+78q+lICoAEDBtBjjz1GUVFRys71igEDFy5cUL634vjm9FPt3LkzTZo0Sfl4/PHHaciQIcpO5x4eHnTo0CG19Jo6/7/wwgvKaxsyZAg99thjFBkZqexjeeLEiSY/N0VfSmtraxo2bBg9+uijygEPwcHB5OTkRFZWViqj6XRdt6L/59q1a5Xb6urqaMyYMQSAXFxcaOzYsZSYmKgcObZkyRKV93j11VeV1xUTE0Pjx4+nzp07K//2GvY51uXrr78mADR79my98qnrs9Z17do+D11/y7pGAMpkMnJzc6MOHToYdR4NIu78b3JFRUW0YMECio6OJhcXF7K2tiY3NzcaPHgw/e9//1OOTmpMLpfT+vXracCAAeTk5ESOjo4UFRVFK1asoKqqKpVjmwqqRETLli0jPz8/5WgXIt1/pDt37qQRI0aQq6sr2draUlhYGC1evFgtv6mpqcprc3FxoZ49e9KcOXMoPz+f5syZQwDovffeUx7fkqDa+GFtbU3u7u4UGxtLCxcuVJusRkHTF10mk9GaNWsoJiaGnJycyNbWloKCgmjatGl0+fJlvT63uro6+uijj6hXr17k6OhIHh4e1KdPH5o/fz6VlpbSI488QgBo27Ztel23tmClOE/fvn3JwcGBJBIJxcXF0TfffKPxerdv304PPfQQubm5kZ2dHXXt2pWmTZtGly5davKzVpBKpeTh4UGBgYFUV1enVz6JTB9Ud+/eTUDLRzE2h4iIZ9hljOlv2bJlmDdvHrZv345HHnnE1NnRyz/+8Q/8/PPPuHTpkt7dAVuKgypjrFmkUik6d+6MyMjIVp38uaXy8vLQpUsXPPvss/j444+Nfj4OqoyxZtu2bRsef/xx7N69GyNGjDB1dnR64okncOjQIWRkZLTKJNUcVBljLfL000/jzz//xKlTp8y2z+rx48cxYMAA7N69W+MwXWPgoMoYYwbE/VQZY8yAOKgyxpgBcVBljDED4qDKGGMGxEGVMcYMiIMqY4wZEAdVxhgzIA6qjDFmQP8fyn3+gDxRG2MAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join('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
}
