CMS 3D CMS Logo

L1TMuonEndCapParamsOnlineProd.cc
Go to the documentation of this file.
1 #include <iostream>
2 #include <fstream>
3 #include <ctime>
4 #include <string>
5 #include <map>
6 
13 #include "OnlineDBqueryHelper.h"
14 
15 class L1TMuonEndCapParamsOnlineProd : public L1ConfigOnlineProdBaseExt<L1TMuonEndCapParamsO2ORcd, L1TMuonEndCapParams> {
16 private:
19 
20 public:
21  std::unique_ptr<const L1TMuonEndCapParams> newObject(const std::string& objectKey,
22  const L1TMuonEndCapParamsO2ORcd& record) override;
23 
26 };
27 
30  wrappedSetWhatProduced(iConfig).setConsumes(baseSettings_token);
31  transactionSafe = iConfig.getParameter<bool>("transactionSafe");
32 }
33 
34 std::unique_ptr<const L1TMuonEndCapParams> L1TMuonEndCapParamsOnlineProd::newObject(
35  const std::string& objectKey, const L1TMuonEndCapParamsO2ORcd& record) {
36  const L1TMuonEndCapParamsRcd& baseRcd = record.template getRecord<L1TMuonEndCapParamsRcd>();
37  auto const& baseSettings = baseRcd.get(baseSettings_token);
38 
39  if (objectKey.empty()) {
40  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << "Key is empty";
41  if (transactionSafe)
42  throw std::runtime_error("SummaryForFunctionManager: EMTF | Faulty | Empty objectKey");
43  else {
44  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << "returning unmodified prototype of L1TMuonEndCapParams";
45  return std::make_unique<const L1TMuonEndCapParams>(baseSettings);
46  }
47  }
48 
49  std::string tscKey = objectKey.substr(0, objectKey.find(":"));
50  std::string rsKey = objectKey.substr(objectKey.find(":") + 1, std::string::npos);
51 
52  edm::LogInfo("L1-O2O: L1TMuonEndCapParamsOnlineProd")
53  << "Producing L1TMuonEndCapParams with TSC key = " << tscKey << " and RS key = " << rsKey;
54 
55  std::string algo_key, hw_key;
56  std::string algo_payload, hw_payload;
57  try {
58  std::map<std::string, std::string> keys =
59  l1t::OnlineDBqueryHelper::fetch({"HW", "ALGO"}, "EMTF_KEYS", tscKey, m_omdsReader);
60 
61  hw_key = keys["HW"];
62  algo_key = keys["ALGO"];
63 
64  hw_payload = l1t::OnlineDBqueryHelper::fetch({"CONF"}, "EMTF_CLOBS", hw_key, m_omdsReader)["CONF"];
65 
66  algo_payload = l1t::OnlineDBqueryHelper::fetch({"CONF"}, "EMTF_CLOBS", algo_key, m_omdsReader)["CONF"];
67 
68  } catch (std::runtime_error& e) {
69  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << e.what();
70  if (transactionSafe)
71  throw std::runtime_error("SummaryForFunctionManager: EMTF | Faulty | Broken key");
72  else {
73  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << "returning unmodified prototype of L1TMuonEndCapParams";
74  return std::make_unique<const L1TMuonEndCapParams>(baseSettings);
75  }
76  }
77 
78  // for debugging purposes dump the configs to local files
79  {
80  std::ofstream output(std::string("/tmp/").append(hw_key.substr(0, hw_key.find("/"))).append(".xml"));
81  output << hw_payload;
82  output.close();
83  }
84  {
85  std::ofstream output(std::string("/tmp/").append(algo_key.substr(0, algo_key.find("/"))).append(".xml"));
86  output << algo_payload;
87  output.close();
88  }
89 
90  l1t::XmlConfigParser xmlRdr;
91  l1t::TriggerSystem trgSys;
92 
93  try {
94  xmlRdr.readDOMFromString(hw_payload);
95  xmlRdr.readRootElement(trgSys);
96 
97  xmlRdr.readDOMFromString(algo_payload);
98  xmlRdr.readRootElement(trgSys);
99 
100  trgSys.setConfigured();
101  } catch (std::runtime_error& e) {
102  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << e.what();
103  if (transactionSafe)
104  throw std::runtime_error("SummaryForFunctionManager: EMTF | Faulty | Cannot parse XMLs");
105  else {
106  edm::LogError("L1-O2O: L1TMuonEndCapParamsOnlineProd") << "returning unmodified prototype of L1TMuonEndCapParams";
107  return std::make_unique<const L1TMuonEndCapParams>(baseSettings);
108  }
109  }
110 
111  // Changed from "EMTF-1" to "EMTFp1", but is this backwards compatible? Does it need to be? - AWB 10.04.2018
112  std::map<std::string, l1t::Parameter> conf = trgSys.getParameters("EMTFp1"); // any processor will do
113  // if (conf still empty) conf = trgSys.getParameters("EMTF+1"); // Should add some conditional for backwards-compatibility
114 
115  std::string core_fwv = conf["core_firmware_version"].getValueAsStr();
116  tm brokenTime;
117  strptime(core_fwv.c_str(), "%Y-%m-%d %T", &brokenTime);
118  time_t fw_sinceEpoch = timegm(&brokenTime);
119 
120  // std::string pclut_v = conf["pc_lut_version"].getValueAsStr();
121  // strptime(pclut_v.c_str(), "%Y-%m-%d", &brokenTime);
122  // time_t pclut_sinceEpoch = timegm(&brokenTime);
123 
124  auto retval = std::make_unique<L1TMuonEndCapParams>();
125 
126  retval->firmwareVersion_ = fw_sinceEpoch;
127  retval->PtAssignVersion_ = conf["pt_lut_version"].getValue<unsigned int>();
128  retval->PhiMatchWindowSt1_ = 1; //pclut_sinceEpoch;
129 
130  edm::LogInfo("L1-O2O: L1TMuonEndCapParamsOnlineProd")
131  << "SummaryForFunctionManager: EMTF | OK | All looks good";
132  return retval;
133 }
134 
135 //define this as a plug-in
L1TMuonEndCapParamsOnlineProd
Definition: L1TMuonEndCapParamsOnlineProd.cc:15
L1ConfigOnlineProdBaseExt< L1TMuonEndCapParamsO2ORcd, L1TMuonEndCapParams >::m_omdsReader
l1t::OMDSReader m_omdsReader
Definition: L1ConfigOnlineProdBaseExt.h:47
l1t::OnlineDBqueryHelper::fetch
static std::map< std::string, std::string > fetch(const std::vector< std::string > &queryColumns, const std::string &table, const std::string &key, l1t::OMDSReader &m_omdsReader)
Definition: OnlineDBqueryHelper.cc:3
convertSQLitetoXML_cfg.output
output
Definition: convertSQLitetoXML_cfg.py:32
L1TMuonEndCapParamsO2ORcd
Definition: L1TMuonEndCapParamsO2ORcd.h:16
l1t::XmlConfigParser::readRootElement
void readRootElement(TriggerSystem &aTriggerSystem, const std::string &sysId="")
Definition: XmlConfigParser.cc:189
edm::LogInfo
Definition: MessageLogger.h:254
GlobalPosition_Frontier_DevDB_cff.record
record
Definition: GlobalPosition_Frontier_DevDB_cff.py:10
L1ConfigOnlineProdBaseExt.h
L1TMuonEndCapParams.h
relativeConstraints.keys
keys
Definition: relativeConstraints.py:89
XmlConfigParser.h
l1t::TriggerSystem
Definition: TriggerSystem.h:14
L1TMuonEndCapParamsOnlineProd::L1TMuonEndCapParamsOnlineProd
L1TMuonEndCapParamsOnlineProd(const edm::ParameterSet &)
Definition: L1TMuonEndCapParamsOnlineProd.cc:28
L1ConfigOnlineProdBaseExt
Definition: L1ConfigOnlineProdBaseExt.h:32
L1TMuonEndCapParamsO2ORcd.h
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
l1t::XmlConfigParser
Definition: XmlConfigParser.h:23
OnlineDBqueryHelper.h
edm::ParameterSet
Definition: ParameterSet.h:36
edm::LogError
Definition: MessageLogger.h:183
mps_setup.append
append
Definition: mps_setup.py:85
L1TMuonEndCapParamsRcd
Definition: L1TMuonEndCapParamsRcd.h:11
edm::ESGetToken< L1TMuonEndCapParams, L1TMuonEndCapParamsRcd >
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
L1TMuonEndCapParams
Definition: L1TMuonEndCapParams.h:15
L1TMuonEndCapParamsRcd.h
l1t::TriggerSystem::getParameters
const std::map< std::string, Parameter > & getParameters(const char *processor) const
Definition: TriggerSystem.cc:168
DEFINE_FWK_EVENTSETUP_MODULE
#define DEFINE_FWK_EVENTSETUP_MODULE(type)
Definition: ModuleFactory.h:60
L1TMuonEndCapParamsOnlineProd::baseSettings_token
edm::ESGetToken< L1TMuonEndCapParams, L1TMuonEndCapParamsRcd > baseSettings_token
Definition: L1TMuonEndCapParamsOnlineProd.cc:18
TriggerSystem.h
edm::eventsetup::EventSetupRecordImplementation::get
PRODUCT const & get(ESGetToken< PRODUCT, T > const &iToken) const
Definition: EventSetupRecordImplementation.h:74
L1TMuonEndCapParamsOnlineProd::transactionSafe
bool transactionSafe
Definition: L1TMuonEndCapParamsOnlineProd.cc:17
l1t::XmlConfigParser::readDOMFromString
void readDOMFromString(const std::string &str, xercesc::DOMDocument *&doc)
l1t::TriggerSystem::setConfigured
void setConfigured(bool state=true) noexcept
Definition: TriggerSystem.h:74
L1ConfigOnlineProdBaseExt< L1TMuonEndCapParamsO2ORcd, L1TMuonEndCapParams >::wrappedSetWhatProduced
edm::ESConsumesCollectorT< L1TMuonEndCapParamsO2ORcd > wrappedSetWhatProduced(const edm::ParameterSet &)
Definition: L1ConfigOnlineProdBaseExt.h:93
L1TMuonEndCapParamsOnlineProd::newObject
std::unique_ptr< const L1TMuonEndCapParams > newObject(const std::string &objectKey, const L1TMuonEndCapParamsO2ORcd &record) override
Definition: L1TMuonEndCapParamsOnlineProd.cc:34
L1TMuonEndCapParamsOnlineProd::~L1TMuonEndCapParamsOnlineProd
~L1TMuonEndCapParamsOnlineProd(void) override
Definition: L1TMuonEndCapParamsOnlineProd.cc:25
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37