112{
114 G4double GamEner = aTrack.GetDynamicParticle()->GetTotalEnergy();
115 if (GamEner < 30. * eV || GamEner > 30. * keV)
117
119 G4cout << std::left << std::setw(12) << __FILE__ <<
" " << __FUNCTION__ <<
" line "
120 << std::right << std::setw(4) << __LINE__ << " GamEner=" << GamEner / keV
121 << " keV previousStepSize=" << previousStepSize
122 << " TrackLength=" << aTrack.GetTrackLength() << " StepLength=" << aTrack.GetStepLength()
124
126 G4VPhysicalVolume* Volume = aTrack.GetVolume();
127 if (fLastVolume && Volume != fLastVolume && aTrack.GetTrackLength() > 0) {
128 const G4Material* theLastMat = fLastVolume->GetLogicalVolume()->GetMaterial();
130
133 if (density > last_density) {
134 G4Navigator* theNavigator =
139 if (valid) fSurfaceNormal = theSurfaceNormal;
141 aTrack.GetDynamicParticle()->GetMomentumDirection() * fSurfaceNormal;
143 MeanFreePath = 0;
144 }
146 const G4VSolid* LastSolid_Volume = fLastVolume->GetLogicalVolume()->GetSolid();
148 G4cout << std::left << std::setw(12) << __FILE__ <<
" " << __FUNCTION__ <<
" line "
149 << std::right << std::setw(4) << __LINE__
150 << " trigger reflection SinIncidentAngle=" << SinIncidentAngle
153 G4cout << std::left << std::setw(12) << __FILE__ <<
" " << __FUNCTION__ <<
" line "
154 << std::right << std::setw(4) << __LINE__ << " volume has changed "
155 << " last logical volume name =" << fLastVolume->GetLogicalVolume()->GetName()
156 <<
" last logical volume material name =" << theLastMat->
GetName()
157 << " last density=" << last_density << " part/cm3 ? "
159 <<
" logical volume material name =" << theMat->
GetName() <<
" density=" << density
160 << " part/cm3 ? "
161 <<
" LastSolid_Volume->Inside(Position)=" << LastSolid_Volume->
Inside(Position)
162 << " sin(IncidentAngle)=" << SinIncidentAngle << " MeanFreePath=" << MeanFreePath
164 }
165 }
166 fLastVolume = Volume;
167 return MeanFreePath;
168}
G4double condition(const G4ErrorSymMatrix &m)
CLHEP::Hep3Vector G4ThreeVector
G4Material * GetMaterial() const
const G4String & GetName() const
G4double GetDensity() const
const G4String & GetName() const
virtual G4ThreeVector GetGlobalExitNormal(const G4ThreeVector &point, G4bool *valid)
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
G4LogicalVolume * GetLogicalVolume() const
virtual EInside Inside(const G4ThreeVector &p) const =0
G4double Reflectivity(const G4double GamEner, const G4double SinIncidentAngle, const G4Material *theMat) const