CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Attributes
pf2pat::IsolatedPFCandidateSelectorDefinition Class Reference

#include <IsolatedPFCandidateSelectorDefinition.h>

Inheritance diagram for pf2pat::IsolatedPFCandidateSelectorDefinition:
pf2pat::PFCandidateSelectorDefinition

Public Types

typedef edm::ValueMap< double > IsoMap
 
- Public Types inherited from pf2pat::PFCandidateSelectorDefinition
typedef reco::PFCandidateCollection collection
 
typedef boost::transform_iterator< Pointer, container::const_iterator > const_iterator
 
typedef std::vector< reco::PFCandidatecontainer
 
typedef edm::Handle< collectionHandleToCollection
 

Public Member Functions

 IsolatedPFCandidateSelectorDefinition (const edm::ParameterSet &cfg, edm::ConsumesCollector &&iC)
 
void select (const HandleToCollection &hc, const edm::Event &e, const edm::EventSetup &s)
 
- Public Member Functions inherited from pf2pat::PFCandidateSelectorDefinition
const_iterator begin () const
 
const_iterator end () const
 
 PFCandidateSelectorDefinition ()
 
const containerselected () const
 
size_t size () const
 

Private Attributes

double deltaBetaFactor_
 
edm::EDGetTokenT< IsoMapdeltaBetaIsolationValueMapToken_
 
bool doDeltaBetaCorrection_
 
double isolationCut_
 
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapChargedTokens_
 
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapNeutralTokens_
 
bool isRelative_
 

Additional Inherited Members

- Protected Attributes inherited from pf2pat::PFCandidateSelectorDefinition
container selected_
 

Detailed Description

Definition at line 14 of file IsolatedPFCandidateSelectorDefinition.h.

Member Typedef Documentation

Definition at line 17 of file IsolatedPFCandidateSelectorDefinition.h.

Constructor & Destructor Documentation

pf2pat::IsolatedPFCandidateSelectorDefinition::IsolatedPFCandidateSelectorDefinition ( const edm::ParameterSet cfg,
edm::ConsumesCollector &&  iC 
)
inline

Definition at line 19 of file IsolatedPFCandidateSelectorDefinition.h.

References looper::cfg, deltaBetaFactor_, deltaBetaIsolationValueMapToken_, doDeltaBetaCorrection_, isolationCut_, isolationValueMapNeutralTokens_, isRelative_, GlobalPosition_Frontier_DevDB_cff::tag, and edm::vector_transform().

19  :
20  isolationValueMapChargedTokens_(edm::vector_transform(cfg.getParameter< std::vector<edm::InputTag> >("isolationValueMapsCharged"), [&](edm::InputTag const & tag){return iC.consumes<IsoMap>(tag);}) ),
21  isolationValueMapNeutralTokens_(edm::vector_transform(cfg.getParameter< std::vector<edm::InputTag> >("isolationValueMapsNeutral"), [&](edm::InputTag const & tag){return iC.consumes<IsoMap>(tag);}) ),
22  doDeltaBetaCorrection_(cfg.getParameter<bool>("doDeltaBetaCorrection")),
23  deltaBetaIsolationValueMapToken_(iC.mayConsume<IsoMap>(cfg.getParameter< edm::InputTag >("deltaBetaIsolationValueMap") ) ),
24  deltaBetaFactor_(cfg.getParameter<double>("deltaBetaFactor")),
25  isRelative_(cfg.getParameter<bool>("isRelative")),
26  isolationCut_(cfg.getParameter<double>("isolationCut")) {}
T getParameter(std::string const &) const
EDGetTokenT< ProductType > mayConsume(edm::InputTag const &tag)
auto vector_transform(std::vector< InputType > const &input, Function predicate) -> std::vector< typename std::remove_cv< typename std::remove_reference< decltype(predicate(input.front()))>::type >::type >
Definition: transform.h:11
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapChargedTokens_
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapNeutralTokens_

Member Function Documentation

void pf2pat::IsolatedPFCandidateSelectorDefinition::select ( const HandleToCollection hc,
const edm::Event e,
const edm::EventSetup s 
)
inline

Definition at line 30 of file IsolatedPFCandidateSelectorDefinition.h.

References deltaBetaFactor_, deltaBetaIsolationValueMapToken_, doDeltaBetaCorrection_, edm::Event::getByToken(), isolationCut_, isolationValueMapChargedTokens_, isolationValueMapNeutralTokens_, objects.IsoTrackAnalyzer::isoSum, isRelative_, crabWrapper::key, TriggerAnalyzer::passed, pf2pat::PFCandidateSelectorDefinition::selected_, and heppy_batch::val.

Referenced by Vispa.Views.LineDecayView.LineDecayContainer::createObject(), Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::find(), Vispa.Views.LineDecayView.LineDecayContainer::mousePressEvent(), Vispa.Gui.PortConnection.PointToPointConnection::mousePressEvent(), Vispa.Gui.VispaWidget.VispaWidget::mousePressEvent(), and Vispa.Views.AbstractView.AbstractView::restoreSelection().

32  {
33  selected_.clear();
34 
35 
36  // read all charged isolation value maps
37  std::vector< edm::Handle<IsoMap> >
38  isoMapsCharged(isolationValueMapChargedTokens_.size());
39  for(unsigned iMap = 0; iMap<isolationValueMapChargedTokens_.size(); ++iMap) {
40  e.getByToken(isolationValueMapChargedTokens_[iMap], isoMapsCharged[iMap]);
41  }
42 
43 
44  // read all neutral isolation value maps
45  std::vector< edm::Handle<IsoMap> >
46  isoMapsNeutral(isolationValueMapNeutralTokens_.size());
47  for(unsigned iMap = 0; iMap<isolationValueMapNeutralTokens_.size(); ++iMap) {
48  e.getByToken(isolationValueMapNeutralTokens_[iMap], isoMapsNeutral[iMap]);
49  }
50 
51  edm::Handle<IsoMap> dBetaH;
54  }
55 
56  unsigned key=0;
57  for( collection::const_iterator pfc = hc->begin();
58  pfc != hc->end(); ++pfc, ++key) {
59  reco::PFCandidateRef candidate(hc,key);
60 
61  bool passed = true;
62  double isoSumCharged=0.0;
63  double isoSumNeutral=0.0;
64 
65  for(unsigned iMap = 0; iMap<isoMapsCharged.size(); ++iMap) {
66  const IsoMap & isoMap = *(isoMapsCharged[iMap]);
67  double val = isoMap[candidate];
68  isoSumCharged+=val;
69  }
70 
71  for(unsigned iMap = 0; iMap<isoMapsNeutral.size(); ++iMap) {
72  const IsoMap & isoMap = *(isoMapsNeutral[iMap]);
73  double val = isoMap[candidate];
74  isoSumNeutral+=val;
75  }
76 
77 
78  if ( doDeltaBetaCorrection_ ) {
79  const IsoMap& isoMap = *dBetaH;
80  double dBetaVal = isoMap[candidate];
81  double dBetaCorIsoSumNeutral = isoSumNeutral + deltaBetaFactor_*dBetaVal;
82  isoSumNeutral = dBetaCorIsoSumNeutral>0 ? dBetaCorIsoSumNeutral : 0; //follow muon POG definition in 2012
83  }
84 
85  double isoSum=isoSumCharged+isoSumNeutral;
86 
87  if( isRelative_ ) {
88  isoSum /= candidate->pt();
89  }
90 
91  if ( isoSum>isolationCut_ ) {
92  passed = false;
93  }
94 
95  if(passed) {
96  // passed all cuts, selected
97  selected_.push_back( reco::PFCandidate(*pfc) );
98  reco::PFCandidatePtr ptrToMother( hc, key );
99  selected_.back().setSourceCandidatePtr( ptrToMother );
100  }
101  }
102  }
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:508
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapChargedTokens_
std::vector< edm::EDGetTokenT< IsoMap > > isolationValueMapNeutralTokens_
Particle reconstructed by the particle flow algorithm.
Definition: PFCandidate.h:39
susybsm::HSCParticleCollection hc
Definition: classes.h:25
isoSum
===> compute the isolation and find the most isolated track

Member Data Documentation

double pf2pat::IsolatedPFCandidateSelectorDefinition::deltaBetaFactor_
private
edm::EDGetTokenT<IsoMap> pf2pat::IsolatedPFCandidateSelectorDefinition::deltaBetaIsolationValueMapToken_
private
bool pf2pat::IsolatedPFCandidateSelectorDefinition::doDeltaBetaCorrection_
private
double pf2pat::IsolatedPFCandidateSelectorDefinition::isolationCut_
private
std::vector<edm::EDGetTokenT<IsoMap> > pf2pat::IsolatedPFCandidateSelectorDefinition::isolationValueMapChargedTokens_
private

Definition at line 106 of file IsolatedPFCandidateSelectorDefinition.h.

Referenced by select().

std::vector<edm::EDGetTokenT<IsoMap> > pf2pat::IsolatedPFCandidateSelectorDefinition::isolationValueMapNeutralTokens_
private
bool pf2pat::IsolatedPFCandidateSelectorDefinition::isRelative_
private