81 fParticleChange =
nullptr;
84 currentMaterial =
nullptr;
85 currentElement =
nullptr;
86 currentCouple =
nullptr;
88 lowEnergyLimit = 0*keV;
89 recoilThreshold = 0.*eV;
94 currentMaterialIndex = -1;
116 currentCouple =
nullptr;
117 currentMaterialIndex = -1;
119 Mottcross->Initialise(p,cosThetaMin);
131 if(!fParticleChange) {
157 if(model ==
"Fast" || model ==
"fast") { XSectionModel=1; }
158 else if(model ==
"Precise" || model ==
"precise") { XSectionModel=0; }
160 G4cout<<
"G4eSingleCoulombScatteringModel WARNING: "<<model
161 <<
" is not a valid model name"<<
G4endl;
178 if(kinEnergy < lowEnergyLimit)
return cross;
183 Mottcross->SetupKinematic(kinEnergy, Z);
184 cross = Mottcross->NuclearCrossSection(FormFactor,XSectionModel);
195 std::vector<G4DynamicParticle*>* fvect,
204 if(kinEnergy < lowEnergyLimit)
return;
206 DefineMaterial(couple);
213 G4int iz = currentElement->GetZasInt();
219 Mottcross->SetupKinematic(kinEnergy, iz);
220 G4double cross= Mottcross->NuclearCrossSection(FormFactor,XSectionModel);
221 if(cross == 0.0) {
return; }
224 G4double z1 = Mottcross->GetScatteringAngle(FormFactor,XSectionModel);
230 G4double ptot = sqrt(kinEnergy*(kinEnergy + 2.0*mass));
242 v1.
setX(momCM*sint*cos(phi));
243 v1.
setY(momCM*sint*sin(phi));
254 fParticleChange->ProposeMomentumDirection(newDirection);
258 G4double trec = std::max(v0.
e() - mass2, 0.0);
266 tcut= std::max(tcut,(*pCuts)[currentMaterialIndex]);
276 fvect->push_back(newdp);
277 }
else if(trec > 0.0) {
279 fParticleChange->ProposeNonIonizingEnergyDeposit(edep);
285 if(finalT <= lowEnergyLimit) {
289 edep = std::max(edep, 0.0);
290 fParticleChange->SetProposedKineticEnergy(finalT);
291 fParticleChange->ProposeLocalEnergyDeposit(edep);
CLHEP::HepLorentzVector G4LorentzVector
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cout
Hep3Vector & rotateUz(const Hep3Vector &)
Hep3Vector boostVector() const
HepLorentzVector & boost(double, double, double)
const G4ThreeVector & GetMomentumDirection() const
G4double GetLogKineticEnergy() const
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const
static G4EmParameters * Instance()
G4NuclearFormfactorType NuclearFormfactorType() const
static G4NistManager * Instance()
static G4double GetNuclearMass(const G4double A, const G4double Z)
G4IonTable * GetIonTable() const
static G4ParticleTable * GetParticleTable()
G4int SelectIsotopeNumber(const G4Element *) const
void SetElementSelectors(std::vector< G4EmElementSelector * > *)
G4ParticleChangeForGamma * GetParticleChangeForGamma()
std::vector< G4EmElementSelector * > * GetElementSelectors()
G4VEmModel(const G4String &nam)
const G4MaterialCutsCouple * CurrentCouple() const
const G4Element * SelectTargetAtom(const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy, G4double logKineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX)
void InitialiseElementSelectors(const G4ParticleDefinition *, const G4DataVector &)
void SetXSectionModel(const G4String &model)
void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy) final
G4eSingleCoulombScatteringModel(const G4String &nam="eSingleCoulombScat")
void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel) final
void Initialise(const G4ParticleDefinition *, const G4DataVector &) final
G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A, G4double cut, G4double emax) final
~G4eSingleCoulombScatteringModel() override