154{
157 }
159
162
163
164 G4hMultipleScattering* hmsc = new G4hMultipleScattering("ionmsc");
165
166
168 G4NuclearStopping* pnuc = nullptr;
169 if(nielEnergyLimit > 0.0) {
170 pnuc = new G4NuclearStopping();
172 }
173
174
176
177
180
181
182 G4PhotoElectricEffect* pe = new G4PhotoElectricEffect();
183 G4VEmModel* peModel = new G4LivermorePhotoElectricModel();
185 if(polar) {
187 }
188
189
190 G4ComptonScattering* cs = new G4ComptonScattering;
192 G4VEmModel* cModel = nullptr;
193 if(polar) {
194 cModel = new G4LowEPPolarizedComptonModel();
195 } else {
196 cModel = new G4LowEPComptonModel();
197 }
200
201
202 G4GammaConversion* gc = new G4GammaConversion();
203 G4VEmModel* conv = new G4BetheHeitler5DModel();
205
206
207 G4RayleighScattering* rl = new G4RayleighScattering();
208 if(polar) {
209 rl->
SetEmModel(
new G4LivermorePolarizedRayleighModel());
210 }
211
213 G4GammaGeneralProcess*
sp =
new G4GammaGeneralProcess();
214 sp->AddEmProcess(pe);
215 sp->AddEmProcess(cs);
216 sp->AddEmProcess(gc);
217 sp->AddEmProcess(rl);
220 } else {
225 }
226
227
229
230
231
232 G4GoudsmitSaundersonMscModel* msc1 = new G4GoudsmitSaundersonMscModel();
233 G4WentzelVIModel* msc2 = new G4WentzelVIModel();
237
238 G4eCoulombScatteringModel* ssm = new G4eCoulombScatteringModel();
239 G4CoulombScattering* ss = new G4CoulombScattering();
244
245
246 G4eIonisation* eioni = new G4eIonisation();
248 G4VEmModel* theIoniMod = new G4PenelopeIonisationModel();
251
252
253 G4eBremsstrahlung* brem = new G4eBremsstrahlung();
254 G4SeltzerBergerModel* br1 = new G4SeltzerBergerModel();
255 G4eBremsstrahlungRelModel* br2 = new G4eBremsstrahlungRelModel();
261
262 G4ePairProduction* ee = new G4ePairProduction();
263
264
269
270
272
273
274
275 msc1 = new G4GoudsmitSaundersonMscModel();
276 msc2 = new G4WentzelVIModel();
280
281 ssm = new G4eCoulombScatteringModel();
282 ss = new G4CoulombScattering();
287
288
289 eioni = new G4eIonisation();
291 G4VEmModel* pen = new G4PenelopeIonisationModel();
294
295
296 brem = new G4eBremsstrahlung();
297 br1 = new G4SeltzerBergerModel();
298 br2 = new G4eBremsstrahlungRelModel();
304
305
306 auto anni = new G4eplusAnnihilation();
308 anni->SetEmModel(new G4eplusTo2or3GammaModel());
309 }
310
311
317
318
320 G4ionIonisation* ionIoni = new G4ionIonisation();
321 ionIoni->
SetEmModel(
new G4LindhardSorensenIonModel());
325
326
328
329
331}
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
G4bool GeneralProcessActive() const
static G4VEmFluctuationModel * ModelOfFluctuations(G4bool isIon=false)
static G4GenericIon * GenericIon()
static G4LossTableManager * Instance()
void SetGammaGeneralProcess(G4VEmProcess *)
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