![]() |
The Gaudi Framework
master (1304469f)
|
The Chrono & Stat Sservice: service implements the IChronoStatSvc interface and provides the basic chronometry and some statistical counts needed by all applications. More...
#include </builds/gaudi/Gaudi/GaudiCommonSvc/src/ChronoStatSvc.h>


Public Types | |
| using | ChronoMap = std::map<IChronoStatSvc::ChronoTag, ChronoEntity> |
| some useful typedefs | |
| using | StatMap = std::map<IChronoStatSvc::StatTag, StatEntity> |
Public Types inherited from extends< Service, IChronoStatSvc, IIncidentListener > | |
| using | base_class |
| Typedef to this class. | |
| using | extend_interfaces_base |
| Typedef to the base of this class. | |
Public Types inherited from Service | |
| using | Factory = Gaudi::PluginService::Factory<IService*( const std::string&, ISvcLocator* )> |
Public Types inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > | |
| using | PropertyHolderImpl |
| Typedef used to refer to this class from derived classes, as in. | |
Public Types inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
| using | base_class |
Public Types inherited from extend_interfaces< Interfaces... > | |
| using | ext_iids |
| take union of the ext_iids of all Interfaces... | |
Public Member Functions | |
| StatusCode | initialize () override |
| Implementation of IService::initialize() | |
| StatusCode | finalize () override |
| Implementation of IService::finalize() | |
| ChronoEntity * | chronoStart (const IChronoStatSvc::ChronoTag &chronoTag) override |
| Implementation of IChronoStatSvc::chronoStart. | |
| const ChronoEntity * | chronoStop (const IChronoStatSvc::ChronoTag &chronoTag) override |
| Implementation of IChronoStatSvc::chronoStop. | |
| IChronoStatSvc::ChronoTime | chronoDelta (const IChronoStatSvc::ChronoTag &chronoTag, IChronoStatSvc::ChronoType theType) override |
| Implementation of IchronoStatSvc::chronoDelta. | |
| void | chronoPrint (const IChronoStatSvc::ChronoTag &chronoTag) override |
| Implementation of IChronoStatSvc::chronoPrint. | |
| ChronoStatus | chronoStatus (const IChronoStatSvc::ChronoTag &chronoTag) override |
| Implementation of IChronoStatSvc::chronoStatus. | |
| void | stat (const IChronoStatSvc::StatTag &statTag, const IChronoStatSvc::StatFlag &statFlag) override |
| Implementation of IChronoStatSvc::stat add statistical information to the entity , tagged by its name. | |
| void | statPrint (const IChronoStatSvc::ChronoTag &statTag) override |
| prints (using message service) info about statistical entity, tagged by its name | |
| const ChronoEntity * | chrono (const IChronoStatSvc::ChronoTag &t) const override |
| extract the chrono entity for the given tag (name) | |
| StatEntity * | stat (const IChronoStatSvc::StatTag &t) override |
| extract the stat entity for the given tag (name) | |
| ChronoStatSvc (const std::string &name, ISvcLocator *svcloc) | |
| Default constructor. | |
| void | merge (const ChronoStatSvc &css) |
| Compound assignment operator. | |
| void | handle (const Incident &incident) override |
| ~ChronoStatSvc () override=default | |
Public Member Functions inherited from extends< Service, IChronoStatSvc, IIncidentListener > | |
| void const * | i_cast (const InterfaceID &tid) const override |
| Implementation of IInterface::i_cast. | |
| StatusCode | queryInterface (const InterfaceID &ti, void **pp) override |
| Implementation of IInterface::queryInterface. | |
| std::vector< std::string > | getInterfaceNames () const override |
| Implementation of IInterface::getInterfaceNames. | |
Public Member Functions inherited from Service | |
| const std::string & | name () const override |
| Retrieve name of the service. | |
| 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. | |
| StatusCode | sysStart () override |
| Initialize Service. | |
| StatusCode | sysStop () override |
| Initialize Service. | |
| StatusCode | sysFinalize () override |
| Finalize Service. | |
| StatusCode | sysReinitialize () override |
| Re-initialize the Service. | |
| StatusCode | sysRestart () override |
| Re-initialize the Service. | |
| Service (std::string name, ISvcLocator *svcloc) | |
| Standard Constructor. | |
| SmartIF< ISvcLocator > & | serviceLocator () const override |
| Retrieve pointer to service locator. | |
| template<typename IFace = IService> | |
| SmartIF< IFace > | service (const std::string &name, bool createIf=true) const |
| template<class T> | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none") |
| template<class T> | |
| StatusCode | declareTool (ToolHandle< T > &handle, bool createIf=true) |
| template<class T> | |
| StatusCode | declareTool (ToolHandle< T > &handle, const std::string &toolTypeAndName, bool createIf=true) |
| Declare used tool. | |
| template<class T> | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none") |
| template<class T> | |
| void | addToolsArray (ToolHandleArray< T > &hndlArr) |
| const std::vector< IAlgTool * > & | tools () const |
| SmartIF< IAuditorSvc > & | auditorSvc () const |
| The standard auditor service.May not be invoked before sysInitialize() has been invoked. | |
Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IService, IProperty, IStateful > > > | |
| StatusCode | setProperty (const Gaudi::Details::PropertyBase &p) |
| Set the property from a property. | |
| StatusCode | setProperty (const std::string &name, const char *v) |
| Special case for string literals. | |
| StatusCode | setProperty (const std::string &name, const std::string &v) |
| Special case for std::string. | |
| StatusCode | setProperty (const std::string &name, const TYPE &value) |
| set the property form the value | |
| PropertyHolder ()=default | |
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Details::PropertyBase &prop) |
| Declare a property. | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, TYPE &value, const std::string &doc="none") |
| Helper to wrap a regular data member and use it as a regular property. | |
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none") |
| Declare a PropertyBase instance setting name and documentation. | |
| Gaudi::Details::PropertyBase * | declareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="") |
| Declare a remote property. | |
| StatusCode | setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p) override |
| set the property from another property with a different name | |
| StatusCode | setProperty (const std::string &s) override |
| set the property from the formatted string | |
| StatusCode | setProperty (const Gaudi::Details::PropertyBase &p) |
| Set the property from a property. | |
| StatusCode | setProperty (const std::string &name, const char *v) |
| Special case for string literals. | |
| StatusCode | setProperty (const std::string &name, const std::string &v) |
| Special case for std::string. | |
| StatusCode | setProperty (const std::string &name, const TYPE &value) |
| set the property form the value | |
| StatusCode | setPropertyRepr (const std::string &n, const std::string &r) override |
| set the property from name and value string representation | |
| StatusCode | getProperty (Gaudi::Details::PropertyBase *p) const override |
| get the property | |
| const Gaudi::Details::PropertyBase & | getProperty (std::string_view name) const override |
| get the property by name | |
| StatusCode | getProperty (std::string_view n, std::string &v) const override |
| convert the property to the string | |
| const std::vector< Gaudi::Details::PropertyBase * > & | getProperties () const override |
| get all properties | |
| bool | hasProperty (std::string_view name) const override |
| Return true if we have a property with the given name. | |
| Gaudi::Details::PropertyBase * | property (std::string_view name) const |
| \fixme property and bindPropertiesTo should be protected | |
| void | bindPropertiesTo (Gaudi::Interfaces::IOptionsSvc &optsSvc) |
| PropertyHolder (const PropertyHolder &)=delete | |
| PropertyHolder & | operator= (const PropertyHolder &)=delete |
Public Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
| MSG::Level | msgLevel () const |
| get the cached level (originally extracted from the embedded MsgStream) | |
| bool | msgLevel (MSG::Level lvl) const |
| get the output level from the embedded MsgStream | |
Public Member Functions inherited from CommonMessagingBase | |
| virtual | ~CommonMessagingBase ()=default |
| Virtual destructor. | |
| const SmartIF< IMessageSvc > & | msgSvc () const |
| The standard message service. | |
| MsgStream & | msgStream () const |
| Return an uninitialized MsgStream. | |
| MsgStream & | msgStream (const MSG::Level level) const |
| Predefined configurable message stream for the efficient printouts. | |
| MsgStream & | always () const |
| shortcut for the method msgStream(MSG::ALWAYS) | |
| MsgStream & | fatal () const |
| shortcut for the method msgStream(MSG::FATAL) | |
| MsgStream & | err () const |
| shortcut for the method msgStream(MSG::ERROR) | |
| MsgStream & | error () const |
| shortcut for the method msgStream(MSG::ERROR) | |
| MsgStream & | warning () const |
| shortcut for the method msgStream(MSG::WARNING) | |
| MsgStream & | info () const |
| shortcut for the method msgStream(MSG::INFO) | |
| MsgStream & | debug () const |
| shortcut for the method msgStream(MSG::DEBUG) | |
| MsgStream & | verbose () const |
| shortcut for the method msgStream(MSG::VERBOSE) | |
| MsgStream & | msg () const |
| shortcut for the method msgStream(MSG::INFO) | |
Protected Member Functions | |
| void | printStats () |
Protected Member Functions inherited from Service | |
| std::vector< IAlgTool * > & | tools () |
| ~Service () override | |
| int | outputLevel () const |
get the Service's output level | |
Protected Member Functions inherited from CommonMessaging< implements< IService, IProperty, IStateful > > | |
| MSG::Level | setUpMessaging () const |
| Set up local caches. | |
| MSG::Level | resetMessaging () |
| Reinitialize internal states. | |
| void | updateMsgStreamOutputLevel (int level) |
| Update the output level of the cached MsgStream. | |
Private Types | |
| using | TimeMap = std::map<ChronoTag, std::vector<IChronoSvc::ChronoTime>> |
Private Member Functions | |
| ChronoStatSvc ()=delete | |
| ChronoStatSvc (const ChronoStatSvc &)=delete | |
| ChronoStatSvc & | operator= (const ChronoStatSvc &)=delete |
| void | saveStats () |
| dump the statistics into an ASCII file for offline processing | |
| bool | isMT () const |
| ChronoEntity & | getEntity (const ChronoTag &chronoTag) |
Static Private Member Functions | |
| static MSG::Level | int2level (int l) |
Private Attributes | |
| ChronoMap | m_chronoEntities |
| chrono part | |
| std::mutex | m_mutex |
| Mutex protecting m_chronoEntities. | |
| MSG::Level | m_chronoPrintLevel = MSG::INFO |
| level of info printing | |
| StatMap | m_statEntities |
| stat part | |
| MSG::Level | m_statPrintLevel = MSG::INFO |
| level of info printing | |
| Gaudi::Property< bool > | m_chronoTableFlag |
| Gaudi::Property< bool > | m_chronoCoutFlag |
| Gaudi::Property< int > | m_intChronoPrintLevel |
| Gaudi::Property< bool > | m_chronoOrderFlag { this, "ChronoTableToBeOrdered", true, "should the printout be ordered" } |
| Gaudi::Property< bool > | m_printUserTime { this, "PrintUserTime", true } |
| Gaudi::Property< bool > | m_printSystemTime { this, "PrintSystemTime", false } |
| Gaudi::Property< bool > | m_printEllapsedTime { this, "PrintEllapsedTime", false } |
| Gaudi::Property< bool > | m_statTableFlag |
| Gaudi::Property< bool > | m_statCoutFlag |
| Gaudi::Property< int > | m_intStatPrintLevel |
| Gaudi::Property< bool > | m_statOrderFlag { this, "StatTableToBeOrdered", true, "should the printout be ordered" } |
| Gaudi::Property< std::string > | m_statsOutFileName |
| Gaudi::Property< std::string > | m_header |
| Gaudi::Property< bool > | m_useEffFormat |
| Gaudi::Property< std::string > | m_perEventFile { this, "PerEventFile", "", "File name for per-event deltas" } |
| ServiceHandle< IInterface > | m_hiveWhiteBoardSvc { this, "HiveWhiteBoardSvc", "EventDataSvc" } |
| TimeMap | m_perEvtTime |
| std::ofstream | m_ofd |
Additional Inherited Members | |
Protected Attributes inherited from Service | |
| Gaudi::StateMachine::State | m_state = Gaudi::StateMachine::OFFLINE |
| Service state. | |
| Gaudi::StateMachine::State | m_targetState = Gaudi::StateMachine::OFFLINE |
| Service state. | |
| Gaudi::Property< int > | m_outputLevel { this, "OutputLevel", MSG::NIL, "output level" } |
| flag indicating whether ToolHandle tools have been added to m_tools | |
| Gaudi::Property< bool > | m_auditorInitialize { this, "AuditInitialize", false, "trigger auditor on initialize()" } |
| Gaudi::Property< bool > | m_auditorStart { this, "AuditStart", false, "trigger auditor on start()" } |
| Gaudi::Property< bool > | m_auditorStop { this, "AuditStop", false, "trigger auditor on stop()" } |
| Gaudi::Property< bool > | m_auditorFinalize { this, "AuditFinalize", false, "trigger auditor on finalize()" } |
| Gaudi::Property< bool > | m_auditorReinitialize { this, "AuditReinitialize", false, "trigger auditor on reinitialize()" } |
| Gaudi::Property< bool > | m_auditorRestart { this, "AuditRestart", false, "trigger auditor on restart()" } |
| Gaudi::Property< bool > | m_autoRetrieveTools |
| Gaudi::Property< bool > | m_checkToolDeps |
| SmartIF< IAuditorSvc > | m_pAuditorSvc |
| Auditor Service. | |
The Chrono & Stat Sservice: service implements the IChronoStatSvc interface and provides the basic chronometry and some statistical counts needed by all applications.
Definition at line 46 of file ChronoStatSvc.h.
| using ChronoStatSvc::ChronoMap = std::map<IChronoStatSvc::ChronoTag, ChronoEntity> |
some useful typedefs
Definition at line 50 of file ChronoStatSvc.h.
| using ChronoStatSvc::StatMap = std::map<IChronoStatSvc::StatTag, StatEntity> |
Definition at line 51 of file ChronoStatSvc.h.
|
private |
Definition at line 209 of file ChronoStatSvc.h.
|
inline |
Default constructor.
| name | service instance name |
| svcloc | pointer to service locator |
Definition at line 118 of file ChronoStatSvc.h.
|
privatedelete |
|
privatedelete |
|
overridedefault |
|
override |
extract the chrono entity for the given tag (name)
| t | chrono tag(name) |
Definition at line 344 of file ChronoStatSvc.cpp.
|
override |
Implementation of IchronoStatSvc::chronoDelta.
Definition at line 293 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoPrint.
Definition at line 300 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStart.
Definition at line 277 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStatus.
Definition at line 308 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::chronoStop.
Definition at line 285 of file ChronoStatSvc.cpp.
|
override |
Implementation of IService::finalize()
stop its own chrono
Is the final chrono table to be printed?
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
decoration
CONTINUE
CONTINUE
stop chrono (if it is still in RUNNING status)
print to std::cout
print to MsgStream
clear the temporary container
the final decoration
Is the final stat table to be printed?
< finalize the base class
Definition at line 123 of file ChronoStatSvc.cpp.
|
inlineprivate |
Definition at line 150 of file ChronoStatSvc.h.
|
override |
Definition at line 509 of file ChronoStatSvc.cpp.
|
override |
Implementation of IService::initialize()
start its own chrono
Definition at line 91 of file ChronoStatSvc.cpp.
|
inlinestaticprivate |
Definition at line 156 of file ChronoStatSvc.h.
|
private |
Definition at line 430 of file ChronoStatSvc.cpp.
| void ChronoStatSvc::merge | ( | const ChronoStatSvc & | css | ) |
Compound assignment operator.
Definition at line 63 of file ChronoStatSvc.cpp.
|
privatedelete |
|
protected |
nothing to print?
CONTINUE
CONTINUE
decoration
Definition at line 444 of file ChronoStatSvc.cpp.
|
private |
dump the statistics into an ASCII file for offline processing
CONTINUE
CONTINUE
Definition at line 363 of file ChronoStatSvc.cpp.
|
override |
Implementation of IChronoStatSvc::stat add statistical information to the entity , tagged by its name.
Definition at line 314 of file ChronoStatSvc.cpp.
|
override |
extract the stat entity for the given tag (name)
| t | stat tag(name) |
Definition at line 356 of file ChronoStatSvc.cpp.
|
override |
prints (using message service) info about statistical entity, tagged by its name
Definition at line 333 of file ChronoStatSvc.cpp.
|
private |
Definition at line 176 of file ChronoStatSvc.h.
|
private |
chrono part
Definition at line 162 of file ChronoStatSvc.h.
|
private |
Definition at line 181 of file ChronoStatSvc.h.
|
private |
level of info printing
Definition at line 167 of file ChronoStatSvc.h.
|
private |
Definition at line 174 of file ChronoStatSvc.h.
|
private |
Definition at line 198 of file ChronoStatSvc.h.
|
private |
Definition at line 207 of file ChronoStatSvc.h.
|
private |
Definition at line 178 of file ChronoStatSvc.h.
|
private |
Definition at line 189 of file ChronoStatSvc.h.
|
mutableprivate |
Mutex protecting m_chronoEntities.
Definition at line 164 of file ChronoStatSvc.h.
|
private |
Definition at line 211 of file ChronoStatSvc.h.
|
private |
Definition at line 205 of file ChronoStatSvc.h.
|
private |
Definition at line 210 of file ChronoStatSvc.h.
|
private |
Definition at line 184 of file ChronoStatSvc.h.
|
private |
Definition at line 183 of file ChronoStatSvc.h.
|
private |
Definition at line 182 of file ChronoStatSvc.h.
|
private |
Definition at line 187 of file ChronoStatSvc.h.
|
private |
stat part
Definition at line 170 of file ChronoStatSvc.h.
|
private |
Definition at line 192 of file ChronoStatSvc.h.
|
private |
level of info printing
Definition at line 172 of file ChronoStatSvc.h.
|
private |
Definition at line 194 of file ChronoStatSvc.h.
|
private |
Definition at line 185 of file ChronoStatSvc.h.
|
private |
Definition at line 202 of file ChronoStatSvc.h.