Jpp  18.3.0-209-g56ce19a
the software that should make you happy
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
pre-calibration_D0ORCA015.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 D0ORCA015 (138) 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 15458-15466
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 D1ORCA011 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 3 taken from /pbs/throng/km3net/detectors/KMNeT_00000100_20220310.tripod.txt
57 # position of emitter 5 taken from https://elog.km3net.de/Operations+FR/8271 (RAB1v2)
58 # position of emitter 6 taken from https://elog.km3net.de/Operations+FR/8731 (RAB2)
59 3 +257097.050 +4743636.700 -2440.300
60 5 +257040.800 +4743317.600 -2439.900
61 6 +256807.500 +4743636.500 -2442.500
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 eval `JPrintDetector -a detector.datx -O SUMMARY`
78 
79 for STRING in ${STRINGS[*]}; do
80 
81  set_variable MODULE `getModule -a detector.datx -L "$STRING 0"`
82 
83  JEditDetector \
84  -a detector.datx \
85  -M "$MODULE setz -2.9" \
86  -o detector.datx --!
87 done
88 
89 JEditDetector -a detector.datx -r "$FIXED_STRINGS[*]" -o detector.datx --!
90 JMergeDetector -a detector.datx -a detector_tmp.datx -o detector.datx --!
91 JEditDetector -a detector.datx -k "$FINAL_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 = 200;
108 EOF
109 
110 cat>disable.txt<<EOF
111 # disable transmissions
112 # <emitter identifier> <module identifier>
113 # all emit. and ORCA.0003.16
114 # emitter 3 and ORCA.0001.12
115 -1 808966194
116  3 809503416
117 EOF
118 
119 cat>transmitter.txt<<EOF
120 # Data from D0ORCA015_baseAcousticBeacon.csv
121  7 20 0 0.02 -0.97 0.71
122 EOF
123 
124 cat>hydrophone.txt<<EOF
125 # Data from D0ORCA015_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 EOF
142 
143 JAcousticsEventBuilder.sh detector.datx $RUNS[*]
144 
145 INPUT_FILES=(`ls KM3NeT_${(l:8::0::0:)DETECTOR_ID}_0*${^RUNS}_event.root`)
146 
147 
148 # Run in WORKDIR
149 
150 cd $WORKDIR
151 
152 if [ ! $HOMEDIR -ef $WORKDIR ]; then
153  cp -p $HOMEDIR/$ACOUSTICS_DETECTOR $WORKDIR
154  cp -p $HOMEDIR/${^ACOUSTICS_KEYS}.txt $WORKDIR
155  cp -p $HOMEDIR/${^ACOUSTICS_AUXS}.txt $WORKDIR
156  cp -p $HOMEDIR/${^INPUT_FILES} $WORKDIR
157 fi
158 
159 cat>script.txt<<EOF
160 
161 fix string $FIXED_STRINGS[*]
162 fix tripod $FIXED_TRIPODS[*]
163 
164 stage 1B 1 0 100.0e-6 10.0 0 0.001 0.1
165 stage 2A 1 0 100.0e-6 10.0 20 0.2 0.5
166 stage 2C 1 0 100.0e-6 10.0 20 0.2
167 
168 initialise
169 
170 stage 2a 1 0 100.0e-6 10.0 20 0.2 0.5
171 stage 2c 1 0 100.0e-6 10.0 20 0.2
172 stage 3a 1 0 50.0e-6 10.0 20 0.2 0.5
173 stage 3c 1 0 50.0e-6 10.0 20 0.2
174 EOF
175 
176 JSydney.sh detector.datx $INPUT_FILES[*] script.txt
177 
178 if [ ! $HOMEDIR -ef $WORKDIR ]; then
179  cp -vru * $HOMEDIR
180 fi
then fatal No hydrophone data file $HYDROPHONE_TXT fi sort gr k
Q(UTCMax_s-UTCMin_s)-livetime_s
clean eval JPrintDetector a $DETECTOR O IDENTIFIER eval JPrintDetector a $DETECTOR O SUMMARY set_variable STRING
then usage eval JPrintDetector a $DETECTOR O IDENTIFIER eval JPrintDetector a $DETECTOR O SUMMARY JAcoustics sh $DETECTOR_ID JCanberra sh $DETECTOR $INPUT_FILES[*] $WORKDIR canberra[%\] root source JAcousticsToolkit sh CHECK_EXIT_CODE typeset A EMITTERS get_tripods $WORKDIR tripod txt EMITTERS get_transmitters $WORKDIR transmitter txt EMITTERS kill_child_processes_at_exit attach getModule a $DETECTOR typeset Z STRING typeset Z FLOOR for STRING in $STRINGS[*]
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:34
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
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
$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 &))'
set_array INPUT_FILES argv[2,$((START_INDEX_STRING-1))] set_array STRINGS
*fatal Invalid number of arguments esac set_variable DETID getDetector D $DETID O string set_variable FILENAME $WORKDIR
Definition: datalogs.sh:27
then fatal The output file must have the wildcard in the e g root fi 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
do sput $STRING $FLOOR sget MODULE INPUT_FILES
*fatal Wrong number of arguments esac for INPUT_FILE in eval ls rt $DIR stage
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
const JModule & getModule(const JDetector &detector, const JModuleLocation &location)
find module with a given string and floor number
esac done
Definition: JAddHDE.sh:21
*fatal Wrong number of arguments esac source JAcousticsToolkit sh mkdir p $WORKDIR post calibration pushd $WORKDIR post calibration post calibration_D0ARCA009 sh $DIR popd set_variable DETECTOR $WORKDIR post calibration detector datx set_variable TRIPOD $WORKDIR post calibration tripod txt set_variable DETECTOR_INITIAL detector_initial datx expand_array RUNS mkdir p $HOMEDIR cd $HOMEDIR JDetectorDB D $DETECTOR_ID r $RUNS[1] V WW o $DETECTOR_INITIAL JEditDetector a $DETECTOR r o detector_tmp datx!eval JPrintDetector a $DETECTOR_INITIAL O SUMMARY