ATLAS Offline Software
LArFastShower.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 #include "LArFastShower.h"
6 
7 #include "GaudiKernel/Bootstrap.h"
8 #include "GaudiKernel/ISvcLocator.h"
9 #include "LArG4Code/EnergySpot.h"
10 
11 #include "AtlasHepMC/GenEvent.h"
12 #include "AtlasHepMC/GenParticle.h"
13 #include "AtlasHepMC/GenVertex.h"
14 #include "AtlasHepMC/IO_GenEvent.h"
15 
16 #include <stdexcept>
17 
18 #include "G4Electron.hh"
19 #include "G4Gamma.hh"
20 #include "G4Positron.hh"
21 #include "G4Neutron.hh"
22 #include "G4PionPlus.hh"
23 #include "G4PionMinus.hh"
24 #include "G4VSensitiveDetector.hh"
25 #include "G4EventManager.hh"
27 #include "IFastSimDedicatedSD.h"
28 
29 #include "GaudiKernel/ConcurrencyFlags.h"
30 
31 #undef _TRACE_FSM_
32 #undef _TRACE_DOIT_
33 #undef _TRACE_POSITION_
34 #undef _INFO_FSM_
35 
36 
38  IFastSimDedicatedSD* fastSimDedicatedSD):
39  G4VFastSimulationModel(name),
40  m_configuration(config),
41  m_fastSimDedicatedSD(fastSimDedicatedSD),
42  m_showerLibSvc(nullptr),
43  m_generate_starting_points(false),
44  m_starting_points_file(),
45  m_eventNum(0)
46 {
47  /* Starting points, i.e. vertex coordinates, are needed to create
48  * the Frozen Shower library, so they are saved in a hepmc file.
49  * Frozen showers are then simulated from these starting points
50  * in a separate job. To speed up the simulation,
51  * showers will be read from the library instead of being simulated.*/
54  std::string hepmcFileName = m_configuration.m_generated_starting_points_file;
55 
56  // In multi-thread run, multiple hepmc files are created.
57  // To distinguish between them we add thread_id in their name.
59  {
60  auto threadId = std::this_thread::get_id();
61  std::stringstream ss;
62  ss << threadId;
63  hepmcFileName += "."+ss.str();
64  }
65 #ifdef HEPMC3
66  m_starting_points_file = std::make_shared<HepMC3::WriterAscii>(hepmcFileName);
67 #else
68  m_starting_points_file = std::make_shared<HepMC::IO_GenEvent> (hepmcFileName,std::ios::out);
69 #endif
70  }
71 
72  enum DETECTOR { EMB=100000, EMEC=200000, FCAL1=300000, FCAL2=400000,
73  FCAL3=500000, HECLOC=600000, HEC=700000 };
74 
75  m_detmap["EMB"]=EMB;
76  m_detmap["EMEC"]=EMEC;
77  m_detmap["FCAL1"]=FCAL1;
78  m_detmap["FCAL2"]=FCAL2;
79  m_detmap["FCAL3"]=FCAL3;
80  m_detmap["HECLOC"]=HECLOC;
81  m_detmap["HEC"]=HEC;
82 }
83 
85 {
86  if ( !m_fastSimDedicatedSD ) {
87  throw std::runtime_error("LArFastShower: no pointer to IFastSimDedicatedSD!");
88  }
89  return m_fastSimDedicatedSD;
90 }
91 
92 
94 {
95  if ( !m_showerLibSvc ) {
96  SmartIF<ILArG4ShowerLibSvc> smartShowerLibSvc{Gaudi::svcLocator()->service(m_configuration.m_showerLibSvcName)};
97  if ( smartShowerLibSvc ) { m_showerLibSvc = smartShowerLibSvc.get(); }
98  if ( !m_showerLibSvc ) {
99  throw std::runtime_error("LArFastShower: cannot retrieve LArG4ShowerLibSvc");
100  }
101  }
102  return m_showerLibSvc;
103 }
104 
105 
106 G4bool LArFastShower::IsApplicable(const G4ParticleDefinition& particleType)
107 {
108 #ifdef _TRACE_FSM_
109  G4cout << "LArFastShower::IsApplicable" << G4endl;
110 #endif
111 
112  /*
113  * if ( flag to parameterize is set )
114  * && ( (we want to record SPs) || (ShowerLibSvc has a library for this particle) )
115  */
116  if (m_applicableMap.find(particleType.GetPDGEncoding()) != m_applicableMap.end()) {
117  return m_applicableMap.find(particleType.GetPDGEncoding())->second;
118  }
119  bool rez = false;
122  showerLibSvc()->checkLibrary( particleType.GetPDGEncoding(),
124  rez = true;
125  m_applicableMap[particleType.GetPDGEncoding()] = rez;
126  return rez;
127 }
128 
129 G4bool LArFastShower::ModelTrigger(const G4FastTrack& fastTrack)
130 {
131  /* ==========================================================================
132  Determine if the particle is to be returned to full Geant4 simulation.
133  In the event where the particle is EITHER killed and parameterised OR
134  simply killed, this must be done in the appropriate LArFastShower DoIt method.
135  This method Checks: 1) Geometry; 2) Energy; 3) (for e+/e-) Containment
136  ========================================================================== */
137 
138 #ifdef _TRACE_FSM_
139  G4cout << "LArFastShower::commonTrigger" << G4endl;
140 #endif
141 
142  // We are in a parameterized volume
143 
144  // Check if the particle is within energy bounds
145  G4double particleEnergy = fastTrack.GetPrimaryTrack()->GetKineticEnergy();
146  const G4ParticleDefinition& particleType = *(fastTrack.GetPrimaryTrack()->GetDefinition());
147 
148  if ( flagToShowerLib(particleType) == true &&
149  particleEnergy > minEneToShowerLib(particleType) &&
150  particleEnergy < maxEneToShowerLib(particleType) ) {
151 
152 #ifdef _TRACE_FSM_
153  G4cout << "Particle has energy (" << particleEnergy << ") for shower lib and shower lib is on! Accept particle!" << G4endl;
154 #endif
155  } else {
156 
157 #ifdef _TRACE_FSM_
158  G4cout << "Particle has energy (" << particleEnergy << ") outside killing, shower lib and parametrisation "
159  << "or some features are switched off ... returning it to Geant " << G4endl;
160 #endif
161 
162  return false;
163  }
164 
165  if (ForcedAccept(fastTrack)) return true;
166  if (ForcedDeny(fastTrack)) return false;
167 
168  if (CheckContainment(fastTrack)==false) {
169 #ifdef _TRACE_FSM_
170  G4cout << "LArFastShower::ModelTrigger() particle failed CheckContainment()... will not be parameterised: " << G4endl;
171 #endif
172  return false;
173  }
174 
175 #ifdef _TRACE_FSM_
176  G4cout << "LArFastShower::ModelTrigger() direction: " << fastTrack.GetPrimaryTrackLocalDirection() << G4endl;
177  G4cout << "LArFastShower::ModelTrigger() mom dir: " << fastTrack.GetPrimaryTrack()->GetMomentumDirection() << G4endl;
178 #endif
179 
180  return true;
181 }
182 
183 
184 void LArFastShower::DoIt(const G4FastTrack& fastTrack, G4FastStep& fastStep)
185 {
186 #ifdef _TRACE_FSM_
187  G4cout << "LArFastShower::Doit()" << G4endl;
188 #endif
189 
191  if ((float)rand()/static_cast<float>(RAND_MAX) <= m_configuration.m_generated_starting_points_ratio) {
192  std::unique_ptr<const HepMC::GenEvent> ge = GetGenEvent(fastTrack);
194  }
195  KillParticle( fastTrack, fastStep );
196  return;
197  }
198  this->UseShowerLib( fastTrack, fastStep );
199 
200 #ifdef _TRACE_FSM_
201  G4cout << "LArFastShower::Doit() done" << G4endl;
202 #endif
203 
204 }
205 
206 #ifdef _TRACE_DOIT_
207 void LArFastShower::KillParticle(const G4FastTrack& fastTrack, G4FastStep& fastStep)
208 #else
209 void LArFastShower::KillParticle(const G4FastTrack&, G4FastStep& fastStep)
210 #endif
211 {
212 
213 #ifdef _TRACE_DOIT_
214  G4cout << "Low energy particle is being killed: " << fastTrack.GetPrimaryTrack()->GetKineticEnergy() << G4endl;
215 #endif
216 
217  // Kill the particle
218  fastStep.KillPrimaryTrack();
219  fastStep.SetPrimaryTrackPathLength(0.0);
220 
221  return;
222 }
223 
224 void LArFastShower::UseShowerLib(const G4FastTrack& fastTrack, G4FastStep& fastStep)
225 {
226  try {
227 #ifdef _TRACE_DOIT_
228  G4cout << "LArFastShower::UseShowerLib()" << G4endl;
229 #endif
230 
231  // kill the electron to be parametrised
232  KillParticle(fastTrack, fastStep);
233 
234  // -----------------------------
235  // Get Shower from ShowerLibSvc
236  // -----------------------------
237  const std::vector<EnergySpot> shower =
239 
240 #ifdef _TRACE_DOIT_
241  G4cout << "Got shower (" << shower.size() << ") from shower lib" << G4endl;
242 #endif
243  const double weight = (m_configuration.m_applyRRWeights) ? fastTrack.GetPrimaryTrack()->GetWeight() : 1.0;
244  // loop over hits in shower
245  for (const auto& a_spot : shower) {
246 
247 #ifdef _TRACE_DOIT_
248  G4cout << "Make Spot: " << a_spot.GetPosition().x() << " "
249  << a_spot.GetPosition().y() << " " << a_spot.GetPosition().z()
250  << " " << a_spot.GetEnergy() << " " << a_spot.GetTime() << G4endl;
251 #endif
252  fastShowerSD()->ProcessSpot(a_spot, weight);
253 
254 #ifdef _TRACE_DOIT_
255  G4cout << "Made Spot" << G4endl;
256 #endif
257 
258  }
259 
260 #ifdef _TRACE_FSM_
261  G4cout << "LArFastShower::UseShowerLib() Done" << G4endl;
262 #endif
263 
264  return;
265  }
266 
267  // FIXME: Catching all exceptions and suppressing them? That's awful!!
268  catch (const std::exception & e) {
269  G4cout << "FastShower::UseShowerLib ERROR Handling an exception in LArFastShower::" << e.what() << G4endl;
270  return;
271  }
272 
273 }
274 
275 G4bool LArFastShower::CheckContainment(const G4FastTrack &fastTrack)
276 {
277 
278  G4ThreeVector showerDirection = fastTrack.GetPrimaryTrack()->GetMomentumDirection();
279  G4ThreeVector initialShowerPosition = fastTrack.GetPrimaryTrack()->GetPosition();
280  G4ThreeVector orthoShower = showerDirection.orthogonal();
281  G4ThreeVector crossShower = showerDirection.cross(orthoShower);
282 
283 #ifdef _TRACE_FSM_
284  G4cout << "LArFastShower::CheckContainment() orthoShower: " << orthoShower << G4endl;
285  G4cout << "LArFastShower::CheckContainment() crossShower: " << crossShower << G4endl;
286 #endif
287 
288  //Build 5 points at the shower max. edges and far end
289  //this picks the points where 99% of the particle energy was already deposited
290  /* Short history of containment check:
291  * First, it was magic numbers from ShowerParams class
292  G4double Zmx = myParameterisation()->GetAveZmx();
293  G4double R = myParameterisation()->GetAveR90(); // Easy - just multiply
294  G4double Z = myParameterisation()->GetAveZ90(); // More convoluted
295  * Then, after ShowerParams class was sent to code heaven, the magic numbers were saved from it
296  * and stored right here:
297  G4double Zmx = 22*mm;
298  G4double R = 1.5*4*cm;
299  G4double Z = 22*2.5*mm;
300  * Now, we take it directly from the library
301  */
304 
305  if (Z == 0.0 && R == 0.0) {
306  // no containment check
307  return true;
308  }
309 
310  // Here is OUR magic number. Looking on the hit distribution plot,
311  // it seems that that way most of hits will be inside
312  G4double Zmx = Z / 3;
313 
314  G4int cosPhi[4] = {1,0,-1,0};
315  G4int sinPhi[4] = {0,1,0,-1};
316 
317 #ifdef _TRACE_FSM_
318  G4cout << "LArFastShower::CheckContainment() R = " << R << G4endl;
319  G4cout << "LArFastShower::CheckContainment() Z = " << Z << G4endl;
320 #endif
321 
322  G4ThreeVector position;
323 
324  G4VSolid* caloSolid = fastTrack.GetEnvelopeSolid();
325  const G4AffineTransform* affineTransformation = fastTrack.GetAffineTransformation();
326 
327  //Startpoint
328  position = initialShowerPosition;
329  affineTransformation->ApplyPointTransform(position);
330  if(caloSolid->Inside(position) == kOutside)
331  return false;
332 
333  //Longitudinal Endpoint
334  position = initialShowerPosition + Z*showerDirection;
335  affineTransformation->ApplyPointTransform(position);
336  if(caloSolid->Inside(position) == kOutside)
337  return false;
338 
339  //Lateral Spread
340  for(int i=0; i<4 ;i++)
341  {
342  position = initialShowerPosition + Zmx*showerDirection +
343  R*cosPhi[i]*orthoShower + R*sinPhi[i]*crossShower;
344  affineTransformation->ApplyPointTransform(position);
345  if(caloSolid->Inside(position) == kOutside)
346  return false;
347  }
348 
349 #ifdef _TRACE_FSM_
350  G4cout << "LArFastShower::CheckContainment() Shower is contained " << G4endl;
351 #endif
352 
353  return true;
354 
355 }
356 
357 std::unique_ptr<const HepMC::GenEvent> LArFastShower::GetGenEvent(const G4FastTrack &fastTrack)
358 {
359  const G4ThreeVector showerPos = fastTrack.GetPrimaryTrack()->GetPosition();
360  const G4ThreeVector showerMom = fastTrack.GetPrimaryTrack()->GetMomentum();
361  const G4double energy = fastTrack.GetPrimaryTrack()->GetKineticEnergy();
362 
363  G4int pdgcode = fastTrack.GetPrimaryTrack()->GetDefinition()->GetPDGEncoding();
364  if (pdgcode < 0) pdgcode = -pdgcode; // hack for positrons. let it be electrons.
365 
366 #ifdef HEPMC3
367  HepMC3::Units::MomentumUnit momentumUnit = HepMC3::Units::MEV;
368  HepMC3::Units::LengthUnit lengthUnit = HepMC3::Units::MM;
369 #else
370  HepMC::Units::MomentumUnit momentumUnit = HepMC::Units::MEV;
371  HepMC::Units::LengthUnit lengthUnit = HepMC::Units::MM;
372 #endif
373  // new event. Signal processing = 0, event number "next"
374  std::unique_ptr<HepMC::GenEvent> ge = std::make_unique<HepMC::GenEvent>(momentumUnit,lengthUnit);
375 
376  ge->set_event_number(++m_eventNum);
377 
378  // starting point from which the shower develops, time = 0.
380  HepMC::FourVector(showerPos.x(), showerPos.y(), showerPos.z(), 0) );
381  ge->add_vertex(gv);
382 
383  // input particle (status=4) is always required by HepMC.
384  // make it a dummy geantino with 4-mom=0. pdg_id=999.
386  HepMC::FourVector(0.,0.,0.,0.),
387  999, 4 );
388  gv->add_particle_in(gpi);
389 
390  // output particle (status=1) is the FourVector of the shower.
392  HepMC::FourVector(showerMom.x(), showerMom.y(), showerMom.z(), energy),
393  pdgcode, 1 );
394  gv->add_particle_out(gpo);
395 
396  // return auto_pointer. will be deleted automatically
397  return ge;
398 }
399 
400 // Helper methods
401 bool LArFastShower::flagToShowerLib( const G4ParticleDefinition& particleType ) const
402 {
403  if ( &particleType == G4Electron::ElectronDefinition() ||
404  &particleType == G4Positron::PositronDefinition() ) {
406  } else if ( &particleType == G4Gamma::GammaDefinition() ) {
408  } else if ( &particleType == G4Neutron::NeutronDefinition() ) {
410  } else if ( &particleType == G4PionPlus::PionPlusDefinition() ||
411  &particleType == G4PionMinus::PionMinusDefinition() ) {
413  }
414  return false;
415 }
416 double LArFastShower::minEneToShowerLib( const G4ParticleDefinition& particleType ) const
417 {
418  if ( &particleType == G4Electron::ElectronDefinition() ||
419  &particleType == G4Positron::PositronDefinition() ) {
421  } else if ( &particleType == G4Gamma::GammaDefinition() ) {
423  } else if ( &particleType == G4Neutron::NeutronDefinition() ) {
425  } else if ( &particleType == G4PionPlus::PionPlusDefinition() ||
426  &particleType == G4PionMinus::PionMinusDefinition() ) {
428  }
429  return 0.0;
430 }
431 
432 double LArFastShower::maxEneToShowerLib( const G4ParticleDefinition& particleType ) const
433 {
434  if ( &particleType == G4Electron::ElectronDefinition() ||
435  &particleType == G4Positron::PositronDefinition() ) {
437  } else if ( &particleType == G4Gamma::GammaDefinition() ) {
439  } else if ( &particleType == G4Neutron::NeutronDefinition() ) {
441  } else if ( &particleType == G4PionPlus::PionPlusDefinition() ||
442  &particleType == G4PionMinus::PionMinusDefinition() ) {
444  }
445  return 0.0;
446 }
447 bool LArFastShower::generateFSStartingPoint( std::unique_ptr<const HepMC::GenEvent> &ge ) const
448 {
450  return false;
451 #ifdef HEPMC3
452  m_starting_points_file->write_event(*ge);
453 #else
454  m_starting_points_file->write_event(ge.get());
455 #endif
456  return true;
457 }
458 G4bool LArFastShower::ForcedAccept(const G4FastTrack & fastTrack)
459 {
460  G4ThreeVector initialShowerPosition = fastTrack.GetPrimaryTrack()->GetPosition();
461 
462  // if ( !m_configuration.m_containHigh &&
463  // ( initialShowerPosition.eta()>=m_configuration.m_absHighEta ||
464  // initialShowerPosition.eta()<=-m_configuration.m_absHighEta ) ) return true;
465 
467  ( initialShowerPosition.eta()>m_configuration.m_absHighEta ||
468  initialShowerPosition.eta()<-m_configuration.m_absHighEta ) ) return true;
469 
471  ( ( initialShowerPosition.eta()>m_configuration.m_absCrackEta1 &&
472  initialShowerPosition.eta()<m_configuration.m_absCrackEta2 ) ||
473  ( initialShowerPosition.eta()<-m_configuration.m_absCrackEta1 &&
474  initialShowerPosition.eta()>-m_configuration.m_absCrackEta2 ) ) ) return true;
475 
477  ( initialShowerPosition.eta()<m_configuration.m_absLowEta ||
478  initialShowerPosition.eta()>-m_configuration.m_absLowEta ) ) return true;
479  return false;
480 }
481 
482 G4bool LArFastShower::ForcedDeny (const G4FastTrack &)
483 {
484  return false;
485 }
HepMC::GenVertexPtr
HepMC::GenVertex * GenVertexPtr
Definition: GenVertex.h:59
FastShowerConfigStruct::m_g_MaxEneShowerLib
double m_g_MaxEneShowerLib
lower energy limit for photon frozen showers
Definition: FastShowerConfigStruct.h:18
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
FastShowerConfigStruct::m_absLowEta
double m_absLowEta
Definition: FastShowerConfigStruct.h:30
LArSamples::HEC
@ HEC
Definition: CaloId.h:26
LArFastShower::CheckContainment
virtual G4bool CheckContainment(const G4FastTrack &fastTrack)
Function to check the containment of a shower within a regular detector region.
Definition: LArFastShower.cxx:275
GenEvent.h
FastShowerConfigStruct::m_absCrackEta1
double m_absCrackEta1
Definition: FastShowerConfigStruct.h:34
ILArG4ShowerLibSvc::getShower
virtual std::vector< EnergySpot > getShower(const G4FastTrack &, int) const =0
PowhegControl_ttHplus_NLO.ss
ss
Definition: PowhegControl_ttHplus_NLO.py:83
FastShowerConfigStruct::m_detector_tag
int m_detector_tag
name for the detector tag for the ShowerLibSvc
Definition: FastShowerConfigStruct.h:38
ILArG4ShowerLibSvc
Definition: ILArG4ShowerLibSvc.h:19
IO_GenEvent.h
LArFastShower::showerLibSvc
ILArG4ShowerLibSvc * showerLibSvc()
Definition: LArFastShower.cxx:93
Monitored::Z
@ Z
Definition: HistogramFillerUtils.h:24
ILArG4ShowerLibSvc::getContainmentZ
virtual double getContainmentZ(const G4FastTrack &, int)=0
GenVertex.h
HepMC::GenParticlePtr
GenParticle * GenParticlePtr
Definition: GenParticle.h:37
FastShowerConfigStruct::m_Pion_FlagShowerLib
bool m_Pion_FlagShowerLib
switch for pion frozen showers
Definition: FastShowerConfigStruct.h:25
python.AthDsoLogger.out
out
Definition: AthDsoLogger.py:71
CaloCell_ID_FCS::FCAL1
@ FCAL1
Definition: FastCaloSim_CaloCell_ID.h:41
MM
@ MM
Definition: RegSelEnums.h:38
LArFastShower::ForcedDeny
virtual G4bool ForcedDeny(const G4FastTrack &)
If it returns true, the particle will be returned to G4 without further checks.
Definition: LArFastShower.cxx:482
IFastSimDedicatedSD
This is the interface for the fast simulation dedicated sensitive detector.
Definition: IFastSimDedicatedSD.h:13
LArFastShower::minEneToShowerLib
double minEneToShowerLib(const G4ParticleDefinition &particleType) const
get upper energy limit for frozen showers
Definition: LArFastShower.cxx:416
LArFastShower::m_eventNum
int m_eventNum
Definition: LArFastShower.h:100
particleType
Definition: particleType.h:29
GenParticle.h
config
Definition: PhysicsAnalysis/AnalysisCommon/AssociationUtils/python/config.py:1
FastShowerConfigStruct::m_applyRRWeights
bool m_applyRRWeights
Definition: FastShowerConfigStruct.h:41
LArFastShower::DoIt
void DoIt(const G4FastTrack &, G4FastStep &) override
Assigns the track to the appropriate method for application of the fast simulation.
Definition: LArFastShower.cxx:184
dqt_zlumi_pandas.weight
int weight
Definition: dqt_zlumi_pandas.py:189
LArSamples::EMEC
@ EMEC
Definition: CaloId.h:25
FastShowerConfigStruct::m_Neut_MaxEneShowerLib
double m_Neut_MaxEneShowerLib
upper energy limit for neutron frozen showers
Definition: FastShowerConfigStruct.h:23
LArFastShower::GetGenEvent
std::unique_ptr< const HepMC::GenEvent > GetGenEvent(const G4FastTrack &fastTrack)
Definition: LArFastShower.cxx:357
IFastSimDedicatedSD.h
FastShowerConfigStruct::m_Neut_MinEneShowerLib
double m_Neut_MinEneShowerLib
lower energy limit for neutron frozen showers
Definition: FastShowerConfigStruct.h:22
ILArG4ShowerLibSvc.h
LArFastShower::fastShowerSD
IFastSimDedicatedSD * fastShowerSD()
Definition: LArFastShower.cxx:84
LArFastShower::generateFSStartingPoint
bool generateFSStartingPoint(std::unique_ptr< const HepMC::GenEvent > &ge) const
Definition: LArFastShower.cxx:447
LArSamples::EMB
@ EMB
Definition: CaloId.h:25
LArG4FSStartPointFilter.rand
rand
Definition: LArG4FSStartPointFilter.py:80
ParticleGun_FastCalo_ChargeFlip_Config.energy
energy
Definition: ParticleGun_FastCalo_ChargeFlip_Config.py:78
LArFastShower::LArFastShower
LArFastShower(const std::string &name, const FastShowerConfigStruct &config, IFastSimDedicatedSD *fastSimDedicatedSD)
Constructor.
Definition: LArFastShower.cxx:37
HepMC::newGenVertexPtr
GenVertexPtr newGenVertexPtr(const HepMC::FourVector &pos=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), const int i=0)
Definition: GenVertex.h:64
lumiFormat.i
int i
Definition: lumiFormat.py:85
LArFastShower::m_generate_starting_points
bool m_generate_starting_points
Definition: LArFastShower.h:91
LArFastShower::ModelTrigger
virtual G4bool ModelTrigger(const G4FastTrack &) override
Determines the applicability of the fast sim model to this particular track.
Definition: LArFastShower.cxx:129
FastShowerConfigStruct::m_absHighEta
double m_absHighEta
Definition: FastShowerConfigStruct.h:32
FastShowerConfigStruct
Definition: FastShowerConfigStruct.h:12
FastShowerConfigStruct::m_absCrackEta2
double m_absCrackEta2
Definition: FastShowerConfigStruct.h:35
calibdata.exception
exception
Definition: calibdata.py:496
FastShowerConfigStruct::m_showerLibSvcName
std::string m_showerLibSvcName
Definition: FastShowerConfigStruct.h:40
LArFastShower::UseShowerLib
void UseShowerLib(const G4FastTrack &, G4FastStep &)
Function for the application of shower library.
Definition: LArFastShower.cxx:224
AnalysisUtils::Delta::R
double R(const INavigable4Momentum *p1, const double v_eta, const double v_phi)
Definition: AnalysisMisc.h:49
LArFastShower::flagToShowerLib
bool flagToShowerLib(const G4ParticleDefinition &particleType) const
get switch for frozen showers
Definition: LArFastShower.cxx:401
FastShowerConfigStruct::m_g_MinEneShowerLib
double m_g_MinEneShowerLib
upper energy limit for photon frozen showers
Definition: FastShowerConfigStruct.h:19
LArFastShower::m_showerLibSvc
ILArG4ShowerLibSvc * m_showerLibSvc
Pointer to the shower library service.
Definition: LArFastShower.h:88
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
LArFastShower::ForcedAccept
virtual G4bool ForcedAccept(const G4FastTrack &)
If it returns true, the particle will be parameterized without further checks.
Definition: LArFastShower.cxx:458
LArFastShower::KillParticle
void KillParticle(const G4FastTrack &, G4FastStep &)
Method to kill a particle and deposit its energy using exponential decay function.
Definition: LArFastShower.cxx:209
IFastSimDedicatedSD::ProcessSpot
virtual void ProcessSpot(const EnergySpot &spot, double weight)=0
ProcessHitsMethod.
LArFastShower.h
FastShowerConfigStruct::m_generated_starting_points_ratio
float m_generated_starting_points_ratio
switch for shower starting point record
Definition: FastShowerConfigStruct.h:37
FastShowerConfigStruct::m_Neut_FlagShowerLib
bool m_Neut_FlagShowerLib
switch for neutron frozen showers
Definition: FastShowerConfigStruct.h:21
FastShowerConfigStruct::m_Pion_MinEneShowerLib
double m_Pion_MinEneShowerLib
lower energy limit for pion frozen showers
Definition: FastShowerConfigStruct.h:26
LArFastShower::m_applicableMap
std::map< int, bool > m_applicableMap
Definition: LArFastShower.h:101
FastShowerConfigStruct::m_g_FlagShowerLib
bool m_g_FlagShowerLib
switch for photon frozen showers
Definition: FastShowerConfigStruct.h:17
LArFastShower::m_configuration
const FastShowerConfigStruct m_configuration
Definition: LArFastShower.h:83
EnergySpot.h
FastShowerConfigStruct::m_generated_starting_points_file
std::string m_generated_starting_points_file
switch for shower starting point record
Definition: FastShowerConfigStruct.h:36
HepMC::newGenParticlePtr
GenParticlePtr newGenParticlePtr(const HepMC::FourVector &mom=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), int pid=0, int status=0)
Definition: GenParticle.h:39
FastShowerConfigStruct::m_e_FlagShowerLib
bool m_e_FlagShowerLib
switch for electron frozen showers
Definition: FastShowerConfigStruct.h:13
python.BackTrackingConfig.numThreads
int numThreads
Definition: BackTrackingConfig.py:61
FastShowerConfigStruct::m_e_MaxEneShowerLib
double m_e_MaxEneShowerLib
upper energy limit for electron frozen showers
Definition: FastShowerConfigStruct.h:15
FastShowerConfigStruct::m_containLow
bool m_containLow
switch for containment check at low eta
Definition: FastShowerConfigStruct.h:29
FastShowerConfigStruct::m_containCrack
bool m_containCrack
switch for containment check in crack region
Definition: FastShowerConfigStruct.h:33
FastShowerConfigStruct::m_e_MinEneShowerLib
double m_e_MinEneShowerLib
lower energy limit for electron frozen showers
Definition: FastShowerConfigStruct.h:14
CaloCell_ID_FCS::FCAL2
@ FCAL2
Definition: FastCaloSim_CaloCell_ID.h:42
LArFastShower::m_starting_points_file
std::shared_ptr< HepMC::IO_GenEvent > m_starting_points_file
Definition: LArFastShower.h:95
LArFastShower::m_fastSimDedicatedSD
IFastSimDedicatedSD * m_fastSimDedicatedSD
Shower library sensitive detector for this shower.
Definition: LArFastShower.h:86
FastShowerConfigStruct::m_containHigh
bool m_containHigh
switch for containment check at high eta
Definition: FastShowerConfigStruct.h:31
FastShowerConfigStruct::m_Pion_MaxEneShowerLib
double m_Pion_MaxEneShowerLib
upper energy limit for pion frozen showers
Definition: FastShowerConfigStruct.h:27
LArFastShower::maxEneToShowerLib
double maxEneToShowerLib(const G4ParticleDefinition &particleType) const
get lower energy limit for frozen showers
Definition: LArFastShower.cxx:432
LArFastShower::IsApplicable
G4bool IsApplicable(const G4ParticleDefinition &) override
Determines the applicability of the fast sim model to this particle type Called once for each track p...
Definition: LArFastShower.cxx:106
LArFastShower::m_detmap
std::map< std::string, int > m_detmap
Definition: LArFastShower.h:98
ILArG4ShowerLibSvc::getContainmentR
virtual double getContainmentR(const G4FastTrack &, int)=0