120 if(fpVerbose !=
nullptr) fpVerbose->DoItStarted();
125 std::size_t initialSize = mainList->
size();
129 for(std::size_t i = 0 ; i < initialSize ; ++i)
135 if (track ==
nullptr)
138 exceptionDescription <<
"No track was pop back the main track list.";
152 fpTrackingManager->EndTracking(track);
158#if defined (DEBUG_MEM) && defined (DEBUG_MEM_DOIT)
159 MemStat mem_first, mem_second, mem_diff;
165#if defined (DEBUG_MEM) && defined (DEBUG_MEM_DOIT)
167 mem_diff = mem_intermediaire-mem_first;
168 G4cout <<
"\t\t >> || MEM || In DoIT with track "
174#if defined (DEBUG_MEM) && defined (DEBUG_MEM_DOIT)
176 mem_diff = mem_second-mem_first;
177 G4cout <<
"\t >> || MEM || In DoIT with track "
179 <<
", diff is : " << mem_diff <<
G4endl;
184 fpTrackContainer->MergeSecondariesWithMainList();
185 fpTrackContainer->KillTracks();
186 fLeadingTracks.Reset();
297 MemStat mem_first, mem_second, mem_diff;
305 if(fpVerbose !=
nullptr) fpVerbose->PreStepVerbose(fpTrack);
308 if(fpProcessInfo ==
nullptr)
311 exceptionDescription <<
"No process info found for particle :"
312 << fpTrack->GetDefinition()->GetParticleName();
314 "ITStepProcessor0012",
316 exceptionDescription);
325 if(fpProcessInfo->MAXofPostStepLoops == 0 &&
326 fpProcessInfo->MAXofAlongStepLoops == 0
327 && fpProcessInfo->MAXofAtRestLoops == 0)
347 if(fpVerbose !=
nullptr) fpVerbose->NewStep();
354 fpNavigator->SetNavigatorState(fpITrack->GetTrackingInfo()->GetNavigatorState());
364 mem_diff = mem_intermediaire-mem_first;
365 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After dealing with navigator with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
370 if(fpProcessInfo->MAXofAtRestLoops > 0 && fpProcessInfo->fpAtRestDoItVector
378 fpStep->GetPostStepPoint()->SetStepStatus(fpState->fStepStatus);
382 if(fpVerbose !=
nullptr) fpVerbose->AtRestDoItInvoked();
391 if(fpITrack ==
nullptr)
394 exceptionDescription <<
" !!! TrackID : " << fpTrack->GetTrackID()
395 <<
G4endl<<
" !!! Track status : "<< fpTrack->GetTrackStatus() <<
G4endl
396 <<
" !!! Particle Name : "<< fpTrack -> GetDefinition() -> GetParticleName() <<
G4endl
397 <<
"No G4ITStepProcessor::fpITrack found" <<
G4endl;
400 "ITStepProcessor0013",
402 exceptionDescription);
406 if(!fpITrack->GetTrackingInfo()->IsLeadingStep())
412 fpStep->GetPostStepPoint()->SetProcessDefinedStep(fpTransportation);
418 mem_diff = mem_intermediaire-mem_first;
419 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After FindTransportationStep() with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
423 fpTrack->SetStepLength(fpState->fPhysicalStep);
424 fpStep->SetStepLength(fpState->fPhysicalStep);
426 G4double GeomStepLength = fpState->fPhysicalStep;
429 fpStep->GetPostStepPoint()->SetStepStatus(fpState->fStepStatus);
436 mem_diff = mem_intermediaire-mem_first;
437 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After InvokeAlongStepDoItProcs() with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
442 if(fpVerbose !=
nullptr) fpVerbose->AlongStepDoItAllDone();
449 fpState->fEndpointSafOrigin = fpPostStepPoint->GetPosition();
451 fpState->fEndpointSafety =
452 std::max(fpState->fProposedSafety - GeomStepLength, kCarTolerance);
454 fpStep->GetPostStepPoint()->SetSafety(fpState->fEndpointSafety);
456 if(
GetIT(fpTrack)->GetTrackingInfo()->IsLeadingStep())
463 mem_diff = mem_intermediaire-mem_first;
464 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After InvokePostStepDoItProcs() with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
468 if(fpVerbose !=
nullptr) fpVerbose->StepInfoForLeadingTrack();
475 fpStep->GetPostStepPoint()->SetProcessDefinedStep(fpTransportation);
479 mem_diff = mem_intermediaire-mem_first;
480 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After InvokeTransportationProc() with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
486 if(fpVerbose !=
nullptr) fpVerbose->PostStepDoItAllDone();
490 fpNavigator->ResetNavigatorState();
494 mem_diff = mem_intermediaire-mem_first;
495 G4cout <<
"\t\t\t >> || MEM || G4ITStepProcessor::DoStepping || After fpNavigator->SetNavigatorState with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
503 fpTrack->AddTrackLength(fpStep->GetStepLength());
504 fpTrack->IncrementCurrentStepNumber();
512 if(fpVerbose !=
nullptr) fpVerbose->PostStepVerbose(fpTrack);
542 fpTrackingManager->AppendStep(fpTrack, fpStep);
547 mem_diff = mem_intermediaire-mem_first;
548 G4cout <<
"\t\t\t >> || MEM || End of DoStepping() with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
562 fpStep->SetStepLength(0.);
563 fpTrack->SetStepLength(0.);
566 fpState->fSelectedAtRestDoItVector;
569 for(std::size_t np = 0; np < fpProcessInfo->MAXofAtRestLoops; ++np)
575 if(selectedAtRestDoItVector[fpProcessInfo->MAXofAtRestLoops - np - 1] !=
InActivated)
589 fpCurrentProcess->SetProcessState(fpTrackingInfo->GetProcessState(fpCurrentProcess
591 fpParticleChange = fpCurrentProcess->AtRestDoIt(*fpTrack, *fpStep);
592 fpCurrentProcess->ResetProcessState();
595 fpStep->GetPostStepPoint()->SetProcessDefinedStep(fpCurrentProcess);
598 fpParticleChange->UpdateStepForAtRest(fpStep);
605 fpTrack->SetTrackStatus(fpParticleChange->GetTrackStatus());
608 fpParticleChange->Clear();
612 fpStep->UpdateTrack();
631 MemStat mem_first, mem_second, mem_diff;
646 for(std::size_t ci = 0; ci < fpProcessInfo->MAXofAlongStepLoops; ++ci)
650 if(fpCurrentProcess ==
nullptr)
continue;
653 fpCurrentProcess->SetProcessState(fpTrackingInfo->GetProcessState(fpCurrentProcess
655 fpParticleChange = fpCurrentProcess->AlongStepDoIt(*fpTrack, *fpStep);
659 mem_diff = mem_intermediaire-mem_first;
660 G4cout <<
"\t\t\t >> || MEM || After calling AlongStepDoIt for " << fpCurrentProcess->GetProcessName() <<
" and track "<< fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
664 fpCurrentProcess->ResetProcessState();
667 fpParticleChange->UpdateStepForAlongStep(fpStep);
671 if(fpVerbose !=
nullptr) fpVerbose->AlongStepDoItOneByOne();
679 fpTrack->SetTrackStatus(fpParticleChange->GetTrackStatus());
682 fpParticleChange->Clear();
687 mem_diff = mem_intermediaire-mem_first;
688 G4cout <<
"\t\t\t >> || MEM || After looping on processes with " << fpTrack->GetTrackID() <<
", diff is : " << mem_diff <<
G4endl;
691 fpStep->UpdateTrack();
695 if(fNewStatus ==
fAlive && fpTrack->GetKineticEnergy() <=
DBL_MIN)
698 if(fpProcessInfo->MAXofAtRestLoops>0) fNewStatus =
fStopButAlive;
700 fpTrack->SetTrackStatus( fNewStatus );
713 std::size_t _MAXofPostStepLoops = fpProcessInfo->MAXofPostStepLoops;
715 ->fSelectedPostStepDoItVector;
719 for(std::size_t np = 0; np < _MAXofPostStepLoops; ++np)
725 G4int Cond = selectedPostStepDoItVector[_MAXofPostStepLoops
745 for(std::size_t np1 = np + 1; np1 < _MAXofPostStepLoops; ++np1)
747 G4int Cond2 = selectedPostStepDoItVector[_MAXofPostStepLoops
763 fpCurrentProcess = (
G4VITProcess*) (*fpProcessInfo->fpPostStepDoItVector)[(
G4int)np];
765 fpCurrentProcess->SetProcessState(fpTrackingInfo->GetProcessState(fpCurrentProcess
767 fpParticleChange = fpCurrentProcess->PostStepDoIt(*fpTrack, *fpStep);
769 fpCurrentProcess->ResetProcessState();
772 fpParticleChange->UpdateStepForPostStep(fpStep);
776 if(fpVerbose !=
nullptr) fpVerbose->PostStepDoItOneByOne();
780 fpStep->UpdateTrack();
789 fpTrack->SetTrackStatus(fpParticleChange->GetTrackStatus());
792 fpParticleChange->Clear();
803 double physicalStep(0.);
805 fpTransportation = fpProcessInfo->fpTransportation;
808 if(fpTrack ==
nullptr)
811 exceptionDescription <<
"No G4ITStepProcessor::fpTrack found";
812 G4Exception(
"G4ITStepProcessor::FindTransportationStep",
813 "ITStepProcessor0013",
815 exceptionDescription);
819 if(fpITrack ==
nullptr)
822 exceptionDescription <<
"No G4ITStepProcessor::fITrack";
823 G4Exception(
"G4ITStepProcessor::FindTransportationStep",
824 "ITStepProcessor0014",
826 exceptionDescription);
829 if((fpITrack->GetTrack()) ==
nullptr)
832 exceptionDescription <<
"No G4ITStepProcessor::fITrack->GetTrack()";
833 G4Exception(
"G4ITStepProcessor::FindTransportationStep",
834 "ITStepProcessor0015",
836 exceptionDescription);
840 if(fpTransportation !=
nullptr)
842 fpTransportation->SetProcessState(fpTrackingInfo->GetProcessState(fpTransportation
844 fpTransportation->ComputeStep(*fpTrack, *fpStep, fTimeStep, physicalStep);
847 fpTransportation->ResetProcessState();
857 fpState->fPhysicalStep = physicalStep;
864 std::size_t _MAXofPostStepLoops = fpProcessInfo->MAXofPostStepLoops;
866 ->fSelectedPostStepDoItVector;
870 for(std::size_t np = 0; np < _MAXofPostStepLoops; ++np)
876 G4int Cond = selectedPostStepDoItVector[_MAXofPostStepLoops - np - 1];
893 for(std::size_t np1 = np + 1; np1 < _MAXofPostStepLoops; ++np1)
895 G4int Cond2 = selectedPostStepDoItVector[_MAXofPostStepLoops - np1 - 1];
G4double GetCharge() const
G4ProcessManager * GetProcessManager() const
G4bool GetApplyCutsFlag() const