{
 "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\n",
    "from src.stats import print_regression_info, print_quadratic_info"
   ]
  },
  {
   "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 = 'train'\n"
   ]
  },
  {
   "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": "6abc8332",
   "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",
    "\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": "markdown",
   "id": "ff37ddb7",
   "metadata": {},
   "source": [
    "## Concepts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "d6f1b7ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.utils as utils\n",
    "\n",
    "name_concept = 'moves'  # moves, natural, size, heavy\n",
    "\n",
    "path_results = os.path.join(path_dataset, 'results', subject_id, 'concepts')\n",
    "assert os.path.exists(path_results)\n",
    "\n",
    "path_filename = os.path.join(path_results, f'{subject_id}_concepts_{split}_{num_neighbors}_{name_concept}.pickle')\n",
    "assert os.path.exists(path_filename)\n",
    "\n",
    "dict_results = utils.load_pickle(path_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "87148803",
   "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 = dict_results['lh'][indices_area_left]\n",
    "\n",
    "    indices_area_right = np.where(labels_vertices_right == label)[0]\n",
    "    vertices_area_right = dict_results['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",
    "    valid_values = vertices_area[vertices_area > 0]\n",
    "    for i_sample in range(num_subsample):\n",
    "        sampled_indices = np.random.choice(num_vertices_area, size=num_subsample, replace=False)\n",
    "        \n",
    "        dims_areas_linear.append({'Area': name,\n",
    "                                  'Linear Dimensionality': vertices_area[sampled_indices].mean(),\n",
    "                                  'Distance (mm)': dict_distances[name]})\n",
    "\n",
    "df_dims_areas_linear = pd.DataFrame(dims_areas_linear)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "ca170f67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.01574501, 0.00491447, 0.00513644, ..., 0.00245882, 0.00406788,\n",
       "       0.00676342], dtype=float32)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "valid_values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "2fdb70b4",
   "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": 48,
   "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": "code",
   "execution_count": 49,
   "id": "4965fda2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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PtYeEuAqia+vL9HR0ezcubPEPsOILcNkYlG50tLSaNu2LSNHjiyxLz8/n6NHj9KsWTOioqLw9/c3O8JO3sOqZc1707lzZ1xcXOR9rAUkwFWicePGcfr0adasWWPcppTi5ZdfxtPT09gFJipX/fr1KSgo4NtvvyUuLs5k38KFC8nIyGDChAm4ublx1113sW3bNrZv324sk5uby5tvvklwcDC33nprZVdfgFXvTXBwMP379+eLL74wjpAFfRq9Dz/8kHbt2tGhQ4dKvwfhAFUy+66Wys7OVi1btlQeHh7q8ccfV++//77q37+/AtTLL79c1dWr1X755Rfl6emp/P391ezZs9U777yjbr/9dgWoPn36qLy8PKWUUufOnVMNGzZUderUUXPnzlVLlixRN9xwg9JoNOrzzz+v4ruoHZ599lmzmUyseW8OHDigfH19VUhIiFq0aJF68803VfPmzZWnp6fatm1bJd6NcCQJcJUsJSVF3XfffapBgwZKq9Wq9u3bq5UrV1Z1tYRSKi4uTg0dOlQFBgYqDw8P1aJFC/X888+rnJwck3InTpxQo0aNUoGBgcrX11d1795dfffdd1VU69qntACnlHXvzd69e9Wtt96q/Pz8lL+/v+rXr5/asWOHg2svKpOs6C2EEMIpyTM4IYQQTkkCnBBCCKckAU4IIYRTkgAnhBDCKUmAE0II4ZQkwAkhhHBKEuCEEEI4JQlwQgghnJIEOAGUvk6dKJv83ISoviTAVaGrV6/y+eefM2TIEK677jq8vLwIDAykV69eLF68mKtXrzq8DoWFhbzzzjs89NBDJttXrFiBRqNh3LhxDq+DgUajQaPRUFBQUG7ZuXPnGssXfXl4eBAYGEjHjh155plnSE5ONnt8nz590Gg0/PTTTzbVtbSfW21x77330qFDBwoLC6u6KqXatWsXbm5ubN68uaqrIqqILHhaRQ4dOsSoUaP4+++/8fb2pm3btnTs2JFz586xa9cufv/9d9577z22bNlCcHCww+rx2WefMX369FIX/KzurrvuOrp37278vqCggIsXL7J3717mz5/PO++8w5dffslNN91k1+vW9J9bRaxdu5ZPPvmE3377rVqvfN25c2cmTJjA+PHjOXToEIGBgVVdJVHZqjYVZu109OhR5efnpwA1c+ZMlZaWZrI/ISFB3XzzzQpQLVu2VNnZ2Q6ry/LlyxWgxo4da7I9PT1dHT58WJ09e9Zh1y4OUIDKz88vt6wh4e748ePN7r969aqaPXu2AlSdOnVUfHy8yf7Tp0+rw4cPq6ysLJvqWtrPzdllZGSo4OBgNWzYsKquikXOnj2rtFqt+s9//lPVVRFVQLooK5lSijFjxnDlyhVmz57Nm2++Sb169UzKNG7cmK+//prrr7+eQ4cO8eGHH1Z6Pf39/YmKiiIkJKTSr20PHh4evPDCC0yZMoXLly/z1FNPmewPDw8nKioKb2/vKqphzfTqq69y/vx5nnzyyaquikVCQkK45557WLZsGfHx8VVdHVHZqjrC1ja//fabAlRISEi5LbPly5erXr16qbfeeqvEvk8++UTdeOONys/PT3l5eanWrVur+fPnl2iRnDx5UgFq2LBhau3atSo8PFx5eXmpNm3aqE6dOhlbTYaXoUVUVgvl559/VsOGDVPBwcHKx8dHtW7dWi1YsKDEtfPz89WHH36o+vbtq+rVq6fc3NxUYGCg6tOnj1q1alWJ82LHFpzBhQsXlJeXlwJUUlKScXtMTIwC1I8//mjcptPp1Ouvv666du2q6tatq7RarWrZsqWaNWuWunjxYoljzf3clNKv+/fqq6+qHj16qMDAQOXm5qbq16+vbr31VvXDDz+Yve927dqp9PR09dBDD6mwsDDl4eGhmjZtqp5++mmzrUydTqc++ugj1bNnTxUQEKACAwNVjx491Jo1a5ROpytRfvPmzWrgwIGqbt26ytPTU0VFRalnn31WZWZmlvnzKyorK0sFBgaqVq1aldg3fvx4BagDBw6oDz/8ULVt21Z5eXmphg0bqgceeEBduXJFFRYWqkWLFqnrr7/e+LN95513StQXUJ06dVIXLlxQDzzwgAoJCTH+jhuWlkpISFBjxoxR9erVUwEBAapfv35q7969Zuu9e/duBajJkydbfK/COUiAq2QPPvigAtQDDzxg0/GFhYVq9OjRClCenp5qwIABasSIEapevXoKUO3btzfp8jQEuOuuu065ubmpzp07q1tvvVUNHDhQzZ8/X3Xv3l0BqkmTJmrs2LHqvffeU0qVHuBeeuklpdFolIuLi+rVq5caMWKEatiwoQJU79691dWrV5VS+g/goUOHKkDVrVtX3XrrrWrEiBGqRYsWxqDw5ptvmpzbEQFOKaX69eunAPXJJ58Yt5kLcA8//LACVL169dTgwYONQZx/u4pzc3OVUqrMn1tOTo7q0qWLAlRoaKi67bbb1NChQ1VERIQClEajUd98802J+27WrJlq06aN0mq1ql+/furWW29VHh4eClBDhgwxKV9QUGD82fr4+KhBgwapQYMGKa1WqwD11FNPmZSfP3++ApSbm5vq3r27GjlypAoNDTX+vhQN3mVZtWqVAtTTTz9dYp8hwA0ePFgBqnv37mrIkCHGrvhhw4apMWPGKA8PD3XTTTep/v37KxcXFwWoV1991ezPo3nz5srPz08NHTpUdevWzeT3pmHDhiokJEQNGzZMNW/e3PizOHPmjNm6N2rUSHl7exvfQ1E7SICrZIYP2xUrVth0/JtvvmkMWMeOHTNuv3z5svHDZeTIkcbthgAHqGnTphm3FxYWKqVKD2Tmtu/atUu5uLioOnXqqN9//924PTMz0xgwXn/9daWUUl9++aUCVNeuXUu0QBYuXGj8ECvKUQHO8EdF0Q/m4gHu9OnTClDNmzdXly9fNpbLzs42frgWDZCl/dxeffVVBagRI0aY3EdBQYGaNm2aAlT//v3N3nd0dLQ6ceKEcfvu3buVu7u7sWVk8NprrylAtWnTxqRVevz4cdWgQQMFGFszP/30kwJUo0aNTFo4V69eVRMmTLDqOeK9996rALV58+YS+wwBTqPRqPXr1xu3x8XFKY1GowDl6+trUof3339fAapFixZmfx4tW7ZU58+fN26fOXOmcd8tt9xibH3m5+er3r17K0AtXLjQbN0NfxQW/YNGOD95BlfJzp07B2DzyMg33ngDgA8//JCmTZsat/v5+fHZZ5/h7+/PV199xbFjx0oc+8gjjxi/dnGx/q1/77330Ol0zJkzh549exq3+/j48PLLL9O0aVPOnj0LQF5eHkOHDuXFF18s8Zxr6tSpAJw8edLqOtgiICAAgLS0tFLLGKYT1K1bFx8fH+N2rVbL4sWL+eCDD+jcuXO51/Lw8GDQoEEsXLgQN7drg5RdXV2ZMmUKUPp9L1y4kCZNmhi/79SpEzfeeCMABw8eNG5fsmQJoP8dCA0NNW6/7rrrmD17Nm3atOHw4cMAvPLKK4D+96Z9+/Ym9XznnXdo0KABa9asISkpqdx727p1KwBt2rQptczgwYMZOnSo8fuOHTsSFRUFwIMPPmhShzvuuAPA7O8qwLx582jQoIHx+6IjVt944w3j++Tm5sbw4cPLPFfbtm0B+OWXX0qtu3A+EuAqmeFDz5K5XsUlJCRw8uRJ6tevb3bYu7+/PwMHDgTg119/Ndmn1Wpp1qyZDTW+xvABV/QDzKBz584cO3aMRYsWAXD33Xezfv16+vTpYyxz9epV9u3bx6pVqwD9XLLKmEeVl5cH6OfZlaZ169bUrVuX2NhYunfvzuLFizl69CgAN9xwA/fddx8tWrQo91rTp0/nu+++MymbnZ3Nzp07+frrrwFKnd9YdLqDgSGAZWdnA5CUlMTRo0cJDg6mS5cuJco/9NBD7N+/n9GjR1NYWMhvv/0GQL9+/UqU9fb2JiYmhsLCQrZt21bmfel0OpKSkvDw8KBhw4alluvWrVuJbUFBQQAmwQ2u/eFRWFho9t9D8XMZzuPl5VXivTCcKzc312y9DH84JCQklFp34XxkHlwlCwkJYf/+/aSkpFh9rKF1FBkZWWoZwz9kQ0vRwPABUBGGc4aHh1tU/vLly3zwwQd8//33HDlyhKSkJHQ6nUmgUZWQCeTixYuAvnVWGm9vb7788kvGjh3Lzp072blzJ6BvFQ0fPpypU6dy/fXXW3S98+fPs2TJEn755ReOHj1KcnIySinjfZd2z+bmaRn+INLpdIB178GFCxeMgbGse4fyP/gvXLhAYWFhuXPJzF3HcN/169c3u93ScxnK16tXr8Sx5Z3L398f0L83ovaQAFfJOnXqxA8//MCff/7JpEmTyiybkZHB888/T9++fRkwYIDxg7Gsf8yGMp6enibbbemSLM6aVufff/9N3759SUlJoUGDBtxwww3cddddtG/fnpiYGMLCwipcH0vt27cPuNZNVZo+ffpw4sQJNm3axLfffstPP/3EiRMneO2111i8eDFffPGF2dZrUVu3bmXIkCFkZWURFhZG165diY6OpmPHjkRGRpbZzVnehzRY9x4YWseenp7G7sDSlNe6z8/PB64F2tK4u7tbXL/y2PNchp9Fdc68IuxPAlwlGzZsGAsWLGDjxo3k5ubi5eVVatkvvviCV199lZUrV3Lu3Dljd1VZz65OnDgB2P6MrywhISGcOnWKxMREmjdvXmL/e++9R6NGjRgyZAjTp08nJSWFJ598kgULFpgE2EuXLtm9bqVJTExk3759uLm5mXSXlsbT05Phw4cbn+nEx8fzwgsv8Omnn/LEE0+UGeCUUkyePJmsrCzeffddHnjgAZP9e/furcitABjnJSYmJprdf/78edavX0/79u1p37497u7u5Ofn89FHH5X4o8cagYGBaDQaLl26RGFhYbXOYGKO4flreS1Z4VzkGVwl69KlC7169eLs2bMsWLCg1HIXL1407r///vtxdXUlPDyciIgI0tLSSjxjA32L74cffgAgJibGovpY0mowMAx42LRpU4l9hw8fZurUqcydOxeAHTt2ADBr1qwSrceiuQHLaxFU1AsvvEBhYSEjR440GbBQ3Jo1a2jWrBkvvPCCyfaoqCjefvttwLQbz9zP7fz585w4cYKAgIASwQ2u3XdF7jkiIoLGjRtz7tw5/vrrrxL7v/rqK+6//37Wrl2Lh4cH3bt3R6fTGX8vilJK0b9/f3r27Gnski2NVqulcePGKKVKdH/XBIbufXN/mAnnJQGuCixZsgStVsvzzz/Pf//7X9LT0032nzx5kiFDhnDixAmaN29ukjXCMBLyvvvuM2nJZWZmMm7cOC5fvsxtt91GRESERXUxtCAzMjLKLfvggw+i0Wh4/vnnTT5cMzMzmT59OoAxObNhQMD69etNzvHbb78xY8YM4/elDQqoqJycHJ577jmWLl1KQEAAL730Upnlo6OjOX78OG+88QZHjhwx2ffpp58CmAzqMPdz8/f3x8PDg/T0dOPgDoOvvvqKefPmARW/Z8PPb8qUKcbni6Bvvc+bNw8XFxdGjx4NXPt9mT59ukkLUqfT8cwzz7BlyxaOHz9Ou3btyr1ujx49gGt/vNQk27dvBzAZ/StqgaqboVC77dixQ9WvX18BytvbW/Xu3VuNGjVK9ejRQ7m6uipAtW7dWp0+fdrkuMLCQjVq1CgFKC8vL3XLLbeoESNGGM/Vrl07lZKSYixvmAfXqFEjs/WIi4szzl8aPHiweuGFF5RSpc/zMsxhc3NzU/369VNDhw41zr269dZbjfPrDHO1ANWzZ091xx13qPbt2xsnUhsmhx85csR4bkN5a+bBXXfddWrs2LHG15133qn69OljnGBcr149tW3bthLHm5vo/dBDDxnvrU+fPuqOO+5Q7dq1M87h2rNnT7k/N8NcLVdXV9W3b181cuRI4+T2iIgI5evrq1xcXEyy2JR134b5ZR988IFxW0FBgRoyZIgClL+/vxo6dKgaMGCAMWPLggULTM7x+OOPG++ra9euasSIEeq6664z/u4VndNYls8++0wBavr06RbVs6yfdVn3XtrPo6zf5bIy7xQWFqrAwEBVp04dh+Z1FdWPBLgqlJKSoubOnau6dOmi/P39laurqwoMDFQxMTHq3XffNWYFKU6n06nly5ernj17Kl9fX+Xj46Pat2+vFi1apHJyckzKlhfglFLqxRdfVKGhocYsE0qV/YHx/fffq5tvvlkFBAQod3d3FRUVpV544YUS9V29erXx3vz9/VWbNm3UjBkzVGJiopoxY4YC1CuvvGIsb0uAK/5ydXVVdevWVd26dVPz5s0rkcjawNyHbmFhoVqyZInq2rWr8vX1Ve7u7io8PFxNnjxZHT9+3KKfW0FBgXr77bdV27ZtlY+Pj6pXr57q2LGjmj17trp06ZK67bbbFKC++OILi+67tMBhuE6nTp2Ut7e30mq1qnv37urzzz83e78bNmxQt9xyiwoMDFSenp6qWbNmavLkyero0aPl/qwNsrKyVL169VRYWJgqKCiwqJ5KVX2A27x5swLbsweJmkujlKzYKISwzIsvvsisWbPYsGEDt912W1VXxyK33347Gzdu5OjRoxZPcRHOQQKcEMJiWVlZXHfddbRr165GLCR65swZmjZtypQpU3jnnXequjqikkmAE0JY5YsvvuDOO+9k8+bN3HzzzVVdnTKNGTOGbdu2sX//flnwtBaSACeEsNrEiRPZvXs3+/btq7Zz4mJjY+nZsyebN282m6pMOD8JcEIIIZySzIMTQgjhlCTACSGEcEoS4IQQQjglCXBCCCGckgQ4IYQQTkkCnBBCCKckAU4IIYRTkgAnhBDCKUmAE0II4ZT+H8sdeR1SqwJWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 450x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4.5, 3.5))\n",
    "ax = plt.gca()\n",
    "\n",
    "ax.errorbar(distance[indices_primary], mean_dim[indices_primary], yerr=std_dim[indices_primary], fmt='o', capsize=5, capthick=2, color=palette[0])\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[2])\n",
    "ax.errorbar(distance[indices_dorsal], mean_dim[indices_dorsal], yerr=std_dim[indices_dorsal], fmt='o', capsize=5, capthick=2, color=palette[3])\n",
    "ax.errorbar(distance[indices_mt], mean_dim[indices_mt], yerr=std_dim[indices_mt], fmt='o', capsize=5, capthick=2, color=palette[4])\n",
    "\n",
    "ax.set_xlabel('Cortical Distance (mm)')\n",
    "ax.set_ylabel('Linear Dimensionality')\n",
    "ax.legend(['Primary', 'Early', 'Ventral', 'Dorsal', 'MT'], loc='upper left', bbox_to_anchor=(1, 1), fontsize=10, frameon=False)\n",
    "\n",
    "fig.suptitle(subject_id, fontsize=16)\n",
    "fig.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "372da988",
   "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": 51,
   "id": "f65c53ce",
   "metadata": {},
   "outputs": [],
   "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, maxfev=5000)\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": 52,
   "id": "48f5a19f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.00x^2.42 + -0.01\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": 53,
   "id": "bb078ef8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVUAAAFKCAYAAACtjMxgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFQklEQVR4nO3deVxUVf8H8M+wDMywL7LIpqgIBIIiopgr5pIL6VM+ppb2WKa5tT09T1a/TBO3FtOsTNOsXLO9nsqt0jJFzS0VXABZVBQElBnWme/vj+tcGGZhwIFh4Pt+vaaGe8+Ze2Zgvt57z/ecIyEiAmOMMbOwsXQDGGOsNeGgyhhjZsRBlTHGzIiDKmOMmREHVcYYMyMOqowxZkYcVBljzIw4qDLGmBlxUGWMMTPioMqsQlZWFiQSifiYO3euSfXeeOMNsU5gYGATt5IxDqrMSn3xxRcwZYT19u3bm6E1jNXgoMqsjp2dHa5cuYI//vjDaLmMjAwcPXq0mVrFmICDKrM6gwcPBgB8/vnnRstpzlK7d+/e5G1iTIODKrM648ePB1D/LYDt27fDxsZGLM9Yc+CgyqxOv3794O/vj7y8PBw8eFBvmfT0dJw8eRIDBw6En5+fwdc6evQoHnnkEQQHB0MqlcLT0xMDBw7Ehg0boFKpxHJEhNDQUEgkErz99tsGX++JJ56ARCLBI488orX91q1bWLRoEbp37w4XFxc4OTkhOjoar776KoqLi/W+Vl5eHubOnYuYmBi4urrCxcUFkZGRmDdvHrKysgx/QMyyiDErkJmZSQAIAF24cIFmz55NAGjevHl6y7/22msEgD788EPauHEjAaCAgACtMsuWLSMbGxsCQK6urtSzZ0/q0KGDeJwBAwZQcXGxzmv26NFD7zHLy8vJzc2NANDevXvF7efOnRNf19bWlrp06UIxMTFkZ2dHACgkJITOnTun9VoXL14kHx8fAkBOTk4UHR1N0dHR5ODgILb3r7/+auSnyZoSB1VmFeoG1f379xMACgwMJLVarVM+MjKS7O3tqbCwUG9Q3blzp/h6r7zyCpWXl4v79u3bR76+vgSAxowZI27PysoiiURCAHSCIBHRjh07xCCpaVNpaSl17tyZAFBycjLl5eWJ5a9evUojR44kANSlSxdSKpXivn/+858EgB588EG6ffu2uP3atWuUmJhIAGjYsGGN/DRZU+KgyqxC3aCqVqspICCAANAff/yhVfbUqVMEgO6//34iIr1BtWvXrgSApk+frvd4Bw8eFI934MABcXtSUhIBoJdeekmnzujRowkA/d///Z+4beXKleLZbXV1tU4dpVJJISEhBIDee+89cXt4eDgBoK+++kqnzpEjR2j48OH0zDPPGPi0mCXxPVVmlSQSCR588EEAulkAml7/CRMm6K174cIFpKenAwCefvppvWX69OmDxMREAMDXX38tbn/ssccAAFu2bNEqX1BQgJ9++gkSiQRTpkwRt3/11VdiW2xtbXWOI5PJxPfx3Xffidu7dOkCAPjvf/+Lb775BmVlZeK+nj174scff8Rbb72lt+3MsjioMqul6dXfuXOnVhbAjh074OjoiAceeEBvvbS0NACAXC5HRESEwdePi4sDADEAA8C4cePg5uaGzMxMrTzZrVu3oqqqCv3790doaKi4/e+//wYArFu3Dvfee6/ehyZoa9oFAAsXLoSzszPS09PxwAMPwMPDA4MHD8aSJUtw8uRJUz4eZimWPlVmzBR1L/+JiNRqNQUFBREAOnjwIBERHTt2jADQP/7xD7Fu3cv/zz77jACQn5+f0WO+9NJLYodVbU8++SQBoJkzZ4rb4uPjCQB9/PHHWmU1nVGmPDw8PLTqXrp0iR5//HHy8vLSKRsdHa11W4K1HHymyqyWvlsA9V36A4CLiwsAIc3JmKKiIq3yGppbADt27EBVVRXS09Nx5MgRODs7i+3RcHJyAiBc2pPQh2HwcfPmTa26oaGhWLduHa5fv47U1FQsX74cw4YNg729PU6fPo1hw4YhJyfH6HtgzY+DKrNqdW8B7NixA87Ozhg5cqTBOuHh4QAApVKJc+fOGSynGeKqub+pkZCQgMjISBQWFuLXX3/F5s2bAQAPPfSQGEQ1unbtCgA4c+aMweNcuHABR48exY0bNwAIObFZWVnYvXs3AMDGxgbx8fH497//jZ9++gl///03XF1doVQq8eWXXxp8XWYZHFSZVevduzdCQkKQk5ODNWvWICsrC8nJyZDJZAbrhIWFicFu5cqVesscPHgQqampAIARI0bo7NecrX711VfiWbJmW22jR48GAKxfv16rs0mjuroaycnJiI+Px/PPPw8AuHnzJrp06YKhQ4fqnbsgLCwMwcHBAKA1QIG1EJa678BYQ+i7p6rx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",
      "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}_concept_{split}_{num_neighbors}_{name_concept}.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(3, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "# sns.regplot(x=x, y=y, color=palette[1], ci=None)\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",
    "ax.plot(x_plot, y_plot, color=palette[1], linewidth=2)\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(name_concept.capitalize())\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "9f622ba9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "y = 0.0x + -0.0\n",
      "R^2: 0.58\n",
      "p <= 0.01 (**)\n",
      "\n",
      "y = 0.0x^2 + -0.0\n",
      "R: 0.85\n",
      "R^2: 0.72\n",
      "p <= 0.001 (***)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_regression_info(x, y)\n",
    "print_quadratic_info(x, y)"
   ]
  }
 ],
 "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
}
