145{
148 }
150
153
154
155 G4hMultipleScattering* hmsc = new G4hMultipleScattering("ionmsc");
156
157
159 G4NuclearStopping* pnuc = nullptr;
160 if(nielEnergyLimit > 0.0) {
161 pnuc = new G4NuclearStopping();
163 }
164
165
167
168 G4PhotoElectricEffect* pe = new G4PhotoElectricEffect();
169 G4VEmModel* peModel = new G4LivermorePhotoElectricModel();
173 }
174
175 G4ComptonScattering* cs = new G4ComptonScattering();
177
178 G4GammaConversion* gc = new G4GammaConversion();
181 }
182
183 G4RayleighScattering* rl = new G4RayleighScattering();
185 rl->
SetEmModel(
new G4LivermorePolarizedRayleighModel());
186 }
187
189 G4GammaGeneralProcess*
sp =
new G4GammaGeneralProcess();
190 sp->AddEmProcess(pe);
191 sp->AddEmProcess(cs);
192 sp->AddEmProcess(gc);
193 sp->AddEmProcess(rl);
196 } else {
201 }
202
203
205
206 G4UrbanMscModel* msc1 = new G4UrbanMscModel();
208
209 G4eIonisation* eIoni = new G4eIonisation();
210
211 G4eBremsstrahlung* brem = new G4eBremsstrahlung();
212 G4SeltzerBergerModel* br1 = new G4SeltzerBergerModel();
213 G4eBremsstrahlungRelModel* br2 = new G4eBremsstrahlungRelModel();
219
220 G4ePairProduction* ee = new G4ePairProduction();
221
225
226
228
229 msc1 = new G4UrbanMscModel();
231
232 eIoni = new G4eIonisation();
233
234 brem = new G4eBremsstrahlung();
235 br1 = new G4SeltzerBergerModel();
236 br2 = new G4eBremsstrahlungRelModel();
242
245
246
247 auto anni = new G4eplusAnnihilation();
249 anni->SetEmModel(new G4eplusTo2or3GammaModel());
250 }
253
254
256 G4ionIonisation* ionIoni = new G4ionIonisation();
257 auto fluc = new G4IonFluctuations();
259 ionIoni->
SetEmModel(
new G4LindhardSorensenIonModel());
263
264
266
267
269}
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
G4bool Use3GammaAnnihilationOnFly() const
static G4GenericIon * GenericIon()
static G4LossTableManager * Instance()
void SetGammaGeneralProcess(G4VEmProcess *)
G4bool RegisterProcess(G4VProcess *process, G4ParticleDefinition *particle)
static G4PhysicsListHelper * GetPhysicsListHelper()
static G4Positron * Positron()
void SetLowEnergyLimit(G4double)
void SetAngularDistribution(G4VEmAngularDistribution *)
void SetEmModel(G4VEmModel *, G4int index=0)
void SetMaxKinEnergy(G4double e)
void SetFluctModel(G4VEmFluctuationModel *)
void SetEmModel(G4VEmModel *, G4int index=0)
const G4String & GetPhysicsName() const