52 :
G4VProcess(processName, theType), fFieldTrack(
'0')
57 fGhostPreStepPoint = fGhostStep->GetPreStepPoint();
58 fGhostPostStepPoint = fGhostStep->GetPostStepPoint();
63 fGhostWorld =
nullptr;
90 fGhostWorldName = parallelWorldName;
91 fGhostWorld = fTransportationManager->GetParallelWorld(fGhostWorldName);
92 fGhostNavigator = fTransportationManager->GetNavigator(fGhostWorld);
101 fGhostWorldName = parallelWorld->
GetName();
102 fGhostWorld = parallelWorld;
103 fGhostNavigator = fTransportationManager->GetNavigator(fGhostWorld);
112 if (partName ==
"geantino")
return false;
113 if (partName ==
"chargedgeantino")
return false;
116 if (pdgCode == 11 || pdgCode == 2212)
return false;
117 pdgCode = std::abs(pdgCode);
118 if (pdgCode == 22)
return false;
119 if (pdgCode == 12 || pdgCode == 14 || pdgCode == 16)
return false;
132 if (fGhostNavigator !=
nullptr) {
133 fNavigatorID = fTransportationManager->ActivateNavigator(fGhostNavigator);
137 "G4ParallelWorldScoringProcess is used for tracking without having a parallel "
145 fOldGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
146 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
147 fNewGhostTouchable = fOldGhostTouchable;
148 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
153 fGhostPreStepPoint->SetStepStatus(
fUndefined);
154 fGhostPostStepPoint->SetStepStatus(
fUndefined);
178 fOldGhostTouchable = fGhostPostStepPoint->GetTouchableHandle();
180 if (fOldGhostTouchable->GetVolume() !=
nullptr) {
181 aSD = fOldGhostTouchable->GetVolume()->GetLogicalVolume()->GetSensitiveDetector();
185 fGhostPreStepPoint->SetSensitiveDetector(aSD);
187 fNewGhostTouchable = fOldGhostTouchable;
189 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
190 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
191 if (fNewGhostTouchable->GetVolume() !=
nullptr) {
192 fGhostPostStepPoint->SetSensitiveDetector(
193 fNewGhostTouchable->GetVolume()->GetLogicalVolume()->GetSensitiveDetector());
196 fGhostPostStepPoint->SetSensitiveDetector(
nullptr);
231 fOldGhostTouchable = fGhostPostStepPoint->GetTouchableHandle();
233 if (fOldGhostTouchable->GetVolume() !=
nullptr) {
234 aSD = fOldGhostTouchable->GetVolume()->GetLogicalVolume()->GetSensitiveDetector();
237 fGhostPreStepPoint->SetSensitiveDetector(aSD);
241 fNewGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
245 fNewGhostTouchable = fOldGhostTouchable;
248 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
249 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
251 if (fNewGhostTouchable->GetVolume() !=
nullptr) {
252 fGhostPostStepPoint->SetSensitiveDetector(
253 fNewGhostTouchable->GetVolume()->GetLogicalVolume()->GetSensitiveDetector());
256 fGhostPostStepPoint->SetSensitiveDetector(
nullptr);
280 if (endTrack_G4MT_TLS_ ==
nullptr) endTrack_G4MT_TLS_ =
new G4FieldTrack(
'0');
283 if (eLimited_G4MT_TLS_ ==
nullptr) eLimited_G4MT_TLS_ =
new ELimited;
284 ELimited& eLimited = *eLimited_G4MT_TLS_;
289 if (previousStepSize > 0.) {
290 fGhostSafety -= previousStepSize;
292 if (fGhostSafety < 0.) fGhostSafety = 0.0;
295 if (currentMinimumStep <= fGhostSafety && currentMinimumStep > 0.) {
297 returnedStep = currentMinimumStep;
299 proposedSafety = fGhostSafety - currentMinimumStep;
305 returnedStep = fPathFinder->ComputeStep(fFieldTrack, currentMinimumStep, fNavigatorID,
311 fGhostSafety = fGhostNavigator->ComputeSafety(endTrack.
GetPosition());
317 proposedSafety = fGhostSafety;
322 returnedStep *= (1.0 + 1.0e-9);
343void G4ParallelWorldScoringProcess::CopyStep(
const G4Step& step)
361 else if (fGhostPostStepPoint->GetStepStatus() ==
fGeomBoundary) {
368 G4cout <<
"In mass geometry ------------------------------------------------" <<
G4endl;
376 G4cout <<
"NoProcessAssigned";
380 G4cout <<
" PostStepPoint : ";
392 G4cout <<
"NoProcessAssigned";
397 G4cout <<
"In ghost geometry ------------------------------------------------" <<
G4endl;
398 G4cout <<
" StepLength : " << fGhostStep->GetStepLength() / mm
399 <<
" TotalEnergyDeposit : " << fGhostStep->GetTotalEnergyDeposit() / MeV <<
G4endl;
400 G4cout <<
" PreStepPoint : " << fGhostStep->GetPreStepPoint()->GetPhysicalVolume()->GetName()
401 <<
" [" << fGhostStep->GetPreStepPoint()->GetTouchable()->GetReplicaNumber() <<
" ]"
403 if (fGhostStep->GetPreStepPoint()->GetProcessDefinedStep() !=
nullptr) {
404 G4cout << fGhostStep->GetPreStepPoint()->GetProcessDefinedStep()->GetProcessName();
407 G4cout <<
"NoProcessAssigned";
410 G4cout <<
" " << fGhostStep->GetPreStepPoint()->GetPosition() <<
G4endl;
411 G4cout <<
" PostStepPoint : ";
412 if (fGhostStep->GetPostStepPoint()->GetPhysicalVolume() !=
nullptr) {
413 G4cout << fGhostStep->GetPostStepPoint()->GetPhysicalVolume()->GetName() <<
" ["
414 << fGhostStep->GetPostStepPoint()->GetTouchable()->GetReplicaNumber() <<
" ]";
420 if (fGhostStep->GetPostStepPoint()->GetProcessDefinedStep() !=
nullptr) {
421 G4cout << fGhostStep->GetPostStepPoint()->GetProcessDefinedStep()->GetProcessName();
424 G4cout <<
"NoProcessAssigned";
427 G4cout <<
" " << fGhostStep->GetPostStepPoint()->GetPosition()
428 <<
" == " << fGhostStep->GetTrack()->GetMomentumDirection() <<
G4endl;
G4double condition(const G4ErrorSymMatrix &m)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
@ NotCandidateForSelection
G4GLOB_DLL std::ostream G4cout
static void Update(G4FieldTrack *, const G4Track *)
G4ThreeVector GetPosition() const
void StartTracking(G4Track *) override
G4VParticleChange * AtRestDoIt(const G4Track &, const G4Step &) override
G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) override
G4bool IsAtRestRequired(G4ParticleDefinition *partDef)
void SetParallelWorld(G4String parallelWorldName)
~G4ParallelWorldScoringProcess() override
G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &) override
G4ParallelWorldScoringProcess(const G4String &processName="ParaWorldScore", G4ProcessType theType=fParameterisation)
G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &) override
G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double, G4double, G4double &, G4GPILSelection *) override
void Verbose(const G4Step &) const
G4double AtRestGetPhysicalInteractionLength(const G4Track &, G4ForceCondition *) override
G4int GetPDGEncoding() const
const G4String & GetParticleName() const
static G4PathFinder * GetInstance()
G4StepStatus GetStepStatus() const
void SetStepStatus(const G4StepStatus aValue)
const G4VProcess * GetProcessDefinedStep() const
const G4ThreeVector & GetPosition() const
G4VPhysicalVolume * GetPhysicalVolume() const
G4SteppingControl GetControlFlag() const
G4Track * GetTrack() const
void SetStepLength(G4double value)
void SetNonIonizingEnergyDeposit(G4double value)
G4StepPoint * GetPreStepPoint() const
G4double GetNonIonizingEnergyDeposit() const
G4double GetStepLength() const
G4double GetTotalEnergyDeposit() const
void SetControlFlag(G4SteppingControl StepControlFlag)
void SetTotalEnergyDeposit(G4double value)
G4StepPoint * GetPostStepPoint() const
void SetTrack(G4Track *value)
G4VPhysicalVolume * GetVolume() const
const G4ThreeVector & GetPosition() const
G4int GetCurrentStepNumber() const
const G4ThreeVector & GetMomentumDirection() const
static G4TransportationManager * GetTransportationManager()
const G4String & GetName() const
G4VProcess(const G4String &aName="NoName", G4ProcessType aType=fNotDefined)
G4VParticleChange * pParticleChange
const G4String & GetProcessName() const
G4bool Hit(G4Step *aStep)