From dbc5716929bf5d09f926b08b948a3cac814785c0 Mon Sep 17 00:00:00 2001 From: Taylor Salo Date: Tue, 26 Nov 2024 14:09:40 -0500 Subject: [PATCH] Fix volume selection and temporarily remove `--dummy-scans` parameter (#468) --- aslprep/cli/parser.py | 24 ++++++++++++------------ aslprep/config.py | 3 ++- aslprep/workflows/asl/base.py | 1 + aslprep/workflows/asl/cbf.py | 11 +++++++++-- 4 files changed, 24 insertions(+), 15 deletions(-) diff --git a/aslprep/cli/parser.py b/aslprep/cli/parser.py index f8008d02f..facd22503 100644 --- a/aslprep/cli/parser.py +++ b/aslprep/cli/parser.py @@ -351,18 +351,18 @@ def _bids_filter(value, parser): default=None, help='Do not use boundary-based registration (no goodness-of-fit checks)', ) - g_conf.add_argument( - '--dummy-scans', - required=False, - action='store', - default=None, - type=int, - help=( - 'Number of non-steady-state volumes. ' - 'Note that this indicates the number of volumes, not the number of control-label ' - 'pairs in the ASL file.' - ), - ) + # g_conf.add_argument( + # '--dummy-scans', + # required=False, + # action='store', + # default=None, + # type=int, + # help=( + # 'Number of non-steady-state volumes. ' + # 'Note that this indicates the number of volumes, not the number of control-label ' + # 'pairs in the ASL file.' + # ), + # ) g_conf.add_argument( '--random-seed', dest='_random_seed', diff --git a/aslprep/config.py b/aslprep/config.py index 9bd92a649..2f048c5ce 100644 --- a/aslprep/config.py +++ b/aslprep/config.py @@ -544,7 +544,8 @@ class workflow(_Config): cifti_output = None """Generate HCP Grayordinates, accepts either ``'91k'`` (default) or ``'170k'``.""" dummy_scans = 0 - """Number of label-control volume pairs to delete before CBF computation.""" + """Number of label-control volume pairs to delete before CBF computation. Not currently used. + """ fmap_bspline = None """Regularize fieldmaps with a field of B-Spline basis.""" fmap_demean = None diff --git a/aslprep/workflows/asl/base.py b/aslprep/workflows/asl/base.py index b0c195abf..84d28055d 100644 --- a/aslprep/workflows/asl/base.py +++ b/aslprep/workflows/asl/base.py @@ -400,6 +400,7 @@ def init_asl_wf( (asl_native_wf, cbf_wf, [ ('outputnode.asl_native', 'inputnode.asl_file'), ('outputnode.aslcontext', 'inputnode.aslcontext'), + ('outputnode.metadata', 'inputnode.metadata'), ('outputnode.m0scan_native', 'inputnode.m0scan'), ]), ]) # fmt:skip diff --git a/aslprep/workflows/asl/cbf.py b/aslprep/workflows/asl/cbf.py index defa5c0bd..dbad344a8 100644 --- a/aslprep/workflows/asl/cbf.py +++ b/aslprep/workflows/asl/cbf.py @@ -76,7 +76,9 @@ def init_cbf_wf( name_source : :obj:`str` Path to the raw ASL file. metadata : :obj:`dict` - BIDS metadata for asl file + BIDS metadata for asl file. + List-type fields in this dict have not been reduced based on selected volumes, + so this should only be used for metadata that is not affected by volume selection. scorescrub basil m0_scale @@ -89,6 +91,10 @@ def init_cbf_wf( asl_file asl series NIfTI file, after preprocessing aslcontext : :obj:`str` + metadata : :obj:`dict` + Metadata dictionary associated with asl_file, after preprocessing. + List-type fields in this dict *have* been reduced based on selected volumes, + so this is the dictionary that should be used to select volumes. m0scan : :obj:`str` or None An M0 scan (if available as a separate file) in aslref space. m0scan_metadata : :obj:`dict` or None @@ -224,6 +230,7 @@ def init_cbf_wf( fields=[ 'asl_file', 'aslcontext', + 'metadata', 'm0scan', 'm0scan_metadata', 'asl_mask', @@ -371,7 +378,6 @@ def _getfiledir(file): name_source=name_source, dummy_scans=dummy_scans, fwhm=smooth_kernel, - metadata=metadata, ), mem_gb=0.2, run_without_submitting=True, @@ -381,6 +387,7 @@ def _getfiledir(file): workflow.connect([ (inputnode, extract_deltam, [ ('asl_file', 'asl_file'), + ('metadata', 'metadata'), ('aslcontext', 'aslcontext'), ('m0scan_metadata', 'm0scan_metadata'), ]),