{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4cc3bbcd",
   "metadata": {},
   "outputs": [],
   "source": [
    "!pip install nibabel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb7b2c39-25a4-412b-830e-0efeb2a32c7b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import numpy as np\n",
    "import plotly.graph_objs as go\n",
    "from ipywidgets import interact, IntSlider\n",
    "\n",
    "def viz_3d(data, cmap):\n",
    "    # Define function for interactive visualization\n",
    "    def visualize_projections(x_index, y_index, z_index, cmap):\n",
    "        fig, axes = plt.subplots(1, 3, figsize=(15, 5))\n",
    "\n",
    "        # Projection along x-axis\n",
    "        if x_index < data.shape[0]:\n",
    "            axes[0].imshow(data[x_index, :, :], cmap=cmap)\n",
    "            axes[0].set_title(f'Projection along X-axis at index {x_index}')\n",
    "        else:\n",
    "            axes[0].text(0.5, 0.5, 'Out of bounds', horizontalalignment='center', verticalalignment='center', fontsize=12, transform=axes[0].transAxes)\n",
    "\n",
    "        # Projection along y-axis\n",
    "        if y_index < data.shape[1]:\n",
    "            axes[1].imshow(data[:, y_index, :], cmap=cmap)\n",
    "            axes[1].set_title(f'Projection along Y-axis at index {y_index}')\n",
    "        else:\n",
    "            axes[1].text(0.5, 0.5, 'Out of bounds', horizontalalignment='center', verticalalignment='center', fontsize=12, transform=axes[1].transAxes)\n",
    "\n",
    "        # Projection along z-axis\n",
    "        if z_index < data.shape[2]:\n",
    "            axes[2].imshow(data[:, :, z_index], cmap=cmap)\n",
    "            axes[2].set_title(f'Projection along Z-axis at index {z_index}')\n",
    "        else:\n",
    "            axes[2].text(0.5, 0.5, 'Out of bounds', horizontalalignment='center', verticalalignment='center', fontsize=12, transform=axes[2].transAxes)\n",
    "\n",
    "        plt.show()\n",
    "\n",
    "    # Create interactive sliders for each axis\n",
    "    x_slider = IntSlider(min=0, max=data.shape[0]-1, step=1, description='X Index')\n",
    "    y_slider = IntSlider(min=0, max=data.shape[1]-1, step=1, description='Y Index')\n",
    "    z_slider = IntSlider(min=0, max=data.shape[2]-1, step=1, description='Z Index')\n",
    "\n",
    "    # Display interactive widget\n",
    "    interact(visualize_projections, x_index=x_slider, y_index=y_slider, z_index=z_slider, cmap=cmap)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4ad13de-9f10-41a5-aa67-7c2cc999e83b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# tvals\n",
    "tvals_array_subj1_bodies = np.load('./nsd-data/nsd/tvals/subj1_bodies.npy')\n",
    "tvals_array_subj2_bodies = np.load('./nsd-data/nsd/tvals/subj2_bodies.npy')\n",
    "tvals_array_subj5_bodies = np.load('./nsd-data/nsd/tvals/subj5_bodies.npy')\n",
    "tvals_array_subj7_bodies = np.load('./nsd-data/nsd/tvals/subj7_bodies.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ef0205e-bb41-4bae-ab42-e2a58f03e1ba",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# voxel masks\n",
    "voxel_mask_sample = np.load(\"./nsd-data/nsd/voxels_masks/subj1/cortical_mask_subj01_floc-faces.npy\")\n",
    "data = voxel_mask_sample\n",
    "\n",
    "viz_3d(data, cmap='jet')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f12a791-f3b8-49c6-ab94-cf78e1c919cb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import nibabel as nib\n",
    "# Load the .nii.gz file\n",
    "img = nib.load('./nsd-data/nsd/voxels_masks/subj1/streams.nii.gz')\n",
    "viz_3d(img.get_fdata(), cmap='jet')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "468ed057-9bca-4b8b-b8d7-caff411c71a4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
