5# utility script to produce PDF and CDF tables.
9# ------------------------------------------------------------------------------------------
11# Utility script to produce PDF and CDF tables.
13# ------------------------------------------------------------------------------------------
15if [ -z $JPP_DIR ]; then
16 echo "Variable JPP_DIR undefined."
20source $JPP_DIR/setenv.sh $JPP_DIR >& /dev/null
22source $JPP_DIR/software/scripts/qlib.sh
25set_variable WORKDIR $JPP_DATA
26set_variable MAKE_PDF 0
27set_variable MERGE_PDF 0
28set_variable MAKE_ZDF 0
29set_variable MAKE_CDF 0
32set_variable BACKGROUND
34set_variable RMAX_M 999
35set_variable: TTS_NS PHYSICS_TTS_NS 2.0
36set_variable: QUEUE_SIZE PHYSICS_QUEUE_SIZE 10
37set_variable: ABSORPTION_LENGTH PHYSICS_ABSORPTION_LENGTH "default 1.0"
38set_variable: SCATTERING_LENGTH PHYSICS_SCATTERING_LENGTH "default 1.0"
39set_variable: SCATTERING_PROBABILITY PHYSICS_SCATTERING_PROBABILITY "default 1.0"
43PDF_TYPES=(1 2 3 4 5 6 12 13 14 23 24)
44CDF_TYPES=(1 2 5 6 12 13 14)
48# Method to print usage of script.
55 "-d <debug level>\n" \
56 "-W <working directory PDF and CDF tables>\n" \
57 "-P create PDF tables\n" \
58 "-M merge PDF tables\n" \
59 "-Z create PDF table for elongated shower\n" \
60 "-C convert PDF tables to CDF tables\n" \
61 "-c clean PDF tables\n" \
62 "-G gzip PDF and CDF tables\n" \
63 "-B parallel running of all jobs in background\n" \
64 "-E executor command (default: nohup, possible values: echo, puts_queue)\n" \
65 "-w download files from GIT server (e.g. \"http://sftp.km3net.de/data/latest/\")\n" \
66 "-R <maximal distance between muon and PMT>\n" \
67 "Script to generate the PDF/CDFs, merge and zip them;\n" \
68 "Standard example: JMakePDF.sh -W \${JPP_DATA} -PMCcG\n" \
69 "List of PDF files:" J${^PDF_TYPES}p.dat.gz "\n" \
70 "List of CDF files:" I${^CDF_TYPES}p.dat.gz "\n" \
71 "Note that the elongated EM-shower PDF is created at option -Z.\n" \
72 "Example to print all necessary batch programs: JMakePDF.sh -W \${JPP_DATA} -E echo -P"
76# Parse command line options.
78while getopts "d:W:PMZCcGBE:w:hA:S:R:" option; do
80 d) set_variable DEBUG $OPTARG;;
81 W) set_variable WORKDIR $OPTARG;;
82 P) set_variable MAKE_PDF 1;;
83 M) set_variable MERGE_PDF 1;;
84 Z) set_variable MAKE_ZDF 1;;
85 C) set_variable MAKE_CDF 1;;
86 c) set_variable CLEAN 1;;
87 G) set_variable GZIPF 1;;
88 B) set_variable BACKGROUND \&;;
89 E) alias EXECUTOR=$OPTARG;;
90 w) set_variable WGET $OPTARG;;
92 R) set_variable RMAX_M $OPTARG;;
97# check whether script is already running
99BUFFER=`get_pid $script`
100BUFFER=${BUFFER/${$}/}
102if [[ -n "${BUFFER/ */}" ]]; then
103 notice "${script} already running <${BUFFER}>"
107check_variable ROOTSYS JPP_DIR WORKDIR
111if [[ ! -d $WORKDIR ]]; then
112 fatal "Directory $WORKDIR does not exist."
115status "Start $script with executor $EXECUTOR"
120set_variable QUEUE $WORKDIR/queue_pdf
122if [[ "$aliases[EXECUTOR]" == "puts_queue" ]]; then
123 eval alias EXECUTOR=\'puts_queue $QUEUE\'
128# Check if PDF already exist.
131# \return 1 if exists; else 0
135 if [[ ! -f $WORKDIR/J${1}p.dat ]] && [[ ! -f $WORKDIR/J${1}p.dat.gz ]]; then
144# Check if CDF already exist.
147# \return 1 if exists; else 0
151 if [[ ! -f $WORKDIR/I${1}p.dat ]] && [[ ! -f $WORKDIR/I${1}p.dat.gz ]]; then
159if [[ -n $WGET ]]; then
163 for FILE in J${^PDF_TYPES}p.dat.gz I${^CDF_TYPES}p.dat.gz; do
165 status "Checking file $WGET/$FILE"
167 if [[ ! -f $FILE ]]; then
171 if (( $? != 0 )); then
173 status "Checking file $WGET/${FILE:r}"
175 wget $WGET/${FILE:r} -q
177 if (( $? == 0 )); then
180 fatal "No file $WGET/$FILE or ${FILE:r}"
190if (( $MAKE_PDF )); then
192 check_process JMakePDF JMakePDG pgrep
194 if [[ "$aliases[EXECUTOR]" == "puts_queue"* ]]; then
195 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE $QUEUE_SIZE start
198 if ( ! check_pdf 1 ); then
202 -@ "absorptionLength = $ABSORPTION_LENGTH" \
203 -@ "scatteringLength = $SCATTERING_LENGTH" \
204 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
205 -o $WORKDIR/J1p.dat \
206 -d $DEBUG --! $BACKGROUND
209 if ( ! check_pdf 2 ); then
213 -@ "absorptionLength = $ABSORPTION_LENGTH" \
214 -@ "scatteringLength = $SCATTERING_LENGTH" \
215 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
216 -o $WORKDIR/J2p.dat \
217 -d $DEBUG --! $BACKGROUND
220 for R in 0.1 0.3 0.5 1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0 10.0 \
221 11.0 12.0 13.0 14.0 15.0 16.0 17.0 18.0 19.0 20.0 \
222 22.0 24.0 26.0 28.0 30.0 32.0 34.0 36.0 38.0 40.0 42.0 44.0 46.0 48.0 50.0 \
223 55.0 60.0 65.0 70.0 75.0 80.0 85.0 90.0 95.0 100.0 110.0 120.0 130.0 140.0 150.0 \
224 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0 360.0 410.0; do
226 if (( $R <= $RMAX_M )); then
228 if ( ! check_pdf 3 ); then
232 -@ "absorptionLength = $ABSORPTION_LENGTH" \
233 -@ "scatteringLength = $SCATTERING_LENGTH" \
234 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
236 -o $WORKDIR/J3p-$R.dat \
237 -d $DEBUG --! $BACKGROUND
240 if ( ! check_pdf 4 ); then
244 -@ "absorptionLength = $ABSORPTION_LENGTH" \
245 -@ "scatteringLength = $SCATTERING_LENGTH" \
246 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
248 -o $WORKDIR/J4p-$R.dat \
249 -d $DEBUG --! $BACKGROUND
254 if ( ! check_pdf 5 ); then
258 -@ "absorptionLength = $ABSORPTION_LENGTH" \
259 -@ "scatteringLength = $SCATTERING_LENGTH" \
260 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
261 -o $WORKDIR/J5p.dat \
262 -d $DEBUG $BACKGROUND
265 if ( ! check_pdf 6 ); then
267 for R in 0.1 0.3 0.5 1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0 10.0 \
268 11.0 12.0 13.0 14.0 15.0 16.0 17.0 18.0 19.0 20.0 \
269 22.0 24.0 26.0 28.0 30.0 32.0 34.0 36.0 38.0 40.0 42.0 44.0 46.0 48.0 50.0 \
270 55.0 60.0 65.0 70.0 75.0 80.0 85.0 90.0 95.0 100.0 110.0 120.0 130.0 140.0 150.0 \
271 170.0 190.0 210.0 230.0 250.0; do
273 if (( $R <= $RMAX_M )); then
277 -@ "absorptionLength = $ABSORPTION_LENGTH" \
278 -@ "scatteringLength = $SCATTERING_LENGTH" \
279 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
281 -o $WORKDIR/J6p-$R.dat \
282 -d $DEBUG --! $BACKGROUND
287 let "DMAX_M = ${RMAX_M}*1.5"
289 if ( ! check_pdf 12 ); then
291 for D in 0.1 0.5 1.0 5.0 10.0 20.0 30.0 40.0 50.0 60.0 70.0 80.0 90.0 100.0 \
292 120.0 150.0 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0; do
294 if (( $D <= $DMAX_M )); then
298 -@ "absorptionLength = $ABSORPTION_LENGTH" \
299 -@ "scatteringLength = $SCATTERING_LENGTH" \
300 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
302 -o $WORKDIR/J12p-$D.dat \
303 -d $DEBUG --! $BACKGROUND
308 if ( ! check_pdf 13 ); then
312 -@ "absorptionLength = $ABSORPTION_LENGTH" \
313 -@ "scatteringLength = $SCATTERING_LENGTH" \
314 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
315 -o $WORKDIR/J13p.dat \
316 -d $DEBUG --! $BACKGROUND
319 let "DMAX_M = ${RMAX_M}*1.5"
321 if ( ! check_pdf 14 ); then
323 for D in 0.1 0.5 1.0 5.0 10.0 20.0 30.0 40.0 50.0 60.0 70.0 80.0 90.0 100.0 \
324 120.0 150.0 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0 \
325 340.0 370.0 400.0 430.0 460.0 490.0 520.0 550.0 600.0 650.0 700.0 750.0 800.0; do
327 if (( $D <= $DMAX_M )); then
331 -@ "absorptionLength = $ABSORPTION_LENGTH" \
332 -@ "scatteringLength = $SCATTERING_LENGTH" \
333 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
335 -o $WORKDIR/J14p-$D.dat \
336 -d $DEBUG --! $BACKGROUND
341 if ( ! check_pdf 23 ); then
345 -@ "absorptionLength = $ABSORPTION_LENGTH" \
346 -@ "scatteringLength = $SCATTERING_LENGTH" \
347 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
348 -o $WORKDIR/J23p.dat \
349 -d $DEBUG --! $BACKGROUND
352 if ( ! check_pdf 24 ); then
356 -@ "absorptionLength = $ABSORPTION_LENGTH" \
357 -@ "scatteringLength = $SCATTERING_LENGTH" \
358 -@ "scatteringProbability = $SCATTERING_PROBABILITY" \
359 -o $WORKDIR/J24p.dat \
360 -d $DEBUG --! $BACKGROUND
363 if [[ "$BACKGROUND" != "" ]]; then
367 if [[ "$aliases[EXECUTOR]" == "puts_queue"* ]]; then
368 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE wait
371 if [[ "$aliases[EXECUTOR]" == "echo" ]]; then
377if (( $MERGE_PDF )); then
379 check_process JMergePDF pgrep
381 if ( ! check_pdf 3 ); then
383 FILE_LIST=(`ls $WORKDIR/J3p-*.dat`)
385 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J3p.dat -d $DEBUG
388 if ( ! check_pdf 4 ); then
390 FILE_LIST=(`ls $WORKDIR/J4p-*.dat`)
392 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J4p.dat -d $DEBUG
395 if ( ! check_pdf 6 ); then
397 FILE_LIST=(`ls $WORKDIR/J6p-*.dat`)
399 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J6p.dat -d $DEBUG
402 if ( ! check_pdf 12 ); then
404 FILE_LIST=(`ls $WORKDIR/J12p-*.dat`)
406 JMergePDG -f${^FILE_LIST} -o $WORKDIR/J12p.dat -d $DEBUG
409 if ( ! check_pdf 14 ); then
411 FILE_LIST=(`ls $WORKDIR/J14p-*.dat`)
413 JMergePDG -f${^FILE_LIST} -o $WORKDIR/J14p.dat -d $DEBUG
418if (( $MAKE_ZDF )); then
420 if ( ! check_pdf 113 ); then
422 if [[ "$aliases[EXECUTOR]" == "puts_queue"* ]]; then
423 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE $QUEUE_SIZE start
426 EXECUTOR JMakePDE -F $WORKDIR/J%p.dat -o $WORKDIR/J113p.dat -T $TTS_NS -d $DEBUG $BACKGROUND
428 if [[ "$BACKGROUND" != "" ]]; then
432 if [[ "$aliases[EXECUTOR]" == "puts_queue"* ]]; then
433 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE wait
438if (( $MAKE_CDF )); then
440 check_process JMakeCDF JMakeCDG pgrep
442 if ( ! check_cdf 1 ); then
443 JMakeCDF -f $WORKDIR/J1p.dat -e 1e-5 -o $WORKDIR/I1p.dat -d $DEBUG
445 if ( ! check_cdf 2 ); then
446 JMakeCDF -f $WORKDIR/J2p.dat -e 1e-4 -o $WORKDIR/I2p.dat -d $DEBUG
448 if ( ! check_cdf 5 ); then
449 JMakeCDF -f $WORKDIR/J5p.dat -e 1e-5 -o $WORKDIR/I5p.dat -d $DEBUG
451 if ( ! check_cdf 6 ); then
452 JMakeCDF -f $WORKDIR/J6p.dat -e 1e-5 -o $WORKDIR/I6p.dat -d $DEBUG
454 if ( ! check_cdf 12 ); then
455 JMakeCDG -f $WORKDIR/J12p.dat -e 1e-5 -o $WORKDIR/I12p.dat -d $DEBUG
457 if ( ! check_cdf 13 ); then
458 JMakeCDG -f $WORKDIR/J13p.dat -e 1e-5 -o $WORKDIR/I13p.dat -d $DEBUG
460 if ( ! check_cdf 14 ); then
461 JMakeCDG -f $WORKDIR/J14p.dat -e 1e-5 -o $WORKDIR/I14p.dat -d $DEBUG
467 { rm -f $WORKDIR/J*p-*.dat } >& /dev/null
473 gzip $WORKDIR/[JI]*p.dat