2024-01-12 19:12:37 -05:00
|
|
|
#ifndef Hit_H
|
|
|
|
#define Hit_H
|
|
|
|
|
2024-02-19 11:53:29 -05:00
|
|
|
#include <vector>
|
|
|
|
|
2024-01-12 19:12:37 -05:00
|
|
|
class Hit{
|
|
|
|
public:
|
2024-01-19 03:07:16 -05:00
|
|
|
unsigned short sn;
|
|
|
|
uint8_t bd;
|
|
|
|
uint8_t ch;
|
2024-01-12 19:12:37 -05:00
|
|
|
unsigned short energy;
|
|
|
|
unsigned short energy2;
|
|
|
|
unsigned long long timestamp;
|
|
|
|
unsigned short fineTime;
|
2024-01-25 18:34:58 -05:00
|
|
|
bool pileUp;
|
2024-01-12 19:12:37 -05:00
|
|
|
|
2024-01-19 03:07:16 -05:00
|
|
|
unsigned short traceLength;
|
2024-01-12 19:12:37 -05:00
|
|
|
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;
|
2024-01-25 18:34:58 -05:00
|
|
|
pileUp = false;
|
2024-01-12 19:12:37 -05:00
|
|
|
trace.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Print(){
|
2024-01-25 18:34:58 -05:00
|
|
|
printf("(%5d, %2d) %6d %16llu, %6d, %d, %5ld\n", sn, ch, energy, timestamp, fineTime, pileUp, trace.size());
|
2024-01-16 15:39:41 -05:00
|
|
|
}
|
|
|
|
|
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]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-16 15:39:41 -05:00
|
|
|
// Define operator< for sorting
|
|
|
|
bool operator<(const Hit& other) const {
|
|
|
|
return timestamp < other.timestamp;
|
2024-01-12 19:12:37 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|