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
MuonSeedProducer Class Reference

#include <MuonSeedProducer.h>

Inheritance diagram for MuonSeedProducer:
edm::EDProducer edm::ProducerBase edm::ProductRegistryHelper

Public Member Functions

 MuonSeedProducer (const edm::ParameterSet &)
 Constructor. More...
 
virtual void produce (edm::Event &, const edm::EventSetup &)
 Get event properties to send to builder to fill seed collection. More...
 
virtual ~MuonSeedProducer ()
 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 &)
 
boost::function< void(const
BranchDescription &)> 
registrationCallback () const
 used by the fwk to register list of products More...
 
virtual ~ProducerBase ()
 

Private Attributes

bool debug
 
MuonSeedBuildermuonSeedBuilder_
 Builder where seeds are formed. More...
 

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
template<class TProducer , class TMethod >
void callWhenNewProductsRegistered (TProducer *iProd, TMethod iMethod)
 

Detailed Description

This EDProducer produces a collection of muon seeds. To do so, it forms pairs of CSC and/or DT segments and look at the properties of the segment pair (eta, dphi) first to estimate the properties of the muon, and segment direction in case where there is only one segment available.

Author
Dominique Fortin - UCR

Definition at line 25 of file MuonSeedProducer.h.

Constructor & Destructor Documentation

MuonSeedProducer::MuonSeedProducer ( const edm::ParameterSet pset)

Constructor.

See header file for a description of this class.

Author
Dominique Fortin - UCR

Definition at line 40 of file MuonSeedProducer.cc.

References debug, edm::ParameterSet::getParameter(), and muonSeedBuilder_.

40  {
41 
42  // Register what this produces
43  produces<TrajectorySeedCollection>();
44 
45  // Local Debug flag
46  debug = pset.getParameter<bool>("DebugMuonSeed");
47 
48  // Builder which returns seed collection
49  muonSeedBuilder_ = new MuonSeedBuilder( pset );
50 
51 }
T getParameter(std::string const &) const
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.
MuonSeedProducer::~MuonSeedProducer ( )
virtual

Destructor.

Definition at line 57 of file MuonSeedProducer.cc.

References muonSeedBuilder_.

57  {
58 
59  delete muonSeedBuilder_;
60 
61 }
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.

Member Function Documentation

void MuonSeedProducer::produce ( edm::Event event,
const edm::EventSetup eSetup 
)
virtual

Get event properties to send to builder to fill seed collection.

Implements edm::EDProducer.

Definition at line 67 of file MuonSeedProducer.cc.

References MuonSeedBuilder::build(), edm::EventSetup::get(), muonSeedBuilder_, convertSQLitetoXML_cfg::output, MuonSeedBuilder::setBField(), and MuonSeedBuilder::setGeometry().

67  {
68 
69  // Muon Geometry
71  eSetup.get<MuonRecoGeometryRecord>().get(muonLayers);
72  const MuonDetLayerGeometry* lgeom = &*muonLayers;
73  muonSeedBuilder_->setGeometry( lgeom );
74 
75  // Magnetic field
77  eSetup.get<IdealMagneticFieldRecord>().get(field);
78  const MagneticField* theField = &*field;
79  muonSeedBuilder_->setBField( theField );
80 
81  // Create pointer to the seed container
82 
83  std::auto_ptr<TrajectorySeedCollection> output(new TrajectorySeedCollection() );
84 
85  //UNUED: int nSeeds = 0;
86  //UNUSED: nSeeds =
87  muonSeedBuilder_->build( event, eSetup, *output);
88 
89  // Append muon seed collection to event
90  event.put( output );
91 
92 }
int build(edm::Event &event, const edm::EventSetup &eventSetup, TrajectorySeedCollection &seeds)
Build seed collection.
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.
std::vector< TrajectorySeed > TrajectorySeedCollection
void setBField(const MagneticField *theField)
Cache pointer to Magnetic field.
const T & get() const
Definition: EventSetup.h:55
void setGeometry(const MuonDetLayerGeometry *lgeom)
Cache pointer to geometry.

Member Data Documentation

bool MuonSeedProducer::debug
private

Definition at line 42 of file MuonSeedProducer.h.

Referenced by MuonSeedProducer().

MuonSeedBuilder* MuonSeedProducer::muonSeedBuilder_
private

Builder where seeds are formed.

Definition at line 45 of file MuonSeedProducer.h.

Referenced by MuonSeedProducer(), produce(), and ~MuonSeedProducer().