8#ifndef PARTONS_CALCPARTONHISTORY_H
9#define PARTONS_CALCPARTONHISTORY_H
26using ROOT::Math::PtEtaPhiMVector;
32 const std::string&
name,
33 const std::vector<std::string>& truthCollections = {
"TruthTop"});
41 const std::string& key);
45 bool Retrievep4(
const std::string& key, PtEtaPhiMVector& p4);
46 bool Retrievep4(
const std::string& key, PtEtaPhiMVector& p4,
const int& idx);
48 bool RetrievepdgId(
const std::string& key, std::vector<int>& pdgIds);
50 bool RetrievepdgId(
const std::string& key,
int& pdgId,
const int& idx);
52 std::vector<const xAOD::TruthParticle*>& particles);
54 PtEtaPhiMVector& particle,
int& pdgId);
56 PtEtaPhiMVector& particle,
int& pdgId,
59 const std::string& alt_prefix,
60 PtEtaPhiMVector& particle,
int& pdgId);
62 std::vector<PtEtaPhiMVector>& particles,
63 std::vector<int>& pdgIds);
86 std::vector<const xAOD::TruthParticle*>& currentPath,
87 std::vector<std::vector<const xAOD::TruthParticle*>>& allPaths);
97 const std::string& newKey, std::string& key);
100 std::vector<std::vector<const xAOD::TruthParticle*>>& allPaths);
104 const std::string& decorationstring,
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);
113 const std::string& decorationstring);
118 const std::string& mode =
"resonant");
120 const std::string& mode =
"resonant");
122 const std::string& mode =
"resonant");
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);
149#ifndef XAOD_STANDALONE
150 using AsgTool::configure;
158 std::map<std::string, std::vector<const xAOD::TruthParticle*>>
m_particleMap;
189 const std::vector<std::string>& collections,
190 const std::string& out_contName);
215 const std::string& collectionToDecorate,
216 const std::string& collectionToLink,
const std::string& nameOfDecoration);
An STL vector of pointers that by default owns its pointed-to elements.
void InitializeVectorAntiCharmDecorators()
bool getZ(const std::string &str_lep1, const std::string &str_lep2, PtEtaPhiMVector &p1, int &pdgId1, PtEtaPhiMVector &p2, int &pdgId2)
void InitializeVectorCharmDecorators()
void InitializeAntiCharmDecorators()
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)
void InitializeVectorAntiBottomDecorators()
CalcPartonHistory(CalcPartonHistory &&rhs)=delete
CalcPartonHistory & operator=(const CalcPartonHistory &rhs)=delete
void Initialize4TopDecorators()
void InitializeVectorBottomDecorators()
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
void InitializeAntiTopDecorators()
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 FillAntiTopPartonHistory()
void InitializeBottomDecorators()
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)
void FillTopPartonHistory()
void InitializePhotonDecorators()
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)
virtual ~CalcPartonHistory()
std::string m_prefix
prefix applied to all decorator and m_particleMap names
CalcPartonHistory(const CalcPartonHistory &rhs)=delete
void FillTtbarPartonHistory()
void InitializeCharmDecorators()
void FillGammaPartonHistory(const std::string &parent)
void setZ(const std::string &fsr, int nZs)
void setW(const std::string &fsr, int nWs)
void InitializeTtbarDecorators()
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 InitializeAntiBottomDecorators()
void TraceParticle(const xAOD::TruthParticle *particle, std::vector< const xAOD::TruthParticle * > ¤tPath, 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)
void InitializeHiggsDecorators()
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 InitializeWDecorators(int nWs=1)
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)
void InitializeTopDecorators()
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.