8 #include <mdst/dataobjects/TRGSummary.h> 
   10 #include <framework/logging/Logger.h> 
   11 #include <framework/database/DBObjPtr.h> 
   12 #include <mdst/dbobjects/TRGGDLDBInputBits.h> 
   13 #include <mdst/dbobjects/TRGGDLDBFTDLBits.h> 
   24                        unsigned int ftdlBits[10],
 
   25                        unsigned int psnmBits[10],
 
   28   for (
int i = 0; i < 10; i++) {
 
   38   for (
unsigned int word = 0; word < 
c_ntrgWords; word++) {
 
   47     B2ERROR(
"Requested input trigger bit number is out of range" << 
LogVar(
"bit", bit));
 
   48     throw std::out_of_range(
"The requested input trigger bit is out of range: " + std::to_string(bit));
 
   58     B2ERROR(
"Requested ftdl trigger bit number is out of range" << 
LogVar(
"bit", bit));
 
   59     throw std::out_of_range(
"The requested FTDL trigger bit is out of range: " + std::to_string(bit));
 
   63   return (
m_ftdlBits[iWord] & (1u << iBit)) != 0;
 
   69     B2ERROR(
"Requested psnm trigger bit number is out of range" << 
LogVar(
"bit", bit));
 
   70     throw std::out_of_range(
"The requested PSNM trigger bit is out of range: " + std::to_string(bit));
 
   74   return (
m_psnmBits[iWord] & (1u << iBit)) != 0;
 
   85     B2WARNING(
"The mapping of input trigger names does not exist in the given globaltags");
 
   86     throw std::runtime_error(
"No input trigger map in the given globaltags");
 
   90     if (std::string(inputBits->getinbitname((
int)bit)) == name) {
 
   95   B2WARNING(
"The requested input trigger name does not exist" << 
LogVar(
"name", name));
 
   96   throw std::invalid_argument(
"The requested input trigger name does not exist: " + name);
 
  107     B2WARNING(
"The mapping of output trigger names does not exist in the given globaltags");
 
  108     throw std::runtime_error(
"No input trigger map in the given globaltags");
 
  112     if (std::string(ftdlBits->getoutbitname((
int)bit)) == name) {
 
  117   B2WARNING(
"The requested output trigger name does not exist" << 
LogVar(
"name", name));
 
  121   throw std::invalid_argument(
"The requested input trigger name does not exist: " + name);
 
  126   std::stringstream htmlOutput;
 
  128   htmlOutput << 
"<table>";
 
  130       << 
"<tr><td></td><td bgcolor='#cccccc'>GDL Input</td><td bgcolor='#cccccc' colspan='2'>GDL Output</td></tr>";
 
  132       << 
"<tr><td>Bit</td><td>Input Bits</td><td>Final Trg DL</td><td>Prescaled Trg and Mask</td></tr>";
 
  134   for (
unsigned int currentBit = 0;
 
  136     htmlOutput << 
"<tr>";
 
  142       (
getFtdlBits(currentWord) & ((
unsigned int)1 << currentBitInWord)) > 0;
 
  144       (
getPsnmBits(currentWord) & ((
unsigned int)1 << currentBitInWord)) > 0;
 
  146                            & ((
unsigned int)1 << currentBitInWord)) > 0;
 
  148     htmlOutput << 
"<td>" << currentBit << 
"(word " << currentWord << 
" bit " 
  149                << currentBitInWord << 
")</td>";
 
  153     htmlOutput << 
"</tr>";
 
  155   htmlOutput << 
"</table>";
 
  157   return htmlOutput.str();
 
  164   const std::string colorNeutral = gROOT->GetColor(kWhite)->AsHexString();
 
  165   const std::string colorAccept = gROOT->GetColor(kGreen)->AsHexString();
 
  167   std::string color = bit > 0 ? colorAccept : colorNeutral;
 
  168   std::stringstream outStream;
 
  169   outStream << 
"<td bgcolor=\"" << color << 
"\">" << bit << 
"</td>";
 
  170   return outStream.str();
 
Class for accessing objects in the database.
static const unsigned int c_trgWordSize
size of a l1 trigger word
unsigned int m_ftdlBits[c_ntrgWords]
ftdl (Final Trigger Decision Logic) bits.
bool test() const
check whether any psnm bit is set
std::string outputBitWithColor(bool bit) const
return the td part of an HTML table with green of the bit is > 0
bool testPsnm(unsigned int bit) const
check whether a psnm bit is set
std::string getInfoHTML() const override
Return a short summary of this object's contents in HTML format.
unsigned int m_inputBits[c_ntrgWords]
input bits from subdetectors
ETimingType
types of trigger timing source defined in b2tt firmware
unsigned int m_psnmBits[c_ntrgWords]
psnm (PreScale aNd Mask) bits.
TRGSummary()=default
default constructor: xxx
unsigned int getFtdlBits(const unsigned i) const
get ftdl bits (directly determined by the trigger conditions)
ETimingType m_timType
types of trigger timing source defined in b2tt firmware
unsigned int getInputBits(const unsigned i) const
get input bits
unsigned int getOutputBitNumber(const std::string &name) const
get number of an output trigger bit
unsigned int getInputBitNumber(const std::string &name) const
get number of an input trigger bit
static const unsigned int c_ntrgWords
number of l1 trigger words
unsigned int getPsnmBits(const unsigned i) const
get psnm bits (prescaled ftdl bits)
bool testInput(unsigned int bit) const
check whether an input bit is set
bool testFtdl(unsigned int bit) const
check whether a ftdl bit is set
Class to store variables with their name which were sent to the logging service.
Abstract base class for different kinds of events.