45 if(
m_trigInfo[trigger].areAnyL1TauIsolated()) {
46 ATH_MSG_FATAL(
"Cannot use isolated L1 tau items if running with SelectL1ByETOnly = True: " << trigger);
47 return StatusCode::FAILURE;
54 return StatusCode::SUCCESS;
59 std::vector<const xAOD::TauJet*> tau_vec;
64 ATH_MSG_DEBUG(
"Tau container name is: " << tau_container_name);
66 for(
auto& featLinkInfo :
vec) {
74 if(include_0P && nTracks == 0) tau_vec.push_back(feat);
75 else tau_vec.push_back(feat);
91 std::vector<const xAOD::TauJet*> tau_vec;
101 if(tau->pt() <
threshold*Gaudi::Units::GeV)
continue;
104 if(std::abs(tau->eta()) > 1.37 && std::abs(tau->eta()) < 1.52)
continue;
111 if(!passThinningAcc.
withDefault(*tau,
true))
continue;
116 if(nTracks == 1 || nTracks == 3) tau_vec.push_back(tau);
131 std::vector<const xAOD::eFexTauRoI*> roi_vec;
134 if(!rois.isValid()) {
146 if(!thresholdPatterns.isValid()) {
147 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_eTauRoi container");
163 std::vector<const xAOD::jFexTauRoI*> roi_vec;
166 if(!rois.isValid()) {
178 if(!thresholdPatterns.isValid()) {
179 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_jTauRoi container");
195 std::vector<std::pair<const xAOD::eFexTauRoI*, const xAOD::jFexTauRoI*>> roi_vec;
198 if(!rois.isValid()) {
203 if(!jTau_roi_link.isValid()) {
204 ATH_MSG_WARNING(
"Failed to create jTauLink accessor for the L1_cTauRoi container");
209 for(
size_t i = 0; i < rois->size(); i++) {
211 const xAOD::jFexTauRoI* jTau_roi = jTau_roi_link(i).isValid() ? *jTau_roi_link(i) :
nullptr;
218 if(!thresholdPatterns.isValid()) {
219 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_cTauRoi container");
223 for(
size_t i = 0; i < rois->size(); i++) {
225 const xAOD::jFexTauRoI* jTau_roi = jTau_roi_link(i).isValid() ? *jTau_roi_link(i) :
nullptr;
239 if(sequence ==
"tracktwoMVA" || sequence ==
"tracktwoMVABDT")
return m_hltTauJetKey;
244 ATH_MSG_ERROR(
"Unknown HLT TauJet container for sequence \"" << sequence <<
"\". Returning the default \"" <<
m_hltTauJetKey.key() <<
"\"");
256 if(
m_trigDecTool->ExperimentalAndExpertMethods().isHLTTruncated()){
258 return StatusCode::SUCCESS;
268 return StatusCode::SUCCESS;
273 return StatusCode::SUCCESS;
279 std::vector<const xAOD::TauJet*> tau_vec;
282 if(!tauid_medium.isValid()) {
288 if(tau->pt() <
threshold*Gaudi::Units::GeV)
continue;
295 if(!tauid_medium(*tau))
continue;
298 tau_vec.push_back(tau);
307 std::vector<const xAOD::TauJet*> tau_vec_0p, tau_vec_1p, tau_vec_mp;
313 if(nTracks == 0) tau_vec_0p.push_back(tau);
314 else if(nTracks == 1) tau_vec_1p.push_back(tau);
315 else tau_vec_mp.push_back(tau);
318 return {tau_vec_0p, tau_vec_1p, tau_vec_mp};
324 std::vector<const xAOD::TauJet*> tau_vec_1p, tau_vec_3p;
330 if(nTracks == 1) tau_vec_1p.push_back(tau);
331 else if(nTracks == 3) tau_vec_3p.push_back(tau);
334 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
const SG::ReadHandleKey< xAOD::TauJetContainer > & getOnlineContainerKey(const std::string &sequence) const
Gaudi::Property< std::map< std::string, float > > m_L1_Phase1_thresholds
SG::ReadHandleKey< xAOD::jFexTauRoIContainer > m_phase1l1jTauRoIKey
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIDecorKey
virtual StatusCode initialize() override
initialize
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetKey
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::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
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetLLPKey
const TrigTauInfo & getTrigInfo(const std::string &trigger) const
virtual StatusCode processEvent(const EventContext &ctx) const =0
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetCaloMVAOnlyKey
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< 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
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetLRTKey
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
std::vector< const xAOD::TauJet * > getOnlineTausAll(const std::string &trigger, bool include_0P=true) 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)
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.