Gaudi Framework, version v25r2

Home   Generated: Wed Jun 4 2014
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | List of all members
Sequencer Class Reference

ClassName: Sequencer. More...

#include <Sequencer.h>

Inheritance diagram for Sequencer:
Inheritance graph
[legend]
Collaboration diagram for Sequencer:
Collaboration graph
[legend]

Public Member Functions

 Sequencer (const std::string &name, ISvcLocator *svcloc)
 Constructor(s)
 
virtual ~Sequencer ()
 Destructor.
 
virtual StatusCode initialize ()
 Initialization of a sequencer.
 
virtual StatusCode reinitialize ()
 Sequencer Reinitialization.
 
virtual StatusCode start ()
 Sequencer finalization.
 
virtual StatusCode execute ()
 The actions to be performed by the sequencer on an event.
 
virtual StatusCode stop ()
 Sequencer finalization.
 
virtual StatusCode finalize ()
 Sequencer finalization.
 
virtual StatusCode beginRun ()
 Sequencer beginRun.
 
virtual StatusCode endRun ()
 Sequencer endRun.
 
void resetExecuted ()
 Reset the Sequencer executed state for the current event.
 
virtual bool branchFilterPassed () const
 Was the branch filter passed for the last event?
 
virtual StatusCode setBranchFilterPassed (bool state)
 Set the branch filter passed flag for the last event.
 
virtual bool isStopOverride () const
 Has the StopOverride mode been set?
 
StatusCode append (Algorithm *pAlgorithm)
 Append an algorithm to the sequencer.
 
StatusCode appendToBranch (Algorithm *pAlgorithm)
 Append an algorithm to the sequencer branch.
 
StatusCode createAndAppend (const std::string &type, const std::string &name, Algorithm *&pAlgorithm)
 Create a algorithm and append it to the sequencer.
 
StatusCode createAndAppendToBranch (const std::string &type, const std::string &name, Algorithm *&pAlgorithm)
 Create a algorithm and append it to the sequencer branch.
 
StatusCode remove (Algorithm *pAlgorithm)
 Remove the specified algorithm from the sequencer.
 
StatusCode remove (const std::string &name)
 
StatusCode removeFromBranch (Algorithm *pAlgorithm)
 
StatusCode removeFromBranch (const std::string &name)
 
std::vector< Algorithm * > * branchAlgorithms () const
 List of branch algorithms.
 
StatusCode decodeMemberNames ()
 Decode Member Name list.
 
void membershipHandler (Property &theProp)
 "Members" property handler
 
StatusCode decodeBranchMemberNames ()
 Decode branch member name list.
 
void branchMembershipHandler (Property &theProp)
 "BranchMembers" property handler
 
- Public Member Functions inherited from Algorithm
 Algorithm (const std::string &name, ISvcLocator *svcloc, const std::string &version=PACKAGE_VERSION)
 Constructor.
 
virtual ~Algorithm ()
 Destructor.
 
virtual StatusCode sysStart ()
 Reinitialization method invoked by the framework.
 
virtual StatusCode sysInitialize ()
 Initialization method invoked by the framework.
 
virtual StatusCode sysReinitialize ()
 Reinitialization method invoked by the framework.
 
virtual StatusCode sysRestart ()
 Restart method invoked by the framework.
 
virtual StatusCode sysExecute ()
 The actions to be performed by the algorithm on an event.
 
virtual StatusCode sysStop ()
 System stop.
 
virtual StatusCode sysFinalize ()
 System finalization.
 
virtual StatusCode sysBeginRun ()
 beginRun method invoked by the framework.
 
virtual StatusCode sysEndRun ()
 endRun method invoked by the framework.
 
virtual const std::string & name () const
 The identifying name of the algorithm object.
 
virtual const std::string & version () const
 
virtual StatusCode configure ()
 Dummy implementation of IStateful::configure() method.
 
virtual StatusCode terminate ()
 Dummy implementation of IStateful::terminate() method.
 
virtual StatusCode restart ()
 the default (empty) implementation of IStateful::restart() method
 
virtual bool isExecuted () const
 Has this algorithm been executed since the last reset?
 
virtual void setExecuted (bool state)
 Set the executed flag to the specified state.
 
virtual Gaudi::StateMachine::State FSMState () const
 returns the current state of the algorithm
 
virtual Gaudi::StateMachine::State targetFSMState () const
 returns the state the algorithm will be in after the ongoing transition
 
virtual bool isEnabled () const
 Is this algorithm enabled or disabled?
 
virtual bool filterPassed () const
 Did this algorithm pass or fail its filter criterion for the last event?
 
virtual void setFilterPassed (bool state)
 Set the filter passed flag to the specified state.
 
template<class T >
StatusCode service (const std::string &name, T *&psvc, bool createIf=true) const
 Access a service by name, creating it if it doesn't already exist.
 
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.
 
SmartIF< IServiceservice (const std::string &name, const bool createIf=true, const bool quiet=false) const
 Return a pointer to the service identified by name (or "type/name")
 
void setOutputLevel (int level)
 Set the output level for current algorithm.
 
SmartIF< IAuditorSvc > & auditorSvc () const
 The standard auditor service.May not be invoked before sysInitialize() has been invoked.
 
SmartIF< IChronoStatSvc > & chronoSvc () const
 The standard Chrono & Stat service, Return a pointer to the service if present.
 
SmartIF< IChronoStatSvc > & chronoStatService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IDataProviderSvc > & detSvc () const
 The standard detector data service.
 
SmartIF< IDataProviderSvc > & detDataService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IConversionSvc > & detCnvSvc () const
 The standard detector data persistency conversion service.
 
SmartIF< IConversionSvc > & detDataCnvService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IDataProviderSvc > & eventSvc () const
 The standard event data service.
 
SmartIF< IDataProviderSvc > & evtSvc () const
 shortcut for method eventSvc
 
SmartIF< IDataProviderSvc > & eventDataService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IConversionSvc > & eventCnvSvc () const
 The standard event data persistency conversion service.
 
SmartIF< IConversionSvc > & eventDataCnvService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IHistogramSvc > & histoSvc () const
 The standard histogram service.
 
SmartIF< IHistogramSvc > & histogramDataService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IMessageSvc > & msgSvc () const
 The standard message service.
 
SmartIF< IMessageSvc > & messageService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< INTupleSvc > & ntupleSvc () const
 The standard N tuple service.
 
SmartIF< INTupleSvc > & ntupleService () const
 Obsoleted name, kept due to the backwards compatibility.
 
SmartIF< IRndmGenSvc > & randSvc () const
 AIDA-based NTuple service Returns a pointer to the AIDATuple service if present.
 
SmartIF< IToolSvc > & toolSvc () const
 The standard ToolSvc service, Return a pointer to the service if present.
 
SmartIF< IExceptionSvc > & exceptionSvc () const
 Get the exception Service.
 
SmartIF< IAlgContextSvc > & contextSvc () const
 get Algorithm Context Service
 
SmartIF< ISvcLocator > & serviceLocator () const
 The standard service locator.
 
SmartIF< ISvcLocator > & svcLoc () const
 shortcut for method serviceLocator
 
bool registerContext () const
 register for Algorithm Context Service?
 
StatusCode createSubAlgorithm (const std::string &type, const std::string &name, Algorithm *&pSubAlg)
 Create a sub algorithm.
 
std::vector< Algorithm * > * subAlgorithms () const
 List of sub-algorithms. Returns a pointer to a vector of (sub) Algorithms.
 
virtual StatusCode setProperty (const Property &p)
 Implementation of IProperty::setProperty.
 
virtual StatusCode setProperty (const std::string &s)
 Implementation of IProperty::setProperty.
 
virtual StatusCode setProperty (const std::string &n, const std::string &v)
 Implementation of IProperty::setProperty.
 
virtual StatusCode getProperty (Property *p) const
 Implementation of IProperty::getProperty.
 
virtual const PropertygetProperty (const std::string &name) const
 Implementation of IProperty::getProperty.
 
virtual StatusCode getProperty (const std::string &n, std::string &v) const
 Implementation of IProperty::getProperty.
 
virtual const std::vector
< Property * > & 
getProperties () const
 Implementation of IProperty::getProperties.
 
StatusCode setProperties ()
 Set the algorithm's properties.
 
template<class T >
PropertydeclareProperty (const std::string &name, T &property, const std::string &doc="none") const
 Declare the named property.
 
PropertydeclareRemoteProperty (const std::string &name, IProperty *rsvc, const std::string &rname="") const
 Declare remote named properties.
 
SmartIF< IMonitorSvc > & monitorSvc () const
 Access the monitor service.
 
template<class T >
void declareInfo (const std::string &name, const T &var, const std::string &desc) const
 Declare monitoring information.
 
void declareInfo (const std::string &name, const std::string &format, const void *var, int size, const std::string &desc) const
 Declare monitoring information (special case)
 
template<class TYPE >
StatusCode setProperty (const std::string &name, const TYPE &value)
 set the property form the value
 

Protected Member Functions

StatusCode append (Algorithm *pAlgorithm, std::vector< Algorithm * > *theAlgs)
 Append an algorithm to the sequencer.
 
StatusCode createAndAppend (const std::string &type, const std::string &name, Algorithm *&pAlgorithm, std::vector< Algorithm * > *theAlgs)
 Create a algorithm and append it to the sequencer.
 
StatusCode decodeNames (StringArrayProperty &theNames, std::vector< Algorithm * > *theAlgs, std::vector< bool > &theLogic)
 Decode algorithm names, creating or appending algorithms as appropriate.
 
StatusCode execute (std::vector< Algorithm * > *theAlgs, std::vector< bool > &theLogic, Algorithm *&lastAlgorithm, unsigned int first=0)
 Execute the members in the specified list.
 
StatusCode executeMember (Algorithm *theAlgorithm)
 Execute member algorithm.
 
StatusCode remove (const std::string &algname, std::vector< Algorithm * > *theAlgs)
 Remove the specified algorithm from the sequencer.
 
- Protected Member Functions inherited from Algorithm
bool isInitialized () const
 Has the Algorithm already been initialized?
 
bool isFinalized () const
 Has the Algorithm already been finalized?
 
int outputLevel () const
 retrieve the Algorithm output level
 
IntegerPropertyoutputLevelProperty ()
 Accessor for the Message level property.
 
void initOutputLevel (Property &prop)
 callback for output level property
 

Private Member Functions

 Sequencer (const Sequencer &a)
 Private Copy constructor: NO COPY ALLOWED.
 
Sequenceroperator= (const Sequencer &rhs)
 Private assignment operator: NO ASSIGNMENT ALLOWED.
 

Private Attributes

StringArrayProperty m_names
 
std::vector< bool > m_isInverted
 
StringArrayProperty m_branchNames
 
std::vector< Algorithm * > * m_branchAlgs
 
std::vector< bool > m_isBranchInverted
 
BooleanProperty m_stopOverride
 
bool m_branchFilterPassed
 

Additional Inherited Members

- Public Types inherited from Algorithm
typedef
Gaudi::PluginService::Factory2
< IAlgorithm *, const
std::string &, ISvcLocator * > 
Factory
 

Detailed Description

ClassName: Sequencer.

Description: A Sequencer is essentially a list of Algorithms and is responsible for their management. Note that Sequences may themselves contain other Sequences. The default execute( ) implementation loops over the members of the sequence, calling their execute( ) methods. However, this can be modified if a member is disabled, has already been executed, or a member indicates that it's filter fails. The the former two cases the execution of the member is bypassed. In the latter case, the loop is terminated and the Sequencer assumes the same filtered state as the last member.

Definition at line 24 of file Sequencer.h.

Constructor & Destructor Documentation

Sequencer::Sequencer ( const std::string &  name,
ISvcLocator svcloc 
)

Constructor(s)

Definition at line 21 of file Sequencer.cpp.

: Algorithm( name, pSvcLocator ),
{
// Create vector of branch algorithms
m_branchAlgs = new std::vector<Algorithm*>();
// Declare Sequencer properties with their defaults
declareProperty( "Members", m_names );
declareProperty( "BranchMembers", m_branchNames );
declareProperty( "StopOverride", m_stopOverride=false );
// Associate action handlers with the "Members" and "BranchMembers" properties
}
Sequencer::~Sequencer ( )
virtual

Destructor.

Definition at line 43 of file Sequencer.cpp.

{
delete m_branchAlgs;
}
Sequencer::Sequencer ( const Sequencer a)
private

Private Copy constructor: NO COPY ALLOWED.

Member Function Documentation

StatusCode Sequencer::append ( Algorithm pAlgorithm)

Append an algorithm to the sequencer.

Definition at line 417 of file Sequencer.cpp.

{
StatusCode result = append( pAlgorithm, subAlgorithms( ) );
return result;
}
StatusCode Sequencer::append ( Algorithm pAlgorithm,
std::vector< Algorithm * > *  theAlgs 
)
protected

Append an algorithm to the sequencer.

Protected Member Functions.

Definition at line 526 of file Sequencer.cpp.

{
// Check that the specified algorithm doesn't already exist in the membership list
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( theAlgorithm == pAlgorithm ) {
break;
}
}
if ( result.isSuccess( ) ) {
theAlgs->push_back( pAlgorithm );
pAlgorithm->addRef();
}
return result;
}
StatusCode Sequencer::appendToBranch ( Algorithm pAlgorithm)

Append an algorithm to the sequencer branch.

Definition at line 424 of file Sequencer.cpp.

{
StatusCode result = append( pAlgorithm, branchAlgorithms( ) );
return result;
}
StatusCode Sequencer::beginRun ( )
virtual

Sequencer beginRun.

Reimplemented from Algorithm.

Definition at line 268 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
// Bypass the loop if this sequencer is disabled
if ( isEnabled( ) ) {
// Loop over all members calling their sysInitialize functions
// if they are not disabled. Note that the Algoriithm::sysInitialize
// function protects this from affecting Algorithms that have already
// been initialized.
std::vector<Algorithm*>* theAlgs = subAlgorithms( );
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysInitialize( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to initialize Algorithm " << theAlgorithm->name() << endmsg;
break;
}
result = theAlgorithm->sysStart( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to start Algorithm " << theAlgorithm->name() << endmsg;
break;
}
}
// Loop over all members calling their beginRun functions
// if they are not disabled.
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->beginRun( ).ignore();
}
}
// Loop over all branch members calling their sysInitialize functions
// if they are not disabled. Note that the Algoriithm::sysInitialize
// function protects this from affecting Algorithms that have already
// been initialized.
theAlgs = branchAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysInitialize( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to initialize Algorithm " << theAlgorithm->name() << endmsg;
break;
}
result = theAlgorithm->sysStart( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to start Algorithm " << theAlgorithm->name() << endmsg;
break;
}
}
// Loop over all branch members calling their beginRun functions
// if they are not disabled.
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->beginRun( ).ignore();
}
}
}
}
std::vector< Algorithm * > * Sequencer::branchAlgorithms ( ) const

List of branch algorithms.

These are the algorithms that would get executed if a filter algorithm indicated a failure. The branch is located within the main sequence by the first element, which is the filter algorithm.

Definition at line 479 of file Sequencer.cpp.

{
return m_branchAlgs;
}
bool Sequencer::branchFilterPassed ( ) const
virtual

Was the branch filter passed for the last event?

Definition at line 398 of file Sequencer.cpp.

void Sequencer::branchMembershipHandler ( Property theProp)

"BranchMembers" property handler

Definition at line 516 of file Sequencer.cpp.

StatusCode Sequencer::createAndAppend ( const std::string &  type,
const std::string &  name,
Algorithm *&  pAlgorithm 
)

Create a algorithm and append it to the sequencer.

A call to this method creates a child algorithm object. Note that the returned pointer is to Algorithm (as opposed to IAlgorithm), and thus the methods of IProperty are also available for the direct setting of the algorithm's properties. Using this mechanism instead of creating algorithms directly via the new operator is preferred since then the framework may take care of all of the necessary book-keeping.

Definition at line 431 of file Sequencer.cpp.

{
StatusCode result = createAndAppend( type, name, pAlgorithm, subAlgorithms( ) );
return result;
}
StatusCode Sequencer::createAndAppend ( const std::string &  type,
const std::string &  name,
Algorithm *&  pAlgorithm,
std::vector< Algorithm * > *  theAlgs 
)
protected

Create a algorithm and append it to the sequencer.

A call to this method creates a child algorithm object. Note that the returned pointer is to Algorithm (as opposed to IAlgorithm), and thus the methods of IProperty are also available for the direct setting of the algorithm's properties. Using this mechanism instead of creating algorithms directly via the new operator is preferred since then the framework may take care of all of the necessary book-keeping.

Definition at line 548 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
SmartIF<IAlgManager> theAlgMgr(serviceLocator()->service("ApplicationMgr"));
if ( theAlgMgr.isValid() ) {
IAlgorithm* tmp;
result = theAlgMgr->createAlgorithm( type, algName, tmp );
if ( result.isSuccess( ) ) {
try{
pAlgorithm = dynamic_cast<Algorithm*>(tmp);
theAlgs->push_back( pAlgorithm );
} catch(...){
log << MSG::ERROR << "Unable to create Algorithm " << algName << endmsg;
}
}
}
return result;
}
StatusCode Sequencer::createAndAppendToBranch ( const std::string &  type,
const std::string &  name,
Algorithm *&  pAlgorithm 
)

Create a algorithm and append it to the sequencer branch.

A call to this method creates a child algorithm object. Note that the returned pointer is to Algorithm (as opposed to IAlgorithm), and thus the methods of IProperty are also available for the direct setting of the algorithm's properties. Using this mechanism instead of creating algorithms directly via the new operator is preferred since then the framework may take care of all of the necessary book-keeping.

Definition at line 440 of file Sequencer.cpp.

{
StatusCode result = createAndAppend( type, name, pAlgorithm, branchAlgorithms( ) );
return result;
}
StatusCode Sequencer::decodeBranchMemberNames ( )

Decode branch member name list.

Definition at line 503 of file Sequencer.cpp.

{
// Decode the branch membership list
return result;
}
StatusCode Sequencer::decodeMemberNames ( )

Decode Member Name list.

Definition at line 484 of file Sequencer.cpp.

{
// Decode the membership list
result = decodeNames( m_names,
return result;
}
StatusCode Sequencer::decodeNames ( StringArrayProperty theNames,
std::vector< Algorithm * > *  theAlgs,
std::vector< bool > &  theLogic 
)
protected

Decode algorithm names, creating or appending algorithms as appropriate.

Definition at line 573 of file Sequencer.cpp.

{
StatusCode result;
MsgStream log( msgSvc( ), name( ) );
SmartIF<IAlgManager> theAlgMgr(serviceLocator()->service("ApplicationMgr"));
if ( theAlgMgr.isValid() ) {
// Clear the existing list of algorithms
theAlgs->clear( );
// Build the list of member algorithms from the contents of the
// theNames list.
const std::vector<std::string>& theNameVector = theNames.value( );
std::vector<std::string>::const_iterator it;
std::vector<std::string>::const_iterator itend = theNameVector.end( );
for (it = theNameVector.begin(); it != itend; it++) {
// Parse the name for a syntax of the form:
//
// <type>/<name>
//
// Where <name> is the algorithm instance name, and <type> is the
// algorithm class type (being a subclass of Algorithm).
const Gaudi::Utils::TypeNameString typeName(*it);
std::string theName = typeName.name();
std::string theType = typeName.type();
// Parse the name for a syntax of the form:
//
// <name>:invert
//
// Where <name> is the algorithm instance name and ":invert"
// indicates that the filter passed logic is inverted.
bool isInverted = false;
std::string::size_type invert = theName.find_first_of( ":" );
// Skip all occurrences of "::" (allow namespaces)
while ( std::string::npos != invert
&& invert < (theName.size() - 1) && theName[invert+1] == ':' )
invert = theName.find_first_of( ":", invert+2 );
if ( std::string::npos != invert ) {
if ( theName == theType ) {
// This means that we got something like "Type:invert",
// so we have to strip the ":invert" from the type too.
theType = theType.substr( 0, invert );
}
theName = theName.substr( 0, invert );
isInverted = true;
}
// Check whether the supplied name corresponds to an existing
// Algorithm object.
SmartIF<IAlgorithm>& theIAlg = theAlgMgr->algorithm(theName, false);
Algorithm* theAlgorithm = 0;
if ( theIAlg.isValid() ) {
try{
theAlgorithm = dynamic_cast<Algorithm*>(theIAlg.get());
} catch(...){
log << MSG::WARNING << theName << " is not an Algorithm - Failed dynamic cast" << endmsg;
theAlgorithm = 0; // release
}
}
if ( theAlgorithm ) {
// The specified Algorithm already exists - just append it to the membership list.
status = append( theAlgorithm, theAlgs );
if ( status.isSuccess( ) ) {
ON_DEBUG log << MSG::DEBUG << theName << " already exists - appended to member list" << endmsg;
} else {
log << MSG::WARNING << theName << " already exists - append failed!!!" << endmsg;
}
} else {
// The specified name doesn't exist - create a new object of the specified type
// and append it to the membership list.
status = createAndAppend( theType, theName, theAlgorithm, theAlgs );
if ( status.isSuccess( ) ) {
ON_DEBUG log << MSG::DEBUG << theName << " doesn't exist - created and appended to member list" << endmsg;
} else {
log << MSG::WARNING << theName << " doesn't exist - creation failed!!!" << endmsg;
}
}
if ( status.isSuccess( ) ) {
theLogic.push_back( isInverted );
}
}
}
// Print membership list
if ( result.isSuccess() && theAlgs->size() != 0 ) {
log << MSG::INFO << "Member list: ";
std::vector<Algorithm*>::iterator ai = theAlgs->begin();
std::vector<bool>::iterator li = theLogic.begin();
for ( ; ai != theAlgs->end(); ++ai, ++li ) {
if ( ai != theAlgs->begin() ) log << ", ";
if ( (*ai)->name() == System::typeinfoName(typeid(**ai)) )
log << (*ai)->name();
else
log << System::typeinfoName(typeid(**ai)) << "/" << (*ai)->name();
if (*li) log << ":invert";
}
log << endmsg;
}
return result;
}
StatusCode Sequencer::endRun ( )
virtual

Sequencer endRun.

Reimplemented from Algorithm.

Definition at line 339 of file Sequencer.cpp.

{
// Bypass the loop if this sequencer is disabled
if ( isEnabled( ) ) {
// Loop over all members calling their endRun functions
// if they are not disabled.
std::vector<Algorithm*>* theAlgms = subAlgorithms( );
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgms->end( );
for (it = theAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->endRun( ).ignore();
}
}
// Loop over all branch members calling their endRun functions
// if they are not disabled.
theAlgms = branchAlgorithms( );
itend = theAlgms->end( );
for (it = theAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->endRun( ).ignore();
}
}
}
}
StatusCode Sequencer::execute ( )
virtual

The actions to be performed by the sequencer on an event.

This method is invoked once per event.

Definition at line 129 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
ON_DEBUG log << MSG::DEBUG << name( ) << " Sequencer::execute( )" << endmsg;
// Bypass the loop if this sequencer is disabled or has already been executed
if ( isEnabled( ) && ! isExecuted( ) ) {
Algorithm* lastAlgorithm;
result = execute( subAlgorithms( ), m_isInverted, lastAlgorithm );
if ( result.isSuccess( ) ) {
bool passed = filterPassed( );
if ( ! passed && ! isStopOverride( ) ) {
// Filter failed and stop override not set. Execute the
// branch if there is one associated with the filter
// algorithm that failed. Note that the first member on
// the branch is the failing algorithm and so should
// be skipped.
std::vector<Algorithm*>* theAlgs = branchAlgorithms( );
if ( theAlgs->size( ) > 0 ) {
Algorithm* branchAlgorithm = (*theAlgs)[0];
if ( lastAlgorithm == branchAlgorithm ) {
// Branch specified - Loop over branch members
result = execute( branchAlgorithms( ),
lastAlgorithm, 1 );
if ( result.isSuccess( ) ) {
// The final filter passed state will be set true if either
// of the main or branches passed, otherwise false.
// Save the branch filter passed state.
}
}
}
}
}
// Prevent multiple executions of this sequencer for the current event
setExecuted( true );
}
return result;
}
StatusCode Sequencer::execute ( std::vector< Algorithm * > *  theAlgs,
std::vector< bool > &  theLogic,
Algorithm *&  lastAlgorithm,
unsigned int  first = 0 
)
protected

Execute the members in the specified list.

Definition at line 685 of file Sequencer.cpp.

{
// Loop over all algorithms calling their execute functions if they
// are (a) not disabled, and (b) aren't already executed. Note that
// in the latter case the filter state is still examined. Terminate
// the loop if an algorithm indicates that it's filter didn't pass.
unsigned int size = theAlgs->size( );
for (unsigned int i = first; i < size; i++) {
lastAlgorithm = (*theAlgs)[i];
result = executeMember( lastAlgorithm );
if ( result.isSuccess( ) ) {
// Take the filter passed status of this algorithm as my own status.
// Note that we take into account inverted logic.
bool passed = lastAlgorithm->filterPassed( );
bool isInverted = theLogic[i];
if ( isInverted ) {
passed = ! passed;
}
setFilterPassed( passed );
// The behaviour when the filter fails depends on the StopOverride property.
// The default action is to stop processing, but this default can be
// overridden by setting the "StopOverride" property to true.
if ( ! isStopOverride( ) ) {
if ( ! passed ) break;
}
} else {
break;
}
}
return result;
}
StatusCode Sequencer::executeMember ( Algorithm theAlgorithm)
protected

Execute member algorithm.

Definition at line 725 of file Sequencer.cpp.

{
if ( theAlgorithm->isEnabled( ) ) {
if ( ! theAlgorithm->isExecuted( ) ) {
result = theAlgorithm->sysExecute( );
// Set the executed state of the algorithm.
// I think this should be done by the algorithm itself, but just in case...
theAlgorithm->setExecuted( true );
}
}
return result;
}
StatusCode Sequencer::finalize ( )
virtual

Sequencer finalization.

Reimplemented from Algorithm.

Definition at line 178 of file Sequencer.cpp.

{
// Loop over all branch members calling their finalize functions
// if they are not disabled. Note that the Algorithm::sysFinalize
// function already does this for the main members.
std::vector<Algorithm*>* theAlgs = branchAlgorithms( );
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if (theAlgorithm->sysFinalize( ).isFailure()) {
MsgStream log( msgSvc( ), name( ) );
log << MSG::ERROR << "Unable to finalize Algorithm "
<< theAlgorithm->name() << endmsg;
}
}
}
StatusCode Sequencer::initialize ( )
virtual

Initialization of a sequencer.

Typically things like histogram creation, setting up of data structures etc, should be done here. If a sequence has properties specified in the job options file, they will be set to the requested values BEFORE the initialize() method is invoked.

Reimplemented from Algorithm.

Definition at line 49 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
std::vector<Algorithm*>* theAlgs;
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend;
result = decodeMemberNames();
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to configure one or more sequencer members " << endmsg;
return result;
}
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to configure one or more branch members " << endmsg;
return result;
}
// Loop over all sub-algorithms
theAlgs = subAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysInitialize( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to initialize Algorithm " << theAlgorithm->name() << endmsg;
return result;
}
}
// Loop over all branches
theAlgs = branchAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysInitialize( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to initialize Algorithm " << theAlgorithm->name() << endmsg;
return result;
}
}
return result;
}
bool Sequencer::isStopOverride ( ) const
virtual

Has the StopOverride mode been set?

Definition at line 411 of file Sequencer.cpp.

{
return m_stopOverride.value( );
}
void Sequencer::membershipHandler ( Property theProp)

"Members" property handler

Definition at line 497 of file Sequencer.cpp.

Sequencer& Sequencer::operator= ( const Sequencer rhs)
private

Private assignment operator: NO ASSIGNMENT ALLOWED.

StatusCode Sequencer::reinitialize ( )
virtual

Sequencer Reinitialization.

Reimplemented from Algorithm.

Definition at line 97 of file Sequencer.cpp.

{
// Bypass the loop if this sequencer is disabled
if ( isEnabled( ) ) {
// Loop over all members calling their reinitialize functions
// if they are not disabled.
std::vector<Algorithm*>* theAlgms = subAlgorithms( );
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgms->end( );
for (it = theAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->reinitialize( ).ignore();
}
}
// Loop over all branch members calling their reinitialize functions
// if they are not disabled.
theAlgms = branchAlgorithms( );
itend = theAlgms->end( );
for (it = theAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( ! theAlgorithm->isEnabled( ) ) {
theAlgorithm->reinitialize( ).ignore();
}
}
}
}
StatusCode Sequencer::remove ( Algorithm pAlgorithm)

Remove the specified algorithm from the sequencer.

Definition at line 449 of file Sequencer.cpp.

{
std::string theName = pAlgorithm->name( );
StatusCode result = remove( theName );
return result;
}
StatusCode Sequencer::remove ( const std::string &  name)

Definition at line 457 of file Sequencer.cpp.

{
StatusCode result = remove( algname, subAlgorithms( ) );
return result;
}
StatusCode Sequencer::remove ( const std::string &  algname,
std::vector< Algorithm * > *  theAlgs 
)
protected

Remove the specified algorithm from the sequencer.

Definition at line 741 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
// Test that the algorithm exists in the member list
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if ( theAlgorithm->name( ) == algname ) {
// Algorithm with specified name exists in the algorithm list - remove it
// THIS ISN'T IMPLEMENTED YET!!!!
log << MSG::INFO <<"Sequencer::remove( ) isn't implemented yet!!!!!" << endmsg;
break;
}
}
return result;
}
StatusCode Sequencer::removeFromBranch ( Algorithm pAlgorithm)

Definition at line 464 of file Sequencer.cpp.

{
std::string theName = pAlgorithm->name( );
StatusCode result = removeFromBranch( theName );
return result;
}
StatusCode Sequencer::removeFromBranch ( const std::string &  name)

Definition at line 472 of file Sequencer.cpp.

{
StatusCode result = remove( algname, branchAlgorithms( ) );
return result;
}
void Sequencer::resetExecuted ( )
virtual

Reset the Sequencer executed state for the current event.

Reimplemented from Algorithm.

Definition at line 370 of file Sequencer.cpp.

{
// Loop over all members calling their resetExecuted functions
// if they are not disabled.
std::vector<Algorithm*>* subAlgms = subAlgorithms( );
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend = subAlgms->end( );
for (it = subAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
theAlgorithm->resetExecuted( );
}
// Loop over all branch members calling their resetExecuted functions
// if they are not disabled.
subAlgms = branchAlgorithms( );
itend = subAlgms->end( );
for (it = subAlgms->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
theAlgorithm->resetExecuted( );
}
// Reset the branch filter passed flag
}
StatusCode Sequencer::setBranchFilterPassed ( bool  state)
virtual

Set the branch filter passed flag for the last event.

Definition at line 404 of file Sequencer.cpp.

StatusCode Sequencer::start ( )
virtual

Sequencer finalization.

Reimplemented from Algorithm.

Definition at line 198 of file Sequencer.cpp.

{
MsgStream log( msgSvc( ), name( ) );
std::vector<Algorithm*>* theAlgs;
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend;
// Loop over all sub-algorithms
theAlgs = subAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysStart( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to start Algorithm " << theAlgorithm->name() << endmsg;
return result;
}
}
// Loop over all branches
theAlgs = branchAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
result = theAlgorithm->sysStart( );
if( result.isFailure() ) {
log << MSG::ERROR << "Unable to start Algorithm " << theAlgorithm->name() << endmsg;
return result;
}
}
return result;
}
StatusCode Sequencer::stop ( )
virtual

Sequencer finalization.

Reimplemented from Algorithm.

Definition at line 235 of file Sequencer.cpp.

{
// Loop over all branch members calling their finalize functions
// if they are not disabled.
std::vector<Algorithm*>* theAlgs;
std::vector<Algorithm*>::iterator it;
std::vector<Algorithm*>::iterator itend;
theAlgs = subAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if (theAlgorithm->sysStop( ).isFailure()) {
MsgStream log( msgSvc( ), name( ) );
log << MSG::ERROR << "Unable to stop Algorithm "
<< theAlgorithm->name() << endmsg;
}
}
theAlgs = branchAlgorithms( );
itend = theAlgs->end( );
for (it = theAlgs->begin(); it != itend; it++) {
Algorithm* theAlgorithm = (*it);
if (theAlgorithm->sysStop( ).isFailure()) {
MsgStream log( msgSvc( ), name( ) );
log << MSG::ERROR << "Unable to stop Algorithm "
<< theAlgorithm->name() << endmsg;
}
}
}

Member Data Documentation

std::vector<Algorithm*>* Sequencer::m_branchAlgs
private

Definition at line 247 of file Sequencer.h.

bool Sequencer::m_branchFilterPassed
private

Definition at line 250 of file Sequencer.h.

StringArrayProperty Sequencer::m_branchNames
private

Definition at line 246 of file Sequencer.h.

std::vector<bool> Sequencer::m_isBranchInverted
private

Definition at line 248 of file Sequencer.h.

std::vector<bool> Sequencer::m_isInverted
private

Definition at line 245 of file Sequencer.h.

StringArrayProperty Sequencer::m_names
private

Definition at line 244 of file Sequencer.h.

BooleanProperty Sequencer::m_stopOverride
private

Definition at line 249 of file Sequencer.h.


The documentation for this class was generated from the following files:

Generated at Wed Jun 4 2014 14:49:03 for Gaudi Framework, version v25r2 by Doxygen version 1.8.2 written by Dimitri van Heesch, © 1997-2004