Skip to main content

Use this gear to initialize BIDS filenames and attributes on all files within a given project.

Project description

BIDS Curation (curate-bids)

Overview

This is a Flywheel Gear that curates a Flywheel project according to the BIDS Specification.

This gear uses a "project curation template" to detect acquisition files and map them to the BIDS Specification. The base curation template is chosen as a configuration option. The "ReproIn" template is recommended and it is the default. This template assumes you used the ReproIn naming convention when setting up your protocol.

Using the ReproIn template for projects containing subjects, sessions, and acquisitions named according to the ReproIn spec means that BIDS curation in Flywheel can proceed very close to automatically. The best place to start this is at the scanner console by setting the proper value for the SeriesDescription DICOM tag.

See this Siemens Prisma 3T walkthrough as an example of how to use the ReproIn naming convention.

The version number of this gear has the form of major.minor.patch_major.minor.patch where the first triplet of numbers (before the underscore) refers to this gear and the second refers to the version of the bids-client. Most of the functionality of this gear is provided by the bids-client.

BIDS curation is not difficult once a project is set up properly, however, setting everything up can take time. Proper setup requires attention to detail and some information about the project's scan protocol.

See Flywheel + BIDS: Getting Started for complete details on setting up and running BIDS curation.

Usage

FAQ

Summary

Use this gear to set the BIDS paths and filenames on all files within a given project.

License

MIT

Classification

Category: Analysis

Gear Level:

  • Project
  • Subject
  • Session
  • Acquisition
  • Analysis

[[TOC]]


Inputs

  • Optional
    • Name: template
    • Type: json
    • Optional: True
    • Classification: source code
    • Description: If provided, this JSON file will either extend a base template, or it can completely override all other templates. If there is a top-level attribute of "extends", the value must be either "bids-v1", "reproin", or "default" and that base template will be extended. If it does not have "extends", then the file must be a complete BIDS specification template, and it will be used all by itself. The base templates are in the BIDS Client repository.
    • Notes: If a template is provided here as an input, the base_template configuration parameter is ignored.

Config

  • base_template

    • Name: base_template
    • Type: either ReproIn or BIDS-v1 (for backwards compatibility).
    • Description: Which base project curation template to use.
    • Default: ReproIn
  • intendedfor_regexes

    • Name: intendedfor_regexes
    • Type: space-separated strings.
    • Description: A list of pairs of regular expressions. The first regex matches the field map acquisition label and the second matches the IntendedFor BIDS path. Initial processing sets the list of IntendedFor paths to all files in the different 'anat', 'func', and 'dwi' BIDS folders. These regex pairs should be used to filter that list so that only the appropriate IntendedFor paths remain. Multiple pairs of regexes can be included. All regexes should be separated by a single space.
    • Default: None
  • reset

    • Name: reset
    • Type: boolean
    • Description: Remove all BIDS info from files before curating.
    • Default: (unchecked) do not reset the curation
    • Warning: If you have manually selected any container or file to be ignored by checking the "bids ignore" flag in the BIDS Custom Information metadata, reset will remove that also, so you will need to do that again if it is important to you. A more permanent way of ignoring files is to add "_ignore-BIDS" at the end of an acquisition container's label (the acquisition that contains the files to be ignored). Note that this functionality depends on the project curation template: it must implement this feature by setting the ignore flag on the container (session or acquisition) to be ignored.
  • save_sidecar_as_metadata

    • Name: save_sidecar_as_metadata
    • Type: boolean
    • Description: Instead of assuming sidecar data is in actual json sidecar, put it in file.info metadata (a.k.a. "Custom Information"). This is the old behavior for this gear and BIDS Curation on Flywheel.
    • Default: False: the new behavior is to assume that the dcm2niix gear created a real json sidecar and did not add that information as metadata on the NIfTI file.
  • use_or_save_config

    • Name: use_or_save_config
    • Type: either leave blank or choose 'Save Config', 'Use Config', or 'Stop Using Config'.
    • Description: Use previously saved inputs and configuration. If you choose 'Save Config', the current configuration will be saved at the current run level (on the session, subject, or project container) in a file called 'curate-bids-[level]-config.json', and it will be used by default on subsequent runs of this gear to set the configuration. If you choose 'Use Config', that file will be ignored if present, and the currently set configuration will be used. The default is to do neither, which will use the saved curate-bids-config.json file if it is present and to use the current configuration if not. For example, using the 'Save Config' option one time while providing an input template, that template will be used by default for future runs. If you choose 'Stop Using Config', the gear will disable the curation file and then quit without curating.
    • Default: blank -- use saved config file if present
  • verbosity

    • Name: verbosity
    • Type: either INFO or DEBUG
    • Description: Set this to DEBUG to see exactly what is happening to help with figuring out BIDS curation.
    • Default: INFO

Outputs

BIDS Metadata

The main "outputs" of this gear are Custom Information metadata written to the "BIDS" namespace in all containers and files. The gear does not actually create BIDS formatted data directly. That happens when exporting data in BIDS format using the CLI and also as the first step in running a BIDS Application gear. The BIDS metadata controls if and how NIfTI files and json sidecars are created following the BIDS Specification. Because of this, any changes you make by manually editing BIDS metadata will override what this gear has done. See the note above about the "reset" option: if you re-run this gear with reset on, manual changes will need to be made again.

5 CSV Files

  • CSV Files
    • Names:
      • [group]_[project]_acquisitions.csv
      • [group]_[project]_acquisitions_details_1.csv
      • [group]_[project]_acquisitions_details_2.csv
      • [group]_[project]_intendedfors.csv
      • [group]_[project]_niftis.csv
    • Type: comma separated values
    • Description: This gear will save a "report" on the state of BIDS curation in the form of a collection of .csv files. Note that the gear may include a log message saying it was run successfully even though the BIDS curation might not have been properly completed. The only way to know if curation was successful is to examine the .csv files in detail. See BIDS Curation Tutorial Part 4: Interpreting the Curation Report to understand the information provided by the .csv files.

Pre-requisites

Prerequisite Gear Runs

Before running this BIDS curation gear, 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 information and stores it as Flywheel Metadata.
  2. Run the DCM2NIIX: dcm2nii DICOM to NIfTI converter gear on all the acquisitions in your project. This step generates the NIfTI files that BIDS Applications need from the DICOMS. It also copies all Flywheel metadata from the DICOM to the NIfTI file (the DICOM header information we extracted in step 1).
  3. Only then can you run this gear on the project.

More information about BIDS Curation on Flywheel can be found here. If you need to rename acquisitions, sessions or subjects before curation, use this gear: relabel-container.

Usage

To run this gear, select a subject, session, or even the project. To do this, find the "Run Analysis Gear" or "Run Gear" button for the desired level of the hierarchy. If you run at the project level, it will curate the entire project. Running at the subject level will curate all containers and files in that subject. Running on an individual session will only curate that session. If running at the subject or project level and some subjects or sessions have already been curated, see the description and warning about the "reset" configuration parameter below. Detailed instructions on running this gear at a specific level are in "Running the BIDS Curation Gear"

This gear is an analysis gear so if you run this gear on a session by starting with the "Run Gear" button, be sure to select the "Analysis Gear" type, not "Utility Gear".

Workflow

This gear does two "template processing" passes through the Flywheel hierarchy. The first time it steps through each container starting at the project level and then through each subject, session, and acquisition. It sets BIDS metadata on all files as determined by the project curation template. The second pass (after all file paths and names have been set) resolves the IntendedFor lists as determined by the field map definition in the project curation template.

Finally, the report csv files are generated. For IntendedFors, the lists produced by the two template processing passes is generated and then the intendedfor_regexes are applied and the remaining IntendedFor lists are generated.

Logging

The gear log describes each step of the gear run. It lists each container and describes the rules that match. Finally, it reports the number of containers and files that were curated and lists any duplicated BIDS path/names.

FAQ

FAQ.md

Contributing

See CONTRIBUTING.md.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

fw_curate_bids-2.2.9-py3-none-any.whl (23.0 kB view details)

Uploaded Python 3

File details

Details for the file fw_curate_bids-2.2.9-py3-none-any.whl.

File metadata

  • Download URL: fw_curate_bids-2.2.9-py3-none-any.whl
  • Upload date:
  • Size: 23.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.9 Linux/5.15.154+

File hashes

Hashes for fw_curate_bids-2.2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 4db51e8151db49240a3a199c1da62508be3b68dd92e8352774c51a2353e88156
MD5 ac264f7c735565ae7e0cd71ef1464836
BLAKE2b-256 b198801c3e8b70c422c96684f8a678aea581637e14d19f7e6d6cabe372e3bb5c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page