58 fWeightWindowAlgorithm(aWeightWindowAlgorithm),
59 fWeightWindowStore(aWWStore),
60 fPlaceOfAction(placeOfAction)
62 if (TrackTerminator !=
nullptr)
70 if (fParticleChange ==
nullptr)
72 G4Exception(
"G4WeightWindowProcess::G4WeightWindowProcess()",
74 "Failed allocation of G4ParticleChange !");
79 fGhostPreStepPoint = fGhostStep->GetPreStepPoint();
80 fGhostPostStepPoint = fGhostStep->GetPostStepPoint();
97 delete fPostStepAction;
98 delete fParticleChange;
115 fGhostWorldName = parallelWorldName;
116 fGhostWorld = fTransportationManager->GetParallelWorld(fGhostWorldName);
117 fGhostNavigator = fTransportationManager->GetNavigator(fGhostWorld);
127 fGhostWorldName = parallelWorld->
GetName();
128 fGhostWorld = parallelWorld;
129 fGhostNavigator = fTransportationManager->GetNavigator(fGhostWorld);
146 if(fGhostNavigator !=
nullptr)
147 { fNavigatorID = fTransportationManager->ActivateNavigator(fGhostNavigator); }
150 G4Exception(
"G4WeightWindowProcess::StartTracking",
152 "G4WeightWindowProcess is used for tracking without having a parallel world assigned");
166 fOldGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
167 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
168 fNewGhostTouchable = fOldGhostTouchable;
169 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
199 fOldGhostTouchable = fGhostPostStepPoint->GetTouchableHandle();
210 fNewGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
222 fNewGhostTouchable = fOldGhostTouchable;
225 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
226 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
250 G4GeometryCell postCell(*(fGhostPostStepPoint->GetPhysicalVolume()),
251 fGhostPostStepPoint->GetTouchable()->GetReplicaNumber());
253 fWeightWindowAlgorithm.Calculate(aTrack.
GetWeight(),
254 fWeightWindowStore.GetLowerWeight(postCell,
256 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
272 fWeightWindowAlgorithm.Calculate(aTrack.
GetWeight(),
273 fWeightWindowStore.GetLowerWeight(postCell,
275 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
279 return fParticleChange;
302 if (previousStepSize > 0.)
303 { fGhostSafety -= previousStepSize; }
306 if (fGhostSafety < 0.) fGhostSafety = 0.0;
311 if (currentMinimumStep <= fGhostSafety && currentMinimumStep > 0.)
314 returnedStep = currentMinimumStep;
316 proposedSafety = fGhostSafety - currentMinimumStep;
325 = fPathFinder->ComputeStep(fFieldTrack,currentMinimumStep,fNavigatorID,
333 fGhostSafety = fGhostNavigator->ComputeSafety(fEndTrack.GetPosition());
340 proposedSafety = fGhostSafety;
346 returnedStep *= (1.0 + 1.0e-9);
388void G4WeightWindowProcess::CopyStep(
const G4Step & step)
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 *)
static G4PathFinder * GetInstance()
G4StepStatus GetStepStatus() const
const G4VTouchable * GetTouchable() const
void SetStepStatus(const G4StepStatus aValue)
G4VPhysicalVolume * GetPhysicalVolume() const
G4SteppingControl GetControlFlag() const
G4Track * GetTrack() const
void SetStepLength(G4double value)
G4StepPoint * GetPreStepPoint() const
G4double GetStepLength() const
G4double GetTotalEnergyDeposit() const
void SetControlFlag(G4SteppingControl StepControlFlag)
void SetTotalEnergyDeposit(G4double value)
G4StepPoint * GetPostStepPoint() const
void SetTrack(G4Track *value)
virtual G4int GetReplicaNumber(G4int depth=0) const
G4VPhysicalVolume * GetVolume() const
G4double GetWeight() const
const G4ThreeVector & GetPosition() const
G4int GetCurrentStepNumber() const
const G4ThreeVector & GetMomentumDirection() const
G4double GetKineticEnergy() const
static G4TransportationManager * GetTransportationManager()
virtual void Initialize(const G4Track &)
const G4String & GetName() const
G4VProcess(const G4String &aName="NoName", G4ProcessType aType=fNotDefined)
G4VParticleChange * pParticleChange
const G4String & GetProcessName() const
virtual ~G4WeightWindowProcess()
G4WeightWindowProcess(const G4VWeightWindowAlgorithm &aWeightWindowAlgorithm, const G4VWeightWindowStore &aWWStore, const G4VTrackTerminator *TrackTerminator, G4PlaceOfAction placeOfAction, const G4String &aName="WeightWindowProcess", G4bool para=false)
void SetParallelWorld(const G4String ¶llelWorldName)
virtual G4double PostStepGetPhysicalInteractionLength(const G4Track &aTrack, G4double previousStepSize, G4ForceCondition *condition)
virtual G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &)
virtual G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double, G4double, G4double &, G4GPILSelection *)
virtual G4double AtRestGetPhysicalInteractionLength(const G4Track &, G4ForceCondition *)
void StartTracking(G4Track *)
virtual void KillTrack() const
virtual G4VParticleChange * AtRestDoIt(const G4Track &, const G4Step &)
virtual const G4String & GetName() const
virtual G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &)