55{
59 if(fDirection == 1)
60 {
62 {
63 thisStepPoint = preStepPoint;
64 }
65 else
66 {
67 return false;
68 }
69 }
70 else if(fDirection == 2)
71 {
73 {
74 thisStepPoint = postStepPoint;
75 }
76 else
77 {
78 return false;
79 }
80 }
81
83
84 if(divare || divcos)
85 {
89 if(physParam != nullptr)
90 {
95 }
96 else
97 {
99 }
100
101 if(divare)
102 {
104 }
105
106 if(divcos)
107 {
117 if(cosT != 0.)
118 flux /= std::abs(cosT);
119 }
120 }
121
123 EvtMap->
add(index, flux);
124
126 {
128 if(filler == nullptr)
129 {
131 "G4PSVolumeFlux::ProcessHits",
"SCORER0123",
JustWarning,
132 "G4TScoreHistFiller is not instantiated!! Histogram is not filled.");
133 }
134 else
135 {
137 }
138 }
139
140 return true;
141}
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
G4VSolid * GetSolid() const
const G4AffineTransform & GetTopTransform() const
G4StepStatus GetStepStatus() const
const G4VTouchable * GetTouchable() const
const G4ThreeVector & GetPosition() const
const G4ThreeVector & GetMomentumDirection() const
const G4TouchableHandle & GetTouchableHandle() const
G4VPhysicalVolume * GetPhysicalVolume() const
G4double GetKineticEnergy() const
G4double GetWeight() const
G4StepPoint * GetPreStepPoint() const
G4StepPoint * GetPostStepPoint() const
virtual G4VSolid * ComputeSolid(const G4int, G4VPhysicalVolume *)
G4LogicalVolume * GetLogicalVolume() const
virtual G4VPVParameterisation * GetParameterisation() const =0
std::map< G4int, G4int > hitIDMap
virtual G4int GetIndex(G4Step *)
static G4VScoreHistFiller * Instance()
virtual void ComputeDimensions(G4VPVParameterisation *p, const G4int n, const G4VPhysicalVolume *pRep)
virtual G4ThreeVector SurfaceNormal(const G4ThreeVector &p) const =0
virtual G4double GetSurfaceArea()
size_t add(const G4int &key, U *&aHit) const
virtual const G4NavigationHistory * GetHistory() const