11#ifndef ALICEO2_EMCAL_STUDECODER_H
12#define ALICEO2_EMCAL_STUDECODER_H
49 int32_t
getRho()
const {
return (mCFGword13 & 0x3FFFF); }
53 int32_t
getParchSize()
const {
return ((mCFGword16 >> 16) & 0xFFFF); }
80 return std::make_tuple(((mCFGWord0 >> 9) & 0x1F), ((mCFGWord0 >> 4) & 0x1F), (mCFGWord0 & 0xF));
97 std::vector<int16_t> mL1JetHighPatchIndex;
98 std::vector<int16_t> mL1JetLowPatchIndex;
99 std::vector<int16_t> mL1GammaHighPatchIndex;
100 std::vector<int16_t> mL1GammaLowPatchIndex;
101 std::vector<int16_t> mFastOrADC;
104 int32_t mCFGWord0 = 0;
105 int32_t mCFGWord1 = 0;
107 int32_t mL1GammaHighThreshold = 0;
108 int32_t mShortPayloadRate = 0;
110 int32_t mL1JetHighThreshold = 0;
111 int32_t mL1GammaLowThreshold = 0;
112 int32_t mL1JetLowThreshold = 0;
113 int32_t mCFGword13 = 0;
114 int32_t mRegionEnable = 0;
115 int32_t mFrameReceived = 0;
116 int32_t mCFGword16 = 0;
119 bool mIsFullPayload =
true;
122 void decodeL1JetPatchIndices(
const uint32_t*
buffer);
123 void decodeL1GammaPatchIndices(
const uint32_t*
buffer);
124 void decodeFastOrADC(
const uint32_t*
buffer);
136 ClassDefNV(StuDecoder, 1);
Reader for raw data produced by the Readout application in in-memory format.
Decoder of the EMCAL/DCAL STU data.
std::vector< int16_t > getL1GammaHighPatchIndices() const
int32_t getL1GammaLowThreshold() const
int getNumberOfL1GammaHighPatches() const
int32_t getFrameReceivedSTU() const
STUtype_t getSTUtype() const
std::tuple< int, int, int > getL1GammaMaxPatch() const
int getNumberOfL1JetHighPatches() const
bool isMedianMode() const
int16_t getFastOrADC(int iTRU, int iCh) const
bool isFullPayload() const
int16_t getIndexOfL1JetLowPatch(int id) const
int32_t getFWversion() const
int16_t getIndexOfL1GammaLowPatch(int id) const
int16_t getIndexOfL1GammaHighPatch(int id) const
int32_t getL1GammaHighThreshold() const
int32_t getFrameReceived() const
int32_t getL1JetHighThreshold() const
int32_t getL1JetLowThreshold() const
int32_t getParchSize() const
std::vector< int16_t > getFastOrADCs() const
std::vector< int16_t > getL1JetHighPatchIndices() const
std::vector< int16_t > getL1GammaLowPatchIndics() const
int getNumberOfL1JetLowPatches() const
bool isL1JetLowFired() const
std::vector< int16_t > getL1JetLowPatchIndices() const
int16_t getIndexOfL1JetHighPatch(int id) const
void decode()
Decode the STU stream.
int getNumberOfTRUs() const
bool isL1JetHighFired() const
int getNumberOfL1GammaLowPatches() const
bool isL1GammaLowFired() const
int32_t getRegionEnable() const
bool isL1GammaHighFired() const
~StuDecoder()=default
Destructor.
constexpr int SubregionsEta[2]
number of subregions over eta
constexpr int PaloadSizeFull[2]
number of words in full payload = 1944/882-16
constexpr int Raw_nWords[2]
number of words with ADC
constexpr int NTRU[2]
number of TRUs
constexpr int L1JetIndex_nWords[2]
number of words with Jet indices
constexpr int FeeID[2]
FEE_ID in RDH.
constexpr int PaloadSizeShort[2]
number of words in shorts payload = 407/209-16
constexpr int SubregionsPhi[2]
number of subregions over phi
constexpr int L0index_nWords[2]
number of words with null data
constexpr int L1GammaIndex_nWords[2]
number of words with Gamma indices
constexpr int CFG_nWords[2]
number of configuration words
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...