Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MAINT: Merge master into multiecho #1324

Merged
merged 120 commits into from
Oct 26, 2018
Merged
Changes from 1 commit
Commits
Show all changes
120 commits
Select commit Hold shift + click to select a range
725fa73
[MAINT] Pin grabbit and pybids in ``setup.py``
oesteban Sep 14, 2018
375c7d3
FIX: Enhance T2 contrast in reference estimate
effigies Sep 26, 2018
d8fbf00
TEST: Plot old/new masks
effigies Aug 10, 2018
26e0f44
Merge pull request #1299 from poldracklab/fix/enhance_t2
oesteban Oct 2, 2018
2c2ab47
FIX: Create template from one usable T1w image
effigies Oct 3, 2018
3e55760
STY: Whitespace
effigies Oct 3, 2018
ab36915
Merge pull request #1305 from poldracklab/fix/structural_reference
oesteban Oct 3, 2018
b718242
update circle outputs
oesteban Oct 4, 2018
b8c897f
first steps in #960. Includes modifications pertaining to #1302
oesteban Oct 4, 2018
15f48fd
actually generate references
oesteban Oct 4, 2018
3a20826
CI: Deploy poldracklab/fmriprep:unstable tracking master
effigies Oct 4, 2018
887cd3e
fix import path
oesteban Oct 4, 2018
b867453
fix ds210
oesteban Oct 4, 2018
9f2e25d
use _boldref suffix. close #960
oesteban Oct 4, 2018
1da1419
fix ordering of derivatives
oesteban Oct 4, 2018
6f74072
Merge pull request #1284 from poldracklab/oesteban-patch-1
oesteban Oct 4, 2018
165df97
Version 1.1.8 - Update CHANGES [skip ci]
oesteban Oct 4, 2018
d617210
Merge pull request #1306 from oesteban/enh/issue-960
oesteban Oct 5, 2018
3befabb
[skip ci] Add YAML file with list of subject that were included in th…
oesteban Oct 5, 2018
2ee473e
[skip ci] Add quotes to string
oesteban Oct 5, 2018
4384681
clean-up caches
oesteban Oct 6, 2018
c19a51a
fix BIDS-validator link
surchs Oct 9, 2018
ec5e651
[ENH] Template-based masking of EPI boldrefs
oesteban Oct 15, 2018
3e344db
fix flake8 error
oesteban Oct 15, 2018
2679533
use poldracklab/niworkflows@0946bad69867840718d4aeeb54ef11bd535c1a9c
oesteban Oct 15, 2018
af0cd52
update pinning to release
oesteban Oct 15, 2018
b5aa8bd
update reports.py
alioco Oct 15, 2018
c088fb6
new registration parameters
oesteban Oct 16, 2018
966d412
pre-cache template getter
oesteban Oct 16, 2018
be17090
fix ds005 problem
oesteban Oct 16, 2018
e121073
Merge pull request #1320 from surchs/master
effigies Oct 16, 2018
76d0f70
1) shorten registration; 2) accept a ``pre_mask``
oesteban Oct 16, 2018
713132f
[skip ci] update documentation
oesteban Oct 16, 2018
0c9e665
CI: Update expected anatomical outputs
effigies Oct 17, 2018
bc502a1
RF: Update anatomical derivatives for RC1
effigies Oct 17, 2018
9f6ca76
[HOTFIX] Missing BOLD reports
oesteban Oct 17, 2018
8bb0241
Merge pull request #1326 from poldracklab/hotfix/reports-2
oesteban Oct 17, 2018
18fe6ca
Merge remote-tracking branch 'upstream/master' into fix/1000
oesteban Oct 17, 2018
eca0cf8
Merge remote-tracking branch 'upstream/master' into bids/derivatives_rc1
oesteban Oct 17, 2018
ba58d8d
fix problems in derivatives datasink
oesteban Oct 17, 2018
9ef8ee1
[HOTFIX] Reportlets - bbregister vs flirtbbr (continues #1326)
oesteban Oct 17, 2018
4dc0908
Merge branch 'hotfix/reports-3' into fix/1000
oesteban Oct 17, 2018
fbe25f0
Merge pull request #1322 from alioco/master
oesteban Oct 17, 2018
450ac3a
Merge branch 'hotfix/reports-3' into bids/derivatives_rc1
oesteban Oct 17, 2018
96f97d6
fix mandatory suffix
oesteban Oct 17, 2018
5da2e92
disambiguate flirt reportlets
oesteban Oct 17, 2018
30d7658
Merge branch 'hotfix/reports-3' into fix/1000
oesteban Oct 17, 2018
3c6303d
Merge pull request #1328 from poldracklab/hotfix/reports-3
oesteban Oct 17, 2018
46411d3
Merge remote-tracking branch 'upstream/master' into bids/derivatives_rc1
oesteban Oct 17, 2018
aa0841b
``_roi`` -> ``_dseg`` (incl. functionals)
oesteban Oct 17, 2018
6215779
[TST] Add heavily-nonuniform boldrefs for regression tests
oesteban Oct 17, 2018
48fdaa0
do not build docs on ``test/`` branches
oesteban Oct 17, 2018
8a974fb
make cache key consistent
oesteban Oct 17, 2018
f36e2eb
is restoring cache necessary in the job?
oesteban Oct 18, 2018
b814d61
CI: Tar up directory for OSF publication
effigies Oct 16, 2018
b6021c4
FIX: Set inputs in inputs object
effigies Oct 16, 2018
da18127
CI: Add -svx options to pytest
effigies Oct 16, 2018
edaa53b
fix problems
oesteban Oct 17, 2018
c1bea4a
fix tarring new masks
oesteban Oct 17, 2018
20325c6
pacify flake8
oesteban Oct 17, 2018
9f69ba7
minor fixes to test
oesteban Oct 18, 2018
ecb1185
clear regression tests cache
oesteban Oct 18, 2018
36b369e
[skip ci] pacify flake8
oesteban Oct 18, 2018
53a96a8
Merge pull request #1329 from poldracklab/tests/add-more-masks
oesteban Oct 18, 2018
65e6fbc
Merge remote-tracking branch 'upstream/master' into fix/1000
oesteban Oct 18, 2018
9b67991
[FIX] Quick update to new template structure
oesteban Oct 18, 2018
fb7806e
Merge remote-tracking branch 'upstream/master' into bids/derivatives_rc1
oesteban Oct 18, 2018
ee574ff
Merge branch 'fix/osf-templates' into bids/derivatives_rc1
oesteban Oct 18, 2018
acb8584
fix ds054 whitelist of outputs
oesteban Oct 18, 2018
2fffaed
[skip ds210][skip tests][skip docs] Clear ds005 cache
oesteban Oct 18, 2018
9f768f4
Merge pull request #1330 from oesteban/fix/osf-templates
oesteban Oct 18, 2018
235aa1c
[skip tests][skip docs][skip ds210][skip ds054] pass mask into ica-ar…
jdkent Oct 18, 2018
cbcf075
[skip ci] Fix ordering of ds054 outputs whitelist
oesteban Oct 18, 2018
c9bfe4f
Merge pull request #1325 from effigies/bids/derivatives_rc1
oesteban Oct 18, 2018
c6a7405
[skip ds005][skip tests][skip docs] Clear caches
oesteban Oct 19, 2018
cdf1f9d
[skip ci] Merge remote-tracking branch 'upstream/master' into add_aro…
oesteban Oct 19, 2018
4caeb9c
Merge pull request #1332 from jdkent/add_aroma_mask
oesteban Oct 19, 2018
b3f34a5
[skip tests][skip docs][skip ds210][skip ds054] wip: remove non stead…
jdkent Oct 20, 2018
b4ab300
[skip tests][skip docs][skip ds210][skip ds054] pacify flake8
jdkent Oct 20, 2018
921bf56
[skip ds210][skip ds054] update the documentation
jdkent Oct 21, 2018
d773cfc
[skip tests][skip docs][skip ds210][skip ds054][skip ds005]
jdkent Oct 21, 2018
c05b7bb
Merge pull request #1336 from jdkent/patch-1
effigies Oct 21, 2018
99f9a23
Merge branch 'master' of https://github.com/poldracklab/fmriprep into…
jdkent Oct 21, 2018
b9e5ff4
remove whitespace
jdkent Oct 23, 2018
11ea1c2
[skip ds210][skip ds054][skip tests] switch n_volumes* to skip_vols a…
jdkent Oct 23, 2018
fabc7c9
[skip tests][skip ds210][skip ds054][skip ds005] add --bind method to…
jdkent Oct 23, 2018
05f445f
CI: Update functional outputs
effigies Oct 17, 2018
117fe8a
Functional derivatives
effigies Oct 17, 2018
266ba15
fix unused variable as excuse to trigger tests
oesteban Oct 19, 2018
11b3e44
Merge pull request #1340 from jdkent/singularity_docs
effigies Oct 23, 2018
a296a79
Merge pull request #1307 from effigies/docker/unstable
effigies Oct 23, 2018
7a512c3
FIX: AROMA/CIFTI names
effigies Oct 23, 2018
51a1021
STY: Unused variable [skip ds005][skip ds054][skip ds210]
effigies Oct 23, 2018
a0460f9
Merge pull request #1333 from effigies/bids/derivatives_rc1
oesteban Oct 24, 2018
8ba55fa
Merge remote-tracking branch 'upstream/master' into fix/1000
oesteban Oct 24, 2018
0448135
Fix to set mod
kasbohm Oct 24, 2018
949b504
[skip ds210][skip ds054][skip tests][skip docs] edits from effigies r…
jdkent Oct 24, 2018
698e821
fix header mismatch problem
oesteban Oct 24, 2018
e52394e
[skip ci] Pin niworkflows==0.4.4
oesteban Oct 24, 2018
2a09ae8
address @effigies' comments on MatchHeader
oesteban Oct 24, 2018
a44b9b4
re-order parameters in docstrings [skip ds210][skip ds054][skip ds005]
jdkent Oct 24, 2018
f86b543
fix master
oesteban Oct 24, 2018
9503750
Merge branch 'ds005/expected-outputs' into fix/1000
oesteban Oct 25, 2018
ca32147
remove one branch
oesteban Oct 25, 2018
736d5d9
fix ordering of expected outputs
oesteban Oct 25, 2018
7535a08
[skip ci] fix minimal error in docs
oesteban Oct 25, 2018
874c4ce
Merge pull request #1321 from oesteban/fix/1000
oesteban Oct 25, 2018
e706408
Merge pull request #1344 from oesteban/ds005/expected-outputs
oesteban Oct 25, 2018
b71ddf3
ENH: Deprecate --debug with --sloppy
effigies Oct 25, 2018
6922e8d
[TST] Add doctest for #1339
oesteban Oct 25, 2018
8eaf472
DOC: Update order, grouping of options [skip ds005][skip ds054][skip …
effigies Oct 25, 2018
666b306
CI: Run sloppy registration
effigies Oct 25, 2018
4141206
Merge pull request #1 from oesteban/test/doctest-1339
kasbohm Oct 25, 2018
3de9874
Added name
kasbohm Oct 25, 2018
0d582f6
Merge pull request #1346 from kasbohm/patch-1
oesteban Oct 25, 2018
b71a9d3
Merge pull request #1347 from effigies/fix/debug_flags
effigies Oct 25, 2018
8f73452
[skip ci] Update notebooks
oesteban Oct 25, 2018
053aa16
Merge remote-tracking branch 'upstream/multiecho' into sync/master_mu…
emdupre Oct 26, 2018
aa56aaa
Merge pull request #1335 from jdkent/remove_init_vol_aroma
effigies Oct 26, 2018
c542dbf
Merge remote-tracking branch 'upstream/master' into sync/master_multi…
effigies Oct 26, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 13 additions & 13 deletions fmriprep/data/epi_atlasbased_brainmask.json
Original file line number Diff line number Diff line change
@@ -2,19 +2,19 @@
"winsorize_upper_quantile": 0.98,
"winsorize_lower_quantile": 0.05,
"float": true,
"metric": ["Mattes", "Mattes"],
"metric_weight": [1, 1],
"radius_or_number_of_bins": [64, 64],
"transforms": ["Affine", "Affine"],
"transform_parameters": [[0.1], [0.1]],
"number_of_iterations": [[200], [15]],
"convergence_window_size": [10, 3],
"convergence_threshold": [1e-08, 1e-09],
"metric": ["Mattes"],
"metric_weight": [1],
"radius_or_number_of_bins": [64],
"transforms": ["Affine"],
"transform_parameters": [[0.1]],
"number_of_iterations": [[200]],
"convergence_window_size": [10],
"convergence_threshold": [1e-09],
"sampling_strategy": ["Random", "Random"],
"smoothing_sigmas": [[4], [2]],
"smoothing_sigmas": [[2]],
"sigma_units": ["mm", "mm", "mm"],
"shrink_factors": [[2], [1]],
"sampling_percentage": [0.2, 0.2],
"use_histogram_matching": [true, true],
"use_estimate_learning_rate_once": [true, true]
"shrink_factors": [[2]],
"sampling_percentage": [0.2],
"use_histogram_matching": [true],
"use_estimate_learning_rate_once": [true]
}
5 changes: 2 additions & 3 deletions fmriprep/workflows/bold/base.py
Original file line number Diff line number Diff line change
@@ -394,9 +394,8 @@ def init_func_preproc_wf(bold_file, ignore, freesurfer,
]),
])

# The first reference uses T2 contrast enhancement
bold_reference_wf = init_bold_reference_wf(
omp_nthreads=omp_nthreads, enhance_t2=True)
# Generate a tentative boldref
bold_reference_wf = init_bold_reference_wf(omp_nthreads=omp_nthreads)

# Top-level BOLD splitter
bold_split = pe.Node(FSLSplit(dimension='t'), name='bold_split',
3 changes: 2 additions & 1 deletion fmriprep/workflows/bold/registration.py
Original file line number Diff line number Diff line change
@@ -324,7 +324,7 @@ def init_bold_t1_trans_wf(freesurfer, mem_gb, omp_nthreads, use_fieldwarp=False,
merge = pe.Node(Merge(compress=use_compression), name='merge', mem_gb=mem_gb)

# Generate a reference on the target T1w space
gen_final_ref = init_bold_reference_wf(omp_nthreads)
gen_final_ref = init_bold_reference_wf(omp_nthreads, pre_mask=True)

workflow.connect([
(inputnode, merge_xforms, [('itk_bold_to_t1', 'in1')]),
@@ -334,6 +334,7 @@ def init_bold_t1_trans_wf(freesurfer, mem_gb, omp_nthreads, use_fieldwarp=False,
(gen_ref, bold_to_t1w_transform, [('out_file', 'reference_image')]),
(bold_to_t1w_transform, merge, [('out_files', 'in_files')]),
(merge, gen_final_ref, [('out_file', 'inputnode.bold_file')]),
(mask_t1w_tfm, gen_final_ref, [('output_image', 'inputnode.bold_mask')]),
(merge, outputnode, [('out_file', 'bold_t1')]),
(gen_final_ref, outputnode, [('outputnode.ref_image', 'bold_t1_ref')]),
])
4 changes: 3 additions & 1 deletion fmriprep/workflows/bold/resampling.py
Original file line number Diff line number Diff line change
@@ -301,7 +301,8 @@ def _aslist(in_value):
mem_gb=mem_gb * 3)

# Generate a reference on the target T1w space
gen_final_ref = init_bold_reference_wf(omp_nthreads)
gen_final_ref = init_bold_reference_wf(
omp_nthreads=omp_nthreads, pre_mask=True)

workflow.connect([
(inputnode, merge_xforms, [('t1_2_mni_forward_transform', 'in1'),
@@ -311,6 +312,7 @@ def _aslist(in_value):
(inputnode, bold_to_mni_transform, [('bold_split', 'input_image')]),
(bold_to_mni_transform, merge, [('out_files', 'in_files')]),
(merge, gen_final_ref, [('out_file', 'inputnode.bold_file')]),
(mask_mni_tfm, gen_final_ref, [('output_image', 'inputnode.bold_mask')]),
(merge, outputnode, [('out_file', 'bold_mni')]),
(gen_final_ref, outputnode, [('outputnode.ref_image', 'bold_mni_ref')]),
])
138 changes: 84 additions & 54 deletions fmriprep/workflows/bold/util.py
Original file line number Diff line number Diff line change
@@ -32,8 +32,8 @@
DEFAULT_MEMORY_MIN_GB = 0.01


def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf',
gen_report=False, enhance_t2=False):
def init_bold_reference_wf(omp_nthreads, bold_file=None, pre_mask=False,
name='bold_reference_wf', gen_report=False):
"""
This workflow generates reference BOLD images for a series

@@ -66,6 +66,9 @@ def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf

bold_file
BOLD series NIfTI file
bold_mask : bool
A tentative brain mask to initialize the workflow (requires ``pre_mask``
parameter set ``True``).

**Outputs**

@@ -95,7 +98,7 @@ def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf
First, a reference volume and its skull-stripped version were generated
using a custom methodology of *fMRIPrep*.
"""
inputnode = pe.Node(niu.IdentityInterface(fields=['bold_file', 'sbref_file']),
inputnode = pe.Node(niu.IdentityInterface(fields=['bold_file', 'sbref_file', 'bold_mask']),
name='inputnode')
outputnode = pe.Node(
niu.IdentityInterface(fields=['bold_file', 'raw_ref_image', 'skip_vols', 'ref_image',
@@ -114,7 +117,7 @@ def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf
# Re-run validation; no effect if no sbref; otherwise apply same validation to sbref as bold
validate_ref = pe.Node(ValidateImage(), name='validate_ref', mem_gb=DEFAULT_MEMORY_MIN_GB)
enhance_and_skullstrip_bold_wf = init_enhance_and_skullstrip_bold_wf(
omp_nthreads=omp_nthreads)
omp_nthreads=omp_nthreads, pre_mask=pre_mask)

workflow.connect([
(inputnode, validate, [('bold_file', 'in_file')]),
@@ -132,6 +135,11 @@ def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf
('outputnode.skull_stripped_file', 'ref_image_brain')]),
])

if pre_mask:
workflow.connect([
(inputnode, enhance_and_skullstrip_bold_wf, [('bold_mask', 'inputnode.pre_mask')]),
])

if gen_report:
mask_reportlet = pe.Node(SimpleShowMaskRPT(), name='mask_reportlet')
workflow.connect([
@@ -144,8 +152,10 @@ def init_bold_reference_wf(omp_nthreads, bold_file=None, name='bold_reference_wf
return workflow


def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',
omp_nthreads=1):
def init_enhance_and_skullstrip_bold_wf(
name='enhance_and_skullstrip_bold_wf',
pre_mask=False,
omp_nthreads=1):
"""
This workflow takes in a :abbr:`BOLD (blood-oxygen level-dependant)`
:abbr:`fMRI (functional MRI)` average/summary (e.g. a reference image
@@ -156,8 +166,11 @@ def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',

Steps of this workflow are:


1. Calculate a conservative mask using Nilearn's ``create_epi_mask``.
1. Calculate a tentative mask by registering (9-parameters) to *fMRIPrep*'s
:abbr:`EPI (echo-planar imaging)` -*boldref* template, which
is in MNI space.
The tentative mask is obtained by resampling the MNI template's
brainmask into *boldref*-space.
2. Run ANTs' ``N4BiasFieldCorrection`` on the input
:abbr:`BOLD (blood-oxygen level-dependant)` average, using the
mask generated in 1) instead of the internal Otsu thresholding.
@@ -171,6 +184,9 @@ def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',
6. Calculate a final mask as the intersection of 3) and 5).
7. Apply final mask on the enhanced reference.

Step 1 can be skipped if the ``pre_mask`` argument is set to ``True`` and
a tentative mask is passed in to the workflow throught the ``pre_mask``
Nipype input.


.. workflow ::
@@ -183,13 +199,19 @@ def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',
**Parameters**
name : str
Name of workflow (default: ``enhance_and_skullstrip_bold_wf``)
pre_mask : bool
Indicates whether the ``pre_mask`` input will be set (and thus, step 1
should be skipped).
omp_nthreads : int
number of threads available to parallel nodes

**Inputs**

in_file
BOLD image (single volume)
pre_mask : bool
A tentative brain mask to initialize the workflow (requires ``pre_mask``
parameter set ``True``).


**Outputs**
@@ -206,48 +228,15 @@ def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',
.. _N4BiasFieldCorrection: https://hdl.handle.net/10380/3053
"""
workflow = Workflow(name=name)
inputnode = pe.Node(niu.IdentityInterface(fields=['in_file']),
inputnode = pe.Node(niu.IdentityInterface(fields=['in_file', 'pre_mask']),
name='inputnode')
outputnode = pe.Node(niu.IdentityInterface(fields=[
'mask_file', 'skull_stripped_file', 'bias_corrected_file']), name='outputnode')

bold_template = get_template('fMRIPrep') / 'tpl-fMRIPrep_space-MNI_res-02_boldref.nii.gz'
brain_mask = get_template('MNI152NLin2009cAsym') / \
'tpl-MNI152NLin2009cAsym_space-MNI_res-02_brainmask.nii.gz'

# Initialize transforms with antsAI
init_aff = pe.Node(AI(
fixed_image=str(bold_template),
fixed_image_mask=str(brain_mask),
metric=('Mattes', 32, 'Regular', 0.2),
transform=('Affine', 0.1),
search_factor=(20, 0.12),
principal_axes=False,
convergence=(10, 1e-6, 10),
verbose=True),
name='init_aff',
n_procs=omp_nthreads)

if parseversion(Registration().version) > Version('2.2.0'):
init_aff.inputs.search_grid = (40, (0, 40, 40))

# Set up spatial normalization
norm = pe.Node(Registration(
from_file=pkgr_fn(
'fmriprep.data',
'epi_atlasbased_brainmask.json')),
name='norm',
n_procs=omp_nthreads)
norm.inputs.fixed_image = str(bold_template)
# fixed_mask_trait = 'fixed_image_mask'
# if parseversion(Registration().version) >= Version('2.2.0'):
# fixed_mask_trait += 's'
# setattr(norm.inputs, fixed_mask_trait, str(brain_mask))

map_brainmask = pe.Node(
ApplyTransforms(interpolation='MultiLabel', float=True, input_image=str(brain_mask)),
name='map_brainmask'
)
# Dilate pre_mask
pre_dilate = pe.Node(fsl.DilateImage(
operation='max', kernel_shape='sphere', kernel_size=3.0,
internal_datatype='char'), name='pre_mask_dilate')

# Run N4 normally, force num_threads=1 for stability (images are small, no need for >1)
n4_correct = pe.Node(ants.N4BiasFieldCorrection(dimension=3, copy_header=True),
@@ -283,18 +272,59 @@ def init_enhance_and_skullstrip_bold_wf(name='enhance_and_skullstrip_bold_wf',
# Compute masked brain
apply_mask = pe.Node(fsl.ApplyMask(), name='apply_mask')

if not pre_mask:
bold_template = get_template('fMRIPrep') / 'tpl-fMRIPrep_space-MNI_res-02_boldref.nii.gz'
brain_mask = get_template('MNI152NLin2009cAsym') / \
'tpl-MNI152NLin2009cAsym_space-MNI_res-02_brainmask.nii.gz'

# Initialize transforms with antsAI
init_aff = pe.Node(AI(
fixed_image=str(bold_template),
fixed_image_mask=str(brain_mask),
metric=('Mattes', 32, 'Regular', 0.2),
transform=('Affine', 0.1),
search_factor=(20, 0.12),
principal_axes=False,
convergence=(10, 1e-6, 10),
verbose=True),
name='init_aff',
n_procs=omp_nthreads)

if parseversion(Registration().version) > Version('2.2.0'):
init_aff.inputs.search_grid = (40, (0, 40, 40))

# Set up spatial normalization
norm = pe.Node(Registration(
from_file=pkgr_fn(
'fmriprep.data',
'epi_atlasbased_brainmask.json')),
name='norm',
n_procs=omp_nthreads)
norm.inputs.fixed_image = str(bold_template)
map_brainmask = pe.Node(
ApplyTransforms(interpolation='MultiLabel', float=True, input_image=str(brain_mask)),
name='map_brainmask'
)
workflow.connect([
(inputnode, init_aff, [('in_file', 'moving_image')]),
(inputnode, map_brainmask, [('in_file', 'reference_image')]),
(inputnode, norm, [('in_file', 'moving_image')]),
(init_aff, norm, [('output_transform', 'initial_moving_transform')]),
(norm, map_brainmask, [
('reverse_invert_flags', 'invert_transform_flags'),
('reverse_transforms', 'transforms')]),
(map_brainmask, pre_dilate, [('output_image', 'in_file')]),
])
else:
workflow.connect([
(inputnode, pre_dilate, [('pre_mask', 'in_file')]),
])

workflow.connect([
(inputnode, init_aff, [('in_file', 'moving_image')]),
(inputnode, map_brainmask, [('in_file', 'reference_image')]),
(inputnode, norm, [('in_file', 'moving_image')]),
(init_aff, norm, [('output_transform', 'initial_moving_transform')]),
(norm, map_brainmask, [
('reverse_invert_flags', 'invert_transform_flags'),
('reverse_transforms', 'transforms')]),
(pre_dilate, n4_correct, [('out_file', 'mask_image')]),
(inputnode, n4_correct, [('in_file', 'input_image')]),
(inputnode, fixhdr_unifize, [('in_file', 'hdr_file')]),
(inputnode, fixhdr_skullstrip2, [('in_file', 'hdr_file')]),
(map_brainmask, n4_correct, [('output_image', 'mask_image')]),
(n4_correct, skullstrip_first_pass, [('output_image', 'in_file')]),
(skullstrip_first_pass, bet_dilate, [('mask_file', 'in_file')]),
(bet_dilate, bet_mask, [('out_file', 'mask_file')]),
5 changes: 4 additions & 1 deletion fmriprep/workflows/fieldmap/unwarp.py
Original file line number Diff line number Diff line change
@@ -152,7 +152,8 @@ def init_sdc_unwarp_wf(omp_nthreads, fmap_demean, debug, name='sdc_unwarp_wf'):

apply_fov_mask = pe.Node(fsl.ApplyMask(), name="apply_fov_mask")

enhance_and_skullstrip_bold_wf = init_enhance_and_skullstrip_bold_wf(omp_nthreads=omp_nthreads)
enhance_and_skullstrip_bold_wf = init_enhance_and_skullstrip_bold_wf(omp_nthreads=omp_nthreads,
pre_mask=True)

workflow.connect([
(inputnode, fmap2ref_reg, [('fmap_ref', 'moving_image')]),
@@ -187,6 +188,8 @@ def init_sdc_unwarp_wf(omp_nthreads, fmap_demean, debug, name='sdc_unwarp_wf'):
(fmap_fov2ref_apply, apply_fov_mask, [('output_image', 'mask_file')]),
(unwarp_reference, apply_fov_mask, [('output_image', 'in_file')]),
(apply_fov_mask, enhance_and_skullstrip_bold_wf, [('out_file', 'inputnode.in_file')]),
(fmap_mask2ref_apply, enhance_and_skullstrip_bold_wf,
[('output_image', 'inputnode.pre_mask')]),
(apply_fov_mask, outputnode, [('out_file', 'out_reference')]),
(enhance_and_skullstrip_bold_wf, outputnode, [
('outputnode.mask_file', 'out_mask'),
5 changes: 2 additions & 3 deletions scripts/generate_reference_mask.py
Original file line number Diff line number Diff line change
@@ -15,8 +15,7 @@ def sink_mask_file(in_file, orig_file, out_dir):


def init_main_wf(bold_file, out_dir, base_dir=None, name='main_wf'):
wf = init_bold_reference_wf(enhance_t2=True,
omp_nthreads=4,
wf = init_bold_reference_wf(omp_nthreads=4,
name=name)
wf.base_dir = base_dir
wf.inputs.inputnode.bold_file = bold_file
@@ -27,7 +26,7 @@ def init_main_wf(bold_file, out_dir, base_dir=None, name='main_wf'):
sink.inputs.orig_file = bold_file
wf.connect([
(wf.get_node('outputnode'), sink, [('bold_mask', 'in_file')]),
])
])
return wf