{
 "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 = '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": "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",
    "        \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.011308</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.011267</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.010975</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.011208</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>V1</td>\n",
       "      <td>0.011300</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.011750</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2596</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.012300</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2597</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.011967</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2598</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.012583</td>\n",
       "      <td>80.366436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2599</th>\n",
       "      <td>VVC</td>\n",
       "      <td>0.012042</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.011308       0.000000\n",
       "1      V1               0.011267       0.000000\n",
       "2      V1               0.010975       0.000000\n",
       "3      V1               0.011208       0.000000\n",
       "4      V1               0.011300       0.000000\n",
       "...   ...                    ...            ...\n",
       "2595  VVC               0.011750      80.366436\n",
       "2596  VVC               0.012300      80.366436\n",
       "2597  VVC               0.011967      80.366436\n",
       "2598  VVC               0.012583      80.366436\n",
       "2599  VVC               0.012042      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": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/g8/xtksjdh97hb95w5r0pwn7b6m0000gn/T/ipykernel_505/1274155522.py:4: RuntimeWarning: divide by zero encountered in power\n",
      "  return a * x**b + c\n"
     ]
    }
   ],
   "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, 1.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.00x^2.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": 21,
   "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_figure = os.path.join('svg', f'{subject_id}_categories_{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
}
