Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // >> 26 // >> 27 // $Id: G4VIntersectionLocator.hh 93289 2015-10-15 10:01:15Z gcosmo $ >> 28 // >> 29 // 26 // Class G4VIntersectionLocator 30 // Class G4VIntersectionLocator 27 // 31 // 28 // class description: 32 // class description: 29 // 33 // 30 // Base class for the calculation of the inter 34 // Base class for the calculation of the intersection point with a boundary 31 // when PropagationInField is used. 35 // when PropagationInField is used. 32 // Gives possibility to choose the method of i 36 // Gives possibility to choose the method of intersection; concrete locators 33 // implemented are: G4SimpleLocator, G4MultiLe 37 // implemented are: G4SimpleLocator, G4MultiLevelLocator, G4BrentLocator. 34 // 38 // 35 // Key Method: EstimateIntersectionPoint() 39 // Key Method: EstimateIntersectionPoint() 36 40 >> 41 // History: >> 42 // ------- 37 // 27.10.08 - John Apostolakis, Tatiana Nikiti 43 // 27.10.08 - John Apostolakis, Tatiana Nikitina: Design and implementation 38 // ------------------------------------------- 44 // --------------------------------------------------------------------------- >> 45 39 #ifndef G4VINTERSECTIONLOCATOR_HH 46 #ifndef G4VINTERSECTIONLOCATOR_HH 40 #define G4VINTERSECTIONLOCATOR_HH 47 #define G4VINTERSECTIONLOCATOR_HH 41 48 42 #include "G4Types.hh" 49 #include "G4Types.hh" 43 #include "G4ThreeVector.hh" 50 #include "G4ThreeVector.hh" 44 #include "G4FieldTrack.hh" 51 #include "G4FieldTrack.hh" 45 52 46 #include "G4Navigator.hh" 53 #include "G4Navigator.hh" 47 #include "G4ChordFinder.hh" 54 #include "G4ChordFinder.hh" 48 55 49 class G4VIntersectionLocator 56 class G4VIntersectionLocator 50 { 57 { 51 public: // with description 58 public: // with description 52 59 53 G4VIntersectionLocator(G4Navigator *theNa 60 G4VIntersectionLocator(G4Navigator *theNavigator); 54 // Constructor 61 // Constructor 55 virtual ~G4VIntersectionLocator(); 62 virtual ~G4VIntersectionLocator(); 56 // Default destructor 63 // Default destructor 57 64 58 virtual G4bool EstimateIntersectionPoint( 65 virtual G4bool EstimateIntersectionPoint( 59 const G4FieldTrack& curveStartP << 66 const G4FieldTrack& curveStartPointTangent, // A 60 const G4FieldTrack& curveEndPoi << 67 const G4FieldTrack& curveEndPointTangent, // B 61 const G4ThreeVector& trialPoint, << 68 const G4ThreeVector& trialPoint, // E 62 G4FieldTrack& intersectPo << 69 G4FieldTrack& intersectPointTangent, // Output 63 G4bool& recalculate << 70 G4bool& recalculatedEndPoint, // Out 64 G4double& fPreviousSa << 71 G4double& fPreviousSafety, // In/Out 65 G4ThreeVector& fPreviousSf << 72 G4ThreeVector& fPreviousSftOrigin) = 0; // In/Out 66 // If such an intersection exists, this 73 // If such an intersection exists, this function calculates the 67 // intersection point of the true path 74 // intersection point of the true path of the particle with the surface 68 // of the current volume (or of one of 75 // of the current volume (or of one of its daughters). 69 // Should use lateral displacement as m 76 // Should use lateral displacement as measure of convergence 70 // NOTE: changes the safety! 77 // NOTE: changes the safety! 71 78 72 void printStatus( const G4FieldTrack& sta 79 void printStatus( const G4FieldTrack& startFT, 73 const G4FieldTrack& cur 80 const G4FieldTrack& currentFT, 74 G4double req 81 G4double requestStep, 75 G4double saf 82 G4double safety, 76 G4int ste 83 G4int stepNum); 77 // Print Method, useful mostly for debu 84 // Print Method, useful mostly for debugging 78 85 79 inline G4bool IntersectChord( const G4Thr 86 inline G4bool IntersectChord( const G4ThreeVector& StartPointA, 80 const G4Thr 87 const G4ThreeVector& EndPointB, 81 G4double& << 88 G4double &NewSafety, 82 G4double& << 89 G4double &PreviousSafety, // In/Out 83 G4ThreeVect << 90 G4ThreeVector &PreviousSftOrigin, // In/Out 84 G4double& << 91 G4double &LinearStepLength, 85 G4ThreeVect << 92 G4ThreeVector &IntersectionPoint, 86 G4bool* << 93 G4bool *calledNavigator=0 ); 87 // Intersect the chord from StartPointA 94 // Intersect the chord from StartPointA to EndPointB and return 88 // whether an intersection occurred. NO 95 // whether an intersection occurred. NOTE: changes the Safety! 89 96 90 inline void SetEpsilonStepFor( G4double E << 97 inline void SetEpsilonStepFor( G4double EpsilonStep ); 91 inline void SetDeltaIntersectionFor( G4do << 98 inline void SetDeltaIntersectionFor( G4double deltaIntersection ); 92 inline void SetNavigatorFor( G4Navigator* << 99 inline void SetNavigatorFor( G4Navigator *fNavigator ); 93 inline void SetChordFinderFor(G4ChordFind << 100 inline void SetChordFinderFor(G4ChordFinder *fCFinder ); 94 // These parameters must be set at each 101 // These parameters must be set at each step, in case they were changed >> 102 95 // Note: This simple approach ensures t 103 // Note: This simple approach ensures that all scenarios are considered. 96 // Future refinement may identify << 104 // [ Future refinement may identify which are invariant during a 97 // track, run or event << 105 // track, run or event ] 98 106 99 inline void SetVerboseFor(G4int fVerbose << 107 inline void SetVerboseFor(G4int fVerbose); 100 inline G4int GetVerboseFor(); << 108 inline G4int GetVerboseFor(); 101 // Controling verbosity enables checkin 109 // Controling verbosity enables checking of the locating of intersections 102 110 103 public: // without description 111 public: // without description 104 112 105 // Additional inline Set/Get methods for p 113 // Additional inline Set/Get methods for parameters, dependent objects 106 114 107 inline G4double GetDeltaIntersection 115 inline G4double GetDeltaIntersectionFor(); 108 inline G4double GetEpsilonStepFor(); 116 inline G4double GetEpsilonStepFor(); 109 inline G4Navigator* GetNavigatorFor(); 117 inline G4Navigator* GetNavigatorFor(); 110 inline G4ChordFinder* GetChordFinderFor(); 118 inline G4ChordFinder* GetChordFinderFor(); 111 119 112 inline void SetSafetyParametersFor(G4bool << 120 inline void SetSafetyParametersFor(G4bool UseSafety ); 113 121 114 inline void AddAdjustementOfFoundIntersect << 122 inline void AddAdjustementOfFoundIntersection(G4bool UseCorrection); 115 inline G4bool GetAdjustementOfFoundInterse 123 inline G4bool GetAdjustementOfFoundIntersection(); 116 // Methods to be made Obsolete - replace 124 // Methods to be made Obsolete - replaced by methods below 117 inline void AdjustIntersections(G4bool Use << 125 inline void AdjustIntersections(G4bool UseCorrection); 118 inline G4bool AreIntersectionsAdjusted(){ 126 inline G4bool AreIntersectionsAdjusted(){ return fUseNormalCorrection; } 119 // Change adjustment flag ( New Interfa 127 // Change adjustment flag ( New Interface ) 120 128 121 static void printStatus( const G4FieldTrac 129 static void printStatus( const G4FieldTrack& startFT, 122 const G4FieldTrac 130 const G4FieldTrack& currentFT, 123 G4double 131 G4double requestStep, 124 G4double 132 G4double safety, 125 G4int 133 G4int stepNum, 126 std::ostrea 134 std::ostream& oss, 127 G4int 135 G4int verboseLevel ); 128 // Print Method for any ostream - e.g. c 136 // Print Method for any ostream - e.g. cerr -- and for G4Exception 129 << 137 130 inline void SetCheckMode( G4bool value ) { << 131 inline G4bool GetCheckMode() { << 132 << 133 protected: // with description 138 protected: // with description 134 139 135 G4FieldTrack ReEstimateEndpoint( const G4F << 140 G4FieldTrack ReEstimateEndpoint( const G4FieldTrack &CurrentStateA, 136 const G4F << 141 const G4FieldTrack &EstimtdEndStateB, 137 G4d 142 G4double linearDistSq, // not used 138 G4d 143 G4double curveDist ); // not used 139 // Return new estimate for state after c 144 // Return new estimate for state after curveDist starting from 140 // CurrentStateA, to replace EstimtdEndS 145 // CurrentStateA, to replace EstimtdEndStateB, and report displacement 141 // (if field is compiled verbose) 146 // (if field is compiled verbose) 142 147 143 G4bool CheckAndReEstimateEndpoint( const G 148 G4bool CheckAndReEstimateEndpoint( const G4FieldTrack& CurrentStartA, 144 const G 149 const G4FieldTrack& EstimatedEndB, 145 G 150 G4FieldTrack& RevisedEndPoint, 146 G 151 G4int & errorCode); 147 // Check whether EndB is too far from St 152 // Check whether EndB is too far from StartA to be reached 148 // and if, re-estimate new value for End 153 // and if, re-estimate new value for EndB (return in RevisedEndPoint) 149 // Report error if EndB is before Start 154 // Report error if EndB is before StartA (in curve length) 150 // In that case return errorCode = 2. 155 // In that case return errorCode = 2. 151 156 152 G4ThreeVector GetSurfaceNormal(const G4Thr << 157 G4ThreeVector GetSurfaceNormal(const G4ThreeVector &CurrentInt_Point, 153 G4boo << 158 G4bool &validNormal); // const 154 // Position *must* be the intersection p 159 // Position *must* be the intersection point from last call 155 // to G4Navigator's ComputeStep (via In 160 // to G4Navigator's ComputeStep (via IntersectChord ) 156 // Will try to use cached (last) value i 161 // Will try to use cached (last) value in Navigator for speed, 157 // if it was kept and valid. 162 // if it was kept and valid. 158 // Value returned is in global coordinat 163 // Value returned is in global coordinates. 159 // It does NOT guarantee to obtain Norma 164 // It does NOT guarantee to obtain Normal. This can happen eg if: 160 // - the "Intersection" Point is not on 165 // - the "Intersection" Point is not on a surface, potentially due to 161 // - inaccuracies in the transformation 166 // - inaccuracies in the transformations used, or 162 // - issues with the Solid. 167 // - issues with the Solid. 163 168 164 G4ThreeVector GetGlobalSurfaceNormal(const << 169 G4ThreeVector GetGlobalSurfaceNormal(const G4ThreeVector &CurrentE_Point, 165 << 170 G4bool &validNormal); 166 // Return the SurfaceNormal of Intersect 171 // Return the SurfaceNormal of Intersecting Solid in global coordinates 167 // Costlier then GetSurfaceNormal 172 // Costlier then GetSurfaceNormal 168 173 169 G4bool AdjustmentOfFoundIntersection(const << 174 G4bool AdjustmentOfFoundIntersection(const G4ThreeVector &A, 170 const << 175 const G4ThreeVector &CurrentE_Point, 171 const << 176 const G4ThreeVector &CurrentF_Point, 172 const << 177 const G4ThreeVector &MomentumDir, 173 const 178 const G4bool IntersectAF, 174 << 179 G4ThreeVector &IntersectionPoint, 175 << 180 G4double &NewSafety, 176 << 181 G4double &fPrevSafety, 177 << 182 G4ThreeVector &fPrevSftOrigin ); 178 // Optional method for adjustment of loc 183 // Optional method for adjustment of located intersection point 179 // using the surface-normal 184 // using the surface-normal 180 185 181 void ReportTrialStep( G4int step_no, 186 void ReportTrialStep( G4int step_no, 182 const G4ThreeVector& 187 const G4ThreeVector& ChordAB_v, 183 const G4ThreeVector& 188 const G4ThreeVector& ChordEF_v, 184 const G4ThreeVector& 189 const G4ThreeVector& NewMomentumDir, 185 const G4ThreeVector& 190 const G4ThreeVector& NormalAtEntry, 186 G4bool validNormal 191 G4bool validNormal ); 187 // Print a three-line report on the curr 192 // Print a three-line report on the current "sub-step", ie trial 188 // intersection 193 // intersection 189 194 190 G4bool LocateGlobalPointWithinVolumeAndChe 195 G4bool LocateGlobalPointWithinVolumeAndCheck( const G4ThreeVector& pos ); 191 // Locate point using navigator - update 196 // Locate point using navigator - updates state of Navigator. 192 // By default, it assumes that the point 197 // By default, it assumes that the point is inside the current volume, 193 // and returns true. 198 // and returns true. 194 // In check mode, checks whether the poi 199 // In check mode, checks whether the point is *inside* the volume. 195 // If it is inside, it returns true. 200 // If it is inside, it returns true. 196 // If not, issues a warning and return 201 // If not, issues a warning and returns false. 197 202 198 void LocateGlobalPointWithinVolumeCheckAnd 203 void LocateGlobalPointWithinVolumeCheckAndReport( const G4ThreeVector& pos, 199 co 204 const G4String& CodeLocationInfo, 200 205 G4int CheckMode ); 201 // As above, but report information abou 206 // As above, but report information about code location. 202 // If CheckMode > 1, report extra inform 207 // If CheckMode > 1, report extra information. >> 208 >> 209 inline void SetCheckMode( G4bool value ) { fCheckMode = value; } >> 210 inline G4bool GetCheckMode() { return fCheckMode; } 203 211 204 protected: // without description 212 protected: // without description 205 213 206 // Auxiliary methods -- to report issues 214 // Auxiliary methods -- to report issues 207 215 208 void ReportReversedPoints( std::ostringstr 216 void ReportReversedPoints( std::ostringstream& ossMsg, 209 const G4FieldTr 217 const G4FieldTrack& StartPointVel, 210 const G4FieldTr 218 const G4FieldTrack& EndPointVel, 211 G4double 219 G4double NewSafety, G4double epsStep, 212 const G4FieldTr 220 const G4FieldTrack& CurrentA_PointVelocity, 213 const G4FieldTr 221 const G4FieldTrack& CurrentB_PointVelocity, 214 const G4FieldTr 222 const G4FieldTrack& SubStart_PointVelocity, 215 const G4ThreeVe 223 const G4ThreeVector& CurrentE_Point, 216 const G4FieldTr 224 const G4FieldTrack& ApproxIntersecPointV, 217 G4int sbstp_no, 225 G4int sbstp_no, G4int sbstp_no_p, G4int depth ); 218 // Build error messsage (in ossMsg) to r 226 // Build error messsage (in ossMsg) to report that point 'B' has 219 // gone past 'A' 227 // gone past 'A' 220 228 221 void ReportProgress( std::ostream& oss, 229 void ReportProgress( std::ostream& oss, 222 const G4FieldTrack& S 230 const G4FieldTrack& StartPointVel, 223 const G4FieldTrack& E 231 const G4FieldTrack& EndPointVel, 224 G4int s 232 G4int substep_no, 225 const G4FieldTrack& A 233 const G4FieldTrack& A_PtVel, // G4double safetyA 226 const G4FieldTrack& B 234 const G4FieldTrack& B_PtVel, 227 G4double s 235 G4double safetyLast, 228 G4int d 236 G4int depth= -1 ); 229 // Report the current status / progress 237 // Report the current status / progress in finding the first intersection 230 238 231 void ReportImmediateHit( const char* 239 void ReportImmediateHit( const char* MethodName, 232 const G4ThreeVec 240 const G4ThreeVector& StartPosition, 233 const G4ThreeVec 241 const G4ThreeVector& TrialPoint, 234 G4double << 242 double tolerance, 235 unsigned long 243 unsigned long int numCalls ); 236 // Report case: trial point is 'close' t 244 // Report case: trial point is 'close' to start, within tolerance 237 245 238 private: // no description 246 private: // no description 239 247 240 G4ThreeVector GetLocalSurfaceNormal(const << 248 G4ThreeVector GetLocalSurfaceNormal(const G4ThreeVector &CurrentE_Point, 241 << 249 G4bool &validNormal); 242 // Return the SurfaceNormal of Intersect 250 // Return the SurfaceNormal of Intersecting Solid in local coordinates 243 251 244 G4ThreeVector GetLastSurfaceNormal( const 252 G4ThreeVector GetLastSurfaceNormal( const G4ThreeVector& intersectPoint, 245 << 253 G4bool &validNormal) const; 246 // Position *must* be the intersection p 254 // Position *must* be the intersection point from last call 247 // to G4Navigator's ComputeStep (via In 255 // to G4Navigator's ComputeStep (via IntersectChord ) 248 // Temporary - will use the same method 256 // Temporary - will use the same method in the Navigator 249 257 250 protected: 258 protected: 251 259 252 G4double kCarTolerance; / << 260 G4double kCarTolerance; // Constant 253 261 254 G4int fVerboseLevel = 0; / << 262 G4int fVerboseLevel; // For debugging 255 G4bool fUseNormalCorrection = false; / << 263 G4bool fUseNormalCorrection; // Configuration parameter 256 G4bool fCheckMode = false; << 264 G4bool fCheckMode; 257 G4bool fiUseSafety = false; // Whethe << 258 265 259 G4Navigator* fiNavigator; << 266 G4Navigator *fiNavigator; 260 267 261 G4ChordFinder* fiChordFinder = nullptr; / << 268 G4ChordFinder *fiChordFinder; 262 G4double fiEpsilonStep = -1.0; / << 269 G4double fiEpsilonStep; 263 G4double fiDeltaIntersection = -1.0; / << 270 G4double fiDeltaIntersection; >> 271 G4bool fiUseSafety; 264 // Parameters set at each physical step 272 // Parameters set at each physical step by calling method 265 // by G4PropagatorInField 273 // by G4PropagatorInField 266 274 267 G4Navigator *fHelpingNavigator; 275 G4Navigator *fHelpingNavigator; 268 // Helper for location 276 // Helper for location 269 277 270 G4TouchableHistory *fpTouchable = nullptr; << 278 G4TouchableHistory *fpTouchable; 271 // Touchable history hook 279 // Touchable history hook 272 }; 280 }; 273 281 274 #include "G4VIntersectionLocator.icc" 282 #include "G4VIntersectionLocator.icc" 275 283 276 #endif 284 #endif 277 285