99     intrinsicLowEnergyLimit(10*
eV),
 
  100     intrinsicHighEnergyLimit(100*
GeV),
 
  101     cutForLowEnergySecondaryPhotons(250.*
eV),
 
  102     cutForLowEnergySecondaryElectrons(250.*
eV)
 
  107       G4Exception(
"G4LowEnergyPhotoElectric::G4LowEnergyPhotoElectric()",
 
  109                   "Energy limit outside intrinsic process validity range!");
 
  143   G4String crossSectionFile = 
"phot/pe-cs-";
 
  147   G4String shellCrossSectionFile = 
"phot/pe-ss-cs-";
 
  191   std::vector<G4DynamicParticle*>* photonVector = 0;
 
  192   std::vector<G4DynamicParticle*> electronVector;
 
  201   if (eKineticEnergy > 0.)
 
  217           electronVector.push_back(electron);
 
  221           energyDeposit += eKineticEnergy;
 
  226       bindingEnergy = photonEnergy;
 
  229   G4int nElectrons = electronVector.size();
 
  230   size_t nTotPhotons = 0;
 
  248   if (Z > 5  && (bindingEnergy > cutg || bindingEnergy > cute))
 
  251       nTotPhotons = photonVector->size();
 
  252       for (
size_t k=0; k<nTotPhotons; k++)
 
  254           aPhoton = (*photonVector)[k];
 
  261               if (itsEnergy > itsCut && itsEnergy <= bindingEnergy)
 
  267                   bindingEnergy -= itsEnergy;
 
  273                   (*photonVector)[k] = 0;
 
  281   G4int nSecondaries  = nElectrons + nPhotons;
 
  284   for (
G4int l = 0; l<nElectrons; l++ )
 
  286       aPhoton = electronVector[l];
 
  291   for ( 
size_t ll = 0; ll < nTotPhotons; ll++)
 
  293       aPhoton = (*photonVector)[ll];
 
  301   if (energyDeposit < 0)
 
  304              << 
"G4LowEnergyPhotoElectric::PostStepDoIt - Negative energy deposit" 
  342   if(cross > 0.0) meanFreePath = 1.0/cross;
 
  372   if (name == 
"default") 
 
  378   else if (name == 
"standard")
 
  384   else if (name == 
"polarized")
 
  392       G4Exception(
"G4LowEnergyPhotoElectric::SetAngularGenerator()",
 
  394                   "Generator does not exist!");
 
void SetCutForLowEnSecElectrons(G4double)
 
G4double ValueForMaterial(const G4Material *material, G4double e) const 
 
const std::vector< G4double > * GetEnergyCutsVector(size_t pcIdx) const 
 
void SetCutForSecondaryPhotons(G4double cut)
 
std::vector< G4DynamicParticle * > * GenerateParticles(G4int Z, G4int shellId)
 
void ActivateAugerElectronProduction(G4bool val)
 
G4double GetKineticEnergy() const 
 
CLHEP::Hep3Vector G4ThreeVector
 
G4bool IsApplicable(const G4ParticleDefinition &)
 
const G4DynamicParticle * GetDynamicParticle() const 
 
void BuildPhysicsTable(const G4ParticleDefinition &photon)
 
const G4MaterialCutsCouple * GetMaterialCutsCouple() const 
 
void LoadShellData(const G4String &dataFile)
 
G4double cutForLowEnergySecondaryElectrons
 
G4RDVPhotoElectricAngularDistribution * ElectronAngularGenerator
 
G4ParticleDefinition * GetDefinition() const 
 
G4RDVEMDataSet * BuildMeanFreePathForMaterials(const G4DataVector *energyCuts=0)
 
void ActivateAuger(G4bool)
 
void ProposeLocalEnergyDeposit(G4double anEnergyPart)
 
void SetAngularGenerator(G4RDVPhotoElectricAngularDistribution *distribution)
 
static G4RDAtomicTransitionManager * Instance()
 
void SetCutForLowEnSecPhotons(G4double)
 
G4GLOB_DLL std::ostream G4cout
 
const G4ThreeVector & GetMomentumDirection() const 
 
G4double BindingEnergy() const 
 
G4int SelectRandomShell(G4int Z, G4double e) const 
 
G4LowEnergyPhotoElectric(const G4String &processName="LowEnPhotoElec")
 
G4double GetMeanFreePath(const G4Track &aTrack, G4double previousStepSize, G4ForceCondition *condition)
 
G4RDVCrossSectionHandler * crossSectionHandler
 
const G4double intrinsicLowEnergyLimit
 
G4RDVRangeTest * rangeTest
 
const G4String & GetProcessName() const 
 
G4Material * GetMaterial() const 
 
~G4LowEnergyPhotoElectric()
 
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
 
virtual G4bool Escape(const G4ParticleDefinition *particle, const G4MaterialCutsCouple *couple, G4double energy, G4double safety) const =0
 
virtual void Initialize(const G4Track &)
 
static G4ProductionCutsTable * GetProductionCutsTable()
 
G4RDVEMDataSet * meanFreePathTable
 
G4double energy(const ThreeVector &p, const G4double m)
 
void SetNumberOfSecondaries(G4int totSecondaries)
 
G4StepPoint * GetPostStepPoint() const 
 
void SetCutForAugerElectrons(G4double cut)
 
G4int SelectRandomAtom(const G4MaterialCutsCouple *couple, G4double e) const 
 
const G4ThreeVector & GetPolarization() const 
 
void ProposeEnergy(G4double finalEnergy)
 
G4ParticleChange aParticleChange
 
T min(const T t1, const T t2)
brief Return the smallest of the two arguments 
 
G4RDAtomicShell * Shell(G4int Z, size_t shellIndex) const 
 
G4double GetSafety() const 
 
void AddSecondary(G4Track *aSecondary)
 
G4VParticleChange * PostStepDoIt(const G4Track &aTrack, const G4Step &aStep)
 
G4RDVCrossSectionHandler * shellCrossSectionHandler
 
static G4Electron * Electron()
 
G4double cutForLowEnergySecondaryPhotons
 
const G4double intrinsicHighEnergyLimit
 
virtual G4ThreeVector GetPhotoElectronDirection(const G4ThreeVector &direction, const G4double kineticEnergy, const G4ThreeVector &polarization, const G4int shellID) const =0
 
void LoadData(const G4String &dataFile)
 
G4RDAtomicDeexcitation deexcitationManager
 
void ProposeMomentumDirection(G4double Px, G4double Py, G4double Pz)
 
void ProposeTrackStatus(G4TrackStatus status)
 
G4double bindingEnergy(G4int A, G4int Z)
 
virtual G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &)
 
virtual void PrintGeneratorInformation() const =0