Warning: This document is for an old version of niworkflows. The main version is master.

niworkflows.interfaces.confounds module

Select terms for a confound model, and compute any requisite expansions.

class niworkflows.interfaces.confounds.ExpandModel(from_file=None, resource_monitor=None, **inputs)[source]

Bases: nipype.interfaces.base.core.SimpleInterface

Expand a confound model according to a specified formula.

input_spec

alias of niworkflows.interfaces.confounds._ExpandModelInputSpec

output_spec

alias of niworkflows.interfaces.confounds._ExpandModelOutputSpec

class niworkflows.interfaces.confounds.NormalizeMotionParams(from_file=None, resource_monitor=None, **inputs)[source]

Bases: nipype.interfaces.base.core.SimpleInterface

Convert input motion parameters into the designated convention.

input_spec

alias of niworkflows.interfaces.confounds._NormalizeMotionParamsInputSpec

output_spec

alias of niworkflows.interfaces.confounds._NormalizeMotionParamsOutputSpec

class niworkflows.interfaces.confounds.SpikeRegressors(from_file=None, resource_monitor=None, **inputs)[source]

Bases: nipype.interfaces.base.core.SimpleInterface

Generate spike regressors.

input_spec

alias of niworkflows.interfaces.confounds._SpikeRegressorsInputSpec

output_spec

alias of niworkflows.interfaces.confounds._SpikeRegressorsOutputSpec

niworkflows.interfaces.confounds.exponential_terms(order, variables, data)[source]

Compute exponential expansions.

Parameters
  • order (list of int) – A list of exponential terms to include. For instance, [1, 2] indicates that the first and second exponential terms should be added. To retain the original terms, 1 must be included in the list.

  • variables (list of str) – List of variables for which exponential terms should be computed.

  • data (DataFrame) – Table of values of all observations of all variables.

Returns

  • variables_exp (list) – A list of variables to include in the final data frame after adding the specified exponential terms.

  • data_exp (DataFrame) – Table of values of all observations of all variables, including any specified exponential terms.

niworkflows.interfaces.confounds.parse_expression(expression, parent_data)[source]

Parse an expression in a model formula.

Parameters
  • expression (str) – Formula expression: either a single variable or a variable group paired with an operation (exponentiation or differentiation).

  • parent_data (DataFrame) – The source data for the model expansion.

Returns

  • variables (list) – A list of variables in the provided formula expression.

  • data (DataFrame) – A tabulation of all terms in the provided formula expression.

niworkflows.interfaces.confounds.parse_formula(model_formula, parent_data, unscramble=False)[source]

Parse a confound manipulation formula.

Recursively parse a model formula by breaking it into additive atoms and tracking grouping symbol depth.

Parameters
  • model_formula (str) – Expression for the model formula, e.g. (a + b)^^2 + dd1(c + (d + e)^3) + f Note that any expressions to be expanded must be in parentheses, even if they include only a single variable (e.g., (x)^2, not x^2). Temporal derivative options:

    • d6(variable) for the 6th temporal derivative

    • dd6(variable) for all temporal derivatives up to the 6th

    • d4-6(variable) for the 4th through 6th temporal derivatives

    • 0 must be included in the temporal derivative range for the original term to be returned when temporal derivatives are computed.

    Exponential options:

    • (variable)^6 for the 6th power

    • (variable)^^6 for all powers up to the 6th

    • (variable)^4-6 for the 4th through 6th powers

    • 1 must be included in the powers range for the original term to be returned when exponential terms are computed.

    Temporal derivatives and exponential terms are computed for all terms in the grouping symbols that they adjoin.

  • parent_data (DataFrame) – A tabulation of all values usable in the model formula. Each additive term in model_formula should correspond either to a variable in this data frame or to instructions for operating on a variable (for instance, computing temporal derivatives or exponential terms).

Returns

  • variables (list of str) – A list of variables included in the model parsed from the provided formula.

  • data (DataFrame) – All values in the complete model.

niworkflows.interfaces.confounds.spike_regressors(data, criteria=None, header_prefix='motion_outlier', lags=None, minimum_contiguous=None, concatenate=True, output='spikes')[source]

Add spike regressors to a confound/nuisance matrix.

Parameters
  • data (DataFrame) – A tabulation of observations from which spike regressors should be estimated.

  • criteria (dict of (str, '>' or '<' or float)) – Criteria for generating a spike regressor. If, for a given frame, the value of the variable corresponding to the key exceeds the threshold indicated by the value, then a spike regressor is created for that frame. By default, the strategy from [Power2014] is implemented: any frames with FD greater than 0.5 or standardised DV greater than 1.5 are flagged for censoring.

  • header_prefix (str) – The prefix used to indicate spike regressors in the output data table.

  • lags (list of int) – A list indicating the frames to be censored relative to each flag. For instance, [0] censors the flagged frame, while [0, 1] censors both the flagged frame and the following frame.

  • minimum_contiguous (int or None) – The minimum number of contiguous frames that must be unflagged for spike regression. If any series of contiguous unflagged frames is shorter than the specified minimum, then all of those frames will additionally have spike regressors implemented.

  • concatenate (bool) – Indicates whether the returned object should include only spikes (if false) or all input time series and spikes (if true, default).

  • output (str) – Indicates whether the output should be formatted as spike regressors (‘spikes’, a separate column for each outlier) or as a temporal mask (‘mask’, a single output column indicating the locations of outliers).

Returns

data – The input DataFrame with a column for each spike regressor.

Return type

DataFrame

References

Power2014

Power JD, et al. (2014) Methods to detect, characterize, and remove motion artifact in resting state fMRI. NeuroImage. doi:10.1016/j.neuroimage.2013.08.048.

niworkflows.interfaces.confounds.temporal_derivatives(order, variables, data)[source]

Compute temporal derivative terms by the method of backwards differences.

Parameters
  • order (list of int) – A list of temporal derivative terms to include. For instance, [1, 2] indicates that the first and second derivative terms should be added. To retain the original terms, 0 must be included in the list.

  • variables (list of str) – List of variables for which temporal derivative terms should be computed.

  • data (DataFrame) – Table of values of all observations of all variables.

Returns

  • variables_deriv (list) – A list of variables to include in the final data frame after adding the specified derivative terms.

  • data_deriv (DataFrame) – Table of values of all observations of all variables, including any specified derivative terms.