CMS 3D CMS Logo

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

#include <ESRawDataTask.h>

Inheritance diagram for ESRawDataTask:
one::DQMEDAnalyzer< T > one::dqmimplementation::DQMBaseClass< T... >

Public Member Functions

 ESRawDataTask (const edm::ParameterSet &ps)
 
 ~ESRawDataTask () override
 
- Public Member Functions inherited from one::DQMEDAnalyzer< T >
 DQMEDAnalyzer ()=default
 
 DQMEDAnalyzer (DQMEDAnalyzer< T... > const &)=delete
 
 DQMEDAnalyzer (DQMEDAnalyzer< T... > &&)=delete
 
 ~DQMEDAnalyzer () override=default
 

Protected Member Functions

void analyze (const edm::Event &e, const edm::EventSetup &c) override
 Analyze. More...
 
void bookHistograms (DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
 Setup. More...
 
void endJob (void) override
 EndJob. More...
 

Private Attributes

edm::EDGetTokenT< ESRawDataCollectiondccCollections_
 
edm::EDGetTokenT< FEDRawDataCollectionFEDRawDataCollection_
 
int ievt_
 
MonitorElementmeBXDCCErrors_
 
MonitorElementmeBXDiff_
 
MonitorElementmeL1ADCCErrors_
 
MonitorElementmeL1ADiff_
 
MonitorElementmeOrbitNumberDCCErrors_
 
MonitorElementmeOrbitNumberDiff_
 
std::string prefixME_
 
int runNum_
 

Detailed Description

Definition at line 15 of file ESRawDataTask.h.

Constructor & Destructor Documentation

ESRawDataTask::ESRawDataTask ( const edm::ParameterSet ps)

Definition at line 29 of file ESRawDataTask.cc.

References edm::ParameterSet::getParameter(), and edm::ParameterSet::getUntrackedParameter().

29  {
30 
31  prefixME_ = ps.getUntrackedParameter<string>("prefixME", "");
32 
33  FEDRawDataCollection_ = consumes<FEDRawDataCollection>(ps.getParameter<InputTag>("FEDRawDataCollection"));
34  dccCollections_ = consumes<ESRawDataCollection>(ps.getParameter<InputTag>("ESDCCCollections"));
35 
36  ievt_ = 0;
37 }
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< FEDRawDataCollection > FEDRawDataCollection_
Definition: ESRawDataTask.h:40
std::string prefixME_
Definition: ESRawDataTask.h:37
edm::EDGetTokenT< ESRawDataCollection > dccCollections_
Definition: ESRawDataTask.h:39
ESRawDataTask::~ESRawDataTask ( )
inlineoverride

Member Function Documentation

void ESRawDataTask::analyze ( const edm::Event e,
const edm::EventSetup c 
)
overrideprotected

Analyze.

Definition at line 87 of file ESRawDataTask.cc.

References edm::SortedCollection< T, SORT >::begin(), edm::EventBase::bunchCrossing(), FEDRawData::data(), DEFINE_FWK_MODULE, edm::SortedCollection< T, SORT >::end(), FEDRawDataCollection::FEDData(), ESDCCHeaderBlock::fedId(), ESDCCHeaderBlock::getBX(), edm::Event::getByToken(), ESDCCHeaderBlock::getLV1(), ESDCCHeaderBlock::getOrbitNumber(), RecoTauValidation_cfi::header, edm::EventBase::id(), edm::EventBase::orbitNumber(), edm::EventID::run(), and FEDRawData::size().

Referenced by ~ESRawDataTask().

87  {
88 
89  ievt_++;
90  runNum_ = e.id().run();
91 
92  int gt_L1A = 0, gt_OrbitNumber = 0, gt_BX = 0;
93  int esDCC_L1A_MostFreqCounts = 0;
94  int esDCC_BX_MostFreqCounts = 0;
95  int esDCC_OrbitNumber_MostFreqCounts = 0;
96 
98  Handle<FEDRawDataCollection> allFedRawData;
99 
100  int gtFedDataSize = 0;
101 
102  if ( e.getByToken(FEDRawDataCollection_, allFedRawData) ) {
103 
104  // GT FED data
105  const FEDRawData& gtFedData = allFedRawData->FEDData(812);
106 
107  gtFedDataSize = gtFedData.size()/sizeof(uint64_t);
108 
109  if ( gtFedDataSize > 0 ) {
110 
111  FEDHeader header(gtFedData.data());
112 
113  gt_L1A = header.lvl1ID();
114  gt_OrbitNumber = e.orbitNumber();
115  gt_BX = e.bunchCrossing();
116  } else {
117 
118  map<int, int> esDCC_L1A_FreqMap;
119  map<int, int> esDCC_BX_FreqMap;
120  map<int, int> esDCC_OrbitNumber_FreqMap;
121 
122  if ( e.getByToken(dccCollections_, dccs) ) {
123  for (ESRawDataCollection::const_iterator dccItr = dccs->begin(); dccItr != dccs->end(); ++dccItr) {
124  ESDCCHeaderBlock esdcc = (*dccItr);
125 
126  esDCC_L1A_FreqMap[esdcc.getLV1()]++;
127  esDCC_BX_FreqMap[esdcc.getBX()]++;
128  esDCC_OrbitNumber_FreqMap[esdcc.getOrbitNumber()]++;
129 
130  if (esDCC_L1A_FreqMap[esdcc.getLV1()] > esDCC_L1A_MostFreqCounts) {
131  esDCC_L1A_MostFreqCounts = esDCC_L1A_FreqMap[esdcc.getLV1()];
132  gt_L1A = esdcc.getLV1();
133  }
134 
135  if (esDCC_BX_FreqMap[esdcc.getBX()] > esDCC_BX_MostFreqCounts) {
136  esDCC_BX_MostFreqCounts = esDCC_BX_FreqMap[esdcc.getBX()];
137  gt_BX = esdcc.getBX();
138  }
139 
140  if (esDCC_OrbitNumber_FreqMap[esdcc.getOrbitNumber()] > esDCC_OrbitNumber_MostFreqCounts) {
141  esDCC_OrbitNumber_MostFreqCounts = esDCC_OrbitNumber_FreqMap[esdcc.getOrbitNumber()];
142  gt_OrbitNumber = esdcc.getOrbitNumber();
143  }
144 
145  }
146  } else {
147  LogWarning("ESRawDataTask") << "dccCollections not available";
148  }
149 
150  }
151  } else {
152  LogWarning("ESRawDataTask") << "FEDRawDataCollection not available";
153  }
154 
155  // DCC
156  vector<int> fiberStatus;
157  if ( e.getByToken(dccCollections_, dccs) ) {
158 
159  for (ESRawDataCollection::const_iterator dccItr = dccs->begin(); dccItr != dccs->end(); ++dccItr) {
160  ESDCCHeaderBlock dcc = (*dccItr);
161 
162  //if (dcc.getRunNumber() != runNum_) {
163  //meRunNumberErrors_->Fill(dcc.fedId());
164  //cout<<"Run # err : "<<dcc.getRunNumber()<<" "<<runNum_<<endl;
165  //}
166 
167  if (dcc.getLV1() != gt_L1A) {
168  meL1ADCCErrors_->Fill(dcc.fedId());
169  //cout<<"L1A err : "<<dcc.getLV1()<<" "<<gt_L1A<<endl;
170  Float_t l1a_diff = dcc.getLV1() - gt_L1A;
171  if (l1a_diff > 100) l1a_diff = 100;
172  else if (l1a_diff < -100) l1a_diff = -100;
173  meL1ADiff_->Fill(l1a_diff);
174  }
175 
176  if (dcc.getBX() != gt_BX) {
177  meBXDCCErrors_->Fill(dcc.fedId());
178  //cout<<"BX err : "<<dcc.getBX()<<" "<<gt_BX<<endl;
179  Float_t bx_diff = dcc.getBX() - gt_BX;
180  if (bx_diff > 100) bx_diff = 100;
181  else if (bx_diff < -100) bx_diff = -100;
182  meBXDiff_->Fill(bx_diff);
183  }
184  if (dcc.getOrbitNumber() != gt_OrbitNumber) {
186  //cout<<"Orbit err : "<<dcc.getOrbitNumber()<<" "<<gt_OrbitNumber<<endl;
187  Float_t orbitnumber_diff = dcc.getOrbitNumber() - gt_OrbitNumber;
188  if (orbitnumber_diff > 100) orbitnumber_diff = 100;
189  else if (orbitnumber_diff < -100) orbitnumber_diff = -100;
190  meOrbitNumberDiff_->Fill(orbitnumber_diff);
191  }
192  }
193  }
194 
195 }
RunNumber_t run() const
Definition: EventID.h:39
MonitorElement * meOrbitNumberDiff_
Definition: ESRawDataTask.h:48
int getLV1() const
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
MonitorElement * meOrbitNumberDCCErrors_
Definition: ESRawDataTask.h:45
std::vector< T >::const_iterator const_iterator
edm::EDGetTokenT< FEDRawDataCollection > FEDRawDataCollection_
Definition: ESRawDataTask.h:40
int bunchCrossing() const
Definition: EventBase.h:64
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:47
void Fill(long long x)
MonitorElement * meL1ADCCErrors_
Definition: ESRawDataTask.h:43
int getBX() const
const FEDRawData & FEDData(int fedid) const
retrieve data for fed
MonitorElement * meBXDCCErrors_
Definition: ESRawDataTask.h:44
int getOrbitNumber() const
int orbitNumber() const
Definition: EventBase.h:65
const_iterator end() const
edm::EDGetTokenT< ESRawDataCollection > dccCollections_
Definition: ESRawDataTask.h:39
unsigned long long uint64_t
Definition: Time.h:15
edm::EventID id() const
Definition: EventBase.h:59
MonitorElement * meL1ADiff_
Definition: ESRawDataTask.h:46
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:28
MonitorElement * meBXDiff_
Definition: ESRawDataTask.h:47
const int fedId() const
const_iterator begin() const
void ESRawDataTask::bookHistograms ( DQMStore::IBooker iBooker,
edm::Run const &  ,
edm::EventSetup const &   
)
overrideprotected

Setup.

Definition at line 39 of file ESRawDataTask.cc.

References DQMStore::IBooker::book1D(), trackerHits::histo, MonitorElement::setAxisTitle(), and DQMStore::IBooker::setCurrentFolder().

Referenced by ~ESRawDataTask().

40 {
41  char histo[200];
42 
43  iBooker.setCurrentFolder(prefixME_ + "/ESRawDataTask");
44 
45  //sprintf(histo, "ES run number errors");
46  //meRunNumberErrors_ = iBooker.book1D(histo, histo, 56, 519.5, 575.5);
47  //meRunNumberErrors_->setAxisTitle("ES FED", 1);
48  //meRunNumberErrors_->setAxisTitle("Num of Events", 2);
49 
50  sprintf(histo, "ES L1A DCC errors");
51  meL1ADCCErrors_ = iBooker.book1D(histo, histo, 56, 519.5, 575.5);
52  meL1ADCCErrors_->setAxisTitle("ES FED", 1);
53  meL1ADCCErrors_->setAxisTitle("Num of Events", 2);
54 
55  sprintf(histo, "ES BX DCC errors");
56  meBXDCCErrors_ = iBooker.book1D(histo, histo, 56, 519.5, 575.5);
57  meBXDCCErrors_->setAxisTitle("ES FED", 1);
58  meBXDCCErrors_->setAxisTitle("Num of Events", 2);
59 
60  sprintf(histo, "ES Orbit Number DCC errors");
61  meOrbitNumberDCCErrors_ = iBooker.book1D(histo, histo, 56, 519.5, 575.5);
63  meOrbitNumberDCCErrors_->setAxisTitle("Num of Events", 2);
64 
65  sprintf(histo, "Difference between ES and GT L1A");
66  meL1ADiff_ = iBooker.book1D(histo, histo, 201, -100.5, 100.5);
67  meL1ADiff_->setAxisTitle("ES - GT L1A", 1);
68  meL1ADiff_->setAxisTitle("Num of Events", 2);
69 
70  sprintf(histo, "Difference between ES and GT BX");
71  meBXDiff_ = iBooker.book1D(histo, histo, 201, -100.5, 100.5);
72  meBXDiff_->setAxisTitle("ES - GT BX", 1);
73  meBXDiff_->setAxisTitle("Num of Events", 2);
74 
75  sprintf(histo, "Difference between ES and GT Orbit Number");
76  meOrbitNumberDiff_ = iBooker.book1D(histo, histo, 201, -100.5, 100.5);
77  meOrbitNumberDiff_->setAxisTitle("ES - GT orbit number", 1);
78  meOrbitNumberDiff_->setAxisTitle("Num of Events", 2);
79 }
MonitorElement * meOrbitNumberDiff_
Definition: ESRawDataTask.h:48
MonitorElement * meOrbitNumberDCCErrors_
Definition: ESRawDataTask.h:45
std::string prefixME_
Definition: ESRawDataTask.h:37
MonitorElement * meL1ADCCErrors_
Definition: ESRawDataTask.h:43
void setCurrentFolder(std::string const &fullpath)
Definition: DQMStore.cc:268
MonitorElement * meBXDCCErrors_
Definition: ESRawDataTask.h:44
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:106
MonitorElement * meL1ADiff_
Definition: ESRawDataTask.h:46
MonitorElement * meBXDiff_
Definition: ESRawDataTask.h:47
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
void ESRawDataTask::endJob ( void  )
overrideprotected

EndJob.

Definition at line 81 of file ESRawDataTask.cc.

Referenced by ~ESRawDataTask().

81  {
82 
83  LogInfo("ESRawDataTask") << "analyzed " << ievt_ << " events";
84 
85 }

Member Data Documentation

edm::EDGetTokenT<ESRawDataCollection> ESRawDataTask::dccCollections_
private

Definition at line 39 of file ESRawDataTask.h.

edm::EDGetTokenT<FEDRawDataCollection> ESRawDataTask::FEDRawDataCollection_
private

Definition at line 40 of file ESRawDataTask.h.

int ESRawDataTask::ievt_
private

Definition at line 35 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meBXDCCErrors_
private

Definition at line 44 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meBXDiff_
private

Definition at line 47 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meL1ADCCErrors_
private

Definition at line 43 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meL1ADiff_
private

Definition at line 46 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meOrbitNumberDCCErrors_
private

Definition at line 45 of file ESRawDataTask.h.

MonitorElement* ESRawDataTask::meOrbitNumberDiff_
private

Definition at line 48 of file ESRawDataTask.h.

std::string ESRawDataTask::prefixME_
private

Definition at line 37 of file ESRawDataTask.h.

int ESRawDataTask::runNum_
private

Definition at line 50 of file ESRawDataTask.h.