|
22 | 22 | # |
23 | 23 | """Test fieldmap-less SDC-SyN.""" |
24 | 24 | import json |
| 25 | + |
| 26 | +import numpy as np |
| 27 | +import nibabel as nb |
25 | 28 | import pytest |
26 | 29 | from nipype.pipeline import engine as pe |
27 | 30 |
|
28 | | -from ..syn import init_syn_sdc_wf, init_syn_preprocessing_wf, _adjust_zooms, _set_dtype |
| 31 | +from .... import data |
| 32 | +from ..syn import init_syn_sdc_wf, init_syn_preprocessing_wf, _adjust_zooms, _set_dtype, _mm2vox |
29 | 33 |
|
30 | 34 |
|
31 | 35 | @pytest.mark.veryslow |
@@ -211,3 +215,27 @@ def test_ensure_dtype(in_dtype, out_dtype, tmpdir): |
211 | 215 | assert out_file == f"{in_dtype}.nii.gz" |
212 | 216 | else: |
213 | 217 | assert out_file == f"{in_dtype}_{out_dtype}.nii.gz" |
| 218 | + |
| 219 | + |
| 220 | +def test_mm2vox(tmp_path): |
| 221 | + img = nb.Nifti1Image(np.zeros((10, 10, 10)), np.diag((2, 3, 4, 1))) |
| 222 | + img_file = tmp_path / "test.nii.gz" |
| 223 | + img.to_filename(img_file) |
| 224 | + |
| 225 | + config = json.loads(data.load.readable("sd_syn.json").read_text()) |
| 226 | + |
| 227 | + params = config['transform_parameters'] |
| 228 | + mm_values = np.array([level[2] for level in params]) |
| 229 | + |
| 230 | + vox_params_i = _mm2vox(str(img_file), 'i', config) |
| 231 | + vox_values_i = [level[2] for level in vox_params_i] |
| 232 | + assert [mm_level[:2] == vox_level[:2] for mm_level, vox_level in zip(params, vox_params_i)] |
| 233 | + assert np.array_equal(vox_values_i, mm_values / 2) |
| 234 | + |
| 235 | + vox_params_j = _mm2vox(str(img_file), 'j', config) |
| 236 | + vox_values_j = [level[2] for level in vox_params_j] |
| 237 | + assert np.array_equal(vox_values_j, mm_values / 3) |
| 238 | + |
| 239 | + vox_params_k = _mm2vox(str(img_file), 'k', config) |
| 240 | + vox_values_k = [level[2] for level in vox_params_k] |
| 241 | + assert np.array_equal(vox_values_k, mm_values / 4) |
0 commit comments