CMS 3D CMS Logo

L1TMuonEndcapParamsOnlineProd.cc
Go to the documentation of this file.
1 #include <iostream>
2 #include <fstream>
3 #include <time.h>
4 #include <string>
5 #include <map>
6 
14 #include "OnlineDBqueryHelper.h"
15 
16 class L1TMuonEndcapParamsOnlineProd : public L1ConfigOnlineProdBaseExt<L1TMuonEndcapParamsO2ORcd,L1TMuonEndCapParams> {
17 private:
18 public:
19  virtual std::shared_ptr<L1TMuonEndCapParams> newObject(const std::string& objectKey, const L1TMuonEndcapParamsO2ORcd& record) override ;
20 
23 };
24 
26 
27 std::shared_ptr<L1TMuonEndCapParams> L1TMuonEndcapParamsOnlineProd::newObject(const std::string& objectKey, const L1TMuonEndcapParamsO2ORcd& record) {
28  using namespace edm::es;
29 
30  const L1TMuonEndcapParamsRcd& baseRcd = record.template getRecord< L1TMuonEndcapParamsRcd >() ;
32  baseRcd.get( baseSettings ) ;
33 
34 
35  if (objectKey.empty()) {
36  edm::LogError( "L1-O2O: L1TMuonEndcapParamsOnlineProd" ) << "Key is empty, returning empty L1TMuonEndcapParams";
37  throw std::runtime_error("Empty objectKey");
38  }
39 
40  std::string tscKey = objectKey.substr(0, objectKey.find(":") );
41  std::string rsKey = objectKey.substr( objectKey.find(":")+1, std::string::npos );
42 
43  edm::LogInfo( "L1-O2O: L1TMuonEndcapParamsOnlineProd" ) << "Producing L1TMuonEndcapParams with TSC key = " << tscKey << " and RS key = " << rsKey ;
44 
45  std::string algo_key, hw_key;
46  std::string algo_payload, hw_payload;
47  try {
48  std::map<std::string,std::string> keys =
49  l1t::OnlineDBqueryHelper::fetch( {"HW","ALGO"},
50  "EMTF_KEYS",
51  tscKey,
53  );
54 
55  hw_key = keys["HW"];
56  algo_key = keys["ALGO"];
57 
58  hw_payload = l1t::OnlineDBqueryHelper::fetch( {"CONF"},
59  "EMTF_CLOBS",
60  hw_key,
62  ) ["CONF"];
63 
64  algo_payload = l1t::OnlineDBqueryHelper::fetch( {"CONF"},
65  "EMTF_CLOBS",
66  algo_key,
68  ) ["CONF"];
69 
70  } catch ( std::runtime_error &e ) {
71  edm::LogError( "L1-O2O: L1TMuonEndcapParamsOnlineProd" ) << e.what();
72  throw std::runtime_error("Broken key");
73  }
74 
75  l1t::XmlConfigParser xmlRdr;
76  l1t::TriggerSystem trgSys;
77 
78  xmlRdr.readDOMFromString( hw_payload );
79  xmlRdr.readRootElement ( trgSys );
80 
81  xmlRdr.readDOMFromString( algo_payload );
82  xmlRdr.readRootElement ( trgSys );
83 
84  trgSys.setConfigured();
85 
86  std::map<std::string, l1t::Parameter> conf = trgSys.getParameters("EMTF-1"); // any processor will do
87 
88  std::string core_fwv = conf["core_firmware_version"].getValueAsStr();
89  tm brokenTime;
90  strptime(core_fwv.c_str(), "%Y-%m-%d %T", &brokenTime);
91  time_t sinceEpoch = timegm(&brokenTime);
92 
94 
95  data.SetFirmwareVersion( sinceEpoch );
96  data.SetPtAssignVersion( conf["pt_lut_version"].getValue<unsigned int>() );
97 
98  std::shared_ptr< L1TMuonEndCapParams > retval( data.getWriteInstance() );
99 
100  return retval;
101 }
102 
103 //define this as a plug-in
void setConfigured(bool state=true) noexcept
Definition: TriggerSystem.h:73
JetCorrectorParameters::Record record
Definition: classes.h:7
void SetFirmwareVersion(unsigned version)
L1TMuonEndcapParamsOnlineProd(const edm::ParameterSet &)
void readDOMFromString(const std::string &str, xercesc::DOMDocument *&doc)
void SetPtAssignVersion(unsigned version)
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)
void get(HolderT &iHolder) const
virtual std::shared_ptr< L1TMuonEndCapParams > newObject(const std::string &objectKey, const L1TMuonEndcapParamsO2ORcd &record) override
L1TMuonEndCapParams * getWriteInstance()
#define DEFINE_FWK_EVENTSETUP_MODULE(type)
Definition: ModuleFactory.h:60
const std::map< std::string, Parameter > & getParameters(const char *processor) const
void readRootElement(TriggerSystem &aTriggerSystem, const std::string &sysId="")
char data[epos_bytes_allocation]
Definition: EPOS_Wrapper.h:82