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

#include <FEI4SimTool.h>

Inheritance diagram for FEI4SimTool:
Collaboration diagram for FEI4SimTool:

Public Member Functions

 FEI4SimTool (const std::string &type, const std::string &name, const IInterface *parent)
virtual StatusCode initialize ()
virtual StatusCode finalize ()
virtual ~FEI4SimTool ()
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

 FEI4SimTool ()
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
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 23 of file FEI4SimTool.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

◆ FEI4SimTool() [1/2]

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

Definition at line 38 of file FEI4SimTool.cxx.

38 :
39 FrontEndSimTool(type, name, parent) {
40}

◆ ~FEI4SimTool()

FEI4SimTool::~FEI4SimTool ( )
virtualdefault

◆ FEI4SimTool() [2/2]

FEI4SimTool::FEI4SimTool ( )
private

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 FEI4SimTool::finalize ( )
virtual

Reimplemented from FrontEndSimTool.

Definition at line 52 of file FEI4SimTool.cxx.

52 {
53 ATH_MSG_DEBUG("FEI4SimTool::finalize()");
54 return StatusCode::SUCCESS;
55}
#define ATH_MSG_DEBUG(x)

◆ initialize()

StatusCode FEI4SimTool::initialize ( )
virtual

Reimplemented from FrontEndSimTool.

Definition at line 44 of file FEI4SimTool.cxx.

44 {
46 ATH_MSG_DEBUG("FEI4SimTool::initialize()");
47 ATH_CHECK(m_moduleDataKey.initialize());
48
49 return StatusCode::SUCCESS;
50}
#define ATH_CHECK
Evaluate an expression and check for errors.
SG::ReadCondHandleKey< PixelModuleData > m_moduleDataKey
Definition FEI4SimTool.h:33
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 FEI4SimTool::process ( SiChargedDiodeCollection & chargedDiodes,
PixelRDO_Collection & rdoCollection,
CLHEP::HepRandomEngine * rndmEngine ) const
virtual

Implements FrontEndSimTool.

Definition at line 57 of file FEI4SimTool.cxx.

58 {
59 const InDetDD::PixelModuleDesign* p_design =
60 static_cast<const InDetDD::PixelModuleDesign*>(&(chargedDiodes.element())->design());
61
63 return;
64 }
65
66 const PixelID* pixelId = static_cast<const PixelID*>(chargedDiodes.element()->getIdHelper());
67 const IdentifierHash moduleHash = pixelId->wafer_hash(chargedDiodes.identify()); // wafer hash
68 Identifier moduleID = pixelId->wafer_id(chargedDiodes.element()->identify());
69
70 int barrel_ec = pixelId->barrel_ec(chargedDiodes.element()->identify());
71 int layerIndex = pixelId->layer_disk(chargedDiodes.element()->identify());
72
73 if (std::abs(barrel_ec) != m_BarrelEC) {
74 return;
75 }
76
77 const EventContext& ctx{Gaudi::Hive::currentContext()};
78 SG::ReadCondHandle<PixelModuleData> moduleDataHandle(m_moduleDataKey, ctx);
79 const PixelModuleData *moduleData = *moduleDataHandle;
80 SG::ReadCondHandle<PixelChargeCalibCondData> calibDataHandle(m_chargeDataKey, ctx);
81 const PixelChargeCalibCondData *calibData = *calibDataHandle;
82
83 int maxFEI4SmallHit = 2;
84 int overflowToT = calibData->getFEI4OverflowToT();
85
86 std::vector<std::unique_ptr<Pixel1RawData>> p_rdo_small_fei4;
87 int nSmallHitsFEI4 = 0;
88 std::vector<int> row, col;
89 const int maxRow = p_design->rowsPerCircuit();
90 const int maxCol = p_design->columnsPerCircuit();
91 std::vector<std::vector<int> > FEI4Map(maxRow + 16, std::vector<int>(maxCol + 16));
92
93 // Add cross-talk
94 crossTalk(moduleData->getCrossTalk(barrel_ec, layerIndex), chargedDiodes);
95
96 if (m_doNoise) {
97 // Add thermal noise
98 thermalNoise(m_thermalNoise, chargedDiodes, rndmEngine);
99
100 // Add random noise
101 randomNoise(chargedDiodes, moduleData, m_numberOfBcid, calibData, rndmEngine, m_pixelReadout.get());
102 }
103
104 // Add random diabled pixels
105 randomDisable(chargedDiodes, moduleData, rndmEngine); // FIXME How should we handle disabling pixels in Overlay jobs?
106
107 for (SiChargedDiodeOrderedIterator i_chargedDiode = chargedDiodes.orderedBegin();
108 i_chargedDiode != chargedDiodes.orderedEnd(); ++i_chargedDiode) {
109 SiChargedDiode& diode = **i_chargedDiode;
110
111 Identifier diodeID = chargedDiodes.getId(diode.diode());
112 double charge = diode.charge();
113
114 // charge scaling function applied. (Reference: ATL-COM-INDET-2018-052)
115
116 double corrQ = 1.11 *
117 (1.0 - (-7.09 * 1000.0) / (23.72 * 1000.0 + charge) + (-0.22 * 1000.0) /
118 (-0.42 * 1000.0 + charge));
119 if (corrQ < 1.0) {
120 corrQ = 1.0;
121 }
122 charge *= 1.0 / corrQ;
123
124 //could scale if necessary
125
126 unsigned int FE = m_pixelReadout->getFE(diodeID, moduleID);
127 InDetDD::PixelDiodeType type = m_pixelReadout->getDiodeType(diodeID);
128 if ((FE == InDetDD::invalidFrontEnd) or (type == InDetDD::PixelDiodeType::NONE)) continue;//invalid frontend
129
130 // Apply analog threshold, timing simulation
131 const auto & thresholds = calibData->getThresholds(type, moduleHash, FE);
132 double threshold = PixelDigitization::randomThreshold(thresholds, rndmEngine);
133 // This noise check is unaffected by digitizationFlags.doInDetNoise in
134 // 21.0 - see PixelCellDiscriminator.cxx in that branch
135
136 if (charge > threshold) {
137 int bunchSim;
138 if (diode.totalCharge().fromTrack()) {
139 bunchSim =
140 static_cast<int>(std::floor((getG4Time(diode.totalCharge()) +
142 } else {
143 bunchSim = CLHEP::RandFlat::shootInt(rndmEngine, m_numberOfBcid);
144 }
145
146 if (bunchSim < 0 || bunchSim > m_numberOfBcid) {
147 SiHelper::belowThreshold(diode, true, true);
148 } else {
149 SiHelper::SetBunch(diode, bunchSim);
150 }
151 } else {
152 SiHelper::belowThreshold(diode, true, true);
153 }
154
155 // charge to ToT conversion
156 double tot = calibData->getToT(type, moduleHash, FE, charge);
157 double totsig = calibData->getTotRes(moduleHash, FE, tot);
158 int nToT = static_cast<int>(CLHEP::RandGaussZiggurat::shoot(rndmEngine, tot, totsig));
159
160 // This is for new IBL calibration, since above method (stat_cast) is not effective.
161 if (totsig==0.0) {
162 double totIBLsig = getSigma(nToT);
163 if (totIBLsig) {
164 if (CLHEP::RandFlat::shoot(rndmEngine,0.0,1.0)<std::exp(-0.5/totIBLsig/totIBLsig)) {
165 if (CLHEP::RandFlat::shoot(rndmEngine,0.0,1.0)<0.5) { nToT--; }
166 else { nToT++; }
167 }
168 }
169 }
170
171
172
173 // FEI4 HitDiscConfig
174 if (nToT == 2 && maxFEI4SmallHit == 2) {
175 nToT = 1;
176 }
177
178 nToT=std::clamp(nToT, 1, overflowToT);
179
180 if (nToT <= moduleData->getToTThreshold(barrel_ec, layerIndex)) {
181 SiHelper::belowThreshold(diode, true, true);
182 }
183
184 // Filter events
185 if (SiHelper::isMaskOut(diode)) {
186 continue;
187 }
188 if (SiHelper::isDisabled(diode)) {
189 continue;
190 }
191
192 if (!m_pixelConditionsTool->isActive(moduleHash, diodeID, ctx)) {
193 SiHelper::disabled(diode, true, true);
194 continue;
195 }
196
197 int flag = diode.flag();
198 int bunch = (flag >> 8) & 0xff;
199
200 InDetDD::SiReadoutCellId cellId = diode.getReadoutCell();
201 const Identifier id_readout = chargedDiodes.element()->identifierFromCellId(cellId);
202
203 int iirow = cellId.phiIndex();
204 int iicol = cellId.etaIndex();
205 if (iicol >= maxCol) {
206 iicol = iicol - maxCol;
207 } // FEI4 copy mechanism works per FE.
208
209 // Front-End simulation
210 if (bunch >= 0 && bunch < m_numberOfBcid) {
211 auto p_rdo = std::make_unique<Pixel1RawData>(id_readout, nToT, bunch, 0, bunch);
212 if (nToT > maxFEI4SmallHit) {
213 rdoCollection.push_back(p_rdo.release());
214 FEI4Map[iirow][iicol] = 2; //Flag for "big hits"
215 } else {
216 p_rdo_small_fei4.push_back(std::move(p_rdo));
217 row.push_back(iirow);
218 col.push_back(iicol);
219 FEI4Map[iirow][iicol] = 1; //Flag for low hits
220 nSmallHitsFEI4++;
221 }
222 }
223 }
224
225 // Copy mechanism for IBL small hits:
226 if (nSmallHitsFEI4 > 0) {
227 bool recorded = false;
228
229 //First case: Record small hits which are in the same Pixel Digital Region than a big hit:
230 for (int ismall = 0; ismall < nSmallHitsFEI4; ismall++) {
231 int rowPDR = row[ismall] / 2;
232 int colPDR = col[ismall] / 2;
233 for (int rowBigHit = 2 * rowPDR; rowBigHit != 2 * rowPDR + 2 && rowBigHit < maxRow; ++rowBigHit) {
234 for (int colBigHit = 2 * colPDR; colBigHit != 2 * colPDR + 2 && colBigHit < maxCol; ++colBigHit) {
236 "rowBig = " << rowBigHit << " colBig = " << colBigHit << " Map Content = " <<
237 FEI4Map[rowBigHit][colBigHit]);
238 if (FEI4Map[rowBigHit][colBigHit] == 2 && !recorded) {
239 rdoCollection.push_back(p_rdo_small_fei4[ismall].release());
240 recorded = true;
241 }
242 }
243 }
244
245 // Second case: Record small hits which are phi-neighbours with a big hit:
246 if (!recorded && row[ismall] < maxRow - 1) {
247 if (FEI4Map[row[ismall] + 1][col[ismall]] == 2) {
248 rdoCollection.push_back(p_rdo_small_fei4[ismall].release());
249 recorded = true;
250 }
251 }
252 if (!recorded && row[ismall] != 0) {
253 if (FEI4Map[row[ismall] - 1][col[ismall]] == 2) {
254 rdoCollection.push_back(p_rdo_small_fei4[ismall].release());
255 recorded = true;
256 }
257 }
258 }
259 }
260 }
double charge(const T &p)
Definition AtlasPID.h:997
SiChargedDiodeOrderedSet::iterator SiChargedDiodeOrderedIterator
value_type push_back(value_type pElem)
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
int rowsPerCircuit() const
Number of cell rows per circuit:
int columnsPerCircuit() const
Number of cell columns per circuit:
int phiIndex() const
Get phi index. Equivalent to strip().
Definition SiCellId.h:122
int etaIndex() const
Get eta index.
Definition SiCellId.h:114
virtual Identifier identify() const override final
identifier of this detector element (inline)
virtual Identifier identifierFromCellId(const SiCellId &cellId) const =0
Identifier <-> SiCellId (ie strip number or pixel eta_index,phi_index) Identifier from SiCellId (ie s...
constexpr int getFEI4OverflowToT() const
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
double getCrossTalk(int barrel_ec, int layer) const
virtual Identifier identify() const override final
SiChargedDiodeOrderedIterator orderedEnd()
SiChargedDiodeOrderedIterator orderedBegin()
Identifier getId(const InDetDD::SiCellId &id) const
const InDetDD::SolidStateDetectorElementBase * element() const
const InDetDD::SiCellId & diode() const
int flag() const
double charge() const
const SiTotalCharge & totalCharge() const
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 belowThreshold(SiChargedDiode &chDiode, bool flag, bool mask=false)
Definition SiHelper.h:84
static bool isDisabled(SiChargedDiode &chDiode)
Definition SiHelper.h:179
bool fromTrack() const
static std::string release
Definition computils.h:50
list recorded
if USE_PDG_VALUES = True, load PDG value of sin2thetaW and particle masses/widths from parameter dict...
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)
row
Appending html table to final .html summary file.
bool flag
Definition master.py:29

◆ 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_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> FEI4SimTool::m_moduleDataKey
private
Initial value:
{
this, "PixelModuleData", "PixelModuleData", "Pixel module data"
}

Definition at line 33 of file FEI4SimTool.h.

33 {
34 this, "PixelModuleData", "PixelModuleData", "Pixel module data"
35 };

◆ 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: