CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
PFEGammaToCandidateRemapper Class Reference
Inheritance diagram for PFEGammaToCandidateRemapper:
edm::global::EDProducer<> edm::global::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 PFEGammaToCandidateRemapper (const edm::ParameterSet &iConfig)
 
virtual void produce (edm::StreamID iID, edm::Event &iEvent, const edm::EventSetup &iSetup) const override
 
virtual ~PFEGammaToCandidateRemapper ()
 
- Public Member Functions inherited from edm::global::EDProducer<>
 EDProducer ()=default
 
- Public Member Functions inherited from edm::global::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 Member Functions

template<typename T >
void run (edm::Event &iEvent, const edm::EDGetTokenT< std::vector< T >> &colltoken, const edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef >>> &oldmaptoken, const edm::ValueMap< reco::PFCandidateRef > &pf2pf, const std::string &name) const
 

Private Attributes

edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > electron2pf_
 
edm::EDGetTokenT< std::vector< reco::GsfElectron > > electrons_
 
edm::EDGetTokenT< edm::ValueMap< reco::PFCandidateRef > > pf2pf_
 
edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > photon2pf_
 
edm::EDGetTokenT< std::vector< reco::Photon > > photons_
 

Additional Inherited Members

- Public Types inherited from edm::global::EDProducerBase
typedef EDProducerBase 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::global::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)
 

Detailed Description

Take as input:

Definition at line 19 of file PFEGammaToCandidateRemapper.cc.

Constructor & Destructor Documentation

PFEGammaToCandidateRemapper::PFEGammaToCandidateRemapper ( const edm::ParameterSet iConfig)
explicit

Definition at line 61 of file PFEGammaToCandidateRemapper.cc.

61  :
62  photons_(consumes<std::vector<reco::Photon>>(iConfig.getParameter<edm::InputTag>("photons"))),
63  electrons_(consumes<std::vector<reco::GsfElectron>>(iConfig.getParameter<edm::InputTag>("electrons"))),
64  photon2pf_(consumes<edm::ValueMap<std::vector<reco::PFCandidateRef>>>(iConfig.getParameter<edm::InputTag>("photon2pf"))),
65  electron2pf_(consumes<edm::ValueMap<std::vector<reco::PFCandidateRef>>>(iConfig.getParameter<edm::InputTag>("electron2pf"))),
67 {
68  produces<edm::ValueMap<std::vector<reco::PFCandidateRef>>>("photons");
69  produces<edm::ValueMap<std::vector<reco::PFCandidateRef>>>("electrons");
70 }
T getParameter(std::string const &) const
edm::EDGetTokenT< std::vector< reco::GsfElectron > > electrons_
edm::EDGetTokenT< edm::ValueMap< reco::PFCandidateRef > > pf2pf_
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > electron2pf_
edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > photon2pf_
edm::EDGetTokenT< std::vector< reco::Photon > > photons_
virtual PFEGammaToCandidateRemapper::~PFEGammaToCandidateRemapper ( )
inlinevirtual

Definition at line 22 of file PFEGammaToCandidateRemapper.cc.

References iEvent, and produce().

22 { }

Member Function Documentation

void PFEGammaToCandidateRemapper::produce ( edm::StreamID  iID,
edm::Event iEvent,
const edm::EventSetup iSetup 
) const
overridevirtual

Definition at line 74 of file PFEGammaToCandidateRemapper.cc.

References DEFINE_FWK_MODULE, electron2pf_, electrons_, edm::Event::getByToken(), iEvent, packedPFCandidateRefMixer_cfi::pf2pf, pf2pf_, photon2pf_, and photons_.

Referenced by JSONExport.JsonExport::export(), HTMLExport.HTMLExport::export(), HTMLExport.HTMLExportStatic::export(), and ~PFEGammaToCandidateRemapper().

74  {
76  iEvent.getByToken(pf2pf_, pf2pf);
77  run<reco::Photon>(iEvent, photons_, photon2pf_, *pf2pf, "photons");
78  run<reco::GsfElectron>(iEvent, electrons_, electron2pf_, *pf2pf, "electrons");
79 }
edm::EDGetTokenT< std::vector< reco::GsfElectron > > electrons_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:460
edm::EDGetTokenT< edm::ValueMap< reco::PFCandidateRef > > pf2pf_
int iEvent
Definition: GenABIO.cc:230
edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > electron2pf_
edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef > > > photon2pf_
edm::EDGetTokenT< std::vector< reco::Photon > > photons_
template<typename T >
void PFEGammaToCandidateRemapper::run ( edm::Event iEvent,
const edm::EDGetTokenT< std::vector< T >> &  colltoken,
const edm::EDGetTokenT< edm::ValueMap< std::vector< reco::PFCandidateRef >>> &  oldmaptoken,
const edm::ValueMap< reco::PFCandidateRef > &  pf2pf,
const std::string &  name 
) const
inlineprivate

Definition at line 33 of file PFEGammaToCandidateRemapper.cc.

References objects.autophobj::filler, edm::Event::getByToken(), cmsBatch::handle, mps_fire::i, eostools::move(), gen::n, MillePedeFileConverter_cfg::out, and edm::Event::put().

Referenced by Types.EventID::cppID(), Types.LuminosityBlockID::cppID(), and o2olib.O2OTool::execute().

37  {
39  iEvent.getByToken(colltoken, handle);
40 
42  iEvent.getByToken(oldmaptoken, oldmap);
43 
44  std::vector<std::vector<reco::PFCandidateRef>> refs(handle->size());
45  for (unsigned int i = 0, n = handle->size(); i < n; ++i) {
46  edm::Ref<std::vector<T>> egRef(handle,i);
47  for (reco::PFCandidateRef pfRef : (*oldmap)[egRef]) {
48  refs[i].push_back(pf2pf[pfRef]);
49  }
50  }
51 
52  std::unique_ptr<edm::ValueMap<std::vector<reco::PFCandidateRef>>> out(new edm::ValueMap<std::vector<reco::PFCandidateRef>>());
54  filler.insert(handle, refs.begin(), refs.end());
55  filler.fill();
56  iEvent.put(std::move(out), name);
57  }
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:460
def move(src, dest)
Definition: eostools.py:510

Member Data Documentation

edm::EDGetTokenT<edm::ValueMap<std::vector<reco::PFCandidateRef> > > PFEGammaToCandidateRemapper::electron2pf_
private

Definition at line 29 of file PFEGammaToCandidateRemapper.cc.

Referenced by produce().

edm::EDGetTokenT<std::vector<reco::GsfElectron> > PFEGammaToCandidateRemapper::electrons_
private

Definition at line 28 of file PFEGammaToCandidateRemapper.cc.

Referenced by produce().

edm::EDGetTokenT<edm::ValueMap<reco::PFCandidateRef> > PFEGammaToCandidateRemapper::pf2pf_
private

Definition at line 30 of file PFEGammaToCandidateRemapper.cc.

Referenced by produce().

edm::EDGetTokenT<edm::ValueMap<std::vector<reco::PFCandidateRef> > > PFEGammaToCandidateRemapper::photon2pf_
private

Definition at line 29 of file PFEGammaToCandidateRemapper.cc.

Referenced by produce().

edm::EDGetTokenT<std::vector<reco::Photon> > PFEGammaToCandidateRemapper::photons_
private

Definition at line 27 of file PFEGammaToCandidateRemapper.cc.

Referenced by produce().