ATLAS Offline Software
Loading...
Searching...
No Matches
EventSelectorAthenaPool.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
5#ifndef EVENTSELECTORATHENAPOOL_H
6#define EVENTSELECTORATHENAPOOL_H
7
12
13#include "GaudiKernel/IEvtSelector.h"
14#include "GaudiKernel/IIoComponent.h"
15#include "GaudiKernel/IIncidentListener.h"
16#include "GaudiKernel/ServiceHandle.h"
17#include "GaudiKernel/ToolHandle.h"
19
28
29#include <map>
30#include <atomic>
31#include <cstdint>
32#include <memory>
33
34// Forward declarations
35class IIncidentSvc;
36class IOpaqueAddress;
37class ISvcLocator;
40class StoreGateSvc;
41namespace pool {
43}
44
49 public extends<::AthService, IEvtSelector, IEvtSelectorSeek, IEventShare, IIoComponent, IIncidentListener, ISecondaryEventSelector>
50{
51
52public: // Constructor and Destructor
54 EventSelectorAthenaPool(const std::string& name, ISvcLocator* pSvcLocator);
57
59 virtual StatusCode initialize() override;
60 virtual StatusCode start() override;
61 virtual StatusCode stop() override;
62 virtual StatusCode finalize() override;
63
64 //-------------------------------------------------
65 // IEventSelector
67 virtual StatusCode createContext(IEvtSelector::Context*& ctxt) const override;
68
70 virtual StatusCode next(IEvtSelector::Context& ctxt) const override;
73 virtual StatusCode next(IEvtSelector::Context& ctxt, int jump) const override;
74
76 virtual StatusCode previous(IEvtSelector::Context& ctxt) const override;
79 virtual StatusCode previous(IEvtSelector::Context& ctxt, int jump) const override;
80
82 virtual StatusCode last(IEvtSelector::Context& ctxt) const override;
83
85 virtual StatusCode rewind(IEvtSelector::Context& ctxt) const override;
86
89 virtual StatusCode createAddress(const IEvtSelector::Context& ctxt, IOpaqueAddress*& iop) const override;
90
92 virtual StatusCode releaseContext(IEvtSelector::Context*& ctxt) const override;
93
97 virtual StatusCode resetCriteria(const std::string& criteria, IEvtSelector::Context& ctxt) const override;
98
99 //-------------------------------------------------
100 // IEventSelectorSeek
104 virtual StatusCode seek(Context& ctxt, int evtnum) const override;
105
108 virtual int curEvent (const Context& ctxt) const override;
109
112 virtual int size (Context& ctxt) const override;
113
114 //-------------------------------------------------
115 // IEventShare
117 virtual StatusCode makeServer(int num) override;
118
120 virtual StatusCode makeClient(int num) override;
121
124 virtual StatusCode share(int evtnum) override;
125
128 virtual StatusCode readEvent(int maxevt) override;
129
130 //-------------------------------------------------
131 // IIoComponent
133 virtual StatusCode io_reinit() override;
135 virtual StatusCode io_finalize() override;
136
137 //-------------------------------------------------
138 // IIncidentListener
140 virtual void handle(const Incident& incident) override;
141
142protected:
143 //-------------------------------------------------
144 // ISecondaryEventSelector
146 virtual StatusCode nextHandleFileTransition(IEvtSelector::Context& ctxt) const override;
148 virtual StatusCode nextWithSkip(IEvtSelector::Context& ctxt) const override;
150 virtual StatusCode recordAttributeList() const override;
152 virtual StatusCode fillAttributeList(coral::AttributeList *attrList, const std::string &suffix, bool copySource) const override;
153 // Disconnect DB if all events from the source FID were processed and the Selector moved to another file
154 virtual bool disconnectIfFinished(const SG::SourceID &fid) const override;
155
156private: // internal member functions
158 StoreGateSvc* eventStore() const;
160 StatusCode reinit() const;
162 std::unique_ptr<PoolCollectionConverter> getCollectionCnv(bool throwIncidents = false) const;
164 int findEvent(int evtNum) const;
166 void fireEndFileIncidents(bool isLastFile) const;
167
168private: // data
170
171 mutable std::unique_ptr<PoolCollectionConverter> m_poolCollectionConverter ATLAS_THREAD_SAFE {};
172 mutable pool::ICollectionCursor* m_headerIterator ATLAS_THREAD_SAFE {};
173 mutable Guid m_guid ATLAS_THREAD_SAFE {};
174 mutable std::map<SG::SourceID, int> m_activeEventsPerSource ATLAS_THREAD_SAFE;
175
176 ServiceHandle<IAthenaPoolCnvSvc> m_athenaPoolCnvSvc{this, "ConversionService", "AthenaPoolCnvSvc", ""};
177 ServiceHandle<IIncidentSvc> m_incidentSvc{this, "IncidentSvc", "IncidentSvc", ""};
178
179private: // properties
181 Gaudi::Property<bool> m_isSecondary{this, "IsSecondary", false, ""};
183 Gaudi::Property<bool> m_processMetadata{this, "ProcessMetadata", true, ""};
185 Gaudi::Property<std::string> m_collectionType{this, "CollectionType", "ImplicitCollection", ""};
186
188 std::string m_attrListKey{"Input"};
189
191 Gaudi::Property<std::vector<std::string>> m_inputCollectionsProp{this, "InputCollections", {}, ""};
192 mutable std::vector<std::string>::const_iterator m_inputCollectionsIterator ATLAS_THREAD_SAFE;
193 void inputCollectionsHandler(Gaudi::Details::PropertyBase&);
195 mutable bool m_inputCollectionsChanged ATLAS_THREAD_SAFE;
196
199 Gaudi::Property<bool> m_keepInputFilesOpen{this, "KeepInputFilesOpen", false, ""};
200
202 mutable ToolHandleArray<IAthenaSelectorTool> m_helperTools ATLAS_THREAD_SAFE {this, "HelperTools", {}, ""};
203 ToolHandle<IAthenaSelectorTool> m_counterTool{this, "CounterTool", "", ""};
204 ToolHandle<IAthenaIPCTool> m_eventStreamingTool{this, "SharedMemoryTool", "", ""};
206 Gaudi::Property<int> m_makeStreamingToolClient{this, "MakeStreamingToolClient",0};
207
211 Gaudi::CheckedProperty<uint32_t> m_runNo{this, "RunNumber", 0, ""};
212 Gaudi::CheckedProperty<uint32_t> m_oldRunNo{this, "OldRunNumber", 0, ""};
213 Gaudi::Property<bool> m_overrideRunNumber{this, "OverrideRunNumber", false, ""};
214 Gaudi::Property<bool> m_overrideRunNumberFromInput{this, "OverrideRunNumberFromInput", false, ""};
215 // TODO: check if not really used
216 Gaudi::CheckedProperty<uint64_t> m_firstEventNo{this, "FirstEvent", 1, ""};
217 // TODO: check if not really used
218 Gaudi::CheckedProperty<uint64_t> m_eventsPerRun{this, "EventsPerRun", 1000000, ""};
219 Gaudi::CheckedProperty<uint32_t> m_firstLBNo{this, "FirstLB", 0, ""};
220 Gaudi::CheckedProperty<uint32_t> m_eventsPerLB{this, "EventsPerLB", 1000, ""};
221 Gaudi::CheckedProperty<uint32_t> m_initTimeStamp{this, "InitialTimeStamp", 0, ""};
222 Gaudi::Property<uint32_t> m_timeStampInterval{this, "TimeStampInterval", 0, ""};
223
224 mutable std::atomic_long m_curCollection{};
225 mutable std::vector<int> m_numEvt ATLAS_THREAD_SAFE;
226 mutable std::vector<int> m_firstEvt ATLAS_THREAD_SAFE;
227
229 Gaudi::Property<int> m_skipEvents{this, "SkipEvents", 0, ""};
230 Gaudi::Property<std::vector<long>> m_skipEventSequenceProp{this, "SkipEventSequence", {}, ""};
232 Gaudi::Property<std::string> m_skipEventRangesProp{this, "SkipEventRanges", {}, ""};
233 mutable std::vector<std::pair<long,long>> m_skipEventRanges ATLAS_THREAD_SAFE;
234
235 mutable std::atomic_int m_evtCount{}; // internal count of events
236 mutable std::atomic_bool m_firedIncident{};
237
238 typedef std::mutex CallMutex;
240
242
246};
247
248#endif
Maintain a set of objects, one per slot.
This file contains the class definition for the Guid class (migrated from POOL).
This file contains the class definition for the IAthenaPoolCnvSvc interface class.
This file contains the class definition for the IAthenaSelectorTool class.
Extension to IEvtSelector to allow for seeking.
Abstract interface for secondary event selectors.
This class provides the context to access an event from POOL persistent store.
EventSelectorAthenaPool(const std::string &name, ISvcLocator *pSvcLocator)
Standard Service Constructor.
Gaudi::CheckedProperty< uint64_t > m_firstEventNo
virtual StatusCode start() override
std::unique_ptr< PoolCollectionConverter > getCollectionCnv(bool throwIncidents=false) const
Return pointer to new PoolCollectionConverter.
Gaudi::Property< bool > m_isSecondary
IsSecondary, know if this is an instance of secondary event selector.
virtual StatusCode makeClient(int num) override
Make this a client.
Gaudi::Property< bool > m_overrideRunNumberFromInput
virtual StatusCode nextWithSkip(IEvtSelector::Context &ctxt) const override
Go to next event and skip if necessary.
virtual StatusCode initialize() override
Required of all Gaudi Services.
Gaudi::Property< int > m_skipEvents
SkipEvents, numbers of events to skip: default = 0.
Gaudi::Property< bool > m_processMetadata
ProcessMetadata, switch on firing of FileIncidents which will trigger processing of metadata: default...
virtual StatusCode share(int evtnum) override
Request to share a given event number.
virtual int curEvent(const Context &ctxt) const override
Return the current event number.
virtual StatusCode createContext(IEvtSelector::Context *&ctxt) const override
create context
virtual StatusCode io_finalize() override
Callback method to finalize the internal state of the component for I/O purposes (e....
Gaudi::Property< std::vector< long > > m_skipEventSequenceProp
friend class DoubleEventSelectorAthenaPool
make the DoubleEventSelectorAthenaPool a friend so it can access the internal EventSelectorAthenaPool...
Gaudi::CheckedProperty< uint32_t > m_initTimeStamp
void inputCollectionsHandler(Gaudi::Details::PropertyBase &)
virtual StatusCode io_reinit() override
Callback method to reinitialize the internal state of the component for I/O purposes (e....
virtual StatusCode resetCriteria(const std::string &criteria, IEvtSelector::Context &ctxt) const override
Set a selection criteria.
StatusCode reinit() const
Reinitialize the service when a fork() occurred/was-issued.
StoreGateSvc * eventStore() const
Return pointer to active event SG.
void fireEndFileIncidents(bool isLastFile) const
Fires the EndInputFile incident (if there is an open file) at end of selector.
virtual StatusCode releaseContext(IEvtSelector::Context *&ctxt) const override
virtual StatusCode stop() override
ServiceHandle< IIncidentSvc > m_incidentSvc
virtual StatusCode next(IEvtSelector::Context &ctxt) const override
virtual ~EventSelectorAthenaPool()
Destructor.
std::unique_ptr< PoolCollectionConverter > m_poolCollectionConverter ATLAS_THREAD_SAFE
ToolHandle< IAthenaSelectorTool > m_counterTool
virtual StatusCode fillAttributeList(coral::AttributeList *attrList, const std::string &suffix, bool copySource) const override
Fill AttributeList with specific items from the selector and a suffix.
std::string m_attrListKey
AttributeList SG key.
virtual StatusCode seek(Context &ctxt, int evtnum) const override
Seek to a given event number.
SG::SlotSpecificObj< SG::SourceID > m_sourceID
ToolHandle< IAthenaIPCTool > m_eventStreamingTool
virtual StatusCode last(IEvtSelector::Context &ctxt) const override
virtual StatusCode makeServer(int num) override
Make this a server.
Gaudi::CheckedProperty< uint64_t > m_eventsPerRun
Gaudi::CheckedProperty< uint32_t > m_eventsPerLB
virtual StatusCode createAddress(const IEvtSelector::Context &ctxt, IOpaqueAddress *&iop) const override
virtual void handle(const Incident &incident) override
Incident service handle listening for BeginProcessing and EndProcessing.
virtual StatusCode previous(IEvtSelector::Context &ctxt) const override
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc
virtual StatusCode rewind(IEvtSelector::Context &ctxt) const override
Gaudi::Property< bool > m_keepInputFilesOpen
KeepInputFilesOpen, boolean flag to keep files open after PoolCollection reaches end: default = false...
Gaudi::CheckedProperty< uint32_t > m_oldRunNo
Gaudi::Property< std::string > m_collectionType
CollectionType, type of the collection: default = "ImplicitCollection".
virtual StatusCode finalize() override
virtual bool disconnectIfFinished(const SG::SourceID &fid) const override
Gaudi::Property< std::vector< std::string > > m_inputCollectionsProp
InputCollections, vector with names of the input collections.
EventContextAthenaPool * m_endIter
Gaudi::Property< int > m_makeStreamingToolClient
Make this instance a Streaming Client during first iteration automatically.
virtual StatusCode readEvent(int maxevt) override
Read the next maxevt events.
virtual StatusCode nextHandleFileTransition(IEvtSelector::Context &ctxt) const override
Handle file transition at the next iteration.
virtual StatusCode recordAttributeList() const override
Record AttributeList in StoreGate.
Gaudi::CheckedProperty< uint32_t > m_runNo
The following are included for compatibility with McEventSelector and are not really used.
virtual int size(Context &ctxt) const override
Return the size of the collection.
int findEvent(int evtNum) const
Search for event with number evtNum.
Gaudi::Property< bool > m_overrideRunNumber
Gaudi::Property< std::string > m_skipEventRangesProp
Skip Events - comma separated list of event to skip, ranges with '-': <start> - <end>
Gaudi::Property< uint32_t > m_timeStampInterval
Gaudi::CheckedProperty< uint32_t > m_firstLBNo
This class provides a encapsulation of a GUID/UUID/CLSID/IID data structure (128 bit number).
Definition Guid.h:25
This class provides an interface to POOL collections.
Maintain a set of objects, one per slot.
The Athena Transient Store API.
An interface used to navigate the result of a query on a collection.
Framework include files.
Definition libname.h:15