![]() |
![]() |
#include <CSCHaloDataProducer.h>
Public Member Functions | |
CSCHaloDataProducer (const edm::ParameterSet &) | |
~CSCHaloDataProducer () | |
Private Member Functions | |
virtual void | beginJob () |
virtual void | beginRun (edm::Run &, const edm::EventSetup &) |
virtual void | endJob () |
virtual void | endRun (edm::Run &, const edm::EventSetup &) |
virtual void | produce (edm::Event &, const edm::EventSetup &) |
Private Attributes | |
CSCHaloAlgo | CSCAlgo |
edm::InputTag | IT_ALCT |
edm::InputTag | IT_CosmicMuon |
edm::InputTag | IT_CSCRecHit |
edm::InputTag | IT_CSCSegment |
edm::InputTag | IT_HLTResult |
edm::InputTag | IT_L1MuGMTReadout |
edm::InputTag | IT_Muon |
edm::InputTag | IT_SA |
std::vector< edm::InputTag > | vIT_HLTBit |
Definition at line 129 of file CSCHaloDataProducer.h.
CSCHaloDataProducer::CSCHaloDataProducer | ( | const edm::ParameterSet & | iConfig | ) | [explicit] |
Definition at line 15 of file CSCHaloDataProducer.cc.
References edm::ParameterSet::getParameter().
{ //Digi Level IT_L1MuGMTReadout = iConfig.getParameter<edm::InputTag>("L1MuGMTReadoutLabel"); //HLT Level IT_HLTResult = iConfig.getParameter<edm::InputTag>("HLTResultLabel"); CSCAlgo.vIT_HLTBit = iConfig.getParameter< std::vector< edm::InputTag> >("HLTBitLabel"); //RecHit Level IT_CSCRecHit = iConfig.getParameter<edm::InputTag>("CSCRecHitLabel"); //Higher Level Reco IT_CSCSegment = iConfig.getParameter<edm::InputTag>("CSCSegmentLabel"); IT_CosmicMuon = iConfig.getParameter<edm::InputTag>("CosmicMuonLabel"); IT_Muon = iConfig.getParameter<edm::InputTag>("MuonLabel"); IT_SA = iConfig.getParameter<edm::InputTag>("SALabel"); IT_ALCT = iConfig.getParameter<edm::InputTag>("ALCTDigiLabel"); // Cosmic track selection parameters CSCAlgo.SetDetaThreshold( (float) iConfig.getParameter<double>("DetaParam")); CSCAlgo.SetDphiThreshold( (float) iConfig.getParameter<double>("DphiParam")); CSCAlgo.SetMinMaxInnerRadius( (float) iConfig.getParameter<double>("InnerRMinParam") , (float) iConfig.getParameter<double>("InnerRMaxParam") ); CSCAlgo.SetMinMaxOuterRadius( (float) iConfig.getParameter<double>("OuterRMinParam"), (float) iConfig.getParameter<double>("OuterRMaxParam")); CSCAlgo.SetNormChi2Threshold( (float) iConfig.getParameter<double>("NormChi2Param") ); CSCAlgo.SetExpectedBX( (short int) iConfig.getParameter<int>("ExpectedBX") ); CSCAlgo.SetRecHitTime0( (float) iConfig.getParameter<double>("RecHitTime0") ); CSCAlgo.SetRecHitTimeWindow( (float) iConfig.getParameter<double>("RecHitTimeWindow") ); CSCAlgo.SetMinMaxOuterMomentumTheta( (float)iConfig.getParameter<double>("MinOuterMomentumTheta"), (float)iConfig.getParameter<double>("MaxOuterMomentumTheta") ); CSCAlgo.SetMatchingDPhiThreshold( (float)iConfig.getParameter<double>("MatchingDPhiThreshold") ); CSCAlgo.SetMatchingDEtaThreshold( (float)iConfig.getParameter<double>("MatchingDEtaThreshold") ); CSCAlgo.SetMatchingDWireThreshold(iConfig.getParameter<int>("MatchingDWireThreshold") ); produces<CSCHaloData>(); }
CSCHaloDataProducer::~CSCHaloDataProducer | ( | ) |
Definition at line 100 of file CSCHaloDataProducer.cc.
{}
void CSCHaloDataProducer::beginJob | ( | void | ) | [private, virtual] |
void CSCHaloDataProducer::beginRun | ( | edm::Run & | , |
const edm::EventSetup & | |||
) | [private, virtual] |
void CSCHaloDataProducer::endJob | ( | void | ) | [private, virtual] |
void CSCHaloDataProducer::endRun | ( | edm::Run & | , |
const edm::EventSetup & | |||
) | [private, virtual] |
void CSCHaloDataProducer::produce | ( | edm::Event & | iEvent, |
const edm::EventSetup & | iSetup | ||
) | [private, virtual] |
Implements edm::EDProducer.
Definition at line 51 of file CSCHaloDataProducer.cc.
References CSCHaloData_cfi::CSCHaloData, edm::EventSetup::get(), edm::Event::getByLabel(), edm::HandleBase::isValid(), edm::Event::put(), and edm::Event::triggerNames().
{ //Get CSC Geometry edm::ESHandle<CSCGeometry> TheCSCGeometry; iSetup.get<MuonGeometryRecord>().get(TheCSCGeometry); //Get CSC Stand-Alone Muons from Cosmic Reconstruction edm::Handle< reco::TrackCollection > TheCosmics; iEvent.getByLabel(IT_CosmicMuon, TheCosmics); //Collision Muon Collection edm::Handle< reco::MuonCollection> TheMuons; iEvent.getByLabel(IT_Muon, TheMuons); //Get CSC Segments edm::Handle<CSCSegmentCollection> TheCSCSegments; iEvent.getByLabel(IT_CSCSegment, TheCSCSegments); //Get CSC RecHits Handle<CSCRecHit2DCollection> TheCSCRecHits; iEvent.getByLabel(IT_CSCRecHit, TheCSCRecHits); //Get L1MuGMT edm::Handle < L1MuGMTReadoutCollection > TheL1GMTReadout ; iEvent.getByLabel (IT_L1MuGMTReadout, TheL1GMTReadout); //Get Chamber Anode Trigger Information edm::Handle<CSCALCTDigiCollection> TheALCTs; iEvent.getByLabel (IT_ALCT, TheALCTs); //Get HLT Results edm::Handle<edm::TriggerResults> TheHLTResults; iEvent.getByLabel( IT_HLTResult , TheHLTResults); const edm::TriggerNames * triggerNames = 0; if (TheHLTResults.isValid()) { triggerNames = &iEvent.triggerNames(*TheHLTResults); } std::auto_ptr<CSCHaloData> TheCSCData(new CSCHaloData( CSCAlgo.Calculate(*TheCSCGeometry, TheCosmics, TheMuons, TheCSCSegments, TheCSCRecHits, TheL1GMTReadout, TheHLTResults, triggerNames, TheALCTs) ) ); // Put it in the event iEvent.put(TheCSCData); return; }
Definition at line 144 of file CSCHaloDataProducer.h.
Definition at line 148 of file CSCHaloDataProducer.h.
Definition at line 158 of file CSCHaloDataProducer.h.
Definition at line 155 of file CSCHaloDataProducer.h.
Definition at line 159 of file CSCHaloDataProducer.h.
Definition at line 151 of file CSCHaloDataProducer.h.
Definition at line 147 of file CSCHaloDataProducer.h.
Definition at line 160 of file CSCHaloDataProducer.h.
Definition at line 161 of file CSCHaloDataProducer.h.
std::vector< edm::InputTag > reco::CSCHaloDataProducer::vIT_HLTBit [private] |
Definition at line 152 of file CSCHaloDataProducer.h.