92 mass = proton_mass_c2;
136 if(
IsMaster() && mass < GeV && part->GetParticleName() !=
"GenericIon") {
168 for (
G4int j=0; j<nelm; ++j) {
170 if(iz < Z) { Z =
iz; }
194 if(kinEnergy <= 0.0) {
return cross; }
212 if(costmin > costmax) {
231 std::vector<G4DynamicParticle*>* fvect,
243 kinEnergy,cutEnergy,kinEnergy);
258 if(costmin <= costmax) {
return; }
261 G4double ratio = ecross/(cross + ecross);
279 G4double pxCM = momCM*newDirection.x();
280 G4double pyCM = momCM*newDirection.y();
281 G4double pzCM = momCM*newDirection.z();
284 G4LorentzVector v1(pxCM , pyCM, gam*(pzCM + bet*eCM), gam*(eCM + bet*pzCM));
287 newDirection = v1.vect().unit();
288 newDirection.rotateUz(dir);
305 newDirection = v0.vect().unit();
306 newDirection.rotateUz(dir);
308 fvect->push_back(newdp);
309 }
else if(trec > 0.0) {
const G4ParticleDefinition * theProton
G4double ComputeNuclearCrossSection(G4double CosThetaMin, G4double CosThetaMax)
static G4double GetNuclearMass(const G4double A, const G4double Z)
virtual G4double MinPrimaryEnergy(const G4Material *, const G4ParticleDefinition *, G4double)
std::vector< G4Element * > G4ElementVector
G4double GetKineticEnergy() const
CLHEP::Hep3Vector G4ThreeVector
void InitialiseElementSelectors(const G4ParticleDefinition *, const G4DataVector &)
G4double GetTotalEnergy() const
void DefineMaterial(const G4MaterialCutsCouple *)
G4ParticleDefinition * GetIon(G4int Z, G4int A, G4int lvl=0)
const std::vector< G4double > * pCuts
G4WentzelVIRelXSection * wokvi
G4ParticleDefinition * GetDefinition() const
void SetupParticle(const G4ParticleDefinition *)
G4NistManager * fNistManager
const G4ElementVector * GetElementVector() const
static G4NistManager * Instance()
void ProposeMomentumDirection(G4double Px, G4double Py, G4double Pz)
const G4MaterialCutsCouple * currentCouple
void ProposeLocalEnergyDeposit(G4double anEnergyPart)
G4double GetTotalMomentum() const
G4IonTable * GetIonTable() const
const G4MaterialCutsCouple * CurrentCouple() const
const G4ParticleDefinition * particle
double A(double temperature)
void ProposeNonIonizingEnergyDeposit(G4double anEnergyPart)
G4double SetupKinematic(G4double kinEnergy, const G4Material *mat, G4double cut, G4double tmass)
G4double SetupTarget(G4int Z, G4double cut)
const G4ThreeVector & GetMomentumDirection() const
static G4Proton * Proton()
virtual ~G4hCoulombScatteringModel()
G4int SelectIsotopeNumber(const G4Element *)
G4ParticleChangeForGamma * fParticleChange
std::vector< G4EmElementSelector * > * GetElementSelectors()
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
const G4Material * currentMaterial
void SetElementSelectors(std::vector< G4EmElementSelector * > *)
G4hCoulombScatteringModel(G4bool combined=true)
virtual G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A, G4double cut, G4double emax)
static G4ParticleTable * GetParticleTable()
T max(const T t1, const T t2)
brief Return the largest of the two arguments
G4int currentMaterialIndex
G4double PolarAngleLimit() const
G4double GetAtomicMassAmu(const G4String &symb) const
void SetProposedKineticEnergy(G4double proposedKinEnergy)
size_t GetNumberOfElements() const
G4double ComputeElectronCrossSection(G4double CosThetaMin, G4double CosThetaMax)
void Initialise(const G4ParticleDefinition *, G4double CosThetaLim)
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
G4ThreeVector & SampleSingleScattering(G4double CosThetaMin, G4double CosThetaMax, G4double elecRatio)
virtual void InitialiseLocal(const G4ParticleDefinition *, G4VEmModel *masterModel)
const G4Element * SelectRandomAtom(const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX)
G4ParticleChangeForGamma * GetParticleChangeForGamma()
CLHEP::HepLorentzVector G4LorentzVector