forked from biochem-fan/eiger2cbf
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy patheiger2cbf_par
executable file
·243 lines (218 loc) · 8.01 KB
/
eiger2cbf_par
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
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
#!/bin/bash
# eiger2cbf_par Script to run eiger2cbf in parallel
# (c) Copyright 2017 Herbert J. Bernstein
# yayahjb@gmail.com, 12 Feb 2017
#
# Covered by CBFlib licenses: lgpl and gpl
######################################################################
# #
# YOU MAY REDISTRIBUTE THE eiger2cbf_par UNDER THE TERMS OF THE GPL #
# #
# ALTERNATIVELY YOU MAY REDISTRIBUTE THE eiger2cbf_par API UNDER THE #
# TERMS OF THE LGPL #
# #
######################################################################
########################### GPL NOTICES ##############################
# #
# This program is free software; you can redistribute it and/or #
# modify it under the terms of the GNU General Public License as #
# published by the Free Software Foundation; either version 2 of #
# (the License, or (at your option) any later version. #
# #
# This program is distributed in the hope that it will be useful, #
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
# GNU General Public License for more details. #
# #
# You should have received a copy of the GNU General Public License #
# along with this program; if not, write to the Free Software #
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA #
# 02111-1307 USA #
# #
######################################################################
######################### LGPL NOTICES ###############################
# #
# This library is free software; you can redistribute it and/or #
# modify it under the terms of the GNU Lesser General Public #
# License as published by the Free Software Foundation; either #
# version 2.1 of the License, or (at your option) any later version. #
# #
# This library is distributed in the hope that it will be useful, #
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU #
# Lesser General Public License for more details. #
# #
# You should have received a copy of the GNU Lesser General Public #
# License along with this library; if not, write to the Free #
# Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, #
# MA 02110-1301 USA #
# #
######################################################################
options=""
full_path="$(cd "${0%/*}" 2>/dev/null; echo "$PWD"/"${0##*/}")"
export EIGER2CBF_ROOT=`dirname "$full_path"`
echo "Running in $EIGER2CBF_ROOT"
export PATH=$EIGER2CBF_ROOT:$PATH
masterfile=$1 #path to the desired master file
if [ "$masterfile" == "--help" ] || [ ${masterfile}xx == "xx" ]
then
echo "eiger2cbf_par --help -- print this message"
echo "eiger2cbf_par [options] masterfile -- get the number of frames"
echo "eiger2cbf_par [options] masterfile first_frame last_frame cbfout "
echo "eiger2cbf_par [options] masterfile first_frame[:last_frame] cbfout "
echo " masterfile -- the master h5 file with the metadata and links to the data"
echo " first_frame last_frame -- frames numbered from 1"
echo " cbfout -- the name of the cbf file without the frame number"
echo " and without the .cbf extension"
echo " options: "
echo " --beam-center beamx,beamy -- new beam center in pixels"
echo " --nimages images -- set the number of images to images"
echo " --maxthreads mthreads -- limit the threads to mthreads (default 4)"
echo " --maxblock kimages -- limit the blocks to kimages"
echo "generates mthreads parallel copies of eiger2cbf in blocks of kimages images for more"
echo "than kimages*mthreads frames, blocks of kimages/2 for more than kimages*mthreads,"
echo "etc. The default for kimages is 40 images per block. The default for mthreads is 4."
shift
masterfile=$1
fi
maxblock=40
maxthreads=25
#echo "test done"
if [ "${masterfile}xx" == "xx" ]
then
exit
fi
while [ "${masterfile:0:2}"xx == "--xx" ]
do
#echo "test beamcenter"
if [ "${masterfile}"xx == "--beamcenterxx" ] || [ "${masterfile}"xx == "--nimagesxx" ]
then
options=${options}" "${1}" "${2}
shift
shift
masterfile=$1
continue
fi
#echo "test maxthreads"
if [ "${masterfile}xx" == "--maxthreadsxx" ]
then
maxthreads=$2
shift
shift
masterfile=$1
continue
fi
#echo "test maxblock"
if [ "${masterfile}xx" == "--maxblockxx" ]
then
maxblock=$2
shift
shift
masterfile=$1
continue
fi
break
done
if [ "${masterfile}"xx == "xx" ]
then
exit
fi
xsubstr=".h5"
if [[ ! "${masterfile}" == *"${xsubstr}" ]]
then
echo "eiger2cbf_par master file does not have an h5 extension"
exit
fi
echo processing eiger2cbf $options $*
first_frame=$2
last_frame=$2
xsubstr=":"
if [ "${first_frame##*$xsubstr}" ] ; then
xframes=(`echo ${first_frame} | tr ':' ' '`)
if [ "${xframes[0]}xx" == "xx" ]; then
first_frame="0"
else
first_frame="${xframes[0]}"
fi
if [ "${xframes[1]}xx" == "xx" ]; then
last_frame="0"
else
last_frame="${xframes[1]}"
fi
else
if [ ! "${first_frame}xx" == "xx" ]
then
first_frame=1
last_frame=1
fi
fi
re='^[0-9]+$'
if [ ! "${first_frame}xx" == "xx" ]
then
if ! [[ $first_frame =~ $re ]] ; then
echo "error: first frame $first_frame Not an integer" >&2; exit 1
fi
fi
if [ ! "${last_frame}xx" == "xx" ]
then
if ! [[ $last_frame =~ $re ]] ; then
echo "error: last frame $last_frame Not an integer" >&2; exit 1
fi
fi
cbfout=$3 #cbf file name to write without the .cbf
if [ "${4}xx" != "xx" ]; then
last_frame=$3
cbfout=$4
fi
echo first_frame:last_frame ${first_frame}:${last_frame}
if [ "${first_frame}xx" == "xx" ]
then
eiger2cbf $options $masterfile
else
if [ $first_frame -lt 1 ]
then
echo first frame $first_frame less than 1, exit
exit
fi
if [ $last_frame -lt $first_frame ]
then
echo last_frame $last_frame less than first frame $first_frame, exit
exit
fi
iframe=$first_frame
nframes=`expr $last_frame - $first_frame + 1`
#echo nframes $nframes
block_size=$maxblock
totframes=$(( $block_size * $maxthreads ))
#echo totframes: $totframes block_size: $block_size maxthreads: $maxthreads
while [ "${totframes}" -gt "${nframes}" ]; do
block_size=$(( $block_size / 2 ))
#echo block_size: $block_size
if [ "${block_size}" -lt "3" ]; then
block_size=1
break
fi
totframes=$(( $block_size * $maxthreads ))
#echo totframes: $totframes block_size: $block_size maxthreads: $maxthreads
done
echo block_size: $block_size, maxthreads: $maxthreads
running=0
while [ $iframe -le $last_frame ]; do
block_end=$(( $iframe + $block_size - 1 ))
if [ $block_end -gt $last_frame ]
then block_end=$last_frame
fi
#echo eiger2cbf $options $masterfile $iframe:$block_end $cbfout >>/tmp/eiger2cbf_par_$$ 2>&1 &
eiger2cbf $options $masterfile $iframe:$block_end $cbfout >>/tmp/eiger2cbf_par_$$ 2>&1 &
running=$(( $running + 1 ))
if [ $running -ge $maxthreads ]
then
wait
running=0
fi
iframe=`expr $block_end + 1`
done
wait
sort -u /tmp/eiger2cbf_par_$$
rm -rf /tmp/eiger2cbf_par_$$
fi