Skip to content

Commit

Permalink
Merge pull request #806 from contsili/ctf_data
Browse files Browse the repository at this point in the history
Added FAQ: ''why should I set cfg.continuous = 'yes' when preprocessing CTF trial-based data?''
  • Loading branch information
robertoostenveld authored Sep 20, 2024
2 parents bafd471 + 72c6ef6 commit 9715cc4
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 9 deletions.
1 change: 1 addition & 0 deletions faq.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ See also the [tutorials](/tutorial) and [example scripts](/example).
- [How can I inspect the electrode impedances of my data?](/faq/how_can_i_inspect_the_electrode_impedances_of_my_data)
- [Should I rereference my EEG data prior to, or after ICA?](/faq/should_I_rereference_prior_to_or_after_ica_for_artifact_removal)
- [I used to work with trl-matrices that have more than 3 columns. Why is this not supported anymore?](/faq/i_used_to_work_with_trl-matrices_that_have_more_than_3_columns._why_is_this_not_supported_anymore)
- [Why should I set cfg.continuous = 'yes' when preprocessing CTF trial-based data?](/faq/continuous)

### Specific data formats

Expand Down
19 changes: 19 additions & 0 deletions faq/continuous.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
---
title: Why should I set cfg.continuous = 'yes' when preprocessing CTF trial-based data?
tags: [faq, ctf, preprocessing, continuous]
authors: [Konstantinos Tsilimparis, Robert Oostenveld]
---

# Why should I set cfg.continuous = 'yes' when preprocessing CTF trial-based data?

The CTF acquisition software by default writes data to disk in blocks. The length of these blocks can be configured, and at the DCCN this is set to 10 seconds. So the continuous recording is actually pseudo-continuous and consists of blocks of 10 seconds, where block N is followed smoothly without gaps by block N+1. However, the CTF acquisition software can also be configured to only write a block of data to disk upon a trigger. This results in "epoched" data, where only the data corresponding to the trial is written to disk and the data in the inter trial intervals is not. In this case there is a gap between block N and block N+1. If you were to read the epoched data as if it were continuously, you won't see the gaps as such along the time axis, but you will see jumps in the data as the signal may have drifted from block N to block N+1.

FieldTrip does not distinguish between the CTF files that are written as blocks in continuous mode, without gaps, and CTF files that are written as epochs with gaps between the blocks. The low-level reading functions by default will give an error when you try to read data that extends over a boundary between two blocks, but the `cfg.continuous` option in **[ft_preprocessing](/reference/ft_preprocessing)** allows you to override that.

The "Subject01.ds" CTF dataset that is used in some tutorials is epoched and has gaps between the trials. If you were to read that as continuous, you would see discontinuities in the MEG channels. If you were to apply the automatic artifact detection functions on that as continuous data, many trials would be detected as an artifact as they start/end with a discontinuous jump in some of the channels. Hence when reading that data the `cfg.continuous` option should be set to `"no"` (which is the default).

Many other CTF datasets are recorded as pseudocontinuous without gaps between the blocks and for those you do want to set the `cfg.continuous` option to `"yes"`.

To check whether your data is epoched or pseudocontinuous, please have a look at the `SCLK01` channel.

Note that besides **[ft_preprocessing](/reference/ft_preprocessing)**, other functions that read data from disk also have the `cfg.continuous` option, such as **[ft_databrowser](/reference/ft_databrowser)** and the automatic artifact detection functions.
4 changes: 0 additions & 4 deletions tag/reproducescript .md

This file was deleted.

4 changes: 0 additions & 4 deletions tag/script .md

This file was deleted.

2 changes: 1 addition & 1 deletion tutorial/preprocessing.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ This results in a cfg.trl that contains the trial definitions of all conditions
The output of **[ft_definetrial](/reference/ft_definetrial)** can be used for **[ft_preprocessing](/reference/ft_preprocessing)**.

cfg.channel = {'MEG' 'EOG'};
cfg.continuous = 'yes';
cfg.continuous = 'yes'; % see https://www.fieldtriptoolbox.org/faq/continuous/
data_all = ft_preprocessing(cfg);

Save the data to disk
Expand Down

0 comments on commit 9715cc4

Please sign in to comment.