ATLAS Offline Software
Loading...
Searching...
No Matches
CalcPartonHistory.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4
7
8#ifndef PARTONS_CALCPARTONHISTORY_H
9#define PARTONS_CALCPARTONHISTORY_H
10
11// system include(s):
12#include <memory>
13#include <vector>
14
15// Framework include(s):
17
18#include "AsgTools/AsgTool.h"
24
25namespace CP {
26using ROOT::Math::PtEtaPhiMVector;
27
29
30 public:
31 explicit CalcPartonHistory(
32 const std::string& name,
33 const std::vector<std::string>& truthCollections = {"TruthTop"});
34 virtual ~CalcPartonHistory() {};
35
39
40 void AddToParticleMap(const xAOD::TruthParticle* particle,
41 const std::string& key);
42 bool ExistsInMap(const std::string& key) const;
43 bool ExistsInKey(const std::string& key,
44 const xAOD::TruthParticle* particle) const;
45 bool Retrievep4(const std::string& key, PtEtaPhiMVector& p4);
46 bool Retrievep4(const std::string& key, PtEtaPhiMVector& p4, const int& idx);
47 bool Retrievep4Gamma(PtEtaPhiMVector& p4, int& parentpdgId);
48 bool RetrievepdgId(const std::string& key, std::vector<int>& pdgIds);
49 bool RetrievepdgId(const std::string& key, int& pdgId);
50 bool RetrievepdgId(const std::string& key, int& pdgId, const int& idx);
51 bool RetrieveParticleInfo(const std::string& prefix,
52 std::vector<const xAOD::TruthParticle*>& particles);
53 bool RetrieveParticleInfo(const std::string& prefix,
54 PtEtaPhiMVector& particle, int& pdgId);
55 bool RetrieveParticleInfo(const std::string& prefix,
56 PtEtaPhiMVector& particle, int& pdgId,
57 const int& idx);
58 bool RetrieveParticleInfo(const std::string& prefix,
59 const std::string& alt_prefix,
60 PtEtaPhiMVector& particle, int& pdgId);
61 bool RetrieveParticleInfo(const std::string& prefix,
62 std::vector<PtEtaPhiMVector>& particles,
63 std::vector<int>& pdgIds);
64
79 void InitializeZDecorators(int nZs = 1, bool extend = false);
80 void InitializeWDecorators(int nWs = 1);
81
82 std::string GetParticleType(const xAOD::TruthParticle* particle);
83
84 void TraceParticle(
85 const xAOD::TruthParticle* particle,
86 std::vector<const xAOD::TruthParticle*>& currentPath,
87 std::vector<std::vector<const xAOD::TruthParticle*>>& allPaths);
88 void TraceParticles(const xAOD::TruthParticleContainer* truthParticles);
89
90 bool handleFSR(const xAOD::TruthParticle* particle, const std::string& newKey,
91 std::string& key);
92 bool handleDecay(const xAOD::TruthParticle* particle, std::string& key,
93 int decayID);
94 void handleSameAsParent(const xAOD::TruthParticle* particle,
95 std::string& key);
96 void handleDefault(const xAOD::TruthParticle* particle,
97 const std::string& newKey, std::string& key);
98
99 void FillParticleMap(
100 std::vector<std::vector<const xAOD::TruthParticle*>>& allPaths);
101
102 // Generic history fillers
103 void FillGenericPartonHistory(const std::string& retrievalstring,
104 const std::string& decorationstring,
105 const int idx);
107 const std::vector<std::string>& retrievalStrings,
108 const std::string& decorationstring, const int idx);
110 const std::vector<std::string>& retrievalStrings,
111 const std::string& decorationstring);
112 void FillGenericVectorPartonHistory(const std::string& retrievalstring,
113 const std::string& decorationstring);
114
115 // Specialised history fillers
116 void FillGammaPartonHistory(const std::string& parent);
117 void FillZPartonHistory(const std::string& parent, int nZs = 1,
118 const std::string& mode = "resonant");
119 void FillZtautauPartonHistory(const std::string& parent, int nZs = 1,
120 const std::string& mode = "resonant");
121 void FillWPartonHistory(const std::string& parent, int nWs = 1,
122 const std::string& mode = "resonant");
125 void FillHiggsPartonHistory(const std::string& mode);
127
128 // Helpers for non-resonant / off-shell reconstruction.
129 void setHiggs(const std::string& fsr);
130 void setW(const std::string& fsr, int nWs);
131 bool getW(const std::string& str_lep, const std::string& str_nu,
132 PtEtaPhiMVector& p1, int& pdgId1, PtEtaPhiMVector& p2, int& pdgId2);
133 void setZ(const std::string& fsr, int nZs);
134 void setZtautau(const std::string& fsr, int nZs);
135 bool getZ(const std::string& str_lep1, const std::string& str_lep2,
136 PtEtaPhiMVector& p1, int& pdgId1, PtEtaPhiMVector& p2, int& pdgId2);
137 bool getZFromTaus(const std::string& fsr, PtEtaPhiMVector& Zdecay1,
138 int& Zdecay1_pdgId, PtEtaPhiMVector& Zdecay2,
139 int& Zdecay2_pdgId, PtEtaPhiMVector& Zdecay1_decay1,
140 int& Zdecay1_decay1_pdgId, PtEtaPhiMVector& Zdecay1_decay2,
141 int& Zdecay1_decay2_pdgId, PtEtaPhiMVector& Zdecay1_decay3,
142 int& Zdecay1_decay3_pdgId, PtEtaPhiMVector& Zdecay2_decay1,
143 int& Zdecay2_decay1_pdgId, PtEtaPhiMVector& Zdecay2_decay2,
144 int& Zdecay2_decay2_pdgId, PtEtaPhiMVector& Zdecay2_decay3,
145 int& Zdecay2_decay3_pdgId);
146
149#ifndef XAOD_STANDALONE
150 using AsgTool::configure;
151#endif
152 void configure(const PartonSchemeConfig& config);
153
154 virtual StatusCode initialize() override;
155 virtual StatusCode execute();
156
157 protected:
158 std::map<std::string, std::vector<const xAOD::TruthParticle*>> m_particleMap;
160
161 const std::vector<std::string> m_truthCollections;
162 std::string
164
165 // this method is used to perform the linking of various TRUTH3 particle
166 // containers for Partons to work
167 virtual StatusCode linkTruthContainers(
169
170 // this is the method that runs the actual parton history reconstruction
171 virtual StatusCode runHistorySaver(
172 const xAOD::TruthParticleContainer* truthParticles,
173 const xAOD::EventInfo* ttbarPartonHistory);
174
175 virtual void initializeDecorators();
176
178 bool m_configured = false;
179
189 const std::vector<std::string>& collections,
190 const std::string& out_contName);
191
201 StatusCode linkBosonCollections();
202
206 const xAOD::TruthParticle* part, const std::string& decorationName);
207
208 private:
215 const std::string& collectionToDecorate,
216 const std::string& collectionToLink, const std::string& nameOfDecoration);
217};
218
219} // namespace CP
220
221#endif
An STL vector of pointers that by default owns its pointed-to elements.
bool getZ(const std::string &str_lep1, const std::string &str_lep2, PtEtaPhiMVector &p1, int &pdgId1, PtEtaPhiMVector &p2, int &pdgId2)
StatusCode buildContainerFromMultipleCollections(const std::vector< std::string > &collections, const std::string &out_contName)
used to build container from multiple collections in DAOD_PHYS we don't have the TruthParticles colle...
CalcPartonHistory(const std::string &name, const std::vector< std::string > &truthCollections={"TruthTop"})
void FillGenericVectorPartonHistory(const std::string &retrievalstring, const std::string &decorationstring)
CalcPartonHistory(CalcPartonHistory &&rhs)=delete
CalcPartonHistory & operator=(const CalcPartonHistory &rhs)=delete
bool ExistsInKey(const std::string &key, const xAOD::TruthParticle *particle) const
void configure(const PartonSchemeConfig &config)
const xAOD::TruthParticle * getTruthParticleLinkedFromDecoration(const xAOD::TruthParticle *part, const std::string &decorationName)
helper method to handle retriveing the truth particle linked in the decoration of another particle
virtual StatusCode runHistorySaver(const xAOD::TruthParticleContainer *truthParticles, const xAOD::EventInfo *ttbarPartonHistory)
void FillParticleMap(std::vector< std::vector< const xAOD::TruthParticle * > > &allPaths)
bool Retrievep4Gamma(PtEtaPhiMVector &p4, int &parentpdgId)
bool RetrieveParticleInfo(const std::string &prefix, std::vector< const xAOD::TruthParticle * > &particles)
const std::vector< std::string > m_truthCollections
void FillHiggsPartonHistory(const std::string &mode)
std::map< std::string, std::vector< const xAOD::TruthParticle * > > m_particleMap
virtual StatusCode linkTruthContainers(const xAOD::TruthParticleContainer *&tp)
void FillWPartonHistory(const std::string &parent, int nWs=1, const std::string &mode="resonant")
std::string GetParticleType(const xAOD::TruthParticle *particle)
bool Retrievep4(const std::string &key, PtEtaPhiMVector &p4)
bool getW(const std::string &str_lep, const std::string &str_nu, PtEtaPhiMVector &p1, int &pdgId1, PtEtaPhiMVector &p2, int &pdgId2)
std::string m_prefix
prefix applied to all decorator and m_particleMap names
CalcPartonHistory(const CalcPartonHistory &rhs)=delete
void FillGammaPartonHistory(const std::string &parent)
void setZ(const std::string &fsr, int nZs)
void setW(const std::string &fsr, int nWs)
bool ExistsInMap(const std::string &key) const
void InitializeZDecorators(int nZs=1, bool extend=false)
void FillZtautauPartonHistory(const std::string &parent, int nZs=1, const std::string &mode="resonant")
bool RetrievepdgId(const std::string &key, std::vector< int > &pdgIds)
bool handleDecay(const xAOD::TruthParticle *particle, std::string &key, int decayID)
bool m_configured
true after configure() has been called
void FillZPartonHistory(const std::string &parent, int nZs=1, const std::string &mode="resonant")
void TraceParticle(const xAOD::TruthParticle *particle, std::vector< const xAOD::TruthParticle * > &currentPath, std::vector< std::vector< const xAOD::TruthParticle * > > &allPaths)
void handleDefault(const xAOD::TruthParticle *particle, const std::string &newKey, std::string &key)
virtual void initializeDecorators()
virtual StatusCode execute()
void TraceParticles(const xAOD::TruthParticleContainer *truthParticles)
StatusCode linkBosonCollections()
currently in DAOD_PHYS TruthTop have links to Ws from the TruthBoson collection, which have no link t...
void FillGenericPartonHistory(const std::string &retrievalstring, const std::string &decorationstring, const int idx)
StatusCode decorateCollectionWithLinksToAnotherCollection(const std::string &collectionToDecorate, const std::string &collectionToLink, const std::string &nameOfDecoration)
helper method currently used in DAOD_PHYS to link particles from a given collection to the same parti...
bool handleFSR(const xAOD::TruthParticle *particle, const std::string &newKey, std::string &key)
void handleSameAsParent(const xAOD::TruthParticle *particle, std::string &key)
void setZtautau(const std::string &fsr, int nZs)
PartonSchemeConfig m_config
scheme configuration set via configure()
bool getZFromTaus(const std::string &fsr, PtEtaPhiMVector &Zdecay1, int &Zdecay1_pdgId, PtEtaPhiMVector &Zdecay2, int &Zdecay2_pdgId, PtEtaPhiMVector &Zdecay1_decay1, int &Zdecay1_decay1_pdgId, PtEtaPhiMVector &Zdecay1_decay2, int &Zdecay1_decay2_pdgId, PtEtaPhiMVector &Zdecay1_decay3, int &Zdecay1_decay3_pdgId, PtEtaPhiMVector &Zdecay2_decay1, int &Zdecay2_decay1_pdgId, PtEtaPhiMVector &Zdecay2_decay2, int &Zdecay2_decay2_pdgId, PtEtaPhiMVector &Zdecay2_decay3, int &Zdecay2_decay3_pdgId)
void AddToParticleMap(const xAOD::TruthParticle *particle, const std::string &key)
virtual StatusCode initialize() override
Dummy implementation of the initialisation function.
void setHiggs(const std::string &fsr)
Base class for the dual-use tool implementation classes.
Definition AsgTool.h:47
Select isolated Photons, Electrons and Muons.
EventInfo_v1 EventInfo
Definition of the latest event info version.
TruthParticle_v1 TruthParticle
Typedef to implementation.
TruthParticleContainer_v1 TruthParticleContainer
Declare the latest version of the truth particle container.
Top-level configuration for a named parton history scheme.
Struct to manage and apply decorators to the EventInfo object.