# emacs: -*- mode: python; py-indent-offset: 4; indent-tabs-mode: nil -*-# vi: set ft=python sts=4 ts=4 sw=4 et:## Copyright 2023 The NiPreps Developers <nipreps@gmail.com>## Licensed under the Apache License, Version 2.0 (the "License");# you may not use this file except in compliance with the License.# You may obtain a copy of the License at## http://www.apache.org/licenses/LICENSE-2.0## Unless required by applicable law or agreed to in writing, software# distributed under the License is distributed on an "AS IS" BASIS,# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.# See the License for the specific language governing permissions and# limitations under the License.## We support and encourage derived works from this project, please read# about our expectations at## https://www.nipreps.org/community/licensing/#"""Build the SDCFlows' standalone workflow."""
[docs]defbuild_workflow(config_file,retval):"""Create the Nipype Workflow that supports the whole execution graph."""importos# We do not need OMP > 1 for workflow creationos.environ["OMP_NUM_THREADS"]="1"fromsdcflowsimportconfigfromsdcflows.workflows.fit.baseimportinit_sdcflows_wfconfig.load(config_file)# Initialize nipype configconfig.nipype.init()# Make sure loggers are startedconfig.loggers.init()config.loggers.cli.log(25,f"""\Running SDCFlows {config.environment.version}: * BIDS dataset path: {config.execution.bids_dir}. * Output folder: {config.execution.output_dir}. * Analysis levels: {config.workflow.analysis_level}.""")retval["return_code"]=1retval["workflow"]=Noneretval["workflow"]=init_sdcflows_wf()retval["return_code"]=int(retval["workflow"]isNone)returnretval