49 #ifndef G4eeToHadronsMultiModel_h
50 #define G4eeToHadronsMultiModel_h 1
57 #include "CLHEP/Units/SystemOfUnits.h"
58 #include "CLHEP/Units/PhysicalConstants.h"
142 G4double mass = CLHEP::electron_mass_c2;
143 G4double totE_lab = kinE_lab + mass;
144 totE_CM = std::sqrt(2*mass*(mass+totE_lab));
static const G4double fac
G4eeToHadronsMultiModel & operator=(const G4eeToHadronsMultiModel &right)
std::vector< G4double > ekinMax
std::vector< G4double > ekinPeak
G4double maxKineticEnergy
std::vector< G4eeToHadronsModel * > models
std::vector< G4double > ekinMin
void AddEEModel(G4Vee2hadrons *, const G4DataVector &)
std::vector< G4double > cumSum
static const G4double A[nN]
G4double ComputeCrossSectionPerElectron(const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX)
G4ParticleChangeForGamma * fParticleChange
G4eeCrossSections * cross
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kineticEnergy, G4double Z, G4double A, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX)
G4eeToHadronsMultiModel(G4int ver=0, const G4String &nam="eeToHadrons")
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
G4double LabToCM(G4double)
G4double energy(const ThreeVector &p, const G4double m)
virtual ~G4eeToHadronsMultiModel()
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin=0.0, G4double maxEnergy=DBL_MAX)
void SetCrossSecFactor(G4double fac)
virtual G4double CrossSectionPerVolume(const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy, G4double maxEnergy)