{
 "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",
    "from tqdm import tqdm\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', f'lh.visual.annot')\n",
    "assert os.path.exists(path_annot_left)\n",
    "\n",
    "labels_vertices_left, _, names_vertices_left = fsio.read_annot(path_annot_left)\n",
    "\n",
    "names_vertices_left = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_left])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2342c8b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_annot_right = os.path.join(path_dataset, 'freesurfer', subject_id, 'label', f'rh.visual.annot')\n",
    "assert os.path.exists(path_annot_right)\n",
    "\n",
    "labels_vertices_right, _, names_vertices_right = fsio.read_annot(path_annot_right)\n",
    "\n",
    "names_vertices_right = np.array([name.decode('utf-8').split('_')[1] for name in names_vertices_right])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1a01d967",
   "metadata": {},
   "outputs": [],
   "source": [
    "unique_labels_left = np.unique(labels_vertices_left)[1:]\n",
    "unique_labels_right = np.unique(labels_vertices_right)[1:]\n",
    "\n",
    "assert np.all(unique_labels_left == unique_labels_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9183eaef",
   "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": 11,
   "id": "c274ee25",
   "metadata": {},
   "outputs": [],
   "source": [
    "assert np.all(np.array(dict_geodesic_lh['areas']) == np.array(dict_geodesic_rh['areas']))\n",
    "\n",
    "names_areas = np.array(dict_geodesic_lh['areas'])\n",
    "matrix_geodesic_lh = dict_geodesic_lh['matrix']\n",
    "matrix_geodesic_rh = dict_geodesic_rh['matrix']\n",
    "\n",
    "index_V1 = np.where(names_areas == 'V1')[0]\n",
    "\n",
    "depths_areas = np.zeros(len(names_areas))\n",
    "for area in names_areas:\n",
    "    index_area = np.where(names_areas == area)[0]\n",
    "    depths_areas[index_area] = (matrix_geodesic_lh[index_V1, index_area].item() + matrix_geodesic_rh[index_V1, index_area].item()) / 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a3f705ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "primary_rois = ['V1']\n",
    "early_rois   = ['V2','V3','V4']\n",
    "ventral_rois = ['V8','FFC','PIT','VMV1','VMV3','VMV2','VVC']\n",
    "dorsal_rois  = ['V6','V3A','V7','IPS1','V3B','V6A']\n",
    "lateral_rois = ['MST','LO1','LO2','MT','PH','V4t','FST','V3CD','LO3']\n",
    "\n",
    "indices_primary = np.array([i for i, area in enumerate(names_vertices_left) if area in primary_rois])\n",
    "indices_early = np.array([i for i, area in enumerate(names_vertices_left) if area in early_rois])\n",
    "indices_ventral = np.array([i for i, area in enumerate(names_vertices_left) if area in ventral_rois])\n",
    "indices_dorsal = np.array([i for i, area in enumerate(names_vertices_left) if area in dorsal_rois])\n",
    "indices_lateral = np.array([i for i, area in enumerate(names_vertices_left) if area in lateral_rois])\n",
    "\n",
    "dict_indices = {'Primary': indices_primary,\n",
    "                'Early': indices_early,\n",
    "                'Ventral': indices_ventral,\n",
    "                'Dorsal': indices_dorsal,\n",
    "                'Lateral': indices_lateral}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1dd1b7ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  0.        ,  98.76294822,  47.18498246,  37.82469954,\n",
       "        47.68391118,  61.25910674,  67.36474315,  54.73967693,\n",
       "        70.6098057 ,  80.12118594,  83.43862856,  71.78736958,\n",
       "        68.54886023,  73.34908732,  71.28017612,  91.89199132,\n",
       "        94.92379115,  64.11225925,  46.45351479,  61.2984268 ,\n",
       "        82.90859992, 100.80122975,  64.64699068,  82.67801942,\n",
       "        55.83223833,  75.40693282])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "depths_areas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0edc9214",
   "metadata": {},
   "outputs": [],
   "source": [
    "name_estimator = 'lpca'\n",
    "path_dict_dims_ED = os.path.join(path_results, 'dimensionality', f'{subject_id}_dimensionality_{split}_{num_neighbors}_{name_estimator}.pickle')\n",
    "assert os.path.exists(path_dict_dims_ED)\n",
    "dict_dims_ED = load_pickle(path_dict_dims_ED)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "87148803",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "8915: 100%|██████████| 100/100 [00:00<00:00, 6610.72it/s]\n",
      "15521: 100%|██████████| 100/100 [00:00<00:00, 5043.41it/s]\n",
      "6208: 100%|██████████| 100/100 [00:00<00:00, 11458.59it/s]\n",
      "5693: 100%|██████████| 100/100 [00:00<00:00, 11512.69it/s]\n",
      "7914: 100%|██████████| 100/100 [00:00<00:00, 9138.32it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(5576)\n",
    "name_estimator = 'lpca'\n",
    "\n",
    "dims_areas_linear_left = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area_left = np.argwhere(np.isin(labels_vertices_left, indices))\n",
    "    vertices_area_left = dict_dims_ED['lh']\n",
    "\n",
    "    indices_area_right = np.argwhere(np.isin(labels_vertices_right, indices)) + len(labels_vertices_left)\n",
    "    vertices_area_right = dict_dims_ED['rh']\n",
    "\n",
    "    vertices_area = np.concatenate((vertices_area_left, vertices_area_right), axis=0)\n",
    "    indices_area = np.concatenate((indices_area_left, indices_area_right), axis=0)\n",
    "\n",
    "    for i_sample in tqdm(range(num_subsample), desc=f'{len(indices_area)}'):\n",
    "        sampled_indices = np.random.choice(indices_area.shape[0], size=num_subsample, replace=False)\n",
    "        dims_areas_linear_left.append({'Area': name,\n",
    "                                       'Effective Dimensionality': vertices_area[indices_area[sampled_indices]].mean(),\n",
    "                                       'Cortical Distance (mm)': depths_areas[indices].mean()})\n",
    "\n",
    "df_dims_areas_linear_left = pd.DataFrame(dims_areas_linear_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "68b9baf2",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_primary = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Primary']['Effective Dimensionality'].mean()\n",
    "std_primary = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Primary']['Effective Dimensionality'].std()\n",
    "depth_primary = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Primary']['Cortical Distance (mm)'].mean()\n",
    "\n",
    "mean_early = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Early']['Effective Dimensionality'].mean()\n",
    "std_early = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Early']['Effective Dimensionality'].std()\n",
    "depth_early = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Early']['Cortical Distance (mm)'].mean()\n",
    "\n",
    "mean_ventral = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Ventral']['Effective Dimensionality'].mean()\n",
    "std_ventral = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Ventral']['Effective Dimensionality'].std()\n",
    "depth_ventral = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Ventral']['Cortical Distance (mm)'].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0077bc9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_dims = np.array([mean_primary, mean_early, mean_ventral])\n",
    "depth_dims = np.array([depth_primary, depth_early, depth_ventral])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1c2d940a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.55x^5.13 + 2.96\n"
     ]
    }
   ],
   "source": [
    "import warnings\n",
    "from scipy.optimize import curve_fit\n",
    "\n",
    "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, depth_dims / depth_dims.max(), mean_dims, 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, depth_dims / depth_dims.max(), mean_dims, p0=p0)\n",
    "    model = linear_model\n",
    "\n",
    "a, b, c = popt\n",
    "print(f'{a:.2f}x^{b:.2f} + {c:.2f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "940d3654",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Curve for plotting\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, depth_dims, mean_dims, p0=p0, maxfev=10000)\n",
    "    model = nonlinear_model\n",
    "\n",
    "if caught:\n",
    "    p0 = [1.0, 2.0, 1.0]\n",
    "    popt, pcov = curve_fit(linear_model, depth_dims, mean_dims, p0=p0)\n",
    "    model = linear_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "70e0b54c",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_plot = np.linspace(0, depth_dims.max(), 100)\n",
    "y_plot = model(x_plot, *popt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "a131eff5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "os.makedirs('svg', exist_ok=True)\n",
    "path_figure = os.path.join('svg', f'{subject_id}_effective_depth.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(3, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "ax.errorbar(depth_primary, mean_primary, yerr=std_primary, fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "ax.errorbar(depth_early, mean_early, yerr=std_early, fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "ax.errorbar(depth_ventral, mean_ventral, yerr=std_ventral, fmt='o', capsize=5, capthick=2, color=palette[1])\n",
    "ax.plot(x_plot, y_plot, color=palette[1], linewidth=2)\n",
    "ax.set_title(f'{a:.2f}x^{b:.2f} + {c:.2f}')\n",
    "\n",
    "ax.set_xlabel('Cortical Distance (mm)')\n",
    "ax.set_ylabel('Effective Dimensionality')\n",
    "ax.set_xticks(np.arange(0, 81, 20))\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
}
