52 unsigned int hits = 0;
168 const int pin = source - 1;
191 std::vector<uint32_t>::const_iterator pos;
210 const int pin = source - 1;
static const int s_fifoOverflowPin
static const int s_sourceIdBit
static const int s_bunchCrossingBits
static const int s_maxHits
static const int s_paddingBits
static const uint32_t s_errorMask
static const int s_threshBit
static const int s_wordLength
Data word length.
bool unpackNeutral()
Unpack neutral data.
static const int s_hitsBits
static const int s_dataWordIdBit
static const int s_threshErrorBit
bool unpack()
Unpack data.
void clear()
Clear all data.
static const int s_dataWordId
int index(int slice, int source) const
unsigned int hits(int slice, int source) const
Return hit counts for given CPM or source ID.
void setHits(int slice, int source, unsigned int hits, int error)
Store hit counts for given CPM or source ID.
static const int s_hitsErrorBits
bool unpackUncompressed()
Unpack uncompressed data.
static const uint32_t s_threshMask
int hitsError(int slice, int source) const
Return hit error for given CPM or source ID.
bool packNeutral()
Pack neutral data.
std::vector< uint32_t > m_hitsData
CPM hits and sums data.
bool packUncompressed()
Pack uncompressed data.
int sourceId(uint32_t word) const
static const uint32_t s_sourceIdMask
void setDaqOverflow(int bit=1)
Set DAQ FIFO Overflow bit in Sub-status word.
void setGlinkParity(int bit=1)
Set G-Link Parity bit in Sub-status word.
void packer(uint32_t datum, int nbits)
Pack given data into given number of bits.
uint32_t unpacker(int nbits)
Unpack given number of bits of data.
void setUnpackErrorCode(int code)
Set the unpacking error code.
bool unpackerSuccess() const
Return unpacker success flag.
bool unpackerNeutralParityError(int pin)
Unpack and test G-Link parity bit for given pin.
void clear()
Clear all data.
void packerNeutralParity(int pin)
Pack current G-Link parity bit for given pin.
void packerFlush()
Flush the current data word padded with zeros.
uint32_t unpackerNeutral(int pin, int nbits)
Unpack given number of bits of neutral data for given pin.
int bunchCrossing() const
Return the Bunch Crossing number (neutral format only)
void unpackerInit()
Initialise unpacker.
void packerNeutral(int pin, uint32_t datum, int nbits)
Pack given neutral data from given pin.
void setBunchCrossing(int bc)
Set the Bunch Crossing number (neutral format only)