![]() |
The Gaudi Framework
master (181af51f)
|
Specialized output stream class for event tag collections, where the basic Event entry point should be placed as well into the collection itself. More...
#include <PersistencySvc/TagCollectionStream.h>
Public Member Functions | |
TagCollectionStream (const std::string &name, ISvcLocator *pSvcLocator) | |
Standard algorithm Constructor. | |
StatusCode | initialize () override |
Initialize TagCollectionStream. | |
StatusCode | finalize () override |
Terminate TagCollectionStream. | |
![]() | |
StatusCode | start () override |
Start OutputStream. | |
StatusCode | initialize () override |
Initialize OutputStream. | |
StatusCode | finalize () override |
Terminate OutputStream. | |
StatusCode | execute () override |
Working entry point. | |
virtual StatusCode | connectConversionSvc () |
virtual bool | collect (IRegistry *dir, int level) |
Store agent's classback. | |
virtual StatusCode | collectObjects () |
Collect all objects to be written to the output stream. | |
void | clearSelection () |
Clear list of selected objects. | |
![]() | |
LegacyAlgorithmAdapter (std::string name, ISvcLocator *svcloc, std::string version=PACKAGE_VERSION) | |
![]() | |
LegacyAlgorithmAdapter (std::string name, ISvcLocator *svcloc, std::string version=PACKAGE_VERSION) | |
const EventContext & | getContext () const |
bool | isExecuted () const |
Has this algorithm been executed since the last reset? | |
void | setExecuted (bool state) const |
Set the executed flag to the specified state. | |
bool | filterPassed () const |
Did this algorithm pass or fail its filter criterion for the last event? | |
void | setFilterPassed (bool state) const |
Set the filter passed flag to the specified state. | |
![]() | |
Algorithm (std::string name, ISvcLocator *svcloc, std::string version=PACKAGE_VERSION) | |
Constructor. | |
StatusCode | sysStart () override |
Reinitialization method invoked by the framework. | |
StatusCode | sysInitialize () override |
Initialization method invoked by the framework. | |
StatusCode | sysReinitialize () override |
Reinitialization method invoked by the framework. | |
StatusCode | sysRestart () override |
Restart method invoked by the framework. | |
StatusCode | sysExecute (const EventContext &ctx) override |
The actions to be performed by the algorithm on an event. | |
StatusCode | sysStop () override |
System stop. | |
StatusCode | sysFinalize () override |
System finalization. | |
const std::string & | name () const override |
The identifying name of the algorithm object. | |
const Gaudi::StringKey & | nameKey () const override |
const std::string & | type () const override |
The type of the algorithm object. | |
void | setType (std::string type) override |
const std::string & | version () const override |
unsigned int | index () const override |
StatusCode | configure () override |
Dummy implementation of IStateful::configure() method. | |
StatusCode | terminate () override |
Dummy implementation of IStateful::terminate() method. | |
StatusCode | initialize () override |
the default (empty) implementation of IStateful::initialize() method | |
StatusCode | start () override |
the default (empty) implementation of IStateful::start() method | |
StatusCode | stop () override |
the default (empty) implementation of IStateful::stop() method | |
StatusCode | finalize () override |
the default (empty) implementation of IStateful::finalize() method | |
StatusCode | reinitialize () override |
the default (empty) implementation of IStateful::reinitialize() method | |
StatusCode | restart () override |
the default (empty) implementation of IStateful::restart() method | |
Gaudi::StateMachine::State | FSMState () const override |
returns the current state of the algorithm | |
Gaudi::StateMachine::State | targetFSMState () const override |
returns the state the algorithm will be in after the ongoing transition | |
bool | isEnabled () const override |
Is this algorithm enabled or disabled? | |
bool | isSequence () const override |
Are we a Sequence? | |
unsigned int | errorCount () const |
Get the number of failures of the algorithm. | |
SmartIF< IService > | service (std::string_view name, const bool createIf=true, const bool quiet=false) const |
Return a pointer to the service identified by name (or "type/name") | |
template<class T> | |
SmartIF< T > | service (std::string_view name, bool createIf=true, bool quiet=false) const |
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< IDataProviderSvc > & | detSvc () const |
The standard detector data service. | |
SmartIF< IConversionSvc > & | detCnvSvc () const |
The standard detector data persistency conversion service. | |
SmartIF< IDataProviderSvc > & | eventSvc () const |
The standard event data service. | |
SmartIF< IDataProviderSvc > & | evtSvc () const |
shortcut for method eventSvc | |
SmartIF< IConversionSvc > & | eventCnvSvc () const |
The standard event data persistency conversion service. | |
SmartIF< IHistogramSvc > & | histoSvc () const |
The standard histogram service. | |
SmartIF< INTupleSvc > & | ntupleSvc () const |
The standard N tuple service. | |
SmartIF< IRndmGenSvc > & | randSvc () const |
The standard RandomGen service, Return a pointer to the 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< ITimelineSvc > & | timelineSvc () const |
SmartIF< ISvcLocator > & | serviceLocator () const override |
The standard service locator. | |
SmartIF< ISvcLocator > & | svcLoc () const |
shortcut for method serviceLocator | |
SmartIF< IHiveWhiteBoard > & | whiteboard () const |
SmartIF< IAlgExecStateSvc > & | algExecStateSvc () const |
bool | registerContext () const |
register for Algorithm Context Service? | |
template<class T> | |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandle< T > &hndl, const std::string &doc="none") |
template<class T> | |
Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, ToolHandleArray< T > &hndlArr, const std::string &doc="none") |
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) | |
void | acceptDHVisitor (IDataHandleVisitor *) const override |
void | registerTool (IAlgTool *tool) const |
void | deregisterTool (IAlgTool *tool) const |
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) |
template<class T> | |
void | addToolsArray (ToolHandleArray< T > &hndlArr) |
const std::vector< IAlgTool * > & | tools () const |
bool | isAsynchronous () const |
void | setAsynchronous (bool value) |
unsigned int | cardinality () const override |
Return the cardinality. | |
const std::vector< std::string > & | neededResources () const override |
AlgExecStateRef | execState (const EventContext &ctx) const override |
get the AlgExecStateRef of current algorithm Actually a small wrapper around it, thus the plain object return type | |
std::ostream & | toControlFlowExpression (std::ostream &os) const override |
Produce string represention of the control flow expression. | |
![]() | |
std::vector< Gaudi::DataHandle * > | inputHandles () const override |
std::vector< Gaudi::DataHandle * > | outputHandles () const override |
virtual const DataObjIDColl & | extraInputDeps () const override |
virtual const DataObjIDColl & | extraOutputDeps () const override |
void | declare (Gaudi::DataHandle &handle) override |
void | renounce (Gaudi::DataHandle &handle) override |
bool | renounceInput (const DataObjID &id) override |
const DataObjIDColl & | inputDataObjs () const override |
const DataObjIDColl & | outputDataObjs () const override |
void | addDependency (const DataObjID &id, const Gaudi::DataHandle::Mode &mode) override |
![]() | |
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. | |
![]() | |
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 |
![]() | |
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 | |
![]() | |
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 | |
StatusCode | writeObjects () override |
OutputStream override: Select the different objects and write them to file. | |
virtual StatusCode | connectAddress () |
Connect address column, if not already connected. | |
StatusCode | writeData () |
Write data objects. | |
StatusCode | writeTuple () |
Write tuple data. | |
StatusCode | writeRecord () |
Write full event record. | |
![]() | |
Gaudi::Algorithm * | decodeAlgorithm (const std::string &theName) |
Decode a single algorithm name. | |
void | decodeAlgorithms (Gaudi::Property< std::vector< std::string > > &theNames, std::vector< Gaudi::Algorithm * > &theAlgs) |
Decode specified list of Algorithms. | |
bool | isEventAccepted () const |
Test whether this event should be output. | |
DataStoreItem * | findItem (const std::string &path) |
Find single item identified by its path (exact match) | |
virtual bool | hasInput () const |
Tell if the instance has been configured with input items or not. | |
![]() | |
bool | isReEntrant () const override |
![]() | |
std::vector< IAlgTool * > & | tools () |
bool | isInitialized () const override |
Has the Algorithm already been initialized? | |
bool | isFinalized () const override |
Has the Algorithm already been finalized? | |
void | setIndex (const unsigned int &idx) override |
set instantiation index of Alg | |
bool | isReEntrant () const override |
![]() | |
void | initDataHandleHolder () |
initializes all handles - called by the sysInitialize method of any descendant of this | |
![]() | |
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. | |
Protected Attributes | |
Gaudi::Property< std::string > | m_addrLeaf |
Gaudi::Property< std::string > | m_addrColName |
Gaudi::Property< std::string > | m_collSvcName { this, "TagCollectionSvc", "NTupleSvc", "name of the collection service" } |
Gaudi::Property< bool > | m_objectsFirst |
Gaudi::Property< std::string > | m_tagName { this, "Collection", "", "name of the tag collection in the transient store" } |
INTupleItem * | m_addrColumn = nullptr |
NTuple column to hold the opaque address of the address leaf. | |
std::string | m_topLeafName |
Name of the top leaf (performance cache) | |
bool | m_isTopLeaf = false |
Short cut flag to indicate if the address leaf is the top leaf (performace cache) | |
SmartIF< INTupleSvc > | m_collectionSvc |
Keep reference to the tuple service. | |
std::unique_ptr< GenericAddress > | m_addr |
Address buffer. | |
NTuple::Item< IOpaqueAddress * > | m_item |
Address item buffer. | |
![]() | |
Gaudi::Property< ItemNames > | m_itemNames { this, "ItemList", {}, "vector of item names to be saved to this stream" } |
Gaudi::Property< ItemNames > | m_optItemNames |
Gaudi::Property< AlgDependentItemNames > | m_algDependentItemList |
Gaudi::Property< bool > | m_doPreLoad |
Gaudi::Property< bool > | m_doPreLoadOpt |
Gaudi::Property< std::string > | m_output { this, "Output", {}, "name of the output file specification" } |
Gaudi::Property< std::string > | m_outputName { this, "OutputFile", {}, "name of the output file" } |
Gaudi::Property< std::string > | m_storeName |
Gaudi::Property< std::string > | m_persName |
Gaudi::Property< std::vector< std::string > > | m_acceptNames |
Gaudi::Property< std::vector< std::string > > | m_requireNames |
Gaudi::Property< std::vector< std::string > > | m_vetoNames |
Gaudi::Property< bool > | m_verifyItems |
bool | m_fireIncidents = true |
should I fire incidents for writing opening/closing etc? | |
SmartIF< IIncidentSvc > | m_incidentSvc |
Reference to the incident service. | |
std::string | m_outputType = "UPDATE" |
Output type: NEW(NEW,CREATE,WRITE,RECREATE), UPDATE) | |
SmartIF< IDataProviderSvc > | m_pDataProvider |
Keep reference to the data provider service. | |
SmartIF< IDataManagerSvc > | m_pDataManager |
Keep reference to the data manager service. | |
SmartIF< IConversionSvc > | m_pConversionSvc |
Keep reference to the data conversion service. | |
DataStoreItem * | m_currentItem |
Keep track of the current item. | |
Items | m_itemList |
Vector of items to be saved to this stream. | |
Items | m_optItemList |
Vector of optional items to be saved to this stream. | |
AlgDependentItems | m_algDependentItems |
Items to be saved for specific algorithms. | |
IDataSelector | m_objects |
Collection of objects being selected. | |
int | m_events |
Number of events written to this output stream. | |
std::vector< Gaudi::Algorithm * > | m_acceptAlgs |
Vector of Algorithms that this stream accepts. | |
std::vector< Gaudi::Algorithm * > | m_requireAlgs |
Vector of Algorithms that this stream requires. | |
std::vector< Gaudi::Algorithm * > | m_vetoAlgs |
Vector of Algorithms that this stream is vetoed by. | |
![]() | |
std::unique_ptr< IDataHandleVisitor > | m_updateDataHandles |
Hook for for derived classes to provide a custom visitor for data handles. | |
![]() | |
DataObjIDColl | m_inputDataObjs |
DataObjIDColl | m_outputDataObjs |
Additional Inherited Members | |
![]() | |
typedef std::vector< DataStoreItem * > | Items |
typedef std::vector< std::string > | ItemNames |
typedef std::map< Gaudi::Algorithm *, Items > | AlgDependentItems |
typedef std::map< std::string, ItemNames > | AlgDependentItemNames |
![]() | |
typedef Gaudi::PluginService::Factory< IAlgorithm *(const std::string &, ISvcLocator *)> | Factory |
![]() | |
using | base_class |
Typedef to this class. | |
using | extend_interfaces_base |
Typedef to the base of this class. | |
![]() | |
using | PropertyHolderImpl |
Typedef used to refer to this class from derived classes, as in. | |
![]() | |
using | base_class |
![]() | |
using | ext_iids |
take union of the ext_iids of all Interfaces... | |
![]() | |
friend | AlgorithmManager |
Specialized output stream class for event tag collections, where the basic Event entry point should be placed as well into the collection itself.
The TagCollectionStream is a rather specialized object combining features of NTuple I/O and object I/O. The main working points are:
1) Write a "normal" tag collection. The address column [property AddressColumn, default:"Address"] is added to the Ntuple identified by its name [mandatory property Collection]. The address column is set to the opaque address of the specified leaf [property "AddressLeaf", default:"/Event"]. The NTuple must be registered to the TES of the service [property: TagCollectionSvc, default:"NTupleSvc"]. This is the normal mode event tag collections work.
2) Write a tag collection with "REDIRECTED INPUT". Example: The collection is created from an intermediate file (MINI DST), but the Address column of the NTuple should point to the file e.g. containing the raw data.
Note: The actual address of "/Event" get changed. No other output should be created after writing such a tag collection.
3) Write an "EMBEDDED COLLECTION". In this mode the OutputStream and the NTuple stream are combined. depending on the property TagCollectionStream.ObjectsFirst the objects are written first and the the tags. The tag file and the file containing the objects may be identical.
Note:
Author: M.Frank Version: 1.0
Definition at line 70 of file TagCollectionStream.h.
TagCollectionStream::TagCollectionStream | ( | const std::string & | name, |
ISvcLocator * | pSvcLocator ) |
Standard algorithm Constructor.
Definition at line 27 of file TagCollectionStream.cpp.
|
protectedvirtual |
Connect address column, if not already connected.
Definition at line 31 of file TagCollectionStream.cpp.
|
override |
Terminate TagCollectionStream.
Definition at line 100 of file TagCollectionStream.cpp.
|
override |
Initialize TagCollectionStream.
Definition at line 49 of file TagCollectionStream.cpp.
|
protected |
Write data objects.
Definition at line 118 of file TagCollectionStream.cpp.
|
overrideprotectedvirtual |
OutputStream override: Select the different objects and write them to file.
Reimplemented from OutputStream.
Definition at line 134 of file TagCollectionStream.cpp.
|
protected |
Write full event record.
Definition at line 128 of file TagCollectionStream.cpp.
|
protected |
Write tuple data.
Definition at line 108 of file TagCollectionStream.cpp.
|
protected |
Address buffer.
Definition at line 90 of file TagCollectionStream.h.
|
protected |
Definition at line 74 of file TagCollectionStream.h.
|
protected |
NTuple column to hold the opaque address of the address leaf.
Definition at line 82 of file TagCollectionStream.h.
|
protected |
Definition at line 72 of file TagCollectionStream.h.
|
protected |
Keep reference to the tuple service.
Definition at line 88 of file TagCollectionStream.h.
|
protected |
Definition at line 76 of file TagCollectionStream.h.
|
protected |
Short cut flag to indicate if the address leaf is the top leaf (performace cache)
Definition at line 86 of file TagCollectionStream.h.
|
protected |
Address item buffer.
Definition at line 92 of file TagCollectionStream.h.
|
protected |
Definition at line 77 of file TagCollectionStream.h.
|
protected |
Definition at line 79 of file TagCollectionStream.h.
|
protected |
Name of the top leaf (performance cache)
Definition at line 84 of file TagCollectionStream.h.