54 fSplitPreStepPoint = fSplitStep->GetPreStepPoint();
55 fSplitPostStepPoint = fSplitStep->GetPostStepPoint();
69 delete fpEnergySplitter;
84 fSplitPreStepPoint->SetTouchableHandle(fOldTouchableH);
85 fNewTouchableH = fOldTouchableH;
87 fSplitPostStepPoint->SetTouchableHandle(fNewTouchableH);
91 fSplitPostStepPoint->SetStepStatus(
fUndefined);
135 G4ThreeVector preStepPosition, postStepPosition, direction, finalPostStepPosition;
142 fSplitPreStepPoint->SetSensitiveDetector(ptrSD);
143 fOldTouchableH = fInitialTouchableH;
144 fNewTouchableH = fOldTouchableH;
149 G4int numberVoxelsInStep = fpEnergySplitter->SplitEnergyInVolumes(&step);
153 direction = (finalPostStepPosition - preStepPosition).unit();
157 postStepPosition = preStepPosition;
160 for (iStep = 0; iStep < numberVoxelsInStep; iStep++) {
162 G4double stepLength = 0.0, energyLoss = 0.0;
164 *fSplitPreStepPoint = *fSplitPostStepPoint;
165 fOldTouchableH = fNewTouchableH;
167 preStepPosition = postStepPosition;
168 fSplitPreStepPoint->SetPosition(preStepPosition);
169 fSplitPreStepPoint->SetTouchableHandle(fOldTouchableH);
171 fpEnergySplitter->GetLengthAndEnergyDeposited(iStep, idVoxel, stepLength, energyLoss);
174 pLogicalVolume->
SetMaterial(fpEnergySplitter->GetVoxelMaterial(iStep));
176 postStepPosition = preStepPosition + stepLength * direction;
177 fSplitPostStepPoint->SetPosition(postStepPosition);
180 fSplitStep->SetStepLength(stepLength);
181 fSplitStep->SetTotalEnergyDeposit(energyLoss);
182 if (iStep < numberVoxelsInStep - 1) {
183 fSplitStep->GetPostStepPoint()->SetStepStatus(
fGeomBoundary);
184 G4int nextVoxelId = -1;
185 fpEnergySplitter->GetVoxelID(iStep + 1, nextVoxelId);
188 G4VTouchable* fNewTouchablePtr = CreateTouchableForSubStep(nextVoxelId, postStepPosition);
190 fSplitPostStepPoint->SetTouchableHandle(fNewTouchableH);
193 fSplitStep->GetPostStepPoint()->SetStepStatus(fullStepStatus);
194 fSplitPostStepPoint->SetTouchableHandle(fFinalTouchableH);
199 eLossFraction = (totalEnergyDeposit > 0.0) ? energyLoss / totalEnergyDeposit : 1.0;
202 fSplitPostStepPoint->SetSensitiveDetector(ptrSD);
205 ptrSD->
Hit(fSplitStep);
228 EVolume curVolumeType = ptrNavHistory->GetTopVolumeType();
230 ptrNavHistory->BackLevel();
239 ptrNavHistory->NewLevel(curPhysicalVol,
kParameterised, newVoxelNum);
242 G4cout <<
" Current volume type is not Parameterised. " <<
G4endl;
244 "G4ScoreSplittingProcess::CreateTouchableForSubStep",
"ErrorRegularParamaterisation",
246 "Score Splitting Process is used for Regular Structure - but did not find one here.");
248 return ptrTouchableHistory;
251void G4ScoreSplittingProcess::CopyStepStart(
const G4Step& step)
253 fSplitStep->SetTrack(step.
GetTrack());
267 G4cout <<
"In mass geometry ------------------------------------------------" <<
G4endl;
275 G4cout <<
"NoProcessAssigned";
279 G4cout <<
" PostStepPoint : ";
291 G4cout <<
"NoProcessAssigned";
296 G4cout <<
"In ghost geometry ------------------------------------------------" <<
G4endl;
297 G4cout <<
" StepLength : " << fSplitStep->GetStepLength() / mm
298 <<
" TotalEnergyDeposit : " << fSplitStep->GetTotalEnergyDeposit() / MeV <<
G4endl;
299 G4cout <<
" PreStepPoint : " << fSplitStep->GetPreStepPoint()->GetPhysicalVolume()->GetName()
300 <<
" [" << fSplitStep->GetPreStepPoint()->GetTouchable()->GetReplicaNumber() <<
" ]"
302 if (fSplitStep->GetPreStepPoint()->GetProcessDefinedStep() !=
nullptr) {
303 G4cout << fSplitStep->GetPreStepPoint()->GetProcessDefinedStep()->GetProcessName();
306 G4cout <<
"NoProcessAssigned";
309 G4cout <<
" " << fSplitStep->GetPreStepPoint()->GetPosition() <<
G4endl;
310 G4cout <<
" PostStepPoint : ";
311 if (fSplitStep->GetPostStepPoint()->GetPhysicalVolume() !=
nullptr) {
312 G4cout << fSplitStep->GetPostStepPoint()->GetPhysicalVolume()->GetName() <<
" ["
313 << fSplitStep->GetPostStepPoint()->GetTouchable()->GetReplicaNumber() <<
" ]";
319 if (fSplitStep->GetPostStepPoint()->GetProcessDefinedStep() !=
nullptr) {
320 G4cout << fSplitStep->GetPostStepPoint()->GetProcessDefinedStep()->GetProcessName();
323 G4cout <<
"NoProcessAssigned";
326 G4cout <<
" " << fSplitStep->GetPostStepPoint()->GetPosition()
327 <<
" == " << fSplitStep->GetTrack()->GetMomentumDirection() <<
G4endl;
365 return &dummyParticleChange;
G4double condition(const G4ErrorSymMatrix &m)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
@ NotCandidateForSelection
CLHEP::Hep3Vector G4ThreeVector
G4ReferenceCountedHandle< G4VTouchable > G4TouchableHandle
G4TouchableHistory G4VTouchable
G4GLOB_DLL std::ostream G4cout
G4VSensitiveDetector * GetSensitiveDetector() const
void SetMaterial(G4Material *pMaterial)
G4TouchableHistory * CreateTouchableHistory() const
static G4RegularNavigationHelper * Instance()
G4double AlongStepGetPhysicalInteractionLength(const G4Track &, G4double, G4double, G4double &, G4GPILSelection *) override
void StartTracking(G4Track *) override
G4VParticleChange * AlongStepDoIt(const G4Track &, const G4Step &) override
void Verbose(const G4Step &) const
~G4ScoreSplittingProcess() override
G4double AtRestGetPhysicalInteractionLength(const G4Track &, G4ForceCondition *) override
G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &) override
G4double PostStepGetPhysicalInteractionLength(const G4Track &track, G4double previousStepSize, G4ForceCondition *condition) override
G4ScoreSplittingProcess(const G4String &processName="ScoreSplittingProc", G4ProcessType theType=fParameterisation)
G4VParticleChange * AtRestDoIt(const G4Track &, const G4Step &) override
G4StepStatus GetStepStatus() const
const G4VProcess * GetProcessDefinedStep() const
const G4ThreeVector & GetPosition() const
G4VPhysicalVolume * GetPhysicalVolume() const
G4SteppingControl GetControlFlag() const
G4Track * GetTrack() const
G4StepPoint * GetPreStepPoint() const
G4double GetNonIonizingEnergyDeposit() const
G4double GetStepLength() const
G4double GetTotalEnergyDeposit() const
G4StepPoint * GetPostStepPoint() const
virtual const G4NavigationHistory * GetHistory() const
G4VPhysicalVolume * GetVolume() const
const G4TouchableHandle & GetNextTouchableHandle() const
const G4TouchableHandle & GetTouchableHandle() const
const G4Step * GetStep() const
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
virtual G4VSolid * ComputeSolid(const G4int, G4VPhysicalVolume *)
virtual void ComputeTransformation(const G4int, G4VPhysicalVolume *) const =0
virtual void Initialize(const G4Track &)
virtual G4bool IsRegularStructure() const =0
G4LogicalVolume * GetLogicalVolume() const
const G4String & GetName() const
virtual G4VPVParameterisation * GetParameterisation() const =0
G4VProcess(const G4String &aName="NoName", G4ProcessType aType=fNotDefined)
G4VParticleChange * pParticleChange
const G4String & GetProcessName() const
G4bool Hit(G4Step *aStep)
virtual void ComputeDimensions(G4VPVParameterisation *p, const G4int n, const G4VPhysicalVolume *pRep)