CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Public Attributes | Private Member Functions | Private Attributes
CastorDataIntegrityMonitor Class Reference

#include <CastorDataIntegrityMonitor.h>

Inheritance diagram for CastorDataIntegrityMonitor:
CastorBaseMonitor

Public Member Functions

void beginRun (const edm::EventSetup &iSetup)
 
 CastorDataIntegrityMonitor ()
 
void cleanup ()
 
void processEvent (const FEDRawDataCollection &RawData, const HcalUnpackerReport &report, const CastorElectronicsMap &emap)
 
void reset ()
 
void setup (const edm::ParameterSet &ps, DQMStore *dbe)
 
void unpack (const FEDRawData &raw, const CastorElectronicsMap &emap)
 
 ~CastorDataIntegrityMonitor ()
 
- Public Member Functions inherited from CastorBaseMonitor
 CastorBaseMonitor ()
 
virtual void clearME ()
 
virtual void done ()
 
bool getDiagnostics () const
 
int getVerbosity () const
 
void setDiagnostics (bool myval)
 
void setVerbosity (int verb)
 
bool vetoCell (HcalCastorDetId id)
 
virtual ~CastorBaseMonitor ()
 

Public Attributes

std::map< uint32_t,
std::vector< HcalCastorDetId > > 
DCCtoCell
 
std::map< uint32_t,
std::vector< HcalCastorDetId >
>::iterator 
thisDCC
 

Private Member Functions

void fillzoos (int bin, int dccid)
 
void mapDCCproblem (int dcc)
 
void mapHTRproblem (int dcc, int spigot)
 
void UpdateMap ()
 

Private Attributes

std::map< int, short > CDFEventType_list
 
std::map< int, short >::iterator CDFEvT_it
 
bool CDFProbThisDCC
 
std::map< int, short >::iterator CDFReservedBits_it
 
std::map< int, short > CDFReservedBits_list
 
std::map< int, short >::iterator CDFvers_it
 
std::map< int, short > CDFversionNumber_list
 
std::map< int, short >::iterator DCCEvtFormat_it
 
std::map< int, short > DCCEvtFormat_list
 
int dccid
 
std::map< int, short >::iterator DCCRsvdBits_it
 
std::map< int, short > DCCRsvdBits_list
 
MonitorElementfedEntries
 
MonitorElementfedFatal
 
MonitorElementfedNonFatal
 
std::vector< int > fedUnpackList_
 
int ievt_
 
MonitorElementmeDCCVersion
 
MonitorElementmeEVT_
 
std::vector< std::vector< bool > > problemCASTOR
 
int problemsSpigot [15][3]
 
int spigotStatus
 
MonitorElementspigotStatusMap
 
double statusSpigotDCC
 

Additional Inherited Members

- Protected Attributes inherited from CastorBaseMonitor
std::string baseFolder_
 
edm::CPUTimer cpu_timer
 
int fVerbosity
 
DQMStorem_dbe
 
bool makeDiagnostics
 
std::string rootFolder_
 
bool showTiming
 

Detailed Description

Definition at line 10 of file CastorDataIntegrityMonitor.h.

Constructor & Destructor Documentation

CastorDataIntegrityMonitor::CastorDataIntegrityMonitor ( )

Definition at line 25 of file CastorDataIntegrityMonitor.cc.

25  {
26 }
CastorDataIntegrityMonitor::~CastorDataIntegrityMonitor ( )

Definition at line 32 of file CastorDataIntegrityMonitor.cc.

32  {
33 }

Member Function Documentation

void CastorDataIntegrityMonitor::beginRun ( const edm::EventSetup iSetup)

Definition at line 88 of file CastorDataIntegrityMonitor.cc.

References CastorBaseMonitor::baseFolder_, DQMStore::book1D(), DQMStore::book2D(), DQMStore::bookInt(), gather_cfg::cout, fedEntries, fedFatal, CastorBaseMonitor::fVerbosity, CastorBaseMonitor::m_dbe, meEVT_, NULL, DQMStore::setCurrentFolder(), and spigotStatusMap.

Referenced by CastorMonitorModule::beginRun().

88  {
89 
90  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::beginRun (start)" << std::endl;
91 
92  if ( m_dbe !=NULL ) {
95  meEVT_ = m_dbe->bookInt("Digi Task Event Number");
96  fedEntries = m_dbe->book1D("FEDEntries_CASTOR" ,"Number of Entries per CASTOR FED",3,690,693); //-- FED 693 take out for the time being
97  fedFatal = m_dbe->book1D("CASTOR FEDFatal errors" ,"Number of Fatal Errors per CASTOR FED",3,690,693); //-- FED 693 take out for the time being
98  //fedNonFatal = m_dbe->book1D("FEDNonFatal_CASTOR","Number of non-fatal errors CASTOR FED",3,690,693); //-- take it out for the time being
99 
100  //meDCCVersion = m_dbe->bookProfile("DCC Firmware Version","DCC Firmware Version", 3, 690, 693, 256, -0.5, 255.5);
101  //meDCCVersion->setAxisTitle("FED ID", 1);
102  spigotStatusMap = m_dbe->book2D("CASTOR spigot status","CASTOR spigot status",15,0,15,4,690,694); //-- get some space for the legend
103 
104  }
105 
106  else{
107  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::setup - NO DQMStore service" << std::endl;
108  }
109 
110 
111  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::beginRun (end)" << std::endl;
112 
113 
114  return;
115 }
MonitorElement * book1D(const char *name, const char *title, int nchX, double lowX, double highX)
Book 1D histogram.
Definition: DQMStore.cc:954
#define NULL
Definition: scimark2.h:8
std::string baseFolder_
tuple cout
Definition: gather_cfg.py:121
MonitorElement * bookInt(const char *name)
Book int.
Definition: DQMStore.cc:861
MonitorElement * book2D(const char *name, const char *title, int nchX, double lowX, double highX, int nchY, double lowY, double highY)
Book 2D histogram.
Definition: DQMStore.cc:1082
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:667
void CastorDataIntegrityMonitor::cleanup ( )

Definition at line 47 of file CastorDataIntegrityMonitor.cc.

47  {
48 
49 }
void CastorDataIntegrityMonitor::fillzoos ( int  bin,
int  dccid 
)
private
void CastorDataIntegrityMonitor::mapDCCproblem ( int  dcc)
private
void CastorDataIntegrityMonitor::mapHTRproblem ( int  dcc,
int  spigot 
)
private
void CastorDataIntegrityMonitor::processEvent ( const FEDRawDataCollection RawData,
const HcalUnpackerReport report,
const CastorElectronicsMap emap 
)

— check the spigot arrays

Definition at line 123 of file CastorDataIntegrityMonitor.cc.

References gather_cfg::cout, FEDRawDataCollection::FEDData(), fedUnpackList_, MonitorElement::Fill(), CastorBaseMonitor::fVerbosity, MonitorElement::getTH2F(), i, ievt_, meEVT_, problemsSpigot, FEDRawData::size(), spigotStatusMap, statusSpigotDCC, and unpack().

Referenced by CastorMonitorModule::analyze().

124  {
125  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::processEvent (begin)" << std::endl;
126 
127  meEVT_->Fill(ievt_);
128 
130  ievt_++;
131 
133  for (std::vector<int>::const_iterator i=fedUnpackList_.begin();i!=fedUnpackList_.end(); i++) {
134  const FEDRawData& fed = RawData.FEDData(*i);
135  if (fed.size()<12) continue;
136  unpack(fed,emap);
137  }
138 
140  for (int spigot=0; spigot<15; spigot++){
141  for (int dcc=0; dcc<3; dcc++){
142 
143  if( problemsSpigot[spigot][dcc] == 0) statusSpigotDCC=1.0;
144  else if( double(problemsSpigot[spigot][dcc])/double(ievt_) < 0.05) statusSpigotDCC=0.;
145  else statusSpigotDCC=-1.0;
147  spigotStatusMap->getTH2F()->SetBinContent(spigot+1,dcc+1,statusSpigotDCC);
148  if(fVerbosity>1)
149  std::cout<< "==> SpigotNr:"<< spigot+1 <<" DCC_ID:"<< dcc+690 << " # problems=" << problemsSpigot[spigot][dcc]
150  << "==> ievt_:"<< ievt_ << " ratio=" << double(problemsSpigot[spigot][dcc])/double(ievt_) << " STATUS=" << statusSpigotDCC << std::endl;
151  }
152  }
153 
154  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::processEvent (end)" << std::endl;
155 
156  return;
157 }
int i
Definition: DBlmapReader.cc:9
void unpack(const FEDRawData &raw, const CastorElectronicsMap &emap)
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:47
void Fill(long long x)
const FEDRawData & FEDData(int fedid) const
retrieve data for fed
tuple cout
Definition: gather_cfg.py:121
TH2F * getTH2F(void) const
void CastorDataIntegrityMonitor::reset ( void  )

Definition at line 39 of file CastorDataIntegrityMonitor.cc.

Referenced by CastorMonitorModule::reset().

39  {
40 
41 }
void CastorDataIntegrityMonitor::setup ( const edm::ParameterSet ps,
DQMStore dbe 
)
virtual

Reimplemented from CastorBaseMonitor.

Definition at line 55 of file CastorDataIntegrityMonitor.cc.

References CastorBaseMonitor::baseFolder_, CDFProbThisDCC, cuy::col, gather_cfg::cout, fedUnpackList_, CastorBaseMonitor::fVerbosity, i, ievt_, FEDNumbering::MAXCASTORFEDID, FEDNumbering::MINCASTORFEDID, problemsSpigot, CastorBaseMonitor::rootFolder_, CastorBaseMonitor::setup(), spigotStatus, and statusSpigotDCC.

Referenced by CastorMonitorModule::CastorMonitorModule().

56 {
57 
58  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::setup (start)" << std::endl;
60  baseFolder_ = rootFolder_+"CastorDataIntegrityMonitor";
61  ievt_=0;
62  spigotStatus=-99;
63  statusSpigotDCC=-99;
64  CDFProbThisDCC = false;
65 
66 
68  for (int row=0; row<15; row++)
69  for (int col=0; col<3; col++)
70  problemsSpigot[row][col] = 0;
71 
72 
73 
76  fedUnpackList_.push_back(i);
77 
78  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor::setup (end)" << std::endl;
79 
80  return;
81 
82 }
int i
Definition: DBlmapReader.cc:9
virtual void setup(const edm::ParameterSet &ps, DQMStore *dbe)
std::string baseFolder_
std::string rootFolder_
tuple cout
Definition: gather_cfg.py:121
int col
Definition: cuy.py:1008
void CastorDataIntegrityMonitor::unpack ( const FEDRawData raw,
const CastorElectronicsMap emap 
)

Definition at line 164 of file CastorDataIntegrityMonitor.cc.

References HcalDCCHeader::BOEshouldBe5Always(), HcalDCCHeader::BOEshouldBeZeroAlways(), CDFEventType_list, CDFEvT_it, CDFProbThisDCC, CDFReservedBits_it, CDFReservedBits_list, CDFvers_it, CDFversionNumber_list, FEDTrailer::check(), HcalHTRData::check(), gather_cfg::cout, FEDRawData::data(), dccid, fedEntries, fedFatal, MonitorElement::Fill(), CastorBaseMonitor::fVerbosity, HcalDCCHeader::getCDFEventType(), HcalDCCHeader::getCDFversionNumber(), HcalDCCHeader::getLRBErrorBits(), HcalDCCHeader::getSlink64ReservedBits(), HcalDCCHeader::getSourceId(), HcalDCCHeader::getSpigotCRCError(), HcalDCCHeader::getSpigotData(), HcalDCCHeader::getSpigotDataLength(), HcalDCCHeader::getSpigotDataTruncated(), HcalDCCHeader::getSpigotEnabled(), HcalDCCHeader::getSpigotPresent(), HcalHTRData::isHistogramEvent(), FEDTrailer::lenght(), FEDTrailer::moreTrailers(), problemsSpigot, FEDRawData::size(), HcalDCCHeader::SPIGOT_COUNT, spigotStatus, HcalDCCHeader::thereIsASecondCDFHeaderWord(), and HcalDCCHeader::thereIsAThirdCDFHeaderWord().

Referenced by processEvent().

164  {
165 
166 
168  const HcalDCCHeader* dccHeader=(const HcalDCCHeader*)(raw.data());
169  if(!dccHeader) return;
170 
172  unsigned char* trailer_ptr = (unsigned char*) (raw.data()+raw.size()-sizeof(uint64_t));
173  FEDTrailer trailer = FEDTrailer(trailer_ptr);
174 
175  dccid=dccHeader->getSourceId();
176 
177  HcalHTRData htr;
178 
180  CDFProbThisDCC = false;
181 
182 
183  //================ BASIC CHECKS OF DATA INTEGRITY ====================//
184 
185 
187 
188  /* 1 */ //There should always be a second CDF header word indicated.
189  if (!dccHeader->thereIsASecondCDFHeaderWord())
190  {
191  CDFProbThisDCC = true;
192  }
193 
194  /* 2 */ //Make sure a reference CDF Version value has been recorded for this dccid
196  if (CDFvers_it == CDFversionNumber_list.end())
197  {
198  CDFversionNumber_list.insert(std::pair<int,short>
199  (dccid,dccHeader->getCDFversionNumber() ) );
201  } // then check against it.
202 
203  if (dccHeader->getCDFversionNumber()!= CDFvers_it->second)
204  {
205  CDFProbThisDCC = true;
206  }
207 
208  /* 3 */ //Make sure a reference CDF EventType value has been recorded for this dccid
210  if (CDFEvT_it == CDFEventType_list.end())
211  {
212  CDFEventType_list.insert(std::pair<int,short>
213  (dccid,dccHeader->getCDFEventType() ) );
215  } // then check against it.
216 
217  if (dccHeader->getCDFEventType()!= CDFEvT_it->second)
218  {
219  // On probation until safe against Orbit Gap Calibration Triggers...
220  CDFProbThisDCC = true;
221  }
222 
223  /* 4 */ //There should always be a '5' in CDF Header word 0, bits [63:60]
224  if (dccHeader->BOEshouldBe5Always()!=5)
225  {
226  CDFProbThisDCC = true;
227  }
228 
229  /* 5 */ //There should never be a third CDF Header word indicated.
230  if (dccHeader->thereIsAThirdCDFHeaderWord())
231  {
232  CDFProbThisDCC = true;
233  }
234 
235  /* 6 */ //Make sure a reference value of Reserved Bits has been recorded for this dccid
236 
239  CDFReservedBits_list.insert(std::pair<int,short>
240  (dccid,dccHeader->getSlink64ReservedBits() ) );
242  } // then check against it.
243 
244  if ((int) dccHeader->getSlink64ReservedBits()!= CDFReservedBits_it->second)
245  {
246  // On probation until safe against Orbit Gap Calibration Triggers...
247  // CDFProbThisDCC = true;
248  }
249 
250  /* 7 */ //There should always be 0x0 in CDF Header word 1, bits [63:60]
251  if (dccHeader->BOEshouldBeZeroAlways() !=0)
252  {
253  CDFProbThisDCC = true;
254  }
255 
256  /* 8 */ //There should only be one trailer
257  if (trailer.moreTrailers())
258  {
259  CDFProbThisDCC = true;
260  }
261  // if trailer.
262 
263  /* 9 */ //CDF Trailer [55:30] should be the # 64-bit words in the EvFragment
264  if ((uint64_t) raw.size() != ( (uint64_t) trailer.lenght()*sizeof(uint64_t)) ) //The function name is a typo! Awesome.
265  {
266  CDFProbThisDCC = true;
267  }
268  /*10 */ //There is a rudimentary sanity check built into the FEDTrailer class
269  if (!trailer.check())
270  {
271  CDFProbThisDCC = true;
272  }
273 
276 
279 
280 
281 
282  //================== do similar what HCALRawDataMonitor does
284  //uint64_t* dccfw= (uint64_t*) (raw.data()+(sizeof(uint64_t)*2)); //64-bit DAQ word number 2 (from 0)
285  //int dcc_fw = ( ((*dccfw)>>(6*8))&0x00000000000000FF ); //Shift right 6 bytes, get that low byte.
286  //meDCCVersion->Fill(dccid,dcc_fw);
287  //char TTS_state = (char)trailer.ttsBits();
288 
289  //errors per-Spigot bits from the DCC Header
290  int WholeErrorList=0;
291 
293  for(int spigot=0; spigot<HcalDCCHeader::SPIGOT_COUNT; spigot++) {
294 
295  if (!( dccHeader->getSpigotEnabled((unsigned int) spigot)) ) continue; //-- skip when not enabled
296 
297  //-- set OK here
298  spigotStatus=1;
299  //-- get DCC id
300  dccid=dccHeader->getSourceId();
301 
302  if (dccid==693) continue; //-- skip this one
303 
305  WholeErrorList=dccHeader->getLRBErrorBits((unsigned int) spigot);
306  if (WholeErrorList!=0) {
307 
308  if ((WholeErrorList>>0)&0x01) {
309  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error==> " << std::endl;
310  spigotStatus=-1;
311  ++problemsSpigot[spigot][dccid-690];
312  }
313 
314  if (((WholeErrorList>>1)&0x01)!=0) {
315  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error ==> Uncorrected Error" << std::endl;
316  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
317  spigotStatus=-1;
318  }
319 
320  if (((WholeErrorList>>2)&0x01)!=0) {
321  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error ==> Truncated data coming into LRB" << std::endl;
322  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
323  spigotStatus=-1;
324  }
325 
326  if (((WholeErrorList>>3)&0x01)!=0) {
327  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor: error ==>: FIFO Overflow" << std::endl;
328  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
329  spigotStatus=-1;
330  }
331 
332  if (((WholeErrorList>>4)&0x01)!=0) {
333  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error ==> (EvN Mismatch), htr payload metadeta" << std::endl;
334  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
335  spigotStatus=-1;
336  }
337 
338  if (((WholeErrorList>>5)&0x01)!=0) {
339  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error ==> STatus: hdr/data/trlr error" << std::endl;
340  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
341  spigotStatus=-1;
342  }
343 
344  if (((WholeErrorList>>6)&0x01)!=0) {
345  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: error ==> ODD 16-bit word count from HT error" << std::endl;
346  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
347  spigotStatus=-1;
348  }
349 
350  }
351 
353 
354  if (!dccHeader->getSpigotPresent((unsigned int) spigot)){
355  if(fVerbosity>0) std::cout <<"CastorDataIntegrityMonitor:: HTR Problem: Spigot Not Present"<<std::endl;
356  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
357  spigotStatus=-1;
358  }
359  else {
360  if ( dccHeader->getSpigotDataTruncated((unsigned int) spigot)) {
361  if(fVerbosity>0) std::cout <<"CastorDataIntegrityMonitor:: HTR Problem: Spigot Data Truncated"<<std::endl;
362  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
363  spigotStatus=-1;
364  }
365  if ( dccHeader->getSpigotCRCError((unsigned int) spigot)) {
366  if(fVerbosity>0) std::cout <<"CastorDataIntegrityMonitor:: HTR Problem: Spigot CRC Error"<<std::endl;
367  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
368  spigotStatus=-1;
369  }
370  if (dccHeader->getSpigotDataLength(spigot) <(unsigned long)4) {
371  if(fVerbosity>0) std::cout <<"CastorDataIntegrityMonitor:: HTR Problem: Spigot Data Length too small"<<std::endl;
372  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
373  spigotStatus=-1;
374  }
375 
376  if (dccHeader->getSpigotData(spigot,htr,raw.size())==-1) {
377  if(fVerbosity>0) std::cout<< "CastorDataIntegrityMonitor:: Invalid HTR data (data beyond payload size) observed on spigot " << spigot
378  << " of DCC with source id " << dccHeader->getSourceId()<< std::endl;
379  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
380  spigotStatus=-1;
381  }
382 
383  if (!htr.check()) {
384  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: Invalid HTR data observed on spigot " << spigot << " of DCC with source id " << dccHeader->getSourceId() << std::endl;
385  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
386  spigotStatus=-1;
387  }
388 
389  if (htr.isHistogramEvent()) {
390  if(fVerbosity>0) std::cout << "CastorDataIntegrityMonitor:: Histogram data passed to non-histogram unpacker on spigot " << spigot << " of DCC with source id "
391  << dccHeader->getSourceId() << std::endl;
392  if(spigotStatus>0) ++problemsSpigot[spigot][dccid-690];
393  spigotStatus=-1;
394  }
395 
396  }
397 
398  } //-- end of loop over spigots
399 
400  return;
401 }
std::map< int, short > CDFEventType_list
bool check()
Definition: FEDTrailer.cc:64
unsigned int getSlink64ReservedBits() const
Definition: HcalDCCHeader.h:48
unsigned int getSpigotDataLength(int nspigot) const
Definition: HcalDCCHeader.h:96
bool check() const
Check for a good event Requires a minimum length, matching wordcount and length, not an empty event...
Definition: HcalHTRData.cc:62
bool getSpigotCRCError(unsigned int nspigot) const
Read the &quot;CRC-Mismatch&quot; bit for this spigot.
bool moreTrailers()
Definition: FEDTrailer.cc:37
bool thereIsAThirdCDFHeaderWord() const
Definition: HcalDCCHeader.h:44
int getSpigotData(int nspigot, HcalHTRData &decodeTool, int validSize) const
unsigned char getLRBErrorBits(unsigned int nspigot) const
Access the Link Receiver Board error bits (decoding tbd)
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:47
std::map< int, short >::iterator CDFvers_it
void Fill(long long x)
std::map< int, short > CDFReservedBits_list
bool getSpigotPresent(unsigned int nspigot) const
Read the &quot;PRESENT&quot; bit for this spigot.
unsigned short getCDFEventType() const
Definition: HcalDCCHeader.h:38
std::map< int, short >::iterator CDFReservedBits_it
bool getSpigotEnabled(unsigned int nspigot) const
Read the &quot;ENABLED&quot; bit for this spigot.
Definition: HcalDCCHeader.h:99
int getSourceId() const
Definition: HcalDCCHeader.h:32
unsigned long long uint64_t
Definition: Time.h:15
int lenght()
The length of the event fragment counted in 64-bit words including header and trailer.
Definition: FEDTrailer.cc:17
std::map< int, short > CDFversionNumber_list
short BOEshouldBeZeroAlways() const
Definition: HcalDCCHeader.h:50
std::map< int, short >::iterator CDFEvT_it
static const int SPIGOT_COUNT
Definition: HcalDCCHeader.h:19
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:28
bool getSpigotDataTruncated(unsigned int nspigot) const
Read the &quot;TRUNCATED&quot; bit for this spigot; LRB truncated data (took too long)
tuple cout
Definition: gather_cfg.py:121
short getCDFversionNumber() const
Definition: HcalDCCHeader.h:30
unsigned short BOEshouldBe5Always() const
Definition: HcalDCCHeader.h:40
bool thereIsASecondCDFHeaderWord() const
Definition: HcalDCCHeader.h:28
bool isHistogramEvent() const
Is this event a histogram event? (do not call standard unpack in this case!!!!!)
Definition: HcalHTRData.cc:385
void CastorDataIntegrityMonitor::UpdateMap ( )
private

Member Data Documentation

std::map<int, short> CastorDataIntegrityMonitor::CDFEventType_list
private

Definition at line 66 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short>::iterator CastorDataIntegrityMonitor::CDFEvT_it
private

Definition at line 67 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

bool CastorDataIntegrityMonitor::CDFProbThisDCC
private

Definition at line 45 of file CastorDataIntegrityMonitor.h.

Referenced by setup(), and unpack().

std::map<int, short>::iterator CastorDataIntegrityMonitor::CDFReservedBits_it
private

Definition at line 69 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short> CastorDataIntegrityMonitor::CDFReservedBits_list
private

Definition at line 68 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short>::iterator CastorDataIntegrityMonitor::CDFvers_it
private

Definition at line 65 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short> CastorDataIntegrityMonitor::CDFversionNumber_list
private

Definition at line 64 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short>::iterator CastorDataIntegrityMonitor::DCCEvtFormat_it
private

Definition at line 71 of file CastorDataIntegrityMonitor.h.

std::map<int, short> CastorDataIntegrityMonitor::DCCEvtFormat_list
private

Definition at line 70 of file CastorDataIntegrityMonitor.h.

int CastorDataIntegrityMonitor::dccid
private

Definition at line 43 of file CastorDataIntegrityMonitor.h.

Referenced by unpack().

std::map<int, short>::iterator CastorDataIntegrityMonitor::DCCRsvdBits_it
private

Definition at line 73 of file CastorDataIntegrityMonitor.h.

std::map<int, short> CastorDataIntegrityMonitor::DCCRsvdBits_list
private

Definition at line 72 of file CastorDataIntegrityMonitor.h.

std::map<uint32_t, std::vector<HcalCastorDetId> > CastorDataIntegrityMonitor::DCCtoCell

Definition at line 29 of file CastorDataIntegrityMonitor.h.

MonitorElement* CastorDataIntegrityMonitor::fedEntries
private

Definition at line 56 of file CastorDataIntegrityMonitor.h.

Referenced by beginRun(), and unpack().

MonitorElement* CastorDataIntegrityMonitor::fedFatal
private

Definition at line 57 of file CastorDataIntegrityMonitor.h.

Referenced by beginRun(), and unpack().

MonitorElement* CastorDataIntegrityMonitor::fedNonFatal
private

Definition at line 58 of file CastorDataIntegrityMonitor.h.

std::vector<int> CastorDataIntegrityMonitor::fedUnpackList_
private

Definition at line 42 of file CastorDataIntegrityMonitor.h.

Referenced by processEvent(), and setup().

int CastorDataIntegrityMonitor::ievt_
private

Definition at line 44 of file CastorDataIntegrityMonitor.h.

Referenced by processEvent(), and setup().

MonitorElement* CastorDataIntegrityMonitor::meDCCVersion
private

Definition at line 60 of file CastorDataIntegrityMonitor.h.

MonitorElement* CastorDataIntegrityMonitor::meEVT_
private

Definition at line 55 of file CastorDataIntegrityMonitor.h.

Referenced by beginRun(), and processEvent().

std::vector<std::vector<bool> > CastorDataIntegrityMonitor::problemCASTOR
private

Definition at line 34 of file CastorDataIntegrityMonitor.h.

int CastorDataIntegrityMonitor::problemsSpigot[15][3]
private

Definition at line 51 of file CastorDataIntegrityMonitor.h.

Referenced by processEvent(), setup(), and unpack().

int CastorDataIntegrityMonitor::spigotStatus
private

Definition at line 46 of file CastorDataIntegrityMonitor.h.

Referenced by setup(), and unpack().

MonitorElement* CastorDataIntegrityMonitor::spigotStatusMap
private

Definition at line 61 of file CastorDataIntegrityMonitor.h.

Referenced by beginRun(), and processEvent().

double CastorDataIntegrityMonitor::statusSpigotDCC
private

Definition at line 47 of file CastorDataIntegrityMonitor.h.

Referenced by processEvent(), and setup().

std::map<uint32_t, std::vector<HcalCastorDetId> >::iterator CastorDataIntegrityMonitor::thisDCC

Definition at line 30 of file CastorDataIntegrityMonitor.h.