45 const std::vector<std::string> Fun4AllEVIOInputManager::LIST_TIMERS = {
62 topNodeName(topnodename),
80 runNode->
addNode(runHeaderNode);
86 runNode->
addNode(hardSpillNode);
89 runNode->
addNode(paramDecoNode);
99 eventNode->
addNode(eventHeaderNode);
102 eventNode->
addNode(hardEventNode);
108 eventNode->
addNode(triggerhitNode);
118 for (
auto it = LIST_TIMERS.begin(); it != LIST_TIMERS.end(); it++) {
134 for (
auto it =
m_timers.begin(); it !=
m_timers.end(); it++)
delete it->second;
141 cout <<
"Closing currently open file "
143 <<
" and opening " << filenam << endl;
159 cout <<
PHWHERE <<
ThisName <<
": could not open file " << fname <<
" with status = " << status <<
"." << endl;
183 cout <<
Name() <<
": No Input file open" << endl;
191 cout <<
Name() <<
": No Input file from filelist opened" << endl;
198 m_timers[
"run_get_node"]->restart();
199 if (
verbosity > 3) cout <<
"Getting Event from " <<
Name() << endl;
202 SQRun* run_header = findNode::getClass<SQRun>(
topNode,
"SQRun");
210 SQIntMap* hard_spill_map = findNode::getClass<SQIntMap>(
topNode,
"SQHardSpillMap");
211 if (!hard_spill_map) {
215 SQEvent* event_header = findNode::getClass<SQEvent>(
topNode,
"SQEvent");
228 SQHitVector* trig_hit_vec = findNode::getClass<SQHitVector>(
topNode,
"SQTriggerHitVector");
234 m_timers[
"run_get_event"]->restart();
265 m_timers[
"run_set_param"]->restart();
278 m_timers[
"run_set_run_data"]->restart();
292 for (
int ii = 0; ii < 5; ii++) {
297 for (
int ii = 0; ii < 3; ii++) {
301 cout <<
" N of V1495 IDs != 5 but " << rd->
v1495_id[0] <<
"." << endl;
303 for (
int ii = 0; ii < 5; ii++) {
326 m_timers[
"run_set_run_data"]->stop();
328 m_timers[
"run_set_spill_data"]->restart();
371 double time_subsys, time_output;
376 m_timers[
"run_set_spill_data"]->stop();
378 m_timers[
"run_set_event_data"]->restart();
401 for (
int ii=0; ii<5; ii++) {
411 m_timers[
"run_set_event_data"]->stop();
413 m_timers[
"run_set_hit_data"]->restart();
414 for (HitDataList::iterator it = ed->
list_hit.begin(); it != ed->
list_hit.end(); it++) {
416 if (hd->
det == 0)
continue;
431 if (hd->
det == 0)
continue;
443 m_timers[
"run_set_hit_data"]->stop();
458 cout <<
Name() <<
": fileclose: No Input file open" << endl;
462 SQRun* sqrun = findNode::getClass<SQRun>(
topNode,
"SQRun");
469 cout <<
"Fun4AllEVIOInputManager: Timer:\n";
470 for (
auto it = LIST_TIMERS.begin(); it != LIST_TIMERS.end(); it++) {
506 list<string>::const_iterator iter =
filelist.begin();
509 cout <<
PHWHERE <<
" opening next file: " << *iter << endl;
513 cout <<
PHWHERE <<
" could not open file: " << *iter << endl;
540 cerr <<
"!!ERROR!! PushBackEvents(): Not implemented yet." << endl;
620 cout <<
PHWHERE <<
Name() <<
" No MasterSync object, cannot perform synchronization" << endl;
621 cout <<
"Most likely your first file does not contain a SyncObject and the file" << endl;
622 cout <<
"opened by the Fun4AllDstInputManager with Name " <<
Name() <<
" has one" << endl;
623 cout <<
"Change your macro and use the file opened by this input manager as first input" << endl;
624 cout <<
"and you will be okay. Fun4All will not process the current configuration" << endl << endl;
630 cout <<
"big problem" << endl;
int verbosity
The verbosity level. 0 means not verbose at all.
virtual const std::string Name() const
Returns the name of this module.
virtual int Verbosity() const
Gets the verbosity of this module.
void ReadSpillTimer(double &time_subsys, double &time_output)
static Fun4AllServer * instance()
PHCompositeNode * topNode() const
void CurrentEvent(const int evt)
void SegmentNumber(const int iseg)
void PrdfEvents(const int i)
void ForceLocalSpillID(const bool force)
void UseLocalSpillID(const bool use)
CodaInputManager * GetCoda()
bool NextPhysicsEvent(EventData *&ed, SpillData *&sd, RunData *&rd)
int OpenCodaFile(const std::string fname, const long file_size_min=32768, const int sec_wait=15, const int n_wait=40)
PHBoolean addNode(PHNode *)
PHNode * findFirst(const std::string &, const std::string &)
Class to measure the time spent by a code block.
An SQ interface class to hold one event header.
virtual void set_data_quality(const int a)=0
virtual void set_qie_turn_id(const int a)=0
virtual void set_qie_presum(const unsigned short i, const int a)=0
virtual void set_spill_id(const int a)=0
virtual void set_event_id(const int a)=0
virtual void set_qie_rf_id(const int a)=0
virtual void set_qie_rf_intensity(const short i, const int a)=0
virtual void set_run_id(const int a)=0
virtual void set_qie_trigger_count(const int a)=0
virtual void set_trigger(const SQEvent::TriggerMask i, const bool a)=0
An SQ interface class to hold one hardware-related event info.
virtual void set_coda_event_id(const int a)=0
virtual void set_after_inh_matrix(const unsigned short i, const bool a)=0
virtual void set_n_board_qie(const short a)=0
virtual void set_vme_time(const int a)=0
virtual void set_flag_v1495(const short a)=0
virtual void set_raw_matrix(const unsigned short i, const bool a)=0
virtual void set_n_board_v1495(const short a)=0
virtual void set_n_board_trig_bit(const short a)=0
virtual void set_n_board_trig_count(const short a)=0
virtual void set_n_board_taiwan(const short a)=0
virtual void set_time_input(const double a)
virtual void set_bos_coda_id(const int a)
virtual void set_bos_vme_time(const int a)
virtual void set_time_decode(const double a)
virtual void set_eos_vme_time(const int a)
virtual void set_eos_coda_id(const int a)
virtual void set_time_map(const double a)
An SQ interface class to hold the hardware-related data of one spill.
virtual void set_time_output(const double a)=0
virtual void set_time_subsys(const double a)=0
An SQ interface class to hold a list of SQHit objects.
virtual void push_back(const SQHit *hit)=0
An SQ interface class to hold one detector hit.
virtual void set_element_id(const short a)
virtual void set_level(const short a)
virtual void set_hit_id(const int a)
virtual void set_pos(const float a)
virtual void set_detector_id(const short a)
virtual void set_tdc_time(const float a)
virtual void set_drift_distance(const float a)
A general-purpose SQ interface class that holds a list of PHObjects with key = integer.
virtual const PHObject * get(unsigned int idkey) const
virtual PHObject * insert(const unsigned int idkey, const PHObject *item)
virtual void set_variable(const std::string name, const std::string value)=0
An SQ interface class to hold the run-level info.
virtual void set_n_v1495_d1ad(const int a)
virtual void set_run_id(const int a)
virtual void set_n_spill(const int a)
virtual void set_n_evt_all(const int a)
virtual void set_fpga_enabled(const int chan, const int a)
virtual void set_n_run_desc(const int a)
virtual void set_n_v1495_d2ad(const int a)
virtual void set_n_flush_evt(const int a)
virtual void set_n_t_hit_bad(const int a)
virtual void set_n_phys_evt(const int a)
virtual void set_n_t_hit(const int a)
virtual void set_unix_time_begin(const int a)
virtual void set_v1495_id(const int chan, const int id)
virtual void set_n_v1495(const int a)
virtual void set_unix_time_end(const int a)
virtual void set_n_hit_bad(const int a)
virtual void set_run_desc(const std::string a)
virtual void set_fpga_prescale(const int chan, const int a)
virtual void set_n_phys_evt_bad(const int a)
virtual void set_n_evt_dec(const int a)
virtual void set_n_fee_prescale(const int a)
virtual void set_n_fee_event(const int a)
virtual void set_nim_enabled(const int chan, const int a)
virtual void set_n_flush_evt_bad(const int a)
virtual void set_n_v1495_d3ad(const int a)
virtual void set_n_hit(const int a)
virtual void set_nim_prescale(const int chan, const int a)
virtual void set_name(const std::string a)
virtual void set_count(const int a)
virtual void set_type(const ScalerType_t a)
virtual void set_value(const std::string a)
virtual void set_type(const std::string a)
virtual void set_name(const std::string a)
virtual void set_time_stamp(const std::string a)
An SQ interface class to hold a list of SQSpill objects.
virtual const SQSpill * get(unsigned int idkey) const
Return the SQSpill entry having spill ID = 'idkey'. Return '0' if no entry exists.
virtual SQSpill * insert(const SQSpill *hit)
Insert the given SQSpill object.
An SQ interface class to hold the data of one spill.
virtual SQStringMap * get_slow_cont_list()
Return the list of slow control variables.
virtual void set_spill_id(const int a)
virtual void set_target_pos(const short a)
virtual SQStringMap * get_bos_scaler_list()
Return the list of scaler variables read out at BOS.
virtual void set_run_id(const int a)
virtual SQStringMap * get_eos_scaler_list()
Return the list of scaler variables read out at EOS.
virtual PHObject * insert(const std::string key, const PHObject *item)
virtual int Different(const SyncObject *other) const
virtual void SegmentNumber(const int)
set Segment Number
virtual void Reset()
Clear Sync.
virtual void EventNumber(const int)
set Event Number
virtual SyncObject * clone() const
Virtual copy constructor.
virtual void EventCounter(const int)
set Event Counter
virtual void RunNumber(const int)
set Run Number
int time_wait
waiting time in second to pretend the online data flow.
ChanMapV1495 chan_map_v1495
ChanMapTaiwan chan_map_taiwan
int verb
Verbosity. 0 = error, 1 = warning, 2 = info, 3 = debug, 4 = insane.
ChanMapScaler chan_map_scaler
HitDataList list_hit_trig
unsigned int triggerCount
double time_input
In msec.
unsigned int eos_vme_time
ScalerDataList list_scaler
double time_decode
In msec.
unsigned int bos_vme_time
SlowControlDataList list_slow_cont