64 #ifndef G4LowEPPolarizedComptonModel_h 65 #define G4LowEPPolarizedComptonModel_h 1 71 #include "G4ParticleChangeForGamma.hh" 80 #include "G4ForceCondition.hh" 83 class G4ParticleChangeForGamma;
94 const G4String& nam =
"LowEPComptonModel");
120 void ReadData(
size_t Z,
const char* path = 0);
static G4DopplerProfile * profileData
virtual ~G4LowEPPolarizedComptonModel()
G4ThreeVector GetPerpendicularPolarization(const G4ThreeVector &direction0, const G4ThreeVector &polarization0) const
virtual void InitialiseForElement(const G4ParticleDefinition *, G4int Z)
static G4ShellData * shellData
virtual void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel)
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
G4double SetPhi(G4double, G4double)
double A(double temperature)
G4double ComputeScatteringFunction(G4double x, G4int Z)
G4LowEPPolarizedComptonModel & operator=(const G4LowEPPolarizedComptonModel &right)
static const G4double ScatFuncFitParam[101][9]
static const G4double emax
G4LowEPPolarizedComptonModel(const G4ParticleDefinition *p=0, const G4String &nam="LowEPComptonModel")
G4ThreeVector SetPerpendicularVector(G4ThreeVector &a)
static G4LPhysicsFreeVector * data[100]
G4ThreeVector SetNewPolarization(G4double LowEPPCepsilon, G4double sinT2, G4double phi, G4double cosTheta)
G4ParticleChangeForGamma * fParticleChange
void ReadData(size_t Z, const char *path=0)
virtual void SampleSecondaries(std::vector< G4DynamicParticle *> *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4VAtomDeexcitation * fAtomDeexcitation
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0, G4double cut=0, G4double emax=DBL_MAX)
G4ThreeVector GetRandomPolarization(G4ThreeVector &direction0)