CMS 3D CMS Logo

List of all members | Public Member Functions
L1TCaloParamsOnlineProd Class Reference
Inheritance diagram for L1TCaloParamsOnlineProd:
L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams > edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Member Functions

 L1TCaloParamsOnlineProd (const edm::ParameterSet &)
 
virtual std::shared_ptr< l1t::CaloParamsnewObject (const std::string &objectKey, const L1TCaloParamsO2ORcd &record) override
 
 ~L1TCaloParamsOnlineProd (void)
 
- Public Member Functions inherited from L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams >
 L1ConfigOnlineProdBaseExt (const edm::ParameterSet &)
 
std::shared_ptr< l1t::CaloParamsproduce (const L1TCaloParamsO2ORcd &iRecord)
 
 ~L1ConfigOnlineProdBaseExt ()
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
virtual ~ESProducer ()(false)
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
virtual void newInterval (const eventsetup::EventSetupRecordKey &iRecordType, const ValidityInterval &iInterval)
 overrides DataProxyProvider method More...
 
virtual ~ESProxyFactoryProducer () noexcept(false)
 
- Public Member Functions inherited from edm::eventsetup::DataProxyProvider
 DataProxyProvider ()
 
const ComponentDescriptiondescription () const
 
bool isUsingRecord (const EventSetupRecordKey &) const
 
const KeyedProxieskeyedProxies (const EventSetupRecordKey &iRecordKey) const
 
void resetProxies (const EventSetupRecordKey &iRecordType)
 
void resetProxiesIfTransient (const EventSetupRecordKey &iRecordType)
 
void setAppendToDataLabel (const edm::ParameterSet &)
 
void setDescription (const ComponentDescription &iDescription)
 
std::set< EventSetupRecordKeyusingRecords () const
 
virtual ~DataProxyProvider () noexcept(false)
 

Additional Inherited Members

- Public Types inherited from edm::eventsetup::DataProxyProvider
typedef std::vector< std::pair< DataKey, edm::propagate_const< std::shared_ptr< DataProxy > > > > KeyedProxies
 
typedef std::vector< EventSetupRecordKeyKeys
 
typedef std::map< EventSetupRecordKey, KeyedProxiesRecordProxies
 
- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams >
bool getObjectKey (const L1TCaloParamsO2ORcd &record, std::shared_ptr< l1t::CaloParams > data, std::string &objectKey)
 
- Protected Member Functions inherited from edm::ESProducer
template<typename T >
void setWhatProduced (T *iThis, const es::Label &iLabel=es::Label())
 
template<typename T >
void setWhatProduced (T *iThis, const char *iLabel)
 
template<typename T >
void setWhatProduced (T *iThis, const std::string &iLabel)
 
template<typename T , typename TDecorator >
void setWhatProduced (T *iThis, const TDecorator &iDec, const es::Label &iLabel=es::Label())
 
template<typename T , typename TReturn , typename TRecord >
void setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const es::Label &iLabel=es::Label())
 
template<typename T , typename TReturn , typename TRecord , typename TArg >
void setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const TArg &iDec, const es::Label &iLabel=es::Label())
 
- Protected Member Functions inherited from edm::ESProxyFactoryProducer
template<class TFactory >
void registerFactory (std::unique_ptr< TFactory > iFactory, const std::string &iLabel=std::string())
 
virtual void registerFactoryWithKey (const eventsetup::EventSetupRecordKey &iRecord, std::unique_ptr< eventsetup::ProxyFactoryBase > iFactory, const std::string &iLabel=std::string())
 
virtual void registerProxies (const eventsetup::EventSetupRecordKey &iRecord, KeyedProxies &aProxyList)
 override DataProxyProvider method More...
 
- Protected Member Functions inherited from edm::eventsetup::DataProxyProvider
void eraseAll (const EventSetupRecordKey &iRecordKey)
 deletes all the Proxies in aStream More...
 
void invalidateProxies (const EventSetupRecordKey &iRecordKey)
 
template<class T >
void usingRecord ()
 
void usingRecordWithKey (const EventSetupRecordKey &)
 
- Protected Attributes inherited from L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams >
bool m_copyFromCondDB
 
cond::persistency::Session m_dbSession
 
bool m_forceGeneration
 
l1t::OMDSReader m_omdsReader
 

Detailed Description

Definition at line 19 of file L1TCaloParamsOnlineProd.cc.

Constructor & Destructor Documentation

L1TCaloParamsOnlineProd::L1TCaloParamsOnlineProd ( const edm::ParameterSet iConfig)
L1TCaloParamsOnlineProd::~L1TCaloParamsOnlineProd ( void  )
inline

Definition at line 25 of file L1TCaloParamsOnlineProd.cc.

25 {}

Member Function Documentation

std::shared_ptr< l1t::CaloParams > L1TCaloParamsOnlineProd::newObject ( const std::string &  objectKey,
const L1TCaloParamsO2ORcd record 
)
overridevirtual

Implements L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams >.

Definition at line 151 of file L1TCaloParamsOnlineProd.cc.

References l1t::TriggerSystem::addProcessor(), mps_alisetup::append, DEFINE_FWK_EVENTSETUP_MODULE, MillePedeFileConverter_cfg::e, l1t::OnlineDBqueryHelper::fetch(), edm::eventsetup::EventSetupRecord::get(), l1t::TriggerSystem::getParameters(), crabWrapper::key, L1ConfigOnlineProdBaseExt< L1TCaloParamsO2ORcd, l1t::CaloParams >::m_omdsReader, convertSQLitetoXML_cfg::output, readCaloLayer1OnlineSettings(), readCaloLayer2OnlineSettings(), l1t::XmlConfigParser::readDOMFromString(), l1t::XmlConfigParser::readRootElement(), l1t::TriggerSystem::setConfigured(), and AlCaHLTBitMon_QueryRunRegistry::string.

151  {
152  using namespace edm::es;
153 
154  const L1TCaloStage2ParamsRcd& baseRcd = record.template getRecord< L1TCaloStage2ParamsRcd >() ;
155  edm::ESHandle< l1t::CaloParams > baseSettings ;
156  baseRcd.get( baseSettings ) ;
157 
158 
159  if( objectKey.empty() ){
160  edm::LogError( "L1-O2O: L1TCaloParamsOnlineProd" ) << "Key is empty, returning empty l1t::CaloParams";
161  throw std::runtime_error("Empty objectKey");
162  }
163 
164  std::string tscKey = objectKey.substr(0, objectKey.find(":") );
165  std::string rsKey = objectKey.substr( objectKey.find(":")+1, std::string::npos );
166 
167  edm::LogInfo( "L1-O2O: L1TCaloParamsOnlineProd" ) << "Producing L1TCaloParamsOnlineProd with TSC key = " << tscKey << " and RS key = " << rsKey ;
168 
169  std::string calol1_top_key, calol1_algo_key;
170  std::string calol1_algo_payload;
171  std::string calol2_top_key, calol2_algo_key, calol2_hw_key;
172  std::string calol2_hw_payload;
173  std::map<std::string,std::string> calol2_algo_payloads; // key -> XML payload
174  try {
175  std::map<std::string,std::string> topKeys =
176  l1t::OnlineDBqueryHelper::fetch( {"CALOL1_KEY","CALOL2_KEY"},
177  "L1_TRG_CONF_KEYS",
178  tscKey,
180  );
181  calol1_top_key = topKeys["CALOL1_KEY"];
182 
183  calol1_algo_key = l1t::OnlineDBqueryHelper::fetch( {"ALGO"},
184  "CALOL1_KEYS",
185  calol1_top_key,
187  ) ["ALGO"];
188 
189  calol1_algo_payload = l1t::OnlineDBqueryHelper::fetch( {"CONF"},
190  "CALOL1_CLOBS",
191  calol1_algo_key,
193  ) ["CONF"];
194 
195  calol2_top_key = topKeys["CALOL2_KEY"];
196 
197  std::map<std::string,std::string> calol2_keys =
198  l1t::OnlineDBqueryHelper::fetch( {"ALGO","HW"},
199  "CALOL2_KEYS",
200  calol2_top_key,
202  );
203 
204  calol2_hw_key = calol2_keys["HW"];
205  calol2_hw_payload = l1t::OnlineDBqueryHelper::fetch( {"CONF"},
206  "CALOL2_CLOBS",
207  calol2_hw_key,
209  ) ["CONF"];
210 
211  calol2_algo_key = calol2_keys["ALGO"];
212 
213  std::map<std::string,std::string> calol2_algo_keys =
214  l1t::OnlineDBqueryHelper::fetch( {"DEMUX","MPS_COMMON","MPS_JET","MP_EGAMMA","MP_SUM","MP_TAU"},
215  "CALOL2_ALGO_KEYS",
216  calol2_algo_key,
218  );
219 
220  for(auto &key : calol2_algo_keys)
221  calol2_algo_payloads[ key.second ] =
223  "CALOL2_CLOBS",
224  key.second,
226  ) ["CONF"];
227 
228  } catch ( std::runtime_error &e ) {
229  edm::LogError( "L1-O2O: L1TCaloParamsOnlineProd" ) << e.what();
230  throw std::runtime_error("Broken key");
231  }
232 
233  // for debugging purposes dump the configs to local files
234  for(auto &conf : calol2_algo_payloads){
235  std::ofstream output(std::string("/tmp/").append(conf.first.substr(0,conf.first.find("/"))).append(".xml"));
236  output<<conf.second;
237  output.close();
238  }
239  {
240  std::ofstream output(std::string("/tmp/").append(calol2_hw_key.substr(0,calol2_hw_key.find("/"))).append(".xml"));
241  output << calol2_hw_payload;
242  output.close();
243  }
244  {
245  std::ofstream output(std::string("/tmp/").append(calol1_algo_key.substr(0,calol1_algo_key.find("/"))).append(".xml"));
246  output << calol1_algo_payload;
247  output.close();
248  }
249 
250 
251 
252  l1t::XmlConfigParser xmlReader1;
253  xmlReader1.readDOMFromString( calol1_algo_payload );
254 
255  l1t::TriggerSystem calol1;
256  calol1.addProcessor("processors", "processors","-1","-1");
257  xmlReader1.readRootElement( calol1, "calol1" );
258  calol1.setConfigured();
259 
260  std::map<std::string, l1t::Parameter> calol1_conf = calol1.getParameters("processors");
261  std::map<std::string, l1t::Mask> calol1_rs ;//= calol1.getMasks ("processors");
262 
263  l1t::TriggerSystem calol2;
264 
265  l1t::XmlConfigParser xmlReader2;
266  xmlReader2.readDOMFromString( calol2_hw_payload );
267  xmlReader2.readRootElement( calol2, "calol2" );
268 
269  for(auto &conf : calol2_algo_payloads){
270  xmlReader2.readDOMFromString( conf.second );
271  xmlReader2.readRootElement( calol2, "calol2" );
272  }
273 
274 // calol2.setSystemId("calol2");
275  calol2.setConfigured();
276 
277  // Perhaps layer 2 has to look at settings for demux and mp separately? // => No demux settings required
278  std::map<std::string, l1t::Parameter> calol2_conf = calol2.getParameters("MP1");
279  std::map<std::string, l1t::Mask> calol2_rs ;//= calol2.getMasks ("processors");
280 
281  l1t::CaloParamsHelper m_params_helper( *(baseSettings.product()) );
282 
283  if( !readCaloLayer1OnlineSettings(m_params_helper, calol1_conf, calol1_rs) )
284  throw std::runtime_error("Parsing error for CaloLayer1");
285  if( !readCaloLayer2OnlineSettings(m_params_helper, calol2_conf, calol2_rs) )
286  throw std::runtime_error("Parsing error for CaloLayer2");
287 
288  std::shared_ptr< l1t::CaloParams > retval = std::make_shared< l1t::CaloParams >( m_params_helper ) ;
289  return retval;
290 }
void setConfigured(bool state=true) noexcept
Definition: TriggerSystem.h:73
bool readCaloLayer2OnlineSettings(l1t::CaloParamsHelper &paramsHelper, std::map< std::string, l1t::Parameter > &conf, std::map< std::string, l1t::Mask > &)
void readDOMFromString(const std::string &str, xercesc::DOMDocument *&doc)
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
const std::map< std::string, Parameter > & getParameters(const char *processor) const
void readRootElement(TriggerSystem &aTriggerSystem, const std::string &sysId="")
void addProcessor(const char *processor, const char *role, const char *crate, const char *slot)
bool readCaloLayer1OnlineSettings(l1t::CaloParamsHelper &paramsHelper, std::map< std::string, l1t::Parameter > &conf, std::map< std::string, l1t::Mask > &)