{
 "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": 79,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'BOLD5000'\n",
    "subject_id = 'CSI1'\n",
    "num_neighbors = 50\n",
    "split = 'train'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "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": 81,
   "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": 82,
   "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": 83,
   "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": 84,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "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": 86,
   "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": 87,
   "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": 88,
   "id": "1dd1b7ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.        , 96.7919276 , 51.15368535, 36.51185153, 55.69342975,\n",
       "       62.70851999, 65.52076844, 53.65777153, 68.77865798, 80.27701467,\n",
       "       90.31666623, 70.56417799, 69.06572649, 71.86105552, 72.82603153,\n",
       "       90.68163835, 99.21207236, 65.92889903, 51.69444789, 66.98975151,\n",
       "       79.8385392 , 99.90306967, 69.08668999, 78.43281948, 61.3442494 ,\n",
       "       82.27850535])"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "depths_areas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "0edc9214",
   "metadata": {},
   "outputs": [],
   "source": [
    "name_estimator = 'mle'\n",
    "path_dict_dims_ID = os.path.join(path_results, 'dimensionality', f'{subject_id}_dimensionality_{split}_{num_neighbors}_{name_estimator}.pickle')\n",
    "assert os.path.exists(path_dict_dims_ID)\n",
    "dict_dims_ID = load_pickle(path_dict_dims_ID)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "87148803",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "9627: 100%|██████████| 100/100 [00:00<00:00, 6495.24it/s]\n",
      "16339: 100%|██████████| 100/100 [00:00<00:00, 4428.90it/s]\n",
      "7169: 100%|██████████| 100/100 [00:00<00:00, 9541.83it/s]\n",
      "5677: 100%|██████████| 100/100 [00:00<00:00, 10231.51it/s]\n",
      "8445: 100%|██████████| 100/100 [00:00<00:00, 7813.10it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(5576)\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_ID['lh']\n",
    "\n",
    "    indices_area_right = np.argwhere(np.isin(labels_vertices_right, indices)) + len(labels_vertices_left)\n",
    "    vertices_area_right = dict_dims_ID['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",
    "                                       'Intrinsic 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": 91,
   "id": "68b9baf2",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_primary = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Primary']['Intrinsic Dimensionality'].mean()\n",
    "std_primary = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Primary']['Intrinsic 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']['Intrinsic Dimensionality'].mean()\n",
    "std_early = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Early']['Intrinsic 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']['Intrinsic Dimensionality'].mean()\n",
    "std_ventral = df_dims_areas_linear_left[df_dims_areas_linear_left['Area'] == 'Ventral']['Intrinsic 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": 92,
   "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": 93,
   "id": "1c2d940a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.66x^69.75 + 10.18\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": null,
   "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=50000)\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": 98,
   "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": 99,
   "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}_intrinsic_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[0])\n",
    "ax.errorbar(depth_early, mean_early, yerr=std_early, fmt='o', capsize=5, capthick=2, color=palette[0])\n",
    "ax.errorbar(depth_ventral, mean_ventral, yerr=std_ventral, fmt='o', capsize=5, capthick=2, color=palette[0])\n",
    "ax.plot(x_plot, y_plot, color=palette[0], 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('Intrinsic 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
}
