-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrawdata.h
45 lines (36 loc) · 1.33 KB
/
rawdata.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// Raw data structures for analyzer parallelization demo
#ifndef PPODD_RAWDATA
#define PPODD_RAWDATA
#include <cstdint>
#include <cstddef>
using EvDat_t = double;
static constexpr size_t MAXDATA = 16;
static constexpr size_t MAXMODULES = 8;
// For each event
struct EventHeader {
EventHeader() : event_length{0}, event_info{0} {}
EventHeader(uint32_t len, uint32_t info) :
event_length(len), event_info(info) {}
uint32_t event_length; // length of full event (bytes), including this word
uint32_t event_info; // info/flags for this event
} __attribute__((aligned(8)));
// For each module in the event
struct ModuleHeader {
ModuleHeader() : module_length{0}, module_number{0}, module_ndata{0} {}
ModuleHeader(uint32_t len, uint16_t num, uint16_t ndata ) :
module_length(len), module_number(num), module_ndata(ndata) {}
uint32_t module_length; // length of module data (bytes), including this word
uint16_t module_number; // module (detector) number
uint16_t module_ndata; // number of data values for this module
} __attribute__((aligned(8)));
struct ModuleData {
ModuleData() : data{} {}
ModuleHeader header;
EvDat_t data[MAXDATA];
} __attribute__((aligned(128)));
struct Event {
Event() : module{} {}
EventHeader header;
ModuleData* module[MAXMODULES];
} __attribute__((aligned(128)));
#endif