{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "992be3e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import shutil\n",
    "\n",
    "import nibabel as nib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import yaml\n",
    "from nilearn import surface\n",
    "from nilearn import plotting\n",
    "from nilearn.masking import unmask\n",
    "from scipy.stats import zscore\n",
    "from sklearn.neighbors import KDTree\n",
    "from tqdm.auto import tqdm\n",
    "\n",
    "from src import freesurfer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17709863",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('config.yaml', 'r') as f:\n",
    "    data = yaml.safe_load(f)\n",
    "\n",
    "print(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "389848af",
   "metadata": {},
   "outputs": [],
   "source": [
    "subject_id = 'S3'\n",
    "assert subject_id in data['BOLD5000']\n",
    "paths = data['BOLD5000'][subject_id]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5843f22f",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_processed_subject = os.path.join('..', 'processed', subject_id)\n",
    "os.makedirs(path_processed_subject, exist_ok=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f993c5e",
   "metadata": {},
   "source": [
    "## T1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e6a3a10",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_T1_raw = paths['T1']\n",
    "assert os.path.exists(path_T1_raw)\n",
    "print(path_T1_raw)\n",
    "\n",
    "path_T1_processed = os.path.join(path_processed_subject, 'structural', f'{subject_id}_T1w.nii.gz')\n",
    "\n",
    "if not os.path.exists(path_T1_processed):\n",
    "    os.makedirs(os.path.dirname(path_T1_processed), exist_ok=True)\n",
    "    shutil.copy2(path_T1_raw, path_T1_processed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2692a6de",
   "metadata": {},
   "source": [
    "## T2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c6b7593",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_T2_raw = paths['T2']\n",
    "assert os.path.exists(path_T2_raw)\n",
    "print(path_T2_raw)\n",
    "\n",
    "path_T2_processed = os.path.join(path_processed_subject, 'structural', f'{subject_id}_T2w.nii.gz')\n",
    "\n",
    "if not os.path.exists(path_T2_processed):\n",
    "    os.makedirs(os.path.dirname(path_T2_processed), exist_ok=True)\n",
    "    shutil.copy2(path_T2_raw, path_T2_processed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3e9c62a4",
   "metadata": {},
   "source": [
    "## Brainmask"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "973d86d1",
   "metadata": {},
   "source": [
    "### Whole brain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3eb944a",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_brainmask_raw = paths['brainmask']\n",
    "assert os.path.exists(path_brainmask_raw)\n",
    "print(path_brainmask_raw)\n",
    "\n",
    "path_brainmask_processed = os.path.join(path_processed_subject, 'brainmasks', f'{subject_id}_brainmask.nii.gz')\n",
    "\n",
    "if not os.path.exists(path_brainmask_processed):\n",
    "    os.makedirs(os.path.dirname(path_brainmask_processed), exist_ok=True)\n",
    "\n",
    "    vol_brainmask_raw = nib.load(path_brainmask_raw)\n",
    "    data_brainmask = vol_brainmask_raw.get_fdata().astype(np.float32)\n",
    "    vol_brainmask_processed = nib.Nifti1Image(data_brainmask, affine=vol_brainmask_raw.affine)\n",
    "    nib.save(vol_brainmask_processed, path_brainmask_processed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b076448b",
   "metadata": {},
   "source": [
    "### Hemispheres"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "03715b74",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_freesufer = paths['freesurfer']\n",
    "assert os.path.exists(path_freesufer)\n",
    "print(path_freesufer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "358fb36b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_aseg = os.path.join(path_freesufer, 'mri', 'aseg.mgz')\n",
    "assert os.path.exists(path_aseg)\n",
    "\n",
    "vol_aseg = nib.load(path_aseg)\n",
    "data_aseg = vol_aseg.get_fdata().astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "306d91d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "vol_brainmask = nib.load(path_brainmask_processed)\n",
    "data_brainmask = vol_brainmask.get_fdata().astype(bool)\n",
    "\n",
    "affine_aseg = vol_aseg.affine\n",
    "affine_brainmask = vol_brainmask.affine\n",
    "\n",
    "left_labels, right_labels = freesurfer.get_hemisphere_labels()\n",
    "\n",
    "left_voxels_aseg = np.column_stack(np.where(np.isin(data_aseg, left_labels)))\n",
    "right_voxels_aseg = np.column_stack(np.where(np.isin(data_aseg, right_labels)))\n",
    "\n",
    "left_coords = nib.affines.apply_affine(affine_aseg, left_voxels_aseg)\n",
    "right_coords = nib.affines.apply_affine(affine_aseg, right_voxels_aseg)\n",
    "\n",
    "left_tree = KDTree(left_coords)\n",
    "right_tree = KDTree(right_coords)\n",
    "\n",
    "voxel_coords_brainmask = np.column_stack(np.where(data_brainmask))\n",
    "voxel_coords_brainmask_ras = nib.affines.apply_affine(affine_brainmask, voxel_coords_brainmask)\n",
    "\n",
    "dist_left, _ = left_tree.query(voxel_coords_brainmask_ras)\n",
    "dist_right, _ = right_tree.query(voxel_coords_brainmask_ras)\n",
    "labels_coords_brainmask = np.where(dist_left < dist_right, 1, 2).flatten()  # Left 1, Right 2\n",
    "data_brainmask_hemi = np.zeros(data_brainmask.shape, dtype=np.float32)\n",
    "data_brainmask_hemi[voxel_coords_brainmask[:, 0], voxel_coords_brainmask[:, 1], voxel_coords_brainmask[:, 2]] = labels_coords_brainmask\n",
    "\n",
    "vol_brainmask_hemispheres = nib.Nifti1Image(data_brainmask_hemi, affine_brainmask)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66cafce1",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_brainmask_hemi_processed = os.path.join(path_processed_subject, 'brainmasks', f'{subject_id}_brainmask_hemi.nii.gz')\n",
    "\n",
    "if not os.path.exists(path_brainmask_hemi_processed):\n",
    "    nib.save(vol_brainmask_hemispheres, path_brainmask_hemi_processed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0b20c7db",
   "metadata": {},
   "source": [
    "## Stimuli"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c5466ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_stimuli_raw = paths['stimuli']\n",
    "assert os.path.exists(path_stimuli_raw)\n",
    "print(path_stimuli_raw)\n",
    "\n",
    "df_stimuli_raw = pd.read_csv(path_stimuli_raw)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "750e89fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_stimuli_processed = pd.DataFrame({})\n",
    "\n",
    "df_stimuli_processed['Session'] = df_stimuli_raw['session']\n",
    "df_stimuli_processed['Run'] = df_stimuli_raw['run']\n",
    "df_stimuli_processed['Trial'] = df_stimuli_raw['trial_id']\n",
    "df_stimuli_processed['Split'] = df_stimuli_raw['trial_type']\n",
    "df_stimuli_processed['Stimulus'] = df_stimuli_raw['stimulus']\n",
    "df_stimuli_processed['Dataset'] = 'THINGS'\n",
    "df_stimuli_processed['Type'] = 'single'\n",
    "df_stimuli_processed['Concept'] = df_stimuli_raw['concept']\n",
    "df_stimuli_processed['Subject'] = subject_id"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0af13ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_stimuli_processed = os.path.join(path_processed_subject, 'stimuli', f'{subject_id}_stimuli.csv')\n",
    "\n",
    "if not os.path.exists(path_stimuli_processed):\n",
    "    os.makedirs(os.path.dirname(path_stimuli_processed), exist_ok=True)\n",
    "    df_stimuli_processed.to_csv(path_stimuli_processed, index=False)\n",
    "\n",
    "df_stimuli_processed"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "33948546",
   "metadata": {},
   "source": [
    "## ROIS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbc0bb63",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_rois_raw = paths['rois']\n",
    "assert os.path.exists(path_rois_raw)\n",
    "print(path_rois_raw)\n",
    "\n",
    "df_rois_raw = pd.read_csv(path_rois_raw)\n",
    "columns = df_rois_raw.columns\n",
    "voxel_coords = df_rois_raw[['voxel_x', 'voxel_y', 'voxel_z']].values\n",
    "\n",
    "vol_brainmask_hemi = nib.load(path_brainmask_hemi_processed)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "567cfccc",
   "metadata": {},
   "source": [
    "### Glasser"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "859b730c",
   "metadata": {},
   "outputs": [],
   "source": [
    "glasser_rois_raw = [column for column in columns if 'glasser' in column]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e79bfcc8",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_glasser = df_rois_raw[glasser_rois_raw]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccd56ac9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_glasser = df_rois_glasser.rename(columns=lambda col: col.removeprefix('glasser-').replace('\\n', ''))\n",
    "df_rois_glasser"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50b66127",
   "metadata": {},
   "outputs": [],
   "source": [
    "is_left_coords = labels_coords_brainmask == 1\n",
    "is_right_coords = labels_coords_brainmask == 2\n",
    "\n",
    "print(f'Num. Voxels Left Hemisphere: {is_left_coords.sum()}')\n",
    "print(f'Num. Voxels Left Hemisphere: {is_right_coords.sum()}')\n",
    "\n",
    "assert np.sum(is_left_coords + is_right_coords) == len(voxel_coords)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6d7ce7af",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_rois_glasser_left = {}\n",
    "dict_rois_glasser_right = {}\n",
    "\n",
    "glasser_rois_processed = df_rois_glasser.columns\n",
    "\n",
    "for glasser_roi in glasser_rois_processed:\n",
    "    name_roi_left = f'lh_{glasser_roi}'\n",
    "    name_roi_right = f'rh_{glasser_roi}'\n",
    "\n",
    "    dict_rois_glasser_left[name_roi_left] = df_rois_glasser[glasser_roi] * is_left_coords\n",
    "    dict_rois_glasser_right[name_roi_right] = df_rois_glasser[glasser_roi] * is_right_coords"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3dec614c",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_glasser_hemi = pd.DataFrame({**dict_rois_glasser_left, **dict_rois_glasser_right})\n",
    "df_rois_glasser_hemi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66ea60da",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_glasser_processed = os.path.join(path_processed_subject, 'rois', 'glasser', f'{subject_id}_glasser.csv')\n",
    "path_glasser_hemi_processed = os.path.join(path_processed_subject, 'rois', 'glasser', f'{subject_id}_glasser_hemi.csv')\n",
    "\n",
    "os.makedirs(os.path.dirname(path_glasser_processed), exist_ok=True)\n",
    "\n",
    "if not os.path.exists(path_glasser_processed):\n",
    "    df_rois_glasser.to_csv(path_glasser_processed, index=False)\n",
    "\n",
    "if not os.path.exists(path_glasser_hemi_processed):\n",
    "    df_rois_glasser_hemi.to_csv(path_glasser_hemi_processed, index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0d421580",
   "metadata": {},
   "source": [
    "### Localizers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b817353e",
   "metadata": {},
   "outputs": [],
   "source": [
    "index_V1 = columns.to_list().index('V1')\n",
    "index_glasser_V1 = columns.to_list().index('glasser-V1') # Localizer rois are between V1 and glasser-V1\n",
    "\n",
    "localizers_columns = columns[index_V1:index_glasser_V1]\n",
    "print(localizers_columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60d2b051",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_localizers = df_rois_raw[localizers_columns]\n",
    "df_rois_localizers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b21930b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_roi_localizers_left = {}\n",
    "dict_roi_localizers_right = {}\n",
    "\n",
    "for localizer_roi in localizers_columns:\n",
    "    if localizer_roi.startswith(\"l\"):\n",
    "        name_roi_left = f'lh_{localizer_roi[1:]}'\n",
    "        dict_roi_localizers_left[name_roi_left] = df_rois_localizers[localizer_roi].values\n",
    "    elif localizer_roi.startswith(\"r\"):\n",
    "        name_roi_right = f'rh_{localizer_roi[1:]}'\n",
    "        dict_roi_localizers_right[name_roi_right] = df_rois_localizers[localizer_roi].values\n",
    "    else:\n",
    "        if localizer_roi == 'LO1 (prf)':\n",
    "            name_roi_left = 'lh_LO1'\n",
    "            name_roi_right = 'rh_LO1'\n",
    "            dict_roi_localizers_left[name_roi_left] = df_rois_localizers['LO1 (prf)'].values * is_left_coords\n",
    "            dict_roi_localizers_right[name_roi_right] = df_rois_localizers['LO1 (prf)'].values * is_right_coords\n",
    "        elif localizer_roi == 'LO2 (prf)':\n",
    "            name_roi_left = 'lh_LO2'\n",
    "            name_roi_right = 'rh_LO2'\n",
    "            dict_roi_localizers_left[name_roi_left] = df_rois_localizers['LO2 (prf)'].values * is_left_coords\n",
    "            dict_roi_localizers_right[name_roi_right] = df_rois_localizers['LO2 (prf)'].values * is_right_coords\n",
    "        else:\n",
    "            name_roi_left = f'lh_{localizer_roi}'\n",
    "            name_roi_right = f'rh_{localizer_roi}'\n",
    "            dict_roi_localizers_left[name_roi_left] = df_rois_localizers[localizer_roi].values * is_left_coords\n",
    "            dict_roi_localizers_right[name_roi_right] = df_rois_localizers[localizer_roi].values * is_right_coords"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98e21ef6",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_localizers_hemi = pd.DataFrame({**dict_roi_localizers_left, **dict_roi_localizers_right})\n",
    "df_rois_localizers_hemi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f48c34e",
   "metadata": {},
   "outputs": [],
   "source": [
    "names_rois_localizers_left = dict_roi_localizers_left.keys()\n",
    "names_rois_localizers_right = dict_roi_localizers_right.keys()\n",
    "\n",
    "dict_roi_localizers_all = {}\n",
    "\n",
    "for roi_left, roi_right in zip(names_rois_localizers_left, names_rois_localizers_right):\n",
    "    assert roi_left[3:] == roi_right[3:]\n",
    "    dict_roi_localizers_all[roi_left[3:]] = dict_roi_localizers_left[roi_left] + dict_roi_localizers_right[roi_right]\n",
    "    assert np.all(dict_roi_localizers_all[roi_left[3:]] < 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b001fa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_localizers_all = pd.DataFrame(dict_roi_localizers_all)\n",
    "df_rois_localizers_all"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3f45f0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_localizers_processed = os.path.join(path_processed_subject, 'rois', 'localizers', f'{subject_id}_localizers.csv')\n",
    "path_localizers_hemi_processed = os.path.join(path_processed_subject, 'rois', 'localizers', f'{subject_id}_localizers_hemi.csv')\n",
    "\n",
    "os.makedirs(os.path.dirname(path_localizers_processed), exist_ok=True)\n",
    "\n",
    "if not os.path.exists(path_localizers_processed):\n",
    "    df_rois_localizers_all.to_csv(path_localizers_processed, index=False)\n",
    "\n",
    "if not os.path.exists(path_localizers_hemi_processed):\n",
    "    df_rois_localizers_hemi.to_csv(path_localizers_hemi_processed, index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ccbc9238",
   "metadata": {},
   "source": [
    "## pRF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f605fbb0",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rois_raw"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcf0511c",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_prf_processed = pd.DataFrame({})\n",
    "dict_prf_processed['Eccentricity'] = df_rois_raw['prf-eccentricity']\n",
    "dict_prf_processed['PolarAngle'] = df_rois_raw['prf-polarangle']\n",
    "dict_prf_processed['RSquared'] = df_rois_raw['prf-rsquared']\n",
    "dict_prf_processed['Size'] = df_rois_raw['prf-size']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b9d2fef",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_prf_processed_hemi = pd.DataFrame({})\n",
    "\n",
    "dict_prf_processed_hemi['lh_Eccentricity'] = df_rois_raw['prf-eccentricity'] * is_left_coords\n",
    "dict_prf_processed_hemi['lh_PolarAngle'] = df_rois_raw['prf-polarangle'] * is_left_coords\n",
    "dict_prf_processed_hemi['lh_RSquared'] = df_rois_raw['prf-rsquared'] * is_left_coords\n",
    "dict_prf_processed_hemi['lh_Size'] = df_rois_raw['prf-size'] * is_left_coords\n",
    "\n",
    "dict_prf_processed_hemi['rh_Eccentricity'] = df_rois_raw['prf-eccentricity'] * is_right_coords\n",
    "dict_prf_processed_hemi['rh_PolarAngle'] = df_rois_raw['prf-polarangle'] * is_right_coords\n",
    "dict_prf_processed_hemi['rh_Rsquared'] = df_rois_raw['prf-rsquared'] * is_right_coords\n",
    "dict_prf_processed_hemi['rh_Size'] = df_rois_raw['prf-size'] * is_right_coords"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9a99cd8",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_prf_processed_hemi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c013d3e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_prf_processed = os.path.join(path_processed_subject, 'prf', f'{subject_id}_prf.csv')\n",
    "path_prf_hemi_processed = os.path.join(path_processed_subject, 'prf', f'{subject_id}_prf_hemi.csv')\n",
    "\n",
    "os.makedirs(os.path.dirname(path_prf_processed), exist_ok=True)\n",
    "\n",
    "if not os.path.exists(path_prf_processed):\n",
    "    dict_prf_processed.to_csv(path_prf_processed, index=False)\n",
    "\n",
    "if not os.path.exists(path_prf_hemi_processed):\n",
    "    dict_prf_processed_hemi.to_csv(path_prf_hemi_processed, index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f273625c",
   "metadata": {},
   "source": [
    "## Betas"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "18c28dc2",
   "metadata": {},
   "source": [
    "### Volume"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8590df88",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_betas_raw = paths['betas']\n",
    "assert os.path.exists(path_betas_raw)\n",
    "print(path_betas_raw)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8724288",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_betas_vol = os.path.join(path_processed_subject, 'betas', 'vol', f'{subject_id}_betas_vol.npy')\n",
    "os.makedirs(os.path.dirname(path_betas_vol), exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06b6a79e",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(path_betas_vol):\n",
    "    betas = pd.read_hdf(path_betas_raw)\n",
    "    betas = betas.drop('voxel_id', axis=1)\n",
    "    betas = betas.to_numpy().T\n",
    "\n",
    "    num_stimuli = betas.shape[0]\n",
    "    num_voxels = betas.shape[1]\n",
    "\n",
    "    print('Num. Voxels:', num_voxels)\n",
    "    print('Num. Stimuli:', num_stimuli)\n",
    "\n",
    "    list_sessions = np.unique(df_stimuli_processed['Session'].to_numpy())\n",
    "    print(list_sessions)\n",
    "\n",
    "    np.save(path_betas_vol, betas)\n",
    "    del betas"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "40437cc6",
   "metadata": {},
   "source": [
    "### Surface"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b0c8c8f6",
   "metadata": {},
   "source": [
    "### Left Hemisphere"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7fb8e40",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_mesh_pial_left = os.path.join(path_freesufer, 'surf', 'lh.pial')\n",
    "path_mesh_white_left = os.path.join(path_freesufer, 'surf', 'lh.white')\n",
    "\n",
    "assert os.path.exists(path_mesh_pial_left)\n",
    "assert os.path.exists(path_mesh_white_left)\n",
    "\n",
    "print(path_mesh_pial_left)\n",
    "print(path_mesh_white_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b674d338",
   "metadata": {},
   "outputs": [],
   "source": [
    "mesh_pial_left = surface.load_surf_mesh(path_mesh_pial_left)\n",
    "mesh_white_left = surface.load_surf_mesh(path_mesh_white_left)\n",
    "num_vertices_left = mesh_pial_left.n_vertices\n",
    "assert mesh_pial_left.n_vertices == mesh_white_left.n_vertices\n",
    "\n",
    "print('Num. Vertices Left:', num_vertices_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be7fcb0b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_betas_surf_left = os.path.join(path_processed_subject, 'betas', 'surf', f'{subject_id}_betas_surf_lh.npy')\n",
    "\n",
    "os.makedirs(os.path.dirname(path_betas_surf_left), exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0351a0a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(path_betas_surf_left):\n",
    "    betas = np.load(path_betas_vol)\n",
    "\n",
    "    num_stimuli = betas.shape[0]\n",
    "    betas_surf_left = np.zeros((num_stimuli, num_vertices_left), dtype=np.float32)\n",
    "\n",
    "    for i_stimulus in tqdm(range(num_stimuli)):\n",
    "        betas_stimulus = betas[i_stimulus, :]\n",
    "        vol_betas_stimulus = unmask(betas_stimulus, vol_brainmask)\n",
    "        betas_surf_left[i_stimulus, :] = surface.vol_to_surf(vol_betas_stimulus,\n",
    "                                                             surf_mesh=mesh_pial_left,\n",
    "                                                             inner_mesh=mesh_white_left,\n",
    "                                                             interpolation='linear',\n",
    "                                                             kind='depth',\n",
    "                                                             depth=[0.5])\n",
    "    np.save(path_betas_surf_left, betas_surf_left)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "69cf01d6",
   "metadata": {},
   "source": [
    "#### Right Hemisphere"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d324db8",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_betas_surf_right = os.path.join(path_processed_subject, 'betas', 'surf', f'{subject_id}_betas_surf_rh.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61305d12",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_mesh_pial_right = os.path.join(path_freesufer, 'surf', 'rh.pial')\n",
    "path_mesh_white_right = os.path.join(path_freesufer, 'surf', 'rh.white')\n",
    "\n",
    "assert os.path.exists(path_mesh_pial_right)\n",
    "assert os.path.exists(path_mesh_white_right)\n",
    "\n",
    "print(path_mesh_pial_right)\n",
    "print(path_mesh_white_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "322d679c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mesh_pial_right = surface.load_surf_mesh(path_mesh_pial_right)\n",
    "mesh_white_right = surface.load_surf_mesh(path_mesh_white_right)\n",
    "num_vertices_right = mesh_pial_right.n_vertices\n",
    "assert mesh_pial_right.n_vertices == mesh_white_right.n_vertices\n",
    "\n",
    "print('Num. Vertices Right:', num_vertices_right)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "56912964",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists(path_betas_surf_right):\n",
    "    if not 'betas' in locals():\n",
    "        betas = np.load(path_betas_vol)\n",
    "\n",
    "    num_stimuli = betas.shape[0]\n",
    "    betas_surf_right = np.zeros((num_stimuli, num_vertices_right), dtype=np.float32)\n",
    "\n",
    "    for i_stimulus in tqdm(range(num_stimuli)):\n",
    "        betas_stimulus = betas[i_stimulus, :]\n",
    "        vol_betas_stimulus = unmask(betas_stimulus, vol_brainmask)\n",
    "        betas_surf_right[i_stimulus, :] = surface.vol_to_surf(vol_betas_stimulus,\n",
    "                                                              surf_mesh=mesh_pial_right,\n",
    "                                                              inner_mesh=mesh_white_right,\n",
    "                                                              interpolation='linear',\n",
    "                                                              kind='depth',\n",
    "                                                              depth=[0.5])\n",
    "    np.save(path_betas_surf_right, betas_surf_right)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a43cdd2",
   "metadata": {},
   "source": [
    "## Visualize betas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "74c89ea9",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_inflated = os.path.join(path_freesufer, 'surf', f'lh.inflated')\n",
    "assert os.path.exists(path_inflated)\n",
    "\n",
    "mesh_inflated = surface.load_surf_mesh(path_inflated)\n",
    "print(mesh_inflated.n_vertices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94226614",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not 'betas_surf_left' in locals():\n",
    "    betas_surf_left = np.load(path_betas_surf_left)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa856a35",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_stimulus = 1\n",
    "\n",
    "fig = plotting.plot_surf_stat_map(\n",
    "    surf_mesh=mesh_inflated,\n",
    "    stat_map=betas_surf_left[idx_stimulus, :],\n",
    "    hemi='left',\n",
    "    view='lateral',\n",
    "    cmap='cold_hot',\n",
    "    title=f'Subject {subject_id} Beta Map (Inflated)',\n",
    "    colorbar=True,\n",
    "    engine='plotly',\n",
    ")\n",
    "fig.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04a99a31",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not 'betas' in locals():\n",
    "    betas = np.load(path_betas_vol)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "707ae1a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "vol_T1 = nib.load(path_T1_processed)\n",
    "\n",
    "betas_zscored_stimulus = betas[idx_stimulus, :]\n",
    "vol_betas_zscored_stimulus = unmask(betas_zscored_stimulus, vol_brainmask)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "351467a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "plotting.plot_stat_map(vol_betas_zscored_stimulus, bg_img=vol_T1)\n",
    "plotting.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06d57358",
   "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
}
