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