HCP Pipelines BIDS App

This a BIDS App wrapper for HCP Pipelines. Like every BIDS App it consists of a container that includes all of the dependencies and run script that parses a BIDS dataset. BIDS Apps run on Windows, Linux, Mac as well as HCPs/clusters.

To convert DICOMs from your HCP-Style (CMRR) acquisitions to BIDS try using heudiconv with this heuristic file.

Description

The HCP Pipelines product is a set of tools (primarily, but not exclusively, shell scripts) for processing MRI images for the Human Connectome Project. Among other things, these tools implement the Minimal Preprocessing Pipeline (MPP) described in Glasser et al. 2013.

This BIDS App requires that each subject has at least one T1w and one T2w scan. Lack fMRI or dMRI scans is handled robustly. Note that while anatomicals (T1w, T2w scans) can be processed without a fieldmap, a fieldmap is mandatory for processing fMRI scans.

Documentation

Release Notes, Installation, and Usage

How to report errors

Discussion of HCP Pipeline usage and improvements can be posted to the hcp-users discussion list. Sign up for hcp-users at http://humanconnectome.org/contact/#subscribe

Acknowledgements

Please cite Glasser et al. 2013 and Smith et al. 2013.

Usage

This App has the following command line arguments:

PS C:\Users\filo> docker run -ti --rm -v /c/Users/filo/hcp_example_bids:/bids_dir:ro -v /c/Users/filo/test_output:/output bids/hcppipelines --help
usage: run.py [-h]
              [--participant_label PARTICIPANT_LABEL [PARTICIPANT_LABEL ...]]
              [--n_cpus N_CPUS]
              [--stages {PreFreeSurfer,FreeSurfer,PostFreeSurfer,fMRIVolume,fMRISurface,DiffusionPreprocessing} [{PreFreeSurfer,FreeSurfer,PostFreeSurfer,fMRIVolume,fMRISurface,DiffusionPreprocessing} ...]]
              --license_key LICENSE_KEY [-v]
              bids_dir output_dir {participant}

HCP Pipeliens BIDS App (T1w, T2w, fMRI)

positional arguments:
  bids_dir              The directory with the input dataset formatted
                        according to the BIDS standard.
  output_dir            The directory where the output files should be stored.
                        If you are running group level analysis this folder
                        should be prepopulated with the results of
                        theparticipant level analysis.
  {participant}         Level of the analysis that will be performed. Multiple
                        participant level analyses can be run independently
                        (in parallel) using the same output_dir.

optional arguments:
  -h, --help            show this help message and exit
  --participant_label PARTICIPANT_LABEL [PARTICIPANT_LABEL ...]
                        The label of the participant that should be analyzed.
                        The label corresponds to sub-<participant_label> from
                        the BIDS spec (so it does not include "sub-"). If this
                        parameter is not provided all subjects should be
                        analyzed. Multiple participants can be specified with
                        a space separated list.
  --n_cpus N_CPUS       Number of CPUs/cores available to use.
  --stages {PreFreeSurfer,FreeSurfer,PostFreeSurfer,fMRIVolume,fMRISurface,DiffusionPreprocessing} [{PreFreeSurfer,FreeSurfer,PostFreeSurfer,fMRIVolume,fMRISurface,DiffusionPreprocessing} ...]
                        Which stages to run. Space separated list.
  --license_key LICENSE_KEY
                        FreeSurfer license key - letters and numbers after "*"
                        in the email you received after registration. To
                        register (for free) visit
                        https://surfer.nmr.mgh.harvard.edu/registration.html
  -v, --version         show program's version number and exit

To run it in participant level mode (for one participant):

docker run -i --rm \
-v /Users/filo/data/ds005:/bids_dataset:ro \
-v /Users/filo/outputs:/outputs \
bids/hcppipelines \
/bids_dataset /outputs participant --participant_label 01 --license_key "XXXXXX"

Commercial use

In addition to FreeSurfer the following non-free Debian packages are part of this BIDS App:

non-free/science        fsl-5.0-core
non-free/science        fsl-5.0-eddy-nonfree
non-free/science        fsl-atlases
non-free/science        fsl-bangor-cerebellar-atlas
non-free/science        fsl-core
non-free/science        fsl-harvard-oxford-atlases
non-free/science        fsl-harvard-oxford-cortical-lateralized-atlas
non-free/science        fsl-jhu-dti-whitematter-atlas
non-free/science        fsl-juelich-histological-atlas
non-free/science        fsl-mni-structural-atlas
non-free/science        fsl-mni152-templates
non-free/science        fsl-oxford-striatal-atlas
non-free/science        fsl-oxford-thalamic-connectivity-atlas
non-free/science        fsl-resting-connectivity-parcellation-atlases
non-free/science        fsl-subthalamic-nucleus-atlas
non-free/science        fsl-talairach-daemon-atlas

If you are considering commercial use of this App please consult the relevant licenses.

TODO

  • Add DiffusionProcessing stage
  • More testing for fMRI with different resolution
  • Run fMRI runs in parallel (when n_cpus present)
  • Add support for TOPUP and GE fieldmaps for structural scans (please get in touch if you can provide sample data)
  • Add support for Siemens and GE fieldmaps for fMRI scans (please get in touch if you can provide sample data)
  • Avoid copying fsaverage folder for every participant
  • Add ICA FIX stage
  • Add group level analysis
  • Add task fMRI model fitting