Skip to content

intermountainneuroimaging/bids-fmriprep

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bids-fmriprep

Flywheel Gear which runs fMRIPrep Long-Term Support version 20.2.6 (November 12, 2021) on BIDS-curated data. fMRIPrep is a functional magnetic resonance imaging (fMRI) data preprocessing pipeline that is designed to provide an easily accessible, state-of-the-art interface that is robust to variations in scan acquisition protocols and that requires minimal user input, while providing easily interpretable and comprehensive error and output reporting. It performs basic processing steps (coregistration, normalization, unwarping, noise component extraction, segmentation, skull stripping, etc.) providing outputs that can be easily submitted to a variety of group level analyses, including task-based or resting-state fMRI, graph theory measures, surface or volume-based statistics, etc.

The version number is (Flywheel gear) MAJOR . MINOR . PATCH _ (algorithm) YY . MINOR . PATCH

Overview

This gear can only be run on datasets that have been BIDS curated and can pass the tests of the BIDS Validator. fMRIPrep requires that your dataset include at least one T1w structural image. It can include multiple T1 images, a T2 image and some number of BOLD series. This data must have its DICOMS classified with our classifier gear, and converted to nifti files with our dcm2niix gear, in that order. There are additional requirements as described under "Troubleshooting" below.

This Gear requires a (free) Freesurfer license. The license can be provided to the Gear in 3 ways. See How to include a Freesurfer license file.

The bids-fmriprep Gear can run at the project, subject or session level. Because files are in the BIDS format, all the proper files will be used for the given session, subject, or separately, by subject, for the whole project.

Setup:

Before running BIDS curation on your data, you must first prepare your data with the following steps:

  1. Run the SciTran: DICOM MR Classifier gear on all the acquisitions in your dataset

    • This step extracts the DICOM header info, and store it as Flywheel Metadata.
  2. Run the DCM2NIIX: dcm2nii DICOM to NIfTI converter gear on all the acquisitions in your dataset

    • This step generates the Nifti files that fMRIPrep needs from the DICOMS. It also copies all flywheel metadata from the DICOM to the Nifti file (In this case, all the DICOM header information we extracted in step 1)
  3. Run the curate-bids gear on the project. More information about BIDS Curation on Flywheel can be found here and running the BIDS curation gear is described here. If you need to rename sessions or subjects before curation, you may find the gear helpful: bids-pre-curate.

  4. Run fMRIPrep on a session, subject, or project.

Steps 1 and 2 can be automatically carried out as gear rules.

These steps MUST be done in this order. Nifti file headers have significantly fewer fields than the DICOM headers. File metadata will be written to .json sidecars when the files are exported in the BIDS format as expected by the fMRIPrep BIDS App which is run by this gear.

Running:

To run the gear, select a project, subject or session.

Instead of running at the project level which will sequentially step through each subject, you can launch multiple bids-fmriprep jobs on subjects or sessions in parallel. An example of running bids-fmriprep on a subject using the Flywheel SDK is in this notebook. More details about running gears using the SDK can be found in this tutorial.

Note that bids-fmriprep can take a long time to run because it runs Freesurfer. Depending on the number of structural and functional files, it can run for 12 to 48 or more hours.

Inputs

Because the project has been BIDS curated, all the proper T1, T2, and fMRI files will be automatically found.

bidsignore (optional)

A list of patterns (like .gitignore syntax) defining files that should be ignored by the bids validator.

bids-filter-file (optional)

A JSON file describing custom BIDS input filters using PyBIDS. See here for details. Recommendation: start with the default and edit it to be like the example shown there. This does the opposite of what providing a bidsignore file does: it only keeps what matches the filters.

freesurfer_license (optional)

Your FreeSurfer license file. Obtaining a license is free. This file will be copied into the $FSHOME directory. There are three ways to provide the license to this gear. A license is required for this gear to run.

fs-subjects-dir (optional)

Zip file of existing FreeSurfer subject's directory to reuse. If the output of FreeSurfer recon-all is provided to fMRIPrep, that output will be used rather than re-running recon-all. Unzipping the file should produce a particular subject's directory which will be placed in the $FREESURFER_HOME/subjects directory. The name of the directory must match the -subjid as passed to recon-all. This version of fMRIPrep uses Freesurfer v6.0.1.

previous-results (optional)

Provide previously calculated fMRIPrep output results zip file as in input. This file will be unzipped into the output directory so that previous results will be used instead of re-calculating them. This input is provided so that bids-fmriprep can be run incrementally as new data is acquired.

work-dir (optional)

THIS IS A FUTURE OPTIONAL INPUT. It has not yet been added. Provide intermediate fMRIPrep results as a zip file. This file will be unzipped into the work directory so that previous results will be used instead of re-calculating them. This option is provided so that bids-fmriprep can be run incrementally as new data is acquired. The zip file to provide can be produced by using the gear-save-intermediate-output configuration option. You definitely also want to use the fs-subject-dir input (above) so that FreeSurfer won't be run multiple times.

Config:

Most config options are identical to those used in fmriprep, and so documentation can be found here https://fmriprep.org/en/20.2.6/usage.html.

The following additional arguments control how the gear code behaves. Note: arguments that start with "gear-" are not passed to fMRIPrep.

gear-run-bids-validation (optional)

Gear argument: Run bids-validator after downloading BIDS formatted data. Default is false.

gear-log-level (optional)

Gear argument: Gear Log verbosity level (ERROR|WARNING|INFO|DEBUG)

gear-save-intermediate-output (optional)

Gear argument: The BIDS App is run in a "work/" directory. Setting this will save ALL contents of that directory including downloaded BIDS data. The file will be named "work_.zip"

gear-intermediate-files (optional)

Gear argument: A space separated list of FILES to retain from the intermediate work directory. Files are saved into "work_selected_.zip"

gear-intermediate-folders (optional)

Gear argument: A space separated list of FOLDERS to retain from the intermediate work directory. Files are saved into "work_selected_.zip"

gear-dry-run (optional)

Gear argument: Do everything except actually executing the BIDS App.

gear-keep-output (optional)

Gear argument: Don't delete output. Output is always zipped into a single file for easy download. Choose this option to prevent output deletion after zipping.

gear-keep-fsaverage (optional)

Keep freesurfer/fsaverage* directories in output. These are copied from the freesurfer installation. Default is to delete them.

gear-FREESURFER_LICENSE (optional)

Gear argument: Text from license file generated during FreeSurfer registration. Copy the contents of the license file and paste it into this argument.

Troubleshooting

Resources

fMRIPrep can require a large amount of memory and disk space depending on the number of acquisitions being analyzed. There is also a trade-off between the cost of analysis and the amount of time necessary. There is a helpful discussion of this in the FAQ and also on NeuroStars. At the top of your job log, you should see the configuration of the virtual machine you are running on. When a job finishes, the output of the GNU time command is placed into the "Custom Information" (metadata) on the analysis. To see it, go to the "Analyses" tab for a project, subject, or session, click on an analysis and then on the "Custom Information" tab.

Metadata

Depending upon your fMRIPrep workflow preferences, a variety of metadata and files may be required for successful execution. And because of this variation, not all cases will be caught during BIDS validation. If you are running into issues executing bids-fmriprep, we recommend reading through the configuration options explained with the fMRIPrep Usage Notes and double-checking the following:

Fieldmaps (BIDS specification)

  • Phase encoding directions for fieldmaps and bold must be opposite.

    • Look for the PhaseEncodingDirection key in the file metadata (or exported JSON sidecar) and note the value (e.g., j-). If the fieldmap and the bold series it is IntendedFor do not have opposite PhaseEncodingDirection, fMRIPrep will error out with "ValueError: None of the discovered fieldmaps has the right phase encoding direction." BIDS specification details can be found here. For more information see discussions here and here.
    • To fix this, you can either write in "fieldmaps" into the "ignore" configuration option for the bids-fmriprep Gear, which will ignore using fieldmaps during the fMRIPrep workflow, or if you collected your data with opposite phase encodings, you can update the values for the PhaseEncodingDirection key as appropriate.
  • IntendedFor field needs to point to an existing file.

    • There are two places where the IntendedFor file metadata is required for bids-fmriprep.
    • The structure of the metadata in Flywheel should be similar to the following:
{
   "BIDS":{
      "Acq":"",
      "Dir":"",
      "error_message":"",
      "Filename":"sub-123_ses-01_fieldmap.nii.gz",
      "Folder":"fmap",
      "ignore":false,
      "IntendedFor":[
         {
            "Folder":"func"
         }
      ],
      "Modality":"fieldmap",
      "Path":"sub-123/ses-01/fmap",
      "Run":"",
      "template":"fieldmap_file",
      "valid":true
   },
   "IntendedFor":[
      "ses-01/func/sub-123_ses-01_task-stroop_run-02_bold.nii.gz",
      "ses-01/func/sub-123_ses-01_task-stroop_run-01_bold.nii.gz"
   ],
   "PhaseEncodingDirection":"j-",
   "TotalReadoutTime":0.123
}
  • Note: PhaseEncodingDirection and TotalReadoutTime are typically required.

Functional (BIDS specification)

  • Each functional NIfTI needs the following metadata: EchoTime, EffectiveEchoSpacing, PhaseEncodingDirection,RepetitionTime, SliceTiming, and TaskName.