12 const std::string& name,
13 const IInterface* parent )
20 return StatusCode::SUCCESS;
28 return StatusCode::SUCCESS;
46 std::optional<ThrVecRef> emThresholds;
51 constexpr static unsigned int s_maxEmTOBs{5};
52 std::unordered_map<unsigned int, std::unordered_map<unsigned int, unsigned int>> tobCounts;
55 for (
const auto & emTauFragment : roib.
eMTauResult() ) {
56 for (
const auto & roi : emTauFragment.roIVec() ) {
57 uint32_t roIWord = roi.roIWord();
59 ATH_MSG_DEBUG(
"Skipping RoI as it is not EM threshold " << roIWord );
66 overflow = (++tobCounts[crate][module] > s_maxEmTOBs);
69 recRoIs->push_back( std::make_unique<LVL1::RecEmTauRoI>(roIWord, l1Menu.
cptr()) );
72 trigRoIs->push_back( std::make_unique<TrigRoiDescriptor>(
77 ATH_MSG_DEBUG(
"RoI word: 0x" << MSG::hex << std::setw( 8 ) << roIWord << MSG::dec );
83 std::vector<TrigCompositeUtils::DecisionID> passedThresholdIDs;
85 for (
const auto& th : emThresholds.value().get()) {
86 ATH_MSG_VERBOSE(
"Checking if the threshold " << th->name() <<
" passed" );
90 ATH_MSG_DEBUG(
"Passed Threshold names " << th->name() <<
" and " << thresholdProbeName);
96 decisionMain->
setDetail(
"thresholds", passedThresholdIDs );
102 decisionProbe->
setDetail(
"thresholds", passedThresholdIDs );
114 for (
Decision* decision : *decisionOutput) {
115 decision->setDetail(
"overflow",
static_cast<char>(overflow));
118 for (
auto roi: *trigRoIs ) {
119 ATH_MSG_DEBUG(
"RoI Eta: " << roi->eta() <<
" Phi: " << roi->phi() <<
" RoIWord: " << roi->roiWord() );
132 return StatusCode::SUCCESS;
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
xAOD::TrigComposite Decision
SG::WriteHandle< DecisionContainer > createAndStore(const SG::WriteHandleKey< DecisionContainer > &key, const EventContext &ctx)
Creates and right away records the DecisionContainer with the key.
Header file to be included by clients of the Monitored infrastructure.
ElementLink implementation for ROOT usage.
virtual double eta() const =0
virtual double phi() const =0
Methods to retrieve data members.
This class defines the reconstructed em/tau hadron ROI.
virtual double eta() const
returns eta coord of ROI
bool passedThreshold(unsigned int threshold_number) const
returns TRUE if threshold number threshold_number has been passed by this ROI.
virtual double phi() const
returns phi coord of ROI
Group of local monitoring quantities and retain correlation when filling histograms
Declare a monitored scalar variable.
Class holding the LVL1 RoIB result build by the RoIBuilder.
const std::vector< EMTauResult > & eMTauResult() const
Gets the egamma part of the L1 RDO.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
const_pointer_type cptr()
Dereference the pointer.
pointer_type ptr()
Dereference the pointer.
bool setObjectLink(const std::string &name, const ElementLink< CONTAINER > &link)
Set the link to an object.
bool setDetail(const std::string &name, const TYPE &value)
Set an TYPE detail on the object.
std::set< HLT::Identifier > IDSet
ValuesCollection< T > Collection(std::string name, const T &collection)
Declare a monitored (double-convertible) collection.
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
SG::WriteHandle< CONT > createAndStoreNoAux(const SG::WriteHandleKey< CONT > &key, const EventContext &ctx)
Creates and right away records the Container CONT with the key.
Decision * newDecisionIn(DecisionContainer *dc, const std::string &name)
Helper method to create a Decision object, place it in the container and return a pointer to it.
const std::string & initialRecRoIString()
const std::string & initialRoIString()
const std::string & hltSeedingNodeName()