46{
48
50 pCurrentProposedStepLength,
51 safetyGeom);
52
53 G4ErrorPropagatorData* g4edata
55
56 if ( g4edata != nullptr )
57 {
58 const G4ErrorTarget* target = g4edata->
GetTarget();
59 if( target != nullptr )
60 {
62
63 if( StepPlane < 0. )
64 {
66 }
67#ifdef G4VERBOSE
69 {
70 G4cout <<
"G4ErrorPropagationNavigator::ComputeStep()" <<
G4endl
71 << " Target step: " << StepPlane
72 <<
", Transportation step: " << Step <<
G4endl;
73 target->
Dump(
"G4ErrorPropagationNavigator::ComputeStep Target " );
74 }
75#endif
76
77 if( StepPlane < Step )
78 {
79#ifdef G4VERBOSE
81 {
82 G4cout <<
"G4ErrorPropagationNavigator::ComputeStep()" <<
G4endl
83 << " TargetCloserThanBoundary: " << StepPlane << " < "
85 }
86#endif
87 Step = StepPlane;
89 }
90 else
91 {
93 }
94 }
95 }
97
98
99
100 pNewSafety = std::min(safetyGeom, safetyTarget);
101
102#ifdef G4VERBOSE
104 {
105 G4cout <<
"G4ErrorPropagationNavigator::ComputeStep()" <<
G4endl
106 << " Step: " << Step << ", ComputeSafety: " << pNewSafety
108 }
109#endif
110
111 return Step;
112}
@ G4ErrorState_TargetCloserThanBoundary
@ G4ErrorState_Propagating
G4GLOB_DLL std::ostream G4cout
static G4ErrorPropagatorData * GetErrorPropagatorData()
const G4ErrorTarget * GetTarget(G4bool mustExist=false) const
void SetState(G4ErrorState sta)
virtual void Dump(const G4String &msg) const =0
virtual G4double GetDistanceFromPoint(const G4ThreeVector &, const G4ThreeVector &) const
virtual G4double ComputeStep(const G4ThreeVector &pGlobalPoint, const G4ThreeVector &pDirection, const G4double pCurrentProposedStepLength, G4double &pNewSafety)