CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Private Types | Private Attributes
PFRecoTauDiscriminationByHPSSelection Class Reference
Inheritance diagram for PFRecoTauDiscriminationByHPSSelection:
TauDiscriminationProducerBase< TauType, TauDiscriminator > edm::stream::EDProducer<> edm::stream::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Classes

struct  DecayModeCuts
 

Public Member Functions

double discriminate (const reco::PFTauRef &) const override
 
 PFRecoTauDiscriminationByHPSSelection (const edm::ParameterSet &)
 
 ~PFRecoTauDiscriminationByHPSSelection ()
 
- Public Member Functions inherited from TauDiscriminationProducerBase< TauType, TauDiscriminator >
virtual void beginEvent (const edm::Event &evt, const edm::EventSetup &evtSetup)
 
virtual double discriminate (const TauRef &tau) const =0
 
virtual void endEvent (edm::Event &evt)
 
void produce (edm::Event &, const edm::EventSetup &)
 
 TauDiscriminationProducerBase (const edm::ParameterSet &iConfig)
 
 TauDiscriminationProducerBase ()
 
virtual ~TauDiscriminationProducerBase ()
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
- Public Member Functions inherited from edm::stream::EDProducerBase
 EDProducerBase ()
 
ModuleDescription const & moduleDescription () const
 
virtual ~EDProducerBase ()
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, std::unordered_multimap< std::string, edm::ProductResolverIndex > const &iIndicies, std::string const &moduleLabel)
 
virtual ~ProducerBase () noexcept(false)
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
virtual ~EDConsumerBase () noexcept(false)
 

Private Types

typedef std::map< IntPair, DecayModeCutsDecayModeCutMap
 
typedef std::pair< double, double > DoublePair
 
typedef std::pair< unsigned int, unsigned int > IntPair
 
typedef StringObjectFunction< reco::PFTauTauFunc
 

Private Attributes

DecayModeCutMap decayModeCuts_
 
double matchingCone_
 
int minPixelHits_
 
double minPt_
 
bool requireTauChargedHadronsToBeChargedPFCands_
 
int verbosity_
 

Additional Inherited Members

- Public Types inherited from TauDiscriminationProducerBase< TauType, TauDiscriminator >
typedef std::vector< TauType > TauCollection
 
typedef edm::Ref< TauCollectionTauRef
 
typedef edm::RefProd< TauCollectionTauRefProd
 
- Public Types inherited from edm::stream::EDProducer<>
typedef CacheContexts< T... > CacheTypes
 
typedef CacheTypes::GlobalCache GlobalCache
 
typedef AbilityChecker< T... > HasAbility
 
typedef CacheTypes::LuminosityBlockCache LuminosityBlockCache
 
typedef LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCacheLuminosityBlockContext
 
typedef CacheTypes::LuminosityBlockSummaryCache LuminosityBlockSummaryCache
 
typedef CacheTypes::RunCache RunCache
 
typedef RunContextT< RunCache, GlobalCacheRunContext
 
typedef CacheTypes::RunSummaryCache RunSummaryCache
 
- Public Types inherited from edm::stream::EDProducerBase
typedef EDProducerAdaptorBase ModuleType
 
- Public Types inherited from edm::ProducerBase
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::stream::EDProducerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
- Protected Attributes inherited from TauDiscriminationProducerBase< TauType, TauDiscriminator >
std::string moduleLabel_
 
double prediscriminantFailValue_
 
edm::EDGetTokenT< TauCollectionTau_token
 
size_t tauIndex_
 
edm::InputTag TauProducer_
 

Detailed Description

Definition at line 21 of file PFRecoTauDiscriminationByHPSSelection.cc.

Member Typedef Documentation

Definition at line 51 of file PFRecoTauDiscriminationByHPSSelection.cc.

typedef std::pair<double, double> PFRecoTauDiscriminationByHPSSelection::DoublePair
private

Definition at line 50 of file PFRecoTauDiscriminationByHPSSelection.cc.

typedef std::pair<unsigned int, unsigned int> PFRecoTauDiscriminationByHPSSelection::IntPair
private

Definition at line 49 of file PFRecoTauDiscriminationByHPSSelection.cc.

Definition at line 29 of file PFRecoTauDiscriminationByHPSSelection.cc.

Constructor & Destructor Documentation

PFRecoTauDiscriminationByHPSSelection::PFRecoTauDiscriminationByHPSSelection ( const edm::ParameterSet pset)
explicit

Definition at line 64 of file PFRecoTauDiscriminationByHPSSelection.cc.

References PFRecoTauDiscriminationByHPSSelection_cfi::applyBendCorrection, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_eta_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_mass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_phi_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::assumeStripMass_, particleFlowClusterECALTimeSelected_cfi::cuts, mvaPFMET_leptons_cfi::decayMode, decayModeCuts_, tauJetCorrFactors_cfi::decayModes, edm::ParameterSet::exists(), edm::ParameterSet::getParameter(), matchingCone_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::maxMass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::maxPi0Mass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::minMass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::minPi0Mass_, minPixelHits_, minPt_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::nChargedPFCandsMin_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::nTracksMin_, requireTauChargedHadronsToBeChargedPFCands_, AlCaHLTBitMon_QueryRunRegistry::string, verbosity_, and HistogramManager_cfi::VPSet().

66 {
67  // Get the matchign cut
68  matchingCone_ = pset.getParameter<double>("matchingCone");
69  minPt_ = pset.getParameter<double>("minTauPt");
70  // Get the mass cuts for each decay mode
71  typedef std::vector<edm::ParameterSet> VPSet;
72  const VPSet& decayModes = pset.getParameter<VPSet>("decayModes");
73  BOOST_FOREACH( const edm::ParameterSet &decayMode, decayModes ) {
74  // The mass window(s)
75  DecayModeCuts cuts;
76  if ( decayMode.exists("nTracksMin") ) {
77  cuts.nTracksMin_ = decayMode.getParameter<unsigned>("nTracksMin");
78  } else {
79  cuts.nTracksMin_ = 0;
80  }
81  if ( decayMode.exists("nChargedPFCandsMin") ) {
82  cuts.nChargedPFCandsMin_ = decayMode.getParameter<unsigned>("nChargedPFCandsMin");
83  } else {
84  cuts.nChargedPFCandsMin_ = 0;
85  }
86  cuts.minMass_ = decayMode.getParameter<double>("minMass");
87  cuts.maxMass_ = new TauFunc(decayMode.getParameter<std::string>("maxMass"));
88  edm::ParameterSet applyBendCorrection = decayMode.getParameter<edm::ParameterSet>("applyBendCorrection");
89  cuts.applyBendCorrection_eta_ = applyBendCorrection.getParameter<bool>("eta");
90  cuts.applyBendCorrection_phi_ = applyBendCorrection.getParameter<bool>("phi");
91  cuts.applyBendCorrection_mass_ = applyBendCorrection.getParameter<bool>("mass");
92  if ( decayMode.exists("minPi0Mass") ) {
93  cuts.minPi0Mass_ = decayMode.getParameter<double>("minPi0Mass");
94  cuts.maxPi0Mass_ = decayMode.getParameter<double>("maxPi0Mass");
95  } else {
96  cuts.minPi0Mass_ = -1.e3;
97  cuts.maxPi0Mass_ = 1.e9;
98  }
99  if ( decayMode.exists("assumeStripMass") ) {
100  cuts.assumeStripMass_ = decayMode.getParameter<double>("assumeStripMass");
101  } else {
102  cuts.assumeStripMass_ = -1.0;
103  }
104  decayModeCuts_.insert(std::make_pair(
105  // The decay mode as a key
106  std::make_pair(
107  decayMode.getParameter<uint32_t>("nCharged"),
108  decayMode.getParameter<uint32_t>("nPiZeros")),
109  cuts
110  ));
111  }
112  requireTauChargedHadronsToBeChargedPFCands_ = pset.getParameter<bool>("requireTauChargedHadronsToBeChargedPFCands");
113  minPixelHits_ = pset.getParameter<int>("minPixelHits");
114  verbosity_ = pset.exists("verbosity") ?
115  pset.getParameter<int>("verbosity") : 0;
116 
117 
118 }
T getParameter(std::string const &) const
bool exists(std::string const &parameterName) const
checks if a parameter exists
TauDiscriminationProducerBase< reco::PFTau, reco::PFTauDiscriminator > PFTauDiscriminationProducerBase
PFRecoTauDiscriminationByHPSSelection::~PFRecoTauDiscriminationByHPSSelection ( )

Definition at line 120 of file PFRecoTauDiscriminationByHPSSelection.cc.

References decayModeCuts_.

121 {
122  for ( DecayModeCutMap::iterator it = decayModeCuts_.begin();
123  it != decayModeCuts_.end(); ++it ) {
124  delete it->second.maxMass_;
125  }
126 }

Member Function Documentation

double PFRecoTauDiscriminationByHPSSelection::discriminate ( const reco::PFTauRef tau) const
override

Definition at line 129 of file PFRecoTauDiscriminationByHPSSelection.cc.

References funct::abs(), reco::PFRecoTauChargedHadron::algo(), PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_eta_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_mass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::applyBendCorrection_phi_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::assumeStripMass_, reco::RecoTauPiZero::bendCorrEta(), reco::RecoTauPiZero::bendCorrPhi(), muons2muons_cfi::chargedHadron, decayModeCuts_, DEFINE_FWK_MODULE, reco::deltaPhi(), deltaR(), reco::LeafCandidate::eta(), reco::TrackBase::hitPattern(), reco::PFRecoTauChargedHadron::kChargedPFCandidate, reco::PFRecoTauChargedHadron::kPFNeutralHadron, reco::PFRecoTauChargedHadron::kTrack, matchingCone_, hpstanc_transforms::max, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::maxMass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::maxPi0Mass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::minMass_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::minPi0Mass_, minPixelHits_, minPt_, PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::nChargedPFCandsMin_, nTracks(), PFRecoTauDiscriminationByHPSSelection::DecayModeCuts::nTracksMin_, reco::HitPattern::numberOfValidPixelHits(), reco::LeafCandidate::p4(), reco::LeafCandidate::phi(), requireTauChargedHadronsToBeChargedPFCands_, AlCaHLTBitMon_QueryRunRegistry::string, HiIsolationCommonParameters_cff::track, and verbosity_.

130 {
131  if ( verbosity_ ) {
132  edm::LogPrint("PFTauByHPSSelect") << "<PFRecoTauDiscriminationByHPSSelection::discriminate>:" ;
133  edm::LogPrint("PFTauByHPSSelect") << " nCharged = " << tau->signalTauChargedHadronCandidates().size() ;
134  edm::LogPrint("PFTauByHPSSelect") << " nPiZeros = " << tau->signalPiZeroCandidates().size() ;
135  }
136 
137  // Check if we pass the min pt
138  if ( tau->pt() < minPt_ ) {
139  if ( verbosity_ ) {
140  edm::LogPrint("PFTauByHPSSelect") << " fails minPt cut." ;
141  }
142  return 0.0;
143  }
144 
145  // See if we select this decay mode
146  DecayModeCutMap::const_iterator massWindowIter =
147  decayModeCuts_.find(std::make_pair(tau->signalTauChargedHadronCandidates().size(),
148  tau->signalPiZeroCandidates().size()));
149  // Check if decay mode is supported
150  if ( massWindowIter == decayModeCuts_.end() ) {
151  if ( verbosity_ ) {
152  edm::LogPrint("PFTauByHPSSelect") << " fails mass-window definition requirement." ;
153  }
154  return 0.0;
155  }
156  const DecayModeCuts& massWindow = massWindowIter->second;
157 
158  if ( massWindow.nTracksMin_ > 0 ) {
159  unsigned int nTracks = 0;
160  const std::vector<reco::PFRecoTauChargedHadron>& chargedHadrons = tau->signalTauChargedHadronCandidates();
161  for ( std::vector<reco::PFRecoTauChargedHadron>::const_iterator chargedHadron = chargedHadrons.begin();
162  chargedHadron != chargedHadrons.end(); ++chargedHadron ) {
164  ++nTracks;
165  }
166  }
167  if ( verbosity_ ) {
168  edm::LogPrint("PFTauByHPSSelect") << "nTracks = " << nTracks << " (min = " << massWindow.nTracksMin_ << ")" ;
169  }
170  if ( nTracks < massWindow.nTracksMin_ ) {
171  if ( verbosity_ ) {
172  edm::LogPrint("PFTauByHPSSelect") << " fails nTracks requirement for mass-window." ;
173  }
174  return 0.0;
175  }
176  }
177  if ( massWindow.nChargedPFCandsMin_ > 0 ) {
178  unsigned int nChargedPFCands = 0;
179  const std::vector<reco::PFRecoTauChargedHadron>& chargedHadrons = tau->signalTauChargedHadronCandidates();
180  for ( std::vector<reco::PFRecoTauChargedHadron>::const_iterator chargedHadron = chargedHadrons.begin();
181  chargedHadron != chargedHadrons.end(); ++chargedHadron ) {
183  ++nChargedPFCands;
184  }
185  }
186  if ( verbosity_ ) {
187  edm::LogPrint("PFTauByHPSSelect") << "nChargedPFCands = " << nChargedPFCands << " (min = " << massWindow.nChargedPFCandsMin_ << ")" ;
188  }
189  if ( nChargedPFCands < massWindow.nChargedPFCandsMin_ ) {
190  if ( verbosity_ ) {
191  edm::LogPrint("PFTauByHPSSelect") << " fails nChargedPFCands requirement for mass-window." ;
192  }
193  return 0.0;
194  }
195  }
196 
197  math::XYZTLorentzVector tauP4 = tau->p4();
198  if ( verbosity_ ) {
199  edm::LogPrint("PFTauByHPSSelect") << "tau: Pt = " << tauP4.pt() << ", eta = " << tauP4.eta() << ", phi = " << tauP4.phi() << ", mass = " << tauP4.mass() ;
200  }
201  // Find the total pizero p4
203  BOOST_FOREACH(const reco::RecoTauPiZero& cand,
204  tau->signalPiZeroCandidates()){
205  math::XYZTLorentzVector candP4 = cand.p4();
206  stripsP4 += candP4;
207  }
208 
209  // Apply strip mass assumption corrections
210  if (massWindow.assumeStripMass_ >= 0) {
211  BOOST_FOREACH(const reco::RecoTauPiZero& cand,
212  tau->signalPiZeroCandidates()){
213  math::XYZTLorentzVector uncorrected = cand.p4();
214  math::XYZTLorentzVector corrected =
215  applyMassConstraint(uncorrected, massWindow.assumeStripMass_);
216  math::XYZTLorentzVector correction = corrected - uncorrected;
217  tauP4 += correction;
218  stripsP4 += correction;
219  }
220  }
221  if ( verbosity_ ) {
222  edm::LogPrint("PFTauByHPSSelect") << "strips: Pt = " << stripsP4.pt() << ", eta = " << stripsP4.eta() << ", phi = " << stripsP4.phi() << ", mass = " << stripsP4.mass() ;
223  }
224 
225  // Check if tau fails mass cut
226  double maxMass_value = (*massWindow.maxMass_)(*tau);
227  double bendCorrection_mass = ( massWindow.applyBendCorrection_mass_ ) ? tau->bendCorrMass() : 0.;
228  if ( !((tauP4.M() - bendCorrection_mass) < maxMass_value && (tauP4.M() + bendCorrection_mass) > massWindow.minMass_) ) {
229  if ( verbosity_ ) {
230  edm::LogPrint("PFTauByHPSSelect") << " fails tau mass-window cut." ;
231  }
232  return 0.0;
233  }
234  // CV: require that mass of charged tau decay products is always within specified mass window,
235  // irrespective of bendCorrection_mass
236  reco::Candidate::LorentzVector tauP4_charged;
237  const std::vector<reco::PFRecoTauChargedHadron>& signalChargedHadrons = tau->signalTauChargedHadronCandidates();
238  for ( std::vector<reco::PFRecoTauChargedHadron>::const_iterator signalChargedHadron = signalChargedHadrons.begin();
239  signalChargedHadron != signalChargedHadrons.end(); ++signalChargedHadron ) {
240  tauP4_charged += signalChargedHadron->p4();
241  }
242  if ( !(tauP4_charged.mass() < maxMass_value) ) {
243  if ( verbosity_ ) {
244  edm::LogPrint("PFTauByHPSSelect") << " fails tau mass-window cut." ;
245  }
246  return 0.0;
247  }
248 
249  // Check if it fails the pi0 IM cut
250  if ( stripsP4.M() > massWindow.maxPi0Mass_ ||
251  stripsP4.M() < massWindow.minPi0Mass_ ) {
252  if ( verbosity_ ) {
253  edm::LogPrint("PFTauByHPSSelect") << " fails strip mass-window cut." ;
254  }
255  return 0.0;
256  }
257 
258  // Check if tau passes matching cone cut
259  //edm::LogPrint("PFTauByHPSSelect") << "dR(tau, jet) = " << deltaR(tauP4, tau->jetRef()->p4()) ;
260  if ( deltaR(tauP4, tau->jetRef()->p4()) > matchingCone_ ) {
261  if ( verbosity_ ) {
262  edm::LogPrint("PFTauByHPSSelect") << " fails matching-cone cut." ;
263  }
264  return 0.0;
265  }
266 
267  // Check if tau passes cone cut
268  double cone_size = tau->signalConeSize();
269  // Check if any charged objects fail the signal cone cut
270  for (auto const& cand : tau->signalTauChargedHadronCandidates()) {
271  if ( verbosity_ ) {
272  edm::LogPrint("PFTauByHPSSelect") << "dR(tau, signalPFChargedHadr) = " << deltaR(cand.p4(), tauP4) ;
273  }
274  if ( deltaR(cand.p4(), tauP4) > cone_size ) {
275  if ( verbosity_ ) {
276  edm::LogPrint("PFTauByHPSSelect") << " fails signal-cone cut for charged hadron(s)." ;
277  }
278  return 0.0;
279  }
280  }
281  // Now check the pizeros
282  for (auto const& cand : tau->signalPiZeroCandidates()) {
283  double bendCorrection_eta = ( massWindow.applyBendCorrection_eta_ ) ? cand.bendCorrEta() : 0.;
284  double dEta = std::max(0., fabs(cand.eta() - tauP4.eta()) - bendCorrection_eta);
285  double bendCorrection_phi = ( massWindow.applyBendCorrection_phi_ ) ? cand.bendCorrPhi() : 0.;
286  double dPhi = std::max(0., std::abs(reco::deltaPhi(cand.phi(), tauP4.phi())) - bendCorrection_phi);
287  double dR2 = dEta*dEta + dPhi*dPhi;
288  if ( verbosity_ ) {
289  edm::LogPrint("PFTauByHPSSelect") << "dR2(tau, signalPiZero) = " << dR2 ;
290  }
291  if ( dR2 > cone_size*cone_size ) {
292  if ( verbosity_ ) {
293  edm::LogPrint("PFTauByHPSSelect") << " fails signal-cone cut for strip(s)." ;
294  }
295  return 0.0;
296  }
297  }
298 
300  BOOST_FOREACH(const reco::PFRecoTauChargedHadron& cand, tau->signalTauChargedHadronCandidates()) {
301  if ( verbosity_ ) {
302  std::string algo_string;
303  if ( cand.algo() == reco::PFRecoTauChargedHadron::kChargedPFCandidate ) algo_string = "ChargedPFCandidate";
304  else if ( cand.algo() == reco::PFRecoTauChargedHadron::kTrack ) algo_string = "Track";
305  else if ( cand.algo() == reco::PFRecoTauChargedHadron::kPFNeutralHadron ) algo_string = "PFNeutralHadron";
306  else algo_string = "Undefined";
307  edm::LogPrint("PFTauByHPSSelect") << "algo(signalPFChargedHadr) = " << algo_string ;
308  }
310  if ( verbosity_ ) {
311  edm::LogPrint("PFTauByHPSSelect") << " fails cut on PFRecoTauChargedHadron algo." ;
312  }
313  return 0.0;
314  }
315  }
316  }
317 
318  if ( minPixelHits_ > 0 ) {
319  int numPixelHits = 0;
320  const std::vector<reco::PFCandidatePtr>& chargedHadrCands = tau->signalPFChargedHadrCands();
321  for ( std::vector<reco::PFCandidatePtr>::const_iterator chargedHadrCand = chargedHadrCands.begin();
322  chargedHadrCand != chargedHadrCands.end(); ++chargedHadrCand ) {
323  const reco::Track* track = 0;
324  if ( (*chargedHadrCand)->trackRef().isNonnull() ) track = (*chargedHadrCand)->trackRef().get();
325  else if ( (*chargedHadrCand)->gsfTrackRef().isNonnull() ) track = (*chargedHadrCand)->gsfTrackRef().get();
326  if ( track ) {
327  numPixelHits += track->hitPattern().numberOfValidPixelHits();
328  }
329  }
330  if ( !(numPixelHits >= minPixelHits_) ) {
331  if ( verbosity_ ) {
332  edm::LogPrint("PFTauByHPSSelect") << " fails cut on sum of pixel hits." ;
333  }
334  return 0.0;
335  }
336  }
337 
338  // Otherwise, we pass!
339  if ( verbosity_ ) {
340  edm::LogPrint("PFTauByHPSSelect") << " passes all cuts." ;
341  }
342  return 1.0;
343 }
const unsigned int nTracks(const reco::Vertex &sv)
PFRecoTauChargedHadronAlgorithm algo() const
Algorithm that built this charged hadron.
virtual double eta() const final
momentum pseudorapidity
virtual double phi() const final
momentum azimuthal angle
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
double deltaR(double eta1, double eta2, double phi1, double phi2)
Definition: TreeUtility.cc:17
double deltaPhi(double phi1, double phi2)
Definition: deltaPhi.h:22
float bendCorrEta() const
Definition: RecoTauPiZero.h:82
const HitPattern & hitPattern() const
Access the hit pattern, indicating in which Tracker layers the track has hits.
Definition: TrackBase.h:445
math::XYZTLorentzVector LorentzVector
Lorentz vector.
Definition: Candidate.h:37
float bendCorrPhi() const
Definition: RecoTauPiZero.h:83
int numberOfValidPixelHits() const
Definition: HitPattern.h:838
virtual const LorentzVector & p4() const final
four-momentum Lorentz vector
Definition: LeafCandidate.h:99

Member Data Documentation

DecayModeCutMap PFRecoTauDiscriminationByHPSSelection::decayModeCuts_
private
double PFRecoTauDiscriminationByHPSSelection::matchingCone_
private
int PFRecoTauDiscriminationByHPSSelection::minPixelHits_
private
double PFRecoTauDiscriminationByHPSSelection::minPt_
private
bool PFRecoTauDiscriminationByHPSSelection::requireTauChargedHadronsToBeChargedPFCands_
private
int PFRecoTauDiscriminationByHPSSelection::verbosity_
private