CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
reco::tau::RecoTauPiZeroStripPlugin Class Reference
Inheritance diagram for reco::tau::RecoTauPiZeroStripPlugin:
reco::tau::RecoTauPiZeroBuilderPlugin reco::tau::RecoTauEventHolderPlugin reco::tau::RecoTauNamedPlugin

Public Member Functions

void beginEvent () override
 Hook called at the beginning of the event. More...
 
return_type operator() (const reco::Jet &jet) const override
 Build a collection of piZeros from objects in the input jet. More...
 
 RecoTauPiZeroStripPlugin (const edm::ParameterSet &pset, edm::ConsumesCollector &&iC)
 
 ~RecoTauPiZeroStripPlugin () override
 
- Public Member Functions inherited from reco::tau::RecoTauPiZeroBuilderPlugin
 RecoTauPiZeroBuilderPlugin (const edm::ParameterSet &pset, edm::ConsumesCollector &&iC)
 
 ~RecoTauPiZeroBuilderPlugin () override
 
- Public Member Functions inherited from reco::tau::RecoTauEventHolderPlugin
edm::Eventevt ()
 
const edm::Eventevt () const
 
const edm::EventSetupevtSetup () const
 
 RecoTauEventHolderPlugin (const edm::ParameterSet &pset)
 
void setup (edm::Event &, const edm::EventSetup &)
 
 ~RecoTauEventHolderPlugin () override
 
- Public Member Functions inherited from reco::tau::RecoTauNamedPlugin
const std::string & name () const
 
 RecoTauNamedPlugin (const edm::ParameterSet &pset)
 
virtual ~RecoTauNamedPlugin ()
 

Private Attributes

double combinatoricStripMassHypo_
 
bool combineStrips_
 
double etaAssociationDistance_
 
std::vector< int > inputParticleIds_
 
int maxStrips_
 
AddFourMomenta p4Builder_
 
double phiAssociationDistance_
 
std::unique_ptr< RecoTauQualityCutsqcuts_
 
RecoTauVertexAssociator vertexAssociator_
 

Additional Inherited Members

- Public Types inherited from reco::tau::RecoTauPiZeroBuilderPlugin
typedef boost::ptr_vector< RecoTauPiZeroPiZeroVector
 
typedef std::unique_ptr< PiZeroVectorreturn_type
 

Detailed Description

Definition at line 43 of file RecoTauPiZeroStripPlugin.cc.

Constructor & Destructor Documentation

◆ RecoTauPiZeroStripPlugin()

reco::tau::RecoTauPiZeroStripPlugin::RecoTauPiZeroStripPlugin ( const edm::ParameterSet pset,
edm::ConsumesCollector &&  iC 
)
explicit

Definition at line 68 of file RecoTauPiZeroStripPlugin.cc.

70  qcuts_(new RecoTauQualityCuts(pset.getParameterSet("qualityCuts").getParameterSet("signalQualityCuts"))),
71  vertexAssociator_(pset.getParameter<edm::ParameterSet>("qualityCuts"), std::move(iC)) {
72  inputParticleIds_ = pset.getParameter<std::vector<int> >("stripCandidatesParticleIds");
73  etaAssociationDistance_ = pset.getParameter<double>("stripEtaAssociationDistance");
74  phiAssociationDistance_ = pset.getParameter<double>("stripPhiAssociationDistance");
75  combineStrips_ = pset.getParameter<bool>("makeCombinatoricStrips");
76  if (combineStrips_) {
77  maxStrips_ = pset.getParameter<int>("maxInputStrips");
78  combinatoricStripMassHypo_ = pset.getParameter<double>("stripMassWhenCombining");
79  }
80  }

References combinatoricStripMassHypo_, combineStrips_, etaAssociationDistance_, inputParticleIds_, maxStrips_, phiAssociationDistance_, and muonDTDigis_cfi::pset.

◆ ~RecoTauPiZeroStripPlugin()

reco::tau::RecoTauPiZeroStripPlugin::~RecoTauPiZeroStripPlugin ( )
inlineoverride

Definition at line 46 of file RecoTauPiZeroStripPlugin.cc.

46 {}

Member Function Documentation

◆ beginEvent()

void reco::tau::RecoTauPiZeroStripPlugin::beginEvent ( )
overridevirtual

◆ operator()()

RecoTauPiZeroStripPlugin::return_type reco::tau::RecoTauPiZeroStripPlugin::operator() ( const reco::Jet ) const
overridevirtual

Build a collection of piZeros from objects in the input jet.

Implements reco::tau::RecoTauPiZeroBuilderPlugin.

Definition at line 85 of file RecoTauPiZeroStripPlugin.cc.

85  {
86  // Get list of gamma candidates
87  typedef std::vector<reco::CandidatePtr> CandPtrs;
88  typedef CandPtrs::iterator CandIter;
90 
91  // Get the candidates passing our quality cuts
93  CandPtrs candsVector = qcuts_->filterCandRefs(pfCandidates(jet, inputParticleIds_));
94  //PFCandPtrs candsVector = qcuts_->filterCandRefs(pfGammas(jet));
95 
96  // Convert to stl::list to allow fast deletions
97  typedef std::list<reco::CandidatePtr> CandPtrList;
98  typedef std::list<reco::CandidatePtr>::iterator CandPtrListIter;
99  CandPtrList cands;
100  cands.insert(cands.end(), candsVector.begin(), candsVector.end());
101 
102  while (!cands.empty()) {
103  // Seed this new strip, and delete it from future strips
104  CandidatePtr seed = cands.front();
105  cands.pop_front();
106 
107  // Add a new candidate to our collection using this seed
108  std::unique_ptr<RecoTauPiZero> strip(new RecoTauPiZero(*seed, RecoTauPiZero::kStrips));
109  strip->addDaughter(seed);
110 
111  // Find all other objects in the strip
112  CandPtrListIter stripCand = cands.begin();
113  while (stripCand != cands.end()) {
114  if (fabs(strip->eta() - (*stripCand)->eta()) < etaAssociationDistance_ &&
115  fabs(deltaPhi(*strip, **stripCand)) < phiAssociationDistance_) {
116  // Add candidate to strip
117  strip->addDaughter(*stripCand);
118  // Update the strips four momenta
119  p4Builder_.set(*strip);
120  // Delete this candidate from future strips and move on to
121  // the next potential candidate
122  stripCand = cands.erase(stripCand);
123  } else {
124  // This candidate isn't compatabile - just move to the next candidate
125  ++stripCand;
126  }
127  }
128  // Update the vertex
129  if (strip->daughterPtr(0).isNonnull())
130  strip->setVertex(strip->daughterPtr(0)->vertex());
131  output.push_back(strip.get());
132  }
133 
134  // Check if we want to combine our strips
135  if (combineStrips_ && output.size() > 1) {
136  PiZeroVector stripCombinations;
137  // Sort the output by descending pt
138  output.sort(output.begin(), output.end(), [&](auto& arg1, auto& arg2) { return arg1.pt() > arg2.pt(); });
139  // Get the end of interesting set of strips to try and combine
140  PiZeroVector::const_iterator end_iter = takeNElements(output.begin(), output.end(), maxStrips_);
141 
142  // Look at all the combinations
143  for (PiZeroVector::const_iterator first = output.begin(); first != end_iter - 1; ++first) {
144  for (PiZeroVector::const_iterator second = first + 1; second != end_iter; ++second) {
145  Candidate::LorentzVector firstP4 = first->p4();
146  Candidate::LorentzVector secondP4 = second->p4();
147  // If we assume a certain mass for each strip apply it here.
148  firstP4 = applyMassConstraint(firstP4, combinatoricStripMassHypo_);
149  secondP4 = applyMassConstraint(secondP4, combinatoricStripMassHypo_);
150  Candidate::LorentzVector totalP4 = firstP4 + secondP4;
151  // Make our new combined strip
152  std::unique_ptr<RecoTauPiZero> combinedStrips(
153  new RecoTauPiZero(0,
154  totalP4,
155  Candidate::Point(0, 0, 0),
156  //111, 10001, true, RecoTauPiZero::kCombinatoricStrips));
157  111,
158  10001,
159  true,
161 
162  // Now loop over the strip members
163  for (auto const& gamma : first->daughterPtrVector()) {
164  combinedStrips->addDaughter(gamma);
165  }
166  for (auto const& gamma : second->daughterPtrVector()) {
167  combinedStrips->addDaughter(gamma);
168  }
169  // Update the vertex
170  if (combinedStrips->daughterPtr(0).isNonnull())
171  combinedStrips->setVertex(combinedStrips->daughterPtr(0)->vertex());
172  // Add to our collection of combined strips
173  stripCombinations.push_back(combinedStrips.get());
174  }
175  }
176  // When done doing all the combinations, add the combined strips to the
177  // output.
178  output.transfer(output.end(), stripCombinations);
179  }
180 
181  return output.release();
182  }

References reco::tau::RecoTauVertexAssociator::associatedVertex(), HLT_FULL_cff::cands, combinatoricStripMassHypo_, combineStrips_, reco::deltaPhi(), etaAssociationDistance_, first, CustomPhysics_cfi::gamma, inputParticleIds_, metsig::jet, reco::RecoTauPiZero::kStrips, reco::RecoTauPiZero::kUndefined, maxStrips_, convertSQLitetoXML_cfg::output, p4Builder_, reco::tau::pfCandidates(), phiAssociationDistance_, qcuts_, edm::second(), fileCollector::seed, AddFourMomenta::set(), digitizers_cfi::strip, reco::tau::takeNElements(), and vertexAssociator_.

Member Data Documentation

◆ combinatoricStripMassHypo_

double reco::tau::RecoTauPiZeroStripPlugin::combinatoricStripMassHypo_
private

Definition at line 63 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ combineStrips_

bool reco::tau::RecoTauPiZeroStripPlugin::combineStrips_
private

Definition at line 61 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ etaAssociationDistance_

double reco::tau::RecoTauPiZeroStripPlugin::etaAssociationDistance_
private

Definition at line 57 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ inputParticleIds_

std::vector<int> reco::tau::RecoTauPiZeroStripPlugin::inputParticleIds_
private

Definition at line 56 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ maxStrips_

int reco::tau::RecoTauPiZeroStripPlugin::maxStrips_
private

Definition at line 62 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ p4Builder_

AddFourMomenta reco::tau::RecoTauPiZeroStripPlugin::p4Builder_
private

Definition at line 65 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()().

◆ phiAssociationDistance_

double reco::tau::RecoTauPiZeroStripPlugin::phiAssociationDistance_
private

Definition at line 58 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()(), and RecoTauPiZeroStripPlugin().

◆ qcuts_

std::unique_ptr<RecoTauQualityCuts> reco::tau::RecoTauPiZeroStripPlugin::qcuts_
private

Definition at line 53 of file RecoTauPiZeroStripPlugin.cc.

Referenced by operator()().

◆ vertexAssociator_

RecoTauVertexAssociator reco::tau::RecoTauPiZeroStripPlugin::vertexAssociator_
private

Definition at line 54 of file RecoTauPiZeroStripPlugin.cc.

Referenced by beginEvent(), and operator()().

reco::tau::RecoTauEventHolderPlugin::evt
const edm::Event * evt() const
Definition: RecoTauPluginsCommon.cc:16
reco::tau::RecoTauPiZeroStripPlugin::combineStrips_
bool combineStrips_
Definition: RecoTauPiZeroStripPlugin.cc:61
reco::tau::RecoTauPiZeroStripPlugin::phiAssociationDistance_
double phiAssociationDistance_
Definition: RecoTauPiZeroStripPlugin.cc:58
convertSQLitetoXML_cfg.output
output
Definition: convertSQLitetoXML_cfg.py:72
reco::deltaPhi
constexpr double deltaPhi(double phi1, double phi2)
Definition: deltaPhi.h:26
digitizers_cfi.strip
strip
Definition: digitizers_cfi.py:19
CustomPhysics_cfi.gamma
gamma
Definition: CustomPhysics_cfi.py:17
edm::second
U second(std::pair< T, U > const &p)
Definition: ParameterSet.cc:222
reco::tau::RecoTauPiZeroStripPlugin::maxStrips_
int maxStrips_
Definition: RecoTauPiZeroStripPlugin.cc:62
fileCollector.seed
seed
Definition: fileCollector.py:127
reco::RecoTauPiZero::kUndefined
Definition: RecoTauPiZero.h:11
reco::tau::RecoTauPiZeroBuilderPlugin::RecoTauPiZeroBuilderPlugin
RecoTauPiZeroBuilderPlugin(const edm::ParameterSet &pset, edm::ConsumesCollector &&iC)
Definition: RecoTauPiZeroPlugins.h:40
reco::tau::RecoTauPiZeroStripPlugin::etaAssociationDistance_
double etaAssociationDistance_
Definition: RecoTauPiZeroStripPlugin.cc:57
reco::tau::RecoTauPiZeroStripPlugin::p4Builder_
AddFourMomenta p4Builder_
Definition: RecoTauPiZeroStripPlugin.cc:65
reco::tau::RecoTauPiZeroStripPlugin::qcuts_
std::unique_ptr< RecoTauQualityCuts > qcuts_
Definition: RecoTauPiZeroStripPlugin.cc:53
reco::tau::RecoTauPiZeroStripPlugin::vertexAssociator_
RecoTauVertexAssociator vertexAssociator_
Definition: RecoTauPiZeroStripPlugin.cc:54
first
auto first
Definition: CAHitNtupletGeneratorKernelsImpl.h:112
reco::tau::RecoTauPiZeroBuilderPlugin::PiZeroVector
boost::ptr_vector< RecoTauPiZero > PiZeroVector
Definition: RecoTauPiZeroPlugins.h:36
HLT_FULL_cff.cands
cands
Definition: HLT_FULL_cff.py:15146
reco::tau::RecoTauVertexAssociator::associatedVertex
reco::VertexRef associatedVertex(const Jet &jet) const
Definition: RecoTauVertexAssociator.cc:378
edm::ParameterSet
Definition: ParameterSet.h:47
CandPtrs
std::vector< reco::CandidatePtr > CandPtrs
Definition: RecoTauCommonUtilities.cc:13
reco::tau::RecoTauVertexAssociator::setEvent
void setEvent(const edm::Event &evt)
Load the vertices from the event.
Definition: RecoTauVertexAssociator.cc:242
reco::tau::takeNElements
InputIterator takeNElements(const InputIterator &begin, const InputIterator &end, size_t N)
Definition: RecoTauCommonUtilities.h:104
eostools.move
def move(src, dest)
Definition: eostools.py:511
reco::tau::RecoTauPiZeroStripPlugin::combinatoricStripMassHypo_
double combinatoricStripMassHypo_
Definition: RecoTauPiZeroStripPlugin.cc:63
metsig::jet
Definition: SignAlgoResolutions.h:47
AddFourMomenta::set
void set(reco::Candidate &c) const
set up a candidate
Definition: AddFourMomenta.cc:6
reco::CandidatePtr
edm::Ptr< Candidate > CandidatePtr
persistent reference to an object in a collection of Candidate objects
Definition: CandidateFwd.h:25
reco::tau::pfCandidates
std::vector< CandidatePtr > pfCandidates(const Jet &jet, int particleId, bool sort=true)
Definition: RecoTauCommonUtilities.cc:59
CandIter
CandPtrs::iterator CandIter
Definition: RecoTauCommonUtilities.cc:14
reco::Candidate::LorentzVector
math::XYZTLorentzVector LorentzVector
Lorentz vector.
Definition: Candidate.h:36
reco::Candidate::Point
math::XYZPoint Point
point in the space
Definition: Candidate.h:40
reco::tau::RecoTauPiZeroStripPlugin::inputParticleIds_
std::vector< int > inputParticleIds_
Definition: RecoTauPiZeroStripPlugin.cc:56
muonDTDigis_cfi.pset
pset
Definition: muonDTDigis_cfi.py:27
reco::RecoTauPiZero::kStrips
Definition: RecoTauPiZero.h:14