The Gaudi Framework  master (37c0b60a)
MemStatAuditor Class Reference
Inheritance diagram for MemStatAuditor:
Collaboration diagram for MemStatAuditor:

Public Member Functions

StatusCode initialize () override
 
void i_before (CustomEventTypeRef, std::string_view) override
 catch all "before" method, implemented in the derived class More...
 
void i_after (CustomEventTypeRef evt, std::string_view caller, const StatusCode &) override
 catch all "after" method, implemented in the derived class More...
 
- Public Member Functions inherited from CommonAuditor
 Auditor (std::string name, ISvcLocator *svcloc)
 Constructor. More...
 
 Auditor (const Auditor &a)=delete
 Constructor. More...
 
void before (StandardEventType evt, const std::string &caller) override
 
void before (StandardEventType evt, INamedInterface *caller) override
 
void before (CustomEventTypeRef evt, const std::string &caller) override
 
void before (CustomEventTypeRef evt, INamedInterface *caller) override
 
void after (StandardEventType evt, const std::string &caller, const StatusCode &sc) override
 
void after (StandardEventType evt, INamedInterface *caller, const StatusCode &sc) override
 
void after (CustomEventTypeRef evt, const std::string &caller, const StatusCode &sc) override
 
void after (CustomEventTypeRef evt, INamedInterface *caller, const StatusCode &sc) override
 
- Public Member Functions inherited from Auditor
 Auditor (std::string name, ISvcLocator *svcloc)
 Constructor. More...
 
 Auditor (const Auditor &a)=delete
 
Auditoroperator= (const Auditor &rhs)=delete
 
StatusCode sysInitialize () override
 Initialization method invoked by the framework. More...
 
StatusCode sysFinalize () override
 Finalization method invoked by the framework. More...
 
void before (StandardEventType, INamedInterface *) override
 The following methods are meant to be implemented by the child class... More...
 
void before (StandardEventType, const std::string &) override
 
void before (CustomEventTypeRef, INamedInterface *) override
 
void before (CustomEventTypeRef, const std::string &) override
 
void after (StandardEventType, INamedInterface *, const StatusCode &) override
 
void after (StandardEventType, const std::string &, const StatusCode &) override
 
void after (CustomEventTypeRef, INamedInterface *, const StatusCode &) override
 
void after (CustomEventTypeRef, const std::string &, const StatusCode &) override
 
void beforeInitialize (INamedInterface *) override
 
void afterInitialize (INamedInterface *) override
 
void beforeReinitialize (INamedInterface *) override
 
void afterReinitialize (INamedInterface *) override
 
void beforeExecute (INamedInterface *) override
 
void afterExecute (INamedInterface *, const StatusCode &) override
 
void beforeFinalize (INamedInterface *) override
 
void afterFinalize (INamedInterface *) override
 
virtual StatusCode finalize ()
 
const std::stringname () const override
 
bool isEnabled () const override
 
SmartIF< ISvcLocator > & serviceLocator () const override
 The standard service locator. More...
 
template<class T >
StatusCode service (std::string_view name, T *&svc, bool createIf=false) const
 Access a service by name, creating it if it doesn't already exist. More...
 
template<class T = IService>
SmartIF< T > service (std::string_view name, bool createIf=false) const
 
- Public Member Functions inherited from PropertyHolder< CommonMessaging< implements< IAuditor, IProperty > > >
 PropertyHolder ()=default
 
Gaudi::Details::PropertyBasedeclareProperty (Gaudi::Details::PropertyBase &prop)
 Declare a property. More...
 
Gaudi::Details::PropertyBasedeclareProperty (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. More...
 
Gaudi::Details::PropertyBasedeclareProperty (const std::string &name, Gaudi::Property< TYPE, VERIFIER, HANDLERS > &prop, const std::string &doc="none")
 Declare a PropertyBase instance setting name and documentation. More...
 
Gaudi::Details::PropertyBasedeclareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="")
 Declare a remote property. More...
 
StatusCode setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p) override
 set the property from another property with a different name More...
 
StatusCode setProperty (const std::string &s) override
 set the property from the formatted string More...
 
StatusCode setProperty (const Gaudi::Details::PropertyBase &p)
 Set the property from a property. More...
 
virtual StatusCode setProperty (const std::string &name, const Gaudi::Details::PropertyBase &p)=0
 Set the property from a property with a different name. More...
 
virtual StatusCode setProperty (const std::string &s)=0
 Set the property by string. More...
 
StatusCode setProperty (const std::string &name, const char *v)
 Special case for string literals. More...
 
StatusCode setProperty (const std::string &name, const std::string &v)
 Special case for std::string. More...
 
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value More...
 
StatusCode setPropertyRepr (const std::string &n, const std::string &r) override
 set the property from name and value string representation More...
 
StatusCode getProperty (Gaudi::Details::PropertyBase *p) const override
 get the property More...
 
const Gaudi::Details::PropertyBasegetProperty (std::string_view name) const override
 get the property by name More...
 
StatusCode getProperty (std::string_view n, std::string &v) const override
 convert the property to the string More...
 
const std::vector< Gaudi::Details::PropertyBase * > & getProperties () const override
 get all properties More...
 
bool hasProperty (std::string_view name) const override
 Return true if we have a property with the given name. More...
 
Gaudi::Details::PropertyBaseproperty (std::string_view name) const
 \fixme property and bindPropertiesTo should be protected More...
 
void bindPropertiesTo (Gaudi::Interfaces::IOptionsSvc &optsSvc)
 
 PropertyHolder (const PropertyHolder &)=delete
 
PropertyHolderoperator= (const PropertyHolder &)=delete
 
- Public Member Functions inherited from CommonMessaging< implements< IAuditor, IProperty > >
MSG::Level msgLevel () const
 get the cached level (originally extracted from the embedded MsgStream) More...
 
bool msgLevel (MSG::Level lvl) const
 get the output level from the embedded MsgStream More...
 

Private Member Functions

void i_printinfo (std::string_view msg, CustomEventTypeRef evt, std::string_view caller)
 

Private Attributes

SmartIF< IChronoStatSvcm_stat
 
double m_vSize = -1
 vsize of the previous call to printinfo More...
 

Additional Inherited Members

- Public Types inherited from Auditor
using Factory = Gaudi::PluginService::Factory< IAuditor *(const std::string &, ISvcLocator *)>
 
- Public Types inherited from PropertyHolder< CommonMessaging< implements< IAuditor, IProperty > > >
using PropertyHolderImpl = PropertyHolder< CommonMessaging< implements< IAuditor, IProperty > > >
 Typedef used to refer to this class from derived classes, as in. More...
 
- Public Types inherited from CommonMessaging< implements< IAuditor, IProperty > >
using base_class = CommonMessaging
 
- Protected Member Functions inherited from CommonAuditor
bool i_auditEventType (std::string_view evt)
 Check if we are requested to audit the passed event type. More...
 
- Protected Member Functions inherited from CommonMessaging< implements< IAuditor, IProperty > >
MSG::Level setUpMessaging () const
 Set up local caches. More...
 
MSG::Level resetMessaging ()
 Reinitialize internal states. More...
 
void updateMsgStreamOutputLevel (int level)
 Update the output level of the cached MsgStream. More...
 

Detailed Description

Just a minor modification of MemoryAuditor to allow the output memory statistics table to be printed

Author
Vanya Belyaev
Marco Clemencic
Date
04/02/2001

Definition at line 28 of file MemStatAuditor.cpp.

Member Function Documentation

◆ i_after()

void MemStatAuditor::i_after ( CustomEventTypeRef  evt,
std::string_view  caller,
const StatusCode sc 
)
inlineoverridevirtual

catch all "after" method, implemented in the derived class

Implements CommonAuditor.

Definition at line 38 of file MemStatAuditor.cpp.

38  {
39  i_printinfo( "Memory usage has changed after", evt, caller );
40  }

◆ i_before()

void MemStatAuditor::i_before ( CustomEventTypeRef  evt,
std::string_view  caller 
)
inlineoverridevirtual

catch all "before" method, implemented in the derived class

Implements CommonAuditor.

Definition at line 34 of file MemStatAuditor.cpp.

34  {
35  // It's not interesting to monitor the memory usage before the methods.
36  }

◆ i_printinfo()

void MemStatAuditor::i_printinfo ( std::string_view  msg,
CustomEventTypeRef  evt,
std::string_view  caller 
)
private

Definition at line 63 of file MemStatAuditor.cpp.

63  {
64  // cannot be exactly 0
65  double deltaVSize = 0.00001;
66 
67  if ( procInfo pInfo; ProcStats::instance()->fetch( pInfo ) ) {
68 
69  if ( pInfo.vsize > 0 ) {
70  if ( m_vSize > 0 ) { deltaVSize = pInfo.vsize - m_vSize; }
71  // store the current VSize to be able to monitor the increment
72  m_vSize = pInfo.vsize;
73  }
74 
75  info() << msg << " " << caller << " " << evt << " \tvirtual size = " << pInfo.vsize << " MB"
76  << " \tresident set size = " << pInfo.rss << " MB"
77  << " deltaVsize = " << deltaVSize << " MB" << endmsg;
78  }
79  // fill the stat for every call, not just when there is a change
80  // only monitor the increment in VSize
81  // Stat stv(m_stat, caller + ":VMemUsage", pInfo.vsize);
82  // Stat str(m_stat, caller + ":RMemUsage", pInfo.rss);
83  Stat sts( m_stat, std::string{ caller }.append( ":VMem" ), deltaVSize );
84 }

◆ initialize()

StatusCode MemStatAuditor::initialize ( )
overridevirtual

Reimplemented from Auditor.

Definition at line 52 of file MemStatAuditor.cpp.

52  {
53  return CommonAuditor::initialize().andThen( [&]() -> StatusCode {
54  m_stat = serviceLocator()->service( "ChronoStatSvc" );
55  if ( !m_stat ) {
56  error() << "Cannot get ChronoStatSvc" << endmsg;
57  return StatusCode::FAILURE;
58  }
59  return StatusCode::SUCCESS;
60  } );
61 }

Member Data Documentation

◆ m_stat

SmartIF<IChronoStatSvc> MemStatAuditor::m_stat
private

Definition at line 44 of file MemStatAuditor.cpp.

◆ m_vSize

double MemStatAuditor::m_vSize = -1
private

vsize of the previous call to printinfo

Definition at line 47 of file MemStatAuditor.cpp.


The documentation for this class was generated from the following file:
IOTest.evt
evt
Definition: IOTest.py:107
MemStatAuditor::i_printinfo
void i_printinfo(std::string_view msg, CustomEventTypeRef evt, std::string_view caller)
Definition: MemStatAuditor.cpp:63
std::string
STL class.
StatusCode::andThen
StatusCode andThen(F &&f, ARGS &&... args) const
Chain code blocks making the execution conditional a success result.
Definition: StatusCode.h:163
GaudiMP.FdsRegistry.msg
msg
Definition: FdsRegistry.py:19
procInfo
Definition: ProcStats.h:29
ProcStats::instance
static ProcStats * instance()
Definition: ProcStats.cpp:239
Auditor::initialize
virtual StatusCode initialize()
Definition: Auditor.cpp:79
StatusCode
Definition: StatusCode.h:65
MemStatAuditor::m_stat
SmartIF< IChronoStatSvc > m_stat
Definition: MemStatAuditor.cpp:44
endmsg
MsgStream & endmsg(MsgStream &s)
MsgStream Modifier: endmsg. Calls the output method of the MsgStream.
Definition: MsgStream.h:202
std::string::append
T append(T... args)
Stat
Definition: Stat.h:56
StatusCode::SUCCESS
constexpr static const auto SUCCESS
Definition: StatusCode.h:100
MemStatAuditor::m_vSize
double m_vSize
vsize of the previous call to printinfo
Definition: MemStatAuditor.cpp:47
ProcStats::fetch
bool fetch(procInfo &fill_me)
Definition: ProcStats.cpp:259
StatusCode::FAILURE
constexpr static const auto FAILURE
Definition: StatusCode.h:101
Auditor::serviceLocator
SmartIF< ISvcLocator > & serviceLocator() const override
The standard service locator.
Definition: Auditor.cpp:196