23 return StatusCode::SUCCESS;
29 std::vector<const xAOD::Electron*> el_vec;
32 if(!electrons.isValid()) {
39 if(el->p4().Pt()/Gaudi::Units::GeV <
threshold)
continue;
53 std::vector<const xAOD::Muon*> mu_vec;
63 if(mu->p4().Pt()/Gaudi::Units::GeV <
threshold)
continue;
66 if(!(mu->quality() <= xAOD::Muon::Medium && mu->passesIDCuts()))
continue;
77 std::vector<const xAOD::Electron*> el_vec;
80 for(
auto &featLinkInfo :
vec) {
81 const auto *feat = *(featLinkInfo.link);
83 el_vec.push_back(feat);
92 std::vector<const xAOD::Muon*> mu_vec;
95 for(
auto &featLinkInfo :
vec) {
96 const auto *feat = *(featLinkInfo.link);
98 mu_vec.push_back(feat);
107 constexpr float threshold_offset = 10.0;
113 for(
const std::string& trigger :
m_triggers) {
116 if(!info.isHLTTandP()) {
117 ATH_MSG_WARNING(
"Chain \"" << trigger <<
"\" is not a Tag and Probe trigger. Skipping...");
130 std::vector<const xAOD::TauJet*> offline_taus =
classifyTausAll(offline_taus_with_id, info.getHLTTauThreshold() - threshold_offset);
133 std::vector<const xAOD::TauJet*> hlt_taus =
getOnlineTausAll(trigger,
true);
135 if(info.hasHLTElectronLeg()) {
137 std::vector<const xAOD::IParticle*> offline_electrons;
141 for(
int i = offline_taus.size()-1; i >= 0; i--) {
142 bool is_match =
matchObjects(offline_taus.at(i), offline_electrons, 0.2);
143 if(is_match) offline_taus.erase(offline_taus.begin() + i);
147 std::vector<const xAOD::IParticle*> hlt_electrons;
153 }
else if(info.hasHLTMuonLeg()) {
155 std::vector<const xAOD::IParticle*> offline_muons;
159 for(
int i = offline_taus.size()-1; i >= 0; i--) {
160 bool is_match =
matchObjects(offline_taus.at(i), offline_muons, 0.2);
161 if(is_match) offline_taus.erase(offline_taus.begin() + i);
165 std::vector<const xAOD::IParticle*> hlt_muons;
173 return StatusCode::SUCCESS;
177void TrigTauMonitorTandPAlgorithm::fillTAndPHLTEfficiencies(
const EventContext& ctx,
const std::string& trigger,
const std::vector<const xAOD::IParticle*>& offline_lep_vec,
const std::vector<const xAOD::IParticle*>& online_lep_vec,
const std::vector<const xAOD::TauJet*>& offline_tau_vec,
const std::vector<const xAOD::TauJet*>& online_tau_vec)
const
179 ATH_MSG_DEBUG(
"Fill Tag and Probe HLT efficiencies: " << trigger);
182 if(online_tau_vec.size() != 1 || offline_tau_vec.size() != 1)
return;
184 if(online_lep_vec.size() != 1 || offline_lep_vec.size() != 1)
return;
186 auto monGroup =
getGroup(trigger+
"_TAndPHLT_Efficiency");
201 bool tau1_match =
matchObjects(offline_tau_vec[0], online_tau_vec, 0.2);
202 bool lep1_match =
matchObjects(offline_lep_vec[0], online_lep_vec, 0.2);
204 tauPt = offline_tau_vec[0]->pt()/Gaudi::Units::GeV;
205 tauEta = offline_tau_vec[0]->eta();
206 tauPhi = offline_tau_vec[0]->phi();
207 dR = offline_tau_vec[0]->p4().DeltaR(offline_lep_vec[0]->p4());
208 dEta = std::abs(offline_tau_vec[0]->
eta() - offline_lep_vec[0]->
eta());
209 dPhi = offline_tau_vec[0]->p4().DeltaPhi(offline_lep_vec[0]->p4());
211 HLT_match = hlt_fires && tau1_match && lep1_match;
213 fill(monGroup, tauPt, tauEta, tauPhi,
dR, dEta, dPhi, averageMu, HLT_match);
217 HLT_match_highPt =
static_cast<bool>(HLT_match);
218 fill(monGroup, tauEta, tauPhi, HLT_match_highPt);
222 ATH_MSG_DEBUG(
"After fill Tag and Probe HLT efficiencies: " << trigger);
230 auto monGroup =
getGroup(trigger+
"_TAndPVars");
233 if(tau_vec.empty() || lep_vec.empty())
return;
249 for(
uint i=0; i < tau_vec.size(); i++) {
250 for(
uint j=0; j< lep_vec.size(); j++) {
251 if(tau_vec[i]->p4().DeltaR(lep_vec[j]->p4()) >= 0.3) {
258 dR = tau_vec[index_tau]->p4().DeltaR(lep_vec[index_lep]->p4());
259 dEta = std::abs(tau_vec[index_tau]->
eta() - lep_vec[index_lep]->
eta());
260 dPhi = tau_vec[index_tau]->p4().DeltaPhi(lep_vec[index_lep]->p4());
261 dPt = std::abs((tau_vec[index_tau]->pt() - lep_vec[index_lep]->pt())/Gaudi::Units::GeV);
263 TLorentzVector diTau4V = tau_vec[index_tau]->p4() + lep_vec[index_lep]->p4();
265 Pt = diTau4V.Pt()/Gaudi::Units::GeV;
268 M = diTau4V.M()/Gaudi::Units::GeV;
270 fill(monGroup,
dR, dEta, dPhi, dPt, Pt, Eta, Phi, M);
272 ATH_MSG_DEBUG(
"After fill Tag & Probe variables: " << trigger);
Scalar eta() const
pseudorapidity method
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
std::vector< size_t > vec
const ToolHandle< GenericMonitoringTool > & getGroup(const std::string &name) const
Get a specific monitoring tool from the tool handle array.
PublicToolHandle< Trig::TrigDecisionTool > m_trigDecTool
Tool to tell whether a specific trigger is passed.
Declare a monitored scalar variable.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
float getHLTTauThreshold() const
Gaudi::Property< bool > m_do_efficiency_plots
virtual StatusCode initialize() override
initialize
double dR(const double eta1, const double phi1, const double eta2, const double phi2) const
TrigTauMonitorBaseAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
std::vector< const xAOD::TauJet * > getOfflineTausAll(const EventContext &ctx, const float threshold=20.0) const
bool matchObjects(const T1 *tau, const std::vector< const T2 * > &tau_vec, float threshold) const
Gaudi::Property< std::vector< std::string > > m_triggers
const TrigTauInfo & getTrigInfo(const std::string &trigger) 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
Gaudi::Property< bool > m_do_variable_plots
std::vector< const xAOD::TauJet * > getOnlineTausAll(const std::string &trigger, bool include_0P=true) const
SG::ReadHandleKey< xAOD::MuonContainer > m_hltMuonKey
TrigTauMonitorTandPAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
virtual StatusCode processEvent(const EventContext &ctx) const override
SG::ReadHandleKey< xAOD::ElectronContainer > m_offlineElectronKey
void fillTAndPHLTEfficiencies(const EventContext &ctx, const std::string &trigger, const std::vector< const xAOD::IParticle * > &offline_lep_vec, const std::vector< const xAOD::IParticle * > &online_lep_vec, const std::vector< const xAOD::TauJet * > &offline_tau_vec, const std::vector< const xAOD::TauJet * > &online_tau_vec) const
Gaudi::Property< unsigned int > m_offline_tau_id
std::vector< const xAOD::Electron * > getOfflineElectrons(const EventContext &ctx, const float threshold=0.0) const
std::vector< const xAOD::Muon * > getOfflineMuons(const EventContext &ctx, const float threshold=0.0) const
SG::ReadHandleKey< xAOD::ElectronContainer > m_hltElectronKey
void fillTagAndProbeVars(const std::string &trigger, const std::vector< const xAOD::TauJet * > &tau_vec, const std::vector< const xAOD::IParticle * > &lep_vec) const
Gaudi::Property< bool > m_requireOfflineTaus
std::vector< const xAOD::Muon * > getOnlineMuons(const std::string &trigger) const
std::vector< const xAOD::Electron * > getOnlineElectrons(const std::string &trigger) const
SG::ReadHandleKey< xAOD::MuonContainer > m_offlineMuonKey
virtual StatusCode initialize() override
initialize
Class providing the definition of the 4-vector interface.
void fill(const ToolHandle< GenericMonitoringTool > &groupHandle, std::vector< std::reference_wrapper< Monitored::IMonitoredVariable > > &&variables) const
Fills a vector of variables to a group by reference.
virtual float lbAverageInteractionsPerCrossing(const EventContext &ctx=Gaudi::Hive::currentContext()) const
Calculate the average mu, i.e.
static const unsigned int EF_prescaled
static const unsigned int L1_isPassedAfterVeto
static const unsigned int Physics
const uint32_t BADCLUSELECTRON
ElectronContainer_v1 ElectronContainer
Definition of the current "electron container version".
Muon_v1 Muon
Reference the current persistent version:
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".
Electron_v1 Electron
Definition of the current "egamma version".