23 return StatusCode::SUCCESS;
29 std::vector<const xAOD::Electron*> el_vec;
53 std::vector<const xAOD::Muon*> mu_vec;
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...");
122 const bool l1_accept_flag =
passBits & TrigDefs::L1_isPassedAfterVeto;
123 const bool hlt_not_prescaled_flag = (
passBits & TrigDefs::EF_prescaled) == 0;
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;
177 void 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;
200 bool hlt_fires =
m_trigDecTool->isPassed(trigger, TrigDefs::Physics);
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);
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;
217 HLT_match_highPt =
static_cast<bool>(HLT_match);
222 ATH_MSG_DEBUG(
"After fill Tag and Probe HLT efficiencies: " << trigger);
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());
263 TLorentzVector diTau4V = tau_vec[index_tau]->p4() + lep_vec[index_lep]->p4();
272 ATH_MSG_DEBUG(
"After fill Tag & Probe variables: " << trigger);