38 #include "tmEventSetup/tmEventSetup.hh"
39 #include "tmEventSetup/esTriggerMenu.hh"
40 #include "tmEventSetup/esAlgorithm.hh"
41 #include "tmEventSetup/esCondition.hh"
42 #include "tmEventSetup/esObject.hh"
43 #include "tmEventSetup/esCut.hh"
44 #include "tmEventSetup/esScale.hh"
45 #include "tmGrammar/Algorithm.hh"
50 : m_triggerMenuInterface(
"NULL"),
51 m_triggerMenuName(
"NULL"),
52 m_triggerMenuImplementation(0x0),
66 m_numberConditionChips = numberConditionChipsValue;
71 m_pinsOnConditionChip = pinsOnConditionChipValue;
77 m_orderConditionChip = orderConditionChipValue;
82 m_numberPhysTriggers = numberPhysTriggersValue;
90 m_triggerMenuInterface = menuInterface;
99 m_triggerMenuImplementation = menuImplementation;
107 m_vecMuonTemplate = vecMuonTempl;
111 m_vecCaloTemplate = vecCaloTempl;
115 const std::vector<std::vector<EnergySumTemplate> >& vecEnergySumTempl) {
116 m_vecEnergySumTemplate = vecEnergySumTempl;
120 const std::vector<std::vector<ExternalTemplate> >& vecExternalTempl) {
121 m_vecExternalTemplate = vecExternalTempl;
125 const std::vector<std::vector<CorrelationTemplate> >& vecCorrelationTempl) {
126 m_vecCorrelationTemplate = vecCorrelationTempl;
130 const std::vector<std::vector<CorrelationWithOverlapRemovalTemplate> >& vecCorrelationWithOverlapRemovalTempl) {
131 m_vecCorrelationWithOverlapRemovalTemplate = vecCorrelationWithOverlapRemovalTempl;
137 m_corMuonTemplate = corMuonTempl;
141 m_corCaloTemplate = corCaloTempl;
145 const std::vector<std::vector<EnergySumTemplate> >& corEnergySumTempl) {
146 m_corEnergySumTemplate = corEnergySumTempl;
156 using namespace tmeventsetup;
157 const esTriggerMenu*
menu = reinterpret_cast<const esTriggerMenu*>(utmMenu);
158 const std::map<std::string, esCondition>& condMap =
menu->getConditionMap();
160 std::map<std::string, unsigned int> extBitMap;
163 for (std::map<std::string, esCondition>::const_iterator cit = condMap.begin(); cit != condMap.end(); cit++) {
164 const esCondition&
condition = cit->second;
165 if (
condition.getType() == esConditionType::Externals) {
170 if (
object.getType() == esObjectType::EXT) {
171 unsigned int channelID =
object.getExternalChannelId();
174 if (extBitMap.count(
name) == 0)
193 m_conditionMap.resize(m_numberConditionChips);
195 m_vecMuonTemplate.resize(m_numberConditionChips);
196 m_vecCaloTemplate.resize(m_numberConditionChips);
197 m_vecEnergySumTemplate.resize(m_numberConditionChips);
198 m_vecExternalTemplate.resize(m_numberConditionChips);
200 m_vecCorrelationTemplate.resize(m_numberConditionChips);
201 m_vecCorrelationWithOverlapRemovalTemplate.resize(m_numberConditionChips);
202 m_corMuonTemplate.resize(m_numberConditionChips);
203 m_corCaloTemplate.resize(m_numberConditionChips);
204 m_corEnergySumTemplate.resize(m_numberConditionChips);
206 using namespace tmeventsetup;
209 const esTriggerMenu*
menu = reinterpret_cast<const esTriggerMenu*>(utmMenu);
212 m_triggerMenuDescription =
menu->getComment();
213 m_triggerMenuDate =
menu->getDatetime();
214 m_triggerMenuImplementation = (getMmHashN(
menu->getFirmwareUuid()) & 0xFFFFFFFF);
215 m_triggerMenuName =
menu->getName();
216 m_triggerMenuInterface =
menu->getVersion();
217 m_triggerMenuUUID = (getMmHashN(
menu->getName()) & 0xFFFFFFFF);
219 const std::map<std::string, esAlgorithm>& algoMap =
menu->getAlgorithmMap();
220 const std::map<std::string, esCondition>& condMap =
menu->getConditionMap();
221 const std::map<std::string, esScale>& scaleMap =
menu->getScaleMap();
224 m_gtScales.setScalesName(
menu->getScaleSetName());
225 parseScales(scaleMap);
228 for (std::map<std::string, esAlgorithm>::const_iterator cit = algoMap.begin(); cit != algoMap.end(); cit++) {
233 const esAlgorithm&
algo = cit->second;
236 parseAlgorithm(
algo, chipNr);
239 const std::vector<std::string>& rpn_vec =
algo.getRpnVector();
240 for (
size_t ii = 0;
ii < rpn_vec.size();
ii++) {
250 if (
condition.getType() == esConditionType::SingleEgamma ||
251 condition.getType() == esConditionType::DoubleEgamma ||
252 condition.getType() == esConditionType::TripleEgamma ||
253 condition.getType() == esConditionType::QuadEgamma ||
condition.getType() == esConditionType::SingleTau ||
254 condition.getType() == esConditionType::DoubleTau ||
condition.getType() == esConditionType::TripleTau ||
255 condition.getType() == esConditionType::QuadTau ||
condition.getType() == esConditionType::SingleJet ||
256 condition.getType() == esConditionType::DoubleJet ||
condition.getType() == esConditionType::TripleJet ||
257 condition.getType() == esConditionType::QuadJet) {
261 }
else if (
condition.getType() == esConditionType::TotalEt ||
262 condition.getType() == esConditionType::TotalEtEM ||
263 condition.getType() == esConditionType::TotalHt ||
264 condition.getType() == esConditionType::MissingEt ||
265 condition.getType() == esConditionType::MissingHt ||
266 condition.getType() == esConditionType::MissingEtHF ||
267 condition.getType() == esConditionType::TowerCount ||
268 condition.getType() == esConditionType::MinBiasHFP0 ||
269 condition.getType() == esConditionType::MinBiasHFM0 ||
270 condition.getType() == esConditionType::MinBiasHFP1 ||
271 condition.getType() == esConditionType::MinBiasHFM1 ||
272 condition.getType() == esConditionType::AsymmetryEt ||
273 condition.getType() == esConditionType::AsymmetryHt ||
274 condition.getType() == esConditionType::AsymmetryEtHF ||
275 condition.getType() == esConditionType::AsymmetryHtHF ||
276 condition.getType() == esConditionType::Centrality0 ||
277 condition.getType() == esConditionType::Centrality1 ||
278 condition.getType() == esConditionType::Centrality2 ||
279 condition.getType() == esConditionType::Centrality3 ||
280 condition.getType() == esConditionType::Centrality4 ||
281 condition.getType() == esConditionType::Centrality5 ||
282 condition.getType() == esConditionType::Centrality6 ||
283 condition.getType() == esConditionType::Centrality7) {
284 parseEnergySum(
condition, chipNr,
false);
289 condition.getType() == esConditionType::TripleMuon ||
290 condition.getType() == esConditionType::QuadMuon) {
294 }
else if (
condition.getType() == esConditionType::MuonMuonCorrelation ||
295 condition.getType() == esConditionType::MuonEsumCorrelation ||
296 condition.getType() == esConditionType::CaloMuonCorrelation ||
297 condition.getType() == esConditionType::CaloCaloCorrelation ||
298 condition.getType() == esConditionType::CaloEsumCorrelation ||
299 condition.getType() == esConditionType::InvariantMass ||
300 condition.getType() == esConditionType::TransverseMass) {
304 }
else if (
condition.getType() == esConditionType::Externals) {
307 }
else if (
condition.getType() == esConditionType::SingleEgammaOvRm ||
308 condition.getType() == esConditionType::DoubleEgammaOvRm ||
309 condition.getType() == esConditionType::TripleEgammaOvRm ||
310 condition.getType() == esConditionType::QuadEgammaOvRm ||
311 condition.getType() == esConditionType::SingleTauOvRm ||
312 condition.getType() == esConditionType::DoubleTauOvRm ||
313 condition.getType() == esConditionType::TripleTauOvRm ||
314 condition.getType() == esConditionType::QuadTauOvRm ||
315 condition.getType() == esConditionType::SingleJetOvRm ||
316 condition.getType() == esConditionType::DoubleJetOvRm ||
317 condition.getType() == esConditionType::TripleJetOvRm ||
318 condition.getType() == esConditionType::QuadJetOvRm) {
321 <<
"SingleEgammaOvRm" << std::endl
322 <<
"DoubleEgammaOvRm" << std::endl
323 <<
"TripleEgammaOvRm" << std::endl
324 <<
"QuadEgammaOvRm" << std::endl
325 <<
"SingleTauOvRm" << std::endl
326 <<
"DoubleTauOvRm" << std::endl
327 <<
"TripleTauOvRm" << std::endl
328 <<
"QuadTauOvRm" << std::endl
329 <<
"SingleJetOvRm" << std::endl
330 <<
"DoubleJetOvRm" << std::endl
331 <<
"TripleJetOvRm" << std::endl
332 <<
"QuadJetOvRm" << std::endl
333 <<
"The above conditions types OvRm are not implemented yet in the parser. Please remove alogrithms that "
334 "use this type of condtion from L1T Menu!"
339 else if (
condition.getType() == esConditionType::CaloCaloCorrelationOvRm ||
340 condition.getType() == esConditionType::InvariantMassOvRm ||
341 condition.getType() == esConditionType::TransverseMassOvRm) {
342 parseCorrelationWithOverlapRemoval(
condition, chipNr);
357 m_triggerMenuInterfaceAuthor =
val;
361 m_triggerMenuInterfaceDescription =
val;
379 for (std::vector<ConditionMap>::iterator itCondOnChip = m_conditionMap.begin(); itCondOnChip != m_conditionMap.end();
383 itCondOnChip->clear();
387 m_algorithmMap.clear();
394 LogTrace(
"TriggerMenuParser") <<
" Trying to insert condition \"" << cName <<
"\" in the condition map."
398 if ((m_conditionMap[chipNr]).
count(cName) != 0) {
399 LogTrace(
"TriggerMenuParser") <<
" Condition " << cName <<
" already exists - not inserted!" << std::endl;
403 (m_conditionMap[chipNr])[cName] = &
cond;
404 LogTrace(
"TriggerMenuParser") <<
" OK - condition inserted!" << std::endl;
417 if (m_algorithmMap.count(algName) != 0) {
418 LogTrace(
"TriggerMenuParser") <<
" Algorithm \"" << algName
419 <<
"\"already exists in the algorithm map- not inserted!" << std::endl;
423 if (m_algorithmAliasMap.count(algAlias) != 0) {
424 LogTrace(
"TriggerMenuParser") <<
" Algorithm alias \"" << algAlias
425 <<
"\"already exists in the algorithm alias map- not inserted!" << std::endl;
432 LogTrace(
"TriggerMenuParser") <<
" Bit number " <<
bitNumber <<
" outside allowed range [0, "
433 << m_numberPhysTriggers <<
") - algorithm not inserted!" << std::endl;
438 if (m_algorithmMap.size() >= m_numberPhysTriggers) {
439 LogTrace(
"TriggerMenuParser") <<
" More than maximum allowed " << m_numberPhysTriggers
440 <<
" algorithms in the algorithm map - not inserted!" << std::endl;
446 static_cast<int>(m_numberConditionChips), static_cast<int>(m_pinsOnConditionChip), m_orderConditionChip);
448 if ((chipNr < 0) || (chipNr > static_cast<int>(m_numberConditionChips))) {
449 LogTrace(
"TriggerMenuParser") <<
" Chip number " << chipNr <<
" outside allowed range [0, "
450 << m_numberConditionChips <<
") - algorithm not inserted!" << std::endl;
456 static_cast<int>(m_numberConditionChips), static_cast<int>(m_pinsOnConditionChip), m_orderConditionChip);
458 if ((outputPin < 0) || (outputPin > static_cast<int>(m_pinsOnConditionChip))) {
459 LogTrace(
"TriggerMenuParser") <<
" Output pin " << outputPin <<
" outside allowed range [0, "
460 << m_pinsOnConditionChip <<
"] - algorithm not inserted!" << std::endl;
465 for (
CItAlgo itAlgo = m_algorithmMap.begin(); itAlgo != m_algorithmMap.end(); itAlgo++) {
466 int iPin = (itAlgo->second)
467 .algoOutputPin(static_cast<int>(m_numberConditionChips),
468 static_cast<int>(m_pinsOnConditionChip),
469 m_orderConditionChip);
471 int iChip = (itAlgo->second)
472 .algoChipNumber(static_cast<int>(m_numberConditionChips),
473 static_cast<int>(m_pinsOnConditionChip),
474 m_orderConditionChip);
476 if ((outputPin == iPin) && (chipNr == iChip)) {
477 LogTrace(
"TriggerMenuParser") <<
" Output pin " << outputPin <<
" is the same as for algorithm " << iName
478 <<
"\n from the same chip number " << chipNr <<
" - algorithm not inserted!"
485 m_algorithmMap[algName] = alg;
486 m_algorithmAliasMap[algAlias] = alg;
495 template <
typename T>
497 std::stringstream
ss;
502 std::stringstream
ss;
517 using namespace tmeventsetup;
532 for (std::map<std::string, esScale>::const_iterator cit = scaleMap.begin(); cit != scaleMap.end(); cit++) {
533 const esScale&
scale = cit->second;
537 scaleParam = &muScales;
538 else if (
scale.getObjectType() == esObjectType::Egamma)
539 scaleParam = &egScales;
541 scaleParam = &tauScales;
543 scaleParam = &jetScales;
545 scaleParam = &ettScales;
546 else if (
scale.getObjectType() == esObjectType::ETTEM)
547 scaleParam = &ettEmScales;
549 scaleParam = &etmScales;
550 else if (
scale.getObjectType() == esObjectType::ETMHF)
551 scaleParam = &etmHfScales;
553 scaleParam = &httScales;
555 scaleParam = &htmScales;
557 scaleParam =
nullptr;
559 if (scaleParam !=
nullptr) {
560 switch (
scale.getScaleType()) {
561 case esScaleType::EtScale: {
567 const std::vector<esBin>& binsV =
scale.getBins();
568 for (
unsigned int i = 0;
i < binsV.size();
i++) {
569 const esBin&
bin = binsV.at(
i);
570 std::pair<double, double> binLimits(
bin.minimum,
bin.maximum);
571 scaleParam->
etBins.push_back(binLimits);
578 scale.getObjectType() == esObjectType::ETTEM ||
scale.getObjectType() == esObjectType::ETMHF) {
583 scale.getObjectType() == esObjectType::ETTEM) {
591 case esScaleType::EtaScale: {
597 const std::vector<esBin>& binsV =
scale.getBins();
599 for (
unsigned int i = 0;
i < binsV.size();
i++) {
600 const esBin&
bin = binsV.at(
i);
601 std::pair<double, double> binLimits(
bin.minimum,
bin.maximum);
602 scaleParam->
etaBins.at(
bin.hw_index) = binLimits;
605 case esScaleType::PhiScale: {
611 const std::vector<esBin>& binsV =
scale.getBins();
613 for (
unsigned int i = 0;
i < binsV.size();
i++) {
614 const esBin&
bin = binsV.at(
i);
615 std::pair<double, double> binLimits(
bin.minimum,
bin.maximum);
616 scaleParam->
phiBins.at(
bin.hw_index) = binLimits;
627 m_gtScales.setMuonScales(muScales);
628 m_gtScales.setEGScales(egScales);
629 m_gtScales.setTauScales(tauScales);
630 m_gtScales.setJetScales(jetScales);
631 m_gtScales.setETTScales(ettScales);
632 m_gtScales.setETTEmScales(ettEmScales);
633 m_gtScales.setETMScales(etmScales);
634 m_gtScales.setETMHfScales(etmHfScales);
635 m_gtScales.setHTTScales(httScales);
636 m_gtScales.setHTMScales(htmScales);
639 bool hasPrecision =
false;
640 std::map<std::string, unsigned int> precisions;
641 getPrecisions(precisions, scaleMap);
642 for (std::map<std::string, unsigned int>::const_iterator cit = precisions.begin(); cit != precisions.end(); cit++) {
650 parseCalMuEta_LUTS(scaleMap,
"EG",
"MU");
651 parseCalMuEta_LUTS(scaleMap,
"JET",
"MU");
652 parseCalMuEta_LUTS(scaleMap,
"TAU",
"MU");
656 parseCalMuPhi_LUTS(scaleMap,
"EG",
"MU");
657 parseCalMuPhi_LUTS(scaleMap,
"JET",
"MU");
658 parseCalMuPhi_LUTS(scaleMap,
"TAU",
"MU");
659 parseCalMuPhi_LUTS(scaleMap,
"HTM",
"MU");
660 parseCalMuPhi_LUTS(scaleMap,
"ETM",
"MU");
661 parseCalMuPhi_LUTS(scaleMap,
"ETMHF",
"MU");
665 parsePt_LUTS(scaleMap,
"Mass",
"EG", precisions[
"PRECISION-EG-MU-MassPt"]);
666 parsePt_LUTS(scaleMap,
"Mass",
"MU", precisions[
"PRECISION-EG-MU-MassPt"]);
667 parsePt_LUTS(scaleMap,
"Mass",
"JET", precisions[
"PRECISION-EG-JET-MassPt"]);
668 parsePt_LUTS(scaleMap,
"Mass",
"TAU", precisions[
"PRECISION-EG-TAU-MassPt"]);
669 parsePt_LUTS(scaleMap,
"Mass",
"ETM", precisions[
"PRECISION-EG-ETM-MassPt"]);
670 parsePt_LUTS(scaleMap,
"Mass",
"ETMHF", precisions[
"PRECISION-EG-ETMHF-MassPt"]);
671 parsePt_LUTS(scaleMap,
"Mass",
"HTM", precisions[
"PRECISION-EG-HTM-MassPt"]);
675 parsePt_LUTS(scaleMap,
"TwoBody",
"EG", precisions[
"PRECISION-EG-MU-TwoBodyPt"]);
676 parsePt_LUTS(scaleMap,
"TwoBody",
"MU", precisions[
"PRECISION-EG-MU-TwoBodyPt"]);
677 parsePt_LUTS(scaleMap,
"TwoBody",
"JET", precisions[
"PRECISION-EG-JET-TwoBodyPt"]);
678 parsePt_LUTS(scaleMap,
"TwoBody",
"TAU", precisions[
"PRECISION-EG-TAU-TwoBodyPt"]);
679 parsePt_LUTS(scaleMap,
"TwoBody",
"ETM", precisions[
"PRECISION-EG-ETM-TwoBodyPt"]);
680 parsePt_LUTS(scaleMap,
"TwoBody",
"ETMHF", precisions[
"PRECISION-EG-ETMHF-TwoBodyPt"]);
681 parsePt_LUTS(scaleMap,
"TwoBody",
"HTM", precisions[
"PRECISION-EG-HTM-TwoBodyPt"]);
685 parseDeltaEta_Cosh_LUTS(
686 scaleMap,
"EG",
"EG", precisions[
"PRECISION-EG-EG-Delta"], precisions[
"PRECISION-EG-EG-Math"]);
687 parseDeltaEta_Cosh_LUTS(
688 scaleMap,
"EG",
"JET", precisions[
"PRECISION-EG-JET-Delta"], precisions[
"PRECISION-EG-JET-Math"]);
689 parseDeltaEta_Cosh_LUTS(
690 scaleMap,
"EG",
"TAU", precisions[
"PRECISION-EG-TAU-Delta"], precisions[
"PRECISION-EG-TAU-Math"]);
691 parseDeltaEta_Cosh_LUTS(
692 scaleMap,
"EG",
"MU", precisions[
"PRECISION-EG-MU-Delta"], precisions[
"PRECISION-EG-MU-Math"]);
694 parseDeltaEta_Cosh_LUTS(
695 scaleMap,
"JET",
"JET", precisions[
"PRECISION-JET-JET-Delta"], precisions[
"PRECISION-JET-JET-Math"]);
696 parseDeltaEta_Cosh_LUTS(
697 scaleMap,
"JET",
"TAU", precisions[
"PRECISION-JET-TAU-Delta"], precisions[
"PRECISION-JET-TAU-Math"]);
698 parseDeltaEta_Cosh_LUTS(
699 scaleMap,
"JET",
"MU", precisions[
"PRECISION-JET-MU-Delta"], precisions[
"PRECISION-JET-MU-Math"]);
701 parseDeltaEta_Cosh_LUTS(
702 scaleMap,
"TAU",
"TAU", precisions[
"PRECISION-TAU-TAU-Delta"], precisions[
"PRECISION-TAU-TAU-Math"]);
703 parseDeltaEta_Cosh_LUTS(
704 scaleMap,
"TAU",
"MU", precisions[
"PRECISION-TAU-MU-Delta"], precisions[
"PRECISION-TAU-MU-Math"]);
706 parseDeltaEta_Cosh_LUTS(
707 scaleMap,
"MU",
"MU", precisions[
"PRECISION-MU-MU-Delta"], precisions[
"PRECISION-MU-MU-Math"]);
711 parseDeltaPhi_Cos_LUTS(
712 scaleMap,
"EG",
"EG", precisions[
"PRECISION-EG-EG-Delta"], precisions[
"PRECISION-EG-EG-Math"]);
713 parseDeltaPhi_Cos_LUTS(
714 scaleMap,
"EG",
"JET", precisions[
"PRECISION-EG-JET-Delta"], precisions[
"PRECISION-EG-JET-Math"]);
715 parseDeltaPhi_Cos_LUTS(
716 scaleMap,
"EG",
"TAU", precisions[
"PRECISION-EG-TAU-Delta"], precisions[
"PRECISION-EG-TAU-Math"]);
717 parseDeltaPhi_Cos_LUTS(
718 scaleMap,
"EG",
"ETM", precisions[
"PRECISION-EG-ETM-Delta"], precisions[
"PRECISION-EG-ETM-Math"]);
719 parseDeltaPhi_Cos_LUTS(
720 scaleMap,
"EG",
"ETMHF", precisions[
"PRECISION-EG-ETMHF-Delta"], precisions[
"PRECISION-EG-ETMHF-Math"]);
721 parseDeltaPhi_Cos_LUTS(
722 scaleMap,
"EG",
"HTM", precisions[
"PRECISION-EG-HTM-Delta"], precisions[
"PRECISION-EG-HTM-Math"]);
723 parseDeltaPhi_Cos_LUTS(
724 scaleMap,
"EG",
"MU", precisions[
"PRECISION-EG-MU-Delta"], precisions[
"PRECISION-EG-MU-Math"]);
726 parseDeltaPhi_Cos_LUTS(
727 scaleMap,
"JET",
"JET", precisions[
"PRECISION-JET-JET-Delta"], precisions[
"PRECISION-JET-JET-Math"]);
728 parseDeltaPhi_Cos_LUTS(
729 scaleMap,
"JET",
"TAU", precisions[
"PRECISION-JET-TAU-Delta"], precisions[
"PRECISION-JET-TAU-Math"]);
730 parseDeltaPhi_Cos_LUTS(
731 scaleMap,
"JET",
"ETM", precisions[
"PRECISION-JET-ETM-Delta"], precisions[
"PRECISION-JET-ETM-Math"]);
732 parseDeltaPhi_Cos_LUTS(
733 scaleMap,
"JET",
"ETMHF", precisions[
"PRECISION-JET-ETMHF-Delta"], precisions[
"PRECISION-JET-ETMHF-Math"]);
734 parseDeltaPhi_Cos_LUTS(
735 scaleMap,
"JET",
"HTM", precisions[
"PRECISION-JET-HTM-Delta"], precisions[
"PRECISION-JET-HTM-Math"]);
736 parseDeltaPhi_Cos_LUTS(
737 scaleMap,
"JET",
"MU", precisions[
"PRECISION-JET-MU-Delta"], precisions[
"PRECISION-JET-MU-Math"]);
739 parseDeltaPhi_Cos_LUTS(
740 scaleMap,
"TAU",
"TAU", precisions[
"PRECISION-TAU-TAU-Delta"], precisions[
"PRECISION-TAU-TAU-Math"]);
741 parseDeltaPhi_Cos_LUTS(
742 scaleMap,
"TAU",
"ETM", precisions[
"PRECISION-TAU-ETM-Delta"], precisions[
"PRECISION-TAU-ETM-Math"]);
743 parseDeltaPhi_Cos_LUTS(
744 scaleMap,
"TAU",
"ETMHF", precisions[
"PRECISION-TAU-ETMHF-Delta"], precisions[
"PRECISION-TAU-ETMHF-Math"]);
745 parseDeltaPhi_Cos_LUTS(
746 scaleMap,
"TAU",
"HTM", precisions[
"PRECISION-TAU-HTM-Delta"], precisions[
"PRECISION-TAU-HTM-Math"]);
747 parseDeltaPhi_Cos_LUTS(
748 scaleMap,
"TAU",
"MU", precisions[
"PRECISION-TAU-MU-Delta"], precisions[
"PRECISION-TAU-MU-Math"]);
750 parseDeltaPhi_Cos_LUTS(
751 scaleMap,
"MU",
"ETM", precisions[
"PRECISION-MU-ETM-Delta"], precisions[
"PRECISION-MU-ETM-Math"]);
752 parseDeltaPhi_Cos_LUTS(
753 scaleMap,
"MU",
"ETMHF", precisions[
"PRECISION-MU-ETMHF-Delta"], precisions[
"PRECISION-MU-ETMHF-Math"]);
754 parseDeltaPhi_Cos_LUTS(
755 scaleMap,
"MU",
"HTM", precisions[
"PRECISION-MU-HTM-Delta"], precisions[
"PRECISION-MU-HTM-Math"]);
756 parseDeltaPhi_Cos_LUTS(
757 scaleMap,
"MU",
"MU", precisions[
"PRECISION-MU-MU-Delta"], precisions[
"PRECISION-MU-MU-Math"]);
759 parsePhi_Trig_LUTS(scaleMap,
"EG",
l1t::COS, precisions[
"PRECISION-EG-EG-Math"]);
760 parsePhi_Trig_LUTS(scaleMap,
"JET",
l1t::COS, precisions[
"PRECISION-JET-JET-Math"]);
761 parsePhi_Trig_LUTS(scaleMap,
"TAU",
l1t::COS, precisions[
"PRECISION-TAU-TAU-Math"]);
762 parsePhi_Trig_LUTS(scaleMap,
"MU",
l1t::COS, precisions[
"PRECISION-MU-MU-Math"]);
764 parsePhi_Trig_LUTS(scaleMap,
"EG",
l1t::SIN, precisions[
"PRECISION-EG-EG-Math"]);
765 parsePhi_Trig_LUTS(scaleMap,
"JET",
l1t::SIN, precisions[
"PRECISION-JET-JET-Math"]);
766 parsePhi_Trig_LUTS(scaleMap,
"TAU",
l1t::SIN, precisions[
"PRECISION-TAU-TAU-Math"]);
767 parsePhi_Trig_LUTS(scaleMap,
"MU",
l1t::SIN, precisions[
"PRECISION-MU-MU-Math"]);
780 using namespace tmeventsetup;
789 if (scaleMap.find(scLabel1) == scaleMap.end() || scaleMap.find(scLabel2) == scaleMap.end())
792 const esScale* scale1 = &scaleMap.find(scLabel1)->second;
793 const esScale* scale2 = &scaleMap.find(scLabel2)->second;
795 std::vector<long long> lut_cal_2_mu_eta;
796 getCaloMuonEtaConversionLut(lut_cal_2_mu_eta, scale1, scale2);
801 m_gtScales.setLUT_CalMuEta(lutName, lut_cal_2_mu_eta);
807 using namespace tmeventsetup;
816 if (scaleMap.find(scLabel1) == scaleMap.end() || scaleMap.find(scLabel2) == scaleMap.end())
819 const esScale* scale1 = &scaleMap.find(scLabel1)->second;
820 const esScale* scale2 = &scaleMap.find(scLabel2)->second;
822 std::vector<long long> lut_cal_2_mu_phi;
823 getCaloMuonPhiConversionLut(lut_cal_2_mu_phi, scale1, scale2);
828 m_gtScales.setLUT_CalMuPhi(lutName, lut_cal_2_mu_phi);
835 using namespace tmeventsetup;
842 if (scaleMap.find(scLabel1) == scaleMap.end())
845 const esScale* scale1 = &scaleMap.find(scLabel1)->second;
847 std::vector<long long> lut_pt;
848 getLut(lut_pt, scale1, prec);
850 m_gtScales.setLUT_Pt(lutpfx +
"_" + scLabel1, lut_pt, prec);
857 unsigned int prec2) {
858 using namespace tmeventsetup;
867 if (scaleMap.find(scLabel1) == scaleMap.end() || scaleMap.find(scLabel2) == scaleMap.end())
870 const esScale* scale1 = &scaleMap.find(scLabel1)->second;
871 const esScale* scale2 = &scaleMap.find(scLabel2)->second;
872 std::vector<double> val_delta_eta;
873 std::vector<long long> lut_delta_eta;
874 size_t n = getDeltaVector(val_delta_eta, scale1, scale2);
875 setLut(lut_delta_eta, val_delta_eta, prec1);
879 m_gtScales.setLUT_DeltaEta(lutName, lut_delta_eta, prec1);
882 std::vector<long long> lut_cosh;
883 applyCosh(val_delta_eta,
n);
884 setLut(lut_cosh, val_delta_eta, prec2);
885 m_gtScales.setLUT_Cosh(lutName, lut_cosh, prec2);
892 unsigned int prec2) {
893 using namespace tmeventsetup;
902 if (scaleMap.find(scLabel1) == scaleMap.end() || scaleMap.find(scLabel2) == scaleMap.end())
905 const esScale* scale1 = &scaleMap.find(scLabel1)->second;
906 const esScale* scale2 = &scaleMap.find(scLabel2)->second;
907 std::vector<double> val_delta_phi;
908 std::vector<long long> lut_delta_phi;
909 size_t n = getDeltaVector(val_delta_phi, scale1, scale2);
910 setLut(lut_delta_phi, val_delta_phi, prec1);
914 m_gtScales.setLUT_DeltaPhi(lutName, lut_delta_phi, prec1);
917 std::vector<long long> lut_cos;
918 applyCos(val_delta_phi,
n);
919 setLut(lut_cos, val_delta_phi, prec2);
920 m_gtScales.setLUT_Cos(lutName, lut_cos, prec2);
927 using namespace tmeventsetup;
933 if (scaleMap.find(scLabel) == scaleMap.end())
938 const esScale*
scale = &scaleMap.find(scLabel)->second;
943 const size_t bitwidth =
std::ceil(std::log10(
n) / std::log10(2));
947 for (
size_t ii = 0;
ii <
n;
ii++) {
952 std::vector<long long> lut;
955 setLut(lut,
array, prec);
956 m_gtScales.setLUT_Sin(lutName, lut, prec);
959 setLut(lut,
array, prec);
960 m_gtScales.setLUT_Cos(lutName, lut, prec);
976 using namespace tmeventsetup;
995 }
else if (condMu.getType() == esConditionType::TripleMuon) {
999 }
else if (condMu.getType() == esConditionType::QuadMuon) {
1004 edm::LogError(
"TriggerMenuParser") <<
"Wrong type for muon-condition (" <<
type <<
")" << std::endl;
1009 edm::LogError(
"TriggerMenuParser") <<
"Unknown type for muon-condition (" <<
type <<
")"
1010 <<
"\nCan not determine number of trigger objects. " << std::endl;
1014 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
1016 <<
"\n condition = " <<
condition <<
"\n particle = " << particle
1017 <<
"\n type = " <<
type <<
"\n name = " <<
name << std::endl;
1022 std::vector<MuonTemplate::ObjectParameter> objParameter(nrObj);
1028 std::vector<uint64_t> tmpValues((nrObj > 2) ? nrObj : 2);
1029 tmpValues.reserve(nrObj);
1031 if (
int(condMu.getObjects().size()) != nrObj) {
1032 edm::LogError(
"TriggerMenuParser") <<
" condMu objects: nrObj = " << nrObj
1033 <<
"condMu.getObjects().size() = " << condMu.getObjects().size() << std::endl;
1038 unsigned int chargeCorrelation = 1;
1039 const std::vector<esCut>&
cuts = condMu.getCuts();
1040 for (
size_t jj = 0;
jj <
cuts.size();
jj++) {
1042 if (
cut.getCutType() == esCutType::ChargeCorrelation) {
1043 if (
cut.getData() ==
"ls")
1044 chargeCorrelation = 2;
1045 else if (
cut.getData() ==
"os")
1046 chargeCorrelation = 4;
1048 chargeCorrelation = 1;
1062 const std::vector<esObject>&
objects = condMu.getObjects();
1065 gEq = (
object.getComparisonOperator() == esComparisonOperator::GE);
1068 relativeBx =
object.getBxOffset();
1071 int upperThresholdInd = -1;
1072 int lowerThresholdInd = 0;
1073 int upperIndexInd = -1;
1074 int lowerIndexInd = 0;
1076 unsigned int etaWindow1Lower = -1, etaWindow1Upper = -1, etaWindow2Lower = -1, etaWindow2Upper = -1;
1078 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
1079 int isolationLUT = 0xF;
1081 int qualityLUT = 0xFFFF;
1083 const std::vector<esCut>&
cuts =
object.getCuts();
1084 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
1087 switch (
cut.getCutType()) {
1089 lowerThresholdInd =
cut.getMinimum().index;
1090 upperThresholdInd =
cut.getMaximum().index;
1093 case esCutType::Slice:
1094 lowerIndexInd =
int(
cut.getMinimum().value);
1095 upperIndexInd =
int(
cut.getMaximum().value);
1098 case esCutType::Eta: {
1100 etaWindow1Lower =
cut.getMinimum().index;
1101 etaWindow1Upper =
cut.getMaximum().index;
1102 }
else if (cntEta == 1) {
1103 etaWindow2Lower =
cut.getMinimum().index;
1104 etaWindow2Upper =
cut.getMaximum().index;
1107 <<
"Too Many Eta Cuts for muon-condition (" << particle <<
")" << std::endl;
1116 phiWindow1Lower =
cut.getMinimum().index;
1117 phiWindow1Upper =
cut.getMaximum().index;
1118 }
else if (cntPhi == 1) {
1119 phiWindow2Lower =
cut.getMinimum().index;
1120 phiWindow2Upper =
cut.getMaximum().index;
1123 <<
"Too Many Phi Cuts for muon-condition (" << particle <<
")" << std::endl;
1131 if (
cut.getData() ==
"positive")
1133 else if (
cut.getData() ==
"negative")
1140 qualityLUT = l1tstr2int(
cut.getData());
1143 case esCutType::Isolation: {
1144 isolationLUT = l1tstr2int(
cut.getData());
1154 objParameter[cnt].ptHighThreshold = upperThresholdInd;
1155 objParameter[cnt].ptLowThreshold = lowerThresholdInd;
1157 objParameter[cnt].indexHigh = upperIndexInd;
1158 objParameter[cnt].indexLow = lowerIndexInd;
1160 objParameter[cnt].etaWindow1Lower = etaWindow1Lower;
1161 objParameter[cnt].etaWindow1Upper = etaWindow1Upper;
1162 objParameter[cnt].etaWindow2Lower = etaWindow2Lower;
1163 objParameter[cnt].etaWindow2Upper = etaWindow2Upper;
1165 objParameter[cnt].phiWindow1Lower = phiWindow1Lower;
1166 objParameter[cnt].phiWindow1Upper = phiWindow1Upper;
1167 objParameter[cnt].phiWindow2Lower = phiWindow2Lower;
1168 objParameter[cnt].phiWindow2Upper = phiWindow2Upper;
1171 objParameter[cnt].enableMip =
false;
1172 objParameter[cnt].enableIso =
false;
1173 objParameter[cnt].requestIso =
false;
1175 objParameter[cnt].charge =
charge;
1176 objParameter[cnt].qualityLUT = qualityLUT;
1177 objParameter[cnt].isolationLUT = isolationLUT;
1197 std::ostringstream myCoutStream;
1198 muonCond.
print(myCoutStream);
1199 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
1203 if (!insertConditionIntoMap(muonCond, chipNr)) {
1204 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate condition (" <<
name <<
")" << std::endl;
1207 LogDebug(
"TriggerMenuParser") <<
"Added Condition " <<
name <<
" to the ConditionMap" << std::endl;
1209 (m_corMuonTemplate[chipNr]).push_back(muonCond);
1211 LogDebug(
"TriggerMenuParser") <<
"Added Condition " <<
name <<
" to the vecMuonTemplate vector" << std::endl;
1212 (m_vecMuonTemplate[chipNr]).push_back(muonCond);
1222 using namespace tmeventsetup;
1234 edm::LogError(
"TriggerMenuParser") <<
"Unknown type for muon-condition (" <<
type <<
")"
1235 <<
"\nCan not determine number of trigger objects. " << std::endl;
1239 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
1241 <<
"\n condition = " <<
condition <<
"\n particle = " << particle
1242 <<
"\n type = " <<
type <<
"\n name = " <<
name << std::endl;
1247 std::vector<MuonTemplate::ObjectParameter> objParameter(nrObj);
1253 std::vector<uint64_t> tmpValues((nrObj > 2) ? nrObj : 2);
1254 tmpValues.reserve(nrObj);
1259 unsigned int chargeCorrelation = 0;
1260 if (str_chargeCorrelation ==
"ig")
1261 chargeCorrelation = 1;
1262 else if (str_chargeCorrelation ==
"ls")
1263 chargeCorrelation = 2;
1264 else if (str_chargeCorrelation ==
"os")
1265 chargeCorrelation = 4;
1275 gEq = (corrMu->getComparisonOperator() == esComparisonOperator::GE);
1278 relativeBx = corrMu->getBxOffset();
1281 int upperThresholdInd = -1;
1282 int lowerThresholdInd = 0;
1283 int upperIndexInd = -1;
1284 int lowerIndexInd = 0;
1286 unsigned int etaWindow1Lower = -1, etaWindow1Upper = -1, etaWindow2Lower = -1, etaWindow2Upper = -1;
1288 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
1289 int isolationLUT = 0xF;
1291 int qualityLUT = 0xFFFF;
1293 const std::vector<esCut>&
cuts = corrMu->getCuts();
1294 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
1297 switch (
cut.getCutType()) {
1299 lowerThresholdInd =
cut.getMinimum().index;
1300 upperThresholdInd =
cut.getMaximum().index;
1303 case esCutType::Slice:
1304 lowerIndexInd =
int(
cut.getMinimum().value);
1305 upperIndexInd =
int(
cut.getMaximum().value);
1308 case esCutType::Eta: {
1310 etaWindow1Lower =
cut.getMinimum().index;
1311 etaWindow1Upper =
cut.getMaximum().index;
1312 }
else if (cntEta == 1) {
1313 etaWindow2Lower =
cut.getMinimum().index;
1314 etaWindow2Upper =
cut.getMaximum().index;
1317 <<
"Too Many Eta Cuts for muon-condition (" << particle <<
")" << std::endl;
1326 phiWindow1Lower =
cut.getMinimum().index;
1327 phiWindow1Upper =
cut.getMaximum().index;
1328 }
else if (cntPhi == 1) {
1329 phiWindow2Lower =
cut.getMinimum().index;
1330 phiWindow2Upper =
cut.getMaximum().index;
1333 <<
"Too Many Phi Cuts for muon-condition (" << particle <<
")" << std::endl;
1341 if (
cut.getData() ==
"positive")
1343 else if (
cut.getData() ==
"negative")
1350 qualityLUT = l1tstr2int(
cut.getData());
1353 case esCutType::Isolation: {
1354 isolationLUT = l1tstr2int(
cut.getData());
1364 objParameter[0].ptHighThreshold = upperThresholdInd;
1365 objParameter[0].ptLowThreshold = lowerThresholdInd;
1367 objParameter[0].indexHigh = upperIndexInd;
1368 objParameter[0].indexLow = lowerIndexInd;
1370 objParameter[0].etaWindow1Lower = etaWindow1Lower;
1371 objParameter[0].etaWindow1Upper = etaWindow1Upper;
1372 objParameter[0].etaWindow2Lower = etaWindow2Lower;
1373 objParameter[0].etaWindow2Upper = etaWindow2Upper;
1375 objParameter[0].phiWindow1Lower = phiWindow1Lower;
1376 objParameter[0].phiWindow1Upper = phiWindow1Upper;
1377 objParameter[0].phiWindow2Lower = phiWindow2Lower;
1378 objParameter[0].phiWindow2Upper = phiWindow2Upper;
1381 objParameter[0].enableMip =
false;
1382 objParameter[0].enableIso =
false;
1383 objParameter[0].requestIso =
false;
1385 objParameter[0].charge =
charge;
1386 objParameter[0].qualityLUT = qualityLUT;
1387 objParameter[0].isolationLUT = isolationLUT;
1403 std::ostringstream myCoutStream;
1404 muonCond.
print(myCoutStream);
1405 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
1421 (m_corMuonTemplate[chipNr]).push_back(muonCond);
1440 using namespace tmeventsetup;
1449 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
1450 <<
"\n (in parseCalo) "
1451 <<
"\n condition = " <<
condition <<
"\n particle = " << particle
1452 <<
"\n type = " <<
type <<
"\n name = " <<
name << std::endl;
1461 if (condCalo.getType() == esConditionType::SingleEgamma) {
1466 }
else if (condCalo.getType() == esConditionType::DoubleEgamma) {
1471 }
else if (condCalo.getType() == esConditionType::TripleEgamma) {
1476 }
else if (condCalo.getType() == esConditionType::QuadEgamma) {
1481 }
else if (condCalo.getType() == esConditionType::SingleJet) {
1482 caloObjType =
gtJet;
1486 }
else if (condCalo.getType() == esConditionType::DoubleJet) {
1487 caloObjType =
gtJet;
1491 }
else if (condCalo.getType() == esConditionType::TripleJet) {
1492 caloObjType =
gtJet;
1496 }
else if (condCalo.getType() == esConditionType::QuadJet) {
1497 caloObjType =
gtJet;
1501 }
else if (condCalo.getType() == esConditionType::SingleTau) {
1502 caloObjType =
gtTau;
1506 }
else if (condCalo.getType() == esConditionType::DoubleTau) {
1507 caloObjType =
gtTau;
1511 }
else if (condCalo.getType() == esConditionType::TripleTau) {
1512 caloObjType =
gtTau;
1516 }
else if (condCalo.getType() == esConditionType::QuadTau) {
1517 caloObjType =
gtTau;
1522 edm::LogError(
"TriggerMenuParser") <<
"Wrong particle for calo-condition (" << particle <<
")" << std::endl;
1529 edm::LogError(
"TriggerMenuParser") <<
"Unknown type for calo-condition (" <<
type <<
")"
1530 <<
"\nCan not determine number of trigger objects. " << std::endl;
1537 std::vector<CaloTemplate::ObjectParameter> objParameter(nrObj);
1543 std::vector<uint64_t> tmpValues((nrObj > 1) ? nrObj : 1);
1544 tmpValues.reserve(nrObj);
1546 if (
int(condCalo.getObjects().size()) != nrObj) {
1547 edm::LogError(
"TriggerMenuParser") <<
" condCalo objects: nrObj = " << nrObj
1548 <<
"condCalo.getObjects().size() = " << condCalo.getObjects().size()
1563 const std::vector<esObject>&
objects = condCalo.getObjects();
1566 gEq = (
object.getComparisonOperator() == esComparisonOperator::GE);
1569 relativeBx =
object.getBxOffset();
1572 int upperThresholdInd = -1;
1573 int lowerThresholdInd = 0;
1574 int upperIndexInd = -1;
1575 int lowerIndexInd = 0;
1577 unsigned int etaWindow1Lower = -1, etaWindow1Upper = -1, etaWindow2Lower = -1, etaWindow2Upper = -1;
1579 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
1580 int isolationLUT = 0xF;
1581 int qualityLUT = 0xF;
1583 const std::vector<esCut>&
cuts =
object.getCuts();
1584 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
1587 switch (
cut.getCutType()) {
1589 lowerThresholdInd =
cut.getMinimum().index;
1590 upperThresholdInd =
cut.getMaximum().index;
1592 case esCutType::Slice:
1593 lowerIndexInd =
int(
cut.getMinimum().value);
1594 upperIndexInd =
int(
cut.getMaximum().value);
1596 case esCutType::Eta: {
1598 etaWindow1Lower =
cut.getMinimum().index;
1599 etaWindow1Upper =
cut.getMaximum().index;
1600 }
else if (cntEta == 1) {
1601 etaWindow2Lower =
cut.getMinimum().index;
1602 etaWindow2Upper =
cut.getMaximum().index;
1605 <<
"Too Many Eta Cuts for calo-condition (" << particle <<
")" << std::endl;
1614 phiWindow1Lower =
cut.getMinimum().index;
1615 phiWindow1Upper =
cut.getMaximum().index;
1616 }
else if (cntPhi == 1) {
1617 phiWindow2Lower =
cut.getMinimum().index;
1618 phiWindow2Upper =
cut.getMaximum().index;
1621 <<
"Too Many Phi Cuts for calo-condition (" << particle <<
")" << std::endl;
1629 edm::LogError(
"TriggerMenuParser") <<
"No charge cut for calo-condition (" << particle <<
")" << std::endl;
1634 qualityLUT = l1tstr2int(
cut.getData());
1637 case esCutType::Isolation: {
1638 isolationLUT = l1tstr2int(
cut.getData());
1648 objParameter[cnt].etHighThreshold = upperThresholdInd;
1649 objParameter[cnt].etLowThreshold = lowerThresholdInd;
1650 objParameter[cnt].indexHigh = upperIndexInd;
1651 objParameter[cnt].indexLow = lowerIndexInd;
1652 objParameter[cnt].etaWindow1Lower = etaWindow1Lower;
1653 objParameter[cnt].etaWindow1Upper = etaWindow1Upper;
1654 objParameter[cnt].etaWindow2Lower = etaWindow2Lower;
1655 objParameter[cnt].etaWindow2Upper = etaWindow2Upper;
1656 objParameter[cnt].phiWindow1Lower = phiWindow1Lower;
1657 objParameter[cnt].phiWindow1Upper = phiWindow1Upper;
1658 objParameter[cnt].phiWindow2Lower = phiWindow2Lower;
1659 objParameter[cnt].phiWindow2Upper = phiWindow2Upper;
1660 objParameter[cnt].isolationLUT = isolationLUT;
1661 objParameter[cnt].qualityLUT = qualityLUT;
1664 LogDebug(
"TriggerMenuParser") <<
"\n Calo ET high thresholds (hex) for calo object " << caloObjType <<
" "
1665 << cnt <<
" = " << std::hex << objParameter[cnt].etLowThreshold <<
" - "
1666 << objParameter[cnt].etHighThreshold
1667 <<
"\n etaWindow Lower / Upper for calo object " << cnt <<
" = 0x"
1668 << objParameter[cnt].etaWindow1Lower <<
" / 0x" << objParameter[cnt].etaWindow1Upper
1669 <<
"\n etaWindowVeto Lower / Upper for calo object " << cnt <<
" = 0x"
1670 << objParameter[cnt].etaWindow2Lower <<
" / 0x" << objParameter[cnt].etaWindow2Upper
1671 <<
"\n phiWindow Lower / Upper for calo object " << cnt <<
" = 0x"
1672 << objParameter[cnt].phiWindow1Lower <<
" / 0x" << objParameter[cnt].phiWindow1Upper
1673 <<
"\n phiWindowVeto Lower / Upper for calo object " << cnt <<
" = 0x"
1674 << objParameter[cnt].phiWindow2Lower <<
" / 0x" << objParameter[cnt].phiWindow2Upper
1675 <<
"\n Isolation LUT for calo object " << cnt <<
" = 0x"
1676 << objParameter[cnt].isolationLUT <<
"\n Quality LUT for calo object " << cnt
1677 <<
" = 0x" << objParameter[cnt].qualityLUT <<
std::dec << std::endl;
1683 std::vector<GlobalObject>
objType(nrObj, caloObjType);
1701 std::ostringstream myCoutStream;
1702 caloCond.
print(myCoutStream);
1703 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
1707 if (!insertConditionIntoMap(caloCond, chipNr)) {
1708 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate condition (" <<
name <<
")" << std::endl;
1713 (m_corCaloTemplate[chipNr]).push_back(caloCond);
1715 (m_vecCaloTemplate[chipNr]).push_back(caloCond);
1736 using namespace tmeventsetup;
1745 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
1746 <<
"\n (in parseCalo) "
1747 <<
"\n condition = " <<
condition <<
"\n particle = " << particle
1748 <<
"\n type = " <<
type <<
"\n name = " <<
name << std::endl;
1757 if (corrCalo->getType() == esObjectType::Egamma) {
1760 caloObjType =
gtJet;
1762 caloObjType =
gtTau;
1764 edm::LogError(
"TriggerMenuParser") <<
"Wrong particle for calo-condition (" << particle <<
")" << std::endl;
1771 edm::LogError(
"TriggerMenuParser") <<
"Unknown type for calo-condition (" <<
type <<
")"
1772 <<
"\nCan not determine number of trigger objects. " << std::endl;
1779 std::vector<CaloTemplate::ObjectParameter> objParameter(nrObj);
1785 std::vector<uint64_t> tmpValues((nrObj > 1) ? nrObj : 1);
1786 tmpValues.reserve(nrObj);
1792 gEq = (corrCalo->getComparisonOperator() == esComparisonOperator::GE);
1795 relativeBx = corrCalo->getBxOffset();
1798 int upperThresholdInd = -1;
1799 int lowerThresholdInd = 0;
1800 int upperIndexInd = -1;
1801 int lowerIndexInd = 0;
1803 unsigned int etaWindow1Lower = -1, etaWindow1Upper = -1, etaWindow2Lower = -1, etaWindow2Upper = -1;
1805 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
1806 int isolationLUT = 0xF;
1807 int qualityLUT = 0xF;
1809 const std::vector<esCut>&
cuts = corrCalo->getCuts();
1810 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
1813 switch (
cut.getCutType()) {
1815 lowerThresholdInd =
cut.getMinimum().index;
1816 upperThresholdInd =
cut.getMaximum().index;
1818 case esCutType::Slice:
1819 lowerIndexInd =
int(
cut.getMinimum().value);
1820 upperIndexInd =
int(
cut.getMaximum().value);
1822 case esCutType::Eta: {
1824 etaWindow1Lower =
cut.getMinimum().index;
1825 etaWindow1Upper =
cut.getMaximum().index;
1826 }
else if (cntEta == 1) {
1827 etaWindow2Lower =
cut.getMinimum().index;
1828 etaWindow2Upper =
cut.getMaximum().index;
1831 <<
"Too Many Eta Cuts for calo-condition (" << particle <<
")" << std::endl;
1840 phiWindow1Lower =
cut.getMinimum().index;
1841 phiWindow1Upper =
cut.getMaximum().index;
1842 }
else if (cntPhi == 1) {
1843 phiWindow2Lower =
cut.getMinimum().index;
1844 phiWindow2Upper =
cut.getMaximum().index;
1847 <<
"Too Many Phi Cuts for calo-condition (" << particle <<
")" << std::endl;
1855 edm::LogError(
"TriggerMenuParser") <<
"No charge cut for calo-condition (" << particle <<
")" << std::endl;
1860 qualityLUT = l1tstr2int(
cut.getData());
1863 case esCutType::Isolation: {
1864 isolationLUT = l1tstr2int(
cut.getData());
1874 objParameter[0].etLowThreshold = lowerThresholdInd;
1875 objParameter[0].etHighThreshold = upperThresholdInd;
1876 objParameter[0].indexHigh = upperIndexInd;
1877 objParameter[0].indexLow = lowerIndexInd;
1878 objParameter[0].etaWindow1Lower = etaWindow1Lower;
1879 objParameter[0].etaWindow1Upper = etaWindow1Upper;
1880 objParameter[0].etaWindow2Lower = etaWindow2Lower;
1881 objParameter[0].etaWindow2Upper = etaWindow2Upper;
1882 objParameter[0].phiWindow1Lower = phiWindow1Lower;
1883 objParameter[0].phiWindow1Upper = phiWindow1Upper;
1884 objParameter[0].phiWindow2Lower = phiWindow2Lower;
1885 objParameter[0].phiWindow2Upper = phiWindow2Upper;
1886 objParameter[0].isolationLUT = isolationLUT;
1887 objParameter[0].qualityLUT = qualityLUT;
1890 LogDebug(
"TriggerMenuParser") <<
"\n Calo ET high threshold (hex) for calo object " << caloObjType <<
" "
1891 <<
" = " << std::hex << objParameter[0].etLowThreshold <<
" - "
1892 << objParameter[0].etHighThreshold <<
"\n etaWindow Lower / Upper for calo object "
1893 <<
" = 0x" << objParameter[0].etaWindow1Lower <<
" / 0x"
1894 << objParameter[0].etaWindow1Upper
1895 <<
"\n etaWindowVeto Lower / Upper for calo object "
1896 <<
" = 0x" << objParameter[0].etaWindow2Lower <<
" / 0x"
1897 << objParameter[0].etaWindow2Upper <<
"\n phiWindow Lower / Upper for calo object "
1898 <<
" = 0x" << objParameter[0].phiWindow1Lower <<
" / 0x"
1899 << objParameter[0].phiWindow1Upper
1900 <<
"\n phiWindowVeto Lower / Upper for calo object "
1901 <<
" = 0x" << objParameter[0].phiWindow2Lower <<
" / 0x"
1902 << objParameter[0].phiWindow2Upper <<
"\n Isolation LUT for calo object "
1903 <<
" = 0x" << objParameter[0].isolationLUT <<
"\n Quality LUT for calo object "
1904 <<
" = 0x" << objParameter[0].qualityLUT <<
std::dec << std::endl;
1907 std::vector<GlobalObject>
objType(nrObj, caloObjType);
1925 std::ostringstream myCoutStream;
1926 caloCond.
print(myCoutStream);
1927 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
1944 (m_corCaloTemplate[chipNr]).push_back(caloCond);
1962 unsigned int chipNr,
1963 const bool corrFlag) {
1965 using namespace tmeventsetup;
1973 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
1974 <<
"\n (in parseEnergySum) "
1976 <<
"\n name = " <<
name << std::endl;
1982 if (condEnergySum.getType() == esConditionType::MissingEt) {
1985 }
else if (condEnergySum.getType() == esConditionType::TotalEt) {
1988 }
else if (condEnergySum.getType() == esConditionType::TotalEtEM) {
1991 }
else if (condEnergySum.getType() == esConditionType::TotalHt) {
1994 }
else if (condEnergySum.getType() == esConditionType::MissingHt) {
1997 }
else if (condEnergySum.getType() == esConditionType::MissingEtHF) {
2000 }
else if (condEnergySum.getType() == esConditionType::TowerCount) {
2003 }
else if (condEnergySum.getType() == esConditionType::MinBiasHFP0) {
2006 }
else if (condEnergySum.getType() == esConditionType::MinBiasHFM0) {
2009 }
else if (condEnergySum.getType() == esConditionType::MinBiasHFP1) {
2012 }
else if (condEnergySum.getType() == esConditionType::MinBiasHFM1) {
2015 }
else if (condEnergySum.getType() == esConditionType::AsymmetryEt) {
2018 }
else if (condEnergySum.getType() == esConditionType::AsymmetryHt) {
2021 }
else if (condEnergySum.getType() == esConditionType::AsymmetryEtHF) {
2024 }
else if (condEnergySum.getType() == esConditionType::AsymmetryHtHF) {
2027 }
else if (condEnergySum.getType() == esConditionType::Centrality0) {
2030 }
else if (condEnergySum.getType() == esConditionType::Centrality1) {
2033 }
else if (condEnergySum.getType() == esConditionType::Centrality2) {
2036 }
else if (condEnergySum.getType() == esConditionType::Centrality3) {
2039 }
else if (condEnergySum.getType() == esConditionType::Centrality4) {
2042 }
else if (condEnergySum.getType() == esConditionType::Centrality5) {
2045 }
else if (condEnergySum.getType() == esConditionType::Centrality6) {
2048 }
else if (condEnergySum.getType() == esConditionType::Centrality7) {
2052 edm::LogError(
"TriggerMenuParser") <<
"Wrong type for energy-sum condition (" <<
type <<
")" << std::endl;
2064 std::vector<EnergySumTemplate::ObjectParameter> objParameter(nrObj);
2075 const std::vector<esObject>&
objects = condEnergySum.getObjects();
2078 gEq = (
object.getComparisonOperator() == esComparisonOperator::GE);
2081 relativeBx =
object.getBxOffset();
2084 int lowerThresholdInd = 0;
2085 int upperThresholdInd = -1;
2087 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
2089 const std::vector<esCut>&
cuts =
object.getCuts();
2090 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
2093 switch (
cut.getCutType()) {
2095 lowerThresholdInd =
cut.getMinimum().index;
2096 upperThresholdInd =
cut.getMaximum().index;
2099 case esCutType::Eta:
2104 phiWindow1Lower =
cut.getMinimum().index;
2105 phiWindow1Upper =
cut.getMaximum().index;
2106 }
else if (cntPhi == 1) {
2107 phiWindow2Lower =
cut.getMinimum().index;
2108 phiWindow2Upper =
cut.getMaximum().index;
2110 edm::LogError(
"TriggerMenuParser") <<
"Too Many Phi Cuts for esum-condition (" <<
type <<
")" << std::endl;
2117 case esCutType::Count:
2118 lowerThresholdInd =
cut.getMinimum().index;
2119 upperThresholdInd = 0xffffff;
2129 objParameter[cnt].etLowThreshold = lowerThresholdInd;
2130 objParameter[cnt].etHighThreshold = upperThresholdInd;
2131 objParameter[cnt].phiWindow1Lower = phiWindow1Lower;
2132 objParameter[cnt].phiWindow1Upper = phiWindow1Upper;
2133 objParameter[cnt].phiWindow2Lower = phiWindow2Lower;
2134 objParameter[cnt].phiWindow2Upper = phiWindow2Upper;
2137 LogDebug(
"TriggerMenuParser") <<
"\n EnergySum ET high threshold (hex) for energy sum object " << cnt <<
" = "
2138 << std::hex << objParameter[cnt].etLowThreshold <<
" - "
2139 << objParameter[cnt].etHighThreshold
2140 <<
"\n phiWindow Lower / Upper for calo object " << cnt <<
" = 0x"
2141 << objParameter[cnt].phiWindow1Lower <<
" / 0x" << objParameter[cnt].phiWindow1Upper
2142 <<
"\n phiWindowVeto Lower / Upper for calo object " << cnt <<
" = 0x"
2143 << objParameter[cnt].phiWindow2Lower <<
" / 0x" << objParameter[cnt].phiWindow2Upper
2150 std::vector<GlobalObject>
objType(nrObj, energySumObjType);
2165 std::ostringstream myCoutStream;
2166 energySumCond.
print(myCoutStream);
2167 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
2171 if (!insertConditionIntoMap(energySumCond, chipNr)) {
2172 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate condition (" <<
name <<
")" << std::endl;
2177 (m_corEnergySumTemplate[chipNr]).push_back(energySumCond);
2180 (m_vecEnergySumTemplate[chipNr]).push_back(energySumCond);
2201 using namespace tmeventsetup;
2209 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
2210 <<
"\n (in parseEnergySum) "
2212 <<
"\n name = " <<
name << std::endl;
2224 }
else if (corrESum->getType() == esObjectType::ETMHF) {
2227 }
else if (corrESum->getType() == esObjectType::TOWERCOUNT) {
2231 edm::LogError(
"TriggerMenuParser") <<
"Wrong type for energy-sum correclation condition (" <<
type <<
")"
2244 std::vector<EnergySumTemplate::ObjectParameter> objParameter(nrObj);
2254 gEq = (corrESum->getComparisonOperator() == esComparisonOperator::GE);
2257 relativeBx = corrESum->getBxOffset();
2260 int lowerThresholdInd = 0;
2261 int upperThresholdInd = -1;
2263 unsigned int phiWindow1Lower = -1, phiWindow1Upper = -1, phiWindow2Lower = -1, phiWindow2Upper = -1;
2265 const std::vector<esCut>&
cuts = corrESum->getCuts();
2266 for (
size_t kk = 0;
kk <
cuts.size();
kk++) {
2269 switch (
cut.getCutType()) {
2271 lowerThresholdInd =
cut.getMinimum().index;
2272 upperThresholdInd =
cut.getMaximum().index;
2275 case esCutType::Eta:
2280 phiWindow1Lower =
cut.getMinimum().index;
2281 phiWindow1Upper =
cut.getMaximum().index;
2282 }
else if (cntPhi == 1) {
2283 phiWindow2Lower =
cut.getMinimum().index;
2284 phiWindow2Upper =
cut.getMaximum().index;
2286 edm::LogError(
"TriggerMenuParser") <<
"Too Many Phi Cuts for esum-condition (" <<
type <<
")" << std::endl;
2300 objParameter[0].etLowThreshold = lowerThresholdInd;
2301 objParameter[0].etHighThreshold = upperThresholdInd;
2302 objParameter[0].phiWindow1Lower = phiWindow1Lower;
2303 objParameter[0].phiWindow1Upper = phiWindow1Upper;
2304 objParameter[0].phiWindow2Lower = phiWindow2Lower;
2305 objParameter[0].phiWindow2Upper = phiWindow2Upper;
2308 LogDebug(
"TriggerMenuParser") <<
"\n EnergySum ET high threshold (hex) for energy sum object " << cnt <<
" = "
2309 << std::hex << objParameter[0].etLowThreshold <<
" - " << objParameter[0].etLowThreshold
2310 <<
"\n phiWindow Lower / Upper for calo object " << cnt <<
" = 0x"
2311 << objParameter[0].phiWindow1Lower <<
" / 0x" << objParameter[0].phiWindow1Upper
2312 <<
"\n phiWindowVeto Lower / Upper for calo object " << cnt <<
" = 0x"
2313 << objParameter[0].phiWindow2Lower <<
" / 0x" << objParameter[0].phiWindow2Upper
2317 std::vector<GlobalObject>
objType(nrObj, energySumObjType);
2332 std::ostringstream myCoutStream;
2333 energySumCond.
print(myCoutStream);
2334 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
2352 (m_corEnergySumTemplate[chipNr]).push_back(energySumCond);
2371 using namespace tmeventsetup;
2379 LogDebug(
"TriggerMenuParser") <<
"\n ****************************************** "
2380 <<
"\n (in parseExternal) "
2381 <<
"\n condition = " <<
condition <<
"\n particle = " << particle
2382 <<
"\n type = " <<
type <<
"\n name = " <<
name << std::endl;
2391 unsigned int channelID = 0;
2394 const std::vector<esObject>&
objects = condExt.getObjects();
2397 if (
object.getType() == esObjectType::EXT) {
2398 relativeBx =
object.getBxOffset();
2399 channelID =
object.getExternalChannelId();
2407 std::vector<GlobalObject>
objType(nrObj, extSignalType);
2419 LogTrace(
"TriggerMenuParser") << externalCond <<
"\n" << std::endl;
2422 if (!insertConditionIntoMap(externalCond, chipNr)) {
2423 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate condition (" <<
name <<
")" << std::endl;
2427 (m_vecExternalTemplate[chipNr]).push_back(externalCond);
2446 using namespace tmeventsetup;
2453 LogDebug(
"TriggerMenuParser") <<
" ****************************************** " << std::endl
2454 <<
" (in parseCorrelation) " << std::endl
2455 <<
" condition = " <<
condition << std::endl
2456 <<
" particle = " << particle << std::endl
2457 <<
" type = " <<
type << std::endl
2458 <<
" name = " <<
name << std::endl;
2464 if (!insertConditionIntoMap(correlationCond, chipNr)) {
2465 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate correlation condition (" <<
name <<
")" << std::endl;
2476 const int nrObj = 2;
2479 int intGEq[nrObj] = {-1, -1};
2480 std::vector<GlobalObject>
objType(nrObj);
2481 std::vector<GtConditionCategory> condCateg(nrObj);
2484 const bool corrFlag =
true;
2485 int corrIndexVal[nrObj] = {-1, -1};
2493 const std::vector<esCut>&
cuts = corrCond.getCuts();
2494 for (
size_t jj = 0;
jj <
cuts.size();
jj++) {
2497 if (
cut.getCutType() == esCutType::ChargeCorrelation) {
2498 if (
cut.getData() ==
"ls")
2500 else if (
cut.getData() ==
"os")
2508 double minV =
cut.getMinimum().value;
2509 double maxV =
cut.getMaximum().value;
2516 LogDebug(
"TriggerMenuParser") <<
"CutType: " <<
cut.getCutType() <<
"\tDeltaEta Cut minV = " << minV
2517 <<
" Max = " << maxV <<
" precMin = " <<
cut.getMinimum().index
2518 <<
" precMax = " <<
cut.getMaximum().index << std::endl;
2522 cutType = cutType | 0x1;
2524 LogDebug(
"TriggerMenuParser") <<
"CutType: " <<
cut.getCutType() <<
"\tDeltaPhi Cut minV = " << minV
2525 <<
" Max = " << maxV <<
" precMin = " <<
cut.getMinimum().index
2526 <<
" precMax = " <<
cut.getMaximum().index << std::endl;
2530 cutType = cutType | 0x2;
2532 LogDebug(
"TriggerMenuParser") <<
"CutType: " <<
cut.getCutType() <<
"\tDeltaR Cut minV = " << minV
2533 <<
" Max = " << maxV <<
" precMin = " <<
cut.getMinimum().index
2534 <<
" precMax = " <<
cut.getMaximum().index << std::endl;
2538 cutType = cutType | 0x4;
2539 }
else if (
cut.getCutType() == esCutType::TwoBodyPt) {
2543 LogDebug(
"TriggerMenuParser") <<
"CutType: " <<
cut.getCutType() <<
"\tTPBT Cut minV = " << minV
2544 <<
" Max = " << maxV <<
" precMin = " <<
cut.getMinimum().index
2545 <<
" precMax = " <<
cut.getMaximum().index << std::endl;
2546 cutType = cutType | 0x20;
2548 LogDebug(
"TriggerMenuParser") <<
"CutType: " <<
cut.getCutType() <<
"\tMass Cut minV = " << minV
2549 <<
" Max = " << maxV <<
" precMin = " <<
cut.getMinimum().index
2550 <<
" precMax = " <<
cut.getMaximum().index << std::endl;
2555 if (corrCond.getType() == esConditionType::TransverseMass) {
2556 cutType = cutType | 0x10;
2559 cutType = cutType | 0x8;
2568 const std::vector<esObject>&
objects = corrCond.getObjects();
2570 edm::LogError(
"TriggerMenuParser") <<
"incorrect number of objects for the correlation condition " <<
name
2571 <<
" corrFlag " << corrFlag << std::endl;
2618 parseMuonCorr(&
object, chipNr);
2619 corrIndexVal[
jj] = (m_corMuonTemplate[chipNr]).
size() - 1;
2622 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2626 }
else if (
object.getType() == esObjectType::Egamma ||
object.getType() ==
esObjectType::Jet ||
2629 parseCaloCorr(&
object, chipNr);
2630 corrIndexVal[
jj] = (m_corCaloTemplate[chipNr]).
size() - 1;
2633 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2634 switch (
object.getType()) {
2635 case esObjectType::Egamma: {
2649 }
else if (
object.getType() ==
esObjectType::ETM ||
object.getType() == esObjectType::ETMHF ||
2650 object.getType() == esObjectType::TOWERCOUNT ||
object.getType() ==
esObjectType::HTM) {
2652 parseEnergySumCorr(&
object, chipNr);
2653 corrIndexVal[
jj] = (m_corEnergySumTemplate[chipNr]).
size() - 1;
2656 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2657 switch (
object.getType()) {
2664 case esObjectType::ETMHF: {
2667 case esObjectType::TOWERCOUNT: {
2676 edm::LogError(
"TriggerMenuParser") <<
"Illegal Object Type " <<
object.getType()
2677 <<
" for the correlation condition " <<
name << std::endl;
2686 if (intGEq[0] != intGEq[1]) {
2687 edm::LogError(
"TriggerMenuParser") <<
"Inconsistent GEq flags for sub-conditions "
2688 <<
" for the correlation condition " <<
name << std::endl;
2692 gEq = (intGEq[0] != 0);
2710 std::ostringstream myCoutStream;
2711 correlationCond.
print(myCoutStream);
2712 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
2718 (m_vecCorrelationTemplate[chipNr]).push_back(correlationCond);
2737 unsigned int chipNr) {
2738 using namespace tmeventsetup;
2745 LogDebug(
"TriggerMenuParser") <<
" ****************************************** " << std::endl
2746 <<
" (in parseCorrelationWithOverlapRemoval) " << std::endl
2747 <<
" condition = " <<
condition << std::endl
2748 <<
" particle = " << particle << std::endl
2749 <<
" type = " <<
type << std::endl
2750 <<
" name = " <<
name << std::endl;
2756 if (!insertConditionIntoMap(correlationWORCond, chipNr)) {
2757 edm::LogError(
"TriggerMenuParser") <<
" Error: duplicate correlation condition (" <<
name <<
")" << std::endl;
2768 const int nrObj = 3;
2771 int intGEq[nrObj] = {-1, -1, -1};
2772 std::vector<GlobalObject>
objType(nrObj);
2773 std::vector<GtConditionCategory> condCateg(nrObj);
2776 const bool corrFlag =
true;
2777 int corrIndexVal[nrObj] = {-1, -1, -1};
2785 const std::vector<esCut>&
cuts = corrCond.getCuts();
2786 for (
size_t jj = 0;
jj <
cuts.size();
jj++) {
2789 if (
cut.getCutType() == esCutType::ChargeCorrelation) {
2790 if (
cut.getData() ==
"ls")
2792 else if (
cut.getData() ==
"os")
2800 double minV =
cut.getMinimum().value;
2801 double maxV =
cut.getMaximum().value;
2812 cutType = cutType | 0x1;
2818 cutType = cutType | 0x2;
2824 cutType = cutType | 0x4;
2830 cutType = cutType | 0x8;
2832 if (
cut.getCutType() == esCutType::OvRmDeltaEta) {
2837 cutType = cutType | 0x10;
2838 }
else if (
cut.getCutType() == esCutType::OvRmDeltaPhi) {
2843 cutType = cutType | 0x20;
2844 }
else if (
cut.getCutType() == esCutType::OvRmDeltaR) {
2849 cutType = cutType | 0x40;
2856 const std::vector<esObject>&
objects = corrCond.getObjects();
2859 <<
"incorrect number of objects for the correlation condition with overlap removal " <<
name <<
" corrFlag "
2860 << corrFlag << std::endl;
2866 const esObject&
object =
objects.at(
jj);
2908 parseMuonCorr(&
object, chipNr);
2909 corrIndexVal[
jj] = (m_corMuonTemplate[chipNr]).
size() - 1;
2912 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2916 }
else if (
object.getType() == esObjectType::Egamma ||
object.getType() ==
esObjectType::Jet ||
2919 parseCaloCorr(&
object, chipNr);
2920 corrIndexVal[
jj] = (m_corCaloTemplate[chipNr]).
size() - 1;
2923 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2924 switch (
object.getType()) {
2925 case esObjectType::Egamma: {
2939 }
else if (
object.getType() ==
esObjectType::ETM ||
object.getType() == esObjectType::ETMHF ||
2940 object.getType() == esObjectType::TOWERCOUNT ||
object.getType() ==
esObjectType::HTM) {
2942 parseEnergySumCorr(&
object, chipNr);
2943 corrIndexVal[
jj] = (m_corEnergySumTemplate[chipNr]).
size() - 1;
2946 intGEq[
jj] = (
object.getComparisonOperator() == esComparisonOperator::GE);
2947 switch (
object.getType()) {
2954 case esObjectType::ETMHF: {
2957 case esObjectType::TOWERCOUNT: {
2966 edm::LogError(
"TriggerMenuParser") <<
"Illegal Object Type " <<
object.getType()
2967 <<
" for the correlation condition " <<
name << std::endl;
2976 if (intGEq[0] != intGEq[1]) {
2977 edm::LogError(
"TriggerMenuParser") <<
"Inconsistent GEq flags for sub-conditions "
2978 <<
" for the correlation condition " <<
name << std::endl;
2982 gEq = (intGEq[0] != 0);
3002 std::ostringstream myCoutStream;
3003 correlationWORCond.
print(myCoutStream);
3004 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
3010 (m_vecCorrelationWithOverlapRemovalTemplate[chipNr]).push_back(correlationWORCond);
3028 using namespace tmeventsetup;
3035 if (algAlias.empty()) {
3037 LogDebug(
"TriggerMenuParser") <<
"\n No alias defined for algorithm. Alias set to algorithm name."
3038 <<
"\n Algorithm name: " << algName <<
"\n Algorithm alias: " << algAlias
3042 LogDebug(
"TriggerMenuParser") <<
"\n Alias defined for algorithm."
3043 <<
"\n Algorithm name: " << algName <<
"\n Algorithm alias: " << algAlias
3050 LogDebug(
"TriggerMenuParser") <<
" Logical expression: " << logExpression
3051 <<
" Chip number: " << chipNr << std::endl;
3057 LogDebug(
"TriggerMenuParser") <<
" Output pin: " << outputPin << std::endl;
3072 std::ostringstream myCoutStream;
3073 alg.
print(myCoutStream);
3074 LogTrace(
"TriggerMenuParser") << myCoutStream.str() <<
"\n" << std::endl;
3078 if (!insertAlgorithmIntoMap(alg)) {