Tutorial: Import and visualize functional NIRS data

<!> This tutorial is under construction <!>

Authors: Thomas Vincent

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.

Download

The dataset used in this tutorial is available online.

Presentation of the experiment

Create the data structure

Create a protocol called "TutorialNIRSTapping":

In term of sensor configuration, NIRS is similar to EEG and the placement of optodes may change from subject to the other. Also, the channel definition will change during data processing, that's why you should always use one channel file per acquisition even if the optode placement does not change.

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

Import anatomy

Import MRI and meshes

Make sure you are in the anatomy view of the protocol. Right-click on "Subject01 -> Import anatomy folder". Select anatomy folder from the nirs_sample data folder. Reply "yes" when asked to apply the transformation. Leave the number of vertices for the head mesh to the default value. This will open the MRI review panel where you have to set the fudicial points (See Import the subject anatomy). Note that the PC, AC and IH points are already defined.

NIRSTORM_tut_nirs_tapping_MRI_edit.gif

Here are the MRI coordinates ([x y z] in mm) of the fiducials used to produce the above figure:

To define NAS, LPA and RPA, you can right click on the anatomy view, select "Edit fiducial points" and enter the coordinates above.

When finished, click on "Save".

The head and white segmentations provided in the NIRS sample data were computed with Brainvisa and should automatically be imported and processed. 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_tut_nirs_tapping_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 data subfolder of the nirs sample folder. It contains the following files:

To import this data set in Brainstorm:

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.

To review this registration, right-click on "NIRS-BRS sensors (104) -> Display sensors -> NIRS" To show the fiducials, which were stored as additional digitized head points: right-click on "NIRS-BRS sensors (104) -> Display sensors -> NIRS labels". To also show the fiducials, right-click on the plot window and select "Figure -> View head points"

NIRSTORM_tut_nirs_tapping_display_sensors_fiducials.png

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_tut_nirs_tapping_brainsight_head_mesh_fiducials_1.gif NIRSTORM_tut_nirs_tapping_brainsight_head_mesh_fiducials_2.gif NIRSTORM_tut_nirs_tapping_brainsight_head_mesh_fiducials_3.gif

Review Channel information

The resulting data organization should be:

NIRSTORM_tut_nirs_tapping_func_organization.png

This indicates that the data comes from the Brainsight system (BRS) and comprises 104 channels (96 NIRS channels + 8 auxiliary signals).

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

NIRSTORM_tut_nirs_tapping_channel_table.png

Visualize NIRS signals

Select "Subject01/S01_Block_FO_LH_Run01/Link to raw file -> NIRS -> Display time series" It will open a new figure with superimposed channels

NIRSTORM_tut_nirs_tapping_time_series_stacked.png

Which can also be viewed in butterfly mode

NIRSTORM_tut_nirs_tapping_time_series_butterfly.png

To view the auxiliary data, select "Subject01/S01_Block_FO_LH_Run01/Link to raw file -> NIRS_AUX -> Display time series"

NIRSTORM_tut_nirs_tapping_time_series_AUX_stacked.gif

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

Montage selection

/!\ TODO add dynamic montages

/!\ Add screenshot

Extract stimulation events

During the experiment, the stimulation paradigm was run under matlab and sent triggers through the parallel port to the acquisition device. These stimulation events are then stored as a box signal in channel AUX2: values above a certain threshold indicate a stimulation block.

To transform this signal into Brainstorm events, drag and drop the NIRS data "S01_Block_FO_LH_Run01" in the Brainstorm process window. Click on "Run" and select Process "Events -> Read from channel".

NIRSTORM_tut_nirs_tapping_detect_events.gif

Use the following parameters:

Run the process.

Then right-click on "Link to raw file" under "S01_Block_FO_LH_Run01" then "NIRS -> Display time series". There should be an event group called "AUX1". Rename it to "MOTOR" using "Events -> Rename Group".

NIRSTORM_tut_nirs_tapping_nirs_time_series_motor_events.gif

The "MOTOR" event group has 10 events which are shown in green on the top of the plot.

Bad channel tagging

NIRS measurement are heterogeneous (long distance measurements, movements, occlusion by hair) and the signal in several channels might not be properly analysed. A first pre-processing step hence consists in removing those channels.

The following criterions may be applied to reject channels:

Drag and drop the NIRS data "S01_Block_FO_LH_Run01" in the Brainstorm process window. Click on "Run" and select Process "NIRSTORM -> Tag bad channels".

[ATTACH]

This process is performed "in place": the channel flags of the given data are modified. To view the result, right-click on "S01_Block_FO_LH_Run01 > Link to raw file" then "Good/Bad Channels > View all bad channels" or "Edit good/bad channels".

Compute [Hb] variations - Modified Beer-Lambert Law

This process computes variations of concentration of oxy-hemoglobin (HbO), deoxy-hemoglobin (HbR) and total hemoglobin (HbT) from the measured light intensity time courses at different wavelengths.

Note that the channel definition will differ from the raw data. Previously there was one channel per wavelength, now there will be one channel per Hb type (HbO, HbR or HbT). The total number of channels may change.

For a given pair, the formula used is:

where:

[ATTACH]

Process parameters:

This process creates a new condition, here "Hb_S01_Block_FO_LH_Run01", because the montage is redefined.

Double-click on "Hb_S01_Block_FO_LH_Run01 |- [Hb]" to browse the delta [Hb] time-series.

[ATTACH]

As shown on the left part, all recorded optode pairs are available as montages to enable the display of overlapping HbO, HbR and HbT.

Linear detrend

This filter process removes any linear trend in the signal.

Clear the process window and drag and drop the item named "[Hb]" into it. Select "Run -> NIRSTORM -> Linear Detrend"

[ATTACH]

Parameters:

This process creates an item called "[Hb] | detrended"

Infinite Impulse Response filtering

So far, the signal still contains a lot of physiological components of non-interest: heart beats, breathing and Mayer waves. As the evoked signal of interest should be distinct from those components in terms of frequency bands, we can get rid of them by filtering.

[ATTACH]

Parameters:

This process creates an item called "[Hb] | detrended | IIR filtered"

Window averaging

the goal is to get the response elicited by the motor paradigm. For this, we perform window-averaging time-locked on each motor onset while correcting for baseline differences across trials.

The first step is to split the data into chunks corresponding to the window over which we want to average. The average window is wider than the stimulation events: we'd like to see the return to baseline / undershoot after stimulation. If we directly use the extended MOTOR events to split data, the window will be constrain to the event durations.

To avoid this, define new "simple" events from the existing ones: Double-click on "[Hb] | detrended | IIR filtered", then in the right panel select the MOTOR event type, click on "Events -> convert to simple events" and select "start". Then click on "File -> Save modifications". This defines the temporal origin point of the peri-stimulus averaging window.

Right-click on "[Hb] | detrended | IIR filtered -> Import in database"

[ATTACH]

Ensure that "Use events" is checked and that the MOTOR events are selected. The epoch time should be: -5000 to 45000 ms. This means that there will be 5 seconds prior to the stimulation event to check if the signal is steady. There will also be 15 seconds after the stimulation to check the return to baseline / undershoot. In the "Pre-processing" panel, check "Remove DC offset" and use a Time range of -5000 to -100 ms. This will set a reference window prior over which to remove chunk offsets. All signals will be zero-centered according to this window. Finally, ensure that the option "Create a separate folder for each event type" is checked".

After clicking on "import", we end up with 10 "MOTOR" data chuncks.

The last step is to actually compute the average of these chunks. Clear the process panel then drag and drop the item "MOTOR (10 files)" into it. Click on "run" and select the process "Average -> Average files".

[ATTACH]

Use Group files: Everything and Function: Arithmetic average + Standard deviation.

To see the results, double click on the created item "AvgStd: MOTOR (10)". You can again browse by measurement pair by using the different montages in the record panel.

[ATTACH]

Tutorials/NIRSFingerTapping (last edited 2016-04-25 16:07:20 by ?ThomasVincent)