Jpp  17.0.0
the software that should make you happy
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
software/JCompass/JCompass.sh
Go to the documentation of this file.
1 #!/bin/zsh
2 #
3 #
4 # \author mdejong
5 #
6 version=1.0
7 script=${0##*/}
8 
9 if [ -z $JPP_DIR ]; then
10  echo "Variable JPP_DIR undefined."
11  exit
12 fi
13 
14 source $JPP_DIR/setenv.sh $JPP_DIR
15 
16 set_variable: DEBUG COMPASS_DEBUG 2
17 set_variable: WORKDIR COMPASS_WORKDIR ./
18 set_variable: TMAX_S COMPASS_TMAX_S 600
19 set_variable: SIGMA_DEG COMPASS_SIGMA_DEG 0.5
20 set_variable: STDEV COMPASS_STDEV 5.0
21 set_variable: MESTIMATOR COMPASS_MESTIMATOR 1
22 set_variable: NUMBER_OF_OUTLIERS COMPASS_NUMBER_OF_OUTLIERS 0
23 
24 if do_usage $*; then
25  usage "$script <detector file> (run[-run])+ <output file>"\
26  "\nAuxiliary script for in situ compass calibration."
27 fi
28 
29 if (( $# < 3 )); then
30  fatal "Wrong number of parameters."
31 fi
32 
34 set_array RUNS $argv[2,-2]
35 set_variable OUTPUT_FILE $argv[-1]
36 
37 set_variable AHRS_CALIBRATION_FILE $WORKDIR/ahrs_calibration.txt
38 
39 if [[ ! ${DETECTOR##*\.} == "datx" ]]; then
40  fatal "Detector file should be binary format."
41 fi
42 
43 eval `JPrintDetector -a $DETECTOR -O IDENTIFIER`
44 
45 typeset -a INPUT_FILES
46 
47 for RANGE in $RUNS[*]; do
48 
49  for (( RUN = ${RANGE%%-*}; $RUN <= ${RANGE##*-}; RUN += 1 )); do
50 
51  set_variable INPUT_FILE $WORKDIR/KM3NeT_${(l:8::0::0:)DETECTOR_ID}_${(l:8::0::0:)RUN}_ahrs.root
52 
53  if [[ ! -f $INPUT_FILE ]]; then
54 
55  echo -n "Writing $INPUT_FILE... "
56 
57  JConvertDB \
58  -q "ahrs" \
59  -@ "detid = $DETECTOR_ID" \
60  -@ "minrun = $RUN" \
61  -@ "maxrun = $RUN" \
62  -o $INPUT_FILE \
63  -d $DEBUG --
64 
65  if (( $? == 0 )); then
66  echo "OK"
67  else
68  continue
69  fi
70  fi
71 
73 
74  done
75 done
76 
77 if [[ ! -f $AHRS_CALIBRATION_FILE ]]; then
78 
79  JAHRSCalibration \
80  -D $DETECTOR_ID \
81  -o $AHRS_CALIBRATION_FILE \
82  -d $DEBUG
83 fi
84 
86 
87 JCompass \
88  -a $DETECTOR \
89  -A \
90  -c $AHRS_CALIBRATION_FILE \
91  -f "$INPUT_FILES[*]" \
92  -o $OUTPUT_FILE \
93  -@ "Tmax_s = $TMAX_S" \
94  -@ "sigma_deg = $SIGMA_DEG" \
95  -@ "stdev = $STDEV" \
96  -@ "mestimator = $MESTIMATOR" \
97  -@ "numberOfOutliers = $NUMBER_OF_OUTLIERS" \
98  -d $DEBUG --!
99 
100 timer_stop
101 timer_print
then usage $script< detector identifier >< startdate\"YYYY-MM-DDHH:MM:SS\"><finaldate\"YYYY-MM-DDHH:MM:SS\"><QA/QCfile> fi case set_variable QAQC_TXT $argv[4]
Definition: JDataMonitor.sh:24
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR &dev null if do_usage *then usage $script< DEETECTOR_ID >< inputdetectorfile >< outputdetectorfile >< firstrun >< lastrun >< namesuffix >< outputdirectory >< datadirectory > fi DETECTOR_ID
Definition: SN_timecalib.sh:15
version
Definition: JEditTuneHV.sh:5
o $QUALITY_ROOT d $DEBUG!JPlot1D f
Definition: JDataQuality.sh:66
exit
Definition: JPizza.sh:36
then echo
const int n
Definition: JPolint.hh:676
then timer_start(JRandomTimesliceWriter-a ${DETECTOR}-o ${PIPE}-n ${NUMBER_OF_SLICES}-P ${PMT_FILE}-d ${DEBUG}-S ${SEED}-B"$BACKGROUND_HZ"-N"$RECYCLING"--!&&for((i=0;$i!=10;++i));do;echo 'EOF' > $PIPE;usleep 100000;done &&rm-f $PIPE)&JTimesliceReprocessor-a $
then fatal Detector file should be binary format fi eval JPrintDetector a $DETECTOR O IDENTIFIER typeset a INPUT_FILES for RANGE in $RUNS[*]
then echo Variable JPP_DIR undefined exit fi source $JPP_DIR setenv sh $JPP_DIR &dev null set_variable
Definition: JAcoustics.sh:21
then rm i $OUTPUT_FILE fi let RUN
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 JConvertDetectorFormat a $DETECTOR[1] o
then JFileTuna f $INPUT_FILE
Definition: file-Tuna.sh:66
&set_variable OUTPUT_FILE
set_variable INPUT_FILE
then fatal Wrong number of arguments fi set_variable DETECTOR $argv[1] set_variable TRIPOD $argv[2] set_variable TX $argv[3] set_variable TY $argv[4] if[[!-f $DETECTOR]]
Definition: JFootprint.sh:28
do sput $STRING $FLOOR sget MODULE INPUT_FILES
Definition: JCanberra.sh:77
then JMuonMCEvt f $INPUT_FILE o $INTERMEDIATE_FILE d
Definition: JMuonPath.sh:47
then JCalibrateToT a
Definition: JTuneHV.sh:116
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
*fatal Wrong number of arguments esac eval JPrintDetector a $DETECTOR O IDENTIFIER RUNS
then display $WORKDIR
Definition: plot-Domino.sh:128
$WORKDIR ev_configure_domsimulator txt echo process $DOM_SIMULATOR $i $SOURCE_HOST[$index] csh c(setenv ROOTSYS $ROOTSYS &&source $JPP_DIR/setenv.csh $JPP_DIR &&($DOM_SIMULATOR\-u\$NAME\$\-H\$SERVER\$\-M\$LOGGER\$\-d $DEBUG</dev/null > &/dev/null &))'
set_variable DETECTOR
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:46
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 detector identifier $DETECTOR_ID fi set_variable RUNSETUPID typeset a RANGE RANGE[1]
do JPrintDAQHeader f $INPUT_FILE d read DETECTOR_ID RUN FRAME_INDEX TIMESLICE_START set_variable OUTPUT_FILE $WORKDIR KM3NeT_
esac done
Definition: JAddHDE.sh:21
#define DEBUG(A)
Message macros.
Definition: JMessage.hh:62