147{
150 }
154
155
156 G4hMultipleScattering* hmsc = new G4hMultipleScattering("ionmsc");
157
158
160
161
163 G4NuclearStopping* pnuc = nullptr;
164 if(nielEnergyLimit > 0.0) {
165 pnuc = new G4NuclearStopping();
167 }
168
169
170
171 G4double PenelopeHighEnergyLimit = 1.0*CLHEP::GeV;
172
173
175
176
177 G4PhotoElectricEffect* thePhotoElectricEffect = new G4PhotoElectricEffect();
178 thePhotoElectricEffect->
SetEmModel(
new G4PEEffectFluoModel());
179 G4PenelopePhotoElectricModel* thePEPenelopeModel = new G4PenelopePhotoElectricModel();
181 thePhotoElectricEffect->
AddEmModel(0, thePEPenelopeModel);
182
183
184 G4ComptonScattering* theComptonScattering = new G4ComptonScattering();
185 G4PenelopeComptonModel* theComptonPenelopeModel = new G4PenelopeComptonModel();
186 theComptonScattering->
SetEmModel(
new G4KleinNishinaModel());
188 theComptonScattering->
AddEmModel(0, theComptonPenelopeModel);
189
190
191 G4GammaConversion* theGammaConversion = new G4GammaConversion();
192 G4PenelopeGammaConversionModel* theGCPenelopeModel = new G4PenelopeGammaConversionModel();
194 theGammaConversion->
AddEmModel(0, theGCPenelopeModel);
195
196
197 G4RayleighScattering* theRayleigh = new G4RayleighScattering();
198 G4PenelopeRayleighModel* theRayleighPenelopeModel = new G4PenelopeRayleighModel();
199 theRayleigh->
SetEmModel(theRayleighPenelopeModel);
200
205
206
208
209
210 G4GoudsmitSaundersonMscModel* msc1 = new G4GoudsmitSaundersonMscModel();
211 G4WentzelVIModel* msc2 = new G4WentzelVIModel();
215
216 G4eCoulombScatteringModel* ssm = new G4eCoulombScatteringModel();
217 G4CoulombScattering* ss = new G4CoulombScattering();
222
223
224 G4eIonisation* eioni = new G4eIonisation();
226 G4PenelopeIonisationModel* theIoniPenelope = new G4PenelopeIonisationModel();
229
230
231 G4eBremsstrahlung* brem = new G4eBremsstrahlung();
232 G4PenelopeBremsstrahlungModel* theBremPenelope = new G4PenelopeBremsstrahlungModel();
235
236 G4ePairProduction* ee = new G4ePairProduction();
237
238
243
244
246
247
248 msc1 = new G4GoudsmitSaundersonMscModel();
249 msc2 = new G4WentzelVIModel();
253
254 ssm = new G4eCoulombScatteringModel();
255 ss = new G4CoulombScattering();
260
261
262 eioni = new G4eIonisation();
264 theIoniPenelope = new G4PenelopeIonisationModel();
267
268
269 brem = new G4eBremsstrahlung();
270 theBremPenelope = new G4PenelopeBremsstrahlungModel();
273
274
275 auto anni = new G4eplusAnnihilation();
276 auto theAnnPenelope = new G4PenelopeAnnihilationModel();
277 theAnnPenelope->SetHighEnergyLimit(PenelopeHighEnergyLimit);
278 anni->AddEmModel(0, theAnnPenelope);
279
280
286
287
289 G4ionIonisation* ionIoni = new G4ionIonisation();
290 ionIoni->
SetEmModel(
new G4LindhardSorensenIonModel());
294
295
297
298
300}
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()
G4double MaxNIELEnergy() const
G4double MscEnergyLimit() 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 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