ATLAS Offline Software
Loading...
Searching...
No Matches
PhysicsAnalysis/TauID/TauAnalysisTools/Root/HelperFunctions.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
5#include <fstream>
6
7// local include(s)
11#include "TF1.h"
12
13#ifdef ASGTOOL_ATHENA
14#include "CLHEP/Units/SystemOfUnits.h"
15using CLHEP::GeV;
16#else
17#define GeV 1000
18#endif
19
20using namespace TauAnalysisTools;
21
22//______________________________________________________________________________
23void TauAnalysisTools::split(const std::string& sInput, const char cDelim, std::vector<std::string>& vOut)
24{
25 std::stringstream sSS(sInput);
26 std::string sItem;
27 while (std::getline(sSS, sItem, cDelim))
28 vOut.push_back(sItem);
29}
30
31//______________________________________________________________________________
32void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<std::string>& vOut)
33{
34 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
35 std::string sItem;
36 while (std::getline(sSS, sItem, cDelim))
37 vOut.push_back(sItem);
38}
39
40//______________________________________________________________________________
41void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<size_t>& vOut)
42{
43 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
44 std::string sItem;
45 while (std::getline(sSS, sItem, cDelim))
46 vOut.push_back(size_t(stoi(sItem)));
47}
48
49//______________________________________________________________________________
50void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<int>& vOut)
51{
52 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
53 std::string sItem;
54 while (std::getline(sSS, sItem, cDelim))
55 vOut.push_back(stoi(sItem));
56}
57
58//______________________________________________________________________________
59void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<unsigned>& vOut)
60{
61 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
62 std::string sItem;
63 while (std::getline(sSS, sItem, cDelim))
64 vOut.push_back(stoi(sItem));
65}
66
67//______________________________________________________________________________
68void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<float>& vOut)
69{
70 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
71 std::string sItem;
72 while (std::getline(sSS, sItem, cDelim))
73 vOut.push_back(stof(sItem));
74}
75
76//______________________________________________________________________________
77void TauAnalysisTools::split(TEnv& rEnv, const std::string& sKey, const char cDelim, std::vector<double>& vOut)
78{
79 std::stringstream sSS(rEnv.GetValue(sKey.c_str(),""));
80 std::string sItem;
81 while (std::getline(sSS, sItem, cDelim))
82 vOut.push_back(stod(sItem));
83}
84//______________________________________________________________________________
86{
87 // return tau pt in GeV
88 return xTau.pt()/1000.;
89}
90
91//______________________________________________________________________________
93{
94 // return tau P in GeV
95 return xTau.p4().P()/1000.;
96}
97
98//______________________________________________________________________________
100{
101 // return tau eta
102 return xTau.eta();
103}
104
105//______________________________________________________________________________
107{
108 // return absolute tau eta
109 return std::abs(xTau.eta());
110}
111
112//______________________________________________________________________________
114{
115 // return MVA based tau pt in GeV
116 return xTau.ptFinalCalib()/GeV;
117}
118
119//______________________________________________________________________________
121{
122 // return MVA based tau eta
123 return xTau.etaFinalCalib();
124}
125
126//______________________________________________________________________________
128{
129 // return MVA based absolute tau eta
130 return std::abs(xTau.etaFinalCalib());
131}
132
133//______________________________________________________________________________
135{
136 // return tau P in GeV
138}
139
140//______________________________________________________________________________
142{
143 // return leading charge tau track eta
144 double dTrackEta = 0.;
145 double dTrackMaxPt = 0.;
146 for( unsigned int iNumTrack = 0; iNumTrack < xTau.nTracks(); iNumTrack++)
147 {
148 if (xTau.track(iNumTrack)->pt() > dTrackMaxPt)
149 {
150 dTrackMaxPt = xTau.track(iNumTrack)->pt();
151 dTrackEta = xTau.track(iNumTrack)->eta();
152 }
153 }
154 return dTrackEta;
155}
156
157//______________________________________________________________________________
159{
160 // return truth tau Pt in GeV
161 const xAOD::TruthParticle* xTruthTau = getTruth(xTau);
162
163 // if there is a truth tau return pT, otherwise return 0 (getTruth will print an error)
164 static const SG::ConstAccessor<char> accIsHadronicTau ("IsHadronicTau");
165 if (xTruthTau!=nullptr && accIsHadronicTau (*xTruthTau))
166 return xTruthTau->pt()/GeV;
167 else
168 return 0.;
169}
170
171//______________________________________________________________________________
173{
174 // return truth tau absolute eta
175 const xAOD::TruthParticle* xTruthTau = getTruth(xTau);
176
177 // if there is a truth tau return absolute eta, otherwise return -5 (getTruth will print an error)
178 static const SG::ConstAccessor<char> accIsHadronicTau ("IsHadronicTau");
179 if (xTruthTau!=nullptr && accIsHadronicTau (*xTruthTau))
180 return std::abs(xTruthTau->eta());
181 else
182 return -5.;
183}
184
185//______________________________________________________________________________
187{
188 // return truth tau decay mode.
189 int iDecayMode = getTruthDecayMode(xTau);
190 return static_cast<double>(iDecayMode);
191}
192
193//______________________________________________________________________________
195{
197 static const SG::ConstAccessor<Link_t> accTruthParticleLink("truthParticleLink");
198 if (!accTruthParticleLink(xTau))
199 {
200 Error("TauAnalysisTools::getTruth", "No truth match information available. Please run TauTruthMatchingTool first");
201 }
202
203 const Link_t xTruthTauLink = accTruthParticleLink(xTau);
204 const xAOD::TruthParticle* xTruthTau = xTruthTauLink.cachedElement();
205
206 return xTruthTau;
207}
208
209
210//______________________________________________________________________________
212{
213 const xAOD::TruthParticle* xTruthTau = getTruth(xTau);
214
215 static const SG::ConstAccessor<char> accIsHadronicTau ("IsHadronicTau");
216 if (xTruthTau!=nullptr && accIsHadronicTau(*xTruthTau))
217 return getTruthDecayMode(*xTruthTau);
218 else
220}
221
222//______________________________________________________________________________
224{
225 static const SG::ConstAccessor<size_t> accNumCharged ("numCharged");
226 if (!(accNumCharged.isAvailable(xTruthTau)))
227 {
228 // passed truth particle is not a truth tau
230 }
231
232 int iCharged = getNTauDecayParticles(xTruthTau,MC::PIPLUS, true) + getNTauDecayParticles(xTruthTau,MC::KPLUS, true);
233 int iNeutral = getNTauDecayParticles(xTruthTau,MC::PI0, true);
234 if (iCharged == 1)
235 {
236 if (iNeutral == 0) return xAOD::TauJetParameters::DecayMode::Mode_1p0n;
237 if (iNeutral == 1) return xAOD::TauJetParameters::DecayMode::Mode_1p1n;
238 if (iNeutral >= 2) return xAOD::TauJetParameters::DecayMode::Mode_1pXn;
239 }
240 else if (iCharged == 3)
241 {
242 if (iNeutral == 0) return xAOD::TauJetParameters::DecayMode::Mode_3p0n;
243 if (iNeutral >= 1) return xAOD::TauJetParameters::DecayMode::Mode_3pXn;
244 }
245
246 if (iCharged == 2 or iCharged == 4 or iCharged == 5)
248 if (iCharged == 0 or iCharged >=6)
250
251 // if you got here, something should have gone wrong
253}
254
255//______________________________________________________________________________
256int TauAnalysisTools::getNTauDecayParticles(const xAOD::TruthParticle& xTruthTau, int iPdgId, bool bCompareAbsoluteValues)
257{
258 int iNum = 0;
259 static const SG::ConstAccessor<std::vector<int> > accDecayModeVector("DecayModeVector");
260 if (!accDecayModeVector.isAvailable(xTruthTau))
261 {
262 Warning("TauAnalysisTools::getNTauDecayParticles", "passed truth particle is not a truth tau, return 0");
263 return 0;
264 }
265
266 for(auto iPdgId2 : accDecayModeVector(xTruthTau))
267 if (!bCompareAbsoluteValues)
268 {
269 if (iPdgId2 == iPdgId) iNum++;
270 }
271 else
272 {
273 if (std::abs(iPdgId2) == std::abs(iPdgId)) iNum++;
274 }
275 return iNum;
276}
277
278//______________________________________________________________________________
280{
281 // returns true if last line in file is empty or the line starts with the
282 // number sign #
283
284 std::ifstream fInputFile;
285 fInputFile.open(sFileName);
286 if(!fInputFile.is_open())
287 return true;
288
289 fInputFile.seekg(-1,fInputFile.end);
290
291 bool bKeepLooping = true;
292 while(bKeepLooping)
293 {
294 char ch;
295 fInputFile.get(ch);
296
297 if(static_cast<int>(fInputFile.tellg()) <= 1)
298 {
299 fInputFile.seekg(0);
300 bKeepLooping = false;
301 }
302 else if(ch == '\n')
303 bKeepLooping = false;
304 else
305 fInputFile.seekg(-2,fInputFile.cur);
306 }
307
308 std::string sLastLine;
309 getline(fInputFile,sLastLine);
310 fInputFile.close();
311
312 return (sLastLine.size() == 0 or sLastLine[0] == '#');
313}
314
315//______________________________________________________________________________
316void TauAnalysisTools::createPi0Vectors(const xAOD::TauJet* xTau, std::vector<TLorentzVector>& vPi0s)
317{
318 // reset the pi0s
319 vPi0s.clear();
320
321 // Since the PFO links as they come out of reconstruction, only correspond to
322 // calorimeter clusters, whereas we want the consts_pi0 vectors to correspond
323 // to real pi0s, we need to be careful to collect the PFOs correctly to pi0s
324 // for the cases where number of pi0s does not match to the decay mode:
325 size_t iNumPi0PFO = xTau->nPi0PFOs();
326
327 int iDecayMode = -1;
328
330 {
331 Error("TauAnalysisTools::createPi0Vectors", "Failed to retrieve panTauDetail decay mode.");
332 return;
333 }
334
335 if (iDecayMode == xAOD::TauJetParameters::DecayMode::Mode_1p1n && iNumPi0PFO > 1)
336 {
337 // float fMassPi0 = ParticleConstants::piZeroMassInMeV;
339
340 // combine both photons (with 0 mass from Pantau) to one pi0 vector:
341 const xAOD::PFO* xPfo1 = xTau->pi0PFO(0);
342 const xAOD::PFO* xPfo2 = xTau->pi0PFO(1);
343 vPi0s.push_back(xPfo1->p4() + xPfo2->p4());
344
345 // re-set the mass to one pi0:
346 double dNewMomentum = std::sqrt(vPi0s[0].E() * vPi0s[0].E() - fMassPi0Squared);
347 vPi0s[0].SetPxPyPzE(vPi0s[0].Vect().Unit().Px() * dNewMomentum,
348 vPi0s[0].Vect().Unit().Py() * dNewMomentum,
349 vPi0s[0].Vect().Unit().Pz() * dNewMomentum,
350 vPi0s[0].E());
351 }
352 else if (iDecayMode == xAOD::TauJetParameters::DecayMode::Mode_1pXn && iNumPi0PFO == 1)
353 {
354 // make a single pi0 from a PFO that contains two pi0s:
355 const xAOD::PFO* xPfo = xTau->pi0PFO(0);
356 // add the 2-pi0 vector preliminarily to the pi0vector:
357 vPi0s.push_back(xPfo->p4());
358
359 // re-set the mass back to one pi0:
360 double dNewMomentum = std::sqrt(vPi0s[0].E() / 2 * vPi0s[0].E() / 2 - vPi0s[0].M() / 2. * vPi0s[0].M() / 2.);
361 vPi0s[0].SetVectM(vPi0s[0].Vect() * (dNewMomentum / vPi0s[0].P()), vPi0s[0].M() / 2.);
362
363 // create another pi0 from the same vector:
364 vPi0s.push_back(vPi0s[0]);
365 }
366 else
367 {
368 // if it's not any of the special cases above then just collect the PFOs:
369 for (size_t iPFO = 0; iPFO < iNumPi0PFO; iPFO++)
370 {
371 vPi0s.push_back(xTau->pi0PFO(iPFO)->p4());
372 }
373 }
374}
375
376
377//______________________________________________________________________________
378void TauAnalysisTools::correctedPi0Vectors(const xAOD::TauJet* xTau, std::vector<TLorentzVector>& correctedPi0s, TLorentzVector& TauP4){
379 //reset the pi0s
380 correctedPi0s.clear();
381
382 int iDecayMode = -1;
383
385 {
386 Error("TauAnalysisTools::correctedPi0Vectors", "Failed to retrieve panTauDetail decay mode.");
387 return;
388 }
389
390 //Reading in the pi0 vector from createPi0Vectors
391 std::vector<TLorentzVector> vPi0s;
392 createPi0Vectors(xTau,vPi0s);
393
395 //Adding up Pi0 P4s from createPi0Vectors
396 TLorentzVector Sum_vPi0s;
397 for(unsigned int i = 0; i < vPi0s.size() ; i++){
398 Sum_vPi0s += vPi0s[i];
399 }
400
401 //Get sum of the chargedPFO (i.e. tau track) p4
402 TLorentzVector Sum_ChrgPFOP4;
403 for(const xAOD::TauTrack* track : xTau->tracks()) {
404 Sum_ChrgPFOP4 += track->p4();
405 }
406
407 //Get tau FinalCalib P4 (explicitly requiring p4(xAOD::TauJetParameters::TauCalibType::FinalCalib) should be superfluous, as FinalCalib is the default p4)
408 TLorentzVector FinalCalibP4 = xTau->p4();
409
410 //Calculate the difference 3-vector between FinalCalib and Sum of chargedPFOP4
411 double px = FinalCalibP4.Px() - Sum_ChrgPFOP4.Px();
412 double py = FinalCalibP4.Py() - Sum_ChrgPFOP4.Py();
413 double pz = FinalCalibP4.Pz() - Sum_ChrgPFOP4.Pz();
414
415 double p_correctedPi0s = std::sqrt( std::pow(px,2.) + std::pow(py,2.) + std::pow(pz,2.) );
416 double p_vPi0s = Sum_vPi0s.P();
417
418 //Calucate scale factor for the pi0 3-vector momentum
419 double X = p_correctedPi0s/p_vPi0s;
420
421 //Scale the pi0s with X and recalculate the new pi0 energy
422 double px_scaled, py_scaled, pz_scaled, e;
424 for(unsigned int i = 0; i < vPi0s.size() ; i++){
425 px_scaled = vPi0s[i].Px() * X;
426 py_scaled = vPi0s[i].Py() * X;
427 pz_scaled = vPi0s[i].Pz() * X;
428 e = std::sqrt( std::pow(px_scaled,2.) + std::pow(py_scaled,2.) + std::pow(pz_scaled,2.) + std::pow(mPi0,2.) );
429
430 //Append the corrected pi0P4 to correctedPi0s
431 TLorentzVector P4_correctedPi0s;
432 P4_correctedPi0s.SetPxPyPzE(px_scaled,py_scaled,pz_scaled,e);
433 correctedPi0s.push_back(P4_correctedPi0s);
434 }
435 }else{
436 correctedPi0s = vPi0s;
437 }
438
439 //Correct angles between pi0s for 1pXn decays with 1 cluster
440 if(iDecayMode == xAOD::TauJetParameters::DecayMode::Mode_1pXn && xTau->nPi0PFOs() == 1){
441
442 //Get Function of Delta R between the two Pi0s
443 TF1 DeltaRdist("DeltaRdist", "pol3", 0, 67500);
444 DeltaRdist.SetParameter(0, 0.07924);
445 DeltaRdist.SetParameter(1, -2.078/1000000.);
446 DeltaRdist.SetParameter(2, 2.619/100000000000.);
447 DeltaRdist.SetParameter(3, -1.238/10000000000000000.);
448
449 //Get Sum of pi0 P4.Pt()
450 TLorentzVector SumPi0_P4;
451 for( unsigned int i = 0 ; i < correctedPi0s.size() ; i++){
452 SumPi0_P4 += correctedPi0s[i];
453 }
454
455 float SumPi0_pt = SumPi0_P4.Pt();
456
457 //Get delta R value (mean of true DeltaR distribution)
458 float deltaR;
459 if(SumPi0_pt >= 67500){
460 deltaR = 0.020; // = DeltaRdist.Eval(67500);
461 } else{
462 deltaR = DeltaRdist.Eval(SumPi0_pt);
463 }
464
465 TLorentzVector correctedPi0_0, correctedPi0_1;
466 correctedPi0_0.SetPtEtaPhiM( correctedPi0s[0].Pt()/cos(0.5*deltaR/std::sqrt(2.0)), correctedPi0s[0].Eta()+0.5*deltaR/std::sqrt(2.0), correctedPi0s[0].Phi()+0.5*deltaR/std::sqrt(2.0), correctedPi0s[0].M() );
467 correctedPi0_1.SetPtEtaPhiM( correctedPi0s[1].Pt()/cos(0.5*deltaR/std::sqrt(2.0)), correctedPi0s[1].Eta()-0.5*deltaR/std::sqrt(2.0), correctedPi0s[1].Phi()-0.5*deltaR/std::sqrt(2.0), correctedPi0s[1].M() );
468
469 std::vector<TLorentzVector> AngleCorrectedPi0s;
470 AngleCorrectedPi0s.push_back(correctedPi0_0);
471 AngleCorrectedPi0s.push_back(correctedPi0_1);
472
473 //Reparametrise: Delta R -> mass of pi0 Cluster
474 TLorentzVector PionCluster_angleCorrected = AngleCorrectedPi0s[0]+AngleCorrectedPi0s[1];
475
476 double dNewMomentum = std::sqrt(PionCluster_angleCorrected.E()/2. * PionCluster_angleCorrected.E()/2. - PionCluster_angleCorrected.M() / 2. * PionCluster_angleCorrected.M() / 2.);
477 correctedPi0s[0].SetVectM(PionCluster_angleCorrected.Vect() * (dNewMomentum / PionCluster_angleCorrected.P()), PionCluster_angleCorrected.M() / 2.);
478 correctedPi0s[1] = correctedPi0s[0];
479 }
480
481 //Calculate the new tau P4
482 for(const xAOD::TauTrack* track : xTau->tracks()) {
483 TauP4 += track->p4();
484 }
485
486 for(unsigned int iPi0=0; iPi0 < correctedPi0s.size(); iPi0++) {
487 TauP4 += correctedPi0s[iPi0];
488 }
489
490}
491
492//______________________________________________________________________________
494{
496 static const SG::ConstAccessor< Link_t > accTruthParticleLink("truthParticleLink");
497 if (!accTruthParticleLink.isAvailable(xTau))
498 Error("TauAnalysisTools::getTruthParticleType", "No truth match information available. Please run TauTruthMatchingTool first.");
499
500 const xAOD::TruthParticle* xTruthParticle = xAOD::TauHelpers::getTruthParticle(&xTau);
501 if (xTruthParticle)
502 {
503 if (xTruthParticle->isTau())
504 {
505 static const SG::ConstAccessor<char> accIsHadronicTau("IsHadronicTau");
506 if (static_cast<bool>(accIsHadronicTau(*xTruthParticle)))
507 return TruthHadronicTau;
508 else
509 return TruthLeptonicTau;
510 }
511 if (xTruthParticle->isMuon())
512 return TruthMuon;
513 if (xTruthParticle->isElectron())
514 return TruthElectron;
515 }
516
517 // TODO: use const xAOD::Jet* xTruthJet = xAOD::TauHelpers::getLink<xAOD::Jet>(&xTau, "truthJetLink");
518 // currently it is unavailable as templated class is not in icc file
519 static const SG::ConstAccessor< ElementLink< xAOD::JetContainer > > accTruthJetLink("truthJetLink");
520 const ElementLink< xAOD::JetContainer > lTruthParticleLink = accTruthJetLink(xTau);
521 if (lTruthParticleLink.isValid())
522 return TruthJet;
523
524 return Unknown;
525}
526
528{
529 static const SG::ConstAccessor<char> accIsTruthHadronic("IsTruthHadronic");
530 if (!accIsTruthHadronic.isAvailable(xDiTau))
531 Error("TauAnalysisTools::getTruthParticleType", "No truth match information available. Please run DiTauTruthMatchingTool first");
532
533 TruthMatchedParticleType eTruthMatchedParticleType = Unknown;
534
535 if (accIsTruthHadronic(xDiTau))
536 eTruthMatchedParticleType = TruthHadronicDiTau;
537
538 return eTruthMatchedParticleType;
539}
540
541std::vector<const xAOD::TauJet*> TauAnalysisTools::combineTauJetsWithMuonRM(const xAOD::TauJetContainer* taus_std, const xAOD::TauJetContainer* taus_muonRM){
545 // std::string message = "found " + std::to_string(taus_muonRM->size()) + " muon-removal taus";
546 // Info("TauAnalysisTools::getTauJetsWithMuonRM", message.c_str());
547 std::vector<const xAOD::TauJet*> taus_murm_vec(taus_muonRM->begin(), taus_muonRM->end());
548 std::vector<const xAOD::TauJet*> taus_combined;
550 originalTauJetAcc ("originalTauJet");
551 for(const xAOD::TauJet* tau_std : *taus_std){
552 auto replacement_itr = std::find_if(taus_murm_vec.begin(), taus_murm_vec.end(),
553 [&](const xAOD::TauJet* tau_murm){
554 auto link_to_ori_tau = originalTauJetAcc (*tau_murm);
555 if (!link_to_ori_tau.isValid()) { return false; }
556 if (*link_to_ori_tau == tau_std){ return true; }
557 return false;
558 }
559 );
560 if (replacement_itr == taus_murm_vec.end()) { taus_combined.push_back(tau_std); }
561 else {
562 // message = "replacement found at TauJets_MuonRM index " + std::to_string((*replacement_itr)->index()) + " for TauJets index " + std::to_string(tau_std->index());
563 // Info("TauAnalysisTools::getTauJetsWithMuonRM", message.c_str());
564 taus_combined.push_back(*replacement_itr);
565 taus_murm_vec.erase(replacement_itr);
566 // message = std::to_string(taus_murm_vec.size()) + " muon-removal taus left";
567 // Info("TauAnalysisTools::getTauJetsWithMuonRM", message.c_str());
568 }
569 }
570 // Every muon-removal tau should have been used, otherwise there is a problem.
571 assert(taus_murm_vec.empty());
572 return taus_combined;
573}
Scalar deltaR(const MatrixBase< Derived > &vec) const
ATLAS-specific HepMC functions.
static Double_t P(Double_t *tt, Double_t *par)
if(febId1==febId2)
A number of constexpr particle constants to avoid hardcoding them directly in various places.
@ Phi
Definition RPCdef.h:8
@ Eta
Definition RPCdef.h:8
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
Helper class to provide constant type-safe access to aux data.
bool isAvailable(const ELT &e) const
Test to see if this variable exists in the store.
virtual FourMom_t p4() const
The full 4-momentum of the particle.
Definition PFO_v1.cxx:95
double etaFinalCalib() const
const PFO * pi0PFO(size_t i) const
Get the pointer to a given pi0 PFO associated with this tau.
virtual FourMom_t p4() const
The full 4-momentum of the particle.
Definition TauJet_v3.cxx:96
virtual double pt() const
The transverse momentum ( ) of the particle.
size_t nPi0PFOs() const
Get the number of pi0 PFO particles associated with this tau.
const TauTrack * track(size_t i, TauJetParameters::TauTrackFlag flag=TauJetParameters::TauTrackFlag::classifiedCharged, int *container_index=0) const
Get the pointer to a given tauTrack associated with this tau /*container index needed by trackNonCons...
double ptFinalCalib() const
bool panTauDetail(TauJetParameters::PanTauDetails panTauDetail, int &value) const
Get and set values of pantau details variables via enum.
virtual double eta() const
The pseudorapidity ( ) of the particle.
size_t nTracks(TauJetParameters::TauTrackFlag flag=TauJetParameters::TauTrackFlag::classifiedCharged) const
std::vector< const TauTrack * > tracks(TauJetParameters::TauTrackFlag flag=TauJetParameters::TauTrackFlag::classifiedCharged) const
Get the v<const pointer> to a given tauTrack collection associated with this tau.
virtual double eta() const
The pseudorapidity ( ) of the particle.
virtual double pt() const
The transverse momentum ( ) of the particle.
virtual double pt() const override final
The transverse momentum ( ) of the particle.
bool isElectron() const
Whether the particle is an electron (or positron)
virtual double eta() const override final
The pseudorapidity ( ) of the particle.
bool isTau() const
Whether the particle is a tau (or antitau)
bool isMuon() const
Whether the particle is a muon (or antimuon)
static const int PI0
static const int KPLUS
static const int PIPLUS
constexpr double piZeroMassInMeV
the mass of the pi zero (in MeV)
double finalTauEta(const xAOD::TauJet &xTau)
return MVA based tau eta
TruthMatchedParticleType getTruthParticleType(const xAOD::TauJet &xTau)
return TauJet match type
void split(const std::string &sInput, const char cDelim, std::vector< std::string > &vOut)
double finalTauPt(const xAOD::TauJet &xTau)
return MVA based tau pt in GeV
std::vector< const xAOD::TauJet * > combineTauJetsWithMuonRM(const xAOD::TauJetContainer *taus_std, const xAOD::TauJetContainer *taus_muonRM)
combine the standard taujets container with the muon removal container
void correctedPi0Vectors(const xAOD::TauJet *xTau, std::vector< TLorentzVector > &correctedPi0s, TLorentzVector &TauP4)
double finalTauAbsEta(const xAOD::TauJet &xTau)
return MVA based absolute tau eta
void createPi0Vectors(const xAOD::TauJet *xTau, std::vector< TLorentzVector > &vPi0s)
double tauP(const xAOD::TauJet &xTau)
return tau P in GeV
int getNTauDecayParticles(const xAOD::TruthParticle &xTruthTau, int iPdgId, bool bCompareAbsoluteValues)
Count truth matched decay particles of a particular PDGID.
double tauPt(const xAOD::TauJet &xTau)
return tau pt in GeV
double tauEta(const xAOD::TauJet &xTau)
return tau eta
double tauLeadTrackEta(const xAOD::TauJet &xTau)
return leading charge tau track eta
const xAOD::TruthParticle * getTruth(const xAOD::TauJet &xTau)
double tauAbsEta(const xAOD::TauJet &xTau)
return absolute tau eta
double truthTauAbsEta(const xAOD::TauJet &xTau)
return truth match tau eta (if hadronic truth tau match)
double finalTauP(const xAOD::TauJet &xTau)
return MVA based tau P in GeV
bool testFileForEOFContainsCharacters(const std::string &sFileName)
returns true if last line in file is empty or the line starts with the number sign
double truthTauPt(const xAOD::TauJet &xTau)
return truth match tau pt in GeV (if hadronic truth tau match)
double truthDecayMode(const xAOD::TauJet &xTau)
return truth decay mode (if hadronic truth tau match)
xAOD::TauJetParameters::DecayMode getTruthDecayMode(const xAOD::TruthParticle &xTruthTau)
Get the Truth Decay Mode from TruthTau particle.
const xAOD::TruthParticle * getTruthParticle(const xAOD::IParticle *, bool debug=false)
return the truthParticle associated to the given IParticle (if any)
PFO_v1 PFO
Definition of the current "pfo version".
Definition PFO.h:17
TauTrack_v1 TauTrack
Definition of the current version.
Definition TauTrack.h:16
TauJet_v3 TauJet
Definition of the current "tau version".
TruthParticle_v1 TruthParticle
Typedef to implementation.
DiTauJet_v1 DiTauJet
Definition of the current version.
Definition DiTauJet.h:17
TauJetContainer_v3 TauJetContainer
Definition of the current "taujet container version".