CMS 3D CMS Logo

CSCTFTrackProducer.cc
Go to the documentation of this file.
2 
3 #include <vector>
9 
12 
17 
22 
24  : my_dtrc{},
25  useDT{pset.getParameter<bool>("useDT")},
26  TMB07{pset.getParameter<bool>("isTMB07")},
27  readDtDirect{pset.getParameter<bool>("readDtDirect")},
29  consumes<CSCCorrelatedLCTDigiCollection>(pset.getUntrackedParameter<edm::InputTag>("SectorReceiverInput"))},
30  dt_producer{consumes<L1MuDTChambPhContainer>(pset.getUntrackedParameter<edm::InputTag>("DTproducer"))},
31  directProd{
32  consumes<CSCTriggerContainer<csctf::TrackStub> >(pset.getUntrackedParameter<edm::InputTag>("DtDirectProd"))},
33  sp_pset{pset.getParameter<edm::ParameterSet>("SectorProcessor")} {
34  m_scalesCacheID = 0ULL;
35  m_ptScaleCacheID = 0ULL;
36  produces<L1CSCTrackCollection>();
37  produces<CSCTriggerContainer<csctf::TrackStub> >();
38 
39  //CSCSectorReceiverLUT has a static member it fills by reading a file
40  usesResource("CSCSectorReceiverLUT");
41  //CSCTFSPcoreLogic has non-const static members
42  usesResource("CSCTFSPCoreLogic");
43  //CSCTFPtLUT has a static member it fills by reading a file
44  usesResource("CSCTFPtLUT");
45 }
46 
48  // Update CSCTFTrackBuilder only if the scales have changed. Use the
49  // EventSetup cacheIdentifier to tell when this has happened.
51  c.get<L1MuTriggerPtScaleRcd>().cacheIdentifier() != m_ptScaleCacheID) {
53  c.get<L1MuTriggerScalesRcd>().get(scales);
54 
56  c.get<L1MuTriggerPtScaleRcd>().get(ptScale);
57 
58  my_builder = std::make_unique<CSCTFTrackBuilder>(sp_pset, TMB07, scales.product(), ptScale.product());
59  my_builder->initialize(c);
60 
61  m_scalesCacheID = c.get<L1MuTriggerScalesRcd>().cacheIdentifier();
62  m_ptScaleCacheID = c.get<L1MuTriggerPtScaleRcd>().cacheIdentifier();
63  }
64 
65  // set geometry pointer
67  c.get<MuonGeometryRecord>().get(pDD);
68 
70  std::unique_ptr<L1CSCTrackCollection> track_product(new L1CSCTrackCollection);
71  e.getByToken(input_module, LCTs);
72  std::unique_ptr<CSCTriggerContainer<csctf::TrackStub> > dt_stubs(new CSCTriggerContainer<csctf::TrackStub>);
73 
74  // Either emulate or directly read in DT stubs based on switch
77  if (readDtDirect == false) {
79  e.getByToken(dt_producer, dttrig);
80  emulStub = my_dtrc.process(dttrig.product());
81  } else {
83  //e.getByLabel("csctfunpacker","DT",stubsFromDaq);
84  e.getByToken(directProd, stubsFromDaq);
85  const CSCTriggerContainer<csctf::TrackStub>* stubPointer = stubsFromDaq.product();
86  emulStub.push_many(*stubPointer);
87  }
88 
89  my_builder->buildTracks(LCTs.product(), (useDT ? &emulStub : nullptr), track_product.get(), dt_stubs.get());
90 
91  e.put(std::move(track_product));
92  e.put(std::move(dt_stubs));
93 }
unsigned long long cacheIdentifier() const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
const edm::EDGetTokenT< CSCCorrelatedLCTDigiCollection > input_module
std::unique_ptr< CSCTFTrackBuilder > my_builder
unsigned long long m_scalesCacheID
const edm::EDGetTokenT< CSCTriggerContainer< csctf::TrackStub > > directProd
std::vector< L1CSCTrack > L1CSCTrackCollection
CSCTriggerContainer< csctf::TrackStub > process(const L1MuDTChambPhContainer *)
CSCTFTrackProducer(const edm::ParameterSet &)
const edm::ParameterSet sp_pset
const edm::EDGetTokenT< L1MuDTChambPhContainer > dt_producer
unsigned long long m_ptScaleCacheID
void push_many(const std::vector< T > &data)
T const * product() const
Definition: Handle.h:69
const std::vector< double > ptScale
Definition: Utilities.cc:33
CSCTFDTReceiver my_dtrc
T get() const
Definition: EventSetup.h:73
T const * product() const
Definition: ESHandle.h:86
def move(src, dest)
Definition: eostools.py:511
void produce(edm::Event &e, const edm::EventSetup &c) override