CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes | Friends
sistrip::FEDChannel Class Reference

#include <SiStripFEDBufferComponents.h>

Public Member Functions

uint16_t cmMedian (const uint8_t apvIndex) const
 
const uint8_t * data () const
 
 FEDChannel (const uint8_t *const data, const size_t offset, const uint16_t length)
 
 FEDChannel (const uint8_t *const data, const size_t offset)
 
uint16_t length () const
 
size_t offset () const
 
uint8_t packetCode () const
 

Private Attributes

const uint8_t * data_
 
uint16_t length_
 
size_t offset_
 

Friends

class FEDBuffer
 

Detailed Description

Definition at line 583 of file SiStripFEDBufferComponents.h.

Constructor & Destructor Documentation

sistrip::FEDChannel::FEDChannel ( const uint8_t *const  data,
const size_t  offset,
const uint16_t  length 
)
inline
sistrip::FEDChannel::FEDChannel ( const uint8_t *const  data,
const size_t  offset 
)
inline

Definition at line 1435 of file SiStripFEDBufferComponents.h.

References data_, length_, and offset_.

1435  : data_(data), offset_(offset) {
1436  length_ = (data_[(offset_) ^ 7] + (data_[(offset_ + 1) ^ 7] << 8));
1437  }
const uint8_t * data() const

Member Function Documentation

uint16_t sistrip::FEDChannel::cmMedian ( const uint8_t  apvIndex) const

Definition at line 1432 of file SiStripFEDBufferComponents.cc.

References Exception, sistrip::PACKET_CODE_ZERO_SUPPRESSED, sistrip::PACKET_CODE_ZERO_SUPPRESSED10, sistrip::PACKET_CODE_ZERO_SUPPRESSED8_BOTBOT, sistrip::PACKET_CODE_ZERO_SUPPRESSED8_TOPBOT, sistrip::FEDBufferBase::packetCode(), mps_fire::result, and contentValuesCheck::ss.

Referenced by SiStripCMMonitorPlugin::analyze().

1432  {
1433  const auto pCode = packetCode();
1434  if ((pCode != PACKET_CODE_ZERO_SUPPRESSED) && (pCode != PACKET_CODE_ZERO_SUPPRESSED10) &&
1436  std::ostringstream ss;
1437  ss << "Request for CM median from channel with non-ZS packet code. "
1438  << "Packet code is " << uint16_t(packetCode()) << "." << std::endl;
1439  throw cms::Exception("FEDBuffer") << ss.str();
1440  }
1441  if (apvIndex > 1) {
1442  std::ostringstream ss;
1443  ss << "Channel APV index out of range when requesting CM median for APV. "
1444  << "Channel APV index is " << uint16_t(apvIndex) << "." << std::endl;
1445  throw cms::Exception("FEDBuffer") << ss.str();
1446  }
1447  uint16_t result = 0;
1448  //CM median is 10 bits with lowest order byte first. First APV CM median starts in 4th byte of channel data
1449  result |= data_[(offset_ + 3 + 2 * apvIndex) ^ 7];
1450  result |= (((data_[(offset_ + 4 + 2 * apvIndex) ^ 7]) << 8) & 0x300);
1451  return result;
1452  }
static const uint8_t PACKET_CODE_ZERO_SUPPRESSED8_BOTBOT
static const uint8_t PACKET_CODE_ZERO_SUPPRESSED8_TOPBOT
static const uint8_t PACKET_CODE_ZERO_SUPPRESSED10
static const uint8_t PACKET_CODE_ZERO_SUPPRESSED
const uint8_t * sistrip::FEDChannel::data ( ) const
inline
uint16_t sistrip::FEDChannel::length ( ) const
inline
size_t sistrip::FEDChannel::offset ( ) const
inline
uint8_t sistrip::FEDChannel::packetCode ( ) const
inline

Definition at line 1444 of file SiStripFEDBufferComponents.h.

References data_, and offset_.

Referenced by SiStripClusterizerFromRaw::run().

1444 { return data_[(offset_ + 2) ^ 7]; }

Friends And Related Function Documentation

friend class FEDBuffer
friend

Definition at line 596 of file SiStripFEDBufferComponents.h.

Member Data Documentation

const uint8_t* sistrip::FEDChannel::data_
private

Definition at line 597 of file SiStripFEDBufferComponents.h.

Referenced by data(), FEDChannel(), and packetCode().

uint16_t sistrip::FEDChannel::length_
private

Definition at line 599 of file SiStripFEDBufferComponents.h.

Referenced by FEDChannel(), and length().

size_t sistrip::FEDChannel::offset_
private

Definition at line 598 of file SiStripFEDBufferComponents.h.

Referenced by FEDChannel(), offset(), and packetCode().