diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.cxx b/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.cxx index 6a7add13835ff5468c3500bd26bfd48395f185dc..d3b2c32518722e7c54cadc78ac837228cb901164 100644 --- a/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.cxx +++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration */ #include "LArRawEvent/LArFebHeader.h" diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.h b/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.h index 81315eace8fce05a5e43517fd81e310b1b01cd04..3a596904b6d3fbbd2422be873f4e7756f49d9ff4 100644 --- a/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.h +++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArFebHeaderReader.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration */ #include "ByteStreamData/RawEvent.h" diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.cxx b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.cxx index 9a5f8f256e23b4f068f45c3e0d43e03e85ac18ca..befdcea76d34d67ddc93c209e23c4f3f375b7092 100644 --- a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.cxx +++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.cxx @@ -73,6 +73,24 @@ LArRawCalibDataReadingAlg::LArRawCalibDataReadingAlg(const std::string& name, IS ATH_CHECK(m_robDataProviderSvc.retrieve()); ATH_CHECK(detStore()->retrieve(m_onlineId,"LArOnlineID")); + + + //Build list of preselected Feedthroughs + if (m_vBEPreselection.size() && m_vPosNegPreselection.size() && m_vFTPreselection.size()) { + ATH_MSG_INFO("Building list of selected feedthroughs"); + for (const unsigned iBE : m_vBEPreselection) { + for (const unsigned iPN: m_vPosNegPreselection) { + for (const unsigned iFT: m_vFTPreselection) { + HWIdentifier finalFTId=m_onlineId->feedthrough_Id(iBE,iPN,iFT); + unsigned int finalFTId32 = finalFTId.get_identifier32().get_compact(); + ATH_MSG_INFO("Adding feedthrough Barrel/Endcap=" << iBE << " pos/neg=" << iPN << " FT=" << iFT + << " (0x" << std::hex << finalFTId32 << std::dec << ")"); + m_vFinalPreselection.insert(finalFTId32); + } + } + } + }//end if something set + return StatusCode::SUCCESS; } @@ -192,6 +210,16 @@ StatusCode LArRawCalibDataReadingAlg::execute(const EventContext& ctx) const { else continue; } + + if (m_vFinalPreselection.size()) { + const unsigned int ftId=m_onlineId->feedthrough_Id(fId).get_identifier32().get_compact(); + if (m_vFinalPreselection.find(ftId)==m_vFinalPreselection.end()) { + ATH_MSG_DEBUG("Feedthrough with id 0x" << MSG::hex << ftId << MSG::dec <<" not in preselection. Ignored."); + continue; + } + } + + const int NthisFebChannel=m_onlineId->channelInSlotMax(fId); //Decode LArCalibDigits (if requested) diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.h b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.h index 1c5b1121fb787b18632208eb58c791b34c187719..ee3a59f4c4db1fa8feee704fb225c46547ad502e 100644 --- a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.h +++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawCalibDataReadingAlg.h @@ -41,6 +41,12 @@ class LArRawCalibDataReadingAlg : public AthReentrantAlgorithm { BooleanProperty m_verifyChecksum{this,"VerifyChecksum",true,"Calculate and compare checksums to detect data transmission errors"}; BooleanProperty m_failOnCorruption{this,"FailOnCorruption",true,"Return FAILURE if data corruption is found"}; + Gaudi::Property<std::vector<unsigned> > m_vBEPreselection{this,"BEPreselection",{},"For channel-selection: Barrel=0, Endcap=1"}; + Gaudi::Property<std::vector<unsigned> > m_vPosNegPreselection{this,"PosNegPreselection",{}, "For channel-selection: C-Side:0, A-Side: 1"}; + Gaudi::Property<std::vector<unsigned> > m_vFTPreselection{this,"FTNumPreselection",{}, "For channel-selection: Feedthrough numbers (e.g. 0 - 31 for barrel)"}; + + std::set<unsigned> m_vFinalPreselection; + //Identifier helper const LArOnlineID* m_onlineId=nullptr;