-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathORKatrinV4FLTEnergyHistogramDecoder.cc
104 lines (91 loc) · 3.53 KB
/
ORKatrinV4FLTEnergyHistogramDecoder.cc
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// ORKatrinV4FLTEnergyHistogramDecoder.cc
#include "TROOT.h"
#include "ORKatrinV4FLTEnergyHistogramDecoder.hh"
#include "ORLogger.hh"
bool ORKatrinV4FLTEnergyHistogramDecoder::SetDataRecord(UInt_t* dataRecord)
{
fDataRecord = dataRecord;
fHistogramLength = HistogramLengthOf(dataRecord);
ORLog(kDebug) << "SetDataRecord(): Setting the data record..." << std::endl;
// remarks for Till: LengthOf(...) is from ORVDataDecoder and is the length extracted from data record -tb-
//TODO: need to implement IsValid() ... -tb- if(!IsValid() || LengthOf(fDataRecord) != kBufHeadLen + fHistogramLength) {
if(LengthOf(fDataRecord) != kBufHeadLen + fHistogramLength) {
ORLog(kDebug) << "SetDataRecord(): data record is not valid" << std::endl;
ORLog(kDebug) << "LengthOf(data record) : " << LengthOf(fDataRecord)
<< " kBufHeadLen + fHistogramLength: " << kBufHeadLen + fHistogramLength << std::endl;
fDataRecord = NULL;
fHistogramLength = -1;
return false;
}
ORLog(kDebug) << "SetDataRecord(): Exiting" << std::endl;
return true;
}
size_t ORKatrinV4FLTEnergyHistogramDecoder::CopyHistogramData(UInt_t* histogram,
size_t len )
//copies the histogram data to the array pointed to by
//histogram, which is of length len
{
//ORLog(kDebug) << "Entered CopyHistogramData ... fDataRecord=" << fDataRecord << std::endl;
size_t wflen = HistogramLengthOf(fDataRecord);
if (wflen == 0){
ORLog(kDebug) << "CopyHistogramData(): histogram is empty" << std::endl;
return 0;
}
if ((len < wflen) || (len == 0)) {
ORLog(kWarning) << "CopyHistogramData(): destination array length is " << len
<< "; histogram data length is " << HistogramLengthOf(fDataRecord) << std::endl;
}
else len = HistogramLengthOf(fDataRecord);;
UInt_t* histogramData = GetHistogramDataPointer();
for(size_t i=0;i<len;i++)
{
histogram[i] = histogramData[i];
ORLog(kDebug) << "CopyHistogramData(): histogram[" << i << "]" << histogram[i]
<< "histogramData[" << i << "] " << histogramData[i] << std::endl;
}
return len;
}
std::string ORKatrinV4FLTEnergyHistogramDecoder::GetParName(size_t iPar)
{
switch(iPar) {
case 0: return "crate";
case 1: return "card";
case 2: return "channel";
case 3: return "readoutSec";
case 4: return "refreshTime";
case 5: return "firstBin";
case 6: return "lastBin";
case 7: return "histogramLength";
case 8: return "maxHistogramLength";
case 9: return "binSize";
case 10:return "offsetEMin";
case 11:return "ID";
case 12:return "Info";
default:
ORLog(kWarning) << "GetParName(): index (" << iPar
<< ") out of range." << std::endl;
return "unknown";
}
}
UInt_t ORKatrinV4FLTEnergyHistogramDecoder::GetPar(UInt_t* record, size_t iPar, size_t /*iRow*/)
{
switch(iPar) {
case 0: return CrateOf(record);
case 1: return CardOf(record);
case 2: return ChannelOf(record);
case 3: return ReadoutSecOf(record);
case 4: return RefreshTimeOf(record);
case 5: return FirstBinOf(record);
case 6: return LastBinOf(record);
case 7: return HistogramLengthOf(record);
case 8: return MaxHistogramLengthOf(record);
case 9: return BinSizeOf(record);
case 10:return OffsetEMinOf(record);
case 11:return HistogramIDOf(record);
case 12:return HistogramInfoOf(record);
default:
ORLog(kWarning) << "GetPar(): index (" << iPar
<< ") out of range." << std::endl;
return 0;
}
}