ATLAS Offline Software
CscROD_Decoder.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 #include "CscROD_Decoder.h"
6 
7 #include <algorithm>
8 
9 #include "GaudiKernel/TypeNameString.h"
12 #include "StoreGate/DataHandle.h"
13 #include "eformat/Issue.h"
14 
15 using eformat::helper::SourceIdentifier;
18 
20 Muon::CscROD_Decoder::CscROD_Decoder(const std::string& type, const std::string& name, const IInterface* parent) :
21  base_class(type, name, parent), m_cabling("CSCcablingSvc", name) {
22  declareProperty("IsCosmics", m_isCosmic = false);
23  declareProperty("IsOldCosmics", m_isOldCosmic = false);
24 }
25 
27  // get the cabling service
28  ATH_CHECK(m_cabling.retrieve());
29  ATH_CHECK(m_idHelperSvc.retrieve());
30  m_hid2re.set(&(*m_cabling), &m_idHelperSvc->cscIdHelper());
31  if (m_isCosmic) {
32  m_hid2re.set_isCosmic();
33  if (m_isOldCosmic) m_hid2re.set_isOldCosmic();
34  }
35  return StatusCode::SUCCESS;
36 }
37 
38 void Muon::CscROD_Decoder::fillCollection(const xAOD::EventInfo& eventInfo, const ROBFragment& robFrag, CscRawDataContainer& rdoIDC) const {
39  ATH_MSG_DEBUG("in CscROD_Decode::fillCollection()");
40 
41  // Check the ROB and ROD fragment . E.P.
42  try {
43  robFrag.check();
44  } catch (eformat::Issue& ex) {
45  ATH_MSG_DEBUG(ex.what());
46  return; // error in fragment - we search for no collection
47  }
48 
49  uint32_t nstat = robFrag.nstatus();
50  if (nstat) {
51  const uint32_t* it;
52  robFrag.status(it);
53  if (*it) {
54  ATH_MSG_DEBUG("Error in ROB status word: 0x" << std::hex << *it << std::dec);
55  return;
56  }
57  }
58 
59  eformat::helper::Version ver(robFrag.rod_version());
60  const uint16_t& rodMinorVersion = ver.minor_version();
61 
62  ATH_MSG_DEBUG("in CscROD_Decoder::fillCollection :ROD version " << MSG::hex << rodMinorVersion << MSG::dec);
63 
64  if (rodMinorVersion == 0x0200)
65  this->rodVersion2(robFrag, rdoIDC);
66  else if ((rodMinorVersion >> 8) == 4) { // minor ver. 0400 Oct. 2014
67  this->rodVersion2(robFrag, rdoIDC);
68  } else if (rodMinorVersion == 0x1 || // ROD version for CTB and DC3 - for backward compatibility
70  this->rodVersion1(robFrag, rdoIDC);
71  else if (rodMinorVersion == 0x0)
72  ATH_MSG_DEBUG("Empty ROB - doing nothing ");
73  else // ROD version for DC2 - old and obselete; for backward compatibility
74  this->rodVersion0(robFrag, rdoIDC);
75 }
76 
80 uint32_t Muon::CscROD_Decoder::getHashId(const uint32_t word, std::string /*detdescr*/) const {
81  CscRODReadOut rodReadOut;
83  rodReadOut.set(&m_idHelperSvc->cscIdHelper());
84  rodReadOut.setChamberBitVaue(1);
85 
86  uint32_t address = rodReadOut.fragmentToAddress(word);
87  Identifier moduleId = rodReadOut.decodeAddress(address);
88  // Identifier channelId = rodReadOut.decodeAddress(moduleId);
89  return rodReadOut.hashIdentifier(address, moduleId);
90 }
91 
93 Identifier Muon::CscROD_Decoder::getChannelId(const uint32_t word, std::string /*detdescr*/) const {
94  CscRODReadOut rodReadOut;
96  rodReadOut.set(&m_idHelperSvc->cscIdHelper());
97  rodReadOut.setChamberBitVaue(1);
98 
99  uint32_t address = rodReadOut.fragmentToAddress(word);
100  Identifier moduleId = rodReadOut.decodeAddress(address);
101  return rodReadOut.decodeAddress(address, moduleId);
102 }
103 
105 void Muon::CscROD_Decoder::getSamples(const std::vector<uint32_t>& words, std::vector<uint16_t>& samples) const {
106  CscRODReadOut rodReadOut;
108  rodReadOut.set(&m_idHelperSvc->cscIdHelper());
109  rodReadOut.setChamberBitVaue(1);
110 
111  for (unsigned int j = 0; j < words.size(); ++j) {
112  uint16_t amp1, amp2;
113  rodReadOut.decodeAmplitude(words[j], amp1, amp2);
114  samples.push_back(amp1);
115  samples.push_back(amp2);
116  }
117 }
118 
120  ATH_MSG_DEBUG(" ");
121  ATH_MSG_DEBUG("===================================================");
122  ATH_MSG_DEBUG("in CscROD_Decode::fillCollection() - ROD version 2");
123 
124  const uint32_t& detev_type = robFrag.rod_detev_type();
125 
126  CscRODReadOut rodReadOut;
127 
128  rodReadOut.set(&m_idHelperSvc->cscIdHelper());
129  rodReadOut.setChamberBitVaue(1);
130 
132  SourceIdentifier sid(robFrag.rod_source_id());
133  uint16_t subDetectorId = sid.subdetector_id();
134  uint32_t onlineRodId = sid.module_id();
135  ATH_MSG_DEBUG("Online ROD id is 0x" << MSG::hex << onlineRodId << MSG::dec);
136 
137  uint16_t rodId = 0xFFFF;
138  bool check = m_cabling->offlineId(onlineRodId, rodId);
139  if (!check)
140  ATH_MSG_ERROR("enable to convert online ROD Id to offline ROD Id - "
141  << "check the cabling service ");
142  uint16_t idColl = m_cabling->collectionId(subDetectorId, rodId);
143 
144  ATH_MSG_DEBUG("Online ROD / ROD / collection / subDetector IDs are 0x" << MSG::hex << onlineRodId << MSG::dec << " " << rodId << " "
145  << idColl << " " << subDetectorId);
146 
147  // assert (subDetectorId == 0x6A || subDetectorId == 0x69); // 50 or 51
148 
149  // Create the Csc container and use the cache to get it
150  std::unique_ptr<CscRawDataCollection> rawCollection(nullptr);
152  if (lock.alreadyPresent()) {
153  ATH_MSG_DEBUG("CSC RDO collection already exist with collection hash = " << idColl << " collection filling is skipped!");
154  return;
155  } else {
156  ATH_MSG_DEBUG("CSC RDO collection does not exist - creating a new one with hash = " << idColl);
157  rawCollection = std::make_unique<CscRawDataCollection>(idColl);
158  }
159 
161  rawCollection->setSubDetectorId(subDetectorId);
162  rawCollection->setRodId(onlineRodId);
163  rawCollection->setOnlineId(idColl);
164 
166  rawCollection->set_eventType(detev_type);
167 
169  bool isSparsified = rawCollection->sparsified();
170 
172  bool ne = rawCollection->neutron();
173 
175  bool cal = rawCollection->calEnabled();
176 
178  uint16_t latency = rawCollection->latency();
179 
181  uint16_t calLayer = rawCollection->calLayer();
182 
184  uint16_t calAmplitude = rawCollection->calAmplitude();
185 
187  uint16_t samplingTime = rawCollection->rate();
188 
190  uint16_t numSamples = detev_type & 0xFF;
191 
192  ATH_MSG_DEBUG("Event Type: " << MSG::hex << detev_type << MSG::dec);
193  ATH_MSG_DEBUG("Sampling Time: " << samplingTime << " Number of Samples: " << numSamples);
194  ATH_MSG_DEBUG("Is Calibration Enabled?: " << cal << " Calibration Amplitude: " << calAmplitude);
195  ATH_MSG_DEBUG("Calibration Layer: " << calLayer << " Latency: " << latency);
196  ATH_MSG_DEBUG("Is neutron rejection ON?: " << ne << " Is sparsified data?: " << isSparsified);
197 
198 
200  uint32_t counter = 0;
201  uint32_t rpuSize = 0;
202 
203  const unsigned int size = robFrag.rod_ndata();
204  ATH_MSG_DEBUG("CscROD_Decoder Total words received = " << size);
205 
206  // uint32_t wordPos = 0;
207  PointerType vint; // OFFLINE_FRAGMENTS_NAMESPACE::
208  robFrag.rod_data(vint);
209 
210  bool isHeaderWordNull = false; // header is 0 so couldn't retrieve rpuID and size.
211  bool isClusterWordsUnrealistic = false; // too many cluster words causes unrealistic strip position
212  while (counter < size) {
214  uint32_t header = vint[counter];
215  ATH_MSG_DEBUG("RPU Header word 0x" << MSG::hex << header << MSG::dec);
216  if (!header) { // rpu size and rpu id couldn't be figured out...
217  isHeaderWordNull = true;
218  break;
219  }
220  counter += 1;
221 
223  uint16_t rpuID_raw = (header >> 24) & 0xFF;
224  ATH_MSG_DEBUG("RPU ID original = " << rpuID_raw);
225  // ROD version 3 (SLAC made) return 13 instead of 11 as of March 2010
226  uint16_t rpuID;
227  if (rpuID_raw == 13) {
228  rpuID = uint16_t(rpuID_raw - 2); // make 13 to 11...
229  } else {
230  rpuID = rpuID_raw;
231  }
232 
233  ATH_MSG_DEBUG("RPU ID Updated = " << rpuID);
234 
235  rawCollection->addRPU(rpuID);
236 
238  uint16_t dataType = (header >> 16) & 0xFF;
239  rawCollection->addDataType(dataType);
240 
242  uint32_t rSize = header & 0xFFFF;
243  rpuSize += rSize;
244  ATH_MSG_DEBUG("RPU size = " << rSize);
245 
246 
254  if (dataType == 1)
255  continue;
256  else if (dataType == 2) {
257  counter += rSize - 1;
258  ATH_MSG_DEBUG("Error condition encounted on RPU ID = " << rpuID << " continuing ...");
259  continue;
260  } else {
263  if (rSize == 1) {
264  ATH_MSG_DEBUG("TTTT Type = " << dataType << " with no data and no errors. "
265  << " Continue to next RPU ...");
266  continue;
267  }
268 
270  uint32_t scaAddress = vint[counter];
271  ATH_MSG_DEBUG("SCA Address = " << scaAddress);
272  rawCollection->set_scaAddress(scaAddress);
273  counter += 1;
274 
276  uint32_t precisionClusters = vint[counter];
277  ATH_MSG_DEBUG("Number of Precision Cluster word 0x" << MSG::hex << precisionClusters << MSG::dec);
278  uint32_t precisionClusterCounts = 0;
279  for (uint16_t k = 0; k < 4; k++) {
280  uint16_t counts = (precisionClusters >> (24 - k * 8)) & 0xFF;
281  precisionClusterCounts += counts;
282  ATH_MSG_DEBUG("Number of precision Cluster Counts - "
283  << "Layer Index = " << k << " Cluster Counts = " << counts);
284  unsigned int index = 0;
285  if (rpuID == 5)
286  index = k;
287  else if (rpuID == 11)
288  index = k + 5;
289  else
290  ATH_MSG_ERROR("RPU ID out of range " << rpuID);
291  rawCollection->set_spuCount(index, counts);
292  }
293  counter += 1;
294 
296  uint32_t secondClusterWord = vint[counter];
297  ATH_MSG_DEBUG("Second cluster word 0x" << MSG::hex << secondClusterWord << MSG::dec);
298  counter += 1;
299 
301  uint16_t nonPrecisionClusterCounts = (secondClusterWord >> 24) & 0xFF;
302  ATH_MSG_DEBUG("Summed Number of Clusters for non-precision layers " << nonPrecisionClusterCounts);
303  if (rpuID == 5) rawCollection->set_spuCount(4, nonPrecisionClusterCounts);
304  if (rpuID == 11)
305  rawCollection->set_spuCount(9, nonPrecisionClusterCounts); // all the counts are in position 5/10 for non-precision strips
306 
308  bool triggerType = (secondClusterWord >> 21) & 0x1;
309  if (triggerType) rawCollection->set_triggerType();
310 
312  bool samplingPhase = (secondClusterWord >> 20) & 0x1;
313  if (samplingPhase) rawCollection->set_samplingPhase();
314 
316  uint8_t firstBitSummary = (secondClusterWord >> 16) & 0xF;
317  rawCollection->set_firstBitSummary(firstBitSummary);
318 
320  uint16_t clusterDataWords = secondClusterWord & 0xFFFF;
321  ATH_MSG_DEBUG("Cluster Data Words = " << clusterDataWords);
322 
324  uint32_t totalClusterCounts = nonPrecisionClusterCounts + precisionClusterCounts;
325  ATH_MSG_DEBUG("Total summed Cluster Count for precision and non-precision layers = " << totalClusterCounts);
326 
327  if (totalClusterCounts == 0) {
328  ATH_MSG_DEBUG("No Cluster found - skipping to next RPU ");
329  counter += rSize - 4;
330  continue;
331  }
332 
334  uint16_t clusterCount = 0;
335 
336  while (clusterCount < totalClusterCounts) {
338  uint32_t address = vint[counter];
339 
340  ATH_MSG_DEBUG("cluster location word 0x" << MSG::hex << address << MSG::dec);
341 
342  uint32_t addr = rodReadOut.fragmentToAddress(address);
343  Identifier moduleId = rodReadOut.decodeAddress(addr);
344  Identifier channelId = rodReadOut.decodeAddress(addr, moduleId);
345  int stationId = m_idHelperSvc->cscIdHelper().stationName(channelId);
346  int currentLayer = m_idHelperSvc->cscIdHelper().wireLayer(channelId);
347  int orientation = m_idHelperSvc->cscIdHelper().measuresPhi(channelId);
348  int stripId = m_idHelperSvc->cscIdHelper().strip(channelId);
349 
350  counter += 1;
351 
353  uint32_t time_width = vint[counter];
354  ATH_MSG_DEBUG(" cluster time size word : stripId (CscIdHelper) 0x" << MSG::hex << time_width << MSG::dec << " " << stripId);
355  counter += 1;
356  uint16_t time = (time_width >> 16) & 0xFFF;
357  uint16_t width = time_width & 0xFFFF;
358  if (width > 192) {
359  isClusterWordsUnrealistic = true;
360  break;
361  }
362  bool isTimeComputed = (time_width >> 28) & 0x1;
363 
364  uint16_t totalSampleWords = width * numSamples / 2 + (width * numSamples) % 2;
365 
367  std::vector<uint16_t> amplitude;
368  for (int j = 0; j < totalSampleWords; ++j) {
369  uint16_t amp1, amp2;
370  rodReadOut.decodeAmplitude(vint[counter], amp1, amp2);
371  amplitude.push_back(amp1);
372  amplitude.push_back(amp2);
373  counter += 1;
374  }
375  clusterCount += 1;
376 
378  uint16_t spuID = 0x0;
379  if (orientation == 0)
380  spuID = static_cast<uint16_t>((stationId - 50) * 5 + currentLayer - 1);
381  else
382  spuID = static_cast<uint16_t>(((stationId - 50) + 1) * 5 - 1);
383 
384  uint32_t hashId = rodReadOut.hashIdentifier(addr, moduleId);
385 
386  // To get rid of unhealthy word Careful!! It should be located after all the counter to look at the next words...
387  if (address == 0) {
388  ATH_MSG_INFO("Location word is not available and CscRawData is discarded!!");
389  continue;
390  }
391 
392  CscRawData* rawData = new CscRawData(amplitude, address, idColl, time, spuID, width, hashId);
393  if (isTimeComputed) rawData->set_isTimeComputed();
394 
395  rawCollection->push_back(rawData);
396  ATH_MSG_DEBUG(" idColl clusHashid spuID stationId :: "
397  << idColl << " " << hashId << " " << spuID << " " << stationId << " :: measphi" << orientation << " L"
398  << currentLayer << " strId " << stripId << " nStr " << width << " T" << time << " nSampWords "
399  << totalSampleWords << " " << m_idHelperSvc->cscIdHelper().show_to_string(channelId));
400  }
401 
402  ATH_MSG_DEBUG("****Total Cluster count = " << clusterCount << " for RPU ID " << rpuID);
404  // If any of two RPU has problem, delete both.....likely have a problem
405 
406  if (counter > rpuSize) {
407  ATH_MSG_INFO("ROB Fragment with ID 0x" << std::hex << robFrag.rod_source_id() << std::dec << " has word Counter ="
408  << counter << " must not exceed summed RPU sizes =" << rpuSize << " Discarded!!");
409 
410  rawCollection->erase(rawCollection->begin(), rawCollection->end());
411  return;
412  }
413 
415  if (counter < rpuSize) {
416  ATH_MSG_DEBUG("" << (rpuSize - counter) << " ghost words at the end of this RPU - skipping ...");
417  counter = rpuSize;
418  }
419  } // if (dataType == 1) else
420  } // while (counter<size)
421 
422  // To reject unhealthy rob
423  if (isHeaderWordNull) {
424  ATH_MSG_INFO(" ROB Fragment with ID " << std::hex << robFrag.rod_source_id() << std::dec << " has null rpuID. Discarded!!");
425  rawCollection->erase(rawCollection->begin(), rawCollection->end());
426  }
427  if (isClusterWordsUnrealistic) {
428  ATH_MSG_INFO(" ROB Fragment with ID 0x" << std::hex << robFrag.rod_source_id() << std::dec
429  << " has too many cluster words. Discarded!!");
430  rawCollection->erase(rawCollection->begin(), rawCollection->end());
431  }
432 
433  if (rawCollection) {
434  StatusCode status_lock = lock.addOrDelete(std::move(rawCollection));
435  if (status_lock.isFailure()) {
436  ATH_MSG_ERROR("Could not insert CscRawDataCollection into CscRawDataContainer...");
437  return;
438  }
439  }
440 
441  ATH_MSG_DEBUG("end of CscROD_Decode::fillCollection()");
442 }
443 
445  ATH_MSG_DEBUG("in CscROD_Decode::fillCollection() - ROD version 1");
446 
447  CscRODReadOutV1 rodReadOut;
448 
449  // Csc Id Helper not needed :: initialize pointer to 0!
450  rodReadOut.set(nullptr);
451 
452  // get some information
453  SourceIdentifier sid(robFrag.rod_source_id());
454 
455  uint16_t subDetectorId = sid.subdetector_id();
456  uint16_t rodId = sid.module_id();
457 
458  uint16_t idColl = m_cabling->collectionId(subDetectorId, rodId);
459 
460  // assert (subDetectorId <= 1);
461 
462  // Create the Csc container and use the cache to get it
463  std::unique_ptr<CscRawDataCollection> rawCollection(nullptr);
465  if (lock.alreadyPresent()) {
466  ATH_MSG_DEBUG("CSC RDO collection already exist with collection hash = " << idColl << " converting is skipped!");
467  return;
468  } else {
469  ATH_MSG_DEBUG("CSC RDO collection does not exist - creating a new one with hash = " << idColl);
470  rawCollection = std::make_unique<CscRawDataCollection>(idColl);
471  }
472 
473  // set the ROD id and the subDector id
474  rawCollection->setSubDetectorId(subDetectorId);
475  rawCollection->setRodId(rodId);
476  rawCollection->setOnlineId(idColl);
477 
478  const unsigned int size = robFrag.rod_ndata();
479  ATH_MSG_DEBUG("CscROD_Decoder Total words received = " << size);
480 
481  PointerType p;
482  robFrag.rod_data(p);
483 
484  // expected number of samples
485  // this is the first word in the ROD data block
486  uint32_t numSamples = p[0];
487  rawCollection->setNumSamples((uint16_t)numSamples);
488 
489  // latency - the second word
490  uint16_t latency = (uint16_t)p[1];
491  rawCollection->setLatency(latency);
492 
493  // the sampling rate
494  uint16_t samplingRate = (uint16_t)p[2];
495  rawCollection->setSamplingRate(samplingRate);
496  // rodReadOut.setSamplingTime(1000.0/samplingRate);
497 
498  // the number of DPU is the fourth word
499  uint32_t numDPU = p[3];
500  rawCollection->setNumDPU((uint16_t)numDPU);
501 
502  // size of the ROD data block
503  // expected size of the ROD header and footer
504  uint32_t rodHeader = rodReadOut.getHeaderSize();
505  uint32_t rodFooter = rodReadOut.getFooterSize();
506 
507  // loop over data fragments and decode them to fill the collection v
508  // move the DPU header
509  bool dpuFragment = rodReadOut.isDPU(p[rodHeader]);
510  if (!dpuFragment) {
511  ATH_MSG_ERROR("expecting a DPU fragment, Aborting...");
512  return;
513  }
514 
515  uint32_t i = rodHeader;
516 
517  while (dpuFragment && i < (size - rodFooter)) {
518  // the DPU id follows the DPU header marker
519  i += 1;
520  uint32_t dpuID = p[i];
521 
522  // number of channel blocks to follow
523  i += 1;
524  uint32_t numChannel = p[i];
525 
526  // the satus word
527  i += 1;
528  // uint32_t status[6];
529  // for (int j=0; j < 6; j++) status[j] = p[i+j];
530 
531  // miscellaneous debugging word
532  i += 6;
533  // uint32_t misc[2];
534  // for (int j=0; j < 2; j++) misc[j] = p[i+j];
535 
536  // increase counter appropriately
537  i += 2;
538 
539  // now check that there is a valid number of channel blocks to read
540  if (!rodReadOut.discard(numChannel)) {
541  for (unsigned int j = 0; j < numChannel; j++) {
542  // decode the channel block data
543  if (rodReadOut.isAddress(p[i])) {
544  rodReadOut.decodeAddress(p[i]);
545  // std::cout << "Found a CSC strip address = " << rodReadOut.address() << std::endl;
546  i += 1;
547  } else
548  ATH_MSG_ERROR("expecting an address fragment");
549  std::vector<uint16_t> amplitude;
550  for (unsigned int j = 1; j <= numSamples; j++) {
551  if ((j % 2) == 1) {
552  rodReadOut.decodeAmplitude(p[i]);
553  amplitude.push_back(rodReadOut.getAmp1());
554  if (amplitude.size() < numSamples) amplitude.push_back(rodReadOut.getAmp2());
555  i += 1;
556  }
557  }
558  uint32_t address = rodReadOut.address();
559  CscRawData* rawData = new CscRawData(amplitude, address, idColl, dpuID);
560  rawCollection->push_back(rawData);
561  }
562  } else { // this is a discard
563  ATH_MSG_INFO("this is a discard::numChannel = " << MSG::hex << numChannel);
564  }
565  // check that the new fragment is a DPU header block
566  if (i < (size - rodFooter)) dpuFragment = rodReadOut.isDPU(p[i]);
567  }
568 
569  if (rawCollection) {
570  StatusCode status_lock = lock.addOrDelete(std::move(rawCollection));
571  if (status_lock.isFailure()) {
572  ATH_MSG_ERROR("Could not insert CscRawDataCollection into CscRawDataContainer...");
573  return;
574  }
575  }
576 
577  }
578 
580  ATH_MSG_DEBUG("in CscROD_Decode::fillCollection() - ROD version 0");
581 
582  CscRODReadOutV0 rodReadOut;
583 
584  // Csc Id Helper not needed :: initialize pointer to 0!
585  rodReadOut.set(nullptr);
586 
587  const unsigned int size = robFrag.rod_ndata();
588  ATH_MSG_DEBUG("CscROD_Decoder Total words received = " << size);
589 
590  PointerType p;
591  robFrag.rod_data(p);
592 
593  // get some information
594  rodReadOut.decodeSourceID(p[3]);
595  uint16_t subDetectorId = rodReadOut.subDetectorId();
596  uint16_t rodId = rodReadOut.rodId();
597 
598  // assert (subDetectorId <= 1);
599 
600  uint16_t subId = (subDetectorId == 0x0) ? 0x6A : 0x69;
601 
602  uint16_t idColl = m_cabling->collectionId(subId, rodId);
603 
604  // Create the Csc container and use the cache to get it
605  std::unique_ptr<CscRawDataCollection> rawCollection(nullptr);
607  if (lock.alreadyPresent()) {
608  ATH_MSG_DEBUG("CSC RDO collection already exist with collection hash = " << idColl << " converting is skipped!");
609  return;
610  } else {
611  ATH_MSG_DEBUG("CSC RDO collection does not exist - creating a new one with hash = " << idColl);
612  rawCollection = std::make_unique<CscRawDataCollection>(idColl);
613  }
614 
615  // set the ROD id and the subDector id
616  rawCollection->setSubDetectorId(subDetectorId);
617  rawCollection->setRodId(rodId);
618  rawCollection->setOnlineId(idColl);
619 
620  uint32_t rodHeader = rodReadOut.getHeaderSize();
621  uint32_t rodFooter = rodReadOut.getFooterSize();
622 
623  // loop over data fragments and decode them to fill the collection v
624  bool bodyFragment = rodReadOut.isBody(p[rodHeader]);
625  if (!bodyFragment) {
626  ATH_MSG_ERROR("expecting a body fragment, Aborting...");
627  return;
628  }
629  uint32_t i = rodHeader;
630  while (bodyFragment && i < (size - rodFooter)) {
631  if (rodReadOut.isAmplitude(p[i])) {
632  rodReadOut.decodeAmplitude(p[i], 1);
633  i += 1;
634  } else {
635  ATH_MSG_ERROR("expecting an amplitude fragment");
636  }
637  if (rodReadOut.isAmplitude(p[i])) {
638  rodReadOut.decodeAmplitude(p[i], 2);
639  i += 1;
640  } else
641  ATH_MSG_ERROR("expecting an amplitude fragment");
642  if (rodReadOut.isAddress(p[i])) {
643  rodReadOut.decodeAddress(p[i]);
644  i += 1;
645  } else
646  ATH_MSG_ERROR("expecting an address fragment");
647  /* MN
648  uint16_t * amplitude = new uint16_t[4];
649  *amplitude = rodReadOut.getAmp1();
650  *(amplitude+1) = rodReadOut.getAmp2();
651  *(amplitude+2) = rodReadOut.getAmp3();
652  *(amplitude+3) = rodReadOut.getAmp4();
653  uint32_t address = rodReadOut.address();
654  CscRawData * rawData = new CscRawData(amplitude,address,idColl);
655  */
656  std::vector<uint16_t> amplitudes;
657  amplitudes.push_back(rodReadOut.getAmp1());
658  amplitudes.push_back(rodReadOut.getAmp2());
659  amplitudes.push_back(rodReadOut.getAmp3());
660  amplitudes.push_back(rodReadOut.getAmp4());
661  CscRawData* rawData = new CscRawData(amplitudes, rodReadOut.address(), idColl);
662 
663  rawCollection->push_back(rawData);
664 
665  // check that the new fragment is body
666  bodyFragment = rodReadOut.isBody(p[i]);
667  }
668 
669  if (rawCollection) {
670  StatusCode status_lock = lock.addOrDelete(std::move(rawCollection));
671  if (status_lock.isFailure()) {
672  ATH_MSG_ERROR("Could not insert CscRawDataCollection into CscRawDataContainer...");
673  return;
674  }
675  }
676 
677  }
Muon::CscROD_Decoder::m_isCosmic
bool m_isCosmic
Definition: CscROD_Decoder.h:62
CscRODReadOut::decodeAddress
Identifier decodeAddress(const uint32_t address) const
Definition: CscRODReadOut.h:161
CscRODReadOut::hashIdentifier
uint32_t hashIdentifier(const uint32_t address, const Identifier &moduleId) const
Definition: CscRODReadOut.h:209
CscRawDataCollection::set_triggerType
void set_triggerType()
Definition: CscRawDataCollection.h:156
plotBeamSpotCompare.x1
x1
Definition: plotBeamSpotCompare.py:216
Muon::CscROD_Decoder::initialize
virtual StatusCode initialize() override
Definition: CscROD_Decoder.cxx:26
CscRODReadOutV1::getHeaderSize
uint32_t getHeaderSize()
Definition: CscRODReadOutV1.h:26
header
Definition: hcg.cxx:526
CscRawDataCollection::addDataType
void addDataType(const uint8_t dataType)
Definition: CscRawDataCollection.h:189
CscRawDataCollection::neutron
bool neutron() const
is neutron rejection ON?
Definition: CscRawDataCollection.cxx:49
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
CscRawDataCollection::set_spuCount
void set_spuCount(unsigned int i, uint16_t count)
Definition: CscRawDataCollection.h:162
xAOD::uint8_t
uint8_t
Definition: Muon_v1.cxx:557
Muon::CscROD_Decoder::rodVersion0
void rodVersion0(const OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment &robFrag, CscRawDataContainer &rdoIDC) const
the ROD version
Definition: CscROD_Decoder.cxx:579
IdentifiableContainerMT::getWriteHandle
IDC_WriteHandle getWriteHandle(IdentifierHash hash)
Definition: IdentifiableContainerMT.h:248
Muon::CscROD_Decoder::rodVersion1
void rodVersion1(const OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment &robFrag, CscRawDataContainer &rdoIDC) const
Definition: CscROD_Decoder.cxx:444
xAOD::uint32_t
setEventNumber uint32_t
Definition: EventInfo_v1.cxx:127
index
Definition: index.py:1
CscRawDataContainer.h
CscRODReadOutV0
Definition: CscRODReadOutV0.h:19
CscRawDataCollection::set_eventType
void set_eventType(const uint32_t eventType)
Definition: CscRawDataCollection.h:159
Issue
Configuration Issue
Definition: PscIssues.h:31
Muon::CscROD_Decoder::CscROD_Decoder
CscROD_Decoder(const std::string &type, const std::string &name, const IInterface *parent)
constructor
Definition: CscROD_Decoder.cxx:20
CscRODReadOutV1::getAmp2
uint16_t getAmp2() const
Definition: CscRODReadOutV1.h:85
CscRawDataCollection::setSubDetectorId
void setSubDetectorId(uint16_t subDetectorId)
Definition: CscRawDataCollection.h:149
CscRODReadOutV0::decodeAddress
void decodeAddress(const uint32_t fragment)
Definition: CscRODReadOutV0.h:146
CscRODReadOutV0::decodeAmplitude
void decodeAmplitude(const uint32_t fragment, int index)
Definition: CscRODReadOutV0.h:132
CscRawDataCollection::sparsified
bool sparsified() const
is sparsified data? is neutron rejection ON? is calibration enabled?
Definition: CscRawDataCollection.cxx:44
skel.it
it
Definition: skel.GENtoEVGEN.py:396
downloadSingle.dataType
string dataType
Definition: downloadSingle.py:18
IdentifiableContainerMT::IDC_WriteHandle::alreadyPresent
bool alreadyPresent()
Definition: IdentifiableContainerMT.h:59
CscRawDataCollection::addRPU
void addRPU(const uint16_t rpuID)
Definition: CscRawDataCollection.h:188
CscRawData
CscRawData
Definition: MuonEventAthenaPoolTPCnv.cxx:59
CscRawDataCollection::set_samplingPhase
void set_samplingPhase()
Definition: CscRawDataCollection.h:154
CscRODReadOutV1::decodeAmplitude
void decodeAmplitude(const uint32_t fragment)
Definition: CscRODReadOutV1.h:178
DataHandle.h
CscRawDataCollection::set_firstBitSummary
void set_firstBitSummary(const uint8_t summary)
Definition: CscRawDataCollection.h:158
CscRODReadOutV0::isAddress
bool isAddress(const uint32_t fragment) const
Definition: CscRODReadOutV0.h:130
CscRawDataCollection::setOnlineId
void setOnlineId(uint16_t id)
Definition: CscRawDataCollection.h:150
CscRODReadOut::fragmentToAddress
uint32_t fragmentToAddress(const uint32_t fragment) const
Definition: CscRODReadOut.h:159
CscRODReadOutV0::decodeSourceID
void decodeSourceID(uint32_t sourceId)
Definition: CscRODReadOutV0.h:108
CscRawDataCollection::calLayer
uint8_t calLayer() const
Calibration layer.
Definition: CscRawDataCollection.cxx:34
CscRODReadOut::decodeAmplitude
void decodeAmplitude(const uint32_t fragment, uint16_t &amp1, uint16_t &amp2) const
Definition: CscRODReadOut.h:154
CscRODReadOutV1::discard
bool discard(const uint32_t fragment) const
Definition: CscRODReadOutV1.h:166
CscRawDataCollection::latency
uint16_t latency() const
Definition: CscRawDataCollection.cxx:16
CscROD_Decoder.h
python.setupRTTAlg.size
int size
Definition: setupRTTAlg.py:39
Pythia8_A14_NNPDF23LO_Var1Down_Common.ver
ver
Definition: Pythia8_A14_NNPDF23LO_Var1Down_Common.py:26
CscRODReadOut::set
void set(const CscIdHelper *cscIdHelper)
Definition: CscRODReadOut.h:50
CscRODReadOutV0::rodId
uint16_t rodId() const
Definition: CscRODReadOutV0.h:60
OFFLINE_FRAGMENTS_NAMESPACE::PointerType
const DataType * PointerType
Definition: RawEvent.h:25
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
CscRODReadOutV0::getHeaderSize
uint32_t getHeaderSize()
Definition: CscRODReadOutV0.h:26
CscRODReadOutV1::isAddress
bool isAddress(const uint32_t fragment) const
Definition: CscRODReadOutV1.h:173
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
CscRODReadOutV0::getAmp2
uint16_t getAmp2() const
Definition: CscRODReadOutV0.h:62
CscRODReadOut
Definition: CscRODReadOut.h:22
xAOD::uint16_t
setWord1 uint16_t
Definition: eFexEMRoI_v1.cxx:93
CscRODReadOutV1::isDPU
bool isDPU(const uint32_t fragment) const
Definition: CscRODReadOutV1.h:164
eformat::ROBFragment
Definition: L1CaloBsDecoderUtil.h:12
lumiFormat.i
int i
Definition: lumiFormat.py:85
Muon::CscROD_Decoder::m_isOldCosmic
bool m_isOldCosmic
Definition: CscROD_Decoder.h:63
CscRODReadOut::setChamberBitVaue
void setChamberBitVaue(uint32_t value)
Definition: CscRODReadOut.h:51
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
CscRawDataCollection::setRodId
void setRodId(uint16_t rodId)
set methods - the name should be self-descriptive
Definition: CscRawDataCollection.h:148
CscRawDataCollection::calAmplitude
uint8_t calAmplitude() const
Calibration pulser amplitude.
Definition: CscRawDataCollection.cxx:39
CscRODReadOutV0::getAmp3
uint16_t getAmp3() const
Definition: CscRODReadOutV0.h:63
CscRODReadOutV1
Definition: CscRODReadOutV1.h:19
CscRawDataCollection::set_scaAddress
void set_scaAddress(const uint32_t sca)
Definition: CscRawDataCollection.h:161
IdentifiableContainerMT::IDC_WriteHandle
Definition: IdentifiableContainerMT.h:34
test_pyathena.parent
parent
Definition: test_pyathena.py:15
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
CscRODReadOutV0::isAmplitude
bool isAmplitude(const uint16_t fragment) const
Definition: CscRODReadOutV0.h:128
CscRODReadOutV1::getAmp1
uint16_t getAmp1() const
Definition: CscRODReadOutV1.h:84
CscRawDataCollection::calEnabled
bool calEnabled() const
is calibration enabled?
Definition: CscRawDataCollection.cxx:54
Muon::CscROD_Decoder::getSamples
virtual void getSamples(const std::vector< uint32_t > &words, std::vector< uint16_t > &samples) const override
Definition: CscROD_Decoder.cxx:105
CaloCondBlobAlgs_fillNoiseFromASCII.channelId
channelId
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:122
CscRODReadOutV0::getAmp1
uint16_t getAmp1() const
Definition: CscRODReadOutV0.h:61
CscRODReadOutV0::getFooterSize
uint32_t getFooterSize()
Definition: CscRODReadOutV0.h:27
Muon::CscROD_Decoder::getHashId
virtual uint32_t getHashId(const uint32_t word, std::string detdesription) const override
Definition: CscROD_Decoder.cxx:80
CscRawDataCollection.h
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
CscRODReadOutV0::isBody
bool isBody(const uint32_t fragment) const
Definition: CscRODReadOutV0.h:126
DataVector::push_back
value_type push_back(value_type pElem)
Add an element to the end of the collection.
CscRODReadOutV0::address
uint32_t address(const Identifier &channelId, int &eta, int &phi) const
Definition: CscRODReadOutV0.h:178
CscRODReadOutV0::getAmp4
uint16_t getAmp4() const
Definition: CscRODReadOutV0.h:64
OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment
eformat::ROBFragment< PointerType > ROBFragment
Definition: RawEvent.h:27
RTTAlgmain.address
address
Definition: RTTAlgmain.py:55
LArNewCalib_Delay_OFC_Cali.check
check
Definition: LArNewCalib_Delay_OFC_Cali.py:267
CscRawData::set_isTimeComputed
void set_isTimeComputed()
Definition: CscRawData.h:122
xAOD::EventInfo_v1
Class describing the basic event information.
Definition: EventInfo_v1.h:43
IdentifiableContainerMT::IDC_WriteHandle::addOrDelete
StatusCode addOrDelete(std::unique_ptr< T > ptr)
Definition: IdentifiableContainerMT.h:53
CscRODReadOutV0::subDetectorId
uint16_t subDetectorId() const
Definition: CscRODReadOutV0.h:59
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
Muon::CscROD_Decoder::getChannelId
virtual Identifier getChannelId(const uint32_t word, std::string detdesription) const override
Definition: CscROD_Decoder.cxx:93
CscRawData
Class to hold the electronic output for a single CSC readout channel: n sampling ADC data + the addre...
Definition: CscRawData.h:21
Base_Fragment.width
width
Definition: Sherpa_i/share/common/Base_Fragment.py:59
CscRawDataCollection::setNumSamples
void setNumSamples(const uint16_t n)
insert the number of samples into the detector event type word
Definition: CscRawDataCollection.cxx:67
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
CscRawDataContainer
This container provides access to collections of CSC RDOs and a mechanism for recording them.
Definition: CscRawDataContainer.h:23
RunTileMonitoring.triggerType
triggerType
Definition: RunTileMonitoring.py:162
CscRawDataCollection::setSamplingRate
void setSamplingRate(const uint16_t rate)
insert the rate into the detector event type word - the rate can 20 or 40 MHz
Definition: CscRawDataCollection.cxx:59
DataVector::erase
iterator erase(iterator position)
Remove element at a given position.
CscRODReadOutV1::address
uint32_t address(const Identifier &channelId, int &eta, int &phi) const
Definition: CscRODReadOutV1.h:266
CscRODReadOutV1::getFooterSize
uint32_t getFooterSize()
Definition: CscRODReadOutV1.h:27
CscRODReadOutV1::set
void set(const CscIdHelper *cscHelper)
Definition: CscRODReadOutV1.h:52
test_pyathena.counter
counter
Definition: test_pyathena.py:15
Muon::CscROD_Decoder::rodVersion2
void rodVersion2(const OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment &robFrag, CscRawDataContainer &rdoIDC) const
Definition: CscROD_Decoder.cxx:119
checkFileSG.words
words
Definition: checkFileSG.py:76
Muon::CscROD_Decoder::fillCollection
virtual void fillCollection(const xAOD::EventInfo &eventInfo, const OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment &robFrag, CscRawDataContainer &rdoIDC) const override
Definition: CscROD_Decoder.cxx:38
CscRODReadOutV0::set
void set(const CscIdHelper *cscHelper)
Definition: CscRODReadOutV0.h:39
xAOD::EventInfo_v1::IS_TESTBEAM
@ IS_TESTBEAM
true: testbeam, false: full detector
Definition: EventInfo_v1.h:153
CscRODReadOutV1::decodeAddress
void decodeAddress(const uint32_t fragment)
Definition: CscRODReadOutV1.h:183
CscRawDataCollection::setLatency
void setLatency(const uint16_t latency)
insert the latency into the detector event type word
Definition: CscRawDataCollection.cxx:73
CscRawDataCollection::rate
uint8_t rate() const
the rate could be 25 or 50 ns
Definition: CscRawDataCollection.cxx:24
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
fitman.k
k
Definition: fitman.py:528
xAOD::EventInfo_v1::eventType
bool eventType(EventType type) const
Check for one particular bitmask value.
CscRawDataCollection::setNumDPU
void setNumDPU(const uint16_t numDPU)
obsolete - just backward compatibility with old data
Definition: CscRawDataCollection.cxx:110
Identifier
Definition: IdentifierFieldParser.cxx:14