9 #include <framework/modules/core/EventInfoSetterModule.h> 
   11 #include <framework/core/Environment.h> 
   12 #include <framework/utilities/Utils.h> 
   29 EventInfoSetterModule::EventInfoSetterModule() : 
Module()
 
   31   if (getenv(
"BELLE2_PRODUCTION"))
 
   36     "Sets the event meta data information (exp, run, evt). You must use this " 
   37     "module to tell basf2 about the number of events you want to generate, " 
   38     "unless you have an input module that already does so. Note that all " 
   39     "experiment/run combinations specified must be unique." 
   43   addParam(
"expList", 
m_expList, 
"List of experiment numbers. Can be overridden via --experiment argument to basf2.", 
m_expList);
 
   46            "should be processed. Can be overridden via -n argument to basf2.",
 
   49            "starting. Equivalent to running over this many events without performing " 
   50            "any action, to allow starting at higher event numbers.", 
m_eventsToSkip);
 
   52            "the specified (experiment, run, event number) occurs. This parameter " 
   53            "is useful for debugging to start with a specific event.", 
m_skipToEvent);
 
   67   if (numEventsArgument > 0 or runOverride >= 0 or expOverride >= 0) {
 
   69       B2ERROR(
"The -n/--events, --run, and --experiment options cannot be used when multiple runs are specified for EventInfoSetter!");
 
   79   if (skipNEventsOverride != 0)
 
   83   unsigned int defListSize = 
m_expList.size();
 
   85     B2ERROR(
"Parameters are inconsistent. The exp, run and evt lists must have the same number of entries.");
 
   86   } 
else if (defListSize == 0) {
 
   87     B2ERROR(
"There are no events to be processed!");
 
   89     set<pair<int, int>> expRunSet;
 
   90     for (
unsigned int i = 0; i < defListSize; i++) {
 
   93         B2ERROR(
"Exp " << ret.first->first << 
", run " << ret.first->second <<
 
   94                 " used more than once! Please make sure all experiment/run combinations are unique.");
 
   97         B2ERROR(
"Experiment " << 
m_expList[i] << 
" is out of range, should be in [0, 1023]!");
 
   99         B2ERROR(
"Run " << 
m_runList[i] << 
" is out of range, should be >= 0!");
 
  101       if (nevents == std::numeric_limits<unsigned int>::max()) {
 
  102         B2ERROR(
"Invalid number of events (valid range: 0.." << std::numeric_limits<unsigned int>::max() - 1 << 
")!");
 
  110       B2ERROR(
"skipToEvent must be a list of three values: experiment, run, event number");
 
  115       B2ERROR(
"You cannot supply a number of events to skip (skipNEvents) and an " 
  116               "event to skip to (skipToEvent) at the same time, ignoring skipNEvents");
 
  126   unsigned int totalevents = 0;
 
  128   while (copy.advanceEventCounter()) {
 
  132   B2DEBUG(100, 
"EventInfoSetter: will process " << totalevents << 
" events in total.");
 
  133   if (totalevents == 0) {
 
  134     B2FATAL(
"Total processed number of events is 0, please check your inputs, -n and --skip-events arguments!");
 
  178       unsigned int nskip = 1;
 
  204   auto time = std::chrono::high_resolution_clock::now().time_since_epoch();
 
  205   m_eventMetaDataPtr->setTime(std::chrono::duration_cast<std::chrono::nanoseconds>(time).count());
 
@ c_ErrorIfAlreadyRegistered
If the object/array was already registered, produce an error (aborting initialisation).
unsigned int getSkipEventsOverride() const
Get skipNEvents override, or 0 if unset.
int getExperimentOverride() const
Get experiment override, or -1 if unset.
int getRunOverride() const
Get run override, or -1 if unset.
static Environment & Instance()
Static method to get a reference to the Environment instance.
unsigned int getNumberEventsOverride() const
Returns number of events in run 1 for EventInfoSetter module, or 0 for no override.
void setNumberOfMCEvents(unsigned int n)
Set number of generated events (for EventInfoSetter).
Module to set event, run, experiment numbers.
std::vector< unsigned int > m_evtNumList
The list (column) of the number of events which should be processed.
virtual void initialize() override
Initializes the Module.
std::vector< int > m_runList
The list (column) of runs.
virtual void event() override
Stores the event meta data into the DataStore.
virtual ~EventInfoSetterModule()
Destructor.
unsigned int m_evtNumber
The current event number.
int m_production
The production number.
unsigned int m_eventsToSkip
skip this many events before starting.
StoreObjPtr< EventMetaData > m_eventMetaDataPtr
Output object.
std::vector< int > m_skipToEvent
The (expNo, runNo, evtNo) tuple to skip to, empty if not used.
std::vector< int > m_expList
The list (column) of experiments.
bool advanceEventCounter()
Advances member variables to the next event (which is given by m_evtNumber).
int m_colIndex
The current index for the exp and run lists.
void setDescription(const std::string &description)
Sets the description of the module.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define branch_unlikely(x)
A macro to tell the compiler that the argument x will be very likely be false.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Abstract base class for different kinds of events.