{
 "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": 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": "markdown",
   "id": "ff37ddb7",
   "metadata": {},
   "source": [
    "## Components"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d6f1b7ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "import src.utils as utils\n",
    "\n",
    "component = 3\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": 12,
   "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": 13,
   "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": 14,
   "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": 15,
   "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": 16,
   "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": 17,
   "id": "f65c53ce",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/g8/xtksjdh97hb95w5r0pwn7b6m0000gn/T/ipykernel_99971/2456198294.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, 2.0, 1.0]  # initial guesses\n",
    "popt, pcov = curve_fit(model, x, y, p0=p0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "919f6161",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.00x^2.96 + -0.00\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": "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": 20,
   "id": "bb078ef8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWwAAAFKCAYAAAA5amWSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABZXElEQVR4nO3deVxU5f4H8M8M67DILgIiIoqgLKIimwuGqeRe6jX1WqaZuV6tWz+prmalaZn71dI0b6ZpWlm2qOWSK7ihopALoIAbmyCLCMz398dxDjPMwr7M+H2/XqMz5zzPOc85zHznzHOeRUJEBMYYY82etKkLwBhjrHo4YDPGmJ7ggM0YY3qCAzZjjOkJDtiMMaYnOGAzxpie4IDNGGN6ggM2Y4zpCQ7YjDGmJzhgP4UkEkmNHg8ePGjqIlfp8uXLassU5f/jjz8abL/79+/Hyy+/DG9vb1hYWMDMzAxt2rTByJEjsWfPngbbL2sciYmJaE6dwY2bugCs6XTo0AEtW7asMp2xcfN9m1y9ehWzZs1CQUEBjh071mj7vXPnDsaPH4+DBw8CAMzNzeHh4QFTU1MkJydj9+7d2L17NyIjI7Fjx45qnWfWfOTn5yMmJgaff/45iouLm89ngNhTBwABoM2bNzd1Ueps/vz5BIAiIiLU1imO88CBA/W6z8TERHJyciIA5O3tTdu3b6eysjJxfWlpKW3atIlatmxJAKhz586Ul5dXr2VgDevQoUPi+6e0tLSpiyPiKhHGaqCkpARjxoxBZmYmgoKCcPLkSYwZMwZGRkZiGmNjY0ycOBF//vknZDIZLl++jPfee68JS80MBQdsxmpgxYoVuHDhAqRSKbZu3Qp7e3utaf38/DBr1iwAwIYNG5Cfn99YxWQGigM2q7Hi4mIsX74coaGhaNGiBczNzeHl5YWpU6fi2rVraukPHz4s3gAsKyvTuE3F+sOHD4vLvvrqK0gkEowZMwbHjx9Hly5dYGZmBldXVyxfvhwSiQTvv/8+AOD48eOQSCRo27atxu3v3bsX/fr1g62tLSwtLeHv74/Fixfj8ePHNTr2DRs2AACGDBmCTp06VZl+5syZ2Lp1KxITE9GiRQu19bt370Z0dDScnJxgamoKFxcXvPDCC2LdeGXK5/Hbb79FeHg4rK2tYWdnh/79++PkyZMAgMLCQrzzzjto3749zMzM4OzsjAkTJuD27dsq20tNTYVEIoGtrS3kcjmWL18OX19fyGQyuLu7Y8yYMTh//rzW48vNzcX777+PoKAgWFlZwcLCAr6+vnjzzTdx584dtfTKf9PCwkK899576NixI8zNzeHg4IAhQ4bg6NGjWveXnJyMadOmoX379jA3N4etrS169eqFjRs3ory8XC39yy+/DIlEgvXr1yM1NRWvvPIKWrduDTMzM7Ru3RqTJ09GamqqSp62bduib9++4msTExNIJBK1dE2iqetkWONDHeqw09LSyMfHR9yGt7c3devWjWQyGQEgc3Nz+vbbb1XyVKc+ULH+0KFD4rLNmzcTAAoMDCQrKyuysbGhoKAgMjc3py1btlBERAS5u7sTAGrRogVFRETQyJEj1bbZu3dvAkBWVlYUFBREzs7O4rqoqCgqLy+v1rEnJyeL+dasWVPjc6fs8ePHNGLECHF7Li4uFBwcTI6OjuKyf/3rX1rP04wZMwgAOTk5UZcuXcTzb2ZmRgcPHqTOnTuTRCIhT09P6ty5s5jPy8uLCgsLxe2lpKQQALKxsaEJEyYQALK3t6fu3buTjY0NASATExPatm2bWlkuXrxIrq6uBICkUil17tyZunTpQsbGxgSA7OzsVP6eRBV/0wEDBpCfnx8BIFdXVwoKCiIzMzMCQEZGRrR37161/X3//fficcpkMgoMDKT27dur/C0fPnyokuell14iAPTqq69SixYtSCqVUocOHahTp05iPicnJ7p165aYZ+TIkWLZ8OT+SEREBN25c6emf+Z6xwH7KVTbgF1WVkZdunQhANSxY0eKj48X1+Xl5dHkyZPFD/ipU6fEdXUN2AAoNDSUHjx4QEREWVlZJJfLiah6Nx0B0JtvvkkFBQVERCSXy2nRokXiul9//bVax//rr7+KeY4ePVqtPNooAq6VlRV999134vKysjJas2aNGPQ+++wzrcf08ccfi+czLS1NJXh6enpSXFycmG///v1kZGREAOirr74SlysCtvJ5KikpISKioqIieu2118Qv4uTkZDFffn6+uL+wsDC6ceOGuO7u3bs0ZMgQ8YtAOZ/y37RVq1a0b98+cd3t27cpICBA/JJWFh8fT2ZmZiSRSOjdd9+l4uJicd25c+eoQ4cOBIDGjx+vkk8RsBXvob///ltcd+LECbK2tiYANHv2bJV8zfWmIwfsp5DyB1TX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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}_components_{split}_{num_neighbors}_{component}.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(dict_title[component])\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "9f622ba9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "y = 0.0x + -0.0\n",
      "R^2: 0.22\n",
      "p: ns\n",
      "\n",
      "y = 0.0x^2 + -0.0\n",
      "R^2: 0.37\n",
      "p <= 0.05 (*)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print_regression_info(x, y)\n",
    "print_quadratic_info(x, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "910ca7c2",
   "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
}
