-
Notifications
You must be signed in to change notification settings - Fork 521
/
brainsresample.py
114 lines (98 loc) · 4.09 KB
/
brainsresample.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# -*- coding: utf-8 -*-
# -*- coding: utf8 -*-
"""Autogenerated file - DO NOT EDIT
If you spot a bug, please report it on the mailing list and/or change the generator."""
from nipype.interfaces.base import (
CommandLine,
CommandLineInputSpec,
SEMLikeCommandLine,
TraitedSpec,
File,
Directory,
traits,
isdefined,
InputMultiPath,
OutputMultiPath,
)
import os
class BRAINSResampleInputSpec(CommandLineInputSpec):
inputVolume = File(desc="Image To Warp", exists=True, argstr="--inputVolume %s")
referenceVolume = File(
desc="Reference image used only to define the output space. If not specified, the warping is done in the same space as the image to warp.",
exists=True,
argstr="--referenceVolume %s",
)
outputVolume = traits.Either(
traits.Bool,
File(),
hash_files=False,
desc="Resulting deformed image",
argstr="--outputVolume %s",
)
pixelType = traits.Enum(
"float",
"short",
"ushort",
"int",
"uint",
"uchar",
"binary",
desc="Specifies the pixel type for the input/output images. The 'binary' pixel type uses a modified algorithm whereby the image is read in as unsigned char, a signed distance map is created, signed distance map is resampled, and then a thresholded image of type unsigned char is written to disk.",
argstr="--pixelType %s",
)
deformationVolume = File(
desc="Displacement Field to be used to warp the image",
exists=True,
argstr="--deformationVolume %s",
)
warpTransform = File(
desc="Filename for the BRAINSFit transform used in place of the deformation field",
exists=True,
argstr="--warpTransform %s",
)
interpolationMode = traits.Enum(
"NearestNeighbor",
"Linear",
"ResampleInPlace",
"BSpline",
"WindowedSinc",
"Hamming",
"Cosine",
"Welch",
"Lanczos",
"Blackman",
desc="Type of interpolation to be used when applying transform to moving volume. Options are Linear, ResampleInPlace, NearestNeighbor, BSpline, or WindowedSinc",
argstr="--interpolationMode %s",
)
inverseTransform = traits.Bool(
desc="True/False is to compute inverse of given transformation. Default is false",
argstr="--inverseTransform ",
)
defaultValue = traits.Float(desc="Default voxel value", argstr="--defaultValue %f")
gridSpacing = InputMultiPath(
traits.Int,
desc="Add warped grid to output image to help show the deformation that occured with specified spacing. A spacing of 0 in a dimension indicates that grid lines should be rendered to fall exactly (i.e. do not allow displacements off that plane). This is useful for makeing a 2D image of grid lines from the 3D space ",
sep=",",
argstr="--gridSpacing %s",
)
numberOfThreads = traits.Int(
desc="Explicitly specify the maximum number of threads to use.",
argstr="--numberOfThreads %d",
)
class BRAINSResampleOutputSpec(TraitedSpec):
outputVolume = File(desc="Resulting deformed image", exists=True)
class BRAINSResample(SEMLikeCommandLine):
"""title: Resample Image (BRAINS)
category: Registration
description:
This program resamples an image image using a deformation field or a transform (BSpline, Affine, Rigid, etc.).
version: 3.0.0
documentation-url: http://www.slicer.org/slicerWiki/index.php/Modules:BRAINSResample
license: https://www.nitrc.org/svn/brains/BuildScripts/trunk/License.txt
contributor: This tool was developed by Vincent Magnotta, Greg Harris, and Hans Johnson.
acknowledgements: The development of this tool was supported by funding from grants NS050568 and NS40068 from the National Institute of Neurological Disorders and Stroke and grants MH31593, MH40856, from the National Institute of Mental Health.
"""
input_spec = BRAINSResampleInputSpec
output_spec = BRAINSResampleOutputSpec
_cmd = "BRAINSResample "
_outputs_filenames = {"outputVolume": "outputVolume.nii"}