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

#include <FEI3SimTool.h>

Inheritance diagram for FEI3SimTool:
Collaboration diagram for FEI3SimTool:

Public Member Functions

 FEI3SimTool (const std::string &type, const std::string &name, const IInterface *parent)
virtual StatusCode initialize ()
virtual StatusCode finalize ()
virtual ~FEI3SimTool ()
virtual void process (SiChargedDiodeCollection &chargedDiodes, PixelRDO_Collection &rdoCollection, CLHEP::HepRandomEngine *rndmEngine) 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 sysInitialize () override
 Perform system initialization for an algorithm.
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

Static Public Member Functions

static const InterfaceID & interfaceID ()

Protected Member Functions

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

int m_numberOfBcid {1}
double m_timeOffset {5.0}
double m_timeJitter {0.0}
double m_thermalNoise {160.0}
ToolHandle< IInDetConditionsToolm_pixelConditionsTool
ServiceHandle< InDetDD::IPixelReadoutManagerm_pixelReadout
SG::ReadCondHandleKey< PixelChargeCalibCondDatam_chargeDataKey
Gaudi::Property< int > m_BarrelEC
Gaudi::Property< bool > m_doNoise
Gaudi::Property< bool > m_cosmics

Static Protected Attributes

static constexpr double m_bunchSpace {25.0}

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

int relativeBunch2009 (const double threshold, const double intimethreshold, const SiTotalCharge &totalCharge, CLHEP::HepRandomEngine *rndmEngine) const
double getProbability (const std::vector< float > &bounds, const std::vector< float > &probs, const double &val) const
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

SG::ReadCondHandleKey< PixelModuleDatam_moduleDataKey
Gaudi::Property< bool > m_duplication
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 26 of file FEI3SimTool.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ FEI3SimTool()

FEI3SimTool::FEI3SimTool ( const std::string & type,
const std::string & name,
const IInterface * parent )

Definition at line 23 of file FEI3SimTool.cxx.

23 :
24 FrontEndSimTool(type, name, parent) {
25}

◆ ~FEI3SimTool()

FEI3SimTool::~FEI3SimTool ( )
virtualdefault

Member Function Documentation

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< AlgTool > >::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< AlgTool > >::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< AlgTool > >::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< AlgTool > >::evtStore ( )
inlineinherited

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

Definition at line 85 of file AthCommonDataStore.h.

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::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

◆ finalize()

StatusCode FEI3SimTool::finalize ( )
virtual

Reimplemented from FrontEndSimTool.

Definition at line 36 of file FEI3SimTool.cxx.

36 {
37 ATH_MSG_DEBUG("FEI3SimTool::finalize()");
38 return StatusCode::SUCCESS;
39}
#define ATH_MSG_DEBUG(x)

◆ getProbability()

double FEI3SimTool::getProbability ( const std::vector< float > & bounds,
const std::vector< float > & probs,
const double & val ) const
private

Definition at line 256 of file FEI3SimTool.cxx.

256 {
257 auto pCategory = std::upper_bound(bounds.begin(), bounds.end(),val);
258 if (pCategory == bounds.end()) return 0.0;
259 auto idx = std::distance(bounds.begin(), pCategory);
260 return probs[idx];
261}

◆ initialize()

StatusCode FEI3SimTool::initialize ( )
virtual

Reimplemented from FrontEndSimTool.

Definition at line 29 of file FEI3SimTool.cxx.

29 {
31 ATH_MSG_DEBUG("FEI3SimTool::initialize()");
32 ATH_CHECK(m_moduleDataKey.initialize());
33 return StatusCode::SUCCESS;
34}
#define ATH_CHECK
Evaluate an expression and check for errors.
SG::ReadCondHandleKey< PixelModuleData > m_moduleDataKey
Definition FEI3SimTool.h:36
virtual StatusCode initialize() override

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< AlgTool > >::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.

◆ interfaceID()

const InterfaceID & FrontEndSimTool::interfaceID ( )
inlinestaticinherited

Definition at line 35 of file FrontEndSimTool.h.

static const InterfaceID IID_IFrontEndSimTool("FrontEndSimTool", 1, 0)

◆ msg()

MsgStream & AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

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

◆ msgLvl()

bool AthCommonMsg< AlgTool >::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< AlgTool > >::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.

◆ process()

void FEI3SimTool::process ( SiChargedDiodeCollection & chargedDiodes,
PixelRDO_Collection & rdoCollection,
CLHEP::HepRandomEngine * rndmEngine ) const
virtual

Implements FrontEndSimTool.

Definition at line 41 of file FEI3SimTool.cxx.

42 {
43 const InDetDD::PixelModuleDesign* p_design =
44 static_cast<const InDetDD::PixelModuleDesign*>(&(chargedDiodes.element())->design());
45
47 return;
48 }
49
50 const PixelID* pixelId = static_cast<const PixelID*>(chargedDiodes.element()->getIdHelper());
51 const IdentifierHash moduleHash = pixelId->wafer_hash(chargedDiodes.identify()); // wafer hash
52 Identifier moduleID = pixelId->wafer_id(chargedDiodes.element()->identify());
53
54 int barrel_ec = pixelId->barrel_ec(chargedDiodes.element()->identify());
55 int layerIndex = pixelId->layer_disk(chargedDiodes.element()->identify());
56 int moduleIndex = pixelId->eta_module(chargedDiodes.element()->identify());
57
58 if (std::abs(barrel_ec) != m_BarrelEC) {
59 return;
60 }
61
62 const EventContext& ctx{Gaudi::Hive::currentContext()};
63 SG::ReadCondHandle<PixelModuleData> moduleDataHandle(m_moduleDataKey, ctx);
64 const PixelModuleData *moduleData = *moduleDataHandle;
65 SG::ReadCondHandle<PixelChargeCalibCondData> calibDataHandle(m_chargeDataKey, ctx);
66 const PixelChargeCalibCondData *calibData = *calibDataHandle;
67 const auto selectedTuneYear = moduleData->getFEI3TimingSimTune(barrel_ec, layerIndex);
68 // Add cross-talk
69 crossTalk(moduleData->getCrossTalk(barrel_ec, layerIndex), chargedDiodes);
70
71 if (m_doNoise) {
72 // Add thermal noise
73 thermalNoise(m_thermalNoise, chargedDiodes, rndmEngine);
74
75 // Add random noise
76 randomNoise(chargedDiodes, moduleData, m_numberOfBcid, calibData, rndmEngine, m_pixelReadout.get());
77 }
78
79 // Add random diabled pixels
80 randomDisable(chargedDiodes, moduleData, rndmEngine); // FIXME How should we handle disabling pixels in Overlay jobs?
81 const InDetDD::SiDetectorElement * siDetEl = static_cast<const InDetDD::SiDetectorElement *>(chargedDiodes.element());
82 for (auto &[mapId,mapDiode]:chargedDiodes) {
83 // Merge ganged pixel
84 InDetDD::SiCellId cellID = chargedDiodes.element()->cellIdFromIdentifier(chargedDiodes.getId( mapId));
85 InDetDD::SiCellId gangedCell = siDetEl->gangedCell(cellID);
86 Identifier gangedID = chargedDiodes.element()->identifierFromCellId(gangedCell);
87 if (gangedCell.isValid()) {
88 SiChargedDiode* gangedChargeDiode = chargedDiodes.find(gangedID);
89 int phiGanged = pixelId->phi_index(gangedID);
90 int phiThis = pixelId->phi_index(chargedDiodes.getId( mapId));
91
92 if (gangedChargeDiode) { // merge charges
93 bool maskGanged = ((phiGanged > 159) && (phiGanged < 168));
94 bool maskThis = ((phiThis > 159) && (phiThis < 168));
95 // mask the one ganged pixel that does not correspond to the readout electronics.
96 // not really sure this is needed
97 if (maskGanged && maskThis) {
98 ATH_MSG_ERROR("FEI3SimTool: both ganged pixels are in the mask out region -> BUG!");
99 }
100 if (maskGanged) {
101 mapDiode.add(gangedChargeDiode->totalCharge()); // merged org pixel
102 SiHelper::maskOut(*gangedChargeDiode, true);
103 } else {
104 gangedChargeDiode->add(mapDiode.totalCharge()); // merged org pixel
105 SiHelper::maskOut(mapDiode, true);
106 }
107 }
108 }
109 }
110
111 for (SiChargedDiodeOrderedIterator i_chargedDiode = chargedDiodes.orderedBegin();
112 i_chargedDiode != chargedDiodes.orderedEnd(); ++i_chargedDiode) {
113 SiChargedDiode& diode = **i_chargedDiode;
114
115 Identifier diodeID = chargedDiodes.getId(diode.diode());
116 double charge = diode.charge();
117
118 unsigned int FE = m_pixelReadout->getFE(diodeID, moduleID);
119 InDetDD::PixelDiodeType type = m_pixelReadout->getDiodeType(diodeID);
120 if ((FE == InDetDD::invalidFrontEnd) or (type == InDetDD::PixelDiodeType::NONE)) continue;//invalid frontend
121
122 // charge to ToT conversion
123 double tot = calibData->getToT(type, moduleHash, FE, charge);
124 const auto thresholds = calibData->getThresholds(type, moduleHash, FE);
125 // Apply analog threshold, timing simulation
126 double th0 = thresholds.value;
127 double ith0 = thresholds.inTimeValue;
128 double threshold = PixelDigitization::randomThreshold(thresholds, rndmEngine);
129 // This noise check is unaffected by digitizationFlags.doInDetNoise in
130 // 21.0 - see PixelCellDiscriminator.cxx in that branch
131
132 if (charge > threshold) {
133 int bunchSim = 0;
134 if (diode.totalCharge().fromTrack()) {
135 const std::vector<float> & totCharges = moduleData->getTimingIndex(barrel_ec, layerIndex);
136 const std::vector<float> & probArray = moduleData->getTimingProbability(barrel_ec, layerIndex, moduleIndex);
137
138 double prob = 0.0;
139 if (selectedTuneYear==2023) { prob = getProbability(totCharges, probArray, tot); }
140 if (selectedTuneYear==2022) { prob = getProbability(totCharges, probArray, tot); }
141 if (selectedTuneYear==2018) { prob = getProbability(totCharges, probArray, diode.totalCharge().charge()); }
142 if (selectedTuneYear==2015) { prob = getProbability(totCharges, probArray, diode.totalCharge().charge()); }
143
144 double G4Time = getG4Time(diode.totalCharge());
145 double rnd = CLHEP::RandFlat::shoot(rndmEngine, 0.0, 1.0);
146
147 double timeWalk = 0.0;
148 if (rnd<prob) { timeWalk = 25.0; }
149 bunchSim = static_cast<int>(std::floor((G4Time+m_timeOffset+timeWalk)/m_bunchSpace));
150
151 if (selectedTuneYear == 2009) { // RUN1 procedure (based on 2007 cosmic data)
152 double intimethreshold = (ith0 / th0) * threshold;
153 bunchSim = relativeBunch2009(threshold, intimethreshold, diode.totalCharge(), rndmEngine);
154 }
155 }
156 else {
157 if (moduleData->getFEI3TimingSimTune(barrel_ec, layerIndex) > 0) {
158 bunchSim = CLHEP::RandFlat::shootInt(rndmEngine, m_numberOfBcid);
159 }
160 }
161
162 if (bunchSim < 0 || bunchSim > m_numberOfBcid) {
163 SiHelper::belowThreshold(diode, true, true);
164 } else {
165 SiHelper::SetBunch(diode, bunchSim);
166 }
167 } else {
168 SiHelper::belowThreshold(diode, true, true);
169 }
170
171 double totsig = calibData->getTotRes(moduleHash, FE, tot);
172 int nToT = static_cast<int>(CLHEP::RandGaussZiggurat::shoot(rndmEngine, tot, totsig));
173
174 if (nToT < 1) {
175 nToT = 1;
176 }
177
178 if (nToT <= moduleData->getToTThreshold(barrel_ec, layerIndex)) {
179 SiHelper::belowThreshold(diode, true, true);
180 }
181
182 if (nToT >= moduleData->getFEI3Latency(barrel_ec, layerIndex)) {
183 SiHelper::belowThreshold(diode, true, true);
184 }
185
186 // Filter events
187 if (SiHelper::isMaskOut(diode)) {
188 continue;
189 }
190 if (SiHelper::isDisabled(diode)) {
191 continue;
192 }
193
194 if (!m_pixelConditionsTool->isActive(moduleHash, diodeID, ctx)) {
195 SiHelper::disabled(diode, true, true);
196 continue;
197 }
198
199 int flag = diode.flag();
200 int bunch = (flag >> 8) & 0xff;
201
202 InDetDD::SiReadoutCellId cellId = diode.getReadoutCell();
203 const Identifier id_readout = chargedDiodes.element()->identifierFromCellId(cellId);
204
205 // Front-End simulation
206 if (bunch >= 0 && bunch < m_numberOfBcid) {
207 rdoCollection.push_back(new Pixel1RawData(id_readout, nToT, bunch, 0, bunch));
208 }
209
210 // Duplication mechanism for FEI3 small hits :
211 if (m_duplication) {//is true for run1 only
212 static constexpr int smallHitThreshold{7}; //constant for both barrel and endcap, never changes
213 bool smallHitChk = false;
214 if (nToT <= smallHitThreshold) {
215 smallHitChk = true;
216 }
217 if (smallHitChk && bunch > 0 && bunch <= m_numberOfBcid) {
218 rdoCollection.push_back(new Pixel1RawData(id_readout, nToT, bunch - 1, 0, bunch - 1));
219 }
220 }
221 }
222 }
#define ATH_MSG_ERROR(x)
double charge(const T &p)
Definition AtlasPID.h:997
static TRandom * rnd
SiChargedDiodeOrderedSet::iterator SiChargedDiodeOrderedIterator
value_type push_back(value_type pElem)
int relativeBunch2009(const double threshold, const double intimethreshold, const SiTotalCharge &totalCharge, CLHEP::HepRandomEngine *rndmEngine) const
double getProbability(const std::vector< float > &bounds, const std::vector< float > &probs, const double &val) const
Gaudi::Property< bool > m_duplication
Definition FEI3SimTool.h:41
SG::ReadCondHandleKey< PixelChargeCalibCondData > m_chargeDataKey
ServiceHandle< InDetDD::IPixelReadoutManager > m_pixelReadout
static constexpr double m_bunchSpace
ToolHandle< IInDetConditionsTool > m_pixelConditionsTool
Gaudi::Property< bool > m_doNoise
Gaudi::Property< int > m_BarrelEC
PixelReadoutTechnology getReadoutTechnology() const
bool isValid() const
Test if its in a valid state.
Definition SiCellId.h:136
SiCellId gangedCell(const SiCellId &cellId) const
If cell is ganged return the id of the other cell which shares the readout for this cell,...
virtual Identifier identify() const override final
identifier of this detector element (inline)
PixelChargeCalib::Thresholds getThresholds(InDetDD::PixelDiodeType type, unsigned int moduleHash, unsigned int FE) const
float getToT(InDetDD::PixelDiodeType type, unsigned int moduleHash, unsigned int FE, float Q) const
float getTotRes(unsigned int moduleHash, unsigned int FE, float Q) const
int layer_disk(const Identifier &id) const
Definition PixelID.h:607
Identifier wafer_id(int barrel_ec, int layer_disk, int phi_module, int eta_module) const
For a single crystal.
Definition PixelID.h:360
int barrel_ec(const Identifier &id) const
Values of different levels (failure returns 0)
Definition PixelID.h:600
IdentifierHash wafer_hash(Identifier wafer_id) const
wafer hash from id
Definition PixelID.h:383
int eta_module(const Identifier &id) const
Definition PixelID.h:632
int phi_index(const Identifier &id) const
Definition PixelID.h:639
int getFEI3Latency(int barrel_ec, int layer) const
int getFEI3TimingSimTune(int barrel_ec, int layer) const
std::vector< float > getTimingProbability(int barrel_ec, int layer, int eta) const
std::vector< float > getTimingIndex(int barrel_ec, int layer) const
double getCrossTalk(int barrel_ec, int layer) const
virtual Identifier identify() const override final
const InDetDD::SolidStateDetectorElementBase * element() const
const InDetDD::SiCellId & diode() const
int flag() const
double charge() const
const SiTotalCharge & totalCharge() const
void add(const SiCharge &charge)
const InDetDD::SiReadoutCellId & getReadoutCell() const
static bool isMaskOut(SiChargedDiode &chDiode)
Definition SiHelper.h:171
static void SetBunch(SiChargedDiode &chDiode, int bunch, MsgStream *log=nullptr)
Definition SiHelper.h:129
static void disabled(SiChargedDiode &chDiode, bool flag, bool mask=false)
Definition SiHelper.h:93
static void maskOut(SiChargedDiode &chDiode, bool flag)
Definition SiHelper.h:67
static void belowThreshold(SiChargedDiode &chDiode, bool flag, bool mask=false)
Definition SiHelper.h:84
static bool isDisabled(SiChargedDiode &chDiode)
Definition SiHelper.h:179
bool fromTrack() const
double charge() const
constexpr uint32_t invalidFrontEnd
const T * getIdHelper(StoreGateSvc *pDetStore, const std::string &helperName)
void randomDisable(SiChargedDiodeCollection &chargedDiodes, const PixelModuleData *moduleData, CLHEP::HepRandomEngine *rndmEngine)
void crossTalk(double crossTalk, SiChargedDiodeCollection &chargedDiodes)
void thermalNoise(double thermalNoise, SiChargedDiodeCollection &chargedDiodes, CLHEP::HepRandomEngine *rndmEngine)
double randomThreshold(const PixelChargeCalib::Thresholds &t, CLHEP::HepRandomEngine *pEngine)
void randomNoise(SiChargedDiodeCollection &chargedDiodes, const PixelModuleData *moduleData, int nBcid, const PixelChargeCalibCondData *chargeCalibData, CLHEP::HepRandomEngine *rndmEngine, InDetDD::IPixelReadoutManager *pixelReadout)
double getG4Time(const SiTotalCharge &totalCharge)
bool flag
Definition master.py:29

◆ relativeBunch2009()

int FEI3SimTool::relativeBunch2009 ( const double threshold,
const double intimethreshold,
const SiTotalCharge & totalCharge,
CLHEP::HepRandomEngine * rndmEngine ) const
private

Definition at line 224 of file FEI3SimTool.cxx.

226 {
227 int BCID = 0;
228 double myTimeWalkEff = 0.;
229 double overdrive = intimethreshold - threshold;
230
231 //my TimeWalk computation through PARAMETRIZATION (by Francesco De Lorenzi - Milan)
232 //double curvature = 7.6e7*overdrive-2.64e10;
233 //double divergence = -1.6*overdrive+942 ;
234 //double myTimeWalk = curvature/(pow((totalCharge.charge()-divergence),2.5));
235
236 //my TimeWalk computation through PARAMETRIZATION from 2009 cosmic data (by I. Ibragimov and D. Miller)
237 double p1 = 20. / std::log(intimethreshold / overdrive);
238 double p0 = p1 * std::log(1. - threshold / 100000.);
239
240 double myTimeWalk = -p0 - p1 * std::log(1. - threshold / totalCharge.charge());
241
242 myTimeWalkEff = myTimeWalk + myTimeWalk * 0.2 * CLHEP::RandGaussZiggurat::shoot(rndmEngine);
243 const double limit = m_timeJitter * 0.5;
244 double randomJitter = CLHEP::RandFlat::shoot(rndmEngine, - limit, limit);
245
246 //double G4Time = totalCharge.time();
247
248 double G4Time = getG4Time(totalCharge);
249 double timing = m_timeOffset + myTimeWalkEff + randomJitter + G4Time;
250 BCID = static_cast<int>(std::floor(timing / m_bunchSpace));
251 //ATH_MSG_DEBUG ( CTW << " , " << myTimeWalkEff << " , " << G4Time << " , " << timing << " , " << BCID );
252
253 return BCID;
254}

◆ 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< AlgTool > >::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< AlgTool > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and DerivationFramework::CfAthAlgTool.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::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< AlgTool > >::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 }
std::vector< SG::VarHandleKeyArray * > m_vhka

Member Data Documentation

◆ m_BarrelEC

Gaudi::Property<int> FrontEndSimTool::m_BarrelEC
protectedinherited
Initial value:
{
this, "BarrelEC", 0, "Index of barrel or endcap"
}

Definition at line 68 of file FrontEndSimTool.h.

68 {
69 this, "BarrelEC", 0, "Index of barrel or endcap"
70 };

◆ m_bunchSpace

double FrontEndSimTool::m_bunchSpace {25.0}
staticconstexprprotectedinherited

Definition at line 50 of file FrontEndSimTool.h.

50{25.0};

◆ m_chargeDataKey

SG::ReadCondHandleKey<PixelChargeCalibCondData> FrontEndSimTool::m_chargeDataKey
protectedinherited
Initial value:
{
this, "PixelChargeCalibCondData", "PixelChargeCalibCondData", "Pixel charge calibration data"
}

Definition at line 64 of file FrontEndSimTool.h.

64 {
65 this, "PixelChargeCalibCondData", "PixelChargeCalibCondData", "Pixel charge calibration data"
66 };

◆ m_cosmics

Gaudi::Property<bool> FrontEndSimTool::m_cosmics
protectedinherited
Initial value:
{
this, "Cosmics", false, "Is this for Cosmics simulation?"
}

Definition at line 76 of file FrontEndSimTool.h.

76 {
77 this, "Cosmics", false, "Is this for Cosmics simulation?"
78 };

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_doNoise

Gaudi::Property<bool> FrontEndSimTool::m_doNoise
protectedinherited
Initial value:
{
this, "DoNoise", true, "Flag of noise simulation"
}

Definition at line 72 of file FrontEndSimTool.h.

72 {
73 this, "DoNoise", true, "Flag of noise simulation"
74 };

◆ m_duplication

Gaudi::Property<bool> FEI3SimTool::m_duplication
private
Initial value:
{
this, "HitDuplication", false, "Turn on Hit Duplication in subsequent timebin for small hits"
}

Definition at line 41 of file FEI3SimTool.h.

41 {
42 this, "HitDuplication", false, "Turn on Hit Duplication in subsequent timebin for small hits"
43 };

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_moduleDataKey

SG::ReadCondHandleKey<PixelModuleData> FEI3SimTool::m_moduleDataKey
private
Initial value:
{
this, "PixelModuleData", "PixelModuleData", "Pixel module data"
}

Definition at line 36 of file FEI3SimTool.h.

36 {
37 this, "PixelModuleData", "PixelModuleData", "Pixel module data"
38 };

◆ m_numberOfBcid

int FrontEndSimTool::m_numberOfBcid {1}
protectedinherited

Definition at line 51 of file FrontEndSimTool.h.

51{1}; //assumed same for all positions

◆ m_pixelConditionsTool

ToolHandle<IInDetConditionsTool> FrontEndSimTool::m_pixelConditionsTool
protectedinherited
Initial value:
{
this, "PixelConditionsSummaryTool", "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"
}

Definition at line 55 of file FrontEndSimTool.h.

55 {
56 this, "PixelConditionsSummaryTool", "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"
57 };

◆ m_pixelReadout

ServiceHandle<InDetDD::IPixelReadoutManager> FrontEndSimTool::m_pixelReadout
protectedinherited
Initial value:
{
this, "PixelReadoutManager", "PixelReadoutManager", "Pixel readout manager"
}

Definition at line 59 of file FrontEndSimTool.h.

59 {
60 this, "PixelReadoutManager", "PixelReadoutManager", "Pixel readout manager"
61 };

◆ m_thermalNoise

double FrontEndSimTool::m_thermalNoise {160.0}
protectedinherited

Definition at line 54 of file FrontEndSimTool.h.

54{160.0}; //default noise level

◆ m_timeJitter

double FrontEndSimTool::m_timeJitter {0.0}
protectedinherited

Definition at line 53 of file FrontEndSimTool.h.

53{0.0};

◆ m_timeOffset

double FrontEndSimTool::m_timeOffset {5.0}
protectedinherited

Definition at line 52 of file FrontEndSimTool.h.

52{5.0};

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

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

Definition at line 398 of file AthCommonDataStore.h.


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