forked from haililihai/ATPP_CLI
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpipeline.sh
176 lines (155 loc) · 9.52 KB
/
pipeline.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
#! /bin/bash
# Automatic Tractography-based Parcellation Pipeline (ATPP)
# pipeline file
# Hai Li ([email protected])
PIPELINE=$1
shift
CONFIG=$1
shift
HEADER=$1
shift
WD=$1
shift
DATA_DIR=$1
shift
SUB_LIST=$1
shift
ROI=$1
shift
MAX_CL_NUM=$1
# fetch the variables
set -o allexport
source ${CONFIG}
# show header info
cat ${HEADER}
# show the exec host
echo "========= >>> ${ROI}@$(hostname)__$(date +%F_%T) <<< =========" |tee -a ${WD}/log/progress_check.txt
echo ""
#===============================================================================
#--------------------------------Pipeline---------------------------------------
#------------NO EDITING BELOW UNLESS YOU KNOW WHAT YOU ARE DOING----------------
#===============================================================================
# in case of errors
SWITCH=(${SWITCH[@]/#/_}) #add a _ before step
SWITCH=(${SWITCH[@]/%/_}) #add a _ after step
# 0) generate the working directory
if [[ ${SWITCH[@]/_0_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =============== 0_gen_WD start! ===============" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/0_gen_WD.sh ${WD} ${DATA_DIR} ${ROI} ${SUB_LIST} ${ROI_DIR}
T="$(($(date +%s)-T))"
echo "$(date +%T) =============== 0_gen_WD done! ===============" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 1) ROI registration, from MNI space to DTI space, using spm batch
if [[ ${SWITCH[@]/_1_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) ========= 1_ROI_registration_spm start! =========" |tee -a ${WD}/log/progress_check.txt
T=$(date +%s)
bash ${PIPELINE}/1_ROI_registration_spm.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${POOLSIZE} ${SPM} ${NIFTI} ${TEMPLATE} ${LEFT} ${RIGHT}
T=$(($(date +%s)-T))
echo "$(date +%T) ========= 1_ROI_registration_spm done! =========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 2) calculate ROI coordinates in DTI space
if [[ ${SWITCH[@]/_2_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 2_ROI_calc_coord start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/2_ROI_calc_coord.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${POOLSIZE} ${NIFTI} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 2_ROI_calc_coord done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 3) generate probabilistic tractography for each voxel in ROI
if [[ ${SWITCH[@]/_3_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 3_ROI_probtrack start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/3_ROI_probtrackx.sh ${WD} ${DATA_DIR} ${ROI} ${SUB_LIST} ${N_SAMPLES} ${DIS_COR} ${LEN_STEP} ${N_STEPS} ${CUR_THRES} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 3_ROI_probtrackx done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 4) calculate connectivity matrix between each voxel in ROI and the remain voxels of whole brain
# and correlation matrix among voxels in ROI
if [[ ${SWITCH[@]/_4_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 4_ROI_calc_matrix start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/4_ROI_calc_matrix.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${POOLSIZE} ${NIFTI} ${VAL_THRES} ${DOWN_SIZE} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 4_ROI_calc_matrix done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 5) ROI parcellation using spectral clustering, to generate 2 to max cluster number subregions
if [[ ${SWITCH[@]/_5_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 5_ROI_parcellation start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/5_ROI_parcellation.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${POOLSIZE} ${NIFTI} ${METHOD} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 5_ROI_parcellation done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 6) transform parcellated ROI from DTI space to MNI space
if [[ ${SWITCH[@]/_6_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 6_ROI_toMNI_spm start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/6_ROI_toMNI_spm.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${SPM} ${POOLSIZE} ${TEMPLATE} ${VOX_SIZE} ${METHOD} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 6_ROI_toMNI_spm done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 7) calculate symmetric group reference images to prepare for the relabel step
if [[ ${SWITCH[@]/_7_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 7_group_refer start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/7_group_refer.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${NIFTI} ${METHOD} ${VOX_SIZE} ${GROUP_THRES} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 7_group_refer done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 8) cluster relabeling according to the group reference image
if [[ ${SWITCH[@]/_8_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 8_cluster_relabel start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/8_cluster_relabel.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${NIFTI} ${POOLSIZE} ${GROUP_THRES} ${METHOD} ${VOX_SIZE} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 8_cluster_relabel done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 9) generate maximum probability map for ROI and probabilistic maps for each subregion
if [[ ${SWITCH[@]/_9_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) ============= 9_calc_mpm start! =============" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/9_calc_mpm.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${NIFTI} ${POOLSIZE} ${METHOD} ${MPM_THRES} ${VOX_SIZE} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) ============= 9_calc_mpm done! =============" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 10) smooth the mpm image
if [[ ${SWITCH[@]/_10_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 10_postprocess_mpm start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/10_postprocess_mpm.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${MAX_CL_NUM} ${NIFTI} ${MPM_THRES} ${VOX_SIZE} ${LEFT} ${RIGHT}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 10_postprocess_mpm done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 11) produce various validity indices
if [[ ${SWITCH[@]/_11_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 11_validation start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/11_validation.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${METHOD} ${VOX_SIZE} ${MAX_CL_NUM} ${NIFTI} ${SPM} ${N_ITER} ${POOLSIZE} ${GROUP_THRES} ${MPM_THRES} ${LEFT} ${RIGHT} ${split_half} ${pairwise} ${leave_one_out} ${cont} ${hi_vi} ${silhouette} ${tpd}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 11_validation done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
# 12) plot indices
if [[ ${SWITCH[@]/_12_/} != ${SWITCH[@]} ]]; then
echo "$(date +%T) =========== 12_indices_plot start! ===========" |tee -a ${WD}/log/progress_check.txt
T="$(date +%s)"
bash ${PIPELINE}/12_indices_plot.sh ${PIPELINE} ${WD} ${ROI} ${SUB_LIST} ${VOX_SIZE} ${MAX_CL_NUM} ${NIFTI} ${LEFT} ${RIGHT} ${split_half} ${pairwise} ${leave_one_out} ${cont} ${hi_vi} ${silhouette} ${tpd}
T="$(($(date +%s)-T))"
echo "$(date +%T) =========== 12_indices_plot done! ===========" |tee -a ${WD}/log/progress_check.txt
printf "Time elapsed: %02d:%02d:%02d:%02d\n\n" "$((T/86400))" "$((T/3600%24))" "$((T/60%60))" "$((T%60))" |tee -a ${WD}/log/progress_check.txt
fi
echo "-------------------------------------------------------------------------"
echo "----------------All Done!!Please check the result images----------------"
echo "-------------------------------------------------------------------------"