12#include "EventInfo/EventInfo.h"
24#include "GaudiKernel/ISvcLocator.h"
25#include "GaudiKernel/IAlgTool.h"
26#include "GaudiKernel/GaudiException.h"
27#include "GaudiKernel/TypeNameString.h"
28#include "GaudiKernel/MsgStream.h"
47 ToolHandleArray<IPileUpXingFolder>::const_iterator
49 while (iXing != iEnd) {
51 if (
msg().level() <= MSG::DEBUG) {
52 msg() << MSG::DEBUG <<
"decodeIntervals: adding IPileUpXingFolder "
56 item(xing.
begin()), endItem(xing.
end());
57 while(item != endItem) {
58 m_ranges[make_pair(item->id(), item->key())]=
60 if (
msg().level() <= MSG::VERBOSE) {
62 <<
"decodeInterval: accepting objects of CLID " << item->id()
63 <<
" key " << item->key() <<
" in the Xing range ["
65 <<
" with cache refresh frequency "
82 m_autoRetrieveTools =
false;
83 m_checkToolDeps =
false;
89 <<
"Could not locate default store"
91 return StatusCode::FAILURE;
96 <<
"Could not locate ITriggerTime tool"
98 return StatusCode::FAILURE;
106 return StatusCode::SUCCESS;
117 if( xAODEventInfo ) {
118 ATH_MSG_DEBUG(
"Found xAOD::EventInfo="<<xAODEventInfo<<
" SG="<<sg<<
" : "<<*xAODEventInfo);
126 std::lock_guard<std::mutex> lock (*m_slotMutex);
129 const EventInfo* pEvent = einame.empty()?
133 ATH_MSG_DEBUG(
"Converting (PileUp)EventInfo "<<pEvent<<
" SG="<<sg<<
" to xAOD::EventInfo");
135 std::unique_ptr< xAOD::EventInfo > pxAODEventInfo(
new xAOD::EventInfo() );
137 pxAODEventInfo->setStore( pxAODEventAuxInfo.get() );
138 pxAODEventInfo->setEvtStore( sg );
139 if( !
m_xAODCnvTool->convert( pEvent, pxAODEventInfo.get(),
true,
false ).isSuccess() ) {
149 puei->setStore( puaux.get() );
152 std::vector< xAOD::EventInfo::SubEvent > subEvents;
155 static const std::map< PileUpEventInfo::SubEvent::pileup_type,
157#define DECLARE_SE_TYPE( TYPE ) \
158 { PileUpTimeEventIndex::TYPE, xAOD::EventInfo::TYPE },
167#undef DECLARE_SE_TYPE
176 const unsigned int countEvents = std::distance(pu_itr,pu_end);
177 ATH_MSG_VERBOSE(
"CHECKING: There are " << countEvents <<
" subevents in this Event." );
178 for( ; pu_itr != pu_end; ++pu_itr ) {
182 if( !
m_xAODCnvTool->convert( pu_itr->pSubEvt, ei.get(),
true,
false ).isSuccess() ) {
183 ATH_MSG_ERROR(
"Failed to convert EventInfo to xAOD::EventInfo");
189 ei->setEvtStore(tmpSG);
195 puei->push_back( ei.release() );
198 auto typeItr = pileupTypeMap.find( pu_itr->type() );
200 if( typeItr == pileupTypeMap.end() ) {
203 type = typeItr->second;
205 ATH_MSG_VERBOSE(
"PileUpEventInfo: time = " << pu_itr->time() <<
", index = " << pu_itr->index());
209 EiLink(
"PileUpEventInfo", puei->size()-1, sg )));
210 ATH_MSG_VERBOSE(
"PileUpEventInfo: time = " << subEvents.back().time() <<
", index = " << subEvents.back().index());
213 if( subEvents.size() ) {
215 pxAODEventInfo->setSubEvents( subEvents );
218 if( !sg->
record( std::move( puaux ),
"PileUpEventInfoAux." ).isSuccess()
219 || !sg->
record( std::move( puei ),
"PileUpEventInfo" ).isSuccess() ) {
220 ATH_MSG_ERROR(
"Failed to record xAOD::EventInfoContainer in SG");
227 xAODEventInfo = std::launder(pxAODEventInfo.get());
229 const auto ptrVal = pxAODEventInfo.get();
230 if( ! sg->
record( std::move( pxAODEventAuxInfo ),
"EventInfoAux." ).isSuccess()
231 || ! sg->
record( std::move( pxAODEventInfo ),
"EventInfo" ).isSuccess() ) {
232 ATH_MSG_ERROR(
"Failed to record the new xAOD::EventInfo in SG");
233 xAODEventInfo =
nullptr;
235 ATH_MSG_DEBUG(
"Record the new xAOD::EventInfo "<<ptrVal<<
" in SG="<<sg);
239 if( !xAODEventInfo ) {
240 ATH_MSG_DEBUG(
"Could not find EventInfo '" << einame <<
"' in store " << sg->name());
242 return xAODEventInfo;
248 return m_ranges[make_pair(
id, dataKey)].contains(iXing);
256 return (
r.contains(iXing) &&
r.doRefresh(
double(random())*(1./RAND_MAX)));
261 StatusCode
sc(StatusCode::FAILURE);
275 if (proxy &&
doRefresh (item.second,
int(subEv.time()))) {
276 proxy->setObject ((DataObject*)0);
277 if (
msg().level() <= MSG::DEBUG) {
279 <<
"clearDataCachesByFolder: object with clid "
280 << item.first.first <<
" and key " << item.first.second
281 <<
" removed from cache "
282 << pSubEvtSG->name() <<
endmsg;
289 if (
msg().level() <= MSG::VERBOSE) {
290 msg() << MSG::VERBOSE
291 <<
"clearDataCachesByFolder: done with store " << pSubEvtSG->name()
296 sc=StatusCode::SUCCESS;
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define CHECK(...)
Evaluate an expression and check for errors.
This class provides a unique identification for each event, in terms of run/event number and/or a tim...
This class provides general information about an event.
uint32_t CLID
The Class ID type.
an interface to SG::Folder with an attached bunch crossing interval
interface to a tool that returns the time offset of the current trigger.
This class provides information about an overlaid event.
the preferred mechanism to access information from the different event stores in a pileup job.
#define DECLARE_SE_TYPE(TYPE)
ElementLink implementation for ROOT usage.
an interface to SG::Folder with an attached bunch crossing interval
SG::IFolder::const_iterator const_iterator
virtual const_iterator end() const =0
virtual float cacheRefreshFrequency() const =0
controls the rate at which we clear data objs in this folder at the end of event
virtual int firstXing() const =0
virtual int lastXing() const =0
virtual const_iterator begin() const =0
This class provides information about an overlaid event.
SubEvent::iterator endSubEvt()
SubEvent::iterator beginSubEvt()
the active crossing range for a data object (CLID/key combination)
ToolHandle< ITriggerTime > m_pITriggerTime
controls PileUpTimedEventIndex for TimedData returned by retrieveSubEvts
void decodeIntervals()
setup PileUpIntervals
ToolHandleArray< IPileUpXingFolder > m_intervals
bool isLive(const KEY &key, int iXing)
is iXing live for DATA/key?
StatusCode clearDataCaches()
clear bkg event caches from unneeded data objects (as configured using PileUpXingFolder CacheRefreshF...
virtual StatusCode initialize() override
Service initialisation.
StringProperty m_EventInfoKeyName
bool doRefresh(const Range &r, int iXing)
ToolHandle< xAODMaker::IEventInfoCnvTool > m_xAODCnvTool
property: Handle to the EventInfo -> xAOD::EventInfo converter tool
PileUpMergeSvc(const std::string &name, ISvcLocator *svc)
Standard Gaudi Constructor.
ServiceHandle< StoreGateSvc > p_overStore
overlaid SG (default)
const xAOD::EventInfo * getPileUpEvent(StoreGateSvc *sg, const std::string &einame) const
get EventInfo from SG, by default using p_overStore
The Athena Transient Store API.
StatusCode record(T *p2BRegistered, const TKEY &key)
Record an object with a key.
const T * tryConstRetrieve() const
void emptyTrash()
throw away bad objects
virtual sgkey_t stringToKey(const std::string &str, CLID clid) override final
Find the key for a string/CLID pair.
virtual SG::DataProxy * proxy_exact(SG::sgkey_t sgkey) const override final
Get proxy given a hashed key+clid.
Class describing the properties of one pileup sub-event.
const std::vector< SubEvent > & subEvents() const
Get the pileup events that were used in the simulation.
PileUpType
Enumerator describing the types of pileup events.
@ Unknown
Type not known/specified.
uint32_t sgkey_t
Type used for hashed StoreGate key+CLID pairs.
EventInfoContainer_v1 EventInfoContainer
Define the latest version of the container.
EventInfo_v1 EventInfo
Definition of the latest event info version.
EventInfoAuxContainer_v1 EventInfoAuxContainer
Define the latest version of the auxiliary container.
EventAuxInfo_v3 EventAuxInfo
Definition of the latest event auxiliary info version.