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