176{
178
180 G4int Ztarget = ((*(aTrack.
GetMaterial()->GetElementVector()))[0])->GetZasInt();
181 G4int Atarget = ((*(aTrack.
GetMaterial()->GetElementVector()))[0])->GetAtomicMassAmu();
189
190 for (
G4int i = 0; i < Nbelements; ++i)
191 {
192 Ztarget = ((*(aTrack.
GetMaterial()->GetElementVector()))[i])->GetZasInt();
193 Atarget = ((*(aTrack.
GetMaterial()->GetElementVector()))[i])->GetAtomicMassAmu();
194 NIEdep = NIEdep + moleculeMass*FractionMass[i] / Atarget*G_Lindhard_Rob(aTrack.
GetKineticEnergy(), Zinc, Ainc, Ztarget, Atarget);
195 }
196
197 WorkFunctionTable::iterator matWF;
198 matWF = tableWF.find(mat);
199
200 if (matWF == tableWF.end())
201 {
202 G4String str = "Material ";
203 str += mat + " not found!";
204 G4Exception(
"G4MicroElecCapture::PostStepGPIL",
"em0002",
206 return nullptr;
207 }
208 else
209 {
210 G4MicroElecMaterialStructure* str = matWF->second;
213
215
216 if (IncPartName == "e-")
217 {
218
220 {
223 }
224 else
225 {
229 }
230 }
231 else
232 {
233 if ((IncPartName == "Genericion") || (IncPartName == "alpha")
234 || (IncPartName == "He3") || (IncPartName == "deuteron")
235 || (IncPartName == "triton") || (IncPartName == "proton"))
236 {
239 }
240 else
241 {
244 }
245 }
246 }
247
248 fParticleChange.SetProposedKineticEnergy(0.0);
250}
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
const G4double * GetFractionVector() const
G4double GetMassOfMolecule() const
std::size_t GetNumberOfElements() const
G4double GetInitialEnergy()
G4int GetAtomicNumber() const
G4int GetAtomicMass() const