40 if(
m_trigInfo[trigger].areAnyL1TauIsolated()) {
41 ATH_MSG_FATAL(
"Cannot use isolated L1 tau items if running with SelectL1ByETOnly = True: " << trigger);
42 return StatusCode::FAILURE;
51 const std::string sfx = info.getHLTTauLegContainerSfx();
59 return StatusCode::SUCCESS;
65 std::vector<const xAOD::TauJet*> tau_vec;
69 std::vector<int> leg_indices = {-1};
70 if(filter_legs) leg_indices = info.getHLTTauLegIndices();
71 for(
size_t i = 0; i < leg_indices.size(); ++i) {
72 const int leg = leg_indices[i];
73 const std::string tau_container_name =
getOnlineContainerKey(info.getHLTTauLegContainerSfxs().at(leg == -1 ? 0 : i)).key();
74 ATH_MSG_DEBUG(
"Tau container name is: " << tau_container_name);
77 for(
auto& featLinkInfo :
vec) {
85 if(include_0P && nTracks == 0) tau_vec.push_back(feat);
86 else tau_vec.push_back(feat);
104 std::vector<const xAOD::TauJet*> tau_vec;
107 if(!
taus.isValid()) {
114 if(tau->pt() <
threshold*Gaudi::Units::GeV)
continue;
117 if(std::abs(tau->eta()) > 1.37 && std::abs(tau->eta()) < 1.52)
continue;
124 if(!passThinningAcc.
withDefault(*tau,
true))
continue;
129 if(nTracks == 1 || nTracks == 3) tau_vec.push_back(tau);
144 std::vector<const xAOD::eFexTauRoI*> roi_vec;
159 if(!thresholdPatterns.isValid()) {
160 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_eTauRoi container");
176 std::vector<const xAOD::jFexTauRoI*> roi_vec;
191 if(!thresholdPatterns.isValid()) {
192 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_jTauRoi container");
208 std::vector<std::pair<const xAOD::eFexTauRoI*, const xAOD::jFexTauRoI*>> roi_vec;
216 if(!jTau_roi_link.isValid()) {
217 ATH_MSG_WARNING(
"Failed to create jTauLink accessor for the L1_cTauRoi container");
222 for(
size_t i = 0; i < rois->size(); i++) {
224 const xAOD::jFexTauRoI* jTau_roi = jTau_roi_link(i).isValid() ? *jTau_roi_link(i) :
nullptr;
231 if(!thresholdPatterns.isValid()) {
232 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_cTauRoi container");
236 for(
size_t i = 0; i < rois->size(); i++) {
238 const xAOD::jFexTauRoI* jTau_roi = jTau_roi_link(i).isValid() ? *jTau_roi_link(i) :
nullptr;
255 ATH_MSG_ERROR(
"HLT TauJet container not registered for suffix \"" << container_suffix <<
"\". Returning the default \"" <<
m_hltTauJetKeysMap.at(
"MVA").key() <<
"\"");
258 ATH_MSG_ERROR(
"HLT TauJet container not registered for suffix \"" << container_suffix <<
"\". Returning the first available container \"" <<
m_hltTauJetKeysMap.begin()->second.key() <<
"\"");
271 if(
m_trigDecTool->ExperimentalAndExpertMethods().isHLTTruncated()){
273 return StatusCode::SUCCESS;
283 return StatusCode::SUCCESS;
288 return StatusCode::SUCCESS;
294 std::vector<const xAOD::TauJet*> tau_vec;
297 if(!tauid_medium.isValid()) {
303 if(tau->pt() <
threshold*Gaudi::Units::GeV)
continue;
310 if(!tauid_medium(*tau))
continue;
313 tau_vec.push_back(tau);
322 std::vector<const xAOD::TauJet*> tau_vec_0p, tau_vec_1p, tau_vec_mp;
328 if(nTracks == 0) tau_vec_0p.push_back(tau);
329 else if(nTracks == 1) tau_vec_1p.push_back(tau);
330 else tau_vec_mp.push_back(tau);
333 return {tau_vec_0p, tau_vec_1p, tau_vec_mp};
339 std::vector<const xAOD::TauJet*> tau_vec_1p, tau_vec_3p;
345 if(nTracks == 1) tau_vec_1p.push_back(tau);
346 else if(nTracks == 3) tau_vec_3p.push_back(tau);
349 return {tau_vec_1p, tau_vec_3p};
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
std::vector< size_t > vec
Handle class for reading a decoration on an object.
virtual StatusCode initialize() override
initialize
SG::ReadHandle< xAOD::EventInfo > GetEventInfo(const EventContext &) const
Return a ReadHandle for an EventInfo object (get run/event numbers, etc.)
PublicToolHandle< Trig::TrigDecisionTool > m_trigDecTool
Tool to tell whether a specific trigger is passed.
AthMonitorAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
Constructor.
Helper class to provide constant type-safe access to aux data.
const_reference_type withDefault(const ELT &e, const T &deflt) const
Fetch the variable for one element, as a const reference, with a default.
Handle class for reading a decoration on an object.
Property holding a SG store/key/clid from which a ReadHandle is made.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
std::vector< const xAOD::eFexTauRoI * > getL1eTAUs(const EventContext &ctx, const std::string &l1_item) const
Gaudi::Property< std::map< std::string, float > > m_L1_Phase1_thresholds
const SG::ReadHandleKey< xAOD::TauJetContainer > & getOnlineContainerKey(const std::string &container_suffix) const
SG::ReadHandleKey< xAOD::jFexTauRoIContainer > m_phase1l1jTauRoIKey
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIDecorKey
virtual StatusCode initialize() override
initialize
std::map< std::string, TrigTauInfo > m_trigInfo
TrigTauMonitorBaseAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
std::vector< const xAOD::TauJet * > getOfflineTausAll(const EventContext &ctx, const float threshold=20.0) const
std::unordered_map< std::string, SG::ReadHandleKey< xAOD::TauJetContainer > > m_hltTauJetKeysMap
std::pair< std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * > > getOfflineTaus(const EventContext &ctx, const float threshold=20.0, const TauID tau_id=TauID::None) const
Gaudi::Property< std::vector< std::string > > m_triggers
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIThresholdPatternsKey
SG::ReadHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1eTauRoIKey
SG::ReadDecorHandleKey< xAOD::jFexTauRoIContainer > m_phase1l1jTauRoIThresholdPatternsKey
std::map< std::string, TrigTauInfo > & getTrigInfoMap()
const TrigTauInfo & getTrigInfo(const std::string &trigger) const
virtual StatusCode processEvent(const EventContext &ctx) const =0
virtual StatusCode fillHistograms(const EventContext &ctx) const override
adds event to the monitoring histograms
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1eTauRoIThresholdPatternsKey
Gaudi::Property< bool > m_L1_select_by_et_only
SG::ReadDecorHandleKey< xAOD::TauJetContainer > m_offlineGNTauDecorKey
std::vector< const xAOD::jFexTauRoI * > getL1jTAUs(const EventContext &ctx, const std::string &l1_item) const
std::vector< const xAOD::TauJet * > getOnlineTausAll(const std::string &trigger, bool include_0P=true, bool filter_legs=false) const
std::vector< std::pair< const xAOD::eFexTauRoI *, const xAOD::jFexTauRoI * > > getL1cTAUs(const EventContext &ctx, const std::string &l1_item) const
std::vector< const xAOD::TauJet * > classifyTausAll(const std::vector< const xAOD::TauJet * > &taus, const float threshold=0.0, const TauID tau_id=TauID::None) const
SG::ReadHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIKey
std::tuple< std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * > > getOnlineTaus(const std::string &trigger) const
std::pair< std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * > > classifyOfflineTaus(const std::vector< const xAOD::TauJet * > &taus, const float threshold=0.0, const TauID tau_id=TauID::None) const
Gaudi::Property< std::map< std::string, uint64_t > > m_L1_Phase1_threshold_patterns
SG::ReadDecorHandleKey< xAOD::EventInfo > m_eventInfoDecorKey
SG::ReadHandleKey< xAOD::TauJetContainer > m_offlineTauJetKey
std::tuple< std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * > > classifyOnlineTaus(const std::vector< const xAOD::TauJet * > &taus, const float threshold=0.0) const
@ Tile
The Tile calorimeter.
@ Core
Core flags describing the event.
@ LAr
The LAr calorimeter.
@ Error
The sub-detector issued an error.
bool detail(TauJetParameters::Detail detail, int &value) const
Get and set values of common details variables via enum.
float et() const
TOB ET (decoded from TOB, stored for convenience)
const std::string & featureString()
static const unsigned int lastFeatureOfType
Run 3 "enum". Only return the final feature along each route through the navigation.
static const unsigned int Physics
TauJet_v3 TauJet
Definition of the current "tau version".
jFexTauRoI_v1 jFexTauRoI
Define the latest version of the jFexSRJetRoI class.
TauJetContainer_v3 TauJetContainer
Definition of the current "taujet container version".
eFexTauRoI_v1 eFexTauRoI
Define the latest version of the eFexTauRoI class.