20 #include "boost/lexical_cast.hpp" 47 auto pL1GtPsbSetup = std::make_shared<L1GtPsbSetup>();
52 std::vector<L1GtPsbConfig> psbConfigurations;
57 std::vector<std::string>::iterator newEnd = std::remove_if(
59 psbColumns.erase(newEnd, psbColumns.end());
63 psbColumns, gtSchema,
"GT_SETUP",
"GT_SETUP.ID",
67 if (!
checkOneLineResult(psbKeys,
"GT_SETUP query for PSB keys with ID = " + objectKey)) {
69 <<
"Problem to get content of CMS_GT.GT_SETUP for GT_SETUP.ID key: " 75 for (std::vector<std::string>::const_iterator it = psbColumns.begin(); it != psbColumns.end(); ++it) {
88 pL1GtPsbSetup->setGtPsbSetup(psbConfigurations);
91 LogTrace(
"L1-O2O") << (*pL1GtPsbSetup) << std::endl;
104 unsigned len = columnName.size();
107 return len <= ( startMatch.size() + endMatch.size() ) ||
109 columnName.substr(0, startMatch.size()) != startMatch ||
111 columnName.substr(len - endMatch.size(), endMatch.size()) != endMatch;
153 std::vector<std::string> columnNames;
155 static const std::string lvdPrefix =
"ENABLE_TT_LVDS_";
158 static const std::string serSuffix =
"_REC_ENABLE";
159 static const std::string boardSlotColumn =
"BOARD_SLOT";
160 static const std::string ch0FormatColumn =
"CH0_SEND_LVDS_NOT_DS92LV16";
161 static const std::string ch1FormatColumn =
"CH1_SEND_LVDS_NOT_DS92LV16";
163 columnNames.push_back(boardSlotColumn);
164 columnNames.push_back(ch0FormatColumn);
165 columnNames.push_back(ch1FormatColumn);
181 if (!
checkOneLineResult(psbQuery,
"GT_PSB_SETUP query for PSB keys with ID = " + psbKey)) {
183 <<
"Problem to get setup for PSB keys with ID = " << psbKey;
192 bool sendLvds0, sendLvds1;
212 psbSetup.push_back(toAdd);
232 psbSetup.push_back(toAdd);
239 std::vector<bool>
result(nColumns);
241 for (
unsigned i = 0;
i < nColumns; ++
i) {
255 edm::LogError(
"L1-O2O") <<
"\n " << queryDescription +
" failed: no match found!";
259 edm::LogError(
"L1-O2O") <<
"\nProblem with " << queryDescription <<
": " 260 << ( result.
numberRows() ) <<
" rows were returned, expected 1.";
278 std::ostringstream colName;
279 colName << prefix << number <<
suffix;
281 return colName.str();
286 std::istringstream stream(aString);
289 for (
unsigned i = 0;
i < aString.size(); ++
i) {
290 if (stream >> result) {
302 throw cms::Exception(
"NumberNotFound") <<
"Failed to extract numeric value from " << aString;
bool checkOneLineResult(const l1t::OMDSReader::QueryResults &result, const std::string &queryDescription) const
Ensures that result contains exactly one line, returning false otherwise.
static bool notPsbColumnName(const std::string &columnName)
std::string numberedColumnName(const std::string &prefix, unsigned number, const std::string &suffix) const
Concatenates prefix, number and suffix into a string.
bool fillVariable(const std::string &columnName, T &outputVariable) const
const QueryResults singleAttribute(const T &data) const
virtual std::shared_ptr< L1GtPsbSetup > newObject(const std::string &objectKey)
public methods
void getRequiredValue(const l1t::OMDSReader::QueryResults &result, const std::string &colName, T &value) const
void setGtPsbEnableRecLvds(const std::vector< bool > &)
void setGtPsbCh0SendLvds(const bool &)
void addDefaultPsb(const std::string &psbColumn, std::vector< L1GtPsbConfig > &psbSetup) const
Creates a default valued PSB from an empty foreign key in the GT_SETUP table.
static const int PsbSerLinkNumberChannels
number of channels per board
static const int PsbNumberLvdsGroups
number of LVDS groups per board
void setGtPsbEnableRecSerLink(const std::vector< bool > &)
std::vector< std::string > columnNames(const std::string &schemaName, const std::string &tableName)
const QueryResults basicQuery(const std::vector< std::string > &columnNames, const std::string &schemaName, const std::string &tableName, const std::string &conditionLHS="", const QueryResults conditionRHS=QueryResults(), const std::string &conditionRHSName="")
l1t::OMDSReader m_omdsReader
std::vector< bool > extractBoolVector(const l1t::OMDSReader::QueryResults &query, const std::string &prefix, const std::string &suffix, unsigned nColumns) const
~L1GtPsbSetupConfigOnlineProd()
destructor
void setGtBoardSlot(const int &)
#define DEFINE_FWK_EVENTSETUP_MODULE(type)
L1GtPsbSetupConfigOnlineProd(const edm::ParameterSet &)
constructor
void addPsbFromDb(const std::string &psbKey, std::vector< L1GtPsbConfig > &psbSetup)
Creates a new PSB object from a GT_PSB_SETUP entry and adds.
void setGtPsbCh1SendLvds(const bool &)
unsigned numberFromString(const std::string &aString) const