![]() |
The Gaudi Framework
v27r1
|
#include <GaudiHive/HiveEventLoopMgr.h>


Public Member Functions | |
| HiveEventLoopMgr (const std::string &nam, ISvcLocator *svcLoc) | |
| Standard Constructor. More... | |
| virtual | ~HiveEventLoopMgr () |
| Standard Destructor. More... | |
| StatusCode | getEventRoot (IOpaqueAddress *&refpAddr) |
| Create event address using event selector. More... | |
| virtual StatusCode | initialize () |
| implementation of IService::initialize More... | |
| virtual StatusCode | reinitialize () |
| implementation of IService::reinitialize More... | |
| virtual StatusCode | stop () |
| implementation of IService::stop More... | |
| virtual StatusCode | finalize () |
| implementation of IService::finalize More... | |
| virtual StatusCode | nextEvent (int maxevt) |
| implementation of IService::nextEvent More... | |
| virtual StatusCode | executeEvent (void *par) |
| implementation of IEventProcessor::executeEvent(void* par) More... | |
| virtual StatusCode | executeRun (int maxevt) |
| implementation of IEventProcessor::executeRun() More... | |
| void | taskFinished (IAlgorithm *&algo) |
| Decrement the number of algos in flight and put algo back in manager - maybe private. More... | |
Public Member Functions inherited from MinimalEventLoopMgr | |
| MinimalEventLoopMgr (const std::string &nam, ISvcLocator *svcLoc) | |
| Standard Constructor. More... | |
| ~MinimalEventLoopMgr () override=default | |
| Standard Destructor. More... | |
| StatusCode | initialize () override |
| implementation of IService::initialize More... | |
| StatusCode | start () override |
| implementation of IService::start More... | |
| StatusCode | stop () override |
| implementation of IService::stop More... | |
| StatusCode | finalize () override |
| implementation of IService::finalize More... | |
| StatusCode | reinitialize () override |
| implementation of IService::reinitialize More... | |
| StatusCode | restart () override |
| implementation of IService::restart More... | |
| StatusCode | nextEvent (int maxevt) override |
| implementation of IEventProcessor::nextEvent More... | |
| StatusCode | executeEvent (void *par) override |
| implementation of IEventProcessor::executeEvent(void* par) More... | |
| StatusCode | executeRun (int maxevt) override |
| implementation of IEventProcessor::executeRun( ) More... | |
| StatusCode | stopRun () override |
| implementation of IEventProcessor::stopRun( ) More... | |
| void | topAlgHandler (Property &p) |
| Top algorithm List handler. More... | |
| StatusCode | decodeTopAlgs () |
| decodeTopAlgNameList & topAlgNameListHandler More... | |
| void | outStreamHandler (Property &p) |
| Output stream List handler. More... | |
| StatusCode | decodeOutStreams () |
| decodeOutStreamNameList & outStreamNameListHandler More... | |
Public Member Functions inherited from extends< Service, IEventProcessor > | |
| void * | i_cast (const InterfaceID &tid) const override |
| Implementation of IInterface::i_cast. More... | |
| StatusCode | queryInterface (const InterfaceID &ti, void **pp) override |
| Implementation of IInterface::queryInterface. More... | |
| std::vector< std::string > | getInterfaceNames () const override |
| Implementation of IInterface::getInterfaceNames. More... | |
| ~extends () override=default | |
| Virtual destructor. More... | |
Public Member Functions inherited from Service | |
| const std::string & | name () const override |
| Retrieve name of the service. More... | |
| StatusCode | configure () override |
| StatusCode | initialize () override |
| StatusCode | start () override |
| StatusCode | stop () override |
| StatusCode | finalize () override |
| StatusCode | terminate () override |
| Gaudi::StateMachine::State | FSMState () const override |
| Gaudi::StateMachine::State | targetFSMState () const override |
| StatusCode | reinitialize () override |
| StatusCode | restart () override |
| StatusCode | sysInitialize () override |
| Initialize Service. More... | |
| StatusCode | sysStart () override |
| Initialize Service. More... | |
| StatusCode | sysStop () override |
| Initialize Service. More... | |
| StatusCode | sysFinalize () override |
| Finalize Service. More... | |
| StatusCode | sysReinitialize () override |
| Re-initialize the Service. More... | |
| StatusCode | sysRestart () override |
| Re-initialize the Service. More... | |
| StatusCode | setProperty (const Property &p) override |
| StatusCode | setProperty (const std::string &s) override |
| StatusCode | setProperty (const std::string &n, const std::string &v) override |
| StatusCode | getProperty (Property *p) const override |
| const Property & | getProperty (const std::string &name) const override |
| StatusCode | getProperty (const std::string &n, std::string &v) const override |
| const std::vector< Property * > & | getProperties () const override |
| bool | hasProperty (const std::string &name) const override |
| template<class TYPE > | |
| StatusCode | setProperty (const std::string &name, const TYPE &value) |
| set the property form the value More... | |
| Service (std::string name, ISvcLocator *svcloc) | |
| Standard Constructor. More... | |
| SmartIF< ISvcLocator > & | serviceLocator () const override |
| Retrieve pointer to service locator. More... | |
| StatusCode | setProperties () |
| Method for setting declared properties to the values specified for the job. More... | |
| template<class T > | |
| StatusCode | service (const std::string &name, const T *&psvc, bool createIf=true) const |
| Access a service by name, creating it if it doesn't already exist. More... | |
| template<class T > | |
| StatusCode | service (const std::string &name, T *&psvc, bool createIf=true) const |
| template<typename IFace = IService> | |
| SmartIF< IFace > | service (const std::string &name, bool createIf=true) const |
| template<class T > | |
| StatusCode | service (const std::string &svcType, const std::string &svcName, T *&psvc) const |
| Access a service by name and type, creating it if it doesn't already exist. More... | |
| template<class T > | |
| Property * | declareProperty (const std::string &name, T &property, const std::string &doc="none") const |
| Declare the named property. More... | |
| Property * | declareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="") const |
| Declare remote named properties. More... | |
| template<class T > | |
| StatusCode | declarePrivateTool (ToolHandle< T > &handle, std::string toolTypeAndName="", bool createIf=true) |
| Declare used Private tool. More... | |
| template<class T > | |
| StatusCode | declarePublicTool (ToolHandle< T > &handle, std::string toolTypeAndName="", bool createIf=true) |
| Declare used Public tool. More... | |
| SmartIF< IAuditorSvc > & | auditorSvc () const |
| The standard auditor service.May not be invoked before sysInitialize() has been invoked. More... | |
Public Member Functions inherited from CommonMessagingBase | |
| virtual | ~CommonMessagingBase ()=default |
| Virtual destructor. More... | |
| SmartIF< IMessageSvc > & | msgSvc () const |
| The standard message service. More... | |
| MsgStream & | msgStream () const |
| Return an uninitialized MsgStream. More... | |
| MsgStream & | msgStream (const MSG::Level level) const |
| Predefined configurable message stream for the efficient printouts. More... | |
| MsgStream & | always () const |
| shortcut for the method msgStream(MSG::ALWAYS) More... | |
| MsgStream & | fatal () const |
| shortcut for the method msgStream(MSG::FATAL) More... | |
| MsgStream & | err () const |
| shortcut for the method msgStream(MSG::ERROR) More... | |
| MsgStream & | error () const |
| shortcut for the method msgStream(MSG::ERROR) More... | |
| MsgStream & | warning () const |
| shortcut for the method msgStream(MSG::WARNING) More... | |
| MsgStream & | info () const |
| shortcut for the method msgStream(MSG::INFO) More... | |
| MsgStream & | debug () const |
| shortcut for the method msgStream(MSG::DEBUG) More... | |
| MsgStream & | verbose () const |
| shortcut for the method msgStream(MSG::VERBOSE) More... | |
| MsgStream & | msg () const |
| shortcut for the method msgStream(MSG::INFO) More... | |
| MSG::Level | msgLevel () const |
| get the output level from the embedded MsgStream More... | |
| MSG::Level | outputLevel () const __attribute__((deprecated)) |
| Backward compatibility function for getting the output level. More... | |
| bool | msgLevel (MSG::Level lvl) const |
| get the output level from the embedded MsgStream More... | |
Public Member Functions inherited from extend_interfaces< Interfaces...> | |
| ~extend_interfaces () override=default | |
| Virtual destructor. More... | |
Protected Types | |
| typedef std::vector< std::vector< std::string > > | algosDependenciesCollection |
| Algorithms Inputs. More... | |
Protected Types inherited from MinimalEventLoopMgr | |
| enum | State { OFFLINE, CONFIGURED, FINALIZED, INITIALIZED } |
Protected Member Functions | |
| void | find_dependencies () |
| Get the input and output collections. More... | |
Protected Member Functions inherited from Service | |
| ~Service () override | |
| Standard Destructor. More... | |
| int | outputLevel () const |
get the Service's output level More... | |
Protected Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
| void | updateMsgStreamOutputLevel (int level) |
| Update the output level of the cached MsgStream. More... | |
Protected Attributes | |
| SmartIF< IDataManagerSvc > | m_evtDataMgrSvc |
| Reference to the Event Data Service's IDataManagerSvc interface. More... | |
| SmartIF< IDataProviderSvc > | m_evtDataSvc |
| Reference to the Event Data Service's IDataProviderSvc interface. More... | |
| SmartIF< IEvtSelector > | m_evtSelector |
| Reference to the Event Selector. More... | |
| IEvtSelector::Context * | m_evtContext |
| Event Iterator. More... | |
| std::string | m_evtsel |
| Event selector. More... | |
| SmartIF< IDataManagerSvc > | m_histoDataMgrSvc |
| Reference to the Histogram Data Service. More... | |
| SmartIF< IConversionSvc > | m_histoPersSvc |
| Reference to the Histogram Persistency Service. More... | |
| SmartIF< IHiveWhiteBoard > | m_whiteboard |
| Reference to the Histogram Persistency Service. More... | |
| SmartIF< IAlgResourcePool > | m_algResourcePool |
| Reference to the Algorithm resource pool. More... | |
| std::string | m_histPersName |
| Name of the Hist Pers type. More... | |
| SmartIF< IProperty > | m_appMgrProperty |
| Property interface of ApplicationMgr. More... | |
| bool | m_endEventFired |
| Flag to avoid to fire the EnvEvent incident twice in a row (and also not before the first event) More... | |
| bool | m_warnings |
| Flag to disable warning messages when using external input. More... | |
| unsigned int | m_max_parallel |
| Maximum number of parallel running algorithms. More... | |
| tbb::task_scheduler_init * | m_tbb_scheduler_init |
| Pointer to tbb task scheduler. More... | |
| state_type | m_termination_requirement |
| The termination requirement. More... | |
| std::vector< state_type > | m_all_requirements |
| All requirements. More... | |
| std::map< DataObjID, unsigned int > | m_product_indices |
| Register of input products. More... | |
| std::atomic_uint | m_total_algos_in_flight |
| Total number of algos in flight across all events. More... | |
| unsigned int | m_numberOfAlgos |
| Total number of algos. More... | |
| bool | m_DumpQueues |
| Dump the algorithm queues. More... | |
| unsigned int | m_evts_parallel |
| Number of events in parallel. More... | |
| unsigned int | m_num_threads |
| Total numbers of threads. More... | |
| bool | m_CloneAlgorithms |
| Clone algorithms to run them simultaneously. More... | |
| algosDependenciesCollection | m_AlgosDependencies |
| unsigned int | m_nProducts |
Protected Attributes inherited from MinimalEventLoopMgr | |
| SmartIF< IAppMgrUI > | m_appMgrUI |
| Reference to the IAppMgrUI interface of the application manager. More... | |
| SmartIF< IIncidentSvc > | m_incidentSvc |
| Reference to the incident service. More... | |
| ListAlg | m_topAlgList |
| List of top level algorithms. More... | |
| ListAlg | m_outStreamList |
| List of output streams. More... | |
| std::string | m_outStreamType |
| Out Stream type. More... | |
| StringArrayProperty | m_topAlgNames |
| List of top level algorithms names. More... | |
| StringArrayProperty | m_outStreamNames |
| List of output stream names. More... | |
| State | m_state = OFFLINE |
| State of the object. More... | |
| bool | m_scheduledStop = false |
| Scheduled stop of event processing. More... | |
| SmartIF< IIncidentListener > | m_abortEventListener |
| Instance of the incident listener waiting for AbortEvent. More... | |
| bool | m_abortEvent = false |
| Flag signalling that the event being processedhas to be aborted (skip all following top algs). More... | |
| std::string | m_abortEventSource |
| Source of the AbortEvent incident. More... | |
Protected Attributes inherited from Service | |
| IntegerProperty | m_outputLevel = MSG::NIL |
| Service output level. More... | |
| Gaudi::StateMachine::State | m_state = Gaudi::StateMachine::OFFLINE |
| Service state. More... | |
| Gaudi::StateMachine::State | m_targetState = Gaudi::StateMachine::OFFLINE |
| Service state. More... | |
Additional Inherited Members | |
Public Types inherited from MinimalEventLoopMgr | |
| typedef std::vector< SmartIF< IAlgorithm > > | ListAlg |
Public Types inherited from extends< Service, IEventProcessor > | |
| using | base_class = extends |
| Typedef to this class. More... | |
| using | extend_interfaces_base = extend_interfaces< Interfaces...> |
| Typedef to the base of this class. More... | |
Public Types inherited from Service | |
| typedef Gaudi::PluginService::Factory< IService *, const std::string &, ISvcLocator * > | Factory |
Public Types inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
| using | base_class = CommonMessaging |
Public Types inherited from extend_interfaces< Interfaces...> | |
| using | ext_iids = typename Gaudi::interface_list_cat< typename Interfaces::ext_iids...>::type |
| take union of the ext_iids of all Interfaces... More... | |
Definition at line 32 of file HiveEventLoopMgr.h.
|
protected |
Algorithms Inputs.
Definition at line 91 of file HiveEventLoopMgr.h.
| HiveEventLoopMgr::HiveEventLoopMgr | ( | const std::string & | nam, |
| ISvcLocator * | svcLoc | ||
| ) |
Standard Constructor.
Definition at line 79 of file HiveEventLoopMgr.cpp.
|
virtual |
Standard Destructor.
Definition at line 113 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IEventProcessor::executeEvent(void* par)
Definition at line 370 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IEventProcessor::executeRun()
Definition at line 428 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IService::finalize
Definition at line 299 of file HiveEventLoopMgr.cpp.
|
protected |
Get the input and output collections.
Compute dependencies between the algorithms.
Definition at line 744 of file HiveEventLoopMgr.cpp.
| StatusCode HiveEventLoopMgr::getEventRoot | ( | IOpaqueAddress *& | refpAddr | ) |
Create event address using event selector.
Definition at line 717 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IService::initialize
Definition at line 125 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IService::nextEvent
Definition at line 442 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IService::reinitialize
Definition at line 217 of file HiveEventLoopMgr.cpp.
|
virtual |
implementation of IService::stop
Definition at line 287 of file HiveEventLoopMgr.cpp.
| void HiveEventLoopMgr::taskFinished | ( | IAlgorithm *& | algo | ) |
Decrement the number of algos in flight and put algo back in manager - maybe private.
Definition at line 787 of file HiveEventLoopMgr.cpp.
|
protected |
Definition at line 93 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Algorithm resource pool.
Definition at line 53 of file HiveEventLoopMgr.h.
|
protected |
All requirements.
Definition at line 74 of file HiveEventLoopMgr.h.
Property interface of ApplicationMgr.
Definition at line 57 of file HiveEventLoopMgr.h.
|
protected |
Clone algorithms to run them simultaneously.
Definition at line 88 of file HiveEventLoopMgr.h.
|
protected |
Dump the algorithm queues.
Definition at line 82 of file HiveEventLoopMgr.h.
|
protected |
Flag to avoid to fire the EnvEvent incident twice in a row (and also not before the first event)
Definition at line 60 of file HiveEventLoopMgr.h.
|
protected |
Event Iterator.
Definition at line 43 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Event Data Service's IDataManagerSvc interface.
Definition at line 37 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Event Data Service's IDataProviderSvc interface.
Definition at line 39 of file HiveEventLoopMgr.h.
|
protected |
Number of events in parallel.
Definition at line 84 of file HiveEventLoopMgr.h.
|
protected |
Event selector.
Definition at line 45 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Event Selector.
Definition at line 41 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Histogram Data Service.
Definition at line 47 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Histogram Persistency Service.
Definition at line 49 of file HiveEventLoopMgr.h.
|
protected |
Name of the Hist Pers type.
Definition at line 55 of file HiveEventLoopMgr.h.
|
protected |
Maximum number of parallel running algorithms.
Definition at line 66 of file HiveEventLoopMgr.h.
|
protected |
Definition at line 95 of file HiveEventLoopMgr.h.
|
protected |
Total numbers of threads.
Definition at line 86 of file HiveEventLoopMgr.h.
|
protected |
Total number of algos.
Definition at line 80 of file HiveEventLoopMgr.h.
Register of input products.
Definition at line 76 of file HiveEventLoopMgr.h.
|
protected |
Pointer to tbb task scheduler.
Definition at line 68 of file HiveEventLoopMgr.h.
|
protected |
The termination requirement.
Definition at line 72 of file HiveEventLoopMgr.h.
|
protected |
Total number of algos in flight across all events.
Definition at line 78 of file HiveEventLoopMgr.h.
|
protected |
Flag to disable warning messages when using external input.
Definition at line 62 of file HiveEventLoopMgr.h.
|
protected |
Reference to the Histogram Persistency Service.
Definition at line 51 of file HiveEventLoopMgr.h.