43 #ifndef G4PENELOPERAYLEIGHMODEL_HH
44 #define G4PENELOPERAYLEIGHMODEL_HH 1
63 const G4String& processName =
"PenRayleigh");
117 std::map<const G4Material*,G4PhysicsFreeVector*> *
pMaxTable;
void InitializeSamplingAlgorithm(const G4Material *)
std::map< G4int, G4PhysicsFreeVector * > * logAtomicCrossSection
G4double fIntrinsicHighEnergyLimit
void SetParticle(const G4ParticleDefinition *)
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
void DumpFormFactorTable(const G4Material *)
void BuildFormFactorTable(const G4Material *)
G4DataVector logQSquareGrid
static const G4double emax
void SetVerbosityLevel(G4int lev)
std::map< const G4Material *, G4PhysicsFreeVector * > * pMaxTable
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
virtual ~G4PenelopeRayleighModel()
std::map< G4int, G4PhysicsFreeVector * > * atomicFormFactor
std::map< const G4Material *, G4PhysicsFreeVector * > * logFormFactorTable
double A(double temperature)
std::map< const G4Material *, G4PenelopeSamplingData * > * samplingTable
virtual void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel)
G4ParticleChangeForGamma * fParticleChange
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0, G4double cut=0, G4double emax=DBL_MAX)
const G4ParticleDefinition * fParticle
void GetPMaxTable(const G4Material *)
G4int GetVerbosityLevel()
G4PenelopeRayleighModel(const G4ParticleDefinition *p=0, const G4String &processName="PenRayleigh")
G4DataVector logEnergyGridPMax
G4PenelopeRayleighModel & operator=(const G4PenelopeRayleighModel &right)
G4double GetFSquared(const G4Material *, const G4double)
G4double fIntrinsicLowEnergyLimit