26 #ifndef G4DNAUeharaScreenedRutherfordElasticModel_h
27 #define G4DNAUeharaScreenedRutherfordElasticModel_h 1
29 #include <CLHEP/Units/SystemOfUnits.h>
40 const G4String& nam =
"DNAUeharaScreenedRutherfordElasticModel");
95 std::vector<G4double>& vec);
125 "*** WARNING : the G4DNAUeharaScreenedRutherfordElasticModel class is "
126 "used above 10 keV !",
137 errMsg <<
"*** WARNING : "
138 <<
"G4DNAUeharaScreenedRutherfordElasticModel::SetKillBelowThreshold"
139 <<
"is deprecated, the kill threshold won't be taken into account";
142 "G4DNAUeharaScreenedRutherfordElasticModel::SetKillBelowThreshold",
150 errMsg <<
"*** WARNING : "
151 <<
"G4DNAUeharaScreenedRutherfordElasticModel::GetKillBelowThreshold"
152 <<
"is deprecated, the returned value is nonsense";
155 "G4DNAUeharaScreenedRutherfordElasticModel::GetKillBelowThreshold",
G4double GetKillBelowThreshold()
const std::vector< G4double > * fpWaterDensity
std::vector< G4double > betaCoeff
std::ostringstream G4ExceptionDescription
virtual G4double CrossSectionPerVolume(const G4Material *material, const G4ParticleDefinition *p, G4double ekin, G4double emin, G4double emax)
std::vector< G4double > gamma10_100Coeff
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
void SetKillBelowThreshold(G4double threshold)
void SetHighEnergyLimit(G4double)
G4DNAUeharaScreenedRutherfordElasticModel(const G4ParticleDefinition *p=0, const G4String &nam="DNAUeharaScreenedRutherfordElasticModel")
void SelectHighEnergyLimit(G4double threshold)
G4double ScreenedRutherfordRandomizeCosTheta(G4double k, G4double z)
G4double RutherfordCrossSection(G4double energy, G4double z)
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
std::vector< G4double > gamma100_200Coeff
void SelectFasterComputation(G4bool input)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
virtual ~G4DNAUeharaScreenedRutherfordElasticModel()
static const G4double emax
G4double ScreeningFactor(G4double energy, G4double z)
G4double intermediateEnergyLimit
G4double energy(const ThreeVector &p, const G4double m)
std::vector< G4double > deltaCoeff
G4double CalculatePolynomial(G4double k, std::vector< G4double > &vec)
G4double BrennerZaiderRandomizeCosTheta(G4double k)
std::vector< G4double > gamma035_10Coeff
static constexpr double keV
G4DNAUeharaScreenedRutherfordElasticModel & operator=(const G4DNAUeharaScreenedRutherfordElasticModel &right)
G4ParticleChangeForGamma * fParticleChangeForGamma