diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 0000000..e69de29 diff --git a/404.html b/404.html new file mode 100644 index 0000000..f7206d8 --- /dev/null +++ b/404.html @@ -0,0 +1,331 @@ + + + +
+ + + + + + + + + + + + + +Neuroimaging is a field with an enormous library of powerful tools +and openly available datasets that can be difficult to get to work together.
+The Brain Imaging Data Structure (BIDS) is a community-driven +standardized data organization protocol that gives analysis tools a common +specification for data input, see this link. BIDS solves the dataset complexity +problem by providing a consistent representation for data sharing and adoption.
+While BIDS is great for +standardizing datasets, analytical tools can take a variety of forms, arguments, +and complexities, limiting their ability to be applied interchangeably. The BIDS +Application Specification solves this problem by creating a community-driven +standardized structure for software definitions and their execution.
+This document is a draft for the BIDS Application +specification for the purposes of tool description, provenance and +reproducibility. This is a working document in draft stage and any comments are +welcome. This document inherits all components of the original specification +(e.g. how to store imaging data, events, stimuli and behavioral data), and +should be seen as an extension of it, not a replacement.
+There are many open comments on the document, and all of them +would benefit from your input. As you read this document, please feel free to +ask questions, complete remaining tasks, or reach out to any of the listed +contributors and moderators.
+ + + + + + +Neuroimaging is a field with an enormous library of powerful tools and openly available datasets that can be difficult to get to work together.
"},{"location":"index.html#what-is-bids","title":"What is BIDS?","text":"The Brain Imaging Data Structure (BIDS) is a community-driven standardized data organization protocol that gives analysis tools a common specification for data input, see this link. BIDS solves the dataset complexity problem by providing a consistent representation for data sharing and adoption.
"},{"location":"index.html#so-why-do-we-need-the-bids-application-specification","title":"So why do we need the BIDS Application Specification?","text":"While BIDS is great for standardizing datasets, analytical tools can take a variety of forms, arguments, and complexities, limiting their ability to be applied interchangeably. The BIDS Application Specification solves this problem by creating a community-driven standardized structure for software definitions and their execution.
"},{"location":"index.html#what-is-this-document","title":"What is this document?","text":"This document is a draft for the BIDS Application specification for the purposes of tool description, provenance and reproducibility. This is a working document in draft stage and any comments are welcome. This document inherits all components of the original specification (e.g. how to store imaging data, events, stimuli and behavioral data), and should be seen as an extension of it, not a replacement.
"},{"location":"index.html#how-can-i-help","title":"How can I help?","text":"There are many open comments on the document, and all of them would benefit from your input. As you read this document, please feel free to ask questions, complete remaining tasks, or reach out to any of the listed contributors and moderators.
"},{"location":"CONTRIBUTING.html","title":"Contributing to the BIDS-Apps specification","text":""},{"location":"CONTRIBUTING.html#extension-leads","title":"Extension leads","text":"While the BIDS format is great for standardizing datasets, analytical tools operating on that structure can take a variety of forms, arguments, and complexities, limiting their ability to be applied interchangeably. The BIDS Application Specification solves this problem by creating a community-driven standardized structure for software definitions and their execution.
This specification extends the Brain Imaging Data Structure (BIDS) Specification to describe how software pipelines and analytic tools should interact with BIDS-formatted datasets. These tools will be referred to as \"BIDS Apps\" or \"BIDS Applications\", and can accept any valid BIDS dataset prior to producing some result (including a message of inaction, as may be applicable in some cases).
"},{"location":"specification.html#goals-of-bids-applications","title":"Goals of BIDS Applications","text":"This extension is motivated by a desire to automatically and reproducibly process neuroscientific data. It seeks to specify file types and metadata for describing the execution of command-line programs that operate upon BIDS datasets. Graphical and web-based interfaces are outside the scope of this extension, though it is expected that this specification will simplify the integration of BIDS datasets and applications into such platforms.
This is guided by the following requirements and desiderata:
The core principles of the original BIDS-Raw specification are inherited by the BIDS Application specification. This specification is a successor to BIDS-Apps, which were described in Gorgolewski, et al. 2017 (doi:10.1371/journal.pcbi.1005209), here referred to as BIDS-Apps 1.0. Backwards compatibility with BIDS-Apps 1.0 is not an explicit goal, but can be achieved in many cases as is discussed in Section 3.1.2.1. A summary of changes from BIDS-Apps 1.0 is included as Appendix A.
This specification is seen as complementary to BIDS-Derivatives, which is part of BIDS as of version 1.4.0, and the most recent stable version may be found at https://bids-specification.readthedocs.io/en/stable/05-derivatives/01-introduction.html. It is not required that every BIDS Application produce a BIDS-Derivatives-compliant result dataset, but any outputs that may be required by the BIDS Application specification must be compliant with the BIDS-Derivatives specification.
Please refer to general BIDS specification document for context and general guidelines (definitions, units, directory structure, missing values, stimulus and event information, etc.): https://bids-specification.readthedocs.io/en/stable/
The keywords \"MUST\", \"MUST NOT\", \"REQUIRED\", \"SHALL\", \"SHALL NOT\", \"SHOULD\", \"SHOULD NOT\", \"RECOMMENDED\", \"MAY\", and \"OPTIONAL\" in this document are to be interpreted as described in [RFC2119.
The terminology that will be used is inherited from BIDS-Raw and includes the following:
There are three domains of requirements that BIDS Applications must specify: (1) User interface components; (2) Required application behaviors; (3) Required application outputs.
BIDS contains \"required\", \"recommended\" and \"optional\" fields. These are indicated throughout the document:
Ultimately, through using Boutiques to define tools and their parameters, the goal is that each tool can be interacted with as follows:
$ # Using Boutiques directly, the \"exec launch\" commands will run the app\n $ bosh exec launch bids-app --invocation input_params.json\n $ # Eventually, we envision that BIDS Application interface will also support\n $ # simple, lightweight overrides to provide some of these common values via\n $ # the command line directly.\n $ bids-launch bids-app --input-dataset /path/to/bids /path/to/derivatives \\\n --output-location /path/to/output \\\n --analysis-level subject--subject-label 01 02 \\\n --random-seed 0xBID5CAFE\n
In the next sections, the bids-app
tool, a Boutiques descriptor, and the input_params.json
, a set of invocation parameters corresponding to this app, will be defined.
A uniform user interface is essential to scalable deployment of BIDS Applications. This section describes the common interface components that may be relied upon by users or platforms running these applications (callers). Command-line interfaces map between positional or flag arguments provided through an interactive shell program (e.g. Bash) to a program and program behavior. However, tools written in different languages or following different conventions may represent and parse these arguments distinctly. For the purposes of automated execution of diverse tools, a more useful interface is a mapping of parameter identifiers to their values, abstracting the way they are represented on the command-line (CLI). Boutiques is a standard developed for this mapping. Boutiques provides a JSON schema and related tools to describe, validate, execute and share command-line tools, among other utilities. The Boutiques toolkit, named bosh, will be referred to when discussing examples throughout this specification.
Instead of requiring specific positional arguments and flags which assign common names to expected options (e.g., \"subject-label\") in the command-line interfaces themselves, BIDS Applications should provide a Boutiques descriptor \u2014 a standardized JSON file that describes the command line behavior and operation of a tool \u2014 that map the tool-specific common arguments to these common names, without requiring rewriting of the command-line tools. In the sections below, the identifiers assigned in the Boutiques descriptor are described in the \"Argument ID\" column of relevant tables.
The Boutiques descriptor for a program SHOULD be retrievable by calling the application with the --bids-exec-spec
flag and no other arguments.
A human-readable schema for a Boutiques descriptor may be found at https://github.com/boutiques/boutiques/blob/0.5.25/schema/README.md. This section attempts to summarize the salient points of that document, but the Boutiques schema is authoritative and complete. In addition to the Boutiques fields (see Tables 1\u20134, 6), BIDS conformant descriptors MUST include a custom object (see Table 2) containing the BIDSApplicationVersion key and associated value which indicates the version of the BIDS application specification to which they conform, together with some additional optional fields. Descriptors SHOULD be simply named as name.json.
Table 1: List of relevant base Boutiques properties and their role within BIDS Applications. Field name Definitioncommand-line
REQUIRED. String. A template string including the command and references to the value-keys of all possible inputs. The ordering imposed here may be significant, in particular for non-optional arguments. custom
REQUIRED. Object. Object which can contain extensible metadata. This has a single required element, as described in Table 2. inputs
REQUIRED. List. List of objects which contain input parameter definitions. Described in Table 3. name
REQUIRED. String. The name of the BIDS Application. output-files
REQUIRED. List. List of objects which contain output parameter definitions. Described in Table 6. schema-version
REQUIRED. String. Boutiques schema version. Must be \"\u22650.5\". This is not to be confused with the BIDS Application schema and associated version. tool-version
REQUIRED. String. Version of the BIDS Application. description
RECOMMENDED. String. A plain-text description of the BIDS Application. descriptor-url
RECOMMENDED. String. Link to the descriptor itself. Likely a GitHub repo alongside the described tool, for example. doi
RECOMMENDED. String. DOI of the descriptor returned once published via Boutiques. (Note: This is not the DOI of the tool itself.) suggested-resources
RECOMMENDED. Object. Contains an execution walltime-estimate in seconds, memory usage in MB, and CPU/GPU usage in number of core threads/devices. container-image
OPTIONAL. Object. The name and location of a container image, such as those in Docker or Singularity formats, containing the configured application. error-codes
OPTIONAL. List. List of objects that contain error code information. The reserved error conditions are described in Table 7. groups
OPTIONAL. List. List of objects that contain relational information among input parameters as described in Table 4. This is not to be confused with any other BIDS-relevant definition of groups. The custom
object has the following defined fields for use in the context of BIDS Applications:
BIDSAppSpecVersion
REQUIRED. String. The version of the BIDS application specification with which the application complies. OutputDataSpecification
OPTIONAL. List. If output data conforms to a standard definition (e.g. NIDM-1.1.0), these data standards may be included as a list of strings. <unspecified>
OPTIONAL. Any. Any key referring to arbitrary metadata that may be relevant or of interest to the application and its users."},{"location":"specification.html#input-specification","title":"Input specification","text":"Inputs to BIDS apps may be specified as JSON objects that map input ids to values. The objects found within the required inputs list have the following fields, described fully in https://github.com/boutiques/boutiques/blob/0.5.25/schema/README.md#inputs (source):
Table 3: List of relevant inputs object properties for the BIDS Application specification. Field name Definitioncommand-line-flag
OPTIONAL. String. For non-positional arguments, the flag which is associated with the argument on the command-line. id
REQUIRED. String. The argument ID. Alphanumeric values and underscores only. CamelCase is recommended. list
OPTIONAL. Boolean. Indicates whether or not the input field is a list of inputs. One of {true, false}
. If omitted, it will be interpreted as false (e.g., non-list input). name
REQUIRED. String. Plain text name of input for display. Can contain spaces. optional
OPTIONAL. Boolean. Indicates whether or not the input field is required. One of {true, false}
. If omitted, will be interpreted as false (e.g. non-optional input). type
REQUIRED. String. One of {\"String\", \"File\", \"Flag\", \"Number\"}
. value-choices
OPTIONAL. List. List of possible values that the parameter may take. value-key
OPTIONAL. String. String to replace in command-line template string. If specified, this MUST NOT be either a superset or subset of the value-key attribute associated with another object in the descriptor; to ensure this, brackets are typically used (e.g. \"[value]\"). In addition to describing inputs themselves, groups of inputs and their relationships can be defined as follows in Table 4:
Table 4: List of group object properties and their role within the BIDS Application specification. Field name Definitionall-or-none
OPTIONAL. Boolean. True if all parameters included in this group need to be included together.. description
RECOMMENDED. String. Description of the input group. id
REQUIRED. String. A short, unique, informative identifier containing only alphanumeric characters and underscores. members
REQUIRED. List. IDs of the input parameters belonging to this group. mutually-exclusive
OPTIONAL. Boolean. True if only one input in the group may be selected at runtime. name
REQUIRED. String. A human-readable name for the input group. one-is-required
OPTIONAL. Boolean. True if at least one of the inputs in the group must be selected."},{"location":"specification.html#required-arguments","title":"Required arguments","text":"BIDS Applications MUST provide the following arguments. Notes that \"Argument ID\" is what is required to exist as the state \"id\" in the Boutiques descriptor, and will be validated, while the example CLI Flag provides a possible way this could be expressed in the tool's interface.
Table 5: List of custom object properties and roles within the BIDS Application specification. Argument ID e.g. CLI Flag DefinitionAnalysisLevel
--analysis-level
REQUIRED. String. String with value-choices which are a subset of {run, session, subject, dataset, meta}. The app may support one or more of these analysis levels. A default may be set, and unsupported analysis levels should return an exit code of 17, consistent with the definition in Table 7. Help
--help
REQUIRED. Flag. Flag that specifies whether or not to show the help-text that describes how the tool may be correctly used. InputDataset
--input-dataset
REQUIRED. List. List of URIs/paths of the BIDS datasets to be processed. Whether or not the order of listed datasets is important MUST be specified in the parameter description. The tool MUST NOT reorder the user-specified list. OutputLocation
--output-location
REQUIRED. List. One URI/path to the location where all outputs will be stored. ToolVersion
--version
REQUIRED. Flag. Returns the version of the tool being used."},{"location":"specification.html#backwards-compatibility","title":"Backwards compatibility","text":"If an app wishes to maintain backwards compatibility with BIDS-Apps 1.0, then the following command-line should be valid:
bids-app InputDataset OutputLocation AnalysisLevel [options]\n
In this case, InputDataset is limited to a list of length one. It is worth noting that all legacy apps can be supported in this spec, they just need to write a descriptor which maps the inputs as they are expected and defined, here, to their associated values in the original application.
"},{"location":"specification.html#reserved-arguments","title":"Reserved arguments","text":"The ability to filter BIDS entities (e.g. subject, session, or run) allows for the selection of subsets of datasets. To be extensible as new entities are added to the BIDS specification, the reserved arguments are defined here as a rule which maps to BIDS entities, rather than specifying the moving goalpost of an exhaustive list. The arguments may be specified as follows:
While several examples exist within Table 5, to the following demonstrates how the above rules can be applied for the BIDS entity \"subject\":
ID: SubjectLabel
CLI flag: --subject-label
Acceptable and equivalent usages:
--subject-label 01 02 03\n --subject-label subject_ids.txt\n
_Contents of subject_ids.txt
:
01\n02\n03\n
In all cases where such arguments are defined and applied, only files in the BIDS dataset that have a value for the specified entities will be subject to filtering. That is, if a file does not have a given entity (e.g., entity value for it is <None>), the file will be included.
Applications are not required to support these arguments, but MUST NOT assign these arguments to other meanings. To reduce conflicts, BIDS Applications SHOULD avoid using this convention except for entities that are anticipated to be standardized.
Example of an Interface descriptor: see 4.1.
For example, suppose we have an application with the following descriptor:
example_app.json
:
{\n\"name\": \"Example BIDS App\",\n\"command-line\": \"bids-app [InputDataset] [OutputLocation] [AnalysisLevel] [ParticipantLabel] [OurRandomSeed]\"\"inputs\": [\n{\n\"id\": \"InputDataset\",\n\"name\": \"Input datasets\",\n\"value-key\": \"[InputDataset]\",\n\"type\": \"File\",\n\"list\": true,\n\"optional\": false,\n\"command-line-flag\": \"--input-datasets\"\n},\n{\n\"id\": \"OutputLocation\",\n\"name\": \"Output location\",\n\"value-key\": \"[OutputLocation]\",\n\"type\": \"File\",\n\"optional\": false,\n\"command-line-flag\": \"--output-location\"\n},\n{\n\"id\": \"AnalysisLevel\",\n\"name\": \"Analysis level\",\n\"value-key\": \"[AnalysisLevel]\",\n\"type\": \"String\",\n\"optional\": false,\n\"value-choices\": [\n\"run\",\n\"session\",\n\"subject\",\n\"dataset\"\n],\n\"default\": \"session\",\n\"command-line-flag\": \"--analysis-level\"\n},\n{\n\"id\": \"SubjectLabel\",\n\"name\": \"Subject labels\",\n\"value-key\": \"[SubjectLabel]\",\n\"type\": \"String\",\n\"list\": true,\n\"optional\": true,\n\"command-line-flag\": \"--subject-label\"\n},\n{\n\"id\": \"RandomSeed\",\n\"name\": \"Seed for pseudorandom number generator\",\n\"value-key\": \"[RandomSeed]\",\n\"type\": \"Number\",\n\"optional\": true,\n\"command-line-flag\": \"--random-seed\"\n}\n]\n}\n
input_params.json
{\n\"InputDataset\": [\"/path/to/bids\", \"/path/to/derivatives\"],\n\"OutputLocation\": \"/path/to/output\",\n\"AnalysisLevel\": \"subject\",\n\"SubjectLabel\": [\"01\", \"02\"],\n\"RandomSeed\": \"0xB1D5CAF3\"\n}\n
"},{"location":"specification.html#outputs","title":"Outputs","text":""},{"location":"specification.html#file-formats-for-the-application-specification-and-report","title":"File formats for the application specification and report","text":"BIDS Apps MUST be able to be called via the BIDS Application Boutiques descriptor and corresponding input parameter dictionary files, commonly referred to in the Boutiques parlance as \"invocations\", and accept any BIDS dataset. It is RECOMMENDED that BIDS Applications produce BIDS-Derivatives-compliant datasets.
Table 6: List of relevant output-files object properties for the BIDS Application specification. Field name Definitioncommand-line-flag
OPTIONAL. String. Flag associated with the argument on the command-line. Examples: -o, --output description
RECOMMENDED. String. A plain-text description of the output-files of the BIDS Application. file-template
OPTIONAL. Array of strings. An array of strings that may contain value keys and together populate the self-contained structure of a configuration file. id
REQUIRED. String. A short, unique, informative identifier containing only alphanumeric characters and underscores. Typically used to generate variable names. (should conform ^[0-9,_,a-z,A-Z]*$
). Example: \"data_file\" list
OPTIONAL. Boolean. True if output is a list of values. name
REQUIRED. String. A human-readable output name. Example: 'Supplementary input file for X task'. optional
OPTIONAL. Boolean. True if output may not be produced by the tool. path-template
OPTIONAL. String. Describes the output file path relative to the execution directory. May contain input value keys and wildcards. Example: \"xx\". path-template-stripped-extensions
OPTIONAL. List. List of file extensions that will be stripped from the input values before being substituted in the path template. Example: [\".nii\",\".nii.gz\"]. value-key
OPTIONAL. String. A string contained in command-line, substituted by the output value and/or flag at runtime."},{"location":"specification.html#execution-report-updating-dataset-description","title":"Execution Report & Updating Dataset Description","text":"When generated, an execution report that completely describes the processing that was executed and the dataset MUST comply with the BIDS Provenance Extension Proposal (BEP28). These outputs are OPTIONAL, and if provided, should be specified in the output-files
section of the tool descriptor.
Similarly, the dataset_description.json file SHOULD be updated to reflect the processing that has occurred by the BIDS Application.
"},{"location":"specification.html#behaviors","title":"Behaviors","text":"For a given set of arguments, the behavior of a BIDS Application will typically vary based on the contents of the input dataset. The dataset may be BIDS-compliant, or it may not; and it may contain the file types the BIDS App requires, or it may not. This section describes the expected behavior under each combination of cases, and describes RECOMMENDED exit codes on systems that support them.
"},{"location":"specification.html#valid-bids-datasets","title":"Valid BIDS datasets","text":"If the dataset is BIDS-compliant and contains the files required by the application, then the application should make a best effort to perform its task to completion.
If the dataset is BIDS-compliant but does not contain the files required by the application, then the application MAY fail immediately or when attempting to open a missing file. In this case, it is RECOMMENDED to use exit code 66 (NOINPUT).
"},{"location":"specification.html#invalid-bids-datasets","title":"Invalid BIDS datasets","text":"If the dataset is not BIDS-compliant, then the BIDS App MAY fail immediately with exit code 16.
If the dataset contains the required files but is not BIDS-compliant (e.g., a \"dirty\" dataset that has more files than needed), then the BIDS App MAY treat the dataset as valid.
"},{"location":"specification.html#exit-codes","title":"Exit codes","text":"An exit code or exit status is an integer indicating the reason for termination for use by the parent program or operating system. The interpretation of exit codes varies across systems, and programmers SHOULD follow the conventions of the systems for which they are programming.
Most operating systems, including POSIX (Linux, Mac OSX) and Windows use 0 to indicate success and >0 to indicate failure. POSIX systems are limited to an unsigned byte (range: 0-255), so these recommendations are limited to that range. Exit codes 64-78 are specified in BSD sysexits(3), and should be avoided unless applicable. Exit codes 2 and 126-165 may be set by Bash, and so will be reserved.
The following exit codes are RECOMMENDED for consistent error handling under POSIX and Windows environments:
Table 7: Reserved exit codes and their definitions. Exit code Definition0
SUCCESS. The program completed successfully. 1
FAILURE. The program failed for unspecified reasons. 2
Reserved 16-31
BIDS-related codes. Reserved except the following 16
An input dataset failed BIDS validation. 17
Unknown analysis level. 18
Entity-based filtering options selected no files. 19
Both command-line arguments and a parameter invocation file were passed to the application. 64-78
BSD codes - Reserved except the following. 64
USAGE. The command was used incorrectly. 65
DATAERR. The input data was incorrect in some way. 66
NOINPUT. The input data was missing or unreadable. 73
CANTCREAT. An output file/directory cannot be created. 74
IOERR. Failure during file reading/writing. 75
TEMPFAIL. Temporary failure. Another run is expected to succeed. 126-165
BASH codes - Reserved"},{"location":"specification.html#example-bids-app","title":"Example BIDS App","text":"This section describes a BIDS Application named bids-app that can only operate at the participant analysis leveland accepts a numeric seed for a random number generator.
"},{"location":"specification.html#interface-descriptor_1","title":"Interface descriptor","text":"{\n\"name\": \"Example BIDS App\",\n\"tool-version\": \"0.0.1\",\n\"schema-version\": \"0.5\",\n\"custom\": {\n\"BIDSApplicationVersion\": \"2.0\"\n},\n\"command-line\": \"bids-app [InputDataset] [OutputLocation] [AnalysisLevel] [ParticipantLabel] [RandomSeed]\",\n\"inputs\": [\n{\n\"id\": \"InputDataset\",\n\"name\": \"Input datasets\",\n\"value-key\": \"[InputDataset]\",\n\"type\": \"File\",\n\"list\": true,\n\"optional\": false,\n\"command-line-flag\": \"--input-dataset\"\n},\n{\n\"id\": \"OutputLocation\",\n\"name\": \"Output location\",\n\"value-key\": \"[OutputLocation]\",\n\"type\": \"File\",\n\"optional\": false,\n\"command-line-flag\": \"--output-location\"\n},\n{\n\"id\": \"AnalysisLevel\",\n\"name\": \"Analysis level\",\n\"value-key\": \"[AnalysisLevel]\",\n\"type\": \"String\",\n\"optional\": true,\n\"value-choices\": [\"participant\"],\n\"default-value\": \"participant\",\n\"command-line-flag\": \"--analysis-level\"\n},\n{\n\"id\": \"SubjectLabel\",\n\"name\": \"Participant labels\",\n\"value-key\": \"[ParticipantLabel]\",\n\"type\": \"String\",\n\"list\": true,\n\"optional\": true,\n\"command-line-flag\": \"--participant-label\"\n},\n{\n\"id\": \"OurRandomSeed\",\n\"name\": \"Seed for pseudorandom number generator\",\n\"description\": \"Example parameter that may be relevant.\",\n\"value-key\": \"[OurRandomSeed]\",\n\"type\": \"Number\",\n\"optional\": true,\n\"command-line-flag\": \"--random-seed\"\n}\n]\n}\n
"},{"location":"specification.html#invocation-definition","title":"Invocation definition","text":"Two example input definitions follow:
input_params1.json
{\n\"InputDataset\": [\"/path/to/bids\", \"/path/to/derivatives\"],\n\"OutputLocation\": \"/path/to/output\",\n\"AnalysisLevel\": \"participant\",\n\"SubjectLabel\": [\"01\", \"02\"],\n\"RandomSeed\": 2983578366\n}\n
input_params2.json
{\n\"InputDataset\": [\"/path/to/bids\", \"/path/to/derivatives\"],\n\"OutputLocation\": \"/path/to/output\",\n\"AnalysisLevel\": \"participant\"\n}\n
"},{"location":"specification.html#bids-app-compatible-example","title":"BIDS App compatible example","text":"Before the BIDS Application specification existed there were BIDS Apps. Attention has been paid to ensure that BIDS Exec apps can be compatible with existing BIDS Apps.
For example, the term participant was widely used in BIDS Apps, whereas subject is the preferred term in BIDS. To allow backwards compatibility here you can use:
{\n\"id\": \"SubjectLabel\",\n\"name\": \"Participant labels\",\n\"value-key\": \"[ParticipantLabel]\",\n\"type\": \"String\",\n\"list\": true,\n\"optional\": true,\n\"command-line-flag\": \"--participant-label\"\n}\n
"}]}
\ No newline at end of file
diff --git a/sitemap.xml b/sitemap.xml
new file mode 100644
index 0000000..6ec962d
--- /dev/null
+++ b/sitemap.xml
@@ -0,0 +1,18 @@
+
+While the BIDS format is great for standardizing datasets, analytical tools +operating on that structure can take a variety of forms, arguments, and +complexities, limiting their ability to be applied interchangeably. The BIDS +Application Specification solves this problem by creating a community-driven +standardized structure for software definitions and their execution.
+This specification extends the Brain Imaging Data Structure (BIDS) Specification +to describe how software pipelines and analytic tools should interact with +BIDS-formatted datasets. These tools will be referred to as "BIDS Apps" or "BIDS +Applications", and can accept any valid BIDS dataset prior to producing some +result (including a message of inaction, as may be applicable in some cases).
+This extension is motivated by a desire to automatically and reproducibly +process neuroscientific data. It seeks to specify file types and metadata for +describing the execution of command-line programs that operate upon BIDS +datasets. Graphical and web-based interfaces are outside the scope of this +extension, though it is expected that this specification will simplify the +integration of BIDS datasets and applications into such platforms.
+This is guided by the following requirements and desiderata:
+The core principles of the original BIDS-Raw specification are inherited by the +BIDS Application specification. This specification is a successor to BIDS-Apps, +which were described in Gorgolewski, et al. 2017 +(doi:10.1371/journal.pcbi.1005209), +here referred to as BIDS-Apps 1.0. Backwards compatibility with BIDS-Apps 1.0 is +not an explicit goal, but can be achieved in many cases as is discussed in +Section 3.1.2.1. A summary of changes from +BIDS-Apps 1.0 is included as +Appendix A.
+This specification is seen as complementary to BIDS-Derivatives, which is part +of BIDS as of version 1.4.0, and the most recent stable version may be found at +https://bids-specification.readthedocs.io/en/stable/05-derivatives/01-introduction.html. +It is not required that every BIDS Application produce a +BIDS-Derivatives-compliant result dataset, but any outputs that may be required +by the BIDS Application specification must be compliant with the +BIDS-Derivatives specification.
+Please refer to general BIDS specification document for context and general +guidelines (definitions, units, directory structure, missing values, stimulus +and event information, etc.): +https://bids-specification.readthedocs.io/en/stable/
+The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", +"SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be +interpreted as described in [RFC2119.
+The terminology that will be used is inherited from BIDS-Raw and includes the +following:
+There are three domains of requirements that BIDS Applications must specify: (1) +User interface components; (2) Required application behaviors; (3) Required +application outputs.
+BIDS contains "required", "recommended" and "optional" fields. These are +indicated throughout the document:
+Ultimately, through using Boutiques to define tools and their parameters, the +goal is that each tool can be interacted with as follows:
+ $ # Using Boutiques directly, the "exec launch" commands will run the app
+ $ bosh exec launch bids-app --invocation input_params.json
+ $ # Eventually, we envision that BIDS Application interface will also support
+ $ # simple, lightweight overrides to provide some of these common values via
+ $ # the command line directly.
+ $ bids-launch bids-app --input-dataset /path/to/bids /path/to/derivatives \
+ --output-location /path/to/output \
+ --analysis-level subject--subject-label 01 02 \
+ --random-seed 0xBID5CAFE
+
In the next sections, the bids-app
tool, a Boutiques descriptor, and the
+input_params.json
, a set of invocation parameters corresponding to this app,
+will be defined.
A uniform user interface is essential to scalable deployment of BIDS +Applications. This section describes the common interface components that may be +relied upon by users or platforms running these applications (callers). +Command-line interfaces map between positional or flag arguments provided +through an interactive shell program (e.g. Bash) to a program and program +behavior. However, tools written in different languages or following different +conventions may represent and parse these arguments distinctly. For the purposes +of automated execution of diverse tools, a more useful interface is a mapping of +parameter identifiers to their values, abstracting the way they are represented +on the command-line (CLI). Boutiques is a standard developed for this mapping. +Boutiques provides a +JSON schema and +related tools to describe, validate, execute and share command-line tools, among +other utilities. The Boutiques toolkit, named bosh, will be referred to when +discussing examples throughout this specification.
+Instead of requiring specific positional arguments and flags which assign common +names to expected options (e.g., "subject-label") in the command-line interfaces +themselves, BIDS Applications should provide a Boutiques descriptor — a +standardized JSON file that describes the command line behavior and operation of +a tool — that map the tool-specific common arguments to these common names, +without requiring rewriting of the command-line tools. In the sections below, +the identifiers assigned in the Boutiques descriptor are described in the +"Argument ID" column of relevant tables.
+The Boutiques descriptor for a program SHOULD be retrievable by calling the
+application with the --bids-exec-spec
flag and no other arguments.
A human-readable schema for a Boutiques descriptor may be found at +https://github.com/boutiques/boutiques/blob/0.5.25/schema/README.md. +This section attempts to summarize the salient points of that document, but the +Boutiques schema is authoritative and complete. In addition to the Boutiques +fields (see Tables 1–4, 6), BIDS conformant descriptors MUST include a custom +object (see Table 2) containing the BIDSApplicationVersion key and associated +value which indicates the version of the BIDS application specification to which +they conform, together with some additional optional fields. Descriptors SHOULD +be simply named as name.json.
+Table 1: List of relevant base Boutiques properties and their role within BIDS Applications. + | +|
Field name + | +Definition + | +
command-line
+ |
+ REQUIRED. String. A template string including the command and references to the value-keys of all possible inputs. The ordering imposed here may be significant, in particular for non-optional arguments. + | +
custom
+ |
+ REQUIRED. Object. Object which can contain extensible metadata. This has a single required element, as described in Table 2. + | +
inputs
+ |
+ REQUIRED. List. List of objects which contain input parameter definitions. Described in Table 3. + | +
name
+ |
+ REQUIRED. String. The name of the BIDS Application. + | +
output-files
+ |
+ REQUIRED. List. List of objects which contain output parameter definitions. Described in Table 6. + | +
schema-version
+ |
+ REQUIRED. String. Boutiques schema version. Must be "≥0.5". This is not to be confused with the BIDS Application schema and associated version. + | +
tool-version
+ |
+ REQUIRED. String. Version of the BIDS Application. + | +
description
+ |
+ RECOMMENDED. String. A plain-text description of the BIDS Application. + | +
descriptor-url
+ |
+ RECOMMENDED. String. Link to the descriptor itself. Likely a GitHub repo alongside the described tool, for example. + | +
doi
+ |
+ RECOMMENDED. String. DOI of the descriptor returned once published via Boutiques. (Note: This is not the DOI of the tool itself.) + | +
suggested-resources
+ |
+ RECOMMENDED. Object. Contains an execution walltime-estimate in seconds, memory usage in MB, and CPU/GPU usage in number of core threads/devices. + | +
container-image
+ |
+ OPTIONAL. Object. The name and location of a container image, such as those in Docker or Singularity formats, containing the configured application. + | +
error-codes
+ |
+ OPTIONAL. List. List of objects that contain error code information. The reserved error conditions are described in Table 7. + | +
groups
+ |
+ OPTIONAL. List. List of objects that contain relational information among input parameters as described in Table 4. This is not to be confused with any other BIDS-relevant definition of groups. + | +
The custom
object has the following defined fields for use in the context of
+BIDS Applications:
Table 2: List of custom object properties and roles within the BIDS Application specification. + | +|
Field name + | +Definition + | +
BIDSAppSpecVersion
+ |
+ REQUIRED. String. The version of the BIDS application specification with which the application complies. + | +
OutputDataSpecification
+ |
+ OPTIONAL. List. If output data conforms to a standard definition (e.g. NIDM-1.1.0), these data standards may be included as a list of strings. + | +
<unspecified>
+ |
+ OPTIONAL. Any. Any key referring to arbitrary metadata that may be relevant or of interest to the application and its users. + | +
Inputs to BIDS apps may be specified as JSON objects that map input ids to +values. The objects found within the required inputs list have the following +fields, described fully in +https://github.com/boutiques/boutiques/blob/0.5.25/schema/README.md#inputs +(source):
+Table 3: List of relevant inputs object properties for the BIDS Application specification. + | +|
Field name + | +Definition + | +
command-line-flag
+ |
+ OPTIONAL. String. For non-positional arguments, the flag which is associated with the argument on the command-line. + | +
id
+ |
+ REQUIRED. String. The argument ID. Alphanumeric values and underscores only. CamelCase is recommended. + | +
list
+ |
+ OPTIONAL. Boolean. Indicates whether or not the input field is a list of inputs. One of {true, false} . If omitted, it will be interpreted as false (e.g., non-list input).
+ |
+
name
+ |
+ REQUIRED. String. Plain text name of input for display. Can contain spaces. + | +
optional
+ |
+ OPTIONAL. Boolean. Indicates whether or not the input field is required. One of {true, false} . If omitted, will be interpreted as false (e.g. non-optional input).
+ |
+
type
+ |
+ REQUIRED. String. One of {"String", "File", "Flag", "Number"} .
+ |
+
value-choices
+ |
+ OPTIONAL. List. List of possible values that the parameter may take. + | +
value-key
+ |
+ OPTIONAL. String. String to replace in command-line template string. If specified, this MUST NOT be either a superset or subset of the value-key attribute associated with another object in the descriptor; to ensure this, brackets are typically used (e.g. "[value]"). + | +
In addition to describing inputs themselves, groups of inputs and their +relationships can be defined as follows in Table 4:
+Table 4: List of group object properties and their role within the BIDS Application specification. + | +|
Field name + | +Definition + | +
all-or-none
+ |
+ OPTIONAL. Boolean. True if all parameters included in this group need to be included together.. + | +
description
+ |
+ RECOMMENDED. String. Description of the input group. + | +
id
+ |
+ REQUIRED. String. A short, unique, informative identifier containing only alphanumeric characters and underscores. + | +
members
+ |
+ REQUIRED. List. IDs of the input parameters belonging to this group. + | +
mutually-exclusive
+ |
+ OPTIONAL. Boolean. True if only one input in the group may be selected at runtime. + | +
name
+ |
+ REQUIRED. String. A human-readable name for the input group. + | +
one-is-required
+ |
+ OPTIONAL. Boolean. True if at least one of the inputs in the group must be selected. + | +
BIDS Applications MUST provide the following arguments. Notes that "Argument ID" +is what is required to exist as the state "id" in the Boutiques descriptor, and +will be validated, while the example CLI Flag provides a possible way this could +be expressed in the tool's interface.
+Table 5: List of custom object properties and roles within the BIDS Application specification. + | +||
Argument ID + | +e.g. CLI Flag + | +Definition + | +
AnalysisLevel
+ |
+ --analysis-level
+ |
+ REQUIRED. String. String with value-choices which are a subset of {run, session, subject, dataset, meta}. The app may support one or more of these analysis levels. A default may be set, and unsupported analysis levels should return an exit code of 17, consistent with the definition in Table 7. + | +
Help
+ |
+ --help
+ |
+ REQUIRED. Flag. Flag that specifies whether or not to show the help-text that describes how the tool may be correctly used. + | +
InputDataset
+ |
+ --input-dataset
+ |
+ REQUIRED. List. List of URIs/paths of the BIDS datasets to be processed. Whether or not the order of listed datasets is important MUST be specified in the parameter description. The tool MUST NOT reorder the user-specified list. + | +
OutputLocation
+ |
+ --output-location
+ |
+ REQUIRED. List. One URI/path to the location where all outputs will be stored. + | +
ToolVersion
+ |
+ --version
+ |
+ REQUIRED. Flag. Returns the version of the tool being used. + | +
If an app wishes to maintain backwards compatibility with BIDS-Apps 1.0, then +the following command-line should be valid:
+ bids-app InputDataset OutputLocation AnalysisLevel [options]
+
In this case, InputDataset is limited to a list of length one. It is worth +noting that all legacy apps can be supported in this spec, they just need to +write a descriptor which maps the inputs as they are expected and defined, here, +to their associated values in the original application.
+The ability to filter BIDS entities (e.g. subject, session, or run) allows for +the selection of subsets of datasets. To be extensible as new entities are added +to the BIDS specification, the reserved arguments are defined here as a rule +which maps to BIDS entities, rather than specifying the moving goalpost of an +exhaustive list. The arguments may be specified as follows:
+While several examples exist within Table 5, to the following demonstrates how +the above rules can be applied for the BIDS entity "subject":
+ID: SubjectLabel
CLI flag: --subject-label
Acceptable and equivalent usages:
+ --subject-label 01 02 03
+ --subject-label subject_ids.txt
+
_Contents of subject_ids.txt
:
01
+02
+03
+
In all cases where such arguments are defined and applied, only files in the +BIDS dataset that have a value for the specified entities will be subject to +filtering. That is, if a file does not have a given entity (e.g., entity value +for it is <None>), the file will be included.
+Applications are not required to support these arguments, but MUST NOT assign +these arguments to other meanings. To reduce conflicts, BIDS Applications SHOULD +avoid using this convention except for entities that are anticipated to be +standardized.
+Example of an Interface descriptor: see 4.1.
+For example, suppose we have an application with the following descriptor:
+example_app.json
:
{
+ "name": "Example BIDS App",
+ "command-line": "bids-app [InputDataset] [OutputLocation] [AnalysisLevel] [ParticipantLabel] [OurRandomSeed]""inputs": [
+ {
+ "id": "InputDataset",
+ "name": "Input datasets",
+ "value-key": "[InputDataset]",
+ "type": "File",
+ "list": true,
+ "optional": false,
+ "command-line-flag": "--input-datasets"
+ },
+ {
+ "id": "OutputLocation",
+ "name": "Output location",
+ "value-key": "[OutputLocation]",
+ "type": "File",
+ "optional": false,
+ "command-line-flag": "--output-location"
+ },
+ {
+ "id": "AnalysisLevel",
+ "name": "Analysis level",
+ "value-key": "[AnalysisLevel]",
+ "type": "String",
+ "optional": false,
+ "value-choices": [
+ "run",
+ "session",
+ "subject",
+ "dataset"
+ ],
+ "default": "session",
+ "command-line-flag": "--analysis-level"
+ },
+ {
+ "id": "SubjectLabel",
+ "name": "Subject labels",
+ "value-key": "[SubjectLabel]",
+ "type": "String",
+ "list": true,
+ "optional": true,
+ "command-line-flag": "--subject-label"
+ },
+ {
+ "id": "RandomSeed",
+ "name": "Seed for pseudorandom number generator",
+ "value-key": "[RandomSeed]",
+ "type": "Number",
+ "optional": true,
+ "command-line-flag": "--random-seed"
+ }
+ ]
+}
+
input_params.json
{
+ "InputDataset": ["/path/to/bids", "/path/to/derivatives"],
+ "OutputLocation": "/path/to/output",
+ "AnalysisLevel": "subject",
+ "SubjectLabel": ["01", "02"],
+ "RandomSeed": "0xB1D5CAF3"
+}
+
BIDS Apps MUST be able to be called via the BIDS Application Boutiques +descriptor and corresponding input parameter dictionary files, commonly referred +to in the Boutiques parlance as "invocations", and accept any BIDS dataset. It +is RECOMMENDED that BIDS Applications produce BIDS-Derivatives-compliant +datasets.
+Table 6: List of relevant output-files object properties for the BIDS Application specification. + | +|
Field name + | +Definition + | +
command-line-flag
+ |
+ OPTIONAL. String. Flag associated with the argument on the command-line. Examples: -o, --output + | +
description
+ |
+ RECOMMENDED. String. A plain-text description of the output-files of the BIDS Application. + | +
file-template
+ |
+ OPTIONAL. Array of strings. An array of strings that may contain value keys and together populate the self-contained structure of a configuration file. + | +
id
+ |
+ REQUIRED. String. A short, unique, informative identifier containing only alphanumeric characters and underscores. Typically used to generate variable names. (should conform ^[0-9,_,a-z,A-Z]*$ ). Example: "data_file"
+ |
+
list
+ |
+ OPTIONAL. Boolean. True if output is a list of values. + | +
name
+ |
+ REQUIRED. String. A human-readable output name. Example: 'Supplementary input file for X task'. + | +
optional
+ |
+ OPTIONAL. Boolean. True if output may not be produced by the tool. + | +
path-template
+ |
+ OPTIONAL. String. Describes the output file path relative to the execution directory. May contain input value keys and wildcards. Example: "xx". + | +
path-template-stripped-extensions
+ |
+ OPTIONAL. List. List of file extensions that will be stripped from the input values before being substituted in the path template. Example: [".nii",".nii.gz"]. + | +
value-key
+ |
+ OPTIONAL. String. A string contained in command-line, substituted by the output value and/or flag at runtime. + | +
When generated, an execution report that completely describes the processing
+that was executed and the dataset MUST comply with the BIDS Provenance Extension
+Proposal (BEP28). These outputs are OPTIONAL, and if provided, should be
+specified in the output-files
section of the tool descriptor.
Similarly, the dataset_description.json file SHOULD be updated to reflect the +processing that has occurred by the BIDS Application.
+For a given set of arguments, the behavior of a BIDS Application will typically +vary based on the contents of the input dataset. The dataset may be +BIDS-compliant, or it may not; and it may contain the file types the BIDS App +requires, or it may not. This section describes the expected behavior under each +combination of cases, and describes RECOMMENDED exit codes on systems that +support them.
+If the dataset is BIDS-compliant and contains the files required by the +application, then the application should make a best effort to perform its task +to completion.
+If the dataset is BIDS-compliant but does not contain the files required by the +application, then the application MAY fail immediately or when attempting to +open a missing file. In this case, it is RECOMMENDED to use exit code 66 +(NOINPUT).
+If the dataset is not BIDS-compliant, then the BIDS App MAY fail immediately +with exit code 16.
+If the dataset contains the required files but is not BIDS-compliant (e.g., a +"dirty" dataset that has more files than needed), then the BIDS App MAY treat +the dataset as valid.
+An exit code or exit status is an +integer indicating the reason for termination for use by the parent program or +operating system. The interpretation of exit codes varies across systems, and +programmers SHOULD follow the conventions of the systems for which they are +programming.
+Most operating systems, including POSIX (Linux, Mac OSX) and Windows use 0 to +indicate success and >0 to indicate failure. POSIX systems are limited to an +unsigned byte (range: 0-255), so these recommendations are limited to that +range. Exit codes 64-78 are specified in BSD +sysexits(3), and +should be avoided unless applicable. Exit codes 2 and 126-165 may be set by +Bash, and so will be +reserved.
+The following exit codes are RECOMMENDED for consistent error handling under +POSIX and Windows environments:
+Table 7: Reserved exit codes and their definitions. + | +|
Exit code + | +Definition + | +
0
+ |
+ SUCCESS. The program completed successfully. + | +
1
+ |
+ FAILURE. The program failed for unspecified reasons. + | +
2
+ |
+ Reserved + | +
16-31
+ |
+ BIDS-related codes. Reserved except the following + | +
16
+ |
+ An input dataset failed BIDS validation. + | +
17
+ |
+ Unknown analysis level. + | +
18
+ |
+ Entity-based filtering options selected no files. + | +
19
+ |
+ Both command-line arguments and a parameter invocation file were passed to the application. + | +
64-78
+ |
+ BSD codes - Reserved except the following. + | +
64
+ |
+ USAGE. The command was used incorrectly. + | +
65
+ |
+ DATAERR. The input data was incorrect in some way. + | +
66
+ |
+ NOINPUT. The input data was missing or unreadable. + | +
73
+ |
+ CANTCREAT. An output file/directory cannot be created. + | +
74
+ |
+ IOERR. Failure during file reading/writing. + | +
75
+ |
+ TEMPFAIL. Temporary failure. Another run is expected to succeed. + | +
126-165
+ |
+ BASH codes - Reserved + | +
This section describes a BIDS Application named bids-app that can only operate +at the participant analysis leveland accepts a numeric seed for a random number +generator.
+{
+ "name": "Example BIDS App",
+ "tool-version": "0.0.1",
+ "schema-version": "0.5",
+ "custom": {
+ "BIDSApplicationVersion": "2.0"
+ },
+ "command-line": "bids-app [InputDataset] [OutputLocation] [AnalysisLevel] [ParticipantLabel] [RandomSeed]",
+ "inputs": [
+ {
+ "id": "InputDataset",
+ "name": "Input datasets",
+ "value-key": "[InputDataset]",
+ "type": "File",
+ "list": true,
+ "optional": false,
+ "command-line-flag": "--input-dataset"
+ },
+ {
+ "id": "OutputLocation",
+ "name": "Output location",
+ "value-key": "[OutputLocation]",
+ "type": "File",
+ "optional": false,
+ "command-line-flag": "--output-location"
+ },
+ {
+ "id": "AnalysisLevel",
+ "name": "Analysis level",
+ "value-key": "[AnalysisLevel]",
+ "type": "String",
+ "optional": true,
+ "value-choices": ["participant"],
+ "default-value": "participant",
+ "command-line-flag": "--analysis-level"
+ },
+ {
+ "id": "SubjectLabel",
+ "name": "Participant labels",
+ "value-key": "[ParticipantLabel]",
+ "type": "String",
+ "list": true,
+ "optional": true,
+ "command-line-flag": "--participant-label"
+ },
+ {
+ "id": "OurRandomSeed",
+ "name": "Seed for pseudorandom number generator",
+ "description": "Example parameter that may be relevant.",
+ "value-key": "[OurRandomSeed]",
+ "type": "Number",
+ "optional": true,
+ "command-line-flag": "--random-seed"
+ }
+ ]
+}
+
Two example input definitions follow:
+input_params1.json
{
+ "InputDataset": ["/path/to/bids", "/path/to/derivatives"],
+ "OutputLocation": "/path/to/output",
+ "AnalysisLevel": "participant",
+ "SubjectLabel": ["01", "02"],
+ "RandomSeed": 2983578366
+}
+
input_params2.json
{
+ "InputDataset": ["/path/to/bids", "/path/to/derivatives"],
+ "OutputLocation": "/path/to/output",
+ "AnalysisLevel": "participant"
+}
+
Before the BIDS Application specification existed there were BIDS Apps. +Attention has been paid to ensure that BIDS Exec apps can be compatible with +existing BIDS Apps.
+For example, the term participant was widely used in BIDS Apps, whereas subject +is the preferred term in BIDS. To allow backwards compatibility here you can +use:
+{
+ "id": "SubjectLabel",
+ "name": "Participant labels",
+ "value-key": "[ParticipantLabel]",
+ "type": "String",
+ "list": true,
+ "optional": true,
+ "command-line-flag": "--participant-label"
+}
+