Jpp  18.5.0
the software that should make you happy
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
pre-calibration_D0ORCA018.sh
Go to the documentation of this file.
1 #!/bin/zsh
2 script=${0##*/}
3 
4 # --------------------------------------------------------------------------------------------
5 #
6 # Steering script for the global-fit-of-global-fits procedure of the D0ORCA018 (148) detector.
7 #
8 # --------------------------------------------------------------------------------------------
9 
10 if [ -z $JPP_DIR ]; then
11  echo "Variable JPP_DIR undefined."
12  exit
13 fi
14 
15 source $JPP_DIR/setenv.sh $JPP_DIR >& /dev/null
16 
18 set_array RUNS 16662-16668
19 set_variable: THREADS ACOUSTICS_THREADS 5
22 
23 if do_usage $*; then
24  usage "$script <source directory> [user directory]"\
25  "\nThe source directory corresponds to a pre-calibrated D1ORCA015 detector."\
26  "\nThe user directory should be specified when this script is submitted in a batch queue."
27 fi
28 
29 case $# in
31  1) set_variable DIR ${1:a};;
32  *) fatal "Wrong number of arguments."
33 esac
34 
35 source JAcousticsToolkit.sh
36 
38 set_variable TRIPOD $DIR/tripod.txt
39 set_variable DETECTOR_INITIAL detector_initial.datx
40 set_variable TRIPOD_INITIAL tripod_initial.txt
41 expand_array RUNS
42 
43 
44 # Run in HOMEDIR
45 
46 mkdir -p $HOMEDIR
47 cd $HOMEDIR
48 
49 JDetectorDB \
50  -D $DETECTOR_ID \
51  -r $RUNS[1] \
52  -WW \
53  -o $DETECTOR_INITIAL
54 
55 cat>$TRIPOD_INITIAL<<EOF
56 # position of emitter 5 taken from https://elog.km3net.de/Operations+FR/8271 (RAB1v2)
57 # position of emitter 6 taken from https://elog.km3net.de/Operations+FR/8731 (RAB2)
58 # position of emitter 8 taken from https://elog.km3net.de/Operations+FR/9603 (RAB3)
59 5 +257040.800 +4743317.600 -2439.900
60 6 +256807.500 +4743636.500 -2442.500
61 8 +257118.100 +4743781.100 -2440.300
62 EOF
63 
64 JEditDetector \
65  -a $DETECTOR \
66  -o detector_tmp.datx --!
67 
68 eval `JPrintDetector -a $DETECTOR_INITIAL -O SUMMARY`; FINAL_STRINGS=($STRINGS[*])
69 eval `JPrintDetector -a detector_tmp.datx -O SUMMARY`; FIXED_STRINGS=($STRINGS[*])
70 
71 # Apply modifications.
72 
73 JEditDetector \
74  -a $DETECTOR_INITIAL \
75  -o detector.datx --!
76 
77 JEditDetector -a detector.datx -r "$FIXED_STRINGS[*]" -o detector.datx --!
78 JMergeDetector -a detector.datx -a detector_tmp.datx -o detector.datx --!
79 JEditDetector -a detector.datx -k "$FINAL_STRINGS[*]" -o detector.datx --!
80 
81 JEditDetector \
82  -a detector.datx \
83  -M "817315169 swap 14 18" \
84  -o detector.datx --!
85 
86 REMOVE_STRINGS=(27 28)
87 
88 FINAL_STRINGS=(${FINAL_STRINGS:|REMOVE_STRINGS})
89 FIXED_STRINGS=(${FIXED_STRINGS:|REMOVE_STRINGS})
90 
91 JEditDetector -a detector.datx -r "$REMOVE_STRINGS[*]" -o detector.datx --!
92 
93 typeset -A TRIPODS
94 
95 get_tripods $TRIPOD_INITIAL TRIPODS; FINAL_TRIPODS=(${(k)TRIPODS[*]})
96 get_tripods $TRIPOD TRIPODS; FIXED_TRIPODS=(${(k)TRIPODS[*]})
97 
98 cp -p $TRIPOD_INITIAL tripod.txt
99 
100 JEditTripod -f tripod.txt -r "${FIXED_TRIPODS}" -o tripod.txt
101 JMergeTripod -f tripod.txt -f $TRIPOD -o tripod.txt
102 JEditTripod -f tripod.txt -k "${FINAL_TRIPODS}" -o tripod.txt
103 
104 cat>acoustics_trigger_parameters.txt<<EOF
105 Q = 0.0;
106 TMax_s = 0.015;
107 numberOfHits = 210;
108 EOF
109 
110 cat>disable.txt<<EOF
111 # disable transmissions
112 # <emitter identifier> <module identifier>
113 # all emitters and ORCA.0003.16
114 # emitter 3 and ORCA.0018.06
115 # emitter 3 and ORCA.0001.12
116 -1 808966194
117 EOF
118 
119 cat>transmitter.txt<<EOF
120 # Data from D0ORCA018_baseAcousticBeacon.csv
121  9 27 0 -0.74 -0.64 0.71
122 EOF
123 
124 cat>hydrophone.txt<<EOF
125 # Data from D0ORCA018_hydrophones.csv
126  1 -1 -0.93 0.46 0.55
127  2 0 0.02 1.04 0.55
128  3 0 0.46 0.93 0.55
129  9 0 -0.75 -0.72 0.55
130  10 -1 0.11 1.04 0.55
131  12 0 0.46 0.93 0.55
132  4 0 0.20 1.02 0.55
133  18 0 0.61 0.84 0.55
134  28 0 0.69 0.78 0.55
135  11 0 -0.07 1.04 0.55
136  19 0 0.46 0.93 0.55
137  20 0 0.61 0.84 0.55
138  29 0 0.46 0.93 0.55
139  30 0 0.46 0.93 0.55
140  21 0 0.11 1.04 0.55
141  17 0 0.46 0.93 0.55
142  27 0 1.04 0.07 0.55
143  31 0 0.75 0.72 0.55
144 EOF
145 
146 JAcousticsEventBuilder.sh detector.datx $RUNS[*]
147 
148 INPUT_FILES=(`ls KM3NeT_${(l:8::0::0:)DETECTOR_ID}_0*${^RUNS}_event.root`)
149 
150 
151 # Run in WORKDIR
152 
153 cd $WORKDIR
154 
155 if [ ! $HOMEDIR -ef $WORKDIR ]; then
156  cp -p $HOMEDIR/$ACOUSTICS_DETECTOR $WORKDIR
157  cp -p $HOMEDIR/${^ACOUSTICS_KEYS}.txt $WORKDIR
158  cp -p $HOMEDIR/${^ACOUSTICS_AUXS}.txt $WORKDIR
159  cp -p $HOMEDIR/${^INPUT_FILES} $WORKDIR
160 fi
161 
162 cat>script.txt<<EOF
163 
164 fix string $FIXED_STRINGS[*]
165 fix tripod $FIXED_TRIPODS[*]
166 
167 stage 1B 1 0 100.0e-6 10.0 0 0.001 0.1
168 stage 2A 1 0 100.0e-6 10.0 20 0.2 0.5
169 stage 2C 1 0 100.0e-6 10.0 20 0.2
170 
171 initialise
172 
173 stage 2a 1 0 100.0e-6 10.0 20 0.2 0.5
174 stage 2c 1 0 100.0e-6 10.0 20 0.2
175 stage 3a 1 0 50.0e-6 10.0 20 0.2 0.5
176 stage 3c 1 0 50.0e-6 10.0 20 0.2
177 EOF
178 
179 JSydney.sh detector.datx $INPUT_FILES[*] script.txt
180 
181 if [ ! $HOMEDIR -ef $WORKDIR ]; then
182  cp -vru * $HOMEDIR
183 fi
then fatal No hydrophone data file $HYDROPHONE_TXT fi sort gr k
Q(UTCMax_s-UTCMin_s)-livetime_s
$WORKDIR stage
then fatal Detector file should be binary format fi eval JPrintDetector a $DETECTOR O IDENTIFIER typeset a INPUT_FILES expand_array RUNS for RUN in $RUNS[*]
then JLigier sh continue fi cat
Definition: JDAQDriver.sh:51
then usage $script[user directory] nThe user directory should be specified when this script is submitted in a batch queue fi case set_variable HOMEDIR
then fatal Wrong number of arguments fi set_variable DETECTOR $argv[1] set_variable INPUT_FILE $argv[2] eval JPrintDetector a $DETECTOR O SUMMARY JPrintDAQHeader f $INPUT_FILE read A DAQ_HEADER set_variable DETECTOR_ID
Definition: JSquid.sh:28
o $QUALITY_ROOT d $DEBUG!CHECK_EXIT_CODE JPlot1D f
Definition: JDataQuality.sh:76
exit
Definition: JPizza.sh:36
data_type r[M+1]
Definition: JPolint.hh:868
then
Definition: datalogs.sh:31
then fatal Wrong number of arguments fi set_variable DETECTOR $argv[1] set_variable TRIPOD $argv[2] set_array INPUT_FILES $argv[3,-1] eval JPrintDetector a $DETECTOR O IDENTIFIER eval JPrintDetector a $DETECTOR O CAN JAcoustics sh $DETECTOR_ID
Definition: footprint.sh:38
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR &dev null set_variable DETECTOR_ID set_array RUNS if do_usage *then usage $script< source directory > nThe source directory corresponds to a pre calibrated D0ARCA009 detector fi case set_variable DIR
then fatal Wrong number of arguments fi JConvertDetectorFormat a o
then fatal Missing detector file $DETECTOR fi eval JPrintDetector a $DETECTOR O IDENTIFIER RUNS
do JCanberra a $DETECTOR f $INPUT_FILE o $WORKDIR canberra[${EMITTER}\] root T $WORKDIR tripod txt V $WORKDIR sound_velocity txt M $WORKDIR mechanics txt H $WORKDIR hydrophone txt E $EMITTER $DISABLE d $DEBUG!done kill_child_processes_at_exit attach getModule a $DETECTOR typeset Z STRING typeset Z FLOOR for STRING in $STRINGS[*]
Definition: JCanberra.sh:70
static const double C
Physics constants.
do JPrintDAQHeader f $INPUT_FILE d read DETECTOR_ID RUN FRAME_INDEX TIMESLICE_START set_variable OUTPUT_FILE $WORKDIR KM3NeT_
then JCalibrateToT a
Definition: JTuneHV.sh:113
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR set_variable DEBUG set_variable WORKDIR if do_usage *then usage for INPUT_FILE in $INPUT_FILES[*]
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR &dev null set_variable
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR &dev null set_variable DEBUG set_variable WORKDIR
Definition: JLegolas.sh:20
* usage
then fatal Timeout at user input fi set_variable SERVER JServerDB wget no check certificate q https
Definition: JCookie.sh:58
do sput $STRING $FLOOR sget MODULE INPUT_FILES
Definition: JCanberra.sh:79
$WORKDIR ev_configure_dqsimulator txt echo process $DQ_SIMULATOR $i $SOURCE_HOST[$index] csh c(setenv ROOTSYS $ROOTSYS &&source $JPP_DIR/setenv.csh $JPP_DIR &&($DQ_SIMULATOR\-u\$NAME\$\-H\$SERVER\$\-M\$LOGGER\$\-d $DEBUG</dev/null > &/dev/null &))'
fi set_variable FILENAME $WORKDIR
Definition: datalogs.sh:34
then fatal Wrong number of arguments fi set_variable DETECTOR $argv[1] set_variable INPUT_FILE $argv[2] eval JPrintDetector a $DETECTOR O IDENTIFIER eval JPrintDetector a $DETECTOR O SUMMARY JAcoustics sh $DETECTOR_ID source JAcousticsToolkit sh CHECK_EXIT_CODE typeset A EMITTERS get_tripods $WORKDIR tripod txt EMITTERS get_transmitters $WORKDIR transmitter txt EMITTERS for EMITTER in
Definition: JCanberra.sh:48
then set_variable MODULE getModule a $DETECTOR L $STRING $FLOOR JEditDetector a $DETECTOR M $MODULE add $X o $DETECTOR else echo No update of detector $DETECTOR
then error Missing CDF files error Run
Definition: JSirene.sh:58
then cp
set_variable DETECTOR
do set_variable DETECTOR_TXT $WORKDIR detector
then echo
Definition: JQAQC.sh:96
source $JPP_DIR setenv csh $JPP_DIR &dev null eval JShellParser o a A
do echo Generating $dir eval D
Definition: JDrawLED.sh:53
then fatal Invalid tripod $TRIPOD
esac $JPP_BIN JLogger sh $LOGGER until pgrep JGetMessage</dev/null > dev null