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 absorptionLengthFactor 1.0
36set_variable scatteringLengthFactor 1.0
37set_variable: TTS_NS PHYSICS_TTS_NS 2.0
38set_variable: QUEUE_SIZE PHYSICS_QUEUE_SIZE 10
39set_variable EXECUTOR "nohup"
41PDF_TYPES=(1 2 3 4 5 6 12 13 14 23 24)
42CDF_TYPES=(1 2 5 6 12 13 14)
46# Method to print usage of script.
53 "-d <debug level>\n" \
54 "-W <working directory PDF and CDF tables>\n" \
55 "-P create PDF tables\n" \
56 "-M merge PDF tables\n" \
57 "-Z create PDF table for elongated shower\n" \
58 "-C convert PDF tables to CDF tables\n" \
59 "-c clean PDF tables\n" \
60 "-G gzip PDF and CDF tables\n" \
61 "-B parallel running of jobs in background\n" \
62 "-E execute command to be evaluated (standard: nohup, example: echo, using -B as well)\n" \
63 "-w download files from GIT server (e.g. \"http://sftp.km3net.de/data/latest/\")\n" \
64 "-R <maximal distance between muon and PMT>\n" \
65 "Script to generate the PDF/CDFs, merge and zip them;\n" \
66 "standard example: JMakePDF.sh -W \${JPP_DATA} -PMCcG\n" \
67 "List of PDF files:" J${^PDF_TYPES}p.dat.gz "\n" \
68 "List of CDF files:" I${^CDF_TYPES}p.dat.gz "\n" \
69 "Note that the elongated EM-shower PDF is created at option -Z.\n" \
70 #"Example to print all necessary programs: JMakePDF.sh -W \${JPP_DATA} -E \"echo\" -PMC"
74# Parse command line options.
76while getopts "d:W:PMZCcGBE:w:hA:S:R:" option; do
78 d) set_variable DEBUG $OPTARG;;
79 W) set_variable WORKDIR $OPTARG;;
80 P) set_variable MAKE_PDF 1;;
81 M) set_variable MERGE_PDF 1;;
82 Z) set_variable MAKE_ZDF 1;;
83 C) set_variable MAKE_CDF 1;;
84 c) set_variable CLEAN 1;;
85 G) set_variable GZIPF 1;;
86 B) set_variable BACKGROUND \&;;
87 E) set_variable EXECUTOR $OPTARG;;
88 w) set_variable WGET $OPTARG;;
90 A) set_variable absorptionLengthFactor $OPTARG;;
91 S) set_variable scatteringLengthFactor $OPTARG;;
92 R) set_variable RMAX_M $OPTARG;;
96# check whether script is already running
98BUFFER=`get_pid $script`
101if [[ -n "${BUFFER/ */}" ]]; then
102 notice "${script} already running <${BUFFER}>"
106check_variable ROOTSYS JPP_DIR WORKDIR
110if [[ ! -d $WORKDIR ]]; then
111 fatal "Directory $WORKDIR does not exist."
114status "Start $script with executor $EXECUTOR"
119set_variable QUEUE $WORKDIR/queue_pdf
121if [[ "$EXECUTOR" == "puts_queue" ]]; then
127# Check if PDF already exist.
130# \return 1 if exists; else 0
134 if [[ ! -f $WORKDIR/J${1}p.dat ]] && [[ ! -f $WORKDIR/J${1}p.dat.gz ]]; then
143# Check if CDF already exist.
146# \return 1 if exists; else 0
150 if [[ ! -f $WORKDIR/I${1}p.dat ]] && [[ ! -f $WORKDIR/I${1}p.dat.gz ]]; then
158if [[ -n $WGET ]]; then
162 for FILE in J${^PDF_TYPES}p.dat.gz I${^CDF_TYPES}p.dat.gz; do
164 status "Checking file $WGET/$FILE"
166 if [[ ! -f $FILE ]]; then
170 if (( $? != 0 )); then
172 status "Checking file $WGET/${FILE:r}"
174 wget $WGET/${FILE:r} -q
176 if (( $? == 0 )); then
179 fatal "No file $WGET/$FILE or ${FILE:r}"
189if (( $MAKE_PDF )); then
191 check_process JMakePDF JMakePDG pgrep
193 if [[ "$EXECUTOR" == "puts_queue"* ]]; then
194 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE $QUEUE_SIZE start
197 if ( ! check_pdf 1 ); then
198 eval $EXECUTOR JMakePDF -F1 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J1p.dat -d $DEBUG $BACKGROUND
201 if ( ! check_pdf 2 ); then
202 eval $EXECUTOR JMakePDF -F2 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J2p.dat -d $DEBUG $BACKGROUND
205 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 \
206 11.0 12.0 13.0 14.0 15.0 16.0 17.0 18.0 19.0 20.0 \
207 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 \
208 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 \
209 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0 360.0 410.0; do
211 if (( $R <= $RMAX_M )); then
213 if ( ! check_pdf 3 ); then
214 eval $EXECUTOR JMakePDF -F3 -A $absorptionLengthFactor -S $scatteringLengthFactor -R $R -o $WORKDIR/J3p-$R.dat -d $DEBUG $BACKGROUND
216 if ( ! check_pdf 4 ); then
217 eval $EXECUTOR JMakePDF -F4 -A $absorptionLengthFactor -S $scatteringLengthFactor -R $R -o $WORKDIR/J4p-$R.dat -d $DEBUG $BACKGROUND
222 if ( ! check_pdf 5 ); then
223 eval $EXECUTOR JMakePDF -F5 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J5p.dat -d $DEBUG $BACKGROUND
226 if ( ! check_pdf 6 ); then
228 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 \
229 11.0 12.0 13.0 14.0 15.0 16.0 17.0 18.0 19.0 20.0 \
230 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 \
231 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 \
232 170.0 190.0 210.0 230.0 250.0; do
234 if (( $R <= $RMAX_M )); then
235 eval $EXECUTOR JMakePDF -F6 -A $absorptionLengthFactor -S $scatteringLengthFactor -R $R -o $WORKDIR/J6p-$R.dat -d $DEBUG $BACKGROUND
240 let "DMAX_M = ${RMAX_M}*1.5"
242 if ( ! check_pdf 12 ); then
244 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 \
245 120.0 150.0 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0; do
247 if (( $D <= $DMAX_M )); then
248 eval $EXECUTOR JMakePDG -F12 -A $absorptionLengthFactor -S $scatteringLengthFactor -D $D -o $WORKDIR/J12p-$D.dat -d $DEBUG $BACKGROUND
253 if ( ! check_pdf 13 ); then
254 eval $EXECUTOR JMakePDG -F13 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J13p.dat -d $DEBUG $BACKGROUND
257 let "DMAX_M = ${RMAX_M}*1.5"
259 if ( ! check_pdf 14 ); then
261 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 \
262 120.0 150.0 170.0 190.0 210.0 230.0 250.0 270.0 290.0 310.0 \
263 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
265 if (( $D <= $DMAX_M )); then
266 eval $EXECUTOR JMakePDG -F14 -A $absorptionLengthFactor -S $scatteringLengthFactor -D $D -o $WORKDIR/J14p-$D.dat -d $DEBUG $BACKGROUND
271 if ( ! check_pdf 23 ); then
272 eval $EXECUTOR JMakePD0 -F23 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J23p.dat -d $DEBUG $BACKGROUND
274 if ( ! check_pdf 24 ); then
275 eval $EXECUTOR JMakePD0 -F24 -A $absorptionLengthFactor -S $scatteringLengthFactor -o $WORKDIR/J24p.dat -d $DEBUG $BACKGROUND
278 if [[ "$BACKGROUND" != "" ]]; then
282 if [[ "$EXECUTOR" == "puts_queue"* ]]; then
283 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE wait
288if (( $MERGE_PDF )); then
290 check_process JMergePDF pgrep
292 if ( ! check_pdf 3 ); then
294 FILE_LIST=(`ls $WORKDIR/J3p-*.dat`)
296 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J3p.dat -d $DEBUG
299 if ( ! check_pdf 4 ); then
301 FILE_LIST=(`ls $WORKDIR/J4p-*.dat`)
303 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J4p.dat -d $DEBUG
306 if ( ! check_pdf 6 ); then
308 FILE_LIST=(`ls $WORKDIR/J6p-*.dat`)
310 JMergePDF -f${^FILE_LIST} -o $WORKDIR/J6p.dat -d $DEBUG
313 if ( ! check_pdf 12 ); then
315 FILE_LIST=(`ls $WORKDIR/J12p-*.dat`)
317 JMergePDG -f${^FILE_LIST} -o $WORKDIR/J12p.dat -d $DEBUG
320 if ( ! check_pdf 14 ); then
322 FILE_LIST=(`ls $WORKDIR/J14p-*.dat`)
324 JMergePDG -f${^FILE_LIST} -o $WORKDIR/J14p.dat -d $DEBUG
329if (( $MAKE_ZDF )); then
331 if ( ! check_pdf 113 ); then
333 if [[ "$EXECUTOR" == "puts_queue"* ]]; then
334 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE $QUEUE_SIZE start
337 eval $EXECUTOR JMakePDE -F $WORKDIR/J%p.dat -o $WORKDIR/J113p.dat -T $TTS_NS -d $DEBUG $BACKGROUND
339 if [[ "$BACKGROUND" != "" ]]; then
343 if [[ "$EXECUTOR" == "puts_queue"* ]]; then
344 $JPP_DIR/examples/scripts/mkqueue.sh $QUEUE wait
349if (( $MAKE_CDF )); then
351 check_process JMakeCDF JMakeCDG pgrep
353 if ( ! check_cdf 1 ); then
354 JMakeCDF -f $WORKDIR/J1p.dat -e 1e-5 -o $WORKDIR/I1p.dat -d $DEBUG
356 if ( ! check_cdf 2 ); then
357 JMakeCDF -f $WORKDIR/J2p.dat -e 1e-4 -o $WORKDIR/I2p.dat -d $DEBUG
359 if ( ! check_cdf 5 ); then
360 JMakeCDF -f $WORKDIR/J5p.dat -e 1e-5 -o $WORKDIR/I5p.dat -d $DEBUG
362 if ( ! check_cdf 6 ); then
363 JMakeCDF -f $WORKDIR/J6p.dat -e 1e-5 -o $WORKDIR/I6p.dat -d $DEBUG
365 if ( ! check_cdf 12 ); then
366 JMakeCDG -f $WORKDIR/J12p.dat -e 1e-5 -o $WORKDIR/I12p.dat -d $DEBUG
368 if ( ! check_cdf 13 ); then
369 JMakeCDG -f $WORKDIR/J13p.dat -e 1e-5 -o $WORKDIR/I13p.dat -d $DEBUG
371 if ( ! check_cdf 14 ); then
372 JMakeCDG -f $WORKDIR/J14p.dat -e 1e-5 -o $WORKDIR/I14p.dat -d $DEBUG
378 { rm -f $WORKDIR/J*p-*.dat } >& /dev/null
384 gzip $WORKDIR/[JI]*p.dat