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
|
#include "DQMOffline/Trigger/interface/EgHLTTrigCodes.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
const int egHLT::TrigCodes::maxNrBits_;
using namespace egHLT;
TrigCodes* TrigCodes::makeCodes(std::vector<std::string>& filterNames) {
auto* p = new TrigCodes();
for (size_t i = 0; i < filterNames.size(); i++) {
p->setCode(filterNames[i].c_str(), i);
}
p->sort();
return p;
}
void TrigCodes::setCode(const char* descript, int bitNr) {
if (bitNr < maxNrBits_) {
TrigBitSet code;
code.set(bitNr);
setCode(descript, code);
} else {
edm::LogWarning("TrigCodes::TrigBitSetMap")
<< " Warning, trying to store at bit " << bitNr << " but max nr bits is " << maxNrBits_;
}
}
void TrigCodes::setCode(const char* descript, TrigBitSet code) {
bool found = false;
for (size_t i = 0; i < codeDefs_.size() && !found; i++) {
if (codeDefs_[i].first == descript)
found = true;
}
if (!found)
codeDefs_.emplace_back(descript, code);
//_codeDefs[descript] = code;
}
TrigCodes::TrigBitSet TrigCodes::getCode(const char* descript) const {
TrigBitSet code;
char const* const end = descript + strlen(descript);
char const* codeKey = descript;
char const* token = nullptr;
do {
token = std::find(codeKey, end, ':');
for (auto const& c : codeDefs_) {
if (0 == c.first.compare(0, std::string::npos, codeKey, token - codeKey)) {
code |= c.second;
break;
}
}
codeKey = token + 1;
} while (token != end);
return code;
}
bool TrigCodes::keyComp(const std::pair<std::string, TrigBitSet>& lhs, const std::pair<std::string, TrigBitSet>& rhs) {
return lhs.first < rhs.first;
}
void TrigCodes::getCodeName(TrigBitSet code, std::string& id) const {
id.clear();
for (auto const& codeDef : codeDefs_) {
if ((code & codeDef.second) == codeDef.second) {
if (!id.empty())
id += ":"; //seperating entries by a ':'
id += codeDef.first;
}
}
}
void TrigCodes::printCodes() {
std::ostringstream msg;
msg << " trig bits defined: " << std::endl;
for (auto& codeDef : codeDefs_)
msg << " key : " << codeDef.first << " bit " << codeDef.second << std::endl;
edm::LogInfo("TrigCodes") << msg.str();
}
|