Skip to content

Commit

Permalink
fix: do not accept multiple files
Browse files Browse the repository at this point in the history
  • Loading branch information
oesteban committed Jun 30, 2023
1 parent 6cfc678 commit fe4faf1
Showing 1 changed file with 16 additions and 36 deletions.
52 changes: 16 additions & 36 deletions sdcflows/interfaces/bspline.py
Original file line number Diff line number Diff line change
Expand Up @@ -288,9 +288,7 @@ def _run_interface(self, runtime):


class _ApplyCoeffsFieldInputSpec(BaseInterfaceInputSpec):
in_data = InputMultiObject(
File(exist=True, mandatory=True, desc="input EPI data to be corrected")
)
in_data = File(exist=True, mandatory=True, desc="input EPI data to be corrected")
in_coeff = InputMultiObject(
File(exists=True),
mandatory=True,
Expand All @@ -300,23 +298,17 @@ class _ApplyCoeffsFieldInputSpec(BaseInterfaceInputSpec):
exists=True,
desc="the transform by which the fieldmap can be resampled on the target EPI's grid.",
)
in_xfms = InputMultiObject(
File(exists=True), desc="list of head-motion correction matrices"
)
ro_time = InputMultiObject(
traits.Float(mandatory=True, desc="EPI readout time (s).")
)
pe_dir = InputMultiObject(
traits.Enum(
"i",
"i-",
"j",
"j-",
"k",
"k-",
mandatory=True,
desc="the phase-encoding direction corresponding to in_data",
)
in_xfms = File(exists=True, desc="list of head-motion correction matrices")
ro_time = traits.Float(mandatory=True, desc="EPI readout time (s).")
pe_dir = traits.Enum(
"i",
"i-",
"j",
"j-",
"k",
"k-",
mandatory=True,
desc="the phase-encoding direction corresponding to in_data",
)
num_threads = traits.Int(nohash=True, desc="number of threads")
approx = traits.Bool(
Expand Down Expand Up @@ -373,18 +365,6 @@ class ApplyCoeffsField(SimpleInterface):
def _run_interface(self, runtime):
from sdcflows.transform import B0FieldTransform

n = len(self.inputs.in_data)

ro_time = self.inputs.ro_time
if len(ro_time) == 1:
ro_time *= n

pe_dir = self.inputs.pe_dir
if len(pe_dir) == 1:
pe_dir *= n

unwarp = None

# Pre-cached interpolator object
unwarp = B0FieldTransform(coeffs=[nb.load(cname) for cname in self.inputs.in_coeff])

Expand All @@ -402,12 +382,12 @@ def _run_interface(self, runtime):
# self._results["out_field"] = out_field

# HMC matrices are only necessary when reslicing the data (i.e., apply())
hmc_mats = None
# Check the length of in_xfms matches that of in_data
self._results["out_corrected"] = unwarp.apply(
self.inputs.in_data,
pe_dir,
ro_time,
xfms=hmc_mats,
self.inputs.pe_dir,
self.input.ro_time,
xfms=self.inputs.in_xfms,
# num_threads=(
# None if not isdefined(self.inputs.num_threads) else self.inputs.num_threads
# ),
Expand Down

0 comments on commit fe4faf1

Please sign in to comment.