44 #ifndef G4PENELOPEPHOTOELECTRICMODEL_HH
45 #define G4PENELOPEPHOTOELECTRICMODEL_HH 1
65 const G4String& processName =
"PenPhotoElec");
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4ParticleChangeForGamma * fParticleChange
virtual void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel)
void SetVerbosityLevel(G4int lev)
G4double GetShellCrossSection(G4int Z, size_t shellID, G4double energy)
G4int GetVerbosityLevel()
G4PenelopePhotoElectricModel(const G4ParticleDefinition *p=0, const G4String &processName="PenPhotoElec")
std::map< G4int, G4PhysicsTable * > * logAtomicShellXS
const G4AtomicTransitionManager * fTransitionManager
G4double fIntrinsicLowEnergyLimit
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
void ReadDataFile(G4int Z)
static const G4double A[nN]
virtual ~G4PenelopePhotoElectricModel()
G4double energy(const ThreeVector &p, const G4double m)
G4VAtomDeexcitation * fAtomDeexcitation
void SetParticle(const G4ParticleDefinition *)
const G4ParticleDefinition * fParticle
size_t SelectRandomShell(G4int Z, G4double energy)
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0, G4double cut=0, G4double emax=DBL_MAX)
size_t GetNumberOfShellXS(G4int)
G4double fIntrinsicHighEnergyLimit
G4double SampleElectronDirection(G4double energy)
G4PenelopePhotoElectricModel & operator=(const G4PenelopePhotoElectricModel &right)
G4String WriteTargetShell(size_t shellID)