|  | ATLAS Offline Software
    | 
 
 
 
Tool to perform ROB fragments to trigger towers and trigger towers to raw data conversions.  
 More...
#include <PpmByteStreamV1Tool.h>
|  | 
|  | PpmByteStreamV1Tool (const std::string &type, const std::string &name, const IInterface *parent) | 
|  | 
| virtual | ~PpmByteStreamV1Tool () | 
|  | 
| virtual StatusCode | initialize () override | 
|  | 
| virtual StatusCode | finalize () override | 
|  | 
| StatusCode | convert (const std::string &sgKey, const IROBDataProviderSvc::VROBFRAG &robFrags, DataVector< LVL1::TriggerTower > *ttCollection) const | 
|  | Convert ROB fragments to trigger towers.  More... 
 | 
|  | 
| StatusCode | convert (const DataVector< LVL1::TriggerTower > *ttCollection, RawEventWrite *re) const | 
|  | Convert trigger towers to bytestream.  More... 
 | 
|  | 
| const std::vector< uint32_t > & | sourceIDs (const std::string &sgKey) const | 
|  | Return reference to vector with all possible Source Identifiers.  More... 
 | 
|  | 
| ServiceHandle< StoreGateSvc > & | evtStore () | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | evtStore () const | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | detStore () const | 
|  | The standard StoreGateSvc/DetectorStoreReturns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| virtual StatusCode | sysInitialize () override | 
|  | Perform system initialization for an algorithm.  More... 
 | 
|  | 
| virtual StatusCode | sysStart () override | 
|  | Handle START transition.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override | 
|  | Return this algorithm's input handles.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override | 
|  | Return this algorithm's output handles.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T, V, H > &t) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc="none") | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| void | updateVHKA (Gaudi::Details::PropertyBase &) | 
|  | 
| MsgStream & | msg () const | 
|  | 
| MsgStream & | msg (const MSG::Level lvl) const | 
|  | 
| bool | msgLvl (const MSG::Level lvl) const | 
|  | 
|  | 
| void | addCompStats (const std::vector< uint32_t > &stats) const | 
|  | Add compression stats to totals.  More... 
 | 
|  | 
| void | printCompStats () const | 
|  | Print compression stats.  More... 
 | 
|  | 
| const LVL1::TriggerTower * | findLayerTriggerTower (double eta, double phi, int layer, const TriggerTowerMapConst &ttEmMap, const TriggerTowerMapConst &ttHadMap, LVL1::TriggerTowerKey &towerKey) const | 
|  | Find a trigger tower using separate layer maps.  More... 
 | 
|  | 
| void | setupTTMaps (const TriggerTowerCollection *ttCollection, TriggerTowerMapConst &ttEmMap, TriggerTowerMapConst &ttHadMap, LVL1::TriggerTowerKey &towerKey) const | 
|  | Set up separate Em and Had trigger tower maps.  More... 
 | 
|  | 
| bool | slinkSlices (int crate, int module, int modulesPerSlink, int &slicesLut, int &slicesFadc, int &trigLut, int &trigFadc, const TriggerTowerMapConst &ttEmMap, const TriggerTowerMapConst &ttHadMap, LVL1::TriggerTowerKey &towerKey) const | 
|  | Get number of slices and triggered slice offsets for next slink.  More... 
 | 
|  | 
| std::vector< uint32_t > | makeSourceIDs (bool spareChannels, bool muonChannels) const | 
|  | 
| void | printVec (const std::vector< int > &vec) const | 
|  | Print a vector.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKey>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyArrayType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKeyArray>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleBase>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &t, const SG::NotHandleType &) | 
|  | specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>  More... 
 | 
|  | 
Tool to perform ROB fragments to trigger towers and trigger towers to raw data conversions. 
Based on ROD document version 1_09h.
- Author
- Peter Faulkner 
Definition at line 56 of file PpmByteStreamV1Tool.h.
◆ ChannelBitVector
◆ ROBIterator
◆ ROBPointer
◆ RODPointer
◆ StoreGateSvc_t
◆ TriggerTowerCollection
◆ TriggerTowerMap
◆ TriggerTowerMapConst
◆ TriggerTowerVector
◆ PpmByteStreamV1Tool()
      
        
          | LVL1BS::PpmByteStreamV1Tool::PpmByteStreamV1Tool | ( | const std::string & | type, | 
        
          |  |  | const std::string & | name, | 
        
          |  |  | const IInterface * | parent | 
        
          |  | ) |  |  | 
      
 
Definition at line 52 of file PpmByteStreamV1Tool.cxx.
   56       m_ppmMaps(
"LVL1::PpmMappingTool/PpmMappingTool"),
 
   57       m_errorTool(
"LVL1BS::L1CaloErrorByteStreamTool/L1CaloErrorByteStreamTool"),
 
   62     declareInterface<PpmByteStreamV1Tool>(
this);
 
   65                     "Crate/Module/Channel to Eta/Phi/Layer mapping tool");
 
   67                     "Tool to collect errors for monitoring");
 
   70                     "Print compressed format statistics");
 
   72                     "The number of S-Links per crate");
 
   76                     "Only make trigger towers with non-zero EM or Had energy");
 
   78                     "ROB fragment source identifiers");
 
   80                     "Pedestal value - needed for compressed formats 0,1 only");
 
   84                     "Format identifier (0-3) in sub-block header");
 
   86                     "FADC baseline lower bound for compressed formats");
 
   88                     "FADC threshold for super-compressed format");
 
   90                     "The number of LUT slices in the simulation");
 
   92                     "The number of FADC slices in the simulation");
 
   94                     "If >0, the number of LUT slices in bytestream");
 
   96                     "If >0, the number of FADC slices in bytestream");
 
   98                     "Minimum crate number, allows partial output");
 
  100                     "Maximum crate number, allows partial output");
 
 
 
 
◆ ~PpmByteStreamV1Tool()
  
  | 
        
          | LVL1BS::PpmByteStreamV1Tool::~PpmByteStreamV1Tool | ( |  | ) |  |  | virtual | 
 
 
◆ addCompStats()
  
  | 
        
          | void LVL1BS::PpmByteStreamV1Tool::addCompStats | ( | const std::vector< uint32_t > & | stats | ) | const |  | private | 
 
 
◆ convert() [1/2]
Convert trigger towers to bytestream. 
Definition at line 787 of file PpmByteStreamV1Tool.cxx.
  812     setupTTMaps(ttCollection, ttEmMap, ttHadMap, towerKey);
 
  816     PpmSubBlockV1 subBlock;
 
  817     const int chanPerSubBlock = subBlock.channelsPerSubBlock(
m_version,
 
  819     if (chanPerSubBlock == 0)
 
  821         msg(MSG::ERROR) << 
"Unsupported version/data format: " 
  823         return StatusCode::FAILURE;
 
  825     PpmSubBlockV1 errorBlock;
 
  831     int slicesLutNew  = 1;
 
  832     int slicesFadcNew = 1;
 
  843             if (
module % modulesPerSlink == 0)
 
  845                 const int daqOrRoi = 0;
 
  846                 const int slink = 
module / modulesPerSlink;
 
  849                     msg() << 
"Treating crate " << crate << 
" slink " << slink << 
endmsg;
 
  854                                    slicesLut, slicesFadc, trigLut, trigFadc,
 
  858                     msg(MSG::ERROR) << 
"Inconsistent number of slices or " 
  859                                     << 
"triggered slice offsets in data for crate " 
  860                                     << crate << 
" slink " << slink << 
endmsg;
 
  861                     return StatusCode::FAILURE;
 
  871                           << 
"LUT slices/offset: " << slicesLut << 
" " << trigLut;
 
  872                     if (slicesLut != slicesLutNew)
 
  874                         msg() << 
" modified to " << slicesLutNew << 
" " << trigLutNew;
 
  877                           << 
"FADC slices/offset: " << slicesFadc << 
" " << trigFadc;
 
  878                     if (slicesFadc != slicesFadcNew)
 
  880                         msg() << 
" modified to " << slicesFadcNew << 
" " << trigFadcNew;
 
  884                 L1CaloUserHeader userHeader;
 
  885                 userHeader.setPpmLut(trigLutNew);
 
  886                 userHeader.setPpmFadc(trigFadcNew);
 
  891                 theROD->push_back(userHeader.header());
 
  898             bool upstreamError = 
false;
 
  906                                                  module, slicesFadcNew, slicesLutNew);
 
  914                                               module, slicesFadcNew, slicesLutNew);
 
  919                                               module, slicesFadcNew, slicesLutNew);
 
  921                     subBlock.setLutOffset(trigLutNew);
 
  922                     subBlock.setFadcOffset(trigFadcNew);
 
  937                     std::vector<int> 
lut;
 
  938                     std::vector<int> fadc;
 
  939                     std::vector<int> bcidLut;
 
  940                     std::vector<int> bcidFadc;
 
  955                         err = 
tt->hadError();
 
  957                     subBlock.fillPpmData(
channel, 
lut, fadc, bcidLut, bcidFadc);
 
  964                             errorBlock.fillPpmError(
channel, errpp);
 
  966                         else subBlock.fillPpmError(
channel, errpp);
 
  967                         if (errpp >> 2) upstreamError = 
true;
 
  970                 if (
chan == chanPerSubBlock - 1)
 
  973                     if ( !subBlock.pack())
 
  975                         msg(MSG::ERROR) << 
"PPM sub-block packing failed" << 
endmsg;
 
  976                         return StatusCode::FAILURE;
 
  982                         subBlock.setStatus(0, 
false, 
false, 
false, 
false,
 
  983                                            false, 
false, 
false);
 
  986                             msg() << 
"PPM sub-block data words: " 
  987                                   << subBlock.dataWords() << 
endmsg;
 
  989                         subBlock.write(theROD);
 
  994                         bool glinkTimeout = 
false;
 
  995                         bool daqOverflow  = 
false;
 
  996                         bool bcnMismatch  = 
false;
 
  997                         bool glinkParity  = 
false;
 
 1000                             glinkTimeout = errorBlock.mcmAbsent() ||
 
 1001                                            errorBlock.timeout();
 
 1002                             daqOverflow  = errorBlock.asicFull() ||
 
 1003                                            errorBlock.fpgaCorrupt();
 
 1004                             bcnMismatch  = errorBlock.eventMismatch() ||
 
 1005                                            errorBlock.bunchMismatch();
 
 1006                             glinkParity  = errorBlock.glinkPinParity();
 
 1010                             glinkTimeout = subBlock.mcmAbsent() ||
 
 1012                             daqOverflow  = subBlock.asicFull() ||
 
 1013                                            subBlock.fpgaCorrupt();
 
 1014                             bcnMismatch  = subBlock.eventMismatch() ||
 
 1015                                            subBlock.bunchMismatch();
 
 1016                             glinkParity  = subBlock.glinkPinParity();
 
 1018                         subBlock.setStatus(0, glinkTimeout, 
false, upstreamError,
 
 1019                                            daqOverflow, bcnMismatch, 
false, glinkParity);
 
 1022                             msg() << 
"PPM sub-block data words: " 
 1023                                   << subBlock.dataWords() << 
endmsg;
 
 1025                         subBlock.write(theROD);
 
 1029                             if ( ! errorBlock.pack())
 
 1031                                 msg(MSG::ERROR) << 
"PPM error block packing failed" << 
endmsg;
 
 1032                                 return StatusCode::FAILURE;
 
 1034                             errorBlock.setStatus(0, glinkTimeout, 
false, upstreamError,
 
 1035                                                  daqOverflow, bcnMismatch, 
false, glinkParity);
 
 1036                             errorBlock.write(theROD);
 
 1039                                 msg() << 
"PPM error block data words: " 
 1040                                       << errorBlock.dataWords() << 
endmsg;
 
 1053     return StatusCode::SUCCESS;
 
 
 
 
◆ convert() [2/2]
Convert ROB fragments to trigger towers. 
Definition at line 139 of file PpmByteStreamV1Tool.cxx.
  148     const std::string 
flag(
"Spare");
 
  149     const std::string::size_type 
pos = sgKey.find(
flag);
 
  151         (
pos != std::string::npos && 
pos == (sgKey.length() - 
flag.length()));
 
  152     const std::string flag2(
"Muon");
 
  153     const std::string::size_type pos2 = sgKey.find(flag2);
 
  155         (pos2 != std::string::npos && pos2 == (sgKey.length() - flag2.length()));
 
  156     bool dataChannels = (!spareChannels && !muonChannels);
 
  161     const int chanBitVecSize = maxChannels / 32;
 
  163     SlotData& 
sd = *m_slotData;
 
  164     std::lock_guard guard (
sd.m_mutex);
 
  166     if (
sd.m_ttData.empty())
 
  168         const int spareSize = maxChannels - 2 * 
s_dataSize;
 
  172         sd.m_ttSpare.reserve(spareSize);
 
  173         sd.m_ttMuon.reserve(muonSize);
 
  174         sd.m_ttPos.resize(maxChannels);
 
  175         sd.m_chanLayer.resize(chanBitVecSize);
 
  176         sd.m_dataChan.resize(chanBitVecSize);
 
  177         sd.m_spareChan.resize(chanBitVecSize);
 
  178         sd.m_muonChan.resize(chanBitVecSize);
 
  179         sd.m_dataMod.resize(modBitVecSize);
 
  180         sd.m_spareMod.resize(modBitVecSize);
 
  181         sd.m_muonMod.resize(modBitVecSize);
 
  184         std::vector<int> dummyS;
 
  185         std::vector<int> dummyL(1);
 
  186         std::vector<int> dummyF(5);
 
  189         for (
int crate = 0; crate < 
s_crates; ++crate)
 
  194                 const int word2  = 
index2 / 32;
 
  195                 const int bit2   = 
index2 % 32;
 
  199                     const int word  = 
index / 32;
 
  200                     const int bit   = 
index % 32;
 
  204                     unsigned int key = 0;
 
  209                         itt = ttMap.find(
key);
 
  210                         if (itt == ttMap.end())
 
  215                                                dummyF, dummyL, dummyF, dummyL, 0, 0, 0,
 
  216                                                dummyF, dummyL, dummyF, dummyL, 0, 0, 0);
 
  217                             sd.m_ttData.push_back(
tt);
 
  218                             const int count = dataCount++;
 
  220                             ttMap.insert(std::make_pair(
key, 
count));
 
  224                             sd.m_ttPos[
index] = itt->second;
 
  226                         sd.m_chanLayer[word] |= (
layer << bit);
 
  227                         sd.m_dataChan[word]  |= (1 << bit);
 
  228                         sd.m_dataMod[word2]  |= (1 << bit2);
 
  236                         phi = 4 * pin + asic;
 
  239                         key = (crate << 24) | (
type << 20) | (
module << 16) | (pin << 8) | asic; 
 
  243                                            dummyF, dummyL, dummyF, dummyL, 0, 0, 0,
 
  244                                            dummyS, dummyS, dummyS, dummyS, 0, 0, 0);
 
  245                         sd.m_ttSpare.push_back(
tt);
 
  246                         sd.m_ttPos[
index] = spareCount++;
 
  247                         sd.m_chanLayer[word] |= (
layer << bit);
 
  248                         sd.m_spareChan[word] |= (1 << bit);
 
  249                         sd.m_spareMod[word2] |= (1 << bit2);
 
  250                         if ((crate == 2 || crate == 3) && (
module == 0))
 
  252                             sd.m_ttMuon.push_back(
tt);
 
  253                             sd.m_muonChan[word] |= (1 << bit);
 
  254                             sd.m_muonMod[word2] |= (1 << bit2);
 
  278     const int colSize = dataChannels ? 2 * ttCol.size()
 
  280     sd.m_foundChan.assign(chanBitVecSize, 0);
 
  284     std::vector<int> 
lut;
 
  285     std::vector<int> fadc;
 
  286     std::vector<int> bcidLut;
 
  287     std::vector<int> bcidFadc;
 
  294     std::set<uint32_t> dupCheck;
 
  297     for (; rob != robEnd; ++rob)
 
  303             msg() << 
"Treating ROB fragment " << robCount << 
endmsg;
 
  308         uint32_t robid = (*rob)->source_id();
 
  309         if ((*rob)->nstatus() > 0)
 
  312             (*rob)->status(robData);
 
  316                 if (
debug) 
msg() << 
"ROB status error - skipping fragment" << 
endmsg;
 
  323         if (!dupCheck.insert(robid).second)
 
  335         (*rob)->rod_data(payloadBeg);
 
  336         payloadEnd = payloadBeg + (*rob)->rod_ndata();
 
  345         const uint32_t sourceID = (*rob)->rod_source_id();
 
  355                 msg() << 
"Wrong source identifier in data: ROD " 
  356                       << MSG::hex << sourceID << 
"  ROB " << robid
 
  363         const int minorVersion = (*rob)->rod_version() & 0xffff;
 
  372             msg() << 
"Treating crate " << rodCrate
 
  383         L1CaloUserHeader userHeader(*
payload);
 
  384         userHeader.setVersion(minorVersion);
 
  385         const int headerWords = userHeader.words();
 
  386         if (headerWords != 1)
 
  391                 msg() << 
"Unexpected number of user header words: " 
  396         for (
int i = 0; 
i < headerWords; ++
i) ++
payload;
 
  398         const int trigLut  = userHeader.ppmLut();
 
  399         const int trigFadc = userHeader.ppmFadc();
 
  401         fadcBaseline = userHeader.lowerBound();
 
  404             msg() << 
"Minor format version number: " 
  405                   << MSG::hex << minorVersion << MSG::dec              << 
endmsg 
  406                   << 
"LUT triggered slice offset:  " << trigLut        << 
endmsg 
  407                   << 
"FADC triggered slice offset: " << trigFadc       << 
endmsg 
  408                   << 
"FADC baseline lower bound:   " << fadcBaseline << 
endmsg;
 
  410         const int runNumber = (*rob)->rod_run_no() & 0xffffff;
 
  414         int chanPerSubBlock = 0;
 
  415         bool firstBlock = 
false;
 
  429             if (
sd.m_ppmBlocks.empty())
 
  431                 sd.m_ppmBlocks.push_back(
new PpmSubBlockV1());
 
  433             PpmSubBlockV1 *
const subBlock = 
sd.m_ppmBlocks[0];
 
  435             payloadFirst = subBlock->read(
payload, payloadEnd);
 
  436             chanPerSubBlock = subBlock->channelsPerSubBlock();
 
  437             if (chanPerSubBlock == 0)
 
  439                 m_errorTool->rodError(robid, subBlock->unpackErrorCode());
 
  440                 if (
debug) 
msg() << 
"Unsupported version/data format: " 
  441                                      << subBlock->version() << 
"/" 
  442                                      << subBlock->format()  << 
endmsg;
 
  445             if (
debug) 
msg() << 
"Channels per sub-block: " 
  446                                  << chanPerSubBlock << 
endmsg;
 
  450             if (
debug) 
msg() << 
"ROB fragment contains user header only" << 
endmsg;
 
  453         const int numSubBlocks = 
s_channels / chanPerSubBlock;
 
  454         const int size = 
sd.m_ppmBlocks.size();
 
  455         if (numSubBlocks > 
size)
 
  457             for (
int i = 
size; 
i < numSubBlocks; ++
i)
 
  459                 sd.m_ppmBlocks.push_back(
new PpmSubBlockV1());
 
  466         for (
int i = 0; 
i < headerWords; ++
i) ++
payload;
 
  476             for (
int block = 0; block < numSubBlocks; ++block)
 
  492                         msg() << 
"Unexpected channel sequence number: " 
  494                               << block *chanPerSubBlock << 
endmsg;
 
  499                 PpmSubBlockV1 *
const subBlock = 
sd.m_ppmBlocks[block];
 
  513                     crate = subBlock->crate();
 
  514                     module = subBlock->module();
 
  519                     if (crate != rodCrate)
 
  523                             msg() << 
"Inconsistent crate number in ROD source ID" << 
endmsg;
 
  531                     if (subBlock->crate() != crate)
 
  533                         if (
debug) 
msg() << 
"Inconsistent crate number in sub-blocks" 
  538                     if (subBlock->module() != 
module)
 
  540                         if (
debug) 
msg() << 
"Inconsistent module number in sub-blocks" 
  546                 if (
payload == payloadEnd && block != numSubBlocks - 1)
 
  557             bool isErrBlock = 
false;
 
  565                     sd.m_errorBlock.clear();
 
  568                     if (
sd.m_errorBlock.crate() != crate)
 
  570                         if (
debug) 
msg() << 
"Inconsistent crate number in error block" 
  575                     if (
sd.m_errorBlock.module() != 
module)
 
  577                         if (
debug) 
msg() << 
"Inconsistent module number in error block" 
  582                     if (
sd.m_errorBlock.dataWords() && !
sd.m_errorBlock.unpack())
 
  586                             std::string errMsg(
sd.m_errorBlock.unpackErrorMsg());
 
  587                             msg() << 
"Unpacking error block failed: " << errMsg << 
endmsg;
 
  589                         rodErr = 
sd.m_errorBlock.unpackErrorCode();
 
  598             const int word2  = 
index2 / 32;
 
  599             const int bit2   = 
index2 % 32;
 
  600             if (!((colMod[word2] >> bit2) & 1)) 
continue;
 
  604             for (
int block = 0; block < nPpmBlocks; ++block)
 
  606                 PpmSubBlockV1 *
const subBlock = 
sd.m_ppmBlocks[block];
 
  607                 subBlock->setLutOffset(trigLut);
 
  608                 subBlock->setFadcOffset(trigFadc);
 
  610                 subBlock->setFadcBaseline(fadcBaseline);
 
  614                     msg() << 
"Unpacking sub-block version/format/seqno: " 
  615                           << subBlock->version() << 
"/" << subBlock->format() << 
"/" 
  616                           << subBlock->seqno() << 
endmsg;
 
  618                 if (subBlock->dataWords() && !subBlock->unpack())
 
  622                         std::string errMsg(subBlock->unpackErrorMsg());
 
  623                         msg() << 
"Unpacking PPM sub-block failed: " << errMsg << 
endmsg;
 
  625                     rodErr = subBlock->unpackErrorCode();
 
  631                     const int channel = block * chanPerSubBlock + 
chan;
 
  633                     const int word  = 
index / 32;
 
  634                     const int bit   = 
index % 32;
 
  635                     if (!((colChan[word] >> bit) & 1)) 
continue; 
 
  636                     if (((
sd.m_foundChan[word] >> bit) & 1))
 
  638                         if (
debug) 
msg() << 
"Duplicate data for crate/module/channel: " 
  648                     subBlock->ppmData(
channel, 
lut, fadc, bcidLut, bcidFadc);
 
  649                     if (
lut.size() < 
size_t(trigLut + 1))
 
  653                             msg() << 
"Triggered LUT slice from header " 
  654                                   << 
"inconsistent with number of slices: " 
  655                                   << trigLut << 
", " << 
lut.size() << 
endmsg;
 
  660                     if (fadc.size() < 
size_t(trigFadc + 1))
 
  664                             msg() << 
"Triggered FADC slice from header " 
  665                                   << 
"inconsistent with number of slices: " 
  666                                   << trigFadc << 
", " << fadc.size() << 
endmsg;
 
  677                                       sd.m_errorBlock.subStatus());
 
  683                         const PpmSubBlockV1 *
const lastBlock =
 
  684                             sd.m_ppmBlocks[nPpmBlocks - 1];
 
  686                                       lastBlock->subStatus());
 
  689                     if (subBlock->format() > 1 && subBlock->seqno() < 4)
 
  694                     const int error = errorBits.error();
 
  706                         msg() << MSG::hex << 
error << MSG::dec << 
"/";
 
  708                     sd.m_foundChan[word] |= (1 << bit);
 
  711                     const int layer = ((
sd.m_chanLayer[word] >> bit) & 1);
 
  714                         tt->addEM(fadc, 
lut, bcidFadc, bcidLut, 
error, trigLut, trigFadc);
 
  718                         tt->addHad(fadc, 
lut, bcidFadc, bcidLut, 
error, trigLut, trigFadc);
 
  731     if (ttCount != colSize)
 
  735             msg() << 
"Found " << ttCount << 
" channels, expected " << colSize << 
endmsg;
 
  737         std::vector<int> 
dummy(1);
 
  738         for (
int word = 0; word < chanBitVecSize; ++word)
 
  740             if (
sd.m_foundChan[word] != colChan[word])
 
  742                 for (
int bit = 0; bit < 32; ++bit)
 
  744                     if (((
sd.m_foundChan[word] >> bit) & 1) != ((colChan[word] >> bit) & 1))
 
  746                         const int index = word * 32 + bit;
 
  748                         const int layer = ((
sd.m_chanLayer[word] >> bit) & 1);
 
  753                         else if (dataChannels)     
 
  769         for (; itr != itrE; ++itr)
 
  771             if ((*itr)->emEnergy() || (dataChannels && (*itr)->hadEnergy()))
 
  779         ttCollection->
assign(ttCol.begin(), ttCol.end());
 
  782     return StatusCode::SUCCESS;
 
 
 
 
◆ declareGaudiProperty() [1/4]
specialization for handling Gaudi::Property<SG::VarHandleKeyArray> 
Definition at line 170 of file AthCommonDataStore.h.
  175                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [2/4]
specialization for handling Gaudi::Property<SG::VarHandleKey> 
Definition at line 156 of file AthCommonDataStore.h.
  161                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [3/4]
specialization for handling Gaudi::Property<SG::VarHandleBase> 
Definition at line 184 of file AthCommonDataStore.h.
  189                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [4/4]
◆ declareProperty() [1/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 245 of file AthCommonDataStore.h.
  250     this->declare(hndl.
vhKey());
 
  251     hndl.
vhKey().setOwner(
this);
 
  253     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [2/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 221 of file AthCommonDataStore.h.
  229     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [3/6]
◆ declareProperty() [4/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty. 
Definition at line 333 of file AthCommonDataStore.h.
  338     return PBASE::declareProperty(
name, property, 
doc);
 
 
 
 
◆ declareProperty() [5/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray. 
Definition at line 352 of file AthCommonDataStore.h.
 
 
◆ declareProperty() [6/6]
◆ detStore()
◆ evtStore() [1/2]
◆ evtStore() [2/2]
◆ extraDeps_update_handler()
Add StoreName to extra input/output deps as needed. 
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given 
 
 
◆ finalize()
  
  | 
        
          | StatusCode LVL1BS::PpmByteStreamV1Tool::finalize | ( |  | ) |  |  | overridevirtual | 
 
 
◆ findLayerTriggerTower()
Find a trigger tower using separate layer maps. 
Definition at line 1083 of file PpmByteStreamV1Tool.cxx.
 1091     TriggerTowerMapConst::const_iterator mapIter;
 
 1094         mapIter = ttEmMap.find(
key);
 
 1095         if (mapIter != ttEmMap.end()) 
tt = mapIter->second;
 
 1099         mapIter = ttHadMap.find(
key);
 
 1100         if (mapIter != ttHadMap.end()) 
tt = mapIter->second;
 
 
 
 
◆ initialize()
  
  | 
        
          | StatusCode LVL1BS::PpmByteStreamV1Tool::initialize | ( |  | ) |  |  | overridevirtual | 
 
 
◆ inputHandles()
Return this algorithm's input handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ interfaceID()
  
  | 
        
          | const InterfaceID & LVL1BS::PpmByteStreamV1Tool::interfaceID | ( |  | ) |  |  | static | 
 
 
◆ makeSourceIDs()
  
  | 
        
          | std::vector< uint32_t > LVL1BS::PpmByteStreamV1Tool::makeSourceIDs | ( | bool | spareChannels, |  
          |  |  | bool | muonChannels |  
          |  | ) |  | const |  | private | 
 
Definition at line 1222 of file PpmByteStreamV1Tool.cxx.
 1224   std::vector<uint32_t> robIds;
 
 1226   if (!spareChannels && !muonChannels) {
 
 1230   if (robIds.empty()) {
 
 1232     for (
int crate = 0; crate < 
s_crates; ++crate)
 
 1234       for (
int slink = 0; slink < maxlinks; ++slink)
 
 1236         const int daqOrRoi = 0;
 
 1241         if (spareChannels && !(crate > 1 && crate < 6)) {
 
 1245         if (muonChannels && !(crate > 1 && crate < 4 && slink == 0)) {
 
 1249         robIds.push_back (robId);
 
 
 
 
◆ msg() [1/2]
◆ msg() [2/2]
◆ msgLvl()
◆ outputHandles()
Return this algorithm's output handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ printCompStats()
  
  | 
        
          | void LVL1BS::PpmByteStreamV1Tool::printCompStats | ( |  | ) | const |  | private | 
 
 
◆ printVec()
  
  | 
        
          | void LVL1BS::PpmByteStreamV1Tool::printVec | ( | const std::vector< int > & | vec | ) | const |  | private | 
 
 
◆ renounce()
◆ renounceArray()
◆ setupTTMaps()
Set up separate Em and Had trigger tower maps. 
Definition at line 1107 of file PpmByteStreamV1Tool.cxx.
 1119     for (; 
pos != pose; ++
pos)
 
 1122         const unsigned int key = towerKey.
ttKey(
tt->phi(), 
tt->eta());
 
 1127                 accumulate((
tt->emBCIDvec()).begin(), (
tt->emBCIDvec()).end(), 0) ||
 
 1128                 accumulate((
tt->emBCIDext()).begin(), (
tt->emBCIDext()).end(), 0) ||
 
 1131             ttEmMap.insert(std::make_pair(
key, 
tt));
 
 1134         if (
accumulate((
tt->hadLUT()).begin(),     (
tt->hadLUT()).end(),     0) ||
 
 1136                 accumulate((
tt->hadBCIDvec()).begin(), (
tt->hadBCIDvec()).end(), 0) ||
 
 1137                 accumulate((
tt->hadBCIDext()).begin(), (
tt->hadBCIDext()).end(), 0) ||
 
 1140             ttHadMap.insert(std::make_pair(
key, 
tt));
 
 
 
 
◆ slinkSlices()
Get number of slices and triggered slice offsets for next slink. 
Definition at line 1147 of file PpmByteStreamV1Tool.cxx.
 1170             if ( !
tt ) 
continue;
 
 1175                     sliceL = (
tt->emLUT()).
size();
 
 1176                     sliceF = (
tt->emADC()).
size();
 
 1177                     trigL  = 
tt->emPeak();
 
 1178                     trigF  = 
tt->emADCPeak();
 
 1182                     if ((
tt->emLUT()).
size() != size_t(sliceL) ||
 
 1183                             (
tt->emADC()).
size() != size_t(sliceF) ||
 
 1184                             tt->emPeak() != trigL || 
tt->emADCPeak() != trigF)
 
 1194                     sliceL = (
tt->hadLUT()).
size();
 
 1195                     sliceF = (
tt->hadADC()).
size();
 
 1196                     trigL  = 
tt->hadPeak();
 
 1197                     trigF  = 
tt->hadADCPeak();
 
 1201                     if ((
tt->hadLUT()).
size() != size_t(sliceL) ||
 
 1202                             (
tt->hadADC()).
size() != size_t(sliceF) ||
 
 1203                             tt->hadPeak() != trigL || 
tt->hadADCPeak() != trigF)
 
 1213     slicesFadc = sliceF;
 
 
 
 
◆ sourceIDs()
      
        
          | const std::vector< uint32_t > & LVL1BS::PpmByteStreamV1Tool::sourceIDs | ( | const std::string & | sgKey | ) | const | 
      
 
Return reference to vector with all possible Source Identifiers. 
Definition at line 1256 of file PpmByteStreamV1Tool.cxx.
 1260     const std::string 
flag(
"Spare");
 
 1261     const std::string::size_type 
pos = sgKey.find(
flag);
 
 1262     bool spareChannels =
 
 1263         (
pos != std::string::npos && 
pos == (sgKey.length() - 
flag.length()));
 
 1265     const std::string flag2(
"Muon");
 
 1266     const std::string::size_type pos2 = sgKey.find(flag2);
 
 1268         (pos2 != std::string::npos && pos2 == (sgKey.length() - flag2.length()));
 
 1270     if (spareChannels) {
 
 1271       static const std::vector<uint32_t> sourceIDsSpare =
 
 1273       return sourceIDsSpare;
 
 1277       static const std::vector<uint32_t> sourceIDsMuon =
 
 1279       return sourceIDsMuon;
 
 1282     static const std::vector<uint32_t> 
sourceIDs =
 
 
 
 
◆ sysInitialize()
◆ sysStart()
Handle START transition. 
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container. 
 
 
◆ updateVHKA()
◆ ATLAS_THREAD_SAFE
◆ m_compStats
  
  | 
        
          | std::atomic<uint32_t> LVL1BS::PpmByteStreamV1Tool::m_compStats[MAXFORMATS] |  | private | 
 
 
◆ m_compVers
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::m_compVers |  | private | 
 
 
◆ m_crateMax
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_crateMax |  | private | 
 
 
◆ m_crateMin
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_crateMin |  | private | 
 
 
◆ m_dataFormat
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_dataFormat |  | private | 
 
 
◆ m_detStore
◆ m_dfltSlicesFadc
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_dfltSlicesFadc |  | private | 
 
 
◆ m_dfltSlicesLut
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_dfltSlicesLut |  | private | 
 
 
◆ m_errorTool
◆ m_evtStore
◆ m_fadcBaseline
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_fadcBaseline |  | private | 
 
 
◆ m_fadcThreshold
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_fadcThreshold |  | private | 
 
 
◆ m_forceSlicesFadc
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_forceSlicesFadc |  | private | 
 
 
◆ m_forceSlicesLut
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_forceSlicesLut |  | private | 
 
 
◆ m_pedestal
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_pedestal |  | private | 
 
 
◆ m_ppmMaps
◆ m_printCompStats
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_printCompStats |  | private | 
 
 
◆ m_slinks
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_slinks |  | private | 
 
 
◆ m_sms
◆ m_sourceIDsProp
  
  | 
        
          | std::vector<uint32_t> LVL1BS::PpmByteStreamV1Tool::m_sourceIDsProp |  | private | 
 
 
◆ m_srcIdMap
◆ m_subDetector
  
  | 
        
          | const eformat::SubDetector LVL1BS::PpmByteStreamV1Tool::m_subDetector |  | private | 
 
 
◆ m_varHandleArraysDeclared
◆ m_version
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::m_version |  | private | 
 
 
◆ m_vhka
◆ m_zeroSuppress
  
  | 
        
          | int LVL1BS::PpmByteStreamV1Tool::m_zeroSuppress |  | private | 
 
 
◆ MAXFORMATS
  
  | 
        
          | constexpr unsigned int LVL1BS::PpmByteStreamV1Tool::MAXFORMATS = 10 |  | staticconstexprprivate | 
 
 
◆ s_channels
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::s_channels = 64 |  | staticprivate | 
 
 
◆ s_crates
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::s_crates = 8 |  | staticprivate | 
 
 
◆ s_dataSize
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::s_dataSize = 3584 |  | staticprivate | 
 
 
◆ s_modules
  
  | 
        
          | const int LVL1BS::PpmByteStreamV1Tool::s_modules = 16 |  | staticprivate | 
 
 
The documentation for this class was generated from the following files:
 
JetConstituentVector::iterator iterator
uint16_t minorVersionPreLS1() const
Return last ROD header minor version for pre-LS1 data.
int slink(uint32_t code) const
Return slink from unpacked moduleID.
Const iterator class for DataVector/DataList.
Scalar phi() const
phi method
Template class for assembling a full atlas raw event from subfragments.
Scalar eta() const
pseudorapidity method
static int peak(int oldPeak, int oldSlices, int newSlices)
Return new triggered slice offset.
accumulate
Update flags based on parser line args.
static bool cmmBlock(uint32_t word)
Determine if header word corresponds to CMM.
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
bool msgLvl(const MSG::Level lvl) const
uint32_t getRobID(uint32_t rod_id) const
Make a ROB Source ID from a ROD source ID.
std::vector< size_t > vec
constexpr auto lut(Generator &&f)
virtual void setOwner(IDataHandleHolder *o)=0
void assign(InputIterator first, InputIterator last)
Assign from iterators.
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
static void data(const std::vector< int > &oldVec, std::vector< int > &newVec, int newSlices)
Return modified data vector<int>
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
int crate(uint32_t code) const
Return crate from unpacked moduleID.
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
static SubBlockWordType wordType(uint32_t word)
Word identification.
virtual void renounce()=0
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
void clear()
Clear internal stack.
Trigger towers are the inputs to all other parts of the calorimeter trigger.
value_type push_back(value_type pElem)
Add an element to the end of the collection.
static bool errorBlock(uint32_t word)
Check if a header word is for an error block.
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
eformat::SubDetector subDet(uint32_t code) const
Return sub-detector for given ID.
void setRodMinorVersion(uint16_t m)
change the ROD minor version
const boost::regex re(r_e)
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
uint32_t getRodID(int crate, int slink, int daqOrRoi, eformat::SubDetector subdet) const
Make a ROD Source ID.
std::vector< uint32_t > RODDATA
ROD data as a vector of unsigned int.
virtual unsigned int ttKey(const TriggerTower &tower)
returns the key of the passed tower
int maxSlinks() const
Return the maximum possible number of slinks.
int daqOrRoi(uint32_t code) const
Return daqOrRoi from unpacked moduleID.
The TriggerTowerKey object provides the key for each trigger tower depending on its eta-phi coords.
RODDATA * getRodData(uint32_t id)
get a block of ROD data
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
void fill(RawEventWrite *re, MsgStream &log)
Fill the FullEventFragment with all the ROD data stored in this.
TriggerTower_v2 TriggerTower
Define the latest version of the TriggerTower class.