Brainstorm
  • Comments
  • Menu
    • Attachments
    • Versions
    • Raw Text
    • Print View
  • Login

Software

  • Introduction

  • Gallery

  • Download

  • Installation

Users

  • Tutorials

  • Forum

  • Courses

  • Community

  • Publications

Development

  • What's new

  • What's next

  • About us

  • Contact us

  • Contribute

Revision 28 as of 2015-11-13 16:36:25
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28

Tutorial: Import and visualize functional NIRS data

<!> This tutorial is under construction <!>

Authors: Thomas Vincent, Zhengchen Cai

The current tutorial assumes that the tutorials 1 to 6 have been performed. Even if they focus on MEG data, they introduce Brainstorm features that are required for this tutorial.

List of prerequisites:

  • Create a new protocol

  • Import the subject anatomy

  • Display the anatomy

  • Channel file / MEG-MRI coregistration

  • Review continuous recordings

Download

The dataset used in this tutorial is available online.

  • Go to the Download /!\ link page of this website, and download the file: nirs_sample.zip

  • Unzip it in a folder that is not in any of the Brainstorm folders

Presentation of the experiment

  • Finger tapping task: 10 stimulation blocks of 30 seconds each, with rest periods of ~30 seconds
  • One subject, one NIRS acquisition run of 12 minutes at 10Hz

  • 4 sources and 12 detectors (+ 4 proximity channels) placed above the right motor region
  • Two wavelengths: 690nm and 830nm
  • MRI anatomy 3T from /!\ scanner type

Create the data structure

Create a protocol called "TutorialNIRSTORM":

  • Got to File -> New Protocol

  • Use the following setting :
    • Default anatomy: Use individual anatomy.

    • Default channel file: Use one channel file per subject (EEG).

In term of sensor configuration, NIRS is very similar to EEG and the placement of optodes may change from subject to the other.

(!) Should we add (EEG or NIRS) in the interface?

Create a subject called "Subject01" (Go to File -> New subject), with the default options

Import anatomy

Import MRI

Make sure you are in the anatomy view of the protocol.

Right-click on "Subject01 -> Import MRI". Select T1_MRI.nii from the NIRS_sample data folder. Reply "yes" when asked to apply the transformation.

This will open the MRI review panel where you have to set the fudicial points (See Import the subject anatomy).

NIRSTORM_tut1_MRI_edit_v2.gif

Here are the MRI coordinates (mm) of the fudicials used to produce the above figure:

  • NAS: x:95 y:213 z:114
  • LPA: x:31 y:126 z:88
  • RPA: x:164 y:128 z:89
  • AC: x:96 y:137 z:132
  • PC: x:97 y:112 z:132
  • IH: x:95 y:103 z:180

Import Meshes

The head and white segmentations provided in the NIRS sample data were computed with Brainvisa.

Right-click on "Subject01 -> Import surfaces". From the NIRS sample data folder, select files: head_10000V.mesh, hemi_8003V.mesh and white_8003V.mesh.

You can check the registration between the MRI and the loaded meshes by right-clicking on each mesh element and going to "MRI registration -> Check MRI/Surface registration".

NIRSTORM_tut1_new_MRI_meshes.gif

Import NIRS functional data

The functional data used in this tutorial was produced by the Brainsight acquisition software and is available in the NIRS sample folder in S01_Block_FO_LH_Run01.brs. This folder contains the following files:

  • fiducials.txt: the coordinates of the fudicials (nasion, left ear, right ear).
    The positions of the Nasion, LPA and RPA should have been digitized at the same location as the fiducials previously marked on the anatomical MRI. These points will be used by Brainstorm for the registration, hence the consistency between the digitized and marked fiducials is essential for good results.

  • optodes.txt: the coordinates of the optodes (sources and detectors), in the same referential as in fiducials.txt. Note: the actual referential is not relevant here, as the registration will be performed by Brainstorm afterwards.

  • S01_Block_FO_LH_Run01.nirs: the NIRS data in a HOMer-based format /!\ document format.
    Note: The fields SrcPos and DetPos will be overwritten to match the given coordinates in "optodes.txt"

To import this data set in Brainstorm:

  • Go to the "functional data" view of the protocol.
  • Right-click on "Subject01 -> Review raw file"

    • Select file type "NIRS: Brainsight (.brs)"
    • Load the file "S01_Block_FO_LH_Run01.nirs" in the NIRS sample folder.
      Note: the importation process assumes that the files optodes.txt and fiducials.txt are in the same folder
      as the .nirs data file.

Registration

In the same way as in the tutorial "Channel file / MEG-MRI coregistration", the registration between the MRI and the NIRS is first based on three reference points Nasion, Left and Right ears. It can then be refined with the either the full head shape of the subject or with manual adjustment.

Step 1: Fiducials

  • The initial registration is based on the three fiducial point that define the Subject Coordinate System (SCS): nasion, left ear, right ear. You have marked these three points in the MRI viewer in the previous part.

  • These same three points have also been marked before the acquisition of the NIRS recordings. The person who recorded this subject digitized their positions with a tracking device (here Brainsight). The position of these points are saved in the NIRS datasets (see fiducials.txt).
  • When we bring the NIRS recordings into the Brainstorm database, we align them on the MRI using these fiducial points: we match the NAS/LPA/RPA points digitized with Brainsight with the ones we placed in the MRI Viewer.
  • This registration method gives approximate results. It can be good enough in some cases, but not always because of the imprecision of the measures. The tracking system is not always very precise, the points are not always easy to identify on the MRI slides, and the very definition of these points does not offer a millimeter precision. All this combined, it is easy to end with an registration error of 1cm or more.
  • The quality of the source analysis we will perform later is highly dependent on the quality of the registration between the sensors and the anatomy. If we start with a 1cm error, this error will be propagated everywhere in the analysis.

Step 2: Head shape

/!\ We don't have digitized head points for this data set. We should skip this

Step 3: manual adjustment

/!\ TODO?

To review this registration, right-click on "Common files / NIRS sensors (96) -> Display sensors"

Show the fiducials, which were stored as additional digitized head points: right-clicj on "Common files / NIRS Sensors (96) -> Digitized head points -> View head points"

NIRSTORM_tut1_display_sensors_fiducials.gif

As reference, the following figures show the position of fiducials [blue] (inion and nose tip are extra positions), sources [orange] and detectors [green] as they were digitized by Brainsight:

NIRSTORM_tut1_brainsight_head_mesh_fiducials_1.gif NIRSTORM_tut1_brainsight_head_mesh_fiducials_2.gif NIRSTORM_tut1_brainsight_head_mesh_fiducials_3.gif

Review Channel information

The resulting data organization should be:

func_data_loading_result.gif

/!\ TODO: update screenshot

This indicates that the data comes from the Brainsight system (BRS) and comprises 97 channels.

To review the content of channels, right-click on "BS channels -> Edit channel file".

/!\ TODO: add screenshot of updated channel table

Name

Type

Group

Comment

Loc(1)

Loc(2)

Loc(3)

...

1

TAPPING

Stim

N/A

N/A

N/A

2

WLs

NIRS_WL_DEF

N/A

N/A

N/A

3

S1D1WL1

NIRS

NIRS_WL1

coords S1

coords D1

coords middle [S1-D1]

4

S1D1WL2

NIRS

NIRS_WL2

coords S1

coords D1

coords middle [S1-D1]

5

S1D2WL1

NIRS

NIRS_WL1

coords S1

coords D2

coords middle [S1-D2]

6

S1D2WL2

NIRS

NIRS_WL2

coords S1

coords D2

coords middle [S1-D2]

7

S1P1WL1

NIRS

NIRS_WL1

(NIRS_PROX)

coords S1

coords D2

coords middle [S1-D2]

8

S1P1WL2

NIRS

NIRS_WL2

(NIRS_PROX)

coords S1

coords D2

coords middle [S1-D2]

  • The channel named "STIM1" encodes the stimulation paradigm
  • Other channels contain the NIRS time-series measurements. For a given NIRS channel, its name is composed of the pair Source / Detector and the wavelength value. Column Loc(1) contains the coordinates of the source, Loc(2) the coordinates of the associated detector.
  • Each NIRS channel is assigned to the group "NIRS_WL690" or "NIRS_WL830" so specified its wavelength.
  • The comment "NIRS_PROX" indicates that the channel is a close-source measurement.
    TODO: keep NIRS_PROX ??

Visualize NIRS signals

Right-clicking on the raw file shows the list of channel types:

  • NIRS: 96 NIRS channels (2 wavelengths x 48 Source-Detector pairs)
  • STIM: 1 sequence stimulation blocks

Select -> NIRS -> Display time series

It will open a new figure with superimposed channels

/!\ add screenshot

Which can also be viewed in butterfly mode

/!\ add screenshot

We refer to the tutorial for navigating in these views "Review continuous recordings"

Montage selection

Within the NIRS channel type, the following channel groups are available:

  • All channels: gathers all NIRS channels

  • NIRS_WL690: contains only the channels corresponding to the 690nm wavelength

  • NIRS_WL830: contains only the channels corresponding to the 830nm wavelength

  • NIRS_PROXY: contains only the proximity channels

/!\ Add screenshot

  • MoinMoin Powered
  • Python Powered
  • GPL licensed
  • Valid HTML 4.01