31 #ifndef G4LivermorePolarizedComptonModel_h 32 #define G4LivermorePolarizedComptonModel_h 1 37 class G4ParticleChangeForGamma;
59 const G4String& nam =
"LivermorePolarizedCompton");
114 void ReadData(
size_t Z,
const char* path = 0);
G4LivermorePolarizedComptonModel & operator=(const G4LivermorePolarizedComptonModel &right)
virtual ~G4LivermorePolarizedComptonModel()
static G4DopplerProfile * profileData
double A(double temperature)
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0, G4double cut=0, G4double emax=DBL_MAX)
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
virtual void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel)
virtual void InitialiseForElement(const G4ParticleDefinition *, G4int Z)
G4ThreeVector SetNewPolarization(G4double epsilon, G4double sinSqrTheta, G4double phi, G4double cosTheta)
static const G4double emax
G4ParticleChangeForGamma * fParticleChange
G4ThreeVector GetPerpendicularPolarization(const G4ThreeVector &direction0, const G4ThreeVector &polarization0) const
static G4ShellData * shellData
static G4CompositeEMDataSet * scatterFunctionData
G4LivermorePolarizedComptonModel(const G4ParticleDefinition *p=0, const G4String &nam="LivermorePolarizedCompton")
void SystemOfRefChange(G4ThreeVector &direction0, G4ThreeVector &direction1, G4ThreeVector &polarization0, G4ThreeVector &polarization1)
G4double SetPhi(G4double, G4double)
void ReadData(size_t Z, const char *path=0)
G4ThreeVector SetPerpendicularVector(G4ThreeVector &a)
static G4LPhysicsFreeVector * data[100]
double epsilon(double density, double temperature)
virtual void SampleSecondaries(std::vector< G4DynamicParticle *> *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4VAtomDeexcitation * fAtomDeexcitation
G4ThreeVector GetRandomPolarization(G4ThreeVector &direction0)