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
|
#include "DPGAnalysis/HcalNanoAOD/interface/QIE11DigiSortedTable.h"
QIE11DigiSortedTable::QIE11DigiSortedTable(const std::vector<HcalDetId>& dids, const unsigned int nTS) {
dids_ = dids;
for (std::vector<HcalDetId>::const_iterator it_did = dids_.begin(); it_did != dids_.end(); ++it_did) {
did_indexmap_[*it_did] = (unsigned int)(it_did - dids_.begin());
}
nTS_ = nTS;
ietas_.resize(dids_.size());
iphis_.resize(dids_.size());
subdets_.resize(dids_.size());
depths_.resize(dids_.size());
rawIds_.resize(dids_.size());
linkErrors_.resize(dids_.size());
capidErrors_.resize(dids_.size());
flags_.resize(dids_.size());
sois_.resize(dids_.size());
valids_.resize(dids_.size());
sipmTypes_.resize(dids_.size());
adcs_.resize(nTS_, std::vector<int>(dids_.size()));
fcs_.resize(nTS_, std::vector<float>(dids_.size()));
pedestalfcs_.resize(nTS_, std::vector<float>(dids_.size()));
tdcs_.resize(nTS_, std::vector<int>(dids_.size()));
capids_.resize(nTS_, std::vector<int>(dids_.size()));
}
void QIE11DigiSortedTable::add(const QIE11DataFrame* digi, const edm::ESHandle<HcalDbService>& dbService) {
HcalDetId did = digi->detid();
unsigned int index = did_indexmap_.at(did);
CaloSamples digiCaloSamples = hcaldqm::utilities::loadADC2fCDB<QIE11DataFrame>(dbService, did, *digi);
HcalCalibrations calibrations = dbService->getHcalCalibrations(did);
ietas_[index] = did.ieta();
iphis_[index] = did.iphi();
subdets_[index] = did.subdet();
depths_[index] = did.depth();
rawIds_[index] = did.rawId();
linkErrors_[index] = digi->linkError();
capidErrors_[index] = digi->capidError();
flags_[index] = digi->flags();
sipmTypes_[index] = (uint8_t)dbService->getHcalSiPMParameter(did)->getType();
for (unsigned int iTS = 0; iTS < (unsigned int)digi->samples(); ++iTS) {
if ((*digi)[iTS].soi()) {
sois_[index] = iTS;
}
adcs_[iTS][index] = (*digi)[iTS].adc();
tdcs_[iTS][index] = (*digi)[iTS].tdc();
capids_[iTS][index] = (*digi)[iTS].capid();
fcs_[iTS][index] = digiCaloSamples[iTS];
pedestalfcs_[iTS][index] = calibrations.pedestal((*digi)[iTS].capid());
}
valids_[index] = true;
}
void QIE11DigiSortedTable::reset() {
std::fill(ietas_.begin(), ietas_.end(), 0);
std::fill(iphis_.begin(), iphis_.end(), 0);
std::fill(subdets_.begin(), subdets_.end(), 0);
std::fill(depths_.begin(), depths_.end(), 0);
std::fill(rawIds_.begin(), rawIds_.end(), 0);
std::fill(linkErrors_.begin(), linkErrors_.end(), false);
std::fill(capidErrors_.begin(), capidErrors_.end(), false);
std::fill(flags_.begin(), flags_.end(), 0);
std::fill(sois_.begin(), sois_.end(), 0);
std::fill(valids_.begin(), valids_.end(), false);
std::fill(sipmTypes_.begin(), sipmTypes_.end(), 0);
for (auto& it : adcs_) {
std::fill(it.begin(), it.end(), 0);
}
for (auto& it : fcs_) {
std::fill(it.begin(), it.end(), 0);
}
for (auto& it : pedestalfcs_) {
std::fill(it.begin(), it.end(), 0);
}
for (auto& it : tdcs_) {
std::fill(it.begin(), it.end(), 0);
}
for (auto& it : capids_) {
std::fill(it.begin(), it.end(), 0);
}
}
|