-
Notifications
You must be signed in to change notification settings - Fork 297
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
[FIX] Remove non-steady-state volumes prior to ICA-AROMA #1335
Conversation
…y state volumes from aroma calculation
… remove_init_vol_aroma
fmriprep/workflows/bold/base.py
Outdated
@@ -424,6 +425,9 @@ def init_func_preproc_wf(bold_file, ignore, freesurfer, | |||
omp_nthreads=omp_nthreads, | |||
use_compression=False) | |||
|
|||
# get non steady-state volumes | |||
non_steady_state = pe.Node(nac.NonSteadyStateDetector(), name='non_steady_state') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You should already be able to get this from bold_reference_wf.outputnode.skip_vols
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice, thanks!
…nd use nonsteady calculation from bold_reference_wf (review by effigies)
ae48390
to
11ea1c2
Compare
If I wanted to write tests for the semi-private functions, where should I put them? Should I test them? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This overall looks good. I left some comments on these functions.
I think testing is a good idea. The rule for tests is: if the function you're testing is in a/b/c.py
, the test should be in a/b/tests/test_c.py
. So let's put them in fmriprep/workflows/bold/tests/test_confounds.py
.
fmriprep/workflows/bold/confounds.py
Outdated
(ica_aroma, ds_report_ica_aroma, [('out_report', 'in_file')]), | ||
]) | ||
|
||
return workflow | ||
|
||
|
||
def _remove_volumes(bold_file, skip_vols): | ||
import nibabel as nb |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Over-indented.
fmriprep/workflows/bold/confounds.py
Outdated
# save the resulting bold file | ||
out = fname_presuffix(bold_file, suffix='_cut') | ||
bold_img.__class__(bold_data_cut, bold_img.affine, bold_img.header).to_filename(out) | ||
return out |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This could be much shorter:
import nibabel as nb
from nipype.utils.filemanip import fname_presuffix
out = fname_presuffix(bold_file, suffix='_cut')
bold_img = nb.load(bold_file)
bold_img.__class__(bold_img.dataobj[..., skip_vols:],
bold_img.affine, bold_img.header).to_filename(out)
return out
Note that the data shape will be set automatically, so there's no need to manually update it. And using the dataobj
should save as much memory as you can, though I don't think there's much waste here, assuming skip_vols
is small.
Or, with nibabel>=2.3:
import nibabel as nb
from nipype.utils.filemanip import fname_presuffix
out = fname_presuffix(bold_file, suffix='_cut')
nb.load(bold_file).slicer[..., skip_vols:].to_filename(out)
return out
fmriprep/workflows/bold/confounds.py
Outdated
bold_cut_data = bold_cut_img.get_data() | ||
|
||
# assign everything from skip_vols foward to bold_cut_data | ||
bold_data[..., skip_vols:] = bold_cut_data |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What about:
bold_img = nb.load(bold_file)
bold_cut_img = nb.load(bold_cut_file)
bold_data = np.concatenate((bold_img.dataobj[..., :skip_vols],
bold_cut_img.dataobj), axis=3)
This would reduce the memory usage by the uncompressed size of bold_cut_img
.
Or, if we're willing to require nibabel>=2.3
:
new_img = nb.concat_images((bold_img.slicer[..., :skip_vols], bold_cut_img), axis=3)
This last has the advantage of checking affines to ensure the images are in the same space.
fmriprep/workflows/bold/confounds.py
Outdated
import nibabel as nb | ||
from nipype.utils.filemanip import fname_presuffix | ||
|
||
# load the bold file and get the 4d matrix |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Before doing anything else, I would check:
if skip_vols == 0:
return bold_file
fmriprep/workflows/bold/confounds.py
Outdated
import nibabel as nb | ||
from nipype.utils.filemanip import fname_presuffix | ||
|
||
# load the data |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if skip_vols == 0:
return bold_cut_file
@jdkent We're trying to update to be largely conformant with BIDS Derivatives RC2 (due out Friday-ish). That will trigger fMRIPrep 1.2.0. Do you want to get this in by then, or do you need more time? |
Hi @effigies, Thanks for the helpful review! I've integrated the changes you suggested in the last commit, but I have not written tests yet. I think I will be able generate tests by friday, but if not, I can make it a separate pull request, and have this one merged as is (if all the tests pass). |
fmriprep/workflows/bold/confounds.py
Outdated
Do not fail on ICA-AROMA errors | ||
aroma_melodic_dim: int or None | ||
Set the dimensionality of the Melodic ICA decomposition | ||
If None, MELODIC automatically estimates dimensionality. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It looks like you sorted these. I would keep these in the order that they are in the parameter list. If we want to reorder that, we can do that in another PR, but that's an API change, and we should avoid it unless there's a good reason.
This looks reasonable to me. I'm okay with making tests a separate PR, if you can't get that in by Friday. @oesteban WDYT? |
@jdkent I'm going to go ahead and merge. Please submit tests in a new PR. |
Thanks @effigies, I should be able to get those tests in on Monday. |
Changes proposed in this pull request
ref nipreps/fmripost-aroma#13
ref #1300
This pull request pulls the steady state detector into
bold/base.py
and uses it's output for both the confounds workflow and the aroma workflow.Documentation that should be reviewed
I need to update the documentation for ica-aroma, more details to come...