172{
173 fParticleChange->Initialize(aTrack);
174
176 {
177 return fParticleChange;
178 }
179
180 if(fParaflag)
181 {
182 fOldGhostTouchable = fGhostPostStepPoint->GetTouchableHandle();
183
184 CopyStep(aStep);
185
186 if(fOnBoundary)
187 {
188
189
190
191
192
193 fNewGhostTouchable = fPathFinder->CreateTouchableHandle(fNavigatorID);
194 }
195 else
196 {
197
198 fNewGhostTouchable = fOldGhostTouchable;
199 }
200
201 fGhostPreStepPoint->SetTouchableHandle(fOldGhostTouchable);
202 fGhostPostStepPoint->SetTouchableHandle(fNewGhostTouchable);
203
206 {
208 {
209 G4cout <<
"WARNING - G4ImportanceProcess::PostStepDoIt()"
210 <<
" StopAndKill track. on boundary" <<
G4endl;
211 }
212
213 G4GeometryCell prekey(*(fGhostPreStepPoint->GetPhysicalVolume()),
214 fGhostPreStepPoint->GetTouchable()->GetReplicaNumber());
215 G4GeometryCell postkey(*(fGhostPostStepPoint->GetPhysicalVolume()),
216 fGhostPostStepPoint->GetTouchable()->GetReplicaNumber());
217
218 G4Nsplit_Weight nw =
219 fImportanceAlgorithm.Calculate(fIStore.GetImportance(prekey),
220 fIStore.GetImportance(postkey),
222 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
223 }
224 }
225 else
226 {
229 {
231 {
232 G4cout <<
"WARNING - G4ImportanceProcess::PostStepDoIt()"
233 << " StopAndKill track. on boundary non-parallel"
235 }
236
239
244
245 G4Nsplit_Weight nw =
246 fImportanceAlgorithm.Calculate(fIStore.GetImportance(prekey),
247 fIStore.GetImportance(postkey),
249 fPostStepAction->DoIt(aTrack, fParticleChange, nw);
250 }
251 }
252 return fParticleChange;
253}
G4StepStatus GetStepStatus() const
const G4VTouchable * GetTouchable() const
G4VPhysicalVolume * GetPhysicalVolume() const
G4StepPoint * GetPreStepPoint() const
G4double GetStepLength() const
G4StepPoint * GetPostStepPoint() const
virtual G4int GetReplicaNumber(G4int depth=0) const
G4TrackStatus GetTrackStatus() const
G4VPhysicalVolume * GetNextVolume() const
G4double GetWeight() const