import os
from nipype.interfaces import utility as util
from CPAC.pipeline import nipype_pipeline_engine as pe
from CPAC.utils.configuration import Configuration
from CPAC.utils.datasource import resolve_resolution
from CPAC.utils.interfaces.function import Function
from CPAC.utils.strategy import Strategy
[docs]
def file_node(path, file_node_num=0):
input_node = pe.Node(
util.IdentityInterface(fields=["file"]),
name=f"file_node_{file_node_num}",
)
input_node.inputs.file = path
return input_node, "file"
[docs]
def configuration_strategy_mock(method="FSL"):
fsldir = os.environ.get("FSLDIR")
# mock the config dictionary
c = Configuration(
{
"pipeline_setup": {
"output_directory": {
"path": "/output/output/pipeline_analysis_nuisance/"
"sub-M10978008_ses-NFB3"
},
"working_directory": {"path": "/scratch/pipeline_tests"},
"system_config": {"num_ants_threads": 4},
},
"registration_workflows": {
"functional_registration": {
"EPI_registration": {
"FSL-FNIRT": {
"identity_matrix": f"{fsldir}/etc/flirtsch/ident.mat",
"interpolation": "sinc",
}
},
"func_registration_to_template": {
"ANTs_pipelines": {"interpolation": "LanczosWindowedSinc"},
"output_resolution": {
"func_preproc_outputs": "3mm",
"func_derivative_outputs": "3mm",
},
"target_template": {
"T1_template": {
"T1w_template_for_resample": f"{fsldir}/"
"data/standard/"
"MNI152_T1_1mm_brain."
"nii.gz",
"T1w_brain_template_funcreg": f"{fsldir}/"
"data/standard/"
"MNI152_T1_"
"${resolution_for_"
"func_preproc}_"
"brain.nii.gz",
"T1w_template_funcreg": f"{fsldir}/data/"
"standard/MNI152_T1_"
"${resolution_for_func_"
"preproc}.nii.gz",
}
},
},
}
},
"post_processing": {"spatial_smoothing": {"fwhm": [2, 3, 4]}},
}
)
if method == "ANTS":
c.update("regOption", "ANTS")
else:
c.update("regOption", "FSL")
# mock the strategy
strat = Strategy()
resource_dict = {
"functional_nuisance_residuals": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"motion_correct/_scan_test/"
"sub-M10978008_ses-NFB3_task-test_bold_calc_tshift_resample_"
"volreg.nii.gz",
),
"mean_functional": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"mean_functional/"
"sub-M10978008_ses-NFB3_task-test_bold_calc_tshift_resample_"
"volreg_calc_tstat.nii.gz",
),
"functional_brain_mask": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"functional_brain_mask/_scan_test/"
"sub-M10978008_ses-NFB3_task-test_bold_calc_tshift_resample_"
"volreg_mask.nii.gz",
),
"motion_correct": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"motion_correct/_scan_test/"
"sub-M10978008_ses-NFB3_task-test_bold_calc_tshift_resample_"
"volreg.nii.gz",
),
"anatomical_brain": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"anatomical_brain/sub-M10978008_ses-NFB3_acq-ao_brain_resample.nii.gz",
),
"ants_initial_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_initial_xfm/transform0DerivedInitialMovingTranslation.mat",
),
"ants_affine_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_affine_xfm/transform2Affine.mat",
),
"ants_rigid_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_rigid_xfm/transform1Rigid.mat",
),
"anatomical_to_mni_linear_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"anatomical_to_mni_linear_xfm/"
"sub-M10978008_ses-NFB3_T1w_resample_calc_flirt.mat",
),
"functional_to_anat_linear_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"functional_to_anat_linear_xfm/_scan_test/"
"sub-M10978008_ses-NFB3_task-test_bold_calc_tshift_resample_"
"volreg_calc_tstat_flirt.mat",
),
"ants_symm_warp_field": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"anatomical_to_symmetric_mni_nonlinear_xfm/transform3Warp.nii.gz",
),
"ants_symm_affine_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_symmetric_affine_xfm/transform2Affine.mat",
),
"ants_symm_rigid_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_symmetric_rigid_xfm/transform1Rigid.mat",
),
"ants_symm_initial_xfm": os.path.join(
c["pipeline_setup", "output_directory", "path"],
"ants_symmetric_initial_xfm/"
"transform0DerivedInitialMovingTranslation.mat",
),
"dr_tempreg_maps_files": [
os.path.join(
"/scratch",
"resting_preproc_sub-M10978008_ses-NFB3_cpac105",
"temporal_dual_regression_0/_scan_test/"
"_selector_CSF-2mmE-M_aC-WM-2mmE-DPC5_G-M_M-SDB_P-2/"
"_spatial_map_PNAS_Smith09_rsn10_spatial_map_file_"
"..cpac_templates..PNAS_Smith09_rsn10.nii.gz/"
f"split_raw_volumes/temp_reg_map_000{n}.nii.gz",
)
for n in range(10)
],
}
if method == "ANTS":
resource_dict["anatomical_to_mni_nonlinear_xfm"] = os.path.join(
c["pipeline_setup", "output_directory", "path"],
"anatomical_to_mni_nonlinear_xfm/transform3Warp.nii.gz",
)
else:
resource_dict["anatomical_to_mni_nonlinear_xfm"] = os.path.join(
c["pipeline_setup", "output_directory", "path"],
"anatomical_to_mni_nonlinear_xfm/"
"sub-M10978008_ses-NFB3_T1w_resample_fieldwarp.nii.gz",
)
file_node_num = 0
for resource, filepath in resource_dict.items():
strat.update_resource_pool({resource: file_node(filepath, file_node_num)})
strat.append_name(resource + "_0")
file_node_num += 1
templates_for_resampling = [
(
c[
"registration_workflows",
"functional_registration",
"func_registration_to_template",
"output_resolution",
"func_preproc_outputs",
],
c[
"registration_workflows",
"functional_registration",
"func_registration_to_template",
"target_template",
"T1_template",
"T1w_brain_template_funcreg",
],
"template_brain_for_func_preproc",
"resolution_for_func_preproc",
),
(
c[
"registration_workflows",
"functional_registration",
"func_registration_to_template",
"output_resolution",
"func_preproc_outputs",
],
c[
"registration_workflows",
"functional_registration",
"func_registration_to_template",
"target_template",
"T1_template",
"T1w_brain_template_funcreg",
],
"template_skull_for_func_preproc",
"resolution_for_func_preproc",
),
]
for resolution, template, template_name, tag in templates_for_resampling:
resampled_template = pe.Node(
Function(
input_names=["resolution", "template", "template_name", "tag"],
output_names=["resampled_template"],
function=resolve_resolution,
as_module=True,
),
name="resampled_" + template_name,
)
resampled_template.inputs.resolution = resolution
resampled_template.inputs.template = template
resampled_template.inputs.template_name = template_name
resampled_template.inputs.tag = tag
resampled_template.inputs.orientation = "RPI"
strat.update_resource_pool(
{template_name: (resampled_template, "resampled_template")}
)
strat.append_name("resampled_template_0")
return c, strat