ATLAS Offline Software
Loading...
Searching...
No Matches
LArHitEMapToDigitAlg Class Reference

#include <LArHitEMapToDigitAlg.h>

Inheritance diagram for LArHitEMapToDigitAlg:

Public Member Functions

virtual StatusCode initialize ()
virtual StatusCode execute (const EventContext &context) const
virtual StatusCode sysInitialize () override
 Override sysInitialize.
virtual bool isClonable () const override
 Specify if the algorithm is clonable.
virtual unsigned int cardinality () const override
 Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.
virtual StatusCode sysExecute (const EventContext &ctx) override
 Execute an algorithm.
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies.
virtual bool filterPassed (const EventContext &ctx) const
virtual void setFilterPassed (bool state, const EventContext &ctx) const
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Protected Types

enum  CaloNum { EM =0 , HEC , FCAL , EMIW }
using staticVecDouble_t = boost::container::static_vector<double,s_MaxNSamples>
using staticVecFloat_t = boost::container::static_vector<float,s_MaxNSamples>

Protected Member Functions

template<class T>
const T * pointerFromKey (const EventContext &context, const SG::ReadCondHandleKey< T > &key) const
StatusCode MakeDigit (const EventContext &ctx, const Identifier &cellId, const HWIdentifier &ch_id, LArDigit *&Digit, DataPool< LArDigit > &dataItemsPool, LArDigit *&Digit_DigiHSTruth, const std::vector< std::pair< float, float > > *TimeE, const LArDigit *rndm_digit, CLHEP::HepRandomEngine *engine, const std::vector< std::pair< float, float > > *TimeE_DigiHSTruth, const LArADC2MeV *adc2MeVs, const ILArfSampl *fSampl, const ILArPedestal *pedestal, const ILArNoise *noise, const LArAutoCorrNoise *autoCorrNoise, const LArBadChannelCont *bcCont, const ILArShape *shape) const
StatusCode ConvertHits2Samples (const Identifier &cellId, HWIdentifier ch_id, CaloGain::CaloGain igain, const std::vector< std::pair< float, float > > *TimeE, staticVecDouble_t &sampleList, const ILArShape *shape) const
CaloGain::CaloGain chooseGain (const staticVecDouble_t &samples, const HWIdentifier id, const CaloNum iCalo, const ILArPedestal *ped, const LArADC2MeV *ramp, const float SF) const
void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed.

Protected Attributes

SG::ReadCondHandleKey< ILArNoisem_noiseKey {this,"NoiseKey","LArNoiseSym","SG Key of ILArNoise object"}
SG::ReadCondHandleKey< ILArfSamplm_fSamplKey {this,"fSamplKey","LArfSamplSym","SG Key of LArfSampl object"}
SG::ReadCondHandleKey< ILArOFCm_OFCKey {this, "OFCKey", "LArOFC", "SG Key of OFC conditions object"}
SG::ReadCondHandleKey< ILArPedestalm_pedestalKey {this,"PedestalKey","LArPedestal","SG Key of LArPedestal object"}
SG::ReadCondHandleKey< ILArShapem_shapeKey {this,"ShapeKey","LArShapeSym","SG Key of LArShape object"}
SG::ReadCondHandleKey< LArADC2MeVm_adc2mevKey {this,"ADC2MeVKey","LArADC2MeV","SG Key of ADC2MeV conditions object"}
SG::ReadCondHandleKey< LArOnOffIdMappingm_cablingKey {this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"}
const LArOnOffIdMappingm_cabling {}
SG::ReadCondHandleKey< LArAutoCorrNoisem_autoCorrNoiseKey {this,"AutoCorrNoiseKey","LArAutoCorrNoise","SG Key of AutoCorrNoise conditions object"}
SG::ReadCondHandleKey< LArBadChannelContm_bcContKey {this, "BadChanKey", "LArBadChannel", "SG key for LArBadChan object"}
SG::ReadCondHandleKey< LArBadFebContm_badFebKey {this, "BadFebKey", "LArBadFeb", "Key of BadFeb object in ConditionsStore"}
Gaudi::Property< std::vector< std::string > > m_problemsToMask {this,"ProblemsToMask",{},"Bad-Channel categories to mask entirly"}
LArBadChannelMask m_bcMask
SG::ReadCondHandleKey< CaloDetDescrManagerm_caloMgrKey {this,"CaloDetDescrManager", "CaloDetDescrManager"}
SG::ReadHandleKey< LArHitEMapm_hitMapKey {this,"LArHitEMapKey","LArHitEMap"}
SG::ReadHandleKey< LArHitEMapm_hitMapKey_DigiHSTruth {this,"LArHitEMap_DigiHSTruthKey","LArHitEMap_DigiHSTruth"}
SG::ReadHandleKey< LArDigitContainerm_inputDigitContainerKey
SG::WriteHandleKey< LArDigitContainerm_DigitContainerName
SG::WriteHandleKey< LArDigitContainerm_DigitContainerName_DigiHSTruth
Gaudi::Property< std::string > m_randomStreamName {this, "RandomStreamName", "LArDigitization", ""}
ServiceHandle< IAthRNGSvcm_rndmGenSvc {this, "RndmSvc", "AthRNGSvc", ""}
Gaudi::Property< uint32_t > m_randomSeedOffset {this, "RandomSeedOffset", 2, ""}
Gaudi::Property< bool > m_useLegacyRandomSeeds
std::array< Gaudi::Property< double >, 4 > m_LowGainThresh
std::array< Gaudi::Property< double >, 4 > m_HighGainThresh
std::array< Gaudi::Property< std::pair< int, int > >, 4 > m_gainRange
Gaudi::Property< unsigned > m_maxADC {this,"maxADC",4096,"Maxium ADC value +1 (for overflow)"}
Gaudi::Property< int > m_NSamples
Gaudi::Property< bool > m_NoiseOnOff
Gaudi::Property< int > m_firstSample
Gaudi::Property< bool > m_usePhase
Gaudi::Property< bool > m_RndmEvtOverlay
Gaudi::Property< bool > m_isMcOverlay
Gaudi::Property< bool > m_doDigiTruth
Gaudi::Property< bool > m_NoiseInEMB
Gaudi::Property< bool > m_NoiseInEMEC
Gaudi::Property< bool > m_NoiseInHEC
Gaudi::Property< bool > m_NoiseInFCAL
Gaudi::Property< bool > m_pedestalNoise
Gaudi::Property< bool > m_roundingNoNoise
Gaudi::Property< bool > m_Windows
Gaudi::Property< float > m_WindowsEtaSize
Gaudi::Property< float > m_WindowsPhiSize
Gaudi::Property< float > m_WindowsPtCut
const CaloCell_IDm_calocell_id {}
const LArEM_IDm_larem_id {}
const LArHEC_IDm_larhec_id {}
const LArFCAL_IDm_larfcal_id {}
const LArOnlineIDm_laronline_id {}

Static Protected Attributes

static constexpr int s_MaxNSamples = 32

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

DataObjIDColl m_extendedExtraObjects
 Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default)
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Detailed Description

Definition at line 58 of file LArHitEMapToDigitAlg.h.

Member Typedef Documentation

◆ staticVecDouble_t

using LArHitEMapToDigitAlg::staticVecDouble_t = boost::container::static_vector<double,s_MaxNSamples>
protected

Definition at line 72 of file LArHitEMapToDigitAlg.h.

◆ staticVecFloat_t

using LArHitEMapToDigitAlg::staticVecFloat_t = boost::container::static_vector<float,s_MaxNSamples>
protected

Definition at line 73 of file LArHitEMapToDigitAlg.h.

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Member Enumeration Documentation

◆ CaloNum

Member Function Documentation

◆ cardinality()

unsigned int AthCommonReentrantAlgorithm< Gaudi::Algorithm >::cardinality ( ) const
overridevirtualinherited

Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.

Override this to return 0 for reentrant algorithms.

Definition at line 75 of file AthCommonReentrantAlgorithm.cxx.

64{
65 return 0;
66}

◆ chooseGain()

CaloGain::CaloGain LArHitEMapToDigitAlg::chooseGain ( const staticVecDouble_t & samples,
const HWIdentifier id,
const CaloNum iCalo,
const ILArPedestal * ped,
const LArADC2MeV * ramp,
const float SF ) const
protected

Definition at line 747 of file LArHitEMapToDigitAlg.cxx.

748 {
749
750 int sampleGainChoice{2};
751 if (m_firstSample < 0)
752 sampleGainChoice -= m_firstSample;
753
754 // fix the shift +1 if HEC and nSamples 4 and firstSample 0
755 if (iCalo == HEC && m_NSamples.value() == 4 && m_firstSample.value() == 0)
756 sampleGainChoice -= 1; // ihecshift
757
758 CaloGain::CaloGain gainChoosingGain = static_cast<CaloGain::CaloGain>(m_gainRange[iCalo].value().second - 1);
759 // We choose the gain in applying thresholds on the 3rd Sample (index "2")
760 // converted in ADC counts in the second-lowest gain (eg MEDIUM gain for run 1,2,3, HIGH gain for run 4)
761 // Indeed, thresholds in ADC counts are defined with respect to the MediumGain.
762 //
763 // 1300 3900
764 // ---------------|----------------|--------------> ADC counts in MediumGain
765 // HighGain <--- MediumGain ---> LowGain
766
767 float Pedestal = pedestal->pedestal(ch_id, gainChoosingGain);
768 if (Pedestal <= (1.0 + LArElecCalib::ERRORCODE)) {
769 ATH_MSG_DEBUG(" Pedestal not found for channel " << m_laronline_id->channel_name(ch_id) << " assume 1000 ");
770 Pedestal = 1000.;
771 }
772 const auto& polynom_adc2mev = adc2MeVs->ADC2MEV(ch_id, gainChoosingGain);
773 if (polynom_adc2mev.size() < 2) {
774 ATH_MSG_WARNING(" No ramp found for channel " << m_laronline_id->channel_name(ch_id) << ", gain " << gainChoosingGain << ", no digit produced...");
776 }
777 const float pseudoADC3 = samples[sampleGainChoice] / (polynom_adc2mev[1]) / SF + Pedestal;
778
779 CaloGain::CaloGain igain = gainChoosingGain;
780 // if we are not yet already in the highest gain and we are below high-gain theshold, switch to high gain
781 if (gainChoosingGain > m_gainRange[iCalo].value().first && pseudoADC3 < m_HighGainThresh[iCalo]) {
783 }
784
785 else if (gainChoosingGain < m_gainRange[iCalo].value().second && pseudoADC3 > m_LowGainThresh[iCalo]) {
787 }
788
789 return igain;
790}
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
std::array< Gaudi::Property< std::pair< int, int > >, 4 > m_gainRange
Gaudi::Property< int > m_firstSample
const LArOnlineID * m_laronline_id
std::array< Gaudi::Property< double >, 4 > m_LowGainThresh
std::array< Gaudi::Property< double >, 4 > m_HighGainThresh
Gaudi::Property< int > m_NSamples
@ INVALIDGAIN
Definition CaloGain.h:18
@ LARLOWGAIN
Definition CaloGain.h:18
@ LARHIGHGAIN
Definition CaloGain.h:18

◆ ConvertHits2Samples()

StatusCode LArHitEMapToDigitAlg::ConvertHits2Samples ( const Identifier & cellId,
HWIdentifier ch_id,
CaloGain::CaloGain igain,
const std::vector< std::pair< float, float > > * TimeE,
staticVecDouble_t & sampleList,
const ILArShape * shape ) const
protected

Definition at line 629 of file LArHitEMapToDigitAlg.cxx.

633{
634// Converts hits of a particular LAr cell into energy samples
635// declarations
636 int nsamples ;
637 int nsamples_der ;
638 int i ;
639 int j ;
640
641// ........ retrieve data (1/2) ................................
642//
643 ILArShape::ShapeRef_t Shape = shape->Shape(ch_id,igain);
644 ILArShape::ShapeRef_t ShapeDer = shape->ShapeDer(ch_id,igain);
645
646 nsamples = Shape.size();
647 nsamples_der = ShapeDer.size();
648
649 if (nsamples==0) {
650 ATH_MSG_INFO(" No samples for cell = " << cellId );
651 return StatusCode::FAILURE;
652 }
653
654#ifndef NDEBUG
655 ATH_MSG_DEBUG(" Cellid " << m_larem_id->show_to_string(cellId));
656 for (i=0;i<nsamples;i++)
657 {
658 ATH_MSG_DEBUG(Shape[i] << " ");
659 }
660 ATH_MSG_DEBUG("m_NSamples, m_usePhase " << m_NSamples << " " << m_usePhase);
661#endif
662
663
664for (const auto& [energy, time] : *TimeE) {
665 // fix the shift +1 if HEC and nSamples 4 and firstSample 0
666 // in case of data overlay this should NOT be done as the pulse shape read from the database is already shifted
667 // but this should still be done in case of MC overlay
668 int ihecshift=0;
669 if((!m_RndmEvtOverlay || m_isMcOverlay) && m_larem_id->is_lar_hec(cellId) && m_NSamples.value() == 4 && m_firstSample.value() == 0) ihecshift=1;
670
671
672 if (!m_usePhase) {
673
674 // Atlas like mode where we use 25ns binned pulse shape and derivative to deal with time offsets
675
676// shift between reference shape and this time
677 int ishift=(int)(rint(time*(1./25.)));
678 double dtime=time-25.*((double)(ishift));
679 for (i=0;i<m_NSamples.value();i++)
680 {
681 j = i - ishift + m_firstSample + ihecshift;
682#ifndef NDEBUG
683 ATH_MSG_DEBUG(" time/i/j " << time << " "<< i << " " << j);
684#endif
685 if (j >=0 && j < nsamples ) {
686 if (j<nsamples_der && std::abs(ShapeDer[j])<10. )
687 sampleList[i] += (Shape[j]- ShapeDer[j]*dtime)*energy ;
688 else sampleList[i] += Shape[j]*energy ;
689 }
690 }
691 }
692// Mode to use phase (tbin) to get pulse shape ( pulse shape with fine time binning should be available)
693
694 else {
695
696 // FIXME hardcode 8phases3ns configuration (cannot access parameters from ILArShape interface now)
697 int nTimeBins = 8;
698 float timeBinWidth = 25./24.*3.;
699
700// -50<t<-25 phase=-t-25, shift by one peak time (for s2 uses shape(3) with tbin)
701// for -25<t<0 phase = -t, no shift of peak time
702// for 0<t<25 phase=25-t, shift by one peak time (for s2 uses shape(1) with tbin)
703// 25<t<50 phase=50-t, shift by two
704// etc...
705
706 int ishift = (int)(time*(1./25.));
707 int tbin;
708 if (time>0) {
709 tbin = (int)(fmod(time,25)/timeBinWidth);
710 if (tbin>0) {
711 tbin=nTimeBins-tbin;
712 ishift +=1;
713 }
714 } else {
715 tbin = (int)(fmod(-time,25)/timeBinWidth);
716 }
717
718 double dtime = time - ( 25.*((float)(ishift)) - timeBinWidth*tbin);
719
720 Shape = shape->Shape(ch_id,igain,tbin);
721 ShapeDer = shape->ShapeDer(ch_id,igain,tbin);
722
723 nsamples = Shape.size();
724 nsamples_der = ShapeDer.size();
725
726
727 for (i=0;i<m_NSamples.value();i++)
728 {
729 j = i - ishift+m_firstSample + ihecshift;
730#ifndef NDEBUG
731 ATH_MSG_DEBUG(" time/i/j " << time << " "<< i << " " << j);
732#endif
733 if (j >=0 && j < nsamples ) {
734 if (j<nsamples_der && std::abs(ShapeDer[j])<10. )
735 sampleList[i] += (Shape[j]- ShapeDer[j]*dtime)*energy ;
736 else sampleList[i] += Shape[j]*energy ;
737 }
738 }
739
740 } // else if of m_usePhase
741 } // loop over hits
742
743 return StatusCode::SUCCESS;
744
745}
#define ATH_MSG_INFO(x)
LArVectorProxy ShapeRef_t
This class defines the interface for accessing Shape (Nsample variable, Dt = 25 ns fixed) @stereotype...
Definition ILArShape.h:26
virtual ShapeRef_t Shape(const HWIdentifier &id, int gain, int tbin=0, int mode=0) const =0
virtual ShapeRef_t ShapeDer(const HWIdentifier &id, int gain, int tbin=0, int mode=0) const =0
Gaudi::Property< bool > m_usePhase
Gaudi::Property< bool > m_isMcOverlay
Gaudi::Property< bool > m_RndmEvtOverlay
time(flags, cells_name, *args, **kw)
float j(const xAOD::IParticle &, const xAOD::TrackMeasurementValidation &hit, const Eigen::Matrix3d &jab_inv)

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ execute()

StatusCode LArHitEMapToDigitAlg::execute ( const EventContext & context) const
virtual

Retrieve BadChannels

Definition at line 113 of file LArHitEMapToDigitAlg.cxx.

113 {
114
115 // load many conditions
117 SG::ReadCondHandle<LArOnOffIdMapping> cablingHdl{m_cablingKey, context};
118 const LArOnOffIdMapping* cabling=*cablingHdl;
119 if(!cabling) {
120 ATH_MSG_ERROR("Failed to retrieve LAr Cabling map with key " << m_cablingKey.key() );
121 return StatusCode::FAILURE;
122 }
123
124 SG::ReadCondHandle<LArADC2MeV> adc2mevHdl(m_adc2mevKey, context);
125 const LArADC2MeV* adc2MeVs=*adc2mevHdl;
126
127 SG::ReadCondHandle<ILArfSampl> fSamplHdl(m_fSamplKey, context);
128 const ILArfSampl* fSampl=*fSamplHdl;
129
130 SG::ReadCondHandle<ILArPedestal> pedHdl(m_pedestalKey, context);
131 const ILArPedestal* pedestal=*pedHdl;
132
133 const ILArNoise* noise=nullptr;
135 SG::ReadCondHandle<ILArNoise> noiseHdl(m_noiseKey, context);
136 noise=*noiseHdl;
137 }
138
139 const LArAutoCorrNoise* autoCorrNoise=nullptr;
141 SG::ReadCondHandle<LArAutoCorrNoise> autoCorrNoiseHdl(m_autoCorrNoiseKey, context);
142 autoCorrNoise=*autoCorrNoiseHdl;
143 }
144
146 SG::ReadCondHandle<LArBadChannelCont> bch{m_bcContKey,context};
147 const LArBadChannelCont* bcCont{*bch};
148
149 SG::ReadCondHandle<ILArShape> shapeHdl(m_shapeKey, context);
150 const ILArShape* shape=*shapeHdl;
151
152 // Inputs
153 SG::ReadHandle<LArHitEMap> hitmap(m_hitMapKey,context);
154 const LArHitEMap* hitmapPtr = hitmap.cptr();
155 const LArHitEMap* hitmapPtr_DigiHSTruth = nullptr;
156 if ( m_doDigiTruth ) {
157 SG::ReadHandle<LArHitEMap> hitmap_DigitHSTruth(m_hitMapKey_DigiHSTruth,context);
158 hitmapPtr_DigiHSTruth = hitmap_DigitHSTruth.cptr();
159 }
160
161 const size_t nCells=hitmapPtr->GetNbCells();
162 // Prepare Output
163 //
164 // For the standard one lets use a DataPool
165 auto DigitContainer = std::make_unique<LArDigitContainer>(SG::VIEW_ELEMENTS);
166 DigitContainer->reserve(nCells);
167 DataPool<LArDigit> dataItemsPool(context);
168 dataItemsPool.reserve(nCells);
169 //
170 // HSTruth output might not be needed so avoid doing anything
171 // in that case
172 std::unique_ptr<LArDigitContainer> DigitContainer_DigiHSTruth = nullptr;
173 if (m_doDigiTruth){
174 DigitContainer_DigiHSTruth = std::make_unique<LArDigitContainer>();
175 DigitContainer_DigiHSTruth->reserve(nCells);
176 }
177 //
178 const std::vector<std::pair<float,float> >* TimeE;
179 const std::vector<std::pair<float,float> >* TimeE_DigiHSTruth = nullptr;
180
181 ATHRNG::RNGWrapper* rngWrapper = m_rndmGenSvc->getEngine(this, m_randomStreamName);
182 CLHEP::HepRandomEngine * engine = rngWrapper->getEngine(context);
184 rngWrapper->setSeedLegacy( m_randomStreamName, context, m_randomSeedOffset, seedingmode );
185
186 for (size_t it=0;it<nCells;++it)
187 {
188 const LArHitList& hitlist = hitmapPtr->GetCell(it);
189
190 if (!m_Windows || hitlist.inWindows()) {
191 TimeE = &(hitlist.getData());
192 if(m_doDigiTruth) {
193 const auto& hitlist_DigiHSTruth=hitmapPtr_DigiHSTruth->GetCell(it);
194 TimeE_DigiHSTruth = &(hitlist_DigiHSTruth.getData());
195 }
196
197 if (!TimeE->empty() || m_NoiseOnOff || m_RndmEvtOverlay) {
198 const Identifier cellID=m_calocell_id->cell_id(IdentifierHash(it));
199 HWIdentifier ch_id = cabling->createSignalChannelIDFromHash(IdentifierHash(it));
200 HWIdentifier febId = m_laronline_id->feb_Id(ch_id);
201 bool missing=!(badFebs->status(febId).good());
202 if (!missing) {
203 const LArDigit * digit = nullptr ;
204 if(m_RndmEvtOverlay) digit = hitmapPtr->GetDigit(it);
205 // MakeDigit called if in no overlay mode or
206 // if in overlay mode and random digit exists
207 if ((!m_RndmEvtOverlay) || (m_RndmEvtOverlay && digit)) {
208 LArDigit* Digit = nullptr;
209 LArDigit* Digit_DigiHSTruth = nullptr;
210 auto sc = MakeDigit(context, cellID, ch_id, Digit,
211 dataItemsPool,
212 Digit_DigiHSTruth, TimeE, digit, engine,
213 TimeE_DigiHSTruth,
214 adc2MeVs,
215 fSampl,
216 pedestal,
217 noise,
218 autoCorrNoise,
219 bcCont,
220 shape);
221
222 if (sc.isFailure()){
223 ATH_MSG_ERROR("LArHitEMapToDigitAlg::execute failed in MakeDigit");
224 delete Digit_DigiHSTruth;
225 return sc;
226 }
227 DigitContainer->push_back(Digit);
228 if (DigitContainer_DigiHSTruth){
229 DigitContainer_DigiHSTruth->push_back(Digit_DigiHSTruth);
230 }
231 }
232 }
233 }
234 } // check window
235 } // end of loop over the cells
236
237
238 ATH_MSG_DEBUG(" number of created digits = " << DigitContainer->size());
239
240 SG::WriteHandle<LArDigitContainer> DigitContainerHandle( m_DigitContainerName, context);
241 ATH_CHECK(DigitContainerHandle.record( std::move(DigitContainer) ) );
242 if ( DigitContainer_DigiHSTruth ){
243 SG::WriteHandle<LArDigitContainer> DigitContainer_DigiHSTruthHandle( m_DigitContainerName_DigiHSTruth, context);
244 ATH_CHECK(DigitContainer_DigiHSTruthHandle.record( std::move(DigitContainer_DigiHSTruth) ) );
245 }
246
247
248 return StatusCode::SUCCESS;
249}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
LArBadXCont< LArBadFeb > LArBadFebCont
LArBadXCont< LArBadChannel > LArBadChannelCont
static Double_t sc
SeedingOptionType
Options for seeding option=0 is setSeed as in MC20 option=1 is setSeedLegacy as in MC16 option=2 is s...
Definition RNGWrapper.h:97
void setSeedLegacy(const std::string &algName, size_t slot, uint64_t ev, uint64_t run, uint64_t offset, SeedingOptionType seeding, EventContext::ContextEvt_t evt=EventContext::INVALID_CONTEXT_EVT)
Set the random seed using a string (e.g.
CLHEP::HepRandomEngine * getEngine(const EventContext &ctx) const
Retrieve the random engine corresponding to the provided EventContext.
Definition RNGWrapper.h:134
LArBC_t status(const HWIdentifier channel) const
Query the status of a particular channel or FEB This is the main client access method.
Gaudi::Property< bool > m_doDigiTruth
SG::ReadHandleKey< LArHitEMap > m_hitMapKey
SG::ReadCondHandleKey< LArADC2MeV > m_adc2mevKey
const CaloCell_ID * m_calocell_id
Gaudi::Property< bool > m_pedestalNoise
SG::ReadHandleKey< LArHitEMap > m_hitMapKey_DigiHSTruth
StatusCode MakeDigit(const EventContext &ctx, const Identifier &cellId, const HWIdentifier &ch_id, LArDigit *&Digit, DataPool< LArDigit > &dataItemsPool, LArDigit *&Digit_DigiHSTruth, const std::vector< std::pair< float, float > > *TimeE, const LArDigit *rndm_digit, CLHEP::HepRandomEngine *engine, const std::vector< std::pair< float, float > > *TimeE_DigiHSTruth, const LArADC2MeV *adc2MeVs, const ILArfSampl *fSampl, const ILArPedestal *pedestal, const ILArNoise *noise, const LArAutoCorrNoise *autoCorrNoise, const LArBadChannelCont *bcCont, const ILArShape *shape) const
Gaudi::Property< uint32_t > m_randomSeedOffset
SG::ReadCondHandleKey< LArBadChannelCont > m_bcContKey
SG::WriteHandleKey< LArDigitContainer > m_DigitContainerName_DigiHSTruth
Gaudi::Property< bool > m_useLegacyRandomSeeds
SG::ReadCondHandleKey< LArOnOffIdMapping > m_cablingKey
SG::ReadCondHandleKey< ILArPedestal > m_pedestalKey
SG::ReadCondHandleKey< ILArNoise > m_noiseKey
Gaudi::Property< bool > m_Windows
Gaudi::Property< bool > m_NoiseOnOff
ServiceHandle< IAthRNGSvc > m_rndmGenSvc
SG::ReadCondHandleKey< LArAutoCorrNoise > m_autoCorrNoiseKey
const T * pointerFromKey(const EventContext &context, const SG::ReadCondHandleKey< T > &key) const
SG::ReadCondHandleKey< LArBadFebCont > m_badFebKey
SG::ReadCondHandleKey< ILArfSampl > m_fSamplKey
SG::WriteHandleKey< LArDigitContainer > m_DigitContainerName
SG::ReadCondHandleKey< ILArShape > m_shapeKey
Gaudi::Property< std::string > m_randomStreamName
size_t GetNbCells(void) const
Definition LArHitEMap.h:42
const LArHitList & GetCell(const unsigned int index) const
Definition LArHitEMap.h:43
const LArDigit * GetDigit(unsigned int index) const
Definition LArHitEMap.h:48
bool inWindows() const
Definition LArHitList.h:26
const LARLIST & getData() const
Definition LArHitList.h:25
@ VIEW_ELEMENTS
this data object is a view, it does not own its elmts
setRawEt setRawPhi nCells

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
protectedinherited

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

◆ extraOutputDeps()

const DataObjIDColl & AthCommonReentrantAlgorithm< Gaudi::Algorithm >::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 94 of file AthCommonReentrantAlgorithm.cxx.

90{
91 // If we didn't find any symlinks to add, just return the collection
92 // from the base class. Otherwise, return the extended collection.
93 if (!m_extendedExtraObjects.empty()) {
95 }
97}
An algorithm that can be simultaneously executed in multiple threads.

◆ filterPassed()

virtual bool AthCommonReentrantAlgorithm< Gaudi::Algorithm >::filterPassed ( const EventContext & ctx) const
inlinevirtualinherited

Definition at line 96 of file AthCommonReentrantAlgorithm.h.

96 {
97 return execState( ctx ).filterPassed();
98 }
virtual bool filterPassed(const EventContext &ctx) const

◆ initialize()

StatusCode LArHitEMapToDigitAlg::initialize ( )
virtual

Definition at line 23 of file LArHitEMapToDigitAlg.cxx.

24{
25
27 ATH_MSG_ERROR("Requested Nsamples " << m_NSamples << " larger than max "
28 << s_MaxNSamples);
29 return StatusCode::FAILURE;
30 }
33
34 ATH_CHECK(m_shapeKey.initialize());
35 ATH_CHECK(m_fSamplKey.initialize());
36 ATH_CHECK(m_OFCKey.initialize());
37 ATH_CHECK(m_pedestalKey.initialize());
39 ATH_CHECK(m_bcContKey.initialize());
40 ATH_CHECK(m_badFebKey.initialize());
41 ATH_CHECK(m_adc2mevKey.initialize());
42 ATH_CHECK(m_caloMgrKey.initialize());
43
44 ATH_CHECK(m_cablingKey.initialize());
45
46 // helpers
47 //retrieve ID helpers
48 ATH_CHECK(detStore()->retrieve(m_calocell_id,"CaloCell_ID"));
49
50
51 const CaloIdManager* caloIdMgr = nullptr;
52 StatusCode sc = detStore()->retrieve(caloIdMgr);
53 if (sc.isFailure()) {
54 ATH_MSG_ERROR(" Unable to retrieve CaloIdManager from DetectoreStore");
55 return StatusCode::FAILURE;
56 }
57 m_larem_id = caloIdMgr->getEM_ID();
58 m_larhec_id = caloIdMgr->getHEC_ID();
59 m_larfcal_id = caloIdMgr->getFCAL_ID();
60
61 sc = detStore()->retrieve(m_laronline_id);
62 if (sc.isFailure()) {
63 ATH_MSG_ERROR(" Unable to retrieve LArOnlineId from DetectoreStore");
64 return StatusCode::FAILURE;
65 }
66 ATH_CHECK(m_bcMask.buildBitMask(m_problemsToMask,msg()));
67
68 // Services
69 ATH_CHECK(m_rndmGenSvc.retrieve());
70 ATH_CHECK(m_hitMapKey.initialize());
72
73 ATH_CHECK(m_DigitContainerName.initialize());
75
76 // Check consistency of gain-ranges and gain-switching thresholds:
77 std::array<std::pair<int,std::string>,4> iCaloToStr{{{EM,"EM"},{HEC,"HEC"},{FCAL,"FCAL"},{EMIW,"EMIW"}}};
78
79 for (int iCalo = EM; iCalo <= EMIW; ++iCalo) {
80 if ((m_gainRange[iCalo].value().first == CaloGain::LARHIGHGAIN) == (m_HighGainThresh[iCalo] != 0))
81 ATH_MSG_INFO("jobO consistency check: " << iCaloToStr[iCalo] << " has " << ((m_gainRange[iCalo].value().first == CaloGain::LARHIGHGAIN) ? "" : "no ")
82 << " HIGH gain and high Gain threshold=" << m_HighGainThresh[iCalo]);
83 else {
84 ATH_MSG_ERROR("jobO inconsistency! " << iCaloToStr[iCalo] << " has" << ((m_gainRange[iCalo].value().first == CaloGain::LARHIGHGAIN) ? "" : "no ")
85 << " HIGH gain but high Gain threshold=" << m_HighGainThresh[iCalo]);
86 return StatusCode::FAILURE;
87 }
88 if ((m_gainRange[iCalo].value().second == CaloGain::LARLOWGAIN) == (m_LowGainThresh[iCalo] <= m_maxADC))
89 ATH_MSG_INFO("jobO consistency check: Calo " << iCaloToStr[iCalo] << " has" << ((m_gainRange[iCalo].value().first == CaloGain::LARHIGHGAIN) ? "" : "no ")
90 << " LOW gain and high Gain threshold=" << m_LowGainThresh[iCalo] << " (maxADC=" << m_maxADC << ")");
91 else {
92 ATH_MSG_ERROR("jobO inconsistency! Calo " << iCaloToStr[iCalo] << " has" << ((m_gainRange[iCalo].value().first == CaloGain::LARHIGHGAIN) ? "" : "no ")
93 << " LOW gain but high Gain threshold=" << m_LowGainThresh[iCalo] << " (maxADC=" << m_maxADC << ")");
94 return StatusCode::FAILURE;
95 }
96
97 if (m_gainRange[iCalo].value().first == m_gainRange[iCalo].value().second) {
98 ATH_MSG_ERROR(" Calo " << iCaloToStr[iCalo] << " configured to have only one gain. This is not supported.");
99 return Status::FAILURE;
100 }
101 if (m_HighGainThresh[iCalo] >= m_LowGainThresh[iCalo] ) {
102 ATH_MSG_ERROR(" Calo " << iCaloToStr[iCalo] << " High gain threshold > low gain threshold! " << m_HighGainThresh[iCalo] << " >= " << m_LowGainThresh[iCalo]);
103 return Status::FAILURE;
104 }
105
106
107 } //end iCalo loop
108
109 return StatusCode::SUCCESS;
110}
const ServiceHandle< StoreGateSvc > & detStore() const
const LArHEC_ID * getHEC_ID(void) const
const LArFCAL_ID * getFCAL_ID(void) const
const LArEM_ID * getEM_ID(void) const
const LArHEC_ID * m_larhec_id
Gaudi::Property< std::vector< std::string > > m_problemsToMask
static constexpr int s_MaxNSamples
const LArFCAL_ID * m_larfcal_id
SG::ReadCondHandleKey< CaloDetDescrManager > m_caloMgrKey
SG::ReadCondHandleKey< ILArOFC > m_OFCKey
Gaudi::Property< unsigned > m_maxADC
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::inputHandles ( ) const
overridevirtualinherited

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.

◆ isClonable()

◆ MakeDigit()

StatusCode LArHitEMapToDigitAlg::MakeDigit ( const EventContext & ctx,
const Identifier & cellId,
const HWIdentifier & ch_id,
LArDigit *& Digit,
DataPool< LArDigit > & dataItemsPool,
LArDigit *& Digit_DigiHSTruth,
const std::vector< std::pair< float, float > > * TimeE,
const LArDigit * rndm_digit,
CLHEP::HepRandomEngine * engine,
const std::vector< std::pair< float, float > > * TimeE_DigiHSTruth,
const LArADC2MeV * adc2MeVs,
const ILArfSampl * fSampl,
const ILArPedestal * pedestal,
const ILArNoise * noise,
const LArAutoCorrNoise * autoCorrNoise,
const LArBadChannelCont * bcCont,
const ILArShape * shape ) const
protected

Definition at line 251 of file LArHitEMapToDigitAlg.cxx.

268 {
269
270 bool createDigit_DigiHSTruth = true;
271
272
273 int i;
274 short Adc;
275 short Adc_DigiHSTruth;
276
277 std::vector<short> AdcSample(m_NSamples);
278 std::vector<short> AdcSample_DigiHSTruth(m_NSamples);
279
280 float SF=1.;
281 float SigmaNoise;
282 staticVecFloat_t rndm_energy_samples(m_NSamples) ;
283
284 int iCalo = EM;
285 if (m_larem_id->is_lar_hec(cellId))
286 iCalo = HEC;
287 else if (m_larem_id->is_lar_fcal(cellId))
288 iCalo = FCAL;
289 else if (m_larem_id->is_em_endcap_inner(cellId))
290 iCalo = EMIW;
291
292 CaloGain::CaloGain initialGain=static_cast<CaloGain::CaloGain>(m_gainRange[iCalo].value().first);
294
295// ........ retrieve data (1/2) ................................
296//
297 SF=fSampl->FSAMPL(ch_id);
298
299//
300// ....... dump info ................................
301//
302#ifndef NDEBUG
303 ATH_MSG_DEBUG(" Cellid " << m_larem_id->show_to_string(cellId));
304 ATH_MSG_DEBUG(" SF: " << SF);
305#endif
306
307 staticVecDouble_t Samples;
308 staticVecDouble_t Samples_DigiHSTruth;
309 staticVecDouble_t Noise;
310 Samples.resize(m_NSamples,0);
311 if(m_doDigiTruth) Samples_DigiHSTruth.resize(m_NSamples,0);
312 Noise.resize(m_NSamples,0);
313
314//
315// ....... make the five samples
316//
317
318#ifndef NDEBUG
319 ATH_MSG_DEBUG(" number of hit for this cell " << TimeE->size());
320#endif
321
322//
323// convert Hits into energy samples and add result to Samples assuming LARHIGHGAIN for pulse shape
324//
325 bool isDead = m_bcMask.cellShouldBeMasked(bcCont,ch_id);
326
327
328 if (!isDead) {
329 if( this->ConvertHits2Samples(cellId,ch_id,initialGain,TimeE, Samples, shape).isFailure() ) {
330 return StatusCode::SUCCESS;
331 }
332 if(m_doDigiTruth && TimeE_DigiHSTruth){
333 if( this->ConvertHits2Samples(cellId,ch_id,initialGain,TimeE_DigiHSTruth, Samples_DigiHSTruth, shape).isFailure() ) {
334 return StatusCode::SUCCESS;
335 }
336 }
337 }
338
339//
340// .... add random event digit if needed
341//
342 float energy2adc ;
343 float rAdc ;
344 if(m_RndmEvtOverlay && rndmEvtDigit ) // no overlay if missing random digit
345 {
346 rndmGain= rndmEvtDigit->gain();
347 auto polynom_adc2mev =adc2MeVs->ADC2MEV(ch_id,rndmEvtDigit->gain());
348 if (polynom_adc2mev.size() > 1) {
349 float adc2energy = SF * polynom_adc2mev[1];
350 const std::vector<short> & rndm_digit_samples = rndmEvtDigit->samples() ;
351 float Pedestal = pedestal->pedestal(ch_id,rndmEvtDigit->gain());
352 if (Pedestal <= (1.0+LArElecCalib::ERRORCODE)) {
353 ATH_MSG_WARNING(" Pedestal not found in database for this channel offID " << cellId << " Use sample 0 for random");
354 Pedestal = rndm_digit_samples[0];
355 }
356 ATH_MSG_DEBUG(" Params for inverting LAr Digitization: pedestal " << Pedestal << " adc2energy " << adc2energy);
357
358// in case Medium or low gain, take into account ramp intercept in ADC->"energy" computation
359// this requires to take into account the sum of the optimal filter coefficients, as they don't compute with ADC shift
360 float adc0=0.;
361 if (!m_isMcOverlay && rndmEvtDigit->gain()>0) {
362 SG::ReadCondHandle<ILArOFC> larOFC(m_OFCKey, ctx);
363 if (larOFC.cptr() != nullptr) {
364 ILArOFC::OFCRef_t ofc_a = larOFC->OFC_a(ch_id,rndmEvtDigit->gain(),0);
365 float sumOfc=0.;
366 if (ofc_a.size()>0) {
367 for (unsigned int j=0;j<ofc_a.size();j++) sumOfc += ofc_a.at(j);
368 }
369 if (sumOfc>0) adc0 = polynom_adc2mev[0] * SF /sumOfc;
370 }
371 }
372
373 int nmax=m_NSamples;
374 if ((int)(rndm_digit_samples.size()) < m_NSamples) {
376 "Less digit Samples than requested in digitization for cell "
377 << ch_id.get_compact() << " Digit has " << rndm_digit_samples.size()
378 << " samples. Digitization request " << m_NSamples);
379 nmax = rndm_digit_samples.size();
380 }
381 for(i=0 ; i<nmax ; i++)
382 {
383 rAdc = (rndm_digit_samples[i] - Pedestal ) * adc2energy + adc0;
384 rndm_energy_samples[i] = rAdc ;
385 Samples[i] += rAdc ;
386 }
387 }
388 else {
389 ATH_MSG_WARNING(" No ramp found for this random cell " << m_larem_id->show_to_string(cellId) << " for gain " << rndmEvtDigit->gain());
390 }
391 }
392
393
394 CaloGain::CaloGain igain=chooseGain(Samples,ch_id,static_cast<CaloNum>(iCalo),pedestal,adc2MeVs,SF);
395 if (igain==CaloGain::INVALIDGAIN) {
396 return StatusCode::FAILURE;
397 }
398
399 // check that select gain is never lower (higher index number) than random gain in case of overlay
400 igain=std::max(rndmGain,igain);
401
402//
403// recompute Samples if igain != HIGHGAIN
404//
405 if (igain != initialGain ){
406 for (i=0;i<m_NSamples;i++) {
407 if(m_doDigiTruth) Samples_DigiHSTruth[i] = 0.;
408 if (m_RndmEvtOverlay) Samples[i]= rndm_energy_samples[i] ;
409 else Samples[i] = 0.;
410 }
411
412 if (!isDead) {
413 if( this->ConvertHits2Samples(cellId,ch_id,igain,TimeE, Samples, shape) == StatusCode::FAILURE ) {
414 return StatusCode::SUCCESS;
415 }
416 if(m_doDigiTruth){
417 if( this->ConvertHits2Samples(cellId,ch_id,igain,TimeE_DigiHSTruth, Samples_DigiHSTruth, shape) == StatusCode::FAILURE ) {
418 return StatusCode::SUCCESS;
419 }
420 }
421 }
422 }
423
424//
425// ........ add the noise ................................
426//
427
428 double Rndm[32]{};
429 int BvsEC=0;
430 if(iCalo==EM || iCalo==EMIW) BvsEC=std::abs(m_larem_id->barrel_ec(cellId));
431
432 bool addedNoise=false;
433 if (m_NoiseOnOff &&
434 ((BvsEC == 1 && m_NoiseInEMB) || (BvsEC > 1 && m_NoiseInEMEC) ||
435 (iCalo == HEC && m_NoiseInHEC) || (iCalo == FCAL && m_NoiseInFCAL)))
436 // add the noise only in the wanted sub-detectors
437 {
438 if (!m_RndmEvtOverlay) {
439 if (!m_pedestalNoise) {
440 SigmaNoise = noise->noise(ch_id, igain);
441 } else {
442 float noise = pedestal->pedestalRMS(ch_id, igain);
443 if (noise >= (1.0 + LArElecCalib::ERRORCODE))
444 SigmaNoise = noise;
445 else
446 SigmaNoise = 0.;
447 }
448 // Sqrt of noise covariance matrix
449 const std::vector<float>& CorGen =
450 autoCorrNoise->autoCorrSqrt(cellId, igain);
451 if (CorGen.size() < (unsigned)m_NSamples * m_NSamples) {
452 ATH_MSG_ERROR("Noise AutoCorr too small, need "
453 << m_NSamples * m_NSamples << " points for "
454 << m_NSamples << " samples.");
455 return StatusCode::FAILURE;
456 }
457
458 RandGaussZiggurat::shootArray(engine, m_NSamples, Rndm, 0., 1.);
459
460 int index;
461 for (int i = 0; i < m_NSamples; i++) {
462 Noise[i] = 0.;
463 for (int j = 0; j <= i; j++) {
464 index = i * m_NSamples + j;
465 Noise[i] += Rndm[j] * CorGen[index];
466 }
467 Noise[i] = Noise[i] * SigmaNoise;
468 }
469 addedNoise = true;
470 } else {
471 // overlay case a priori don't add any noise
472 for (int i = 0; i < m_NSamples; i++)
473 Noise[i] = 0.;
474 // if gain from zerobias events is < gain from mixed events => add extra
475 // noise to account for gain vs noise dependance
476 // done in a simple way without taking into account the time
477 // correlation of this extra noise properly
478 if (rndmEvtDigit) {
479 // if gain of cell is different from ZB event gain
480 if (igain > rndmEvtDigit->gain()) {
481 double SigmaNoiseZB = 0.; // noise in ZB event for gain of ZB event
482 double SigmaNoise = 0.; // noise expected for new gain value
483 double SigmaExtraNoise = 0.; // quadratic difference of noise values
484 if (!m_pedestalNoise) {
485 SigmaNoiseZB = noise->noise(ch_id, rndmEvtDigit->gain());
486 SigmaNoise = noise->noise(ch_id, igain);
487 } else {
488 float noise = pedestal->pedestalRMS(ch_id, rndmEvtDigit->gain());
489 if (noise >= (1.0 + LArElecCalib::ERRORCODE))
490 SigmaNoiseZB = noise;
491 else
492 SigmaNoiseZB = 0.;
493 noise = pedestal->pedestalRMS(ch_id, igain);
494 if (noise >= (1.0 + LArElecCalib::ERRORCODE))
495 SigmaNoise = noise;
496 else
497 SigmaNoise = 0.;
498 }
499 // Convert SigmaNoiseZB in noise in ADC counts for igain conversion
500 auto polynom_adc2mevZB =
501 adc2MeVs->ADC2MEV(cellId, rndmEvtDigit->gain());
502 auto polynom_adc2mev = adc2MeVs->ADC2MEV(cellId, igain);
503 if (polynom_adc2mevZB.size() > 1 && polynom_adc2mev.size() > 1) {
504 if (polynom_adc2mev[1] > 0.) {
505 SigmaNoiseZB = SigmaNoiseZB * (polynom_adc2mevZB[1]) /
506 (polynom_adc2mev[1]);
507 if (SigmaNoise > SigmaNoiseZB)
508 SigmaExtraNoise = sqrt(SigmaNoise * SigmaNoise -
509 SigmaNoiseZB * SigmaNoiseZB);
510 }
511 } // check that AC2MeV factors are there
512 RandGaussZiggurat::shootArray(engine, m_NSamples, Rndm, 0.,
513 1.); // generate noise
514 for (int i = 0; i < m_NSamples; i++)
515 Noise[i] = SigmaExtraNoise * Rndm[i];
516 addedNoise = true;
517 } // different gains
518 } // rndm Digit is there
519 } // rndm Overlay test
520 } // add noise ?
521 //
522// ......... convert into adc counts ................................
523//
524 float Pedestal = pedestal->pedestal(ch_id,igain);
525 if (Pedestal <= (1.0+LArElecCalib::ERRORCODE)) {
526 ATH_MSG_WARNING(" pedestal not found for cellId " << cellId << " assume 1000" );
527 Pedestal=1000.;
528 }
529 const auto polynom_adc2mev = adc2MeVs->ADC2MEV(cellId,igain);
530 if (polynom_adc2mev.size() < 2) {
531 ATH_MSG_WARNING(" No ramp found for requested gain " << igain << " for cell " << m_larem_id->show_to_string(cellId) << " no digit made...");
532 return StatusCode::SUCCESS;
533 }
534
535 energy2adc=1./(polynom_adc2mev[1])/SF;
536
537// in case Medium or low gain, take into account ramp intercept in energy->ADC computation
538// this requires to take into account the sum of the optimal filter coefficients, as they don't compute with ADC shift
539 if(!m_isMcOverlay && m_RndmEvtOverlay && igain>0)
540 {
541 SG::ReadCondHandle<ILArOFC> larOFC(m_OFCKey, ctx);
542 if (larOFC.cptr() != nullptr) {
543 float sumOfc=0.;
544 ILArOFC::OFCRef_t ofc_a = larOFC->OFC_a(ch_id,igain,0);
545 if (ofc_a.size()>0) {
546 for (unsigned int j=0;j<ofc_a.size();j++) sumOfc+= ofc_a.at(j);
547 }
548 if ((polynom_adc2mev[1])>0 && sumOfc>0) Pedestal = Pedestal - (polynom_adc2mev[0])/(polynom_adc2mev[1])/sumOfc;
549 ATH_MSG_DEBUG(" Params for final LAr Digitization gain: " << igain << " pedestal: " << Pedestal << " energy2adc: " << energy2adc);
550 }
551 }
552 for(i=0;i<m_NSamples;i++)
553 {
554 double xAdc;
555 double xAdc_DigiHSTruth = 0;
556
557 if ( addedNoise ){
558 xAdc = Samples[i]*energy2adc + Noise[i] + Pedestal + 0.5;
559 if(m_doDigiTruth) {
560 xAdc_DigiHSTruth = Samples_DigiHSTruth[i]*energy2adc + Noise[i] + Pedestal + 0.5;
561 }
562 }
563
564 else {
565 if (m_roundingNoNoise) {
566 float flatRndm = RandFlat::shoot(engine);
567 xAdc = Samples[i]*energy2adc + Pedestal + flatRndm;
568 if(m_doDigiTruth) {
569 xAdc_DigiHSTruth = Samples_DigiHSTruth[i]*energy2adc + Pedestal + flatRndm;
570 }
571
572 }
573 else{
574 xAdc = Samples[i]*energy2adc + Pedestal + 0.5;
575 if(m_doDigiTruth) {
576 xAdc_DigiHSTruth = Samples_DigiHSTruth[i]*energy2adc + Pedestal + 0.5;
577 }
578 }
579
580 }
581
582//
583// ........ truncate at maximum value + 1
584// add possibility to saturate at 0 for negative signals
585//
586 if (xAdc <0) Adc=0;
587 else if (xAdc >= m_maxADC) Adc=m_maxADC;
588 else Adc = (short) xAdc;
589
590 AdcSample[i]=Adc;
591
592 if(m_doDigiTruth){
593 if (xAdc_DigiHSTruth <0) Adc_DigiHSTruth=0;
594 else if (xAdc_DigiHSTruth >= m_maxADC) Adc_DigiHSTruth=m_maxADC;
595 else Adc_DigiHSTruth = (short) xAdc_DigiHSTruth;
596 AdcSample_DigiHSTruth[i] = Adc_DigiHSTruth;
597 }
598
599#ifndef NDEBUG
600 ATH_MSG_DEBUG(" Sample " << i << " Energy= " << Samples[i] << " Adc=" << Adc);
601#endif
602
603 }
604
605//
606// ...... create the LArDigit .............
607//
608 Digit = dataItemsPool.nextElementPtr();
609 (*Digit)=LArDigit(ch_id,igain,std::move(AdcSample));
610
611 if (m_doDigiTruth && createDigit_DigiHSTruth) {
612 createDigit_DigiHSTruth = false;
613 Digit_DigiHSTruth = nullptr;
614
615 for (int i = 0; i < m_NSamples; i++) {
616 if (Samples_DigiHSTruth[i] != 0)
617 createDigit_DigiHSTruth = true;
618 }
619
620 Digit_DigiHSTruth =
621 new LArDigit(ch_id, igain, std::move(AdcSample_DigiHSTruth));
622 }
623
624 return StatusCode::SUCCESS;
625}
const int nmax(200)
pointer nextElementPtr()
obtain the next available element in pool by pointer pool is resized if its limit has been reached On...
LArVectorProxy OFCRef_t
This class defines the interface for accessing Optimal Filtering coefficients for each channel provid...
Definition ILArOFC.h:26
virtual float pedestal(const HWIdentifier &id, int gain) const =0
virtual float pedestalRMS(const HWIdentifier &id, int gain) const =0
access to RMS of Pedestal index by Identifier, and gain setting
virtual const float & FSAMPL(const HWIdentifier &id) const =0
value_type get_compact() const
Get the compact id.
const LArVectorProxy ADC2MEV(const HWIdentifier &id, int gain) const
Definition LArADC2MeV.h:32
const std::vector< float > & autoCorrSqrt(const HWIdentifier &id, int gain) const
Gaudi::Property< bool > m_NoiseInEMEC
StatusCode ConvertHits2Samples(const Identifier &cellId, HWIdentifier ch_id, CaloGain::CaloGain igain, const std::vector< std::pair< float, float > > *TimeE, staticVecDouble_t &sampleList, const ILArShape *shape) const
Gaudi::Property< bool > m_roundingNoNoise
Gaudi::Property< bool > m_NoiseInEMB
Gaudi::Property< bool > m_NoiseInHEC
boost::container::static_vector< double, s_MaxNSamples > staticVecDouble_t
CaloGain::CaloGain chooseGain(const staticVecDouble_t &samples, const HWIdentifier id, const CaloNum iCalo, const ILArPedestal *ped, const LArADC2MeV *ramp, const float SF) const
boost::container::static_vector< float, s_MaxNSamples > staticVecFloat_t
Gaudi::Property< bool > m_NoiseInFCAL
value_type at(size_t i) const
Vector indexing with bounds check.
str index
Definition DeMoScan.py:362
const float SF[NF]
Cross sections for Fluor.

◆ msg()

MsgStream & AthCommonMsg< Gaudi::Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msgLvl()

bool AthCommonMsg< Gaudi::Algorithm >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::outputHandles ( ) const
overridevirtualinherited

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.

◆ pointerFromKey()

template<class T>
const T * LArHitEMapToDigitAlg::pointerFromKey ( const EventContext & context,
const SG::ReadCondHandleKey< T > & key ) const
protected

Definition at line 214 of file LArHitEMapToDigitAlg.h.

214 {
215 SG::ReadCondHandle<T> aHandle(key, context);
216 const T* object = *aHandle;
217 if (object == nullptr) ATH_MSG_ERROR("Object could not be fetched with key " << aHandle.key() );
218 return object;
219}
unsigned long long T

◆ renounce()

std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
384 }
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce(T &h)

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ setFilterPassed()

virtual void AthCommonReentrantAlgorithm< Gaudi::Algorithm >::setFilterPassed ( bool state,
const EventContext & ctx ) const
inlinevirtualinherited

Definition at line 100 of file AthCommonReentrantAlgorithm.h.

100 {
102 }
virtual void setFilterPassed(bool state, const EventContext &ctx) const

◆ sysExecute()

StatusCode AthCommonReentrantAlgorithm< Gaudi::Algorithm >::sysExecute ( const EventContext & ctx)
overridevirtualinherited

Execute an algorithm.

We override this in order to work around an issue with the Algorithm base class storing the event context in a member variable that can cause crashes in MT jobs.

Definition at line 85 of file AthCommonReentrantAlgorithm.cxx.

77{
78 return BaseAlg::sysExecute (ctx);
79}

◆ sysInitialize()

StatusCode AthCommonReentrantAlgorithm< Gaudi::Algorithm >::sysInitialize ( )
overridevirtualinherited

Override sysInitialize.

Override sysInitialize from the base class.

Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc

Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc

Reimplemented from AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >.

Reimplemented in HypoBase, and InputMakerBase.

Definition at line 61 of file AthCommonReentrantAlgorithm.cxx.

107 {
109
110 if (sc.isFailure()) {
111 return sc;
112 }
113
114 ServiceHandle<ICondSvc> cs("CondSvc",name());
115 for (auto h : outputHandles()) {
116 if (h->isCondition() && h->mode() == Gaudi::DataHandle::Writer) {
117 // do this inside the loop so we don't create the CondSvc until needed
118 if ( cs.retrieve().isFailure() ) {
119 ATH_MSG_WARNING("no CondSvc found: won't autoreg WriteCondHandles");
120 return StatusCode::SUCCESS;
121 }
122 if (cs->regHandle(this,*h).isFailure()) {
124 ATH_MSG_ERROR("unable to register WriteCondHandle " << h->fullKey()
125 << " with CondSvc");
126 }
127 }
128 }
129 return sc;
130}
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }

Member Data Documentation

◆ m_adc2mevKey

SG::ReadCondHandleKey<LArADC2MeV> LArHitEMapToDigitAlg::m_adc2mevKey {this,"ADC2MeVKey","LArADC2MeV","SG Key of ADC2MeV conditions object"}
protected

Definition at line 109 of file LArHitEMapToDigitAlg.h.

109{this,"ADC2MeVKey","LArADC2MeV","SG Key of ADC2MeV conditions object"};

◆ m_autoCorrNoiseKey

SG::ReadCondHandleKey<LArAutoCorrNoise> LArHitEMapToDigitAlg::m_autoCorrNoiseKey {this,"AutoCorrNoiseKey","LArAutoCorrNoise","SG Key of AutoCorrNoise conditions object"}
protected

Definition at line 113 of file LArHitEMapToDigitAlg.h.

113{this,"AutoCorrNoiseKey","LArAutoCorrNoise","SG Key of AutoCorrNoise conditions object"};

◆ m_badFebKey

SG::ReadCondHandleKey<LArBadFebCont> LArHitEMapToDigitAlg::m_badFebKey {this, "BadFebKey", "LArBadFeb", "Key of BadFeb object in ConditionsStore"}
protected

Definition at line 116 of file LArHitEMapToDigitAlg.h.

116{this, "BadFebKey", "LArBadFeb", "Key of BadFeb object in ConditionsStore"};

◆ m_bcContKey

SG::ReadCondHandleKey<LArBadChannelCont> LArHitEMapToDigitAlg::m_bcContKey {this, "BadChanKey", "LArBadChannel", "SG key for LArBadChan object"}
protected

Definition at line 115 of file LArHitEMapToDigitAlg.h.

115{this, "BadChanKey", "LArBadChannel", "SG key for LArBadChan object"};

◆ m_bcMask

LArBadChannelMask LArHitEMapToDigitAlg::m_bcMask
protected

Definition at line 118 of file LArHitEMapToDigitAlg.h.

◆ m_cabling

const LArOnOffIdMapping* LArHitEMapToDigitAlg::m_cabling {}
protected

Definition at line 111 of file LArHitEMapToDigitAlg.h.

111{}; //Set in perpareEvent, used also in mergeEvent

◆ m_cablingKey

SG::ReadCondHandleKey<LArOnOffIdMapping> LArHitEMapToDigitAlg::m_cablingKey {this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"}
protected

Definition at line 110 of file LArHitEMapToDigitAlg.h.

110{this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"};

◆ m_calocell_id

const CaloCell_ID* LArHitEMapToDigitAlg::m_calocell_id {}
protected

Definition at line 205 of file LArHitEMapToDigitAlg.h.

205{};

◆ m_caloMgrKey

SG::ReadCondHandleKey<CaloDetDescrManager> LArHitEMapToDigitAlg::m_caloMgrKey {this,"CaloDetDescrManager", "CaloDetDescrManager"}
protected

Definition at line 120 of file LArHitEMapToDigitAlg.h.

120{this,"CaloDetDescrManager", "CaloDetDescrManager"};

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_DigitContainerName

SG::WriteHandleKey<LArDigitContainer> LArHitEMapToDigitAlg::m_DigitContainerName
protected
Initial value:
{this, "DigitContainer", "LArDigitContainer_MC",
"Name of output digit container"}

Definition at line 128 of file LArHitEMapToDigitAlg.h.

128 {this, "DigitContainer", "LArDigitContainer_MC",
129 "Name of output digit container"}; // output digit container name list

◆ m_DigitContainerName_DigiHSTruth

SG::WriteHandleKey<LArDigitContainer> LArHitEMapToDigitAlg::m_DigitContainerName_DigiHSTruth
protected
Initial value:
{this, "DigitContainer_DigiHSTruth",
"LArDigitContainer_DigiHSTruth", "Name of output signal digit container"}

Definition at line 130 of file LArHitEMapToDigitAlg.h.

130 {this, "DigitContainer_DigiHSTruth",
131 "LArDigitContainer_DigiHSTruth", "Name of output signal digit container"}; // output digit container name list

◆ m_doDigiTruth

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_doDigiTruth
protected
Initial value:
{this, "DoDigiTruthReconstruction", false,
"Also create information about reconstructed digits for HS hits"}

Definition at line 180 of file LArHitEMapToDigitAlg.h.

180 {this, "DoDigiTruthReconstruction", false,
181 "Also create information about reconstructed digits for HS hits"};

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_extendedExtraObjects

DataObjIDColl AthCommonReentrantAlgorithm< Gaudi::Algorithm >::m_extendedExtraObjects
privateinherited

Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.

Empty if no symlinks were found.

Definition at line 114 of file AthCommonReentrantAlgorithm.h.

◆ m_firstSample

Gaudi::Property<int> LArHitEMapToDigitAlg::m_firstSample
protected
Initial value:
{this, "firstSample", 0,
"First sample to use for the shape for in-time signal"}

Definition at line 172 of file LArHitEMapToDigitAlg.h.

172 {this, "firstSample", 0,
173 "First sample to use for the shape for in-time signal"}; // first sample to use for pulse shape for in time energy deposit (use a negative value to include preceeding digits)

◆ m_fSamplKey

SG::ReadCondHandleKey<ILArfSampl> LArHitEMapToDigitAlg::m_fSamplKey {this,"fSamplKey","LArfSamplSym","SG Key of LArfSampl object"}
protected

Definition at line 105 of file LArHitEMapToDigitAlg.h.

105{this,"fSamplKey","LArfSamplSym","SG Key of LArfSampl object"};

◆ m_gainRange

std::array<Gaudi::Property<std::pair<int,int> >,4> LArHitEMapToDigitAlg::m_gainRange
protected
Initial value:
{{
{this,"GainRangeEM",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
{this,"GainRangeHEC",{CaloGain::LARMEDIUMGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
{this,"GainRangeFCAL",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
{this,"GainRangeEMECIW",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
}}
@ LARMEDIUMGAIN
Definition CaloGain.h:18

Definition at line 158 of file LArHitEMapToDigitAlg.h.

158 {{
159 {this,"GainRangeEM",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
160 {this,"GainRangeHEC",{CaloGain::LARMEDIUMGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
161 {this,"GainRangeFCAL",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
162 {this,"GainRangeEMECIW",{CaloGain::LARHIGHGAIN,CaloGain::LARLOWGAIN},"Range of gains"},
163 }};

◆ m_HighGainThresh

std::array<Gaudi::Property<double>,4> LArHitEMapToDigitAlg::m_HighGainThresh
protected
Initial value:
{{
{this,"HighGainThreshEM",1300,"ADC counts in medium gain"},
{this,"HighGainThreshHEC",0,"ADC counts in medium gain"},
{this,"HighGainThreshFCAL",1100,"ADC counts in medium gain"},
{this,"HighGainThreshEMECIW",1300,"ADC counts in medium gain"}
}}

Definition at line 149 of file LArHitEMapToDigitAlg.h.

149 {{
150 {this,"HighGainThreshEM",1300,"ADC counts in medium gain"},
151 {this,"HighGainThreshHEC",0,"ADC counts in medium gain"},
152 {this,"HighGainThreshFCAL",1100,"ADC counts in medium gain"},
153 {this,"HighGainThreshEMECIW",1300,"ADC counts in medium gain"}
154 }};

◆ m_hitMapKey

SG::ReadHandleKey<LArHitEMap> LArHitEMapToDigitAlg::m_hitMapKey {this,"LArHitEMapKey","LArHitEMap"}
protected

Definition at line 123 of file LArHitEMapToDigitAlg.h.

123{this,"LArHitEMapKey","LArHitEMap"};

◆ m_hitMapKey_DigiHSTruth

SG::ReadHandleKey<LArHitEMap> LArHitEMapToDigitAlg::m_hitMapKey_DigiHSTruth {this,"LArHitEMap_DigiHSTruthKey","LArHitEMap_DigiHSTruth"}
protected

Definition at line 124 of file LArHitEMapToDigitAlg.h.

124{this,"LArHitEMap_DigiHSTruthKey","LArHitEMap_DigiHSTruth"};

◆ m_inputDigitContainerKey

SG::ReadHandleKey<LArDigitContainer> LArHitEMapToDigitAlg::m_inputDigitContainerKey
protected
Initial value:
{this, "InputDigitContainer", "",
"Name of input digit container"}

Definition at line 125 of file LArHitEMapToDigitAlg.h.

125 {this, "InputDigitContainer", "",
126 "Name of input digit container"}; // input digit container name

◆ m_isMcOverlay

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_isMcOverlay
protected
Initial value:
{this, "isMcOverlay", false,
"Is input Overlay from MC or data (default=false, from data)"}

Definition at line 178 of file LArHitEMapToDigitAlg.h.

178 {this, "isMcOverlay", false,
179 "Is input Overlay from MC or data (default=false, from data)"}; // true if input RDO for overlay are from MC, false if from data

◆ m_larem_id

const LArEM_ID* LArHitEMapToDigitAlg::m_larem_id {}
protected

Definition at line 206 of file LArHitEMapToDigitAlg.h.

206{};

◆ m_larfcal_id

const LArFCAL_ID* LArHitEMapToDigitAlg::m_larfcal_id {}
protected

Definition at line 208 of file LArHitEMapToDigitAlg.h.

208{};

◆ m_larhec_id

const LArHEC_ID* LArHitEMapToDigitAlg::m_larhec_id {}
protected

Definition at line 207 of file LArHitEMapToDigitAlg.h.

207{};

◆ m_laronline_id

const LArOnlineID* LArHitEMapToDigitAlg::m_laronline_id {}
protected

Definition at line 209 of file LArHitEMapToDigitAlg.h.

209{};

◆ m_LowGainThresh

std::array<Gaudi::Property<double>,4> LArHitEMapToDigitAlg::m_LowGainThresh
protected
Initial value:
{{
{this,"LowGainThreshEM",3900,"ADC counts in medium gain"},
{this,"LowGainThreshHEC",2500,"ADC counts in medium gain"},
{this,"LowGainThreshFCAL",2000,"ADC counts in medium gain"},
{this,"LowGainThreshEMECIW",3900,"ADC counts in medium gain"}
}}

Definition at line 141 of file LArHitEMapToDigitAlg.h.

141 {{
142 {this,"LowGainThreshEM",3900,"ADC counts in medium gain"},
143 {this,"LowGainThreshHEC",2500,"ADC counts in medium gain"},
144 {this,"LowGainThreshFCAL",2000,"ADC counts in medium gain"},
145 {this,"LowGainThreshEMECIW",3900,"ADC counts in medium gain"}
146 }};

◆ m_maxADC

Gaudi::Property<unsigned> LArHitEMapToDigitAlg::m_maxADC {this,"maxADC",4096,"Maxium ADC value +1 (for overflow)"}
protected

Definition at line 165 of file LArHitEMapToDigitAlg.h.

165{this,"maxADC",4096,"Maxium ADC value +1 (for overflow)"};

◆ m_NoiseInEMB

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_NoiseInEMB
protected
Initial value:
{this, "NoiseInEMB", true,
"put noise in EMB (default=true)"}

Definition at line 183 of file LArHitEMapToDigitAlg.h.

183 {this, "NoiseInEMB", true,
184 "put noise in EMB (default=true)"}; // noise in Barrel is off if false

◆ m_NoiseInEMEC

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_NoiseInEMEC
protected
Initial value:
{this, "NoiseInEMEC", true,
"put noise in EMEC (default=true)"}

Definition at line 185 of file LArHitEMapToDigitAlg.h.

185 {this, "NoiseInEMEC", true,
186 "put noise in EMEC (default=true)"}; // noise in EndCap is off if false

◆ m_NoiseInFCAL

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_NoiseInFCAL
protected
Initial value:
{this, "NoiseInFCAL", true,
"put noise in FCAL (default=true)"}

Definition at line 189 of file LArHitEMapToDigitAlg.h.

189 {this, "NoiseInFCAL", true,
190 "put noise in FCAL (default=true)"}; // noise in FCAL is off if false

◆ m_NoiseInHEC

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_NoiseInHEC
protected
Initial value:
{this, "NoiseInHEC", true,
"put noise in HEC (default=true)"}

Definition at line 187 of file LArHitEMapToDigitAlg.h.

187 {this, "NoiseInHEC", true,
188 "put noise in HEC (default=true)"}; // noise in HEC is off if false

◆ m_noiseKey

SG::ReadCondHandleKey<ILArNoise> LArHitEMapToDigitAlg::m_noiseKey {this,"NoiseKey","LArNoiseSym","SG Key of ILArNoise object"}
protected

Definition at line 104 of file LArHitEMapToDigitAlg.h.

104{this,"NoiseKey","LArNoiseSym","SG Key of ILArNoise object"};

◆ m_NoiseOnOff

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_NoiseOnOff
protected
Initial value:
{this, "NoiseOnOff", true,
"put electronic noise (default=true)"}

Definition at line 170 of file LArHitEMapToDigitAlg.h.

170 {this, "NoiseOnOff", true,
171 "put electronic noise (default=true)"}; // noise (in all sub-detectors) is on if true

◆ m_NSamples

Gaudi::Property<int> LArHitEMapToDigitAlg::m_NSamples
protected
Initial value:
{this, "Nsamples", 5,
"Number of ADC samples (default=5)"}

Definition at line 168 of file LArHitEMapToDigitAlg.h.

168 {this, "Nsamples", 5,
169 "Number of ADC samples (default=5)"}; // number of samples in Digit

◆ m_OFCKey

SG::ReadCondHandleKey<ILArOFC> LArHitEMapToDigitAlg::m_OFCKey {this, "OFCKey", "LArOFC", "SG Key of OFC conditions object"}
protected

Definition at line 106 of file LArHitEMapToDigitAlg.h.

106{this, "OFCKey", "LArOFC", "SG Key of OFC conditions object"};

◆ m_pedestalKey

SG::ReadCondHandleKey<ILArPedestal> LArHitEMapToDigitAlg::m_pedestalKey {this,"PedestalKey","LArPedestal","SG Key of LArPedestal object"}
protected

Definition at line 107 of file LArHitEMapToDigitAlg.h.

107{this,"PedestalKey","LArPedestal","SG Key of LArPedestal object"};

◆ m_pedestalNoise

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_pedestalNoise
protected
Initial value:
{this, "PedestalNoise", false,
"Use noise from Pedestal structure instead of LArNoise (default=false)"}

Definition at line 191 of file LArHitEMapToDigitAlg.h.

191 {this, "PedestalNoise", false,
192 "Use noise from Pedestal structure instead of LArNoise (default=false)"};

◆ m_problemsToMask

Gaudi::Property<std::vector<std::string> > LArHitEMapToDigitAlg::m_problemsToMask {this,"ProblemsToMask",{},"Bad-Channel categories to mask entirly"}
protected

Definition at line 117 of file LArHitEMapToDigitAlg.h.

117{this,"ProblemsToMask",{},"Bad-Channel categories to mask entirly"};

◆ m_randomSeedOffset

Gaudi::Property<uint32_t> LArHitEMapToDigitAlg::m_randomSeedOffset {this, "RandomSeedOffset", 2, ""}
protected

Definition at line 136 of file LArHitEMapToDigitAlg.h.

136{this, "RandomSeedOffset", 2, ""}; //

◆ m_randomStreamName

Gaudi::Property<std::string> LArHitEMapToDigitAlg::m_randomStreamName {this, "RandomStreamName", "LArDigitization", ""}
protected

Definition at line 132 of file LArHitEMapToDigitAlg.h.

132{this, "RandomStreamName", "LArDigitization", ""};

◆ m_RndmEvtOverlay

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_RndmEvtOverlay
protected
Initial value:
{this, "RndmEvtOverlay", false,
"Pileup and/or noise added by overlaying random events (default=false)"}

Definition at line 176 of file LArHitEMapToDigitAlg.h.

176 {this, "RndmEvtOverlay", false,
177 "Pileup and/or noise added by overlaying random events (default=false)"}; // Pileup and noise added by overlaying random events

◆ m_rndmGenSvc

ServiceHandle<IAthRNGSvc> LArHitEMapToDigitAlg::m_rndmGenSvc {this, "RndmSvc", "AthRNGSvc", ""}
protected

Definition at line 135 of file LArHitEMapToDigitAlg.h.

135{this, "RndmSvc", "AthRNGSvc", ""};

◆ m_roundingNoNoise

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_roundingNoNoise
protected
Initial value:
{this, "RoundingNoNoise", true,
"if true add random number [0:1[ in no noise case before rounding ADC to integer, if false add only 0.5 average"}

Definition at line 193 of file LArHitEMapToDigitAlg.h.

193 {this, "RoundingNoNoise", true,
194 "if true add random number [0:1[ in no noise case before rounding ADC to integer, if false add only 0.5 average"}; // flag used in NoNoise case: if true add random number [0;1[ in ADC count, if false add only average of 0.5

◆ m_shapeKey

SG::ReadCondHandleKey<ILArShape> LArHitEMapToDigitAlg::m_shapeKey {this,"ShapeKey","LArShapeSym","SG Key of LArShape object"}
protected

Definition at line 108 of file LArHitEMapToDigitAlg.h.

108{this,"ShapeKey","LArShapeSym","SG Key of LArShape object"};

◆ m_useLegacyRandomSeeds

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_useLegacyRandomSeeds
protected
Initial value:
{this, "UseLegacyRandomSeeds", false,
"Use MC16-style random number seeding"}

Definition at line 137 of file LArHitEMapToDigitAlg.h.

137 {this, "UseLegacyRandomSeeds", false,
138 "Use MC16-style random number seeding"};

◆ m_usePhase

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_usePhase
protected
Initial value:
{this, "UsePhase", false,
"use 1ns binned pulse shape (default=false)"}

Definition at line 174 of file LArHitEMapToDigitAlg.h.

174 {this, "UsePhase", false,
175 "use 1ns binned pulse shape (default=false)"}; // use tbin phase to get shape (default = false for Atlas)

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.

◆ m_Windows

Gaudi::Property<bool> LArHitEMapToDigitAlg::m_Windows
protected
Initial value:
{this, "Windows", false,
"Window mode (produce digits only around true e/photon) (default=false)"}

Definition at line 195 of file LArHitEMapToDigitAlg.h.

195 {this, "Windows", false,
196 "Window mode (produce digits only around true e/photon) (default=false)"};

◆ m_WindowsEtaSize

Gaudi::Property<float> LArHitEMapToDigitAlg::m_WindowsEtaSize
protected
Initial value:
{this, "WindowsEtaSize", 0.4,
"Eta size of window (default=0.4)"}

Definition at line 197 of file LArHitEMapToDigitAlg.h.

197 {this, "WindowsEtaSize", 0.4,
198 "Eta size of window (default=0.4)"};

◆ m_WindowsPhiSize

Gaudi::Property<float> LArHitEMapToDigitAlg::m_WindowsPhiSize
protected
Initial value:
{this, "WindowsPhiSize", 0.5,
"Phi size of window (default=0.5)"}

Definition at line 199 of file LArHitEMapToDigitAlg.h.

199 {this, "WindowsPhiSize", 0.5,
200 "Phi size of window (default=0.5)"};

◆ m_WindowsPtCut

Gaudi::Property<float> LArHitEMapToDigitAlg::m_WindowsPtCut
protected
Initial value:
{this, "WindowsPtCut", 5000.,
"Pt cut on e/photons for window mode (Default=5GeV)"}

Definition at line 201 of file LArHitEMapToDigitAlg.h.

201 {this, "WindowsPtCut", 5000.,
202 "Pt cut on e/photons for window mode (Default=5GeV)"};

◆ s_MaxNSamples

int LArHitEMapToDigitAlg::s_MaxNSamples = 32
staticconstexprprotected

Definition at line 70 of file LArHitEMapToDigitAlg.h.


The documentation for this class was generated from the following files: