ATLAS Offline Software
EMRoIsUnpackingTool.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 // HLTSeeding includes
5 #include "EMRoIsUnpackingTool.h"
9 
10 
12  const std::string& name,
13  const IInterface* parent )
15 
16 
20  return StatusCode::SUCCESS;
21 }
22 
23 
25  ATH_CHECK(decodeMapping([](const std::string& name){
26  return name.find("EM") == 0 or name.find(getProbeThresholdName("EM")) == 0;
27  }));
28  return StatusCode::SUCCESS;
29 }
30 
31 
32 StatusCode EMRoIsUnpackingTool::unpack(const EventContext& ctx,
33  const ROIB::RoIBResult& roib,
34  const HLT::IDSet& activeChains) const {
35  using namespace TrigCompositeUtils;
36 
37  // create and record the collections needed
42 
43  // Retrieve the L1 menu configuration
45  ATH_CHECK(l1Menu.isValid());
46  std::optional<ThrVecRef> emThresholds;
47  ATH_CHECK(getL1Thresholds(*l1Menu, "EM", emThresholds));
48 
49  // Flag if there was an overflow in the TOB transmission to CMX (there were more TOBs than can be transferred)
50  bool overflow{false};
51  constexpr static unsigned int s_maxEmTOBs{5}; // Hardcoded in L1Calo firmware, see ATR-23697 and ATR-12285
52  std::unordered_map<unsigned int, std::unordered_map<unsigned int, unsigned int>> tobCounts; // {crate, {module, count}}
53 
54  // RoIBResult contains vector of EM fragments
55  for ( const auto & emTauFragment : roib.eMTauResult() ) {
56  for ( const auto & roi : emTauFragment.roIVec() ) {
57  uint32_t roIWord = roi.roIWord();
58  if ( not ( LVL1::TrigT1CaloDefs::EMRoIWordType == roi.roIType() ) ) {
59  ATH_MSG_DEBUG( "Skipping RoI as it is not EM threshold " << roIWord );
60  continue;
61  }
62 
63  if (!overflow) {
64  unsigned int crate = m_cpDecoder.crate(roIWord);
65  unsigned int module = m_cpDecoder.module(roIWord);
66  overflow = (++tobCounts[crate][module] > s_maxEmTOBs);
67  }
68 
69  recRoIs->push_back( std::make_unique<LVL1::RecEmTauRoI>(roIWord, l1Menu.cptr()) );
70  const LVL1::RecEmTauRoI* recRoI = recRoIs->back();
71 
72  trigRoIs->push_back( std::make_unique<TrigRoiDescriptor>(
73  roIWord, 0u ,0u,
74  recRoI->eta(), recRoI->eta()-m_roIWidth, recRoI->eta()+m_roIWidth,
75  recRoI->phi(), recRoI->phi()-m_roIWidth, recRoI->phi()+m_roIWidth) );
76 
77  ATH_MSG_DEBUG( "RoI word: 0x" << MSG::hex << std::setw( 8 ) << roIWord << MSG::dec );
78 
79  // The hltSeedingNodeName denotes an initial node with no parents
80  Decision* decisionMain = TrigCompositeUtils::newDecisionIn( decisionOutput.ptr(), hltSeedingNodeName() );
81  Decision* decisionProbe = TrigCompositeUtils::newDecisionIn( decisionOutputProbe.ptr(), hltSeedingNodeName() );
82 
83  std::vector<TrigCompositeUtils::DecisionID> passedThresholdIDs;
84 
85  for (const auto& th : emThresholds.value().get()) {
86  ATH_MSG_VERBOSE( "Checking if the threshold " << th->name() << " passed" );
87  if ( recRoI->passedThreshold( th->mapping() ) ) {
88  passedThresholdIDs.push_back( HLT::Identifier( th->name() ) );
89  const std::string thresholdProbeName = getProbeThresholdName(th->name());
90  ATH_MSG_DEBUG( "Passed Threshold names " << th->name() << " and " << thresholdProbeName);
91  addChainsToDecision( HLT::Identifier( th->name() ), decisionMain, activeChains );
92  addChainsToDecision( HLT::Identifier( thresholdProbeName ), decisionProbe, activeChains );
93  }
94  }
95 
96  decisionMain->setDetail( "thresholds", passedThresholdIDs );
97  decisionMain->setObjectLink( initialRoIString(),
99  decisionMain->setObjectLink( initialRecRoIString(),
101 
102  decisionProbe->setDetail( "thresholds", passedThresholdIDs );
103  decisionProbe->setObjectLink( initialRoIString(),
105  decisionProbe->setObjectLink( initialRecRoIString(),
107  }
108  }
109 
110  // Decorate the decisions with overflow information
111  if (overflow) {
112  ATH_MSG_WARNING("L1Calo overflow for EM TOBs to CMX detected");
113  }
114  for (Decision* decision : *decisionOutput) {
115  decision->setDetail("overflow", static_cast<char>(overflow));
116  }
117 
118  for ( auto roi: *trigRoIs ) {
119  ATH_MSG_DEBUG( "RoI Eta: " << roi->eta() << " Phi: " << roi->phi() << " RoIWord: " << roi->roiWord() );
120  }
121 
122  // monitoring
123  {
124  auto RoIsCount = Monitored::Scalar( "count", trigRoIs->size() );
125  auto RoIsPhi = Monitored::Collection( "phi", *trigRoIs, &TrigRoiDescriptor::phi );
126  auto RoIsEta = Monitored::Collection( "eta", *trigRoIs, &TrigRoiDescriptor::eta );
127  Monitored::Group( m_monTool, RoIsCount, RoIsEta, RoIsPhi );
128  }
129 
130  ATH_MSG_DEBUG( "Unpacked " << trigRoIs->size() << " RoIs" );
131 
132  return StatusCode::SUCCESS;
133 }
LVL1::CPRoIDecoder::crate
unsigned int crate(const unsigned int roiWord) const
Decode crate number from RoI word.
Definition: CPRoIDecoder.cxx:104
EMRoIsUnpackingTool.h
xAOD::TrigComposite_v1::setDetail
bool setDetail(const std::string &name, const TYPE &value)
Set an TYPE detail on the object.
TrigDefs::Group
Group
Properties of a chain group.
Definition: GroupProperties.h:13
RoIsUnpackingToolBase
Base class for RoI unpackers.
Definition: RoIsUnpackingToolBase.h:32
SG::ReadHandle::cptr
const_pointer_type cptr()
Dereference the pointer.
ROIB::RoIBResult
Class holding the LVL1 RoIB result build by the RoIBuilder.
Definition: RoIBResult.h:47
TrigCompositeUtils::hltSeedingNodeName
const std::string & hltSeedingNodeName()
Definition: TrigCompositeUtilsRoot.cxx:892
xAOD::uint32_t
setEventNumber uint32_t
Definition: EventInfo_v1.cxx:127
RoIBResult.h
TrigCompositeUtils::newDecisionIn
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.
Definition: TrigCompositeUtilsRoot.cxx:46
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:70
ROIB::RoIBResult::eMTauResult
const std::vector< EMTauResult > & eMTauResult() const
Gets the egamma part of the L1 RDO.
Definition: RoIBResult.cxx:68
RoIsUnpackingToolBase::addChainsToDecision
void addChainsToDecision(HLT::Identifier thresholdId, TrigCompositeUtils::Decision *d, const HLT::IDSet &activeChains) const
Definition: RoIsUnpackingToolBase.cxx:88
TrigCompositeUtils::createAndStore
SG::WriteHandle< DecisionContainer > createAndStore(const SG::WriteHandleKey< DecisionContainer > &key, const EventContext &ctx)
Creates and right away records the DecisionContainer with the key.
Definition: TrigCompositeUtilsRoot.cxx:30
TrigCompositeUtils::initialRecRoIString
const std::string & initialRecRoIString()
Definition: TrigCompositeUtilsRoot.cxx:872
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
EMRoIsUnpackingTool::m_recRoIsKey
SG::WriteHandleKey< DataVector< LVL1::RecEmTauRoI > > m_recRoIsKey
Definition: EMRoIsUnpackingTool.h:29
EMRoIsUnpackingTool::m_roIWidth
Gaudi::Property< float > m_roIWidth
Definition: EMRoIsUnpackingTool.h:33
Trk::u
@ u
Enums for curvilinear frames.
Definition: ParamDefs.h:77
Monitored::Collection
ValuesCollection< T > Collection(std::string name, const T &collection)
Declare a monitored (double-convertible) collection.
Definition: MonitoredCollection.h:38
EMRoIsUnpackingTool::EMRoIsUnpackingTool
EMRoIsUnpackingTool(const std::string &type, const std::string &name, const IInterface *parent)
Definition: EMRoIsUnpackingTool.cxx:11
SG::makeHandle
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
Definition: ReadCondHandle.h:270
LVL1::RecEmTauRoI::passedThreshold
bool passedThreshold(unsigned int threshold_number) const
returns TRUE if threshold number threshold_number has been passed by this ROI.
Definition: RecEmTauRoI.cxx:382
python.PyAthena.module
module
Definition: PyAthena.py:131
RoIsUnpackingToolBase::m_decisionsKeyProbe
SG::WriteHandleKey< TrigCompositeUtils::DecisionContainer > m_decisionsKeyProbe
Definition: RoIsUnpackingToolBase.h:54
python.TriggerHandler.th
th
Definition: TriggerHandler.py:296
RoIsUnpackingToolBase::decodeMapping
StatusCode decodeMapping(std::function< bool(const std::string &)> &&filter)
Fills mapping from L1 threshold -> to HLT chain.
Definition: RoIsUnpackingToolBase.cxx:52
xAOD::TrigComposite_v1::setObjectLink
bool setObjectLink(const std::string &name, const ElementLink< CONTAINER > &link)
Set the link to an object.
TrigCompositeUtils::initialRoIString
const std::string & initialRoIString()
Definition: TrigCompositeUtilsRoot.cxx:868
RoIsUnpackingToolBase::getL1Thresholds
StatusCode getL1Thresholds(const TrigConf::L1Menu &l1Menu, const std::string &thrType, std::optional< ThrVecRef > &thrVec) const
Retrieve a vector of thresholds with type thrType from L1Menu.
Definition: RoIsUnpackingToolBase.cxx:33
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
SG::WriteHandle::ptr
pointer_type ptr()
Dereference the pointer.
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
test_pyathena.parent
parent
Definition: test_pyathena.py:15
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
LVL1::RecEmTauRoI
This class defines the reconstructed em/tau hadron ROI.
Definition: RecEmTauRoI.h:44
EMRoIsUnpackingTool::start
virtual StatusCode start() override
Definition: EMRoIsUnpackingTool.cxx:24
EMRoIsUnpackingTool::unpack
StatusCode unpack(const EventContext &ctx, const ROIB::RoIBResult &roib, const HLT::IDSet &activeChains) const override
Definition: EMRoIsUnpackingTool.cxx:32
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
TrigCompositeUtils::createAndStoreNoAux
SG::WriteHandle< CONT > createAndStoreNoAux(const SG::WriteHandleKey< CONT > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
Creates and right away records the Container CONT with the key.
xAOD::TrigComposite_v1
Class used to describe composite objects in the HLT.
Definition: TrigComposite_v1.h:52
RoIsUnpackingToolBase::m_decisionsKey
SG::WriteHandleKey< TrigCompositeUtils::DecisionContainer > m_decisionsKey
Definition: RoIsUnpackingToolBase.h:51
DataVector
Derived DataVector<T>.
Definition: DataVector.h:581
HLT::Identifier
Definition: TrigCompositeUtils/TrigCompositeUtils/HLTIdentifier.h:20
Monitored.h
Header file to be included by clients of the Monitored infrastructure.
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
LVL1::RecEmTauRoI::phi
virtual double phi() const
returns phi coord of ROI
Definition: RecEmTauRoI.cxx:333
RoIsUnpackingToolBase::m_monTool
ToolHandle< GenericMonitoringTool > m_monTool
Definition: RoIsUnpackingToolBase.h:67
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
DataVector::push_back
value_type push_back(value_type pElem)
Add an element to the end of the collection.
TrigT1CaloDefs.h
RoIsUnpackingToolBase::m_trigRoIsKey
SG::WriteHandleKey< TrigRoiDescriptorCollection > m_trigRoIsKey
Definition: RoIsUnpackingToolBase.h:57
RoIsUnpackingToolBase::m_l1MenuKey
SG::ReadHandleKey< TrigConf::L1Menu > m_l1MenuKey
Definition: RoIsUnpackingToolBase.h:60
SG::WriteHandle< TrigRoiDescriptorCollection >
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
RoiDescriptor::phi
virtual double phi() const override final
Methods to retrieve data members.
Definition: RoiDescriptor.h:100
LVL1::CPRoIDecoder::module
unsigned int module(const unsigned int roiWord) const
Decode module number from RoI word.
Definition: CPRoIDecoder.cxx:111
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
HLT::IDSet
std::set< HLT::Identifier > IDSet
Definition: TrigCompositeUtils/TrigCompositeUtils/HLTIdentifier.h:63
RoIsUnpackingToolBase::initialize
virtual StatusCode initialize() override
Definition: RoIsUnpackingToolBase.cxx:16
RoiDescriptor::eta
virtual double eta() const override final
Definition: RoiDescriptor.h:101
LVL1::TrigT1CaloDefs::EMRoIWordType
@ EMRoIWordType
Definition: TrigT1CaloDefs.h:173
TrigCompositeUtils
Definition: Event/xAOD/xAODTrigger/xAODTrigger/TrigComposite.h:19
Monitored::Scalar
Declare a monitored scalar variable.
Definition: MonitoredScalar.h:34
LVL1::RecEmTauRoI::eta
virtual double eta() const
returns eta coord of ROI
Definition: RecEmTauRoI.cxx:343
EMRoIsUnpackingTool::m_cpDecoder
LVL1::CPRoIDecoder m_cpDecoder
Definition: EMRoIsUnpackingTool.h:36
DataVector::size
size_type size() const noexcept
Returns the number of elements in the collection.
RoIsUnpackingToolBase::getProbeThresholdName
static std::string getProbeThresholdName(const std::string &thresholdName)
Concatenate the probe identifier string with the threshold name string.
Definition: RoIsUnpackingToolBase.cxx:47
EMRoIsUnpackingTool::initialize
virtual StatusCode initialize() override
Definition: EMRoIsUnpackingTool.cxx:17