forked from ANTsX/ANTs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
antswithdt.sh
executable file
·152 lines (124 loc) · 4.7 KB
/
antswithdt.sh
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#!/bin/bash
NUMPARAMS=$#
MAXITERATIONS=30x90x20
export ANTSPATH=${ANTSPATH:="$HOME/bin/ants/"}
if [ $NUMPARAMS -lt 3 ]
then
echo " USAGE :: "
echo " sh ants.sh ImageDimension fixed.ext moving.ext Subject/Moving-DT-To-Deform-To-Fixed-Image OPTIONAL-Subject/Moving-BZero-To-DistortionCorrect-To-Moving-T1-Image "
echo " be sure to set ANTSPATH environment variable "
echo " Max-Iterations in form : JxKxL where "
echo " J = max iterations at coarsest resolution (here, reduce by power of 2^2) "
echo " K = middle resolution iterations ( here, reduce by power of 2 ) "
echo " L = fine resolution iterations ( here, full resolution ) -- this level takes much more time per iteration "
echo " an extra Ix before JxKxL would add another level "
echo " Default ierations is $MAXITERATIONS -- you can often get away with fewer for many apps "
echo " Other parameters are defaults used in the A. Klein evaluation paper in Neuroimage, 2009 "
echo " "
echo " The DT component is distortion corrected to the T1 image either by the B-Zero Image / Average-DWI Image "
echo " or whatever is passed as the last parameter --- Alternatively, we compute the FA from the DTI and then "
echo " distortion correct to it. One should test the validity of this approach on your data before widely applying ."
echo " We use the cross-correlation to perform the distortion correction. "
echo " Some parameter tuning may be required, depending on the distortions present in your acquisition. "
exit
fi
if [ ${#ANTSPATH} -le 3 ] ; then
echo we guess at your ants path
export ANTSPATH=${ANTSPATH:="$HOME/bin/ants/"} # EDIT THIS
fi
if [ ! -s ${ANTSPATH}/ANTS ] ; then
echo we cant find the ANTS program -- does not seem to exist. please \(re\)define \$ANTSPATH in your environment.
exit
fi
#initialization, here, is unbiased
DIM=$1
if [ ${#DIM} -gt 1 ]
then
echo " Problem with specified ImageDimension => User Specified Value = $DIM "
exit
fi
FIXED=$2
if [ ${#FIXED} -lt 1 -o ! -f $FIXED ]
then
echo " Problem with specified Fixed Image => User Specified Value = $FIXED "
exit
fi
MOVING=$3
if [ ${#MOVING} -lt 1 -o ! -f $MOVING ]
then
echo " Problem with specified Moving Image => User Specified Value = $MOVING "
exit
fi
OUTPUTNAME=${MOVING%.*.*}
if [ ${#OUTPUTNAME} -eq ${#MOVING} ]
then
OUTPUTNAME=${MOVING%.*}
fi
MOVINGDT=0
if [ $NUMPARAMS -gt 3 ]
then
MOVINGDT=$4
if [ ! -f $MOVINGDT ]
then
echo " THIS DTI DOES NOT EXIST : $MOVINGDT "
MOVINGDT=""
fi
fi
MOVINGBZ=0
if [ $NUMPARAMS -gt 4 ]
then
MOVINGBZ=$5
if [ ! -f $MOVINGBZ ]
then
echo " THIS BZero DOES NOT EXIST : $MOVINGBZ "
MOVINGBZ=0
fi
fi
if [ ${#MOVINGDT} -gt 3 ]
then
echo " The BZero DOES NOT EXIST : Using FA Instead!!"
${ANTSPATH}/ImageMath 3 ${OUTPUTNAME}_fa.nii TensorFA $MOVINGDT
MOVINGBZ=${OUTPUTNAME}_fa.nii
fi
# Mapping Parameters
TRANSFORMATION="SyN[ 0.25 ]"
ITERATLEVEL=(`echo $MAXITERATIONS | tr 'x' ' '`)
NUMLEVELS=${#ITERATLEVEL[@]}
echo $NUMLEVELS
REGULARIZATION="Gauss[ 3,0 ]"
METRIC="CC[ "
METRICPARAMS="1,2 ]"
#echo " $METRICPARAMS & $METRIC "
#exit
echo " ANTSPATH $ANTSPATH "
echo " Mapping Parameters :: "
echo " Transformation is: $TRANSFORMATION "
echo " MaxIterations : $MAXITERATIONS "
echo " Number Of MultiResolution Levels $NUMLEVELS "
echo " Regularization : $REGULARIZATION "
echo " Metric : ${METRIC} "
echo " OutputName : $OUTPUTNAME "
echo " "
echo " if the files and parameters are all ok then uncomment the exit call below this line "
echo " "
#exit
# first, do distortion correction of MOVINGDT to MOVING
# use the B0 image
${ANTSPATH}/ANTS 3 -m CC[ ${MOVINGBZ},${MOVING},1,2 ] -o ${OUTPUTNAME}distcorr -r Gauss[ 3,0 ] -t SyN[ 0.25 ] -i 25x20x0 --number-of-affine-iterations 10000x10000x10000
${ANTSPATH}/WarpImageMultiTransform 3 $MOVING ${OUTPUTNAME}distcorr.nii.gz ${OUTPUTNAME}distcorrWarp.nii.gz ${OUTPUTNAME}distcorrAffine.txt -R $MOVINGBZ
#exit
if [[ ! -s ${OUTPUTNAME}Affine.txt ]] ; then
sh ${ANTSPATH}/ants.sh $DIM $FIXED $MOVING ${OUTPUTNAME}
fi
if [[ -s ${MOVINGDT} ]] && [[ -s ${OUTPUTNAME}Affine.txt ]] ; then
DTDEF=${OUTPUTNAME}DTdeformed.nii.gz
FIXEDSUB=${OUTPUTNAME}fixedsub.nii.gz
# ${ANTSPATH}/ResampleImageBySpacing 3 $FIXED $FIXEDSUB 2 2 2
FIXEDSUB=$FIXED
echo " Warp DT "
${ANTSPATH}/WarpTensorImageMultiTransform $DIM $MOVINGDT $DTDEF ${OUTPUTNAME}Warp.nii.gz ${OUTPUTNAME}Affine.txt -i ${OUTPUTNAME}distcorrAffine.txt ${OUTPUTNAME}distcorrInverseWarp.nii.gz -R $FIXEDSUB
COMPWARP=${OUTPUTNAME}DTwarp.nii.gz
${ANTSPATH}/ComposeMultiTransform $DIM $COMPWARP -R ${FIXEDSUB} ${OUTPUTNAME}Warp.nii.gz ${OUTPUTNAME}Affine.txt -i ${OUTPUTNAME}distcorrAffine.txt ${OUTPUTNAME}distcorrInverseWarp.nii.gz
${ANTSPATH}/ReorientTensorImage 3 $DTDEF $DTDEF $COMPWARP
fi
exit