ATLAS Offline Software
Loading...
Searching...
No Matches
MonitorChainAlgorithm.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3*/
4
7
8MonitorChainAlgorithm::MonitorChainAlgorithm(const std::string& name, const MonitoredRange* parent)
9 : MonitorBase(name, parent) {
10}
11
12StatusCode MonitorChainAlgorithm::newEvent(const CostData& data, const float weight) {
13 const std::vector<TrigCompositeUtils::AlgToChainTool::ChainInfo>& seededChains = data.seededChains();
14 for (size_t i = 0; i < seededChains.size(); ++i){
15 // Find algorithms associated with chain name
16 if (!data.chainToAlgMap().count(seededChains[i].name)) continue;
17
18 for (const size_t algIndex : data.chainToAlgMap().at(seededChains[i].name)){
19 const xAOD::TrigComposite* alg = data.costCollection().at(algIndex);
20
21 const uint32_t slot = alg->getDetail<uint32_t>("slot");
22 if (slot != data.onlineSlot()) {
23 continue; // When monitoring the master slot, this Monitor ignores algs running in different slots
24 }
25
26 const uint32_t nameHash = alg->getDetail<TrigConf::HLTHash>("alg");
27 const std::string algName = TrigConf::HLTUtils::hash2string(nameHash, "ALG");
28
29 std::stringstream counterName;
30 counterName << seededChains[i].name << "__" << algName;
31 ATH_CHECK( getCounter(counterName.str())->newEvent(data, algIndex, weight) );
32 }
33 }
34
35 return StatusCode::SUCCESS;
36}
37
38
39std::unique_ptr<CounterBase> MonitorChainAlgorithm::newCounter(const std::string& name) {
40 return std::make_unique<CounterAlgorithm>(name, this);
41}
#define ATH_CHECK
Evaluate an expression and check for errors.
char data[hepevt_bytes_allocation_ATLAS]
Definition HepEvt.cxx:11
Caches and propagates event data to be used by monitoring algorithms.
Definition CostData.h:26
virtual StatusCode newEvent(const CostData &data, size_t index, float weight=1.0)=0
Pure virtual interface called by Monitor to instruct this Counter to perform its analysis.
CounterBase * getCounter(const std::string &name)
Retrieve counter by name.
MonitorBase()=delete
Forbid default constructor.
virtual StatusCode newEvent(const CostData &data, const float weight=1.) override
Concrete dispatch method.
virtual std::unique_ptr< CounterBase > newCounter(const std::string &name) override
Concrete counter instantiation.
MonitorChainAlgorithm()=delete
Forbid default constructor.
Container which represents a time range and holds a collection of Monitors which monitor this range.
static const std::string hash2string(HLTHash, const std::string &category="TE")
hash function translating identifiers into names (via internal dictionary)
TrigComposite_v1 TrigComposite
Declare the latest version of the class.