FSUDAQ_Qt6/Hit.h

54 lines
911 B
C
Raw Normal View History

#ifndef Hit_H
#define Hit_H
2024-02-19 11:53:29 -05:00
#include <vector>
class Hit{
public:
2024-01-19 03:07:16 -05:00
unsigned short sn;
uint8_t bd;
uint8_t ch;
unsigned short energy;
unsigned short energy2;
unsigned long long timestamp;
unsigned short fineTime;
bool pileUp;
2024-01-19 03:07:16 -05:00
unsigned short traceLength;
std::vector<short> trace;
Hit(){
Clear();
}
void Clear(){
sn = 0;
bd = 0;
ch = 0;
energy = 0;
energy2 = 0;
timestamp = 0;
fineTime = 0;
2024-01-19 03:07:16 -05:00
traceLength = 0;
pileUp = false;
trace.clear();
}
void Print(){
printf("(%5d, %2d) %6d %16llu, %6d, %d, %5ld\n", sn, ch, energy, timestamp, fineTime, pileUp, trace.size());
}
2024-01-19 03:07:16 -05:00
void PrintTrace(){
for( unsigned short i = 0; i < traceLength; i++){
printf("%3u | %6d \n", i, trace[i]);
}
}
// Define operator< for sorting
bool operator<(const Hit& other) const {
return timestamp < other.timestamp;
}
};
#endif