CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
MuonSeedProducer Class Reference

#include <MuonSeedProducer.h>

Inheritance diagram for MuonSeedProducer:
edm::stream::EDProducer<>

Public Member Functions

 MuonSeedProducer (const edm::ParameterSet &)
 Constructor. More...
 
void produce (edm::Event &, const edm::EventSetup &) override
 Get event properties to send to builder to fill seed collection. More...
 
 ~MuonSeedProducer () override
 Destructor. More...
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
bool hasAbilityToProduceInLumis () const final
 
bool hasAbilityToProduceInRuns () const final
 

Private Attributes

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

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

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 
49  edm::ConsumesCollector iC = consumesCollector();
50 
51  // Builder which returns seed collection
52  muonSeedBuilder_ = new MuonSeedBuilder( pset,iC );
53 
54 }
T getParameter(std::string const &) const
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.
MuonSeedProducer::~MuonSeedProducer ( )
override

Destructor.

Definition at line 60 of file MuonSeedProducer.cc.

References muonSeedBuilder_.

60  {
61 
62  delete muonSeedBuilder_;
63 
64 }
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.

Member Function Documentation

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

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

Definition at line 70 of file MuonSeedProducer.cc.

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

70  {
71 
72  // Muon Geometry
74  eSetup.get<MuonRecoGeometryRecord>().get(muonLayers);
75  const MuonDetLayerGeometry* lgeom = &*muonLayers;
76  muonSeedBuilder_->setGeometry( lgeom );
77 
78  // Magnetic field
80  eSetup.get<IdealMagneticFieldRecord>().get(field);
81  const MagneticField* theField = &*field;
82  muonSeedBuilder_->setBField( theField );
83 
84  // Create pointer to the seed container
85 
86  auto output = std::make_unique<TrajectorySeedCollection>();
87 
88  //UNUED: int nSeeds = 0;
89  //UNUSED: nSeeds =
90  muonSeedBuilder_->build( event, eSetup, *output);
91 
92  // Append muon seed collection to event
93  event.put(std::move(output));
94 
95 }
int build(edm::Event &event, const edm::EventSetup &eventSetup, TrajectorySeedCollection &seeds)
Build seed collection.
MuonSeedBuilder * muonSeedBuilder_
Builder where seeds are formed.
void setBField(const MagneticField *theField)
Cache pointer to Magnetic field.
const T & get() const
Definition: EventSetup.h:59
void setGeometry(const MuonDetLayerGeometry *lgeom)
Cache pointer to geometry.
def move(src, dest)
Definition: eostools.py:510

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().