55 constexpr G4double c_highland = 13.6*CLHEP::MeV;
66 lManager->Register(
this);
73 lManager->DeRegister(
this);
78void G4DynamicParticleMSC::PreStepInitialisation(
const G4Track& track)
83 fEkinPreStep = dpart->GetKineticEnergy();
84 fBeta = dpart->GetBeta();
85 fCharge = dpart->GetCharge()/CLHEP::eplus;
86 fMass = std::max(dpart->GetMass(), CLHEP::electron_mass_c2);
96 PreStepInitialisation(track);
117 fParticleChange.InitialiseMSC(track, step);
120 if (fCharge == 0.0) {
return &fParticleChange; }
123 G4double y = geomLength/fMaterial->GetRadlen();
124 G4double theta0 = c_highland*std::abs(fCharge)*std::sqrt(y)*
125 (1.0 + 0.038*
G4Log(y*fCharge*fCharge/(fBeta*fBeta)))/fBeta;
127 if (theta0 < 0.001) {
return &fParticleChange; }
132 cost -= theta2*
G4Log(1.0 + r*(
G4Exp(2.0/theta2) - 1.0));
137 G4double sint = std::sqrt((1.0 - cost)*(1.0 + cost));
138 fNewDir.set(sint*std::cos(phi), sint*std::sin(phi), cost);
141 fParticleChange.ProposeMomentumDirection(fNewDir);
142 fParticleChange.ProposeTrueStepLength(geomLength);
143 return &fParticleChange;
165 currentSafety, &selection);
173 out <<
"G4DynamicParticleMSC: no delta rays" <<
G4endl;
@ fDynamicMultipleScattering
G4double condition(const G4ErrorSymMatrix &m)
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
@ NotCandidateForSelection
G4double G4Log(G4double x)
void ProcessDescription(std::ostream &) const override
G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double previousStepSize, G4double currentMinimumStep, G4double ¤tSafety, G4GPILSelection *selection) override
~G4DynamicParticleMSC() override
G4double GetMeanFreePath(const G4Track &, G4double, G4ForceCondition *condition) override
G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) override
G4double GetContinuousStepLimit(const G4Track &track, G4double previousStepSize, G4double currentMinimalStep, G4double ¤tSafety) override
G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &) override
G4double GetZeffective() const
static G4LossTableManager * Instance()
G4IonisParamMat * GetIonisation() const
const G4ThreeVector & GetMomentumDirection() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
G4Material * GetMaterial() const
const G4DynamicParticle * GetDynamicParticle() const
G4VContinuousDiscreteProcess(const G4String &, G4ProcessType aType=fNotDefined)
void SetVerboseLevel(G4int value)
void SetProcessSubType(G4int)