{
 "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\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": 4,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'THINGS-fMRI'\n",
    "subject_id = 'S1'\n",
    "num_neighbors = 50\n",
    "split = 'train'\n"
   ]
  },
  {
   "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": null,
   "id": "2c3b068b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": null,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": "markdown",
   "id": "ff37ddb7",
   "metadata": {},
   "source": [
    "## Components"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6f1b7ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.utils as utils\n",
    "\n",
    "name_property = 'moves'\n",
    "\n",
    "path_results = os.path.join(path_dataset, 'results', subject_id, 'properties')\n",
    "assert os.path.exists(path_results)\n",
    "\n",
    "path_filename = os.path.join(path_results, f'{subject_id}_properties_{split}_{num_neighbors}_{name_property}.pickle')\n",
    "assert os.path.exists(path_filename)\n",
    "\n",
    "dict_results = utils.load_pickle(path_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "id": "ca170f67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.04324964, 0.0100136 , 0.00889976, ..., 0.02903492, 0.03074188,\n",
       "       0.00400838], dtype=float32)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "valid_values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": null,
   "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": null,
   "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": null,
   "id": "f65c53ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.optimize import curve_fit\n",
    "\n",
    "def model(x, a, b, c):\n",
    "    return a * x**b + c\n",
    "\n",
    "p0 = [1.0, 1.0, 1.0]\n",
    "lower_bounds = [   0.0, 1e-8, -np.inf]  # a ≥0, b ≥1e−8, c unbounded\n",
    "upper_bounds = [ np.inf, np.inf,  np.inf]\n",
    "\n",
    "popt, pcov = curve_fit(\n",
    "    model, x, y,\n",
    "    p0=p0,\n",
    "    bounds=(lower_bounds, upper_bounds),\n",
    "    maxfev=0000\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": [
    "os.makedirs('svg', exist_ok=True)\n",
    "path_figure = os.path.join('svg', f'{subject_id}_property_{split}_{num_neighbors}_{name_property}.svg')\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(name_property.capitalize())\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f622ba9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "y = 0.0x + -0.0\n",
      "R^2: 0.49\n",
      "p <= 0.05 (*)\n",
      "\n",
      "y = 0.0x^2 + -0.0\n",
      "R^2: 0.69\n",
      "p <= 0.01 (**)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_regression_info(x, y)\n",
    "print_quadratic_info(x, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d9f64e3",
   "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
}
