forked from danjonpeterson/dti_preproc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmotion_correct_report.sh
executable file
·192 lines (140 loc) · 6.76 KB
/
motion_correct_report.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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
#! /bin/sh
#example usage
#motion_correct_report.sh -t temp-motion_correct -r report-motion_correct -o dti_v2 -k DTI_64.nii.gz
#---------variables---------#
tmpdir=`mktemp -d /tmp/temp-motion_correctXXXX` # name of directory for intermediate files
method=not_entered
reportdir=motion_correct_report # report dir
logfile_name=motion_correct_report.log # Log file
outdir=.
dti=DTI_64.nii.gz
scale_and_skew=n
scriptdir=`dirname $0`
#----------- Utility Functions ----------#
usage_exit() {
cat <<EOF
Generates report for motion and eddy current correction
Usage:
$CMD -t <directory with intermediade files from unwarp_fieldmap> -r <directory to put the generated reports> -o <output directory> -k <input 4D dti file> -m method -i <index file if using topup>
EOF
exit 1;
}
T () {
E=0
if [ "$1" = "-e" ] ; then # just outputting and logging a message with T -e
E=1; shift
fi
cmd="$*"
echo $* | tee -a $LF # read the command into the console, and the log file
if [ "$E" != "1" ] ; then
$cmd 2>&1 | tee -a $LF # run the command. read the output into a the log file. Stderr is not directed to the logfile
fi
echo | tee -a $LF # write an empty line to the console and log file
}
threecolumnmeansd () {
mean=`cat $1 | awk 'BEGIN {x=0;y=0;z=0;N=0};{x=x+$1;y=y+$2;z=z+$3;N=N+1}END {printf("%f, %f, %f",x/N,y/N,z/N)}'`
xm=`echo $mean | awk '{print $1}'`; ym=`echo $mean | awk '{print $2}'`; zm=`echo $mean | awk '{print $3}'`
sd=`cat $1 | awk 'BEGIN {x=0;y=0;z=0;N=0};{x=x+($1-"$xm")^2;y=y+($2-"$ym")^2;z=z+($3-"$zm")^2;N=N+1}END {printf("%f, %f, %f",sqrt(x/N),sqrt(y/N),sqrt(z/N))}'`
echo $mean $sd
}
#------------- Parse Parameters --------------------#
while getopts t:r:s:o:k:m:i: OPT
do
case "$OPT" in
"t" ) tmpdir="$OPTARG";;
"r" ) reportdir="$OPTARG";;
"o" ) outdir="$OPTARG";;
"k" ) dti="$OPTARG";;
"m" ) method="$OPTARG";;
"i" ) index="$OPTARG";;
* ) usage_exit;;
esac
done;
#------------- Begin report --------------------#
LF=$reportdir/$logfile_name
RF=$reportdir/motion_correct_report
if [ -e $reportdir ]; then /bin/rm -Rf $reportdir;fi
mkdir -p $reportdir
echo "---"> ${RF}.Rmd
echo "title: QA report for correction of subject motion and eddy-current induced distortions ">> ${RF}.Rmd
echo "output:" >> ${RF}.Rmd
echo " html_document: " >> ${RF}.Rmd
echo " keep_md: yes " >> ${RF}.Rmd
echo " toc: yes " >> ${RF}.Rmd
echo " force_captions: TRUE " >> ${RF}.Rmd
echo "---">> ${RF}.Rmd
echo \# MOTION CORRECTION REPORT >> ${RF}.Rmd
echo "__motion correction method: $method __\n" >> ${RF}.Rmd
## framewise displacement
dtidim4=`echo $tmpdir/dti_ecc.mat/* | wc -w`
echo "__number of volumes: $dtidim4 __\n" >> ${RF}.Rmd
i=2 #start at the second entry (b/c we are comparing this and the previous one)
while [ $i -lt `expr $dtidim4 + 1` ]; do ## loop through DWIs
prev=`expr $i - 1`
# when zero-indexed
i_zi=`expr $i - 1`
prev_zi=`expr $i - 2`
i_zi_pad=`zeropad $i_zi 4`
prev_zi_pad=`zeropad $prev_zi 4`
# awk is not zero-indexed
if [ "$method" = "eddy_with_topup" ]; then
index_entry=`cat $index | awk -v n=$i '{print $n}'`
prev_index_entry=`cat $index | awk -v n=$prev '{print $n}'`
fi
# skip seams in the index file
if [ "$method" != "eddy_with_topup" ] || [ "$index_entry" = "$prev_index_entry" ]; then
# MC xform matrices ARE zero-indexed
# T rmsdiff $tmpdir/dti_ecc.mat/MAT_$prev_zi_pad $tmpdir/dti_ecc.mat/MAT_$i_zi_pad $dti
echo `rmsdiff $tmpdir/dti_ecc.mat/MAT_$prev_zi_pad $tmpdir/dti_ecc.mat/MAT_$i_zi_pad $dti` >> $reportdir/framewise_displacement.par
else
echo " Removing $prev -to- $i step from FWD calculation \n" >> ${RF}.Rmd
fi
i=`expr $i + 1`
done ## end while loop across DWIs
mean_fwd=`cat $reportdir/framewise_displacement.par | awk '{ sum += $1; n++ } END { if (n > 0) print sum / n; }'`
echo sd max median mean > $reportdir/fwd_summary.par
Rscript -e 'd<-scan("stdin", quiet=TRUE)' \
-e 'cat(c(sd(d), max(d), median(d), mean(d), sep="\n"))' < $reportdir/framewise_displacement.par > $reportdir/fwd_summary.par
echo "## Relative Framewise Displacement" >> ${RF}.Rmd
echo "__Mean: `cat $reportdir/fwd_summary.par | awk '{print $4}'` __ \n" >> ${RF}.Rmd
echo "__Median: `cat $reportdir/fwd_summary.par | awk '{print $3}'` __ \n" >> ${RF}.Rmd
echo "__Max: `cat $reportdir/fwd_summary.par | awk '{print $2}'` __ \n" >> ${RF}.Rmd
echo "__Standard Deviation: `cat $reportdir/fwd_summary.par | awk '{print $1}'` __ \n" >> ${RF}.Rmd
T fsl_tsplot -i $reportdir/framewise_displacement.par -o $reportdir/fwd.png -t "Framewise_Displacement" -y "[mm]" -x "Volume"
echo "data:image/s3,"s3://crabby-images/ce146/ce14658fbfe2396d6dcc2196e5c627eae9e53090" alt="" \n" >> ${RF}.Rmd
## generate rotation and translation plots
T fsl_tsplot -i $tmpdir/translation.par -o $reportdir/translation.png -t "Translation" -y [mm] -x Volume -a x,y,z
T fsl_tsplot -i $tmpdir/rotation.par -o $reportdir/rotation.png -t "Rotation" -y [degree] -x Volume -a x,y,z
echo "## Absolute Displacement" >> ${RF}.Rmd
meandisl=`cat $tmpdir/translation.par | awk 'BEGIN {x=0;N=0};{x=x+($1^2+$2^2+$3^2)^0.5;N=N+1}END {printf("%f",x/N)}'`
echo "__Mean displacement from t=0 : $meandisl [mm]__ \n" >> ${RF}.Rmd
meansdt=`threecolumnmeansd $tmpdir/translation.par`
meansdr=`threecolumnmeansd $tmpdir/rotation.par`
echo "__Mean translation: (x y z)=(`echo $meansdt | awk '{print $1,$2,$3}'`) [mm]__ \n" >> ${RF}.Rmd
echo "__Mean rotation: (x y z)=(`echo $meansdr | awk '{print $1,$2,$3}'`) [degrees]__ \n" >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/0f0e9/0f0e9d411a1129e24db29d1d96127446ae3c3b26" alt="" \n" >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/09fe8/09fe8c534874a8eb198b575f3b2d9d0467842a6f" alt="" \n" >> ${RF}.Rmd
echo "##Diffusion Volume Images" >> ${RF}.Rmd
T $scriptdir/image_to_movie.sh $dti $reportdir/uncorrected_movie.gif
echo "__Uncorrected diffusion volumes__ \n " >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/41fe6/41fe64056639317902b40f8bfc1fad55dc927631" alt="" \n" >> ${RF}.Rmd
if [ "$method" = "eddy_with_topup" ]; then
T $scriptdir/image_to_movie.sh $tmpdir/dti_ecc.nii.gz $reportdir/corrected_movie.gif
else
T $scriptdir/image_to_movie.sh $outdir/mc_`basename $dti` $reportdir/corrected_movie.gif
fi
echo "__Corrected diffusion volumes __\n " >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/758aa/758aa51f6e32d305c1ecd29ca17960e064eef5c4" alt="" \n" >> ${RF}.Rmd
if [ "$scale_and_skew" = "y" ]; then
echo "# Scale and skew " >> ${RF}.Rmd
T fsl_tsplot -i $tmpdir/scale.par -o $reportdir/scale.png -t "Scale" -x Volume -a x,y,z
T fsl_tsplot -i $tmpdir/skew.par -o $reportdir/skew.png -t "Skew" -x Volume -a x,y,z
meansdS=`threecolumnmeansd $tmpdir/scale.par`
meansds=`threecolumnmeansd $tmpdir/skew.par`
echo Estimated distortion \n >> ${RF}.Rmd
echo "Mean scale: (x y z)=(`echo $meansdS | awk '{print $1,$2,$3}'`) \n" >> ${RF}.Rmd
echo "Mean skew: \(x y z\)=\(`echo $meansds | awk '{print $1,$2,$3}'`) \n" >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/57fe3/57fe36e05dad4f68f0b5cee9a891162293c0da83" alt="" \n" >> ${RF}.Rmd
echo "data:image/s3,"s3://crabby-images/b94f1/b94f1c6496f04ca10953881d7e9eadc6bc1b879c" alt="" \n" >> ${RF}.Rmd
fi
T R -e library\(rmarkdown\)\;rmarkdown::render\(\"${RF}.Rmd\"\)