Geant4
10.03
|
#include <G4WentzelVIModel.hh>
Protected Member Functions | |
void | DefineMaterial (const G4MaterialCutsCouple *) |
![]() | |
G4ParticleChangeForMSC * | GetParticleChangeForMSC (const G4ParticleDefinition *p=nullptr) |
G4double | ConvertTrueToGeom (G4double &tLength, G4double &gLength) |
![]() | |
G4ParticleChangeForLoss * | GetParticleChangeForLoss () |
G4ParticleChangeForGamma * | GetParticleChangeForGamma () |
virtual G4double | MaxSecondaryEnergy (const G4ParticleDefinition *, G4double kineticEnergy) |
const G4MaterialCutsCouple * | CurrentCouple () const |
void | SetCurrentElement (const G4Element *) |
Protected Attributes | |
G4WentzelOKandVIxSection * | wokvi |
G4double | tlimitminfix |
G4double | ssFactor |
G4double | invssFactor |
G4double | preKinEnergy |
G4double | tPathLength |
G4double | zPathLength |
G4double | lambdaeff |
G4double | currentRange |
G4double | cosTetMaxNuc |
G4int | currentMaterialIndex |
const G4MaterialCutsCouple * | currentCouple |
const G4Material * | currentMaterial |
const G4ParticleDefinition * | particle |
G4bool | singleScatteringMode |
![]() | |
G4double | facrange |
G4double | facgeom |
G4double | facsafety |
G4double | skin |
G4double | dtrl |
G4double | lambdalimit |
G4double | geomMin |
G4double | geomMax |
G4ThreeVector | fDisplacement |
G4MscStepLimitType | steppingAlgorithm |
G4bool | samplez |
G4bool | latDisplasment |
![]() | |
G4ElementData * | fElementData |
G4VParticleChange * | pParticleChange |
G4PhysicsTable * | xSectionTable |
const std::vector< G4double > * | theDensityFactor |
const std::vector< G4int > * | theDensityIdx |
size_t | idxTable |
Private Member Functions | |
G4double | ComputeTransportXSectionPerVolume (G4double cosTheta) |
G4double | ComputeSecondMoment (const G4ParticleDefinition *, G4double kineticEnergy) |
void | SetupParticle (const G4ParticleDefinition *) |
G4WentzelVIModel & | operator= (const G4WentzelVIModel &right)=delete |
G4WentzelVIModel (const G4WentzelVIModel &)=delete | |
Private Attributes | |
G4ParticleChangeForMSC * | fParticleChange |
const G4DataVector * | currentCuts |
G4double | invsqrt12 |
G4double | fixedCut |
G4double | effKinEnergy |
G4double | cosThetaMin |
G4double | cosThetaMax |
G4PhysicsTable * | fSecondMoments |
size_t | idx2 |
G4int | minNCollisions |
G4int | nelments |
std::vector< G4double > | xsecn |
std::vector< G4double > | prob |
G4double | xtsec |
G4double | numlimit |
G4double | lowEnergyLimit |
G4bool | isCombined |
G4bool | useSecondMoment |
Additional Inherited Members | |
![]() | |
static const G4double | inveplus = 1.0/CLHEP::eplus |
Definition at line 66 of file G4WentzelVIModel.hh.
|
explicit |
Definition at line 74 of file G4WentzelVIModel.cc.
References cosTetMaxNuc, currentCuts, currentMaterial, currentMaterialIndex, currentRange, effKinEnergy, eV, fixedCut, fParticleChange, invsqrt12, lambdaeff, lowEnergyLimit, minNCollisions, mm, nelments, particle, preKinEnergy, prob, SetSingleScatteringFactor(), tlimitminfix, tPathLength, wokvi, xsecn, xtsec, and zPathLength.
|
virtual |
Definition at line 112 of file G4WentzelVIModel.cc.
References fSecondMoments, G4VEmModel::IsMaster(), and wokvi.
|
privatedelete |
|
overridevirtual |
Reimplemented from G4VEmModel.
Definition at line 210 of file G4WentzelVIModel.cc.
References G4WentzelOKandVIxSection::ComputeTransportCrossSectionPerAtom(), cosTetMaxNuc, G4VEmModel::CurrentCouple(), currentMaterial, DefineMaterial(), FatalException, fixedCut, G4Exception(), G4lrint(), lowEnergyLimit, particle, G4WentzelOKandVIxSection::SetupKinematic(), SetupParticle(), G4WentzelOKandVIxSection::SetupTarget(), and wokvi.
Reimplemented from G4VMscModel.
Definition at line 347 of file G4WentzelVIModel.cc.
References ComputeTransportXSectionPerVolume(), cosTetMaxNuc, cosThetaMin, currentCouple, currentMaterial, currentRange, DBL_MAX, effKinEnergy, G4Exp(), G4VMscModel::GetEnergy(), G4VMscModel::GetTransportMeanFreePath(), lambdaeff, minNCollisions, numlimit, particle, preKinEnergy, G4WentzelOKandVIxSection::SetupKinematic(), singleScatteringMode, tPathLength, wokvi, xtsec, and zPathLength.
|
private |
Definition at line 753 of file G4WentzelVIModel.cc.
References G4WentzelOKandVIxSection::ComputeSecondTransportMoment(), cosTetMaxNuc, currentMaterial, currentMaterialIndex, fixedCut, G4Material::GetElementVector(), G4Material::GetNumberOfElements(), G4Material::GetVecNbOfAtomsPerVolume(), G4WentzelOKandVIxSection::SetupKinematic(), SetupParticle(), G4WentzelOKandVIxSection::SetupTarget(), and wokvi.
Referenced by Initialise(), and SecondMoment().
Definition at line 698 of file G4WentzelVIModel.cc.
References G4WentzelOKandVIxSection::ComputeElectronCrossSection(), G4WentzelOKandVIxSection::ComputeNuclearCrossSection(), G4WentzelOKandVIxSection::ComputeTransportCrossSectionPerAtom(), cosTetMaxNuc, currentMaterial, currentMaterialIndex, fixedCut, G4Material::GetElementVector(), G4Material::GetNumberOfElements(), G4Material::GetVecNbOfAtomsPerVolume(), nelments, prob, G4WentzelOKandVIxSection::SetupTarget(), wokvi, xsecn, and xtsec.
Referenced by ComputeGeomPathLength(), and ComputeTrueStepLength().
|
overridevirtual |
Reimplemented from G4VMscModel.
Reimplemented in G4LowEWentzelVIModel.
Definition at line 250 of file G4WentzelVIModel.cc.
References G4VMscModel::ComputeGeomLimit(), G4VMscModel::ComputeSafety(), G4VMscModel::ConvertTrueToGeom(), cosTetMaxNuc, cosThetaMax, currentCouple, currentMaterial, currentRange, DefineMaterial(), effKinEnergy, G4VMscModel::facgeom, G4VMscModel::facrange, G4VMscModel::facsafety, fGeomBoundary, fUseDistanceToBoundary, G4Track::GetDynamicParticle(), G4DynamicParticle::GetKineticEnergy(), G4Track::GetMaterialCutsCouple(), G4StepPoint::GetPosition(), G4Step::GetPreStepPoint(), G4ProductionCuts::GetProductionCut(), G4MaterialCutsCouple::GetProductionCuts(), G4Material::GetRadlen(), G4VMscModel::GetRange(), G4StepPoint::GetSafety(), G4Track::GetStep(), G4StepPoint::GetStepStatus(), G4VMscModel::GetTransportMeanFreePath(), invssFactor, lambdaeff, G4INCL::Math::max(), G4INCL::Math::min(), particle, preKinEnergy, G4WentzelOKandVIxSection::SetupKinematic(), singleScatteringMode, G4InuclParticleNames::sp, G4VMscModel::steppingAlgorithm, tlimitminfix, and wokvi.
Reimplemented from G4VMscModel.
Definition at line 391 of file G4WentzelVIModel.cc.
References ComputeTransportXSectionPerVolume(), cosTetMaxNuc, cosThetaMin, currentCouple, currentMaterial, currentRange, DBL_MAX, effKinEnergy, G4Log(), G4VMscModel::GetEnergy(), G4VMscModel::GetTransportMeanFreePath(), lambdaeff, G4INCL::Math::min(), minNCollisions, numlimit, particle, preKinEnergy, G4WentzelOKandVIxSection::SetupKinematic(), singleScatteringMode, ssFactor, tPathLength, wokvi, xtsec, and zPathLength.
|
inlineprotected |
Definition at line 205 of file G4WentzelVIModel.hh.
References currentCouple, currentMaterial, currentMaterialIndex, G4MaterialCutsCouple::GetIndex(), G4MaterialCutsCouple::GetMaterial(), and G4VEmModel::SetCurrentCouple().
Referenced by ComputeCrossSectionPerAtom(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), Initialise(), and SecondMoment().
|
inline |
Definition at line 235 of file G4WentzelVIModel.hh.
References fixedCut.
|
inline |
Definition at line 263 of file G4WentzelVIModel.hh.
References fSecondMoments.
Referenced by InitialiseLocal().
|
inline |
Definition at line 242 of file G4WentzelVIModel.hh.
References wokvi.
|
overridevirtual |
Implements G4VEmModel.
Definition at line 123 of file G4WentzelVIModel.cc.
References ComputeSecondMoment(), cosThetaMax, currentCuts, currentRange, DefineMaterial(), emax, G4PhysicsVector::Energy(), G4PhysicsVector::FillSecondDerivatives(), fParticleChange, fSecondMoments, G4lrint(), G4VEmModel::GetCrossSectionTable(), G4PhysicsTable::GetFlag(), G4ProductionCutsTable::GetMaterialCutsCouple(), G4VMscModel::GetParticleChangeForMSC(), G4ProductionCutsTable::GetProductionCutsTable(), G4ProductionCutsTable::GetTableSize(), G4VEmModel::HighEnergyActivationLimit(), G4VEmModel::HighEnergyLimit(), G4WentzelOKandVIxSection::Initialise(), G4EmParameters::Instance(), isCombined, G4VEmModel::IsMaster(), G4VEmModel::LowEnergyActivationLimit(), G4VEmModel::LowEnergyLimit(), G4INCL::Math::max(), G4INCL::Math::min(), n, G4EmParameters::NumberOfBinsPerDecade(), pi, G4VEmModel::PolarAngleLimit(), G4PhysicsTableHelper::PreparePhysicsTable(), G4PhysicsVector::PutValue(), SetupParticle(), tet, useSecondMoment, and wokvi.
Referenced by G4TablesForExtrapolator::ComputeTrasportXS().
|
overridevirtual |
Reimplemented from G4VEmModel.
Definition at line 201 of file G4WentzelVIModel.cc.
References fSecondMoments, and GetSecondMomentTable().
|
privatedelete |
|
overridevirtual |
Reimplemented from G4VMscModel.
Definition at line 488 of file G4WentzelVIModel.cc.
References cosThetaMin, currentCouple, currentMaterial, currentMaterialIndex, DBL_MAX, effKinEnergy, G4VMscModel::fDisplacement, fixedCut, fParticleChange, G4Exp(), G4Log(), G4Material::GetElementVector(), G4Material::GetNumberOfElements(), invsqrt12, lambdaeff, G4VMscModel::latDisplasment, lowEnergyLimit, particle, preKinEnergy, prob, G4ParticleChangeForMSC::ProposeMomentumDirection(), G4WentzelOKandVIxSection::SampleSingleScattering(), SecondMoment(), G4WentzelOKandVIxSection::SetupTarget(), G4INCL::DeJongSpin::shoot(), singleScatteringMode, tPathLength, twopi, useSecondMoment, wokvi, xsecn, xtsec, G4InuclParticleNames::z0, and zPathLength.
|
inline |
Definition at line 271 of file G4WentzelVIModel.hh.
References ComputeSecondMoment(), currentMaterialIndex, DefineMaterial(), fSecondMoments, idx2, and useSecondMoment.
Referenced by SampleScattering().
|
inline |
Definition at line 228 of file G4WentzelVIModel.hh.
References fixedCut.
void G4WentzelVIModel::SetSingleScatteringFactor | ( | G4double | val | ) |
Definition at line 783 of file G4WentzelVIModel.cc.
References invssFactor, and ssFactor.
Referenced by G4LowEWentzelVIModel::G4LowEWentzelVIModel(), and G4WentzelVIModel().
|
inlineprivate |
Definition at line 217 of file G4WentzelVIModel.hh.
References particle, G4WentzelOKandVIxSection::SetupParticle(), and wokvi.
Referenced by ComputeCrossSectionPerAtom(), ComputeSecondMoment(), Initialise(), and StartTracking().
|
inline |
Definition at line 249 of file G4WentzelVIModel.hh.
References useSecondMoment.
|
overridevirtual |
Reimplemented from G4VEmModel.
Definition at line 243 of file G4WentzelVIModel.cc.
References G4DynamicParticle::GetDefinition(), G4Track::GetDynamicParticle(), and SetupParticle().
|
inline |
Definition at line 256 of file G4WentzelVIModel.hh.
References useSecondMoment.
|
protected |
Definition at line 154 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), ComputeGeomPathLength(), ComputeSecondMoment(), ComputeTransportXSectionPerVolume(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), and G4WentzelVIModel().
|
private |
Definition at line 179 of file G4WentzelVIModel.hh.
Referenced by ComputeTruePathLengthLimit(), and Initialise().
|
private |
Definition at line 178 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTrueStepLength(), and SampleScattering().
|
protected |
Definition at line 158 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), DefineMaterial(), and SampleScattering().
|
private |
Definition at line 169 of file G4WentzelVIModel.hh.
Referenced by G4WentzelVIModel(), and Initialise().
|
protected |
Definition at line 159 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), ComputeGeomPathLength(), ComputeSecondMoment(), ComputeTransportXSectionPerVolume(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), DefineMaterial(), G4WentzelVIModel(), and SampleScattering().
|
protected |
Definition at line 157 of file G4WentzelVIModel.hh.
Referenced by ComputeSecondMoment(), ComputeTransportXSectionPerVolume(), DefineMaterial(), G4WentzelVIModel(), SampleScattering(), and SecondMoment().
|
protected |
Definition at line 153 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), and Initialise().
|
private |
Definition at line 175 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 172 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), ComputeSecondMoment(), ComputeTransportXSectionPerVolume(), G4WentzelVIModel(), GetFixedCut(), SampleScattering(), and SetFixedCut().
|
private |
Definition at line 168 of file G4WentzelVIModel.hh.
Referenced by G4WentzelVIModel(), Initialise(), and SampleScattering().
|
private |
Definition at line 181 of file G4WentzelVIModel.hh.
Referenced by GetSecondMomentTable(), Initialise(), InitialiseLocal(), SecondMoment(), and ~G4WentzelVIModel().
|
private |
Definition at line 182 of file G4WentzelVIModel.hh.
Referenced by SecondMoment().
|
private |
Definition at line 171 of file G4WentzelVIModel.hh.
Referenced by G4WentzelVIModel(), and SampleScattering().
|
protected |
Definition at line 146 of file G4WentzelVIModel.hh.
Referenced by ComputeTruePathLengthLimit(), and SetSingleScatteringFactor().
|
private |
Definition at line 197 of file G4WentzelVIModel.hh.
Referenced by Initialise().
|
protected |
Definition at line 152 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 194 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 185 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTrueStepLength(), and G4WentzelVIModel().
|
private |
Definition at line 186 of file G4WentzelVIModel.hh.
Referenced by ComputeTransportXSectionPerVolume(), and G4WentzelVIModel().
|
private |
Definition at line 191 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), and ComputeTrueStepLength().
|
protected |
Definition at line 161 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), SampleScattering(), and SetupParticle().
|
protected |
Definition at line 149 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 188 of file G4WentzelVIModel.hh.
Referenced by ComputeTransportXSectionPerVolume(), G4WentzelVIModel(), and SampleScattering().
|
protected |
Definition at line 164 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), and SampleScattering().
|
protected |
Definition at line 145 of file G4WentzelVIModel.hh.
Referenced by ComputeTrueStepLength(), and SetSingleScatteringFactor().
|
protected |
Definition at line 144 of file G4WentzelVIModel.hh.
Referenced by G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), and G4WentzelVIModel().
|
protected |
Definition at line 150 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 198 of file G4WentzelVIModel.hh.
Referenced by Initialise(), SampleScattering(), SecondMoment(), SetUseSecondMoment(), and UseSecondMoment().
|
protected |
Definition at line 142 of file G4WentzelVIModel.hh.
Referenced by ComputeCrossSectionPerAtom(), ComputeGeomPathLength(), ComputeSecondMoment(), ComputeTransportXSectionPerVolume(), G4LowEWentzelVIModel::ComputeTruePathLengthLimit(), ComputeTruePathLengthLimit(), ComputeTrueStepLength(), G4WentzelVIModel(), GetWVICrossSection(), Initialise(), SampleScattering(), SetupParticle(), and ~G4WentzelVIModel().
|
private |
Definition at line 187 of file G4WentzelVIModel.hh.
Referenced by ComputeTransportXSectionPerVolume(), G4WentzelVIModel(), and SampleScattering().
|
private |
Definition at line 190 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTransportXSectionPerVolume(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().
|
protected |
Definition at line 151 of file G4WentzelVIModel.hh.
Referenced by ComputeGeomPathLength(), ComputeTrueStepLength(), G4WentzelVIModel(), and SampleScattering().