26{
29
31 JLimit_t& numberOfEvents = inputFile.getLimit();
32 string detectorFile;
33 bool overwriteDetector;
35
36 try {
37
38 JParser<> zap(
"Auxialiry program to determine average creep of strings.");
39
40 zap[
'f'] =
make_field(inputFile,
"input file (output of JKatoomba[.sh])");
42 zap[
'a'] =
make_field(detectorFile,
"detector file.") =
"";
43 zap[
'A'] =
make_field(overwriteDetector,
"overwrite detector file provided through '-a' with average stretching.");
45
46 zap(argc, argv);
47 }
48 catch(const exception &error) {
49 FATAL(error.what() << endl);
50 }
51
53
54 if (detectorFile != "") {
55 try {
57 }
60 }
61 }
62
64
66
68
70
71 for (JEvt::const_iterator i = evt->begin(); i != evt->end(); ++i) {
72 Q[i->id].put(i->vs);
73 }
74 }
76
79 cout << setw(4) << i->first << ' '
80 << setw(6) << i->second.getCount() << ' '
81 <<
FIXED(9,6) << i->second.getMean (0.0) <<
' '
82 <<
FIXED(9,6) << i->second.getSTDev(0.0) << endl;
83 }
84 }
85
86 if (overwriteDetector) {
87
89
90 for (JDetector::iterator module =
detector.begin(); module !=
detector.end(); ++module) {
91 buffer[module->getString()][module->getFloor()] = &(*module);
92 }
93
95
96 if (buffer.count(i->first) != 0 && buffer[i->first].count(0) != 0) {
97
98 const double z0 = buffer[i->first][0]->getZ();
99
100 for (auto& module : buffer[i->first]) {
101
102 if (module.second->getFloor() != 0) {
103
104 const double z1 = module.second->getZ();
105
106 module.second->add(JPosition3D(0.0, 0.0, i->second.getMean(0.0) * (z1 - z0)));
107 }
108 }
109
110 } else {
111
112 FATAL(
"Missing location " <<
FILL(4,
'0') << i->first <<
'.' <<
FILL(2,
'0') << 0 <<
FILL() << endl);
113 }
114 }
115
116 NOTICE(
"Store stretching data on file " << detectorFile << endl);
117
119 }
120}
#define DEBUG(A)
Message macros.
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object
Utility class to parse command line options.
General purpose class for object reading from a list of file names.
virtual bool hasNext() override
Check availability of next element.
counter_type getCounter() const
Get counter.
virtual const pointer_type & next() override
Get next element.
void load(const std::string &file_name, JDetector &detector)
Load detector from input file.
void store(const std::string &file_name, const JDetector &detector)
Store detector to output file.
This name space includes all other name spaces (except KM3NETDAQ, KM3NET and ANTARES).
Auxiliary data structure for sequence of same character.
Auxiliary data structure for floating point format specification.
Auxiliary class for defining the range of iterations of objects.
static counter_type max()
Get maximum counter value.