264{
266 if(!flagPIXE && !activePIXEMedia[coupleIndex]) { return; }
267 if(eLossMax <= 0.0 || truelength <= 0.0) { return; }
268
269
275
276
277 const G4Track* track = step.
GetTrack();
280
281
282 G4double gCut = (*theCoupleTable->GetEnergyCutsVector(0))[coupleIndex];
283 if(ignoreCuts) { gCut = 0.0; }
286 eCut = (*theCoupleTable->GetEnergyCutsVector(1))[coupleIndex];
287 if(ignoreCuts) { eCut = 0.0; }
288 }
289
290
291
292
293 const G4Material* material = preStep->
GetMaterial();
295 const G4double* theAtomNumDensityVector =
298
299
300 for(std::size_t i=0; i<nelm; ++i) {
301 G4int Z = (*theElementVector)[i]->GetZasInt();
302 if(activeZ[Z] && Z < 93) {
304 std::min(9,(*theElementVector)[i]->GetNbOfAtomicShells());
305 G4double rho = truelength*theAtomNumDensityVector[i];
306
307 for(
G4int ii=0; ii<nshells; ++ii) {
311
312 if(gCut > bindingEnergy) { break; }
313
314 if(eLossMax > bindingEnergy) {
317
318
319 if(sig > 0.0) {
322
323
324 do {
326 if( stot > 1.0 || eLossMax < bindingEnergy) { break; }
327
328 vdyn.clear();
330 std::size_t nsec = vdyn.size();
331 if(nsec > 0) {
334 for(std::size_t j=0; j<nsec; ++j) {
335 G4DynamicParticle* dp = vdyn[j];
337
338
339 if(eLossMax >= e) {
340 eLossMax -= e;
341 G4Track* t = new G4Track(dp, time, r);
342
343
346 } else {
348 }
349 tracks.push_back(t);
350 } else {
351 delete dp;
352 }
353 }
354 }
355
356 } while (stot < 1.0);
357 }
358 }
359 }
360 }
361 }
362 return;
363}
std::vector< const G4Element * > G4ElementVector
G4double G4Log(G4double x)
CLHEP::Hep3Vector G4ThreeVector
G4double BindingEnergy() const
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const
const G4ElementVector * GetElementVector() const
const G4double * GetVecNbOfAtomsPerVolume() const
std::size_t GetNumberOfElements() const
G4double GetGlobalTime() const
G4Material * GetMaterial() const
const G4ThreeVector & GetPosition() const
G4double GetKineticEnergy() const
G4Track * GetTrack() const
G4StepPoint * GetPreStepPoint() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
G4ParticleDefinition * GetDefinition() const
void SetCreatorModelID(const G4int id)
virtual const G4AtomicShell * GetAtomicShell(G4int Z, G4AtomicShellEnumerator shell)=0
G4bool CheckAugerActiveRegion(G4int coupleIndex)
void GenerateParticles(std::vector< G4DynamicParticle * > *secVect, const G4AtomicShell *, G4int Z, G4int coupleIndex)
virtual G4double GetShellIonisationCrossSectionPerAtom(const G4ParticleDefinition *, G4int Z, G4AtomicShellEnumerator shell, G4double kinE, const G4Material *mat=nullptr)=0
G4double bindingEnergy(G4int A, G4int Z)