{
 "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": 57,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'THINGS-fMRI'\n",
    "subject_id = 'S2'\n",
    "num_neighbors = 50\n",
    "split = 'train'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "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": 59,
   "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": 60,
   "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": 61,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "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": 63,
   "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",
    "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": [
    "## Components"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "d6f1b7ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.utils as utils\n",
    "\n",
    "component = 0\n",
    "\n",
    "path_results = os.path.join(path_dataset, 'results', subject_id, 'components')\n",
    "assert os.path.exists(path_results)\n",
    "\n",
    "path_filename = os.path.join(path_results, f'{subject_id}_components_{split}_{num_neighbors}_{component}.pickle')\n",
    "assert os.path.exists(path_filename)\n",
    "\n",
    "dict_results = utils.load_pickle(path_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "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": 99,
   "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": 100,
   "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": 101,
   "id": "4965fda2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 102,
   "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": 103,
   "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)\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": 104,
   "id": "919f6161",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-0.00x^0.82 + 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": 105,
   "id": "9d9a9988",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_title = {\n",
    "    0: 'First Component',\n",
    "    1: 'Second Component',\n",
    "    2: 'Third Component',\n",
    "    3: 'Fourth Component'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "bb078ef8",
   "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}_components_{split}_{num_neighbors}_{component}.svg')\n",
    "\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(dict_title[component])\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "9f622ba9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "y = -0.0x + 0.0\n",
      "R^2: 0.91\n",
      "p <= 0.0001 (****)\n",
      "\n",
      "y = -0.0x^2 + 0.0\n",
      "R: 0.88\n",
      "R^2: 0.77\n",
      "p <= 0.001 (***)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_regression_info(x, y)\n",
    "print_quadratic_info(x, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32d1ff49",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
