 |
ATLAS Offline Software
|
Go to the documentation of this file.
44 if(
m_trigInfo[trigger].areAnyL1TauIsolated()) {
45 ATH_MSG_FATAL(
"Cannot use isolated L1 tau items if running with SelectL1ByETOnly = True: " << trigger);
46 return StatusCode::FAILURE;
53 return StatusCode::SUCCESS;
58 std::vector<const xAOD::TauJet*> tau_vec;
63 ATH_MSG_DEBUG(
"Tau container name is: " << tau_container_name);
65 for(
auto& featLinkInfo :
vec) {
73 if(include_0P && nTracks == 0) tau_vec.push_back(feat);
74 else tau_vec.push_back(feat);
90 std::vector<const xAOD::TauJet*> tau_vec;
103 if(std::abs(tau->eta()) > 1.37 && std::abs(tau->eta()) < 1.52)
continue;
110 if(!passThinningAcc.
withDefault(*tau,
true))
continue;
115 if(nTracks == 1 || nTracks == 3) tau_vec.push_back(tau);
130 std::vector<const xAOD::eFexTauRoI*> roi_vec;
133 if(!
rois.isValid()) {
145 if(!thresholdPatterns.isValid()) {
146 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_eTauRoi container");
162 std::vector<const xAOD::jFexTauRoI*> roi_vec;
165 if(!
rois.isValid()) {
177 if(!thresholdPatterns.isValid()) {
178 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property accessor for the L1_jTauRoi container");
194 std::vector<std::pair<const xAOD::eFexTauRoI*, const xAOD::jFexTauRoI*>> roi_vec;
197 if(!
rois.isValid()) {
202 if(!jTau_roi_link.isValid()) {
203 ATH_MSG_WARNING(
"Failed to create jTauLink accessor for the L1_cTauRoi container");
208 for(
size_t i = 0;
i <
rois->size();
i++) {
210 const xAOD::jFexTauRoI* jTau_roi = jTau_roi_link(
i).isValid() ? *jTau_roi_link(
i) :
nullptr;
217 if(!thresholdPatterns.isValid()) {
218 ATH_MSG_WARNING(
"Failed to create thresholdPatterns property 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;
238 if(sequence ==
"tracktwoMVA" || sequence ==
"tracktwoMVABDT")
return m_hltTauJetKey;
243 ATH_MSG_ERROR(
"Unknown HLT TauJet container for sequence \"" << sequence <<
"\". Returning the default \"" <<
m_hltTauJetKey.key() <<
"\"");
255 if(
m_trigDecTool->ExperimentalAndExpertMethods().isHLTTruncated()){
257 return StatusCode::SUCCESS;
267 return StatusCode::SUCCESS;
272 return StatusCode::SUCCESS;
278 std::vector<const xAOD::TauJet*> tau_vec;
281 if(!tauid_medium.isValid()) {
290 if(tau_id == TauID::RNN) {
293 else if(tau_id == TauID::GNTau) {
294 if(!tauid_medium(*tau))
continue;
297 tau_vec.push_back(tau);
306 std::vector<const xAOD::TauJet*> tau_vec_0p, tau_vec_1p, tau_vec_mp;
312 if(nTracks == 0) tau_vec_0p.push_back(tau);
313 else if(nTracks == 1) tau_vec_1p.push_back(tau);
314 else tau_vec_mp.push_back(tau);
317 return {tau_vec_0p, tau_vec_1p, tau_vec_mp};
323 std::vector<const xAOD::TauJet*> tau_vec_1p, tau_vec_3p;
329 if(nTracks == 1) tau_vec_1p.push_back(tau);
330 else if(nTracks == 3) tau_vec_3p.push_back(tau);
333 return {tau_vec_1p, tau_vec_3p};
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetKey
Class describing properties of a LVL1 jFEX global Trigger Object (TOB) in the xAOD format.
float et() const
TOB ET (decoded from TOB, stored for convenience)
PublicToolHandle< Trig::TrigDecisionTool > m_trigDecTool
Tool to tell whether a specific trigger is passed.
std::map< std::string, TrigTauInfo > m_trigInfo
virtual StatusCode initialize() override
initialize
SG::ReadDecorHandleKey< xAOD::jFexTauRoIContainer > m_phase1l1jTauRoIThresholdPatternsKey
SG::ReadHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1eTauRoIKey
std::vector< std::pair< const xAOD::eFexTauRoI *, const xAOD::jFexTauRoI * > > getL1cTAUs(const EventContext &ctx, const std::string &l1_item) const
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIDecorKey
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
Gaudi::Property< bool > m_L1_select_by_et_only
std::vector< size_t > vec
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1eTauRoIThresholdPatternsKey
std::vector< const xAOD::eFexTauRoI * > getL1eTAUs(const EventContext &ctx, const std::string &l1_item) const
Property holding a SG store/key/clid from which a ReadHandle is made.
@ LAr
The LAr calorimeter.
Gaudi::Property< std::map< std::string, float > > m_L1_Phase1_thresholds
@ Error
The sub-detector issued an error.
Base class for Athena Monitoring Algorithms.
SG::ReadHandleKey< xAOD::jFexTauRoIContainer > m_phase1l1jTauRoIKey
std::vector< const xAOD::TauJet * > getOnlineTausAll(const std::string &trigger, bool include_0P=true) const
Gaudi::Property< std::map< std::string, uint64_t > > m_L1_Phase1_threshold_patterns
Handle class for reading a decoration on an object.
TrigTauMonitorBaseAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
Class describing a LVL1 eFEX tau region of interest.
::StatusCode StatusCode
StatusCode definition for legacy code.
const SG::ReadHandleKey< xAOD::TauJetContainer > & getOnlineContainerKey(const std::string &sequence) const
Class describing a tau jet.
SG::ReadHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIKey
SG::ReadHandle< xAOD::EventInfo > GetEventInfo(const EventContext &) const
Return a ReadHandle for an EventInfo object (get run/event numbers, etc.)
virtual bool isValid() override final
Can the handle be successfully dereferenced?
bool detail(TauJetParameters::Detail detail, int &value) const
Get and set values of common details variables via enum.
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
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
SG::ReadHandleKey< xAOD::TauJetContainer > m_offlineTauJetKey
SG::ReadDecorHandleKey< xAOD::TauJetContainer > m_offlineGNTauDecorKey
virtual StatusCode initialize() override
initialize
virtual StatusCode fillHistograms(const EventContext &ctx) const override
adds event to the monitoring histograms
@ Tile
The Tile calorimeter.
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetCaloMVAOnlyKey
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
virtual StatusCode processEvent(const EventContext &ctx) const =0
std::vector< const xAOD::jFexTauRoI * > getL1jTAUs(const EventContext &ctx, const std::string &l1_item) const
#define ATH_MSG_WARNING(x)
SG::ReadDecorHandleKey< xAOD::eFexTauRoIContainer > m_phase1l1cTauRoIThresholdPatternsKey
EventFlagErrorState errorState(EventFlagSubDet subDet) const
Get the error state for a particular sub-detector.
Gaudi::Property< std::vector< std::string > > m_triggers
bool isEventFlagBitSet(EventFlagSubDet subDet, size_t bit) const
Check one particular bit of one particular sub-detector.
Handle class for reading a decoration on an object.
const TrigTauInfo & getTrigInfo(const std::string &trigger) const
SG::ReadDecorHandleKey< xAOD::EventInfo > m_eventInfoDecorKey
std::tuple< std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * >, std::vector< const xAOD::TauJet * > > getOnlineTaus(const std::string &trigger) const
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetLRTKey
@ Core
Core flags describing the event.
std::vector< const xAOD::TauJet * > getOfflineTausAll(const EventContext &ctx, const float threshold=20.0) const
SG::ReadHandleKey< xAOD::TauJetContainer > m_hltTauJetLLPKey
const_reference_type withDefault(const ELT &e, const T &deflt) const
Fetch the variable for one element, as a const reference, with a default.