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 Attributes
L3MuonCandidateProducerFromMuons Class Reference

#include <L3MuonCandidateProducerFromMuons.h>

Inheritance diagram for L3MuonCandidateProducerFromMuons:
edm::EDProducer edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 L3MuonCandidateProducerFromMuons (const edm::ParameterSet &)
 constructor with config More...
 
virtual void produce (edm::Event &, const edm::EventSetup &)
 produce candidates More...
 
virtual ~L3MuonCandidateProducerFromMuons ()
 destructor More...
 
- Public Member Functions inherited from edm::EDProducer
 EDProducer ()
 
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 ()
 
ProductHolderIndex indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Attributes

edm::InputTag m_L3CollectionLabel
 

Additional Inherited Members

- Public Types inherited from edm::EDProducer
typedef EDProducer ModuleType
 
typedef WorkerT< EDProducerWorkerType
 
- 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::EDProducer
CurrentProcessingContext const * currentContext () const
 
- 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

This class takes the tracker muons (which are reco::Muons) and creates the correspondent reco::RecoChargedCandidate.

Intermediate step in the L3 muons selection. This class takes the tracker muons (which are reco::Muons) and creates the correspondent reco::RecoChargedCandidate.

Definition at line 17 of file L3MuonCandidateProducerFromMuons.h.

Constructor & Destructor Documentation

L3MuonCandidateProducerFromMuons::L3MuonCandidateProducerFromMuons ( const edm::ParameterSet parameterSet)

constructor with config

Definition at line 37 of file L3MuonCandidateProducerFromMuons.cc.

References category(), and LogTrace.

37  :
38  m_L3CollectionLabel( parameterSet.getParameter<InputTag>("InputObjects") ) // standAlone Collection Label
39 {
40  LogTrace(category)<<" constructor called";
41  produces<RecoChargedCandidateCollection>();
42 }
T getParameter(std::string const &) const
#define LogTrace(id)
static const std::string category("Muon|RecoMuon|L3MuonCandidateProducerFromMuons")
L3MuonCandidateProducerFromMuons::~L3MuonCandidateProducerFromMuons ( )
virtual

destructor

Definition at line 45 of file L3MuonCandidateProducerFromMuons.cc.

References category(), and LogTrace.

45  {
46  LogTrace(category)<<" L3MuonCandidateProducerFromMuons destructor called";
47 }
#define LogTrace(id)
static const std::string category("Muon|RecoMuon|L3MuonCandidateProducerFromMuons")

Member Function Documentation

void L3MuonCandidateProducerFromMuons::produce ( edm::Event event,
const edm::EventSetup eventSetup 
)
virtual

produce candidates

reconstruct muons

Implements edm::EDProducer.

Definition at line 51 of file L3MuonCandidateProducerFromMuons.cc.

References abs, category(), i, edm::HandleBase::isValid(), edm::InputTag::label(), LogTrace, m_L3CollectionLabel, patZpeak::muons, p4, evf::utils::pid, lumiQueryAPI::q, reco::RecoChargedCandidate::setTrack(), and edm::HandleBase::whyFailed().

51  {
52  // Create a RecoChargedCandidate collection
53  LogTrace(category)<<" Creating the RecoChargedCandidate collection";
54  auto_ptr<RecoChargedCandidateCollection> candidates( new RecoChargedCandidateCollection());
55 
56  // Take the L3 container
57  LogTrace(category)<<" Taking the L3/GLB muons: "<<m_L3CollectionLabel.label();
59  event.getByLabel(m_L3CollectionLabel,muons);
60 
61  if (not muons.isValid()) {
62  LogError(category) << muons.whyFailed()->what();
63  } else {
64  for (unsigned int i=0; i<muons->size(); i++) {
65  TrackRef tkref = (*muons)[i].innerTrack();
66 
67  Particle::Charge q = tkref->charge();
68  Particle::LorentzVector p4(tkref->px(), tkref->py(), tkref->pz(), tkref->p());
69  Particle::Point vtx(tkref->vx(),tkref->vy(), tkref->vz());
70 
71  int pid = 13;
72  if (abs(q)==1)
73  pid = q < 0 ? 13 : -13;
74  else
75  LogWarning(category) << "L3MuonCandidate has charge = " << q;
76  RecoChargedCandidate cand(q, p4, vtx, pid);
77 
78  cand.setTrack(tkref);
79  candidates->push_back(cand);
80  }
81  }
82  event.put(candidates);
83 }
int i
Definition: DBlmapReader.cc:9
#define abs(x)
Definition: mlp_lapack.h:159
int Charge
electric charge type
Definition: Particle.h:23
double p4[4]
Definition: TauolaWrapper.h:92
math::XYZPoint Point
point in the space
Definition: Particle.h:29
bool isValid() const
Definition: HandleBase.h:76
boost::shared_ptr< cms::Exception > whyFailed() const
Definition: HandleBase.h:90
#define LogTrace(id)
std::vector< RecoChargedCandidate > RecoChargedCandidateCollection
collectin of RecoChargedCandidate objects
std::string const & label() const
Definition: InputTag.h:42
tuple muons
Definition: patZpeak.py:38
static const std::string category("Muon|RecoMuon|L3MuonCandidateProducerFromMuons")
math::XYZTLorentzVector LorentzVector
Lorentz vector.
Definition: Particle.h:25

Member Data Documentation

edm::InputTag L3MuonCandidateProducerFromMuons::m_L3CollectionLabel
private

Definition at line 33 of file L3MuonCandidateProducerFromMuons.h.

Referenced by produce().