{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "from scipy.stats import zscore\n",
    "\n",
    "from src.dimensionality import Dimensionality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "298bf7de",
   "metadata": {},
   "outputs": [],
   "source": [
    "def zscore_betas(betas, df_stimuli):\n",
    "    assert np.isnan(betas).sum() == 0, 'Betas contain NaN values'\n",
    "    indices_session = df_stimuli['Session'].values\n",
    "    betas_zscore = np.zeros_like(betas)\n",
    "    sessions = np.unique(indices_session)\n",
    "    num_sessions = len(sessions)\n",
    "    for i_session in tqdm(sessions, total=num_sessions):\n",
    "        indices = np.where(indices_session == i_session)[0]\n",
    "        betas_zscore[indices] = zscore(betas[indices], axis=0)\n",
    "    betas_zscore = np.nan_to_num(betas_zscore)\n",
    "    return betas_zscore"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": 4,
   "id": "51757aa8",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_datasets = os.path.join(..., 'datasets')\n",
    "assert os.path.exists(path_datasets)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3f19a720",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'THINGS-fMRI'\n",
    "subject_id = 'S1'\n",
    "num_neighbors = 50\n",
    "split = 'train'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "541847a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_dataset = os.path.join(path_datasets, dataset)\n",
    "assert os.path.exists(path_dataset)\n",
    "\n",
    "path_processed = os.path.join(path_dataset, 'processed', subject_id)\n",
    "assert os.path.exists(path_processed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b81bc883",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_stimuli = os.path.join(path_processed, 'stimuli',  f'{subject_id}_stimuli.csv')\n",
    "assert os.path.exists(path_stimuli)\n",
    "\n",
    "df_stimuli = pd.read_csv(path_stimuli)\n",
    "indices_split = df_stimuli[df_stimuli['Split'] == split]['Trial'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2c3b068b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 12/12 [00:10<00:00,  1.18it/s]\n"
     ]
    }
   ],
   "source": [
    "path_betas_left = os.path.join(path_processed, 'betas', 'surf', f'{subject_id}_betas_surf_lh.npy')\n",
    "assert os.path.exists(path_betas_left), path_betas_left\n",
    "\n",
    "betas_left = np.load(path_betas_left)\n",
    "betas_left = zscore_betas(betas_left, df_stimuli)\n",
    "betas_left = betas_left[indices_split]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "id": "1a01d967",
   "metadata": {},
   "outputs": [],
   "source": [
    "unique_labels_left = np.unique(labels_vertices_left)[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "21764c19",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_subsample = 100\n",
    "total_subsample = 100"
   ]
  },
  {
   "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": "87148803",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4847:   0%|          | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4847: 100%|██████████| 100/100 [00:15<00:00,  6.34it/s]\n",
      "8315: 100%|██████████| 100/100 [00:16<00:00,  6.16it/s]\n",
      "3225: 100%|██████████| 100/100 [00:15<00:00,  6.60it/s]\n",
      "2527: 100%|██████████| 100/100 [00:15<00:00,  6.47it/s]\n",
      "3805: 100%|██████████| 100/100 [00:15<00:00,  6.52it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(1234)\n",
    "name_estimator = 'mle'\n",
    "\n",
    "dims_areas_nonlinear_left = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area = np.argwhere(np.isin(labels_vertices_left, indices))\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",
    "        \n",
    "        dims_areas_nonlinear_left.append({'Area': name,\n",
    "                                       'Intrinsic Dimensionality': Dimensionality.intrinsic_dimensionality(betas_left[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_nonlinear_left = pd.DataFrame(dims_areas_nonlinear_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "68b9baf2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "group_colors = {\n",
    "    'Primary': palette[0],\n",
    "    'Early':   palette[1],\n",
    "    'Ventral': palette[2],\n",
    "    'Dorsal': palette[3],\n",
    "    'Lateral':   palette[4]\n",
    "}\n",
    "\n",
    "os.makedirs('svg', exist_ok=True)\n",
    "path_figure = os.path.join('svg', f'figureS10_intrinsic_lh_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "sns.boxplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear_left, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear_left , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(30, 42)\n",
    "ax.set_yticks([30, 32, 34, 36, 38, 40, 42], [30, 32, 34, 36, 38, 40, 42])\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "adf019c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 12/12 [00:11<00:00,  1.05it/s]\n"
     ]
    }
   ],
   "source": [
    "path_betas_right = os.path.join(path_processed, 'betas', 'surf', f'{subject_id}_betas_surf_rh.npy')\n",
    "assert os.path.exists(path_betas_right), path_betas_left\n",
    "\n",
    "betas_right = np.load(path_betas_right)\n",
    "betas_right = zscore_betas(betas_right, df_stimuli)\n",
    "betas_right = betas_right[indices_split]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b801a524",
   "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": 17,
   "id": "37ba2755",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4946:   2%|▏         | 2/100 [00:00<00:25,  3.91it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "4946: 100%|██████████| 100/100 [00:16<00:00,  5.99it/s]\n",
      "8239: 100%|██████████| 100/100 [00:15<00:00,  6.59it/s]\n",
      "4027: 100%|██████████| 100/100 [00:15<00:00,  6.41it/s]\n",
      "2976: 100%|██████████| 100/100 [00:14<00:00,  6.76it/s]\n",
      "4580: 100%|██████████| 100/100 [00:14<00:00,  6.75it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(9988)\n",
    "\n",
    "dims_areas_nonlinear_right = []\n",
    "\n",
    "for i_area, (name, indices) in enumerate(dict_indices.items()):\n",
    "    indices_area = np.argwhere(np.isin(labels_vertices_right, indices))\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",
    "        \n",
    "        dims_areas_nonlinear_right.append({'Area': name,\n",
    "                                        'Intrinsic Dimensionality': Dimensionality.intrinsic_dimensionality(betas_right[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_nonlinear_right = pd.DataFrame(dims_areas_nonlinear_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "e62ff724",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "path_figure = os.path.join('svg', f'figureS10_intrinsic_rh_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "sns.boxplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear_right, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear_right , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(30, 42)\n",
    "ax.set_yticks([30, 32, 34, 36, 38, 40, 42], [30, 32, 34, 36, 38, 40, 42])\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "f62227e3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8640, 279601)\n"
     ]
    }
   ],
   "source": [
    "betas = np.hstack((betas_left, betas_right))\n",
    "print(betas.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "35adf1ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "9793: 100%|██████████| 100/100 [00:45<00:00,  2.21it/s]\n",
      "16554: 100%|██████████| 100/100 [00:23<00:00,  4.26it/s]\n",
      "7252: 100%|██████████| 100/100 [00:24<00:00,  4.16it/s]\n",
      "5503: 100%|██████████| 100/100 [00:16<00:00,  6.12it/s]\n",
      "8385: 100%|██████████| 100/100 [00:17<00:00,  5.77it/s]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(1231)\n",
    "\n",
    "dims_areas_nonlinear = []\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",
    "    indices_area_right = betas_left.shape[1] + np.argwhere(np.isin(labels_vertices_right, indices))\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",
    "        \n",
    "        dims_areas_nonlinear_left.append({'Area': name,\n",
    "                                  'Intrinsic Dimensionality': Dimensionality.intrinsic_dimensionality(betas[:, indices_area[sampled_indices]])})\n",
    "\n",
    "df_dims_areas_nonlinear = pd.DataFrame(dims_areas_nonlinear_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "2b25e773",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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T5+uALVo0SKj9589e1a5u7urpk2bKqWU6tu3r/Ly8lIBAQHqvffeU2+//bbasWOH2rZtmwLU9OnTDec2adJENWjQQPn4+KgXX3xRffbZZ6p3794KUPfcc4/y9fVVL774ovr8889Vnz59FKDeffddw/nx8fHK3d1dNW/eXL3zzjvqq6++Uq+88oqqV6+eAtTu3bsNbU3FNW7cOAWoAwcOlPq+9u7dqwD11ltvWe/JtJHin9H8+fPV5cuXTX4VFRUppZT6+OOPFaDuuOMONW/ePPXZZ5+pxx57TLm6uqqgoCB18+ZNQ9+A8vHxUa1atVILFixQL7zwgrp69arhMbdt26aUUurNN99UgFq9enWp2C5cuKCcnZ3V448/brfnwxq6deum3N3dVUZGRqnj58+fV05OTuq+++5TSulfJ76+vqphw4ZqxowZ6tNPP1WPPPKI0mg0Kjo6WmVnZxvOBVTTpk2Vj4+PeuGFF9QXX3yhHnzwQQWoPn36GNotW7ZMtW7dWgFq2bJl6pdfflFKmX4N5+fnq27duik3Nzf17LPPqi+//FLNmTNHRUdHK6DUc79o0aJyf58dQUXvOUopVVRUpDw9PVV4eLhSSqkdO3YoT09P5evrq1566aVSP4fmzZurS5cuGc5t0qSJ8vHxUWFhYWru3Lnq9ddfV3/88YdavXq10mg06u6771affPKJWrBggerfv78C1EsvvWQ4v7LvO478pyg2NrbU77EpkyZNUoAaMWKE+uSTT9Qnn3yiRo8erTQajWrVqpUqLCxUSpl+7Z48eVKFhoaqwMBA9fLLL6vPPvtMPf3008rV1VU1b95cXb582fBYpn4+165dU02aNFF+fn7q//2//6e++uor9e6776q2bduWea++9f3Jnhz3p12DmPqjdv78efXjjz+qzp07K0AtXLhQKfXXL9onn3xSqh9TiQegvvvuO8Ox9PR05ezsXOaP2I0bN5Srq6vq1auX4djIkSOVu7u7unDhQqnH2rhxowLUs88+azhmKq6dO3cqQE2aNKnU8QkTJignJyd17ty5Sj5j9lf8M6roKyMjQxUUFKjg4GDVqVMnVVBQUKqfqVOnlnnei89NSEgw+pjFv9hnz55VTk5OasSIEaXavf/++2XejGuCBQsWKEB99dVXpY6/++67ClA//vijKioqUu3atVPh4eHqypUrpdp99dVX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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6, 3))\n",
    "ax = plt.gca()\n",
    "\n",
    "path_figure = os.path.join('svg', f'figureS10_intrinsic_both_{subject_id}_{split}_{num_neighbors}.svg')\n",
    "\n",
    "sns.boxplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear, palette=group_colors, showfliers=False, **seaborn_props, ax=ax)\n",
    "sns.stripplot(x='Area', y='Intrinsic Dimensionality', data=df_dims_areas_nonlinear , palette=group_colors, zorder=-1, ax=ax)\n",
    "ax.set_xlabel('')\n",
    "ax.set_ylim(30, 42)\n",
    "ax.set_yticks([30, 32, 34, 36, 38, 40, 42], [30, 32, 34, 36, 38, 40, 42])\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "424bc514",
   "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
}
