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