155{
158 }
162
163
164 G4hMultipleScattering* hmsc = new G4hMultipleScattering("ionmsc");
165
166
168 G4double livEnergyLimit = 1*CLHEP::GeV;
169
170
172 G4NuclearStopping* pnuc = nullptr;
173 if(nielEnergyLimit > 0.0) {
174 pnuc = new G4NuclearStopping();
176 }
177
178
179
180
183
184
185 G4PhotoElectricEffect* pe = new G4PhotoElectricEffect();
186 G4VEmModel* peModel = new G4LivermorePhotoElectricModel();
188 if(polar) {
190 }
191
192
193 G4ComptonScattering* cs = new G4ComptonScattering;
195 G4VEmModel* cModel = nullptr;
196 if(polar) {
197 cModel = new G4LivermorePolarizedComptonModel();
199 } else {
200 cModel = new G4LivermoreComptonModel();
202 }
204
205
206 G4GammaConversion* gc = new G4GammaConversion();
207 G4VEmModel* convLiv = new G4LivermoreGammaConversion5DModel();
209
210
211 G4RayleighScattering* rl = new G4RayleighScattering();
212 if(polar) {
213 rl->
SetEmModel(
new G4LivermorePolarizedRayleighModel());
214 }
215
220
221
223
224
225 G4GoudsmitSaundersonMscModel* msc1 = new G4GoudsmitSaundersonMscModel();
226 G4WentzelVIModel* msc2 = new G4WentzelVIModel();
230
231 G4eCoulombScatteringModel* ssm = new G4eCoulombScatteringModel();
232 G4CoulombScattering* ss = new G4CoulombScattering();
237
238
239 G4eIonisation* eioni = new G4eIonisation();
241 G4VEmModel* theIoniLiv = new G4LivermoreIonisationModel();
244
245
246 G4eBremsstrahlung* brem = new G4eBremsstrahlung();
247 G4SeltzerBergerModel* br1 = new G4SeltzerBergerModel();
248 G4eBremsstrahlungRelModel* br2 = new G4eBremsstrahlungRelModel();
254
255 G4ePairProduction* ee = new G4ePairProduction();
256
257
262
263
265
266
267 msc1 = new G4GoudsmitSaundersonMscModel();
268 msc2 = new G4WentzelVIModel();
272
273 ssm = new G4eCoulombScatteringModel();
274 ss = new G4CoulombScattering();
279
280
281 eioni = new G4eIonisation();
282
283
284 brem = new G4eBremsstrahlung();
285 br1 = new G4SeltzerBergerModel();
286 br2 = new G4eBremsstrahlungRelModel();
292
293
294 auto anni = new G4eplusAnnihilation();
296 anni->SetEmModel(new G4eplusTo2or3GammaModel());
297 }
298
299
305
306
308 G4ionIonisation* ionIoni = new G4ionIonisation();
309 ionIoni->
SetEmModel(
new G4LindhardSorensenIonModel());
313
314
316
317
319
320}
G4GLOB_DLL std::ostream G4cout
static G4Electron * Electron()
static void ConstructCharged(G4hMultipleScattering *hmsc, G4NuclearStopping *nucStopping, G4bool isWVI=true)
static void ConstructElectronMscProcess(G4VMscModel *msc1, G4VMscModel *msc2, G4ParticleDefinition *particle)
static void PrepareEMPhysics()
G4bool EnablePolarisation() const
G4double MaxNIELEnergy() const
G4double MscEnergyLimit() const
G4bool Use3GammaAnnihilationOnFly() const
static G4VEmFluctuationModel * ModelOfFluctuations(G4bool isIon=false)
static G4GenericIon * GenericIon()
G4bool RegisterProcess(G4VProcess *process, G4ParticleDefinition *particle)
static G4PhysicsListHelper * GetPhysicsListHelper()
static G4Positron * Positron()
void SetHighEnergyLimit(G4double)
void SetActivationLowEnergyLimit(G4double)
void SetLowEnergyLimit(G4double)
void SetAngularDistribution(G4VEmAngularDistribution *)
void SetMinKinEnergy(G4double e)
void AddEmModel(G4int, G4VEmModel *, const G4Region *region=nullptr)
void SetEmModel(G4VEmModel *, G4int index=0)
void SetMaxKinEnergy(G4double e)
void AddEmModel(G4int, G4VEmModel *, G4VEmFluctuationModel *fluc=nullptr, const G4Region *region=nullptr)
void SetFluctModel(G4VEmFluctuationModel *)
void SetEmModel(G4VEmModel *, G4int index=0)
const G4String & GetPhysicsName() const