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