{
 "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 = 'train'"
   ]
  },
  {
   "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": "019c6a42",
   "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",
    "\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",
    "        \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": 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.009767</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.009808</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.009733</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.009883</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.009600</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.012517</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2596</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.011550</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2597</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.011875</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2598</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.012383</td>\n",
       "      <td>75.406933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2599</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.012250</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.009767       0.000000\n",
       "1      V1               0.009808       0.000000\n",
       "2      V1               0.009733       0.000000\n",
       "3      V1               0.009883       0.000000\n",
       "4      V1               0.009600       0.000000\n",
       "...   ...                    ...            ...\n",
       "2595  VVC               0.012517      75.406933\n",
       "2596  VVC               0.011550      75.406933\n",
       "2597  VVC               0.011875      75.406933\n",
       "2598  VVC               0.012383      75.406933\n",
       "2599  VVC               0.012250      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": "b212e7a8",
   "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)\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^1.36 + 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": 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": "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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}_stimuli_{split}_{num_neighbors}.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(3, 3))\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[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",
    "\n",
    "ax.set_xlabel('Cortical Distance (mm)')\n",
    "ax.set_ylabel('Accuracy')\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('Categories')\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
}
