38   static const char* 
const EFFICIENCY = 
"EFFICIENCY";
 
   48 int main(
int argc, 
char **argv)
 
   52   using namespace KM3NETDAQ;
 
   62     JParser<> zap(
"Auxiliary application to plot PMT parameters.");
 
   64     zap[
'a'] = 
make_field(detectorFile,      
"detector file.");
 
   67     zap[
'A'] = 
make_field(showPMTAddress,    
"show PMT address on y-axis");
 
   72   catch(
const exception &error) {
 
   73     FATAL(error.what() << endl);
 
   86     FATAL(
"Empty detector." << endl);
 
   91   for (JDetector::iterator module = 
detector.begin(); module != 
detector.end(); ++module) {
 
   93     DEBUG(
"Module " << setw(10) << module->getID() << endl);
 
   99       for (JProperties::const_iterator p = properties.begin(); p != properties.end(); ++p) {
 
  103         try { value = (p->second.getValue<
const double>()); }           
catch(
const exception& error) {}
 
  104         try { value = (p->second.getValue<
const bool>() ? 1.0 : 0.0); } 
catch(
const exception& error) {}
 
  106         manager[
MAKE_CSTRING(module->getID() << 
"." << p->first)]->SetBinContent(pmt + 1, value);
 
  111       manager[
MAKE_CSTRING(module->getID() << 
"." << EFFICIENCY)]->SetBinContent(pmt + 1, value);
 
  115   if (showPMTAddress) {
 
  123       istringstream(i->first) >> id;
 
Utility class to parse command line options. 
 
int main(int argc, char *argv[])
 
Utility class to parse parameter values. 
 
*fatal Wrong number of arguments esac JCookie sh typeset Z DETECTOR typeset Z SOURCE_RUN typeset Z TARGET_RUN set_variable PARAMETERS_FILE $WORKDIR parameters
 
#define MAKE_CSTRING(A)
Make C-string. 
 
Lookup table for PMT addresses in detector. 
 
Dynamic ROOT object management. 
 
Data structure for detector geometry and calibration. 
 
const JModuleAddressMap & get(const int id) const 
Get module address map. 
 
Auxiliary class to manage set of compatible ROOT objects (e.g. histograms) using unique keys...
 
I/O formatting auxiliaries. 
 
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object 
 
void setAxisLabels(TAxis *axis, const JModuleAddressMap &memo)
Set axis with PMT address labels. 
 
void Write(TDirectory &out, const bool wm=false)
Write objects to file. 
 
Auxiliary class for map of PMT parameters. 
 
JDetectorAddressMap & getDetectorAddressMap()
Get detector address map. 
 
General purpose messaging. 
 
void load(const std::string &file_name, JDetector &detector)
Load detector from input file. 
 
Utility class to parse command line options. 
 
double getSurvivalProbability(const JPMTParameters ¶meters)
Get model dependent probability that a one photo-electron hit survives the simulation of the PMT assu...
 
then usage $script< input_file >< detector_file > fi set_variable OUTPUT_DIR set_variable SELECTOR JDAQTimesliceL1 set_variable DEBUG case set_variable DEBUG
 
Data structure for PMT parameters. 
 
KM3NeT DAQ constants, bit handling, etc. 
 
static const int NUMBER_OF_PMTS
Total number of PMTs in module. 
 
double QE
relative quantum efficiency