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

Track Sources for outputs with BIDS URIs #966

Merged
merged 64 commits into from
Oct 20, 2023
Merged
Changes from 1 commit
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
32f4ed1
Track sources for some outputs.
tsalo Oct 10, 2023
e64c4c1
Update bids.py
tsalo Oct 10, 2023
a64cddb
Fix maybe?
tsalo Oct 10, 2023
7edfd13
Well that's silly.
tsalo Oct 10, 2023
a54afa9
Try that.
tsalo Oct 10, 2023
e6395c3
Try patching connection.
tsalo Oct 10, 2023
b96b9c4
Whoops.
tsalo Oct 10, 2023
b391c0b
ugh
tsalo Oct 10, 2023
719f5ea
Update outputs.
tsalo Oct 10, 2023
b8df302
Update bids.py
tsalo Oct 10, 2023
e60a656
Update concatenation.py
tsalo Oct 10, 2023
9649f45
Merge branch 'main' into track-sources
tsalo Oct 10, 2023
7880f8a
Update concatenation.py
tsalo Oct 11, 2023
9d4287e
Update concatenation.py
tsalo Oct 11, 2023
6adc88d
Update expected outputs.
tsalo Oct 11, 2023
36128c2
Fix outputs.
tsalo Oct 11, 2023
dd4f805
More work.
tsalo Oct 11, 2023
7b4731f
Merge branch 'main' into track-sources
tsalo Oct 11, 2023
717564c
Whoops!
tsalo Oct 11, 2023
f6c367e
Connect the datasink.
tsalo Oct 11, 2023
caa9b15
Update outputs.
tsalo Oct 11, 2023
f948750
Make Sources an iterfield.
tsalo Oct 11, 2023
8f7d67f
Update outputs.py
tsalo Oct 11, 2023
9e923aa
Update.
tsalo Oct 11, 2023
41750ba
Add "Sources".
tsalo Oct 11, 2023
ad93edf
update
tsalo Oct 11, 2023
544a093
Give this a try.
tsalo Oct 13, 2023
6905ac9
Whoops
tsalo Oct 13, 2023
5e83d7d
Merge remote-tracking branch 'upstream/main' into track-sources
tsalo Oct 13, 2023
8642bfb
Try that!
tsalo Oct 13, 2023
dcaef91
Update expected outputs.
tsalo Oct 13, 2023
6712e0e
Fill in TODO list.
tsalo Oct 13, 2023
e80cce5
Reorder datasinks.
tsalo Oct 14, 2023
30463f5
Simplify outputs workflow.
tsalo Oct 14, 2023
ed154b6
Keep working.
tsalo Oct 14, 2023
66be748
Keep working.
tsalo Oct 14, 2023
305b990
Update outputs.py
tsalo Oct 14, 2023
23a5f09
Update things.
tsalo Oct 14, 2023
91c7df7
Update outputs.py
tsalo Oct 14, 2023
5c87661
Allow lists.
tsalo Oct 15, 2023
53f01cc
Copy the dictionary.
tsalo Oct 15, 2023
d5f1376
Transpose list of lists.
tsalo Oct 15, 2023
2d0d27f
Update concatenation.py
tsalo Oct 15, 2023
d3d5e09
update
tsalo Oct 15, 2023
8ee7fe6
Update outputs.py
tsalo Oct 15, 2023
223ef42
Update outputs.py
tsalo Oct 15, 2023
c560f30
Update things.
tsalo Oct 15, 2023
d815d7f
Update outputs.py
tsalo Oct 15, 2023
10379ff
Update outputs.py
tsalo Oct 15, 2023
4386480
Update expected outputs.
tsalo Oct 15, 2023
bdaf171
Add docstrings and tests.
tsalo Oct 16, 2023
aba3e1b
Update.
tsalo Oct 16, 2023
551bfc0
Try fixing tests.
tsalo Oct 16, 2023
2b169d6
Fix tests.
tsalo Oct 16, 2023
65a1da9
Maybe fix bug?
tsalo Oct 16, 2023
0aceec3
Add SamplingFrequency to time series files.
tsalo Oct 17, 2023
385f6f3
Try this.
tsalo Oct 17, 2023
dcc2ea8
Work around badness.
tsalo Oct 17, 2023
16a3c9f
Remove InferBIDSURIs.
tsalo Oct 17, 2023
922cfc7
Improve test coverage.
tsalo Oct 17, 2023
ae63e8e
Fix test maybe.
tsalo Oct 17, 2023
8a7e248
Fix test.
tsalo Oct 17, 2023
3567ff2
Merge remote-tracking branch 'upstream/main' into track-sources
tsalo Oct 20, 2023
8886cb8
Remove duplicate expected outputs.
tsalo Oct 20, 2023
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
Prev Previous commit
Next Next commit
Update outputs.py
tsalo committed Oct 15, 2023
commit d815d7f8a533e711941fd32d89048aa41eb5b3ac
83 changes: 42 additions & 41 deletions xcp_d/workflows/outputs.py
Original file line number Diff line number Diff line change
@@ -395,36 +395,50 @@ def _custom_to_source(out_file):
])
# fmt:on

ds_temporal_mask = pe.Node(
DerivativesDataSink(
base_directory=output_dir,
dismiss_entities=["atlas", "den", "res", "space", "cohort", "desc"],
suffix="outliers",
extension=".tsv",
source_file=name_source,
# Metadata
Threshold=fd_thresh,
),
name="ds_temporal_mask",
merge_dense_src = pe.Node(
niu.Merge(numinputs=(1 + (1 if fd_thresh > 0 else 0) + (1 if params != "none" else 0))),
name="merge_dense_src",
run_without_submitting=True,
mem_gb=1,
)
# fmt:off
workflow.connect([
(inputnode, ds_temporal_mask, [
("temporal_mask_metadata", "meta_dict"),
("temporal_mask", "in_file"),
]),
(ds_filtered_motion, ds_temporal_mask, [
(("out_file", _postproc_to_source, output_dir), "Sources"),
]),
(ds_temporal_mask, outputnode, [("out_file", "temporal_mask")]),
])
# fmt:on
merge_dense_src.inputs.in1 = preproc_bold_src

if fd_thresh > 0:
ds_temporal_mask = pe.Node(
DerivativesDataSink(
base_directory=output_dir,
dismiss_entities=["atlas", "den", "res", "space", "cohort", "desc"],
suffix="outliers",
extension=".tsv",
source_file=name_source,
# Metadata
Threshold=fd_thresh,
),
name="ds_temporal_mask",
run_without_submitting=True,
mem_gb=1,
)
# fmt:off
workflow.connect([
(inputnode, ds_temporal_mask, [
("temporal_mask_metadata", "meta_dict"),
("temporal_mask", "in_file"),
]),
(ds_filtered_motion, ds_temporal_mask, [
(("out_file", _postproc_to_source, output_dir), "Sources"),
]),
(ds_temporal_mask, outputnode, [("out_file", "temporal_mask")]),
(ds_temporal_mask, merge_dense_src, [
(("out_file", _postproc_to_source, output_dir), "in2"),
]),
])
# fmt:on

if params != "none":
confounds_src = pe.Node(
niu.Merge(numinputs=3 if custom_confounds_file else 2),
niu.Merge(
numinputs=(1 + (1 if fd_thresh > 0 else 0) + (1 if custom_confounds_file else 0))
),
name="confounds_src",
run_without_submitting=True,
mem_gb=1,
@@ -436,7 +450,7 @@ def _custom_to_source(out_file):
(("out_file", _postproc_to_source, output_dir), "in2"),
]),
])
# fmt:on
# fmt:off
if custom_confounds_file:
confounds_src.inputs.in3 = _custom_to_source(custom_confounds_file)

@@ -456,25 +470,12 @@ def _custom_to_source(out_file):
workflow.connect([
(inputnode, ds_confounds, [("confounds_file", "in_file")]),
(confounds_src, ds_confounds, [("out", "Sources")]),
(ds_confounds, merge_dense_src, [
(("out_file", _postproc_to_source, output_dir), f"in{3 if fd_thresh > 0 else 2}"),
]),
])
# fmt:on

merge_dense_src = pe.Node(
niu.Merge(numinputs=3),
name="merge_dense_src",
run_without_submitting=True,
mem_gb=1,
)
merge_dense_src.inputs.in1 = preproc_bold_src
# fmt:off
workflow.connect([
(ds_confounds, merge_dense_src, [(("out_file", _postproc_to_source, output_dir), "in2")]),
(ds_temporal_mask, merge_dense_src, [
(("out_file", _postproc_to_source, output_dir), "in3"),
]),
])
# fmt:on

# Write out derivatives via DerivativesDataSink
ds_denoised_bold = pe.Node(
DerivativesDataSink(