CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Types | Private Attributes | Static Private Attributes
citk::PFIsolationSumProducer Class Reference
Inheritance diagram for citk::PFIsolationSumProducer:
edm::EDProducer edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

void beginLuminosityBlock (const edm::LuminosityBlock &, const edm::EventSetup &) overridefinal
 
 PFIsolationSumProducer (const edm::ParameterSet &)
 
void produce (edm::Event &, const edm::EventSetup &) overridefinal
 
virtual ~PFIsolationSumProducer ()
 
- Public Member Functions inherited from edm::EDProducer
 EDProducer ()
 
ModuleDescription const & moduleDescription () const
 
virtual ~EDProducer ()
 
- Public Member Functions inherited from edm::ProducerBase
 ProducerBase ()
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription
const &)> 
registrationCallback () const
 used by the fwk to register list of products More...
 
virtual ~ProducerBase ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
std::vector
< ProductHolderIndexAndSkipBit >
const & 
itemsToGetFromEvent () const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesDependentUpon (const std::string &iProcessName, std::vector< const char * > &oModuleLabels) const
 
bool registeredToConsume (ProductHolderIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Types

typedef edm::View
< reco::Candidate
CandView
 
typedef std::vector
< std::unique_ptr
< IsolationConeDefinitionBase > > 
IsoTypes
 
typedef std::unordered_map
< std::string, int > 
TypeMap
 

Private Attributes

edm::EDGetTokenT< CandView_isolate_with
 
std::array< IsoTypes, kNPFTypes_isolation_types
 
std::array< std::vector
< std::string >, kNPFTypes
_product_names
 
edm::EDGetTokenT< CandView_to_isolate
 
const TypeMap _typeMap
 

Static Private Attributes

static unsigned kNPFTypes = 8
 

Additional Inherited Members

- Public Types inherited from edm::EDProducer
typedef EDProducer ModuleType
 
- Public Types inherited from edm::ProducerBase
typedef
ProductRegistryHelper::TypeLabelList 
TypeLabelList
 
- Static Public Member Functions inherited from edm::EDProducer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
- 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)
 

Detailed Description

Definition at line 32 of file CITKPFIsolationSumProducer.cc.

Member Typedef Documentation

Definition at line 49 of file CITKPFIsolationSumProducer.cc.

typedef std::vector<std::unique_ptr<IsolationConeDefinitionBase> > citk::PFIsolationSumProducer::IsoTypes
private

Definition at line 48 of file CITKPFIsolationSumProducer.cc.

typedef std::unordered_map<std::string,int> citk::PFIsolationSumProducer::TypeMap
private

Definition at line 47 of file CITKPFIsolationSumProducer.cc.

Constructor & Destructor Documentation

citk::PFIsolationSumProducer::PFIsolationSumProducer ( const edm::ParameterSet c)

Definition at line 63 of file CITKPFIsolationSumProducer.cc.

63  :
64  _typeMap( { {"h+",1},
65  {"h0",5},
66  {"gamma",4},
67  {"electron",2},
68  {"muon",3},
69  {"HFh",6},
70  {"HFgamma",7} } ){
virtual citk::PFIsolationSumProducer::~PFIsolationSumProducer ( )
inlinevirtual

Definition at line 37 of file CITKPFIsolationSumProducer.cc.

37 {}

Member Function Documentation

void citk::PFIsolationSumProducer::beginLuminosityBlock ( const edm::LuminosityBlock ,
const edm::EventSetup es 
)
finaloverridevirtual

Reimplemented from edm::EDProducer.

Definition at line 106 of file CITKPFIsolationSumProducer.cc.

References _isolation_types.

107  {
108  for( const auto& isolators_for_type : _isolation_types ) {
109  for( const auto& isolator : isolators_for_type ) {
110  isolator->getEventSetupInfo(es);
111  }
112  }
113  }
std::array< IsoTypes, kNPFTypes > _isolation_types
void citk::PFIsolationSumProducer::produce ( edm::Event ev,
const edm::EventSetup es 
)
finaloverridevirtual

Implements edm::EDProducer.

Definition at line 116 of file CITKPFIsolationSumProducer.cc.

References _isolate_with, _isolation_types, _product_names, _to_isolate, begin, EnergyCorrector::c, end, edm::helper::Filler< Map >::fill(), edm::Event::getByToken(), i, edm::helper::Filler< Map >::insert(), j, roll_playback::k, kNPFTypes, edm::Event::put(), reco::PFCandidate::translatePdgIdToType(), and relativeConstraints::value.

116  {
117  typedef std::auto_ptr<edm::ValueMap<float> > product_type;
118  typedef std::vector<float> product_values;
119  edm::Handle<CandView> to_isolate;
120  edm::Handle<CandView> isolate_with;
121  ev.getByToken(_to_isolate,to_isolate);
122  ev.getByToken(_isolate_with,isolate_with);
123  // the list of value vectors indexed as "to_isolate"
124  std::array<std::vector<product_values>,kNPFTypes> the_values;
125  // get extra event info and setup value cache
126  unsigned i = 0;
127  for( const auto& isolators_for_type : _isolation_types ) {
128  the_values[i++].resize(isolators_for_type.size());
129  for( const auto& isolator : isolators_for_type ) {
130  isolator->getEventInfo(ev);
131  }
132  }
133  reco::PFCandidate helper; // to translate pdg id to type
134  // loop over the candidates we are isolating and fill the values
135  for( size_t c = 0; c < to_isolate->size(); ++c ) {
136  auto cand_to_isolate = to_isolate->ptrAt(c);
137  std::array<std::vector<float>,kNPFTypes> cand_values;
138  unsigned k = 0;
139  for( const auto& isolators_for_type : _isolation_types ) {
140  cand_values[k].resize(isolators_for_type.size());
141  for( auto& value : cand_values[k] ) value = 0.0;
142  ++k;
143  }
144  for( size_t ic = 0; ic < isolate_with->size(); ++ic ) {
145  auto isocand = isolate_with->ptrAt(ic);
146  auto isotype = helper.translatePdgIdToType(isocand->pdgId());
147  const auto& isolations = _isolation_types[isotype];
148  for( unsigned i = 0; i < isolations.size(); ++ i ) {
149  if( isolations[i]->isInIsolationCone(cand_to_isolate,isocand) ) {
150  cand_values[isotype][i] += isocand->pt();
151  }
152  }
153  }
154  // add this candidate to isolation value list
155  for( unsigned i = 0; i < kNPFTypes; ++i ) {
156  for( unsigned j = 0; j < cand_values[i].size(); ++j ) {
157  the_values[i][j].push_back(cand_values[i][j]);
158  }
159  }
160  }
161  // fill and put all products
162  for( unsigned i = 0; i < kNPFTypes; ++ i ) {
163  for( unsigned j = 0; j < the_values[i].size(); ++j ) {
164  product_type the_product( new edm::ValueMap<float> );
165  edm::ValueMap<float>::Filler fillerprod(*the_product);
166  fillerprod.insert(to_isolate,
167  the_values[i][j].begin(),
168  the_values[i][j].end());
169  fillerprod.fill();
170  ev.put(the_product,_product_names[i][j]);
171  }
172  }
173  }
int i
Definition: DBlmapReader.cc:9
std::array< std::vector< std::string >, kNPFTypes > _product_names
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:446
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:113
edm::EDGetTokenT< CandView > _to_isolate
int j
Definition: DBlmapReader.cc:9
#define end
Definition: vmac.h:37
ParticleType translatePdgIdToType(int pdgid) const
Definition: PFCandidate.cc:224
Particle reconstructed by the particle flow algorithm.
Definition: PFCandidate.h:39
#define begin
Definition: vmac.h:30
edm::EDGetTokenT< CandView > _isolate_with
std::array< IsoTypes, kNPFTypes > _isolation_types

Member Data Documentation

edm::EDGetTokenT<CandView> citk::PFIsolationSumProducer::_isolate_with
private

Definition at line 51 of file CITKPFIsolationSumProducer.cc.

Referenced by produce().

std::array<IsoTypes,kNPFTypes> citk::PFIsolationSumProducer::_isolation_types
private

Definition at line 53 of file CITKPFIsolationSumProducer.cc.

Referenced by beginLuminosityBlock(), and produce().

std::array<std::vector<std::string>,kNPFTypes> citk::PFIsolationSumProducer::_product_names
private

Definition at line 54 of file CITKPFIsolationSumProducer.cc.

Referenced by produce().

edm::EDGetTokenT<CandView> citk::PFIsolationSumProducer::_to_isolate
private

Definition at line 51 of file CITKPFIsolationSumProducer.cc.

Referenced by produce().

const TypeMap citk::PFIsolationSumProducer::_typeMap
private

Definition at line 50 of file CITKPFIsolationSumProducer.cc.

unsigned citk::PFIsolationSumProducer::kNPFTypes = 8
staticprivate

Definition at line 46 of file CITKPFIsolationSumProducer.cc.

Referenced by produce().