CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
RawTask.cc
Go to the documentation of this file.
2 
3 
4 using namespace hcaldqm;
5 using namespace hcaldqm::constants;
6 
8  DQTask(ps)
9 {
11  edm::InputTag("rawDataCollector"));
13  edm::InputTag("hcalDigis"));
14  _calibProcessing = ps.getUntrackedParameter<bool>("calibProcessing",
15  false);
16  _thresh_calib_nbadq = ps.getUntrackedParameter<int>("thresh_calib_nbadq",
17  5000);
18 
19  _tokFEDs = consumes<FEDRawDataCollection>(_tagFEDs);
20  _tokReport = consumes<HcalUnpackerReport>(_tagReport);
21 
22  _vflags.resize(nRawFlag);
23  _vflags[fEvnMsm]=flag::Flag("EvnMsm");
24  _vflags[fBcnMsm]=flag::Flag("BcnMsm");
25  _vflags[fBadQ]=flag::Flag("BadQ");
26  _vflags[fOrnMsm]=flag::Flag("OrnMsm");
27 }
28 
30  edm::Run const& r, edm::EventSetup const& es)
31 {
32  DQTask::bookHistograms(ib,r,es);
33 
34  // GET WHAT YOU NEED
36  es.get<HcalDbRecord>().get(dbs);
37  _emap = dbs->getHcalMapping();
38  std::vector<int> vFEDs = hcaldqm::utilities::getFEDList(_emap);
39  std::vector<int> vFEDsVME = hcaldqm::utilities::getFEDVMEList(_emap);
40  std::vector<int> vFEDsuTCA = hcaldqm::utilities::getFEDuTCAList(_emap);
41  std::vector<uint32_t> vVME;
42  std::vector<uint32_t> vuTCA;
43  std::vector<uint32_t> vhashFEDsVME;
44  std::vector<uint32_t> vhashFEDsuTCA;
48  FIBER_uTCA_MIN1, FIBERCH_MIN, false).rawId());
50  vVME);
52  vuTCA);
53 
54  for (std::vector<int>::const_iterator it=vFEDsVME.begin();
55  it!=vFEDsVME.end(); ++it)
56  {
57  vhashFEDsVME.push_back(HcalElectronicsId(constants::FIBERCH_MIN,
59  (*it)-constants::FED_VME_MIN).rawId());
62  (*it)-constants::FED_VME_MIN).rawId());
63  }
64  for (std::vector<int>::const_iterator it=vFEDsuTCA.begin();
65  it!=vFEDsuTCA.end(); ++it)
66  {
67  std::pair<uint16_t, uint16_t> cspair = utilities::fed2crate(*it);
68  vhashFEDsuTCA.push_back(HcalElectronicsId(
69  cspair.first, cspair.second, FIBER_uTCA_MIN1,
70  FIBERCH_MIN, false).rawId());
71  _vhashFEDs.push_back(HcalElectronicsId(
72  cspair.first, cspair.second, FIBER_uTCA_MIN1,
73  FIBERCH_MIN, false).rawId());
74  }
76  hcaldqm::hashfunctions::fFED, vhashFEDsVME);
78  hcaldqm::hashfunctions::fFED, vhashFEDsuTCA);
79 
80  // INITIALIZE FIRST
83  new hcaldqm::quantity::FEDQuantity(vFEDsVME),
88  new hcaldqm::quantity::FEDQuantity(vFEDsVME),
93  new hcaldqm::quantity::FEDQuantity(vFEDsVME),
98  new hcaldqm::quantity::FEDQuantity(vFEDsuTCA),
103  new hcaldqm::quantity::FEDQuantity(vFEDsuTCA),
108  new hcaldqm::quantity::FEDQuantity(vFEDsuTCA),
111 
112  // Bad Quality
113  _cBadQuality_FEDVME.initialize(_name, "BadQuality",
118  _cBadQuality_FEDuTCA.initialize(_name, "BadQuality",
123  _cBadQualityvsLS.initialize(_name, "BadQualityvsLS",
126  _cBadQualityvsBX.initialize(_name, "BadQualityvsBX",
129  _cBadQuality_depth.initialize(_name, "BadQuality",
134 
135  // INITIALIZE HISTOGRAMS to be used in Online Only
136  if (_ptype==fOnline)
137  {
142  _cSummaryvsLS_FED.initialize(_name, "SummaryvsLS",
147  _cSummaryvsLS.initialize(_name, "SummaryvsLS",
151  // FED Size vs LS
152  _cDataSizevsLS_FED.initialize(_name, "DataSizevsLS",
156  }
157 
158  // BOOK HISTOGRAMS
165 
166 
172 
173  // BOOK HISTOGRAMS to be used in ONLINE ONLY!
174  if (_ptype==fOnline)
175  {
183  }
184 
185  // FOR OFFLINE PROCESSING MARK THESE HISTOGRAMS AS LUMI BASED
186  if (_ptype==fOffline)
187  {
193  }
194 
195  // initialize hash map
197 }
198 
200 {
201  // base reset
202  DQTask::_resetMonitors(uf);
203 }
204 
205 /* virtual */ void RawTask::_process(edm::Event const& e,
206  edm::EventSetup const&)
207 {
210  if (!e.getByToken(_tokFEDs, craw))
211  _logger.dqmthrow("Collection FEDRawDataCollection isn't available"+
212  _tagFEDs.label()+" " +_tagFEDs.instance());
213  if (!e.getByToken(_tokReport, creport))
214  _logger.dqmthrow("Collection HcalUnpackerReport isn't available"+
216 
217  // extract some info
218  int bx = e.bunchCrossing();
219 
220  /*
221  * For Calibration/Abort Gap Processing
222  * check if the #channels taht are bad from the unpacker
223  * is > 5000. If it is skip...
224  */
225  if (_calibProcessing)
226  {
227  int nbadq = creport->badQualityDigis();
228  if (nbadq>=_thresh_calib_nbadq)
229  return;
230  }
231 
232  int nn = 0;
233  // loop thru and fill the detIds with bad quality
234  // NOTE: Calibration Channels are skipped!
235  // TODO: Include for Online Calibration Channels marked as bad
236  // a comment below is left on purpose!
237  //_cBadQualityvsBX.fill(bx, creport->badQualityDigis());
238  for (std::vector<DetId>::const_iterator it=creport->bad_quality_begin();
239  it!=creport->bad_quality_end(); ++it)
240  {
241  // skip non HCAL det ids
242  if (!HcalGenericDetId(*it).isHcalDetId())
243  continue;
244 
245  // skip those that are of bad quality from conditions
246  // Masked or Dead
247  if (_xQuality.exists(HcalDetId(*it)))
248  {
249  HcalChannelStatus cs(it->rawId(), _xQuality.get(HcalDetId(*it)));
250  if (cs.isBitSet(HcalChannelStatus::HcalCellMask) ||
252  continue;
253  }
254 
255  nn++;
258  // ONLINE ONLY!
259  if (_ptype==fOnline)
260  _xBadQLS.get(eid)++;
261  if (eid.isVMEid())
262  {
263  if (_filter_FEDsVME.filter(eid))
264  continue;
266  }
267  else
268  {
269  if (_filter_FEDsuTCA.filter(eid))
270  continue;
272  }
273  }
275  _cBadQualityvsBX.fill(bx, nn);
276 
277  for (int fed=FEDNumbering::MINHCALFEDID;
278  fed<=FEDNumbering::MAXHCALuTCAFEDID; fed++)
279  {
280  // skip nonHCAL FEDs
281  if ((fed>FEDNumbering::MAXHCALFEDID &&
284  continue;
285  FEDRawData const& raw = craw->FEDData(fed);
286  if (raw.size()<constants::RAW_EMPTY)
287  continue;
288 
289  if (fed<=FEDNumbering::MAXHCALFEDID) // VME
290  {
291  HcalDCCHeader const* hdcc = (HcalDCCHeader const*)(raw.data());
292  if (!hdcc)
293  continue;
294 
295  uint32_t bcn = hdcc->getBunchId();
296  uint32_t orn = hdcc->getOrbitNumber() & 0x1F; // LS 5 bits only
297  uint32_t evn = hdcc->getDCCEventNumber();
299 
300  /* online only */
301  if (_ptype==fOnline)
302  {
305  if (_filter_FEDsVME.filter(eid))
306  continue;
307  _cDataSizevsLS_FED.fill(eid, _currentLS, double(raw.size())/1024.);
308  }
309 
310  // iterate over spigots
311  HcalHTRData htr;
312  for (int is=0; is<HcalDCCHeader::SPIGOT_COUNT; is++)
313  {
314  int r = hdcc->getSpigotData(is, htr, raw.size());
315  if (r!=0 || !htr.check())
316  continue;
319  is, dccId);
320  if (_filter_FEDsVME.filter(eid))
321  continue;
322 
323  uint32_t htr_evn = htr.getL1ANumber();
324  uint32_t htr_orn = htr.getOrbitNumber();
325  uint32_t htr_bcn = htr.getBunchNumber();
326  bool qevn = (htr_evn!=evn);
327  bool qbcn = (htr_bcn!=bcn);
328  bool qorn = (htr_orn!=orn);
329  if (qevn)
330  {
332 
334  _xEvnMsmLS.get(eid)++;
335  }
336  if (qorn)
337  {
339 
341  _xOrnMsmLS.get(eid)++;
342  }
343  if (qbcn)
344  {
346 
348  _xBcnMsmLS.get(eid)++;
349  }
350  }
351  }
352  else // uTCA
353  {
354  hcal::AMC13Header const* hamc13 = (hcal::AMC13Header const*)
355  raw.data();
356  if (!hamc13)
357  continue;
358 
359  /* online only */
360  if (_ptype==fOnline)
361  {
362  std::pair<uint16_t, uint16_t> cspair = utilities::fed2crate(fed);
363  HcalElectronicsId eid = HcalElectronicsId(cspair.first,
364  cspair.second, FIBER_uTCA_MIN1, FIBERCH_MIN, false);
365  if (_filter_FEDsuTCA.filter(eid))
366  continue;
367  _cDataSizevsLS_FED.fill(eid, _currentLS, double(raw.size())/1024.);
368  }
369 
370  uint32_t bcn = hamc13->bunchId();
371  uint32_t orn = hamc13->orbitNumber() & 0xFFFF; // LS 16bits only
372  uint32_t evn = hamc13->l1aNumber();
373  int namc = hamc13->NAMC();
374 
375  for (int iamc=0; iamc<namc; iamc++)
376  {
377  int slot = hamc13->AMCSlot(iamc);
378  int crate = hamc13->AMCId(iamc)&0xFF;
379  HcalElectronicsId eid(crate, slot, FIBER_uTCA_MIN1,
380  FIBERCH_MIN, false);
381  if (_filter_FEDsuTCA.filter(eid))
382  continue;
383  HcalUHTRData uhtr(hamc13->AMCPayload(iamc),
384  hamc13->AMCSize(iamc));
385 
386  uint32_t uhtr_evn = uhtr.l1ANumber();
387  uint32_t uhtr_bcn = uhtr.bunchNumber();
388  uint32_t uhtr_orn = uhtr.orbitNumber();
389  bool qevn = (uhtr_evn!=evn);
390  bool qbcn = (uhtr_bcn!=bcn);
391  bool qorn = (uhtr_orn!=orn);
392  if (qevn)
393  {
395 
396  if (_ptype==fOnline)
397  _xEvnMsmLS.get(eid)++;
398  }
399  if (qorn)
400  {
402 
403  if (_ptype==fOnline)
404  _xOrnMsmLS.get(eid)++;
405  }
406  if (qbcn)
407  {
409 
410  if (_ptype==fOnline)
411  _xBcnMsmLS.get(eid)++;
412  }
413  }
414  }
415  }
416 }
417 
419  edm::EventSetup const& es)
420 {
421  DQTask::beginLuminosityBlock(lb, es);
422 
423 // _cBadQualityvsLS.extendAxisRange(_currentLS);
424 
425  // ONLINE ONLY!
426  if (_ptype!=fOnline)
427  return;
428 // _cSummaryvsLS_FED.extendAxisRange(_currentLS);
429 // _cSummaryvsLS.extendAxisRange(_currentLS);
430 
431 }
432 
434  edm::EventSetup const& es)
435 {
436  if (_ptype!=fOnline)
437  return;
438 
439  //
440  // GENERATE STATUS ONLY FOR ONLINE!
441  //
442  for (std::vector<uint32_t>::const_iterator it=_vhashFEDs.begin();
443  it!=_vhashFEDs.end(); ++it)
444  {
445  flag::Flag fSum("RAW");
447 
448  std::vector<uint32_t>::const_iterator cit=std::find(
449  _vcdaqEids.begin(), _vcdaqEids.end(), *it);
450  if (cit==_vcdaqEids.end())
451  {
452  // not @cDAQ
453  for (uint32_t iflag=0; iflag<_vflags.size(); iflag++)
454  _cSummaryvsLS_FED.setBinContent(eid, _currentLS, int(iflag),
455  int(flag::fNCDAQ));
457  continue;
458  }
459 
460  // FED is @cDAQ
463  {
464  if (_xEvnMsmLS.get(eid)>0)
465  _vflags[fEvnMsm]._state = flag::fBAD;
466  else
467  _vflags[fEvnMsm]._state = flag::fGOOD;
468  if (_xBcnMsmLS.get(eid)>0)
469  _vflags[fBcnMsm]._state = flag::fBAD;
470  else
471  _vflags[fBcnMsm]._state = flag::fGOOD;
472  if (_xOrnMsmLS.get(eid)>0)
473  _vflags[fOrnMsm]._state = flag::fBAD;
474  else
475  _vflags[fOrnMsm]._state = flag::fGOOD;
476  if (double(_xBadQLS.get(eid))>double(12*_evsPerLS))
477  _vflags[fBadQ]._state = flag::fBAD;
478  else if (_xBadQLS.get(eid)>0)
479  _vflags[fBadQ]._state = flag::fPROBLEMATIC;
480  else
481  _vflags[fBadQ]._state = flag::fGOOD;
482  }
483 
484  int iflag=0;
485  // iterate over all flags:
486  // - sum them all up in summary flag for this FED
487  // - reset each flag right after using it
488  for (std::vector<flag::Flag>::iterator ft=_vflags.begin();
489  ft!=_vflags.end(); ++ft)
490  {
491  _cSummaryvsLS_FED.setBinContent(eid, _currentLS, int(iflag),
492  ft->_state);
493  fSum+=(*ft);
494  iflag++;
495 
496  // this is the MUST! We don't keep flags per FED, reset
497  // each one of them after using
498  ft->reset();
499  }
501  }
502 
503  // reset...
505 
506  // in the end always do the DQTask::endLumi
507  DQTask::endLuminosityBlock(lb, es);
508 }
509 
511 
T getUntrackedParameter(std::string const &, T const &) const
hcaldqm::Container2D _cSummaryvsLS_FED
Definition: RawTask.h:92
int const RAW_EMPTY
Definition: Constants.h:218
auto_ptr< ClusterSequence > cs
virtual void initialize(std::string const &folder, Quantity *, Quantity *qy=new ValueQuantity(quantity::fN), int debug=0)
virtual bool exists(HcalDetId const &)
Definition: ContainerXXX.h:267
virtual void setBinContent(HcalDetId const &, int)
Definition: Container2D.cc:235
int const CRATE_VME_MIN
Definition: Constants.h:60
int ib
Definition: cuy.py:660
bool check() const
Check for a good event Requires a minimum length, matching wordcount and length, not an empty event...
Definition: HcalHTRData.cc:62
std::pair< uint16_t, uint16_t > fed2crate(int fed)
Definition: Utilities.cc:13
uint32_t rawId() const
bool _calibProcessing
Definition: RawTask.h:62
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:462
void initialize(HcalElectronicsMap const *, ElectronicsMapType etype=fHcalElectronicsMap)
virtual void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &)
Definition: RawTask.cc:29
hcaldqm::electronicsmap::ElectronicsMap _ehashmap
Definition: RawTask.h:59
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
UpdateFreq
Definition: DQTask.h:17
State _state
Definition: Flag.h:79
hcaldqm::Container2D _cOrnMsm_ElectronicsuTCA
Definition: RawTask.h:89
int bunchCrossing() const
Definition: EventBase.h:65
int const SPIGOT_MIN
Definition: Constants.h:85
hcaldqm::ContainerXXX< uint32_t > _xEvnMsmLS
Definition: RawTask.h:90
virtual void _process(edm::Event const &, edm::EventSetup const &)
Definition: RawTask.cc:205
virtual void reset()
Definition: ContainerXXX.h:366
int l1aNumber() const
Definition: AMC13Header.h:19
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:7
int getSpigotData(int nspigot, HcalHTRData &decodeTool, int validSize) const
int const FIBER_VME_MIN
Definition: Constants.h:90
unsigned int getOrbitNumber() const
Get the HTR orbit number.
Definition: HcalHTRData.cc:324
size_t size() const
Lenght of the data buffer in bytes.
Definition: FEDRawData.h:47
void bookHistograms(fwlite::EventContainer &eventCont)
int const FIBERCH_MIN
Definition: Constants.h:100
int AMCSize(int i) const
Definition: AMC13Header.h:37
virtual void book(DQMStore::IBooker &, std::string subsystem="Hcal", std::string aux="")
std::vector< int > getFEDVMEList(HcalElectronicsMap const *)
Definition: Utilities.cc:78
int const SPIGOT_MAX
Definition: Constants.h:86
hcaldqm::Container2D _cBadQuality_depth
Definition: RawTask.h:77
virtual void fill(HcalDetId const &)
Definition: Container2D.cc:59
unsigned int getOrbitNumber() const
Definition: HcalDCCHeader.h:46
hcaldqm::ContainerSingle2D _cSummaryvsLS
Definition: RawTask.h:93
int getBunchId() const
Definition: HcalDCCHeader.h:34
hcaldqm::ContainerXXX< uint32_t > _xBcnMsmLS
Definition: RawTask.h:90
ProcessingType _ptype
Definition: DQModule.h:59
virtual void fill(uint32_t)
Definition: Container1D.cc:82
int bunchId() const
Definition: AMC13Header.h:17
virtual void initialize(std::string const &folder, hashfunctions::HashType, Quantity *, Quantity *, int debug=0)
void reset()
Definition: Flag.h:76
virtual void setBinContent(int, int, int)
hcaldqm::filter::HashFilter _filter_FEDsuTCA
Definition: RawTask.h:72
void dqmthrow(std::string const &msg) const
Definition: Logger.h:15
ContainerXXX< uint32_t > _xQuality
Definition: DQTask.h:62
std::vector< uint32_t > _vhashFEDs
Definition: RawTask.h:66
int const FED_VME_MIN
Definition: Constants.h:47
virtual void initialize(std::string const &folder, hashfunctions::HashType, Quantity *, Quantity *, Quantity *qz=new ValueQuantity(quantity::fN), int debug=0)
Definition: Container2D.cc:32
int const FIBER_uTCA_MIN1
Definition: Constants.h:93
hcaldqm::ContainerXXX< uint32_t > _xOrnMsmLS
Definition: RawTask.h:90
RawTask(edm::ParameterSet const &)
Definition: RawTask.cc:7
Logger _logger
Definition: DQModule.h:70
edm::EDGetTokenT< HcalUnpackerReport > _tokReport
Definition: RawTask.h:44
std::string _name
Definition: DQModule.h:57
virtual void book(DQMStore::IBooker &, HcalElectronicsMap const *, std::string subsystem="Hcal", std::string aux="")
edm::EDGetTokenT< FEDRawDataCollection > _tokFEDs
Definition: RawTask.h:43
bool isHcalDetId() const
hcaldqm::Container2D _cBadQuality_FEDuTCA
Definition: RawTask.h:76
int const CRATE_uTCA_MIN
Definition: Constants.h:65
hcaldqm::Container2D _cEvnMsm_ElectronicsuTCA
Definition: RawTask.h:87
hcaldqm::filter::HashFilter _filter_uTCA
Definition: RawTask.h:70
int getSourceId() const
Definition: HcalDCCHeader.h:32
unsigned int orbitNumber() const
Definition: AMC13Header.h:23
int _thresh_calib_nbadq
Definition: RawTask.h:63
bool isVMEid() const
virtual void endLuminosityBlock(edm::LuminosityBlock const &, edm::EventSetup const &)
Definition: RawTask.cc:433
hcaldqm::ContainerXXX< uint32_t > _xBadQLS
Definition: RawTask.h:90
bool isFEDHBHE(HcalElectronicsId const &)
Definition: Utilities.cc:131
virtual void book(DQMStore::IBooker &, HcalElectronicsMap const *, std::string subsystem="Hcal", std::string aux="")
Definition: Container2D.cc:895
virtual void book(HcalElectronicsMap const *)
Definition: ContainerXXX.h:99
hcaldqm::Container2D _cBadQuality_FEDVME
Definition: RawTask.h:75
virtual void initialize(std::string const &folder, Quantity *, Quantity *, Quantity *qz=new ValueQuantity(quantity::fN), int debug=0)
virtual void _resetMonitors(hcaldqm::UpdateFreq)
Definition: RawTask.cc:199
const T & get() const
Definition: EventSetup.h:56
hcaldqm::Container2D _cBcnMsm_ElectronicsVME
Definition: RawTask.h:85
uint32_t l1ANumber() const
Get the HTR event number.
Definition: HcalUHTRData.h:104
hcaldqm::filter::HashFilter _filter_FEDsVME
Definition: RawTask.h:71
std::string const & label() const
Definition: InputTag.h:36
hcaldqm::ContainerSingleProf1D _cBadQualityvsLS
Definition: RawTask.h:79
hcaldqm::Container2D _cOrnMsm_ElectronicsVME
Definition: RawTask.h:86
edm::InputTag _tagFEDs
Definition: RawTask.h:41
std::vector< hcaldqm::flag::Flag > _vflags
Definition: RawTask.h:47
int NAMC() const
Definition: AMC13Header.h:25
static const int SPIGOT_COUNT
Definition: HcalDCCHeader.h:19
hcaldqm::Container2D _cBcnMsm_ElectronicsuTCA
Definition: RawTask.h:88
virtual STDTYPE & get(HcalDetId const &)
Definition: ContainerXXX.h:249
int AMCSlot(int i) const
Definition: AMC13Header.h:33
const uint64_t * AMCPayload(int i) const
Definition: AMC13Header.cc:4
virtual void setLumiFlag()
hcaldqm::ContainerProf1D _cDataSizevsLS_FED
Definition: RawTask.h:81
unsigned int getBunchNumber() const
Get the HTR bunch number.
Definition: HcalHTRData.h:115
std::vector< int > getFEDList(HcalElectronicsMap const *)
Definition: Utilities.cc:54
const unsigned char * data() const
Return a const pointer to the beginning of the data buffer.
Definition: FEDRawData.cc:28
std::vector< int > getFEDuTCAList(HcalElectronicsMap const *)
Definition: Utilities.cc:104
virtual bool filter(HcalDetId const &) const
Definition: HashFilter.cc:36
std::string _subsystem
Definition: DQModule.h:64
edm::InputTag _tagReport
Definition: RawTask.h:42
bool isFEDHO(HcalElectronicsId const &)
Definition: Utilities.cc:178
hcaldqm::filter::HashFilter _filter_VME
Definition: RawTask.h:69
hcaldqm::ContainerSingleProf1D _cBadQualityvsBX
Definition: RawTask.h:80
std::vector< uint32_t > _vcdaqEids
Definition: DQTask.h:65
virtual void initialize(hashfunctions::HashType, int debug=0)
Definition: ContainerXXX.h:91
virtual void initialize(FilterType ftype, HashType htype, std::vector< uint32_t > const &)
Definition: HashFilter.cc:26
virtual void book(DQMStore::IBooker &, std::string subsystem="Hcal", std::string aux="")
virtual void beginLuminosityBlock(edm::LuminosityBlock const &, edm::EventSetup const &)
Definition: RawTask.cc:418
uint16_t AMCId(int i) const
Definition: AMC13Header.h:31
unsigned int getL1ANumber() const
Get the HTR event number.
Definition: HcalHTRData.h:111
unsigned dccId(DetId const &)
hcaldqm::Container2D _cEvnMsm_ElectronicsVME
Definition: RawTask.h:84
unsigned long getDCCEventNumber() const
Definition: HcalDCCHeader.h:36
Readout chain identification for Hcal.
std::string const & instance() const
Definition: InputTag.h:37
bool isFEDHF(HcalElectronicsId const &)
Definition: Utilities.cc:153
int const SLOT_uTCA_MIN
Definition: Constants.h:72
Definition: Run.h:43
HcalElectronicsMap const * _emap
Definition: RawTask.h:58