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
pat::PATTrackAndVertexUnpacker Class Reference
Inheritance diagram for pat::PATTrackAndVertexUnpacker:
edm::global::EDProducer<> edm::global::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 PATTrackAndVertexUnpacker (const edm::ParameterSet &iConfig)
 
virtual void produce (edm::StreamID, edm::Event &iEvent, const edm::EventSetup &iSetup) const override
 
 ~PATTrackAndVertexUnpacker ()
 
- 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)
 
 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
std::vector< ConsumesInfoconsumesInfo () const
 
 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
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
bool registeredToConsume (ProductHolderIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Types

typedef std::vector
< edm::InputTag
VInputTag
 

Private Attributes

const edm::EDGetTokenT
< std::vector
< pat::PackedCandidate > > 
AdditionalTracks_
 
const edm::EDGetTokenT
< std::vector
< pat::PackedCandidate > > 
Cands_
 
const edm::EDGetTokenT
< reco::VertexCollection
PVs_
 
const edm::EDGetTokenT
< reco::VertexCompositePtrCandidateCollection
SVs_
 

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

Definition at line 28 of file TrackAndVertexUnpacker.cc.

Member Typedef Documentation

Definition at line 39 of file TrackAndVertexUnpacker.cc.

Constructor & Destructor Documentation

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

Definition at line 53 of file TrackAndVertexUnpacker.cc.

53  :
54  Cands_(consumes< std::vector<pat::PackedCandidate> >(iConfig.getParameter<edm::InputTag>("packedCandidates"))),
55  PVs_(consumes<reco::VertexCollection>(iConfig.getParameter<edm::InputTag>("slimmedVertices"))),
56  SVs_(consumes<reco::VertexCompositePtrCandidateCollection>(iConfig.getParameter<edm::InputTag>("slimmedSecondaryVertices"))),
57  AdditionalTracks_(consumes<pat::PackedCandidateCollection>(iConfig.getParameter<edm::InputTag>("additionalTracks")))
58 {
59  produces<reco::TrackCollection>();
60  produces<reco::VertexCollection>();
61  produces<reco::VertexCollection>("secondary");
62 }
const edm::EDGetTokenT< reco::VertexCollection > PVs_
T getParameter(std::string const &) const
const edm::EDGetTokenT< std::vector< pat::PackedCandidate > > Cands_
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
const edm::EDGetTokenT< std::vector< pat::PackedCandidate > > AdditionalTracks_
const edm::EDGetTokenT< reco::VertexCompositePtrCandidateCollection > SVs_
PATTrackAndVertexUnpacker::~PATTrackAndVertexUnpacker ( )

Definition at line 65 of file TrackAndVertexUnpacker.cc.

65  {
66 }

Member Function Documentation

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

Implements edm::global::EDProducerBase.

Definition at line 69 of file TrackAndVertexUnpacker.cc.

References reco::Vertex::add(), AdditionalTracks_, EnergyCorrector::c, Cands_, pat::PackedCandidate::charge(), reco::CompositePtrCandidate::daughterPtr(), pat::PackedCandidate::fromPV(), edm::Event::getByToken(), i, edm::ProductID::id(), edm::Ptr< T >::id(), j, edm::Ptr< T >::key(), reco::CompositePtrCandidate::numberOfDaughters(), pat::PackedCandidate::numberOfHits(), pat::PackedCandidate::pseudoTrack(), edm::Event::put(), MetAnalyzer::pv(), PVs_, pat::PackedCandidate::PVUsedInFit, alignCSCRings::r, dt_dqm_sourceclient_common_cff::reco, findQualityFiles::rr, SVs_, reco::LeafCandidate::vertex(), reco::VertexCompositePtrCandidate::vertexChi2(), reco::VertexCompositePtrCandidate::vertexCovariance(), and reco::VertexCompositePtrCandidate::vertexNdof().

69  {
70  using namespace edm; using namespace std; using namespace reco;
72  iEvent.getByToken(Cands_, cands);
74  iEvent.getByToken(PVs_, pvs);
76  iEvent.getByToken(SVs_, svs);
78  iEvent.getByToken(AdditionalTracks_, addTracks);
79 
80  std::auto_ptr< std::vector<reco::Track> > outTks( new std::vector<reco::Track> );
81  std::map<unsigned int, std::vector<unsigned int> > asso;
82  std::map<unsigned int, unsigned int> trackKeys;
83  unsigned int j=0;
84  for(unsigned int i=0;i<cands->size();i++) {
85  const pat::PackedCandidate & c = (*cands)[i];
86  if(c.charge() != 0 && c.numberOfHits()> 0){
87  outTks->push_back(c.pseudoTrack());
88  for(size_t ipv=0;ipv< pvs->size(); ++ipv) {
90  asso[ipv].push_back(j);
91  }
92  trackKeys[i]=j;
93  j++;
94  }
95  }
96 
97  int offsetAdd=j;
98  for(unsigned int i = 0; i < addTracks->size(); i++) {
99  outTks->push_back((*addTracks)[i].pseudoTrack());
100  for(size_t ipv=0;ipv< pvs->size(); ++ipv) {
101  if((*addTracks)[i].fromPV(ipv)==pat::PackedCandidate::PVUsedInFit)
102  asso[ipv].push_back(j);
103  }
104  j++;
105  }
106 
107  edm::OrphanHandle< std::vector<reco::Track> > oh = iEvent.put( outTks );
108 
109  std::auto_ptr< std::vector<reco::Vertex> > outPv( new std::vector<reco::Vertex> );
110 
111  for(size_t ipv=0;ipv< pvs->size(); ++ipv) {
112  reco::Vertex pv = (*pvs)[ipv];
113  for(unsigned int i=0;i<asso[ipv].size();i++)
114  {
115  TrackRef r(oh,asso[ipv][i]);
116  TrackBaseRef rr(r);
117  pv.add(rr);
118  }
119  outPv->push_back(pv);
120  }
121  iEvent.put(outPv);
122 
123  std::auto_ptr< std::vector<reco::Vertex> > outSv( new std::vector<reco::Vertex> );
124  for(size_t i=0;i< svs->size(); i++) {
125  const reco::VertexCompositePtrCandidate &sv = (*svs)[i];
126  outSv->push_back(reco::Vertex(sv.vertex(),sv.vertexCovariance(),sv.vertexChi2(),sv.vertexNdof(),0));
127  for(size_t j=0;j<sv.numberOfDaughters();j++){
128  TrackRef r;
129  if(sv.daughterPtr(j).id() == cands.id()) {
130  r= TrackRef(oh,trackKeys[sv.daughterPtr(j).key()]); // use trackKeys because cand->track has gaps from neutral
131  } else {
132 // std::cout << "vertex " << i << " using lost Track " << sv.daughterPtr(j).key() << " " << offsetAdd+sv.daughterPtr(j).key() << std::endl;
133  r=TrackRef(oh,offsetAdd+sv.daughterPtr(j).key()); // use directly the key because addTracks is only charged
134  }
135  TrackBaseRef rr(r);
136  outSv->back().add(rr);
137 
138  }
139  }
140 
141  iEvent.put(outSv,"secondary");
142 
143 }
const edm::EDGetTokenT< reco::VertexCollection > PVs_
int i
Definition: DBlmapReader.cc:9
virtual double vertexChi2() const
chi-squares
int numberOfHits() const
key_type key() const
Definition: Ptr.h:186
CandidatePtr daughterPtr(size_type i) const
reference to daughter at given position
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:464
virtual const Point & vertex() const
vertex position (overwritten by PF...)
const edm::EDGetTokenT< std::vector< pat::PackedCandidate > > Cands_
virtual double vertexCovariance(int i, int j) const
(i, j)-th element of error matrix, i, j = 0, ... 2
virtual size_t numberOfDaughters() const
number of daughters
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:120
const PVAssoc fromPV(size_t ipv=0) const
int j
Definition: DBlmapReader.cc:9
virtual int charge() const
electric charge
virtual const reco::Track & pseudoTrack() const
Return reference to a pseudo track made with candidate kinematics, parameterized error for eta...
const edm::EDGetTokenT< std::vector< pat::PackedCandidate > > AdditionalTracks_
void add(const TrackBaseRef &r, float w=1.0)
add a reference to a Track
const edm::EDGetTokenT< reco::VertexCompositePtrCandidateCollection > SVs_
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
Definition: TrackFwd.h:20
ProductID id() const
Accessor for product ID.
Definition: Ptr.h:181
ProductIndex id() const
Definition: ProductID.h:38

Member Data Documentation

const edm::EDGetTokenT<std::vector<pat::PackedCandidate> > pat::PATTrackAndVertexUnpacker::AdditionalTracks_
private

Definition at line 44 of file TrackAndVertexUnpacker.cc.

Referenced by produce().

const edm::EDGetTokenT<std::vector<pat::PackedCandidate> > pat::PATTrackAndVertexUnpacker::Cands_
private

Definition at line 41 of file TrackAndVertexUnpacker.cc.

Referenced by produce().

const edm::EDGetTokenT<reco::VertexCollection> pat::PATTrackAndVertexUnpacker::PVs_
private

Definition at line 42 of file TrackAndVertexUnpacker.cc.

Referenced by produce().

const edm::EDGetTokenT<reco::VertexCompositePtrCandidateCollection> pat::PATTrackAndVertexUnpacker::SVs_
private

Definition at line 43 of file TrackAndVertexUnpacker.cc.

Referenced by produce().