229 if (objectKey.empty()) {
230 edm::LogError(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"Key is empty";
232 throw std::runtime_error(
"SummaryForFunctionManager: Calo | Faulty | Empty objectKey");
234 edm::LogError(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"returning unmodified prototype of l1t::CaloParams";
235 return std::make_unique<const l1t::CaloParams>(baseSettings);
239 std::string tscKey = objectKey.substr(0, objectKey.find(
':'));
240 std::string rsKey = objectKey.substr(objectKey.find(
':') + 1, std::string::npos);
243 <<
"Producing L1TCaloParamsOnlineProd with TSC key = " << tscKey <<
" and RS key = " << rsKey;
247 std::string calol2_top_key, calol2_algo_key, calol2_hw_key;
249 std::map<std::string, std::string> calol2_algo_payloads;
251 std::map<std::string, std::string> topKeys =
255 calol1_top_key = topKeys[
"CALOL1_KEY"];
259 calol1_algo_payload =
264 calol2_top_key = topKeys[
"CALOL2_KEY"];
266 std::map<std::string, std::string> calol2_keys =
269 calol2_hw_key = calol2_keys[
"HW"];
273 calol2_algo_key = calol2_keys[
"ALGO"];
275 std::map<std::string, std::string> calol2_algo_keys =
281 for (
auto&
key : calol2_algo_keys)
282 calol2_algo_payloads[
key.second] =
286 }
catch (std::runtime_error&
e) {
289 throw std::runtime_error(
std::string(
"SummaryForFunctionManager: Calo | Faulty | ") +
e.what());
291 edm::LogError(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"returning unmodified prototype of l1t::CaloParams";
292 return std::make_unique<const l1t::CaloParams>(baseSettings);
298 for (
auto& conf : calol2_algo_payloads) {
303 std::ofstream
output(
std::string(
"/tmp/").
append(calol2_hw_key.substr(0, calol2_hw_key.find(
'/'))).append(
".xml"));
304 output << calol2_hw_payload;
309 std::string(
"/tmp/").
append(calol1_algo_key.substr(0, calol1_algo_key.find(
'/'))).append(
".xml"));
310 output << calol1_algo_payload;
322 calol1.
addProcessor(
"processors",
"processors",
"-1",
"-1");
326 std::map<std::string, l1t::Parameter> calol1_conf = calol1.
getParameters(
"processors");
327 std::map<std::string, l1t::Mask> calol1_rs;
330 throw std::runtime_error(
"Parsing error for CaloLayer1");
332 }
catch (std::runtime_error&
e) {
335 throw std::runtime_error(
std::string(
"SummaryForFunctionManager: Calo | Faulty | ") +
e.what());
337 edm::LogError(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"returning unmodified prototype of l1t::CaloParams";
338 return std::make_unique<const l1t::CaloParams>(baseSettings);
350 for (
auto& conf : calol2_algo_payloads) {
358 std::map<std::string, l1t::Parameter> calol2_conf = calol2.
getParameters(
"MP1");
359 std::map<std::string, l1t::Parameter> calol2_conf_demux = calol2.
getParameters(
"DEMUX");
360 calol2_conf.insert(calol2_conf_demux.begin(), calol2_conf_demux.end());
361 std::map<std::string, l1t::Mask> calol2_rs;
364 throw std::runtime_error(
"Parsing error for CaloLayer2");
366 }
catch (std::runtime_error&
e) {
369 throw std::runtime_error(
std::string(
"SummaryForFunctionManager: Calo | Faulty | ") +
e.what());
371 edm::LogError(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"returning unmodified prototype of l1t::CaloParams";
372 return std::make_unique<const l1t::CaloParams>(baseSettings);
377 auto retval = std::make_unique<const l1t::CaloParams>(m_params_helper);
379 edm::LogInfo(
"L1-O2O: L1TCaloParamsOnlineProd") <<
"SummaryForFunctionManager: Calo | OK | All looks good";
void setConfigured(bool state=true) noexcept
Log< level::Error, false > LogError
const edm::ESGetToken< l1t::CaloParams, L1TCaloParamsRcd > baseSettings_token
l1t::OMDSReader m_omdsReader
PRODUCT const & get(ESGetToken< PRODUCT, T > const &iToken) const
void readDOMFromString(const std::string &str, xercesc::DOMDocument *&doc)
const std::map< std::string, Parameter > & getParameters(const char *processor) const
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)
bool readCaloLayer2OnlineSettings(l1t::CaloParamsHelperO2O ¶msHelper, std::map< std::string, l1t::Parameter > &conf, std::map< std::string, l1t::Mask > &)
key
prepare the HTCondor submission files and eventually submit them
Log< level::Info, false > LogInfo
void readRootElement(TriggerSystem &aTriggerSystem, const std::string &sysId="")
bool readCaloLayer1OnlineSettings(l1t::CaloParamsHelperO2O ¶msHelper, std::map< std::string, l1t::Parameter > &conf, std::map< std::string, l1t::Mask > &)
void addProcessor(const char *processor, const char *role, const char *crate, const char *slot)
const unsigned int exclusiveLayer
const bool transactionSafe