90 if(isInitialised) {
return; }
99 if(theta == CLHEP::pi) { yes =
true; }
111 isInitialised =
true;
122 if(name !=
"e-" && name !=
"e+" &&
123 name !=
"mu+" && name !=
"mu-" && name !=
"pi+" &&
154 emin = sqrt(p2 + mass*mass) - mass;
166 if(tetmin > 179.) { outFile <<
"ThetaMin(p)"; }
167 else { outFile << tetmin; }
168 outFile <<
" < Theta(degree) < 180";
170 if(q2Max <
DBL_MAX) { outFile <<
"; pLimit(GeV^1)= " << sqrt(q2Max)/GeV; }
179 " Coulomb scattering. Simulation of elastic scattering\n" <<
180 " events individually. May be used in combination with multiple\n" <<
181 " scattering, where Coulomb scattering is used for hard (large angle)\n" <<
182 " collisions and multiple scattering for soft collisions.";
virtual G4bool IsApplicable(const G4ParticleDefinition &p) final
G4CoulombScattering(const G4String &name="CoulombScat")
virtual void ProcessDescription(std::ostream &) const override
virtual void StreamProcessInfo(std::ostream &outFile) const override
virtual G4double MinPrimaryEnergy(const G4ParticleDefinition *, const G4Material *) final
virtual void InitialiseProcess(const G4ParticleDefinition *) override
virtual ~G4CoulombScattering()
static G4EmParameters * Instance()
G4double MinKinEnergy() const
G4double MscThetaLimit() const
G4double MaxKinEnergy() const
G4double FactorForAngleLimit() const
G4double GetInvA23() const
G4IonisParamMat * GetIonisation() const
const G4String & GetParticleType() const
G4bool IsShortLived() const
G4double GetPDGMass() const
G4double GetPDGCharge() const
const G4String & GetParticleName() const
static G4Proton * Proton()
void SetPolarAngleLimit(G4double)
void SetHighEnergyLimit(G4double)
G4double LowEnergyLimit() const
G4double HighEnergyLimit() const
void SetLowEnergyLimit(G4double)
void SetIntegral(G4bool val)
G4VEmModel * EmModel(size_t index=0) const
void SetBuildTableFlag(G4bool val)
void AddEmModel(G4int, G4VEmModel *, const G4Region *region=nullptr)
void SetEmModel(G4VEmModel *, G4int index=0)
void SetSecondaryParticle(const G4ParticleDefinition *p)
virtual void ProcessDescription(std::ostream &outFile) const override
void SetStartFromNullFlag(G4bool val)
void SetVerboseLevel(G4int value)
void SetProcessSubType(G4int)