CMS 3D CMS Logo

List of all members | Public Member Functions | Private Types | Private Attributes
pat::PATVertexAssociationProducer Class Reference

Produces VertexAssociation and a ValueMap to the originating reco jets. More...

Inheritance diagram for pat::PATVertexAssociationProducer:
edm::stream::EDProducer<>

Public Member Functions

 PATVertexAssociationProducer (const edm::ParameterSet &iConfig)
 
void produce (edm::Event &iEvent, const edm::EventSetup &iSetup) override
 
 ~PATVertexAssociationProducer () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndRuns () const final
 

Private Types

typedef edm::ValueMap< pat::VertexAssociationVertexAssociationMap
 
typedef std::vector< edm::InputTagVInputTag
 

Private Attributes

std::vector< edm::InputTagparticles_
 
std::vector< edm::EDGetTokenT< edm::View< reco::Candidate > > > particlesTokens_
 
pat::helper::VertexingHelper vertexing_
 

Additional Inherited Members

- 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
 

Detailed Description

Produces VertexAssociation and a ValueMap to the originating reco jets.

The PATVertexAssociationProducer produces a set of vertex associations for one or more collection of Candidates, and saves them in a ValueMap in the event.

These can be retrieved in PAT Layer 1 to be embedded in PAT Objects

Author
Giovanni Petrucciani
Version
Id
VertexAssociationProducer.cc,v 1.2 2010/02/20 21:00:29 wmtan Exp

Definition at line 27 of file VertexAssociationProducer.cc.

Member Typedef Documentation

◆ VertexAssociationMap

Definition at line 28 of file VertexAssociationProducer.cc.

◆ VInputTag

Definition at line 37 of file VertexAssociationProducer.cc.

Constructor & Destructor Documentation

◆ PATVertexAssociationProducer()

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

Definition at line 48 of file VertexAssociationProducer.cc.

49  : particles_(iConfig.existsAs<VInputTag>("candidates")
50  ? // if it's a VInputTag
51  iConfig.getParameter<VInputTag>("candidates")
52  : VInputTag(1, iConfig.getParameter<edm::InputTag>("candidates"))),
53  vertexing_(iConfig, consumesCollector()) {
54  for (VInputTag::const_iterator it = particles_.begin(), end = particles_.end(); it != end; ++it) {
55  particlesTokens_.push_back(consumes<edm::View<reco::Candidate> >(*it));
56  }
57  produces<VertexAssociationMap>();
58 }

References end, particles_, and particlesTokens_.

◆ ~PATVertexAssociationProducer()

PATVertexAssociationProducer::~PATVertexAssociationProducer ( )
override

Definition at line 60 of file VertexAssociationProducer.cc.

60 {}

Member Function Documentation

◆ produce()

void PATVertexAssociationProducer::produce ( edm::Event iEvent,
const edm::EventSetup iSetup 
)
override

Definition at line 62 of file VertexAssociationProducer.cc.

62  {
63  using namespace edm;
64  using namespace std;
65  // read in vertices and EventSetup
66  vertexing_.newEvent(iEvent, iSetup);
67 
68  // prepare room and tools for output
69  auto result = std::make_unique<VertexAssociationMap>();
71  vector<pat::VertexAssociation> assos;
72 
73  // loop on input tags
74  for (std::vector<edm::EDGetTokenT<edm::View<reco::Candidate> > >::const_iterator it = particlesTokens_.begin(),
75  end = particlesTokens_.end();
76  it != end;
77  ++it) {
78  // read candidates
80  iEvent.getByToken(*it, cands);
81  assos.clear();
82  assos.reserve(cands->size());
83  // loop on candidates
84  for (size_t i = 0, n = cands->size(); i < n; ++i) {
85  assos.push_back(vertexing_(cands->refAt(i)));
86  }
87  // insert into ValueMap
88  filler.insert(cands, assos.begin(), assos.end());
89  }
90 
91  // do the real filling
92  filler.fill();
93 
94  // put our produced stuff in the event
95  iEvent.put(std::move(result));
96 }

References HLT_2018_cff::cands, end, trigObjTnPSource_cfi::filler, mps_fire::i, iEvent, eostools::move(), dqmiodumpmetadata::n, pat::helper::VertexingHelper::newEvent(), particlesTokens_, mps_fire::result, and vertexing_.

Member Data Documentation

◆ particles_

std::vector<edm::InputTag> pat::PATVertexAssociationProducer::particles_
private

Definition at line 39 of file VertexAssociationProducer.cc.

Referenced by PATVertexAssociationProducer().

◆ particlesTokens_

std::vector<edm::EDGetTokenT<edm::View<reco::Candidate> > > pat::PATVertexAssociationProducer::particlesTokens_
private

Definition at line 40 of file VertexAssociationProducer.cc.

Referenced by PATVertexAssociationProducer(), and produce().

◆ vertexing_

pat::helper::VertexingHelper pat::PATVertexAssociationProducer::vertexing_
private

Definition at line 41 of file VertexAssociationProducer.cc.

Referenced by produce().

mps_fire.i
i
Definition: mps_fire.py:355
dqmiodumpmetadata.n
n
Definition: dqmiodumpmetadata.py:28
edm::EDGetTokenT
Definition: EDGetToken.h:33
edm
HLT enums.
Definition: AlignableModifier.h:19
pat::PATVertexAssociationProducer::vertexing_
pat::helper::VertexingHelper vertexing_
Definition: VertexAssociationProducer.cc:41
edm::ParameterSet::existsAs
bool existsAs(std::string const &parameterName, bool trackiness=true) const
checks if a parameter exists as a given type
Definition: ParameterSet.h:160
edm::Handle
Definition: AssociativeIterator.h:50
end
#define end
Definition: vmac.h:39
edm::View
Definition: CaloClusterFwd.h:14
pat::helper::VertexingHelper::newEvent
void newEvent(const edm::Event &event)
To be called for each new event, reads in the vertex collection.
Definition: VertexingHelper.cc:38
trigObjTnPSource_cfi.filler
filler
Definition: trigObjTnPSource_cfi.py:21
iEvent
int iEvent
Definition: GenABIO.cc:224
edm::ValueMap::Filler
helper::Filler< ValueMap< T > > Filler
Definition: ValueMap.h:168
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
pat::PATVertexAssociationProducer::particles_
std::vector< edm::InputTag > particles_
Definition: VertexAssociationProducer.cc:39
eostools.move
def move(src, dest)
Definition: eostools.py:511
std
Definition: JetResolutionObject.h:76
pat::PATVertexAssociationProducer::VInputTag
std::vector< edm::InputTag > VInputTag
Definition: VertexAssociationProducer.cc:37
pat::PATVertexAssociationProducer::particlesTokens_
std::vector< edm::EDGetTokenT< edm::View< reco::Candidate > > > particlesTokens_
Definition: VertexAssociationProducer.cc:40
HLT_2018_cff.cands
cands
Definition: HLT_2018_cff.py:13762
mps_fire.result
result
Definition: mps_fire.py:303
edm::InputTag
Definition: InputTag.h:15