194{
195
196 fParticleChange->Initialize(aTrack);
197
198 if(fParaflag) {
199 fOldGhostTouchable = fGhostPostStepPoint->GetTouchableHandle();
200
201 CopyStep(aStep);
202
203 if(fOnBoundary)
204 {
205
206
207
208
209
210 fNewGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
211
212 }
213 else
214 {
215
216
217
218
219
220
221
222 fNewGhostTouchable = fOldGhostTouchable;
223 }
224
225 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
226 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
227
228 }
229
231 {
232
233
234
235
236
237 if(fParaflag) {
243 {
244
245
246
247
248
249
250 G4GeometryCell postCell(*(fGhostPostStepPoint->GetPhysicalVolume()),
251 fGhostPostStepPoint->GetTouchable()->GetReplicaNumber());
252 G4Nsplit_Weight nw =
253 fWeightWindowAlgorithm.Calculate(aTrack.
GetWeight(),
254 fWeightWindowStore.GetLowerWeight(postCell,
256 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
257 }
258 } else {
264 {
265
267
270
271 G4Nsplit_Weight nw =
272 fWeightWindowAlgorithm.Calculate(aTrack.
GetWeight(),
273 fWeightWindowStore.GetLowerWeight(postCell,
275 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
276 }
277 }
278 }
279 return fParticleChange;
280}
G4StepStatus GetStepStatus() const
const G4VTouchable * GetTouchable() const
G4VPhysicalVolume * GetPhysicalVolume() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
virtual G4int GetReplicaNumber(G4int depth=0) const
G4double GetWeight() const
G4double GetKineticEnergy() const