Jpp
Functions
JSimbad.cc File Reference
#include <string>
#include <iostream>
#include <iomanip>
#include "JDAQ/JDAQSummarysliceIO.hh"
#include "JDetector/JDetector.hh"
#include "JDetector/JDetectorToolkit.hh"
#include "JDetector/JDetectorSimulator.hh"
#include "JDetector/JModuleMapper.hh"
#include "JDetector/JK40Rates.hh"
#include "JDetector/JPMTParametersMap.hh"
#include "JDetector/JK40DefaultSimulator.hh"
#include "JDetector/JPMTDefaultSimulator.hh"
#include "JDetector/JCLBDefaultSimulator.hh"
#include "JDetector/JK40RunByRunSimulator.hh"
#include "JDetector/JPMTRunByRunSimulator.hh"
#include "JSupport/JSingleFileScanner.hh"
#include "JSupport/JFileRecorder.hh"
#include "JSupport/JSupport.hh"
#include "JSupport/JMeta.hh"
#include "JSummaryslice/JSummaryslice.hh"
#include "JTools/JRange.hh"
#include "Jeep/JPrint.hh"
#include "Jeep/JParser.hh"
#include "Jeep/JMessage.hh"

Go to the source code of this file.

Functions

int main (int argc, char **argv)
 

Detailed Description

Example program to simulate summary data.

Author
mdejong

Definition in file JSimbad.cc.

Function Documentation

◆ main()

int main ( int  argc,
char **  argv 
)

Definition at line 39 of file JSimbad.cc.

40 {
41  using namespace std;
42  using namespace JPP;
43  using namespace KM3NETDAQ;
44 
47  JLimit_t& numberOfEvents = inputFile.getLimit();
48  string detectorFile;
49  JPMTParametersMap pmtParameters;
50  JPMTRateRange R_Hz;
51  int debug;
52 
53  try {
54 
55  JParser<> zap("Example program to simulate summary data.");
56 
57  zap['f'] = make_field(inputFile, "input DAQ file");
58  zap['o'] = make_field(outputFile, "output file") = "simbad.root";
59  zap['n'] = make_field(numberOfEvents) = JLimit::max();
60  zap['a'] = make_field(detectorFile , "detector file");
61  zap['P'] = make_field(pmtParameters, "PMT simulation data (or corresponding file name)") = JPARSER::initialised();
62  zap['R'] = make_field(R_Hz) = JPMTRateRange();
63  zap['d'] = make_field(debug, "debug") = 0;
64 
65  zap(argc, argv);
66  }
67  catch(const exception &error) {
68  FATAL(error.what() << endl);
69  }
70 
71  cout.tie(&cerr);
72 
74 
75  try {
76  load(detectorFile, detector);
77  }
78  catch(const JException& error) {
79  FATAL(error);
80  }
81 
82  JPMTParametersMap::Throw(true);
83 
84  if (!pmtParameters.is_valid()) {
85  FATAL("Invalid PMT parameters " << pmtParameters << endl);
86  }
87 
88  const JModuleRouter moduleRouter(detector);
90  JSummaryRouter summaryRouter;
91 
92  try {
93  simbad.reset(new JK40RunByRunSimulator(summaryRouter, JK40Rates()));
94  simbad.reset(new JPMTRunByRunSimulator(summaryRouter, pmtParameters, detector, R_Hz));
95  simbad.reset(new JCLBDefaultSimulator());
96  }
97  catch(const JException& error) {
98  FATAL(error.what() << endl);
99  }
100 
101  outputFile.open();
102 
103  if (!outputFile.is_open()) {
104  FATAL("Error opening file " << outputFile << endl);
105  }
106 
107  outputFile.put(JMeta(argc, argv));
108 
109  while (inputFile.hasNext()) {
110 
111  STATUS("event: " << setw(10) << inputFile.getCounter() << '\r'); DEBUG(endl);
112 
113  JDAQSummaryslice* summary = inputFile.next();
114 
115  summaryRouter.update(summary);
116 
117  summaryRouter.correct(dynamic_cast<const JPMTDefaultSimulatorInterface&>(simbad.getPMTSimulator()));
118 
119  outputFile.put(JSummaryslice(summary->getDAQChronometer(),simbad));
120  }
121  STATUS(endl);
122 
123  outputFile.close();
124 }
KM3NETDAQ::JSummaryslice::correct
void correct(const JPMTDefaultSimulatorInterface &simulator)
Correct measured singles rates for the probability that a hit survives the simulation of the PMT.
Definition: JSummaryslice.hh:121
JDETECTOR::JPMTRateRange
Data structure for range of PMT rates.
Definition: JPMTRateRange.hh:22
JSUPPORT::JSingleFileScanner::getCounter
counter_type getCounter() const
Get counter.
Definition: JSingleFileScanner.hh:208
JSUPPORT::JLimit
Auxiliary class for defining the range of iterations of objects.
Definition: JLimit.hh:41
JDETECTOR::JCLBDefaultSimulator
Default CLB simulation.
Definition: JCLBDefaultSimulator.hh:139
JPARSER::initialised
Empty structure for specification of parser element that is initialised (i.e.
Definition: JParser.hh:63
JDETECTOR::load
void load(const JString &file_name, JDetector &detector)
Load detector from input file.
Definition: JDetectorToolkit.hh:476
JSUPPORT::JSingleFileScanner::next
virtual const pointer_type & next()
Get next element.
Definition: JSingleFileScanner.hh:280
JPARSER::JParser
Utility class to parse command line options.
Definition: JParser.hh:1493
JDETECTOR::JPMTRunByRunSimulator
PMT simulation based on run-by-run information.
Definition: JPMTRunByRunSimulator.hh:32
JDETECTOR::JK40RunByRunSimulator
K40 simulation based on run-by-run information.
Definition: JK40RunByRunSimulator.hh:29
JSUPPORT::JSingleFileScanner::hasNext
virtual bool hasNext()
Check availability of next element.
Definition: JSingleFileScanner.hh:234
JPP
This name space includes all other name spaces (except KM3NETDAQ, KM3NET and ANTARES).
Definition: JAAnetToolkit.hh:37
JDETECTOR::JK40Rates
Auxiliary class for K40 rates.
Definition: JK40Rates.hh:41
debug
int debug
debug level
Definition: JSirene.cc:59
KM3NETDAQ::JSummaryslice
Auxiliary class to create summary data.
Definition: JSummaryslice.hh:33
KM3NETDAQ::JDAQSummaryslice
Data summary slice.
Definition: JDAQSummaryslice.hh:25
JDETECTOR::JPMTParametersMap
Auxiliary class for map of PMT parameters.
Definition: JPMTParametersMap.hh:88
JTRIGGER::JSummaryRouter
Router for fast addressing of summary data in JDAQSummaryslice data structure as a function of the op...
Definition: JSummaryRouter.hh:32
STATUS
#define STATUS(A)
Definition: JMessage.hh:63
JDETECTOR::JModuleRouter
Router for direct addressing of module data in detector data structure.
Definition: JModuleRouter.hh:34
make_field
#define make_field(A,...)
macro to convert parameter to JParserTemplateElement object
Definition: JParser.hh:1954
JDETECTOR::JDetector
Detector data structure.
Definition: JDetector.hh:80
JAANET::detector
Detector file.
Definition: JHead.hh:130
KM3NETDAQ::JDAQChronometer::getDAQChronometer
const JDAQChronometer & getDAQChronometer() const
Get DAQ chronometer.
Definition: JDAQChronometer.hh:88
JSUPPORT::JMeta
Auxiliary class for ROOT I/O of application specific meta data.
Definition: JMeta.hh:71
DEBUG
#define DEBUG(A)
Message macros.
Definition: JMessage.hh:62
JTRIGGER::JSummaryRouter::update
void update(JDAQSummaryslice *ps)
Update router.
Definition: JSummaryRouter.hh:49
std
Definition: jaanetDictionary.h:36
JDETECTOR::JDetectorSimulator
Detector simulation.
Definition: JDetectorSimulator.hh:33
KM3NETDAQ
KM3NeT DAQ data structures and auxiliaries.
Definition: DataQueue.cc:39
JDETECTOR::JPMTParametersMap::is_valid
bool is_valid() const
Check validity of PMT parameters.
Definition: JPMTParametersMap.hh:242
JLANG::JException::what
virtual const char * what() const
Get error message.
Definition: JException.hh:48
FATAL
#define FATAL(A)
Definition: JMessage.hh:67
outputFile
string outputFile
Definition: JDAQTimesliceSelector.cc:37
JSUPPORT::JFileRecorder
Object writing to file.
Definition: JFileRecorder.hh:41
JLANG::JException
General exception.
Definition: JException.hh:23
JSUPPORT::JSingleFileScanner
Object reading from a list of files.
Definition: JSingleFileScanner.hh:75