CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
CSCDigiAnalyzer.cc
Go to the documentation of this file.
1 
8 #include <iostream>
9 
18 
28 
32 
34 public:
35  explicit CSCDigiAnalyzer(edm::ParameterSet const& conf);
36  void analyze(edm::Event const& e, edm::EventSetup const& iSetup) override;
37 
38 private:
40 
50 };
51 
53  eventNumber = 0;
54 
55  wd_token = consumes<CSCWireDigiCollection>(conf.getParameter<edm::InputTag>("wireDigiTag"));
56  sd_token = consumes<CSCStripDigiCollection>(conf.getParameter<edm::InputTag>("stripDigiTag"));
57  cd_token = consumes<CSCComparatorDigiCollection>(conf.getParameter<edm::InputTag>("compDigiTag"));
58  al_token = consumes<CSCALCTDigiCollection>(conf.getParameter<edm::InputTag>("alctDigiTag"));
59  cl_token = consumes<CSCCLCTDigiCollection>(conf.getParameter<edm::InputTag>("clctDigiTag"));
60  rd_token = consumes<CSCRPCDigiCollection>(conf.getParameter<edm::InputTag>("rpcDigiTag"));
61  co_token = consumes<CSCCorrelatedLCTDigiCollection>(conf.getParameter<edm::InputTag>("corrlctDigiTag"));
62  dd_token = consumes<CSCDDUStatusDigiCollection>(conf.getParameter<edm::InputTag>("ddusDigiTag"));
63  dc_token = consumes<CSCDCCFormatStatusDigiCollection>(conf.getParameter<edm::InputTag>("dccfDigiTag"));
64 }
65 
76 
77  e.getByToken(dd_token, dduStatusDigi);
78  e.getByToken(wd_token, wires);
79  e.getByToken(sd_token, strips);
80  e.getByToken(cd_token, comparators);
81  e.getByToken(al_token, alcts);
82  e.getByToken(cl_token, clcts);
83  e.getByToken(rd_token, rpcs);
84  e.getByToken(co_token, correlatedlcts);
85  e.getByToken(dc_token, formatStatusDigi);
86 
87  for (CSCDCCFormatStatusDigiCollection::DigiRangeIterator j = formatStatusDigi->begin(); j != formatStatusDigi->end();
88  j++) {
89  std::vector<CSCDCCFormatStatusDigi>::const_iterator digiItr = (*j).second.first;
90  std::vector<CSCDCCFormatStatusDigi>::const_iterator last = (*j).second.second;
91  for (; digiItr != last; ++digiItr) {
92  digiItr->print();
93  }
94  }
95 
96  for (CSCDDUStatusDigiCollection::DigiRangeIterator j = dduStatusDigi->begin(); j != dduStatusDigi->end(); j++) {
97  std::vector<CSCDDUStatusDigi>::const_iterator digiItr = (*j).second.first;
98  std::vector<CSCDDUStatusDigi>::const_iterator last = (*j).second.second;
99  for (; digiItr != last; ++digiItr) {
100  CSCDDUHeader header(*digiItr);
101  std::cout << "L1 number = " << header.lvl1num() << std::endl;
102  std::cout << "DDU number = " << header.source_id() << std::endl;
103  }
104  }
105 
106  for (CSCStripDigiCollection::DigiRangeIterator j = strips->begin(); j != strips->end(); j++) {
107  std::vector<CSCStripDigi>::const_iterator digiItr = (*j).second.first;
108  CSCDetId const cscDetId = (*j).first;
109  std::cout << cscDetId << std::endl;
110  std::vector<CSCStripDigi>::const_iterator last = (*j).second.second;
111  for (; digiItr != last; ++digiItr) {
112  digiItr->print();
113  }
114  }
115 
116  for (CSCWireDigiCollection::DigiRangeIterator j = wires->begin(); j != wires->end(); j++) {
117  CSCDetId const cscDetId = (*j).first;
118  std::cout << cscDetId << std::endl;
119  std::vector<CSCWireDigi>::const_iterator digiItr = (*j).second.first;
120  std::vector<CSCWireDigi>::const_iterator last = (*j).second.second;
121  for (; digiItr != last; ++digiItr) {
122  digiItr->print();
123  }
124  }
125 
126  for (CSCComparatorDigiCollection::DigiRangeIterator j = comparators->begin(); j != comparators->end(); j++) {
127  std::vector<CSCComparatorDigi>::const_iterator digiItr = (*j).second.first;
128  std::vector<CSCComparatorDigi>::const_iterator last = (*j).second.second;
129  for (; digiItr != last; ++digiItr) {
130  digiItr->print();
131  }
132  }
133 
134  for (CSCALCTDigiCollection::DigiRangeIterator j = alcts->begin(); j != alcts->end(); j++) {
135  std::vector<CSCALCTDigi>::const_iterator digiItr = (*j).second.first;
136  std::vector<CSCALCTDigi>::const_iterator last = (*j).second.second;
137  for (; digiItr != last; ++digiItr) {
138  digiItr->print();
139  }
140  }
141 
142  for (CSCCLCTDigiCollection::DigiRangeIterator j = clcts->begin(); j != clcts->end(); j++) {
143  std::vector<CSCCLCTDigi>::const_iterator digiItr = (*j).second.first;
144  std::vector<CSCCLCTDigi>::const_iterator last = (*j).second.second;
145  for (; digiItr != last; ++digiItr) {
146  digiItr->print();
147  }
148  }
149 
150  for (CSCRPCDigiCollection::DigiRangeIterator j = rpcs->begin(); j != rpcs->end(); j++) {
151  std::vector<CSCRPCDigi>::const_iterator digiItr = (*j).second.first;
152  std::vector<CSCRPCDigi>::const_iterator last = (*j).second.second;
153  for (; digiItr != last; ++digiItr) {
154  digiItr->print();
155  }
156  }
157 
158  for (CSCCorrelatedLCTDigiCollection::DigiRangeIterator j = correlatedlcts->begin(); j != correlatedlcts->end(); j++) {
159  std::vector<CSCCorrelatedLCTDigi>::const_iterator digiItr = (*j).second.first;
160  std::vector<CSCCorrelatedLCTDigi>::const_iterator last = (*j).second.second;
161  for (; digiItr != last; ++digiItr) {
162  digiItr->print();
163  }
164  }
165 
166  eventNumber++;
167  edm::LogInfo("CSCDigiAnalyzer") << "end of event number " << eventNumber;
168 }
169 
int lvl1num() const
Definition: CSCDDUHeader.h:24
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:539
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
edm::EDGetTokenT< CSCDDUStatusDigiCollection > dd_token
CSCDigiAnalyzer(edm::ParameterSet const &conf)
edm::EDGetTokenT< CSCALCTDigiCollection > al_token
tuple strips
#turn off noise in all subdetectors simHcalUnsuppressedDigis.doNoise = False mix.digitizers.hcal.doNoise = False simEcalUnsuppressedDigis.doNoise = False mix.digitizers.ecal.doNoise = False simEcalUnsuppressedDigis.doESNoise = False simSiPixelDigis.AddNoise = False mix.digitizers.pixel.AddNoise = False simSiStripDigis.Noise = False mix.digitizers.strip.AddNoise = False
Definition: DigiDM_cff.py:32
void analyze(edm::Event const &e, edm::EventSetup const &iSetup) override
edm::EDGetTokenT< CSCStripDigiCollection > sd_token
Log< level::Info, false > LogInfo
edm::EDGetTokenT< CSCCorrelatedLCTDigiCollection > co_token
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
edm::EDGetTokenT< CSCCLCTDigiCollection > cl_token
tuple cout
Definition: gather_cfg.py:144
int source_id() const
Definition: CSCDDUHeader.h:22
tuple wires
Definition: DigiDM_cff.py:33
edm::EDGetTokenT< CSCWireDigiCollection > wd_token
tuple last
Definition: dqmdumpme.py:56
edm::EDGetTokenT< CSCComparatorDigiCollection > cd_token
edm::EDGetTokenT< CSCRPCDigiCollection > rd_token
edm::EDGetTokenT< CSCDCCFormatStatusDigiCollection > dc_token