Loading [MathJax]/jax/input/TeX/config.js
 |
ATLAS Offline Software
|
Go to the documentation of this file.
6 #ifndef PILEUPMT_ONDEMANDMINBIASSVC_H
7 #define PILEUPMT_ONDEMANDMINBIASSVC_H
9 #include <fmt/format.h>
20 #include "Gaudi/Property.h"
21 #include "GaudiKernel/IEvtSelector.h"
22 #include "GaudiKernel/ServiceHandle.h"
42 std::size_t
getNumForBunch(
const EventContext& ctx,
int bunch)
const override;
44 std::int64_t
get_hs_id(
const EventContext& ctx)
const override {
53 Gaudi::Property<std::uint64_t>
m_seed{
this,
"Seed", 0,
54 "Additional seed for PRNGs"};
56 this,
"OnDemandMB",
false,
57 "Should minbias event contents be read on demand"};
59 "Number of skipped HS events"};
61 this,
"AvgMBPerBunch", 0.f,
62 "Average (max) number of minbias events per bunch"};
64 "Whether to use a Poisson distribution "
65 "(if False, use a delta distribution)"};
67 this,
"UseBeamInt",
true,
"Whether to use the beam intensity service"};
69 this,
"UseBeamLumi",
true,
"Whether to use the beam luminosity service"};
71 this,
"EarliestDeltaBC", -32,
72 "Earliest bunch crossing to consider (as delta)"};
74 this,
"LatestDeltaBC", +6,
75 "Latest bunch crossing to consider (as delta)"};
77 this,
"SkipEvtIdxSvc",
"SkipEventIdxSvc",
78 "Skipped event index (run / lb num) provider"};
80 this,
"BkgEventSelector", {},
"Event selector for minbias events"};
82 "Beam intensity service"};
84 this,
"BeamLumiSvc",
"LumiProfileSvc",
"Beam luminosity service"};
86 this,
"ActiveStoreSvc",
"ActiveStoreSvc",
"ActiveStoreSvc"};
90 "StoreGate for discarding events"};
105 unsigned int run,
unsigned int lumi,
109 #endif // PILEUPMT_ONDEMANDMINBIASSVC_H
ServiceHandle< IBeamLuminosity > m_beamLumi
Gaudi::Property< bool > m_useBeamInt
std::vector< std::vector< std::uint64_t > > m_num_mb_by_bunch
OnDemandMinbiasSvc(const std::string &name, ISvcLocator *svc)
Constructor.
ServiceHandle< ISkipEventIdxSvc > m_skipEventIdxSvc
std::size_t calcMBRequired(std::int64_t hs_id, std::size_t slot, unsigned int run, unsigned int lumi, std::uint64_t event)
ServiceHandle< IEvtSelector > m_bkgEventSelector
std::vector< std::vector< std::uint64_t > > m_idx_lists
Gaudi::Property< bool > m_usePoisson
ServiceHandle< IProxyProviderSvc > m_proxyProviderSvc
~OnDemandMinbiasSvc() final
Destructor.
The Athena Transient Store API.
virtual std::int64_t get_hs_id(const EventContext &ctx) const override
StoreGateSvc * getMinbias(const EventContext &ctx, std::uint64_t mb_id) override
POOL::TEvent event(POOL::TEvent::kClassAccess)
std::atomic_int64_t m_last_loaded_hs
Gaudi::Property< bool > m_onDemandMB
::StatusCode StatusCode
StatusCode definition for legacy code.
Gaudi::Property< bool > m_useBeamLumi
static constexpr std::size_t s_NoSlot
StatusCode beginHardScatter(const EventContext &ctx) override
std::vector< std::vector< SGHandle > > m_stores
AthROOTErrorHandlerSvc * svc
IEvtSelector::Context * m_bkg_evt_sel_ctx
StatusCode initialize() final
AthService initialize.
Gaudi::Property< float > m_nPerBunch
Gaudi::Property< int > m_latestDeltaBC
StatusCode endHardScatter(const EventContext &ctx) override
Gaudi::Property< int > m_skippedHSEvents
ServiceHandle< IBeamIntensity > m_beamInt
provides the relative beam intensity as a function of the bunch xing.
std::size_t getNumForBunch(const EventContext &ctx, int bunch) const override
std::mutex m_reading_batch_mtx
Gaudi::Property< int > m_earliestDeltaBC
ServiceHandle< ActiveStoreSvc > m_activeStoreSvc
provides the relative beam luminosity as a function of the bunch xing.
Gaudi::Property< std::uint64_t > m_seed