65 #include "boost/algorithm/string.hpp"
68 std::vector<std::regex> convertToRegex(std::vector<std::string>
const& iPatterns) {
69 std::vector<std::regex>
result;
71 for (
auto const&
pattern : iPatterns) {
73 boost::replace_all(regexPattern,
"*",
".*");
74 boost::replace_all(regexPattern,
"?",
".");
76 result.emplace_back(regexPattern);
86 : throw_(ps.getParameter<
bool>(
"throw")),
87 pn_(ps.getParameter<
std::
string>(
"processName")),
88 moduleLabelPatternsToMatch_(
89 convertToRegex(ps.getParameter<
std::vector<
std::
string>>(
"moduleLabelPatternsToMatch"))),
90 moduleLabelPatternsToSkip_(
91 convertToRegex(ps.getParameter<
std::vector<
std::
string>>(
"moduleLabelPatternsToSkip"))) {
97 edm::LogError(
"TriggerSummaryProducerAOD") <<
"HLT Error: TriggerNamesService not available!";
101 LogDebug(
"TriggerSummaryProducerAOD") <<
"Using process name: '" <<
pn_ <<
"'";
103 produces<trigger::TriggerEvent>();
105 auto const* pProcessName = &
pn_;
110 if (iBranch.processName() == *pProcessName || *pProcessName ==
"*") {
111 auto const&
label = iBranch.moduleLabel();
116 if (std::regex_match(
label, reject)) {
203 const char token(
':');
208 if (
i1 == string::npos) {
215 if (
i2 == string::npos) {
227 desc.
add<
bool>(
"throw",
false)->setComment(
"Throw exception or LogError");
230 "Process name to use when getting data. The value of '@' is used to denote the current process name.");
231 desc.
add<std::vector<std::string>>(
"moduleLabelPatternsToMatch", std::vector<std::string>(1,
"hlt*"))
232 ->setComment(
"glob patterns for module labels to get data.");
233 desc.
add<std::vector<std::string>>(
"moduleLabelPatternsToSkip", std::vector<std::string>())
234 ->setComment(
"module labels for data products which should not be gotten.");
235 descriptions.
add(
"triggerSummaryProducerAOD", desc);
242 using namespace reco;
247 std::vector<edm::Handle<trigger::TriggerFilterObjectWithRefs>> fobs;
250 const unsigned int nfob(fobs.size());
251 LogTrace(
"TriggerSummaryProducerAOD") <<
"Number of filter objects found: " << nfob;
253 string tagLabel, tagInstance, tagProcess;
260 std::vector<bool> maskFilters;
261 maskFilters.resize(nfob);
266 for (
unsigned int ifob = 0; ifob != nfob; ++ifob) {
267 maskFilters[ifob] =
false;
268 const vector<string>& collectionTags_(fobs[ifob]->getCollectionTagsAsStrings());
269 const unsigned int ncol(collectionTags_.size());
272 maskFilters[ifob] =
true;
274 const string&
instance(fobs[ifob].provenance()->productInstanceName());
277 for (
unsigned int icol = 0; icol != ncol; ++icol) {
279 tokenizeTag(collectionTags_[icol], tagLabel, tagInstance, tagProcess);
280 collectionTagsEvent.insert(
InputTag(tagLabel, tagInstance,
pn_));
285 if (filterTagsEvent.size() != nf) {
286 LogError(
"TriggerSummaryProducerAOD")
287 <<
"Mismatch in number of filter tags: " << filterTagsEvent.size() <<
"!=" << nf;
297 const unsigned int nc(collectionTagsEvent.size());
298 LogTrace(
"TriggerSummaryProducerAOD") <<
"Number of unique collections requested " << nc;
299 const InputTagSet::const_iterator cb(collectionTagsEvent.begin());
300 const InputTagSet::const_iterator ce(collectionTagsEvent.end());
301 for (InputTagSet::const_iterator ci = cb; ci != ce; ++ci) {
302 LogTrace(
"TriggerSummaryProducerAOD") <<
distance(cb, ci) <<
" " << ci->encode();
304 const unsigned int nf(filterTagsEvent.size());
305 LogTrace(
"TriggerSummaryProducerAOD") <<
"Number of unique filters requested " << nf;
306 const InputTagSet::const_iterator
fb(filterTagsEvent.begin());
307 const InputTagSet::const_iterator fe(filterTagsEvent.end());
308 for (InputTagSet::const_iterator fi =
fb; fi != fe; ++fi) {
320 std::vector<std::string>
tags;
322 std::map<edm::ProductID, unsigned int>
offset;
324 fillTriggerObjectCollections<RecoEcalCandidateCollection>(
326 fillTriggerObjectCollections<ElectronCollection>(
328 fillTriggerObjectCollections<RecoChargedCandidateCollection>(
330 fillTriggerObjectCollections<CaloJetCollection>(
332 fillTriggerObjectCollections<CompositeCandidateCollection>(
335 fillTriggerObjectCollections<CaloMETCollection>(
337 fillTriggerObjectCollections<IsolatedPixelTrackCandidateCollection>(
340 fillTriggerObjectCollections<L1EmParticleCollection>(
342 fillTriggerObjectCollections<L1MuonParticleCollection>(
344 fillTriggerObjectCollections<L1JetParticleCollection>(
346 fillTriggerObjectCollections<L1EtMissParticleCollection>(
348 fillTriggerObjectCollections<L1HFRingsCollection>(
350 fillTriggerObjectCollections<MuonBxCollection>(
352 fillTriggerObjectCollections<EGammaBxCollection>(
354 fillTriggerObjectCollections<JetBxCollection>(
356 fillTriggerObjectCollections<TauBxCollection>(
358 fillTriggerObjectCollections<EtSumBxCollection>(
361 fillTriggerObjectCollections<l1t::TkMuonCollection>(
363 fillTriggerObjectCollections<l1t::TkElectronCollection>(
365 fillTriggerObjectCollections<l1t::TkEmCollection>(
367 fillTriggerObjectCollections<l1t::PFJetCollection>(
369 fillTriggerObjectCollections<l1t::PFTauCollection>(
371 fillTriggerObjectCollections<l1t::HPSPFTauCollection>(
373 fillTriggerObjectCollections<l1t::PFTrackCollection>(
376 fillTriggerObjectCollections<reco::PFJetCollection>(
378 fillTriggerObjectCollections<reco::PFTauCollection>(
380 fillTriggerObjectCollections<reco::PFMETCollection>(
383 const unsigned int nk(
tags.size());
384 LogDebug(
"TriggerSummaryProducerAOD") <<
"Number of collections found: " << nk;
385 const unsigned int no(toc.size());
386 LogDebug(
"TriggerSummaryProducerAOD") <<
"Number of physics objects found: " << no;
393 product->addCollections(
tags,
keys);
394 product->addObjects(toc);
398 for (
unsigned int ifob = 0; ifob != nfob; ++ifob) {
399 if (maskFilters[ifob]) {
401 const string&
instance(fobs[ifob].provenance()->productInstanceName());
408 iEvent, filterTag, fobs[ifob]->electronIds(), fobs[ifob]->electronRefs(),
offset,
keys, ids);
412 iEvent, filterTag, fobs[ifob]->compositeIds(), fobs[ifob]->compositeRefs(),
offset,
keys, ids);
414 iEvent, filterTag, fobs[ifob]->basemetIds(), fobs[ifob]->basemetRefs(),
offset,
keys, ids);
416 iEvent, filterTag, fobs[ifob]->calometIds(), fobs[ifob]->calometRefs(),
offset,
keys, ids);
418 iEvent, filterTag, fobs[ifob]->pixtrackIds(), fobs[ifob]->pixtrackRefs(),
offset,
keys, ids);
423 iEvent, filterTag, fobs[ifob]->l1etmissIds(), fobs[ifob]->l1etmissRefs(),
offset,
keys, ids);
425 iEvent, filterTag, fobs[ifob]->l1hfringsIds(), fobs[ifob]->l1hfringsRefs(),
offset,
keys, ids);
427 iEvent, filterTag, fobs[ifob]->l1tmuonIds(), fobs[ifob]->l1tmuonRefs(),
offset,
keys, ids);
429 iEvent, filterTag, fobs[ifob]->l1tegammaIds(), fobs[ifob]->l1tegammaRefs(),
offset,
keys, ids);
433 iEvent, filterTag, fobs[ifob]->l1tetsumIds(), fobs[ifob]->l1tetsumRefs(),
offset,
keys, ids);
436 iEvent, filterTag, fobs[ifob]->l1ttkmuonIds(), fobs[ifob]->l1ttkmuonRefs(),
offset,
keys, ids);
438 iEvent, filterTag, fobs[ifob]->l1ttkeleIds(), fobs[ifob]->l1ttkeleRefs(),
offset,
keys, ids);
440 iEvent, filterTag, fobs[ifob]->l1ttkemIds(), fobs[ifob]->l1ttkemRefs(),
offset,
keys, ids);
442 iEvent, filterTag, fobs[ifob]->l1tpfjetIds(), fobs[ifob]->l1tpfjetRefs(),
offset,
keys, ids);
444 iEvent, filterTag, fobs[ifob]->l1tpftauIds(), fobs[ifob]->l1tpftauRefs(),
offset,
keys, ids);
446 iEvent, filterTag, fobs[ifob]->l1thpspftauIds(), fobs[ifob]->l1thpspftauRefs(),
offset,
keys, ids);
448 iEvent, filterTag, fobs[ifob]->l1tpftrackIds(), fobs[ifob]->l1tpftrackRefs(),
offset,
keys, ids);
453 product->addFilter(filterTag, ids,
keys);
458 LogTrace(
"TriggerSummaryProducerAOD") <<
"Number of physics objects packed: " << ref->
sizeObjects();
459 LogTrace(
"TriggerSummaryProducerAOD") <<
"Number of filter objects packed: " << ref->
sizeFilters();
462 template <
typename C>
465 std::vector<std::string>&
tags,
476 using namespace reco;
485 for (
unsigned int ic = 0; ic != nc; ++ic) {
492 if (collectionTagsEvent.find(collectionTag) != collectionTagsEvent.end()) {
495 LogError(
"TriggerSummaryProducerAOD") <<
"Duplicate pid: " << pid;
499 for (
unsigned int i = 0;
i !=
n; ++
i) {
502 tags.push_back(collectionTag.encode());
503 keys.push_back(toc.size());
509 template <
typename T>
512 toc.emplace_back(
object);
523 object.hfEtSum(L1HFRings::kRing1PosEta),
524 object.hfEtSum(L1HFRings::kRing1NegEta),
525 object.hfEtSum(L1HFRings::kRing2PosEta),
526 object.hfEtSum(L1HFRings::kRing2NegEta));
528 object.hfBitCount(L1HFRings::kRing1PosEta),
529 object.hfBitCount(L1HFRings::kRing1NegEta),
530 object.hfBitCount(L1HFRings::kRing2PosEta),
531 object.hfBitCount(L1HFRings::kRing2NegEta));
541 toc.emplace_back(
object);
542 if (
object.
type() == L1EtMissParticle::kMET) {
543 toc.emplace_back(
TriggerL1ETT,
object.etTotal(), 0.0, 0.0, 0.0);
544 }
else if (
object.
type() == L1EtMissParticle::kMHT) {
545 toc.emplace_back(
TriggerL1HTT,
object.etTotal(), 0.0, 0.0, 0.0);
547 toc.emplace_back(0,
object.etTotal(), 0.0, 0.0, 0.0);
555 using namespace reco;
558 toc.emplace_back(
object);
560 toc.emplace_back(
TriggerMETSig,
object.mEtSig(), 0.0, 0.0, 0.0);
561 toc.emplace_back(
TriggerELongit,
object.e_longitudinal(), 0.0, 0.0, 0.0);
568 using namespace reco;
571 toc.emplace_back(
object);
573 toc.emplace_back(
TriggerMETSig,
object.mEtSig(), 0.0, 0.0, 0.0);
574 toc.emplace_back(
TriggerELongit,
object.e_longitudinal(), 0.0, 0.0, 0.0);
581 using namespace reco;
584 toc.emplace_back(
object);
586 toc.emplace_back(
TriggerMHTSig,
object.mEtSig(), 0.0, 0.0, 0.0);
587 toc.emplace_back(
TriggerHLongit,
object.e_longitudinal(), 0.0, 0.0, 0.0);
592 template <
typename C>
606 using namespace reco;
610 if (ids.size() != refs.size()) {
611 LogError(
"TriggerSummaryProducerAOD") <<
"Vector length is different: " << ids.size() <<
" " << refs.size();
614 const unsigned int n(
min(ids.size(), refs.size()));
615 for (
unsigned int i = 0;
i !=
n; ++
i) {
618 std::ostringstream ost;
619 ost <<
"Iinvalid pid: " << pid <<
" FilterTag / Key: " <<
tag.encode() <<
" / " <<
i <<
"of" <<
n
620 <<
" CollectionTag / Key: "
621 <<
" <Unrecoverable>"
622 <<
" / " << refs[
i].key() <<
" CollectionType: " <<
typeid(
C).
name();
626 LogError(
"TriggerSummaryProducerAOD") << ost.str();
629 auto itOffset =
offset.find(pid);
630 if (itOffset ==
offset.end()) {
631 const string&
label(
iEvent.getProvenance(pid).moduleLabel());
632 const string&
instance(
iEvent.getProvenance(pid).productInstanceName());
633 const string&
process(
iEvent.getProvenance(pid).processName());
634 std::ostringstream ost;
635 ost <<
"Uunknown pid: " << pid <<
" FilterTag / Key: " <<
tag.encode() <<
" / " <<
i <<
"of" <<
n
637 <<
" CollectionType: " <<
typeid(
C).
name();
641 LogError(
"TriggerSummaryProducerAOD") << ost.str();
651 template <
typename C>
763 LogVerbatim(
"TriggerSummaryProducerAOD") <<
"TriggerSummaryProducerAOD::globalEndJob - accumulated tags:" << endl;
772 const unsigned int nf(filterTags.size());
773 LogVerbatim(
"TriggerSummaryProducerAOD") <<
" Overall number of Collections/Filters: " << nc <<
"/" << nf << endl;
775 LogVerbatim(
"TriggerSummaryProducerAOD") <<
" The collections: " << nc << endl;
778 for (InputTagSet::const_iterator ci = cb; ci != ce; ++ci) {
779 LogVerbatim(
"TriggerSummaryProducerAOD") <<
" " <<
distance(cb, ci) <<
" " << ci->encode() << endl;
782 LogVerbatim(
"TriggerSummaryProducerAOD") <<
" The filters:" << nf << endl;
783 const InputTagSet::const_iterator
fb(filterTags.begin());
784 const InputTagSet::const_iterator fe(filterTags.end());
785 for (InputTagSet::const_iterator fi =
fb; fi != fe; ++fi) {
789 LogVerbatim(
"TriggerSummaryProducerAOD") <<
"TriggerSummaryProducerAOD::endJob." << endl;