59 FlagParticleContainment = 1;
69 FlagParticleContainment = 1;
94 if (FlagParamType != 0) {
97 if (ParticleEnergy >
PBound->GetMinEneToParametrise(ParticleType)
98 && ParticleEnergy < PBound->GetMaxEneToParametrise(ParticleType))
103 select = CheckParticleDefAndContainment(fastTrack);
104 if (select) EnergyStop =
PBound->GetEneToKill(ParticleType);
111G4bool GFlashShowerModel::CheckParticleDefAndContainment(
const G4FastTrack& fastTrack)
120 if (FlagParticleContainment == 1) {
121 filter = CheckContainment(fastTrack);
138 CrossShower = DirectionShower.
cross(OrthoShower);
142 G4int CosPhi[4] = {1, 0, -1, 0};
143 G4int SinPhi[4] = {0, 1, 0, -1};
146 G4int NlateralInside = 0;
149 for (
int i = 0; i < 4; i++) {
151 Position = InitialPositionShower + Z * DirectionShower + R * CosPhi[i] * OrthoShower
152 + R * SinPhi[i] * CrossShower;
158 if (NlateralInside == 4) filter =
true;
168 ElectronDoIt(fastTrack, fastStep);
189 CrossShower = DirectionShower.
cross(OrthoShower);
227 if (Bound < stepLength) {
235 ZEndStep = ZEndStep + Dz;
238 if (EnergyNow > EnergyStop) {
239 LastEneIntegral = EneIntegral;
241 DEne = std::min(EnergyNow, (EneIntegral - LastEneIntegral) * Energy);
242 LastNspIntegral = NspIntegral;
245 std::max(1., std::floor((NspIntegral - LastNspIntegral) *
Parameterisation->GetNspot()));
250 DNsp = std::max(1., std::floor((1. - NspIntegral) *
Parameterisation->GetNspot()));
252 EnergyNow = EnergyNow - DEne;
256 GFlashSamplingShowerParameterisation*
sp =
259 G4double DEneSampling =
sp->ApplySampling(DEne, Energy);
264 StepLenght = StepLenght + Dz / 2.00;
265 NewPositionShower = NewPositionShower + StepLenght * DirectionShower;
266 StepLenght = Dz / 2.00;
269 for (
G4int i = 0; i < DNsp; ++i) {
270 GFlashEnergySpot Spot;
276 ->GenerateRadius(i, Energy, ZEndStep - Dz / 2.);
282 NewPositionShower + Dz / DNsp * DirectionShower * (i + 1 / 2. - DNsp / 2.)
283 + RSpot * std::cos(PhiSpot) * OrthoShower + RSpot * std::sin(PhiSpot) * CrossShower;
287 HMaker->make(&Spot, &fastTrack);
289 }
while (EnergyNow > 0.0 && Bound > 0.0);
CLHEP::Hep3Vector G4ThreeVector
Hep3Vector orthogonal() const
Hep3Vector cross(const Hep3Vector &) const
static G4Electron * ElectronDefinition()
void ProposeTotalEnergyDeposited(G4double anEnergyPart)
void ProposePrimaryTrackPathLength(G4double)
G4ThreeVector GetPrimaryTrackLocalPosition() const
const G4Track * GetPrimaryTrack() const
G4ThreeVector GetPrimaryTrackLocalDirection() const
G4VSolid * GetEnvelopeSolid() const
static G4Positron * PositronDefinition()
const G4ThreeVector & GetPosition() const
G4ParticleDefinition * GetDefinition() const
const G4ThreeVector & GetMomentumDirection() const
G4double GetKineticEnergy() const
G4VFastSimulationModel(const G4String &aName)
virtual EInside Inside(const G4ThreeVector &p) const =0
virtual G4double DistanceToOut(const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcNorm=false, G4bool *validNorm=nullptr, G4ThreeVector *n=nullptr) const =0
void SetPosition(const G4ThreeVector &point)
void SetEnergy(const G4double &E)
void DoIt(const G4FastTrack &, G4FastStep &)
G4bool ModelTrigger(const G4FastTrack &)
GFlashShowerModel(G4String, G4Envelope *)
G4bool IsApplicable(const G4ParticleDefinition &)
GFlashParticleBounds * PBound
GVFlashShowerParameterisation * Parameterisation
virtual void GenerateLongitudinalProfile(G4double Energy)=0
virtual G4double GetX0()=0