CMS 3D CMS Logo

cloneDecayTree.cc
Go to the documentation of this file.
3 using namespace std;
4 using namespace reco;
5 
6 unique_ptr<Candidate> cloneDecayTree(const Candidate &c) {
7  size_t n = c.numberOfDaughters();
8  if (n == 1)
9  return unique_ptr<Candidate>(c.clone());
10  // pass a particle, not a candidate, to avoid cloning daughters
11  const Candidate &p = c;
12  auto cmp = std::make_unique<CompositeCandidate>(p);
13  for (size_t i = 0; i < n; ++i)
14  cmp->addDaughter(cloneDecayTree(*c.daughter(i)));
15  return cmp;
16 }
unique_ptr< Candidate > cloneDecayTree(const Candidate &c)
fixed size matrix